diff --git a/css/845.6548e7b4.css b/css/226.6548e7b4.css similarity index 100% rename from css/845.6548e7b4.css rename to css/226.6548e7b4.css diff --git a/css/845.6548e7b4.css.gz b/css/226.6548e7b4.css.gz similarity index 100% rename from css/845.6548e7b4.css.gz rename to css/226.6548e7b4.css.gz diff --git a/css/226.a32a5829.css b/css/407.a32a5829.css similarity index 100% rename from css/226.a32a5829.css rename to css/407.a32a5829.css diff --git a/css/226.a32a5829.css.gz b/css/407.a32a5829.css.gz similarity index 100% rename from css/226.a32a5829.css.gz rename to css/407.a32a5829.css.gz diff --git a/css/488.085a2879.css.gz b/css/488.085a2879.css.gz deleted file mode 100644 index 35488d8..0000000 Binary files a/css/488.085a2879.css.gz and /dev/null differ diff --git a/css/488.085a2879.css b/css/743.ab3d1775.css similarity index 77% rename from css/488.085a2879.css rename to css/743.ab3d1775.css index 328f379..cdd4940 100644 --- a/css/488.085a2879.css +++ b/css/743.ab3d1775.css @@ -1 +1 @@ -.mobile-drawer-overlay[data-v-2d8e83ec]{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.4);z-index:2000;backdrop-filter:blur(4px)}.mobile-drawer[data-v-2d8e83ec]{position:absolute;top:22vh;left:8px;bottom:8px;width:280px;max-width:calc(85vw - 16px);background:var(--el-bg-color);border-radius:16px;box-shadow:0 8px 32px rgba(0,0,0,.2),0 2px 8px rgba(0,0,0,.1);display:flex;flex-direction:column;overflow:hidden}html.dark .mobile-drawer[data-v-2d8e83ec]{background:rgba(40,40,45,.98);box-shadow:0 8px 32px rgba(0,0,0,.4),0 2px 8px rgba(0,0,0,.3)}.mobile-drawer-header[data-v-2d8e83ec]{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:linear-gradient(135deg,rgba(56,189,248,.12),rgba(14,165,233,.08));border-bottom:1px solid var(--el-border-color-lighter)}.mobile-drawer-title[data-v-2d8e83ec]{font-size:15px;font-weight:600;color:#38bdf8;display:flex;align-items:center;gap:8px}.mobile-drawer-title[data-v-2d8e83ec]:before{content:"";display:inline-block;width:4px;height:16px;background:linear-gradient(180deg,#38bdf8,rgba(14,165,233,.5));border-radius:2px}.mobile-drawer-close[data-v-2d8e83ec]{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--el-text-color-secondary);cursor:pointer;border-radius:8px;transition:all .2s ease;background:transparent}.mobile-drawer-close[data-v-2d8e83ec]:active{background:var(--el-fill-color);color:var(--el-text-color-primary)}.mobile-drawer-content[data-v-2d8e83ec]{flex:1;overflow-y:auto;padding:8px}.mobile-drawer-item[data-v-2d8e83ec]{display:flex;align-items:center;gap:12px;padding:14px 16px;margin:2px 0;cursor:pointer;transition:all .2s ease;color:var(--el-text-color-primary);border-radius:10px;font-size:14px}.mobile-drawer-item[data-v-2d8e83ec]:active{background:var(--el-fill-color-light);transform:scale(.98)}.mobile-drawer-item.active[data-v-2d8e83ec]{background:linear-gradient(135deg,rgba(56,189,248,.2),rgba(14,165,233,.12));color:#38bdf8;font-weight:600}.mobile-drawer-item-icon[data-v-2d8e83ec]{font-size:18px;width:24px;text-align:center;opacity:.7}.mobile-drawer-item.active .mobile-drawer-item-icon[data-v-2d8e83ec]{opacity:1;color:#38bdf8}.mobile-drawer-back[data-v-2d8e83ec]{display:flex;align-items:center;gap:12px;padding:14px 16px;margin:8px 8px;border-radius:10px;background:var(--el-fill-color-lighter);cursor:pointer;transition:all .2s ease;color:var(--el-text-color-secondary);font-size:14px}.mobile-drawer-back[data-v-2d8e83ec]:active{background:var(--el-fill-color);color:var(--el-text-color-primary);transform:scale(.98)}.drawer-slide-enter-active[data-v-2d8e83ec]{transition:opacity .3s ease}.drawer-slide-leave-active[data-v-2d8e83ec]{transition:opacity .2s ease}.drawer-slide-enter-active .mobile-drawer[data-v-2d8e83ec]{animation:slideInLeft-2d8e83ec .3s ease-out}.drawer-slide-leave-active .mobile-drawer[data-v-2d8e83ec]{animation:slideOutLeft-2d8e83ec .2s ease-in}.drawer-slide-enter-from[data-v-2d8e83ec],.drawer-slide-leave-to[data-v-2d8e83ec]{opacity:0}@keyframes slideInLeft-2d8e83ec{0%{transform:translateX(-100%)}to{transform:translateX(0)}}@keyframes slideOutLeft-2d8e83ec{0%{transform:translateX(0)}to{transform:translateX(-100%)}}.bottom-sheet-overlay[data-v-7579ad69]{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:9999;display:flex;align-items:flex-end;justify-content:center}.bottom-sheet[data-v-7579ad69]{width:100%;max-width:100%;background:var(--bottom-sheet-bg,hsla(0,0%,100%,.95));backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:20px 20px 0 0;max-height:70vh;overflow:hidden;box-shadow:0 -4px 30px rgba(0,0,0,.15);border-top:1px solid var(--bottom-sheet-border,rgba(0,0,0,.05))}html.dark .bottom-sheet[data-v-7579ad69]{--bottom-sheet-bg:rgba(40,44,52,.95);--bottom-sheet-border:hsla(0,0%,100%,.1);box-shadow:0 -4px 30px rgba(0,0,0,.4)}.bottom-sheet-header[data-v-7579ad69]{display:flex;flex-direction:column;align-items:center;gap:12px;padding:16px 20px 12px;border-bottom:1px solid var(--el-border-color-lighter)}.bottom-sheet-handle[data-v-7579ad69]{width:40px;height:4px;background:var(--el-border-color);border-radius:2px}.bottom-sheet-title[data-v-7579ad69]{font-size:16px;font-weight:600;color:var(--el-text-color-primary);text-align:center;max-width:80%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}html.dark .bottom-sheet-title[data-v-7579ad69]{color:#f0f0f0}.bottom-sheet-content[data-v-7579ad69]{padding:12px 16px;padding-bottom:calc(20px + env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:8px}.bottom-sheet-item[data-v-7579ad69]{display:flex;align-items:center;gap:16px;padding:16px 20px;border-radius:14px;cursor:pointer;transition:all .2s ease;background:var(--bottom-sheet-item-bg,rgba(0,0,0,.04));color:var(--el-text-color-primary)}html.dark .bottom-sheet-item[data-v-7579ad69]{--bottom-sheet-item-bg:hsla(0,0%,100%,.08)}.bottom-sheet-item[data-v-7579ad69]:active{transform:scale(.98);background:var(--bottom-sheet-item-active-bg,rgba(0,0,0,.08))}html.dark .bottom-sheet-item[data-v-7579ad69]:active{--bottom-sheet-item-active-bg:hsla(0,0%,100%,.15)}.bottom-sheet-icon[data-v-7579ad69]{font-size:20px;width:28px;text-align:center;color:#38bdf8}.bottom-sheet-danger .bottom-sheet-icon[data-v-7579ad69],.bottom-sheet-danger[data-v-7579ad69]{color:var(--el-color-danger)}.bottom-sheet-enter-active[data-v-7579ad69]{transition:all .3s ease-out}.bottom-sheet-leave-active[data-v-7579ad69]{transition:all .2s ease-in}.bottom-sheet-enter-active .bottom-sheet[data-v-7579ad69]{animation:slideUp-7579ad69 .3s ease-out}.bottom-sheet-leave-active .bottom-sheet[data-v-7579ad69]{animation:slideDown-7579ad69 .2s ease-in}.bottom-sheet-enter-from[data-v-7579ad69],.bottom-sheet-leave-to[data-v-7579ad69]{opacity:0}.bottom-sheet-enter-from .bottom-sheet[data-v-7579ad69],.bottom-sheet-leave-to .bottom-sheet[data-v-7579ad69]{transform:translateY(100%)}@keyframes slideUp-7579ad69{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes slideDown-7579ad69{0%{transform:translateY(0)}to{transform:translateY(100%)}}:root{--el-popup-modal-bg-color:var(--el-color-black);--el-popup-modal-opacity:0.5}.v-modal-enter{animation:v-modal-in var(--el-transition-duration-fast) ease}.v-modal-leave{animation:v-modal-out var(--el-transition-duration-fast) ease forwards}@keyframes v-modal-in{0%{opacity:0}}@keyframes v-modal-out{to{opacity:0}}.v-modal{background:var(--el-popup-modal-bg-color);height:100%;left:0;opacity:var(--el-popup-modal-opacity);position:fixed;top:0;width:100%}.el-popup-parent--hidden{overflow:hidden}.el-dialog{--el-dialog-width:50%;--el-dialog-margin-top:15vh;--el-dialog-bg-color:var(--el-bg-color);--el-dialog-box-shadow:var(--el-box-shadow);--el-dialog-title-font-size:var(--el-font-size-large);--el-dialog-content-font-size:14px;--el-dialog-font-line-height:var(--el-font-line-height-primary);--el-dialog-padding-primary:16px;--el-dialog-border-radius:var(--el-border-radius-base);background:var(--el-dialog-bg-color);border-radius:var(--el-dialog-border-radius);box-shadow:var(--el-dialog-box-shadow);box-sizing:border-box;margin:var(--el-dialog-margin-top,15vh) auto 50px;overflow-wrap:break-word;padding:var(--el-dialog-padding-primary);position:relative;width:var(--el-dialog-width,50%)}.el-dialog:focus{outline:none!important}.el-dialog.is-align-center{margin:auto}.el-dialog.is-fullscreen{--el-dialog-width:100%;--el-dialog-margin-top:0;border-radius:0;height:100%;margin-bottom:0;overflow:auto}.el-dialog__wrapper{bottom:0;left:0;margin:0;overflow:auto;position:fixed;right:0;top:0}.el-dialog.is-draggable .el-dialog__header{cursor:move;-webkit-user-select:none;user-select:none}.el-dialog__header{padding-bottom:var(--el-dialog-padding-primary)}.el-dialog__header.show-close{padding-right:calc(var(--el-dialog-padding-primary) + var(--el-message-close-size, 16px))}.el-dialog__headerbtn{background:transparent;border:none;cursor:pointer;font-size:var(--el-message-close-size,16px);height:48px;outline:none;padding:0;position:absolute;right:0;top:0;width:48px}.el-dialog__headerbtn .el-dialog__close{color:var(--el-color-info);font-size:inherit}.el-dialog__headerbtn:focus .el-dialog__close,.el-dialog__headerbtn:hover .el-dialog__close{color:var(--el-color-primary)}.el-dialog__title{color:var(--el-text-color-primary);font-size:var(--el-dialog-title-font-size);line-height:var(--el-dialog-font-line-height)}.el-dialog__body{color:var(--el-text-color-regular);font-size:var(--el-dialog-content-font-size)}.el-dialog__footer{box-sizing:border-box;padding-top:var(--el-dialog-padding-primary);text-align:right}.el-dialog--center{text-align:center}.el-dialog--center .el-dialog__body{text-align:initial}.el-dialog--center .el-dialog__footer{text-align:inherit}.el-modal-dialog.is-penetrable{pointer-events:none}.el-modal-dialog.is-penetrable .el-dialog{pointer-events:auto}.el-overlay-dialog{bottom:0;left:0;overflow:auto;position:fixed;right:0;top:0}.dialog-fade-enter-active{animation:modal-fade-in var(--el-transition-duration)}.dialog-fade-enter-active .el-overlay-dialog{animation:dialog-fade-in var(--el-transition-duration)}.dialog-fade-leave-active{animation:modal-fade-out var(--el-transition-duration)}.dialog-fade-leave-active .el-overlay-dialog{animation:dialog-fade-out var(--el-transition-duration)}@keyframes dialog-fade-in{0%{opacity:0;transform:translate3d(0,-20px,0)}to{opacity:1;transform:translateZ(0)}}@keyframes dialog-fade-out{0%{opacity:1;transform:translateZ(0)}to{opacity:0;transform:translate3d(0,-20px,0)}}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-fade-out{0%{opacity:1}to{opacity:0}}.el-tabs{--el-tabs-header-height:40px;display:flex}.el-tabs__header{align-items:center;display:flex;justify-content:space-between;margin:0 0 15px;padding:0;position:relative}.el-tabs__header-vertical{flex-direction:column}.el-tabs__active-bar{background-color:var(--el-color-primary);bottom:0;height:2px;left:0;list-style:none;position:absolute;transition:width var(--el-transition-duration) var(--el-transition-function-ease-in-out-bezier),transform var(--el-transition-duration) var(--el-transition-function-ease-in-out-bezier);z-index:1}.el-tabs__active-bar.is-bottom{bottom:auto}.el-tabs__new-tab{align-items:center;border:1px solid var(--el-border-color);border-radius:3px;color:var(--el-text-color-primary);cursor:pointer;display:flex;flex-shrink:0;font-size:12px;height:20px;justify-content:center;line-height:20px;margin:10px 0 10px 10px;text-align:center;transition:all .15s;width:20px}.el-tabs__new-tab .is-icon-plus{height:inherit;transform:scale(.8);width:inherit}.el-tabs__new-tab .is-icon-plus svg{vertical-align:middle}.el-tabs__new-tab:hover{color:var(--el-color-primary)}.el-tabs__new-tab-vertical{margin-left:0}.el-tabs__nav-wrap{flex:1 auto;margin-bottom:-1px;overflow:hidden;position:relative}.el-tabs__nav-wrap:after{background-color:var(--el-border-color-light);bottom:0;content:"";height:2px;left:0;position:absolute;width:100%;z-index:var(--el-index-normal)}.el-tabs__nav-wrap.is-bottom:after{bottom:auto;top:0}.el-tabs__nav-wrap.is-scrollable{box-sizing:border-box;padding:0 20px}.el-tabs__nav-scroll{overflow:hidden}.el-tabs__nav-next,.el-tabs__nav-prev{color:var(--el-text-color-secondary);cursor:pointer;font-size:12px;line-height:44px;position:absolute;text-align:center;width:20px}.el-tabs__nav-next{right:0}.el-tabs__nav-prev{left:0}.el-tabs__nav{display:flex;float:left;position:relative;transition:transform var(--el-transition-duration);white-space:nowrap;z-index:calc(var(--el-index-normal) + 1)}.el-tabs__nav.is-stretch{display:flex;min-width:100%}.el-tabs__nav.is-stretch>*{flex:1;text-align:center}.el-tabs__item{align-items:center;box-sizing:border-box;color:var(--el-text-color-primary);display:flex;font-size:var(--el-font-size-base);font-weight:500;height:var(--el-tabs-header-height);justify-content:center;list-style:none;padding:0 20px;position:relative}.el-tabs__item:focus,.el-tabs__item:focus:active{outline:none}.el-tabs__item:focus-visible{border-radius:3px;box-shadow:0 0 2px 2px var(--el-color-primary) inset}.el-tabs__item .is-icon-close{border-radius:50%;margin-left:5px;text-align:center;transition:all var(--el-transition-duration) var(--el-transition-function-ease-in-out-bezier)}.el-tabs__item .is-icon-close:before{display:inline-block;transform:scale(.9)}.el-tabs__item .is-icon-close:hover{background-color:var(--el-text-color-placeholder);color:#fff}.el-tabs__item.is-active,.el-tabs__item:hover{color:var(--el-color-primary)}.el-tabs__item:hover{cursor:pointer}.el-tabs__item.is-disabled{color:var(--el-disabled-text-color);cursor:not-allowed}.el-tabs__content{flex-grow:1;overflow:hidden;position:relative}.el-tabs--bottom>.el-tabs__header .el-tabs__item:nth-child(2),.el-tabs--top>.el-tabs__header .el-tabs__item:nth-child(2){padding-left:0}.el-tabs--bottom>.el-tabs__header .el-tabs__item:last-child,.el-tabs--top>.el-tabs__header .el-tabs__item:last-child{padding-right:0}.el-tabs--bottom.el-tabs--border-card>.el-tabs__header .el-tabs__item:nth-child(2),.el-tabs--bottom.el-tabs--card>.el-tabs__header .el-tabs__item:nth-child(2),.el-tabs--top.el-tabs--border-card>.el-tabs__header .el-tabs__item:nth-child(2),.el-tabs--top.el-tabs--card>.el-tabs__header .el-tabs__item:nth-child(2){padding-left:20px}.el-tabs--bottom.el-tabs--border-card>.el-tabs__header .el-tabs__item:last-child,.el-tabs--bottom.el-tabs--card>.el-tabs__header .el-tabs__item:last-child,.el-tabs--top.el-tabs--border-card>.el-tabs__header .el-tabs__item:last-child,.el-tabs--top.el-tabs--card>.el-tabs__header .el-tabs__item:last-child{padding-right:20px}.el-tabs--card>.el-tabs__header{border-bottom:1px solid var(--el-border-color-light);box-sizing:border-box;height:var(--el-tabs-header-height)}.el-tabs--card>.el-tabs__header .el-tabs__nav-wrap:after{content:none}.el-tabs--card>.el-tabs__header .el-tabs__nav{border:1px solid var(--el-border-color-light);border-bottom:none;border-radius:4px 4px 0 0;box-sizing:border-box}.el-tabs--card>.el-tabs__header .el-tabs__active-bar{display:none}.el-tabs--card>.el-tabs__header .el-tabs__item .is-icon-close{font-size:12px;height:14px;overflow:hidden;position:relative;right:-2px;transform-origin:100% 50%;width:0}.el-tabs--card>.el-tabs__header .el-tabs__item{border-bottom:1px solid transparent;border-left:1px solid var(--el-border-color-light);margin-top:-1px;transition:color var(--el-transition-duration) var(--el-transition-function-ease-in-out-bezier),padding var(--el-transition-duration) var(--el-transition-function-ease-in-out-bezier)}.el-tabs--card>.el-tabs__header .el-tabs__item:first-child{border-left:none}.el-tabs--card>.el-tabs__header .el-tabs__item.is-closable:hover{padding-left:13px;padding-right:13px}.el-tabs--card>.el-tabs__header .el-tabs__item.is-closable:hover .is-icon-close{width:14px}.el-tabs--card>.el-tabs__header .el-tabs__item.is-active{border-bottom-color:var(--el-bg-color)}.el-tabs--card>.el-tabs__header .el-tabs__item.is-active.is-closable{padding-left:20px;padding-right:20px}.el-tabs--card>.el-tabs__header .el-tabs__item.is-active.is-closable .is-icon-close{width:14px}.el-tabs--border-card{background:var(--el-bg-color-overlay);border:1px solid var(--el-border-color)}.el-tabs--border-card>.el-tabs__content{padding:15px}.el-tabs--border-card>.el-tabs__header{background-color:var(--el-fill-color-light);border-bottom:1px solid var(--el-border-color-light);margin:0}.el-tabs--border-card>.el-tabs__header .el-tabs__nav-wrap:after{content:none}.el-tabs--border-card>.el-tabs__header .el-tabs__item{border:1px solid transparent;color:var(--el-text-color-secondary);margin-top:-1px;transition:all var(--el-transition-duration) var(--el-transition-function-ease-in-out-bezier)}.el-tabs--border-card>.el-tabs__header .el-tabs__item+.el-tabs__item,.el-tabs--border-card>.el-tabs__header .el-tabs__item:first-child{margin-left:-1px}.el-tabs--border-card>.el-tabs__header .el-tabs__item.is-active{background-color:var(--el-bg-color-overlay);border-left-color:var(--el-border-color);border-right-color:var(--el-border-color);color:var(--el-color-primary)}.el-tabs--border-card>.el-tabs__header .el-tabs__item:not(.is-disabled):hover{color:var(--el-color-primary)}.el-tabs--border-card>.el-tabs__header .el-tabs__item.is-disabled{color:var(--el-disabled-text-color)}.el-tabs--border-card>.el-tabs__header .is-scrollable .el-tabs__item:first-child{margin-left:0}.el-tabs--bottom{flex-direction:column}.el-tabs--bottom .el-tabs__header.is-bottom{margin-bottom:0;margin-top:10px}.el-tabs--bottom.el-tabs--border-card .el-tabs__header.is-bottom{border-bottom:0;border-top:1px solid var(--el-border-color)}.el-tabs--bottom.el-tabs--border-card .el-tabs__nav-wrap.is-bottom{margin-bottom:0;margin-top:-1px}.el-tabs--bottom.el-tabs--border-card .el-tabs__item.is-bottom:not(.is-active){border:1px solid transparent}.el-tabs--bottom.el-tabs--border-card .el-tabs__item.is-bottom{margin:0 -1px -1px}.el-tabs--left,.el-tabs--right{overflow:hidden}.el-tabs--left .el-tabs__header.is-left,.el-tabs--left .el-tabs__header.is-right,.el-tabs--left .el-tabs__nav-scroll,.el-tabs--left .el-tabs__nav-wrap.is-left,.el-tabs--left .el-tabs__nav-wrap.is-right,.el-tabs--right .el-tabs__header.is-left,.el-tabs--right .el-tabs__header.is-right,.el-tabs--right .el-tabs__nav-scroll,.el-tabs--right .el-tabs__nav-wrap.is-left,.el-tabs--right .el-tabs__nav-wrap.is-right{height:100%}.el-tabs--left .el-tabs__active-bar.is-left,.el-tabs--left .el-tabs__active-bar.is-right,.el-tabs--right .el-tabs__active-bar.is-left,.el-tabs--right .el-tabs__active-bar.is-right{bottom:auto;height:auto;top:0;width:2px}.el-tabs--left .el-tabs__nav-wrap.is-left,.el-tabs--left .el-tabs__nav-wrap.is-right,.el-tabs--right .el-tabs__nav-wrap.is-left,.el-tabs--right .el-tabs__nav-wrap.is-right{margin-bottom:0}.el-tabs--left .el-tabs__nav-wrap.is-left>.el-tabs__nav-next,.el-tabs--left .el-tabs__nav-wrap.is-left>.el-tabs__nav-prev,.el-tabs--left .el-tabs__nav-wrap.is-right>.el-tabs__nav-next,.el-tabs--left .el-tabs__nav-wrap.is-right>.el-tabs__nav-prev,.el-tabs--right .el-tabs__nav-wrap.is-left>.el-tabs__nav-next,.el-tabs--right .el-tabs__nav-wrap.is-left>.el-tabs__nav-prev,.el-tabs--right .el-tabs__nav-wrap.is-right>.el-tabs__nav-next,.el-tabs--right .el-tabs__nav-wrap.is-right>.el-tabs__nav-prev{cursor:pointer;height:30px;line-height:30px;text-align:center;width:100%}.el-tabs--left .el-tabs__nav-wrap.is-left>.el-tabs__nav-next i,.el-tabs--left .el-tabs__nav-wrap.is-left>.el-tabs__nav-prev i,.el-tabs--left .el-tabs__nav-wrap.is-right>.el-tabs__nav-next i,.el-tabs--left .el-tabs__nav-wrap.is-right>.el-tabs__nav-prev i,.el-tabs--right .el-tabs__nav-wrap.is-left>.el-tabs__nav-next i,.el-tabs--right .el-tabs__nav-wrap.is-left>.el-tabs__nav-prev i,.el-tabs--right .el-tabs__nav-wrap.is-right>.el-tabs__nav-next i,.el-tabs--right .el-tabs__nav-wrap.is-right>.el-tabs__nav-prev i{transform:rotate(90deg)}.el-tabs--left .el-tabs__nav-wrap.is-left>.el-tabs__nav-prev,.el-tabs--left .el-tabs__nav-wrap.is-right>.el-tabs__nav-prev,.el-tabs--right .el-tabs__nav-wrap.is-left>.el-tabs__nav-prev,.el-tabs--right .el-tabs__nav-wrap.is-right>.el-tabs__nav-prev{left:auto;top:0}.el-tabs--left .el-tabs__nav-wrap.is-left>.el-tabs__nav-next,.el-tabs--left .el-tabs__nav-wrap.is-right>.el-tabs__nav-next,.el-tabs--right .el-tabs__nav-wrap.is-left>.el-tabs__nav-next,.el-tabs--right .el-tabs__nav-wrap.is-right>.el-tabs__nav-next{bottom:0;right:auto}.el-tabs--left .el-tabs__nav-wrap.is-left.is-scrollable,.el-tabs--left .el-tabs__nav-wrap.is-right.is-scrollable,.el-tabs--right .el-tabs__nav-wrap.is-left.is-scrollable,.el-tabs--right .el-tabs__nav-wrap.is-right.is-scrollable{padding:30px 0}.el-tabs--left .el-tabs__nav-wrap.is-left:after,.el-tabs--left .el-tabs__nav-wrap.is-right:after,.el-tabs--right .el-tabs__nav-wrap.is-left:after,.el-tabs--right .el-tabs__nav-wrap.is-right:after{bottom:auto;height:100%;top:0;width:2px}.el-tabs--left .el-tabs__nav.is-left,.el-tabs--left .el-tabs__nav.is-right,.el-tabs--right .el-tabs__nav.is-left,.el-tabs--right .el-tabs__nav.is-right{flex-direction:column}.el-tabs--left .el-tabs__item.is-left,.el-tabs--right .el-tabs__item.is-left{justify-content:flex-end}.el-tabs--left .el-tabs__item.is-right,.el-tabs--right .el-tabs__item.is-right{justify-content:flex-start}.el-tabs--left{flex-direction:row}.el-tabs--left .el-tabs__header.is-left{margin-bottom:0;margin-right:10px}.el-tabs--left .el-tabs__nav-wrap.is-left{margin-right:-1px}.el-tabs--left .el-tabs__active-bar.is-left,.el-tabs--left .el-tabs__nav-wrap.is-left:after{left:auto;right:0}.el-tabs--left .el-tabs__item.is-left{text-align:right}.el-tabs--left.el-tabs--card .el-tabs__active-bar.is-left{display:none}.el-tabs--left.el-tabs--card .el-tabs__item.is-left{border-bottom:none;border-left:none;border-right:1px solid var(--el-border-color-light);border-top:1px solid var(--el-border-color-light);text-align:left}.el-tabs--left.el-tabs--card .el-tabs__item.is-left:first-child{border-right:1px solid var(--el-border-color-light);border-top:none}.el-tabs--left.el-tabs--card .el-tabs__item.is-left.is-active{border:1px solid var(--el-border-color-light);border-bottom:none;border-left:none;border-right:1px solid #fff}.el-tabs--left.el-tabs--card .el-tabs__item.is-left.is-active:first-child{border-top:none}.el-tabs--left.el-tabs--card .el-tabs__item.is-left.is-active:last-child{border-bottom:none}.el-tabs--left.el-tabs--card .el-tabs__nav{border-bottom:1px solid var(--el-border-color-light);border-radius:4px 0 0 4px;border-right:none}.el-tabs--left.el-tabs--card .el-tabs__new-tab{float:none}.el-tabs--left.el-tabs--border-card .el-tabs__header.is-left{border-right:1px solid var(--el-border-color)}.el-tabs--left.el-tabs--border-card .el-tabs__item.is-left{border:1px solid transparent;margin:-1px 0 -1px -1px}.el-tabs--left.el-tabs--border-card .el-tabs__item.is-left.is-active{border-color:#d1dbe5 transparent}.el-tabs--left>.el-tabs__content+.el-tabs__header{order:-1}.el-tabs--right .el-tabs__header.is-right{margin-bottom:0;margin-left:10px}.el-tabs--right .el-tabs__nav-wrap.is-right{margin-left:-1px}.el-tabs--right .el-tabs__nav-wrap.is-right:after{left:0;right:auto}.el-tabs--right .el-tabs__active-bar.is-right{left:0}.el-tabs--right.el-tabs--card .el-tabs__active-bar.is-right{display:none}.el-tabs--right.el-tabs--card .el-tabs__item.is-right{border-bottom:none;border-top:1px solid var(--el-border-color-light)}.el-tabs--right.el-tabs--card .el-tabs__item.is-right:first-child{border-left:1px solid var(--el-border-color-light);border-top:none}.el-tabs--right.el-tabs--card .el-tabs__item.is-right.is-active{border:1px solid var(--el-border-color-light);border-bottom:none;border-left:1px solid #fff;border-right:none}.el-tabs--right.el-tabs--card .el-tabs__item.is-right.is-active:first-child{border-top:none}.el-tabs--right.el-tabs--card .el-tabs__item.is-right.is-active:last-child{border-bottom:none}.el-tabs--right.el-tabs--card .el-tabs__nav{border-bottom:1px solid var(--el-border-color-light);border-left:none;border-radius:0 4px 4px 0}.el-tabs--right.el-tabs--border-card .el-tabs__header.is-right{border-left:1px solid var(--el-border-color)}.el-tabs--right.el-tabs--border-card .el-tabs__item.is-right{border:1px solid transparent;margin:-1px -1px -1px 0}.el-tabs--right.el-tabs--border-card .el-tabs__item.is-right.is-active{border-color:#d1dbe5 transparent}.el-tabs--top{flex-direction:column}.el-tabs--top>.el-tabs__content+.el-tabs__header{order:-1}.slideInLeft-transition,.slideInRight-transition{display:inline-block}.slideInRight-enter{animation:slideInRight-enter var(--el-transition-duration)}.slideInRight-leave{animation:slideInRight-leave var(--el-transition-duration);left:0;position:absolute;right:0}.slideInLeft-enter{animation:slideInLeft-enter var(--el-transition-duration)}.slideInLeft-leave{animation:slideInLeft-leave var(--el-transition-duration);left:0;position:absolute;right:0}@keyframes slideInRight-enter{0%{opacity:0;transform:translateX(100%);transform-origin:0 0}to{opacity:1;transform:translateX(0);transform-origin:0 0}}@keyframes slideInRight-leave{0%{opacity:1;transform:translateX(0);transform-origin:0 0}to{opacity:0;transform:translateX(100%);transform-origin:0 0}}@keyframes slideInLeft-enter{0%{opacity:0;transform:translateX(-100%);transform-origin:0 0}to{opacity:1;transform:translateX(0);transform-origin:0 0}}@keyframes slideInLeft-leave{0%{opacity:1;transform:translateX(0);transform-origin:0 0}to{opacity:0;transform:translateX(-100%);transform-origin:0 0}}.el-alert{--el-alert-padding:8px 16px;--el-alert-border-radius-base:var(--el-border-radius-base);--el-alert-title-font-size:14px;--el-alert-title-with-description-font-size:16px;--el-alert-description-font-size:14px;--el-alert-close-font-size:16px;--el-alert-close-customed-font-size:14px;--el-alert-icon-size:16px;--el-alert-icon-large-size:28px;align-items:center;background-color:var(--el-color-white);border-radius:var(--el-alert-border-radius-base);box-sizing:border-box;display:flex;margin:0;opacity:1;overflow:hidden;padding:var(--el-alert-padding);position:relative;transition:opacity var(--el-transition-duration-fast);width:100%}.el-alert.is-light .el-alert__close-btn{color:var(--el-text-color-placeholder)}.el-alert.is-dark .el-alert__close-btn,.el-alert.is-dark .el-alert__description{color:var(--el-color-white)}.el-alert.is-center{justify-content:center}.el-alert--primary{--el-alert-bg-color:var(--el-color-primary-light-9)}.el-alert--primary.is-light{background-color:var(--el-alert-bg-color)}.el-alert--primary.is-light,.el-alert--primary.is-light .el-alert__description{color:var(--el-color-primary)}.el-alert--primary.is-dark{background-color:var(--el-color-primary);color:var(--el-color-white)}.el-alert--success{--el-alert-bg-color:var(--el-color-success-light-9)}.el-alert--success.is-light{background-color:var(--el-alert-bg-color)}.el-alert--success.is-light,.el-alert--success.is-light .el-alert__description{color:var(--el-color-success)}.el-alert--success.is-dark{background-color:var(--el-color-success);color:var(--el-color-white)}.el-alert--info{--el-alert-bg-color:var(--el-color-info-light-9)}.el-alert--info.is-light{background-color:var(--el-alert-bg-color)}.el-alert--info.is-light,.el-alert--info.is-light .el-alert__description{color:var(--el-color-info)}.el-alert--info.is-dark{background-color:var(--el-color-info);color:var(--el-color-white)}.el-alert--warning{--el-alert-bg-color:var(--el-color-warning-light-9)}.el-alert--warning.is-light{background-color:var(--el-alert-bg-color)}.el-alert--warning.is-light,.el-alert--warning.is-light .el-alert__description{color:var(--el-color-warning)}.el-alert--warning.is-dark{background-color:var(--el-color-warning);color:var(--el-color-white)}.el-alert--error{--el-alert-bg-color:var(--el-color-error-light-9)}.el-alert--error.is-light{background-color:var(--el-alert-bg-color)}.el-alert--error.is-light,.el-alert--error.is-light .el-alert__description{color:var(--el-color-error)}.el-alert--error.is-dark{background-color:var(--el-color-error);color:var(--el-color-white)}.el-alert__content{display:flex;flex-direction:column;gap:4px}.el-alert .el-alert__icon{font-size:var(--el-alert-icon-size);margin-right:8px;width:var(--el-alert-icon-size)}.el-alert .el-alert__icon.is-big{font-size:var(--el-alert-icon-large-size);margin-right:12px;width:var(--el-alert-icon-large-size)}.el-alert__title{font-size:var(--el-alert-title-font-size);line-height:24px}.el-alert__title.with-description{font-size:var(--el-alert-title-with-description-font-size)}.el-alert .el-alert__description{font-size:var(--el-alert-description-font-size);margin:0}.el-alert .el-alert__close-btn{cursor:pointer;font-size:var(--el-alert-close-font-size);opacity:1;position:absolute;right:16px;top:12px}.el-alert .el-alert__close-btn.is-customed{font-size:var(--el-alert-close-customed-font-size);font-style:normal;line-height:24px;top:8px}.el-alert-fade-enter-from,.el-alert-fade-leave-active{opacity:0}.batch-tag-container[data-v-dacf7742]{padding:0}.tab-content[data-v-dacf7742]{padding:20px}.tab-description[data-v-dacf7742]{margin:0 0 15px 0;color:#606266;font-size:14px}.input-section[data-v-dacf7742]{position:relative;margin-bottom:20px}.suggestions-panel[data-v-dacf7742]{position:absolute;top:100%;left:0;right:0;background:var(--admin-dashboard-tag-suggestion-bg-color);border:1px solid var(--admin-dashboard-tag-suggestion-border-color);border-radius:4px;box-shadow:var(--admin-dashboard-tag-suggestion-box-shadow);max-height:200px;overflow-y:auto;z-index:1000;margin-top:4px}.suggestion-item[data-v-dacf7742]{padding:8px 12px;cursor:pointer;transition:background-color .2s}.suggestion-item[data-v-dacf7742]:hover{background-color:var(--admin-dashboard-tag-suggestion-item-hover-bg-color)}.common-tags-section[data-v-dacf7742],.tags-to-add-section[data-v-dacf7742]{margin-bottom:20px}.common-tags-section h4[data-v-dacf7742],.tags-to-add-section h4[data-v-dacf7742]{margin:0 0 10px 0;font-size:14px;color:#606266}.tags-container[data-v-dacf7742]{display:flex;flex-wrap:wrap;gap:8px;min-height:40px}.tag-item[data-v-dacf7742]{cursor:default}.empty-message[data-v-dacf7742]{color:#909399;font-size:13px;padding:10px 0}.action-buttons[data-v-dacf7742]{margin-top:20px;display:flex;justify-content:flex-end}.tag-management-container[data-v-8b4291b4]{padding:10px 0}.input-section[data-v-8b4291b4]{position:relative;margin-bottom:20px}.suggestions-panel[data-v-8b4291b4]{position:absolute;top:100%;left:0;right:0;background:var(--admin-dashboard-tag-suggestion-bg-color);border:1px solid var(--admin-dashboard-tag-suggestion-border-color);border-radius:4px;box-shadow:var(--admin-dashboard-tag-suggestion-box-shadow);max-height:200px;overflow-y:auto;z-index:1000;margin-top:4px}.suggestion-item[data-v-8b4291b4]{padding:8px 12px;cursor:pointer;transition:background-color .2s}.suggestion-item[data-v-8b4291b4]:hover{background-color:var(--admin-dashboard-tag-suggestion-item-hover-bg-color)}.current-tags-section[data-v-8b4291b4],.popular-tags-section[data-v-8b4291b4]{margin-bottom:20px}.current-tags-section h4[data-v-8b4291b4],.popular-tags-section h4[data-v-8b4291b4]{margin:0 0 10px 0;font-size:14px;color:#606266}.tags-container[data-v-8b4291b4]{display:flex;flex-wrap:wrap;gap:8px;min-height:40px}.tag-item[data-v-8b4291b4]{cursor:default}.tag-item.clickable[data-v-8b4291b4]{cursor:pointer;transition:transform .2s}.tag-item.clickable[data-v-8b4291b4]:hover{transform:translateY(-2px)}.empty-message[data-v-8b4291b4]{color:#909399;font-size:13px;padding:10px 0}.dialog-footer[data-v-8b4291b4]{display:flex;justify-content:flex-end}.el-radio{--el-radio-font-size:var(--el-font-size-base);--el-radio-text-color:var(--el-text-color-regular);--el-radio-font-weight:var(--el-font-weight-primary);--el-radio-input-height:14px;--el-radio-input-width:14px;--el-radio-input-border-radius:var(--el-border-radius-circle);--el-radio-input-bg-color:var(--el-fill-color-blank);--el-radio-input-border:var(--el-border);--el-radio-input-border-color:var(--el-border-color);--el-radio-input-border-color-hover:var(--el-color-primary);align-items:center;color:var(--el-radio-text-color);cursor:pointer;display:inline-flex;font-size:var(--el-font-size-base);font-weight:var(--el-radio-font-weight);height:32px;margin-right:30px;outline:none;position:relative;-webkit-user-select:none;user-select:none;white-space:nowrap}.el-radio.el-radio--large{height:40px}.el-radio.el-radio--small{height:24px}.el-radio.is-bordered{border:var(--el-border);border-radius:var(--el-border-radius-base);box-sizing:border-box;padding:0 15px 0 9px}.el-radio.is-bordered.is-checked{border-color:var(--el-color-primary)}.el-radio.is-bordered.is-disabled{border-color:var(--el-border-color-lighter);cursor:not-allowed}.el-radio.is-bordered.el-radio--large{border-radius:var(--el-border-radius-base);padding:0 19px 0 11px}.el-radio.is-bordered.el-radio--large .el-radio__label{font-size:var(--el-font-size-base)}.el-radio.is-bordered.el-radio--large .el-radio__inner{height:14px;width:14px}.el-radio.is-bordered.el-radio--small{border-radius:var(--el-border-radius-base);padding:0 11px 0 7px}.el-radio.is-bordered.el-radio--small .el-radio__label{font-size:12px}.el-radio.is-bordered.el-radio--small .el-radio__inner{height:12px;width:12px}.el-radio:last-child{margin-right:0}.el-radio__input{cursor:pointer;display:inline-flex;outline:none;position:relative;vertical-align:middle;white-space:nowrap}.el-radio__input.is-disabled .el-radio__inner{border-color:var(--el-disabled-border-color)}.el-radio__input.is-disabled .el-radio__inner,.el-radio__input.is-disabled .el-radio__inner:after{background-color:var(--el-disabled-bg-color);cursor:not-allowed}.el-radio__input.is-disabled .el-radio__inner+.el-radio__label{cursor:not-allowed}.el-radio__input.is-disabled.is-checked .el-radio__inner{background-color:var(--el-disabled-bg-color);border-color:var(--el-disabled-border-color)}.el-radio__input.is-disabled.is-checked .el-radio__inner:after{background-color:var(--el-text-color-placeholder)}.el-radio__input.is-disabled+span.el-radio__label{color:var(--el-text-color-placeholder);cursor:not-allowed}.el-radio__input.is-checked .el-radio__inner{background:var(--el-color-primary);border-color:var(--el-color-primary)}.el-radio__input.is-checked .el-radio__inner:after{background-color:var(--el-color-white);transform:translate(-50%,-50%) scale(1)}.el-radio__input.is-checked+.el-radio__label{color:var(--el-color-primary)}.el-radio__input.is-focus .el-radio__inner{border-color:var(--el-radio-input-border-color-hover)}.el-radio__inner{background-color:var(--el-radio-input-bg-color);border:var(--el-radio-input-border);border-radius:var(--el-radio-input-border-radius);box-sizing:border-box;cursor:pointer;display:inline-block;height:var(--el-radio-input-height);position:relative;width:var(--el-radio-input-width)}.el-radio__inner:hover{border-color:var(--el-radio-input-border-color-hover)}.el-radio__inner:after{border-radius:var(--el-radio-input-border-radius);content:"";height:4px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%) scale(0);transition:transform .15s ease-in;width:4px}.el-radio__original{bottom:0;left:0;margin:0;opacity:0;outline:none;position:absolute;right:0;top:0;z-index:-1}.el-radio__original:focus-visible+.el-radio__inner{border-radius:var(--el-radio-input-border-radius);outline:2px solid var(--el-radio-input-border-color-hover);outline-offset:1px}.el-radio:focus:not(:focus-visible):not(.is-focus):not(:active):not(.is-disabled) .el-radio__inner{box-shadow:0 0 2px 2px var(--el-radio-input-border-color-hover)}.el-radio__label{font-size:var(--el-radio-font-size);padding-left:8px}.el-radio.el-radio--large .el-radio__label{font-size:14px}.el-radio.el-radio--large .el-radio__inner{height:14px;width:14px}.el-radio.el-radio--small .el-radio__label{font-size:12px}.el-radio.el-radio--small .el-radio__inner{height:12px;width:12px}.el-radio-group{align-items:center;display:inline-flex;flex-wrap:wrap;font-size:0}.el-descriptions{--el-descriptions-table-border:1px solid var(--el-border-color-lighter);--el-descriptions-item-bordered-label-background:var(--el-fill-color-light);box-sizing:border-box;color:var(--el-text-color-primary);font-size:var(--el-font-size-base)}.el-descriptions__header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.el-descriptions__title{color:var(--el-text-color-primary);font-size:16px;font-weight:700}.el-descriptions__body{background-color:var(--el-fill-color-blank)}.el-descriptions__body .el-descriptions__table{border-collapse:collapse;width:100%}.el-descriptions__body .el-descriptions__table .el-descriptions__cell{box-sizing:border-box;font-size:14px;line-height:23px;text-align:left}.el-descriptions__body .el-descriptions__table .el-descriptions__cell.is-left{text-align:left}.el-descriptions__body .el-descriptions__table .el-descriptions__cell.is-center{text-align:center}.el-descriptions__body .el-descriptions__table .el-descriptions__cell.is-right{text-align:right}.el-descriptions__body .el-descriptions__table.is-bordered .el-descriptions__cell{border:var(--el-descriptions-table-border);padding:8px 11px}.el-descriptions__body .el-descriptions__table:not(.is-bordered) .el-descriptions__cell{padding-bottom:12px}.el-descriptions--large{font-size:14px}.el-descriptions--large .el-descriptions__header{margin-bottom:20px}.el-descriptions--large .el-descriptions__header .el-descriptions__title{font-size:16px}.el-descriptions--large .el-descriptions__body .el-descriptions__table .el-descriptions__cell{font-size:14px}.el-descriptions--large .el-descriptions__body .el-descriptions__table.is-bordered .el-descriptions__cell{padding:12px 15px}.el-descriptions--large .el-descriptions__body .el-descriptions__table:not(.is-bordered) .el-descriptions__cell{padding-bottom:16px}.el-descriptions--small{font-size:12px}.el-descriptions--small .el-descriptions__header{margin-bottom:12px}.el-descriptions--small .el-descriptions__header .el-descriptions__title{font-size:14px}.el-descriptions--small .el-descriptions__body .el-descriptions__table .el-descriptions__cell{font-size:12px}.el-descriptions--small .el-descriptions__body .el-descriptions__table.is-bordered .el-descriptions__cell{padding:4px 7px}.el-descriptions--small .el-descriptions__body .el-descriptions__table:not(.is-bordered) .el-descriptions__cell{padding-bottom:8px}.el-descriptions__label.el-descriptions__cell.is-bordered-label{background:var(--el-descriptions-item-bordered-label-background);color:var(--el-text-color-regular);font-weight:700}.el-descriptions__label:not(.is-bordered-label){color:var(--el-text-color-primary);margin-right:16px}.el-descriptions__label.el-descriptions__cell:not(.is-bordered-label).is-vertical-label{padding-bottom:6px}.el-descriptions__content.el-descriptions__cell.is-bordered-content{color:var(--el-text-color-primary)}.el-descriptions__content:not(.is-bordered-label){color:var(--el-text-color-regular)}.el-descriptions--large .el-descriptions__label:not(.is-bordered-label){margin-right:16px}.el-descriptions--large .el-descriptions__label.el-descriptions__cell:not(.is-bordered-label).is-vertical-label{padding-bottom:8px}.el-descriptions--small .el-descriptions__label:not(.is-bordered-label){margin-right:12px}.el-descriptions--small .el-descriptions__label.el-descriptions__cell:not(.is-bordered-label).is-vertical-label{padding-bottom:4px}.el-image__error,.el-image__inner,.el-image__placeholder,.el-image__wrapper{height:100%;width:100%}.el-image{display:inline-block;overflow:hidden;position:relative}.el-image__inner{opacity:1;vertical-align:top}.el-image__inner.is-loading{opacity:0}.el-image__wrapper{left:0;position:absolute;top:0}.el-image__error,.el-image__placeholder{background:var(--el-fill-color-light)}.el-image__error{align-items:center;color:var(--el-text-color-placeholder);display:flex;font-size:14px;justify-content:center;vertical-align:middle}.el-image__preview{cursor:pointer}.el-image-viewer__wrapper{bottom:0;left:0;position:fixed;right:0;top:0}.el-image-viewer__wrapper:focus{outline:none!important}.el-image-viewer__btn{align-items:center;border-radius:50%;box-sizing:border-box;cursor:pointer;display:flex;justify-content:center;opacity:.8;position:absolute;-webkit-user-select:none;user-select:none;z-index:1}.el-image-viewer__btn .el-icon{cursor:pointer}.el-image-viewer__close{font-size:40px;height:40px;right:40px;top:40px;width:40px}.el-image-viewer__canvas{align-items:center;display:flex;height:100%;justify-content:center;position:static;-webkit-user-select:none;user-select:none;width:100%}.el-image-viewer__actions{background-color:var(--el-text-color-regular);border-color:#fff;border-radius:22px;bottom:30px;height:44px;left:50%;padding:0 23px;transform:translateX(-50%)}.el-image-viewer__actions__inner{align-items:center;color:#fff;cursor:default;display:flex;font-size:23px;gap:22px;height:100%;justify-content:space-around;padding:0 6px;width:100%}.el-image-viewer__actions__divider{margin:0 -6px}.el-image-viewer__progress{bottom:90px;color:#fff;cursor:default;left:50%;transform:translateX(-50%)}.el-image-viewer__prev{left:40px}.el-image-viewer__next,.el-image-viewer__prev{background-color:var(--el-text-color-regular);border-color:#fff;color:#fff;font-size:24px;height:44px;top:50%;transform:translateY(-50%);width:44px}.el-image-viewer__next{right:40px;text-indent:2px}.el-image-viewer__close{background-color:var(--el-text-color-regular);border-color:#fff;color:#fff;font-size:24px;height:44px;width:44px}.el-image-viewer__mask{background:#000;height:100%;left:0;opacity:.5;position:absolute;top:0;width:100%}.el-image-viewer-parent--hidden{overflow:hidden}.viewer-fade-enter-active{animation:viewer-fade-in var(--el-transition-duration)}.viewer-fade-leave-active{animation:viewer-fade-out var(--el-transition-duration)}@keyframes viewer-fade-in{0%{opacity:0;transform:translate3d(0,-20px,0)}to{opacity:1;transform:translateZ(0)}}@keyframes viewer-fade-out{0%{opacity:1;transform:translateZ(0)}to{opacity:0;transform:translate3d(0,-20px,0)}}.detail-actions[data-v-0dc381fc]{display:flex;justify-content:right;margin-bottom:10px;flex-wrap:wrap;gap:8px}.detail-action[data-v-0dc381fc]{margin-left:0!important}.video-preview[data-v-0dc381fc]{max-height:300px;cursor:pointer;-o-object-fit:contain;object-fit:contain}.audio-preview[data-v-0dc381fc],.video-preview[data-v-0dc381fc]{width:100%;max-width:400px;border-radius:8px}.image-preview[data-v-0dc381fc]{width:auto;height:auto;max-width:100%;max-height:300px;border-radius:8px;cursor:pointer}.image-preview[data-v-0dc381fc] img{max-width:100%;max-height:300px;-o-object-fit:contain;object-fit:contain}.file-icon-detail[data-v-0dc381fc]{font-size:64px;color:var(--el-text-color-secondary)}.preview-section[data-v-0dc381fc]{display:flex;justify-content:center;margin-bottom:15px;padding:12px;background:var(--el-fill-color-light);border-radius:8px;min-height:60px}.preview-content[data-v-0dc381fc]{display:flex;justify-content:center;align-items:center;width:100%}[data-v-0dc381fc] .description-item{word-break:break-all;word-wrap:break-word}[data-v-0dc381fc] .el-descriptions__label{width:120px!important;min-width:100px!important;max-width:120px!important}@media (max-width:768px){.detail-actions[data-v-0dc381fc]{justify-content:center}}.el-container{box-sizing:border-box;display:flex;flex:1;flex-basis:auto;flex-direction:row;min-width:0}.el-container.is-vertical{flex-direction:column}.el-aside{overflow:auto;width:var(--el-aside-width,300px)}.el-aside,.el-footer{box-sizing:border-box;flex-shrink:0}.el-footer{--el-footer-padding:0 20px;--el-footer-height:60px;height:var(--el-footer-height);padding:var(--el-footer-padding)}.el-header{--el-header-padding:0 20px;--el-header-height:60px;flex-shrink:0;height:var(--el-header-height);padding:var(--el-header-padding)}.el-header,.el-main{box-sizing:border-box}.el-main{--el-main-padding:20px;display:block;flex:1;flex-basis:auto;overflow:auto;padding:var(--el-main-padding)}.el-pagination{--el-pagination-font-size:14px;--el-pagination-bg-color:var(--el-fill-color-blank);--el-pagination-text-color:var(--el-text-color-primary);--el-pagination-border-radius:2px;--el-pagination-button-color:var(--el-text-color-primary);--el-pagination-button-width:32px;--el-pagination-button-height:32px;--el-pagination-button-disabled-color:var(--el-text-color-placeholder);--el-pagination-button-disabled-bg-color:var(--el-fill-color-blank);--el-pagination-button-bg-color:var(--el-fill-color);--el-pagination-hover-color:var(--el-color-primary);--el-pagination-font-size-small:12px;--el-pagination-button-width-small:24px;--el-pagination-button-height-small:24px;--el-pagination-button-width-large:40px;--el-pagination-button-height-large:40px;--el-pagination-item-gap:16px;align-items:center;color:var(--el-pagination-text-color);display:flex;font-size:var(--el-pagination-font-size);font-weight:400;white-space:nowrap}.el-pagination .el-input__inner{-moz-appearance:textfield;text-align:center}.el-pagination .el-select{width:128px}.el-pagination .btn-next,.el-pagination .btn-prev{align-items:center;background:var(--el-pagination-bg-color);border:none;border-radius:var(--el-pagination-border-radius);box-sizing:border-box;color:var(--el-pagination-button-color);cursor:pointer;display:flex;font-size:var(--el-pagination-font-size);height:var(--el-pagination-button-height);justify-content:center;line-height:var(--el-pagination-button-height);min-width:var(--el-pagination-button-width);padding:0 4px;text-align:center}.el-pagination .btn-next *,.el-pagination .btn-prev *{pointer-events:none}.el-pagination .btn-next:focus,.el-pagination .btn-prev:focus{outline:none}.el-pagination .btn-next:hover,.el-pagination .btn-prev:hover{color:var(--el-pagination-hover-color)}.el-pagination .btn-next.is-active,.el-pagination .btn-prev.is-active{color:var(--el-pagination-hover-color);cursor:default;font-weight:700}.el-pagination .btn-next.is-active.is-disabled,.el-pagination .btn-prev.is-active.is-disabled{color:var(--el-text-color-secondary);font-weight:700}.el-pagination .btn-next.is-disabled,.el-pagination .btn-next:disabled,.el-pagination .btn-prev.is-disabled,.el-pagination .btn-prev:disabled{background-color:var(--el-pagination-button-disabled-bg-color);color:var(--el-pagination-button-disabled-color);cursor:not-allowed}.el-pagination .btn-next:focus-visible,.el-pagination .btn-prev:focus-visible{outline:1px solid var(--el-pagination-hover-color);outline-offset:-1px}.el-pagination .btn-next .el-icon,.el-pagination .btn-prev .el-icon{display:block;font-size:12px;font-weight:700;width:inherit}.el-pagination>.is-first{margin-left:0!important}.el-pagination>.is-last{margin-right:0!important}.el-pagination .btn-prev{margin-left:var(--el-pagination-item-gap)}.el-pagination__sizes,.el-pagination__total{color:var(--el-text-color-regular);font-weight:400;margin-left:var(--el-pagination-item-gap)}.el-pagination__total[disabled=true]{color:var(--el-text-color-placeholder)}.el-pagination__jump{align-items:center;color:var(--el-text-color-regular);display:flex;font-weight:400;margin-left:var(--el-pagination-item-gap)}.el-pagination__jump[disabled=true]{color:var(--el-text-color-placeholder)}.el-pagination__goto{margin-right:8px}.el-pagination__editor{box-sizing:border-box;text-align:center}.el-pagination__editor.el-input{width:56px}.el-pagination__editor .el-input__inner::-webkit-inner-spin-button,.el-pagination__editor .el-input__inner::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.el-pagination__classifier{margin-left:8px}.el-pagination__rightwrapper{align-items:center;display:flex;flex:1;justify-content:flex-end}.el-pagination.is-background .btn-next,.el-pagination.is-background .btn-prev,.el-pagination.is-background .el-pager li{background-color:var(--el-pagination-button-bg-color);margin:0 4px}.el-pagination.is-background .btn-next.is-active,.el-pagination.is-background .btn-prev.is-active,.el-pagination.is-background .el-pager li.is-active{background-color:var(--el-color-primary);color:var(--el-color-white)}.el-pagination.is-background .btn-next.is-disabled,.el-pagination.is-background .btn-next:disabled,.el-pagination.is-background .btn-prev.is-disabled,.el-pagination.is-background .btn-prev:disabled,.el-pagination.is-background .el-pager li.is-disabled,.el-pagination.is-background .el-pager li:disabled{background-color:var(--el-disabled-bg-color);color:var(--el-text-color-placeholder)}.el-pagination.is-background .btn-next.is-disabled.is-active,.el-pagination.is-background .btn-next:disabled.is-active,.el-pagination.is-background .btn-prev.is-disabled.is-active,.el-pagination.is-background .btn-prev:disabled.is-active,.el-pagination.is-background .el-pager li.is-disabled.is-active,.el-pagination.is-background .el-pager li:disabled.is-active{background-color:var(--el-fill-color-dark);color:var(--el-text-color-secondary)}.el-pagination.is-background .btn-prev{margin-left:var(--el-pagination-item-gap)}.el-pagination--small .btn-next,.el-pagination--small .btn-prev,.el-pagination--small .el-pager li{font-size:var(--el-pagination-font-size-small);height:var(--el-pagination-button-height-small);line-height:var(--el-pagination-button-height-small);min-width:var(--el-pagination-button-width-small)}.el-pagination--small button,.el-pagination--small span:not([class*=suffix]){font-size:var(--el-pagination-font-size-small)}.el-pagination--small .el-select{width:100px}.el-pagination--large .btn-next,.el-pagination--large .btn-prev,.el-pagination--large .el-pager li{height:var(--el-pagination-button-height-large);line-height:var(--el-pagination-button-height-large);min-width:var(--el-pagination-button-width-large)}.el-pagination--large .el-select .el-input{width:160px}.el-pager{font-size:0;list-style:none;margin:0;padding:0;-webkit-user-select:none;user-select:none}.el-pager,.el-pager li{align-items:center;display:flex}.el-pager li{background:var(--el-pagination-bg-color);border:none;border-radius:var(--el-pagination-border-radius);box-sizing:border-box;color:var(--el-pagination-button-color);cursor:pointer;font-size:var(--el-pagination-font-size);height:var(--el-pagination-button-height);justify-content:center;line-height:var(--el-pagination-button-height);min-width:var(--el-pagination-button-width);padding:0 4px;text-align:center}.el-pager li *{pointer-events:none}.el-pager li:focus{outline:none}.el-pager li.is-active,.el-pager li:hover{color:var(--el-pagination-hover-color)}.el-pager li.is-active{cursor:default;font-weight:700}.el-pager li.is-active.is-disabled{color:var(--el-text-color-secondary);font-weight:700}.el-pager li.is-disabled,.el-pager li:disabled{background-color:var(--el-pagination-button-disabled-bg-color);color:var(--el-pagination-button-disabled-color);cursor:not-allowed}.el-pager li:focus-visible{outline:1px solid var(--el-pagination-hover-color);outline-offset:-1px}.list-item[data-v-9968e9fe]{display:grid;grid-template-columns:50px 60px minmax(180px,1fr) 130px 100px 110px 130px 80px 100px 120px;padding:12px 20px;align-items:center;transition:background .2s ease;border-bottom:1px solid var(--el-border-color-lighter);min-width:-moz-fit-content;min-width:fit-content}.list-item[data-v-9968e9fe]:last-child{border-bottom:none}.list-item[data-v-9968e9fe]:hover{background:var(--el-fill-color-light)}.list-col[data-v-9968e9fe]{display:flex;align-items:center}.list-col-checkbox[data-v-9968e9fe]{justify-content:center;min-width:40px}.list-col-preview[data-v-9968e9fe]{justify-content:center;cursor:pointer}.list-col-name[data-v-9968e9fe]{cursor:pointer;overflow:hidden;padding-right:16px;min-width:0}.list-col-name[data-v-9968e9fe]:hover{color:#38bdf8}.filename-ellipsis[data-v-9968e9fe]{display:flex;max-width:100%;overflow:hidden;align-items:center}.filename-start[data-v-9968e9fe]{flex-shrink:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.filename-end[data-v-9968e9fe]{flex-shrink:0;white-space:nowrap}.list-col-channel-name[data-v-9968e9fe],.list-col-channel[data-v-9968e9fe],.list-col-date[data-v-9968e9fe],.list-col-size[data-v-9968e9fe]{font-size:13px;color:var(--el-text-color-secondary)}.list-col-address[data-v-9968e9fe]{font-size:13px}.address-box[data-v-9968e9fe],.channel-name-box[data-v-9968e9fe]{background:var(--el-fill-color-light);border:1px solid var(--el-border-color-lighter);border-radius:4px;padding:4px 8px;font-size:12px;color:var(--el-text-color-secondary);max-width:100%;overflow-x:auto;overflow-y:hidden;white-space:nowrap;scrollbar-width:none;-ms-overflow-style:none}.address-box[data-v-9968e9fe]{width:85px;font-family:Consolas,Monaco,monospace}.channel-name-box[data-v-9968e9fe]{width:70px}.address-box[data-v-9968e9fe]::-webkit-scrollbar,.channel-name-box[data-v-9968e9fe]::-webkit-scrollbar{display:none}.list-col-tags[data-v-9968e9fe]{display:flex;align-items:center;gap:4px;flex-wrap:nowrap;overflow:hidden}.custom-checkbox[data-v-9968e9fe]{width:18px;height:18px;border:2px solid var(--el-border-color);border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;background:transparent}.custom-checkbox[data-v-9968e9fe]:hover{border-color:#38bdf8}.custom-checkbox.checked[data-v-9968e9fe]{background:linear-gradient(135deg,#0ea5e9,#38bdf8);border-color:#38bdf8}.custom-checkbox .check-icon[data-v-9968e9fe]{font-size:10px;color:#fff}.color-tag[data-v-9968e9fe]{padding:2px 8px;border-radius:10px;font-size:11px;color:#fff;white-space:nowrap;max-width:60px;overflow:hidden;text-overflow:ellipsis;text-shadow:0 1px 2px rgba(0,0,0,.2)}.color-tag-more[data-v-9968e9fe]{min-width:30px;text-align:center}.list-empty[data-v-9968e9fe]{color:var(--el-text-color-placeholder)}.list-col-actions[data-v-9968e9fe]{display:flex;gap:8px;justify-content:flex-end}.list-preview-img[data-v-9968e9fe]{width:40px;height:40px;-o-object-fit:cover;object-fit:cover;border-radius:6px}.list-folder-icon[data-v-9968e9fe]{font-size:28px;color:var(--el-color-primary)}.list-file-icon[data-v-9968e9fe]{font-size:24px;color:var(--el-text-color-secondary)}.list-action-btn[data-v-9968e9fe]{width:32px;height:32px;border:none;border-radius:8px;background:var(--el-fill-color);color:var(--el-text-color-regular);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.list-action-btn[data-v-9968e9fe]:hover{background:#38bdf8;color:#fff}.list-action-danger[data-v-9968e9fe]:hover{background:var(--el-color-danger)}@media (max-width:768px){.list-item[data-v-9968e9fe]{grid-template-columns:28px 40px 1fr auto;padding:10px 8px;gap:8px}.list-col-address[data-v-9968e9fe],.list-col-channel-name[data-v-9968e9fe],.list-col-channel[data-v-9968e9fe],.list-col-date[data-v-9968e9fe],.list-col-size[data-v-9968e9fe],.list-col-tags[data-v-9968e9fe]{display:none}.list-col-actions[data-v-9968e9fe]{gap:4px}.list-action-btn[data-v-9968e9fe]{width:28px;height:28px}.list-col-checkbox[data-v-9968e9fe]{width:24px;min-width:24px}}.el-card{--el-card-border-color:var(--el-border-color-light);--el-card-border-radius:4px;--el-card-padding:20px;--el-card-bg-color:var(--el-fill-color-blank);background-color:var(--el-card-bg-color);border:1px solid var(--el-card-border-color);border-radius:var(--el-card-border-radius);color:var(--el-text-color-primary);display:flex;flex-direction:column;overflow:hidden;transition:var(--el-transition-duration)}.el-card.is-always-shadow,.el-card.is-hover-shadow:focus,.el-card.is-hover-shadow:hover{box-shadow:var(--el-box-shadow-light)}.el-card__header{border-bottom:1px solid var(--el-card-border-color);box-sizing:border-box;padding:calc(var(--el-card-padding) - 2px) var(--el-card-padding)}.el-card__body{flex:1;overflow:auto;padding:var(--el-card-padding)}.el-card__footer{border-top:1px solid var(--el-card-border-color);box-sizing:border-box;padding:calc(var(--el-card-padding) - 2px) var(--el-card-padding)}.el-checkbox{--el-checkbox-font-size:14px;--el-checkbox-font-weight:var(--el-font-weight-primary);--el-checkbox-text-color:var(--el-text-color-regular);--el-checkbox-input-height:14px;--el-checkbox-input-width:14px;--el-checkbox-border-radius:var(--el-border-radius-small);--el-checkbox-bg-color:var(--el-fill-color-blank);--el-checkbox-input-border:var(--el-border);--el-checkbox-disabled-border-color:var(--el-border-color);--el-checkbox-disabled-input-fill:var(--el-fill-color-light);--el-checkbox-disabled-icon-color:var(--el-text-color-placeholder);--el-checkbox-disabled-checked-input-fill:var(--el-border-color-extra-light);--el-checkbox-disabled-checked-input-border-color:var(--el-border-color);--el-checkbox-disabled-checked-icon-color:var(--el-text-color-placeholder);--el-checkbox-checked-text-color:var(--el-color-primary);--el-checkbox-checked-input-border-color:var(--el-color-primary);--el-checkbox-checked-bg-color:var(--el-color-primary);--el-checkbox-checked-icon-color:var(--el-color-white);--el-checkbox-input-border-color-hover:var(--el-color-primary);align-items:center;color:var(--el-checkbox-text-color);cursor:pointer;display:inline-flex;font-size:var(--el-font-size-base);font-weight:var(--el-checkbox-font-weight);height:var(--el-checkbox-height,32px);margin-right:30px;position:relative;-webkit-user-select:none;user-select:none;white-space:nowrap}.el-checkbox.is-disabled{cursor:not-allowed}.el-checkbox.is-bordered{border:var(--el-border);border-radius:var(--el-border-radius-base);box-sizing:border-box;padding:0 15px 0 9px}.el-checkbox.is-bordered.is-checked{border-color:var(--el-color-primary)}.el-checkbox.is-bordered.is-disabled{border-color:var(--el-border-color-lighter)}.el-checkbox.is-bordered.el-checkbox--large{border-radius:var(--el-border-radius-base);padding:0 19px 0 11px}.el-checkbox.is-bordered.el-checkbox--large .el-checkbox__label{font-size:var(--el-font-size-base)}.el-checkbox.is-bordered.el-checkbox--large .el-checkbox__inner{height:14px;width:14px}.el-checkbox.is-bordered.el-checkbox--small{border-radius:calc(var(--el-border-radius-base) - 1px);padding:0 11px 0 7px}.el-checkbox.is-bordered.el-checkbox--small .el-checkbox__label{font-size:12px}.el-checkbox.is-bordered.el-checkbox--small .el-checkbox__inner{height:12px;width:12px}.el-checkbox.is-bordered.el-checkbox--small .el-checkbox__inner:after{height:6px;width:2px}.el-checkbox input:focus-visible+.el-checkbox__inner{border-radius:var(--el-checkbox-border-radius);outline:2px solid var(--el-checkbox-input-border-color-hover);outline-offset:1px}.el-checkbox__input{cursor:pointer;display:inline-flex;outline:none;position:relative;white-space:nowrap}.el-checkbox__input.is-disabled .el-checkbox__inner{background-color:var(--el-checkbox-disabled-input-fill);border-color:var(--el-checkbox-disabled-border-color);cursor:not-allowed}.el-checkbox__input.is-disabled .el-checkbox__inner:after{border-color:var(--el-checkbox-disabled-icon-color);cursor:not-allowed}.el-checkbox__input.is-disabled.is-checked .el-checkbox__inner{background-color:var(--el-checkbox-disabled-checked-input-fill);border-color:var(--el-checkbox-disabled-checked-input-border-color)}.el-checkbox__input.is-disabled.is-checked .el-checkbox__inner:after{border-color:var(--el-checkbox-disabled-checked-icon-color)}.el-checkbox__input.is-disabled.is-indeterminate .el-checkbox__inner{background-color:var(--el-checkbox-disabled-checked-input-fill);border-color:var(--el-checkbox-disabled-checked-input-border-color)}.el-checkbox__input.is-disabled.is-indeterminate .el-checkbox__inner:before{background-color:var(--el-checkbox-disabled-checked-icon-color);border-color:var(--el-checkbox-disabled-checked-icon-color)}.el-checkbox__input.is-disabled+span.el-checkbox__label{color:var(--el-disabled-text-color);cursor:not-allowed}.el-checkbox__input.is-checked .el-checkbox__inner{background-color:var(--el-checkbox-checked-bg-color);border-color:var(--el-checkbox-checked-input-border-color)}.el-checkbox__input.is-checked .el-checkbox__inner:after{border-color:var(--el-checkbox-checked-icon-color);transform:translate(-45%,-60%) rotate(45deg) scaleY(1)}.el-checkbox__input.is-checked+.el-checkbox__label{color:var(--el-checkbox-checked-text-color)}.el-checkbox__input.is-focus:not(.is-checked) .el-checkbox__original:not(:focus-visible){border-color:var(--el-checkbox-input-border-color-hover)}.el-checkbox__input.is-indeterminate .el-checkbox__inner{background-color:var(--el-checkbox-checked-bg-color);border-color:var(--el-checkbox-checked-input-border-color)}.el-checkbox__input.is-indeterminate .el-checkbox__inner:before{background-color:var(--el-checkbox-checked-icon-color);content:"";display:block;height:2px;left:0;position:absolute;right:0;top:5px;transform:scale(.5)}.el-checkbox__input.is-indeterminate .el-checkbox__inner:after{display:none}.el-checkbox__inner{background-color:var(--el-checkbox-bg-color);border:var(--el-checkbox-input-border);border-radius:var(--el-checkbox-border-radius);box-sizing:border-box;display:inline-block;height:var(--el-checkbox-input-height);position:relative;transition:border-color .25s cubic-bezier(.71,-.46,.29,1.46),background-color .25s cubic-bezier(.71,-.46,.29,1.46),outline .25s cubic-bezier(.71,-.46,.29,1.46);width:var(--el-checkbox-input-width);z-index:var(--el-index-normal)}.el-checkbox__inner:hover{border-color:var(--el-checkbox-input-border-color-hover)}.el-checkbox__inner:after{border:1px solid transparent;border-left:0;border-top:0;box-sizing:content-box;content:"";height:7px;left:50%;position:absolute;top:50%;transform:translate(-45%,-60%) rotate(45deg) scaleY(0);transform-origin:center;transition:transform .15s ease-in .05s;width:3px}.el-checkbox__original{height:0;margin:0;opacity:0;outline:none;position:absolute;width:0;z-index:-1}.el-checkbox__label{display:inline-block;font-size:var(--el-checkbox-font-size);line-height:1;padding-left:8px}.el-checkbox.el-checkbox--large{height:40px}.el-checkbox.el-checkbox--large .el-checkbox__label{font-size:14px}.el-checkbox.el-checkbox--large .el-checkbox__inner{height:14px;width:14px}.el-checkbox.el-checkbox--small{height:24px}.el-checkbox.el-checkbox--small .el-checkbox__label{font-size:12px}.el-checkbox.el-checkbox--small .el-checkbox__inner{height:12px;width:12px}.el-checkbox.el-checkbox--small .el-checkbox__input.is-indeterminate .el-checkbox__inner:before{top:4px}.el-checkbox.el-checkbox--small .el-checkbox__inner:after{height:6px;width:2px}.el-checkbox:last-of-type{margin-right:0}.img-card[data-v-ddf49ce2]{width:100%;height:22vh;background:var(--admin-dashboard-imgcard-bg-color);border-radius:8px;box-shadow:var(--admin-dashboard-imgcard-shadow);overflow:hidden;position:relative;transition:transform .3s ease}.img-card[data-v-ddf49ce2] .el-card__body{padding:0;height:100%;overflow:hidden}.img-card[data-v-ddf49ce2] .el-checkbox{position:absolute;top:10px;right:10px;transform:scale(1.5);z-index:10}.img-card[data-v-ddf49ce2]:hover{transform:scale(1.05)}.image-preview[data-v-ddf49ce2],.video-preview[data-v-ddf49ce2]{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform .4s ease,opacity .3s ease;filter:var(--image-preview-filter)}.video-preview[data-v-ddf49ce2]{cursor:pointer}.img-card:hover .file-icon[data-v-ddf49ce2],.img-card:hover .image-preview[data-v-ddf49ce2],.img-card:hover .video-preview[data-v-ddf49ce2]{transform:scale(1.08)}.image-preview[data-v-ddf49ce2]:hover{opacity:.8}.file-short-info[data-v-ddf49ce2]{position:absolute;z-index:10;top:3px;left:3px;display:flex;gap:5px;align-items:start}.success-tag[data-v-ddf49ce2]{background-color:rgba(34,139,34,.6);border:1px solid rgba(34,139,34,.7);border-radius:6px}.fail-tag[data-v-ddf49ce2],.success-tag[data-v-ddf49ce2]{color:hsla(0,0%,100%,.95);padding:3px 8px;font-size:11px;font-weight:500;height:auto;line-height:1.2;text-shadow:0 1px 2px rgba(0,0,0,.3);backdrop-filter:blur(4px)}.fail-tag[data-v-ddf49ce2]{background-color:rgba(220,53,69,.6);border:1px solid rgba(220,53,69,.7);border-radius:6px}.primary-tag[data-v-ddf49ce2]{background-color:rgba(250,82,194,.6);color:hsla(0,0%,100%,.95);border:1px solid rgba(250,82,194,.7);padding:3px 8px;border-radius:6px;font-size:11px;font-weight:500;display:flex;align-items:center;height:auto;line-height:1.2;text-shadow:0 1px 2px rgba(0,0,0,.3);backdrop-filter:blur(4px)}.file-preview[data-v-ddf49ce2]{display:flex;justify-content:center;align-items:center;width:100%;height:100%}.file-icon[data-v-ddf49ce2]{opacity:.6;font-size:clamp(40px,4vw,64px);transition:transform .4s ease}.audio-icon[data-v-ddf49ce2]{color:var(--el-color-primary);opacity:.8}.audio-card-preview[data-v-ddf49ce2]{cursor:pointer}.card-bottom-overlay[data-v-ddf49ce2]{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,.7));padding:clamp(15px,2.5vh,30px) clamp(6px,1vw,12px) clamp(5px,.8vh,10px);display:flex;flex-direction:column;gap:clamp(3px,.5vh,6px);z-index:10}.file-name-row[data-v-ddf49ce2]{display:flex;align-items:center;justify-content:center}.file-name[data-v-ddf49ce2]{color:#fff;font-size:clamp(10px,1.1vw,14px);text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%;text-shadow:0 1px 3px rgba(0,0,0,.5)}.action-bar[data-v-ddf49ce2]{display:flex;justify-content:space-between;align-items:center;opacity:0;transform:translateY(4px);transition:all .25s cubic-bezier(.4,0,.2,1);pointer-events:none}.el-card:hover .action-bar[data-v-ddf49ce2]{opacity:1;transform:translateY(0);pointer-events:auto}.action-bar-left[data-v-ddf49ce2],.action-bar-right[data-v-ddf49ce2]{display:flex;align-items:center;gap:clamp(3px,.4vw,6px)}.action-btn[data-v-ddf49ce2]{width:clamp(24px,2.5vw,28px);height:clamp(24px,2.5vw,28px);border:none;border-radius:clamp(5px,.6vw,8px);background:hsla(0,0%,100%,.15);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;font-size:clamp(11px,1.1vw,14px)}.action-btn[data-v-ddf49ce2]:hover{background:hsla(0,0%,100%,.25);transform:scale(1.08)}.action-btn[data-v-ddf49ce2]:active{transform:scale(.95)}.action-btn-danger[data-v-ddf49ce2]:hover{background:rgba(239,68,68,.6)}@media (max-width:768px){.action-bar[data-v-ddf49ce2]{display:none!important}}@keyframes skeleton-shimmer-ddf49ce2{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton-wrapper[data-v-ddf49ce2]{width:100%;height:100%;background:linear-gradient(90deg,var(--skeleton-bg-color) 25%,color-mix(in srgb,var(--skeleton-bg-color) 70%,var(--skeleton-shimmer-color)) 50%,var(--skeleton-bg-color) 75%);background-size:200% 100%;animation:skeleton-shimmer-ddf49ce2 1.5s ease-in-out infinite}.error-wrapper[data-v-ddf49ce2]{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--skeleton-bg-color);cursor:pointer;gap:8px}.error-icon[data-v-ddf49ce2]{font-size:32px;color:var(--el-color-warning);opacity:.7}.error-text[data-v-ddf49ce2]{font-size:12px;color:var(--el-text-color-secondary)}.img-card[data-v-20e5d6b4]{width:100%;height:22vh;background:var(--admin-dashboard-imgcard-bg-color);border-radius:8px;box-shadow:var(--admin-dashboard-imgcard-shadow);overflow:hidden;position:relative;transition:transform .3s ease}.img-card[data-v-20e5d6b4] .el-card__body{padding:0;height:100%;overflow:hidden}.img-card[data-v-20e5d6b4] .el-checkbox{position:absolute;top:10px;right:10px;transform:scale(1.5);z-index:10}.img-card[data-v-20e5d6b4]:hover{transform:scale(1.05)}.folder-card[data-v-20e5d6b4]{cursor:pointer}.folder-icon[data-v-20e5d6b4]{display:flex;justify-content:center;align-items:center;width:100%;height:100%;color:var(--el-color-primary)}.folder-icon-svg[data-v-20e5d6b4]{font-size:clamp(40px,4vw,64px);transition:transform .4s ease}.img-card:hover .folder-icon-svg[data-v-20e5d6b4]{transform:scale(1.08)}.card-bottom-overlay[data-v-20e5d6b4]{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,.7));padding:clamp(15px,2.5vh,30px) clamp(6px,1vw,12px) clamp(5px,.8vh,10px);display:flex;flex-direction:column;gap:clamp(3px,.5vh,6px);z-index:10}.file-name-row[data-v-20e5d6b4]{display:flex;align-items:center;justify-content:center}.file-name[data-v-20e5d6b4]{color:#fff;font-size:clamp(10px,1.1vw,14px);text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%;text-shadow:0 1px 3px rgba(0,0,0,.5)}.action-bar[data-v-20e5d6b4]{display:flex;justify-content:space-between;align-items:center;opacity:0;transform:translateY(4px);transition:all .25s cubic-bezier(.4,0,.2,1);pointer-events:none}.el-card:hover .action-bar[data-v-20e5d6b4]{opacity:1;transform:translateY(0);pointer-events:auto}.action-bar-left[data-v-20e5d6b4],.action-bar-right[data-v-20e5d6b4]{display:flex;align-items:center;gap:clamp(3px,.4vw,6px)}.action-btn[data-v-20e5d6b4]{width:clamp(24px,2.5vw,28px);height:clamp(24px,2.5vw,28px);border:none;border-radius:clamp(5px,.6vw,8px);background:hsla(0,0%,100%,.15);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;font-size:clamp(11px,1.1vw,14px)}.action-btn[data-v-20e5d6b4]:hover{background:hsla(0,0%,100%,.25);transform:scale(1.08)}.action-btn[data-v-20e5d6b4]:active{transform:scale(.95)}.action-btn-danger[data-v-20e5d6b4]:hover{background:rgba(239,68,68,.6)}@media (max-width:768px){.action-bar[data-v-20e5d6b4]{display:none!important}}@keyframes skeleton-shimmer-71848b62{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes skeleton-pulse-71848b62{0%,to{opacity:.4}50%{opacity:.8}}.skeleton-card[data-v-71848b62]{width:100%;height:22vh;background:var(--admin-dashboard-imgcard-bg-color);border-radius:12px;box-shadow:var(--admin-dashboard-imgcard-shadow);overflow:hidden;position:relative}.skeleton-image[data-v-71848b62]{width:100%;height:100%;background:linear-gradient(90deg,var(--skeleton-bg-color) 25%,color-mix(in srgb,var(--skeleton-bg-color) 70%,var(--skeleton-shimmer-color)) 50%,var(--skeleton-bg-color) 75%);background-size:200% 100%;animation:skeleton-shimmer-71848b62 1.5s ease-in-out infinite}.skeleton-info[data-v-71848b62]{position:absolute;bottom:0;left:0;right:0;padding:15px;background:linear-gradient(transparent,rgba(0,0,0,.5))}.skeleton-text[data-v-71848b62]{height:14px;width:60%;margin:0 auto;border-radius:4px;background:linear-gradient(90deg,hsla(0,0%,100%,.1) 25%,hsla(0,0%,100%,.25) 50%,hsla(0,0%,100%,.1) 75%);background-size:200% 100%;animation:skeleton-shimmer-71848b62 1.5s ease-in-out infinite}.skeleton-list-item[data-v-71848b62]{animation:skeleton-pulse-71848b62 1.5s ease-in-out infinite}.skeleton-checkbox[data-v-71848b62]{width:18px;height:18px;border-radius:4px;background:var(--skeleton-bg-color)}.skeleton-preview[data-v-71848b62]{width:40px;height:40px;border-radius:6px;background:linear-gradient(90deg,var(--skeleton-bg-color) 25%,color-mix(in srgb,var(--skeleton-bg-color) 70%,var(--skeleton-shimmer-color)) 50%,var(--skeleton-bg-color) 75%);background-size:200% 100%;animation:skeleton-shimmer-71848b62 1.5s ease-in-out infinite}.skeleton-text-long[data-v-71848b62]{width:80%}.skeleton-text-long[data-v-71848b62],.skeleton-text-short[data-v-71848b62]{height:14px;border-radius:4px;background:linear-gradient(90deg,var(--skeleton-bg-color) 25%,color-mix(in srgb,var(--skeleton-bg-color) 70%,var(--skeleton-shimmer-color)) 50%,var(--skeleton-bg-color) 75%);background-size:200% 100%;animation:skeleton-shimmer-71848b62 1.5s ease-in-out infinite}.skeleton-text-short[data-v-71848b62]{width:60px}.skeleton-text-tiny[data-v-71848b62]{height:14px;width:40px;border-radius:4px}.skeleton-tag[data-v-71848b62],.skeleton-text-tiny[data-v-71848b62]{background:linear-gradient(90deg,var(--skeleton-bg-color) 25%,color-mix(in srgb,var(--skeleton-bg-color) 70%,var(--skeleton-shimmer-color)) 50%,var(--skeleton-bg-color) 75%);background-size:200% 100%;animation:skeleton-shimmer-71848b62 1.5s ease-in-out infinite}.skeleton-tag[data-v-71848b62]{height:20px;width:50px;border-radius:10px}.skeleton-actions[data-v-71848b62]{height:28px;width:80px;border-radius:6px;background:var(--skeleton-bg-color)}.list-item[data-v-71848b62]{display:grid;grid-template-columns:50px 60px minmax(180px,1fr) 130px 100px 110px 130px 80px 100px 120px;padding:12px 20px;align-items:center;border-bottom:1px solid var(--el-border-color-lighter)}.list-col[data-v-71848b62]{display:flex;align-items:center}.list-col-checkbox[data-v-71848b62],.list-col-preview[data-v-71848b62]{justify-content:center}@media (max-width:768px){.list-item[data-v-71848b62]{grid-template-columns:28px 40px 1fr auto;padding:10px 8px;gap:8px}.list-col-address[data-v-71848b62],.list-col-channel-name[data-v-71848b62],.list-col-channel[data-v-71848b62],.list-col-date[data-v-71848b62],.list-col-size[data-v-71848b62],.list-col-tags[data-v-71848b62]{display:none}}.el-breadcrumb{font-size:14px;line-height:1}.el-breadcrumb:after,.el-breadcrumb:before{content:"";display:table}.el-breadcrumb:after{clear:both}.el-breadcrumb__separator{color:var(--el-text-color-placeholder);font-weight:700;margin:0 9px}.el-breadcrumb__separator.el-icon{font-weight:400;margin:0 6px}.el-breadcrumb__separator.el-icon svg{vertical-align:middle}.el-breadcrumb__item{align-items:center;display:inline-flex;float:left}.el-breadcrumb__inner{color:var(--el-text-color-regular)}.el-breadcrumb__inner a,.el-breadcrumb__inner.is-link{color:var(--el-text-color-primary);font-weight:700;text-decoration:none;transition:var(--el-transition-color)}.el-breadcrumb__inner a:hover,.el-breadcrumb__inner.is-link:hover{color:var(--el-color-primary);cursor:pointer}.el-breadcrumb__item:last-child .el-breadcrumb__inner,.el-breadcrumb__item:last-child .el-breadcrumb__inner a,.el-breadcrumb__item:last-child .el-breadcrumb__inner a:hover,.el-breadcrumb__item:last-child .el-breadcrumb__inner:hover{color:var(--el-text-color-regular);cursor:text;font-weight:400}.el-breadcrumb__item:last-child .el-breadcrumb__separator{display:none}#themeToggle[data-v-4c6ec90c]{border:0;cursor:pointer;display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:.375rem;transition-property:background-color,border-color,color;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.theme_toggle_circle1[data-v-4c6ec90c]{transition:cx .5s ease-in-out,cy .5s ease-in-out,r .5s ease-in-out}.theme_toggle_circle2[data-v-4c6ec90c]{transition:all .5s ease-in-out;fill:var(--admin-theme-toggle-bg-color)}.theme_toggle_svg[data-v-4c6ec90c]{transition:transform .5s cubic-bezier(.68,-.55,.27,1.55);color:var(--admin-theme-toggle-color)}.dark.theme_toggle_svg[data-v-4c6ec90c]{transform:rotate(40deg)}.theme_toggle_g[data-v-4c6ec90c]{transition:opacity .5s ease-in-out}.icon-fade-enter-active[data-v-4c6ec90c],.icon-fade-leave-active[data-v-4c6ec90c]{transition:opacity .3s ease-in-out,transform .3s ease-in-out}.icon-fade-enter-from[data-v-4c6ec90c]{opacity:0;transform:scale(.8) rotate(-90deg)}.icon-fade-leave-to[data-v-4c6ec90c]{opacity:0;transform:scale(.8) rotate(90deg)}.icon-fade-enter-to[data-v-4c6ec90c],.icon-fade-leave-from[data-v-4c6ec90c]{opacity:1;transform:scale(1) rotate(0deg)}.auto-icon[data-v-4c6ec90c]{display:inline-block}.tabs[data-v-4673d77a]{display:flex;align-items:center;justify-content:center;gap:12px}.title[data-v-4673d77a]{display:flex;align-items:center;gap:10px;font-size:1.2em;font-weight:700;cursor:pointer;transition:all .3s ease;color:var(--admin-container-color);padding:6px 14px;border-radius:10px;background:linear-gradient(135deg,rgba(99,102,241,.08),rgba(139,92,246,.05));border:1px solid rgba(99,102,241,.15)}.title[data-v-4673d77a]:hover{background:linear-gradient(135deg,rgba(99,102,241,.15),rgba(139,92,246,.1));border-color:rgba(99,102,241,.25);transform:translateY(-1px)}.title .fa-images[data-v-4673d77a]{font-size:1em;color:var(--el-color-primary);background:linear-gradient(135deg,#6366f1,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.tabs-dropdown[data-v-4673d77a]{display:flex;align-items:center}.tabs-dropdown-link[data-v-4673d77a]{cursor:pointer;font-size:1.5em;transition:all .3s ease;color:var(--admin-container-color);padding:6px 10px;border-radius:8px;background:transparent}.tabs-dropdown-link.rotate-up[data-v-4673d77a],.tabs-dropdown-link[data-v-4673d77a]:hover{background:rgba(99,102,241,.1);color:var(--el-color-primary)}@media (max-width:768px){.title[data-v-4673d77a]{font-size:1.3em;padding:4px 10px;gap:6px}.tabs-dropdown-link[data-v-4673d77a]{font-size:1.3em;padding:4px 8px}}.el-dropdown__popper.el-popper.tabs-dropdown-popper{border-radius:12px;border:none;background-color:var(--tabs-dropdown-popper-bg-color);backdrop-filter:blur(10px);box-shadow:var(--tabs-dropdown-popper-shadow)}.el-dropdown__popper.el-popper.tabs-dropdown-popper .el-dropdown-menu{border:none;background:none}.el-dropdown__popper.el-popper.tabs-dropdown-popper .el-dropdown-menu__item{border:none;background:none;font-size:16px;font-weight:700;transition:font-size .3s ease}.el-dropdown__popper.el-popper.tabs-dropdown-popper .el-dropdown-menu__item:hover{font-size:18px}.container[data-v-6028d7b0]{background:var(--admin-container-bg-color);min-height:100vh;font-family:Arial,sans-serif;color:var(--admin-container-color);margin:0;padding:0}[data-v-6028d7b0] .el-container,[data-v-6028d7b0] .el-main{overflow:visible}[data-v-6028d7b0] .el-dialog{border-radius:12px;background-color:var(--dialog-bg-color);backdrop-filter:blur(10px);box-shadow:var(--dialog-box-shadow)}.header-content[data-v-6028d7b0]{display:flex;justify-content:space-between;align-items:center;padding:10px 24px;background:hsla(0,0%,100%,.72);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid hsla(0,0%,100%,.3);border-top:1px solid hsla(0,0%,100%,.5);box-shadow:0 4px 30px rgba(0,0,0,.1),0 1px 3px rgba(0,0,0,.05),inset 0 1px 0 hsla(0,0%,100%,.4);transition:all .4s cubic-bezier(.4,0,.2,1);border-radius:16px;position:fixed;top:8px;left:50%;transform:translateX(-50%);width:calc(95% - 16px);z-index:2001;min-height:45px}html.dark .header-content[data-v-6028d7b0]{background:rgba(30,30,30,.75);border:1px solid hsla(0,0%,100%,.08);border-top:1px solid hsla(0,0%,100%,.12);box-shadow:0 4px 30px rgba(0,0,0,.3),0 1px 3px rgba(0,0,0,.2),inset 0 1px 0 hsla(0,0%,100%,.05)}@media (max-width:768px){.header-content[data-v-6028d7b0]{flex-direction:column;top:6px;width:calc(100% - 32px);border-radius:14px;padding:6px 12px;gap:4px}.header-icon[data-v-6028d7b0]{font-size:.95em}.header-content .actions[data-v-6028d7b0]{gap:10px}.search-card[data-v-6028d7b0] .el-input__inner{height:28px;font-size:.85em;width:50vw}.search-card[data-v-6028d7b0] .el-input__wrapper{padding:0 10px}.search-card[data-v-6028d7b0] .el-input__inner:focus{width:65vw}}.header-content[data-v-6028d7b0]:hover{background:hsla(0,0%,100%,.82);box-shadow:0 8px 40px rgba(0,0,0,.12),0 2px 6px rgba(0,0,0,.08),inset 0 1px 0 hsla(0,0%,100%,.5);transform:translateX(-50%) translateY(-1px)}html.dark .header-content[data-v-6028d7b0]:hover{background:rgba(35,35,35,.85);box-shadow:0 8px 40px rgba(0,0,0,.4),0 2px 6px rgba(0,0,0,.3),inset 0 1px 0 hsla(0,0%,100%,.08)}.header-icon[data-v-6028d7b0]{font-size:1.5em;cursor:pointer;transition:all .3s ease;color:var(--admin-container-color);outline:none}.header-icon[data-v-6028d7b0]:hover{color:var(--admin-purple);transform:scale(1.2)}.breadcrumb-container[data-v-6028d7b0]{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0 10px;margin-bottom:4px}@media (max-width:768px){.breadcrumb-container[data-v-6028d7b0]{flex-direction:row;align-items:center;gap:8px;padding:0 5px;margin-bottom:2px}}.stats-badge[data-v-6028d7b0]{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:500;color:var(--el-text-color-secondary);background:var(--el-fill-color-light);padding:4px 10px;border-radius:12px;border:1px solid var(--el-border-color-lighter);transition:all .2s ease;white-space:nowrap;flex-shrink:0}.stats-badge[data-v-6028d7b0]:hover{background:var(--el-fill-color);color:var(--admin-purple);border-color:var(--admin-purple)}.stats-badge-icon[data-v-6028d7b0]{font-size:11px;opacity:.8}@media (max-width:768px){.stats-badge[data-v-6028d7b0]{font-size:10px;padding:2px 6px;border-radius:8px}.stats-badge-icon[data-v-6028d7b0]{font-size:9px}}.header-content .actions[data-v-6028d7b0]{display:flex;align-items:center;gap:15px}@media (max-width:768px){.header-content .actions[data-v-6028d7b0]{margin-top:10px}}.header-content .actions i[data-v-6028d7b0]{font-size:1.5em;cursor:pointer;transition:color .3s,transform .3s;color:var(--admin-container-color)}.header-content .actions i[data-v-6028d7b0]:hover{color:var(--admin-purple);transform:scale(1.2)}.header-content .actions .el-dropdown-link i[data-v-6028d7b0]{color:var(--admin-container-color)}.header-content .actions .el-dropdown-link i[data-v-6028d7b0]:hover{color:var(--admin-purple)}.header-content .actions .disabled[data-v-6028d7b0]{color:#bbb;pointer-events:none}.header-content .actions .enabled[data-v-6028d7b0]{color:var(--admin-purple)}.batch-action-item-icon[data-v-6028d7b0]{width:20px;margin-right:5px}.search-card[data-v-6028d7b0]{margin-left:auto;margin-right:20px}@media (max-width:768px){.search-card[data-v-6028d7b0]{margin-right:0;margin-left:0;margin-top:10px}}.search-card[data-v-6028d7b0] .el-input__wrapper{border-radius:20px;background:var(--admin-dashboard-search-card-bg-color);box-shadow:var(--admin-dashboard-search-card-box-shadow);transition:background-color .3s}.search-card[data-v-6028d7b0] .el-input__inner{width:300px;height:40px;font-size:1.2em;border:none;transition:width .3s;background:none}.search-card[data-v-6028d7b0] .el-input__inner::-moz-placeholder{color:var(--el-text-color-placeholder);font-style:italic;font-weight:400;font-size:14px;opacity:.6;letter-spacing:.5px;-moz-transition:all .3s ease;transition:all .3s ease}.search-card[data-v-6028d7b0] .el-input__inner::placeholder{color:var(--el-text-color-placeholder);font-style:italic;font-weight:400;font-size:14px;opacity:.6;letter-spacing:.5px;transition:all .3s ease}.search-card[data-v-6028d7b0] .el-input__inner:focus::-moz-placeholder{opacity:.4;transform:translateX(5px)}.search-card[data-v-6028d7b0] .el-input__inner:focus::placeholder{opacity:.4;transform:translateX(5px)}@media (max-width:768px){.search-card[data-v-6028d7b0] .el-input__inner{width:60vw}}.search-card[data-v-6028d7b0] .el-input__inner:focus{width:400px}@media (max-width:768px){.search-card[data-v-6028d7b0] .el-input__inner:focus{width:80vw}}.search-icon[data-v-6028d7b0]{cursor:pointer;color:var(--admin-container-color);transition:all .3s ease;font-size:1.3em;opacity:0;transform:scale(.8);pointer-events:none}.search-card:focus-within .search-icon[data-v-6028d7b0]{opacity:1;transform:scale(1);pointer-events:auto}.search-card:focus-within .search-icon[data-v-6028d7b0]:hover{color:var(--admin-purple);transform:scale(1.2)}.search-card[data-v-6028d7b0] .el-input__suffix{display:flex;align-items:center;right:10px}.main-container[data-v-6028d7b0]{display:flex;flex-direction:column;padding:20px 60px;min-height:calc(100vh - 80px)}@media (max-width:768px){.main-container[data-v-6028d7b0]{margin-top:12vh}}.content[data-v-6028d7b0]{display:grid;grid-template-columns:repeat(5,1fr);grid-template-rows:repeat(3,1fr);gap:20px;padding:10px;padding-bottom:0;flex-grow:1;min-height:80vh}@media (max-width:768px){.content[data-v-6028d7b0]{grid-template-columns:1fr;grid-template-rows:none}}.list-view[data-v-6028d7b0]{display:flex;flex-direction:column;gap:0;background:var(--admin-dashboard-imgcard-bg-color);border-radius:12px;overflow-x:auto;overflow-y:visible;box-shadow:var(--admin-dashboard-imgcard-shadow);margin-top:15px}.list-header[data-v-6028d7b0]{display:grid;grid-template-columns:50px 60px minmax(180px,1fr) 130px 100px 110px 130px 80px 100px 120px;padding:12px 20px;background:var(--admin-dashboard-stats-bg);font-weight:600;font-size:13px;color:var(--el-text-color-secondary);border-bottom:1px solid var(--el-border-color-lighter);min-width:-moz-fit-content;min-width:fit-content}.list-col[data-v-6028d7b0]{display:flex;align-items:center}.list-col-checkbox[data-v-6028d7b0]{justify-content:center;min-width:40px}.custom-checkbox[data-v-6028d7b0]{width:18px;height:18px;border:2px solid var(--el-border-color);border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;background:transparent}.custom-checkbox[data-v-6028d7b0]:hover{border-color:#38bdf8}.custom-checkbox.checked[data-v-6028d7b0],.custom-checkbox.indeterminate[data-v-6028d7b0]{background:linear-gradient(135deg,#0ea5e9,#38bdf8);border-color:#38bdf8}.custom-checkbox .check-icon[data-v-6028d7b0]{font-size:10px;color:#fff}@media (max-width:768px){.list-header[data-v-6028d7b0]{display:none}}.pagination-container[data-v-6028d7b0]{display:flex;justify-content:center;align-items:center;margin-top:20px;padding-bottom:20px;gap:15px;position:relative}.pagination-center[data-v-6028d7b0]{display:flex;align-items:center;gap:10px}.pagination-container[data-v-6028d7b0] .el-pagination{--el-pagination-button-bg-color:var(--admin-dashboard-btn-bg-color);--el-pagination-hover-color:var(--admin-purple)}.pagination-container[data-v-6028d7b0] .el-pager li{background:var(--admin-dashboard-btn-bg-color);border-radius:10px;margin:0 4px;min-width:36px;height:36px;line-height:36px;font-weight:500;border:none;box-shadow:var(--admin-dashboard-btn-shadow);transition:all .3s cubic-bezier(.4,0,.2,1)}.pagination-container[data-v-6028d7b0] .el-pager li:hover{color:#38bdf8;transform:translateY(-2px);box-shadow:var(--admin-dashboard-btn-hover-shadow)}.pagination-container[data-v-6028d7b0] .el-pager li.is-active{background:linear-gradient(135deg,#0ea5e9,#38bdf8)!important;color:#fff!important;border-radius:10px;box-shadow:var(--admin-dashboard-btn-shadow),0 4px 12px rgba(56,189,248,.3),inset 0 1px 0 hsla(0,0%,100%,.2);transition:all .3s cubic-bezier(.4,0,.2,1)}.pagination-container[data-v-6028d7b0] .el-pager li.is-active:hover{transform:translateY(-2px)!important;box-shadow:var(--admin-dashboard-btn-hover-shadow),0 6px 16px rgba(56,189,248,.4),inset 0 1px 0 hsla(0,0%,100%,.2)!important}.pagination-container[data-v-6028d7b0] .btn-next,.pagination-container[data-v-6028d7b0] .btn-prev{background:var(--admin-dashboard-btn-bg-color)!important;border-radius:10px!important;min-width:36px;height:36px;border:none;box-shadow:var(--admin-dashboard-btn-shadow);transition:all .3s cubic-bezier(.4,0,.2,1)}.pagination-container[data-v-6028d7b0] .btn-next:hover,.pagination-container[data-v-6028d7b0] .btn-prev:hover{color:#38bdf8;transform:translateY(-2px);box-shadow:var(--admin-dashboard-btn-hover-shadow)}.pagination-right[data-v-6028d7b0]{display:flex;align-items:center;gap:10px;position:absolute;right:0}.page-total[data-v-6028d7b0]{font-size:13px;color:var(--el-text-color-secondary);white-space:nowrap}.page-jump[data-v-6028d7b0]{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--el-text-color-secondary)}.page-jump .jump-input[data-v-6028d7b0]{width:50px}.page-jump .jump-input[data-v-6028d7b0] .el-input__wrapper{background:var(--admin-dashboard-btn-bg-color);box-shadow:var(--admin-dashboard-btn-shadow);border-radius:8px;padding:0 8px;height:28px}.page-jump .jump-input[data-v-6028d7b0] .el-input__inner{text-align:center;color:var(--el-text-color-primary);height:28px;line-height:28px}.page-jump .jump-btn[data-v-6028d7b0]{background:linear-gradient(135deg,#0ea5e9,#38bdf8);border:none;border-radius:8px;padding:0 12px;height:28px;font-size:12px;font-weight:600;color:#fff;box-shadow:0 2px 8px rgba(56,189,248,.3);transition:all .3s ease}.page-jump .jump-btn[data-v-6028d7b0]:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(56,189,248,.4)}@media (max-width:768px){.pagination-container[data-v-6028d7b0]{flex-direction:column;gap:12px;padding-bottom:15px}.pagination-center[data-v-6028d7b0]{order:0}.pagination-right[data-v-6028d7b0]{position:static;width:100%;justify-content:center;order:1}.page-jump .jump-input[data-v-6028d7b0]{width:45px}}.refresh-btn[data-v-6028d7b0]{cursor:pointer;background:var(--admin-dashboard-btn-bg-color);box-shadow:var(--admin-dashboard-btn-shadow);color:#38bdf8;border:none;border-radius:10px;width:36px;height:36px;min-width:36px;padding:0;display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .3s cubic-bezier(.4,0,.2,1)}.refresh-btn[data-v-6028d7b0]:hover{transform:translateY(-2px);box-shadow:var(--admin-dashboard-btn-hover-shadow);background:linear-gradient(135deg,#0ea5e9,#38bdf8);color:#fff}.load-more[data-v-6028d7b0]{cursor:pointer;background:linear-gradient(135deg,#0ea5e9,#38bdf8);box-shadow:0 4px 15px rgba(56,189,248,.3);color:#fff;border:none;border-radius:10px;height:36px;padding:0 16px;font-weight:500;transition:all .3s cubic-bezier(.4,0,.2,1)}.load-more[data-v-6028d7b0]:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(56,189,248,.5)}[data-v-6028d7b0] .btn-prev{left:8px}[data-v-6028d7b0] .btn-next,[data-v-6028d7b0] .btn-prev{border-radius:100%;position:fixed;top:50%;scale:1;color:var(--admin-dashboard-btn-color)}[data-v-6028d7b0] .btn-next{right:8px}@media (min-width:768px){[data-v-6028d7b0] .el-pagination.is-background .btn-next,[data-v-6028d7b0] .el-pagination.is-background .btn-prev{background-color:var(--admin-dashboard-btn-bg-color);backdrop-filter:blur(10px);box-shadow:var(--admin-dashboard-btn-shadow);transition:all .3s ease}[data-v-6028d7b0] .el-pagination.is-background .btn-next:hover,[data-v-6028d7b0] .el-pagination.is-background .btn-prev:hover{transform:translateY(-10%);box-shadow:var(--admin-dashboard-btn-hover-shadow)}}.question-icon[data-v-6028d7b0]{margin:0 3px}.breadcrumb[data-v-6028d7b0]{padding:8px 12px;background-color:var(--el-bg-color);border-radius:6px;font-size:.95em;box-shadow:var(--admin-dashboard-stats-shadow);transition:all .3s ease}.breadcrumb[data-v-6028d7b0]:hover{transform:translateY(-1px);box-shadow:var(--admin-dashboard-stats-hover-shadow)}.breadcrumb-home-icon[data-v-6028d7b0]{font-size:14px;color:#38bdf8;transition:color .2s ease}.breadcrumb-home-icon[data-v-6028d7b0]:hover{color:var(--admin-purple)}[data-v-6028d7b0] .el-breadcrumb__item{cursor:pointer}[data-v-6028d7b0] .el-breadcrumb__inner:hover{color:var(--el-color-primary)}.mobile-directory-trigger[data-v-6028d7b0]{display:none;align-items:center;gap:6px;padding:6px 10px;background:var(--el-fill-color-light);border-radius:8px;border:1px solid var(--el-border-color-lighter);cursor:pointer;transition:all .2s ease}.mobile-directory-trigger[data-v-6028d7b0]:active{background:var(--el-fill-color)}.mobile-directory-icon[data-v-6028d7b0]{font-size:12px;color:#38bdf8}.mobile-directory-path[data-v-6028d7b0]{font-size:12px;font-weight:500;color:var(--el-text-color-primary);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-directory-arrow[data-v-6028d7b0]{font-size:8px;color:var(--el-text-color-secondary)}.desktop-only[data-v-6028d7b0]{display:block}@media (max-width:768px){.mobile-directory-trigger[data-v-6028d7b0]{display:flex}.desktop-only[data-v-6028d7b0]{display:none!important}.breadcrumb-container[data-v-6028d7b0]{padding:0;margin-left:0}} \ No newline at end of file +.mobile-drawer-overlay[data-v-2d8e83ec]{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.4);z-index:2000;backdrop-filter:blur(4px)}.mobile-drawer[data-v-2d8e83ec]{position:absolute;top:22vh;left:8px;bottom:8px;width:280px;max-width:calc(85vw - 16px);background:var(--el-bg-color);border-radius:16px;box-shadow:0 8px 32px rgba(0,0,0,.2),0 2px 8px rgba(0,0,0,.1);display:flex;flex-direction:column;overflow:hidden}html.dark .mobile-drawer[data-v-2d8e83ec]{background:rgba(40,40,45,.98);box-shadow:0 8px 32px rgba(0,0,0,.4),0 2px 8px rgba(0,0,0,.3)}.mobile-drawer-header[data-v-2d8e83ec]{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:linear-gradient(135deg,rgba(56,189,248,.12),rgba(14,165,233,.08));border-bottom:1px solid var(--el-border-color-lighter)}.mobile-drawer-title[data-v-2d8e83ec]{font-size:15px;font-weight:600;color:#38bdf8;display:flex;align-items:center;gap:8px}.mobile-drawer-title[data-v-2d8e83ec]:before{content:"";display:inline-block;width:4px;height:16px;background:linear-gradient(180deg,#38bdf8,rgba(14,165,233,.5));border-radius:2px}.mobile-drawer-close[data-v-2d8e83ec]{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--el-text-color-secondary);cursor:pointer;border-radius:8px;transition:all .2s ease;background:transparent}.mobile-drawer-close[data-v-2d8e83ec]:active{background:var(--el-fill-color);color:var(--el-text-color-primary)}.mobile-drawer-content[data-v-2d8e83ec]{flex:1;overflow-y:auto;padding:8px}.mobile-drawer-item[data-v-2d8e83ec]{display:flex;align-items:center;gap:12px;padding:14px 16px;margin:2px 0;cursor:pointer;transition:all .2s ease;color:var(--el-text-color-primary);border-radius:10px;font-size:14px}.mobile-drawer-item[data-v-2d8e83ec]:active{background:var(--el-fill-color-light);transform:scale(.98)}.mobile-drawer-item.active[data-v-2d8e83ec]{background:linear-gradient(135deg,rgba(56,189,248,.2),rgba(14,165,233,.12));color:#38bdf8;font-weight:600}.mobile-drawer-item-icon[data-v-2d8e83ec]{font-size:18px;width:24px;text-align:center;opacity:.7}.mobile-drawer-item.active .mobile-drawer-item-icon[data-v-2d8e83ec]{opacity:1;color:#38bdf8}.mobile-drawer-back[data-v-2d8e83ec]{display:flex;align-items:center;gap:12px;padding:14px 16px;margin:8px 8px;border-radius:10px;background:var(--el-fill-color-lighter);cursor:pointer;transition:all .2s ease;color:var(--el-text-color-secondary);font-size:14px}.mobile-drawer-back[data-v-2d8e83ec]:active{background:var(--el-fill-color);color:var(--el-text-color-primary);transform:scale(.98)}.drawer-slide-enter-active[data-v-2d8e83ec]{transition:opacity .3s ease}.drawer-slide-leave-active[data-v-2d8e83ec]{transition:opacity .2s ease}.drawer-slide-enter-active .mobile-drawer[data-v-2d8e83ec]{animation:slideInLeft-2d8e83ec .3s ease-out}.drawer-slide-leave-active .mobile-drawer[data-v-2d8e83ec]{animation:slideOutLeft-2d8e83ec .2s ease-in}.drawer-slide-enter-from[data-v-2d8e83ec],.drawer-slide-leave-to[data-v-2d8e83ec]{opacity:0}@keyframes slideInLeft-2d8e83ec{0%{transform:translateX(-100%)}to{transform:translateX(0)}}@keyframes slideOutLeft-2d8e83ec{0%{transform:translateX(0)}to{transform:translateX(-100%)}}.bottom-sheet-overlay[data-v-7579ad69]{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:9999;display:flex;align-items:flex-end;justify-content:center}.bottom-sheet[data-v-7579ad69]{width:100%;max-width:100%;background:var(--bottom-sheet-bg,hsla(0,0%,100%,.95));backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:20px 20px 0 0;max-height:70vh;overflow:hidden;box-shadow:0 -4px 30px rgba(0,0,0,.15);border-top:1px solid var(--bottom-sheet-border,rgba(0,0,0,.05))}html.dark .bottom-sheet[data-v-7579ad69]{--bottom-sheet-bg:rgba(40,44,52,.95);--bottom-sheet-border:hsla(0,0%,100%,.1);box-shadow:0 -4px 30px rgba(0,0,0,.4)}.bottom-sheet-header[data-v-7579ad69]{display:flex;flex-direction:column;align-items:center;gap:12px;padding:16px 20px 12px;border-bottom:1px solid var(--el-border-color-lighter)}.bottom-sheet-handle[data-v-7579ad69]{width:40px;height:4px;background:var(--el-border-color);border-radius:2px}.bottom-sheet-title[data-v-7579ad69]{font-size:16px;font-weight:600;color:var(--el-text-color-primary);text-align:center;max-width:80%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}html.dark .bottom-sheet-title[data-v-7579ad69]{color:#f0f0f0}.bottom-sheet-content[data-v-7579ad69]{padding:12px 16px;padding-bottom:calc(20px + env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:8px}.bottom-sheet-item[data-v-7579ad69]{display:flex;align-items:center;gap:16px;padding:16px 20px;border-radius:14px;cursor:pointer;transition:all .2s ease;background:var(--bottom-sheet-item-bg,rgba(0,0,0,.04));color:var(--el-text-color-primary)}html.dark .bottom-sheet-item[data-v-7579ad69]{--bottom-sheet-item-bg:hsla(0,0%,100%,.08)}.bottom-sheet-item[data-v-7579ad69]:active{transform:scale(.98);background:var(--bottom-sheet-item-active-bg,rgba(0,0,0,.08))}html.dark .bottom-sheet-item[data-v-7579ad69]:active{--bottom-sheet-item-active-bg:hsla(0,0%,100%,.15)}.bottom-sheet-icon[data-v-7579ad69]{font-size:20px;width:28px;text-align:center;color:#38bdf8}.bottom-sheet-danger .bottom-sheet-icon[data-v-7579ad69],.bottom-sheet-danger[data-v-7579ad69]{color:var(--el-color-danger)}.bottom-sheet-enter-active[data-v-7579ad69]{transition:all .3s ease-out}.bottom-sheet-leave-active[data-v-7579ad69]{transition:all .2s ease-in}.bottom-sheet-enter-active .bottom-sheet[data-v-7579ad69]{animation:slideUp-7579ad69 .3s ease-out}.bottom-sheet-leave-active .bottom-sheet[data-v-7579ad69]{animation:slideDown-7579ad69 .2s ease-in}.bottom-sheet-enter-from[data-v-7579ad69],.bottom-sheet-leave-to[data-v-7579ad69]{opacity:0}.bottom-sheet-enter-from .bottom-sheet[data-v-7579ad69],.bottom-sheet-leave-to .bottom-sheet[data-v-7579ad69]{transform:translateY(100%)}@keyframes slideUp-7579ad69{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes slideDown-7579ad69{0%{transform:translateY(0)}to{transform:translateY(100%)}}:root{--el-popup-modal-bg-color:var(--el-color-black);--el-popup-modal-opacity:0.5}.v-modal-enter{animation:v-modal-in var(--el-transition-duration-fast) ease}.v-modal-leave{animation:v-modal-out var(--el-transition-duration-fast) ease forwards}@keyframes v-modal-in{0%{opacity:0}}@keyframes v-modal-out{to{opacity:0}}.v-modal{background:var(--el-popup-modal-bg-color);height:100%;left:0;opacity:var(--el-popup-modal-opacity);position:fixed;top:0;width:100%}.el-popup-parent--hidden{overflow:hidden}.el-dialog{--el-dialog-width:50%;--el-dialog-margin-top:15vh;--el-dialog-bg-color:var(--el-bg-color);--el-dialog-box-shadow:var(--el-box-shadow);--el-dialog-title-font-size:var(--el-font-size-large);--el-dialog-content-font-size:14px;--el-dialog-font-line-height:var(--el-font-line-height-primary);--el-dialog-padding-primary:16px;--el-dialog-border-radius:var(--el-border-radius-base);background:var(--el-dialog-bg-color);border-radius:var(--el-dialog-border-radius);box-shadow:var(--el-dialog-box-shadow);box-sizing:border-box;margin:var(--el-dialog-margin-top,15vh) auto 50px;overflow-wrap:break-word;padding:var(--el-dialog-padding-primary);position:relative;width:var(--el-dialog-width,50%)}.el-dialog:focus{outline:none!important}.el-dialog.is-align-center{margin:auto}.el-dialog.is-fullscreen{--el-dialog-width:100%;--el-dialog-margin-top:0;border-radius:0;height:100%;margin-bottom:0;overflow:auto}.el-dialog__wrapper{bottom:0;left:0;margin:0;overflow:auto;position:fixed;right:0;top:0}.el-dialog.is-draggable .el-dialog__header{cursor:move;-webkit-user-select:none;user-select:none}.el-dialog__header{padding-bottom:var(--el-dialog-padding-primary)}.el-dialog__header.show-close{padding-right:calc(var(--el-dialog-padding-primary) + var(--el-message-close-size, 16px))}.el-dialog__headerbtn{background:transparent;border:none;cursor:pointer;font-size:var(--el-message-close-size,16px);height:48px;outline:none;padding:0;position:absolute;right:0;top:0;width:48px}.el-dialog__headerbtn .el-dialog__close{color:var(--el-color-info);font-size:inherit}.el-dialog__headerbtn:focus .el-dialog__close,.el-dialog__headerbtn:hover .el-dialog__close{color:var(--el-color-primary)}.el-dialog__title{color:var(--el-text-color-primary);font-size:var(--el-dialog-title-font-size);line-height:var(--el-dialog-font-line-height)}.el-dialog__body{color:var(--el-text-color-regular);font-size:var(--el-dialog-content-font-size)}.el-dialog__footer{box-sizing:border-box;padding-top:var(--el-dialog-padding-primary);text-align:right}.el-dialog--center{text-align:center}.el-dialog--center .el-dialog__body{text-align:initial}.el-dialog--center .el-dialog__footer{text-align:inherit}.el-modal-dialog.is-penetrable{pointer-events:none}.el-modal-dialog.is-penetrable .el-dialog{pointer-events:auto}.el-overlay-dialog{bottom:0;left:0;overflow:auto;position:fixed;right:0;top:0}.dialog-fade-enter-active{animation:modal-fade-in var(--el-transition-duration)}.dialog-fade-enter-active .el-overlay-dialog{animation:dialog-fade-in var(--el-transition-duration)}.dialog-fade-leave-active{animation:modal-fade-out var(--el-transition-duration)}.dialog-fade-leave-active .el-overlay-dialog{animation:dialog-fade-out var(--el-transition-duration)}@keyframes dialog-fade-in{0%{opacity:0;transform:translate3d(0,-20px,0)}to{opacity:1;transform:translateZ(0)}}@keyframes dialog-fade-out{0%{opacity:1;transform:translateZ(0)}to{opacity:0;transform:translate3d(0,-20px,0)}}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-fade-out{0%{opacity:1}to{opacity:0}}.el-tabs{--el-tabs-header-height:40px;display:flex}.el-tabs__header{align-items:center;display:flex;justify-content:space-between;margin:0 0 15px;padding:0;position:relative}.el-tabs__header-vertical{flex-direction:column}.el-tabs__active-bar{background-color:var(--el-color-primary);bottom:0;height:2px;left:0;list-style:none;position:absolute;transition:width var(--el-transition-duration) var(--el-transition-function-ease-in-out-bezier),transform var(--el-transition-duration) var(--el-transition-function-ease-in-out-bezier);z-index:1}.el-tabs__active-bar.is-bottom{bottom:auto}.el-tabs__new-tab{align-items:center;border:1px solid var(--el-border-color);border-radius:3px;color:var(--el-text-color-primary);cursor:pointer;display:flex;flex-shrink:0;font-size:12px;height:20px;justify-content:center;line-height:20px;margin:10px 0 10px 10px;text-align:center;transition:all .15s;width:20px}.el-tabs__new-tab .is-icon-plus{height:inherit;transform:scale(.8);width:inherit}.el-tabs__new-tab .is-icon-plus svg{vertical-align:middle}.el-tabs__new-tab:hover{color:var(--el-color-primary)}.el-tabs__new-tab-vertical{margin-left:0}.el-tabs__nav-wrap{flex:1 auto;margin-bottom:-1px;overflow:hidden;position:relative}.el-tabs__nav-wrap:after{background-color:var(--el-border-color-light);bottom:0;content:"";height:2px;left:0;position:absolute;width:100%;z-index:var(--el-index-normal)}.el-tabs__nav-wrap.is-bottom:after{bottom:auto;top:0}.el-tabs__nav-wrap.is-scrollable{box-sizing:border-box;padding:0 20px}.el-tabs__nav-scroll{overflow:hidden}.el-tabs__nav-next,.el-tabs__nav-prev{color:var(--el-text-color-secondary);cursor:pointer;font-size:12px;line-height:44px;position:absolute;text-align:center;width:20px}.el-tabs__nav-next{right:0}.el-tabs__nav-prev{left:0}.el-tabs__nav{display:flex;float:left;position:relative;transition:transform var(--el-transition-duration);white-space:nowrap;z-index:calc(var(--el-index-normal) + 1)}.el-tabs__nav.is-stretch{display:flex;min-width:100%}.el-tabs__nav.is-stretch>*{flex:1;text-align:center}.el-tabs__item{align-items:center;box-sizing:border-box;color:var(--el-text-color-primary);display:flex;font-size:var(--el-font-size-base);font-weight:500;height:var(--el-tabs-header-height);justify-content:center;list-style:none;padding:0 20px;position:relative}.el-tabs__item:focus,.el-tabs__item:focus:active{outline:none}.el-tabs__item:focus-visible{border-radius:3px;box-shadow:0 0 2px 2px var(--el-color-primary) inset}.el-tabs__item .is-icon-close{border-radius:50%;margin-left:5px;text-align:center;transition:all var(--el-transition-duration) var(--el-transition-function-ease-in-out-bezier)}.el-tabs__item .is-icon-close:before{display:inline-block;transform:scale(.9)}.el-tabs__item .is-icon-close:hover{background-color:var(--el-text-color-placeholder);color:#fff}.el-tabs__item.is-active,.el-tabs__item:hover{color:var(--el-color-primary)}.el-tabs__item:hover{cursor:pointer}.el-tabs__item.is-disabled{color:var(--el-disabled-text-color);cursor:not-allowed}.el-tabs__content{flex-grow:1;overflow:hidden;position:relative}.el-tabs--bottom>.el-tabs__header .el-tabs__item:nth-child(2),.el-tabs--top>.el-tabs__header .el-tabs__item:nth-child(2){padding-left:0}.el-tabs--bottom>.el-tabs__header .el-tabs__item:last-child,.el-tabs--top>.el-tabs__header .el-tabs__item:last-child{padding-right:0}.el-tabs--bottom.el-tabs--border-card>.el-tabs__header .el-tabs__item:nth-child(2),.el-tabs--bottom.el-tabs--card>.el-tabs__header .el-tabs__item:nth-child(2),.el-tabs--top.el-tabs--border-card>.el-tabs__header .el-tabs__item:nth-child(2),.el-tabs--top.el-tabs--card>.el-tabs__header .el-tabs__item:nth-child(2){padding-left:20px}.el-tabs--bottom.el-tabs--border-card>.el-tabs__header .el-tabs__item:last-child,.el-tabs--bottom.el-tabs--card>.el-tabs__header .el-tabs__item:last-child,.el-tabs--top.el-tabs--border-card>.el-tabs__header .el-tabs__item:last-child,.el-tabs--top.el-tabs--card>.el-tabs__header .el-tabs__item:last-child{padding-right:20px}.el-tabs--card>.el-tabs__header{border-bottom:1px solid var(--el-border-color-light);box-sizing:border-box;height:var(--el-tabs-header-height)}.el-tabs--card>.el-tabs__header .el-tabs__nav-wrap:after{content:none}.el-tabs--card>.el-tabs__header .el-tabs__nav{border:1px solid var(--el-border-color-light);border-bottom:none;border-radius:4px 4px 0 0;box-sizing:border-box}.el-tabs--card>.el-tabs__header .el-tabs__active-bar{display:none}.el-tabs--card>.el-tabs__header .el-tabs__item .is-icon-close{font-size:12px;height:14px;overflow:hidden;position:relative;right:-2px;transform-origin:100% 50%;width:0}.el-tabs--card>.el-tabs__header .el-tabs__item{border-bottom:1px solid transparent;border-left:1px solid var(--el-border-color-light);margin-top:-1px;transition:color var(--el-transition-duration) var(--el-transition-function-ease-in-out-bezier),padding var(--el-transition-duration) var(--el-transition-function-ease-in-out-bezier)}.el-tabs--card>.el-tabs__header .el-tabs__item:first-child{border-left:none}.el-tabs--card>.el-tabs__header .el-tabs__item.is-closable:hover{padding-left:13px;padding-right:13px}.el-tabs--card>.el-tabs__header .el-tabs__item.is-closable:hover .is-icon-close{width:14px}.el-tabs--card>.el-tabs__header .el-tabs__item.is-active{border-bottom-color:var(--el-bg-color)}.el-tabs--card>.el-tabs__header .el-tabs__item.is-active.is-closable{padding-left:20px;padding-right:20px}.el-tabs--card>.el-tabs__header .el-tabs__item.is-active.is-closable .is-icon-close{width:14px}.el-tabs--border-card{background:var(--el-bg-color-overlay);border:1px solid var(--el-border-color)}.el-tabs--border-card>.el-tabs__content{padding:15px}.el-tabs--border-card>.el-tabs__header{background-color:var(--el-fill-color-light);border-bottom:1px solid var(--el-border-color-light);margin:0}.el-tabs--border-card>.el-tabs__header .el-tabs__nav-wrap:after{content:none}.el-tabs--border-card>.el-tabs__header .el-tabs__item{border:1px solid transparent;color:var(--el-text-color-secondary);margin-top:-1px;transition:all var(--el-transition-duration) var(--el-transition-function-ease-in-out-bezier)}.el-tabs--border-card>.el-tabs__header .el-tabs__item+.el-tabs__item,.el-tabs--border-card>.el-tabs__header .el-tabs__item:first-child{margin-left:-1px}.el-tabs--border-card>.el-tabs__header .el-tabs__item.is-active{background-color:var(--el-bg-color-overlay);border-left-color:var(--el-border-color);border-right-color:var(--el-border-color);color:var(--el-color-primary)}.el-tabs--border-card>.el-tabs__header .el-tabs__item:not(.is-disabled):hover{color:var(--el-color-primary)}.el-tabs--border-card>.el-tabs__header .el-tabs__item.is-disabled{color:var(--el-disabled-text-color)}.el-tabs--border-card>.el-tabs__header .is-scrollable .el-tabs__item:first-child{margin-left:0}.el-tabs--bottom{flex-direction:column}.el-tabs--bottom .el-tabs__header.is-bottom{margin-bottom:0;margin-top:10px}.el-tabs--bottom.el-tabs--border-card .el-tabs__header.is-bottom{border-bottom:0;border-top:1px solid var(--el-border-color)}.el-tabs--bottom.el-tabs--border-card .el-tabs__nav-wrap.is-bottom{margin-bottom:0;margin-top:-1px}.el-tabs--bottom.el-tabs--border-card .el-tabs__item.is-bottom:not(.is-active){border:1px solid transparent}.el-tabs--bottom.el-tabs--border-card .el-tabs__item.is-bottom{margin:0 -1px -1px}.el-tabs--left,.el-tabs--right{overflow:hidden}.el-tabs--left .el-tabs__header.is-left,.el-tabs--left .el-tabs__header.is-right,.el-tabs--left .el-tabs__nav-scroll,.el-tabs--left .el-tabs__nav-wrap.is-left,.el-tabs--left .el-tabs__nav-wrap.is-right,.el-tabs--right .el-tabs__header.is-left,.el-tabs--right .el-tabs__header.is-right,.el-tabs--right .el-tabs__nav-scroll,.el-tabs--right .el-tabs__nav-wrap.is-left,.el-tabs--right .el-tabs__nav-wrap.is-right{height:100%}.el-tabs--left .el-tabs__active-bar.is-left,.el-tabs--left .el-tabs__active-bar.is-right,.el-tabs--right .el-tabs__active-bar.is-left,.el-tabs--right .el-tabs__active-bar.is-right{bottom:auto;height:auto;top:0;width:2px}.el-tabs--left .el-tabs__nav-wrap.is-left,.el-tabs--left .el-tabs__nav-wrap.is-right,.el-tabs--right .el-tabs__nav-wrap.is-left,.el-tabs--right .el-tabs__nav-wrap.is-right{margin-bottom:0}.el-tabs--left .el-tabs__nav-wrap.is-left>.el-tabs__nav-next,.el-tabs--left .el-tabs__nav-wrap.is-left>.el-tabs__nav-prev,.el-tabs--left .el-tabs__nav-wrap.is-right>.el-tabs__nav-next,.el-tabs--left .el-tabs__nav-wrap.is-right>.el-tabs__nav-prev,.el-tabs--right .el-tabs__nav-wrap.is-left>.el-tabs__nav-next,.el-tabs--right .el-tabs__nav-wrap.is-left>.el-tabs__nav-prev,.el-tabs--right .el-tabs__nav-wrap.is-right>.el-tabs__nav-next,.el-tabs--right .el-tabs__nav-wrap.is-right>.el-tabs__nav-prev{cursor:pointer;height:30px;line-height:30px;text-align:center;width:100%}.el-tabs--left .el-tabs__nav-wrap.is-left>.el-tabs__nav-next i,.el-tabs--left .el-tabs__nav-wrap.is-left>.el-tabs__nav-prev i,.el-tabs--left .el-tabs__nav-wrap.is-right>.el-tabs__nav-next i,.el-tabs--left .el-tabs__nav-wrap.is-right>.el-tabs__nav-prev i,.el-tabs--right .el-tabs__nav-wrap.is-left>.el-tabs__nav-next i,.el-tabs--right .el-tabs__nav-wrap.is-left>.el-tabs__nav-prev i,.el-tabs--right .el-tabs__nav-wrap.is-right>.el-tabs__nav-next i,.el-tabs--right .el-tabs__nav-wrap.is-right>.el-tabs__nav-prev i{transform:rotate(90deg)}.el-tabs--left .el-tabs__nav-wrap.is-left>.el-tabs__nav-prev,.el-tabs--left .el-tabs__nav-wrap.is-right>.el-tabs__nav-prev,.el-tabs--right .el-tabs__nav-wrap.is-left>.el-tabs__nav-prev,.el-tabs--right .el-tabs__nav-wrap.is-right>.el-tabs__nav-prev{left:auto;top:0}.el-tabs--left .el-tabs__nav-wrap.is-left>.el-tabs__nav-next,.el-tabs--left .el-tabs__nav-wrap.is-right>.el-tabs__nav-next,.el-tabs--right .el-tabs__nav-wrap.is-left>.el-tabs__nav-next,.el-tabs--right .el-tabs__nav-wrap.is-right>.el-tabs__nav-next{bottom:0;right:auto}.el-tabs--left .el-tabs__nav-wrap.is-left.is-scrollable,.el-tabs--left .el-tabs__nav-wrap.is-right.is-scrollable,.el-tabs--right .el-tabs__nav-wrap.is-left.is-scrollable,.el-tabs--right .el-tabs__nav-wrap.is-right.is-scrollable{padding:30px 0}.el-tabs--left .el-tabs__nav-wrap.is-left:after,.el-tabs--left .el-tabs__nav-wrap.is-right:after,.el-tabs--right .el-tabs__nav-wrap.is-left:after,.el-tabs--right .el-tabs__nav-wrap.is-right:after{bottom:auto;height:100%;top:0;width:2px}.el-tabs--left .el-tabs__nav.is-left,.el-tabs--left .el-tabs__nav.is-right,.el-tabs--right .el-tabs__nav.is-left,.el-tabs--right .el-tabs__nav.is-right{flex-direction:column}.el-tabs--left .el-tabs__item.is-left,.el-tabs--right .el-tabs__item.is-left{justify-content:flex-end}.el-tabs--left .el-tabs__item.is-right,.el-tabs--right .el-tabs__item.is-right{justify-content:flex-start}.el-tabs--left{flex-direction:row}.el-tabs--left .el-tabs__header.is-left{margin-bottom:0;margin-right:10px}.el-tabs--left .el-tabs__nav-wrap.is-left{margin-right:-1px}.el-tabs--left .el-tabs__active-bar.is-left,.el-tabs--left .el-tabs__nav-wrap.is-left:after{left:auto;right:0}.el-tabs--left .el-tabs__item.is-left{text-align:right}.el-tabs--left.el-tabs--card .el-tabs__active-bar.is-left{display:none}.el-tabs--left.el-tabs--card .el-tabs__item.is-left{border-bottom:none;border-left:none;border-right:1px solid var(--el-border-color-light);border-top:1px solid var(--el-border-color-light);text-align:left}.el-tabs--left.el-tabs--card .el-tabs__item.is-left:first-child{border-right:1px solid var(--el-border-color-light);border-top:none}.el-tabs--left.el-tabs--card .el-tabs__item.is-left.is-active{border:1px solid var(--el-border-color-light);border-bottom:none;border-left:none;border-right:1px solid #fff}.el-tabs--left.el-tabs--card .el-tabs__item.is-left.is-active:first-child{border-top:none}.el-tabs--left.el-tabs--card .el-tabs__item.is-left.is-active:last-child{border-bottom:none}.el-tabs--left.el-tabs--card .el-tabs__nav{border-bottom:1px solid var(--el-border-color-light);border-radius:4px 0 0 4px;border-right:none}.el-tabs--left.el-tabs--card .el-tabs__new-tab{float:none}.el-tabs--left.el-tabs--border-card .el-tabs__header.is-left{border-right:1px solid var(--el-border-color)}.el-tabs--left.el-tabs--border-card .el-tabs__item.is-left{border:1px solid transparent;margin:-1px 0 -1px -1px}.el-tabs--left.el-tabs--border-card .el-tabs__item.is-left.is-active{border-color:#d1dbe5 transparent}.el-tabs--left>.el-tabs__content+.el-tabs__header{order:-1}.el-tabs--right .el-tabs__header.is-right{margin-bottom:0;margin-left:10px}.el-tabs--right .el-tabs__nav-wrap.is-right{margin-left:-1px}.el-tabs--right .el-tabs__nav-wrap.is-right:after{left:0;right:auto}.el-tabs--right .el-tabs__active-bar.is-right{left:0}.el-tabs--right.el-tabs--card .el-tabs__active-bar.is-right{display:none}.el-tabs--right.el-tabs--card .el-tabs__item.is-right{border-bottom:none;border-top:1px solid var(--el-border-color-light)}.el-tabs--right.el-tabs--card .el-tabs__item.is-right:first-child{border-left:1px solid var(--el-border-color-light);border-top:none}.el-tabs--right.el-tabs--card .el-tabs__item.is-right.is-active{border:1px solid var(--el-border-color-light);border-bottom:none;border-left:1px solid #fff;border-right:none}.el-tabs--right.el-tabs--card .el-tabs__item.is-right.is-active:first-child{border-top:none}.el-tabs--right.el-tabs--card .el-tabs__item.is-right.is-active:last-child{border-bottom:none}.el-tabs--right.el-tabs--card .el-tabs__nav{border-bottom:1px solid var(--el-border-color-light);border-left:none;border-radius:0 4px 4px 0}.el-tabs--right.el-tabs--border-card .el-tabs__header.is-right{border-left:1px solid var(--el-border-color)}.el-tabs--right.el-tabs--border-card .el-tabs__item.is-right{border:1px solid transparent;margin:-1px -1px -1px 0}.el-tabs--right.el-tabs--border-card .el-tabs__item.is-right.is-active{border-color:#d1dbe5 transparent}.el-tabs--top{flex-direction:column}.el-tabs--top>.el-tabs__content+.el-tabs__header{order:-1}.slideInLeft-transition,.slideInRight-transition{display:inline-block}.slideInRight-enter{animation:slideInRight-enter var(--el-transition-duration)}.slideInRight-leave{animation:slideInRight-leave var(--el-transition-duration);left:0;position:absolute;right:0}.slideInLeft-enter{animation:slideInLeft-enter var(--el-transition-duration)}.slideInLeft-leave{animation:slideInLeft-leave var(--el-transition-duration);left:0;position:absolute;right:0}@keyframes slideInRight-enter{0%{opacity:0;transform:translateX(100%);transform-origin:0 0}to{opacity:1;transform:translateX(0);transform-origin:0 0}}@keyframes slideInRight-leave{0%{opacity:1;transform:translateX(0);transform-origin:0 0}to{opacity:0;transform:translateX(100%);transform-origin:0 0}}@keyframes slideInLeft-enter{0%{opacity:0;transform:translateX(-100%);transform-origin:0 0}to{opacity:1;transform:translateX(0);transform-origin:0 0}}@keyframes slideInLeft-leave{0%{opacity:1;transform:translateX(0);transform-origin:0 0}to{opacity:0;transform:translateX(-100%);transform-origin:0 0}}.el-alert{--el-alert-padding:8px 16px;--el-alert-border-radius-base:var(--el-border-radius-base);--el-alert-title-font-size:14px;--el-alert-title-with-description-font-size:16px;--el-alert-description-font-size:14px;--el-alert-close-font-size:16px;--el-alert-close-customed-font-size:14px;--el-alert-icon-size:16px;--el-alert-icon-large-size:28px;align-items:center;background-color:var(--el-color-white);border-radius:var(--el-alert-border-radius-base);box-sizing:border-box;display:flex;margin:0;opacity:1;overflow:hidden;padding:var(--el-alert-padding);position:relative;transition:opacity var(--el-transition-duration-fast);width:100%}.el-alert.is-light .el-alert__close-btn{color:var(--el-text-color-placeholder)}.el-alert.is-dark .el-alert__close-btn,.el-alert.is-dark .el-alert__description{color:var(--el-color-white)}.el-alert.is-center{justify-content:center}.el-alert--primary{--el-alert-bg-color:var(--el-color-primary-light-9)}.el-alert--primary.is-light{background-color:var(--el-alert-bg-color)}.el-alert--primary.is-light,.el-alert--primary.is-light .el-alert__description{color:var(--el-color-primary)}.el-alert--primary.is-dark{background-color:var(--el-color-primary);color:var(--el-color-white)}.el-alert--success{--el-alert-bg-color:var(--el-color-success-light-9)}.el-alert--success.is-light{background-color:var(--el-alert-bg-color)}.el-alert--success.is-light,.el-alert--success.is-light .el-alert__description{color:var(--el-color-success)}.el-alert--success.is-dark{background-color:var(--el-color-success);color:var(--el-color-white)}.el-alert--info{--el-alert-bg-color:var(--el-color-info-light-9)}.el-alert--info.is-light{background-color:var(--el-alert-bg-color)}.el-alert--info.is-light,.el-alert--info.is-light .el-alert__description{color:var(--el-color-info)}.el-alert--info.is-dark{background-color:var(--el-color-info);color:var(--el-color-white)}.el-alert--warning{--el-alert-bg-color:var(--el-color-warning-light-9)}.el-alert--warning.is-light{background-color:var(--el-alert-bg-color)}.el-alert--warning.is-light,.el-alert--warning.is-light .el-alert__description{color:var(--el-color-warning)}.el-alert--warning.is-dark{background-color:var(--el-color-warning);color:var(--el-color-white)}.el-alert--error{--el-alert-bg-color:var(--el-color-error-light-9)}.el-alert--error.is-light{background-color:var(--el-alert-bg-color)}.el-alert--error.is-light,.el-alert--error.is-light .el-alert__description{color:var(--el-color-error)}.el-alert--error.is-dark{background-color:var(--el-color-error);color:var(--el-color-white)}.el-alert__content{display:flex;flex-direction:column;gap:4px}.el-alert .el-alert__icon{font-size:var(--el-alert-icon-size);margin-right:8px;width:var(--el-alert-icon-size)}.el-alert .el-alert__icon.is-big{font-size:var(--el-alert-icon-large-size);margin-right:12px;width:var(--el-alert-icon-large-size)}.el-alert__title{font-size:var(--el-alert-title-font-size);line-height:24px}.el-alert__title.with-description{font-size:var(--el-alert-title-with-description-font-size)}.el-alert .el-alert__description{font-size:var(--el-alert-description-font-size);margin:0}.el-alert .el-alert__close-btn{cursor:pointer;font-size:var(--el-alert-close-font-size);opacity:1;position:absolute;right:16px;top:12px}.el-alert .el-alert__close-btn.is-customed{font-size:var(--el-alert-close-customed-font-size);font-style:normal;line-height:24px;top:8px}.el-alert-fade-enter-from,.el-alert-fade-leave-active{opacity:0}.batch-tag-container[data-v-dacf7742]{padding:0}.tab-content[data-v-dacf7742]{padding:20px}.tab-description[data-v-dacf7742]{margin:0 0 15px 0;color:#606266;font-size:14px}.input-section[data-v-dacf7742]{position:relative;margin-bottom:20px}.suggestions-panel[data-v-dacf7742]{position:absolute;top:100%;left:0;right:0;background:var(--admin-dashboard-tag-suggestion-bg-color);border:1px solid var(--admin-dashboard-tag-suggestion-border-color);border-radius:4px;box-shadow:var(--admin-dashboard-tag-suggestion-box-shadow);max-height:200px;overflow-y:auto;z-index:1000;margin-top:4px}.suggestion-item[data-v-dacf7742]{padding:8px 12px;cursor:pointer;transition:background-color .2s}.suggestion-item[data-v-dacf7742]:hover{background-color:var(--admin-dashboard-tag-suggestion-item-hover-bg-color)}.common-tags-section[data-v-dacf7742],.tags-to-add-section[data-v-dacf7742]{margin-bottom:20px}.common-tags-section h4[data-v-dacf7742],.tags-to-add-section h4[data-v-dacf7742]{margin:0 0 10px 0;font-size:14px;color:#606266}.tags-container[data-v-dacf7742]{display:flex;flex-wrap:wrap;gap:8px;min-height:40px}.tag-item[data-v-dacf7742]{cursor:default}.empty-message[data-v-dacf7742]{color:#909399;font-size:13px;padding:10px 0}.action-buttons[data-v-dacf7742]{margin-top:20px;display:flex;justify-content:flex-end}.tag-management-container[data-v-8b4291b4]{padding:10px 0}.input-section[data-v-8b4291b4]{position:relative;margin-bottom:20px}.suggestions-panel[data-v-8b4291b4]{position:absolute;top:100%;left:0;right:0;background:var(--admin-dashboard-tag-suggestion-bg-color);border:1px solid var(--admin-dashboard-tag-suggestion-border-color);border-radius:4px;box-shadow:var(--admin-dashboard-tag-suggestion-box-shadow);max-height:200px;overflow-y:auto;z-index:1000;margin-top:4px}.suggestion-item[data-v-8b4291b4]{padding:8px 12px;cursor:pointer;transition:background-color .2s}.suggestion-item[data-v-8b4291b4]:hover{background-color:var(--admin-dashboard-tag-suggestion-item-hover-bg-color)}.current-tags-section[data-v-8b4291b4],.popular-tags-section[data-v-8b4291b4]{margin-bottom:20px}.current-tags-section h4[data-v-8b4291b4],.popular-tags-section h4[data-v-8b4291b4]{margin:0 0 10px 0;font-size:14px;color:#606266}.tags-container[data-v-8b4291b4]{display:flex;flex-wrap:wrap;gap:8px;min-height:40px}.tag-item[data-v-8b4291b4]{cursor:default}.tag-item.clickable[data-v-8b4291b4]{cursor:pointer;transition:transform .2s}.tag-item.clickable[data-v-8b4291b4]:hover{transform:translateY(-2px)}.empty-message[data-v-8b4291b4]{color:#909399;font-size:13px;padding:10px 0}.dialog-footer[data-v-8b4291b4]{display:flex;justify-content:flex-end}.el-radio{--el-radio-font-size:var(--el-font-size-base);--el-radio-text-color:var(--el-text-color-regular);--el-radio-font-weight:var(--el-font-weight-primary);--el-radio-input-height:14px;--el-radio-input-width:14px;--el-radio-input-border-radius:var(--el-border-radius-circle);--el-radio-input-bg-color:var(--el-fill-color-blank);--el-radio-input-border:var(--el-border);--el-radio-input-border-color:var(--el-border-color);--el-radio-input-border-color-hover:var(--el-color-primary);align-items:center;color:var(--el-radio-text-color);cursor:pointer;display:inline-flex;font-size:var(--el-font-size-base);font-weight:var(--el-radio-font-weight);height:32px;margin-right:30px;outline:none;position:relative;-webkit-user-select:none;user-select:none;white-space:nowrap}.el-radio.el-radio--large{height:40px}.el-radio.el-radio--small{height:24px}.el-radio.is-bordered{border:var(--el-border);border-radius:var(--el-border-radius-base);box-sizing:border-box;padding:0 15px 0 9px}.el-radio.is-bordered.is-checked{border-color:var(--el-color-primary)}.el-radio.is-bordered.is-disabled{border-color:var(--el-border-color-lighter);cursor:not-allowed}.el-radio.is-bordered.el-radio--large{border-radius:var(--el-border-radius-base);padding:0 19px 0 11px}.el-radio.is-bordered.el-radio--large .el-radio__label{font-size:var(--el-font-size-base)}.el-radio.is-bordered.el-radio--large .el-radio__inner{height:14px;width:14px}.el-radio.is-bordered.el-radio--small{border-radius:var(--el-border-radius-base);padding:0 11px 0 7px}.el-radio.is-bordered.el-radio--small .el-radio__label{font-size:12px}.el-radio.is-bordered.el-radio--small .el-radio__inner{height:12px;width:12px}.el-radio:last-child{margin-right:0}.el-radio__input{cursor:pointer;display:inline-flex;outline:none;position:relative;vertical-align:middle;white-space:nowrap}.el-radio__input.is-disabled .el-radio__inner{border-color:var(--el-disabled-border-color)}.el-radio__input.is-disabled .el-radio__inner,.el-radio__input.is-disabled .el-radio__inner:after{background-color:var(--el-disabled-bg-color);cursor:not-allowed}.el-radio__input.is-disabled .el-radio__inner+.el-radio__label{cursor:not-allowed}.el-radio__input.is-disabled.is-checked .el-radio__inner{background-color:var(--el-disabled-bg-color);border-color:var(--el-disabled-border-color)}.el-radio__input.is-disabled.is-checked .el-radio__inner:after{background-color:var(--el-text-color-placeholder)}.el-radio__input.is-disabled+span.el-radio__label{color:var(--el-text-color-placeholder);cursor:not-allowed}.el-radio__input.is-checked .el-radio__inner{background:var(--el-color-primary);border-color:var(--el-color-primary)}.el-radio__input.is-checked .el-radio__inner:after{background-color:var(--el-color-white);transform:translate(-50%,-50%) scale(1)}.el-radio__input.is-checked+.el-radio__label{color:var(--el-color-primary)}.el-radio__input.is-focus .el-radio__inner{border-color:var(--el-radio-input-border-color-hover)}.el-radio__inner{background-color:var(--el-radio-input-bg-color);border:var(--el-radio-input-border);border-radius:var(--el-radio-input-border-radius);box-sizing:border-box;cursor:pointer;display:inline-block;height:var(--el-radio-input-height);position:relative;width:var(--el-radio-input-width)}.el-radio__inner:hover{border-color:var(--el-radio-input-border-color-hover)}.el-radio__inner:after{border-radius:var(--el-radio-input-border-radius);content:"";height:4px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%) scale(0);transition:transform .15s ease-in;width:4px}.el-radio__original{bottom:0;left:0;margin:0;opacity:0;outline:none;position:absolute;right:0;top:0;z-index:-1}.el-radio__original:focus-visible+.el-radio__inner{border-radius:var(--el-radio-input-border-radius);outline:2px solid var(--el-radio-input-border-color-hover);outline-offset:1px}.el-radio:focus:not(:focus-visible):not(.is-focus):not(:active):not(.is-disabled) .el-radio__inner{box-shadow:0 0 2px 2px var(--el-radio-input-border-color-hover)}.el-radio__label{font-size:var(--el-radio-font-size);padding-left:8px}.el-radio.el-radio--large .el-radio__label{font-size:14px}.el-radio.el-radio--large .el-radio__inner{height:14px;width:14px}.el-radio.el-radio--small .el-radio__label{font-size:12px}.el-radio.el-radio--small .el-radio__inner{height:12px;width:12px}.el-radio-group{align-items:center;display:inline-flex;flex-wrap:wrap;font-size:0}.el-descriptions{--el-descriptions-table-border:1px solid var(--el-border-color-lighter);--el-descriptions-item-bordered-label-background:var(--el-fill-color-light);box-sizing:border-box;color:var(--el-text-color-primary);font-size:var(--el-font-size-base)}.el-descriptions__header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.el-descriptions__title{color:var(--el-text-color-primary);font-size:16px;font-weight:700}.el-descriptions__body{background-color:var(--el-fill-color-blank)}.el-descriptions__body .el-descriptions__table{border-collapse:collapse;width:100%}.el-descriptions__body .el-descriptions__table .el-descriptions__cell{box-sizing:border-box;font-size:14px;line-height:23px;text-align:left}.el-descriptions__body .el-descriptions__table .el-descriptions__cell.is-left{text-align:left}.el-descriptions__body .el-descriptions__table .el-descriptions__cell.is-center{text-align:center}.el-descriptions__body .el-descriptions__table .el-descriptions__cell.is-right{text-align:right}.el-descriptions__body .el-descriptions__table.is-bordered .el-descriptions__cell{border:var(--el-descriptions-table-border);padding:8px 11px}.el-descriptions__body .el-descriptions__table:not(.is-bordered) .el-descriptions__cell{padding-bottom:12px}.el-descriptions--large{font-size:14px}.el-descriptions--large .el-descriptions__header{margin-bottom:20px}.el-descriptions--large .el-descriptions__header .el-descriptions__title{font-size:16px}.el-descriptions--large .el-descriptions__body .el-descriptions__table .el-descriptions__cell{font-size:14px}.el-descriptions--large .el-descriptions__body .el-descriptions__table.is-bordered .el-descriptions__cell{padding:12px 15px}.el-descriptions--large .el-descriptions__body .el-descriptions__table:not(.is-bordered) .el-descriptions__cell{padding-bottom:16px}.el-descriptions--small{font-size:12px}.el-descriptions--small .el-descriptions__header{margin-bottom:12px}.el-descriptions--small .el-descriptions__header .el-descriptions__title{font-size:14px}.el-descriptions--small .el-descriptions__body .el-descriptions__table .el-descriptions__cell{font-size:12px}.el-descriptions--small .el-descriptions__body .el-descriptions__table.is-bordered .el-descriptions__cell{padding:4px 7px}.el-descriptions--small .el-descriptions__body .el-descriptions__table:not(.is-bordered) .el-descriptions__cell{padding-bottom:8px}.el-descriptions__label.el-descriptions__cell.is-bordered-label{background:var(--el-descriptions-item-bordered-label-background);color:var(--el-text-color-regular);font-weight:700}.el-descriptions__label:not(.is-bordered-label){color:var(--el-text-color-primary);margin-right:16px}.el-descriptions__label.el-descriptions__cell:not(.is-bordered-label).is-vertical-label{padding-bottom:6px}.el-descriptions__content.el-descriptions__cell.is-bordered-content{color:var(--el-text-color-primary)}.el-descriptions__content:not(.is-bordered-label){color:var(--el-text-color-regular)}.el-descriptions--large .el-descriptions__label:not(.is-bordered-label){margin-right:16px}.el-descriptions--large .el-descriptions__label.el-descriptions__cell:not(.is-bordered-label).is-vertical-label{padding-bottom:8px}.el-descriptions--small .el-descriptions__label:not(.is-bordered-label){margin-right:12px}.el-descriptions--small .el-descriptions__label.el-descriptions__cell:not(.is-bordered-label).is-vertical-label{padding-bottom:4px}.el-image__error,.el-image__inner,.el-image__placeholder,.el-image__wrapper{height:100%;width:100%}.el-image{display:inline-block;overflow:hidden;position:relative}.el-image__inner{opacity:1;vertical-align:top}.el-image__inner.is-loading{opacity:0}.el-image__wrapper{left:0;position:absolute;top:0}.el-image__error,.el-image__placeholder{background:var(--el-fill-color-light)}.el-image__error{align-items:center;color:var(--el-text-color-placeholder);display:flex;font-size:14px;justify-content:center;vertical-align:middle}.el-image__preview{cursor:pointer}.el-image-viewer__wrapper{bottom:0;left:0;position:fixed;right:0;top:0}.el-image-viewer__wrapper:focus{outline:none!important}.el-image-viewer__btn{align-items:center;border-radius:50%;box-sizing:border-box;cursor:pointer;display:flex;justify-content:center;opacity:.8;position:absolute;-webkit-user-select:none;user-select:none;z-index:1}.el-image-viewer__btn .el-icon{cursor:pointer}.el-image-viewer__close{font-size:40px;height:40px;right:40px;top:40px;width:40px}.el-image-viewer__canvas{align-items:center;display:flex;height:100%;justify-content:center;position:static;-webkit-user-select:none;user-select:none;width:100%}.el-image-viewer__actions{background-color:var(--el-text-color-regular);border-color:#fff;border-radius:22px;bottom:30px;height:44px;left:50%;padding:0 23px;transform:translateX(-50%)}.el-image-viewer__actions__inner{align-items:center;color:#fff;cursor:default;display:flex;font-size:23px;gap:22px;height:100%;justify-content:space-around;padding:0 6px;width:100%}.el-image-viewer__actions__divider{margin:0 -6px}.el-image-viewer__progress{bottom:90px;color:#fff;cursor:default;left:50%;transform:translateX(-50%)}.el-image-viewer__prev{left:40px}.el-image-viewer__next,.el-image-viewer__prev{background-color:var(--el-text-color-regular);border-color:#fff;color:#fff;font-size:24px;height:44px;top:50%;transform:translateY(-50%);width:44px}.el-image-viewer__next{right:40px;text-indent:2px}.el-image-viewer__close{background-color:var(--el-text-color-regular);border-color:#fff;color:#fff;font-size:24px;height:44px;width:44px}.el-image-viewer__mask{background:#000;height:100%;left:0;opacity:.5;position:absolute;top:0;width:100%}.el-image-viewer-parent--hidden{overflow:hidden}.viewer-fade-enter-active{animation:viewer-fade-in var(--el-transition-duration)}.viewer-fade-leave-active{animation:viewer-fade-out var(--el-transition-duration)}@keyframes viewer-fade-in{0%{opacity:0;transform:translate3d(0,-20px,0)}to{opacity:1;transform:translateZ(0)}}@keyframes viewer-fade-out{0%{opacity:1;transform:translateZ(0)}to{opacity:0;transform:translate3d(0,-20px,0)}}.detail-actions[data-v-0dc381fc]{display:flex;justify-content:right;margin-bottom:10px;flex-wrap:wrap;gap:8px}.detail-action[data-v-0dc381fc]{margin-left:0!important}.video-preview[data-v-0dc381fc]{max-height:300px;cursor:pointer;-o-object-fit:contain;object-fit:contain}.audio-preview[data-v-0dc381fc],.video-preview[data-v-0dc381fc]{width:100%;max-width:400px;border-radius:8px}.image-preview[data-v-0dc381fc]{width:auto;height:auto;max-width:100%;max-height:300px;border-radius:8px;cursor:pointer}.image-preview[data-v-0dc381fc] img{max-width:100%;max-height:300px;-o-object-fit:contain;object-fit:contain}.file-icon-detail[data-v-0dc381fc]{font-size:64px;color:var(--el-text-color-secondary)}.preview-section[data-v-0dc381fc]{display:flex;justify-content:center;margin-bottom:15px;padding:12px;background:var(--el-fill-color-light);border-radius:8px;min-height:60px}.preview-content[data-v-0dc381fc]{display:flex;justify-content:center;align-items:center;width:100%}[data-v-0dc381fc] .description-item{word-break:break-all;word-wrap:break-word}[data-v-0dc381fc] .el-descriptions__label{width:120px!important;min-width:100px!important;max-width:120px!important}@media (max-width:768px){.detail-actions[data-v-0dc381fc]{justify-content:center}}.el-container{box-sizing:border-box;display:flex;flex:1;flex-basis:auto;flex-direction:row;min-width:0}.el-container.is-vertical{flex-direction:column}.el-aside{overflow:auto;width:var(--el-aside-width,300px)}.el-aside,.el-footer{box-sizing:border-box;flex-shrink:0}.el-footer{--el-footer-padding:0 20px;--el-footer-height:60px;height:var(--el-footer-height);padding:var(--el-footer-padding)}.el-header{--el-header-padding:0 20px;--el-header-height:60px;flex-shrink:0;height:var(--el-header-height);padding:var(--el-header-padding)}.el-header,.el-main{box-sizing:border-box}.el-main{--el-main-padding:20px;display:block;flex:1;flex-basis:auto;overflow:auto;padding:var(--el-main-padding)}.el-pagination{--el-pagination-font-size:14px;--el-pagination-bg-color:var(--el-fill-color-blank);--el-pagination-text-color:var(--el-text-color-primary);--el-pagination-border-radius:2px;--el-pagination-button-color:var(--el-text-color-primary);--el-pagination-button-width:32px;--el-pagination-button-height:32px;--el-pagination-button-disabled-color:var(--el-text-color-placeholder);--el-pagination-button-disabled-bg-color:var(--el-fill-color-blank);--el-pagination-button-bg-color:var(--el-fill-color);--el-pagination-hover-color:var(--el-color-primary);--el-pagination-font-size-small:12px;--el-pagination-button-width-small:24px;--el-pagination-button-height-small:24px;--el-pagination-button-width-large:40px;--el-pagination-button-height-large:40px;--el-pagination-item-gap:16px;align-items:center;color:var(--el-pagination-text-color);display:flex;font-size:var(--el-pagination-font-size);font-weight:400;white-space:nowrap}.el-pagination .el-input__inner{-moz-appearance:textfield;text-align:center}.el-pagination .el-select{width:128px}.el-pagination .btn-next,.el-pagination .btn-prev{align-items:center;background:var(--el-pagination-bg-color);border:none;border-radius:var(--el-pagination-border-radius);box-sizing:border-box;color:var(--el-pagination-button-color);cursor:pointer;display:flex;font-size:var(--el-pagination-font-size);height:var(--el-pagination-button-height);justify-content:center;line-height:var(--el-pagination-button-height);min-width:var(--el-pagination-button-width);padding:0 4px;text-align:center}.el-pagination .btn-next *,.el-pagination .btn-prev *{pointer-events:none}.el-pagination .btn-next:focus,.el-pagination .btn-prev:focus{outline:none}.el-pagination .btn-next:hover,.el-pagination .btn-prev:hover{color:var(--el-pagination-hover-color)}.el-pagination .btn-next.is-active,.el-pagination .btn-prev.is-active{color:var(--el-pagination-hover-color);cursor:default;font-weight:700}.el-pagination .btn-next.is-active.is-disabled,.el-pagination .btn-prev.is-active.is-disabled{color:var(--el-text-color-secondary);font-weight:700}.el-pagination .btn-next.is-disabled,.el-pagination .btn-next:disabled,.el-pagination .btn-prev.is-disabled,.el-pagination .btn-prev:disabled{background-color:var(--el-pagination-button-disabled-bg-color);color:var(--el-pagination-button-disabled-color);cursor:not-allowed}.el-pagination .btn-next:focus-visible,.el-pagination .btn-prev:focus-visible{outline:1px solid var(--el-pagination-hover-color);outline-offset:-1px}.el-pagination .btn-next .el-icon,.el-pagination .btn-prev .el-icon{display:block;font-size:12px;font-weight:700;width:inherit}.el-pagination>.is-first{margin-left:0!important}.el-pagination>.is-last{margin-right:0!important}.el-pagination .btn-prev{margin-left:var(--el-pagination-item-gap)}.el-pagination__sizes,.el-pagination__total{color:var(--el-text-color-regular);font-weight:400;margin-left:var(--el-pagination-item-gap)}.el-pagination__total[disabled=true]{color:var(--el-text-color-placeholder)}.el-pagination__jump{align-items:center;color:var(--el-text-color-regular);display:flex;font-weight:400;margin-left:var(--el-pagination-item-gap)}.el-pagination__jump[disabled=true]{color:var(--el-text-color-placeholder)}.el-pagination__goto{margin-right:8px}.el-pagination__editor{box-sizing:border-box;text-align:center}.el-pagination__editor.el-input{width:56px}.el-pagination__editor .el-input__inner::-webkit-inner-spin-button,.el-pagination__editor .el-input__inner::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.el-pagination__classifier{margin-left:8px}.el-pagination__rightwrapper{align-items:center;display:flex;flex:1;justify-content:flex-end}.el-pagination.is-background .btn-next,.el-pagination.is-background .btn-prev,.el-pagination.is-background .el-pager li{background-color:var(--el-pagination-button-bg-color);margin:0 4px}.el-pagination.is-background .btn-next.is-active,.el-pagination.is-background .btn-prev.is-active,.el-pagination.is-background .el-pager li.is-active{background-color:var(--el-color-primary);color:var(--el-color-white)}.el-pagination.is-background .btn-next.is-disabled,.el-pagination.is-background .btn-next:disabled,.el-pagination.is-background .btn-prev.is-disabled,.el-pagination.is-background .btn-prev:disabled,.el-pagination.is-background .el-pager li.is-disabled,.el-pagination.is-background .el-pager li:disabled{background-color:var(--el-disabled-bg-color);color:var(--el-text-color-placeholder)}.el-pagination.is-background .btn-next.is-disabled.is-active,.el-pagination.is-background .btn-next:disabled.is-active,.el-pagination.is-background .btn-prev.is-disabled.is-active,.el-pagination.is-background .btn-prev:disabled.is-active,.el-pagination.is-background .el-pager li.is-disabled.is-active,.el-pagination.is-background .el-pager li:disabled.is-active{background-color:var(--el-fill-color-dark);color:var(--el-text-color-secondary)}.el-pagination.is-background .btn-prev{margin-left:var(--el-pagination-item-gap)}.el-pagination--small .btn-next,.el-pagination--small .btn-prev,.el-pagination--small .el-pager li{font-size:var(--el-pagination-font-size-small);height:var(--el-pagination-button-height-small);line-height:var(--el-pagination-button-height-small);min-width:var(--el-pagination-button-width-small)}.el-pagination--small button,.el-pagination--small span:not([class*=suffix]){font-size:var(--el-pagination-font-size-small)}.el-pagination--small .el-select{width:100px}.el-pagination--large .btn-next,.el-pagination--large .btn-prev,.el-pagination--large .el-pager li{height:var(--el-pagination-button-height-large);line-height:var(--el-pagination-button-height-large);min-width:var(--el-pagination-button-width-large)}.el-pagination--large .el-select .el-input{width:160px}.el-pager{font-size:0;list-style:none;margin:0;padding:0;-webkit-user-select:none;user-select:none}.el-pager,.el-pager li{align-items:center;display:flex}.el-pager li{background:var(--el-pagination-bg-color);border:none;border-radius:var(--el-pagination-border-radius);box-sizing:border-box;color:var(--el-pagination-button-color);cursor:pointer;font-size:var(--el-pagination-font-size);height:var(--el-pagination-button-height);justify-content:center;line-height:var(--el-pagination-button-height);min-width:var(--el-pagination-button-width);padding:0 4px;text-align:center}.el-pager li *{pointer-events:none}.el-pager li:focus{outline:none}.el-pager li.is-active,.el-pager li:hover{color:var(--el-pagination-hover-color)}.el-pager li.is-active{cursor:default;font-weight:700}.el-pager li.is-active.is-disabled{color:var(--el-text-color-secondary);font-weight:700}.el-pager li.is-disabled,.el-pager li:disabled{background-color:var(--el-pagination-button-disabled-bg-color);color:var(--el-pagination-button-disabled-color);cursor:not-allowed}.el-pager li:focus-visible{outline:1px solid var(--el-pagination-hover-color);outline-offset:-1px}.list-item[data-v-9968e9fe]{display:grid;grid-template-columns:50px 60px minmax(180px,1fr) 130px 100px 110px 130px 80px 100px 120px;padding:12px 20px;align-items:center;transition:background .2s ease;border-bottom:1px solid var(--el-border-color-lighter);min-width:-moz-fit-content;min-width:fit-content}.list-item[data-v-9968e9fe]:last-child{border-bottom:none}.list-item[data-v-9968e9fe]:hover{background:var(--el-fill-color-light)}.list-col[data-v-9968e9fe]{display:flex;align-items:center}.list-col-checkbox[data-v-9968e9fe]{justify-content:center;min-width:40px}.list-col-preview[data-v-9968e9fe]{justify-content:center;cursor:pointer}.list-col-name[data-v-9968e9fe]{cursor:pointer;overflow:hidden;padding-right:16px;min-width:0}.list-col-name[data-v-9968e9fe]:hover{color:#38bdf8}.filename-ellipsis[data-v-9968e9fe]{display:flex;max-width:100%;overflow:hidden;align-items:center}.filename-start[data-v-9968e9fe]{flex-shrink:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.filename-end[data-v-9968e9fe]{flex-shrink:0;white-space:nowrap}.list-col-channel-name[data-v-9968e9fe],.list-col-channel[data-v-9968e9fe],.list-col-date[data-v-9968e9fe],.list-col-size[data-v-9968e9fe]{font-size:13px;color:var(--el-text-color-secondary)}.list-col-address[data-v-9968e9fe]{font-size:13px}.address-box[data-v-9968e9fe],.channel-name-box[data-v-9968e9fe]{background:var(--el-fill-color-light);border:1px solid var(--el-border-color-lighter);border-radius:4px;padding:4px 8px;font-size:12px;color:var(--el-text-color-secondary);max-width:100%;overflow-x:auto;overflow-y:hidden;white-space:nowrap;scrollbar-width:none;-ms-overflow-style:none}.address-box[data-v-9968e9fe]{width:85px;font-family:Consolas,Monaco,monospace}.channel-name-box[data-v-9968e9fe]{width:70px}.address-box[data-v-9968e9fe]::-webkit-scrollbar,.channel-name-box[data-v-9968e9fe]::-webkit-scrollbar{display:none}.list-col-tags[data-v-9968e9fe]{display:flex;align-items:center;gap:4px;flex-wrap:nowrap;overflow:hidden}.custom-checkbox[data-v-9968e9fe]{width:18px;height:18px;border:2px solid var(--el-border-color);border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;background:transparent}.custom-checkbox[data-v-9968e9fe]:hover{border-color:#38bdf8}.custom-checkbox.checked[data-v-9968e9fe]{background:linear-gradient(135deg,#0ea5e9,#38bdf8);border-color:#38bdf8}.custom-checkbox .check-icon[data-v-9968e9fe]{font-size:10px;color:#fff}.color-tag[data-v-9968e9fe]{padding:2px 8px;border-radius:10px;font-size:11px;color:#fff;white-space:nowrap;max-width:60px;overflow:hidden;text-overflow:ellipsis;text-shadow:0 1px 2px rgba(0,0,0,.2)}.color-tag-more[data-v-9968e9fe]{min-width:30px;text-align:center}.list-empty[data-v-9968e9fe]{color:var(--el-text-color-placeholder)}.list-col-actions[data-v-9968e9fe]{display:flex;gap:8px;justify-content:flex-end}.list-preview-img[data-v-9968e9fe]{width:40px;height:40px;-o-object-fit:cover;object-fit:cover;border-radius:6px}.list-folder-icon[data-v-9968e9fe]{font-size:28px;color:var(--el-color-primary)}.list-file-icon[data-v-9968e9fe]{font-size:24px;color:var(--el-text-color-secondary)}.list-action-btn[data-v-9968e9fe]{width:32px;height:32px;border:none;border-radius:8px;background:var(--el-fill-color);color:var(--el-text-color-regular);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.list-action-btn[data-v-9968e9fe]:hover{background:#38bdf8;color:#fff}.list-action-danger[data-v-9968e9fe]:hover{background:var(--el-color-danger)}@media (max-width:768px){.list-item[data-v-9968e9fe]{grid-template-columns:28px 40px 1fr auto;padding:10px 8px;gap:8px}.list-col-address[data-v-9968e9fe],.list-col-channel-name[data-v-9968e9fe],.list-col-channel[data-v-9968e9fe],.list-col-date[data-v-9968e9fe],.list-col-size[data-v-9968e9fe],.list-col-tags[data-v-9968e9fe]{display:none}.list-col-actions[data-v-9968e9fe]{gap:4px}.list-action-btn[data-v-9968e9fe]{width:28px;height:28px}.list-col-checkbox[data-v-9968e9fe]{width:24px;min-width:24px}}.el-card{--el-card-border-color:var(--el-border-color-light);--el-card-border-radius:4px;--el-card-padding:20px;--el-card-bg-color:var(--el-fill-color-blank);background-color:var(--el-card-bg-color);border:1px solid var(--el-card-border-color);border-radius:var(--el-card-border-radius);color:var(--el-text-color-primary);display:flex;flex-direction:column;overflow:hidden;transition:var(--el-transition-duration)}.el-card.is-always-shadow,.el-card.is-hover-shadow:focus,.el-card.is-hover-shadow:hover{box-shadow:var(--el-box-shadow-light)}.el-card__header{border-bottom:1px solid var(--el-card-border-color);box-sizing:border-box;padding:calc(var(--el-card-padding) - 2px) var(--el-card-padding)}.el-card__body{flex:1;overflow:auto;padding:var(--el-card-padding)}.el-card__footer{border-top:1px solid var(--el-card-border-color);box-sizing:border-box;padding:calc(var(--el-card-padding) - 2px) var(--el-card-padding)}.el-checkbox{--el-checkbox-font-size:14px;--el-checkbox-font-weight:var(--el-font-weight-primary);--el-checkbox-text-color:var(--el-text-color-regular);--el-checkbox-input-height:14px;--el-checkbox-input-width:14px;--el-checkbox-border-radius:var(--el-border-radius-small);--el-checkbox-bg-color:var(--el-fill-color-blank);--el-checkbox-input-border:var(--el-border);--el-checkbox-disabled-border-color:var(--el-border-color);--el-checkbox-disabled-input-fill:var(--el-fill-color-light);--el-checkbox-disabled-icon-color:var(--el-text-color-placeholder);--el-checkbox-disabled-checked-input-fill:var(--el-border-color-extra-light);--el-checkbox-disabled-checked-input-border-color:var(--el-border-color);--el-checkbox-disabled-checked-icon-color:var(--el-text-color-placeholder);--el-checkbox-checked-text-color:var(--el-color-primary);--el-checkbox-checked-input-border-color:var(--el-color-primary);--el-checkbox-checked-bg-color:var(--el-color-primary);--el-checkbox-checked-icon-color:var(--el-color-white);--el-checkbox-input-border-color-hover:var(--el-color-primary);align-items:center;color:var(--el-checkbox-text-color);cursor:pointer;display:inline-flex;font-size:var(--el-font-size-base);font-weight:var(--el-checkbox-font-weight);height:var(--el-checkbox-height,32px);margin-right:30px;position:relative;-webkit-user-select:none;user-select:none;white-space:nowrap}.el-checkbox.is-disabled{cursor:not-allowed}.el-checkbox.is-bordered{border:var(--el-border);border-radius:var(--el-border-radius-base);box-sizing:border-box;padding:0 15px 0 9px}.el-checkbox.is-bordered.is-checked{border-color:var(--el-color-primary)}.el-checkbox.is-bordered.is-disabled{border-color:var(--el-border-color-lighter)}.el-checkbox.is-bordered.el-checkbox--large{border-radius:var(--el-border-radius-base);padding:0 19px 0 11px}.el-checkbox.is-bordered.el-checkbox--large .el-checkbox__label{font-size:var(--el-font-size-base)}.el-checkbox.is-bordered.el-checkbox--large .el-checkbox__inner{height:14px;width:14px}.el-checkbox.is-bordered.el-checkbox--small{border-radius:calc(var(--el-border-radius-base) - 1px);padding:0 11px 0 7px}.el-checkbox.is-bordered.el-checkbox--small .el-checkbox__label{font-size:12px}.el-checkbox.is-bordered.el-checkbox--small .el-checkbox__inner{height:12px;width:12px}.el-checkbox.is-bordered.el-checkbox--small .el-checkbox__inner:after{height:6px;width:2px}.el-checkbox input:focus-visible+.el-checkbox__inner{border-radius:var(--el-checkbox-border-radius);outline:2px solid var(--el-checkbox-input-border-color-hover);outline-offset:1px}.el-checkbox__input{cursor:pointer;display:inline-flex;outline:none;position:relative;white-space:nowrap}.el-checkbox__input.is-disabled .el-checkbox__inner{background-color:var(--el-checkbox-disabled-input-fill);border-color:var(--el-checkbox-disabled-border-color);cursor:not-allowed}.el-checkbox__input.is-disabled .el-checkbox__inner:after{border-color:var(--el-checkbox-disabled-icon-color);cursor:not-allowed}.el-checkbox__input.is-disabled.is-checked .el-checkbox__inner{background-color:var(--el-checkbox-disabled-checked-input-fill);border-color:var(--el-checkbox-disabled-checked-input-border-color)}.el-checkbox__input.is-disabled.is-checked .el-checkbox__inner:after{border-color:var(--el-checkbox-disabled-checked-icon-color)}.el-checkbox__input.is-disabled.is-indeterminate .el-checkbox__inner{background-color:var(--el-checkbox-disabled-checked-input-fill);border-color:var(--el-checkbox-disabled-checked-input-border-color)}.el-checkbox__input.is-disabled.is-indeterminate .el-checkbox__inner:before{background-color:var(--el-checkbox-disabled-checked-icon-color);border-color:var(--el-checkbox-disabled-checked-icon-color)}.el-checkbox__input.is-disabled+span.el-checkbox__label{color:var(--el-disabled-text-color);cursor:not-allowed}.el-checkbox__input.is-checked .el-checkbox__inner{background-color:var(--el-checkbox-checked-bg-color);border-color:var(--el-checkbox-checked-input-border-color)}.el-checkbox__input.is-checked .el-checkbox__inner:after{border-color:var(--el-checkbox-checked-icon-color);transform:translate(-45%,-60%) rotate(45deg) scaleY(1)}.el-checkbox__input.is-checked+.el-checkbox__label{color:var(--el-checkbox-checked-text-color)}.el-checkbox__input.is-focus:not(.is-checked) .el-checkbox__original:not(:focus-visible){border-color:var(--el-checkbox-input-border-color-hover)}.el-checkbox__input.is-indeterminate .el-checkbox__inner{background-color:var(--el-checkbox-checked-bg-color);border-color:var(--el-checkbox-checked-input-border-color)}.el-checkbox__input.is-indeterminate .el-checkbox__inner:before{background-color:var(--el-checkbox-checked-icon-color);content:"";display:block;height:2px;left:0;position:absolute;right:0;top:5px;transform:scale(.5)}.el-checkbox__input.is-indeterminate .el-checkbox__inner:after{display:none}.el-checkbox__inner{background-color:var(--el-checkbox-bg-color);border:var(--el-checkbox-input-border);border-radius:var(--el-checkbox-border-radius);box-sizing:border-box;display:inline-block;height:var(--el-checkbox-input-height);position:relative;transition:border-color .25s cubic-bezier(.71,-.46,.29,1.46),background-color .25s cubic-bezier(.71,-.46,.29,1.46),outline .25s cubic-bezier(.71,-.46,.29,1.46);width:var(--el-checkbox-input-width);z-index:var(--el-index-normal)}.el-checkbox__inner:hover{border-color:var(--el-checkbox-input-border-color-hover)}.el-checkbox__inner:after{border:1px solid transparent;border-left:0;border-top:0;box-sizing:content-box;content:"";height:7px;left:50%;position:absolute;top:50%;transform:translate(-45%,-60%) rotate(45deg) scaleY(0);transform-origin:center;transition:transform .15s ease-in .05s;width:3px}.el-checkbox__original{height:0;margin:0;opacity:0;outline:none;position:absolute;width:0;z-index:-1}.el-checkbox__label{display:inline-block;font-size:var(--el-checkbox-font-size);line-height:1;padding-left:8px}.el-checkbox.el-checkbox--large{height:40px}.el-checkbox.el-checkbox--large .el-checkbox__label{font-size:14px}.el-checkbox.el-checkbox--large .el-checkbox__inner{height:14px;width:14px}.el-checkbox.el-checkbox--small{height:24px}.el-checkbox.el-checkbox--small .el-checkbox__label{font-size:12px}.el-checkbox.el-checkbox--small .el-checkbox__inner{height:12px;width:12px}.el-checkbox.el-checkbox--small .el-checkbox__input.is-indeterminate .el-checkbox__inner:before{top:4px}.el-checkbox.el-checkbox--small .el-checkbox__inner:after{height:6px;width:2px}.el-checkbox:last-of-type{margin-right:0}.img-card[data-v-ddf49ce2]{width:100%;height:22vh;background:var(--admin-dashboard-imgcard-bg-color);border-radius:8px;box-shadow:var(--admin-dashboard-imgcard-shadow);overflow:hidden;position:relative;transition:transform .3s ease}.img-card[data-v-ddf49ce2] .el-card__body{padding:0;height:100%;overflow:hidden}.img-card[data-v-ddf49ce2] .el-checkbox{position:absolute;top:10px;right:10px;transform:scale(1.5);z-index:10}.img-card[data-v-ddf49ce2]:hover{transform:scale(1.05)}.image-preview[data-v-ddf49ce2],.video-preview[data-v-ddf49ce2]{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform .4s ease,opacity .3s ease;filter:var(--image-preview-filter)}.video-preview[data-v-ddf49ce2]{cursor:pointer}.img-card:hover .file-icon[data-v-ddf49ce2],.img-card:hover .image-preview[data-v-ddf49ce2],.img-card:hover .video-preview[data-v-ddf49ce2]{transform:scale(1.08)}.image-preview[data-v-ddf49ce2]:hover{opacity:.8}.file-short-info[data-v-ddf49ce2]{position:absolute;z-index:10;top:3px;left:3px;display:flex;gap:5px;align-items:start}.success-tag[data-v-ddf49ce2]{background-color:rgba(34,139,34,.6);border:1px solid rgba(34,139,34,.7);border-radius:6px}.fail-tag[data-v-ddf49ce2],.success-tag[data-v-ddf49ce2]{color:hsla(0,0%,100%,.95);padding:3px 8px;font-size:11px;font-weight:500;height:auto;line-height:1.2;text-shadow:0 1px 2px rgba(0,0,0,.3);backdrop-filter:blur(4px)}.fail-tag[data-v-ddf49ce2]{background-color:rgba(220,53,69,.6);border:1px solid rgba(220,53,69,.7);border-radius:6px}.primary-tag[data-v-ddf49ce2]{background-color:rgba(250,82,194,.6);color:hsla(0,0%,100%,.95);border:1px solid rgba(250,82,194,.7);padding:3px 8px;border-radius:6px;font-size:11px;font-weight:500;display:flex;align-items:center;height:auto;line-height:1.2;text-shadow:0 1px 2px rgba(0,0,0,.3);backdrop-filter:blur(4px)}.file-preview[data-v-ddf49ce2]{display:flex;justify-content:center;align-items:center;width:100%;height:100%}.file-icon[data-v-ddf49ce2]{opacity:.6;font-size:clamp(40px,4vw,64px);transition:transform .4s ease}.audio-icon[data-v-ddf49ce2]{color:var(--el-color-primary);opacity:.8}.audio-card-preview[data-v-ddf49ce2]{cursor:pointer}.card-bottom-overlay[data-v-ddf49ce2]{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,.7));padding:clamp(15px,2.5vh,30px) clamp(6px,1vw,12px) clamp(5px,.8vh,10px);display:flex;flex-direction:column;gap:clamp(3px,.5vh,6px);z-index:10}.file-name-row[data-v-ddf49ce2]{display:flex;align-items:center;justify-content:center}.file-name[data-v-ddf49ce2]{color:#fff;font-size:clamp(10px,1.1vw,14px);text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%;text-shadow:0 1px 3px rgba(0,0,0,.5)}.action-bar[data-v-ddf49ce2]{display:flex;justify-content:space-between;align-items:center;opacity:0;transform:translateY(4px);transition:all .25s cubic-bezier(.4,0,.2,1);pointer-events:none}.el-card:hover .action-bar[data-v-ddf49ce2]{opacity:1;transform:translateY(0);pointer-events:auto}.action-bar-left[data-v-ddf49ce2],.action-bar-right[data-v-ddf49ce2]{display:flex;align-items:center;gap:clamp(3px,.4vw,6px)}.action-btn[data-v-ddf49ce2]{width:clamp(24px,2.5vw,28px);height:clamp(24px,2.5vw,28px);border:none;border-radius:clamp(5px,.6vw,8px);background:hsla(0,0%,100%,.15);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;font-size:clamp(11px,1.1vw,14px)}.action-btn[data-v-ddf49ce2]:hover{background:hsla(0,0%,100%,.25);transform:scale(1.08)}.action-btn[data-v-ddf49ce2]:active{transform:scale(.95)}.action-btn-danger[data-v-ddf49ce2]:hover{background:rgba(239,68,68,.6)}@media (max-width:768px){.action-bar[data-v-ddf49ce2]{display:none!important}}@keyframes skeleton-shimmer-ddf49ce2{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton-wrapper[data-v-ddf49ce2]{width:100%;height:100%;background:linear-gradient(90deg,var(--skeleton-bg-color) 25%,color-mix(in srgb,var(--skeleton-bg-color) 70%,var(--skeleton-shimmer-color)) 50%,var(--skeleton-bg-color) 75%);background-size:200% 100%;animation:skeleton-shimmer-ddf49ce2 1.5s ease-in-out infinite}.error-wrapper[data-v-ddf49ce2]{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--skeleton-bg-color);cursor:pointer;gap:8px}.error-icon[data-v-ddf49ce2]{font-size:32px;color:var(--el-color-warning);opacity:.7}.error-text[data-v-ddf49ce2]{font-size:12px;color:var(--el-text-color-secondary)}.img-card[data-v-20e5d6b4]{width:100%;height:22vh;background:var(--admin-dashboard-imgcard-bg-color);border-radius:8px;box-shadow:var(--admin-dashboard-imgcard-shadow);overflow:hidden;position:relative;transition:transform .3s ease}.img-card[data-v-20e5d6b4] .el-card__body{padding:0;height:100%;overflow:hidden}.img-card[data-v-20e5d6b4] .el-checkbox{position:absolute;top:10px;right:10px;transform:scale(1.5);z-index:10}.img-card[data-v-20e5d6b4]:hover{transform:scale(1.05)}.folder-card[data-v-20e5d6b4]{cursor:pointer}.folder-icon[data-v-20e5d6b4]{display:flex;justify-content:center;align-items:center;width:100%;height:100%;color:var(--el-color-primary)}.folder-icon-svg[data-v-20e5d6b4]{font-size:clamp(40px,4vw,64px);transition:transform .4s ease}.img-card:hover .folder-icon-svg[data-v-20e5d6b4]{transform:scale(1.08)}.card-bottom-overlay[data-v-20e5d6b4]{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,.7));padding:clamp(15px,2.5vh,30px) clamp(6px,1vw,12px) clamp(5px,.8vh,10px);display:flex;flex-direction:column;gap:clamp(3px,.5vh,6px);z-index:10}.file-name-row[data-v-20e5d6b4]{display:flex;align-items:center;justify-content:center}.file-name[data-v-20e5d6b4]{color:#fff;font-size:clamp(10px,1.1vw,14px);text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%;text-shadow:0 1px 3px rgba(0,0,0,.5)}.action-bar[data-v-20e5d6b4]{display:flex;justify-content:space-between;align-items:center;opacity:0;transform:translateY(4px);transition:all .25s cubic-bezier(.4,0,.2,1);pointer-events:none}.el-card:hover .action-bar[data-v-20e5d6b4]{opacity:1;transform:translateY(0);pointer-events:auto}.action-bar-left[data-v-20e5d6b4],.action-bar-right[data-v-20e5d6b4]{display:flex;align-items:center;gap:clamp(3px,.4vw,6px)}.action-btn[data-v-20e5d6b4]{width:clamp(24px,2.5vw,28px);height:clamp(24px,2.5vw,28px);border:none;border-radius:clamp(5px,.6vw,8px);background:hsla(0,0%,100%,.15);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;font-size:clamp(11px,1.1vw,14px)}.action-btn[data-v-20e5d6b4]:hover{background:hsla(0,0%,100%,.25);transform:scale(1.08)}.action-btn[data-v-20e5d6b4]:active{transform:scale(.95)}.action-btn-danger[data-v-20e5d6b4]:hover{background:rgba(239,68,68,.6)}@media (max-width:768px){.action-bar[data-v-20e5d6b4]{display:none!important}}@keyframes skeleton-shimmer-71848b62{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes skeleton-pulse-71848b62{0%,to{opacity:.4}50%{opacity:.8}}.skeleton-card[data-v-71848b62]{width:100%;height:22vh;background:var(--admin-dashboard-imgcard-bg-color);border-radius:12px;box-shadow:var(--admin-dashboard-imgcard-shadow);overflow:hidden;position:relative}.skeleton-image[data-v-71848b62]{width:100%;height:100%;background:linear-gradient(90deg,var(--skeleton-bg-color) 25%,color-mix(in srgb,var(--skeleton-bg-color) 70%,var(--skeleton-shimmer-color)) 50%,var(--skeleton-bg-color) 75%);background-size:200% 100%;animation:skeleton-shimmer-71848b62 1.5s ease-in-out infinite}.skeleton-info[data-v-71848b62]{position:absolute;bottom:0;left:0;right:0;padding:15px;background:linear-gradient(transparent,rgba(0,0,0,.5))}.skeleton-text[data-v-71848b62]{height:14px;width:60%;margin:0 auto;border-radius:4px;background:linear-gradient(90deg,hsla(0,0%,100%,.1) 25%,hsla(0,0%,100%,.25) 50%,hsla(0,0%,100%,.1) 75%);background-size:200% 100%;animation:skeleton-shimmer-71848b62 1.5s ease-in-out infinite}.skeleton-list-item[data-v-71848b62]{animation:skeleton-pulse-71848b62 1.5s ease-in-out infinite}.skeleton-checkbox[data-v-71848b62]{width:18px;height:18px;border-radius:4px;background:var(--skeleton-bg-color)}.skeleton-preview[data-v-71848b62]{width:40px;height:40px;border-radius:6px;background:linear-gradient(90deg,var(--skeleton-bg-color) 25%,color-mix(in srgb,var(--skeleton-bg-color) 70%,var(--skeleton-shimmer-color)) 50%,var(--skeleton-bg-color) 75%);background-size:200% 100%;animation:skeleton-shimmer-71848b62 1.5s ease-in-out infinite}.skeleton-text-long[data-v-71848b62]{width:80%}.skeleton-text-long[data-v-71848b62],.skeleton-text-short[data-v-71848b62]{height:14px;border-radius:4px;background:linear-gradient(90deg,var(--skeleton-bg-color) 25%,color-mix(in srgb,var(--skeleton-bg-color) 70%,var(--skeleton-shimmer-color)) 50%,var(--skeleton-bg-color) 75%);background-size:200% 100%;animation:skeleton-shimmer-71848b62 1.5s ease-in-out infinite}.skeleton-text-short[data-v-71848b62]{width:60px}.skeleton-text-tiny[data-v-71848b62]{height:14px;width:40px;border-radius:4px}.skeleton-tag[data-v-71848b62],.skeleton-text-tiny[data-v-71848b62]{background:linear-gradient(90deg,var(--skeleton-bg-color) 25%,color-mix(in srgb,var(--skeleton-bg-color) 70%,var(--skeleton-shimmer-color)) 50%,var(--skeleton-bg-color) 75%);background-size:200% 100%;animation:skeleton-shimmer-71848b62 1.5s ease-in-out infinite}.skeleton-tag[data-v-71848b62]{height:20px;width:50px;border-radius:10px}.skeleton-actions[data-v-71848b62]{height:28px;width:80px;border-radius:6px;background:var(--skeleton-bg-color)}.list-item[data-v-71848b62]{display:grid;grid-template-columns:50px 60px minmax(180px,1fr) 130px 100px 110px 130px 80px 100px 120px;padding:12px 20px;align-items:center;border-bottom:1px solid var(--el-border-color-lighter)}.list-col[data-v-71848b62]{display:flex;align-items:center}.list-col-checkbox[data-v-71848b62],.list-col-preview[data-v-71848b62]{justify-content:center}@media (max-width:768px){.list-item[data-v-71848b62]{grid-template-columns:28px 40px 1fr auto;padding:10px 8px;gap:8px}.list-col-address[data-v-71848b62],.list-col-channel-name[data-v-71848b62],.list-col-channel[data-v-71848b62],.list-col-date[data-v-71848b62],.list-col-size[data-v-71848b62],.list-col-tags[data-v-71848b62]{display:none}}.el-breadcrumb{font-size:14px;line-height:1}.el-breadcrumb:after,.el-breadcrumb:before{content:"";display:table}.el-breadcrumb:after{clear:both}.el-breadcrumb__separator{color:var(--el-text-color-placeholder);font-weight:700;margin:0 9px}.el-breadcrumb__separator.el-icon{font-weight:400;margin:0 6px}.el-breadcrumb__separator.el-icon svg{vertical-align:middle}.el-breadcrumb__item{align-items:center;display:inline-flex;float:left}.el-breadcrumb__inner{color:var(--el-text-color-regular)}.el-breadcrumb__inner a,.el-breadcrumb__inner.is-link{color:var(--el-text-color-primary);font-weight:700;text-decoration:none;transition:var(--el-transition-color)}.el-breadcrumb__inner a:hover,.el-breadcrumb__inner.is-link:hover{color:var(--el-color-primary);cursor:pointer}.el-breadcrumb__item:last-child .el-breadcrumb__inner,.el-breadcrumb__item:last-child .el-breadcrumb__inner a,.el-breadcrumb__item:last-child .el-breadcrumb__inner a:hover,.el-breadcrumb__item:last-child .el-breadcrumb__inner:hover{color:var(--el-text-color-regular);cursor:text;font-weight:400}.el-breadcrumb__item:last-child .el-breadcrumb__separator{display:none}.el-checkbox-group{font-size:0;line-height:0}.filter-dropdown[data-v-062d5f10]{flex-shrink:0}.filter-trigger[data-v-062d5f10]{cursor:pointer;display:flex;align-items:center}.header-icon[data-v-062d5f10]{font-size:1.5em;cursor:pointer;transition:all .3s ease;color:var(--admin-container-color);outline:none}.header-icon[data-v-062d5f10]:hover{color:var(--admin-purple);transform:scale(1.2)}.filter-badge[data-v-062d5f10] .el-badge__content{background:linear-gradient(135deg,#0ea5e9,#38bdf8);border:none;font-size:10px;height:16px;line-height:16px;padding:0 5px}.filter-dropdown-menu[data-v-062d5f10]{padding:8px 0;min-width:180px;max-height:400px;overflow-y:auto}.filter-section[data-v-062d5f10]{padding:8px 12px;border-bottom:1px solid var(--el-border-color-lighter)}.filter-section[data-v-062d5f10]:last-of-type{border-bottom:none}.filter-title[data-v-062d5f10]{font-size:12px;font-weight:600;color:var(--el-text-color-secondary);margin-bottom:6px}.filter-options[data-v-062d5f10],.filter-options[data-v-062d5f10] .el-checkbox-group{display:flex;flex-direction:column;gap:2px}.filter-options[data-v-062d5f10] .el-checkbox{margin-right:0;height:26px;padding:0 6px;border-radius:4px;transition:all .2s ease}.filter-options[data-v-062d5f10] .el-checkbox:hover{background:var(--el-fill-color-light)}.filter-options[data-v-062d5f10] .el-checkbox__label{font-size:13px;color:var(--el-text-color-primary)}.filter-options[data-v-062d5f10] .el-checkbox__input.is-checked+.el-checkbox__label{color:#0ea5e9}.channel-group-title[data-v-062d5f10]{font-size:11px;font-weight:600;color:var(--el-text-color-secondary);text-transform:uppercase;letter-spacing:.5px;padding:4px 6px;margin-top:4px;margin-bottom:2px}.channel-divider[data-v-062d5f10]{height:1px;background:var(--el-border-color-lighter);margin:6px 0}.filter-options[data-v-062d5f10] .el-checkbox__input.is-checked .el-checkbox__inner{background-color:#0ea5e9;border-color:#0ea5e9}.filter-actions[data-v-062d5f10]{padding:10px 12px 6px;display:flex;justify-content:center}.filter-actions .el-button[data-v-062d5f10]{width:100%;background:var(--el-fill-color-light);border:1px solid var(--el-border-color);color:var(--el-text-color-regular);border-radius:6px;transition:all .2s ease}.filter-actions .el-button[data-v-062d5f10]:hover:not(:disabled){background:linear-gradient(135deg,#0ea5e9,#38bdf8);border-color:#38bdf8;color:#fff}.filter-actions .el-button[data-v-062d5f10]:disabled{opacity:.5;cursor:not-allowed}@media (max-width:768px){.filter-dropdown-menu[data-v-062d5f10]{min-width:160px;max-height:320px}.filter-section[data-v-062d5f10]{padding:6px 10px}.filter-title[data-v-062d5f10]{font-size:11px;margin-bottom:4px}.filter-options[data-v-062d5f10] .el-checkbox{height:24px;padding:0 4px}.filter-options[data-v-062d5f10] .el-checkbox__label{font-size:12px}.header-icon[data-v-062d5f10]{font-size:1.2em}}#themeToggle[data-v-4c6ec90c]{border:0;cursor:pointer;display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:.375rem;transition-property:background-color,border-color,color;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.theme_toggle_circle1[data-v-4c6ec90c]{transition:cx .5s ease-in-out,cy .5s ease-in-out,r .5s ease-in-out}.theme_toggle_circle2[data-v-4c6ec90c]{transition:all .5s ease-in-out;fill:var(--admin-theme-toggle-bg-color)}.theme_toggle_svg[data-v-4c6ec90c]{transition:transform .5s cubic-bezier(.68,-.55,.27,1.55);color:var(--admin-theme-toggle-color)}.dark.theme_toggle_svg[data-v-4c6ec90c]{transform:rotate(40deg)}.theme_toggle_g[data-v-4c6ec90c]{transition:opacity .5s ease-in-out}.icon-fade-enter-active[data-v-4c6ec90c],.icon-fade-leave-active[data-v-4c6ec90c]{transition:opacity .3s ease-in-out,transform .3s ease-in-out}.icon-fade-enter-from[data-v-4c6ec90c]{opacity:0;transform:scale(.8) rotate(-90deg)}.icon-fade-leave-to[data-v-4c6ec90c]{opacity:0;transform:scale(.8) rotate(90deg)}.icon-fade-enter-to[data-v-4c6ec90c],.icon-fade-leave-from[data-v-4c6ec90c]{opacity:1;transform:scale(1) rotate(0deg)}.auto-icon[data-v-4c6ec90c]{display:inline-block}.tabs[data-v-4673d77a]{display:flex;align-items:center;justify-content:center;gap:12px}.title[data-v-4673d77a]{display:flex;align-items:center;gap:10px;font-size:1.2em;font-weight:700;cursor:pointer;transition:all .3s ease;color:var(--admin-container-color);padding:6px 14px;border-radius:10px;background:linear-gradient(135deg,rgba(99,102,241,.08),rgba(139,92,246,.05));border:1px solid rgba(99,102,241,.15)}.title[data-v-4673d77a]:hover{background:linear-gradient(135deg,rgba(99,102,241,.15),rgba(139,92,246,.1));border-color:rgba(99,102,241,.25);transform:translateY(-1px)}.title .fa-images[data-v-4673d77a]{font-size:1em;color:var(--el-color-primary);background:linear-gradient(135deg,#6366f1,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.tabs-dropdown[data-v-4673d77a]{display:flex;align-items:center}.tabs-dropdown-link[data-v-4673d77a]{cursor:pointer;font-size:1.5em;transition:all .3s ease;color:var(--admin-container-color);padding:6px 10px;border-radius:8px;background:transparent}.tabs-dropdown-link.rotate-up[data-v-4673d77a],.tabs-dropdown-link[data-v-4673d77a]:hover{background:rgba(99,102,241,.1);color:var(--el-color-primary)}@media (max-width:768px){.title[data-v-4673d77a]{font-size:1.3em;padding:4px 10px;gap:6px}.tabs-dropdown-link[data-v-4673d77a]{font-size:1.3em;padding:4px 8px}}.el-dropdown__popper.el-popper.tabs-dropdown-popper{border-radius:12px;border:none;background-color:var(--tabs-dropdown-popper-bg-color);backdrop-filter:blur(10px);box-shadow:var(--tabs-dropdown-popper-shadow)}.el-dropdown__popper.el-popper.tabs-dropdown-popper .el-dropdown-menu{border:none;background:none}.el-dropdown__popper.el-popper.tabs-dropdown-popper .el-dropdown-menu__item{border:none;background:none;font-size:16px;font-weight:700;transition:font-size .3s ease}.el-dropdown__popper.el-popper.tabs-dropdown-popper .el-dropdown-menu__item:hover{font-size:18px}.container[data-v-5c4ee283]{background:var(--admin-container-bg-color);min-height:100vh;font-family:Arial,sans-serif;color:var(--admin-container-color);margin:0;padding:0}[data-v-5c4ee283] .el-container,[data-v-5c4ee283] .el-main{overflow:visible}[data-v-5c4ee283] .el-dialog{border-radius:12px;background-color:var(--dialog-bg-color);backdrop-filter:blur(10px);box-shadow:var(--dialog-box-shadow)}.header-content[data-v-5c4ee283]{display:flex;justify-content:space-between;align-items:center;padding:10px 24px;background:hsla(0,0%,100%,.72);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid hsla(0,0%,100%,.3);border-top:1px solid hsla(0,0%,100%,.5);box-shadow:0 4px 30px rgba(0,0,0,.1),0 1px 3px rgba(0,0,0,.05),inset 0 1px 0 hsla(0,0%,100%,.4);transition:all .4s cubic-bezier(.4,0,.2,1);border-radius:16px;position:fixed;top:8px;left:50%;transform:translateX(-50%);width:calc(95% - 16px);z-index:2001;min-height:45px}html.dark .header-content[data-v-5c4ee283]{background:rgba(30,30,30,.75);border:1px solid hsla(0,0%,100%,.08);border-top:1px solid hsla(0,0%,100%,.12);box-shadow:0 4px 30px rgba(0,0,0,.3),0 1px 3px rgba(0,0,0,.2),inset 0 1px 0 hsla(0,0%,100%,.05)}@media (max-width:768px){.header-content[data-v-5c4ee283]{flex-direction:column;top:6px;width:calc(100% - 32px);border-radius:14px;padding:6px 12px;gap:4px}.header-icon[data-v-5c4ee283]{font-size:.95em}.header-content .actions[data-v-5c4ee283]{gap:10px}.search-card[data-v-5c4ee283] .el-input__inner{height:28px;font-size:.85em;width:50vw}.search-card[data-v-5c4ee283] .el-input__wrapper{padding:0 10px}.search-card[data-v-5c4ee283] .el-input__inner:focus{width:65vw}}.header-content[data-v-5c4ee283]:hover{background:hsla(0,0%,100%,.82);box-shadow:0 8px 40px rgba(0,0,0,.12),0 2px 6px rgba(0,0,0,.08),inset 0 1px 0 hsla(0,0%,100%,.5);transform:translateX(-50%) translateY(-1px)}html.dark .header-content[data-v-5c4ee283]:hover{background:rgba(35,35,35,.85);box-shadow:0 8px 40px rgba(0,0,0,.4),0 2px 6px rgba(0,0,0,.3),inset 0 1px 0 hsla(0,0%,100%,.08)}.header-icon[data-v-5c4ee283]{font-size:1.5em;cursor:pointer;transition:all .3s ease;color:var(--admin-container-color);outline:none}.header-icon[data-v-5c4ee283]:hover{color:var(--admin-purple);transform:scale(1.2)}.breadcrumb-container[data-v-5c4ee283]{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0 10px;margin-bottom:4px}@media (max-width:768px){.breadcrumb-container[data-v-5c4ee283]{flex-direction:row;align-items:center;gap:8px;padding:0 5px;margin-bottom:2px}}.stats-badge[data-v-5c4ee283]{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:500;color:var(--el-text-color-secondary);background:var(--el-fill-color-light);padding:4px 10px;border-radius:12px;border:1px solid var(--el-border-color-lighter);transition:all .2s ease;white-space:nowrap;flex-shrink:0}.stats-badge[data-v-5c4ee283]:hover{background:var(--el-fill-color);color:var(--admin-purple);border-color:var(--admin-purple)}.stats-badge-icon[data-v-5c4ee283]{font-size:11px;opacity:.8}@media (max-width:768px){.stats-badge[data-v-5c4ee283]{font-size:10px;padding:2px 6px;border-radius:8px}.stats-badge-icon[data-v-5c4ee283]{font-size:9px}}.header-content .actions[data-v-5c4ee283]{display:flex;align-items:center;gap:15px}@media (max-width:768px){.header-content .actions[data-v-5c4ee283]{margin-top:10px}}.header-content .actions i[data-v-5c4ee283]{font-size:1.5em;cursor:pointer;transition:color .3s,transform .3s;color:var(--admin-container-color)}.header-content .actions i[data-v-5c4ee283]:hover{color:var(--admin-purple);transform:scale(1.2)}.header-content .actions .el-dropdown-link i[data-v-5c4ee283]{color:var(--admin-container-color)}.header-content .actions .el-dropdown-link i[data-v-5c4ee283]:hover{color:var(--admin-purple)}.header-content .actions .disabled[data-v-5c4ee283]{color:#bbb;pointer-events:none}.header-content .actions .enabled[data-v-5c4ee283]{color:var(--admin-purple)}.batch-action-item-icon[data-v-5c4ee283]{width:20px;margin-right:5px}.search-area[data-v-5c4ee283]{margin-left:auto;margin-right:20px;display:flex;align-items:center;gap:8px}@media (max-width:768px){.search-area[data-v-5c4ee283]{margin-right:0;margin-left:0;margin-top:10px;gap:6px}}.search-card[data-v-5c4ee283]{display:flex;align-items:center}.search-card[data-v-5c4ee283] .el-input__wrapper{border-radius:20px;background:var(--admin-dashboard-search-card-bg-color);box-shadow:var(--admin-dashboard-search-card-box-shadow);transition:background-color .3s}.search-card[data-v-5c4ee283] .el-input__inner{width:280px;height:40px;font-size:1.2em;border:none;transition:width .3s;background:none}.search-card[data-v-5c4ee283] .el-input__inner::-moz-placeholder{color:var(--el-text-color-placeholder);font-style:italic;font-weight:400;font-size:14px;opacity:.6;letter-spacing:.5px;-moz-transition:all .3s ease;transition:all .3s ease}.search-card[data-v-5c4ee283] .el-input__inner::placeholder{color:var(--el-text-color-placeholder);font-style:italic;font-weight:400;font-size:14px;opacity:.6;letter-spacing:.5px;transition:all .3s ease}.search-card[data-v-5c4ee283] .el-input__inner:focus::-moz-placeholder{opacity:.4;transform:translateX(5px)}.search-card[data-v-5c4ee283] .el-input__inner:focus::placeholder{opacity:.4;transform:translateX(5px)}@media (max-width:768px){.search-card[data-v-5c4ee283] .el-input__inner{width:45vw;height:32px;font-size:1em}}.search-card[data-v-5c4ee283] .el-input__inner:focus{width:350px}@media (max-width:768px){.search-card[data-v-5c4ee283] .el-input__inner:focus{width:55vw}}.search-icon[data-v-5c4ee283]{cursor:pointer;color:var(--admin-container-color);transition:all .3s ease;font-size:1.3em;opacity:0;transform:scale(.8);pointer-events:none}.search-card:focus-within .search-icon[data-v-5c4ee283]{opacity:1;transform:scale(1);pointer-events:auto}.search-card:focus-within .search-icon[data-v-5c4ee283]:hover{color:var(--admin-purple);transform:scale(1.2)}.search-card[data-v-5c4ee283] .el-input__suffix{display:flex;align-items:center;right:10px}.main-container[data-v-5c4ee283]{display:flex;flex-direction:column;padding:20px 60px;min-height:calc(100vh - 80px)}@media (max-width:768px){.main-container[data-v-5c4ee283]{margin-top:12vh}}.content[data-v-5c4ee283]{display:grid;grid-template-columns:repeat(5,1fr);grid-template-rows:repeat(3,1fr);gap:20px;padding:10px;padding-bottom:0;flex-grow:1;min-height:80vh}.empty-state[data-v-5c4ee283]{grid-column:1/-1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--admin-container-color);opacity:.6}.empty-icon[data-v-5c4ee283]{font-size:64px;margin-bottom:20px;color:var(--admin-container-color);opacity:.3}.empty-text[data-v-5c4ee283]{font-size:18px;font-weight:500;margin:0 0 8px 0}.empty-hint[data-v-5c4ee283]{font-size:14px;margin:0;opacity:.7}.list-empty[data-v-5c4ee283]{padding:80px 20px}@media (max-width:768px){.content[data-v-5c4ee283]{grid-template-columns:1fr;grid-template-rows:none}}.list-view[data-v-5c4ee283]{display:flex;flex-direction:column;gap:0;background:var(--admin-dashboard-imgcard-bg-color);border-radius:12px;overflow-x:auto;overflow-y:visible;box-shadow:var(--admin-dashboard-imgcard-shadow);margin-top:15px}.list-header[data-v-5c4ee283]{display:grid;grid-template-columns:50px 60px minmax(180px,1fr) 130px 100px 110px 130px 80px 100px 120px;padding:12px 20px;background:var(--admin-dashboard-stats-bg);font-weight:600;font-size:13px;color:var(--el-text-color-secondary);border-bottom:1px solid var(--el-border-color-lighter);min-width:-moz-fit-content;min-width:fit-content}.list-col[data-v-5c4ee283]{display:flex;align-items:center}.list-col-checkbox[data-v-5c4ee283]{justify-content:center;min-width:40px}.custom-checkbox[data-v-5c4ee283]{width:18px;height:18px;border:2px solid var(--el-border-color);border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;background:transparent}.custom-checkbox[data-v-5c4ee283]:hover{border-color:#38bdf8}.custom-checkbox.checked[data-v-5c4ee283],.custom-checkbox.indeterminate[data-v-5c4ee283]{background:linear-gradient(135deg,#0ea5e9,#38bdf8);border-color:#38bdf8}.custom-checkbox .check-icon[data-v-5c4ee283]{font-size:10px;color:#fff}@media (max-width:768px){.list-header[data-v-5c4ee283]{display:none}}.pagination-container[data-v-5c4ee283]{display:flex;justify-content:center;align-items:center;margin-top:20px;padding-bottom:20px;gap:15px;position:relative}.pagination-center[data-v-5c4ee283]{display:flex;align-items:center;gap:10px}.pagination-container[data-v-5c4ee283] .el-pagination{--el-pagination-button-bg-color:var(--admin-dashboard-btn-bg-color);--el-pagination-hover-color:var(--admin-purple)}.pagination-container[data-v-5c4ee283] .el-pager li{background:var(--admin-dashboard-btn-bg-color);border-radius:10px;margin:0 4px;min-width:36px;height:36px;line-height:36px;font-weight:500;border:none;box-shadow:var(--admin-dashboard-btn-shadow);transition:all .3s cubic-bezier(.4,0,.2,1)}.pagination-container[data-v-5c4ee283] .el-pager li:hover{color:#38bdf8;transform:translateY(-2px);box-shadow:var(--admin-dashboard-btn-hover-shadow)}.pagination-container[data-v-5c4ee283] .el-pager li.is-active{background:linear-gradient(135deg,#0ea5e9,#38bdf8)!important;color:#fff!important;border-radius:10px;box-shadow:var(--admin-dashboard-btn-shadow),0 4px 12px rgba(56,189,248,.3),inset 0 1px 0 hsla(0,0%,100%,.2);transition:all .3s cubic-bezier(.4,0,.2,1)}.pagination-container[data-v-5c4ee283] .el-pager li.is-active:hover{transform:translateY(-2px)!important;box-shadow:var(--admin-dashboard-btn-hover-shadow),0 6px 16px rgba(56,189,248,.4),inset 0 1px 0 hsla(0,0%,100%,.2)!important}.pagination-container[data-v-5c4ee283] .btn-next,.pagination-container[data-v-5c4ee283] .btn-prev{background:var(--admin-dashboard-btn-bg-color)!important;border-radius:10px!important;min-width:36px;height:36px;border:none;box-shadow:var(--admin-dashboard-btn-shadow);transition:all .3s cubic-bezier(.4,0,.2,1)}.pagination-container[data-v-5c4ee283] .btn-next:hover,.pagination-container[data-v-5c4ee283] .btn-prev:hover{color:#38bdf8;transform:translateY(-2px);box-shadow:var(--admin-dashboard-btn-hover-shadow)}.pagination-right[data-v-5c4ee283]{display:flex;align-items:center;gap:10px;position:absolute;right:0}.page-total[data-v-5c4ee283]{font-size:13px;color:var(--el-text-color-secondary);white-space:nowrap}.page-jump[data-v-5c4ee283]{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--el-text-color-secondary)}.page-jump .jump-input[data-v-5c4ee283]{width:50px}.page-jump .jump-input[data-v-5c4ee283] .el-input__wrapper{background:var(--admin-dashboard-btn-bg-color);box-shadow:var(--admin-dashboard-btn-shadow);border-radius:8px;padding:0 8px;height:28px}.page-jump .jump-input[data-v-5c4ee283] .el-input__inner{text-align:center;color:var(--el-text-color-primary);height:28px;line-height:28px}.page-jump .jump-btn[data-v-5c4ee283]{background:linear-gradient(135deg,#0ea5e9,#38bdf8);border:none;border-radius:8px;padding:0 12px;height:28px;font-size:12px;font-weight:600;color:#fff;box-shadow:0 2px 8px rgba(56,189,248,.3);transition:all .3s ease}.page-jump .jump-btn[data-v-5c4ee283]:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(56,189,248,.4)}@media (max-width:768px){.pagination-container[data-v-5c4ee283]{flex-direction:column;gap:12px;padding-bottom:15px}.pagination-center[data-v-5c4ee283]{order:0}.pagination-right[data-v-5c4ee283]{position:static;width:100%;justify-content:center;order:1}.page-jump .jump-input[data-v-5c4ee283]{width:45px}}.refresh-btn[data-v-5c4ee283]{cursor:pointer;background:var(--admin-dashboard-btn-bg-color);box-shadow:var(--admin-dashboard-btn-shadow);color:#38bdf8;border:none;border-radius:10px;width:36px;height:36px;min-width:36px;padding:0;display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .3s cubic-bezier(.4,0,.2,1)}.refresh-btn[data-v-5c4ee283]:hover{transform:translateY(-2px);box-shadow:var(--admin-dashboard-btn-hover-shadow);background:linear-gradient(135deg,#0ea5e9,#38bdf8);color:#fff}.load-more[data-v-5c4ee283]{cursor:pointer;background:linear-gradient(135deg,#0ea5e9,#38bdf8);box-shadow:0 4px 15px rgba(56,189,248,.3);color:#fff;border:none;border-radius:10px;height:36px;padding:0 16px;font-weight:500;transition:all .3s cubic-bezier(.4,0,.2,1)}.load-more[data-v-5c4ee283]:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(56,189,248,.5)}[data-v-5c4ee283] .btn-prev{left:8px}[data-v-5c4ee283] .btn-next,[data-v-5c4ee283] .btn-prev{border-radius:100%;position:fixed;top:50%;scale:1;color:var(--admin-dashboard-btn-color)}[data-v-5c4ee283] .btn-next{right:8px}@media (min-width:768px){[data-v-5c4ee283] .el-pagination.is-background .btn-next,[data-v-5c4ee283] .el-pagination.is-background .btn-prev{background-color:var(--admin-dashboard-btn-bg-color);backdrop-filter:blur(10px);box-shadow:var(--admin-dashboard-btn-shadow);transition:all .3s ease}[data-v-5c4ee283] .el-pagination.is-background .btn-next:hover,[data-v-5c4ee283] .el-pagination.is-background .btn-prev:hover{transform:translateY(-10%);box-shadow:var(--admin-dashboard-btn-hover-shadow)}}.question-icon[data-v-5c4ee283]{margin:0 3px}.breadcrumb[data-v-5c4ee283]{padding:8px 12px;background-color:var(--el-bg-color);border-radius:6px;font-size:.95em;box-shadow:var(--admin-dashboard-stats-shadow);transition:all .3s ease}.breadcrumb[data-v-5c4ee283]:hover{transform:translateY(-1px);box-shadow:var(--admin-dashboard-stats-hover-shadow)}.breadcrumb-home-icon[data-v-5c4ee283]{font-size:14px;color:#38bdf8;transition:color .2s ease}.breadcrumb-home-icon[data-v-5c4ee283]:hover{color:var(--admin-purple)}[data-v-5c4ee283] .el-breadcrumb__item{cursor:pointer}[data-v-5c4ee283] .el-breadcrumb__inner:hover{color:var(--el-color-primary)}.mobile-directory-trigger[data-v-5c4ee283]{display:none;align-items:center;gap:6px;padding:6px 10px;background:var(--el-fill-color-light);border-radius:8px;border:1px solid var(--el-border-color-lighter);cursor:pointer;transition:all .2s ease}.mobile-directory-trigger[data-v-5c4ee283]:active{background:var(--el-fill-color)}.mobile-directory-icon[data-v-5c4ee283]{font-size:12px;color:#38bdf8}.mobile-directory-path[data-v-5c4ee283]{font-size:12px;font-weight:500;color:var(--el-text-color-primary);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-directory-arrow[data-v-5c4ee283]{font-size:8px;color:var(--el-text-color-secondary)}.desktop-only[data-v-5c4ee283]{display:block}@media (max-width:768px){.mobile-directory-trigger[data-v-5c4ee283]{display:flex}.desktop-only[data-v-5c4ee283]{display:none!important}.breadcrumb-container[data-v-5c4ee283]{padding:0;margin-left:0}} \ No newline at end of file diff --git a/css/743.ab3d1775.css.gz b/css/743.ab3d1775.css.gz new file mode 100644 index 0000000..ed9ad09 Binary files /dev/null and b/css/743.ab3d1775.css.gz differ diff --git a/css/988.6b45e8e3.css b/css/845.6b45e8e3.css similarity index 100% rename from css/988.6b45e8e3.css rename to css/845.6b45e8e3.css diff --git a/css/988.6b45e8e3.css.gz b/css/845.6b45e8e3.css.gz similarity index 100% rename from css/988.6b45e8e3.css.gz rename to css/845.6b45e8e3.css.gz diff --git a/functions/api/channels.js b/functions/api/channels.js index 402a3ca..ea0e274 100644 --- a/functions/api/channels.js +++ b/functions/api/channels.js @@ -1,5 +1,7 @@ -// 获取可用上传渠道列表 API +// 获取上传渠道列表 API import { fetchUploadConfig } from '../utils/sysConfig.js'; +import { getUploadConfig } from './manage/sysConfig/upload.js'; +import { getDatabase } from '../utils/databaseAdapter.js'; export async function onRequest(context) { const { request, env } = context; @@ -9,30 +11,40 @@ export async function onRequest(context) { } try { - // 获取上传配置(已过滤禁用的渠道) - const uploadConfig = await fetchUploadConfig(env, context); + const url = new URL(request.url); + const includeDisabled = url.searchParams.get('includeDisabled') === 'true'; - // 构建渠道列表,只返回渠道名称 + let uploadConfig; + if (includeDisabled) { + // 获取所有上传配置(包括禁用的渠道) + const db = getDatabase(env); + uploadConfig = await getUploadConfig(db, env); + } else { + // 获取上传配置(已过滤禁用的渠道) + uploadConfig = await fetchUploadConfig(env, context); + } + + // 构建渠道列表,返回渠道名称和实际的 Channel 类型 const channels = { telegram: uploadConfig.telegram.channels.map(ch => ({ name: ch.name, - type: 'telegram' + type: 'TelegramNew' })), cfr2: uploadConfig.cfr2.channels.map(ch => ({ name: ch.name, - type: 'cfr2' + type: 'CloudflareR2' })), s3: uploadConfig.s3.channels.map(ch => ({ name: ch.name, - type: 's3' + type: 'S3' })), discord: uploadConfig.discord.channels.map(ch => ({ name: ch.name, - type: 'discord' + type: 'Discord' })), huggingface: uploadConfig.huggingface.channels.map(ch => ({ name: ch.name, - type: 'huggingface' + type: 'HuggingFace' })) }; diff --git a/functions/api/manage/list.js b/functions/api/manage/list.js index b7e807c..f81597a 100644 --- a/functions/api/manage/list.js +++ b/functions/api/manage/list.js @@ -25,9 +25,13 @@ export async function onRequest(context) { let search = url.searchParams.get('search') || ''; let channel = url.searchParams.get('channel') || ''; let listType = url.searchParams.get('listType') || ''; + let accessStatus = url.searchParams.get('accessStatus') || ''; let action = url.searchParams.get('action') || ''; let includeTags = url.searchParams.get('includeTags') || ''; let excludeTags = url.searchParams.get('excludeTags') || ''; + let label = url.searchParams.get('label') || ''; + let fileType = url.searchParams.get('fileType') || ''; + let channelName = url.searchParams.get('channelName') || ''; // 处理搜索关键字 if (search) { @@ -38,6 +42,14 @@ export async function onRequest(context) { const includeTagsArray = includeTags ? includeTags.split(',').map(t => t.trim()).filter(t => t) : []; const excludeTagsArray = excludeTags ? excludeTags.split(',').map(t => t.trim()).filter(t => t) : []; + // 处理筛选参数(支持逗号分隔的多选) + const listTypeArray = listType ? listType.split(',').map(t => t.trim()).filter(t => t) : []; + const accessStatusArray = accessStatus ? accessStatus.split(',').map(t => t.trim()).filter(t => t) : []; + const labelArray = label ? label.split(',').map(t => t.trim()).filter(t => t) : []; + const fileTypeArray = fileType ? fileType.split(',').map(t => t.trim()).filter(t => t) : []; + const channelArray = channel ? channel.split(',').map(t => t.trim()).filter(t => t) : []; + const channelNameArray = channelName ? channelName.split(',').map(t => t.trim()).filter(t => t) : []; + // 处理目录参数 if (dir.startsWith('/')) { dir = dir.substring(1); @@ -97,8 +109,12 @@ export async function onRequest(context) { const result = await readIndex(context, { search, directory: dir, - channel, - listType, + channel: channelArray, + listType: listTypeArray, + accessStatus: accessStatusArray, + label: labelArray, + fileType: fileTypeArray, + channelName: channelNameArray, includeTags: includeTagsArray, excludeTags: excludeTagsArray, countOnly: true @@ -118,8 +134,12 @@ export async function onRequest(context) { directory: dir, start, count, - channel, - listType, + channel: channelArray, + listType: listTypeArray, + accessStatus: accessStatusArray, + label: labelArray, + fileType: fileTypeArray, + channelName: channelNameArray, includeTags: includeTagsArray, excludeTags: excludeTagsArray, includeSubdirFiles: recursive, diff --git a/functions/utils/indexManager.js b/functions/utils/indexManager.js index e5b6530..dfc1e5d 100644 --- a/functions/utils/indexManager.js +++ b/functions/utils/indexManager.js @@ -475,8 +475,12 @@ export async function mergeOperationsToIndex(context, options = {}) { * @param {string} options.directory - 目录过滤 * @param {number} options.start - 起始位置 * @param {number} options.count - 返回数量,-1 表示返回所有 - * @param {string} options.channel - 渠道过滤 - * @param {string} options.listType - 列表类型过滤 + * @param {Array|string} options.channel - 渠道过滤(支持数组多选) + * @param {Array|string} options.listType - 列表类型过滤(支持数组多选) + * @param {Array|string} options.accessStatus - 访问状态筛选(支持数组多选):'normal'=正常, 'blocked'=已屏蔽 + * @param {Array|string} options.label - 审查结果筛选(支持数组多选) + * @param {Array|string} options.fileType - 文件类型筛选(支持数组多选) + * @param {Array|string} options.channelName - 渠道名称筛选(支持数组多选) * @param {Array} options.includeTags - 必须包含的标签数组 * @param {Array} options.excludeTags - 必须排除的标签数组 * @param {boolean} options.countOnly - 仅返回总数 @@ -489,13 +493,26 @@ export async function readIndex(context, options = {}) { directory = '', start = 0, count = 50, - channel = '', - listType = '', + channel = [], + listType = [], + accessStatus = [], + label = [], + fileType = [], + channelName = [], includeTags = [], excludeTags = [], countOnly = false, includeSubdirFiles = false } = options; + + // 将参数统一转换为数组形式 + const channelArr = Array.isArray(channel) ? channel : (channel ? [channel] : []); + const listTypeArr = Array.isArray(listType) ? listType : (listType ? [listType] : []); + const accessStatusArr = Array.isArray(accessStatus) ? accessStatus : (accessStatus ? [accessStatus] : []); + const labelArr = Array.isArray(label) ? label : (label ? [label] : []); + const fileTypeArr = Array.isArray(fileType) ? fileType : (fileType ? [fileType] : []); + const channelNameArr = Array.isArray(channelName) ? channelName : (channelName ? [channelName] : []); + // 处理目录满足无头有尾的格式,根目录为空 const dirPrefix = directory === '' || directory.endsWith('/') ? directory : directory + '/'; @@ -522,18 +539,113 @@ export async function readIndex(context, options = {}) { }); } - // 渠道过滤 - if (channel) { + // 渠道过滤(支持多选,OR 逻辑) + if (channelArr.length > 0) { filteredFiles = filteredFiles.filter(file => - file.metadata.Channel?.toLowerCase() === channel.toLowerCase() + channelArr.some(ch => file.metadata.Channel?.toLowerCase() === ch.toLowerCase()) ); } - // 列表类型过滤 - if (listType) { - filteredFiles = filteredFiles.filter(file => - file.metadata.ListType === listType - ); + // 列表类型过滤(黑白名单,支持多选,OR 逻辑) + // White=白名单, Block=黑名单, None=未设置 + if (listTypeArr.length > 0) { + filteredFiles = filteredFiles.filter(file => { + const fileListType = file.metadata.ListType; + return listTypeArr.some(lt => { + if (lt === 'None') { + // 未设置:ListType 为空、undefined、null 或字符串 'None' + return !fileListType || fileListType === '' || fileListType === 'None'; + } + return fileListType === lt; + }); + }); + } + + // 访问状态筛选(综合判断 ListType 和 Label,支持多选,OR 逻辑) + // 'normal' = 正常:非已屏蔽状态 + // 'blocked' = 已屏蔽:ListType === 'Block' || (Label === 'adult' && ListType !== 'White') + // 注意:白名单优先,即使 Label 是 adult,只要 ListType 是 White 就是正常 + if (accessStatusArr.length > 0) { + filteredFiles = filteredFiles.filter(file => { + const fileListType = file.metadata.ListType; + const fileLabel = file.metadata.Label; + const isBlocked = fileListType === 'Block' || (fileLabel === 'adult' && fileListType !== 'White'); + + return accessStatusArr.some(status => { + if (status === 'normal') { + return !isBlocked; + } else if (status === 'blocked') { + return isBlocked; + } + return false; + }); + }); + } + + // 审查结果筛选 (label)(支持多选,OR 逻辑) + // 'normal' 匹配 Label 为 'everyone', 'None', '', null, undefined + // 'teen' 匹配 Label 为 'teen' + // 'adult' 匹配 Label 为 'adult' + if (labelArr.length > 0) { + filteredFiles = filteredFiles.filter(file => { + const fileLabel = file.metadata.Label; + return labelArr.some(lbl => { + if (lbl === 'normal') { + return !fileLabel || fileLabel === '' || fileLabel === 'None' || fileLabel === 'everyone'; + } else if (lbl === 'teen') { + return fileLabel === 'teen'; + } else if (lbl === 'adult') { + return fileLabel === 'adult'; + } + return false; + }); + }); + } + + // 文件类型筛选 (fileType)(支持多选,OR 逻辑) + // 'image' 匹配 FileType 以 'image/' 开头 + // 'video' 匹配 FileType 以 'video/' 开头 + // 'audio' 匹配 FileType 以 'audio/' 开头 + // 'other' 匹配不属于以上三类的文件 + if (fileTypeArr.length > 0) { + filteredFiles = filteredFiles.filter(file => { + const mimeType = file.metadata.FileType || ''; + return fileTypeArr.some(ft => { + if (ft === 'image') { + return mimeType.startsWith('image/'); + } else if (ft === 'video') { + return mimeType.startsWith('video/'); + } else if (ft === 'audio') { + return mimeType.startsWith('audio/'); + } else if (ft === 'other') { + return !mimeType.startsWith('image/') && + !mimeType.startsWith('video/') && + !mimeType.startsWith('audio/'); + } + return false; + }); + }); + } + + // 渠道名称筛选 (channelName)(支持多选,OR 逻辑) + // 支持 "type:name" 格式(如 "TelegramNew:default")或单独的名称 + if (channelNameArr.length > 0) { + filteredFiles = filteredFiles.filter(file => { + const fileChannel = file.metadata.Channel; + const fileChannelName = file.metadata.ChannelName; + + return channelNameArr.some(filterValue => { + // 检查是否是 "type:name" 格式 + if (filterValue.includes(':')) { + const [type, name] = filterValue.split(':', 2); + // 同时匹配渠道类型和名称(大小写敏感) + return fileChannel === type && fileChannelName === name; + } else { + // 只匹配名称(向后兼容) + return fileChannelName === filterValue; + } + }); + }); } // 标签过滤(独立于搜索关键字) diff --git a/index.html b/index.html index 948c410..8481943 100644 --- a/index.html +++ b/index.html @@ -1 +1 @@ -Sanyue ImgHub
\ No newline at end of file +Sanyue ImgHub
\ No newline at end of file diff --git a/index.html.gz b/index.html.gz index 94a31d4..9fa822c 100644 Binary files a/index.html.gz and b/index.html.gz differ diff --git a/js/226.478c43ad.js.gz b/js/226.478c43ad.js.gz deleted file mode 100644 index 9c63a88..0000000 Binary files a/js/226.478c43ad.js.gz and /dev/null differ diff --git a/js/845.97c9b302.js b/js/226.f737e39a.js similarity index 98% rename from js/845.97c9b302.js rename to js/226.f737e39a.js index 38f3eb6..6d5cd9c 100644 --- a/js/845.97c9b302.js +++ b/js/226.f737e39a.js @@ -1,2 +1,2 @@ -"use strict";(self["webpackChunksanyue_imghub"]=self["webpackChunksanyue_imghub"]||[]).push([[845],{6682:function(e,t,a){e.exports=a.p+"img/404.8ed11fb3.png"},7835:function(e,t,a){e.exports=a.p+"img/background-light.f17603bc.jpg"},8226:function(e,t,a){a.r(t),a.d(t,{default:function(){return B}});var n=a(47),i=(a(5331),a(9648),a(6768));const s={class:"not-found-container"},o=["innerHTML"],r={class:"not-found-content"},l={class:"back-button-wrapper"},c={class:"error-animation"},d={class:"error-image"},u=["src"],g={class:"error-info"},m={class:"error-actions"},h={class:"help-links"},p={class:"quick-links"};function k(e,t,a,k,b,y){const f=(0,i.g2)("font-awesome-icon"),v=n.S2;return(0,i.uX)(),(0,i.CE)("div",s,[(0,i.Lk)("div",{class:"background-wrapper",innerHTML:e.backgroundImagesTemplate},null,8,o),(0,i.Lk)("div",r,[(0,i.Lk)("div",l,[(0,i.bF)(v,{class:"back-button",onClick:y.goHome,circle:"",size:"large"},{default:(0,i.k6)(()=>[(0,i.bF)(f,{icon:"home"})]),_:1},8,["onClick"])]),(0,i.Lk)("div",c,[t[3]||(t[3]=(0,i.Lk)("div",{class:"error-number"},[(0,i.Lk)("span",{class:"four"},"4"),(0,i.Lk)("span",{class:"zero"},"0"),(0,i.Lk)("span",{class:"four"},"4")],-1)),(0,i.Lk)("div",d,[(0,i.Lk)("img",{src:y.errorImage,alt:"404",class:"floating-image"},null,8,u)])]),(0,i.Lk)("div",g,[t[10]||(t[10]=(0,i.Lk)("h1",{class:"error-title"},"页面走丢了",-1)),t[11]||(t[11]=(0,i.Lk)("p",{class:"error-description"}," 抱歉,您访问的页面可能已被删除、更名或暂时不可用 ",-1)),(0,i.Lk)("div",m,[(0,i.bF)(v,{type:"primary",size:"large",class:"action-btn primary-btn",onClick:y.goHome},{default:(0,i.k6)(()=>[(0,i.bF)(f,{icon:"home",class:"btn-icon"}),t[4]||(t[4]=(0,i.eW)(" 返回首页 ",-1))]),_:1},8,["onClick"]),(0,i.bF)(v,{size:"large",class:"action-btn secondary-btn",onClick:y.goBack},{default:(0,i.k6)(()=>[(0,i.bF)(f,{icon:"arrow-left",class:"btn-icon"}),t[5]||(t[5]=(0,i.eW)(" 返回上页 ",-1))]),_:1},8,["onClick"])]),(0,i.Lk)("div",h,[t[9]||(t[9]=(0,i.Lk)("p",{class:"help-text"},"也许您想要:",-1)),(0,i.Lk)("div",p,[(0,i.Lk)("a",{href:"javascript:void(0)",onClick:t[0]||(t[0]=(...e)=>y.goHome&&y.goHome(...e)),class:"quick-link"},[(0,i.bF)(f,{icon:"cloud-upload-alt"}),t[6]||(t[6]=(0,i.eW)(" 图片上传 ",-1))]),(0,i.Lk)("a",{href:"javascript:void(0)",onClick:t[1]||(t[1]=(...e)=>y.goDashboard&&y.goDashboard(...e)),class:"quick-link"},[(0,i.bF)(f,{icon:"tachometer-alt"}),t[7]||(t[7]=(0,i.eW)(" 管理面板 ",-1))]),(0,i.Lk)("a",{href:"javascript:void(0)",onClick:t[2]||(t[2]=(...e)=>y.refreshPage&&y.refreshPage(...e)),class:"quick-link"},[(0,i.bF)(f,{icon:"redo"}),t[8]||(t[8]=(0,i.eW)(" 刷新页面 ",-1))])])])])]),t[12]||(t[12]=(0,i.Fv)('
',1))])}a(4114);var b=a(8401),y=a(8903),f={name:"NotFound",mixins:[y.A],computed:{...(0,b.L8)(["useDarkMode","userConfig"]),errorImage(){return a(6682)}},mounted(){this.initializeBackground("uploadBkImg",".not-found-container",!1,!0)},beforeUnmount(){this.clearBackgroundInterval()},methods:{goHome(){this.$router.push("/")},goBack(){window.history.length>1?this.$router.go(-1):this.$router.push("/")},goDashboard(){this.$router.push("/dashboard")},refreshPage(){window.location.reload()}}},v=a(1241);const I=(0,v.A)(f,[["render",k],["__scopeId","data-v-5437e264"]]);var B=I},8351:function(e,t,a){e.exports=a.p+"img/background.ea1b7ee7.jpg"},8903:function(e,t,a){var n=a(8401);t.A={data(){return{bingWallPaperIndex:0,customWallPaperIndex:0,backgroundInterval:null,backgroundInitParams:null}},computed:{...(0,n.L8)(["userConfig","bingWallPapers","useDarkMode"]),bkInterval(){return this.userConfig?.bkInterval||3e3},bkOpacity(){return this.userConfig?.bkOpacity||1},backgroundImagesTemplate(){return'\n Background Image\n Background Image\n '},backgroundImagesStyles(){return"\n .background-image1 {\n position: fixed;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n object-fit: cover;\n z-index: -1;\n opacity: 0;\n transition: opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1), filter 0.3s ease;\n filter: var(--background-image-filter, brightness(1));\n }\n .background-image2 {\n position: fixed;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n object-fit: cover;\n z-index: -1;\n opacity: 0;\n transition: opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1), filter 0.3s ease;\n filter: var(--background-image-filter, brightness(1));\n }\n "}},watch:{useDarkMode(e,t){e!==t&&this.backgroundInitParams&&this.$nextTick(()=>{this.smoothThemeTransition(this.backgroundInitParams.configKey,this.backgroundInitParams.containerSelector,this.backgroundInitParams.useDefaultBackground,this.backgroundInitParams.autoCreateElements)})}},mounted(){this.injectBackgroundStyles()},beforeUnmount(){this.backgroundInterval&&clearInterval(this.backgroundInterval),this.clearBackgroundImages(!0),this.removeBackgroundStyles()},methods:{injectBackgroundStyles(){const e="background-manager-styles";if(!document.getElementById(e)){const t=document.createElement("style");t.id=e,t.textContent=this.backgroundImagesStyles,document.head.appendChild(t)}},removeBackgroundStyles(){const e="background-manager-styles",t=document.getElementById(e);t&&t.remove()},createBackgroundElements(e){if(!e)return void console.warn("未提供有效的容器元素");if(document.getElementById("bg1")||document.getElementById("bg2"))return;const t=document.createElement("img");t.id="bg1",t.className="background-image1",t.alt="Background Image";const a=document.createElement("img");a.id="bg2",a.className="background-image2",a.alt="Background Image",e.insertBefore(t,e.firstChild),e.insertBefore(a,e.firstChild)},initializeBackground(e,t=".login",a=!1,n=!1){if(this.backgroundInitParams={configKey:e,containerSelector:t,useDefaultBackground:a,autoCreateElements:n},n){const e=document.querySelector(t);!e||document.getElementById("bg1")&&document.getElementById("bg2")||this.createBackgroundElements(e)}const i=document.getElementById("bg1"),s=document.getElementById("bg2");if(!i||!s)return void console.warn("背景图元素 #bg1 或 #bg2 未找到,请确保页面中包含这些元素或启用 autoCreateElements");const o=this.userConfig?.[e];"bing"===o?this.setupBingWallpaper(i,s,t):Array.isArray(o)&&o.length>1?this.setupCustomWallpaperCarousel(i,s,o,t):Array.isArray(o)&&1===o.length?this.setupSingleCustomWallpaper(i,o[0],t):a&&this.setupDefaultWallpaper(i,t)},setupBingWallpaper(e,t,a){this.$store.dispatch("fetchBingWallPapers").then(()=>{0!==this.bingWallPapers.length&&(this.loadBackgroundImage(e,this.bingWallPapers[this.bingWallPaperIndex]?.url,a),this.backgroundInterval=setInterval(()=>{this.switchBingWallpaper(e,t)},this.bkInterval))})},setupCustomWallpaperCarousel(e,t,a,n){this.loadBackgroundImage(e,a[this.customWallPaperIndex],n),this.backgroundInterval=setInterval(()=>{this.switchCustomWallpaper(e,t,a)},this.bkInterval)},setupSingleCustomWallpaper(e,t,a){this.loadBackgroundImage(e,t,a)},setupDefaultWallpaper(e,t){const n=this.useDarkMode,i=a(n?8351:7835);this.loadBackgroundImage(e,i,t)},loadBackgroundImage(e,t,a){e.src=t,e.onload=()=>{e.style.opacity=this.bkOpacity;const t=document.querySelector(a);t&&(t.style.background="transparent")}},switchBingWallpaper(e,t){if(0===this.bingWallPapers.length)return;const a=0!=e.style.opacity?e:t,n=0!=e.style.opacity?t:e;a.style.opacity=0,this.bingWallPaperIndex=(this.bingWallPaperIndex+1)%this.bingWallPapers.length,n.src=this.bingWallPapers[this.bingWallPaperIndex]?.url,n.onload=()=>{n.style.opacity=this.bkOpacity}},switchCustomWallpaper(e,t,a){const n=0!=e.style.opacity?e:t,i=0!=e.style.opacity?t:e;n.style.opacity=0,this.customWallPaperIndex=(this.customWallPaperIndex+1)%a.length,i.src=a[this.customWallPaperIndex],i.onload=()=>{i.style.opacity=this.bkOpacity}},clearBackgroundInterval(){this.backgroundInterval&&(clearInterval(this.backgroundInterval),this.backgroundInterval=null)},clearBackgroundImages(e=!1){const t=document.getElementById("bg1"),a=document.getElementById("bg2");e?(t&&(t.style.transition="none",t.style.opacity=0,t.src="",setTimeout(()=>{t&&(t.style.transition="opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1)")},50)),a&&(a.style.transition="none",a.style.opacity=0,a.src="",setTimeout(()=>{a&&(a.style.transition="opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1)")},50))):(t&&(t.style.opacity=0,setTimeout(()=>{t&&(t.src="")},800)),a&&(a.style.opacity=0,setTimeout(()=>{a&&(a.src="")},800)))},smoothThemeTransition(e,t=".login",n=!1,i=!1){const s=this.userConfig?.[e];if(!n||void 0!==s)return void this.reinitializeBackground(e,t,n,i);const o=document.getElementById("bg1"),r=document.getElementById("bg2");if(!o||!r)return void this.reinitializeBackground(e,t,n,i);const l=0!=o.style.opacity?o:r,c=0!=o.style.opacity?r:o,d=this.useDarkMode,u=a(d?8351:7835),g=new Image;g.onload=()=>{c.src=u,c.onload=()=>{l.style.opacity=0,setTimeout(()=>{c.style.opacity=this.bkOpacity;const e=document.querySelector(t);e&&(e.style.background="transparent")},50)}},g.onerror=()=>{console.warn("主题背景图预加载失败,回退到直接切换"),this.reinitializeBackground(e,t,n,i)},g.src=u},reinitializeBackground(e,t=".login",a=!1,n=!1){this.clearBackgroundInterval(),this.clearBackgroundImages(!0),this.bingWallPaperIndex=0,this.customWallPaperIndex=0,setTimeout(()=>{this.initializeBackground(e,t,a,n)},100)}}}}}]); -//# sourceMappingURL=845.97c9b302.js.map \ No newline at end of file +"use strict";(self["webpackChunksanyue_imghub"]=self["webpackChunksanyue_imghub"]||[]).push([[226],{6682:function(e,t,a){e.exports=a.p+"img/404.8ed11fb3.png"},7835:function(e,t,a){e.exports=a.p+"img/background-light.f17603bc.jpg"},8226:function(e,t,a){a.r(t),a.d(t,{default:function(){return B}});var n=a(47),i=(a(5331),a(9648),a(6768));const s={class:"not-found-container"},o=["innerHTML"],r={class:"not-found-content"},l={class:"back-button-wrapper"},c={class:"error-animation"},d={class:"error-image"},u=["src"],g={class:"error-info"},m={class:"error-actions"},h={class:"help-links"},p={class:"quick-links"};function k(e,t,a,k,b,y){const f=(0,i.g2)("font-awesome-icon"),v=n.S2;return(0,i.uX)(),(0,i.CE)("div",s,[(0,i.Lk)("div",{class:"background-wrapper",innerHTML:e.backgroundImagesTemplate},null,8,o),(0,i.Lk)("div",r,[(0,i.Lk)("div",l,[(0,i.bF)(v,{class:"back-button",onClick:y.goHome,circle:"",size:"large"},{default:(0,i.k6)(()=>[(0,i.bF)(f,{icon:"home"})]),_:1},8,["onClick"])]),(0,i.Lk)("div",c,[t[3]||(t[3]=(0,i.Lk)("div",{class:"error-number"},[(0,i.Lk)("span",{class:"four"},"4"),(0,i.Lk)("span",{class:"zero"},"0"),(0,i.Lk)("span",{class:"four"},"4")],-1)),(0,i.Lk)("div",d,[(0,i.Lk)("img",{src:y.errorImage,alt:"404",class:"floating-image"},null,8,u)])]),(0,i.Lk)("div",g,[t[10]||(t[10]=(0,i.Lk)("h1",{class:"error-title"},"页面走丢了",-1)),t[11]||(t[11]=(0,i.Lk)("p",{class:"error-description"}," 抱歉,您访问的页面可能已被删除、更名或暂时不可用 ",-1)),(0,i.Lk)("div",m,[(0,i.bF)(v,{type:"primary",size:"large",class:"action-btn primary-btn",onClick:y.goHome},{default:(0,i.k6)(()=>[(0,i.bF)(f,{icon:"home",class:"btn-icon"}),t[4]||(t[4]=(0,i.eW)(" 返回首页 ",-1))]),_:1},8,["onClick"]),(0,i.bF)(v,{size:"large",class:"action-btn secondary-btn",onClick:y.goBack},{default:(0,i.k6)(()=>[(0,i.bF)(f,{icon:"arrow-left",class:"btn-icon"}),t[5]||(t[5]=(0,i.eW)(" 返回上页 ",-1))]),_:1},8,["onClick"])]),(0,i.Lk)("div",h,[t[9]||(t[9]=(0,i.Lk)("p",{class:"help-text"},"也许您想要:",-1)),(0,i.Lk)("div",p,[(0,i.Lk)("a",{href:"javascript:void(0)",onClick:t[0]||(t[0]=(...e)=>y.goHome&&y.goHome(...e)),class:"quick-link"},[(0,i.bF)(f,{icon:"cloud-upload-alt"}),t[6]||(t[6]=(0,i.eW)(" 图片上传 ",-1))]),(0,i.Lk)("a",{href:"javascript:void(0)",onClick:t[1]||(t[1]=(...e)=>y.goDashboard&&y.goDashboard(...e)),class:"quick-link"},[(0,i.bF)(f,{icon:"tachometer-alt"}),t[7]||(t[7]=(0,i.eW)(" 管理面板 ",-1))]),(0,i.Lk)("a",{href:"javascript:void(0)",onClick:t[2]||(t[2]=(...e)=>y.refreshPage&&y.refreshPage(...e)),class:"quick-link"},[(0,i.bF)(f,{icon:"redo"}),t[8]||(t[8]=(0,i.eW)(" 刷新页面 ",-1))])])])])]),t[12]||(t[12]=(0,i.Fv)('
',1))])}a(4114);var b=a(8401),y=a(8903),f={name:"NotFound",mixins:[y.A],computed:{...(0,b.L8)(["useDarkMode","userConfig"]),errorImage(){return a(6682)}},mounted(){this.initializeBackground("uploadBkImg",".not-found-container",!1,!0)},beforeUnmount(){this.clearBackgroundInterval()},methods:{goHome(){this.$router.push("/")},goBack(){window.history.length>1?this.$router.go(-1):this.$router.push("/")},goDashboard(){this.$router.push("/dashboard")},refreshPage(){window.location.reload()}}},v=a(1241);const I=(0,v.A)(f,[["render",k],["__scopeId","data-v-5437e264"]]);var B=I},8351:function(e,t,a){e.exports=a.p+"img/background.ea1b7ee7.jpg"},8903:function(e,t,a){var n=a(8401);t.A={data(){return{bingWallPaperIndex:0,customWallPaperIndex:0,backgroundInterval:null,backgroundInitParams:null}},computed:{...(0,n.L8)(["userConfig","bingWallPapers","useDarkMode"]),bkInterval(){return this.userConfig?.bkInterval||3e3},bkOpacity(){return this.userConfig?.bkOpacity||1},backgroundImagesTemplate(){return'\n Background Image\n Background Image\n '},backgroundImagesStyles(){return"\n .background-image1 {\n position: fixed;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n object-fit: cover;\n z-index: -1;\n opacity: 0;\n transition: opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1), filter 0.3s ease;\n filter: var(--background-image-filter, brightness(1));\n }\n .background-image2 {\n position: fixed;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n object-fit: cover;\n z-index: -1;\n opacity: 0;\n transition: opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1), filter 0.3s ease;\n filter: var(--background-image-filter, brightness(1));\n }\n "}},watch:{useDarkMode(e,t){e!==t&&this.backgroundInitParams&&this.$nextTick(()=>{this.smoothThemeTransition(this.backgroundInitParams.configKey,this.backgroundInitParams.containerSelector,this.backgroundInitParams.useDefaultBackground,this.backgroundInitParams.autoCreateElements)})}},mounted(){this.injectBackgroundStyles()},beforeUnmount(){this.backgroundInterval&&clearInterval(this.backgroundInterval),this.clearBackgroundImages(!0),this.removeBackgroundStyles()},methods:{injectBackgroundStyles(){const e="background-manager-styles";if(!document.getElementById(e)){const t=document.createElement("style");t.id=e,t.textContent=this.backgroundImagesStyles,document.head.appendChild(t)}},removeBackgroundStyles(){const e="background-manager-styles",t=document.getElementById(e);t&&t.remove()},createBackgroundElements(e){if(!e)return void console.warn("未提供有效的容器元素");if(document.getElementById("bg1")||document.getElementById("bg2"))return;const t=document.createElement("img");t.id="bg1",t.className="background-image1",t.alt="Background Image";const a=document.createElement("img");a.id="bg2",a.className="background-image2",a.alt="Background Image",e.insertBefore(t,e.firstChild),e.insertBefore(a,e.firstChild)},initializeBackground(e,t=".login",a=!1,n=!1){if(this.backgroundInitParams={configKey:e,containerSelector:t,useDefaultBackground:a,autoCreateElements:n},n){const e=document.querySelector(t);!e||document.getElementById("bg1")&&document.getElementById("bg2")||this.createBackgroundElements(e)}const i=document.getElementById("bg1"),s=document.getElementById("bg2");if(!i||!s)return void console.warn("背景图元素 #bg1 或 #bg2 未找到,请确保页面中包含这些元素或启用 autoCreateElements");const o=this.userConfig?.[e];"bing"===o?this.setupBingWallpaper(i,s,t):Array.isArray(o)&&o.length>1?this.setupCustomWallpaperCarousel(i,s,o,t):Array.isArray(o)&&1===o.length?this.setupSingleCustomWallpaper(i,o[0],t):a&&this.setupDefaultWallpaper(i,t)},setupBingWallpaper(e,t,a){this.$store.dispatch("fetchBingWallPapers").then(()=>{0!==this.bingWallPapers.length&&(this.loadBackgroundImage(e,this.bingWallPapers[this.bingWallPaperIndex]?.url,a),this.backgroundInterval=setInterval(()=>{this.switchBingWallpaper(e,t)},this.bkInterval))})},setupCustomWallpaperCarousel(e,t,a,n){this.loadBackgroundImage(e,a[this.customWallPaperIndex],n),this.backgroundInterval=setInterval(()=>{this.switchCustomWallpaper(e,t,a)},this.bkInterval)},setupSingleCustomWallpaper(e,t,a){this.loadBackgroundImage(e,t,a)},setupDefaultWallpaper(e,t){const n=this.useDarkMode,i=a(n?8351:7835);this.loadBackgroundImage(e,i,t)},loadBackgroundImage(e,t,a){e.src=t,e.onload=()=>{e.style.opacity=this.bkOpacity;const t=document.querySelector(a);t&&(t.style.background="transparent")}},switchBingWallpaper(e,t){if(0===this.bingWallPapers.length)return;const a=0!=e.style.opacity?e:t,n=0!=e.style.opacity?t:e;a.style.opacity=0,this.bingWallPaperIndex=(this.bingWallPaperIndex+1)%this.bingWallPapers.length,n.src=this.bingWallPapers[this.bingWallPaperIndex]?.url,n.onload=()=>{n.style.opacity=this.bkOpacity}},switchCustomWallpaper(e,t,a){const n=0!=e.style.opacity?e:t,i=0!=e.style.opacity?t:e;n.style.opacity=0,this.customWallPaperIndex=(this.customWallPaperIndex+1)%a.length,i.src=a[this.customWallPaperIndex],i.onload=()=>{i.style.opacity=this.bkOpacity}},clearBackgroundInterval(){this.backgroundInterval&&(clearInterval(this.backgroundInterval),this.backgroundInterval=null)},clearBackgroundImages(e=!1){const t=document.getElementById("bg1"),a=document.getElementById("bg2");e?(t&&(t.style.transition="none",t.style.opacity=0,t.src="",setTimeout(()=>{t&&(t.style.transition="opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1)")},50)),a&&(a.style.transition="none",a.style.opacity=0,a.src="",setTimeout(()=>{a&&(a.style.transition="opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1)")},50))):(t&&(t.style.opacity=0,setTimeout(()=>{t&&(t.src="")},800)),a&&(a.style.opacity=0,setTimeout(()=>{a&&(a.src="")},800)))},smoothThemeTransition(e,t=".login",n=!1,i=!1){const s=this.userConfig?.[e];if(!n||void 0!==s)return void this.reinitializeBackground(e,t,n,i);const o=document.getElementById("bg1"),r=document.getElementById("bg2");if(!o||!r)return void this.reinitializeBackground(e,t,n,i);const l=0!=o.style.opacity?o:r,c=0!=o.style.opacity?r:o,d=this.useDarkMode,u=a(d?8351:7835),g=new Image;g.onload=()=>{c.src=u,c.onload=()=>{l.style.opacity=0,setTimeout(()=>{c.style.opacity=this.bkOpacity;const e=document.querySelector(t);e&&(e.style.background="transparent")},50)}},g.onerror=()=>{console.warn("主题背景图预加载失败,回退到直接切换"),this.reinitializeBackground(e,t,n,i)},g.src=u},reinitializeBackground(e,t=".login",a=!1,n=!1){this.clearBackgroundInterval(),this.clearBackgroundImages(!0),this.bingWallPaperIndex=0,this.customWallPaperIndex=0,setTimeout(()=>{this.initializeBackground(e,t,a,n)},100)}}}}}]); +//# sourceMappingURL=226.f737e39a.js.map \ No newline at end of file diff --git a/js/226.f737e39a.js.gz b/js/226.f737e39a.js.gz new file mode 100644 index 0000000..55a51c9 Binary files /dev/null and b/js/226.f737e39a.js.gz differ diff --git a/js/845.97c9b302.js.map b/js/226.f737e39a.js.map similarity index 99% rename from js/845.97c9b302.js.map rename to js/226.f737e39a.js.map index 7d28239..6e6aa8c 100644 --- a/js/845.97c9b302.js.map +++ b/js/226.f737e39a.js.map @@ -1 +1 @@ -{"version":3,"file":"js/845.97c9b302.js","mappings":"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","sources":["webpack://sanyue_imghub/./src/views/NotFound.vue?1f11","webpack://sanyue_imghub/./src/views/NotFound.vue","webpack://sanyue_imghub/./src/views/NotFound.vue?5f0d","webpack://sanyue_imghub/./src/mixins/backgroundManager.js"],"sourcesContent":["import { createElementVNode as _createElementVNode, resolveComponent as _resolveComponent, createVNode as _createVNode, withCtx as _withCtx, createTextVNode as _createTextVNode, createStaticVNode as _createStaticVNode, openBlock as _openBlock, createElementBlock as _createElementBlock } from \"vue\";\nconst _hoisted_1 = {\n class: \"not-found-container\"\n};\nconst _hoisted_2 = [\"innerHTML\"];\nconst _hoisted_3 = {\n class: \"not-found-content\"\n};\nconst _hoisted_4 = {\n class: \"back-button-wrapper\"\n};\nconst _hoisted_5 = {\n class: \"error-animation\"\n};\nconst _hoisted_6 = {\n class: \"error-image\"\n};\nconst _hoisted_7 = [\"src\"];\nconst _hoisted_8 = {\n class: \"error-info\"\n};\nconst _hoisted_9 = {\n class: \"error-actions\"\n};\nconst _hoisted_10 = {\n class: \"help-links\"\n};\nconst _hoisted_11 = {\n class: \"quick-links\"\n};\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n const _component_el_button = _resolveComponent(\"el-button\");\n return _openBlock(), _createElementBlock(\"div\", _hoisted_1, [_createElementVNode(\"div\", {\n class: \"background-wrapper\",\n innerHTML: _ctx.backgroundImagesTemplate\n }, null, 8, _hoisted_2), _createElementVNode(\"div\", _hoisted_3, [_createElementVNode(\"div\", _hoisted_4, [_createVNode(_component_el_button, {\n class: \"back-button\",\n onClick: $options.goHome,\n circle: \"\",\n size: \"large\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"home\"\n })]),\n _: 1\n }, 8, [\"onClick\"])]), _createElementVNode(\"div\", _hoisted_5, [_cache[3] || (_cache[3] = _createElementVNode(\"div\", {\n class: \"error-number\"\n }, [_createElementVNode(\"span\", {\n class: \"four\"\n }, \"4\"), _createElementVNode(\"span\", {\n class: \"zero\"\n }, \"0\"), _createElementVNode(\"span\", {\n class: \"four\"\n }, \"4\")], -1)), _createElementVNode(\"div\", _hoisted_6, [_createElementVNode(\"img\", {\n src: $options.errorImage,\n alt: \"404\",\n class: \"floating-image\"\n }, null, 8, _hoisted_7)])]), _createElementVNode(\"div\", _hoisted_8, [_cache[10] || (_cache[10] = _createElementVNode(\"h1\", {\n class: \"error-title\"\n }, \"页面走丢了\", -1)), _cache[11] || (_cache[11] = _createElementVNode(\"p\", {\n class: \"error-description\"\n }, \" 抱歉,您访问的页面可能已被删除、更名或暂时不可用 \", -1)), _createElementVNode(\"div\", _hoisted_9, [_createVNode(_component_el_button, {\n type: \"primary\",\n size: \"large\",\n class: \"action-btn primary-btn\",\n onClick: $options.goHome\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"home\",\n class: \"btn-icon\"\n }), _cache[4] || (_cache[4] = _createTextVNode(\" 返回首页 \", -1))]),\n _: 1\n }, 8, [\"onClick\"]), _createVNode(_component_el_button, {\n size: \"large\",\n class: \"action-btn secondary-btn\",\n onClick: $options.goBack\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"arrow-left\",\n class: \"btn-icon\"\n }), _cache[5] || (_cache[5] = _createTextVNode(\" 返回上页 \", -1))]),\n _: 1\n }, 8, [\"onClick\"])]), _createElementVNode(\"div\", _hoisted_10, [_cache[9] || (_cache[9] = _createElementVNode(\"p\", {\n class: \"help-text\"\n }, \"也许您想要:\", -1)), _createElementVNode(\"div\", _hoisted_11, [_createElementVNode(\"a\", {\n href: \"javascript:void(0)\",\n onClick: _cache[0] || (_cache[0] = (...args) => $options.goHome && $options.goHome(...args)),\n class: \"quick-link\"\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"cloud-upload-alt\"\n }), _cache[6] || (_cache[6] = _createTextVNode(\" 图片上传 \", -1))]), _createElementVNode(\"a\", {\n href: \"javascript:void(0)\",\n onClick: _cache[1] || (_cache[1] = (...args) => $options.goDashboard && $options.goDashboard(...args)),\n class: \"quick-link\"\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"tachometer-alt\"\n }), _cache[7] || (_cache[7] = _createTextVNode(\" 管理面板 \", -1))]), _createElementVNode(\"a\", {\n href: \"javascript:void(0)\",\n onClick: _cache[2] || (_cache[2] = (...args) => $options.refreshPage && $options.refreshPage(...args)),\n class: \"quick-link\"\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"redo\"\n }), _cache[8] || (_cache[8] = _createTextVNode(\" 刷新页面 \", -1))])])])])]), _cache[12] || (_cache[12] = _createStaticVNode(\"
\", 1))]);\n}","import \"core-js/modules/es.array.push.js\";\nimport { mapGetters } from 'vuex';\nimport backgroundManager from '@/mixins/backgroundManager';\nexport default {\n name: 'NotFound',\n mixins: [backgroundManager],\n computed: {\n ...mapGetters(['useDarkMode', 'userConfig']),\n errorImage() {\n // 使用项目中已有的404图片\n return require('@/assets/404.png');\n }\n },\n mounted() {\n // 初始化背景图\n this.initializeBackground('uploadBkImg', '.not-found-container', false, true);\n },\n beforeUnmount() {\n // 清理背景轮播定时器\n this.clearBackgroundInterval();\n },\n methods: {\n goHome() {\n this.$router.push('/');\n },\n goBack() {\n if (window.history.length > 1) {\n this.$router.go(-1);\n } else {\n this.$router.push('/');\n }\n },\n goDashboard() {\n this.$router.push('/dashboard');\n },\n refreshPage() {\n window.location.reload();\n }\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./NotFound.vue?vue&type=template&id=5437e264&scoped=true\"\nimport script from \"./NotFound.vue?vue&type=script&lang=js\"\nexport * from \"./NotFound.vue?vue&type=script&lang=js\"\n\nimport \"./NotFound.vue?vue&type=style&index=0&id=5437e264&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-5437e264\"]])\n\nexport default __exports__","/**\r\n * 背景图管理 Mixin\r\n * 用于统一管理页面背景图的加载和轮播逻辑\r\n */\r\n\r\nimport { mapGetters } from 'vuex'\r\n\r\nexport default {\r\n data() {\r\n return {\r\n bingWallPaperIndex: 0,\r\n customWallPaperIndex: 0,\r\n backgroundInterval: null, // 存储轮播定时器\r\n // 存储初始化参数,用于主题切换时重新初始化\r\n backgroundInitParams: null,\r\n }\r\n },\r\n computed: {\r\n ...mapGetters(['userConfig', 'bingWallPapers', 'useDarkMode']),\r\n bkInterval() {\r\n return this.userConfig?.bkInterval || 3000\r\n },\r\n bkOpacity() {\r\n return this.userConfig?.bkOpacity || 1\r\n },\r\n // 提供背景图片元素的模板\r\n backgroundImagesTemplate() {\r\n return `\r\n \"Background\r\n \"Background\r\n `\r\n },\r\n // 提供背景图片的CSS样式\r\n backgroundImagesStyles() {\r\n return `\r\n .background-image1 {\r\n position: fixed;\r\n top: 0;\r\n left: 0;\r\n width: 100%;\r\n height: 100%;\r\n object-fit: cover;\r\n z-index: -1;\r\n opacity: 0;\r\n transition: opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1), filter 0.3s ease;\r\n filter: var(--background-image-filter, brightness(1));\r\n }\r\n .background-image2 {\r\n position: fixed;\r\n top: 0;\r\n left: 0;\r\n width: 100%;\r\n height: 100%;\r\n object-fit: cover;\r\n z-index: -1;\r\n opacity: 0;\r\n transition: opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1), filter 0.3s ease;\r\n filter: var(--background-image-filter, brightness(1));\r\n }\r\n `\r\n }\r\n },\r\n\r\n watch: {\r\n // 监听深色模式切换\r\n useDarkMode(newVal, oldVal) {\r\n // 只有在值真正改变且已经初始化过背景时才平滑切换主题\r\n if (newVal !== oldVal && this.backgroundInitParams) {\r\n this.$nextTick(() => {\r\n this.smoothThemeTransition(\r\n this.backgroundInitParams.configKey,\r\n this.backgroundInitParams.containerSelector,\r\n this.backgroundInitParams.useDefaultBackground,\r\n this.backgroundInitParams.autoCreateElements\r\n )\r\n })\r\n }\r\n }\r\n },\r\n\r\n mounted() {\r\n // 动态注入背景图片的CSS样式\r\n this.injectBackgroundStyles()\r\n },\r\n\r\n beforeUnmount() {\r\n // 组件销毁前清除定时器\r\n if (this.backgroundInterval) {\r\n clearInterval(this.backgroundInterval)\r\n }\r\n // 立即清除背景图片,不使用过渡效果\r\n this.clearBackgroundImages(true)\r\n // 移除动态注入的样式\r\n this.removeBackgroundStyles()\r\n },\r\n\r\n methods: {\r\n /**\r\n * 动态注入背景图片样式\r\n */\r\n injectBackgroundStyles() {\r\n const styleId = 'background-manager-styles'\r\n if (!document.getElementById(styleId)) {\r\n const style = document.createElement('style')\r\n style.id = styleId\r\n style.textContent = this.backgroundImagesStyles\r\n document.head.appendChild(style)\r\n }\r\n },\r\n\r\n /**\r\n * 移除动态注入的样式\r\n */\r\n removeBackgroundStyles() {\r\n const styleId = 'background-manager-styles'\r\n const existingStyle = document.getElementById(styleId)\r\n if (existingStyle) {\r\n existingStyle.remove()\r\n }\r\n },\r\n\r\n /**\r\n * 动态创建背景图片元素\r\n * @param {HTMLElement} container - 要插入背景图片的容器元素\r\n */\r\n createBackgroundElements(container) {\r\n if (!container) {\r\n console.warn('未提供有效的容器元素')\r\n return\r\n }\r\n\r\n // 检查是否已经存在背景图片元素\r\n if (document.getElementById('bg1') || document.getElementById('bg2')) {\r\n return\r\n }\r\n\r\n // 创建 bg1 元素\r\n const bg1 = document.createElement('img')\r\n bg1.id = 'bg1'\r\n bg1.className = 'background-image1'\r\n bg1.alt = 'Background Image'\r\n \r\n // 创建 bg2 元素\r\n const bg2 = document.createElement('img')\r\n bg2.id = 'bg2'\r\n bg2.className = 'background-image2'\r\n bg2.alt = 'Background Image'\r\n\r\n // 将元素插入到容器的开头\r\n container.insertBefore(bg1, container.firstChild)\r\n container.insertBefore(bg2, container.firstChild)\r\n },\r\n /**\r\n * 初始化背景图\r\n * @param {string} configKey - 用户配置中的背景图配置键名\r\n * @param {string} containerSelector - 容器选择器,用于设置透明背景\r\n * @param {boolean} useDefaultBackground - 是否使用默认背景图\r\n * @param {boolean} autoCreateElements - 是否自动创建背景元素\r\n */\r\n initializeBackground(configKey, containerSelector = '.login', useDefaultBackground = false, autoCreateElements = false) {\r\n // 保存初始化参数,用于主题切换时重新初始化\r\n this.backgroundInitParams = {\r\n configKey,\r\n containerSelector,\r\n useDefaultBackground,\r\n autoCreateElements\r\n }\r\n\r\n // 如果需要自动创建元素且元素不存在,则创建\r\n if (autoCreateElements) {\r\n const container = document.querySelector(containerSelector)\r\n if (container && (!document.getElementById('bg1') || !document.getElementById('bg2'))) {\r\n this.createBackgroundElements(container)\r\n }\r\n }\r\n\r\n const bg1 = document.getElementById('bg1')\r\n const bg2 = document.getElementById('bg2')\r\n \r\n if (!bg1 || !bg2) {\r\n console.warn('背景图元素 #bg1 或 #bg2 未找到,请确保页面中包含这些元素或启用 autoCreateElements')\r\n return\r\n }\r\n\r\n const backgroundConfig = this.userConfig?.[configKey]\r\n\r\n if (backgroundConfig === 'bing') {\r\n this.setupBingWallpaper(bg1, bg2, containerSelector)\r\n } else if (Array.isArray(backgroundConfig) && backgroundConfig.length > 1) {\r\n this.setupCustomWallpaperCarousel(bg1, bg2, backgroundConfig, containerSelector)\r\n } else if (Array.isArray(backgroundConfig) && backgroundConfig.length === 1) {\r\n this.setupSingleCustomWallpaper(bg1, backgroundConfig[0], containerSelector)\r\n } else if (useDefaultBackground) {\r\n this.setupDefaultWallpaper(bg1, containerSelector)\r\n }\r\n },\r\n\r\n /**\r\n * 设置 Bing 壁纸轮播\r\n */\r\n setupBingWallpaper(bg1, bg2, containerSelector) {\r\n this.$store.dispatch('fetchBingWallPapers').then(() => {\r\n if (this.bingWallPapers.length === 0) return\r\n\r\n this.loadBackgroundImage(bg1, this.bingWallPapers[this.bingWallPaperIndex]?.url, containerSelector)\r\n \r\n this.backgroundInterval = setInterval(() => {\r\n this.switchBingWallpaper(bg1, bg2)\r\n }, this.bkInterval)\r\n })\r\n },\r\n\r\n /**\r\n * 设置自定义壁纸轮播\r\n */\r\n setupCustomWallpaperCarousel(bg1, bg2, wallpapers, containerSelector) {\r\n this.loadBackgroundImage(bg1, wallpapers[this.customWallPaperIndex], containerSelector)\r\n \r\n this.backgroundInterval = setInterval(() => {\r\n this.switchCustomWallpaper(bg1, bg2, wallpapers)\r\n }, this.bkInterval)\r\n },\r\n\r\n /**\r\n * 设置单张自定义壁纸\r\n */\r\n setupSingleCustomWallpaper(bg1, wallpaperUrl, containerSelector) {\r\n this.loadBackgroundImage(bg1, wallpaperUrl, containerSelector)\r\n },\r\n\r\n /**\r\n * 设置默认壁纸\r\n */\r\n setupDefaultWallpaper(bg1, containerSelector) {\r\n // 根据当前深色模式状态选择背景图\r\n const isDark = this.useDarkMode\r\n const defaultImage = isDark \r\n ? require('@/assets/background.jpg') \r\n : require('@/assets/background-light.jpg')\r\n \r\n this.loadBackgroundImage(bg1, defaultImage, containerSelector)\r\n },\r\n\r\n /**\r\n * 加载背景图片\r\n */\r\n loadBackgroundImage(imgElement, imageSrc, containerSelector) {\r\n imgElement.src = imageSrc\r\n imgElement.onload = () => {\r\n imgElement.style.opacity = this.bkOpacity\r\n // 设置容器背景为透明\r\n const container = document.querySelector(containerSelector)\r\n if (container) {\r\n container.style.background = 'transparent'\r\n }\r\n }\r\n },\r\n\r\n /**\r\n * 切换 Bing 壁纸\r\n */\r\n switchBingWallpaper(bg1, bg2) {\r\n if (this.bingWallPapers.length === 0) return\r\n\r\n const curBg = bg1.style.opacity != 0 ? bg1 : bg2\r\n const nextBg = bg1.style.opacity != 0 ? bg2 : bg1\r\n \r\n curBg.style.opacity = 0\r\n this.bingWallPaperIndex = (this.bingWallPaperIndex + 1) % this.bingWallPapers.length\r\n \r\n nextBg.src = this.bingWallPapers[this.bingWallPaperIndex]?.url\r\n nextBg.onload = () => {\r\n nextBg.style.opacity = this.bkOpacity\r\n }\r\n },\r\n\r\n /**\r\n * 切换自定义壁纸\r\n */\r\n switchCustomWallpaper(bg1, bg2, wallpapers) {\r\n const curBg = bg1.style.opacity != 0 ? bg1 : bg2\r\n const nextBg = bg1.style.opacity != 0 ? bg2 : bg1\r\n \r\n curBg.style.opacity = 0\r\n this.customWallPaperIndex = (this.customWallPaperIndex + 1) % wallpapers.length\r\n \r\n nextBg.src = wallpapers[this.customWallPaperIndex]\r\n nextBg.onload = () => {\r\n nextBg.style.opacity = this.bkOpacity\r\n }\r\n },\r\n\r\n /**\r\n * 清除背景轮播定时器\r\n */\r\n clearBackgroundInterval() {\r\n if (this.backgroundInterval) {\r\n clearInterval(this.backgroundInterval)\r\n this.backgroundInterval = null\r\n }\r\n },\r\n\r\n /**\r\n * 清除背景图片显示(带过渡效果)\r\n * @param {boolean} immediate - 是否立即清除,不使用过渡效果\r\n */\r\n clearBackgroundImages(immediate = false) {\r\n const bg1 = document.getElementById('bg1')\r\n const bg2 = document.getElementById('bg2')\r\n \r\n if (immediate) {\r\n // 立即清除,不使用过渡效果\r\n if (bg1) {\r\n bg1.style.transition = 'none'\r\n bg1.style.opacity = 0\r\n bg1.src = ''\r\n // 恢复过渡效果\r\n setTimeout(() => {\r\n if (bg1) bg1.style.transition = 'opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1)'\r\n }, 50)\r\n }\r\n if (bg2) {\r\n bg2.style.transition = 'none'\r\n bg2.style.opacity = 0\r\n bg2.src = ''\r\n // 恢复过渡效果\r\n setTimeout(() => {\r\n if (bg2) bg2.style.transition = 'opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1)'\r\n }, 50)\r\n }\r\n } else {\r\n // 使用过渡效果淡出\r\n if (bg1) {\r\n bg1.style.opacity = 0\r\n setTimeout(() => {\r\n if (bg1) bg1.src = ''\r\n }, 800) // 等待过渡完成后清除src\r\n }\r\n if (bg2) {\r\n bg2.style.opacity = 0\r\n setTimeout(() => {\r\n if (bg2) bg2.src = ''\r\n }, 800) // 等待过渡完成后清除src\r\n }\r\n }\r\n },\r\n\r\n /**\r\n * 平滑主题切换(用于响应主题模式变化)\r\n * @param {string} configKey - 用户配置中的背景图配置键名\r\n * @param {string} containerSelector - 容器选择器\r\n * @param {boolean} useDefaultBackground - 是否使用默认背景图\r\n * @param {boolean} autoCreateElements - 是否自动创建背景元素\r\n */\r\n smoothThemeTransition(configKey, containerSelector = '.login', useDefaultBackground = false, autoCreateElements = false) {\r\n const backgroundConfig = this.userConfig?.[configKey]\r\n \r\n // 如果不是默认背景配置,则直接重新初始化(自定义背景不受主题影响)\r\n if (!useDefaultBackground || backgroundConfig !== undefined) {\r\n this.reinitializeBackground(configKey, containerSelector, useDefaultBackground, autoCreateElements)\r\n return\r\n }\r\n\r\n // 对于默认背景,执行平滑过渡\r\n const bg1 = document.getElementById('bg1')\r\n const bg2 = document.getElementById('bg2')\r\n \r\n if (!bg1 || !bg2) {\r\n // 如果背景元素不存在,直接重新初始化\r\n this.reinitializeBackground(configKey, containerSelector, useDefaultBackground, autoCreateElements)\r\n return\r\n }\r\n\r\n // 确定当前显示的背景和下一个背景\r\n const currentBg = bg1.style.opacity != 0 ? bg1 : bg2\r\n const nextBg = bg1.style.opacity != 0 ? bg2 : bg1\r\n\r\n // 获取新主题对应的背景图\r\n const isDark = this.useDarkMode\r\n const newThemeImage = isDark \r\n ? require('@/assets/background.jpg') \r\n : require('@/assets/background-light.jpg')\r\n\r\n // 预加载新背景图\r\n const preloadImg = new Image()\r\n preloadImg.onload = () => {\r\n // 设置下一个背景的图片源\r\n nextBg.src = newThemeImage\r\n \r\n // 等待图片加载完成后执行淡入淡出过渡\r\n nextBg.onload = () => {\r\n // 淡出当前背景\r\n currentBg.style.opacity = 0\r\n \r\n // 稍微延迟后淡入新背景,确保过渡效果平滑\r\n setTimeout(() => {\r\n nextBg.style.opacity = this.bkOpacity\r\n \r\n // 设置容器背景为透明\r\n const container = document.querySelector(containerSelector)\r\n if (container) {\r\n container.style.background = 'transparent'\r\n }\r\n }, 50) // 50ms 延迟,让淡出效果先开始\r\n }\r\n }\r\n \r\n preloadImg.onerror = () => {\r\n // 如果预加载失败,回退到直接重新初始化\r\n console.warn('主题背景图预加载失败,回退到直接切换')\r\n this.reinitializeBackground(configKey, containerSelector, useDefaultBackground, autoCreateElements)\r\n }\r\n \r\n preloadImg.src = newThemeImage\r\n },\r\n\r\n /**\r\n * 重新初始化背景图(用于响应配置变化)\r\n */\r\n reinitializeBackground(configKey, containerSelector = '.login', useDefaultBackground = false, autoCreateElements = false) {\r\n this.clearBackgroundInterval()\r\n this.clearBackgroundImages(true) // 使用立即清除\r\n this.bingWallPaperIndex = 0\r\n this.customWallPaperIndex = 0\r\n \r\n // 延迟一小段时间确保清理完成\r\n setTimeout(() => {\r\n this.initializeBackground(configKey, containerSelector, useDefaultBackground, autoCreateElements)\r\n }, 100)\r\n }\r\n }\r\n}\r\n"],"names":["_hoisted_1","class","_hoisted_2","_hoisted_3","_hoisted_4","_hoisted_5","_hoisted_6","_hoisted_7","_hoisted_8","_hoisted_9","_hoisted_10","_hoisted_11","render","_ctx","_cache","$props","$setup","$data","$options","_component_font_awesome_icon","_component_el_button","innerHTML","backgroundImagesTemplate","onClick","goHome","circle","size","default","icon","_","src","errorImage","alt","type","goBack","href","args","goDashboard","refreshPage","name","mixins","backgroundManager","computed","mounted","this","initializeBackground","beforeUnmount","clearBackgroundInterval","methods","$router","push","window","history","length","go","location","reload","__exports__","data","bingWallPaperIndex","customWallPaperIndex","backgroundInterval","backgroundInitParams","mapGetters","bkInterval","userConfig","bkOpacity","backgroundImagesStyles","watch","useDarkMode","newVal","oldVal","$nextTick","smoothThemeTransition","configKey","containerSelector","useDefaultBackground","autoCreateElements","injectBackgroundStyles","clearInterval","clearBackgroundImages","removeBackgroundStyles","styleId","document","getElementById","style","createElement","id","textContent","head","appendChild","existingStyle","remove","createBackgroundElements","container","console","warn","bg1","className","bg2","insertBefore","firstChild","querySelector","backgroundConfig","setupBingWallpaper","Array","isArray","setupCustomWallpaperCarousel","setupSingleCustomWallpaper","setupDefaultWallpaper","$store","dispatch","then","bingWallPapers","loadBackgroundImage","url","setInterval","switchBingWallpaper","wallpapers","switchCustomWallpaper","wallpaperUrl","isDark","defaultImage","require","imgElement","imageSrc","onload","opacity","background","curBg","nextBg","immediate","transition","setTimeout","undefined","reinitializeBackground","currentBg","newThemeImage","preloadImg","Image","onerror"],"ignoreList":[],"sourceRoot":""} \ No newline at end of file +{"version":3,"file":"js/226.f737e39a.js","mappings":"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","sources":["webpack://sanyue_imghub/./src/views/NotFound.vue?1f11","webpack://sanyue_imghub/./src/views/NotFound.vue","webpack://sanyue_imghub/./src/views/NotFound.vue?5f0d","webpack://sanyue_imghub/./src/mixins/backgroundManager.js"],"sourcesContent":["import { createElementVNode as _createElementVNode, resolveComponent as _resolveComponent, createVNode as _createVNode, withCtx as _withCtx, createTextVNode as _createTextVNode, createStaticVNode as _createStaticVNode, openBlock as _openBlock, createElementBlock as _createElementBlock } from \"vue\";\nconst _hoisted_1 = {\n class: \"not-found-container\"\n};\nconst _hoisted_2 = [\"innerHTML\"];\nconst _hoisted_3 = {\n class: \"not-found-content\"\n};\nconst _hoisted_4 = {\n class: \"back-button-wrapper\"\n};\nconst _hoisted_5 = {\n class: \"error-animation\"\n};\nconst _hoisted_6 = {\n class: \"error-image\"\n};\nconst _hoisted_7 = [\"src\"];\nconst _hoisted_8 = {\n class: \"error-info\"\n};\nconst _hoisted_9 = {\n class: \"error-actions\"\n};\nconst _hoisted_10 = {\n class: \"help-links\"\n};\nconst _hoisted_11 = {\n class: \"quick-links\"\n};\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n const _component_el_button = _resolveComponent(\"el-button\");\n return _openBlock(), _createElementBlock(\"div\", _hoisted_1, [_createElementVNode(\"div\", {\n class: \"background-wrapper\",\n innerHTML: _ctx.backgroundImagesTemplate\n }, null, 8, _hoisted_2), _createElementVNode(\"div\", _hoisted_3, [_createElementVNode(\"div\", _hoisted_4, [_createVNode(_component_el_button, {\n class: \"back-button\",\n onClick: $options.goHome,\n circle: \"\",\n size: \"large\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"home\"\n })]),\n _: 1\n }, 8, [\"onClick\"])]), _createElementVNode(\"div\", _hoisted_5, [_cache[3] || (_cache[3] = _createElementVNode(\"div\", {\n class: \"error-number\"\n }, [_createElementVNode(\"span\", {\n class: \"four\"\n }, \"4\"), _createElementVNode(\"span\", {\n class: \"zero\"\n }, \"0\"), _createElementVNode(\"span\", {\n class: \"four\"\n }, \"4\")], -1)), _createElementVNode(\"div\", _hoisted_6, [_createElementVNode(\"img\", {\n src: $options.errorImage,\n alt: \"404\",\n class: \"floating-image\"\n }, null, 8, _hoisted_7)])]), _createElementVNode(\"div\", _hoisted_8, [_cache[10] || (_cache[10] = _createElementVNode(\"h1\", {\n class: \"error-title\"\n }, \"页面走丢了\", -1)), _cache[11] || (_cache[11] = _createElementVNode(\"p\", {\n class: \"error-description\"\n }, \" 抱歉,您访问的页面可能已被删除、更名或暂时不可用 \", -1)), _createElementVNode(\"div\", _hoisted_9, [_createVNode(_component_el_button, {\n type: \"primary\",\n size: \"large\",\n class: \"action-btn primary-btn\",\n onClick: $options.goHome\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"home\",\n class: \"btn-icon\"\n }), _cache[4] || (_cache[4] = _createTextVNode(\" 返回首页 \", -1))]),\n _: 1\n }, 8, [\"onClick\"]), _createVNode(_component_el_button, {\n size: \"large\",\n class: \"action-btn secondary-btn\",\n onClick: $options.goBack\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"arrow-left\",\n class: \"btn-icon\"\n }), _cache[5] || (_cache[5] = _createTextVNode(\" 返回上页 \", -1))]),\n _: 1\n }, 8, [\"onClick\"])]), _createElementVNode(\"div\", _hoisted_10, [_cache[9] || (_cache[9] = _createElementVNode(\"p\", {\n class: \"help-text\"\n }, \"也许您想要:\", -1)), _createElementVNode(\"div\", _hoisted_11, [_createElementVNode(\"a\", {\n href: \"javascript:void(0)\",\n onClick: _cache[0] || (_cache[0] = (...args) => $options.goHome && $options.goHome(...args)),\n class: \"quick-link\"\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"cloud-upload-alt\"\n }), _cache[6] || (_cache[6] = _createTextVNode(\" 图片上传 \", -1))]), _createElementVNode(\"a\", {\n href: \"javascript:void(0)\",\n onClick: _cache[1] || (_cache[1] = (...args) => $options.goDashboard && $options.goDashboard(...args)),\n class: \"quick-link\"\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"tachometer-alt\"\n }), _cache[7] || (_cache[7] = _createTextVNode(\" 管理面板 \", -1))]), _createElementVNode(\"a\", {\n href: \"javascript:void(0)\",\n onClick: _cache[2] || (_cache[2] = (...args) => $options.refreshPage && $options.refreshPage(...args)),\n class: \"quick-link\"\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"redo\"\n }), _cache[8] || (_cache[8] = _createTextVNode(\" 刷新页面 \", -1))])])])])]), _cache[12] || (_cache[12] = _createStaticVNode(\"
\", 1))]);\n}","import \"core-js/modules/es.array.push.js\";\nimport { mapGetters } from 'vuex';\nimport backgroundManager from '@/mixins/backgroundManager';\nexport default {\n name: 'NotFound',\n mixins: [backgroundManager],\n computed: {\n ...mapGetters(['useDarkMode', 'userConfig']),\n errorImage() {\n // 使用项目中已有的404图片\n return require('@/assets/404.png');\n }\n },\n mounted() {\n // 初始化背景图\n this.initializeBackground('uploadBkImg', '.not-found-container', false, true);\n },\n beforeUnmount() {\n // 清理背景轮播定时器\n this.clearBackgroundInterval();\n },\n methods: {\n goHome() {\n this.$router.push('/');\n },\n goBack() {\n if (window.history.length > 1) {\n this.$router.go(-1);\n } else {\n this.$router.push('/');\n }\n },\n goDashboard() {\n this.$router.push('/dashboard');\n },\n refreshPage() {\n window.location.reload();\n }\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./NotFound.vue?vue&type=template&id=5437e264&scoped=true\"\nimport script from \"./NotFound.vue?vue&type=script&lang=js\"\nexport * from \"./NotFound.vue?vue&type=script&lang=js\"\n\nimport \"./NotFound.vue?vue&type=style&index=0&id=5437e264&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-5437e264\"]])\n\nexport default __exports__","/**\r\n * 背景图管理 Mixin\r\n * 用于统一管理页面背景图的加载和轮播逻辑\r\n */\r\n\r\nimport { mapGetters } from 'vuex'\r\n\r\nexport default {\r\n data() {\r\n return {\r\n bingWallPaperIndex: 0,\r\n customWallPaperIndex: 0,\r\n backgroundInterval: null, // 存储轮播定时器\r\n // 存储初始化参数,用于主题切换时重新初始化\r\n backgroundInitParams: null,\r\n }\r\n },\r\n computed: {\r\n ...mapGetters(['userConfig', 'bingWallPapers', 'useDarkMode']),\r\n bkInterval() {\r\n return this.userConfig?.bkInterval || 3000\r\n },\r\n bkOpacity() {\r\n return this.userConfig?.bkOpacity || 1\r\n },\r\n // 提供背景图片元素的模板\r\n backgroundImagesTemplate() {\r\n return `\r\n \"Background\r\n \"Background\r\n `\r\n },\r\n // 提供背景图片的CSS样式\r\n backgroundImagesStyles() {\r\n return `\r\n .background-image1 {\r\n position: fixed;\r\n top: 0;\r\n left: 0;\r\n width: 100%;\r\n height: 100%;\r\n object-fit: cover;\r\n z-index: -1;\r\n opacity: 0;\r\n transition: opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1), filter 0.3s ease;\r\n filter: var(--background-image-filter, brightness(1));\r\n }\r\n .background-image2 {\r\n position: fixed;\r\n top: 0;\r\n left: 0;\r\n width: 100%;\r\n height: 100%;\r\n object-fit: cover;\r\n z-index: -1;\r\n opacity: 0;\r\n transition: opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1), filter 0.3s ease;\r\n filter: var(--background-image-filter, brightness(1));\r\n }\r\n `\r\n }\r\n },\r\n\r\n watch: {\r\n // 监听深色模式切换\r\n useDarkMode(newVal, oldVal) {\r\n // 只有在值真正改变且已经初始化过背景时才平滑切换主题\r\n if (newVal !== oldVal && this.backgroundInitParams) {\r\n this.$nextTick(() => {\r\n this.smoothThemeTransition(\r\n this.backgroundInitParams.configKey,\r\n this.backgroundInitParams.containerSelector,\r\n this.backgroundInitParams.useDefaultBackground,\r\n this.backgroundInitParams.autoCreateElements\r\n )\r\n })\r\n }\r\n }\r\n },\r\n\r\n mounted() {\r\n // 动态注入背景图片的CSS样式\r\n this.injectBackgroundStyles()\r\n },\r\n\r\n beforeUnmount() {\r\n // 组件销毁前清除定时器\r\n if (this.backgroundInterval) {\r\n clearInterval(this.backgroundInterval)\r\n }\r\n // 立即清除背景图片,不使用过渡效果\r\n this.clearBackgroundImages(true)\r\n // 移除动态注入的样式\r\n this.removeBackgroundStyles()\r\n },\r\n\r\n methods: {\r\n /**\r\n * 动态注入背景图片样式\r\n */\r\n injectBackgroundStyles() {\r\n const styleId = 'background-manager-styles'\r\n if (!document.getElementById(styleId)) {\r\n const style = document.createElement('style')\r\n style.id = styleId\r\n style.textContent = this.backgroundImagesStyles\r\n document.head.appendChild(style)\r\n }\r\n },\r\n\r\n /**\r\n * 移除动态注入的样式\r\n */\r\n removeBackgroundStyles() {\r\n const styleId = 'background-manager-styles'\r\n const existingStyle = document.getElementById(styleId)\r\n if (existingStyle) {\r\n existingStyle.remove()\r\n }\r\n },\r\n\r\n /**\r\n * 动态创建背景图片元素\r\n * @param {HTMLElement} container - 要插入背景图片的容器元素\r\n */\r\n createBackgroundElements(container) {\r\n if (!container) {\r\n console.warn('未提供有效的容器元素')\r\n return\r\n }\r\n\r\n // 检查是否已经存在背景图片元素\r\n if (document.getElementById('bg1') || document.getElementById('bg2')) {\r\n return\r\n }\r\n\r\n // 创建 bg1 元素\r\n const bg1 = document.createElement('img')\r\n bg1.id = 'bg1'\r\n bg1.className = 'background-image1'\r\n bg1.alt = 'Background Image'\r\n \r\n // 创建 bg2 元素\r\n const bg2 = document.createElement('img')\r\n bg2.id = 'bg2'\r\n bg2.className = 'background-image2'\r\n bg2.alt = 'Background Image'\r\n\r\n // 将元素插入到容器的开头\r\n container.insertBefore(bg1, container.firstChild)\r\n container.insertBefore(bg2, container.firstChild)\r\n },\r\n /**\r\n * 初始化背景图\r\n * @param {string} configKey - 用户配置中的背景图配置键名\r\n * @param {string} containerSelector - 容器选择器,用于设置透明背景\r\n * @param {boolean} useDefaultBackground - 是否使用默认背景图\r\n * @param {boolean} autoCreateElements - 是否自动创建背景元素\r\n */\r\n initializeBackground(configKey, containerSelector = '.login', useDefaultBackground = false, autoCreateElements = false) {\r\n // 保存初始化参数,用于主题切换时重新初始化\r\n this.backgroundInitParams = {\r\n configKey,\r\n containerSelector,\r\n useDefaultBackground,\r\n autoCreateElements\r\n }\r\n\r\n // 如果需要自动创建元素且元素不存在,则创建\r\n if (autoCreateElements) {\r\n const container = document.querySelector(containerSelector)\r\n if (container && (!document.getElementById('bg1') || !document.getElementById('bg2'))) {\r\n this.createBackgroundElements(container)\r\n }\r\n }\r\n\r\n const bg1 = document.getElementById('bg1')\r\n const bg2 = document.getElementById('bg2')\r\n \r\n if (!bg1 || !bg2) {\r\n console.warn('背景图元素 #bg1 或 #bg2 未找到,请确保页面中包含这些元素或启用 autoCreateElements')\r\n return\r\n }\r\n\r\n const backgroundConfig = this.userConfig?.[configKey]\r\n\r\n if (backgroundConfig === 'bing') {\r\n this.setupBingWallpaper(bg1, bg2, containerSelector)\r\n } else if (Array.isArray(backgroundConfig) && backgroundConfig.length > 1) {\r\n this.setupCustomWallpaperCarousel(bg1, bg2, backgroundConfig, containerSelector)\r\n } else if (Array.isArray(backgroundConfig) && backgroundConfig.length === 1) {\r\n this.setupSingleCustomWallpaper(bg1, backgroundConfig[0], containerSelector)\r\n } else if (useDefaultBackground) {\r\n this.setupDefaultWallpaper(bg1, containerSelector)\r\n }\r\n },\r\n\r\n /**\r\n * 设置 Bing 壁纸轮播\r\n */\r\n setupBingWallpaper(bg1, bg2, containerSelector) {\r\n this.$store.dispatch('fetchBingWallPapers').then(() => {\r\n if (this.bingWallPapers.length === 0) return\r\n\r\n this.loadBackgroundImage(bg1, this.bingWallPapers[this.bingWallPaperIndex]?.url, containerSelector)\r\n \r\n this.backgroundInterval = setInterval(() => {\r\n this.switchBingWallpaper(bg1, bg2)\r\n }, this.bkInterval)\r\n })\r\n },\r\n\r\n /**\r\n * 设置自定义壁纸轮播\r\n */\r\n setupCustomWallpaperCarousel(bg1, bg2, wallpapers, containerSelector) {\r\n this.loadBackgroundImage(bg1, wallpapers[this.customWallPaperIndex], containerSelector)\r\n \r\n this.backgroundInterval = setInterval(() => {\r\n this.switchCustomWallpaper(bg1, bg2, wallpapers)\r\n }, this.bkInterval)\r\n },\r\n\r\n /**\r\n * 设置单张自定义壁纸\r\n */\r\n setupSingleCustomWallpaper(bg1, wallpaperUrl, containerSelector) {\r\n this.loadBackgroundImage(bg1, wallpaperUrl, containerSelector)\r\n },\r\n\r\n /**\r\n * 设置默认壁纸\r\n */\r\n setupDefaultWallpaper(bg1, containerSelector) {\r\n // 根据当前深色模式状态选择背景图\r\n const isDark = this.useDarkMode\r\n const defaultImage = isDark \r\n ? require('@/assets/background.jpg') \r\n : require('@/assets/background-light.jpg')\r\n \r\n this.loadBackgroundImage(bg1, defaultImage, containerSelector)\r\n },\r\n\r\n /**\r\n * 加载背景图片\r\n */\r\n loadBackgroundImage(imgElement, imageSrc, containerSelector) {\r\n imgElement.src = imageSrc\r\n imgElement.onload = () => {\r\n imgElement.style.opacity = this.bkOpacity\r\n // 设置容器背景为透明\r\n const container = document.querySelector(containerSelector)\r\n if (container) {\r\n container.style.background = 'transparent'\r\n }\r\n }\r\n },\r\n\r\n /**\r\n * 切换 Bing 壁纸\r\n */\r\n switchBingWallpaper(bg1, bg2) {\r\n if (this.bingWallPapers.length === 0) return\r\n\r\n const curBg = bg1.style.opacity != 0 ? bg1 : bg2\r\n const nextBg = bg1.style.opacity != 0 ? bg2 : bg1\r\n \r\n curBg.style.opacity = 0\r\n this.bingWallPaperIndex = (this.bingWallPaperIndex + 1) % this.bingWallPapers.length\r\n \r\n nextBg.src = this.bingWallPapers[this.bingWallPaperIndex]?.url\r\n nextBg.onload = () => {\r\n nextBg.style.opacity = this.bkOpacity\r\n }\r\n },\r\n\r\n /**\r\n * 切换自定义壁纸\r\n */\r\n switchCustomWallpaper(bg1, bg2, wallpapers) {\r\n const curBg = bg1.style.opacity != 0 ? bg1 : bg2\r\n const nextBg = bg1.style.opacity != 0 ? bg2 : bg1\r\n \r\n curBg.style.opacity = 0\r\n this.customWallPaperIndex = (this.customWallPaperIndex + 1) % wallpapers.length\r\n \r\n nextBg.src = wallpapers[this.customWallPaperIndex]\r\n nextBg.onload = () => {\r\n nextBg.style.opacity = this.bkOpacity\r\n }\r\n },\r\n\r\n /**\r\n * 清除背景轮播定时器\r\n */\r\n clearBackgroundInterval() {\r\n if (this.backgroundInterval) {\r\n clearInterval(this.backgroundInterval)\r\n this.backgroundInterval = null\r\n }\r\n },\r\n\r\n /**\r\n * 清除背景图片显示(带过渡效果)\r\n * @param {boolean} immediate - 是否立即清除,不使用过渡效果\r\n */\r\n clearBackgroundImages(immediate = false) {\r\n const bg1 = document.getElementById('bg1')\r\n const bg2 = document.getElementById('bg2')\r\n \r\n if (immediate) {\r\n // 立即清除,不使用过渡效果\r\n if (bg1) {\r\n bg1.style.transition = 'none'\r\n bg1.style.opacity = 0\r\n bg1.src = ''\r\n // 恢复过渡效果\r\n setTimeout(() => {\r\n if (bg1) bg1.style.transition = 'opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1)'\r\n }, 50)\r\n }\r\n if (bg2) {\r\n bg2.style.transition = 'none'\r\n bg2.style.opacity = 0\r\n bg2.src = ''\r\n // 恢复过渡效果\r\n setTimeout(() => {\r\n if (bg2) bg2.style.transition = 'opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1)'\r\n }, 50)\r\n }\r\n } else {\r\n // 使用过渡效果淡出\r\n if (bg1) {\r\n bg1.style.opacity = 0\r\n setTimeout(() => {\r\n if (bg1) bg1.src = ''\r\n }, 800) // 等待过渡完成后清除src\r\n }\r\n if (bg2) {\r\n bg2.style.opacity = 0\r\n setTimeout(() => {\r\n if (bg2) bg2.src = ''\r\n }, 800) // 等待过渡完成后清除src\r\n }\r\n }\r\n },\r\n\r\n /**\r\n * 平滑主题切换(用于响应主题模式变化)\r\n * @param {string} configKey - 用户配置中的背景图配置键名\r\n * @param {string} containerSelector - 容器选择器\r\n * @param {boolean} useDefaultBackground - 是否使用默认背景图\r\n * @param {boolean} autoCreateElements - 是否自动创建背景元素\r\n */\r\n smoothThemeTransition(configKey, containerSelector = '.login', useDefaultBackground = false, autoCreateElements = false) {\r\n const backgroundConfig = this.userConfig?.[configKey]\r\n \r\n // 如果不是默认背景配置,则直接重新初始化(自定义背景不受主题影响)\r\n if (!useDefaultBackground || backgroundConfig !== undefined) {\r\n this.reinitializeBackground(configKey, containerSelector, useDefaultBackground, autoCreateElements)\r\n return\r\n }\r\n\r\n // 对于默认背景,执行平滑过渡\r\n const bg1 = document.getElementById('bg1')\r\n const bg2 = document.getElementById('bg2')\r\n \r\n if (!bg1 || !bg2) {\r\n // 如果背景元素不存在,直接重新初始化\r\n this.reinitializeBackground(configKey, containerSelector, useDefaultBackground, autoCreateElements)\r\n return\r\n }\r\n\r\n // 确定当前显示的背景和下一个背景\r\n const currentBg = bg1.style.opacity != 0 ? bg1 : bg2\r\n const nextBg = bg1.style.opacity != 0 ? bg2 : bg1\r\n\r\n // 获取新主题对应的背景图\r\n const isDark = this.useDarkMode\r\n const newThemeImage = isDark \r\n ? require('@/assets/background.jpg') \r\n : require('@/assets/background-light.jpg')\r\n\r\n // 预加载新背景图\r\n const preloadImg = new Image()\r\n preloadImg.onload = () => {\r\n // 设置下一个背景的图片源\r\n nextBg.src = newThemeImage\r\n \r\n // 等待图片加载完成后执行淡入淡出过渡\r\n nextBg.onload = () => {\r\n // 淡出当前背景\r\n currentBg.style.opacity = 0\r\n \r\n // 稍微延迟后淡入新背景,确保过渡效果平滑\r\n setTimeout(() => {\r\n nextBg.style.opacity = this.bkOpacity\r\n \r\n // 设置容器背景为透明\r\n const container = document.querySelector(containerSelector)\r\n if (container) {\r\n container.style.background = 'transparent'\r\n }\r\n }, 50) // 50ms 延迟,让淡出效果先开始\r\n }\r\n }\r\n \r\n preloadImg.onerror = () => {\r\n // 如果预加载失败,回退到直接重新初始化\r\n console.warn('主题背景图预加载失败,回退到直接切换')\r\n this.reinitializeBackground(configKey, containerSelector, useDefaultBackground, autoCreateElements)\r\n }\r\n \r\n preloadImg.src = newThemeImage\r\n },\r\n\r\n /**\r\n * 重新初始化背景图(用于响应配置变化)\r\n */\r\n reinitializeBackground(configKey, containerSelector = '.login', useDefaultBackground = false, autoCreateElements = false) {\r\n this.clearBackgroundInterval()\r\n this.clearBackgroundImages(true) // 使用立即清除\r\n this.bingWallPaperIndex = 0\r\n this.customWallPaperIndex = 0\r\n \r\n // 延迟一小段时间确保清理完成\r\n setTimeout(() => {\r\n this.initializeBackground(configKey, containerSelector, useDefaultBackground, autoCreateElements)\r\n }, 100)\r\n }\r\n }\r\n}\r\n"],"names":["_hoisted_1","class","_hoisted_2","_hoisted_3","_hoisted_4","_hoisted_5","_hoisted_6","_hoisted_7","_hoisted_8","_hoisted_9","_hoisted_10","_hoisted_11","render","_ctx","_cache","$props","$setup","$data","$options","_component_font_awesome_icon","_component_el_button","innerHTML","backgroundImagesTemplate","onClick","goHome","circle","size","default","icon","_","src","errorImage","alt","type","goBack","href","args","goDashboard","refreshPage","name","mixins","backgroundManager","computed","mounted","this","initializeBackground","beforeUnmount","clearBackgroundInterval","methods","$router","push","window","history","length","go","location","reload","__exports__","data","bingWallPaperIndex","customWallPaperIndex","backgroundInterval","backgroundInitParams","mapGetters","bkInterval","userConfig","bkOpacity","backgroundImagesStyles","watch","useDarkMode","newVal","oldVal","$nextTick","smoothThemeTransition","configKey","containerSelector","useDefaultBackground","autoCreateElements","injectBackgroundStyles","clearInterval","clearBackgroundImages","removeBackgroundStyles","styleId","document","getElementById","style","createElement","id","textContent","head","appendChild","existingStyle","remove","createBackgroundElements","container","console","warn","bg1","className","bg2","insertBefore","firstChild","querySelector","backgroundConfig","setupBingWallpaper","Array","isArray","setupCustomWallpaperCarousel","setupSingleCustomWallpaper","setupDefaultWallpaper","$store","dispatch","then","bingWallPapers","loadBackgroundImage","url","setInterval","switchBingWallpaper","wallpapers","switchCustomWallpaper","wallpaperUrl","isDark","defaultImage","require","imgElement","imageSrc","onload","opacity","background","curBg","nextBg","immediate","transition","setTimeout","undefined","reinitializeBackground","currentBg","newThemeImage","preloadImg","Image","onerror"],"ignoreList":[],"sourceRoot":""} \ No newline at end of file diff --git a/js/226.f737e39a.js.map.gz b/js/226.f737e39a.js.map.gz new file mode 100644 index 0000000..322b5b7 Binary files /dev/null and b/js/226.f737e39a.js.map.gz differ diff --git a/js/226.478c43ad.js b/js/407.f0b5dee5.js similarity index 85% rename from js/226.478c43ad.js rename to js/407.f0b5dee5.js index dd0afec..93b6bcc 100644 --- a/js/226.478c43ad.js +++ b/js/407.f0b5dee5.js @@ -1,4 +1,4 @@ -"use strict";(self["webpackChunksanyue_imghub"]=self["webpackChunksanyue_imghub"]||[]).push([[226],{333:function(t,e,i){i(5331),i(6711)},415:function(t,e,i){i(5331),i(3565)},694:function(t,e,i){i(5331)},1114:function(t,e,i){function s(t){return s="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},s(t)}function n(t,e){if("object"!=s(t)||!t)return t;var i=t[Symbol.toPrimitive];if(void 0!==i){var n=i.call(t,e||"default");if("object"!=s(n))return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===e?String:Number)(t)}function a(t){var e=n(t,"string");return"symbol"==s(e)?e:e+""}function o(t,e,i){return(e=a(e))in t?Object.defineProperty(t,e,{value:i,enumerable:!0,configurable:!0,writable:!0}):t[e]=i,t}i.d(e,{A:function(){return o}})},2893:function(t,e,i){i(5331)},3565:function(t,e,i){i(5331)},4752:function(t,e,i){i(5331),i(8736),i(8785)},5226:function(t,e,i){i.r(e),i.d(e,{default:function(){return Yu}});var s=i(6768),n=i(4232);const a={class:"menu-list"},o=["onClick"],r={class:"menu-text"};function l(t,e,i,l,h,c){const d=(0,s.g2)("font-awesome-icon");return(0,s.uX)(),(0,s.CE)("div",{class:(0,n.C4)(["sidebar-container",{"is-collapsed":i.isCollapse}])},[(0,s.Lk)("div",a,[((0,s.uX)(!0),(0,s.CE)(s.FK,null,(0,s.pI)(h.menuItems,t=>((0,s.uX)(),(0,s.CE)("div",{key:t.index,class:(0,n.C4)(["menu-item",{"is-active":i.activeIndex===t.index}]),onClick:e=>c.handleSelect(t.index)},[(0,s.bF)(d,{icon:t.icon,class:"menu-icon"},null,8,["icon"]),(0,s.Lk)("span",r,(0,n.v_)(t.title),1)],10,o))),128))]),(0,s.Lk)("div",{class:"toggle-button",onClick:e[0]||(e[0]=(...t)=>c.toggleCollapse&&c.toggleCollapse(...t))},[(0,s.bF)(d,{icon:i.isCollapse?"angle-double-right":"angle-double-left"},null,8,["icon"])])],2)}var h={name:"SysConfigTabs",props:{activeIndex:{type:String,default:"status"},isCollapse:{type:Boolean,default:!1}},data(){return{menuItems:[{index:"status",icon:"chart-bar",title:"系统状态"},{index:"upload",icon:"cloud-upload",title:"上传设置"},{index:"security",icon:"shield",title:"安全设置"},{index:"page",icon:"pager",title:"网页设置"},{index:"others",icon:"cog",title:"其他设置"}]}},methods:{toggleCollapse(){this.$emit("update:isCollapse",!this.isCollapse)},checkMobile(){const t=window.innerWidth<=768;this.$emit("update:isCollapse",t)},handleSelect(t){this.$emit("update:activeIndex",t)}},mounted(){this.checkMobile(),window.addEventListener("resize",this.checkMobile)},beforeDestroy(){window.removeEventListener("resize",this.checkMobile)}},c=i(1241);const d=(0,c.A)(h,[["render",l],["__scopeId","data-v-5bb00686"]]);var u=d,g=i(4880),p=(i(5331),i(7128),i(8507)),f=(i(213),i(6011));const m={class:"container"},b={class:"header-content"},x={class:"header-action"};function y(t,e,i,a,o,r){const l=f.A,h=(0,s.g2)("font-awesome-icon"),c=p.R7,d=g.bZ,y=u;return(0,s.uX)(),(0,s.CE)("div",m,[(0,s.bF)(d,null,{default:(0,s.k6)(()=>[(0,s.Lk)("div",b,[(0,s.bF)(l,{activeTab:"systemConfig"}),(0,s.Lk)("div",x,[(0,s.bF)(c,{disabled:r.disableTooltip,content:"退出登录",placement:"bottom"},{default:(0,s.k6)(()=>[(0,s.bF)(h,{icon:"sign-out-alt",class:"header-icon",onClick:r.handleLogout},null,8,["onClick"])]),_:1},8,["disabled"])])])]),_:1}),(0,s.bF)(y,{activeIndex:o.activeIndex,"onUpdate:activeIndex":e[0]||(e[0]=t=>o.activeIndex=t),isCollapse:o.isSidebarCollapse,"onUpdate:isCollapse":e[1]||(e[1]=t=>o.isSidebarCollapse=t)},null,8,["activeIndex","isCollapse"]),((0,s.uX)(),(0,s.Wv)((0,s.$y)(r.currentComponent),{class:(0,n.C4)(["main-container",{collapsed:o.isSidebarCollapse}])},null,8,["class"]))])}i(4114);var _=i(9114),v=(i(694),i(7009)),k=(i(8450),i(47)),w=(i(9648),i(9655));i(2893);const C={class:"status-panel"},S={class:"overview-cards"},F={class:"card-icon"},M={class:"card-content"},A={class:"card-value"},T={class:"overview-card index-status"},P={class:"card-icon"},D={class:"card-content"},E={class:"card-value"},L={class:"card-subtitle"},I={class:"card-icon"},V={class:"card-content"},O={class:"card-value"},R={class:"charts-section"},W={class:"chart-card"},B={class:"chart-header"},z={class:"chart-content"},N={key:0,class:"empty-state"},U={key:1,class:"pie-chart-container"},$={class:"pie-chart-wrapper"},j={class:"chart-center-text"},H={class:"center-value"},X={class:"chart-legend"},q={class:"legend-label"},K={class:"legend-value"},Y={class:"legend-percent"},Q={class:"chart-card"},G={class:"chart-header"},J={class:"chart-content"},Z={key:0,class:"empty-state"},tt={key:1,class:"pie-chart-container"},et={class:"pie-chart-wrapper"},it={class:"chart-center-text"},st={class:"center-value"},nt={class:"chart-legend"},at={class:"legend-label"},ot={class:"legend-value"},rt={class:"legend-percent"},lt={class:"actions-section"},ht={class:"action-card"},ct={class:"action-header"},dt={class:"action-content"},ut={key:0,class:"progress-container"},gt={class:"progress-header"},pt={class:"progress-phase"},ft={class:"progress-percentage"},mt={class:"progress-details"},bt={key:0,class:"progress-count"},xt={key:1,class:"progress-time"},yt={key:0,class:"progress-message"},_t={key:1,class:"error-container"},vt={class:"error-icon"},kt={class:"error-content"},wt={class:"error-message"},Ct={key:0,class:"error-suggestion"},St={class:"error-actions"},Ft={key:2,class:"action-buttons"},Mt={class:"restore-section"},At={key:0,class:"file-info-section"},Tt=["src"],Pt={key:2,class:"card-bg-fallback"},Dt={class:"file-card-header"},Et={class:"info-card-footer"},Lt={class:"file-name"},It={class:"file-meta"},Vt=["src"],Ot={key:2,class:"card-bg-fallback"},Rt={class:"file-card-header warning"},Wt={class:"info-card-footer"},Bt={class:"file-name"},zt={class:"file-meta"};function Nt(t,e,i,a,o,r){const l=(0,s.g2)("font-awesome-icon"),h=(0,s.g2)("Doughnut"),c=w.ve,d=k.S2,u=p.R7,g=v.Zq,f=_.A;return(0,s.bo)(((0,s.uX)(),(0,s.CE)("div",C,[(0,s.Lk)("div",S,[(0,s.Lk)("div",{class:"overview-card total-files",onClick:e[0]||(e[0]=(...t)=>r.fetchIndexInfo&&r.fetchIndexInfo(...t))},[(0,s.Lk)("div",F,[(0,s.bF)(l,{icon:"database"})]),(0,s.Lk)("div",M,[e[9]||(e[9]=(0,s.Lk)("div",{class:"card-title"},"文件总数",-1)),(0,s.Lk)("div",A,(0,n.v_)(o.indexInfo.totalFiles?.toLocaleString()||"0"),1),e[10]||(e[10]=(0,s.Lk)("div",{class:"card-subtitle"},"点击刷新",-1))])]),(0,s.Lk)("div",T,[(0,s.Lk)("div",P,[(0,s.bF)(l,{icon:"clock"})]),(0,s.Lk)("div",D,[e[11]||(e[11]=(0,s.Lk)("div",{class:"card-title"},"索引更新时间",-1)),(0,s.Lk)("div",E,(0,n.v_)(r.formatTime(o.indexInfo.lastUpdated)),1),(0,s.Lk)("div",L,(0,n.v_)(r.getTimeAgo(o.indexInfo.lastUpdated)),1)])]),(0,s.Lk)("div",{class:"overview-card system-version",onClick:e[1]||(e[1]=(...t)=>r.openReleases&&r.openReleases(...t))},[(0,s.Lk)("div",I,[(0,s.bF)(l,{icon:"code-branch"})]),(0,s.Lk)("div",V,[e[12]||(e[12]=(0,s.Lk)("div",{class:"card-title"},"系统版本",-1)),(0,s.Lk)("div",O,"v"+(0,n.v_)(o.version),1),e[13]||(e[13]=(0,s.Lk)("div",{class:"card-subtitle"},"点击查看更新日志",-1))])])]),(0,s.Lk)("div",R,[(0,s.Lk)("div",W,[(0,s.Lk)("div",B,[(0,s.bF)(l,{icon:"share-alt"}),e[14]||(e[14]=(0,s.Lk)("span",null,"上传渠道分布",-1))]),(0,s.Lk)("div",z,[0===Object.keys(o.indexInfo.channelStats||{}).length?((0,s.uX)(),(0,s.CE)("div",N,[(0,s.bF)(l,{icon:"inbox"}),e[15]||(e[15]=(0,s.Lk)("span",null,"暂无数据",-1))])):((0,s.uX)(),(0,s.CE)("div",U,[(0,s.Lk)("div",$,[(0,s.bF)(h,{data:r.channelChartData,options:r.chartOptions},null,8,["data","options"]),(0,s.Lk)("div",j,[(0,s.Lk)("div",H,(0,n.v_)(o.indexInfo.totalFiles?.toLocaleString()||"0"),1),e[16]||(e[16]=(0,s.Lk)("div",{class:"center-label"},"文件总数",-1))])]),(0,s.Lk)("div",X,[((0,s.uX)(!0),(0,s.CE)(s.FK,null,(0,s.pI)(o.indexInfo.channelStats,(t,e,i)=>((0,s.uX)(),(0,s.CE)("div",{key:e,class:"legend-item"},[(0,s.Lk)("span",{class:"legend-color",style:(0,n.Tr)({background:r.getChartColor(i)})},null,4),(0,s.Lk)("span",q,(0,n.v_)(e),1),(0,s.Lk)("span",K,(0,n.v_)(t.toLocaleString()),1),(0,s.Lk)("span",Y,(0,n.v_)(r.getPercentage(t,o.indexInfo.totalFiles))+"%",1)]))),128))])]))])]),(0,s.Lk)("div",Q,[(0,s.Lk)("div",G,[(0,s.bF)(l,{icon:"file-alt"}),e[17]||(e[17]=(0,s.Lk)("span",null,"文件状态分布",-1))]),(0,s.Lk)("div",J,[0===Object.keys(o.indexInfo.typeStats||{}).length?((0,s.uX)(),(0,s.CE)("div",Z,[(0,s.bF)(l,{icon:"inbox"}),e[18]||(e[18]=(0,s.Lk)("span",null,"暂无数据",-1))])):((0,s.uX)(),(0,s.CE)("div",tt,[(0,s.Lk)("div",et,[(0,s.bF)(h,{data:r.typeChartData,options:r.chartOptions},null,8,["data","options"]),(0,s.Lk)("div",it,[(0,s.Lk)("div",st,(0,n.v_)(Object.keys(o.indexInfo.typeStats).length),1),e[19]||(e[19]=(0,s.Lk)("div",{class:"center-label"},"状态类型",-1))])]),(0,s.Lk)("div",nt,[((0,s.uX)(!0),(0,s.CE)(s.FK,null,(0,s.pI)(r.aggregatedTypeStats,(t,e,i)=>((0,s.uX)(),(0,s.CE)("div",{key:e,class:"legend-item"},[(0,s.Lk)("span",{class:"legend-color",style:(0,n.Tr)({background:r.getTypeChartColor(i)})},null,4),(0,s.Lk)("span",at,(0,n.v_)(e),1),(0,s.Lk)("span",ot,(0,n.v_)(t.toLocaleString()),1),(0,s.Lk)("span",rt,(0,n.v_)(r.getPercentage(t,o.indexInfo.totalFiles))+"%",1)]))),128))])]))])])]),(0,s.Lk)("div",lt,[(0,s.Lk)("div",ht,[(0,s.Lk)("div",ct,[(0,s.bF)(l,{icon:"tools"}),e[20]||(e[20]=(0,s.Lk)("span",null,"系统维护",-1))]),(0,s.Lk)("div",dt,[o.isProcessing?((0,s.uX)(),(0,s.CE)("div",ut,[(0,s.Lk)("div",gt,[(0,s.Lk)("span",pt,(0,n.v_)(r.phaseDescription),1),(0,s.Lk)("span",ft,(0,n.v_)(Math.round(o.processingProgress.percentage))+"%",1)]),(0,s.bF)(c,{percentage:o.processingProgress.percentage,"stroke-width":12,"show-text":!1,class:"progress-bar"},null,8,["percentage"]),(0,s.Lk)("div",mt,[o.processingProgress.current>0?((0,s.uX)(),(0,s.CE)("span",bt,[(0,s.bF)(l,{icon:"file-alt"}),(0,s.eW)(" "+(0,n.v_)(o.processingProgress.current.toLocaleString())+" ",1),o.processingProgress.total>0?((0,s.uX)(),(0,s.CE)(s.FK,{key:0},[(0,s.eW)(" / "+(0,n.v_)(o.processingProgress.total.toLocaleString()),1)],64)):(0,s.Q3)("",!0),e[21]||(e[21]=(0,s.eW)(" 条记录 ",-1))])):(0,s.Q3)("",!0),r.estimatedTimeRemaining?((0,s.uX)(),(0,s.CE)("span",xt,[(0,s.bF)(l,{icon:"clock"}),(0,s.eW)(" "+(0,n.v_)(r.estimatedTimeRemaining),1)])):(0,s.Q3)("",!0)]),o.processingProgress.message?((0,s.uX)(),(0,s.CE)("div",yt,(0,n.v_)(o.processingProgress.message),1)):(0,s.Q3)("",!0),(0,s.bF)(d,{type:"danger",plain:"",size:"small",onClick:r.cancelOperation,class:"cancel-btn"},{default:(0,s.k6)(()=>[(0,s.bF)(l,{icon:"times"}),e[22]||(e[22]=(0,s.eW)(" 取消操作 ",-1))]),_:1},8,["onClick"])])):o.processingError?((0,s.uX)(),(0,s.CE)("div",_t,[(0,s.Lk)("div",vt,[(0,s.bF)(l,{icon:"exclamation-triangle"})]),(0,s.Lk)("div",kt,[(0,s.Lk)("div",wt,(0,n.v_)(o.processingError.message),1),o.processingError.suggestion?((0,s.uX)(),(0,s.CE)("div",Ct,(0,n.v_)(o.processingError.suggestion),1)):(0,s.Q3)("",!0)]),(0,s.Lk)("div",St,[o.processingError.recoverable?((0,s.uX)(),(0,s.Wv)(d,{key:0,type:"primary",size:"small",onClick:r.retryOperation},{default:(0,s.k6)(()=>[(0,s.bF)(l,{icon:"redo"}),e[23]||(e[23]=(0,s.eW)(" 重试 ",-1))]),_:1},8,["onClick"])):(0,s.Q3)("",!0),(0,s.bF)(d,{type:"default",size:"small",onClick:r.dismissError},{default:(0,s.k6)(()=>[...e[24]||(e[24]=[(0,s.eW)(" 关闭 ",-1)])]),_:1},8,["onClick"])])])):((0,s.uX)(),(0,s.CE)("div",Ft,[(0,s.bF)(u,{content:"重新扫描所有文件并更新索引数据,适用于数据不一致时的修复",placement:"top"},{default:(0,s.k6)(()=>[(0,s.bF)(d,{type:"primary",loading:o.rebuilding,disabled:o.isProcessing,onClick:r.rebuildIndex,class:"action-btn rebuild-btn"},{default:(0,s.k6)(()=>[(0,s.bF)(l,{icon:"sync-alt"}),(0,s.eW)(" "+(0,n.v_)(o.rebuilding?"重建中...":"重建索引"),1)]),_:1},8,["loading","disabled","onClick"])]),_:1}),(0,s.bF)(u,{content:"备份所有文件元数据和系统设置到JSON文件",placement:"top"},{default:(0,s.k6)(()=>[(0,s.bF)(d,{type:"success",loading:o.backing,disabled:o.isProcessing,onClick:r.backupData,class:"action-btn backup-btn"},{default:(0,s.k6)(()=>[(0,s.bF)(l,{icon:"download"}),(0,s.eW)(" "+(0,n.v_)(o.backing?"备份中...":"备份数据"),1)]),_:1},8,["loading","disabled","onClick"])]),_:1}),(0,s.bF)(u,{content:"从备份文件恢复数据,将覆盖现有的文件元数据和系统设置",placement:"top"},{default:(0,s.k6)(()=>[(0,s.Lk)("div",Mt,[(0,s.Lk)("input",{type:"file",ref:"fileInput",accept:".json",onChange:e[2]||(e[2]=(...t)=>r.handleFileSelect&&r.handleFileSelect(...t)),style:{display:"none"}},null,544),(0,s.bF)(d,{type:"warning",loading:o.restoring,disabled:o.isProcessing,onClick:r.selectRestoreFile,class:"action-btn restore-btn"},{default:(0,s.k6)(()=>[(0,s.bF)(l,{icon:"upload"}),(0,s.eW)(" "+(0,n.v_)(o.restoring?"恢复中...":"恢复数据"),1)]),_:1},8,["loading","disabled","onClick"])])]),_:1})]))])])]),o.indexInfo.newestFile||o.indexInfo.oldestFile?((0,s.uX)(),(0,s.CE)("div",At,[o.indexInfo.newestFile?((0,s.uX)(),(0,s.CE)("div",{key:0,class:"file-info-card info-card-newest",onClick:e[5]||(e[5]=t=>r.openFileInNewTab(o.indexInfo.newestFile))},[r.isImageFile(o.indexInfo.newestFile)&&!o.loadErrors["newest"]?((0,s.uX)(),(0,s.Wv)(g,{key:0,src:"/file/"+o.indexInfo.newestFile.id+"?from=admin",fit:"cover",class:"card-bg-media",onError:e[3]||(e[3]=t=>r.handleImageError("newest"))},null,8,["src"])):r.isVideoFile(o.indexInfo.newestFile)&&!o.loadErrors["newest"]?((0,s.uX)(),(0,s.CE)("video",{key:1,src:"/file/"+o.indexInfo.newestFile.id+"?from=admin",class:"card-bg-media",muted:"",loop:"",autoplay:"",onError:e[4]||(e[4]=t=>r.handleImageError("newest"))},null,40,Tt)):((0,s.uX)(),(0,s.CE)("div",Pt,[(0,s.bF)(l,{icon:"file-alt",class:"fallback-icon"})])),(0,s.Lk)("div",Dt,[(0,s.bF)(l,{icon:"arrow-up"}),e[25]||(e[25]=(0,s.Lk)("span",null,"最近上传",-1))]),(0,s.Lk)("div",Et,[(0,s.Lk)("div",Lt,(0,n.v_)(o.indexInfo.newestFile.metadata?.FileName||o.indexInfo.newestFile.id),1),(0,s.Lk)("div",It,(0,n.v_)(r.formatTime(o.indexInfo.newestFile.metadata?.TimeStamp)),1)])])):(0,s.Q3)("",!0),o.indexInfo.oldestFile?((0,s.uX)(),(0,s.CE)("div",{key:1,class:"file-info-card info-card-oldest",onClick:e[8]||(e[8]=t=>r.openFileInNewTab(o.indexInfo.oldestFile))},[r.isImageFile(o.indexInfo.oldestFile)&&!o.loadErrors["oldest"]?((0,s.uX)(),(0,s.Wv)(g,{key:0,src:"/file/"+o.indexInfo.oldestFile.id+"?from=admin",fit:"cover",class:"card-bg-media",onError:e[6]||(e[6]=t=>r.handleImageError("oldest"))},null,8,["src"])):r.isVideoFile(o.indexInfo.oldestFile)&&!o.loadErrors["oldest"]?((0,s.uX)(),(0,s.CE)("video",{key:1,src:"/file/"+o.indexInfo.oldestFile.id+"?from=admin",class:"card-bg-media",muted:"",loop:"",autoplay:"",onError:e[7]||(e[7]=t=>r.handleImageError("oldest"))},null,40,Vt)):((0,s.uX)(),(0,s.CE)("div",Ot,[(0,s.bF)(l,{icon:"file-alt",class:"fallback-icon"})])),(0,s.Lk)("div",Rt,[(0,s.bF)(l,{icon:"arrow-down"}),e[26]||(e[26]=(0,s.Lk)("span",null,"最早上传",-1))]),(0,s.Lk)("div",Wt,[(0,s.Lk)("div",Bt,(0,n.v_)(o.indexInfo.oldestFile.metadata?.FileName||o.indexInfo.oldestFile.id),1),(0,s.Lk)("div",zt,(0,n.v_)(r.formatTime(o.indexInfo.oldestFile.metadata?.TimeStamp)),1)])])):(0,s.Q3)("",!0)])):(0,s.Q3)("",!0)])),[[f,o.loading]])}i(8111),i(8237),i(8335);var Ut=i(797),$t={rE:"2.5.4"},jt=(i(116),i(1701),i(1114));i(2489),i(7588),i(3579),i(7642),i(8004),i(3853),i(5876),i(2475),i(5024),i(1698),i(3110); +"use strict";(self["webpackChunksanyue_imghub"]=self["webpackChunksanyue_imghub"]||[]).push([[407],{333:function(t,e,i){i(5331),i(6711)},415:function(t,e,i){i(5331),i(3565)},694:function(t,e,i){i(5331)},1114:function(t,e,i){function s(t){return s="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},s(t)}function n(t,e){if("object"!=s(t)||!t)return t;var i=t[Symbol.toPrimitive];if(void 0!==i){var n=i.call(t,e||"default");if("object"!=s(n))return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===e?String:Number)(t)}function a(t){var e=n(t,"string");return"symbol"==s(e)?e:e+""}function o(t,e,i){return(e=a(e))in t?Object.defineProperty(t,e,{value:i,enumerable:!0,configurable:!0,writable:!0}):t[e]=i,t}i.d(e,{A:function(){return o}})},2893:function(t,e,i){i(5331)},3565:function(t,e,i){i(5331)},4752:function(t,e,i){i(5331),i(8736),i(8785)},5616:function(t,e,i){i(5331),i(7197)},5802:function(t,e,i){i(5331),i(8736),i(213),i(5970)},6407:function(t,e,i){i.r(e),i.d(e,{default:function(){return Yu}});var s=i(6768),n=i(4232);const a={class:"menu-list"},o=["onClick"],r={class:"menu-text"};function l(t,e,i,l,h,c){const d=(0,s.g2)("font-awesome-icon");return(0,s.uX)(),(0,s.CE)("div",{class:(0,n.C4)(["sidebar-container",{"is-collapsed":i.isCollapse}])},[(0,s.Lk)("div",a,[((0,s.uX)(!0),(0,s.CE)(s.FK,null,(0,s.pI)(h.menuItems,t=>((0,s.uX)(),(0,s.CE)("div",{key:t.index,class:(0,n.C4)(["menu-item",{"is-active":i.activeIndex===t.index}]),onClick:e=>c.handleSelect(t.index)},[(0,s.bF)(d,{icon:t.icon,class:"menu-icon"},null,8,["icon"]),(0,s.Lk)("span",r,(0,n.v_)(t.title),1)],10,o))),128))]),(0,s.Lk)("div",{class:"toggle-button",onClick:e[0]||(e[0]=(...t)=>c.toggleCollapse&&c.toggleCollapse(...t))},[(0,s.bF)(d,{icon:i.isCollapse?"angle-double-right":"angle-double-left"},null,8,["icon"])])],2)}var h={name:"SysConfigTabs",props:{activeIndex:{type:String,default:"status"},isCollapse:{type:Boolean,default:!1}},data(){return{menuItems:[{index:"status",icon:"chart-bar",title:"系统状态"},{index:"upload",icon:"cloud-upload",title:"上传设置"},{index:"security",icon:"shield",title:"安全设置"},{index:"page",icon:"pager",title:"网页设置"},{index:"others",icon:"cog",title:"其他设置"}]}},methods:{toggleCollapse(){this.$emit("update:isCollapse",!this.isCollapse)},checkMobile(){const t=window.innerWidth<=768;this.$emit("update:isCollapse",t)},handleSelect(t){this.$emit("update:activeIndex",t)}},mounted(){this.checkMobile(),window.addEventListener("resize",this.checkMobile)},beforeDestroy(){window.removeEventListener("resize",this.checkMobile)}},c=i(1241);const d=(0,c.A)(h,[["render",l],["__scopeId","data-v-5bb00686"]]);var u=d,g=i(4880),p=(i(5331),i(7128),i(8507)),f=(i(213),i(6011));const m={class:"container"},b={class:"header-content"},x={class:"header-action"};function y(t,e,i,a,o,r){const l=f.A,h=(0,s.g2)("font-awesome-icon"),c=p.R7,d=g.bZ,y=u;return(0,s.uX)(),(0,s.CE)("div",m,[(0,s.bF)(d,null,{default:(0,s.k6)(()=>[(0,s.Lk)("div",b,[(0,s.bF)(l,{activeTab:"systemConfig"}),(0,s.Lk)("div",x,[(0,s.bF)(c,{disabled:r.disableTooltip,content:"退出登录",placement:"bottom"},{default:(0,s.k6)(()=>[(0,s.bF)(h,{icon:"sign-out-alt",class:"header-icon",onClick:r.handleLogout},null,8,["onClick"])]),_:1},8,["disabled"])])])]),_:1}),(0,s.bF)(y,{activeIndex:o.activeIndex,"onUpdate:activeIndex":e[0]||(e[0]=t=>o.activeIndex=t),isCollapse:o.isSidebarCollapse,"onUpdate:isCollapse":e[1]||(e[1]=t=>o.isSidebarCollapse=t)},null,8,["activeIndex","isCollapse"]),((0,s.uX)(),(0,s.Wv)((0,s.$y)(r.currentComponent),{class:(0,n.C4)(["main-container",{collapsed:o.isSidebarCollapse}])},null,8,["class"]))])}i(4114);var _=i(9114),v=(i(694),i(7009)),k=(i(8450),i(47)),w=(i(9648),i(9655));i(2893);const C={class:"status-panel"},S={class:"overview-cards"},F={class:"card-icon"},M={class:"card-content"},A={class:"card-value"},T={class:"overview-card index-status"},P={class:"card-icon"},D={class:"card-content"},E={class:"card-value"},L={class:"card-subtitle"},I={class:"card-icon"},V={class:"card-content"},O={class:"card-value"},R={class:"charts-section"},W={class:"chart-card"},B={class:"chart-header"},z={class:"chart-content"},N={key:0,class:"empty-state"},U={key:1,class:"pie-chart-container"},$={class:"pie-chart-wrapper"},j={class:"chart-center-text"},H={class:"center-value"},X={class:"chart-legend"},q={class:"legend-label"},K={class:"legend-value"},Y={class:"legend-percent"},Q={class:"chart-card"},G={class:"chart-header"},J={class:"chart-content"},Z={key:0,class:"empty-state"},tt={key:1,class:"pie-chart-container"},et={class:"pie-chart-wrapper"},it={class:"chart-center-text"},st={class:"center-value"},nt={class:"chart-legend"},at={class:"legend-label"},ot={class:"legend-value"},rt={class:"legend-percent"},lt={class:"actions-section"},ht={class:"action-card"},ct={class:"action-header"},dt={class:"action-content"},ut={key:0,class:"progress-container"},gt={class:"progress-header"},pt={class:"progress-phase"},ft={class:"progress-percentage"},mt={class:"progress-details"},bt={key:0,class:"progress-count"},xt={key:1,class:"progress-time"},yt={key:0,class:"progress-message"},_t={key:1,class:"error-container"},vt={class:"error-icon"},kt={class:"error-content"},wt={class:"error-message"},Ct={key:0,class:"error-suggestion"},St={class:"error-actions"},Ft={key:2,class:"action-buttons"},Mt={class:"restore-section"},At={key:0,class:"file-info-section"},Tt=["src"],Pt={key:2,class:"card-bg-fallback"},Dt={class:"file-card-header"},Et={class:"info-card-footer"},Lt={class:"file-name"},It={class:"file-meta"},Vt=["src"],Ot={key:2,class:"card-bg-fallback"},Rt={class:"file-card-header warning"},Wt={class:"info-card-footer"},Bt={class:"file-name"},zt={class:"file-meta"};function Nt(t,e,i,a,o,r){const l=(0,s.g2)("font-awesome-icon"),h=(0,s.g2)("Doughnut"),c=w.ve,d=k.S2,u=p.R7,g=v.Zq,f=_.A;return(0,s.bo)(((0,s.uX)(),(0,s.CE)("div",C,[(0,s.Lk)("div",S,[(0,s.Lk)("div",{class:"overview-card total-files",onClick:e[0]||(e[0]=(...t)=>r.fetchIndexInfo&&r.fetchIndexInfo(...t))},[(0,s.Lk)("div",F,[(0,s.bF)(l,{icon:"database"})]),(0,s.Lk)("div",M,[e[9]||(e[9]=(0,s.Lk)("div",{class:"card-title"},"文件总数",-1)),(0,s.Lk)("div",A,(0,n.v_)(o.indexInfo.totalFiles?.toLocaleString()||"0"),1),e[10]||(e[10]=(0,s.Lk)("div",{class:"card-subtitle"},"点击刷新",-1))])]),(0,s.Lk)("div",T,[(0,s.Lk)("div",P,[(0,s.bF)(l,{icon:"clock"})]),(0,s.Lk)("div",D,[e[11]||(e[11]=(0,s.Lk)("div",{class:"card-title"},"索引更新时间",-1)),(0,s.Lk)("div",E,(0,n.v_)(r.formatTime(o.indexInfo.lastUpdated)),1),(0,s.Lk)("div",L,(0,n.v_)(r.getTimeAgo(o.indexInfo.lastUpdated)),1)])]),(0,s.Lk)("div",{class:"overview-card system-version",onClick:e[1]||(e[1]=(...t)=>r.openReleases&&r.openReleases(...t))},[(0,s.Lk)("div",I,[(0,s.bF)(l,{icon:"code-branch"})]),(0,s.Lk)("div",V,[e[12]||(e[12]=(0,s.Lk)("div",{class:"card-title"},"系统版本",-1)),(0,s.Lk)("div",O,"v"+(0,n.v_)(o.version),1),e[13]||(e[13]=(0,s.Lk)("div",{class:"card-subtitle"},"点击查看更新日志",-1))])])]),(0,s.Lk)("div",R,[(0,s.Lk)("div",W,[(0,s.Lk)("div",B,[(0,s.bF)(l,{icon:"share-alt"}),e[14]||(e[14]=(0,s.Lk)("span",null,"上传渠道分布",-1))]),(0,s.Lk)("div",z,[0===Object.keys(o.indexInfo.channelStats||{}).length?((0,s.uX)(),(0,s.CE)("div",N,[(0,s.bF)(l,{icon:"inbox"}),e[15]||(e[15]=(0,s.Lk)("span",null,"暂无数据",-1))])):((0,s.uX)(),(0,s.CE)("div",U,[(0,s.Lk)("div",$,[(0,s.bF)(h,{data:r.channelChartData,options:r.chartOptions},null,8,["data","options"]),(0,s.Lk)("div",j,[(0,s.Lk)("div",H,(0,n.v_)(o.indexInfo.totalFiles?.toLocaleString()||"0"),1),e[16]||(e[16]=(0,s.Lk)("div",{class:"center-label"},"文件总数",-1))])]),(0,s.Lk)("div",X,[((0,s.uX)(!0),(0,s.CE)(s.FK,null,(0,s.pI)(o.indexInfo.channelStats,(t,e,i)=>((0,s.uX)(),(0,s.CE)("div",{key:e,class:"legend-item"},[(0,s.Lk)("span",{class:"legend-color",style:(0,n.Tr)({background:r.getChartColor(i)})},null,4),(0,s.Lk)("span",q,(0,n.v_)(e),1),(0,s.Lk)("span",K,(0,n.v_)(t.toLocaleString()),1),(0,s.Lk)("span",Y,(0,n.v_)(r.getPercentage(t,o.indexInfo.totalFiles))+"%",1)]))),128))])]))])]),(0,s.Lk)("div",Q,[(0,s.Lk)("div",G,[(0,s.bF)(l,{icon:"file-alt"}),e[17]||(e[17]=(0,s.Lk)("span",null,"文件状态分布",-1))]),(0,s.Lk)("div",J,[0===Object.keys(o.indexInfo.typeStats||{}).length?((0,s.uX)(),(0,s.CE)("div",Z,[(0,s.bF)(l,{icon:"inbox"}),e[18]||(e[18]=(0,s.Lk)("span",null,"暂无数据",-1))])):((0,s.uX)(),(0,s.CE)("div",tt,[(0,s.Lk)("div",et,[(0,s.bF)(h,{data:r.typeChartData,options:r.chartOptions},null,8,["data","options"]),(0,s.Lk)("div",it,[(0,s.Lk)("div",st,(0,n.v_)(Object.keys(o.indexInfo.typeStats).length),1),e[19]||(e[19]=(0,s.Lk)("div",{class:"center-label"},"状态类型",-1))])]),(0,s.Lk)("div",nt,[((0,s.uX)(!0),(0,s.CE)(s.FK,null,(0,s.pI)(r.aggregatedTypeStats,(t,e,i)=>((0,s.uX)(),(0,s.CE)("div",{key:e,class:"legend-item"},[(0,s.Lk)("span",{class:"legend-color",style:(0,n.Tr)({background:r.getTypeChartColor(i)})},null,4),(0,s.Lk)("span",at,(0,n.v_)(e),1),(0,s.Lk)("span",ot,(0,n.v_)(t.toLocaleString()),1),(0,s.Lk)("span",rt,(0,n.v_)(r.getPercentage(t,o.indexInfo.totalFiles))+"%",1)]))),128))])]))])])]),(0,s.Lk)("div",lt,[(0,s.Lk)("div",ht,[(0,s.Lk)("div",ct,[(0,s.bF)(l,{icon:"tools"}),e[20]||(e[20]=(0,s.Lk)("span",null,"系统维护",-1))]),(0,s.Lk)("div",dt,[o.isProcessing?((0,s.uX)(),(0,s.CE)("div",ut,[(0,s.Lk)("div",gt,[(0,s.Lk)("span",pt,(0,n.v_)(r.phaseDescription),1),(0,s.Lk)("span",ft,(0,n.v_)(Math.round(o.processingProgress.percentage))+"%",1)]),(0,s.bF)(c,{percentage:o.processingProgress.percentage,"stroke-width":12,"show-text":!1,class:"progress-bar"},null,8,["percentage"]),(0,s.Lk)("div",mt,[o.processingProgress.current>0?((0,s.uX)(),(0,s.CE)("span",bt,[(0,s.bF)(l,{icon:"file-alt"}),(0,s.eW)(" "+(0,n.v_)(o.processingProgress.current.toLocaleString())+" ",1),o.processingProgress.total>0?((0,s.uX)(),(0,s.CE)(s.FK,{key:0},[(0,s.eW)(" / "+(0,n.v_)(o.processingProgress.total.toLocaleString()),1)],64)):(0,s.Q3)("",!0),e[21]||(e[21]=(0,s.eW)(" 条记录 ",-1))])):(0,s.Q3)("",!0),r.estimatedTimeRemaining?((0,s.uX)(),(0,s.CE)("span",xt,[(0,s.bF)(l,{icon:"clock"}),(0,s.eW)(" "+(0,n.v_)(r.estimatedTimeRemaining),1)])):(0,s.Q3)("",!0)]),o.processingProgress.message?((0,s.uX)(),(0,s.CE)("div",yt,(0,n.v_)(o.processingProgress.message),1)):(0,s.Q3)("",!0),(0,s.bF)(d,{type:"danger",plain:"",size:"small",onClick:r.cancelOperation,class:"cancel-btn"},{default:(0,s.k6)(()=>[(0,s.bF)(l,{icon:"times"}),e[22]||(e[22]=(0,s.eW)(" 取消操作 ",-1))]),_:1},8,["onClick"])])):o.processingError?((0,s.uX)(),(0,s.CE)("div",_t,[(0,s.Lk)("div",vt,[(0,s.bF)(l,{icon:"exclamation-triangle"})]),(0,s.Lk)("div",kt,[(0,s.Lk)("div",wt,(0,n.v_)(o.processingError.message),1),o.processingError.suggestion?((0,s.uX)(),(0,s.CE)("div",Ct,(0,n.v_)(o.processingError.suggestion),1)):(0,s.Q3)("",!0)]),(0,s.Lk)("div",St,[o.processingError.recoverable?((0,s.uX)(),(0,s.Wv)(d,{key:0,type:"primary",size:"small",onClick:r.retryOperation},{default:(0,s.k6)(()=>[(0,s.bF)(l,{icon:"redo"}),e[23]||(e[23]=(0,s.eW)(" 重试 ",-1))]),_:1},8,["onClick"])):(0,s.Q3)("",!0),(0,s.bF)(d,{type:"default",size:"small",onClick:r.dismissError},{default:(0,s.k6)(()=>[...e[24]||(e[24]=[(0,s.eW)(" 关闭 ",-1)])]),_:1},8,["onClick"])])])):((0,s.uX)(),(0,s.CE)("div",Ft,[(0,s.bF)(u,{content:"重新扫描所有文件并更新索引数据,适用于数据不一致时的修复",placement:"top"},{default:(0,s.k6)(()=>[(0,s.bF)(d,{type:"primary",loading:o.rebuilding,disabled:o.isProcessing,onClick:r.rebuildIndex,class:"action-btn rebuild-btn"},{default:(0,s.k6)(()=>[(0,s.bF)(l,{icon:"sync-alt"}),(0,s.eW)(" "+(0,n.v_)(o.rebuilding?"重建中...":"重建索引"),1)]),_:1},8,["loading","disabled","onClick"])]),_:1}),(0,s.bF)(u,{content:"备份所有文件元数据和系统设置到JSON文件",placement:"top"},{default:(0,s.k6)(()=>[(0,s.bF)(d,{type:"success",loading:o.backing,disabled:o.isProcessing,onClick:r.backupData,class:"action-btn backup-btn"},{default:(0,s.k6)(()=>[(0,s.bF)(l,{icon:"download"}),(0,s.eW)(" "+(0,n.v_)(o.backing?"备份中...":"备份数据"),1)]),_:1},8,["loading","disabled","onClick"])]),_:1}),(0,s.bF)(u,{content:"从备份文件恢复数据,将覆盖现有的文件元数据和系统设置",placement:"top"},{default:(0,s.k6)(()=>[(0,s.Lk)("div",Mt,[(0,s.Lk)("input",{type:"file",ref:"fileInput",accept:".json",onChange:e[2]||(e[2]=(...t)=>r.handleFileSelect&&r.handleFileSelect(...t)),style:{display:"none"}},null,544),(0,s.bF)(d,{type:"warning",loading:o.restoring,disabled:o.isProcessing,onClick:r.selectRestoreFile,class:"action-btn restore-btn"},{default:(0,s.k6)(()=>[(0,s.bF)(l,{icon:"upload"}),(0,s.eW)(" "+(0,n.v_)(o.restoring?"恢复中...":"恢复数据"),1)]),_:1},8,["loading","disabled","onClick"])])]),_:1})]))])])]),o.indexInfo.newestFile||o.indexInfo.oldestFile?((0,s.uX)(),(0,s.CE)("div",At,[o.indexInfo.newestFile?((0,s.uX)(),(0,s.CE)("div",{key:0,class:"file-info-card info-card-newest",onClick:e[5]||(e[5]=t=>r.openFileInNewTab(o.indexInfo.newestFile))},[r.isImageFile(o.indexInfo.newestFile)&&!o.loadErrors["newest"]?((0,s.uX)(),(0,s.Wv)(g,{key:0,src:"/file/"+o.indexInfo.newestFile.id+"?from=admin",fit:"cover",class:"card-bg-media",onError:e[3]||(e[3]=t=>r.handleImageError("newest"))},null,8,["src"])):r.isVideoFile(o.indexInfo.newestFile)&&!o.loadErrors["newest"]?((0,s.uX)(),(0,s.CE)("video",{key:1,src:"/file/"+o.indexInfo.newestFile.id+"?from=admin",class:"card-bg-media",muted:"",loop:"",autoplay:"",onError:e[4]||(e[4]=t=>r.handleImageError("newest"))},null,40,Tt)):((0,s.uX)(),(0,s.CE)("div",Pt,[(0,s.bF)(l,{icon:"file-alt",class:"fallback-icon"})])),(0,s.Lk)("div",Dt,[(0,s.bF)(l,{icon:"arrow-up"}),e[25]||(e[25]=(0,s.Lk)("span",null,"最近上传",-1))]),(0,s.Lk)("div",Et,[(0,s.Lk)("div",Lt,(0,n.v_)(o.indexInfo.newestFile.metadata?.FileName||o.indexInfo.newestFile.id),1),(0,s.Lk)("div",It,(0,n.v_)(r.formatTime(o.indexInfo.newestFile.metadata?.TimeStamp)),1)])])):(0,s.Q3)("",!0),o.indexInfo.oldestFile?((0,s.uX)(),(0,s.CE)("div",{key:1,class:"file-info-card info-card-oldest",onClick:e[8]||(e[8]=t=>r.openFileInNewTab(o.indexInfo.oldestFile))},[r.isImageFile(o.indexInfo.oldestFile)&&!o.loadErrors["oldest"]?((0,s.uX)(),(0,s.Wv)(g,{key:0,src:"/file/"+o.indexInfo.oldestFile.id+"?from=admin",fit:"cover",class:"card-bg-media",onError:e[6]||(e[6]=t=>r.handleImageError("oldest"))},null,8,["src"])):r.isVideoFile(o.indexInfo.oldestFile)&&!o.loadErrors["oldest"]?((0,s.uX)(),(0,s.CE)("video",{key:1,src:"/file/"+o.indexInfo.oldestFile.id+"?from=admin",class:"card-bg-media",muted:"",loop:"",autoplay:"",onError:e[7]||(e[7]=t=>r.handleImageError("oldest"))},null,40,Vt)):((0,s.uX)(),(0,s.CE)("div",Ot,[(0,s.bF)(l,{icon:"file-alt",class:"fallback-icon"})])),(0,s.Lk)("div",Rt,[(0,s.bF)(l,{icon:"arrow-down"}),e[26]||(e[26]=(0,s.Lk)("span",null,"最早上传",-1))]),(0,s.Lk)("div",Wt,[(0,s.Lk)("div",Bt,(0,n.v_)(o.indexInfo.oldestFile.metadata?.FileName||o.indexInfo.oldestFile.id),1),(0,s.Lk)("div",zt,(0,n.v_)(r.formatTime(o.indexInfo.oldestFile.metadata?.TimeStamp)),1)])])):(0,s.Q3)("",!0)])):(0,s.Q3)("",!0)])),[[f,o.loading]])}i(8111),i(8237),i(8335);var Ut=i(797),$t={rE:"2.5.5"},jt=(i(116),i(1701),i(1114));i(2489),i(7588),i(3579),i(7642),i(8004),i(3853),i(5876),i(2475),i(5024),i(1698),i(3110); /*! * @kurkle/color v0.3.4 * https://github.com/kurkle/color#readme @@ -19,5 +19,5 @@ function Oe(){}const Re=(()=>{let t=0;return()=>t++})();function We(t){return nu * (c) 2025 Chart.js Contributors * Released under the MIT License */ -class fa{constructor(){this._request=null,this._charts=new Map,this._running=!1,this._lastDate=void 0}_notify(t,e,i,s){const n=e.listeners[s],a=e.duration;n.forEach(s=>s({chart:t,initial:e.initial,numSteps:a,currentStep:Math.min(i-e.start,a)}))}_refresh(){this._request||(this._running=!0,this._request=Xi.call(window,()=>{this._update(),this._request=null,this._running&&this._refresh()}))}_update(t=Date.now()){let e=0;this._charts.forEach((i,s)=>{if(!i.running||!i.items.length)return;const n=i.items;let a,o=n.length-1,r=!1;for(;o>=0;--o)a=n[o],a._active?(a._total>i.duration&&(i.duration=a._total),a.tick(t),r=!0):(n[o]=n[n.length-1],n.pop());r&&(s.draw(),this._notify(s,i,t,"progress")),n.length||(i.running=!1,this._notify(s,i,t,"complete"),i.initial=!1),e+=n.length}),this._lastDate=t,0===e&&(this._running=!1)}_getAnims(t){const e=this._charts;let i=e.get(t);return i||(i={running:!1,initial:!0,items:[],listeners:{complete:[],progress:[]}},e.set(t,i)),i}listen(t,e,i){this._getAnims(t).listeners[e].push(i)}add(t,e){e&&e.length&&this._getAnims(t).items.push(...e)}has(t){return this._getAnims(t).items.length>0}start(t){const e=this._charts.get(t);e&&(e.running=!0,e.start=Date.now(),e.duration=e.items.reduce((t,e)=>Math.max(t,e._duration),0),this._refresh())}running(t){if(!this._running)return!1;const e=this._charts.get(t);return!!(e&&e.running&&e.items.length)}stop(t){const e=this._charts.get(t);if(!e||!e.items.length)return;const i=e.items;let s=i.length-1;for(;s>=0;--s)i[s].cancel();e.items=[],this._notify(t,e,Date.now(),"complete")}remove(t){return this._charts.delete(t)}}var ma=new fa;const ba="transparent",xa={boolean(t,e,i){return i>.5?e:t},color(t,e,i){const s=as(t||ba),n=s.valid&&as(e||ba);return n&&n.valid?n.mix(s,i).hexString():e},number(t,e,i){return t+(e-t)*i}};class ya{constructor(t,e,i,s){const n=e[i];s=Qs([t.to,s,n,t.from]);const a=Qs([t.from,n,s]);this._active=!0,this._fn=t.fn||xa[t.type||typeof a],this._easing=ss[t.easing]||ss.linear,this._start=Math.floor(Date.now()+(t.delay||0)),this._duration=this._total=Math.floor(t.duration),this._loop=!!t.loop,this._target=e,this._prop=i,this._from=a,this._to=s,this._promises=void 0}active(){return this._active}update(t,e,i){if(this._active){this._notify(!1);const s=this._target[this._prop],n=i-this._start,a=this._duration-n;this._start=i,this._duration=Math.floor(Math.max(a,t.duration)),this._total+=n,this._loop=!!t.loop,this._to=Qs([t.to,e,s,t.from]),this._from=Qs([t.from,s,e])}}cancel(){this._active&&(this.tick(Date.now()),this._active=!1,this._notify(!1))}tick(t){const e=t-this._start,i=this._duration,s=this._prop,n=this._from,a=this._loop,o=this._to;let r;if(this._active=n!==o&&(a||e1?2-r:r,r=this._easing(Math.min(1,Math.max(0,r))),this._target[s]=this._fn(n,o,r))}wait(){const t=this._promises||(this._promises=[]);return new Promise((e,i)=>{t.push({res:e,rej:i})})}_notify(t){const e=t?"res":"rej",i=this._promises||[];for(let s=0;s{const n=t[s];if(!ze(n))return;const a={};for(const t of e)a[t]=n[t];(Be(n.properties)&&n.properties||[s]).forEach(t=>{t!==s&&i.has(t)||i.set(t,a)})})}_animateOptions(t,e){const i=e.options,s=ka(t,i);if(!s)return[];const n=this._createAnimations(s,i);return i.$shared&&va(t.options.$animations,i).then(()=>{t.options=i},()=>{}),n}_createAnimations(t,e){const i=this._properties,s=[],n=t.$animations||(t.$animations={}),a=Object.keys(e),o=Date.now();let r;for(r=a.length-1;r>=0;--r){const l=a[r];if("$"===l.charAt(0))continue;if("options"===l){s.push(...this._animateOptions(t,e));continue}const h=e[l];let c=n[l];const d=i.get(l);if(c){if(d&&c.active()){c.update(d,h,o);continue}c.cancel()}d&&d.duration?(n[l]=c=new ya(d,t,l,h),s.push(c)):t[l]=h}return s}update(t,e){if(0===this._properties.size)return void Object.assign(t,e);const i=this._createAnimations(t,e);return i.length?(ma.add(this._chart,i),!0):void 0}}function va(t,e){const i=[],s=Object.keys(e);for(let n=0;n0||!i&&e<0)return n.index}return null}function Ia(t,e){const{chart:i,_cachedMeta:s}=t,n=i._stacks||(i._stacks={}),{iScale:a,vScale:o,index:r}=s,l=a.axis,h=o.axis,c=Pa(a,o,s),d=e.length;let u;for(let g=0;gi[t].axis===e).shift()}function Oa(t,e){return Js(t,{active:!1,dataset:void 0,datasetIndex:e,index:e,mode:"default",type:"dataset"})}function Ra(t,e,i){return Js(t,{active:!1,dataIndex:e,parsed:void 0,raw:void 0,element:i,index:e,mode:"default",type:"data"})}function Wa(t,e){const i=t.controller.index,s=t.vScale&&t.vScale.axis;if(s){e=e||t._parsed;for(const t of e){const e=t._stacks;if(!e||void 0===e[s]||void 0===e[s][i])return;delete e[s][i],void 0!==e[s]._visualValues&&void 0!==e[s]._visualValues[i]&&delete e[s]._visualValues[i]}}}const Ba=t=>"reset"===t||"none"===t,za=(t,e)=>e?t:Object.assign({},t),Na=(t,e,i)=>t&&!e.hidden&&e._stacked&&{keys:Fa(i,!0),values:null};class Ua{constructor(t,e){this.chart=t,this._ctx=t.ctx,this.index=e,this._cachedDataOpts={},this._cachedMeta=this.getMeta(),this._type=this._cachedMeta.type,this.options=void 0,this._parsing=!1,this._data=void 0,this._objectData=void 0,this._sharedOptions=void 0,this._drawStart=void 0,this._drawCount=void 0,this.enableOptionSharing=!1,this.supportsDecimation=!1,this.$context=void 0,this._syncList=[],this.datasetElementType=new.target.datasetElementType,this.dataElementType=new.target.dataElementType,this.initialize()}initialize(){const t=this._cachedMeta;this.configure(),this.linkScales(),t._stacked=Ta(t.vScale,t),this.addElements(),this.options.fill&&!this.chart.isPluginEnabled("filler")&&console.warn("Tried to use the 'fill' option without the 'Filler' plugin enabled. Please import and register the 'Filler' plugin and make sure it is not disabled in the options")}updateIndex(t){this.index!==t&&Wa(this._cachedMeta),this.index=t}linkScales(){const t=this.chart,e=this._cachedMeta,i=this.getDataset(),s=(t,e,i,s)=>"x"===t?e:"r"===t?s:i,n=e.xAxisID=$e(i.xAxisID,Va(t,"x")),a=e.yAxisID=$e(i.yAxisID,Va(t,"y")),o=e.rAxisID=$e(i.rAxisID,Va(t,"r")),r=e.indexAxis,l=e.iAxisID=s(r,n,a,o),h=e.vAxisID=s(r,a,n,o);e.xScale=this.getScaleForId(n),e.yScale=this.getScaleForId(a),e.rScale=this.getScaleForId(o),e.iScale=this.getScaleForId(l),e.vScale=this.getScaleForId(h)}getDataset(){return this.chart.data.datasets[this.index]}getMeta(){return this.chart.getDatasetMeta(this.index)}getScaleForId(t){return this.chart.scales[t]}_getOtherScale(t){const e=this._cachedMeta;return t===e.iScale?e.vScale:e.iScale}reset(){this._update("reset")}_destroy(){const t=this._cachedMeta;this._data&&ji(this._data,this),t._stacked&&Wa(t)}_dataCheck(){const t=this.getDataset(),e=t.data||(t.data=[]),i=this._data;if(ze(e)){const t=this._cachedMeta;this._data=Aa(e,t)}else if(i!==e){if(i){ji(i,this);const t=this._cachedMeta;Wa(t),t._parsed=[]}e&&Object.isExtensible(e)&&$i(e,this),this._syncList=[],this._data=e}}addElements(){const t=this._cachedMeta;this._dataCheck(),this.datasetElementType&&(t.dataset=new this.datasetElementType)}buildOrUpdateElements(t){const e=this._cachedMeta,i=this.getDataset();let s=!1;this._dataCheck();const n=e._stacked;e._stacked=Ta(e.vScale,e),e.stack!==i.stack&&(s=!0,Wa(e),e.stack=i.stack),this._resyncElements(t),(s||n!==e._stacked)&&(Ia(this,e._parsed),e._stacked=Ta(e.vScale,e))}configure(){const t=this.chart.config,e=t.datasetScopeKeys(this._type),i=t.getOptionScopes(this.getDataset(),e,!0);this.options=t.createResolver(i,this.getContext()),this._parsing=this.options.parsing,this._cachedDataOpts={}}parse(t,e){const{_cachedMeta:i,_data:s}=this,{iScale:n,_stacked:a}=i,o=n.axis;let r,l,h,c=0===t&&e===s.length||i._sorted,d=t>0&&i._parsed[t-1];if(!1===this._parsing)i._parsed=s,i._sorted=!0,h=s;else{h=Be(s[t])?this.parseArrayData(i,s,t,e):ze(s[t])?this.parseObjectData(i,s,t,e):this.parsePrimitiveData(i,s,t,e);const n=()=>null===l[o]||d&&l[o]e||c=0;--d)if(!g()){this.updateRangeFromParsed(l,t,u,r);break}return l}getAllParsedValues(t){const e=this._cachedMeta._parsed,i=[];let s,n,a;for(s=0,n=e.length;s=0&&tthis.getContext(i,s,e),p=l.resolveNamedOptions(d,u,g,c);return p.$shared&&(p.$shared=r,n[a]=Object.freeze(za(p,r))),p}_resolveAnimations(t,e,i){const s=this.chart,n=this._cachedDataOpts,a=`animation-${e}`,o=n[a];if(o)return o;let r;if(!1!==s.options.animation){const s=this.chart.config,n=s.datasetAnimationScopeKeys(this._type,e),a=s.getOptionScopes(this.getDataset(),n);r=s.createResolver(a,this.getContext(t,i,e))}const l=new _a(s,r&&r.animations);return r&&r._cacheable&&(n[a]=Object.freeze(l)),l}getSharedOptions(t){if(t.$shared)return this._sharedOptions||(this._sharedOptions=Object.assign({},t))}includeOptions(t,e){return!e||Ba(t)||this.chart._animationsDisabled}_getSharedOptions(t,e){const i=this.resolveDataElementOptions(t,e),s=this._sharedOptions,n=this.getSharedOptions(i),a=this.includeOptions(e,n)||n!==s;return this.updateSharedOptions(n,e,i),{sharedOptions:n,includeOptions:a}}updateElement(t,e,i,s){Ba(s)?Object.assign(t,i):this._resolveAnimations(e,s).update(t,i)}updateSharedOptions(t,e,i){t&&!Ba(e)&&this._resolveAnimations(void 0,e).update(t,i)}_setStyle(t,e,i,s){t.active=s;const n=this.getStyle(e,s);this._resolveAnimations(e,i,s).update(t,{options:!s&&this.getSharedOptions(n)||n})}removeHoverStyle(t,e,i){this._setStyle(t,i,"active",!1)}setHoverStyle(t,e,i){this._setStyle(t,i,"active",!0)}_removeDatasetHoverStyle(){const t=this._cachedMeta.dataset;t&&this._setStyle(t,void 0,"active",!1)}_setDatasetHoverStyle(){const t=this._cachedMeta.dataset;t&&this._setStyle(t,void 0,"active",!0)}_resyncElements(t){const e=this._data,i=this._cachedMeta.data;for(const[o,r,l]of this._syncList)this[o](r,l);this._syncList=[];const s=i.length,n=e.length,a=Math.min(n,s);a&&this.parse(0,a),n>s?this._insertElements(s,n-s,t):n{for(t.length+=e,o=t.length-1;o>=a;o--)t[o]=t[o-e]};for(r(n),o=t;ot-e))}return t._cache.$bar}function ja(t){const e=t.iScale,i=$a(e,t.type);let s,n,a,o,r=e._length;const l=()=>{32767!==a&&-32768!==a&&(oi(o)&&(r=Math.min(r,Math.abs(a-o)||r)),o=a)};for(s=0,n=i.length;s0?n[t-1]:null,r=tMath.abs(r)&&(l=r,h=o),e[i.axis]=h,e._custom={barStart:l,barEnd:h,start:n,end:a,min:o,max:r}}function Ka(t,e,i,s){return Be(t)?qa(t,e,i,s):e[i.axis]=i.parse(t,s),e}function Ya(t,e,i,s){const n=t.iScale,a=t.vScale,o=n.getLabels(),r=n===a,l=[];let h,c,d,u;for(h=i,c=i+s;h=i?1:-1)}function Ja(t){let e,i,s,n,a;return t.horizontal?(e=t.base>t.x,i="left",s="right"):(e=t.baset.controller.options.grouped),n=i.options.stacked,a=[],o=this._cachedMeta.controller.getParsed(e),r=o&&o[i.axis],l=t=>{const e=t._parsed.find(t=>t[i.axis]===r),s=e&&e[t.vScale.axis];if(We(s)||isNaN(s))return!0};for(const h of s)if((void 0===e||!l(h))&&((!1===n||-1===a.indexOf(h.stack)||void 0===n&&void 0===h.stack)&&a.push(h.stack),h.index===t))break;return a.length||a.push(void 0),a}_getStackCount(t){return this._getStacks(void 0,t).length}_getAxisCount(){return this._getAxis().length}getFirstScaleIdForIndexAxis(){const t=this.chart.scales,e=this.chart.options.indexAxis;return Object.keys(t).filter(i=>t[i].axis===e).shift()}_getAxis(){const t={},e=this.getFirstScaleIdForIndexAxis();for(const i of this.chart.data.datasets)t[$e("x"===this.chart.options.indexAxis?i.xAxisID:i.yAxisID,e)]=!0;return Object.keys(t)}_getStackIndex(t,e,i){const s=this._getStacks(t,i),n=void 0!==e?s.indexOf(e):-1;return-1===n?s.length-1:n}_getRuler(){const t=this.options,e=this._cachedMeta,i=e.iScale,s=[];let n,a;for(n=0,a=e.data.length;n=0;--i)e=Math.max(e,t[i].size(this.resolveDataElementOptions(i))/2);return e>0&&e}getLabelAndValue(t){const e=this._cachedMeta,i=this.chart.data.labels||[],{xScale:s,yScale:n}=e,a=this.getParsed(t),o=s.getLabelForValue(a.x),r=n.getLabelForValue(a.y),l=a._custom;return{label:i[t]||"",value:"("+o+", "+r+(l?", "+l:"")+")"}}update(t){const e=this._cachedMeta.data;this.updateElements(e,0,e.length,t)}updateElements(t,e,i,s){const n="reset"===s,{iScale:a,vScale:o}=this._cachedMeta,{sharedOptions:r,includeOptions:l}=this._getSharedOptions(e,s),h=a.axis,c=o.axis;for(let d=e;dIi(t,r,l,!0)?1:Math.max(e,e*i,s,s*i),p=(t,e,s)=>Ii(t,r,l,!0)?-1:Math.min(e,e*i,s,s*i),f=g(0,h,d),m=g(fi,c,u),b=p(ci,h,d),x=p(ci+fi,c,u);s=(f-b)/2,n=(m-x)/2,a=-(f+b)/2,o=-(m+x)/2}return{ratioX:s,ratioY:n,offsetX:a,offsetY:o}}(0,jt.A)(ao,"id","bubble"),(0,jt.A)(ao,"defaults",{datasetElementType:!1,dataElementType:"point",animations:{numbers:{type:"number",properties:["x","y","borderWidth","radius"]}}}),(0,jt.A)(ao,"overrides",{scales:{x:{type:"linear"},y:{type:"linear"}}});class ro extends Ua{constructor(t,e){super(t,e),this.enableOptionSharing=!0,this.innerRadius=void 0,this.outerRadius=void 0,this.offsetX=void 0,this.offsetY=void 0}linkScales(){}parse(t,e){const i=this.getDataset().data,s=this._cachedMeta;if(!1===this._parsing)s._parsed=i;else{let n,a,o=t=>+i[t];if(ze(i[t])){const{key:t="value"}=this._parsing;o=e=>+ni(i[e],t)}for(n=t,a=t+e;n0&&!isNaN(t)?di*(Math.abs(t)/e):0}getLabelAndValue(t){const e=this._cachedMeta,i=this.chart,s=i.data.labels||[],n=gs(e._parsed[t],i.options.locale);return{label:s[t]||"",value:n}}getMaxBorderWidth(t){let e=0;const i=this.chart;let s,n,a,o,r;if(!t)for(s=0,n=i.data.datasets.length;s"spacing"!==t,_indexable:t=>"spacing"!==t&&!t.startsWith("borderDash")&&!t.startsWith("hoverBorderDash")}),(0,jt.A)(ro,"overrides",{aspectRatio:1,plugins:{legend:{labels:{generateLabels(t){const e=t.data,{labels:{pointStyle:i,textAlign:s,color:n,useBorderRadius:a,borderRadius:o}}=t.legend.options;return e.labels.length&&e.datasets.length?e.labels.map((e,r)=>{const l=t.getDatasetMeta(0),h=l.controller.getStyle(r);return{text:e,fillStyle:h.backgroundColor,fontColor:n,hidden:!t.getDataVisibility(r),lineDash:h.borderDash,lineDashOffset:h.borderDashOffset,lineJoin:h.borderJoinStyle,lineWidth:h.borderWidth,strokeStyle:h.borderColor,textAlign:s,pointStyle:i,borderRadius:a&&(o||h.borderRadius),index:r}}):[]}},onClick(t,e,i){i.chart.toggleDataVisibility(e.index),i.chart.update()}}}});class lo extends Ua{initialize(){this.enableOptionSharing=!0,this.supportsDecimation=!0,super.initialize()}update(t){const e=this._cachedMeta,{dataset:i,data:s=[],_dataset:n}=e,a=this.chart._animationsDisabled;let{start:o,count:r}=Ji(e,s,a);this._drawStart=o,this._drawCount=r,Zi(e)&&(o=0,r=s.length),i._chart=this.chart,i._datasetIndex=this.index,i._decimated=!!n._decimated,i.points=s;const l=this.resolveDatasetElementOptions(t);this.options.showLine||(l.borderWidth=0),l.segment=this.options.segment,this.updateElement(i,void 0,{animated:!a,options:l},t),this.updateElements(s,o,r,t)}updateElements(t,e,i,s){const n="reset"===s,{iScale:a,vScale:o,_stacked:r,_dataset:l}=this._cachedMeta,{sharedOptions:h,includeOptions:c}=this._getSharedOptions(e,s),d=a.axis,u=o.axis,{spanGaps:g,segment:p}=this.options,f=Ci(g)?g:Number.POSITIVE_INFINITY,m=this.chart._animationsDisabled||n||"none"===s,b=e+i,x=t.length;let y=e>0&&this.getParsed(e-1);for(let _=0;_=b){g.skip=!0;continue}const x=this.getParsed(_),v=We(x[u]),k=g[d]=a.getPixelForValue(x[d],_),w=g[u]=n||v?o.getBasePixel():o.getPixelForValue(r?this.applyStack(o,x,r):x[u],_);g.skip=isNaN(k)||isNaN(w)||v,g.stop=_>0&&Math.abs(x[d]-y[d])>f,p&&(g.parsed=x,g.raw=l.data[_]),c&&(g.options=h||this.resolveDataElementOptions(_,i.active?"active":s)),m||this.updateElement(i,_,g,s),y=x}}getMaxOverflow(){const t=this._cachedMeta,e=t.dataset,i=e.options&&e.options.borderWidth||0,s=t.data||[];if(!s.length)return i;const n=s[0].size(this.resolveDataElementOptions(0)),a=s[s.length-1].size(this.resolveDataElementOptions(s.length-1));return Math.max(i,n,a)/2}draw(){const t=this._cachedMeta;t.dataset.updateControlPoints(this.chart.chartArea,t.iScale.axis),super.draw()}}(0,jt.A)(lo,"id","line"),(0,jt.A)(lo,"defaults",{datasetElementType:"line",dataElementType:"point",showLine:!0,spanGaps:!1}),(0,jt.A)(lo,"overrides",{scales:{_index_:{type:"category"},_value_:{type:"linear"}}});class ho extends Ua{constructor(t,e){super(t,e),this.innerRadius=void 0,this.outerRadius=void 0}getLabelAndValue(t){const e=this._cachedMeta,i=this.chart,s=i.data.labels||[],n=gs(e._parsed[t].r,i.options.locale);return{label:s[t]||"",value:n}}parseObjectData(t,e,i,s){return yn.bind(this)(t,e,i,s)}update(t){const e=this._cachedMeta.data;this._updateRadius(),this.updateElements(e,0,e.length,t)}getMinMax(){const t=this._cachedMeta,e={min:Number.POSITIVE_INFINITY,max:Number.NEGATIVE_INFINITY};return t.data.forEach((t,i)=>{const s=this.getParsed(i).r;!isNaN(s)&&this.chart.getDataVisibility(i)&&(se.max&&(e.max=s))}),e}_updateRadius(){const t=this.chart,e=t.chartArea,i=t.options,s=Math.min(e.right-e.left,e.bottom-e.top),n=Math.max(s/2,0),a=Math.max(i.cutoutPercentage?n/100*i.cutoutPercentage:1,0),o=(n-a)/t.getVisibleDatasetCount();this.outerRadius=n-o*this.index,this.innerRadius=this.outerRadius-o}updateElements(t,e,i,s){const n="reset"===s,a=this.chart,o=a.options,r=o.animation,l=this._cachedMeta.rScale,h=l.xCenter,c=l.yCenter,d=l.getIndexAngle(0)-.5*ci;let u,g=d;const p=360/this.countVisibleElements();for(u=0;u{!isNaN(this.getParsed(i).r)&&this.chart.getDataVisibility(i)&&e++}),e}_computeAngle(t,e,i){return this.chart.getDataVisibility(t)?Mi(this.resolveDataElementOptions(t,e).angle||i):0}}(0,jt.A)(ho,"id","polarArea"),(0,jt.A)(ho,"defaults",{dataElementType:"arc",animation:{animateRotate:!0,animateScale:!0},animations:{numbers:{type:"number",properties:["x","y","startAngle","endAngle","innerRadius","outerRadius"]}},indexAxis:"r",startAngle:0}),(0,jt.A)(ho,"overrides",{aspectRatio:1,plugins:{legend:{labels:{generateLabels(t){const e=t.data;if(e.labels.length&&e.datasets.length){const{labels:{pointStyle:i,color:s}}=t.legend.options;return e.labels.map((e,n)=>{const a=t.getDatasetMeta(0),o=a.controller.getStyle(n);return{text:e,fillStyle:o.backgroundColor,strokeStyle:o.borderColor,fontColor:s,lineWidth:o.borderWidth,pointStyle:i,hidden:!t.getDataVisibility(n),index:n}})}return[]}},onClick(t,e,i){i.chart.toggleDataVisibility(e.index),i.chart.update()}}},scales:{r:{type:"radialLinear",angleLines:{display:!1},beginAtZero:!0,grid:{circular:!0},pointLabels:{display:!1},startAngle:0}}});class co extends ro{}(0,jt.A)(co,"id","pie"),(0,jt.A)(co,"defaults",{cutout:0,rotation:0,circumference:360,radius:"100%"});class uo extends Ua{getLabelAndValue(t){const e=this._cachedMeta.vScale,i=this.getParsed(t);return{label:e.getLabels()[t],value:""+e.getLabelForValue(i[e.axis])}}parseObjectData(t,e,i,s){return yn.bind(this)(t,e,i,s)}update(t){const e=this._cachedMeta,i=e.dataset,s=e.data||[],n=e.iScale.getLabels();if(i.points=s,"resize"!==t){const e=this.resolveDatasetElementOptions(t);this.options.showLine||(e.borderWidth=0);const a={_loop:!0,_fullLoop:n.length===s.length,options:e};this.updateElement(i,void 0,a,t)}this.updateElements(s,0,s.length,t)}updateElements(t,e,i,s){const n=this._cachedMeta.rScale,a="reset"===s;for(let o=e;o0&&this.getParsed(e-1);for(let y=e;y0&&Math.abs(i[u]-x[u])>m,f&&(h.parsed=i,h.raw=l.data[y]),d&&(h.options=c||this.resolveDataElementOptions(y,e.active?"active":s)),b||this.updateElement(e,y,h,s),x=i}this.updateSharedOptions(c,s,h)}getMaxOverflow(){const t=this._cachedMeta,e=t.data||[];if(!this.options.showLine){let t=0;for(let i=e.length-1;i>=0;--i)t=Math.max(t,e[i].size(this.resolveDataElementOptions(i))/2);return t>0&&t}const i=t.dataset,s=i.options&&i.options.borderWidth||0;if(!e.length)return s;const n=e[0].size(this.resolveDataElementOptions(0)),a=e[e.length-1].size(this.resolveDataElementOptions(e.length-1));return Math.max(s,n,a)/2}}(0,jt.A)(go,"id","scatter"),(0,jt.A)(go,"defaults",{datasetElementType:!1,dataElementType:"point",showLine:!1,fill:!1}),(0,jt.A)(go,"overrides",{interaction:{mode:"point"},scales:{x:{type:"linear"},y:{type:"linear"}}});function po(){throw new Error("This method is not implemented: Check that a complete date adapter is provided.")}class fo{static override(t){Object.assign(fo.prototype,t)}constructor(t){(0,jt.A)(this,"options",void 0),this.options=t||{}}init(){}formats(){return po()}parse(){return po()}format(){return po()}add(){return po()}diff(){return po()}startOf(){return po()}endOf(){return po()}}var mo={_date:fo};function bo(t,e,i,s){const{controller:n,data:a,_sorted:o}=t,r=n._cachedMeta.iScale,l=t.dataset&&t.dataset.options?t.dataset.options.spanGaps:null;if(r&&e===r.axis&&"r"!==e&&o&&a.length){const o=r._reversePixels?zi:Bi;if(!s){const s=o(a,e,i);if(l){const{vScale:e}=n._cachedMeta,{_parsed:i}=t,a=i.slice(0,s.lo+1).reverse().findIndex(t=>!We(t[e.axis]));s.lo-=Math.max(0,a);const o=i.slice(s.hi).findIndex(t=>!We(t[e.axis]));s.hi+=Math.max(0,o)}return s}if(n._sharedOptions){const t=a[0],s="function"===typeof t.getRange&&t.getRange(e);if(s){const t=o(a,e,i-s),n=o(a,e,i+s);return{lo:t.lo,hi:n.hi}}}}return{lo:0,hi:a.length-1}}function xo(t,e,i,s,n){const a=t.getSortedVisibleDatasetMetas(),o=i[e];for(let r=0,l=a.length;r{t[o]&&t[o](e[i],n)&&(a.push({element:t,datasetIndex:s,index:l}),r=r||t.inRange(e.x,e.y,n))}),s&&!r?[]:a}var So={evaluateInteractionItems:xo,modes:{index(t,e,i,s){const n=Bn(e,t),a=i.axis||"x",o=i.includeInvisible||!1,r=i.intersect?_o(t,n,a,s,o):wo(t,n,a,!1,s,o),l=[];return r.length?(t.getSortedVisibleDatasetMetas().forEach(t=>{const e=r[0].index,i=t.data[e];i&&!i.skip&&l.push({element:i,datasetIndex:t.index,index:e})}),l):[]},dataset(t,e,i,s){const n=Bn(e,t),a=i.axis||"xy",o=i.includeInvisible||!1;let r=i.intersect?_o(t,n,a,s,o):wo(t,n,a,!1,s,o);if(r.length>0){const e=r[0].datasetIndex,i=t.getDatasetMeta(e).data;r=[];for(let t=0;tt.pos===e)}function Ao(t,e){return t.filter(t=>-1===Fo.indexOf(t.pos)&&t.box.axis===e)}function To(t,e){return t.sort((t,i)=>{const s=e?i:t,n=e?t:i;return s.weight===n.weight?s.index-n.index:s.weight-n.weight})}function Po(t){const e=[];let i,s,n,a,o,r;for(i=0,s=(t||[]).length;it.box.fullSize),!0),s=To(Mo(e,"left"),!0),n=To(Mo(e,"right")),a=To(Mo(e,"top"),!0),o=To(Mo(e,"bottom")),r=Ao(e,"x"),l=Ao(e,"y");return{fullSize:i,leftAndTop:s.concat(a),rightAndBottom:n.concat(l).concat(o).concat(r),chartArea:Mo(e,"chartArea"),vertical:s.concat(n).concat(l),horizontal:a.concat(o).concat(r)}}function Io(t,e,i,s){return Math.max(t[i],e[i])+Math.max(t[s],e[s])}function Vo(t,e){t.top=Math.max(t.top,e.top),t.left=Math.max(t.left,e.left),t.bottom=Math.max(t.bottom,e.bottom),t.right=Math.max(t.right,e.right)}function Oo(t,e,i,s){const{pos:n,box:a}=i,o=t.maxPadding;if(!ze(n)){i.size&&(t[n]-=i.size);const e=s[i.stack]||{size:0,count:1};e.size=Math.max(e.size,i.horizontal?a.height:a.width),i.size=e.size/e.count,t[n]+=i.size}a.getPadding&&Vo(o,a.getPadding());const r=Math.max(0,e.outerWidth-Io(o,t,"left","right")),l=Math.max(0,e.outerHeight-Io(o,t,"top","bottom")),h=r!==t.w,c=l!==t.h;return t.w=r,t.h=l,i.horizontal?{same:h,other:c}:{same:c,other:h}}function Ro(t){const e=t.maxPadding;function i(i){const s=Math.max(e[i]-t[i],0);return t[i]+=s,s}t.y+=i("top"),t.x+=i("left"),i("right"),i("bottom")}function Wo(t,e){const i=e.maxPadding;function s(t){const s={left:0,top:0,right:0,bottom:0};return t.forEach(t=>{s[t]=Math.max(e[t],i[t])}),s}return s(t?["left","right"]:["top","bottom"])}function Bo(t,e,i,s){const n=[];let a,o,r,l,h,c;for(a=0,o=t.length,h=0;a{"function"===typeof t.beforeLayout&&t.beforeLayout()});const c=l.reduce((t,e)=>e.box.options&&!1===e.box.options.display?t:t+1,0)||1,d=Object.freeze({outerWidth:e,outerHeight:i,padding:n,availableWidth:a,availableHeight:o,vBoxMaxWidth:a/2/c,hBoxMaxHeight:o/2}),u=Object.assign({},n);Vo(u,Ks(s));const g=Object.assign({maxPadding:u,w:a,h:o,x:n.left,y:n.top},n),p=Eo(l.concat(h),d);Bo(r.fullSize,g,d,p),Bo(l,g,d,p),Bo(h,g,d,p)&&Bo(l,g,d,p),Ro(g),No(r.leftAndTop,g,d,p),g.x+=g.w,g.y+=g.h,No(r.rightAndBottom,g,d,p),t.chartArea={left:g.left,top:g.top,right:g.left+g.w,bottom:g.top+g.h,height:g.h,width:g.w},qe(r.chartArea,e=>{const i=e.box;Object.assign(i,t.chartArea),i.update(g.w,g.h,{left:0,top:0,right:0,bottom:0})})}};class $o{acquireContext(t,e){}releaseContext(t){return!1}addEventListener(t,e,i){}removeEventListener(t,e,i){}getDevicePixelRatio(){return 1}getMaximumSize(t,e,i,s){return e=Math.max(0,e||t.width),i=i||t.height,{width:e,height:Math.max(0,s?Math.floor(e/s):i)}}isAttached(t){return!0}updateConfig(t){}}class jo extends $o{acquireContext(t){return t&&t.getContext&&t.getContext("2d")||null}updateConfig(t){t.options.animation=!1}}const Ho="$chartjs",Xo={touchstart:"mousedown",touchmove:"mousemove",touchend:"mouseup",pointerenter:"mouseenter",pointerdown:"mousedown",pointermove:"mousemove",pointerup:"mouseup",pointerleave:"mouseout",pointerout:"mouseout"},qo=t=>null===t||""===t;function Ko(t,e){const i=t.style,s=t.getAttribute("height"),n=t.getAttribute("width");if(t[Ho]={initial:{height:s,width:n,style:{display:i.display,height:i.height,width:i.width}}},i.display=i.display||"block",i.boxSizing=i.boxSizing||"border-box",qo(n)){const e=Hn(t,"width");void 0!==e&&(t.width=e)}if(qo(s))if(""===t.style.height)t.height=t.width/(e||2);else{const e=Hn(t,"height");void 0!==e&&(t.height=e)}return t}const Yo=!!jn&&{passive:!0};function Qo(t,e,i){t&&t.addEventListener(e,i,Yo)}function Go(t,e,i){t&&t.canvas&&t.canvas.removeEventListener(e,i,Yo)}function Jo(t,e){const i=Xo[t.type]||t.type,{x:s,y:n}=Bn(t,e);return{type:i,chart:e,native:t,x:void 0!==s?s:null,y:void 0!==n?n:null}}function Zo(t,e){for(const i of t)if(i===e||i.contains(e))return!0}function tr(t,e,i){const s=t.canvas,n=new MutationObserver(t=>{let e=!1;for(const i of t)e=e||Zo(i.addedNodes,s),e=e&&!Zo(i.removedNodes,s);e&&i()});return n.observe(document,{childList:!0,subtree:!0}),n}function er(t,e,i){const s=t.canvas,n=new MutationObserver(t=>{let e=!1;for(const i of t)e=e||Zo(i.removedNodes,s),e=e&&!Zo(i.addedNodes,s);e&&i()});return n.observe(document,{childList:!0,subtree:!0}),n}const ir=new Map;let sr=0;function nr(){const t=window.devicePixelRatio;t!==sr&&(sr=t,ir.forEach((e,i)=>{i.currentDevicePixelRatio!==t&&e()}))}function ar(t,e){ir.size||window.addEventListener("resize",nr),ir.set(t,e)}function or(t){ir.delete(t),ir.size||window.removeEventListener("resize",nr)}function rr(t,e,i){const s=t.canvas,n=s&&Dn(s);if(!n)return;const a=qi((t,e)=>{const s=n.clientWidth;i(t,e),s{const e=t[0],i=e.contentRect.width,s=e.contentRect.height;0===i&&0===s||a(i,s)});return o.observe(n),ar(t,a),o}function lr(t,e,i){i&&i.disconnect(),"resize"===e&&or(t)}function hr(t,e,i){const s=t.canvas,n=qi(e=>{null!==t.ctx&&i(Jo(e,t))},t);return Qo(s,e,n),n}class cr extends $o{acquireContext(t,e){const i=t&&t.getContext&&t.getContext("2d");return i&&i.canvas===t?(Ko(t,e),i):null}releaseContext(t){const e=t.canvas;if(!e[Ho])return!1;const i=e[Ho].initial;["height","width"].forEach(t=>{const s=i[t];We(s)?e.removeAttribute(t):e.setAttribute(t,s)});const s=i.style||{};return Object.keys(s).forEach(t=>{e.style[t]=s[t]}),e.width=e.width,delete e[Ho],!0}addEventListener(t,e,i){this.removeEventListener(t,e);const s=t.$proxies||(t.$proxies={}),n={attach:tr,detach:er,resize:rr},a=n[e]||hr;s[e]=a(t,e,i)}removeEventListener(t,e){const i=t.$proxies||(t.$proxies={}),s=i[e];if(!s)return;const n={attach:lr,detach:lr,resize:lr},a=n[e]||Go;a(t,e,s),i[e]=void 0}getDevicePixelRatio(){return window.devicePixelRatio}getMaximumSize(t,e,i,s){return Un(t,e,i,s)}isAttached(t){const e=t&&Dn(t);return!(!e||!e.isConnected)}}function dr(t){return!Pn()||"undefined"!==typeof OffscreenCanvas&&t instanceof OffscreenCanvas?jo:cr}class ur{constructor(){(0,jt.A)(this,"x",void 0),(0,jt.A)(this,"y",void 0),(0,jt.A)(this,"active",!1),(0,jt.A)(this,"options",void 0),(0,jt.A)(this,"$animations",void 0)}tooltipPosition(t){const{x:e,y:i}=this.getProps(["x","y"],t);return{x:e,y:i}}hasValue(){return Ci(this.x)&&Ci(this.y)}getProps(t,e){const i=this.$animations;if(!e||!i)return this;const s={};return t.forEach(t=>{s[t]=i[t]&&i[t].active()?i[t]._to:this[t]}),s}}function gr(t,e){const i=t.options.ticks,s=pr(t),n=Math.min(i.maxTicksLimit||s,s),a=i.major.enabled?mr(e):[],o=a.length,r=a[0],l=a[o-1],h=[];if(o>n)return br(e,h,a,o/n),h;const c=fr(a,e,n);if(o>0){let t,i;const s=o>1?Math.round((l-r)/(o-1)):null;for(xr(e,h,c,We(s)?0:r-s,r),t=0,i=o-1;tn)return t}return Math.max(n,1)}function mr(t){const e=[];let i,s;for(i=0,s=t.length;i"left"===t?"right":"right"===t?"left":t,vr=(t,e,i)=>"top"===e||"left"===e?t[e]+i:t[e]-i,kr=(t,e)=>Math.min(e||t,t);function wr(t,e){const i=[],s=t.length/e,n=t.length;let a=0;for(;ao+r)))return h}function Sr(t,e){qe(t,t=>{const i=t.gc,s=i.length/2;let n;if(s>e){for(n=0;ns?s:i,s=n&&i>s?i:s,{min:Ue(i,Ue(s,i)),max:Ue(s,Ue(i,s))}}getPadding(){return{left:this.paddingLeft||0,top:this.paddingTop||0,right:this.paddingRight||0,bottom:this.paddingBottom||0}}getTicks(){return this.ticks}getLabels(){const t=this.chart.data;return this.options.labels||(this.isHorizontal()?t.xLabels:t.yLabels)||t.labels||[]}getLabelItems(t=this.chart.chartArea){const e=this._labelItems||(this._labelItems=this._computeLabelItems(t));return e}beforeLayout(){this._cache={},this._dataLimitsCached=!1}beforeUpdate(){Xe(this.options.beforeUpdate,[this])}update(t,e,i){const{beginAtZero:s,grace:n,ticks:a}=this.options,o=a.sampleSize;this.beforeUpdate(),this.maxWidth=t,this.maxHeight=e,this._margins=i=Object.assign({left:0,right:0,top:0,bottom:0},i),this.ticks=null,this._labelSizes=null,this._gridLineItems=null,this._labelItems=null,this.beforeSetDimensions(),this.setDimensions(),this.afterSetDimensions(),this._maxLength=this.isHorizontal()?this.width+i.left+i.right:this.height+i.top+i.bottom,this._dataLimitsCached||(this.beforeDataLimits(),this.determineDataLimits(),this.afterDataLimits(),this._range=Gs(this,n,s),this._dataLimitsCached=!0),this.beforeBuildTicks(),this.ticks=this.buildTicks()||[],this.afterBuildTicks();const r=o=n||i<=1||!this.isHorizontal())return void(this.labelRotation=s);const h=this._getLabelSizes(),c=h.widest.width,d=h.highest.height,u=Vi(this.chart.width-c,0,this.maxWidth);a=t.offset?this.maxWidth/i:u/(i-1),c+6>a&&(a=u/(i-(t.offset?.5:1)),o=this.maxHeight-Fr(t.grid)-e.padding-Mr(t.title,this.chart.options.font),r=Math.sqrt(c*c+d*d),l=Ai(Math.min(Math.asin(Vi((h.highest.height+6)/a,-1,1)),Math.asin(Vi(o/r,-1,1))-Math.asin(Vi(d/r,-1,1)))),l=Math.max(s,Math.min(n,l))),this.labelRotation=l}afterCalculateLabelRotation(){Xe(this.options.afterCalculateLabelRotation,[this])}afterAutoSkip(){}beforeFit(){Xe(this.options.beforeFit,[this])}fit(){const t={width:0,height:0},{chart:e,options:{ticks:i,title:s,grid:n}}=this,a=this._isVisible(),o=this.isHorizontal();if(a){const a=Mr(s,e.options.font);if(o?(t.width=this.maxWidth,t.height=Fr(n)+a):(t.height=this.maxHeight,t.width=Fr(n)+a),i.display&&this.ticks.length){const{first:e,last:s,widest:n,highest:a}=this._getLabelSizes(),r=2*i.padding,l=Mi(this.labelRotation),h=Math.cos(l),c=Math.sin(l);if(o){const e=i.mirror?0:c*n.width+h*a.height;t.height=Math.min(this.maxHeight,t.height+e+r)}else{const e=i.mirror?0:h*n.width+c*a.height;t.width=Math.min(this.maxWidth,t.width+e+r)}this._calculatePadding(e,s,c,h)}}this._handleMargins(),o?(this.width=this._length=e.width-this._margins.left-this._margins.right,this.height=t.height):(this.width=t.width,this.height=this._length=e.height-this._margins.top-this._margins.bottom)}_calculatePadding(t,e,i,s){const{ticks:{align:n,padding:a},position:o}=this.options,r=0!==this.labelRotation,l="top"!==o&&"x"===this.axis;if(this.isHorizontal()){const o=this.getPixelForTick(0)-this.left,h=this.right-this.getPixelForTick(this.ticks.length-1);let c=0,d=0;r?l?(c=s*t.width,d=i*e.height):(c=i*t.height,d=s*e.width):"start"===n?d=e.width:"end"===n?c=t.width:"inner"!==n&&(c=t.width/2,d=e.width/2),this.paddingLeft=Math.max((c-o+a)*this.width/(this.width-o),0),this.paddingRight=Math.max((d-h+a)*this.width/(this.width-h),0)}else{let i=e.height/2,s=t.height/2;"start"===n?(i=0,s=t.height):"end"===n&&(i=e.height,s=0),this.paddingTop=i+a,this.paddingBottom=s+a}}_handleMargins(){this._margins&&(this._margins.left=Math.max(this.paddingLeft,this._margins.left),this._margins.top=Math.max(this.paddingTop,this._margins.top),this._margins.right=Math.max(this.paddingRight,this._margins.right),this._margins.bottom=Math.max(this.paddingBottom,this._margins.bottom))}afterFit(){Xe(this.options.afterFit,[this])}isHorizontal(){const{axis:t,position:e}=this.options;return"top"===e||"bottom"===e||"x"===t}isFullSize(){return this.options.fullSize}_convertTicksToLabels(t){let e,i;for(this.beforeTickToLabelConversion(),this.generateTickLabels(t),e=0,i=t.length;e({width:a[t]||0,height:o[t]||0});return{first:w(0),last:w(e-1),widest:w(v),highest:w(k),widths:a,heights:o}}getLabelForValue(t){return t}getPixelForValue(t,e){return NaN}getValueForPixel(t){}getPixelForTick(t){const e=this.ticks;return t<0||t>e.length-1?null:this.getPixelForValue(e[t].value)}getPixelForDecimal(t){this._reversePixels&&(t=1-t);const e=this._startPixel+t*this._length;return Oi(this._alignToPixels?Ms(this.chart,e,0):e)}getDecimalForPixel(t){const e=(t-this._startPixel)/this._length;return this._reversePixels?1-e:e}getBasePixel(){return this.getPixelForValue(this.getBaseValue())}getBaseValue(){const{min:t,max:e}=this;return t<0&&e<0?e:t>0&&e>0?t:0}getContext(t){const e=this.ticks||[];if(t>=0&&to*s?o/i:r/s:r*s0}_computeGridLineItems(t){const e=this.axis,i=this.chart,s=this.options,{grid:n,position:a,border:o}=s,r=n.offset,l=this.isHorizontal(),h=this.ticks,c=h.length+(r?1:0),d=Fr(n),u=[],g=o.setContext(this.getContext()),p=g.display?g.width:0,f=p/2,m=function(t){return Ms(i,t,p)};let b,x,y,_,v,k,w,C,S,F,M,A;if("top"===a)b=m(this.bottom),k=this.bottom-d,C=b-f,F=m(t.top)+f,A=t.bottom;else if("bottom"===a)b=m(this.top),F=t.top,A=m(t.bottom)-f,k=b+f,C=this.top+d;else if("left"===a)b=m(this.right),v=this.right-d,w=b-f,S=m(t.left)+f,M=t.right;else if("right"===a)b=m(this.left),S=t.left,M=m(t.right)-f,v=b+f,w=this.left+d;else if("x"===e){if("center"===a)b=m((t.top+t.bottom)/2+.5);else if(ze(a)){const t=Object.keys(a)[0],e=a[t];b=m(this.chart.scales[t].getPixelForValue(e))}F=t.top,A=t.bottom,k=b+f,C=k+d}else if("y"===e){if("center"===a)b=m((t.left+t.right)/2);else if(ze(a)){const t=Object.keys(a)[0],e=a[t];b=m(this.chart.scales[t].getPixelForValue(e))}v=b-f,w=v-d,S=t.left,M=t.right}const T=$e(s.ticks.maxTicksLimit,c),P=Math.max(1,Math.ceil(c/T));for(x=0;x0&&(a-=s/2);break}d={left:a,top:n,width:s+e.width,height:i+e.height,color:t.backdropColor}}f.push({label:y,font:C,textOffset:M,options:{rotation:p,color:i,strokeColor:r,strokeWidth:h,textAlign:u,textBaseline:A,translation:[_,v],backdrop:d}})}return f}_getXAxisLabelAlignment(){const{position:t,ticks:e}=this.options,i=-Mi(this.labelRotation);if(i)return"top"===t?"left":"right";let s="center";return"start"===e.align?s="left":"end"===e.align?s="right":"inner"===e.align&&(s="inner"),s}_getYAxisLabelAlignment(t){const{position:e,ticks:{crossAlign:i,mirror:s,padding:n}}=this.options,a=this._getLabelSizes(),o=t+n,r=a.widest.width;let l,h;return"left"===e?s?(h=this.right+n,"near"===i?l="left":"center"===i?(l="center",h+=r/2):(l="right",h+=r)):(h=this.right-o,"near"===i?l="right":"center"===i?(l="center",h-=r/2):(l="left",h=this.left)):"right"===e?s?(h=this.left+n,"near"===i?l="right":"center"===i?(l="center",h-=r/2):(l="left",h-=r)):(h=this.left+o,"near"===i?l="left":"center"===i?(l="center",h+=r/2):(l="right",h=this.right)):l="right",{textAlign:l,x:h}}_computeLabelArea(){if(this.options.ticks.mirror)return;const t=this.chart,e=this.options.position;return"left"===e||"right"===e?{top:0,left:this.left,bottom:t.height,right:this.right}:"top"===e||"bottom"===e?{top:this.top,left:0,bottom:this.bottom,right:t.width}:void 0}drawBackground(){const{ctx:t,options:{backgroundColor:e},left:i,top:s,width:n,height:a}=this;e&&(t.save(),t.fillStyle=e,t.fillRect(i,s,n,a),t.restore())}getLineWidthForValue(t){const e=this.options.grid;if(!this._isVisible()||!e.display)return 0;const i=this.ticks,s=i.findIndex(e=>e.value===t);if(s>=0){const t=e.setContext(this.getContext(s));return t.lineWidth}return 0}drawGrid(t){const e=this.options.grid,i=this.ctx,s=this._gridLineItems||(this._gridLineItems=this._computeGridLineItems(t));let n,a;const o=(t,e,s)=>{s.width&&s.color&&(i.save(),i.lineWidth=s.width,i.strokeStyle=s.color,i.setLineDash(s.borderDash||[]),i.lineDashOffset=s.borderDashOffset,i.beginPath(),i.moveTo(t.x,t.y),i.lineTo(e.x,e.y),i.stroke(),i.restore())};if(e.display)for(n=0,a=s.length;n{this.drawBackground(),this.drawGrid(t),this.drawTitle()}},{z:s,draw:()=>{this.drawBorder()}},{z:e,draw:t=>{this.drawLabels(t)}}]:[{z:e,draw:t=>{this.draw(t)}}]}getMatchingVisibleMetas(t){const e=this.chart.getSortedVisibleDatasetMetas(),i=this.axis+"AxisID",s=[];let n,a;for(n=0,a=e.length;n{const s=i.split("."),n=s.pop(),a=[t].concat(s).join("."),o=e[i].split("."),r=o.pop(),l=o.join(".");ws.route(a,n,l,r)})}function Or(t){return"id"in t&&"defaults"in t}class Rr{constructor(){this.controllers=new Lr(Ua,"datasets",!0),this.elements=new Lr(ur,"elements"),this.plugins=new Lr(Object,"plugins"),this.scales=new Lr(Er,"scales"),this._typedRegistries=[this.controllers,this.scales,this.elements]}add(...t){this._each("register",t)}remove(...t){this._each("unregister",t)}addControllers(...t){this._each("register",t,this.controllers)}addElements(...t){this._each("register",t,this.elements)}addPlugins(...t){this._each("register",t,this.plugins)}addScales(...t){this._each("register",t,this.scales)}getController(t){return this._get(t,this.controllers,"controller")}getElement(t){return this._get(t,this.elements,"element")}getPlugin(t){return this._get(t,this.plugins,"plugin")}getScale(t){return this._get(t,this.scales,"scale")}removeControllers(...t){this._each("unregister",t,this.controllers)}removeElements(...t){this._each("unregister",t,this.elements)}removePlugins(...t){this._each("unregister",t,this.plugins)}removeScales(...t){this._each("unregister",t,this.scales)}_each(t,e,i){[...e].forEach(e=>{const s=i||this._getRegistryForType(e);i||s.isForType(e)||s===this.plugins&&e.id?this._exec(t,s,e):qe(e,e=>{const s=i||this._getRegistryForType(e);this._exec(t,s,e)})})}_exec(t,e,i){const s=ai(t);Xe(i["before"+s],[],i),e[t](i),Xe(i["after"+s],[],i)}_getRegistryForType(t){for(let e=0;et.filter(t=>!e.some(e=>t.plugin.id===e.plugin.id));this._notify(s(e,i),t,"stop"),this._notify(s(i,e),t,"start")}}function zr(t){const e={},i=[],s=Object.keys(Wr.plugins.items);for(let a=0;a1&&qr(t[0].toLowerCase());if(e)return e}throw new Error(`Cannot determine type of '${t}' axis. Please provide 'axis' or 'position' option.`)}function Qr(t,e,i){if(i[e+"AxisID"]===t)return{axis:e}}function Gr(t,e){if(e.data&&e.data.datasets){const i=e.data.datasets.filter(e=>e.xAxisID===t||e.yAxisID===t);if(i.length)return Qr(t,"x",i[0])||Qr(t,"y",i[0])}return{}}function Jr(t,e){const i=xs[t.type]||{scales:{}},s=e.scales||{},n=jr(t.type,e),a=Object.create(null);return Object.keys(s).forEach(e=>{const o=s[e];if(!ze(o))return console.error(`Invalid scale configuration for scale: ${e}`);if(o._proxy)return console.warn(`Ignoring resolver passed as options for scale: ${e}`);const r=Yr(e,o,Gr(e,t),ws.scales[o.type]),l=Xr(r,n),h=i.scales||{};a[e]=Ze(Object.create(null),[{axis:r},o,h[r],h[l]])}),t.data.datasets.forEach(i=>{const n=i.type||t.type,o=i.indexAxis||jr(n,e),r=xs[n]||{},l=r.scales||{};Object.keys(l).forEach(t=>{const e=Hr(t,o),n=i[e+"AxisID"]||e;a[n]=a[n]||Object.create(null),Ze(a[n],[{axis:e},s[n],l[t]])})}),Object.keys(a).forEach(t=>{const e=a[t];Ze(e,[ws.scales[e.type],ws.scale])}),a}function Zr(t){const e=t.options||(t.options={});e.plugins=$e(e.plugins,{}),e.scales=Jr(t,e)}function tl(t){return t=t||{},t.datasets=t.datasets||[],t.labels=t.labels||[],t}function el(t){return t=t||{},t.data=tl(t.data),Zr(t),t}const il=new Map,sl=new Set;function nl(t,e){let i=il.get(t);return i||(i=e(),il.set(t,i),sl.add(i)),i}const al=(t,e,i)=>{const s=ni(e,i);void 0!==s&&t.add(s)};class ol{constructor(t){this._config=el(t),this._scopeCache=new Map,this._resolverCache=new Map}get platform(){return this._config.platform}get type(){return this._config.type}set type(t){this._config.type=t}get data(){return this._config.data}set data(t){this._config.data=tl(t)}get options(){return this._config.options}set options(t){this._config.options=t}get plugins(){return this._config.plugins}update(){const t=this._config;this.clearCache(),Zr(t)}clearCache(){this._scopeCache.clear(),this._resolverCache.clear()}datasetScopeKeys(t){return nl(t,()=>[[`datasets.${t}`,""]])}datasetAnimationScopeKeys(t,e){return nl(`${t}.transition.${e}`,()=>[[`datasets.${t}.transitions.${e}`,`transitions.${e}`],[`datasets.${t}`,""]])}datasetElementScopeKeys(t,e){return nl(`${t}-${e}`,()=>[[`datasets.${t}.elements.${e}`,`datasets.${t}`,`elements.${e}`,""]])}pluginScopeKeys(t){const e=t.id,i=this.type;return nl(`${i}-plugin-${e}`,()=>[[`plugins.${e}`,...t.additionalOptionScopes||[]]])}_cachedScopes(t,e){const i=this._scopeCache;let s=i.get(t);return s&&!e||(s=new Map,i.set(t,s)),s}getOptionScopes(t,e,i){const{options:s,type:n}=this,a=this._cachedScopes(t,i),o=a.get(e);if(o)return o;const r=new Set;e.forEach(e=>{t&&(r.add(t),e.forEach(e=>al(r,t,e))),e.forEach(t=>al(r,s,t)),e.forEach(t=>al(r,xs[n]||{},t)),e.forEach(t=>al(r,ws,t)),e.forEach(t=>al(r,ys,t))});const l=Array.from(r);return 0===l.length&&l.push(Object.create(null)),sl.has(e)&&a.set(e,l),l}chartOptionScopes(){const{options:t,type:e}=this;return[t,xs[e]||{},ws.datasets[e]||{},{type:e},ws,ys]}resolveNamedOptions(t,e,i,s=[""]){const n={$shared:!0},{resolver:a,subPrefixes:o}=rl(this._resolverCache,t,s);let r=a;if(hl(a,e)){n.$shared=!1,i=ri(i)?i():i;const e=this.createResolver(t,i,o);r=tn(a,i,e)}for(const l of e)n[l]=r[l];return n}createResolver(t,e,i=[""],s){const{resolver:n}=rl(this._resolverCache,t,i);return ze(e)?tn(n,e,void 0,s):n}}function rl(t,e,i){let s=t.get(e);s||(s=new Map,t.set(e,s));const n=i.join();let a=s.get(n);if(!a){const t=Zs(e,i);a={resolver:t,subPrefixes:i.filter(t=>!t.toLowerCase().includes("hover"))},s.set(n,a)}return a}const ll=t=>ze(t)&&Object.getOwnPropertyNames(t).some(e=>ri(t[e]));function hl(t,e){const{isScriptable:i,isIndexable:s}=en(t);for(const n of e){const e=i(n),a=s(n),o=(a||e)&&t[n];if(e&&(ri(o)||ll(o))||a&&Be(o))return!0}return!1}var cl="4.5.1";const dl=["top","bottom","left","right","chartArea"];function ul(t,e){return"top"===t||"bottom"===t||-1===dl.indexOf(t)&&"x"===e}function gl(t,e){return function(i,s){return i[t]===s[t]?i[e]-s[e]:i[t]-s[t]}}function pl(t){const e=t.chart,i=e.options.animation;e.notifyPlugins("afterRender"),Xe(i&&i.onComplete,[t],e)}function fl(t){const e=t.chart,i=e.options.animation;Xe(i&&i.onProgress,[t],e)}function ml(t){return Pn()&&"string"===typeof t?t=document.getElementById(t):t&&t.length&&(t=t[0]),t&&t.canvas&&(t=t.canvas),t}const bl={},xl=t=>{const e=ml(t);return Object.values(bl).filter(t=>t.canvas===e).pop()};function yl(t,e,i){const s=Object.keys(t);for(const n of s){const s=+n;if(s>=e){const a=t[n];delete t[n],(i>0||s>e)&&(t[s+i]=a)}}}function _l(t,e,i,s){return i&&"mouseout"!==t.type?s?e:t:null}class vl{static register(...t){Wr.add(...t),kl()}static unregister(...t){Wr.remove(...t),kl()}constructor(t,e){const i=this.config=new ol(e),s=ml(t),n=xl(s);if(n)throw new Error("Canvas is already in use. Chart with ID '"+n.id+"' must be destroyed before the canvas with ID '"+n.canvas.id+"' can be reused.");const a=i.createResolver(i.chartOptionScopes(),this.getContext());this.platform=new(i.platform||dr(s)),this.platform.updateConfig(i);const o=this.platform.acquireContext(s,a.aspectRatio),r=o&&o.canvas,l=r&&r.height,h=r&&r.width;this.id=Re(),this.ctx=o,this.canvas=r,this.width=h,this.height=l,this._options=a,this._aspectRatio=this.aspectRatio,this._layers=[],this._metasets=[],this._stacks=void 0,this.boxes=[],this.currentDevicePixelRatio=void 0,this.chartArea=void 0,this._active=[],this._lastEvent=void 0,this._listeners={},this._responsiveListeners=void 0,this._sortedMetasets=[],this.scales={},this._plugins=new Br,this.$proxies={},this._hiddenIndices={},this.attached=!1,this._animationsDisabled=void 0,this.$context=void 0,this._doResize=Ki(t=>this.update(t),a.resizeDelay||0),this._dataChanges=[],bl[this.id]=this,o&&r?(ma.listen(this,"complete",pl),ma.listen(this,"progress",fl),this._initialize(),this.attached&&this.update()):console.error("Failed to create chart: can't acquire context from the given item")}get aspectRatio(){const{options:{aspectRatio:t,maintainAspectRatio:e},width:i,height:s,_aspectRatio:n}=this;return We(t)?e&&n?n:s?i/s:null:t}get data(){return this.config.data}set data(t){this.config.data=t}get options(){return this._options}set options(t){this.config.options=t}get registry(){return Wr}_initialize(){return this.notifyPlugins("beforeInit"),this.options.responsive?this.resize():$n(this,this.options.devicePixelRatio),this.bindEvents(),this.notifyPlugins("afterInit"),this}clear(){return As(this.canvas,this.ctx),this}stop(){return ma.stop(this),this}resize(t,e){ma.running(this)?this._resizeBeforeDraw={width:t,height:e}:this._resize(t,e)}_resize(t,e){const i=this.options,s=this.canvas,n=i.maintainAspectRatio&&this.aspectRatio,a=this.platform.getMaximumSize(s,t,e,n),o=i.devicePixelRatio||this.platform.getDevicePixelRatio(),r=this.width?"resize":"attach";this.width=a.width,this.height=a.height,this._aspectRatio=this.aspectRatio,$n(this,o,!0)&&(this.notifyPlugins("resize",{size:a}),Xe(i.onResize,[this,a],this),this.attached&&this._doResize(r)&&this.render())}ensureScalesHaveIDs(){const t=this.options,e=t.scales||{};qe(e,(t,e)=>{t.id=e})}buildOrUpdateScales(){const t=this.options,e=t.scales,i=this.scales,s=Object.keys(i).reduce((t,e)=>(t[e]=!1,t),{});let n=[];e&&(n=n.concat(Object.keys(e).map(t=>{const i=e[t],s=Yr(t,i),n="r"===s,a="x"===s;return{options:i,dposition:n?"chartArea":a?"bottom":"left",dtype:n?"radialLinear":a?"category":"linear"}}))),qe(n,e=>{const n=e.options,a=n.id,o=Yr(a,n),r=$e(n.type,e.dtype);void 0!==n.position&&ul(n.position,o)===ul(e.dposition)||(n.position=e.dposition),s[a]=!0;let l=null;if(a in i&&i[a].type===r)l=i[a];else{const t=Wr.getScale(r);l=new t({id:a,type:r,ctx:this.ctx,chart:this}),i[l.id]=l}l.init(n,t)}),qe(s,(t,e)=>{t||delete i[e]}),qe(i,t=>{Uo.configure(this,t,t.options),Uo.addBox(this,t)})}_updateMetasets(){const t=this._metasets,e=this.data.datasets.length,i=t.length;if(t.sort((t,e)=>t.index-e.index),i>e){for(let t=e;te.length&&delete this._stacks,t.forEach((t,i)=>{0===e.filter(e=>e===t._dataset).length&&this._destroyDatasetMeta(i)})}buildOrUpdateControllers(){const t=[],e=this.data.datasets;let i,s;for(this._removeUnreferencedMetasets(),i=0,s=e.length;i{this.getDatasetMeta(e).controller.reset()},this)}reset(){this._resetElements(),this.notifyPlugins("reset")}update(t){const e=this.config;e.update();const i=this._options=e.createResolver(e.chartOptionScopes(),this.getContext()),s=this._animationsDisabled=!i.animation;if(this._updateScales(),this._checkEventBindings(),this._updateHiddenIndices(),this._plugins.invalidate(),!1===this.notifyPlugins("beforeUpdate",{mode:t,cancelable:!0}))return;const n=this.buildOrUpdateControllers();this.notifyPlugins("beforeElementsUpdate");let a=0;for(let l=0,h=this.data.datasets.length;l{t.reset()}),this._updateDatasets(t),this.notifyPlugins("afterUpdate",{mode:t}),this._layers.sort(gl("z","_idx"));const{_active:o,_lastEvent:r}=this;r?this._eventHandler(r,!0):o.length&&this._updateHoverStyles(o,o,!0),this.render()}_updateScales(){qe(this.scales,t=>{Uo.removeBox(this,t)}),this.ensureScalesHaveIDs(),this.buildOrUpdateScales()}_checkEventBindings(){const t=this.options,e=new Set(Object.keys(this._listeners)),i=new Set(t.events);li(e,i)&&!!this._responsiveListeners===t.responsive||(this.unbindEvents(),this.bindEvents())}_updateHiddenIndices(){const{_hiddenIndices:t}=this,e=this._getUniformDataChanges()||[];for(const{method:i,start:s,count:n}of e){const e="_removeElements"===i?-n:n;yl(t,s,e)}}_getUniformDataChanges(){const t=this._dataChanges;if(!t||!t.length)return;this._dataChanges=[];const e=this.data.datasets.length,i=e=>new Set(t.filter(t=>t[0]===e).map((t,e)=>e+","+t.splice(1).join(","))),s=i(0);for(let n=1;nt.split(",")).map(t=>({method:t[1],start:+t[2],count:+t[3]}))}_updateLayout(t){if(!1===this.notifyPlugins("beforeLayout",{cancelable:!0}))return;Uo.update(this,this.width,this.height,t);const e=this.chartArea,i=e.width<=0||e.height<=0;this._layers=[],qe(this.boxes,t=>{i&&"chartArea"===t.position||(t.configure&&t.configure(),this._layers.push(...t._layers()))},this),this._layers.forEach((t,e)=>{t._idx=e}),this.notifyPlugins("afterLayout")}_updateDatasets(t){if(!1!==this.notifyPlugins("beforeDatasetsUpdate",{mode:t,cancelable:!0})){for(let t=0,e=this.data.datasets.length;t=0;--e)this._drawDataset(t[e]);this.notifyPlugins("afterDatasetsDraw")}_drawDataset(t){const e=this.ctx,i={meta:t,index:t.index,cancelable:!0},s=pa(this,t);!1!==this.notifyPlugins("beforeDatasetDraw",i)&&(s&&Es(e,s),t.controller.draw(),s&&Ls(e),i.cancelable=!1,this.notifyPlugins("afterDatasetDraw",i))}isPointInArea(t){return Ds(t,this.chartArea,this._minPadding)}getElementsAtEventForMode(t,e,i,s){const n=So.modes[e];return"function"===typeof n?n(this,t,i,s):[]}getDatasetMeta(t){const e=this.data.datasets[t],i=this._metasets;let s=i.filter(t=>t&&t._dataset===e).pop();return s||(s={type:null,data:[],dataset:null,controller:null,hidden:null,xAxisID:null,yAxisID:null,order:e&&e.order||0,index:t,_dataset:e,_parsed:[],_sorted:!1},i.push(s)),s}getContext(){return this.$context||(this.$context=Js(null,{chart:this,type:"chart"}))}getVisibleDatasetCount(){return this.getSortedVisibleDatasetMetas().length}isDatasetVisible(t){const e=this.data.datasets[t];if(!e)return!1;const i=this.getDatasetMeta(t);return"boolean"===typeof i.hidden?!i.hidden:!e.hidden}setDatasetVisibility(t,e){const i=this.getDatasetMeta(t);i.hidden=!e}toggleDataVisibility(t){this._hiddenIndices[t]=!this._hiddenIndices[t]}getDataVisibility(t){return!this._hiddenIndices[t]}_updateVisibility(t,e,i){const s=i?"show":"hide",n=this.getDatasetMeta(t),a=n.controller._resolveAnimations(void 0,s);oi(e)?(n.data[e].hidden=!i,this.update()):(this.setDatasetVisibility(t,i),a.update(n,{visible:i}),this.update(e=>e.datasetIndex===t?s:void 0))}hide(t,e){this._updateVisibility(t,e,!1)}show(t,e){this._updateVisibility(t,e,!0)}_destroyDatasetMeta(t){const e=this._metasets[t];e&&e.controller&&e.controller._destroy(),delete this._metasets[t]}_stop(){let t,e;for(this.stop(),ma.remove(this),t=0,e=this.data.datasets.length;t{e.addEventListener(this,i,s),t[i]=s},s=(t,e,i)=>{t.offsetX=e,t.offsetY=i,this._eventHandler(t)};qe(this.options.events,t=>i(t,s))}bindResponsiveEvents(){this._responsiveListeners||(this._responsiveListeners={});const t=this._responsiveListeners,e=this.platform,i=(i,s)=>{e.addEventListener(this,i,s),t[i]=s},s=(i,s)=>{t[i]&&(e.removeEventListener(this,i,s),delete t[i])},n=(t,e)=>{this.canvas&&this.resize(t,e)};let a;const o=()=>{s("attach",o),this.attached=!0,this.resize(),i("resize",n),i("detach",a)};a=()=>{this.attached=!1,s("resize",n),this._stop(),this._resize(0,0),i("attach",o)},e.isAttached(this.canvas)?o():a()}unbindEvents(){qe(this._listeners,(t,e)=>{this.platform.removeEventListener(this,e,t)}),this._listeners={},qe(this._responsiveListeners,(t,e)=>{this.platform.removeEventListener(this,e,t)}),this._responsiveListeners=void 0}updateHoverStyle(t,e,i){const s=i?"set":"remove";let n,a,o,r;for("dataset"===e&&(n=this.getDatasetMeta(t[0].datasetIndex),n.controller["_"+s+"DatasetHoverStyle"]()),o=0,r=t.length;o{const i=this.getDatasetMeta(t);if(!i)throw new Error("No dataset found at index "+t);return{datasetIndex:t,element:i.data[e],index:e}}),s=!Ke(i,e);s&&(this._active=i,this._lastEvent=null,this._updateHoverStyles(i,e))}notifyPlugins(t,e,i){return this._plugins.notify(this,t,e,i)}isPluginEnabled(t){return 1===this._plugins._cache.filter(e=>e.plugin.id===t).length}_updateHoverStyles(t,e,i){const s=this.options.hover,n=(t,e)=>t.filter(t=>!e.some(e=>t.datasetIndex===e.datasetIndex&&t.index===e.index)),a=n(e,t),o=i?t:n(t,e);a.length&&this.updateHoverStyle(a,s.mode,!1),o.length&&s.mode&&this.updateHoverStyle(o,s.mode,!0)}_eventHandler(t,e){const i={event:t,replay:e,cancelable:!0,inChartArea:this.isPointInArea(t)},s=e=>(e.options.events||this.options.events).includes(t.native.type);if(!1===this.notifyPlugins("beforeEvent",i,s))return;const n=this._handleEvent(t,e,i.inChartArea);return i.cancelable=!1,this.notifyPlugins("afterEvent",i,s),(n||i.changed)&&this.render(),this}_handleEvent(t,e,i){const{_active:s=[],options:n}=this,a=e,o=this._getActiveElements(t,s,i,a),r=hi(t),l=_l(t,this._lastEvent,i,r);i&&(this._lastEvent=null,Xe(n.onHover,[t,o,this],this),r&&Xe(n.onClick,[t,o,this],this));const h=!Ke(o,s);return(h||e)&&(this._active=o,this._updateHoverStyles(o,s,e)),this._lastEvent=l,h}_getActiveElements(t,e,i,s){if("mouseout"===t.type)return[];if(!i)return e;const n=this.options.hover;return this.getElementsAtEventForMode(t,n.mode,n,s)}}function kl(){return qe(vl.instances,t=>t._plugins.invalidate())}function wl(t,e,i){const{startAngle:s,x:n,y:a,outerRadius:o,innerRadius:r,options:l}=e,{borderWidth:h,borderJoinStyle:c}=l,d=Math.min(h/o,Li(s-i));if(t.beginPath(),t.arc(n,a,o-h/2,s+d/2,i-d/2),r>0){const e=Math.min(h/r,Li(s-i));t.arc(n,a,r+h/2,i-e/2,s+e/2,!0)}else{const e=Math.min(h/2,o*Li(s-i));if("round"===c)t.arc(n,a,e,i-ci/2,s+ci/2,!0);else if("bevel"===c){const o=2*e*e,r=-o*Math.cos(i+ci/2)+n,l=-o*Math.sin(i+ci/2)+a,h=o*Math.cos(s+ci/2)+n,c=o*Math.sin(s+ci/2)+a;t.lineTo(r,l),t.lineTo(h,c)}}t.closePath(),t.moveTo(0,0),t.rect(0,0,t.canvas.width,t.canvas.height),t.clip("evenodd")}function Cl(t,e,i){const{startAngle:s,pixelMargin:n,x:a,y:o,outerRadius:r,innerRadius:l}=e;let h=n/r;t.beginPath(),t.arc(a,o,r,s-h,i+h),l>n?(h=n/l,t.arc(a,o,l,i+h,s-h,!0)):t.arc(a,o,n,i+fi,s-fi),t.closePath(),t.clip()}function Sl(t){return Hs(t,["outerStart","outerEnd","innerStart","innerEnd"])}function Fl(t,e,i,s){const n=Sl(t.options.borderRadius),a=(i-e)/2,o=Math.min(a,s*e/2),r=t=>{const e=(i-Math.min(a,t))*s/2;return Vi(t,0,Math.min(a,e))};return{outerStart:r(n.outerStart),outerEnd:r(n.outerEnd),innerStart:Vi(n.innerStart,0,o),innerEnd:Vi(n.innerEnd,0,o)}}function Ml(t,e,i,s){return{x:i+t*Math.cos(e),y:s+t*Math.sin(e)}}function Al(t,e,i,s,n,a){const{x:o,y:r,startAngle:l,pixelMargin:h,innerRadius:c}=e,d=Math.max(e.outerRadius+s+i-h,0),u=c>0?c+s+i+h:0;let g=0;const p=n-l;if(s){const t=c>0?c-s:0,e=d>0?d-s:0,i=(t+e)/2,n=0!==i?p*i/(i+s):p;g=(p-n)/2}const f=Math.max(.001,p*d-i/ci)/d,m=(p-f)/2,b=l+m+g,x=n-m-g,{outerStart:y,outerEnd:_,innerStart:v,innerEnd:k}=Fl(e,u,d,x-b),w=d-y,C=d-_,S=b+y/w,F=x-_/C,M=u+v,A=u+k,T=b+v/M,P=x-k/A;if(t.beginPath(),a){const e=(S+F)/2;if(t.arc(o,r,d,S,e),t.arc(o,r,d,e,F),_>0){const e=Ml(C,F,o,r);t.arc(e.x,e.y,_,F,x+fi)}const i=Ml(A,x,o,r);if(t.lineTo(i.x,i.y),k>0){const e=Ml(A,P,o,r);t.arc(e.x,e.y,k,x+fi,P+Math.PI)}const s=(x-k/u+(b+v/u))/2;if(t.arc(o,r,u,x-k/u,s,!0),t.arc(o,r,u,s,b+v/u,!0),v>0){const e=Ml(M,T,o,r);t.arc(e.x,e.y,v,T+Math.PI,b-fi)}const n=Ml(w,b,o,r);if(t.lineTo(n.x,n.y),y>0){const e=Ml(w,S,o,r);t.arc(e.x,e.y,y,b-fi,S)}}else{t.moveTo(o,r);const e=Math.cos(S)*d+o,i=Math.sin(S)*d+r;t.lineTo(e,i);const s=Math.cos(F)*d+o,n=Math.sin(F)*d+r;t.lineTo(s,n)}t.closePath()}function Tl(t,e,i,s,n){const{fullCircles:a,startAngle:o,circumference:r}=e;let l=e.endAngle;if(a){Al(t,e,i,s,l,n);for(let e=0;e=ci&&0===g&&"miter"!==c&&wl(t,e,f),a||(Al(t,e,i,s,f,n),t.stroke())}(0,jt.A)(vl,"defaults",ws),(0,jt.A)(vl,"instances",bl),(0,jt.A)(vl,"overrides",xs),(0,jt.A)(vl,"registry",Wr),(0,jt.A)(vl,"version",cl),(0,jt.A)(vl,"getChart",xl);class Dl extends ur{constructor(t){super(),(0,jt.A)(this,"circumference",void 0),(0,jt.A)(this,"endAngle",void 0),(0,jt.A)(this,"fullCircles",void 0),(0,jt.A)(this,"innerRadius",void 0),(0,jt.A)(this,"outerRadius",void 0),(0,jt.A)(this,"pixelMargin",void 0),(0,jt.A)(this,"startAngle",void 0),this.options=void 0,this.circumference=void 0,this.startAngle=void 0,this.endAngle=void 0,this.innerRadius=void 0,this.outerRadius=void 0,this.pixelMargin=0,this.fullCircles=0,t&&Object.assign(this,t)}inRange(t,e,i){const s=this.getProps(["x","y"],i),{angle:n,distance:a}=Pi(s,{x:t,y:e}),{startAngle:o,endAngle:r,innerRadius:l,outerRadius:h,circumference:c}=this.getProps(["startAngle","endAngle","innerRadius","outerRadius","circumference"],i),d=(this.options.spacing+this.options.borderWidth)/2,u=$e(c,r-o),g=Ii(n,o,r)&&o!==r,p=u>=di||g,f=Ri(a,l+d,h+d);return p&&f}getCenterPoint(t){const{x:e,y:i,startAngle:s,endAngle:n,innerRadius:a,outerRadius:o}=this.getProps(["x","y","startAngle","endAngle","innerRadius","outerRadius"],t),{offset:r,spacing:l}=this.options,h=(s+n)/2,c=(a+o+l+r)/2;return{x:e+Math.cos(h)*c,y:i+Math.sin(h)*c}}tooltipPosition(t){return this.getCenterPoint(t)}draw(t){const{options:e,circumference:i}=this,s=(e.offset||0)/4,n=(e.spacing||0)/2,a=e.circular;if(this.pixelMargin="inner"===e.borderAlign?.33:0,this.fullCircles=i>di?Math.floor(i/di):0,0===i||this.innerRadius<0||this.outerRadius<0)return;t.save();const o=(this.startAngle+this.endAngle)/2;t.translate(Math.cos(o)*s,Math.sin(o)*s);const r=1-Math.sin(Math.min(ci,i||0)),l=s*r;t.fillStyle=e.backgroundColor,t.strokeStyle=e.borderColor,Tl(t,this,l,n,a),Pl(t,this,l,n,a),t.restore()}}function El(t,e,i=e){t.lineCap=$e(i.borderCapStyle,e.borderCapStyle),t.setLineDash($e(i.borderDash,e.borderDash)),t.lineDashOffset=$e(i.borderDashOffset,e.borderDashOffset),t.lineJoin=$e(i.borderJoinStyle,e.borderJoinStyle),t.lineWidth=$e(i.borderWidth,e.borderWidth),t.strokeStyle=$e(i.borderColor,e.borderColor)}function Ll(t,e,i){t.lineTo(i.x,i.y)}function Il(t){return t.stepped?Is:t.tension||"monotone"===t.cubicInterpolationMode?Vs:Ll}function Vl(t,e,i={}){const s=t.length,{start:n=0,end:a=s-1}=i,{start:o,end:r}=e,l=Math.max(n,o),h=Math.min(a,r),c=nr&&a>r;return{count:s,start:l,loop:e.loop,ilen:h(o+(h?r-t:t))%a,y=()=>{g!==p&&(t.lineTo(m,p),t.lineTo(m,g),t.lineTo(m,f))};for(l&&(d=n[x(0)],t.moveTo(d.x,d.y)),c=0;c<=r;++c){if(d=n[x(c)],d.skip)continue;const e=d.x,i=d.y,s=0|e;s===u?(ip&&(p=i),m=(b*m+e)/++b):(y(),t.lineTo(e,i),u=s,b=0,g=p=i),f=i}y()}function Wl(t){const e=t.options,i=e.borderDash&&e.borderDash.length,s=!t._decimated&&!t._loop&&!e.tension&&"monotone"!==e.cubicInterpolationMode&&!e.stepped&&!i;return s?Rl:Ol}function Bl(t){return t.stepped?qn:t.tension||"monotone"===t.cubicInterpolationMode?Kn:Xn}function zl(t,e,i,s){let n=e._path;n||(n=e._path=new Path2D,e.path(n,i,s)&&n.closePath()),El(t,e.options),t.stroke(n)}function Nl(t,e,i,s){const{segments:n,options:a}=e,o=Wl(e);for(const r of n)El(t,a,r.style),t.beginPath(),o(t,e,r,{start:i,end:i+s-1})&&t.closePath(),t.stroke()}(0,jt.A)(Dl,"id","arc"),(0,jt.A)(Dl,"defaults",{borderAlign:"center",borderColor:"#fff",borderDash:[],borderDashOffset:0,borderJoinStyle:void 0,borderRadius:0,borderWidth:2,offset:0,spacing:0,angle:void 0,circular:!0,selfJoin:!1}),(0,jt.A)(Dl,"defaultRoutes",{backgroundColor:"backgroundColor"}),(0,jt.A)(Dl,"descriptors",{_scriptable:!0,_indexable:t=>"borderDash"!==t});const Ul="function"===typeof Path2D;function $l(t,e,i,s){Ul&&!e.options.segment?zl(t,e,i,s):Nl(t,e,i,s)}class jl extends ur{constructor(t){super(),this.animated=!0,this.options=void 0,this._chart=void 0,this._loop=void 0,this._fullLoop=void 0,this._path=void 0,this._points=void 0,this._segments=void 0,this._decimated=!1,this._pointsUpdated=!1,this._datasetIndex=void 0,t&&Object.assign(this,t)}updateControlPoints(t,e){const i=this.options;if((i.tension||"monotone"===i.cubicInterpolationMode)&&!i.stepped&&!this._pointsUpdated){const s=i.spanGaps?this._loop:this._fullLoop;Tn(this._points,i,t,s,e),this._pointsUpdated=!0}}set points(t){this._points=t,delete this._segments,delete this._path,this._pointsUpdated=!1}get points(){return this._points}get segments(){return this._segments||(this._segments=ra(this,this.options.segment))}first(){const t=this.segments,e=this.points;return t.length&&e[t[0].start]}last(){const t=this.segments,e=this.points,i=t.length;return i&&e[t[i-1].end]}interpolate(t,e){const i=this.options,s=t[e],n=this.points,a=na(this,{property:e,start:s,end:s});if(!a.length)return;const o=[],r=Bl(i);let l,h;for(l=0,h=a.length;l"borderDash"!==t&&"fill"!==t});class Xl extends ur{constructor(t){super(),(0,jt.A)(this,"parsed",void 0),(0,jt.A)(this,"skip",void 0),(0,jt.A)(this,"stop",void 0),this.options=void 0,this.parsed=void 0,this.skip=void 0,this.stop=void 0,t&&Object.assign(this,t)}inRange(t,e,i){const s=this.options,{x:n,y:a}=this.getProps(["x","y"],i);return Math.pow(t-n,2)+Math.pow(e-a,2){let{boxHeight:i=e,boxWidth:s=e}=t;return t.usePointStyle&&(i=Math.min(i,e),s=t.pointStyleWidth||Math.min(s,e)),{boxWidth:s,boxHeight:i,itemHeight:Math.max(e,i)}},nh=(t,e)=>null!==t&&null!==e&&t.datasetIndex===e.datasetIndex&&t.index===e.index;class ah extends ur{constructor(t){super(),this._added=!1,this.legendHitBoxes=[],this._hoveredItem=null,this.doughnutMode=!1,this.chart=t.chart,this.options=t.options,this.ctx=t.ctx,this.legendItems=void 0,this.columnSizes=void 0,this.lineWidths=void 0,this.maxHeight=void 0,this.maxWidth=void 0,this.top=void 0,this.bottom=void 0,this.left=void 0,this.right=void 0,this.height=void 0,this.width=void 0,this._margins=void 0,this.position=void 0,this.weight=void 0,this.fullSize=void 0}update(t,e,i){this.maxWidth=t,this.maxHeight=e,this._margins=i,this.setDimensions(),this.buildLabels(),this.fit()}setDimensions(){this.isHorizontal()?(this.width=this.maxWidth,this.left=this._margins.left,this.right=this.width):(this.height=this.maxHeight,this.top=this._margins.top,this.bottom=this.height)}buildLabels(){const t=this.options.labels||{};let e=Xe(t.generateLabels,[this.chart],this)||[];t.filter&&(e=e.filter(e=>t.filter(e,this.chart.data))),t.sort&&(e=e.sort((e,i)=>t.sort(e,i,this.chart.data))),this.options.reverse&&e.reverse(),this.legendItems=e}fit(){const{options:t,ctx:e}=this;if(!t.display)return void(this.width=this.height=0);const i=t.labels,s=Ys(i.font),n=s.size,a=this._computeTitleHeight(),{boxWidth:o,itemHeight:r}=sh(i,n);let l,h;e.font=s.string,this.isHorizontal()?(l=this.maxWidth,h=this._fitRows(a,n,o,r)+10):(h=this.maxHeight,l=this._fitCols(a,s,o,r)+10),this.width=Math.min(l,t.maxWidth||this.maxWidth),this.height=Math.min(h,t.maxHeight||this.maxHeight)}_fitRows(t,e,i,s){const{ctx:n,maxWidth:a,options:{labels:{padding:o}}}=this,r=this.legendHitBoxes=[],l=this.lineWidths=[0],h=s+o;let c=t;n.textAlign="left",n.textBaseline="middle";let d=-1,u=-h;return this.legendItems.forEach((t,g)=>{const p=i+e/2+n.measureText(t.text).width;(0===g||l[l.length-1]+p+2*o>a)&&(c+=h,l[l.length-(g>0?0:1)]=0,u+=h,d++),r[g]={left:0,top:u,row:d,width:p,height:s},l[l.length-1]+=p+o}),c}_fitCols(t,e,i,s){const{ctx:n,maxHeight:a,options:{labels:{padding:o}}}=this,r=this.legendHitBoxes=[],l=this.columnSizes=[],h=a-t;let c=o,d=0,u=0,g=0,p=0;return this.legendItems.forEach((t,a)=>{const{itemWidth:f,itemHeight:m}=oh(i,e,n,t,s);a>0&&u+m+2*o>h&&(c+=d+o,l.push({width:d,height:u}),g+=d+o,p++,d=u=0),r[a]={left:g,top:u,col:p,width:f,height:m},d=Math.max(d,f),u+=m+o}),c+=d,l.push({width:d,height:u}),c}adjustHitBoxes(){if(!this.options.display)return;const t=this._computeTitleHeight(),{legendHitBoxes:e,options:{align:i,labels:{padding:s},rtl:n}}=this,a=Gn(n,this.left,this.width);if(this.isHorizontal()){let n=0,o=Qi(i,this.left+s,this.right-this.lineWidths[n]);for(const r of e)n!==r.row&&(n=r.row,o=Qi(i,this.left+s,this.right-this.lineWidths[n])),r.top+=this.top+t+s,r.left=a.leftForLtr(a.x(o),r.width),o+=r.width+s}else{let n=0,o=Qi(i,this.top+t+s,this.bottom-this.columnSizes[n].height);for(const r of e)r.col!==n&&(n=r.col,o=Qi(i,this.top+t+s,this.bottom-this.columnSizes[n].height)),r.top=o,r.left+=this.left+s,r.left=a.leftForLtr(a.x(r.left),r.width),o+=r.height+s}}isHorizontal(){return"top"===this.options.position||"bottom"===this.options.position}draw(){if(this.options.display){const t=this.ctx;Es(t,this),this._draw(),Ls(t)}}_draw(){const{options:t,columnSizes:e,lineWidths:i,ctx:s}=this,{align:n,labels:a}=t,o=ws.color,r=Gn(t.rtl,this.left,this.width),l=Ys(a.font),{padding:h}=a,c=l.size,d=c/2;let u;this.drawTitle(),s.textAlign=r.textAlign("left"),s.textBaseline="middle",s.lineWidth=.5,s.font=l.string;const{boxWidth:g,boxHeight:p,itemHeight:f}=sh(a,c),m=function(t,e,i){if(isNaN(g)||g<=0||isNaN(p)||p<0)return;s.save();const n=$e(i.lineWidth,1);if(s.fillStyle=$e(i.fillStyle,o),s.lineCap=$e(i.lineCap,"butt"),s.lineDashOffset=$e(i.lineDashOffset,0),s.lineJoin=$e(i.lineJoin,"miter"),s.lineWidth=n,s.strokeStyle=$e(i.strokeStyle,o),s.setLineDash($e(i.lineDash,[])),a.usePointStyle){const o={radius:p*Math.SQRT2/2,pointStyle:i.pointStyle,rotation:i.rotation,borderWidth:n},l=r.xPlus(t,g/2),h=e+d;Ps(s,o,l,h,a.pointStyleWidth&&g)}else{const a=e+Math.max((c-p)/2,0),o=r.leftForLtr(t,g),l=qs(i.borderRadius);s.beginPath(),Object.values(l).some(t=>0!==t)?zs(s,{x:o,y:a,w:g,h:p,radius:l}):s.rect(o,a,g,p),s.fill(),0!==n&&s.stroke()}s.restore()},b=function(t,e,i){Bs(s,i.text,t,e+f/2,l,{strikethrough:i.hidden,textAlign:r.textAlign(i.textAlign)})},x=this.isHorizontal(),y=this._computeTitleHeight();u=x?{x:Qi(n,this.left+h,this.right-i[0]),y:this.top+h+y,line:0}:{x:this.left+h,y:Qi(n,this.top+y+h,this.bottom-e[0].height),line:0},Jn(this.ctx,t.textDirection);const _=f+h;this.legendItems.forEach((o,c)=>{s.strokeStyle=o.fontColor,s.fillStyle=o.fontColor;const p=s.measureText(o.text).width,f=r.textAlign(o.textAlign||(o.textAlign=a.textAlign)),v=g+d+p;let k=u.x,w=u.y;r.setWidth(this.width),x?c>0&&k+v+h>this.right&&(w=u.y+=_,u.line++,k=u.x=Qi(n,this.left+h,this.right-i[u.line])):c>0&&w+_>this.bottom&&(k=u.x=k+e[u.line].width+h,u.line++,w=u.y=Qi(n,this.top+y+h,this.bottom-e[u.line].height));const C=r.x(k);if(m(C,w,o),k=Gi(f,k+g+d,x?k+v:this.right,t.rtl),b(r.x(k),w,o),x)u.x+=v+h;else if("string"!==typeof o.text){const t=l.lineHeight;u.y+=hh(o,t)+h}else u.y+=_}),Zn(this.ctx,t.textDirection)}drawTitle(){const t=this.options,e=t.title,i=Ys(e.font),s=Ks(e.padding);if(!e.display)return;const n=Gn(t.rtl,this.left,this.width),a=this.ctx,o=e.position,r=i.size/2,l=s.top+r;let h,c=this.left,d=this.width;if(this.isHorizontal())d=Math.max(...this.lineWidths),h=this.top+l,c=Qi(t.align,c,this.right-d);else{const e=this.columnSizes.reduce((t,e)=>Math.max(t,e.height),0);h=l+Qi(t.align,this.top,this.bottom-e-t.labels.padding-this._computeTitleHeight())}const u=Qi(o,c,c+d);a.textAlign=n.textAlign(Yi(o)),a.textBaseline="middle",a.strokeStyle=e.color,a.fillStyle=e.color,a.font=i.string,Bs(a,e.text,u,h,i)}_computeTitleHeight(){const t=this.options.title,e=Ys(t.font),i=Ks(t.padding);return t.display?e.lineHeight+i.height:0}_getLegendItemAt(t,e){let i,s,n;if(Ri(t,this.left,this.right)&&Ri(e,this.top,this.bottom))for(n=this.legendHitBoxes,i=0;it.length>e.length?t:e)),e+i.size/2+s.measureText(n).width}function lh(t,e,i){let s=t;return"string"!==typeof e.text&&(s=hh(e,i)),s}function hh(t,e){const i=t.text?t.text.length:0;return e*i}function ch(t,e){return!("mousemove"!==t&&"mouseout"!==t||!e.onHover&&!e.onLeave)||!(!e.onClick||"click"!==t&&"mouseup"!==t)}var dh={id:"legend",_element:ah,start(t,e,i){const s=t.legend=new ah({ctx:t.ctx,options:i,chart:t});Uo.configure(t,s,i),Uo.addBox(t,s)},stop(t){Uo.removeBox(t,t.legend),delete t.legend},beforeUpdate(t,e,i){const s=t.legend;Uo.configure(t,s,i),s.options=i},afterUpdate(t){const e=t.legend;e.buildLabels(),e.adjustHitBoxes()},afterEvent(t,e){e.replay||t.legend.handleEvent(e.event)},defaults:{display:!0,position:"top",align:"center",fullSize:!0,reverse:!1,weight:1e3,onClick(t,e,i){const s=e.datasetIndex,n=i.chart;n.isDatasetVisible(s)?(n.hide(s),e.hidden=!0):(n.show(s),e.hidden=!1)},onHover:null,onLeave:null,labels:{color:t=>t.chart.options.color,boxWidth:40,padding:10,generateLabels(t){const e=t.data.datasets,{labels:{usePointStyle:i,pointStyle:s,textAlign:n,color:a,useBorderRadius:o,borderRadius:r}}=t.legend.options;return t._getSortedDatasetMetas().map(t=>{const l=t.controller.getStyle(i?0:void 0),h=Ks(l.borderWidth);return{text:e[t.index].label,fillStyle:l.backgroundColor,fontColor:a,hidden:!t.visible,lineCap:l.borderCapStyle,lineDash:l.borderDash,lineDashOffset:l.borderDashOffset,lineJoin:l.borderJoinStyle,lineWidth:(h.width+h.height)/4,strokeStyle:l.borderColor,pointStyle:s||l.pointStyle,rotation:l.rotation,textAlign:n||l.textAlign,borderRadius:o&&(r||l.borderRadius),datasetIndex:t.index}},this)}},title:{color:t=>t.chart.options.color,display:!1,position:"center",text:""}},descriptors:{_scriptable:t=>!t.startsWith("on"),labels:{_scriptable:t=>!["generateLabels","filter","sort"].includes(t)}}};new WeakMap;const uh={average(t){if(!t.length)return!1;let e,i,s=new Set,n=0,a=0;for(e=0,i=t.length;et+e)/s.size;return{x:o,y:n/a}},nearest(t,e){if(!t.length)return!1;let i,s,n,a=e.x,o=e.y,r=Number.POSITIVE_INFINITY;for(i=0,s=t.length;i-1?t.split("\n"):t}function fh(t,e){const{element:i,datasetIndex:s,index:n}=e,a=t.getDatasetMeta(s).controller,{label:o,value:r}=a.getLabelAndValue(n);return{chart:t,label:o,parsed:a.getParsed(n),raw:t.data.datasets[s].data[n],formattedValue:r,dataset:a.getDataset(),dataIndex:n,datasetIndex:s,element:i}}function mh(t,e){const i=t.chart.ctx,{body:s,footer:n,title:a}=t,{boxWidth:o,boxHeight:r}=e,l=Ys(e.bodyFont),h=Ys(e.titleFont),c=Ys(e.footerFont),d=a.length,u=n.length,g=s.length,p=Ks(e.padding);let f=p.height,m=0,b=s.reduce((t,e)=>t+e.before.length+e.lines.length+e.after.length,0);if(b+=t.beforeBody.length+t.afterBody.length,d&&(f+=d*h.lineHeight+(d-1)*e.titleSpacing+e.titleMarginBottom),b){const t=e.displayColors?Math.max(r,l.lineHeight):l.lineHeight;f+=g*t+(b-g)*l.lineHeight+(b-1)*e.bodySpacing}u&&(f+=e.footerMarginTop+u*c.lineHeight+(u-1)*e.footerSpacing);let x=0;const y=function(t){m=Math.max(m,i.measureText(t).width+x)};return i.save(),i.font=h.string,qe(t.title,y),i.font=l.string,qe(t.beforeBody.concat(t.afterBody),y),x=e.displayColors?o+2+e.boxPadding:0,qe(s,t=>{qe(t.before,y),qe(t.lines,y),qe(t.after,y)}),x=0,i.font=c.string,qe(t.footer,y),i.restore(),m+=p.width,{width:m,height:f}}function bh(t,e){const{y:i,height:s}=e;return it.height-s/2?"bottom":"center"}function xh(t,e,i,s){const{x:n,width:a}=s,o=i.caretSize+i.caretPadding;return"left"===t&&n+a+o>e.width||("right"===t&&n-a-o<0||void 0)}function yh(t,e,i,s){const{x:n,width:a}=i,{width:o,chartArea:{left:r,right:l}}=t;let h="center";return"center"===s?h=n<=(r+l)/2?"left":"right":n<=a/2?h="left":n>=o-a/2&&(h="right"),xh(h,t,e,i)&&(h="center"),h}function _h(t,e,i){const s=i.yAlign||e.yAlign||bh(t,i);return{xAlign:i.xAlign||e.xAlign||yh(t,e,i,s),yAlign:s}}function vh(t,e){let{x:i,width:s}=t;return"right"===e?i-=s:"center"===e&&(i-=s/2),i}function kh(t,e,i){let{y:s,height:n}=t;return"top"===e?s+=i:s-="bottom"===e?n+i:n/2,s}function wh(t,e,i,s){const{caretSize:n,caretPadding:a,cornerRadius:o}=t,{xAlign:r,yAlign:l}=i,h=n+a,{topLeft:c,topRight:d,bottomLeft:u,bottomRight:g}=qs(o);let p=vh(e,r);const f=kh(e,l,h);return"center"===l?"left"===r?p+=h:"right"===r&&(p-=h):"left"===r?p-=Math.max(c,u)+n:"right"===r&&(p+=Math.max(d,g)+n),{x:Vi(p,0,s.width-e.width),y:Vi(f,0,s.height-e.height)}}function Ch(t,e,i){const s=Ks(i.padding);return"center"===e?t.x+t.width/2:"right"===e?t.x+t.width-s.right:t.x+s.left}function Sh(t){return gh([],ph(t))}function Fh(t,e,i){return Js(t,{tooltip:e,tooltipItems:i,type:"tooltip"})}function Mh(t,e){const i=e&&e.dataset&&e.dataset.tooltip&&e.dataset.tooltip.callbacks;return i?t.override(i):t}const Ah={beforeTitle:Oe,title(t){if(t.length>0){const e=t[0],i=e.chart.data.labels,s=i?i.length:0;if(this&&this.options&&"dataset"===this.options.mode)return e.dataset.label||"";if(e.label)return e.label;if(s>0&&e.dataIndex{const e={before:[],lines:[],after:[]},n=Mh(i,t);gh(e.before,ph(Th(n,"beforeLabel",this,t))),gh(e.lines,Th(n,"label",this,t)),gh(e.after,ph(Th(n,"afterLabel",this,t))),s.push(e)}),s}getAfterBody(t,e){return Sh(Th(e.callbacks,"afterBody",this,t))}getFooter(t,e){const{callbacks:i}=e,s=Th(i,"beforeFooter",this,t),n=Th(i,"footer",this,t),a=Th(i,"afterFooter",this,t);let o=[];return o=gh(o,ph(s)),o=gh(o,ph(n)),o=gh(o,ph(a)),o}_createItems(t){const e=this._active,i=this.chart.data,s=[],n=[],a=[];let o,r,l=[];for(o=0,r=e.length;ot.filter(e,s,n,i))),t.itemSort&&(l=l.sort((e,s)=>t.itemSort(e,s,i))),qe(l,e=>{const i=Mh(t.callbacks,e);s.push(Th(i,"labelColor",this,e)),n.push(Th(i,"labelPointStyle",this,e)),a.push(Th(i,"labelTextColor",this,e))}),this.labelColors=s,this.labelPointStyles=n,this.labelTextColors=a,this.dataPoints=l,l}update(t,e){const i=this.options.setContext(this.getContext()),s=this._active;let n,a=[];if(s.length){const t=uh[i.position].call(this,s,this._eventPosition);a=this._createItems(i),this.title=this.getTitle(a,i),this.beforeBody=this.getBeforeBody(a,i),this.body=this.getBody(a,i),this.afterBody=this.getAfterBody(a,i),this.footer=this.getFooter(a,i);const e=this._size=mh(this,i),o=Object.assign({},t,e),r=_h(this.chart,i,o),l=wh(i,o,r,this.chart);this.xAlign=r.xAlign,this.yAlign=r.yAlign,n={opacity:1,x:l.x,y:l.y,width:e.width,height:e.height,caretX:t.x,caretY:t.y}}else 0!==this.opacity&&(n={opacity:0});this._tooltipItems=a,this.$context=void 0,n&&this._resolveAnimations().update(this,n),t&&i.external&&i.external.call(this,{chart:this.chart,tooltip:this,replay:e})}drawCaret(t,e,i,s){const n=this.getCaretPosition(t,i,s);e.lineTo(n.x1,n.y1),e.lineTo(n.x2,n.y2),e.lineTo(n.x3,n.y3)}getCaretPosition(t,e,i){const{xAlign:s,yAlign:n}=this,{caretSize:a,cornerRadius:o}=i,{topLeft:r,topRight:l,bottomLeft:h,bottomRight:c}=qs(o),{x:d,y:u}=t,{width:g,height:p}=e;let f,m,b,x,y,_;return"center"===n?(y=u+p/2,"left"===s?(f=d,m=f-a,x=y+a,_=y-a):(f=d+g,m=f+a,x=y-a,_=y+a),b=f):(m="left"===s?d+Math.max(r,h)+a:"right"===s?d+g-Math.max(l,c)-a:this.caretX,"top"===n?(x=u,y=x-a,f=m-a,b=m+a):(x=u+p,y=x+a,f=m+a,b=m-a),_=x),{x1:f,x2:m,x3:b,y1:x,y2:y,y3:_}}drawTitle(t,e,i){const s=this.title,n=s.length;let a,o,r;if(n){const l=Gn(i.rtl,this.x,this.width);for(t.x=Ch(this,i.titleAlign,i),e.textAlign=l.textAlign(i.titleAlign),e.textBaseline="middle",a=Ys(i.titleFont),o=i.titleSpacing,e.fillStyle=i.titleColor,e.font=a.string,r=0;r0!==t)?(t.beginPath(),t.fillStyle=n.multiKeyBackground,zs(t,{x:e,y:g,w:l,h:r,radius:o}),t.fill(),t.stroke(),t.fillStyle=a.backgroundColor,t.beginPath(),zs(t,{x:i,y:g+1,w:l-2,h:r-2,radius:o}),t.fill()):(t.fillStyle=n.multiKeyBackground,t.fillRect(e,g,l,r),t.strokeRect(e,g,l,r),t.fillStyle=a.backgroundColor,t.fillRect(i,g+1,l-2,r-2))}t.fillStyle=this.labelTextColors[i]}drawBody(t,e,i){const{body:s}=this,{bodySpacing:n,bodyAlign:a,displayColors:o,boxHeight:r,boxWidth:l,boxPadding:h}=i,c=Ys(i.bodyFont);let d=c.lineHeight,u=0;const g=Gn(i.rtl,this.x,this.width),p=function(i){e.fillText(i,g.x(t.x+u),t.y+d/2),t.y+=d+n},f=g.textAlign(a);let m,b,x,y,_,v,k;for(e.textAlign=a,e.textBaseline="middle",e.font=c.string,t.x=Ch(this,f,i),e.fillStyle=i.bodyColor,qe(this.beforeBody,p),u=o&&"right"!==f?"center"===a?l/2+h:l+2+h:0,y=0,v=s.length;y0&&e.stroke()}_updateAnimationTarget(t){const e=this.chart,i=this.$animations,s=i&&i.x,n=i&&i.y;if(s||n){const i=uh[t.position].call(this,this._active,this._eventPosition);if(!i)return;const a=this._size=mh(this,t),o=Object.assign({},i,this._size),r=_h(e,t,o),l=wh(t,o,r,e);s._to===l.x&&n._to===l.y||(this.xAlign=r.xAlign,this.yAlign=r.yAlign,this.width=a.width,this.height=a.height,this.caretX=i.x,this.caretY=i.y,this._resolveAnimations().update(this,l))}}_willRender(){return!!this.opacity}draw(t){const e=this.options.setContext(this.getContext());let i=this.opacity;if(!i)return;this._updateAnimationTarget(e);const s={width:this.width,height:this.height},n={x:this.x,y:this.y};i=Math.abs(i)<.001?0:i;const a=Ks(e.padding),o=this.title.length||this.beforeBody.length||this.body.length||this.afterBody.length||this.footer.length;e.enabled&&o&&(t.save(),t.globalAlpha=i,this.drawBackground(n,t,s,e),Jn(t,e.textDirection),n.y+=a.top,this.drawTitle(n,t,e),this.drawBody(n,t,e),this.drawFooter(n,t,e),Zn(t,e.textDirection),t.restore())}getActiveElements(){return this._active||[]}setActiveElements(t,e){const i=this._active,s=t.map(({datasetIndex:t,index:e})=>{const i=this.chart.getDatasetMeta(t);if(!i)throw new Error("Cannot find a dataset at index "+t);return{datasetIndex:t,element:i.data[e],index:e}}),n=!Ke(i,s),a=this._positionChanged(s,e);(n||a)&&(this._active=s,this._eventPosition=e,this._ignoreReplayEvents=!0,this.update(!0))}handleEvent(t,e,i=!0){if(e&&this._ignoreReplayEvents)return!1;this._ignoreReplayEvents=!1;const s=this.options,n=this._active||[],a=this._getActiveElements(t,n,e,i),o=this._positionChanged(a,t),r=e||!Ke(a,n)||o;return r&&(this._active=a,(s.enabled||s.external)&&(this._eventPosition={x:t.x,y:t.y},this.update(!0,e))),r}_getActiveElements(t,e,i,s){const n=this.options;if("mouseout"===t.type)return[];if(!s)return e.filter(t=>this.chart.data.datasets[t.datasetIndex]&&void 0!==this.chart.getDatasetMeta(t.datasetIndex).controller.getParsed(t.index));const a=this.chart.getElementsAtEventForMode(t,n.mode,n,i);return n.reverse&&a.reverse(),a}_positionChanged(t,e){const{caretX:i,caretY:s,options:n}=this,a=uh[n.position].call(this,t,e);return!1!==a&&(i!==a.x||s!==a.y)}}(0,jt.A)(Ph,"positioners",uh);var Dh={id:"tooltip",_element:Ph,positioners:uh,afterInit(t,e,i){i&&(t.tooltip=new Ph({chart:t,options:i}))},beforeUpdate(t,e,i){t.tooltip&&t.tooltip.initialize(i)},reset(t,e,i){t.tooltip&&t.tooltip.initialize(i)},afterDraw(t){const e=t.tooltip;if(e&&e._willRender()){const i={tooltip:e};if(!1===t.notifyPlugins("beforeTooltipDraw",{...i,cancelable:!0}))return;e.draw(t.ctx),t.notifyPlugins("afterTooltipDraw",i)}},afterEvent(t,e){if(t.tooltip){const i=e.replay;t.tooltip.handleEvent(e.event,i,e.inChartArea)&&(e.changed=!0)}},defaults:{enabled:!0,external:null,position:"average",backgroundColor:"rgba(0,0,0,0.8)",titleColor:"#fff",titleFont:{weight:"bold"},titleSpacing:2,titleMarginBottom:6,titleAlign:"left",bodyColor:"#fff",bodySpacing:2,bodyFont:{},bodyAlign:"left",footerColor:"#fff",footerSpacing:2,footerMarginTop:6,footerFont:{weight:"bold"},footerAlign:"left",padding:6,caretPadding:2,caretSize:5,cornerRadius:6,boxHeight:(t,e)=>e.bodyFont.size,boxWidth:(t,e)=>e.bodyFont.size,multiKeyBackground:"#fff",displayColors:!0,boxPadding:0,borderColor:"rgba(0,0,0,0)",borderWidth:0,animation:{duration:400,easing:"easeOutQuart"},animations:{numbers:{type:"number",properties:["x","y","width","height","caretX","caretY"]},opacity:{easing:"linear",duration:200}},callbacks:Ah},defaultRoutes:{bodyFont:"font",footerFont:"font",titleFont:"font"},descriptors:{_scriptable:t=>"filter"!==t&&"itemSort"!==t&&"external"!==t,_indexable:!1,callbacks:{_scriptable:!1,_indexable:!1},animation:{_fallback:!1},animations:{_fallback:"animation"}},additionalOptionScopes:["interaction"]};const Eh=(t,e,i,s)=>("string"===typeof e?(i=t.push(e)-1,s.unshift({index:i,label:e})):isNaN(e)&&(i=null),i);function Lh(t,e,i,s){const n=t.indexOf(e);if(-1===n)return Eh(t,e,i,s);const a=t.lastIndexOf(e);return n!==a?i:n}const Ih=(t,e)=>null===t?null:Vi(Math.round(t),0,e);function Vh(t){const e=this.getLabels();return t>=0&&te.length-1?null:this.getPixelForValue(e[t].value)}getValueForPixel(t){return Math.round(this._startValue+this.getDecimalForPixel(t)*this._valueRange)}getBasePixel(){return this.bottom}}function Rh(t,e){const i=[],s=1e-14,{bounds:n,step:a,min:o,max:r,precision:l,count:h,maxTicks:c,maxDigits:d,includeBounds:u}=t,g=a||1,p=c-1,{min:f,max:m}=e,b=!We(o),x=!We(r),y=!We(h),_=(m-f)/(d+1);let v,k,w,C,S=vi((m-f)/p/g)*g;if(Sp&&(S=vi(C*S/p/g)*g),We(l)||(v=Math.pow(10,l),S=Math.ceil(S*v)/v),"ticks"===n?(k=Math.floor(f/S)*S,w=Math.ceil(m/S)*S):(k=f,w=m),b&&x&&a&&Si((r-o)/a,S/1e3)?(C=Math.round(Math.min((r-o)/S,c)),S=(r-o)/C,k=o,w=r):y?(k=b?o:k,w=x?r:w,C=h-1,S=(w-k)/C):(C=(w-k)/S,C=_i(C,Math.round(C),S/1e3)?Math.round(C):Math.ceil(C));const F=Math.max(Ti(S),Ti(k));v=Math.pow(10,We(l)?F:l),k=Math.round(k*v)/v,w=Math.round(w*v)/v;let M=0;for(b&&(u&&k!==o?(i.push({value:o}),kr)break;i.push({value:t})}return x&&u&&w!==r?i.length&&_i(i[i.length-1].value,r,Wh(r,_,t))?i[i.length-1].value=r:i.push({value:r}):x&&w!==r||i.push({value:w}),i}function Wh(t,e,{horizontal:i,minRotation:s}){const n=Mi(s),a=(i?Math.sin(n):Math.cos(n))||.001,o=.75*e*(""+t).length;return Math.min(e/a,o)}(0,jt.A)(Oh,"id","category"),(0,jt.A)(Oh,"defaults",{ticks:{callback:Vh}});class Bh extends Er{constructor(t){super(t),this.start=void 0,this.end=void 0,this._startValue=void 0,this._endValue=void 0,this._valueRange=0}parse(t,e){return We(t)||("number"===typeof t||t instanceof Number)&&!isFinite(+t)?null:+t}handleTickRangeOptions(){const{beginAtZero:t}=this.options,{minDefined:e,maxDefined:i}=this.getUserBounds();let{min:s,max:n}=this;const a=t=>s=e?s:t,o=t=>n=i?n:t;if(t){const t=yi(s),e=yi(n);t<0&&e<0?o(0):t>0&&e>0&&a(0)}if(s===n){let e=0===n?1:Math.abs(.05*n);o(n+e),t||a(s-e)}this.min=s,this.max=n}getTickLimit(){const t=this.options.ticks;let e,{maxTicksLimit:i,stepSize:s}=t;return s?(e=Math.ceil(this.max/s)-Math.floor(this.min/s)+1,e>1e3&&(console.warn(`scales.${this.id}.ticks.stepSize: ${s} would result generating up to ${e} ticks. Limiting to 1000.`),e=1e3)):(e=this.computeTickLimit(),i=i||11),i&&(e=Math.min(i,e)),e}computeTickLimit(){return Number.POSITIVE_INFINITY}buildTicks(){const t=this.options,e=t.ticks;let i=this.getTickLimit();i=Math.max(2,i);const s={maxTicks:i,bounds:t.bounds,min:t.min,max:t.max,precision:e.precision,step:e.stepSize,count:e.count,maxDigits:this._maxDigits(),horizontal:this.isHorizontal(),minRotation:e.minRotation||0,includeBounds:!1!==e.includeBounds},n=this._range||this,a=Rh(s,n);return"ticks"===t.bounds&&Fi(a,this,"value"),t.reverse?(a.reverse(),this.start=this.max,this.end=this.min):(this.start=this.min,this.end=this.max),a}configure(){const t=this.ticks;let e=this.min,i=this.max;if(super.configure(),this.options.offset&&t.length){const s=(i-e)/Math.max(t.length-1,1)/2;e-=s,i+=s}this._startValue=e,this._endValue=i,this._valueRange=i-e}getLabelForValue(t){return gs(t,this.chart.options.locale,this.options.ticks.format)}}class zh extends Bh{determineDataLimits(){const{min:t,max:e}=this.getMinMax(!0);this.min=Ne(t)?t:0,this.max=Ne(e)?e:1,this.handleTickRangeOptions()}computeTickLimit(){const t=this.isHorizontal(),e=t?this.width:this.height,i=Mi(this.options.ticks.minRotation),s=(t?Math.sin(i):Math.cos(i))||.001,n=this._resolveTickFontOptions(0);return Math.ceil(e/Math.min(40,n.lineHeight/s))}getPixelForValue(t){return null===t?NaN:this.getPixelForDecimal((t-this._startValue)/this._valueRange)}getValueForPixel(t){return this._startValue+this.getDecimalForPixel(t)*this._valueRange}}(0,jt.A)(zh,"id","linear"),(0,jt.A)(zh,"defaults",{ticks:{callback:ms.formatters.numeric}});const Nh=t=>Math.floor(xi(t)),Uh=(t,e)=>Math.pow(10,Nh(t)+e);function $h(t){const e=t/Math.pow(10,Nh(t));return 1===e}function jh(t,e,i){const s=Math.pow(10,i),n=Math.floor(t/s),a=Math.ceil(e/s);return a-n}function Hh(t,e){const i=e-t;let s=Nh(i);while(jh(t,e,s)>10)s++;while(jh(t,e,s)<10)s--;return Math.min(s,Nh(t))}function Xh(t,{min:e,max:i}){e=Ue(t.min,e);const s=[],n=Nh(e);let a=Hh(e,i),o=a<0?Math.pow(10,Math.abs(a)):1;const r=Math.pow(10,a),l=n>a?Math.pow(10,n):0,h=Math.round((e-l)*o)/o,c=Math.floor((e-l)/r/10)*r*10;let d=Math.floor((h-c)/Math.pow(10,a)),u=Ue(t.min,Math.round((l+c+d*Math.pow(10,a))*o)/o);while(u=10?d=d<15?15:20:d++,d>=20&&(a++,d=2,o=a>=0?1:o),u=Math.round((l+c+d*Math.pow(10,a))*o)/o;const g=Ue(t.max,u);return s.push({value:g,major:$h(g),significand:d}),s}class qh extends Er{constructor(t){super(t),this.start=void 0,this.end=void 0,this._startValue=void 0,this._valueRange=0}parse(t,e){const i=Bh.prototype.parse.apply(this,[t,e]);if(0!==i)return Ne(i)&&i>0?i:null;this._zero=!0}determineDataLimits(){const{min:t,max:e}=this.getMinMax(!0);this.min=Ne(t)?Math.max(0,t):null,this.max=Ne(e)?Math.max(0,e):null,this.options.beginAtZero&&(this._zero=!0),this._zero&&this.min!==this._suggestedMin&&!Ne(this._userMin)&&(this.min=t===Uh(this.min,0)?Uh(this.min,-1):Uh(this.min,0)),this.handleTickRangeOptions()}handleTickRangeOptions(){const{minDefined:t,maxDefined:e}=this.getUserBounds();let i=this.min,s=this.max;const n=e=>i=t?i:e,a=t=>s=e?s:t;i===s&&(i<=0?(n(1),a(10)):(n(Uh(i,-1)),a(Uh(s,1)))),i<=0&&n(Uh(s,-1)),s<=0&&a(Uh(i,1)),this.min=i,this.max=s}buildTicks(){const t=this.options,e={min:this._userMin,max:this._userMax},i=Xh(e,this);return"ticks"===t.bounds&&Fi(i,this,"value"),t.reverse?(i.reverse(),this.start=this.max,this.end=this.min):(this.start=this.min,this.end=this.max),i}getLabelForValue(t){return void 0===t?"0":gs(t,this.chart.options.locale,this.options.ticks.format)}configure(){const t=this.min;super.configure(),this._startValue=xi(t),this._valueRange=xi(this.max)-xi(t)}getPixelForValue(t){return void 0!==t&&0!==t||(t=this.min),null===t||isNaN(t)?NaN:this.getPixelForDecimal(t===this.min?0:(xi(t)-this._startValue)/this._valueRange)}getValueForPixel(t){const e=this.getDecimalForPixel(t);return Math.pow(10,this._startValue+e*this._valueRange)}}function Kh(t){const e=t.ticks;if(e.display&&t.display){const t=Ks(e.backdropPadding);return $e(e.font&&e.font.size,ws.font.size)+t.height}return 0}function Yh(t,e,i){return i=Be(i)?i:[i],{w:Fs(t,e.string,i),h:i.length*e.lineHeight}}function Qh(t,e,i,s,n){return t===s||t===n?{start:e-i/2,end:e+i/2}:tn?{start:e-i,end:e}:{start:e,end:e+i}}function Gh(t){const e={l:t.left+t._padding.left,r:t.right-t._padding.right,t:t.top+t._padding.top,b:t.bottom-t._padding.bottom},i=Object.assign({},e),s=[],n=[],a=t._pointLabels.length,o=t.options.pointLabels,r=o.centerPointLabels?ci/a:0;for(let l=0;le.r&&(r=(s.end-e.r)/a,t.r=Math.max(t.r,e.r+r)),n.starte.b&&(l=(n.end-e.b)/o,t.b=Math.max(t.b,e.b+l))}function Zh(t,e,i){const s=t.drawingArea,{extra:n,additionalAngle:a,padding:o,size:r}=i,l=t.getPointPosition(e,s+n+o,a),h=Math.round(Ai(Li(l.angle+fi))),c=nc(l.y,r.h,h),d=ic(h),u=sc(l.x,r.w,d);return{visible:!0,x:l.x,y:c,textAlign:d,left:u,top:c,right:u+r.w,bottom:c+r.h}}function tc(t,e){if(!e)return!0;const{left:i,top:s,right:n,bottom:a}=t,o=Ds({x:i,y:s},e)||Ds({x:i,y:a},e)||Ds({x:n,y:s},e)||Ds({x:n,y:a},e);return!o}function ec(t,e,i){const s=[],n=t._pointLabels.length,a=t.options,{centerPointLabels:o,display:r}=a.pointLabels,l={extra:Kh(a)/2,additionalAngle:o?ci/n:0};let h;for(let c=0;c270||i<90)&&(t-=e),t}function ac(t,e,i){const{left:s,top:n,right:a,bottom:o}=i,{backdropColor:r}=e;if(!We(r)){const i=qs(e.borderRadius),l=Ks(e.backdropPadding);t.fillStyle=r;const h=s-l.left,c=n-l.top,d=a-s+l.width,u=o-n+l.height;Object.values(i).some(t=>0!==t)?(t.beginPath(),zs(t,{x:h,y:c,w:d,h:u,radius:i}),t.fill()):t.fillRect(h,c,d,u)}}function oc(t,e){const{ctx:i,options:{pointLabels:s}}=t;for(let n=e-1;n>=0;n--){const e=t._pointLabelItems[n];if(!e.visible)continue;const a=s.setContext(t.getPointLabelContext(n));ac(i,a,e);const o=Ys(a.font),{x:r,y:l,textAlign:h}=e;Bs(i,t._pointLabels[n],r,l+o.lineHeight/2,o,{color:a.color,textAlign:h,textBaseline:"middle"})}}function rc(t,e,i,s){const{ctx:n}=t;if(i)n.arc(t.xCenter,t.yCenter,e,0,di);else{let i=t.getPointPosition(0,e);n.moveTo(i.x,i.y);for(let a=1;a{const i=Xe(this.options.pointLabels.callback,[t,e],this);return i||0===i?i:""}).filter((t,e)=>this.chart.getDataVisibility(e))}fit(){const t=this.options;t.display&&t.pointLabels.display?Gh(this):this.setCenterPoint(0,0,0,0)}setCenterPoint(t,e,i,s){this.xCenter+=Math.floor((t-e)/2),this.yCenter+=Math.floor((i-s)/2),this.drawingArea-=Math.min(this.drawingArea/2,Math.max(t,e,i,s))}getIndexAngle(t){const e=di/(this._pointLabels.length||1),i=this.options.startAngle||0;return Li(t*e+Mi(i))}getDistanceFromCenterForValue(t){if(We(t))return NaN;const e=this.drawingArea/(this.max-this.min);return this.options.reverse?(this.max-t)*e:(t-this.min)*e}getValueForDistanceFromCenter(t){if(We(t))return NaN;const e=t/(this.drawingArea/(this.max-this.min));return this.options.reverse?this.max-e:this.min+e}getPointLabelContext(t){const e=this._pointLabels||[];if(t>=0&&t{if(0!==e||0===e&&this.min<0){r=this.getDistanceFromCenterForValue(t.value);const i=this.getContext(e),o=s.setContext(i),l=n.setContext(i);lc(this,o,r,a,l)}}),i.display){for(t.save(),o=a-1;o>=0;o--){const s=i.setContext(this.getPointLabelContext(o)),{color:n,lineWidth:a}=s;a&&n&&(t.lineWidth=a,t.strokeStyle=n,t.setLineDash(s.borderDash),t.lineDashOffset=s.borderDashOffset,r=this.getDistanceFromCenterForValue(e.reverse?this.min:this.max),l=this.getPointPosition(o,r),t.beginPath(),t.moveTo(this.xCenter,this.yCenter),t.lineTo(l.x,l.y),t.stroke())}t.restore()}}drawBorder(){}drawLabels(){const t=this.ctx,e=this.options,i=e.ticks;if(!i.display)return;const s=this.getIndexAngle(0);let n,a;t.save(),t.translate(this.xCenter,this.yCenter),t.rotate(s),t.textAlign="center",t.textBaseline="middle",this.ticks.forEach((s,o)=>{if(0===o&&this.min>=0&&!e.reverse)return;const r=i.setContext(this.getContext(o)),l=Ys(r.font);if(n=this.getDistanceFromCenterForValue(this.ticks[o].value),r.showLabelBackdrop){t.font=l.string,a=t.measureText(s.label).width,t.fillStyle=r.backdropColor;const e=Ks(r.backdropPadding);t.fillRect(-a/2-e.left,-n-l.size/2-e.top,a+e.width,l.size+e.height)}Bs(t,s.label,0,-n,l,{color:r.color,strokeColor:r.textStrokeColor,strokeWidth:r.textStrokeWidth})}),t.restore()}drawTitle(){}}(0,jt.A)(cc,"id","radialLinear"),(0,jt.A)(cc,"defaults",{display:!0,animate:!0,position:"chartArea",angleLines:{display:!0,lineWidth:1,borderDash:[],borderDashOffset:0},grid:{circular:!1},startAngle:0,ticks:{showLabelBackdrop:!0,callback:ms.formatters.numeric},pointLabels:{backdropColor:void 0,backdropPadding:2,display:!0,font:{size:10},callback(t){return t},padding:5,centerPointLabels:!1}}),(0,jt.A)(cc,"defaultRoutes",{"angleLines.color":"borderColor","pointLabels.color":"color","ticks.color":"color"}),(0,jt.A)(cc,"descriptors",{angleLines:{_fallback:"grid"}});const dc={millisecond:{common:!0,size:1,steps:1e3},second:{common:!0,size:1e3,steps:60},minute:{common:!0,size:6e4,steps:60},hour:{common:!0,size:36e5,steps:24},day:{common:!0,size:864e5,steps:30},week:{common:!1,size:6048e5,steps:4},month:{common:!0,size:2628e6,steps:12},quarter:{common:!1,size:7884e6,steps:4},year:{common:!0,size:3154e7}},uc=Object.keys(dc);function gc(t,e){return t-e}function pc(t,e){if(We(e))return null;const i=t._adapter,{parser:s,round:n,isoWeekday:a}=t._parseOpts;let o=e;return"function"===typeof s&&(o=s(o)),Ne(o)||(o="string"===typeof s?i.parse(o,s):i.parse(o)),null===o?null:(n&&(o="week"!==n||!Ci(a)&&!0!==a?i.startOf(o,n):i.startOf(o,"isoWeek",a)),+o)}function fc(t,e,i,s){const n=uc.length;for(let a=uc.indexOf(t);a=uc.indexOf(i);a--){const i=uc[a];if(dc[i].common&&t._adapter.diff(n,s,i)>=e-1)return i}return uc[i?uc.indexOf(i):0]}function bc(t){for(let e=uc.indexOf(t)+1,i=uc.length;e=e?i[s]:i[n];t[a]=!0}}else t[e]=!0}function yc(t,e,i,s){const n=t._adapter,a=+n.startOf(e[0].value,s),o=e[e.length-1].value;let r,l;for(r=a;r<=o;r=+n.add(r,1,s))l=i[r],l>=0&&(e[l].major=!0);return e}function _c(t,e,i){const s=[],n={},a=e.length;let o,r;for(o=0;o+t.value))}initOffsets(t=[]){let e,i,s=0,n=0;this.options.offset&&t.length&&(e=this.getDecimalForValue(t[0]),s=1===t.length?1-e:(this.getDecimalForValue(t[1])-e)/2,i=this.getDecimalForValue(t[t.length-1]),n=1===t.length?i:(i-this.getDecimalForValue(t[t.length-2]))/2);const a=t.length<3?.5:.25;s=Vi(s,0,a),n=Vi(n,0,a),this._offsets={start:s,end:n,factor:1/(s+1+n)}}_generate(){const t=this._adapter,e=this.min,i=this.max,s=this.options,n=s.time,a=n.unit||fc(n.minUnit,e,i,this._getLabelCapacity(e)),o=$e(s.ticks.stepSize,1),r="week"===a&&n.isoWeekday,l=Ci(r)||!0===r,h={};let c,d,u=e;if(l&&(u=+t.startOf(u,"isoWeek",r)),u=+t.startOf(u,l?"day":a),t.diff(i,e,a)>1e5*o)throw new Error(e+" and "+i+" are too far apart with stepSize of "+o+" "+a);const g="data"===s.ticks.source&&this.getDataTimestamps();for(c=u,d=0;c+t)}getLabelForValue(t){const e=this._adapter,i=this.options.time;return i.tooltipFormat?e.format(t,i.tooltipFormat):e.format(t,i.displayFormats.datetime)}format(t,e){const i=this.options,s=i.time.displayFormats,n=this._unit,a=e||s[n];return this._adapter.format(t,a)}_tickFormatFunction(t,e,i,s){const n=this.options,a=n.ticks.callback;if(a)return Xe(a,[t,e,i],this);const o=n.time.displayFormats,r=this._unit,l=this._majorUnit,h=r&&o[r],c=l&&o[l],d=i[e],u=l&&c&&d&&d.major;return this._adapter.format(t,s||(u?c:h))}generateTickLabels(t){let e,i,s;for(e=0,i=t.length;e0?o:1}getDataTimestamps(){let t,e,i=this._cache.data||[];if(i.length)return i;const s=this.getMatchingVisibleMetas();if(this._normalized&&s.length)return this._cache.data=s[0].controller.getAllParsedValues(this);for(t=0,e=s.length;t=t[r].pos&&e<=t[l].pos&&({lo:r,hi:l}=Bi(t,"pos",e)),({pos:s,time:a}=t[r]),({pos:n,time:o}=t[l])):(e>=t[r].time&&e<=t[l].time&&({lo:r,hi:l}=Bi(t,"time",e)),({time:s,pos:a}=t[r]),({time:n,pos:o}=t[l]));const h=n-s;return h?a+(o-a)*(e-s)/h:a}(0,jt.A)(vc,"id","time"),(0,jt.A)(vc,"defaults",{bounds:"data",adapters:{},time:{parser:!1,unit:!1,round:!1,isoWeekday:!1,minUnit:"millisecond",displayFormats:{}},ticks:{source:"auto",callback:!1,major:{enabled:!1}}});class wc extends vc{constructor(t){super(t),this._table=[],this._minPos=void 0,this._tableRange=void 0}initOffsets(){const t=this._getTimestampsForTable(),e=this._table=this.buildLookupTable(t);this._minPos=kc(e,this.min),this._tableRange=kc(e,this.max)-this._minPos,super.initOffsets(t)}buildLookupTable(t){const{min:e,max:i}=this,s=[],n=[];let a,o,r,l,h;for(a=0,o=t.length;a=e&&l<=i&&s.push(l);if(s.length<2)return[{time:e,pos:0},{time:i,pos:1}];for(a=0,o=s.length;at-e)}_getTimestampsForTable(){let t=this._cache.all||[];if(t.length)return t;const e=this.getDataTimestamps(),i=this.getLabelTimestamps();return t=e.length&&i.length?this.normalize(e.concat(i)):e.length?e:i,t=this._cache.all=t,t}getDecimalForValue(t){return(kc(this._table,t)-this._minPos)/this._tableRange}getValueForPixel(t){const e=this._offsets,i=this.getDecimalForPixel(t)/e.factor-e.end;return kc(this._table,i*this._tableRange+this._minPos,!0)}}(0,jt.A)(wc,"id","timeseries"),(0,jt.A)(wc,"defaults",vc.defaults);var Cc=i(144);const Sc={data:{type:Object,required:!0},options:{type:Object,default:()=>({})},plugins:{type:Array,default:()=>[]},datasetIdKey:{type:String,default:"label"},updateMode:{type:String,default:void 0}},Fc={ariaLabel:{type:String},ariaDescribedby:{type:String}},Mc={type:{type:String,required:!0},destroyDelay:{type:Number,default:0},...Sc,...Fc},Ac="2"===s.rE[0]?(t,e)=>Object.assign(t,{attrs:e}):(t,e)=>Object.assign(t,e);function Tc(t){return(0,Cc.ju)(t)?(0,Cc.ux)(t):t}function Pc(t){let e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:t;return(0,Cc.ju)(e)?new Proxy(t,{}):t}function Dc(t,e){const i=t.options;i&&e&&Object.assign(i,e)}function Ec(t,e){t.labels=e}function Lc(t,e,i){const s=[];t.datasets=e.map(e=>{const n=t.datasets.find(t=>t[i]===e[i]);return n&&e.data&&!s.includes(n)?(s.push(n),Object.assign(n,e),n):{...e}})}function Ic(t,e){const i={labels:[],datasets:[]};return Ec(i,t.labels),Lc(i,t.datasets,e),i}const Vc=(0,s.pM)({props:Mc,setup(t,e){let{expose:i,slots:n}=e;const a=(0,Cc.KR)(null),o=(0,Cc.IJ)(null);i({chart:o});const r=()=>{if(!a.value)return;const{type:e,data:i,options:s,plugins:n,datasetIdKey:r}=t,l=Ic(i,r),h=Pc(l,i);o.value=new vl(a.value,{type:e,data:h,options:{...s},plugins:n})},l=()=>{const e=(0,Cc.ux)(o.value);e&&(t.destroyDelay>0?setTimeout(()=>{e.destroy(),o.value=null},t.destroyDelay):(e.destroy(),o.value=null))},h=e=>{e.update(t.updateMode)};return(0,s.sV)(r),(0,s.hi)(l),(0,s.wB)([()=>t.options,()=>t.data],(e,i)=>{let[n,a]=e,[r,l]=i;const c=(0,Cc.ux)(o.value);if(!c)return;let d=!1;if(n){const t=Tc(n),e=Tc(r);t&&t!==e&&(Dc(c,t),d=!0)}if(a){const e=Tc(a.labels),i=Tc(l.labels),s=Tc(a.datasets),n=Tc(l.datasets);e!==i&&(Ec(c.config.data,e),d=!0),s&&s!==n&&(Lc(c.config.data,s,t.datasetIdKey),d=!0)}d&&(0,s.dY)(()=>{h(c)})},{deep:!0}),()=>(0,s.h)("canvas",{role:"img","aria-label":t.ariaLabel,"aria-describedby":t.ariaDescribedby,ref:a},[(0,s.h)("p",{},[n.default?n.default():""])])}});function Oc(t,e){return vl.register(e),(0,s.pM)({props:Sc,setup(e,i){let{expose:n}=i;const a=(0,Cc.IJ)(null),o=t=>{a.value=t?.chart};return n({chart:a}),()=>(0,s.h)(Vc,Ac({ref:o},{type:t,...e}))}})}const Rc=Oc("doughnut",ro);i(6573),i(8100),i(7936),i(9577),i(1549),i(9797),i(9631),i(5623),i(4603),i(7566),i(8721);class Wc extends Error{constructor(t,e,i=!1,s=""){super(t),this.name="BatchOperationError",this.code=e,this.recoverable=i,this.suggestion=s}}const Bc={401:()=>new Wc("认证失败,请重新登录","AUTH_FAILED",!1,"请刷新页面并重新登录"),403:()=>new Wc("权限不足或请求被拒绝","FORBIDDEN",!1,"请确认您有管理员权限"),400:t=>new Wc(`请求数据无效: ${t}`,"INVALID_DATA",!0,"请检查数据格式后重试"),500:()=>new Wc("服务器内部错误","SERVER_ERROR",!0,"请稍后重试,如果问题持续请联系管理员"),NETWORK:()=>new Wc("网络连接失败","NETWORK_ERROR",!0,"请检查网络连接后重试"),ABORT:()=>new Wc("操作已取消","ABORTED",!1,"")};function zc(t,e=""){if("AbortError"===t.name)return Bc.ABORT();if(t instanceof Response||t&&"number"===typeof t.status){const i=Bc[t.status];return i?i(e):new Wc(`请求失败: ${t.status}`,"HTTP_ERROR",!0,"请稍后重试")}return t instanceof TypeError&&t.message.includes("fetch")?Bc.NETWORK():new Wc(t.message||"未知错误","UNKNOWN_ERROR",!0,"请稍后重试")}class Nc{constructor(t={}){this.batchSize=t.batchSize||1e3,this.onProgress=t.onProgress||(()=>{}),this.onError=t.onError||(()=>{}),this.abortController=null}async fetchAllRecords(t=!1){this.abortController=new AbortController;const e=[];let i=null,s=0,n=0;try{do{if(this.abortController.signal.aborted)break;const a=await this.fetchBatch(i,t);e.push(...a.records),i=a.nextCursor,s+=a.records.length,n++,this.onProgress({phase:"fetching",current:s,batchCount:n,message:`已获取 ${s} 条记录...`})}while(i&&!this.abortController.signal.aborted);if(this.abortController.signal.aborted)throw Bc.ABORT();return e}catch(a){const t=a instanceof Wc?a:zc(a);throw this.onError(t),t}}async fetchBatch(t,e){const i=new URLSearchParams;t&&i.set("cursor",t),e&&i.set("includeValue","true"),i.set("limit",String(this.batchSize));try{const t=await(0,Ut.A)(`/api/manage/batch/list?${i}`,{signal:this.abortController.signal});if(!t.ok){let e="";try{const i=await t.json();e=i.error||""}catch{}throw zc(t,e)}const e=await t.json();if(!e.success)throw new Wc(e.error||"请求失败","API_ERROR",!0,"请稍后重试");return{records:e.records||[],nextCursor:e.nextCursor||null,totalProcessed:e.totalProcessed||0}}catch(s){if(s instanceof Wc)throw s;throw zc(s)}}abort(){this.abortController&&this.abortController.abort()}isAborted(){return!!this.abortController&&this.abortController.signal.aborted}reset(){this.abortController=null}}var Uc=Nc;class $c{constructor(t={}){this.chunkSize=t.chunkSize||null,this.maxRetries=t.maxRetries||3,this.retryDelay=t.retryDelay||1e3,this.onProgress=t.onProgress||(()=>{}),this.onError=t.onError||(()=>{}),this.sessionId=this.generateSessionId(),this.aborted=!1}async fetchConfig(){try{const t=await(0,Ut.A)("/api/manage/batch/index/config");if(!t.ok)throw new Error("获取配置失败");const e=await t.json();if(e.success)return{chunkSize:e.chunkSize||500,databaseType:e.databaseType||"unknown"};throw new Error(e.error||"获取配置失败")}catch(t){return console.warn("Failed to fetch index config, using default:",t),{chunkSize:500,databaseType:"unknown"}}}async rebuild(){this.aborted=!1;try{if(!this.chunkSize){const t=await this.fetchConfig();this.chunkSize=t.chunkSize}this.onProgress({phase:"fetching",message:"正在获取数据...",current:0});const t=new Uc({onProgress:t=>this.onProgress({...t,phase:"fetching"}),onError:t=>this.onError(t)}),e=await t.fetchAllRecords(!1);if(this.aborted)throw new Wc("操作已取消","ABORTED",!1,"");if(this.onProgress({phase:"sorting",message:"正在排序...",current:0,total:e.length}),this.sortByTimestampDescending(e),this.aborted)throw new Wc("操作已取消","ABORTED",!1,"");const i=this.splitIntoChunks(e);for(let s=0;s{const i=t.metadata&&t.metadata.TimeStamp||0,s=e.metadata&&e.metadata.TimeStamp||0;return s-i})}splitIntoChunks(t){const e=[];for(let i=0;it.toString(16).padStart(2,"0")).join("")}createHttpError(t,e=""){switch(t){case 401:return new Wc("认证失败,请重新登录","AUTH_FAILED",!1,"请刷新页面并重新登录");case 403:return new Wc("权限不足或请求被拒绝","FORBIDDEN",!1,"请确认您有管理员权限");case 400:return new Wc(`请求数据无效: ${e}`,"INVALID_DATA",!0,"请检查数据格式后重试");case 404:return new Wc("会话不存在","SESSION_NOT_FOUND",!1,"请重新开始索引重建");case 410:return new Wc("会话已过期","SESSION_EXPIRED",!1,"请重新开始索引重建");case 500:default:return new Wc(`服务器错误: ${e||t}`,"SERVER_ERROR",!0,"请稍后重试")}}sleep(t){return new Promise(e=>setTimeout(e,t))}abort(){this.aborted=!0}reset(){this.aborted=!1,this.sessionId=this.generateSessionId()}}var jc=$c;class Hc{constructor(t={}){this.onProgress=t.onProgress||(()=>{}),this.processor=null}async generateBackup(){this.processor=new Uc({onProgress:t=>this.onProgress({...t,phase:"fetching"})});const t=await this.processor.fetchAllRecords(!0);this.onProgress({phase:"building",message:"正在构建备份数据..."});const e={timestamp:Date.now(),version:$t.rE,data:{fileCount:t.length,files:{},settings:{}}};for(const n of t)e.data.files[n.id]={metadata:n.metadata,value:n.value||null};const i=await this.fetchSettings();e.data.settings=i,this.onProgress({phase:"downloading",message:"正在生成下载..."}),this.downloadBackup(e);const s=Object.keys(i).length;return{success:!0,fileCount:t.length,settingsCount:s}}async fetchSettings(){try{const t=await(0,Ut.A)("/api/manage/batch/settings");if(!t.ok)return console.warn("Failed to fetch settings:",t.status),{};const e=await t.json();return e.settings||{}}catch(t){return console.warn("Failed to fetch settings:",t),{}}}downloadBackup(t){const e=JSON.stringify(t,null,2),i=new Blob([e],{type:"application/json"}),s=URL.createObjectURL(i),n=document.createElement("a");n.href=s,n.download=`imgbed_backup_${(new Date).toISOString().split("T")[0]}.json`,document.body.appendChild(n),n.click(),document.body.removeChild(n),URL.revokeObjectURL(s)}abort(){this.processor&&this.processor.abort()}isAborted(){return!!this.processor&&this.processor.isAborted()}}var Xc=Hc;class qc{constructor(t={}){this.chunkSize=t.chunkSize||50,this.maxRetries=t.maxRetries||3,this.retryDelay=t.retryDelay||1e3,this.onProgress=t.onProgress||(()=>{}),this.onError=t.onError||(()=>{}),this.aborted=!1}async restore(t){if(this.aborted=!1,!t||!t.data)throw new Wc("备份文件格式无效","INVALID_BACKUP",!1,"请选择有效的备份文件");const{files:e={},settings:i={}}=t.data,s=Object.entries(e),n=Object.entries(i),a=s.length,o=n.length,r=a+o;let l=0,h=0,c=0,d=0;try{this.onProgress({phase:"restoring_files",message:"正在恢复文件数据...",current:0,total:r});const e=this.splitIntoChunks(s,this.chunkSize);for(let t=0;tsetTimeout(e,t))}abort(){this.aborted=!0}}var Kc=qc;vl.register(Dl,Dh,dh);var Yc={name:"SysCogStatus",components:{Doughnut:Rc},data(){return{loading:!1,rebuilding:!1,backing:!1,restoring:!1,indexInfo:{},version:$t.rE,loadErrors:{newest:!1,oldest:!1},channelColors:["#8B5CF6","#EC4899","#06B6D4","#10B981","#F59E0B","#EF4444","#6366F1","#84CC16"],typeColors:["#10B981","#3B82F6","#F59E0B","#EF4444","#8B5CF6","#EC4899","#06B6D4","#84CC16"],isProcessing:!1,processingPhase:"",processingProgress:{current:0,total:0,message:"",percentage:0},processingError:null,processingStartTime:null,currentRebuilder:null,currentBackupGenerator:null,currentRestoreProcessor:null}},computed:{channelChartData(){const t=this.indexInfo.channelStats||{};return{labels:Object.keys(t),datasets:[{data:Object.values(t),backgroundColor:this.channelColors.slice(0,Object.keys(t).length),borderWidth:0}]}},typeChartData(){const t=this.aggregatedTypeStats;return{labels:Object.keys(t),datasets:[{data:Object.values(t),backgroundColor:this.typeColors.slice(0,Object.keys(t).length),borderWidth:0}]}},aggregatedTypeStats(){const t=this.indexInfo.typeStats||{},e={};for(const[i,s]of Object.entries(t)){const t="Block"===i?"已屏蔽":"正常";e[t]=(e[t]||0)+s}return e},chartOptions(){return{responsive:!0,maintainAspectRatio:!0,cutout:"65%",hoverOffset:8,layout:{padding:10},plugins:{legend:{display:!1},tooltip:{backgroundColor:"rgba(0, 0, 0, 0.8)",titleColor:"#fff",bodyColor:"#fff",padding:12,cornerRadius:8,displayColors:!0,z:100,callbacks:{label:t=>{const e=t.raw,i=t.dataset.data.reduce((t,e)=>t+e,0),s=(e/i*100).toFixed(1);return` ${e.toLocaleString()} (${s}%)`}}}},animation:{animateRotate:!0,animateScale:!0}}},estimatedTimeRemaining(){if(!this.isProcessing||!this.processingStartTime)return"";if(0===this.processingProgress.current||0===this.processingProgress.percentage)return"";const t=Date.now()-this.processingStartTime,e=this.processingProgress.percentage/100;if(e<=0)return"";const i=t/e,s=i-t;if(s<=0)return"即将完成";const n=Math.ceil(s/1e3);if(n<60)return`约 ${n} 秒`;const a=Math.ceil(n/60);if(a<60)return`约 ${a} 分钟`;const o=Math.floor(a/60),r=a%60;return`约 ${o} 小时 ${r} 分钟`},phaseDescription(){const t={fetching:"正在获取数据",sorting:"正在排序",uploading:"正在上传",finalizing:"正在完成",building:"正在构建备份",downloading:"正在生成下载",restoring_files:"正在恢复文件",restoring_settings:"正在恢复设置",completed:"已完成",retrying:"正在重试"};return t[this.processingPhase]||this.processingPhase}},mounted(){this.fetchIndexInfo()},methods:{getChartColor(t){return this.channelColors[t%this.channelColors.length]},getTypeChartColor(t){return this.typeColors[t%this.typeColors.length]},async fetchIndexInfo(){this.loading=!0;try{const t=await(0,Ut.A)("/api/manage/list?action=info",{method:"GET"});if(!t.ok)throw new Error("API请求失败");{const e=await t.json();this.indexInfo=e}}catch(t){console.error("获取索引信息失败:",t),this.$message.error("获取索引信息失败")}finally{this.loading=!1}},async rebuildIndex(){if(this.isProcessing)this.$message.warning("已有操作正在进行中");else{this.rebuilding=!0,this.isProcessing=!0,this.processingError=null,this.processingStartTime=Date.now(),this.processingProgress={current:0,total:0,message:"",percentage:0},this.currentRebuilder=new jc({onProgress:t=>this.handleProgress(t),onError:t=>this.handleError(t)});try{const t=await this.currentRebuilder.rebuild();this.$message.success(`索引重建完成!共处理 ${t.totalFiles.toLocaleString()} 个文件`),setTimeout(()=>{this.fetchIndexInfo()},1e3)}catch(t){if("ABORTED"!==t.code){const e=t.suggestion?`${t.message}。${t.suggestion}`:t.message;this.$message.error(e),this.processingError={message:t.message,suggestion:t.suggestion,recoverable:t.recoverable}}}finally{this.rebuilding=!1,this.isProcessing=!1,this.currentRebuilder=null,this.processingStartTime=null}}},async backupData(){if(this.isProcessing)this.$message.warning("已有操作正在进行中");else{this.backing=!0,this.isProcessing=!0,this.processingError=null,this.processingStartTime=Date.now(),this.processingProgress={current:0,total:0,message:"",percentage:0},this.currentBackupGenerator=new Xc({onProgress:t=>this.handleProgress(t)});try{const t=await this.currentBackupGenerator.generateBackup(),e=t.settingsCount>0?`,${t.settingsCount} 个设置项`:"";this.$message.success(`备份完成!共备份 ${t.fileCount.toLocaleString()} 个文件${e}`)}catch(t){if("ABORTED"!==t.code){const e=t.suggestion?`${t.message}。${t.suggestion}`:t.message;this.$message.error(e),this.processingError={message:t.message,suggestion:t.suggestion,recoverable:t.recoverable}}}finally{this.backing=!1,this.isProcessing=!1,this.currentBackupGenerator=null,this.processingStartTime=null}}},selectRestoreFile(){this.restoring||this.$refs.fileInput.click()},async handleFileSelect(t){const e=t.target.files[0];if(e)if(e.name.endsWith(".json")){try{await this.$confirm("恢复操作将覆盖现有的文件元数据和系统设置,此操作不可逆。确定要继续吗?","确认恢复",{confirmButtonText:"确定恢复",cancelButtonText:"取消",type:"warning"}),await this.restoreData(e)}catch(i){"cancel"!==i&&console.error("确认恢复失败:",i)}t.target.value=""}else this.$message.error("请选择JSON格式的备份文件")},async restoreData(t){if(this.isProcessing)this.$message.warning("已有操作正在进行中");else{this.restoring=!0,this.isProcessing=!0,this.processingError=null,this.processingStartTime=Date.now(),this.processingProgress={current:0,total:0,message:"",percentage:0};try{const i=await t.text();let s;try{s=JSON.parse(i)}catch(e){throw new Error("备份文件格式无效,请选择有效的 JSON 文件")}this.currentRestoreProcessor=new Kc({chunkSize:100,onProgress:t=>this.handleProgress(t),onError:t=>this.handleError(t)});const n=await this.currentRestoreProcessor.restore(s);this.restoring=!1,this.isProcessing=!1,this.currentRestoreProcessor=null,this.processingStartTime=null,this.$message.success(`恢复完成!已恢复 ${n.restoredFiles} 个文件和 ${n.restoredSettings} 个设置项,正在重建索引...`),await new Promise(t=>setTimeout(t,500)),await this.rebuildIndex()}catch(i){if(console.error("恢复数据失败:",i),this.restoring=!1,this.isProcessing=!1,this.currentRestoreProcessor=null,this.processingStartTime=null,"ABORTED"!==i.code){const t=i.suggestion?`${i.message}。${i.suggestion}`:i.message;this.$message.error("恢复数据失败: "+t),this.processingError={message:i.message,suggestion:i.suggestion,recoverable:i.recoverable}}}}},formatTime(t){if(!t)return"未知";const e=new Date(t);return e.toLocaleString("zh-CN",{year:"numeric",month:"2-digit",day:"2-digit",hour:"2-digit",minute:"2-digit"})},getPercentage(t,e){return e&&0!==e?Math.round(t/e*100):0},getTimeAgo(t){if(!t)return"";const e=Date.now(),i=e-t,s=Math.floor(i/6e4),n=Math.floor(i/36e5),a=Math.floor(i/864e5);return a>0?`${a}天前`:n>0?`${n}小时前`:s>0?`${s}分钟前`:"刚刚"},handleImageError(t){this.loadErrors[t]=!0},isValidPreview(t,e){return!this.loadErrors[t]&&(!!e?.metadata?.FileType&&(e.metadata.FileType.includes("image")||e.metadata.FileType.includes("video")))},openReleases(){window.open("https://github.com/MarSeventh/CloudFlare-ImgBed/releases","_blank")},isImageFile(t){if(!t)return!1;if(t.metadata?.FileType?.includes("image"))return!0;const e=t.metadata?.FileName||t.id||"",i=e.substring(e.lastIndexOf(".")+1).toLowerCase(),s=["jpg","jpeg","png","gif","bmp","webp","svg","ico","tiff","tif","avif","heic","heif"];return s.includes(i)},isVideoFile(t){if(!t)return!1;if(t.metadata?.FileType?.includes("video"))return!0;const e=t.metadata?.FileName||t.id||"",i=e.substring(e.lastIndexOf(".")+1).toLowerCase(),s=["mp4","webm","ogg","avi","mov","flv","wmv","mkv","m4v","3gp","mpeg","mpg"];return s.includes(i)},openFileInNewTab(t){t?.id&&window.open("/file/"+t.id,"_blank")},handleProgress(t){this.processingPhase=t.phase,this.processingProgress.message=t.message||"",this.processingProgress.current=t.current||0,"fetching"===t.phase?(this.processingProgress.total=t.total||0,t.total&&t.total>0?this.processingProgress.percentage=Math.min(60,t.current/t.total*60):this.processingProgress.percentage=Math.min(50,15*Math.log10(t.current+1))):"sorting"===t.phase?(this.processingProgress.percentage=65,this.processingProgress.total=t.total||this.processingProgress.total):"uploading"===t.phase?(this.processingProgress.total=t.total||0,t.total&&t.total>0&&(this.processingProgress.percentage=70+t.current/t.total*25)):"finalizing"===t.phase?this.processingProgress.percentage=97:"building"===t.phase?this.processingProgress.percentage=80:"downloading"===t.phase?this.processingProgress.percentage=95:"restoring_files"===t.phase?(this.processingProgress.total=t.total||0,this.processingProgress.percentage=t.percentage||0):"restoring_settings"===t.phase?(this.processingProgress.total=t.total||0,this.processingProgress.percentage=t.percentage||80):"completed"===t.phase?this.processingProgress.percentage=100:"retrying"===t.phase&&(this.processingProgress.message=t.message)},handleError(t){console.error("批量操作错误:",t),this.processingError={message:t.message,suggestion:t.suggestion,recoverable:t.recoverable}},cancelOperation(){this.currentRebuilder&&(this.currentRebuilder.abort(),this.$message.info("正在取消索引重建...")),this.currentBackupGenerator&&(this.currentBackupGenerator.abort(),this.$message.info("正在取消备份...")),this.currentRestoreProcessor&&(this.currentRestoreProcessor.abort(),this.$message.info("正在取消恢复..."))},retryOperation(){this.processingError=null,this.rebuilding?(this.rebuilding=!1,this.isProcessing=!1,this.$nextTick(()=>{this.rebuildIndex()})):this.backing&&(this.backing=!1,this.isProcessing=!1,this.$nextTick(()=>{this.backupData()}))},dismissError(){this.processingError=null}}};const Qc=(0,c.A)(Yc,[["render",Nt],["__scopeId","data-v-68ed43d0"]]);var Gc=Qc,Jc=i(9869),Zc=(i(415),i(3565),i(9267)),td=(i(5616),i(2006)),ed=i(1418),id=(i(333),i(9623)),sd=(i(6711),i(6018)),nd=(i(6808),i(200),i(5558)),ad=(i(8075),i(2687)),od=(i(8785),i(5130));const rd=["onClick"];function ld(t,e,i,a,o,r){const l=(0,s.g2)("font-awesome-icon");return(0,s.uX)(),(0,s.CE)("div",{class:(0,n.C4)(["custom-select",{"is-open":o.isOpen}]),style:(0,n.Tr)({width:i.width})},[(0,s.Lk)("div",{class:"custom-select-trigger",onClick:e[0]||(e[0]=(...t)=>r.toggleDropdown&&r.toggleDropdown(...t))},[(0,s.Lk)("span",{class:(0,n.C4)(["custom-select-value",{"is-placeholder":!i.modelValue}])},(0,n.v_)(r.displayLabel),3),(0,s.bF)(l,{icon:"chevron-down",class:"custom-select-arrow"})]),(0,s.bF)(od.eB,{name:"dropdown-fade"},{default:(0,s.k6)(()=>[(0,s.bo)((0,s.Lk)("div",{class:"custom-select-dropdown",onClick:e[1]||(e[1]=(0,od.D$)(()=>{},["stop"]))},[((0,s.uX)(!0),(0,s.CE)(s.FK,null,(0,s.pI)(i.options,e=>((0,s.uX)(),(0,s.CE)("div",{key:e.value,class:(0,n.C4)(["custom-select-option",{"is-selected":i.modelValue===e.value}]),onClick:t=>r.selectOption(e.value)},[(0,s.RG)(t.$slots,"option",{option:e},()=>[e.icon?((0,s.uX)(),(0,s.Wv)(l,{key:0,icon:e.icon,class:"option-icon"},null,8,["icon"])):(0,s.Q3)("",!0),(0,s.Lk)("span",null,(0,n.v_)(e.label),1)],!0)],10,rd))),128))],512),[[od.aG,o.isOpen]])]),_:3})],6)}var hd={name:"CustomSelect",props:{modelValue:{type:[String,Number],default:""},options:{type:Array,required:!0},placeholder:{type:String,default:"请选择"},width:{type:String,default:"160px"}},emits:["update:modelValue","change"],data(){return{isOpen:!1}},computed:{displayLabel(){const t=this.options.find(t=>t.value===this.modelValue);return t?t.label:this.placeholder}},mounted(){document.addEventListener("click",this.handleClickOutside)},beforeUnmount(){document.removeEventListener("click",this.handleClickOutside)},methods:{toggleDropdown(){this.isOpen=!this.isOpen},selectOption(t){this.$emit("update:modelValue",t),this.$emit("change",t),this.isOpen=!1},handleClickOutside(t){this.$el.contains(t.target)||(this.isOpen=!1)}}};const cd=(0,c.A)(hd,[["render",ld],["__scopeId","data-v-6c59d112"]]);var dd=cd;const ud={class:"upload-settings"},gd={class:"page-header"},pd={class:"first-title"},fd={class:"header-actions"},md={class:"group-header"},bd={class:"group-title"},xd={key:0,class:"load-balance-switch"},yd={key:0,class:"channel-cards"},_d=["onMousemove","onMouseleave"],vd={class:"card-header"},kd={class:"card-title"},wd={class:"channel-name"},Cd={class:"card-body"},Sd={class:"card-info"},Fd={class:"info-item"},Md={class:"info-text"},Ad={key:0,class:"info-item"},Td={class:"info-text"},Pd={key:1,class:"info-item"},Dd=["title"],Ed={class:"info-item"},Ld={class:"info-text"},Id={key:0,class:"info-item"},Vd=["title"],Od={class:"info-item"},Rd={class:"info-text"},Wd={class:"info-item"},Bd={class:"info-text"},zd={class:"info-item"},Nd={class:"info-text"},Ud={key:0,class:"quota-mini"},$d={class:"quota-text"},jd={class:"card-actions"},Hd={key:1,class:"empty-tip"},Xd={class:"form-warning"},qd={class:"quota-label"},Kd={class:"quota-status"};function Yd(t,e,i,a,o,r){const l=(0,s.g2)("font-awesome-icon"),h=p.R7,c=dd,d=k.S2,u=ad.u,g=nd.qi,f=w.ve,m=sd.P9,b=sd.AV,x=td.xE,y=id.WK,v=ed.lq,C=td.US,S=Zc.kZ,F=Jc.MF,M=Jc.TS,A=_.A;return(0,s.bo)(((0,s.uX)(),(0,s.CE)("div",ud,[(0,s.Lk)("div",gd,[(0,s.Lk)("h3",pd,[e[59]||(e[59]=(0,s.eW)(" 上传渠道管理 ",-1)),(0,s.bF)(h,{content:"管理所有上传渠道的配置,点击卡片查看详情或编辑",placement:"right"},{default:(0,s.k6)(()=>[(0,s.bF)(l,{icon:"question-circle",class:"help-icon"})]),_:1})]),(0,s.Lk)("div",fd,[(0,s.bF)(c,{modelValue:o.channelFilter,"onUpdate:modelValue":e[0]||(e[0]=t=>o.channelFilter=t),options:r.filterOptions,placeholder:"筛选渠道类型",width:"160px"},null,8,["modelValue","options"]),(0,s.bF)(d,{type:"primary",onClick:e[1]||(e[1]=t=>o.showAddDialog=!0),class:"add-btn"},{default:(0,s.k6)(()=>[(0,s.bF)(l,{icon:"plus",style:{"margin-right":"6px"}}),e[60]||(e[60]=(0,s.eW)(" 添加渠道 ",-1))]),_:1})])]),((0,s.uX)(!0),(0,s.CE)(s.FK,null,(0,s.pI)(r.filteredChannels,t=>((0,s.uX)(),(0,s.CE)("div",{key:t.value,class:"channel-group"},[(0,s.Lk)("div",md,[(0,s.Lk)("div",bd,[(0,s.bF)(l,{icon:r.getChannelIcon(t.value),class:"group-icon"},null,8,["icon"]),(0,s.Lk)("span",null,(0,n.v_)(t.label),1),(0,s.bF)(u,{size:"small",type:"info",class:"channel-count"},{default:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(r.getChannelList(t.value).length),1)]),_:2},1024)]),r.hasLoadBalance(t.value)?((0,s.uX)(),(0,s.CE)("div",xd,[e[61]||(e[61]=(0,s.Lk)("span",{class:"switch-label"},"负载均衡",-1)),(0,s.bF)(g,{modelValue:r.getSettings(t.value).loadBalance.enabled,"onUpdate:modelValue":e=>r.getSettings(t.value).loadBalance.enabled=e,size:"small",onChange:r.saveSettings},null,8,["modelValue","onUpdate:modelValue","onChange"])])):(0,s.Q3)("",!0)]),r.getChannelList(t.value).length>0?((0,s.uX)(),(0,s.CE)("div",yd,[((0,s.uX)(!0),(0,s.CE)(s.FK,null,(0,s.pI)(r.getChannelList(t.value),(i,a)=>((0,s.uX)(),(0,s.CE)("div",{key:i.name||a,class:(0,n.C4)(["channel-card",[t.value,{disabled:!i.enabled,fixed:i.fixed}]]),onMousemove:e=>r.handleCardMouseMove(e,t.value,a),onMouseleave:e=>r.handleCardMouseLeave(t.value,a)},[(0,s.Lk)("div",{class:"card-glow",ref_for:!0,ref:`glow-${t.value}-${a}`},null,512),(0,s.Lk)("div",vd,[(0,s.Lk)("div",kd,[(0,s.Lk)("span",wd,(0,n.v_)(i.name||"未命名渠道"),1),i.fixed?((0,s.uX)(),(0,s.Wv)(u,{key:0,size:"small",type:"warning"},{default:(0,s.k6)(()=>[...e[62]||(e[62]=[(0,s.eW)("环境变量",-1)])]),_:1})):(0,s.Q3)("",!0)]),(0,s.bF)(g,{modelValue:i.enabled,"onUpdate:modelValue":t=>i.enabled=t,size:"small",onClick:e[2]||(e[2]=(0,od.D$)(()=>{},["stop"])),onChange:r.saveSettings},null,8,["modelValue","onUpdate:modelValue","onChange"])]),(0,s.Lk)("div",Cd,[(0,s.Lk)("div",Sd,["telegram"===t.value?((0,s.uX)(),(0,s.CE)(s.FK,{key:0},[(0,s.Lk)("div",Fd,[(0,s.bF)(l,{icon:"robot",class:"info-icon"}),(0,s.Lk)("span",Md,"Bot: "+(0,n.v_)(r.maskText(i.botToken)),1)]),i.chatId?((0,s.uX)(),(0,s.CE)("div",Ad,[(0,s.bF)(l,{icon:"comments",class:"info-icon"}),(0,s.Lk)("span",Td,"Channel: "+(0,n.v_)(r.maskText(i.chatId)),1)])):(0,s.Q3)("",!0)],64)):"cfr2"===t.value?((0,s.uX)(),(0,s.CE)("div",Pd,[(0,s.bF)(l,{icon:"link",class:"info-icon"}),(0,s.Lk)("span",{class:"info-text",title:i.publicUrl},(0,n.v_)(i.publicUrl||"未设置公开链接"),9,Dd)])):"s3"===t.value?((0,s.uX)(),(0,s.CE)(s.FK,{key:2},[(0,s.Lk)("div",Ed,[(0,s.bF)(l,{icon:"server",class:"info-icon"}),(0,s.Lk)("span",Ld,(0,n.v_)(i.bucketName||"未设置"),1)]),i.endpoint?((0,s.uX)(),(0,s.CE)("div",Id,[(0,s.bF)(l,{icon:"link",class:"info-icon"}),(0,s.Lk)("span",{class:"info-text",title:i.endpoint},(0,n.v_)(i.endpoint),9,Vd)])):(0,s.Q3)("",!0)],64)):"discord"===t.value?((0,s.uX)(),(0,s.CE)(s.FK,{key:3},[(0,s.Lk)("div",Od,[(0,s.bF)(l,{icon:"robot",class:"info-icon"}),(0,s.Lk)("span",Rd,"Bot: "+(0,n.v_)(r.maskText(i.botToken)),1)]),(0,s.Lk)("div",Wd,[(0,s.bF)(l,{icon:"hashtag",class:"info-icon"}),(0,s.Lk)("span",Bd,"Channel: "+(0,n.v_)(r.maskText(i.channelId)),1)]),i.isNitro?((0,s.uX)(),(0,s.Wv)(u,{key:0,size:"small",type:"success"},{default:(0,s.k6)(()=>[...e[63]||(e[63]=[(0,s.eW)("Nitro",-1)])]),_:1})):(0,s.Q3)("",!0)],64)):"huggingface"===t.value?((0,s.uX)(),(0,s.CE)(s.FK,{key:4},[(0,s.Lk)("div",zd,[(0,s.bF)(l,{icon:"database",class:"info-icon"}),(0,s.Lk)("span",Nd,(0,n.v_)(i.repo||"未设置仓库"),1)]),i.isPrivate?((0,s.uX)(),(0,s.Wv)(u,{key:0,size:"small",type:"warning"},{default:(0,s.k6)(()=>[...e[64]||(e[64]=[(0,s.eW)("私有",-1)])]),_:1})):(0,s.Q3)("",!0)],64)):(0,s.Q3)("",!0)]),i.quota?.enabled?((0,s.uX)(),(0,s.CE)("div",Ud,[(0,s.bF)(f,{percentage:r.getQuotaPercentage(i),status:r.getQuotaStatus(i),"stroke-width":6},null,8,["percentage","status"]),(0,s.Lk)("span",$d,(0,n.v_)(r.getQuotaText(i)),1)])):(0,s.Q3)("",!0)]),(0,s.Lk)("div",jd,[(0,s.bF)(d,{text:"",type:"primary",size:"small",onClick:e=>r.openDetailDialog(t.value,a)},{default:(0,s.k6)(()=>[(0,s.bF)(l,{icon:"eye",style:{"margin-right":"4px"}}),e[65]||(e[65]=(0,s.eW)("详情 ",-1))]),_:1},8,["onClick"]),(0,s.bF)(d,{text:"",type:"primary",size:"small",onClick:e=>r.openEditDialog(t.value,a)},{default:(0,s.k6)(()=>[(0,s.bF)(l,{icon:"edit",style:{"margin-right":"4px"}}),e[66]||(e[66]=(0,s.eW)("编辑 ",-1))]),_:1},8,["onClick"]),(0,s.bF)(d,{text:"",type:"danger",size:"small",onClick:e=>r.deleteChannel(t.value,a),disabled:i.fixed},{default:(0,s.k6)(()=>[(0,s.bF)(l,{icon:"trash-alt",style:{"margin-right":"4px"}}),e[67]||(e[67]=(0,s.eW)("删除 ",-1))]),_:1},8,["onClick","disabled"])])],42,_d))),128))])):((0,s.uX)(),(0,s.CE)("div",Hd,[(0,s.bF)(l,{icon:"inbox",class:"empty-icon"}),(0,s.Lk)("span",null,"暂无 "+(0,n.v_)(t.label)+" 渠道",1)]))]))),128)),(0,s.bF)(S,{modelValue:o.showAddDialog,"onUpdate:modelValue":e[26]||(e[26]=t=>o.showAddDialog=t),title:"添加新渠道",class:"channel-dialog","destroy-on-close":"",onClosed:r.resetAddForm},{footer:(0,s.k6)(()=>[(0,s.bF)(d,{onClick:e[25]||(e[25]=t=>o.showAddDialog=!1)},{default:(0,s.k6)(()=>[...e[73]||(e[73]=[(0,s.eW)("取消",-1)])]),_:1}),(0,s.bF)(d,{type:"primary",onClick:r.confirmAddChannel},{default:(0,s.k6)(()=>[...e[74]||(e[74]=[(0,s.eW)("确认添加",-1)])]),_:1},8,["onClick"])]),default:(0,s.k6)(()=>[(0,s.bF)(C,{model:o.newChannel,"label-position":"top",ref:"addForm",rules:o.addRules},{default:(0,s.k6)(()=>[(0,s.bF)(x,{label:"渠道类型",prop:"type"},{default:(0,s.k6)(()=>[(0,s.bF)(b,{modelValue:o.newChannel.type,"onUpdate:modelValue":e[3]||(e[3]=t=>o.newChannel.type=t),placeholder:"请选择渠道类型",style:{width:"100%"},onChange:r.onChannelTypeChange},{default:(0,s.k6)(()=>[((0,s.uX)(!0),(0,s.CE)(s.FK,null,(0,s.pI)(o.addableChannels,t=>((0,s.uX)(),(0,s.Wv)(m,{key:t.value,label:t.label,value:t.value},{default:(0,s.k6)(()=>[(0,s.bF)(l,{icon:r.getChannelIcon(t.value),class:"select-option-icon"},null,8,["icon"]),(0,s.eW)(" "+(0,n.v_)(t.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","onChange"])]),_:1}),(0,s.bF)(x,{label:"渠道名称",prop:"name"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.newChannel.name,"onUpdate:modelValue":e[4]||(e[4]=t=>o.newChannel.name=t),placeholder:"请输入渠道名称"},null,8,["modelValue"])]),_:1}),"telegram"===o.newChannel.type?((0,s.uX)(),(0,s.CE)(s.FK,{key:0},[(0,s.bF)(x,{label:"Bot Token",prop:"botToken"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.newChannel.botToken,"onUpdate:modelValue":e[5]||(e[5]=t=>o.newChannel.botToken=t),type:"password","show-password":"",placeholder:"请输入 Bot Token"},null,8,["modelValue"])]),_:1}),(0,s.bF)(x,{label:"Chat ID",prop:"chatId"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.newChannel.chatId,"onUpdate:modelValue":e[6]||(e[6]=t=>o.newChannel.chatId=t),type:"password","show-password":"",placeholder:"请输入 Chat ID"},null,8,["modelValue"])]),_:1}),(0,s.bF)(x,{label:"代理域名"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.newChannel.proxyUrl,"onUpdate:modelValue":e[7]||(e[7]=t=>o.newChannel.proxyUrl=t),placeholder:"可选,例如: your-proxy.example.com"},null,8,["modelValue"])]),_:1})],64)):"s3"===o.newChannel.type?((0,s.uX)(),(0,s.CE)(s.FK,{key:1},[(0,s.bF)(x,{label:"Endpoint",prop:"endpoint"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.newChannel.endpoint,"onUpdate:modelValue":e[8]||(e[8]=t=>o.newChannel.endpoint=t),placeholder:"例如: https://s3.us-east-005.backblazeb2.com"},null,8,["modelValue"])]),_:1}),(0,s.bF)(x,{label:"CDN 域名"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.newChannel.cdnDomain,"onUpdate:modelValue":e[9]||(e[9]=t=>o.newChannel.cdnDomain=t),placeholder:"如果有 CDN,请配置 CDN 域名,例如:https://cdn.example.com"},null,8,["modelValue"]),e[68]||(e[68]=(0,s.Lk)("span",{class:"form-tip"},"可选配置。配置后将优先通过 CDN 读取文件,提高访问速度和降低成本",-1))]),_:1}),(0,s.bF)(x,{label:"存储桶名称",prop:"bucketName"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.newChannel.bucketName,"onUpdate:modelValue":e[10]||(e[10]=t=>o.newChannel.bucketName=t),placeholder:"请输入存储桶名称"},null,8,["modelValue"])]),_:1}),(0,s.bF)(x,{label:"存储桶区域",prop:"region"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.newChannel.region,"onUpdate:modelValue":e[11]||(e[11]=t=>o.newChannel.region=t),placeholder:"默认填写 auto"},null,8,["modelValue"])]),_:1}),(0,s.bF)(x,{label:"访问密钥 ID",prop:"accessKeyId"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.newChannel.accessKeyId,"onUpdate:modelValue":e[12]||(e[12]=t=>o.newChannel.accessKeyId=t),type:"password","show-password":"",placeholder:"请输入访问密钥 ID"},null,8,["modelValue"])]),_:1}),(0,s.bF)(x,{label:"机密访问密钥",prop:"secretAccessKey"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.newChannel.secretAccessKey,"onUpdate:modelValue":e[13]||(e[13]=t=>o.newChannel.secretAccessKey=t),type:"password","show-password":"",placeholder:"请输入机密访问密钥"},null,8,["modelValue"])]),_:1}),(0,s.bF)(x,{label:"路径风格"},{default:(0,s.k6)(()=>[(0,s.bF)(g,{modelValue:o.newChannel.pathStyle,"onUpdate:modelValue":e[14]||(e[14]=t=>o.newChannel.pathStyle=t)},null,8,["modelValue"]),e[69]||(e[69]=(0,s.Lk)("span",{class:"form-tip"},"使用 OpenList 时需开启",-1))]),_:1}),(0,s.bF)(x,{label:"容量限制"},{default:(0,s.k6)(()=>[(0,s.bF)(g,{modelValue:o.newChannel.quota.enabled,"onUpdate:modelValue":e[15]||(e[15]=t=>o.newChannel.quota.enabled=t)},null,8,["modelValue"])]),_:1}),o.newChannel.quota?.enabled?((0,s.uX)(),(0,s.CE)(s.FK,{key:0},[(0,s.bF)(x,{label:"容量上限 (GB)"},{default:(0,s.k6)(()=>[(0,s.bF)(v,{modelValue:o.newChannel.quota.limitGB,"onUpdate:modelValue":e[16]||(e[16]=t=>o.newChannel.quota.limitGB=t),min:.1,step:1,precision:1},null,8,["modelValue"])]),_:1}),(0,s.bF)(x,{label:"停用阈值 (%)"},{default:(0,s.k6)(()=>[(0,s.bF)(v,{modelValue:o.newChannel.quota.threshold,"onUpdate:modelValue":e[17]||(e[17]=t=>o.newChannel.quota.threshold=t),min:50,max:100,step:5},null,8,["modelValue"])]),_:1})],64)):(0,s.Q3)("",!0)],64)):"discord"===o.newChannel.type?((0,s.uX)(),(0,s.CE)(s.FK,{key:2},[(0,s.bF)(x,{label:"Bot Token",prop:"botToken"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.newChannel.botToken,"onUpdate:modelValue":e[18]||(e[18]=t=>o.newChannel.botToken=t),type:"password","show-password":"",placeholder:"请输入 Bot Token"},null,8,["modelValue"])]),_:1}),(0,s.bF)(x,{label:"Channel ID",prop:"channelId"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.newChannel.channelId,"onUpdate:modelValue":e[19]||(e[19]=t=>o.newChannel.channelId=t),type:"password","show-password":"",placeholder:"请输入 Channel ID"},null,8,["modelValue"])]),_:1}),(0,s.bF)(x,{label:"代理域名"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.newChannel.proxyUrl,"onUpdate:modelValue":e[20]||(e[20]=t=>o.newChannel.proxyUrl=t),placeholder:"可选,例如: your-proxy.example.com"},null,8,["modelValue"])]),_:1}),(0,s.bF)(x,{label:"Nitro 会员"},{default:(0,s.k6)(()=>[(0,s.bF)(g,{modelValue:o.newChannel.isNitro,"onUpdate:modelValue":e[21]||(e[21]=t=>o.newChannel.isNitro=t)},null,8,["modelValue"]),e[70]||(e[70]=(0,s.Lk)("span",{class:"form-tip"},"会员单文件限制 25MB,否则为 10MB",-1))]),_:1}),(0,s.Lk)("div",Xd,[(0,s.bF)(l,{icon:"exclamation-triangle",style:{"margin-right":"6px"}}),e[71]||(e[71]=(0,s.eW)(" Discord 有接口频率限制,不建议将其用作大规模并发场景 ",-1))])],64)):"huggingface"===o.newChannel.type?((0,s.uX)(),(0,s.CE)(s.FK,{key:3},[(0,s.bF)(x,{label:"仓库名",prop:"repo"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.newChannel.repo,"onUpdate:modelValue":e[22]||(e[22]=t=>o.newChannel.repo=t),placeholder:"格式: username/repo-name"},null,8,["modelValue"])]),_:1}),(0,s.bF)(x,{label:"Access Token",prop:"token"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.newChannel.token,"onUpdate:modelValue":e[23]||(e[23]=t=>o.newChannel.token=t),type:"password","show-password":"",placeholder:"请输入 Access Token"},null,8,["modelValue"])]),_:1}),(0,s.bF)(x,{label:"私有仓库"},{default:(0,s.k6)(()=>[(0,s.bF)(g,{modelValue:o.newChannel.isPrivate,"onUpdate:modelValue":e[24]||(e[24]=t=>o.newChannel.isPrivate=t)},null,8,["modelValue"]),e[72]||(e[72]=(0,s.Lk)("span",{class:"form-tip"},"私有仓库限制 100GB",-1))]),_:1})],64)):(0,s.Q3)("",!0)]),_:1},8,["model","rules"])]),_:1},8,["modelValue","onClosed"]),(0,s.bF)(S,{modelValue:o.showDetailDialog,"onUpdate:modelValue":e[28]||(e[28]=t=>o.showDetailDialog=t),title:"渠道详情 - "+(o.currentChannel?.name||""),class:"channel-dialog",onClosed:r.resetDetailData},{footer:(0,s.k6)(()=>[(0,s.bF)(d,{onClick:e[27]||(e[27]=t=>o.showDetailDialog=!1)},{default:(0,s.k6)(()=>[...e[77]||(e[77]=[(0,s.eW)("关闭",-1)])]),_:1}),(0,s.bF)(d,{type:"primary",onClick:r.openEditFromDetail},{default:(0,s.k6)(()=>[...e[78]||(e[78]=[(0,s.eW)("编辑",-1)])]),_:1},8,["onClick"])]),default:(0,s.k6)(()=>[(0,s.bF)(M,{column:1,border:""},{default:(0,s.k6)(()=>[(0,s.bF)(F,{label:"渠道名称"},{default:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(o.currentChannel?.name),1)]),_:1}),(0,s.bF)(F,{label:"渠道类型"},{default:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(r.getChannelTypeLabel(o.currentChannelType)),1)]),_:1}),(0,s.bF)(F,{label:"状态"},{default:(0,s.k6)(()=>[(0,s.bF)(u,{type:o.currentChannel?.enabled?"success":"info"},{default:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(o.currentChannel?.enabled?"已启用":"已禁用"),1)]),_:1},8,["type"])]),_:1}),o.currentChannel?.fixed?((0,s.uX)(),(0,s.Wv)(F,{key:0,label:"配置来源"},{default:(0,s.k6)(()=>[(0,s.bF)(u,{type:"warning"},{default:(0,s.k6)(()=>[...e[75]||(e[75]=[(0,s.eW)("环境变量",-1)])]),_:1})]),_:1})):(0,s.Q3)("",!0),"telegram"===o.currentChannelType?((0,s.uX)(),(0,s.CE)(s.FK,{key:1},[(0,s.bF)(F,{label:"Bot Token"},{default:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(r.maskText(o.currentChannel?.botToken,10)),1)]),_:1}),(0,s.bF)(F,{label:"Chat ID"},{default:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(r.maskText(o.currentChannel?.chatId,6)),1)]),_:1}),(0,s.bF)(F,{label:"代理域名"},{default:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(o.currentChannel?.proxyUrl||"未设置"),1)]),_:1})],64)):"cfr2"===o.currentChannelType?((0,s.uX)(),(0,s.Wv)(F,{key:2,label:"公开访问链接"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{"model-value":o.currentChannel?.publicUrl||"未设置",readonly:""},null,8,["model-value"])]),_:1})):"s3"===o.currentChannelType?((0,s.uX)(),(0,s.CE)(s.FK,{key:3},[(0,s.bF)(F,{label:"Endpoint"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{"model-value":o.currentChannel?.endpoint,readonly:""},null,8,["model-value"])]),_:1}),(0,s.bF)(F,{label:"CDN 域名"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{"model-value":o.currentChannel?.cdnDomain||"未设置",readonly:""},null,8,["model-value"])]),_:1}),(0,s.bF)(F,{label:"存储桶名称"},{default:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(o.currentChannel?.bucketName),1)]),_:1}),(0,s.bF)(F,{label:"存储桶区域"},{default:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(o.currentChannel?.region),1)]),_:1}),(0,s.bF)(F,{label:"路径风格"},{default:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(o.currentChannel?.pathStyle?"是":"否"),1)]),_:1})],64)):"discord"===o.currentChannelType?((0,s.uX)(),(0,s.CE)(s.FK,{key:4},[(0,s.bF)(F,{label:"Bot Token"},{default:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(r.maskText(o.currentChannel?.botToken,10)),1)]),_:1}),(0,s.bF)(F,{label:"Channel ID"},{default:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(r.maskText(o.currentChannel?.channelId,6)),1)]),_:1}),(0,s.bF)(F,{label:"代理域名"},{default:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(o.currentChannel?.proxyUrl||"未设置"),1)]),_:1}),(0,s.bF)(F,{label:"Nitro 会员"},{default:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(o.currentChannel?.isNitro?"是":"否"),1)]),_:1})],64)):"huggingface"===o.currentChannelType?((0,s.uX)(),(0,s.CE)(s.FK,{key:5},[(0,s.bF)(F,{label:"仓库名"},{default:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(o.currentChannel?.repo),1)]),_:1}),(0,s.bF)(F,{label:"私有仓库"},{default:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(o.currentChannel?.isPrivate?"是":"否"),1)]),_:1})],64)):(0,s.Q3)("",!0),o.currentChannel?.quota?.enabled?((0,s.uX)(),(0,s.CE)(s.FK,{key:6},[(0,s.bF)(F,{label:"容量限制"},{default:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(o.currentChannel?.quota?.limitGB)+" GB",1)]),_:1}),(0,s.bF)(F,{label:"停用阈值"},{default:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(o.currentChannel?.quota?.threshold)+"%",1)]),_:1}),(0,s.bF)(F,null,{label:(0,s.k6)(()=>[(0,s.Lk)("span",qd,[e[76]||(e[76]=(0,s.eW)(" 当前用量 ",-1)),(0,s.bF)(d,{link:"",type:"primary",onClick:r.refreshQuota,class:"refresh-btn"},{default:(0,s.k6)(()=>[(0,s.bF)(l,{icon:"sync-alt",class:(0,n.C4)({"fa-spin":o.quotaLoading})},null,8,["class"])]),_:1},8,["onClick"])])]),default:(0,s.k6)(()=>[(0,s.Lk)("div",Kd,[(0,s.bF)(f,{percentage:r.getQuotaPercentage(o.currentChannel),status:r.getQuotaStatus(o.currentChannel),"stroke-width":16,"text-inside":!0,format:()=>r.getQuotaText(o.currentChannel)},null,8,["percentage","status","format"]),(0,s.Lk)("div",{class:(0,n.C4)(["quota-info",{"quota-warning":r.isQuotaExceeded(o.currentChannel)}])},(0,n.v_)(r.getQuotaStatusText(o.currentChannel)),3)])]),_:1})],64)):(0,s.Q3)("",!0)]),_:1})]),_:1},8,["modelValue","title","onClosed"]),(0,s.bF)(S,{modelValue:o.showEditDialog,"onUpdate:modelValue":e[58]||(e[58]=t=>o.showEditDialog=t),title:"编辑渠道 - "+(o.editChannel?.name||""),class:"channel-dialog","destroy-on-close":"",onClosed:r.resetEditData},{footer:(0,s.k6)(()=>[(0,s.bF)(d,{onClick:e[57]||(e[57]=t=>o.showEditDialog=!1)},{default:(0,s.k6)(()=>[...e[80]||(e[80]=[(0,s.eW)("取消",-1)])]),_:1}),(0,s.bF)(d,{type:"primary",onClick:r.confirmEditChannel},{default:(0,s.k6)(()=>[...e[81]||(e[81]=[(0,s.eW)("保存修改",-1)])]),_:1},8,["onClick"])]),default:(0,s.k6)(()=>[(0,s.bF)(C,{model:o.editChannel,"label-position":"top",ref:"editForm",rules:o.editRules},{default:(0,s.k6)(()=>[(0,s.bF)(x,{label:"渠道名称",prop:"name"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.editChannel.name,"onUpdate:modelValue":e[29]||(e[29]=t=>o.editChannel.name=t),disabled:o.editChannel.fixed},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(x,{label:"启用渠道"},{default:(0,s.k6)(()=>[(0,s.bF)(g,{modelValue:o.editChannel.enabled,"onUpdate:modelValue":e[30]||(e[30]=t=>o.editChannel.enabled=t)},null,8,["modelValue"])]),_:1}),"telegram"===o.currentChannelType?((0,s.uX)(),(0,s.CE)(s.FK,{key:0},[(0,s.bF)(x,{label:"Bot Token",prop:"botToken"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.editChannel.botToken,"onUpdate:modelValue":e[31]||(e[31]=t=>o.editChannel.botToken=t),disabled:o.editChannel.fixed,type:"password","show-password":""},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(x,{label:"Chat ID",prop:"chatId"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.editChannel.chatId,"onUpdate:modelValue":e[32]||(e[32]=t=>o.editChannel.chatId=t),disabled:o.editChannel.fixed,type:"password","show-password":""},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(x,{label:"代理域名"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.editChannel.proxyUrl,"onUpdate:modelValue":e[33]||(e[33]=t=>o.editChannel.proxyUrl=t),placeholder:"例如: your-proxy.example.com"},null,8,["modelValue"])]),_:1})],64)):"cfr2"===o.currentChannelType?((0,s.uX)(),(0,s.CE)(s.FK,{key:1},[(0,s.bF)(x,{label:"公开访问链接"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.editChannel.publicUrl,"onUpdate:modelValue":e[34]||(e[34]=t=>o.editChannel.publicUrl=t)},null,8,["modelValue"])]),_:1}),(0,s.bF)(x,{label:"容量限制"},{default:(0,s.k6)(()=>[(0,s.bF)(g,{modelValue:o.editChannel.quota.enabled,"onUpdate:modelValue":e[35]||(e[35]=t=>o.editChannel.quota.enabled=t),onChange:e[36]||(e[36]=t=>r.onQuotaEnabledChange(t,o.editChannel))},null,8,["modelValue"])]),_:1}),o.editChannel.quota?.enabled?((0,s.uX)(),(0,s.CE)(s.FK,{key:0},[(0,s.bF)(x,{label:"容量上限 (GB)"},{default:(0,s.k6)(()=>[(0,s.bF)(v,{modelValue:o.editChannel.quota.limitGB,"onUpdate:modelValue":e[37]||(e[37]=t=>o.editChannel.quota.limitGB=t),min:.1,step:1,precision:1},null,8,["modelValue"])]),_:1}),(0,s.bF)(x,{label:"停用阈值 (%)"},{default:(0,s.k6)(()=>[(0,s.bF)(v,{modelValue:o.editChannel.quota.threshold,"onUpdate:modelValue":e[38]||(e[38]=t=>o.editChannel.quota.threshold=t),min:50,max:100,step:5},null,8,["modelValue"])]),_:1})],64)):(0,s.Q3)("",!0)],64)):"s3"===o.currentChannelType?((0,s.uX)(),(0,s.CE)(s.FK,{key:2},[(0,s.bF)(x,{label:"Endpoint",prop:"endpoint"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.editChannel.endpoint,"onUpdate:modelValue":e[39]||(e[39]=t=>o.editChannel.endpoint=t),disabled:o.editChannel.fixed},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(x,{label:"CDN 域名"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.editChannel.cdnDomain,"onUpdate:modelValue":e[40]||(e[40]=t=>o.editChannel.cdnDomain=t),placeholder:"如果有 CDN,请配置 CDN 域名,例如:https://cdn.example.com"},null,8,["modelValue"]),e[79]||(e[79]=(0,s.Lk)("span",{class:"form-tip"},"可选配置。配置后将优先通过 CDN 读取文件,提高访问速度和降低成本",-1))]),_:1}),(0,s.bF)(x,{label:"存储桶名称",prop:"bucketName"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.editChannel.bucketName,"onUpdate:modelValue":e[41]||(e[41]=t=>o.editChannel.bucketName=t),disabled:o.editChannel.fixed},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(x,{label:"存储桶区域",prop:"region"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.editChannel.region,"onUpdate:modelValue":e[42]||(e[42]=t=>o.editChannel.region=t),disabled:o.editChannel.fixed},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(x,{label:"访问密钥 ID",prop:"accessKeyId"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.editChannel.accessKeyId,"onUpdate:modelValue":e[43]||(e[43]=t=>o.editChannel.accessKeyId=t),disabled:o.editChannel.fixed,type:"password","show-password":""},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(x,{label:"机密访问密钥",prop:"secretAccessKey"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.editChannel.secretAccessKey,"onUpdate:modelValue":e[44]||(e[44]=t=>o.editChannel.secretAccessKey=t),disabled:o.editChannel.fixed,type:"password","show-password":""},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(x,{label:"路径风格"},{default:(0,s.k6)(()=>[(0,s.bF)(g,{modelValue:o.editChannel.pathStyle,"onUpdate:modelValue":e[45]||(e[45]=t=>o.editChannel.pathStyle=t),disabled:o.editChannel.fixed},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(x,{label:"容量限制"},{default:(0,s.k6)(()=>[(0,s.bF)(g,{modelValue:o.editChannel.quota.enabled,"onUpdate:modelValue":e[46]||(e[46]=t=>o.editChannel.quota.enabled=t),onChange:e[47]||(e[47]=t=>r.onQuotaEnabledChange(t,o.editChannel))},null,8,["modelValue"])]),_:1}),o.editChannel.quota?.enabled?((0,s.uX)(),(0,s.CE)(s.FK,{key:0},[(0,s.bF)(x,{label:"容量上限 (GB)"},{default:(0,s.k6)(()=>[(0,s.bF)(v,{modelValue:o.editChannel.quota.limitGB,"onUpdate:modelValue":e[48]||(e[48]=t=>o.editChannel.quota.limitGB=t),min:.1,step:1,precision:1},null,8,["modelValue"])]),_:1}),(0,s.bF)(x,{label:"停用阈值 (%)"},{default:(0,s.k6)(()=>[(0,s.bF)(v,{modelValue:o.editChannel.quota.threshold,"onUpdate:modelValue":e[49]||(e[49]=t=>o.editChannel.quota.threshold=t),min:50,max:100,step:5},null,8,["modelValue"])]),_:1})],64)):(0,s.Q3)("",!0)],64)):"discord"===o.currentChannelType?((0,s.uX)(),(0,s.CE)(s.FK,{key:3},[(0,s.bF)(x,{label:"Bot Token",prop:"botToken"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.editChannel.botToken,"onUpdate:modelValue":e[50]||(e[50]=t=>o.editChannel.botToken=t),disabled:o.editChannel.fixed,type:"password","show-password":""},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(x,{label:"Channel ID",prop:"channelId"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.editChannel.channelId,"onUpdate:modelValue":e[51]||(e[51]=t=>o.editChannel.channelId=t),disabled:o.editChannel.fixed,type:"password","show-password":""},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(x,{label:"代理域名"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.editChannel.proxyUrl,"onUpdate:modelValue":e[52]||(e[52]=t=>o.editChannel.proxyUrl=t),placeholder:"例如: your-proxy.example.com"},null,8,["modelValue"])]),_:1}),(0,s.bF)(x,{label:"Nitro 会员"},{default:(0,s.k6)(()=>[(0,s.bF)(g,{modelValue:o.editChannel.isNitro,"onUpdate:modelValue":e[53]||(e[53]=t=>o.editChannel.isNitro=t)},null,8,["modelValue"])]),_:1})],64)):"huggingface"===o.currentChannelType?((0,s.uX)(),(0,s.CE)(s.FK,{key:4},[(0,s.bF)(x,{label:"仓库名",prop:"repo"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.editChannel.repo,"onUpdate:modelValue":e[54]||(e[54]=t=>o.editChannel.repo=t),disabled:o.editChannel.fixed},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(x,{label:"Access Token",prop:"token"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.editChannel.token,"onUpdate:modelValue":e[55]||(e[55]=t=>o.editChannel.token=t),disabled:o.editChannel.fixed,type:"password","show-password":""},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(x,{label:"私有仓库"},{default:(0,s.k6)(()=>[(0,s.bF)(g,{modelValue:o.editChannel.isPrivate,"onUpdate:modelValue":e[56]||(e[56]=t=>o.editChannel.isPrivate=t)},null,8,["modelValue"])]),_:1})],64)):(0,s.Q3)("",!0)]),_:1},8,["model","rules"])]),_:1},8,["modelValue","title","onClosed"])])),[[A,o.loading]])}var Qd={components:{CustomSelect:dd},data(){return{channelFilter:"",channels:[{value:"telegram",label:"Telegram"},{value:"cfr2",label:"CloudFlare R2"},{value:"s3",label:"S3"},{value:"discord",label:"Discord"},{value:"huggingface",label:"HuggingFace"}],addableChannels:[{value:"telegram",label:"Telegram"},{value:"s3",label:"S3"},{value:"discord",label:"Discord"},{value:"huggingface",label:"HuggingFace"}],telegramSettings:{loadBalance:{enabled:!1},channels:[]},cfr2Settings:{channels:[]},s3Settings:{loadBalance:{enabled:!1},channels:[]},discordSettings:{loadBalance:{enabled:!1},channels:[]},huggingfaceSettings:{loadBalance:{enabled:!1},channels:[]},showAddDialog:!1,showDetailDialog:!1,showEditDialog:!1,currentChannelType:"",currentChannelIndex:-1,currentChannel:null,editChannel:{},newChannel:{type:"",name:"",enabled:!0,botToken:"",chatId:"",proxyUrl:"",endpoint:"",cdnDomain:"",bucketName:"",region:"auto",accessKeyId:"",secretAccessKey:"",pathStyle:!1,quota:{enabled:!1,limitGB:10,threshold:95},channelId:"",isNitro:!1,repo:"",token:"",isPrivate:!1},addRules:{type:[{required:!0,message:"请选择渠道类型",trigger:"change"}],name:[{required:!0,message:"请输入渠道名称",trigger:"blur"},{pattern:/^[\u4e00-\u9fa5a-zA-Z0-9_-]+$/,message:"渠道名称只能包含中英文、数字、下划线和横线",trigger:"blur"}],botToken:[{required:!0,message:"请输入 Bot Token",trigger:"blur"}],chatId:[{required:!0,message:"请输入 Chat ID",trigger:"blur"}],channelId:[{required:!0,message:"请输入 Channel ID",trigger:"blur"}],endpoint:[{required:!0,message:"请输入 Endpoint",trigger:"blur"}],bucketName:[{required:!0,message:"请输入存储桶名称",trigger:"blur"}],region:[{required:!0,message:"请输入存储桶区域",trigger:"blur"}],accessKeyId:[{required:!0,message:"请输入访问密钥 ID",trigger:"blur"}],secretAccessKey:[{required:!0,message:"请输入机密访问密钥",trigger:"blur"}],repo:[{required:!0,message:"请输入仓库名",trigger:"blur"}],token:[{required:!0,message:"请输入 Access Token",trigger:"blur"}]},editRules:{name:[{required:!0,message:"请输入渠道名称",trigger:"blur"},{pattern:/^[\u4e00-\u9fa5a-zA-Z0-9_-]+$/,message:"渠道名称只能包含中英文、数字、下划线和横线",trigger:"blur"}],botToken:[{required:!0,message:"请输入 Bot Token",trigger:"blur"}],chatId:[{required:!0,message:"请输入 Chat ID",trigger:"blur"}],channelId:[{required:!0,message:"请输入 Channel ID",trigger:"blur"}],endpoint:[{required:!0,message:"请输入 Endpoint",trigger:"blur"}],bucketName:[{required:!0,message:"请输入存储桶名称",trigger:"blur"}],region:[{required:!0,message:"请输入存储桶区域",trigger:"blur"}],accessKeyId:[{required:!0,message:"请输入访问密钥 ID",trigger:"blur"}],secretAccessKey:[{required:!0,message:"请输入机密访问密钥",trigger:"blur"}],repo:[{required:!0,message:"请输入仓库名",trigger:"blur"}],token:[{required:!0,message:"请输入 Access Token",trigger:"blur"}]},quotaStats:{},quotaLoading:!1,loading:!1}},computed:{filterOptions(){const t={telegram:"paper-plane",cfr2:"cloud",s3:"database",discord:"comments",huggingface:"robot"};return[{value:"",label:"全部类型"},...this.channels.map(e=>({value:e.value,label:e.label,icon:t[e.value]||"server"}))]},filteredChannels(){return this.channelFilter?this.channels.filter(t=>t.value===this.channelFilter):this.channels}},methods:{handleCardMouseMove(t,e,i){const s=t.currentTarget,n=s.getBoundingClientRect(),a=t.clientX-n.left,o=t.clientY-n.top,r=`glow-${e}-${i}`,l=this.$refs[r];l&&l[0]&&(l[0].style.opacity="1",l[0].style.left=`${a}px`,l[0].style.top=`${o}px`)},handleCardMouseLeave(t,e){const i=`glow-${t}-${e}`,s=this.$refs[i];s&&s[0]&&(s[0].style.opacity="0")},getChannelIcon(t){const e={telegram:"paper-plane",cfr2:"cloud",s3:"database",discord:"comments",huggingface:"robot"};return e[t]||"server"},getChannelTypeLabel(t){const e=this.channels.find(e=>e.value===t);return e?e.label:t},getChannelList(t){return this.getSettings(t)?.channels||[]},getSettings(t){const e={telegram:this.telegramSettings,cfr2:this.cfr2Settings,s3:this.s3Settings,discord:this.discordSettings,huggingface:this.huggingfaceSettings};return e[t]},hasLoadBalance(t){return["telegram","s3","discord","huggingface"].includes(t)},maskText(t,e=4){return t?t.length<=2*e?"****":t.slice(0,e)+"****"+t.slice(-e):"未设置"},openDetailDialog(t,e){this.currentChannelType=t,this.currentChannelIndex=e,this.currentChannel=this.getChannelList(t)[e],this.showDetailDialog=!0},openEditDialog(t,e){this.currentChannelType=t,this.currentChannelIndex=e;const i=this.getChannelList(t)[e];this.editChannel=JSON.parse(JSON.stringify(i)),this.editChannel.quota||(this.editChannel.quota={enabled:!1,limitGB:10,threshold:95}),this.showEditDialog=!0},openEditFromDetail(){this.showDetailDialog=!1,this.openEditDialog(this.currentChannelType,this.currentChannelIndex)},resetAddForm(){this.newChannel={type:"",name:"",enabled:!0,botToken:"",chatId:"",proxyUrl:"",endpoint:"",bucketName:"",region:"auto",accessKeyId:"",secretAccessKey:"",pathStyle:!1,quota:{enabled:!1,limitGB:10,threshold:95},channelId:"",isNitro:!1,repo:"",token:"",isPrivate:!1}},resetDetailData(){this.currentChannel=null},resetEditData(){this.editChannel={}},onChannelTypeChange(){const{type:t,name:e}=this.newChannel;this.newChannel={type:t,name:e,enabled:!0,botToken:"",chatId:"",proxyUrl:"",endpoint:"",cdnDomain:"",bucketName:"",region:"auto",accessKeyId:"",secretAccessKey:"",pathStyle:!1,quota:{enabled:!1,limitGB:10,threshold:95},channelId:"",isNitro:!1,repo:"",token:"",isPrivate:!1}},confirmAddChannel(){this.$refs.addForm.validate(t=>{if(!t)return;const{type:e,name:i}=this.newChannel,s=this.getSettings(e),n=["Telegram_env","R2_env","S3_env","Discord_env","HuggingFace_env"];if(n.includes(i))return void this.$message.warning("该名称为系统保留名称,请使用其他名称");const a=s.channels.some(t=>t.name===i);if(a)return void this.$message.warning("该类型下已存在同名渠道,请使用其他名称");let o={id:s.channels.length+1,name:this.newChannel.name,type:e,savePath:"database",enabled:!0,fixed:!1};"telegram"===e?Object.assign(o,{botToken:this.newChannel.botToken,chatId:this.newChannel.chatId,proxyUrl:this.newChannel.proxyUrl}):"s3"===e?Object.assign(o,{endpoint:this.newChannel.endpoint,cdnDomain:this.newChannel.cdnDomain,bucketName:this.newChannel.bucketName,region:this.newChannel.region,accessKeyId:this.newChannel.accessKeyId,secretAccessKey:this.newChannel.secretAccessKey,pathStyle:this.newChannel.pathStyle,quota:{...this.newChannel.quota}}):"discord"===e?Object.assign(o,{botToken:this.newChannel.botToken,channelId:this.newChannel.channelId,proxyUrl:this.newChannel.proxyUrl,isNitro:this.newChannel.isNitro}):"huggingface"===e&&Object.assign(o,{repo:this.newChannel.repo,token:this.newChannel.token,isPrivate:this.newChannel.isPrivate}),s.channels.push(o),this.showAddDialog=!1,this.saveSettings()})},confirmEditChannel(){this.$refs.editForm.validate(t=>{if(!t)return;const e=this.getSettings(this.currentChannelType),i=this.editChannel.name,s=this.currentChannelIndex,n=this.editChannel.fixed;if(!n){const t=["Telegram_env","R2_env","S3_env","Discord_env","HuggingFace_env"];if(t.includes(i))return void this.$message.warning("该名称为系统保留名称,请使用其他名称");const n=e.channels.some((t,e)=>e!==s&&t.name===i);if(n)return void this.$message.warning("该类型下已存在同名渠道,请使用其他名称")}e.channels[this.currentChannelIndex]={...this.editChannel},this.showEditDialog=!1,this.saveSettings()})},deleteChannel(t,e){const i=this.getChannelList(t)[e];i.fixed?this.$message.warning("环境变量配置的渠道无法删除"):this.$confirm("确定要删除该渠道吗?","提示",{confirmButtonText:"确定",cancelButtonText:"取消",type:"warning"}).then(()=>{const i=this.getSettings(t);i.channels.splice(e,1),i.channels.forEach((t,e)=>{t.id=e+1}),this.saveSettings()}).catch(()=>{})},saveSettings(){const t={telegram:this.telegramSettings,cfr2:this.cfr2Settings,s3:this.s3Settings,discord:this.discordSettings,huggingface:this.huggingfaceSettings};(0,Ut.A)("/api/manage/sysConfig/upload",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(t)}).then(()=>{this.$message.success("设置已保存")})},async refreshQuota(){this.quotaLoading=!0;try{const t=await(0,Ut.A)("/api/manage/quota",{method:"POST"}),e=await t.json();if(e.success)this.quotaStats=e.channelStats||{};else{const t=await(0,Ut.A)("/api/manage/quota"),e=await t.json();e.success&&(this.quotaStats=e.quotaStats||{})}}catch(t){console.error("Failed to refresh quota stats:",t)}finally{this.quotaLoading=!1}},async loadQuotaStats(){try{const t=await(0,Ut.A)("/api/manage/quota"),e=await t.json();e.success&&(this.quotaStats=e.quotaStats||{})}catch(t){console.error("Failed to load quota stats:",t)}},getChannelUsedGB(t){const e=this.quotaStats[t.name];return e?(e.usedMB||0)/1024:0},getQuotaPercentage(t){const e=this.getChannelUsedGB(t),i=t.quota?.limitGB||10,s=e/i*100;return Math.min(100,Math.round(10*s)/10)},getQuotaStatus(t){const e=this.getQuotaPercentage(t),i=t.quota?.threshold||95;return e>=i?"exception":e>=80?"warning":"success"},getQuotaText(t){const e=this.getChannelUsedGB(t),i=t.quota?.limitGB||10;return`${e.toFixed(2)} / ${i} GB`},isQuotaExceeded(t){const e=this.getQuotaPercentage(t),i=t.quota?.threshold||95;return e>=i},getQuotaStatusText(t){const e=this.getQuotaPercentage(t),i=t.quota?.threshold||95;return e>=i?`⚠️ 已达到容量阈值 (${i}%),渠道写入已暂停`:e>=80?"⚡ 容量使用较高,接近阈值":"✓ 容量正常"},async onQuotaEnabledChange(t,e){if(t&&e.name){const t=this.quotaStats[e.name];t||this.$confirm("首次启用容量限制需要统计现有文件容量,这可能需要一些时间。是否立即统计?","初始化容量统计",{confirmButtonText:"立即统计",cancelButtonText:"稍后手动统计",type:"info"}).then(async()=>{await this.recalculateQuota()}).catch(()=>{this.$message.info("您可以稍后点击刷新按钮手动统计")})}},async recalculateQuota(){this.quotaLoading=!0;try{this.$message.info("正在统计容量,请稍候...");const t=await(0,Ut.A)("/api/manage/quota",{method:"POST"}),e=await t.json();e.success?(this.quotaStats=e.channelStats||{},this.$message.success("容量统计完成")):this.$message.error("统计失败: "+(e.error||"未知错误"))}catch(t){console.error("Failed to recalculate quota:",t),this.$message.error("统计失败")}finally{this.quotaLoading=!1}}},mounted(){this.loading=!0,(0,Ut.A)("/api/manage/sysConfig/upload").then(t=>t.json()).then(t=>{this.telegramSettings=t.telegram,t.cfr2&&t.cfr2.channels&&(t.cfr2.channels=t.cfr2.channels.map(t=>({...t,quota:t.quota||{enabled:!1,limitGB:10,threshold:95}}))),this.cfr2Settings=t.cfr2,t.s3&&t.s3.channels&&(t.s3.channels=t.s3.channels.map(t=>({...t,quota:t.quota||{enabled:!1,limitGB:10,threshold:95}}))),this.s3Settings=t.s3,t.discord&&t.discord.channels&&(t.discord.channels=t.discord.channels.map(t=>({...t,proxyUrl:t.proxyUrl||""}))),this.discordSettings=t.discord||{loadBalance:{},channels:[]},t.huggingface&&t.huggingface.channels&&(t.huggingface.channels=t.huggingface.channels.map(t=>({...t,isPrivate:t.isPrivate||!1}))),this.huggingfaceSettings=t.huggingface||{loadBalance:{},channels:[]},this.loadQuotaStats()}).finally(()=>{this.loading=!1})}};const Gd=(0,c.A)(Qd,[["render",Yd],["__scopeId","data-v-89234e52"]]);var Jd=Gd,Zd=i(850);i(8736);const tu={class:"save-text"};function eu(t,e,i,a,o,r){const l=(0,s.g2)("font-awesome-icon");return(0,s.uX)(),(0,s.Wv)(od.eB,{name:"fade-up"},{default:(0,s.k6)(()=>[(0,s.bo)((0,s.Lk)("div",{class:(0,n.C4)(["floating-save-btn",{"is-loading":i.loading}]),onClick:e[0]||(e[0]=(...t)=>r.handleClick&&r.handleClick(...t))},[i.loading?((0,s.uX)(),(0,s.Wv)(l,{key:0,icon:"spinner",spin:""})):((0,s.uX)(),(0,s.Wv)(l,{key:1,icon:"save"})),(0,s.Lk)("span",tu,(0,n.v_)(i.loading?"保存中":"保存"),1)],2),[[od.aG,o.visible]])]),_:1})}var iu={name:"FloatingSaveButton",props:{loading:{type:Boolean,default:!1},show:{type:Boolean,default:!0}},data(){return{visible:!1}},watch:{show:{immediate:!0,handler(t){t?setTimeout(()=>{this.visible=!0},600):this.visible=!1}}},methods:{handleClick(){this.loading||this.$emit("click")}}};const su=(0,c.A)(iu,[["render",eu],["__scopeId","data-v-27fc6cc8"]]);var nu=su,au=i(7138);i(5802),i(4752);const ou={class:"security-settings"},ru={class:"first-settings"},lu={class:"second-title token-title"},hu={class:"token-actions"},cu={class:"token-table-container"},du={class:"table-cell-content"},uu={class:"table-cell-content"},gu={class:"token-display"},pu={class:"table-cell-content"},fu={class:"table-cell-content"},mu={class:"table-cell-content action-buttons"},bu={class:"first-settings"},xu={class:"second-title"},yu={class:"first-settings"},_u={class:"dialog-footer"},vu={class:"dialog-footer"},ku={class:"token-result"},wu={style:{"margin-bottom":"15px",color:"#e6a23c"}},Cu={class:"dialog-footer"};function Su(t,e,i,a,o,r){const l=id.WK,h=td.xE,c=td.US,d=(0,s.g2)("font-awesome-icon"),u=k.S2,g=au.o8,f=ad.u,m=au.Up,b=p.R7,x=nd.qi,y=sd.P9,v=sd.AV,w=nu,C=Zd.dI,S=Zd.o5,F=Zc.kZ,M=_.A;return(0,s.bo)(((0,s.uX)(),(0,s.CE)("div",ou,[(0,s.Lk)("div",ru,[e[26]||(e[26]=(0,s.Lk)("h3",{class:"first-title"},"认证管理",-1)),e[27]||(e[27]=(0,s.Lk)("h4",{class:"second-title"},"用户端认证",-1)),(0,s.bF)(c,{model:o.authSettings.user,rules:o.userPassRules,ref:"userPassForm","label-width":"120px"},{default:(0,s.k6)(()=>[(0,s.bF)(h,{label:"上传密码",prop:"authCode"},{default:(0,s.k6)(()=>[(0,s.bF)(l,{modelValue:o.authSettings.user.authCode,"onUpdate:modelValue":e[0]||(e[0]=t=>o.authSettings.user.authCode=t),type:"password","show-password":"",onInput:r.handleUserPassInput,autocomplete:"new-password"},null,8,["modelValue","onInput"])]),_:1}),(0,s.bF)(od.eB,{name:"fade-slide",mode:"out-in"},{default:(0,s.k6)(()=>[o.showUserPassConfirm?((0,s.uX)(),(0,s.Wv)(h,{label:"确认密码",prop:"confirmNewUserPassword",key:"user-confirm"},{default:(0,s.k6)(()=>[(0,s.bF)(l,{modelValue:o.authSettings.user.confirmNewUserPassword,"onUpdate:modelValue":e[1]||(e[1]=t=>o.authSettings.user.confirmNewUserPassword=t),type:"password","show-password":"",autocomplete:"new-password"},null,8,["modelValue"])]),_:1})):(0,s.Q3)("",!0)]),_:1})]),_:1},8,["model","rules"]),e[28]||(e[28]=(0,s.Lk)("h4",{class:"second-title"},"管理端认证",-1)),(0,s.bF)(c,{model:o.authSettings.admin,rules:o.adminPassRules,ref:"adminPassForm","label-width":"120px"},{default:(0,s.k6)(()=>[(0,s.bF)(h,{label:"用户名",prop:"adminUsername"},{default:(0,s.k6)(()=>[(0,s.bF)(l,{modelValue:o.authSettings.admin.adminUsername,"onUpdate:modelValue":e[2]||(e[2]=t=>o.authSettings.admin.adminUsername=t),autocomplete:"new-password"},null,8,["modelValue"])]),_:1}),(0,s.bF)(h,{label:"密码",prop:"adminPassword"},{default:(0,s.k6)(()=>[(0,s.bF)(l,{modelValue:o.authSettings.admin.adminPassword,"onUpdate:modelValue":e[3]||(e[3]=t=>o.authSettings.admin.adminPassword=t),type:"password","show-password":"",onInput:r.handleAdminPassInput,autocomplete:"new-password"},null,8,["modelValue","onInput"])]),_:1}),(0,s.bF)(od.eB,{name:"fade-slide",mode:"out-in"},{default:(0,s.k6)(()=>[o.showAdminPassConfirm?((0,s.uX)(),(0,s.Wv)(h,{label:"确认密码",prop:"confirmNewAdminPassword",key:"admin-confirm"},{default:(0,s.k6)(()=>[(0,s.bF)(l,{modelValue:o.authSettings.admin.confirmNewAdminPassword,"onUpdate:modelValue":e[4]||(e[4]=t=>o.authSettings.admin.confirmNewAdminPassword=t),type:"password","show-password":"",autocomplete:"new-password"},null,8,["modelValue"])]),_:1})):(0,s.Q3)("",!0)]),_:1})]),_:1},8,["model","rules"]),(0,s.Lk)("h4",lu,[e[23]||(e[23]=(0,s.eW)("API Token 管理 ",-1)),(0,s.Lk)("a",hu,[(0,s.bF)(u,{type:"primary",size:"small",onClick:e[5]||(e[5]=t=>o.showCreateTokenDialog=!0),circle:""},{default:(0,s.k6)(()=>[(0,s.bF)(d,{icon:"plus"})]),_:1})])]),(0,s.Lk)("div",cu,[(0,s.bo)(((0,s.uX)(),(0,s.Wv)(m,{data:o.apiTokens,class:"token-table"},{default:(0,s.k6)(()=>[(0,s.bF)(g,{prop:"name",label:"名称","header-align":"center"},{default:(0,s.k6)(t=>[(0,s.Lk)("div",du,(0,n.v_)(t.row.name),1)]),_:1}),(0,s.bF)(g,{prop:"token",label:"Token","header-align":"center"},{default:(0,s.k6)(t=>[(0,s.Lk)("div",uu,[(0,s.Lk)("span",gu,(0,n.v_)(t.row.token),1)])]),_:1}),(0,s.bF)(g,{prop:"permissions",label:"权限","header-align":"center"},{default:(0,s.k6)(t=>[(0,s.Lk)("div",pu,[((0,s.uX)(!0),(0,s.CE)(s.FK,null,(0,s.pI)(t.row.permissions,t=>((0,s.uX)(),(0,s.Wv)(f,{key:t,size:"small",class:"permission-tag"},{default:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(r.getPermissionText(t)),1)]),_:2},1024))),128))])]),_:1}),(0,s.bF)(g,{prop:"createdAt",label:"创建时间","header-align":"center"},{default:(0,s.k6)(t=>[(0,s.Lk)("div",fu,(0,n.v_)(r.formatDate(t.row.createdAt)),1)]),_:1}),(0,s.bF)(g,{label:"操作",fixed:"right","header-align":"center"},{default:(0,s.k6)(t=>[(0,s.Lk)("div",mu,[(0,s.bF)(u,{class:"action-button",size:"small",onClick:e=>r.editToken(t.row)},{default:(0,s.k6)(()=>[...e[24]||(e[24]=[(0,s.eW)("编辑",-1)])]),_:1},8,["onClick"]),(0,s.bF)(u,{class:"action-button",size:"small",type:"danger",onClick:e=>r.deleteToken(t.row.id)},{default:(0,s.k6)(()=>[...e[25]||(e[25]=[(0,s.eW)("删除",-1)])]),_:1},8,["onClick"])])]),_:1})]),_:1},8,["data"])),[[M,o.tokenLoading]])])]),(0,s.Lk)("div",bu,[e[30]||(e[30]=(0,s.Lk)("h3",{class:"first-title"},"上传管理",-1)),(0,s.Lk)("h4",xu,[e[29]||(e[29]=(0,s.eW)("图像审查 ",-1)),(0,s.bF)(b,{content:"仅对非分块上传文件生效,支持 nsfwjs 和 moderatecontent.com 渠道",placement:"top"},{default:(0,s.k6)(()=>[(0,s.bF)(d,{icon:"question-circle",style:{"margin-left":"5px",cursor:"pointer"}})]),_:1})]),(0,s.bF)(c,{model:o.uploadSettings.moderate,"label-width":"120px"},{default:(0,s.k6)(()=>[(0,s.bF)(h,{label:"开启审查"},{default:(0,s.k6)(()=>[(0,s.bF)(x,{modelValue:o.uploadSettings.moderate.enabled,"onUpdate:modelValue":e[6]||(e[6]=t=>o.uploadSettings.moderate.enabled=t)},null,8,["modelValue"])]),_:1}),(0,s.bF)(h,{label:"审查渠道"},{default:(0,s.k6)(()=>[(0,s.bF)(v,{modelValue:o.uploadSettings.moderate.channel,"onUpdate:modelValue":e[7]||(e[7]=t=>o.uploadSettings.moderate.channel=t),placeholder:"请选择审查渠道"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{label:"moderatecontent.com",value:"moderatecontent.com"}),(0,s.bF)(y,{label:"nsfwjs",value:"nsfwjs"})]),_:1},8,["modelValue"])]),_:1}),"moderatecontent.com"===o.uploadSettings.moderate.channel?((0,s.uX)(),(0,s.Wv)(h,{key:0,label:"API Key"},{default:(0,s.k6)(()=>[(0,s.bF)(l,{modelValue:o.uploadSettings.moderate.moderateContentApiKey,"onUpdate:modelValue":e[8]||(e[8]=t=>o.uploadSettings.moderate.moderateContentApiKey=t)},null,8,["modelValue"])]),_:1})):(0,s.Q3)("",!0),"nsfwjs"===o.uploadSettings.moderate.channel?((0,s.uX)(),(0,s.Wv)(h,{key:1,label:"API 路径"},{default:(0,s.k6)(()=>[(0,s.bF)(l,{modelValue:o.uploadSettings.moderate.nsfwApiPath,"onUpdate:modelValue":e[9]||(e[9]=t=>o.uploadSettings.moderate.nsfwApiPath=t),placeholder:"https://nsfwjs.your.domain"},null,8,["modelValue"])]),_:1})):(0,s.Q3)("",!0)]),_:1},8,["model"])]),(0,s.Lk)("div",yu,[e[33]||(e[33]=(0,s.Lk)("h3",{class:"first-title"},"访问管理",-1)),e[34]||(e[34]=(0,s.Lk)("h4",{class:"second-title"},"域名过滤",-1)),(0,s.bF)(c,{model:o.accessSettings,"label-width":"120px"},{default:(0,s.k6)(()=>[(0,s.bF)(h,null,{label:(0,s.k6)(()=>[e[31]||(e[31]=(0,s.eW)(" 放行域名 ",-1)),(0,s.bF)(b,{content:"1.针对访问域名设置权限
2.留空默认全部放行,多个域名请用英文逗号分隔",placement:"top","raw-content":""},{default:(0,s.k6)(()=>[(0,s.bF)(d,{icon:"question-circle",style:{"margin-left":"5px",cursor:"pointer"}})]),_:1})]),default:(0,s.k6)(()=>[(0,s.bF)(l,{modelValue:o.accessSettings.allowedDomains,"onUpdate:modelValue":e[10]||(e[10]=t=>o.accessSettings.allowedDomains=t)},null,8,["modelValue"])]),_:1})]),_:1},8,["model"]),e[35]||(e[35]=(0,s.Lk)("h4",{class:"second-title"},"白名单模式",-1)),(0,s.bF)(c,{model:o.accessSettings,"label-width":"120px"},{default:(0,s.k6)(()=>[(0,s.bF)(h,null,{label:(0,s.k6)(()=>[e[32]||(e[32]=(0,s.eW)(" 是否开启 ",-1)),(0,s.bF)(b,{content:"1.针对文件设置权限
2.开启后,仅被加入白名单的文件可被访问",placement:"top","raw-content":""},{default:(0,s.k6)(()=>[(0,s.bF)(d,{icon:"question-circle",style:{"margin-left":"5px",cursor:"pointer"}})]),_:1})]),default:(0,s.k6)(()=>[(0,s.bF)(x,{modelValue:o.accessSettings.whiteListMode,"onUpdate:modelValue":e[11]||(e[11]=t=>o.accessSettings.whiteListMode=t)},null,8,["modelValue"])]),_:1})]),_:1},8,["model"])]),(0,s.bF)(w,{show:!o.loading,onClick:r.saveSettings},null,8,["show","onClick"]),(0,s.bF)(F,{modelValue:o.showCreateTokenDialog,"onUpdate:modelValue":e[15]||(e[15]=t=>o.showCreateTokenDialog=t),title:"创建新 API Token",width:r.dialogWidth},{footer:(0,s.k6)(()=>[(0,s.Lk)("span",_u,[(0,s.bF)(u,{onClick:e[14]||(e[14]=t=>o.showCreateTokenDialog=!1)},{default:(0,s.k6)(()=>[...e[39]||(e[39]=[(0,s.eW)("取消",-1)])]),_:1}),(0,s.bF)(u,{type:"primary",onClick:r.createToken},{default:(0,s.k6)(()=>[...e[40]||(e[40]=[(0,s.eW)("创建",-1)])]),_:1},8,["onClick"])])]),default:(0,s.k6)(()=>[(0,s.bF)(c,{model:o.newToken,rules:o.tokenRules,ref:"tokenForm","label-width":"100px"},{default:(0,s.k6)(()=>[(0,s.bF)(h,{label:"Token 名称",prop:"name"},{default:(0,s.k6)(()=>[(0,s.bF)(l,{modelValue:o.newToken.name,"onUpdate:modelValue":e[12]||(e[12]=t=>o.newToken.name=t),placeholder:"请输入Token名称"},null,8,["modelValue"])]),_:1}),(0,s.bF)(h,{label:"权限",prop:"permissions"},{default:(0,s.k6)(()=>[(0,s.bF)(S,{modelValue:o.newToken.permissions,"onUpdate:modelValue":e[13]||(e[13]=t=>o.newToken.permissions=t)},{default:(0,s.k6)(()=>[(0,s.bF)(C,{label:"upload"},{default:(0,s.k6)(()=>[...e[36]||(e[36]=[(0,s.eW)("上传",-1)])]),_:1}),(0,s.bF)(C,{label:"delete"},{default:(0,s.k6)(()=>[...e[37]||(e[37]=[(0,s.eW)("删除",-1)])]),_:1}),(0,s.bF)(C,{label:"list"},{default:(0,s.k6)(()=>[...e[38]||(e[38]=[(0,s.eW)("列出",-1)])]),_:1})]),_:1},8,["modelValue"])]),_:1})]),_:1},8,["model","rules"])]),_:1},8,["modelValue","width"]),(0,s.bF)(F,{modelValue:o.showEditTokenDialog,"onUpdate:modelValue":e[19]||(e[19]=t=>o.showEditTokenDialog=t),title:"编辑 API Token",width:r.dialogWidth},{footer:(0,s.k6)(()=>[(0,s.Lk)("span",vu,[(0,s.bF)(u,{onClick:e[18]||(e[18]=t=>o.showEditTokenDialog=!1)},{default:(0,s.k6)(()=>[...e[44]||(e[44]=[(0,s.eW)("取消",-1)])]),_:1}),(0,s.bF)(u,{type:"primary",onClick:r.updateToken},{default:(0,s.k6)(()=>[...e[45]||(e[45]=[(0,s.eW)("更新",-1)])]),_:1},8,["onClick"])])]),default:(0,s.k6)(()=>[(0,s.bF)(c,{model:o.editingToken,rules:o.tokenRules,ref:"editTokenForm","label-width":"100px"},{default:(0,s.k6)(()=>[(0,s.bF)(h,{label:"Token 名称"},{default:(0,s.k6)(()=>[(0,s.bF)(l,{modelValue:o.editingToken.name,"onUpdate:modelValue":e[16]||(e[16]=t=>o.editingToken.name=t),disabled:""},null,8,["modelValue"])]),_:1}),(0,s.bF)(h,{label:"权限",prop:"permissions"},{default:(0,s.k6)(()=>[(0,s.bF)(S,{modelValue:o.editingToken.permissions,"onUpdate:modelValue":e[17]||(e[17]=t=>o.editingToken.permissions=t)},{default:(0,s.k6)(()=>[(0,s.bF)(C,{label:"upload"},{default:(0,s.k6)(()=>[...e[41]||(e[41]=[(0,s.eW)("上传",-1)])]),_:1}),(0,s.bF)(C,{label:"delete"},{default:(0,s.k6)(()=>[...e[42]||(e[42]=[(0,s.eW)("删除",-1)])]),_:1}),(0,s.bF)(C,{label:"list"},{default:(0,s.k6)(()=>[...e[43]||(e[43]=[(0,s.eW)("列出",-1)])]),_:1})]),_:1},8,["modelValue"])]),_:1})]),_:1},8,["model","rules"])]),_:1},8,["modelValue","width"]),(0,s.bF)(F,{modelValue:o.showTokenResultDialog,"onUpdate:modelValue":e[22]||(e[22]=t=>o.showTokenResultDialog=t),title:"Token 创建成功",width:r.dialogWidth},{footer:(0,s.k6)(()=>[(0,s.Lk)("span",Cu,[(0,s.bF)(u,{type:"primary",onClick:e[21]||(e[21]=t=>o.showTokenResultDialog=!1)},{default:(0,s.k6)(()=>[...e[48]||(e[48]=[(0,s.eW)("我已保存",-1)])]),_:1})])]),default:(0,s.k6)(()=>[(0,s.Lk)("div",ku,[(0,s.Lk)("p",wu,[(0,s.bF)(d,{icon:"exclamation-triangle",style:{"margin-right":"5px"}}),e[46]||(e[46]=(0,s.eW)(" 请妥善保存以下Token,关闭此窗口后将无法再次查看完整Token! ",-1))]),(0,s.bF)(c,{"label-width":"100px"},{default:(0,s.k6)(()=>[(0,s.bF)(h,{label:"Token 名称"},{default:(0,s.k6)(()=>[(0,s.Lk)("span",null,(0,n.v_)(o.createdToken.name),1)]),_:1}),(0,s.bF)(h,{label:"完整Token"},{default:(0,s.k6)(()=>[(0,s.bF)(l,{modelValue:o.createdToken.token,"onUpdate:modelValue":e[20]||(e[20]=t=>o.createdToken.token=t),readonly:""},{append:(0,s.k6)(()=>[(0,s.bF)(u,{onClick:r.copyToken},{default:(0,s.k6)(()=>[...e[47]||(e[47]=[(0,s.eW)("复制",-1)])]),_:1},8,["onClick"])]),_:1},8,["modelValue"])]),_:1})]),_:1})])]),_:1},8,["modelValue","width"])])),[[M,o.loading]])}i(1148);var Fu={components:{FloatingSaveButton:nu},data(){return{authSettings:{user:{},admin:{}},uploadSettings:{moderate:{}},accessSettings:{},apiTokens:[],loading:!0,tokenLoading:!1,oriUserPassword:"",oriAdminPassword:"",showUserPassConfirm:!1,showAdminPassConfirm:!1,showCreateTokenDialog:!1,showEditTokenDialog:!1,showTokenResultDialog:!1,newToken:{name:"",owner:"",permissions:[]},editingToken:{id:"",name:"",owner:"",permissions:[]},createdToken:{name:"",token:""},userPassRules:{authCode:[{validator:(t,e,i)=>{const s=["%","&","?","#","/"],n=s.some(t=>e&&e.includes(t));n?i(new Error("密码不能包含部分URL保留字符: % & ? # /")):i()},trigger:"blur"}],confirmNewUserPassword:[{message:"请再次输入上传密码",trigger:"blur"},{validator:(t,e,i)=>{e&&e!==this.authSettings.user.authCode?i(new Error("两次输入密码不一致")):i()},trigger:"blur"}]},adminPassRules:{confirmNewAdminPassword:[{message:"请再次输入管理密码",trigger:"blur"},{validator:(t,e,i)=>{e&&e!==this.authSettings.admin.adminPassword?i(new Error("两次输入密码不一致")):i()},trigger:"blur"}]},tokenRules:{name:[{required:!0,message:"请输入Token名称",trigger:"blur"}],permissions:[{required:!0,message:"请选择权限",trigger:"change"}]}}},computed:{dialogWidth(){return window.innerWidth>768?"50%":"90%"}},methods:{handleUserPassInput(){this.authSettings.user.authCode!==this.oriUserPassword?this.showUserPassConfirm=!0:this.showUserPassConfirm=!1},handleAdminPassInput(){this.authSettings.admin.adminPassword!==this.oriAdminPassword?this.showAdminPassConfirm=!0:this.showAdminPassConfirm=!1},getPermissionText(t){const e={upload:"上传",delete:"删除",list:"列出"};return e[t]||t},formatDate(t){return new Date(t).toLocaleString("zh-CN")},async loadApiTokens(){this.tokenLoading=!0;try{const t=await(0,Ut.A)("/api/manage/apiTokens"),e=await t.json();this.apiTokens=e.tokens||[]}catch(t){this.$message.error("获取Token列表失败")}finally{this.tokenLoading=!1}},createToken(){this.$refs.tokenForm.validate(async t=>{if(t)try{this.newToken.owner="admin";const t=await(0,Ut.A)("/api/manage/apiTokens",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(this.newToken)}),e=await t.json();t.ok?(this.createdToken={name:e.name,token:e.token},this.showCreateTokenDialog=!1,this.showTokenResultDialog=!0,this.newToken={name:"",owner:"",permissions:[]},await this.loadApiTokens(),this.$message.success("Token创建成功")):this.$message.error(e.error||"Token创建失败")}catch(e){this.$message.error("Token创建失败")}})},editToken(t){this.editingToken={id:t.id,name:t.name,owner:t.owner,permissions:[...t.permissions]},this.showEditTokenDialog=!0},updateToken(){this.$refs.editTokenForm.validate(async t=>{if(t)try{const t=await(0,Ut.A)("/api/manage/apiTokens",{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify({tokenId:this.editingToken.id,permissions:this.editingToken.permissions})}),e=await t.json();t.ok?(this.showEditTokenDialog=!1,await this.loadApiTokens(),this.$message.success("Token权限更新成功")):this.$message.error(e.error||"Token更新失败")}catch(e){this.$message.error("Token更新失败")}})},async deleteToken(t){try{await this.$confirm("此操作将永久删除该Token,是否继续?","提示",{confirmButtonText:"确定",cancelButtonText:"取消",type:"warning"});const e=await(0,Ut.A)(`/api/manage/apiTokens?id=${t}`,{method:"DELETE"}),i=await e.json();e.ok?(await this.loadApiTokens(),this.$message.success("Token删除成功")):this.$message.error(i.error||"Token删除失败")}catch(e){"cancel"!==e&&this.$message.error("Token删除失败")}},async copyToken(){try{await navigator.clipboard.writeText(this.createdToken.token),this.$message.success("Token已复制到剪贴板")}catch(t){this.$message.error("复制失败,请手动复制")}},saveSettings(){let t=[];t.push(new Promise(t=>{this.$refs.userPassForm.validate(e=>{t(e)})})),t.push(new Promise(t=>{this.$refs.adminPassForm.validate(e=>{t(e)})})),Promise.all(t).then(t=>{const e=t.every(t=>t);if(!e)return;const i={auth:this.authSettings,upload:this.uploadSettings,access:this.accessSettings};delete i.auth.user.confirmNewUserPassword,delete i.auth.admin.confirmNewAdminPassword,(0,Ut.A)("/api/manage/sysConfig/security",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(i)}).then(()=>{this.$message.success("设置已保存"),this.oriUserPassword=this.authSettings.user.authCode,this.oriAdminPassword=this.authSettings.admin.adminPassword,this.showUserPassConfirm=!1,this.showAdminPassConfirm=!1})})}},mounted(){this.loading=!0,(0,Ut.A)("/api/manage/sysConfig/security").then(t=>t.json()).then(t=>{this.authSettings=t.auth,this.uploadSettings=t.upload,this.accessSettings=t.access,this.oriUserPassword=this.authSettings.user.authCode,this.oriAdminPassword=this.authSettings.admin.adminPassword,this.authSettings.user.confirmNewUserPassword="",this.authSettings.admin.confirmNewAdminPassword="",this.loadApiTokens()}).finally(()=>{this.loading=!1})}};const Mu=(0,c.A)(Fu,[["render",Su],["__scopeId","data-v-fdf607e4"]]);var Au=Mu;const Tu={class:"page-settings"},Pu={class:"first-title"};function Du(t,e,i,a,o,r){const l=(0,s.g2)("font-awesome-icon"),h=p.R7,c=sd.P9,d=sd.AV,u=nd.qi,g=id.WK,f=td.xE,m=td.US,b=nu,x=_.A;return(0,s.bo)(((0,s.uX)(),(0,s.CE)("div",Tu,[((0,s.uX)(!0),(0,s.CE)(s.FK,null,(0,s.pI)(r.groupedSettings,(t,e)=>((0,s.uX)(),(0,s.CE)("div",{key:e,class:"first-settings"},[(0,s.Lk)("h3",Pu,(0,n.v_)(e),1),(0,s.bF)(m,{model:o.settings,"label-width":"150px"},{default:(0,s.k6)(()=>[((0,s.uX)(!0),(0,s.CE)(s.FK,null,(0,s.pI)(t,(t,e)=>((0,s.uX)(),(0,s.Wv)(f,{key:t.id},{label:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(t.label)+" ",1),t.tooltip?((0,s.uX)(),(0,s.Wv)(h,{key:0,content:t.tooltip,placement:"top","raw-content":""},{default:(0,s.k6)(()=>[(0,s.bF)(l,{icon:"question-circle",style:{"margin-left":"5px",cursor:"pointer"}})]),_:1},8,["content"])):(0,s.Q3)("",!0)]),default:(0,s.k6)(()=>["select"===t.type?((0,s.uX)(),(0,s.Wv)(d,{key:0,modelValue:t.value,"onUpdate:modelValue":e=>t.value=e,disabled:t.fixed,placeholder:t.placeholder,style:{width:"100%"}},{default:(0,s.k6)(()=>[((0,s.uX)(!0),(0,s.CE)(s.FK,null,(0,s.pI)(t.options,t=>((0,s.uX)(),(0,s.Wv)(c,{key:t.value,label:t.label,value:t.value},null,8,["label","value"]))),128))]),_:2},1032,["modelValue","onUpdate:modelValue","disabled","placeholder"])):"channelName"===t.type?((0,s.uX)(),(0,s.Wv)(d,{key:1,modelValue:t.value,"onUpdate:modelValue":e=>t.value=e,disabled:!r.currentUploadChannel||0===r.currentChannelList.length,placeholder:"请先选择上传渠道",clearable:"",style:{width:"100%"}},{default:(0,s.k6)(()=>[((0,s.uX)(!0),(0,s.CE)(s.FK,null,(0,s.pI)(r.currentChannelList,t=>((0,s.uX)(),(0,s.Wv)(c,{key:t.name,label:t.name,value:t.name},null,8,["label","value"]))),128))]),_:1},8,["modelValue","onUpdate:modelValue","disabled"])):"boolean"===t.type?((0,s.uX)(),(0,s.Wv)(u,{key:2,modelValue:t.value,"onUpdate:modelValue":e=>t.value=e,disabled:t.fixed},null,8,["modelValue","onUpdate:modelValue","disabled"])):((0,s.uX)(),(0,s.Wv)(g,{key:3,modelValue:t.value,"onUpdate:modelValue":e=>t.value=e,disabled:t.fixed,placeholder:t.placeholder},null,8,["modelValue","onUpdate:modelValue","disabled","placeholder"]))]),_:2},1024))),128))]),_:2},1032,["model"])]))),128)),(0,s.bF)(b,{show:!o.loading,onClick:r.saveSettings},null,8,["show","onClick"])])),[[x,o.loading]])}var Eu=i(457),Lu={components:{FloatingSaveButton:nu},data(){return{settings:{config:[]},loading:!0,availableChannels:{}}},computed:{groupedSettings(){const t={};return this.settings.config&&this.settings.config.forEach(e=>{const i=e.category||"其他设置";t[i]||(t[i]=[]),t[i].push(e)}),t},currentUploadChannel(){const t=this.settings.config?.find(t=>"defaultUploadChannel"===t.id);return t?.value||""},currentChannelList(){return this.availableChannels[this.currentUploadChannel]||[]}},watch:{currentUploadChannel(t,e){if(t!==e){const e=this.settings.config?.find(t=>"defaultChannelName"===t.id);if(e){const i=this.availableChannels[t]||[];i.some(t=>t.name===e.value)||(e.value="")}}}},methods:{saveSettings(){(0,Ut.A)("/api/manage/sysConfig/page",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(this.settings)}).then(()=>this.$message.success("设置已保存"))},async fetchAvailableChannels(){try{const t=await Eu.A.get("/api/channels");t.data&&(this.availableChannels=t.data)}catch(t){console.error("Failed to fetch available channels:",t)}}},mounted(){this.loading=!0,this.fetchAvailableChannels(),(0,Ut.A)("/api/manage/sysConfig/page").then(t=>t.json()).then(t=>{this.settings=t,this.settings.config&&this.settings.config.forEach(t=>{"boolean"===t.type&&("string"===typeof t.value?t.value="true"===t.value:void 0!==t.value&&null!==t.value||(t.value=t.default||!1))})}).finally(()=>{this.loading=!1})}};const Iu=(0,c.A)(Lu,[["render",Du],["__scopeId","data-v-44bd640d"]]);var Vu=Iu;const Ou={class:"others-settings"},Ru={class:"first-settings"},Wu={class:"first-title"},Bu={class:"first-title"},zu={class:"first-title"},Nu={class:"first-title"},Uu={class:"first-title"};function $u(t,e,i,n,a,o){const r=(0,s.g2)("font-awesome-icon"),l=p.R7,h=nd.qi,c=td.xE,d=td.US,u=id.WK,g=sd.P9,f=sd.AV,m=nu,b=_.A;return(0,s.bo)(((0,s.uX)(),(0,s.CE)("div",Ou,[(0,s.Lk)("div",Ru,[(0,s.Lk)("h3",Wu,[e[13]||(e[13]=(0,s.eW)("远端遥测 ",-1)),(0,s.bF)(l,{content:"便于问题查找和定位,建议开启",placement:"right"},{default:(0,s.k6)(()=>[(0,s.bF)(r,{icon:"question-circle",style:{"margin-left":"5px",cursor:"pointer"}})]),_:1})]),(0,s.bF)(d,{model:a.settings.telemetry,"label-width":"120px"},{default:(0,s.k6)(()=>[(0,s.bF)(c,{label:"启用"},{default:(0,s.k6)(()=>[(0,s.bF)(h,{modelValue:a.settings.telemetry.enabled,"onUpdate:modelValue":e[0]||(e[0]=t=>a.settings.telemetry.enabled=t),disabled:a.settings.telemetry.fixed},null,8,["modelValue","disabled"])]),_:1})]),_:1},8,["model"]),(0,s.Lk)("h3",Bu,[e[14]||(e[14]=(0,s.eW)("随机图像API ",-1)),(0,s.bF)(l,{content:"API具体用法请查阅文档",placement:"right"},{default:(0,s.k6)(()=>[(0,s.bF)(r,{icon:"question-circle",style:{"margin-left":"5px",cursor:"pointer"}})]),_:1})]),(0,s.bF)(d,{model:a.settings.randomImageAPI,"label-width":"120px"},{default:(0,s.k6)(()=>[(0,s.bF)(c,{label:"启用"},{default:(0,s.k6)(()=>[(0,s.bF)(h,{modelValue:a.settings.randomImageAPI.enabled,"onUpdate:modelValue":e[1]||(e[1]=t=>a.settings.randomImageAPI.enabled=t),disabled:a.settings.randomImageAPI.fixed},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(c,{prop:"randomImageAPI.allowedDir"},{label:(0,s.k6)(()=>[e[15]||(e[15]=(0,s.Lk)("span",null,"目录",-1)),(0,s.bF)(l,{content:"1. 开放随机图权限的目录,默认为根目录,多个目录用逗号分隔
2. 目录均采用绝对路径,例如/img/cover,表示该目录及其所有子目录的文件可被随机图API访问",placement:"right","raw-content":""},{default:(0,s.k6)(()=>[(0,s.bF)(r,{icon:"question-circle",style:{"margin-left":"5px",cursor:"pointer"}})]),_:1})]),default:(0,s.k6)(()=>[(0,s.bF)(u,{modelValue:a.settings.randomImageAPI.allowedDir,"onUpdate:modelValue":e[2]||(e[2]=t=>a.settings.randomImageAPI.allowedDir=t),disabled:a.settings.randomImageAPI.fixed},null,8,["modelValue","disabled"])]),_:1})]),_:1},8,["model"]),(0,s.Lk)("h3",zu,[e[16]||(e[16]=(0,s.eW)("访客图库 ",-1)),(0,s.bF)(l,{content:"启用后,访客可通过 /browse 路径浏览指定目录的图片(只读,无法删除/移动)",placement:"right","raw-content":""},{default:(0,s.k6)(()=>[(0,s.bF)(r,{icon:"question-circle",style:{"margin-left":"5px",cursor:"pointer"}})]),_:1})]),(0,s.bF)(d,{model:a.settings.publicBrowse,"label-width":"120px"},{default:(0,s.k6)(()=>[(0,s.bF)(c,{label:"启用"},{default:(0,s.k6)(()=>[(0,s.bF)(h,{modelValue:a.settings.publicBrowse.enabled,"onUpdate:modelValue":e[3]||(e[3]=t=>a.settings.publicBrowse.enabled=t),disabled:a.settings.publicBrowse.fixed},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(c,{prop:"publicBrowse.allowedDir"},{label:(0,s.k6)(()=>[e[18]||(e[18]=(0,s.Lk)("span",null,"开放目录",-1)),(0,s.bF)(l,{placement:"right","raw-content":""},{content:(0,s.k6)(()=>[...e[17]||(e[17]=[(0,s.Lk)("div",{style:{"max-width":"320px","line-height":"1.6"}},[(0,s.Lk)("p",{style:{margin:"0 0 8px 0"}},[(0,s.Lk)("b",null,"允许公开浏览的目录,多个目录用逗号分隔")]),(0,s.Lk)("p",{style:{margin:"0 0 8px 0"}},"示例:wallpaper,photos,album"),(0,s.Lk)("p",{style:{margin:"0 0 8px 0",color:"#909399"}},"支持子目录:2026/lucky,2026/rich"),(0,s.Lk)("p",{style:{margin:"0",color:"#67c23a"}},"访问链接:https://你的域名/browse/2026/lucky")],-1)])]),default:(0,s.k6)(()=>[(0,s.bF)(r,{icon:"question-circle",style:{"margin-left":"5px",cursor:"pointer"}})]),_:1})]),default:(0,s.k6)(()=>[(0,s.bF)(u,{modelValue:a.settings.publicBrowse.allowedDir,"onUpdate:modelValue":e[4]||(e[4]=t=>a.settings.publicBrowse.allowedDir=t),disabled:a.settings.publicBrowse.fixed,placeholder:"wallpaper,photos,album"},null,8,["modelValue","disabled"])]),_:1})]),_:1},8,["model"]),(0,s.Lk)("h3",Nu,[e[19]||(e[19]=(0,s.eW)("CloudFlare API Token ",-1)),(0,s.bF)(l,{content:"设置后可以使后端拉黑、删除等操作不受CDN缓存限制
建议设置,设置方式请查阅文档",placement:"right","raw-content":""},{default:(0,s.k6)(()=>[(0,s.bF)(r,{icon:"question-circle",style:{"margin-left":"5px",cursor:"pointer"}})]),_:1})]),(0,s.bF)(d,{model:a.settings.cloudflareApiToken,"label-width":"120px"},{default:(0,s.k6)(()=>[(0,s.bF)(c,{label:"区域ID"},{default:(0,s.k6)(()=>[(0,s.bF)(u,{modelValue:a.settings.cloudflareApiToken.CF_ZONE_ID,"onUpdate:modelValue":e[5]||(e[5]=t=>a.settings.cloudflareApiToken.CF_ZONE_ID=t),disabled:a.settings.cloudflareApiToken.fixed},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(c,{label:"账户邮箱"},{default:(0,s.k6)(()=>[(0,s.bF)(u,{modelValue:a.settings.cloudflareApiToken.CF_EMAIL,"onUpdate:modelValue":e[6]||(e[6]=t=>a.settings.cloudflareApiToken.CF_EMAIL=t),disabled:a.settings.cloudflareApiToken.fixed},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(c,{label:"API Key"},{default:(0,s.k6)(()=>[(0,s.bF)(u,{modelValue:a.settings.cloudflareApiToken.CF_API_KEY,"onUpdate:modelValue":e[7]||(e[7]=t=>a.settings.cloudflareApiToken.CF_API_KEY=t),disabled:a.settings.cloudflareApiToken.fixed,type:"password","show-password":"",autocomplete:"new-password"},null,8,["modelValue","disabled"])]),_:1})]),_:1},8,["model"]),(0,s.Lk)("h3",Uu,[e[20]||(e[20]=(0,s.eW)("WebDAV ",-1)),(0,s.bF)(l,{content:"启用后,可以通过WebDAV协议访问和管理图片",placement:"right","raw-content":""},{default:(0,s.k6)(()=>[(0,s.bF)(r,{icon:"question-circle",style:{"margin-left":"5px",cursor:"pointer"}})]),_:1})]),(0,s.bF)(d,{model:a.settings.webDAV,"label-width":"120px"},{default:(0,s.k6)(()=>[(0,s.bF)(c,{label:"启用"},{default:(0,s.k6)(()=>[(0,s.bF)(h,{modelValue:a.settings.webDAV.enabled,"onUpdate:modelValue":e[8]||(e[8]=t=>a.settings.webDAV.enabled=t),disabled:a.settings.webDAV.fixed},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(c,{label:"用户名"},{default:(0,s.k6)(()=>[(0,s.bF)(u,{modelValue:a.settings.webDAV.username,"onUpdate:modelValue":e[9]||(e[9]=t=>a.settings.webDAV.username=t),disabled:a.settings.webDAV.fixed},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(c,{label:"密码"},{default:(0,s.k6)(()=>[(0,s.bF)(u,{modelValue:a.settings.webDAV.password,"onUpdate:modelValue":e[10]||(e[10]=t=>a.settings.webDAV.password=t),disabled:a.settings.webDAV.fixed,type:"password","show-password":"",autocomplete:"new-password"},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(c,{label:"上传渠道"},{default:(0,s.k6)(()=>[(0,s.bF)(f,{modelValue:a.settings.webDAV.uploadChannel,"onUpdate:modelValue":e[11]||(e[11]=t=>a.settings.webDAV.uploadChannel=t),disabled:a.settings.webDAV.fixed,placeholder:"默认渠道",clearable:""},{default:(0,s.k6)(()=>[(0,s.bF)(g,{label:"Telegram",value:"telegram"}),(0,s.bF)(g,{label:"Cloudflare R2",value:"cfr2"}),(0,s.bF)(g,{label:"S3",value:"s3"}),(0,s.bF)(g,{label:"Discord",value:"discord"}),(0,s.bF)(g,{label:"HuggingFace",value:"huggingface"})]),_:1},8,["modelValue","disabled"])]),_:1}),a.settings.webDAV.uploadChannel&&o.webdavChannelList.length>1?((0,s.uX)(),(0,s.Wv)(c,{key:0,label:"指定渠道名"},{default:(0,s.k6)(()=>[(0,s.bF)(f,{modelValue:a.settings.webDAV.channelName,"onUpdate:modelValue":e[12]||(e[12]=t=>a.settings.webDAV.channelName=t),disabled:a.settings.webDAV.fixed,placeholder:"自动选择",clearable:""},{default:(0,s.k6)(()=>[((0,s.uX)(!0),(0,s.CE)(s.FK,null,(0,s.pI)(o.webdavChannelList,t=>((0,s.uX)(),(0,s.Wv)(g,{key:t.name,label:t.name,value:t.name},null,8,["label","value"]))),128))]),_:1},8,["modelValue","disabled"])]),_:1})):(0,s.Q3)("",!0)]),_:1},8,["model"])]),(0,s.bF)(m,{show:!a.loading,onClick:o.saveSettings},null,8,["show","onClick"])])),[[b,a.loading]])}var ju={components:{FloatingSaveButton:nu},data(){return{settings:{telemetry:{},randomImageAPI:{},cloudflareApiToken:{},webDAV:{},publicBrowse:{}},availableChannels:{},loading:!0}},computed:{webdavChannelList(){const t=this.settings.webDAV?.uploadChannel;return t&&this.availableChannels[t]||[]}},watch:{"settings.webDAV.uploadChannel"(){this.settings.webDAV&&(this.settings.webDAV.channelName="")}},methods:{saveSettings(){(0,Ut.A)("/api/manage/sysConfig/others",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(this.settings)}).then(()=>this.$message.success("设置已保存"))},async fetchAvailableChannels(){try{const t=await(0,Ut.A)("/api/channels");t.ok&&(this.availableChannels=await t.json())}catch(t){console.error("Failed to fetch available channels:",t)}}},mounted(){this.loading=!0,(0,Ut.A)("/api/manage/sysConfig/others").then(t=>t.json()).then(t=>{this.settings=t}).finally(()=>{this.loading=!1}),this.fetchAvailableChannels()}};const Hu=(0,c.A)(ju,[["render",$u],["__scopeId","data-v-0cedb60a"]]);var Xu=Hu,qu={name:"SystemConfig",data(){return{activeIndex:"status",isSidebarCollapse:!1}},watch:{"$route.hash":{immediate:!0,handler(t){this.activeIndex=t.replace("#",""),window.scrollTo(0,0)}},activeIndex(t){const e=`#${t}`;this.$router.push({hash:e})}},components:{DashboardTabs:f.A,SysConfigTabs:u,SysCogStatus:Gc,SysCogUpload:Jd,SysCogSecurity:Au,SysCogPage:Vu,SysCogOthers:Xu},computed:{disableTooltip(){return window.innerWidth<768},currentComponent(){const t=this.$route.hash.replace("#","");switch(t){case"status":return Gc;case"upload":return Jd;case"security":return Au;case"page":return Vu;case"others":return Xu;default:return Gc}}},methods:{handleLogout(){this.$store.commit("setCredentials",null),this.$router.push("/adminLogin")},setDefaultHash(){const t="#status";window.location.hash=t,this.activeIndex=t.replace("#","")}},mounted(){window.location.hash||this.setDefaultHash()}};const Ku=(0,c.A)(qu,[["render",y],["__scopeId","data-v-4cdf1dc2"]]);var Yu=Ku},5616:function(t,e,i){i(5331),i(7197)},5802:function(t,e,i){i(5331),i(8736),i(213),i(5970)}}]); -//# sourceMappingURL=226.478c43ad.js.map \ No newline at end of file +class fa{constructor(){this._request=null,this._charts=new Map,this._running=!1,this._lastDate=void 0}_notify(t,e,i,s){const n=e.listeners[s],a=e.duration;n.forEach(s=>s({chart:t,initial:e.initial,numSteps:a,currentStep:Math.min(i-e.start,a)}))}_refresh(){this._request||(this._running=!0,this._request=Xi.call(window,()=>{this._update(),this._request=null,this._running&&this._refresh()}))}_update(t=Date.now()){let e=0;this._charts.forEach((i,s)=>{if(!i.running||!i.items.length)return;const n=i.items;let a,o=n.length-1,r=!1;for(;o>=0;--o)a=n[o],a._active?(a._total>i.duration&&(i.duration=a._total),a.tick(t),r=!0):(n[o]=n[n.length-1],n.pop());r&&(s.draw(),this._notify(s,i,t,"progress")),n.length||(i.running=!1,this._notify(s,i,t,"complete"),i.initial=!1),e+=n.length}),this._lastDate=t,0===e&&(this._running=!1)}_getAnims(t){const e=this._charts;let i=e.get(t);return i||(i={running:!1,initial:!0,items:[],listeners:{complete:[],progress:[]}},e.set(t,i)),i}listen(t,e,i){this._getAnims(t).listeners[e].push(i)}add(t,e){e&&e.length&&this._getAnims(t).items.push(...e)}has(t){return this._getAnims(t).items.length>0}start(t){const e=this._charts.get(t);e&&(e.running=!0,e.start=Date.now(),e.duration=e.items.reduce((t,e)=>Math.max(t,e._duration),0),this._refresh())}running(t){if(!this._running)return!1;const e=this._charts.get(t);return!!(e&&e.running&&e.items.length)}stop(t){const e=this._charts.get(t);if(!e||!e.items.length)return;const i=e.items;let s=i.length-1;for(;s>=0;--s)i[s].cancel();e.items=[],this._notify(t,e,Date.now(),"complete")}remove(t){return this._charts.delete(t)}}var ma=new fa;const ba="transparent",xa={boolean(t,e,i){return i>.5?e:t},color(t,e,i){const s=as(t||ba),n=s.valid&&as(e||ba);return n&&n.valid?n.mix(s,i).hexString():e},number(t,e,i){return t+(e-t)*i}};class ya{constructor(t,e,i,s){const n=e[i];s=Qs([t.to,s,n,t.from]);const a=Qs([t.from,n,s]);this._active=!0,this._fn=t.fn||xa[t.type||typeof a],this._easing=ss[t.easing]||ss.linear,this._start=Math.floor(Date.now()+(t.delay||0)),this._duration=this._total=Math.floor(t.duration),this._loop=!!t.loop,this._target=e,this._prop=i,this._from=a,this._to=s,this._promises=void 0}active(){return this._active}update(t,e,i){if(this._active){this._notify(!1);const s=this._target[this._prop],n=i-this._start,a=this._duration-n;this._start=i,this._duration=Math.floor(Math.max(a,t.duration)),this._total+=n,this._loop=!!t.loop,this._to=Qs([t.to,e,s,t.from]),this._from=Qs([t.from,s,e])}}cancel(){this._active&&(this.tick(Date.now()),this._active=!1,this._notify(!1))}tick(t){const e=t-this._start,i=this._duration,s=this._prop,n=this._from,a=this._loop,o=this._to;let r;if(this._active=n!==o&&(a||e1?2-r:r,r=this._easing(Math.min(1,Math.max(0,r))),this._target[s]=this._fn(n,o,r))}wait(){const t=this._promises||(this._promises=[]);return new Promise((e,i)=>{t.push({res:e,rej:i})})}_notify(t){const e=t?"res":"rej",i=this._promises||[];for(let s=0;s{const n=t[s];if(!ze(n))return;const a={};for(const t of e)a[t]=n[t];(Be(n.properties)&&n.properties||[s]).forEach(t=>{t!==s&&i.has(t)||i.set(t,a)})})}_animateOptions(t,e){const i=e.options,s=ka(t,i);if(!s)return[];const n=this._createAnimations(s,i);return i.$shared&&va(t.options.$animations,i).then(()=>{t.options=i},()=>{}),n}_createAnimations(t,e){const i=this._properties,s=[],n=t.$animations||(t.$animations={}),a=Object.keys(e),o=Date.now();let r;for(r=a.length-1;r>=0;--r){const l=a[r];if("$"===l.charAt(0))continue;if("options"===l){s.push(...this._animateOptions(t,e));continue}const h=e[l];let c=n[l];const d=i.get(l);if(c){if(d&&c.active()){c.update(d,h,o);continue}c.cancel()}d&&d.duration?(n[l]=c=new ya(d,t,l,h),s.push(c)):t[l]=h}return s}update(t,e){if(0===this._properties.size)return void Object.assign(t,e);const i=this._createAnimations(t,e);return i.length?(ma.add(this._chart,i),!0):void 0}}function va(t,e){const i=[],s=Object.keys(e);for(let n=0;n0||!i&&e<0)return n.index}return null}function Ia(t,e){const{chart:i,_cachedMeta:s}=t,n=i._stacks||(i._stacks={}),{iScale:a,vScale:o,index:r}=s,l=a.axis,h=o.axis,c=Pa(a,o,s),d=e.length;let u;for(let g=0;gi[t].axis===e).shift()}function Oa(t,e){return Js(t,{active:!1,dataset:void 0,datasetIndex:e,index:e,mode:"default",type:"dataset"})}function Ra(t,e,i){return Js(t,{active:!1,dataIndex:e,parsed:void 0,raw:void 0,element:i,index:e,mode:"default",type:"data"})}function Wa(t,e){const i=t.controller.index,s=t.vScale&&t.vScale.axis;if(s){e=e||t._parsed;for(const t of e){const e=t._stacks;if(!e||void 0===e[s]||void 0===e[s][i])return;delete e[s][i],void 0!==e[s]._visualValues&&void 0!==e[s]._visualValues[i]&&delete e[s]._visualValues[i]}}}const Ba=t=>"reset"===t||"none"===t,za=(t,e)=>e?t:Object.assign({},t),Na=(t,e,i)=>t&&!e.hidden&&e._stacked&&{keys:Fa(i,!0),values:null};class Ua{constructor(t,e){this.chart=t,this._ctx=t.ctx,this.index=e,this._cachedDataOpts={},this._cachedMeta=this.getMeta(),this._type=this._cachedMeta.type,this.options=void 0,this._parsing=!1,this._data=void 0,this._objectData=void 0,this._sharedOptions=void 0,this._drawStart=void 0,this._drawCount=void 0,this.enableOptionSharing=!1,this.supportsDecimation=!1,this.$context=void 0,this._syncList=[],this.datasetElementType=new.target.datasetElementType,this.dataElementType=new.target.dataElementType,this.initialize()}initialize(){const t=this._cachedMeta;this.configure(),this.linkScales(),t._stacked=Ta(t.vScale,t),this.addElements(),this.options.fill&&!this.chart.isPluginEnabled("filler")&&console.warn("Tried to use the 'fill' option without the 'Filler' plugin enabled. Please import and register the 'Filler' plugin and make sure it is not disabled in the options")}updateIndex(t){this.index!==t&&Wa(this._cachedMeta),this.index=t}linkScales(){const t=this.chart,e=this._cachedMeta,i=this.getDataset(),s=(t,e,i,s)=>"x"===t?e:"r"===t?s:i,n=e.xAxisID=$e(i.xAxisID,Va(t,"x")),a=e.yAxisID=$e(i.yAxisID,Va(t,"y")),o=e.rAxisID=$e(i.rAxisID,Va(t,"r")),r=e.indexAxis,l=e.iAxisID=s(r,n,a,o),h=e.vAxisID=s(r,a,n,o);e.xScale=this.getScaleForId(n),e.yScale=this.getScaleForId(a),e.rScale=this.getScaleForId(o),e.iScale=this.getScaleForId(l),e.vScale=this.getScaleForId(h)}getDataset(){return this.chart.data.datasets[this.index]}getMeta(){return this.chart.getDatasetMeta(this.index)}getScaleForId(t){return this.chart.scales[t]}_getOtherScale(t){const e=this._cachedMeta;return t===e.iScale?e.vScale:e.iScale}reset(){this._update("reset")}_destroy(){const t=this._cachedMeta;this._data&&ji(this._data,this),t._stacked&&Wa(t)}_dataCheck(){const t=this.getDataset(),e=t.data||(t.data=[]),i=this._data;if(ze(e)){const t=this._cachedMeta;this._data=Aa(e,t)}else if(i!==e){if(i){ji(i,this);const t=this._cachedMeta;Wa(t),t._parsed=[]}e&&Object.isExtensible(e)&&$i(e,this),this._syncList=[],this._data=e}}addElements(){const t=this._cachedMeta;this._dataCheck(),this.datasetElementType&&(t.dataset=new this.datasetElementType)}buildOrUpdateElements(t){const e=this._cachedMeta,i=this.getDataset();let s=!1;this._dataCheck();const n=e._stacked;e._stacked=Ta(e.vScale,e),e.stack!==i.stack&&(s=!0,Wa(e),e.stack=i.stack),this._resyncElements(t),(s||n!==e._stacked)&&(Ia(this,e._parsed),e._stacked=Ta(e.vScale,e))}configure(){const t=this.chart.config,e=t.datasetScopeKeys(this._type),i=t.getOptionScopes(this.getDataset(),e,!0);this.options=t.createResolver(i,this.getContext()),this._parsing=this.options.parsing,this._cachedDataOpts={}}parse(t,e){const{_cachedMeta:i,_data:s}=this,{iScale:n,_stacked:a}=i,o=n.axis;let r,l,h,c=0===t&&e===s.length||i._sorted,d=t>0&&i._parsed[t-1];if(!1===this._parsing)i._parsed=s,i._sorted=!0,h=s;else{h=Be(s[t])?this.parseArrayData(i,s,t,e):ze(s[t])?this.parseObjectData(i,s,t,e):this.parsePrimitiveData(i,s,t,e);const n=()=>null===l[o]||d&&l[o]e||c=0;--d)if(!g()){this.updateRangeFromParsed(l,t,u,r);break}return l}getAllParsedValues(t){const e=this._cachedMeta._parsed,i=[];let s,n,a;for(s=0,n=e.length;s=0&&tthis.getContext(i,s,e),p=l.resolveNamedOptions(d,u,g,c);return p.$shared&&(p.$shared=r,n[a]=Object.freeze(za(p,r))),p}_resolveAnimations(t,e,i){const s=this.chart,n=this._cachedDataOpts,a=`animation-${e}`,o=n[a];if(o)return o;let r;if(!1!==s.options.animation){const s=this.chart.config,n=s.datasetAnimationScopeKeys(this._type,e),a=s.getOptionScopes(this.getDataset(),n);r=s.createResolver(a,this.getContext(t,i,e))}const l=new _a(s,r&&r.animations);return r&&r._cacheable&&(n[a]=Object.freeze(l)),l}getSharedOptions(t){if(t.$shared)return this._sharedOptions||(this._sharedOptions=Object.assign({},t))}includeOptions(t,e){return!e||Ba(t)||this.chart._animationsDisabled}_getSharedOptions(t,e){const i=this.resolveDataElementOptions(t,e),s=this._sharedOptions,n=this.getSharedOptions(i),a=this.includeOptions(e,n)||n!==s;return this.updateSharedOptions(n,e,i),{sharedOptions:n,includeOptions:a}}updateElement(t,e,i,s){Ba(s)?Object.assign(t,i):this._resolveAnimations(e,s).update(t,i)}updateSharedOptions(t,e,i){t&&!Ba(e)&&this._resolveAnimations(void 0,e).update(t,i)}_setStyle(t,e,i,s){t.active=s;const n=this.getStyle(e,s);this._resolveAnimations(e,i,s).update(t,{options:!s&&this.getSharedOptions(n)||n})}removeHoverStyle(t,e,i){this._setStyle(t,i,"active",!1)}setHoverStyle(t,e,i){this._setStyle(t,i,"active",!0)}_removeDatasetHoverStyle(){const t=this._cachedMeta.dataset;t&&this._setStyle(t,void 0,"active",!1)}_setDatasetHoverStyle(){const t=this._cachedMeta.dataset;t&&this._setStyle(t,void 0,"active",!0)}_resyncElements(t){const e=this._data,i=this._cachedMeta.data;for(const[o,r,l]of this._syncList)this[o](r,l);this._syncList=[];const s=i.length,n=e.length,a=Math.min(n,s);a&&this.parse(0,a),n>s?this._insertElements(s,n-s,t):n{for(t.length+=e,o=t.length-1;o>=a;o--)t[o]=t[o-e]};for(r(n),o=t;ot-e))}return t._cache.$bar}function ja(t){const e=t.iScale,i=$a(e,t.type);let s,n,a,o,r=e._length;const l=()=>{32767!==a&&-32768!==a&&(oi(o)&&(r=Math.min(r,Math.abs(a-o)||r)),o=a)};for(s=0,n=i.length;s0?n[t-1]:null,r=tMath.abs(r)&&(l=r,h=o),e[i.axis]=h,e._custom={barStart:l,barEnd:h,start:n,end:a,min:o,max:r}}function Ka(t,e,i,s){return Be(t)?qa(t,e,i,s):e[i.axis]=i.parse(t,s),e}function Ya(t,e,i,s){const n=t.iScale,a=t.vScale,o=n.getLabels(),r=n===a,l=[];let h,c,d,u;for(h=i,c=i+s;h=i?1:-1)}function Ja(t){let e,i,s,n,a;return t.horizontal?(e=t.base>t.x,i="left",s="right"):(e=t.baset.controller.options.grouped),n=i.options.stacked,a=[],o=this._cachedMeta.controller.getParsed(e),r=o&&o[i.axis],l=t=>{const e=t._parsed.find(t=>t[i.axis]===r),s=e&&e[t.vScale.axis];if(We(s)||isNaN(s))return!0};for(const h of s)if((void 0===e||!l(h))&&((!1===n||-1===a.indexOf(h.stack)||void 0===n&&void 0===h.stack)&&a.push(h.stack),h.index===t))break;return a.length||a.push(void 0),a}_getStackCount(t){return this._getStacks(void 0,t).length}_getAxisCount(){return this._getAxis().length}getFirstScaleIdForIndexAxis(){const t=this.chart.scales,e=this.chart.options.indexAxis;return Object.keys(t).filter(i=>t[i].axis===e).shift()}_getAxis(){const t={},e=this.getFirstScaleIdForIndexAxis();for(const i of this.chart.data.datasets)t[$e("x"===this.chart.options.indexAxis?i.xAxisID:i.yAxisID,e)]=!0;return Object.keys(t)}_getStackIndex(t,e,i){const s=this._getStacks(t,i),n=void 0!==e?s.indexOf(e):-1;return-1===n?s.length-1:n}_getRuler(){const t=this.options,e=this._cachedMeta,i=e.iScale,s=[];let n,a;for(n=0,a=e.data.length;n=0;--i)e=Math.max(e,t[i].size(this.resolveDataElementOptions(i))/2);return e>0&&e}getLabelAndValue(t){const e=this._cachedMeta,i=this.chart.data.labels||[],{xScale:s,yScale:n}=e,a=this.getParsed(t),o=s.getLabelForValue(a.x),r=n.getLabelForValue(a.y),l=a._custom;return{label:i[t]||"",value:"("+o+", "+r+(l?", "+l:"")+")"}}update(t){const e=this._cachedMeta.data;this.updateElements(e,0,e.length,t)}updateElements(t,e,i,s){const n="reset"===s,{iScale:a,vScale:o}=this._cachedMeta,{sharedOptions:r,includeOptions:l}=this._getSharedOptions(e,s),h=a.axis,c=o.axis;for(let d=e;dIi(t,r,l,!0)?1:Math.max(e,e*i,s,s*i),p=(t,e,s)=>Ii(t,r,l,!0)?-1:Math.min(e,e*i,s,s*i),f=g(0,h,d),m=g(fi,c,u),b=p(ci,h,d),x=p(ci+fi,c,u);s=(f-b)/2,n=(m-x)/2,a=-(f+b)/2,o=-(m+x)/2}return{ratioX:s,ratioY:n,offsetX:a,offsetY:o}}(0,jt.A)(ao,"id","bubble"),(0,jt.A)(ao,"defaults",{datasetElementType:!1,dataElementType:"point",animations:{numbers:{type:"number",properties:["x","y","borderWidth","radius"]}}}),(0,jt.A)(ao,"overrides",{scales:{x:{type:"linear"},y:{type:"linear"}}});class ro extends Ua{constructor(t,e){super(t,e),this.enableOptionSharing=!0,this.innerRadius=void 0,this.outerRadius=void 0,this.offsetX=void 0,this.offsetY=void 0}linkScales(){}parse(t,e){const i=this.getDataset().data,s=this._cachedMeta;if(!1===this._parsing)s._parsed=i;else{let n,a,o=t=>+i[t];if(ze(i[t])){const{key:t="value"}=this._parsing;o=e=>+ni(i[e],t)}for(n=t,a=t+e;n0&&!isNaN(t)?di*(Math.abs(t)/e):0}getLabelAndValue(t){const e=this._cachedMeta,i=this.chart,s=i.data.labels||[],n=gs(e._parsed[t],i.options.locale);return{label:s[t]||"",value:n}}getMaxBorderWidth(t){let e=0;const i=this.chart;let s,n,a,o,r;if(!t)for(s=0,n=i.data.datasets.length;s"spacing"!==t,_indexable:t=>"spacing"!==t&&!t.startsWith("borderDash")&&!t.startsWith("hoverBorderDash")}),(0,jt.A)(ro,"overrides",{aspectRatio:1,plugins:{legend:{labels:{generateLabels(t){const e=t.data,{labels:{pointStyle:i,textAlign:s,color:n,useBorderRadius:a,borderRadius:o}}=t.legend.options;return e.labels.length&&e.datasets.length?e.labels.map((e,r)=>{const l=t.getDatasetMeta(0),h=l.controller.getStyle(r);return{text:e,fillStyle:h.backgroundColor,fontColor:n,hidden:!t.getDataVisibility(r),lineDash:h.borderDash,lineDashOffset:h.borderDashOffset,lineJoin:h.borderJoinStyle,lineWidth:h.borderWidth,strokeStyle:h.borderColor,textAlign:s,pointStyle:i,borderRadius:a&&(o||h.borderRadius),index:r}}):[]}},onClick(t,e,i){i.chart.toggleDataVisibility(e.index),i.chart.update()}}}});class lo extends Ua{initialize(){this.enableOptionSharing=!0,this.supportsDecimation=!0,super.initialize()}update(t){const e=this._cachedMeta,{dataset:i,data:s=[],_dataset:n}=e,a=this.chart._animationsDisabled;let{start:o,count:r}=Ji(e,s,a);this._drawStart=o,this._drawCount=r,Zi(e)&&(o=0,r=s.length),i._chart=this.chart,i._datasetIndex=this.index,i._decimated=!!n._decimated,i.points=s;const l=this.resolveDatasetElementOptions(t);this.options.showLine||(l.borderWidth=0),l.segment=this.options.segment,this.updateElement(i,void 0,{animated:!a,options:l},t),this.updateElements(s,o,r,t)}updateElements(t,e,i,s){const n="reset"===s,{iScale:a,vScale:o,_stacked:r,_dataset:l}=this._cachedMeta,{sharedOptions:h,includeOptions:c}=this._getSharedOptions(e,s),d=a.axis,u=o.axis,{spanGaps:g,segment:p}=this.options,f=Ci(g)?g:Number.POSITIVE_INFINITY,m=this.chart._animationsDisabled||n||"none"===s,b=e+i,x=t.length;let y=e>0&&this.getParsed(e-1);for(let _=0;_=b){g.skip=!0;continue}const x=this.getParsed(_),v=We(x[u]),k=g[d]=a.getPixelForValue(x[d],_),w=g[u]=n||v?o.getBasePixel():o.getPixelForValue(r?this.applyStack(o,x,r):x[u],_);g.skip=isNaN(k)||isNaN(w)||v,g.stop=_>0&&Math.abs(x[d]-y[d])>f,p&&(g.parsed=x,g.raw=l.data[_]),c&&(g.options=h||this.resolveDataElementOptions(_,i.active?"active":s)),m||this.updateElement(i,_,g,s),y=x}}getMaxOverflow(){const t=this._cachedMeta,e=t.dataset,i=e.options&&e.options.borderWidth||0,s=t.data||[];if(!s.length)return i;const n=s[0].size(this.resolveDataElementOptions(0)),a=s[s.length-1].size(this.resolveDataElementOptions(s.length-1));return Math.max(i,n,a)/2}draw(){const t=this._cachedMeta;t.dataset.updateControlPoints(this.chart.chartArea,t.iScale.axis),super.draw()}}(0,jt.A)(lo,"id","line"),(0,jt.A)(lo,"defaults",{datasetElementType:"line",dataElementType:"point",showLine:!0,spanGaps:!1}),(0,jt.A)(lo,"overrides",{scales:{_index_:{type:"category"},_value_:{type:"linear"}}});class ho extends Ua{constructor(t,e){super(t,e),this.innerRadius=void 0,this.outerRadius=void 0}getLabelAndValue(t){const e=this._cachedMeta,i=this.chart,s=i.data.labels||[],n=gs(e._parsed[t].r,i.options.locale);return{label:s[t]||"",value:n}}parseObjectData(t,e,i,s){return yn.bind(this)(t,e,i,s)}update(t){const e=this._cachedMeta.data;this._updateRadius(),this.updateElements(e,0,e.length,t)}getMinMax(){const t=this._cachedMeta,e={min:Number.POSITIVE_INFINITY,max:Number.NEGATIVE_INFINITY};return t.data.forEach((t,i)=>{const s=this.getParsed(i).r;!isNaN(s)&&this.chart.getDataVisibility(i)&&(se.max&&(e.max=s))}),e}_updateRadius(){const t=this.chart,e=t.chartArea,i=t.options,s=Math.min(e.right-e.left,e.bottom-e.top),n=Math.max(s/2,0),a=Math.max(i.cutoutPercentage?n/100*i.cutoutPercentage:1,0),o=(n-a)/t.getVisibleDatasetCount();this.outerRadius=n-o*this.index,this.innerRadius=this.outerRadius-o}updateElements(t,e,i,s){const n="reset"===s,a=this.chart,o=a.options,r=o.animation,l=this._cachedMeta.rScale,h=l.xCenter,c=l.yCenter,d=l.getIndexAngle(0)-.5*ci;let u,g=d;const p=360/this.countVisibleElements();for(u=0;u{!isNaN(this.getParsed(i).r)&&this.chart.getDataVisibility(i)&&e++}),e}_computeAngle(t,e,i){return this.chart.getDataVisibility(t)?Mi(this.resolveDataElementOptions(t,e).angle||i):0}}(0,jt.A)(ho,"id","polarArea"),(0,jt.A)(ho,"defaults",{dataElementType:"arc",animation:{animateRotate:!0,animateScale:!0},animations:{numbers:{type:"number",properties:["x","y","startAngle","endAngle","innerRadius","outerRadius"]}},indexAxis:"r",startAngle:0}),(0,jt.A)(ho,"overrides",{aspectRatio:1,plugins:{legend:{labels:{generateLabels(t){const e=t.data;if(e.labels.length&&e.datasets.length){const{labels:{pointStyle:i,color:s}}=t.legend.options;return e.labels.map((e,n)=>{const a=t.getDatasetMeta(0),o=a.controller.getStyle(n);return{text:e,fillStyle:o.backgroundColor,strokeStyle:o.borderColor,fontColor:s,lineWidth:o.borderWidth,pointStyle:i,hidden:!t.getDataVisibility(n),index:n}})}return[]}},onClick(t,e,i){i.chart.toggleDataVisibility(e.index),i.chart.update()}}},scales:{r:{type:"radialLinear",angleLines:{display:!1},beginAtZero:!0,grid:{circular:!0},pointLabels:{display:!1},startAngle:0}}});class co extends ro{}(0,jt.A)(co,"id","pie"),(0,jt.A)(co,"defaults",{cutout:0,rotation:0,circumference:360,radius:"100%"});class uo extends Ua{getLabelAndValue(t){const e=this._cachedMeta.vScale,i=this.getParsed(t);return{label:e.getLabels()[t],value:""+e.getLabelForValue(i[e.axis])}}parseObjectData(t,e,i,s){return yn.bind(this)(t,e,i,s)}update(t){const e=this._cachedMeta,i=e.dataset,s=e.data||[],n=e.iScale.getLabels();if(i.points=s,"resize"!==t){const e=this.resolveDatasetElementOptions(t);this.options.showLine||(e.borderWidth=0);const a={_loop:!0,_fullLoop:n.length===s.length,options:e};this.updateElement(i,void 0,a,t)}this.updateElements(s,0,s.length,t)}updateElements(t,e,i,s){const n=this._cachedMeta.rScale,a="reset"===s;for(let o=e;o0&&this.getParsed(e-1);for(let y=e;y0&&Math.abs(i[u]-x[u])>m,f&&(h.parsed=i,h.raw=l.data[y]),d&&(h.options=c||this.resolveDataElementOptions(y,e.active?"active":s)),b||this.updateElement(e,y,h,s),x=i}this.updateSharedOptions(c,s,h)}getMaxOverflow(){const t=this._cachedMeta,e=t.data||[];if(!this.options.showLine){let t=0;for(let i=e.length-1;i>=0;--i)t=Math.max(t,e[i].size(this.resolveDataElementOptions(i))/2);return t>0&&t}const i=t.dataset,s=i.options&&i.options.borderWidth||0;if(!e.length)return s;const n=e[0].size(this.resolveDataElementOptions(0)),a=e[e.length-1].size(this.resolveDataElementOptions(e.length-1));return Math.max(s,n,a)/2}}(0,jt.A)(go,"id","scatter"),(0,jt.A)(go,"defaults",{datasetElementType:!1,dataElementType:"point",showLine:!1,fill:!1}),(0,jt.A)(go,"overrides",{interaction:{mode:"point"},scales:{x:{type:"linear"},y:{type:"linear"}}});function po(){throw new Error("This method is not implemented: Check that a complete date adapter is provided.")}class fo{static override(t){Object.assign(fo.prototype,t)}constructor(t){(0,jt.A)(this,"options",void 0),this.options=t||{}}init(){}formats(){return po()}parse(){return po()}format(){return po()}add(){return po()}diff(){return po()}startOf(){return po()}endOf(){return po()}}var mo={_date:fo};function bo(t,e,i,s){const{controller:n,data:a,_sorted:o}=t,r=n._cachedMeta.iScale,l=t.dataset&&t.dataset.options?t.dataset.options.spanGaps:null;if(r&&e===r.axis&&"r"!==e&&o&&a.length){const o=r._reversePixels?zi:Bi;if(!s){const s=o(a,e,i);if(l){const{vScale:e}=n._cachedMeta,{_parsed:i}=t,a=i.slice(0,s.lo+1).reverse().findIndex(t=>!We(t[e.axis]));s.lo-=Math.max(0,a);const o=i.slice(s.hi).findIndex(t=>!We(t[e.axis]));s.hi+=Math.max(0,o)}return s}if(n._sharedOptions){const t=a[0],s="function"===typeof t.getRange&&t.getRange(e);if(s){const t=o(a,e,i-s),n=o(a,e,i+s);return{lo:t.lo,hi:n.hi}}}}return{lo:0,hi:a.length-1}}function xo(t,e,i,s,n){const a=t.getSortedVisibleDatasetMetas(),o=i[e];for(let r=0,l=a.length;r{t[o]&&t[o](e[i],n)&&(a.push({element:t,datasetIndex:s,index:l}),r=r||t.inRange(e.x,e.y,n))}),s&&!r?[]:a}var So={evaluateInteractionItems:xo,modes:{index(t,e,i,s){const n=Bn(e,t),a=i.axis||"x",o=i.includeInvisible||!1,r=i.intersect?_o(t,n,a,s,o):wo(t,n,a,!1,s,o),l=[];return r.length?(t.getSortedVisibleDatasetMetas().forEach(t=>{const e=r[0].index,i=t.data[e];i&&!i.skip&&l.push({element:i,datasetIndex:t.index,index:e})}),l):[]},dataset(t,e,i,s){const n=Bn(e,t),a=i.axis||"xy",o=i.includeInvisible||!1;let r=i.intersect?_o(t,n,a,s,o):wo(t,n,a,!1,s,o);if(r.length>0){const e=r[0].datasetIndex,i=t.getDatasetMeta(e).data;r=[];for(let t=0;tt.pos===e)}function Ao(t,e){return t.filter(t=>-1===Fo.indexOf(t.pos)&&t.box.axis===e)}function To(t,e){return t.sort((t,i)=>{const s=e?i:t,n=e?t:i;return s.weight===n.weight?s.index-n.index:s.weight-n.weight})}function Po(t){const e=[];let i,s,n,a,o,r;for(i=0,s=(t||[]).length;it.box.fullSize),!0),s=To(Mo(e,"left"),!0),n=To(Mo(e,"right")),a=To(Mo(e,"top"),!0),o=To(Mo(e,"bottom")),r=Ao(e,"x"),l=Ao(e,"y");return{fullSize:i,leftAndTop:s.concat(a),rightAndBottom:n.concat(l).concat(o).concat(r),chartArea:Mo(e,"chartArea"),vertical:s.concat(n).concat(l),horizontal:a.concat(o).concat(r)}}function Io(t,e,i,s){return Math.max(t[i],e[i])+Math.max(t[s],e[s])}function Vo(t,e){t.top=Math.max(t.top,e.top),t.left=Math.max(t.left,e.left),t.bottom=Math.max(t.bottom,e.bottom),t.right=Math.max(t.right,e.right)}function Oo(t,e,i,s){const{pos:n,box:a}=i,o=t.maxPadding;if(!ze(n)){i.size&&(t[n]-=i.size);const e=s[i.stack]||{size:0,count:1};e.size=Math.max(e.size,i.horizontal?a.height:a.width),i.size=e.size/e.count,t[n]+=i.size}a.getPadding&&Vo(o,a.getPadding());const r=Math.max(0,e.outerWidth-Io(o,t,"left","right")),l=Math.max(0,e.outerHeight-Io(o,t,"top","bottom")),h=r!==t.w,c=l!==t.h;return t.w=r,t.h=l,i.horizontal?{same:h,other:c}:{same:c,other:h}}function Ro(t){const e=t.maxPadding;function i(i){const s=Math.max(e[i]-t[i],0);return t[i]+=s,s}t.y+=i("top"),t.x+=i("left"),i("right"),i("bottom")}function Wo(t,e){const i=e.maxPadding;function s(t){const s={left:0,top:0,right:0,bottom:0};return t.forEach(t=>{s[t]=Math.max(e[t],i[t])}),s}return s(t?["left","right"]:["top","bottom"])}function Bo(t,e,i,s){const n=[];let a,o,r,l,h,c;for(a=0,o=t.length,h=0;a{"function"===typeof t.beforeLayout&&t.beforeLayout()});const c=l.reduce((t,e)=>e.box.options&&!1===e.box.options.display?t:t+1,0)||1,d=Object.freeze({outerWidth:e,outerHeight:i,padding:n,availableWidth:a,availableHeight:o,vBoxMaxWidth:a/2/c,hBoxMaxHeight:o/2}),u=Object.assign({},n);Vo(u,Ks(s));const g=Object.assign({maxPadding:u,w:a,h:o,x:n.left,y:n.top},n),p=Eo(l.concat(h),d);Bo(r.fullSize,g,d,p),Bo(l,g,d,p),Bo(h,g,d,p)&&Bo(l,g,d,p),Ro(g),No(r.leftAndTop,g,d,p),g.x+=g.w,g.y+=g.h,No(r.rightAndBottom,g,d,p),t.chartArea={left:g.left,top:g.top,right:g.left+g.w,bottom:g.top+g.h,height:g.h,width:g.w},qe(r.chartArea,e=>{const i=e.box;Object.assign(i,t.chartArea),i.update(g.w,g.h,{left:0,top:0,right:0,bottom:0})})}};class $o{acquireContext(t,e){}releaseContext(t){return!1}addEventListener(t,e,i){}removeEventListener(t,e,i){}getDevicePixelRatio(){return 1}getMaximumSize(t,e,i,s){return e=Math.max(0,e||t.width),i=i||t.height,{width:e,height:Math.max(0,s?Math.floor(e/s):i)}}isAttached(t){return!0}updateConfig(t){}}class jo extends $o{acquireContext(t){return t&&t.getContext&&t.getContext("2d")||null}updateConfig(t){t.options.animation=!1}}const Ho="$chartjs",Xo={touchstart:"mousedown",touchmove:"mousemove",touchend:"mouseup",pointerenter:"mouseenter",pointerdown:"mousedown",pointermove:"mousemove",pointerup:"mouseup",pointerleave:"mouseout",pointerout:"mouseout"},qo=t=>null===t||""===t;function Ko(t,e){const i=t.style,s=t.getAttribute("height"),n=t.getAttribute("width");if(t[Ho]={initial:{height:s,width:n,style:{display:i.display,height:i.height,width:i.width}}},i.display=i.display||"block",i.boxSizing=i.boxSizing||"border-box",qo(n)){const e=Hn(t,"width");void 0!==e&&(t.width=e)}if(qo(s))if(""===t.style.height)t.height=t.width/(e||2);else{const e=Hn(t,"height");void 0!==e&&(t.height=e)}return t}const Yo=!!jn&&{passive:!0};function Qo(t,e,i){t&&t.addEventListener(e,i,Yo)}function Go(t,e,i){t&&t.canvas&&t.canvas.removeEventListener(e,i,Yo)}function Jo(t,e){const i=Xo[t.type]||t.type,{x:s,y:n}=Bn(t,e);return{type:i,chart:e,native:t,x:void 0!==s?s:null,y:void 0!==n?n:null}}function Zo(t,e){for(const i of t)if(i===e||i.contains(e))return!0}function tr(t,e,i){const s=t.canvas,n=new MutationObserver(t=>{let e=!1;for(const i of t)e=e||Zo(i.addedNodes,s),e=e&&!Zo(i.removedNodes,s);e&&i()});return n.observe(document,{childList:!0,subtree:!0}),n}function er(t,e,i){const s=t.canvas,n=new MutationObserver(t=>{let e=!1;for(const i of t)e=e||Zo(i.removedNodes,s),e=e&&!Zo(i.addedNodes,s);e&&i()});return n.observe(document,{childList:!0,subtree:!0}),n}const ir=new Map;let sr=0;function nr(){const t=window.devicePixelRatio;t!==sr&&(sr=t,ir.forEach((e,i)=>{i.currentDevicePixelRatio!==t&&e()}))}function ar(t,e){ir.size||window.addEventListener("resize",nr),ir.set(t,e)}function or(t){ir.delete(t),ir.size||window.removeEventListener("resize",nr)}function rr(t,e,i){const s=t.canvas,n=s&&Dn(s);if(!n)return;const a=qi((t,e)=>{const s=n.clientWidth;i(t,e),s{const e=t[0],i=e.contentRect.width,s=e.contentRect.height;0===i&&0===s||a(i,s)});return o.observe(n),ar(t,a),o}function lr(t,e,i){i&&i.disconnect(),"resize"===e&&or(t)}function hr(t,e,i){const s=t.canvas,n=qi(e=>{null!==t.ctx&&i(Jo(e,t))},t);return Qo(s,e,n),n}class cr extends $o{acquireContext(t,e){const i=t&&t.getContext&&t.getContext("2d");return i&&i.canvas===t?(Ko(t,e),i):null}releaseContext(t){const e=t.canvas;if(!e[Ho])return!1;const i=e[Ho].initial;["height","width"].forEach(t=>{const s=i[t];We(s)?e.removeAttribute(t):e.setAttribute(t,s)});const s=i.style||{};return Object.keys(s).forEach(t=>{e.style[t]=s[t]}),e.width=e.width,delete e[Ho],!0}addEventListener(t,e,i){this.removeEventListener(t,e);const s=t.$proxies||(t.$proxies={}),n={attach:tr,detach:er,resize:rr},a=n[e]||hr;s[e]=a(t,e,i)}removeEventListener(t,e){const i=t.$proxies||(t.$proxies={}),s=i[e];if(!s)return;const n={attach:lr,detach:lr,resize:lr},a=n[e]||Go;a(t,e,s),i[e]=void 0}getDevicePixelRatio(){return window.devicePixelRatio}getMaximumSize(t,e,i,s){return Un(t,e,i,s)}isAttached(t){const e=t&&Dn(t);return!(!e||!e.isConnected)}}function dr(t){return!Pn()||"undefined"!==typeof OffscreenCanvas&&t instanceof OffscreenCanvas?jo:cr}class ur{constructor(){(0,jt.A)(this,"x",void 0),(0,jt.A)(this,"y",void 0),(0,jt.A)(this,"active",!1),(0,jt.A)(this,"options",void 0),(0,jt.A)(this,"$animations",void 0)}tooltipPosition(t){const{x:e,y:i}=this.getProps(["x","y"],t);return{x:e,y:i}}hasValue(){return Ci(this.x)&&Ci(this.y)}getProps(t,e){const i=this.$animations;if(!e||!i)return this;const s={};return t.forEach(t=>{s[t]=i[t]&&i[t].active()?i[t]._to:this[t]}),s}}function gr(t,e){const i=t.options.ticks,s=pr(t),n=Math.min(i.maxTicksLimit||s,s),a=i.major.enabled?mr(e):[],o=a.length,r=a[0],l=a[o-1],h=[];if(o>n)return br(e,h,a,o/n),h;const c=fr(a,e,n);if(o>0){let t,i;const s=o>1?Math.round((l-r)/(o-1)):null;for(xr(e,h,c,We(s)?0:r-s,r),t=0,i=o-1;tn)return t}return Math.max(n,1)}function mr(t){const e=[];let i,s;for(i=0,s=t.length;i"left"===t?"right":"right"===t?"left":t,vr=(t,e,i)=>"top"===e||"left"===e?t[e]+i:t[e]-i,kr=(t,e)=>Math.min(e||t,t);function wr(t,e){const i=[],s=t.length/e,n=t.length;let a=0;for(;ao+r)))return h}function Sr(t,e){qe(t,t=>{const i=t.gc,s=i.length/2;let n;if(s>e){for(n=0;ns?s:i,s=n&&i>s?i:s,{min:Ue(i,Ue(s,i)),max:Ue(s,Ue(i,s))}}getPadding(){return{left:this.paddingLeft||0,top:this.paddingTop||0,right:this.paddingRight||0,bottom:this.paddingBottom||0}}getTicks(){return this.ticks}getLabels(){const t=this.chart.data;return this.options.labels||(this.isHorizontal()?t.xLabels:t.yLabels)||t.labels||[]}getLabelItems(t=this.chart.chartArea){const e=this._labelItems||(this._labelItems=this._computeLabelItems(t));return e}beforeLayout(){this._cache={},this._dataLimitsCached=!1}beforeUpdate(){Xe(this.options.beforeUpdate,[this])}update(t,e,i){const{beginAtZero:s,grace:n,ticks:a}=this.options,o=a.sampleSize;this.beforeUpdate(),this.maxWidth=t,this.maxHeight=e,this._margins=i=Object.assign({left:0,right:0,top:0,bottom:0},i),this.ticks=null,this._labelSizes=null,this._gridLineItems=null,this._labelItems=null,this.beforeSetDimensions(),this.setDimensions(),this.afterSetDimensions(),this._maxLength=this.isHorizontal()?this.width+i.left+i.right:this.height+i.top+i.bottom,this._dataLimitsCached||(this.beforeDataLimits(),this.determineDataLimits(),this.afterDataLimits(),this._range=Gs(this,n,s),this._dataLimitsCached=!0),this.beforeBuildTicks(),this.ticks=this.buildTicks()||[],this.afterBuildTicks();const r=o=n||i<=1||!this.isHorizontal())return void(this.labelRotation=s);const h=this._getLabelSizes(),c=h.widest.width,d=h.highest.height,u=Vi(this.chart.width-c,0,this.maxWidth);a=t.offset?this.maxWidth/i:u/(i-1),c+6>a&&(a=u/(i-(t.offset?.5:1)),o=this.maxHeight-Fr(t.grid)-e.padding-Mr(t.title,this.chart.options.font),r=Math.sqrt(c*c+d*d),l=Ai(Math.min(Math.asin(Vi((h.highest.height+6)/a,-1,1)),Math.asin(Vi(o/r,-1,1))-Math.asin(Vi(d/r,-1,1)))),l=Math.max(s,Math.min(n,l))),this.labelRotation=l}afterCalculateLabelRotation(){Xe(this.options.afterCalculateLabelRotation,[this])}afterAutoSkip(){}beforeFit(){Xe(this.options.beforeFit,[this])}fit(){const t={width:0,height:0},{chart:e,options:{ticks:i,title:s,grid:n}}=this,a=this._isVisible(),o=this.isHorizontal();if(a){const a=Mr(s,e.options.font);if(o?(t.width=this.maxWidth,t.height=Fr(n)+a):(t.height=this.maxHeight,t.width=Fr(n)+a),i.display&&this.ticks.length){const{first:e,last:s,widest:n,highest:a}=this._getLabelSizes(),r=2*i.padding,l=Mi(this.labelRotation),h=Math.cos(l),c=Math.sin(l);if(o){const e=i.mirror?0:c*n.width+h*a.height;t.height=Math.min(this.maxHeight,t.height+e+r)}else{const e=i.mirror?0:h*n.width+c*a.height;t.width=Math.min(this.maxWidth,t.width+e+r)}this._calculatePadding(e,s,c,h)}}this._handleMargins(),o?(this.width=this._length=e.width-this._margins.left-this._margins.right,this.height=t.height):(this.width=t.width,this.height=this._length=e.height-this._margins.top-this._margins.bottom)}_calculatePadding(t,e,i,s){const{ticks:{align:n,padding:a},position:o}=this.options,r=0!==this.labelRotation,l="top"!==o&&"x"===this.axis;if(this.isHorizontal()){const o=this.getPixelForTick(0)-this.left,h=this.right-this.getPixelForTick(this.ticks.length-1);let c=0,d=0;r?l?(c=s*t.width,d=i*e.height):(c=i*t.height,d=s*e.width):"start"===n?d=e.width:"end"===n?c=t.width:"inner"!==n&&(c=t.width/2,d=e.width/2),this.paddingLeft=Math.max((c-o+a)*this.width/(this.width-o),0),this.paddingRight=Math.max((d-h+a)*this.width/(this.width-h),0)}else{let i=e.height/2,s=t.height/2;"start"===n?(i=0,s=t.height):"end"===n&&(i=e.height,s=0),this.paddingTop=i+a,this.paddingBottom=s+a}}_handleMargins(){this._margins&&(this._margins.left=Math.max(this.paddingLeft,this._margins.left),this._margins.top=Math.max(this.paddingTop,this._margins.top),this._margins.right=Math.max(this.paddingRight,this._margins.right),this._margins.bottom=Math.max(this.paddingBottom,this._margins.bottom))}afterFit(){Xe(this.options.afterFit,[this])}isHorizontal(){const{axis:t,position:e}=this.options;return"top"===e||"bottom"===e||"x"===t}isFullSize(){return this.options.fullSize}_convertTicksToLabels(t){let e,i;for(this.beforeTickToLabelConversion(),this.generateTickLabels(t),e=0,i=t.length;e({width:a[t]||0,height:o[t]||0});return{first:w(0),last:w(e-1),widest:w(v),highest:w(k),widths:a,heights:o}}getLabelForValue(t){return t}getPixelForValue(t,e){return NaN}getValueForPixel(t){}getPixelForTick(t){const e=this.ticks;return t<0||t>e.length-1?null:this.getPixelForValue(e[t].value)}getPixelForDecimal(t){this._reversePixels&&(t=1-t);const e=this._startPixel+t*this._length;return Oi(this._alignToPixels?Ms(this.chart,e,0):e)}getDecimalForPixel(t){const e=(t-this._startPixel)/this._length;return this._reversePixels?1-e:e}getBasePixel(){return this.getPixelForValue(this.getBaseValue())}getBaseValue(){const{min:t,max:e}=this;return t<0&&e<0?e:t>0&&e>0?t:0}getContext(t){const e=this.ticks||[];if(t>=0&&to*s?o/i:r/s:r*s0}_computeGridLineItems(t){const e=this.axis,i=this.chart,s=this.options,{grid:n,position:a,border:o}=s,r=n.offset,l=this.isHorizontal(),h=this.ticks,c=h.length+(r?1:0),d=Fr(n),u=[],g=o.setContext(this.getContext()),p=g.display?g.width:0,f=p/2,m=function(t){return Ms(i,t,p)};let b,x,y,_,v,k,w,C,S,F,M,A;if("top"===a)b=m(this.bottom),k=this.bottom-d,C=b-f,F=m(t.top)+f,A=t.bottom;else if("bottom"===a)b=m(this.top),F=t.top,A=m(t.bottom)-f,k=b+f,C=this.top+d;else if("left"===a)b=m(this.right),v=this.right-d,w=b-f,S=m(t.left)+f,M=t.right;else if("right"===a)b=m(this.left),S=t.left,M=m(t.right)-f,v=b+f,w=this.left+d;else if("x"===e){if("center"===a)b=m((t.top+t.bottom)/2+.5);else if(ze(a)){const t=Object.keys(a)[0],e=a[t];b=m(this.chart.scales[t].getPixelForValue(e))}F=t.top,A=t.bottom,k=b+f,C=k+d}else if("y"===e){if("center"===a)b=m((t.left+t.right)/2);else if(ze(a)){const t=Object.keys(a)[0],e=a[t];b=m(this.chart.scales[t].getPixelForValue(e))}v=b-f,w=v-d,S=t.left,M=t.right}const T=$e(s.ticks.maxTicksLimit,c),P=Math.max(1,Math.ceil(c/T));for(x=0;x0&&(a-=s/2);break}d={left:a,top:n,width:s+e.width,height:i+e.height,color:t.backdropColor}}f.push({label:y,font:C,textOffset:M,options:{rotation:p,color:i,strokeColor:r,strokeWidth:h,textAlign:u,textBaseline:A,translation:[_,v],backdrop:d}})}return f}_getXAxisLabelAlignment(){const{position:t,ticks:e}=this.options,i=-Mi(this.labelRotation);if(i)return"top"===t?"left":"right";let s="center";return"start"===e.align?s="left":"end"===e.align?s="right":"inner"===e.align&&(s="inner"),s}_getYAxisLabelAlignment(t){const{position:e,ticks:{crossAlign:i,mirror:s,padding:n}}=this.options,a=this._getLabelSizes(),o=t+n,r=a.widest.width;let l,h;return"left"===e?s?(h=this.right+n,"near"===i?l="left":"center"===i?(l="center",h+=r/2):(l="right",h+=r)):(h=this.right-o,"near"===i?l="right":"center"===i?(l="center",h-=r/2):(l="left",h=this.left)):"right"===e?s?(h=this.left+n,"near"===i?l="right":"center"===i?(l="center",h-=r/2):(l="left",h-=r)):(h=this.left+o,"near"===i?l="left":"center"===i?(l="center",h+=r/2):(l="right",h=this.right)):l="right",{textAlign:l,x:h}}_computeLabelArea(){if(this.options.ticks.mirror)return;const t=this.chart,e=this.options.position;return"left"===e||"right"===e?{top:0,left:this.left,bottom:t.height,right:this.right}:"top"===e||"bottom"===e?{top:this.top,left:0,bottom:this.bottom,right:t.width}:void 0}drawBackground(){const{ctx:t,options:{backgroundColor:e},left:i,top:s,width:n,height:a}=this;e&&(t.save(),t.fillStyle=e,t.fillRect(i,s,n,a),t.restore())}getLineWidthForValue(t){const e=this.options.grid;if(!this._isVisible()||!e.display)return 0;const i=this.ticks,s=i.findIndex(e=>e.value===t);if(s>=0){const t=e.setContext(this.getContext(s));return t.lineWidth}return 0}drawGrid(t){const e=this.options.grid,i=this.ctx,s=this._gridLineItems||(this._gridLineItems=this._computeGridLineItems(t));let n,a;const o=(t,e,s)=>{s.width&&s.color&&(i.save(),i.lineWidth=s.width,i.strokeStyle=s.color,i.setLineDash(s.borderDash||[]),i.lineDashOffset=s.borderDashOffset,i.beginPath(),i.moveTo(t.x,t.y),i.lineTo(e.x,e.y),i.stroke(),i.restore())};if(e.display)for(n=0,a=s.length;n{this.drawBackground(),this.drawGrid(t),this.drawTitle()}},{z:s,draw:()=>{this.drawBorder()}},{z:e,draw:t=>{this.drawLabels(t)}}]:[{z:e,draw:t=>{this.draw(t)}}]}getMatchingVisibleMetas(t){const e=this.chart.getSortedVisibleDatasetMetas(),i=this.axis+"AxisID",s=[];let n,a;for(n=0,a=e.length;n{const s=i.split("."),n=s.pop(),a=[t].concat(s).join("."),o=e[i].split("."),r=o.pop(),l=o.join(".");ws.route(a,n,l,r)})}function Or(t){return"id"in t&&"defaults"in t}class Rr{constructor(){this.controllers=new Lr(Ua,"datasets",!0),this.elements=new Lr(ur,"elements"),this.plugins=new Lr(Object,"plugins"),this.scales=new Lr(Er,"scales"),this._typedRegistries=[this.controllers,this.scales,this.elements]}add(...t){this._each("register",t)}remove(...t){this._each("unregister",t)}addControllers(...t){this._each("register",t,this.controllers)}addElements(...t){this._each("register",t,this.elements)}addPlugins(...t){this._each("register",t,this.plugins)}addScales(...t){this._each("register",t,this.scales)}getController(t){return this._get(t,this.controllers,"controller")}getElement(t){return this._get(t,this.elements,"element")}getPlugin(t){return this._get(t,this.plugins,"plugin")}getScale(t){return this._get(t,this.scales,"scale")}removeControllers(...t){this._each("unregister",t,this.controllers)}removeElements(...t){this._each("unregister",t,this.elements)}removePlugins(...t){this._each("unregister",t,this.plugins)}removeScales(...t){this._each("unregister",t,this.scales)}_each(t,e,i){[...e].forEach(e=>{const s=i||this._getRegistryForType(e);i||s.isForType(e)||s===this.plugins&&e.id?this._exec(t,s,e):qe(e,e=>{const s=i||this._getRegistryForType(e);this._exec(t,s,e)})})}_exec(t,e,i){const s=ai(t);Xe(i["before"+s],[],i),e[t](i),Xe(i["after"+s],[],i)}_getRegistryForType(t){for(let e=0;et.filter(t=>!e.some(e=>t.plugin.id===e.plugin.id));this._notify(s(e,i),t,"stop"),this._notify(s(i,e),t,"start")}}function zr(t){const e={},i=[],s=Object.keys(Wr.plugins.items);for(let a=0;a1&&qr(t[0].toLowerCase());if(e)return e}throw new Error(`Cannot determine type of '${t}' axis. Please provide 'axis' or 'position' option.`)}function Qr(t,e,i){if(i[e+"AxisID"]===t)return{axis:e}}function Gr(t,e){if(e.data&&e.data.datasets){const i=e.data.datasets.filter(e=>e.xAxisID===t||e.yAxisID===t);if(i.length)return Qr(t,"x",i[0])||Qr(t,"y",i[0])}return{}}function Jr(t,e){const i=xs[t.type]||{scales:{}},s=e.scales||{},n=jr(t.type,e),a=Object.create(null);return Object.keys(s).forEach(e=>{const o=s[e];if(!ze(o))return console.error(`Invalid scale configuration for scale: ${e}`);if(o._proxy)return console.warn(`Ignoring resolver passed as options for scale: ${e}`);const r=Yr(e,o,Gr(e,t),ws.scales[o.type]),l=Xr(r,n),h=i.scales||{};a[e]=Ze(Object.create(null),[{axis:r},o,h[r],h[l]])}),t.data.datasets.forEach(i=>{const n=i.type||t.type,o=i.indexAxis||jr(n,e),r=xs[n]||{},l=r.scales||{};Object.keys(l).forEach(t=>{const e=Hr(t,o),n=i[e+"AxisID"]||e;a[n]=a[n]||Object.create(null),Ze(a[n],[{axis:e},s[n],l[t]])})}),Object.keys(a).forEach(t=>{const e=a[t];Ze(e,[ws.scales[e.type],ws.scale])}),a}function Zr(t){const e=t.options||(t.options={});e.plugins=$e(e.plugins,{}),e.scales=Jr(t,e)}function tl(t){return t=t||{},t.datasets=t.datasets||[],t.labels=t.labels||[],t}function el(t){return t=t||{},t.data=tl(t.data),Zr(t),t}const il=new Map,sl=new Set;function nl(t,e){let i=il.get(t);return i||(i=e(),il.set(t,i),sl.add(i)),i}const al=(t,e,i)=>{const s=ni(e,i);void 0!==s&&t.add(s)};class ol{constructor(t){this._config=el(t),this._scopeCache=new Map,this._resolverCache=new Map}get platform(){return this._config.platform}get type(){return this._config.type}set type(t){this._config.type=t}get data(){return this._config.data}set data(t){this._config.data=tl(t)}get options(){return this._config.options}set options(t){this._config.options=t}get plugins(){return this._config.plugins}update(){const t=this._config;this.clearCache(),Zr(t)}clearCache(){this._scopeCache.clear(),this._resolverCache.clear()}datasetScopeKeys(t){return nl(t,()=>[[`datasets.${t}`,""]])}datasetAnimationScopeKeys(t,e){return nl(`${t}.transition.${e}`,()=>[[`datasets.${t}.transitions.${e}`,`transitions.${e}`],[`datasets.${t}`,""]])}datasetElementScopeKeys(t,e){return nl(`${t}-${e}`,()=>[[`datasets.${t}.elements.${e}`,`datasets.${t}`,`elements.${e}`,""]])}pluginScopeKeys(t){const e=t.id,i=this.type;return nl(`${i}-plugin-${e}`,()=>[[`plugins.${e}`,...t.additionalOptionScopes||[]]])}_cachedScopes(t,e){const i=this._scopeCache;let s=i.get(t);return s&&!e||(s=new Map,i.set(t,s)),s}getOptionScopes(t,e,i){const{options:s,type:n}=this,a=this._cachedScopes(t,i),o=a.get(e);if(o)return o;const r=new Set;e.forEach(e=>{t&&(r.add(t),e.forEach(e=>al(r,t,e))),e.forEach(t=>al(r,s,t)),e.forEach(t=>al(r,xs[n]||{},t)),e.forEach(t=>al(r,ws,t)),e.forEach(t=>al(r,ys,t))});const l=Array.from(r);return 0===l.length&&l.push(Object.create(null)),sl.has(e)&&a.set(e,l),l}chartOptionScopes(){const{options:t,type:e}=this;return[t,xs[e]||{},ws.datasets[e]||{},{type:e},ws,ys]}resolveNamedOptions(t,e,i,s=[""]){const n={$shared:!0},{resolver:a,subPrefixes:o}=rl(this._resolverCache,t,s);let r=a;if(hl(a,e)){n.$shared=!1,i=ri(i)?i():i;const e=this.createResolver(t,i,o);r=tn(a,i,e)}for(const l of e)n[l]=r[l];return n}createResolver(t,e,i=[""],s){const{resolver:n}=rl(this._resolverCache,t,i);return ze(e)?tn(n,e,void 0,s):n}}function rl(t,e,i){let s=t.get(e);s||(s=new Map,t.set(e,s));const n=i.join();let a=s.get(n);if(!a){const t=Zs(e,i);a={resolver:t,subPrefixes:i.filter(t=>!t.toLowerCase().includes("hover"))},s.set(n,a)}return a}const ll=t=>ze(t)&&Object.getOwnPropertyNames(t).some(e=>ri(t[e]));function hl(t,e){const{isScriptable:i,isIndexable:s}=en(t);for(const n of e){const e=i(n),a=s(n),o=(a||e)&&t[n];if(e&&(ri(o)||ll(o))||a&&Be(o))return!0}return!1}var cl="4.5.1";const dl=["top","bottom","left","right","chartArea"];function ul(t,e){return"top"===t||"bottom"===t||-1===dl.indexOf(t)&&"x"===e}function gl(t,e){return function(i,s){return i[t]===s[t]?i[e]-s[e]:i[t]-s[t]}}function pl(t){const e=t.chart,i=e.options.animation;e.notifyPlugins("afterRender"),Xe(i&&i.onComplete,[t],e)}function fl(t){const e=t.chart,i=e.options.animation;Xe(i&&i.onProgress,[t],e)}function ml(t){return Pn()&&"string"===typeof t?t=document.getElementById(t):t&&t.length&&(t=t[0]),t&&t.canvas&&(t=t.canvas),t}const bl={},xl=t=>{const e=ml(t);return Object.values(bl).filter(t=>t.canvas===e).pop()};function yl(t,e,i){const s=Object.keys(t);for(const n of s){const s=+n;if(s>=e){const a=t[n];delete t[n],(i>0||s>e)&&(t[s+i]=a)}}}function _l(t,e,i,s){return i&&"mouseout"!==t.type?s?e:t:null}class vl{static register(...t){Wr.add(...t),kl()}static unregister(...t){Wr.remove(...t),kl()}constructor(t,e){const i=this.config=new ol(e),s=ml(t),n=xl(s);if(n)throw new Error("Canvas is already in use. Chart with ID '"+n.id+"' must be destroyed before the canvas with ID '"+n.canvas.id+"' can be reused.");const a=i.createResolver(i.chartOptionScopes(),this.getContext());this.platform=new(i.platform||dr(s)),this.platform.updateConfig(i);const o=this.platform.acquireContext(s,a.aspectRatio),r=o&&o.canvas,l=r&&r.height,h=r&&r.width;this.id=Re(),this.ctx=o,this.canvas=r,this.width=h,this.height=l,this._options=a,this._aspectRatio=this.aspectRatio,this._layers=[],this._metasets=[],this._stacks=void 0,this.boxes=[],this.currentDevicePixelRatio=void 0,this.chartArea=void 0,this._active=[],this._lastEvent=void 0,this._listeners={},this._responsiveListeners=void 0,this._sortedMetasets=[],this.scales={},this._plugins=new Br,this.$proxies={},this._hiddenIndices={},this.attached=!1,this._animationsDisabled=void 0,this.$context=void 0,this._doResize=Ki(t=>this.update(t),a.resizeDelay||0),this._dataChanges=[],bl[this.id]=this,o&&r?(ma.listen(this,"complete",pl),ma.listen(this,"progress",fl),this._initialize(),this.attached&&this.update()):console.error("Failed to create chart: can't acquire context from the given item")}get aspectRatio(){const{options:{aspectRatio:t,maintainAspectRatio:e},width:i,height:s,_aspectRatio:n}=this;return We(t)?e&&n?n:s?i/s:null:t}get data(){return this.config.data}set data(t){this.config.data=t}get options(){return this._options}set options(t){this.config.options=t}get registry(){return Wr}_initialize(){return this.notifyPlugins("beforeInit"),this.options.responsive?this.resize():$n(this,this.options.devicePixelRatio),this.bindEvents(),this.notifyPlugins("afterInit"),this}clear(){return As(this.canvas,this.ctx),this}stop(){return ma.stop(this),this}resize(t,e){ma.running(this)?this._resizeBeforeDraw={width:t,height:e}:this._resize(t,e)}_resize(t,e){const i=this.options,s=this.canvas,n=i.maintainAspectRatio&&this.aspectRatio,a=this.platform.getMaximumSize(s,t,e,n),o=i.devicePixelRatio||this.platform.getDevicePixelRatio(),r=this.width?"resize":"attach";this.width=a.width,this.height=a.height,this._aspectRatio=this.aspectRatio,$n(this,o,!0)&&(this.notifyPlugins("resize",{size:a}),Xe(i.onResize,[this,a],this),this.attached&&this._doResize(r)&&this.render())}ensureScalesHaveIDs(){const t=this.options,e=t.scales||{};qe(e,(t,e)=>{t.id=e})}buildOrUpdateScales(){const t=this.options,e=t.scales,i=this.scales,s=Object.keys(i).reduce((t,e)=>(t[e]=!1,t),{});let n=[];e&&(n=n.concat(Object.keys(e).map(t=>{const i=e[t],s=Yr(t,i),n="r"===s,a="x"===s;return{options:i,dposition:n?"chartArea":a?"bottom":"left",dtype:n?"radialLinear":a?"category":"linear"}}))),qe(n,e=>{const n=e.options,a=n.id,o=Yr(a,n),r=$e(n.type,e.dtype);void 0!==n.position&&ul(n.position,o)===ul(e.dposition)||(n.position=e.dposition),s[a]=!0;let l=null;if(a in i&&i[a].type===r)l=i[a];else{const t=Wr.getScale(r);l=new t({id:a,type:r,ctx:this.ctx,chart:this}),i[l.id]=l}l.init(n,t)}),qe(s,(t,e)=>{t||delete i[e]}),qe(i,t=>{Uo.configure(this,t,t.options),Uo.addBox(this,t)})}_updateMetasets(){const t=this._metasets,e=this.data.datasets.length,i=t.length;if(t.sort((t,e)=>t.index-e.index),i>e){for(let t=e;te.length&&delete this._stacks,t.forEach((t,i)=>{0===e.filter(e=>e===t._dataset).length&&this._destroyDatasetMeta(i)})}buildOrUpdateControllers(){const t=[],e=this.data.datasets;let i,s;for(this._removeUnreferencedMetasets(),i=0,s=e.length;i{this.getDatasetMeta(e).controller.reset()},this)}reset(){this._resetElements(),this.notifyPlugins("reset")}update(t){const e=this.config;e.update();const i=this._options=e.createResolver(e.chartOptionScopes(),this.getContext()),s=this._animationsDisabled=!i.animation;if(this._updateScales(),this._checkEventBindings(),this._updateHiddenIndices(),this._plugins.invalidate(),!1===this.notifyPlugins("beforeUpdate",{mode:t,cancelable:!0}))return;const n=this.buildOrUpdateControllers();this.notifyPlugins("beforeElementsUpdate");let a=0;for(let l=0,h=this.data.datasets.length;l{t.reset()}),this._updateDatasets(t),this.notifyPlugins("afterUpdate",{mode:t}),this._layers.sort(gl("z","_idx"));const{_active:o,_lastEvent:r}=this;r?this._eventHandler(r,!0):o.length&&this._updateHoverStyles(o,o,!0),this.render()}_updateScales(){qe(this.scales,t=>{Uo.removeBox(this,t)}),this.ensureScalesHaveIDs(),this.buildOrUpdateScales()}_checkEventBindings(){const t=this.options,e=new Set(Object.keys(this._listeners)),i=new Set(t.events);li(e,i)&&!!this._responsiveListeners===t.responsive||(this.unbindEvents(),this.bindEvents())}_updateHiddenIndices(){const{_hiddenIndices:t}=this,e=this._getUniformDataChanges()||[];for(const{method:i,start:s,count:n}of e){const e="_removeElements"===i?-n:n;yl(t,s,e)}}_getUniformDataChanges(){const t=this._dataChanges;if(!t||!t.length)return;this._dataChanges=[];const e=this.data.datasets.length,i=e=>new Set(t.filter(t=>t[0]===e).map((t,e)=>e+","+t.splice(1).join(","))),s=i(0);for(let n=1;nt.split(",")).map(t=>({method:t[1],start:+t[2],count:+t[3]}))}_updateLayout(t){if(!1===this.notifyPlugins("beforeLayout",{cancelable:!0}))return;Uo.update(this,this.width,this.height,t);const e=this.chartArea,i=e.width<=0||e.height<=0;this._layers=[],qe(this.boxes,t=>{i&&"chartArea"===t.position||(t.configure&&t.configure(),this._layers.push(...t._layers()))},this),this._layers.forEach((t,e)=>{t._idx=e}),this.notifyPlugins("afterLayout")}_updateDatasets(t){if(!1!==this.notifyPlugins("beforeDatasetsUpdate",{mode:t,cancelable:!0})){for(let t=0,e=this.data.datasets.length;t=0;--e)this._drawDataset(t[e]);this.notifyPlugins("afterDatasetsDraw")}_drawDataset(t){const e=this.ctx,i={meta:t,index:t.index,cancelable:!0},s=pa(this,t);!1!==this.notifyPlugins("beforeDatasetDraw",i)&&(s&&Es(e,s),t.controller.draw(),s&&Ls(e),i.cancelable=!1,this.notifyPlugins("afterDatasetDraw",i))}isPointInArea(t){return Ds(t,this.chartArea,this._minPadding)}getElementsAtEventForMode(t,e,i,s){const n=So.modes[e];return"function"===typeof n?n(this,t,i,s):[]}getDatasetMeta(t){const e=this.data.datasets[t],i=this._metasets;let s=i.filter(t=>t&&t._dataset===e).pop();return s||(s={type:null,data:[],dataset:null,controller:null,hidden:null,xAxisID:null,yAxisID:null,order:e&&e.order||0,index:t,_dataset:e,_parsed:[],_sorted:!1},i.push(s)),s}getContext(){return this.$context||(this.$context=Js(null,{chart:this,type:"chart"}))}getVisibleDatasetCount(){return this.getSortedVisibleDatasetMetas().length}isDatasetVisible(t){const e=this.data.datasets[t];if(!e)return!1;const i=this.getDatasetMeta(t);return"boolean"===typeof i.hidden?!i.hidden:!e.hidden}setDatasetVisibility(t,e){const i=this.getDatasetMeta(t);i.hidden=!e}toggleDataVisibility(t){this._hiddenIndices[t]=!this._hiddenIndices[t]}getDataVisibility(t){return!this._hiddenIndices[t]}_updateVisibility(t,e,i){const s=i?"show":"hide",n=this.getDatasetMeta(t),a=n.controller._resolveAnimations(void 0,s);oi(e)?(n.data[e].hidden=!i,this.update()):(this.setDatasetVisibility(t,i),a.update(n,{visible:i}),this.update(e=>e.datasetIndex===t?s:void 0))}hide(t,e){this._updateVisibility(t,e,!1)}show(t,e){this._updateVisibility(t,e,!0)}_destroyDatasetMeta(t){const e=this._metasets[t];e&&e.controller&&e.controller._destroy(),delete this._metasets[t]}_stop(){let t,e;for(this.stop(),ma.remove(this),t=0,e=this.data.datasets.length;t{e.addEventListener(this,i,s),t[i]=s},s=(t,e,i)=>{t.offsetX=e,t.offsetY=i,this._eventHandler(t)};qe(this.options.events,t=>i(t,s))}bindResponsiveEvents(){this._responsiveListeners||(this._responsiveListeners={});const t=this._responsiveListeners,e=this.platform,i=(i,s)=>{e.addEventListener(this,i,s),t[i]=s},s=(i,s)=>{t[i]&&(e.removeEventListener(this,i,s),delete t[i])},n=(t,e)=>{this.canvas&&this.resize(t,e)};let a;const o=()=>{s("attach",o),this.attached=!0,this.resize(),i("resize",n),i("detach",a)};a=()=>{this.attached=!1,s("resize",n),this._stop(),this._resize(0,0),i("attach",o)},e.isAttached(this.canvas)?o():a()}unbindEvents(){qe(this._listeners,(t,e)=>{this.platform.removeEventListener(this,e,t)}),this._listeners={},qe(this._responsiveListeners,(t,e)=>{this.platform.removeEventListener(this,e,t)}),this._responsiveListeners=void 0}updateHoverStyle(t,e,i){const s=i?"set":"remove";let n,a,o,r;for("dataset"===e&&(n=this.getDatasetMeta(t[0].datasetIndex),n.controller["_"+s+"DatasetHoverStyle"]()),o=0,r=t.length;o{const i=this.getDatasetMeta(t);if(!i)throw new Error("No dataset found at index "+t);return{datasetIndex:t,element:i.data[e],index:e}}),s=!Ke(i,e);s&&(this._active=i,this._lastEvent=null,this._updateHoverStyles(i,e))}notifyPlugins(t,e,i){return this._plugins.notify(this,t,e,i)}isPluginEnabled(t){return 1===this._plugins._cache.filter(e=>e.plugin.id===t).length}_updateHoverStyles(t,e,i){const s=this.options.hover,n=(t,e)=>t.filter(t=>!e.some(e=>t.datasetIndex===e.datasetIndex&&t.index===e.index)),a=n(e,t),o=i?t:n(t,e);a.length&&this.updateHoverStyle(a,s.mode,!1),o.length&&s.mode&&this.updateHoverStyle(o,s.mode,!0)}_eventHandler(t,e){const i={event:t,replay:e,cancelable:!0,inChartArea:this.isPointInArea(t)},s=e=>(e.options.events||this.options.events).includes(t.native.type);if(!1===this.notifyPlugins("beforeEvent",i,s))return;const n=this._handleEvent(t,e,i.inChartArea);return i.cancelable=!1,this.notifyPlugins("afterEvent",i,s),(n||i.changed)&&this.render(),this}_handleEvent(t,e,i){const{_active:s=[],options:n}=this,a=e,o=this._getActiveElements(t,s,i,a),r=hi(t),l=_l(t,this._lastEvent,i,r);i&&(this._lastEvent=null,Xe(n.onHover,[t,o,this],this),r&&Xe(n.onClick,[t,o,this],this));const h=!Ke(o,s);return(h||e)&&(this._active=o,this._updateHoverStyles(o,s,e)),this._lastEvent=l,h}_getActiveElements(t,e,i,s){if("mouseout"===t.type)return[];if(!i)return e;const n=this.options.hover;return this.getElementsAtEventForMode(t,n.mode,n,s)}}function kl(){return qe(vl.instances,t=>t._plugins.invalidate())}function wl(t,e,i){const{startAngle:s,x:n,y:a,outerRadius:o,innerRadius:r,options:l}=e,{borderWidth:h,borderJoinStyle:c}=l,d=Math.min(h/o,Li(s-i));if(t.beginPath(),t.arc(n,a,o-h/2,s+d/2,i-d/2),r>0){const e=Math.min(h/r,Li(s-i));t.arc(n,a,r+h/2,i-e/2,s+e/2,!0)}else{const e=Math.min(h/2,o*Li(s-i));if("round"===c)t.arc(n,a,e,i-ci/2,s+ci/2,!0);else if("bevel"===c){const o=2*e*e,r=-o*Math.cos(i+ci/2)+n,l=-o*Math.sin(i+ci/2)+a,h=o*Math.cos(s+ci/2)+n,c=o*Math.sin(s+ci/2)+a;t.lineTo(r,l),t.lineTo(h,c)}}t.closePath(),t.moveTo(0,0),t.rect(0,0,t.canvas.width,t.canvas.height),t.clip("evenodd")}function Cl(t,e,i){const{startAngle:s,pixelMargin:n,x:a,y:o,outerRadius:r,innerRadius:l}=e;let h=n/r;t.beginPath(),t.arc(a,o,r,s-h,i+h),l>n?(h=n/l,t.arc(a,o,l,i+h,s-h,!0)):t.arc(a,o,n,i+fi,s-fi),t.closePath(),t.clip()}function Sl(t){return Hs(t,["outerStart","outerEnd","innerStart","innerEnd"])}function Fl(t,e,i,s){const n=Sl(t.options.borderRadius),a=(i-e)/2,o=Math.min(a,s*e/2),r=t=>{const e=(i-Math.min(a,t))*s/2;return Vi(t,0,Math.min(a,e))};return{outerStart:r(n.outerStart),outerEnd:r(n.outerEnd),innerStart:Vi(n.innerStart,0,o),innerEnd:Vi(n.innerEnd,0,o)}}function Ml(t,e,i,s){return{x:i+t*Math.cos(e),y:s+t*Math.sin(e)}}function Al(t,e,i,s,n,a){const{x:o,y:r,startAngle:l,pixelMargin:h,innerRadius:c}=e,d=Math.max(e.outerRadius+s+i-h,0),u=c>0?c+s+i+h:0;let g=0;const p=n-l;if(s){const t=c>0?c-s:0,e=d>0?d-s:0,i=(t+e)/2,n=0!==i?p*i/(i+s):p;g=(p-n)/2}const f=Math.max(.001,p*d-i/ci)/d,m=(p-f)/2,b=l+m+g,x=n-m-g,{outerStart:y,outerEnd:_,innerStart:v,innerEnd:k}=Fl(e,u,d,x-b),w=d-y,C=d-_,S=b+y/w,F=x-_/C,M=u+v,A=u+k,T=b+v/M,P=x-k/A;if(t.beginPath(),a){const e=(S+F)/2;if(t.arc(o,r,d,S,e),t.arc(o,r,d,e,F),_>0){const e=Ml(C,F,o,r);t.arc(e.x,e.y,_,F,x+fi)}const i=Ml(A,x,o,r);if(t.lineTo(i.x,i.y),k>0){const e=Ml(A,P,o,r);t.arc(e.x,e.y,k,x+fi,P+Math.PI)}const s=(x-k/u+(b+v/u))/2;if(t.arc(o,r,u,x-k/u,s,!0),t.arc(o,r,u,s,b+v/u,!0),v>0){const e=Ml(M,T,o,r);t.arc(e.x,e.y,v,T+Math.PI,b-fi)}const n=Ml(w,b,o,r);if(t.lineTo(n.x,n.y),y>0){const e=Ml(w,S,o,r);t.arc(e.x,e.y,y,b-fi,S)}}else{t.moveTo(o,r);const e=Math.cos(S)*d+o,i=Math.sin(S)*d+r;t.lineTo(e,i);const s=Math.cos(F)*d+o,n=Math.sin(F)*d+r;t.lineTo(s,n)}t.closePath()}function Tl(t,e,i,s,n){const{fullCircles:a,startAngle:o,circumference:r}=e;let l=e.endAngle;if(a){Al(t,e,i,s,l,n);for(let e=0;e=ci&&0===g&&"miter"!==c&&wl(t,e,f),a||(Al(t,e,i,s,f,n),t.stroke())}(0,jt.A)(vl,"defaults",ws),(0,jt.A)(vl,"instances",bl),(0,jt.A)(vl,"overrides",xs),(0,jt.A)(vl,"registry",Wr),(0,jt.A)(vl,"version",cl),(0,jt.A)(vl,"getChart",xl);class Dl extends ur{constructor(t){super(),(0,jt.A)(this,"circumference",void 0),(0,jt.A)(this,"endAngle",void 0),(0,jt.A)(this,"fullCircles",void 0),(0,jt.A)(this,"innerRadius",void 0),(0,jt.A)(this,"outerRadius",void 0),(0,jt.A)(this,"pixelMargin",void 0),(0,jt.A)(this,"startAngle",void 0),this.options=void 0,this.circumference=void 0,this.startAngle=void 0,this.endAngle=void 0,this.innerRadius=void 0,this.outerRadius=void 0,this.pixelMargin=0,this.fullCircles=0,t&&Object.assign(this,t)}inRange(t,e,i){const s=this.getProps(["x","y"],i),{angle:n,distance:a}=Pi(s,{x:t,y:e}),{startAngle:o,endAngle:r,innerRadius:l,outerRadius:h,circumference:c}=this.getProps(["startAngle","endAngle","innerRadius","outerRadius","circumference"],i),d=(this.options.spacing+this.options.borderWidth)/2,u=$e(c,r-o),g=Ii(n,o,r)&&o!==r,p=u>=di||g,f=Ri(a,l+d,h+d);return p&&f}getCenterPoint(t){const{x:e,y:i,startAngle:s,endAngle:n,innerRadius:a,outerRadius:o}=this.getProps(["x","y","startAngle","endAngle","innerRadius","outerRadius"],t),{offset:r,spacing:l}=this.options,h=(s+n)/2,c=(a+o+l+r)/2;return{x:e+Math.cos(h)*c,y:i+Math.sin(h)*c}}tooltipPosition(t){return this.getCenterPoint(t)}draw(t){const{options:e,circumference:i}=this,s=(e.offset||0)/4,n=(e.spacing||0)/2,a=e.circular;if(this.pixelMargin="inner"===e.borderAlign?.33:0,this.fullCircles=i>di?Math.floor(i/di):0,0===i||this.innerRadius<0||this.outerRadius<0)return;t.save();const o=(this.startAngle+this.endAngle)/2;t.translate(Math.cos(o)*s,Math.sin(o)*s);const r=1-Math.sin(Math.min(ci,i||0)),l=s*r;t.fillStyle=e.backgroundColor,t.strokeStyle=e.borderColor,Tl(t,this,l,n,a),Pl(t,this,l,n,a),t.restore()}}function El(t,e,i=e){t.lineCap=$e(i.borderCapStyle,e.borderCapStyle),t.setLineDash($e(i.borderDash,e.borderDash)),t.lineDashOffset=$e(i.borderDashOffset,e.borderDashOffset),t.lineJoin=$e(i.borderJoinStyle,e.borderJoinStyle),t.lineWidth=$e(i.borderWidth,e.borderWidth),t.strokeStyle=$e(i.borderColor,e.borderColor)}function Ll(t,e,i){t.lineTo(i.x,i.y)}function Il(t){return t.stepped?Is:t.tension||"monotone"===t.cubicInterpolationMode?Vs:Ll}function Vl(t,e,i={}){const s=t.length,{start:n=0,end:a=s-1}=i,{start:o,end:r}=e,l=Math.max(n,o),h=Math.min(a,r),c=nr&&a>r;return{count:s,start:l,loop:e.loop,ilen:h(o+(h?r-t:t))%a,y=()=>{g!==p&&(t.lineTo(m,p),t.lineTo(m,g),t.lineTo(m,f))};for(l&&(d=n[x(0)],t.moveTo(d.x,d.y)),c=0;c<=r;++c){if(d=n[x(c)],d.skip)continue;const e=d.x,i=d.y,s=0|e;s===u?(ip&&(p=i),m=(b*m+e)/++b):(y(),t.lineTo(e,i),u=s,b=0,g=p=i),f=i}y()}function Wl(t){const e=t.options,i=e.borderDash&&e.borderDash.length,s=!t._decimated&&!t._loop&&!e.tension&&"monotone"!==e.cubicInterpolationMode&&!e.stepped&&!i;return s?Rl:Ol}function Bl(t){return t.stepped?qn:t.tension||"monotone"===t.cubicInterpolationMode?Kn:Xn}function zl(t,e,i,s){let n=e._path;n||(n=e._path=new Path2D,e.path(n,i,s)&&n.closePath()),El(t,e.options),t.stroke(n)}function Nl(t,e,i,s){const{segments:n,options:a}=e,o=Wl(e);for(const r of n)El(t,a,r.style),t.beginPath(),o(t,e,r,{start:i,end:i+s-1})&&t.closePath(),t.stroke()}(0,jt.A)(Dl,"id","arc"),(0,jt.A)(Dl,"defaults",{borderAlign:"center",borderColor:"#fff",borderDash:[],borderDashOffset:0,borderJoinStyle:void 0,borderRadius:0,borderWidth:2,offset:0,spacing:0,angle:void 0,circular:!0,selfJoin:!1}),(0,jt.A)(Dl,"defaultRoutes",{backgroundColor:"backgroundColor"}),(0,jt.A)(Dl,"descriptors",{_scriptable:!0,_indexable:t=>"borderDash"!==t});const Ul="function"===typeof Path2D;function $l(t,e,i,s){Ul&&!e.options.segment?zl(t,e,i,s):Nl(t,e,i,s)}class jl extends ur{constructor(t){super(),this.animated=!0,this.options=void 0,this._chart=void 0,this._loop=void 0,this._fullLoop=void 0,this._path=void 0,this._points=void 0,this._segments=void 0,this._decimated=!1,this._pointsUpdated=!1,this._datasetIndex=void 0,t&&Object.assign(this,t)}updateControlPoints(t,e){const i=this.options;if((i.tension||"monotone"===i.cubicInterpolationMode)&&!i.stepped&&!this._pointsUpdated){const s=i.spanGaps?this._loop:this._fullLoop;Tn(this._points,i,t,s,e),this._pointsUpdated=!0}}set points(t){this._points=t,delete this._segments,delete this._path,this._pointsUpdated=!1}get points(){return this._points}get segments(){return this._segments||(this._segments=ra(this,this.options.segment))}first(){const t=this.segments,e=this.points;return t.length&&e[t[0].start]}last(){const t=this.segments,e=this.points,i=t.length;return i&&e[t[i-1].end]}interpolate(t,e){const i=this.options,s=t[e],n=this.points,a=na(this,{property:e,start:s,end:s});if(!a.length)return;const o=[],r=Bl(i);let l,h;for(l=0,h=a.length;l"borderDash"!==t&&"fill"!==t});class Xl extends ur{constructor(t){super(),(0,jt.A)(this,"parsed",void 0),(0,jt.A)(this,"skip",void 0),(0,jt.A)(this,"stop",void 0),this.options=void 0,this.parsed=void 0,this.skip=void 0,this.stop=void 0,t&&Object.assign(this,t)}inRange(t,e,i){const s=this.options,{x:n,y:a}=this.getProps(["x","y"],i);return Math.pow(t-n,2)+Math.pow(e-a,2){let{boxHeight:i=e,boxWidth:s=e}=t;return t.usePointStyle&&(i=Math.min(i,e),s=t.pointStyleWidth||Math.min(s,e)),{boxWidth:s,boxHeight:i,itemHeight:Math.max(e,i)}},nh=(t,e)=>null!==t&&null!==e&&t.datasetIndex===e.datasetIndex&&t.index===e.index;class ah extends ur{constructor(t){super(),this._added=!1,this.legendHitBoxes=[],this._hoveredItem=null,this.doughnutMode=!1,this.chart=t.chart,this.options=t.options,this.ctx=t.ctx,this.legendItems=void 0,this.columnSizes=void 0,this.lineWidths=void 0,this.maxHeight=void 0,this.maxWidth=void 0,this.top=void 0,this.bottom=void 0,this.left=void 0,this.right=void 0,this.height=void 0,this.width=void 0,this._margins=void 0,this.position=void 0,this.weight=void 0,this.fullSize=void 0}update(t,e,i){this.maxWidth=t,this.maxHeight=e,this._margins=i,this.setDimensions(),this.buildLabels(),this.fit()}setDimensions(){this.isHorizontal()?(this.width=this.maxWidth,this.left=this._margins.left,this.right=this.width):(this.height=this.maxHeight,this.top=this._margins.top,this.bottom=this.height)}buildLabels(){const t=this.options.labels||{};let e=Xe(t.generateLabels,[this.chart],this)||[];t.filter&&(e=e.filter(e=>t.filter(e,this.chart.data))),t.sort&&(e=e.sort((e,i)=>t.sort(e,i,this.chart.data))),this.options.reverse&&e.reverse(),this.legendItems=e}fit(){const{options:t,ctx:e}=this;if(!t.display)return void(this.width=this.height=0);const i=t.labels,s=Ys(i.font),n=s.size,a=this._computeTitleHeight(),{boxWidth:o,itemHeight:r}=sh(i,n);let l,h;e.font=s.string,this.isHorizontal()?(l=this.maxWidth,h=this._fitRows(a,n,o,r)+10):(h=this.maxHeight,l=this._fitCols(a,s,o,r)+10),this.width=Math.min(l,t.maxWidth||this.maxWidth),this.height=Math.min(h,t.maxHeight||this.maxHeight)}_fitRows(t,e,i,s){const{ctx:n,maxWidth:a,options:{labels:{padding:o}}}=this,r=this.legendHitBoxes=[],l=this.lineWidths=[0],h=s+o;let c=t;n.textAlign="left",n.textBaseline="middle";let d=-1,u=-h;return this.legendItems.forEach((t,g)=>{const p=i+e/2+n.measureText(t.text).width;(0===g||l[l.length-1]+p+2*o>a)&&(c+=h,l[l.length-(g>0?0:1)]=0,u+=h,d++),r[g]={left:0,top:u,row:d,width:p,height:s},l[l.length-1]+=p+o}),c}_fitCols(t,e,i,s){const{ctx:n,maxHeight:a,options:{labels:{padding:o}}}=this,r=this.legendHitBoxes=[],l=this.columnSizes=[],h=a-t;let c=o,d=0,u=0,g=0,p=0;return this.legendItems.forEach((t,a)=>{const{itemWidth:f,itemHeight:m}=oh(i,e,n,t,s);a>0&&u+m+2*o>h&&(c+=d+o,l.push({width:d,height:u}),g+=d+o,p++,d=u=0),r[a]={left:g,top:u,col:p,width:f,height:m},d=Math.max(d,f),u+=m+o}),c+=d,l.push({width:d,height:u}),c}adjustHitBoxes(){if(!this.options.display)return;const t=this._computeTitleHeight(),{legendHitBoxes:e,options:{align:i,labels:{padding:s},rtl:n}}=this,a=Gn(n,this.left,this.width);if(this.isHorizontal()){let n=0,o=Qi(i,this.left+s,this.right-this.lineWidths[n]);for(const r of e)n!==r.row&&(n=r.row,o=Qi(i,this.left+s,this.right-this.lineWidths[n])),r.top+=this.top+t+s,r.left=a.leftForLtr(a.x(o),r.width),o+=r.width+s}else{let n=0,o=Qi(i,this.top+t+s,this.bottom-this.columnSizes[n].height);for(const r of e)r.col!==n&&(n=r.col,o=Qi(i,this.top+t+s,this.bottom-this.columnSizes[n].height)),r.top=o,r.left+=this.left+s,r.left=a.leftForLtr(a.x(r.left),r.width),o+=r.height+s}}isHorizontal(){return"top"===this.options.position||"bottom"===this.options.position}draw(){if(this.options.display){const t=this.ctx;Es(t,this),this._draw(),Ls(t)}}_draw(){const{options:t,columnSizes:e,lineWidths:i,ctx:s}=this,{align:n,labels:a}=t,o=ws.color,r=Gn(t.rtl,this.left,this.width),l=Ys(a.font),{padding:h}=a,c=l.size,d=c/2;let u;this.drawTitle(),s.textAlign=r.textAlign("left"),s.textBaseline="middle",s.lineWidth=.5,s.font=l.string;const{boxWidth:g,boxHeight:p,itemHeight:f}=sh(a,c),m=function(t,e,i){if(isNaN(g)||g<=0||isNaN(p)||p<0)return;s.save();const n=$e(i.lineWidth,1);if(s.fillStyle=$e(i.fillStyle,o),s.lineCap=$e(i.lineCap,"butt"),s.lineDashOffset=$e(i.lineDashOffset,0),s.lineJoin=$e(i.lineJoin,"miter"),s.lineWidth=n,s.strokeStyle=$e(i.strokeStyle,o),s.setLineDash($e(i.lineDash,[])),a.usePointStyle){const o={radius:p*Math.SQRT2/2,pointStyle:i.pointStyle,rotation:i.rotation,borderWidth:n},l=r.xPlus(t,g/2),h=e+d;Ps(s,o,l,h,a.pointStyleWidth&&g)}else{const a=e+Math.max((c-p)/2,0),o=r.leftForLtr(t,g),l=qs(i.borderRadius);s.beginPath(),Object.values(l).some(t=>0!==t)?zs(s,{x:o,y:a,w:g,h:p,radius:l}):s.rect(o,a,g,p),s.fill(),0!==n&&s.stroke()}s.restore()},b=function(t,e,i){Bs(s,i.text,t,e+f/2,l,{strikethrough:i.hidden,textAlign:r.textAlign(i.textAlign)})},x=this.isHorizontal(),y=this._computeTitleHeight();u=x?{x:Qi(n,this.left+h,this.right-i[0]),y:this.top+h+y,line:0}:{x:this.left+h,y:Qi(n,this.top+y+h,this.bottom-e[0].height),line:0},Jn(this.ctx,t.textDirection);const _=f+h;this.legendItems.forEach((o,c)=>{s.strokeStyle=o.fontColor,s.fillStyle=o.fontColor;const p=s.measureText(o.text).width,f=r.textAlign(o.textAlign||(o.textAlign=a.textAlign)),v=g+d+p;let k=u.x,w=u.y;r.setWidth(this.width),x?c>0&&k+v+h>this.right&&(w=u.y+=_,u.line++,k=u.x=Qi(n,this.left+h,this.right-i[u.line])):c>0&&w+_>this.bottom&&(k=u.x=k+e[u.line].width+h,u.line++,w=u.y=Qi(n,this.top+y+h,this.bottom-e[u.line].height));const C=r.x(k);if(m(C,w,o),k=Gi(f,k+g+d,x?k+v:this.right,t.rtl),b(r.x(k),w,o),x)u.x+=v+h;else if("string"!==typeof o.text){const t=l.lineHeight;u.y+=hh(o,t)+h}else u.y+=_}),Zn(this.ctx,t.textDirection)}drawTitle(){const t=this.options,e=t.title,i=Ys(e.font),s=Ks(e.padding);if(!e.display)return;const n=Gn(t.rtl,this.left,this.width),a=this.ctx,o=e.position,r=i.size/2,l=s.top+r;let h,c=this.left,d=this.width;if(this.isHorizontal())d=Math.max(...this.lineWidths),h=this.top+l,c=Qi(t.align,c,this.right-d);else{const e=this.columnSizes.reduce((t,e)=>Math.max(t,e.height),0);h=l+Qi(t.align,this.top,this.bottom-e-t.labels.padding-this._computeTitleHeight())}const u=Qi(o,c,c+d);a.textAlign=n.textAlign(Yi(o)),a.textBaseline="middle",a.strokeStyle=e.color,a.fillStyle=e.color,a.font=i.string,Bs(a,e.text,u,h,i)}_computeTitleHeight(){const t=this.options.title,e=Ys(t.font),i=Ks(t.padding);return t.display?e.lineHeight+i.height:0}_getLegendItemAt(t,e){let i,s,n;if(Ri(t,this.left,this.right)&&Ri(e,this.top,this.bottom))for(n=this.legendHitBoxes,i=0;it.length>e.length?t:e)),e+i.size/2+s.measureText(n).width}function lh(t,e,i){let s=t;return"string"!==typeof e.text&&(s=hh(e,i)),s}function hh(t,e){const i=t.text?t.text.length:0;return e*i}function ch(t,e){return!("mousemove"!==t&&"mouseout"!==t||!e.onHover&&!e.onLeave)||!(!e.onClick||"click"!==t&&"mouseup"!==t)}var dh={id:"legend",_element:ah,start(t,e,i){const s=t.legend=new ah({ctx:t.ctx,options:i,chart:t});Uo.configure(t,s,i),Uo.addBox(t,s)},stop(t){Uo.removeBox(t,t.legend),delete t.legend},beforeUpdate(t,e,i){const s=t.legend;Uo.configure(t,s,i),s.options=i},afterUpdate(t){const e=t.legend;e.buildLabels(),e.adjustHitBoxes()},afterEvent(t,e){e.replay||t.legend.handleEvent(e.event)},defaults:{display:!0,position:"top",align:"center",fullSize:!0,reverse:!1,weight:1e3,onClick(t,e,i){const s=e.datasetIndex,n=i.chart;n.isDatasetVisible(s)?(n.hide(s),e.hidden=!0):(n.show(s),e.hidden=!1)},onHover:null,onLeave:null,labels:{color:t=>t.chart.options.color,boxWidth:40,padding:10,generateLabels(t){const e=t.data.datasets,{labels:{usePointStyle:i,pointStyle:s,textAlign:n,color:a,useBorderRadius:o,borderRadius:r}}=t.legend.options;return t._getSortedDatasetMetas().map(t=>{const l=t.controller.getStyle(i?0:void 0),h=Ks(l.borderWidth);return{text:e[t.index].label,fillStyle:l.backgroundColor,fontColor:a,hidden:!t.visible,lineCap:l.borderCapStyle,lineDash:l.borderDash,lineDashOffset:l.borderDashOffset,lineJoin:l.borderJoinStyle,lineWidth:(h.width+h.height)/4,strokeStyle:l.borderColor,pointStyle:s||l.pointStyle,rotation:l.rotation,textAlign:n||l.textAlign,borderRadius:o&&(r||l.borderRadius),datasetIndex:t.index}},this)}},title:{color:t=>t.chart.options.color,display:!1,position:"center",text:""}},descriptors:{_scriptable:t=>!t.startsWith("on"),labels:{_scriptable:t=>!["generateLabels","filter","sort"].includes(t)}}};new WeakMap;const uh={average(t){if(!t.length)return!1;let e,i,s=new Set,n=0,a=0;for(e=0,i=t.length;et+e)/s.size;return{x:o,y:n/a}},nearest(t,e){if(!t.length)return!1;let i,s,n,a=e.x,o=e.y,r=Number.POSITIVE_INFINITY;for(i=0,s=t.length;i-1?t.split("\n"):t}function fh(t,e){const{element:i,datasetIndex:s,index:n}=e,a=t.getDatasetMeta(s).controller,{label:o,value:r}=a.getLabelAndValue(n);return{chart:t,label:o,parsed:a.getParsed(n),raw:t.data.datasets[s].data[n],formattedValue:r,dataset:a.getDataset(),dataIndex:n,datasetIndex:s,element:i}}function mh(t,e){const i=t.chart.ctx,{body:s,footer:n,title:a}=t,{boxWidth:o,boxHeight:r}=e,l=Ys(e.bodyFont),h=Ys(e.titleFont),c=Ys(e.footerFont),d=a.length,u=n.length,g=s.length,p=Ks(e.padding);let f=p.height,m=0,b=s.reduce((t,e)=>t+e.before.length+e.lines.length+e.after.length,0);if(b+=t.beforeBody.length+t.afterBody.length,d&&(f+=d*h.lineHeight+(d-1)*e.titleSpacing+e.titleMarginBottom),b){const t=e.displayColors?Math.max(r,l.lineHeight):l.lineHeight;f+=g*t+(b-g)*l.lineHeight+(b-1)*e.bodySpacing}u&&(f+=e.footerMarginTop+u*c.lineHeight+(u-1)*e.footerSpacing);let x=0;const y=function(t){m=Math.max(m,i.measureText(t).width+x)};return i.save(),i.font=h.string,qe(t.title,y),i.font=l.string,qe(t.beforeBody.concat(t.afterBody),y),x=e.displayColors?o+2+e.boxPadding:0,qe(s,t=>{qe(t.before,y),qe(t.lines,y),qe(t.after,y)}),x=0,i.font=c.string,qe(t.footer,y),i.restore(),m+=p.width,{width:m,height:f}}function bh(t,e){const{y:i,height:s}=e;return it.height-s/2?"bottom":"center"}function xh(t,e,i,s){const{x:n,width:a}=s,o=i.caretSize+i.caretPadding;return"left"===t&&n+a+o>e.width||("right"===t&&n-a-o<0||void 0)}function yh(t,e,i,s){const{x:n,width:a}=i,{width:o,chartArea:{left:r,right:l}}=t;let h="center";return"center"===s?h=n<=(r+l)/2?"left":"right":n<=a/2?h="left":n>=o-a/2&&(h="right"),xh(h,t,e,i)&&(h="center"),h}function _h(t,e,i){const s=i.yAlign||e.yAlign||bh(t,i);return{xAlign:i.xAlign||e.xAlign||yh(t,e,i,s),yAlign:s}}function vh(t,e){let{x:i,width:s}=t;return"right"===e?i-=s:"center"===e&&(i-=s/2),i}function kh(t,e,i){let{y:s,height:n}=t;return"top"===e?s+=i:s-="bottom"===e?n+i:n/2,s}function wh(t,e,i,s){const{caretSize:n,caretPadding:a,cornerRadius:o}=t,{xAlign:r,yAlign:l}=i,h=n+a,{topLeft:c,topRight:d,bottomLeft:u,bottomRight:g}=qs(o);let p=vh(e,r);const f=kh(e,l,h);return"center"===l?"left"===r?p+=h:"right"===r&&(p-=h):"left"===r?p-=Math.max(c,u)+n:"right"===r&&(p+=Math.max(d,g)+n),{x:Vi(p,0,s.width-e.width),y:Vi(f,0,s.height-e.height)}}function Ch(t,e,i){const s=Ks(i.padding);return"center"===e?t.x+t.width/2:"right"===e?t.x+t.width-s.right:t.x+s.left}function Sh(t){return gh([],ph(t))}function Fh(t,e,i){return Js(t,{tooltip:e,tooltipItems:i,type:"tooltip"})}function Mh(t,e){const i=e&&e.dataset&&e.dataset.tooltip&&e.dataset.tooltip.callbacks;return i?t.override(i):t}const Ah={beforeTitle:Oe,title(t){if(t.length>0){const e=t[0],i=e.chart.data.labels,s=i?i.length:0;if(this&&this.options&&"dataset"===this.options.mode)return e.dataset.label||"";if(e.label)return e.label;if(s>0&&e.dataIndex{const e={before:[],lines:[],after:[]},n=Mh(i,t);gh(e.before,ph(Th(n,"beforeLabel",this,t))),gh(e.lines,Th(n,"label",this,t)),gh(e.after,ph(Th(n,"afterLabel",this,t))),s.push(e)}),s}getAfterBody(t,e){return Sh(Th(e.callbacks,"afterBody",this,t))}getFooter(t,e){const{callbacks:i}=e,s=Th(i,"beforeFooter",this,t),n=Th(i,"footer",this,t),a=Th(i,"afterFooter",this,t);let o=[];return o=gh(o,ph(s)),o=gh(o,ph(n)),o=gh(o,ph(a)),o}_createItems(t){const e=this._active,i=this.chart.data,s=[],n=[],a=[];let o,r,l=[];for(o=0,r=e.length;ot.filter(e,s,n,i))),t.itemSort&&(l=l.sort((e,s)=>t.itemSort(e,s,i))),qe(l,e=>{const i=Mh(t.callbacks,e);s.push(Th(i,"labelColor",this,e)),n.push(Th(i,"labelPointStyle",this,e)),a.push(Th(i,"labelTextColor",this,e))}),this.labelColors=s,this.labelPointStyles=n,this.labelTextColors=a,this.dataPoints=l,l}update(t,e){const i=this.options.setContext(this.getContext()),s=this._active;let n,a=[];if(s.length){const t=uh[i.position].call(this,s,this._eventPosition);a=this._createItems(i),this.title=this.getTitle(a,i),this.beforeBody=this.getBeforeBody(a,i),this.body=this.getBody(a,i),this.afterBody=this.getAfterBody(a,i),this.footer=this.getFooter(a,i);const e=this._size=mh(this,i),o=Object.assign({},t,e),r=_h(this.chart,i,o),l=wh(i,o,r,this.chart);this.xAlign=r.xAlign,this.yAlign=r.yAlign,n={opacity:1,x:l.x,y:l.y,width:e.width,height:e.height,caretX:t.x,caretY:t.y}}else 0!==this.opacity&&(n={opacity:0});this._tooltipItems=a,this.$context=void 0,n&&this._resolveAnimations().update(this,n),t&&i.external&&i.external.call(this,{chart:this.chart,tooltip:this,replay:e})}drawCaret(t,e,i,s){const n=this.getCaretPosition(t,i,s);e.lineTo(n.x1,n.y1),e.lineTo(n.x2,n.y2),e.lineTo(n.x3,n.y3)}getCaretPosition(t,e,i){const{xAlign:s,yAlign:n}=this,{caretSize:a,cornerRadius:o}=i,{topLeft:r,topRight:l,bottomLeft:h,bottomRight:c}=qs(o),{x:d,y:u}=t,{width:g,height:p}=e;let f,m,b,x,y,_;return"center"===n?(y=u+p/2,"left"===s?(f=d,m=f-a,x=y+a,_=y-a):(f=d+g,m=f+a,x=y-a,_=y+a),b=f):(m="left"===s?d+Math.max(r,h)+a:"right"===s?d+g-Math.max(l,c)-a:this.caretX,"top"===n?(x=u,y=x-a,f=m-a,b=m+a):(x=u+p,y=x+a,f=m+a,b=m-a),_=x),{x1:f,x2:m,x3:b,y1:x,y2:y,y3:_}}drawTitle(t,e,i){const s=this.title,n=s.length;let a,o,r;if(n){const l=Gn(i.rtl,this.x,this.width);for(t.x=Ch(this,i.titleAlign,i),e.textAlign=l.textAlign(i.titleAlign),e.textBaseline="middle",a=Ys(i.titleFont),o=i.titleSpacing,e.fillStyle=i.titleColor,e.font=a.string,r=0;r0!==t)?(t.beginPath(),t.fillStyle=n.multiKeyBackground,zs(t,{x:e,y:g,w:l,h:r,radius:o}),t.fill(),t.stroke(),t.fillStyle=a.backgroundColor,t.beginPath(),zs(t,{x:i,y:g+1,w:l-2,h:r-2,radius:o}),t.fill()):(t.fillStyle=n.multiKeyBackground,t.fillRect(e,g,l,r),t.strokeRect(e,g,l,r),t.fillStyle=a.backgroundColor,t.fillRect(i,g+1,l-2,r-2))}t.fillStyle=this.labelTextColors[i]}drawBody(t,e,i){const{body:s}=this,{bodySpacing:n,bodyAlign:a,displayColors:o,boxHeight:r,boxWidth:l,boxPadding:h}=i,c=Ys(i.bodyFont);let d=c.lineHeight,u=0;const g=Gn(i.rtl,this.x,this.width),p=function(i){e.fillText(i,g.x(t.x+u),t.y+d/2),t.y+=d+n},f=g.textAlign(a);let m,b,x,y,_,v,k;for(e.textAlign=a,e.textBaseline="middle",e.font=c.string,t.x=Ch(this,f,i),e.fillStyle=i.bodyColor,qe(this.beforeBody,p),u=o&&"right"!==f?"center"===a?l/2+h:l+2+h:0,y=0,v=s.length;y0&&e.stroke()}_updateAnimationTarget(t){const e=this.chart,i=this.$animations,s=i&&i.x,n=i&&i.y;if(s||n){const i=uh[t.position].call(this,this._active,this._eventPosition);if(!i)return;const a=this._size=mh(this,t),o=Object.assign({},i,this._size),r=_h(e,t,o),l=wh(t,o,r,e);s._to===l.x&&n._to===l.y||(this.xAlign=r.xAlign,this.yAlign=r.yAlign,this.width=a.width,this.height=a.height,this.caretX=i.x,this.caretY=i.y,this._resolveAnimations().update(this,l))}}_willRender(){return!!this.opacity}draw(t){const e=this.options.setContext(this.getContext());let i=this.opacity;if(!i)return;this._updateAnimationTarget(e);const s={width:this.width,height:this.height},n={x:this.x,y:this.y};i=Math.abs(i)<.001?0:i;const a=Ks(e.padding),o=this.title.length||this.beforeBody.length||this.body.length||this.afterBody.length||this.footer.length;e.enabled&&o&&(t.save(),t.globalAlpha=i,this.drawBackground(n,t,s,e),Jn(t,e.textDirection),n.y+=a.top,this.drawTitle(n,t,e),this.drawBody(n,t,e),this.drawFooter(n,t,e),Zn(t,e.textDirection),t.restore())}getActiveElements(){return this._active||[]}setActiveElements(t,e){const i=this._active,s=t.map(({datasetIndex:t,index:e})=>{const i=this.chart.getDatasetMeta(t);if(!i)throw new Error("Cannot find a dataset at index "+t);return{datasetIndex:t,element:i.data[e],index:e}}),n=!Ke(i,s),a=this._positionChanged(s,e);(n||a)&&(this._active=s,this._eventPosition=e,this._ignoreReplayEvents=!0,this.update(!0))}handleEvent(t,e,i=!0){if(e&&this._ignoreReplayEvents)return!1;this._ignoreReplayEvents=!1;const s=this.options,n=this._active||[],a=this._getActiveElements(t,n,e,i),o=this._positionChanged(a,t),r=e||!Ke(a,n)||o;return r&&(this._active=a,(s.enabled||s.external)&&(this._eventPosition={x:t.x,y:t.y},this.update(!0,e))),r}_getActiveElements(t,e,i,s){const n=this.options;if("mouseout"===t.type)return[];if(!s)return e.filter(t=>this.chart.data.datasets[t.datasetIndex]&&void 0!==this.chart.getDatasetMeta(t.datasetIndex).controller.getParsed(t.index));const a=this.chart.getElementsAtEventForMode(t,n.mode,n,i);return n.reverse&&a.reverse(),a}_positionChanged(t,e){const{caretX:i,caretY:s,options:n}=this,a=uh[n.position].call(this,t,e);return!1!==a&&(i!==a.x||s!==a.y)}}(0,jt.A)(Ph,"positioners",uh);var Dh={id:"tooltip",_element:Ph,positioners:uh,afterInit(t,e,i){i&&(t.tooltip=new Ph({chart:t,options:i}))},beforeUpdate(t,e,i){t.tooltip&&t.tooltip.initialize(i)},reset(t,e,i){t.tooltip&&t.tooltip.initialize(i)},afterDraw(t){const e=t.tooltip;if(e&&e._willRender()){const i={tooltip:e};if(!1===t.notifyPlugins("beforeTooltipDraw",{...i,cancelable:!0}))return;e.draw(t.ctx),t.notifyPlugins("afterTooltipDraw",i)}},afterEvent(t,e){if(t.tooltip){const i=e.replay;t.tooltip.handleEvent(e.event,i,e.inChartArea)&&(e.changed=!0)}},defaults:{enabled:!0,external:null,position:"average",backgroundColor:"rgba(0,0,0,0.8)",titleColor:"#fff",titleFont:{weight:"bold"},titleSpacing:2,titleMarginBottom:6,titleAlign:"left",bodyColor:"#fff",bodySpacing:2,bodyFont:{},bodyAlign:"left",footerColor:"#fff",footerSpacing:2,footerMarginTop:6,footerFont:{weight:"bold"},footerAlign:"left",padding:6,caretPadding:2,caretSize:5,cornerRadius:6,boxHeight:(t,e)=>e.bodyFont.size,boxWidth:(t,e)=>e.bodyFont.size,multiKeyBackground:"#fff",displayColors:!0,boxPadding:0,borderColor:"rgba(0,0,0,0)",borderWidth:0,animation:{duration:400,easing:"easeOutQuart"},animations:{numbers:{type:"number",properties:["x","y","width","height","caretX","caretY"]},opacity:{easing:"linear",duration:200}},callbacks:Ah},defaultRoutes:{bodyFont:"font",footerFont:"font",titleFont:"font"},descriptors:{_scriptable:t=>"filter"!==t&&"itemSort"!==t&&"external"!==t,_indexable:!1,callbacks:{_scriptable:!1,_indexable:!1},animation:{_fallback:!1},animations:{_fallback:"animation"}},additionalOptionScopes:["interaction"]};const Eh=(t,e,i,s)=>("string"===typeof e?(i=t.push(e)-1,s.unshift({index:i,label:e})):isNaN(e)&&(i=null),i);function Lh(t,e,i,s){const n=t.indexOf(e);if(-1===n)return Eh(t,e,i,s);const a=t.lastIndexOf(e);return n!==a?i:n}const Ih=(t,e)=>null===t?null:Vi(Math.round(t),0,e);function Vh(t){const e=this.getLabels();return t>=0&&te.length-1?null:this.getPixelForValue(e[t].value)}getValueForPixel(t){return Math.round(this._startValue+this.getDecimalForPixel(t)*this._valueRange)}getBasePixel(){return this.bottom}}function Rh(t,e){const i=[],s=1e-14,{bounds:n,step:a,min:o,max:r,precision:l,count:h,maxTicks:c,maxDigits:d,includeBounds:u}=t,g=a||1,p=c-1,{min:f,max:m}=e,b=!We(o),x=!We(r),y=!We(h),_=(m-f)/(d+1);let v,k,w,C,S=vi((m-f)/p/g)*g;if(Sp&&(S=vi(C*S/p/g)*g),We(l)||(v=Math.pow(10,l),S=Math.ceil(S*v)/v),"ticks"===n?(k=Math.floor(f/S)*S,w=Math.ceil(m/S)*S):(k=f,w=m),b&&x&&a&&Si((r-o)/a,S/1e3)?(C=Math.round(Math.min((r-o)/S,c)),S=(r-o)/C,k=o,w=r):y?(k=b?o:k,w=x?r:w,C=h-1,S=(w-k)/C):(C=(w-k)/S,C=_i(C,Math.round(C),S/1e3)?Math.round(C):Math.ceil(C));const F=Math.max(Ti(S),Ti(k));v=Math.pow(10,We(l)?F:l),k=Math.round(k*v)/v,w=Math.round(w*v)/v;let M=0;for(b&&(u&&k!==o?(i.push({value:o}),kr)break;i.push({value:t})}return x&&u&&w!==r?i.length&&_i(i[i.length-1].value,r,Wh(r,_,t))?i[i.length-1].value=r:i.push({value:r}):x&&w!==r||i.push({value:w}),i}function Wh(t,e,{horizontal:i,minRotation:s}){const n=Mi(s),a=(i?Math.sin(n):Math.cos(n))||.001,o=.75*e*(""+t).length;return Math.min(e/a,o)}(0,jt.A)(Oh,"id","category"),(0,jt.A)(Oh,"defaults",{ticks:{callback:Vh}});class Bh extends Er{constructor(t){super(t),this.start=void 0,this.end=void 0,this._startValue=void 0,this._endValue=void 0,this._valueRange=0}parse(t,e){return We(t)||("number"===typeof t||t instanceof Number)&&!isFinite(+t)?null:+t}handleTickRangeOptions(){const{beginAtZero:t}=this.options,{minDefined:e,maxDefined:i}=this.getUserBounds();let{min:s,max:n}=this;const a=t=>s=e?s:t,o=t=>n=i?n:t;if(t){const t=yi(s),e=yi(n);t<0&&e<0?o(0):t>0&&e>0&&a(0)}if(s===n){let e=0===n?1:Math.abs(.05*n);o(n+e),t||a(s-e)}this.min=s,this.max=n}getTickLimit(){const t=this.options.ticks;let e,{maxTicksLimit:i,stepSize:s}=t;return s?(e=Math.ceil(this.max/s)-Math.floor(this.min/s)+1,e>1e3&&(console.warn(`scales.${this.id}.ticks.stepSize: ${s} would result generating up to ${e} ticks. Limiting to 1000.`),e=1e3)):(e=this.computeTickLimit(),i=i||11),i&&(e=Math.min(i,e)),e}computeTickLimit(){return Number.POSITIVE_INFINITY}buildTicks(){const t=this.options,e=t.ticks;let i=this.getTickLimit();i=Math.max(2,i);const s={maxTicks:i,bounds:t.bounds,min:t.min,max:t.max,precision:e.precision,step:e.stepSize,count:e.count,maxDigits:this._maxDigits(),horizontal:this.isHorizontal(),minRotation:e.minRotation||0,includeBounds:!1!==e.includeBounds},n=this._range||this,a=Rh(s,n);return"ticks"===t.bounds&&Fi(a,this,"value"),t.reverse?(a.reverse(),this.start=this.max,this.end=this.min):(this.start=this.min,this.end=this.max),a}configure(){const t=this.ticks;let e=this.min,i=this.max;if(super.configure(),this.options.offset&&t.length){const s=(i-e)/Math.max(t.length-1,1)/2;e-=s,i+=s}this._startValue=e,this._endValue=i,this._valueRange=i-e}getLabelForValue(t){return gs(t,this.chart.options.locale,this.options.ticks.format)}}class zh extends Bh{determineDataLimits(){const{min:t,max:e}=this.getMinMax(!0);this.min=Ne(t)?t:0,this.max=Ne(e)?e:1,this.handleTickRangeOptions()}computeTickLimit(){const t=this.isHorizontal(),e=t?this.width:this.height,i=Mi(this.options.ticks.minRotation),s=(t?Math.sin(i):Math.cos(i))||.001,n=this._resolveTickFontOptions(0);return Math.ceil(e/Math.min(40,n.lineHeight/s))}getPixelForValue(t){return null===t?NaN:this.getPixelForDecimal((t-this._startValue)/this._valueRange)}getValueForPixel(t){return this._startValue+this.getDecimalForPixel(t)*this._valueRange}}(0,jt.A)(zh,"id","linear"),(0,jt.A)(zh,"defaults",{ticks:{callback:ms.formatters.numeric}});const Nh=t=>Math.floor(xi(t)),Uh=(t,e)=>Math.pow(10,Nh(t)+e);function $h(t){const e=t/Math.pow(10,Nh(t));return 1===e}function jh(t,e,i){const s=Math.pow(10,i),n=Math.floor(t/s),a=Math.ceil(e/s);return a-n}function Hh(t,e){const i=e-t;let s=Nh(i);while(jh(t,e,s)>10)s++;while(jh(t,e,s)<10)s--;return Math.min(s,Nh(t))}function Xh(t,{min:e,max:i}){e=Ue(t.min,e);const s=[],n=Nh(e);let a=Hh(e,i),o=a<0?Math.pow(10,Math.abs(a)):1;const r=Math.pow(10,a),l=n>a?Math.pow(10,n):0,h=Math.round((e-l)*o)/o,c=Math.floor((e-l)/r/10)*r*10;let d=Math.floor((h-c)/Math.pow(10,a)),u=Ue(t.min,Math.round((l+c+d*Math.pow(10,a))*o)/o);while(u=10?d=d<15?15:20:d++,d>=20&&(a++,d=2,o=a>=0?1:o),u=Math.round((l+c+d*Math.pow(10,a))*o)/o;const g=Ue(t.max,u);return s.push({value:g,major:$h(g),significand:d}),s}class qh extends Er{constructor(t){super(t),this.start=void 0,this.end=void 0,this._startValue=void 0,this._valueRange=0}parse(t,e){const i=Bh.prototype.parse.apply(this,[t,e]);if(0!==i)return Ne(i)&&i>0?i:null;this._zero=!0}determineDataLimits(){const{min:t,max:e}=this.getMinMax(!0);this.min=Ne(t)?Math.max(0,t):null,this.max=Ne(e)?Math.max(0,e):null,this.options.beginAtZero&&(this._zero=!0),this._zero&&this.min!==this._suggestedMin&&!Ne(this._userMin)&&(this.min=t===Uh(this.min,0)?Uh(this.min,-1):Uh(this.min,0)),this.handleTickRangeOptions()}handleTickRangeOptions(){const{minDefined:t,maxDefined:e}=this.getUserBounds();let i=this.min,s=this.max;const n=e=>i=t?i:e,a=t=>s=e?s:t;i===s&&(i<=0?(n(1),a(10)):(n(Uh(i,-1)),a(Uh(s,1)))),i<=0&&n(Uh(s,-1)),s<=0&&a(Uh(i,1)),this.min=i,this.max=s}buildTicks(){const t=this.options,e={min:this._userMin,max:this._userMax},i=Xh(e,this);return"ticks"===t.bounds&&Fi(i,this,"value"),t.reverse?(i.reverse(),this.start=this.max,this.end=this.min):(this.start=this.min,this.end=this.max),i}getLabelForValue(t){return void 0===t?"0":gs(t,this.chart.options.locale,this.options.ticks.format)}configure(){const t=this.min;super.configure(),this._startValue=xi(t),this._valueRange=xi(this.max)-xi(t)}getPixelForValue(t){return void 0!==t&&0!==t||(t=this.min),null===t||isNaN(t)?NaN:this.getPixelForDecimal(t===this.min?0:(xi(t)-this._startValue)/this._valueRange)}getValueForPixel(t){const e=this.getDecimalForPixel(t);return Math.pow(10,this._startValue+e*this._valueRange)}}function Kh(t){const e=t.ticks;if(e.display&&t.display){const t=Ks(e.backdropPadding);return $e(e.font&&e.font.size,ws.font.size)+t.height}return 0}function Yh(t,e,i){return i=Be(i)?i:[i],{w:Fs(t,e.string,i),h:i.length*e.lineHeight}}function Qh(t,e,i,s,n){return t===s||t===n?{start:e-i/2,end:e+i/2}:tn?{start:e-i,end:e}:{start:e,end:e+i}}function Gh(t){const e={l:t.left+t._padding.left,r:t.right-t._padding.right,t:t.top+t._padding.top,b:t.bottom-t._padding.bottom},i=Object.assign({},e),s=[],n=[],a=t._pointLabels.length,o=t.options.pointLabels,r=o.centerPointLabels?ci/a:0;for(let l=0;le.r&&(r=(s.end-e.r)/a,t.r=Math.max(t.r,e.r+r)),n.starte.b&&(l=(n.end-e.b)/o,t.b=Math.max(t.b,e.b+l))}function Zh(t,e,i){const s=t.drawingArea,{extra:n,additionalAngle:a,padding:o,size:r}=i,l=t.getPointPosition(e,s+n+o,a),h=Math.round(Ai(Li(l.angle+fi))),c=nc(l.y,r.h,h),d=ic(h),u=sc(l.x,r.w,d);return{visible:!0,x:l.x,y:c,textAlign:d,left:u,top:c,right:u+r.w,bottom:c+r.h}}function tc(t,e){if(!e)return!0;const{left:i,top:s,right:n,bottom:a}=t,o=Ds({x:i,y:s},e)||Ds({x:i,y:a},e)||Ds({x:n,y:s},e)||Ds({x:n,y:a},e);return!o}function ec(t,e,i){const s=[],n=t._pointLabels.length,a=t.options,{centerPointLabels:o,display:r}=a.pointLabels,l={extra:Kh(a)/2,additionalAngle:o?ci/n:0};let h;for(let c=0;c270||i<90)&&(t-=e),t}function ac(t,e,i){const{left:s,top:n,right:a,bottom:o}=i,{backdropColor:r}=e;if(!We(r)){const i=qs(e.borderRadius),l=Ks(e.backdropPadding);t.fillStyle=r;const h=s-l.left,c=n-l.top,d=a-s+l.width,u=o-n+l.height;Object.values(i).some(t=>0!==t)?(t.beginPath(),zs(t,{x:h,y:c,w:d,h:u,radius:i}),t.fill()):t.fillRect(h,c,d,u)}}function oc(t,e){const{ctx:i,options:{pointLabels:s}}=t;for(let n=e-1;n>=0;n--){const e=t._pointLabelItems[n];if(!e.visible)continue;const a=s.setContext(t.getPointLabelContext(n));ac(i,a,e);const o=Ys(a.font),{x:r,y:l,textAlign:h}=e;Bs(i,t._pointLabels[n],r,l+o.lineHeight/2,o,{color:a.color,textAlign:h,textBaseline:"middle"})}}function rc(t,e,i,s){const{ctx:n}=t;if(i)n.arc(t.xCenter,t.yCenter,e,0,di);else{let i=t.getPointPosition(0,e);n.moveTo(i.x,i.y);for(let a=1;a{const i=Xe(this.options.pointLabels.callback,[t,e],this);return i||0===i?i:""}).filter((t,e)=>this.chart.getDataVisibility(e))}fit(){const t=this.options;t.display&&t.pointLabels.display?Gh(this):this.setCenterPoint(0,0,0,0)}setCenterPoint(t,e,i,s){this.xCenter+=Math.floor((t-e)/2),this.yCenter+=Math.floor((i-s)/2),this.drawingArea-=Math.min(this.drawingArea/2,Math.max(t,e,i,s))}getIndexAngle(t){const e=di/(this._pointLabels.length||1),i=this.options.startAngle||0;return Li(t*e+Mi(i))}getDistanceFromCenterForValue(t){if(We(t))return NaN;const e=this.drawingArea/(this.max-this.min);return this.options.reverse?(this.max-t)*e:(t-this.min)*e}getValueForDistanceFromCenter(t){if(We(t))return NaN;const e=t/(this.drawingArea/(this.max-this.min));return this.options.reverse?this.max-e:this.min+e}getPointLabelContext(t){const e=this._pointLabels||[];if(t>=0&&t{if(0!==e||0===e&&this.min<0){r=this.getDistanceFromCenterForValue(t.value);const i=this.getContext(e),o=s.setContext(i),l=n.setContext(i);lc(this,o,r,a,l)}}),i.display){for(t.save(),o=a-1;o>=0;o--){const s=i.setContext(this.getPointLabelContext(o)),{color:n,lineWidth:a}=s;a&&n&&(t.lineWidth=a,t.strokeStyle=n,t.setLineDash(s.borderDash),t.lineDashOffset=s.borderDashOffset,r=this.getDistanceFromCenterForValue(e.reverse?this.min:this.max),l=this.getPointPosition(o,r),t.beginPath(),t.moveTo(this.xCenter,this.yCenter),t.lineTo(l.x,l.y),t.stroke())}t.restore()}}drawBorder(){}drawLabels(){const t=this.ctx,e=this.options,i=e.ticks;if(!i.display)return;const s=this.getIndexAngle(0);let n,a;t.save(),t.translate(this.xCenter,this.yCenter),t.rotate(s),t.textAlign="center",t.textBaseline="middle",this.ticks.forEach((s,o)=>{if(0===o&&this.min>=0&&!e.reverse)return;const r=i.setContext(this.getContext(o)),l=Ys(r.font);if(n=this.getDistanceFromCenterForValue(this.ticks[o].value),r.showLabelBackdrop){t.font=l.string,a=t.measureText(s.label).width,t.fillStyle=r.backdropColor;const e=Ks(r.backdropPadding);t.fillRect(-a/2-e.left,-n-l.size/2-e.top,a+e.width,l.size+e.height)}Bs(t,s.label,0,-n,l,{color:r.color,strokeColor:r.textStrokeColor,strokeWidth:r.textStrokeWidth})}),t.restore()}drawTitle(){}}(0,jt.A)(cc,"id","radialLinear"),(0,jt.A)(cc,"defaults",{display:!0,animate:!0,position:"chartArea",angleLines:{display:!0,lineWidth:1,borderDash:[],borderDashOffset:0},grid:{circular:!1},startAngle:0,ticks:{showLabelBackdrop:!0,callback:ms.formatters.numeric},pointLabels:{backdropColor:void 0,backdropPadding:2,display:!0,font:{size:10},callback(t){return t},padding:5,centerPointLabels:!1}}),(0,jt.A)(cc,"defaultRoutes",{"angleLines.color":"borderColor","pointLabels.color":"color","ticks.color":"color"}),(0,jt.A)(cc,"descriptors",{angleLines:{_fallback:"grid"}});const dc={millisecond:{common:!0,size:1,steps:1e3},second:{common:!0,size:1e3,steps:60},minute:{common:!0,size:6e4,steps:60},hour:{common:!0,size:36e5,steps:24},day:{common:!0,size:864e5,steps:30},week:{common:!1,size:6048e5,steps:4},month:{common:!0,size:2628e6,steps:12},quarter:{common:!1,size:7884e6,steps:4},year:{common:!0,size:3154e7}},uc=Object.keys(dc);function gc(t,e){return t-e}function pc(t,e){if(We(e))return null;const i=t._adapter,{parser:s,round:n,isoWeekday:a}=t._parseOpts;let o=e;return"function"===typeof s&&(o=s(o)),Ne(o)||(o="string"===typeof s?i.parse(o,s):i.parse(o)),null===o?null:(n&&(o="week"!==n||!Ci(a)&&!0!==a?i.startOf(o,n):i.startOf(o,"isoWeek",a)),+o)}function fc(t,e,i,s){const n=uc.length;for(let a=uc.indexOf(t);a=uc.indexOf(i);a--){const i=uc[a];if(dc[i].common&&t._adapter.diff(n,s,i)>=e-1)return i}return uc[i?uc.indexOf(i):0]}function bc(t){for(let e=uc.indexOf(t)+1,i=uc.length;e=e?i[s]:i[n];t[a]=!0}}else t[e]=!0}function yc(t,e,i,s){const n=t._adapter,a=+n.startOf(e[0].value,s),o=e[e.length-1].value;let r,l;for(r=a;r<=o;r=+n.add(r,1,s))l=i[r],l>=0&&(e[l].major=!0);return e}function _c(t,e,i){const s=[],n={},a=e.length;let o,r;for(o=0;o+t.value))}initOffsets(t=[]){let e,i,s=0,n=0;this.options.offset&&t.length&&(e=this.getDecimalForValue(t[0]),s=1===t.length?1-e:(this.getDecimalForValue(t[1])-e)/2,i=this.getDecimalForValue(t[t.length-1]),n=1===t.length?i:(i-this.getDecimalForValue(t[t.length-2]))/2);const a=t.length<3?.5:.25;s=Vi(s,0,a),n=Vi(n,0,a),this._offsets={start:s,end:n,factor:1/(s+1+n)}}_generate(){const t=this._adapter,e=this.min,i=this.max,s=this.options,n=s.time,a=n.unit||fc(n.minUnit,e,i,this._getLabelCapacity(e)),o=$e(s.ticks.stepSize,1),r="week"===a&&n.isoWeekday,l=Ci(r)||!0===r,h={};let c,d,u=e;if(l&&(u=+t.startOf(u,"isoWeek",r)),u=+t.startOf(u,l?"day":a),t.diff(i,e,a)>1e5*o)throw new Error(e+" and "+i+" are too far apart with stepSize of "+o+" "+a);const g="data"===s.ticks.source&&this.getDataTimestamps();for(c=u,d=0;c+t)}getLabelForValue(t){const e=this._adapter,i=this.options.time;return i.tooltipFormat?e.format(t,i.tooltipFormat):e.format(t,i.displayFormats.datetime)}format(t,e){const i=this.options,s=i.time.displayFormats,n=this._unit,a=e||s[n];return this._adapter.format(t,a)}_tickFormatFunction(t,e,i,s){const n=this.options,a=n.ticks.callback;if(a)return Xe(a,[t,e,i],this);const o=n.time.displayFormats,r=this._unit,l=this._majorUnit,h=r&&o[r],c=l&&o[l],d=i[e],u=l&&c&&d&&d.major;return this._adapter.format(t,s||(u?c:h))}generateTickLabels(t){let e,i,s;for(e=0,i=t.length;e0?o:1}getDataTimestamps(){let t,e,i=this._cache.data||[];if(i.length)return i;const s=this.getMatchingVisibleMetas();if(this._normalized&&s.length)return this._cache.data=s[0].controller.getAllParsedValues(this);for(t=0,e=s.length;t=t[r].pos&&e<=t[l].pos&&({lo:r,hi:l}=Bi(t,"pos",e)),({pos:s,time:a}=t[r]),({pos:n,time:o}=t[l])):(e>=t[r].time&&e<=t[l].time&&({lo:r,hi:l}=Bi(t,"time",e)),({time:s,pos:a}=t[r]),({time:n,pos:o}=t[l]));const h=n-s;return h?a+(o-a)*(e-s)/h:a}(0,jt.A)(vc,"id","time"),(0,jt.A)(vc,"defaults",{bounds:"data",adapters:{},time:{parser:!1,unit:!1,round:!1,isoWeekday:!1,minUnit:"millisecond",displayFormats:{}},ticks:{source:"auto",callback:!1,major:{enabled:!1}}});class wc extends vc{constructor(t){super(t),this._table=[],this._minPos=void 0,this._tableRange=void 0}initOffsets(){const t=this._getTimestampsForTable(),e=this._table=this.buildLookupTable(t);this._minPos=kc(e,this.min),this._tableRange=kc(e,this.max)-this._minPos,super.initOffsets(t)}buildLookupTable(t){const{min:e,max:i}=this,s=[],n=[];let a,o,r,l,h;for(a=0,o=t.length;a=e&&l<=i&&s.push(l);if(s.length<2)return[{time:e,pos:0},{time:i,pos:1}];for(a=0,o=s.length;at-e)}_getTimestampsForTable(){let t=this._cache.all||[];if(t.length)return t;const e=this.getDataTimestamps(),i=this.getLabelTimestamps();return t=e.length&&i.length?this.normalize(e.concat(i)):e.length?e:i,t=this._cache.all=t,t}getDecimalForValue(t){return(kc(this._table,t)-this._minPos)/this._tableRange}getValueForPixel(t){const e=this._offsets,i=this.getDecimalForPixel(t)/e.factor-e.end;return kc(this._table,i*this._tableRange+this._minPos,!0)}}(0,jt.A)(wc,"id","timeseries"),(0,jt.A)(wc,"defaults",vc.defaults);var Cc=i(144);const Sc={data:{type:Object,required:!0},options:{type:Object,default:()=>({})},plugins:{type:Array,default:()=>[]},datasetIdKey:{type:String,default:"label"},updateMode:{type:String,default:void 0}},Fc={ariaLabel:{type:String},ariaDescribedby:{type:String}},Mc={type:{type:String,required:!0},destroyDelay:{type:Number,default:0},...Sc,...Fc},Ac="2"===s.rE[0]?(t,e)=>Object.assign(t,{attrs:e}):(t,e)=>Object.assign(t,e);function Tc(t){return(0,Cc.ju)(t)?(0,Cc.ux)(t):t}function Pc(t){let e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:t;return(0,Cc.ju)(e)?new Proxy(t,{}):t}function Dc(t,e){const i=t.options;i&&e&&Object.assign(i,e)}function Ec(t,e){t.labels=e}function Lc(t,e,i){const s=[];t.datasets=e.map(e=>{const n=t.datasets.find(t=>t[i]===e[i]);return n&&e.data&&!s.includes(n)?(s.push(n),Object.assign(n,e),n):{...e}})}function Ic(t,e){const i={labels:[],datasets:[]};return Ec(i,t.labels),Lc(i,t.datasets,e),i}const Vc=(0,s.pM)({props:Mc,setup(t,e){let{expose:i,slots:n}=e;const a=(0,Cc.KR)(null),o=(0,Cc.IJ)(null);i({chart:o});const r=()=>{if(!a.value)return;const{type:e,data:i,options:s,plugins:n,datasetIdKey:r}=t,l=Ic(i,r),h=Pc(l,i);o.value=new vl(a.value,{type:e,data:h,options:{...s},plugins:n})},l=()=>{const e=(0,Cc.ux)(o.value);e&&(t.destroyDelay>0?setTimeout(()=>{e.destroy(),o.value=null},t.destroyDelay):(e.destroy(),o.value=null))},h=e=>{e.update(t.updateMode)};return(0,s.sV)(r),(0,s.hi)(l),(0,s.wB)([()=>t.options,()=>t.data],(e,i)=>{let[n,a]=e,[r,l]=i;const c=(0,Cc.ux)(o.value);if(!c)return;let d=!1;if(n){const t=Tc(n),e=Tc(r);t&&t!==e&&(Dc(c,t),d=!0)}if(a){const e=Tc(a.labels),i=Tc(l.labels),s=Tc(a.datasets),n=Tc(l.datasets);e!==i&&(Ec(c.config.data,e),d=!0),s&&s!==n&&(Lc(c.config.data,s,t.datasetIdKey),d=!0)}d&&(0,s.dY)(()=>{h(c)})},{deep:!0}),()=>(0,s.h)("canvas",{role:"img","aria-label":t.ariaLabel,"aria-describedby":t.ariaDescribedby,ref:a},[(0,s.h)("p",{},[n.default?n.default():""])])}});function Oc(t,e){return vl.register(e),(0,s.pM)({props:Sc,setup(e,i){let{expose:n}=i;const a=(0,Cc.IJ)(null),o=t=>{a.value=t?.chart};return n({chart:a}),()=>(0,s.h)(Vc,Ac({ref:o},{type:t,...e}))}})}const Rc=Oc("doughnut",ro);i(6573),i(8100),i(7936),i(9577),i(1549),i(9797),i(9631),i(5623),i(4603),i(7566),i(8721);class Wc extends Error{constructor(t,e,i=!1,s=""){super(t),this.name="BatchOperationError",this.code=e,this.recoverable=i,this.suggestion=s}}const Bc={401:()=>new Wc("认证失败,请重新登录","AUTH_FAILED",!1,"请刷新页面并重新登录"),403:()=>new Wc("权限不足或请求被拒绝","FORBIDDEN",!1,"请确认您有管理员权限"),400:t=>new Wc(`请求数据无效: ${t}`,"INVALID_DATA",!0,"请检查数据格式后重试"),500:()=>new Wc("服务器内部错误","SERVER_ERROR",!0,"请稍后重试,如果问题持续请联系管理员"),NETWORK:()=>new Wc("网络连接失败","NETWORK_ERROR",!0,"请检查网络连接后重试"),ABORT:()=>new Wc("操作已取消","ABORTED",!1,"")};function zc(t,e=""){if("AbortError"===t.name)return Bc.ABORT();if(t instanceof Response||t&&"number"===typeof t.status){const i=Bc[t.status];return i?i(e):new Wc(`请求失败: ${t.status}`,"HTTP_ERROR",!0,"请稍后重试")}return t instanceof TypeError&&t.message.includes("fetch")?Bc.NETWORK():new Wc(t.message||"未知错误","UNKNOWN_ERROR",!0,"请稍后重试")}class Nc{constructor(t={}){this.batchSize=t.batchSize||1e3,this.onProgress=t.onProgress||(()=>{}),this.onError=t.onError||(()=>{}),this.abortController=null}async fetchAllRecords(t=!1){this.abortController=new AbortController;const e=[];let i=null,s=0,n=0;try{do{if(this.abortController.signal.aborted)break;const a=await this.fetchBatch(i,t);e.push(...a.records),i=a.nextCursor,s+=a.records.length,n++,this.onProgress({phase:"fetching",current:s,batchCount:n,message:`已获取 ${s} 条记录...`})}while(i&&!this.abortController.signal.aborted);if(this.abortController.signal.aborted)throw Bc.ABORT();return e}catch(a){const t=a instanceof Wc?a:zc(a);throw this.onError(t),t}}async fetchBatch(t,e){const i=new URLSearchParams;t&&i.set("cursor",t),e&&i.set("includeValue","true"),i.set("limit",String(this.batchSize));try{const t=await(0,Ut.A)(`/api/manage/batch/list?${i}`,{signal:this.abortController.signal});if(!t.ok){let e="";try{const i=await t.json();e=i.error||""}catch{}throw zc(t,e)}const e=await t.json();if(!e.success)throw new Wc(e.error||"请求失败","API_ERROR",!0,"请稍后重试");return{records:e.records||[],nextCursor:e.nextCursor||null,totalProcessed:e.totalProcessed||0}}catch(s){if(s instanceof Wc)throw s;throw zc(s)}}abort(){this.abortController&&this.abortController.abort()}isAborted(){return!!this.abortController&&this.abortController.signal.aborted}reset(){this.abortController=null}}var Uc=Nc;class $c{constructor(t={}){this.chunkSize=t.chunkSize||null,this.maxRetries=t.maxRetries||3,this.retryDelay=t.retryDelay||1e3,this.onProgress=t.onProgress||(()=>{}),this.onError=t.onError||(()=>{}),this.sessionId=this.generateSessionId(),this.aborted=!1}async fetchConfig(){try{const t=await(0,Ut.A)("/api/manage/batch/index/config");if(!t.ok)throw new Error("获取配置失败");const e=await t.json();if(e.success)return{chunkSize:e.chunkSize||500,databaseType:e.databaseType||"unknown"};throw new Error(e.error||"获取配置失败")}catch(t){return console.warn("Failed to fetch index config, using default:",t),{chunkSize:500,databaseType:"unknown"}}}async rebuild(){this.aborted=!1;try{if(!this.chunkSize){const t=await this.fetchConfig();this.chunkSize=t.chunkSize}this.onProgress({phase:"fetching",message:"正在获取数据...",current:0});const t=new Uc({onProgress:t=>this.onProgress({...t,phase:"fetching"}),onError:t=>this.onError(t)}),e=await t.fetchAllRecords(!1);if(this.aborted)throw new Wc("操作已取消","ABORTED",!1,"");if(this.onProgress({phase:"sorting",message:"正在排序...",current:0,total:e.length}),this.sortByTimestampDescending(e),this.aborted)throw new Wc("操作已取消","ABORTED",!1,"");const i=this.splitIntoChunks(e);for(let s=0;s{const i=t.metadata&&t.metadata.TimeStamp||0,s=e.metadata&&e.metadata.TimeStamp||0;return s-i})}splitIntoChunks(t){const e=[];for(let i=0;it.toString(16).padStart(2,"0")).join("")}createHttpError(t,e=""){switch(t){case 401:return new Wc("认证失败,请重新登录","AUTH_FAILED",!1,"请刷新页面并重新登录");case 403:return new Wc("权限不足或请求被拒绝","FORBIDDEN",!1,"请确认您有管理员权限");case 400:return new Wc(`请求数据无效: ${e}`,"INVALID_DATA",!0,"请检查数据格式后重试");case 404:return new Wc("会话不存在","SESSION_NOT_FOUND",!1,"请重新开始索引重建");case 410:return new Wc("会话已过期","SESSION_EXPIRED",!1,"请重新开始索引重建");case 500:default:return new Wc(`服务器错误: ${e||t}`,"SERVER_ERROR",!0,"请稍后重试")}}sleep(t){return new Promise(e=>setTimeout(e,t))}abort(){this.aborted=!0}reset(){this.aborted=!1,this.sessionId=this.generateSessionId()}}var jc=$c;class Hc{constructor(t={}){this.onProgress=t.onProgress||(()=>{}),this.processor=null}async generateBackup(){this.processor=new Uc({onProgress:t=>this.onProgress({...t,phase:"fetching"})});const t=await this.processor.fetchAllRecords(!0);this.onProgress({phase:"building",message:"正在构建备份数据..."});const e={timestamp:Date.now(),version:$t.rE,data:{fileCount:t.length,files:{},settings:{}}};for(const n of t)e.data.files[n.id]={metadata:n.metadata,value:n.value||null};const i=await this.fetchSettings();e.data.settings=i,this.onProgress({phase:"downloading",message:"正在生成下载..."}),this.downloadBackup(e);const s=Object.keys(i).length;return{success:!0,fileCount:t.length,settingsCount:s}}async fetchSettings(){try{const t=await(0,Ut.A)("/api/manage/batch/settings");if(!t.ok)return console.warn("Failed to fetch settings:",t.status),{};const e=await t.json();return e.settings||{}}catch(t){return console.warn("Failed to fetch settings:",t),{}}}downloadBackup(t){const e=JSON.stringify(t,null,2),i=new Blob([e],{type:"application/json"}),s=URL.createObjectURL(i),n=document.createElement("a");n.href=s,n.download=`imgbed_backup_${(new Date).toISOString().split("T")[0]}.json`,document.body.appendChild(n),n.click(),document.body.removeChild(n),URL.revokeObjectURL(s)}abort(){this.processor&&this.processor.abort()}isAborted(){return!!this.processor&&this.processor.isAborted()}}var Xc=Hc;class qc{constructor(t={}){this.chunkSize=t.chunkSize||50,this.maxRetries=t.maxRetries||3,this.retryDelay=t.retryDelay||1e3,this.onProgress=t.onProgress||(()=>{}),this.onError=t.onError||(()=>{}),this.aborted=!1}async restore(t){if(this.aborted=!1,!t||!t.data)throw new Wc("备份文件格式无效","INVALID_BACKUP",!1,"请选择有效的备份文件");const{files:e={},settings:i={}}=t.data,s=Object.entries(e),n=Object.entries(i),a=s.length,o=n.length,r=a+o;let l=0,h=0,c=0,d=0;try{this.onProgress({phase:"restoring_files",message:"正在恢复文件数据...",current:0,total:r});const e=this.splitIntoChunks(s,this.chunkSize);for(let t=0;tsetTimeout(e,t))}abort(){this.aborted=!0}}var Kc=qc;vl.register(Dl,Dh,dh);var Yc={name:"SysCogStatus",components:{Doughnut:Rc},data(){return{loading:!1,rebuilding:!1,backing:!1,restoring:!1,indexInfo:{},version:$t.rE,loadErrors:{newest:!1,oldest:!1},channelColors:["#8B5CF6","#EC4899","#06B6D4","#10B981","#F59E0B","#EF4444","#6366F1","#84CC16"],typeColors:["#10B981","#3B82F6","#F59E0B","#EF4444","#8B5CF6","#EC4899","#06B6D4","#84CC16"],isProcessing:!1,processingPhase:"",processingProgress:{current:0,total:0,message:"",percentage:0},processingError:null,processingStartTime:null,currentRebuilder:null,currentBackupGenerator:null,currentRestoreProcessor:null}},computed:{channelChartData(){const t=this.indexInfo.channelStats||{};return{labels:Object.keys(t),datasets:[{data:Object.values(t),backgroundColor:this.channelColors.slice(0,Object.keys(t).length),borderWidth:0}]}},typeChartData(){const t=this.aggregatedTypeStats;return{labels:Object.keys(t),datasets:[{data:Object.values(t),backgroundColor:this.typeColors.slice(0,Object.keys(t).length),borderWidth:0}]}},aggregatedTypeStats(){const t=this.indexInfo.typeStats||{},e={};for(const[i,s]of Object.entries(t)){const t="Block"===i?"已屏蔽":"正常";e[t]=(e[t]||0)+s}return e},chartOptions(){return{responsive:!0,maintainAspectRatio:!0,cutout:"65%",hoverOffset:8,layout:{padding:10},plugins:{legend:{display:!1},tooltip:{backgroundColor:"rgba(0, 0, 0, 0.8)",titleColor:"#fff",bodyColor:"#fff",padding:12,cornerRadius:8,displayColors:!0,z:100,callbacks:{label:t=>{const e=t.raw,i=t.dataset.data.reduce((t,e)=>t+e,0),s=(e/i*100).toFixed(1);return` ${e.toLocaleString()} (${s}%)`}}}},animation:{animateRotate:!0,animateScale:!0}}},estimatedTimeRemaining(){if(!this.isProcessing||!this.processingStartTime)return"";if(0===this.processingProgress.current||0===this.processingProgress.percentage)return"";const t=Date.now()-this.processingStartTime,e=this.processingProgress.percentage/100;if(e<=0)return"";const i=t/e,s=i-t;if(s<=0)return"即将完成";const n=Math.ceil(s/1e3);if(n<60)return`约 ${n} 秒`;const a=Math.ceil(n/60);if(a<60)return`约 ${a} 分钟`;const o=Math.floor(a/60),r=a%60;return`约 ${o} 小时 ${r} 分钟`},phaseDescription(){const t={fetching:"正在获取数据",sorting:"正在排序",uploading:"正在上传",finalizing:"正在完成",building:"正在构建备份",downloading:"正在生成下载",restoring_files:"正在恢复文件",restoring_settings:"正在恢复设置",completed:"已完成",retrying:"正在重试"};return t[this.processingPhase]||this.processingPhase}},mounted(){this.fetchIndexInfo()},methods:{getChartColor(t){return this.channelColors[t%this.channelColors.length]},getTypeChartColor(t){return this.typeColors[t%this.typeColors.length]},async fetchIndexInfo(){this.loading=!0;try{const t=await(0,Ut.A)("/api/manage/list?action=info",{method:"GET"});if(!t.ok)throw new Error("API请求失败");{const e=await t.json();this.indexInfo=e}}catch(t){console.error("获取索引信息失败:",t),this.$message.error("获取索引信息失败")}finally{this.loading=!1}},async rebuildIndex(){if(this.isProcessing)this.$message.warning("已有操作正在进行中");else{this.rebuilding=!0,this.isProcessing=!0,this.processingError=null,this.processingStartTime=Date.now(),this.processingProgress={current:0,total:0,message:"",percentage:0},this.currentRebuilder=new jc({onProgress:t=>this.handleProgress(t),onError:t=>this.handleError(t)});try{const t=await this.currentRebuilder.rebuild();this.$message.success(`索引重建完成!共处理 ${t.totalFiles.toLocaleString()} 个文件`),setTimeout(()=>{this.fetchIndexInfo()},1e3)}catch(t){if("ABORTED"!==t.code){const e=t.suggestion?`${t.message}。${t.suggestion}`:t.message;this.$message.error(e),this.processingError={message:t.message,suggestion:t.suggestion,recoverable:t.recoverable}}}finally{this.rebuilding=!1,this.isProcessing=!1,this.currentRebuilder=null,this.processingStartTime=null}}},async backupData(){if(this.isProcessing)this.$message.warning("已有操作正在进行中");else{this.backing=!0,this.isProcessing=!0,this.processingError=null,this.processingStartTime=Date.now(),this.processingProgress={current:0,total:0,message:"",percentage:0},this.currentBackupGenerator=new Xc({onProgress:t=>this.handleProgress(t)});try{const t=await this.currentBackupGenerator.generateBackup(),e=t.settingsCount>0?`,${t.settingsCount} 个设置项`:"";this.$message.success(`备份完成!共备份 ${t.fileCount.toLocaleString()} 个文件${e}`)}catch(t){if("ABORTED"!==t.code){const e=t.suggestion?`${t.message}。${t.suggestion}`:t.message;this.$message.error(e),this.processingError={message:t.message,suggestion:t.suggestion,recoverable:t.recoverable}}}finally{this.backing=!1,this.isProcessing=!1,this.currentBackupGenerator=null,this.processingStartTime=null}}},selectRestoreFile(){this.restoring||this.$refs.fileInput.click()},async handleFileSelect(t){const e=t.target.files[0];if(e)if(e.name.endsWith(".json")){try{await this.$confirm("恢复操作将覆盖现有的文件元数据和系统设置,此操作不可逆。确定要继续吗?","确认恢复",{confirmButtonText:"确定恢复",cancelButtonText:"取消",type:"warning"}),await this.restoreData(e)}catch(i){"cancel"!==i&&console.error("确认恢复失败:",i)}t.target.value=""}else this.$message.error("请选择JSON格式的备份文件")},async restoreData(t){if(this.isProcessing)this.$message.warning("已有操作正在进行中");else{this.restoring=!0,this.isProcessing=!0,this.processingError=null,this.processingStartTime=Date.now(),this.processingProgress={current:0,total:0,message:"",percentage:0};try{const i=await t.text();let s;try{s=JSON.parse(i)}catch(e){throw new Error("备份文件格式无效,请选择有效的 JSON 文件")}this.currentRestoreProcessor=new Kc({chunkSize:100,onProgress:t=>this.handleProgress(t),onError:t=>this.handleError(t)});const n=await this.currentRestoreProcessor.restore(s);this.restoring=!1,this.isProcessing=!1,this.currentRestoreProcessor=null,this.processingStartTime=null,this.$message.success(`恢复完成!已恢复 ${n.restoredFiles} 个文件和 ${n.restoredSettings} 个设置项,正在重建索引...`),await new Promise(t=>setTimeout(t,500)),await this.rebuildIndex()}catch(i){if(console.error("恢复数据失败:",i),this.restoring=!1,this.isProcessing=!1,this.currentRestoreProcessor=null,this.processingStartTime=null,"ABORTED"!==i.code){const t=i.suggestion?`${i.message}。${i.suggestion}`:i.message;this.$message.error("恢复数据失败: "+t),this.processingError={message:i.message,suggestion:i.suggestion,recoverable:i.recoverable}}}}},formatTime(t){if(!t)return"未知";const e=new Date(t);return e.toLocaleString("zh-CN",{year:"numeric",month:"2-digit",day:"2-digit",hour:"2-digit",minute:"2-digit"})},getPercentage(t,e){return e&&0!==e?Math.round(t/e*100):0},getTimeAgo(t){if(!t)return"";const e=Date.now(),i=e-t,s=Math.floor(i/6e4),n=Math.floor(i/36e5),a=Math.floor(i/864e5);return a>0?`${a}天前`:n>0?`${n}小时前`:s>0?`${s}分钟前`:"刚刚"},handleImageError(t){this.loadErrors[t]=!0},isValidPreview(t,e){return!this.loadErrors[t]&&(!!e?.metadata?.FileType&&(e.metadata.FileType.includes("image")||e.metadata.FileType.includes("video")))},openReleases(){window.open("https://github.com/MarSeventh/CloudFlare-ImgBed/releases","_blank")},isImageFile(t){if(!t)return!1;if(t.metadata?.FileType?.includes("image"))return!0;const e=t.metadata?.FileName||t.id||"",i=e.substring(e.lastIndexOf(".")+1).toLowerCase(),s=["jpg","jpeg","png","gif","bmp","webp","svg","ico","tiff","tif","avif","heic","heif"];return s.includes(i)},isVideoFile(t){if(!t)return!1;if(t.metadata?.FileType?.includes("video"))return!0;const e=t.metadata?.FileName||t.id||"",i=e.substring(e.lastIndexOf(".")+1).toLowerCase(),s=["mp4","webm","ogg","avi","mov","flv","wmv","mkv","m4v","3gp","mpeg","mpg"];return s.includes(i)},openFileInNewTab(t){t?.id&&window.open("/file/"+t.id,"_blank")},handleProgress(t){this.processingPhase=t.phase,this.processingProgress.message=t.message||"",this.processingProgress.current=t.current||0,"fetching"===t.phase?(this.processingProgress.total=t.total||0,t.total&&t.total>0?this.processingProgress.percentage=Math.min(60,t.current/t.total*60):this.processingProgress.percentage=Math.min(50,15*Math.log10(t.current+1))):"sorting"===t.phase?(this.processingProgress.percentage=65,this.processingProgress.total=t.total||this.processingProgress.total):"uploading"===t.phase?(this.processingProgress.total=t.total||0,t.total&&t.total>0&&(this.processingProgress.percentage=70+t.current/t.total*25)):"finalizing"===t.phase?this.processingProgress.percentage=97:"building"===t.phase?this.processingProgress.percentage=80:"downloading"===t.phase?this.processingProgress.percentage=95:"restoring_files"===t.phase?(this.processingProgress.total=t.total||0,this.processingProgress.percentage=t.percentage||0):"restoring_settings"===t.phase?(this.processingProgress.total=t.total||0,this.processingProgress.percentage=t.percentage||80):"completed"===t.phase?this.processingProgress.percentage=100:"retrying"===t.phase&&(this.processingProgress.message=t.message)},handleError(t){console.error("批量操作错误:",t),this.processingError={message:t.message,suggestion:t.suggestion,recoverable:t.recoverable}},cancelOperation(){this.currentRebuilder&&(this.currentRebuilder.abort(),this.$message.info("正在取消索引重建...")),this.currentBackupGenerator&&(this.currentBackupGenerator.abort(),this.$message.info("正在取消备份...")),this.currentRestoreProcessor&&(this.currentRestoreProcessor.abort(),this.$message.info("正在取消恢复..."))},retryOperation(){this.processingError=null,this.rebuilding?(this.rebuilding=!1,this.isProcessing=!1,this.$nextTick(()=>{this.rebuildIndex()})):this.backing&&(this.backing=!1,this.isProcessing=!1,this.$nextTick(()=>{this.backupData()}))},dismissError(){this.processingError=null}}};const Qc=(0,c.A)(Yc,[["render",Nt],["__scopeId","data-v-68ed43d0"]]);var Gc=Qc,Jc=i(9869),Zc=(i(415),i(3565),i(9267)),td=(i(5616),i(2006)),ed=i(1418),id=(i(333),i(9623)),sd=(i(6711),i(6018)),nd=(i(6808),i(200),i(5558)),ad=(i(8075),i(2687)),od=(i(8785),i(5130));const rd=["onClick"];function ld(t,e,i,a,o,r){const l=(0,s.g2)("font-awesome-icon");return(0,s.uX)(),(0,s.CE)("div",{class:(0,n.C4)(["custom-select",{"is-open":o.isOpen}]),style:(0,n.Tr)({width:i.width})},[(0,s.Lk)("div",{class:"custom-select-trigger",onClick:e[0]||(e[0]=(...t)=>r.toggleDropdown&&r.toggleDropdown(...t))},[(0,s.Lk)("span",{class:(0,n.C4)(["custom-select-value",{"is-placeholder":!i.modelValue}])},(0,n.v_)(r.displayLabel),3),(0,s.bF)(l,{icon:"chevron-down",class:"custom-select-arrow"})]),(0,s.bF)(od.eB,{name:"dropdown-fade"},{default:(0,s.k6)(()=>[(0,s.bo)((0,s.Lk)("div",{class:"custom-select-dropdown",onClick:e[1]||(e[1]=(0,od.D$)(()=>{},["stop"]))},[((0,s.uX)(!0),(0,s.CE)(s.FK,null,(0,s.pI)(i.options,e=>((0,s.uX)(),(0,s.CE)("div",{key:e.value,class:(0,n.C4)(["custom-select-option",{"is-selected":i.modelValue===e.value}]),onClick:t=>r.selectOption(e.value)},[(0,s.RG)(t.$slots,"option",{option:e},()=>[e.icon?((0,s.uX)(),(0,s.Wv)(l,{key:0,icon:e.icon,class:"option-icon"},null,8,["icon"])):(0,s.Q3)("",!0),(0,s.Lk)("span",null,(0,n.v_)(e.label),1)],!0)],10,rd))),128))],512),[[od.aG,o.isOpen]])]),_:3})],6)}var hd={name:"CustomSelect",props:{modelValue:{type:[String,Number],default:""},options:{type:Array,required:!0},placeholder:{type:String,default:"请选择"},width:{type:String,default:"160px"}},emits:["update:modelValue","change"],data(){return{isOpen:!1}},computed:{displayLabel(){const t=this.options.find(t=>t.value===this.modelValue);return t?t.label:this.placeholder}},mounted(){document.addEventListener("click",this.handleClickOutside)},beforeUnmount(){document.removeEventListener("click",this.handleClickOutside)},methods:{toggleDropdown(){this.isOpen=!this.isOpen},selectOption(t){this.$emit("update:modelValue",t),this.$emit("change",t),this.isOpen=!1},handleClickOutside(t){this.$el.contains(t.target)||(this.isOpen=!1)}}};const cd=(0,c.A)(hd,[["render",ld],["__scopeId","data-v-6c59d112"]]);var dd=cd;const ud={class:"upload-settings"},gd={class:"page-header"},pd={class:"first-title"},fd={class:"header-actions"},md={class:"group-header"},bd={class:"group-title"},xd={key:0,class:"load-balance-switch"},yd={key:0,class:"channel-cards"},_d=["onMousemove","onMouseleave"],vd={class:"card-header"},kd={class:"card-title"},wd={class:"channel-name"},Cd={class:"card-body"},Sd={class:"card-info"},Fd={class:"info-item"},Md={class:"info-text"},Ad={key:0,class:"info-item"},Td={class:"info-text"},Pd={key:1,class:"info-item"},Dd=["title"],Ed={class:"info-item"},Ld={class:"info-text"},Id={key:0,class:"info-item"},Vd=["title"],Od={class:"info-item"},Rd={class:"info-text"},Wd={class:"info-item"},Bd={class:"info-text"},zd={class:"info-item"},Nd={class:"info-text"},Ud={key:0,class:"quota-mini"},$d={class:"quota-text"},jd={class:"card-actions"},Hd={key:1,class:"empty-tip"},Xd={class:"form-warning"},qd={class:"quota-label"},Kd={class:"quota-status"};function Yd(t,e,i,a,o,r){const l=(0,s.g2)("font-awesome-icon"),h=p.R7,c=dd,d=k.S2,u=ad.u,g=nd.qi,f=w.ve,m=sd.P9,b=sd.AV,x=td.xE,y=id.WK,v=ed.lq,C=td.US,S=Zc.kZ,F=Jc.MF,M=Jc.TS,A=_.A;return(0,s.bo)(((0,s.uX)(),(0,s.CE)("div",ud,[(0,s.Lk)("div",gd,[(0,s.Lk)("h3",pd,[e[59]||(e[59]=(0,s.eW)(" 上传渠道管理 ",-1)),(0,s.bF)(h,{content:"管理所有上传渠道的配置,点击卡片查看详情或编辑",placement:"right"},{default:(0,s.k6)(()=>[(0,s.bF)(l,{icon:"question-circle",class:"help-icon"})]),_:1})]),(0,s.Lk)("div",fd,[(0,s.bF)(c,{modelValue:o.channelFilter,"onUpdate:modelValue":e[0]||(e[0]=t=>o.channelFilter=t),options:r.filterOptions,placeholder:"筛选渠道类型",width:"160px"},null,8,["modelValue","options"]),(0,s.bF)(d,{type:"primary",onClick:e[1]||(e[1]=t=>o.showAddDialog=!0),class:"add-btn"},{default:(0,s.k6)(()=>[(0,s.bF)(l,{icon:"plus",style:{"margin-right":"6px"}}),e[60]||(e[60]=(0,s.eW)(" 添加渠道 ",-1))]),_:1})])]),((0,s.uX)(!0),(0,s.CE)(s.FK,null,(0,s.pI)(r.filteredChannels,t=>((0,s.uX)(),(0,s.CE)("div",{key:t.value,class:"channel-group"},[(0,s.Lk)("div",md,[(0,s.Lk)("div",bd,[(0,s.bF)(l,{icon:r.getChannelIcon(t.value),class:"group-icon"},null,8,["icon"]),(0,s.Lk)("span",null,(0,n.v_)(t.label),1),(0,s.bF)(u,{size:"small",type:"info",class:"channel-count"},{default:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(r.getChannelList(t.value).length),1)]),_:2},1024)]),r.hasLoadBalance(t.value)?((0,s.uX)(),(0,s.CE)("div",xd,[e[61]||(e[61]=(0,s.Lk)("span",{class:"switch-label"},"负载均衡",-1)),(0,s.bF)(g,{modelValue:r.getSettings(t.value).loadBalance.enabled,"onUpdate:modelValue":e=>r.getSettings(t.value).loadBalance.enabled=e,size:"small",onChange:r.saveSettings},null,8,["modelValue","onUpdate:modelValue","onChange"])])):(0,s.Q3)("",!0)]),r.getChannelList(t.value).length>0?((0,s.uX)(),(0,s.CE)("div",yd,[((0,s.uX)(!0),(0,s.CE)(s.FK,null,(0,s.pI)(r.getChannelList(t.value),(i,a)=>((0,s.uX)(),(0,s.CE)("div",{key:i.name||a,class:(0,n.C4)(["channel-card",[t.value,{disabled:!i.enabled,fixed:i.fixed}]]),onMousemove:e=>r.handleCardMouseMove(e,t.value,a),onMouseleave:e=>r.handleCardMouseLeave(t.value,a)},[(0,s.Lk)("div",{class:"card-glow",ref_for:!0,ref:`glow-${t.value}-${a}`},null,512),(0,s.Lk)("div",vd,[(0,s.Lk)("div",kd,[(0,s.Lk)("span",wd,(0,n.v_)(i.name||"未命名渠道"),1),i.fixed?((0,s.uX)(),(0,s.Wv)(u,{key:0,size:"small",type:"warning"},{default:(0,s.k6)(()=>[...e[62]||(e[62]=[(0,s.eW)("环境变量",-1)])]),_:1})):(0,s.Q3)("",!0)]),(0,s.bF)(g,{modelValue:i.enabled,"onUpdate:modelValue":t=>i.enabled=t,size:"small",onClick:e[2]||(e[2]=(0,od.D$)(()=>{},["stop"])),onChange:r.saveSettings},null,8,["modelValue","onUpdate:modelValue","onChange"])]),(0,s.Lk)("div",Cd,[(0,s.Lk)("div",Sd,["telegram"===t.value?((0,s.uX)(),(0,s.CE)(s.FK,{key:0},[(0,s.Lk)("div",Fd,[(0,s.bF)(l,{icon:"robot",class:"info-icon"}),(0,s.Lk)("span",Md,"Bot: "+(0,n.v_)(r.maskText(i.botToken)),1)]),i.chatId?((0,s.uX)(),(0,s.CE)("div",Ad,[(0,s.bF)(l,{icon:"comments",class:"info-icon"}),(0,s.Lk)("span",Td,"Channel: "+(0,n.v_)(r.maskText(i.chatId)),1)])):(0,s.Q3)("",!0)],64)):"cfr2"===t.value?((0,s.uX)(),(0,s.CE)("div",Pd,[(0,s.bF)(l,{icon:"link",class:"info-icon"}),(0,s.Lk)("span",{class:"info-text",title:i.publicUrl},(0,n.v_)(i.publicUrl||"未设置公开链接"),9,Dd)])):"s3"===t.value?((0,s.uX)(),(0,s.CE)(s.FK,{key:2},[(0,s.Lk)("div",Ed,[(0,s.bF)(l,{icon:"server",class:"info-icon"}),(0,s.Lk)("span",Ld,(0,n.v_)(i.bucketName||"未设置"),1)]),i.endpoint?((0,s.uX)(),(0,s.CE)("div",Id,[(0,s.bF)(l,{icon:"link",class:"info-icon"}),(0,s.Lk)("span",{class:"info-text",title:i.endpoint},(0,n.v_)(i.endpoint),9,Vd)])):(0,s.Q3)("",!0)],64)):"discord"===t.value?((0,s.uX)(),(0,s.CE)(s.FK,{key:3},[(0,s.Lk)("div",Od,[(0,s.bF)(l,{icon:"robot",class:"info-icon"}),(0,s.Lk)("span",Rd,"Bot: "+(0,n.v_)(r.maskText(i.botToken)),1)]),(0,s.Lk)("div",Wd,[(0,s.bF)(l,{icon:"hashtag",class:"info-icon"}),(0,s.Lk)("span",Bd,"Channel: "+(0,n.v_)(r.maskText(i.channelId)),1)]),i.isNitro?((0,s.uX)(),(0,s.Wv)(u,{key:0,size:"small",type:"success"},{default:(0,s.k6)(()=>[...e[63]||(e[63]=[(0,s.eW)("Nitro",-1)])]),_:1})):(0,s.Q3)("",!0)],64)):"huggingface"===t.value?((0,s.uX)(),(0,s.CE)(s.FK,{key:4},[(0,s.Lk)("div",zd,[(0,s.bF)(l,{icon:"database",class:"info-icon"}),(0,s.Lk)("span",Nd,(0,n.v_)(i.repo||"未设置仓库"),1)]),i.isPrivate?((0,s.uX)(),(0,s.Wv)(u,{key:0,size:"small",type:"warning"},{default:(0,s.k6)(()=>[...e[64]||(e[64]=[(0,s.eW)("私有",-1)])]),_:1})):(0,s.Q3)("",!0)],64)):(0,s.Q3)("",!0)]),i.quota?.enabled?((0,s.uX)(),(0,s.CE)("div",Ud,[(0,s.bF)(f,{percentage:r.getQuotaPercentage(i),status:r.getQuotaStatus(i),"stroke-width":6},null,8,["percentage","status"]),(0,s.Lk)("span",$d,(0,n.v_)(r.getQuotaText(i)),1)])):(0,s.Q3)("",!0)]),(0,s.Lk)("div",jd,[(0,s.bF)(d,{text:"",type:"primary",size:"small",onClick:e=>r.openDetailDialog(t.value,a)},{default:(0,s.k6)(()=>[(0,s.bF)(l,{icon:"eye",style:{"margin-right":"4px"}}),e[65]||(e[65]=(0,s.eW)("详情 ",-1))]),_:1},8,["onClick"]),(0,s.bF)(d,{text:"",type:"primary",size:"small",onClick:e=>r.openEditDialog(t.value,a)},{default:(0,s.k6)(()=>[(0,s.bF)(l,{icon:"edit",style:{"margin-right":"4px"}}),e[66]||(e[66]=(0,s.eW)("编辑 ",-1))]),_:1},8,["onClick"]),(0,s.bF)(d,{text:"",type:"danger",size:"small",onClick:e=>r.deleteChannel(t.value,a),disabled:i.fixed},{default:(0,s.k6)(()=>[(0,s.bF)(l,{icon:"trash-alt",style:{"margin-right":"4px"}}),e[67]||(e[67]=(0,s.eW)("删除 ",-1))]),_:1},8,["onClick","disabled"])])],42,_d))),128))])):((0,s.uX)(),(0,s.CE)("div",Hd,[(0,s.bF)(l,{icon:"inbox",class:"empty-icon"}),(0,s.Lk)("span",null,"暂无 "+(0,n.v_)(t.label)+" 渠道",1)]))]))),128)),(0,s.bF)(S,{modelValue:o.showAddDialog,"onUpdate:modelValue":e[26]||(e[26]=t=>o.showAddDialog=t),title:"添加新渠道",class:"channel-dialog","destroy-on-close":"",onClosed:r.resetAddForm},{footer:(0,s.k6)(()=>[(0,s.bF)(d,{onClick:e[25]||(e[25]=t=>o.showAddDialog=!1)},{default:(0,s.k6)(()=>[...e[73]||(e[73]=[(0,s.eW)("取消",-1)])]),_:1}),(0,s.bF)(d,{type:"primary",onClick:r.confirmAddChannel},{default:(0,s.k6)(()=>[...e[74]||(e[74]=[(0,s.eW)("确认添加",-1)])]),_:1},8,["onClick"])]),default:(0,s.k6)(()=>[(0,s.bF)(C,{model:o.newChannel,"label-position":"top",ref:"addForm",rules:o.addRules},{default:(0,s.k6)(()=>[(0,s.bF)(x,{label:"渠道类型",prop:"type"},{default:(0,s.k6)(()=>[(0,s.bF)(b,{modelValue:o.newChannel.type,"onUpdate:modelValue":e[3]||(e[3]=t=>o.newChannel.type=t),placeholder:"请选择渠道类型",style:{width:"100%"},onChange:r.onChannelTypeChange},{default:(0,s.k6)(()=>[((0,s.uX)(!0),(0,s.CE)(s.FK,null,(0,s.pI)(o.addableChannels,t=>((0,s.uX)(),(0,s.Wv)(m,{key:t.value,label:t.label,value:t.value},{default:(0,s.k6)(()=>[(0,s.bF)(l,{icon:r.getChannelIcon(t.value),class:"select-option-icon"},null,8,["icon"]),(0,s.eW)(" "+(0,n.v_)(t.label),1)]),_:2},1032,["label","value"]))),128))]),_:1},8,["modelValue","onChange"])]),_:1}),(0,s.bF)(x,{label:"渠道名称",prop:"name"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.newChannel.name,"onUpdate:modelValue":e[4]||(e[4]=t=>o.newChannel.name=t),placeholder:"请输入渠道名称"},null,8,["modelValue"])]),_:1}),"telegram"===o.newChannel.type?((0,s.uX)(),(0,s.CE)(s.FK,{key:0},[(0,s.bF)(x,{label:"Bot Token",prop:"botToken"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.newChannel.botToken,"onUpdate:modelValue":e[5]||(e[5]=t=>o.newChannel.botToken=t),type:"password","show-password":"",placeholder:"请输入 Bot Token"},null,8,["modelValue"])]),_:1}),(0,s.bF)(x,{label:"Chat ID",prop:"chatId"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.newChannel.chatId,"onUpdate:modelValue":e[6]||(e[6]=t=>o.newChannel.chatId=t),type:"password","show-password":"",placeholder:"请输入 Chat ID"},null,8,["modelValue"])]),_:1}),(0,s.bF)(x,{label:"代理域名"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.newChannel.proxyUrl,"onUpdate:modelValue":e[7]||(e[7]=t=>o.newChannel.proxyUrl=t),placeholder:"可选,例如: your-proxy.example.com"},null,8,["modelValue"])]),_:1})],64)):"s3"===o.newChannel.type?((0,s.uX)(),(0,s.CE)(s.FK,{key:1},[(0,s.bF)(x,{label:"Endpoint",prop:"endpoint"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.newChannel.endpoint,"onUpdate:modelValue":e[8]||(e[8]=t=>o.newChannel.endpoint=t),placeholder:"例如: https://s3.us-east-005.backblazeb2.com"},null,8,["modelValue"])]),_:1}),(0,s.bF)(x,{label:"CDN 域名"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.newChannel.cdnDomain,"onUpdate:modelValue":e[9]||(e[9]=t=>o.newChannel.cdnDomain=t),placeholder:"如果有 CDN,请配置 CDN 域名,例如:https://cdn.example.com"},null,8,["modelValue"]),e[68]||(e[68]=(0,s.Lk)("span",{class:"form-tip"},"可选配置。配置后将优先通过 CDN 读取文件,提高访问速度和降低成本",-1))]),_:1}),(0,s.bF)(x,{label:"存储桶名称",prop:"bucketName"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.newChannel.bucketName,"onUpdate:modelValue":e[10]||(e[10]=t=>o.newChannel.bucketName=t),placeholder:"请输入存储桶名称"},null,8,["modelValue"])]),_:1}),(0,s.bF)(x,{label:"存储桶区域",prop:"region"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.newChannel.region,"onUpdate:modelValue":e[11]||(e[11]=t=>o.newChannel.region=t),placeholder:"默认填写 auto"},null,8,["modelValue"])]),_:1}),(0,s.bF)(x,{label:"访问密钥 ID",prop:"accessKeyId"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.newChannel.accessKeyId,"onUpdate:modelValue":e[12]||(e[12]=t=>o.newChannel.accessKeyId=t),type:"password","show-password":"",placeholder:"请输入访问密钥 ID"},null,8,["modelValue"])]),_:1}),(0,s.bF)(x,{label:"机密访问密钥",prop:"secretAccessKey"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.newChannel.secretAccessKey,"onUpdate:modelValue":e[13]||(e[13]=t=>o.newChannel.secretAccessKey=t),type:"password","show-password":"",placeholder:"请输入机密访问密钥"},null,8,["modelValue"])]),_:1}),(0,s.bF)(x,{label:"路径风格"},{default:(0,s.k6)(()=>[(0,s.bF)(g,{modelValue:o.newChannel.pathStyle,"onUpdate:modelValue":e[14]||(e[14]=t=>o.newChannel.pathStyle=t)},null,8,["modelValue"]),e[69]||(e[69]=(0,s.Lk)("span",{class:"form-tip"},"使用 OpenList 时需开启",-1))]),_:1}),(0,s.bF)(x,{label:"容量限制"},{default:(0,s.k6)(()=>[(0,s.bF)(g,{modelValue:o.newChannel.quota.enabled,"onUpdate:modelValue":e[15]||(e[15]=t=>o.newChannel.quota.enabled=t)},null,8,["modelValue"])]),_:1}),o.newChannel.quota?.enabled?((0,s.uX)(),(0,s.CE)(s.FK,{key:0},[(0,s.bF)(x,{label:"容量上限 (GB)"},{default:(0,s.k6)(()=>[(0,s.bF)(v,{modelValue:o.newChannel.quota.limitGB,"onUpdate:modelValue":e[16]||(e[16]=t=>o.newChannel.quota.limitGB=t),min:.1,step:1,precision:1},null,8,["modelValue"])]),_:1}),(0,s.bF)(x,{label:"停用阈值 (%)"},{default:(0,s.k6)(()=>[(0,s.bF)(v,{modelValue:o.newChannel.quota.threshold,"onUpdate:modelValue":e[17]||(e[17]=t=>o.newChannel.quota.threshold=t),min:50,max:100,step:5},null,8,["modelValue"])]),_:1})],64)):(0,s.Q3)("",!0)],64)):"discord"===o.newChannel.type?((0,s.uX)(),(0,s.CE)(s.FK,{key:2},[(0,s.bF)(x,{label:"Bot Token",prop:"botToken"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.newChannel.botToken,"onUpdate:modelValue":e[18]||(e[18]=t=>o.newChannel.botToken=t),type:"password","show-password":"",placeholder:"请输入 Bot Token"},null,8,["modelValue"])]),_:1}),(0,s.bF)(x,{label:"Channel ID",prop:"channelId"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.newChannel.channelId,"onUpdate:modelValue":e[19]||(e[19]=t=>o.newChannel.channelId=t),type:"password","show-password":"",placeholder:"请输入 Channel ID"},null,8,["modelValue"])]),_:1}),(0,s.bF)(x,{label:"代理域名"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.newChannel.proxyUrl,"onUpdate:modelValue":e[20]||(e[20]=t=>o.newChannel.proxyUrl=t),placeholder:"可选,例如: your-proxy.example.com"},null,8,["modelValue"])]),_:1}),(0,s.bF)(x,{label:"Nitro 会员"},{default:(0,s.k6)(()=>[(0,s.bF)(g,{modelValue:o.newChannel.isNitro,"onUpdate:modelValue":e[21]||(e[21]=t=>o.newChannel.isNitro=t)},null,8,["modelValue"]),e[70]||(e[70]=(0,s.Lk)("span",{class:"form-tip"},"会员单文件限制 25MB,否则为 10MB",-1))]),_:1}),(0,s.Lk)("div",Xd,[(0,s.bF)(l,{icon:"exclamation-triangle",style:{"margin-right":"6px"}}),e[71]||(e[71]=(0,s.eW)(" Discord 有接口频率限制,不建议将其用作大规模并发场景 ",-1))])],64)):"huggingface"===o.newChannel.type?((0,s.uX)(),(0,s.CE)(s.FK,{key:3},[(0,s.bF)(x,{label:"仓库名",prop:"repo"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.newChannel.repo,"onUpdate:modelValue":e[22]||(e[22]=t=>o.newChannel.repo=t),placeholder:"格式: username/repo-name"},null,8,["modelValue"])]),_:1}),(0,s.bF)(x,{label:"Access Token",prop:"token"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.newChannel.token,"onUpdate:modelValue":e[23]||(e[23]=t=>o.newChannel.token=t),type:"password","show-password":"",placeholder:"请输入 Access Token"},null,8,["modelValue"])]),_:1}),(0,s.bF)(x,{label:"私有仓库"},{default:(0,s.k6)(()=>[(0,s.bF)(g,{modelValue:o.newChannel.isPrivate,"onUpdate:modelValue":e[24]||(e[24]=t=>o.newChannel.isPrivate=t)},null,8,["modelValue"]),e[72]||(e[72]=(0,s.Lk)("span",{class:"form-tip"},"私有仓库限制 100GB",-1))]),_:1})],64)):(0,s.Q3)("",!0)]),_:1},8,["model","rules"])]),_:1},8,["modelValue","onClosed"]),(0,s.bF)(S,{modelValue:o.showDetailDialog,"onUpdate:modelValue":e[28]||(e[28]=t=>o.showDetailDialog=t),title:"渠道详情 - "+(o.currentChannel?.name||""),class:"channel-dialog",onClosed:r.resetDetailData},{footer:(0,s.k6)(()=>[(0,s.bF)(d,{onClick:e[27]||(e[27]=t=>o.showDetailDialog=!1)},{default:(0,s.k6)(()=>[...e[77]||(e[77]=[(0,s.eW)("关闭",-1)])]),_:1}),(0,s.bF)(d,{type:"primary",onClick:r.openEditFromDetail},{default:(0,s.k6)(()=>[...e[78]||(e[78]=[(0,s.eW)("编辑",-1)])]),_:1},8,["onClick"])]),default:(0,s.k6)(()=>[(0,s.bF)(M,{column:1,border:""},{default:(0,s.k6)(()=>[(0,s.bF)(F,{label:"渠道名称"},{default:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(o.currentChannel?.name),1)]),_:1}),(0,s.bF)(F,{label:"渠道类型"},{default:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(r.getChannelTypeLabel(o.currentChannelType)),1)]),_:1}),(0,s.bF)(F,{label:"状态"},{default:(0,s.k6)(()=>[(0,s.bF)(u,{type:o.currentChannel?.enabled?"success":"info"},{default:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(o.currentChannel?.enabled?"已启用":"已禁用"),1)]),_:1},8,["type"])]),_:1}),o.currentChannel?.fixed?((0,s.uX)(),(0,s.Wv)(F,{key:0,label:"配置来源"},{default:(0,s.k6)(()=>[(0,s.bF)(u,{type:"warning"},{default:(0,s.k6)(()=>[...e[75]||(e[75]=[(0,s.eW)("环境变量",-1)])]),_:1})]),_:1})):(0,s.Q3)("",!0),"telegram"===o.currentChannelType?((0,s.uX)(),(0,s.CE)(s.FK,{key:1},[(0,s.bF)(F,{label:"Bot Token"},{default:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(r.maskText(o.currentChannel?.botToken,10)),1)]),_:1}),(0,s.bF)(F,{label:"Chat ID"},{default:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(r.maskText(o.currentChannel?.chatId,6)),1)]),_:1}),(0,s.bF)(F,{label:"代理域名"},{default:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(o.currentChannel?.proxyUrl||"未设置"),1)]),_:1})],64)):"cfr2"===o.currentChannelType?((0,s.uX)(),(0,s.Wv)(F,{key:2,label:"公开访问链接"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{"model-value":o.currentChannel?.publicUrl||"未设置",readonly:""},null,8,["model-value"])]),_:1})):"s3"===o.currentChannelType?((0,s.uX)(),(0,s.CE)(s.FK,{key:3},[(0,s.bF)(F,{label:"Endpoint"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{"model-value":o.currentChannel?.endpoint,readonly:""},null,8,["model-value"])]),_:1}),(0,s.bF)(F,{label:"CDN 域名"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{"model-value":o.currentChannel?.cdnDomain||"未设置",readonly:""},null,8,["model-value"])]),_:1}),(0,s.bF)(F,{label:"存储桶名称"},{default:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(o.currentChannel?.bucketName),1)]),_:1}),(0,s.bF)(F,{label:"存储桶区域"},{default:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(o.currentChannel?.region),1)]),_:1}),(0,s.bF)(F,{label:"路径风格"},{default:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(o.currentChannel?.pathStyle?"是":"否"),1)]),_:1})],64)):"discord"===o.currentChannelType?((0,s.uX)(),(0,s.CE)(s.FK,{key:4},[(0,s.bF)(F,{label:"Bot Token"},{default:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(r.maskText(o.currentChannel?.botToken,10)),1)]),_:1}),(0,s.bF)(F,{label:"Channel ID"},{default:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(r.maskText(o.currentChannel?.channelId,6)),1)]),_:1}),(0,s.bF)(F,{label:"代理域名"},{default:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(o.currentChannel?.proxyUrl||"未设置"),1)]),_:1}),(0,s.bF)(F,{label:"Nitro 会员"},{default:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(o.currentChannel?.isNitro?"是":"否"),1)]),_:1})],64)):"huggingface"===o.currentChannelType?((0,s.uX)(),(0,s.CE)(s.FK,{key:5},[(0,s.bF)(F,{label:"仓库名"},{default:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(o.currentChannel?.repo),1)]),_:1}),(0,s.bF)(F,{label:"私有仓库"},{default:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(o.currentChannel?.isPrivate?"是":"否"),1)]),_:1})],64)):(0,s.Q3)("",!0),o.currentChannel?.quota?.enabled?((0,s.uX)(),(0,s.CE)(s.FK,{key:6},[(0,s.bF)(F,{label:"容量限制"},{default:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(o.currentChannel?.quota?.limitGB)+" GB",1)]),_:1}),(0,s.bF)(F,{label:"停用阈值"},{default:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(o.currentChannel?.quota?.threshold)+"%",1)]),_:1}),(0,s.bF)(F,null,{label:(0,s.k6)(()=>[(0,s.Lk)("span",qd,[e[76]||(e[76]=(0,s.eW)(" 当前用量 ",-1)),(0,s.bF)(d,{link:"",type:"primary",onClick:r.refreshQuota,class:"refresh-btn"},{default:(0,s.k6)(()=>[(0,s.bF)(l,{icon:"sync-alt",class:(0,n.C4)({"fa-spin":o.quotaLoading})},null,8,["class"])]),_:1},8,["onClick"])])]),default:(0,s.k6)(()=>[(0,s.Lk)("div",Kd,[(0,s.bF)(f,{percentage:r.getQuotaPercentage(o.currentChannel),status:r.getQuotaStatus(o.currentChannel),"stroke-width":16,"text-inside":!0,format:()=>r.getQuotaText(o.currentChannel)},null,8,["percentage","status","format"]),(0,s.Lk)("div",{class:(0,n.C4)(["quota-info",{"quota-warning":r.isQuotaExceeded(o.currentChannel)}])},(0,n.v_)(r.getQuotaStatusText(o.currentChannel)),3)])]),_:1})],64)):(0,s.Q3)("",!0)]),_:1})]),_:1},8,["modelValue","title","onClosed"]),(0,s.bF)(S,{modelValue:o.showEditDialog,"onUpdate:modelValue":e[58]||(e[58]=t=>o.showEditDialog=t),title:"编辑渠道 - "+(o.editChannel?.name||""),class:"channel-dialog","destroy-on-close":"",onClosed:r.resetEditData},{footer:(0,s.k6)(()=>[(0,s.bF)(d,{onClick:e[57]||(e[57]=t=>o.showEditDialog=!1)},{default:(0,s.k6)(()=>[...e[80]||(e[80]=[(0,s.eW)("取消",-1)])]),_:1}),(0,s.bF)(d,{type:"primary",onClick:r.confirmEditChannel},{default:(0,s.k6)(()=>[...e[81]||(e[81]=[(0,s.eW)("保存修改",-1)])]),_:1},8,["onClick"])]),default:(0,s.k6)(()=>[(0,s.bF)(C,{model:o.editChannel,"label-position":"top",ref:"editForm",rules:o.editRules},{default:(0,s.k6)(()=>[(0,s.bF)(x,{label:"渠道名称",prop:"name"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.editChannel.name,"onUpdate:modelValue":e[29]||(e[29]=t=>o.editChannel.name=t),disabled:o.editChannel.fixed},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(x,{label:"启用渠道"},{default:(0,s.k6)(()=>[(0,s.bF)(g,{modelValue:o.editChannel.enabled,"onUpdate:modelValue":e[30]||(e[30]=t=>o.editChannel.enabled=t)},null,8,["modelValue"])]),_:1}),"telegram"===o.currentChannelType?((0,s.uX)(),(0,s.CE)(s.FK,{key:0},[(0,s.bF)(x,{label:"Bot Token",prop:"botToken"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.editChannel.botToken,"onUpdate:modelValue":e[31]||(e[31]=t=>o.editChannel.botToken=t),disabled:o.editChannel.fixed,type:"password","show-password":""},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(x,{label:"Chat ID",prop:"chatId"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.editChannel.chatId,"onUpdate:modelValue":e[32]||(e[32]=t=>o.editChannel.chatId=t),disabled:o.editChannel.fixed,type:"password","show-password":""},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(x,{label:"代理域名"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.editChannel.proxyUrl,"onUpdate:modelValue":e[33]||(e[33]=t=>o.editChannel.proxyUrl=t),placeholder:"例如: your-proxy.example.com"},null,8,["modelValue"])]),_:1})],64)):"cfr2"===o.currentChannelType?((0,s.uX)(),(0,s.CE)(s.FK,{key:1},[(0,s.bF)(x,{label:"公开访问链接"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.editChannel.publicUrl,"onUpdate:modelValue":e[34]||(e[34]=t=>o.editChannel.publicUrl=t)},null,8,["modelValue"])]),_:1}),(0,s.bF)(x,{label:"容量限制"},{default:(0,s.k6)(()=>[(0,s.bF)(g,{modelValue:o.editChannel.quota.enabled,"onUpdate:modelValue":e[35]||(e[35]=t=>o.editChannel.quota.enabled=t),onChange:e[36]||(e[36]=t=>r.onQuotaEnabledChange(t,o.editChannel))},null,8,["modelValue"])]),_:1}),o.editChannel.quota?.enabled?((0,s.uX)(),(0,s.CE)(s.FK,{key:0},[(0,s.bF)(x,{label:"容量上限 (GB)"},{default:(0,s.k6)(()=>[(0,s.bF)(v,{modelValue:o.editChannel.quota.limitGB,"onUpdate:modelValue":e[37]||(e[37]=t=>o.editChannel.quota.limitGB=t),min:.1,step:1,precision:1},null,8,["modelValue"])]),_:1}),(0,s.bF)(x,{label:"停用阈值 (%)"},{default:(0,s.k6)(()=>[(0,s.bF)(v,{modelValue:o.editChannel.quota.threshold,"onUpdate:modelValue":e[38]||(e[38]=t=>o.editChannel.quota.threshold=t),min:50,max:100,step:5},null,8,["modelValue"])]),_:1})],64)):(0,s.Q3)("",!0)],64)):"s3"===o.currentChannelType?((0,s.uX)(),(0,s.CE)(s.FK,{key:2},[(0,s.bF)(x,{label:"Endpoint",prop:"endpoint"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.editChannel.endpoint,"onUpdate:modelValue":e[39]||(e[39]=t=>o.editChannel.endpoint=t),disabled:o.editChannel.fixed},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(x,{label:"CDN 域名"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.editChannel.cdnDomain,"onUpdate:modelValue":e[40]||(e[40]=t=>o.editChannel.cdnDomain=t),placeholder:"如果有 CDN,请配置 CDN 域名,例如:https://cdn.example.com"},null,8,["modelValue"]),e[79]||(e[79]=(0,s.Lk)("span",{class:"form-tip"},"可选配置。配置后将优先通过 CDN 读取文件,提高访问速度和降低成本",-1))]),_:1}),(0,s.bF)(x,{label:"存储桶名称",prop:"bucketName"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.editChannel.bucketName,"onUpdate:modelValue":e[41]||(e[41]=t=>o.editChannel.bucketName=t),disabled:o.editChannel.fixed},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(x,{label:"存储桶区域",prop:"region"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.editChannel.region,"onUpdate:modelValue":e[42]||(e[42]=t=>o.editChannel.region=t),disabled:o.editChannel.fixed},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(x,{label:"访问密钥 ID",prop:"accessKeyId"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.editChannel.accessKeyId,"onUpdate:modelValue":e[43]||(e[43]=t=>o.editChannel.accessKeyId=t),disabled:o.editChannel.fixed,type:"password","show-password":""},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(x,{label:"机密访问密钥",prop:"secretAccessKey"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.editChannel.secretAccessKey,"onUpdate:modelValue":e[44]||(e[44]=t=>o.editChannel.secretAccessKey=t),disabled:o.editChannel.fixed,type:"password","show-password":""},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(x,{label:"路径风格"},{default:(0,s.k6)(()=>[(0,s.bF)(g,{modelValue:o.editChannel.pathStyle,"onUpdate:modelValue":e[45]||(e[45]=t=>o.editChannel.pathStyle=t),disabled:o.editChannel.fixed},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(x,{label:"容量限制"},{default:(0,s.k6)(()=>[(0,s.bF)(g,{modelValue:o.editChannel.quota.enabled,"onUpdate:modelValue":e[46]||(e[46]=t=>o.editChannel.quota.enabled=t),onChange:e[47]||(e[47]=t=>r.onQuotaEnabledChange(t,o.editChannel))},null,8,["modelValue"])]),_:1}),o.editChannel.quota?.enabled?((0,s.uX)(),(0,s.CE)(s.FK,{key:0},[(0,s.bF)(x,{label:"容量上限 (GB)"},{default:(0,s.k6)(()=>[(0,s.bF)(v,{modelValue:o.editChannel.quota.limitGB,"onUpdate:modelValue":e[48]||(e[48]=t=>o.editChannel.quota.limitGB=t),min:.1,step:1,precision:1},null,8,["modelValue"])]),_:1}),(0,s.bF)(x,{label:"停用阈值 (%)"},{default:(0,s.k6)(()=>[(0,s.bF)(v,{modelValue:o.editChannel.quota.threshold,"onUpdate:modelValue":e[49]||(e[49]=t=>o.editChannel.quota.threshold=t),min:50,max:100,step:5},null,8,["modelValue"])]),_:1})],64)):(0,s.Q3)("",!0)],64)):"discord"===o.currentChannelType?((0,s.uX)(),(0,s.CE)(s.FK,{key:3},[(0,s.bF)(x,{label:"Bot Token",prop:"botToken"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.editChannel.botToken,"onUpdate:modelValue":e[50]||(e[50]=t=>o.editChannel.botToken=t),disabled:o.editChannel.fixed,type:"password","show-password":""},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(x,{label:"Channel ID",prop:"channelId"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.editChannel.channelId,"onUpdate:modelValue":e[51]||(e[51]=t=>o.editChannel.channelId=t),disabled:o.editChannel.fixed,type:"password","show-password":""},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(x,{label:"代理域名"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.editChannel.proxyUrl,"onUpdate:modelValue":e[52]||(e[52]=t=>o.editChannel.proxyUrl=t),placeholder:"例如: your-proxy.example.com"},null,8,["modelValue"])]),_:1}),(0,s.bF)(x,{label:"Nitro 会员"},{default:(0,s.k6)(()=>[(0,s.bF)(g,{modelValue:o.editChannel.isNitro,"onUpdate:modelValue":e[53]||(e[53]=t=>o.editChannel.isNitro=t)},null,8,["modelValue"])]),_:1})],64)):"huggingface"===o.currentChannelType?((0,s.uX)(),(0,s.CE)(s.FK,{key:4},[(0,s.bF)(x,{label:"仓库名",prop:"repo"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.editChannel.repo,"onUpdate:modelValue":e[54]||(e[54]=t=>o.editChannel.repo=t),disabled:o.editChannel.fixed},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(x,{label:"Access Token",prop:"token"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{modelValue:o.editChannel.token,"onUpdate:modelValue":e[55]||(e[55]=t=>o.editChannel.token=t),disabled:o.editChannel.fixed,type:"password","show-password":""},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(x,{label:"私有仓库"},{default:(0,s.k6)(()=>[(0,s.bF)(g,{modelValue:o.editChannel.isPrivate,"onUpdate:modelValue":e[56]||(e[56]=t=>o.editChannel.isPrivate=t)},null,8,["modelValue"])]),_:1})],64)):(0,s.Q3)("",!0)]),_:1},8,["model","rules"])]),_:1},8,["modelValue","title","onClosed"])])),[[A,o.loading]])}var Qd={components:{CustomSelect:dd},data(){return{channelFilter:"",channels:[{value:"telegram",label:"Telegram"},{value:"cfr2",label:"CloudFlare R2"},{value:"s3",label:"S3"},{value:"discord",label:"Discord"},{value:"huggingface",label:"HuggingFace"}],addableChannels:[{value:"telegram",label:"Telegram"},{value:"s3",label:"S3"},{value:"discord",label:"Discord"},{value:"huggingface",label:"HuggingFace"}],telegramSettings:{loadBalance:{enabled:!1},channels:[]},cfr2Settings:{channels:[]},s3Settings:{loadBalance:{enabled:!1},channels:[]},discordSettings:{loadBalance:{enabled:!1},channels:[]},huggingfaceSettings:{loadBalance:{enabled:!1},channels:[]},showAddDialog:!1,showDetailDialog:!1,showEditDialog:!1,currentChannelType:"",currentChannelIndex:-1,currentChannel:null,editChannel:{},newChannel:{type:"",name:"",enabled:!0,botToken:"",chatId:"",proxyUrl:"",endpoint:"",cdnDomain:"",bucketName:"",region:"auto",accessKeyId:"",secretAccessKey:"",pathStyle:!1,quota:{enabled:!1,limitGB:10,threshold:95},channelId:"",isNitro:!1,repo:"",token:"",isPrivate:!1},addRules:{type:[{required:!0,message:"请选择渠道类型",trigger:"change"}],name:[{required:!0,message:"请输入渠道名称",trigger:"blur"},{pattern:/^[\u4e00-\u9fa5a-zA-Z0-9_-]+$/,message:"渠道名称只能包含中英文、数字、下划线和横线",trigger:"blur"}],botToken:[{required:!0,message:"请输入 Bot Token",trigger:"blur"}],chatId:[{required:!0,message:"请输入 Chat ID",trigger:"blur"}],channelId:[{required:!0,message:"请输入 Channel ID",trigger:"blur"}],endpoint:[{required:!0,message:"请输入 Endpoint",trigger:"blur"}],bucketName:[{required:!0,message:"请输入存储桶名称",trigger:"blur"}],region:[{required:!0,message:"请输入存储桶区域",trigger:"blur"}],accessKeyId:[{required:!0,message:"请输入访问密钥 ID",trigger:"blur"}],secretAccessKey:[{required:!0,message:"请输入机密访问密钥",trigger:"blur"}],repo:[{required:!0,message:"请输入仓库名",trigger:"blur"}],token:[{required:!0,message:"请输入 Access Token",trigger:"blur"}]},editRules:{name:[{required:!0,message:"请输入渠道名称",trigger:"blur"},{pattern:/^[\u4e00-\u9fa5a-zA-Z0-9_-]+$/,message:"渠道名称只能包含中英文、数字、下划线和横线",trigger:"blur"}],botToken:[{required:!0,message:"请输入 Bot Token",trigger:"blur"}],chatId:[{required:!0,message:"请输入 Chat ID",trigger:"blur"}],channelId:[{required:!0,message:"请输入 Channel ID",trigger:"blur"}],endpoint:[{required:!0,message:"请输入 Endpoint",trigger:"blur"}],bucketName:[{required:!0,message:"请输入存储桶名称",trigger:"blur"}],region:[{required:!0,message:"请输入存储桶区域",trigger:"blur"}],accessKeyId:[{required:!0,message:"请输入访问密钥 ID",trigger:"blur"}],secretAccessKey:[{required:!0,message:"请输入机密访问密钥",trigger:"blur"}],repo:[{required:!0,message:"请输入仓库名",trigger:"blur"}],token:[{required:!0,message:"请输入 Access Token",trigger:"blur"}]},quotaStats:{},quotaLoading:!1,loading:!1}},computed:{filterOptions(){const t={telegram:"paper-plane",cfr2:"cloud",s3:"database",discord:"comments",huggingface:"robot"};return[{value:"",label:"全部类型"},...this.channels.map(e=>({value:e.value,label:e.label,icon:t[e.value]||"server"}))]},filteredChannels(){return this.channelFilter?this.channels.filter(t=>t.value===this.channelFilter):this.channels}},methods:{handleCardMouseMove(t,e,i){const s=t.currentTarget,n=s.getBoundingClientRect(),a=t.clientX-n.left,o=t.clientY-n.top,r=`glow-${e}-${i}`,l=this.$refs[r];l&&l[0]&&(l[0].style.opacity="1",l[0].style.left=`${a}px`,l[0].style.top=`${o}px`)},handleCardMouseLeave(t,e){const i=`glow-${t}-${e}`,s=this.$refs[i];s&&s[0]&&(s[0].style.opacity="0")},getChannelIcon(t){const e={telegram:"paper-plane",cfr2:"cloud",s3:"database",discord:"comments",huggingface:"robot"};return e[t]||"server"},getChannelTypeLabel(t){const e=this.channels.find(e=>e.value===t);return e?e.label:t},getChannelList(t){return this.getSettings(t)?.channels||[]},getSettings(t){const e={telegram:this.telegramSettings,cfr2:this.cfr2Settings,s3:this.s3Settings,discord:this.discordSettings,huggingface:this.huggingfaceSettings};return e[t]},hasLoadBalance(t){return["telegram","s3","discord","huggingface"].includes(t)},maskText(t,e=4){return t?t.length<=2*e?"****":t.slice(0,e)+"****"+t.slice(-e):"未设置"},openDetailDialog(t,e){this.currentChannelType=t,this.currentChannelIndex=e,this.currentChannel=this.getChannelList(t)[e],this.showDetailDialog=!0},openEditDialog(t,e){this.currentChannelType=t,this.currentChannelIndex=e;const i=this.getChannelList(t)[e];this.editChannel=JSON.parse(JSON.stringify(i)),this.editChannel.quota||(this.editChannel.quota={enabled:!1,limitGB:10,threshold:95}),this.showEditDialog=!0},openEditFromDetail(){this.showDetailDialog=!1,this.openEditDialog(this.currentChannelType,this.currentChannelIndex)},resetAddForm(){this.newChannel={type:"",name:"",enabled:!0,botToken:"",chatId:"",proxyUrl:"",endpoint:"",bucketName:"",region:"auto",accessKeyId:"",secretAccessKey:"",pathStyle:!1,quota:{enabled:!1,limitGB:10,threshold:95},channelId:"",isNitro:!1,repo:"",token:"",isPrivate:!1}},resetDetailData(){this.currentChannel=null},resetEditData(){this.editChannel={}},onChannelTypeChange(){const{type:t,name:e}=this.newChannel;this.newChannel={type:t,name:e,enabled:!0,botToken:"",chatId:"",proxyUrl:"",endpoint:"",cdnDomain:"",bucketName:"",region:"auto",accessKeyId:"",secretAccessKey:"",pathStyle:!1,quota:{enabled:!1,limitGB:10,threshold:95},channelId:"",isNitro:!1,repo:"",token:"",isPrivate:!1}},confirmAddChannel(){this.$refs.addForm.validate(t=>{if(!t)return;const{type:e,name:i}=this.newChannel,s=this.getSettings(e),n=["Telegram_env","R2_env","S3_env","Discord_env","HuggingFace_env"];if(n.includes(i))return void this.$message.warning("该名称为系统保留名称,请使用其他名称");const a=s.channels.some(t=>t.name===i);if(a)return void this.$message.warning("该类型下已存在同名渠道,请使用其他名称");let o={id:s.channels.length+1,name:this.newChannel.name,type:e,savePath:"database",enabled:!0,fixed:!1};"telegram"===e?Object.assign(o,{botToken:this.newChannel.botToken,chatId:this.newChannel.chatId,proxyUrl:this.newChannel.proxyUrl}):"s3"===e?Object.assign(o,{endpoint:this.newChannel.endpoint,cdnDomain:this.newChannel.cdnDomain,bucketName:this.newChannel.bucketName,region:this.newChannel.region,accessKeyId:this.newChannel.accessKeyId,secretAccessKey:this.newChannel.secretAccessKey,pathStyle:this.newChannel.pathStyle,quota:{...this.newChannel.quota}}):"discord"===e?Object.assign(o,{botToken:this.newChannel.botToken,channelId:this.newChannel.channelId,proxyUrl:this.newChannel.proxyUrl,isNitro:this.newChannel.isNitro}):"huggingface"===e&&Object.assign(o,{repo:this.newChannel.repo,token:this.newChannel.token,isPrivate:this.newChannel.isPrivate}),s.channels.push(o),this.showAddDialog=!1,this.saveSettings()})},confirmEditChannel(){this.$refs.editForm.validate(t=>{if(!t)return;const e=this.getSettings(this.currentChannelType),i=this.editChannel.name,s=this.currentChannelIndex,n=this.editChannel.fixed;if(!n){const t=["Telegram_env","R2_env","S3_env","Discord_env","HuggingFace_env"];if(t.includes(i))return void this.$message.warning("该名称为系统保留名称,请使用其他名称");const n=e.channels.some((t,e)=>e!==s&&t.name===i);if(n)return void this.$message.warning("该类型下已存在同名渠道,请使用其他名称")}e.channels[this.currentChannelIndex]={...this.editChannel},this.showEditDialog=!1,this.saveSettings()})},deleteChannel(t,e){const i=this.getChannelList(t)[e];i.fixed?this.$message.warning("环境变量配置的渠道无法删除"):this.$confirm("确定要删除该渠道吗?","提示",{confirmButtonText:"确定",cancelButtonText:"取消",type:"warning"}).then(()=>{const i=this.getSettings(t);i.channels.splice(e,1),i.channels.forEach((t,e)=>{t.id=e+1}),this.saveSettings()}).catch(()=>{})},saveSettings(){const t={telegram:this.telegramSettings,cfr2:this.cfr2Settings,s3:this.s3Settings,discord:this.discordSettings,huggingface:this.huggingfaceSettings};(0,Ut.A)("/api/manage/sysConfig/upload",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(t)}).then(()=>{this.$message.success("设置已保存")})},async refreshQuota(){this.quotaLoading=!0;try{const t=await(0,Ut.A)("/api/manage/quota",{method:"POST"}),e=await t.json();if(e.success)this.quotaStats=e.channelStats||{};else{const t=await(0,Ut.A)("/api/manage/quota"),e=await t.json();e.success&&(this.quotaStats=e.quotaStats||{})}}catch(t){console.error("Failed to refresh quota stats:",t)}finally{this.quotaLoading=!1}},async loadQuotaStats(){try{const t=await(0,Ut.A)("/api/manage/quota"),e=await t.json();e.success&&(this.quotaStats=e.quotaStats||{})}catch(t){console.error("Failed to load quota stats:",t)}},getChannelUsedGB(t){const e=this.quotaStats[t.name];return e?(e.usedMB||0)/1024:0},getQuotaPercentage(t){const e=this.getChannelUsedGB(t),i=t.quota?.limitGB||10,s=e/i*100;return Math.min(100,Math.round(10*s)/10)},getQuotaStatus(t){const e=this.getQuotaPercentage(t),i=t.quota?.threshold||95;return e>=i?"exception":e>=80?"warning":"success"},getQuotaText(t){const e=this.getChannelUsedGB(t),i=t.quota?.limitGB||10;return`${e.toFixed(2)} / ${i} GB`},isQuotaExceeded(t){const e=this.getQuotaPercentage(t),i=t.quota?.threshold||95;return e>=i},getQuotaStatusText(t){const e=this.getQuotaPercentage(t),i=t.quota?.threshold||95;return e>=i?`⚠️ 已达到容量阈值 (${i}%),渠道写入已暂停`:e>=80?"⚡ 容量使用较高,接近阈值":"✓ 容量正常"},async onQuotaEnabledChange(t,e){if(t&&e.name){const t=this.quotaStats[e.name];t||this.$confirm("首次启用容量限制需要统计现有文件容量,这可能需要一些时间。是否立即统计?","初始化容量统计",{confirmButtonText:"立即统计",cancelButtonText:"稍后手动统计",type:"info"}).then(async()=>{await this.recalculateQuota()}).catch(()=>{this.$message.info("您可以稍后点击刷新按钮手动统计")})}},async recalculateQuota(){this.quotaLoading=!0;try{this.$message.info("正在统计容量,请稍候...");const t=await(0,Ut.A)("/api/manage/quota",{method:"POST"}),e=await t.json();e.success?(this.quotaStats=e.channelStats||{},this.$message.success("容量统计完成")):this.$message.error("统计失败: "+(e.error||"未知错误"))}catch(t){console.error("Failed to recalculate quota:",t),this.$message.error("统计失败")}finally{this.quotaLoading=!1}}},mounted(){this.loading=!0,(0,Ut.A)("/api/manage/sysConfig/upload").then(t=>t.json()).then(t=>{this.telegramSettings=t.telegram,t.cfr2&&t.cfr2.channels&&(t.cfr2.channels=t.cfr2.channels.map(t=>({...t,quota:t.quota||{enabled:!1,limitGB:10,threshold:95}}))),this.cfr2Settings=t.cfr2,t.s3&&t.s3.channels&&(t.s3.channels=t.s3.channels.map(t=>({...t,quota:t.quota||{enabled:!1,limitGB:10,threshold:95}}))),this.s3Settings=t.s3,t.discord&&t.discord.channels&&(t.discord.channels=t.discord.channels.map(t=>({...t,proxyUrl:t.proxyUrl||""}))),this.discordSettings=t.discord||{loadBalance:{},channels:[]},t.huggingface&&t.huggingface.channels&&(t.huggingface.channels=t.huggingface.channels.map(t=>({...t,isPrivate:t.isPrivate||!1}))),this.huggingfaceSettings=t.huggingface||{loadBalance:{},channels:[]},this.loadQuotaStats()}).finally(()=>{this.loading=!1})}};const Gd=(0,c.A)(Qd,[["render",Yd],["__scopeId","data-v-89234e52"]]);var Jd=Gd,Zd=i(850);i(9187),i(8736);const tu={class:"save-text"};function eu(t,e,i,a,o,r){const l=(0,s.g2)("font-awesome-icon");return(0,s.uX)(),(0,s.Wv)(od.eB,{name:"fade-up"},{default:(0,s.k6)(()=>[(0,s.bo)((0,s.Lk)("div",{class:(0,n.C4)(["floating-save-btn",{"is-loading":i.loading}]),onClick:e[0]||(e[0]=(...t)=>r.handleClick&&r.handleClick(...t))},[i.loading?((0,s.uX)(),(0,s.Wv)(l,{key:0,icon:"spinner",spin:""})):((0,s.uX)(),(0,s.Wv)(l,{key:1,icon:"save"})),(0,s.Lk)("span",tu,(0,n.v_)(i.loading?"保存中":"保存"),1)],2),[[od.aG,o.visible]])]),_:1})}var iu={name:"FloatingSaveButton",props:{loading:{type:Boolean,default:!1},show:{type:Boolean,default:!0}},data(){return{visible:!1}},watch:{show:{immediate:!0,handler(t){t?setTimeout(()=>{this.visible=!0},600):this.visible=!1}}},methods:{handleClick(){this.loading||this.$emit("click")}}};const su=(0,c.A)(iu,[["render",eu],["__scopeId","data-v-27fc6cc8"]]);var nu=su,au=i(7138);i(5802),i(4752);const ou={class:"security-settings"},ru={class:"first-settings"},lu={class:"second-title token-title"},hu={class:"token-actions"},cu={class:"token-table-container"},du={class:"table-cell-content"},uu={class:"table-cell-content"},gu={class:"token-display"},pu={class:"table-cell-content"},fu={class:"table-cell-content"},mu={class:"table-cell-content action-buttons"},bu={class:"first-settings"},xu={class:"second-title"},yu={class:"first-settings"},_u={class:"dialog-footer"},vu={class:"dialog-footer"},ku={class:"token-result"},wu={style:{"margin-bottom":"15px",color:"#e6a23c"}},Cu={class:"dialog-footer"};function Su(t,e,i,a,o,r){const l=id.WK,h=td.xE,c=td.US,d=(0,s.g2)("font-awesome-icon"),u=k.S2,g=au.o8,f=ad.u,m=au.Up,b=p.R7,x=nd.qi,y=sd.P9,v=sd.AV,w=nu,C=Zd.dI,S=Zd.o5,F=Zc.kZ,M=_.A;return(0,s.bo)(((0,s.uX)(),(0,s.CE)("div",ou,[(0,s.Lk)("div",ru,[e[26]||(e[26]=(0,s.Lk)("h3",{class:"first-title"},"认证管理",-1)),e[27]||(e[27]=(0,s.Lk)("h4",{class:"second-title"},"用户端认证",-1)),(0,s.bF)(c,{model:o.authSettings.user,rules:o.userPassRules,ref:"userPassForm","label-width":"120px"},{default:(0,s.k6)(()=>[(0,s.bF)(h,{label:"上传密码",prop:"authCode"},{default:(0,s.k6)(()=>[(0,s.bF)(l,{modelValue:o.authSettings.user.authCode,"onUpdate:modelValue":e[0]||(e[0]=t=>o.authSettings.user.authCode=t),type:"password","show-password":"",onInput:r.handleUserPassInput,autocomplete:"new-password"},null,8,["modelValue","onInput"])]),_:1}),(0,s.bF)(od.eB,{name:"fade-slide",mode:"out-in"},{default:(0,s.k6)(()=>[o.showUserPassConfirm?((0,s.uX)(),(0,s.Wv)(h,{label:"确认密码",prop:"confirmNewUserPassword",key:"user-confirm"},{default:(0,s.k6)(()=>[(0,s.bF)(l,{modelValue:o.authSettings.user.confirmNewUserPassword,"onUpdate:modelValue":e[1]||(e[1]=t=>o.authSettings.user.confirmNewUserPassword=t),type:"password","show-password":"",autocomplete:"new-password"},null,8,["modelValue"])]),_:1})):(0,s.Q3)("",!0)]),_:1})]),_:1},8,["model","rules"]),e[28]||(e[28]=(0,s.Lk)("h4",{class:"second-title"},"管理端认证",-1)),(0,s.bF)(c,{model:o.authSettings.admin,rules:o.adminPassRules,ref:"adminPassForm","label-width":"120px"},{default:(0,s.k6)(()=>[(0,s.bF)(h,{label:"用户名",prop:"adminUsername"},{default:(0,s.k6)(()=>[(0,s.bF)(l,{modelValue:o.authSettings.admin.adminUsername,"onUpdate:modelValue":e[2]||(e[2]=t=>o.authSettings.admin.adminUsername=t),autocomplete:"new-password"},null,8,["modelValue"])]),_:1}),(0,s.bF)(h,{label:"密码",prop:"adminPassword"},{default:(0,s.k6)(()=>[(0,s.bF)(l,{modelValue:o.authSettings.admin.adminPassword,"onUpdate:modelValue":e[3]||(e[3]=t=>o.authSettings.admin.adminPassword=t),type:"password","show-password":"",onInput:r.handleAdminPassInput,autocomplete:"new-password"},null,8,["modelValue","onInput"])]),_:1}),(0,s.bF)(od.eB,{name:"fade-slide",mode:"out-in"},{default:(0,s.k6)(()=>[o.showAdminPassConfirm?((0,s.uX)(),(0,s.Wv)(h,{label:"确认密码",prop:"confirmNewAdminPassword",key:"admin-confirm"},{default:(0,s.k6)(()=>[(0,s.bF)(l,{modelValue:o.authSettings.admin.confirmNewAdminPassword,"onUpdate:modelValue":e[4]||(e[4]=t=>o.authSettings.admin.confirmNewAdminPassword=t),type:"password","show-password":"",autocomplete:"new-password"},null,8,["modelValue"])]),_:1})):(0,s.Q3)("",!0)]),_:1})]),_:1},8,["model","rules"]),(0,s.Lk)("h4",lu,[e[23]||(e[23]=(0,s.eW)("API Token 管理 ",-1)),(0,s.Lk)("a",hu,[(0,s.bF)(u,{type:"primary",size:"small",onClick:e[5]||(e[5]=t=>o.showCreateTokenDialog=!0),circle:""},{default:(0,s.k6)(()=>[(0,s.bF)(d,{icon:"plus"})]),_:1})])]),(0,s.Lk)("div",cu,[(0,s.bo)(((0,s.uX)(),(0,s.Wv)(m,{data:o.apiTokens,class:"token-table"},{default:(0,s.k6)(()=>[(0,s.bF)(g,{prop:"name",label:"名称","header-align":"center"},{default:(0,s.k6)(t=>[(0,s.Lk)("div",du,(0,n.v_)(t.row.name),1)]),_:1}),(0,s.bF)(g,{prop:"token",label:"Token","header-align":"center"},{default:(0,s.k6)(t=>[(0,s.Lk)("div",uu,[(0,s.Lk)("span",gu,(0,n.v_)(t.row.token),1)])]),_:1}),(0,s.bF)(g,{prop:"permissions",label:"权限","header-align":"center"},{default:(0,s.k6)(t=>[(0,s.Lk)("div",pu,[((0,s.uX)(!0),(0,s.CE)(s.FK,null,(0,s.pI)(t.row.permissions,t=>((0,s.uX)(),(0,s.Wv)(f,{key:t,size:"small",class:"permission-tag"},{default:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(r.getPermissionText(t)),1)]),_:2},1024))),128))])]),_:1}),(0,s.bF)(g,{prop:"createdAt",label:"创建时间","header-align":"center"},{default:(0,s.k6)(t=>[(0,s.Lk)("div",fu,(0,n.v_)(r.formatDate(t.row.createdAt)),1)]),_:1}),(0,s.bF)(g,{label:"操作",fixed:"right","header-align":"center"},{default:(0,s.k6)(t=>[(0,s.Lk)("div",mu,[(0,s.bF)(u,{class:"action-button",size:"small",onClick:e=>r.editToken(t.row)},{default:(0,s.k6)(()=>[...e[24]||(e[24]=[(0,s.eW)("编辑",-1)])]),_:1},8,["onClick"]),(0,s.bF)(u,{class:"action-button",size:"small",type:"danger",onClick:e=>r.deleteToken(t.row.id)},{default:(0,s.k6)(()=>[...e[25]||(e[25]=[(0,s.eW)("删除",-1)])]),_:1},8,["onClick"])])]),_:1})]),_:1},8,["data"])),[[M,o.tokenLoading]])])]),(0,s.Lk)("div",bu,[e[30]||(e[30]=(0,s.Lk)("h3",{class:"first-title"},"上传管理",-1)),(0,s.Lk)("h4",xu,[e[29]||(e[29]=(0,s.eW)("图像审查 ",-1)),(0,s.bF)(b,{content:"仅对非分块上传文件生效,支持 nsfwjs 和 moderatecontent.com 渠道",placement:"top"},{default:(0,s.k6)(()=>[(0,s.bF)(d,{icon:"question-circle",style:{"margin-left":"5px",cursor:"pointer"}})]),_:1})]),(0,s.bF)(c,{model:o.uploadSettings.moderate,"label-width":"120px"},{default:(0,s.k6)(()=>[(0,s.bF)(h,{label:"开启审查"},{default:(0,s.k6)(()=>[(0,s.bF)(x,{modelValue:o.uploadSettings.moderate.enabled,"onUpdate:modelValue":e[6]||(e[6]=t=>o.uploadSettings.moderate.enabled=t)},null,8,["modelValue"])]),_:1}),(0,s.bF)(h,{label:"审查渠道"},{default:(0,s.k6)(()=>[(0,s.bF)(v,{modelValue:o.uploadSettings.moderate.channel,"onUpdate:modelValue":e[7]||(e[7]=t=>o.uploadSettings.moderate.channel=t),placeholder:"请选择审查渠道"},{default:(0,s.k6)(()=>[(0,s.bF)(y,{label:"moderatecontent.com",value:"moderatecontent.com"}),(0,s.bF)(y,{label:"nsfwjs",value:"nsfwjs"})]),_:1},8,["modelValue"])]),_:1}),"moderatecontent.com"===o.uploadSettings.moderate.channel?((0,s.uX)(),(0,s.Wv)(h,{key:0,label:"API Key"},{default:(0,s.k6)(()=>[(0,s.bF)(l,{modelValue:o.uploadSettings.moderate.moderateContentApiKey,"onUpdate:modelValue":e[8]||(e[8]=t=>o.uploadSettings.moderate.moderateContentApiKey=t)},null,8,["modelValue"])]),_:1})):(0,s.Q3)("",!0),"nsfwjs"===o.uploadSettings.moderate.channel?((0,s.uX)(),(0,s.Wv)(h,{key:1,label:"API 路径"},{default:(0,s.k6)(()=>[(0,s.bF)(l,{modelValue:o.uploadSettings.moderate.nsfwApiPath,"onUpdate:modelValue":e[9]||(e[9]=t=>o.uploadSettings.moderate.nsfwApiPath=t),placeholder:"https://nsfwjs.your.domain"},null,8,["modelValue"])]),_:1})):(0,s.Q3)("",!0)]),_:1},8,["model"])]),(0,s.Lk)("div",yu,[e[33]||(e[33]=(0,s.Lk)("h3",{class:"first-title"},"访问管理",-1)),e[34]||(e[34]=(0,s.Lk)("h4",{class:"second-title"},"域名过滤",-1)),(0,s.bF)(c,{model:o.accessSettings,"label-width":"120px"},{default:(0,s.k6)(()=>[(0,s.bF)(h,null,{label:(0,s.k6)(()=>[e[31]||(e[31]=(0,s.eW)(" 放行域名 ",-1)),(0,s.bF)(b,{content:"1.针对访问域名设置权限
2.留空默认全部放行,多个域名请用英文逗号分隔",placement:"top","raw-content":""},{default:(0,s.k6)(()=>[(0,s.bF)(d,{icon:"question-circle",style:{"margin-left":"5px",cursor:"pointer"}})]),_:1})]),default:(0,s.k6)(()=>[(0,s.bF)(l,{modelValue:o.accessSettings.allowedDomains,"onUpdate:modelValue":e[10]||(e[10]=t=>o.accessSettings.allowedDomains=t)},null,8,["modelValue"])]),_:1})]),_:1},8,["model"]),e[35]||(e[35]=(0,s.Lk)("h4",{class:"second-title"},"白名单模式",-1)),(0,s.bF)(c,{model:o.accessSettings,"label-width":"120px"},{default:(0,s.k6)(()=>[(0,s.bF)(h,null,{label:(0,s.k6)(()=>[e[32]||(e[32]=(0,s.eW)(" 是否开启 ",-1)),(0,s.bF)(b,{content:"1.针对文件设置权限
2.开启后,仅被加入白名单的文件可被访问",placement:"top","raw-content":""},{default:(0,s.k6)(()=>[(0,s.bF)(d,{icon:"question-circle",style:{"margin-left":"5px",cursor:"pointer"}})]),_:1})]),default:(0,s.k6)(()=>[(0,s.bF)(x,{modelValue:o.accessSettings.whiteListMode,"onUpdate:modelValue":e[11]||(e[11]=t=>o.accessSettings.whiteListMode=t)},null,8,["modelValue"])]),_:1})]),_:1},8,["model"])]),(0,s.bF)(w,{show:!o.loading,onClick:r.saveSettings},null,8,["show","onClick"]),(0,s.bF)(F,{modelValue:o.showCreateTokenDialog,"onUpdate:modelValue":e[15]||(e[15]=t=>o.showCreateTokenDialog=t),title:"创建新 API Token",width:r.dialogWidth},{footer:(0,s.k6)(()=>[(0,s.Lk)("span",_u,[(0,s.bF)(u,{onClick:e[14]||(e[14]=t=>o.showCreateTokenDialog=!1)},{default:(0,s.k6)(()=>[...e[39]||(e[39]=[(0,s.eW)("取消",-1)])]),_:1}),(0,s.bF)(u,{type:"primary",onClick:r.createToken},{default:(0,s.k6)(()=>[...e[40]||(e[40]=[(0,s.eW)("创建",-1)])]),_:1},8,["onClick"])])]),default:(0,s.k6)(()=>[(0,s.bF)(c,{model:o.newToken,rules:o.tokenRules,ref:"tokenForm","label-width":"100px"},{default:(0,s.k6)(()=>[(0,s.bF)(h,{label:"Token 名称",prop:"name"},{default:(0,s.k6)(()=>[(0,s.bF)(l,{modelValue:o.newToken.name,"onUpdate:modelValue":e[12]||(e[12]=t=>o.newToken.name=t),placeholder:"请输入Token名称"},null,8,["modelValue"])]),_:1}),(0,s.bF)(h,{label:"权限",prop:"permissions"},{default:(0,s.k6)(()=>[(0,s.bF)(S,{modelValue:o.newToken.permissions,"onUpdate:modelValue":e[13]||(e[13]=t=>o.newToken.permissions=t)},{default:(0,s.k6)(()=>[(0,s.bF)(C,{label:"upload"},{default:(0,s.k6)(()=>[...e[36]||(e[36]=[(0,s.eW)("上传",-1)])]),_:1}),(0,s.bF)(C,{label:"delete"},{default:(0,s.k6)(()=>[...e[37]||(e[37]=[(0,s.eW)("删除",-1)])]),_:1}),(0,s.bF)(C,{label:"list"},{default:(0,s.k6)(()=>[...e[38]||(e[38]=[(0,s.eW)("列出",-1)])]),_:1})]),_:1},8,["modelValue"])]),_:1})]),_:1},8,["model","rules"])]),_:1},8,["modelValue","width"]),(0,s.bF)(F,{modelValue:o.showEditTokenDialog,"onUpdate:modelValue":e[19]||(e[19]=t=>o.showEditTokenDialog=t),title:"编辑 API Token",width:r.dialogWidth},{footer:(0,s.k6)(()=>[(0,s.Lk)("span",vu,[(0,s.bF)(u,{onClick:e[18]||(e[18]=t=>o.showEditTokenDialog=!1)},{default:(0,s.k6)(()=>[...e[44]||(e[44]=[(0,s.eW)("取消",-1)])]),_:1}),(0,s.bF)(u,{type:"primary",onClick:r.updateToken},{default:(0,s.k6)(()=>[...e[45]||(e[45]=[(0,s.eW)("更新",-1)])]),_:1},8,["onClick"])])]),default:(0,s.k6)(()=>[(0,s.bF)(c,{model:o.editingToken,rules:o.tokenRules,ref:"editTokenForm","label-width":"100px"},{default:(0,s.k6)(()=>[(0,s.bF)(h,{label:"Token 名称"},{default:(0,s.k6)(()=>[(0,s.bF)(l,{modelValue:o.editingToken.name,"onUpdate:modelValue":e[16]||(e[16]=t=>o.editingToken.name=t),disabled:""},null,8,["modelValue"])]),_:1}),(0,s.bF)(h,{label:"权限",prop:"permissions"},{default:(0,s.k6)(()=>[(0,s.bF)(S,{modelValue:o.editingToken.permissions,"onUpdate:modelValue":e[17]||(e[17]=t=>o.editingToken.permissions=t)},{default:(0,s.k6)(()=>[(0,s.bF)(C,{label:"upload"},{default:(0,s.k6)(()=>[...e[41]||(e[41]=[(0,s.eW)("上传",-1)])]),_:1}),(0,s.bF)(C,{label:"delete"},{default:(0,s.k6)(()=>[...e[42]||(e[42]=[(0,s.eW)("删除",-1)])]),_:1}),(0,s.bF)(C,{label:"list"},{default:(0,s.k6)(()=>[...e[43]||(e[43]=[(0,s.eW)("列出",-1)])]),_:1})]),_:1},8,["modelValue"])]),_:1})]),_:1},8,["model","rules"])]),_:1},8,["modelValue","width"]),(0,s.bF)(F,{modelValue:o.showTokenResultDialog,"onUpdate:modelValue":e[22]||(e[22]=t=>o.showTokenResultDialog=t),title:"Token 创建成功",width:r.dialogWidth},{footer:(0,s.k6)(()=>[(0,s.Lk)("span",Cu,[(0,s.bF)(u,{type:"primary",onClick:e[21]||(e[21]=t=>o.showTokenResultDialog=!1)},{default:(0,s.k6)(()=>[...e[48]||(e[48]=[(0,s.eW)("我已保存",-1)])]),_:1})])]),default:(0,s.k6)(()=>[(0,s.Lk)("div",ku,[(0,s.Lk)("p",wu,[(0,s.bF)(d,{icon:"exclamation-triangle",style:{"margin-right":"5px"}}),e[46]||(e[46]=(0,s.eW)(" 请妥善保存以下Token,关闭此窗口后将无法再次查看完整Token! ",-1))]),(0,s.bF)(c,{"label-width":"100px"},{default:(0,s.k6)(()=>[(0,s.bF)(h,{label:"Token 名称"},{default:(0,s.k6)(()=>[(0,s.Lk)("span",null,(0,n.v_)(o.createdToken.name),1)]),_:1}),(0,s.bF)(h,{label:"完整Token"},{default:(0,s.k6)(()=>[(0,s.bF)(l,{modelValue:o.createdToken.token,"onUpdate:modelValue":e[20]||(e[20]=t=>o.createdToken.token=t),readonly:""},{append:(0,s.k6)(()=>[(0,s.bF)(u,{onClick:r.copyToken},{default:(0,s.k6)(()=>[...e[47]||(e[47]=[(0,s.eW)("复制",-1)])]),_:1},8,["onClick"])]),_:1},8,["modelValue"])]),_:1})]),_:1})])]),_:1},8,["modelValue","width"])])),[[M,o.loading]])}i(1148);var Fu={components:{FloatingSaveButton:nu},data(){return{authSettings:{user:{},admin:{}},uploadSettings:{moderate:{}},accessSettings:{},apiTokens:[],loading:!0,tokenLoading:!1,oriUserPassword:"",oriAdminPassword:"",showUserPassConfirm:!1,showAdminPassConfirm:!1,showCreateTokenDialog:!1,showEditTokenDialog:!1,showTokenResultDialog:!1,newToken:{name:"",owner:"",permissions:[]},editingToken:{id:"",name:"",owner:"",permissions:[]},createdToken:{name:"",token:""},userPassRules:{authCode:[{validator:(t,e,i)=>{const s=["%","&","?","#","/"],n=s.some(t=>e&&e.includes(t));n?i(new Error("密码不能包含部分URL保留字符: % & ? # /")):i()},trigger:"blur"}],confirmNewUserPassword:[{message:"请再次输入上传密码",trigger:"blur"},{validator:(t,e,i)=>{e&&e!==this.authSettings.user.authCode?i(new Error("两次输入密码不一致")):i()},trigger:"blur"}]},adminPassRules:{confirmNewAdminPassword:[{message:"请再次输入管理密码",trigger:"blur"},{validator:(t,e,i)=>{e&&e!==this.authSettings.admin.adminPassword?i(new Error("两次输入密码不一致")):i()},trigger:"blur"}]},tokenRules:{name:[{required:!0,message:"请输入Token名称",trigger:"blur"}],permissions:[{required:!0,message:"请选择权限",trigger:"change"}]}}},computed:{dialogWidth(){return window.innerWidth>768?"50%":"90%"}},methods:{handleUserPassInput(){this.authSettings.user.authCode!==this.oriUserPassword?this.showUserPassConfirm=!0:this.showUserPassConfirm=!1},handleAdminPassInput(){this.authSettings.admin.adminPassword!==this.oriAdminPassword?this.showAdminPassConfirm=!0:this.showAdminPassConfirm=!1},getPermissionText(t){const e={upload:"上传",delete:"删除",list:"列出"};return e[t]||t},formatDate(t){return new Date(t).toLocaleString("zh-CN")},async loadApiTokens(){this.tokenLoading=!0;try{const t=await(0,Ut.A)("/api/manage/apiTokens"),e=await t.json();this.apiTokens=e.tokens||[]}catch(t){this.$message.error("获取Token列表失败")}finally{this.tokenLoading=!1}},createToken(){this.$refs.tokenForm.validate(async t=>{if(t)try{this.newToken.owner="admin";const t=await(0,Ut.A)("/api/manage/apiTokens",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(this.newToken)}),e=await t.json();t.ok?(this.createdToken={name:e.name,token:e.token},this.showCreateTokenDialog=!1,this.showTokenResultDialog=!0,this.newToken={name:"",owner:"",permissions:[]},await this.loadApiTokens(),this.$message.success("Token创建成功")):this.$message.error(e.error||"Token创建失败")}catch(e){this.$message.error("Token创建失败")}})},editToken(t){this.editingToken={id:t.id,name:t.name,owner:t.owner,permissions:[...t.permissions]},this.showEditTokenDialog=!0},updateToken(){this.$refs.editTokenForm.validate(async t=>{if(t)try{const t=await(0,Ut.A)("/api/manage/apiTokens",{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify({tokenId:this.editingToken.id,permissions:this.editingToken.permissions})}),e=await t.json();t.ok?(this.showEditTokenDialog=!1,await this.loadApiTokens(),this.$message.success("Token权限更新成功")):this.$message.error(e.error||"Token更新失败")}catch(e){this.$message.error("Token更新失败")}})},async deleteToken(t){try{await this.$confirm("此操作将永久删除该Token,是否继续?","提示",{confirmButtonText:"确定",cancelButtonText:"取消",type:"warning"});const e=await(0,Ut.A)(`/api/manage/apiTokens?id=${t}`,{method:"DELETE"}),i=await e.json();e.ok?(await this.loadApiTokens(),this.$message.success("Token删除成功")):this.$message.error(i.error||"Token删除失败")}catch(e){"cancel"!==e&&this.$message.error("Token删除失败")}},async copyToken(){try{await navigator.clipboard.writeText(this.createdToken.token),this.$message.success("Token已复制到剪贴板")}catch(t){this.$message.error("复制失败,请手动复制")}},saveSettings(){let t=[];t.push(new Promise(t=>{this.$refs.userPassForm.validate(e=>{t(e)})})),t.push(new Promise(t=>{this.$refs.adminPassForm.validate(e=>{t(e)})})),Promise.all(t).then(t=>{const e=t.every(t=>t);if(!e)return;const i={auth:this.authSettings,upload:this.uploadSettings,access:this.accessSettings};delete i.auth.user.confirmNewUserPassword,delete i.auth.admin.confirmNewAdminPassword,(0,Ut.A)("/api/manage/sysConfig/security",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(i)}).then(()=>{this.$message.success("设置已保存"),this.oriUserPassword=this.authSettings.user.authCode,this.oriAdminPassword=this.authSettings.admin.adminPassword,this.showUserPassConfirm=!1,this.showAdminPassConfirm=!1})})}},mounted(){this.loading=!0,(0,Ut.A)("/api/manage/sysConfig/security").then(t=>t.json()).then(t=>{this.authSettings=t.auth,this.uploadSettings=t.upload,this.accessSettings=t.access,this.oriUserPassword=this.authSettings.user.authCode,this.oriAdminPassword=this.authSettings.admin.adminPassword,this.authSettings.user.confirmNewUserPassword="",this.authSettings.admin.confirmNewAdminPassword="",this.loadApiTokens()}).finally(()=>{this.loading=!1})}};const Mu=(0,c.A)(Fu,[["render",Su],["__scopeId","data-v-fdf607e4"]]);var Au=Mu;const Tu={class:"page-settings"},Pu={class:"first-title"};function Du(t,e,i,a,o,r){const l=(0,s.g2)("font-awesome-icon"),h=p.R7,c=sd.P9,d=sd.AV,u=nd.qi,g=id.WK,f=td.xE,m=td.US,b=nu,x=_.A;return(0,s.bo)(((0,s.uX)(),(0,s.CE)("div",Tu,[((0,s.uX)(!0),(0,s.CE)(s.FK,null,(0,s.pI)(r.groupedSettings,(t,e)=>((0,s.uX)(),(0,s.CE)("div",{key:e,class:"first-settings"},[(0,s.Lk)("h3",Pu,(0,n.v_)(e),1),(0,s.bF)(m,{model:o.settings,"label-width":"150px"},{default:(0,s.k6)(()=>[((0,s.uX)(!0),(0,s.CE)(s.FK,null,(0,s.pI)(t,(t,e)=>((0,s.uX)(),(0,s.Wv)(f,{key:t.id},{label:(0,s.k6)(()=>[(0,s.eW)((0,n.v_)(t.label)+" ",1),t.tooltip?((0,s.uX)(),(0,s.Wv)(h,{key:0,content:t.tooltip,placement:"top","raw-content":""},{default:(0,s.k6)(()=>[(0,s.bF)(l,{icon:"question-circle",style:{"margin-left":"5px",cursor:"pointer"}})]),_:1},8,["content"])):(0,s.Q3)("",!0)]),default:(0,s.k6)(()=>["select"===t.type?((0,s.uX)(),(0,s.Wv)(d,{key:0,modelValue:t.value,"onUpdate:modelValue":e=>t.value=e,disabled:t.fixed,placeholder:t.placeholder,style:{width:"100%"}},{default:(0,s.k6)(()=>[((0,s.uX)(!0),(0,s.CE)(s.FK,null,(0,s.pI)(t.options,t=>((0,s.uX)(),(0,s.Wv)(c,{key:t.value,label:t.label,value:t.value},null,8,["label","value"]))),128))]),_:2},1032,["modelValue","onUpdate:modelValue","disabled","placeholder"])):"channelName"===t.type?((0,s.uX)(),(0,s.Wv)(d,{key:1,modelValue:t.value,"onUpdate:modelValue":e=>t.value=e,disabled:!r.currentUploadChannel||0===r.currentChannelList.length,placeholder:"请先选择上传渠道",clearable:"",style:{width:"100%"}},{default:(0,s.k6)(()=>[((0,s.uX)(!0),(0,s.CE)(s.FK,null,(0,s.pI)(r.currentChannelList,t=>((0,s.uX)(),(0,s.Wv)(c,{key:t.name,label:t.name,value:t.name},null,8,["label","value"]))),128))]),_:1},8,["modelValue","onUpdate:modelValue","disabled"])):"boolean"===t.type?((0,s.uX)(),(0,s.Wv)(u,{key:2,modelValue:t.value,"onUpdate:modelValue":e=>t.value=e,disabled:t.fixed},null,8,["modelValue","onUpdate:modelValue","disabled"])):((0,s.uX)(),(0,s.Wv)(g,{key:3,modelValue:t.value,"onUpdate:modelValue":e=>t.value=e,disabled:t.fixed,placeholder:t.placeholder},null,8,["modelValue","onUpdate:modelValue","disabled","placeholder"]))]),_:2},1024))),128))]),_:2},1032,["model"])]))),128)),(0,s.bF)(b,{show:!o.loading,onClick:r.saveSettings},null,8,["show","onClick"])])),[[x,o.loading]])}var Eu=i(457),Lu={components:{FloatingSaveButton:nu},data(){return{settings:{config:[]},loading:!0,availableChannels:{}}},computed:{groupedSettings(){const t={};return this.settings.config&&this.settings.config.forEach(e=>{const i=e.category||"其他设置";t[i]||(t[i]=[]),t[i].push(e)}),t},currentUploadChannel(){const t=this.settings.config?.find(t=>"defaultUploadChannel"===t.id);return t?.value||""},currentChannelList(){return this.availableChannels[this.currentUploadChannel]||[]}},watch:{currentUploadChannel(t,e){if(t!==e){const e=this.settings.config?.find(t=>"defaultChannelName"===t.id);if(e){const i=this.availableChannels[t]||[];i.some(t=>t.name===e.value)||(e.value="")}}}},methods:{saveSettings(){(0,Ut.A)("/api/manage/sysConfig/page",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(this.settings)}).then(()=>this.$message.success("设置已保存"))},async fetchAvailableChannels(){try{const t=await Eu.A.get("/api/channels");t.data&&(this.availableChannels=t.data)}catch(t){console.error("Failed to fetch available channels:",t)}}},mounted(){this.loading=!0,this.fetchAvailableChannels(),(0,Ut.A)("/api/manage/sysConfig/page").then(t=>t.json()).then(t=>{this.settings=t,this.settings.config&&this.settings.config.forEach(t=>{"boolean"===t.type&&("string"===typeof t.value?t.value="true"===t.value:void 0!==t.value&&null!==t.value||(t.value=t.default||!1))})}).finally(()=>{this.loading=!1})}};const Iu=(0,c.A)(Lu,[["render",Du],["__scopeId","data-v-44bd640d"]]);var Vu=Iu;const Ou={class:"others-settings"},Ru={class:"first-settings"},Wu={class:"first-title"},Bu={class:"first-title"},zu={class:"first-title"},Nu={class:"first-title"},Uu={class:"first-title"};function $u(t,e,i,n,a,o){const r=(0,s.g2)("font-awesome-icon"),l=p.R7,h=nd.qi,c=td.xE,d=td.US,u=id.WK,g=sd.P9,f=sd.AV,m=nu,b=_.A;return(0,s.bo)(((0,s.uX)(),(0,s.CE)("div",Ou,[(0,s.Lk)("div",Ru,[(0,s.Lk)("h3",Wu,[e[13]||(e[13]=(0,s.eW)("远端遥测 ",-1)),(0,s.bF)(l,{content:"便于问题查找和定位,建议开启",placement:"right"},{default:(0,s.k6)(()=>[(0,s.bF)(r,{icon:"question-circle",style:{"margin-left":"5px",cursor:"pointer"}})]),_:1})]),(0,s.bF)(d,{model:a.settings.telemetry,"label-width":"120px"},{default:(0,s.k6)(()=>[(0,s.bF)(c,{label:"启用"},{default:(0,s.k6)(()=>[(0,s.bF)(h,{modelValue:a.settings.telemetry.enabled,"onUpdate:modelValue":e[0]||(e[0]=t=>a.settings.telemetry.enabled=t),disabled:a.settings.telemetry.fixed},null,8,["modelValue","disabled"])]),_:1})]),_:1},8,["model"]),(0,s.Lk)("h3",Bu,[e[14]||(e[14]=(0,s.eW)("随机图像API ",-1)),(0,s.bF)(l,{content:"API具体用法请查阅文档",placement:"right"},{default:(0,s.k6)(()=>[(0,s.bF)(r,{icon:"question-circle",style:{"margin-left":"5px",cursor:"pointer"}})]),_:1})]),(0,s.bF)(d,{model:a.settings.randomImageAPI,"label-width":"120px"},{default:(0,s.k6)(()=>[(0,s.bF)(c,{label:"启用"},{default:(0,s.k6)(()=>[(0,s.bF)(h,{modelValue:a.settings.randomImageAPI.enabled,"onUpdate:modelValue":e[1]||(e[1]=t=>a.settings.randomImageAPI.enabled=t),disabled:a.settings.randomImageAPI.fixed},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(c,{prop:"randomImageAPI.allowedDir"},{label:(0,s.k6)(()=>[e[15]||(e[15]=(0,s.Lk)("span",null,"目录",-1)),(0,s.bF)(l,{content:"1. 开放随机图权限的目录,默认为根目录,多个目录用逗号分隔
2. 目录均采用绝对路径,例如/img/cover,表示该目录及其所有子目录的文件可被随机图API访问",placement:"right","raw-content":""},{default:(0,s.k6)(()=>[(0,s.bF)(r,{icon:"question-circle",style:{"margin-left":"5px",cursor:"pointer"}})]),_:1})]),default:(0,s.k6)(()=>[(0,s.bF)(u,{modelValue:a.settings.randomImageAPI.allowedDir,"onUpdate:modelValue":e[2]||(e[2]=t=>a.settings.randomImageAPI.allowedDir=t),disabled:a.settings.randomImageAPI.fixed},null,8,["modelValue","disabled"])]),_:1})]),_:1},8,["model"]),(0,s.Lk)("h3",zu,[e[16]||(e[16]=(0,s.eW)("访客图库 ",-1)),(0,s.bF)(l,{content:"启用后,访客可通过 /browse 路径浏览指定目录的图片(只读,无法删除/移动)",placement:"right","raw-content":""},{default:(0,s.k6)(()=>[(0,s.bF)(r,{icon:"question-circle",style:{"margin-left":"5px",cursor:"pointer"}})]),_:1})]),(0,s.bF)(d,{model:a.settings.publicBrowse,"label-width":"120px"},{default:(0,s.k6)(()=>[(0,s.bF)(c,{label:"启用"},{default:(0,s.k6)(()=>[(0,s.bF)(h,{modelValue:a.settings.publicBrowse.enabled,"onUpdate:modelValue":e[3]||(e[3]=t=>a.settings.publicBrowse.enabled=t),disabled:a.settings.publicBrowse.fixed},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(c,{prop:"publicBrowse.allowedDir"},{label:(0,s.k6)(()=>[e[18]||(e[18]=(0,s.Lk)("span",null,"开放目录",-1)),(0,s.bF)(l,{placement:"right","raw-content":""},{content:(0,s.k6)(()=>[...e[17]||(e[17]=[(0,s.Lk)("div",{style:{"max-width":"320px","line-height":"1.6"}},[(0,s.Lk)("p",{style:{margin:"0 0 8px 0"}},[(0,s.Lk)("b",null,"允许公开浏览的目录,多个目录用逗号分隔")]),(0,s.Lk)("p",{style:{margin:"0 0 8px 0"}},"示例:wallpaper,photos,album"),(0,s.Lk)("p",{style:{margin:"0 0 8px 0",color:"#909399"}},"支持子目录:2026/lucky,2026/rich"),(0,s.Lk)("p",{style:{margin:"0",color:"#67c23a"}},"访问链接:https://你的域名/browse/2026/lucky")],-1)])]),default:(0,s.k6)(()=>[(0,s.bF)(r,{icon:"question-circle",style:{"margin-left":"5px",cursor:"pointer"}})]),_:1})]),default:(0,s.k6)(()=>[(0,s.bF)(u,{modelValue:a.settings.publicBrowse.allowedDir,"onUpdate:modelValue":e[4]||(e[4]=t=>a.settings.publicBrowse.allowedDir=t),disabled:a.settings.publicBrowse.fixed,placeholder:"wallpaper,photos,album"},null,8,["modelValue","disabled"])]),_:1})]),_:1},8,["model"]),(0,s.Lk)("h3",Nu,[e[19]||(e[19]=(0,s.eW)("CloudFlare API Token ",-1)),(0,s.bF)(l,{content:"设置后可以使后端拉黑、删除等操作不受CDN缓存限制
建议设置,设置方式请查阅文档",placement:"right","raw-content":""},{default:(0,s.k6)(()=>[(0,s.bF)(r,{icon:"question-circle",style:{"margin-left":"5px",cursor:"pointer"}})]),_:1})]),(0,s.bF)(d,{model:a.settings.cloudflareApiToken,"label-width":"120px"},{default:(0,s.k6)(()=>[(0,s.bF)(c,{label:"区域ID"},{default:(0,s.k6)(()=>[(0,s.bF)(u,{modelValue:a.settings.cloudflareApiToken.CF_ZONE_ID,"onUpdate:modelValue":e[5]||(e[5]=t=>a.settings.cloudflareApiToken.CF_ZONE_ID=t),disabled:a.settings.cloudflareApiToken.fixed},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(c,{label:"账户邮箱"},{default:(0,s.k6)(()=>[(0,s.bF)(u,{modelValue:a.settings.cloudflareApiToken.CF_EMAIL,"onUpdate:modelValue":e[6]||(e[6]=t=>a.settings.cloudflareApiToken.CF_EMAIL=t),disabled:a.settings.cloudflareApiToken.fixed},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(c,{label:"API Key"},{default:(0,s.k6)(()=>[(0,s.bF)(u,{modelValue:a.settings.cloudflareApiToken.CF_API_KEY,"onUpdate:modelValue":e[7]||(e[7]=t=>a.settings.cloudflareApiToken.CF_API_KEY=t),disabled:a.settings.cloudflareApiToken.fixed,type:"password","show-password":"",autocomplete:"new-password"},null,8,["modelValue","disabled"])]),_:1})]),_:1},8,["model"]),(0,s.Lk)("h3",Uu,[e[20]||(e[20]=(0,s.eW)("WebDAV ",-1)),(0,s.bF)(l,{content:"启用后,可以通过WebDAV协议访问和管理图片",placement:"right","raw-content":""},{default:(0,s.k6)(()=>[(0,s.bF)(r,{icon:"question-circle",style:{"margin-left":"5px",cursor:"pointer"}})]),_:1})]),(0,s.bF)(d,{model:a.settings.webDAV,"label-width":"120px"},{default:(0,s.k6)(()=>[(0,s.bF)(c,{label:"启用"},{default:(0,s.k6)(()=>[(0,s.bF)(h,{modelValue:a.settings.webDAV.enabled,"onUpdate:modelValue":e[8]||(e[8]=t=>a.settings.webDAV.enabled=t),disabled:a.settings.webDAV.fixed},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(c,{label:"用户名"},{default:(0,s.k6)(()=>[(0,s.bF)(u,{modelValue:a.settings.webDAV.username,"onUpdate:modelValue":e[9]||(e[9]=t=>a.settings.webDAV.username=t),disabled:a.settings.webDAV.fixed},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(c,{label:"密码"},{default:(0,s.k6)(()=>[(0,s.bF)(u,{modelValue:a.settings.webDAV.password,"onUpdate:modelValue":e[10]||(e[10]=t=>a.settings.webDAV.password=t),disabled:a.settings.webDAV.fixed,type:"password","show-password":"",autocomplete:"new-password"},null,8,["modelValue","disabled"])]),_:1}),(0,s.bF)(c,{label:"上传渠道"},{default:(0,s.k6)(()=>[(0,s.bF)(f,{modelValue:a.settings.webDAV.uploadChannel,"onUpdate:modelValue":e[11]||(e[11]=t=>a.settings.webDAV.uploadChannel=t),disabled:a.settings.webDAV.fixed,placeholder:"默认渠道",clearable:""},{default:(0,s.k6)(()=>[(0,s.bF)(g,{label:"Telegram",value:"telegram"}),(0,s.bF)(g,{label:"Cloudflare R2",value:"cfr2"}),(0,s.bF)(g,{label:"S3",value:"s3"}),(0,s.bF)(g,{label:"Discord",value:"discord"}),(0,s.bF)(g,{label:"HuggingFace",value:"huggingface"})]),_:1},8,["modelValue","disabled"])]),_:1}),a.settings.webDAV.uploadChannel&&o.webdavChannelList.length>1?((0,s.uX)(),(0,s.Wv)(c,{key:0,label:"指定渠道名"},{default:(0,s.k6)(()=>[(0,s.bF)(f,{modelValue:a.settings.webDAV.channelName,"onUpdate:modelValue":e[12]||(e[12]=t=>a.settings.webDAV.channelName=t),disabled:a.settings.webDAV.fixed,placeholder:"自动选择",clearable:""},{default:(0,s.k6)(()=>[((0,s.uX)(!0),(0,s.CE)(s.FK,null,(0,s.pI)(o.webdavChannelList,t=>((0,s.uX)(),(0,s.Wv)(g,{key:t.name,label:t.name,value:t.name},null,8,["label","value"]))),128))]),_:1},8,["modelValue","disabled"])]),_:1})):(0,s.Q3)("",!0)]),_:1},8,["model"])]),(0,s.bF)(m,{show:!a.loading,onClick:o.saveSettings},null,8,["show","onClick"])])),[[b,a.loading]])}var ju={components:{FloatingSaveButton:nu},data(){return{settings:{telemetry:{},randomImageAPI:{},cloudflareApiToken:{},webDAV:{},publicBrowse:{}},availableChannels:{},loading:!0}},computed:{webdavChannelList(){const t=this.settings.webDAV?.uploadChannel;return t&&this.availableChannels[t]||[]}},watch:{"settings.webDAV.uploadChannel"(){this.settings.webDAV&&(this.settings.webDAV.channelName="")}},methods:{saveSettings(){(0,Ut.A)("/api/manage/sysConfig/others",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(this.settings)}).then(()=>this.$message.success("设置已保存"))},async fetchAvailableChannels(){try{const t=await(0,Ut.A)("/api/channels");t.ok&&(this.availableChannels=await t.json())}catch(t){console.error("Failed to fetch available channels:",t)}}},mounted(){this.loading=!0,(0,Ut.A)("/api/manage/sysConfig/others").then(t=>t.json()).then(t=>{this.settings=t}).finally(()=>{this.loading=!1}),this.fetchAvailableChannels()}};const Hu=(0,c.A)(ju,[["render",$u],["__scopeId","data-v-0cedb60a"]]);var Xu=Hu,qu={name:"SystemConfig",data(){return{activeIndex:"status",isSidebarCollapse:!1}},watch:{"$route.hash":{immediate:!0,handler(t){this.activeIndex=t.replace("#",""),window.scrollTo(0,0)}},activeIndex(t){const e=`#${t}`;this.$router.push({hash:e})}},components:{DashboardTabs:f.A,SysConfigTabs:u,SysCogStatus:Gc,SysCogUpload:Jd,SysCogSecurity:Au,SysCogPage:Vu,SysCogOthers:Xu},computed:{disableTooltip(){return window.innerWidth<768},currentComponent(){const t=this.$route.hash.replace("#","");switch(t){case"status":return Gc;case"upload":return Jd;case"security":return Au;case"page":return Vu;case"others":return Xu;default:return Gc}}},methods:{handleLogout(){this.$store.commit("setCredentials",null),this.$router.push("/adminLogin")},setDefaultHash(){const t="#status";window.location.hash=t,this.activeIndex=t.replace("#","")}},mounted(){window.location.hash||this.setDefaultHash()}};const Ku=(0,c.A)(qu,[["render",y],["__scopeId","data-v-4cdf1dc2"]]);var Yu=Ku},9187:function(t,e,i){i(5331),i(8736)}}]); +//# sourceMappingURL=407.f0b5dee5.js.map \ No newline at end of file diff --git a/js/407.f0b5dee5.js.gz b/js/407.f0b5dee5.js.gz new file mode 100644 index 0000000..8d0a2f1 Binary files /dev/null and b/js/407.f0b5dee5.js.gz differ diff --git a/js/226.478c43ad.js.map b/js/407.f0b5dee5.js.map similarity index 99% rename from js/226.478c43ad.js.map rename to js/407.f0b5dee5.js.map index e8eedec..d2e587c 100644 --- a/js/226.478c43ad.js.map +++ b/js/407.f0b5dee5.js.map @@ -1 +1 @@ -{"version":3,"file":"js/226.478c43ad.js","mappings":"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","sources":["webpack://sanyue_imghub/./node_modules/@babel/runtime/helpers/esm/typeof.js","webpack://sanyue_imghub/./node_modules/@babel/runtime/helpers/esm/toPrimitive.js","webpack://sanyue_imghub/./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js","webpack://sanyue_imghub/./node_modules/@babel/runtime/helpers/esm/defineProperty.js","webpack://sanyue_imghub/./src/components/SysConfigTabs.vue?8637","webpack://sanyue_imghub/./src/components/SysConfigTabs.vue","webpack://sanyue_imghub/./src/components/SysConfigTabs.vue?909a","webpack://sanyue_imghub/./src/views/SystemConfig.vue?5740","webpack://sanyue_imghub/./src/components/SysCogStatus.vue?8436","webpack://sanyue_imghub/./node_modules/@kurkle/color/dist/color.esm.js","webpack://sanyue_imghub/../../src/helpers/helpers.core.ts","webpack://sanyue_imghub/../../src/helpers/helpers.math.ts","webpack://sanyue_imghub/../../src/helpers/helpers.collection.ts","webpack://sanyue_imghub/../../src/helpers/helpers.extras.ts","webpack://sanyue_imghub/../../src/helpers/helpers.easing.ts","webpack://sanyue_imghub/../../src/helpers/helpers.color.ts","webpack://sanyue_imghub/../../src/core/core.animations.defaults.js","webpack://sanyue_imghub/../../src/core/core.layouts.defaults.js","webpack://sanyue_imghub/../../src/helpers/helpers.intl.ts","webpack://sanyue_imghub/../../src/core/core.ticks.js","webpack://sanyue_imghub/../../src/core/core.scale.defaults.js","webpack://sanyue_imghub/../../src/core/core.defaults.js","webpack://sanyue_imghub/../../src/helpers/helpers.canvas.ts","webpack://sanyue_imghub/../../src/helpers/helpers.options.ts","webpack://sanyue_imghub/../../src/helpers/helpers.config.ts","webpack://sanyue_imghub/../../src/helpers/helpers.curve.ts","webpack://sanyue_imghub/../../src/helpers/helpers.dom.ts","webpack://sanyue_imghub/../../src/helpers/helpers.interpolation.ts","webpack://sanyue_imghub/../../src/helpers/helpers.rtl.ts","webpack://sanyue_imghub/../../src/helpers/helpers.segment.js","webpack://sanyue_imghub/../../src/helpers/helpers.dataset.ts","webpack://sanyue_imghub/../src/core/core.animator.js","webpack://sanyue_imghub/../src/core/core.animation.js","webpack://sanyue_imghub/../src/core/core.animations.js","webpack://sanyue_imghub/../src/core/core.datasetController.js","webpack://sanyue_imghub/../src/controllers/controller.bar.js","webpack://sanyue_imghub/../src/controllers/controller.bubble.js","webpack://sanyue_imghub/../src/controllers/controller.doughnut.js","webpack://sanyue_imghub/../src/controllers/controller.line.js","webpack://sanyue_imghub/../src/controllers/controller.polarArea.js","webpack://sanyue_imghub/../src/controllers/controller.pie.js","webpack://sanyue_imghub/../src/controllers/controller.radar.js","webpack://sanyue_imghub/../src/controllers/controller.scatter.js","webpack://sanyue_imghub/../src/core/core.adapters.ts","webpack://sanyue_imghub/../src/core/core.interaction.js","webpack://sanyue_imghub/../src/core/core.layouts.js","webpack://sanyue_imghub/../src/platform/platform.base.js","webpack://sanyue_imghub/../src/platform/platform.basic.js","webpack://sanyue_imghub/../src/platform/platform.dom.js","webpack://sanyue_imghub/../src/platform/index.js","webpack://sanyue_imghub/../src/core/core.element.ts","webpack://sanyue_imghub/../src/core/core.scale.autoskip.js","webpack://sanyue_imghub/../src/core/core.scale.js","webpack://sanyue_imghub/../src/core/core.typedRegistry.js","webpack://sanyue_imghub/../src/core/core.registry.js","webpack://sanyue_imghub/../src/core/core.plugins.js","webpack://sanyue_imghub/../src/core/core.config.js","webpack://sanyue_imghub/../src/core/core.controller.js","webpack://sanyue_imghub/../src/elements/element.arc.ts","webpack://sanyue_imghub/../src/elements/element.line.js","webpack://sanyue_imghub/../src/elements/element.point.ts","webpack://sanyue_imghub/../src/elements/element.bar.js","webpack://sanyue_imghub/../src/plugins/plugin.legend.js","webpack://sanyue_imghub/../src/plugins/plugin.subtitle.js","webpack://sanyue_imghub/../src/plugins/plugin.tooltip.js","webpack://sanyue_imghub/../src/scales/scale.category.js","webpack://sanyue_imghub/../src/scales/scale.linearbase.js","webpack://sanyue_imghub/../src/scales/scale.linear.js","webpack://sanyue_imghub/../src/scales/scale.logarithmic.js","webpack://sanyue_imghub/../src/scales/scale.radialLinear.js","webpack://sanyue_imghub/../src/scales/scale.time.js","webpack://sanyue_imghub/../src/scales/scale.timeseries.js","webpack://sanyue_imghub/../src/props.ts","webpack://sanyue_imghub/../src/utils.ts","webpack://sanyue_imghub/../src/chart.ts","webpack://sanyue_imghub/../src/typedCharts.ts","webpack://sanyue_imghub/./src/utils/batchProcessor.js","webpack://sanyue_imghub/./src/utils/indexRebuilder.js","webpack://sanyue_imghub/./src/utils/backupGenerator.js","webpack://sanyue_imghub/./src/utils/restoreProcessor.js","webpack://sanyue_imghub/./src/components/SysCogStatus.vue","webpack://sanyue_imghub/./src/components/SysCogStatus.vue?535e","webpack://sanyue_imghub/./src/components/CustomSelect.vue?b677","webpack://sanyue_imghub/./src/components/CustomSelect.vue","webpack://sanyue_imghub/./src/components/CustomSelect.vue?9326","webpack://sanyue_imghub/./src/components/SysCogUpload.vue?2dac","webpack://sanyue_imghub/./src/components/SysCogUpload.vue","webpack://sanyue_imghub/./src/components/SysCogUpload.vue?5e68","webpack://sanyue_imghub/./src/components/FloatingSaveButton.vue?ac4d","webpack://sanyue_imghub/./src/components/FloatingSaveButton.vue","webpack://sanyue_imghub/./src/components/FloatingSaveButton.vue?45e6","webpack://sanyue_imghub/./src/components/SysCogSecurity.vue?279c","webpack://sanyue_imghub/./src/components/SysCogSecurity.vue","webpack://sanyue_imghub/./src/components/SysCogSecurity.vue?e29e","webpack://sanyue_imghub/./src/components/SysCogPage.vue?7031","webpack://sanyue_imghub/./src/components/SysCogPage.vue","webpack://sanyue_imghub/./src/components/SysCogPage.vue?c23d","webpack://sanyue_imghub/./src/components/SysCogOthers.vue?3dca","webpack://sanyue_imghub/./src/components/SysCogOthers.vue","webpack://sanyue_imghub/./src/components/SysCogOthers.vue?ad31","webpack://sanyue_imghub/./src/views/SystemConfig.vue","webpack://sanyue_imghub/./src/views/SystemConfig.vue?d269"],"sourcesContent":["function _typeof(o) {\n \"@babel/helpers - typeof\";\n\n return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (o) {\n return typeof o;\n } : function (o) {\n return o && \"function\" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? \"symbol\" : typeof o;\n }, _typeof(o);\n}\nexport { _typeof as default };","import _typeof from \"./typeof.js\";\nfunction toPrimitive(t, r) {\n if (\"object\" != _typeof(t) || !t) return t;\n var e = t[Symbol.toPrimitive];\n if (void 0 !== e) {\n var i = e.call(t, r || \"default\");\n if (\"object\" != _typeof(i)) return i;\n throw new TypeError(\"@@toPrimitive must return a primitive value.\");\n }\n return (\"string\" === r ? String : Number)(t);\n}\nexport { toPrimitive as default };","import _typeof from \"./typeof.js\";\nimport toPrimitive from \"./toPrimitive.js\";\nfunction toPropertyKey(t) {\n var i = toPrimitive(t, \"string\");\n return \"symbol\" == _typeof(i) ? i : i + \"\";\n}\nexport { toPropertyKey as default };","import toPropertyKey from \"./toPropertyKey.js\";\nfunction _defineProperty(e, r, t) {\n return (r = toPropertyKey(r)) in e ? Object.defineProperty(e, r, {\n value: t,\n enumerable: !0,\n configurable: !0,\n writable: !0\n }) : e[r] = t, e;\n}\nexport { _defineProperty as default };","import { renderList as _renderList, Fragment as _Fragment, openBlock as _openBlock, createElementBlock as _createElementBlock, resolveComponent as _resolveComponent, createVNode as _createVNode, toDisplayString as _toDisplayString, createElementVNode as _createElementVNode, normalizeClass as _normalizeClass } from \"vue\";\nconst _hoisted_1 = {\n class: \"menu-list\"\n};\nconst _hoisted_2 = [\"onClick\"];\nconst _hoisted_3 = {\n class: \"menu-text\"\n};\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n return _openBlock(), _createElementBlock(\"div\", {\n class: _normalizeClass([\"sidebar-container\", {\n 'is-collapsed': $props.isCollapse\n }])\n }, [_createElementVNode(\"div\", _hoisted_1, [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($data.menuItems, item => {\n return _openBlock(), _createElementBlock(\"div\", {\n key: item.index,\n class: _normalizeClass([\"menu-item\", {\n 'is-active': $props.activeIndex === item.index\n }]),\n onClick: $event => $options.handleSelect(item.index)\n }, [_createVNode(_component_font_awesome_icon, {\n icon: item.icon,\n class: \"menu-icon\"\n }, null, 8, [\"icon\"]), _createElementVNode(\"span\", _hoisted_3, _toDisplayString(item.title), 1)], 10, _hoisted_2);\n }), 128))]), _createElementVNode(\"div\", {\n class: \"toggle-button\",\n onClick: _cache[0] || (_cache[0] = (...args) => $options.toggleCollapse && $options.toggleCollapse(...args))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: $props.isCollapse ? 'angle-double-right' : 'angle-double-left'\n }, null, 8, [\"icon\"])])], 2);\n}","export default {\n name: 'SysConfigTabs',\n props: {\n activeIndex: {\n type: String,\n default: 'status'\n },\n isCollapse: {\n type: Boolean,\n default: false\n }\n },\n data() {\n return {\n menuItems: [{\n index: 'status',\n icon: 'chart-bar',\n title: '系统状态'\n }, {\n index: 'upload',\n icon: 'cloud-upload',\n title: '上传设置'\n }, {\n index: 'security',\n icon: 'shield',\n title: '安全设置'\n }, {\n index: 'page',\n icon: 'pager',\n title: '网页设置'\n }, {\n index: 'others',\n icon: 'cog',\n title: '其他设置'\n }]\n };\n },\n methods: {\n toggleCollapse() {\n this.$emit('update:isCollapse', !this.isCollapse);\n },\n checkMobile() {\n const isMobile = window.innerWidth <= 768;\n this.$emit('update:isCollapse', isMobile);\n },\n handleSelect(index) {\n this.$emit('update:activeIndex', index);\n }\n },\n mounted() {\n this.checkMobile();\n window.addEventListener('resize', this.checkMobile);\n },\n beforeDestroy() {\n window.removeEventListener('resize', this.checkMobile);\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./SysConfigTabs.vue?vue&type=template&id=5bb00686&scoped=true\"\nimport script from \"./SysConfigTabs.vue?vue&type=script&lang=js\"\nexport * from \"./SysConfigTabs.vue?vue&type=script&lang=js\"\n\nimport \"./SysConfigTabs.vue?vue&type=style&index=0&id=5bb00686&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-5bb00686\"]])\n\nexport default __exports__","import { resolveComponent as _resolveComponent, createVNode as _createVNode, withCtx as _withCtx, createElementVNode as _createElementVNode, resolveDynamicComponent as _resolveDynamicComponent, normalizeClass as _normalizeClass, openBlock as _openBlock, createBlock as _createBlock, createElementBlock as _createElementBlock } from \"vue\";\nconst _hoisted_1 = {\n class: \"container\"\n};\nconst _hoisted_2 = {\n class: \"header-content\"\n};\nconst _hoisted_3 = {\n class: \"header-action\"\n};\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_DashboardTabs = _resolveComponent(\"DashboardTabs\");\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n const _component_el_tooltip = _resolveComponent(\"el-tooltip\");\n const _component_el_header = _resolveComponent(\"el-header\");\n const _component_SysConfigTabs = _resolveComponent(\"SysConfigTabs\");\n return _openBlock(), _createElementBlock(\"div\", _hoisted_1, [_createVNode(_component_el_header, null, {\n default: _withCtx(() => [_createElementVNode(\"div\", _hoisted_2, [_createVNode(_component_DashboardTabs, {\n activeTab: \"systemConfig\"\n }), _createElementVNode(\"div\", _hoisted_3, [_createVNode(_component_el_tooltip, {\n disabled: $options.disableTooltip,\n content: \"退出登录\",\n placement: \"bottom\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"sign-out-alt\",\n class: \"header-icon\",\n onClick: $options.handleLogout\n }, null, 8, [\"onClick\"])]),\n _: 1\n }, 8, [\"disabled\"])])])]),\n _: 1\n }), _createVNode(_component_SysConfigTabs, {\n activeIndex: $data.activeIndex,\n \"onUpdate:activeIndex\": _cache[0] || (_cache[0] = $event => $data.activeIndex = $event),\n isCollapse: $data.isSidebarCollapse,\n \"onUpdate:isCollapse\": _cache[1] || (_cache[1] = $event => $data.isSidebarCollapse = $event)\n }, null, 8, [\"activeIndex\", \"isCollapse\"]), (_openBlock(), _createBlock(_resolveDynamicComponent($options.currentComponent), {\n class: _normalizeClass(['main-container', {\n 'collapsed': $data.isSidebarCollapse\n }])\n }, null, 8, [\"class\"]))]);\n}","import { resolveComponent as _resolveComponent, createVNode as _createVNode, createElementVNode as _createElementVNode, toDisplayString as _toDisplayString, openBlock as _openBlock, createElementBlock as _createElementBlock, createCommentVNode as _createCommentVNode, renderList as _renderList, Fragment as _Fragment, normalizeStyle as _normalizeStyle, createTextVNode as _createTextVNode, withCtx as _withCtx, createBlock as _createBlock, resolveDirective as _resolveDirective, withDirectives as _withDirectives } from \"vue\";\nconst _hoisted_1 = {\n class: \"status-panel\"\n};\nconst _hoisted_2 = {\n class: \"overview-cards\"\n};\nconst _hoisted_3 = {\n class: \"card-icon\"\n};\nconst _hoisted_4 = {\n class: \"card-content\"\n};\nconst _hoisted_5 = {\n class: \"card-value\"\n};\nconst _hoisted_6 = {\n class: \"overview-card index-status\"\n};\nconst _hoisted_7 = {\n class: \"card-icon\"\n};\nconst _hoisted_8 = {\n class: \"card-content\"\n};\nconst _hoisted_9 = {\n class: \"card-value\"\n};\nconst _hoisted_10 = {\n class: \"card-subtitle\"\n};\nconst _hoisted_11 = {\n class: \"card-icon\"\n};\nconst _hoisted_12 = {\n class: \"card-content\"\n};\nconst _hoisted_13 = {\n class: \"card-value\"\n};\nconst _hoisted_14 = {\n class: \"charts-section\"\n};\nconst _hoisted_15 = {\n class: \"chart-card\"\n};\nconst _hoisted_16 = {\n class: \"chart-header\"\n};\nconst _hoisted_17 = {\n class: \"chart-content\"\n};\nconst _hoisted_18 = {\n key: 0,\n class: \"empty-state\"\n};\nconst _hoisted_19 = {\n key: 1,\n class: \"pie-chart-container\"\n};\nconst _hoisted_20 = {\n class: \"pie-chart-wrapper\"\n};\nconst _hoisted_21 = {\n class: \"chart-center-text\"\n};\nconst _hoisted_22 = {\n class: \"center-value\"\n};\nconst _hoisted_23 = {\n class: \"chart-legend\"\n};\nconst _hoisted_24 = {\n class: \"legend-label\"\n};\nconst _hoisted_25 = {\n class: \"legend-value\"\n};\nconst _hoisted_26 = {\n class: \"legend-percent\"\n};\nconst _hoisted_27 = {\n class: \"chart-card\"\n};\nconst _hoisted_28 = {\n class: \"chart-header\"\n};\nconst _hoisted_29 = {\n class: \"chart-content\"\n};\nconst _hoisted_30 = {\n key: 0,\n class: \"empty-state\"\n};\nconst _hoisted_31 = {\n key: 1,\n class: \"pie-chart-container\"\n};\nconst _hoisted_32 = {\n class: \"pie-chart-wrapper\"\n};\nconst _hoisted_33 = {\n class: \"chart-center-text\"\n};\nconst _hoisted_34 = {\n class: \"center-value\"\n};\nconst _hoisted_35 = {\n class: \"chart-legend\"\n};\nconst _hoisted_36 = {\n class: \"legend-label\"\n};\nconst _hoisted_37 = {\n class: \"legend-value\"\n};\nconst _hoisted_38 = {\n class: \"legend-percent\"\n};\nconst _hoisted_39 = {\n class: \"actions-section\"\n};\nconst _hoisted_40 = {\n class: \"action-card\"\n};\nconst _hoisted_41 = {\n class: \"action-header\"\n};\nconst _hoisted_42 = {\n class: \"action-content\"\n};\nconst _hoisted_43 = {\n key: 0,\n class: \"progress-container\"\n};\nconst _hoisted_44 = {\n class: \"progress-header\"\n};\nconst _hoisted_45 = {\n class: \"progress-phase\"\n};\nconst _hoisted_46 = {\n class: \"progress-percentage\"\n};\nconst _hoisted_47 = {\n class: \"progress-details\"\n};\nconst _hoisted_48 = {\n key: 0,\n class: \"progress-count\"\n};\nconst _hoisted_49 = {\n key: 1,\n class: \"progress-time\"\n};\nconst _hoisted_50 = {\n key: 0,\n class: \"progress-message\"\n};\nconst _hoisted_51 = {\n key: 1,\n class: \"error-container\"\n};\nconst _hoisted_52 = {\n class: \"error-icon\"\n};\nconst _hoisted_53 = {\n class: \"error-content\"\n};\nconst _hoisted_54 = {\n class: \"error-message\"\n};\nconst _hoisted_55 = {\n key: 0,\n class: \"error-suggestion\"\n};\nconst _hoisted_56 = {\n class: \"error-actions\"\n};\nconst _hoisted_57 = {\n key: 2,\n class: \"action-buttons\"\n};\nconst _hoisted_58 = {\n class: \"restore-section\"\n};\nconst _hoisted_59 = {\n key: 0,\n class: \"file-info-section\"\n};\nconst _hoisted_60 = [\"src\"];\nconst _hoisted_61 = {\n key: 2,\n class: \"card-bg-fallback\"\n};\nconst _hoisted_62 = {\n class: \"file-card-header\"\n};\nconst _hoisted_63 = {\n class: \"info-card-footer\"\n};\nconst _hoisted_64 = {\n class: \"file-name\"\n};\nconst _hoisted_65 = {\n class: \"file-meta\"\n};\nconst _hoisted_66 = [\"src\"];\nconst _hoisted_67 = {\n key: 2,\n class: \"card-bg-fallback\"\n};\nconst _hoisted_68 = {\n class: \"file-card-header warning\"\n};\nconst _hoisted_69 = {\n class: \"info-card-footer\"\n};\nconst _hoisted_70 = {\n class: \"file-name\"\n};\nconst _hoisted_71 = {\n class: \"file-meta\"\n};\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n const _component_Doughnut = _resolveComponent(\"Doughnut\");\n const _component_el_progress = _resolveComponent(\"el-progress\");\n const _component_el_button = _resolveComponent(\"el-button\");\n const _component_el_tooltip = _resolveComponent(\"el-tooltip\");\n const _component_el_image = _resolveComponent(\"el-image\");\n const _directive_loading = _resolveDirective(\"loading\");\n return _withDirectives((_openBlock(), _createElementBlock(\"div\", _hoisted_1, [_createElementVNode(\"div\", _hoisted_2, [_createElementVNode(\"div\", {\n class: \"overview-card total-files\",\n onClick: _cache[0] || (_cache[0] = (...args) => $options.fetchIndexInfo && $options.fetchIndexInfo(...args))\n }, [_createElementVNode(\"div\", _hoisted_3, [_createVNode(_component_font_awesome_icon, {\n icon: \"database\"\n })]), _createElementVNode(\"div\", _hoisted_4, [_cache[9] || (_cache[9] = _createElementVNode(\"div\", {\n class: \"card-title\"\n }, \"文件总数\", -1)), _createElementVNode(\"div\", _hoisted_5, _toDisplayString($data.indexInfo.totalFiles?.toLocaleString() || '0'), 1), _cache[10] || (_cache[10] = _createElementVNode(\"div\", {\n class: \"card-subtitle\"\n }, \"点击刷新\", -1))])]), _createElementVNode(\"div\", _hoisted_6, [_createElementVNode(\"div\", _hoisted_7, [_createVNode(_component_font_awesome_icon, {\n icon: \"clock\"\n })]), _createElementVNode(\"div\", _hoisted_8, [_cache[11] || (_cache[11] = _createElementVNode(\"div\", {\n class: \"card-title\"\n }, \"索引更新时间\", -1)), _createElementVNode(\"div\", _hoisted_9, _toDisplayString($options.formatTime($data.indexInfo.lastUpdated)), 1), _createElementVNode(\"div\", _hoisted_10, _toDisplayString($options.getTimeAgo($data.indexInfo.lastUpdated)), 1)])]), _createElementVNode(\"div\", {\n class: \"overview-card system-version\",\n onClick: _cache[1] || (_cache[1] = (...args) => $options.openReleases && $options.openReleases(...args))\n }, [_createElementVNode(\"div\", _hoisted_11, [_createVNode(_component_font_awesome_icon, {\n icon: \"code-branch\"\n })]), _createElementVNode(\"div\", _hoisted_12, [_cache[12] || (_cache[12] = _createElementVNode(\"div\", {\n class: \"card-title\"\n }, \"系统版本\", -1)), _createElementVNode(\"div\", _hoisted_13, \"v\" + _toDisplayString($data.version), 1), _cache[13] || (_cache[13] = _createElementVNode(\"div\", {\n class: \"card-subtitle\"\n }, \"点击查看更新日志\", -1))])])]), _createElementVNode(\"div\", _hoisted_14, [_createElementVNode(\"div\", _hoisted_15, [_createElementVNode(\"div\", _hoisted_16, [_createVNode(_component_font_awesome_icon, {\n icon: \"share-alt\"\n }), _cache[14] || (_cache[14] = _createElementVNode(\"span\", null, \"上传渠道分布\", -1))]), _createElementVNode(\"div\", _hoisted_17, [Object.keys($data.indexInfo.channelStats || {}).length === 0 ? (_openBlock(), _createElementBlock(\"div\", _hoisted_18, [_createVNode(_component_font_awesome_icon, {\n icon: \"inbox\"\n }), _cache[15] || (_cache[15] = _createElementVNode(\"span\", null, \"暂无数据\", -1))])) : (_openBlock(), _createElementBlock(\"div\", _hoisted_19, [_createElementVNode(\"div\", _hoisted_20, [_createVNode(_component_Doughnut, {\n data: $options.channelChartData,\n options: $options.chartOptions\n }, null, 8, [\"data\", \"options\"]), _createElementVNode(\"div\", _hoisted_21, [_createElementVNode(\"div\", _hoisted_22, _toDisplayString($data.indexInfo.totalFiles?.toLocaleString() || '0'), 1), _cache[16] || (_cache[16] = _createElementVNode(\"div\", {\n class: \"center-label\"\n }, \"文件总数\", -1))])]), _createElementVNode(\"div\", _hoisted_23, [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($data.indexInfo.channelStats, (count, channel, index) => {\n return _openBlock(), _createElementBlock(\"div\", {\n key: channel,\n class: \"legend-item\"\n }, [_createElementVNode(\"span\", {\n class: \"legend-color\",\n style: _normalizeStyle({\n background: $options.getChartColor(index)\n })\n }, null, 4), _createElementVNode(\"span\", _hoisted_24, _toDisplayString(channel), 1), _createElementVNode(\"span\", _hoisted_25, _toDisplayString(count.toLocaleString()), 1), _createElementVNode(\"span\", _hoisted_26, _toDisplayString($options.getPercentage(count, $data.indexInfo.totalFiles)) + \"%\", 1)]);\n }), 128))])]))])]), _createElementVNode(\"div\", _hoisted_27, [_createElementVNode(\"div\", _hoisted_28, [_createVNode(_component_font_awesome_icon, {\n icon: \"file-alt\"\n }), _cache[17] || (_cache[17] = _createElementVNode(\"span\", null, \"文件状态分布\", -1))]), _createElementVNode(\"div\", _hoisted_29, [Object.keys($data.indexInfo.typeStats || {}).length === 0 ? (_openBlock(), _createElementBlock(\"div\", _hoisted_30, [_createVNode(_component_font_awesome_icon, {\n icon: \"inbox\"\n }), _cache[18] || (_cache[18] = _createElementVNode(\"span\", null, \"暂无数据\", -1))])) : (_openBlock(), _createElementBlock(\"div\", _hoisted_31, [_createElementVNode(\"div\", _hoisted_32, [_createVNode(_component_Doughnut, {\n data: $options.typeChartData,\n options: $options.chartOptions\n }, null, 8, [\"data\", \"options\"]), _createElementVNode(\"div\", _hoisted_33, [_createElementVNode(\"div\", _hoisted_34, _toDisplayString(Object.keys($data.indexInfo.typeStats).length), 1), _cache[19] || (_cache[19] = _createElementVNode(\"div\", {\n class: \"center-label\"\n }, \"状态类型\", -1))])]), _createElementVNode(\"div\", _hoisted_35, [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($options.aggregatedTypeStats, (count, status, index) => {\n return _openBlock(), _createElementBlock(\"div\", {\n key: status,\n class: \"legend-item\"\n }, [_createElementVNode(\"span\", {\n class: \"legend-color\",\n style: _normalizeStyle({\n background: $options.getTypeChartColor(index)\n })\n }, null, 4), _createElementVNode(\"span\", _hoisted_36, _toDisplayString(status), 1), _createElementVNode(\"span\", _hoisted_37, _toDisplayString(count.toLocaleString()), 1), _createElementVNode(\"span\", _hoisted_38, _toDisplayString($options.getPercentage(count, $data.indexInfo.totalFiles)) + \"%\", 1)]);\n }), 128))])]))])])]), _createElementVNode(\"div\", _hoisted_39, [_createElementVNode(\"div\", _hoisted_40, [_createElementVNode(\"div\", _hoisted_41, [_createVNode(_component_font_awesome_icon, {\n icon: \"tools\"\n }), _cache[20] || (_cache[20] = _createElementVNode(\"span\", null, \"系统维护\", -1))]), _createElementVNode(\"div\", _hoisted_42, [$data.isProcessing ? (_openBlock(), _createElementBlock(\"div\", _hoisted_43, [_createElementVNode(\"div\", _hoisted_44, [_createElementVNode(\"span\", _hoisted_45, _toDisplayString($options.phaseDescription), 1), _createElementVNode(\"span\", _hoisted_46, _toDisplayString(Math.round($data.processingProgress.percentage)) + \"%\", 1)]), _createVNode(_component_el_progress, {\n percentage: $data.processingProgress.percentage,\n \"stroke-width\": 12,\n \"show-text\": false,\n class: \"progress-bar\"\n }, null, 8, [\"percentage\"]), _createElementVNode(\"div\", _hoisted_47, [$data.processingProgress.current > 0 ? (_openBlock(), _createElementBlock(\"span\", _hoisted_48, [_createVNode(_component_font_awesome_icon, {\n icon: \"file-alt\"\n }), _createTextVNode(\" \" + _toDisplayString($data.processingProgress.current.toLocaleString()) + \" \", 1), $data.processingProgress.total > 0 ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 0\n }, [_createTextVNode(\" / \" + _toDisplayString($data.processingProgress.total.toLocaleString()), 1)], 64)) : _createCommentVNode(\"\", true), _cache[21] || (_cache[21] = _createTextVNode(\" 条记录 \", -1))])) : _createCommentVNode(\"\", true), $options.estimatedTimeRemaining ? (_openBlock(), _createElementBlock(\"span\", _hoisted_49, [_createVNode(_component_font_awesome_icon, {\n icon: \"clock\"\n }), _createTextVNode(\" \" + _toDisplayString($options.estimatedTimeRemaining), 1)])) : _createCommentVNode(\"\", true)]), $data.processingProgress.message ? (_openBlock(), _createElementBlock(\"div\", _hoisted_50, _toDisplayString($data.processingProgress.message), 1)) : _createCommentVNode(\"\", true), _createVNode(_component_el_button, {\n type: \"danger\",\n plain: \"\",\n size: \"small\",\n onClick: $options.cancelOperation,\n class: \"cancel-btn\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"times\"\n }), _cache[22] || (_cache[22] = _createTextVNode(\" 取消操作 \", -1))]),\n _: 1\n }, 8, [\"onClick\"])])) : $data.processingError ? (_openBlock(), _createElementBlock(\"div\", _hoisted_51, [_createElementVNode(\"div\", _hoisted_52, [_createVNode(_component_font_awesome_icon, {\n icon: \"exclamation-triangle\"\n })]), _createElementVNode(\"div\", _hoisted_53, [_createElementVNode(\"div\", _hoisted_54, _toDisplayString($data.processingError.message), 1), $data.processingError.suggestion ? (_openBlock(), _createElementBlock(\"div\", _hoisted_55, _toDisplayString($data.processingError.suggestion), 1)) : _createCommentVNode(\"\", true)]), _createElementVNode(\"div\", _hoisted_56, [$data.processingError.recoverable ? (_openBlock(), _createBlock(_component_el_button, {\n key: 0,\n type: \"primary\",\n size: \"small\",\n onClick: $options.retryOperation\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"redo\"\n }), _cache[23] || (_cache[23] = _createTextVNode(\" 重试 \", -1))]),\n _: 1\n }, 8, [\"onClick\"])) : _createCommentVNode(\"\", true), _createVNode(_component_el_button, {\n type: \"default\",\n size: \"small\",\n onClick: $options.dismissError\n }, {\n default: _withCtx(() => [...(_cache[24] || (_cache[24] = [_createTextVNode(\" 关闭 \", -1)]))]),\n _: 1\n }, 8, [\"onClick\"])])])) : (_openBlock(), _createElementBlock(\"div\", _hoisted_57, [_createVNode(_component_el_tooltip, {\n content: \"重新扫描所有文件并更新索引数据,适用于数据不一致时的修复\",\n placement: \"top\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_button, {\n type: \"primary\",\n loading: $data.rebuilding,\n disabled: $data.isProcessing,\n onClick: $options.rebuildIndex,\n class: \"action-btn rebuild-btn\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"sync-alt\"\n }), _createTextVNode(\" \" + _toDisplayString($data.rebuilding ? '重建中...' : '重建索引'), 1)]),\n _: 1\n }, 8, [\"loading\", \"disabled\", \"onClick\"])]),\n _: 1\n }), _createVNode(_component_el_tooltip, {\n content: \"备份所有文件元数据和系统设置到JSON文件\",\n placement: \"top\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_button, {\n type: \"success\",\n loading: $data.backing,\n disabled: $data.isProcessing,\n onClick: $options.backupData,\n class: \"action-btn backup-btn\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"download\"\n }), _createTextVNode(\" \" + _toDisplayString($data.backing ? '备份中...' : '备份数据'), 1)]),\n _: 1\n }, 8, [\"loading\", \"disabled\", \"onClick\"])]),\n _: 1\n }), _createVNode(_component_el_tooltip, {\n content: \"从备份文件恢复数据,将覆盖现有的文件元数据和系统设置\",\n placement: \"top\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"div\", _hoisted_58, [_createElementVNode(\"input\", {\n type: \"file\",\n ref: \"fileInput\",\n accept: \".json\",\n onChange: _cache[2] || (_cache[2] = (...args) => $options.handleFileSelect && $options.handleFileSelect(...args)),\n style: {\n \"display\": \"none\"\n }\n }, null, 544), _createVNode(_component_el_button, {\n type: \"warning\",\n loading: $data.restoring,\n disabled: $data.isProcessing,\n onClick: $options.selectRestoreFile,\n class: \"action-btn restore-btn\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"upload\"\n }), _createTextVNode(\" \" + _toDisplayString($data.restoring ? '恢复中...' : '恢复数据'), 1)]),\n _: 1\n }, 8, [\"loading\", \"disabled\", \"onClick\"])])]),\n _: 1\n })]))])])]), $data.indexInfo.newestFile || $data.indexInfo.oldestFile ? (_openBlock(), _createElementBlock(\"div\", _hoisted_59, [$data.indexInfo.newestFile ? (_openBlock(), _createElementBlock(\"div\", {\n key: 0,\n class: \"file-info-card info-card-newest\",\n onClick: _cache[5] || (_cache[5] = $event => $options.openFileInNewTab($data.indexInfo.newestFile))\n }, [$options.isImageFile($data.indexInfo.newestFile) && !$data.loadErrors['newest'] ? (_openBlock(), _createBlock(_component_el_image, {\n key: 0,\n src: '/file/' + $data.indexInfo.newestFile.id + '?from=admin',\n fit: \"cover\",\n class: \"card-bg-media\",\n onError: _cache[3] || (_cache[3] = $event => $options.handleImageError('newest'))\n }, null, 8, [\"src\"])) : $options.isVideoFile($data.indexInfo.newestFile) && !$data.loadErrors['newest'] ? (_openBlock(), _createElementBlock(\"video\", {\n key: 1,\n src: '/file/' + $data.indexInfo.newestFile.id + '?from=admin',\n class: \"card-bg-media\",\n muted: \"\",\n loop: \"\",\n autoplay: \"\",\n onError: _cache[4] || (_cache[4] = $event => $options.handleImageError('newest'))\n }, null, 40, _hoisted_60)) : (_openBlock(), _createElementBlock(\"div\", _hoisted_61, [_createVNode(_component_font_awesome_icon, {\n icon: \"file-alt\",\n class: \"fallback-icon\"\n })])), _createElementVNode(\"div\", _hoisted_62, [_createVNode(_component_font_awesome_icon, {\n icon: \"arrow-up\"\n }), _cache[25] || (_cache[25] = _createElementVNode(\"span\", null, \"最近上传\", -1))]), _createElementVNode(\"div\", _hoisted_63, [_createElementVNode(\"div\", _hoisted_64, _toDisplayString($data.indexInfo.newestFile.metadata?.FileName || $data.indexInfo.newestFile.id), 1), _createElementVNode(\"div\", _hoisted_65, _toDisplayString($options.formatTime($data.indexInfo.newestFile.metadata?.TimeStamp)), 1)])])) : _createCommentVNode(\"\", true), $data.indexInfo.oldestFile ? (_openBlock(), _createElementBlock(\"div\", {\n key: 1,\n class: \"file-info-card info-card-oldest\",\n onClick: _cache[8] || (_cache[8] = $event => $options.openFileInNewTab($data.indexInfo.oldestFile))\n }, [$options.isImageFile($data.indexInfo.oldestFile) && !$data.loadErrors['oldest'] ? (_openBlock(), _createBlock(_component_el_image, {\n key: 0,\n src: '/file/' + $data.indexInfo.oldestFile.id + '?from=admin',\n fit: \"cover\",\n class: \"card-bg-media\",\n onError: _cache[6] || (_cache[6] = $event => $options.handleImageError('oldest'))\n }, null, 8, [\"src\"])) : $options.isVideoFile($data.indexInfo.oldestFile) && !$data.loadErrors['oldest'] ? (_openBlock(), _createElementBlock(\"video\", {\n key: 1,\n src: '/file/' + $data.indexInfo.oldestFile.id + '?from=admin',\n class: \"card-bg-media\",\n muted: \"\",\n loop: \"\",\n autoplay: \"\",\n onError: _cache[7] || (_cache[7] = $event => $options.handleImageError('oldest'))\n }, null, 40, _hoisted_66)) : (_openBlock(), _createElementBlock(\"div\", _hoisted_67, [_createVNode(_component_font_awesome_icon, {\n icon: \"file-alt\",\n class: \"fallback-icon\"\n })])), _createElementVNode(\"div\", _hoisted_68, [_createVNode(_component_font_awesome_icon, {\n icon: \"arrow-down\"\n }), _cache[26] || (_cache[26] = _createElementVNode(\"span\", null, \"最早上传\", -1))]), _createElementVNode(\"div\", _hoisted_69, [_createElementVNode(\"div\", _hoisted_70, _toDisplayString($data.indexInfo.oldestFile.metadata?.FileName || $data.indexInfo.oldestFile.id), 1), _createElementVNode(\"div\", _hoisted_71, _toDisplayString($options.formatTime($data.indexInfo.oldestFile.metadata?.TimeStamp)), 1)])])) : _createCommentVNode(\"\", true)])) : _createCommentVNode(\"\", true)])), [[_directive_loading, $data.loading]]);\n}","/*!\n * @kurkle/color v0.3.4\n * https://github.com/kurkle/color#readme\n * (c) 2024 Jukka Kurkela\n * Released under the MIT License\n */\nfunction round(v) {\n return v + 0.5 | 0;\n}\nconst lim = (v, l, h) => Math.max(Math.min(v, h), l);\nfunction p2b(v) {\n return lim(round(v * 2.55), 0, 255);\n}\nfunction b2p(v) {\n return lim(round(v / 2.55), 0, 100);\n}\nfunction n2b(v) {\n return lim(round(v * 255), 0, 255);\n}\nfunction b2n(v) {\n return lim(round(v / 2.55) / 100, 0, 1);\n}\nfunction n2p(v) {\n return lim(round(v * 100), 0, 100);\n}\n\nconst map$1 = {0: 0, 1: 1, 2: 2, 3: 3, 4: 4, 5: 5, 6: 6, 7: 7, 8: 8, 9: 9, A: 10, B: 11, C: 12, D: 13, E: 14, F: 15, a: 10, b: 11, c: 12, d: 13, e: 14, f: 15};\nconst hex = [...'0123456789ABCDEF'];\nconst h1 = b => hex[b & 0xF];\nconst h2 = b => hex[(b & 0xF0) >> 4] + hex[b & 0xF];\nconst eq = b => ((b & 0xF0) >> 4) === (b & 0xF);\nconst isShort = v => eq(v.r) && eq(v.g) && eq(v.b) && eq(v.a);\nfunction hexParse(str) {\n var len = str.length;\n var ret;\n if (str[0] === '#') {\n if (len === 4 || len === 5) {\n ret = {\n r: 255 & map$1[str[1]] * 17,\n g: 255 & map$1[str[2]] * 17,\n b: 255 & map$1[str[3]] * 17,\n a: len === 5 ? map$1[str[4]] * 17 : 255\n };\n } else if (len === 7 || len === 9) {\n ret = {\n r: map$1[str[1]] << 4 | map$1[str[2]],\n g: map$1[str[3]] << 4 | map$1[str[4]],\n b: map$1[str[5]] << 4 | map$1[str[6]],\n a: len === 9 ? (map$1[str[7]] << 4 | map$1[str[8]]) : 255\n };\n }\n }\n return ret;\n}\nconst alpha = (a, f) => a < 255 ? f(a) : '';\nfunction hexString(v) {\n var f = isShort(v) ? h1 : h2;\n return v\n ? '#' + f(v.r) + f(v.g) + f(v.b) + alpha(v.a, f)\n : undefined;\n}\n\nconst HUE_RE = /^(hsla?|hwb|hsv)\\(\\s*([-+.e\\d]+)(?:deg)?[\\s,]+([-+.e\\d]+)%[\\s,]+([-+.e\\d]+)%(?:[\\s,]+([-+.e\\d]+)(%)?)?\\s*\\)$/;\nfunction hsl2rgbn(h, s, l) {\n const a = s * Math.min(l, 1 - l);\n const f = (n, k = (n + h / 30) % 12) => l - a * Math.max(Math.min(k - 3, 9 - k, 1), -1);\n return [f(0), f(8), f(4)];\n}\nfunction hsv2rgbn(h, s, v) {\n const f = (n, k = (n + h / 60) % 6) => v - v * s * Math.max(Math.min(k, 4 - k, 1), 0);\n return [f(5), f(3), f(1)];\n}\nfunction hwb2rgbn(h, w, b) {\n const rgb = hsl2rgbn(h, 1, 0.5);\n let i;\n if (w + b > 1) {\n i = 1 / (w + b);\n w *= i;\n b *= i;\n }\n for (i = 0; i < 3; i++) {\n rgb[i] *= 1 - w - b;\n rgb[i] += w;\n }\n return rgb;\n}\nfunction hueValue(r, g, b, d, max) {\n if (r === max) {\n return ((g - b) / d) + (g < b ? 6 : 0);\n }\n if (g === max) {\n return (b - r) / d + 2;\n }\n return (r - g) / d + 4;\n}\nfunction rgb2hsl(v) {\n const range = 255;\n const r = v.r / range;\n const g = v.g / range;\n const b = v.b / range;\n const max = Math.max(r, g, b);\n const min = Math.min(r, g, b);\n const l = (max + min) / 2;\n let h, s, d;\n if (max !== min) {\n d = max - min;\n s = l > 0.5 ? d / (2 - max - min) : d / (max + min);\n h = hueValue(r, g, b, d, max);\n h = h * 60 + 0.5;\n }\n return [h | 0, s || 0, l];\n}\nfunction calln(f, a, b, c) {\n return (\n Array.isArray(a)\n ? f(a[0], a[1], a[2])\n : f(a, b, c)\n ).map(n2b);\n}\nfunction hsl2rgb(h, s, l) {\n return calln(hsl2rgbn, h, s, l);\n}\nfunction hwb2rgb(h, w, b) {\n return calln(hwb2rgbn, h, w, b);\n}\nfunction hsv2rgb(h, s, v) {\n return calln(hsv2rgbn, h, s, v);\n}\nfunction hue(h) {\n return (h % 360 + 360) % 360;\n}\nfunction hueParse(str) {\n const m = HUE_RE.exec(str);\n let a = 255;\n let v;\n if (!m) {\n return;\n }\n if (m[5] !== v) {\n a = m[6] ? p2b(+m[5]) : n2b(+m[5]);\n }\n const h = hue(+m[2]);\n const p1 = +m[3] / 100;\n const p2 = +m[4] / 100;\n if (m[1] === 'hwb') {\n v = hwb2rgb(h, p1, p2);\n } else if (m[1] === 'hsv') {\n v = hsv2rgb(h, p1, p2);\n } else {\n v = hsl2rgb(h, p1, p2);\n }\n return {\n r: v[0],\n g: v[1],\n b: v[2],\n a: a\n };\n}\nfunction rotate(v, deg) {\n var h = rgb2hsl(v);\n h[0] = hue(h[0] + deg);\n h = hsl2rgb(h);\n v.r = h[0];\n v.g = h[1];\n v.b = h[2];\n}\nfunction hslString(v) {\n if (!v) {\n return;\n }\n const a = rgb2hsl(v);\n const h = a[0];\n const s = n2p(a[1]);\n const l = n2p(a[2]);\n return v.a < 255\n ? `hsla(${h}, ${s}%, ${l}%, ${b2n(v.a)})`\n : `hsl(${h}, ${s}%, ${l}%)`;\n}\n\nconst map = {\n\tx: 'dark',\n\tZ: 'light',\n\tY: 're',\n\tX: 'blu',\n\tW: 'gr',\n\tV: 'medium',\n\tU: 'slate',\n\tA: 'ee',\n\tT: 'ol',\n\tS: 'or',\n\tB: 'ra',\n\tC: 'lateg',\n\tD: 'ights',\n\tR: 'in',\n\tQ: 'turquois',\n\tE: 'hi',\n\tP: 'ro',\n\tO: 'al',\n\tN: 'le',\n\tM: 'de',\n\tL: 'yello',\n\tF: 'en',\n\tK: 'ch',\n\tG: 'arks',\n\tH: 'ea',\n\tI: 'ightg',\n\tJ: 'wh'\n};\nconst names$1 = {\n\tOiceXe: 'f0f8ff',\n\tantiquewEte: 'faebd7',\n\taqua: 'ffff',\n\taquamarRe: '7fffd4',\n\tazuY: 'f0ffff',\n\tbeige: 'f5f5dc',\n\tbisque: 'ffe4c4',\n\tblack: '0',\n\tblanKedOmond: 'ffebcd',\n\tXe: 'ff',\n\tXeviTet: '8a2be2',\n\tbPwn: 'a52a2a',\n\tburlywood: 'deb887',\n\tcaMtXe: '5f9ea0',\n\tKartYuse: '7fff00',\n\tKocTate: 'd2691e',\n\tcSO: 'ff7f50',\n\tcSnflowerXe: '6495ed',\n\tcSnsilk: 'fff8dc',\n\tcrimson: 'dc143c',\n\tcyan: 'ffff',\n\txXe: '8b',\n\txcyan: '8b8b',\n\txgTMnPd: 'b8860b',\n\txWay: 'a9a9a9',\n\txgYF: '6400',\n\txgYy: 'a9a9a9',\n\txkhaki: 'bdb76b',\n\txmagFta: '8b008b',\n\txTivegYF: '556b2f',\n\txSange: 'ff8c00',\n\txScEd: '9932cc',\n\txYd: '8b0000',\n\txsOmon: 'e9967a',\n\txsHgYF: '8fbc8f',\n\txUXe: '483d8b',\n\txUWay: '2f4f4f',\n\txUgYy: '2f4f4f',\n\txQe: 'ced1',\n\txviTet: '9400d3',\n\tdAppRk: 'ff1493',\n\tdApskyXe: 'bfff',\n\tdimWay: '696969',\n\tdimgYy: '696969',\n\tdodgerXe: '1e90ff',\n\tfiYbrick: 'b22222',\n\tflSOwEte: 'fffaf0',\n\tfoYstWAn: '228b22',\n\tfuKsia: 'ff00ff',\n\tgaRsbSo: 'dcdcdc',\n\tghostwEte: 'f8f8ff',\n\tgTd: 'ffd700',\n\tgTMnPd: 'daa520',\n\tWay: '808080',\n\tgYF: '8000',\n\tgYFLw: 'adff2f',\n\tgYy: '808080',\n\thoneyMw: 'f0fff0',\n\thotpRk: 'ff69b4',\n\tRdianYd: 'cd5c5c',\n\tRdigo: '4b0082',\n\tivSy: 'fffff0',\n\tkhaki: 'f0e68c',\n\tlavFMr: 'e6e6fa',\n\tlavFMrXsh: 'fff0f5',\n\tlawngYF: '7cfc00',\n\tNmoncEffon: 'fffacd',\n\tZXe: 'add8e6',\n\tZcSO: 'f08080',\n\tZcyan: 'e0ffff',\n\tZgTMnPdLw: 'fafad2',\n\tZWay: 'd3d3d3',\n\tZgYF: '90ee90',\n\tZgYy: 'd3d3d3',\n\tZpRk: 'ffb6c1',\n\tZsOmon: 'ffa07a',\n\tZsHgYF: '20b2aa',\n\tZskyXe: '87cefa',\n\tZUWay: '778899',\n\tZUgYy: '778899',\n\tZstAlXe: 'b0c4de',\n\tZLw: 'ffffe0',\n\tlime: 'ff00',\n\tlimegYF: '32cd32',\n\tlRF: 'faf0e6',\n\tmagFta: 'ff00ff',\n\tmaPon: '800000',\n\tVaquamarRe: '66cdaa',\n\tVXe: 'cd',\n\tVScEd: 'ba55d3',\n\tVpurpN: '9370db',\n\tVsHgYF: '3cb371',\n\tVUXe: '7b68ee',\n\tVsprRggYF: 'fa9a',\n\tVQe: '48d1cc',\n\tVviTetYd: 'c71585',\n\tmidnightXe: '191970',\n\tmRtcYam: 'f5fffa',\n\tmistyPse: 'ffe4e1',\n\tmoccasR: 'ffe4b5',\n\tnavajowEte: 'ffdead',\n\tnavy: '80',\n\tTdlace: 'fdf5e6',\n\tTive: '808000',\n\tTivedBb: '6b8e23',\n\tSange: 'ffa500',\n\tSangeYd: 'ff4500',\n\tScEd: 'da70d6',\n\tpOegTMnPd: 'eee8aa',\n\tpOegYF: '98fb98',\n\tpOeQe: 'afeeee',\n\tpOeviTetYd: 'db7093',\n\tpapayawEp: 'ffefd5',\n\tpHKpuff: 'ffdab9',\n\tperu: 'cd853f',\n\tpRk: 'ffc0cb',\n\tplum: 'dda0dd',\n\tpowMrXe: 'b0e0e6',\n\tpurpN: '800080',\n\tYbeccapurpN: '663399',\n\tYd: 'ff0000',\n\tPsybrown: 'bc8f8f',\n\tPyOXe: '4169e1',\n\tsaddNbPwn: '8b4513',\n\tsOmon: 'fa8072',\n\tsandybPwn: 'f4a460',\n\tsHgYF: '2e8b57',\n\tsHshell: 'fff5ee',\n\tsiFna: 'a0522d',\n\tsilver: 'c0c0c0',\n\tskyXe: '87ceeb',\n\tUXe: '6a5acd',\n\tUWay: '708090',\n\tUgYy: '708090',\n\tsnow: 'fffafa',\n\tsprRggYF: 'ff7f',\n\tstAlXe: '4682b4',\n\ttan: 'd2b48c',\n\tteO: '8080',\n\ttEstN: 'd8bfd8',\n\ttomato: 'ff6347',\n\tQe: '40e0d0',\n\tviTet: 'ee82ee',\n\tJHt: 'f5deb3',\n\twEte: 'ffffff',\n\twEtesmoke: 'f5f5f5',\n\tLw: 'ffff00',\n\tLwgYF: '9acd32'\n};\nfunction unpack() {\n const unpacked = {};\n const keys = Object.keys(names$1);\n const tkeys = Object.keys(map);\n let i, j, k, ok, nk;\n for (i = 0; i < keys.length; i++) {\n ok = nk = keys[i];\n for (j = 0; j < tkeys.length; j++) {\n k = tkeys[j];\n nk = nk.replace(k, map[k]);\n }\n k = parseInt(names$1[ok], 16);\n unpacked[nk] = [k >> 16 & 0xFF, k >> 8 & 0xFF, k & 0xFF];\n }\n return unpacked;\n}\n\nlet names;\nfunction nameParse(str) {\n if (!names) {\n names = unpack();\n names.transparent = [0, 0, 0, 0];\n }\n const a = names[str.toLowerCase()];\n return a && {\n r: a[0],\n g: a[1],\n b: a[2],\n a: a.length === 4 ? a[3] : 255\n };\n}\n\nconst RGB_RE = /^rgba?\\(\\s*([-+.\\d]+)(%)?[\\s,]+([-+.e\\d]+)(%)?[\\s,]+([-+.e\\d]+)(%)?(?:[\\s,/]+([-+.e\\d]+)(%)?)?\\s*\\)$/;\nfunction rgbParse(str) {\n const m = RGB_RE.exec(str);\n let a = 255;\n let r, g, b;\n if (!m) {\n return;\n }\n if (m[7] !== r) {\n const v = +m[7];\n a = m[8] ? p2b(v) : lim(v * 255, 0, 255);\n }\n r = +m[1];\n g = +m[3];\n b = +m[5];\n r = 255 & (m[2] ? p2b(r) : lim(r, 0, 255));\n g = 255 & (m[4] ? p2b(g) : lim(g, 0, 255));\n b = 255 & (m[6] ? p2b(b) : lim(b, 0, 255));\n return {\n r: r,\n g: g,\n b: b,\n a: a\n };\n}\nfunction rgbString(v) {\n return v && (\n v.a < 255\n ? `rgba(${v.r}, ${v.g}, ${v.b}, ${b2n(v.a)})`\n : `rgb(${v.r}, ${v.g}, ${v.b})`\n );\n}\n\nconst to = v => v <= 0.0031308 ? v * 12.92 : Math.pow(v, 1.0 / 2.4) * 1.055 - 0.055;\nconst from = v => v <= 0.04045 ? v / 12.92 : Math.pow((v + 0.055) / 1.055, 2.4);\nfunction interpolate(rgb1, rgb2, t) {\n const r = from(b2n(rgb1.r));\n const g = from(b2n(rgb1.g));\n const b = from(b2n(rgb1.b));\n return {\n r: n2b(to(r + t * (from(b2n(rgb2.r)) - r))),\n g: n2b(to(g + t * (from(b2n(rgb2.g)) - g))),\n b: n2b(to(b + t * (from(b2n(rgb2.b)) - b))),\n a: rgb1.a + t * (rgb2.a - rgb1.a)\n };\n}\n\nfunction modHSL(v, i, ratio) {\n if (v) {\n let tmp = rgb2hsl(v);\n tmp[i] = Math.max(0, Math.min(tmp[i] + tmp[i] * ratio, i === 0 ? 360 : 1));\n tmp = hsl2rgb(tmp);\n v.r = tmp[0];\n v.g = tmp[1];\n v.b = tmp[2];\n }\n}\nfunction clone(v, proto) {\n return v ? Object.assign(proto || {}, v) : v;\n}\nfunction fromObject(input) {\n var v = {r: 0, g: 0, b: 0, a: 255};\n if (Array.isArray(input)) {\n if (input.length >= 3) {\n v = {r: input[0], g: input[1], b: input[2], a: 255};\n if (input.length > 3) {\n v.a = n2b(input[3]);\n }\n }\n } else {\n v = clone(input, {r: 0, g: 0, b: 0, a: 1});\n v.a = n2b(v.a);\n }\n return v;\n}\nfunction functionParse(str) {\n if (str.charAt(0) === 'r') {\n return rgbParse(str);\n }\n return hueParse(str);\n}\nclass Color {\n constructor(input) {\n if (input instanceof Color) {\n return input;\n }\n const type = typeof input;\n let v;\n if (type === 'object') {\n v = fromObject(input);\n } else if (type === 'string') {\n v = hexParse(input) || nameParse(input) || functionParse(input);\n }\n this._rgb = v;\n this._valid = !!v;\n }\n get valid() {\n return this._valid;\n }\n get rgb() {\n var v = clone(this._rgb);\n if (v) {\n v.a = b2n(v.a);\n }\n return v;\n }\n set rgb(obj) {\n this._rgb = fromObject(obj);\n }\n rgbString() {\n return this._valid ? rgbString(this._rgb) : undefined;\n }\n hexString() {\n return this._valid ? hexString(this._rgb) : undefined;\n }\n hslString() {\n return this._valid ? hslString(this._rgb) : undefined;\n }\n mix(color, weight) {\n if (color) {\n const c1 = this.rgb;\n const c2 = color.rgb;\n let w2;\n const p = weight === w2 ? 0.5 : weight;\n const w = 2 * p - 1;\n const a = c1.a - c2.a;\n const w1 = ((w * a === -1 ? w : (w + a) / (1 + w * a)) + 1) / 2.0;\n w2 = 1 - w1;\n c1.r = 0xFF & w1 * c1.r + w2 * c2.r + 0.5;\n c1.g = 0xFF & w1 * c1.g + w2 * c2.g + 0.5;\n c1.b = 0xFF & w1 * c1.b + w2 * c2.b + 0.5;\n c1.a = p * c1.a + (1 - p) * c2.a;\n this.rgb = c1;\n }\n return this;\n }\n interpolate(color, t) {\n if (color) {\n this._rgb = interpolate(this._rgb, color._rgb, t);\n }\n return this;\n }\n clone() {\n return new Color(this.rgb);\n }\n alpha(a) {\n this._rgb.a = n2b(a);\n return this;\n }\n clearer(ratio) {\n const rgb = this._rgb;\n rgb.a *= 1 - ratio;\n return this;\n }\n greyscale() {\n const rgb = this._rgb;\n const val = round(rgb.r * 0.3 + rgb.g * 0.59 + rgb.b * 0.11);\n rgb.r = rgb.g = rgb.b = val;\n return this;\n }\n opaquer(ratio) {\n const rgb = this._rgb;\n rgb.a *= 1 + ratio;\n return this;\n }\n negate() {\n const v = this._rgb;\n v.r = 255 - v.r;\n v.g = 255 - v.g;\n v.b = 255 - v.b;\n return this;\n }\n lighten(ratio) {\n modHSL(this._rgb, 2, ratio);\n return this;\n }\n darken(ratio) {\n modHSL(this._rgb, 2, -ratio);\n return this;\n }\n saturate(ratio) {\n modHSL(this._rgb, 1, ratio);\n return this;\n }\n desaturate(ratio) {\n modHSL(this._rgb, 1, -ratio);\n return this;\n }\n rotate(deg) {\n rotate(this._rgb, deg);\n return this;\n }\n}\n\nfunction index_esm(input) {\n return new Color(input);\n}\n\nexport { Color, b2n, b2p, index_esm as default, hexParse, hexString, hsl2rgb, hslString, hsv2rgb, hueParse, hwb2rgb, lim, n2b, n2p, nameParse, p2b, rgb2hsl, rgbParse, rgbString, rotate, round };\n","/**\n * @namespace Chart.helpers\n */\n\nimport type {AnyObject} from '../types/basic.js';\nimport type {ActiveDataPoint, ChartEvent} from '../types/index.js';\n\n/**\n * An empty function that can be used, for example, for optional callback.\n */\nexport function noop() {\n /* noop */\n}\n\n/**\n * Returns a unique id, sequentially generated from a global variable.\n */\nexport const uid = (() => {\n let id = 0;\n return () => id++;\n})();\n\n/**\n * Returns true if `value` is neither null nor undefined, else returns false.\n * @param value - The value to test.\n * @since 2.7.0\n */\nexport function isNullOrUndef(value: unknown): value is null | undefined {\n return value === null || value === undefined;\n}\n\n/**\n * Returns true if `value` is an array (including typed arrays), else returns false.\n * @param value - The value to test.\n * @function\n */\nexport function isArray(value: unknown): value is T[] {\n if (Array.isArray && Array.isArray(value)) {\n return true;\n }\n const type = Object.prototype.toString.call(value);\n if (type.slice(0, 7) === '[object' && type.slice(-6) === 'Array]') {\n return true;\n }\n return false;\n}\n\n/**\n * Returns true if `value` is an object (excluding null), else returns false.\n * @param value - The value to test.\n * @since 2.7.0\n */\nexport function isObject(value: unknown): value is AnyObject {\n return value !== null && Object.prototype.toString.call(value) === '[object Object]';\n}\n\n/**\n * Returns true if `value` is a finite number, else returns false\n * @param value - The value to test.\n */\nfunction isNumberFinite(value: unknown): value is number {\n return (typeof value === 'number' || value instanceof Number) && isFinite(+value);\n}\nexport {\n isNumberFinite as isFinite,\n};\n\n/**\n * Returns `value` if finite, else returns `defaultValue`.\n * @param value - The value to return if defined.\n * @param defaultValue - The value to return if `value` is not finite.\n */\nexport function finiteOrDefault(value: unknown, defaultValue: number) {\n return isNumberFinite(value) ? value : defaultValue;\n}\n\n/**\n * Returns `value` if defined, else returns `defaultValue`.\n * @param value - The value to return if defined.\n * @param defaultValue - The value to return if `value` is undefined.\n */\nexport function valueOrDefault(value: T | undefined, defaultValue: T) {\n return typeof value === 'undefined' ? defaultValue : value;\n}\n\nexport const toPercentage = (value: number | string, dimension: number) =>\n typeof value === 'string' && value.endsWith('%') ?\n parseFloat(value) / 100\n : +value / dimension;\n\nexport const toDimension = (value: number | string, dimension: number) =>\n typeof value === 'string' && value.endsWith('%') ?\n parseFloat(value) / 100 * dimension\n : +value;\n\n/**\n * Calls `fn` with the given `args` in the scope defined by `thisArg` and returns the\n * value returned by `fn`. If `fn` is not a function, this method returns undefined.\n * @param fn - The function to call.\n * @param args - The arguments with which `fn` should be called.\n * @param [thisArg] - The value of `this` provided for the call to `fn`.\n */\nexport function callback R, TA, R>(\n fn: T | undefined,\n args: unknown[],\n thisArg?: TA\n): R | undefined {\n if (fn && typeof fn.call === 'function') {\n return fn.apply(thisArg, args);\n }\n}\n\n/**\n * Note(SB) for performance sake, this method should only be used when loopable type\n * is unknown or in none intensive code (not called often and small loopable). Else\n * it's preferable to use a regular for() loop and save extra function calls.\n * @param loopable - The object or array to be iterated.\n * @param fn - The function to call for each item.\n * @param [thisArg] - The value of `this` provided for the call to `fn`.\n * @param [reverse] - If true, iterates backward on the loopable.\n */\nexport function each(\n loopable: Record,\n fn: (this: TA, v: T, i: string) => void,\n thisArg?: TA,\n reverse?: boolean\n): void;\nexport function each(\n loopable: T[],\n fn: (this: TA, v: T, i: number) => void,\n thisArg?: TA,\n reverse?: boolean\n): void;\nexport function each(\n loopable: T[] | Record,\n fn: (this: TA, v: T, i: any) => void,\n thisArg?: TA,\n reverse?: boolean\n) {\n let i: number, len: number, keys: string[];\n if (isArray(loopable)) {\n len = loopable.length;\n if (reverse) {\n for (i = len - 1; i >= 0; i--) {\n fn.call(thisArg, loopable[i], i);\n }\n } else {\n for (i = 0; i < len; i++) {\n fn.call(thisArg, loopable[i], i);\n }\n }\n } else if (isObject(loopable)) {\n keys = Object.keys(loopable);\n len = keys.length;\n for (i = 0; i < len; i++) {\n fn.call(thisArg, loopable[keys[i]], keys[i]);\n }\n }\n}\n\n/**\n * Returns true if the `a0` and `a1` arrays have the same content, else returns false.\n * @param a0 - The array to compare\n * @param a1 - The array to compare\n * @private\n */\nexport function _elementsEqual(a0: ActiveDataPoint[], a1: ActiveDataPoint[]) {\n let i: number, ilen: number, v0: ActiveDataPoint, v1: ActiveDataPoint;\n\n if (!a0 || !a1 || a0.length !== a1.length) {\n return false;\n }\n\n for (i = 0, ilen = a0.length; i < ilen; ++i) {\n v0 = a0[i];\n v1 = a1[i];\n\n if (v0.datasetIndex !== v1.datasetIndex || v0.index !== v1.index) {\n return false;\n }\n }\n\n return true;\n}\n\n/**\n * Returns a deep copy of `source` without keeping references on objects and arrays.\n * @param source - The value to clone.\n */\nexport function clone(source: T): T {\n if (isArray(source)) {\n return source.map(clone) as unknown as T;\n }\n\n if (isObject(source)) {\n const target = Object.create(null);\n const keys = Object.keys(source);\n const klen = keys.length;\n let k = 0;\n\n for (; k < klen; ++k) {\n target[keys[k]] = clone(source[keys[k]]);\n }\n\n return target;\n }\n\n return source;\n}\n\nfunction isValidKey(key: string) {\n return ['__proto__', 'prototype', 'constructor'].indexOf(key) === -1;\n}\n\n/**\n * The default merger when Chart.helpers.merge is called without merger option.\n * Note(SB): also used by mergeConfig and mergeScaleConfig as fallback.\n * @private\n */\nexport function _merger(key: string, target: AnyObject, source: AnyObject, options: AnyObject) {\n if (!isValidKey(key)) {\n return;\n }\n\n const tval = target[key];\n const sval = source[key];\n\n if (isObject(tval) && isObject(sval)) {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n merge(tval, sval, options);\n } else {\n target[key] = clone(sval);\n }\n}\n\nexport interface MergeOptions {\n merger?: (key: string, target: AnyObject, source: AnyObject, options?: AnyObject) => void;\n}\n\n/**\n * Recursively deep copies `source` properties into `target` with the given `options`.\n * IMPORTANT: `target` is not cloned and will be updated with `source` properties.\n * @param target - The target object in which all sources are merged into.\n * @param source - Object(s) to merge into `target`.\n * @param [options] - Merging options:\n * @param [options.merger] - The merge method (key, target, source, options)\n * @returns The `target` object.\n */\nexport function merge(target: T, source: [], options?: MergeOptions): T;\nexport function merge(target: T, source: S1, options?: MergeOptions): T & S1;\nexport function merge(target: T, source: [S1], options?: MergeOptions): T & S1;\nexport function merge(target: T, source: [S1, S2], options?: MergeOptions): T & S1 & S2;\nexport function merge(target: T, source: [S1, S2, S3], options?: MergeOptions): T & S1 & S2 & S3;\nexport function merge(\n target: T,\n source: [S1, S2, S3, S4],\n options?: MergeOptions\n): T & S1 & S2 & S3 & S4;\nexport function merge(target: T, source: AnyObject[], options?: MergeOptions): AnyObject;\nexport function merge(target: T, source: AnyObject[], options?: MergeOptions): AnyObject {\n const sources = isArray(source) ? source : [source];\n const ilen = sources.length;\n\n if (!isObject(target)) {\n return target as AnyObject;\n }\n\n options = options || {};\n const merger = options.merger || _merger;\n let current: AnyObject;\n\n for (let i = 0; i < ilen; ++i) {\n current = sources[i];\n if (!isObject(current)) {\n continue;\n }\n\n const keys = Object.keys(current);\n for (let k = 0, klen = keys.length; k < klen; ++k) {\n merger(keys[k], target, current, options as AnyObject);\n }\n }\n\n return target;\n}\n\n/**\n * Recursively deep copies `source` properties into `target` *only* if not defined in target.\n * IMPORTANT: `target` is not cloned and will be updated with `source` properties.\n * @param target - The target object in which all sources are merged into.\n * @param source - Object(s) to merge into `target`.\n * @returns The `target` object.\n */\nexport function mergeIf(target: T, source: []): T;\nexport function mergeIf(target: T, source: S1): T & S1;\nexport function mergeIf(target: T, source: [S1]): T & S1;\nexport function mergeIf(target: T, source: [S1, S2]): T & S1 & S2;\nexport function mergeIf(target: T, source: [S1, S2, S3]): T & S1 & S2 & S3;\nexport function mergeIf(target: T, source: [S1, S2, S3, S4]): T & S1 & S2 & S3 & S4;\nexport function mergeIf(target: T, source: AnyObject[]): AnyObject;\nexport function mergeIf(target: T, source: AnyObject[]): AnyObject {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n return merge(target, source, {merger: _mergerIf});\n}\n\n/**\n * Merges source[key] in target[key] only if target[key] is undefined.\n * @private\n */\nexport function _mergerIf(key: string, target: AnyObject, source: AnyObject) {\n if (!isValidKey(key)) {\n return;\n }\n\n const tval = target[key];\n const sval = source[key];\n\n if (isObject(tval) && isObject(sval)) {\n mergeIf(tval, sval);\n } else if (!Object.prototype.hasOwnProperty.call(target, key)) {\n target[key] = clone(sval);\n }\n}\n\n/**\n * @private\n */\nexport function _deprecated(scope: string, value: unknown, previous: string, current: string) {\n if (value !== undefined) {\n console.warn(scope + ': \"' + previous +\n '\" is deprecated. Please use \"' + current + '\" instead');\n }\n}\n\n// resolveObjectKey resolver cache\nconst keyResolvers = {\n // Chart.helpers.core resolveObjectKey should resolve empty key to root object\n '': v => v,\n // default resolvers\n x: o => o.x,\n y: o => o.y\n};\n\n/**\n * @private\n */\nexport function _splitKey(key: string) {\n const parts = key.split('.');\n const keys: string[] = [];\n let tmp = '';\n for (const part of parts) {\n tmp += part;\n if (tmp.endsWith('\\\\')) {\n tmp = tmp.slice(0, -1) + '.';\n } else {\n keys.push(tmp);\n tmp = '';\n }\n }\n return keys;\n}\n\nfunction _getKeyResolver(key: string) {\n const keys = _splitKey(key);\n return obj => {\n for (const k of keys) {\n if (k === '') {\n // For backward compatibility:\n // Chart.helpers.core resolveObjectKey should break at empty key\n break;\n }\n obj = obj && obj[k];\n }\n return obj;\n };\n}\n\nexport function resolveObjectKey(obj: AnyObject, key: string): any {\n const resolver = keyResolvers[key] || (keyResolvers[key] = _getKeyResolver(key));\n return resolver(obj);\n}\n\n/**\n * @private\n */\nexport function _capitalize(str: string) {\n return str.charAt(0).toUpperCase() + str.slice(1);\n}\n\n\nexport const defined = (value: unknown) => typeof value !== 'undefined';\n\nexport const isFunction = (value: unknown): value is (...args: any[]) => any => typeof value === 'function';\n\n// Adapted from https://stackoverflow.com/questions/31128855/comparing-ecma6-sets-for-equality#31129384\nexport const setsEqual = (a: Set, b: Set) => {\n if (a.size !== b.size) {\n return false;\n }\n\n for (const item of a) {\n if (!b.has(item)) {\n return false;\n }\n }\n\n return true;\n};\n\n/**\n * @param e - The event\n * @private\n */\nexport function _isClickEvent(e: ChartEvent) {\n return e.type === 'mouseup' || e.type === 'click' || e.type === 'contextmenu';\n}\n","import type {Point} from '../types/geometric.js';\nimport {isFinite as isFiniteNumber} from './helpers.core.js';\n\n/**\n * @alias Chart.helpers.math\n * @namespace\n */\n\nexport const PI = Math.PI;\nexport const TAU = 2 * PI;\nexport const PITAU = TAU + PI;\nexport const INFINITY = Number.POSITIVE_INFINITY;\nexport const RAD_PER_DEG = PI / 180;\nexport const HALF_PI = PI / 2;\nexport const QUARTER_PI = PI / 4;\nexport const TWO_THIRDS_PI = PI * 2 / 3;\n\nexport const log10 = Math.log10;\nexport const sign = Math.sign;\n\nexport function almostEquals(x: number, y: number, epsilon: number) {\n return Math.abs(x - y) < epsilon;\n}\n\n/**\n * Implementation of the nice number algorithm used in determining where axis labels will go\n */\nexport function niceNum(range: number) {\n const roundedRange = Math.round(range);\n range = almostEquals(range, roundedRange, range / 1000) ? roundedRange : range;\n const niceRange = Math.pow(10, Math.floor(log10(range)));\n const fraction = range / niceRange;\n const niceFraction = fraction <= 1 ? 1 : fraction <= 2 ? 2 : fraction <= 5 ? 5 : 10;\n return niceFraction * niceRange;\n}\n\n/**\n * Returns an array of factors sorted from 1 to sqrt(value)\n * @private\n */\nexport function _factorize(value: number) {\n const result: number[] = [];\n const sqrt = Math.sqrt(value);\n let i: number;\n\n for (i = 1; i < sqrt; i++) {\n if (value % i === 0) {\n result.push(i);\n result.push(value / i);\n }\n }\n if (sqrt === (sqrt | 0)) { // if value is a square number\n result.push(sqrt);\n }\n\n result.sort((a, b) => a - b).pop();\n return result;\n}\n\n/**\n * Verifies that attempting to coerce n to string or number won't throw a TypeError.\n */\nfunction isNonPrimitive(n: unknown) {\n return typeof n === 'symbol' || (typeof n === 'object' && n !== null && !(Symbol.toPrimitive in n || 'toString' in n || 'valueOf' in n));\n}\n\nexport function isNumber(n: unknown): n is number {\n return !isNonPrimitive(n) && !isNaN(parseFloat(n as string)) && isFinite(n as number);\n}\n\nexport function almostWhole(x: number, epsilon: number) {\n const rounded = Math.round(x);\n return ((rounded - epsilon) <= x) && ((rounded + epsilon) >= x);\n}\n\n/**\n * @private\n */\nexport function _setMinAndMaxByKey(\n array: Record[],\n target: { min: number, max: number },\n property: string\n) {\n let i: number, ilen: number, value: number;\n\n for (i = 0, ilen = array.length; i < ilen; i++) {\n value = array[i][property];\n if (!isNaN(value)) {\n target.min = Math.min(target.min, value);\n target.max = Math.max(target.max, value);\n }\n }\n}\n\nexport function toRadians(degrees: number) {\n return degrees * (PI / 180);\n}\n\nexport function toDegrees(radians: number) {\n return radians * (180 / PI);\n}\n\n/**\n * Returns the number of decimal places\n * i.e. the number of digits after the decimal point, of the value of this Number.\n * @param x - A number.\n * @returns The number of decimal places.\n * @private\n */\nexport function _decimalPlaces(x: number) {\n if (!isFiniteNumber(x)) {\n return;\n }\n let e = 1;\n let p = 0;\n while (Math.round(x * e) / e !== x) {\n e *= 10;\n p++;\n }\n return p;\n}\n\n// Gets the angle from vertical upright to the point about a centre.\nexport function getAngleFromPoint(\n centrePoint: Point,\n anglePoint: Point\n) {\n const distanceFromXCenter = anglePoint.x - centrePoint.x;\n const distanceFromYCenter = anglePoint.y - centrePoint.y;\n const radialDistanceFromCenter = Math.sqrt(distanceFromXCenter * distanceFromXCenter + distanceFromYCenter * distanceFromYCenter);\n\n let angle = Math.atan2(distanceFromYCenter, distanceFromXCenter);\n\n if (angle < (-0.5 * PI)) {\n angle += TAU; // make sure the returned angle is in the range of (-PI/2, 3PI/2]\n }\n\n return {\n angle,\n distance: radialDistanceFromCenter\n };\n}\n\nexport function distanceBetweenPoints(pt1: Point, pt2: Point) {\n return Math.sqrt(Math.pow(pt2.x - pt1.x, 2) + Math.pow(pt2.y - pt1.y, 2));\n}\n\n/**\n * Shortest distance between angles, in either direction.\n * @private\n */\nexport function _angleDiff(a: number, b: number) {\n return (a - b + PITAU) % TAU - PI;\n}\n\n/**\n * Normalize angle to be between 0 and 2*PI\n * @private\n */\nexport function _normalizeAngle(a: number) {\n return (a % TAU + TAU) % TAU;\n}\n\n/**\n * @private\n */\nexport function _angleBetween(angle: number, start: number, end: number, sameAngleIsFullCircle?: boolean) {\n const a = _normalizeAngle(angle);\n const s = _normalizeAngle(start);\n const e = _normalizeAngle(end);\n const angleToStart = _normalizeAngle(s - a);\n const angleToEnd = _normalizeAngle(e - a);\n const startToAngle = _normalizeAngle(a - s);\n const endToAngle = _normalizeAngle(a - e);\n return a === s || a === e || (sameAngleIsFullCircle && s === e)\n || (angleToStart > angleToEnd && startToAngle < endToAngle);\n}\n\n/**\n * Limit `value` between `min` and `max`\n * @param value\n * @param min\n * @param max\n * @private\n */\nexport function _limitValue(value: number, min: number, max: number) {\n return Math.max(min, Math.min(max, value));\n}\n\n/**\n * @param {number} value\n * @private\n */\nexport function _int16Range(value: number) {\n return _limitValue(value, -32768, 32767);\n}\n\n/**\n * @param value\n * @param start\n * @param end\n * @param [epsilon]\n * @private\n */\nexport function _isBetween(value: number, start: number, end: number, epsilon = 1e-6) {\n return value >= Math.min(start, end) - epsilon && value <= Math.max(start, end) + epsilon;\n}\n","import {_capitalize} from './helpers.core.js';\n\n/**\n * Binary search\n * @param table - the table search. must be sorted!\n * @param value - value to find\n * @param cmp\n * @private\n */\nexport function _lookup(\n table: number[],\n value: number,\n cmp?: (value: number) => boolean\n): {lo: number, hi: number};\nexport function _lookup(\n table: T[],\n value: number,\n cmp: (value: number) => boolean\n): {lo: number, hi: number};\nexport function _lookup(\n table: unknown[],\n value: number,\n cmp?: (value: number) => boolean\n) {\n cmp = cmp || ((index) => table[index] < value);\n let hi = table.length - 1;\n let lo = 0;\n let mid: number;\n\n while (hi - lo > 1) {\n mid = (lo + hi) >> 1;\n if (cmp(mid)) {\n lo = mid;\n } else {\n hi = mid;\n }\n }\n\n return {lo, hi};\n}\n\n/**\n * Binary search\n * @param table - the table search. must be sorted!\n * @param key - property name for the value in each entry\n * @param value - value to find\n * @param last - lookup last index\n * @private\n */\nexport const _lookupByKey = (\n table: Record[],\n key: string,\n value: number,\n last?: boolean\n) =>\n _lookup(table, value, last\n ? index => {\n const ti = table[index][key];\n return ti < value || ti === value && table[index + 1][key] === value;\n }\n : index => table[index][key] < value);\n\n/**\n * Reverse binary search\n * @param table - the table search. must be sorted!\n * @param key - property name for the value in each entry\n * @param value - value to find\n * @private\n */\nexport const _rlookupByKey = (\n table: Record[],\n key: string,\n value: number\n) =>\n _lookup(table, value, index => table[index][key] >= value);\n\n/**\n * Return subset of `values` between `min` and `max` inclusive.\n * Values are assumed to be in sorted order.\n * @param values - sorted array of values\n * @param min - min value\n * @param max - max value\n */\nexport function _filterBetween(values: number[], min: number, max: number) {\n let start = 0;\n let end = values.length;\n\n while (start < end && values[start] < min) {\n start++;\n }\n while (end > start && values[end - 1] > max) {\n end--;\n }\n\n return start > 0 || end < values.length\n ? values.slice(start, end)\n : values;\n}\n\nconst arrayEvents = ['push', 'pop', 'shift', 'splice', 'unshift'] as const;\n\nexport interface ArrayListener {\n _onDataPush?(...item: T[]): void;\n _onDataPop?(): void;\n _onDataShift?(): void;\n _onDataSplice?(index: number, deleteCount: number, ...items: T[]): void;\n _onDataUnshift?(...item: T[]): void;\n}\n\n/**\n * Hooks the array methods that add or remove values ('push', pop', 'shift', 'splice',\n * 'unshift') and notify the listener AFTER the array has been altered. Listeners are\n * called on the '_onData*' callbacks (e.g. _onDataPush, etc.) with same arguments.\n */\nexport function listenArrayEvents(array: T[], listener: ArrayListener): void;\nexport function listenArrayEvents(array, listener) {\n if (array._chartjs) {\n array._chartjs.listeners.push(listener);\n return;\n }\n\n Object.defineProperty(array, '_chartjs', {\n configurable: true,\n enumerable: false,\n value: {\n listeners: [listener]\n }\n });\n\n arrayEvents.forEach((key) => {\n const method = '_onData' + _capitalize(key);\n const base = array[key];\n\n Object.defineProperty(array, key, {\n configurable: true,\n enumerable: false,\n value(...args) {\n const res = base.apply(this, args);\n\n array._chartjs.listeners.forEach((object) => {\n if (typeof object[method] === 'function') {\n object[method](...args);\n }\n });\n\n return res;\n }\n });\n });\n}\n\n\n/**\n * Removes the given array event listener and cleanup extra attached properties (such as\n * the _chartjs stub and overridden methods) if array doesn't have any more listeners.\n */\nexport function unlistenArrayEvents(array: T[], listener: ArrayListener): void;\nexport function unlistenArrayEvents(array, listener) {\n const stub = array._chartjs;\n if (!stub) {\n return;\n }\n\n const listeners = stub.listeners;\n const index = listeners.indexOf(listener);\n if (index !== -1) {\n listeners.splice(index, 1);\n }\n\n if (listeners.length > 0) {\n return;\n }\n\n arrayEvents.forEach((key) => {\n delete array[key];\n });\n\n delete array._chartjs;\n}\n\n/**\n * @param items\n */\nexport function _arrayUnique(items: T[]) {\n const set = new Set(items);\n\n if (set.size === items.length) {\n return items;\n }\n\n return Array.from(set);\n}\n","import type {ChartMeta, PointElement} from '../types/index.js';\n\nimport {_limitValue} from './helpers.math.js';\nimport {_lookupByKey} from './helpers.collection.js';\nimport {isNullOrUndef} from './helpers.core.js';\n\nexport function fontString(pixelSize: number, fontStyle: string, fontFamily: string) {\n return fontStyle + ' ' + pixelSize + 'px ' + fontFamily;\n}\n\n/**\n* Request animation polyfill\n*/\nexport const requestAnimFrame = (function() {\n if (typeof window === 'undefined') {\n return function(callback) {\n return callback();\n };\n }\n return window.requestAnimationFrame;\n}());\n\n/**\n * Throttles calling `fn` once per animation frame\n * Latest arguments are used on the actual call\n */\nexport function throttled>(\n fn: (...args: TArgs) => void,\n thisArg: any,\n) {\n let argsToUse = [] as TArgs;\n let ticking = false;\n\n return function(...args: TArgs) {\n // Save the args for use later\n argsToUse = args;\n if (!ticking) {\n ticking = true;\n requestAnimFrame.call(window, () => {\n ticking = false;\n fn.apply(thisArg, argsToUse);\n });\n }\n };\n}\n\n/**\n * Debounces calling `fn` for `delay` ms\n */\nexport function debounce>(fn: (...args: TArgs) => void, delay: number) {\n let timeout;\n return function(...args: TArgs) {\n if (delay) {\n clearTimeout(timeout);\n timeout = setTimeout(fn, delay, args);\n } else {\n fn.apply(this, args);\n }\n return delay;\n };\n}\n\n/**\n * Converts 'start' to 'left', 'end' to 'right' and others to 'center'\n * @private\n */\nexport const _toLeftRightCenter = (align: 'start' | 'end' | 'center') => align === 'start' ? 'left' : align === 'end' ? 'right' : 'center';\n\n/**\n * Returns `start`, `end` or `(start + end) / 2` depending on `align`. Defaults to `center`\n * @private\n */\nexport const _alignStartEnd = (align: 'start' | 'end' | 'center', start: number, end: number) => align === 'start' ? start : align === 'end' ? end : (start + end) / 2;\n\n/**\n * Returns `left`, `right` or `(left + right) / 2` depending on `align`. Defaults to `left`\n * @private\n */\nexport const _textX = (align: 'left' | 'right' | 'center', left: number, right: number, rtl: boolean) => {\n const check = rtl ? 'left' : 'right';\n return align === check ? right : align === 'center' ? (left + right) / 2 : left;\n};\n\n/**\n * Return start and count of visible points.\n * @private\n */\nexport function _getStartAndCountOfVisiblePoints(meta: ChartMeta<'line' | 'scatter'>, points: PointElement[], animationsDisabled: boolean) {\n const pointCount = points.length;\n\n let start = 0;\n let count = pointCount;\n\n if (meta._sorted) {\n const {iScale, vScale, _parsed} = meta;\n const spanGaps = meta.dataset ? meta.dataset.options ? meta.dataset.options.spanGaps : null : null;\n const axis = iScale.axis;\n const {min, max, minDefined, maxDefined} = iScale.getUserBounds();\n\n if (minDefined) {\n start = Math.min(\n // @ts-expect-error Need to type _parsed\n _lookupByKey(_parsed, axis, min).lo,\n // @ts-expect-error Need to fix types on _lookupByKey\n animationsDisabled ? pointCount : _lookupByKey(points, axis, iScale.getPixelForValue(min)).lo);\n if (spanGaps) {\n const distanceToDefinedLo = (_parsed\n .slice(0, start + 1)\n .reverse()\n .findIndex(\n point => !isNullOrUndef(point[vScale.axis])));\n start -= Math.max(0, distanceToDefinedLo);\n }\n start = _limitValue(start, 0, pointCount - 1);\n }\n if (maxDefined) {\n let end = Math.max(\n // @ts-expect-error Need to type _parsed\n _lookupByKey(_parsed, iScale.axis, max, true).hi + 1,\n // @ts-expect-error Need to fix types on _lookupByKey\n animationsDisabled ? 0 : _lookupByKey(points, axis, iScale.getPixelForValue(max), true).hi + 1);\n if (spanGaps) {\n const distanceToDefinedHi = (_parsed\n .slice(end - 1)\n .findIndex(\n point => !isNullOrUndef(point[vScale.axis])));\n end += Math.max(0, distanceToDefinedHi);\n }\n count = _limitValue(end, start, pointCount) - start;\n } else {\n count = pointCount - start;\n }\n }\n\n return {start, count};\n}\n\n/**\n * Checks if the scale ranges have changed.\n * @param {object} meta - dataset meta.\n * @returns {boolean}\n * @private\n */\nexport function _scaleRangesChanged(meta) {\n const {xScale, yScale, _scaleRanges} = meta;\n const newRanges = {\n xmin: xScale.min,\n xmax: xScale.max,\n ymin: yScale.min,\n ymax: yScale.max\n };\n if (!_scaleRanges) {\n meta._scaleRanges = newRanges;\n return true;\n }\n const changed = _scaleRanges.xmin !== xScale.min\n\t\t|| _scaleRanges.xmax !== xScale.max\n\t\t|| _scaleRanges.ymin !== yScale.min\n\t\t|| _scaleRanges.ymax !== yScale.max;\n\n Object.assign(_scaleRanges, newRanges);\n return changed;\n}\n","import {PI, TAU, HALF_PI} from './helpers.math.js';\n\nconst atEdge = (t: number) => t === 0 || t === 1;\nconst elasticIn = (t: number, s: number, p: number) => -(Math.pow(2, 10 * (t -= 1)) * Math.sin((t - s) * TAU / p));\nconst elasticOut = (t: number, s: number, p: number) => Math.pow(2, -10 * t) * Math.sin((t - s) * TAU / p) + 1;\n\n/**\n * Easing functions adapted from Robert Penner's easing equations.\n * @namespace Chart.helpers.easing.effects\n * @see http://www.robertpenner.com/easing/\n */\nconst effects = {\n linear: (t: number) => t,\n\n easeInQuad: (t: number) => t * t,\n\n easeOutQuad: (t: number) => -t * (t - 2),\n\n easeInOutQuad: (t: number) => ((t /= 0.5) < 1)\n ? 0.5 * t * t\n : -0.5 * ((--t) * (t - 2) - 1),\n\n easeInCubic: (t: number) => t * t * t,\n\n easeOutCubic: (t: number) => (t -= 1) * t * t + 1,\n\n easeInOutCubic: (t: number) => ((t /= 0.5) < 1)\n ? 0.5 * t * t * t\n : 0.5 * ((t -= 2) * t * t + 2),\n\n easeInQuart: (t: number) => t * t * t * t,\n\n easeOutQuart: (t: number) => -((t -= 1) * t * t * t - 1),\n\n easeInOutQuart: (t: number) => ((t /= 0.5) < 1)\n ? 0.5 * t * t * t * t\n : -0.5 * ((t -= 2) * t * t * t - 2),\n\n easeInQuint: (t: number) => t * t * t * t * t,\n\n easeOutQuint: (t: number) => (t -= 1) * t * t * t * t + 1,\n\n easeInOutQuint: (t: number) => ((t /= 0.5) < 1)\n ? 0.5 * t * t * t * t * t\n : 0.5 * ((t -= 2) * t * t * t * t + 2),\n\n easeInSine: (t: number) => -Math.cos(t * HALF_PI) + 1,\n\n easeOutSine: (t: number) => Math.sin(t * HALF_PI),\n\n easeInOutSine: (t: number) => -0.5 * (Math.cos(PI * t) - 1),\n\n easeInExpo: (t: number) => (t === 0) ? 0 : Math.pow(2, 10 * (t - 1)),\n\n easeOutExpo: (t: number) => (t === 1) ? 1 : -Math.pow(2, -10 * t) + 1,\n\n easeInOutExpo: (t: number) => atEdge(t) ? t : t < 0.5\n ? 0.5 * Math.pow(2, 10 * (t * 2 - 1))\n : 0.5 * (-Math.pow(2, -10 * (t * 2 - 1)) + 2),\n\n easeInCirc: (t: number) => (t >= 1) ? t : -(Math.sqrt(1 - t * t) - 1),\n\n easeOutCirc: (t: number) => Math.sqrt(1 - (t -= 1) * t),\n\n easeInOutCirc: (t: number) => ((t /= 0.5) < 1)\n ? -0.5 * (Math.sqrt(1 - t * t) - 1)\n : 0.5 * (Math.sqrt(1 - (t -= 2) * t) + 1),\n\n easeInElastic: (t: number) => atEdge(t) ? t : elasticIn(t, 0.075, 0.3),\n\n easeOutElastic: (t: number) => atEdge(t) ? t : elasticOut(t, 0.075, 0.3),\n\n easeInOutElastic(t: number) {\n const s = 0.1125;\n const p = 0.45;\n return atEdge(t) ? t :\n t < 0.5\n ? 0.5 * elasticIn(t * 2, s, p)\n : 0.5 + 0.5 * elasticOut(t * 2 - 1, s, p);\n },\n\n easeInBack(t: number) {\n const s = 1.70158;\n return t * t * ((s + 1) * t - s);\n },\n\n easeOutBack(t: number) {\n const s = 1.70158;\n return (t -= 1) * t * ((s + 1) * t + s) + 1;\n },\n\n easeInOutBack(t: number) {\n let s = 1.70158;\n if ((t /= 0.5) < 1) {\n return 0.5 * (t * t * (((s *= (1.525)) + 1) * t - s));\n }\n return 0.5 * ((t -= 2) * t * (((s *= (1.525)) + 1) * t + s) + 2);\n },\n\n easeInBounce: (t: number) => 1 - effects.easeOutBounce(1 - t),\n\n easeOutBounce(t: number) {\n const m = 7.5625;\n const d = 2.75;\n if (t < (1 / d)) {\n return m * t * t;\n }\n if (t < (2 / d)) {\n return m * (t -= (1.5 / d)) * t + 0.75;\n }\n if (t < (2.5 / d)) {\n return m * (t -= (2.25 / d)) * t + 0.9375;\n }\n return m * (t -= (2.625 / d)) * t + 0.984375;\n },\n\n easeInOutBounce: (t: number) => (t < 0.5)\n ? effects.easeInBounce(t * 2) * 0.5\n : effects.easeOutBounce(t * 2 - 1) * 0.5 + 0.5,\n} as const;\n\nexport type EasingFunction = keyof typeof effects\n\nexport default effects;\n","import {Color} from '@kurkle/color';\n\nexport function isPatternOrGradient(value: unknown): value is CanvasPattern | CanvasGradient {\n if (value && typeof value === 'object') {\n const type = value.toString();\n return type === '[object CanvasPattern]' || type === '[object CanvasGradient]';\n }\n\n return false;\n}\n\nexport function color(value: CanvasGradient): CanvasGradient;\nexport function color(value: CanvasPattern): CanvasPattern;\nexport function color(\n value:\n | string\n | { r: number; g: number; b: number; a: number }\n | [number, number, number]\n | [number, number, number, number]\n): Color;\nexport function color(value) {\n return isPatternOrGradient(value) ? value : new Color(value);\n}\n\nexport function getHoverColor(value: CanvasGradient): CanvasGradient;\nexport function getHoverColor(value: CanvasPattern): CanvasPattern;\nexport function getHoverColor(value: string): string;\nexport function getHoverColor(value) {\n return isPatternOrGradient(value)\n ? value\n : new Color(value).saturate(0.5).darken(0.1).hexString();\n}\n","const numbers = ['x', 'y', 'borderWidth', 'radius', 'tension'];\nconst colors = ['color', 'borderColor', 'backgroundColor'];\n\nexport function applyAnimationsDefaults(defaults) {\n defaults.set('animation', {\n delay: undefined,\n duration: 1000,\n easing: 'easeOutQuart',\n fn: undefined,\n from: undefined,\n loop: undefined,\n to: undefined,\n type: undefined,\n });\n\n defaults.describe('animation', {\n _fallback: false,\n _indexable: false,\n _scriptable: (name) => name !== 'onProgress' && name !== 'onComplete' && name !== 'fn',\n });\n\n defaults.set('animations', {\n colors: {\n type: 'color',\n properties: colors\n },\n numbers: {\n type: 'number',\n properties: numbers\n },\n });\n\n defaults.describe('animations', {\n _fallback: 'animation',\n });\n\n defaults.set('transitions', {\n active: {\n animation: {\n duration: 400\n }\n },\n resize: {\n animation: {\n duration: 0\n }\n },\n show: {\n animations: {\n colors: {\n from: 'transparent'\n },\n visible: {\n type: 'boolean',\n duration: 0 // show immediately\n },\n }\n },\n hide: {\n animations: {\n colors: {\n to: 'transparent'\n },\n visible: {\n type: 'boolean',\n easing: 'linear',\n fn: v => v | 0 // for keeping the dataset visible all the way through the animation\n },\n }\n }\n });\n}\n","export function applyLayoutsDefaults(defaults) {\n defaults.set('layout', {\n autoPadding: true,\n padding: {\n top: 0,\n right: 0,\n bottom: 0,\n left: 0\n }\n });\n}\n","\nconst intlCache = new Map();\n\nfunction getNumberFormat(locale: string, options?: Intl.NumberFormatOptions) {\n options = options || {};\n const cacheKey = locale + JSON.stringify(options);\n let formatter = intlCache.get(cacheKey);\n if (!formatter) {\n formatter = new Intl.NumberFormat(locale, options);\n intlCache.set(cacheKey, formatter);\n }\n return formatter;\n}\n\nexport function formatNumber(num: number, locale: string, options?: Intl.NumberFormatOptions) {\n return getNumberFormat(locale, options).format(num);\n}\n","import {isArray} from '../helpers/helpers.core.js';\nimport {formatNumber} from '../helpers/helpers.intl.js';\nimport {log10} from '../helpers/helpers.math.js';\n\n/**\n * Namespace to hold formatters for different types of ticks\n * @namespace Chart.Ticks.formatters\n */\nconst formatters = {\n /**\n * Formatter for value labels\n * @method Chart.Ticks.formatters.values\n * @param value the value to display\n * @return {string|string[]} the label to display\n */\n values(value) {\n return isArray(value) ? /** @type {string[]} */ (value) : '' + value;\n },\n\n /**\n * Formatter for numeric ticks\n * @method Chart.Ticks.formatters.numeric\n * @param tickValue {number} the value to be formatted\n * @param index {number} the position of the tickValue parameter in the ticks array\n * @param ticks {object[]} the list of ticks being converted\n * @return {string} string representation of the tickValue parameter\n */\n numeric(tickValue, index, ticks) {\n if (tickValue === 0) {\n return '0'; // never show decimal places for 0\n }\n\n const locale = this.chart.options.locale;\n let notation;\n let delta = tickValue; // This is used when there are less than 2 ticks as the tick interval.\n\n if (ticks.length > 1) {\n // all ticks are small or there huge numbers; use scientific notation\n const maxTick = Math.max(Math.abs(ticks[0].value), Math.abs(ticks[ticks.length - 1].value));\n if (maxTick < 1e-4 || maxTick > 1e+15) {\n notation = 'scientific';\n }\n\n delta = calculateDelta(tickValue, ticks);\n }\n\n const logDelta = log10(Math.abs(delta));\n\n // When datasets have values approaching Number.MAX_VALUE, the tick calculations might result in\n // infinity and eventually NaN. Passing NaN for minimumFractionDigits or maximumFractionDigits\n // will make the number formatter throw. So instead we check for isNaN and use a fallback value.\n //\n // toFixed has a max of 20 decimal places\n const numDecimal = isNaN(logDelta) ? 1 : Math.max(Math.min(-1 * Math.floor(logDelta), 20), 0);\n\n const options = {notation, minimumFractionDigits: numDecimal, maximumFractionDigits: numDecimal};\n Object.assign(options, this.options.ticks.format);\n\n return formatNumber(tickValue, locale, options);\n },\n\n\n /**\n * Formatter for logarithmic ticks\n * @method Chart.Ticks.formatters.logarithmic\n * @param tickValue {number} the value to be formatted\n * @param index {number} the position of the tickValue parameter in the ticks array\n * @param ticks {object[]} the list of ticks being converted\n * @return {string} string representation of the tickValue parameter\n */\n logarithmic(tickValue, index, ticks) {\n if (tickValue === 0) {\n return '0';\n }\n const remain = ticks[index].significand || (tickValue / (Math.pow(10, Math.floor(log10(tickValue)))));\n if ([1, 2, 3, 5, 10, 15].includes(remain) || index > 0.8 * ticks.length) {\n return formatters.numeric.call(this, tickValue, index, ticks);\n }\n return '';\n }\n\n};\n\n\nfunction calculateDelta(tickValue, ticks) {\n // Figure out how many digits to show\n // The space between the first two ticks might be smaller than normal spacing\n let delta = ticks.length > 3 ? ticks[2].value - ticks[1].value : ticks[1].value - ticks[0].value;\n\n // If we have a number like 2.5 as the delta, figure out how many decimal places we need\n if (Math.abs(delta) >= 1 && tickValue !== Math.floor(tickValue)) {\n // not an integer\n delta = tickValue - Math.floor(tickValue);\n }\n return delta;\n}\n\n/**\n * Namespace to hold static tick generation functions\n * @namespace Chart.Ticks\n */\nexport default {formatters};\n","import Ticks from './core.ticks.js';\n\nexport function applyScaleDefaults(defaults) {\n defaults.set('scale', {\n display: true,\n offset: false,\n reverse: false,\n beginAtZero: false,\n\n /**\n * Scale boundary strategy (bypassed by min/max time options)\n * - `data`: make sure data are fully visible, ticks outside are removed\n * - `ticks`: make sure ticks are fully visible, data outside are truncated\n * @see https://github.com/chartjs/Chart.js/pull/4556\n * @since 3.0.0\n */\n bounds: 'ticks',\n\n clip: true,\n\n /**\n * Addition grace added to max and reduced from min data value.\n * @since 3.0.0\n */\n grace: 0,\n\n // grid line settings\n grid: {\n display: true,\n lineWidth: 1,\n drawOnChartArea: true,\n drawTicks: true,\n tickLength: 8,\n tickWidth: (_ctx, options) => options.lineWidth,\n tickColor: (_ctx, options) => options.color,\n offset: false,\n },\n\n border: {\n display: true,\n dash: [],\n dashOffset: 0.0,\n width: 1\n },\n\n // scale title\n title: {\n // display property\n display: false,\n\n // actual label\n text: '',\n\n // top/bottom padding\n padding: {\n top: 4,\n bottom: 4\n }\n },\n\n // label settings\n ticks: {\n minRotation: 0,\n maxRotation: 50,\n mirror: false,\n textStrokeWidth: 0,\n textStrokeColor: '',\n padding: 3,\n display: true,\n autoSkip: true,\n autoSkipPadding: 3,\n labelOffset: 0,\n // We pass through arrays to be rendered as multiline labels, we convert Others to strings here.\n callback: Ticks.formatters.values,\n minor: {},\n major: {},\n align: 'center',\n crossAlign: 'near',\n\n showLabelBackdrop: false,\n backdropColor: 'rgba(255, 255, 255, 0.75)',\n backdropPadding: 2,\n }\n });\n\n defaults.route('scale.ticks', 'color', '', 'color');\n defaults.route('scale.grid', 'color', '', 'borderColor');\n defaults.route('scale.border', 'color', '', 'borderColor');\n defaults.route('scale.title', 'color', '', 'color');\n\n defaults.describe('scale', {\n _fallback: false,\n _scriptable: (name) => !name.startsWith('before') && !name.startsWith('after') && name !== 'callback' && name !== 'parser',\n _indexable: (name) => name !== 'borderDash' && name !== 'tickBorderDash' && name !== 'dash',\n });\n\n defaults.describe('scales', {\n _fallback: 'scale',\n });\n\n defaults.describe('scale.ticks', {\n _scriptable: (name) => name !== 'backdropPadding' && name !== 'callback',\n _indexable: (name) => name !== 'backdropPadding',\n });\n}\n","import {getHoverColor} from '../helpers/helpers.color.js';\nimport {isObject, merge, valueOrDefault} from '../helpers/helpers.core.js';\nimport {applyAnimationsDefaults} from './core.animations.defaults.js';\nimport {applyLayoutsDefaults} from './core.layouts.defaults.js';\nimport {applyScaleDefaults} from './core.scale.defaults.js';\n\nexport const overrides = Object.create(null);\nexport const descriptors = Object.create(null);\n\n/**\n * @param {object} node\n * @param {string} key\n * @return {object}\n */\nfunction getScope(node, key) {\n if (!key) {\n return node;\n }\n const keys = key.split('.');\n for (let i = 0, n = keys.length; i < n; ++i) {\n const k = keys[i];\n node = node[k] || (node[k] = Object.create(null));\n }\n return node;\n}\n\nfunction set(root, scope, values) {\n if (typeof scope === 'string') {\n return merge(getScope(root, scope), values);\n }\n return merge(getScope(root, ''), scope);\n}\n\n/**\n * Please use the module's default export which provides a singleton instance\n * Note: class is exported for typedoc\n */\nexport class Defaults {\n constructor(_descriptors, _appliers) {\n this.animation = undefined;\n this.backgroundColor = 'rgba(0,0,0,0.1)';\n this.borderColor = 'rgba(0,0,0,0.1)';\n this.color = '#666';\n this.datasets = {};\n this.devicePixelRatio = (context) => context.chart.platform.getDevicePixelRatio();\n this.elements = {};\n this.events = [\n 'mousemove',\n 'mouseout',\n 'click',\n 'touchstart',\n 'touchmove'\n ];\n this.font = {\n family: \"'Helvetica Neue', 'Helvetica', 'Arial', sans-serif\",\n size: 12,\n style: 'normal',\n lineHeight: 1.2,\n weight: null\n };\n this.hover = {};\n this.hoverBackgroundColor = (ctx, options) => getHoverColor(options.backgroundColor);\n this.hoverBorderColor = (ctx, options) => getHoverColor(options.borderColor);\n this.hoverColor = (ctx, options) => getHoverColor(options.color);\n this.indexAxis = 'x';\n this.interaction = {\n mode: 'nearest',\n intersect: true,\n includeInvisible: false\n };\n this.maintainAspectRatio = true;\n this.onHover = null;\n this.onClick = null;\n this.parsing = true;\n this.plugins = {};\n this.responsive = true;\n this.scale = undefined;\n this.scales = {};\n this.showLine = true;\n this.drawActiveElementsOnTop = true;\n\n this.describe(_descriptors);\n this.apply(_appliers);\n }\n\n /**\n\t * @param {string|object} scope\n\t * @param {object} [values]\n\t */\n set(scope, values) {\n return set(this, scope, values);\n }\n\n /**\n\t * @param {string} scope\n\t */\n get(scope) {\n return getScope(this, scope);\n }\n\n /**\n\t * @param {string|object} scope\n\t * @param {object} [values]\n\t */\n describe(scope, values) {\n return set(descriptors, scope, values);\n }\n\n override(scope, values) {\n return set(overrides, scope, values);\n }\n\n /**\n\t * Routes the named defaults to fallback to another scope/name.\n\t * This routing is useful when those target values, like defaults.color, are changed runtime.\n\t * If the values would be copied, the runtime change would not take effect. By routing, the\n\t * fallback is evaluated at each access, so its always up to date.\n\t *\n\t * Example:\n\t *\n\t * \tdefaults.route('elements.arc', 'backgroundColor', '', 'color')\n\t * - reads the backgroundColor from defaults.color when undefined locally\n\t *\n\t * @param {string} scope Scope this route applies to.\n\t * @param {string} name Property name that should be routed to different namespace when not defined here.\n\t * @param {string} targetScope The namespace where those properties should be routed to.\n\t * Empty string ('') is the root of defaults.\n\t * @param {string} targetName The target name in the target scope the property should be routed to.\n\t */\n route(scope, name, targetScope, targetName) {\n const scopeObject = getScope(this, scope);\n const targetScopeObject = getScope(this, targetScope);\n const privateName = '_' + name;\n\n Object.defineProperties(scopeObject, {\n // A private property is defined to hold the actual value, when this property is set in its scope (set in the setter)\n [privateName]: {\n value: scopeObject[name],\n writable: true\n },\n // The actual property is defined as getter/setter so we can do the routing when value is not locally set.\n [name]: {\n enumerable: true,\n get() {\n const local = this[privateName];\n const target = targetScopeObject[targetName];\n if (isObject(local)) {\n return Object.assign({}, target, local);\n }\n return valueOrDefault(local, target);\n },\n set(value) {\n this[privateName] = value;\n }\n }\n });\n }\n\n apply(appliers) {\n appliers.forEach((apply) => apply(this));\n }\n}\n\n// singleton instance\nexport default /* #__PURE__ */ new Defaults({\n _scriptable: (name) => !name.startsWith('on'),\n _indexable: (name) => name !== 'events',\n hover: {\n _fallback: 'interaction'\n },\n interaction: {\n _scriptable: false,\n _indexable: false,\n }\n}, [applyAnimationsDefaults, applyLayoutsDefaults, applyScaleDefaults]);\n","import type {\n Chart,\n Point,\n FontSpec,\n CanvasFontSpec,\n PointStyle,\n RenderTextOpts,\n BackdropOptions\n} from '../types/index.js';\nimport type {\n TRBL,\n SplinePoint,\n RoundedRect,\n TRBLCorners\n} from '../types/geometric.js';\nimport {isArray, isNullOrUndef} from './helpers.core.js';\nimport {PI, TAU, HALF_PI, QUARTER_PI, TWO_THIRDS_PI, RAD_PER_DEG} from './helpers.math.js';\n\n/**\n * Converts the given font object into a CSS font string.\n * @param font - A font object.\n * @return The CSS font string. See https://developer.mozilla.org/en-US/docs/Web/CSS/font\n * @private\n */\nexport function toFontString(font: FontSpec) {\n if (!font || isNullOrUndef(font.size) || isNullOrUndef(font.family)) {\n return null;\n }\n\n return (font.style ? font.style + ' ' : '')\n\t\t+ (font.weight ? font.weight + ' ' : '')\n\t\t+ font.size + 'px '\n\t\t+ font.family;\n}\n\n/**\n * @private\n */\nexport function _measureText(\n ctx: CanvasRenderingContext2D,\n data: Record,\n gc: string[],\n longest: number,\n string: string\n) {\n let textWidth = data[string];\n if (!textWidth) {\n textWidth = data[string] = ctx.measureText(string).width;\n gc.push(string);\n }\n if (textWidth > longest) {\n longest = textWidth;\n }\n return longest;\n}\n\ntype Thing = string | undefined | null\ntype Things = (Thing | Thing[])[]\n\n/**\n * @private\n */\n// eslint-disable-next-line complexity\nexport function _longestText(\n ctx: CanvasRenderingContext2D,\n font: string,\n arrayOfThings: Things,\n cache?: {data?: Record, garbageCollect?: string[], font?: string}\n) {\n cache = cache || {};\n let data = cache.data = cache.data || {};\n let gc = cache.garbageCollect = cache.garbageCollect || [];\n\n if (cache.font !== font) {\n data = cache.data = {};\n gc = cache.garbageCollect = [];\n cache.font = font;\n }\n\n ctx.save();\n\n ctx.font = font;\n let longest = 0;\n const ilen = arrayOfThings.length;\n let i: number, j: number, jlen: number, thing: Thing | Thing[], nestedThing: Thing | Thing[];\n for (i = 0; i < ilen; i++) {\n thing = arrayOfThings[i];\n\n // Undefined strings and arrays should not be measured\n if (thing !== undefined && thing !== null && !isArray(thing)) {\n longest = _measureText(ctx, data, gc, longest, thing);\n } else if (isArray(thing)) {\n // if it is an array lets measure each element\n // to do maybe simplify this function a bit so we can do this more recursively?\n for (j = 0, jlen = thing.length; j < jlen; j++) {\n nestedThing = thing[j];\n // Undefined strings and arrays should not be measured\n if (nestedThing !== undefined && nestedThing !== null && !isArray(nestedThing)) {\n longest = _measureText(ctx, data, gc, longest, nestedThing);\n }\n }\n }\n }\n\n ctx.restore();\n\n const gcLen = gc.length / 2;\n if (gcLen > arrayOfThings.length) {\n for (i = 0; i < gcLen; i++) {\n delete data[gc[i]];\n }\n gc.splice(0, gcLen);\n }\n return longest;\n}\n\n/**\n * Returns the aligned pixel value to avoid anti-aliasing blur\n * @param chart - The chart instance.\n * @param pixel - A pixel value.\n * @param width - The width of the element.\n * @returns The aligned pixel value.\n * @private\n */\nexport function _alignPixel(chart: Chart, pixel: number, width: number) {\n const devicePixelRatio = chart.currentDevicePixelRatio;\n const halfWidth = width !== 0 ? Math.max(width / 2, 0.5) : 0;\n return Math.round((pixel - halfWidth) * devicePixelRatio) / devicePixelRatio + halfWidth;\n}\n\n/**\n * Clears the entire canvas.\n */\nexport function clearCanvas(canvas?: HTMLCanvasElement, ctx?: CanvasRenderingContext2D) {\n if (!ctx && !canvas) {\n return;\n }\n\n ctx = ctx || canvas.getContext('2d');\n\n ctx.save();\n // canvas.width and canvas.height do not consider the canvas transform,\n // while clearRect does\n ctx.resetTransform();\n ctx.clearRect(0, 0, canvas.width, canvas.height);\n ctx.restore();\n}\n\nexport interface DrawPointOptions {\n pointStyle: PointStyle;\n rotation?: number;\n radius: number;\n borderWidth: number;\n}\n\nexport function drawPoint(\n ctx: CanvasRenderingContext2D,\n options: DrawPointOptions,\n x: number,\n y: number\n) {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n drawPointLegend(ctx, options, x, y, null);\n}\n\n// eslint-disable-next-line complexity\nexport function drawPointLegend(\n ctx: CanvasRenderingContext2D,\n options: DrawPointOptions,\n x: number,\n y: number,\n w: number\n) {\n let type: string, xOffset: number, yOffset: number, size: number, cornerRadius: number, width: number, xOffsetW: number, yOffsetW: number;\n const style = options.pointStyle;\n const rotation = options.rotation;\n const radius = options.radius;\n let rad = (rotation || 0) * RAD_PER_DEG;\n\n if (style && typeof style === 'object') {\n type = style.toString();\n if (type === '[object HTMLImageElement]' || type === '[object HTMLCanvasElement]') {\n ctx.save();\n ctx.translate(x, y);\n ctx.rotate(rad);\n ctx.drawImage(style, -style.width / 2, -style.height / 2, style.width, style.height);\n ctx.restore();\n return;\n }\n }\n\n if (isNaN(radius) || radius <= 0) {\n return;\n }\n\n ctx.beginPath();\n\n switch (style) {\n // Default includes circle\n default:\n if (w) {\n ctx.ellipse(x, y, w / 2, radius, 0, 0, TAU);\n } else {\n ctx.arc(x, y, radius, 0, TAU);\n }\n ctx.closePath();\n break;\n case 'triangle':\n width = w ? w / 2 : radius;\n ctx.moveTo(x + Math.sin(rad) * width, y - Math.cos(rad) * radius);\n rad += TWO_THIRDS_PI;\n ctx.lineTo(x + Math.sin(rad) * width, y - Math.cos(rad) * radius);\n rad += TWO_THIRDS_PI;\n ctx.lineTo(x + Math.sin(rad) * width, y - Math.cos(rad) * radius);\n ctx.closePath();\n break;\n case 'rectRounded':\n // NOTE: the rounded rect implementation changed to use `arc` instead of\n // `quadraticCurveTo` since it generates better results when rect is\n // almost a circle. 0.516 (instead of 0.5) produces results with visually\n // closer proportion to the previous impl and it is inscribed in the\n // circle with `radius`. For more details, see the following PRs:\n // https://github.com/chartjs/Chart.js/issues/5597\n // https://github.com/chartjs/Chart.js/issues/5858\n cornerRadius = radius * 0.516;\n size = radius - cornerRadius;\n xOffset = Math.cos(rad + QUARTER_PI) * size;\n xOffsetW = Math.cos(rad + QUARTER_PI) * (w ? w / 2 - cornerRadius : size);\n yOffset = Math.sin(rad + QUARTER_PI) * size;\n yOffsetW = Math.sin(rad + QUARTER_PI) * (w ? w / 2 - cornerRadius : size);\n ctx.arc(x - xOffsetW, y - yOffset, cornerRadius, rad - PI, rad - HALF_PI);\n ctx.arc(x + yOffsetW, y - xOffset, cornerRadius, rad - HALF_PI, rad);\n ctx.arc(x + xOffsetW, y + yOffset, cornerRadius, rad, rad + HALF_PI);\n ctx.arc(x - yOffsetW, y + xOffset, cornerRadius, rad + HALF_PI, rad + PI);\n ctx.closePath();\n break;\n case 'rect':\n if (!rotation) {\n size = Math.SQRT1_2 * radius;\n width = w ? w / 2 : size;\n ctx.rect(x - width, y - size, 2 * width, 2 * size);\n break;\n }\n rad += QUARTER_PI;\n /* falls through */\n case 'rectRot':\n xOffsetW = Math.cos(rad) * (w ? w / 2 : radius);\n xOffset = Math.cos(rad) * radius;\n yOffset = Math.sin(rad) * radius;\n yOffsetW = Math.sin(rad) * (w ? w / 2 : radius);\n ctx.moveTo(x - xOffsetW, y - yOffset);\n ctx.lineTo(x + yOffsetW, y - xOffset);\n ctx.lineTo(x + xOffsetW, y + yOffset);\n ctx.lineTo(x - yOffsetW, y + xOffset);\n ctx.closePath();\n break;\n case 'crossRot':\n rad += QUARTER_PI;\n /* falls through */\n case 'cross':\n xOffsetW = Math.cos(rad) * (w ? w / 2 : radius);\n xOffset = Math.cos(rad) * radius;\n yOffset = Math.sin(rad) * radius;\n yOffsetW = Math.sin(rad) * (w ? w / 2 : radius);\n ctx.moveTo(x - xOffsetW, y - yOffset);\n ctx.lineTo(x + xOffsetW, y + yOffset);\n ctx.moveTo(x + yOffsetW, y - xOffset);\n ctx.lineTo(x - yOffsetW, y + xOffset);\n break;\n case 'star':\n xOffsetW = Math.cos(rad) * (w ? w / 2 : radius);\n xOffset = Math.cos(rad) * radius;\n yOffset = Math.sin(rad) * radius;\n yOffsetW = Math.sin(rad) * (w ? w / 2 : radius);\n ctx.moveTo(x - xOffsetW, y - yOffset);\n ctx.lineTo(x + xOffsetW, y + yOffset);\n ctx.moveTo(x + yOffsetW, y - xOffset);\n ctx.lineTo(x - yOffsetW, y + xOffset);\n rad += QUARTER_PI;\n xOffsetW = Math.cos(rad) * (w ? w / 2 : radius);\n xOffset = Math.cos(rad) * radius;\n yOffset = Math.sin(rad) * radius;\n yOffsetW = Math.sin(rad) * (w ? w / 2 : radius);\n ctx.moveTo(x - xOffsetW, y - yOffset);\n ctx.lineTo(x + xOffsetW, y + yOffset);\n ctx.moveTo(x + yOffsetW, y - xOffset);\n ctx.lineTo(x - yOffsetW, y + xOffset);\n break;\n case 'line':\n xOffset = w ? w / 2 : Math.cos(rad) * radius;\n yOffset = Math.sin(rad) * radius;\n ctx.moveTo(x - xOffset, y - yOffset);\n ctx.lineTo(x + xOffset, y + yOffset);\n break;\n case 'dash':\n ctx.moveTo(x, y);\n ctx.lineTo(x + Math.cos(rad) * (w ? w / 2 : radius), y + Math.sin(rad) * radius);\n break;\n case false:\n ctx.closePath();\n break;\n }\n\n ctx.fill();\n if (options.borderWidth > 0) {\n ctx.stroke();\n }\n}\n\n/**\n * Returns true if the point is inside the rectangle\n * @param point - The point to test\n * @param area - The rectangle\n * @param margin - allowed margin\n * @private\n */\nexport function _isPointInArea(\n point: Point,\n area: TRBL,\n margin?: number\n) {\n margin = margin || 0.5; // margin - default is to match rounded decimals\n\n return !area || (point && point.x > area.left - margin && point.x < area.right + margin &&\n\t\tpoint.y > area.top - margin && point.y < area.bottom + margin);\n}\n\nexport function clipArea(ctx: CanvasRenderingContext2D, area: TRBL) {\n ctx.save();\n ctx.beginPath();\n ctx.rect(area.left, area.top, area.right - area.left, area.bottom - area.top);\n ctx.clip();\n}\n\nexport function unclipArea(ctx: CanvasRenderingContext2D) {\n ctx.restore();\n}\n\n/**\n * @private\n */\nexport function _steppedLineTo(\n ctx: CanvasRenderingContext2D,\n previous: Point,\n target: Point,\n flip?: boolean,\n mode?: string\n) {\n if (!previous) {\n return ctx.lineTo(target.x, target.y);\n }\n if (mode === 'middle') {\n const midpoint = (previous.x + target.x) / 2.0;\n ctx.lineTo(midpoint, previous.y);\n ctx.lineTo(midpoint, target.y);\n } else if (mode === 'after' !== !!flip) {\n ctx.lineTo(previous.x, target.y);\n } else {\n ctx.lineTo(target.x, previous.y);\n }\n ctx.lineTo(target.x, target.y);\n}\n\n/**\n * @private\n */\nexport function _bezierCurveTo(\n ctx: CanvasRenderingContext2D,\n previous: SplinePoint,\n target: SplinePoint,\n flip?: boolean\n) {\n if (!previous) {\n return ctx.lineTo(target.x, target.y);\n }\n ctx.bezierCurveTo(\n flip ? previous.cp1x : previous.cp2x,\n flip ? previous.cp1y : previous.cp2y,\n flip ? target.cp2x : target.cp1x,\n flip ? target.cp2y : target.cp1y,\n target.x,\n target.y);\n}\n\nfunction setRenderOpts(ctx: CanvasRenderingContext2D, opts: RenderTextOpts) {\n if (opts.translation) {\n ctx.translate(opts.translation[0], opts.translation[1]);\n }\n\n if (!isNullOrUndef(opts.rotation)) {\n ctx.rotate(opts.rotation);\n }\n\n if (opts.color) {\n ctx.fillStyle = opts.color;\n }\n\n if (opts.textAlign) {\n ctx.textAlign = opts.textAlign;\n }\n\n if (opts.textBaseline) {\n ctx.textBaseline = opts.textBaseline;\n }\n}\n\nfunction decorateText(\n ctx: CanvasRenderingContext2D,\n x: number,\n y: number,\n line: string,\n opts: RenderTextOpts\n) {\n if (opts.strikethrough || opts.underline) {\n /**\n * Now that IE11 support has been dropped, we can use more\n * of the TextMetrics object. The actual bounding boxes\n * are unflagged in Chrome, Firefox, Edge, and Safari so they\n * can be safely used.\n * See https://developer.mozilla.org/en-US/docs/Web/API/TextMetrics#Browser_compatibility\n */\n const metrics = ctx.measureText(line);\n const left = x - metrics.actualBoundingBoxLeft;\n const right = x + metrics.actualBoundingBoxRight;\n const top = y - metrics.actualBoundingBoxAscent;\n const bottom = y + metrics.actualBoundingBoxDescent;\n const yDecoration = opts.strikethrough ? (top + bottom) / 2 : bottom;\n\n ctx.strokeStyle = ctx.fillStyle;\n ctx.beginPath();\n ctx.lineWidth = opts.decorationWidth || 2;\n ctx.moveTo(left, yDecoration);\n ctx.lineTo(right, yDecoration);\n ctx.stroke();\n }\n}\n\nfunction drawBackdrop(ctx: CanvasRenderingContext2D, opts: BackdropOptions) {\n const oldColor = ctx.fillStyle;\n\n ctx.fillStyle = opts.color as string;\n ctx.fillRect(opts.left, opts.top, opts.width, opts.height);\n ctx.fillStyle = oldColor;\n}\n\n/**\n * Render text onto the canvas\n */\nexport function renderText(\n ctx: CanvasRenderingContext2D,\n text: string | string[],\n x: number,\n y: number,\n font: CanvasFontSpec,\n opts: RenderTextOpts = {}\n) {\n const lines = isArray(text) ? text : [text];\n const stroke = opts.strokeWidth > 0 && opts.strokeColor !== '';\n let i: number, line: string;\n\n ctx.save();\n ctx.font = font.string;\n setRenderOpts(ctx, opts);\n\n for (i = 0; i < lines.length; ++i) {\n line = lines[i];\n\n if (opts.backdrop) {\n drawBackdrop(ctx, opts.backdrop);\n }\n\n if (stroke) {\n if (opts.strokeColor) {\n ctx.strokeStyle = opts.strokeColor;\n }\n\n if (!isNullOrUndef(opts.strokeWidth)) {\n ctx.lineWidth = opts.strokeWidth;\n }\n\n ctx.strokeText(line, x, y, opts.maxWidth);\n }\n\n ctx.fillText(line, x, y, opts.maxWidth);\n decorateText(ctx, x, y, line, opts);\n\n y += Number(font.lineHeight);\n }\n\n ctx.restore();\n}\n\n/**\n * Add a path of a rectangle with rounded corners to the current sub-path\n * @param ctx - Context\n * @param rect - Bounding rect\n */\nexport function addRoundedRectPath(\n ctx: CanvasRenderingContext2D,\n rect: RoundedRect & { radius: TRBLCorners }\n) {\n const {x, y, w, h, radius} = rect;\n\n // top left arc\n ctx.arc(x + radius.topLeft, y + radius.topLeft, radius.topLeft, 1.5 * PI, PI, true);\n\n // line from top left to bottom left\n ctx.lineTo(x, y + h - radius.bottomLeft);\n\n // bottom left arc\n ctx.arc(x + radius.bottomLeft, y + h - radius.bottomLeft, radius.bottomLeft, PI, HALF_PI, true);\n\n // line from bottom left to bottom right\n ctx.lineTo(x + w - radius.bottomRight, y + h);\n\n // bottom right arc\n ctx.arc(x + w - radius.bottomRight, y + h - radius.bottomRight, radius.bottomRight, HALF_PI, 0, true);\n\n // line from bottom right to top right\n ctx.lineTo(x + w, y + radius.topRight);\n\n // top right arc\n ctx.arc(x + w - radius.topRight, y + radius.topRight, radius.topRight, 0, -HALF_PI, true);\n\n // line from top right to top left\n ctx.lineTo(x + radius.topLeft, y);\n}\n","import defaults from '../core/core.defaults.js';\nimport {isArray, isObject, toDimension, valueOrDefault} from './helpers.core.js';\nimport {toFontString} from './helpers.canvas.js';\nimport type {ChartArea, FontSpec, Point} from '../types/index.js';\nimport type {TRBL, TRBLCorners} from '../types/geometric.js';\n\nconst LINE_HEIGHT = /^(normal|(\\d+(?:\\.\\d+)?)(px|em|%)?)$/;\nconst FONT_STYLE = /^(normal|italic|initial|inherit|unset|(oblique( -?[0-9]?[0-9]deg)?))$/;\n\n/**\n * @alias Chart.helpers.options\n * @namespace\n */\n/**\n * Converts the given line height `value` in pixels for a specific font `size`.\n * @param value - The lineHeight to parse (eg. 1.6, '14px', '75%', '1.6em').\n * @param size - The font size (in pixels) used to resolve relative `value`.\n * @returns The effective line height in pixels (size * 1.2 if value is invalid).\n * @see https://developer.mozilla.org/en-US/docs/Web/CSS/line-height\n * @since 2.7.0\n */\nexport function toLineHeight(value: number | string, size: number): number {\n const matches = ('' + value).match(LINE_HEIGHT);\n if (!matches || matches[1] === 'normal') {\n return size * 1.2;\n }\n\n value = +matches[2];\n\n switch (matches[3]) {\n case 'px':\n return value;\n case '%':\n value /= 100;\n break;\n default:\n break;\n }\n\n return size * value;\n}\n\nconst numberOrZero = (v: unknown) => +v || 0;\n\n/**\n * @param value\n * @param props\n */\nexport function _readValueToProps(value: number | Record, props: K[]): Record;\nexport function _readValueToProps(value: number | Record, props: Record): Record;\nexport function _readValueToProps(value: number | Record, props: string[] | Record) {\n const ret = {};\n const objProps = isObject(props);\n const keys = objProps ? Object.keys(props) : props;\n const read = isObject(value)\n ? objProps\n ? prop => valueOrDefault(value[prop], value[props[prop]])\n : prop => value[prop]\n : () => value;\n\n for (const prop of keys) {\n ret[prop] = numberOrZero(read(prop));\n }\n return ret;\n}\n\n/**\n * Converts the given value into a TRBL object.\n * @param value - If a number, set the value to all TRBL component,\n * else, if an object, use defined properties and sets undefined ones to 0.\n * x / y are shorthands for same value for left/right and top/bottom.\n * @returns The padding values (top, right, bottom, left)\n * @since 3.0.0\n */\nexport function toTRBL(value: number | TRBL | Point) {\n return _readValueToProps(value, {top: 'y', right: 'x', bottom: 'y', left: 'x'});\n}\n\n/**\n * Converts the given value into a TRBL corners object (similar with css border-radius).\n * @param value - If a number, set the value to all TRBL corner components,\n * else, if an object, use defined properties and sets undefined ones to 0.\n * @returns The TRBL corner values (topLeft, topRight, bottomLeft, bottomRight)\n * @since 3.0.0\n */\nexport function toTRBLCorners(value: number | TRBLCorners) {\n return _readValueToProps(value, ['topLeft', 'topRight', 'bottomLeft', 'bottomRight']);\n}\n\n/**\n * Converts the given value into a padding object with pre-computed width/height.\n * @param value - If a number, set the value to all TRBL component,\n * else, if an object, use defined properties and sets undefined ones to 0.\n * x / y are shorthands for same value for left/right and top/bottom.\n * @returns The padding values (top, right, bottom, left, width, height)\n * @since 2.7.0\n */\nexport function toPadding(value?: number | TRBL): ChartArea {\n const obj = toTRBL(value) as ChartArea;\n\n obj.width = obj.left + obj.right;\n obj.height = obj.top + obj.bottom;\n\n return obj;\n}\n\n/**\n * Parses font options and returns the font object.\n * @param options - A object that contains font options to be parsed.\n * @param fallback - A object that contains fallback font options.\n * @return The font object.\n * @private\n */\n\nexport function toFont(options: Partial, fallback?: Partial) {\n options = options || {};\n fallback = fallback || defaults.font as FontSpec;\n\n let size = valueOrDefault(options.size, fallback.size);\n\n if (typeof size === 'string') {\n size = parseInt(size, 10);\n }\n let style = valueOrDefault(options.style, fallback.style);\n if (style && !('' + style).match(FONT_STYLE)) {\n console.warn('Invalid font style specified: \"' + style + '\"');\n style = undefined;\n }\n\n const font = {\n family: valueOrDefault(options.family, fallback.family),\n lineHeight: toLineHeight(valueOrDefault(options.lineHeight, fallback.lineHeight), size),\n size,\n style,\n weight: valueOrDefault(options.weight, fallback.weight),\n string: ''\n };\n\n font.string = toFontString(font);\n return font;\n}\n\n/**\n * Evaluates the given `inputs` sequentially and returns the first defined value.\n * @param inputs - An array of values, falling back to the last value.\n * @param context - If defined and the current value is a function, the value\n * is called with `context` as first argument and the result becomes the new input.\n * @param index - If defined and the current value is an array, the value\n * at `index` become the new input.\n * @param info - object to return information about resolution in\n * @param info.cacheable - Will be set to `false` if option is not cacheable.\n * @since 2.7.0\n */\nexport function resolve(inputs: Array, context?: object, index?: number, info?: { cacheable: boolean }) {\n let cacheable = true;\n let i: number, ilen: number, value: unknown;\n\n for (i = 0, ilen = inputs.length; i < ilen; ++i) {\n value = inputs[i];\n if (value === undefined) {\n continue;\n }\n if (context !== undefined && typeof value === 'function') {\n value = value(context);\n cacheable = false;\n }\n if (index !== undefined && isArray(value)) {\n value = value[index % value.length];\n cacheable = false;\n }\n if (value !== undefined) {\n if (info && !cacheable) {\n info.cacheable = false;\n }\n return value;\n }\n }\n}\n\n/**\n * @param minmax\n * @param grace\n * @param beginAtZero\n * @private\n */\nexport function _addGrace(minmax: { min: number; max: number; }, grace: number | string, beginAtZero: boolean) {\n const {min, max} = minmax;\n const change = toDimension(grace, (max - min) / 2);\n const keepZero = (value: number, add: number) => beginAtZero && value === 0 ? 0 : value + add;\n return {\n min: keepZero(min, -Math.abs(change)),\n max: keepZero(max, change)\n };\n}\n\n/**\n * Create a context inheriting parentContext\n * @param parentContext\n * @param context\n * @returns\n */\nexport function createContext(parentContext: null, context: T): T;\nexport function createContext(parentContext: P, context: T): P & T;\nexport function createContext(parentContext: object, context: object) {\n return Object.assign(Object.create(parentContext), context);\n}\n","/* eslint-disable @typescript-eslint/no-use-before-define */\nimport type {AnyObject} from '../types/basic.js';\nimport type {ChartMeta} from '../types/index.js';\nimport type {\n ResolverObjectKey,\n ResolverCache,\n ResolverProxy,\n DescriptorDefaults,\n Descriptor,\n ContextCache,\n ContextProxy\n} from './helpers.config.types.js';\nimport {isArray, isFunction, isObject, resolveObjectKey, _capitalize} from './helpers.core.js';\n\nexport * from './helpers.config.types.js';\n\n/**\n * Creates a Proxy for resolving raw values for options.\n * @param scopes - The option scopes to look for values, in resolution order\n * @param prefixes - The prefixes for values, in resolution order.\n * @param rootScopes - The root option scopes\n * @param fallback - Parent scopes fallback\n * @param getTarget - callback for getting the target for changed values\n * @returns Proxy\n * @private\n */\nexport function _createResolver<\n T extends AnyObject[] = AnyObject[],\n R extends AnyObject[] = T\n>(\n scopes: T,\n prefixes = [''],\n rootScopes?: R,\n fallback?: ResolverObjectKey,\n getTarget = () => scopes[0]\n) {\n const finalRootScopes = rootScopes || scopes;\n if (typeof fallback === 'undefined') {\n fallback = _resolve('_fallback', scopes);\n }\n const cache: ResolverCache = {\n [Symbol.toStringTag]: 'Object',\n _cacheable: true,\n _scopes: scopes,\n _rootScopes: finalRootScopes,\n _fallback: fallback,\n _getTarget: getTarget,\n override: (scope: AnyObject) => _createResolver([scope, ...scopes], prefixes, finalRootScopes, fallback),\n };\n return new Proxy(cache, {\n /**\n * A trap for the delete operator.\n */\n deleteProperty(target, prop: string) {\n delete target[prop]; // remove from cache\n delete target._keys; // remove cached keys\n delete scopes[0][prop]; // remove from top level scope\n return true;\n },\n\n /**\n * A trap for getting property values.\n */\n get(target, prop: string) {\n return _cached(target, prop,\n () => _resolveWithPrefixes(prop, prefixes, scopes, target));\n },\n\n /**\n * A trap for Object.getOwnPropertyDescriptor.\n * Also used by Object.hasOwnProperty.\n */\n getOwnPropertyDescriptor(target, prop) {\n return Reflect.getOwnPropertyDescriptor(target._scopes[0], prop);\n },\n\n /**\n * A trap for Object.getPrototypeOf.\n */\n getPrototypeOf() {\n return Reflect.getPrototypeOf(scopes[0]);\n },\n\n /**\n * A trap for the in operator.\n */\n has(target, prop: string) {\n return getKeysFromAllScopes(target).includes(prop);\n },\n\n /**\n * A trap for Object.getOwnPropertyNames and Object.getOwnPropertySymbols.\n */\n ownKeys(target) {\n return getKeysFromAllScopes(target);\n },\n\n /**\n * A trap for setting property values.\n */\n set(target, prop: string, value) {\n const storage = target._storage || (target._storage = getTarget());\n target[prop] = storage[prop] = value; // set to top level scope + cache\n delete target._keys; // remove cached keys\n return true;\n }\n }) as ResolverProxy;\n}\n\n/**\n * Returns an Proxy for resolving option values with context.\n * @param proxy - The Proxy returned by `_createResolver`\n * @param context - Context object for scriptable/indexable options\n * @param subProxy - The proxy provided for scriptable options\n * @param descriptorDefaults - Defaults for descriptors\n * @private\n */\nexport function _attachContext<\n T extends AnyObject[] = AnyObject[],\n R extends AnyObject[] = T\n>(\n proxy: ResolverProxy,\n context: AnyObject,\n subProxy?: ResolverProxy,\n descriptorDefaults?: DescriptorDefaults\n) {\n const cache: ContextCache = {\n _cacheable: false,\n _proxy: proxy,\n _context: context,\n _subProxy: subProxy,\n _stack: new Set(),\n _descriptors: _descriptors(proxy, descriptorDefaults),\n setContext: (ctx: AnyObject) => _attachContext(proxy, ctx, subProxy, descriptorDefaults),\n override: (scope: AnyObject) => _attachContext(proxy.override(scope), context, subProxy, descriptorDefaults)\n };\n return new Proxy(cache, {\n /**\n * A trap for the delete operator.\n */\n deleteProperty(target, prop) {\n delete target[prop]; // remove from cache\n delete proxy[prop]; // remove from proxy\n return true;\n },\n\n /**\n * A trap for getting property values.\n */\n get(target, prop: string, receiver) {\n return _cached(target, prop,\n () => _resolveWithContext(target, prop, receiver));\n },\n\n /**\n * A trap for Object.getOwnPropertyDescriptor.\n * Also used by Object.hasOwnProperty.\n */\n getOwnPropertyDescriptor(target, prop) {\n return target._descriptors.allKeys\n ? Reflect.has(proxy, prop) ? {enumerable: true, configurable: true} : undefined\n : Reflect.getOwnPropertyDescriptor(proxy, prop);\n },\n\n /**\n * A trap for Object.getPrototypeOf.\n */\n getPrototypeOf() {\n return Reflect.getPrototypeOf(proxy);\n },\n\n /**\n * A trap for the in operator.\n */\n has(target, prop) {\n return Reflect.has(proxy, prop);\n },\n\n /**\n * A trap for Object.getOwnPropertyNames and Object.getOwnPropertySymbols.\n */\n ownKeys() {\n return Reflect.ownKeys(proxy);\n },\n\n /**\n * A trap for setting property values.\n */\n set(target, prop, value) {\n proxy[prop] = value; // set to proxy\n delete target[prop]; // remove from cache\n return true;\n }\n }) as ContextProxy;\n}\n\n/**\n * @private\n */\nexport function _descriptors(\n proxy: ResolverCache,\n defaults: DescriptorDefaults = {scriptable: true, indexable: true}\n): Descriptor {\n const {_scriptable = defaults.scriptable, _indexable = defaults.indexable, _allKeys = defaults.allKeys} = proxy;\n return {\n allKeys: _allKeys,\n scriptable: _scriptable,\n indexable: _indexable,\n isScriptable: isFunction(_scriptable) ? _scriptable : () => _scriptable,\n isIndexable: isFunction(_indexable) ? _indexable : () => _indexable\n };\n}\n\nconst readKey = (prefix: string, name: string) => prefix ? prefix + _capitalize(name) : name;\nconst needsSubResolver = (prop: string, value: unknown) => isObject(value) && prop !== 'adapters' &&\n (Object.getPrototypeOf(value) === null || value.constructor === Object);\n\nfunction _cached(\n target: AnyObject,\n prop: string,\n resolve: () => unknown\n) {\n if (Object.prototype.hasOwnProperty.call(target, prop) || prop === 'constructor') {\n return target[prop];\n }\n\n const value = resolve();\n // cache the resolved value\n target[prop] = value;\n return value;\n}\n\nfunction _resolveWithContext(\n target: ContextCache,\n prop: string,\n receiver: AnyObject\n) {\n const {_proxy, _context, _subProxy, _descriptors: descriptors} = target;\n let value = _proxy[prop]; // resolve from proxy\n\n // resolve with context\n if (isFunction(value) && descriptors.isScriptable(prop)) {\n value = _resolveScriptable(prop, value, target, receiver);\n }\n if (isArray(value) && value.length) {\n value = _resolveArray(prop, value, target, descriptors.isIndexable);\n }\n if (needsSubResolver(prop, value)) {\n // if the resolved value is an object, create a sub resolver for it\n value = _attachContext(value, _context, _subProxy && _subProxy[prop], descriptors);\n }\n return value;\n}\n\nfunction _resolveScriptable(\n prop: string,\n getValue: (ctx: AnyObject, sub: AnyObject) => unknown,\n target: ContextCache,\n receiver: AnyObject\n) {\n const {_proxy, _context, _subProxy, _stack} = target;\n if (_stack.has(prop)) {\n throw new Error('Recursion detected: ' + Array.from(_stack).join('->') + '->' + prop);\n }\n _stack.add(prop);\n let value = getValue(_context, _subProxy || receiver);\n _stack.delete(prop);\n if (needsSubResolver(prop, value)) {\n // When scriptable option returns an object, create a resolver on that.\n value = createSubResolver(_proxy._scopes, _proxy, prop, value);\n }\n return value;\n}\n\nfunction _resolveArray(\n prop: string,\n value: unknown[],\n target: ContextCache,\n isIndexable: (key: string) => boolean\n) {\n const {_proxy, _context, _subProxy, _descriptors: descriptors} = target;\n\n if (typeof _context.index !== 'undefined' && isIndexable(prop)) {\n return value[_context.index % value.length];\n } else if (isObject(value[0])) {\n // Array of objects, return array or resolvers\n const arr = value;\n const scopes = _proxy._scopes.filter(s => s !== arr);\n value = [];\n for (const item of arr) {\n const resolver = createSubResolver(scopes, _proxy, prop, item);\n value.push(_attachContext(resolver, _context, _subProxy && _subProxy[prop], descriptors));\n }\n }\n return value;\n}\n\nfunction resolveFallback(\n fallback: ResolverObjectKey | ((prop: ResolverObjectKey, value: unknown) => ResolverObjectKey),\n prop: ResolverObjectKey,\n value: unknown\n) {\n return isFunction(fallback) ? fallback(prop, value) : fallback;\n}\n\nconst getScope = (key: ResolverObjectKey, parent: AnyObject) => key === true ? parent\n : typeof key === 'string' ? resolveObjectKey(parent, key) : undefined;\n\nfunction addScopes(\n set: Set,\n parentScopes: AnyObject[],\n key: ResolverObjectKey,\n parentFallback: ResolverObjectKey,\n value: unknown\n) {\n for (const parent of parentScopes) {\n const scope = getScope(key, parent);\n if (scope) {\n set.add(scope);\n const fallback = resolveFallback(scope._fallback, key, value);\n if (typeof fallback !== 'undefined' && fallback !== key && fallback !== parentFallback) {\n // When we reach the descriptor that defines a new _fallback, return that.\n // The fallback will resume to that new scope.\n return fallback;\n }\n } else if (scope === false && typeof parentFallback !== 'undefined' && key !== parentFallback) {\n // Fallback to `false` results to `false`, when falling back to different key.\n // For example `interaction` from `hover` or `plugins.tooltip` and `animation` from `animations`\n return null;\n }\n }\n return false;\n}\n\nfunction createSubResolver(\n parentScopes: AnyObject[],\n resolver: ResolverCache,\n prop: ResolverObjectKey,\n value: unknown\n) {\n const rootScopes = resolver._rootScopes;\n const fallback = resolveFallback(resolver._fallback, prop, value);\n const allScopes = [...parentScopes, ...rootScopes];\n const set = new Set();\n set.add(value);\n let key = addScopesFromKey(set, allScopes, prop, fallback || prop, value);\n if (key === null) {\n return false;\n }\n if (typeof fallback !== 'undefined' && fallback !== prop) {\n key = addScopesFromKey(set, allScopes, fallback, key, value);\n if (key === null) {\n return false;\n }\n }\n return _createResolver(Array.from(set), [''], rootScopes, fallback,\n () => subGetTarget(resolver, prop as string, value));\n}\n\nfunction addScopesFromKey(\n set: Set,\n allScopes: AnyObject[],\n key: ResolverObjectKey,\n fallback: ResolverObjectKey,\n item: unknown\n) {\n while (key) {\n key = addScopes(set, allScopes, key, fallback, item);\n }\n return key;\n}\n\nfunction subGetTarget(\n resolver: ResolverCache,\n prop: string,\n value: unknown\n) {\n const parent = resolver._getTarget();\n if (!(prop in parent)) {\n parent[prop] = {};\n }\n const target = parent[prop];\n if (isArray(target) && isObject(value)) {\n // For array of objects, the object is used to store updated values\n return value;\n }\n return target || {};\n}\n\nfunction _resolveWithPrefixes(\n prop: string,\n prefixes: string[],\n scopes: AnyObject[],\n proxy: ResolverProxy\n) {\n let value: unknown;\n for (const prefix of prefixes) {\n value = _resolve(readKey(prefix, prop), scopes);\n if (typeof value !== 'undefined') {\n return needsSubResolver(prop, value)\n ? createSubResolver(scopes, proxy, prop, value)\n : value;\n }\n }\n}\n\nfunction _resolve(key: string, scopes: AnyObject[]) {\n for (const scope of scopes) {\n if (!scope) {\n continue;\n }\n const value = scope[key];\n if (typeof value !== 'undefined') {\n return value;\n }\n }\n}\n\nfunction getKeysFromAllScopes(target: ResolverCache) {\n let keys = target._keys;\n if (!keys) {\n keys = target._keys = resolveKeysFromAllScopes(target._scopes);\n }\n return keys;\n}\n\nfunction resolveKeysFromAllScopes(scopes: AnyObject[]) {\n const set = new Set();\n for (const scope of scopes) {\n for (const key of Object.keys(scope).filter(k => !k.startsWith('_'))) {\n set.add(key);\n }\n }\n return Array.from(set);\n}\n\nexport function _parseObjectDataRadialScale(\n meta: ChartMeta<'line' | 'scatter'>,\n data: AnyObject[],\n start: number,\n count: number\n) {\n const {iScale} = meta;\n const {key = 'r'} = this._parsing;\n const parsed = new Array<{r: unknown}>(count);\n let i: number, ilen: number, index: number, item: AnyObject;\n\n for (i = 0, ilen = count; i < ilen; ++i) {\n index = i + start;\n item = data[index];\n parsed[i] = {\n r: iScale.parse(resolveObjectKey(item, key), index)\n };\n }\n return parsed;\n}\n","import {almostEquals, distanceBetweenPoints, sign} from './helpers.math.js';\nimport {_isPointInArea} from './helpers.canvas.js';\nimport type {ChartArea} from '../types/index.js';\nimport type {SplinePoint} from '../types/geometric.js';\n\nconst EPSILON = Number.EPSILON || 1e-14;\n\ntype OptionalSplinePoint = SplinePoint | false\nconst getPoint = (points: SplinePoint[], i: number): OptionalSplinePoint => i < points.length && !points[i].skip && points[i];\nconst getValueAxis = (indexAxis: 'x' | 'y') => indexAxis === 'x' ? 'y' : 'x';\n\nexport function splineCurve(\n firstPoint: SplinePoint,\n middlePoint: SplinePoint,\n afterPoint: SplinePoint,\n t: number\n): {\n previous: SplinePoint\n next: SplinePoint\n } {\n // Props to Rob Spencer at scaled innovation for his post on splining between points\n // http://scaledinnovation.com/analytics/splines/aboutSplines.html\n\n // This function must also respect \"skipped\" points\n\n const previous = firstPoint.skip ? middlePoint : firstPoint;\n const current = middlePoint;\n const next = afterPoint.skip ? middlePoint : afterPoint;\n const d01 = distanceBetweenPoints(current, previous);\n const d12 = distanceBetweenPoints(next, current);\n\n let s01 = d01 / (d01 + d12);\n let s12 = d12 / (d01 + d12);\n\n // If all points are the same, s01 & s02 will be inf\n s01 = isNaN(s01) ? 0 : s01;\n s12 = isNaN(s12) ? 0 : s12;\n\n const fa = t * s01; // scaling factor for triangle Ta\n const fb = t * s12;\n\n return {\n previous: {\n x: current.x - fa * (next.x - previous.x),\n y: current.y - fa * (next.y - previous.y)\n },\n next: {\n x: current.x + fb * (next.x - previous.x),\n y: current.y + fb * (next.y - previous.y)\n }\n };\n}\n\n/**\n * Adjust tangents to ensure monotonic properties\n */\nfunction monotoneAdjust(points: SplinePoint[], deltaK: number[], mK: number[]) {\n const pointsLen = points.length;\n\n let alphaK: number, betaK: number, tauK: number, squaredMagnitude: number, pointCurrent: OptionalSplinePoint;\n let pointAfter = getPoint(points, 0);\n for (let i = 0; i < pointsLen - 1; ++i) {\n pointCurrent = pointAfter;\n pointAfter = getPoint(points, i + 1);\n if (!pointCurrent || !pointAfter) {\n continue;\n }\n\n if (almostEquals(deltaK[i], 0, EPSILON)) {\n mK[i] = mK[i + 1] = 0;\n continue;\n }\n\n alphaK = mK[i] / deltaK[i];\n betaK = mK[i + 1] / deltaK[i];\n squaredMagnitude = Math.pow(alphaK, 2) + Math.pow(betaK, 2);\n if (squaredMagnitude <= 9) {\n continue;\n }\n\n tauK = 3 / Math.sqrt(squaredMagnitude);\n mK[i] = alphaK * tauK * deltaK[i];\n mK[i + 1] = betaK * tauK * deltaK[i];\n }\n}\n\nfunction monotoneCompute(points: SplinePoint[], mK: number[], indexAxis: 'x' | 'y' = 'x') {\n const valueAxis = getValueAxis(indexAxis);\n const pointsLen = points.length;\n let delta: number, pointBefore: OptionalSplinePoint, pointCurrent: OptionalSplinePoint;\n let pointAfter = getPoint(points, 0);\n\n for (let i = 0; i < pointsLen; ++i) {\n pointBefore = pointCurrent;\n pointCurrent = pointAfter;\n pointAfter = getPoint(points, i + 1);\n if (!pointCurrent) {\n continue;\n }\n\n const iPixel = pointCurrent[indexAxis];\n const vPixel = pointCurrent[valueAxis];\n if (pointBefore) {\n delta = (iPixel - pointBefore[indexAxis]) / 3;\n pointCurrent[`cp1${indexAxis}`] = iPixel - delta;\n pointCurrent[`cp1${valueAxis}`] = vPixel - delta * mK[i];\n }\n if (pointAfter) {\n delta = (pointAfter[indexAxis] - iPixel) / 3;\n pointCurrent[`cp2${indexAxis}`] = iPixel + delta;\n pointCurrent[`cp2${valueAxis}`] = vPixel + delta * mK[i];\n }\n }\n}\n\n/**\n * This function calculates Bézier control points in a similar way than |splineCurve|,\n * but preserves monotonicity of the provided data and ensures no local extremums are added\n * between the dataset discrete points due to the interpolation.\n * See : https://en.wikipedia.org/wiki/Monotone_cubic_interpolation\n */\nexport function splineCurveMonotone(points: SplinePoint[], indexAxis: 'x' | 'y' = 'x') {\n const valueAxis = getValueAxis(indexAxis);\n const pointsLen = points.length;\n const deltaK: number[] = Array(pointsLen).fill(0);\n const mK: number[] = Array(pointsLen);\n\n // Calculate slopes (deltaK) and initialize tangents (mK)\n let i, pointBefore: OptionalSplinePoint, pointCurrent: OptionalSplinePoint;\n let pointAfter = getPoint(points, 0);\n\n for (i = 0; i < pointsLen; ++i) {\n pointBefore = pointCurrent;\n pointCurrent = pointAfter;\n pointAfter = getPoint(points, i + 1);\n if (!pointCurrent) {\n continue;\n }\n\n if (pointAfter) {\n const slopeDelta = pointAfter[indexAxis] - pointCurrent[indexAxis];\n\n // In the case of two points that appear at the same x pixel, slopeDeltaX is 0\n deltaK[i] = slopeDelta !== 0 ? (pointAfter[valueAxis] - pointCurrent[valueAxis]) / slopeDelta : 0;\n }\n mK[i] = !pointBefore ? deltaK[i]\n : !pointAfter ? deltaK[i - 1]\n : (sign(deltaK[i - 1]) !== sign(deltaK[i])) ? 0\n : (deltaK[i - 1] + deltaK[i]) / 2;\n }\n\n monotoneAdjust(points, deltaK, mK);\n\n monotoneCompute(points, mK, indexAxis);\n}\n\nfunction capControlPoint(pt: number, min: number, max: number) {\n return Math.max(Math.min(pt, max), min);\n}\n\nfunction capBezierPoints(points: SplinePoint[], area: ChartArea) {\n let i, ilen, point, inArea, inAreaPrev;\n let inAreaNext = _isPointInArea(points[0], area);\n for (i = 0, ilen = points.length; i < ilen; ++i) {\n inAreaPrev = inArea;\n inArea = inAreaNext;\n inAreaNext = i < ilen - 1 && _isPointInArea(points[i + 1], area);\n if (!inArea) {\n continue;\n }\n point = points[i];\n if (inAreaPrev) {\n point.cp1x = capControlPoint(point.cp1x, area.left, area.right);\n point.cp1y = capControlPoint(point.cp1y, area.top, area.bottom);\n }\n if (inAreaNext) {\n point.cp2x = capControlPoint(point.cp2x, area.left, area.right);\n point.cp2y = capControlPoint(point.cp2y, area.top, area.bottom);\n }\n }\n}\n\n/**\n * @private\n */\nexport function _updateBezierControlPoints(\n points: SplinePoint[],\n options,\n area: ChartArea,\n loop: boolean,\n indexAxis: 'x' | 'y'\n) {\n let i: number, ilen: number, point: SplinePoint, controlPoints: ReturnType;\n\n // Only consider points that are drawn in case the spanGaps option is used\n if (options.spanGaps) {\n points = points.filter((pt) => !pt.skip);\n }\n\n if (options.cubicInterpolationMode === 'monotone') {\n splineCurveMonotone(points, indexAxis);\n } else {\n let prev = loop ? points[points.length - 1] : points[0];\n for (i = 0, ilen = points.length; i < ilen; ++i) {\n point = points[i];\n controlPoints = splineCurve(\n prev,\n point,\n points[Math.min(i + 1, ilen - (loop ? 0 : 1)) % ilen],\n options.tension\n );\n point.cp1x = controlPoints.previous.x;\n point.cp1y = controlPoints.previous.y;\n point.cp2x = controlPoints.next.x;\n point.cp2y = controlPoints.next.y;\n prev = point;\n }\n }\n\n if (options.capBezierPoints) {\n capBezierPoints(points, area);\n }\n}\n","import type {ChartArea, Scale} from '../types/index.js';\nimport type PrivateChart from '../core/core.controller.js';\nimport type {Chart, ChartEvent} from '../types.js';\nimport {INFINITY} from './helpers.math.js';\n\n/**\n * @private\n */\nexport function _isDomSupported(): boolean {\n return typeof window !== 'undefined' && typeof document !== 'undefined';\n}\n\n/**\n * @private\n */\nexport function _getParentNode(domNode: HTMLCanvasElement): HTMLCanvasElement {\n let parent = domNode.parentNode;\n if (parent && parent.toString() === '[object ShadowRoot]') {\n parent = (parent as ShadowRoot).host;\n }\n return parent as HTMLCanvasElement;\n}\n\n/**\n * convert max-width/max-height values that may be percentages into a number\n * @private\n */\n\nfunction parseMaxStyle(styleValue: string | number, node: HTMLElement, parentProperty: string) {\n let valueInPixels: number;\n if (typeof styleValue === 'string') {\n valueInPixels = parseInt(styleValue, 10);\n\n if (styleValue.indexOf('%') !== -1) {\n // percentage * size in dimension\n valueInPixels = (valueInPixels / 100) * node.parentNode[parentProperty];\n }\n } else {\n valueInPixels = styleValue;\n }\n\n return valueInPixels;\n}\n\nconst getComputedStyle = (element: HTMLElement): CSSStyleDeclaration =>\n element.ownerDocument.defaultView.getComputedStyle(element, null);\n\nexport function getStyle(el: HTMLElement, property: string): string {\n return getComputedStyle(el).getPropertyValue(property);\n}\n\nconst positions = ['top', 'right', 'bottom', 'left'];\nfunction getPositionedStyle(styles: CSSStyleDeclaration, style: string, suffix?: string): ChartArea {\n const result = {} as ChartArea;\n suffix = suffix ? '-' + suffix : '';\n for (let i = 0; i < 4; i++) {\n const pos = positions[i];\n result[pos] = parseFloat(styles[style + '-' + pos + suffix]) || 0;\n }\n result.width = result.left + result.right;\n result.height = result.top + result.bottom;\n return result;\n}\n\nconst useOffsetPos = (x: number, y: number, target: HTMLElement | EventTarget) =>\n (x > 0 || y > 0) && (!target || !(target as HTMLElement).shadowRoot);\n\n/**\n * @param e\n * @param canvas\n * @returns Canvas position\n */\nfunction getCanvasPosition(\n e: Event | TouchEvent | MouseEvent,\n canvas: HTMLCanvasElement\n): {\n x: number;\n y: number;\n box: boolean;\n } {\n const touches = (e as TouchEvent).touches;\n const source = (touches && touches.length ? touches[0] : e) as MouseEvent;\n const {offsetX, offsetY} = source as MouseEvent;\n let box = false;\n let x, y;\n if (useOffsetPos(offsetX, offsetY, e.target)) {\n x = offsetX;\n y = offsetY;\n } else {\n const rect = canvas.getBoundingClientRect();\n x = source.clientX - rect.left;\n y = source.clientY - rect.top;\n box = true;\n }\n return {x, y, box};\n}\n\n/**\n * Gets an event's x, y coordinates, relative to the chart area\n * @param event\n * @param chart\n * @returns x and y coordinates of the event\n */\n\nexport function getRelativePosition(\n event: Event | ChartEvent | TouchEvent | MouseEvent,\n chart: Chart | PrivateChart\n): { x: number; y: number } {\n if ('native' in event) {\n return event;\n }\n\n const {canvas, currentDevicePixelRatio} = chart;\n const style = getComputedStyle(canvas);\n const borderBox = style.boxSizing === 'border-box';\n const paddings = getPositionedStyle(style, 'padding');\n const borders = getPositionedStyle(style, 'border', 'width');\n const {x, y, box} = getCanvasPosition(event, canvas);\n const xOffset = paddings.left + (box && borders.left);\n const yOffset = paddings.top + (box && borders.top);\n\n let {width, height} = chart;\n if (borderBox) {\n width -= paddings.width + borders.width;\n height -= paddings.height + borders.height;\n }\n return {\n x: Math.round((x - xOffset) / width * canvas.width / currentDevicePixelRatio),\n y: Math.round((y - yOffset) / height * canvas.height / currentDevicePixelRatio)\n };\n}\n\nfunction getContainerSize(canvas: HTMLCanvasElement, width: number, height: number): Partial {\n let maxWidth: number, maxHeight: number;\n\n if (width === undefined || height === undefined) {\n const container = canvas && _getParentNode(canvas);\n if (!container) {\n width = canvas.clientWidth;\n height = canvas.clientHeight;\n } else {\n const rect = container.getBoundingClientRect(); // this is the border box of the container\n const containerStyle = getComputedStyle(container);\n const containerBorder = getPositionedStyle(containerStyle, 'border', 'width');\n const containerPadding = getPositionedStyle(containerStyle, 'padding');\n width = rect.width - containerPadding.width - containerBorder.width;\n height = rect.height - containerPadding.height - containerBorder.height;\n maxWidth = parseMaxStyle(containerStyle.maxWidth, container, 'clientWidth');\n maxHeight = parseMaxStyle(containerStyle.maxHeight, container, 'clientHeight');\n }\n }\n return {\n width,\n height,\n maxWidth: maxWidth || INFINITY,\n maxHeight: maxHeight || INFINITY\n };\n}\n\nconst round1 = (v: number) => Math.round(v * 10) / 10;\n\n// eslint-disable-next-line complexity\nexport function getMaximumSize(\n canvas: HTMLCanvasElement,\n bbWidth?: number,\n bbHeight?: number,\n aspectRatio?: number\n): { width: number; height: number } {\n const style = getComputedStyle(canvas);\n const margins = getPositionedStyle(style, 'margin');\n const maxWidth = parseMaxStyle(style.maxWidth, canvas, 'clientWidth') || INFINITY;\n const maxHeight = parseMaxStyle(style.maxHeight, canvas, 'clientHeight') || INFINITY;\n const containerSize = getContainerSize(canvas, bbWidth, bbHeight);\n let {width, height} = containerSize;\n\n if (style.boxSizing === 'content-box') {\n const borders = getPositionedStyle(style, 'border', 'width');\n const paddings = getPositionedStyle(style, 'padding');\n width -= paddings.width + borders.width;\n height -= paddings.height + borders.height;\n }\n width = Math.max(0, width - margins.width);\n height = Math.max(0, aspectRatio ? width / aspectRatio : height - margins.height);\n width = round1(Math.min(width, maxWidth, containerSize.maxWidth));\n height = round1(Math.min(height, maxHeight, containerSize.maxHeight));\n if (width && !height) {\n // https://github.com/chartjs/Chart.js/issues/4659\n // If the canvas has width, but no height, default to aspectRatio of 2 (canvas default)\n height = round1(width / 2);\n }\n\n const maintainHeight = bbWidth !== undefined || bbHeight !== undefined;\n\n if (maintainHeight && aspectRatio && containerSize.height && height > containerSize.height) {\n height = containerSize.height;\n width = round1(Math.floor(height * aspectRatio));\n }\n\n return {width, height};\n}\n\n/**\n * @param chart\n * @param forceRatio\n * @param forceStyle\n * @returns True if the canvas context size or transformation has changed.\n */\nexport function retinaScale(\n chart: Chart | PrivateChart,\n forceRatio: number,\n forceStyle?: boolean\n): boolean | void {\n const pixelRatio = forceRatio || 1;\n const deviceHeight = round1(chart.height * pixelRatio);\n const deviceWidth = round1(chart.width * pixelRatio);\n\n (chart as PrivateChart).height = round1(chart.height);\n (chart as PrivateChart).width = round1(chart.width);\n\n const canvas = chart.canvas;\n\n // If no style has been set on the canvas, the render size is used as display size,\n // making the chart visually bigger, so let's enforce it to the \"correct\" values.\n // See https://github.com/chartjs/Chart.js/issues/3575\n if (canvas.style && (forceStyle || (!canvas.style.height && !canvas.style.width))) {\n canvas.style.height = `${chart.height}px`;\n canvas.style.width = `${chart.width}px`;\n }\n\n if (chart.currentDevicePixelRatio !== pixelRatio\n || canvas.height !== deviceHeight\n || canvas.width !== deviceWidth) {\n (chart as PrivateChart).currentDevicePixelRatio = pixelRatio;\n canvas.height = deviceHeight;\n canvas.width = deviceWidth;\n chart.ctx.setTransform(pixelRatio, 0, 0, pixelRatio, 0, 0);\n return true;\n }\n return false;\n}\n\n/**\n * Detects support for options object argument in addEventListener.\n * https://developer.mozilla.org/en-US/docs/Web/API/EventTarget/addEventListener#Safely_detecting_option_support\n * @private\n */\nexport const supportsEventListenerOptions = (function() {\n let passiveSupported = false;\n try {\n const options = {\n get passive() { // This function will be called when the browser attempts to access the passive property.\n passiveSupported = true;\n return false;\n }\n } as EventListenerOptions;\n\n if (_isDomSupported()) {\n window.addEventListener('test', null, options);\n window.removeEventListener('test', null, options);\n }\n } catch (e) {\n // continue regardless of error\n }\n return passiveSupported;\n}());\n\n/**\n * The \"used\" size is the final value of a dimension property after all calculations have\n * been performed. This method uses the computed style of `element` but returns undefined\n * if the computed style is not expressed in pixels. That can happen in some cases where\n * `element` has a size relative to its parent and this last one is not yet displayed,\n * for example because of `display: none` on a parent node.\n * @see https://developer.mozilla.org/en-US/docs/Web/CSS/used_value\n * @returns Size in pixels or undefined if unknown.\n */\n\nexport function readUsedSize(\n element: HTMLElement,\n property: 'width' | 'height'\n): number | undefined {\n const value = getStyle(element, property);\n const matches = value && value.match(/^(\\d+)(\\.\\d+)?px$/);\n return matches ? +matches[1] : undefined;\n}\n","import type {Point, SplinePoint} from '../types/geometric.js';\n\n/**\n * @private\n */\nexport function _pointInLine(p1: Point, p2: Point, t: number, mode?) { // eslint-disable-line @typescript-eslint/no-unused-vars\n return {\n x: p1.x + t * (p2.x - p1.x),\n y: p1.y + t * (p2.y - p1.y)\n };\n}\n\n/**\n * @private\n */\nexport function _steppedInterpolation(\n p1: Point,\n p2: Point,\n t: number, mode: 'middle' | 'after' | unknown\n) {\n return {\n x: p1.x + t * (p2.x - p1.x),\n y: mode === 'middle' ? t < 0.5 ? p1.y : p2.y\n : mode === 'after' ? t < 1 ? p1.y : p2.y\n : t > 0 ? p2.y : p1.y\n };\n}\n\n/**\n * @private\n */\nexport function _bezierInterpolation(p1: SplinePoint, p2: SplinePoint, t: number, mode?) { // eslint-disable-line @typescript-eslint/no-unused-vars\n const cp1 = {x: p1.cp2x, y: p1.cp2y};\n const cp2 = {x: p2.cp1x, y: p2.cp1y};\n const a = _pointInLine(p1, cp1, t);\n const b = _pointInLine(cp1, cp2, t);\n const c = _pointInLine(cp2, p2, t);\n const d = _pointInLine(a, b, t);\n const e = _pointInLine(b, c, t);\n return _pointInLine(d, e, t);\n}\n","export interface RTLAdapter {\n x(x: number): number;\n setWidth(w: number): void;\n textAlign(align: 'center' | 'left' | 'right'): 'center' | 'left' | 'right';\n xPlus(x: number, value: number): number;\n leftForLtr(x: number, itemWidth: number): number;\n}\n\nconst getRightToLeftAdapter = function(rectX: number, width: number): RTLAdapter {\n return {\n x(x) {\n return rectX + rectX + width - x;\n },\n setWidth(w) {\n width = w;\n },\n textAlign(align) {\n if (align === 'center') {\n return align;\n }\n return align === 'right' ? 'left' : 'right';\n },\n xPlus(x, value) {\n return x - value;\n },\n leftForLtr(x, itemWidth) {\n return x - itemWidth;\n },\n };\n};\n\nconst getLeftToRightAdapter = function(): RTLAdapter {\n return {\n x(x) {\n return x;\n },\n setWidth(w) { // eslint-disable-line no-unused-vars\n },\n textAlign(align) {\n return align;\n },\n xPlus(x, value) {\n return x + value;\n },\n leftForLtr(x, _itemWidth) { // eslint-disable-line @typescript-eslint/no-unused-vars\n return x;\n },\n };\n};\n\nexport function getRtlAdapter(rtl: boolean, rectX: number, width: number) {\n return rtl ? getRightToLeftAdapter(rectX, width) : getLeftToRightAdapter();\n}\n\nexport function overrideTextDirection(ctx: CanvasRenderingContext2D, direction: 'ltr' | 'rtl') {\n let style: CSSStyleDeclaration, original: [string, string];\n if (direction === 'ltr' || direction === 'rtl') {\n style = ctx.canvas.style;\n original = [\n style.getPropertyValue('direction'),\n style.getPropertyPriority('direction'),\n ];\n\n style.setProperty('direction', direction, 'important');\n (ctx as { prevTextDirection?: [string, string] }).prevTextDirection = original;\n }\n}\n\nexport function restoreTextDirection(ctx: CanvasRenderingContext2D, original?: [string, string]) {\n if (original !== undefined) {\n delete (ctx as { prevTextDirection?: [string, string] }).prevTextDirection;\n ctx.canvas.style.setProperty('direction', original[0], original[1]);\n }\n}\n","import {_angleBetween, _angleDiff, _isBetween, _normalizeAngle} from './helpers.math.js';\nimport {createContext} from './helpers.options.js';\nimport {isPatternOrGradient} from './helpers.color.js';\n\n/**\n * @typedef { import('../elements/element.line.js').default } LineElement\n * @typedef { import('../elements/element.point.js').default } PointElement\n * @typedef {{start: number, end: number, loop: boolean, style?: any}} Segment\n */\n\nfunction propertyFn(property) {\n if (property === 'angle') {\n return {\n between: _angleBetween,\n compare: _angleDiff,\n normalize: _normalizeAngle,\n };\n }\n return {\n between: _isBetween,\n compare: (a, b) => a - b,\n normalize: x => x\n };\n}\n\nfunction normalizeSegment({start, end, count, loop, style}) {\n return {\n start: start % count,\n end: end % count,\n loop: loop && (end - start + 1) % count === 0,\n style\n };\n}\n\nfunction getSegment(segment, points, bounds) {\n const {property, start: startBound, end: endBound} = bounds;\n const {between, normalize} = propertyFn(property);\n const count = points.length;\n // eslint-disable-next-line prefer-const\n let {start, end, loop} = segment;\n let i, ilen;\n\n if (loop) {\n start += count;\n end += count;\n for (i = 0, ilen = count; i < ilen; ++i) {\n if (!between(normalize(points[start % count][property]), startBound, endBound)) {\n break;\n }\n start--;\n end--;\n }\n start %= count;\n end %= count;\n }\n\n if (end < start) {\n end += count;\n }\n return {start, end, loop, style: segment.style};\n}\n\n/**\n * Returns the sub-segment(s) of a line segment that fall in the given bounds\n * @param {object} segment\n * @param {number} segment.start - start index of the segment, referring the points array\n * @param {number} segment.end - end index of the segment, referring the points array\n * @param {boolean} segment.loop - indicates that the segment is a loop\n * @param {object} [segment.style] - segment style\n * @param {PointElement[]} points - the points that this segment refers to\n * @param {object} [bounds]\n * @param {string} bounds.property - the property of a `PointElement` we are bounding. `x`, `y` or `angle`.\n * @param {number} bounds.start - start value of the property\n * @param {number} bounds.end - end value of the property\n * @private\n **/\nexport function _boundSegment(segment, points, bounds) {\n if (!bounds) {\n return [segment];\n }\n\n const {property, start: startBound, end: endBound} = bounds;\n const count = points.length;\n const {compare, between, normalize} = propertyFn(property);\n const {start, end, loop, style} = getSegment(segment, points, bounds);\n\n const result = [];\n let inside = false;\n let subStart = null;\n let value, point, prevValue;\n\n const startIsBefore = () => between(startBound, prevValue, value) && compare(startBound, prevValue) !== 0;\n const endIsBefore = () => compare(endBound, value) === 0 || between(endBound, prevValue, value);\n const shouldStart = () => inside || startIsBefore();\n const shouldStop = () => !inside || endIsBefore();\n\n for (let i = start, prev = start; i <= end; ++i) {\n point = points[i % count];\n\n if (point.skip) {\n continue;\n }\n\n value = normalize(point[property]);\n\n if (value === prevValue) {\n continue;\n }\n\n inside = between(value, startBound, endBound);\n\n if (subStart === null && shouldStart()) {\n subStart = compare(value, startBound) === 0 ? i : prev;\n }\n\n if (subStart !== null && shouldStop()) {\n result.push(normalizeSegment({start: subStart, end: i, loop, count, style}));\n subStart = null;\n }\n prev = i;\n prevValue = value;\n }\n\n if (subStart !== null) {\n result.push(normalizeSegment({start: subStart, end, loop, count, style}));\n }\n\n return result;\n}\n\n\n/**\n * Returns the segments of the line that are inside given bounds\n * @param {LineElement} line\n * @param {object} [bounds]\n * @param {string} bounds.property - the property we are bounding with. `x`, `y` or `angle`.\n * @param {number} bounds.start - start value of the `property`\n * @param {number} bounds.end - end value of the `property`\n * @private\n */\nexport function _boundSegments(line, bounds) {\n const result = [];\n const segments = line.segments;\n\n for (let i = 0; i < segments.length; i++) {\n const sub = _boundSegment(segments[i], line.points, bounds);\n if (sub.length) {\n result.push(...sub);\n }\n }\n return result;\n}\n\n/**\n * Find start and end index of a line.\n */\nfunction findStartAndEnd(points, count, loop, spanGaps) {\n let start = 0;\n let end = count - 1;\n\n if (loop && !spanGaps) {\n // loop and not spanning gaps, first find a gap to start from\n while (start < count && !points[start].skip) {\n start++;\n }\n }\n\n // find first non skipped point (after the first gap possibly)\n while (start < count && points[start].skip) {\n start++;\n }\n\n // if we looped to count, start needs to be 0\n start %= count;\n\n if (loop) {\n // loop will go past count, if start > 0\n end += start;\n }\n\n while (end > start && points[end % count].skip) {\n end--;\n }\n\n // end could be more than count, normalize\n end %= count;\n\n return {start, end};\n}\n\n/**\n * Compute solid segments from Points, when spanGaps === false\n * @param {PointElement[]} points - the points\n * @param {number} start - start index\n * @param {number} max - max index (can go past count on a loop)\n * @param {boolean} loop - boolean indicating that this would be a loop if no gaps are found\n */\nfunction solidSegments(points, start, max, loop) {\n const count = points.length;\n const result = [];\n let last = start;\n let prev = points[start];\n let end;\n\n for (end = start + 1; end <= max; ++end) {\n const cur = points[end % count];\n if (cur.skip || cur.stop) {\n if (!prev.skip) {\n loop = false;\n result.push({start: start % count, end: (end - 1) % count, loop});\n // @ts-ignore\n start = last = cur.stop ? end : null;\n }\n } else {\n last = end;\n if (prev.skip) {\n start = end;\n }\n }\n prev = cur;\n }\n\n if (last !== null) {\n result.push({start: start % count, end: last % count, loop});\n }\n\n return result;\n}\n\n/**\n * Compute the continuous segments that define the whole line\n * There can be skipped points within a segment, if spanGaps is true.\n * @param {LineElement} line\n * @param {object} [segmentOptions]\n * @return {Segment[]}\n * @private\n */\nexport function _computeSegments(line, segmentOptions) {\n const points = line.points;\n const spanGaps = line.options.spanGaps;\n const count = points.length;\n\n if (!count) {\n return [];\n }\n\n const loop = !!line._loop;\n const {start, end} = findStartAndEnd(points, count, loop, spanGaps);\n\n if (spanGaps === true) {\n return splitByStyles(line, [{start, end, loop}], points, segmentOptions);\n }\n\n const max = end < start ? end + count : end;\n const completeLoop = !!line._fullLoop && start === 0 && end === count - 1;\n return splitByStyles(line, solidSegments(points, start, max, completeLoop), points, segmentOptions);\n}\n\n/**\n * @param {Segment[]} segments\n * @param {PointElement[]} points\n * @param {object} [segmentOptions]\n * @return {Segment[]}\n */\nfunction splitByStyles(line, segments, points, segmentOptions) {\n if (!segmentOptions || !segmentOptions.setContext || !points) {\n return segments;\n }\n return doSplitByStyles(line, segments, points, segmentOptions);\n}\n\n/**\n * @param {LineElement} line\n * @param {Segment[]} segments\n * @param {PointElement[]} points\n * @param {object} [segmentOptions]\n * @return {Segment[]}\n */\nfunction doSplitByStyles(line, segments, points, segmentOptions) {\n const chartContext = line._chart.getContext();\n const baseStyle = readStyle(line.options);\n const {_datasetIndex: datasetIndex, options: {spanGaps}} = line;\n const count = points.length;\n const result = [];\n let prevStyle = baseStyle;\n let start = segments[0].start;\n let i = start;\n\n function addStyle(s, e, l, st) {\n const dir = spanGaps ? -1 : 1;\n if (s === e) {\n return;\n }\n // Style can not start/end on a skipped point, adjust indices accordingly\n s += count;\n while (points[s % count].skip) {\n s -= dir;\n }\n while (points[e % count].skip) {\n e += dir;\n }\n if (s % count !== e % count) {\n result.push({start: s % count, end: e % count, loop: l, style: st});\n prevStyle = st;\n start = e % count;\n }\n }\n\n for (const segment of segments) {\n start = spanGaps ? start : segment.start;\n let prev = points[start % count];\n let style;\n for (i = start + 1; i <= segment.end; i++) {\n const pt = points[i % count];\n style = readStyle(segmentOptions.setContext(createContext(chartContext, {\n type: 'segment',\n p0: prev,\n p1: pt,\n p0DataIndex: (i - 1) % count,\n p1DataIndex: i % count,\n datasetIndex\n })));\n if (styleChanged(style, prevStyle)) {\n addStyle(start, i - 1, segment.loop, prevStyle);\n }\n prev = pt;\n prevStyle = style;\n }\n if (start < i - 1) {\n addStyle(start, i - 1, segment.loop, prevStyle);\n }\n }\n\n return result;\n}\n\nfunction readStyle(options) {\n return {\n backgroundColor: options.backgroundColor,\n borderCapStyle: options.borderCapStyle,\n borderDash: options.borderDash,\n borderDashOffset: options.borderDashOffset,\n borderJoinStyle: options.borderJoinStyle,\n borderWidth: options.borderWidth,\n borderColor: options.borderColor\n };\n}\n\nfunction styleChanged(style, prevStyle) {\n if (!prevStyle) {\n return false;\n }\n const cache = [];\n const replacer = function(key, value) {\n if (!isPatternOrGradient(value)) {\n return value;\n }\n if (!cache.includes(value)) {\n cache.push(value);\n }\n return cache.indexOf(value);\n };\n return JSON.stringify(style, replacer) !== JSON.stringify(prevStyle, replacer);\n}\n","import type {Chart, ChartArea, ChartMeta, Scale, TRBL} from '../types/index.js';\n\nfunction getSizeForArea(scale: Scale, chartArea: ChartArea, field: keyof ChartArea) {\n return scale.options.clip ? scale[field] : chartArea[field];\n}\n\nfunction getDatasetArea(meta: ChartMeta, chartArea: ChartArea): TRBL {\n const {xScale, yScale} = meta;\n if (xScale && yScale) {\n return {\n left: getSizeForArea(xScale, chartArea, 'left'),\n right: getSizeForArea(xScale, chartArea, 'right'),\n top: getSizeForArea(yScale, chartArea, 'top'),\n bottom: getSizeForArea(yScale, chartArea, 'bottom')\n };\n }\n return chartArea;\n}\n\nexport function getDatasetClipArea(chart: Chart, meta: ChartMeta): TRBL | false {\n const clip = meta._clip;\n if (clip.disabled) {\n return false;\n }\n const area = getDatasetArea(meta, chart.chartArea);\n\n return {\n left: clip.left === false ? 0 : area.left - (clip.left === true ? 0 : clip.left),\n right: clip.right === false ? chart.width : area.right + (clip.right === true ? 0 : clip.right),\n top: clip.top === false ? 0 : area.top - (clip.top === true ? 0 : clip.top),\n bottom: clip.bottom === false ? chart.height : area.bottom + (clip.bottom === true ? 0 : clip.bottom)\n };\n}\n","import {requestAnimFrame} from '../helpers/helpers.extras.js';\n\n/**\n * @typedef { import('./core.animation.js').default } Animation\n * @typedef { import('./core.controller.js').default } Chart\n */\n\n/**\n * Please use the module's default export which provides a singleton instance\n * Note: class is export for typedoc\n */\nexport class Animator {\n constructor() {\n this._request = null;\n this._charts = new Map();\n this._running = false;\n this._lastDate = undefined;\n }\n\n /**\n\t * @private\n\t */\n _notify(chart, anims, date, type) {\n const callbacks = anims.listeners[type];\n const numSteps = anims.duration;\n\n callbacks.forEach(fn => fn({\n chart,\n initial: anims.initial,\n numSteps,\n currentStep: Math.min(date - anims.start, numSteps)\n }));\n }\n\n /**\n\t * @private\n\t */\n _refresh() {\n if (this._request) {\n return;\n }\n this._running = true;\n\n this._request = requestAnimFrame.call(window, () => {\n this._update();\n this._request = null;\n\n if (this._running) {\n this._refresh();\n }\n });\n }\n\n /**\n\t * @private\n\t */\n _update(date = Date.now()) {\n let remaining = 0;\n\n this._charts.forEach((anims, chart) => {\n if (!anims.running || !anims.items.length) {\n return;\n }\n const items = anims.items;\n let i = items.length - 1;\n let draw = false;\n let item;\n\n for (; i >= 0; --i) {\n item = items[i];\n\n if (item._active) {\n if (item._total > anims.duration) {\n // if the animation has been updated and its duration prolonged,\n // update to total duration of current animations run (for progress event)\n anims.duration = item._total;\n }\n item.tick(date);\n draw = true;\n } else {\n // Remove the item by replacing it with last item and removing the last\n // A lot faster than splice.\n items[i] = items[items.length - 1];\n items.pop();\n }\n }\n\n if (draw) {\n chart.draw();\n this._notify(chart, anims, date, 'progress');\n }\n\n if (!items.length) {\n anims.running = false;\n this._notify(chart, anims, date, 'complete');\n anims.initial = false;\n }\n\n remaining += items.length;\n });\n\n this._lastDate = date;\n\n if (remaining === 0) {\n this._running = false;\n }\n }\n\n /**\n\t * @private\n\t */\n _getAnims(chart) {\n const charts = this._charts;\n let anims = charts.get(chart);\n if (!anims) {\n anims = {\n running: false,\n initial: true,\n items: [],\n listeners: {\n complete: [],\n progress: []\n }\n };\n charts.set(chart, anims);\n }\n return anims;\n }\n\n /**\n\t * @param {Chart} chart\n\t * @param {string} event - event name\n\t * @param {Function} cb - callback\n\t */\n listen(chart, event, cb) {\n this._getAnims(chart).listeners[event].push(cb);\n }\n\n /**\n\t * Add animations\n\t * @param {Chart} chart\n\t * @param {Animation[]} items - animations\n\t */\n add(chart, items) {\n if (!items || !items.length) {\n return;\n }\n this._getAnims(chart).items.push(...items);\n }\n\n /**\n\t * Counts number of active animations for the chart\n\t * @param {Chart} chart\n\t */\n has(chart) {\n return this._getAnims(chart).items.length > 0;\n }\n\n /**\n\t * Start animating (all charts)\n\t * @param {Chart} chart\n\t */\n start(chart) {\n const anims = this._charts.get(chart);\n if (!anims) {\n return;\n }\n anims.running = true;\n anims.start = Date.now();\n anims.duration = anims.items.reduce((acc, cur) => Math.max(acc, cur._duration), 0);\n this._refresh();\n }\n\n running(chart) {\n if (!this._running) {\n return false;\n }\n const anims = this._charts.get(chart);\n if (!anims || !anims.running || !anims.items.length) {\n return false;\n }\n return true;\n }\n\n /**\n\t * Stop all animations for the chart\n\t * @param {Chart} chart\n\t */\n stop(chart) {\n const anims = this._charts.get(chart);\n if (!anims || !anims.items.length) {\n return;\n }\n const items = anims.items;\n let i = items.length - 1;\n\n for (; i >= 0; --i) {\n items[i].cancel();\n }\n anims.items = [];\n this._notify(chart, anims, Date.now(), 'complete');\n }\n\n /**\n\t * Remove chart from Animator\n\t * @param {Chart} chart\n\t */\n remove(chart) {\n return this._charts.delete(chart);\n }\n}\n\n// singleton instance\nexport default /* #__PURE__ */ new Animator();\n","import effects from '../helpers/helpers.easing.js';\nimport {resolve} from '../helpers/helpers.options.js';\nimport {color as helpersColor} from '../helpers/helpers.color.js';\n\nconst transparent = 'transparent';\nconst interpolators = {\n boolean(from, to, factor) {\n return factor > 0.5 ? to : from;\n },\n /**\n * @param {string} from\n * @param {string} to\n * @param {number} factor\n */\n color(from, to, factor) {\n const c0 = helpersColor(from || transparent);\n const c1 = c0.valid && helpersColor(to || transparent);\n return c1 && c1.valid\n ? c1.mix(c0, factor).hexString()\n : to;\n },\n number(from, to, factor) {\n return from + (to - from) * factor;\n }\n};\n\nexport default class Animation {\n constructor(cfg, target, prop, to) {\n const currentValue = target[prop];\n\n to = resolve([cfg.to, to, currentValue, cfg.from]);\n const from = resolve([cfg.from, currentValue, to]);\n\n this._active = true;\n this._fn = cfg.fn || interpolators[cfg.type || typeof from];\n this._easing = effects[cfg.easing] || effects.linear;\n this._start = Math.floor(Date.now() + (cfg.delay || 0));\n this._duration = this._total = Math.floor(cfg.duration);\n this._loop = !!cfg.loop;\n this._target = target;\n this._prop = prop;\n this._from = from;\n this._to = to;\n this._promises = undefined;\n }\n\n active() {\n return this._active;\n }\n\n update(cfg, to, date) {\n if (this._active) {\n this._notify(false);\n\n const currentValue = this._target[this._prop];\n const elapsed = date - this._start;\n const remain = this._duration - elapsed;\n this._start = date;\n this._duration = Math.floor(Math.max(remain, cfg.duration));\n this._total += elapsed;\n this._loop = !!cfg.loop;\n this._to = resolve([cfg.to, to, currentValue, cfg.from]);\n this._from = resolve([cfg.from, currentValue, to]);\n }\n }\n\n cancel() {\n if (this._active) {\n // update current evaluated value, for smoother animations\n this.tick(Date.now());\n this._active = false;\n this._notify(false);\n }\n }\n\n tick(date) {\n const elapsed = date - this._start;\n const duration = this._duration;\n const prop = this._prop;\n const from = this._from;\n const loop = this._loop;\n const to = this._to;\n let factor;\n\n this._active = from !== to && (loop || (elapsed < duration));\n\n if (!this._active) {\n this._target[prop] = to;\n this._notify(true);\n return;\n }\n\n if (elapsed < 0) {\n this._target[prop] = from;\n return;\n }\n\n factor = (elapsed / duration) % 2;\n factor = loop && factor > 1 ? 2 - factor : factor;\n factor = this._easing(Math.min(1, Math.max(0, factor)));\n\n this._target[prop] = this._fn(from, to, factor);\n }\n\n wait() {\n const promises = this._promises || (this._promises = []);\n return new Promise((res, rej) => {\n promises.push({res, rej});\n });\n }\n\n _notify(resolved) {\n const method = resolved ? 'res' : 'rej';\n const promises = this._promises || [];\n for (let i = 0; i < promises.length; i++) {\n promises[i][method]();\n }\n }\n}\n","import animator from './core.animator.js';\nimport Animation from './core.animation.js';\nimport defaults from './core.defaults.js';\nimport {isArray, isObject} from '../helpers/helpers.core.js';\n\nexport default class Animations {\n constructor(chart, config) {\n this._chart = chart;\n this._properties = new Map();\n this.configure(config);\n }\n\n configure(config) {\n if (!isObject(config)) {\n return;\n }\n\n const animationOptions = Object.keys(defaults.animation);\n const animatedProps = this._properties;\n\n Object.getOwnPropertyNames(config).forEach(key => {\n const cfg = config[key];\n if (!isObject(cfg)) {\n return;\n }\n const resolved = {};\n for (const option of animationOptions) {\n resolved[option] = cfg[option];\n }\n\n (isArray(cfg.properties) && cfg.properties || [key]).forEach((prop) => {\n if (prop === key || !animatedProps.has(prop)) {\n animatedProps.set(prop, resolved);\n }\n });\n });\n }\n\n /**\n\t * Utility to handle animation of `options`.\n\t * @private\n\t */\n _animateOptions(target, values) {\n const newOptions = values.options;\n const options = resolveTargetOptions(target, newOptions);\n if (!options) {\n return [];\n }\n\n const animations = this._createAnimations(options, newOptions);\n if (newOptions.$shared) {\n // Going to shared options:\n // After all animations are done, assign the shared options object to the element\n // So any new updates to the shared options are observed\n awaitAll(target.options.$animations, newOptions).then(() => {\n target.options = newOptions;\n }, () => {\n // rejected, noop\n });\n }\n\n return animations;\n }\n\n /**\n\t * @private\n\t */\n _createAnimations(target, values) {\n const animatedProps = this._properties;\n const animations = [];\n const running = target.$animations || (target.$animations = {});\n const props = Object.keys(values);\n const date = Date.now();\n let i;\n\n for (i = props.length - 1; i >= 0; --i) {\n const prop = props[i];\n if (prop.charAt(0) === '$') {\n continue;\n }\n\n if (prop === 'options') {\n animations.push(...this._animateOptions(target, values));\n continue;\n }\n const value = values[prop];\n let animation = running[prop];\n const cfg = animatedProps.get(prop);\n\n if (animation) {\n if (cfg && animation.active()) {\n // There is an existing active animation, let's update that\n animation.update(cfg, value, date);\n continue;\n } else {\n animation.cancel();\n }\n }\n if (!cfg || !cfg.duration) {\n // not animated, set directly to new value\n target[prop] = value;\n continue;\n }\n\n running[prop] = animation = new Animation(cfg, target, prop, value);\n animations.push(animation);\n }\n return animations;\n }\n\n\n /**\n\t * Update `target` properties to new values, using configured animations\n\t * @param {object} target - object to update\n\t * @param {object} values - new target properties\n\t * @returns {boolean|undefined} - `true` if animations were started\n\t **/\n update(target, values) {\n if (this._properties.size === 0) {\n // Nothing is animated, just apply the new values.\n Object.assign(target, values);\n return;\n }\n\n const animations = this._createAnimations(target, values);\n\n if (animations.length) {\n animator.add(this._chart, animations);\n return true;\n }\n }\n}\n\nfunction awaitAll(animations, properties) {\n const running = [];\n const keys = Object.keys(properties);\n for (let i = 0; i < keys.length; i++) {\n const anim = animations[keys[i]];\n if (anim && anim.active()) {\n running.push(anim.wait());\n }\n }\n // @ts-ignore\n return Promise.all(running);\n}\n\nfunction resolveTargetOptions(target, newOptions) {\n if (!newOptions) {\n return;\n }\n let options = target.options;\n if (!options) {\n target.options = newOptions;\n return;\n }\n if (options.$shared) {\n // Going from shared options to distinct one:\n // Create new options object containing the old shared values and start updating that.\n target.options = options = Object.assign({}, options, {$shared: false, $animations: {}});\n }\n return options;\n}\n","import Animations from './core.animations.js';\nimport defaults from './core.defaults.js';\nimport {isArray, isFinite, isObject, valueOrDefault, resolveObjectKey, defined} from '../helpers/helpers.core.js';\nimport {listenArrayEvents, unlistenArrayEvents} from '../helpers/helpers.collection.js';\nimport {createContext, sign} from '../helpers/index.js';\n\n/**\n * @typedef { import('./core.controller.js').default } Chart\n * @typedef { import('./core.scale.js').default } Scale\n */\n\nfunction scaleClip(scale, allowedOverflow) {\n const opts = scale && scale.options || {};\n const reverse = opts.reverse;\n const min = opts.min === undefined ? allowedOverflow : 0;\n const max = opts.max === undefined ? allowedOverflow : 0;\n return {\n start: reverse ? max : min,\n end: reverse ? min : max\n };\n}\n\nfunction defaultClip(xScale, yScale, allowedOverflow) {\n if (allowedOverflow === false) {\n return false;\n }\n const x = scaleClip(xScale, allowedOverflow);\n const y = scaleClip(yScale, allowedOverflow);\n\n return {\n top: y.end,\n right: x.end,\n bottom: y.start,\n left: x.start\n };\n}\n\nfunction toClip(value) {\n let t, r, b, l;\n\n if (isObject(value)) {\n t = value.top;\n r = value.right;\n b = value.bottom;\n l = value.left;\n } else {\n t = r = b = l = value;\n }\n\n return {\n top: t,\n right: r,\n bottom: b,\n left: l,\n disabled: value === false\n };\n}\n\nfunction getSortedDatasetIndices(chart, filterVisible) {\n const keys = [];\n const metasets = chart._getSortedDatasetMetas(filterVisible);\n let i, ilen;\n\n for (i = 0, ilen = metasets.length; i < ilen; ++i) {\n keys.push(metasets[i].index);\n }\n return keys;\n}\n\nfunction applyStack(stack, value, dsIndex, options = {}) {\n const keys = stack.keys;\n const singleMode = options.mode === 'single';\n let i, ilen, datasetIndex, otherValue;\n\n if (value === null) {\n return;\n }\n\n let found = false;\n for (i = 0, ilen = keys.length; i < ilen; ++i) {\n datasetIndex = +keys[i];\n if (datasetIndex === dsIndex) {\n found = true;\n if (options.all) {\n continue;\n }\n break;\n }\n otherValue = stack.values[datasetIndex];\n if (isFinite(otherValue) && (singleMode || (value === 0 || sign(value) === sign(otherValue)))) {\n value += otherValue;\n }\n }\n\n if (!found && !options.all) {\n return 0;\n }\n\n return value;\n}\n\nfunction convertObjectDataToArray(data, meta) {\n const {iScale, vScale} = meta;\n const iAxisKey = iScale.axis === 'x' ? 'x' : 'y';\n const vAxisKey = vScale.axis === 'x' ? 'x' : 'y';\n const keys = Object.keys(data);\n const adata = new Array(keys.length);\n let i, ilen, key;\n for (i = 0, ilen = keys.length; i < ilen; ++i) {\n key = keys[i];\n adata[i] = {\n [iAxisKey]: key,\n [vAxisKey]: data[key]\n };\n }\n return adata;\n}\n\nfunction isStacked(scale, meta) {\n const stacked = scale && scale.options.stacked;\n return stacked || (stacked === undefined && meta.stack !== undefined);\n}\n\nfunction getStackKey(indexScale, valueScale, meta) {\n return `${indexScale.id}.${valueScale.id}.${meta.stack || meta.type}`;\n}\n\nfunction getUserBounds(scale) {\n const {min, max, minDefined, maxDefined} = scale.getUserBounds();\n return {\n min: minDefined ? min : Number.NEGATIVE_INFINITY,\n max: maxDefined ? max : Number.POSITIVE_INFINITY\n };\n}\n\nfunction getOrCreateStack(stacks, stackKey, indexValue) {\n const subStack = stacks[stackKey] || (stacks[stackKey] = {});\n return subStack[indexValue] || (subStack[indexValue] = {});\n}\n\nfunction getLastIndexInStack(stack, vScale, positive, type) {\n for (const meta of vScale.getMatchingVisibleMetas(type).reverse()) {\n const value = stack[meta.index];\n if ((positive && value > 0) || (!positive && value < 0)) {\n return meta.index;\n }\n }\n\n return null;\n}\n\nfunction updateStacks(controller, parsed) {\n const {chart, _cachedMeta: meta} = controller;\n const stacks = chart._stacks || (chart._stacks = {}); // map structure is {stackKey: {datasetIndex: value}}\n const {iScale, vScale, index: datasetIndex} = meta;\n const iAxis = iScale.axis;\n const vAxis = vScale.axis;\n const key = getStackKey(iScale, vScale, meta);\n const ilen = parsed.length;\n let stack;\n\n for (let i = 0; i < ilen; ++i) {\n const item = parsed[i];\n const {[iAxis]: index, [vAxis]: value} = item;\n const itemStacks = item._stacks || (item._stacks = {});\n stack = itemStacks[vAxis] = getOrCreateStack(stacks, key, index);\n stack[datasetIndex] = value;\n\n stack._top = getLastIndexInStack(stack, vScale, true, meta.type);\n stack._bottom = getLastIndexInStack(stack, vScale, false, meta.type);\n\n const visualValues = stack._visualValues || (stack._visualValues = {});\n visualValues[datasetIndex] = value;\n }\n}\n\nfunction getFirstScaleId(chart, axis) {\n const scales = chart.scales;\n return Object.keys(scales).filter(key => scales[key].axis === axis).shift();\n}\n\nfunction createDatasetContext(parent, index) {\n return createContext(parent,\n {\n active: false,\n dataset: undefined,\n datasetIndex: index,\n index,\n mode: 'default',\n type: 'dataset'\n }\n );\n}\n\nfunction createDataContext(parent, index, element) {\n return createContext(parent, {\n active: false,\n dataIndex: index,\n parsed: undefined,\n raw: undefined,\n element,\n index,\n mode: 'default',\n type: 'data'\n });\n}\n\nfunction clearStacks(meta, items) {\n // Not using meta.index here, because it might be already updated if the dataset changed location\n const datasetIndex = meta.controller.index;\n const axis = meta.vScale && meta.vScale.axis;\n if (!axis) {\n return;\n }\n\n items = items || meta._parsed;\n for (const parsed of items) {\n const stacks = parsed._stacks;\n if (!stacks || stacks[axis] === undefined || stacks[axis][datasetIndex] === undefined) {\n return;\n }\n delete stacks[axis][datasetIndex];\n if (stacks[axis]._visualValues !== undefined && stacks[axis]._visualValues[datasetIndex] !== undefined) {\n delete stacks[axis]._visualValues[datasetIndex];\n }\n }\n}\n\nconst isDirectUpdateMode = (mode) => mode === 'reset' || mode === 'none';\nconst cloneIfNotShared = (cached, shared) => shared ? cached : Object.assign({}, cached);\nconst createStack = (canStack, meta, chart) => canStack && !meta.hidden && meta._stacked\n && {keys: getSortedDatasetIndices(chart, true), values: null};\n\nexport default class DatasetController {\n\n /**\n * @type {any}\n */\n static defaults = {};\n\n /**\n * Element type used to generate a meta dataset (e.g. Chart.element.LineElement).\n */\n static datasetElementType = null;\n\n /**\n * Element type used to generate a meta data (e.g. Chart.element.PointElement).\n */\n static dataElementType = null;\n\n /**\n\t * @param {Chart} chart\n\t * @param {number} datasetIndex\n\t */\n constructor(chart, datasetIndex) {\n this.chart = chart;\n this._ctx = chart.ctx;\n this.index = datasetIndex;\n this._cachedDataOpts = {};\n this._cachedMeta = this.getMeta();\n this._type = this._cachedMeta.type;\n this.options = undefined;\n /** @type {boolean | object} */\n this._parsing = false;\n this._data = undefined;\n this._objectData = undefined;\n this._sharedOptions = undefined;\n this._drawStart = undefined;\n this._drawCount = undefined;\n this.enableOptionSharing = false;\n this.supportsDecimation = false;\n this.$context = undefined;\n this._syncList = [];\n this.datasetElementType = new.target.datasetElementType;\n this.dataElementType = new.target.dataElementType;\n\n this.initialize();\n }\n\n initialize() {\n const meta = this._cachedMeta;\n this.configure();\n this.linkScales();\n meta._stacked = isStacked(meta.vScale, meta);\n this.addElements();\n\n if (this.options.fill && !this.chart.isPluginEnabled('filler')) {\n console.warn(\"Tried to use the 'fill' option without the 'Filler' plugin enabled. Please import and register the 'Filler' plugin and make sure it is not disabled in the options\");\n }\n }\n\n updateIndex(datasetIndex) {\n if (this.index !== datasetIndex) {\n clearStacks(this._cachedMeta);\n }\n this.index = datasetIndex;\n }\n\n linkScales() {\n const chart = this.chart;\n const meta = this._cachedMeta;\n const dataset = this.getDataset();\n\n const chooseId = (axis, x, y, r) => axis === 'x' ? x : axis === 'r' ? r : y;\n\n const xid = meta.xAxisID = valueOrDefault(dataset.xAxisID, getFirstScaleId(chart, 'x'));\n const yid = meta.yAxisID = valueOrDefault(dataset.yAxisID, getFirstScaleId(chart, 'y'));\n const rid = meta.rAxisID = valueOrDefault(dataset.rAxisID, getFirstScaleId(chart, 'r'));\n const indexAxis = meta.indexAxis;\n const iid = meta.iAxisID = chooseId(indexAxis, xid, yid, rid);\n const vid = meta.vAxisID = chooseId(indexAxis, yid, xid, rid);\n meta.xScale = this.getScaleForId(xid);\n meta.yScale = this.getScaleForId(yid);\n meta.rScale = this.getScaleForId(rid);\n meta.iScale = this.getScaleForId(iid);\n meta.vScale = this.getScaleForId(vid);\n }\n\n getDataset() {\n return this.chart.data.datasets[this.index];\n }\n\n getMeta() {\n return this.chart.getDatasetMeta(this.index);\n }\n\n /**\n\t * @param {string} scaleID\n\t * @return {Scale}\n\t */\n getScaleForId(scaleID) {\n return this.chart.scales[scaleID];\n }\n\n /**\n\t * @private\n\t */\n _getOtherScale(scale) {\n const meta = this._cachedMeta;\n return scale === meta.iScale\n ? meta.vScale\n : meta.iScale;\n }\n\n reset() {\n this._update('reset');\n }\n\n /**\n\t * @private\n\t */\n _destroy() {\n const meta = this._cachedMeta;\n if (this._data) {\n unlistenArrayEvents(this._data, this);\n }\n if (meta._stacked) {\n clearStacks(meta);\n }\n }\n\n /**\n\t * @private\n\t */\n _dataCheck() {\n const dataset = this.getDataset();\n const data = dataset.data || (dataset.data = []);\n const _data = this._data;\n\n // In order to correctly handle data addition/deletion animation (and thus simulate\n // real-time charts), we need to monitor these data modifications and synchronize\n // the internal metadata accordingly.\n\n if (isObject(data)) {\n const meta = this._cachedMeta;\n this._data = convertObjectDataToArray(data, meta);\n } else if (_data !== data) {\n if (_data) {\n // This case happens when the user replaced the data array instance.\n unlistenArrayEvents(_data, this);\n // Discard old parsed data and stacks\n const meta = this._cachedMeta;\n clearStacks(meta);\n meta._parsed = [];\n }\n if (data && Object.isExtensible(data)) {\n listenArrayEvents(data, this);\n }\n this._syncList = [];\n this._data = data;\n }\n }\n\n addElements() {\n const meta = this._cachedMeta;\n\n this._dataCheck();\n\n if (this.datasetElementType) {\n meta.dataset = new this.datasetElementType();\n }\n }\n\n buildOrUpdateElements(resetNewElements) {\n const meta = this._cachedMeta;\n const dataset = this.getDataset();\n let stackChanged = false;\n\n this._dataCheck();\n\n // make sure cached _stacked status is current\n const oldStacked = meta._stacked;\n meta._stacked = isStacked(meta.vScale, meta);\n\n // detect change in stack option\n if (meta.stack !== dataset.stack) {\n stackChanged = true;\n // remove values from old stack\n clearStacks(meta);\n meta.stack = dataset.stack;\n }\n\n // Re-sync meta data in case the user replaced the data array or if we missed\n // any updates and so make sure that we handle number of datapoints changing.\n this._resyncElements(resetNewElements);\n\n // if stack changed, update stack values for the whole dataset\n if (stackChanged || oldStacked !== meta._stacked) {\n updateStacks(this, meta._parsed);\n meta._stacked = isStacked(meta.vScale, meta);\n }\n }\n\n /**\n\t * Merges user-supplied and default dataset-level options\n\t * @private\n\t */\n configure() {\n const config = this.chart.config;\n const scopeKeys = config.datasetScopeKeys(this._type);\n const scopes = config.getOptionScopes(this.getDataset(), scopeKeys, true);\n this.options = config.createResolver(scopes, this.getContext());\n this._parsing = this.options.parsing;\n this._cachedDataOpts = {};\n }\n\n /**\n\t * @param {number} start\n\t * @param {number} count\n\t */\n parse(start, count) {\n const {_cachedMeta: meta, _data: data} = this;\n const {iScale, _stacked} = meta;\n const iAxis = iScale.axis;\n\n let sorted = start === 0 && count === data.length ? true : meta._sorted;\n let prev = start > 0 && meta._parsed[start - 1];\n let i, cur, parsed;\n\n if (this._parsing === false) {\n meta._parsed = data;\n meta._sorted = true;\n parsed = data;\n } else {\n if (isArray(data[start])) {\n parsed = this.parseArrayData(meta, data, start, count);\n } else if (isObject(data[start])) {\n parsed = this.parseObjectData(meta, data, start, count);\n } else {\n parsed = this.parsePrimitiveData(meta, data, start, count);\n }\n\n const isNotInOrderComparedToPrev = () => cur[iAxis] === null || (prev && cur[iAxis] < prev[iAxis]);\n for (i = 0; i < count; ++i) {\n meta._parsed[i + start] = cur = parsed[i];\n if (sorted) {\n if (isNotInOrderComparedToPrev()) {\n sorted = false;\n }\n prev = cur;\n }\n }\n meta._sorted = sorted;\n }\n\n if (_stacked) {\n updateStacks(this, parsed);\n }\n }\n\n /**\n\t * Parse array of primitive values\n\t * @param {object} meta - dataset meta\n\t * @param {array} data - data array. Example [1,3,4]\n\t * @param {number} start - start index\n\t * @param {number} count - number of items to parse\n\t * @returns {object} parsed item - item containing index and a parsed value\n\t * for each scale id.\n\t * Example: {xScale0: 0, yScale0: 1}\n\t * @protected\n\t */\n parsePrimitiveData(meta, data, start, count) {\n const {iScale, vScale} = meta;\n const iAxis = iScale.axis;\n const vAxis = vScale.axis;\n const labels = iScale.getLabels();\n const singleScale = iScale === vScale;\n const parsed = new Array(count);\n let i, ilen, index;\n\n for (i = 0, ilen = count; i < ilen; ++i) {\n index = i + start;\n parsed[i] = {\n [iAxis]: singleScale || iScale.parse(labels[index], index),\n [vAxis]: vScale.parse(data[index], index)\n };\n }\n return parsed;\n }\n\n /**\n\t * Parse array of arrays\n\t * @param {object} meta - dataset meta\n\t * @param {array} data - data array. Example [[1,2],[3,4]]\n\t * @param {number} start - start index\n\t * @param {number} count - number of items to parse\n\t * @returns {object} parsed item - item containing index and a parsed value\n\t * for each scale id.\n\t * Example: {x: 0, y: 1}\n\t * @protected\n\t */\n parseArrayData(meta, data, start, count) {\n const {xScale, yScale} = meta;\n const parsed = new Array(count);\n let i, ilen, index, item;\n\n for (i = 0, ilen = count; i < ilen; ++i) {\n index = i + start;\n item = data[index];\n parsed[i] = {\n x: xScale.parse(item[0], index),\n y: yScale.parse(item[1], index)\n };\n }\n return parsed;\n }\n\n /**\n\t * Parse array of objects\n\t * @param {object} meta - dataset meta\n\t * @param {array} data - data array. Example [{x:1, y:5}, {x:2, y:10}]\n\t * @param {number} start - start index\n\t * @param {number} count - number of items to parse\n\t * @returns {object} parsed item - item containing index and a parsed value\n\t * for each scale id. _custom is optional\n\t * Example: {xScale0: 0, yScale0: 1, _custom: {r: 10, foo: 'bar'}}\n\t * @protected\n\t */\n parseObjectData(meta, data, start, count) {\n const {xScale, yScale} = meta;\n const {xAxisKey = 'x', yAxisKey = 'y'} = this._parsing;\n const parsed = new Array(count);\n let i, ilen, index, item;\n\n for (i = 0, ilen = count; i < ilen; ++i) {\n index = i + start;\n item = data[index];\n parsed[i] = {\n x: xScale.parse(resolveObjectKey(item, xAxisKey), index),\n y: yScale.parse(resolveObjectKey(item, yAxisKey), index)\n };\n }\n return parsed;\n }\n\n /**\n\t * @protected\n\t */\n getParsed(index) {\n return this._cachedMeta._parsed[index];\n }\n\n /**\n\t * @protected\n\t */\n getDataElement(index) {\n return this._cachedMeta.data[index];\n }\n\n /**\n\t * @protected\n\t */\n applyStack(scale, parsed, mode) {\n const chart = this.chart;\n const meta = this._cachedMeta;\n const value = parsed[scale.axis];\n const stack = {\n keys: getSortedDatasetIndices(chart, true),\n values: parsed._stacks[scale.axis]._visualValues\n };\n return applyStack(stack, value, meta.index, {mode});\n }\n\n /**\n\t * @protected\n\t */\n updateRangeFromParsed(range, scale, parsed, stack) {\n const parsedValue = parsed[scale.axis];\n let value = parsedValue === null ? NaN : parsedValue;\n const values = stack && parsed._stacks[scale.axis];\n if (stack && values) {\n stack.values = values;\n value = applyStack(stack, parsedValue, this._cachedMeta.index);\n }\n range.min = Math.min(range.min, value);\n range.max = Math.max(range.max, value);\n }\n\n /**\n\t * @protected\n\t */\n getMinMax(scale, canStack) {\n const meta = this._cachedMeta;\n const _parsed = meta._parsed;\n const sorted = meta._sorted && scale === meta.iScale;\n const ilen = _parsed.length;\n const otherScale = this._getOtherScale(scale);\n const stack = createStack(canStack, meta, this.chart);\n const range = {min: Number.POSITIVE_INFINITY, max: Number.NEGATIVE_INFINITY};\n const {min: otherMin, max: otherMax} = getUserBounds(otherScale);\n let i, parsed;\n\n function _skip() {\n parsed = _parsed[i];\n const otherValue = parsed[otherScale.axis];\n return !isFinite(parsed[scale.axis]) || otherMin > otherValue || otherMax < otherValue;\n }\n\n for (i = 0; i < ilen; ++i) {\n if (_skip()) {\n continue;\n }\n this.updateRangeFromParsed(range, scale, parsed, stack);\n if (sorted) {\n // if the data is sorted, we don't need to check further from this end of array\n break;\n }\n }\n if (sorted) {\n // in the sorted case, find first non-skipped value from other end of array\n for (i = ilen - 1; i >= 0; --i) {\n if (_skip()) {\n continue;\n }\n this.updateRangeFromParsed(range, scale, parsed, stack);\n break;\n }\n }\n return range;\n }\n\n getAllParsedValues(scale) {\n const parsed = this._cachedMeta._parsed;\n const values = [];\n let i, ilen, value;\n\n for (i = 0, ilen = parsed.length; i < ilen; ++i) {\n value = parsed[i][scale.axis];\n if (isFinite(value)) {\n values.push(value);\n }\n }\n return values;\n }\n\n /**\n\t * @return {number|boolean}\n\t * @protected\n\t */\n getMaxOverflow() {\n return false;\n }\n\n /**\n\t * @protected\n\t */\n getLabelAndValue(index) {\n const meta = this._cachedMeta;\n const iScale = meta.iScale;\n const vScale = meta.vScale;\n const parsed = this.getParsed(index);\n return {\n label: iScale ? '' + iScale.getLabelForValue(parsed[iScale.axis]) : '',\n value: vScale ? '' + vScale.getLabelForValue(parsed[vScale.axis]) : ''\n };\n }\n\n /**\n\t * @private\n\t */\n _update(mode) {\n const meta = this._cachedMeta;\n this.update(mode || 'default');\n meta._clip = toClip(valueOrDefault(this.options.clip, defaultClip(meta.xScale, meta.yScale, this.getMaxOverflow())));\n }\n\n /**\n\t * @param {string} mode\n\t */\n update(mode) {} // eslint-disable-line no-unused-vars\n\n draw() {\n const ctx = this._ctx;\n const chart = this.chart;\n const meta = this._cachedMeta;\n const elements = meta.data || [];\n const area = chart.chartArea;\n const active = [];\n const start = this._drawStart || 0;\n const count = this._drawCount || (elements.length - start);\n const drawActiveElementsOnTop = this.options.drawActiveElementsOnTop;\n let i;\n\n if (meta.dataset) {\n meta.dataset.draw(ctx, area, start, count);\n }\n\n for (i = start; i < start + count; ++i) {\n const element = elements[i];\n if (element.hidden) {\n continue;\n }\n if (element.active && drawActiveElementsOnTop) {\n active.push(element);\n } else {\n element.draw(ctx, area);\n }\n }\n\n for (i = 0; i < active.length; ++i) {\n active[i].draw(ctx, area);\n }\n }\n\n /**\n\t * Returns a set of predefined style properties that should be used to represent the dataset\n\t * or the data if the index is specified\n\t * @param {number} index - data index\n\t * @param {boolean} [active] - true if hover\n\t * @return {object} style object\n\t */\n getStyle(index, active) {\n const mode = active ? 'active' : 'default';\n return index === undefined && this._cachedMeta.dataset\n ? this.resolveDatasetElementOptions(mode)\n : this.resolveDataElementOptions(index || 0, mode);\n }\n\n /**\n\t * @protected\n\t */\n getContext(index, active, mode) {\n const dataset = this.getDataset();\n let context;\n if (index >= 0 && index < this._cachedMeta.data.length) {\n const element = this._cachedMeta.data[index];\n context = element.$context ||\n (element.$context = createDataContext(this.getContext(), index, element));\n context.parsed = this.getParsed(index);\n context.raw = dataset.data[index];\n context.index = context.dataIndex = index;\n } else {\n context = this.$context ||\n (this.$context = createDatasetContext(this.chart.getContext(), this.index));\n context.dataset = dataset;\n context.index = context.datasetIndex = this.index;\n }\n\n context.active = !!active;\n context.mode = mode;\n return context;\n }\n\n /**\n\t * @param {string} [mode]\n\t * @protected\n\t */\n resolveDatasetElementOptions(mode) {\n return this._resolveElementOptions(this.datasetElementType.id, mode);\n }\n\n /**\n\t * @param {number} index\n\t * @param {string} [mode]\n\t * @protected\n\t */\n resolveDataElementOptions(index, mode) {\n return this._resolveElementOptions(this.dataElementType.id, mode, index);\n }\n\n /**\n\t * @private\n\t */\n _resolveElementOptions(elementType, mode = 'default', index) {\n const active = mode === 'active';\n const cache = this._cachedDataOpts;\n const cacheKey = elementType + '-' + mode;\n const cached = cache[cacheKey];\n const sharing = this.enableOptionSharing && defined(index);\n if (cached) {\n return cloneIfNotShared(cached, sharing);\n }\n const config = this.chart.config;\n const scopeKeys = config.datasetElementScopeKeys(this._type, elementType);\n const prefixes = active ? [`${elementType}Hover`, 'hover', elementType, ''] : [elementType, ''];\n const scopes = config.getOptionScopes(this.getDataset(), scopeKeys);\n const names = Object.keys(defaults.elements[elementType]);\n // context is provided as a function, and is called only if needed,\n // so we don't create a context for each element if not needed.\n const context = () => this.getContext(index, active, mode);\n const values = config.resolveNamedOptions(scopes, names, context, prefixes);\n\n if (values.$shared) {\n // `$shared` indicates this set of options can be shared between multiple elements.\n // Sharing is used to reduce number of properties to change during animation.\n values.$shared = sharing;\n\n // We cache options by `mode`, which can be 'active' for example. This enables us\n // to have the 'active' element options and 'default' options to switch between\n // when interacting.\n cache[cacheKey] = Object.freeze(cloneIfNotShared(values, sharing));\n }\n\n return values;\n }\n\n\n /**\n\t * @private\n\t */\n _resolveAnimations(index, transition, active) {\n const chart = this.chart;\n const cache = this._cachedDataOpts;\n const cacheKey = `animation-${transition}`;\n const cached = cache[cacheKey];\n if (cached) {\n return cached;\n }\n let options;\n if (chart.options.animation !== false) {\n const config = this.chart.config;\n const scopeKeys = config.datasetAnimationScopeKeys(this._type, transition);\n const scopes = config.getOptionScopes(this.getDataset(), scopeKeys);\n options = config.createResolver(scopes, this.getContext(index, active, transition));\n }\n const animations = new Animations(chart, options && options.animations);\n if (options && options._cacheable) {\n cache[cacheKey] = Object.freeze(animations);\n }\n return animations;\n }\n\n /**\n\t * Utility for getting the options object shared between elements\n\t * @protected\n\t */\n getSharedOptions(options) {\n if (!options.$shared) {\n return;\n }\n return this._sharedOptions || (this._sharedOptions = Object.assign({}, options));\n }\n\n /**\n\t * Utility for determining if `options` should be included in the updated properties\n\t * @protected\n\t */\n includeOptions(mode, sharedOptions) {\n return !sharedOptions || isDirectUpdateMode(mode) || this.chart._animationsDisabled;\n }\n\n /**\n * @todo v4, rename to getSharedOptions and remove excess functions\n */\n _getSharedOptions(start, mode) {\n const firstOpts = this.resolveDataElementOptions(start, mode);\n const previouslySharedOptions = this._sharedOptions;\n const sharedOptions = this.getSharedOptions(firstOpts);\n const includeOptions = this.includeOptions(mode, sharedOptions) || (sharedOptions !== previouslySharedOptions);\n this.updateSharedOptions(sharedOptions, mode, firstOpts);\n return {sharedOptions, includeOptions};\n }\n\n /**\n\t * Utility for updating an element with new properties, using animations when appropriate.\n\t * @protected\n\t */\n updateElement(element, index, properties, mode) {\n if (isDirectUpdateMode(mode)) {\n Object.assign(element, properties);\n } else {\n this._resolveAnimations(index, mode).update(element, properties);\n }\n }\n\n /**\n\t * Utility to animate the shared options, that are potentially affecting multiple elements.\n\t * @protected\n\t */\n updateSharedOptions(sharedOptions, mode, newOptions) {\n if (sharedOptions && !isDirectUpdateMode(mode)) {\n this._resolveAnimations(undefined, mode).update(sharedOptions, newOptions);\n }\n }\n\n /**\n\t * @private\n\t */\n _setStyle(element, index, mode, active) {\n element.active = active;\n const options = this.getStyle(index, active);\n this._resolveAnimations(index, mode, active).update(element, {\n // When going from active to inactive, we need to update to the shared options.\n // This way the once hovered element will end up with the same original shared options instance, after animation.\n options: (!active && this.getSharedOptions(options)) || options\n });\n }\n\n removeHoverStyle(element, datasetIndex, index) {\n this._setStyle(element, index, 'active', false);\n }\n\n setHoverStyle(element, datasetIndex, index) {\n this._setStyle(element, index, 'active', true);\n }\n\n /**\n\t * @private\n\t */\n _removeDatasetHoverStyle() {\n const element = this._cachedMeta.dataset;\n\n if (element) {\n this._setStyle(element, undefined, 'active', false);\n }\n }\n\n /**\n\t * @private\n\t */\n _setDatasetHoverStyle() {\n const element = this._cachedMeta.dataset;\n\n if (element) {\n this._setStyle(element, undefined, 'active', true);\n }\n }\n\n /**\n\t * @private\n\t */\n _resyncElements(resetNewElements) {\n const data = this._data;\n const elements = this._cachedMeta.data;\n\n // Apply changes detected through array listeners\n for (const [method, arg1, arg2] of this._syncList) {\n this[method](arg1, arg2);\n }\n this._syncList = [];\n\n const numMeta = elements.length;\n const numData = data.length;\n const count = Math.min(numData, numMeta);\n\n if (count) {\n // TODO: It is not optimal to always parse the old data\n // This is done because we are not detecting direct assignments:\n // chart.data.datasets[0].data[5] = 10;\n // chart.data.datasets[0].data[5].y = 10;\n this.parse(0, count);\n }\n\n if (numData > numMeta) {\n this._insertElements(numMeta, numData - numMeta, resetNewElements);\n } else if (numData < numMeta) {\n this._removeElements(numData, numMeta - numData);\n }\n }\n\n /**\n\t * @private\n\t */\n _insertElements(start, count, resetNewElements = true) {\n const meta = this._cachedMeta;\n const data = meta.data;\n const end = start + count;\n let i;\n\n const move = (arr) => {\n arr.length += count;\n for (i = arr.length - 1; i >= end; i--) {\n arr[i] = arr[i - count];\n }\n };\n move(data);\n\n for (i = start; i < end; ++i) {\n data[i] = new this.dataElementType();\n }\n\n if (this._parsing) {\n move(meta._parsed);\n }\n this.parse(start, count);\n\n if (resetNewElements) {\n this.updateElements(data, start, count, 'reset');\n }\n }\n\n updateElements(element, start, count, mode) {} // eslint-disable-line no-unused-vars\n\n /**\n\t * @private\n\t */\n _removeElements(start, count) {\n const meta = this._cachedMeta;\n if (this._parsing) {\n const removed = meta._parsed.splice(start, count);\n if (meta._stacked) {\n clearStacks(meta, removed);\n }\n }\n meta.data.splice(start, count);\n }\n\n /**\n\t * @private\n */\n _sync(args) {\n if (this._parsing) {\n this._syncList.push(args);\n } else {\n const [method, arg1, arg2] = args;\n this[method](arg1, arg2);\n }\n this.chart._dataChanges.push([this.index, ...args]);\n }\n\n _onDataPush() {\n const count = arguments.length;\n this._sync(['_insertElements', this.getDataset().data.length - count, count]);\n }\n\n _onDataPop() {\n this._sync(['_removeElements', this._cachedMeta.data.length - 1, 1]);\n }\n\n _onDataShift() {\n this._sync(['_removeElements', 0, 1]);\n }\n\n _onDataSplice(start, count) {\n if (count) {\n this._sync(['_removeElements', start, count]);\n }\n const newCount = arguments.length - 2;\n if (newCount) {\n this._sync(['_insertElements', start, newCount]);\n }\n }\n\n _onDataUnshift() {\n this._sync(['_insertElements', 0, arguments.length]);\n }\n}\n","import DatasetController from '../core/core.datasetController.js';\nimport {\n _arrayUnique, isArray, isNullOrUndef,\n valueOrDefault, resolveObjectKey, sign, defined\n} from '../helpers/index.js';\n\nfunction getAllScaleValues(scale, type) {\n if (!scale._cache.$bar) {\n const visibleMetas = scale.getMatchingVisibleMetas(type);\n let values = [];\n\n for (let i = 0, ilen = visibleMetas.length; i < ilen; i++) {\n values = values.concat(visibleMetas[i].controller.getAllParsedValues(scale));\n }\n scale._cache.$bar = _arrayUnique(values.sort((a, b) => a - b));\n }\n return scale._cache.$bar;\n}\n\n/**\n * Computes the \"optimal\" sample size to maintain bars equally sized while preventing overlap.\n * @private\n */\nfunction computeMinSampleSize(meta) {\n const scale = meta.iScale;\n const values = getAllScaleValues(scale, meta.type);\n let min = scale._length;\n let i, ilen, curr, prev;\n const updateMinAndPrev = () => {\n if (curr === 32767 || curr === -32768) {\n // Ignore truncated pixels\n return;\n }\n if (defined(prev)) {\n // curr - prev === 0 is ignored\n min = Math.min(min, Math.abs(curr - prev) || min);\n }\n prev = curr;\n };\n\n for (i = 0, ilen = values.length; i < ilen; ++i) {\n curr = scale.getPixelForValue(values[i]);\n updateMinAndPrev();\n }\n\n prev = undefined;\n for (i = 0, ilen = scale.ticks.length; i < ilen; ++i) {\n curr = scale.getPixelForTick(i);\n updateMinAndPrev();\n }\n\n return min;\n}\n\n/**\n * Computes an \"ideal\" category based on the absolute bar thickness or, if undefined or null,\n * uses the smallest interval (see computeMinSampleSize) that prevents bar overlapping. This\n * mode currently always generates bars equally sized (until we introduce scriptable options?).\n * @private\n */\nfunction computeFitCategoryTraits(index, ruler, options, stackCount) {\n const thickness = options.barThickness;\n let size, ratio;\n\n if (isNullOrUndef(thickness)) {\n size = ruler.min * options.categoryPercentage;\n ratio = options.barPercentage;\n } else {\n // When bar thickness is enforced, category and bar percentages are ignored.\n // Note(SB): we could add support for relative bar thickness (e.g. barThickness: '50%')\n // and deprecate barPercentage since this value is ignored when thickness is absolute.\n size = thickness * stackCount;\n ratio = 1;\n }\n\n return {\n chunk: size / stackCount,\n ratio,\n start: ruler.pixels[index] - (size / 2)\n };\n}\n\n/**\n * Computes an \"optimal\" category that globally arranges bars side by side (no gap when\n * percentage options are 1), based on the previous and following categories. This mode\n * generates bars with different widths when data are not evenly spaced.\n * @private\n */\nfunction computeFlexCategoryTraits(index, ruler, options, stackCount) {\n const pixels = ruler.pixels;\n const curr = pixels[index];\n let prev = index > 0 ? pixels[index - 1] : null;\n let next = index < pixels.length - 1 ? pixels[index + 1] : null;\n const percent = options.categoryPercentage;\n\n if (prev === null) {\n // first data: its size is double based on the next point or,\n // if it's also the last data, we use the scale size.\n prev = curr - (next === null ? ruler.end - ruler.start : next - curr);\n }\n\n if (next === null) {\n // last data: its size is also double based on the previous point.\n next = curr + curr - prev;\n }\n\n const start = curr - (curr - Math.min(prev, next)) / 2 * percent;\n const size = Math.abs(next - prev) / 2 * percent;\n\n return {\n chunk: size / stackCount,\n ratio: options.barPercentage,\n start\n };\n}\n\nfunction parseFloatBar(entry, item, vScale, i) {\n const startValue = vScale.parse(entry[0], i);\n const endValue = vScale.parse(entry[1], i);\n const min = Math.min(startValue, endValue);\n const max = Math.max(startValue, endValue);\n let barStart = min;\n let barEnd = max;\n\n if (Math.abs(min) > Math.abs(max)) {\n barStart = max;\n barEnd = min;\n }\n\n // Store `barEnd` (furthest away from origin) as parsed value,\n // to make stacking straight forward\n item[vScale.axis] = barEnd;\n\n item._custom = {\n barStart,\n barEnd,\n start: startValue,\n end: endValue,\n min,\n max\n };\n}\n\nfunction parseValue(entry, item, vScale, i) {\n if (isArray(entry)) {\n parseFloatBar(entry, item, vScale, i);\n } else {\n item[vScale.axis] = vScale.parse(entry, i);\n }\n return item;\n}\n\nfunction parseArrayOrPrimitive(meta, data, start, count) {\n const iScale = meta.iScale;\n const vScale = meta.vScale;\n const labels = iScale.getLabels();\n const singleScale = iScale === vScale;\n const parsed = [];\n let i, ilen, item, entry;\n\n for (i = start, ilen = start + count; i < ilen; ++i) {\n entry = data[i];\n item = {};\n item[iScale.axis] = singleScale || iScale.parse(labels[i], i);\n parsed.push(parseValue(entry, item, vScale, i));\n }\n return parsed;\n}\n\nfunction isFloatBar(custom) {\n return custom && custom.barStart !== undefined && custom.barEnd !== undefined;\n}\n\nfunction barSign(size, vScale, actualBase) {\n if (size !== 0) {\n return sign(size);\n }\n return (vScale.isHorizontal() ? 1 : -1) * (vScale.min >= actualBase ? 1 : -1);\n}\n\nfunction borderProps(properties) {\n let reverse, start, end, top, bottom;\n if (properties.horizontal) {\n reverse = properties.base > properties.x;\n start = 'left';\n end = 'right';\n } else {\n reverse = properties.base < properties.y;\n start = 'bottom';\n end = 'top';\n }\n if (reverse) {\n top = 'end';\n bottom = 'start';\n } else {\n top = 'start';\n bottom = 'end';\n }\n return {start, end, reverse, top, bottom};\n}\n\nfunction setBorderSkipped(properties, options, stack, index) {\n let edge = options.borderSkipped;\n const res = {};\n\n if (!edge) {\n properties.borderSkipped = res;\n return;\n }\n\n if (edge === true) {\n properties.borderSkipped = {top: true, right: true, bottom: true, left: true};\n return;\n }\n\n const {start, end, reverse, top, bottom} = borderProps(properties);\n\n if (edge === 'middle' && stack) {\n properties.enableBorderRadius = true;\n if ((stack._top || 0) === index) {\n edge = top;\n } else if ((stack._bottom || 0) === index) {\n edge = bottom;\n } else {\n res[parseEdge(bottom, start, end, reverse)] = true;\n edge = top;\n }\n }\n\n res[parseEdge(edge, start, end, reverse)] = true;\n properties.borderSkipped = res;\n}\n\nfunction parseEdge(edge, a, b, reverse) {\n if (reverse) {\n edge = swap(edge, a, b);\n edge = startEnd(edge, b, a);\n } else {\n edge = startEnd(edge, a, b);\n }\n return edge;\n}\n\nfunction swap(orig, v1, v2) {\n return orig === v1 ? v2 : orig === v2 ? v1 : orig;\n}\n\nfunction startEnd(v, start, end) {\n return v === 'start' ? start : v === 'end' ? end : v;\n}\n\nfunction setInflateAmount(properties, {inflateAmount}, ratio) {\n properties.inflateAmount = inflateAmount === 'auto'\n ? ratio === 1 ? 0.33 : 0\n : inflateAmount;\n}\n\nexport default class BarController extends DatasetController {\n\n static id = 'bar';\n\n /**\n * @type {any}\n */\n static defaults = {\n datasetElementType: false,\n dataElementType: 'bar',\n\n categoryPercentage: 0.8,\n barPercentage: 0.9,\n grouped: true,\n\n animations: {\n numbers: {\n type: 'number',\n properties: ['x', 'y', 'base', 'width', 'height']\n }\n }\n };\n\n /**\n * @type {any}\n */\n static overrides = {\n scales: {\n _index_: {\n type: 'category',\n offset: true,\n grid: {\n offset: true\n }\n },\n _value_: {\n type: 'linear',\n beginAtZero: true,\n }\n }\n };\n\n\n /**\n\t * Overriding primitive data parsing since we support mixed primitive/array\n\t * data for float bars\n\t * @protected\n\t */\n parsePrimitiveData(meta, data, start, count) {\n return parseArrayOrPrimitive(meta, data, start, count);\n }\n\n /**\n\t * Overriding array data parsing since we support mixed primitive/array\n\t * data for float bars\n\t * @protected\n\t */\n parseArrayData(meta, data, start, count) {\n return parseArrayOrPrimitive(meta, data, start, count);\n }\n\n /**\n\t * Overriding object data parsing since we support mixed primitive/array\n\t * value-scale data for float bars\n\t * @protected\n\t */\n parseObjectData(meta, data, start, count) {\n const {iScale, vScale} = meta;\n const {xAxisKey = 'x', yAxisKey = 'y'} = this._parsing;\n const iAxisKey = iScale.axis === 'x' ? xAxisKey : yAxisKey;\n const vAxisKey = vScale.axis === 'x' ? xAxisKey : yAxisKey;\n const parsed = [];\n let i, ilen, item, obj;\n for (i = start, ilen = start + count; i < ilen; ++i) {\n obj = data[i];\n item = {};\n item[iScale.axis] = iScale.parse(resolveObjectKey(obj, iAxisKey), i);\n parsed.push(parseValue(resolveObjectKey(obj, vAxisKey), item, vScale, i));\n }\n return parsed;\n }\n\n /**\n\t * @protected\n\t */\n updateRangeFromParsed(range, scale, parsed, stack) {\n super.updateRangeFromParsed(range, scale, parsed, stack);\n const custom = parsed._custom;\n if (custom && scale === this._cachedMeta.vScale) {\n // float bar: only one end of the bar is considered by `super`\n range.min = Math.min(range.min, custom.min);\n range.max = Math.max(range.max, custom.max);\n }\n }\n\n /**\n\t * @return {number|boolean}\n\t * @protected\n\t */\n getMaxOverflow() {\n return 0;\n }\n\n /**\n\t * @protected\n\t */\n getLabelAndValue(index) {\n const meta = this._cachedMeta;\n const {iScale, vScale} = meta;\n const parsed = this.getParsed(index);\n const custom = parsed._custom;\n const value = isFloatBar(custom)\n ? '[' + custom.start + ', ' + custom.end + ']'\n : '' + vScale.getLabelForValue(parsed[vScale.axis]);\n\n return {\n label: '' + iScale.getLabelForValue(parsed[iScale.axis]),\n value\n };\n }\n\n initialize() {\n this.enableOptionSharing = true;\n\n super.initialize();\n\n const meta = this._cachedMeta;\n meta.stack = this.getDataset().stack;\n }\n\n update(mode) {\n const meta = this._cachedMeta;\n this.updateElements(meta.data, 0, meta.data.length, mode);\n }\n\n updateElements(bars, start, count, mode) {\n const reset = mode === 'reset';\n const {index, _cachedMeta: {vScale}} = this;\n const base = vScale.getBasePixel();\n const horizontal = vScale.isHorizontal();\n const ruler = this._getRuler();\n const {sharedOptions, includeOptions} = this._getSharedOptions(start, mode);\n\n for (let i = start; i < start + count; i++) {\n const parsed = this.getParsed(i);\n const vpixels = reset || isNullOrUndef(parsed[vScale.axis]) ? {base, head: base} : this._calculateBarValuePixels(i);\n const ipixels = this._calculateBarIndexPixels(i, ruler);\n const stack = (parsed._stacks || {})[vScale.axis];\n\n const properties = {\n horizontal,\n base: vpixels.base,\n enableBorderRadius: !stack || isFloatBar(parsed._custom) || (index === stack._top || index === stack._bottom),\n x: horizontal ? vpixels.head : ipixels.center,\n y: horizontal ? ipixels.center : vpixels.head,\n height: horizontal ? ipixels.size : Math.abs(vpixels.size),\n width: horizontal ? Math.abs(vpixels.size) : ipixels.size\n };\n\n if (includeOptions) {\n properties.options = sharedOptions || this.resolveDataElementOptions(i, bars[i].active ? 'active' : mode);\n }\n const options = properties.options || bars[i].options;\n setBorderSkipped(properties, options, stack, index);\n setInflateAmount(properties, options, ruler.ratio);\n this.updateElement(bars[i], i, properties, mode);\n }\n }\n\n /**\n\t * Returns the stacks based on groups and bar visibility.\n\t * @param {number} [last] - The dataset index\n\t * @param {number} [dataIndex] - The data index of the ruler\n\t * @returns {string[]} The list of stack IDs\n\t * @private\n\t */\n _getStacks(last, dataIndex) {\n const {iScale} = this._cachedMeta;\n const metasets = iScale.getMatchingVisibleMetas(this._type)\n .filter(meta => meta.controller.options.grouped);\n const stacked = iScale.options.stacked;\n const stacks = [];\n const currentParsed = this._cachedMeta.controller.getParsed(dataIndex);\n const iScaleValue = currentParsed && currentParsed[iScale.axis];\n\n const skipNull = (meta) => {\n const parsed = meta._parsed.find(item => item[iScale.axis] === iScaleValue);\n const val = parsed && parsed[meta.vScale.axis];\n\n if (isNullOrUndef(val) || isNaN(val)) {\n return true;\n }\n };\n\n for (const meta of metasets) {\n if (dataIndex !== undefined && skipNull(meta)) {\n continue;\n }\n\n // stacked | meta.stack\n // | found | not found | undefined\n // false | x | x | x\n // true | | x |\n // undefined | | x | x\n if (stacked === false || stacks.indexOf(meta.stack) === -1 ||\n\t\t\t\t(stacked === undefined && meta.stack === undefined)) {\n stacks.push(meta.stack);\n }\n if (meta.index === last) {\n break;\n }\n }\n\n // No stacks? that means there is no visible data. Let's still initialize an `undefined`\n // stack where possible invisible bars will be located.\n // https://github.com/chartjs/Chart.js/issues/6368\n if (!stacks.length) {\n stacks.push(undefined);\n }\n\n return stacks;\n }\n\n /**\n\t * Returns the effective number of stacks based on groups and bar visibility.\n\t * @private\n\t */\n _getStackCount(index) {\n return this._getStacks(undefined, index).length;\n }\n\n _getAxisCount() {\n return this._getAxis().length;\n }\n\n getFirstScaleIdForIndexAxis() {\n const scales = this.chart.scales;\n const indexScaleId = this.chart.options.indexAxis;\n return Object.keys(scales).filter(key => scales[key].axis === indexScaleId).shift();\n }\n\n _getAxis() {\n const axis = {};\n const firstScaleAxisId = this.getFirstScaleIdForIndexAxis();\n for (const dataset of this.chart.data.datasets) {\n axis[valueOrDefault(\n this.chart.options.indexAxis === 'x' ? dataset.xAxisID : dataset.yAxisID, firstScaleAxisId\n )] = true;\n }\n return Object.keys(axis);\n }\n\n /**\n\t * Returns the stack index for the given dataset based on groups and bar visibility.\n\t * @param {number} [datasetIndex] - The dataset index\n\t * @param {string} [name] - The stack name to find\n * @param {number} [dataIndex]\n\t * @returns {number} The stack index\n\t * @private\n\t */\n _getStackIndex(datasetIndex, name, dataIndex) {\n const stacks = this._getStacks(datasetIndex, dataIndex);\n const index = (name !== undefined)\n ? stacks.indexOf(name)\n : -1; // indexOf returns -1 if element is not present\n\n return (index === -1)\n ? stacks.length - 1\n : index;\n }\n\n /**\n\t * @private\n\t */\n _getRuler() {\n const opts = this.options;\n const meta = this._cachedMeta;\n const iScale = meta.iScale;\n const pixels = [];\n let i, ilen;\n\n for (i = 0, ilen = meta.data.length; i < ilen; ++i) {\n pixels.push(iScale.getPixelForValue(this.getParsed(i)[iScale.axis], i));\n }\n\n const barThickness = opts.barThickness;\n const min = barThickness || computeMinSampleSize(meta);\n\n return {\n min,\n pixels,\n start: iScale._startPixel,\n end: iScale._endPixel,\n stackCount: this._getStackCount(),\n scale: iScale,\n grouped: opts.grouped,\n // bar thickness ratio used for non-grouped bars\n ratio: barThickness ? 1 : opts.categoryPercentage * opts.barPercentage\n };\n }\n\n /**\n\t * Note: pixel values are not clamped to the scale area.\n\t * @private\n\t */\n _calculateBarValuePixels(index) {\n const {_cachedMeta: {vScale, _stacked, index: datasetIndex}, options: {base: baseValue, minBarLength}} = this;\n const actualBase = baseValue || 0;\n const parsed = this.getParsed(index);\n const custom = parsed._custom;\n const floating = isFloatBar(custom);\n let value = parsed[vScale.axis];\n let start = 0;\n let length = _stacked ? this.applyStack(vScale, parsed, _stacked) : value;\n let head, size;\n\n if (length !== value) {\n start = length - value;\n length = value;\n }\n\n if (floating) {\n value = custom.barStart;\n length = custom.barEnd - custom.barStart;\n // bars crossing origin are not stacked\n if (value !== 0 && sign(value) !== sign(custom.barEnd)) {\n start = 0;\n }\n start += value;\n }\n\n const startValue = !isNullOrUndef(baseValue) && !floating ? baseValue : start;\n let base = vScale.getPixelForValue(startValue);\n\n if (this.chart.getDataVisibility(index)) {\n head = vScale.getPixelForValue(start + length);\n } else {\n // When not visible, no height\n head = base;\n }\n\n size = head - base;\n\n if (Math.abs(size) < minBarLength) {\n size = barSign(size, vScale, actualBase) * minBarLength;\n if (value === actualBase) {\n base -= size / 2;\n }\n const startPixel = vScale.getPixelForDecimal(0);\n const endPixel = vScale.getPixelForDecimal(1);\n const min = Math.min(startPixel, endPixel);\n const max = Math.max(startPixel, endPixel);\n base = Math.max(Math.min(base, max), min);\n head = base + size;\n\n if (_stacked && !floating) {\n // visual data coordinates after applying minBarLength\n parsed._stacks[vScale.axis]._visualValues[datasetIndex] = vScale.getValueForPixel(head) - vScale.getValueForPixel(base);\n }\n }\n\n if (base === vScale.getPixelForValue(actualBase)) {\n const halfGrid = sign(size) * vScale.getLineWidthForValue(actualBase) / 2;\n base += halfGrid;\n size -= halfGrid;\n }\n\n return {\n size,\n base,\n head,\n center: head + size / 2\n };\n }\n\n /**\n\t * @private\n\t */\n _calculateBarIndexPixels(index, ruler) {\n const scale = ruler.scale;\n const options = this.options;\n const skipNull = options.skipNull;\n const maxBarThickness = valueOrDefault(options.maxBarThickness, Infinity);\n let center, size;\n const axisCount = this._getAxisCount();\n if (ruler.grouped) {\n const stackCount = skipNull ? this._getStackCount(index) : ruler.stackCount;\n const range = options.barThickness === 'flex'\n ? computeFlexCategoryTraits(index, ruler, options, stackCount * axisCount)\n : computeFitCategoryTraits(index, ruler, options, stackCount * axisCount);\n const axisID = this.chart.options.indexAxis === 'x' ? this.getDataset().xAxisID : this.getDataset().yAxisID;\n const axisNumber = this._getAxis().indexOf(valueOrDefault(axisID, this.getFirstScaleIdForIndexAxis()));\n const stackIndex = this._getStackIndex(this.index, this._cachedMeta.stack, skipNull ? index : undefined) + axisNumber;\n center = range.start + (range.chunk * stackIndex) + (range.chunk / 2);\n size = Math.min(maxBarThickness, range.chunk * range.ratio);\n } else {\n // For non-grouped bar charts, exact pixel values are used\n center = scale.getPixelForValue(this.getParsed(index)[scale.axis], index);\n size = Math.min(maxBarThickness, ruler.min * ruler.ratio);\n }\n\n\n return {\n base: center - size / 2,\n head: center + size / 2,\n center,\n size\n };\n }\n\n draw() {\n const meta = this._cachedMeta;\n const vScale = meta.vScale;\n const rects = meta.data;\n const ilen = rects.length;\n let i = 0;\n\n for (; i < ilen; ++i) {\n if (this.getParsed(i)[vScale.axis] !== null && !rects[i].hidden) {\n rects[i].draw(this._ctx);\n }\n }\n }\n\n}\n","import DatasetController from '../core/core.datasetController.js';\nimport {valueOrDefault} from '../helpers/helpers.core.js';\n\nexport default class BubbleController extends DatasetController {\n\n static id = 'bubble';\n\n /**\n * @type {any}\n */\n static defaults = {\n datasetElementType: false,\n dataElementType: 'point',\n\n animations: {\n numbers: {\n type: 'number',\n properties: ['x', 'y', 'borderWidth', 'radius']\n }\n }\n };\n\n /**\n * @type {any}\n */\n static overrides = {\n scales: {\n x: {\n type: 'linear'\n },\n y: {\n type: 'linear'\n }\n }\n };\n\n initialize() {\n this.enableOptionSharing = true;\n super.initialize();\n }\n\n /**\n\t * Parse array of primitive values\n\t * @protected\n\t */\n parsePrimitiveData(meta, data, start, count) {\n const parsed = super.parsePrimitiveData(meta, data, start, count);\n for (let i = 0; i < parsed.length; i++) {\n parsed[i]._custom = this.resolveDataElementOptions(i + start).radius;\n }\n return parsed;\n }\n\n /**\n\t * Parse array of arrays\n\t * @protected\n\t */\n parseArrayData(meta, data, start, count) {\n const parsed = super.parseArrayData(meta, data, start, count);\n for (let i = 0; i < parsed.length; i++) {\n const item = data[start + i];\n parsed[i]._custom = valueOrDefault(item[2], this.resolveDataElementOptions(i + start).radius);\n }\n return parsed;\n }\n\n /**\n\t * Parse array of objects\n\t * @protected\n\t */\n parseObjectData(meta, data, start, count) {\n const parsed = super.parseObjectData(meta, data, start, count);\n for (let i = 0; i < parsed.length; i++) {\n const item = data[start + i];\n parsed[i]._custom = valueOrDefault(item && item.r && +item.r, this.resolveDataElementOptions(i + start).radius);\n }\n return parsed;\n }\n\n /**\n\t * @protected\n\t */\n getMaxOverflow() {\n const data = this._cachedMeta.data;\n\n let max = 0;\n for (let i = data.length - 1; i >= 0; --i) {\n max = Math.max(max, data[i].size(this.resolveDataElementOptions(i)) / 2);\n }\n return max > 0 && max;\n }\n\n /**\n\t * @protected\n\t */\n getLabelAndValue(index) {\n const meta = this._cachedMeta;\n const labels = this.chart.data.labels || [];\n const {xScale, yScale} = meta;\n const parsed = this.getParsed(index);\n const x = xScale.getLabelForValue(parsed.x);\n const y = yScale.getLabelForValue(parsed.y);\n const r = parsed._custom;\n\n return {\n label: labels[index] || '',\n value: '(' + x + ', ' + y + (r ? ', ' + r : '') + ')'\n };\n }\n\n update(mode) {\n const points = this._cachedMeta.data;\n\n // Update Points\n this.updateElements(points, 0, points.length, mode);\n }\n\n updateElements(points, start, count, mode) {\n const reset = mode === 'reset';\n const {iScale, vScale} = this._cachedMeta;\n const {sharedOptions, includeOptions} = this._getSharedOptions(start, mode);\n const iAxis = iScale.axis;\n const vAxis = vScale.axis;\n\n for (let i = start; i < start + count; i++) {\n const point = points[i];\n const parsed = !reset && this.getParsed(i);\n const properties = {};\n const iPixel = properties[iAxis] = reset ? iScale.getPixelForDecimal(0.5) : iScale.getPixelForValue(parsed[iAxis]);\n const vPixel = properties[vAxis] = reset ? vScale.getBasePixel() : vScale.getPixelForValue(parsed[vAxis]);\n\n properties.skip = isNaN(iPixel) || isNaN(vPixel);\n\n if (includeOptions) {\n properties.options = sharedOptions || this.resolveDataElementOptions(i, point.active ? 'active' : mode);\n\n if (reset) {\n properties.options.radius = 0;\n }\n }\n\n this.updateElement(point, i, properties, mode);\n }\n }\n\n /**\n\t * @param {number} index\n\t * @param {string} [mode]\n\t * @protected\n\t */\n resolveDataElementOptions(index, mode) {\n const parsed = this.getParsed(index);\n let values = super.resolveDataElementOptions(index, mode);\n\n // In case values were cached (and thus frozen), we need to clone the values\n if (values.$shared) {\n values = Object.assign({}, values, {$shared: false});\n }\n\n // Custom radius resolution\n const radius = values.radius;\n if (mode !== 'active') {\n values.radius = 0;\n }\n values.radius += valueOrDefault(parsed && parsed._custom, radius);\n\n return values;\n }\n}\n","import DatasetController from '../core/core.datasetController.js';\nimport {isObject, resolveObjectKey, toPercentage, toDimension, valueOrDefault} from '../helpers/helpers.core.js';\nimport {formatNumber} from '../helpers/helpers.intl.js';\nimport {toRadians, PI, TAU, HALF_PI, _angleBetween} from '../helpers/helpers.math.js';\n\n/**\n * @typedef { import('../core/core.controller.js').default } Chart\n */\n\nfunction getRatioAndOffset(rotation, circumference, cutout) {\n let ratioX = 1;\n let ratioY = 1;\n let offsetX = 0;\n let offsetY = 0;\n // If the chart's circumference isn't a full circle, calculate size as a ratio of the width/height of the arc\n if (circumference < TAU) {\n const startAngle = rotation;\n const endAngle = startAngle + circumference;\n const startX = Math.cos(startAngle);\n const startY = Math.sin(startAngle);\n const endX = Math.cos(endAngle);\n const endY = Math.sin(endAngle);\n const calcMax = (angle, a, b) => _angleBetween(angle, startAngle, endAngle, true) ? 1 : Math.max(a, a * cutout, b, b * cutout);\n const calcMin = (angle, a, b) => _angleBetween(angle, startAngle, endAngle, true) ? -1 : Math.min(a, a * cutout, b, b * cutout);\n const maxX = calcMax(0, startX, endX);\n const maxY = calcMax(HALF_PI, startY, endY);\n const minX = calcMin(PI, startX, endX);\n const minY = calcMin(PI + HALF_PI, startY, endY);\n ratioX = (maxX - minX) / 2;\n ratioY = (maxY - minY) / 2;\n offsetX = -(maxX + minX) / 2;\n offsetY = -(maxY + minY) / 2;\n }\n return {ratioX, ratioY, offsetX, offsetY};\n}\n\nexport default class DoughnutController extends DatasetController {\n\n static id = 'doughnut';\n\n /**\n * @type {any}\n */\n static defaults = {\n datasetElementType: false,\n dataElementType: 'arc',\n animation: {\n // Boolean - Whether we animate the rotation of the Doughnut\n animateRotate: true,\n // Boolean - Whether we animate scaling the Doughnut from the centre\n animateScale: false\n },\n animations: {\n numbers: {\n type: 'number',\n properties: ['circumference', 'endAngle', 'innerRadius', 'outerRadius', 'startAngle', 'x', 'y', 'offset', 'borderWidth', 'spacing']\n },\n },\n // The percentage of the chart that we cut out of the middle.\n cutout: '50%',\n\n // The rotation of the chart, where the first data arc begins.\n rotation: 0,\n\n // The total circumference of the chart.\n circumference: 360,\n\n // The outer radius of the chart\n radius: '100%',\n\n // Spacing between arcs\n spacing: 0,\n\n indexAxis: 'r',\n };\n\n static descriptors = {\n _scriptable: (name) => name !== 'spacing',\n _indexable: (name) => name !== 'spacing' && !name.startsWith('borderDash') && !name.startsWith('hoverBorderDash'),\n };\n\n /**\n * @type {any}\n */\n static overrides = {\n aspectRatio: 1,\n\n // Need to override these to give a nice default\n plugins: {\n legend: {\n labels: {\n generateLabels(chart) {\n const data = chart.data;\n const {labels: {pointStyle, textAlign, color, useBorderRadius, borderRadius}} = chart.legend.options;\n if (data.labels.length && data.datasets.length) {\n return data.labels.map((label, i) => {\n const meta = chart.getDatasetMeta(0);\n const style = meta.controller.getStyle(i);\n\n return {\n text: label,\n fillStyle: style.backgroundColor,\n fontColor: color,\n hidden: !chart.getDataVisibility(i),\n lineDash: style.borderDash,\n lineDashOffset: style.borderDashOffset,\n lineJoin: style.borderJoinStyle,\n lineWidth: style.borderWidth,\n strokeStyle: style.borderColor,\n textAlign: textAlign,\n pointStyle: pointStyle,\n borderRadius: useBorderRadius && (borderRadius || style.borderRadius),\n // Extra data used for toggling the correct item\n index: i\n };\n });\n }\n return [];\n }\n },\n\n onClick(e, legendItem, legend) {\n legend.chart.toggleDataVisibility(legendItem.index);\n legend.chart.update();\n }\n }\n }\n };\n\n constructor(chart, datasetIndex) {\n super(chart, datasetIndex);\n\n this.enableOptionSharing = true;\n this.innerRadius = undefined;\n this.outerRadius = undefined;\n this.offsetX = undefined;\n this.offsetY = undefined;\n }\n\n linkScales() {}\n\n /**\n\t * Override data parsing, since we are not using scales\n\t */\n parse(start, count) {\n const data = this.getDataset().data;\n const meta = this._cachedMeta;\n\n if (this._parsing === false) {\n meta._parsed = data;\n } else {\n let getter = (i) => +data[i];\n\n if (isObject(data[start])) {\n const {key = 'value'} = this._parsing;\n getter = (i) => +resolveObjectKey(data[i], key);\n }\n\n let i, ilen;\n for (i = start, ilen = start + count; i < ilen; ++i) {\n meta._parsed[i] = getter(i);\n }\n }\n }\n\n /**\n\t * @private\n\t */\n _getRotation() {\n return toRadians(this.options.rotation - 90);\n }\n\n /**\n\t * @private\n\t */\n _getCircumference() {\n return toRadians(this.options.circumference);\n }\n\n /**\n\t * Get the maximal rotation & circumference extents\n\t * across all visible datasets.\n\t */\n _getRotationExtents() {\n let min = TAU;\n let max = -TAU;\n\n for (let i = 0; i < this.chart.data.datasets.length; ++i) {\n if (this.chart.isDatasetVisible(i) && this.chart.getDatasetMeta(i).type === this._type) {\n const controller = this.chart.getDatasetMeta(i).controller;\n const rotation = controller._getRotation();\n const circumference = controller._getCircumference();\n\n min = Math.min(min, rotation);\n max = Math.max(max, rotation + circumference);\n }\n }\n\n return {\n rotation: min,\n circumference: max - min,\n };\n }\n\n /**\n\t * @param {string} mode\n\t */\n update(mode) {\n const chart = this.chart;\n const {chartArea} = chart;\n const meta = this._cachedMeta;\n const arcs = meta.data;\n const spacing = this.getMaxBorderWidth() + this.getMaxOffset(arcs) + this.options.spacing;\n const maxSize = Math.max((Math.min(chartArea.width, chartArea.height) - spacing) / 2, 0);\n const cutout = Math.min(toPercentage(this.options.cutout, maxSize), 1);\n const chartWeight = this._getRingWeight(this.index);\n\n // Compute the maximal rotation & circumference limits.\n // If we only consider our dataset, this can cause problems when two datasets\n // are both less than a circle with different rotations (starting angles)\n const {circumference, rotation} = this._getRotationExtents();\n const {ratioX, ratioY, offsetX, offsetY} = getRatioAndOffset(rotation, circumference, cutout);\n const maxWidth = (chartArea.width - spacing) / ratioX;\n const maxHeight = (chartArea.height - spacing) / ratioY;\n const maxRadius = Math.max(Math.min(maxWidth, maxHeight) / 2, 0);\n const outerRadius = toDimension(this.options.radius, maxRadius);\n const innerRadius = Math.max(outerRadius * cutout, 0);\n const radiusLength = (outerRadius - innerRadius) / this._getVisibleDatasetWeightTotal();\n this.offsetX = offsetX * outerRadius;\n this.offsetY = offsetY * outerRadius;\n\n meta.total = this.calculateTotal();\n\n this.outerRadius = outerRadius - radiusLength * this._getRingWeightOffset(this.index);\n this.innerRadius = Math.max(this.outerRadius - radiusLength * chartWeight, 0);\n\n this.updateElements(arcs, 0, arcs.length, mode);\n }\n\n /**\n * @private\n */\n _circumference(i, reset) {\n const opts = this.options;\n const meta = this._cachedMeta;\n const circumference = this._getCircumference();\n if ((reset && opts.animation.animateRotate) || !this.chart.getDataVisibility(i) || meta._parsed[i] === null || meta.data[i].hidden) {\n return 0;\n }\n return this.calculateCircumference(meta._parsed[i] * circumference / TAU);\n }\n\n updateElements(arcs, start, count, mode) {\n const reset = mode === 'reset';\n const chart = this.chart;\n const chartArea = chart.chartArea;\n const opts = chart.options;\n const animationOpts = opts.animation;\n const centerX = (chartArea.left + chartArea.right) / 2;\n const centerY = (chartArea.top + chartArea.bottom) / 2;\n const animateScale = reset && animationOpts.animateScale;\n const innerRadius = animateScale ? 0 : this.innerRadius;\n const outerRadius = animateScale ? 0 : this.outerRadius;\n const {sharedOptions, includeOptions} = this._getSharedOptions(start, mode);\n let startAngle = this._getRotation();\n let i;\n\n for (i = 0; i < start; ++i) {\n startAngle += this._circumference(i, reset);\n }\n\n for (i = start; i < start + count; ++i) {\n const circumference = this._circumference(i, reset);\n const arc = arcs[i];\n const properties = {\n x: centerX + this.offsetX,\n y: centerY + this.offsetY,\n startAngle,\n endAngle: startAngle + circumference,\n circumference,\n outerRadius,\n innerRadius\n };\n if (includeOptions) {\n properties.options = sharedOptions || this.resolveDataElementOptions(i, arc.active ? 'active' : mode);\n }\n startAngle += circumference;\n\n this.updateElement(arc, i, properties, mode);\n }\n }\n\n calculateTotal() {\n const meta = this._cachedMeta;\n const metaData = meta.data;\n let total = 0;\n let i;\n\n for (i = 0; i < metaData.length; i++) {\n const value = meta._parsed[i];\n if (value !== null && !isNaN(value) && this.chart.getDataVisibility(i) && !metaData[i].hidden) {\n total += Math.abs(value);\n }\n }\n\n return total;\n }\n\n calculateCircumference(value) {\n const total = this._cachedMeta.total;\n if (total > 0 && !isNaN(value)) {\n return TAU * (Math.abs(value) / total);\n }\n return 0;\n }\n\n getLabelAndValue(index) {\n const meta = this._cachedMeta;\n const chart = this.chart;\n const labels = chart.data.labels || [];\n const value = formatNumber(meta._parsed[index], chart.options.locale);\n\n return {\n label: labels[index] || '',\n value,\n };\n }\n\n getMaxBorderWidth(arcs) {\n let max = 0;\n const chart = this.chart;\n let i, ilen, meta, controller, options;\n\n if (!arcs) {\n // Find the outmost visible dataset\n for (i = 0, ilen = chart.data.datasets.length; i < ilen; ++i) {\n if (chart.isDatasetVisible(i)) {\n meta = chart.getDatasetMeta(i);\n arcs = meta.data;\n controller = meta.controller;\n break;\n }\n }\n }\n\n if (!arcs) {\n return 0;\n }\n\n for (i = 0, ilen = arcs.length; i < ilen; ++i) {\n options = controller.resolveDataElementOptions(i);\n if (options.borderAlign !== 'inner') {\n max = Math.max(max, options.borderWidth || 0, options.hoverBorderWidth || 0);\n }\n }\n return max;\n }\n\n getMaxOffset(arcs) {\n let max = 0;\n\n for (let i = 0, ilen = arcs.length; i < ilen; ++i) {\n const options = this.resolveDataElementOptions(i);\n max = Math.max(max, options.offset || 0, options.hoverOffset || 0);\n }\n return max;\n }\n\n /**\n\t * Get radius length offset of the dataset in relation to the visible datasets weights. This allows determining the inner and outer radius correctly\n\t * @private\n\t */\n _getRingWeightOffset(datasetIndex) {\n let ringWeightOffset = 0;\n\n for (let i = 0; i < datasetIndex; ++i) {\n if (this.chart.isDatasetVisible(i)) {\n ringWeightOffset += this._getRingWeight(i);\n }\n }\n\n return ringWeightOffset;\n }\n\n /**\n\t * @private\n\t */\n _getRingWeight(datasetIndex) {\n return Math.max(valueOrDefault(this.chart.data.datasets[datasetIndex].weight, 1), 0);\n }\n\n /**\n\t * Returns the sum of all visible data set weights.\n\t * @private\n\t */\n _getVisibleDatasetWeightTotal() {\n return this._getRingWeightOffset(this.chart.data.datasets.length) || 1;\n }\n}\n","import DatasetController from '../core/core.datasetController.js';\nimport {isNullOrUndef} from '../helpers/index.js';\nimport {isNumber} from '../helpers/helpers.math.js';\nimport {_getStartAndCountOfVisiblePoints, _scaleRangesChanged} from '../helpers/helpers.extras.js';\n\nexport default class LineController extends DatasetController {\n\n static id = 'line';\n\n /**\n * @type {any}\n */\n static defaults = {\n datasetElementType: 'line',\n dataElementType: 'point',\n\n showLine: true,\n spanGaps: false,\n };\n\n /**\n * @type {any}\n */\n static overrides = {\n scales: {\n _index_: {\n type: 'category',\n },\n _value_: {\n type: 'linear',\n },\n }\n };\n\n initialize() {\n this.enableOptionSharing = true;\n this.supportsDecimation = true;\n super.initialize();\n }\n\n update(mode) {\n const meta = this._cachedMeta;\n const {dataset: line, data: points = [], _dataset} = meta;\n // @ts-ignore\n const animationsDisabled = this.chart._animationsDisabled;\n let {start, count} = _getStartAndCountOfVisiblePoints(meta, points, animationsDisabled);\n\n this._drawStart = start;\n this._drawCount = count;\n\n if (_scaleRangesChanged(meta)) {\n start = 0;\n count = points.length;\n }\n\n // Update Line\n line._chart = this.chart;\n line._datasetIndex = this.index;\n line._decimated = !!_dataset._decimated;\n line.points = points;\n\n const options = this.resolveDatasetElementOptions(mode);\n if (!this.options.showLine) {\n options.borderWidth = 0;\n }\n options.segment = this.options.segment;\n this.updateElement(line, undefined, {\n animated: !animationsDisabled,\n options\n }, mode);\n\n // Update Points\n this.updateElements(points, start, count, mode);\n }\n\n updateElements(points, start, count, mode) {\n const reset = mode === 'reset';\n const {iScale, vScale, _stacked, _dataset} = this._cachedMeta;\n const {sharedOptions, includeOptions} = this._getSharedOptions(start, mode);\n const iAxis = iScale.axis;\n const vAxis = vScale.axis;\n const {spanGaps, segment} = this.options;\n const maxGapLength = isNumber(spanGaps) ? spanGaps : Number.POSITIVE_INFINITY;\n const directUpdate = this.chart._animationsDisabled || reset || mode === 'none';\n const end = start + count;\n const pointsCount = points.length;\n let prevParsed = start > 0 && this.getParsed(start - 1);\n\n for (let i = 0; i < pointsCount; ++i) {\n const point = points[i];\n const properties = directUpdate ? point : {};\n\n if (i < start || i >= end) {\n properties.skip = true;\n continue;\n }\n\n const parsed = this.getParsed(i);\n const nullData = isNullOrUndef(parsed[vAxis]);\n const iPixel = properties[iAxis] = iScale.getPixelForValue(parsed[iAxis], i);\n const vPixel = properties[vAxis] = reset || nullData ? vScale.getBasePixel() : vScale.getPixelForValue(_stacked ? this.applyStack(vScale, parsed, _stacked) : parsed[vAxis], i);\n\n properties.skip = isNaN(iPixel) || isNaN(vPixel) || nullData;\n properties.stop = i > 0 && (Math.abs(parsed[iAxis] - prevParsed[iAxis])) > maxGapLength;\n if (segment) {\n properties.parsed = parsed;\n properties.raw = _dataset.data[i];\n }\n\n if (includeOptions) {\n properties.options = sharedOptions || this.resolveDataElementOptions(i, point.active ? 'active' : mode);\n }\n\n if (!directUpdate) {\n this.updateElement(point, i, properties, mode);\n }\n\n prevParsed = parsed;\n }\n }\n\n /**\n\t * @protected\n\t */\n getMaxOverflow() {\n const meta = this._cachedMeta;\n const dataset = meta.dataset;\n const border = dataset.options && dataset.options.borderWidth || 0;\n const data = meta.data || [];\n if (!data.length) {\n return border;\n }\n const firstPoint = data[0].size(this.resolveDataElementOptions(0));\n const lastPoint = data[data.length - 1].size(this.resolveDataElementOptions(data.length - 1));\n return Math.max(border, firstPoint, lastPoint) / 2;\n }\n\n draw() {\n const meta = this._cachedMeta;\n meta.dataset.updateControlPoints(this.chart.chartArea, meta.iScale.axis);\n super.draw();\n }\n}\n","import DatasetController from '../core/core.datasetController.js';\nimport {toRadians, PI, formatNumber, _parseObjectDataRadialScale} from '../helpers/index.js';\n\nexport default class PolarAreaController extends DatasetController {\n\n static id = 'polarArea';\n\n /**\n * @type {any}\n */\n static defaults = {\n dataElementType: 'arc',\n animation: {\n animateRotate: true,\n animateScale: true\n },\n animations: {\n numbers: {\n type: 'number',\n properties: ['x', 'y', 'startAngle', 'endAngle', 'innerRadius', 'outerRadius']\n },\n },\n indexAxis: 'r',\n startAngle: 0,\n };\n\n /**\n * @type {any}\n */\n static overrides = {\n aspectRatio: 1,\n\n plugins: {\n legend: {\n labels: {\n generateLabels(chart) {\n const data = chart.data;\n if (data.labels.length && data.datasets.length) {\n const {labels: {pointStyle, color}} = chart.legend.options;\n\n return data.labels.map((label, i) => {\n const meta = chart.getDatasetMeta(0);\n const style = meta.controller.getStyle(i);\n\n return {\n text: label,\n fillStyle: style.backgroundColor,\n strokeStyle: style.borderColor,\n fontColor: color,\n lineWidth: style.borderWidth,\n pointStyle: pointStyle,\n hidden: !chart.getDataVisibility(i),\n\n // Extra data used for toggling the correct item\n index: i\n };\n });\n }\n return [];\n }\n },\n\n onClick(e, legendItem, legend) {\n legend.chart.toggleDataVisibility(legendItem.index);\n legend.chart.update();\n }\n }\n },\n\n scales: {\n r: {\n type: 'radialLinear',\n angleLines: {\n display: false\n },\n beginAtZero: true,\n grid: {\n circular: true\n },\n pointLabels: {\n display: false\n },\n startAngle: 0\n }\n }\n };\n\n constructor(chart, datasetIndex) {\n super(chart, datasetIndex);\n\n this.innerRadius = undefined;\n this.outerRadius = undefined;\n }\n\n getLabelAndValue(index) {\n const meta = this._cachedMeta;\n const chart = this.chart;\n const labels = chart.data.labels || [];\n const value = formatNumber(meta._parsed[index].r, chart.options.locale);\n\n return {\n label: labels[index] || '',\n value,\n };\n }\n\n parseObjectData(meta, data, start, count) {\n return _parseObjectDataRadialScale.bind(this)(meta, data, start, count);\n }\n\n update(mode) {\n const arcs = this._cachedMeta.data;\n\n this._updateRadius();\n this.updateElements(arcs, 0, arcs.length, mode);\n }\n\n /**\n * @protected\n */\n getMinMax() {\n const meta = this._cachedMeta;\n const range = {min: Number.POSITIVE_INFINITY, max: Number.NEGATIVE_INFINITY};\n\n meta.data.forEach((element, index) => {\n const parsed = this.getParsed(index).r;\n\n if (!isNaN(parsed) && this.chart.getDataVisibility(index)) {\n if (parsed < range.min) {\n range.min = parsed;\n }\n\n if (parsed > range.max) {\n range.max = parsed;\n }\n }\n });\n\n return range;\n }\n\n /**\n\t * @private\n\t */\n _updateRadius() {\n const chart = this.chart;\n const chartArea = chart.chartArea;\n const opts = chart.options;\n const minSize = Math.min(chartArea.right - chartArea.left, chartArea.bottom - chartArea.top);\n\n const outerRadius = Math.max(minSize / 2, 0);\n const innerRadius = Math.max(opts.cutoutPercentage ? (outerRadius / 100) * (opts.cutoutPercentage) : 1, 0);\n const radiusLength = (outerRadius - innerRadius) / chart.getVisibleDatasetCount();\n\n this.outerRadius = outerRadius - (radiusLength * this.index);\n this.innerRadius = this.outerRadius - radiusLength;\n }\n\n updateElements(arcs, start, count, mode) {\n const reset = mode === 'reset';\n const chart = this.chart;\n const opts = chart.options;\n const animationOpts = opts.animation;\n const scale = this._cachedMeta.rScale;\n const centerX = scale.xCenter;\n const centerY = scale.yCenter;\n const datasetStartAngle = scale.getIndexAngle(0) - 0.5 * PI;\n let angle = datasetStartAngle;\n let i;\n\n const defaultAngle = 360 / this.countVisibleElements();\n\n for (i = 0; i < start; ++i) {\n angle += this._computeAngle(i, mode, defaultAngle);\n }\n for (i = start; i < start + count; i++) {\n const arc = arcs[i];\n let startAngle = angle;\n let endAngle = angle + this._computeAngle(i, mode, defaultAngle);\n let outerRadius = chart.getDataVisibility(i) ? scale.getDistanceFromCenterForValue(this.getParsed(i).r) : 0;\n angle = endAngle;\n\n if (reset) {\n if (animationOpts.animateScale) {\n outerRadius = 0;\n }\n if (animationOpts.animateRotate) {\n startAngle = endAngle = datasetStartAngle;\n }\n }\n\n const properties = {\n x: centerX,\n y: centerY,\n innerRadius: 0,\n outerRadius,\n startAngle,\n endAngle,\n options: this.resolveDataElementOptions(i, arc.active ? 'active' : mode)\n };\n\n this.updateElement(arc, i, properties, mode);\n }\n }\n\n countVisibleElements() {\n const meta = this._cachedMeta;\n let count = 0;\n\n meta.data.forEach((element, index) => {\n if (!isNaN(this.getParsed(index).r) && this.chart.getDataVisibility(index)) {\n count++;\n }\n });\n\n return count;\n }\n\n /**\n\t * @private\n\t */\n _computeAngle(index, mode, defaultAngle) {\n return this.chart.getDataVisibility(index)\n ? toRadians(this.resolveDataElementOptions(index, mode).angle || defaultAngle)\n : 0;\n }\n}\n","import DoughnutController from './controller.doughnut.js';\n\n// Pie charts are Doughnut chart with different defaults\nexport default class PieController extends DoughnutController {\n\n static id = 'pie';\n\n /**\n * @type {any}\n */\n static defaults = {\n // The percentage of the chart that we cut out of the middle.\n cutout: 0,\n\n // The rotation of the chart, where the first data arc begins.\n rotation: 0,\n\n // The total circumference of the chart.\n circumference: 360,\n\n // The outer radius of the chart\n radius: '100%'\n };\n}\n","import DatasetController from '../core/core.datasetController.js';\nimport {_parseObjectDataRadialScale} from '../helpers/index.js';\n\nexport default class RadarController extends DatasetController {\n\n static id = 'radar';\n\n /**\n * @type {any}\n */\n static defaults = {\n datasetElementType: 'line',\n dataElementType: 'point',\n indexAxis: 'r',\n showLine: true,\n elements: {\n line: {\n fill: 'start'\n }\n },\n };\n\n /**\n * @type {any}\n */\n static overrides = {\n aspectRatio: 1,\n\n scales: {\n r: {\n type: 'radialLinear',\n }\n }\n };\n\n /**\n\t * @protected\n\t */\n getLabelAndValue(index) {\n const vScale = this._cachedMeta.vScale;\n const parsed = this.getParsed(index);\n\n return {\n label: vScale.getLabels()[index],\n value: '' + vScale.getLabelForValue(parsed[vScale.axis])\n };\n }\n\n parseObjectData(meta, data, start, count) {\n return _parseObjectDataRadialScale.bind(this)(meta, data, start, count);\n }\n\n update(mode) {\n const meta = this._cachedMeta;\n const line = meta.dataset;\n const points = meta.data || [];\n const labels = meta.iScale.getLabels();\n\n // Update Line\n line.points = points;\n // In resize mode only point locations change, so no need to set the points or options.\n if (mode !== 'resize') {\n const options = this.resolveDatasetElementOptions(mode);\n if (!this.options.showLine) {\n options.borderWidth = 0;\n }\n\n const properties = {\n _loop: true,\n _fullLoop: labels.length === points.length,\n options\n };\n\n this.updateElement(line, undefined, properties, mode);\n }\n\n // Update Points\n this.updateElements(points, 0, points.length, mode);\n }\n\n updateElements(points, start, count, mode) {\n const scale = this._cachedMeta.rScale;\n const reset = mode === 'reset';\n\n for (let i = start; i < start + count; i++) {\n const point = points[i];\n const options = this.resolveDataElementOptions(i, point.active ? 'active' : mode);\n const pointPosition = scale.getPointPositionForValue(i, this.getParsed(i).r);\n\n const x = reset ? scale.xCenter : pointPosition.x;\n const y = reset ? scale.yCenter : pointPosition.y;\n\n const properties = {\n x,\n y,\n angle: pointPosition.angle,\n skip: isNaN(x) || isNaN(y),\n options\n };\n\n this.updateElement(point, i, properties, mode);\n }\n }\n}\n","import DatasetController from '../core/core.datasetController.js';\nimport {isNullOrUndef} from '../helpers/index.js';\nimport {isNumber} from '../helpers/helpers.math.js';\nimport {_getStartAndCountOfVisiblePoints, _scaleRangesChanged} from '../helpers/helpers.extras.js';\n\nexport default class ScatterController extends DatasetController {\n\n static id = 'scatter';\n\n /**\n * @type {any}\n */\n static defaults = {\n datasetElementType: false,\n dataElementType: 'point',\n showLine: false,\n fill: false\n };\n\n /**\n * @type {any}\n */\n static overrides = {\n\n interaction: {\n mode: 'point'\n },\n\n scales: {\n x: {\n type: 'linear'\n },\n y: {\n type: 'linear'\n }\n }\n };\n\n /**\n\t * @protected\n\t */\n getLabelAndValue(index) {\n const meta = this._cachedMeta;\n const labels = this.chart.data.labels || [];\n const {xScale, yScale} = meta;\n const parsed = this.getParsed(index);\n const x = xScale.getLabelForValue(parsed.x);\n const y = yScale.getLabelForValue(parsed.y);\n\n return {\n label: labels[index] || '',\n value: '(' + x + ', ' + y + ')'\n };\n }\n\n update(mode) {\n const meta = this._cachedMeta;\n const {data: points = []} = meta;\n // @ts-ignore\n const animationsDisabled = this.chart._animationsDisabled;\n let {start, count} = _getStartAndCountOfVisiblePoints(meta, points, animationsDisabled);\n\n this._drawStart = start;\n this._drawCount = count;\n\n if (_scaleRangesChanged(meta)) {\n start = 0;\n count = points.length;\n }\n\n if (this.options.showLine) {\n\n // https://github.com/chartjs/Chart.js/issues/11333\n if (!this.datasetElementType) {\n this.addElements();\n }\n const {dataset: line, _dataset} = meta;\n\n // Update Line\n line._chart = this.chart;\n line._datasetIndex = this.index;\n line._decimated = !!_dataset._decimated;\n line.points = points;\n\n const options = this.resolveDatasetElementOptions(mode);\n options.segment = this.options.segment;\n this.updateElement(line, undefined, {\n animated: !animationsDisabled,\n options\n }, mode);\n } else if (this.datasetElementType) {\n // https://github.com/chartjs/Chart.js/issues/11333\n delete meta.dataset;\n this.datasetElementType = false;\n }\n\n // Update Points\n this.updateElements(points, start, count, mode);\n }\n\n addElements() {\n const {showLine} = this.options;\n\n if (!this.datasetElementType && showLine) {\n this.datasetElementType = this.chart.registry.getElement('line');\n }\n\n super.addElements();\n }\n\n updateElements(points, start, count, mode) {\n const reset = mode === 'reset';\n const {iScale, vScale, _stacked, _dataset} = this._cachedMeta;\n const firstOpts = this.resolveDataElementOptions(start, mode);\n const sharedOptions = this.getSharedOptions(firstOpts);\n const includeOptions = this.includeOptions(mode, sharedOptions);\n const iAxis = iScale.axis;\n const vAxis = vScale.axis;\n const {spanGaps, segment} = this.options;\n const maxGapLength = isNumber(spanGaps) ? spanGaps : Number.POSITIVE_INFINITY;\n const directUpdate = this.chart._animationsDisabled || reset || mode === 'none';\n let prevParsed = start > 0 && this.getParsed(start - 1);\n\n for (let i = start; i < start + count; ++i) {\n const point = points[i];\n const parsed = this.getParsed(i);\n const properties = directUpdate ? point : {};\n const nullData = isNullOrUndef(parsed[vAxis]);\n const iPixel = properties[iAxis] = iScale.getPixelForValue(parsed[iAxis], i);\n const vPixel = properties[vAxis] = reset || nullData ? vScale.getBasePixel() : vScale.getPixelForValue(_stacked ? this.applyStack(vScale, parsed, _stacked) : parsed[vAxis], i);\n\n properties.skip = isNaN(iPixel) || isNaN(vPixel) || nullData;\n properties.stop = i > 0 && (Math.abs(parsed[iAxis] - prevParsed[iAxis])) > maxGapLength;\n if (segment) {\n properties.parsed = parsed;\n properties.raw = _dataset.data[i];\n }\n\n if (includeOptions) {\n properties.options = sharedOptions || this.resolveDataElementOptions(i, point.active ? 'active' : mode);\n }\n\n if (!directUpdate) {\n this.updateElement(point, i, properties, mode);\n }\n\n prevParsed = parsed;\n }\n\n this.updateSharedOptions(sharedOptions, mode, firstOpts);\n }\n\n /**\n\t * @protected\n\t */\n getMaxOverflow() {\n const meta = this._cachedMeta;\n const data = meta.data || [];\n\n if (!this.options.showLine) {\n let max = 0;\n for (let i = data.length - 1; i >= 0; --i) {\n max = Math.max(max, data[i].size(this.resolveDataElementOptions(i)) / 2);\n }\n return max > 0 && max;\n }\n\n const dataset = meta.dataset;\n const border = dataset.options && dataset.options.borderWidth || 0;\n\n if (!data.length) {\n return border;\n }\n\n const firstPoint = data[0].size(this.resolveDataElementOptions(0));\n const lastPoint = data[data.length - 1].size(this.resolveDataElementOptions(data.length - 1));\n return Math.max(border, firstPoint, lastPoint) / 2;\n }\n}\n","/**\n * @namespace Chart._adapters\n * @since 2.8.0\n * @private\n */\n\nimport type {AnyObject} from '../types/basic.js';\nimport type {ChartOptions} from '../types/index.js';\n\nexport type TimeUnit = 'millisecond' | 'second' | 'minute' | 'hour' | 'day' | 'week' | 'month' | 'quarter' | 'year';\n\nexport interface DateAdapter {\n readonly options: T;\n /**\n * Will called with chart options after adapter creation.\n */\n init(this: DateAdapter, chartOptions: ChartOptions): void;\n /**\n * Returns a map of time formats for the supported formatting units defined\n * in Unit as well as 'datetime' representing a detailed date/time string.\n */\n formats(this: DateAdapter): Record;\n /**\n * Parses the given `value` and return the associated timestamp.\n * @param value - the value to parse (usually comes from the data)\n * @param [format] - the expected data format\n */\n parse(this: DateAdapter, value: unknown, format?: string): number | null;\n /**\n * Returns the formatted date in the specified `format` for a given `timestamp`.\n * @param timestamp - the timestamp to format\n * @param format - the date/time token\n */\n format(this: DateAdapter, timestamp: number, format: string): string;\n /**\n * Adds the specified `amount` of `unit` to the given `timestamp`.\n * @param timestamp - the input timestamp\n * @param amount - the amount to add\n * @param unit - the unit as string\n */\n add(this: DateAdapter, timestamp: number, amount: number, unit: TimeUnit): number;\n /**\n * Returns the number of `unit` between the given timestamps.\n * @param a - the input timestamp (reference)\n * @param b - the timestamp to subtract\n * @param unit - the unit as string\n */\n diff(this: DateAdapter, a: number, b: number, unit: TimeUnit): number;\n /**\n * Returns start of `unit` for the given `timestamp`.\n * @param timestamp - the input timestamp\n * @param unit - the unit as string\n * @param [weekday] - the ISO day of the week with 1 being Monday\n * and 7 being Sunday (only needed if param *unit* is `isoWeek`).\n */\n startOf(this: DateAdapter, timestamp: number, unit: TimeUnit | 'isoWeek', weekday?: number | boolean): number;\n /**\n * Returns end of `unit` for the given `timestamp`.\n * @param timestamp - the input timestamp\n * @param unit - the unit as string\n */\n endOf(this: DateAdapter, timestamp: number, unit: TimeUnit): number;\n}\n\nfunction abstract(): T {\n throw new Error('This method is not implemented: Check that a complete date adapter is provided.');\n}\n\n/**\n * Date adapter (current used by the time scale)\n * @namespace Chart._adapters._date\n * @memberof Chart._adapters\n * @private\n */\nclass DateAdapterBase implements DateAdapter {\n\n /**\n * Override default date adapter methods.\n * Accepts type parameter to define options type.\n * @example\n * Chart._adapters._date.override<{myAdapterOption: string}>({\n * init() {\n * console.log(this.options.myAdapterOption);\n * }\n * })\n */\n static override(\n members: Partial, 'options'>>\n ) {\n Object.assign(DateAdapterBase.prototype, members);\n }\n\n readonly options: AnyObject;\n\n constructor(options?: AnyObject) {\n this.options = options || {};\n }\n\n // eslint-disable-next-line @typescript-eslint/no-empty-function\n init() {}\n\n formats(): Record {\n return abstract();\n }\n\n parse(): number | null {\n return abstract();\n }\n\n format(): string {\n return abstract();\n }\n\n add(): number {\n return abstract();\n }\n\n diff(): number {\n return abstract();\n }\n\n startOf(): number {\n return abstract();\n }\n\n endOf(): number {\n return abstract();\n }\n}\n\nexport default {\n _date: DateAdapterBase as {\n new (options?: AnyObject): DateAdapter;\n override(\n members: Partial, 'options'>>\n ): void;\n }\n};\n","import {_lookupByKey, _rlookupByKey} from '../helpers/helpers.collection.js';\nimport {getRelativePosition} from '../helpers/helpers.dom.js';\nimport {_angleBetween, getAngleFromPoint} from '../helpers/helpers.math.js';\nimport {_isPointInArea, isNullOrUndef} from '../helpers/index.js';\n\n/**\n * @typedef { import('./core.controller.js').default } Chart\n * @typedef { import('../types/index.js').ChartEvent } ChartEvent\n * @typedef {{axis?: string, intersect?: boolean, includeInvisible?: boolean}} InteractionOptions\n * @typedef {{datasetIndex: number, index: number, element: import('./core.element.js').default}} InteractionItem\n * @typedef { import('../types/index.js').Point } Point\n */\n\n/**\n * Helper function to do binary search when possible\n * @param {object} metaset - the dataset meta\n * @param {string} axis - the axis mode. x|y|xy|r\n * @param {number} value - the value to find\n * @param {boolean} [intersect] - should the element intersect\n * @returns {{lo:number, hi:number}} indices to search data array between\n */\nfunction binarySearch(metaset, axis, value, intersect) {\n const {controller, data, _sorted} = metaset;\n const iScale = controller._cachedMeta.iScale;\n const spanGaps = metaset.dataset ? metaset.dataset.options ? metaset.dataset.options.spanGaps : null : null;\n\n if (iScale && axis === iScale.axis && axis !== 'r' && _sorted && data.length) {\n const lookupMethod = iScale._reversePixels ? _rlookupByKey : _lookupByKey;\n if (!intersect) {\n const result = lookupMethod(data, axis, value);\n if (spanGaps) {\n const {vScale} = controller._cachedMeta;\n const {_parsed} = metaset;\n\n const distanceToDefinedLo = (_parsed\n .slice(0, result.lo + 1)\n .reverse()\n .findIndex(\n point => !isNullOrUndef(point[vScale.axis])));\n result.lo -= Math.max(0, distanceToDefinedLo);\n\n const distanceToDefinedHi = (_parsed\n .slice(result.hi)\n .findIndex(\n point => !isNullOrUndef(point[vScale.axis])));\n result.hi += Math.max(0, distanceToDefinedHi);\n }\n return result;\n } else if (controller._sharedOptions) {\n // _sharedOptions indicates that each element has equal options -> equal proportions\n // So we can do a ranged binary search based on the range of first element and\n // be confident to get the full range of indices that can intersect with the value.\n const el = data[0];\n const range = typeof el.getRange === 'function' && el.getRange(axis);\n if (range) {\n const start = lookupMethod(data, axis, value - range);\n const end = lookupMethod(data, axis, value + range);\n return {lo: start.lo, hi: end.hi};\n }\n }\n }\n // Default to all elements, when binary search can not be used.\n return {lo: 0, hi: data.length - 1};\n}\n\n/**\n * Helper function to select candidate elements for interaction\n * @param {Chart} chart - the chart\n * @param {string} axis - the axis mode. x|y|xy|r\n * @param {Point} position - the point to be nearest to, in relative coordinates\n * @param {function} handler - the callback to execute for each visible item\n * @param {boolean} [intersect] - consider intersecting items\n */\nfunction evaluateInteractionItems(chart, axis, position, handler, intersect) {\n const metasets = chart.getSortedVisibleDatasetMetas();\n const value = position[axis];\n for (let i = 0, ilen = metasets.length; i < ilen; ++i) {\n const {index, data} = metasets[i];\n const {lo, hi} = binarySearch(metasets[i], axis, value, intersect);\n for (let j = lo; j <= hi; ++j) {\n const element = data[j];\n if (!element.skip) {\n handler(element, index, j);\n }\n }\n }\n}\n\n/**\n * Get a distance metric function for two points based on the\n * axis mode setting\n * @param {string} axis - the axis mode. x|y|xy|r\n */\nfunction getDistanceMetricForAxis(axis) {\n const useX = axis.indexOf('x') !== -1;\n const useY = axis.indexOf('y') !== -1;\n\n return function(pt1, pt2) {\n const deltaX = useX ? Math.abs(pt1.x - pt2.x) : 0;\n const deltaY = useY ? Math.abs(pt1.y - pt2.y) : 0;\n return Math.sqrt(Math.pow(deltaX, 2) + Math.pow(deltaY, 2));\n };\n}\n\n/**\n * Helper function to get the items that intersect the event position\n * @param {Chart} chart - the chart\n * @param {Point} position - the point to be nearest to, in relative coordinates\n * @param {string} axis - the axis mode. x|y|xy|r\n * @param {boolean} [useFinalPosition] - use the element's animation target instead of current position\n * @param {boolean} [includeInvisible] - include invisible points that are outside of the chart area\n * @return {InteractionItem[]} the nearest items\n */\nfunction getIntersectItems(chart, position, axis, useFinalPosition, includeInvisible) {\n const items = [];\n\n if (!includeInvisible && !chart.isPointInArea(position)) {\n return items;\n }\n\n const evaluationFunc = function(element, datasetIndex, index) {\n if (!includeInvisible && !_isPointInArea(element, chart.chartArea, 0)) {\n return;\n }\n if (element.inRange(position.x, position.y, useFinalPosition)) {\n items.push({element, datasetIndex, index});\n }\n };\n\n evaluateInteractionItems(chart, axis, position, evaluationFunc, true);\n return items;\n}\n\n/**\n * Helper function to get the items nearest to the event position for a radial chart\n * @param {Chart} chart - the chart to look at elements from\n * @param {Point} position - the point to be nearest to, in relative coordinates\n * @param {string} axis - the axes along which to measure distance\n * @param {boolean} [useFinalPosition] - use the element's animation target instead of current position\n * @return {InteractionItem[]} the nearest items\n */\nfunction getNearestRadialItems(chart, position, axis, useFinalPosition) {\n let items = [];\n\n function evaluationFunc(element, datasetIndex, index) {\n const {startAngle, endAngle} = element.getProps(['startAngle', 'endAngle'], useFinalPosition);\n const {angle} = getAngleFromPoint(element, {x: position.x, y: position.y});\n\n if (_angleBetween(angle, startAngle, endAngle)) {\n items.push({element, datasetIndex, index});\n }\n }\n\n evaluateInteractionItems(chart, axis, position, evaluationFunc);\n return items;\n}\n\n/**\n * Helper function to get the items nearest to the event position for a cartesian chart\n * @param {Chart} chart - the chart to look at elements from\n * @param {Point} position - the point to be nearest to, in relative coordinates\n * @param {string} axis - the axes along which to measure distance\n * @param {boolean} [intersect] - if true, only consider items that intersect the position\n * @param {boolean} [useFinalPosition] - use the element's animation target instead of current position\n * @param {boolean} [includeInvisible] - include invisible points that are outside of the chart area\n * @return {InteractionItem[]} the nearest items\n */\nfunction getNearestCartesianItems(chart, position, axis, intersect, useFinalPosition, includeInvisible) {\n let items = [];\n const distanceMetric = getDistanceMetricForAxis(axis);\n let minDistance = Number.POSITIVE_INFINITY;\n\n function evaluationFunc(element, datasetIndex, index) {\n const inRange = element.inRange(position.x, position.y, useFinalPosition);\n if (intersect && !inRange) {\n return;\n }\n\n const center = element.getCenterPoint(useFinalPosition);\n const pointInArea = !!includeInvisible || chart.isPointInArea(center);\n if (!pointInArea && !inRange) {\n return;\n }\n\n const distance = distanceMetric(position, center);\n if (distance < minDistance) {\n items = [{element, datasetIndex, index}];\n minDistance = distance;\n } else if (distance === minDistance) {\n // Can have multiple items at the same distance in which case we sort by size\n items.push({element, datasetIndex, index});\n }\n }\n\n evaluateInteractionItems(chart, axis, position, evaluationFunc);\n return items;\n}\n\n/**\n * Helper function to get the items nearest to the event position considering all visible items in the chart\n * @param {Chart} chart - the chart to look at elements from\n * @param {Point} position - the point to be nearest to, in relative coordinates\n * @param {string} axis - the axes along which to measure distance\n * @param {boolean} [intersect] - if true, only consider items that intersect the position\n * @param {boolean} [useFinalPosition] - use the element's animation target instead of current position\n * @param {boolean} [includeInvisible] - include invisible points that are outside of the chart area\n * @return {InteractionItem[]} the nearest items\n */\nfunction getNearestItems(chart, position, axis, intersect, useFinalPosition, includeInvisible) {\n if (!includeInvisible && !chart.isPointInArea(position)) {\n return [];\n }\n\n return axis === 'r' && !intersect\n ? getNearestRadialItems(chart, position, axis, useFinalPosition)\n : getNearestCartesianItems(chart, position, axis, intersect, useFinalPosition, includeInvisible);\n}\n\n/**\n * Helper function to get the items matching along the given X or Y axis\n * @param {Chart} chart - the chart to look at elements from\n * @param {Point} position - the point to be nearest to, in relative coordinates\n * @param {string} axis - the axis to match\n * @param {boolean} [intersect] - if true, only consider items that intersect the position\n * @param {boolean} [useFinalPosition] - use the element's animation target instead of current position\n * @return {InteractionItem[]} the nearest items\n */\nfunction getAxisItems(chart, position, axis, intersect, useFinalPosition) {\n const items = [];\n const rangeMethod = axis === 'x' ? 'inXRange' : 'inYRange';\n let intersectsItem = false;\n\n evaluateInteractionItems(chart, axis, position, (element, datasetIndex, index) => {\n if (element[rangeMethod] && element[rangeMethod](position[axis], useFinalPosition)) {\n items.push({element, datasetIndex, index});\n intersectsItem = intersectsItem || element.inRange(position.x, position.y, useFinalPosition);\n }\n });\n\n // If we want to trigger on an intersect and we don't have any items\n // that intersect the position, return nothing\n if (intersect && !intersectsItem) {\n return [];\n }\n return items;\n}\n\n/**\n * Contains interaction related functions\n * @namespace Chart.Interaction\n */\nexport default {\n // Part of the public API to facilitate developers creating their own modes\n evaluateInteractionItems,\n\n // Helper function for different modes\n modes: {\n /**\n\t\t * Returns items at the same index. If the options.intersect parameter is true, we only return items if we intersect something\n\t\t * If the options.intersect mode is false, we find the nearest item and return the items at the same index as that item\n\t\t * @function Chart.Interaction.modes.index\n\t\t * @since v2.4.0\n\t\t * @param {Chart} chart - the chart we are returning items from\n\t\t * @param {Event} e - the event we are find things at\n\t\t * @param {InteractionOptions} options - options to use\n\t\t * @param {boolean} [useFinalPosition] - use final element position (animation target)\n\t\t * @return {InteractionItem[]} - items that are found\n\t\t */\n index(chart, e, options, useFinalPosition) {\n const position = getRelativePosition(e, chart);\n // Default axis for index mode is 'x' to match old behaviour\n const axis = options.axis || 'x';\n const includeInvisible = options.includeInvisible || false;\n const items = options.intersect\n ? getIntersectItems(chart, position, axis, useFinalPosition, includeInvisible)\n : getNearestItems(chart, position, axis, false, useFinalPosition, includeInvisible);\n const elements = [];\n\n if (!items.length) {\n return [];\n }\n\n chart.getSortedVisibleDatasetMetas().forEach((meta) => {\n const index = items[0].index;\n const element = meta.data[index];\n\n // don't count items that are skipped (null data)\n if (element && !element.skip) {\n elements.push({element, datasetIndex: meta.index, index});\n }\n });\n\n return elements;\n },\n\n /**\n\t\t * Returns items in the same dataset. If the options.intersect parameter is true, we only return items if we intersect something\n\t\t * If the options.intersect is false, we find the nearest item and return the items in that dataset\n\t\t * @function Chart.Interaction.modes.dataset\n\t\t * @param {Chart} chart - the chart we are returning items from\n\t\t * @param {Event} e - the event we are find things at\n\t\t * @param {InteractionOptions} options - options to use\n\t\t * @param {boolean} [useFinalPosition] - use final element position (animation target)\n\t\t * @return {InteractionItem[]} - items that are found\n\t\t */\n dataset(chart, e, options, useFinalPosition) {\n const position = getRelativePosition(e, chart);\n const axis = options.axis || 'xy';\n const includeInvisible = options.includeInvisible || false;\n let items = options.intersect\n ? getIntersectItems(chart, position, axis, useFinalPosition, includeInvisible) :\n getNearestItems(chart, position, axis, false, useFinalPosition, includeInvisible);\n\n if (items.length > 0) {\n const datasetIndex = items[0].datasetIndex;\n const data = chart.getDatasetMeta(datasetIndex).data;\n items = [];\n for (let i = 0; i < data.length; ++i) {\n items.push({element: data[i], datasetIndex, index: i});\n }\n }\n\n return items;\n },\n\n /**\n\t\t * Point mode returns all elements that hit test based on the event position\n\t\t * of the event\n\t\t * @function Chart.Interaction.modes.intersect\n\t\t * @param {Chart} chart - the chart we are returning items from\n\t\t * @param {Event} e - the event we are find things at\n\t\t * @param {InteractionOptions} options - options to use\n\t\t * @param {boolean} [useFinalPosition] - use final element position (animation target)\n\t\t * @return {InteractionItem[]} - items that are found\n\t\t */\n point(chart, e, options, useFinalPosition) {\n const position = getRelativePosition(e, chart);\n const axis = options.axis || 'xy';\n const includeInvisible = options.includeInvisible || false;\n return getIntersectItems(chart, position, axis, useFinalPosition, includeInvisible);\n },\n\n /**\n\t\t * nearest mode returns the element closest to the point\n\t\t * @function Chart.Interaction.modes.intersect\n\t\t * @param {Chart} chart - the chart we are returning items from\n\t\t * @param {Event} e - the event we are find things at\n\t\t * @param {InteractionOptions} options - options to use\n\t\t * @param {boolean} [useFinalPosition] - use final element position (animation target)\n\t\t * @return {InteractionItem[]} - items that are found\n\t\t */\n nearest(chart, e, options, useFinalPosition) {\n const position = getRelativePosition(e, chart);\n const axis = options.axis || 'xy';\n const includeInvisible = options.includeInvisible || false;\n return getNearestItems(chart, position, axis, options.intersect, useFinalPosition, includeInvisible);\n },\n\n /**\n\t\t * x mode returns the elements that hit-test at the current x coordinate\n\t\t * @function Chart.Interaction.modes.x\n\t\t * @param {Chart} chart - the chart we are returning items from\n\t\t * @param {Event} e - the event we are find things at\n\t\t * @param {InteractionOptions} options - options to use\n\t\t * @param {boolean} [useFinalPosition] - use final element position (animation target)\n\t\t * @return {InteractionItem[]} - items that are found\n\t\t */\n x(chart, e, options, useFinalPosition) {\n const position = getRelativePosition(e, chart);\n return getAxisItems(chart, position, 'x', options.intersect, useFinalPosition);\n },\n\n /**\n\t\t * y mode returns the elements that hit-test at the current y coordinate\n\t\t * @function Chart.Interaction.modes.y\n\t\t * @param {Chart} chart - the chart we are returning items from\n\t\t * @param {Event} e - the event we are find things at\n\t\t * @param {InteractionOptions} options - options to use\n\t\t * @param {boolean} [useFinalPosition] - use final element position (animation target)\n\t\t * @return {InteractionItem[]} - items that are found\n\t\t */\n y(chart, e, options, useFinalPosition) {\n const position = getRelativePosition(e, chart);\n return getAxisItems(chart, position, 'y', options.intersect, useFinalPosition);\n }\n }\n};\n","import {defined, each, isObject} from '../helpers/helpers.core.js';\nimport {toPadding} from '../helpers/helpers.options.js';\n\n/**\n * @typedef { import('./core.controller.js').default } Chart\n */\n\nconst STATIC_POSITIONS = ['left', 'top', 'right', 'bottom'];\n\nfunction filterByPosition(array, position) {\n return array.filter(v => v.pos === position);\n}\n\nfunction filterDynamicPositionByAxis(array, axis) {\n return array.filter(v => STATIC_POSITIONS.indexOf(v.pos) === -1 && v.box.axis === axis);\n}\n\nfunction sortByWeight(array, reverse) {\n return array.sort((a, b) => {\n const v0 = reverse ? b : a;\n const v1 = reverse ? a : b;\n return v0.weight === v1.weight ?\n v0.index - v1.index :\n v0.weight - v1.weight;\n });\n}\n\nfunction wrapBoxes(boxes) {\n const layoutBoxes = [];\n let i, ilen, box, pos, stack, stackWeight;\n\n for (i = 0, ilen = (boxes || []).length; i < ilen; ++i) {\n box = boxes[i];\n ({position: pos, options: {stack, stackWeight = 1}} = box);\n layoutBoxes.push({\n index: i,\n box,\n pos,\n horizontal: box.isHorizontal(),\n weight: box.weight,\n stack: stack && (pos + stack),\n stackWeight\n });\n }\n return layoutBoxes;\n}\n\nfunction buildStacks(layouts) {\n const stacks = {};\n for (const wrap of layouts) {\n const {stack, pos, stackWeight} = wrap;\n if (!stack || !STATIC_POSITIONS.includes(pos)) {\n continue;\n }\n const _stack = stacks[stack] || (stacks[stack] = {count: 0, placed: 0, weight: 0, size: 0});\n _stack.count++;\n _stack.weight += stackWeight;\n }\n return stacks;\n}\n\n/**\n * store dimensions used instead of available chartArea in fitBoxes\n **/\nfunction setLayoutDims(layouts, params) {\n const stacks = buildStacks(layouts);\n const {vBoxMaxWidth, hBoxMaxHeight} = params;\n let i, ilen, layout;\n for (i = 0, ilen = layouts.length; i < ilen; ++i) {\n layout = layouts[i];\n const {fullSize} = layout.box;\n const stack = stacks[layout.stack];\n const factor = stack && layout.stackWeight / stack.weight;\n if (layout.horizontal) {\n layout.width = factor ? factor * vBoxMaxWidth : fullSize && params.availableWidth;\n layout.height = hBoxMaxHeight;\n } else {\n layout.width = vBoxMaxWidth;\n layout.height = factor ? factor * hBoxMaxHeight : fullSize && params.availableHeight;\n }\n }\n return stacks;\n}\n\nfunction buildLayoutBoxes(boxes) {\n const layoutBoxes = wrapBoxes(boxes);\n const fullSize = sortByWeight(layoutBoxes.filter(wrap => wrap.box.fullSize), true);\n const left = sortByWeight(filterByPosition(layoutBoxes, 'left'), true);\n const right = sortByWeight(filterByPosition(layoutBoxes, 'right'));\n const top = sortByWeight(filterByPosition(layoutBoxes, 'top'), true);\n const bottom = sortByWeight(filterByPosition(layoutBoxes, 'bottom'));\n const centerHorizontal = filterDynamicPositionByAxis(layoutBoxes, 'x');\n const centerVertical = filterDynamicPositionByAxis(layoutBoxes, 'y');\n\n return {\n fullSize,\n leftAndTop: left.concat(top),\n rightAndBottom: right.concat(centerVertical).concat(bottom).concat(centerHorizontal),\n chartArea: filterByPosition(layoutBoxes, 'chartArea'),\n vertical: left.concat(right).concat(centerVertical),\n horizontal: top.concat(bottom).concat(centerHorizontal)\n };\n}\n\nfunction getCombinedMax(maxPadding, chartArea, a, b) {\n return Math.max(maxPadding[a], chartArea[a]) + Math.max(maxPadding[b], chartArea[b]);\n}\n\nfunction updateMaxPadding(maxPadding, boxPadding) {\n maxPadding.top = Math.max(maxPadding.top, boxPadding.top);\n maxPadding.left = Math.max(maxPadding.left, boxPadding.left);\n maxPadding.bottom = Math.max(maxPadding.bottom, boxPadding.bottom);\n maxPadding.right = Math.max(maxPadding.right, boxPadding.right);\n}\n\nfunction updateDims(chartArea, params, layout, stacks) {\n const {pos, box} = layout;\n const maxPadding = chartArea.maxPadding;\n\n // dynamically placed boxes size is not considered\n if (!isObject(pos)) {\n if (layout.size) {\n // this layout was already counted for, lets first reduce old size\n chartArea[pos] -= layout.size;\n }\n const stack = stacks[layout.stack] || {size: 0, count: 1};\n stack.size = Math.max(stack.size, layout.horizontal ? box.height : box.width);\n layout.size = stack.size / stack.count;\n chartArea[pos] += layout.size;\n }\n\n if (box.getPadding) {\n updateMaxPadding(maxPadding, box.getPadding());\n }\n\n const newWidth = Math.max(0, params.outerWidth - getCombinedMax(maxPadding, chartArea, 'left', 'right'));\n const newHeight = Math.max(0, params.outerHeight - getCombinedMax(maxPadding, chartArea, 'top', 'bottom'));\n const widthChanged = newWidth !== chartArea.w;\n const heightChanged = newHeight !== chartArea.h;\n chartArea.w = newWidth;\n chartArea.h = newHeight;\n\n // return booleans on the changes per direction\n return layout.horizontal\n ? {same: widthChanged, other: heightChanged}\n : {same: heightChanged, other: widthChanged};\n}\n\nfunction handleMaxPadding(chartArea) {\n const maxPadding = chartArea.maxPadding;\n\n function updatePos(pos) {\n const change = Math.max(maxPadding[pos] - chartArea[pos], 0);\n chartArea[pos] += change;\n return change;\n }\n chartArea.y += updatePos('top');\n chartArea.x += updatePos('left');\n updatePos('right');\n updatePos('bottom');\n}\n\nfunction getMargins(horizontal, chartArea) {\n const maxPadding = chartArea.maxPadding;\n\n function marginForPositions(positions) {\n const margin = {left: 0, top: 0, right: 0, bottom: 0};\n positions.forEach((pos) => {\n margin[pos] = Math.max(chartArea[pos], maxPadding[pos]);\n });\n return margin;\n }\n\n return horizontal\n ? marginForPositions(['left', 'right'])\n : marginForPositions(['top', 'bottom']);\n}\n\nfunction fitBoxes(boxes, chartArea, params, stacks) {\n const refitBoxes = [];\n let i, ilen, layout, box, refit, changed;\n\n for (i = 0, ilen = boxes.length, refit = 0; i < ilen; ++i) {\n layout = boxes[i];\n box = layout.box;\n\n box.update(\n layout.width || chartArea.w,\n layout.height || chartArea.h,\n getMargins(layout.horizontal, chartArea)\n );\n const {same, other} = updateDims(chartArea, params, layout, stacks);\n\n // Dimensions changed and there were non full width boxes before this\n // -> we have to refit those\n refit |= same && refitBoxes.length;\n\n // Chart area changed in the opposite direction\n changed = changed || other;\n\n if (!box.fullSize) { // fullSize boxes don't need to be re-fitted in any case\n refitBoxes.push(layout);\n }\n }\n\n return refit && fitBoxes(refitBoxes, chartArea, params, stacks) || changed;\n}\n\nfunction setBoxDims(box, left, top, width, height) {\n box.top = top;\n box.left = left;\n box.right = left + width;\n box.bottom = top + height;\n box.width = width;\n box.height = height;\n}\n\nfunction placeBoxes(boxes, chartArea, params, stacks) {\n const userPadding = params.padding;\n let {x, y} = chartArea;\n\n for (const layout of boxes) {\n const box = layout.box;\n const stack = stacks[layout.stack] || {count: 1, placed: 0, weight: 1};\n const weight = (layout.stackWeight / stack.weight) || 1;\n if (layout.horizontal) {\n const width = chartArea.w * weight;\n const height = stack.size || box.height;\n if (defined(stack.start)) {\n y = stack.start;\n }\n if (box.fullSize) {\n setBoxDims(box, userPadding.left, y, params.outerWidth - userPadding.right - userPadding.left, height);\n } else {\n setBoxDims(box, chartArea.left + stack.placed, y, width, height);\n }\n stack.start = y;\n stack.placed += width;\n y = box.bottom;\n } else {\n const height = chartArea.h * weight;\n const width = stack.size || box.width;\n if (defined(stack.start)) {\n x = stack.start;\n }\n if (box.fullSize) {\n setBoxDims(box, x, userPadding.top, width, params.outerHeight - userPadding.bottom - userPadding.top);\n } else {\n setBoxDims(box, x, chartArea.top + stack.placed, width, height);\n }\n stack.start = x;\n stack.placed += height;\n x = box.right;\n }\n }\n\n chartArea.x = x;\n chartArea.y = y;\n}\n\n/**\n * @interface LayoutItem\n * @typedef {object} LayoutItem\n * @prop {string} position - The position of the item in the chart layout. Possible values are\n * 'left', 'top', 'right', 'bottom', and 'chartArea'\n * @prop {number} weight - The weight used to sort the item. Higher weights are further away from the chart area\n * @prop {boolean} fullSize - if true, and the item is horizontal, then push vertical boxes down\n * @prop {function} isHorizontal - returns true if the layout item is horizontal (ie. top or bottom)\n * @prop {function} update - Takes two parameters: width and height. Returns size of item\n * @prop {function} draw - Draws the element\n * @prop {function} [getPadding] - Returns an object with padding on the edges\n * @prop {number} width - Width of item. Must be valid after update()\n * @prop {number} height - Height of item. Must be valid after update()\n * @prop {number} left - Left edge of the item. Set by layout system and cannot be used in update\n * @prop {number} top - Top edge of the item. Set by layout system and cannot be used in update\n * @prop {number} right - Right edge of the item. Set by layout system and cannot be used in update\n * @prop {number} bottom - Bottom edge of the item. Set by layout system and cannot be used in update\n */\n\n// The layout service is very self explanatory. It's responsible for the layout within a chart.\n// Scales, Legends and Plugins all rely on the layout service and can easily register to be placed anywhere they need\n// It is this service's responsibility of carrying out that layout.\nexport default {\n\n /**\n\t * Register a box to a chart.\n\t * A box is simply a reference to an object that requires layout. eg. Scales, Legend, Title.\n\t * @param {Chart} chart - the chart to use\n\t * @param {LayoutItem} item - the item to add to be laid out\n\t */\n addBox(chart, item) {\n if (!chart.boxes) {\n chart.boxes = [];\n }\n\n // initialize item with default values\n item.fullSize = item.fullSize || false;\n item.position = item.position || 'top';\n item.weight = item.weight || 0;\n // @ts-ignore\n item._layers = item._layers || function() {\n return [{\n z: 0,\n draw(chartArea) {\n item.draw(chartArea);\n }\n }];\n };\n\n chart.boxes.push(item);\n },\n\n /**\n\t * Remove a layoutItem from a chart\n\t * @param {Chart} chart - the chart to remove the box from\n\t * @param {LayoutItem} layoutItem - the item to remove from the layout\n\t */\n removeBox(chart, layoutItem) {\n const index = chart.boxes ? chart.boxes.indexOf(layoutItem) : -1;\n if (index !== -1) {\n chart.boxes.splice(index, 1);\n }\n },\n\n /**\n\t * Sets (or updates) options on the given `item`.\n\t * @param {Chart} chart - the chart in which the item lives (or will be added to)\n\t * @param {LayoutItem} item - the item to configure with the given options\n\t * @param {object} options - the new item options.\n\t */\n configure(chart, item, options) {\n item.fullSize = options.fullSize;\n item.position = options.position;\n item.weight = options.weight;\n },\n\n /**\n\t * Fits boxes of the given chart into the given size by having each box measure itself\n\t * then running a fitting algorithm\n\t * @param {Chart} chart - the chart\n\t * @param {number} width - the width to fit into\n\t * @param {number} height - the height to fit into\n * @param {number} minPadding - minimum padding required for each side of chart area\n\t */\n update(chart, width, height, minPadding) {\n if (!chart) {\n return;\n }\n\n const padding = toPadding(chart.options.layout.padding);\n const availableWidth = Math.max(width - padding.width, 0);\n const availableHeight = Math.max(height - padding.height, 0);\n const boxes = buildLayoutBoxes(chart.boxes);\n const verticalBoxes = boxes.vertical;\n const horizontalBoxes = boxes.horizontal;\n\n // Before any changes are made, notify boxes that an update is about to being\n // This is used to clear any cached data (e.g. scale limits)\n each(chart.boxes, box => {\n if (typeof box.beforeLayout === 'function') {\n box.beforeLayout();\n }\n });\n\n // Essentially we now have any number of boxes on each of the 4 sides.\n // Our canvas looks like the following.\n // The areas L1 and L2 are the left axes. R1 is the right axis, T1 is the top axis and\n // B1 is the bottom axis\n // There are also 4 quadrant-like locations (left to right instead of clockwise) reserved for chart overlays\n // These locations are single-box locations only, when trying to register a chartArea location that is already taken,\n // an error will be thrown.\n //\n // |----------------------------------------------------|\n // | T1 (Full Width) |\n // |----------------------------------------------------|\n // | | | T2 | |\n // | |----|-------------------------------------|----|\n // | | | C1 | | C2 | |\n // | | |----| |----| |\n // | | | | |\n // | L1 | L2 | ChartArea (C0) | R1 |\n // | | | | |\n // | | |----| |----| |\n // | | | C3 | | C4 | |\n // | |----|-------------------------------------|----|\n // | | | B1 | |\n // |----------------------------------------------------|\n // | B2 (Full Width) |\n // |----------------------------------------------------|\n //\n\n const visibleVerticalBoxCount = verticalBoxes.reduce((total, wrap) =>\n wrap.box.options && wrap.box.options.display === false ? total : total + 1, 0) || 1;\n\n const params = Object.freeze({\n outerWidth: width,\n outerHeight: height,\n padding,\n availableWidth,\n availableHeight,\n vBoxMaxWidth: availableWidth / 2 / visibleVerticalBoxCount,\n hBoxMaxHeight: availableHeight / 2\n });\n const maxPadding = Object.assign({}, padding);\n updateMaxPadding(maxPadding, toPadding(minPadding));\n const chartArea = Object.assign({\n maxPadding,\n w: availableWidth,\n h: availableHeight,\n x: padding.left,\n y: padding.top\n }, padding);\n\n const stacks = setLayoutDims(verticalBoxes.concat(horizontalBoxes), params);\n\n // First fit the fullSize boxes, to reduce probability of re-fitting.\n fitBoxes(boxes.fullSize, chartArea, params, stacks);\n\n // Then fit vertical boxes\n fitBoxes(verticalBoxes, chartArea, params, stacks);\n\n // Then fit horizontal boxes\n if (fitBoxes(horizontalBoxes, chartArea, params, stacks)) {\n // if the area changed, re-fit vertical boxes\n fitBoxes(verticalBoxes, chartArea, params, stacks);\n }\n\n handleMaxPadding(chartArea);\n\n // Finally place the boxes to correct coordinates\n placeBoxes(boxes.leftAndTop, chartArea, params, stacks);\n\n // Move to opposite side of chart\n chartArea.x += chartArea.w;\n chartArea.y += chartArea.h;\n\n placeBoxes(boxes.rightAndBottom, chartArea, params, stacks);\n\n chart.chartArea = {\n left: chartArea.left,\n top: chartArea.top,\n right: chartArea.left + chartArea.w,\n bottom: chartArea.top + chartArea.h,\n height: chartArea.h,\n width: chartArea.w,\n };\n\n // Finally update boxes in chartArea (radial scale for example)\n each(boxes.chartArea, (layout) => {\n const box = layout.box;\n Object.assign(box, chart.chartArea);\n box.update(chartArea.w, chartArea.h, {left: 0, top: 0, right: 0, bottom: 0});\n });\n }\n};\n","\n/**\n * @typedef { import('../core/core.controller.js').default } Chart\n */\n\n/**\n * Abstract class that allows abstracting platform dependencies away from the chart.\n */\nexport default class BasePlatform {\n /**\n\t * Called at chart construction time, returns a context2d instance implementing\n\t * the [W3C Canvas 2D Context API standard]{@link https://www.w3.org/TR/2dcontext/}.\n\t * @param {HTMLCanvasElement} canvas - The canvas from which to acquire context (platform specific)\n\t * @param {number} [aspectRatio] - The chart options\n\t */\n acquireContext(canvas, aspectRatio) {} // eslint-disable-line no-unused-vars\n\n /**\n\t * Called at chart destruction time, releases any resources associated to the context\n\t * previously returned by the acquireContext() method.\n\t * @param {CanvasRenderingContext2D} context - The context2d instance\n\t * @returns {boolean} true if the method succeeded, else false\n\t */\n releaseContext(context) { // eslint-disable-line no-unused-vars\n return false;\n }\n\n /**\n\t * Registers the specified listener on the given chart.\n\t * @param {Chart} chart - Chart from which to listen for event\n\t * @param {string} type - The ({@link ChartEvent}) type to listen for\n\t * @param {function} listener - Receives a notification (an object that implements\n\t * the {@link ChartEvent} interface) when an event of the specified type occurs.\n\t */\n addEventListener(chart, type, listener) {} // eslint-disable-line no-unused-vars\n\n /**\n\t * Removes the specified listener previously registered with addEventListener.\n\t * @param {Chart} chart - Chart from which to remove the listener\n\t * @param {string} type - The ({@link ChartEvent}) type to remove\n\t * @param {function} listener - The listener function to remove from the event target.\n\t */\n removeEventListener(chart, type, listener) {} // eslint-disable-line no-unused-vars\n\n /**\n\t * @returns {number} the current devicePixelRatio of the device this platform is connected to.\n\t */\n getDevicePixelRatio() {\n return 1;\n }\n\n /**\n\t * Returns the maximum size in pixels of given canvas element.\n\t * @param {HTMLCanvasElement} element\n\t * @param {number} [width] - content width of parent element\n\t * @param {number} [height] - content height of parent element\n\t * @param {number} [aspectRatio] - aspect ratio to maintain\n\t */\n getMaximumSize(element, width, height, aspectRatio) {\n width = Math.max(0, width || element.width);\n height = height || element.height;\n return {\n width,\n height: Math.max(0, aspectRatio ? Math.floor(width / aspectRatio) : height)\n };\n }\n\n /**\n\t * @param {HTMLCanvasElement} canvas\n\t * @returns {boolean} true if the canvas is attached to the platform, false if not.\n\t */\n isAttached(canvas) { // eslint-disable-line no-unused-vars\n return true;\n }\n\n /**\n * Updates config with platform specific requirements\n * @param {import('../core/core.config.js').default} config\n */\n updateConfig(config) { // eslint-disable-line no-unused-vars\n // no-op\n }\n}\n","/**\n * Platform fallback implementation (minimal).\n * @see https://github.com/chartjs/Chart.js/pull/4591#issuecomment-319575939\n */\n\nimport BasePlatform from './platform.base.js';\n\n/**\n * Platform class for charts without access to the DOM or to many element properties\n * This platform is used by default for any chart passed an OffscreenCanvas.\n * @extends BasePlatform\n */\nexport default class BasicPlatform extends BasePlatform {\n acquireContext(item) {\n // To prevent canvas fingerprinting, some add-ons undefine the getContext\n // method, for example: https://github.com/kkapsner/CanvasBlocker\n // https://github.com/chartjs/Chart.js/issues/2807\n return item && item.getContext && item.getContext('2d') || null;\n }\n updateConfig(config) {\n config.options.animation = false;\n }\n}\n","/**\n * Chart.Platform implementation for targeting a web browser\n */\n\nimport BasePlatform from './platform.base.js';\nimport {_getParentNode, getRelativePosition, supportsEventListenerOptions, readUsedSize, getMaximumSize} from '../helpers/helpers.dom.js';\nimport {throttled} from '../helpers/helpers.extras.js';\nimport {isNullOrUndef} from '../helpers/helpers.core.js';\n\n/**\n * @typedef { import('../core/core.controller.js').default } Chart\n */\n\nconst EXPANDO_KEY = '$chartjs';\n\n/**\n * DOM event types -> Chart.js event types.\n * Note: only events with different types are mapped.\n * @see https://developer.mozilla.org/en-US/docs/Web/Events\n */\nconst EVENT_TYPES = {\n touchstart: 'mousedown',\n touchmove: 'mousemove',\n touchend: 'mouseup',\n pointerenter: 'mouseenter',\n pointerdown: 'mousedown',\n pointermove: 'mousemove',\n pointerup: 'mouseup',\n pointerleave: 'mouseout',\n pointerout: 'mouseout'\n};\n\nconst isNullOrEmpty = value => value === null || value === '';\n/**\n * Initializes the canvas style and render size without modifying the canvas display size,\n * since responsiveness is handled by the controller.resize() method. The config is used\n * to determine the aspect ratio to apply in case no explicit height has been specified.\n * @param {HTMLCanvasElement} canvas\n * @param {number} [aspectRatio]\n */\nfunction initCanvas(canvas, aspectRatio) {\n const style = canvas.style;\n\n // NOTE(SB) canvas.getAttribute('width') !== canvas.width: in the first case it\n // returns null or '' if no explicit value has been set to the canvas attribute.\n const renderHeight = canvas.getAttribute('height');\n const renderWidth = canvas.getAttribute('width');\n\n // Chart.js modifies some canvas values that we want to restore on destroy\n canvas[EXPANDO_KEY] = {\n initial: {\n height: renderHeight,\n width: renderWidth,\n style: {\n display: style.display,\n height: style.height,\n width: style.width\n }\n }\n };\n\n // Force canvas to display as block to avoid extra space caused by inline\n // elements, which would interfere with the responsive resize process.\n // https://github.com/chartjs/Chart.js/issues/2538\n style.display = style.display || 'block';\n // Include possible borders in the size\n style.boxSizing = style.boxSizing || 'border-box';\n\n if (isNullOrEmpty(renderWidth)) {\n const displayWidth = readUsedSize(canvas, 'width');\n if (displayWidth !== undefined) {\n canvas.width = displayWidth;\n }\n }\n\n if (isNullOrEmpty(renderHeight)) {\n if (canvas.style.height === '') {\n // If no explicit render height and style height, let's apply the aspect ratio,\n // which one can be specified by the user but also by charts as default option\n // (i.e. options.aspectRatio). If not specified, use canvas aspect ratio of 2.\n canvas.height = canvas.width / (aspectRatio || 2);\n } else {\n const displayHeight = readUsedSize(canvas, 'height');\n if (displayHeight !== undefined) {\n canvas.height = displayHeight;\n }\n }\n }\n\n return canvas;\n}\n\n// Default passive to true as expected by Chrome for 'touchstart' and 'touchend' events.\n// https://github.com/chartjs/Chart.js/issues/4287\nconst eventListenerOptions = supportsEventListenerOptions ? {passive: true} : false;\n\nfunction addListener(node, type, listener) {\n if (node) {\n node.addEventListener(type, listener, eventListenerOptions);\n }\n}\n\nfunction removeListener(chart, type, listener) {\n if (chart && chart.canvas) {\n chart.canvas.removeEventListener(type, listener, eventListenerOptions);\n }\n}\n\nfunction fromNativeEvent(event, chart) {\n const type = EVENT_TYPES[event.type] || event.type;\n const {x, y} = getRelativePosition(event, chart);\n return {\n type,\n chart,\n native: event,\n x: x !== undefined ? x : null,\n y: y !== undefined ? y : null,\n };\n}\n\nfunction nodeListContains(nodeList, canvas) {\n for (const node of nodeList) {\n if (node === canvas || node.contains(canvas)) {\n return true;\n }\n }\n}\n\nfunction createAttachObserver(chart, type, listener) {\n const canvas = chart.canvas;\n const observer = new MutationObserver(entries => {\n let trigger = false;\n for (const entry of entries) {\n trigger = trigger || nodeListContains(entry.addedNodes, canvas);\n trigger = trigger && !nodeListContains(entry.removedNodes, canvas);\n }\n if (trigger) {\n listener();\n }\n });\n observer.observe(document, {childList: true, subtree: true});\n return observer;\n}\n\nfunction createDetachObserver(chart, type, listener) {\n const canvas = chart.canvas;\n const observer = new MutationObserver(entries => {\n let trigger = false;\n for (const entry of entries) {\n trigger = trigger || nodeListContains(entry.removedNodes, canvas);\n trigger = trigger && !nodeListContains(entry.addedNodes, canvas);\n }\n if (trigger) {\n listener();\n }\n });\n observer.observe(document, {childList: true, subtree: true});\n return observer;\n}\n\nconst drpListeningCharts = new Map();\nlet oldDevicePixelRatio = 0;\n\nfunction onWindowResize() {\n const dpr = window.devicePixelRatio;\n if (dpr === oldDevicePixelRatio) {\n return;\n }\n oldDevicePixelRatio = dpr;\n drpListeningCharts.forEach((resize, chart) => {\n if (chart.currentDevicePixelRatio !== dpr) {\n resize();\n }\n });\n}\n\nfunction listenDevicePixelRatioChanges(chart, resize) {\n if (!drpListeningCharts.size) {\n window.addEventListener('resize', onWindowResize);\n }\n drpListeningCharts.set(chart, resize);\n}\n\nfunction unlistenDevicePixelRatioChanges(chart) {\n drpListeningCharts.delete(chart);\n if (!drpListeningCharts.size) {\n window.removeEventListener('resize', onWindowResize);\n }\n}\n\nfunction createResizeObserver(chart, type, listener) {\n const canvas = chart.canvas;\n const container = canvas && _getParentNode(canvas);\n if (!container) {\n return;\n }\n const resize = throttled((width, height) => {\n const w = container.clientWidth;\n listener(width, height);\n if (w < container.clientWidth) {\n // If the container size shrank during chart resize, let's assume\n // scrollbar appeared. So we resize again with the scrollbar visible -\n // effectively making chart smaller and the scrollbar hidden again.\n // Because we are inside `throttled`, and currently `ticking`, scroll\n // events are ignored during this whole 2 resize process.\n // If we assumed wrong and something else happened, we are resizing\n // twice in a frame (potential performance issue)\n listener();\n }\n }, window);\n\n // @ts-ignore until https://github.com/microsoft/TypeScript/issues/37861 implemented\n const observer = new ResizeObserver(entries => {\n const entry = entries[0];\n const width = entry.contentRect.width;\n const height = entry.contentRect.height;\n // When its container's display is set to 'none' the callback will be called with a\n // size of (0, 0), which will cause the chart to lose its original height, so skip\n // resizing in such case.\n if (width === 0 && height === 0) {\n return;\n }\n resize(width, height);\n });\n observer.observe(container);\n listenDevicePixelRatioChanges(chart, resize);\n\n return observer;\n}\n\nfunction releaseObserver(chart, type, observer) {\n if (observer) {\n observer.disconnect();\n }\n if (type === 'resize') {\n unlistenDevicePixelRatioChanges(chart);\n }\n}\n\nfunction createProxyAndListen(chart, type, listener) {\n const canvas = chart.canvas;\n const proxy = throttled((event) => {\n // This case can occur if the chart is destroyed while waiting\n // for the throttled function to occur. We prevent crashes by checking\n // for a destroyed chart\n if (chart.ctx !== null) {\n listener(fromNativeEvent(event, chart));\n }\n }, chart);\n\n addListener(canvas, type, proxy);\n\n return proxy;\n}\n\n/**\n * Platform class for charts that can access the DOM and global window/document properties\n * @extends BasePlatform\n */\nexport default class DomPlatform extends BasePlatform {\n\n /**\n\t * @param {HTMLCanvasElement} canvas\n\t * @param {number} [aspectRatio]\n\t * @return {CanvasRenderingContext2D|null}\n\t */\n acquireContext(canvas, aspectRatio) {\n // To prevent canvas fingerprinting, some add-ons undefine the getContext\n // method, for example: https://github.com/kkapsner/CanvasBlocker\n // https://github.com/chartjs/Chart.js/issues/2807\n const context = canvas && canvas.getContext && canvas.getContext('2d');\n\n // `instanceof HTMLCanvasElement/CanvasRenderingContext2D` fails when the canvas is\n // inside an iframe or when running in a protected environment. We could guess the\n // types from their toString() value but let's keep things flexible and assume it's\n // a sufficient condition if the canvas has a context2D which has canvas as `canvas`.\n // https://github.com/chartjs/Chart.js/issues/3887\n // https://github.com/chartjs/Chart.js/issues/4102\n // https://github.com/chartjs/Chart.js/issues/4152\n if (context && context.canvas === canvas) {\n // Load platform resources on first chart creation, to make it possible to\n // import the library before setting platform options.\n initCanvas(canvas, aspectRatio);\n return context;\n }\n\n return null;\n }\n\n /**\n\t * @param {CanvasRenderingContext2D} context\n\t */\n releaseContext(context) {\n const canvas = context.canvas;\n if (!canvas[EXPANDO_KEY]) {\n return false;\n }\n\n const initial = canvas[EXPANDO_KEY].initial;\n ['height', 'width'].forEach((prop) => {\n const value = initial[prop];\n if (isNullOrUndef(value)) {\n canvas.removeAttribute(prop);\n } else {\n canvas.setAttribute(prop, value);\n }\n });\n\n const style = initial.style || {};\n Object.keys(style).forEach((key) => {\n canvas.style[key] = style[key];\n });\n\n // The canvas render size might have been changed (and thus the state stack discarded),\n // we can't use save() and restore() to restore the initial state. So make sure that at\n // least the canvas context is reset to the default state by setting the canvas width.\n // https://www.w3.org/TR/2011/WD-html5-20110525/the-canvas-element.html\n // eslint-disable-next-line no-self-assign\n canvas.width = canvas.width;\n\n delete canvas[EXPANDO_KEY];\n return true;\n }\n\n /**\n\t *\n\t * @param {Chart} chart\n\t * @param {string} type\n\t * @param {function} listener\n\t */\n addEventListener(chart, type, listener) {\n // Can have only one listener per type, so make sure previous is removed\n this.removeEventListener(chart, type);\n\n const proxies = chart.$proxies || (chart.$proxies = {});\n const handlers = {\n attach: createAttachObserver,\n detach: createDetachObserver,\n resize: createResizeObserver\n };\n const handler = handlers[type] || createProxyAndListen;\n proxies[type] = handler(chart, type, listener);\n }\n\n\n /**\n\t * @param {Chart} chart\n\t * @param {string} type\n\t */\n removeEventListener(chart, type) {\n const proxies = chart.$proxies || (chart.$proxies = {});\n const proxy = proxies[type];\n\n if (!proxy) {\n return;\n }\n\n const handlers = {\n attach: releaseObserver,\n detach: releaseObserver,\n resize: releaseObserver\n };\n const handler = handlers[type] || removeListener;\n handler(chart, type, proxy);\n proxies[type] = undefined;\n }\n\n getDevicePixelRatio() {\n return window.devicePixelRatio;\n }\n\n /**\n\t * @param {HTMLCanvasElement} canvas\n\t * @param {number} [width] - content width of parent element\n\t * @param {number} [height] - content height of parent element\n\t * @param {number} [aspectRatio] - aspect ratio to maintain\n\t */\n getMaximumSize(canvas, width, height, aspectRatio) {\n return getMaximumSize(canvas, width, height, aspectRatio);\n }\n\n /**\n\t * @param {HTMLCanvasElement} canvas\n\t */\n isAttached(canvas) {\n const container = canvas && _getParentNode(canvas);\n return !!(container && container.isConnected);\n }\n}\n","import {_isDomSupported} from '../helpers/index.js';\nimport BasePlatform from './platform.base.js';\nimport BasicPlatform from './platform.basic.js';\nimport DomPlatform from './platform.dom.js';\n\nexport function _detectPlatform(canvas) {\n if (!_isDomSupported() || (typeof OffscreenCanvas !== 'undefined' && canvas instanceof OffscreenCanvas)) {\n return BasicPlatform;\n }\n return DomPlatform;\n}\n\nexport {BasePlatform, BasicPlatform, DomPlatform};\n","import type {AnyObject} from '../types/basic.js';\nimport type {Point} from '../types/geometric.js';\nimport type {Animation} from '../types/animation.js';\nimport {isNumber} from '../helpers/helpers.math.js';\n\nexport default class Element {\n\n static defaults = {};\n static defaultRoutes = undefined;\n\n x: number;\n y: number;\n active = false;\n options: O;\n $animations: Record;\n\n tooltipPosition(useFinalPosition: boolean): Point {\n const {x, y} = this.getProps(['x', 'y'], useFinalPosition);\n return {x, y} as Point;\n }\n\n hasValue() {\n return isNumber(this.x) && isNumber(this.y);\n }\n\n /**\n * Gets the current or final value of each prop. Can return extra properties (whole object).\n * @param props - properties to get\n * @param [final] - get the final value (animation target)\n */\n getProps

(props: P, final?: boolean): Pick;\n getProps

(props: P[], final?: boolean): Partial>;\n getProps(props: string[], final?: boolean): Partial> {\n const anims = this.$animations;\n if (!final || !anims) {\n // let's not create an object, if not needed\n return this as Record;\n }\n const ret: Record = {};\n props.forEach((prop) => {\n ret[prop] = anims[prop] && anims[prop].active() ? anims[prop]._to : this[prop as string];\n });\n return ret;\n }\n}\n","import {isNullOrUndef, valueOrDefault} from '../helpers/helpers.core.js';\nimport {_factorize} from '../helpers/helpers.math.js';\n\n\n/**\n * @typedef { import('./core.controller.js').default } Chart\n * @typedef {{value:number | string, label?:string, major?:boolean, $context?:any}} Tick\n */\n\n/**\n * Returns a subset of ticks to be plotted to avoid overlapping labels.\n * @param {import('./core.scale.js').default} scale\n * @param {Tick[]} ticks\n * @return {Tick[]}\n * @private\n */\nexport function autoSkip(scale, ticks) {\n const tickOpts = scale.options.ticks;\n const determinedMaxTicks = determineMaxTicks(scale);\n const ticksLimit = Math.min(tickOpts.maxTicksLimit || determinedMaxTicks, determinedMaxTicks);\n const majorIndices = tickOpts.major.enabled ? getMajorIndices(ticks) : [];\n const numMajorIndices = majorIndices.length;\n const first = majorIndices[0];\n const last = majorIndices[numMajorIndices - 1];\n const newTicks = [];\n\n // If there are too many major ticks to display them all\n if (numMajorIndices > ticksLimit) {\n skipMajors(ticks, newTicks, majorIndices, numMajorIndices / ticksLimit);\n return newTicks;\n }\n\n const spacing = calculateSpacing(majorIndices, ticks, ticksLimit);\n\n if (numMajorIndices > 0) {\n let i, ilen;\n const avgMajorSpacing = numMajorIndices > 1 ? Math.round((last - first) / (numMajorIndices - 1)) : null;\n skip(ticks, newTicks, spacing, isNullOrUndef(avgMajorSpacing) ? 0 : first - avgMajorSpacing, first);\n for (i = 0, ilen = numMajorIndices - 1; i < ilen; i++) {\n skip(ticks, newTicks, spacing, majorIndices[i], majorIndices[i + 1]);\n }\n skip(ticks, newTicks, spacing, last, isNullOrUndef(avgMajorSpacing) ? ticks.length : last + avgMajorSpacing);\n return newTicks;\n }\n skip(ticks, newTicks, spacing);\n return newTicks;\n}\n\nfunction determineMaxTicks(scale) {\n const offset = scale.options.offset;\n const tickLength = scale._tickSize();\n const maxScale = scale._length / tickLength + (offset ? 0 : 1);\n const maxChart = scale._maxLength / tickLength;\n return Math.floor(Math.min(maxScale, maxChart));\n}\n\n/**\n * @param {number[]} majorIndices\n * @param {Tick[]} ticks\n * @param {number} ticksLimit\n */\nfunction calculateSpacing(majorIndices, ticks, ticksLimit) {\n const evenMajorSpacing = getEvenSpacing(majorIndices);\n const spacing = ticks.length / ticksLimit;\n\n // If the major ticks are evenly spaced apart, place the minor ticks\n // so that they divide the major ticks into even chunks\n if (!evenMajorSpacing) {\n return Math.max(spacing, 1);\n }\n\n const factors = _factorize(evenMajorSpacing);\n for (let i = 0, ilen = factors.length - 1; i < ilen; i++) {\n const factor = factors[i];\n if (factor > spacing) {\n return factor;\n }\n }\n return Math.max(spacing, 1);\n}\n\n/**\n * @param {Tick[]} ticks\n */\nfunction getMajorIndices(ticks) {\n const result = [];\n let i, ilen;\n for (i = 0, ilen = ticks.length; i < ilen; i++) {\n if (ticks[i].major) {\n result.push(i);\n }\n }\n return result;\n}\n\n/**\n * @param {Tick[]} ticks\n * @param {Tick[]} newTicks\n * @param {number[]} majorIndices\n * @param {number} spacing\n */\nfunction skipMajors(ticks, newTicks, majorIndices, spacing) {\n let count = 0;\n let next = majorIndices[0];\n let i;\n\n spacing = Math.ceil(spacing);\n for (i = 0; i < ticks.length; i++) {\n if (i === next) {\n newTicks.push(ticks[i]);\n count++;\n next = majorIndices[count * spacing];\n }\n }\n}\n\n/**\n * @param {Tick[]} ticks\n * @param {Tick[]} newTicks\n * @param {number} spacing\n * @param {number} [majorStart]\n * @param {number} [majorEnd]\n */\nfunction skip(ticks, newTicks, spacing, majorStart, majorEnd) {\n const start = valueOrDefault(majorStart, 0);\n const end = Math.min(valueOrDefault(majorEnd, ticks.length), ticks.length);\n let count = 0;\n let length, i, next;\n\n spacing = Math.ceil(spacing);\n if (majorEnd) {\n length = majorEnd - majorStart;\n spacing = length / Math.floor(length / spacing);\n }\n\n next = start;\n\n while (next < 0) {\n count++;\n next = Math.round(start + count * spacing);\n }\n\n for (i = Math.max(start, 0); i < end; i++) {\n if (i === next) {\n newTicks.push(ticks[i]);\n count++;\n next = Math.round(start + count * spacing);\n }\n }\n}\n\n\n/**\n * @param {number[]} arr\n */\nfunction getEvenSpacing(arr) {\n const len = arr.length;\n let i, diff;\n\n if (len < 2) {\n return false;\n }\n\n for (diff = arr[0], i = 1; i < len; ++i) {\n if (arr[i] - arr[i - 1] !== diff) {\n return false;\n }\n }\n return diff;\n}\n","import Element from './core.element.js';\nimport {_alignPixel, _measureText, renderText, clipArea, unclipArea} from '../helpers/helpers.canvas.js';\nimport {callback as call, each, finiteOrDefault, isArray, isFinite, isNullOrUndef, isObject, valueOrDefault} from '../helpers/helpers.core.js';\nimport {toDegrees, toRadians, _int16Range, _limitValue, HALF_PI} from '../helpers/helpers.math.js';\nimport {_alignStartEnd, _toLeftRightCenter} from '../helpers/helpers.extras.js';\nimport {createContext, toFont, toPadding, _addGrace} from '../helpers/helpers.options.js';\nimport {autoSkip} from './core.scale.autoskip.js';\n\nconst reverseAlign = (align) => align === 'left' ? 'right' : align === 'right' ? 'left' : align;\nconst offsetFromEdge = (scale, edge, offset) => edge === 'top' || edge === 'left' ? scale[edge] + offset : scale[edge] - offset;\nconst getTicksLimit = (ticksLength, maxTicksLimit) => Math.min(maxTicksLimit || ticksLength, ticksLength);\n\n/**\n * @typedef { import('../types/index.js').Chart } Chart\n * @typedef {{value:number | string, label?:string, major?:boolean, $context?:any}} Tick\n */\n\n/**\n * Returns a new array containing numItems from arr\n * @param {any[]} arr\n * @param {number} numItems\n */\nfunction sample(arr, numItems) {\n const result = [];\n const increment = arr.length / numItems;\n const len = arr.length;\n let i = 0;\n\n for (; i < len; i += increment) {\n result.push(arr[Math.floor(i)]);\n }\n return result;\n}\n\n/**\n * @param {Scale} scale\n * @param {number} index\n * @param {boolean} offsetGridLines\n */\nfunction getPixelForGridLine(scale, index, offsetGridLines) {\n const length = scale.ticks.length;\n const validIndex = Math.min(index, length - 1);\n const start = scale._startPixel;\n const end = scale._endPixel;\n const epsilon = 1e-6; // 1e-6 is margin in pixels for accumulated error.\n let lineValue = scale.getPixelForTick(validIndex);\n let offset;\n\n if (offsetGridLines) {\n if (length === 1) {\n offset = Math.max(lineValue - start, end - lineValue);\n } else if (index === 0) {\n offset = (scale.getPixelForTick(1) - lineValue) / 2;\n } else {\n offset = (lineValue - scale.getPixelForTick(validIndex - 1)) / 2;\n }\n lineValue += validIndex < index ? offset : -offset;\n\n // Return undefined if the pixel is out of the range\n if (lineValue < start - epsilon || lineValue > end + epsilon) {\n return;\n }\n }\n return lineValue;\n}\n\n/**\n * @param {object} caches\n * @param {number} length\n */\nfunction garbageCollect(caches, length) {\n each(caches, (cache) => {\n const gc = cache.gc;\n const gcLen = gc.length / 2;\n let i;\n if (gcLen > length) {\n for (i = 0; i < gcLen; ++i) {\n delete cache.data[gc[i]];\n }\n gc.splice(0, gcLen);\n }\n });\n}\n\n/**\n * @param {object} options\n */\nfunction getTickMarkLength(options) {\n return options.drawTicks ? options.tickLength : 0;\n}\n\n/**\n * @param {object} options\n */\nfunction getTitleHeight(options, fallback) {\n if (!options.display) {\n return 0;\n }\n\n const font = toFont(options.font, fallback);\n const padding = toPadding(options.padding);\n const lines = isArray(options.text) ? options.text.length : 1;\n\n return (lines * font.lineHeight) + padding.height;\n}\n\nfunction createScaleContext(parent, scale) {\n return createContext(parent, {\n scale,\n type: 'scale'\n });\n}\n\nfunction createTickContext(parent, index, tick) {\n return createContext(parent, {\n tick,\n index,\n type: 'tick'\n });\n}\n\nfunction titleAlign(align, position, reverse) {\n /** @type {CanvasTextAlign} */\n let ret = _toLeftRightCenter(align);\n if ((reverse && position !== 'right') || (!reverse && position === 'right')) {\n ret = reverseAlign(ret);\n }\n return ret;\n}\n\nfunction titleArgs(scale, offset, position, align) {\n const {top, left, bottom, right, chart} = scale;\n const {chartArea, scales} = chart;\n let rotation = 0;\n let maxWidth, titleX, titleY;\n const height = bottom - top;\n const width = right - left;\n\n if (scale.isHorizontal()) {\n titleX = _alignStartEnd(align, left, right);\n\n if (isObject(position)) {\n const positionAxisID = Object.keys(position)[0];\n const value = position[positionAxisID];\n titleY = scales[positionAxisID].getPixelForValue(value) + height - offset;\n } else if (position === 'center') {\n titleY = (chartArea.bottom + chartArea.top) / 2 + height - offset;\n } else {\n titleY = offsetFromEdge(scale, position, offset);\n }\n maxWidth = right - left;\n } else {\n if (isObject(position)) {\n const positionAxisID = Object.keys(position)[0];\n const value = position[positionAxisID];\n titleX = scales[positionAxisID].getPixelForValue(value) - width + offset;\n } else if (position === 'center') {\n titleX = (chartArea.left + chartArea.right) / 2 - width + offset;\n } else {\n titleX = offsetFromEdge(scale, position, offset);\n }\n titleY = _alignStartEnd(align, bottom, top);\n rotation = position === 'left' ? -HALF_PI : HALF_PI;\n }\n return {titleX, titleY, maxWidth, rotation};\n}\n\nexport default class Scale extends Element {\n\n // eslint-disable-next-line max-statements\n constructor(cfg) {\n super();\n\n /** @type {string} */\n this.id = cfg.id;\n /** @type {string} */\n this.type = cfg.type;\n /** @type {any} */\n this.options = undefined;\n /** @type {CanvasRenderingContext2D} */\n this.ctx = cfg.ctx;\n /** @type {Chart} */\n this.chart = cfg.chart;\n\n // implements box\n /** @type {number} */\n this.top = undefined;\n /** @type {number} */\n this.bottom = undefined;\n /** @type {number} */\n this.left = undefined;\n /** @type {number} */\n this.right = undefined;\n /** @type {number} */\n this.width = undefined;\n /** @type {number} */\n this.height = undefined;\n this._margins = {\n left: 0,\n right: 0,\n top: 0,\n bottom: 0\n };\n /** @type {number} */\n this.maxWidth = undefined;\n /** @type {number} */\n this.maxHeight = undefined;\n /** @type {number} */\n this.paddingTop = undefined;\n /** @type {number} */\n this.paddingBottom = undefined;\n /** @type {number} */\n this.paddingLeft = undefined;\n /** @type {number} */\n this.paddingRight = undefined;\n\n // scale-specific properties\n /** @type {string=} */\n this.axis = undefined;\n /** @type {number=} */\n this.labelRotation = undefined;\n this.min = undefined;\n this.max = undefined;\n this._range = undefined;\n /** @type {Tick[]} */\n this.ticks = [];\n /** @type {object[]|null} */\n this._gridLineItems = null;\n /** @type {object[]|null} */\n this._labelItems = null;\n /** @type {object|null} */\n this._labelSizes = null;\n this._length = 0;\n this._maxLength = 0;\n this._longestTextCache = {};\n /** @type {number} */\n this._startPixel = undefined;\n /** @type {number} */\n this._endPixel = undefined;\n this._reversePixels = false;\n this._userMax = undefined;\n this._userMin = undefined;\n this._suggestedMax = undefined;\n this._suggestedMin = undefined;\n this._ticksLength = 0;\n this._borderValue = 0;\n this._cache = {};\n this._dataLimitsCached = false;\n this.$context = undefined;\n }\n\n /**\n\t * @param {any} options\n\t * @since 3.0\n\t */\n init(options) {\n this.options = options.setContext(this.getContext());\n\n this.axis = options.axis;\n\n // parse min/max value, so we can properly determine min/max for other scales\n this._userMin = this.parse(options.min);\n this._userMax = this.parse(options.max);\n this._suggestedMin = this.parse(options.suggestedMin);\n this._suggestedMax = this.parse(options.suggestedMax);\n }\n\n /**\n\t * Parse a supported input value to internal representation.\n\t * @param {*} raw\n\t * @param {number} [index]\n\t * @since 3.0\n\t */\n parse(raw, index) { // eslint-disable-line no-unused-vars\n return raw;\n }\n\n /**\n\t * @return {{min: number, max: number, minDefined: boolean, maxDefined: boolean}}\n\t * @protected\n\t * @since 3.0\n\t */\n getUserBounds() {\n let {_userMin, _userMax, _suggestedMin, _suggestedMax} = this;\n _userMin = finiteOrDefault(_userMin, Number.POSITIVE_INFINITY);\n _userMax = finiteOrDefault(_userMax, Number.NEGATIVE_INFINITY);\n _suggestedMin = finiteOrDefault(_suggestedMin, Number.POSITIVE_INFINITY);\n _suggestedMax = finiteOrDefault(_suggestedMax, Number.NEGATIVE_INFINITY);\n return {\n min: finiteOrDefault(_userMin, _suggestedMin),\n max: finiteOrDefault(_userMax, _suggestedMax),\n minDefined: isFinite(_userMin),\n maxDefined: isFinite(_userMax)\n };\n }\n\n /**\n\t * @param {boolean} canStack\n\t * @return {{min: number, max: number}}\n\t * @protected\n\t * @since 3.0\n\t */\n getMinMax(canStack) {\n let {min, max, minDefined, maxDefined} = this.getUserBounds();\n let range;\n\n if (minDefined && maxDefined) {\n return {min, max};\n }\n\n const metas = this.getMatchingVisibleMetas();\n for (let i = 0, ilen = metas.length; i < ilen; ++i) {\n range = metas[i].controller.getMinMax(this, canStack);\n if (!minDefined) {\n min = Math.min(min, range.min);\n }\n if (!maxDefined) {\n max = Math.max(max, range.max);\n }\n }\n\n // Make sure min <= max when only min or max is defined by user and the data is outside that range\n min = maxDefined && min > max ? max : min;\n max = minDefined && min > max ? min : max;\n\n return {\n min: finiteOrDefault(min, finiteOrDefault(max, min)),\n max: finiteOrDefault(max, finiteOrDefault(min, max))\n };\n }\n\n /**\n\t * Get the padding needed for the scale\n\t * @return {{top: number, left: number, bottom: number, right: number}} the necessary padding\n\t * @private\n\t */\n getPadding() {\n return {\n left: this.paddingLeft || 0,\n top: this.paddingTop || 0,\n right: this.paddingRight || 0,\n bottom: this.paddingBottom || 0\n };\n }\n\n /**\n\t * Returns the scale tick objects\n\t * @return {Tick[]}\n\t * @since 2.7\n\t */\n getTicks() {\n return this.ticks;\n }\n\n /**\n\t * @return {string[]}\n\t */\n getLabels() {\n const data = this.chart.data;\n return this.options.labels || (this.isHorizontal() ? data.xLabels : data.yLabels) || data.labels || [];\n }\n\n /**\n * @return {import('../types.js').LabelItem[]}\n */\n getLabelItems(chartArea = this.chart.chartArea) {\n const items = this._labelItems || (this._labelItems = this._computeLabelItems(chartArea));\n return items;\n }\n\n // When a new layout is created, reset the data limits cache\n beforeLayout() {\n this._cache = {};\n this._dataLimitsCached = false;\n }\n\n // These methods are ordered by lifecycle. Utilities then follow.\n // Any function defined here is inherited by all scale types.\n // Any function can be extended by the scale type\n\n beforeUpdate() {\n call(this.options.beforeUpdate, [this]);\n }\n\n /**\n\t * @param {number} maxWidth - the max width in pixels\n\t * @param {number} maxHeight - the max height in pixels\n\t * @param {{top: number, left: number, bottom: number, right: number}} margins - the space between the edge of the other scales and edge of the chart\n\t * This space comes from two sources:\n\t * - padding - space that's required to show the labels at the edges of the scale\n\t * - thickness of scales or legends in another orientation\n\t */\n update(maxWidth, maxHeight, margins) {\n const {beginAtZero, grace, ticks: tickOpts} = this.options;\n const sampleSize = tickOpts.sampleSize;\n\n // Update Lifecycle - Probably don't want to ever extend or overwrite this function ;)\n this.beforeUpdate();\n\n // Absorb the master measurements\n this.maxWidth = maxWidth;\n this.maxHeight = maxHeight;\n this._margins = margins = Object.assign({\n left: 0,\n right: 0,\n top: 0,\n bottom: 0\n }, margins);\n\n this.ticks = null;\n this._labelSizes = null;\n this._gridLineItems = null;\n this._labelItems = null;\n\n // Dimensions\n this.beforeSetDimensions();\n this.setDimensions();\n this.afterSetDimensions();\n\n this._maxLength = this.isHorizontal()\n ? this.width + margins.left + margins.right\n : this.height + margins.top + margins.bottom;\n\n // Data min/max\n if (!this._dataLimitsCached) {\n this.beforeDataLimits();\n this.determineDataLimits();\n this.afterDataLimits();\n this._range = _addGrace(this, grace, beginAtZero);\n this._dataLimitsCached = true;\n }\n\n this.beforeBuildTicks();\n\n this.ticks = this.buildTicks() || [];\n\n // Allow modification of ticks in callback.\n this.afterBuildTicks();\n\n // Compute tick rotation and fit using a sampled subset of labels\n // We generally don't need to compute the size of every single label for determining scale size\n const samplingEnabled = sampleSize < this.ticks.length;\n this._convertTicksToLabels(samplingEnabled ? sample(this.ticks, sampleSize) : this.ticks);\n\n // configure is called twice, once here, once from core.controller.updateLayout.\n // Here we haven't been positioned yet, but dimensions are correct.\n // Variables set in configure are needed for calculateLabelRotation, and\n // it's ok that coordinates are not correct there, only dimensions matter.\n this.configure();\n\n // Tick Rotation\n this.beforeCalculateLabelRotation();\n this.calculateLabelRotation(); // Preconditions: number of ticks and sizes of largest labels must be calculated beforehand\n this.afterCalculateLabelRotation();\n\n // Auto-skip\n if (tickOpts.display && (tickOpts.autoSkip || tickOpts.source === 'auto')) {\n this.ticks = autoSkip(this, this.ticks);\n this._labelSizes = null;\n this.afterAutoSkip();\n }\n\n if (samplingEnabled) {\n // Generate labels using all non-skipped ticks\n this._convertTicksToLabels(this.ticks);\n }\n\n this.beforeFit();\n this.fit(); // Preconditions: label rotation and label sizes must be calculated beforehand\n this.afterFit();\n\n // IMPORTANT: after this point, we consider that `this.ticks` will NEVER change!\n\n this.afterUpdate();\n }\n\n /**\n\t * @protected\n\t */\n configure() {\n let reversePixels = this.options.reverse;\n let startPixel, endPixel;\n\n if (this.isHorizontal()) {\n startPixel = this.left;\n endPixel = this.right;\n } else {\n startPixel = this.top;\n endPixel = this.bottom;\n // by default vertical scales are from bottom to top, so pixels are reversed\n reversePixels = !reversePixels;\n }\n this._startPixel = startPixel;\n this._endPixel = endPixel;\n this._reversePixels = reversePixels;\n this._length = endPixel - startPixel;\n this._alignToPixels = this.options.alignToPixels;\n }\n\n afterUpdate() {\n call(this.options.afterUpdate, [this]);\n }\n\n //\n\n beforeSetDimensions() {\n call(this.options.beforeSetDimensions, [this]);\n }\n setDimensions() {\n // Set the unconstrained dimension before label rotation\n if (this.isHorizontal()) {\n // Reset position before calculating rotation\n this.width = this.maxWidth;\n this.left = 0;\n this.right = this.width;\n } else {\n this.height = this.maxHeight;\n\n // Reset position before calculating rotation\n this.top = 0;\n this.bottom = this.height;\n }\n\n // Reset padding\n this.paddingLeft = 0;\n this.paddingTop = 0;\n this.paddingRight = 0;\n this.paddingBottom = 0;\n }\n afterSetDimensions() {\n call(this.options.afterSetDimensions, [this]);\n }\n\n _callHooks(name) {\n this.chart.notifyPlugins(name, this.getContext());\n call(this.options[name], [this]);\n }\n\n // Data limits\n beforeDataLimits() {\n this._callHooks('beforeDataLimits');\n }\n determineDataLimits() {}\n afterDataLimits() {\n this._callHooks('afterDataLimits');\n }\n\n //\n beforeBuildTicks() {\n this._callHooks('beforeBuildTicks');\n }\n /**\n\t * @return {object[]} the ticks\n\t */\n buildTicks() {\n return [];\n }\n afterBuildTicks() {\n this._callHooks('afterBuildTicks');\n }\n\n beforeTickToLabelConversion() {\n call(this.options.beforeTickToLabelConversion, [this]);\n }\n /**\n\t * Convert ticks to label strings\n\t * @param {Tick[]} ticks\n\t */\n generateTickLabels(ticks) {\n const tickOpts = this.options.ticks;\n let i, ilen, tick;\n for (i = 0, ilen = ticks.length; i < ilen; i++) {\n tick = ticks[i];\n tick.label = call(tickOpts.callback, [tick.value, i, ticks], this);\n }\n }\n afterTickToLabelConversion() {\n call(this.options.afterTickToLabelConversion, [this]);\n }\n\n //\n\n beforeCalculateLabelRotation() {\n call(this.options.beforeCalculateLabelRotation, [this]);\n }\n calculateLabelRotation() {\n const options = this.options;\n const tickOpts = options.ticks;\n const numTicks = getTicksLimit(this.ticks.length, options.ticks.maxTicksLimit);\n const minRotation = tickOpts.minRotation || 0;\n const maxRotation = tickOpts.maxRotation;\n let labelRotation = minRotation;\n let tickWidth, maxHeight, maxLabelDiagonal;\n\n if (!this._isVisible() || !tickOpts.display || minRotation >= maxRotation || numTicks <= 1 || !this.isHorizontal()) {\n this.labelRotation = minRotation;\n return;\n }\n\n const labelSizes = this._getLabelSizes();\n const maxLabelWidth = labelSizes.widest.width;\n const maxLabelHeight = labelSizes.highest.height;\n\n // Estimate the width of each grid based on the canvas width, the maximum\n // label width and the number of tick intervals\n const maxWidth = _limitValue(this.chart.width - maxLabelWidth, 0, this.maxWidth);\n tickWidth = options.offset ? this.maxWidth / numTicks : maxWidth / (numTicks - 1);\n\n // Allow 3 pixels x2 padding either side for label readability\n if (maxLabelWidth + 6 > tickWidth) {\n tickWidth = maxWidth / (numTicks - (options.offset ? 0.5 : 1));\n maxHeight = this.maxHeight - getTickMarkLength(options.grid)\n\t\t\t\t- tickOpts.padding - getTitleHeight(options.title, this.chart.options.font);\n maxLabelDiagonal = Math.sqrt(maxLabelWidth * maxLabelWidth + maxLabelHeight * maxLabelHeight);\n labelRotation = toDegrees(Math.min(\n Math.asin(_limitValue((labelSizes.highest.height + 6) / tickWidth, -1, 1)),\n Math.asin(_limitValue(maxHeight / maxLabelDiagonal, -1, 1)) - Math.asin(_limitValue(maxLabelHeight / maxLabelDiagonal, -1, 1))\n ));\n labelRotation = Math.max(minRotation, Math.min(maxRotation, labelRotation));\n }\n\n this.labelRotation = labelRotation;\n }\n afterCalculateLabelRotation() {\n call(this.options.afterCalculateLabelRotation, [this]);\n }\n afterAutoSkip() {}\n\n //\n\n beforeFit() {\n call(this.options.beforeFit, [this]);\n }\n fit() {\n // Reset\n const minSize = {\n width: 0,\n height: 0\n };\n\n const {chart, options: {ticks: tickOpts, title: titleOpts, grid: gridOpts}} = this;\n const display = this._isVisible();\n const isHorizontal = this.isHorizontal();\n\n if (display) {\n const titleHeight = getTitleHeight(titleOpts, chart.options.font);\n if (isHorizontal) {\n minSize.width = this.maxWidth;\n minSize.height = getTickMarkLength(gridOpts) + titleHeight;\n } else {\n minSize.height = this.maxHeight; // fill all the height\n minSize.width = getTickMarkLength(gridOpts) + titleHeight;\n }\n\n // Don't bother fitting the ticks if we are not showing the labels\n if (tickOpts.display && this.ticks.length) {\n const {first, last, widest, highest} = this._getLabelSizes();\n const tickPadding = tickOpts.padding * 2;\n const angleRadians = toRadians(this.labelRotation);\n const cos = Math.cos(angleRadians);\n const sin = Math.sin(angleRadians);\n\n if (isHorizontal) {\n // A horizontal axis is more constrained by the height.\n const labelHeight = tickOpts.mirror ? 0 : sin * widest.width + cos * highest.height;\n minSize.height = Math.min(this.maxHeight, minSize.height + labelHeight + tickPadding);\n } else {\n // A vertical axis is more constrained by the width. Labels are the\n // dominant factor here, so get that length first and account for padding\n const labelWidth = tickOpts.mirror ? 0 : cos * widest.width + sin * highest.height;\n\n minSize.width = Math.min(this.maxWidth, minSize.width + labelWidth + tickPadding);\n }\n this._calculatePadding(first, last, sin, cos);\n }\n }\n\n this._handleMargins();\n\n if (isHorizontal) {\n this.width = this._length = chart.width - this._margins.left - this._margins.right;\n this.height = minSize.height;\n } else {\n this.width = minSize.width;\n this.height = this._length = chart.height - this._margins.top - this._margins.bottom;\n }\n }\n\n _calculatePadding(first, last, sin, cos) {\n const {ticks: {align, padding}, position} = this.options;\n const isRotated = this.labelRotation !== 0;\n const labelsBelowTicks = position !== 'top' && this.axis === 'x';\n\n if (this.isHorizontal()) {\n const offsetLeft = this.getPixelForTick(0) - this.left;\n const offsetRight = this.right - this.getPixelForTick(this.ticks.length - 1);\n let paddingLeft = 0;\n let paddingRight = 0;\n\n // Ensure that our ticks are always inside the canvas. When rotated, ticks are right aligned\n // which means that the right padding is dominated by the font height\n if (isRotated) {\n if (labelsBelowTicks) {\n paddingLeft = cos * first.width;\n paddingRight = sin * last.height;\n } else {\n paddingLeft = sin * first.height;\n paddingRight = cos * last.width;\n }\n } else if (align === 'start') {\n paddingRight = last.width;\n } else if (align === 'end') {\n paddingLeft = first.width;\n } else if (align !== 'inner') {\n paddingLeft = first.width / 2;\n paddingRight = last.width / 2;\n }\n\n // Adjust padding taking into account changes in offsets\n this.paddingLeft = Math.max((paddingLeft - offsetLeft + padding) * this.width / (this.width - offsetLeft), 0);\n this.paddingRight = Math.max((paddingRight - offsetRight + padding) * this.width / (this.width - offsetRight), 0);\n } else {\n let paddingTop = last.height / 2;\n let paddingBottom = first.height / 2;\n\n if (align === 'start') {\n paddingTop = 0;\n paddingBottom = first.height;\n } else if (align === 'end') {\n paddingTop = last.height;\n paddingBottom = 0;\n }\n\n this.paddingTop = paddingTop + padding;\n this.paddingBottom = paddingBottom + padding;\n }\n }\n\n /**\n\t * Handle margins and padding interactions\n\t * @private\n\t */\n _handleMargins() {\n if (this._margins) {\n this._margins.left = Math.max(this.paddingLeft, this._margins.left);\n this._margins.top = Math.max(this.paddingTop, this._margins.top);\n this._margins.right = Math.max(this.paddingRight, this._margins.right);\n this._margins.bottom = Math.max(this.paddingBottom, this._margins.bottom);\n }\n }\n\n afterFit() {\n call(this.options.afterFit, [this]);\n }\n\n // Shared Methods\n /**\n\t * @return {boolean}\n\t */\n isHorizontal() {\n const {axis, position} = this.options;\n return position === 'top' || position === 'bottom' || axis === 'x';\n }\n /**\n\t * @return {boolean}\n\t */\n isFullSize() {\n return this.options.fullSize;\n }\n\n /**\n\t * @param {Tick[]} ticks\n\t * @private\n\t */\n _convertTicksToLabels(ticks) {\n this.beforeTickToLabelConversion();\n\n this.generateTickLabels(ticks);\n\n // Ticks should be skipped when callback returns null or undef, so lets remove those.\n let i, ilen;\n for (i = 0, ilen = ticks.length; i < ilen; i++) {\n if (isNullOrUndef(ticks[i].label)) {\n ticks.splice(i, 1);\n ilen--;\n i--;\n }\n }\n\n this.afterTickToLabelConversion();\n }\n\n /**\n\t * @return {{ first: object, last: object, widest: object, highest: object, widths: Array, heights: array }}\n\t * @private\n\t */\n _getLabelSizes() {\n let labelSizes = this._labelSizes;\n\n if (!labelSizes) {\n const sampleSize = this.options.ticks.sampleSize;\n let ticks = this.ticks;\n if (sampleSize < ticks.length) {\n ticks = sample(ticks, sampleSize);\n }\n\n this._labelSizes = labelSizes = this._computeLabelSizes(ticks, ticks.length, this.options.ticks.maxTicksLimit);\n }\n\n return labelSizes;\n }\n\n /**\n\t * Returns {width, height, offset} objects for the first, last, widest, highest tick\n\t * labels where offset indicates the anchor point offset from the top in pixels.\n\t * @return {{ first: object, last: object, widest: object, highest: object, widths: Array, heights: array }}\n\t * @private\n\t */\n _computeLabelSizes(ticks, length, maxTicksLimit) {\n const {ctx, _longestTextCache: caches} = this;\n const widths = [];\n const heights = [];\n const increment = Math.floor(length / getTicksLimit(length, maxTicksLimit));\n let widestLabelSize = 0;\n let highestLabelSize = 0;\n let i, j, jlen, label, tickFont, fontString, cache, lineHeight, width, height, nestedLabel;\n\n for (i = 0; i < length; i += increment) {\n label = ticks[i].label;\n tickFont = this._resolveTickFontOptions(i);\n ctx.font = fontString = tickFont.string;\n cache = caches[fontString] = caches[fontString] || {data: {}, gc: []};\n lineHeight = tickFont.lineHeight;\n width = height = 0;\n // Undefined labels and arrays should not be measured\n if (!isNullOrUndef(label) && !isArray(label)) {\n width = _measureText(ctx, cache.data, cache.gc, width, label);\n height = lineHeight;\n } else if (isArray(label)) {\n // if it is an array let's measure each element\n for (j = 0, jlen = label.length; j < jlen; ++j) {\n nestedLabel = /** @type {string} */ (label[j]);\n // Undefined labels and arrays should not be measured\n if (!isNullOrUndef(nestedLabel) && !isArray(nestedLabel)) {\n width = _measureText(ctx, cache.data, cache.gc, width, nestedLabel);\n height += lineHeight;\n }\n }\n }\n widths.push(width);\n heights.push(height);\n widestLabelSize = Math.max(width, widestLabelSize);\n highestLabelSize = Math.max(height, highestLabelSize);\n }\n garbageCollect(caches, length);\n\n const widest = widths.indexOf(widestLabelSize);\n const highest = heights.indexOf(highestLabelSize);\n\n const valueAt = (idx) => ({width: widths[idx] || 0, height: heights[idx] || 0});\n\n return {\n first: valueAt(0),\n last: valueAt(length - 1),\n widest: valueAt(widest),\n highest: valueAt(highest),\n widths,\n heights,\n };\n }\n\n /**\n\t * Used to get the label to display in the tooltip for the given value\n\t * @param {*} value\n\t * @return {string}\n\t */\n getLabelForValue(value) {\n return value;\n }\n\n /**\n\t * Returns the location of the given data point. Value can either be an index or a numerical value\n\t * The coordinate (0, 0) is at the upper-left corner of the canvas\n\t * @param {*} value\n\t * @param {number} [index]\n\t * @return {number}\n\t */\n getPixelForValue(value, index) { // eslint-disable-line no-unused-vars\n return NaN;\n }\n\n /**\n\t * Used to get the data value from a given pixel. This is the inverse of getPixelForValue\n\t * The coordinate (0, 0) is at the upper-left corner of the canvas\n\t * @param {number} pixel\n\t * @return {*}\n\t */\n getValueForPixel(pixel) {} // eslint-disable-line no-unused-vars\n\n /**\n\t * Returns the location of the tick at the given index\n\t * The coordinate (0, 0) is at the upper-left corner of the canvas\n\t * @param {number} index\n\t * @return {number}\n\t */\n getPixelForTick(index) {\n const ticks = this.ticks;\n if (index < 0 || index > ticks.length - 1) {\n return null;\n }\n return this.getPixelForValue(ticks[index].value);\n }\n\n /**\n\t * Utility for getting the pixel location of a percentage of scale\n\t * The coordinate (0, 0) is at the upper-left corner of the canvas\n\t * @param {number} decimal\n\t * @return {number}\n\t */\n getPixelForDecimal(decimal) {\n if (this._reversePixels) {\n decimal = 1 - decimal;\n }\n\n const pixel = this._startPixel + decimal * this._length;\n return _int16Range(this._alignToPixels ? _alignPixel(this.chart, pixel, 0) : pixel);\n }\n\n /**\n\t * @param {number} pixel\n\t * @return {number}\n\t */\n getDecimalForPixel(pixel) {\n const decimal = (pixel - this._startPixel) / this._length;\n return this._reversePixels ? 1 - decimal : decimal;\n }\n\n /**\n\t * Returns the pixel for the minimum chart value\n\t * The coordinate (0, 0) is at the upper-left corner of the canvas\n\t * @return {number}\n\t */\n getBasePixel() {\n return this.getPixelForValue(this.getBaseValue());\n }\n\n /**\n\t * @return {number}\n\t */\n getBaseValue() {\n const {min, max} = this;\n\n return min < 0 && max < 0 ? max :\n min > 0 && max > 0 ? min :\n 0;\n }\n\n /**\n\t * @protected\n\t */\n getContext(index) {\n const ticks = this.ticks || [];\n\n if (index >= 0 && index < ticks.length) {\n const tick = ticks[index];\n return tick.$context ||\n\t\t\t\t(tick.$context = createTickContext(this.getContext(), index, tick));\n }\n return this.$context ||\n\t\t\t(this.$context = createScaleContext(this.chart.getContext(), this));\n }\n\n /**\n\t * @return {number}\n\t * @private\n\t */\n _tickSize() {\n const optionTicks = this.options.ticks;\n\n // Calculate space needed by label in axis direction.\n const rot = toRadians(this.labelRotation);\n const cos = Math.abs(Math.cos(rot));\n const sin = Math.abs(Math.sin(rot));\n\n const labelSizes = this._getLabelSizes();\n const padding = optionTicks.autoSkipPadding || 0;\n const w = labelSizes ? labelSizes.widest.width + padding : 0;\n const h = labelSizes ? labelSizes.highest.height + padding : 0;\n\n // Calculate space needed for 1 tick in axis direction.\n return this.isHorizontal()\n ? h * cos > w * sin ? w / cos : h / sin\n : h * sin < w * cos ? h / cos : w / sin;\n }\n\n /**\n\t * @return {boolean}\n\t * @private\n\t */\n _isVisible() {\n const display = this.options.display;\n\n if (display !== 'auto') {\n return !!display;\n }\n\n return this.getMatchingVisibleMetas().length > 0;\n }\n\n /**\n\t * @private\n\t */\n _computeGridLineItems(chartArea) {\n const axis = this.axis;\n const chart = this.chart;\n const options = this.options;\n const {grid, position, border} = options;\n const offset = grid.offset;\n const isHorizontal = this.isHorizontal();\n const ticks = this.ticks;\n const ticksLength = ticks.length + (offset ? 1 : 0);\n const tl = getTickMarkLength(grid);\n const items = [];\n\n const borderOpts = border.setContext(this.getContext());\n const axisWidth = borderOpts.display ? borderOpts.width : 0;\n const axisHalfWidth = axisWidth / 2;\n const alignBorderValue = function(pixel) {\n return _alignPixel(chart, pixel, axisWidth);\n };\n let borderValue, i, lineValue, alignedLineValue;\n let tx1, ty1, tx2, ty2, x1, y1, x2, y2;\n\n if (position === 'top') {\n borderValue = alignBorderValue(this.bottom);\n ty1 = this.bottom - tl;\n ty2 = borderValue - axisHalfWidth;\n y1 = alignBorderValue(chartArea.top) + axisHalfWidth;\n y2 = chartArea.bottom;\n } else if (position === 'bottom') {\n borderValue = alignBorderValue(this.top);\n y1 = chartArea.top;\n y2 = alignBorderValue(chartArea.bottom) - axisHalfWidth;\n ty1 = borderValue + axisHalfWidth;\n ty2 = this.top + tl;\n } else if (position === 'left') {\n borderValue = alignBorderValue(this.right);\n tx1 = this.right - tl;\n tx2 = borderValue - axisHalfWidth;\n x1 = alignBorderValue(chartArea.left) + axisHalfWidth;\n x2 = chartArea.right;\n } else if (position === 'right') {\n borderValue = alignBorderValue(this.left);\n x1 = chartArea.left;\n x2 = alignBorderValue(chartArea.right) - axisHalfWidth;\n tx1 = borderValue + axisHalfWidth;\n tx2 = this.left + tl;\n } else if (axis === 'x') {\n if (position === 'center') {\n borderValue = alignBorderValue((chartArea.top + chartArea.bottom) / 2 + 0.5);\n } else if (isObject(position)) {\n const positionAxisID = Object.keys(position)[0];\n const value = position[positionAxisID];\n borderValue = alignBorderValue(this.chart.scales[positionAxisID].getPixelForValue(value));\n }\n\n y1 = chartArea.top;\n y2 = chartArea.bottom;\n ty1 = borderValue + axisHalfWidth;\n ty2 = ty1 + tl;\n } else if (axis === 'y') {\n if (position === 'center') {\n borderValue = alignBorderValue((chartArea.left + chartArea.right) / 2);\n } else if (isObject(position)) {\n const positionAxisID = Object.keys(position)[0];\n const value = position[positionAxisID];\n borderValue = alignBorderValue(this.chart.scales[positionAxisID].getPixelForValue(value));\n }\n\n tx1 = borderValue - axisHalfWidth;\n tx2 = tx1 - tl;\n x1 = chartArea.left;\n x2 = chartArea.right;\n }\n\n const limit = valueOrDefault(options.ticks.maxTicksLimit, ticksLength);\n const step = Math.max(1, Math.ceil(ticksLength / limit));\n for (i = 0; i < ticksLength; i += step) {\n const context = this.getContext(i);\n const optsAtIndex = grid.setContext(context);\n const optsAtIndexBorder = border.setContext(context);\n\n const lineWidth = optsAtIndex.lineWidth;\n const lineColor = optsAtIndex.color;\n const borderDash = optsAtIndexBorder.dash || [];\n const borderDashOffset = optsAtIndexBorder.dashOffset;\n\n const tickWidth = optsAtIndex.tickWidth;\n const tickColor = optsAtIndex.tickColor;\n const tickBorderDash = optsAtIndex.tickBorderDash || [];\n const tickBorderDashOffset = optsAtIndex.tickBorderDashOffset;\n\n lineValue = getPixelForGridLine(this, i, offset);\n\n // Skip if the pixel is out of the range\n if (lineValue === undefined) {\n continue;\n }\n\n alignedLineValue = _alignPixel(chart, lineValue, lineWidth);\n\n if (isHorizontal) {\n tx1 = tx2 = x1 = x2 = alignedLineValue;\n } else {\n ty1 = ty2 = y1 = y2 = alignedLineValue;\n }\n\n items.push({\n tx1,\n ty1,\n tx2,\n ty2,\n x1,\n y1,\n x2,\n y2,\n width: lineWidth,\n color: lineColor,\n borderDash,\n borderDashOffset,\n tickWidth,\n tickColor,\n tickBorderDash,\n tickBorderDashOffset,\n });\n }\n\n this._ticksLength = ticksLength;\n this._borderValue = borderValue;\n\n return items;\n }\n\n /**\n\t * @private\n\t */\n _computeLabelItems(chartArea) {\n const axis = this.axis;\n const options = this.options;\n const {position, ticks: optionTicks} = options;\n const isHorizontal = this.isHorizontal();\n const ticks = this.ticks;\n const {align, crossAlign, padding, mirror} = optionTicks;\n const tl = getTickMarkLength(options.grid);\n const tickAndPadding = tl + padding;\n const hTickAndPadding = mirror ? -padding : tickAndPadding;\n const rotation = -toRadians(this.labelRotation);\n const items = [];\n let i, ilen, tick, label, x, y, textAlign, pixel, font, lineHeight, lineCount, textOffset;\n let textBaseline = 'middle';\n\n if (position === 'top') {\n y = this.bottom - hTickAndPadding;\n textAlign = this._getXAxisLabelAlignment();\n } else if (position === 'bottom') {\n y = this.top + hTickAndPadding;\n textAlign = this._getXAxisLabelAlignment();\n } else if (position === 'left') {\n const ret = this._getYAxisLabelAlignment(tl);\n textAlign = ret.textAlign;\n x = ret.x;\n } else if (position === 'right') {\n const ret = this._getYAxisLabelAlignment(tl);\n textAlign = ret.textAlign;\n x = ret.x;\n } else if (axis === 'x') {\n if (position === 'center') {\n y = ((chartArea.top + chartArea.bottom) / 2) + tickAndPadding;\n } else if (isObject(position)) {\n const positionAxisID = Object.keys(position)[0];\n const value = position[positionAxisID];\n y = this.chart.scales[positionAxisID].getPixelForValue(value) + tickAndPadding;\n }\n textAlign = this._getXAxisLabelAlignment();\n } else if (axis === 'y') {\n if (position === 'center') {\n x = ((chartArea.left + chartArea.right) / 2) - tickAndPadding;\n } else if (isObject(position)) {\n const positionAxisID = Object.keys(position)[0];\n const value = position[positionAxisID];\n x = this.chart.scales[positionAxisID].getPixelForValue(value);\n }\n textAlign = this._getYAxisLabelAlignment(tl).textAlign;\n }\n\n if (axis === 'y') {\n if (align === 'start') {\n textBaseline = 'top';\n } else if (align === 'end') {\n textBaseline = 'bottom';\n }\n }\n\n const labelSizes = this._getLabelSizes();\n for (i = 0, ilen = ticks.length; i < ilen; ++i) {\n tick = ticks[i];\n label = tick.label;\n\n const optsAtIndex = optionTicks.setContext(this.getContext(i));\n pixel = this.getPixelForTick(i) + optionTicks.labelOffset;\n font = this._resolveTickFontOptions(i);\n lineHeight = font.lineHeight;\n lineCount = isArray(label) ? label.length : 1;\n const halfCount = lineCount / 2;\n const color = optsAtIndex.color;\n const strokeColor = optsAtIndex.textStrokeColor;\n const strokeWidth = optsAtIndex.textStrokeWidth;\n let tickTextAlign = textAlign;\n\n if (isHorizontal) {\n x = pixel;\n\n if (textAlign === 'inner') {\n if (i === ilen - 1) {\n tickTextAlign = !this.options.reverse ? 'right' : 'left';\n } else if (i === 0) {\n tickTextAlign = !this.options.reverse ? 'left' : 'right';\n } else {\n tickTextAlign = 'center';\n }\n }\n\n if (position === 'top') {\n if (crossAlign === 'near' || rotation !== 0) {\n textOffset = -lineCount * lineHeight + lineHeight / 2;\n } else if (crossAlign === 'center') {\n textOffset = -labelSizes.highest.height / 2 - halfCount * lineHeight + lineHeight;\n } else {\n textOffset = -labelSizes.highest.height + lineHeight / 2;\n }\n } else {\n // eslint-disable-next-line no-lonely-if\n if (crossAlign === 'near' || rotation !== 0) {\n textOffset = lineHeight / 2;\n } else if (crossAlign === 'center') {\n textOffset = labelSizes.highest.height / 2 - halfCount * lineHeight;\n } else {\n textOffset = labelSizes.highest.height - lineCount * lineHeight;\n }\n }\n if (mirror) {\n textOffset *= -1;\n }\n if (rotation !== 0 && !optsAtIndex.showLabelBackdrop) {\n x += (lineHeight / 2) * Math.sin(rotation);\n }\n } else {\n y = pixel;\n textOffset = (1 - lineCount) * lineHeight / 2;\n }\n\n let backdrop;\n\n if (optsAtIndex.showLabelBackdrop) {\n const labelPadding = toPadding(optsAtIndex.backdropPadding);\n const height = labelSizes.heights[i];\n const width = labelSizes.widths[i];\n\n let top = textOffset - labelPadding.top;\n let left = 0 - labelPadding.left;\n\n switch (textBaseline) {\n case 'middle':\n top -= height / 2;\n break;\n case 'bottom':\n top -= height;\n break;\n default:\n break;\n }\n\n switch (textAlign) {\n case 'center':\n left -= width / 2;\n break;\n case 'right':\n left -= width;\n break;\n case 'inner':\n if (i === ilen - 1) {\n left -= width;\n } else if (i > 0) {\n left -= width / 2;\n }\n break;\n default:\n break;\n }\n\n backdrop = {\n left,\n top,\n width: width + labelPadding.width,\n height: height + labelPadding.height,\n\n color: optsAtIndex.backdropColor,\n };\n }\n\n items.push({\n label,\n font,\n textOffset,\n options: {\n rotation,\n color,\n strokeColor,\n strokeWidth,\n textAlign: tickTextAlign,\n textBaseline,\n translation: [x, y],\n backdrop,\n }\n });\n }\n\n return items;\n }\n\n _getXAxisLabelAlignment() {\n const {position, ticks} = this.options;\n const rotation = -toRadians(this.labelRotation);\n\n if (rotation) {\n return position === 'top' ? 'left' : 'right';\n }\n\n let align = 'center';\n\n if (ticks.align === 'start') {\n align = 'left';\n } else if (ticks.align === 'end') {\n align = 'right';\n } else if (ticks.align === 'inner') {\n align = 'inner';\n }\n\n return align;\n }\n\n _getYAxisLabelAlignment(tl) {\n const {position, ticks: {crossAlign, mirror, padding}} = this.options;\n const labelSizes = this._getLabelSizes();\n const tickAndPadding = tl + padding;\n const widest = labelSizes.widest.width;\n\n let textAlign;\n let x;\n\n if (position === 'left') {\n if (mirror) {\n x = this.right + padding;\n\n if (crossAlign === 'near') {\n textAlign = 'left';\n } else if (crossAlign === 'center') {\n textAlign = 'center';\n x += (widest / 2);\n } else {\n textAlign = 'right';\n x += widest;\n }\n } else {\n x = this.right - tickAndPadding;\n\n if (crossAlign === 'near') {\n textAlign = 'right';\n } else if (crossAlign === 'center') {\n textAlign = 'center';\n x -= (widest / 2);\n } else {\n textAlign = 'left';\n x = this.left;\n }\n }\n } else if (position === 'right') {\n if (mirror) {\n x = this.left + padding;\n\n if (crossAlign === 'near') {\n textAlign = 'right';\n } else if (crossAlign === 'center') {\n textAlign = 'center';\n x -= (widest / 2);\n } else {\n textAlign = 'left';\n x -= widest;\n }\n } else {\n x = this.left + tickAndPadding;\n\n if (crossAlign === 'near') {\n textAlign = 'left';\n } else if (crossAlign === 'center') {\n textAlign = 'center';\n x += widest / 2;\n } else {\n textAlign = 'right';\n x = this.right;\n }\n }\n } else {\n textAlign = 'right';\n }\n\n return {textAlign, x};\n }\n\n /**\n\t * @private\n\t */\n _computeLabelArea() {\n if (this.options.ticks.mirror) {\n return;\n }\n\n const chart = this.chart;\n const position = this.options.position;\n\n if (position === 'left' || position === 'right') {\n return {top: 0, left: this.left, bottom: chart.height, right: this.right};\n } if (position === 'top' || position === 'bottom') {\n return {top: this.top, left: 0, bottom: this.bottom, right: chart.width};\n }\n }\n\n /**\n * @protected\n */\n drawBackground() {\n const {ctx, options: {backgroundColor}, left, top, width, height} = this;\n if (backgroundColor) {\n ctx.save();\n ctx.fillStyle = backgroundColor;\n ctx.fillRect(left, top, width, height);\n ctx.restore();\n }\n }\n\n getLineWidthForValue(value) {\n const grid = this.options.grid;\n if (!this._isVisible() || !grid.display) {\n return 0;\n }\n const ticks = this.ticks;\n const index = ticks.findIndex(t => t.value === value);\n if (index >= 0) {\n const opts = grid.setContext(this.getContext(index));\n return opts.lineWidth;\n }\n return 0;\n }\n\n /**\n\t * @protected\n\t */\n drawGrid(chartArea) {\n const grid = this.options.grid;\n const ctx = this.ctx;\n const items = this._gridLineItems || (this._gridLineItems = this._computeGridLineItems(chartArea));\n let i, ilen;\n\n const drawLine = (p1, p2, style) => {\n if (!style.width || !style.color) {\n return;\n }\n ctx.save();\n ctx.lineWidth = style.width;\n ctx.strokeStyle = style.color;\n ctx.setLineDash(style.borderDash || []);\n ctx.lineDashOffset = style.borderDashOffset;\n\n ctx.beginPath();\n ctx.moveTo(p1.x, p1.y);\n ctx.lineTo(p2.x, p2.y);\n ctx.stroke();\n ctx.restore();\n };\n\n if (grid.display) {\n for (i = 0, ilen = items.length; i < ilen; ++i) {\n const item = items[i];\n\n if (grid.drawOnChartArea) {\n drawLine(\n {x: item.x1, y: item.y1},\n {x: item.x2, y: item.y2},\n item\n );\n }\n\n if (grid.drawTicks) {\n drawLine(\n {x: item.tx1, y: item.ty1},\n {x: item.tx2, y: item.ty2},\n {\n color: item.tickColor,\n width: item.tickWidth,\n borderDash: item.tickBorderDash,\n borderDashOffset: item.tickBorderDashOffset\n }\n );\n }\n }\n }\n }\n\n /**\n\t * @protected\n\t */\n drawBorder() {\n const {chart, ctx, options: {border, grid}} = this;\n const borderOpts = border.setContext(this.getContext());\n const axisWidth = border.display ? borderOpts.width : 0;\n if (!axisWidth) {\n return;\n }\n const lastLineWidth = grid.setContext(this.getContext(0)).lineWidth;\n const borderValue = this._borderValue;\n let x1, x2, y1, y2;\n\n if (this.isHorizontal()) {\n x1 = _alignPixel(chart, this.left, axisWidth) - axisWidth / 2;\n x2 = _alignPixel(chart, this.right, lastLineWidth) + lastLineWidth / 2;\n y1 = y2 = borderValue;\n } else {\n y1 = _alignPixel(chart, this.top, axisWidth) - axisWidth / 2;\n y2 = _alignPixel(chart, this.bottom, lastLineWidth) + lastLineWidth / 2;\n x1 = x2 = borderValue;\n }\n ctx.save();\n ctx.lineWidth = borderOpts.width;\n ctx.strokeStyle = borderOpts.color;\n\n ctx.beginPath();\n ctx.moveTo(x1, y1);\n ctx.lineTo(x2, y2);\n ctx.stroke();\n\n ctx.restore();\n }\n\n /**\n\t * @protected\n\t */\n drawLabels(chartArea) {\n const optionTicks = this.options.ticks;\n\n if (!optionTicks.display) {\n return;\n }\n\n const ctx = this.ctx;\n\n const area = this._computeLabelArea();\n if (area) {\n clipArea(ctx, area);\n }\n\n const items = this.getLabelItems(chartArea);\n for (const item of items) {\n const renderTextOptions = item.options;\n const tickFont = item.font;\n const label = item.label;\n const y = item.textOffset;\n renderText(ctx, label, 0, y, tickFont, renderTextOptions);\n }\n\n if (area) {\n unclipArea(ctx);\n }\n }\n\n /**\n\t * @protected\n\t */\n drawTitle() {\n const {ctx, options: {position, title, reverse}} = this;\n\n if (!title.display) {\n return;\n }\n\n const font = toFont(title.font);\n const padding = toPadding(title.padding);\n const align = title.align;\n let offset = font.lineHeight / 2;\n\n if (position === 'bottom' || position === 'center' || isObject(position)) {\n offset += padding.bottom;\n if (isArray(title.text)) {\n offset += font.lineHeight * (title.text.length - 1);\n }\n } else {\n offset += padding.top;\n }\n\n const {titleX, titleY, maxWidth, rotation} = titleArgs(this, offset, position, align);\n\n renderText(ctx, title.text, 0, 0, font, {\n color: title.color,\n maxWidth,\n rotation,\n textAlign: titleAlign(align, position, reverse),\n textBaseline: 'middle',\n translation: [titleX, titleY],\n });\n }\n\n draw(chartArea) {\n if (!this._isVisible()) {\n return;\n }\n\n this.drawBackground();\n this.drawGrid(chartArea);\n this.drawBorder();\n this.drawTitle();\n this.drawLabels(chartArea);\n }\n\n /**\n\t * @return {object[]}\n\t * @private\n\t */\n _layers() {\n const opts = this.options;\n const tz = opts.ticks && opts.ticks.z || 0;\n const gz = valueOrDefault(opts.grid && opts.grid.z, -1);\n const bz = valueOrDefault(opts.border && opts.border.z, 0);\n\n if (!this._isVisible() || this.draw !== Scale.prototype.draw) {\n // backward compatibility: draw has been overridden by custom scale\n return [{\n z: tz,\n draw: (chartArea) => {\n this.draw(chartArea);\n }\n }];\n }\n\n return [{\n z: gz,\n draw: (chartArea) => {\n this.drawBackground();\n this.drawGrid(chartArea);\n this.drawTitle();\n }\n }, {\n z: bz,\n draw: () => {\n this.drawBorder();\n }\n }, {\n z: tz,\n draw: (chartArea) => {\n this.drawLabels(chartArea);\n }\n }];\n }\n\n /**\n\t * Returns visible dataset metas that are attached to this scale\n\t * @param {string} [type] - if specified, also filter by dataset type\n\t * @return {object[]}\n\t */\n getMatchingVisibleMetas(type) {\n const metas = this.chart.getSortedVisibleDatasetMetas();\n const axisID = this.axis + 'AxisID';\n const result = [];\n let i, ilen;\n\n for (i = 0, ilen = metas.length; i < ilen; ++i) {\n const meta = metas[i];\n if (meta[axisID] === this.id && (!type || meta.type === type)) {\n result.push(meta);\n }\n }\n return result;\n }\n\n /**\n\t * @param {number} index\n\t * @return {object}\n\t * @protected\n \t */\n _resolveTickFontOptions(index) {\n const opts = this.options.ticks.setContext(this.getContext(index));\n return toFont(opts.font);\n }\n\n /**\n * @protected\n */\n _maxDigits() {\n const fontSize = this._resolveTickFontOptions(0).lineHeight;\n return (this.isHorizontal() ? this.width : this.height) / fontSize;\n }\n}\n","import {merge} from '../helpers/index.js';\nimport defaults, {overrides} from './core.defaults.js';\n\n/**\n * @typedef {{id: string, defaults: any, overrides?: any, defaultRoutes: any}} IChartComponent\n */\n\nexport default class TypedRegistry {\n constructor(type, scope, override) {\n this.type = type;\n this.scope = scope;\n this.override = override;\n this.items = Object.create(null);\n }\n\n isForType(type) {\n return Object.prototype.isPrototypeOf.call(this.type.prototype, type.prototype);\n }\n\n /**\n\t * @param {IChartComponent} item\n\t * @returns {string} The scope where items defaults were registered to.\n\t */\n register(item) {\n const proto = Object.getPrototypeOf(item);\n let parentScope;\n\n if (isIChartComponent(proto)) {\n // Make sure the parent is registered and note the scope where its defaults are.\n parentScope = this.register(proto);\n }\n\n const items = this.items;\n const id = item.id;\n const scope = this.scope + '.' + id;\n\n if (!id) {\n throw new Error('class does not have id: ' + item);\n }\n\n if (id in items) {\n // already registered\n return scope;\n }\n\n items[id] = item;\n registerDefaults(item, scope, parentScope);\n if (this.override) {\n defaults.override(item.id, item.overrides);\n }\n\n return scope;\n }\n\n /**\n\t * @param {string} id\n\t * @returns {object?}\n\t */\n get(id) {\n return this.items[id];\n }\n\n /**\n\t * @param {IChartComponent} item\n\t */\n unregister(item) {\n const items = this.items;\n const id = item.id;\n const scope = this.scope;\n\n if (id in items) {\n delete items[id];\n }\n\n if (scope && id in defaults[scope]) {\n delete defaults[scope][id];\n if (this.override) {\n delete overrides[id];\n }\n }\n }\n}\n\nfunction registerDefaults(item, scope, parentScope) {\n // Inherit the parent's defaults and keep existing defaults\n const itemDefaults = merge(Object.create(null), [\n parentScope ? defaults.get(parentScope) : {},\n defaults.get(scope),\n item.defaults\n ]);\n\n defaults.set(scope, itemDefaults);\n\n if (item.defaultRoutes) {\n routeDefaults(scope, item.defaultRoutes);\n }\n\n if (item.descriptors) {\n defaults.describe(scope, item.descriptors);\n }\n}\n\nfunction routeDefaults(scope, routes) {\n Object.keys(routes).forEach(property => {\n const propertyParts = property.split('.');\n const sourceName = propertyParts.pop();\n const sourceScope = [scope].concat(propertyParts).join('.');\n const parts = routes[property].split('.');\n const targetName = parts.pop();\n const targetScope = parts.join('.');\n defaults.route(sourceScope, sourceName, targetScope, targetName);\n });\n}\n\nfunction isIChartComponent(proto) {\n return 'id' in proto && 'defaults' in proto;\n}\n","import DatasetController from './core.datasetController.js';\nimport Element from './core.element.js';\nimport Scale from './core.scale.js';\nimport TypedRegistry from './core.typedRegistry.js';\nimport {each, callback as call, _capitalize} from '../helpers/helpers.core.js';\n\n/**\n * Please use the module's default export which provides a singleton instance\n * Note: class is exported for typedoc\n */\nexport class Registry {\n constructor() {\n this.controllers = new TypedRegistry(DatasetController, 'datasets', true);\n this.elements = new TypedRegistry(Element, 'elements');\n this.plugins = new TypedRegistry(Object, 'plugins');\n this.scales = new TypedRegistry(Scale, 'scales');\n // Order is important, Scale has Element in prototype chain,\n // so Scales must be before Elements. Plugins are a fallback, so not listed here.\n this._typedRegistries = [this.controllers, this.scales, this.elements];\n }\n\n /**\n\t * @param {...any} args\n\t */\n add(...args) {\n this._each('register', args);\n }\n\n remove(...args) {\n this._each('unregister', args);\n }\n\n /**\n\t * @param {...typeof DatasetController} args\n\t */\n addControllers(...args) {\n this._each('register', args, this.controllers);\n }\n\n /**\n\t * @param {...typeof Element} args\n\t */\n addElements(...args) {\n this._each('register', args, this.elements);\n }\n\n /**\n\t * @param {...any} args\n\t */\n addPlugins(...args) {\n this._each('register', args, this.plugins);\n }\n\n /**\n\t * @param {...typeof Scale} args\n\t */\n addScales(...args) {\n this._each('register', args, this.scales);\n }\n\n /**\n\t * @param {string} id\n\t * @returns {typeof DatasetController}\n\t */\n getController(id) {\n return this._get(id, this.controllers, 'controller');\n }\n\n /**\n\t * @param {string} id\n\t * @returns {typeof Element}\n\t */\n getElement(id) {\n return this._get(id, this.elements, 'element');\n }\n\n /**\n\t * @param {string} id\n\t * @returns {object}\n\t */\n getPlugin(id) {\n return this._get(id, this.plugins, 'plugin');\n }\n\n /**\n\t * @param {string} id\n\t * @returns {typeof Scale}\n\t */\n getScale(id) {\n return this._get(id, this.scales, 'scale');\n }\n\n /**\n\t * @param {...typeof DatasetController} args\n\t */\n removeControllers(...args) {\n this._each('unregister', args, this.controllers);\n }\n\n /**\n\t * @param {...typeof Element} args\n\t */\n removeElements(...args) {\n this._each('unregister', args, this.elements);\n }\n\n /**\n\t * @param {...any} args\n\t */\n removePlugins(...args) {\n this._each('unregister', args, this.plugins);\n }\n\n /**\n\t * @param {...typeof Scale} args\n\t */\n removeScales(...args) {\n this._each('unregister', args, this.scales);\n }\n\n /**\n\t * @private\n\t */\n _each(method, args, typedRegistry) {\n [...args].forEach(arg => {\n const reg = typedRegistry || this._getRegistryForType(arg);\n if (typedRegistry || reg.isForType(arg) || (reg === this.plugins && arg.id)) {\n this._exec(method, reg, arg);\n } else {\n // Handle loopable args\n // Use case:\n // import * as plugins from './plugins.js';\n // Chart.register(plugins);\n each(arg, item => {\n // If there are mixed types in the loopable, make sure those are\n // registered in correct registry\n // Use case: (treemap exporting controller, elements etc)\n // import * as treemap from 'chartjs-chart-treemap.js';\n // Chart.register(treemap);\n\n const itemReg = typedRegistry || this._getRegistryForType(item);\n this._exec(method, itemReg, item);\n });\n }\n });\n }\n\n /**\n\t * @private\n\t */\n _exec(method, registry, component) {\n const camelMethod = _capitalize(method);\n call(component['before' + camelMethod], [], component); // beforeRegister / beforeUnregister\n registry[method](component);\n call(component['after' + camelMethod], [], component); // afterRegister / afterUnregister\n }\n\n /**\n\t * @private\n\t */\n _getRegistryForType(type) {\n for (let i = 0; i < this._typedRegistries.length; i++) {\n const reg = this._typedRegistries[i];\n if (reg.isForType(type)) {\n return reg;\n }\n }\n // plugins is the fallback registry\n return this.plugins;\n }\n\n /**\n\t * @private\n\t */\n _get(id, typedRegistry, type) {\n const item = typedRegistry.get(id);\n if (item === undefined) {\n throw new Error('\"' + id + '\" is not a registered ' + type + '.');\n }\n return item;\n }\n\n}\n\n// singleton instance\nexport default /* #__PURE__ */ new Registry();\n","import registry from './core.registry.js';\nimport {callback as callCallback, isNullOrUndef, valueOrDefault} from '../helpers/helpers.core.js';\n\n/**\n * @typedef { import('./core.controller.js').default } Chart\n * @typedef { import('../types/index.js').ChartEvent } ChartEvent\n * @typedef { import('../plugins/plugin.tooltip.js').default } Tooltip\n */\n\n/**\n * @callback filterCallback\n * @param {{plugin: object, options: object}} value\n * @param {number} [index]\n * @param {array} [array]\n * @param {object} [thisArg]\n * @return {boolean}\n */\n\n\nexport default class PluginService {\n constructor() {\n this._init = undefined;\n }\n\n /**\n\t * Calls enabled plugins for `chart` on the specified hook and with the given args.\n\t * This method immediately returns as soon as a plugin explicitly returns false. The\n\t * returned value can be used, for instance, to interrupt the current action.\n\t * @param {Chart} chart - The chart instance for which plugins should be called.\n\t * @param {string} hook - The name of the plugin method to call (e.g. 'beforeUpdate').\n\t * @param {object} [args] - Extra arguments to apply to the hook call.\n * @param {filterCallback} [filter] - Filtering function for limiting which plugins are notified\n\t * @returns {boolean} false if any of the plugins return false, else returns true.\n\t */\n notify(chart, hook, args, filter) {\n if (hook === 'beforeInit') {\n this._init = this._createDescriptors(chart, true);\n this._notify(this._init, chart, 'install');\n }\n\n if (this._init === undefined) { // Do not trigger events before install\n return;\n }\n\n const descriptors = filter ? this._descriptors(chart).filter(filter) : this._descriptors(chart);\n const result = this._notify(descriptors, chart, hook, args);\n\n if (hook === 'afterDestroy') {\n this._notify(descriptors, chart, 'stop');\n this._notify(this._init, chart, 'uninstall');\n this._init = undefined; // Do not trigger events after uninstall\n }\n return result;\n }\n\n /**\n\t * @private\n\t */\n _notify(descriptors, chart, hook, args) {\n args = args || {};\n for (const descriptor of descriptors) {\n const plugin = descriptor.plugin;\n const method = plugin[hook];\n const params = [chart, args, descriptor.options];\n if (callCallback(method, params, plugin) === false && args.cancelable) {\n return false;\n }\n }\n\n return true;\n }\n\n invalidate() {\n // When plugins are registered, there is the possibility of a double\n // invalidate situation. In this case, we only want to invalidate once.\n // If we invalidate multiple times, the `_oldCache` is lost and all of the\n // plugins are restarted without being correctly stopped.\n // See https://github.com/chartjs/Chart.js/issues/8147\n if (!isNullOrUndef(this._cache)) {\n this._oldCache = this._cache;\n this._cache = undefined;\n }\n }\n\n /**\n\t * @param {Chart} chart\n\t * @private\n\t */\n _descriptors(chart) {\n if (this._cache) {\n return this._cache;\n }\n\n const descriptors = this._cache = this._createDescriptors(chart);\n\n this._notifyStateChanges(chart);\n\n return descriptors;\n }\n\n _createDescriptors(chart, all) {\n const config = chart && chart.config;\n const options = valueOrDefault(config.options && config.options.plugins, {});\n const plugins = allPlugins(config);\n // options === false => all plugins are disabled\n return options === false && !all ? [] : createDescriptors(chart, plugins, options, all);\n }\n\n /**\n\t * @param {Chart} chart\n\t * @private\n\t */\n _notifyStateChanges(chart) {\n const previousDescriptors = this._oldCache || [];\n const descriptors = this._cache;\n const diff = (a, b) => a.filter(x => !b.some(y => x.plugin.id === y.plugin.id));\n this._notify(diff(previousDescriptors, descriptors), chart, 'stop');\n this._notify(diff(descriptors, previousDescriptors), chart, 'start');\n }\n}\n\n/**\n * @param {import('./core.config.js').default} config\n */\nfunction allPlugins(config) {\n const localIds = {};\n const plugins = [];\n const keys = Object.keys(registry.plugins.items);\n for (let i = 0; i < keys.length; i++) {\n plugins.push(registry.getPlugin(keys[i]));\n }\n\n const local = config.plugins || [];\n for (let i = 0; i < local.length; i++) {\n const plugin = local[i];\n\n if (plugins.indexOf(plugin) === -1) {\n plugins.push(plugin);\n localIds[plugin.id] = true;\n }\n }\n\n return {plugins, localIds};\n}\n\nfunction getOpts(options, all) {\n if (!all && options === false) {\n return null;\n }\n if (options === true) {\n return {};\n }\n return options;\n}\n\nfunction createDescriptors(chart, {plugins, localIds}, options, all) {\n const result = [];\n const context = chart.getContext();\n\n for (const plugin of plugins) {\n const id = plugin.id;\n const opts = getOpts(options[id], all);\n if (opts === null) {\n continue;\n }\n result.push({\n plugin,\n options: pluginOpts(chart.config, {plugin, local: localIds[id]}, opts, context)\n });\n }\n\n return result;\n}\n\nfunction pluginOpts(config, {plugin, local}, opts, context) {\n const keys = config.pluginScopeKeys(plugin);\n const scopes = config.getOptionScopes(opts, keys);\n if (local && plugin.defaults) {\n // make sure plugin defaults are in scopes for local (not registered) plugins\n scopes.push(plugin.defaults);\n }\n return config.createResolver(scopes, context, [''], {\n // These are just defaults that plugins can override\n scriptable: false,\n indexable: false,\n allKeys: true\n });\n}\n","import defaults, {overrides, descriptors} from './core.defaults.js';\nimport {mergeIf, resolveObjectKey, isArray, isFunction, valueOrDefault, isObject} from '../helpers/helpers.core.js';\nimport {_attachContext, _createResolver, _descriptors} from '../helpers/helpers.config.js';\n\nexport function getIndexAxis(type, options) {\n const datasetDefaults = defaults.datasets[type] || {};\n const datasetOptions = (options.datasets || {})[type] || {};\n return datasetOptions.indexAxis || options.indexAxis || datasetDefaults.indexAxis || 'x';\n}\n\nfunction getAxisFromDefaultScaleID(id, indexAxis) {\n let axis = id;\n if (id === '_index_') {\n axis = indexAxis;\n } else if (id === '_value_') {\n axis = indexAxis === 'x' ? 'y' : 'x';\n }\n return axis;\n}\n\nfunction getDefaultScaleIDFromAxis(axis, indexAxis) {\n return axis === indexAxis ? '_index_' : '_value_';\n}\n\nfunction idMatchesAxis(id) {\n if (id === 'x' || id === 'y' || id === 'r') {\n return id;\n }\n}\n\nfunction axisFromPosition(position) {\n if (position === 'top' || position === 'bottom') {\n return 'x';\n }\n if (position === 'left' || position === 'right') {\n return 'y';\n }\n}\n\nexport function determineAxis(id, ...scaleOptions) {\n if (idMatchesAxis(id)) {\n return id;\n }\n for (const opts of scaleOptions) {\n const axis = opts.axis\n || axisFromPosition(opts.position)\n || id.length > 1 && idMatchesAxis(id[0].toLowerCase());\n if (axis) {\n return axis;\n }\n }\n throw new Error(`Cannot determine type of '${id}' axis. Please provide 'axis' or 'position' option.`);\n}\n\nfunction getAxisFromDataset(id, axis, dataset) {\n if (dataset[axis + 'AxisID'] === id) {\n return {axis};\n }\n}\n\nfunction retrieveAxisFromDatasets(id, config) {\n if (config.data && config.data.datasets) {\n const boundDs = config.data.datasets.filter((d) => d.xAxisID === id || d.yAxisID === id);\n if (boundDs.length) {\n return getAxisFromDataset(id, 'x', boundDs[0]) || getAxisFromDataset(id, 'y', boundDs[0]);\n }\n }\n return {};\n}\n\nfunction mergeScaleConfig(config, options) {\n const chartDefaults = overrides[config.type] || {scales: {}};\n const configScales = options.scales || {};\n const chartIndexAxis = getIndexAxis(config.type, options);\n const scales = Object.create(null);\n\n // First figure out first scale id's per axis.\n Object.keys(configScales).forEach(id => {\n const scaleConf = configScales[id];\n if (!isObject(scaleConf)) {\n return console.error(`Invalid scale configuration for scale: ${id}`);\n }\n if (scaleConf._proxy) {\n return console.warn(`Ignoring resolver passed as options for scale: ${id}`);\n }\n const axis = determineAxis(id, scaleConf, retrieveAxisFromDatasets(id, config), defaults.scales[scaleConf.type]);\n const defaultId = getDefaultScaleIDFromAxis(axis, chartIndexAxis);\n const defaultScaleOptions = chartDefaults.scales || {};\n scales[id] = mergeIf(Object.create(null), [{axis}, scaleConf, defaultScaleOptions[axis], defaultScaleOptions[defaultId]]);\n });\n\n // Then merge dataset defaults to scale configs\n config.data.datasets.forEach(dataset => {\n const type = dataset.type || config.type;\n const indexAxis = dataset.indexAxis || getIndexAxis(type, options);\n const datasetDefaults = overrides[type] || {};\n const defaultScaleOptions = datasetDefaults.scales || {};\n Object.keys(defaultScaleOptions).forEach(defaultID => {\n const axis = getAxisFromDefaultScaleID(defaultID, indexAxis);\n const id = dataset[axis + 'AxisID'] || axis;\n scales[id] = scales[id] || Object.create(null);\n mergeIf(scales[id], [{axis}, configScales[id], defaultScaleOptions[defaultID]]);\n });\n });\n\n // apply scale defaults, if not overridden by dataset defaults\n Object.keys(scales).forEach(key => {\n const scale = scales[key];\n mergeIf(scale, [defaults.scales[scale.type], defaults.scale]);\n });\n\n return scales;\n}\n\nfunction initOptions(config) {\n const options = config.options || (config.options = {});\n\n options.plugins = valueOrDefault(options.plugins, {});\n options.scales = mergeScaleConfig(config, options);\n}\n\nfunction initData(data) {\n data = data || {};\n data.datasets = data.datasets || [];\n data.labels = data.labels || [];\n return data;\n}\n\nfunction initConfig(config) {\n config = config || {};\n config.data = initData(config.data);\n\n initOptions(config);\n\n return config;\n}\n\nconst keyCache = new Map();\nconst keysCached = new Set();\n\nfunction cachedKeys(cacheKey, generate) {\n let keys = keyCache.get(cacheKey);\n if (!keys) {\n keys = generate();\n keyCache.set(cacheKey, keys);\n keysCached.add(keys);\n }\n return keys;\n}\n\nconst addIfFound = (set, obj, key) => {\n const opts = resolveObjectKey(obj, key);\n if (opts !== undefined) {\n set.add(opts);\n }\n};\n\nexport default class Config {\n constructor(config) {\n this._config = initConfig(config);\n this._scopeCache = new Map();\n this._resolverCache = new Map();\n }\n\n get platform() {\n return this._config.platform;\n }\n\n get type() {\n return this._config.type;\n }\n\n set type(type) {\n this._config.type = type;\n }\n\n get data() {\n return this._config.data;\n }\n\n set data(data) {\n this._config.data = initData(data);\n }\n\n get options() {\n return this._config.options;\n }\n\n set options(options) {\n this._config.options = options;\n }\n\n get plugins() {\n return this._config.plugins;\n }\n\n update() {\n const config = this._config;\n this.clearCache();\n initOptions(config);\n }\n\n clearCache() {\n this._scopeCache.clear();\n this._resolverCache.clear();\n }\n\n /**\n * Returns the option scope keys for resolving dataset options.\n * These keys do not include the dataset itself, because it is not under options.\n * @param {string} datasetType\n * @return {string[][]}\n */\n datasetScopeKeys(datasetType) {\n return cachedKeys(datasetType,\n () => [[\n `datasets.${datasetType}`,\n ''\n ]]);\n }\n\n /**\n * Returns the option scope keys for resolving dataset animation options.\n * These keys do not include the dataset itself, because it is not under options.\n * @param {string} datasetType\n * @param {string} transition\n * @return {string[][]}\n */\n datasetAnimationScopeKeys(datasetType, transition) {\n return cachedKeys(`${datasetType}.transition.${transition}`,\n () => [\n [\n `datasets.${datasetType}.transitions.${transition}`,\n `transitions.${transition}`,\n ],\n // The following are used for looking up the `animations` and `animation` keys\n [\n `datasets.${datasetType}`,\n ''\n ]\n ]);\n }\n\n /**\n * Returns the options scope keys for resolving element options that belong\n * to an dataset. These keys do not include the dataset itself, because it\n * is not under options.\n * @param {string} datasetType\n * @param {string} elementType\n * @return {string[][]}\n */\n datasetElementScopeKeys(datasetType, elementType) {\n return cachedKeys(`${datasetType}-${elementType}`,\n () => [[\n `datasets.${datasetType}.elements.${elementType}`,\n `datasets.${datasetType}`,\n `elements.${elementType}`,\n ''\n ]]);\n }\n\n /**\n * Returns the options scope keys for resolving plugin options.\n * @param {{id: string, additionalOptionScopes?: string[]}} plugin\n * @return {string[][]}\n */\n pluginScopeKeys(plugin) {\n const id = plugin.id;\n const type = this.type;\n return cachedKeys(`${type}-plugin-${id}`,\n () => [[\n `plugins.${id}`,\n ...plugin.additionalOptionScopes || [],\n ]]);\n }\n\n /**\n * @private\n */\n _cachedScopes(mainScope, resetCache) {\n const _scopeCache = this._scopeCache;\n let cache = _scopeCache.get(mainScope);\n if (!cache || resetCache) {\n cache = new Map();\n _scopeCache.set(mainScope, cache);\n }\n return cache;\n }\n\n /**\n * Resolves the objects from options and defaults for option value resolution.\n * @param {object} mainScope - The main scope object for options\n * @param {string[][]} keyLists - The arrays of keys in resolution order\n * @param {boolean} [resetCache] - reset the cache for this mainScope\n */\n getOptionScopes(mainScope, keyLists, resetCache) {\n const {options, type} = this;\n const cache = this._cachedScopes(mainScope, resetCache);\n const cached = cache.get(keyLists);\n if (cached) {\n return cached;\n }\n\n const scopes = new Set();\n\n keyLists.forEach(keys => {\n if (mainScope) {\n scopes.add(mainScope);\n keys.forEach(key => addIfFound(scopes, mainScope, key));\n }\n keys.forEach(key => addIfFound(scopes, options, key));\n keys.forEach(key => addIfFound(scopes, overrides[type] || {}, key));\n keys.forEach(key => addIfFound(scopes, defaults, key));\n keys.forEach(key => addIfFound(scopes, descriptors, key));\n });\n\n const array = Array.from(scopes);\n if (array.length === 0) {\n array.push(Object.create(null));\n }\n if (keysCached.has(keyLists)) {\n cache.set(keyLists, array);\n }\n return array;\n }\n\n /**\n * Returns the option scopes for resolving chart options\n * @return {object[]}\n */\n chartOptionScopes() {\n const {options, type} = this;\n\n return [\n options,\n overrides[type] || {},\n defaults.datasets[type] || {}, // https://github.com/chartjs/Chart.js/issues/8531\n {type},\n defaults,\n descriptors\n ];\n }\n\n /**\n * @param {object[]} scopes\n * @param {string[]} names\n * @param {function|object} context\n * @param {string[]} [prefixes]\n * @return {object}\n */\n resolveNamedOptions(scopes, names, context, prefixes = ['']) {\n const result = {$shared: true};\n const {resolver, subPrefixes} = getResolver(this._resolverCache, scopes, prefixes);\n let options = resolver;\n if (needContext(resolver, names)) {\n result.$shared = false;\n context = isFunction(context) ? context() : context;\n // subResolver is passed to scriptable options. It should not resolve to hover options.\n const subResolver = this.createResolver(scopes, context, subPrefixes);\n options = _attachContext(resolver, context, subResolver);\n }\n\n for (const prop of names) {\n result[prop] = options[prop];\n }\n return result;\n }\n\n /**\n * @param {object[]} scopes\n * @param {object} [context]\n * @param {string[]} [prefixes]\n * @param {{scriptable: boolean, indexable: boolean, allKeys?: boolean}} [descriptorDefaults]\n */\n createResolver(scopes, context, prefixes = [''], descriptorDefaults) {\n const {resolver} = getResolver(this._resolverCache, scopes, prefixes);\n return isObject(context)\n ? _attachContext(resolver, context, undefined, descriptorDefaults)\n : resolver;\n }\n}\n\nfunction getResolver(resolverCache, scopes, prefixes) {\n let cache = resolverCache.get(scopes);\n if (!cache) {\n cache = new Map();\n resolverCache.set(scopes, cache);\n }\n const cacheKey = prefixes.join();\n let cached = cache.get(cacheKey);\n if (!cached) {\n const resolver = _createResolver(scopes, prefixes);\n cached = {\n resolver,\n subPrefixes: prefixes.filter(p => !p.toLowerCase().includes('hover'))\n };\n cache.set(cacheKey, cached);\n }\n return cached;\n}\n\nconst hasFunction = value => isObject(value)\n && Object.getOwnPropertyNames(value).some((key) => isFunction(value[key]));\n\nfunction needContext(proxy, names) {\n const {isScriptable, isIndexable} = _descriptors(proxy);\n\n for (const prop of names) {\n const scriptable = isScriptable(prop);\n const indexable = isIndexable(prop);\n const value = (indexable || scriptable) && proxy[prop];\n if ((scriptable && (isFunction(value) || hasFunction(value)))\n || (indexable && isArray(value))) {\n return true;\n }\n }\n return false;\n}\n","import animator from './core.animator.js';\nimport defaults, {overrides} from './core.defaults.js';\nimport Interaction from './core.interaction.js';\nimport layouts from './core.layouts.js';\nimport {_detectPlatform} from '../platform/index.js';\nimport PluginService from './core.plugins.js';\nimport registry from './core.registry.js';\nimport Config, {determineAxis, getIndexAxis} from './core.config.js';\nimport {each, callback as callCallback, uid, valueOrDefault, _elementsEqual, isNullOrUndef, setsEqual, defined, isFunction, _isClickEvent} from '../helpers/helpers.core.js';\nimport {clearCanvas, clipArea, createContext, unclipArea, _isPointInArea, _isDomSupported, retinaScale, getDatasetClipArea} from '../helpers/index.js';\n// @ts-ignore\nimport {version} from '../../package.json';\nimport {debounce} from '../helpers/helpers.extras.js';\n\n/**\n * @typedef { import('../types/index.js').ChartEvent } ChartEvent\n * @typedef { import('../types/index.js').Point } Point\n */\n\nconst KNOWN_POSITIONS = ['top', 'bottom', 'left', 'right', 'chartArea'];\nfunction positionIsHorizontal(position, axis) {\n return position === 'top' || position === 'bottom' || (KNOWN_POSITIONS.indexOf(position) === -1 && axis === 'x');\n}\n\nfunction compare2Level(l1, l2) {\n return function(a, b) {\n return a[l1] === b[l1]\n ? a[l2] - b[l2]\n : a[l1] - b[l1];\n };\n}\n\nfunction onAnimationsComplete(context) {\n const chart = context.chart;\n const animationOptions = chart.options.animation;\n\n chart.notifyPlugins('afterRender');\n callCallback(animationOptions && animationOptions.onComplete, [context], chart);\n}\n\nfunction onAnimationProgress(context) {\n const chart = context.chart;\n const animationOptions = chart.options.animation;\n callCallback(animationOptions && animationOptions.onProgress, [context], chart);\n}\n\n/**\n * Chart.js can take a string id of a canvas element, a 2d context, or a canvas element itself.\n * Attempt to unwrap the item passed into the chart constructor so that it is a canvas element (if possible).\n */\nfunction getCanvas(item) {\n if (_isDomSupported() && typeof item === 'string') {\n item = document.getElementById(item);\n } else if (item && item.length) {\n // Support for array based queries (such as jQuery)\n item = item[0];\n }\n\n if (item && item.canvas) {\n // Support for any object associated to a canvas (including a context2d)\n item = item.canvas;\n }\n return item;\n}\n\nconst instances = {};\nconst getChart = (key) => {\n const canvas = getCanvas(key);\n return Object.values(instances).filter((c) => c.canvas === canvas).pop();\n};\n\nfunction moveNumericKeys(obj, start, move) {\n const keys = Object.keys(obj);\n for (const key of keys) {\n const intKey = +key;\n if (intKey >= start) {\n const value = obj[key];\n delete obj[key];\n if (move > 0 || intKey > start) {\n obj[intKey + move] = value;\n }\n }\n }\n}\n\n/**\n * @param {ChartEvent} e\n * @param {ChartEvent|null} lastEvent\n * @param {boolean} inChartArea\n * @param {boolean} isClick\n * @returns {ChartEvent|null}\n */\nfunction determineLastEvent(e, lastEvent, inChartArea, isClick) {\n if (!inChartArea || e.type === 'mouseout') {\n return null;\n }\n if (isClick) {\n return lastEvent;\n }\n return e;\n}\n\nclass Chart {\n\n static defaults = defaults;\n static instances = instances;\n static overrides = overrides;\n static registry = registry;\n static version = version;\n static getChart = getChart;\n\n static register(...items) {\n registry.add(...items);\n invalidatePlugins();\n }\n\n static unregister(...items) {\n registry.remove(...items);\n invalidatePlugins();\n }\n\n // eslint-disable-next-line max-statements\n constructor(item, userConfig) {\n const config = this.config = new Config(userConfig);\n const initialCanvas = getCanvas(item);\n const existingChart = getChart(initialCanvas);\n if (existingChart) {\n throw new Error(\n 'Canvas is already in use. Chart with ID \\'' + existingChart.id + '\\'' +\n\t\t\t\t' must be destroyed before the canvas with ID \\'' + existingChart.canvas.id + '\\' can be reused.'\n );\n }\n\n const options = config.createResolver(config.chartOptionScopes(), this.getContext());\n\n this.platform = new (config.platform || _detectPlatform(initialCanvas))();\n this.platform.updateConfig(config);\n\n const context = this.platform.acquireContext(initialCanvas, options.aspectRatio);\n const canvas = context && context.canvas;\n const height = canvas && canvas.height;\n const width = canvas && canvas.width;\n\n this.id = uid();\n this.ctx = context;\n this.canvas = canvas;\n this.width = width;\n this.height = height;\n this._options = options;\n // Store the previously used aspect ratio to determine if a resize\n // is needed during updates. Do this after _options is set since\n // aspectRatio uses a getter\n this._aspectRatio = this.aspectRatio;\n this._layers = [];\n this._metasets = [];\n this._stacks = undefined;\n this.boxes = [];\n this.currentDevicePixelRatio = undefined;\n this.chartArea = undefined;\n this._active = [];\n this._lastEvent = undefined;\n this._listeners = {};\n /** @type {?{attach?: function, detach?: function, resize?: function}} */\n this._responsiveListeners = undefined;\n this._sortedMetasets = [];\n this.scales = {};\n this._plugins = new PluginService();\n this.$proxies = {};\n this._hiddenIndices = {};\n this.attached = false;\n this._animationsDisabled = undefined;\n this.$context = undefined;\n this._doResize = debounce(mode => this.update(mode), options.resizeDelay || 0);\n this._dataChanges = [];\n\n // Add the chart instance to the global namespace\n instances[this.id] = this;\n\n if (!context || !canvas) {\n // The given item is not a compatible context2d element, let's return before finalizing\n // the chart initialization but after setting basic chart / controller properties that\n // can help to figure out that the chart is not valid (e.g chart.canvas !== null);\n // https://github.com/chartjs/Chart.js/issues/2807\n console.error(\"Failed to create chart: can't acquire context from the given item\");\n return;\n }\n\n animator.listen(this, 'complete', onAnimationsComplete);\n animator.listen(this, 'progress', onAnimationProgress);\n\n this._initialize();\n if (this.attached) {\n this.update();\n }\n }\n\n get aspectRatio() {\n const {options: {aspectRatio, maintainAspectRatio}, width, height, _aspectRatio} = this;\n if (!isNullOrUndef(aspectRatio)) {\n // If aspectRatio is defined in options, use that.\n return aspectRatio;\n }\n\n if (maintainAspectRatio && _aspectRatio) {\n // If maintainAspectRatio is truthly and we had previously determined _aspectRatio, use that\n return _aspectRatio;\n }\n\n // Calculate\n return height ? width / height : null;\n }\n\n get data() {\n return this.config.data;\n }\n\n set data(data) {\n this.config.data = data;\n }\n\n get options() {\n return this._options;\n }\n\n set options(options) {\n this.config.options = options;\n }\n\n get registry() {\n return registry;\n }\n\n /**\n\t * @private\n\t */\n _initialize() {\n // Before init plugin notification\n this.notifyPlugins('beforeInit');\n\n if (this.options.responsive) {\n this.resize();\n } else {\n retinaScale(this, this.options.devicePixelRatio);\n }\n\n this.bindEvents();\n\n // After init plugin notification\n this.notifyPlugins('afterInit');\n\n return this;\n }\n\n clear() {\n clearCanvas(this.canvas, this.ctx);\n return this;\n }\n\n stop() {\n animator.stop(this);\n return this;\n }\n\n /**\n\t * Resize the chart to its container or to explicit dimensions.\n\t * @param {number} [width]\n\t * @param {number} [height]\n\t */\n resize(width, height) {\n if (!animator.running(this)) {\n this._resize(width, height);\n } else {\n this._resizeBeforeDraw = {width, height};\n }\n }\n\n _resize(width, height) {\n const options = this.options;\n const canvas = this.canvas;\n const aspectRatio = options.maintainAspectRatio && this.aspectRatio;\n const newSize = this.platform.getMaximumSize(canvas, width, height, aspectRatio);\n const newRatio = options.devicePixelRatio || this.platform.getDevicePixelRatio();\n const mode = this.width ? 'resize' : 'attach';\n\n this.width = newSize.width;\n this.height = newSize.height;\n this._aspectRatio = this.aspectRatio;\n if (!retinaScale(this, newRatio, true)) {\n return;\n }\n\n this.notifyPlugins('resize', {size: newSize});\n\n callCallback(options.onResize, [this, newSize], this);\n\n if (this.attached) {\n if (this._doResize(mode)) {\n // The resize update is delayed, only draw without updating.\n this.render();\n }\n }\n }\n\n ensureScalesHaveIDs() {\n const options = this.options;\n const scalesOptions = options.scales || {};\n\n each(scalesOptions, (axisOptions, axisID) => {\n axisOptions.id = axisID;\n });\n }\n\n /**\n\t * Builds a map of scale ID to scale object for future lookup.\n\t */\n buildOrUpdateScales() {\n const options = this.options;\n const scaleOpts = options.scales;\n const scales = this.scales;\n const updated = Object.keys(scales).reduce((obj, id) => {\n obj[id] = false;\n return obj;\n }, {});\n let items = [];\n\n if (scaleOpts) {\n items = items.concat(\n Object.keys(scaleOpts).map((id) => {\n const scaleOptions = scaleOpts[id];\n const axis = determineAxis(id, scaleOptions);\n const isRadial = axis === 'r';\n const isHorizontal = axis === 'x';\n return {\n options: scaleOptions,\n dposition: isRadial ? 'chartArea' : isHorizontal ? 'bottom' : 'left',\n dtype: isRadial ? 'radialLinear' : isHorizontal ? 'category' : 'linear'\n };\n })\n );\n }\n\n each(items, (item) => {\n const scaleOptions = item.options;\n const id = scaleOptions.id;\n const axis = determineAxis(id, scaleOptions);\n const scaleType = valueOrDefault(scaleOptions.type, item.dtype);\n\n if (scaleOptions.position === undefined || positionIsHorizontal(scaleOptions.position, axis) !== positionIsHorizontal(item.dposition)) {\n scaleOptions.position = item.dposition;\n }\n\n updated[id] = true;\n let scale = null;\n if (id in scales && scales[id].type === scaleType) {\n scale = scales[id];\n } else {\n const scaleClass = registry.getScale(scaleType);\n scale = new scaleClass({\n id,\n type: scaleType,\n ctx: this.ctx,\n chart: this\n });\n scales[scale.id] = scale;\n }\n\n scale.init(scaleOptions, options);\n });\n // clear up discarded scales\n each(updated, (hasUpdated, id) => {\n if (!hasUpdated) {\n delete scales[id];\n }\n });\n\n each(scales, (scale) => {\n layouts.configure(this, scale, scale.options);\n layouts.addBox(this, scale);\n });\n }\n\n /**\n\t * @private\n\t */\n _updateMetasets() {\n const metasets = this._metasets;\n const numData = this.data.datasets.length;\n const numMeta = metasets.length;\n\n metasets.sort((a, b) => a.index - b.index);\n if (numMeta > numData) {\n for (let i = numData; i < numMeta; ++i) {\n this._destroyDatasetMeta(i);\n }\n metasets.splice(numData, numMeta - numData);\n }\n this._sortedMetasets = metasets.slice(0).sort(compare2Level('order', 'index'));\n }\n\n /**\n\t * @private\n\t */\n _removeUnreferencedMetasets() {\n const {_metasets: metasets, data: {datasets}} = this;\n if (metasets.length > datasets.length) {\n delete this._stacks;\n }\n metasets.forEach((meta, index) => {\n if (datasets.filter(x => x === meta._dataset).length === 0) {\n this._destroyDatasetMeta(index);\n }\n });\n }\n\n buildOrUpdateControllers() {\n const newControllers = [];\n const datasets = this.data.datasets;\n let i, ilen;\n\n this._removeUnreferencedMetasets();\n\n for (i = 0, ilen = datasets.length; i < ilen; i++) {\n const dataset = datasets[i];\n let meta = this.getDatasetMeta(i);\n const type = dataset.type || this.config.type;\n\n if (meta.type && meta.type !== type) {\n this._destroyDatasetMeta(i);\n meta = this.getDatasetMeta(i);\n }\n meta.type = type;\n meta.indexAxis = dataset.indexAxis || getIndexAxis(type, this.options);\n meta.order = dataset.order || 0;\n meta.index = i;\n meta.label = '' + dataset.label;\n meta.visible = this.isDatasetVisible(i);\n\n if (meta.controller) {\n meta.controller.updateIndex(i);\n meta.controller.linkScales();\n } else {\n const ControllerClass = registry.getController(type);\n const {datasetElementType, dataElementType} = defaults.datasets[type];\n Object.assign(ControllerClass, {\n dataElementType: registry.getElement(dataElementType),\n datasetElementType: datasetElementType && registry.getElement(datasetElementType)\n });\n meta.controller = new ControllerClass(this, i);\n newControllers.push(meta.controller);\n }\n }\n\n this._updateMetasets();\n return newControllers;\n }\n\n /**\n\t * Reset the elements of all datasets\n\t * @private\n\t */\n _resetElements() {\n each(this.data.datasets, (dataset, datasetIndex) => {\n this.getDatasetMeta(datasetIndex).controller.reset();\n }, this);\n }\n\n /**\n\t* Resets the chart back to its state before the initial animation\n\t*/\n reset() {\n this._resetElements();\n this.notifyPlugins('reset');\n }\n\n update(mode) {\n const config = this.config;\n\n config.update();\n const options = this._options = config.createResolver(config.chartOptionScopes(), this.getContext());\n const animsDisabled = this._animationsDisabled = !options.animation;\n\n this._updateScales();\n this._checkEventBindings();\n this._updateHiddenIndices();\n\n // plugins options references might have change, let's invalidate the cache\n // https://github.com/chartjs/Chart.js/issues/5111#issuecomment-355934167\n this._plugins.invalidate();\n\n if (this.notifyPlugins('beforeUpdate', {mode, cancelable: true}) === false) {\n return;\n }\n\n // Make sure dataset controllers are updated and new controllers are reset\n const newControllers = this.buildOrUpdateControllers();\n\n this.notifyPlugins('beforeElementsUpdate');\n\n // Make sure all dataset controllers have correct meta data counts\n let minPadding = 0;\n for (let i = 0, ilen = this.data.datasets.length; i < ilen; i++) {\n const {controller} = this.getDatasetMeta(i);\n const reset = !animsDisabled && newControllers.indexOf(controller) === -1;\n // New controllers will be reset after the layout pass, so we only want to modify\n // elements added to new datasets\n controller.buildOrUpdateElements(reset);\n minPadding = Math.max(+controller.getMaxOverflow(), minPadding);\n }\n minPadding = this._minPadding = options.layout.autoPadding ? minPadding : 0;\n this._updateLayout(minPadding);\n\n // Only reset the controllers if we have animations\n if (!animsDisabled) {\n // Can only reset the new controllers after the scales have been updated\n // Reset is done to get the starting point for the initial animation\n each(newControllers, (controller) => {\n controller.reset();\n });\n }\n\n this._updateDatasets(mode);\n\n // Do this before render so that any plugins that need final scale updates can use it\n this.notifyPlugins('afterUpdate', {mode});\n\n this._layers.sort(compare2Level('z', '_idx'));\n\n // Replay last event from before update, or set hover styles on active elements\n const {_active, _lastEvent} = this;\n if (_lastEvent) {\n this._eventHandler(_lastEvent, true);\n } else if (_active.length) {\n this._updateHoverStyles(_active, _active, true);\n }\n\n this.render();\n }\n\n /**\n * @private\n */\n _updateScales() {\n each(this.scales, (scale) => {\n layouts.removeBox(this, scale);\n });\n\n this.ensureScalesHaveIDs();\n this.buildOrUpdateScales();\n }\n\n /**\n * @private\n */\n _checkEventBindings() {\n const options = this.options;\n const existingEvents = new Set(Object.keys(this._listeners));\n const newEvents = new Set(options.events);\n\n if (!setsEqual(existingEvents, newEvents) || !!this._responsiveListeners !== options.responsive) {\n // The configured events have changed. Rebind.\n this.unbindEvents();\n this.bindEvents();\n }\n }\n\n /**\n * @private\n */\n _updateHiddenIndices() {\n const {_hiddenIndices} = this;\n const changes = this._getUniformDataChanges() || [];\n for (const {method, start, count} of changes) {\n const move = method === '_removeElements' ? -count : count;\n moveNumericKeys(_hiddenIndices, start, move);\n }\n }\n\n /**\n * @private\n */\n _getUniformDataChanges() {\n const _dataChanges = this._dataChanges;\n if (!_dataChanges || !_dataChanges.length) {\n return;\n }\n\n this._dataChanges = [];\n const datasetCount = this.data.datasets.length;\n const makeSet = (idx) => new Set(\n _dataChanges\n .filter(c => c[0] === idx)\n .map((c, i) => i + ',' + c.splice(1).join(','))\n );\n\n const changeSet = makeSet(0);\n for (let i = 1; i < datasetCount; i++) {\n if (!setsEqual(changeSet, makeSet(i))) {\n return;\n }\n }\n return Array.from(changeSet)\n .map(c => c.split(','))\n .map(a => ({method: a[1], start: +a[2], count: +a[3]}));\n }\n\n /**\n\t * Updates the chart layout unless a plugin returns `false` to the `beforeLayout`\n\t * hook, in which case, plugins will not be called on `afterLayout`.\n\t * @private\n\t */\n _updateLayout(minPadding) {\n if (this.notifyPlugins('beforeLayout', {cancelable: true}) === false) {\n return;\n }\n\n layouts.update(this, this.width, this.height, minPadding);\n\n const area = this.chartArea;\n const noArea = area.width <= 0 || area.height <= 0;\n\n this._layers = [];\n each(this.boxes, (box) => {\n if (noArea && box.position === 'chartArea') {\n // Skip drawing and configuring chartArea boxes when chartArea is zero or negative\n return;\n }\n\n // configure is called twice, once in core.scale.update and once here.\n // Here the boxes are fully updated and at their final positions.\n if (box.configure) {\n box.configure();\n }\n this._layers.push(...box._layers());\n }, this);\n\n this._layers.forEach((item, index) => {\n item._idx = index;\n });\n\n this.notifyPlugins('afterLayout');\n }\n\n /**\n\t * Updates all datasets unless a plugin returns `false` to the `beforeDatasetsUpdate`\n\t * hook, in which case, plugins will not be called on `afterDatasetsUpdate`.\n\t * @private\n\t */\n _updateDatasets(mode) {\n if (this.notifyPlugins('beforeDatasetsUpdate', {mode, cancelable: true}) === false) {\n return;\n }\n\n for (let i = 0, ilen = this.data.datasets.length; i < ilen; ++i) {\n this.getDatasetMeta(i).controller.configure();\n }\n\n for (let i = 0, ilen = this.data.datasets.length; i < ilen; ++i) {\n this._updateDataset(i, isFunction(mode) ? mode({datasetIndex: i}) : mode);\n }\n\n this.notifyPlugins('afterDatasetsUpdate', {mode});\n }\n\n /**\n\t * Updates dataset at index unless a plugin returns `false` to the `beforeDatasetUpdate`\n\t * hook, in which case, plugins will not be called on `afterDatasetUpdate`.\n\t * @private\n\t */\n _updateDataset(index, mode) {\n const meta = this.getDatasetMeta(index);\n const args = {meta, index, mode, cancelable: true};\n\n if (this.notifyPlugins('beforeDatasetUpdate', args) === false) {\n return;\n }\n\n meta.controller._update(mode);\n\n args.cancelable = false;\n this.notifyPlugins('afterDatasetUpdate', args);\n }\n\n render() {\n if (this.notifyPlugins('beforeRender', {cancelable: true}) === false) {\n return;\n }\n\n if (animator.has(this)) {\n if (this.attached && !animator.running(this)) {\n animator.start(this);\n }\n } else {\n this.draw();\n onAnimationsComplete({chart: this});\n }\n }\n\n draw() {\n let i;\n if (this._resizeBeforeDraw) {\n const {width, height} = this._resizeBeforeDraw;\n // Unset pending resize request now to avoid possible recursion within _resize\n this._resizeBeforeDraw = null;\n this._resize(width, height);\n }\n this.clear();\n\n if (this.width <= 0 || this.height <= 0) {\n return;\n }\n\n if (this.notifyPlugins('beforeDraw', {cancelable: true}) === false) {\n return;\n }\n\n // Because of plugin hooks (before/afterDatasetsDraw), datasets can't\n // currently be part of layers. Instead, we draw\n // layers <= 0 before(default, backward compat), and the rest after\n const layers = this._layers;\n for (i = 0; i < layers.length && layers[i].z <= 0; ++i) {\n layers[i].draw(this.chartArea);\n }\n\n this._drawDatasets();\n\n // Rest of layers\n for (; i < layers.length; ++i) {\n layers[i].draw(this.chartArea);\n }\n\n this.notifyPlugins('afterDraw');\n }\n\n /**\n\t * @private\n\t */\n _getSortedDatasetMetas(filterVisible) {\n const metasets = this._sortedMetasets;\n const result = [];\n let i, ilen;\n\n for (i = 0, ilen = metasets.length; i < ilen; ++i) {\n const meta = metasets[i];\n if (!filterVisible || meta.visible) {\n result.push(meta);\n }\n }\n\n return result;\n }\n\n /**\n\t * Gets the visible dataset metas in drawing order\n\t * @return {object[]}\n\t */\n getSortedVisibleDatasetMetas() {\n return this._getSortedDatasetMetas(true);\n }\n\n /**\n\t * Draws all datasets unless a plugin returns `false` to the `beforeDatasetsDraw`\n\t * hook, in which case, plugins will not be called on `afterDatasetsDraw`.\n\t * @private\n\t */\n _drawDatasets() {\n if (this.notifyPlugins('beforeDatasetsDraw', {cancelable: true}) === false) {\n return;\n }\n\n const metasets = this.getSortedVisibleDatasetMetas();\n for (let i = metasets.length - 1; i >= 0; --i) {\n this._drawDataset(metasets[i]);\n }\n\n this.notifyPlugins('afterDatasetsDraw');\n }\n\n /**\n\t * Draws dataset at index unless a plugin returns `false` to the `beforeDatasetDraw`\n\t * hook, in which case, plugins will not be called on `afterDatasetDraw`.\n\t * @private\n\t */\n _drawDataset(meta) {\n const ctx = this.ctx;\n const args = {\n meta,\n index: meta.index,\n cancelable: true\n };\n // @ts-expect-error\n const clip = getDatasetClipArea(this, meta);\n\n if (this.notifyPlugins('beforeDatasetDraw', args) === false) {\n return;\n }\n\n if (clip) {\n clipArea(ctx, clip);\n }\n\n meta.controller.draw();\n\n if (clip) {\n unclipArea(ctx);\n }\n\n args.cancelable = false;\n this.notifyPlugins('afterDatasetDraw', args);\n }\n\n /**\n * Checks whether the given point is in the chart area.\n * @param {Point} point - in relative coordinates (see, e.g., getRelativePosition)\n * @returns {boolean}\n */\n isPointInArea(point) {\n return _isPointInArea(point, this.chartArea, this._minPadding);\n }\n\n getElementsAtEventForMode(e, mode, options, useFinalPosition) {\n const method = Interaction.modes[mode];\n if (typeof method === 'function') {\n return method(this, e, options, useFinalPosition);\n }\n\n return [];\n }\n\n getDatasetMeta(datasetIndex) {\n const dataset = this.data.datasets[datasetIndex];\n const metasets = this._metasets;\n let meta = metasets.filter(x => x && x._dataset === dataset).pop();\n\n if (!meta) {\n meta = {\n type: null,\n data: [],\n dataset: null,\n controller: null,\n hidden: null,\t\t\t// See isDatasetVisible() comment\n xAxisID: null,\n yAxisID: null,\n order: dataset && dataset.order || 0,\n index: datasetIndex,\n _dataset: dataset,\n _parsed: [],\n _sorted: false\n };\n metasets.push(meta);\n }\n\n return meta;\n }\n\n getContext() {\n return this.$context || (this.$context = createContext(null, {chart: this, type: 'chart'}));\n }\n\n getVisibleDatasetCount() {\n return this.getSortedVisibleDatasetMetas().length;\n }\n\n isDatasetVisible(datasetIndex) {\n const dataset = this.data.datasets[datasetIndex];\n if (!dataset) {\n return false;\n }\n\n const meta = this.getDatasetMeta(datasetIndex);\n\n // meta.hidden is a per chart dataset hidden flag override with 3 states: if true or false,\n // the dataset.hidden value is ignored, else if null, the dataset hidden state is returned.\n return typeof meta.hidden === 'boolean' ? !meta.hidden : !dataset.hidden;\n }\n\n setDatasetVisibility(datasetIndex, visible) {\n const meta = this.getDatasetMeta(datasetIndex);\n meta.hidden = !visible;\n }\n\n toggleDataVisibility(index) {\n this._hiddenIndices[index] = !this._hiddenIndices[index];\n }\n\n getDataVisibility(index) {\n return !this._hiddenIndices[index];\n }\n\n /**\n\t * @private\n\t */\n _updateVisibility(datasetIndex, dataIndex, visible) {\n const mode = visible ? 'show' : 'hide';\n const meta = this.getDatasetMeta(datasetIndex);\n const anims = meta.controller._resolveAnimations(undefined, mode);\n\n if (defined(dataIndex)) {\n meta.data[dataIndex].hidden = !visible;\n this.update();\n } else {\n this.setDatasetVisibility(datasetIndex, visible);\n // Animate visible state, so hide animation can be seen. This could be handled better if update / updateDataset returned a Promise.\n anims.update(meta, {visible});\n this.update((ctx) => ctx.datasetIndex === datasetIndex ? mode : undefined);\n }\n }\n\n hide(datasetIndex, dataIndex) {\n this._updateVisibility(datasetIndex, dataIndex, false);\n }\n\n show(datasetIndex, dataIndex) {\n this._updateVisibility(datasetIndex, dataIndex, true);\n }\n\n /**\n\t * @private\n\t */\n _destroyDatasetMeta(datasetIndex) {\n const meta = this._metasets[datasetIndex];\n if (meta && meta.controller) {\n meta.controller._destroy();\n }\n delete this._metasets[datasetIndex];\n }\n\n _stop() {\n let i, ilen;\n this.stop();\n animator.remove(this);\n\n for (i = 0, ilen = this.data.datasets.length; i < ilen; ++i) {\n this._destroyDatasetMeta(i);\n }\n }\n\n destroy() {\n this.notifyPlugins('beforeDestroy');\n const {canvas, ctx} = this;\n\n this._stop();\n this.config.clearCache();\n\n if (canvas) {\n this.unbindEvents();\n clearCanvas(canvas, ctx);\n this.platform.releaseContext(ctx);\n this.canvas = null;\n this.ctx = null;\n }\n\n delete instances[this.id];\n\n this.notifyPlugins('afterDestroy');\n }\n\n toBase64Image(...args) {\n return this.canvas.toDataURL(...args);\n }\n\n /**\n\t * @private\n\t */\n bindEvents() {\n this.bindUserEvents();\n if (this.options.responsive) {\n this.bindResponsiveEvents();\n } else {\n this.attached = true;\n }\n }\n\n /**\n * @private\n */\n bindUserEvents() {\n const listeners = this._listeners;\n const platform = this.platform;\n\n const _add = (type, listener) => {\n platform.addEventListener(this, type, listener);\n listeners[type] = listener;\n };\n\n const listener = (e, x, y) => {\n e.offsetX = x;\n e.offsetY = y;\n this._eventHandler(e);\n };\n\n each(this.options.events, (type) => _add(type, listener));\n }\n\n /**\n * @private\n */\n bindResponsiveEvents() {\n if (!this._responsiveListeners) {\n this._responsiveListeners = {};\n }\n const listeners = this._responsiveListeners;\n const platform = this.platform;\n\n const _add = (type, listener) => {\n platform.addEventListener(this, type, listener);\n listeners[type] = listener;\n };\n const _remove = (type, listener) => {\n if (listeners[type]) {\n platform.removeEventListener(this, type, listener);\n delete listeners[type];\n }\n };\n\n const listener = (width, height) => {\n if (this.canvas) {\n this.resize(width, height);\n }\n };\n\n let detached; // eslint-disable-line prefer-const\n const attached = () => {\n _remove('attach', attached);\n\n this.attached = true;\n this.resize();\n\n _add('resize', listener);\n _add('detach', detached);\n };\n\n detached = () => {\n this.attached = false;\n\n _remove('resize', listener);\n\n // Stop animating and remove metasets, so when re-attached, the animations start from beginning.\n this._stop();\n this._resize(0, 0);\n\n _add('attach', attached);\n };\n\n if (platform.isAttached(this.canvas)) {\n attached();\n } else {\n detached();\n }\n }\n\n /**\n\t * @private\n\t */\n unbindEvents() {\n each(this._listeners, (listener, type) => {\n this.platform.removeEventListener(this, type, listener);\n });\n this._listeners = {};\n\n each(this._responsiveListeners, (listener, type) => {\n this.platform.removeEventListener(this, type, listener);\n });\n this._responsiveListeners = undefined;\n }\n\n updateHoverStyle(items, mode, enabled) {\n const prefix = enabled ? 'set' : 'remove';\n let meta, item, i, ilen;\n\n if (mode === 'dataset') {\n meta = this.getDatasetMeta(items[0].datasetIndex);\n meta.controller['_' + prefix + 'DatasetHoverStyle']();\n }\n\n for (i = 0, ilen = items.length; i < ilen; ++i) {\n item = items[i];\n const controller = item && this.getDatasetMeta(item.datasetIndex).controller;\n if (controller) {\n controller[prefix + 'HoverStyle'](item.element, item.datasetIndex, item.index);\n }\n }\n }\n\n /**\n\t * Get active (hovered) elements\n\t * @returns array\n\t */\n getActiveElements() {\n return this._active || [];\n }\n\n /**\n\t * Set active (hovered) elements\n\t * @param {array} activeElements New active data points\n\t */\n setActiveElements(activeElements) {\n const lastActive = this._active || [];\n const active = activeElements.map(({datasetIndex, index}) => {\n const meta = this.getDatasetMeta(datasetIndex);\n if (!meta) {\n throw new Error('No dataset found at index ' + datasetIndex);\n }\n\n return {\n datasetIndex,\n element: meta.data[index],\n index,\n };\n });\n const changed = !_elementsEqual(active, lastActive);\n\n if (changed) {\n this._active = active;\n // Make sure we don't use the previous mouse event to override the active elements in update.\n this._lastEvent = null;\n this._updateHoverStyles(active, lastActive);\n }\n }\n\n /**\n\t * Calls enabled plugins on the specified hook and with the given args.\n\t * This method immediately returns as soon as a plugin explicitly returns false. The\n\t * returned value can be used, for instance, to interrupt the current action.\n\t * @param {string} hook - The name of the plugin method to call (e.g. 'beforeUpdate').\n\t * @param {Object} [args] - Extra arguments to apply to the hook call.\n * @param {import('./core.plugins.js').filterCallback} [filter] - Filtering function for limiting which plugins are notified\n\t * @returns {boolean} false if any of the plugins return false, else returns true.\n\t */\n notifyPlugins(hook, args, filter) {\n return this._plugins.notify(this, hook, args, filter);\n }\n\n /**\n * Check if a plugin with the specific ID is registered and enabled\n * @param {string} pluginId - The ID of the plugin of which to check if it is enabled\n * @returns {boolean}\n */\n isPluginEnabled(pluginId) {\n return this._plugins._cache.filter(p => p.plugin.id === pluginId).length === 1;\n }\n\n /**\n\t * @private\n\t */\n _updateHoverStyles(active, lastActive, replay) {\n const hoverOptions = this.options.hover;\n const diff = (a, b) => a.filter(x => !b.some(y => x.datasetIndex === y.datasetIndex && x.index === y.index));\n const deactivated = diff(lastActive, active);\n const activated = replay ? active : diff(active, lastActive);\n\n if (deactivated.length) {\n this.updateHoverStyle(deactivated, hoverOptions.mode, false);\n }\n\n if (activated.length && hoverOptions.mode) {\n this.updateHoverStyle(activated, hoverOptions.mode, true);\n }\n }\n\n /**\n\t * @private\n\t */\n _eventHandler(e, replay) {\n const args = {\n event: e,\n replay,\n cancelable: true,\n inChartArea: this.isPointInArea(e)\n };\n const eventFilter = (plugin) => (plugin.options.events || this.options.events).includes(e.native.type);\n\n if (this.notifyPlugins('beforeEvent', args, eventFilter) === false) {\n return;\n }\n\n const changed = this._handleEvent(e, replay, args.inChartArea);\n\n args.cancelable = false;\n this.notifyPlugins('afterEvent', args, eventFilter);\n\n if (changed || args.changed) {\n this.render();\n }\n\n return this;\n }\n\n /**\n\t * Handle an event\n\t * @param {ChartEvent} e the event to handle\n\t * @param {boolean} [replay] - true if the event was replayed by `update`\n * @param {boolean} [inChartArea] - true if the event is inside chartArea\n\t * @return {boolean} true if the chart needs to re-render\n\t * @private\n\t */\n _handleEvent(e, replay, inChartArea) {\n const {_active: lastActive = [], options} = this;\n\n // If the event is replayed from `update`, we should evaluate with the final positions.\n //\n // The `replay`:\n // It's the last event (excluding click) that has occurred before `update`.\n // So mouse has not moved. It's also over the chart, because there is a `replay`.\n //\n // The why:\n // If animations are active, the elements haven't moved yet compared to state before update.\n // But if they will, we are activating the elements that would be active, if this check\n // was done after the animations have completed. => \"final positions\".\n // If there is no animations, the \"final\" and \"current\" positions are equal.\n // This is done so we do not have to evaluate the active elements each animation frame\n // - it would be expensive.\n const useFinalPosition = replay;\n const active = this._getActiveElements(e, lastActive, inChartArea, useFinalPosition);\n const isClick = _isClickEvent(e);\n const lastEvent = determineLastEvent(e, this._lastEvent, inChartArea, isClick);\n\n if (inChartArea) {\n // Set _lastEvent to null while we are processing the event handlers.\n // This prevents recursion if the handler calls chart.update()\n this._lastEvent = null;\n\n // Invoke onHover hook\n callCallback(options.onHover, [e, active, this], this);\n\n if (isClick) {\n callCallback(options.onClick, [e, active, this], this);\n }\n }\n\n const changed = !_elementsEqual(active, lastActive);\n if (changed || replay) {\n this._active = active;\n this._updateHoverStyles(active, lastActive, replay);\n }\n\n this._lastEvent = lastEvent;\n\n return changed;\n }\n\n /**\n * @param {ChartEvent} e - The event\n * @param {import('../types/index.js').ActiveElement[]} lastActive - Previously active elements\n * @param {boolean} inChartArea - Is the event inside chartArea\n * @param {boolean} useFinalPosition - Should the evaluation be done with current or final (after animation) element positions\n * @returns {import('../types/index.js').ActiveElement[]} - The active elements\n * @pravate\n */\n _getActiveElements(e, lastActive, inChartArea, useFinalPosition) {\n if (e.type === 'mouseout') {\n return [];\n }\n\n if (!inChartArea) {\n // Let user control the active elements outside chartArea. Eg. using Legend.\n return lastActive;\n }\n\n const hoverOptions = this.options.hover;\n return this.getElementsAtEventForMode(e, hoverOptions.mode, hoverOptions, useFinalPosition);\n }\n}\n\n// @ts-ignore\nfunction invalidatePlugins() {\n return each(Chart.instances, (chart) => chart._plugins.invalidate());\n}\n\nexport default Chart;\n","import Element from '../core/core.element.js';\nimport {_angleBetween, getAngleFromPoint, TAU, HALF_PI, valueOrDefault} from '../helpers/index.js';\nimport {PI, _angleDiff, _normalizeAngle, _isBetween, _limitValue} from '../helpers/helpers.math.js';\nimport {_readValueToProps} from '../helpers/helpers.options.js';\nimport type {ArcOptions, Point} from '../types/index.js';\n\nfunction clipSelf(ctx: CanvasRenderingContext2D, element: ArcElement, endAngle: number) {\n const {startAngle, x, y, outerRadius, innerRadius, options} = element;\n const {borderWidth, borderJoinStyle} = options;\n const outerAngleClip = Math.min(borderWidth / outerRadius, _normalizeAngle(startAngle - endAngle));\n ctx.beginPath();\n ctx.arc(x, y, outerRadius - borderWidth / 2, startAngle + outerAngleClip / 2, endAngle - outerAngleClip / 2);\n\n if (innerRadius > 0) {\n const innerAngleClip = Math.min(borderWidth / innerRadius, _normalizeAngle(startAngle - endAngle));\n ctx.arc(x, y, innerRadius + borderWidth / 2, endAngle - innerAngleClip / 2, startAngle + innerAngleClip / 2, true);\n } else {\n const clipWidth = Math.min(borderWidth / 2, outerRadius * _normalizeAngle(startAngle - endAngle));\n\n if (borderJoinStyle === 'round') {\n ctx.arc(x, y, clipWidth, endAngle - PI / 2, startAngle + PI / 2, true);\n } else if (borderJoinStyle === 'bevel') {\n const r = 2 * clipWidth * clipWidth;\n const endX = -r * Math.cos(endAngle + PI / 2) + x;\n const endY = -r * Math.sin(endAngle + PI / 2) + y;\n const startX = r * Math.cos(startAngle + PI / 2) + x;\n const startY = r * Math.sin(startAngle + PI / 2) + y;\n ctx.lineTo(endX, endY);\n ctx.lineTo(startX, startY);\n }\n }\n ctx.closePath();\n\n ctx.moveTo(0, 0);\n ctx.rect(0, 0, ctx.canvas.width, ctx.canvas.height);\n\n ctx.clip('evenodd');\n}\n\n\nfunction clipArc(ctx: CanvasRenderingContext2D, element: ArcElement, endAngle: number) {\n const {startAngle, pixelMargin, x, y, outerRadius, innerRadius} = element;\n let angleMargin = pixelMargin / outerRadius;\n\n // Draw an inner border by clipping the arc and drawing a double-width border\n // Enlarge the clipping arc by 0.33 pixels to eliminate glitches between borders\n ctx.beginPath();\n ctx.arc(x, y, outerRadius, startAngle - angleMargin, endAngle + angleMargin);\n if (innerRadius > pixelMargin) {\n angleMargin = pixelMargin / innerRadius;\n ctx.arc(x, y, innerRadius, endAngle + angleMargin, startAngle - angleMargin, true);\n } else {\n ctx.arc(x, y, pixelMargin, endAngle + HALF_PI, startAngle - HALF_PI);\n }\n ctx.closePath();\n ctx.clip();\n}\n\nfunction toRadiusCorners(value) {\n return _readValueToProps(value, ['outerStart', 'outerEnd', 'innerStart', 'innerEnd']);\n}\n\n/**\n * Parse border radius from the provided options\n */\nfunction parseBorderRadius(arc: ArcElement, innerRadius: number, outerRadius: number, angleDelta: number) {\n const o = toRadiusCorners(arc.options.borderRadius);\n const halfThickness = (outerRadius - innerRadius) / 2;\n const innerLimit = Math.min(halfThickness, angleDelta * innerRadius / 2);\n\n // Outer limits are complicated. We want to compute the available angular distance at\n // a radius of outerRadius - borderRadius because for small angular distances, this term limits.\n // We compute at r = outerRadius - borderRadius because this circle defines the center of the border corners.\n //\n // If the borderRadius is large, that value can become negative.\n // This causes the outer borders to lose their radius entirely, which is rather unexpected. To solve that, if borderRadius > outerRadius\n // we know that the thickness term will dominate and compute the limits at that point\n const computeOuterLimit = (val) => {\n const outerArcLimit = (outerRadius - Math.min(halfThickness, val)) * angleDelta / 2;\n return _limitValue(val, 0, Math.min(halfThickness, outerArcLimit));\n };\n\n return {\n outerStart: computeOuterLimit(o.outerStart),\n outerEnd: computeOuterLimit(o.outerEnd),\n innerStart: _limitValue(o.innerStart, 0, innerLimit),\n innerEnd: _limitValue(o.innerEnd, 0, innerLimit),\n };\n}\n\n/**\n * Convert (r, 𝜃) to (x, y)\n */\nfunction rThetaToXY(r: number, theta: number, x: number, y: number) {\n return {\n x: x + r * Math.cos(theta),\n y: y + r * Math.sin(theta),\n };\n}\n\n\n/**\n * Path the arc, respecting border radius by separating into left and right halves.\n *\n * Start End\n *\n * 1--->a--->2 Outer\n * / \\\n * 8 3\n * | |\n * | |\n * 7 4\n * \\ /\n * 6<---b<---5 Inner\n */\nfunction pathArc(\n ctx: CanvasRenderingContext2D,\n element: ArcElement,\n offset: number,\n spacing: number,\n end: number,\n circular: boolean,\n) {\n const {x, y, startAngle: start, pixelMargin, innerRadius: innerR} = element;\n\n const outerRadius = Math.max(element.outerRadius + spacing + offset - pixelMargin, 0);\n const innerRadius = innerR > 0 ? innerR + spacing + offset + pixelMargin : 0;\n\n let spacingOffset = 0;\n const alpha = end - start;\n\n if (spacing) {\n // When spacing is present, it is the same for all items\n // So we adjust the start and end angle of the arc such that\n // the distance is the same as it would be without the spacing\n const noSpacingInnerRadius = innerR > 0 ? innerR - spacing : 0;\n const noSpacingOuterRadius = outerRadius > 0 ? outerRadius - spacing : 0;\n const avNogSpacingRadius = (noSpacingInnerRadius + noSpacingOuterRadius) / 2;\n const adjustedAngle = avNogSpacingRadius !== 0 ? (alpha * avNogSpacingRadius) / (avNogSpacingRadius + spacing) : alpha;\n spacingOffset = (alpha - adjustedAngle) / 2;\n }\n\n const beta = Math.max(0.001, alpha * outerRadius - offset / PI) / outerRadius;\n const angleOffset = (alpha - beta) / 2;\n const startAngle = start + angleOffset + spacingOffset;\n const endAngle = end - angleOffset - spacingOffset;\n const {outerStart, outerEnd, innerStart, innerEnd} = parseBorderRadius(element, innerRadius, outerRadius, endAngle - startAngle);\n\n const outerStartAdjustedRadius = outerRadius - outerStart;\n const outerEndAdjustedRadius = outerRadius - outerEnd;\n const outerStartAdjustedAngle = startAngle + outerStart / outerStartAdjustedRadius;\n const outerEndAdjustedAngle = endAngle - outerEnd / outerEndAdjustedRadius;\n\n const innerStartAdjustedRadius = innerRadius + innerStart;\n const innerEndAdjustedRadius = innerRadius + innerEnd;\n const innerStartAdjustedAngle = startAngle + innerStart / innerStartAdjustedRadius;\n const innerEndAdjustedAngle = endAngle - innerEnd / innerEndAdjustedRadius;\n\n ctx.beginPath();\n\n if (circular) {\n // The first arc segments from point 1 to point a to point 2\n const outerMidAdjustedAngle = (outerStartAdjustedAngle + outerEndAdjustedAngle) / 2;\n ctx.arc(x, y, outerRadius, outerStartAdjustedAngle, outerMidAdjustedAngle);\n ctx.arc(x, y, outerRadius, outerMidAdjustedAngle, outerEndAdjustedAngle);\n\n // The corner segment from point 2 to point 3\n if (outerEnd > 0) {\n const pCenter = rThetaToXY(outerEndAdjustedRadius, outerEndAdjustedAngle, x, y);\n ctx.arc(pCenter.x, pCenter.y, outerEnd, outerEndAdjustedAngle, endAngle + HALF_PI);\n }\n\n // The line from point 3 to point 4\n const p4 = rThetaToXY(innerEndAdjustedRadius, endAngle, x, y);\n ctx.lineTo(p4.x, p4.y);\n\n // The corner segment from point 4 to point 5\n if (innerEnd > 0) {\n const pCenter = rThetaToXY(innerEndAdjustedRadius, innerEndAdjustedAngle, x, y);\n ctx.arc(pCenter.x, pCenter.y, innerEnd, endAngle + HALF_PI, innerEndAdjustedAngle + Math.PI);\n }\n\n // The inner arc from point 5 to point b to point 6\n const innerMidAdjustedAngle = ((endAngle - (innerEnd / innerRadius)) + (startAngle + (innerStart / innerRadius))) / 2;\n ctx.arc(x, y, innerRadius, endAngle - (innerEnd / innerRadius), innerMidAdjustedAngle, true);\n ctx.arc(x, y, innerRadius, innerMidAdjustedAngle, startAngle + (innerStart / innerRadius), true);\n\n // The corner segment from point 6 to point 7\n if (innerStart > 0) {\n const pCenter = rThetaToXY(innerStartAdjustedRadius, innerStartAdjustedAngle, x, y);\n ctx.arc(pCenter.x, pCenter.y, innerStart, innerStartAdjustedAngle + Math.PI, startAngle - HALF_PI);\n }\n\n // The line from point 7 to point 8\n const p8 = rThetaToXY(outerStartAdjustedRadius, startAngle, x, y);\n ctx.lineTo(p8.x, p8.y);\n\n // The corner segment from point 8 to point 1\n if (outerStart > 0) {\n const pCenter = rThetaToXY(outerStartAdjustedRadius, outerStartAdjustedAngle, x, y);\n ctx.arc(pCenter.x, pCenter.y, outerStart, startAngle - HALF_PI, outerStartAdjustedAngle);\n }\n } else {\n ctx.moveTo(x, y);\n\n const outerStartX = Math.cos(outerStartAdjustedAngle) * outerRadius + x;\n const outerStartY = Math.sin(outerStartAdjustedAngle) * outerRadius + y;\n ctx.lineTo(outerStartX, outerStartY);\n\n const outerEndX = Math.cos(outerEndAdjustedAngle) * outerRadius + x;\n const outerEndY = Math.sin(outerEndAdjustedAngle) * outerRadius + y;\n ctx.lineTo(outerEndX, outerEndY);\n }\n\n ctx.closePath();\n}\n\nfunction drawArc(\n ctx: CanvasRenderingContext2D,\n element: ArcElement,\n offset: number,\n spacing: number,\n circular: boolean,\n) {\n const {fullCircles, startAngle, circumference} = element;\n let endAngle = element.endAngle;\n if (fullCircles) {\n pathArc(ctx, element, offset, spacing, endAngle, circular);\n for (let i = 0; i < fullCircles; ++i) {\n ctx.fill();\n }\n if (!isNaN(circumference)) {\n endAngle = startAngle + (circumference % TAU || TAU);\n }\n }\n pathArc(ctx, element, offset, spacing, endAngle, circular);\n ctx.fill();\n return endAngle;\n}\n\nfunction drawBorder(\n ctx: CanvasRenderingContext2D,\n element: ArcElement,\n offset: number,\n spacing: number,\n circular: boolean,\n) {\n const {fullCircles, startAngle, circumference, options} = element;\n const {borderWidth, borderJoinStyle, borderDash, borderDashOffset, borderRadius} = options;\n const inner = options.borderAlign === 'inner';\n\n if (!borderWidth) {\n return;\n }\n\n ctx.setLineDash(borderDash || []);\n ctx.lineDashOffset = borderDashOffset;\n\n if (inner) {\n ctx.lineWidth = borderWidth * 2;\n ctx.lineJoin = borderJoinStyle || 'round';\n } else {\n ctx.lineWidth = borderWidth;\n ctx.lineJoin = borderJoinStyle || 'bevel';\n }\n\n let endAngle = element.endAngle;\n if (fullCircles) {\n pathArc(ctx, element, offset, spacing, endAngle, circular);\n for (let i = 0; i < fullCircles; ++i) {\n ctx.stroke();\n }\n if (!isNaN(circumference)) {\n endAngle = startAngle + (circumference % TAU || TAU);\n }\n }\n\n if (inner) {\n clipArc(ctx, element, endAngle);\n }\n\n if (options.selfJoin && endAngle - startAngle >= PI && borderRadius === 0 && borderJoinStyle !== 'miter') {\n clipSelf(ctx, element, endAngle);\n }\n\n if (!fullCircles) {\n pathArc(ctx, element, offset, spacing, endAngle, circular);\n ctx.stroke();\n }\n}\n\nexport interface ArcProps extends Point {\n startAngle: number;\n endAngle: number;\n innerRadius: number;\n outerRadius: number;\n circumference: number;\n}\n\nexport default class ArcElement extends Element {\n\n static id = 'arc';\n\n static defaults = {\n borderAlign: 'center',\n borderColor: '#fff',\n borderDash: [],\n borderDashOffset: 0,\n borderJoinStyle: undefined,\n borderRadius: 0,\n borderWidth: 2,\n offset: 0,\n spacing: 0,\n angle: undefined,\n circular: true,\n selfJoin: false,\n };\n\n static defaultRoutes = {\n backgroundColor: 'backgroundColor'\n };\n\n static descriptors = {\n _scriptable: true,\n _indexable: (name) => name !== 'borderDash'\n };\n\n circumference: number;\n endAngle: number;\n fullCircles: number;\n innerRadius: number;\n outerRadius: number;\n pixelMargin: number;\n startAngle: number;\n\n constructor(cfg) {\n super();\n\n this.options = undefined;\n this.circumference = undefined;\n this.startAngle = undefined;\n this.endAngle = undefined;\n this.innerRadius = undefined;\n this.outerRadius = undefined;\n this.pixelMargin = 0;\n this.fullCircles = 0;\n\n if (cfg) {\n Object.assign(this, cfg);\n }\n }\n\n inRange(chartX: number, chartY: number, useFinalPosition: boolean) {\n const point = this.getProps(['x', 'y'], useFinalPosition);\n const {angle, distance} = getAngleFromPoint(point, {x: chartX, y: chartY});\n const {startAngle, endAngle, innerRadius, outerRadius, circumference} = this.getProps([\n 'startAngle',\n 'endAngle',\n 'innerRadius',\n 'outerRadius',\n 'circumference'\n ], useFinalPosition);\n const rAdjust = (this.options.spacing + this.options.borderWidth) / 2;\n const _circumference = valueOrDefault(circumference, endAngle - startAngle);\n const nonZeroBetween = _angleBetween(angle, startAngle, endAngle) && startAngle !== endAngle;\n const betweenAngles = _circumference >= TAU || nonZeroBetween;\n const withinRadius = _isBetween(distance, innerRadius + rAdjust, outerRadius + rAdjust);\n\n return (betweenAngles && withinRadius);\n }\n\n getCenterPoint(useFinalPosition: boolean) {\n const {x, y, startAngle, endAngle, innerRadius, outerRadius} = this.getProps([\n 'x',\n 'y',\n 'startAngle',\n 'endAngle',\n 'innerRadius',\n 'outerRadius'\n ], useFinalPosition);\n const {offset, spacing} = this.options;\n const halfAngle = (startAngle + endAngle) / 2;\n const halfRadius = (innerRadius + outerRadius + spacing + offset) / 2;\n return {\n x: x + Math.cos(halfAngle) * halfRadius,\n y: y + Math.sin(halfAngle) * halfRadius\n };\n }\n\n tooltipPosition(useFinalPosition: boolean) {\n return this.getCenterPoint(useFinalPosition);\n }\n\n draw(ctx: CanvasRenderingContext2D) {\n const {options, circumference} = this;\n const offset = (options.offset || 0) / 4;\n const spacing = (options.spacing || 0) / 2;\n const circular = options.circular;\n this.pixelMargin = (options.borderAlign === 'inner') ? 0.33 : 0;\n this.fullCircles = circumference > TAU ? Math.floor(circumference / TAU) : 0;\n\n if (circumference === 0 || this.innerRadius < 0 || this.outerRadius < 0) {\n return;\n }\n\n ctx.save();\n\n const halfAngle = (this.startAngle + this.endAngle) / 2;\n ctx.translate(Math.cos(halfAngle) * offset, Math.sin(halfAngle) * offset);\n const fix = 1 - Math.sin(Math.min(PI, circumference || 0));\n const radiusOffset = offset * fix;\n\n ctx.fillStyle = options.backgroundColor;\n ctx.strokeStyle = options.borderColor;\n\n drawArc(ctx, this, radiusOffset, spacing, circular);\n drawBorder(ctx, this, radiusOffset, spacing, circular);\n\n ctx.restore();\n }\n}\n","import Element from '../core/core.element.js';\nimport {_bezierInterpolation, _pointInLine, _steppedInterpolation} from '../helpers/helpers.interpolation.js';\nimport {_computeSegments, _boundSegments} from '../helpers/helpers.segment.js';\nimport {_steppedLineTo, _bezierCurveTo} from '../helpers/helpers.canvas.js';\nimport {_updateBezierControlPoints} from '../helpers/helpers.curve.js';\nimport {valueOrDefault} from '../helpers/index.js';\n\n/**\n * @typedef { import('./element.point.js').default } PointElement\n */\n\nfunction setStyle(ctx, options, style = options) {\n ctx.lineCap = valueOrDefault(style.borderCapStyle, options.borderCapStyle);\n ctx.setLineDash(valueOrDefault(style.borderDash, options.borderDash));\n ctx.lineDashOffset = valueOrDefault(style.borderDashOffset, options.borderDashOffset);\n ctx.lineJoin = valueOrDefault(style.borderJoinStyle, options.borderJoinStyle);\n ctx.lineWidth = valueOrDefault(style.borderWidth, options.borderWidth);\n ctx.strokeStyle = valueOrDefault(style.borderColor, options.borderColor);\n}\n\nfunction lineTo(ctx, previous, target) {\n ctx.lineTo(target.x, target.y);\n}\n\n/**\n * @returns {any}\n */\nfunction getLineMethod(options) {\n if (options.stepped) {\n return _steppedLineTo;\n }\n\n if (options.tension || options.cubicInterpolationMode === 'monotone') {\n return _bezierCurveTo;\n }\n\n return lineTo;\n}\n\nfunction pathVars(points, segment, params = {}) {\n const count = points.length;\n const {start: paramsStart = 0, end: paramsEnd = count - 1} = params;\n const {start: segmentStart, end: segmentEnd} = segment;\n const start = Math.max(paramsStart, segmentStart);\n const end = Math.min(paramsEnd, segmentEnd);\n const outside = paramsStart < segmentStart && paramsEnd < segmentStart || paramsStart > segmentEnd && paramsEnd > segmentEnd;\n\n return {\n count,\n start,\n loop: segment.loop,\n ilen: end < start && !outside ? count + end - start : end - start\n };\n}\n\n/**\n * Create path from points, grouping by truncated x-coordinate\n * Points need to be in order by x-coordinate for this to work efficiently\n * @param {CanvasRenderingContext2D|Path2D} ctx - Context\n * @param {LineElement} line\n * @param {object} segment\n * @param {number} segment.start - start index of the segment, referring the points array\n * @param {number} segment.end - end index of the segment, referring the points array\n * @param {boolean} segment.loop - indicates that the segment is a loop\n * @param {object} params\n * @param {boolean} params.move - move to starting point (vs line to it)\n * @param {boolean} params.reverse - path the segment from end to start\n * @param {number} params.start - limit segment to points starting from `start` index\n * @param {number} params.end - limit segment to points ending at `start` + `count` index\n */\nfunction pathSegment(ctx, line, segment, params) {\n const {points, options} = line;\n const {count, start, loop, ilen} = pathVars(points, segment, params);\n const lineMethod = getLineMethod(options);\n // eslint-disable-next-line prefer-const\n let {move = true, reverse} = params || {};\n let i, point, prev;\n\n for (i = 0; i <= ilen; ++i) {\n point = points[(start + (reverse ? ilen - i : i)) % count];\n\n if (point.skip) {\n // If there is a skipped point inside a segment, spanGaps must be true\n continue;\n } else if (move) {\n ctx.moveTo(point.x, point.y);\n move = false;\n } else {\n lineMethod(ctx, prev, point, reverse, options.stepped);\n }\n\n prev = point;\n }\n\n if (loop) {\n point = points[(start + (reverse ? ilen : 0)) % count];\n lineMethod(ctx, prev, point, reverse, options.stepped);\n }\n\n return !!loop;\n}\n\n/**\n * Create path from points, grouping by truncated x-coordinate\n * Points need to be in order by x-coordinate for this to work efficiently\n * @param {CanvasRenderingContext2D|Path2D} ctx - Context\n * @param {LineElement} line\n * @param {object} segment\n * @param {number} segment.start - start index of the segment, referring the points array\n * @param {number} segment.end - end index of the segment, referring the points array\n * @param {boolean} segment.loop - indicates that the segment is a loop\n * @param {object} params\n * @param {boolean} params.move - move to starting point (vs line to it)\n * @param {boolean} params.reverse - path the segment from end to start\n * @param {number} params.start - limit segment to points starting from `start` index\n * @param {number} params.end - limit segment to points ending at `start` + `count` index\n */\nfunction fastPathSegment(ctx, line, segment, params) {\n const points = line.points;\n const {count, start, ilen} = pathVars(points, segment, params);\n const {move = true, reverse} = params || {};\n let avgX = 0;\n let countX = 0;\n let i, point, prevX, minY, maxY, lastY;\n\n const pointIndex = (index) => (start + (reverse ? ilen - index : index)) % count;\n const drawX = () => {\n if (minY !== maxY) {\n // Draw line to maxY and minY, using the average x-coordinate\n ctx.lineTo(avgX, maxY);\n ctx.lineTo(avgX, minY);\n // Line to y-value of last point in group. So the line continues\n // from correct position. Not using move, to have solid path.\n ctx.lineTo(avgX, lastY);\n }\n };\n\n if (move) {\n point = points[pointIndex(0)];\n ctx.moveTo(point.x, point.y);\n }\n\n for (i = 0; i <= ilen; ++i) {\n point = points[pointIndex(i)];\n\n if (point.skip) {\n // If there is a skipped point inside a segment, spanGaps must be true\n continue;\n }\n\n const x = point.x;\n const y = point.y;\n const truncX = x | 0; // truncated x-coordinate\n\n if (truncX === prevX) {\n // Determine `minY` / `maxY` and `avgX` while we stay within same x-position\n if (y < minY) {\n minY = y;\n } else if (y > maxY) {\n maxY = y;\n }\n // For first point in group, countX is `0`, so average will be `x` / 1.\n avgX = (countX * avgX + x) / ++countX;\n } else {\n drawX();\n // Draw line to next x-position, using the first (or only)\n // y-value in that group\n ctx.lineTo(x, y);\n\n prevX = truncX;\n countX = 0;\n minY = maxY = y;\n }\n // Keep track of the last y-value in group\n lastY = y;\n }\n drawX();\n}\n\n/**\n * @param {LineElement} line - the line\n * @returns {function}\n * @private\n */\nfunction _getSegmentMethod(line) {\n const opts = line.options;\n const borderDash = opts.borderDash && opts.borderDash.length;\n const useFastPath = !line._decimated && !line._loop && !opts.tension && opts.cubicInterpolationMode !== 'monotone' && !opts.stepped && !borderDash;\n return useFastPath ? fastPathSegment : pathSegment;\n}\n\n/**\n * @private\n */\nfunction _getInterpolationMethod(options) {\n if (options.stepped) {\n return _steppedInterpolation;\n }\n\n if (options.tension || options.cubicInterpolationMode === 'monotone') {\n return _bezierInterpolation;\n }\n\n return _pointInLine;\n}\n\nfunction strokePathWithCache(ctx, line, start, count) {\n let path = line._path;\n if (!path) {\n path = line._path = new Path2D();\n if (line.path(path, start, count)) {\n path.closePath();\n }\n }\n setStyle(ctx, line.options);\n ctx.stroke(path);\n}\n\nfunction strokePathDirect(ctx, line, start, count) {\n const {segments, options} = line;\n const segmentMethod = _getSegmentMethod(line);\n\n for (const segment of segments) {\n setStyle(ctx, options, segment.style);\n ctx.beginPath();\n if (segmentMethod(ctx, line, segment, {start, end: start + count - 1})) {\n ctx.closePath();\n }\n ctx.stroke();\n }\n}\n\nconst usePath2D = typeof Path2D === 'function';\n\nfunction draw(ctx, line, start, count) {\n if (usePath2D && !line.options.segment) {\n strokePathWithCache(ctx, line, start, count);\n } else {\n strokePathDirect(ctx, line, start, count);\n }\n}\n\nexport default class LineElement extends Element {\n\n static id = 'line';\n\n /**\n * @type {any}\n */\n static defaults = {\n borderCapStyle: 'butt',\n borderDash: [],\n borderDashOffset: 0,\n borderJoinStyle: 'miter',\n borderWidth: 3,\n capBezierPoints: true,\n cubicInterpolationMode: 'default',\n fill: false,\n spanGaps: false,\n stepped: false,\n tension: 0,\n };\n\n /**\n * @type {any}\n */\n static defaultRoutes = {\n backgroundColor: 'backgroundColor',\n borderColor: 'borderColor'\n };\n\n\n static descriptors = {\n _scriptable: true,\n _indexable: (name) => name !== 'borderDash' && name !== 'fill',\n };\n\n\n constructor(cfg) {\n super();\n\n this.animated = true;\n this.options = undefined;\n this._chart = undefined;\n this._loop = undefined;\n this._fullLoop = undefined;\n this._path = undefined;\n this._points = undefined;\n this._segments = undefined;\n this._decimated = false;\n this._pointsUpdated = false;\n this._datasetIndex = undefined;\n\n if (cfg) {\n Object.assign(this, cfg);\n }\n }\n\n updateControlPoints(chartArea, indexAxis) {\n const options = this.options;\n if ((options.tension || options.cubicInterpolationMode === 'monotone') && !options.stepped && !this._pointsUpdated) {\n const loop = options.spanGaps ? this._loop : this._fullLoop;\n _updateBezierControlPoints(this._points, options, chartArea, loop, indexAxis);\n this._pointsUpdated = true;\n }\n }\n\n set points(points) {\n this._points = points;\n delete this._segments;\n delete this._path;\n this._pointsUpdated = false;\n }\n\n get points() {\n return this._points;\n }\n\n get segments() {\n return this._segments || (this._segments = _computeSegments(this, this.options.segment));\n }\n\n /**\n\t * First non-skipped point on this line\n\t * @returns {PointElement|undefined}\n\t */\n first() {\n const segments = this.segments;\n const points = this.points;\n return segments.length && points[segments[0].start];\n }\n\n /**\n\t * Last non-skipped point on this line\n\t * @returns {PointElement|undefined}\n\t */\n last() {\n const segments = this.segments;\n const points = this.points;\n const count = segments.length;\n return count && points[segments[count - 1].end];\n }\n\n /**\n\t * Interpolate a point in this line at the same value on `property` as\n\t * the reference `point` provided\n\t * @param {PointElement} point - the reference point\n\t * @param {string} property - the property to match on\n\t * @returns {PointElement|undefined}\n\t */\n interpolate(point, property) {\n const options = this.options;\n const value = point[property];\n const points = this.points;\n const segments = _boundSegments(this, {property, start: value, end: value});\n\n if (!segments.length) {\n return;\n }\n\n const result = [];\n const _interpolate = _getInterpolationMethod(options);\n let i, ilen;\n for (i = 0, ilen = segments.length; i < ilen; ++i) {\n const {start, end} = segments[i];\n const p1 = points[start];\n const p2 = points[end];\n if (p1 === p2) {\n result.push(p1);\n continue;\n }\n const t = Math.abs((value - p1[property]) / (p2[property] - p1[property]));\n const interpolated = _interpolate(p1, p2, t, options.stepped);\n interpolated[property] = point[property];\n result.push(interpolated);\n }\n return result.length === 1 ? result[0] : result;\n }\n\n /**\n\t * Append a segment of this line to current path.\n\t * @param {CanvasRenderingContext2D} ctx\n\t * @param {object} segment\n\t * @param {number} segment.start - start index of the segment, referring the points array\n \t * @param {number} segment.end - end index of the segment, referring the points array\n \t * @param {boolean} segment.loop - indicates that the segment is a loop\n\t * @param {object} params\n\t * @param {boolean} params.move - move to starting point (vs line to it)\n\t * @param {boolean} params.reverse - path the segment from end to start\n\t * @param {number} params.start - limit segment to points starting from `start` index\n\t * @param {number} params.end - limit segment to points ending at `start` + `count` index\n\t * @returns {undefined|boolean} - true if the segment is a full loop (path should be closed)\n\t */\n pathSegment(ctx, segment, params) {\n const segmentMethod = _getSegmentMethod(this);\n return segmentMethod(ctx, this, segment, params);\n }\n\n /**\n\t * Append all segments of this line to current path.\n\t * @param {CanvasRenderingContext2D|Path2D} ctx\n\t * @param {number} [start]\n\t * @param {number} [count]\n\t * @returns {undefined|boolean} - true if line is a full loop (path should be closed)\n\t */\n path(ctx, start, count) {\n const segments = this.segments;\n const segmentMethod = _getSegmentMethod(this);\n let loop = this._loop;\n\n start = start || 0;\n count = count || (this.points.length - start);\n\n for (const segment of segments) {\n loop &= segmentMethod(ctx, this, segment, {start, end: start + count - 1});\n }\n return !!loop;\n }\n\n /**\n\t * Draw\n\t * @param {CanvasRenderingContext2D} ctx\n\t * @param {object} chartArea\n\t * @param {number} [start]\n\t * @param {number} [count]\n\t */\n draw(ctx, chartArea, start, count) {\n const options = this.options || {};\n const points = this.points || [];\n\n if (points.length && options.borderWidth) {\n ctx.save();\n\n draw(ctx, this, start, count);\n\n ctx.restore();\n }\n\n if (this.animated) {\n // When line is animated, the control points and path are not cached.\n this._pointsUpdated = false;\n this._path = undefined;\n }\n }\n}\n","import Element from '../core/core.element.js';\nimport {drawPoint, _isPointInArea} from '../helpers/helpers.canvas.js';\nimport type {\n CartesianParsedData,\n ChartArea,\n Point,\n PointHoverOptions,\n PointOptions,\n} from '../types/index.js';\n\nfunction inRange(el: PointElement, pos: number, axis: 'x' | 'y', useFinalPosition?: boolean) {\n const options = el.options;\n const {[axis]: value} = el.getProps([axis], useFinalPosition);\n\n return (Math.abs(pos - value) < options.radius + options.hitRadius);\n}\n\nexport type PointProps = Point\n\nexport default class PointElement extends Element {\n\n static id = 'point';\n\n parsed: CartesianParsedData;\n skip?: boolean;\n stop?: boolean;\n\n /**\n * @type {any}\n */\n static defaults = {\n borderWidth: 1,\n hitRadius: 1,\n hoverBorderWidth: 1,\n hoverRadius: 4,\n pointStyle: 'circle',\n radius: 3,\n rotation: 0\n };\n\n /**\n * @type {any}\n */\n static defaultRoutes = {\n backgroundColor: 'backgroundColor',\n borderColor: 'borderColor'\n };\n\n constructor(cfg) {\n super();\n\n this.options = undefined;\n this.parsed = undefined;\n this.skip = undefined;\n this.stop = undefined;\n\n if (cfg) {\n Object.assign(this, cfg);\n }\n }\n\n inRange(mouseX: number, mouseY: number, useFinalPosition?: boolean) {\n const options = this.options;\n const {x, y} = this.getProps(['x', 'y'], useFinalPosition);\n return ((Math.pow(mouseX - x, 2) + Math.pow(mouseY - y, 2)) < Math.pow(options.hitRadius + options.radius, 2));\n }\n\n inXRange(mouseX: number, useFinalPosition?: boolean) {\n return inRange(this, mouseX, 'x', useFinalPosition);\n }\n\n inYRange(mouseY: number, useFinalPosition?: boolean) {\n return inRange(this, mouseY, 'y', useFinalPosition);\n }\n\n getCenterPoint(useFinalPosition?: boolean) {\n const {x, y} = this.getProps(['x', 'y'], useFinalPosition);\n return {x, y};\n }\n\n size(options?: Partial) {\n options = options || this.options || {};\n let radius = options.radius || 0;\n radius = Math.max(radius, radius && options.hoverRadius || 0);\n const borderWidth = radius && options.borderWidth || 0;\n return (radius + borderWidth) * 2;\n }\n\n draw(ctx: CanvasRenderingContext2D, area: ChartArea) {\n const options = this.options;\n\n if (this.skip || options.radius < 0.1 || !_isPointInArea(this, area, this.size(options) / 2)) {\n return;\n }\n\n ctx.strokeStyle = options.borderColor;\n ctx.lineWidth = options.borderWidth;\n ctx.fillStyle = options.backgroundColor;\n drawPoint(ctx, options, this.x, this.y);\n }\n\n getRange() {\n const options = this.options || {};\n // @ts-expect-error Fallbacks should never be hit in practice\n return options.radius + options.hitRadius;\n }\n}\n","import Element from '../core/core.element.js';\nimport {isObject, _isBetween, _limitValue} from '../helpers/index.js';\nimport {addRoundedRectPath} from '../helpers/helpers.canvas.js';\nimport {toTRBL, toTRBLCorners} from '../helpers/helpers.options.js';\n\n/** @typedef {{ x: number, y: number, base: number, horizontal: boolean, width: number, height: number }} BarProps */\n\n/**\n * Helper function to get the bounds of the bar regardless of the orientation\n * @param {BarElement} bar the bar\n * @param {boolean} [useFinalPosition]\n * @return {object} bounds of the bar\n * @private\n */\nfunction getBarBounds(bar, useFinalPosition) {\n const {x, y, base, width, height} = /** @type {BarProps} */ (bar.getProps(['x', 'y', 'base', 'width', 'height'], useFinalPosition));\n\n let left, right, top, bottom, half;\n\n if (bar.horizontal) {\n half = height / 2;\n left = Math.min(x, base);\n right = Math.max(x, base);\n top = y - half;\n bottom = y + half;\n } else {\n half = width / 2;\n left = x - half;\n right = x + half;\n top = Math.min(y, base);\n bottom = Math.max(y, base);\n }\n\n return {left, top, right, bottom};\n}\n\nfunction skipOrLimit(skip, value, min, max) {\n return skip ? 0 : _limitValue(value, min, max);\n}\n\nfunction parseBorderWidth(bar, maxW, maxH) {\n const value = bar.options.borderWidth;\n const skip = bar.borderSkipped;\n const o = toTRBL(value);\n\n return {\n t: skipOrLimit(skip.top, o.top, 0, maxH),\n r: skipOrLimit(skip.right, o.right, 0, maxW),\n b: skipOrLimit(skip.bottom, o.bottom, 0, maxH),\n l: skipOrLimit(skip.left, o.left, 0, maxW)\n };\n}\n\nfunction parseBorderRadius(bar, maxW, maxH) {\n const {enableBorderRadius} = bar.getProps(['enableBorderRadius']);\n const value = bar.options.borderRadius;\n const o = toTRBLCorners(value);\n const maxR = Math.min(maxW, maxH);\n const skip = bar.borderSkipped;\n\n // If the value is an object, assume the user knows what they are doing\n // and apply as directed.\n const enableBorder = enableBorderRadius || isObject(value);\n\n return {\n topLeft: skipOrLimit(!enableBorder || skip.top || skip.left, o.topLeft, 0, maxR),\n topRight: skipOrLimit(!enableBorder || skip.top || skip.right, o.topRight, 0, maxR),\n bottomLeft: skipOrLimit(!enableBorder || skip.bottom || skip.left, o.bottomLeft, 0, maxR),\n bottomRight: skipOrLimit(!enableBorder || skip.bottom || skip.right, o.bottomRight, 0, maxR)\n };\n}\n\nfunction boundingRects(bar) {\n const bounds = getBarBounds(bar);\n const width = bounds.right - bounds.left;\n const height = bounds.bottom - bounds.top;\n const border = parseBorderWidth(bar, width / 2, height / 2);\n const radius = parseBorderRadius(bar, width / 2, height / 2);\n\n return {\n outer: {\n x: bounds.left,\n y: bounds.top,\n w: width,\n h: height,\n radius\n },\n inner: {\n x: bounds.left + border.l,\n y: bounds.top + border.t,\n w: width - border.l - border.r,\n h: height - border.t - border.b,\n radius: {\n topLeft: Math.max(0, radius.topLeft - Math.max(border.t, border.l)),\n topRight: Math.max(0, radius.topRight - Math.max(border.t, border.r)),\n bottomLeft: Math.max(0, radius.bottomLeft - Math.max(border.b, border.l)),\n bottomRight: Math.max(0, radius.bottomRight - Math.max(border.b, border.r)),\n }\n }\n };\n}\n\nfunction inRange(bar, x, y, useFinalPosition) {\n const skipX = x === null;\n const skipY = y === null;\n const skipBoth = skipX && skipY;\n const bounds = bar && !skipBoth && getBarBounds(bar, useFinalPosition);\n\n return bounds\n\t\t&& (skipX || _isBetween(x, bounds.left, bounds.right))\n\t\t&& (skipY || _isBetween(y, bounds.top, bounds.bottom));\n}\n\nfunction hasRadius(radius) {\n return radius.topLeft || radius.topRight || radius.bottomLeft || radius.bottomRight;\n}\n\n/**\n * Add a path of a rectangle to the current sub-path\n * @param {CanvasRenderingContext2D} ctx Context\n * @param {*} rect Bounding rect\n */\nfunction addNormalRectPath(ctx, rect) {\n ctx.rect(rect.x, rect.y, rect.w, rect.h);\n}\n\nfunction inflateRect(rect, amount, refRect = {}) {\n const x = rect.x !== refRect.x ? -amount : 0;\n const y = rect.y !== refRect.y ? -amount : 0;\n const w = (rect.x + rect.w !== refRect.x + refRect.w ? amount : 0) - x;\n const h = (rect.y + rect.h !== refRect.y + refRect.h ? amount : 0) - y;\n return {\n x: rect.x + x,\n y: rect.y + y,\n w: rect.w + w,\n h: rect.h + h,\n radius: rect.radius\n };\n}\n\nexport default class BarElement extends Element {\n\n static id = 'bar';\n\n /**\n * @type {any}\n */\n static defaults = {\n borderSkipped: 'start',\n borderWidth: 0,\n borderRadius: 0,\n inflateAmount: 'auto',\n pointStyle: undefined\n };\n\n /**\n * @type {any}\n */\n static defaultRoutes = {\n backgroundColor: 'backgroundColor',\n borderColor: 'borderColor'\n };\n\n constructor(cfg) {\n super();\n\n this.options = undefined;\n this.horizontal = undefined;\n this.base = undefined;\n this.width = undefined;\n this.height = undefined;\n this.inflateAmount = undefined;\n\n if (cfg) {\n Object.assign(this, cfg);\n }\n }\n\n draw(ctx) {\n const {inflateAmount, options: {borderColor, backgroundColor}} = this;\n const {inner, outer} = boundingRects(this);\n const addRectPath = hasRadius(outer.radius) ? addRoundedRectPath : addNormalRectPath;\n\n ctx.save();\n\n if (outer.w !== inner.w || outer.h !== inner.h) {\n ctx.beginPath();\n addRectPath(ctx, inflateRect(outer, inflateAmount, inner));\n ctx.clip();\n addRectPath(ctx, inflateRect(inner, -inflateAmount, outer));\n ctx.fillStyle = borderColor;\n ctx.fill('evenodd');\n }\n\n ctx.beginPath();\n addRectPath(ctx, inflateRect(inner, inflateAmount));\n ctx.fillStyle = backgroundColor;\n ctx.fill();\n\n ctx.restore();\n }\n\n inRange(mouseX, mouseY, useFinalPosition) {\n return inRange(this, mouseX, mouseY, useFinalPosition);\n }\n\n inXRange(mouseX, useFinalPosition) {\n return inRange(this, mouseX, null, useFinalPosition);\n }\n\n inYRange(mouseY, useFinalPosition) {\n return inRange(this, null, mouseY, useFinalPosition);\n }\n\n getCenterPoint(useFinalPosition) {\n const {x, y, base, horizontal} = /** @type {BarProps} */ (this.getProps(['x', 'y', 'base', 'horizontal'], useFinalPosition));\n return {\n x: horizontal ? (x + base) / 2 : x,\n y: horizontal ? y : (y + base) / 2\n };\n }\n\n getRange(axis) {\n return axis === 'x' ? this.width / 2 : this.height / 2;\n }\n}\n","import defaults from '../core/core.defaults.js';\nimport Element from '../core/core.element.js';\nimport layouts from '../core/core.layouts.js';\nimport {addRoundedRectPath, drawPointLegend, renderText} from '../helpers/helpers.canvas.js';\nimport {\n _isBetween,\n callback as call,\n clipArea,\n getRtlAdapter,\n overrideTextDirection,\n restoreTextDirection,\n toFont,\n toPadding,\n unclipArea,\n valueOrDefault,\n} from '../helpers/index.js';\nimport {_alignStartEnd, _textX, _toLeftRightCenter} from '../helpers/helpers.extras.js';\nimport {toTRBLCorners} from '../helpers/helpers.options.js';\n\n/**\n * @typedef { import('../types/index.js').ChartEvent } ChartEvent\n */\n\nconst getBoxSize = (labelOpts, fontSize) => {\n let {boxHeight = fontSize, boxWidth = fontSize} = labelOpts;\n\n if (labelOpts.usePointStyle) {\n boxHeight = Math.min(boxHeight, fontSize);\n boxWidth = labelOpts.pointStyleWidth || Math.min(boxWidth, fontSize);\n }\n\n return {\n boxWidth,\n boxHeight,\n itemHeight: Math.max(fontSize, boxHeight)\n };\n};\n\nconst itemsEqual = (a, b) => a !== null && b !== null && a.datasetIndex === b.datasetIndex && a.index === b.index;\n\nexport class Legend extends Element {\n\n /**\n\t * @param {{ ctx: any; options: any; chart: any; }} config\n\t */\n constructor(config) {\n super();\n\n this._added = false;\n\n // Contains hit boxes for each dataset (in dataset order)\n this.legendHitBoxes = [];\n\n /**\n \t\t * @private\n \t\t */\n this._hoveredItem = null;\n\n // Are we in doughnut mode which has a different data type\n this.doughnutMode = false;\n\n this.chart = config.chart;\n this.options = config.options;\n this.ctx = config.ctx;\n this.legendItems = undefined;\n this.columnSizes = undefined;\n this.lineWidths = undefined;\n this.maxHeight = undefined;\n this.maxWidth = undefined;\n this.top = undefined;\n this.bottom = undefined;\n this.left = undefined;\n this.right = undefined;\n this.height = undefined;\n this.width = undefined;\n this._margins = undefined;\n this.position = undefined;\n this.weight = undefined;\n this.fullSize = undefined;\n }\n\n update(maxWidth, maxHeight, margins) {\n this.maxWidth = maxWidth;\n this.maxHeight = maxHeight;\n this._margins = margins;\n\n this.setDimensions();\n this.buildLabels();\n this.fit();\n }\n\n setDimensions() {\n if (this.isHorizontal()) {\n this.width = this.maxWidth;\n this.left = this._margins.left;\n this.right = this.width;\n } else {\n this.height = this.maxHeight;\n this.top = this._margins.top;\n this.bottom = this.height;\n }\n }\n\n buildLabels() {\n const labelOpts = this.options.labels || {};\n let legendItems = call(labelOpts.generateLabels, [this.chart], this) || [];\n\n if (labelOpts.filter) {\n legendItems = legendItems.filter((item) => labelOpts.filter(item, this.chart.data));\n }\n\n if (labelOpts.sort) {\n legendItems = legendItems.sort((a, b) => labelOpts.sort(a, b, this.chart.data));\n }\n\n if (this.options.reverse) {\n legendItems.reverse();\n }\n\n this.legendItems = legendItems;\n }\n\n fit() {\n const {options, ctx} = this;\n\n // The legend may not be displayed for a variety of reasons including\n // the fact that the defaults got set to `false`.\n // When the legend is not displayed, there are no guarantees that the options\n // are correctly formatted so we need to bail out as early as possible.\n if (!options.display) {\n this.width = this.height = 0;\n return;\n }\n\n const labelOpts = options.labels;\n const labelFont = toFont(labelOpts.font);\n const fontSize = labelFont.size;\n const titleHeight = this._computeTitleHeight();\n const {boxWidth, itemHeight} = getBoxSize(labelOpts, fontSize);\n\n let width, height;\n\n ctx.font = labelFont.string;\n\n if (this.isHorizontal()) {\n width = this.maxWidth; // fill all the width\n height = this._fitRows(titleHeight, fontSize, boxWidth, itemHeight) + 10;\n } else {\n height = this.maxHeight; // fill all the height\n width = this._fitCols(titleHeight, labelFont, boxWidth, itemHeight) + 10;\n }\n\n this.width = Math.min(width, options.maxWidth || this.maxWidth);\n this.height = Math.min(height, options.maxHeight || this.maxHeight);\n }\n\n /**\n\t * @private\n\t */\n _fitRows(titleHeight, fontSize, boxWidth, itemHeight) {\n const {ctx, maxWidth, options: {labels: {padding}}} = this;\n const hitboxes = this.legendHitBoxes = [];\n // Width of each line of legend boxes. Labels wrap onto multiple lines when there are too many to fit on one\n const lineWidths = this.lineWidths = [0];\n const lineHeight = itemHeight + padding;\n let totalHeight = titleHeight;\n\n ctx.textAlign = 'left';\n ctx.textBaseline = 'middle';\n\n let row = -1;\n let top = -lineHeight;\n this.legendItems.forEach((legendItem, i) => {\n const itemWidth = boxWidth + (fontSize / 2) + ctx.measureText(legendItem.text).width;\n\n if (i === 0 || lineWidths[lineWidths.length - 1] + itemWidth + 2 * padding > maxWidth) {\n totalHeight += lineHeight;\n lineWidths[lineWidths.length - (i > 0 ? 0 : 1)] = 0;\n top += lineHeight;\n row++;\n }\n\n hitboxes[i] = {left: 0, top, row, width: itemWidth, height: itemHeight};\n\n lineWidths[lineWidths.length - 1] += itemWidth + padding;\n });\n\n return totalHeight;\n }\n\n _fitCols(titleHeight, labelFont, boxWidth, _itemHeight) {\n const {ctx, maxHeight, options: {labels: {padding}}} = this;\n const hitboxes = this.legendHitBoxes = [];\n const columnSizes = this.columnSizes = [];\n const heightLimit = maxHeight - titleHeight;\n\n let totalWidth = padding;\n let currentColWidth = 0;\n let currentColHeight = 0;\n\n let left = 0;\n let col = 0;\n\n this.legendItems.forEach((legendItem, i) => {\n const {itemWidth, itemHeight} = calculateItemSize(boxWidth, labelFont, ctx, legendItem, _itemHeight);\n\n // If too tall, go to new column\n if (i > 0 && currentColHeight + itemHeight + 2 * padding > heightLimit) {\n totalWidth += currentColWidth + padding;\n columnSizes.push({width: currentColWidth, height: currentColHeight}); // previous column size\n left += currentColWidth + padding;\n col++;\n currentColWidth = currentColHeight = 0;\n }\n\n // Store the hitbox width and height here. Final position will be updated in `draw`\n hitboxes[i] = {left, top: currentColHeight, col, width: itemWidth, height: itemHeight};\n\n // Get max width\n currentColWidth = Math.max(currentColWidth, itemWidth);\n currentColHeight += itemHeight + padding;\n });\n\n totalWidth += currentColWidth;\n columnSizes.push({width: currentColWidth, height: currentColHeight}); // previous column size\n\n return totalWidth;\n }\n\n adjustHitBoxes() {\n if (!this.options.display) {\n return;\n }\n const titleHeight = this._computeTitleHeight();\n const {legendHitBoxes: hitboxes, options: {align, labels: {padding}, rtl}} = this;\n const rtlHelper = getRtlAdapter(rtl, this.left, this.width);\n if (this.isHorizontal()) {\n let row = 0;\n let left = _alignStartEnd(align, this.left + padding, this.right - this.lineWidths[row]);\n for (const hitbox of hitboxes) {\n if (row !== hitbox.row) {\n row = hitbox.row;\n left = _alignStartEnd(align, this.left + padding, this.right - this.lineWidths[row]);\n }\n hitbox.top += this.top + titleHeight + padding;\n hitbox.left = rtlHelper.leftForLtr(rtlHelper.x(left), hitbox.width);\n left += hitbox.width + padding;\n }\n } else {\n let col = 0;\n let top = _alignStartEnd(align, this.top + titleHeight + padding, this.bottom - this.columnSizes[col].height);\n for (const hitbox of hitboxes) {\n if (hitbox.col !== col) {\n col = hitbox.col;\n top = _alignStartEnd(align, this.top + titleHeight + padding, this.bottom - this.columnSizes[col].height);\n }\n hitbox.top = top;\n hitbox.left += this.left + padding;\n hitbox.left = rtlHelper.leftForLtr(rtlHelper.x(hitbox.left), hitbox.width);\n top += hitbox.height + padding;\n }\n }\n }\n\n isHorizontal() {\n return this.options.position === 'top' || this.options.position === 'bottom';\n }\n\n draw() {\n if (this.options.display) {\n const ctx = this.ctx;\n clipArea(ctx, this);\n\n this._draw();\n\n unclipArea(ctx);\n }\n }\n\n /**\n\t * @private\n\t */\n _draw() {\n const {options: opts, columnSizes, lineWidths, ctx} = this;\n const {align, labels: labelOpts} = opts;\n const defaultColor = defaults.color;\n const rtlHelper = getRtlAdapter(opts.rtl, this.left, this.width);\n const labelFont = toFont(labelOpts.font);\n const {padding} = labelOpts;\n const fontSize = labelFont.size;\n const halfFontSize = fontSize / 2;\n let cursor;\n\n this.drawTitle();\n\n // Canvas setup\n ctx.textAlign = rtlHelper.textAlign('left');\n ctx.textBaseline = 'middle';\n ctx.lineWidth = 0.5;\n ctx.font = labelFont.string;\n\n const {boxWidth, boxHeight, itemHeight} = getBoxSize(labelOpts, fontSize);\n\n // current position\n const drawLegendBox = function(x, y, legendItem) {\n if (isNaN(boxWidth) || boxWidth <= 0 || isNaN(boxHeight) || boxHeight < 0) {\n return;\n }\n\n // Set the ctx for the box\n ctx.save();\n\n const lineWidth = valueOrDefault(legendItem.lineWidth, 1);\n ctx.fillStyle = valueOrDefault(legendItem.fillStyle, defaultColor);\n ctx.lineCap = valueOrDefault(legendItem.lineCap, 'butt');\n ctx.lineDashOffset = valueOrDefault(legendItem.lineDashOffset, 0);\n ctx.lineJoin = valueOrDefault(legendItem.lineJoin, 'miter');\n ctx.lineWidth = lineWidth;\n ctx.strokeStyle = valueOrDefault(legendItem.strokeStyle, defaultColor);\n\n ctx.setLineDash(valueOrDefault(legendItem.lineDash, []));\n\n if (labelOpts.usePointStyle) {\n // Recalculate x and y for drawPoint() because its expecting\n // x and y to be center of figure (instead of top left)\n const drawOptions = {\n radius: boxHeight * Math.SQRT2 / 2,\n pointStyle: legendItem.pointStyle,\n rotation: legendItem.rotation,\n borderWidth: lineWidth\n };\n const centerX = rtlHelper.xPlus(x, boxWidth / 2);\n const centerY = y + halfFontSize;\n\n // Draw pointStyle as legend symbol\n drawPointLegend(ctx, drawOptions, centerX, centerY, labelOpts.pointStyleWidth && boxWidth);\n } else {\n // Draw box as legend symbol\n // Adjust position when boxHeight < fontSize (want it centered)\n const yBoxTop = y + Math.max((fontSize - boxHeight) / 2, 0);\n const xBoxLeft = rtlHelper.leftForLtr(x, boxWidth);\n const borderRadius = toTRBLCorners(legendItem.borderRadius);\n\n ctx.beginPath();\n\n if (Object.values(borderRadius).some(v => v !== 0)) {\n addRoundedRectPath(ctx, {\n x: xBoxLeft,\n y: yBoxTop,\n w: boxWidth,\n h: boxHeight,\n radius: borderRadius,\n });\n } else {\n ctx.rect(xBoxLeft, yBoxTop, boxWidth, boxHeight);\n }\n\n ctx.fill();\n if (lineWidth !== 0) {\n ctx.stroke();\n }\n }\n\n ctx.restore();\n };\n\n const fillText = function(x, y, legendItem) {\n renderText(ctx, legendItem.text, x, y + (itemHeight / 2), labelFont, {\n strikethrough: legendItem.hidden,\n textAlign: rtlHelper.textAlign(legendItem.textAlign)\n });\n };\n\n // Horizontal\n const isHorizontal = this.isHorizontal();\n const titleHeight = this._computeTitleHeight();\n if (isHorizontal) {\n cursor = {\n x: _alignStartEnd(align, this.left + padding, this.right - lineWidths[0]),\n y: this.top + padding + titleHeight,\n line: 0\n };\n } else {\n cursor = {\n x: this.left + padding,\n y: _alignStartEnd(align, this.top + titleHeight + padding, this.bottom - columnSizes[0].height),\n line: 0\n };\n }\n\n overrideTextDirection(this.ctx, opts.textDirection);\n\n const lineHeight = itemHeight + padding;\n this.legendItems.forEach((legendItem, i) => {\n ctx.strokeStyle = legendItem.fontColor; // for strikethrough effect\n ctx.fillStyle = legendItem.fontColor; // render in correct colour\n\n const textWidth = ctx.measureText(legendItem.text).width;\n const textAlign = rtlHelper.textAlign(legendItem.textAlign || (legendItem.textAlign = labelOpts.textAlign));\n const width = boxWidth + halfFontSize + textWidth;\n let x = cursor.x;\n let y = cursor.y;\n\n rtlHelper.setWidth(this.width);\n\n if (isHorizontal) {\n if (i > 0 && x + width + padding > this.right) {\n y = cursor.y += lineHeight;\n cursor.line++;\n x = cursor.x = _alignStartEnd(align, this.left + padding, this.right - lineWidths[cursor.line]);\n }\n } else if (i > 0 && y + lineHeight > this.bottom) {\n x = cursor.x = x + columnSizes[cursor.line].width + padding;\n cursor.line++;\n y = cursor.y = _alignStartEnd(align, this.top + titleHeight + padding, this.bottom - columnSizes[cursor.line].height);\n }\n\n const realX = rtlHelper.x(x);\n\n drawLegendBox(realX, y, legendItem);\n\n x = _textX(textAlign, x + boxWidth + halfFontSize, isHorizontal ? x + width : this.right, opts.rtl);\n\n // Fill the actual label\n fillText(rtlHelper.x(x), y, legendItem);\n\n if (isHorizontal) {\n cursor.x += width + padding;\n } else if (typeof legendItem.text !== 'string') {\n const fontLineHeight = labelFont.lineHeight;\n cursor.y += calculateLegendItemHeight(legendItem, fontLineHeight) + padding;\n } else {\n cursor.y += lineHeight;\n }\n });\n\n restoreTextDirection(this.ctx, opts.textDirection);\n }\n\n /**\n\t * @protected\n\t */\n drawTitle() {\n const opts = this.options;\n const titleOpts = opts.title;\n const titleFont = toFont(titleOpts.font);\n const titlePadding = toPadding(titleOpts.padding);\n\n if (!titleOpts.display) {\n return;\n }\n\n const rtlHelper = getRtlAdapter(opts.rtl, this.left, this.width);\n const ctx = this.ctx;\n const position = titleOpts.position;\n const halfFontSize = titleFont.size / 2;\n const topPaddingPlusHalfFontSize = titlePadding.top + halfFontSize;\n let y;\n\n // These defaults are used when the legend is vertical.\n // When horizontal, they are computed below.\n let left = this.left;\n let maxWidth = this.width;\n\n if (this.isHorizontal()) {\n // Move left / right so that the title is above the legend lines\n maxWidth = Math.max(...this.lineWidths);\n y = this.top + topPaddingPlusHalfFontSize;\n left = _alignStartEnd(opts.align, left, this.right - maxWidth);\n } else {\n // Move down so that the title is above the legend stack in every alignment\n const maxHeight = this.columnSizes.reduce((acc, size) => Math.max(acc, size.height), 0);\n y = topPaddingPlusHalfFontSize + _alignStartEnd(opts.align, this.top, this.bottom - maxHeight - opts.labels.padding - this._computeTitleHeight());\n }\n\n // Now that we know the left edge of the inner legend box, compute the correct\n // X coordinate from the title alignment\n const x = _alignStartEnd(position, left, left + maxWidth);\n\n // Canvas setup\n ctx.textAlign = rtlHelper.textAlign(_toLeftRightCenter(position));\n ctx.textBaseline = 'middle';\n ctx.strokeStyle = titleOpts.color;\n ctx.fillStyle = titleOpts.color;\n ctx.font = titleFont.string;\n\n renderText(ctx, titleOpts.text, x, y, titleFont);\n }\n\n /**\n\t * @private\n\t */\n _computeTitleHeight() {\n const titleOpts = this.options.title;\n const titleFont = toFont(titleOpts.font);\n const titlePadding = toPadding(titleOpts.padding);\n return titleOpts.display ? titleFont.lineHeight + titlePadding.height : 0;\n }\n\n /**\n\t * @private\n\t */\n _getLegendItemAt(x, y) {\n let i, hitBox, lh;\n\n if (_isBetween(x, this.left, this.right)\n && _isBetween(y, this.top, this.bottom)) {\n // See if we are touching one of the dataset boxes\n lh = this.legendHitBoxes;\n for (i = 0; i < lh.length; ++i) {\n hitBox = lh[i];\n\n if (_isBetween(x, hitBox.left, hitBox.left + hitBox.width)\n && _isBetween(y, hitBox.top, hitBox.top + hitBox.height)) {\n // Touching an element\n return this.legendItems[i];\n }\n }\n }\n\n return null;\n }\n\n /**\n\t * Handle an event\n\t * @param {ChartEvent} e - The event to handle\n\t */\n handleEvent(e) {\n const opts = this.options;\n if (!isListened(e.type, opts)) {\n return;\n }\n\n // Chart event already has relative position in it\n const hoveredItem = this._getLegendItemAt(e.x, e.y);\n\n if (e.type === 'mousemove' || e.type === 'mouseout') {\n const previous = this._hoveredItem;\n const sameItem = itemsEqual(previous, hoveredItem);\n if (previous && !sameItem) {\n call(opts.onLeave, [e, previous, this], this);\n }\n\n this._hoveredItem = hoveredItem;\n\n if (hoveredItem && !sameItem) {\n call(opts.onHover, [e, hoveredItem, this], this);\n }\n } else if (hoveredItem) {\n call(opts.onClick, [e, hoveredItem, this], this);\n }\n }\n}\n\nfunction calculateItemSize(boxWidth, labelFont, ctx, legendItem, _itemHeight) {\n const itemWidth = calculateItemWidth(legendItem, boxWidth, labelFont, ctx);\n const itemHeight = calculateItemHeight(_itemHeight, legendItem, labelFont.lineHeight);\n return {itemWidth, itemHeight};\n}\n\nfunction calculateItemWidth(legendItem, boxWidth, labelFont, ctx) {\n let legendItemText = legendItem.text;\n if (legendItemText && typeof legendItemText !== 'string') {\n legendItemText = legendItemText.reduce((a, b) => a.length > b.length ? a : b);\n }\n return boxWidth + (labelFont.size / 2) + ctx.measureText(legendItemText).width;\n}\n\nfunction calculateItemHeight(_itemHeight, legendItem, fontLineHeight) {\n let itemHeight = _itemHeight;\n if (typeof legendItem.text !== 'string') {\n itemHeight = calculateLegendItemHeight(legendItem, fontLineHeight);\n }\n return itemHeight;\n}\n\nfunction calculateLegendItemHeight(legendItem, fontLineHeight) {\n const labelHeight = legendItem.text ? legendItem.text.length : 0;\n return fontLineHeight * labelHeight;\n}\n\nfunction isListened(type, opts) {\n if ((type === 'mousemove' || type === 'mouseout') && (opts.onHover || opts.onLeave)) {\n return true;\n }\n if (opts.onClick && (type === 'click' || type === 'mouseup')) {\n return true;\n }\n return false;\n}\n\nexport default {\n id: 'legend',\n\n /**\n\t * For tests\n\t * @private\n\t */\n _element: Legend,\n\n start(chart, _args, options) {\n const legend = chart.legend = new Legend({ctx: chart.ctx, options, chart});\n layouts.configure(chart, legend, options);\n layouts.addBox(chart, legend);\n },\n\n stop(chart) {\n layouts.removeBox(chart, chart.legend);\n delete chart.legend;\n },\n\n // During the beforeUpdate step, the layout configuration needs to run\n // This ensures that if the legend position changes (via an option update)\n // the layout system respects the change. See https://github.com/chartjs/Chart.js/issues/7527\n beforeUpdate(chart, _args, options) {\n const legend = chart.legend;\n layouts.configure(chart, legend, options);\n legend.options = options;\n },\n\n // The labels need to be built after datasets are updated to ensure that colors\n // and other styling are correct. See https://github.com/chartjs/Chart.js/issues/6968\n afterUpdate(chart) {\n const legend = chart.legend;\n legend.buildLabels();\n legend.adjustHitBoxes();\n },\n\n\n afterEvent(chart, args) {\n if (!args.replay) {\n chart.legend.handleEvent(args.event);\n }\n },\n\n defaults: {\n display: true,\n position: 'top',\n align: 'center',\n fullSize: true,\n reverse: false,\n weight: 1000,\n\n // a callback that will handle\n onClick(e, legendItem, legend) {\n const index = legendItem.datasetIndex;\n const ci = legend.chart;\n if (ci.isDatasetVisible(index)) {\n ci.hide(index);\n legendItem.hidden = true;\n } else {\n ci.show(index);\n legendItem.hidden = false;\n }\n },\n\n onHover: null,\n onLeave: null,\n\n labels: {\n color: (ctx) => ctx.chart.options.color,\n boxWidth: 40,\n padding: 10,\n // Generates labels shown in the legend\n // Valid properties to return:\n // text : text to display\n // fillStyle : fill of coloured box\n // strokeStyle: stroke of coloured box\n // hidden : if this legend item refers to a hidden item\n // lineCap : cap style for line\n // lineDash\n // lineDashOffset :\n // lineJoin :\n // lineWidth :\n generateLabels(chart) {\n const datasets = chart.data.datasets;\n const {labels: {usePointStyle, pointStyle, textAlign, color, useBorderRadius, borderRadius}} = chart.legend.options;\n\n return chart._getSortedDatasetMetas().map((meta) => {\n const style = meta.controller.getStyle(usePointStyle ? 0 : undefined);\n const borderWidth = toPadding(style.borderWidth);\n\n return {\n text: datasets[meta.index].label,\n fillStyle: style.backgroundColor,\n fontColor: color,\n hidden: !meta.visible,\n lineCap: style.borderCapStyle,\n lineDash: style.borderDash,\n lineDashOffset: style.borderDashOffset,\n lineJoin: style.borderJoinStyle,\n lineWidth: (borderWidth.width + borderWidth.height) / 4,\n strokeStyle: style.borderColor,\n pointStyle: pointStyle || style.pointStyle,\n rotation: style.rotation,\n textAlign: textAlign || style.textAlign,\n borderRadius: useBorderRadius && (borderRadius || style.borderRadius),\n\n // Below is extra data used for toggling the datasets\n datasetIndex: meta.index\n };\n }, this);\n }\n },\n\n title: {\n color: (ctx) => ctx.chart.options.color,\n display: false,\n position: 'center',\n text: '',\n }\n },\n\n descriptors: {\n _scriptable: (name) => !name.startsWith('on'),\n labels: {\n _scriptable: (name) => !['generateLabels', 'filter', 'sort'].includes(name),\n }\n },\n};\n","import {Title} from './plugin.title.js';\nimport layouts from '../core/core.layouts.js';\n\nconst map = new WeakMap();\n\nexport default {\n id: 'subtitle',\n\n start(chart, _args, options) {\n const title = new Title({\n ctx: chart.ctx,\n options,\n chart\n });\n\n layouts.configure(chart, title, options);\n layouts.addBox(chart, title);\n map.set(chart, title);\n },\n\n stop(chart) {\n layouts.removeBox(chart, map.get(chart));\n map.delete(chart);\n },\n\n beforeUpdate(chart, _args, options) {\n const title = map.get(chart);\n layouts.configure(chart, title, options);\n title.options = options;\n },\n\n defaults: {\n align: 'center',\n display: false,\n font: {\n weight: 'normal',\n },\n fullSize: true,\n padding: 0,\n position: 'top',\n text: '',\n weight: 1500 // by default greater than legend (1000) and smaller than title (2000)\n },\n\n defaultRoutes: {\n color: 'color'\n },\n\n descriptors: {\n _scriptable: true,\n _indexable: false,\n },\n};\n","import Animations from '../core/core.animations.js';\nimport Element from '../core/core.element.js';\nimport {addRoundedRectPath} from '../helpers/helpers.canvas.js';\nimport {each, noop, isNullOrUndef, isArray, _elementsEqual, isObject} from '../helpers/helpers.core.js';\nimport {toFont, toPadding, toTRBLCorners} from '../helpers/helpers.options.js';\nimport {getRtlAdapter, overrideTextDirection, restoreTextDirection} from '../helpers/helpers.rtl.js';\nimport {distanceBetweenPoints, _limitValue} from '../helpers/helpers.math.js';\nimport {createContext, drawPoint} from '../helpers/index.js';\n\n/**\n * @typedef { import('../platform/platform.base.js').Chart } Chart\n * @typedef { import('../types/index.js').ChartEvent } ChartEvent\n * @typedef { import('../types/index.js').ActiveElement } ActiveElement\n * @typedef { import('../core/core.interaction.js').InteractionItem } InteractionItem\n */\n\nconst positioners = {\n /**\n\t * Average mode places the tooltip at the average position of the elements shown\n\t */\n average(items) {\n if (!items.length) {\n return false;\n }\n\n let i, len;\n let xSet = new Set();\n let y = 0;\n let count = 0;\n\n for (i = 0, len = items.length; i < len; ++i) {\n const el = items[i].element;\n if (el && el.hasValue()) {\n const pos = el.tooltipPosition();\n xSet.add(pos.x);\n y += pos.y;\n ++count;\n }\n }\n\n // No visible items where found, return false so we don't have to divide by 0 which reduces in NaN\n if (count === 0 || xSet.size === 0) {\n return false;\n }\n\n const xAverage = [...xSet].reduce((a, b) => a + b) / xSet.size;\n\n return {\n x: xAverage,\n y: y / count\n };\n },\n\n /**\n\t * Gets the tooltip position nearest of the item nearest to the event position\n\t */\n nearest(items, eventPosition) {\n if (!items.length) {\n return false;\n }\n\n let x = eventPosition.x;\n let y = eventPosition.y;\n let minDistance = Number.POSITIVE_INFINITY;\n let i, len, nearestElement;\n\n for (i = 0, len = items.length; i < len; ++i) {\n const el = items[i].element;\n if (el && el.hasValue()) {\n const center = el.getCenterPoint();\n const d = distanceBetweenPoints(eventPosition, center);\n\n if (d < minDistance) {\n minDistance = d;\n nearestElement = el;\n }\n }\n }\n\n if (nearestElement) {\n const tp = nearestElement.tooltipPosition();\n x = tp.x;\n y = tp.y;\n }\n\n return {\n x,\n y\n };\n }\n};\n\n// Helper to push or concat based on if the 2nd parameter is an array or not\nfunction pushOrConcat(base, toPush) {\n if (toPush) {\n if (isArray(toPush)) {\n // base = base.concat(toPush);\n Array.prototype.push.apply(base, toPush);\n } else {\n base.push(toPush);\n }\n }\n\n return base;\n}\n\n/**\n * Returns array of strings split by newline\n * @param {*} str - The value to split by newline.\n * @returns {string|string[]} value if newline present - Returned from String split() method\n * @function\n */\nfunction splitNewlines(str) {\n if ((typeof str === 'string' || str instanceof String) && str.indexOf('\\n') > -1) {\n return str.split('\\n');\n }\n return str;\n}\n\n\n/**\n * Private helper to create a tooltip item model\n * @param {Chart} chart\n * @param {ActiveElement} item - {element, index, datasetIndex} to create the tooltip item for\n * @return new tooltip item\n */\nfunction createTooltipItem(chart, item) {\n const {element, datasetIndex, index} = item;\n const controller = chart.getDatasetMeta(datasetIndex).controller;\n const {label, value} = controller.getLabelAndValue(index);\n\n return {\n chart,\n label,\n parsed: controller.getParsed(index),\n raw: chart.data.datasets[datasetIndex].data[index],\n formattedValue: value,\n dataset: controller.getDataset(),\n dataIndex: index,\n datasetIndex,\n element\n };\n}\n\n/**\n * Get the size of the tooltip\n */\nfunction getTooltipSize(tooltip, options) {\n const ctx = tooltip.chart.ctx;\n const {body, footer, title} = tooltip;\n const {boxWidth, boxHeight} = options;\n const bodyFont = toFont(options.bodyFont);\n const titleFont = toFont(options.titleFont);\n const footerFont = toFont(options.footerFont);\n const titleLineCount = title.length;\n const footerLineCount = footer.length;\n const bodyLineItemCount = body.length;\n\n const padding = toPadding(options.padding);\n let height = padding.height;\n let width = 0;\n\n // Count of all lines in the body\n let combinedBodyLength = body.reduce((count, bodyItem) => count + bodyItem.before.length + bodyItem.lines.length + bodyItem.after.length, 0);\n combinedBodyLength += tooltip.beforeBody.length + tooltip.afterBody.length;\n\n if (titleLineCount) {\n height += titleLineCount * titleFont.lineHeight\n\t\t\t+ (titleLineCount - 1) * options.titleSpacing\n\t\t\t+ options.titleMarginBottom;\n }\n if (combinedBodyLength) {\n // Body lines may include some extra height depending on boxHeight\n const bodyLineHeight = options.displayColors ? Math.max(boxHeight, bodyFont.lineHeight) : bodyFont.lineHeight;\n height += bodyLineItemCount * bodyLineHeight\n\t\t\t+ (combinedBodyLength - bodyLineItemCount) * bodyFont.lineHeight\n\t\t\t+ (combinedBodyLength - 1) * options.bodySpacing;\n }\n if (footerLineCount) {\n height += options.footerMarginTop\n\t\t\t+ footerLineCount * footerFont.lineHeight\n\t\t\t+ (footerLineCount - 1) * options.footerSpacing;\n }\n\n // Title width\n let widthPadding = 0;\n const maxLineWidth = function(line) {\n width = Math.max(width, ctx.measureText(line).width + widthPadding);\n };\n\n ctx.save();\n\n ctx.font = titleFont.string;\n each(tooltip.title, maxLineWidth);\n\n // Body width\n ctx.font = bodyFont.string;\n each(tooltip.beforeBody.concat(tooltip.afterBody), maxLineWidth);\n\n // Body lines may include some extra width due to the color box\n widthPadding = options.displayColors ? (boxWidth + 2 + options.boxPadding) : 0;\n each(body, (bodyItem) => {\n each(bodyItem.before, maxLineWidth);\n each(bodyItem.lines, maxLineWidth);\n each(bodyItem.after, maxLineWidth);\n });\n\n // Reset back to 0\n widthPadding = 0;\n\n // Footer width\n ctx.font = footerFont.string;\n each(tooltip.footer, maxLineWidth);\n\n ctx.restore();\n\n // Add padding\n width += padding.width;\n\n return {width, height};\n}\n\nfunction determineYAlign(chart, size) {\n const {y, height} = size;\n\n if (y < height / 2) {\n return 'top';\n } else if (y > (chart.height - height / 2)) {\n return 'bottom';\n }\n return 'center';\n}\n\nfunction doesNotFitWithAlign(xAlign, chart, options, size) {\n const {x, width} = size;\n const caret = options.caretSize + options.caretPadding;\n if (xAlign === 'left' && x + width + caret > chart.width) {\n return true;\n }\n\n if (xAlign === 'right' && x - width - caret < 0) {\n return true;\n }\n}\n\nfunction determineXAlign(chart, options, size, yAlign) {\n const {x, width} = size;\n const {width: chartWidth, chartArea: {left, right}} = chart;\n let xAlign = 'center';\n\n if (yAlign === 'center') {\n xAlign = x <= (left + right) / 2 ? 'left' : 'right';\n } else if (x <= width / 2) {\n xAlign = 'left';\n } else if (x >= chartWidth - width / 2) {\n xAlign = 'right';\n }\n\n if (doesNotFitWithAlign(xAlign, chart, options, size)) {\n xAlign = 'center';\n }\n\n return xAlign;\n}\n\n/**\n * Helper to get the alignment of a tooltip given the size\n */\nfunction determineAlignment(chart, options, size) {\n const yAlign = size.yAlign || options.yAlign || determineYAlign(chart, size);\n\n return {\n xAlign: size.xAlign || options.xAlign || determineXAlign(chart, options, size, yAlign),\n yAlign\n };\n}\n\nfunction alignX(size, xAlign) {\n let {x, width} = size;\n if (xAlign === 'right') {\n x -= width;\n } else if (xAlign === 'center') {\n x -= (width / 2);\n }\n return x;\n}\n\nfunction alignY(size, yAlign, paddingAndSize) {\n // eslint-disable-next-line prefer-const\n let {y, height} = size;\n if (yAlign === 'top') {\n y += paddingAndSize;\n } else if (yAlign === 'bottom') {\n y -= height + paddingAndSize;\n } else {\n y -= (height / 2);\n }\n return y;\n}\n\n/**\n * Helper to get the location a tooltip needs to be placed at given the initial position (via the vm) and the size and alignment\n */\nfunction getBackgroundPoint(options, size, alignment, chart) {\n const {caretSize, caretPadding, cornerRadius} = options;\n const {xAlign, yAlign} = alignment;\n const paddingAndSize = caretSize + caretPadding;\n const {topLeft, topRight, bottomLeft, bottomRight} = toTRBLCorners(cornerRadius);\n\n let x = alignX(size, xAlign);\n const y = alignY(size, yAlign, paddingAndSize);\n\n if (yAlign === 'center') {\n if (xAlign === 'left') {\n x += paddingAndSize;\n } else if (xAlign === 'right') {\n x -= paddingAndSize;\n }\n } else if (xAlign === 'left') {\n x -= Math.max(topLeft, bottomLeft) + caretSize;\n } else if (xAlign === 'right') {\n x += Math.max(topRight, bottomRight) + caretSize;\n }\n\n return {\n x: _limitValue(x, 0, chart.width - size.width),\n y: _limitValue(y, 0, chart.height - size.height)\n };\n}\n\nfunction getAlignedX(tooltip, align, options) {\n const padding = toPadding(options.padding);\n\n return align === 'center'\n ? tooltip.x + tooltip.width / 2\n : align === 'right'\n ? tooltip.x + tooltip.width - padding.right\n : tooltip.x + padding.left;\n}\n\n/**\n * Helper to build before and after body lines\n */\nfunction getBeforeAfterBodyLines(callback) {\n return pushOrConcat([], splitNewlines(callback));\n}\n\nfunction createTooltipContext(parent, tooltip, tooltipItems) {\n return createContext(parent, {\n tooltip,\n tooltipItems,\n type: 'tooltip'\n });\n}\n\nfunction overrideCallbacks(callbacks, context) {\n const override = context && context.dataset && context.dataset.tooltip && context.dataset.tooltip.callbacks;\n return override ? callbacks.override(override) : callbacks;\n}\n\nconst defaultCallbacks = {\n // Args are: (tooltipItems, data)\n beforeTitle: noop,\n title(tooltipItems) {\n if (tooltipItems.length > 0) {\n const item = tooltipItems[0];\n const labels = item.chart.data.labels;\n const labelCount = labels ? labels.length : 0;\n\n if (this && this.options && this.options.mode === 'dataset') {\n return item.dataset.label || '';\n } else if (item.label) {\n return item.label;\n } else if (labelCount > 0 && item.dataIndex < labelCount) {\n return labels[item.dataIndex];\n }\n }\n\n return '';\n },\n afterTitle: noop,\n\n // Args are: (tooltipItems, data)\n beforeBody: noop,\n\n // Args are: (tooltipItem, data)\n beforeLabel: noop,\n label(tooltipItem) {\n if (this && this.options && this.options.mode === 'dataset') {\n return tooltipItem.label + ': ' + tooltipItem.formattedValue || tooltipItem.formattedValue;\n }\n\n let label = tooltipItem.dataset.label || '';\n\n if (label) {\n label += ': ';\n }\n const value = tooltipItem.formattedValue;\n if (!isNullOrUndef(value)) {\n label += value;\n }\n return label;\n },\n labelColor(tooltipItem) {\n const meta = tooltipItem.chart.getDatasetMeta(tooltipItem.datasetIndex);\n const options = meta.controller.getStyle(tooltipItem.dataIndex);\n return {\n borderColor: options.borderColor,\n backgroundColor: options.backgroundColor,\n borderWidth: options.borderWidth,\n borderDash: options.borderDash,\n borderDashOffset: options.borderDashOffset,\n borderRadius: 0,\n };\n },\n labelTextColor() {\n return this.options.bodyColor;\n },\n labelPointStyle(tooltipItem) {\n const meta = tooltipItem.chart.getDatasetMeta(tooltipItem.datasetIndex);\n const options = meta.controller.getStyle(tooltipItem.dataIndex);\n return {\n pointStyle: options.pointStyle,\n rotation: options.rotation,\n };\n },\n afterLabel: noop,\n\n // Args are: (tooltipItems, data)\n afterBody: noop,\n\n // Args are: (tooltipItems, data)\n beforeFooter: noop,\n footer: noop,\n afterFooter: noop\n};\n\n/**\n * Invoke callback from object with context and arguments.\n * If callback returns `undefined`, then will be invoked default callback.\n * @param {Record} callbacks\n * @param {keyof typeof defaultCallbacks} name\n * @param {*} ctx\n * @param {*} arg\n * @returns {any}\n */\nfunction invokeCallbackWithFallback(callbacks, name, ctx, arg) {\n const result = callbacks[name].call(ctx, arg);\n\n if (typeof result === 'undefined') {\n return defaultCallbacks[name].call(ctx, arg);\n }\n\n return result;\n}\n\nexport class Tooltip extends Element {\n\n /**\n * @namespace Chart.Tooltip.positioners\n */\n static positioners = positioners;\n\n constructor(config) {\n super();\n\n this.opacity = 0;\n this._active = [];\n this._eventPosition = undefined;\n this._size = undefined;\n this._cachedAnimations = undefined;\n this._tooltipItems = [];\n this.$animations = undefined;\n this.$context = undefined;\n this.chart = config.chart;\n this.options = config.options;\n this.dataPoints = undefined;\n this.title = undefined;\n this.beforeBody = undefined;\n this.body = undefined;\n this.afterBody = undefined;\n this.footer = undefined;\n this.xAlign = undefined;\n this.yAlign = undefined;\n this.x = undefined;\n this.y = undefined;\n this.height = undefined;\n this.width = undefined;\n this.caretX = undefined;\n this.caretY = undefined;\n // TODO: V4, make this private, rename to `_labelStyles`, and combine with `labelPointStyles`\n // and `labelTextColors` to create a single variable\n this.labelColors = undefined;\n this.labelPointStyles = undefined;\n this.labelTextColors = undefined;\n }\n\n initialize(options) {\n this.options = options;\n this._cachedAnimations = undefined;\n this.$context = undefined;\n }\n\n /**\n\t * @private\n\t */\n _resolveAnimations() {\n const cached = this._cachedAnimations;\n\n if (cached) {\n return cached;\n }\n\n const chart = this.chart;\n const options = this.options.setContext(this.getContext());\n const opts = options.enabled && chart.options.animation && options.animations;\n const animations = new Animations(this.chart, opts);\n if (opts._cacheable) {\n this._cachedAnimations = Object.freeze(animations);\n }\n\n return animations;\n }\n\n /**\n\t * @protected\n\t */\n getContext() {\n return this.$context ||\n\t\t\t(this.$context = createTooltipContext(this.chart.getContext(), this, this._tooltipItems));\n }\n\n getTitle(context, options) {\n const {callbacks} = options;\n\n const beforeTitle = invokeCallbackWithFallback(callbacks, 'beforeTitle', this, context);\n const title = invokeCallbackWithFallback(callbacks, 'title', this, context);\n const afterTitle = invokeCallbackWithFallback(callbacks, 'afterTitle', this, context);\n\n let lines = [];\n lines = pushOrConcat(lines, splitNewlines(beforeTitle));\n lines = pushOrConcat(lines, splitNewlines(title));\n lines = pushOrConcat(lines, splitNewlines(afterTitle));\n\n return lines;\n }\n\n getBeforeBody(tooltipItems, options) {\n return getBeforeAfterBodyLines(\n invokeCallbackWithFallback(options.callbacks, 'beforeBody', this, tooltipItems)\n );\n }\n\n getBody(tooltipItems, options) {\n const {callbacks} = options;\n const bodyItems = [];\n\n each(tooltipItems, (context) => {\n const bodyItem = {\n before: [],\n lines: [],\n after: []\n };\n const scoped = overrideCallbacks(callbacks, context);\n pushOrConcat(bodyItem.before, splitNewlines(invokeCallbackWithFallback(scoped, 'beforeLabel', this, context)));\n pushOrConcat(bodyItem.lines, invokeCallbackWithFallback(scoped, 'label', this, context));\n pushOrConcat(bodyItem.after, splitNewlines(invokeCallbackWithFallback(scoped, 'afterLabel', this, context)));\n\n bodyItems.push(bodyItem);\n });\n\n return bodyItems;\n }\n\n getAfterBody(tooltipItems, options) {\n return getBeforeAfterBodyLines(\n invokeCallbackWithFallback(options.callbacks, 'afterBody', this, tooltipItems)\n );\n }\n\n // Get the footer and beforeFooter and afterFooter lines\n getFooter(tooltipItems, options) {\n const {callbacks} = options;\n\n const beforeFooter = invokeCallbackWithFallback(callbacks, 'beforeFooter', this, tooltipItems);\n const footer = invokeCallbackWithFallback(callbacks, 'footer', this, tooltipItems);\n const afterFooter = invokeCallbackWithFallback(callbacks, 'afterFooter', this, tooltipItems);\n\n let lines = [];\n lines = pushOrConcat(lines, splitNewlines(beforeFooter));\n lines = pushOrConcat(lines, splitNewlines(footer));\n lines = pushOrConcat(lines, splitNewlines(afterFooter));\n\n return lines;\n }\n\n /**\n\t * @private\n\t */\n _createItems(options) {\n const active = this._active;\n const data = this.chart.data;\n const labelColors = [];\n const labelPointStyles = [];\n const labelTextColors = [];\n let tooltipItems = [];\n let i, len;\n\n for (i = 0, len = active.length; i < len; ++i) {\n tooltipItems.push(createTooltipItem(this.chart, active[i]));\n }\n\n // If the user provided a filter function, use it to modify the tooltip items\n if (options.filter) {\n tooltipItems = tooltipItems.filter((element, index, array) => options.filter(element, index, array, data));\n }\n\n // If the user provided a sorting function, use it to modify the tooltip items\n if (options.itemSort) {\n tooltipItems = tooltipItems.sort((a, b) => options.itemSort(a, b, data));\n }\n\n // Determine colors for boxes\n each(tooltipItems, (context) => {\n const scoped = overrideCallbacks(options.callbacks, context);\n labelColors.push(invokeCallbackWithFallback(scoped, 'labelColor', this, context));\n labelPointStyles.push(invokeCallbackWithFallback(scoped, 'labelPointStyle', this, context));\n labelTextColors.push(invokeCallbackWithFallback(scoped, 'labelTextColor', this, context));\n });\n\n this.labelColors = labelColors;\n this.labelPointStyles = labelPointStyles;\n this.labelTextColors = labelTextColors;\n this.dataPoints = tooltipItems;\n return tooltipItems;\n }\n\n update(changed, replay) {\n const options = this.options.setContext(this.getContext());\n const active = this._active;\n let properties;\n let tooltipItems = [];\n\n if (!active.length) {\n if (this.opacity !== 0) {\n properties = {\n opacity: 0\n };\n }\n } else {\n const position = positioners[options.position].call(this, active, this._eventPosition);\n tooltipItems = this._createItems(options);\n\n this.title = this.getTitle(tooltipItems, options);\n this.beforeBody = this.getBeforeBody(tooltipItems, options);\n this.body = this.getBody(tooltipItems, options);\n this.afterBody = this.getAfterBody(tooltipItems, options);\n this.footer = this.getFooter(tooltipItems, options);\n\n const size = this._size = getTooltipSize(this, options);\n const positionAndSize = Object.assign({}, position, size);\n const alignment = determineAlignment(this.chart, options, positionAndSize);\n const backgroundPoint = getBackgroundPoint(options, positionAndSize, alignment, this.chart);\n\n this.xAlign = alignment.xAlign;\n this.yAlign = alignment.yAlign;\n\n properties = {\n opacity: 1,\n x: backgroundPoint.x,\n y: backgroundPoint.y,\n width: size.width,\n height: size.height,\n caretX: position.x,\n caretY: position.y\n };\n }\n\n this._tooltipItems = tooltipItems;\n this.$context = undefined;\n\n if (properties) {\n this._resolveAnimations().update(this, properties);\n }\n\n if (changed && options.external) {\n options.external.call(this, {chart: this.chart, tooltip: this, replay});\n }\n }\n\n drawCaret(tooltipPoint, ctx, size, options) {\n const caretPosition = this.getCaretPosition(tooltipPoint, size, options);\n\n ctx.lineTo(caretPosition.x1, caretPosition.y1);\n ctx.lineTo(caretPosition.x2, caretPosition.y2);\n ctx.lineTo(caretPosition.x3, caretPosition.y3);\n }\n\n getCaretPosition(tooltipPoint, size, options) {\n const {xAlign, yAlign} = this;\n const {caretSize, cornerRadius} = options;\n const {topLeft, topRight, bottomLeft, bottomRight} = toTRBLCorners(cornerRadius);\n const {x: ptX, y: ptY} = tooltipPoint;\n const {width, height} = size;\n let x1, x2, x3, y1, y2, y3;\n\n if (yAlign === 'center') {\n y2 = ptY + (height / 2);\n\n if (xAlign === 'left') {\n x1 = ptX;\n x2 = x1 - caretSize;\n\n // Left draws bottom -> top, this y1 is on the bottom\n y1 = y2 + caretSize;\n y3 = y2 - caretSize;\n } else {\n x1 = ptX + width;\n x2 = x1 + caretSize;\n\n // Right draws top -> bottom, thus y1 is on the top\n y1 = y2 - caretSize;\n y3 = y2 + caretSize;\n }\n\n x3 = x1;\n } else {\n if (xAlign === 'left') {\n x2 = ptX + Math.max(topLeft, bottomLeft) + (caretSize);\n } else if (xAlign === 'right') {\n x2 = ptX + width - Math.max(topRight, bottomRight) - caretSize;\n } else {\n x2 = this.caretX;\n }\n\n if (yAlign === 'top') {\n y1 = ptY;\n y2 = y1 - caretSize;\n\n // Top draws left -> right, thus x1 is on the left\n x1 = x2 - caretSize;\n x3 = x2 + caretSize;\n } else {\n y1 = ptY + height;\n y2 = y1 + caretSize;\n\n // Bottom draws right -> left, thus x1 is on the right\n x1 = x2 + caretSize;\n x3 = x2 - caretSize;\n }\n y3 = y1;\n }\n return {x1, x2, x3, y1, y2, y3};\n }\n\n drawTitle(pt, ctx, options) {\n const title = this.title;\n const length = title.length;\n let titleFont, titleSpacing, i;\n\n if (length) {\n const rtlHelper = getRtlAdapter(options.rtl, this.x, this.width);\n\n pt.x = getAlignedX(this, options.titleAlign, options);\n\n ctx.textAlign = rtlHelper.textAlign(options.titleAlign);\n ctx.textBaseline = 'middle';\n\n titleFont = toFont(options.titleFont);\n titleSpacing = options.titleSpacing;\n\n ctx.fillStyle = options.titleColor;\n ctx.font = titleFont.string;\n\n for (i = 0; i < length; ++i) {\n ctx.fillText(title[i], rtlHelper.x(pt.x), pt.y + titleFont.lineHeight / 2);\n pt.y += titleFont.lineHeight + titleSpacing; // Line Height and spacing\n\n if (i + 1 === length) {\n pt.y += options.titleMarginBottom - titleSpacing; // If Last, add margin, remove spacing\n }\n }\n }\n }\n\n /**\n\t * @private\n\t */\n _drawColorBox(ctx, pt, i, rtlHelper, options) {\n const labelColor = this.labelColors[i];\n const labelPointStyle = this.labelPointStyles[i];\n const {boxHeight, boxWidth} = options;\n const bodyFont = toFont(options.bodyFont);\n const colorX = getAlignedX(this, 'left', options);\n const rtlColorX = rtlHelper.x(colorX);\n const yOffSet = boxHeight < bodyFont.lineHeight ? (bodyFont.lineHeight - boxHeight) / 2 : 0;\n const colorY = pt.y + yOffSet;\n\n if (options.usePointStyle) {\n const drawOptions = {\n radius: Math.min(boxWidth, boxHeight) / 2, // fit the circle in the box\n pointStyle: labelPointStyle.pointStyle,\n rotation: labelPointStyle.rotation,\n borderWidth: 1\n };\n // Recalculate x and y for drawPoint() because its expecting\n // x and y to be center of figure (instead of top left)\n const centerX = rtlHelper.leftForLtr(rtlColorX, boxWidth) + boxWidth / 2;\n const centerY = colorY + boxHeight / 2;\n\n // Fill the point with white so that colours merge nicely if the opacity is < 1\n ctx.strokeStyle = options.multiKeyBackground;\n ctx.fillStyle = options.multiKeyBackground;\n drawPoint(ctx, drawOptions, centerX, centerY);\n\n // Draw the point\n ctx.strokeStyle = labelColor.borderColor;\n ctx.fillStyle = labelColor.backgroundColor;\n drawPoint(ctx, drawOptions, centerX, centerY);\n } else {\n // Border\n ctx.lineWidth = isObject(labelColor.borderWidth) ? Math.max(...Object.values(labelColor.borderWidth)) : (labelColor.borderWidth || 1); // TODO, v4 remove fallback\n ctx.strokeStyle = labelColor.borderColor;\n ctx.setLineDash(labelColor.borderDash || []);\n ctx.lineDashOffset = labelColor.borderDashOffset || 0;\n\n // Fill a white rect so that colours merge nicely if the opacity is < 1\n const outerX = rtlHelper.leftForLtr(rtlColorX, boxWidth);\n const innerX = rtlHelper.leftForLtr(rtlHelper.xPlus(rtlColorX, 1), boxWidth - 2);\n const borderRadius = toTRBLCorners(labelColor.borderRadius);\n\n if (Object.values(borderRadius).some(v => v !== 0)) {\n ctx.beginPath();\n ctx.fillStyle = options.multiKeyBackground;\n addRoundedRectPath(ctx, {\n x: outerX,\n y: colorY,\n w: boxWidth,\n h: boxHeight,\n radius: borderRadius,\n });\n ctx.fill();\n ctx.stroke();\n\n // Inner square\n ctx.fillStyle = labelColor.backgroundColor;\n ctx.beginPath();\n addRoundedRectPath(ctx, {\n x: innerX,\n y: colorY + 1,\n w: boxWidth - 2,\n h: boxHeight - 2,\n radius: borderRadius,\n });\n ctx.fill();\n } else {\n // Normal rect\n ctx.fillStyle = options.multiKeyBackground;\n ctx.fillRect(outerX, colorY, boxWidth, boxHeight);\n ctx.strokeRect(outerX, colorY, boxWidth, boxHeight);\n // Inner square\n ctx.fillStyle = labelColor.backgroundColor;\n ctx.fillRect(innerX, colorY + 1, boxWidth - 2, boxHeight - 2);\n }\n }\n\n // restore fillStyle\n ctx.fillStyle = this.labelTextColors[i];\n }\n\n drawBody(pt, ctx, options) {\n const {body} = this;\n const {bodySpacing, bodyAlign, displayColors, boxHeight, boxWidth, boxPadding} = options;\n const bodyFont = toFont(options.bodyFont);\n let bodyLineHeight = bodyFont.lineHeight;\n let xLinePadding = 0;\n\n const rtlHelper = getRtlAdapter(options.rtl, this.x, this.width);\n\n const fillLineOfText = function(line) {\n ctx.fillText(line, rtlHelper.x(pt.x + xLinePadding), pt.y + bodyLineHeight / 2);\n pt.y += bodyLineHeight + bodySpacing;\n };\n\n const bodyAlignForCalculation = rtlHelper.textAlign(bodyAlign);\n let bodyItem, textColor, lines, i, j, ilen, jlen;\n\n ctx.textAlign = bodyAlign;\n ctx.textBaseline = 'middle';\n ctx.font = bodyFont.string;\n\n pt.x = getAlignedX(this, bodyAlignForCalculation, options);\n\n // Before body lines\n ctx.fillStyle = options.bodyColor;\n each(this.beforeBody, fillLineOfText);\n\n xLinePadding = displayColors && bodyAlignForCalculation !== 'right'\n ? bodyAlign === 'center' ? (boxWidth / 2 + boxPadding) : (boxWidth + 2 + boxPadding)\n : 0;\n\n // Draw body lines now\n for (i = 0, ilen = body.length; i < ilen; ++i) {\n bodyItem = body[i];\n textColor = this.labelTextColors[i];\n\n ctx.fillStyle = textColor;\n each(bodyItem.before, fillLineOfText);\n\n lines = bodyItem.lines;\n // Draw Legend-like boxes if needed\n if (displayColors && lines.length) {\n this._drawColorBox(ctx, pt, i, rtlHelper, options);\n bodyLineHeight = Math.max(bodyFont.lineHeight, boxHeight);\n }\n\n for (j = 0, jlen = lines.length; j < jlen; ++j) {\n fillLineOfText(lines[j]);\n // Reset for any lines that don't include colorbox\n bodyLineHeight = bodyFont.lineHeight;\n }\n\n each(bodyItem.after, fillLineOfText);\n }\n\n // Reset back to 0 for after body\n xLinePadding = 0;\n bodyLineHeight = bodyFont.lineHeight;\n\n // After body lines\n each(this.afterBody, fillLineOfText);\n pt.y -= bodySpacing; // Remove last body spacing\n }\n\n drawFooter(pt, ctx, options) {\n const footer = this.footer;\n const length = footer.length;\n let footerFont, i;\n\n if (length) {\n const rtlHelper = getRtlAdapter(options.rtl, this.x, this.width);\n\n pt.x = getAlignedX(this, options.footerAlign, options);\n pt.y += options.footerMarginTop;\n\n ctx.textAlign = rtlHelper.textAlign(options.footerAlign);\n ctx.textBaseline = 'middle';\n\n footerFont = toFont(options.footerFont);\n\n ctx.fillStyle = options.footerColor;\n ctx.font = footerFont.string;\n\n for (i = 0; i < length; ++i) {\n ctx.fillText(footer[i], rtlHelper.x(pt.x), pt.y + footerFont.lineHeight / 2);\n pt.y += footerFont.lineHeight + options.footerSpacing;\n }\n }\n }\n\n drawBackground(pt, ctx, tooltipSize, options) {\n const {xAlign, yAlign} = this;\n const {x, y} = pt;\n const {width, height} = tooltipSize;\n const {topLeft, topRight, bottomLeft, bottomRight} = toTRBLCorners(options.cornerRadius);\n\n ctx.fillStyle = options.backgroundColor;\n ctx.strokeStyle = options.borderColor;\n ctx.lineWidth = options.borderWidth;\n\n ctx.beginPath();\n ctx.moveTo(x + topLeft, y);\n if (yAlign === 'top') {\n this.drawCaret(pt, ctx, tooltipSize, options);\n }\n ctx.lineTo(x + width - topRight, y);\n ctx.quadraticCurveTo(x + width, y, x + width, y + topRight);\n if (yAlign === 'center' && xAlign === 'right') {\n this.drawCaret(pt, ctx, tooltipSize, options);\n }\n ctx.lineTo(x + width, y + height - bottomRight);\n ctx.quadraticCurveTo(x + width, y + height, x + width - bottomRight, y + height);\n if (yAlign === 'bottom') {\n this.drawCaret(pt, ctx, tooltipSize, options);\n }\n ctx.lineTo(x + bottomLeft, y + height);\n ctx.quadraticCurveTo(x, y + height, x, y + height - bottomLeft);\n if (yAlign === 'center' && xAlign === 'left') {\n this.drawCaret(pt, ctx, tooltipSize, options);\n }\n ctx.lineTo(x, y + topLeft);\n ctx.quadraticCurveTo(x, y, x + topLeft, y);\n ctx.closePath();\n\n ctx.fill();\n\n if (options.borderWidth > 0) {\n ctx.stroke();\n }\n }\n\n /**\n\t * Update x/y animation targets when _active elements are animating too\n\t * @private\n\t */\n _updateAnimationTarget(options) {\n const chart = this.chart;\n const anims = this.$animations;\n const animX = anims && anims.x;\n const animY = anims && anims.y;\n if (animX || animY) {\n const position = positioners[options.position].call(this, this._active, this._eventPosition);\n if (!position) {\n return;\n }\n const size = this._size = getTooltipSize(this, options);\n const positionAndSize = Object.assign({}, position, this._size);\n const alignment = determineAlignment(chart, options, positionAndSize);\n const point = getBackgroundPoint(options, positionAndSize, alignment, chart);\n if (animX._to !== point.x || animY._to !== point.y) {\n this.xAlign = alignment.xAlign;\n this.yAlign = alignment.yAlign;\n this.width = size.width;\n this.height = size.height;\n this.caretX = position.x;\n this.caretY = position.y;\n this._resolveAnimations().update(this, point);\n }\n }\n }\n\n /**\n * Determine if the tooltip will draw anything\n * @returns {boolean} True if the tooltip will render\n */\n _willRender() {\n return !!this.opacity;\n }\n\n draw(ctx) {\n const options = this.options.setContext(this.getContext());\n let opacity = this.opacity;\n\n if (!opacity) {\n return;\n }\n\n this._updateAnimationTarget(options);\n\n const tooltipSize = {\n width: this.width,\n height: this.height\n };\n const pt = {\n x: this.x,\n y: this.y\n };\n\n // IE11/Edge does not like very small opacities, so snap to 0\n opacity = Math.abs(opacity) < 1e-3 ? 0 : opacity;\n\n const padding = toPadding(options.padding);\n\n // Truthy/falsey value for empty tooltip\n const hasTooltipContent = this.title.length || this.beforeBody.length || this.body.length || this.afterBody.length || this.footer.length;\n\n if (options.enabled && hasTooltipContent) {\n ctx.save();\n ctx.globalAlpha = opacity;\n\n // Draw Background\n this.drawBackground(pt, ctx, tooltipSize, options);\n\n overrideTextDirection(ctx, options.textDirection);\n\n pt.y += padding.top;\n\n // Titles\n this.drawTitle(pt, ctx, options);\n\n // Body\n this.drawBody(pt, ctx, options);\n\n // Footer\n this.drawFooter(pt, ctx, options);\n\n restoreTextDirection(ctx, options.textDirection);\n\n ctx.restore();\n }\n }\n\n /**\n\t * Get active elements in the tooltip\n\t * @returns {Array} Array of elements that are active in the tooltip\n\t */\n getActiveElements() {\n return this._active || [];\n }\n\n /**\n\t * Set active elements in the tooltip\n\t * @param {array} activeElements Array of active datasetIndex/index pairs.\n\t * @param {object} eventPosition Synthetic event position used in positioning\n\t */\n setActiveElements(activeElements, eventPosition) {\n const lastActive = this._active;\n const active = activeElements.map(({datasetIndex, index}) => {\n const meta = this.chart.getDatasetMeta(datasetIndex);\n\n if (!meta) {\n throw new Error('Cannot find a dataset at index ' + datasetIndex);\n }\n\n return {\n datasetIndex,\n element: meta.data[index],\n index,\n };\n });\n const changed = !_elementsEqual(lastActive, active);\n const positionChanged = this._positionChanged(active, eventPosition);\n\n if (changed || positionChanged) {\n this._active = active;\n this._eventPosition = eventPosition;\n this._ignoreReplayEvents = true;\n this.update(true);\n }\n }\n\n /**\n\t * Handle an event\n\t * @param {ChartEvent} e - The event to handle\n\t * @param {boolean} [replay] - This is a replayed event (from update)\n\t * @param {boolean} [inChartArea] - The event is inside chartArea\n\t * @returns {boolean} true if the tooltip changed\n\t */\n handleEvent(e, replay, inChartArea = true) {\n if (replay && this._ignoreReplayEvents) {\n return false;\n }\n this._ignoreReplayEvents = false;\n\n const options = this.options;\n const lastActive = this._active || [];\n const active = this._getActiveElements(e, lastActive, replay, inChartArea);\n\n // When there are multiple items shown, but the tooltip position is nearest mode\n // an update may need to be made because our position may have changed even though\n // the items are the same as before.\n const positionChanged = this._positionChanged(active, e);\n\n // Remember Last Actives\n const changed = replay || !_elementsEqual(active, lastActive) || positionChanged;\n\n // Only handle target event on tooltip change\n if (changed) {\n this._active = active;\n\n if (options.enabled || options.external) {\n this._eventPosition = {\n x: e.x,\n y: e.y\n };\n\n this.update(true, replay);\n }\n }\n\n return changed;\n }\n\n /**\n\t * Helper for determining the active elements for event\n\t * @param {ChartEvent} e - The event to handle\n\t * @param {InteractionItem[]} lastActive - Previously active elements\n\t * @param {boolean} [replay] - This is a replayed event (from update)\n\t * @param {boolean} [inChartArea] - The event is inside chartArea\n\t * @returns {InteractionItem[]} - Active elements\n\t * @private\n\t */\n _getActiveElements(e, lastActive, replay, inChartArea) {\n const options = this.options;\n\n if (e.type === 'mouseout') {\n return [];\n }\n\n if (!inChartArea) {\n // Let user control the active elements outside chartArea. Eg. using Legend.\n // But make sure that active elements are still valid.\n return lastActive.filter(i =>\n this.chart.data.datasets[i.datasetIndex] &&\n this.chart.getDatasetMeta(i.datasetIndex).controller.getParsed(i.index) !== undefined\n );\n }\n\n // Find Active Elements for tooltips\n const active = this.chart.getElementsAtEventForMode(e, options.mode, options, replay);\n\n if (options.reverse) {\n active.reverse();\n }\n\n return active;\n }\n\n /**\n\t * Determine if the active elements + event combination changes the\n\t * tooltip position\n\t * @param {array} active - Active elements\n\t * @param {ChartEvent} e - Event that triggered the position change\n\t * @returns {boolean} True if the position has changed\n\t */\n _positionChanged(active, e) {\n const {caretX, caretY, options} = this;\n const position = positioners[options.position].call(this, active, e);\n return position !== false && (caretX !== position.x || caretY !== position.y);\n }\n}\n\nexport default {\n id: 'tooltip',\n _element: Tooltip,\n positioners,\n\n afterInit(chart, _args, options) {\n if (options) {\n chart.tooltip = new Tooltip({chart, options});\n }\n },\n\n beforeUpdate(chart, _args, options) {\n if (chart.tooltip) {\n chart.tooltip.initialize(options);\n }\n },\n\n reset(chart, _args, options) {\n if (chart.tooltip) {\n chart.tooltip.initialize(options);\n }\n },\n\n afterDraw(chart) {\n const tooltip = chart.tooltip;\n\n if (tooltip && tooltip._willRender()) {\n const args = {\n tooltip\n };\n\n if (chart.notifyPlugins('beforeTooltipDraw', {...args, cancelable: true}) === false) {\n return;\n }\n\n tooltip.draw(chart.ctx);\n\n chart.notifyPlugins('afterTooltipDraw', args);\n }\n },\n\n afterEvent(chart, args) {\n if (chart.tooltip) {\n // If the event is replayed from `update`, we should evaluate with the final positions.\n const useFinalPosition = args.replay;\n if (chart.tooltip.handleEvent(args.event, useFinalPosition, args.inChartArea)) {\n // notify chart about the change, so it will render\n args.changed = true;\n }\n }\n },\n\n defaults: {\n enabled: true,\n external: null,\n position: 'average',\n backgroundColor: 'rgba(0,0,0,0.8)',\n titleColor: '#fff',\n titleFont: {\n weight: 'bold',\n },\n titleSpacing: 2,\n titleMarginBottom: 6,\n titleAlign: 'left',\n bodyColor: '#fff',\n bodySpacing: 2,\n bodyFont: {\n },\n bodyAlign: 'left',\n footerColor: '#fff',\n footerSpacing: 2,\n footerMarginTop: 6,\n footerFont: {\n weight: 'bold',\n },\n footerAlign: 'left',\n padding: 6,\n caretPadding: 2,\n caretSize: 5,\n cornerRadius: 6,\n boxHeight: (ctx, opts) => opts.bodyFont.size,\n boxWidth: (ctx, opts) => opts.bodyFont.size,\n multiKeyBackground: '#fff',\n displayColors: true,\n boxPadding: 0,\n borderColor: 'rgba(0,0,0,0)',\n borderWidth: 0,\n animation: {\n duration: 400,\n easing: 'easeOutQuart',\n },\n animations: {\n numbers: {\n type: 'number',\n properties: ['x', 'y', 'width', 'height', 'caretX', 'caretY'],\n },\n opacity: {\n easing: 'linear',\n duration: 200\n }\n },\n callbacks: defaultCallbacks\n },\n\n defaultRoutes: {\n bodyFont: 'font',\n footerFont: 'font',\n titleFont: 'font'\n },\n\n descriptors: {\n _scriptable: (name) => name !== 'filter' && name !== 'itemSort' && name !== 'external',\n _indexable: false,\n callbacks: {\n _scriptable: false,\n _indexable: false,\n },\n animation: {\n _fallback: false\n },\n animations: {\n _fallback: 'animation'\n }\n },\n\n // Resolve additionally from `interaction` options and defaults.\n additionalOptionScopes: ['interaction']\n};\n","import Scale from '../core/core.scale.js';\nimport {isNullOrUndef, valueOrDefault, _limitValue} from '../helpers/index.js';\n\nconst addIfString = (labels, raw, index, addedLabels) => {\n if (typeof raw === 'string') {\n index = labels.push(raw) - 1;\n addedLabels.unshift({index, label: raw});\n } else if (isNaN(raw)) {\n index = null;\n }\n return index;\n};\n\nfunction findOrAddLabel(labels, raw, index, addedLabels) {\n const first = labels.indexOf(raw);\n if (first === -1) {\n return addIfString(labels, raw, index, addedLabels);\n }\n const last = labels.lastIndexOf(raw);\n return first !== last ? index : first;\n}\n\nconst validIndex = (index, max) => index === null ? null : _limitValue(Math.round(index), 0, max);\n\nfunction _getLabelForValue(value) {\n const labels = this.getLabels();\n\n if (value >= 0 && value < labels.length) {\n return labels[value];\n }\n return value;\n}\n\nexport default class CategoryScale extends Scale {\n\n static id = 'category';\n\n /**\n * @type {any}\n */\n static defaults = {\n ticks: {\n callback: _getLabelForValue\n }\n };\n\n constructor(cfg) {\n super(cfg);\n\n /** @type {number} */\n this._startValue = undefined;\n this._valueRange = 0;\n this._addedLabels = [];\n }\n\n init(scaleOptions) {\n const added = this._addedLabels;\n if (added.length) {\n const labels = this.getLabels();\n for (const {index, label} of added) {\n if (labels[index] === label) {\n labels.splice(index, 1);\n }\n }\n this._addedLabels = [];\n }\n super.init(scaleOptions);\n }\n\n parse(raw, index) {\n if (isNullOrUndef(raw)) {\n return null;\n }\n const labels = this.getLabels();\n index = isFinite(index) && labels[index] === raw ? index\n : findOrAddLabel(labels, raw, valueOrDefault(index, raw), this._addedLabels);\n return validIndex(index, labels.length - 1);\n }\n\n determineDataLimits() {\n const {minDefined, maxDefined} = this.getUserBounds();\n let {min, max} = this.getMinMax(true);\n\n if (this.options.bounds === 'ticks') {\n if (!minDefined) {\n min = 0;\n }\n if (!maxDefined) {\n max = this.getLabels().length - 1;\n }\n }\n\n this.min = min;\n this.max = max;\n }\n\n buildTicks() {\n const min = this.min;\n const max = this.max;\n const offset = this.options.offset;\n const ticks = [];\n let labels = this.getLabels();\n\n // If we are viewing some subset of labels, slice the original array\n labels = (min === 0 && max === labels.length - 1) ? labels : labels.slice(min, max + 1);\n\n this._valueRange = Math.max(labels.length - (offset ? 0 : 1), 1);\n this._startValue = this.min - (offset ? 0.5 : 0);\n\n for (let value = min; value <= max; value++) {\n ticks.push({value});\n }\n return ticks;\n }\n\n getLabelForValue(value) {\n return _getLabelForValue.call(this, value);\n }\n\n /**\n\t * @protected\n\t */\n configure() {\n super.configure();\n\n if (!this.isHorizontal()) {\n // For backward compatibility, vertical category scale reverse is inverted.\n this._reversePixels = !this._reversePixels;\n }\n }\n\n // Used to get data value locations. Value can either be an index or a numerical value\n getPixelForValue(value) {\n if (typeof value !== 'number') {\n value = this.parse(value);\n }\n\n return value === null ? NaN : this.getPixelForDecimal((value - this._startValue) / this._valueRange);\n }\n\n // Must override base implementation because it calls getPixelForValue\n // and category scale can have duplicate values\n getPixelForTick(index) {\n const ticks = this.ticks;\n if (index < 0 || index > ticks.length - 1) {\n return null;\n }\n return this.getPixelForValue(ticks[index].value);\n }\n\n getValueForPixel(pixel) {\n return Math.round(this._startValue + this.getDecimalForPixel(pixel) * this._valueRange);\n }\n\n getBasePixel() {\n return this.bottom;\n }\n}\n","import {isNullOrUndef} from '../helpers/helpers.core.js';\nimport {almostEquals, almostWhole, niceNum, _decimalPlaces, _setMinAndMaxByKey, sign, toRadians} from '../helpers/helpers.math.js';\nimport Scale from '../core/core.scale.js';\nimport {formatNumber} from '../helpers/helpers.intl.js';\n\n/**\n * Generate a set of linear ticks for an axis\n * 1. If generationOptions.min, generationOptions.max, and generationOptions.step are defined:\n * if (max - min) / step is an integer, ticks are generated as [min, min + step, ..., max]\n * Note that the generationOptions.maxCount setting is respected in this scenario\n *\n * 2. If generationOptions.min, generationOptions.max, and generationOptions.count is defined\n * spacing = (max - min) / count\n * Ticks are generated as [min, min + spacing, ..., max]\n *\n * 3. If generationOptions.count is defined\n * spacing = (niceMax - niceMin) / count\n *\n * 4. Compute optimal spacing of ticks using niceNum algorithm\n *\n * @param generationOptions the options used to generate the ticks\n * @param dataRange the range of the data\n * @returns {object[]} array of tick objects\n */\nfunction generateTicks(generationOptions, dataRange) {\n const ticks = [];\n // To get a \"nice\" value for the tick spacing, we will use the appropriately named\n // \"nice number\" algorithm. See https://stackoverflow.com/questions/8506881/nice-label-algorithm-for-charts-with-minimum-ticks\n // for details.\n\n const MIN_SPACING = 1e-14;\n const {bounds, step, min, max, precision, count, maxTicks, maxDigits, includeBounds} = generationOptions;\n const unit = step || 1;\n const maxSpaces = maxTicks - 1;\n const {min: rmin, max: rmax} = dataRange;\n const minDefined = !isNullOrUndef(min);\n const maxDefined = !isNullOrUndef(max);\n const countDefined = !isNullOrUndef(count);\n const minSpacing = (rmax - rmin) / (maxDigits + 1);\n let spacing = niceNum((rmax - rmin) / maxSpaces / unit) * unit;\n let factor, niceMin, niceMax, numSpaces;\n\n // Beyond MIN_SPACING floating point numbers being to lose precision\n // such that we can't do the math necessary to generate ticks\n if (spacing < MIN_SPACING && !minDefined && !maxDefined) {\n return [{value: rmin}, {value: rmax}];\n }\n\n numSpaces = Math.ceil(rmax / spacing) - Math.floor(rmin / spacing);\n if (numSpaces > maxSpaces) {\n // If the calculated num of spaces exceeds maxNumSpaces, recalculate it\n spacing = niceNum(numSpaces * spacing / maxSpaces / unit) * unit;\n }\n\n if (!isNullOrUndef(precision)) {\n // If the user specified a precision, round to that number of decimal places\n factor = Math.pow(10, precision);\n spacing = Math.ceil(spacing * factor) / factor;\n }\n\n if (bounds === 'ticks') {\n niceMin = Math.floor(rmin / spacing) * spacing;\n niceMax = Math.ceil(rmax / spacing) * spacing;\n } else {\n niceMin = rmin;\n niceMax = rmax;\n }\n\n if (minDefined && maxDefined && step && almostWhole((max - min) / step, spacing / 1000)) {\n // Case 1: If min, max and stepSize are set and they make an evenly spaced scale use it.\n // spacing = step;\n // numSpaces = (max - min) / spacing;\n // Note that we round here to handle the case where almostWhole translated an FP error\n numSpaces = Math.round(Math.min((max - min) / spacing, maxTicks));\n spacing = (max - min) / numSpaces;\n niceMin = min;\n niceMax = max;\n } else if (countDefined) {\n // Cases 2 & 3, we have a count specified. Handle optional user defined edges to the range.\n // Sometimes these are no-ops, but it makes the code a lot clearer\n // and when a user defined range is specified, we want the correct ticks\n niceMin = minDefined ? min : niceMin;\n niceMax = maxDefined ? max : niceMax;\n numSpaces = count - 1;\n spacing = (niceMax - niceMin) / numSpaces;\n } else {\n // Case 4\n numSpaces = (niceMax - niceMin) / spacing;\n\n // If very close to our rounded value, use it.\n if (almostEquals(numSpaces, Math.round(numSpaces), spacing / 1000)) {\n numSpaces = Math.round(numSpaces);\n } else {\n numSpaces = Math.ceil(numSpaces);\n }\n }\n\n // The spacing will have changed in cases 1, 2, and 3 so the factor cannot be computed\n // until this point\n const decimalPlaces = Math.max(\n _decimalPlaces(spacing),\n _decimalPlaces(niceMin)\n );\n factor = Math.pow(10, isNullOrUndef(precision) ? decimalPlaces : precision);\n niceMin = Math.round(niceMin * factor) / factor;\n niceMax = Math.round(niceMax * factor) / factor;\n\n let j = 0;\n if (minDefined) {\n if (includeBounds && niceMin !== min) {\n ticks.push({value: min});\n\n if (niceMin < min) {\n j++; // Skip niceMin\n }\n // If the next nice tick is close to min, skip it\n if (almostEquals(Math.round((niceMin + j * spacing) * factor) / factor, min, relativeLabelSize(min, minSpacing, generationOptions))) {\n j++;\n }\n } else if (niceMin < min) {\n j++;\n }\n }\n\n for (; j < numSpaces; ++j) {\n const tickValue = Math.round((niceMin + j * spacing) * factor) / factor;\n if (maxDefined && tickValue > max) {\n break;\n }\n ticks.push({value: tickValue});\n }\n\n if (maxDefined && includeBounds && niceMax !== max) {\n // If the previous tick is too close to max, replace it with max, else add max\n if (ticks.length && almostEquals(ticks[ticks.length - 1].value, max, relativeLabelSize(max, minSpacing, generationOptions))) {\n ticks[ticks.length - 1].value = max;\n } else {\n ticks.push({value: max});\n }\n } else if (!maxDefined || niceMax === max) {\n ticks.push({value: niceMax});\n }\n\n return ticks;\n}\n\nfunction relativeLabelSize(value, minSpacing, {horizontal, minRotation}) {\n const rad = toRadians(minRotation);\n const ratio = (horizontal ? Math.sin(rad) : Math.cos(rad)) || 0.001;\n const length = 0.75 * minSpacing * ('' + value).length;\n return Math.min(minSpacing / ratio, length);\n}\n\nexport default class LinearScaleBase extends Scale {\n\n constructor(cfg) {\n super(cfg);\n\n /** @type {number} */\n this.start = undefined;\n /** @type {number} */\n this.end = undefined;\n /** @type {number} */\n this._startValue = undefined;\n /** @type {number} */\n this._endValue = undefined;\n this._valueRange = 0;\n }\n\n parse(raw, index) { // eslint-disable-line no-unused-vars\n if (isNullOrUndef(raw)) {\n return null;\n }\n if ((typeof raw === 'number' || raw instanceof Number) && !isFinite(+raw)) {\n return null;\n }\n\n return +raw;\n }\n\n handleTickRangeOptions() {\n const {beginAtZero} = this.options;\n const {minDefined, maxDefined} = this.getUserBounds();\n let {min, max} = this;\n\n const setMin = v => (min = minDefined ? min : v);\n const setMax = v => (max = maxDefined ? max : v);\n\n if (beginAtZero) {\n const minSign = sign(min);\n const maxSign = sign(max);\n\n if (minSign < 0 && maxSign < 0) {\n setMax(0);\n } else if (minSign > 0 && maxSign > 0) {\n setMin(0);\n }\n }\n\n if (min === max) {\n let offset = max === 0 ? 1 : Math.abs(max * 0.05);\n\n setMax(max + offset);\n\n if (!beginAtZero) {\n setMin(min - offset);\n }\n }\n this.min = min;\n this.max = max;\n }\n\n getTickLimit() {\n const tickOpts = this.options.ticks;\n // eslint-disable-next-line prefer-const\n let {maxTicksLimit, stepSize} = tickOpts;\n let maxTicks;\n\n if (stepSize) {\n maxTicks = Math.ceil(this.max / stepSize) - Math.floor(this.min / stepSize) + 1;\n if (maxTicks > 1000) {\n console.warn(`scales.${this.id}.ticks.stepSize: ${stepSize} would result generating up to ${maxTicks} ticks. Limiting to 1000.`);\n maxTicks = 1000;\n }\n } else {\n maxTicks = this.computeTickLimit();\n maxTicksLimit = maxTicksLimit || 11;\n }\n\n if (maxTicksLimit) {\n maxTicks = Math.min(maxTicksLimit, maxTicks);\n }\n\n return maxTicks;\n }\n\n /**\n\t * @protected\n\t */\n computeTickLimit() {\n return Number.POSITIVE_INFINITY;\n }\n\n buildTicks() {\n const opts = this.options;\n const tickOpts = opts.ticks;\n\n // Figure out what the max number of ticks we can support it is based on the size of\n // the axis area. For now, we say that the minimum tick spacing in pixels must be 40\n // We also limit the maximum number of ticks to 11 which gives a nice 10 squares on\n // the graph. Make sure we always have at least 2 ticks\n let maxTicks = this.getTickLimit();\n maxTicks = Math.max(2, maxTicks);\n\n const numericGeneratorOptions = {\n maxTicks,\n bounds: opts.bounds,\n min: opts.min,\n max: opts.max,\n precision: tickOpts.precision,\n step: tickOpts.stepSize,\n count: tickOpts.count,\n maxDigits: this._maxDigits(),\n horizontal: this.isHorizontal(),\n minRotation: tickOpts.minRotation || 0,\n includeBounds: tickOpts.includeBounds !== false\n };\n const dataRange = this._range || this;\n const ticks = generateTicks(numericGeneratorOptions, dataRange);\n\n // At this point, we need to update our max and min given the tick values,\n // since we probably have expanded the range of the scale\n if (opts.bounds === 'ticks') {\n _setMinAndMaxByKey(ticks, this, 'value');\n }\n\n if (opts.reverse) {\n ticks.reverse();\n\n this.start = this.max;\n this.end = this.min;\n } else {\n this.start = this.min;\n this.end = this.max;\n }\n\n return ticks;\n }\n\n /**\n\t * @protected\n\t */\n configure() {\n const ticks = this.ticks;\n let start = this.min;\n let end = this.max;\n\n super.configure();\n\n if (this.options.offset && ticks.length) {\n const offset = (end - start) / Math.max(ticks.length - 1, 1) / 2;\n start -= offset;\n end += offset;\n }\n this._startValue = start;\n this._endValue = end;\n this._valueRange = end - start;\n }\n\n getLabelForValue(value) {\n return formatNumber(value, this.chart.options.locale, this.options.ticks.format);\n }\n}\n","import {isFinite} from '../helpers/helpers.core.js';\nimport LinearScaleBase from './scale.linearbase.js';\nimport Ticks from '../core/core.ticks.js';\nimport {toRadians} from '../helpers/index.js';\n\nexport default class LinearScale extends LinearScaleBase {\n\n static id = 'linear';\n\n /**\n * @type {any}\n */\n static defaults = {\n ticks: {\n callback: Ticks.formatters.numeric\n }\n };\n\n\n determineDataLimits() {\n const {min, max} = this.getMinMax(true);\n\n this.min = isFinite(min) ? min : 0;\n this.max = isFinite(max) ? max : 1;\n\n // Common base implementation to handle min, max, beginAtZero\n this.handleTickRangeOptions();\n }\n\n /**\n\t * Returns the maximum number of ticks based on the scale dimension\n\t * @protected\n \t */\n computeTickLimit() {\n const horizontal = this.isHorizontal();\n const length = horizontal ? this.width : this.height;\n const minRotation = toRadians(this.options.ticks.minRotation);\n const ratio = (horizontal ? Math.sin(minRotation) : Math.cos(minRotation)) || 0.001;\n const tickFont = this._resolveTickFontOptions(0);\n return Math.ceil(length / Math.min(40, tickFont.lineHeight / ratio));\n }\n\n // Utils\n getPixelForValue(value) {\n return value === null ? NaN : this.getPixelForDecimal((value - this._startValue) / this._valueRange);\n }\n\n getValueForPixel(pixel) {\n return this._startValue + this.getDecimalForPixel(pixel) * this._valueRange;\n }\n}\n","import {finiteOrDefault, isFinite} from '../helpers/helpers.core.js';\nimport {formatNumber} from '../helpers/helpers.intl.js';\nimport {_setMinAndMaxByKey, log10} from '../helpers/helpers.math.js';\nimport Scale from '../core/core.scale.js';\nimport LinearScaleBase from './scale.linearbase.js';\nimport Ticks from '../core/core.ticks.js';\n\nconst log10Floor = v => Math.floor(log10(v));\nconst changeExponent = (v, m) => Math.pow(10, log10Floor(v) + m);\n\nfunction isMajor(tickVal) {\n const remain = tickVal / (Math.pow(10, log10Floor(tickVal)));\n return remain === 1;\n}\n\nfunction steps(min, max, rangeExp) {\n const rangeStep = Math.pow(10, rangeExp);\n const start = Math.floor(min / rangeStep);\n const end = Math.ceil(max / rangeStep);\n return end - start;\n}\n\nfunction startExp(min, max) {\n const range = max - min;\n let rangeExp = log10Floor(range);\n while (steps(min, max, rangeExp) > 10) {\n rangeExp++;\n }\n while (steps(min, max, rangeExp) < 10) {\n rangeExp--;\n }\n return Math.min(rangeExp, log10Floor(min));\n}\n\n\n/**\n * Generate a set of logarithmic ticks\n * @param generationOptions the options used to generate the ticks\n * @param dataRange the range of the data\n * @returns {object[]} array of tick objects\n */\nfunction generateTicks(generationOptions, {min, max}) {\n min = finiteOrDefault(generationOptions.min, min);\n const ticks = [];\n const minExp = log10Floor(min);\n let exp = startExp(min, max);\n let precision = exp < 0 ? Math.pow(10, Math.abs(exp)) : 1;\n const stepSize = Math.pow(10, exp);\n const base = minExp > exp ? Math.pow(10, minExp) : 0;\n const start = Math.round((min - base) * precision) / precision;\n const offset = Math.floor((min - base) / stepSize / 10) * stepSize * 10;\n let significand = Math.floor((start - offset) / Math.pow(10, exp));\n let value = finiteOrDefault(generationOptions.min, Math.round((base + offset + significand * Math.pow(10, exp)) * precision) / precision);\n while (value < max) {\n ticks.push({value, major: isMajor(value), significand});\n if (significand >= 10) {\n significand = significand < 15 ? 15 : 20;\n } else {\n significand++;\n }\n if (significand >= 20) {\n exp++;\n significand = 2;\n precision = exp >= 0 ? 1 : precision;\n }\n value = Math.round((base + offset + significand * Math.pow(10, exp)) * precision) / precision;\n }\n const lastTick = finiteOrDefault(generationOptions.max, value);\n ticks.push({value: lastTick, major: isMajor(lastTick), significand});\n\n return ticks;\n}\n\nexport default class LogarithmicScale extends Scale {\n\n static id = 'logarithmic';\n\n /**\n * @type {any}\n */\n static defaults = {\n ticks: {\n callback: Ticks.formatters.logarithmic,\n major: {\n enabled: true\n }\n }\n };\n\n\n constructor(cfg) {\n super(cfg);\n\n /** @type {number} */\n this.start = undefined;\n /** @type {number} */\n this.end = undefined;\n /** @type {number} */\n this._startValue = undefined;\n this._valueRange = 0;\n }\n\n parse(raw, index) {\n const value = LinearScaleBase.prototype.parse.apply(this, [raw, index]);\n if (value === 0) {\n this._zero = true;\n return undefined;\n }\n return isFinite(value) && value > 0 ? value : null;\n }\n\n determineDataLimits() {\n const {min, max} = this.getMinMax(true);\n\n this.min = isFinite(min) ? Math.max(0, min) : null;\n this.max = isFinite(max) ? Math.max(0, max) : null;\n\n if (this.options.beginAtZero) {\n this._zero = true;\n }\n\n // if data has `0` in it or `beginAtZero` is true, min (non zero) value is at bottom\n // of scale, and it does not equal suggestedMin, lower the min bound by one exp.\n if (this._zero && this.min !== this._suggestedMin && !isFinite(this._userMin)) {\n this.min = min === changeExponent(this.min, 0) ? changeExponent(this.min, -1) : changeExponent(this.min, 0);\n }\n\n this.handleTickRangeOptions();\n }\n\n handleTickRangeOptions() {\n const {minDefined, maxDefined} = this.getUserBounds();\n let min = this.min;\n let max = this.max;\n\n const setMin = v => (min = minDefined ? min : v);\n const setMax = v => (max = maxDefined ? max : v);\n\n if (min === max) {\n if (min <= 0) { // includes null\n setMin(1);\n setMax(10);\n } else {\n setMin(changeExponent(min, -1));\n setMax(changeExponent(max, +1));\n }\n }\n if (min <= 0) {\n setMin(changeExponent(max, -1));\n }\n if (max <= 0) {\n\n setMax(changeExponent(min, +1));\n }\n\n this.min = min;\n this.max = max;\n }\n\n buildTicks() {\n const opts = this.options;\n\n const generationOptions = {\n min: this._userMin,\n max: this._userMax\n };\n const ticks = generateTicks(generationOptions, this);\n\n // At this point, we need to update our max and min given the tick values,\n // since we probably have expanded the range of the scale\n if (opts.bounds === 'ticks') {\n _setMinAndMaxByKey(ticks, this, 'value');\n }\n\n if (opts.reverse) {\n ticks.reverse();\n\n this.start = this.max;\n this.end = this.min;\n } else {\n this.start = this.min;\n this.end = this.max;\n }\n\n return ticks;\n }\n\n /**\n\t * @param {number} value\n\t * @return {string}\n\t */\n getLabelForValue(value) {\n return value === undefined\n ? '0'\n : formatNumber(value, this.chart.options.locale, this.options.ticks.format);\n }\n\n /**\n\t * @protected\n\t */\n configure() {\n const start = this.min;\n\n super.configure();\n\n this._startValue = log10(start);\n this._valueRange = log10(this.max) - log10(start);\n }\n\n getPixelForValue(value) {\n if (value === undefined || value === 0) {\n value = this.min;\n }\n if (value === null || isNaN(value)) {\n return NaN;\n }\n return this.getPixelForDecimal(value === this.min\n ? 0\n : (log10(value) - this._startValue) / this._valueRange);\n }\n\n getValueForPixel(pixel) {\n const decimal = this.getDecimalForPixel(pixel);\n return Math.pow(10, this._startValue + decimal * this._valueRange);\n }\n}\n","import defaults from '../core/core.defaults.js';\nimport {_longestText, addRoundedRectPath, renderText, _isPointInArea} from '../helpers/helpers.canvas.js';\nimport {HALF_PI, TAU, toDegrees, toRadians, _normalizeAngle, PI} from '../helpers/helpers.math.js';\nimport LinearScaleBase from './scale.linearbase.js';\nimport Ticks from '../core/core.ticks.js';\nimport {valueOrDefault, isArray, isFinite, callback as callCallback, isNullOrUndef} from '../helpers/helpers.core.js';\nimport {createContext, toFont, toPadding, toTRBLCorners} from '../helpers/helpers.options.js';\n\nfunction getTickBackdropHeight(opts) {\n const tickOpts = opts.ticks;\n\n if (tickOpts.display && opts.display) {\n const padding = toPadding(tickOpts.backdropPadding);\n return valueOrDefault(tickOpts.font && tickOpts.font.size, defaults.font.size) + padding.height;\n }\n return 0;\n}\n\nfunction measureLabelSize(ctx, font, label) {\n label = isArray(label) ? label : [label];\n return {\n w: _longestText(ctx, font.string, label),\n h: label.length * font.lineHeight\n };\n}\n\nfunction determineLimits(angle, pos, size, min, max) {\n if (angle === min || angle === max) {\n return {\n start: pos - (size / 2),\n end: pos + (size / 2)\n };\n } else if (angle < min || angle > max) {\n return {\n start: pos - size,\n end: pos\n };\n }\n\n return {\n start: pos,\n end: pos + size\n };\n}\n\n/**\n * Helper function to fit a radial linear scale with point labels\n */\nfunction fitWithPointLabels(scale) {\n\n // Right, this is really confusing and there is a lot of maths going on here\n // The gist of the problem is here: https://gist.github.com/nnnick/696cc9c55f4b0beb8fe9\n //\n // Reaction: https://dl.dropboxusercontent.com/u/34601363/toomuchscience.gif\n //\n // Solution:\n //\n // We assume the radius of the polygon is half the size of the canvas at first\n // at each index we check if the text overlaps.\n //\n // Where it does, we store that angle and that index.\n //\n // After finding the largest index and angle we calculate how much we need to remove\n // from the shape radius to move the point inwards by that x.\n //\n // We average the left and right distances to get the maximum shape radius that can fit in the box\n // along with labels.\n //\n // Once we have that, we can find the centre point for the chart, by taking the x text protrusion\n // on each side, removing that from the size, halving it and adding the left x protrusion width.\n //\n // This will mean we have a shape fitted to the canvas, as large as it can be with the labels\n // and position it in the most space efficient manner\n //\n // https://dl.dropboxusercontent.com/u/34601363/yeahscience.gif\n\n // Get maximum radius of the polygon. Either half the height (minus the text width) or half the width.\n // Use this to calculate the offset + change. - Make sure L/R protrusion is at least 0 to stop issues with centre points\n const orig = {\n l: scale.left + scale._padding.left,\n r: scale.right - scale._padding.right,\n t: scale.top + scale._padding.top,\n b: scale.bottom - scale._padding.bottom\n };\n const limits = Object.assign({}, orig);\n const labelSizes = [];\n const padding = [];\n const valueCount = scale._pointLabels.length;\n const pointLabelOpts = scale.options.pointLabels;\n const additionalAngle = pointLabelOpts.centerPointLabels ? PI / valueCount : 0;\n\n for (let i = 0; i < valueCount; i++) {\n const opts = pointLabelOpts.setContext(scale.getPointLabelContext(i));\n padding[i] = opts.padding;\n const pointPosition = scale.getPointPosition(i, scale.drawingArea + padding[i], additionalAngle);\n const plFont = toFont(opts.font);\n const textSize = measureLabelSize(scale.ctx, plFont, scale._pointLabels[i]);\n labelSizes[i] = textSize;\n\n const angleRadians = _normalizeAngle(scale.getIndexAngle(i) + additionalAngle);\n const angle = Math.round(toDegrees(angleRadians));\n const hLimits = determineLimits(angle, pointPosition.x, textSize.w, 0, 180);\n const vLimits = determineLimits(angle, pointPosition.y, textSize.h, 90, 270);\n updateLimits(limits, orig, angleRadians, hLimits, vLimits);\n }\n\n scale.setCenterPoint(\n orig.l - limits.l,\n limits.r - orig.r,\n orig.t - limits.t,\n limits.b - orig.b\n );\n\n // Now that text size is determined, compute the full positions\n scale._pointLabelItems = buildPointLabelItems(scale, labelSizes, padding);\n}\n\nfunction updateLimits(limits, orig, angle, hLimits, vLimits) {\n const sin = Math.abs(Math.sin(angle));\n const cos = Math.abs(Math.cos(angle));\n let x = 0;\n let y = 0;\n if (hLimits.start < orig.l) {\n x = (orig.l - hLimits.start) / sin;\n limits.l = Math.min(limits.l, orig.l - x);\n } else if (hLimits.end > orig.r) {\n x = (hLimits.end - orig.r) / sin;\n limits.r = Math.max(limits.r, orig.r + x);\n }\n if (vLimits.start < orig.t) {\n y = (orig.t - vLimits.start) / cos;\n limits.t = Math.min(limits.t, orig.t - y);\n } else if (vLimits.end > orig.b) {\n y = (vLimits.end - orig.b) / cos;\n limits.b = Math.max(limits.b, orig.b + y);\n }\n}\n\nfunction createPointLabelItem(scale, index, itemOpts) {\n const outerDistance = scale.drawingArea;\n const {extra, additionalAngle, padding, size} = itemOpts;\n const pointLabelPosition = scale.getPointPosition(index, outerDistance + extra + padding, additionalAngle);\n const angle = Math.round(toDegrees(_normalizeAngle(pointLabelPosition.angle + HALF_PI)));\n const y = yForAngle(pointLabelPosition.y, size.h, angle);\n const textAlign = getTextAlignForAngle(angle);\n const left = leftForTextAlign(pointLabelPosition.x, size.w, textAlign);\n return {\n // if to draw or overlapped\n visible: true,\n\n // Text position\n x: pointLabelPosition.x,\n y,\n\n // Text rendering data\n textAlign,\n\n // Bounding box\n left,\n top: y,\n right: left + size.w,\n bottom: y + size.h\n };\n}\n\nfunction isNotOverlapped(item, area) {\n if (!area) {\n return true;\n }\n const {left, top, right, bottom} = item;\n const apexesInArea = _isPointInArea({x: left, y: top}, area) || _isPointInArea({x: left, y: bottom}, area) ||\n _isPointInArea({x: right, y: top}, area) || _isPointInArea({x: right, y: bottom}, area);\n return !apexesInArea;\n}\n\nfunction buildPointLabelItems(scale, labelSizes, padding) {\n const items = [];\n const valueCount = scale._pointLabels.length;\n const opts = scale.options;\n const {centerPointLabels, display} = opts.pointLabels;\n const itemOpts = {\n extra: getTickBackdropHeight(opts) / 2,\n additionalAngle: centerPointLabels ? PI / valueCount : 0\n };\n let area;\n\n for (let i = 0; i < valueCount; i++) {\n itemOpts.padding = padding[i];\n itemOpts.size = labelSizes[i];\n\n const item = createPointLabelItem(scale, i, itemOpts);\n items.push(item);\n if (display === 'auto') {\n item.visible = isNotOverlapped(item, area);\n if (item.visible) {\n area = item;\n }\n }\n }\n return items;\n}\n\nfunction getTextAlignForAngle(angle) {\n if (angle === 0 || angle === 180) {\n return 'center';\n } else if (angle < 180) {\n return 'left';\n }\n\n return 'right';\n}\n\nfunction leftForTextAlign(x, w, align) {\n if (align === 'right') {\n x -= w;\n } else if (align === 'center') {\n x -= (w / 2);\n }\n return x;\n}\n\nfunction yForAngle(y, h, angle) {\n if (angle === 90 || angle === 270) {\n y -= (h / 2);\n } else if (angle > 270 || angle < 90) {\n y -= h;\n }\n return y;\n}\n\nfunction drawPointLabelBox(ctx, opts, item) {\n const {left, top, right, bottom} = item;\n const {backdropColor} = opts;\n\n if (!isNullOrUndef(backdropColor)) {\n const borderRadius = toTRBLCorners(opts.borderRadius);\n const padding = toPadding(opts.backdropPadding);\n ctx.fillStyle = backdropColor;\n\n const backdropLeft = left - padding.left;\n const backdropTop = top - padding.top;\n const backdropWidth = right - left + padding.width;\n const backdropHeight = bottom - top + padding.height;\n\n if (Object.values(borderRadius).some(v => v !== 0)) {\n ctx.beginPath();\n addRoundedRectPath(ctx, {\n x: backdropLeft,\n y: backdropTop,\n w: backdropWidth,\n h: backdropHeight,\n radius: borderRadius,\n });\n ctx.fill();\n } else {\n ctx.fillRect(backdropLeft, backdropTop, backdropWidth, backdropHeight);\n }\n }\n}\n\nfunction drawPointLabels(scale, labelCount) {\n const {ctx, options: {pointLabels}} = scale;\n\n for (let i = labelCount - 1; i >= 0; i--) {\n const item = scale._pointLabelItems[i];\n if (!item.visible) {\n // overlapping\n continue;\n }\n const optsAtIndex = pointLabels.setContext(scale.getPointLabelContext(i));\n drawPointLabelBox(ctx, optsAtIndex, item);\n const plFont = toFont(optsAtIndex.font);\n const {x, y, textAlign} = item;\n\n renderText(\n ctx,\n scale._pointLabels[i],\n x,\n y + (plFont.lineHeight / 2),\n plFont,\n {\n color: optsAtIndex.color,\n textAlign: textAlign,\n textBaseline: 'middle'\n }\n );\n }\n}\n\nfunction pathRadiusLine(scale, radius, circular, labelCount) {\n const {ctx} = scale;\n if (circular) {\n // Draw circular arcs between the points\n ctx.arc(scale.xCenter, scale.yCenter, radius, 0, TAU);\n } else {\n // Draw straight lines connecting each index\n let pointPosition = scale.getPointPosition(0, radius);\n ctx.moveTo(pointPosition.x, pointPosition.y);\n\n for (let i = 1; i < labelCount; i++) {\n pointPosition = scale.getPointPosition(i, radius);\n ctx.lineTo(pointPosition.x, pointPosition.y);\n }\n }\n}\n\nfunction drawRadiusLine(scale, gridLineOpts, radius, labelCount, borderOpts) {\n const ctx = scale.ctx;\n const circular = gridLineOpts.circular;\n\n const {color, lineWidth} = gridLineOpts;\n\n if ((!circular && !labelCount) || !color || !lineWidth || radius < 0) {\n return;\n }\n\n ctx.save();\n ctx.strokeStyle = color;\n ctx.lineWidth = lineWidth;\n ctx.setLineDash(borderOpts.dash || []);\n ctx.lineDashOffset = borderOpts.dashOffset;\n\n ctx.beginPath();\n pathRadiusLine(scale, radius, circular, labelCount);\n ctx.closePath();\n ctx.stroke();\n ctx.restore();\n}\n\nfunction createPointLabelContext(parent, index, label) {\n return createContext(parent, {\n label,\n index,\n type: 'pointLabel'\n });\n}\n\nexport default class RadialLinearScale extends LinearScaleBase {\n\n static id = 'radialLinear';\n\n /**\n * @type {any}\n */\n static defaults = {\n display: true,\n\n // Boolean - Whether to animate scaling the chart from the centre\n animate: true,\n position: 'chartArea',\n\n angleLines: {\n display: true,\n lineWidth: 1,\n borderDash: [],\n borderDashOffset: 0.0\n },\n\n grid: {\n circular: false\n },\n\n startAngle: 0,\n\n // label settings\n ticks: {\n // Boolean - Show a backdrop to the scale label\n showLabelBackdrop: true,\n\n callback: Ticks.formatters.numeric\n },\n\n pointLabels: {\n backdropColor: undefined,\n\n // Number - The backdrop padding above & below the label in pixels\n backdropPadding: 2,\n\n // Boolean - if true, show point labels\n display: true,\n\n // Number - Point label font size in pixels\n font: {\n size: 10\n },\n\n // Function - Used to convert point labels\n callback(label) {\n return label;\n },\n\n // Number - Additionl padding between scale and pointLabel\n padding: 5,\n\n // Boolean - if true, center point labels to slices in polar chart\n centerPointLabels: false\n }\n };\n\n static defaultRoutes = {\n 'angleLines.color': 'borderColor',\n 'pointLabels.color': 'color',\n 'ticks.color': 'color'\n };\n\n static descriptors = {\n angleLines: {\n _fallback: 'grid'\n }\n };\n\n constructor(cfg) {\n super(cfg);\n\n /** @type {number} */\n this.xCenter = undefined;\n /** @type {number} */\n this.yCenter = undefined;\n /** @type {number} */\n this.drawingArea = undefined;\n /** @type {string[]} */\n this._pointLabels = [];\n this._pointLabelItems = [];\n }\n\n setDimensions() {\n // Set the unconstrained dimension before label rotation\n const padding = this._padding = toPadding(getTickBackdropHeight(this.options) / 2);\n const w = this.width = this.maxWidth - padding.width;\n const h = this.height = this.maxHeight - padding.height;\n this.xCenter = Math.floor(this.left + w / 2 + padding.left);\n this.yCenter = Math.floor(this.top + h / 2 + padding.top);\n this.drawingArea = Math.floor(Math.min(w, h) / 2);\n }\n\n determineDataLimits() {\n const {min, max} = this.getMinMax(false);\n\n this.min = isFinite(min) && !isNaN(min) ? min : 0;\n this.max = isFinite(max) && !isNaN(max) ? max : 0;\n\n // Common base implementation to handle min, max, beginAtZero\n this.handleTickRangeOptions();\n }\n\n /**\n\t * Returns the maximum number of ticks based on the scale dimension\n\t * @protected\n\t */\n computeTickLimit() {\n return Math.ceil(this.drawingArea / getTickBackdropHeight(this.options));\n }\n\n generateTickLabels(ticks) {\n LinearScaleBase.prototype.generateTickLabels.call(this, ticks);\n\n // Point labels\n this._pointLabels = this.getLabels()\n .map((value, index) => {\n const label = callCallback(this.options.pointLabels.callback, [value, index], this);\n return label || label === 0 ? label : '';\n })\n .filter((v, i) => this.chart.getDataVisibility(i));\n }\n\n fit() {\n const opts = this.options;\n\n if (opts.display && opts.pointLabels.display) {\n fitWithPointLabels(this);\n } else {\n this.setCenterPoint(0, 0, 0, 0);\n }\n }\n\n setCenterPoint(leftMovement, rightMovement, topMovement, bottomMovement) {\n this.xCenter += Math.floor((leftMovement - rightMovement) / 2);\n this.yCenter += Math.floor((topMovement - bottomMovement) / 2);\n this.drawingArea -= Math.min(this.drawingArea / 2, Math.max(leftMovement, rightMovement, topMovement, bottomMovement));\n }\n\n getIndexAngle(index) {\n const angleMultiplier = TAU / (this._pointLabels.length || 1);\n const startAngle = this.options.startAngle || 0;\n\n return _normalizeAngle(index * angleMultiplier + toRadians(startAngle));\n }\n\n getDistanceFromCenterForValue(value) {\n if (isNullOrUndef(value)) {\n return NaN;\n }\n\n // Take into account half font size + the yPadding of the top value\n const scalingFactor = this.drawingArea / (this.max - this.min);\n if (this.options.reverse) {\n return (this.max - value) * scalingFactor;\n }\n return (value - this.min) * scalingFactor;\n }\n\n getValueForDistanceFromCenter(distance) {\n if (isNullOrUndef(distance)) {\n return NaN;\n }\n\n const scaledDistance = distance / (this.drawingArea / (this.max - this.min));\n return this.options.reverse ? this.max - scaledDistance : this.min + scaledDistance;\n }\n\n getPointLabelContext(index) {\n const pointLabels = this._pointLabels || [];\n\n if (index >= 0 && index < pointLabels.length) {\n const pointLabel = pointLabels[index];\n return createPointLabelContext(this.getContext(), index, pointLabel);\n }\n }\n\n getPointPosition(index, distanceFromCenter, additionalAngle = 0) {\n const angle = this.getIndexAngle(index) - HALF_PI + additionalAngle;\n return {\n x: Math.cos(angle) * distanceFromCenter + this.xCenter,\n y: Math.sin(angle) * distanceFromCenter + this.yCenter,\n angle\n };\n }\n\n getPointPositionForValue(index, value) {\n return this.getPointPosition(index, this.getDistanceFromCenterForValue(value));\n }\n\n getBasePosition(index) {\n return this.getPointPositionForValue(index || 0, this.getBaseValue());\n }\n\n getPointLabelPosition(index) {\n const {left, top, right, bottom} = this._pointLabelItems[index];\n return {\n left,\n top,\n right,\n bottom,\n };\n }\n\n /**\n\t * @protected\n\t */\n drawBackground() {\n const {backgroundColor, grid: {circular}} = this.options;\n if (backgroundColor) {\n const ctx = this.ctx;\n ctx.save();\n ctx.beginPath();\n pathRadiusLine(this, this.getDistanceFromCenterForValue(this._endValue), circular, this._pointLabels.length);\n ctx.closePath();\n ctx.fillStyle = backgroundColor;\n ctx.fill();\n ctx.restore();\n }\n }\n\n /**\n\t * @protected\n\t */\n drawGrid() {\n const ctx = this.ctx;\n const opts = this.options;\n const {angleLines, grid, border} = opts;\n const labelCount = this._pointLabels.length;\n\n let i, offset, position;\n\n if (opts.pointLabels.display) {\n drawPointLabels(this, labelCount);\n }\n\n if (grid.display) {\n this.ticks.forEach((tick, index) => {\n if (index !== 0 || (index === 0 && this.min < 0)) {\n offset = this.getDistanceFromCenterForValue(tick.value);\n const context = this.getContext(index);\n const optsAtIndex = grid.setContext(context);\n const optsAtIndexBorder = border.setContext(context);\n\n drawRadiusLine(this, optsAtIndex, offset, labelCount, optsAtIndexBorder);\n }\n });\n }\n\n if (angleLines.display) {\n ctx.save();\n\n for (i = labelCount - 1; i >= 0; i--) {\n const optsAtIndex = angleLines.setContext(this.getPointLabelContext(i));\n const {color, lineWidth} = optsAtIndex;\n\n if (!lineWidth || !color) {\n continue;\n }\n\n ctx.lineWidth = lineWidth;\n ctx.strokeStyle = color;\n\n ctx.setLineDash(optsAtIndex.borderDash);\n ctx.lineDashOffset = optsAtIndex.borderDashOffset;\n\n offset = this.getDistanceFromCenterForValue(opts.reverse ? this.min : this.max);\n position = this.getPointPosition(i, offset);\n ctx.beginPath();\n ctx.moveTo(this.xCenter, this.yCenter);\n ctx.lineTo(position.x, position.y);\n ctx.stroke();\n }\n\n ctx.restore();\n }\n }\n\n /**\n\t * @protected\n\t */\n drawBorder() {}\n\n /**\n\t * @protected\n\t */\n drawLabels() {\n const ctx = this.ctx;\n const opts = this.options;\n const tickOpts = opts.ticks;\n\n if (!tickOpts.display) {\n return;\n }\n\n const startAngle = this.getIndexAngle(0);\n let offset, width;\n\n ctx.save();\n ctx.translate(this.xCenter, this.yCenter);\n ctx.rotate(startAngle);\n ctx.textAlign = 'center';\n ctx.textBaseline = 'middle';\n\n this.ticks.forEach((tick, index) => {\n if ((index === 0 && this.min >= 0) && !opts.reverse) {\n return;\n }\n\n const optsAtIndex = tickOpts.setContext(this.getContext(index));\n const tickFont = toFont(optsAtIndex.font);\n offset = this.getDistanceFromCenterForValue(this.ticks[index].value);\n\n if (optsAtIndex.showLabelBackdrop) {\n ctx.font = tickFont.string;\n width = ctx.measureText(tick.label).width;\n ctx.fillStyle = optsAtIndex.backdropColor;\n\n const padding = toPadding(optsAtIndex.backdropPadding);\n ctx.fillRect(\n -width / 2 - padding.left,\n -offset - tickFont.size / 2 - padding.top,\n width + padding.width,\n tickFont.size + padding.height\n );\n }\n\n renderText(ctx, tick.label, 0, -offset, tickFont, {\n color: optsAtIndex.color,\n strokeColor: optsAtIndex.textStrokeColor,\n strokeWidth: optsAtIndex.textStrokeWidth,\n });\n });\n\n ctx.restore();\n }\n\n /**\n\t * @protected\n\t */\n drawTitle() {}\n}\n","import adapters from '../core/core.adapters.js';\nimport {callback as call, isFinite, isNullOrUndef, mergeIf, valueOrDefault} from '../helpers/helpers.core.js';\nimport {toRadians, isNumber, _limitValue} from '../helpers/helpers.math.js';\nimport Scale from '../core/core.scale.js';\nimport {_arrayUnique, _filterBetween, _lookup} from '../helpers/helpers.collection.js';\n\n/**\n * @typedef { import('../core/core.adapters.js').TimeUnit } Unit\n * @typedef {{common: boolean, size: number, steps?: number}} Interval\n * @typedef { import('../core/core.adapters.js').DateAdapter } DateAdapter\n */\n\n/**\n * @type {Object}\n */\nconst INTERVALS = {\n millisecond: {common: true, size: 1, steps: 1000},\n second: {common: true, size: 1000, steps: 60},\n minute: {common: true, size: 60000, steps: 60},\n hour: {common: true, size: 3600000, steps: 24},\n day: {common: true, size: 86400000, steps: 30},\n week: {common: false, size: 604800000, steps: 4},\n month: {common: true, size: 2.628e9, steps: 12},\n quarter: {common: false, size: 7.884e9, steps: 4},\n year: {common: true, size: 3.154e10}\n};\n\n/**\n * @type {Unit[]}\n */\nconst UNITS = /** @type Unit[] */ /* #__PURE__ */ (Object.keys(INTERVALS));\n\n/**\n * @param {number} a\n * @param {number} b\n */\nfunction sorter(a, b) {\n return a - b;\n}\n\n/**\n * @param {TimeScale} scale\n * @param {*} input\n * @return {number}\n */\nfunction parse(scale, input) {\n if (isNullOrUndef(input)) {\n return null;\n }\n\n const adapter = scale._adapter;\n const {parser, round, isoWeekday} = scale._parseOpts;\n let value = input;\n\n if (typeof parser === 'function') {\n value = parser(value);\n }\n\n // Only parse if it's not a timestamp already\n if (!isFinite(value)) {\n value = typeof parser === 'string'\n ? adapter.parse(value, parser)\n : adapter.parse(value);\n }\n\n if (value === null) {\n return null;\n }\n\n if (round) {\n value = round === 'week' && (isNumber(isoWeekday) || isoWeekday === true)\n ? adapter.startOf(value, 'isoWeek', isoWeekday)\n : adapter.startOf(value, round);\n }\n\n return +value;\n}\n\n/**\n * Figures out what unit results in an appropriate number of auto-generated ticks\n * @param {Unit} minUnit\n * @param {number} min\n * @param {number} max\n * @param {number} capacity\n * @return {object}\n */\nfunction determineUnitForAutoTicks(minUnit, min, max, capacity) {\n const ilen = UNITS.length;\n\n for (let i = UNITS.indexOf(minUnit); i < ilen - 1; ++i) {\n const interval = INTERVALS[UNITS[i]];\n const factor = interval.steps ? interval.steps : Number.MAX_SAFE_INTEGER;\n\n if (interval.common && Math.ceil((max - min) / (factor * interval.size)) <= capacity) {\n return UNITS[i];\n }\n }\n\n return UNITS[ilen - 1];\n}\n\n/**\n * Figures out what unit to format a set of ticks with\n * @param {TimeScale} scale\n * @param {number} numTicks\n * @param {Unit} minUnit\n * @param {number} min\n * @param {number} max\n * @return {Unit}\n */\nfunction determineUnitForFormatting(scale, numTicks, minUnit, min, max) {\n for (let i = UNITS.length - 1; i >= UNITS.indexOf(minUnit); i--) {\n const unit = UNITS[i];\n if (INTERVALS[unit].common && scale._adapter.diff(max, min, unit) >= numTicks - 1) {\n return unit;\n }\n }\n\n return UNITS[minUnit ? UNITS.indexOf(minUnit) : 0];\n}\n\n/**\n * @param {Unit} unit\n * @return {object}\n */\nfunction determineMajorUnit(unit) {\n for (let i = UNITS.indexOf(unit) + 1, ilen = UNITS.length; i < ilen; ++i) {\n if (INTERVALS[UNITS[i]].common) {\n return UNITS[i];\n }\n }\n}\n\n/**\n * @param {object} ticks\n * @param {number} time\n * @param {number[]} [timestamps] - if defined, snap to these timestamps\n */\nfunction addTick(ticks, time, timestamps) {\n if (!timestamps) {\n ticks[time] = true;\n } else if (timestamps.length) {\n const {lo, hi} = _lookup(timestamps, time);\n const timestamp = timestamps[lo] >= time ? timestamps[lo] : timestamps[hi];\n ticks[timestamp] = true;\n }\n}\n\n/**\n * @param {TimeScale} scale\n * @param {object[]} ticks\n * @param {object} map\n * @param {Unit} majorUnit\n * @return {object[]}\n */\nfunction setMajorTicks(scale, ticks, map, majorUnit) {\n const adapter = scale._adapter;\n const first = +adapter.startOf(ticks[0].value, majorUnit);\n const last = ticks[ticks.length - 1].value;\n let major, index;\n\n for (major = first; major <= last; major = +adapter.add(major, 1, majorUnit)) {\n index = map[major];\n if (index >= 0) {\n ticks[index].major = true;\n }\n }\n return ticks;\n}\n\n/**\n * @param {TimeScale} scale\n * @param {number[]} values\n * @param {Unit|undefined} [majorUnit]\n * @return {object[]}\n */\nfunction ticksFromTimestamps(scale, values, majorUnit) {\n const ticks = [];\n /** @type {Object} */\n const map = {};\n const ilen = values.length;\n let i, value;\n\n for (i = 0; i < ilen; ++i) {\n value = values[i];\n map[value] = i;\n\n ticks.push({\n value,\n major: false\n });\n }\n\n // We set the major ticks separately from the above loop because calling startOf for every tick\n // is expensive when there is a large number of ticks\n return (ilen === 0 || !majorUnit) ? ticks : setMajorTicks(scale, ticks, map, majorUnit);\n}\n\nexport default class TimeScale extends Scale {\n\n static id = 'time';\n\n /**\n * @type {any}\n */\n static defaults = {\n /**\n * Scale boundary strategy (bypassed by min/max time options)\n * - `data`: make sure data are fully visible, ticks outside are removed\n * - `ticks`: make sure ticks are fully visible, data outside are truncated\n * @see https://github.com/chartjs/Chart.js/pull/4556\n * @since 2.7.0\n */\n bounds: 'data',\n\n adapters: {},\n time: {\n parser: false, // false == a pattern string from or a custom callback that converts its argument to a timestamp\n unit: false, // false == automatic or override with week, month, year, etc.\n round: false, // none, or override with week, month, year, etc.\n isoWeekday: false, // override week start day\n minUnit: 'millisecond',\n displayFormats: {}\n },\n ticks: {\n /**\n * Ticks generation input values:\n * - 'auto': generates \"optimal\" ticks based on scale size and time options.\n * - 'data': generates ticks from data (including labels from data {t|x|y} objects).\n * - 'labels': generates ticks from user given `data.labels` values ONLY.\n * @see https://github.com/chartjs/Chart.js/pull/4507\n * @since 2.7.0\n */\n source: 'auto',\n\n callback: false,\n\n major: {\n enabled: false\n }\n }\n };\n\n /**\n\t * @param {object} props\n\t */\n constructor(props) {\n super(props);\n\n /** @type {{data: number[], labels: number[], all: number[]}} */\n this._cache = {\n data: [],\n labels: [],\n all: []\n };\n\n /** @type {Unit} */\n this._unit = 'day';\n /** @type {Unit=} */\n this._majorUnit = undefined;\n this._offsets = {};\n this._normalized = false;\n this._parseOpts = undefined;\n }\n\n init(scaleOpts, opts = {}) {\n const time = scaleOpts.time || (scaleOpts.time = {});\n /** @type {DateAdapter} */\n const adapter = this._adapter = new adapters._date(scaleOpts.adapters.date);\n\n adapter.init(opts);\n\n // Backward compatibility: before introducing adapter, `displayFormats` was\n // supposed to contain *all* unit/string pairs but this can't be resolved\n // when loading the scale (adapters are loaded afterward), so let's populate\n // missing formats on update\n mergeIf(time.displayFormats, adapter.formats());\n\n this._parseOpts = {\n parser: time.parser,\n round: time.round,\n isoWeekday: time.isoWeekday\n };\n\n super.init(scaleOpts);\n\n this._normalized = opts.normalized;\n }\n\n /**\n\t * @param {*} raw\n\t * @param {number?} [index]\n\t * @return {number}\n\t */\n parse(raw, index) { // eslint-disable-line no-unused-vars\n if (raw === undefined) {\n return null;\n }\n return parse(this, raw);\n }\n\n beforeLayout() {\n super.beforeLayout();\n this._cache = {\n data: [],\n labels: [],\n all: []\n };\n }\n\n determineDataLimits() {\n const options = this.options;\n const adapter = this._adapter;\n const unit = options.time.unit || 'day';\n // eslint-disable-next-line prefer-const\n let {min, max, minDefined, maxDefined} = this.getUserBounds();\n\n /**\n\t\t * @param {object} bounds\n\t\t */\n function _applyBounds(bounds) {\n if (!minDefined && !isNaN(bounds.min)) {\n min = Math.min(min, bounds.min);\n }\n if (!maxDefined && !isNaN(bounds.max)) {\n max = Math.max(max, bounds.max);\n }\n }\n\n // If we have user provided `min` and `max` labels / data bounds can be ignored\n if (!minDefined || !maxDefined) {\n // Labels are always considered, when user did not force bounds\n _applyBounds(this._getLabelBounds());\n\n // If `bounds` is `'ticks'` and `ticks.source` is `'labels'`,\n // data bounds are ignored (and don't need to be determined)\n if (options.bounds !== 'ticks' || options.ticks.source !== 'labels') {\n _applyBounds(this.getMinMax(false));\n }\n }\n\n min = isFinite(min) && !isNaN(min) ? min : +adapter.startOf(Date.now(), unit);\n max = isFinite(max) && !isNaN(max) ? max : +adapter.endOf(Date.now(), unit) + 1;\n\n // Make sure that max is strictly higher than min (required by the timeseries lookup table)\n this.min = Math.min(min, max - 1);\n this.max = Math.max(min + 1, max);\n }\n\n /**\n\t * @private\n\t */\n _getLabelBounds() {\n const arr = this.getLabelTimestamps();\n let min = Number.POSITIVE_INFINITY;\n let max = Number.NEGATIVE_INFINITY;\n\n if (arr.length) {\n min = arr[0];\n max = arr[arr.length - 1];\n }\n return {min, max};\n }\n\n /**\n\t * @return {object[]}\n\t */\n buildTicks() {\n const options = this.options;\n const timeOpts = options.time;\n const tickOpts = options.ticks;\n const timestamps = tickOpts.source === 'labels' ? this.getLabelTimestamps() : this._generate();\n\n if (options.bounds === 'ticks' && timestamps.length) {\n this.min = this._userMin || timestamps[0];\n this.max = this._userMax || timestamps[timestamps.length - 1];\n }\n\n const min = this.min;\n const max = this.max;\n\n const ticks = _filterBetween(timestamps, min, max);\n\n // PRIVATE\n // determineUnitForFormatting relies on the number of ticks so we don't use it when\n // autoSkip is enabled because we don't yet know what the final number of ticks will be\n this._unit = timeOpts.unit || (tickOpts.autoSkip\n ? determineUnitForAutoTicks(timeOpts.minUnit, this.min, this.max, this._getLabelCapacity(min))\n : determineUnitForFormatting(this, ticks.length, timeOpts.minUnit, this.min, this.max));\n this._majorUnit = !tickOpts.major.enabled || this._unit === 'year' ? undefined\n : determineMajorUnit(this._unit);\n this.initOffsets(timestamps);\n\n if (options.reverse) {\n ticks.reverse();\n }\n\n return ticksFromTimestamps(this, ticks, this._majorUnit);\n }\n\n afterAutoSkip() {\n // Offsets for bar charts need to be handled with the auto skipped\n // ticks. Once ticks have been skipped, we re-compute the offsets.\n if (this.options.offsetAfterAutoskip) {\n this.initOffsets(this.ticks.map(tick => +tick.value));\n }\n }\n\n /**\n\t * Returns the start and end offsets from edges in the form of {start, end}\n\t * where each value is a relative width to the scale and ranges between 0 and 1.\n\t * They add extra margins on the both sides by scaling down the original scale.\n\t * Offsets are added when the `offset` option is true.\n\t * @param {number[]} timestamps\n\t * @protected\n\t */\n initOffsets(timestamps = []) {\n let start = 0;\n let end = 0;\n let first, last;\n\n if (this.options.offset && timestamps.length) {\n first = this.getDecimalForValue(timestamps[0]);\n if (timestamps.length === 1) {\n start = 1 - first;\n } else {\n start = (this.getDecimalForValue(timestamps[1]) - first) / 2;\n }\n last = this.getDecimalForValue(timestamps[timestamps.length - 1]);\n if (timestamps.length === 1) {\n end = last;\n } else {\n end = (last - this.getDecimalForValue(timestamps[timestamps.length - 2])) / 2;\n }\n }\n const limit = timestamps.length < 3 ? 0.5 : 0.25;\n start = _limitValue(start, 0, limit);\n end = _limitValue(end, 0, limit);\n\n this._offsets = {start, end, factor: 1 / (start + 1 + end)};\n }\n\n /**\n\t * Generates a maximum of `capacity` timestamps between min and max, rounded to the\n\t * `minor` unit using the given scale time `options`.\n\t * Important: this method can return ticks outside the min and max range, it's the\n\t * responsibility of the calling code to clamp values if needed.\n\t * @protected\n\t */\n _generate() {\n const adapter = this._adapter;\n const min = this.min;\n const max = this.max;\n const options = this.options;\n const timeOpts = options.time;\n // @ts-ignore\n const minor = timeOpts.unit || determineUnitForAutoTicks(timeOpts.minUnit, min, max, this._getLabelCapacity(min));\n const stepSize = valueOrDefault(options.ticks.stepSize, 1);\n const weekday = minor === 'week' ? timeOpts.isoWeekday : false;\n const hasWeekday = isNumber(weekday) || weekday === true;\n const ticks = {};\n let first = min;\n let time, count;\n\n // For 'week' unit, handle the first day of week option\n if (hasWeekday) {\n first = +adapter.startOf(first, 'isoWeek', weekday);\n }\n\n // Align first ticks on unit\n first = +adapter.startOf(first, hasWeekday ? 'day' : minor);\n\n // Prevent browser from freezing in case user options request millions of milliseconds\n if (adapter.diff(max, min, minor) > 100000 * stepSize) {\n throw new Error(min + ' and ' + max + ' are too far apart with stepSize of ' + stepSize + ' ' + minor);\n }\n\n const timestamps = options.ticks.source === 'data' && this.getDataTimestamps();\n for (time = first, count = 0; time < max; time = +adapter.add(time, stepSize, minor), count++) {\n addTick(ticks, time, timestamps);\n }\n\n if (time === max || options.bounds === 'ticks' || count === 1) {\n addTick(ticks, time, timestamps);\n }\n\n // @ts-ignore\n return Object.keys(ticks).sort(sorter).map(x => +x);\n }\n\n /**\n\t * @param {number} value\n\t * @return {string}\n\t */\n getLabelForValue(value) {\n const adapter = this._adapter;\n const timeOpts = this.options.time;\n\n if (timeOpts.tooltipFormat) {\n return adapter.format(value, timeOpts.tooltipFormat);\n }\n return adapter.format(value, timeOpts.displayFormats.datetime);\n }\n\n /**\n\t * @param {number} value\n\t * @param {string|undefined} format\n\t * @return {string}\n\t */\n format(value, format) {\n const options = this.options;\n const formats = options.time.displayFormats;\n const unit = this._unit;\n const fmt = format || formats[unit];\n return this._adapter.format(value, fmt);\n }\n\n /**\n\t * Function to format an individual tick mark\n\t * @param {number} time\n\t * @param {number} index\n\t * @param {object[]} ticks\n\t * @param {string|undefined} [format]\n\t * @return {string}\n\t * @private\n\t */\n _tickFormatFunction(time, index, ticks, format) {\n const options = this.options;\n const formatter = options.ticks.callback;\n\n if (formatter) {\n return call(formatter, [time, index, ticks], this);\n }\n\n const formats = options.time.displayFormats;\n const unit = this._unit;\n const majorUnit = this._majorUnit;\n const minorFormat = unit && formats[unit];\n const majorFormat = majorUnit && formats[majorUnit];\n const tick = ticks[index];\n const major = majorUnit && majorFormat && tick && tick.major;\n\n return this._adapter.format(time, format || (major ? majorFormat : minorFormat));\n }\n\n /**\n\t * @param {object[]} ticks\n\t */\n generateTickLabels(ticks) {\n let i, ilen, tick;\n\n for (i = 0, ilen = ticks.length; i < ilen; ++i) {\n tick = ticks[i];\n tick.label = this._tickFormatFunction(tick.value, i, ticks);\n }\n }\n\n /**\n\t * @param {number} value - Milliseconds since epoch (1 January 1970 00:00:00 UTC)\n\t * @return {number}\n\t */\n getDecimalForValue(value) {\n return value === null ? NaN : (value - this.min) / (this.max - this.min);\n }\n\n /**\n\t * @param {number} value - Milliseconds since epoch (1 January 1970 00:00:00 UTC)\n\t * @return {number}\n\t */\n getPixelForValue(value) {\n const offsets = this._offsets;\n const pos = this.getDecimalForValue(value);\n return this.getPixelForDecimal((offsets.start + pos) * offsets.factor);\n }\n\n /**\n\t * @param {number} pixel\n\t * @return {number}\n\t */\n getValueForPixel(pixel) {\n const offsets = this._offsets;\n const pos = this.getDecimalForPixel(pixel) / offsets.factor - offsets.end;\n return this.min + pos * (this.max - this.min);\n }\n\n /**\n\t * @param {string} label\n\t * @return {{w:number, h:number}}\n\t * @private\n\t */\n _getLabelSize(label) {\n const ticksOpts = this.options.ticks;\n const tickLabelWidth = this.ctx.measureText(label).width;\n const angle = toRadians(this.isHorizontal() ? ticksOpts.maxRotation : ticksOpts.minRotation);\n const cosRotation = Math.cos(angle);\n const sinRotation = Math.sin(angle);\n const tickFontSize = this._resolveTickFontOptions(0).size;\n\n return {\n w: (tickLabelWidth * cosRotation) + (tickFontSize * sinRotation),\n h: (tickLabelWidth * sinRotation) + (tickFontSize * cosRotation)\n };\n }\n\n /**\n\t * @param {number} exampleTime\n\t * @return {number}\n\t * @private\n\t */\n _getLabelCapacity(exampleTime) {\n const timeOpts = this.options.time;\n const displayFormats = timeOpts.displayFormats;\n\n // pick the longest format (milliseconds) for guesstimation\n const format = displayFormats[timeOpts.unit] || displayFormats.millisecond;\n const exampleLabel = this._tickFormatFunction(exampleTime, 0, ticksFromTimestamps(this, [exampleTime], this._majorUnit), format);\n const size = this._getLabelSize(exampleLabel);\n // subtract 1 - if offset then there's one less label than tick\n // if not offset then one half label padding is added to each end leaving room for one less label\n const capacity = Math.floor(this.isHorizontal() ? this.width / size.w : this.height / size.h) - 1;\n return capacity > 0 ? capacity : 1;\n }\n\n /**\n\t * @protected\n\t */\n getDataTimestamps() {\n let timestamps = this._cache.data || [];\n let i, ilen;\n\n if (timestamps.length) {\n return timestamps;\n }\n\n const metas = this.getMatchingVisibleMetas();\n\n if (this._normalized && metas.length) {\n return (this._cache.data = metas[0].controller.getAllParsedValues(this));\n }\n\n for (i = 0, ilen = metas.length; i < ilen; ++i) {\n timestamps = timestamps.concat(metas[i].controller.getAllParsedValues(this));\n }\n\n return (this._cache.data = this.normalize(timestamps));\n }\n\n /**\n\t * @protected\n\t */\n getLabelTimestamps() {\n const timestamps = this._cache.labels || [];\n let i, ilen;\n\n if (timestamps.length) {\n return timestamps;\n }\n\n const labels = this.getLabels();\n for (i = 0, ilen = labels.length; i < ilen; ++i) {\n timestamps.push(parse(this, labels[i]));\n }\n\n return (this._cache.labels = this._normalized ? timestamps : this.normalize(timestamps));\n }\n\n /**\n\t * @param {number[]} values\n\t * @protected\n\t */\n normalize(values) {\n // It seems to be somewhat faster to do sorting first\n return _arrayUnique(values.sort(sorter));\n }\n}\n","import TimeScale from './scale.time.js';\nimport {_lookupByKey} from '../helpers/helpers.collection.js';\n\n/**\n * Linearly interpolates the given source `val` using the table. If value is out of bounds, values\n * at edges are used for the interpolation.\n * @param {object} table\n * @param {number} val\n * @param {boolean} [reverse] lookup time based on position instead of vice versa\n * @return {object}\n */\nfunction interpolate(table, val, reverse) {\n let lo = 0;\n let hi = table.length - 1;\n let prevSource, nextSource, prevTarget, nextTarget;\n if (reverse) {\n if (val >= table[lo].pos && val <= table[hi].pos) {\n ({lo, hi} = _lookupByKey(table, 'pos', val));\n }\n ({pos: prevSource, time: prevTarget} = table[lo]);\n ({pos: nextSource, time: nextTarget} = table[hi]);\n } else {\n if (val >= table[lo].time && val <= table[hi].time) {\n ({lo, hi} = _lookupByKey(table, 'time', val));\n }\n ({time: prevSource, pos: prevTarget} = table[lo]);\n ({time: nextSource, pos: nextTarget} = table[hi]);\n }\n\n const span = nextSource - prevSource;\n return span ? prevTarget + (nextTarget - prevTarget) * (val - prevSource) / span : prevTarget;\n}\n\nclass TimeSeriesScale extends TimeScale {\n\n static id = 'timeseries';\n\n /**\n * @type {any}\n */\n static defaults = TimeScale.defaults;\n\n /**\n\t * @param {object} props\n\t */\n constructor(props) {\n super(props);\n\n /** @type {object[]} */\n this._table = [];\n /** @type {number} */\n this._minPos = undefined;\n /** @type {number} */\n this._tableRange = undefined;\n }\n\n /**\n\t * @protected\n\t */\n initOffsets() {\n const timestamps = this._getTimestampsForTable();\n const table = this._table = this.buildLookupTable(timestamps);\n this._minPos = interpolate(table, this.min);\n this._tableRange = interpolate(table, this.max) - this._minPos;\n super.initOffsets(timestamps);\n }\n\n /**\n\t * Returns an array of {time, pos} objects used to interpolate a specific `time` or position\n\t * (`pos`) on the scale, by searching entries before and after the requested value. `pos` is\n\t * a decimal between 0 and 1: 0 being the start of the scale (left or top) and 1 the other\n\t * extremity (left + width or top + height). Note that it would be more optimized to directly\n\t * store pre-computed pixels, but the scale dimensions are not guaranteed at the time we need\n\t * to create the lookup table. The table ALWAYS contains at least two items: min and max.\n\t * @param {number[]} timestamps\n\t * @return {object[]}\n\t * @protected\n\t */\n buildLookupTable(timestamps) {\n const {min, max} = this;\n const items = [];\n const table = [];\n let i, ilen, prev, curr, next;\n\n for (i = 0, ilen = timestamps.length; i < ilen; ++i) {\n curr = timestamps[i];\n if (curr >= min && curr <= max) {\n items.push(curr);\n }\n }\n\n if (items.length < 2) {\n // In case there is less that 2 timestamps between min and max, the scale is defined by min and max\n return [\n {time: min, pos: 0},\n {time: max, pos: 1}\n ];\n }\n\n for (i = 0, ilen = items.length; i < ilen; ++i) {\n next = items[i + 1];\n prev = items[i - 1];\n curr = items[i];\n\n // only add points that breaks the scale linearity\n if (Math.round((next + prev) / 2) !== curr) {\n table.push({time: curr, pos: i / (ilen - 1)});\n }\n }\n return table;\n }\n\n /**\n * Generates all timestamps defined in the data.\n * Important: this method can return ticks outside the min and max range, it's the\n * responsibility of the calling code to clamp values if needed.\n * @protected\n */\n _generate() {\n const min = this.min;\n const max = this.max;\n let timestamps = super.getDataTimestamps();\n if (!timestamps.includes(min) || !timestamps.length) {\n timestamps.splice(0, 0, min);\n }\n if (!timestamps.includes(max) || timestamps.length === 1) {\n timestamps.push(max);\n }\n return timestamps.sort((a, b) => a - b);\n }\n\n /**\n\t * Returns all timestamps\n\t * @return {number[]}\n\t * @private\n\t */\n _getTimestampsForTable() {\n let timestamps = this._cache.all || [];\n\n if (timestamps.length) {\n return timestamps;\n }\n\n const data = this.getDataTimestamps();\n const label = this.getLabelTimestamps();\n if (data.length && label.length) {\n // If combining labels and data (data might not contain all labels),\n // we need to recheck uniqueness and sort\n timestamps = this.normalize(data.concat(label));\n } else {\n timestamps = data.length ? data : label;\n }\n timestamps = this._cache.all = timestamps;\n\n return timestamps;\n }\n\n /**\n\t * @param {number} value - Milliseconds since epoch (1 January 1970 00:00:00 UTC)\n\t * @return {number}\n\t */\n getDecimalForValue(value) {\n return (interpolate(this._table, value) - this._minPos) / this._tableRange;\n }\n\n /**\n\t * @param {number} pixel\n\t * @return {number}\n\t */\n getValueForPixel(pixel) {\n const offsets = this._offsets;\n const decimal = this.getDecimalForPixel(pixel) / offsets.factor - offsets.end;\n return interpolate(this._table, decimal * this._tableRange + this._minPos, true);\n }\n}\n\nexport default TimeSeriesScale;\n","import type { PropType } from 'vue'\nimport type {\n ChartType,\n ChartData,\n ChartOptions,\n Plugin,\n UpdateMode\n} from 'chart.js'\n\nexport const CommonProps = {\n data: {\n type: Object as PropType,\n required: true\n },\n options: {\n type: Object as PropType,\n default: () => ({})\n },\n plugins: {\n type: Array as PropType,\n default: () => []\n },\n datasetIdKey: {\n type: String,\n default: 'label'\n },\n updateMode: {\n type: String as PropType,\n default: undefined\n }\n} as const\n\nexport const A11yProps = {\n ariaLabel: {\n type: String\n },\n ariaDescribedby: {\n type: String\n }\n} as const\n\nexport const Props = {\n type: {\n type: String as PropType,\n required: true\n },\n destroyDelay: {\n type: Number,\n default: 0 // No delay by default\n },\n ...CommonProps,\n ...A11yProps\n} as const\n","import { isProxy, toRaw, version } from 'vue'\nimport type {\n Chart,\n ChartType,\n ChartData,\n ChartDataset,\n ChartOptions,\n DefaultDataPoint\n} from 'chart.js'\n\nexport const compatProps =\n version[0] === '2'\n ? (internals: I, props: T) =>\n Object.assign(internals, { attrs: props }) as unknown as I & T\n : (internals: I, props: T) =>\n Object.assign(internals, props)\n\nexport function toRawIfProxy(obj: T) {\n return isProxy(obj) ? toRaw(obj) : obj\n}\n\nexport function cloneProxy(obj: T, src = obj) {\n return isProxy(src) ? new Proxy(obj, {}) : obj\n}\n\nexport function setOptions<\n TType extends ChartType = ChartType,\n TData = DefaultDataPoint,\n TLabel = unknown\n>(chart: Chart, nextOptions: ChartOptions) {\n const options = chart.options\n\n if (options && nextOptions) {\n Object.assign(options, nextOptions)\n }\n}\n\nexport function setLabels<\n TType extends ChartType = ChartType,\n TData = DefaultDataPoint,\n TLabel = unknown\n>(\n currentData: ChartData,\n nextLabels: TLabel[] | undefined\n) {\n currentData.labels = nextLabels\n}\n\nexport function setDatasets<\n TType extends ChartType = ChartType,\n TData = DefaultDataPoint,\n TLabel = unknown\n>(\n currentData: ChartData,\n nextDatasets: ChartDataset[],\n datasetIdKey: string\n) {\n const addedDatasets: ChartDataset[] = []\n\n currentData.datasets = nextDatasets.map(\n (nextDataset: Record) => {\n // given the new set, find it's current match\n const currentDataset = currentData.datasets.find(\n (dataset: Record) =>\n dataset[datasetIdKey] === nextDataset[datasetIdKey]\n )\n\n // There is no original to update, so simply add new one\n if (\n !currentDataset ||\n !nextDataset.data ||\n addedDatasets.includes(currentDataset)\n ) {\n return { ...nextDataset } as ChartDataset\n }\n\n addedDatasets.push(currentDataset)\n\n Object.assign(currentDataset, nextDataset)\n\n return currentDataset\n }\n )\n}\n\nexport function cloneData<\n TType extends ChartType = ChartType,\n TData = DefaultDataPoint,\n TLabel = unknown\n>(data: ChartData, datasetIdKey: string) {\n const nextData: ChartData = {\n labels: [],\n datasets: []\n }\n\n setLabels(nextData, data.labels)\n setDatasets(nextData, data.datasets, datasetIdKey)\n\n return nextData\n}\n\n/**\n * Get dataset from mouse click event\n * @param chart - Chart.js instance\n * @param event - Mouse click event\n * @returns Dataset\n */\nexport function getDatasetAtEvent(chart: Chart, event: MouseEvent) {\n return chart.getElementsAtEventForMode(\n event,\n 'dataset',\n { intersect: true },\n false\n )\n}\n\n/**\n * Get single dataset element from mouse click event\n * @param chart - Chart.js instance\n * @param event - Mouse click event\n * @returns Dataset\n */\nexport function getElementAtEvent(chart: Chart, event: MouseEvent) {\n return chart.getElementsAtEventForMode(\n event,\n 'nearest',\n { intersect: true },\n false\n )\n}\n\n/**\n * Get all dataset elements from mouse click event\n * @param chart - Chart.js instance\n * @param event - Mouse click event\n * @returns Dataset\n */\nexport function getElementsAtEvent(chart: Chart, event: MouseEvent) {\n return chart.getElementsAtEventForMode(\n event,\n 'index',\n { intersect: true },\n false\n )\n}\n","import { Chart as ChartJS } from 'chart.js'\nimport {\n defineComponent,\n h,\n nextTick,\n onUnmounted,\n onMounted,\n ref,\n shallowRef,\n toRaw,\n watch\n} from 'vue'\n\nimport type { ChartComponent } from './types.js'\nimport { Props } from './props.js'\nimport {\n cloneData,\n setLabels,\n setDatasets,\n setOptions,\n toRawIfProxy,\n cloneProxy\n} from './utils.js'\n\nexport const Chart = defineComponent({\n props: Props,\n setup(props, { expose, slots }) {\n const canvasRef = ref(null)\n const chartRef = shallowRef(null)\n\n expose({ chart: chartRef })\n\n const renderChart = () => {\n if (!canvasRef.value) return\n\n const { type, data, options, plugins, datasetIdKey } = props\n const clonedData = cloneData(data, datasetIdKey)\n const proxiedData = cloneProxy(clonedData, data)\n\n chartRef.value = new ChartJS(canvasRef.value, {\n type,\n data: proxiedData,\n options: { ...options },\n plugins\n })\n }\n\n const destroyChart = () => {\n const chart = toRaw(chartRef.value)\n\n if (chart) {\n if (props.destroyDelay > 0) {\n setTimeout(() => {\n chart.destroy()\n chartRef.value = null\n }, props.destroyDelay)\n } else {\n chart.destroy()\n chartRef.value = null\n }\n }\n }\n\n const update = (chart: ChartJS) => {\n chart.update(props.updateMode)\n }\n\n onMounted(renderChart)\n\n onUnmounted(destroyChart)\n\n watch(\n [() => props.options, () => props.data],\n (\n [nextOptionsProxy, nextDataProxy],\n [prevOptionsProxy, prevDataProxy]\n ) => {\n const chart = toRaw(chartRef.value)\n\n if (!chart) {\n return\n }\n\n let shouldUpdate = false\n\n if (nextOptionsProxy) {\n const nextOptions = toRawIfProxy(nextOptionsProxy)\n const prevOptions = toRawIfProxy(prevOptionsProxy)\n\n if (nextOptions && nextOptions !== prevOptions) {\n setOptions(chart, nextOptions)\n shouldUpdate = true\n }\n }\n\n if (nextDataProxy) {\n const nextLabels = toRawIfProxy(nextDataProxy.labels)\n const prevLabels = toRawIfProxy(prevDataProxy.labels)\n const nextDatasets = toRawIfProxy(nextDataProxy.datasets)\n const prevDatasets = toRawIfProxy(prevDataProxy.datasets)\n\n if (nextLabels !== prevLabels) {\n setLabels(chart.config.data, nextLabels)\n shouldUpdate = true\n }\n\n if (nextDatasets && nextDatasets !== prevDatasets) {\n setDatasets(chart.config.data, nextDatasets, props.datasetIdKey)\n shouldUpdate = true\n }\n }\n\n if (shouldUpdate) {\n nextTick(() => {\n update(chart)\n })\n }\n },\n { deep: true }\n )\n\n return () => {\n return h(\n 'canvas',\n {\n role: 'img',\n 'aria-label': props.ariaLabel,\n 'aria-describedby': props.ariaDescribedby,\n ref: canvasRef\n },\n [h('p', {}, [slots.default ? slots.default() : ''])]\n )\n }\n }\n}) as ChartComponent\n","import { defineComponent, shallowRef, h } from 'vue'\nimport type { ChartType, ChartComponentLike, DefaultDataPoint } from 'chart.js'\nimport {\n Chart as ChartJS,\n BarController,\n BubbleController,\n DoughnutController,\n LineController,\n PieController,\n PolarAreaController,\n RadarController,\n ScatterController\n} from 'chart.js'\nimport type { DistributiveArray } from 'chart.js/dist/types/utils'\nimport type { TypedChartComponent, ChartComponentRef } from './types.js'\nimport { CommonProps } from './props.js'\nimport { Chart } from './chart.js'\nimport { compatProps } from './utils.js'\n\nexport function createTypedChart<\n TType extends ChartType = ChartType,\n TData = DefaultDataPoint,\n TLabel = unknown\n>(\n type: TType,\n registerables: ChartComponentLike\n): TypedChartComponent {\n ChartJS.register(registerables)\n\n return defineComponent({\n props: CommonProps,\n setup(props, { expose }) {\n const ref = shallowRef(null)\n const reforwardRef = (chartRef: ChartComponentRef) => {\n ref.value = chartRef?.chart\n }\n\n expose({ chart: ref })\n\n return () => {\n return h(\n Chart,\n compatProps(\n {\n ref: reforwardRef as any\n },\n {\n type,\n ...props\n }\n )\n )\n }\n }\n }) as any\n}\n\nexport interface ExtendedDataPoint {\n [key: string]: string | number | null | ExtendedDataPoint\n}\n\nexport const Bar = /* #__PURE__ */ createTypedChart<\n 'bar',\n DefaultDataPoint<'bar'> | DistributiveArray\n>('bar', BarController)\n\nexport const Doughnut = /* #__PURE__ */ createTypedChart(\n 'doughnut',\n DoughnutController\n)\n\nexport const Line = /* #__PURE__ */ createTypedChart('line', LineController)\n\nexport const Pie = /* #__PURE__ */ createTypedChart('pie', PieController)\n\nexport const PolarArea = /* #__PURE__ */ createTypedChart(\n 'polarArea',\n PolarAreaController\n)\n\nexport const Radar = /* #__PURE__ */ createTypedChart('radar', RadarController)\n\nexport const Bubble = /* #__PURE__ */ createTypedChart(\n 'bubble',\n BubbleController\n)\n\nexport const Scatter = /* #__PURE__ */ createTypedChart(\n 'scatter',\n ScatterController\n)\n","/**\r\n * BatchProcessor - 批量数据处理类\r\n * \r\n * 处理批量数据获取和处理的核心类,使用 cursor 分页机制获取所有数据。\r\n * 支持进度回调和取消功能。\r\n */\r\n\r\nimport fetchWithAuth from '@/utils/fetchWithAuth';\r\n\r\n/**\r\n * 批量操作错误类\r\n * 提供错误代码、是否可恢复、建议操作等信息\r\n */\r\nexport class BatchOperationError extends Error {\r\n constructor(message, code, recoverable = false, suggestion = '') {\r\n super(message);\r\n this.name = 'BatchOperationError';\r\n this.code = code;\r\n this.recoverable = recoverable;\r\n this.suggestion = suggestion;\r\n }\r\n}\r\n\r\n/**\r\n * 错误处理器映射\r\n * 根据 HTTP 状态码返回对应的错误对象\r\n */\r\nconst ERROR_HANDLERS = {\r\n 401: () => new BatchOperationError(\r\n '认证失败,请重新登录',\r\n 'AUTH_FAILED',\r\n false,\r\n '请刷新页面并重新登录'\r\n ),\r\n 403: () => new BatchOperationError(\r\n '权限不足或请求被拒绝',\r\n 'FORBIDDEN',\r\n false,\r\n '请确认您有管理员权限'\r\n ),\r\n 400: (details) => new BatchOperationError(\r\n `请求数据无效: ${details}`,\r\n 'INVALID_DATA',\r\n true,\r\n '请检查数据格式后重试'\r\n ),\r\n 500: () => new BatchOperationError(\r\n '服务器内部错误',\r\n 'SERVER_ERROR',\r\n true,\r\n '请稍后重试,如果问题持续请联系管理员'\r\n ),\r\n NETWORK: () => new BatchOperationError(\r\n '网络连接失败',\r\n 'NETWORK_ERROR',\r\n true,\r\n '请检查网络连接后重试'\r\n ),\r\n ABORT: () => new BatchOperationError(\r\n '操作已取消',\r\n 'ABORTED',\r\n false,\r\n ''\r\n )\r\n};\r\n\r\n/**\r\n * 根据错误创建 BatchOperationError\r\n * @param {Error|Response} error - 原始错误或响应对象\r\n * @param {string} details - 错误详情\r\n * @returns {BatchOperationError}\r\n */\r\nfunction createError(error, details = '') {\r\n // 处理取消操作\r\n if (error.name === 'AbortError') {\r\n return ERROR_HANDLERS.ABORT();\r\n }\r\n \r\n // 处理 HTTP 响应错误\r\n if (error instanceof Response || (error && typeof error.status === 'number')) {\r\n const handler = ERROR_HANDLERS[error.status];\r\n if (handler) {\r\n return handler(details);\r\n }\r\n return new BatchOperationError(\r\n `请求失败: ${error.status}`,\r\n 'HTTP_ERROR',\r\n true,\r\n '请稍后重试'\r\n );\r\n }\r\n \r\n // 处理网络错误\r\n if (error instanceof TypeError && error.message.includes('fetch')) {\r\n return ERROR_HANDLERS.NETWORK();\r\n }\r\n \r\n // 其他错误\r\n return new BatchOperationError(\r\n error.message || '未知错误',\r\n 'UNKNOWN_ERROR',\r\n true,\r\n '请稍后重试'\r\n );\r\n}\r\n\r\n/**\r\n * BatchProcessor 类\r\n * \r\n * 用于批量获取和处理数据的核心类\r\n */\r\nclass BatchProcessor {\r\n /**\r\n * 创建 BatchProcessor 实例\r\n * @param {Object} options - 配置选项\r\n * @param {number} options.batchSize - 每批数据量,默认 1000\r\n * @param {Function} options.onProgress - 进度回调函数\r\n * @param {Function} options.onError - 错误回调函数\r\n */\r\n constructor(options = {}) {\r\n this.batchSize = options.batchSize || 1000;\r\n this.onProgress = options.onProgress || (() => {});\r\n this.onError = options.onError || (() => {});\r\n this.abortController = null;\r\n }\r\n\r\n /**\r\n * 获取所有数据记录\r\n * 使用 cursor 分页机制循环获取所有数据,直到没有更多数据或操作被取消\r\n * \r\n * @param {boolean} includeValue - 是否包含分块文件的 value 数据\r\n * @returns {Promise} 所有记录的数组\r\n * @throws {BatchOperationError} 当发生错误时抛出\r\n */\r\n async fetchAllRecords(includeValue = false) {\r\n // 创建新的 AbortController 用于取消操作\r\n this.abortController = new AbortController();\r\n const allRecords = [];\r\n let cursor = null;\r\n let totalFetched = 0;\r\n let batchCount = 0;\r\n\r\n try {\r\n do {\r\n // 检查是否已取消\r\n if (this.abortController.signal.aborted) {\r\n break;\r\n }\r\n\r\n // 获取一批数据\r\n const response = await this.fetchBatch(cursor, includeValue);\r\n \r\n // 合并数据到总数组\r\n allRecords.push(...response.records);\r\n cursor = response.nextCursor;\r\n totalFetched += response.records.length;\r\n batchCount++;\r\n\r\n // 调用进度回调\r\n this.onProgress({\r\n phase: 'fetching',\r\n current: totalFetched,\r\n batchCount: batchCount,\r\n message: `已获取 ${totalFetched} 条记录...`\r\n });\r\n\r\n } while (cursor && !this.abortController.signal.aborted);\r\n\r\n // 如果是因为取消而退出循环,抛出取消错误\r\n if (this.abortController.signal.aborted) {\r\n throw ERROR_HANDLERS.ABORT();\r\n }\r\n\r\n return allRecords;\r\n } catch (error) {\r\n // 调用错误回调\r\n const batchError = error instanceof BatchOperationError \r\n ? error \r\n : createError(error);\r\n this.onError(batchError);\r\n throw batchError;\r\n }\r\n }\r\n\r\n /**\r\n * 获取单批数据\r\n * \r\n * @param {string|null} cursor - 分页游标,首次请求为 null\r\n * @param {boolean} includeValue - 是否包含分块文件的 value 数据\r\n * @returns {Promise} 包含 records 和 nextCursor 的响应对象\r\n * @throws {BatchOperationError} 当请求失败时抛出\r\n */\r\n async fetchBatch(cursor, includeValue) {\r\n // 构建查询参数\r\n const params = new URLSearchParams();\r\n if (cursor) {\r\n params.set('cursor', cursor);\r\n }\r\n if (includeValue) {\r\n params.set('includeValue', 'true');\r\n }\r\n params.set('limit', String(this.batchSize));\r\n\r\n try {\r\n // 发送请求,传入 abort signal 支持取消\r\n const response = await fetchWithAuth(\r\n `/api/manage/batch/list?${params}`,\r\n { signal: this.abortController.signal }\r\n );\r\n\r\n // 检查响应状态\r\n if (!response.ok) {\r\n let errorDetails = '';\r\n try {\r\n const errorData = await response.json();\r\n errorDetails = errorData.error || '';\r\n } catch {\r\n // 忽略 JSON 解析错误\r\n }\r\n throw createError(response, errorDetails);\r\n }\r\n\r\n // 解析响应数据\r\n const data = await response.json();\r\n \r\n // 验证响应格式\r\n if (!data.success) {\r\n throw new BatchOperationError(\r\n data.error || '请求失败',\r\n 'API_ERROR',\r\n true,\r\n '请稍后重试'\r\n );\r\n }\r\n\r\n return {\r\n records: data.records || [],\r\n nextCursor: data.nextCursor || null,\r\n totalProcessed: data.totalProcessed || 0\r\n };\r\n } catch (error) {\r\n // 如果已经是 BatchOperationError,直接抛出\r\n if (error instanceof BatchOperationError) {\r\n throw error;\r\n }\r\n // 否则转换为 BatchOperationError\r\n throw createError(error);\r\n }\r\n }\r\n\r\n /**\r\n * 取消当前操作\r\n * 调用此方法将中止正在进行的 fetch 请求\r\n */\r\n abort() {\r\n if (this.abortController) {\r\n this.abortController.abort();\r\n }\r\n }\r\n\r\n /**\r\n * 检查操作是否已被取消\r\n * @returns {boolean}\r\n */\r\n isAborted() {\r\n return this.abortController ? this.abortController.signal.aborted : false;\r\n }\r\n\r\n /**\r\n * 重置处理器状态\r\n * 在开始新的批量操作前调用\r\n */\r\n reset() {\r\n this.abortController = null;\r\n }\r\n}\r\n\r\nexport default BatchProcessor;\r\n","/**\r\n * IndexRebuilder - 索引重建类\r\n * \r\n * 处理索引重建的完整流程,包括数据获取、排序、分块上传和完成。\r\n */\r\n\r\nimport fetchWithAuth from '@/utils/fetchWithAuth';\r\nimport BatchProcessor, { BatchOperationError } from '@/utils/batchProcessor';\r\n\r\n/**\r\n * IndexRebuilder 类\r\n * \r\n * 用于重建索引的核心类,协调数据获取、排序和分块上传\r\n */\r\nclass IndexRebuilder {\r\n /**\r\n * 创建 IndexRebuilder 实例\r\n * @param {Object} options - 配置选项\r\n * @param {number} options.chunkSize - 每个分块的记录数,默认从后端获取\r\n * @param {number} options.maxRetries - 分块上传最大重试次数,默认 3\r\n * @param {number} options.retryDelay - 重试延迟基数(毫秒),默认 1000\r\n * @param {Function} options.onProgress - 进度回调函数\r\n * @param {Function} options.onError - 错误回调函数\r\n */\r\n constructor(options = {}) {\r\n this.chunkSize = options.chunkSize || null; // 从后端获取\r\n this.maxRetries = options.maxRetries || 3;\r\n this.retryDelay = options.retryDelay || 1000;\r\n this.onProgress = options.onProgress || (() => {});\r\n this.onError = options.onError || (() => {});\r\n this.sessionId = this.generateSessionId();\r\n this.aborted = false;\r\n }\r\n\r\n /**\r\n * 从后端获取索引配置(分块大小等)\r\n * @returns {Promise} 配置对象 { chunkSize, databaseType }\r\n */\r\n async fetchConfig() {\r\n try {\r\n const response = await fetchWithAuth('/api/manage/batch/index/config');\r\n if (!response.ok) {\r\n throw new Error('获取配置失败');\r\n }\r\n const result = await response.json();\r\n if (result.success) {\r\n return {\r\n chunkSize: result.chunkSize || 500,\r\n databaseType: result.databaseType || 'unknown'\r\n };\r\n }\r\n throw new Error(result.error || '获取配置失败');\r\n } catch (error) {\r\n // 获取失败时使用保守的默认值(兼容 D1)\r\n console.warn('Failed to fetch index config, using default:', error);\r\n return { chunkSize: 500, databaseType: 'unknown' };\r\n }\r\n }\r\n\r\n /**\r\n * 执行索引重建\r\n * \r\n * 完整流程:\r\n * 1. 获取配置(分块大小)\r\n * 2. 获取所有记录\r\n * 3. 按时间戳降序排序\r\n * 4. 分块上传\r\n * 5. 完成重建\r\n * \r\n * @returns {Promise} 重建结果 { success: boolean, totalFiles: number }\r\n * @throws {BatchOperationError} 当发生错误时抛出\r\n */\r\n async rebuild() {\r\n this.aborted = false;\r\n \r\n try {\r\n // 获取配置(分块大小)\r\n if (!this.chunkSize) {\r\n const config = await this.fetchConfig();\r\n this.chunkSize = config.chunkSize;\r\n }\r\n\r\n // 获取所有记录\r\n this.onProgress({ \r\n phase: 'fetching', \r\n message: '正在获取数据...',\r\n current: 0\r\n });\r\n \r\n const processor = new BatchProcessor({\r\n onProgress: (p) => this.onProgress({ ...p, phase: 'fetching' }),\r\n onError: (e) => this.onError(e)\r\n });\r\n \r\n const records = await processor.fetchAllRecords(false);\r\n \r\n if (this.aborted) {\r\n throw new BatchOperationError('操作已取消', 'ABORTED', false, '');\r\n }\r\n\r\n // 排序(按时间戳降序)\r\n this.onProgress({ \r\n phase: 'sorting', \r\n message: '正在排序...',\r\n current: 0,\r\n total: records.length\r\n });\r\n \r\n this.sortByTimestampDescending(records);\r\n \r\n if (this.aborted) {\r\n throw new BatchOperationError('操作已取消', 'ABORTED', false, '');\r\n }\r\n\r\n // 分块上传\r\n const chunks = this.splitIntoChunks(records);\r\n \r\n for (let i = 0; i < chunks.length; i++) {\r\n if (this.aborted) {\r\n throw new BatchOperationError('操作已取消', 'ABORTED', false, '');\r\n }\r\n \r\n // 使用重试机制上传分块\r\n await this.uploadChunkWithRetry(chunks[i], i);\r\n \r\n this.onProgress({\r\n phase: 'uploading',\r\n current: i + 1,\r\n total: chunks.length,\r\n message: `正在上传分块 ${i + 1}/${chunks.length}...`\r\n });\r\n }\r\n\r\n // 完成重建\r\n this.onProgress({ \r\n phase: 'finalizing', \r\n message: '正在完成重建...',\r\n current: chunks.length,\r\n total: chunks.length\r\n });\r\n \r\n await this.finalize(chunks.length, records.length);\r\n\r\n this.onProgress({\r\n phase: 'completed',\r\n message: `索引重建完成,共 ${records.length} 个文件`,\r\n current: records.length,\r\n total: records.length\r\n });\r\n\r\n return { success: true, totalFiles: records.length };\r\n } catch (error) {\r\n const batchError = error instanceof BatchOperationError \r\n ? error \r\n : new BatchOperationError(\r\n error.message || '索引重建失败',\r\n 'REBUILD_ERROR',\r\n true,\r\n '请稍后重试'\r\n );\r\n this.onError(batchError);\r\n throw batchError;\r\n }\r\n }\r\n\r\n /**\r\n * 按时间戳降序排序记录\r\n * \r\n * @param {Array} records - 要排序的记录数组(原地排序)\r\n */\r\n sortByTimestampDescending(records) {\r\n records.sort((a, b) => {\r\n const timestampA = (a.metadata && a.metadata.TimeStamp) || 0;\r\n const timestampB = (b.metadata && b.metadata.TimeStamp) || 0;\r\n return timestampB - timestampA;\r\n });\r\n }\r\n\r\n /**\r\n * 将记录分割为多个块\r\n * \r\n * @param {Array} records - 要分割的记录数组\r\n * @returns {Array} 分块后的二维数组\r\n */\r\n splitIntoChunks(records) {\r\n const chunks = [];\r\n for (let i = 0; i < records.length; i += this.chunkSize) {\r\n chunks.push(records.slice(i, i + this.chunkSize));\r\n }\r\n return chunks;\r\n }\r\n\r\n /**\r\n * 带重试机制的分块上传\r\n * \r\n * @param {Array} chunk - 要上传的分块数据\r\n * @param {number} chunkId - 分块 ID\r\n * @returns {Promise} 上传响应\r\n * @throws {BatchOperationError} 当所有重试都失败时抛出\r\n */\r\n async uploadChunkWithRetry(chunk, chunkId) {\r\n let lastError;\r\n \r\n for (let attempt = 1; attempt <= this.maxRetries; attempt++) {\r\n try {\r\n return await this.uploadChunk(chunk, chunkId);\r\n } catch (error) {\r\n lastError = error;\r\n \r\n // 不重试的错误类型\r\n if (error instanceof BatchOperationError) {\r\n if (error.code === 'AUTH_FAILED' || \r\n error.code === 'FORBIDDEN' || \r\n error.code === 'ABORTED') {\r\n throw error;\r\n }\r\n }\r\n \r\n // 如果还有重试机会,等待后重试\r\n if (attempt < this.maxRetries) {\r\n // 指数退避\r\n const delay = this.retryDelay * Math.pow(2, attempt - 1);\r\n await this.sleep(delay);\r\n \r\n this.onProgress({\r\n phase: 'retrying',\r\n message: `分块 ${chunkId + 1} 上传失败,正在重试 (${attempt}/${this.maxRetries})...`,\r\n current: chunkId,\r\n attempt: attempt\r\n });\r\n }\r\n }\r\n }\r\n \r\n // 所有重试都失败\r\n throw lastError instanceof BatchOperationError \r\n ? lastError \r\n : new BatchOperationError(\r\n `分块 ${chunkId + 1} 上传失败,已重试 ${this.maxRetries} 次`,\r\n 'CHUNK_UPLOAD_FAILED',\r\n false,\r\n '请检查网络连接后重新开始重建'\r\n );\r\n }\r\n\r\n /**\r\n * 上传单个分块\r\n * \r\n * @param {Array} chunk - 要上传的分块数据\r\n * @param {number} chunkId - 分块 ID\r\n * @returns {Promise} 上传响应\r\n * @throws {BatchOperationError} 当上传失败时抛出\r\n */\r\n async uploadChunk(chunk, chunkId) {\r\n const checksum = await this.calculateChecksum(chunk);\r\n \r\n try {\r\n const response = await fetchWithAuth('/api/manage/batch/index/chunk', {\r\n method: 'POST',\r\n headers: { 'Content-Type': 'application/json' },\r\n body: JSON.stringify({\r\n chunkId: String(chunkId),\r\n sessionId: this.sessionId,\r\n data: chunk,\r\n checksum\r\n })\r\n });\r\n\r\n if (!response.ok) {\r\n let errorDetails = '';\r\n try {\r\n const errorData = await response.json();\r\n errorDetails = errorData.error || '';\r\n } catch {\r\n // 忽略 JSON 解析错误\r\n }\r\n throw this.createHttpError(response.status, errorDetails);\r\n }\r\n\r\n const result = await response.json();\r\n \r\n if (!result.success) {\r\n throw new BatchOperationError(\r\n result.error || '分块上传失败',\r\n 'CHUNK_UPLOAD_FAILED',\r\n true,\r\n '请稍后重试'\r\n );\r\n }\r\n\r\n return result;\r\n } catch (error) {\r\n if (error instanceof BatchOperationError) {\r\n throw error;\r\n }\r\n // 网络错误\r\n if (error instanceof TypeError && error.message.includes('fetch')) {\r\n throw new BatchOperationError(\r\n '网络连接失败',\r\n 'NETWORK_ERROR',\r\n true,\r\n '请检查网络连接后重试'\r\n );\r\n }\r\n throw new BatchOperationError(\r\n error.message || '分块上传失败',\r\n 'CHUNK_UPLOAD_FAILED',\r\n true,\r\n '请稍后重试'\r\n );\r\n }\r\n }\r\n\r\n /**\r\n * 完成索引重建\r\n * \r\n * @param {number} totalChunks - 总分块数\r\n * @param {number} totalFiles - 总文件数\r\n * @returns {Promise} 完成响应\r\n * @throws {BatchOperationError} 当完成请求失败时抛出\r\n */\r\n async finalize(totalChunks, totalFiles) {\r\n try {\r\n const response = await fetchWithAuth('/api/manage/batch/index/finalize', {\r\n method: 'POST',\r\n headers: { 'Content-Type': 'application/json' },\r\n body: JSON.stringify({\r\n sessionId: this.sessionId,\r\n totalChunks,\r\n totalFiles\r\n })\r\n });\r\n\r\n if (!response.ok) {\r\n let errorDetails = '';\r\n try {\r\n const errorData = await response.json();\r\n errorDetails = errorData.error || '';\r\n } catch {\r\n // 忽略 JSON 解析错误\r\n }\r\n throw this.createHttpError(response.status, errorDetails);\r\n }\r\n\r\n const result = await response.json();\r\n \r\n if (!result.success) {\r\n throw new BatchOperationError(\r\n result.error || '索引完成失败',\r\n 'FINALIZE_FAILED',\r\n true,\r\n '请稍后重试'\r\n );\r\n }\r\n\r\n return result;\r\n } catch (error) {\r\n if (error instanceof BatchOperationError) {\r\n throw error;\r\n }\r\n throw new BatchOperationError(\r\n error.message || '索引完成失败',\r\n 'FINALIZE_FAILED',\r\n true,\r\n '请稍后重试'\r\n );\r\n }\r\n }\r\n\r\n /**\r\n * 生成唯一的会话 ID\r\n * \r\n * @returns {string} 会话 ID\r\n */\r\n generateSessionId() {\r\n return `rebuild_${Date.now()}_${Math.random().toString(36).slice(2)}`;\r\n }\r\n\r\n /**\r\n * 计算数据的 SHA-256 校验和\r\n * \r\n * @param {Array} data - 要计算校验和的数据\r\n * @returns {Promise} 十六进制格式的校验和\r\n */\r\n async calculateChecksum(data) {\r\n const text = JSON.stringify(data);\r\n const encoder = new TextEncoder();\r\n const dataBuffer = encoder.encode(text);\r\n const hashBuffer = await crypto.subtle.digest('SHA-256', dataBuffer);\r\n const hashArray = Array.from(new Uint8Array(hashBuffer));\r\n return hashArray.map(b => b.toString(16).padStart(2, '0')).join('');\r\n }\r\n\r\n /**\r\n * 根据 HTTP 状态码创建错误对象\r\n * \r\n * @param {number} status - HTTP 状态码\r\n * @param {string} details - 错误详情\r\n * @returns {BatchOperationError}\r\n */\r\n createHttpError(status, details = '') {\r\n switch (status) {\r\n case 401:\r\n return new BatchOperationError(\r\n '认证失败,请重新登录',\r\n 'AUTH_FAILED',\r\n false,\r\n '请刷新页面并重新登录'\r\n );\r\n case 403:\r\n return new BatchOperationError(\r\n '权限不足或请求被拒绝',\r\n 'FORBIDDEN',\r\n false,\r\n '请确认您有管理员权限'\r\n );\r\n case 400:\r\n return new BatchOperationError(\r\n `请求数据无效: ${details}`,\r\n 'INVALID_DATA',\r\n true,\r\n '请检查数据格式后重试'\r\n );\r\n case 404:\r\n return new BatchOperationError(\r\n '会话不存在',\r\n 'SESSION_NOT_FOUND',\r\n false,\r\n '请重新开始索引重建'\r\n );\r\n case 410:\r\n return new BatchOperationError(\r\n '会话已过期',\r\n 'SESSION_EXPIRED',\r\n false,\r\n '请重新开始索引重建'\r\n );\r\n case 500:\r\n default:\r\n return new BatchOperationError(\r\n `服务器错误: ${details || status}`,\r\n 'SERVER_ERROR',\r\n true,\r\n '请稍后重试'\r\n );\r\n }\r\n }\r\n\r\n /**\r\n * 延迟执行\r\n * \r\n * @param {number} ms - 延迟毫秒数\r\n * @returns {Promise}\r\n */\r\n sleep(ms) {\r\n return new Promise(resolve => setTimeout(resolve, ms));\r\n }\r\n\r\n /**\r\n * 取消当前操作\r\n */\r\n abort() {\r\n this.aborted = true;\r\n }\r\n\r\n /**\r\n * 重置重建器状态\r\n * 在开始新的重建操作前调用\r\n */\r\n reset() {\r\n this.aborted = false;\r\n this.sessionId = this.generateSessionId();\r\n }\r\n}\r\n\r\nexport default IndexRebuilder;\r\n","/**\r\n * BackupGenerator - 备份数据生成类\r\n * \r\n * 处理前端辅助备份功能,获取所有文件记录(包含分块文件的 value),\r\n * 构建完整的备份 JSON 文件,并触发浏览器下载。\r\n */\r\n\r\nimport BatchProcessor from '@/utils/batchProcessor';\r\nimport fetchWithAuth from '@/utils/fetchWithAuth';\r\nimport packageInfo from '../../package.json'\r\n\r\n/**\r\n * BackupGenerator 类\r\n * \r\n * 用于生成和下载备份数据的类\r\n */\r\nclass BackupGenerator {\r\n /**\r\n * 创建 BackupGenerator 实例\r\n * @param {Object} options - 配置选项\r\n * @param {Function} options.onProgress - 进度回调函数\r\n */\r\n constructor(options = {}) {\r\n this.onProgress = options.onProgress || (() => {});\r\n this.processor = null;\r\n }\r\n\r\n /**\r\n * 生成并下载备份\r\n * \r\n * 完整流程:\r\n * 1. 获取所有文件记录(包含分块文件的 value)\r\n * 2. 构建备份数据结构\r\n * 3. 获取系统设置\r\n * 4. 生成并触发下载\r\n * \r\n * @returns {Promise} 包含 success 和 fileCount 的结果对象\r\n * @throws {Error} 当备份过程中发生错误时抛出\r\n */\r\n async generateBackup() {\r\n // 获取所有文件记录(包含分块文件的 value)\r\n this.processor = new BatchProcessor({\r\n onProgress: (p) => this.onProgress({ ...p, phase: 'fetching' })\r\n });\r\n\r\n const records = await this.processor.fetchAllRecords(true);\r\n\r\n // 构建备份数据\r\n this.onProgress({ phase: 'building', message: '正在构建备份数据...' });\r\n\r\n const backupData = {\r\n timestamp: Date.now(),\r\n version: packageInfo.version,\r\n data: {\r\n fileCount: records.length,\r\n files: {},\r\n settings: {}\r\n }\r\n };\r\n\r\n // 将记录转换为以 id 为键的对象格式\r\n for (const record of records) {\r\n backupData.data.files[record.id] = {\r\n metadata: record.metadata,\r\n value: record.value || null\r\n };\r\n }\r\n\r\n // 3. 获取系统设置\r\n const settings = await this.fetchSettings();\r\n backupData.data.settings = settings;\r\n\r\n // 生成下载\r\n this.onProgress({ phase: 'downloading', message: '正在生成下载...' });\r\n this.downloadBackup(backupData);\r\n\r\n const settingsCount = Object.keys(settings).length;\r\n return { success: true, fileCount: records.length, settingsCount };\r\n }\r\n\r\n /**\r\n * 获取系统设置\r\n * \r\n * @returns {Promise} 系统设置对象,失败时返回空对象\r\n */\r\n async fetchSettings() {\r\n try {\r\n const response = await fetchWithAuth('/api/manage/batch/settings');\r\n if (!response.ok) {\r\n console.warn('Failed to fetch settings:', response.status);\r\n return {};\r\n }\r\n const data = await response.json();\r\n // 返回 settings 字段,而不是整个响应\r\n return data.settings || {};\r\n } catch (error) {\r\n console.warn('Failed to fetch settings:', error);\r\n return {};\r\n }\r\n }\r\n\r\n /**\r\n * 触发浏览器下载备份文件\r\n * \r\n * @param {Object} data - 备份数据对象\r\n */\r\n downloadBackup(data) {\r\n // 将数据转换为格式化的 JSON 字符串\r\n const json = JSON.stringify(data, null, 2);\r\n \r\n // 创建 Blob 对象\r\n const blob = new Blob([json], { type: 'application/json' });\r\n \r\n // 创建下载 URL\r\n const url = URL.createObjectURL(blob);\r\n\r\n // 创建临时下载链接\r\n const a = document.createElement('a');\r\n a.href = url;\r\n // 使用日期作为文件名的一部分\r\n a.download = `imgbed_backup_${new Date().toISOString().split('T')[0]}.json`;\r\n \r\n // 触发下载\r\n document.body.appendChild(a);\r\n a.click();\r\n \r\n // 清理\r\n document.body.removeChild(a);\r\n URL.revokeObjectURL(url);\r\n }\r\n\r\n /**\r\n * 取消当前备份操作\r\n */\r\n abort() {\r\n if (this.processor) {\r\n this.processor.abort();\r\n }\r\n }\r\n\r\n /**\r\n * 检查操作是否已被取消\r\n * @returns {boolean}\r\n */\r\n isAborted() {\r\n return this.processor ? this.processor.isAborted() : false;\r\n }\r\n}\r\n\r\nexport default BackupGenerator;\r\n","/**\r\n * RestoreProcessor - 分批恢复数据类\r\n * \r\n * 将备份数据分批上传到后端进行恢复,避免 CPU 超时\r\n */\r\n\r\nimport fetchWithAuth from '@/utils/fetchWithAuth';\r\nimport { BatchOperationError } from '@/utils/batchProcessor';\r\n\r\n/**\r\n * RestoreProcessor 类\r\n */\r\nclass RestoreProcessor {\r\n /**\r\n * 创建 RestoreProcessor 实例\r\n * @param {Object} options - 配置选项\r\n * @param {number} options.chunkSize - 每批数据量,默认 50\r\n * @param {number} options.maxRetries - 最大重试次数,默认 3\r\n * @param {number} options.retryDelay - 重试延迟基数(毫秒),默认 1000\r\n * @param {Function} options.onProgress - 进度回调函数\r\n * @param {Function} options.onError - 错误回调函数\r\n */\r\n constructor(options = {}) {\r\n this.chunkSize = options.chunkSize || 50;\r\n this.maxRetries = options.maxRetries || 3;\r\n this.retryDelay = options.retryDelay || 1000;\r\n this.onProgress = options.onProgress || (() => {});\r\n this.onError = options.onError || (() => {});\r\n this.aborted = false;\r\n }\r\n\r\n /**\r\n * 执行恢复操作\r\n * \r\n * @param {Object} backupData - 备份数据对象\r\n * @returns {Promise} 恢复结果\r\n */\r\n async restore(backupData) {\r\n this.aborted = false;\r\n\r\n // 验证备份数据格式\r\n if (!backupData || !backupData.data) {\r\n throw new BatchOperationError(\r\n '备份文件格式无效',\r\n 'INVALID_BACKUP',\r\n false,\r\n '请选择有效的备份文件'\r\n );\r\n }\r\n\r\n const { files = {}, settings = {} } = backupData.data;\r\n const fileEntries = Object.entries(files);\r\n const settingEntries = Object.entries(settings);\r\n \r\n const totalFiles = fileEntries.length;\r\n const totalSettings = settingEntries.length;\r\n const totalItems = totalFiles + totalSettings;\r\n\r\n let restoredFiles = 0;\r\n let restoredSettings = 0;\r\n let failedFiles = 0;\r\n let failedSettings = 0;\r\n\r\n try {\r\n // 1. 分批恢复文件数据\r\n this.onProgress({\r\n phase: 'restoring_files',\r\n message: '正在恢复文件数据...',\r\n current: 0,\r\n total: totalItems\r\n });\r\n\r\n const fileChunks = this.splitIntoChunks(fileEntries, this.chunkSize);\r\n \r\n for (let i = 0; i < fileChunks.length; i++) {\r\n if (this.aborted) {\r\n throw new BatchOperationError('操作已取消', 'ABORTED', false, '');\r\n }\r\n\r\n const chunk = fileChunks[i];\r\n const chunkData = Object.fromEntries(chunk);\r\n \r\n const result = await this.uploadChunkWithRetry('files', chunkData);\r\n restoredFiles += result.restoredCount;\r\n failedFiles += result.failedCount;\r\n\r\n this.onProgress({\r\n phase: 'restoring_files',\r\n message: `正在恢复文件数据 ${restoredFiles}/${totalFiles}...`,\r\n current: restoredFiles,\r\n total: totalItems,\r\n percentage: (restoredFiles / totalItems) * 80\r\n });\r\n }\r\n\r\n // 2. 分批恢复系统设置\r\n this.onProgress({\r\n phase: 'restoring_settings',\r\n message: '正在恢复系统设置...',\r\n current: restoredFiles,\r\n total: totalItems\r\n });\r\n\r\n const settingChunks = this.splitIntoChunks(settingEntries, this.chunkSize);\r\n \r\n for (let i = 0; i < settingChunks.length; i++) {\r\n if (this.aborted) {\r\n throw new BatchOperationError('操作已取消', 'ABORTED', false, '');\r\n }\r\n\r\n const chunk = settingChunks[i];\r\n const chunkData = Object.fromEntries(chunk);\r\n \r\n const result = await this.uploadChunkWithRetry('settings', chunkData);\r\n restoredSettings += result.restoredCount;\r\n failedSettings += result.failedCount;\r\n\r\n this.onProgress({\r\n phase: 'restoring_settings',\r\n message: `正在恢复系统设置 ${restoredSettings}/${totalSettings}...`,\r\n current: restoredFiles + restoredSettings,\r\n total: totalItems,\r\n percentage: 80 + (restoredSettings / totalSettings) * 20\r\n });\r\n }\r\n\r\n // 3. 完成\r\n this.onProgress({\r\n phase: 'completed',\r\n message: '恢复完成',\r\n current: totalItems,\r\n total: totalItems,\r\n percentage: 100\r\n });\r\n\r\n return {\r\n success: true,\r\n restoredFiles,\r\n restoredSettings,\r\n failedFiles,\r\n failedSettings,\r\n backupTimestamp: backupData.timestamp\r\n };\r\n\r\n } catch (error) {\r\n const batchError = error instanceof BatchOperationError\r\n ? error\r\n : new BatchOperationError(\r\n error.message || '恢复失败',\r\n 'RESTORE_ERROR',\r\n true,\r\n '请稍后重试'\r\n );\r\n this.onError(batchError);\r\n throw batchError;\r\n }\r\n }\r\n\r\n /**\r\n * 将数组分割为多个块\r\n */\r\n splitIntoChunks(entries, chunkSize) {\r\n const chunks = [];\r\n for (let i = 0; i < entries.length; i += chunkSize) {\r\n chunks.push(entries.slice(i, i + chunkSize));\r\n }\r\n return chunks;\r\n }\r\n\r\n /**\r\n * 带重试机制的分块上传\r\n */\r\n async uploadChunkWithRetry(type, data) {\r\n let lastError;\r\n\r\n for (let attempt = 1; attempt <= this.maxRetries; attempt++) {\r\n try {\r\n return await this.uploadChunk(type, data);\r\n } catch (error) {\r\n lastError = error;\r\n\r\n if (error instanceof BatchOperationError) {\r\n if (error.code === 'AUTH_FAILED' ||\r\n error.code === 'FORBIDDEN' ||\r\n error.code === 'ABORTED') {\r\n throw error;\r\n }\r\n }\r\n\r\n if (attempt < this.maxRetries) {\r\n const delay = this.retryDelay * Math.pow(2, attempt - 1);\r\n await this.sleep(delay);\r\n }\r\n }\r\n }\r\n\r\n throw lastError;\r\n }\r\n\r\n /**\r\n * 上传单个分块\r\n */\r\n async uploadChunk(type, data) {\r\n try {\r\n const response = await fetchWithAuth('/api/manage/batch/restore/chunk', {\r\n method: 'POST',\r\n headers: { 'Content-Type': 'application/json' },\r\n body: JSON.stringify({ type, data })\r\n });\r\n\r\n if (!response.ok) {\r\n let errorDetails = '';\r\n try {\r\n const errorData = await response.json();\r\n errorDetails = errorData.error || '';\r\n } catch {\r\n // 忽略 JSON 解析错误\r\n }\r\n throw this.createHttpError(response.status, errorDetails);\r\n }\r\n\r\n const result = await response.json();\r\n\r\n if (!result.success) {\r\n throw new BatchOperationError(\r\n result.error || '恢复分块失败',\r\n 'CHUNK_RESTORE_FAILED',\r\n true,\r\n '请稍后重试'\r\n );\r\n }\r\n\r\n return result;\r\n } catch (error) {\r\n if (error instanceof BatchOperationError) {\r\n throw error;\r\n }\r\n if (error instanceof TypeError && error.message.includes('fetch')) {\r\n throw new BatchOperationError(\r\n '网络连接失败',\r\n 'NETWORK_ERROR',\r\n true,\r\n '请检查网络连接后重试'\r\n );\r\n }\r\n throw new BatchOperationError(\r\n error.message || '恢复分块失败',\r\n 'CHUNK_RESTORE_FAILED',\r\n true,\r\n '请稍后重试'\r\n );\r\n }\r\n }\r\n\r\n /**\r\n * 根据 HTTP 状态码创建错误对象\r\n */\r\n createHttpError(status, details = '') {\r\n switch (status) {\r\n case 401:\r\n return new BatchOperationError(\r\n '认证失败,请重新登录',\r\n 'AUTH_FAILED',\r\n false,\r\n '请刷新页面并重新登录'\r\n );\r\n case 403:\r\n return new BatchOperationError(\r\n '权限不足或请求被拒绝',\r\n 'FORBIDDEN',\r\n false,\r\n '请确认您有管理员权限'\r\n );\r\n case 400:\r\n return new BatchOperationError(\r\n `请求数据无效: ${details}`,\r\n 'INVALID_DATA',\r\n true,\r\n '请检查备份文件格式'\r\n );\r\n case 500:\r\n default:\r\n return new BatchOperationError(\r\n `服务器错误: ${details || status}`,\r\n 'SERVER_ERROR',\r\n true,\r\n '请稍后重试'\r\n );\r\n }\r\n }\r\n\r\n /**\r\n * 延迟执行\r\n */\r\n sleep(ms) {\r\n return new Promise(resolve => setTimeout(resolve, ms));\r\n }\r\n\r\n /**\r\n * 取消当前操作\r\n */\r\n abort() {\r\n this.aborted = true;\r\n }\r\n}\r\n\r\nexport default RestoreProcessor;\r\n","import \"core-js/modules/es.iterator.constructor.js\";\nimport \"core-js/modules/es.iterator.reduce.js\";\nimport \"core-js/modules/esnext.json.parse.js\";\nimport fetchWithAuth from '@/utils/fetchWithAuth';\nimport packageInfo from '../../package.json';\nimport { Doughnut } from 'vue-chartjs';\nimport { Chart as ChartJS, ArcElement, Tooltip, Legend } from 'chart.js';\nimport IndexRebuilder from '@/utils/indexRebuilder';\nimport BackupGenerator from '@/utils/backupGenerator';\nimport RestoreProcessor from '@/utils/restoreProcessor';\nChartJS.register(ArcElement, Tooltip, Legend);\nexport default {\n name: 'SysCogStatus',\n components: {\n Doughnut\n },\n data() {\n return {\n loading: false,\n rebuilding: false,\n backing: false,\n restoring: false,\n indexInfo: {},\n version: packageInfo.version,\n // 从package.json获取版本号\n loadErrors: {\n newest: false,\n oldest: false\n },\n // 渠道图表颜色\n channelColors: ['#8B5CF6', '#EC4899', '#06B6D4', '#10B981', '#F59E0B', '#EF4444', '#6366F1', '#84CC16'],\n // 状态图表颜色\n typeColors: ['#10B981', '#3B82F6', '#F59E0B', '#EF4444', '#8B5CF6', '#EC4899', '#06B6D4', '#84CC16'],\n // 批量操作进度状态\n isProcessing: false,\n processingPhase: '',\n // fetching, sorting, uploading, finalizing, building, downloading, completed\n processingProgress: {\n current: 0,\n total: 0,\n message: '',\n percentage: 0\n },\n processingError: null,\n processingStartTime: null,\n // 当前处理器实例(用于取消操作)\n currentRebuilder: null,\n currentBackupGenerator: null,\n currentRestoreProcessor: null\n };\n },\n computed: {\n // 渠道分布图表数据\n channelChartData() {\n const stats = this.indexInfo.channelStats || {};\n return {\n labels: Object.keys(stats),\n datasets: [{\n data: Object.values(stats),\n backgroundColor: this.channelColors.slice(0, Object.keys(stats).length),\n borderWidth: 0\n }]\n };\n },\n // 文件状态图表数据 - 将Block映射为\"已屏蔽\",其余为\"正常\"\n typeChartData() {\n const aggregatedStats = this.aggregatedTypeStats;\n return {\n labels: Object.keys(aggregatedStats),\n datasets: [{\n data: Object.values(aggregatedStats),\n backgroundColor: this.typeColors.slice(0, Object.keys(aggregatedStats).length),\n borderWidth: 0\n }]\n };\n },\n // 聚合后的状态统计:Block -> 已屏蔽,其余 -> 正常\n aggregatedTypeStats() {\n const stats = this.indexInfo.typeStats || {};\n const aggregatedStats = {};\n for (const [status, count] of Object.entries(stats)) {\n const mappedStatus = status === 'Block' ? '已屏蔽' : '正常';\n aggregatedStats[mappedStatus] = (aggregatedStats[mappedStatus] || 0) + count;\n }\n return aggregatedStats;\n },\n // 图表配置\n chartOptions() {\n return {\n responsive: true,\n maintainAspectRatio: true,\n cutout: '65%',\n hoverOffset: 8,\n layout: {\n padding: 10\n },\n plugins: {\n legend: {\n display: false\n },\n tooltip: {\n backgroundColor: 'rgba(0, 0, 0, 0.8)',\n titleColor: '#fff',\n bodyColor: '#fff',\n padding: 12,\n cornerRadius: 8,\n displayColors: true,\n z: 100,\n callbacks: {\n label: context => {\n const value = context.raw;\n const total = context.dataset.data.reduce((a, b) => a + b, 0);\n const percentage = (value / total * 100).toFixed(1);\n return ` ${value.toLocaleString()} (${percentage}%)`;\n }\n }\n }\n },\n animation: {\n animateRotate: true,\n animateScale: true\n }\n };\n },\n // 预计剩余时间(Requirements 9.2)\n estimatedTimeRemaining() {\n if (!this.isProcessing || !this.processingStartTime) return '';\n if (this.processingProgress.current === 0 || this.processingProgress.percentage === 0) return '';\n const elapsed = Date.now() - this.processingStartTime;\n const progress = this.processingProgress.percentage / 100;\n if (progress <= 0) return '';\n const totalEstimated = elapsed / progress;\n const remaining = totalEstimated - elapsed;\n if (remaining <= 0) return '即将完成';\n const seconds = Math.ceil(remaining / 1000);\n if (seconds < 60) return `约 ${seconds} 秒`;\n const minutes = Math.ceil(seconds / 60);\n if (minutes < 60) return `约 ${minutes} 分钟`;\n const hours = Math.floor(minutes / 60);\n const remainingMinutes = minutes % 60;\n return `约 ${hours} 小时 ${remainingMinutes} 分钟`;\n },\n // 处理阶段描述\n phaseDescription() {\n const phaseMap = {\n 'fetching': '正在获取数据',\n 'sorting': '正在排序',\n 'uploading': '正在上传',\n 'finalizing': '正在完成',\n 'building': '正在构建备份',\n 'downloading': '正在生成下载',\n 'restoring_files': '正在恢复文件',\n 'restoring_settings': '正在恢复设置',\n 'completed': '已完成',\n 'retrying': '正在重试'\n };\n return phaseMap[this.processingPhase] || this.processingPhase;\n }\n },\n mounted() {\n this.fetchIndexInfo();\n },\n methods: {\n // 获取渠道图表颜色\n getChartColor(index) {\n return this.channelColors[index % this.channelColors.length];\n },\n // 获取状态图表颜色\n getTypeChartColor(index) {\n return this.typeColors[index % this.typeColors.length];\n },\n // 获取索引信息\n async fetchIndexInfo() {\n this.loading = true;\n try {\n const response = await fetchWithAuth('/api/manage/list?action=info', {\n method: 'GET'\n });\n if (response.ok) {\n const data = await response.json();\n this.indexInfo = data;\n } else {\n throw new Error('API请求失败');\n }\n } catch (error) {\n console.error('获取索引信息失败:', error);\n this.$message.error('获取索引信息失败');\n } finally {\n this.loading = false;\n }\n },\n // 重建索引 - 使用前端辅助重建流程 (Requirements 3.6, 9.1, 9.2, 9.3, 9.4)\n async rebuildIndex() {\n if (this.isProcessing) {\n this.$message.warning('已有操作正在进行中');\n return;\n }\n this.rebuilding = true;\n this.isProcessing = true;\n this.processingError = null;\n this.processingStartTime = Date.now();\n this.processingProgress = {\n current: 0,\n total: 0,\n message: '',\n percentage: 0\n };\n\n // 创建 IndexRebuilder 实例\n this.currentRebuilder = new IndexRebuilder({\n onProgress: progress => this.handleProgress(progress),\n onError: error => this.handleError(error)\n });\n try {\n const result = await this.currentRebuilder.rebuild();\n\n // 成功完成 (Requirement 9.4)\n this.$message.success(`索引重建完成!共处理 ${result.totalFiles.toLocaleString()} 个文件`);\n\n // 刷新索引信息\n setTimeout(() => {\n this.fetchIndexInfo();\n }, 1000);\n } catch (error) {\n // 错误处理 (Requirement 9.3)\n if (error.code !== 'ABORTED') {\n const errorMessage = error.suggestion ? `${error.message}。${error.suggestion}` : error.message;\n this.$message.error(errorMessage);\n this.processingError = {\n message: error.message,\n suggestion: error.suggestion,\n recoverable: error.recoverable\n };\n }\n } finally {\n this.rebuilding = false;\n this.isProcessing = false;\n this.currentRebuilder = null;\n this.processingStartTime = null;\n }\n },\n // 备份数据 - 使用前端辅助备份流程 (Requirements 4.6, 9.1, 9.2, 9.3, 9.4)\n async backupData() {\n if (this.isProcessing) {\n this.$message.warning('已有操作正在进行中');\n return;\n }\n this.backing = true;\n this.isProcessing = true;\n this.processingError = null;\n this.processingStartTime = Date.now();\n this.processingProgress = {\n current: 0,\n total: 0,\n message: '',\n percentage: 0\n };\n\n // 创建 BackupGenerator 实例\n this.currentBackupGenerator = new BackupGenerator({\n onProgress: progress => this.handleProgress(progress)\n });\n try {\n const result = await this.currentBackupGenerator.generateBackup();\n\n // 成功完成 (Requirement 9.4)\n const settingsMsg = result.settingsCount > 0 ? `,${result.settingsCount} 个设置项` : '';\n this.$message.success(`备份完成!共备份 ${result.fileCount.toLocaleString()} 个文件${settingsMsg}`);\n } catch (error) {\n // 错误处理 (Requirement 9.3)\n if (error.code !== 'ABORTED') {\n const errorMessage = error.suggestion ? `${error.message}。${error.suggestion}` : error.message;\n this.$message.error(errorMessage);\n this.processingError = {\n message: error.message,\n suggestion: error.suggestion,\n recoverable: error.recoverable\n };\n }\n } finally {\n this.backing = false;\n this.isProcessing = false;\n this.currentBackupGenerator = null;\n this.processingStartTime = null;\n }\n },\n // 选择恢复文件\n selectRestoreFile() {\n if (this.restoring) return;\n this.$refs.fileInput.click();\n },\n // 处理文件选择\n async handleFileSelect(event) {\n const file = event.target.files[0];\n if (!file) return;\n if (!file.name.endsWith('.json')) {\n this.$message.error('请选择JSON格式的备份文件');\n return;\n }\n\n // 确认恢复操作\n try {\n await this.$confirm('恢复操作将覆盖现有的文件元数据和系统设置,此操作不可逆。确定要继续吗?', '确认恢复', {\n confirmButtonText: '确定恢复',\n cancelButtonText: '取消',\n type: 'warning'\n });\n await this.restoreData(file);\n } catch (error) {\n if (error !== 'cancel') {\n console.error('确认恢复失败:', error);\n }\n }\n\n // 清除文件选择\n event.target.value = '';\n },\n // 恢复数据 - 使用前端辅助分批恢复流程\n async restoreData(file) {\n if (this.isProcessing) {\n this.$message.warning('已有操作正在进行中');\n return;\n }\n this.restoring = true;\n this.isProcessing = true;\n this.processingError = null;\n this.processingStartTime = Date.now();\n this.processingProgress = {\n current: 0,\n total: 0,\n message: '',\n percentage: 0\n };\n try {\n // 解析备份文件\n const fileContent = await file.text();\n let backupData;\n try {\n backupData = JSON.parse(fileContent);\n } catch (parseError) {\n throw new Error('备份文件格式无效,请选择有效的 JSON 文件');\n }\n\n // 创建 RestoreProcessor 实例\n this.currentRestoreProcessor = new RestoreProcessor({\n chunkSize: 100,\n // 每批恢复 100 条\n onProgress: progress => this.handleProgress(progress),\n onError: error => this.handleError(error)\n });\n const result = await this.currentRestoreProcessor.restore(backupData);\n\n // 恢复完成,重置恢复状态\n this.restoring = false;\n this.isProcessing = false;\n this.currentRestoreProcessor = null;\n this.processingStartTime = null;\n\n // 显示恢复成功消息\n this.$message.success(`恢复完成!已恢复 ${result.restoredFiles} 个文件和 ${result.restoredSettings} 个设置项,正在重建索引...`);\n\n // 短暂延迟后自动开始重建索引\n await new Promise(resolve => setTimeout(resolve, 500));\n await this.rebuildIndex();\n } catch (error) {\n console.error('恢复数据失败:', error);\n\n // 出错时重置状态\n this.restoring = false;\n this.isProcessing = false;\n this.currentRestoreProcessor = null;\n this.processingStartTime = null;\n if (error.code !== 'ABORTED') {\n const errorMessage = error.suggestion ? `${error.message}。${error.suggestion}` : error.message;\n this.$message.error('恢复数据失败: ' + errorMessage);\n this.processingError = {\n message: error.message,\n suggestion: error.suggestion,\n recoverable: error.recoverable\n };\n }\n }\n },\n // 格式化时间\n formatTime(timestamp) {\n if (!timestamp) return '未知';\n const date = new Date(timestamp);\n return date.toLocaleString('zh-CN', {\n year: 'numeric',\n month: '2-digit',\n day: '2-digit',\n hour: '2-digit',\n minute: '2-digit'\n });\n },\n // 计算百分比\n getPercentage(value, total) {\n if (!total || total === 0) return 0;\n return Math.round(value / total * 100);\n },\n // 计算时间差\n getTimeAgo(timestamp) {\n if (!timestamp) return '';\n const now = Date.now();\n const diff = now - timestamp;\n const minutes = Math.floor(diff / 60000);\n const hours = Math.floor(diff / 3600000);\n const days = Math.floor(diff / 86400000);\n if (days > 0) return `${days}天前`;\n if (hours > 0) return `${hours}小时前`;\n if (minutes > 0) return `${minutes}分钟前`;\n return '刚刚';\n },\n // 图片加载失败处理\n handleImageError(type) {\n this.loadErrors[type] = true;\n },\n // 检查是否应该显示预览图\n isValidPreview(type, file) {\n if (this.loadErrors[type]) return false;\n if (!file?.metadata?.FileType) return false;\n return file.metadata.FileType.includes('image') || file.metadata.FileType.includes('video');\n },\n // 打开发布页面\n openReleases() {\n window.open('https://github.com/MarSeventh/CloudFlare-ImgBed/releases', '_blank');\n },\n // 判断是否为图片文件\n isImageFile(file) {\n if (!file) return false;\n // 优先通过 FileType 判断\n if (file.metadata?.FileType?.includes('image')) return true;\n // 通过文件名后缀判断\n const fileName = file.metadata?.FileName || file.id || '';\n const extension = fileName.substring(fileName.lastIndexOf('.') + 1).toLowerCase();\n const imageExtensions = ['jpg', 'jpeg', 'png', 'gif', 'bmp', 'webp', 'svg', 'ico', 'tiff', 'tif', 'avif', 'heic', 'heif'];\n return imageExtensions.includes(extension);\n },\n // 判断是否为视频文件\n isVideoFile(file) {\n if (!file) return false;\n // 优先通过 FileType 判断\n if (file.metadata?.FileType?.includes('video')) return true;\n // 通过文件名后缀判断\n const fileName = file.metadata?.FileName || file.id || '';\n const extension = fileName.substring(fileName.lastIndexOf('.') + 1).toLowerCase();\n const videoExtensions = ['mp4', 'webm', 'ogg', 'avi', 'mov', 'flv', 'wmv', 'mkv', 'm4v', '3gp', 'mpeg', 'mpg'];\n return videoExtensions.includes(extension);\n },\n // 在新窗口打开文件\n openFileInNewTab(file) {\n if (!file?.id) return;\n window.open('/file/' + file.id, '_blank');\n },\n // 处理进度更新 (Requirements 3.6, 4.6, 9.1, 9.2)\n handleProgress(progress) {\n this.processingPhase = progress.phase;\n this.processingProgress.message = progress.message || '';\n this.processingProgress.current = progress.current || 0;\n\n // 根据不同阶段计算进度百分比\n if (progress.phase === 'fetching') {\n // 获取阶段:基于已获取的记录数估算(假设总数未知时显示已获取数量)\n this.processingProgress.total = progress.total || 0;\n // 获取阶段占总进度的 60%\n if (progress.total && progress.total > 0) {\n this.processingProgress.percentage = Math.min(60, progress.current / progress.total * 60);\n } else {\n // 未知总数时,使用对数增长模拟进度\n this.processingProgress.percentage = Math.min(50, Math.log10(progress.current + 1) * 15);\n }\n } else if (progress.phase === 'sorting') {\n // 排序阶段:占 60-70%\n this.processingProgress.percentage = 65;\n this.processingProgress.total = progress.total || this.processingProgress.total;\n } else if (progress.phase === 'uploading') {\n // 上传阶段:占 70-95%\n this.processingProgress.total = progress.total || 0;\n if (progress.total && progress.total > 0) {\n this.processingProgress.percentage = 70 + progress.current / progress.total * 25;\n }\n } else if (progress.phase === 'finalizing') {\n // 完成阶段:95-100%\n this.processingProgress.percentage = 97;\n } else if (progress.phase === 'building') {\n // 构建备份阶段:70-90%\n this.processingProgress.percentage = 80;\n } else if (progress.phase === 'downloading') {\n // 下载阶段:90-100%\n this.processingProgress.percentage = 95;\n } else if (progress.phase === 'restoring_files') {\n // 恢复文件阶段:0-80%\n this.processingProgress.total = progress.total || 0;\n this.processingProgress.percentage = progress.percentage || 0;\n } else if (progress.phase === 'restoring_settings') {\n // 恢复设置阶段:80-100%\n this.processingProgress.total = progress.total || 0;\n this.processingProgress.percentage = progress.percentage || 80;\n } else if (progress.phase === 'completed') {\n // 完成\n this.processingProgress.percentage = 100;\n } else if (progress.phase === 'retrying') {\n // 重试阶段:保持当前进度\n this.processingProgress.message = progress.message;\n }\n },\n // 处理错误 (Requirement 9.3)\n handleError(error) {\n console.error('批量操作错误:', error);\n this.processingError = {\n message: error.message,\n suggestion: error.suggestion,\n recoverable: error.recoverable\n };\n },\n // 取消当前操作 (Requirement 2.4)\n cancelOperation() {\n if (this.currentRebuilder) {\n this.currentRebuilder.abort();\n this.$message.info('正在取消索引重建...');\n }\n if (this.currentBackupGenerator) {\n this.currentBackupGenerator.abort();\n this.$message.info('正在取消备份...');\n }\n if (this.currentRestoreProcessor) {\n this.currentRestoreProcessor.abort();\n this.$message.info('正在取消恢复...');\n }\n },\n // 重试操作\n retryOperation() {\n this.processingError = null;\n if (this.rebuilding) {\n this.rebuilding = false;\n this.isProcessing = false;\n this.$nextTick(() => {\n this.rebuildIndex();\n });\n } else if (this.backing) {\n this.backing = false;\n this.isProcessing = false;\n this.$nextTick(() => {\n this.backupData();\n });\n }\n },\n // 关闭错误提示\n dismissError() {\n this.processingError = null;\n }\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./SysCogStatus.vue?vue&type=template&id=68ed43d0&scoped=true\"\nimport script from \"./SysCogStatus.vue?vue&type=script&lang=js\"\nexport * from \"./SysCogStatus.vue?vue&type=script&lang=js\"\n\nimport \"./SysCogStatus.vue?vue&type=style&index=0&id=68ed43d0&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-68ed43d0\"]])\n\nexport default __exports__","import { toDisplayString as _toDisplayString, normalizeClass as _normalizeClass, createElementVNode as _createElementVNode, resolveComponent as _resolveComponent, createVNode as _createVNode, renderList as _renderList, Fragment as _Fragment, openBlock as _openBlock, createElementBlock as _createElementBlock, renderSlot as _renderSlot, createBlock as _createBlock, createCommentVNode as _createCommentVNode, vShow as _vShow, withModifiers as _withModifiers, withDirectives as _withDirectives, Transition as _Transition, withCtx as _withCtx, normalizeStyle as _normalizeStyle } from \"vue\";\nconst _hoisted_1 = [\"onClick\"];\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n return _openBlock(), _createElementBlock(\"div\", {\n class: _normalizeClass([\"custom-select\", {\n 'is-open': $data.isOpen\n }]),\n style: _normalizeStyle({\n width: $props.width\n })\n }, [_createElementVNode(\"div\", {\n class: \"custom-select-trigger\",\n onClick: _cache[0] || (_cache[0] = (...args) => $options.toggleDropdown && $options.toggleDropdown(...args))\n }, [_createElementVNode(\"span\", {\n class: _normalizeClass([\"custom-select-value\", {\n 'is-placeholder': !$props.modelValue\n }])\n }, _toDisplayString($options.displayLabel), 3), _createVNode(_component_font_awesome_icon, {\n icon: \"chevron-down\",\n class: \"custom-select-arrow\"\n })]), _createVNode(_Transition, {\n name: \"dropdown-fade\"\n }, {\n default: _withCtx(() => [_withDirectives(_createElementVNode(\"div\", {\n class: \"custom-select-dropdown\",\n onClick: _cache[1] || (_cache[1] = _withModifiers(() => {}, [\"stop\"]))\n }, [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($props.options, option => {\n return _openBlock(), _createElementBlock(\"div\", {\n key: option.value,\n class: _normalizeClass([\"custom-select-option\", {\n 'is-selected': $props.modelValue === option.value\n }]),\n onClick: $event => $options.selectOption(option.value)\n }, [_renderSlot(_ctx.$slots, \"option\", {\n option: option\n }, () => [option.icon ? (_openBlock(), _createBlock(_component_font_awesome_icon, {\n key: 0,\n icon: option.icon,\n class: \"option-icon\"\n }, null, 8, [\"icon\"])) : _createCommentVNode(\"\", true), _createElementVNode(\"span\", null, _toDisplayString(option.label), 1)], true)], 10, _hoisted_1);\n }), 128))], 512), [[_vShow, $data.isOpen]])]),\n _: 3\n })], 6);\n}","import \"core-js/modules/es.iterator.constructor.js\";\nimport \"core-js/modules/es.iterator.find.js\";\nexport default {\n name: 'CustomSelect',\n props: {\n modelValue: {\n type: [String, Number],\n default: ''\n },\n options: {\n type: Array,\n required: true\n // 格式: [{ value: '', label: '', icon?: '' }]\n },\n placeholder: {\n type: String,\n default: '请选择'\n },\n width: {\n type: String,\n default: '160px'\n }\n },\n emits: ['update:modelValue', 'change'],\n data() {\n return {\n isOpen: false\n };\n },\n computed: {\n displayLabel() {\n const selected = this.options.find(opt => opt.value === this.modelValue);\n return selected ? selected.label : this.placeholder;\n }\n },\n mounted() {\n document.addEventListener('click', this.handleClickOutside);\n },\n beforeUnmount() {\n document.removeEventListener('click', this.handleClickOutside);\n },\n methods: {\n toggleDropdown() {\n this.isOpen = !this.isOpen;\n },\n selectOption(value) {\n this.$emit('update:modelValue', value);\n this.$emit('change', value);\n this.isOpen = false;\n },\n handleClickOutside(e) {\n if (!this.$el.contains(e.target)) {\n this.isOpen = false;\n }\n }\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./CustomSelect.vue?vue&type=template&id=6c59d112&scoped=true\"\nimport script from \"./CustomSelect.vue?vue&type=script&lang=js\"\nexport * from \"./CustomSelect.vue?vue&type=script&lang=js\"\n\nimport \"./CustomSelect.vue?vue&type=style&index=0&id=6c59d112&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-6c59d112\"]])\n\nexport default __exports__","import { resolveComponent as _resolveComponent, createVNode as _createVNode, withCtx as _withCtx, createTextVNode as _createTextVNode, createElementVNode as _createElementVNode, renderList as _renderList, Fragment as _Fragment, openBlock as _openBlock, createElementBlock as _createElementBlock, toDisplayString as _toDisplayString, createCommentVNode as _createCommentVNode, createBlock as _createBlock, withModifiers as _withModifiers, normalizeClass as _normalizeClass, resolveDirective as _resolveDirective, withDirectives as _withDirectives } from \"vue\";\nconst _hoisted_1 = {\n class: \"upload-settings\"\n};\nconst _hoisted_2 = {\n class: \"page-header\"\n};\nconst _hoisted_3 = {\n class: \"first-title\"\n};\nconst _hoisted_4 = {\n class: \"header-actions\"\n};\nconst _hoisted_5 = {\n class: \"group-header\"\n};\nconst _hoisted_6 = {\n class: \"group-title\"\n};\nconst _hoisted_7 = {\n key: 0,\n class: \"load-balance-switch\"\n};\nconst _hoisted_8 = {\n key: 0,\n class: \"channel-cards\"\n};\nconst _hoisted_9 = [\"onMousemove\", \"onMouseleave\"];\nconst _hoisted_10 = {\n class: \"card-header\"\n};\nconst _hoisted_11 = {\n class: \"card-title\"\n};\nconst _hoisted_12 = {\n class: \"channel-name\"\n};\nconst _hoisted_13 = {\n class: \"card-body\"\n};\nconst _hoisted_14 = {\n class: \"card-info\"\n};\nconst _hoisted_15 = {\n class: \"info-item\"\n};\nconst _hoisted_16 = {\n class: \"info-text\"\n};\nconst _hoisted_17 = {\n key: 0,\n class: \"info-item\"\n};\nconst _hoisted_18 = {\n class: \"info-text\"\n};\nconst _hoisted_19 = {\n key: 1,\n class: \"info-item\"\n};\nconst _hoisted_20 = [\"title\"];\nconst _hoisted_21 = {\n class: \"info-item\"\n};\nconst _hoisted_22 = {\n class: \"info-text\"\n};\nconst _hoisted_23 = {\n key: 0,\n class: \"info-item\"\n};\nconst _hoisted_24 = [\"title\"];\nconst _hoisted_25 = {\n class: \"info-item\"\n};\nconst _hoisted_26 = {\n class: \"info-text\"\n};\nconst _hoisted_27 = {\n class: \"info-item\"\n};\nconst _hoisted_28 = {\n class: \"info-text\"\n};\nconst _hoisted_29 = {\n class: \"info-item\"\n};\nconst _hoisted_30 = {\n class: \"info-text\"\n};\nconst _hoisted_31 = {\n key: 0,\n class: \"quota-mini\"\n};\nconst _hoisted_32 = {\n class: \"quota-text\"\n};\nconst _hoisted_33 = {\n class: \"card-actions\"\n};\nconst _hoisted_34 = {\n key: 1,\n class: \"empty-tip\"\n};\nconst _hoisted_35 = {\n class: \"form-warning\"\n};\nconst _hoisted_36 = {\n class: \"quota-label\"\n};\nconst _hoisted_37 = {\n class: \"quota-status\"\n};\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n const _component_el_tooltip = _resolveComponent(\"el-tooltip\");\n const _component_CustomSelect = _resolveComponent(\"CustomSelect\");\n const _component_el_button = _resolveComponent(\"el-button\");\n const _component_el_tag = _resolveComponent(\"el-tag\");\n const _component_el_switch = _resolveComponent(\"el-switch\");\n const _component_el_progress = _resolveComponent(\"el-progress\");\n const _component_el_option = _resolveComponent(\"el-option\");\n const _component_el_select = _resolveComponent(\"el-select\");\n const _component_el_form_item = _resolveComponent(\"el-form-item\");\n const _component_el_input = _resolveComponent(\"el-input\");\n const _component_el_input_number = _resolveComponent(\"el-input-number\");\n const _component_el_form = _resolveComponent(\"el-form\");\n const _component_el_dialog = _resolveComponent(\"el-dialog\");\n const _component_el_descriptions_item = _resolveComponent(\"el-descriptions-item\");\n const _component_el_descriptions = _resolveComponent(\"el-descriptions\");\n const _directive_loading = _resolveDirective(\"loading\");\n return _withDirectives((_openBlock(), _createElementBlock(\"div\", _hoisted_1, [_createElementVNode(\"div\", _hoisted_2, [_createElementVNode(\"h3\", _hoisted_3, [_cache[59] || (_cache[59] = _createTextVNode(\" 上传渠道管理 \", -1)), _createVNode(_component_el_tooltip, {\n content: \"管理所有上传渠道的配置,点击卡片查看详情或编辑\",\n placement: \"right\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"question-circle\",\n class: \"help-icon\"\n })]),\n _: 1\n })]), _createElementVNode(\"div\", _hoisted_4, [_createVNode(_component_CustomSelect, {\n modelValue: $data.channelFilter,\n \"onUpdate:modelValue\": _cache[0] || (_cache[0] = $event => $data.channelFilter = $event),\n options: $options.filterOptions,\n placeholder: \"筛选渠道类型\",\n width: \"160px\"\n }, null, 8, [\"modelValue\", \"options\"]), _createVNode(_component_el_button, {\n type: \"primary\",\n onClick: _cache[1] || (_cache[1] = $event => $data.showAddDialog = true),\n class: \"add-btn\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"plus\",\n style: {\n \"margin-right\": \"6px\"\n }\n }), _cache[60] || (_cache[60] = _createTextVNode(\" 添加渠道 \", -1))]),\n _: 1\n })])]), (_openBlock(true), _createElementBlock(_Fragment, null, _renderList($options.filteredChannels, channelType => {\n return _openBlock(), _createElementBlock(\"div\", {\n key: channelType.value,\n class: \"channel-group\"\n }, [_createElementVNode(\"div\", _hoisted_5, [_createElementVNode(\"div\", _hoisted_6, [_createVNode(_component_font_awesome_icon, {\n icon: $options.getChannelIcon(channelType.value),\n class: \"group-icon\"\n }, null, 8, [\"icon\"]), _createElementVNode(\"span\", null, _toDisplayString(channelType.label), 1), _createVNode(_component_el_tag, {\n size: \"small\",\n type: \"info\",\n class: \"channel-count\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($options.getChannelList(channelType.value).length), 1)]),\n _: 2\n }, 1024)]), $options.hasLoadBalance(channelType.value) ? (_openBlock(), _createElementBlock(\"div\", _hoisted_7, [_cache[61] || (_cache[61] = _createElementVNode(\"span\", {\n class: \"switch-label\"\n }, \"负载均衡\", -1)), _createVNode(_component_el_switch, {\n modelValue: $options.getSettings(channelType.value).loadBalance.enabled,\n \"onUpdate:modelValue\": $event => $options.getSettings(channelType.value).loadBalance.enabled = $event,\n size: \"small\",\n onChange: $options.saveSettings\n }, null, 8, [\"modelValue\", \"onUpdate:modelValue\", \"onChange\"])])) : _createCommentVNode(\"\", true)]), $options.getChannelList(channelType.value).length > 0 ? (_openBlock(), _createElementBlock(\"div\", _hoisted_8, [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($options.getChannelList(channelType.value), (channel, index) => {\n return _openBlock(), _createElementBlock(\"div\", {\n key: channel.name || index,\n class: _normalizeClass([\"channel-card\", [channelType.value, {\n 'disabled': !channel.enabled,\n 'fixed': channel.fixed\n }]]),\n onMousemove: $event => $options.handleCardMouseMove($event, channelType.value, index),\n onMouseleave: $event => $options.handleCardMouseLeave(channelType.value, index)\n }, [_createElementVNode(\"div\", {\n class: \"card-glow\",\n ref_for: true,\n ref: `glow-${channelType.value}-${index}`\n }, null, 512), _createElementVNode(\"div\", _hoisted_10, [_createElementVNode(\"div\", _hoisted_11, [_createElementVNode(\"span\", _hoisted_12, _toDisplayString(channel.name || '未命名渠道'), 1), channel.fixed ? (_openBlock(), _createBlock(_component_el_tag, {\n key: 0,\n size: \"small\",\n type: \"warning\"\n }, {\n default: _withCtx(() => [...(_cache[62] || (_cache[62] = [_createTextVNode(\"环境变量\", -1)]))]),\n _: 1\n })) : _createCommentVNode(\"\", true)]), _createVNode(_component_el_switch, {\n modelValue: channel.enabled,\n \"onUpdate:modelValue\": $event => channel.enabled = $event,\n size: \"small\",\n onClick: _cache[2] || (_cache[2] = _withModifiers(() => {}, [\"stop\"])),\n onChange: $options.saveSettings\n }, null, 8, [\"modelValue\", \"onUpdate:modelValue\", \"onChange\"])]), _createElementVNode(\"div\", _hoisted_13, [_createElementVNode(\"div\", _hoisted_14, [channelType.value === 'telegram' ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 0\n }, [_createElementVNode(\"div\", _hoisted_15, [_createVNode(_component_font_awesome_icon, {\n icon: \"robot\",\n class: \"info-icon\"\n }), _createElementVNode(\"span\", _hoisted_16, \"Bot: \" + _toDisplayString($options.maskText(channel.botToken)), 1)]), channel.chatId ? (_openBlock(), _createElementBlock(\"div\", _hoisted_17, [_createVNode(_component_font_awesome_icon, {\n icon: \"comments\",\n class: \"info-icon\"\n }), _createElementVNode(\"span\", _hoisted_18, \"Channel: \" + _toDisplayString($options.maskText(channel.chatId)), 1)])) : _createCommentVNode(\"\", true)], 64)) : channelType.value === 'cfr2' ? (_openBlock(), _createElementBlock(\"div\", _hoisted_19, [_createVNode(_component_font_awesome_icon, {\n icon: \"link\",\n class: \"info-icon\"\n }), _createElementVNode(\"span\", {\n class: \"info-text\",\n title: channel.publicUrl\n }, _toDisplayString(channel.publicUrl || '未设置公开链接'), 9, _hoisted_20)])) : channelType.value === 's3' ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 2\n }, [_createElementVNode(\"div\", _hoisted_21, [_createVNode(_component_font_awesome_icon, {\n icon: \"server\",\n class: \"info-icon\"\n }), _createElementVNode(\"span\", _hoisted_22, _toDisplayString(channel.bucketName || '未设置'), 1)]), channel.endpoint ? (_openBlock(), _createElementBlock(\"div\", _hoisted_23, [_createVNode(_component_font_awesome_icon, {\n icon: \"link\",\n class: \"info-icon\"\n }), _createElementVNode(\"span\", {\n class: \"info-text\",\n title: channel.endpoint\n }, _toDisplayString(channel.endpoint), 9, _hoisted_24)])) : _createCommentVNode(\"\", true)], 64)) : channelType.value === 'discord' ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 3\n }, [_createElementVNode(\"div\", _hoisted_25, [_createVNode(_component_font_awesome_icon, {\n icon: \"robot\",\n class: \"info-icon\"\n }), _createElementVNode(\"span\", _hoisted_26, \"Bot: \" + _toDisplayString($options.maskText(channel.botToken)), 1)]), _createElementVNode(\"div\", _hoisted_27, [_createVNode(_component_font_awesome_icon, {\n icon: \"hashtag\",\n class: \"info-icon\"\n }), _createElementVNode(\"span\", _hoisted_28, \"Channel: \" + _toDisplayString($options.maskText(channel.channelId)), 1)]), channel.isNitro ? (_openBlock(), _createBlock(_component_el_tag, {\n key: 0,\n size: \"small\",\n type: \"success\"\n }, {\n default: _withCtx(() => [...(_cache[63] || (_cache[63] = [_createTextVNode(\"Nitro\", -1)]))]),\n _: 1\n })) : _createCommentVNode(\"\", true)], 64)) : channelType.value === 'huggingface' ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 4\n }, [_createElementVNode(\"div\", _hoisted_29, [_createVNode(_component_font_awesome_icon, {\n icon: \"database\",\n class: \"info-icon\"\n }), _createElementVNode(\"span\", _hoisted_30, _toDisplayString(channel.repo || '未设置仓库'), 1)]), channel.isPrivate ? (_openBlock(), _createBlock(_component_el_tag, {\n key: 0,\n size: \"small\",\n type: \"warning\"\n }, {\n default: _withCtx(() => [...(_cache[64] || (_cache[64] = [_createTextVNode(\"私有\", -1)]))]),\n _: 1\n })) : _createCommentVNode(\"\", true)], 64)) : _createCommentVNode(\"\", true)]), channel.quota?.enabled ? (_openBlock(), _createElementBlock(\"div\", _hoisted_31, [_createVNode(_component_el_progress, {\n percentage: $options.getQuotaPercentage(channel),\n status: $options.getQuotaStatus(channel),\n \"stroke-width\": 6\n }, null, 8, [\"percentage\", \"status\"]), _createElementVNode(\"span\", _hoisted_32, _toDisplayString($options.getQuotaText(channel)), 1)])) : _createCommentVNode(\"\", true)]), _createElementVNode(\"div\", _hoisted_33, [_createVNode(_component_el_button, {\n text: \"\",\n type: \"primary\",\n size: \"small\",\n onClick: $event => $options.openDetailDialog(channelType.value, index)\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"eye\",\n style: {\n \"margin-right\": \"4px\"\n }\n }), _cache[65] || (_cache[65] = _createTextVNode(\"详情 \", -1))]),\n _: 1\n }, 8, [\"onClick\"]), _createVNode(_component_el_button, {\n text: \"\",\n type: \"primary\",\n size: \"small\",\n onClick: $event => $options.openEditDialog(channelType.value, index)\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"edit\",\n style: {\n \"margin-right\": \"4px\"\n }\n }), _cache[66] || (_cache[66] = _createTextVNode(\"编辑 \", -1))]),\n _: 1\n }, 8, [\"onClick\"]), _createVNode(_component_el_button, {\n text: \"\",\n type: \"danger\",\n size: \"small\",\n onClick: $event => $options.deleteChannel(channelType.value, index),\n disabled: channel.fixed\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"trash-alt\",\n style: {\n \"margin-right\": \"4px\"\n }\n }), _cache[67] || (_cache[67] = _createTextVNode(\"删除 \", -1))]),\n _: 1\n }, 8, [\"onClick\", \"disabled\"])])], 42, _hoisted_9);\n }), 128))])) : (_openBlock(), _createElementBlock(\"div\", _hoisted_34, [_createVNode(_component_font_awesome_icon, {\n icon: \"inbox\",\n class: \"empty-icon\"\n }), _createElementVNode(\"span\", null, \"暂无 \" + _toDisplayString(channelType.label) + \" 渠道\", 1)]))]);\n }), 128)), _createVNode(_component_el_dialog, {\n modelValue: $data.showAddDialog,\n \"onUpdate:modelValue\": _cache[26] || (_cache[26] = $event => $data.showAddDialog = $event),\n title: \"添加新渠道\",\n class: \"channel-dialog\",\n \"destroy-on-close\": \"\",\n onClosed: $options.resetAddForm\n }, {\n footer: _withCtx(() => [_createVNode(_component_el_button, {\n onClick: _cache[25] || (_cache[25] = $event => $data.showAddDialog = false)\n }, {\n default: _withCtx(() => [...(_cache[73] || (_cache[73] = [_createTextVNode(\"取消\", -1)]))]),\n _: 1\n }), _createVNode(_component_el_button, {\n type: \"primary\",\n onClick: $options.confirmAddChannel\n }, {\n default: _withCtx(() => [...(_cache[74] || (_cache[74] = [_createTextVNode(\"确认添加\", -1)]))]),\n _: 1\n }, 8, [\"onClick\"])]),\n default: _withCtx(() => [_createVNode(_component_el_form, {\n model: $data.newChannel,\n \"label-position\": \"top\",\n ref: \"addForm\",\n rules: $data.addRules\n }, {\n default: _withCtx(() => [_createVNode(_component_el_form_item, {\n label: \"渠道类型\",\n prop: \"type\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_select, {\n modelValue: $data.newChannel.type,\n \"onUpdate:modelValue\": _cache[3] || (_cache[3] = $event => $data.newChannel.type = $event),\n placeholder: \"请选择渠道类型\",\n style: {\n \"width\": \"100%\"\n },\n onChange: $options.onChannelTypeChange\n }, {\n default: _withCtx(() => [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($data.addableChannels, ch => {\n return _openBlock(), _createBlock(_component_el_option, {\n key: ch.value,\n label: ch.label,\n value: ch.value\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: $options.getChannelIcon(ch.value),\n class: \"select-option-icon\"\n }, null, 8, [\"icon\"]), _createTextVNode(\" \" + _toDisplayString(ch.label), 1)]),\n _: 2\n }, 1032, [\"label\", \"value\"]);\n }), 128))]),\n _: 1\n }, 8, [\"modelValue\", \"onChange\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"渠道名称\",\n prop: \"name\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.newChannel.name,\n \"onUpdate:modelValue\": _cache[4] || (_cache[4] = $event => $data.newChannel.name = $event),\n placeholder: \"请输入渠道名称\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), $data.newChannel.type === 'telegram' ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 0\n }, [_createVNode(_component_el_form_item, {\n label: \"Bot Token\",\n prop: \"botToken\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.newChannel.botToken,\n \"onUpdate:modelValue\": _cache[5] || (_cache[5] = $event => $data.newChannel.botToken = $event),\n type: \"password\",\n \"show-password\": \"\",\n placeholder: \"请输入 Bot Token\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"Chat ID\",\n prop: \"chatId\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.newChannel.chatId,\n \"onUpdate:modelValue\": _cache[6] || (_cache[6] = $event => $data.newChannel.chatId = $event),\n type: \"password\",\n \"show-password\": \"\",\n placeholder: \"请输入 Chat ID\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"代理域名\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.newChannel.proxyUrl,\n \"onUpdate:modelValue\": _cache[7] || (_cache[7] = $event => $data.newChannel.proxyUrl = $event),\n placeholder: \"可选,例如: your-proxy.example.com\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n })], 64)) : $data.newChannel.type === 's3' ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 1\n }, [_createVNode(_component_el_form_item, {\n label: \"Endpoint\",\n prop: \"endpoint\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.newChannel.endpoint,\n \"onUpdate:modelValue\": _cache[8] || (_cache[8] = $event => $data.newChannel.endpoint = $event),\n placeholder: \"例如: https://s3.us-east-005.backblazeb2.com\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"CDN 域名\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.newChannel.cdnDomain,\n \"onUpdate:modelValue\": _cache[9] || (_cache[9] = $event => $data.newChannel.cdnDomain = $event),\n placeholder: \"如果有 CDN,请配置 CDN 域名,例如:https://cdn.example.com\"\n }, null, 8, [\"modelValue\"]), _cache[68] || (_cache[68] = _createElementVNode(\"span\", {\n class: \"form-tip\"\n }, \"可选配置。配置后将优先通过 CDN 读取文件,提高访问速度和降低成本\", -1))]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"存储桶名称\",\n prop: \"bucketName\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.newChannel.bucketName,\n \"onUpdate:modelValue\": _cache[10] || (_cache[10] = $event => $data.newChannel.bucketName = $event),\n placeholder: \"请输入存储桶名称\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"存储桶区域\",\n prop: \"region\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.newChannel.region,\n \"onUpdate:modelValue\": _cache[11] || (_cache[11] = $event => $data.newChannel.region = $event),\n placeholder: \"默认填写 auto\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"访问密钥 ID\",\n prop: \"accessKeyId\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.newChannel.accessKeyId,\n \"onUpdate:modelValue\": _cache[12] || (_cache[12] = $event => $data.newChannel.accessKeyId = $event),\n type: \"password\",\n \"show-password\": \"\",\n placeholder: \"请输入访问密钥 ID\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"机密访问密钥\",\n prop: \"secretAccessKey\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.newChannel.secretAccessKey,\n \"onUpdate:modelValue\": _cache[13] || (_cache[13] = $event => $data.newChannel.secretAccessKey = $event),\n type: \"password\",\n \"show-password\": \"\",\n placeholder: \"请输入机密访问密钥\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"路径风格\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_switch, {\n modelValue: $data.newChannel.pathStyle,\n \"onUpdate:modelValue\": _cache[14] || (_cache[14] = $event => $data.newChannel.pathStyle = $event)\n }, null, 8, [\"modelValue\"]), _cache[69] || (_cache[69] = _createElementVNode(\"span\", {\n class: \"form-tip\"\n }, \"使用 OpenList 时需开启\", -1))]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"容量限制\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_switch, {\n modelValue: $data.newChannel.quota.enabled,\n \"onUpdate:modelValue\": _cache[15] || (_cache[15] = $event => $data.newChannel.quota.enabled = $event)\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), $data.newChannel.quota?.enabled ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 0\n }, [_createVNode(_component_el_form_item, {\n label: \"容量上限 (GB)\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input_number, {\n modelValue: $data.newChannel.quota.limitGB,\n \"onUpdate:modelValue\": _cache[16] || (_cache[16] = $event => $data.newChannel.quota.limitGB = $event),\n min: 0.1,\n step: 1,\n precision: 1\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"停用阈值 (%)\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input_number, {\n modelValue: $data.newChannel.quota.threshold,\n \"onUpdate:modelValue\": _cache[17] || (_cache[17] = $event => $data.newChannel.quota.threshold = $event),\n min: 50,\n max: 100,\n step: 5\n }, null, 8, [\"modelValue\"])]),\n _: 1\n })], 64)) : _createCommentVNode(\"\", true)], 64)) : $data.newChannel.type === 'discord' ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 2\n }, [_createVNode(_component_el_form_item, {\n label: \"Bot Token\",\n prop: \"botToken\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.newChannel.botToken,\n \"onUpdate:modelValue\": _cache[18] || (_cache[18] = $event => $data.newChannel.botToken = $event),\n type: \"password\",\n \"show-password\": \"\",\n placeholder: \"请输入 Bot Token\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"Channel ID\",\n prop: \"channelId\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.newChannel.channelId,\n \"onUpdate:modelValue\": _cache[19] || (_cache[19] = $event => $data.newChannel.channelId = $event),\n type: \"password\",\n \"show-password\": \"\",\n placeholder: \"请输入 Channel ID\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"代理域名\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.newChannel.proxyUrl,\n \"onUpdate:modelValue\": _cache[20] || (_cache[20] = $event => $data.newChannel.proxyUrl = $event),\n placeholder: \"可选,例如: your-proxy.example.com\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"Nitro 会员\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_switch, {\n modelValue: $data.newChannel.isNitro,\n \"onUpdate:modelValue\": _cache[21] || (_cache[21] = $event => $data.newChannel.isNitro = $event)\n }, null, 8, [\"modelValue\"]), _cache[70] || (_cache[70] = _createElementVNode(\"span\", {\n class: \"form-tip\"\n }, \"会员单文件限制 25MB,否则为 10MB\", -1))]),\n _: 1\n }), _createElementVNode(\"div\", _hoisted_35, [_createVNode(_component_font_awesome_icon, {\n icon: \"exclamation-triangle\",\n style: {\n \"margin-right\": \"6px\"\n }\n }), _cache[71] || (_cache[71] = _createTextVNode(\" Discord 有接口频率限制,不建议将其用作大规模并发场景 \", -1))])], 64)) : $data.newChannel.type === 'huggingface' ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 3\n }, [_createVNode(_component_el_form_item, {\n label: \"仓库名\",\n prop: \"repo\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.newChannel.repo,\n \"onUpdate:modelValue\": _cache[22] || (_cache[22] = $event => $data.newChannel.repo = $event),\n placeholder: \"格式: username/repo-name\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"Access Token\",\n prop: \"token\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.newChannel.token,\n \"onUpdate:modelValue\": _cache[23] || (_cache[23] = $event => $data.newChannel.token = $event),\n type: \"password\",\n \"show-password\": \"\",\n placeholder: \"请输入 Access Token\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"私有仓库\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_switch, {\n modelValue: $data.newChannel.isPrivate,\n \"onUpdate:modelValue\": _cache[24] || (_cache[24] = $event => $data.newChannel.isPrivate = $event)\n }, null, 8, [\"modelValue\"]), _cache[72] || (_cache[72] = _createElementVNode(\"span\", {\n class: \"form-tip\"\n }, \"私有仓库限制 100GB\", -1))]),\n _: 1\n })], 64)) : _createCommentVNode(\"\", true)]),\n _: 1\n }, 8, [\"model\", \"rules\"])]),\n _: 1\n }, 8, [\"modelValue\", \"onClosed\"]), _createVNode(_component_el_dialog, {\n modelValue: $data.showDetailDialog,\n \"onUpdate:modelValue\": _cache[28] || (_cache[28] = $event => $data.showDetailDialog = $event),\n title: '渠道详情 - ' + ($data.currentChannel?.name || ''),\n class: \"channel-dialog\",\n onClosed: $options.resetDetailData\n }, {\n footer: _withCtx(() => [_createVNode(_component_el_button, {\n onClick: _cache[27] || (_cache[27] = $event => $data.showDetailDialog = false)\n }, {\n default: _withCtx(() => [...(_cache[77] || (_cache[77] = [_createTextVNode(\"关闭\", -1)]))]),\n _: 1\n }), _createVNode(_component_el_button, {\n type: \"primary\",\n onClick: $options.openEditFromDetail\n }, {\n default: _withCtx(() => [...(_cache[78] || (_cache[78] = [_createTextVNode(\"编辑\", -1)]))]),\n _: 1\n }, 8, [\"onClick\"])]),\n default: _withCtx(() => [_createVNode(_component_el_descriptions, {\n column: 1,\n border: \"\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_descriptions_item, {\n label: \"渠道名称\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($data.currentChannel?.name), 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"渠道类型\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($options.getChannelTypeLabel($data.currentChannelType)), 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"状态\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_tag, {\n type: $data.currentChannel?.enabled ? 'success' : 'info'\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($data.currentChannel?.enabled ? '已启用' : '已禁用'), 1)]),\n _: 1\n }, 8, [\"type\"])]),\n _: 1\n }), $data.currentChannel?.fixed ? (_openBlock(), _createBlock(_component_el_descriptions_item, {\n key: 0,\n label: \"配置来源\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_tag, {\n type: \"warning\"\n }, {\n default: _withCtx(() => [...(_cache[75] || (_cache[75] = [_createTextVNode(\"环境变量\", -1)]))]),\n _: 1\n })]),\n _: 1\n })) : _createCommentVNode(\"\", true), $data.currentChannelType === 'telegram' ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 1\n }, [_createVNode(_component_el_descriptions_item, {\n label: \"Bot Token\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($options.maskText($data.currentChannel?.botToken, 10)), 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"Chat ID\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($options.maskText($data.currentChannel?.chatId, 6)), 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"代理域名\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($data.currentChannel?.proxyUrl || '未设置'), 1)]),\n _: 1\n })], 64)) : $data.currentChannelType === 'cfr2' ? (_openBlock(), _createBlock(_component_el_descriptions_item, {\n key: 2,\n label: \"公开访问链接\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n \"model-value\": $data.currentChannel?.publicUrl || '未设置',\n readonly: \"\"\n }, null, 8, [\"model-value\"])]),\n _: 1\n })) : $data.currentChannelType === 's3' ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 3\n }, [_createVNode(_component_el_descriptions_item, {\n label: \"Endpoint\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n \"model-value\": $data.currentChannel?.endpoint,\n readonly: \"\"\n }, null, 8, [\"model-value\"])]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"CDN 域名\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n \"model-value\": $data.currentChannel?.cdnDomain || '未设置',\n readonly: \"\"\n }, null, 8, [\"model-value\"])]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"存储桶名称\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($data.currentChannel?.bucketName), 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"存储桶区域\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($data.currentChannel?.region), 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"路径风格\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($data.currentChannel?.pathStyle ? '是' : '否'), 1)]),\n _: 1\n })], 64)) : $data.currentChannelType === 'discord' ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 4\n }, [_createVNode(_component_el_descriptions_item, {\n label: \"Bot Token\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($options.maskText($data.currentChannel?.botToken, 10)), 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"Channel ID\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($options.maskText($data.currentChannel?.channelId, 6)), 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"代理域名\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($data.currentChannel?.proxyUrl || '未设置'), 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"Nitro 会员\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($data.currentChannel?.isNitro ? '是' : '否'), 1)]),\n _: 1\n })], 64)) : $data.currentChannelType === 'huggingface' ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 5\n }, [_createVNode(_component_el_descriptions_item, {\n label: \"仓库名\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($data.currentChannel?.repo), 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"私有仓库\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($data.currentChannel?.isPrivate ? '是' : '否'), 1)]),\n _: 1\n })], 64)) : _createCommentVNode(\"\", true), $data.currentChannel?.quota?.enabled ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 6\n }, [_createVNode(_component_el_descriptions_item, {\n label: \"容量限制\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($data.currentChannel?.quota?.limitGB) + \" GB\", 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"停用阈值\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($data.currentChannel?.quota?.threshold) + \"%\", 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, null, {\n label: _withCtx(() => [_createElementVNode(\"span\", _hoisted_36, [_cache[76] || (_cache[76] = _createTextVNode(\" 当前用量 \", -1)), _createVNode(_component_el_button, {\n link: \"\",\n type: \"primary\",\n onClick: $options.refreshQuota,\n class: \"refresh-btn\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"sync-alt\",\n class: _normalizeClass({\n 'fa-spin': $data.quotaLoading\n })\n }, null, 8, [\"class\"])]),\n _: 1\n }, 8, [\"onClick\"])])]),\n default: _withCtx(() => [_createElementVNode(\"div\", _hoisted_37, [_createVNode(_component_el_progress, {\n percentage: $options.getQuotaPercentage($data.currentChannel),\n status: $options.getQuotaStatus($data.currentChannel),\n \"stroke-width\": 16,\n \"text-inside\": true,\n format: () => $options.getQuotaText($data.currentChannel)\n }, null, 8, [\"percentage\", \"status\", \"format\"]), _createElementVNode(\"div\", {\n class: _normalizeClass([\"quota-info\", {\n 'quota-warning': $options.isQuotaExceeded($data.currentChannel)\n }])\n }, _toDisplayString($options.getQuotaStatusText($data.currentChannel)), 3)])]),\n _: 1\n })], 64)) : _createCommentVNode(\"\", true)]),\n _: 1\n })]),\n _: 1\n }, 8, [\"modelValue\", \"title\", \"onClosed\"]), _createVNode(_component_el_dialog, {\n modelValue: $data.showEditDialog,\n \"onUpdate:modelValue\": _cache[58] || (_cache[58] = $event => $data.showEditDialog = $event),\n title: '编辑渠道 - ' + ($data.editChannel?.name || ''),\n class: \"channel-dialog\",\n \"destroy-on-close\": \"\",\n onClosed: $options.resetEditData\n }, {\n footer: _withCtx(() => [_createVNode(_component_el_button, {\n onClick: _cache[57] || (_cache[57] = $event => $data.showEditDialog = false)\n }, {\n default: _withCtx(() => [...(_cache[80] || (_cache[80] = [_createTextVNode(\"取消\", -1)]))]),\n _: 1\n }), _createVNode(_component_el_button, {\n type: \"primary\",\n onClick: $options.confirmEditChannel\n }, {\n default: _withCtx(() => [...(_cache[81] || (_cache[81] = [_createTextVNode(\"保存修改\", -1)]))]),\n _: 1\n }, 8, [\"onClick\"])]),\n default: _withCtx(() => [_createVNode(_component_el_form, {\n model: $data.editChannel,\n \"label-position\": \"top\",\n ref: \"editForm\",\n rules: $data.editRules\n }, {\n default: _withCtx(() => [_createVNode(_component_el_form_item, {\n label: \"渠道名称\",\n prop: \"name\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.editChannel.name,\n \"onUpdate:modelValue\": _cache[29] || (_cache[29] = $event => $data.editChannel.name = $event),\n disabled: $data.editChannel.fixed\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"启用渠道\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_switch, {\n modelValue: $data.editChannel.enabled,\n \"onUpdate:modelValue\": _cache[30] || (_cache[30] = $event => $data.editChannel.enabled = $event)\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), $data.currentChannelType === 'telegram' ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 0\n }, [_createVNode(_component_el_form_item, {\n label: \"Bot Token\",\n prop: \"botToken\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.editChannel.botToken,\n \"onUpdate:modelValue\": _cache[31] || (_cache[31] = $event => $data.editChannel.botToken = $event),\n disabled: $data.editChannel.fixed,\n type: \"password\",\n \"show-password\": \"\"\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"Chat ID\",\n prop: \"chatId\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.editChannel.chatId,\n \"onUpdate:modelValue\": _cache[32] || (_cache[32] = $event => $data.editChannel.chatId = $event),\n disabled: $data.editChannel.fixed,\n type: \"password\",\n \"show-password\": \"\"\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"代理域名\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.editChannel.proxyUrl,\n \"onUpdate:modelValue\": _cache[33] || (_cache[33] = $event => $data.editChannel.proxyUrl = $event),\n placeholder: \"例如: your-proxy.example.com\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n })], 64)) : $data.currentChannelType === 'cfr2' ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 1\n }, [_createVNode(_component_el_form_item, {\n label: \"公开访问链接\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.editChannel.publicUrl,\n \"onUpdate:modelValue\": _cache[34] || (_cache[34] = $event => $data.editChannel.publicUrl = $event)\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"容量限制\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_switch, {\n modelValue: $data.editChannel.quota.enabled,\n \"onUpdate:modelValue\": _cache[35] || (_cache[35] = $event => $data.editChannel.quota.enabled = $event),\n onChange: _cache[36] || (_cache[36] = val => $options.onQuotaEnabledChange(val, $data.editChannel))\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), $data.editChannel.quota?.enabled ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 0\n }, [_createVNode(_component_el_form_item, {\n label: \"容量上限 (GB)\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input_number, {\n modelValue: $data.editChannel.quota.limitGB,\n \"onUpdate:modelValue\": _cache[37] || (_cache[37] = $event => $data.editChannel.quota.limitGB = $event),\n min: 0.1,\n step: 1,\n precision: 1\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"停用阈值 (%)\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input_number, {\n modelValue: $data.editChannel.quota.threshold,\n \"onUpdate:modelValue\": _cache[38] || (_cache[38] = $event => $data.editChannel.quota.threshold = $event),\n min: 50,\n max: 100,\n step: 5\n }, null, 8, [\"modelValue\"])]),\n _: 1\n })], 64)) : _createCommentVNode(\"\", true)], 64)) : $data.currentChannelType === 's3' ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 2\n }, [_createVNode(_component_el_form_item, {\n label: \"Endpoint\",\n prop: \"endpoint\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.editChannel.endpoint,\n \"onUpdate:modelValue\": _cache[39] || (_cache[39] = $event => $data.editChannel.endpoint = $event),\n disabled: $data.editChannel.fixed\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"CDN 域名\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.editChannel.cdnDomain,\n \"onUpdate:modelValue\": _cache[40] || (_cache[40] = $event => $data.editChannel.cdnDomain = $event),\n placeholder: \"如果有 CDN,请配置 CDN 域名,例如:https://cdn.example.com\"\n }, null, 8, [\"modelValue\"]), _cache[79] || (_cache[79] = _createElementVNode(\"span\", {\n class: \"form-tip\"\n }, \"可选配置。配置后将优先通过 CDN 读取文件,提高访问速度和降低成本\", -1))]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"存储桶名称\",\n prop: \"bucketName\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.editChannel.bucketName,\n \"onUpdate:modelValue\": _cache[41] || (_cache[41] = $event => $data.editChannel.bucketName = $event),\n disabled: $data.editChannel.fixed\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"存储桶区域\",\n prop: \"region\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.editChannel.region,\n \"onUpdate:modelValue\": _cache[42] || (_cache[42] = $event => $data.editChannel.region = $event),\n disabled: $data.editChannel.fixed\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"访问密钥 ID\",\n prop: \"accessKeyId\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.editChannel.accessKeyId,\n \"onUpdate:modelValue\": _cache[43] || (_cache[43] = $event => $data.editChannel.accessKeyId = $event),\n disabled: $data.editChannel.fixed,\n type: \"password\",\n \"show-password\": \"\"\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"机密访问密钥\",\n prop: \"secretAccessKey\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.editChannel.secretAccessKey,\n \"onUpdate:modelValue\": _cache[44] || (_cache[44] = $event => $data.editChannel.secretAccessKey = $event),\n disabled: $data.editChannel.fixed,\n type: \"password\",\n \"show-password\": \"\"\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"路径风格\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_switch, {\n modelValue: $data.editChannel.pathStyle,\n \"onUpdate:modelValue\": _cache[45] || (_cache[45] = $event => $data.editChannel.pathStyle = $event),\n disabled: $data.editChannel.fixed\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"容量限制\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_switch, {\n modelValue: $data.editChannel.quota.enabled,\n \"onUpdate:modelValue\": _cache[46] || (_cache[46] = $event => $data.editChannel.quota.enabled = $event),\n onChange: _cache[47] || (_cache[47] = val => $options.onQuotaEnabledChange(val, $data.editChannel))\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), $data.editChannel.quota?.enabled ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 0\n }, [_createVNode(_component_el_form_item, {\n label: \"容量上限 (GB)\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input_number, {\n modelValue: $data.editChannel.quota.limitGB,\n \"onUpdate:modelValue\": _cache[48] || (_cache[48] = $event => $data.editChannel.quota.limitGB = $event),\n min: 0.1,\n step: 1,\n precision: 1\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"停用阈值 (%)\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input_number, {\n modelValue: $data.editChannel.quota.threshold,\n \"onUpdate:modelValue\": _cache[49] || (_cache[49] = $event => $data.editChannel.quota.threshold = $event),\n min: 50,\n max: 100,\n step: 5\n }, null, 8, [\"modelValue\"])]),\n _: 1\n })], 64)) : _createCommentVNode(\"\", true)], 64)) : $data.currentChannelType === 'discord' ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 3\n }, [_createVNode(_component_el_form_item, {\n label: \"Bot Token\",\n prop: \"botToken\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.editChannel.botToken,\n \"onUpdate:modelValue\": _cache[50] || (_cache[50] = $event => $data.editChannel.botToken = $event),\n disabled: $data.editChannel.fixed,\n type: \"password\",\n \"show-password\": \"\"\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"Channel ID\",\n prop: \"channelId\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.editChannel.channelId,\n \"onUpdate:modelValue\": _cache[51] || (_cache[51] = $event => $data.editChannel.channelId = $event),\n disabled: $data.editChannel.fixed,\n type: \"password\",\n \"show-password\": \"\"\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"代理域名\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.editChannel.proxyUrl,\n \"onUpdate:modelValue\": _cache[52] || (_cache[52] = $event => $data.editChannel.proxyUrl = $event),\n placeholder: \"例如: your-proxy.example.com\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"Nitro 会员\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_switch, {\n modelValue: $data.editChannel.isNitro,\n \"onUpdate:modelValue\": _cache[53] || (_cache[53] = $event => $data.editChannel.isNitro = $event)\n }, null, 8, [\"modelValue\"])]),\n _: 1\n })], 64)) : $data.currentChannelType === 'huggingface' ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 4\n }, [_createVNode(_component_el_form_item, {\n label: \"仓库名\",\n prop: \"repo\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.editChannel.repo,\n \"onUpdate:modelValue\": _cache[54] || (_cache[54] = $event => $data.editChannel.repo = $event),\n disabled: $data.editChannel.fixed\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"Access Token\",\n prop: \"token\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.editChannel.token,\n \"onUpdate:modelValue\": _cache[55] || (_cache[55] = $event => $data.editChannel.token = $event),\n disabled: $data.editChannel.fixed,\n type: \"password\",\n \"show-password\": \"\"\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"私有仓库\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_switch, {\n modelValue: $data.editChannel.isPrivate,\n \"onUpdate:modelValue\": _cache[56] || (_cache[56] = $event => $data.editChannel.isPrivate = $event)\n }, null, 8, [\"modelValue\"])]),\n _: 1\n })], 64)) : _createCommentVNode(\"\", true)]),\n _: 1\n }, 8, [\"model\", \"rules\"])]),\n _: 1\n }, 8, [\"modelValue\", \"title\", \"onClosed\"])])), [[_directive_loading, $data.loading]]);\n}","import \"core-js/modules/es.array.push.js\";\nimport \"core-js/modules/es.iterator.constructor.js\";\nimport \"core-js/modules/es.iterator.filter.js\";\nimport \"core-js/modules/es.iterator.find.js\";\nimport \"core-js/modules/es.iterator.for-each.js\";\nimport \"core-js/modules/es.iterator.map.js\";\nimport \"core-js/modules/es.iterator.some.js\";\nimport \"core-js/modules/es.json.stringify.js\";\nimport \"core-js/modules/esnext.json.parse.js\";\nimport fetchWithAuth from '@/utils/fetchWithAuth';\nimport CustomSelect from '@/components/CustomSelect.vue';\nexport default {\n components: {\n CustomSelect\n },\n data() {\n return {\n // 渠道类型筛选\n channelFilter: '',\n // 渠道类型列表\n channels: [{\n value: 'telegram',\n label: 'Telegram'\n }, {\n value: 'cfr2',\n label: 'CloudFlare R2'\n }, {\n value: 's3',\n label: 'S3'\n }, {\n value: 'discord',\n label: 'Discord'\n }, {\n value: 'huggingface',\n label: 'HuggingFace'\n }],\n // 可添加的渠道类型(排除 cfr2,因为只能通过绑定 R2 或 S3 添加)\n addableChannels: [{\n value: 'telegram',\n label: 'Telegram'\n }, {\n value: 's3',\n label: 'S3'\n }, {\n value: 'discord',\n label: 'Discord'\n }, {\n value: 'huggingface',\n label: 'HuggingFace'\n }],\n // 各渠道配置\n telegramSettings: {\n loadBalance: {\n enabled: false\n },\n channels: []\n },\n cfr2Settings: {\n channels: []\n },\n s3Settings: {\n loadBalance: {\n enabled: false\n },\n channels: []\n },\n discordSettings: {\n loadBalance: {\n enabled: false\n },\n channels: []\n },\n huggingfaceSettings: {\n loadBalance: {\n enabled: false\n },\n channels: []\n },\n // 弹窗控制\n showAddDialog: false,\n showDetailDialog: false,\n showEditDialog: false,\n // 当前操作的渠道\n currentChannelType: '',\n currentChannelIndex: -1,\n currentChannel: null,\n editChannel: {},\n // 新增渠道表单\n newChannel: {\n type: '',\n name: '',\n enabled: true,\n // Telegram\n botToken: '',\n chatId: '',\n proxyUrl: '',\n // S3\n endpoint: '',\n cdnDomain: '',\n bucketName: '',\n region: 'auto',\n accessKeyId: '',\n secretAccessKey: '',\n pathStyle: false,\n quota: {\n enabled: false,\n limitGB: 10,\n threshold: 95\n },\n // Discord\n channelId: '',\n isNitro: false,\n // HuggingFace\n repo: '',\n token: '',\n isPrivate: false\n },\n // 添加表单验证规则\n addRules: {\n type: [{\n required: true,\n message: '请选择渠道类型',\n trigger: 'change'\n }],\n name: [{\n required: true,\n message: '请输入渠道名称',\n trigger: 'blur'\n }, {\n pattern: /^[\\u4e00-\\u9fa5a-zA-Z0-9_-]+$/,\n message: '渠道名称只能包含中英文、数字、下划线和横线',\n trigger: 'blur'\n }],\n botToken: [{\n required: true,\n message: '请输入 Bot Token',\n trigger: 'blur'\n }],\n chatId: [{\n required: true,\n message: '请输入 Chat ID',\n trigger: 'blur'\n }],\n channelId: [{\n required: true,\n message: '请输入 Channel ID',\n trigger: 'blur'\n }],\n endpoint: [{\n required: true,\n message: '请输入 Endpoint',\n trigger: 'blur'\n }],\n bucketName: [{\n required: true,\n message: '请输入存储桶名称',\n trigger: 'blur'\n }],\n region: [{\n required: true,\n message: '请输入存储桶区域',\n trigger: 'blur'\n }],\n accessKeyId: [{\n required: true,\n message: '请输入访问密钥 ID',\n trigger: 'blur'\n }],\n secretAccessKey: [{\n required: true,\n message: '请输入机密访问密钥',\n trigger: 'blur'\n }],\n repo: [{\n required: true,\n message: '请输入仓库名',\n trigger: 'blur'\n }],\n token: [{\n required: true,\n message: '请输入 Access Token',\n trigger: 'blur'\n }]\n },\n // 编辑表单验证规则\n editRules: {\n name: [{\n required: true,\n message: '请输入渠道名称',\n trigger: 'blur'\n }, {\n pattern: /^[\\u4e00-\\u9fa5a-zA-Z0-9_-]+$/,\n message: '渠道名称只能包含中英文、数字、下划线和横线',\n trigger: 'blur'\n }],\n botToken: [{\n required: true,\n message: '请输入 Bot Token',\n trigger: 'blur'\n }],\n chatId: [{\n required: true,\n message: '请输入 Chat ID',\n trigger: 'blur'\n }],\n channelId: [{\n required: true,\n message: '请输入 Channel ID',\n trigger: 'blur'\n }],\n endpoint: [{\n required: true,\n message: '请输入 Endpoint',\n trigger: 'blur'\n }],\n bucketName: [{\n required: true,\n message: '请输入存储桶名称',\n trigger: 'blur'\n }],\n region: [{\n required: true,\n message: '请输入存储桶区域',\n trigger: 'blur'\n }],\n accessKeyId: [{\n required: true,\n message: '请输入访问密钥 ID',\n trigger: 'blur'\n }],\n secretAccessKey: [{\n required: true,\n message: '请输入机密访问密钥',\n trigger: 'blur'\n }],\n repo: [{\n required: true,\n message: '请输入仓库名',\n trigger: 'blur'\n }],\n token: [{\n required: true,\n message: '请输入 Access Token',\n trigger: 'blur'\n }]\n },\n // 容量统计数据\n quotaStats: {},\n quotaLoading: false,\n // 加载状态\n loading: false\n };\n },\n computed: {\n // 筛选下拉框选项\n filterOptions() {\n const iconMap = {\n telegram: 'paper-plane',\n cfr2: 'cloud',\n s3: 'database',\n discord: 'comments',\n huggingface: 'robot'\n };\n return [{\n value: '',\n label: '全部类型'\n }, ...this.channels.map(ch => ({\n value: ch.value,\n label: ch.label,\n icon: iconMap[ch.value] || 'server'\n }))];\n },\n // 根据筛选条件过滤渠道类型\n filteredChannels() {\n if (!this.channelFilter) {\n return this.channels;\n }\n return this.channels.filter(ch => ch.value === this.channelFilter);\n }\n },\n methods: {\n // 卡片光斑跟随鼠标\n handleCardMouseMove(event, channelType, index) {\n const card = event.currentTarget;\n const rect = card.getBoundingClientRect();\n const x = event.clientX - rect.left;\n const y = event.clientY - rect.top;\n const refKey = `glow-${channelType}-${index}`;\n const glowEl = this.$refs[refKey];\n if (glowEl && glowEl[0]) {\n glowEl[0].style.opacity = '1';\n glowEl[0].style.left = `${x}px`;\n glowEl[0].style.top = `${y}px`;\n }\n },\n handleCardMouseLeave(channelType, index) {\n const refKey = `glow-${channelType}-${index}`;\n const glowEl = this.$refs[refKey];\n if (glowEl && glowEl[0]) {\n glowEl[0].style.opacity = '0';\n }\n },\n // 获取渠道图标\n getChannelIcon(type) {\n const icons = {\n telegram: 'paper-plane',\n cfr2: 'cloud',\n s3: 'database',\n discord: 'comments',\n huggingface: 'robot'\n };\n return icons[type] || 'server';\n },\n // 获取渠道类型标签\n getChannelTypeLabel(type) {\n const channel = this.channels.find(c => c.value === type);\n return channel ? channel.label : type;\n },\n // 获取渠道列表\n getChannelList(type) {\n return this.getSettings(type)?.channels || [];\n },\n // 获取渠道设置对象\n getSettings(type) {\n const map = {\n telegram: this.telegramSettings,\n cfr2: this.cfr2Settings,\n s3: this.s3Settings,\n discord: this.discordSettings,\n huggingface: this.huggingfaceSettings\n };\n return map[type];\n },\n // 是否有负载均衡选项\n hasLoadBalance(type) {\n return ['telegram', 's3', 'discord', 'huggingface'].includes(type);\n },\n // 文本脱敏\n maskText(text, showLength = 4) {\n if (!text) return '未设置';\n if (text.length <= showLength * 2) return '****';\n return text.slice(0, showLength) + '****' + text.slice(-showLength);\n },\n // 打开详情弹窗\n openDetailDialog(type, index) {\n this.currentChannelType = type;\n this.currentChannelIndex = index;\n this.currentChannel = this.getChannelList(type)[index];\n this.showDetailDialog = true;\n },\n // 打开编辑弹窗\n openEditDialog(type, index) {\n this.currentChannelType = type;\n this.currentChannelIndex = index;\n const channel = this.getChannelList(type)[index];\n this.editChannel = JSON.parse(JSON.stringify(channel));\n // 确保 quota 对象存在\n if (!this.editChannel.quota) {\n this.editChannel.quota = {\n enabled: false,\n limitGB: 10,\n threshold: 95\n };\n }\n this.showEditDialog = true;\n },\n // 从详情页打开编辑\n openEditFromDetail() {\n this.showDetailDialog = false;\n this.openEditDialog(this.currentChannelType, this.currentChannelIndex);\n },\n // 重置添加表单\n resetAddForm() {\n this.newChannel = {\n type: '',\n name: '',\n enabled: true,\n botToken: '',\n chatId: '',\n proxyUrl: '',\n endpoint: '',\n bucketName: '',\n region: 'auto',\n accessKeyId: '',\n secretAccessKey: '',\n pathStyle: false,\n quota: {\n enabled: false,\n limitGB: 10,\n threshold: 95\n },\n channelId: '',\n isNitro: false,\n repo: '',\n token: '',\n isPrivate: false\n };\n },\n // 重置详情弹窗数据\n resetDetailData() {\n this.currentChannel = null;\n },\n // 重置编辑弹窗数据\n resetEditData() {\n this.editChannel = {};\n },\n // 渠道类型变更时重置表单\n onChannelTypeChange() {\n // 保留 type 和 name,重置其他字段\n const {\n type,\n name\n } = this.newChannel;\n this.newChannel = {\n type,\n name,\n enabled: true,\n botToken: '',\n chatId: '',\n proxyUrl: '',\n endpoint: '',\n cdnDomain: '',\n bucketName: '',\n region: 'auto',\n accessKeyId: '',\n secretAccessKey: '',\n pathStyle: false,\n quota: {\n enabled: false,\n limitGB: 10,\n threshold: 95\n },\n channelId: '',\n isNitro: false,\n repo: '',\n token: '',\n isPrivate: false\n };\n },\n // 确认添加渠道\n confirmAddChannel() {\n this.$refs.addForm.validate(valid => {\n if (!valid) return;\n const {\n type,\n name\n } = this.newChannel;\n const settings = this.getSettings(type);\n\n // 检查是否为保留名称({type}_env)\n const reservedNames = ['Telegram_env', 'R2_env', 'S3_env', 'Discord_env', 'HuggingFace_env'];\n if (reservedNames.includes(name)) {\n this.$message.warning('该名称为系统保留名称,请使用其他名称');\n return;\n }\n\n // 检查名称是否重复\n const isDuplicate = settings.channels.some(ch => ch.name === name);\n if (isDuplicate) {\n this.$message.warning('该类型下已存在同名渠道,请使用其他名称');\n return;\n }\n let newChannelData = {\n id: settings.channels.length + 1,\n name: this.newChannel.name,\n type: type,\n savePath: 'database',\n enabled: true,\n fixed: false\n };\n\n // 根据类型添加特定字段\n if (type === 'telegram') {\n Object.assign(newChannelData, {\n botToken: this.newChannel.botToken,\n chatId: this.newChannel.chatId,\n proxyUrl: this.newChannel.proxyUrl\n });\n } else if (type === 's3') {\n Object.assign(newChannelData, {\n endpoint: this.newChannel.endpoint,\n cdnDomain: this.newChannel.cdnDomain,\n bucketName: this.newChannel.bucketName,\n region: this.newChannel.region,\n accessKeyId: this.newChannel.accessKeyId,\n secretAccessKey: this.newChannel.secretAccessKey,\n pathStyle: this.newChannel.pathStyle,\n quota: {\n ...this.newChannel.quota\n }\n });\n } else if (type === 'discord') {\n Object.assign(newChannelData, {\n botToken: this.newChannel.botToken,\n channelId: this.newChannel.channelId,\n proxyUrl: this.newChannel.proxyUrl,\n isNitro: this.newChannel.isNitro\n });\n } else if (type === 'huggingface') {\n Object.assign(newChannelData, {\n repo: this.newChannel.repo,\n token: this.newChannel.token,\n isPrivate: this.newChannel.isPrivate\n });\n }\n settings.channels.push(newChannelData);\n this.showAddDialog = false;\n // 自动保存全部设置\n this.saveSettings();\n });\n },\n // 确认编辑渠道\n confirmEditChannel() {\n this.$refs.editForm.validate(valid => {\n if (!valid) return;\n const settings = this.getSettings(this.currentChannelType);\n const newName = this.editChannel.name;\n const currentIndex = this.currentChannelIndex;\n const isFixedChannel = this.editChannel.fixed;\n\n // 非环境变量渠道才检查名称\n if (!isFixedChannel) {\n // 检查是否为保留名称({type}_env)\n const reservedNames = ['Telegram_env', 'R2_env', 'S3_env', 'Discord_env', 'HuggingFace_env'];\n if (reservedNames.includes(newName)) {\n this.$message.warning('该名称为系统保留名称,请使用其他名称');\n return;\n }\n\n // 检查名称是否与其他渠道重复(排除当前编辑的渠道)\n const isDuplicate = settings.channels.some((ch, idx) => idx !== currentIndex && ch.name === newName);\n if (isDuplicate) {\n this.$message.warning('该类型下已存在同名渠道,请使用其他名称');\n return;\n }\n }\n settings.channels[this.currentChannelIndex] = {\n ...this.editChannel\n };\n this.showEditDialog = false;\n // 自动保存全部设置\n this.saveSettings();\n });\n },\n // 删除渠道\n deleteChannel(type, index) {\n const channel = this.getChannelList(type)[index];\n if (channel.fixed) {\n this.$message.warning('环境变量配置的渠道无法删除');\n return;\n }\n this.$confirm('确定要删除该渠道吗?', '提示', {\n confirmButtonText: '确定',\n cancelButtonText: '取消',\n type: 'warning'\n }).then(() => {\n const settings = this.getSettings(type);\n settings.channels.splice(index, 1);\n // 重新调整 id\n settings.channels.forEach((item, i) => {\n item.id = i + 1;\n });\n // 自动保存\n this.saveSettings();\n }).catch(() => {});\n },\n saveSettings() {\n // 保存设置\n const settings = {\n telegram: this.telegramSettings,\n cfr2: this.cfr2Settings,\n s3: this.s3Settings,\n discord: this.discordSettings,\n huggingface: this.huggingfaceSettings\n };\n fetchWithAuth('/api/manage/sysConfig/upload', {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json'\n },\n body: JSON.stringify(settings)\n }).then(() => {\n this.$message.success('设置已保存');\n });\n },\n // 获取容量统计(重新计算)\n async refreshQuota() {\n this.quotaLoading = true;\n try {\n // 使用 POST 请求重新统计容量(会触发索引重建)\n const response = await fetchWithAuth('/api/manage/quota', {\n method: 'POST'\n });\n const data = await response.json();\n if (data.success) {\n this.quotaStats = data.channelStats || {};\n } else {\n // 如果重新统计失败,尝试获取已有数据\n const getResponse = await fetchWithAuth('/api/manage/quota');\n const getData = await getResponse.json();\n if (getData.success) {\n this.quotaStats = getData.quotaStats || {};\n }\n }\n } catch (error) {\n console.error('Failed to refresh quota stats:', error);\n } finally {\n this.quotaLoading = false;\n }\n },\n // 获取容量统计(仅读取,不重建索引)\n async loadQuotaStats() {\n try {\n const response = await fetchWithAuth('/api/manage/quota');\n const data = await response.json();\n if (data.success) {\n this.quotaStats = data.quotaStats || {};\n }\n } catch (error) {\n console.error('Failed to load quota stats:', error);\n }\n },\n // 获取渠道已用容量 (GB)\n getChannelUsedGB(channel) {\n const stats = this.quotaStats[channel.name];\n if (!stats) return 0;\n return (stats.usedMB || 0) / 1024;\n },\n // 获取容量百分比\n getQuotaPercentage(channel) {\n const usedGB = this.getChannelUsedGB(channel);\n const limitGB = channel.quota?.limitGB || 10;\n const percentage = usedGB / limitGB * 100;\n return Math.min(100, Math.round(percentage * 10) / 10);\n },\n // 获取进度条状态\n getQuotaStatus(channel) {\n const percentage = this.getQuotaPercentage(channel);\n const threshold = channel.quota?.threshold || 95;\n if (percentage >= threshold) return 'exception';\n if (percentage >= 80) return 'warning';\n return 'success';\n },\n // 获取容量文本\n getQuotaText(channel) {\n const usedGB = this.getChannelUsedGB(channel);\n const limitGB = channel.quota?.limitGB || 10;\n return `${usedGB.toFixed(2)} / ${limitGB} GB`;\n },\n // 判断是否超过阈值\n isQuotaExceeded(channel) {\n const percentage = this.getQuotaPercentage(channel);\n const threshold = channel.quota?.threshold || 95;\n return percentage >= threshold;\n },\n // 获取状态文本\n getQuotaStatusText(channel) {\n const percentage = this.getQuotaPercentage(channel);\n const threshold = channel.quota?.threshold || 95;\n if (percentage >= threshold) {\n return `⚠️ 已达到容量阈值 (${threshold}%),渠道写入已暂停`;\n }\n if (percentage >= 80) {\n return `⚡ 容量使用较高,接近阈值`;\n }\n return `✓ 容量正常`;\n },\n // 容量限制开关变化时\n async onQuotaEnabledChange(enabled, channel) {\n if (enabled && channel.name) {\n // 首次启用时,检查是否有该渠道的统计数据\n const stats = this.quotaStats[channel.name];\n if (!stats) {\n // 没有统计数据,提示用户需要重新统计\n this.$confirm('首次启用容量限制需要统计现有文件容量,这可能需要一些时间。是否立即统计?', '初始化容量统计', {\n confirmButtonText: '立即统计',\n cancelButtonText: '稍后手动统计',\n type: 'info'\n }).then(async () => {\n await this.recalculateQuota();\n }).catch(() => {\n this.$message.info('您可以稍后点击刷新按钮手动统计');\n });\n }\n }\n },\n // 重新统计容量\n async recalculateQuota() {\n this.quotaLoading = true;\n try {\n this.$message.info('正在统计容量,请稍候...');\n const response = await fetchWithAuth('/api/manage/quota', {\n method: 'POST'\n });\n const data = await response.json();\n if (data.success) {\n this.quotaStats = data.channelStats || {};\n this.$message.success('容量统计完成');\n } else {\n this.$message.error('统计失败: ' + (data.error || '未知错误'));\n }\n } catch (error) {\n console.error('Failed to recalculate quota:', error);\n this.$message.error('统计失败');\n } finally {\n this.quotaLoading = false;\n }\n }\n },\n mounted() {\n this.loading = true;\n // 获取上传设置\n fetchWithAuth('/api/manage/sysConfig/upload').then(response => response.json()).then(data => {\n this.telegramSettings = data.telegram;\n // 确保 R2 渠道有 quota 默认值\n if (data.cfr2 && data.cfr2.channels) {\n data.cfr2.channels = data.cfr2.channels.map(channel => ({\n ...channel,\n quota: channel.quota || {\n enabled: false,\n limitGB: 10,\n threshold: 95\n }\n }));\n }\n this.cfr2Settings = data.cfr2;\n // 确保 S3 渠道有 quota 默认值\n if (data.s3 && data.s3.channels) {\n data.s3.channels = data.s3.channels.map(channel => ({\n ...channel,\n quota: channel.quota || {\n enabled: false,\n limitGB: 10,\n threshold: 95\n }\n }));\n }\n this.s3Settings = data.s3;\n // 确保 Discord 渠道有默认值\n if (data.discord && data.discord.channels) {\n data.discord.channels = data.discord.channels.map(channel => ({\n ...channel,\n proxyUrl: channel.proxyUrl || ''\n }));\n }\n this.discordSettings = data.discord || {\n loadBalance: {},\n channels: []\n };\n // 确保 HuggingFace 渠道有默认值\n if (data.huggingface && data.huggingface.channels) {\n data.huggingface.channels = data.huggingface.channels.map(channel => ({\n ...channel,\n isPrivate: channel.isPrivate || false\n }));\n }\n this.huggingfaceSettings = data.huggingface || {\n loadBalance: {},\n channels: []\n };\n // 加载容量统计(仅读取,不重建索引)\n this.loadQuotaStats();\n }).finally(() => {\n this.loading = false;\n });\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./SysCogUpload.vue?vue&type=template&id=89234e52&scoped=true\"\nimport script from \"./SysCogUpload.vue?vue&type=script&lang=js\"\nexport * from \"./SysCogUpload.vue?vue&type=script&lang=js\"\n\nimport \"./SysCogUpload.vue?vue&type=style&index=0&id=89234e52&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-89234e52\"]])\n\nexport default __exports__","import { resolveComponent as _resolveComponent, openBlock as _openBlock, createBlock as _createBlock, createCommentVNode as _createCommentVNode, toDisplayString as _toDisplayString, createElementVNode as _createElementVNode, vShow as _vShow, normalizeClass as _normalizeClass, withDirectives as _withDirectives, Transition as _Transition, withCtx as _withCtx } from \"vue\";\nconst _hoisted_1 = {\n class: \"save-text\"\n};\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n return _openBlock(), _createBlock(_Transition, {\n name: \"fade-up\"\n }, {\n default: _withCtx(() => [_withDirectives(_createElementVNode(\"div\", {\n class: _normalizeClass([\"floating-save-btn\", {\n 'is-loading': $props.loading\n }]),\n onClick: _cache[0] || (_cache[0] = (...args) => $options.handleClick && $options.handleClick(...args))\n }, [$props.loading ? (_openBlock(), _createBlock(_component_font_awesome_icon, {\n key: 0,\n icon: \"spinner\",\n spin: \"\"\n })) : (_openBlock(), _createBlock(_component_font_awesome_icon, {\n key: 1,\n icon: \"save\"\n })), _createElementVNode(\"span\", _hoisted_1, _toDisplayString($props.loading ? '保存中' : '保存'), 1)], 2), [[_vShow, $data.visible]])]),\n _: 1\n });\n}","export default {\n name: 'FloatingSaveButton',\n props: {\n loading: {\n type: Boolean,\n default: false\n },\n show: {\n type: Boolean,\n default: true\n }\n },\n data() {\n return {\n visible: false\n };\n },\n watch: {\n show: {\n immediate: true,\n handler(val) {\n if (val) {\n // 延迟显示,等待 Element Plus 加载遮罩淡出动画完成\n setTimeout(() => {\n this.visible = true;\n }, 600);\n } else {\n this.visible = false;\n }\n }\n }\n },\n methods: {\n handleClick() {\n if (!this.loading) {\n this.$emit('click');\n }\n }\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./FloatingSaveButton.vue?vue&type=template&id=27fc6cc8&scoped=true\"\nimport script from \"./FloatingSaveButton.vue?vue&type=script&lang=js\"\nexport * from \"./FloatingSaveButton.vue?vue&type=script&lang=js\"\n\nimport \"./FloatingSaveButton.vue?vue&type=style&index=0&id=27fc6cc8&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-27fc6cc8\"]])\n\nexport default __exports__","import { createElementVNode as _createElementVNode, resolveComponent as _resolveComponent, createVNode as _createVNode, withCtx as _withCtx, openBlock as _openBlock, createBlock as _createBlock, createCommentVNode as _createCommentVNode, Transition as _Transition, createTextVNode as _createTextVNode, toDisplayString as _toDisplayString, renderList as _renderList, Fragment as _Fragment, createElementBlock as _createElementBlock, resolveDirective as _resolveDirective, withDirectives as _withDirectives } from \"vue\";\nconst _hoisted_1 = {\n class: \"security-settings\"\n};\nconst _hoisted_2 = {\n class: \"first-settings\"\n};\nconst _hoisted_3 = {\n class: \"second-title token-title\"\n};\nconst _hoisted_4 = {\n class: \"token-actions\"\n};\nconst _hoisted_5 = {\n class: \"token-table-container\"\n};\nconst _hoisted_6 = {\n class: \"table-cell-content\"\n};\nconst _hoisted_7 = {\n class: \"table-cell-content\"\n};\nconst _hoisted_8 = {\n class: \"token-display\"\n};\nconst _hoisted_9 = {\n class: \"table-cell-content\"\n};\nconst _hoisted_10 = {\n class: \"table-cell-content\"\n};\nconst _hoisted_11 = {\n class: \"table-cell-content action-buttons\"\n};\nconst _hoisted_12 = {\n class: \"first-settings\"\n};\nconst _hoisted_13 = {\n class: \"second-title\"\n};\nconst _hoisted_14 = {\n class: \"first-settings\"\n};\nconst _hoisted_15 = {\n class: \"dialog-footer\"\n};\nconst _hoisted_16 = {\n class: \"dialog-footer\"\n};\nconst _hoisted_17 = {\n class: \"token-result\"\n};\nconst _hoisted_18 = {\n style: {\n \"margin-bottom\": \"15px\",\n \"color\": \"#e6a23c\"\n }\n};\nconst _hoisted_19 = {\n class: \"dialog-footer\"\n};\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_el_input = _resolveComponent(\"el-input\");\n const _component_el_form_item = _resolveComponent(\"el-form-item\");\n const _component_el_form = _resolveComponent(\"el-form\");\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n const _component_el_button = _resolveComponent(\"el-button\");\n const _component_el_table_column = _resolveComponent(\"el-table-column\");\n const _component_el_tag = _resolveComponent(\"el-tag\");\n const _component_el_table = _resolveComponent(\"el-table\");\n const _component_el_tooltip = _resolveComponent(\"el-tooltip\");\n const _component_el_switch = _resolveComponent(\"el-switch\");\n const _component_el_option = _resolveComponent(\"el-option\");\n const _component_el_select = _resolveComponent(\"el-select\");\n const _component_FloatingSaveButton = _resolveComponent(\"FloatingSaveButton\");\n const _component_el_checkbox = _resolveComponent(\"el-checkbox\");\n const _component_el_checkbox_group = _resolveComponent(\"el-checkbox-group\");\n const _component_el_dialog = _resolveComponent(\"el-dialog\");\n const _directive_loading = _resolveDirective(\"loading\");\n return _withDirectives((_openBlock(), _createElementBlock(\"div\", _hoisted_1, [_createElementVNode(\"div\", _hoisted_2, [_cache[26] || (_cache[26] = _createElementVNode(\"h3\", {\n class: \"first-title\"\n }, \"认证管理\", -1)), _cache[27] || (_cache[27] = _createElementVNode(\"h4\", {\n class: \"second-title\"\n }, \"用户端认证\", -1)), _createVNode(_component_el_form, {\n model: $data.authSettings.user,\n rules: $data.userPassRules,\n ref: \"userPassForm\",\n \"label-width\": \"120px\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_form_item, {\n label: \"上传密码\",\n prop: \"authCode\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.authSettings.user.authCode,\n \"onUpdate:modelValue\": _cache[0] || (_cache[0] = $event => $data.authSettings.user.authCode = $event),\n type: \"password\",\n \"show-password\": \"\",\n onInput: $options.handleUserPassInput,\n autocomplete: \"new-password\"\n }, null, 8, [\"modelValue\", \"onInput\"])]),\n _: 1\n }), _createVNode(_Transition, {\n name: \"fade-slide\",\n mode: \"out-in\"\n }, {\n default: _withCtx(() => [$data.showUserPassConfirm ? (_openBlock(), _createBlock(_component_el_form_item, {\n label: \"确认密码\",\n prop: \"confirmNewUserPassword\",\n key: \"user-confirm\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.authSettings.user.confirmNewUserPassword,\n \"onUpdate:modelValue\": _cache[1] || (_cache[1] = $event => $data.authSettings.user.confirmNewUserPassword = $event),\n type: \"password\",\n \"show-password\": \"\",\n autocomplete: \"new-password\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n })) : _createCommentVNode(\"\", true)]),\n _: 1\n })]),\n _: 1\n }, 8, [\"model\", \"rules\"]), _cache[28] || (_cache[28] = _createElementVNode(\"h4\", {\n class: \"second-title\"\n }, \"管理端认证\", -1)), _createVNode(_component_el_form, {\n model: $data.authSettings.admin,\n rules: $data.adminPassRules,\n ref: \"adminPassForm\",\n \"label-width\": \"120px\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_form_item, {\n label: \"用户名\",\n prop: \"adminUsername\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.authSettings.admin.adminUsername,\n \"onUpdate:modelValue\": _cache[2] || (_cache[2] = $event => $data.authSettings.admin.adminUsername = $event),\n autocomplete: \"new-password\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"密码\",\n prop: \"adminPassword\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.authSettings.admin.adminPassword,\n \"onUpdate:modelValue\": _cache[3] || (_cache[3] = $event => $data.authSettings.admin.adminPassword = $event),\n type: \"password\",\n \"show-password\": \"\",\n onInput: $options.handleAdminPassInput,\n autocomplete: \"new-password\"\n }, null, 8, [\"modelValue\", \"onInput\"])]),\n _: 1\n }), _createVNode(_Transition, {\n name: \"fade-slide\",\n mode: \"out-in\"\n }, {\n default: _withCtx(() => [$data.showAdminPassConfirm ? (_openBlock(), _createBlock(_component_el_form_item, {\n label: \"确认密码\",\n prop: \"confirmNewAdminPassword\",\n key: \"admin-confirm\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.authSettings.admin.confirmNewAdminPassword,\n \"onUpdate:modelValue\": _cache[4] || (_cache[4] = $event => $data.authSettings.admin.confirmNewAdminPassword = $event),\n type: \"password\",\n \"show-password\": \"\",\n autocomplete: \"new-password\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n })) : _createCommentVNode(\"\", true)]),\n _: 1\n })]),\n _: 1\n }, 8, [\"model\", \"rules\"]), _createElementVNode(\"h4\", _hoisted_3, [_cache[23] || (_cache[23] = _createTextVNode(\"API Token 管理 \", -1)), _createElementVNode(\"a\", _hoisted_4, [_createVNode(_component_el_button, {\n type: \"primary\",\n size: \"small\",\n onClick: _cache[5] || (_cache[5] = $event => $data.showCreateTokenDialog = true),\n circle: \"\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"plus\"\n })]),\n _: 1\n })])]), _createElementVNode(\"div\", _hoisted_5, [_withDirectives((_openBlock(), _createBlock(_component_el_table, {\n data: $data.apiTokens,\n class: \"token-table\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_table_column, {\n prop: \"name\",\n label: \"名称\",\n \"header-align\": \"center\"\n }, {\n default: _withCtx(scope => [_createElementVNode(\"div\", _hoisted_6, _toDisplayString(scope.row.name), 1)]),\n _: 1\n }), _createVNode(_component_el_table_column, {\n prop: \"token\",\n label: \"Token\",\n \"header-align\": \"center\"\n }, {\n default: _withCtx(scope => [_createElementVNode(\"div\", _hoisted_7, [_createElementVNode(\"span\", _hoisted_8, _toDisplayString(scope.row.token), 1)])]),\n _: 1\n }), _createVNode(_component_el_table_column, {\n prop: \"permissions\",\n label: \"权限\",\n \"header-align\": \"center\"\n }, {\n default: _withCtx(scope => [_createElementVNode(\"div\", _hoisted_9, [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList(scope.row.permissions, perm => {\n return _openBlock(), _createBlock(_component_el_tag, {\n key: perm,\n size: \"small\",\n class: \"permission-tag\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($options.getPermissionText(perm)), 1)]),\n _: 2\n }, 1024);\n }), 128))])]),\n _: 1\n }), _createVNode(_component_el_table_column, {\n prop: \"createdAt\",\n label: \"创建时间\",\n \"header-align\": \"center\"\n }, {\n default: _withCtx(scope => [_createElementVNode(\"div\", _hoisted_10, _toDisplayString($options.formatDate(scope.row.createdAt)), 1)]),\n _: 1\n }), _createVNode(_component_el_table_column, {\n label: \"操作\",\n fixed: \"right\",\n \"header-align\": \"center\"\n }, {\n default: _withCtx(scope => [_createElementVNode(\"div\", _hoisted_11, [_createVNode(_component_el_button, {\n class: \"action-button\",\n size: \"small\",\n onClick: $event => $options.editToken(scope.row)\n }, {\n default: _withCtx(() => [...(_cache[24] || (_cache[24] = [_createTextVNode(\"编辑\", -1)]))]),\n _: 1\n }, 8, [\"onClick\"]), _createVNode(_component_el_button, {\n class: \"action-button\",\n size: \"small\",\n type: \"danger\",\n onClick: $event => $options.deleteToken(scope.row.id)\n }, {\n default: _withCtx(() => [...(_cache[25] || (_cache[25] = [_createTextVNode(\"删除\", -1)]))]),\n _: 1\n }, 8, [\"onClick\"])])]),\n _: 1\n })]),\n _: 1\n }, 8, [\"data\"])), [[_directive_loading, $data.tokenLoading]])])]), _createElementVNode(\"div\", _hoisted_12, [_cache[30] || (_cache[30] = _createElementVNode(\"h3\", {\n class: \"first-title\"\n }, \"上传管理\", -1)), _createElementVNode(\"h4\", _hoisted_13, [_cache[29] || (_cache[29] = _createTextVNode(\"图像审查 \", -1)), _createVNode(_component_el_tooltip, {\n content: \"仅对非分块上传文件生效,支持 nsfwjs 和 moderatecontent.com 渠道\",\n placement: \"top\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"question-circle\",\n style: {\n \"margin-left\": \"5px\",\n \"cursor\": \"pointer\"\n }\n })]),\n _: 1\n })]), _createVNode(_component_el_form, {\n model: $data.uploadSettings.moderate,\n \"label-width\": \"120px\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_form_item, {\n label: \"开启审查\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_switch, {\n modelValue: $data.uploadSettings.moderate.enabled,\n \"onUpdate:modelValue\": _cache[6] || (_cache[6] = $event => $data.uploadSettings.moderate.enabled = $event)\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"审查渠道\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_select, {\n modelValue: $data.uploadSettings.moderate.channel,\n \"onUpdate:modelValue\": _cache[7] || (_cache[7] = $event => $data.uploadSettings.moderate.channel = $event),\n placeholder: \"请选择审查渠道\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_option, {\n label: \"moderatecontent.com\",\n value: \"moderatecontent.com\"\n }), _createVNode(_component_el_option, {\n label: \"nsfwjs\",\n value: \"nsfwjs\"\n })]),\n _: 1\n }, 8, [\"modelValue\"])]),\n _: 1\n }), $data.uploadSettings.moderate.channel === 'moderatecontent.com' ? (_openBlock(), _createBlock(_component_el_form_item, {\n key: 0,\n label: \"API Key\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.uploadSettings.moderate.moderateContentApiKey,\n \"onUpdate:modelValue\": _cache[8] || (_cache[8] = $event => $data.uploadSettings.moderate.moderateContentApiKey = $event)\n }, null, 8, [\"modelValue\"])]),\n _: 1\n })) : _createCommentVNode(\"\", true), $data.uploadSettings.moderate.channel === 'nsfwjs' ? (_openBlock(), _createBlock(_component_el_form_item, {\n key: 1,\n label: \"API 路径\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.uploadSettings.moderate.nsfwApiPath,\n \"onUpdate:modelValue\": _cache[9] || (_cache[9] = $event => $data.uploadSettings.moderate.nsfwApiPath = $event),\n placeholder: \"https://nsfwjs.your.domain\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n })) : _createCommentVNode(\"\", true)]),\n _: 1\n }, 8, [\"model\"])]), _createElementVNode(\"div\", _hoisted_14, [_cache[33] || (_cache[33] = _createElementVNode(\"h3\", {\n class: \"first-title\"\n }, \"访问管理\", -1)), _cache[34] || (_cache[34] = _createElementVNode(\"h4\", {\n class: \"second-title\"\n }, \"域名过滤\", -1)), _createVNode(_component_el_form, {\n model: $data.accessSettings,\n \"label-width\": \"120px\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_form_item, null, {\n label: _withCtx(() => [_cache[31] || (_cache[31] = _createTextVNode(\" 放行域名 \", -1)), _createVNode(_component_el_tooltip, {\n content: \"1.针对访问域名设置权限
2.留空默认全部放行,多个域名请用英文逗号分隔\",\n placement: \"top\",\n \"raw-content\": \"\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"question-circle\",\n style: {\n \"margin-left\": \"5px\",\n \"cursor\": \"pointer\"\n }\n })]),\n _: 1\n })]),\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.accessSettings.allowedDomains,\n \"onUpdate:modelValue\": _cache[10] || (_cache[10] = $event => $data.accessSettings.allowedDomains = $event)\n }, null, 8, [\"modelValue\"])]),\n _: 1\n })]),\n _: 1\n }, 8, [\"model\"]), _cache[35] || (_cache[35] = _createElementVNode(\"h4\", {\n class: \"second-title\"\n }, \"白名单模式\", -1)), _createVNode(_component_el_form, {\n model: $data.accessSettings,\n \"label-width\": \"120px\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_form_item, null, {\n label: _withCtx(() => [_cache[32] || (_cache[32] = _createTextVNode(\" 是否开启 \", -1)), _createVNode(_component_el_tooltip, {\n content: \"1.针对文件设置权限
2.开启后,仅被加入白名单的文件可被访问\",\n placement: \"top\",\n \"raw-content\": \"\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"question-circle\",\n style: {\n \"margin-left\": \"5px\",\n \"cursor\": \"pointer\"\n }\n })]),\n _: 1\n })]),\n default: _withCtx(() => [_createVNode(_component_el_switch, {\n modelValue: $data.accessSettings.whiteListMode,\n \"onUpdate:modelValue\": _cache[11] || (_cache[11] = $event => $data.accessSettings.whiteListMode = $event)\n }, null, 8, [\"modelValue\"])]),\n _: 1\n })]),\n _: 1\n }, 8, [\"model\"])]), _createVNode(_component_FloatingSaveButton, {\n show: !$data.loading,\n onClick: $options.saveSettings\n }, null, 8, [\"show\", \"onClick\"]), _createVNode(_component_el_dialog, {\n modelValue: $data.showCreateTokenDialog,\n \"onUpdate:modelValue\": _cache[15] || (_cache[15] = $event => $data.showCreateTokenDialog = $event),\n title: \"创建新 API Token\",\n width: $options.dialogWidth\n }, {\n footer: _withCtx(() => [_createElementVNode(\"span\", _hoisted_15, [_createVNode(_component_el_button, {\n onClick: _cache[14] || (_cache[14] = $event => $data.showCreateTokenDialog = false)\n }, {\n default: _withCtx(() => [...(_cache[39] || (_cache[39] = [_createTextVNode(\"取消\", -1)]))]),\n _: 1\n }), _createVNode(_component_el_button, {\n type: \"primary\",\n onClick: $options.createToken\n }, {\n default: _withCtx(() => [...(_cache[40] || (_cache[40] = [_createTextVNode(\"创建\", -1)]))]),\n _: 1\n }, 8, [\"onClick\"])])]),\n default: _withCtx(() => [_createVNode(_component_el_form, {\n model: $data.newToken,\n rules: $data.tokenRules,\n ref: \"tokenForm\",\n \"label-width\": \"100px\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_form_item, {\n label: \"Token 名称\",\n prop: \"name\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.newToken.name,\n \"onUpdate:modelValue\": _cache[12] || (_cache[12] = $event => $data.newToken.name = $event),\n placeholder: \"请输入Token名称\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"权限\",\n prop: \"permissions\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_checkbox_group, {\n modelValue: $data.newToken.permissions,\n \"onUpdate:modelValue\": _cache[13] || (_cache[13] = $event => $data.newToken.permissions = $event)\n }, {\n default: _withCtx(() => [_createVNode(_component_el_checkbox, {\n label: \"upload\"\n }, {\n default: _withCtx(() => [...(_cache[36] || (_cache[36] = [_createTextVNode(\"上传\", -1)]))]),\n _: 1\n }), _createVNode(_component_el_checkbox, {\n label: \"delete\"\n }, {\n default: _withCtx(() => [...(_cache[37] || (_cache[37] = [_createTextVNode(\"删除\", -1)]))]),\n _: 1\n }), _createVNode(_component_el_checkbox, {\n label: \"list\"\n }, {\n default: _withCtx(() => [...(_cache[38] || (_cache[38] = [_createTextVNode(\"列出\", -1)]))]),\n _: 1\n })]),\n _: 1\n }, 8, [\"modelValue\"])]),\n _: 1\n })]),\n _: 1\n }, 8, [\"model\", \"rules\"])]),\n _: 1\n }, 8, [\"modelValue\", \"width\"]), _createVNode(_component_el_dialog, {\n modelValue: $data.showEditTokenDialog,\n \"onUpdate:modelValue\": _cache[19] || (_cache[19] = $event => $data.showEditTokenDialog = $event),\n title: \"编辑 API Token\",\n width: $options.dialogWidth\n }, {\n footer: _withCtx(() => [_createElementVNode(\"span\", _hoisted_16, [_createVNode(_component_el_button, {\n onClick: _cache[18] || (_cache[18] = $event => $data.showEditTokenDialog = false)\n }, {\n default: _withCtx(() => [...(_cache[44] || (_cache[44] = [_createTextVNode(\"取消\", -1)]))]),\n _: 1\n }), _createVNode(_component_el_button, {\n type: \"primary\",\n onClick: $options.updateToken\n }, {\n default: _withCtx(() => [...(_cache[45] || (_cache[45] = [_createTextVNode(\"更新\", -1)]))]),\n _: 1\n }, 8, [\"onClick\"])])]),\n default: _withCtx(() => [_createVNode(_component_el_form, {\n model: $data.editingToken,\n rules: $data.tokenRules,\n ref: \"editTokenForm\",\n \"label-width\": \"100px\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_form_item, {\n label: \"Token 名称\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.editingToken.name,\n \"onUpdate:modelValue\": _cache[16] || (_cache[16] = $event => $data.editingToken.name = $event),\n disabled: \"\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"权限\",\n prop: \"permissions\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_checkbox_group, {\n modelValue: $data.editingToken.permissions,\n \"onUpdate:modelValue\": _cache[17] || (_cache[17] = $event => $data.editingToken.permissions = $event)\n }, {\n default: _withCtx(() => [_createVNode(_component_el_checkbox, {\n label: \"upload\"\n }, {\n default: _withCtx(() => [...(_cache[41] || (_cache[41] = [_createTextVNode(\"上传\", -1)]))]),\n _: 1\n }), _createVNode(_component_el_checkbox, {\n label: \"delete\"\n }, {\n default: _withCtx(() => [...(_cache[42] || (_cache[42] = [_createTextVNode(\"删除\", -1)]))]),\n _: 1\n }), _createVNode(_component_el_checkbox, {\n label: \"list\"\n }, {\n default: _withCtx(() => [...(_cache[43] || (_cache[43] = [_createTextVNode(\"列出\", -1)]))]),\n _: 1\n })]),\n _: 1\n }, 8, [\"modelValue\"])]),\n _: 1\n })]),\n _: 1\n }, 8, [\"model\", \"rules\"])]),\n _: 1\n }, 8, [\"modelValue\", \"width\"]), _createVNode(_component_el_dialog, {\n modelValue: $data.showTokenResultDialog,\n \"onUpdate:modelValue\": _cache[22] || (_cache[22] = $event => $data.showTokenResultDialog = $event),\n title: \"Token 创建成功\",\n width: $options.dialogWidth\n }, {\n footer: _withCtx(() => [_createElementVNode(\"span\", _hoisted_19, [_createVNode(_component_el_button, {\n type: \"primary\",\n onClick: _cache[21] || (_cache[21] = $event => $data.showTokenResultDialog = false)\n }, {\n default: _withCtx(() => [...(_cache[48] || (_cache[48] = [_createTextVNode(\"我已保存\", -1)]))]),\n _: 1\n })])]),\n default: _withCtx(() => [_createElementVNode(\"div\", _hoisted_17, [_createElementVNode(\"p\", _hoisted_18, [_createVNode(_component_font_awesome_icon, {\n icon: \"exclamation-triangle\",\n style: {\n \"margin-right\": \"5px\"\n }\n }), _cache[46] || (_cache[46] = _createTextVNode(\" 请妥善保存以下Token,关闭此窗口后将无法再次查看完整Token! \", -1))]), _createVNode(_component_el_form, {\n \"label-width\": \"100px\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_form_item, {\n label: \"Token 名称\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"span\", null, _toDisplayString($data.createdToken.name), 1)]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"完整Token\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.createdToken.token,\n \"onUpdate:modelValue\": _cache[20] || (_cache[20] = $event => $data.createdToken.token = $event),\n readonly: \"\"\n }, {\n append: _withCtx(() => [_createVNode(_component_el_button, {\n onClick: $options.copyToken\n }, {\n default: _withCtx(() => [...(_cache[47] || (_cache[47] = [_createTextVNode(\"复制\", -1)]))]),\n _: 1\n }, 8, [\"onClick\"])]),\n _: 1\n }, 8, [\"modelValue\"])]),\n _: 1\n })]),\n _: 1\n })])]),\n _: 1\n }, 8, [\"modelValue\", \"width\"])])), [[_directive_loading, $data.loading]]);\n}","import \"core-js/modules/es.array.push.js\";\nimport \"core-js/modules/es.iterator.constructor.js\";\nimport \"core-js/modules/es.iterator.every.js\";\nimport \"core-js/modules/es.json.stringify.js\";\nimport fetchWithAuth from '@/utils/fetchWithAuth';\nimport FloatingSaveButton from '@/components/FloatingSaveButton.vue';\nexport default {\n components: {\n FloatingSaveButton\n },\n data() {\n return {\n authSettings: {\n user: {},\n admin: {}\n },\n uploadSettings: {\n moderate: {}\n },\n accessSettings: {},\n apiTokens: [],\n // API Token列表\n // 加载状态\n loading: true,\n tokenLoading: false,\n // 修改密码相关\n oriUserPassword: '',\n // 原上传密码\n oriAdminPassword: '',\n // 原管理端密码\n\n showUserPassConfirm: false,\n // 显示用户密码确认框\n showAdminPassConfirm: false,\n // 显示管理密码确认框\n\n // Token对话框相关\n showCreateTokenDialog: false,\n showEditTokenDialog: false,\n showTokenResultDialog: false,\n newToken: {\n name: '',\n owner: '',\n permissions: []\n },\n editingToken: {\n id: '',\n name: '',\n owner: '',\n permissions: []\n },\n createdToken: {\n name: '',\n token: ''\n },\n userPassRules: {\n authCode: [{\n validator: (rule, value, callback) => {\n // URL保留字符列表\n const urlReservedChars = ['%', '&', '?', '#', '/'];\n const hasReservedChar = urlReservedChars.some(char => value && value.includes(char));\n if (hasReservedChar) {\n callback(new Error('密码不能包含部分URL保留字符: % & ? # /'));\n } else {\n callback();\n }\n },\n trigger: 'blur'\n }],\n confirmNewUserPassword: [{\n message: '请再次输入上传密码',\n trigger: 'blur'\n }, {\n validator: (rule, value, callback) => {\n if (value && value !== this.authSettings.user.authCode) {\n callback(new Error('两次输入密码不一致'));\n } else {\n callback();\n }\n },\n trigger: 'blur'\n }]\n },\n adminPassRules: {\n confirmNewAdminPassword: [{\n message: '请再次输入管理密码',\n trigger: 'blur'\n }, {\n validator: (rule, value, callback) => {\n if (value && value !== this.authSettings.admin.adminPassword) {\n callback(new Error('两次输入密码不一致'));\n } else {\n callback();\n }\n },\n trigger: 'blur'\n }]\n },\n tokenRules: {\n name: [{\n required: true,\n message: '请输入Token名称',\n trigger: 'blur'\n }],\n permissions: [{\n required: true,\n message: '请选择权限',\n trigger: 'change'\n }]\n }\n };\n },\n computed: {\n dialogWidth() {\n return window.innerWidth > 768 ? '50%' : '90%';\n }\n },\n methods: {\n handleUserPassInput() {\n if (this.authSettings.user.authCode !== this.oriUserPassword) {\n this.showUserPassConfirm = true;\n } else {\n this.showUserPassConfirm = false;\n }\n },\n handleAdminPassInput() {\n if (this.authSettings.admin.adminPassword !== this.oriAdminPassword) {\n this.showAdminPassConfirm = true;\n } else {\n this.showAdminPassConfirm = false;\n }\n },\n // Token相关方法\n getPermissionText(permission) {\n const permissionMap = {\n 'upload': '上传',\n 'delete': '删除',\n 'list': '列出'\n };\n return permissionMap[permission] || permission;\n },\n formatDate(dateString) {\n return new Date(dateString).toLocaleString('zh-CN');\n },\n async loadApiTokens() {\n this.tokenLoading = true;\n try {\n const response = await fetchWithAuth('/api/manage/apiTokens');\n const data = await response.json();\n this.apiTokens = data.tokens || [];\n } catch (error) {\n this.$message.error('获取Token列表失败');\n } finally {\n this.tokenLoading = false;\n }\n },\n createToken() {\n this.$refs.tokenForm.validate(async valid => {\n if (!valid) return;\n try {\n this.newToken.owner = 'admin'; // 默认所有Token归属管理员\n const response = await fetchWithAuth('/api/manage/apiTokens', {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json'\n },\n body: JSON.stringify(this.newToken)\n });\n const data = await response.json();\n if (response.ok) {\n this.createdToken = {\n name: data.name,\n token: data.token\n };\n this.showCreateTokenDialog = false;\n this.showTokenResultDialog = true;\n this.newToken = {\n name: '',\n owner: '',\n permissions: []\n };\n await this.loadApiTokens();\n this.$message.success('Token创建成功');\n } else {\n this.$message.error(data.error || 'Token创建失败');\n }\n } catch (error) {\n this.$message.error('Token创建失败');\n }\n });\n },\n editToken(token) {\n this.editingToken = {\n id: token.id,\n name: token.name,\n owner: token.owner,\n permissions: [...token.permissions]\n };\n this.showEditTokenDialog = true;\n },\n updateToken() {\n this.$refs.editTokenForm.validate(async valid => {\n if (!valid) return;\n try {\n const response = await fetchWithAuth('/api/manage/apiTokens', {\n method: 'PUT',\n headers: {\n 'Content-Type': 'application/json'\n },\n body: JSON.stringify({\n tokenId: this.editingToken.id,\n permissions: this.editingToken.permissions\n })\n });\n const data = await response.json();\n if (response.ok) {\n this.showEditTokenDialog = false;\n await this.loadApiTokens();\n this.$message.success('Token权限更新成功');\n } else {\n this.$message.error(data.error || 'Token更新失败');\n }\n } catch (error) {\n this.$message.error('Token更新失败');\n }\n });\n },\n async deleteToken(tokenId) {\n try {\n await this.$confirm('此操作将永久删除该Token,是否继续?', '提示', {\n confirmButtonText: '确定',\n cancelButtonText: '取消',\n type: 'warning'\n });\n const response = await fetchWithAuth(`/api/manage/apiTokens?id=${tokenId}`, {\n method: 'DELETE'\n });\n const data = await response.json();\n if (response.ok) {\n await this.loadApiTokens();\n this.$message.success('Token删除成功');\n } else {\n this.$message.error(data.error || 'Token删除失败');\n }\n } catch (error) {\n if (error !== 'cancel') {\n this.$message.error('Token删除失败');\n }\n }\n },\n async copyToken() {\n try {\n await navigator.clipboard.writeText(this.createdToken.token);\n this.$message.success('Token已复制到剪贴板');\n } catch (error) {\n this.$message.error('复制失败,请手动复制');\n }\n },\n saveSettings() {\n // 所有表单的Promise数组\n let validationPromises = [];\n\n // 验证用户密码表单\n validationPromises.push(new Promise(resolve => {\n this.$refs.userPassForm.validate(valid => {\n resolve(valid);\n });\n }));\n\n // 验证管理密码表单\n validationPromises.push(new Promise(resolve => {\n this.$refs.adminPassForm.validate(valid => {\n resolve(valid);\n });\n }));\n\n // 等待所有验证完成\n Promise.all(validationPromises).then(results => {\n const isValid = results.every(valid => valid);\n if (!isValid) {\n return;\n }\n const settings = {\n auth: this.authSettings,\n upload: this.uploadSettings,\n access: this.accessSettings\n };\n // 不保存确认密码相关字段\n delete settings.auth.user.confirmNewUserPassword;\n delete settings.auth.admin.confirmNewAdminPassword;\n fetchWithAuth('/api/manage/sysConfig/security', {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json'\n },\n body: JSON.stringify(settings)\n }).then(() => {\n this.$message.success('设置已保存');\n // 更新原密码\n this.oriUserPassword = this.authSettings.user.authCode;\n this.oriAdminPassword = this.authSettings.admin.adminPassword;\n this.showUserPassConfirm = false;\n this.showAdminPassConfirm = false;\n });\n });\n }\n },\n mounted() {\n this.loading = true;\n // 获取上传设置\n fetchWithAuth('/api/manage/sysConfig/security').then(response => response.json()).then(data => {\n this.authSettings = data.auth;\n this.uploadSettings = data.upload;\n this.accessSettings = data.access;\n\n // 保存原密码\n this.oriUserPassword = this.authSettings.user.authCode;\n this.oriAdminPassword = this.authSettings.admin.adminPassword;\n this.authSettings.user.confirmNewUserPassword = '';\n this.authSettings.admin.confirmNewAdminPassword = '';\n\n // 加载API Token列表\n this.loadApiTokens();\n }).finally(() => {\n this.loading = false;\n });\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./SysCogSecurity.vue?vue&type=template&id=fdf607e4&scoped=true\"\nimport script from \"./SysCogSecurity.vue?vue&type=script&lang=js\"\nexport * from \"./SysCogSecurity.vue?vue&type=script&lang=js\"\n\nimport \"./SysCogSecurity.vue?vue&type=style&index=0&id=fdf607e4&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-fdf607e4\"]])\n\nexport default __exports__","import { renderList as _renderList, Fragment as _Fragment, openBlock as _openBlock, createElementBlock as _createElementBlock, toDisplayString as _toDisplayString, createElementVNode as _createElementVNode, resolveComponent as _resolveComponent, createVNode as _createVNode, withCtx as _withCtx, createBlock as _createBlock, createCommentVNode as _createCommentVNode, createTextVNode as _createTextVNode, resolveDirective as _resolveDirective, withDirectives as _withDirectives } from \"vue\";\nconst _hoisted_1 = {\n class: \"page-settings\"\n};\nconst _hoisted_2 = {\n class: \"first-title\"\n};\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n const _component_el_tooltip = _resolveComponent(\"el-tooltip\");\n const _component_el_option = _resolveComponent(\"el-option\");\n const _component_el_select = _resolveComponent(\"el-select\");\n const _component_el_switch = _resolveComponent(\"el-switch\");\n const _component_el_input = _resolveComponent(\"el-input\");\n const _component_el_form_item = _resolveComponent(\"el-form-item\");\n const _component_el_form = _resolveComponent(\"el-form\");\n const _component_FloatingSaveButton = _resolveComponent(\"FloatingSaveButton\");\n const _directive_loading = _resolveDirective(\"loading\");\n return _withDirectives((_openBlock(), _createElementBlock(\"div\", _hoisted_1, [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($options.groupedSettings, (categoryGroup, categoryName) => {\n return _openBlock(), _createElementBlock(\"div\", {\n key: categoryName,\n class: \"first-settings\"\n }, [_createElementVNode(\"h3\", _hoisted_2, _toDisplayString(categoryName), 1), _createVNode(_component_el_form, {\n model: $data.settings,\n \"label-width\": \"150px\"\n }, {\n default: _withCtx(() => [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList(categoryGroup, (setting, index) => {\n return _openBlock(), _createBlock(_component_el_form_item, {\n key: setting.id\n }, {\n label: _withCtx(() => [_createTextVNode(_toDisplayString(setting.label) + \" \", 1), setting.tooltip ? (_openBlock(), _createBlock(_component_el_tooltip, {\n key: 0,\n content: setting.tooltip,\n placement: \"top\",\n \"raw-content\": \"\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"question-circle\",\n style: {\n \"margin-left\": \"5px\",\n \"cursor\": \"pointer\"\n }\n })]),\n _: 1\n }, 8, [\"content\"])) : _createCommentVNode(\"\", true)]),\n default: _withCtx(() => [setting.type === 'select' ? (_openBlock(), _createBlock(_component_el_select, {\n key: 0,\n modelValue: setting.value,\n \"onUpdate:modelValue\": $event => setting.value = $event,\n disabled: setting.fixed,\n placeholder: setting.placeholder,\n style: {\n \"width\": \"100%\"\n }\n }, {\n default: _withCtx(() => [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList(setting.options, option => {\n return _openBlock(), _createBlock(_component_el_option, {\n key: option.value,\n label: option.label,\n value: option.value\n }, null, 8, [\"label\", \"value\"]);\n }), 128))]),\n _: 2\n }, 1032, [\"modelValue\", \"onUpdate:modelValue\", \"disabled\", \"placeholder\"])) : setting.type === 'channelName' ? (_openBlock(), _createBlock(_component_el_select, {\n key: 1,\n modelValue: setting.value,\n \"onUpdate:modelValue\": $event => setting.value = $event,\n disabled: !$options.currentUploadChannel || $options.currentChannelList.length === 0,\n placeholder: \"请先选择上传渠道\",\n clearable: \"\",\n style: {\n \"width\": \"100%\"\n }\n }, {\n default: _withCtx(() => [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($options.currentChannelList, ch => {\n return _openBlock(), _createBlock(_component_el_option, {\n key: ch.name,\n label: ch.name,\n value: ch.name\n }, null, 8, [\"label\", \"value\"]);\n }), 128))]),\n _: 1\n }, 8, [\"modelValue\", \"onUpdate:modelValue\", \"disabled\"])) : setting.type === 'boolean' ? (_openBlock(), _createBlock(_component_el_switch, {\n key: 2,\n modelValue: setting.value,\n \"onUpdate:modelValue\": $event => setting.value = $event,\n disabled: setting.fixed\n }, null, 8, [\"modelValue\", \"onUpdate:modelValue\", \"disabled\"])) : (_openBlock(), _createBlock(_component_el_input, {\n key: 3,\n modelValue: setting.value,\n \"onUpdate:modelValue\": $event => setting.value = $event,\n disabled: setting.fixed,\n placeholder: setting.placeholder\n }, null, 8, [\"modelValue\", \"onUpdate:modelValue\", \"disabled\", \"placeholder\"]))]),\n _: 2\n }, 1024);\n }), 128))]),\n _: 2\n }, 1032, [\"model\"])]);\n }), 128)), _createVNode(_component_FloatingSaveButton, {\n show: !$data.loading,\n onClick: $options.saveSettings\n }, null, 8, [\"show\", \"onClick\"])])), [[_directive_loading, $data.loading]]);\n}","import \"core-js/modules/es.array.push.js\";\nimport \"core-js/modules/es.iterator.constructor.js\";\nimport \"core-js/modules/es.iterator.find.js\";\nimport \"core-js/modules/es.iterator.for-each.js\";\nimport \"core-js/modules/es.iterator.some.js\";\nimport \"core-js/modules/es.json.stringify.js\";\nimport fetchWithAuth from '@/utils/fetchWithAuth';\nimport axios from '@/utils/axios';\nimport FloatingSaveButton from '@/components/FloatingSaveButton.vue';\nexport default {\n components: {\n FloatingSaveButton\n },\n data() {\n return {\n settings: {\n config: []\n },\n // 加载状态\n loading: true,\n // 可用渠道列表\n availableChannels: {}\n };\n },\n computed: {\n // 根据category将配置项分组\n groupedSettings() {\n const grouped = {};\n if (this.settings.config) {\n this.settings.config.forEach(setting => {\n const category = setting.category || '其他设置';\n if (!grouped[category]) {\n grouped[category] = [];\n }\n grouped[category].push(setting);\n });\n }\n return grouped;\n },\n // 当前选择的上传渠道\n currentUploadChannel() {\n const channelSetting = this.settings.config?.find(s => s.id === 'defaultUploadChannel');\n return channelSetting?.value || '';\n },\n // 当前渠道类型对应的渠道列表\n currentChannelList() {\n return this.availableChannels[this.currentUploadChannel] || [];\n }\n },\n watch: {\n // 监听上传渠道变化,清空渠道名称(如果不在新列表中)\n currentUploadChannel(newVal, oldVal) {\n if (newVal !== oldVal) {\n const channelNameSetting = this.settings.config?.find(s => s.id === 'defaultChannelName');\n if (channelNameSetting) {\n const newChannelList = this.availableChannels[newVal] || [];\n if (!newChannelList.some(ch => ch.name === channelNameSetting.value)) {\n channelNameSetting.value = '';\n }\n }\n }\n }\n },\n methods: {\n saveSettings() {\n fetchWithAuth('/api/manage/sysConfig/page', {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json'\n },\n body: JSON.stringify(this.settings)\n }).then(() => this.$message.success('设置已保存'));\n },\n // 获取可用渠道列表\n async fetchAvailableChannels() {\n try {\n const response = await axios.get('/api/channels');\n if (response.data) {\n this.availableChannels = response.data;\n }\n } catch (error) {\n console.error('Failed to fetch available channels:', error);\n }\n }\n },\n mounted() {\n this.loading = true;\n // 获取可用渠道列表\n this.fetchAvailableChannels();\n // 获取上传设置\n fetchWithAuth('/api/manage/sysConfig/page').then(response => response.json()).then(data => {\n this.settings = data;\n // 处理布尔类型的值初始化\n if (this.settings.config) {\n this.settings.config.forEach(setting => {\n if (setting.type === 'boolean') {\n // 将字符串转换为布尔值\n if (typeof setting.value === 'string') {\n setting.value = setting.value === 'true';\n } else if (setting.value === undefined || setting.value === null) {\n // 如果没有值,使用默认值\n setting.value = setting.default || false;\n }\n }\n });\n }\n }).finally(() => {\n this.loading = false;\n });\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./SysCogPage.vue?vue&type=template&id=44bd640d&scoped=true\"\nimport script from \"./SysCogPage.vue?vue&type=script&lang=js\"\nexport * from \"./SysCogPage.vue?vue&type=script&lang=js\"\n\nimport \"./SysCogPage.vue?vue&type=style&index=0&id=44bd640d&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-44bd640d\"]])\n\nexport default __exports__","import { resolveComponent as _resolveComponent, createVNode as _createVNode, withCtx as _withCtx, createTextVNode as _createTextVNode, createElementVNode as _createElementVNode, renderList as _renderList, Fragment as _Fragment, openBlock as _openBlock, createElementBlock as _createElementBlock, createBlock as _createBlock, createCommentVNode as _createCommentVNode, resolveDirective as _resolveDirective, withDirectives as _withDirectives } from \"vue\";\nconst _hoisted_1 = {\n class: \"others-settings\"\n};\nconst _hoisted_2 = {\n class: \"first-settings\"\n};\nconst _hoisted_3 = {\n class: \"first-title\"\n};\nconst _hoisted_4 = {\n class: \"first-title\"\n};\nconst _hoisted_5 = {\n class: \"first-title\"\n};\nconst _hoisted_6 = {\n class: \"first-title\"\n};\nconst _hoisted_7 = {\n class: \"first-title\"\n};\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n const _component_el_tooltip = _resolveComponent(\"el-tooltip\");\n const _component_el_switch = _resolveComponent(\"el-switch\");\n const _component_el_form_item = _resolveComponent(\"el-form-item\");\n const _component_el_form = _resolveComponent(\"el-form\");\n const _component_el_input = _resolveComponent(\"el-input\");\n const _component_el_option = _resolveComponent(\"el-option\");\n const _component_el_select = _resolveComponent(\"el-select\");\n const _component_FloatingSaveButton = _resolveComponent(\"FloatingSaveButton\");\n const _directive_loading = _resolveDirective(\"loading\");\n return _withDirectives((_openBlock(), _createElementBlock(\"div\", _hoisted_1, [_createElementVNode(\"div\", _hoisted_2, [_createElementVNode(\"h3\", _hoisted_3, [_cache[13] || (_cache[13] = _createTextVNode(\"远端遥测 \", -1)), _createVNode(_component_el_tooltip, {\n content: \"便于问题查找和定位,建议开启\",\n placement: \"right\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"question-circle\",\n style: {\n \"margin-left\": \"5px\",\n \"cursor\": \"pointer\"\n }\n })]),\n _: 1\n })]), _createVNode(_component_el_form, {\n model: $data.settings.telemetry,\n \"label-width\": \"120px\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_form_item, {\n label: \"启用\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_switch, {\n modelValue: $data.settings.telemetry.enabled,\n \"onUpdate:modelValue\": _cache[0] || (_cache[0] = $event => $data.settings.telemetry.enabled = $event),\n disabled: $data.settings.telemetry.fixed\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n })]),\n _: 1\n }, 8, [\"model\"]), _createElementVNode(\"h3\", _hoisted_4, [_cache[14] || (_cache[14] = _createTextVNode(\"随机图像API \", -1)), _createVNode(_component_el_tooltip, {\n content: \"API具体用法请查阅文档\",\n placement: \"right\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"question-circle\",\n style: {\n \"margin-left\": \"5px\",\n \"cursor\": \"pointer\"\n }\n })]),\n _: 1\n })]), _createVNode(_component_el_form, {\n model: $data.settings.randomImageAPI,\n \"label-width\": \"120px\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_form_item, {\n label: \"启用\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_switch, {\n modelValue: $data.settings.randomImageAPI.enabled,\n \"onUpdate:modelValue\": _cache[1] || (_cache[1] = $event => $data.settings.randomImageAPI.enabled = $event),\n disabled: $data.settings.randomImageAPI.fixed\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n prop: \"randomImageAPI.allowedDir\"\n }, {\n label: _withCtx(() => [_cache[15] || (_cache[15] = _createElementVNode(\"span\", null, \"目录\", -1)), _createVNode(_component_el_tooltip, {\n content: \"1. 开放随机图权限的目录,默认为根目录,多个目录用逗号分隔
2. 目录均采用绝对路径,例如/img/cover,表示该目录及其所有子目录的文件可被随机图API访问\",\n placement: \"right\",\n \"raw-content\": \"\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"question-circle\",\n style: {\n \"margin-left\": \"5px\",\n \"cursor\": \"pointer\"\n }\n })]),\n _: 1\n })]),\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.settings.randomImageAPI.allowedDir,\n \"onUpdate:modelValue\": _cache[2] || (_cache[2] = $event => $data.settings.randomImageAPI.allowedDir = $event),\n disabled: $data.settings.randomImageAPI.fixed\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n })]),\n _: 1\n }, 8, [\"model\"]), _createElementVNode(\"h3\", _hoisted_5, [_cache[16] || (_cache[16] = _createTextVNode(\"访客图库 \", -1)), _createVNode(_component_el_tooltip, {\n content: \"启用后,访客可通过 /browse 路径浏览指定目录的图片(只读,无法删除/移动)\",\n placement: \"right\",\n \"raw-content\": \"\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"question-circle\",\n style: {\n \"margin-left\": \"5px\",\n \"cursor\": \"pointer\"\n }\n })]),\n _: 1\n })]), _createVNode(_component_el_form, {\n model: $data.settings.publicBrowse,\n \"label-width\": \"120px\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_form_item, {\n label: \"启用\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_switch, {\n modelValue: $data.settings.publicBrowse.enabled,\n \"onUpdate:modelValue\": _cache[3] || (_cache[3] = $event => $data.settings.publicBrowse.enabled = $event),\n disabled: $data.settings.publicBrowse.fixed\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n prop: \"publicBrowse.allowedDir\"\n }, {\n label: _withCtx(() => [_cache[18] || (_cache[18] = _createElementVNode(\"span\", null, \"开放目录\", -1)), _createVNode(_component_el_tooltip, {\n placement: \"right\",\n \"raw-content\": \"\"\n }, {\n content: _withCtx(() => [...(_cache[17] || (_cache[17] = [_createElementVNode(\"div\", {\n style: {\n \"max-width\": \"320px\",\n \"line-height\": \"1.6\"\n }\n }, [_createElementVNode(\"p\", {\n style: {\n \"margin\": \"0 0 8px 0\"\n }\n }, [_createElementVNode(\"b\", null, \"允许公开浏览的目录,多个目录用逗号分隔\")]), _createElementVNode(\"p\", {\n style: {\n \"margin\": \"0 0 8px 0\"\n }\n }, \"示例:wallpaper,photos,album\"), _createElementVNode(\"p\", {\n style: {\n \"margin\": \"0 0 8px 0\",\n \"color\": \"#909399\"\n }\n }, \"支持子目录:2026/lucky,2026/rich\"), _createElementVNode(\"p\", {\n style: {\n \"margin\": \"0\",\n \"color\": \"#67c23a\"\n }\n }, \"访问链接:https://你的域名/browse/2026/lucky\")], -1)]))]),\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"question-circle\",\n style: {\n \"margin-left\": \"5px\",\n \"cursor\": \"pointer\"\n }\n })]),\n _: 1\n })]),\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.settings.publicBrowse.allowedDir,\n \"onUpdate:modelValue\": _cache[4] || (_cache[4] = $event => $data.settings.publicBrowse.allowedDir = $event),\n disabled: $data.settings.publicBrowse.fixed,\n placeholder: \"wallpaper,photos,album\"\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n })]),\n _: 1\n }, 8, [\"model\"]), _createElementVNode(\"h3\", _hoisted_6, [_cache[19] || (_cache[19] = _createTextVNode(\"CloudFlare API Token \", -1)), _createVNode(_component_el_tooltip, {\n content: \"设置后可以使后端拉黑、删除等操作不受CDN缓存限制
建议设置,设置方式请查阅文档\",\n placement: \"right\",\n \"raw-content\": \"\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"question-circle\",\n style: {\n \"margin-left\": \"5px\",\n \"cursor\": \"pointer\"\n }\n })]),\n _: 1\n })]), _createVNode(_component_el_form, {\n model: $data.settings.cloudflareApiToken,\n \"label-width\": \"120px\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_form_item, {\n label: \"区域ID\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.settings.cloudflareApiToken.CF_ZONE_ID,\n \"onUpdate:modelValue\": _cache[5] || (_cache[5] = $event => $data.settings.cloudflareApiToken.CF_ZONE_ID = $event),\n disabled: $data.settings.cloudflareApiToken.fixed\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"账户邮箱\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.settings.cloudflareApiToken.CF_EMAIL,\n \"onUpdate:modelValue\": _cache[6] || (_cache[6] = $event => $data.settings.cloudflareApiToken.CF_EMAIL = $event),\n disabled: $data.settings.cloudflareApiToken.fixed\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"API Key\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.settings.cloudflareApiToken.CF_API_KEY,\n \"onUpdate:modelValue\": _cache[7] || (_cache[7] = $event => $data.settings.cloudflareApiToken.CF_API_KEY = $event),\n disabled: $data.settings.cloudflareApiToken.fixed,\n type: \"password\",\n \"show-password\": \"\",\n autocomplete: \"new-password\"\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n })]),\n _: 1\n }, 8, [\"model\"]), _createElementVNode(\"h3\", _hoisted_7, [_cache[20] || (_cache[20] = _createTextVNode(\"WebDAV \", -1)), _createVNode(_component_el_tooltip, {\n content: \"启用后,可以通过WebDAV协议访问和管理图片\",\n placement: \"right\",\n \"raw-content\": \"\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"question-circle\",\n style: {\n \"margin-left\": \"5px\",\n \"cursor\": \"pointer\"\n }\n })]),\n _: 1\n })]), _createVNode(_component_el_form, {\n model: $data.settings.webDAV,\n \"label-width\": \"120px\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_form_item, {\n label: \"启用\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_switch, {\n modelValue: $data.settings.webDAV.enabled,\n \"onUpdate:modelValue\": _cache[8] || (_cache[8] = $event => $data.settings.webDAV.enabled = $event),\n disabled: $data.settings.webDAV.fixed\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"用户名\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.settings.webDAV.username,\n \"onUpdate:modelValue\": _cache[9] || (_cache[9] = $event => $data.settings.webDAV.username = $event),\n disabled: $data.settings.webDAV.fixed\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"密码\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.settings.webDAV.password,\n \"onUpdate:modelValue\": _cache[10] || (_cache[10] = $event => $data.settings.webDAV.password = $event),\n disabled: $data.settings.webDAV.fixed,\n type: \"password\",\n \"show-password\": \"\",\n autocomplete: \"new-password\"\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"上传渠道\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_select, {\n modelValue: $data.settings.webDAV.uploadChannel,\n \"onUpdate:modelValue\": _cache[11] || (_cache[11] = $event => $data.settings.webDAV.uploadChannel = $event),\n disabled: $data.settings.webDAV.fixed,\n placeholder: \"默认渠道\",\n clearable: \"\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_option, {\n label: \"Telegram\",\n value: \"telegram\"\n }), _createVNode(_component_el_option, {\n label: \"Cloudflare R2\",\n value: \"cfr2\"\n }), _createVNode(_component_el_option, {\n label: \"S3\",\n value: \"s3\"\n }), _createVNode(_component_el_option, {\n label: \"Discord\",\n value: \"discord\"\n }), _createVNode(_component_el_option, {\n label: \"HuggingFace\",\n value: \"huggingface\"\n })]),\n _: 1\n }, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), $data.settings.webDAV.uploadChannel && $options.webdavChannelList.length > 1 ? (_openBlock(), _createBlock(_component_el_form_item, {\n key: 0,\n label: \"指定渠道名\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_select, {\n modelValue: $data.settings.webDAV.channelName,\n \"onUpdate:modelValue\": _cache[12] || (_cache[12] = $event => $data.settings.webDAV.channelName = $event),\n disabled: $data.settings.webDAV.fixed,\n placeholder: \"自动选择\",\n clearable: \"\"\n }, {\n default: _withCtx(() => [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($options.webdavChannelList, ch => {\n return _openBlock(), _createBlock(_component_el_option, {\n key: ch.name,\n label: ch.name,\n value: ch.name\n }, null, 8, [\"label\", \"value\"]);\n }), 128))]),\n _: 1\n }, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n })) : _createCommentVNode(\"\", true)]),\n _: 1\n }, 8, [\"model\"])]), _createVNode(_component_FloatingSaveButton, {\n show: !$data.loading,\n onClick: $options.saveSettings\n }, null, 8, [\"show\", \"onClick\"])])), [[_directive_loading, $data.loading]]);\n}","import \"core-js/modules/es.json.stringify.js\";\nimport fetchWithAuth from '@/utils/fetchWithAuth';\nimport FloatingSaveButton from '@/components/FloatingSaveButton.vue';\nexport default {\n components: {\n FloatingSaveButton\n },\n data() {\n return {\n settings: {\n telemetry: {},\n randomImageAPI: {},\n cloudflareApiToken: {},\n webDAV: {},\n publicBrowse: {}\n },\n availableChannels: {},\n // 可用渠道列表\n // 加载状态\n loading: true\n };\n },\n computed: {\n // WebDAV 当前渠道类型对应的渠道列表\n webdavChannelList() {\n const channelType = this.settings.webDAV?.uploadChannel;\n return channelType ? this.availableChannels[channelType] || [] : [];\n }\n },\n watch: {\n 'settings.webDAV.uploadChannel'() {\n // 切换渠道类型时清空指定的渠道名称\n if (this.settings.webDAV) {\n this.settings.webDAV.channelName = '';\n }\n }\n },\n methods: {\n saveSettings() {\n fetchWithAuth('/api/manage/sysConfig/others', {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json'\n },\n body: JSON.stringify(this.settings)\n }).then(() => this.$message.success('设置已保存'));\n },\n async fetchAvailableChannels() {\n try {\n const response = await fetchWithAuth('/api/channels');\n if (response.ok) {\n this.availableChannels = await response.json();\n }\n } catch (error) {\n console.error('Failed to fetch available channels:', error);\n }\n }\n },\n mounted() {\n this.loading = true;\n // 获取上传设置\n fetchWithAuth('/api/manage/sysConfig/others').then(response => response.json()).then(data => {\n this.settings = data;\n }).finally(() => {\n this.loading = false;\n });\n // 获取可用渠道列表\n this.fetchAvailableChannels();\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./SysCogOthers.vue?vue&type=template&id=0cedb60a&scoped=true\"\nimport script from \"./SysCogOthers.vue?vue&type=script&lang=js\"\nexport * from \"./SysCogOthers.vue?vue&type=script&lang=js\"\n\nimport \"./SysCogOthers.vue?vue&type=style&index=0&id=0cedb60a&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-0cedb60a\"]])\n\nexport default __exports__","import \"core-js/modules/es.array.push.js\";\nimport DashboardTabs from '@/components/DashboardTabs.vue';\nimport SysConfigTabs from '@/components/SysConfigTabs.vue';\nimport SysCogStatus from '@/components/SysCogStatus.vue';\nimport SysCogUpload from '@/components/SysCogUpload.vue';\nimport SysCogSecurity from '@/components/SysCogSecurity.vue';\nimport SysCogPage from '@/components/SysCogPage.vue';\nimport SysCogOthers from '@/components/SysCogOthers.vue';\nexport default {\n name: 'SystemConfig',\n data() {\n return {\n activeIndex: 'status',\n isSidebarCollapse: false\n };\n },\n watch: {\n // 监听锚点变化\n '$route.hash': {\n immediate: true,\n handler(newHash) {\n this.activeIndex = newHash.replace('#', '');\n window.scrollTo(0, 0); // 滚动到页面顶部\n }\n },\n activeIndex(newIndex) {\n // 更新锚点\n const hash = `#${newIndex}`;\n this.$router.push({\n hash\n });\n }\n },\n components: {\n DashboardTabs,\n SysConfigTabs,\n SysCogStatus,\n SysCogUpload,\n SysCogSecurity,\n SysCogPage,\n SysCogOthers\n },\n computed: {\n disableTooltip() {\n return window.innerWidth < 768;\n },\n // 根据锚点动态返回对应的组件\n currentComponent() {\n const hash = this.$route.hash.replace('#', '');\n switch (hash) {\n case 'status':\n return SysCogStatus;\n case 'upload':\n return SysCogUpload;\n case 'security':\n return SysCogSecurity;\n case 'page':\n return SysCogPage;\n case 'others':\n return SysCogOthers;\n default:\n return SysCogStatus;\n }\n }\n },\n methods: {\n handleLogout() {\n this.$store.commit('setCredentials', null);\n this.$router.push('/adminLogin');\n },\n // 设置默认锚点\n setDefaultHash() {\n const defaultHash = '#status'; // 默认锚点\n window.location.hash = defaultHash;\n this.activeIndex = defaultHash.replace('#', '');\n }\n },\n mounted() {\n // 如果 URL 中没有锚点,则设置默认锚点\n if (!window.location.hash) {\n this.setDefaultHash();\n }\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./SystemConfig.vue?vue&type=template&id=4cdf1dc2&scoped=true\"\nimport script from \"./SystemConfig.vue?vue&type=script&lang=js\"\nexport * from \"./SystemConfig.vue?vue&type=script&lang=js\"\n\nimport \"./SystemConfig.vue?vue&type=style&index=0&id=4cdf1dc2&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-4cdf1dc2\"]])\n\nexport default __exports__"],"names":["_typeof","o","Symbol","iterator","constructor","prototype","toPrimitive","t","r","e","i","call","TypeError","String","Number","toPropertyKey","_defineProperty","Object","defineProperty","value","enumerable","configurable","writable","_hoisted_1","class","_hoisted_2","_hoisted_3","render","_ctx","_cache","$props","$setup","$data","$options","_component_font_awesome_icon","isCollapse","menuItems","item","key","index","activeIndex","onClick","$event","handleSelect","icon","title","args","toggleCollapse","name","props","type","default","Boolean","data","methods","this","$emit","checkMobile","isMobile","window","innerWidth","mounted","addEventListener","beforeDestroy","removeEventListener","__exports__","_component_DashboardTabs","_component_el_tooltip","_component_el_header","_component_SysConfigTabs","activeTab","disabled","disableTooltip","content","placement","handleLogout","_","isSidebarCollapse","currentComponent","_hoisted_4","_hoisted_5","_hoisted_6","_hoisted_7","_hoisted_8","_hoisted_9","_hoisted_10","_hoisted_11","_hoisted_12","_hoisted_13","_hoisted_14","_hoisted_15","_hoisted_16","_hoisted_17","_hoisted_18","_hoisted_19","_hoisted_20","_hoisted_21","_hoisted_22","_hoisted_23","_hoisted_24","_hoisted_25","_hoisted_26","_hoisted_27","_hoisted_28","_hoisted_29","_hoisted_30","_hoisted_31","_hoisted_32","_hoisted_33","_hoisted_34","_hoisted_35","_hoisted_36","_hoisted_37","_hoisted_38","_hoisted_39","_hoisted_40","_hoisted_41","_hoisted_42","_hoisted_43","_hoisted_44","_hoisted_45","_hoisted_46","_hoisted_47","_hoisted_48","_hoisted_49","_hoisted_50","_hoisted_51","_hoisted_52","_hoisted_53","_hoisted_54","_hoisted_55","_hoisted_56","_hoisted_57","_hoisted_58","_hoisted_59","_hoisted_60","_hoisted_61","_hoisted_62","_hoisted_63","_hoisted_64","_hoisted_65","_hoisted_66","_hoisted_67","_hoisted_68","_hoisted_69","_hoisted_70","_hoisted_71","_component_Doughnut","_component_el_progress","_component_el_button","_component_el_image","_directive_loading","fetchIndexInfo","indexInfo","totalFiles","toLocaleString","formatTime","lastUpdated","getTimeAgo","openReleases","version","keys","channelStats","length","channelChartData","options","chartOptions","count","channel","style","background","getChartColor","getPercentage","typeStats","typeChartData","aggregatedTypeStats","status","getTypeChartColor","isProcessing","phaseDescription","Math","round","processingProgress","percentage","current","total","estimatedTimeRemaining","message","plain","size","cancelOperation","processingError","suggestion","recoverable","retryOperation","dismissError","loading","rebuilding","rebuildIndex","backing","backupData","ref","accept","onChange","handleFileSelect","restoring","selectRestoreFile","newestFile","oldestFile","openFileInNewTab","isImageFile","loadErrors","src","id","fit","onError","handleImageError","isVideoFile","muted","loop","autoplay","metadata","FileName","TimeStamp","v","lim","l","h","max","min","p2b","n2b","b2n","n2p","map$1","A","B","C","D","E","F","a","b","c","d","f","hex","h1","h2","eq","isShort","g","hexParse","str","ret","len","alpha","hexString","undefined","HUE_RE","hsl2rgbn","s","n","k","hsv2rgbn","hwb2rgbn","w","rgb","hueValue","rgb2hsl","range","calln","Array","isArray","map","hsl2rgb","hwb2rgb","hsv2rgb","hue","hueParse","m","exec","p1","p2","rotate","deg","hslString","x","Z","Y","X","W","V","U","T","S","R","Q","P","O","N","M","L","K","G","H","I","J","names$1","OiceXe","antiquewEte","aqua","aquamarRe","azuY","beige","bisque","black","blanKedOmond","Xe","XeviTet","bPwn","burlywood","caMtXe","KartYuse","KocTate","cSO","cSnflowerXe","cSnsilk","crimson","cyan","xXe","xcyan","xgTMnPd","xWay","xgYF","xgYy","xkhaki","xmagFta","xTivegYF","xSange","xScEd","xYd","xsOmon","xsHgYF","xUXe","xUWay","xUgYy","xQe","xviTet","dAppRk","dApskyXe","dimWay","dimgYy","dodgerXe","fiYbrick","flSOwEte","foYstWAn","fuKsia","gaRsbSo","ghostwEte","gTd","gTMnPd","Way","gYF","gYFLw","gYy","honeyMw","hotpRk","RdianYd","Rdigo","ivSy","khaki","lavFMr","lavFMrXsh","lawngYF","NmoncEffon","ZXe","ZcSO","Zcyan","ZgTMnPdLw","ZWay","ZgYF","ZgYy","ZpRk","ZsOmon","ZsHgYF","ZskyXe","ZUWay","ZUgYy","ZstAlXe","ZLw","lime","limegYF","lRF","magFta","maPon","VaquamarRe","VXe","VScEd","VpurpN","VsHgYF","VUXe","VsprRggYF","VQe","VviTetYd","midnightXe","mRtcYam","mistyPse","moccasR","navajowEte","navy","Tdlace","Tive","TivedBb","Sange","SangeYd","ScEd","pOegTMnPd","pOegYF","pOeQe","pOeviTetYd","papayawEp","pHKpuff","peru","pRk","plum","powMrXe","purpN","YbeccapurpN","Yd","Psybrown","PyOXe","saddNbPwn","sOmon","sandybPwn","sHgYF","sHshell","siFna","silver","skyXe","UXe","UWay","UgYy","snow","sprRggYF","stAlXe","tan","teO","tEstN","tomato","Qe","viTet","JHt","wEte","wEtesmoke","Lw","LwgYF","unpack","unpacked","tkeys","j","ok","nk","replace","parseInt","names","nameParse","transparent","toLowerCase","RGB_RE","rgbParse","rgbString","to","pow","from","interpolate","rgb1","rgb2","modHSL","ratio","tmp","clone","proto","assign","fromObject","input","functionParse","charAt","Color","_rgb","_valid","valid","obj","mix","color","weight","c1","c2","w2","p","w1","clearer","greyscale","val","opaquer","negate","lighten","darken","saturate","desaturate","noop","uid","isNullOrUndef","toString","slice","isObject","isNumberFinite","isFinite","finiteOrDefault","defaultValue","valueOrDefault","toPercentage","dimension","endsWith","parseFloat","toDimension","callback","fn","thisArg","apply","each","loopable","reverse","_elementsEqual","a0","a1","ilen","v0","v1","datasetIndex","source","target","create","klen","isValidKey","indexOf","_merger","tval","sval","merge","sources","merger","mergeIf","_mergerIf","hasOwnProperty","keyResolvers","y","_splitKey","parts","split","part","push","_getKeyResolver","resolveObjectKey","resolver","_capitalize","toUpperCase","defined","isFunction","setsEqual","has","_isClickEvent","PI","TAU","PITAU","INFINITY","POSITIVE_INFINITY","RAD_PER_DEG","HALF_PI","QUARTER_PI","TWO_THIRDS_PI","log10","sign","almostEquals","epsilon","abs","niceNum","roundedRange","niceRange","floor","fraction","niceFraction","_factorize","result","sqrt","sort","pop","isNonPrimitive","isNumber","isNaN","almostWhole","rounded","_setMinAndMaxByKey","array","property","toRadians","degrees","toDegrees","radians","_decimalPlaces","getAngleFromPoint","centrePoint","anglePoint","distanceFromXCenter","distanceFromYCenter","radialDistanceFromCenter","angle","atan2","distance","distanceBetweenPoints","pt1","pt2","_angleDiff","_normalizeAngle","_angleBetween","start","end","sameAngleIsFullCircle","angleToStart","angleToEnd","startToAngle","endToAngle","_limitValue","_int16Range","_isBetween","_lookup","table","cmp","mid","hi","lo","_lookupByKey","last","ti","_rlookupByKey","_filterBetween","values","arrayEvents","listenArrayEvents","listener","_chartjs","listeners","forEach","method","base","res","object","unlistenArrayEvents","stub","splice","_arrayUnique","items","set","Set","requestAnimFrame","requestAnimationFrame","throttled","argsToUse","ticking","debounce","delay","timeout","clearTimeout","setTimeout","_toLeftRightCenter","align","_alignStartEnd","_textX","left","right","rtl","check","_getStartAndCountOfVisiblePoints","meta","points","animationsDisabled","pointCount","_sorted","iScale","vScale","_parsed","spanGaps","dataset","axis","minDefined","maxDefined","getUserBounds","getPixelForValue","distanceToDefinedLo","findIndex","point","distanceToDefinedHi","_scaleRangesChanged","xScale","yScale","_scaleRanges","newRanges","xmin","xmax","ymin","ymax","changed","atEdge","elasticIn","sin","elasticOut","effects","linear","easeInQuad","easeOutQuad","easeInOutQuad","easeInCubic","easeOutCubic","easeInOutCubic","easeInQuart","easeOutQuart","easeInOutQuart","easeInQuint","easeOutQuint","easeInOutQuint","easeInSine","cos","easeOutSine","easeInOutSine","easeInExpo","easeOutExpo","easeInOutExpo","easeInCirc","easeOutCirc","easeInOutCirc","easeInElastic","easeOutElastic","easeInOutElastic","easeInBack","easeOutBack","easeInOutBack","easeInBounce","easeOutBounce","easeInOutBounce","isPatternOrGradient","getHoverColor","numbers","colors","applyAnimationsDefaults","defaults","duration","easing","describe","_fallback","_indexable","_scriptable","properties","active","animation","resize","show","animations","visible","hide","applyLayoutsDefaults","autoPadding","padding","top","bottom","intlCache","Map","getNumberFormat","locale","cacheKey","JSON","stringify","formatter","get","Intl","NumberFormat","formatNumber","num","format","formatters","numeric","tickValue","ticks","chart","notation","delta","maxTick","calculateDelta","logDelta","numDecimal","minimumFractionDigits","maximumFractionDigits","logarithmic","remain","significand","includes","Ticks","applyScaleDefaults","display","offset","beginAtZero","bounds","clip","grace","grid","lineWidth","drawOnChartArea","drawTicks","tickLength","tickWidth","tickColor","border","dash","dashOffset","width","text","minRotation","maxRotation","mirror","textStrokeWidth","textStrokeColor","autoSkip","autoSkipPadding","labelOffset","minor","major","crossAlign","showLabelBackdrop","backdropColor","backdropPadding","route","startsWith","overrides","descriptors","getScope$1","node","root","scope","Defaults","_descriptors","_appliers","backgroundColor","borderColor","datasets","devicePixelRatio","context","platform","getDevicePixelRatio","elements","events","font","family","lineHeight","hover","hoverBackgroundColor","ctx","hoverBorderColor","hoverColor","indexAxis","interaction","mode","intersect","includeInvisible","maintainAspectRatio","onHover","parsing","plugins","responsive","scale","scales","showLine","drawActiveElementsOnTop","override","targetScope","targetName","scopeObject","targetScopeObject","privateName","defineProperties","local","appliers","toFontString","_measureText","gc","longest","string","textWidth","measureText","_longestText","arrayOfThings","cache","garbageCollect","save","jlen","thing","nestedThing","restore","gcLen","_alignPixel","pixel","currentDevicePixelRatio","halfWidth","clearCanvas","canvas","getContext","resetTransform","clearRect","height","drawPoint","drawPointLegend","xOffset","yOffset","cornerRadius","xOffsetW","yOffsetW","pointStyle","rotation","radius","rad","translate","drawImage","beginPath","ellipse","arc","closePath","moveTo","lineTo","SQRT1_2","rect","fill","borderWidth","stroke","_isPointInArea","area","margin","clipArea","unclipArea","_steppedLineTo","previous","flip","midpoint","_bezierCurveTo","bezierCurveTo","cp1x","cp2x","cp1y","cp2y","setRenderOpts","opts","translation","fillStyle","textAlign","textBaseline","decorateText","line","strikethrough","underline","metrics","actualBoundingBoxLeft","actualBoundingBoxRight","actualBoundingBoxAscent","actualBoundingBoxDescent","yDecoration","strokeStyle","decorationWidth","drawBackdrop","oldColor","fillRect","renderText","lines","strokeWidth","strokeColor","backdrop","strokeText","maxWidth","fillText","addRoundedRectPath","topLeft","bottomLeft","bottomRight","topRight","LINE_HEIGHT","FONT_STYLE","toLineHeight","matches","match","numberOrZero","_readValueToProps","objProps","read","prop","toTRBL","toTRBLCorners","toPadding","toFont","fallback","console","warn","resolve","inputs","info","cacheable","_addGrace","minmax","change","keepZero","add","createContext","parentContext","_createResolver","scopes","prefixes","rootScopes","getTarget","finalRootScopes","_resolve","toStringTag","_cacheable","_scopes","_rootScopes","_getTarget","Proxy","deleteProperty","_keys","_cached","_resolveWithPrefixes","getOwnPropertyDescriptor","Reflect","getPrototypeOf","getKeysFromAllScopes","ownKeys","storage","_storage","_attachContext","proxy","subProxy","descriptorDefaults","_proxy","_context","_subProxy","_stack","setContext","receiver","_resolveWithContext","allKeys","scriptable","indexable","_allKeys","isScriptable","isIndexable","readKey","prefix","needsSubResolver","_resolveScriptable","_resolveArray","getValue","Error","join","delete","createSubResolver","arr","filter","resolveFallback","getScope","parent","addScopes","parentScopes","parentFallback","allScopes","addScopesFromKey","subGetTarget","resolveKeysFromAllScopes","_parseObjectDataRadialScale","_parsing","parsed","parse","EPSILON","getPoint","skip","getValueAxis","splineCurve","firstPoint","middlePoint","afterPoint","next","d01","d12","s01","s12","fa","fb","monotoneAdjust","deltaK","mK","pointsLen","alphaK","betaK","tauK","squaredMagnitude","pointCurrent","pointAfter","monotoneCompute","valueAxis","pointBefore","iPixel","vPixel","splineCurveMonotone","slopeDelta","capControlPoint","pt","capBezierPoints","inArea","inAreaPrev","inAreaNext","_updateBezierControlPoints","controlPoints","cubicInterpolationMode","prev","tension","_isDomSupported","document","_getParentNode","domNode","parentNode","host","parseMaxStyle","styleValue","parentProperty","valueInPixels","getComputedStyle","element","ownerDocument","defaultView","getStyle","el","getPropertyValue","positions","getPositionedStyle","styles","suffix","pos","useOffsetPos","shadowRoot","getCanvasPosition","touches","offsetX","offsetY","box","getBoundingClientRect","clientX","clientY","getRelativePosition","event","borderBox","boxSizing","paddings","borders","getContainerSize","maxHeight","container","containerStyle","containerBorder","containerPadding","clientWidth","clientHeight","round1","getMaximumSize","bbWidth","bbHeight","aspectRatio","margins","containerSize","maintainHeight","retinaScale","forceRatio","forceStyle","pixelRatio","deviceHeight","deviceWidth","setTransform","supportsEventListenerOptions","passiveSupported","passive","readUsedSize","_pointInLine","_steppedInterpolation","_bezierInterpolation","cp1","cp2","getRightToLeftAdapter","rectX","setWidth","xPlus","leftForLtr","itemWidth","getLeftToRightAdapter","_itemWidth","getRtlAdapter","overrideTextDirection","direction","original","getPropertyPriority","setProperty","prevTextDirection","restoreTextDirection","propertyFn","between","compare","normalize","normalizeSegment","getSegment","segment","startBound","endBound","_boundSegment","prevValue","inside","subStart","startIsBefore","endIsBefore","shouldStart","shouldStop","_boundSegments","segments","sub","findStartAndEnd","solidSegments","cur","stop","_computeSegments","segmentOptions","_loop","splitByStyles","completeLoop","_fullLoop","doSplitByStyles","chartContext","_chart","baseStyle","readStyle","_datasetIndex","prevStyle","addStyle","st","dir","p0","p0DataIndex","p1DataIndex","styleChanged","borderCapStyle","borderDash","borderDashOffset","borderJoinStyle","replacer","getSizeForArea","chartArea","field","getDatasetArea","getDatasetClipArea","_clip","Animator","_request","_charts","_running","_lastDate","_notify","anims","date","callbacks","numSteps","initial","currentStep","_refresh","_update","Date","now","remaining","running","draw","_active","_total","tick","_getAnims","charts","complete","progress","listen","cb","reduce","acc","_duration","cancel","remove","animator","interpolators","boolean","factor","c0","number","Animation","cfg","currentValue","_fn","_easing","_start","_target","_prop","_from","_to","_promises","update","elapsed","wait","promises","Promise","rej","resolved","Animations","config","_properties","configure","animationOptions","animatedProps","getOwnPropertyNames","option","_animateOptions","newOptions","resolveTargetOptions","_createAnimations","$shared","awaitAll","$animations","then","anim","all","scaleClip","allowedOverflow","defaultClip","toClip","getSortedDatasetIndices","filterVisible","metasets","_getSortedDatasetMetas","applyStack","stack","dsIndex","singleMode","otherValue","found","convertObjectDataToArray","iAxisKey","vAxisKey","adata","isStacked","stacked","getStackKey","indexScale","valueScale","NEGATIVE_INFINITY","getOrCreateStack","stacks","stackKey","indexValue","subStack","getLastIndexInStack","positive","getMatchingVisibleMetas","updateStacks","controller","_cachedMeta","_stacks","iAxis","vAxis","itemStacks","_top","_bottom","visualValues","_visualValues","getFirstScaleId","shift","createDatasetContext","createDataContext","dataIndex","raw","clearStacks","isDirectUpdateMode","cloneIfNotShared","cached","shared","createStack","canStack","hidden","_stacked","DatasetController","_cachedDataOpts","getMeta","_type","_data","_objectData","_sharedOptions","_drawStart","_drawCount","enableOptionSharing","supportsDecimation","$context","_syncList","datasetElementType","dataElementType","initialize","linkScales","addElements","isPluginEnabled","updateIndex","getDataset","chooseId","xid","xAxisID","yid","yAxisID","rid","rAxisID","iid","iAxisID","vid","vAxisID","getScaleForId","rScale","getDatasetMeta","scaleID","_getOtherScale","reset","_destroy","_dataCheck","isExtensible","buildOrUpdateElements","resetNewElements","stackChanged","oldStacked","_resyncElements","scopeKeys","datasetScopeKeys","getOptionScopes","createResolver","sorted","parseArrayData","parseObjectData","parsePrimitiveData","isNotInOrderComparedToPrev","labels","getLabels","singleScale","xAxisKey","yAxisKey","getParsed","getDataElement","updateRangeFromParsed","parsedValue","NaN","getMinMax","otherScale","otherMin","otherMax","_skip","getAllParsedValues","getMaxOverflow","getLabelAndValue","label","getLabelForValue","resolveDatasetElementOptions","resolveDataElementOptions","_resolveElementOptions","elementType","sharing","datasetElementScopeKeys","resolveNamedOptions","freeze","_resolveAnimations","transition","datasetAnimationScopeKeys","getSharedOptions","includeOptions","sharedOptions","_animationsDisabled","_getSharedOptions","firstOpts","previouslySharedOptions","updateSharedOptions","updateElement","_setStyle","removeHoverStyle","setHoverStyle","_removeDatasetHoverStyle","_setDatasetHoverStyle","arg1","arg2","numMeta","numData","_insertElements","_removeElements","move","updateElements","removed","_sync","_dataChanges","_onDataPush","arguments","_onDataPop","_onDataShift","_onDataSplice","newCount","_onDataUnshift","getAllScaleValues","$bar","visibleMetas","concat","computeMinSampleSize","curr","_length","updateMinAndPrev","getPixelForTick","computeFitCategoryTraits","ruler","stackCount","thickness","barThickness","categoryPercentage","barPercentage","chunk","pixels","computeFlexCategoryTraits","percent","parseFloatBar","entry","startValue","endValue","barStart","barEnd","_custom","parseValue","parseArrayOrPrimitive","isFloatBar","custom","barSign","actualBase","isHorizontal","borderProps","horizontal","setBorderSkipped","edge","borderSkipped","enableBorderRadius","parseEdge","swap","startEnd","orig","v2","setInflateAmount","inflateAmount","BarController","super","bars","getBasePixel","_getRuler","vpixels","head","_calculateBarValuePixels","ipixels","_calculateBarIndexPixels","center","_getStacks","grouped","currentParsed","iScaleValue","skipNull","find","_getStackCount","_getAxisCount","_getAxis","getFirstScaleIdForIndexAxis","indexScaleId","firstScaleAxisId","_getStackIndex","_startPixel","_endPixel","baseValue","minBarLength","floating","getDataVisibility","startPixel","getPixelForDecimal","endPixel","getValueForPixel","halfGrid","getLineWidthForValue","maxBarThickness","Infinity","axisCount","axisID","axisNumber","stackIndex","rects","_index_","_value_","BubbleController","getRatioAndOffset","circumference","cutout","ratioX","ratioY","startAngle","endAngle","startX","startY","endX","endY","calcMax","calcMin","maxX","maxY","minX","minY","DoughnutController","innerRadius","outerRadius","getter","_getRotation","_getCircumference","_getRotationExtents","isDatasetVisible","arcs","spacing","getMaxBorderWidth","getMaxOffset","maxSize","chartWeight","_getRingWeight","maxRadius","radiusLength","_getVisibleDatasetWeightTotal","calculateTotal","_getRingWeightOffset","_circumference","animateRotate","calculateCircumference","animationOpts","centerX","centerY","animateScale","metaData","borderAlign","hoverBorderWidth","hoverOffset","ringWeightOffset","legend","generateLabels","useBorderRadius","borderRadius","fontColor","lineDash","lineDashOffset","lineJoin","legendItem","toggleDataVisibility","LineController","_dataset","_decimated","animated","maxGapLength","directUpdate","pointsCount","prevParsed","nullData","lastPoint","updateControlPoints","PolarAreaController","bind","_updateRadius","minSize","cutoutPercentage","getVisibleDatasetCount","xCenter","yCenter","datasetStartAngle","getIndexAngle","defaultAngle","countVisibleElements","_computeAngle","getDistanceFromCenterForValue","angleLines","circular","pointLabels","PieController","RadarController","pointPosition","getPointPositionForValue","ScatterController","registry","getElement","abstract","DateAdapterBase","members","init","formats","diff","startOf","endOf","adapters","_date","binarySearch","metaset","lookupMethod","_reversePixels","getRange","evaluateInteractionItems","position","handler","getSortedVisibleDatasetMetas","getDistanceMetricForAxis","useX","useY","deltaX","deltaY","getIntersectItems","useFinalPosition","isPointInArea","evaluationFunc","inRange","getNearestRadialItems","getProps","getNearestCartesianItems","distanceMetric","minDistance","getCenterPoint","pointInArea","getNearestItems","getAxisItems","rangeMethod","intersectsItem","Interaction","modes","nearest","STATIC_POSITIONS","filterByPosition","filterDynamicPositionByAxis","sortByWeight","wrapBoxes","boxes","layoutBoxes","stackWeight","buildStacks","layouts","wrap","placed","setLayoutDims","params","vBoxMaxWidth","hBoxMaxHeight","layout","fullSize","availableWidth","availableHeight","buildLayoutBoxes","centerHorizontal","centerVertical","leftAndTop","rightAndBottom","vertical","getCombinedMax","maxPadding","updateMaxPadding","boxPadding","updateDims","getPadding","newWidth","outerWidth","newHeight","outerHeight","widthChanged","heightChanged","same","other","handleMaxPadding","updatePos","getMargins","marginForPositions","fitBoxes","refitBoxes","refit","setBoxDims","placeBoxes","userPadding","addBox","_layers","z","removeBox","layoutItem","minPadding","verticalBoxes","horizontalBoxes","beforeLayout","visibleVerticalBoxCount","BasePlatform","acquireContext","releaseContext","isAttached","updateConfig","BasicPlatform","EXPANDO_KEY","EVENT_TYPES","touchstart","touchmove","touchend","pointerenter","pointerdown","pointermove","pointerup","pointerleave","pointerout","isNullOrEmpty","initCanvas","renderHeight","getAttribute","renderWidth","displayWidth","displayHeight","eventListenerOptions","addListener","removeListener","fromNativeEvent","native","nodeListContains","nodeList","contains","createAttachObserver","observer","MutationObserver","entries","trigger","addedNodes","removedNodes","observe","childList","subtree","createDetachObserver","drpListeningCharts","oldDevicePixelRatio","onWindowResize","dpr","listenDevicePixelRatioChanges","unlistenDevicePixelRatioChanges","createResizeObserver","ResizeObserver","contentRect","releaseObserver","disconnect","createProxyAndListen","DomPlatform","removeAttribute","setAttribute","proxies","$proxies","handlers","attach","detach","isConnected","_detectPlatform","OffscreenCanvas","Element","tooltipPosition","hasValue","final","tickOpts","determinedMaxTicks","determineMaxTicks","ticksLimit","maxTicksLimit","majorIndices","enabled","getMajorIndices","numMajorIndices","first","newTicks","skipMajors","calculateSpacing","avgMajorSpacing","_tickSize","maxScale","maxChart","_maxLength","evenMajorSpacing","getEvenSpacing","factors","ceil","majorStart","majorEnd","reverseAlign","offsetFromEdge","getTicksLimit","ticksLength","sample","numItems","increment","getPixelForGridLine","offsetGridLines","validIndex","lineValue","caches","getTickMarkLength","getTitleHeight","createScaleContext","createTickContext","titleAlign","titleArgs","titleX","titleY","positionAxisID","Scale","_margins","paddingTop","paddingBottom","paddingLeft","paddingRight","labelRotation","_range","_gridLineItems","_labelItems","_labelSizes","_longestTextCache","_userMax","_userMin","_suggestedMax","_suggestedMin","_ticksLength","_borderValue","_dataLimitsCached","suggestedMin","suggestedMax","metas","getTicks","xLabels","yLabels","getLabelItems","_computeLabelItems","beforeUpdate","sampleSize","beforeSetDimensions","setDimensions","afterSetDimensions","beforeDataLimits","determineDataLimits","afterDataLimits","beforeBuildTicks","buildTicks","afterBuildTicks","samplingEnabled","_convertTicksToLabels","beforeCalculateLabelRotation","calculateLabelRotation","afterCalculateLabelRotation","afterAutoSkip","beforeFit","afterFit","afterUpdate","reversePixels","_alignToPixels","alignToPixels","_callHooks","notifyPlugins","beforeTickToLabelConversion","generateTickLabels","afterTickToLabelConversion","numTicks","maxLabelDiagonal","_isVisible","labelSizes","_getLabelSizes","maxLabelWidth","widest","maxLabelHeight","highest","asin","titleOpts","gridOpts","titleHeight","tickPadding","angleRadians","labelHeight","labelWidth","_calculatePadding","_handleMargins","isRotated","labelsBelowTicks","offsetLeft","offsetRight","isFullSize","_computeLabelSizes","widths","heights","tickFont","fontString","nestedLabel","widestLabelSize","highestLabelSize","_resolveTickFontOptions","valueAt","idx","decimal","getDecimalForPixel","getBaseValue","optionTicks","rot","_computeGridLineItems","tl","borderOpts","axisWidth","axisHalfWidth","alignBorderValue","borderValue","alignedLineValue","tx1","ty1","tx2","ty2","x1","y1","x2","y2","limit","step","optsAtIndex","optsAtIndexBorder","lineColor","tickBorderDash","tickBorderDashOffset","tickAndPadding","hTickAndPadding","lineCount","textOffset","_getXAxisLabelAlignment","_getYAxisLabelAlignment","halfCount","tickTextAlign","labelPadding","_computeLabelArea","drawBackground","drawGrid","drawLine","setLineDash","drawBorder","lastLineWidth","drawLabels","renderTextOptions","drawTitle","tz","gz","bz","_maxDigits","fontSize","TypedRegistry","isForType","isPrototypeOf","register","parentScope","isIChartComponent","registerDefaults","unregister","itemDefaults","defaultRoutes","routeDefaults","routes","propertyParts","sourceName","sourceScope","Registry","controllers","_typedRegistries","_each","addControllers","addPlugins","addScales","getController","_get","getPlugin","getScale","removeControllers","removeElements","removePlugins","removeScales","typedRegistry","arg","reg","_getRegistryForType","_exec","itemReg","component","camelMethod","PluginService","_init","notify","hook","_createDescriptors","descriptor","plugin","cancelable","invalidate","_oldCache","_notifyStateChanges","allPlugins","createDescriptors","previousDescriptors","some","localIds","getOpts","pluginOpts","pluginScopeKeys","getIndexAxis","datasetDefaults","datasetOptions","getAxisFromDefaultScaleID","getDefaultScaleIDFromAxis","idMatchesAxis","axisFromPosition","determineAxis","scaleOptions","getAxisFromDataset","retrieveAxisFromDatasets","boundDs","mergeScaleConfig","chartDefaults","configScales","chartIndexAxis","scaleConf","error","defaultId","defaultScaleOptions","defaultID","initOptions","initData","initConfig","keyCache","keysCached","cachedKeys","generate","addIfFound","Config","_config","_scopeCache","_resolverCache","clearCache","clear","datasetType","additionalOptionScopes","_cachedScopes","mainScope","resetCache","keyLists","chartOptionScopes","subPrefixes","getResolver","needContext","subResolver","resolverCache","hasFunction","KNOWN_POSITIONS","positionIsHorizontal","compare2Level","l1","l2","onAnimationsComplete","onComplete","onAnimationProgress","onProgress","getCanvas","getElementById","instances","getChart","moveNumericKeys","intKey","determineLastEvent","lastEvent","inChartArea","isClick","Chart","invalidatePlugins","userConfig","initialCanvas","existingChart","_options","_aspectRatio","_metasets","_lastEvent","_listeners","_responsiveListeners","_sortedMetasets","_plugins","_hiddenIndices","attached","_doResize","resizeDelay","_initialize","bindEvents","_resizeBeforeDraw","_resize","newSize","newRatio","onResize","ensureScalesHaveIDs","scalesOptions","axisOptions","buildOrUpdateScales","scaleOpts","updated","isRadial","dposition","dtype","scaleType","scaleClass","hasUpdated","_updateMetasets","_destroyDatasetMeta","_removeUnreferencedMetasets","buildOrUpdateControllers","newControllers","order","ControllerClass","_resetElements","animsDisabled","_updateScales","_checkEventBindings","_updateHiddenIndices","_minPadding","_updateLayout","_updateDatasets","_eventHandler","_updateHoverStyles","existingEvents","newEvents","unbindEvents","changes","_getUniformDataChanges","datasetCount","makeSet","changeSet","noArea","_idx","_updateDataset","layers","_drawDatasets","_drawDataset","getElementsAtEventForMode","setDatasetVisibility","_updateVisibility","_stop","destroy","toBase64Image","toDataURL","bindUserEvents","bindResponsiveEvents","_add","_remove","detached","updateHoverStyle","getActiveElements","setActiveElements","activeElements","lastActive","pluginId","replay","hoverOptions","deactivated","activated","eventFilter","_handleEvent","_getActiveElements","clipSelf","outerAngleClip","innerAngleClip","clipWidth","clipArc","pixelMargin","angleMargin","toRadiusCorners","parseBorderRadius$1","angleDelta","halfThickness","innerLimit","computeOuterLimit","outerArcLimit","outerStart","outerEnd","innerStart","innerEnd","rThetaToXY","theta","pathArc","innerR","spacingOffset","noSpacingInnerRadius","noSpacingOuterRadius","avNogSpacingRadius","adjustedAngle","beta","angleOffset","outerStartAdjustedRadius","outerEndAdjustedRadius","outerStartAdjustedAngle","outerEndAdjustedAngle","innerStartAdjustedRadius","innerEndAdjustedRadius","innerStartAdjustedAngle","innerEndAdjustedAngle","outerMidAdjustedAngle","pCenter","p4","innerMidAdjustedAngle","p8","outerStartX","outerStartY","outerEndX","outerEndY","drawArc","fullCircles","inner","selfJoin","ArcElement","chartX","chartY","rAdjust","nonZeroBetween","betweenAngles","withinRadius","halfAngle","halfRadius","fix","radiusOffset","setStyle","lineCap","getLineMethod","stepped","pathVars","paramsStart","paramsEnd","segmentStart","segmentEnd","outside","pathSegment","lineMethod","fastPathSegment","prevX","lastY","avgX","countX","pointIndex","drawX","truncX","_getSegmentMethod","useFastPath","_getInterpolationMethod","strokePathWithCache","path","_path","Path2D","strokePathDirect","segmentMethod","usePath2D","LineElement","_points","_segments","_pointsUpdated","_interpolate","interpolated","inRange$1","hitRadius","PointElement","mouseX","mouseY","inXRange","inYRange","hoverRadius","getBarBounds","bar","half","skipOrLimit","parseBorderWidth","maxW","maxH","parseBorderRadius","maxR","enableBorder","boundingRects","outer","skipX","skipY","skipBoth","hasRadius","addNormalRectPath","inflateRect","amount","refRect","BarElement","addRectPath","getBoxSize","labelOpts","boxHeight","boxWidth","usePointStyle","pointStyleWidth","itemHeight","itemsEqual","Legend","_added","legendHitBoxes","_hoveredItem","doughnutMode","legendItems","columnSizes","lineWidths","buildLabels","labelFont","_computeTitleHeight","_fitRows","_fitCols","hitboxes","totalHeight","row","_itemHeight","heightLimit","totalWidth","currentColWidth","currentColHeight","col","calculateItemSize","adjustHitBoxes","rtlHelper","hitbox","_draw","defaultColor","halfFontSize","cursor","drawLegendBox","drawOptions","SQRT2","yBoxTop","xBoxLeft","textDirection","realX","fontLineHeight","calculateLegendItemHeight","titleFont","titlePadding","topPaddingPlusHalfFontSize","_getLegendItemAt","hitBox","lh","handleEvent","isListened","hoveredItem","sameItem","onLeave","calculateItemWidth","calculateItemHeight","legendItemText","plugin_legend","_element","_args","afterEvent","ci","WeakMap","positioners","average","xSet","xAverage","eventPosition","nearestElement","tp","pushOrConcat","toPush","splitNewlines","createTooltipItem","formattedValue","getTooltipSize","tooltip","body","footer","bodyFont","footerFont","titleLineCount","footerLineCount","bodyLineItemCount","combinedBodyLength","bodyItem","before","after","beforeBody","afterBody","titleSpacing","titleMarginBottom","bodyLineHeight","displayColors","bodySpacing","footerMarginTop","footerSpacing","widthPadding","maxLineWidth","determineYAlign","doesNotFitWithAlign","xAlign","caret","caretSize","caretPadding","determineXAlign","yAlign","chartWidth","determineAlignment","alignX","alignY","paddingAndSize","getBackgroundPoint","alignment","getAlignedX","getBeforeAfterBodyLines","createTooltipContext","tooltipItems","overrideCallbacks","defaultCallbacks","beforeTitle","labelCount","afterTitle","beforeLabel","tooltipItem","labelColor","labelTextColor","bodyColor","labelPointStyle","afterLabel","beforeFooter","afterFooter","invokeCallbackWithFallback","Tooltip","opacity","_eventPosition","_size","_cachedAnimations","_tooltipItems","dataPoints","caretX","caretY","labelColors","labelPointStyles","labelTextColors","getTitle","getBeforeBody","getBody","bodyItems","scoped","getAfterBody","getFooter","_createItems","itemSort","positionAndSize","backgroundPoint","external","drawCaret","tooltipPoint","caretPosition","getCaretPosition","x3","y3","ptX","ptY","titleColor","_drawColorBox","colorX","rtlColorX","yOffSet","colorY","multiKeyBackground","outerX","innerX","strokeRect","drawBody","bodyAlign","xLinePadding","fillLineOfText","bodyAlignForCalculation","textColor","drawFooter","footerAlign","footerColor","tooltipSize","quadraticCurveTo","_updateAnimationTarget","animX","animY","_willRender","hasTooltipContent","globalAlpha","positionChanged","_positionChanged","_ignoreReplayEvents","plugin_tooltip","afterInit","afterDraw","addIfString","addedLabels","unshift","findOrAddLabel","lastIndexOf","_getLabelForValue","CategoryScale","_startValue","_valueRange","_addedLabels","added","generateTicks$1","generationOptions","dataRange","MIN_SPACING","precision","maxTicks","maxDigits","includeBounds","unit","maxSpaces","rmin","rmax","countDefined","minSpacing","niceMin","niceMax","numSpaces","decimalPlaces","relativeLabelSize","LinearScaleBase","_endValue","handleTickRangeOptions","setMin","setMax","minSign","maxSign","getTickLimit","stepSize","computeTickLimit","numericGeneratorOptions","LinearScale","log10Floor","changeExponent","isMajor","tickVal","steps","rangeExp","rangeStep","startExp","generateTicks","minExp","exp","lastTick","LogarithmicScale","_zero","getTickBackdropHeight","measureLabelSize","determineLimits","fitWithPointLabels","_padding","limits","valueCount","_pointLabels","pointLabelOpts","additionalAngle","centerPointLabels","getPointLabelContext","getPointPosition","drawingArea","plFont","textSize","hLimits","vLimits","updateLimits","setCenterPoint","_pointLabelItems","buildPointLabelItems","createPointLabelItem","itemOpts","outerDistance","extra","pointLabelPosition","yForAngle","getTextAlignForAngle","leftForTextAlign","isNotOverlapped","apexesInArea","drawPointLabelBox","backdropLeft","backdropTop","backdropWidth","backdropHeight","drawPointLabels","pathRadiusLine","drawRadiusLine","gridLineOpts","createPointLabelContext","RadialLinearScale","leftMovement","rightMovement","topMovement","bottomMovement","angleMultiplier","scalingFactor","getValueForDistanceFromCenter","scaledDistance","pointLabel","distanceFromCenter","getBasePosition","getPointLabelPosition","animate","INTERVALS","millisecond","common","second","minute","hour","day","week","month","quarter","year","UNITS","sorter","adapter","_adapter","parser","isoWeekday","_parseOpts","determineUnitForAutoTicks","minUnit","capacity","interval","MAX_SAFE_INTEGER","determineUnitForFormatting","determineMajorUnit","addTick","time","timestamps","timestamp","setMajorTicks","majorUnit","ticksFromTimestamps","TimeScale","_unit","_majorUnit","_offsets","_normalized","displayFormats","normalized","_applyBounds","_getLabelBounds","getLabelTimestamps","timeOpts","_generate","_getLabelCapacity","initOffsets","offsetAfterAutoskip","getDecimalForValue","weekday","hasWeekday","getDataTimestamps","tooltipFormat","datetime","fmt","_tickFormatFunction","minorFormat","majorFormat","offsets","_getLabelSize","ticksOpts","tickLabelWidth","cosRotation","sinRotation","tickFontSize","exampleTime","exampleLabel","prevSource","nextSource","prevTarget","nextTarget","span","TimeSeriesScale","_table","_minPos","_tableRange","_getTimestampsForTable","buildLookupTable","CommonProps","required","datasetIdKey","updateMode","A11yProps","ariaLabel","ariaDescribedby","Props","destroyDelay","compatProps","internals","attrs","toRawIfProxy","isProxy","toRaw","cloneProxy","setOptions","nextOptions","setLabels","currentData","nextLabels","setDatasets","nextDatasets","addedDatasets","nextDataset","currentDataset","cloneData","nextData","defineComponent","setup","param","expose","slots","canvasRef","chartRef","shallowRef","renderChart","clonedData","proxiedData","Chart$1","destroyChart","onMounted","onUnmounted","watch","param1","nextOptionsProxy","nextDataProxy","prevOptionsProxy","prevDataProxy","shouldUpdate","prevOptions","prevLabels","prevDatasets","nextTick","deep","role","createTypedChart","registerables","reforwardRef","Doughnut","BatchOperationError","code","ERROR_HANDLERS","details","NETWORK","ABORT","createError","Response","BatchProcessor","batchSize","abortController","fetchAllRecords","includeValue","AbortController","allRecords","totalFetched","batchCount","signal","aborted","response","fetchBatch","records","nextCursor","phase","batchError","URLSearchParams","fetchWithAuth","errorDetails","errorData","json","success","totalProcessed","abort","isAborted","IndexRebuilder","chunkSize","maxRetries","retryDelay","sessionId","generateSessionId","fetchConfig","databaseType","rebuild","processor","sortByTimestampDescending","chunks","splitIntoChunks","uploadChunkWithRetry","finalize","timestampA","timestampB","chunkId","lastError","attempt","uploadChunk","sleep","checksum","calculateChecksum","headers","createHttpError","totalChunks","random","encoder","TextEncoder","dataBuffer","encode","hashBuffer","crypto","subtle","digest","hashArray","Uint8Array","padStart","ms","BackupGenerator","generateBackup","packageInfo","fileCount","files","settings","record","fetchSettings","downloadBackup","settingsCount","blob","Blob","url","URL","createObjectURL","createElement","href","download","toISOString","appendChild","click","removeChild","revokeObjectURL","RestoreProcessor","fileEntries","settingEntries","totalSettings","totalItems","restoredFiles","restoredSettings","failedFiles","failedSettings","fileChunks","chunkData","fromEntries","restoredCount","failedCount","settingChunks","backupTimestamp","components","newest","oldest","channelColors","typeColors","processingPhase","processingStartTime","currentRebuilder","currentBackupGenerator","currentRestoreProcessor","computed","stats","aggregatedStats","mappedStatus","toFixed","totalEstimated","seconds","minutes","hours","remainingMinutes","phaseMap","$message","warning","handleProgress","handleError","errorMessage","settingsMsg","$refs","fileInput","file","$confirm","confirmButtonText","cancelButtonText","restoreData","fileContent","parseError","days","isValidPreview","FileType","open","fileName","extension","substring","imageExtensions","videoExtensions","$nextTick","isOpen","toggleDropdown","modelValue","displayLabel","selectOption","$slots","placeholder","emits","selected","opt","handleClickOutside","beforeUnmount","$el","_component_CustomSelect","_component_el_tag","_component_el_switch","_component_el_option","_component_el_select","_component_el_form_item","_component_el_input","_component_el_input_number","_component_el_form","_component_el_dialog","_component_el_descriptions_item","_component_el_descriptions","channelFilter","filterOptions","showAddDialog","filteredChannels","channelType","getChannelIcon","getChannelList","hasLoadBalance","getSettings","loadBalance","saveSettings","fixed","onMousemove","handleCardMouseMove","onMouseleave","handleCardMouseLeave","ref_for","maskText","botToken","chatId","publicUrl","bucketName","endpoint","channelId","isNitro","repo","isPrivate","quota","getQuotaPercentage","getQuotaStatus","getQuotaText","openDetailDialog","openEditDialog","deleteChannel","onClosed","resetAddForm","confirmAddChannel","model","newChannel","rules","addRules","onChannelTypeChange","addableChannels","ch","proxyUrl","cdnDomain","region","accessKeyId","secretAccessKey","pathStyle","limitGB","threshold","token","showDetailDialog","currentChannel","resetDetailData","openEditFromDetail","column","getChannelTypeLabel","currentChannelType","readonly","link","refreshQuota","quotaLoading","isQuotaExceeded","getQuotaStatusText","showEditDialog","editChannel","resetEditData","confirmEditChannel","editRules","onQuotaEnabledChange","CustomSelect","channels","telegramSettings","cfr2Settings","s3Settings","discordSettings","huggingfaceSettings","currentChannelIndex","pattern","quotaStats","iconMap","telegram","cfr2","s3","discord","huggingface","card","currentTarget","refKey","glowEl","icons","showLength","addForm","validate","reservedNames","isDuplicate","newChannelData","savePath","editForm","newName","currentIndex","isFixedChannel","catch","getResponse","getData","loadQuotaStats","getChannelUsedGB","usedMB","usedGB","async","recalculateQuota","finally","handleClick","spin","immediate","_component_el_table_column","_component_el_table","_component_FloatingSaveButton","_component_el_checkbox","_component_el_checkbox_group","authSettings","user","userPassRules","authCode","onInput","handleUserPassInput","autocomplete","showUserPassConfirm","confirmNewUserPassword","admin","adminPassRules","adminUsername","adminPassword","handleAdminPassInput","showAdminPassConfirm","confirmNewAdminPassword","showCreateTokenDialog","circle","apiTokens","permissions","perm","getPermissionText","formatDate","createdAt","editToken","deleteToken","tokenLoading","uploadSettings","moderate","moderateContentApiKey","nsfwApiPath","accessSettings","allowedDomains","whiteListMode","dialogWidth","createToken","newToken","tokenRules","showEditTokenDialog","updateToken","editingToken","showTokenResultDialog","createdToken","append","copyToken","FloatingSaveButton","oriUserPassword","oriAdminPassword","owner","validator","rule","urlReservedChars","hasReservedChar","char","permission","permissionMap","dateString","loadApiTokens","tokens","tokenForm","editTokenForm","tokenId","navigator","clipboard","writeText","validationPromises","userPassForm","adminPassForm","results","isValid","every","auth","upload","access","groupedSettings","categoryGroup","categoryName","setting","currentUploadChannel","currentChannelList","clearable","availableChannels","category","channelSetting","newVal","oldVal","channelNameSetting","newChannelList","fetchAvailableChannels","axios","telemetry","randomImageAPI","allowedDir","publicBrowse","cloudflareApiToken","CF_ZONE_ID","CF_EMAIL","CF_API_KEY","webDAV","username","password","uploadChannel","webdavChannelList","channelName","newHash","scrollTo","newIndex","hash","$router","DashboardTabs","SysConfigTabs","SysCogStatus","SysCogUpload","SysCogSecurity","SysCogPage","SysCogOthers","$route","$store","commit","setDefaultHash","defaultHash","location"],"ignoreList":[],"sourceRoot":""} \ No newline at end of file +{"version":3,"file":"js/407.f0b5dee5.js","mappings":"gOAAA,SAASA,EAAQC,GAGf,OAAOD,EAAU,mBAAqBE,QAAU,iBAAmBA,OAAOC,SAAW,SAAUF,GAC7F,cAAcA,CAChB,EAAI,SAAUA,GACZ,OAAOA,GAAK,mBAAqBC,QAAUD,EAAEG,cAAgBF,QAAUD,IAAMC,OAAOG,UAAY,gBAAkBJ,CACpH,EAAGD,EAAQC,EACb,CCPA,SAASK,EAAYC,EAAGC,GACtB,GAAI,UAAYR,EAAQO,KAAOA,EAAG,OAAOA,EACzC,IAAIE,EAAIF,EAAEL,OAAOI,aACjB,QAAI,IAAWG,EAAG,CAChB,IAAIC,EAAID,EAAEE,KAAKJ,EAAGC,GAAK,WACvB,GAAI,UAAYR,EAAQU,GAAI,OAAOA,EACnC,MAAM,IAAIE,UAAU,+CACtB,CACA,OAAQ,WAAaJ,EAAIK,OAASC,QAAQP,EAC5C,CCRA,SAASQ,EAAcR,GACrB,IAAIG,EAAIJ,EAAYC,EAAG,UACvB,MAAO,UAAYP,EAAQU,GAAKA,EAAIA,EAAI,EAC1C,CCJA,SAASM,EAAgBP,EAAGD,EAAGD,GAC7B,OAAQC,EAAIO,EAAcP,MAAOC,EAAIQ,OAAOC,eAAeT,EAAGD,EAAG,CAC/DW,MAAOZ,EACPa,YAAY,EACZC,cAAc,EACdC,UAAU,IACPb,EAAED,GAAKD,EAAGE,CACjB,C,iUCPA,MAAMc,EAAa,CACjBC,MAAO,aAEHC,EAAa,CAAC,WACdC,EAAa,CACjBF,MAAO,aAEF,SAASG,EAAOC,EAAMC,EAAQC,EAAQC,EAAQC,EAAOC,GAC1D,MAAMC,GAA+B,QAAkB,qBACvD,OAAO,WAAc,QAAoB,MAAO,CAC9CV,OAAO,QAAgB,CAAC,oBAAqB,CAC3C,eAAgBM,EAAOK,eAExB,EAAC,QAAoB,MAAOZ,EAAY,GAAE,SAAW,IAAO,QAAoB,KAAW,MAAM,QAAYS,EAAMI,UAAWC,KACxH,WAAc,QAAoB,MAAO,CAC9CC,IAAKD,EAAKE,MACVf,OAAO,QAAgB,CAAC,YAAa,CACnC,YAAaM,EAAOU,cAAgBH,EAAKE,SAE3CE,QAASC,GAAUT,EAASU,aAAaN,EAAKE,QAC7C,EAAC,QAAaL,EAA8B,CAC7CU,KAAMP,EAAKO,KACXpB,MAAO,aACN,KAAM,EAAG,CAAC,UAAU,QAAoB,OAAQE,GAAY,QAAiBW,EAAKQ,OAAQ,IAAK,GAAIpB,KACpG,SAAS,QAAoB,MAAO,CACtCD,MAAO,gBACPiB,QAASZ,EAAO,KAAOA,EAAO,GAAK,IAAIiB,IAASb,EAASc,gBAAkBd,EAASc,kBAAkBD,KACrG,EAAC,QAAaZ,EAA8B,CAC7CU,KAAMd,EAAOK,WAAa,qBAAuB,qBAChD,KAAM,EAAG,CAAC,YAAa,EAC5B,CC/BA,OACEa,KAAM,gBACNC,MAAO,CACLT,YAAa,CACXU,KAAMrC,OACNsC,QAAS,UAEXhB,WAAY,CACVe,KAAME,QACND,SAAS,IAGb,IAAAE,GACE,MAAO,CACLjB,UAAW,CAAC,CACVG,MAAO,SACPK,KAAM,YACNC,MAAO,QACN,CACDN,MAAO,SACPK,KAAM,eACNC,MAAO,QACN,CACDN,MAAO,WACPK,KAAM,SACNC,MAAO,QACN,CACDN,MAAO,OACPK,KAAM,QACNC,MAAO,QACN,CACDN,MAAO,SACPK,KAAM,MACNC,MAAO,SAGb,EACAS,QAAS,CACP,cAAAP,GACEQ,KAAKC,MAAM,qBAAsBD,KAAKpB,WACxC,EACA,WAAAsB,GACE,MAAMC,EAAWC,OAAOC,YAAc,IACtCL,KAAKC,MAAM,oBAAqBE,EAClC,EACA,YAAAf,CAAaJ,GACXgB,KAAKC,MAAM,qBAAsBjB,EACnC,GAEF,OAAAsB,GACEN,KAAKE,cACLE,OAAOG,iBAAiB,SAAUP,KAAKE,YACzC,EACA,aAAAM,GACEJ,OAAOK,oBAAoB,SAAUT,KAAKE,YAC5C,G,UChDF,MAAMQ,GAA2B,OAAgB,EAAQ,CAAC,CAAC,SAAStC,GAAQ,CAAC,YAAY,qBAEzF,Q,yDCRA,MAAM,EAAa,CACjBH,MAAO,aAEH,EAAa,CACjBA,MAAO,kBAEH,EAAa,CACjBA,MAAO,iBAEF,SAAS,EAAOI,EAAMC,EAAQC,EAAQC,EAAQC,EAAOC,GAC1D,MAAMiC,EAA2B,IAC3BhC,GAA+B,QAAkB,qBACjDiC,EAAwB,KACxBC,EAAuB,KACvBC,EAA2B,EACjC,OAAO,WAAc,QAAoB,MAAO,EAAY,EAAC,QAAaD,EAAsB,KAAM,CACpGjB,SAAS,QAAS,IAAM,EAAC,QAAoB,MAAO,EAAY,EAAC,QAAae,EAA0B,CACtGI,UAAW,kBACT,QAAoB,MAAO,EAAY,EAAC,QAAaH,EAAuB,CAC9EI,SAAUtC,EAASuC,eACnBC,QAAS,OACTC,UAAW,UACV,CACDvB,SAAS,QAAS,IAAM,EAAC,QAAajB,EAA8B,CAClEU,KAAM,eACNpB,MAAO,cACPiB,QAASR,EAAS0C,cACjB,KAAM,EAAG,CAAC,cACbC,EAAG,GACF,EAAG,CAAC,mBACPA,EAAG,KACD,QAAaP,EAA0B,CACzC7B,YAAaR,EAAMQ,YACnB,uBAAwBX,EAAO,KAAOA,EAAO,GAAKa,GAAUV,EAAMQ,YAAcE,GAChFP,WAAYH,EAAM6C,kBAClB,sBAAuBhD,EAAO,KAAOA,EAAO,GAAKa,GAAUV,EAAM6C,kBAAoBnC,IACpF,KAAM,EAAG,CAAC,cAAe,iBAAiB,WAAc,SAAa,QAAyBT,EAAS6C,kBAAmB,CAC3HtD,OAAO,QAAgB,CAAC,iBAAkB,CACxC,UAAaQ,EAAM6C,sBAEpB,KAAM,EAAG,CAAC,YACf,C,uFCzCA,MAAM,EAAa,CACjBrD,MAAO,gBAEH,EAAa,CACjBA,MAAO,kBAEH,EAAa,CACjBA,MAAO,aAEHuD,EAAa,CACjBvD,MAAO,gBAEHwD,EAAa,CACjBxD,MAAO,cAEHyD,EAAa,CACjBzD,MAAO,8BAEH0D,EAAa,CACjB1D,MAAO,aAEH2D,EAAa,CACjB3D,MAAO,gBAEH4D,EAAa,CACjB5D,MAAO,cAEH6D,EAAc,CAClB7D,MAAO,iBAEH8D,EAAc,CAClB9D,MAAO,aAEH+D,EAAc,CAClB/D,MAAO,gBAEHgE,EAAc,CAClBhE,MAAO,cAEHiE,EAAc,CAClBjE,MAAO,kBAEHkE,EAAc,CAClBlE,MAAO,cAEHmE,EAAc,CAClBnE,MAAO,gBAEHoE,EAAc,CAClBpE,MAAO,iBAEHqE,EAAc,CAClBvD,IAAK,EACLd,MAAO,eAEHsE,EAAc,CAClBxD,IAAK,EACLd,MAAO,uBAEHuE,EAAc,CAClBvE,MAAO,qBAEHwE,EAAc,CAClBxE,MAAO,qBAEHyE,EAAc,CAClBzE,MAAO,gBAEH0E,EAAc,CAClB1E,MAAO,gBAEH2E,EAAc,CAClB3E,MAAO,gBAEH4E,EAAc,CAClB5E,MAAO,gBAEH6E,EAAc,CAClB7E,MAAO,kBAEH8E,EAAc,CAClB9E,MAAO,cAEH+E,EAAc,CAClB/E,MAAO,gBAEHgF,EAAc,CAClBhF,MAAO,iBAEHiF,EAAc,CAClBnE,IAAK,EACLd,MAAO,eAEHkF,GAAc,CAClBpE,IAAK,EACLd,MAAO,uBAEHmF,GAAc,CAClBnF,MAAO,qBAEHoF,GAAc,CAClBpF,MAAO,qBAEHqF,GAAc,CAClBrF,MAAO,gBAEHsF,GAAc,CAClBtF,MAAO,gBAEHuF,GAAc,CAClBvF,MAAO,gBAEHwF,GAAc,CAClBxF,MAAO,gBAEHyF,GAAc,CAClBzF,MAAO,kBAEH0F,GAAc,CAClB1F,MAAO,mBAEH2F,GAAc,CAClB3F,MAAO,eAEH4F,GAAc,CAClB5F,MAAO,iBAEH6F,GAAc,CAClB7F,MAAO,kBAEH8F,GAAc,CAClBhF,IAAK,EACLd,MAAO,sBAEH+F,GAAc,CAClB/F,MAAO,mBAEHgG,GAAc,CAClBhG,MAAO,kBAEHiG,GAAc,CAClBjG,MAAO,uBAEHkG,GAAc,CAClBlG,MAAO,oBAEHmG,GAAc,CAClBrF,IAAK,EACLd,MAAO,kBAEHoG,GAAc,CAClBtF,IAAK,EACLd,MAAO,iBAEHqG,GAAc,CAClBvF,IAAK,EACLd,MAAO,oBAEHsG,GAAc,CAClBxF,IAAK,EACLd,MAAO,mBAEHuG,GAAc,CAClBvG,MAAO,cAEHwG,GAAc,CAClBxG,MAAO,iBAEHyG,GAAc,CAClBzG,MAAO,iBAEH0G,GAAc,CAClB5F,IAAK,EACLd,MAAO,oBAEH2G,GAAc,CAClB3G,MAAO,iBAEH4G,GAAc,CAClB9F,IAAK,EACLd,MAAO,kBAEH6G,GAAc,CAClB7G,MAAO,mBAEH8G,GAAc,CAClBhG,IAAK,EACLd,MAAO,qBAEH+G,GAAc,CAAC,OACfC,GAAc,CAClBlG,IAAK,EACLd,MAAO,oBAEHiH,GAAc,CAClBjH,MAAO,oBAEHkH,GAAc,CAClBlH,MAAO,oBAEHmH,GAAc,CAClBnH,MAAO,aAEHoH,GAAc,CAClBpH,MAAO,aAEHqH,GAAc,CAAC,OACfC,GAAc,CAClBxG,IAAK,EACLd,MAAO,oBAEHuH,GAAc,CAClBvH,MAAO,4BAEHwH,GAAc,CAClBxH,MAAO,oBAEHyH,GAAc,CAClBzH,MAAO,aAEH0H,GAAc,CAClB1H,MAAO,aAEF,SAAS,GAAOI,EAAMC,EAAQC,EAAQC,EAAQC,EAAOC,GAC1D,MAAMC,GAA+B,QAAkB,qBACjDiH,GAAsB,QAAkB,YACxCC,EAAyB,KACzBC,EAAuB,KACvBlF,EAAwB,KACxBmF,EAAsB,KACtBC,EAAqB,IAC3B,OAAO,UAAiB,WAAc,QAAoB,MAAO,EAAY,EAAC,QAAoB,MAAO,EAAY,EAAC,QAAoB,MAAO,CAC/I/H,MAAO,4BACPiB,QAASZ,EAAO,KAAOA,EAAO,GAAK,IAAIiB,IAASb,EAASuH,gBAAkBvH,EAASuH,kBAAkB1G,KACrG,EAAC,QAAoB,MAAO,EAAY,EAAC,QAAaZ,EAA8B,CACrFU,KAAM,gBACF,QAAoB,MAAOmC,EAAY,CAAClD,EAAO,KAAOA,EAAO,IAAK,QAAoB,MAAO,CACjGL,MAAO,cACN,QAAS,KAAK,QAAoB,MAAOwD,GAAY,QAAiBhD,EAAMyH,UAAUC,YAAYC,kBAAoB,KAAM,GAAI9H,EAAO,MAAQA,EAAO,KAAM,QAAoB,MAAO,CACxLL,MAAO,iBACN,QAAS,SAAS,QAAoB,MAAOyD,EAAY,EAAC,QAAoB,MAAOC,EAAY,EAAC,QAAahD,EAA8B,CAC9IU,KAAM,aACF,QAAoB,MAAOuC,EAAY,CAACtD,EAAO,MAAQA,EAAO,KAAM,QAAoB,MAAO,CACnGL,MAAO,cACN,UAAW,KAAK,QAAoB,MAAO4D,GAAY,QAAiBnD,EAAS2H,WAAW5H,EAAMyH,UAAUI,cAAe,IAAI,QAAoB,MAAOxE,GAAa,QAAiBpD,EAAS6H,WAAW9H,EAAMyH,UAAUI,cAAe,QAAQ,QAAoB,MAAO,CAC/QrI,MAAO,+BACPiB,QAASZ,EAAO,KAAOA,EAAO,GAAK,IAAIiB,IAASb,EAAS8H,cAAgB9H,EAAS8H,gBAAgBjH,KACjG,EAAC,QAAoB,MAAOwC,EAAa,EAAC,QAAapD,EAA8B,CACtFU,KAAM,mBACF,QAAoB,MAAO2C,EAAa,CAAC1D,EAAO,MAAQA,EAAO,KAAM,QAAoB,MAAO,CACpGL,MAAO,cACN,QAAS,KAAK,QAAoB,MAAOgE,EAAa,KAAM,QAAiBxD,EAAMgI,SAAU,GAAInI,EAAO,MAAQA,EAAO,KAAM,QAAoB,MAAO,CACzJL,MAAO,iBACN,YAAa,WAAW,QAAoB,MAAOiE,EAAa,EAAC,QAAoB,MAAOC,EAAa,EAAC,QAAoB,MAAOC,EAAa,EAAC,QAAazD,EAA8B,CAC/LU,KAAM,cACJf,EAAO,MAAQA,EAAO,KAAM,QAAoB,OAAQ,KAAM,UAAW,OAAO,QAAoB,MAAO+D,EAAa,CAA4D,IAA3D3E,OAAOgJ,KAAKjI,EAAMyH,UAAUS,cAAgB,CAAC,GAAGC,SAAgB,WAAc,QAAoB,MAAOtE,EAAa,EAAC,QAAa3D,EAA8B,CAC7RU,KAAM,UACJf,EAAO,MAAQA,EAAO,KAAM,QAAoB,OAAQ,KAAM,QAAS,SAAU,WAAc,QAAoB,MAAOiE,EAAa,EAAC,QAAoB,MAAOC,EAAa,EAAC,QAAaoD,EAAqB,CACrN9F,KAAMpB,EAASmI,iBACfC,QAASpI,EAASqI,cACjB,KAAM,EAAG,CAAC,OAAQ,aAAa,QAAoB,MAAOtE,EAAa,EAAC,QAAoB,MAAOC,GAAa,QAAiBjE,EAAMyH,UAAUC,YAAYC,kBAAoB,KAAM,GAAI9H,EAAO,MAAQA,EAAO,KAAM,QAAoB,MAAO,CACnPL,MAAO,gBACN,QAAS,SAAS,QAAoB,MAAO0E,EAAa,GAAE,SAAW,IAAO,QAAoB,KAAW,MAAM,QAAYlE,EAAMyH,UAAUS,aAAc,CAACK,EAAOC,EAASjI,MACxK,WAAc,QAAoB,MAAO,CAC9CD,IAAKkI,EACLhJ,MAAO,eACN,EAAC,QAAoB,OAAQ,CAC9BA,MAAO,eACPiJ,OAAO,QAAgB,CACrBC,WAAYzI,EAAS0I,cAAcpI,MAEpC,KAAM,IAAI,QAAoB,OAAQ4D,GAAa,QAAiBqE,GAAU,IAAI,QAAoB,OAAQpE,GAAa,QAAiBmE,EAAMZ,kBAAmB,IAAI,QAAoB,OAAQtD,GAAa,QAAiBpE,EAAS2I,cAAcL,EAAOvI,EAAMyH,UAAUC,aAAe,IAAK,OACtS,gBAAgB,QAAoB,MAAOpD,EAAa,EAAC,QAAoB,MAAOC,EAAa,EAAC,QAAarE,EAA8B,CAC/IU,KAAM,aACJf,EAAO,MAAQA,EAAO,KAAM,QAAoB,OAAQ,KAAM,UAAW,OAAO,QAAoB,MAAO2E,EAAa,CAAyD,IAAxDvF,OAAOgJ,KAAKjI,EAAMyH,UAAUoB,WAAa,CAAC,GAAGV,SAAgB,WAAc,QAAoB,MAAO1D,EAAa,EAAC,QAAavE,EAA8B,CAC1RU,KAAM,UACJf,EAAO,MAAQA,EAAO,KAAM,QAAoB,OAAQ,KAAM,QAAS,SAAU,WAAc,QAAoB,MAAO6E,GAAa,EAAC,QAAoB,MAAOC,GAAa,EAAC,QAAawC,EAAqB,CACrN9F,KAAMpB,EAAS6I,cACfT,QAASpI,EAASqI,cACjB,KAAM,EAAG,CAAC,OAAQ,aAAa,QAAoB,MAAO1D,GAAa,EAAC,QAAoB,MAAOC,IAAa,QAAiB5F,OAAOgJ,KAAKjI,EAAMyH,UAAUoB,WAAWV,QAAS,GAAItI,EAAO,MAAQA,EAAO,KAAM,QAAoB,MAAO,CAC7OL,MAAO,gBACN,QAAS,SAAS,QAAoB,MAAOsF,GAAa,GAAE,SAAW,IAAO,QAAoB,KAAW,MAAM,QAAY7E,EAAS8I,oBAAqB,CAACR,EAAOS,EAAQzI,MACvK,WAAc,QAAoB,MAAO,CAC9CD,IAAK0I,EACLxJ,MAAO,eACN,EAAC,QAAoB,OAAQ,CAC9BA,MAAO,eACPiJ,OAAO,QAAgB,CACrBC,WAAYzI,EAASgJ,kBAAkB1I,MAExC,KAAM,IAAI,QAAoB,OAAQwE,IAAa,QAAiBiE,GAAS,IAAI,QAAoB,OAAQhE,IAAa,QAAiBuD,EAAMZ,kBAAmB,IAAI,QAAoB,OAAQ1C,IAAa,QAAiBhF,EAAS2I,cAAcL,EAAOvI,EAAMyH,UAAUC,aAAe,IAAK,OACrS,kBAAkB,QAAoB,MAAOxC,GAAa,EAAC,QAAoB,MAAOC,GAAa,EAAC,QAAoB,MAAOC,GAAa,EAAC,QAAalF,EAA8B,CAC1LU,KAAM,UACJf,EAAO,MAAQA,EAAO,KAAM,QAAoB,OAAQ,KAAM,QAAS,OAAO,QAAoB,MAAOwF,GAAa,CAACrF,EAAMkJ,eAAgB,WAAc,QAAoB,MAAO5D,GAAa,EAAC,QAAoB,MAAOC,GAAa,EAAC,QAAoB,OAAQC,IAAa,QAAiBvF,EAASkJ,kBAAmB,IAAI,QAAoB,OAAQ1D,IAAa,QAAiB2D,KAAKC,MAAMrJ,EAAMsJ,mBAAmBC,aAAe,IAAK,MAAM,QAAanC,EAAwB,CACtemC,WAAYvJ,EAAMsJ,mBAAmBC,WACrC,eAAgB,GAChB,aAAa,EACb/J,MAAO,gBACN,KAAM,EAAG,CAAC,gBAAgB,QAAoB,MAAOkG,GAAa,CAAC1F,EAAMsJ,mBAAmBE,QAAU,IAAK,WAAc,QAAoB,OAAQ7D,GAAa,EAAC,QAAazF,EAA8B,CAC/MU,KAAM,cACJ,QAAiB,KAAM,QAAiBZ,EAAMsJ,mBAAmBE,QAAQ7B,kBAAoB,IAAK,GAAI3H,EAAMsJ,mBAAmBG,MAAQ,IAAK,WAAc,QAAoB,KAAW,CAC3LnJ,IAAK,GACJ,EAAC,QAAiB,OAAQ,QAAiBN,EAAMsJ,mBAAmBG,MAAM9B,kBAAmB,IAAK,MAAO,QAAoB,IAAI,GAAO9H,EAAO,MAAQA,EAAO,KAAM,QAAiB,SAAU,QAAS,QAAoB,IAAI,GAAOI,EAASyJ,yBAA0B,WAAc,QAAoB,OAAQ9D,GAAa,EAAC,QAAa1F,EAA8B,CAC9WU,KAAM,WACJ,QAAiB,KAAM,QAAiBX,EAASyJ,wBAAyB,OAAQ,QAAoB,IAAI,KAAS1J,EAAMsJ,mBAAmBK,UAAW,WAAc,QAAoB,MAAO9D,IAAa,QAAiB7F,EAAMsJ,mBAAmBK,SAAU,KAAM,QAAoB,IAAI,IAAO,QAAatC,EAAsB,CAC3UnG,KAAM,SACN0I,MAAO,GACPC,KAAM,QACNpJ,QAASR,EAAS6J,gBAClBtK,MAAO,cACN,CACD2B,SAAS,QAAS,IAAM,EAAC,QAAajB,EAA8B,CAClEU,KAAM,UACJf,EAAO,MAAQA,EAAO,KAAM,QAAiB,UAAW,MAC5D+C,EAAG,GACF,EAAG,CAAC,eAAiB5C,EAAM+J,kBAAmB,WAAc,QAAoB,MAAOjE,GAAa,EAAC,QAAoB,MAAOC,GAAa,EAAC,QAAa7F,EAA8B,CAC1LU,KAAM,4BACF,QAAoB,MAAOoF,GAAa,EAAC,QAAoB,MAAOC,IAAa,QAAiBjG,EAAM+J,gBAAgBJ,SAAU,GAAI3J,EAAM+J,gBAAgBC,aAAc,WAAc,QAAoB,MAAO9D,IAAa,QAAiBlG,EAAM+J,gBAAgBC,YAAa,KAAM,QAAoB,IAAI,MAAS,QAAoB,MAAO7D,GAAa,CAACnG,EAAM+J,gBAAgBE,cAAe,WAAc,QAAa5C,EAAsB,CAC9b/G,IAAK,EACLY,KAAM,UACN2I,KAAM,QACNpJ,QAASR,EAASiK,gBACjB,CACD/I,SAAS,QAAS,IAAM,EAAC,QAAajB,EAA8B,CAClEU,KAAM,SACJf,EAAO,MAAQA,EAAO,KAAM,QAAiB,QAAS,MAC1D+C,EAAG,GACF,EAAG,CAAC,cAAe,QAAoB,IAAI,IAAO,QAAayE,EAAsB,CACtFnG,KAAM,UACN2I,KAAM,QACNpJ,QAASR,EAASkK,cACjB,CACDhJ,SAAS,QAAS,IAAM,IAAKtB,EAAO,MAAQA,EAAO,IAAM,EAAC,QAAiB,QAAS,OACpF+C,EAAG,GACF,EAAG,CAAC,mBAAoB,WAAc,QAAoB,MAAOwD,GAAa,EAAC,QAAajE,EAAuB,CACpHM,QAAS,+BACTC,UAAW,OACV,CACDvB,SAAS,QAAS,IAAM,EAAC,QAAakG,EAAsB,CAC1DnG,KAAM,UACNkJ,QAASpK,EAAMqK,WACf9H,SAAUvC,EAAMkJ,aAChBzI,QAASR,EAASqK,aAClB9K,MAAO,0BACN,CACD2B,SAAS,QAAS,IAAM,EAAC,QAAajB,EAA8B,CAClEU,KAAM,cACJ,QAAiB,KAAM,QAAiBZ,EAAMqK,WAAa,SAAW,QAAS,KACnFzH,EAAG,GACF,EAAG,CAAC,UAAW,WAAY,cAC9BA,EAAG,KACD,QAAaT,EAAuB,CACtCM,QAAS,wBACTC,UAAW,OACV,CACDvB,SAAS,QAAS,IAAM,EAAC,QAAakG,EAAsB,CAC1DnG,KAAM,UACNkJ,QAASpK,EAAMuK,QACfhI,SAAUvC,EAAMkJ,aAChBzI,QAASR,EAASuK,WAClBhL,MAAO,yBACN,CACD2B,SAAS,QAAS,IAAM,EAAC,QAAajB,EAA8B,CAClEU,KAAM,cACJ,QAAiB,KAAM,QAAiBZ,EAAMuK,QAAU,SAAW,QAAS,KAChF3H,EAAG,GACF,EAAG,CAAC,UAAW,WAAY,cAC9BA,EAAG,KACD,QAAaT,EAAuB,CACtCM,QAAS,6BACTC,UAAW,OACV,CACDvB,SAAS,QAAS,IAAM,EAAC,QAAoB,MAAOkF,GAAa,EAAC,QAAoB,QAAS,CAC7FnF,KAAM,OACNuJ,IAAK,YACLC,OAAQ,QACRC,SAAU9K,EAAO,KAAOA,EAAO,GAAK,IAAIiB,IAASb,EAAS2K,kBAAoB3K,EAAS2K,oBAAoB9J,IAC3G2H,MAAO,CACL,QAAW,SAEZ,KAAM,MAAM,QAAapB,EAAsB,CAChDnG,KAAM,UACNkJ,QAASpK,EAAM6K,UACftI,SAAUvC,EAAMkJ,aAChBzI,QAASR,EAAS6K,kBAClBtL,MAAO,0BACN,CACD2B,SAAS,QAAS,IAAM,EAAC,QAAajB,EAA8B,CAClEU,KAAM,YACJ,QAAiB,KAAM,QAAiBZ,EAAM6K,UAAY,SAAW,QAAS,KAClFjI,EAAG,GACF,EAAG,CAAC,UAAW,WAAY,gBAC9BA,EAAG,aACQ5C,EAAMyH,UAAUsD,YAAc/K,EAAMyH,UAAUuD,aAAc,WAAc,QAAoB,MAAO1E,GAAa,CAACtG,EAAMyH,UAAUsD,aAAc,WAAc,QAAoB,MAAO,CACrMzK,IAAK,EACLd,MAAO,kCACPiB,QAASZ,EAAO,KAAOA,EAAO,GAAKa,GAAUT,EAASgL,iBAAiBjL,EAAMyH,UAAUsD,cACtF,CAAC9K,EAASiL,YAAYlL,EAAMyH,UAAUsD,cAAgB/K,EAAMmL,WAAW,YAAa,WAAc,QAAa7D,EAAqB,CACrIhH,IAAK,EACL8K,IAAK,SAAWpL,EAAMyH,UAAUsD,WAAWM,GAAK,cAChDC,IAAK,QACL9L,MAAO,gBACP+L,QAAS1L,EAAO,KAAOA,EAAO,GAAKa,GAAUT,EAASuL,iBAAiB,YACtE,KAAM,EAAG,CAAC,SAAWvL,EAASwL,YAAYzL,EAAMyH,UAAUsD,cAAgB/K,EAAMmL,WAAW,YAAa,WAAc,QAAoB,QAAS,CACpJ7K,IAAK,EACL8K,IAAK,SAAWpL,EAAMyH,UAAUsD,WAAWM,GAAK,cAChD7L,MAAO,gBACPkM,MAAO,GACPC,KAAM,GACNC,SAAU,GACVL,QAAS1L,EAAO,KAAOA,EAAO,GAAKa,GAAUT,EAASuL,iBAAiB,YACtE,KAAM,GAAIjF,OAAiB,WAAc,QAAoB,MAAOC,GAAa,EAAC,QAAatG,EAA8B,CAC9HU,KAAM,WACNpB,MAAO,sBACF,QAAoB,MAAOiH,GAAa,EAAC,QAAavG,EAA8B,CACzFU,KAAM,aACJf,EAAO,MAAQA,EAAO,KAAM,QAAoB,OAAQ,KAAM,QAAS,OAAO,QAAoB,MAAO6G,GAAa,EAAC,QAAoB,MAAOC,IAAa,QAAiB3G,EAAMyH,UAAUsD,WAAWc,UAAUC,UAAY9L,EAAMyH,UAAUsD,WAAWM,IAAK,IAAI,QAAoB,MAAOzE,IAAa,QAAiB3G,EAAS2H,WAAW5H,EAAMyH,UAAUsD,WAAWc,UAAUE,YAAa,SAAU,QAAoB,IAAI,GAAO/L,EAAMyH,UAAUuD,aAAc,WAAc,QAAoB,MAAO,CACtf1K,IAAK,EACLd,MAAO,kCACPiB,QAASZ,EAAO,KAAOA,EAAO,GAAKa,GAAUT,EAASgL,iBAAiBjL,EAAMyH,UAAUuD,cACtF,CAAC/K,EAASiL,YAAYlL,EAAMyH,UAAUuD,cAAgBhL,EAAMmL,WAAW,YAAa,WAAc,QAAa7D,EAAqB,CACrIhH,IAAK,EACL8K,IAAK,SAAWpL,EAAMyH,UAAUuD,WAAWK,GAAK,cAChDC,IAAK,QACL9L,MAAO,gBACP+L,QAAS1L,EAAO,KAAOA,EAAO,GAAKa,GAAUT,EAASuL,iBAAiB,YACtE,KAAM,EAAG,CAAC,SAAWvL,EAASwL,YAAYzL,EAAMyH,UAAUuD,cAAgBhL,EAAMmL,WAAW,YAAa,WAAc,QAAoB,QAAS,CACpJ7K,IAAK,EACL8K,IAAK,SAAWpL,EAAMyH,UAAUuD,WAAWK,GAAK,cAChD7L,MAAO,gBACPkM,MAAO,GACPC,KAAM,GACNC,SAAU,GACVL,QAAS1L,EAAO,KAAOA,EAAO,GAAKa,GAAUT,EAASuL,iBAAiB,YACtE,KAAM,GAAI3E,OAAiB,WAAc,QAAoB,MAAOC,GAAa,EAAC,QAAa5G,EAA8B,CAC9HU,KAAM,WACNpB,MAAO,sBACF,QAAoB,MAAOuH,GAAa,EAAC,QAAa7G,EAA8B,CACzFU,KAAM,eACJf,EAAO,MAAQA,EAAO,KAAM,QAAoB,OAAQ,KAAM,QAAS,OAAO,QAAoB,MAAOmH,GAAa,EAAC,QAAoB,MAAOC,IAAa,QAAiBjH,EAAMyH,UAAUuD,WAAWa,UAAUC,UAAY9L,EAAMyH,UAAUuD,WAAWK,IAAK,IAAI,QAAoB,MAAOnE,IAAa,QAAiBjH,EAAS2H,WAAW5H,EAAMyH,UAAUuD,WAAWa,UAAUE,YAAa,SAAU,QAAoB,IAAI,OAAW,QAAoB,IAAI,MAAU,CAAC,CAACxE,EAAoBvH,EAAMoK,UACrf,C;;;;;;;ACnbA,SAASf,GAAM2C,GACb,OAAOA,EAAI,GAAM,CACnB,CACA,MAAMC,GAAMA,CAACD,EAAGE,EAAGC,IAAM/C,KAAKgD,IAAIhD,KAAKiD,IAAIL,EAAGG,GAAID,GAClD,SAASI,GAAIN,GACX,OAAOC,GAAI5C,GAAU,KAAJ2C,GAAW,EAAG,IACjC,CAIA,SAASO,GAAIP,GACX,OAAOC,GAAI5C,GAAU,IAAJ2C,GAAU,EAAG,IAChC,CACA,SAASQ,GAAIR,GACX,OAAOC,GAAI5C,GAAM2C,EAAI,MAAQ,IAAK,EAAG,EACvC,CACA,SAASS,GAAIT,GACX,OAAOC,GAAI5C,GAAU,IAAJ2C,GAAU,EAAG,IAChC,CAEA,MAAMU,GAAQ,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAGC,EAAG,GAAIC,EAAG,GAAIC,EAAG,GAAIC,EAAG,GAAIC,EAAG,GAAIC,EAAG,GAAIC,EAAG,GAAIC,EAAG,GAAIC,EAAG,GAAIC,EAAG,GAAI3O,EAAG,GAAI4O,EAAG,IACrJC,GAAM,IAAI,oBACVC,GAAKL,GAAKI,GAAQ,GAAJJ,GACdM,GAAKN,GAAKI,IAAS,IAAJJ,IAAa,GAAKI,GAAQ,GAAJJ,GACrCO,GAAKP,IAAW,IAAJA,IAAa,KAAY,GAAJA,GACjCQ,GAAU1B,GAAKyB,GAAGzB,EAAExN,IAAMiP,GAAGzB,EAAE2B,IAAMF,GAAGzB,EAAEkB,IAAMO,GAAGzB,EAAEiB,GAC3D,SAASW,GAASC,GAChB,IACIC,EADAC,EAAMF,EAAI1F,OAmBd,MAjBe,MAAX0F,EAAI,KACM,IAARE,GAAqB,IAARA,EACfD,EAAM,CACJtP,EAAG,IAAsB,GAAhBkO,GAAMmB,EAAI,IACnBF,EAAG,IAAsB,GAAhBjB,GAAMmB,EAAI,IACnBX,EAAG,IAAsB,GAAhBR,GAAMmB,EAAI,IACnBZ,EAAW,IAARc,EAA4B,GAAhBrB,GAAMmB,EAAI,IAAW,KAErB,IAARE,GAAqB,IAARA,IACtBD,EAAM,CACJtP,EAAGkO,GAAMmB,EAAI,KAAO,EAAInB,GAAMmB,EAAI,IAClCF,EAAGjB,GAAMmB,EAAI,KAAO,EAAInB,GAAMmB,EAAI,IAClCX,EAAGR,GAAMmB,EAAI,KAAO,EAAInB,GAAMmB,EAAI,IAClCZ,EAAW,IAARc,EAAarB,GAAMmB,EAAI,KAAO,EAAInB,GAAMmB,EAAI,IAAO,OAIrDC,CACT,CACA,MAAME,GAAQA,CAACf,EAAGI,IAAMJ,EAAI,IAAMI,EAAEJ,GAAK,GACzC,SAASgB,GAAUjC,GACjB,IAAIqB,EAAIK,GAAQ1B,GAAKuB,GAAKC,GAC1B,OAAOxB,EACH,IAAMqB,EAAErB,EAAExN,GAAK6O,EAAErB,EAAE2B,GAAKN,EAAErB,EAAEkB,GAAKc,GAAMhC,EAAEiB,EAAGI,QAC5Ca,CACN,CAEA,MAAMC,GAAS,+GACf,SAASC,GAASjC,EAAGkC,EAAGnC,GACtB,MAAMe,EAAIoB,EAAIjF,KAAKiD,IAAIH,EAAG,EAAIA,GACxBmB,EAAIA,CAACiB,EAAGC,GAAKD,EAAInC,EAAI,IAAM,KAAOD,EAAIe,EAAI7D,KAAKgD,IAAIhD,KAAKiD,IAAIkC,EAAI,EAAG,EAAIA,EAAG,IAAK,GACrF,MAAO,CAAClB,EAAE,GAAIA,EAAE,GAAIA,EAAE,GACxB,CACA,SAASmB,GAASrC,EAAGkC,EAAGrC,GACtB,MAAMqB,EAAIA,CAACiB,EAAGC,GAAKD,EAAInC,EAAI,IAAM,IAAMH,EAAIA,EAAIqC,EAAIjF,KAAKgD,IAAIhD,KAAKiD,IAAIkC,EAAG,EAAIA,EAAG,GAAI,GACnF,MAAO,CAAClB,EAAE,GAAIA,EAAE,GAAIA,EAAE,GACxB,CACA,SAASoB,GAAStC,EAAGuC,EAAGxB,GACtB,MAAMyB,EAAMP,GAASjC,EAAG,EAAG,IAC3B,IAAIzN,EAMJ,IALIgQ,EAAIxB,EAAI,IACVxO,EAAI,GAAKgQ,EAAIxB,GACbwB,GAAKhQ,EACLwO,GAAKxO,GAEFA,EAAI,EAAGA,EAAI,EAAGA,IACjBiQ,EAAIjQ,IAAM,EAAIgQ,EAAIxB,EAClByB,EAAIjQ,IAAMgQ,EAEZ,OAAOC,CACT,CACA,SAASC,GAASpQ,EAAGmP,EAAGT,EAAGE,EAAGhB,GAC5B,OAAI5N,IAAM4N,GACCuB,EAAIT,GAAKE,GAAMO,EAAIT,EAAI,EAAI,GAElCS,IAAMvB,GACAc,EAAI1O,GAAK4O,EAAI,GAEf5O,EAAImP,GAAKP,EAAI,CACvB,CACA,SAASyB,GAAQ7C,GACf,MAAM8C,EAAQ,IACRtQ,EAAIwN,EAAExN,EAAIsQ,EACVnB,EAAI3B,EAAE2B,EAAImB,EACV5B,EAAIlB,EAAEkB,EAAI4B,EACV1C,EAAMhD,KAAKgD,IAAI5N,EAAGmP,EAAGT,GACrBb,EAAMjD,KAAKiD,IAAI7N,EAAGmP,EAAGT,GACrBhB,GAAKE,EAAMC,GAAO,EACxB,IAAIF,EAAGkC,EAAGjB,EAOV,OANIhB,IAAQC,IACVe,EAAIhB,EAAMC,EACVgC,EAAInC,EAAI,GAAMkB,GAAK,EAAIhB,EAAMC,GAAOe,GAAKhB,EAAMC,GAC/CF,EAAIyC,GAASpQ,EAAGmP,EAAGT,EAAGE,EAAGhB,GACzBD,EAAQ,GAAJA,EAAS,IAER,CAAK,EAAJA,EAAOkC,GAAK,EAAGnC,EACzB,CACA,SAAS6C,GAAM1B,EAAGJ,EAAGC,EAAGC,GACtB,OACE6B,MAAMC,QAAQhC,GACVI,EAAEJ,EAAE,GAAIA,EAAE,GAAIA,EAAE,IAChBI,EAAEJ,EAAGC,EAAGC,IACZ+B,IAAI3C,GACR,CACA,SAAS4C,GAAQhD,EAAGkC,EAAGnC,GACrB,OAAO6C,GAAMX,GAAUjC,EAAGkC,EAAGnC,EAC/B,CACA,SAASkD,GAAQjD,EAAGuC,EAAGxB,GACrB,OAAO6B,GAAMN,GAAUtC,EAAGuC,EAAGxB,EAC/B,CACA,SAASmC,GAAQlD,EAAGkC,EAAGrC,GACrB,OAAO+C,GAAMP,GAAUrC,EAAGkC,EAAGrC,EAC/B,CACA,SAASsD,GAAInD,GACX,OAAQA,EAAI,IAAM,KAAO,GAC3B,CACA,SAASoD,GAAS1B,GAChB,MAAM2B,EAAIrB,GAAOsB,KAAK5B,GACtB,IACI7B,EADAiB,EAAI,IAER,IAAKuC,EACH,OAEEA,EAAE,KAAOxD,IACXiB,EAAIuC,EAAE,GAAKlD,IAAKkD,EAAE,IAAMjD,IAAKiD,EAAE,KAEjC,MAAMrD,EAAImD,IAAKE,EAAE,IACXE,GAAMF,EAAE,GAAK,IACbG,GAAMH,EAAE,GAAK,IAQnB,OANExD,EADW,QAATwD,EAAE,GACAJ,GAAQjD,EAAGuD,EAAIC,GACD,QAATH,EAAE,GACPH,GAAQlD,EAAGuD,EAAIC,GAEfR,GAAQhD,EAAGuD,EAAIC,GAEd,CACLnR,EAAGwN,EAAE,GACL2B,EAAG3B,EAAE,GACLkB,EAAGlB,EAAE,GACLiB,EAAGA,EAEP,CACA,SAAS2C,GAAO5D,EAAG6D,GACjB,IAAI1D,EAAI0C,GAAQ7C,GAChBG,EAAE,GAAKmD,GAAInD,EAAE,GAAK0D,GAClB1D,EAAIgD,GAAQhD,GACZH,EAAExN,EAAI2N,EAAE,GACRH,EAAE2B,EAAIxB,EAAE,GACRH,EAAEkB,EAAIf,EAAE,EACV,CACA,SAAS2D,GAAU9D,GACjB,IAAKA,EACH,OAEF,MAAMiB,EAAI4B,GAAQ7C,GACZG,EAAIc,EAAE,GACNoB,EAAI5B,GAAIQ,EAAE,IACVf,EAAIO,GAAIQ,EAAE,IAChB,OAAOjB,EAAEiB,EAAI,IACT,QAAQd,MAAMkC,OAAOnC,OAAOM,GAAIR,EAAEiB,MAClC,OAAOd,MAAMkC,OAAOnC,KAC1B,CAEA,MAAMgD,GAAM,CACXa,EAAG,OACHC,EAAG,QACHC,EAAG,KACHC,EAAG,MACHC,EAAG,KACHC,EAAG,SACHC,EAAG,QACH1D,EAAG,KACH2D,EAAG,KACHC,EAAG,KACH3D,EAAG,KACHC,EAAG,QACHC,EAAG,QACH0D,EAAG,KACHC,EAAG,WACH1D,EAAG,KACH2D,EAAG,KACHC,EAAG,KACHC,EAAG,KACHC,EAAG,KACHC,EAAG,QACH9D,EAAG,KACH+D,EAAG,KACHC,EAAG,OACHC,EAAG,KACHC,EAAG,QACHC,EAAG,MAEEC,GAAU,CACfC,OAAQ,SACRC,YAAa,SACbC,KAAM,OACNC,UAAW,SACXC,KAAM,SACNC,MAAO,SACPC,OAAQ,SACRC,MAAO,IACPC,aAAc,SACdC,GAAI,KACJC,QAAS,SACTC,KAAM,SACNC,UAAW,SACXC,OAAQ,SACRC,SAAU,SACVC,QAAS,SACTC,IAAK,SACLC,YAAa,SACbC,QAAS,SACTC,QAAS,SACTC,KAAM,OACNC,IAAK,KACLC,MAAO,OACPC,QAAS,SACTC,KAAM,SACNC,KAAM,OACNC,KAAM,SACNC,OAAQ,SACRC,QAAS,SACTC,SAAU,SACVC,OAAQ,SACRC,MAAO,SACPC,IAAK,SACLC,OAAQ,SACRC,OAAQ,SACRC,KAAM,SACNC,MAAO,SACPC,MAAO,SACPC,IAAK,OACLC,OAAQ,SACRC,OAAQ,SACRC,SAAU,OACVC,OAAQ,SACRC,OAAQ,SACRC,SAAU,SACVC,SAAU,SACVC,SAAU,SACVC,SAAU,SACVC,OAAQ,SACRC,QAAS,SACTC,UAAW,SACXC,IAAK,SACLC,OAAQ,SACRC,IAAK,SACLC,IAAK,OACLC,MAAO,SACPC,IAAK,SACLC,QAAS,SACTC,OAAQ,SACRC,QAAS,SACTC,MAAO,SACPC,KAAM,SACNC,MAAO,SACPC,OAAQ,SACRC,UAAW,SACXC,QAAS,SACTC,WAAY,SACZC,IAAK,SACLC,KAAM,SACNC,MAAO,SACPC,UAAW,SACXC,KAAM,SACNC,KAAM,SACNC,KAAM,SACNC,KAAM,SACNC,OAAQ,SACRC,OAAQ,SACRC,OAAQ,SACRC,MAAO,SACPC,MAAO,SACPC,QAAS,SACTC,IAAK,SACLC,KAAM,OACNC,QAAS,SACTC,IAAK,SACLC,OAAQ,SACRC,MAAO,SACPC,WAAY,SACZC,IAAK,KACLC,MAAO,SACPC,OAAQ,SACRC,OAAQ,SACRC,KAAM,SACNC,UAAW,OACXC,IAAK,SACLC,SAAU,SACVC,WAAY,SACZC,QAAS,SACTC,SAAU,SACVC,QAAS,SACTC,WAAY,SACZC,KAAM,KACNC,OAAQ,SACRC,KAAM,SACNC,QAAS,SACTC,MAAO,SACPC,QAAS,SACTC,KAAM,SACNC,UAAW,SACXC,OAAQ,SACRC,MAAO,SACPC,WAAY,SACZC,UAAW,SACXC,QAAS,SACTC,KAAM,SACNC,IAAK,SACLC,KAAM,SACNC,QAAS,SACTC,MAAO,SACPC,YAAa,SACbC,GAAI,SACJC,SAAU,SACVC,MAAO,SACPC,UAAW,SACXC,MAAO,SACPC,UAAW,SACXC,MAAO,SACPC,QAAS,SACTC,MAAO,SACPC,OAAQ,SACRC,MAAO,SACPC,IAAK,SACLC,KAAM,SACNC,KAAM,SACNC,KAAM,SACNC,SAAU,OACVC,OAAQ,SACRC,IAAK,SACLC,IAAK,OACLC,MAAO,SACPC,OAAQ,SACRC,GAAI,SACJC,MAAO,SACPC,IAAK,SACLC,KAAM,SACNC,UAAW,SACXC,GAAI,SACJC,MAAO,UAER,SAASC,KACP,MAAMC,EAAW,CAAC,EACZzS,EAAOhJ,OAAOgJ,KAAKmJ,IACnBuJ,EAAQ1b,OAAOgJ,KAAKiH,IAC1B,IAAIxQ,EAAGkc,EAAGrM,EAAGsM,EAAIC,EACjB,IAAKpc,EAAI,EAAGA,EAAIuJ,EAAKE,OAAQzJ,IAAK,CAEhC,IADAmc,EAAKC,EAAK7S,EAAKvJ,GACVkc,EAAI,EAAGA,EAAID,EAAMxS,OAAQyS,IAC5BrM,EAAIoM,EAAMC,GACVE,EAAKA,EAAGC,QAAQxM,EAAGW,GAAIX,IAEzBA,EAAIyM,SAAS5J,GAAQyJ,GAAK,IAC1BH,EAASI,GAAM,CAACvM,GAAK,GAAK,IAAMA,GAAK,EAAI,IAAU,IAAJA,EACjD,CACA,OAAOmM,CACT,CAEA,IAAIO,GACJ,SAASC,GAAUrN,GACZoN,KACHA,GAAQR,KACRQ,GAAME,YAAc,CAAC,EAAG,EAAG,EAAG,IAEhC,MAAMlO,EAAIgO,GAAMpN,EAAIuN,eACpB,OAAOnO,GAAK,CACVzO,EAAGyO,EAAE,GACLU,EAAGV,EAAE,GACLC,EAAGD,EAAE,GACLA,EAAgB,IAAbA,EAAE9E,OAAe8E,EAAE,GAAK,IAE/B,CAEA,MAAMoO,GAAS,uGACf,SAASC,GAASzN,GAChB,MAAM2B,EAAI6L,GAAO5L,KAAK5B,GACtB,IACIrP,EAAGmP,EAAGT,EADND,EAAI,IAER,GAAKuC,EAAL,CAGA,GAAIA,EAAE,KAAOhR,EAAG,CACd,MAAMwN,GAAKwD,EAAE,GACbvC,EAAIuC,EAAE,GAAKlD,GAAIN,GAAKC,GAAQ,IAAJD,EAAS,EAAG,IACtC,CAOA,OANAxN,GAAKgR,EAAE,GACP7B,GAAK6B,EAAE,GACPtC,GAAKsC,EAAE,GACPhR,EAAI,KAAOgR,EAAE,GAAKlD,GAAI9N,GAAKyN,GAAIzN,EAAG,EAAG,MACrCmP,EAAI,KAAO6B,EAAE,GAAKlD,GAAIqB,GAAK1B,GAAI0B,EAAG,EAAG,MACrCT,EAAI,KAAOsC,EAAE,GAAKlD,GAAIY,GAAKjB,GAAIiB,EAAG,EAAG,MAC9B,CACL1O,EAAGA,EACHmP,EAAGA,EACHT,EAAGA,EACHD,EAAGA,EAfL,CAiBF,CACA,SAASsO,GAAUvP,GACjB,OAAOA,IACLA,EAAEiB,EAAI,IACF,QAAQjB,EAAExN,MAAMwN,EAAE2B,MAAM3B,EAAEkB,MAAMV,GAAIR,EAAEiB,MACtC,OAAOjB,EAAExN,MAAMwN,EAAE2B,MAAM3B,EAAEkB,KAEjC,CAEA,MAAMsO,GAAKxP,GAAKA,GAAK,SAAgB,MAAJA,EAAqC,MAAzB5C,KAAKqS,IAAIzP,EAAG,EAAM,KAAe,KACxE0P,GAAO1P,GAAKA,GAAK,OAAUA,EAAI,MAAQ5C,KAAKqS,KAAKzP,EAAI,MAAS,MAAO,KAC3E,SAAS2P,GAAYC,EAAMC,EAAMtd,GAC/B,MAAMC,EAAIkd,GAAKlP,GAAIoP,EAAKpd,IAClBmP,EAAI+N,GAAKlP,GAAIoP,EAAKjO,IAClBT,EAAIwO,GAAKlP,GAAIoP,EAAK1O,IACxB,MAAO,CACL1O,EAAG+N,GAAIiP,GAAGhd,EAAID,GAAKmd,GAAKlP,GAAIqP,EAAKrd,IAAMA,KACvCmP,EAAGpB,GAAIiP,GAAG7N,EAAIpP,GAAKmd,GAAKlP,GAAIqP,EAAKlO,IAAMA,KACvCT,EAAGX,GAAIiP,GAAGtO,EAAI3O,GAAKmd,GAAKlP,GAAIqP,EAAK3O,IAAMA,KACvCD,EAAG2O,EAAK3O,EAAI1O,GAAKsd,EAAK5O,EAAI2O,EAAK3O,GAEnC,CAEA,SAAS6O,GAAO9P,EAAGtN,EAAGqd,GACpB,GAAI/P,EAAG,CACL,IAAIgQ,EAAMnN,GAAQ7C,GAClBgQ,EAAItd,GAAK0K,KAAKgD,IAAI,EAAGhD,KAAKiD,IAAI2P,EAAItd,GAAKsd,EAAItd,GAAKqd,EAAa,IAANrd,EAAU,IAAM,IACvEsd,EAAM7M,GAAQ6M,GACdhQ,EAAExN,EAAIwd,EAAI,GACVhQ,EAAE2B,EAAIqO,EAAI,GACVhQ,EAAEkB,EAAI8O,EAAI,EACZ,CACF,CACA,SAASC,GAAMjQ,EAAGkQ,GAChB,OAAOlQ,EAAI/M,OAAOkd,OAAOD,GAAS,CAAC,EAAGlQ,GAAKA,CAC7C,CACA,SAASoQ,GAAWC,GAClB,IAAIrQ,EAAI,CAACxN,EAAG,EAAGmP,EAAG,EAAGT,EAAG,EAAGD,EAAG,KAY9B,OAXI+B,MAAMC,QAAQoN,GACZA,EAAMlU,QAAU,IAClB6D,EAAI,CAACxN,EAAG6d,EAAM,GAAI1O,EAAG0O,EAAM,GAAInP,EAAGmP,EAAM,GAAIpP,EAAG,KAC3CoP,EAAMlU,OAAS,IACjB6D,EAAEiB,EAAIV,GAAI8P,EAAM,OAIpBrQ,EAAIiQ,GAAMI,EAAO,CAAC7d,EAAG,EAAGmP,EAAG,EAAGT,EAAG,EAAGD,EAAG,IACvCjB,EAAEiB,EAAIV,GAAIP,EAAEiB,IAEPjB,CACT,CACA,SAASsQ,GAAczO,GACrB,MAAsB,MAAlBA,EAAI0O,OAAO,GACNjB,GAASzN,GAEX0B,GAAS1B,EAClB,CACA,MAAM2O,GACJpe,WAAAA,CAAYie,GACV,GAAIA,aAAiBG,GACnB,OAAOH,EAET,MAAMnb,SAAcmb,EACpB,IAAIrQ,EACS,WAAT9K,EACF8K,EAAIoQ,GAAWC,GACG,WAATnb,IACT8K,EAAI4B,GAASyO,IAAUnB,GAAUmB,IAAUC,GAAcD,IAE3D9a,KAAKkb,KAAOzQ,EACZzK,KAAKmb,SAAW1Q,CAClB,CACA,SAAI2Q,GACF,OAAOpb,KAAKmb,MACd,CACA,OAAI/N,GACF,IAAI3C,EAAIiQ,GAAM1a,KAAKkb,MAInB,OAHIzQ,IACFA,EAAEiB,EAAIT,GAAIR,EAAEiB,IAEPjB,CACT,CACA,OAAI2C,CAAIiO,GACNrb,KAAKkb,KAAOL,GAAWQ,EACzB,CACArB,SAAAA,GACE,OAAOha,KAAKmb,OAASnB,GAAUha,KAAKkb,WAAQvO,CAC9C,CACAD,SAAAA,GACE,OAAO1M,KAAKmb,OAASzO,GAAU1M,KAAKkb,WAAQvO,CAC9C,CACA4B,SAAAA,GACE,OAAOvO,KAAKmb,OAAS5M,GAAUvO,KAAKkb,WAAQvO,CAC9C,CACA2O,GAAAA,CAAIC,EAAOC,GACT,GAAID,EAAO,CACT,MAAME,EAAKzb,KAAKoN,IACVsO,EAAKH,EAAMnO,IACjB,IAAIuO,EACJ,MAAMC,EAAIJ,IAAWG,EAAK,GAAMH,EAC1BrO,EAAI,EAAIyO,EAAI,EACZlQ,EAAI+P,EAAG/P,EAAIgQ,EAAGhQ,EACdmQ,IAAO1O,EAAIzB,KAAO,EAAIyB,GAAKA,EAAIzB,IAAM,EAAIyB,EAAIzB,IAAM,GAAK,EAC9DiQ,EAAK,EAAIE,EACTJ,EAAGxe,EAAI,IAAO4e,EAAKJ,EAAGxe,EAAI0e,EAAKD,EAAGze,EAAI,GACtCwe,EAAGrP,EAAI,IAAOyP,EAAKJ,EAAGrP,EAAIuP,EAAKD,EAAGtP,EAAI,GACtCqP,EAAG9P,EAAI,IAAOkQ,EAAKJ,EAAG9P,EAAIgQ,EAAKD,EAAG/P,EAAI,GACtC8P,EAAG/P,EAAIkQ,EAAIH,EAAG/P,GAAK,EAAIkQ,GAAKF,EAAGhQ,EAC/B1L,KAAKoN,IAAMqO,CACb,CACA,OAAOzb,IACT,CACAoa,WAAAA,CAAYmB,EAAOve,GAIjB,OAHIue,IACFvb,KAAKkb,KAAOd,GAAYpa,KAAKkb,KAAMK,EAAML,KAAMle,IAE1CgD,IACT,CACA0a,KAAAA,GACE,OAAO,IAAIO,GAAMjb,KAAKoN,IACxB,CACAX,KAAAA,CAAMf,GAEJ,OADA1L,KAAKkb,KAAKxP,EAAIV,GAAIU,GACX1L,IACT,CACA8b,OAAAA,CAAQtB,GACN,MAAMpN,EAAMpN,KAAKkb,KAEjB,OADA9N,EAAI1B,GAAK,EAAI8O,EACNxa,IACT,CACA+b,SAAAA,GACE,MAAM3O,EAAMpN,KAAKkb,KACXc,EAAMlU,GAAc,GAARsF,EAAInQ,EAAkB,IAARmQ,EAAIhB,EAAmB,IAARgB,EAAIzB,GAEnD,OADAyB,EAAInQ,EAAImQ,EAAIhB,EAAIgB,EAAIzB,EAAIqQ,EACjBhc,IACT,CACAic,OAAAA,CAAQzB,GACN,MAAMpN,EAAMpN,KAAKkb,KAEjB,OADA9N,EAAI1B,GAAK,EAAI8O,EACNxa,IACT,CACAkc,MAAAA,GACE,MAAMzR,EAAIzK,KAAKkb,KAIf,OAHAzQ,EAAExN,EAAI,IAAMwN,EAAExN,EACdwN,EAAE2B,EAAI,IAAM3B,EAAE2B,EACd3B,EAAEkB,EAAI,IAAMlB,EAAEkB,EACP3L,IACT,CACAmc,OAAAA,CAAQ3B,GAEN,OADAD,GAAOva,KAAKkb,KAAM,EAAGV,GACdxa,IACT,CACAoc,MAAAA,CAAO5B,GAEL,OADAD,GAAOva,KAAKkb,KAAM,GAAIV,GACfxa,IACT,CACAqc,QAAAA,CAAS7B,GAEP,OADAD,GAAOva,KAAKkb,KAAM,EAAGV,GACdxa,IACT,CACAsc,UAAAA,CAAW9B,GAET,OADAD,GAAOva,KAAKkb,KAAM,GAAIV,GACfxa,IACT,CACAqO,MAAAA,CAAOC,GAEL,OADAD,GAAOrO,KAAKkb,KAAM5M,GACXtO,IACT;;;;;;;AC3jBK,SAASuc,KACJ,CAML,MAAMC,GAAO,MAClB,IAAI1S,EAAK,EACT,MAAO,IAAMA,GACd,EAHmB,GAUb,SAAS2S,GAAc7e,GAC5B,OAAiB,OAAVA,QAA4B+O,IAAV/O,CAC3B,CAOO,SAAS8P,GAAqB9P,GACnC,GAAI6P,MAAMC,SAAWD,MAAMC,QAAQ9P,GACjC,OAAO,EAET,MAAM+B,EAAOjC,OAAOZ,UAAU4f,SAAStf,KAAKQ,GAC5C,MAAyB,YAArB+B,EAAKgd,MAAM,EAAG,IAAuC,WAAnBhd,EAAKgd,OAAO,EAIpD,CAOO,SAASC,GAAShf,GACvB,OAAiB,OAAVA,GAA4D,oBAA1CF,OAAOZ,UAAU4f,SAAStf,KAAKQ,EAC1D,CAMA,SAASif,GAAejf,GACtB,OAAyB,kBAAVA,GAAsBA,aAAiBL,SAAWuf,UAAUlf,EAC7E,CAUO,SAASmf,GAAgBnf,EAAgBof,GAC9C,OAAOH,GAAejf,GAASA,EAAQof,CACzC,CAOO,SAASC,GAAkBrf,EAAsBof,GACtD,MAAwB,qBAAVpf,EAAwBof,EAAepf,CACvD,C,MAEasf,GAAeA,CAACtf,EAAwBuf,IAClC,kBAAVvf,GAAsBA,EAAMwf,SAAS,KAC1CC,WAAWzf,GAAS,KACjBA,EAAQuf,EAEFG,GAAcA,CAAC1f,EAAwBuf,IACjC,kBAAVvf,GAAsBA,EAAMwf,SAAS,KAC1CC,WAAWzf,GAAS,IAAMuf,GACvBvf,EASA,SAAS2f,GACdC,EACAje,EACAke,GAEA,GAAID,GAAyB,oBAAZA,EAAGpgB,KAClB,OAAOogB,EAAGE,MAAMD,EAASle,EAE7B,CAuBO,SAASoe,GACdC,EACAJ,EACAC,EACAI,GAEA,IAAI1gB,EAAWqP,EAAa9F,EAC5B,GAAIgH,GAAQkQ,GAEV,GADApR,EAAMoR,EAAShX,OACXiX,EACF,IAAK1gB,EAAIqP,EAAM,EAAGrP,GAAK,EAAGA,IACxBqgB,EAAGpgB,KAAKqgB,EAASG,EAASzgB,GAAIA,QAGhC,IAAKA,EAAI,EAAGA,EAAIqP,EAAKrP,IACnBqgB,EAAGpgB,KAAKqgB,EAASG,EAASzgB,GAAIA,QAG7B,GAAIyf,GAASgB,GAGlB,IAFAlX,EAAOhJ,OAAOgJ,KAAKkX,GACnBpR,EAAM9F,EAAKE,OACNzJ,EAAI,EAAGA,EAAIqP,EAAKrP,IACnBqgB,EAAGpgB,KAAKqgB,EAASG,EAASlX,EAAKvJ,IAAKuJ,EAAKvJ,GAG/C,CAQO,SAAS2gB,GAAeC,EAAuBC,GACpD,IAAI7gB,EAAW8gB,EAAcC,EAAqBC,EAElD,IAAKJ,IAAOC,GAAMD,EAAGnX,SAAWoX,EAAGpX,OACjC,OAAO,EAGT,IAAKzJ,EAAI,EAAG8gB,EAAOF,EAAGnX,OAAQzJ,EAAI8gB,IAAQ9gB,EAIxC,GAHA+gB,EAAKH,EAAG5gB,GACRghB,EAAKH,EAAG7gB,GAEJ+gB,EAAGE,eAAiBD,EAAGC,cAAgBF,EAAGlf,QAAUmf,EAAGnf,MACzD,OAAO,EAIX,OAAO,CACT,CAMO,SAAS0b,GAAS2D,GACvB,GAAI3Q,GAAQ2Q,GACV,OAAOA,EAAO1Q,IAAI+M,IAGpB,GAAIkC,GAASyB,GAAS,CACpB,MAAMC,EAAS5gB,OAAO6gB,OAAO,MACvB7X,EAAOhJ,OAAOgJ,KAAK2X,GACnBG,EAAO9X,EAAKE,OAClB,IAAIoG,EAAI,EAER,KAAOA,EAAIwR,IAAQxR,EACjBsR,EAAO5X,EAAKsG,IAAM0N,GAAM2D,EAAO3X,EAAKsG,KAGtC,OAAOsR,C,CAGT,OAAOD,CACT,CAEA,SAASI,GAAW1f,GAClB,OAAmE,IAA5D,CAAC,YAAa,YAAa,eAAe2f,QAAQ3f,EAC3D,CAOO,SAAS4f,GAAQ5f,EAAauf,EAAmBD,EAAmBvX,GACzE,IAAK2X,GAAW1f,GACd,OAGF,MAAM6f,EAAON,EAAOvf,GACd8f,EAAOR,EAAOtf,GAEhB6d,GAASgC,IAAShC,GAASiC,GAE7BC,GAAMF,EAAMC,EAAM/X,GAElBwX,EAAOvf,GAAO2b,GAAMmE,EAExB,CA0BO,SAASC,GAASR,EAAWD,EAAqBvX,GACvD,MAAMiY,EAAUrR,GAAQ2Q,GAAUA,EAAS,CAACA,GACtCJ,EAAOc,EAAQnY,OAErB,IAAKgW,GAAS0B,GACZ,OAAOA,EAGTxX,EAAUA,GAAW,CAAC,EACtB,MAAMkY,EAASlY,EAAQkY,QAAUL,GACjC,IAAI1W,EAEJ,IAAK,IAAI9K,EAAI,EAAGA,EAAI8gB,IAAQ9gB,EAAG,CAE7B,GADA8K,EAAU8W,EAAQ5hB,IACbyf,GAAS3U,GACZ,SAGF,MAAMvB,EAAOhJ,OAAOgJ,KAAKuB,GACzB,IAAK,IAAI+E,EAAI,EAAGwR,EAAO9X,EAAKE,OAAQoG,EAAIwR,IAAQxR,EAC9CgS,EAAOtY,EAAKsG,GAAIsR,EAAQrW,EAASnB,EAErC,CAEA,OAAOwX,CACT,CAgBO,SAASW,GAAWX,EAAWD,GAEpC,OAAOS,GAASR,EAAQD,EAAQ,CAACW,OAAQE,IAC3C,CAMO,SAASA,GAAUngB,EAAauf,EAAmBD,GACxD,IAAKI,GAAW1f,GACd,OAGF,MAAM6f,EAAON,EAAOvf,GACd8f,EAAOR,EAAOtf,GAEhB6d,GAASgC,IAAShC,GAASiC,GAC7BI,GAAQL,EAAMC,GACJnhB,OAAOZ,UAAUqiB,eAAe/hB,KAAKkhB,EAAQvf,KACvDuf,EAAOvf,GAAO2b,GAAMmE,GAExB,CAaA,MAAMO,GAAe,CAEnB,GAAI3U,GAAKA,EAET+D,EAAG9R,GAAKA,EAAE8R,EACV6Q,EAAG3iB,GAAKA,EAAE2iB,GAML,SAASC,GAAUvgB,GACxB,MAAMwgB,EAAQxgB,EAAIygB,MAAM,KAClB9Y,EAAiB,GACvB,IAAI+T,EAAM,GACV,IAAK,MAAMgF,KAAQF,EACjB9E,GAAOgF,EACHhF,EAAI2C,SAAS,MACf3C,EAAMA,EAAIkC,MAAM,GAAI,GAAK,KAEzBjW,EAAKgZ,KAAKjF,GACVA,EAAM,IAGV,OAAO/T,CACT,CAEA,SAASiZ,GAAgB5gB,GACvB,MAAM2H,EAAO4Y,GAAUvgB,GACvB,OAAOsc,IACL,IAAK,MAAMrO,KAAKtG,EAAM,CACpB,GAAU,KAANsG,EAGF,MAEFqO,EAAMA,GAAOA,EAAIrO,EACnB,CACA,OAAOqO,EAEX,CAEO,SAASuE,GAAiBvE,EAAgBtc,GAC/C,MAAM8gB,EAAWT,GAAargB,KAASqgB,GAAargB,GAAO4gB,GAAgB5gB,IAC3E,OAAO8gB,EAASxE,EAClB,CAKO,SAASyE,GAAYxT,GAC1B,OAAOA,EAAI0O,OAAO,GAAG+E,cAAgBzT,EAAIqQ,MAAM,EACjD,C,MAGaqD,GAAWpiB,GAAoC,qBAAVA,EAErCqiB,GAAcriB,GAAsE,oBAAVA,EAG1EsiB,GAAYA,CAAIxU,EAAWC,KACtC,GAAID,EAAEpD,OAASqD,EAAErD,KACf,OAAO,EAGT,IAAK,MAAMxJ,KAAQ4M,EACjB,IAAKC,EAAEwU,IAAIrhB,GACT,OAAO,EAIX,OAAO,GAOF,SAASshB,GAAcljB,GAC5B,MAAkB,YAAXA,EAAEyC,MAAiC,UAAXzC,EAAEyC,MAA+B,gBAAXzC,EAAEyC,IACzD,CCvZO,MAAM0gB,GAAKxY,KAAKwY,GACVC,GAAM,EAAID,GACVE,GAAQD,GAAMD,GACdG,GAAWjjB,OAAOkjB,kBAClBC,GAAcL,GAAK,IACnBM,GAAUN,GAAK,EACfO,GAAaP,GAAK,EAClBQ,GAAqB,EAALR,GAAS,EAEzBS,GAAQjZ,KAAKiZ,MACbC,GAAOlZ,KAAKkZ,KAElB,SAASC,GAAaxS,EAAW6Q,EAAW4B,GACjD,OAAOpZ,KAAKqZ,IAAI1S,EAAI6Q,GAAK4B,CAC3B,CAKO,SAASE,GAAQ5T,GACtB,MAAM6T,EAAevZ,KAAKC,MAAMyF,GAChCA,EAAQyT,GAAazT,EAAO6T,EAAc7T,EAAQ,KAAQ6T,EAAe7T,EACzE,MAAM8T,EAAYxZ,KAAKqS,IAAI,GAAIrS,KAAKyZ,MAAMR,GAAMvT,KAC1CgU,EAAWhU,EAAQ8T,EACnBG,EAAeD,GAAY,EAAI,EAAIA,GAAY,EAAI,EAAIA,GAAY,EAAI,EAAI,GACjF,OAAOC,EAAeH,CACxB,CAMO,SAASI,GAAW7jB,GACzB,MAAM8jB,EAAmB,GACnBC,EAAO9Z,KAAK8Z,KAAK/jB,GACvB,IAAIT,EAEJ,IAAKA,EAAI,EAAGA,EAAIwkB,EAAMxkB,IAChBS,EAAQT,IAAM,IAChBukB,EAAOhC,KAAKviB,GACZukB,EAAOhC,KAAK9hB,EAAQT,IAQxB,OALIwkB,KAAiB,EAAPA,IACZD,EAAOhC,KAAKiC,GAGdD,EAAOE,KAAK,CAAClW,EAAGC,IAAMD,EAAIC,GAAGkW,MACtBH,CACT,CAKA,SAASI,GAAe/U,GACtB,MAAoB,kBAANA,GAAgC,kBAANA,GAAwB,OAANA,KAAgBpQ,OAAOI,eAAegQ,GAAK,aAAcA,GAAK,YAAaA,EACvI,CAEO,SAASgV,GAAShV,GACvB,OAAQ+U,GAAe/U,KAAOiV,MAAM3E,WAAWtQ,KAAiB+P,SAAS/P,EAC3E,CAEO,SAASkV,GAAYzT,EAAWyS,GACrC,MAAMiB,EAAUra,KAAKC,MAAM0G,GAC3B,OAAO0T,EAAYjB,GAAYzS,GAAQ0T,EAAUjB,GAAYzS,CAC/D,CAKO,SAAS2T,GACdC,EACA9D,EACA+D,GAEA,IAAIllB,EAAW8gB,EAAcrgB,EAE7B,IAAKT,EAAI,EAAG8gB,EAAOmE,EAAMxb,OAAQzJ,EAAI8gB,EAAM9gB,IACzCS,EAAQwkB,EAAMjlB,GAAGklB,GACZL,MAAMpkB,KACT0gB,EAAOxT,IAAMjD,KAAKiD,IAAIwT,EAAOxT,IAAKlN,GAClC0gB,EAAOzT,IAAMhD,KAAKgD,IAAIyT,EAAOzT,IAAKjN,GAGxC,CAEO,SAAS0kB,GAAUC,GACxB,OAAOA,GAAWlC,GAAK,IACzB,CAEO,SAASmC,GAAUC,GACxB,OAAOA,GAAW,IAAMpC,GAC1B,CASO,SAASqC,GAAelU,GAC7B,IAAKqO,GAAerO,GAClB,OAEF,IAAItR,EAAI,EACJ0e,EAAI,EACR,MAAO/T,KAAKC,MAAM0G,EAAItR,GAAKA,IAAMsR,EAC/BtR,GAAK,GACL0e,IAEF,OAAOA,CACT,CAGO,SAAS+G,GACdC,EACAC,GAEA,MAAMC,EAAsBD,EAAWrU,EAAIoU,EAAYpU,EACjDuU,EAAsBF,EAAWxD,EAAIuD,EAAYvD,EACjD2D,EAA2Bnb,KAAK8Z,KAAKmB,EAAsBA,EAAsBC,EAAsBA,GAE7G,IAAIE,EAAQpb,KAAKqb,MAAMH,EAAqBD,GAM5C,OAJIG,GAAU,GAAM5C,KAClB4C,GAAS3C,IAGJ,CACL2C,QACAE,SAAUH,EAEd,CAEO,SAASI,GAAsBC,EAAYC,GAChD,OAAOzb,KAAK8Z,KAAK9Z,KAAKqS,IAAIoJ,EAAI9U,EAAI6U,EAAI7U,EAAG,GAAK3G,KAAKqS,IAAIoJ,EAAIjE,EAAIgE,EAAIhE,EAAG,GACxE,CAMO,SAASkE,GAAW7X,EAAWC,GACpC,OAAQD,EAAIC,EAAI4U,IAASD,GAAMD,EACjC,CAMO,SAASmD,GAAgB9X,GAC9B,OAAQA,EAAI4U,GAAMA,IAAOA,EAC3B,CAKO,SAASmD,GAAcR,EAAeS,EAAeC,EAAaC,GACvE,MAAMlY,EAAI8X,GAAgBP,GACpBnW,EAAI0W,GAAgBE,GACpBxmB,EAAIsmB,GAAgBG,GACpBE,EAAeL,GAAgB1W,EAAIpB,GACnCoY,EAAaN,GAAgBtmB,EAAIwO,GACjCqY,EAAeP,GAAgB9X,EAAIoB,GACnCkX,EAAaR,GAAgB9X,EAAIxO,GACvC,OAAOwO,IAAMoB,GAAKpB,IAAMxO,GAAM0mB,GAAyB9W,IAAM5P,GACvD2mB,EAAeC,GAAcC,EAAeC,CACpD,CASO,SAASC,GAAYrmB,EAAekN,EAAaD,GACtD,OAAOhD,KAAKgD,IAAIC,EAAKjD,KAAKiD,IAAID,EAAKjN,GACrC,CAMO,SAASsmB,GAAYtmB,GAC1B,OAAOqmB,GAAYrmB,GAAQ,MAAO,MACpC,CASO,SAASumB,GAAWvmB,EAAe8lB,EAAeC,EAAa1C,EAAU,MAC9E,OAAOrjB,GAASiK,KAAKiD,IAAI4Y,EAAOC,GAAO1C,GAAWrjB,GAASiK,KAAKgD,IAAI6Y,EAAOC,GAAO1C,CACpF,CC3LO,SAASmD,GACdC,EACAzmB,EACA0mB,GAEAA,EAAMA,GAAA,CAAStlB,GAAUqlB,EAAMrlB,GAASpB,GACxC,IAEI2mB,EAFAC,EAAKH,EAAMzd,OAAS,EACpB6d,EAAK,EAGT,MAAOD,EAAKC,EAAK,EACfF,EAAOE,EAAKD,GAAO,EACfF,EAAIC,GACNE,EAAKF,EAELC,EAAKD,EAIT,MAAO,CAACE,KAAID,KACd,CAUO,MAAME,GAAeA,CAC1BL,EACAtlB,EACAnB,EACA+mB,IAEAP,GAAQC,EAAOzmB,EAAO+mB,EAClB3lB,IACA,MAAM4lB,EAAKP,EAAMrlB,GAAOD,GACxB,OAAO6lB,EAAKhnB,GAASgnB,IAAOhnB,GAASymB,EAAMrlB,EAAQ,GAAGD,KAASnB,GAE/DoB,GAASqlB,EAAMrlB,GAAOD,GAAOnB,GAStBinB,GAAgBA,CAC3BR,EACAtlB,EACAnB,IAEAwmB,GAAQC,EAAOzmB,EAAOoB,GAASqlB,EAAMrlB,GAAOD,IAAQnB,GAS/C,SAASknB,GAAeC,EAAkBja,EAAaD,GAC5D,IAAI6Y,EAAQ,EACRC,EAAMoB,EAAOne,OAEjB,MAAO8c,EAAQC,GAAOoB,EAAOrB,GAAS5Y,EACpC4Y,IAEF,MAAOC,EAAMD,GAASqB,EAAOpB,EAAM,GAAK9Y,EACtC8Y,IAGF,OAAOD,EAAQ,GAAKC,EAAMoB,EAAOne,OAC7Bme,EAAOpI,MAAM+G,EAAOC,GACpBoB,CACN,CAEA,MAAMC,GAAc,CAAC,OAAQ,MAAO,QAAS,SAAU,WAgBhD,SAASC,GAAkB7C,EAAO8C,GACnC9C,EAAM+C,SACR/C,EAAM+C,SAASC,UAAU1F,KAAKwF,IAIhCxnB,OAAOC,eAAeykB,EAAO,WAAY,CACvCtkB,cAAc,EACdD,YAAY,EACZD,MAAO,CACLwnB,UAAW,CAACF,MAIhBF,GAAYK,QAAStmB,IACnB,MAAMumB,EAAS,UAAYxF,GAAY/gB,GACjCwmB,EAAOnD,EAAMrjB,GAEnBrB,OAAOC,eAAeykB,EAAOrjB,EAAK,CAChCjB,cAAc,EACdD,YAAY,EACZD,KAAAA,IAAS2B,GACP,MAAMimB,EAAMD,EAAK7H,MAAM1d,KAAMT,GAQ7B,OANA6iB,EAAM+C,SAASC,UAAUC,QAASI,IACF,oBAAnBA,EAAOH,IAChBG,EAAOH,MAAW/lB,KAIfimB,CACT,MAGN,CAQO,SAASE,GAAoBtD,EAAO8C,GACzC,MAAMS,EAAOvD,EAAM+C,SACnB,IAAKQ,EACH,OAGF,MAAMP,EAAYO,EAAKP,UACjBpmB,EAAQomB,EAAU1G,QAAQwG,IACjB,IAAXlmB,GACFomB,EAAUQ,OAAO5mB,EAAO,GAGtBomB,EAAUxe,OAAS,IAIvBoe,GAAYK,QAAStmB,WACZqjB,EAAMrjB,YAGRqjB,EAAM+C,SACf,CAKO,SAASU,GAAgBC,GAC9B,MAAMC,EAAM,IAAIC,IAAOF,GAEvB,OAAIC,EAAIzd,OAASwd,EAAMlf,OACdkf,EAGFrY,MAAM0M,KAAK4L,EACpB,CClLa,MAAAE,GAAoB,WAC/B,MAAsB,qBAAX7lB,OACF,SAASmd,GACd,OAAOA,GACT,EAEKnd,OAAO8lB,qBAChB,CAPiC,GAa1B,SAASC,GACd3I,EACAC,GAEA,IAAI2I,EAAY,GACZC,GAAU,EAEd,OAAO,YAAY9mB,GAEjB6mB,EAAY7mB,EACP8mB,IACHA,GAAU,EACVJ,GAAiB7oB,KAAKgD,OAAQ,KAC5BimB,GAAU,EACV7I,EAAGE,MAAMD,EAAS2I,KAGxB,CACF,CAKO,SAASE,GAAmC9I,EAA8B+I,GAC/E,IAAIC,EACJ,OAAO,YAAYjnB,GAOjB,OANIgnB,GACFE,aAAaD,GACbA,EAAUE,WAAWlJ,EAAI+I,EAAOhnB,IAEhCie,EAAGE,MAAM1d,KAAMT,GAEVgnB,CACT,CACF,CAMO,MAAMI,GAAsBC,GAAgD,UAAVA,EAAoB,OAAmB,QAAVA,EAAkB,QAAU,SAMrHC,GAAiBA,CAACD,EAAmClD,EAAeC,IAA0B,UAAViD,EAAoBlD,EAAkB,QAAVkD,EAAkBjD,GAAOD,EAAQC,GAAO,EAMxJmD,GAASA,CAACF,EAAoCG,EAAcC,EAAeC,KACtF,MAAMC,EAAQD,EAAM,OAAS,QAC7B,OAAOL,IAAUM,EAAQF,EAAkB,WAAVJ,GAAsBG,EAAOC,GAAS,EAAID,GAOtE,SAASI,GAAiCC,EAAqCC,EAAwBC,GAC5G,MAAMC,EAAaF,EAAOzgB,OAE1B,IAAI8c,EAAQ,EACR1c,EAAQugB,EAEZ,GAAIH,EAAKI,QAAS,CAChB,MAAM,OAACC,EAAM,OAAEC,EAAA,QAAQC,GAAWP,EAC5BQ,EAAWR,EAAKS,SAAUT,EAAKS,QAAQ/gB,QAAUsgB,EAAKS,QAAQ/gB,QAAQ8gB,SAAkB,KACxFE,EAAOL,EAAOK,MACd,IAAChd,EAAG,IAAED,EAAG,WAAEkd,EAAU,WAAEC,GAAcP,EAAOQ,gBAElD,GAAIF,EAAY,CAMd,GALArE,EAAQ7b,KAAKiD,IAEX4Z,GAAaiD,EAASG,EAAMhd,GAAK2Z,GAEjC6C,EAAqBC,EAAa7C,GAAa2C,EAAQS,EAAML,EAAOS,iBAAiBpd,IAAM2Z,IACzFmD,EAAU,CACZ,MAAMO,EAAuBR,EAC1BhL,MAAM,EAAG+G,EAAQ,GACjB7F,UACAuK,UACCC,IAAU5L,GAAc4L,EAAMX,EAAOI,QACzCpE,GAAS7b,KAAKgD,IAAI,EAAGsd,E,CAEvBzE,EAAQO,GAAYP,EAAO,EAAG6D,EAAa,E,CAE7C,GAAIS,EAAY,CACd,IAAIrE,EAAM9b,KAAKgD,IAEb6Z,GAAaiD,EAASF,EAAOK,KAAMjd,GAAK,GAAM2Z,GAAK,EAEnD8C,EAAqB,EAAI5C,GAAa2C,EAAQS,EAAML,EAAOS,iBAAiBrd,IAAM,GAAM2Z,GAAK,GAC/F,GAAIoD,EAAU,CACZ,MAAMU,EAAuBX,EAC1BhL,MAAMgH,EAAM,GACZyE,UACCC,IAAU5L,GAAc4L,EAAMX,EAAOI,QACzCnE,GAAO9b,KAAKgD,IAAI,EAAGyd,E,CAErBthB,EAAQid,GAAYN,EAAKD,EAAO6D,GAAc7D,C,MAE9C1c,EAAQugB,EAAa7D,C,CAIzB,MAAO,CAACA,QAAO1c,QACjB,CAQO,SAASuhB,GAAoBnB,GAClC,MAAM,OAACoB,EAAM,OAAEC,EAAA,aAAQC,GAAgBtB,EACjCuB,EAAY,CAChBC,KAAMJ,EAAO1d,IACb+d,KAAML,EAAO3d,IACbie,KAAML,EAAO3d,IACbie,KAAMN,EAAO5d,KAEf,IAAK6d,EAEH,OADAtB,EAAKsB,aAAeC,GACb,EAET,MAAMK,EAAUN,EAAaE,OAASJ,EAAO1d,KAC1C4d,EAAaG,OAASL,EAAO3d,KAC7B6d,EAAaI,OAASL,EAAO3d,KAC7B4d,EAAaK,OAASN,EAAO5d,IAGhC,OADAnN,OAAOkd,OAAO8N,EAAcC,GACrBK,CACT,CChKA,MAAMC,GAAUjsB,GAAoB,IAANA,GAAiB,IAANA,EACnCksB,GAAYA,CAAClsB,EAAW8P,EAAW8O,KAAgB/T,KAAKqS,IAAI,EAAG,IAAMld,GAAK,IAAM6K,KAAKshB,KAAKnsB,EAAI8P,GAAKwT,GAAM1E,GACzGwN,GAAaA,CAACpsB,EAAW8P,EAAW8O,IAAc/T,KAAKqS,IAAI,GAAI,GAAKld,GAAK6K,KAAKshB,KAAKnsB,EAAI8P,GAAKwT,GAAM1E,GAAK,EAOvGyN,GAAU,CACdC,OAAStsB,GAAcA,EAEvBusB,WAAavsB,GAAcA,EAAIA,EAE/BwsB,YAAcxsB,IAAeA,GAAKA,EAAI,GAEtCysB,cAAgBzsB,IAAgBA,GAAK,IAAO,EACxC,GAAMA,EAAIA,GACT,MAAUA,GAAMA,EAAI,GAAK,GAE9B0sB,YAAc1sB,GAAcA,EAAIA,EAAIA,EAEpC2sB,aAAe3sB,IAAeA,GAAK,GAAKA,EAAIA,EAAI,EAEhD4sB,eAAiB5sB,IAAgBA,GAAK,IAAO,EACzC,GAAMA,EAAIA,EAAIA,EACd,KAAQA,GAAK,GAAKA,EAAIA,EAAI,GAE9B6sB,YAAc7sB,GAAcA,EAAIA,EAAIA,EAAIA,EAExC8sB,aAAe9sB,MAAiBA,GAAK,GAAKA,EAAIA,EAAIA,EAAI,GAEtD+sB,eAAiB/sB,IAAgBA,GAAK,IAAO,EACzC,GAAMA,EAAIA,EAAIA,EAAIA,GACjB,KAAQA,GAAK,GAAKA,EAAIA,EAAIA,EAAI,GAEnCgtB,YAAchtB,GAAcA,EAAIA,EAAIA,EAAIA,EAAIA,EAE5CitB,aAAejtB,IAAeA,GAAK,GAAKA,EAAIA,EAAIA,EAAIA,EAAI,EAExDktB,eAAiBltB,IAAgBA,GAAK,IAAO,EACzC,GAAMA,EAAIA,EAAIA,EAAIA,EAAIA,EACtB,KAAQA,GAAK,GAAKA,EAAIA,EAAIA,EAAIA,EAAI,GAEtCmtB,WAAantB,GAAuC,EAAxB6K,KAAKuiB,IAAIptB,EAAI2jB,IAEzC0J,YAAcrtB,GAAc6K,KAAKshB,IAAInsB,EAAI2jB,IAEzC2J,cAAgBttB,IAAe,IAAO6K,KAAKuiB,IAAI/J,GAAKrjB,GAAK,GAEzDutB,WAAavtB,GAAqB,IAAPA,EAAY,EAAI6K,KAAKqS,IAAI,EAAG,IAAMld,EAAI,IAEjEwtB,YAAcxtB,GAAqB,IAAPA,EAAY,EAA4B,EAAvB6K,KAAKqS,IAAI,GAAI,GAAKld,GAE/DytB,cAAgBztB,GAAcisB,GAAOjsB,GAAKA,EAAIA,EAAI,GAC9C,GAAM6K,KAAKqS,IAAI,EAAG,IAAU,EAAJld,EAAQ,IAChC,IAAyC,EAAjC6K,KAAKqS,IAAI,GAAI,IAAU,EAAJld,EAAQ,KAEvC0tB,WAAa1tB,GAAcA,GAAM,EAAKA,IAAM6K,KAAK8Z,KAAK,EAAI3kB,EAAIA,GAAK,GAEnE2tB,YAAc3tB,GAAc6K,KAAK8Z,KAAK,GAAK3kB,GAAK,GAAKA,GAErD4tB,cAAgB5tB,IAAgBA,GAAK,IAAO,GACvC,IAAO6K,KAAK8Z,KAAK,EAAI3kB,EAAIA,GAAK,GAC/B,IAAO6K,KAAK8Z,KAAK,GAAK3kB,GAAK,GAAKA,GAAK,GAEzC6tB,cAAgB7tB,GAAcisB,GAAOjsB,GAAKA,EAAIksB,GAAUlsB,EAAG,KAAO,IAElE8tB,eAAiB9tB,GAAcisB,GAAOjsB,GAAKA,EAAIosB,GAAWpsB,EAAG,KAAO,IAEpE+tB,gBAAAA,CAAiB/tB,GACf,MAAM8P,EAAI,MACJ8O,EAAI,IACV,OAAOqN,GAAOjsB,GAAKA,EACjBA,EAAI,GACA,GAAMksB,GAAc,EAAJlsB,EAAO8P,EAAG8O,GAC1B,GAAM,GAAMwN,GAAe,EAAJpsB,EAAQ,EAAG8P,EAAG8O,EAC7C,EAEAoP,UAAAA,CAAWhuB,GACT,MAAM8P,EAAI,QACV,OAAO9P,EAAIA,IAAM8P,EAAI,GAAK9P,EAAI8P,EAChC,EAEAme,WAAAA,CAAYjuB,GACV,MAAM8P,EAAI,QACV,OAAQ9P,GAAK,GAAKA,IAAM8P,EAAI,GAAK9P,EAAI8P,GAAK,CAC5C,EAEAoe,aAAAA,CAAcluB,GACZ,IAAI8P,EAAI,QACR,OAAK9P,GAAK,IAAO,EACDA,EAAIA,IAAuB,GAAhB8P,GAAM,QAAe9P,EAAI8P,GAA3C,GAEF,KAAQ9P,GAAK,GAAKA,IAAuB,GAAhB8P,GAAM,QAAe9P,EAAI8P,GAAK,EAChE,EAEAqe,aAAenuB,GAAc,EAAIqsB,GAAQ+B,cAAc,EAAIpuB,GAE3DouB,aAAAA,CAAcpuB,GACZ,MAAMiR,EAAI,OACJpC,EAAI,KACV,OAAI7O,EAAK,EAAI6O,EACJoC,EAAIjR,EAAIA,EAEbA,EAAK,EAAI6O,EACJoC,GAAKjR,GAAM,IAAM6O,GAAM7O,EAAI,IAEhCA,EAAK,IAAM6O,EACNoC,GAAKjR,GAAM,KAAO6O,GAAM7O,EAAI,MAE9BiR,GAAKjR,GAAM,MAAQ6O,GAAM7O,EAAI,OACtC,EAEAquB,gBAAkBruB,GAAeA,EAAI,GACH,GAA9BqsB,GAAQ8B,aAAiB,EAAJnuB,GACc,GAAnCqsB,GAAQ+B,cAAkB,EAAJpuB,EAAQ,GAAW,ICpHxC,SAASsuB,GAAoB1tB,GAClC,GAAIA,GAA0B,kBAAVA,EAAoB,CACtC,MAAM+B,EAAO/B,EAAM8e,WACnB,MAAgB,2BAAT/c,GAA8C,4BAATA,C,CAG9C,OAAO,CACT,CAWO,SAAS4b,GAAM3d,GACpB,OAAO0tB,GAAoB1tB,GAASA,EAAQ,IAAIqd,GAAMrd,EACxD,CAKO,SAAS2tB,GAAc3tB,GAC5B,OAAO0tB,GAAoB1tB,GACvBA,EACA,IAAIqd,GAAMrd,GAAOye,SAAS,IAAKD,OAAO,IAAK1P,WACjD,CC/BA,MAAM8e,GAAU,CAAC,IAAK,IAAK,cAAe,SAAU,WAC9CC,GAAS,CAAC,QAAS,cAAe,mBAEjC,SAASC,GAAwBC,GACtCA,EAAS5F,IAAI,YAAa,CACxBQ,WAAO5Z,EACPif,SAAU,IACVC,OAAQ,eACRrO,QAAI7Q,EACJwN,UAAMxN,EACNvC,UAAMuC,EACNsN,QAAItN,EACJhN,UAAMgN,IAGRgf,EAASG,SAAS,YAAa,CAC7BC,WAAW,EACXC,YAAY,EACZC,YAAcxsB,GAAkB,eAATA,GAAkC,eAATA,GAAkC,OAATA,IAG3EksB,EAAS5F,IAAI,aAAc,CACzB0F,OAAQ,CACN9rB,KAAM,QACNusB,WAAYT,IAEdD,QAAS,CACP7rB,KAAM,SACNusB,WAAYV,MAIhBG,EAASG,SAAS,aAAc,CAC9BC,UAAW,cAGbJ,EAAS5F,IAAI,cAAe,CAC1BoG,OAAQ,CACNC,UAAW,CACTR,SAAU,MAGdS,OAAQ,CACND,UAAW,CACTR,SAAU,IAGdU,KAAM,CACJC,WAAY,CACVd,OAAQ,CACNtR,KAAM,eAERqS,QAAS,CACP7sB,KAAM,UACNisB,SAAU,KAIhBa,KAAM,CACJF,WAAY,CACVd,OAAQ,CACNxR,GAAI,eAENuS,QAAS,CACP7sB,KAAM,UACNksB,OAAQ,SACRrO,GAAI/S,GAAS,EAAJA,MAKnB,CCvEO,SAASiiB,GAAqBf,GACnCA,EAAS5F,IAAI,SAAU,CACrB4G,aAAa,EACbC,QAAS,CACPC,IAAK,EACL7F,MAAO,EACP8F,OAAQ,EACR/F,KAAM,IAGZ,CCTA,MAAMgG,GAAY,IAAIC,IAEtB,SAASC,GAAgBC,EAAgBpmB,GACvCA,EAAUA,GAAW,CAAC,EACtB,MAAMqmB,EAAWD,EAASE,KAAKC,UAAUvmB,GACzC,IAAIwmB,EAAYP,GAAUQ,IAAIJ,GAK9B,OAJKG,IACHA,EAAY,IAAIE,KAAKC,aAAaP,EAAQpmB,GAC1CimB,GAAUhH,IAAIoH,EAAUG,IAEnBA,CACT,CAEO,SAASI,GAAaC,EAAaT,EAAgBpmB,GACxD,OAAOmmB,GAAgBC,EAAQpmB,GAAS8mB,OAAOD,EACjD,CCRA,MAAME,GAAa,CAOjB9I,MAAAA,CAAOnnB,GACL,OAAO8P,GAAQ9P,GAAkCA,EAAS,GAAKA,CACjE,EAUAkwB,OAAAA,CAAQC,EAAW/uB,EAAOgvB,GACxB,GAAkB,IAAdD,EACF,MAAO,IAGT,MAAMb,EAASltB,KAAKiuB,MAAMnnB,QAAQomB,OAClC,IAAIgB,EACAC,EAAQJ,EAEZ,GAAIC,EAAMpnB,OAAS,EAAG,CAEpB,MAAMwnB,EAAUvmB,KAAKgD,IAAIhD,KAAKqZ,IAAI8M,EAAM,GAAGpwB,OAAQiK,KAAKqZ,IAAI8M,EAAMA,EAAMpnB,OAAS,GAAGhJ,SAChFwwB,EAAU,MAAQA,EAAU,QAC9BF,EAAW,cAGbC,EAAQE,GAAeN,EAAWC,E,CAGpC,MAAMM,EAAWxN,GAAMjZ,KAAKqZ,IAAIiN,IAO1BI,EAAavM,MAAMsM,GAAY,EAAIzmB,KAAKgD,IAAIhD,KAAKiD,KAAK,EAAIjD,KAAKyZ,MAAMgN,GAAW,IAAK,GAErFxnB,EAAU,CAAConB,WAAUM,sBAAuBD,EAAYE,sBAAuBF,GAGrF,OAFA7wB,OAAOkd,OAAO9T,EAAS9G,KAAK8G,QAAQknB,MAAMJ,QAEnCF,GAAaK,EAAWb,EAAQpmB,EACzC,EAWA4nB,WAAAA,CAAYX,EAAW/uB,EAAOgvB,GAC5B,GAAkB,IAAdD,EACF,MAAO,IAET,MAAMY,EAASX,EAAMhvB,GAAO4vB,aAAgBb,EAAalmB,KAAKqS,IAAI,GAAIrS,KAAKyZ,MAAMR,GAAMiN,KACvF,MAAI,CAAC,EAAG,EAAG,EAAG,EAAG,GAAI,IAAIc,SAASF,IAAW3vB,EAAQ,GAAMgvB,EAAMpnB,OACxDinB,GAAWC,QAAQ1wB,KAAK4C,KAAM+tB,EAAW/uB,EAAOgvB,GAElD,EACT,GAKF,SAASK,GAAeN,EAAWC,GAGjC,IAAIG,EAAQH,EAAMpnB,OAAS,EAAIonB,EAAM,GAAGpwB,MAAQowB,EAAM,GAAGpwB,MAAQowB,EAAM,GAAGpwB,MAAQowB,EAAM,GAAGpwB,MAO3F,OAJIiK,KAAKqZ,IAAIiN,IAAU,GAAKJ,IAAclmB,KAAKyZ,MAAMyM,KAEnDI,EAAQJ,EAAYlmB,KAAKyZ,MAAMyM,IAE1BI,CACT,CAMA,IAAAW,GAAe,CAACjB,eCnGT,SAASkB,GAAmBpD,GACjCA,EAAS5F,IAAI,QAAS,CACpBiJ,SAAS,EACTC,QAAQ,EACRpR,SAAS,EACTqR,aAAa,EASbC,OAAQ,QAERC,MAAM,EAMNC,MAAO,EAGPC,KAAM,CACJN,SAAS,EACTO,UAAW,EACXC,iBAAiB,EACjBC,WAAW,EACXC,WAAY,EACZC,UAAWA,CAACtxB,EAAMyI,IAAYA,EAAQyoB,UACtCK,UAAWA,CAACvxB,EAAMyI,IAAYA,EAAQyU,MACtC0T,QAAQ,GAGVY,OAAQ,CACNb,SAAS,EACTc,KAAM,GACNC,WAAY,EACZC,MAAO,GAIT1wB,MAAO,CAEL0vB,SAAS,EAGTiB,KAAM,GAGNrD,QAAS,CACPC,IAAK,EACLC,OAAQ,IAKZkB,MAAO,CACLkC,YAAa,EACbC,YAAa,GACbC,QAAQ,EACRC,gBAAiB,EACjBC,gBAAiB,GACjB1D,QAAS,EACToC,SAAS,EACTuB,UAAU,EACVC,gBAAiB,EACjBC,YAAa,EAEblT,SAAUuR,GAAMjB,WAAW9I,OAC3B2L,MAAO,CAAC,EACRC,MAAO,CAAC,EACR/J,MAAO,SACPgK,WAAY,OAEZC,mBAAmB,EACnBC,cAAe,4BACfC,gBAAiB,KAIrBpF,EAASqF,MAAM,cAAe,QAAS,GAAI,SAC3CrF,EAASqF,MAAM,aAAc,QAAS,GAAI,eAC1CrF,EAASqF,MAAM,eAAgB,QAAS,GAAI,eAC5CrF,EAASqF,MAAM,cAAe,QAAS,GAAI,SAE3CrF,EAASG,SAAS,QAAS,CACzBC,WAAW,EACXE,YAAcxsB,IAAUA,EAAKwxB,WAAW,YAAcxxB,EAAKwxB,WAAW,UAAqB,aAATxxB,GAAgC,WAATA,EACzGusB,WAAavsB,GAAkB,eAATA,GAAkC,mBAATA,GAAsC,SAATA,IAG9EksB,EAASG,SAAS,SAAU,CAC1BC,UAAW,UAGbJ,EAASG,SAAS,cAAe,CAC/BG,YAAcxsB,GAAkB,oBAATA,GAAuC,aAATA,EACrDusB,WAAavsB,GAAkB,oBAATA,GAE1B,C,MClGayxB,GAAYxzB,OAAO6gB,OAAO,MAC1B4S,GAAczzB,OAAO6gB,OAAO,MAOzC,SAAS6S,GAASC,EAAMtyB,GACtB,IAAKA,EACH,OAAOsyB,EAET,MAAM3qB,EAAO3H,EAAIygB,MAAM,KACvB,IAAK,IAAIriB,EAAI,EAAG4P,EAAIrG,EAAKE,OAAQzJ,EAAI4P,IAAK5P,EAAG,CAC3C,MAAM6P,EAAItG,EAAKvJ,GACfk0B,EAAOA,EAAKrkB,KAAOqkB,EAAKrkB,GAAKtP,OAAO6gB,OAAO,MAC7C,CACA,OAAO8S,CACT,CAEA,SAAStL,GAAIuL,EAAMC,EAAOxM,GACxB,MAAqB,kBAAVwM,EACFzS,GAAMsS,GAASE,EAAMC,GAAQxM,GAE/BjG,GAAMsS,GAASE,EAAM,IAAKC,EACnC,CAMO,MAAMC,GACX30B,WAAAA,CAAY40B,EAAcC,GACxB1xB,KAAKosB,eAAYzf,EACjB3M,KAAK2xB,gBAAkB,kBACvB3xB,KAAK4xB,YAAc,kBACnB5xB,KAAKub,MAAQ,OACbvb,KAAK6xB,SAAW,CAAC,EACjB7xB,KAAK8xB,iBAAoBC,GAAYA,EAAQ9D,MAAM+D,SAASC,sBAC5DjyB,KAAKkyB,SAAW,CAAC,EACjBlyB,KAAKmyB,OAAS,CACZ,YACA,WACA,QACA,aACA,aAEFnyB,KAAKoyB,KAAO,CACVC,OAAQ,qDACR/pB,KAAM,GACNpB,MAAO,SACPorB,WAAY,IACZ9W,OAAQ,MAEVxb,KAAKuyB,MAAQ,CAAC,EACdvyB,KAAKwyB,qBAAuB,CAACC,EAAK3rB,IAAYykB,GAAczkB,EAAQ6qB,iBACpE3xB,KAAK0yB,iBAAmB,CAACD,EAAK3rB,IAAYykB,GAAczkB,EAAQ8qB,aAChE5xB,KAAK2yB,WAAa,CAACF,EAAK3rB,IAAYykB,GAAczkB,EAAQyU,OAC1Dvb,KAAK4yB,UAAY,IACjB5yB,KAAK6yB,YAAc,CACjBC,KAAM,UACNC,WAAW,EACXC,kBAAkB,GAEpBhzB,KAAKizB,qBAAsB,EAC3BjzB,KAAKkzB,QAAU,KACflzB,KAAKd,QAAU,KACfc,KAAKmzB,SAAU,EACfnzB,KAAKozB,QAAU,CAAC,EAChBpzB,KAAKqzB,YAAa,EAClBrzB,KAAKszB,WAAQ3mB,EACb3M,KAAKuzB,OAAS,CAAC,EACfvzB,KAAKwzB,UAAW,EAChBxzB,KAAKyzB,yBAA0B,EAE/BzzB,KAAK8rB,SAAS2F,GACdzxB,KAAK0d,MAAMgU,EACb,CAMA3L,GAAAA,CAAIwL,EAAOxM,GACT,OAAOgB,GAAI/lB,KAAMuxB,EAAOxM,EAC1B,CAKAwI,GAAAA,CAAIgE,GACF,OAAOH,GAASpxB,KAAMuxB,EACxB,CAMAzF,QAAAA,CAASyF,EAAOxM,GACd,OAAOgB,GAAIoL,GAAaI,EAAOxM,EACjC,CAEA2O,QAAAA,CAASnC,EAAOxM,GACd,OAAOgB,GAAImL,GAAWK,EAAOxM,EAC/B,CAmBAiM,KAAAA,CAAMO,EAAO9xB,EAAMk0B,EAAaC,GAC9B,MAAMC,EAAczC,GAASpxB,KAAMuxB,GAC7BuC,EAAoB1C,GAASpxB,KAAM2zB,GACnCI,EAAc,IAAMt0B,EAE1B/B,OAAOs2B,iBAAiBH,EAAa,CAEnC,CAACE,GAAc,CACbn2B,MAAOi2B,EAAYp0B,GACnB1B,UAAU,GAGZ,CAAC0B,GAAO,CACN5B,YAAY,EACZ0vB,GAAAA,GACE,MAAM0G,EAAQj0B,KAAK+zB,GACbzV,EAASwV,EAAkBF,GACjC,OAAIhX,GAASqX,GACJv2B,OAAOkd,OAAO,CAAC,EAAG0D,EAAQ2V,GAE5BhX,GAAegX,EAAO3V,EAC/B,EACAyH,GAAAA,CAAInoB,GACFoC,KAAK+zB,GAAen2B,CACtB,IAGN,CAEA8f,KAAAA,CAAMwW,GACJA,EAAS7O,QAAS3H,GAAUA,EAAM1d,MACpC,EAIF,IAAA2rB,GAA+B,IAAI6F,GAAS,CAC1CvF,YAAcxsB,IAAUA,EAAKwxB,WAAW,MACxCjF,WAAavsB,GAAkB,WAATA,EACtB8yB,MAAO,CACLxG,UAAW,eAEb8G,YAAa,CACX5G,aAAa,EACbD,YAAY,IAEb,CAACN,GAAyBgB,GAAsBqC,KCtJ5C,SAASoF,GAAa/B,GAC3B,OAAKA,GAAQ3V,GAAc2V,EAAK9pB,OAASmU,GAAc2V,EAAKC,QACnD,MAGDD,EAAKlrB,MAAQkrB,EAAKlrB,MAAQ,IAAM,KACrCkrB,EAAK5W,OAAS4W,EAAK5W,OAAS,IAAM,IACnC4W,EAAK9pB,KAAO,MACZ8pB,EAAKC,MACT,CAKO,SAAS+B,GACd3B,EACA3yB,EACAu0B,EACAC,EACAC,GAEA,IAAIC,EAAY10B,EAAKy0B,GAQrB,OAPKC,IACHA,EAAY10B,EAAKy0B,GAAU9B,EAAIgC,YAAYF,GAAQvE,MACnDqE,EAAG3U,KAAK6U,IAENC,EAAYF,IACdA,EAAUE,GAELF,CACT,CASO,SAASI,GACdjC,EACAL,EACAuC,EACAC,GAEAA,EAAQA,GAAS,CAAC,EAClB,IAAI90B,EAAO80B,EAAM90B,KAAO80B,EAAM90B,MAAQ,CAAC,EACnCu0B,EAAKO,EAAMC,eAAiBD,EAAMC,gBAAkB,GAEpDD,EAAMxC,OAASA,IACjBtyB,EAAO80B,EAAM90B,KAAO,CAAC,EACrBu0B,EAAKO,EAAMC,eAAiB,GAC5BD,EAAMxC,KAAOA,GAGfK,EAAIqC,OAEJrC,EAAIL,KAAOA,EACX,IAAIkC,EAAU,EACd,MAAMrW,EAAO0W,EAAc/tB,OAC3B,IAAIzJ,EAAWkc,EAAW0b,EAAcC,EAAwBC,EAChE,IAAK93B,EAAI,EAAGA,EAAI8gB,EAAM9gB,IAIpB,GAHA63B,EAAQL,EAAcx3B,QAGRwP,IAAVqoB,GAAiC,OAAVA,GAAmBtnB,GAAQsnB,IAE/C,GAAItnB,GAAQsnB,GAGjB,IAAK3b,EAAI,EAAG0b,EAAOC,EAAMpuB,OAAQyS,EAAI0b,EAAM1b,IACzC4b,EAAcD,EAAM3b,QAEA1M,IAAhBsoB,GAA6C,OAAhBA,GAAyBvnB,GAAQunB,KAChEX,EAAUF,GAAa3B,EAAK3yB,EAAMu0B,EAAIC,EAASW,SARnDX,EAAUF,GAAa3B,EAAK3yB,EAAMu0B,EAAIC,EAASU,GAcnDvC,EAAIyC,UAEJ,MAAMC,EAAQd,EAAGztB,OAAS,EAC1B,GAAIuuB,EAAQR,EAAc/tB,OAAQ,CAChC,IAAKzJ,EAAI,EAAGA,EAAIg4B,EAAOh4B,WACd2C,EAAKu0B,EAAGl3B,IAEjBk3B,EAAGzO,OAAO,EAAGuP,E,CAEf,OAAOb,CACT,CAUO,SAASc,GAAYnH,EAAcoH,EAAerF,GACvD,MAAM8B,EAAmB7D,EAAMqH,wBACzBC,EAAsB,IAAVvF,EAAcnoB,KAAKgD,IAAImlB,EAAQ,EAAG,IAAO,EAC3D,OAAOnoB,KAAKC,OAAOutB,EAAQE,GAAazD,GAAoBA,EAAmByD,CACjF,CAKO,SAASC,GAAYC,EAA4BhD,IACjDA,GAAQgD,KAIbhD,EAAMA,GAAOgD,EAAOC,WAAW,MAE/BjD,EAAIqC,OAGJrC,EAAIkD,iBACJlD,EAAImD,UAAU,EAAG,EAAGH,EAAOzF,MAAOyF,EAAOI,QACzCpD,EAAIyC,UACN,CASO,SAASY,GACdrD,EACA3rB,EACA0H,EACA6Q,GAGA0W,GAAgBtD,EAAK3rB,EAAS0H,EAAG6Q,EAAG,KACtC,CAGO,SAAS0W,GACdtD,EACA3rB,EACA0H,EACA6Q,EACAlS,GAEA,IAAIxN,EAAcq2B,EAAiBC,EAAiB3tB,EAAc4tB,EAAsBlG,EAAemG,EAAkBC,EACzH,MAAMlvB,EAAQJ,EAAQuvB,WAChBC,EAAWxvB,EAAQwvB,SACnBC,EAASzvB,EAAQyvB,OACvB,IAAIC,GAAOF,GAAY,GAAK5V,GAE5B,GAAIxZ,GAA0B,kBAAVA,IAClBvH,EAAOuH,EAAMwV,WACA,8BAAT/c,GAAiD,+BAATA,GAM1C,OALA8yB,EAAIqC,OACJrC,EAAIgE,UAAUjoB,EAAG6Q,GACjBoT,EAAIpkB,OAAOmoB,GACX/D,EAAIiE,UAAUxvB,GAAQA,EAAM8oB,MAAQ,GAAI9oB,EAAM2uB,OAAS,EAAG3uB,EAAM8oB,MAAO9oB,EAAM2uB,aAC7EpD,EAAIyC,UAKR,KAAIlT,MAAMuU,IAAWA,GAAU,GAA/B,CAMA,OAFA9D,EAAIkE,YAEIzvB,GAEN,QACMiG,EACFslB,EAAImE,QAAQpoB,EAAG6Q,EAAGlS,EAAI,EAAGopB,EAAQ,EAAG,EAAGjW,IAEvCmS,EAAIoE,IAAIroB,EAAG6Q,EAAGkX,EAAQ,EAAGjW,IAE3BmS,EAAIqE,YACJ,MACF,IAAK,WACH9G,EAAQ7iB,EAAIA,EAAI,EAAIopB,EACpB9D,EAAIsE,OAAOvoB,EAAI3G,KAAKshB,IAAIqN,GAAOxG,EAAO3Q,EAAIxX,KAAKuiB,IAAIoM,GAAOD,GAC1DC,GAAO3V,GACP4R,EAAIuE,OAAOxoB,EAAI3G,KAAKshB,IAAIqN,GAAOxG,EAAO3Q,EAAIxX,KAAKuiB,IAAIoM,GAAOD,GAC1DC,GAAO3V,GACP4R,EAAIuE,OAAOxoB,EAAI3G,KAAKshB,IAAIqN,GAAOxG,EAAO3Q,EAAIxX,KAAKuiB,IAAIoM,GAAOD,GAC1D9D,EAAIqE,YACJ,MACF,IAAK,cAQHZ,EAAwB,KAATK,EACfjuB,EAAOiuB,EAASL,EAChBF,EAAUnuB,KAAKuiB,IAAIoM,EAAM5V,IAActY,EACvC6tB,EAAWtuB,KAAKuiB,IAAIoM,EAAM5V,KAAezT,EAAIA,EAAI,EAAI+oB,EAAe5tB,GACpE2tB,EAAUpuB,KAAKshB,IAAIqN,EAAM5V,IAActY,EACvC8tB,EAAWvuB,KAAKshB,IAAIqN,EAAM5V,KAAezT,EAAIA,EAAI,EAAI+oB,EAAe5tB,GACpEmqB,EAAIoE,IAAIroB,EAAI2nB,EAAU9W,EAAI4W,EAASC,EAAcM,EAAMnW,GAAImW,EAAM7V,IACjE8R,EAAIoE,IAAIroB,EAAI4nB,EAAU/W,EAAI2W,EAASE,EAAcM,EAAM7V,GAAS6V,GAChE/D,EAAIoE,IAAIroB,EAAI2nB,EAAU9W,EAAI4W,EAASC,EAAcM,EAAKA,EAAM7V,IAC5D8R,EAAIoE,IAAIroB,EAAI4nB,EAAU/W,EAAI2W,EAASE,EAAcM,EAAM7V,GAAS6V,EAAMnW,IACtEoS,EAAIqE,YACJ,MACF,IAAK,OACH,IAAKR,EAAU,CACbhuB,EAAOT,KAAKovB,QAAUV,EACtBvG,EAAQ7iB,EAAIA,EAAI,EAAI7E,EACpBmqB,EAAIyE,KAAK1oB,EAAIwhB,EAAO3Q,EAAI/W,EAAM,EAAI0nB,EAAO,EAAI1nB,GAC7C,K,CAEFkuB,GAAO5V,GAET,IAAK,UACHuV,EAAWtuB,KAAKuiB,IAAIoM,IAAQrpB,EAAIA,EAAI,EAAIopB,GACxCP,EAAUnuB,KAAKuiB,IAAIoM,GAAOD,EAC1BN,EAAUpuB,KAAKshB,IAAIqN,GAAOD,EAC1BH,EAAWvuB,KAAKshB,IAAIqN,IAAQrpB,EAAIA,EAAI,EAAIopB,GACxC9D,EAAIsE,OAAOvoB,EAAI2nB,EAAU9W,EAAI4W,GAC7BxD,EAAIuE,OAAOxoB,EAAI4nB,EAAU/W,EAAI2W,GAC7BvD,EAAIuE,OAAOxoB,EAAI2nB,EAAU9W,EAAI4W,GAC7BxD,EAAIuE,OAAOxoB,EAAI4nB,EAAU/W,EAAI2W,GAC7BvD,EAAIqE,YACJ,MACF,IAAK,WACHN,GAAO5V,GAET,IAAK,QACHuV,EAAWtuB,KAAKuiB,IAAIoM,IAAQrpB,EAAIA,EAAI,EAAIopB,GACxCP,EAAUnuB,KAAKuiB,IAAIoM,GAAOD,EAC1BN,EAAUpuB,KAAKshB,IAAIqN,GAAOD,EAC1BH,EAAWvuB,KAAKshB,IAAIqN,IAAQrpB,EAAIA,EAAI,EAAIopB,GACxC9D,EAAIsE,OAAOvoB,EAAI2nB,EAAU9W,EAAI4W,GAC7BxD,EAAIuE,OAAOxoB,EAAI2nB,EAAU9W,EAAI4W,GAC7BxD,EAAIsE,OAAOvoB,EAAI4nB,EAAU/W,EAAI2W,GAC7BvD,EAAIuE,OAAOxoB,EAAI4nB,EAAU/W,EAAI2W,GAC7B,MACF,IAAK,OACHG,EAAWtuB,KAAKuiB,IAAIoM,IAAQrpB,EAAIA,EAAI,EAAIopB,GACxCP,EAAUnuB,KAAKuiB,IAAIoM,GAAOD,EAC1BN,EAAUpuB,KAAKshB,IAAIqN,GAAOD,EAC1BH,EAAWvuB,KAAKshB,IAAIqN,IAAQrpB,EAAIA,EAAI,EAAIopB,GACxC9D,EAAIsE,OAAOvoB,EAAI2nB,EAAU9W,EAAI4W,GAC7BxD,EAAIuE,OAAOxoB,EAAI2nB,EAAU9W,EAAI4W,GAC7BxD,EAAIsE,OAAOvoB,EAAI4nB,EAAU/W,EAAI2W,GAC7BvD,EAAIuE,OAAOxoB,EAAI4nB,EAAU/W,EAAI2W,GAC7BQ,GAAO5V,GACPuV,EAAWtuB,KAAKuiB,IAAIoM,IAAQrpB,EAAIA,EAAI,EAAIopB,GACxCP,EAAUnuB,KAAKuiB,IAAIoM,GAAOD,EAC1BN,EAAUpuB,KAAKshB,IAAIqN,GAAOD,EAC1BH,EAAWvuB,KAAKshB,IAAIqN,IAAQrpB,EAAIA,EAAI,EAAIopB,GACxC9D,EAAIsE,OAAOvoB,EAAI2nB,EAAU9W,EAAI4W,GAC7BxD,EAAIuE,OAAOxoB,EAAI2nB,EAAU9W,EAAI4W,GAC7BxD,EAAIsE,OAAOvoB,EAAI4nB,EAAU/W,EAAI2W,GAC7BvD,EAAIuE,OAAOxoB,EAAI4nB,EAAU/W,EAAI2W,GAC7B,MACF,IAAK,OACHA,EAAU7oB,EAAIA,EAAI,EAAItF,KAAKuiB,IAAIoM,GAAOD,EACtCN,EAAUpuB,KAAKshB,IAAIqN,GAAOD,EAC1B9D,EAAIsE,OAAOvoB,EAAIwnB,EAAS3W,EAAI4W,GAC5BxD,EAAIuE,OAAOxoB,EAAIwnB,EAAS3W,EAAI4W,GAC5B,MACF,IAAK,OACHxD,EAAIsE,OAAOvoB,EAAG6Q,GACdoT,EAAIuE,OAAOxoB,EAAI3G,KAAKuiB,IAAIoM,IAAQrpB,EAAIA,EAAI,EAAIopB,GAASlX,EAAIxX,KAAKshB,IAAIqN,GAAOD,GACzE,MACF,KAAK,EACH9D,EAAIqE,YACJ,MAGJrE,EAAI0E,OACArwB,EAAQswB,YAAc,GACxB3E,EAAI4E,Q,CAER,CASO,SAASC,GACdjP,EACAkP,EACAC,GAIA,OAFAA,EAASA,GAAU,IAEXD,GAASlP,GAASA,EAAM7Z,EAAI+oB,EAAKxQ,KAAOyQ,GAAUnP,EAAM7Z,EAAI+oB,EAAKvQ,MAAQwQ,GACjFnP,EAAMhJ,EAAIkY,EAAK1K,IAAM2K,GAAUnP,EAAMhJ,EAAIkY,EAAKzK,OAAS0K,CACzD,CAEO,SAASC,GAAShF,EAA+B8E,GACtD9E,EAAIqC,OACJrC,EAAIkE,YACJlE,EAAIyE,KAAKK,EAAKxQ,KAAMwQ,EAAK1K,IAAK0K,EAAKvQ,MAAQuQ,EAAKxQ,KAAMwQ,EAAKzK,OAASyK,EAAK1K,KACzE4F,EAAIrD,MACN,CAEO,SAASsI,GAAWjF,GACzBA,EAAIyC,SACN,CAKO,SAASyC,GACdlF,EACAmF,EACAtZ,EACAuZ,EACA/E,GAEA,IAAK8E,EACH,OAAOnF,EAAIuE,OAAO1Y,EAAO9P,EAAG8P,EAAOe,GAErC,GAAa,WAATyT,EAAmB,CACrB,MAAMgF,GAAYF,EAASppB,EAAI8P,EAAO9P,GAAK,EAC3CikB,EAAIuE,OAAOc,EAAUF,EAASvY,GAC9BoT,EAAIuE,OAAOc,EAAUxZ,EAAOe,EAC9B,KAAoB,UAATyT,MAAuB+E,EAChCpF,EAAIuE,OAAOY,EAASppB,EAAG8P,EAAOe,GAE9BoT,EAAIuE,OAAO1Y,EAAO9P,EAAGopB,EAASvY,GAEhCoT,EAAIuE,OAAO1Y,EAAO9P,EAAG8P,EAAOe,EAC9B,CAKO,SAAS0Y,GACdtF,EACAmF,EACAtZ,EACAuZ,GAEA,IAAKD,EACH,OAAOnF,EAAIuE,OAAO1Y,EAAO9P,EAAG8P,EAAOe,GAErCoT,EAAIuF,cACFH,EAAOD,EAASK,KAAOL,EAASM,KAChCL,EAAOD,EAASO,KAAOP,EAASQ,KAChCP,EAAOvZ,EAAO4Z,KAAO5Z,EAAO2Z,KAC5BJ,EAAOvZ,EAAO8Z,KAAO9Z,EAAO6Z,KAC5B7Z,EAAO9P,EACP8P,EAAOe,EACX,CAEA,SAASgZ,GAAc5F,EAA+B6F,GAChDA,EAAKC,aACP9F,EAAIgE,UAAU6B,EAAKC,YAAY,GAAID,EAAKC,YAAY,IAGjD9b,GAAc6b,EAAKhC,WACtB7D,EAAIpkB,OAAOiqB,EAAKhC,UAGdgC,EAAK/c,QACPkX,EAAI+F,UAAYF,EAAK/c,OAGnB+c,EAAKG,YACPhG,EAAIgG,UAAYH,EAAKG,WAGnBH,EAAKI,eACPjG,EAAIiG,aAAeJ,EAAKI,aAE5B,CAEA,SAASC,GACPlG,EACAjkB,EACA6Q,EACAuZ,EACAN,GAEA,GAAIA,EAAKO,eAAiBP,EAAKQ,UAAW,CAQxC,MAAMC,EAAUtG,EAAIgC,YAAYmE,GAC1B7R,EAAOvY,EAAIuqB,EAAQC,sBACnBhS,EAAQxY,EAAIuqB,EAAQE,uBACpBpM,EAAMxN,EAAI0Z,EAAQG,wBAClBpM,EAASzN,EAAI0Z,EAAQI,yBACrBC,EAAcd,EAAKO,eAAiBhM,EAAMC,GAAU,EAAIA,EAE9D2F,EAAI4G,YAAc5G,EAAI+F,UACtB/F,EAAIkE,YACJlE,EAAIlD,UAAY+I,EAAKgB,iBAAmB,EACxC7G,EAAIsE,OAAOhQ,EAAMqS,GACjB3G,EAAIuE,OAAOhQ,EAAOoS,GAClB3G,EAAI4E,Q,CAER,CAEA,SAASkC,GAAa9G,EAA+B6F,GACnD,MAAMkB,EAAW/G,EAAI+F,UAErB/F,EAAI+F,UAAYF,EAAK/c,MACrBkX,EAAIgH,SAASnB,EAAKvR,KAAMuR,EAAKzL,IAAKyL,EAAKtI,MAAOsI,EAAKzC,QACnDpD,EAAI+F,UAAYgB,CAClB,CAKO,SAASE,GACdjH,EACAxC,EACAzhB,EACA6Q,EACA+S,EACAkG,EAAuB,IAEvB,MAAMqB,EAAQjsB,GAAQuiB,GAAQA,EAAO,CAACA,GAChCoH,EAASiB,EAAKsB,YAAc,GAA0B,KAArBtB,EAAKuB,YAC5C,IAAI18B,EAAWy7B,EAMf,IAJAnG,EAAIqC,OACJrC,EAAIL,KAAOA,EAAKmC,OAChB8D,GAAc5F,EAAK6F,GAEdn7B,EAAI,EAAGA,EAAIw8B,EAAM/yB,SAAUzJ,EAC9By7B,EAAOe,EAAMx8B,GAETm7B,EAAKwB,UACPP,GAAa9G,EAAK6F,EAAKwB,UAGrBzC,IACEiB,EAAKuB,cACPpH,EAAI4G,YAAcf,EAAKuB,aAGpBpd,GAAc6b,EAAKsB,eACtBnH,EAAIlD,UAAY+I,EAAKsB,aAGvBnH,EAAIsH,WAAWnB,EAAMpqB,EAAG6Q,EAAGiZ,EAAK0B,WAGlCvH,EAAIwH,SAASrB,EAAMpqB,EAAG6Q,EAAGiZ,EAAK0B,UAC9BrB,GAAalG,EAAKjkB,EAAG6Q,EAAGuZ,EAAMN,GAE9BjZ,GAAK9hB,OAAO60B,EAAKE,YAGnBG,EAAIyC,SACN,CAOO,SAASgF,GACdzH,EACAyE,GAEA,MAAM,EAAC1oB,EAAC,EAAE6Q,EAAC,EAAElS,EAAC,EAAEvC,EAAC,OAAE2rB,GAAUW,EAG7BzE,EAAIoE,IAAIroB,EAAI+nB,EAAO4D,QAAS9a,EAAIkX,EAAO4D,QAAS5D,EAAO4D,QAAS,IAAM9Z,GAAIA,IAAI,GAG9EoS,EAAIuE,OAAOxoB,EAAG6Q,EAAIzU,EAAI2rB,EAAO6D,YAG7B3H,EAAIoE,IAAIroB,EAAI+nB,EAAO6D,WAAY/a,EAAIzU,EAAI2rB,EAAO6D,WAAY7D,EAAO6D,WAAY/Z,GAAIM,IAAS,GAG1F8R,EAAIuE,OAAOxoB,EAAIrB,EAAIopB,EAAO8D,YAAahb,EAAIzU,GAG3C6nB,EAAIoE,IAAIroB,EAAIrB,EAAIopB,EAAO8D,YAAahb,EAAIzU,EAAI2rB,EAAO8D,YAAa9D,EAAO8D,YAAa1Z,GAAS,GAAG,GAGhG8R,EAAIuE,OAAOxoB,EAAIrB,EAAGkS,EAAIkX,EAAO+D,UAG7B7H,EAAIoE,IAAIroB,EAAIrB,EAAIopB,EAAO+D,SAAUjb,EAAIkX,EAAO+D,SAAU/D,EAAO+D,SAAU,GAAI3Z,IAAS,GAGpF8R,EAAIuE,OAAOxoB,EAAI+nB,EAAO4D,QAAS9a,EACjC,CCxgBA,MAAMkb,GAAc,uCACdC,GAAa,wEAcZ,SAASC,GAAa78B,EAAwB0K,GACnD,MAAMoyB,GAAW,GAAK98B,GAAO+8B,MAAMJ,IACnC,IAAKG,GAA0B,WAAfA,EAAQ,GACtB,OAAc,IAAPpyB,EAKT,OAFA1K,GAAS88B,EAAQ,GAETA,EAAQ,IACd,IAAK,KACH,OAAO98B,EACT,IAAK,IACHA,GAAS,IACT,MAKJ,OAAO0K,EAAO1K,CAChB,CAEA,MAAMg9B,GAAgBnwB,IAAgBA,GAAK,EAQpC,SAASowB,GAAkBj9B,EAAwC8B,GACxE,MAAM6M,EAAM,CAAC,EACPuuB,EAAWle,GAASld,GACpBgH,EAAOo0B,EAAWp9B,OAAOgJ,KAAKhH,GAASA,EACvCq7B,EAAOne,GAAShf,GAClBk9B,EACEE,GAAQ/d,GAAerf,EAAMo9B,GAAOp9B,EAAM8B,EAAMs7B,KAChDA,GAAQp9B,EAAMo9B,GAChB,IAAMp9B,EAEV,IAAK,MAAMo9B,KAAQt0B,EACjB6F,EAAIyuB,GAAQJ,GAAaG,EAAKC,IAEhC,OAAOzuB,CACT,CAUO,SAAS0uB,GAAOr9B,GACrB,OAAOi9B,GAAkBj9B,EAAO,CAACivB,IAAK,IAAK7F,MAAO,IAAK8F,OAAQ,IAAK/F,KAAM,KAC5E,CASO,SAASmU,GAAct9B,GAC5B,OAAOi9B,GAAkBj9B,EAAO,CAAC,UAAW,WAAY,aAAc,eACxE,CAUO,SAASu9B,GAAUv9B,GACxB,MAAMyd,EAAM4f,GAAOr9B,GAKnB,OAHAyd,EAAI2U,MAAQ3U,EAAI0L,KAAO1L,EAAI2L,MAC3B3L,EAAIwa,OAASxa,EAAIwR,IAAMxR,EAAIyR,OAEpBzR,CACT,CAUO,SAAS+f,GAAOt0B,EAA4Bu0B,GACjDv0B,EAAUA,GAAW,CAAC,EACtBu0B,EAAWA,GAAY1P,GAASyG,KAEhC,IAAI9pB,EAAO2U,GAAenW,EAAQwB,KAAM+yB,EAAS/yB,MAE7B,kBAATA,IACTA,EAAOmR,SAASnR,EAAM,KAExB,IAAIpB,EAAQ+V,GAAenW,EAAQI,MAAOm0B,EAASn0B,OAC/CA,KAAW,GAAKA,GAAOyzB,MAAMH,MAC/Bc,QAAQC,KAAK,kCAAoCr0B,EAAQ,KACzDA,OAAQyF,GAGV,MAAMylB,EAAO,CACXC,OAAQpV,GAAenW,EAAQurB,OAAQgJ,EAAShJ,QAChDC,WAAYmI,GAAaxd,GAAenW,EAAQwrB,WAAY+I,EAAS/I,YAAahqB,GAClFA,OACApB,QACAsU,OAAQyB,GAAenW,EAAQ0U,OAAQ6f,EAAS7f,QAChD+Y,OAAQ,IAIV,OADAnC,EAAKmC,OAASJ,GAAa/B,GACpBA,CACT,CAaO,SAASoJ,GAAQC,EAAwB1J,EAAkB/yB,EAAgB08B,GAChF,IACIv+B,EAAW8gB,EAAcrgB,EADzB+9B,GAAY,EAGhB,IAAKx+B,EAAI,EAAG8gB,EAAOwd,EAAO70B,OAAQzJ,EAAI8gB,IAAQ9gB,EAE5C,GADAS,EAAQ69B,EAAOt+B,QACDwP,IAAV/O,SAGY+O,IAAZolB,GAA0C,oBAAVn0B,IAClCA,EAAQA,EAAMm0B,GACd4J,GAAY,QAEAhvB,IAAV3N,GAAuB0O,GAAQ9P,KACjCA,EAAQA,EAAMoB,EAAQpB,EAAMgJ,QAC5B+0B,GAAY,QAEAhvB,IAAV/O,GAIF,OAHI89B,IAASC,IACXD,EAAKC,WAAY,GAEZ/9B,CAGb,CAQO,SAASg+B,GAAUC,EAAuCxM,EAAwBH,GACvF,MAAM,IAACpkB,EAAA,IAAKD,GAAOgxB,EACbC,EAASxe,GAAY+R,GAAQxkB,EAAMC,GAAO,GAC1CixB,EAAWA,CAACn+B,EAAeo+B,IAAgB9M,GAAyB,IAAVtxB,EAAc,EAAIA,EAAQo+B,EAC1F,MAAO,CACLlxB,IAAKixB,EAASjxB,GAAMjD,KAAKqZ,IAAI4a,IAC7BjxB,IAAKkxB,EAASlxB,EAAKixB,GAEvB,CAUO,SAASG,GAAcC,EAAuBnK,GACnD,OAAOr0B,OAAOkd,OAAOld,OAAO6gB,OAAO2d,GAAgBnK,EACrD,CCnLO,SAASoK,GAIdC,EACAC,EAAW,CAAC,IACZC,EACAjB,EACAkB,EAAYA,IAAMH,EAAO,IAEzB,MAAMI,EAAkBF,GAAcF,EACd,qBAAbf,IACTA,EAAWoB,GAAS,YAAaL,IAEnC,MAAMxH,EAA6B,CACjC,CAACj4B,OAAO+/B,aAAc,SACtBC,YAAY,EACZC,QAASR,EACTS,YAAaL,EACbzQ,UAAWsP,EACXyB,WAAYP,EACZ7I,SAAWnC,GAAqB4K,GAAgB,CAAC5K,KAAU6K,GAASC,EAAUG,EAAiBnB,IAEjG,OAAO,IAAI0B,MAAMnI,EAAO,CAItBoI,cAAAA,CAAe1e,EAAQ0c,GAIrB,cAHO1c,EAAO0c,UACP1c,EAAO2e,aACPb,EAAO,GAAGpB,IACV,CACT,EAKAzN,GAAAA,CAAIjP,EAAQ0c,GACV,OAAOkC,GAAQ5e,EAAQ0c,EACrB,IAAMmC,GAAqBnC,EAAMqB,EAAUD,EAAQ9d,GACvD,EAMA8e,wBAAAA,CAAyB9e,EAAQ0c,GAC/B,OAAOqC,QAAQD,yBAAyB9e,EAAOse,QAAQ,GAAI5B,EAC7D,EAKAsC,cAAAA,GACE,OAAOD,QAAQC,eAAelB,EAAO,GACvC,EAKAjc,GAAAA,CAAI7B,EAAQ0c,GACV,OAAOuC,GAAqBjf,GAAQuQ,SAASmM,EAC/C,EAKAwC,OAAAA,CAAQlf,GACN,OAAOif,GAAqBjf,EAC9B,EAKAyH,GAAAA,CAAIzH,EAAQ0c,EAAcp9B,GACxB,MAAM6/B,EAAUnf,EAAOof,WAAapf,EAAOof,SAAWnB,KAGtD,OAFAje,EAAO0c,GAAQyC,EAAQzC,GAAQp9B,SACxB0gB,EAAO2e,OACP,CACT,GAEJ,CAUO,SAASU,GAIdC,EACA7L,EACA8L,EACAC,GAEA,MAAMlJ,EAA4B,CAChC+H,YAAY,EACZoB,OAAQH,EACRI,SAAUjM,EACVkM,UAAWJ,EACXK,OAAQ,IAAIlY,IACZyL,aAAcA,GAAamM,EAAOE,GAClCK,WAAa1L,GAAmBkL,GAAeC,EAAOnL,EAAKoL,EAAUC,GACrEpK,SAAWnC,GAAqBoM,GAAeC,EAAMlK,SAASnC,GAAQQ,EAAS8L,EAAUC,IAE3F,OAAO,IAAIf,MAAMnI,EAAO,CAItBoI,cAAAA,CAAe1e,EAAQ0c,GAGrB,cAFO1c,EAAO0c,UACP4C,EAAM5C,IACN,CACT,EAKAzN,GAAAA,CAAIjP,EAAQ0c,EAAcoD,GACxB,OAAOlB,GAAQ5e,EAAQ0c,EACrB,IAAMqD,GAAoB/f,EAAQ0c,EAAMoD,GAC5C,EAMAhB,wBAAAA,CAAyB9e,EAAQ0c,GAC/B,OAAO1c,EAAOmT,aAAa6M,QACvBjB,QAAQld,IAAIyd,EAAO5C,GAAQ,CAACn9B,YAAY,EAAMC,cAAc,QAAQ6O,EACpE0wB,QAAQD,yBAAyBQ,EAAO5C,EAC9C,EAKAsC,cAAAA,GACE,OAAOD,QAAQC,eAAeM,EAChC,EAKAzd,GAAAA,CAAI7B,EAAQ0c,GACV,OAAOqC,QAAQld,IAAIyd,EAAO5C,EAC5B,EAKAwC,OAAAA,GACE,OAAOH,QAAQG,QAAQI,EACzB,EAKA7X,GAAAA,CAAIzH,EAAQ0c,EAAMp9B,GAGhB,OAFAggC,EAAM5C,GAAQp9B,SACP0gB,EAAO0c,IACP,CACT,GAEJ,CAKO,SAASvJ,GACdmM,EACAjS,EAA+B,CAAC4S,YAAY,EAAMC,WAAW,IAE7D,MAAM,YAACvS,EAAcN,EAAS4S,WAAU,WAAEvS,EAAaL,EAAS6S,UAAS,SAAEC,EAAW9S,EAAS2S,SAAWV,EAC1G,MAAO,CACLU,QAASG,EACTF,WAAYtS,EACZuS,UAAWxS,EACX0S,aAAcze,GAAWgM,GAAeA,EAAc,IAAMA,EAC5D0S,YAAa1e,GAAW+L,GAAcA,EAAa,IAAMA,EAE7D,CAEA,MAAM4S,GAAUA,CAACC,EAAgBp/B,IAAiBo/B,EAASA,EAAS/e,GAAYrgB,GAAQA,EAClFq/B,GAAmBA,CAAC9D,EAAcp9B,IAAmBgf,GAAShf,IAAmB,aAATo9B,IAC1C,OAAjCt9B,OAAO4/B,eAAe1/B,IAAmBA,EAAMf,cAAgBa,QAElE,SAASw/B,GACP5e,EACA0c,EACAQ,GAEA,GAAI99B,OAAOZ,UAAUqiB,eAAe/hB,KAAKkhB,EAAQ0c,IAAkB,gBAATA,EACxD,OAAO1c,EAAO0c,GAGhB,MAAMp9B,EAAQ49B,IAGd,OADAld,EAAO0c,GAAQp9B,EACRA,CACT,CAEA,SAASygC,GACP/f,EACA0c,EACAoD,GAEA,MAAM,OAACL,EAAM,SAAEC,EAAQ,UAAEC,EAAWxM,aAAcN,GAAe7S,EACjE,IAAI1gB,EAAQmgC,EAAO/C,GAanB,OAVI/a,GAAWriB,IAAUuzB,EAAYuN,aAAa1D,KAChDp9B,EAAQmhC,GAAmB/D,EAAMp9B,EAAO0gB,EAAQ8f,IAE9C1wB,GAAQ9P,IAAUA,EAAMgJ,SAC1BhJ,EAAQohC,GAAchE,EAAMp9B,EAAO0gB,EAAQ6S,EAAYwN,cAErDG,GAAiB9D,EAAMp9B,KAEzBA,EAAQ+/B,GAAe//B,EAAOogC,EAAUC,GAAaA,EAAUjD,GAAO7J,IAEjEvzB,CACT,CAEA,SAASmhC,GACP/D,EACAiE,EACA3gB,EACA8f,GAEA,MAAM,OAACL,EAAA,SAAQC,EAAA,UAAUC,EAAS,OAAEC,GAAU5f,EAC9C,GAAI4f,EAAO/d,IAAI6a,GACb,MAAM,IAAIkE,MAAM,uBAAyBzxB,MAAM0M,KAAK+jB,GAAQiB,KAAK,MAAQ,KAAOnE,GAElFkD,EAAOlC,IAAIhB,GACX,IAAIp9B,EAAQqhC,EAASjB,EAAUC,GAAaG,GAM5C,OALAF,EAAOkB,OAAOpE,GACV8D,GAAiB9D,EAAMp9B,KAEzBA,EAAQyhC,GAAkBtB,EAAOnB,QAASmB,EAAQ/C,EAAMp9B,IAEnDA,CACT,CAEA,SAASohC,GACPhE,EACAp9B,EACA0gB,EACAqgB,GAEA,MAAM,OAACZ,EAAM,SAAEC,EAAQ,UAAEC,EAAWxM,aAAcN,GAAe7S,EAEjE,GAA8B,qBAAnB0f,EAASh/B,OAAyB2/B,EAAY3D,GACvD,OAAOp9B,EAAMogC,EAASh/B,MAAQpB,EAAMgJ,QAC/B,GAAIgW,GAAShf,EAAM,IAAK,CAE7B,MAAM0hC,EAAM1hC,EACNw+B,EAAS2B,EAAOnB,QAAQ2C,OAAOzyB,GAAKA,IAAMwyB,GAChD1hC,EAAQ,GACR,IAAK,MAAMkB,KAAQwgC,EAAK,CACtB,MAAMzf,EAAWwf,GAAkBjD,EAAQ2B,EAAQ/C,EAAMl8B,GACzDlB,EAAM8hB,KAAKie,GAAe9d,EAAUme,EAAUC,GAAaA,EAAUjD,GAAO7J,GAC9E,C,CAEF,OAAOvzB,CACT,CAEA,SAAS4hC,GACPnE,EACAL,EACAp9B,GAEA,OAAOqiB,GAAWob,GAAYA,EAASL,EAAMp9B,GAASy9B,CACxD,CAEA,MAAMoE,GAAWA,CAAC1gC,EAAwB2gC,KAA8B,IAAR3gC,EAAe2gC,EAC5D,kBAAR3gC,EAAmB6gB,GAAiB8f,EAAQ3gC,QAAO4N,EAE9D,SAASgzB,GACP5Z,EACA6Z,EACA7gC,EACA8gC,EACAjiC,GAEA,IAAK,MAAM8hC,KAAUE,EAAc,CACjC,MAAMrO,EAAQkO,GAAS1gC,EAAK2gC,GAC5B,GAAInO,EAAO,CACTxL,EAAIiW,IAAIzK,GACR,MAAM8J,EAAWmE,GAAgBjO,EAAMxF,UAAWhtB,EAAKnB,GACvD,GAAwB,qBAAby9B,GAA4BA,IAAat8B,GAAOs8B,IAAawE,EAGtE,OAAOxE,C,MAEJ,IAAc,IAAV9J,GAA6C,qBAAnBsO,GAAkC9gC,IAAQ8gC,EAG7E,OAAO,IAEX,CACA,OAAO,CACT,CAEA,SAASR,GACPO,EACA/f,EACAmb,EACAp9B,GAEA,MAAM0+B,EAAazc,EAASgd,YACtBxB,EAAWmE,GAAgB3f,EAASkM,UAAWiP,EAAMp9B,GACrDkiC,EAAY,IAAIF,KAAiBtD,GACjCvW,EAAM,IAAIC,IAChBD,EAAIiW,IAAIp+B,GACR,IAAImB,EAAMghC,GAAiBha,EAAK+Z,EAAW9E,EAAMK,GAAYL,EAAMp9B,GACnE,OAAY,OAARmB,KAGoB,qBAAbs8B,GAA4BA,IAAaL,IAClDj8B,EAAMghC,GAAiBha,EAAK+Z,EAAWzE,EAAUt8B,EAAKnB,GAC1C,OAARmB,KAICo9B,GAAgB1uB,MAAM0M,KAAK4L,GAAM,CAAC,IAAKuW,EAAYjB,EACxD,IAAM2E,GAAangB,EAAUmb,EAAgBp9B,IACjD,CAEA,SAASmiC,GACPha,EACA+Z,EACA/gC,EACAs8B,EACAv8B,GAEA,MAAOC,EACLA,EAAM4gC,GAAU5Z,EAAK+Z,EAAW/gC,EAAKs8B,EAAUv8B,GAEjD,OAAOC,CACT,CAEA,SAASihC,GACPngB,EACAmb,EACAp9B,GAEA,MAAM8hC,EAAS7f,EAASid,aAClB9B,KAAQ0E,IACZA,EAAO1E,GAAQ,CAAC,GAElB,MAAM1c,EAASohB,EAAO1E,GACtB,OAAIttB,GAAQ4Q,IAAW1B,GAAShf,GAEvBA,EAEF0gB,GAAU,CAAC,CACpB,CAEA,SAAS6e,GACPnC,EACAqB,EACAD,EACAwB,GAEA,IAAIhgC,EACJ,IAAK,MAAMihC,KAAUxC,EAEnB,GADAz+B,EAAQ6+B,GAASmC,GAAQC,EAAQ7D,GAAOoB,GACnB,qBAAVx+B,EACT,OAAOkhC,GAAiB9D,EAAMp9B,GAC1ByhC,GAAkBjD,EAAQwB,EAAO5C,EAAMp9B,GACvCA,CAGV,CAEA,SAAS6+B,GAAS19B,EAAaq9B,GAC7B,IAAK,MAAM7K,KAAS6K,EAAQ,CAC1B,IAAK7K,EACH,SAEF,MAAM3zB,EAAQ2zB,EAAMxyB,GACpB,GAAqB,qBAAVnB,EACT,OAAOA,CAEX,CACF,CAEA,SAAS2/B,GAAqBjf,GAC5B,IAAI5X,EAAO4X,EAAO2e,MAIlB,OAHKv2B,IACHA,EAAO4X,EAAO2e,MAAQgD,GAAyB3hB,EAAOse,UAEjDl2B,CACT,CAEA,SAASu5B,GAAyB7D,GAChC,MAAMrW,EAAM,IAAIC,IAChB,IAAK,MAAMuL,KAAS6K,EAClB,IAAK,MAAMr9B,KAAOrB,OAAOgJ,KAAK6qB,GAAOgO,OAAOvyB,IAAMA,EAAEikB,WAAW,MAC7DlL,EAAIiW,IAAIj9B,GAGZ,OAAO0O,MAAM0M,KAAK4L,EACpB,CAEO,SAASma,GACd9Y,EACAtnB,EACA4jB,EACA1c,GAEA,MAAM,OAACygB,GAAUL,GACX,IAACroB,EAAM,KAAOiB,KAAKmgC,SACnBC,EAAS,IAAI3yB,MAAoBzG,GACvC,IAAI7J,EAAW8gB,EAAcjf,EAAeF,EAE5C,IAAK3B,EAAI,EAAG8gB,EAAOjX,EAAO7J,EAAI8gB,IAAQ9gB,EACpC6B,EAAQ7B,EAAIumB,EACZ5kB,EAAOgB,EAAKd,GACZohC,EAAOjjC,GAAK,CACVF,EAAGwqB,EAAO4Y,MAAMzgB,GAAiB9gB,EAAMC,GAAMC,IAGjD,OAAOohC,CACT,CClcA,MAAME,GAAU/iC,OAAO+iC,SAAW,MAG5BC,GAAWA,CAAClZ,EAAuBlqB,IAAmCA,EAAIkqB,EAAOzgB,SAAWygB,EAAOlqB,GAAGqjC,MAAQnZ,EAAOlqB,GACrHsjC,GAAgB7N,GAAuC,MAAdA,EAAoB,IAAM,IAElE,SAAS8N,GACdC,EACAC,EACAC,EACA7jC,GAUA,MAAM46B,EAAW+I,EAAWH,KAAOI,EAAcD,EAC3C14B,EAAU24B,EACVE,EAAOD,EAAWL,KAAOI,EAAcC,EACvCE,EAAM3d,GAAsBnb,EAAS2vB,GACrCoJ,EAAM5d,GAAsB0d,EAAM74B,GAExC,IAAIg5B,EAAMF,GAAOA,EAAMC,GACnBE,EAAMF,GAAOD,EAAMC,GAGvBC,EAAMjf,MAAMif,GAAO,EAAIA,EACvBC,EAAMlf,MAAMkf,GAAO,EAAIA,EAEvB,MAAMC,EAAKnkC,EAAIikC,EACTG,EAAKpkC,EAAIkkC,EAEf,MAAO,CACLtJ,SAAU,CACRppB,EAAGvG,EAAQuG,EAAI2yB,GAAML,EAAKtyB,EAAIopB,EAASppB,GACvC6Q,EAAGpX,EAAQoX,EAAI8hB,GAAML,EAAKzhB,EAAIuY,EAASvY,IAEzCyhB,KAAM,CACJtyB,EAAGvG,EAAQuG,EAAI4yB,GAAMN,EAAKtyB,EAAIopB,EAASppB,GACvC6Q,EAAGpX,EAAQoX,EAAI+hB,GAAMN,EAAKzhB,EAAIuY,EAASvY,IAG7C,CAKA,SAASgiB,GAAeha,EAAuBia,EAAkBC,GAC/D,MAAMC,EAAYna,EAAOzgB,OAEzB,IAAI66B,EAAgBC,EAAeC,EAAcC,EAA0BC,EACvEC,EAAavB,GAASlZ,EAAQ,GAClC,IAAK,IAAIlqB,EAAI,EAAGA,EAAIqkC,EAAY,IAAKrkC,EACnC0kC,EAAeC,EACfA,EAAavB,GAASlZ,EAAQlqB,EAAI,GAC7B0kC,GAAiBC,IAIlB9gB,GAAasgB,EAAOnkC,GAAI,EAAGmjC,IAC7BiB,EAAGpkC,GAAKokC,EAAGpkC,EAAI,GAAK,GAItBskC,EAASF,EAAGpkC,GAAKmkC,EAAOnkC,GACxBukC,EAAQH,EAAGpkC,EAAI,GAAKmkC,EAAOnkC,GAC3BykC,EAAmB/5B,KAAKqS,IAAIunB,EAAQ,GAAK55B,KAAKqS,IAAIwnB,EAAO,GACrDE,GAAoB,IAIxBD,EAAO,EAAI95B,KAAK8Z,KAAKigB,GACrBL,EAAGpkC,GAAKskC,EAASE,EAAOL,EAAOnkC,GAC/BokC,EAAGpkC,EAAI,GAAKukC,EAAQC,EAAOL,EAAOnkC,KAEtC,CAEA,SAAS4kC,GAAgB1a,EAAuBka,EAAc3O,EAAuB,KACnF,MAAMoP,EAAYvB,GAAa7N,GACzB4O,EAAYna,EAAOzgB,OACzB,IAAIunB,EAAe8T,EAAkCJ,EACjDC,EAAavB,GAASlZ,EAAQ,GAElC,IAAK,IAAIlqB,EAAI,EAAGA,EAAIqkC,IAAarkC,EAAG,CAIlC,GAHA8kC,EAAcJ,EACdA,EAAeC,EACfA,EAAavB,GAASlZ,EAAQlqB,EAAI,IAC7B0kC,EACH,SAGF,MAAMK,EAASL,EAAajP,GACtBuP,EAASN,EAAaG,GACxBC,IACF9T,GAAS+T,EAASD,EAAYrP,IAAc,EAC5CiP,EAAa,MAAMjP,KAAesP,EAAS/T,EAC3C0T,EAAa,MAAMG,KAAeG,EAAShU,EAAQoT,EAAGpkC,IAEpD2kC,IACF3T,GAAS2T,EAAWlP,GAAasP,GAAU,EAC3CL,EAAa,MAAMjP,KAAesP,EAAS/T,EAC3C0T,EAAa,MAAMG,KAAeG,EAAShU,EAAQoT,EAAGpkC,GAE1D,CACF,CAQO,SAASilC,GAAoB/a,EAAuBuL,EAAuB,KAChF,MAAMoP,EAAYvB,GAAa7N,GACzB4O,EAAYna,EAAOzgB,OACnB06B,EAAmB7zB,MAAM+zB,GAAWrK,KAAK,GACzCoK,EAAe9zB,MAAM+zB,GAG3B,IAAIrkC,EAAG8kC,EAAkCJ,EACrCC,EAAavB,GAASlZ,EAAQ,GAElC,IAAKlqB,EAAI,EAAGA,EAAIqkC,IAAarkC,EAI3B,GAHA8kC,EAAcJ,EACdA,EAAeC,EACfA,EAAavB,GAASlZ,EAAQlqB,EAAI,GAC7B0kC,EAAL,CAIA,GAAIC,EAAY,CACd,MAAMO,EAAaP,EAAWlP,GAAaiP,EAAajP,GAGxD0O,EAAOnkC,GAAoB,IAAfklC,GAAoBP,EAAWE,GAAaH,EAAaG,IAAcK,EAAa,C,CAElGd,EAAGpkC,GAAM8kC,EACJH,EACE/gB,GAAKugB,EAAOnkC,EAAI,MAAQ4jB,GAAKugB,EAAOnkC,IAAO,GACzCmkC,EAAOnkC,EAAI,GAAKmkC,EAAOnkC,IAAM,EAFpBmkC,EAAOnkC,EAAI,GADNmkC,EAAOnkC,E,CAMhCkkC,GAAeha,EAAQia,EAAQC,GAE/BQ,GAAgB1a,EAAQka,EAAI3O,EAC9B,CAEA,SAAS0P,GAAgBC,EAAYz3B,EAAaD,GAChD,OAAOhD,KAAKgD,IAAIhD,KAAKiD,IAAIy3B,EAAI13B,GAAMC,EACrC,CAEA,SAAS03B,GAAgBnb,EAAuBkQ,GAC9C,IAAIp6B,EAAG8gB,EAAMoK,EAAOoa,EAAQC,EACxBC,EAAarL,GAAejQ,EAAO,GAAIkQ,GAC3C,IAAKp6B,EAAI,EAAG8gB,EAAOoJ,EAAOzgB,OAAQzJ,EAAI8gB,IAAQ9gB,EAC5CulC,EAAaD,EACbA,EAASE,EACTA,EAAaxlC,EAAI8gB,EAAO,GAAKqZ,GAAejQ,EAAOlqB,EAAI,GAAIo6B,GACtDkL,IAGLpa,EAAQhB,EAAOlqB,GACXulC,IACFra,EAAM4P,KAAOqK,GAAgBja,EAAM4P,KAAMV,EAAKxQ,KAAMwQ,EAAKvQ,OACzDqB,EAAM8P,KAAOmK,GAAgBja,EAAM8P,KAAMZ,EAAK1K,IAAK0K,EAAKzK,SAEtD6V,IACFta,EAAM6P,KAAOoK,GAAgBja,EAAM6P,KAAMX,EAAKxQ,KAAMwQ,EAAKvQ,OACzDqB,EAAM+P,KAAOkK,GAAgBja,EAAM+P,KAAMb,EAAK1K,IAAK0K,EAAKzK,SAG9D,CAKO,SAAS8V,GACdvb,EACAvgB,EACAywB,EACAntB,EACAwoB,GAEA,IAAIz1B,EAAW8gB,EAAcoK,EAAoBwa,EAOjD,GAJI/7B,EAAQ8gB,WACVP,EAASA,EAAOkY,OAAQgD,IAAQA,EAAG/B,OAGE,aAAnC15B,EAAQg8B,uBACVV,GAAoB/a,EAAQuL,OACvB,CACL,IAAImQ,EAAO34B,EAAOid,EAAOA,EAAOzgB,OAAS,GAAKygB,EAAO,GACrD,IAAKlqB,EAAI,EAAG8gB,EAAOoJ,EAAOzgB,OAAQzJ,EAAI8gB,IAAQ9gB,EAC5CkrB,EAAQhB,EAAOlqB,GACf0lC,EAAgBnC,GACdqC,EACA1a,EACAhB,EAAOxf,KAAKiD,IAAI3N,EAAI,EAAG8gB,GAAQ7T,EAAO,EAAI,IAAM6T,GAChDnX,EAAQk8B,SAEV3a,EAAM4P,KAAO4K,EAAcjL,SAASppB,EACpC6Z,EAAM8P,KAAO0K,EAAcjL,SAASvY,EACpCgJ,EAAM6P,KAAO2K,EAAc/B,KAAKtyB,EAChC6Z,EAAM+P,KAAOyK,EAAc/B,KAAKzhB,EAChC0jB,EAAO1a,C,CAIPvhB,EAAQ07B,iBACVA,GAAgBnb,EAAQkQ,EAE5B,CCtNO,SAAS0L,KACd,MAAyB,qBAAX7iC,QAA8C,qBAAb8iC,QACjD,CAKO,SAASC,GAAeC,GAC7B,IAAI1D,EAAS0D,EAAQC,WAIrB,OAHI3D,GAAgC,wBAAtBA,EAAOhjB,aACnBgjB,EAAUA,EAAsB4D,MAE3B5D,CACT,CAOA,SAAS6D,GAAcC,EAA6BnS,EAAmBoS,GACrE,IAAIC,EAYJ,MAX0B,kBAAfF,GACTE,EAAgBjqB,SAAS+pB,EAAY,KAEJ,IAA7BA,EAAW9kB,QAAQ,OAErBglB,EAAgBA,EAAiB,IAAOrS,EAAKgS,WAAWI,KAG1DC,EAAgBF,EAGXE,CACT,CAEA,MAAMC,GAAoBC,GACxBA,EAAQC,cAAcC,YAAYH,iBAAiBC,EAAS,MAEvD,SAASG,GAASC,EAAiB3hB,GACxC,OAAOshB,GAAiBK,GAAIC,iBAAiB5hB,EAC/C,CAEA,MAAM6hB,GAAY,CAAC,MAAO,QAAS,SAAU,QAC7C,SAASC,GAAmBC,EAA6Bl9B,EAAem9B,GACtE,MAAM3iB,EAAS,CAAC,EAChB2iB,EAASA,EAAS,IAAMA,EAAS,GACjC,IAAK,IAAIlnC,EAAI,EAAGA,EAAI,EAAGA,IAAK,CAC1B,MAAMmnC,EAAMJ,GAAU/mC,GACtBukB,EAAO4iB,GAAOjnB,WAAW+mB,EAAOl9B,EAAQ,IAAMo9B,EAAMD,KAAY,CAClE,CAGA,OAFA3iB,EAAOsO,MAAQtO,EAAOqF,KAAOrF,EAAOsF,MACpCtF,EAAOmU,OAASnU,EAAOmL,IAAMnL,EAAOoL,OAC7BpL,CACT,CAEA,MAAM6iB,GAAeA,CAAC/1B,EAAW6Q,EAAWf,KACzC9P,EAAI,GAAK6Q,EAAI,MAAQf,IAAWA,EAAwBkmB,YAO3D,SAASC,GACPvnC,EACAu4B,GAMA,MAAMiP,EAAUxnC,EAAkBwnC,QAC5BrmB,EAAUqmB,GAAWA,EAAQ99B,OAAS89B,EAAQ,GAAKxnC,GACnD,QAACynC,EAAA,QAASC,GAAWvmB,EAC3B,IACI7P,EAAG6Q,EADHwlB,GAAM,EAEV,GAAIN,GAAaI,EAASC,EAAS1nC,EAAEohB,QACnC9P,EAAIm2B,EACJtlB,EAAIulB,MACC,CACL,MAAM1N,EAAOzB,EAAOqP,wBACpBt2B,EAAI6P,EAAO0mB,QAAU7N,EAAKnQ,KAC1B1H,EAAIhB,EAAO2mB,QAAU9N,EAAKrK,IAC1BgY,GAAM,C,CAER,MAAO,CAACr2B,IAAG6Q,IAAGwlB,MAChB,CASO,SAASI,GACdC,EACAjX,GAEA,GAAI,WAAYiX,EACd,OAAOA,EAGT,MAAM,OAACzP,EAAA,wBAAQH,GAA2BrH,EACpC/mB,EAAQy8B,GAAiBlO,GACzB0P,EAAgC,eAApBj+B,EAAMk+B,UAClBC,EAAWlB,GAAmBj9B,EAAO,WACrCo+B,EAAUnB,GAAmBj9B,EAAO,SAAU,UAC9C,EAACsH,EAAA,EAAG6Q,EAAA,IAAGwlB,GAAOJ,GAAkBS,EAAOzP,GACvCO,EAAUqP,EAASte,MAAQ8d,GAAOS,EAAQve,MAC1CkP,EAAUoP,EAASxY,KAAOgY,GAAOS,EAAQzY,KAE/C,IAAI,MAACmD,EAAA,OAAO6F,GAAU5H,EAKtB,OAJIkX,IACFnV,GAASqV,EAASrV,MAAQsV,EAAQtV,MAClC6F,GAAUwP,EAASxP,OAASyP,EAAQzP,QAE/B,CACLrnB,EAAG3G,KAAKC,OAAO0G,EAAIwnB,GAAWhG,EAAQyF,EAAOzF,MAAQsF,GACrDjW,EAAGxX,KAAKC,OAAOuX,EAAI4W,GAAWJ,EAASJ,EAAOI,OAASP,GAE3D,CAEA,SAASiQ,GAAiB9P,EAA2BzF,EAAe6F,GAClE,IAAImE,EAAkBwL,EAEtB,QAAc74B,IAAVqjB,QAAkCrjB,IAAXkpB,EAAsB,CAC/C,MAAM4P,EAAYhQ,GAAU0N,GAAe1N,GAC3C,GAAKgQ,EAGE,CACL,MAAMvO,EAAOuO,EAAUX,wBACjBY,EAAiB/B,GAAiB8B,GAClCE,EAAkBxB,GAAmBuB,EAAgB,SAAU,SAC/DE,EAAmBzB,GAAmBuB,EAAgB,WAC5D1V,EAAQkH,EAAKlH,MAAQ4V,EAAiB5V,MAAQ2V,EAAgB3V,MAC9D6F,EAASqB,EAAKrB,OAAS+P,EAAiB/P,OAAS8P,EAAgB9P,OACjEmE,EAAWuJ,GAAcmC,EAAe1L,SAAUyL,EAAW,eAC7DD,EAAYjC,GAAcmC,EAAeF,UAAWC,EAAW,e,MAV/DzV,EAAQyF,EAAOoQ,YACfhQ,EAASJ,EAAOqQ,Y,CAYpB,MAAO,CACL9V,QACA6F,SACAmE,SAAUA,GAAYxZ,GACtBglB,UAAWA,GAAahlB,GAE5B,CAEA,MAAMulB,GAAUt7B,GAAc5C,KAAKC,MAAU,GAAJ2C,GAAU,GAG5C,SAASu7B,GACdvQ,EACAwQ,EACAC,EACAC,GAEA,MAAMj/B,EAAQy8B,GAAiBlO,GACzB2Q,EAAUjC,GAAmBj9B,EAAO,UACpC8yB,EAAWuJ,GAAcr8B,EAAM8yB,SAAUvE,EAAQ,gBAAkBjV,GACnEglB,EAAYjC,GAAcr8B,EAAMs+B,UAAW/P,EAAQ,iBAAmBjV,GACtE6lB,EAAgBd,GAAiB9P,EAAQwQ,EAASC,GACxD,IAAI,MAAClW,EAAA,OAAO6F,GAAUwQ,EAEtB,GAAwB,gBAApBn/B,EAAMk+B,UAA6B,CACrC,MAAME,EAAUnB,GAAmBj9B,EAAO,SAAU,SAC9Cm+B,EAAWlB,GAAmBj9B,EAAO,WAC3C8oB,GAASqV,EAASrV,MAAQsV,EAAQtV,MAClC6F,GAAUwP,EAASxP,OAASyP,EAAQzP,M,CAEtC7F,EAAQnoB,KAAKgD,IAAI,EAAGmlB,EAAQoW,EAAQpW,OACpC6F,EAAShuB,KAAKgD,IAAI,EAAGs7B,EAAcnW,EAAQmW,EAActQ,EAASuQ,EAAQvQ,QAC1E7F,EAAQ+V,GAAOl+B,KAAKiD,IAAIklB,EAAOgK,EAAUqM,EAAcrM,WACvDnE,EAASkQ,GAAOl+B,KAAKiD,IAAI+qB,EAAQ2P,EAAWa,EAAcb,YACtDxV,IAAU6F,IAGZA,EAASkQ,GAAO/V,EAAQ,IAG1B,MAAMsW,OAA6B35B,IAAZs5B,QAAsCt5B,IAAbu5B,EAOhD,OALII,GAAkBH,GAAeE,EAAcxQ,QAAUA,EAASwQ,EAAcxQ,SAClFA,EAASwQ,EAAcxQ,OACvB7F,EAAQ+V,GAAOl+B,KAAKyZ,MAAMuU,EAASsQ,KAG9B,CAACnW,QAAO6F,SACjB,CAQO,SAAS0Q,GACdtY,EACAuY,EACAC,GAEA,MAAMC,EAAaF,GAAc,EAC3BG,EAAeZ,GAAO9X,EAAM4H,OAAS6Q,GACrCE,EAAcb,GAAO9X,EAAM+B,MAAQ0W,GAExCzY,EAAuB4H,OAASkQ,GAAO9X,EAAM4H,QAC7C5H,EAAuB+B,MAAQ+V,GAAO9X,EAAM+B,OAE7C,MAAMyF,EAASxH,EAAMwH,OAUrB,OALIA,EAAOvuB,QAAUu/B,IAAgBhR,EAAOvuB,MAAM2uB,SAAWJ,EAAOvuB,MAAM8oB,SACxEyF,EAAOvuB,MAAM2uB,OAAS,GAAG5H,EAAM4H,WAC/BJ,EAAOvuB,MAAM8oB,MAAQ,GAAG/B,EAAM+B,YAG5B/B,EAAMqH,0BAA4BoR,GAC/BjR,EAAOI,SAAW8Q,GAClBlR,EAAOzF,QAAU4W,KACrB3Y,EAAuBqH,wBAA0BoR,EAClDjR,EAAOI,OAAS8Q,EAChBlR,EAAOzF,MAAQ4W,EACf3Y,EAAMwE,IAAIoU,aAAaH,EAAY,EAAG,EAAGA,EAAY,EAAG,IACjD,EAGX,CAOa,MAAAI,GAAgC,WAC3C,IAAIC,GAAmB,EACvB,IACE,MAAMjgC,EAAU,CACd,WAAIkgC,GAEF,OADAD,GAAmB,GACZ,CACT,GAGE9D,OACF7iC,OAAOG,iBAAiB,OAAQ,KAAMuG,GACtC1G,OAAOK,oBAAoB,OAAQ,KAAMqG,GAE7C,CAAE,MAAO5J,G,CAGT,OAAO6pC,CACT,CAlB6C,GA8BtC,SAASE,GACdrD,EACAvhB,GAEA,MAAMzkB,EAAQmmC,GAASH,EAASvhB,GAC1BqY,EAAU98B,GAASA,EAAM+8B,MAAM,qBACrC,OAAOD,GAAWA,EAAQ,QAAK/tB,CACjC,CCtRO,SAASu6B,GAAa/4B,EAAWC,EAAWpR,EAAW81B,GAC5D,MAAO,CACLtkB,EAAGL,EAAGK,EAAIxR,GAAKoR,EAAGI,EAAIL,EAAGK,GACzB6Q,EAAGlR,EAAGkR,EAAIriB,GAAKoR,EAAGiR,EAAIlR,EAAGkR,GAE7B,CAKO,SAAS8nB,GACdh5B,EACAC,EACApR,EAAW81B,GAEX,MAAO,CACLtkB,EAAGL,EAAGK,EAAIxR,GAAKoR,EAAGI,EAAIL,EAAGK,GACzB6Q,EAAY,WAATyT,EAAoB91B,EAAI,GAAMmR,EAAGkR,EAAIjR,EAAGiR,EAC9B,UAATyT,EAAmB91B,EAAI,EAAImR,EAAGkR,EAAIjR,EAAGiR,EACnCriB,EAAI,EAAIoR,EAAGiR,EAAIlR,EAAGkR,EAE5B,CAKO,SAAS+nB,GAAqBj5B,EAAiBC,EAAiBpR,EAAW81B,GAChF,MAAMuU,EAAM,CAAC74B,EAAGL,EAAG+pB,KAAM7Y,EAAGlR,EAAGiqB,MACzBkP,EAAM,CAAC94B,EAAGJ,EAAG6pB,KAAM5Y,EAAGjR,EAAG+pB,MACzBzsB,EAAIw7B,GAAa/4B,EAAIk5B,EAAKrqC,GAC1B2O,EAAIu7B,GAAaG,EAAKC,EAAKtqC,GAC3B4O,EAAIs7B,GAAaI,EAAKl5B,EAAIpR,GAC1B6O,EAAIq7B,GAAax7B,EAAGC,EAAG3O,GACvBE,EAAIgqC,GAAav7B,EAAGC,EAAG5O,GAC7B,OAAOkqC,GAAar7B,EAAG3O,EAAGF,EAC5B,CChCA,MAAMuqC,GAAwB,SAASC,EAAexX,GACpD,MAAO,CACLxhB,CAAAA,CAAEA,GACA,OAAOg5B,EAAQA,EAAQxX,EAAQxhB,CACjC,EACAi5B,QAAAA,CAASt6B,GACP6iB,EAAQ7iB,CACV,EACAsrB,SAAAA,CAAU7R,GACR,MAAc,WAAVA,EACKA,EAEQ,UAAVA,EAAoB,OAAS,OACtC,EACA8gB,KAAAA,CAAMl5B,EAAG5Q,GACP,OAAO4Q,EAAI5Q,CACb,EACA+pC,UAAAA,CAAWn5B,EAAGo5B,GACZ,OAAOp5B,EAAIo5B,CACb,EAEJ,EAEMC,GAAwB,WAC5B,MAAO,CACLr5B,CAAAA,CAAEA,GACA,OAAOA,CACT,EACAi5B,QAAAA,CAASt6B,GAAI,EAEbsrB,SAAAA,CAAU7R,GACR,OAAOA,CACT,EACA8gB,KAAAA,CAAMl5B,EAAG5Q,GACP,OAAO4Q,EAAI5Q,CACb,EACA+pC,UAAAA,CAAWn5B,EAAGs5B,GACZ,OAAOt5B,CACT,EAEJ,EAEO,SAASu5B,GAAc9gB,EAAcugB,EAAexX,GACzD,OAAO/I,EAAMsgB,GAAsBC,EAAOxX,GAAS6X,IACrD,CAEO,SAASG,GAAsBvV,EAA+BwV,GACnE,IAAI/gC,EAA4BghC,EACd,QAAdD,GAAqC,QAAdA,IACzB/gC,EAAQurB,EAAIgD,OAAOvuB,MACnBghC,EAAW,CACThhC,EAAM+8B,iBAAiB,aACvB/8B,EAAMihC,oBAAoB,cAG5BjhC,EAAMkhC,YAAY,YAAaH,EAAW,aACzCxV,EAAiD4V,kBAAoBH,EAE1E,CAEO,SAASI,GAAqB7V,EAA+ByV,QACjDv7B,IAAbu7B,WACMzV,EAAiD4V,kBACzD5V,EAAIgD,OAAOvuB,MAAMkhC,YAAY,YAAaF,EAAS,GAAIA,EAAS,IAEpE,CC/DA,SAASK,GAAWlmB,GAClB,MAAiB,UAAbA,EACK,CACLmmB,QAAS/kB,GACTglB,QAASllB,GACTmlB,UAAWllB,IAGR,CACLglB,QAASrkB,GACTskB,QAASA,CAAC/8B,EAAGC,IAAMD,EAAIC,EACvB+8B,UAAWl6B,GAAKA,EAEpB,CAEA,SAASm6B,IAAiB,MAACjlB,EAAK,IAAEC,EAAG,MAAE3c,EAAK,KAAEoD,EAAI,MAAElD,IAClD,MAAO,CACLwc,MAAOA,EAAQ1c,EACf2c,IAAKA,EAAM3c,EACXoD,KAAMA,IAASuZ,EAAMD,EAAQ,GAAK1c,IAAU,EAC5CE,QAEJ,CAEA,SAAS0hC,GAAWC,EAASxhB,EAAQ8H,GACnC,MAAM,SAAC9M,EAAUqB,MAAOolB,EAAYnlB,IAAKolB,GAAY5Z,GAC/C,QAACqZ,EAAO,UAAEE,GAAaH,GAAWlmB,GAClCrb,EAAQqgB,EAAOzgB,OAErB,IACIzJ,EAAG8gB,GADH,MAACyF,EAAK,IAAEC,EAAA,KAAKvZ,GAAQy+B,EAGzB,GAAIz+B,EAAM,CAGR,IAFAsZ,GAAS1c,EACT2c,GAAO3c,EACF7J,EAAI,EAAG8gB,EAAOjX,EAAO7J,EAAI8gB,IAAQ9gB,EAAG,CACvC,IAAKqrC,EAAQE,EAAUrhB,EAAO3D,EAAQ1c,GAAOqb,IAAYymB,EAAYC,GACnE,MAEFrlB,IACAC,GACF,CACAD,GAAS1c,EACT2c,GAAO3c,C,CAMT,OAHI2c,EAAMD,IACRC,GAAO3c,GAEF,CAAC0c,QAAOC,MAAKvZ,OAAMlD,MAAO2hC,EAAQ3hC,MAC3C,CAgBO,SAAS8hC,GAAcH,EAASxhB,EAAQ8H,GAC7C,IAAKA,EACH,MAAO,CAAC0Z,GAGV,MAAM,SAACxmB,EAAUqB,MAAOolB,EAAYnlB,IAAKolB,GAAY5Z,EAC/CnoB,EAAQqgB,EAAOzgB,QACf,QAAC6hC,EAAA,QAASD,EAAA,UAASE,GAAaH,GAAWlmB,IAC3C,MAACqB,EAAA,IAAOC,EAAA,KAAKvZ,EAAA,MAAMlD,GAAS0hC,GAAWC,EAASxhB,EAAQ8H,GAExDzN,EAAS,GACf,IAEI9jB,EAAOyqB,EAAO4gB,EAFdC,GAAS,EACTC,EAAW,KAGf,MAAMC,EAAgBA,IAAMZ,EAAQM,EAAYG,EAAWrrC,IAA6C,IAAnC6qC,EAAQK,EAAYG,GACnFI,EAAcA,IAAmC,IAA7BZ,EAAQM,EAAUnrC,IAAgB4qC,EAAQO,EAAUE,EAAWrrC,GACnF0rC,EAAcA,IAAMJ,GAAUE,IAC9BG,EAAaA,KAAOL,GAAUG,IAEpC,IAAK,IAAIlsC,EAAIumB,EAAOqf,EAAOrf,EAAOvmB,GAAKwmB,IAAOxmB,EAC5CkrB,EAAQhB,EAAOlqB,EAAI6J,GAEfqhB,EAAMmY,OAIV5iC,EAAQ8qC,EAAUrgB,EAAMhG,IAEpBzkB,IAAUqrC,IAIdC,EAASV,EAAQ5qC,EAAOkrC,EAAYC,GAEnB,OAAbI,GAAqBG,MACvBH,EAA0C,IAA/BV,EAAQ7qC,EAAOkrC,GAAoB3rC,EAAI4lC,GAGnC,OAAboG,GAAqBI,MACvB7nB,EAAOhC,KAAKipB,GAAiB,CAACjlB,MAAOylB,EAAUxlB,IAAKxmB,EAAGiN,OAAMpD,QAAOE,WACpEiiC,EAAW,MAEbpG,EAAO5lC,EACP8rC,EAAYrrC,IAOd,OAJiB,OAAburC,GACFznB,EAAOhC,KAAKipB,GAAiB,CAACjlB,MAAOylB,EAAUxlB,MAAKvZ,OAAMpD,QAAOE,WAG5Dwa,CACT,CAYO,SAAS8nB,GAAe5Q,EAAMzJ,GACnC,MAAMzN,EAAS,GACT+nB,EAAW7Q,EAAK6Q,SAEtB,IAAK,IAAItsC,EAAI,EAAGA,EAAIssC,EAAS7iC,OAAQzJ,IAAK,CACxC,MAAMusC,EAAMV,GAAcS,EAAStsC,GAAIy7B,EAAKvR,OAAQ8H,GAChDua,EAAI9iC,QACN8a,EAAOhC,QAAQgqB,EAEnB,CACA,OAAOhoB,CACT,CAKA,SAASioB,GAAgBtiB,EAAQrgB,EAAOoD,EAAMwd,GAC5C,IAAIlE,EAAQ,EACRC,EAAM3c,EAAQ,EAElB,GAAIoD,IAASwd,EAEX,MAAOlE,EAAQ1c,IAAUqgB,EAAO3D,GAAO8c,KACrC9c,IAKJ,MAAOA,EAAQ1c,GAASqgB,EAAO3D,GAAO8c,KACpC9c,IAIFA,GAAS1c,EAELoD,IAEFuZ,GAAOD,GAGT,MAAOC,EAAMD,GAAS2D,EAAO1D,EAAM3c,GAAOw5B,KACxC7c,IAMF,OAFAA,GAAO3c,EAEA,CAAC0c,QAAOC,MACjB,CASA,SAASimB,GAAcviB,EAAQ3D,EAAO7Y,EAAKT,GACzC,MAAMpD,EAAQqgB,EAAOzgB,OACf8a,EAAS,GACf,IAEIiC,EAFAgB,EAAOjB,EACPqf,EAAO1b,EAAO3D,GAGlB,IAAKC,EAAMD,EAAQ,EAAGC,GAAO9Y,IAAO8Y,EAAK,CACvC,MAAMkmB,EAAMxiB,EAAO1D,EAAM3c,GACrB6iC,EAAIrJ,MAAQqJ,EAAIC,KACb/G,EAAKvC,OACRp2B,GAAO,EACPsX,EAAOhC,KAAK,CAACgE,MAAOA,EAAQ1c,EAAO2c,KAAMA,EAAM,GAAK3c,EAAOoD,SAE3DsZ,EAAQiB,EAAOklB,EAAIC,KAAOnmB,EAAM,OAGlCgB,EAAOhB,EACHof,EAAKvC,OACP9c,EAAQC,IAGZof,EAAO8G,CACT,CAMA,OAJa,OAATllB,GACFjD,EAAOhC,KAAK,CAACgE,MAAOA,EAAQ1c,EAAO2c,IAAKgB,EAAO3d,EAAOoD,SAGjDsX,CACT,CAUO,SAASqoB,GAAiBnR,EAAMoR,GACrC,MAAM3iB,EAASuR,EAAKvR,OACdO,EAAWgR,EAAK9xB,QAAQ8gB,SACxB5gB,EAAQqgB,EAAOzgB,OAErB,IAAKI,EACH,MAAO,GAGT,MAAMoD,IAASwuB,EAAKqR,OACd,MAACvmB,EAAA,IAAOC,GAAOgmB,GAAgBtiB,EAAQrgB,EAAOoD,EAAMwd,GAE1D,IAAiB,IAAbA,EACF,OAAOsiB,GAActR,EAAM,CAAC,CAAClV,QAAOC,MAAKvZ,SAAQid,EAAQ2iB,GAG3D,MAAMn/B,EAAM8Y,EAAMD,EAAQC,EAAM3c,EAAQ2c,EAClCwmB,IAAiBvR,EAAKwR,WAAuB,IAAV1mB,GAAeC,IAAQ3c,EAAQ,EACxE,OAAOkjC,GAActR,EAAMgR,GAAcviB,EAAQ3D,EAAO7Y,EAAKs/B,GAAe9iB,EAAQ2iB,EACtF,CAQA,SAASE,GAActR,EAAM6Q,EAAUpiB,EAAQ2iB,GAC7C,OAAKA,GAAmBA,EAAe7L,YAAe9W,EAG/CgjB,GAAgBzR,EAAM6Q,EAAUpiB,EAAQ2iB,GAFtCP,CAGX,CASA,SAASY,GAAgBzR,EAAM6Q,EAAUpiB,EAAQ2iB,GAC/C,MAAMM,EAAe1R,EAAK2R,OAAO7U,aAC3B8U,EAAYC,GAAU7R,EAAK9xB,UAC1B4jC,cAAetsB,EAActX,SAAS,SAAC8gB,IAAagR,EACrD5xB,EAAQqgB,EAAOzgB,OACf8a,EAAS,GACf,IAAIipB,EAAYH,EACZ9mB,EAAQ+lB,EAAS,GAAG/lB,MACpBvmB,EAAIumB,EAER,SAASknB,EAAS99B,EAAG5P,EAAGyN,EAAGkgC,GACzB,MAAMC,EAAMljB,GAAY,EAAI,EAC5B,GAAI9a,IAAM5P,EAAV,CAIA4P,GAAK9F,EACL,MAAOqgB,EAAOva,EAAI9F,GAAOw5B,KACvB1zB,GAAKg+B,EAEP,MAAOzjB,EAAOnqB,EAAI8J,GAAOw5B,KACvBtjC,GAAK4tC,EAEHh+B,EAAI9F,IAAU9J,EAAI8J,IACpB0a,EAAOhC,KAAK,CAACgE,MAAO5W,EAAI9F,EAAO2c,IAAKzmB,EAAI8J,EAAOoD,KAAMO,EAAGzD,MAAO2jC,IAC/DF,EAAYE,EACZnnB,EAAQxmB,EAAI8J,E,CAEhB,CAEA,IAAK,MAAM6hC,KAAWY,EAAU,CAC9B/lB,EAAQkE,EAAWlE,EAAQmlB,EAAQnlB,MACnC,IACIxc,EADA67B,EAAO1b,EAAO3D,EAAQ1c,GAE1B,IAAK7J,EAAIumB,EAAQ,EAAGvmB,GAAK0rC,EAAQllB,IAAKxmB,IAAK,CACzC,MAAMolC,EAAKlb,EAAOlqB,EAAI6J,GACtBE,EAAQujC,GAAUT,EAAe7L,WAAWlC,GAAcqO,EAAc,CACtE3qC,KAAM,UACNorC,GAAIhI,EACJ50B,GAAIo0B,EACJyI,aAAc7tC,EAAI,GAAK6J,EACvBikC,YAAa9tC,EAAI6J,EACjBoX,mBAEE8sB,GAAahkC,EAAOyjC,IACtBC,EAASlnB,EAAOvmB,EAAI,EAAG0rC,EAAQz+B,KAAMugC,GAEvC5H,EAAOR,EACPoI,EAAYzjC,CACd,CACIwc,EAAQvmB,EAAI,GACdytC,EAASlnB,EAAOvmB,EAAI,EAAG0rC,EAAQz+B,KAAMugC,EAEzC,CAEA,OAAOjpB,CACT,CAEA,SAAS+oB,GAAU3jC,GACjB,MAAO,CACL6qB,gBAAiB7qB,EAAQ6qB,gBACzBwZ,eAAgBrkC,EAAQqkC,eACxBC,WAAYtkC,EAAQskC,WACpBC,iBAAkBvkC,EAAQukC,iBAC1BC,gBAAiBxkC,EAAQwkC,gBACzBlU,YAAatwB,EAAQswB,YACrBxF,YAAa9qB,EAAQ8qB,YAEzB,CAEA,SAASsZ,GAAahkC,EAAOyjC,GAC3B,IAAKA,EACH,OAAO,EAET,MAAM/V,EAAQ,GACR2W,EAAW,SAASxsC,EAAKnB,GAC7B,OAAK0tB,GAAoB1tB,IAGpBg3B,EAAM/F,SAASjxB,IAClBg3B,EAAMlV,KAAK9hB,GAENg3B,EAAMlW,QAAQ9gB,IALZA,CAMX,EACA,OAAOwvB,KAAKC,UAAUnmB,EAAOqkC,KAAcne,KAAKC,UAAUsd,EAAWY,EACvE,CCzWA,SAASC,GAAelY,EAAcmY,EAAsBC,GAC1D,OAAOpY,EAAMxsB,QAAQsoB,KAAOkE,EAAMoY,GAASD,EAAUC,EACvD,CAEA,SAASC,GAAevkB,EAAiBqkB,GACvC,MAAM,OAACjjB,EAAA,OAAQC,GAAUrB,EACzB,OAAIoB,GAAUC,EACL,CACL1B,KAAMykB,GAAehjB,EAAQijB,EAAW,QACxCzkB,MAAOwkB,GAAehjB,EAAQijB,EAAW,SACzC5e,IAAK2e,GAAe/iB,EAAQgjB,EAAW,OACvC3e,OAAQ0e,GAAe/iB,EAAQgjB,EAAW,WAGvCA,CACT,CAEO,SAASG,GAAmB3d,EAAc7G,GAC/C,MAAMgI,EAAOhI,EAAKykB,MAClB,GAAIzc,EAAKpuB,SACP,OAAO,EAET,MAAMu2B,EAAOoU,GAAevkB,EAAM6G,EAAMwd,WAExC,MAAO,CACL1kB,MAAoB,IAAdqI,EAAKrI,KAAiB,EAAIwQ,EAAKxQ,OAAsB,IAAdqI,EAAKrI,KAAgB,EAAIqI,EAAKrI,MAC3EC,OAAsB,IAAfoI,EAAKpI,MAAkBiH,EAAM+B,MAAQuH,EAAKvQ,QAAwB,IAAfoI,EAAKpI,MAAiB,EAAIoI,EAAKpI,OACzF6F,KAAkB,IAAbuC,EAAKvC,IAAgB,EAAI0K,EAAK1K,MAAoB,IAAbuC,EAAKvC,IAAe,EAAIuC,EAAKvC,KACvEC,QAAwB,IAAhBsC,EAAKtC,OAAmBmB,EAAM4H,OAAS0B,EAAKzK,SAA0B,IAAhBsC,EAAKtC,OAAkB,EAAIsC,EAAKtC,QAElG;;;;;;;ACrBO,MAAMgf,GACXjvC,WAAAA,GACEmD,KAAK+rC,SAAW,KAChB/rC,KAAKgsC,QAAU,IAAIhf,IACnBhtB,KAAKisC,UAAW,EAChBjsC,KAAKksC,eAAYv/B,CACnB,CAKAw/B,OAAAA,CAAQle,EAAOme,EAAOC,EAAM1sC,GAC1B,MAAM2sC,EAAYF,EAAMhnB,UAAUzlB,GAC5B4sC,EAAWH,EAAMxgB,SAEvB0gB,EAAUjnB,QAAQ7H,GAAMA,EAAG,CACzByQ,QACAue,QAASJ,EAAMI,QACfD,WACAE,YAAa5kC,KAAKiD,IAAIuhC,EAAOD,EAAM1oB,MAAO6oB,KAE9C,CAKAG,QAAAA,GACM1sC,KAAK+rC,WAGT/rC,KAAKisC,UAAW,EAEhBjsC,KAAK+rC,SAAW9lB,GAAiB7oB,KAAKgD,OAAQ,KAC5CJ,KAAK2sC,UACL3sC,KAAK+rC,SAAW,KAEZ/rC,KAAKisC,UACPjsC,KAAK0sC,aAGX,CAKAC,OAAAA,CAAQN,EAAOO,KAAKC,OAClB,IAAIC,EAAY,EAEhB9sC,KAAKgsC,QAAQ3mB,QAAQ,CAAC+mB,EAAOne,KAC3B,IAAKme,EAAMW,UAAYX,EAAMtmB,MAAMlf,OACjC,OAEF,MAAMkf,EAAQsmB,EAAMtmB,MACpB,IAEIhnB,EAFA3B,EAAI2oB,EAAMlf,OAAS,EACnBomC,GAAO,EAGX,KAAO7vC,GAAK,IAAKA,EACf2B,EAAOgnB,EAAM3oB,GAET2B,EAAKmuC,SACHnuC,EAAKouC,OAASd,EAAMxgB,WAGtBwgB,EAAMxgB,SAAW9sB,EAAKouC,QAExBpuC,EAAKquC,KAAKd,GACVW,GAAO,IAIPlnB,EAAM3oB,GAAK2oB,EAAMA,EAAMlf,OAAS,GAChCkf,EAAMjE,OAINmrB,IACF/e,EAAM+e,OACNhtC,KAAKmsC,QAAQle,EAAOme,EAAOC,EAAM,aAG9BvmB,EAAMlf,SACTwlC,EAAMW,SAAU,EAChB/sC,KAAKmsC,QAAQle,EAAOme,EAAOC,EAAM,YACjCD,EAAMI,SAAU,GAGlBM,GAAahnB,EAAMlf,SAGrB5G,KAAKksC,UAAYG,EAEC,IAAdS,IACF9sC,KAAKisC,UAAW,EAEpB,CAKAmB,SAAAA,CAAUnf,GACR,MAAMof,EAASrtC,KAAKgsC,QACpB,IAAII,EAAQiB,EAAO9f,IAAIU,GAavB,OAZKme,IACHA,EAAQ,CACNW,SAAS,EACTP,SAAS,EACT1mB,MAAO,GACPV,UAAW,CACTkoB,SAAU,GACVC,SAAU,KAGdF,EAAOtnB,IAAIkI,EAAOme,IAEbA,CACT,CAOAoB,MAAAA,CAAOvf,EAAOiX,EAAOuI,GACnBztC,KAAKotC,UAAUnf,GAAO7I,UAAU8f,GAAOxlB,KAAK+tB,EAC9C,CAOAzR,GAAAA,CAAI/N,EAAOnI,GACJA,GAAUA,EAAMlf,QAGrB5G,KAAKotC,UAAUnf,GAAOnI,MAAMpG,QAAQoG,EACtC,CAMA3F,GAAAA,CAAI8N,GACF,OAAOjuB,KAAKotC,UAAUnf,GAAOnI,MAAMlf,OAAS,CAC9C,CAMA8c,KAAAA,CAAMuK,GACJ,MAAMme,EAAQpsC,KAAKgsC,QAAQze,IAAIU,GAC1Bme,IAGLA,EAAMW,SAAU,EAChBX,EAAM1oB,MAAQkpB,KAAKC,MACnBT,EAAMxgB,SAAWwgB,EAAMtmB,MAAM4nB,OAAO,CAACC,EAAK9D,IAAQhiC,KAAKgD,IAAI8iC,EAAK9D,EAAI+D,WAAY,GAChF5tC,KAAK0sC,WACP,CAEAK,OAAAA,CAAQ9e,GACN,IAAKjuB,KAAKisC,SACR,OAAO,EAET,MAAMG,EAAQpsC,KAAKgsC,QAAQze,IAAIU,GAC/B,SAAKme,GAAUA,EAAMW,SAAYX,EAAMtmB,MAAMlf,OAI/C,CAMAkjC,IAAAA,CAAK7b,GACH,MAAMme,EAAQpsC,KAAKgsC,QAAQze,IAAIU,GAC/B,IAAKme,IAAUA,EAAMtmB,MAAMlf,OACzB,OAEF,MAAMkf,EAAQsmB,EAAMtmB,MACpB,IAAI3oB,EAAI2oB,EAAMlf,OAAS,EAEvB,KAAOzJ,GAAK,IAAKA,EACf2oB,EAAM3oB,GAAG0wC,SAEXzB,EAAMtmB,MAAQ,GACd9lB,KAAKmsC,QAAQle,EAAOme,EAAOQ,KAAKC,MAAO,WACzC,CAMAiB,MAAAA,CAAO7f,GACL,OAAOjuB,KAAKgsC,QAAQ5M,OAAOnR,EAC7B,EAIF,IAAA8f,GAA+B,IAAIjC,GCjNnC,MAAMlyB,GAAc,cACdo0B,GAAgB,CACpBC,OAAAA,CAAQ9zB,EAAMF,EAAIi0B,GAChB,OAAOA,EAAS,GAAMj0B,EAAKE,CAC7B,EAMAoB,KAAAA,CAAMpB,EAAMF,EAAIi0B,GACd,MAAMC,EAAK5yB,GAAapB,GAAQP,IAC1B6B,EAAK0yB,EAAG/yB,OAASG,GAAatB,GAAML,IAC1C,OAAO6B,GAAMA,EAAGL,MACZK,EAAGH,IAAI6yB,EAAID,GAAQxhC,YACnBuN,CACN,EACAm0B,MAAAA,CAAOj0B,EAAMF,EAAIi0B,GACf,OAAO/zB,GAAQF,EAAKE,GAAQ+zB,CAC9B,GAGa,MAAMG,GACnBxxC,WAAAA,CAAYyxC,EAAKhwB,EAAQ0c,EAAM/gB,GAC7B,MAAMs0B,EAAejwB,EAAO0c,GAE5B/gB,EAAKuhB,GAAQ,CAAC8S,EAAIr0B,GAAIA,EAAIs0B,EAAcD,EAAIn0B,OAC5C,MAAMA,EAAOqhB,GAAQ,CAAC8S,EAAIn0B,KAAMo0B,EAAct0B,IAE9Cja,KAAKitC,SAAU,EACfjtC,KAAKwuC,IAAMF,EAAI9wB,IAAMwwB,GAAcM,EAAI3uC,aAAewa,GACtDna,KAAKyuC,QAAUplB,GAAQilB,EAAIziB,SAAWxC,GAAQC,OAC9CtpB,KAAK0uC,OAAS7mC,KAAKyZ,MAAMsrB,KAAKC,OAASyB,EAAI/nB,OAAS,IACpDvmB,KAAK4tC,UAAY5tC,KAAKktC,OAASrlC,KAAKyZ,MAAMgtB,EAAI1iB,UAC9C5rB,KAAKiqC,QAAUqE,EAAIlkC,KACnBpK,KAAK2uC,QAAUrwB,EACfte,KAAK4uC,MAAQ5T,EACbh7B,KAAK6uC,MAAQ10B,EACbna,KAAK8uC,IAAM70B,EACXja,KAAK+uC,eAAYpiC,CACnB,CAEAwf,MAAAA,GACE,OAAOnsB,KAAKitC,OACd,CAEA+B,MAAAA,CAAOV,EAAKr0B,EAAIoyB,GACd,GAAIrsC,KAAKitC,QAAS,CAChBjtC,KAAKmsC,SAAQ,GAEb,MAAMoC,EAAevuC,KAAK2uC,QAAQ3uC,KAAK4uC,OACjCK,EAAU5C,EAAOrsC,KAAK0uC,OACtB/f,EAAS3uB,KAAK4tC,UAAYqB,EAChCjvC,KAAK0uC,OAASrC,EACdrsC,KAAK4tC,UAAY/lC,KAAKyZ,MAAMzZ,KAAKgD,IAAI8jB,EAAQ2f,EAAI1iB,WACjD5rB,KAAKktC,QAAU+B,EACfjvC,KAAKiqC,QAAUqE,EAAIlkC,KACnBpK,KAAK8uC,IAAMtT,GAAQ,CAAC8S,EAAIr0B,GAAIA,EAAIs0B,EAAcD,EAAIn0B,OAClDna,KAAK6uC,MAAQrT,GAAQ,CAAC8S,EAAIn0B,KAAMo0B,EAAct0B,G,CAElD,CAEA4zB,MAAAA,GACM7tC,KAAKitC,UAEPjtC,KAAKmtC,KAAKP,KAAKC,OACf7sC,KAAKitC,SAAU,EACfjtC,KAAKmsC,SAAQ,GAEjB,CAEAgB,IAAAA,CAAKd,GACH,MAAM4C,EAAU5C,EAAOrsC,KAAK0uC,OACtB9iB,EAAW5rB,KAAK4tC,UAChB5S,EAAOh7B,KAAK4uC,MACZz0B,EAAOna,KAAK6uC,MACZzkC,EAAOpK,KAAKiqC,MACZhwB,EAAKja,KAAK8uC,IAChB,IAAIZ,EAIJ,GAFAluC,KAAKitC,QAAU9yB,IAASF,IAAO7P,GAAS6kC,EAAUrjB,IAE7C5rB,KAAKitC,QAGR,OAFAjtC,KAAK2uC,QAAQ3T,GAAQ/gB,OACrBja,KAAKmsC,SAAQ,GAIX8C,EAAU,EACZjvC,KAAK2uC,QAAQ3T,GAAQ7gB,GAIvB+zB,EAAUe,EAAUrjB,EAAY,EAChCsiB,EAAS9jC,GAAQ8jC,EAAS,EAAI,EAAIA,EAASA,EAC3CA,EAASluC,KAAKyuC,QAAQ5mC,KAAKiD,IAAI,EAAGjD,KAAKgD,IAAI,EAAGqjC,KAE9CluC,KAAK2uC,QAAQ3T,GAAQh7B,KAAKwuC,IAAIr0B,EAAMF,EAAIi0B,GAC1C,CAEAgB,IAAAA,GACE,MAAMC,EAAWnvC,KAAK+uC,YAAc/uC,KAAK+uC,UAAY,IACrD,OAAO,IAAIK,QAAQ,CAAC5pB,EAAK6pB,KACvBF,EAASzvB,KAAK,CAAC8F,MAAK6pB,SAExB,CAEAlD,OAAAA,CAAQmD,GACN,MAAMhqB,EAASgqB,EAAW,MAAQ,MAC5BH,EAAWnvC,KAAK+uC,WAAa,GACnC,IAAK,IAAI5xC,EAAI,EAAGA,EAAIgyC,EAASvoC,OAAQzJ,IACnCgyC,EAAShyC,GAAGmoB,IAEhB,EChHa,MAAMiqB,GACnB1yC,WAAAA,CAAYoxB,EAAOuhB,GACjBxvC,KAAKuqC,OAAStc,EACdjuB,KAAKyvC,YAAc,IAAIziB,IACvBhtB,KAAK0vC,UAAUF,EACjB,CAEAE,SAAAA,CAAUF,GACR,IAAK5yB,GAAS4yB,GACZ,OAGF,MAAMG,EAAmBjyC,OAAOgJ,KAAKilB,GAASS,WACxCwjB,EAAgB5vC,KAAKyvC,YAE3B/xC,OAAOmyC,oBAAoBL,GAAQnqB,QAAQtmB,IACzC,MAAMuvC,EAAMkB,EAAOzwC,GACnB,IAAK6d,GAAS0xB,GACZ,OAEF,MAAMgB,EAAW,CAAC,EAClB,IAAK,MAAMQ,KAAUH,EACnBL,EAASQ,GAAUxB,EAAIwB,IAGxBpiC,GAAQ4gC,EAAIpiB,aAAeoiB,EAAIpiB,YAAc,CAACntB,IAAMsmB,QAAS2V,IACxDA,IAASj8B,GAAQ6wC,EAAczvB,IAAI6a,IACrC4U,EAAc7pB,IAAIiV,EAAMsU,MAIhC,CAMAS,eAAAA,CAAgBzxB,EAAQyG,GACtB,MAAMirB,EAAajrB,EAAOje,QACpBA,EAAUmpC,GAAqB3xB,EAAQ0xB,GAC7C,IAAKlpC,EACH,MAAO,GAGT,MAAMylB,EAAavsB,KAAKkwC,kBAAkBppC,EAASkpC,GAYnD,OAXIA,EAAWG,SAIbC,GAAS9xB,EAAOxX,QAAQupC,YAAaL,GAAYM,KAAK,KACpDhyB,EAAOxX,QAAUkpC,GAChB,QAKEzjB,CACT,CAKA2jB,iBAAAA,CAAkB5xB,EAAQyG,GACxB,MAAM6qB,EAAgB5vC,KAAKyvC,YACrBljB,EAAa,GACbwgB,EAAUzuB,EAAO+xB,cAAgB/xB,EAAO+xB,YAAc,CAAC,GACvD3wC,EAAQhC,OAAOgJ,KAAKqe,GACpBsnB,EAAOO,KAAKC,MAClB,IAAI1vC,EAEJ,IAAKA,EAAIuC,EAAMkH,OAAS,EAAGzJ,GAAK,IAAKA,EAAG,CACtC,MAAM69B,EAAOt7B,EAAMvC,GACnB,GAAuB,MAAnB69B,EAAKhgB,OAAO,GACd,SAGF,GAAa,YAATggB,EAAoB,CACtBzO,EAAW7M,QAAQ1f,KAAK+vC,gBAAgBzxB,EAAQyG,IAChD,Q,CAEF,MAAMnnB,EAAQmnB,EAAOiW,GACrB,IAAI5O,EAAY2gB,EAAQ/R,GACxB,MAAMsT,EAAMsB,EAAcriB,IAAIyN,GAE9B,GAAI5O,EAAW,CACb,GAAIkiB,GAAOliB,EAAUD,SAAU,CAE7BC,EAAU4iB,OAAOV,EAAK1wC,EAAOyuC,GAC7B,Q,CAEAjgB,EAAUyhB,Q,CAGTS,GAAQA,EAAI1iB,UAMjBmhB,EAAQ/R,GAAQ5O,EAAY,IAAIiiB,GAAUC,EAAKhwB,EAAQ0c,EAAMp9B,GAC7D2uB,EAAW7M,KAAK0M,IALd9N,EAAO0c,GAAQp9B,CAMnB,CACA,OAAO2uB,CACT,CASAyiB,MAAAA,CAAO1wB,EAAQyG,GACb,GAA8B,IAA1B/kB,KAAKyvC,YAAYnnC,KAGnB,YADA5K,OAAOkd,OAAO0D,EAAQyG,GAIxB,MAAMwH,EAAavsB,KAAKkwC,kBAAkB5xB,EAAQyG,GAElD,OAAIwH,EAAW3lB,QACbmnC,GAAS/R,IAAIh8B,KAAKuqC,OAAQhe,IACnB,QAFT,CAIF,EAGF,SAAS6jB,GAAS7jB,EAAYL,GAC5B,MAAM6gB,EAAU,GACVrmC,EAAOhJ,OAAOgJ,KAAKwlB,GACzB,IAAK,IAAI/uB,EAAI,EAAGA,EAAIuJ,EAAKE,OAAQzJ,IAAK,CACpC,MAAMozC,EAAOhkB,EAAW7lB,EAAKvJ,IACzBozC,GAAQA,EAAKpkB,UACf4gB,EAAQrtB,KAAK6wB,EAAKrB,OAEtB,CAEA,OAAOE,QAAQoB,IAAIzD,EACrB,CAEA,SAASkD,GAAqB3xB,EAAQ0xB,GACpC,IAAKA,EACH,OAEF,IAAIlpC,EAAUwX,EAAOxX,QACrB,GAAKA,EASL,OALIA,EAAQqpC,UAGV7xB,EAAOxX,QAAUA,EAAUpJ,OAAOkd,OAAO,CAAC,EAAG9T,EAAS,CAACqpC,SAAS,EAAOE,YAAa,CAAC,KAEhFvpC,EARLwX,EAAOxX,QAAUkpC,CASrB,CCtJA,SAASS,GAAUnd,EAAOod,GACxB,MAAMpY,EAAOhF,GAASA,EAAMxsB,SAAW,CAAC,EAClC+W,EAAUya,EAAKza,QACf/S,OAAmB6B,IAAb2rB,EAAKxtB,IAAoB4lC,EAAkB,EACjD7lC,OAAmB8B,IAAb2rB,EAAKztB,IAAoB6lC,EAAkB,EACvD,MAAO,CACLhtB,MAAO7F,EAAUhT,EAAMC,EACvB6Y,IAAK9F,EAAU/S,EAAMD,EAEzB,CAEA,SAAS8lC,GAAYnoB,EAAQC,EAAQioB,GACnC,IAAwB,IAApBA,EACF,OAAO,EAET,MAAMliC,EAAIiiC,GAAUjoB,EAAQkoB,GACtBrxB,EAAIoxB,GAAUhoB,EAAQioB,GAE5B,MAAO,CACL7jB,IAAKxN,EAAEsE,IACPqD,MAAOxY,EAAEmV,IACTmJ,OAAQzN,EAAEqE,MACVqD,KAAMvY,EAAEkV,MAEZ,CAEA,SAASktB,GAAOhzC,GACd,IAAIZ,EAAGC,EAAG0O,EAAGhB,EAWb,OATIiS,GAAShf,IACXZ,EAAIY,EAAMivB,IACV5vB,EAAIW,EAAMopB,MACVrb,EAAI/N,EAAMkvB,OACVniB,EAAI/M,EAAMmpB,MAEV/pB,EAAIC,EAAI0O,EAAIhB,EAAI/M,EAGX,CACLivB,IAAK7vB,EACLgqB,MAAO/pB,EACP6vB,OAAQnhB,EACRob,KAAMpc,EACN3J,UAAoB,IAAVpD,EAEd,CAEA,SAASizC,GAAwB5iB,EAAO6iB,GACtC,MAAMpqC,EAAO,GACPqqC,EAAW9iB,EAAM+iB,uBAAuBF,GAC9C,IAAI3zC,EAAG8gB,EAEP,IAAK9gB,EAAI,EAAG8gB,EAAO8yB,EAASnqC,OAAQzJ,EAAI8gB,IAAQ9gB,EAC9CuJ,EAAKgZ,KAAKqxB,EAAS5zC,GAAG6B,OAExB,OAAO0H,CACT,CAEA,SAASuqC,GAAWC,EAAOtzC,EAAOuzC,EAASrqC,EAAU,CAAC,GACpD,MAAMJ,EAAOwqC,EAAMxqC,KACb0qC,EAA8B,WAAjBtqC,EAAQgsB,KAC3B,IAAI31B,EAAG8gB,EAAMG,EAAcizB,EAE3B,GAAc,OAAVzzC,EACF,OAGF,IAAI0zC,GAAQ,EACZ,IAAKn0C,EAAI,EAAG8gB,EAAOvX,EAAKE,OAAQzJ,EAAI8gB,IAAQ9gB,EAAG,CAE7C,GADAihB,GAAgB1X,EAAKvJ,GACjBihB,IAAiB+yB,EAAS,CAE5B,GADAG,GAAQ,EACJxqC,EAAQ0pC,IACV,SAEF,K,CAEFa,EAAaH,EAAMnsB,OAAO3G,GACtBvB,GAASw0B,KAAgBD,GAAyB,IAAVxzC,GAAemjB,GAAKnjB,KAAWmjB,GAAKswB,MAC9EzzC,GAASyzC,EAEb,CAEA,OAAKC,GAAUxqC,EAAQ0pC,IAIhB5yC,EAHE,CAIX,CAEA,SAAS2zC,GAAyBzxC,EAAMsnB,GACtC,MAAM,OAACK,EAAA,OAAQC,GAAUN,EACnBoqB,EAA2B,MAAhB/pB,EAAOK,KAAe,IAAM,IACvC2pB,EAA2B,MAAhB/pB,EAAOI,KAAe,IAAM,IACvCphB,EAAOhJ,OAAOgJ,KAAK5G,GACnB4xC,EAAQ,IAAIjkC,MAAM/G,EAAKE,QAC7B,IAAIzJ,EAAG8gB,EAAMlf,EACb,IAAK5B,EAAI,EAAG8gB,EAAOvX,EAAKE,OAAQzJ,EAAI8gB,IAAQ9gB,EAC1C4B,EAAM2H,EAAKvJ,GACXu0C,EAAMv0C,GAAK,CACT,CAACq0C,GAAWzyC,EACZ,CAAC0yC,GAAW3xC,EAAKf,IAGrB,OAAO2yC,CACT,CAEA,SAASC,GAAUre,EAAOlM,GACxB,MAAMwqB,EAAUte,GAASA,EAAMxsB,QAAQ8qC,QACvC,OAAOA,QAAwBjlC,IAAZilC,QAAwCjlC,IAAfya,EAAK8pB,KACnD,CAEA,SAASW,GAAYC,EAAYC,EAAY3qB,GAC3C,MAAO,GAAG0qB,EAAWhoC,MAAMioC,EAAWjoC,MAAMsd,EAAK8pB,OAAS9pB,EAAKznB,MACjE,CAEA,SAASsoB,GAAcqL,GACrB,MAAM,IAACxoB,EAAG,IAAED,EAAG,WAAEkd,EAAU,WAAEC,GAAcsL,EAAMrL,gBACjD,MAAO,CACLnd,IAAKid,EAAajd,EAAMvN,OAAOy0C,kBAC/BnnC,IAAKmd,EAAand,EAAMtN,OAAOkjB,kBAEnC,CAEA,SAASwxB,GAAiBC,EAAQC,EAAUC,GAC1C,MAAMC,EAAWH,EAAOC,KAAcD,EAAOC,GAAY,CAAC,GAC1D,OAAOE,EAASD,KAAgBC,EAASD,GAAc,CAAC,EAC1D,CAEA,SAASE,GAAoBpB,EAAOxpB,EAAQ6qB,EAAU5yC,GACpD,IAAK,MAAMynB,KAAQM,EAAO8qB,wBAAwB7yC,GAAMke,UAAW,CACjE,MAAMjgB,EAAQszC,EAAM9pB,EAAKpoB,OACzB,GAAIuzC,GAAa30C,EAAQ,IAAQ20C,GAAY30C,EAAQ,EACnD,OAAOwpB,EAAKpoB,KAEhB,CAEA,OAAO,IACT,CAEA,SAASyzC,GAAaC,EAAYtS,GAChC,MAAM,MAACnS,EAAO0kB,YAAavrB,GAAQsrB,EAC7BR,EAASjkB,EAAM2kB,UAAY3kB,EAAM2kB,QAAU,CAAC,IAC5C,OAACnrB,EAAA,OAAQC,EAAQ1oB,MAAOof,GAAgBgJ,EACxCyrB,EAAQprB,EAAOK,KACfgrB,EAAQprB,EAAOI,KACf/oB,EAAM8yC,GAAYpqB,EAAQC,EAAQN,GAClCnJ,EAAOmiB,EAAOx5B,OACpB,IAAIsqC,EAEJ,IAAK,IAAI/zC,EAAI,EAAGA,EAAI8gB,IAAQ9gB,EAAG,CAC7B,MAAM2B,EAAOshC,EAAOjjC,IACb,CAAC01C,GAAQ7zC,EAAO,CAAC8zC,GAAQl1C,GAASkB,EACnCi0C,EAAaj0C,EAAK8zC,UAAY9zC,EAAK8zC,QAAU,CAAC,GACpD1B,EAAQ6B,EAAWD,GAASb,GAAiBC,EAAQnzC,EAAKC,GAC1DkyC,EAAM9yB,GAAgBxgB,EAEtBszC,EAAM8B,KAAOV,GAAoBpB,EAAOxpB,GAAQ,EAAMN,EAAKznB,MAC3DuxC,EAAM+B,QAAUX,GAAoBpB,EAAOxpB,GAAQ,EAAON,EAAKznB,MAE/D,MAAMuzC,EAAehC,EAAMiC,gBAAkBjC,EAAMiC,cAAgB,CAAC,GACpED,EAAa90B,GAAgBxgB,CAC/B,CACF,CAEA,SAASw1C,GAAgBnlB,EAAOnG,GAC9B,MAAMyL,EAAStF,EAAMsF,OACrB,OAAO71B,OAAOgJ,KAAK6sB,GAAQgM,OAAOxgC,GAAOw0B,EAAOx0B,GAAK+oB,OAASA,GAAMurB,OACtE,CAEA,SAASC,GAAqB5T,EAAQ1gC,GACpC,OAAOi9B,GAAcyD,EACnB,CACEvT,QAAQ,EACRtE,aAASlb,EACTyR,aAAcpf,EACdA,QACA8zB,KAAM,UACNnzB,KAAM,WAGZ,CAEA,SAAS4zC,GAAkB7T,EAAQ1gC,EAAO4kC,GACxC,OAAO3H,GAAcyD,EAAQ,CAC3BvT,QAAQ,EACRqnB,UAAWx0C,EACXohC,YAAQzzB,EACR8mC,SAAK9mC,EACLi3B,UACA5kC,QACA8zB,KAAM,UACNnzB,KAAM,QAEV,CAEA,SAAS+zC,GAAYtsB,EAAMtB,GAEzB,MAAM1H,EAAegJ,EAAKsrB,WAAW1zC,MAC/B8oB,EAAOV,EAAKM,QAAUN,EAAKM,OAAOI,KACxC,GAAKA,EAAL,CAIAhC,EAAQA,GAASsB,EAAKO,QACtB,IAAK,MAAMyY,KAAUta,EAAO,CAC1B,MAAMosB,EAAS9R,EAAOwS,QACtB,IAAKV,QAA2BvlC,IAAjBulC,EAAOpqB,SAAsDnb,IAA/BulC,EAAOpqB,GAAM1J,GACxD,cAEK8zB,EAAOpqB,GAAM1J,QACezR,IAA/BulC,EAAOpqB,GAAMqrB,oBAA4ExmC,IAA7CulC,EAAOpqB,GAAMqrB,cAAc/0B,WAClE8zB,EAAOpqB,GAAMqrB,cAAc/0B,EAEtC,C,CACF,CAEA,MAAMu1B,GAAsB7gB,GAAkB,UAATA,GAA6B,SAATA,EACnD8gB,GAAmBA,CAACC,EAAQC,IAAWA,EAASD,EAASn2C,OAAOkd,OAAO,CAAC,EAAGi5B,GAC3EE,GAAcA,CAACC,EAAU5sB,EAAM6G,IAAU+lB,IAAa5sB,EAAK6sB,QAAU7sB,EAAK8sB,UAC3E,CAACxtC,KAAMmqC,GAAwB5iB,GAAO,GAAOlJ,OAAQ,MAE3C,MAAMovB,GAqBnBt3C,WAAAA,CAAYoxB,EAAO7P,GACjBpe,KAAKiuB,MAAQA,EACbjuB,KAAK3B,KAAO4vB,EAAMwE,IAClBzyB,KAAKhB,MAAQof,EACbpe,KAAKo0C,gBAAkB,CAAC,EACxBp0C,KAAK2yC,YAAc3yC,KAAKq0C,UACxBr0C,KAAKs0C,MAAQt0C,KAAK2yC,YAAYhzC,KAC9BK,KAAK8G,aAAU6F,EAEf3M,KAAKmgC,UAAW,EAChBngC,KAAKu0C,WAAQ5nC,EACb3M,KAAKw0C,iBAAc7nC,EACnB3M,KAAKy0C,oBAAiB9nC,EACtB3M,KAAK00C,gBAAa/nC,EAClB3M,KAAK20C,gBAAahoC,EAClB3M,KAAK40C,qBAAsB,EAC3B50C,KAAK60C,oBAAqB,EAC1B70C,KAAK80C,cAAWnoC,EAChB3M,KAAK+0C,UAAY,GACjB/0C,KAAKg1C,8BAAgCA,mBACrCh1C,KAAKi1C,2BAA6BA,gBAElCj1C,KAAKk1C,YACP,CAEAA,UAAAA,GACE,MAAM9tB,EAAOpnB,KAAK2yC,YAClB3yC,KAAK0vC,YACL1vC,KAAKm1C,aACL/tB,EAAK8sB,SAAWvC,GAAUvqB,EAAKM,OAAQN,GACvCpnB,KAAKo1C,cAEDp1C,KAAK8G,QAAQqwB,OAASn3B,KAAKiuB,MAAMonB,gBAAgB,WACnD/Z,QAAQC,KAAK,qKAEjB,CAEA+Z,WAAAA,CAAYl3B,GACNpe,KAAKhB,QAAUof,GACjBs1B,GAAY1zC,KAAK2yC,aAEnB3yC,KAAKhB,MAAQof,CACf,CAEA+2B,UAAAA,GACE,MAAMlnB,EAAQjuB,KAAKiuB,MACb7G,EAAOpnB,KAAK2yC,YACZ9qB,EAAU7nB,KAAKu1C,aAEfC,EAAWA,CAAC1tB,EAAMtZ,EAAG6Q,EAAGpiB,IAAe,MAAT6qB,EAAetZ,EAAa,MAATsZ,EAAe7qB,EAAIoiB,EAEpEo2B,EAAMruB,EAAKsuB,QAAUz4B,GAAe4K,EAAQ6tB,QAAStC,GAAgBnlB,EAAO,MAC5E0nB,EAAMvuB,EAAKwuB,QAAU34B,GAAe4K,EAAQ+tB,QAASxC,GAAgBnlB,EAAO,MAC5E4nB,EAAMzuB,EAAK0uB,QAAU74B,GAAe4K,EAAQiuB,QAAS1C,GAAgBnlB,EAAO,MAC5E2E,EAAYxL,EAAKwL,UACjBmjB,EAAM3uB,EAAK4uB,QAAUR,EAAS5iB,EAAW6iB,EAAKE,EAAKE,GACnDI,EAAM7uB,EAAK8uB,QAAUV,EAAS5iB,EAAW+iB,EAAKF,EAAKI,GACzDzuB,EAAKoB,OAASxoB,KAAKm2C,cAAcV,GACjCruB,EAAKqB,OAASzoB,KAAKm2C,cAAcR,GACjCvuB,EAAKgvB,OAASp2C,KAAKm2C,cAAcN,GACjCzuB,EAAKK,OAASznB,KAAKm2C,cAAcJ,GACjC3uB,EAAKM,OAAS1nB,KAAKm2C,cAAcF,EACnC,CAEAV,UAAAA,GACE,OAAOv1C,KAAKiuB,MAAMnuB,KAAK+xB,SAAS7xB,KAAKhB,MACvC,CAEAq1C,OAAAA,GACE,OAAOr0C,KAAKiuB,MAAMooB,eAAer2C,KAAKhB,MACxC,CAMAm3C,aAAAA,CAAcG,GACZ,OAAOt2C,KAAKiuB,MAAMsF,OAAO+iB,EAC3B,CAKAC,cAAAA,CAAejjB,GACb,MAAMlM,EAAOpnB,KAAK2yC,YAClB,OAAOrf,IAAUlM,EAAKK,OAClBL,EAAKM,OACLN,EAAKK,MACX,CAEA+uB,KAAAA,GACEx2C,KAAK2sC,QAAQ,QACf,CAKA8J,QAAAA,GACE,MAAMrvB,EAAOpnB,KAAK2yC,YACd3yC,KAAKu0C,OACP7uB,GAAoB1lB,KAAKu0C,MAAOv0C,MAE9BonB,EAAK8sB,UACPR,GAAYtsB,EAEhB,CAKAsvB,UAAAA,GACE,MAAM7uB,EAAU7nB,KAAKu1C,aACfz1C,EAAO+nB,EAAQ/nB,OAAS+nB,EAAQ/nB,KAAO,IACvCy0C,EAAQv0C,KAAKu0C,MAMnB,GAAI33B,GAAS9c,GAAO,CAClB,MAAMsnB,EAAOpnB,KAAK2yC,YAClB3yC,KAAKu0C,MAAQhD,GAAyBzxC,EAAMsnB,E,MACvC,GAAImtB,IAAUz0C,EAAM,CACzB,GAAIy0C,EAAO,CAET7uB,GAAoB6uB,EAAOv0C,MAE3B,MAAMonB,EAAOpnB,KAAK2yC,YAClBe,GAAYtsB,GACZA,EAAKO,QAAU,E,CAEb7nB,GAAQpC,OAAOi5C,aAAa72C,IAC9BmlB,GAAkBnlB,EAAME,MAE1BA,KAAK+0C,UAAY,GACjB/0C,KAAKu0C,MAAQz0C,C,CAEjB,CAEAs1C,WAAAA,GACE,MAAMhuB,EAAOpnB,KAAK2yC,YAElB3yC,KAAK02C,aAED12C,KAAKg1C,qBACP5tB,EAAKS,QAAU,IAAI7nB,KAAKg1C,mBAE5B,CAEA4B,qBAAAA,CAAsBC,GACpB,MAAMzvB,EAAOpnB,KAAK2yC,YACZ9qB,EAAU7nB,KAAKu1C,aACrB,IAAIuB,GAAe,EAEnB92C,KAAK02C,aAGL,MAAMK,EAAa3vB,EAAK8sB,SACxB9sB,EAAK8sB,SAAWvC,GAAUvqB,EAAKM,OAAQN,GAGnCA,EAAK8pB,QAAUrpB,EAAQqpB,QACzB4F,GAAe,EAEfpD,GAAYtsB,GACZA,EAAK8pB,MAAQrpB,EAAQqpB,OAKvBlxC,KAAKg3C,gBAAgBH,IAGjBC,GAAgBC,IAAe3vB,EAAK8sB,YACtCzB,GAAazyC,KAAMonB,EAAKO,SACxBP,EAAK8sB,SAAWvC,GAAUvqB,EAAKM,OAAQN,GAE3C,CAMAsoB,SAAAA,GACE,MAAMF,EAASxvC,KAAKiuB,MAAMuhB,OACpByH,EAAYzH,EAAO0H,iBAAiBl3C,KAAKs0C,OACzClY,EAASoT,EAAO2H,gBAAgBn3C,KAAKu1C,aAAc0B,GAAW,GACpEj3C,KAAK8G,QAAU0oC,EAAO4H,eAAehb,EAAQp8B,KAAK01B,cAClD11B,KAAKmgC,SAAWngC,KAAK8G,QAAQqsB,QAC7BnzB,KAAKo0C,gBAAkB,CAAC,CAC1B,CAMA/T,KAAAA,CAAM3c,EAAO1c,GACX,MAAO2rC,YAAavrB,EAAMmtB,MAAOz0C,GAAQE,MACnC,OAACynB,EAAA,SAAQysB,GAAY9sB,EACrByrB,EAAQprB,EAAOK,KAErB,IAEI3qB,EAAG0sC,EAAKzJ,EAFRiX,EAAmB,IAAV3zB,GAAe1c,IAAUlH,EAAK8G,QAAgBwgB,EAAKI,QAC5Dub,EAAOrf,EAAQ,GAAK0D,EAAKO,QAAQjE,EAAQ,GAG7C,IAAsB,IAAlB1jB,KAAKmgC,SACP/Y,EAAKO,QAAU7nB,EACfsnB,EAAKI,SAAU,EACf4Y,EAAStgC,MACJ,CAEHsgC,EADE1yB,GAAQ5N,EAAK4jB,IACN1jB,KAAKs3C,eAAelwB,EAAMtnB,EAAM4jB,EAAO1c,GACvC4V,GAAS9c,EAAK4jB,IACd1jB,KAAKu3C,gBAAgBnwB,EAAMtnB,EAAM4jB,EAAO1c,GAExChH,KAAKw3C,mBAAmBpwB,EAAMtnB,EAAM4jB,EAAO1c,GAGtD,MAAMywC,EAA6BA,IAAqB,OAAf5N,EAAIgJ,IAAoB9P,GAAQ8G,EAAIgJ,GAAS9P,EAAK8P,GAC3F,IAAK11C,EAAI,EAAGA,EAAI6J,IAAS7J,EACvBiqB,EAAKO,QAAQxqB,EAAIumB,GAASmmB,EAAMzJ,EAAOjjC,GACnCk6C,IACEI,MACFJ,GAAS,GAEXtU,EAAO8G,GAGXziB,EAAKI,QAAU6vB,C,CAGbnD,GACFzB,GAAazyC,KAAMogC,EAEvB,CAaAoX,kBAAAA,CAAmBpwB,EAAMtnB,EAAM4jB,EAAO1c,GACpC,MAAM,OAACygB,EAAA,OAAQC,GAAUN,EACnByrB,EAAQprB,EAAOK,KACfgrB,EAAQprB,EAAOI,KACf4vB,EAASjwB,EAAOkwB,YAChBC,EAAcnwB,IAAWC,EACzB0Y,EAAS,IAAI3yB,MAAMzG,GACzB,IAAI7J,EAAG8gB,EAAMjf,EAEb,IAAK7B,EAAI,EAAG8gB,EAAOjX,EAAO7J,EAAI8gB,IAAQ9gB,EACpC6B,EAAQ7B,EAAIumB,EACZ0c,EAAOjjC,GAAK,CACV,CAAC01C,GAAQ+E,GAAenwB,EAAO4Y,MAAMqX,EAAO14C,GAAQA,GACpD,CAAC8zC,GAAQprB,EAAO2Y,MAAMvgC,EAAKd,GAAQA,IAGvC,OAAOohC,CACT,CAaAkX,cAAAA,CAAelwB,EAAMtnB,EAAM4jB,EAAO1c,GAChC,MAAM,OAACwhB,EAAA,OAAQC,GAAUrB,EACnBgZ,EAAS,IAAI3yB,MAAMzG,GACzB,IAAI7J,EAAG8gB,EAAMjf,EAAOF,EAEpB,IAAK3B,EAAI,EAAG8gB,EAAOjX,EAAO7J,EAAI8gB,IAAQ9gB,EACpC6B,EAAQ7B,EAAIumB,EACZ5kB,EAAOgB,EAAKd,GACZohC,EAAOjjC,GAAK,CACVqR,EAAGga,EAAO6X,MAAMvhC,EAAK,GAAIE,GACzBqgB,EAAGoJ,EAAO4X,MAAMvhC,EAAK,GAAIE,IAG7B,OAAOohC,CACT,CAaAmX,eAAAA,CAAgBnwB,EAAMtnB,EAAM4jB,EAAO1c,GACjC,MAAM,OAACwhB,EAAA,OAAQC,GAAUrB,GACnB,SAACywB,EAAW,aAAKC,EAAW,KAAO93C,KAAKmgC,SACxCC,EAAS,IAAI3yB,MAAMzG,GACzB,IAAI7J,EAAG8gB,EAAMjf,EAAOF,EAEpB,IAAK3B,EAAI,EAAG8gB,EAAOjX,EAAO7J,EAAI8gB,IAAQ9gB,EACpC6B,EAAQ7B,EAAIumB,EACZ5kB,EAAOgB,EAAKd,GACZohC,EAAOjjC,GAAK,CACVqR,EAAGga,EAAO6X,MAAMzgB,GAAiB9gB,EAAM+4C,GAAW74C,GAClDqgB,EAAGoJ,EAAO4X,MAAMzgB,GAAiB9gB,EAAMg5C,GAAW94C,IAGtD,OAAOohC,CACT,CAKA2X,SAAAA,CAAU/4C,GACR,OAAOgB,KAAK2yC,YAAYhrB,QAAQ3oB,EAClC,CAKAg5C,cAAAA,CAAeh5C,GACb,OAAOgB,KAAK2yC,YAAY7yC,KAAKd,EAC/B,CAKAiyC,UAAAA,CAAW3d,EAAO8M,EAAQtN,GACxB,MAAM7E,EAAQjuB,KAAKiuB,MACb7G,EAAOpnB,KAAK2yC,YACZ/0C,EAAQwiC,EAAO9M,EAAMxL,MACrBopB,EAAQ,CACZxqC,KAAMmqC,GAAwB5iB,GAAO,GACrClJ,OAAQqb,EAAOwS,QAAQtf,EAAMxL,MAAMqrB,eAErC,OAAOlC,GAAWC,EAAOtzC,EAAOwpB,EAAKpoB,MAAO,CAAC8zB,QAC/C,CAKAmlB,qBAAAA,CAAsB1qC,EAAO+lB,EAAO8M,EAAQ8Q,GAC1C,MAAMgH,EAAc9X,EAAO9M,EAAMxL,MACjC,IAAIlqB,EAAwB,OAAhBs6C,EAAuBC,IAAMD,EACzC,MAAMnzB,EAASmsB,GAAS9Q,EAAOwS,QAAQtf,EAAMxL,MACzCopB,GAASnsB,IACXmsB,EAAMnsB,OAASA,EACfnnB,EAAQqzC,GAAWC,EAAOgH,EAAal4C,KAAK2yC,YAAY3zC,QAE1DuO,EAAMzC,IAAMjD,KAAKiD,IAAIyC,EAAMzC,IAAKlN,GAChC2P,EAAM1C,IAAMhD,KAAKgD,IAAI0C,EAAM1C,IAAKjN,EAClC,CAKAw6C,SAAAA,CAAU9kB,EAAO0gB,GACf,MAAM5sB,EAAOpnB,KAAK2yC,YACZhrB,EAAUP,EAAKO,QACf0vB,EAASjwB,EAAKI,SAAW8L,IAAUlM,EAAKK,OACxCxJ,EAAO0J,EAAQ/gB,OACfyxC,EAAar4C,KAAKu2C,eAAejjB,GACjC4d,EAAQ6C,GAAYC,EAAU5sB,EAAMpnB,KAAKiuB,OACzC1gB,EAAQ,CAACzC,IAAKvN,OAAOkjB,kBAAmB5V,IAAKtN,OAAOy0C,oBACnDlnC,IAAKwtC,EAAUztC,IAAK0tC,GAAYtwB,GAAcowB,GACrD,IAAIl7C,EAAGijC,EAEP,SAASoY,IACPpY,EAASzY,EAAQxqB,GACjB,MAAMk0C,EAAajR,EAAOiY,EAAWvwB,MACrC,OAAQjL,GAASujB,EAAO9M,EAAMxL,QAAUwwB,EAAWjH,GAAckH,EAAWlH,CAC9E,CAEA,IAAKl0C,EAAI,EAAGA,EAAI8gB,IAAQ9gB,EACtB,IAAIq7C,MAGJx4C,KAAKi4C,sBAAsB1qC,EAAO+lB,EAAO8M,EAAQ8Q,GAC7CmG,GAEF,MAGJ,GAAIA,EAEF,IAAKl6C,EAAI8gB,EAAO,EAAG9gB,GAAK,IAAKA,EAC3B,IAAIq7C,IAAJ,CAGAx4C,KAAKi4C,sBAAsB1qC,EAAO+lB,EAAO8M,EAAQ8Q,GACjD,K,CAGJ,OAAO3jC,CACT,CAEAkrC,kBAAAA,CAAmBnlB,GACjB,MAAM8M,EAASpgC,KAAK2yC,YAAYhrB,QAC1B5C,EAAS,GACf,IAAI5nB,EAAG8gB,EAAMrgB,EAEb,IAAKT,EAAI,EAAG8gB,EAAOmiB,EAAOx5B,OAAQzJ,EAAI8gB,IAAQ9gB,EAC5CS,EAAQwiC,EAAOjjC,GAAGm2B,EAAMxL,MACpBjL,GAASjf,IACXmnB,EAAOrF,KAAK9hB,GAGhB,OAAOmnB,CACT,CAMA2zB,cAAAA,GACE,OAAO,CACT,CAKAC,gBAAAA,CAAiB35C,GACf,MAAMooB,EAAOpnB,KAAK2yC,YACZlrB,EAASL,EAAKK,OACdC,EAASN,EAAKM,OACd0Y,EAASpgC,KAAK+3C,UAAU/4C,GAC9B,MAAO,CACL45C,MAAOnxB,EAAS,GAAKA,EAAOoxB,iBAAiBzY,EAAO3Y,EAAOK,OAAS,GACpElqB,MAAO8pB,EAAS,GAAKA,EAAOmxB,iBAAiBzY,EAAO1Y,EAAOI,OAAS,GAExE,CAKA6kB,OAAAA,CAAQ7Z,GACN,MAAM1L,EAAOpnB,KAAK2yC,YAClB3yC,KAAKgvC,OAAOlc,GAAQ,WACpB1L,EAAKykB,MAAQ+E,GAAO3zB,GAAejd,KAAK8G,QAAQsoB,KAAMuhB,GAAYvpB,EAAKoB,OAAQpB,EAAKqB,OAAQzoB,KAAK04C,mBACnG,CAKA1J,MAAAA,CAAOlc,GAAO,CAEdka,IAAAA,GACE,MAAMva,EAAMzyB,KAAK3B,KACX4vB,EAAQjuB,KAAKiuB,MACb7G,EAAOpnB,KAAK2yC,YACZzgB,EAAW9K,EAAKtnB,MAAQ,GACxBy3B,EAAOtJ,EAAMwd,UACbtf,EAAS,GACTzI,EAAQ1jB,KAAK00C,YAAc,EAC3B1tC,EAAQhH,KAAK20C,YAAeziB,EAAStrB,OAAS8c,EAC9C+P,EAA0BzzB,KAAK8G,QAAQ2sB,wBAC7C,IAAIt2B,EAMJ,IAJIiqB,EAAKS,SACPT,EAAKS,QAAQmlB,KAAKva,EAAK8E,EAAM7T,EAAO1c,GAGjC7J,EAAIumB,EAAOvmB,EAAIumB,EAAQ1c,IAAS7J,EAAG,CACtC,MAAMymC,EAAU1R,EAAS/0B,GACrBymC,EAAQqQ,SAGRrQ,EAAQzX,QAAUsH,EACpBtH,EAAOzM,KAAKkkB,GAEZA,EAAQoJ,KAAKva,EAAK8E,GAEtB,CAEA,IAAKp6B,EAAI,EAAGA,EAAIgvB,EAAOvlB,SAAUzJ,EAC/BgvB,EAAOhvB,GAAG6vC,KAAKva,EAAK8E,EAExB,CASAwM,QAAAA,CAAS/kC,EAAOmtB,GACd,MAAM2G,EAAO3G,EAAS,SAAW,UACjC,YAAiBxf,IAAV3N,GAAuBgB,KAAK2yC,YAAY9qB,QAC3C7nB,KAAK84C,6BAA6BhmB,GAClC9yB,KAAK+4C,0BAA0B/5C,GAAS,EAAG8zB,EACjD,CAKA4C,UAAAA,CAAW12B,EAAOmtB,EAAQ2G,GACxB,MAAMjL,EAAU7nB,KAAKu1C,aACrB,IAAIxjB,EACJ,GAAI/yB,GAAS,GAAKA,EAAQgB,KAAK2yC,YAAY7yC,KAAK8G,OAAQ,CACtD,MAAMg9B,EAAU5jC,KAAK2yC,YAAY7yC,KAAKd,GACtC+yB,EAAU6R,EAAQkR,WACflR,EAAQkR,SAAWvB,GAAkBvzC,KAAK01B,aAAc12B,EAAO4kC,IAClE7R,EAAQqO,OAASpgC,KAAK+3C,UAAU/4C,GAChC+yB,EAAQ0hB,IAAM5rB,EAAQ/nB,KAAKd,GAC3B+yB,EAAQ/yB,MAAQ+yB,EAAQyhB,UAAYx0C,C,MAEpC+yB,EAAU/xB,KAAK80C,WACZ90C,KAAK80C,SAAWxB,GAAqBtzC,KAAKiuB,MAAMyH,aAAc11B,KAAKhB,QACtE+yB,EAAQlK,QAAUA,EAClBkK,EAAQ/yB,MAAQ+yB,EAAQ3T,aAAepe,KAAKhB,MAK9C,OAFA+yB,EAAQ5F,SAAWA,EACnB4F,EAAQe,KAAOA,EACRf,CACT,CAMA+mB,4BAAAA,CAA6BhmB,GAC3B,OAAO9yB,KAAKg5C,uBAAuBh5C,KAAKg1C,mBAAmBlrC,GAAIgpB,EACjE,CAOAimB,yBAAAA,CAA0B/5C,EAAO8zB,GAC/B,OAAO9yB,KAAKg5C,uBAAuBh5C,KAAKi1C,gBAAgBnrC,GAAIgpB,EAAM9zB,EACpE,CAKAg6C,sBAAAA,CAAuBC,EAAanmB,EAAO,UAAW9zB,GACpD,MAAMmtB,EAAkB,WAAT2G,EACT8B,EAAQ50B,KAAKo0C,gBACbjnB,EAAW8rB,EAAc,IAAMnmB,EAC/B+gB,EAASjf,EAAMzH,GACf+rB,EAAUl5C,KAAK40C,qBAAuB50B,GAAQhhB,GACpD,GAAI60C,EACF,OAAOD,GAAiBC,EAAQqF,GAElC,MAAM1J,EAASxvC,KAAKiuB,MAAMuhB,OACpByH,EAAYzH,EAAO2J,wBAAwBn5C,KAAKs0C,MAAO2E,GACvD5c,EAAWlQ,EAAS,CAAC,GAAG8sB,SAAoB,QAASA,EAAa,IAAM,CAACA,EAAa,IACtF7c,EAASoT,EAAO2H,gBAAgBn3C,KAAKu1C,aAAc0B,GACnDv9B,EAAQhc,OAAOgJ,KAAKilB,GAASuG,SAAS+mB,IAGtClnB,EAAUA,IAAM/xB,KAAK01B,WAAW12B,EAAOmtB,EAAQ2G,GAC/C/N,EAASyqB,EAAO4J,oBAAoBhd,EAAQ1iB,EAAOqY,EAASsK,GAalE,OAXItX,EAAOorB,UAGTprB,EAAOorB,QAAU+I,EAKjBtkB,EAAMzH,GAAYzvB,OAAO27C,OAAOzF,GAAiB7uB,EAAQm0B,KAGpDn0B,CACT,CAMAu0B,kBAAAA,CAAmBt6C,EAAOu6C,EAAYptB,GACpC,MAAM8B,EAAQjuB,KAAKiuB,MACb2G,EAAQ50B,KAAKo0C,gBACbjnB,EAAW,aAAaosB,IACxB1F,EAASjf,EAAMzH,GACrB,GAAI0mB,EACF,OAAOA,EAET,IAAI/sC,EACJ,IAAgC,IAA5BmnB,EAAMnnB,QAAQslB,UAAqB,CACrC,MAAMojB,EAASxvC,KAAKiuB,MAAMuhB,OACpByH,EAAYzH,EAAOgK,0BAA0Bx5C,KAAKs0C,MAAOiF,GACzDnd,EAASoT,EAAO2H,gBAAgBn3C,KAAKu1C,aAAc0B,GACzDnwC,EAAU0oC,EAAO4H,eAAehb,EAAQp8B,KAAK01B,WAAW12B,EAAOmtB,EAAQotB,G,CAEzE,MAAMhtB,EAAa,IAAIgjB,GAAWthB,EAAOnnB,GAAWA,EAAQylB,YAI5D,OAHIzlB,GAAWA,EAAQ61B,aACrB/H,EAAMzH,GAAYzvB,OAAO27C,OAAO9sB,IAE3BA,CACT,CAMAktB,gBAAAA,CAAiB3yC,GACf,GAAKA,EAAQqpC,QAGb,OAAOnwC,KAAKy0C,iBAAmBz0C,KAAKy0C,eAAiB/2C,OAAOkd,OAAO,CAAC,EAAG9T,GACzE,CAMA4yC,cAAAA,CAAe5mB,EAAM6mB,GACnB,OAAQA,GAAiBhG,GAAmB7gB,IAAS9yB,KAAKiuB,MAAM2rB,mBAClE,CAKAC,iBAAAA,CAAkBn2B,EAAOoP,GACvB,MAAMgnB,EAAY95C,KAAK+4C,0BAA0Br1B,EAAOoP,GAClDinB,EAA0B/5C,KAAKy0C,eAC/BkF,EAAgB35C,KAAKy5C,iBAAiBK,GACtCJ,EAAiB15C,KAAK05C,eAAe5mB,EAAM6mB,IAAmBA,IAAkBI,EAEtF,OADA/5C,KAAKg6C,oBAAoBL,EAAe7mB,EAAMgnB,GACvC,CAACH,gBAAeD,iBACzB,CAMAO,aAAAA,CAAcrW,EAAS5kC,EAAOktB,EAAY4G,GACpC6gB,GAAmB7gB,GACrBp1B,OAAOkd,OAAOgpB,EAAS1X,GAEvBlsB,KAAKs5C,mBAAmBt6C,EAAO8zB,GAAMkc,OAAOpL,EAAS1X,EAEzD,CAMA8tB,mBAAAA,CAAoBL,EAAe7mB,EAAMkd,GACnC2J,IAAkBhG,GAAmB7gB,IACvC9yB,KAAKs5C,wBAAmB3sC,EAAWmmB,GAAMkc,OAAO2K,EAAe3J,EAEnE,CAKAkK,SAAAA,CAAUtW,EAAS5kC,EAAO8zB,EAAM3G,GAC9ByX,EAAQzX,OAASA,EACjB,MAAMrlB,EAAU9G,KAAK+jC,SAAS/kC,EAAOmtB,GACrCnsB,KAAKs5C,mBAAmBt6C,EAAO8zB,EAAM3G,GAAQ6iB,OAAOpL,EAAS,CAG3D98B,SAAWqlB,GAAUnsB,KAAKy5C,iBAAiB3yC,IAAaA,GAE5D,CAEAqzC,gBAAAA,CAAiBvW,EAASxlB,EAAcpf,GACtCgB,KAAKk6C,UAAUtW,EAAS5kC,EAAO,UAAU,EAC3C,CAEAo7C,aAAAA,CAAcxW,EAASxlB,EAAcpf,GACnCgB,KAAKk6C,UAAUtW,EAAS5kC,EAAO,UAAU,EAC3C,CAKAq7C,wBAAAA,GACE,MAAMzW,EAAU5jC,KAAK2yC,YAAY9qB,QAE7B+b,GACF5jC,KAAKk6C,UAAUtW,OAASj3B,EAAW,UAAU,EAEjD,CAKA2tC,qBAAAA,GACE,MAAM1W,EAAU5jC,KAAK2yC,YAAY9qB,QAE7B+b,GACF5jC,KAAKk6C,UAAUtW,OAASj3B,EAAW,UAAU,EAEjD,CAKAqqC,eAAAA,CAAgBH,GACd,MAAM/2C,EAAOE,KAAKu0C,MACZriB,EAAWlyB,KAAK2yC,YAAY7yC,KAGlC,IAAK,MAAOwlB,EAAQi1B,EAAMC,KAASx6C,KAAK+0C,UACtC/0C,KAAKslB,GAAQi1B,EAAMC,GAErBx6C,KAAK+0C,UAAY,GAEjB,MAAM0F,EAAUvoB,EAAStrB,OACnB8zC,EAAU56C,EAAK8G,OACfI,EAAQa,KAAKiD,IAAI4vC,EAASD,GAE5BzzC,GAKFhH,KAAKqgC,MAAM,EAAGr5B,GAGZ0zC,EAAUD,EACZz6C,KAAK26C,gBAAgBF,EAASC,EAAUD,EAAS5D,GACxC6D,EAAUD,GACnBz6C,KAAK46C,gBAAgBF,EAASD,EAAUC,EAE5C,CAKAC,eAAAA,CAAgBj3B,EAAO1c,EAAO6vC,GAAmB,GAC/C,MAAMzvB,EAAOpnB,KAAK2yC,YACZ7yC,EAAOsnB,EAAKtnB,KACZ6jB,EAAMD,EAAQ1c,EACpB,IAAI7J,EAEJ,MAAM09C,EAAQvb,IAEZ,IADAA,EAAI14B,QAAUI,EACT7J,EAAImiC,EAAI14B,OAAS,EAAGzJ,GAAKwmB,EAAKxmB,IACjCmiC,EAAIniC,GAAKmiC,EAAIniC,EAAI6J,IAKrB,IAFA6zC,EAAK/6C,GAEA3C,EAAIumB,EAAOvmB,EAAIwmB,IAAOxmB,EACzB2C,EAAK3C,GAAK,IAAI6C,KAAKi1C,gBAGjBj1C,KAAKmgC,UACP0a,EAAKzzB,EAAKO,SAEZ3nB,KAAKqgC,MAAM3c,EAAO1c,GAEd6vC,GACF72C,KAAK86C,eAAeh7C,EAAM4jB,EAAO1c,EAAO,QAE5C,CAEA8zC,cAAAA,CAAelX,EAASlgB,EAAO1c,EAAO8rB,GAAO,CAK7C8nB,eAAAA,CAAgBl3B,EAAO1c,GACrB,MAAMogB,EAAOpnB,KAAK2yC,YAClB,GAAI3yC,KAAKmgC,SAAU,CACjB,MAAM4a,EAAU3zB,EAAKO,QAAQ/B,OAAOlC,EAAO1c,GACvCogB,EAAK8sB,UACPR,GAAYtsB,EAAM2zB,E,CAGtB3zB,EAAKtnB,KAAK8lB,OAAOlC,EAAO1c,EAC1B,CAKAg0C,KAAAA,CAAMz7C,GACJ,GAAIS,KAAKmgC,SACPngC,KAAK+0C,UAAUr1B,KAAKngB,OACf,CACL,MAAO+lB,EAAQi1B,EAAMC,GAAQj7C,EAC7BS,KAAKslB,GAAQi1B,EAAMC,E,CAErBx6C,KAAKiuB,MAAMgtB,aAAav7B,KAAK,CAAC1f,KAAKhB,SAAUO,GAC/C,CAEA27C,WAAAA,GACE,MAAMl0C,EAAQm0C,UAAUv0C,OACxB5G,KAAKg7C,MAAM,CAAC,kBAAmBh7C,KAAKu1C,aAAaz1C,KAAK8G,OAASI,EAAOA,GACxE,CAEAo0C,UAAAA,GACEp7C,KAAKg7C,MAAM,CAAC,kBAAmBh7C,KAAK2yC,YAAY7yC,KAAK8G,OAAS,EAAG,GACnE,CAEAy0C,YAAAA,GACEr7C,KAAKg7C,MAAM,CAAC,kBAAmB,EAAG,GACpC,CAEAM,aAAAA,CAAc53B,EAAO1c,GACfA,GACFhH,KAAKg7C,MAAM,CAAC,kBAAmBt3B,EAAO1c,IAExC,MAAMu0C,EAAWJ,UAAUv0C,OAAS,EAChC20C,GACFv7C,KAAKg7C,MAAM,CAAC,kBAAmBt3B,EAAO63B,GAE1C,CAEAC,cAAAA,GACEx7C,KAAKg7C,MAAM,CAAC,kBAAmB,EAAGG,UAAUv0C,QAC9C,EC7iCF,SAAS60C,GAAkBnoB,EAAO3zB,GAChC,IAAK2zB,EAAMh1B,OAAOo9C,KAAM,CACtB,MAAMC,EAAeroB,EAAMkf,wBAAwB7yC,GACnD,IAAIolB,EAAS,GAEb,IAAK,IAAI5nB,EAAI,EAAG8gB,EAAO09B,EAAa/0C,OAAQzJ,EAAI8gB,EAAM9gB,IACpD4nB,EAASA,EAAO62B,OAAOD,EAAax+C,GAAGu1C,WAAW+F,mBAAmBnlB,IAEvEA,EAAMh1B,OAAOo9C,KAAO71B,GAAad,EAAOnD,KAAK,CAAClW,EAAGC,IAAMD,EAAIC,G,CAE7D,OAAO2nB,EAAMh1B,OAAOo9C,IACtB,CAMA,SAASG,GAAqBz0B,GAC5B,MAAMkM,EAAQlM,EAAKK,OACb1C,EAAS02B,GAAkBnoB,EAAOlM,EAAKznB,MAC7C,IACIxC,EAAG8gB,EAAM69B,EAAM/Y,EADfj4B,EAAMwoB,EAAMyoB,QAEhB,MAAMC,EAAmBA,KACV,QAATF,IAA4B,QAAVA,IAIlB97B,GAAQ+iB,KAEVj4B,EAAMjD,KAAKiD,IAAIA,EAAKjD,KAAKqZ,IAAI46B,EAAO/Y,IAASj4B,IAE/Ci4B,EAAO+Y,IAGT,IAAK3+C,EAAI,EAAG8gB,EAAO8G,EAAOne,OAAQzJ,EAAI8gB,IAAQ9gB,EAC5C2+C,EAAOxoB,EAAMpL,iBAAiBnD,EAAO5nB,IACrC6+C,IAIF,IADAjZ,OAAOp2B,EACFxP,EAAI,EAAG8gB,EAAOqV,EAAMtF,MAAMpnB,OAAQzJ,EAAI8gB,IAAQ9gB,EACjD2+C,EAAOxoB,EAAM2oB,gBAAgB9+C,GAC7B6+C,IAGF,OAAOlxC,CACT,CAQA,SAASoxC,GAAyBl9C,EAAOm9C,EAAOr1C,EAASs1C,GACvD,MAAMC,EAAYv1C,EAAQw1C,aAC1B,IAAIh0C,EAAMkS,EAaV,OAXIiC,GAAc4/B,IAChB/zC,EAAO6zC,EAAMrxC,IAAMhE,EAAQy1C,mBAC3B/hC,EAAQ1T,EAAQ01C,gBAKhBl0C,EAAO+zC,EAAYD,EACnB5hC,EAAQ,GAGH,CACLiiC,MAAOn0C,EAAO8zC,EACd5hC,QACAkJ,MAAOy4B,EAAMO,OAAO19C,GAAUsJ,EAAO,EAEzC,CAQA,SAASq0C,GAA0B39C,EAAOm9C,EAAOr1C,EAASs1C,GACxD,MAAMM,EAASP,EAAMO,OACfZ,EAAOY,EAAO19C,GACpB,IAAI+jC,EAAO/jC,EAAQ,EAAI09C,EAAO19C,EAAQ,GAAK,KACvC8hC,EAAO9hC,EAAQ09C,EAAO91C,OAAS,EAAI81C,EAAO19C,EAAQ,GAAK,KAC3D,MAAM49C,EAAU91C,EAAQy1C,mBAEX,OAATxZ,IAGFA,EAAO+Y,GAAiB,OAAThb,EAAgBqb,EAAMx4B,IAAMw4B,EAAMz4B,MAAQod,EAAOgb,IAGrD,OAAThb,IAEFA,EAAOgb,EAAOA,EAAO/Y,GAGvB,MAAMrf,EAAQo4B,GAAQA,EAAOj0C,KAAKiD,IAAIi4B,EAAMjC,IAAS,EAAI8b,EACnDt0C,EAAOT,KAAKqZ,IAAI4f,EAAOiC,GAAQ,EAAI6Z,EAEzC,MAAO,CACLH,MAAOn0C,EAAO8zC,EACd5hC,MAAO1T,EAAQ01C,cACf94B,QAEJ,CAEA,SAASm5B,GAAcC,EAAOh+C,EAAM4oB,EAAQvqB,GAC1C,MAAM4/C,EAAar1B,EAAO2Y,MAAMyc,EAAM,GAAI3/C,GACpC6/C,EAAWt1B,EAAO2Y,MAAMyc,EAAM,GAAI3/C,GAClC2N,EAAMjD,KAAKiD,IAAIiyC,EAAYC,GAC3BnyC,EAAMhD,KAAKgD,IAAIkyC,EAAYC,GACjC,IAAIC,EAAWnyC,EACXoyC,EAASryC,EAEThD,KAAKqZ,IAAIpW,GAAOjD,KAAKqZ,IAAIrW,KAC3BoyC,EAAWpyC,EACXqyC,EAASpyC,GAKXhM,EAAK4oB,EAAOI,MAAQo1B,EAEpBp+C,EAAKq+C,QAAU,CACbF,WACAC,SACAx5B,MAAOq5B,EACPp5B,IAAKq5B,EACLlyC,MACAD,MAEJ,CAEA,SAASuyC,GAAWN,EAAOh+C,EAAM4oB,EAAQvqB,GAMvC,OALIuQ,GAAQovC,GACVD,GAAcC,EAAOh+C,EAAM4oB,EAAQvqB,GAEnC2B,EAAK4oB,EAAOI,MAAQJ,EAAO2Y,MAAMyc,EAAO3/C,GAEnC2B,CACT,CAEA,SAASu+C,GAAsBj2B,EAAMtnB,EAAM4jB,EAAO1c,GAChD,MAAMygB,EAASL,EAAKK,OACdC,EAASN,EAAKM,OACdgwB,EAASjwB,EAAOkwB,YAChBC,EAAcnwB,IAAWC,EACzB0Y,EAAS,GACf,IAAIjjC,EAAG8gB,EAAMnf,EAAMg+C,EAEnB,IAAK3/C,EAAIumB,EAAOzF,EAAOyF,EAAQ1c,EAAO7J,EAAI8gB,IAAQ9gB,EAChD2/C,EAAQh9C,EAAK3C,GACb2B,EAAO,CAAC,EACRA,EAAK2oB,EAAOK,MAAQ8vB,GAAenwB,EAAO4Y,MAAMqX,EAAOv6C,GAAIA,GAC3DijC,EAAO1gB,KAAK09B,GAAWN,EAAOh+C,EAAM4oB,EAAQvqB,IAE9C,OAAOijC,CACT,CAEA,SAASkd,GAAWC,GAClB,OAAOA,QAA8B5wC,IAApB4wC,EAAON,eAA4CtwC,IAAlB4wC,EAAOL,MAC3D,CAEA,SAASM,GAAQl1C,EAAMof,EAAQ+1B,GAC7B,OAAa,IAATn1C,EACKyY,GAAKzY,IAENof,EAAOg2B,eAAiB,GAAK,IAAMh2B,EAAO5c,KAAO2yC,EAAa,GAAK,EAC7E,CAEA,SAASE,GAAYzxB,GACnB,IAAIrO,EAAS6F,EAAOC,EAAKkJ,EAAKC,EAiB9B,OAhBIZ,EAAW0xB,YACb//B,EAAUqO,EAAW3G,KAAO2G,EAAW1d,EACvCkV,EAAQ,OACRC,EAAM,UAEN9F,EAAUqO,EAAW3G,KAAO2G,EAAW7M,EACvCqE,EAAQ,SACRC,EAAM,OAEJ9F,GACFgP,EAAM,MACNC,EAAS,UAETD,EAAM,QACNC,EAAS,OAEJ,CAACpJ,QAAOC,MAAK9F,UAASgP,MAAKC,SACpC,CAEA,SAAS+wB,GAAiB3xB,EAAYplB,EAASoqC,EAAOlyC,GACpD,IAAI8+C,EAAOh3C,EAAQi3C,cACnB,MAAMv4B,EAAM,CAAC,EAEb,IAAKs4B,EAEH,YADA5xB,EAAW6xB,cAAgBv4B,GAI7B,IAAa,IAATs4B,EAEF,YADA5xB,EAAW6xB,cAAgB,CAAClxB,KAAK,EAAM7F,OAAO,EAAM8F,QAAQ,EAAM/F,MAAM,IAI1E,MAAM,MAACrD,EAAA,IAAOC,EAAA,QAAK9F,EAAA,IAASgP,EAAA,OAAKC,GAAU6wB,GAAYzxB,GAE1C,WAAT4xB,GAAqB5M,IACvBhlB,EAAW8xB,oBAAqB,GAC3B9M,EAAM8B,MAAQ,KAAOh0C,EACxB8+C,EAAOjxB,GACGqkB,EAAM+B,SAAW,KAAOj0C,EAClC8+C,EAAOhxB,GAEPtH,EAAIy4B,GAAUnxB,EAAQpJ,EAAOC,EAAK9F,KAAY,EAC9CigC,EAAOjxB,IAIXrH,EAAIy4B,GAAUH,EAAMp6B,EAAOC,EAAK9F,KAAY,EAC5CqO,EAAW6xB,cAAgBv4B,CAC7B,CAEA,SAASy4B,GAAUH,EAAMpyC,EAAGC,EAAGkS,GAO7B,OANIA,GACFigC,EAAOI,GAAKJ,EAAMpyC,EAAGC,GACrBmyC,EAAOK,GAASL,EAAMnyC,EAAGD,IAEzBoyC,EAAOK,GAASL,EAAMpyC,EAAGC,GAEpBmyC,CACT,CAEA,SAASI,GAAKE,EAAMjgC,EAAIkgC,GACtB,OAAOD,IAASjgC,EAAKkgC,EAAKD,IAASC,EAAKlgC,EAAKigC,CAC/C,CAEA,SAASD,GAAS1zC,EAAGiZ,EAAOC,GAC1B,MAAa,UAANlZ,EAAgBiZ,EAAc,QAANjZ,EAAckZ,EAAMlZ,CACrD,CAEA,SAAS6zC,GAAiBpyB,GAAY,cAACqyB,GAAgB/jC,GACrD0R,EAAWqyB,cAAkC,SAAlBA,EACb,IAAV/jC,EAAc,IAAO,EACrB+jC,CACN,EDqzBA9gD,EAAAA,GAAAA,GA30BqB02C,GAAA,WAKD,CAAC,IAAE12C,EAAAA,GAAAA,GALF02C,GAAA,qBAUS,OAAI12C,EAAAA,GAAAA,GAVb02C,GAAA,kBAeM,MCSZ,MAAMqK,WAAsBrK,GAgDzCqD,kBAAAA,CAAmBpwB,EAAMtnB,EAAM4jB,EAAO1c,GACpC,OAAOq2C,GAAsBj2B,EAAMtnB,EAAM4jB,EAAO1c,EAClD,CAOAswC,cAAAA,CAAelwB,EAAMtnB,EAAM4jB,EAAO1c,GAChC,OAAOq2C,GAAsBj2B,EAAMtnB,EAAM4jB,EAAO1c,EAClD,CAOAuwC,eAAAA,CAAgBnwB,EAAMtnB,EAAM4jB,EAAO1c,GACjC,MAAM,OAACygB,EAAA,OAAQC,GAAUN,GACnB,SAACywB,EAAW,aAAKC,EAAW,KAAO93C,KAAKmgC,SACxCqR,EAA2B,MAAhB/pB,EAAOK,KAAe+vB,EAAWC,EAC5CrG,EAA2B,MAAhB/pB,EAAOI,KAAe+vB,EAAWC,EAC5C1X,EAAS,GACf,IAAIjjC,EAAG8gB,EAAMnf,EAAMuc,EACnB,IAAKle,EAAIumB,EAAOzF,EAAOyF,EAAQ1c,EAAO7J,EAAI8gB,IAAQ9gB,EAChDke,EAAMvb,EAAK3C,GACX2B,EAAO,CAAC,EACRA,EAAK2oB,EAAOK,MAAQL,EAAO4Y,MAAMzgB,GAAiBvE,EAAKm2B,GAAWr0C,GAClEijC,EAAO1gB,KAAK09B,GAAWx9B,GAAiBvE,EAAKo2B,GAAW3yC,EAAM4oB,EAAQvqB,IAExE,OAAOijC,CACT,CAKA6X,qBAAAA,CAAsB1qC,EAAO+lB,EAAO8M,EAAQ8Q,GAC1CuN,MAAMxG,sBAAsB1qC,EAAO+lB,EAAO8M,EAAQ8Q,GAClD,MAAMqM,EAASnd,EAAO+c,QAClBI,GAAUjqB,IAAUtzB,KAAK2yC,YAAYjrB,SAEvCna,EAAMzC,IAAMjD,KAAKiD,IAAIyC,EAAMzC,IAAKyyC,EAAOzyC,KACvCyC,EAAM1C,IAAMhD,KAAKgD,IAAI0C,EAAM1C,IAAK0yC,EAAO1yC,KAE3C,CAMA6tC,cAAAA,GACE,OAAO,CACT,CAKAC,gBAAAA,CAAiB35C,GACf,MAAMooB,EAAOpnB,KAAK2yC,aACZ,OAAClrB,EAAA,OAAQC,GAAUN,EACnBgZ,EAASpgC,KAAK+3C,UAAU/4C,GACxBu+C,EAASnd,EAAO+c,QAChBv/C,EAAQ0/C,GAAWC,GACrB,IAAMA,EAAO75B,MAAQ,KAAO65B,EAAO55B,IAAM,IACzC,GAAK+D,EAAOmxB,iBAAiBzY,EAAO1Y,EAAOI,OAE/C,MAAO,CACL8wB,MAAO,GAAKnxB,EAAOoxB,iBAAiBzY,EAAO3Y,EAAOK,OAClDlqB,QAEJ,CAEAs3C,UAAAA,GACEl1C,KAAK40C,qBAAsB,EAE3B6J,MAAMvJ,aAEN,MAAM9tB,EAAOpnB,KAAK2yC,YAClBvrB,EAAK8pB,MAAQlxC,KAAKu1C,aAAarE,KACjC,CAEAlC,MAAAA,CAAOlc,GACL,MAAM1L,EAAOpnB,KAAK2yC,YAClB3yC,KAAK86C,eAAe1zB,EAAKtnB,KAAM,EAAGsnB,EAAKtnB,KAAK8G,OAAQksB,EACtD,CAEAgoB,cAAAA,CAAe4D,EAAMh7B,EAAO1c,EAAO8rB,GACjC,MAAM0jB,EAAiB,UAAT1jB,GACR,MAAC9zB,EAAO2zC,aAAa,OAACjrB,IAAW1nB,KACjCulB,EAAOmC,EAAOi3B,eACdf,EAAal2B,EAAOg2B,eACpBvB,EAAQn8C,KAAK4+C,aACb,cAACjF,EAAa,eAAED,GAAkB15C,KAAK65C,kBAAkBn2B,EAAOoP,GAEtE,IAAK,IAAI31B,EAAIumB,EAAOvmB,EAAIumB,EAAQ1c,EAAO7J,IAAK,CAC1C,MAAMijC,EAASpgC,KAAK+3C,UAAU56C,GACxB0hD,EAAUrI,GAAS/5B,GAAc2jB,EAAO1Y,EAAOI,OAAS,CAACvC,OAAMu5B,KAAMv5B,GAAQvlB,KAAK++C,yBAAyB5hD,GAC3G6hD,EAAUh/C,KAAKi/C,yBAAyB9hD,EAAGg/C,GAC3CjL,GAAS9Q,EAAOwS,SAAW,CAAC,GAAGlrB,EAAOI,MAEtCoE,EAAa,CACjB0xB,aACAr4B,KAAMs5B,EAAQt5B,KACdy4B,oBAAqB9M,GAASoM,GAAWld,EAAO+c,UAAan+C,IAAUkyC,EAAM8B,MAAQh0C,IAAUkyC,EAAM+B,QACrGzkC,EAAGovC,EAAaiB,EAAQC,KAAOE,EAAQE,OACvC7/B,EAAGu+B,EAAaoB,EAAQE,OAASL,EAAQC,KACzCjpB,OAAQ+nB,EAAaoB,EAAQ12C,KAAOT,KAAKqZ,IAAI29B,EAAQv2C,MACrD0nB,MAAO4tB,EAAa/1C,KAAKqZ,IAAI29B,EAAQv2C,MAAQ02C,EAAQ12C,MAGnDoxC,IACFxtB,EAAWplB,QAAU6yC,GAAiB35C,KAAK+4C,0BAA0B57C,EAAGuhD,EAAKvhD,GAAGgvB,OAAS,SAAW2G,IAEtG,MAAMhsB,EAAUolB,EAAWplB,SAAW43C,EAAKvhD,GAAG2J,QAC9C+2C,GAAiB3xB,EAAYplB,EAASoqC,EAAOlyC,GAC7Cs/C,GAAiBpyB,EAAYplB,EAASq1C,EAAM3hC,OAC5Cxa,KAAKi6C,cAAcyE,EAAKvhD,GAAIA,EAAG+uB,EAAY4G,EAC7C,CACF,CASAqsB,UAAAA,CAAWx6B,EAAM6uB,GACf,MAAM,OAAC/rB,GAAUznB,KAAK2yC,YAChB5B,EAAWtpB,EAAO+qB,wBAAwBxyC,KAAKs0C,OAClD/U,OAAOnY,GAAQA,EAAKsrB,WAAW5rC,QAAQs4C,SACpCxN,EAAUnqB,EAAO3gB,QAAQ8qC,QACzBM,EAAS,GACTmN,EAAgBr/C,KAAK2yC,YAAYD,WAAWqF,UAAUvE,GACtD8L,EAAcD,GAAiBA,EAAc53B,EAAOK,MAEpDy3B,EAAYn4B,IAChB,MAAMgZ,EAAShZ,EAAKO,QAAQ63B,KAAK1gD,GAAQA,EAAK2oB,EAAOK,QAAUw3B,GACzDtjC,EAAMokB,GAAUA,EAAOhZ,EAAKM,OAAOI,MAEzC,GAAIrL,GAAcT,IAAQgG,MAAMhG,GAC9B,OAAO,GAIX,IAAK,MAAMoL,KAAQ2pB,EACjB,SAAkBpkC,IAAd6mC,IAA2B+L,EAASn4B,QASxB,IAAZwqB,IAAqD,IAAhCM,EAAOxzB,QAAQ0I,EAAK8pB,aAClCvkC,IAAZilC,QAAwCjlC,IAAfya,EAAK8pB,QAC3BgB,EAAOxyB,KAAK0H,EAAK8pB,OAEf9pB,EAAKpoB,QAAU2lB,GACjB,MAWJ,OAJKutB,EAAOtrC,QACVsrC,EAAOxyB,UAAK/S,GAGPulC,CACT,CAMAuN,cAAAA,CAAezgD,GACb,OAAOgB,KAAKm/C,gBAAWxyC,EAAW3N,GAAO4H,MAC3C,CAEA84C,aAAAA,GACE,OAAO1/C,KAAK2/C,WAAW/4C,MACzB,CAEAg5C,2BAAAA,GACE,MAAMrsB,EAASvzB,KAAKiuB,MAAMsF,OACpBssB,EAAe7/C,KAAKiuB,MAAMnnB,QAAQ8rB,UACxC,OAAOl1B,OAAOgJ,KAAK6sB,GAAQgM,OAAOxgC,GAAOw0B,EAAOx0B,GAAK+oB,OAAS+3B,GAAcxM,OAC9E,CAEAsM,QAAAA,GACE,MAAM73B,EAAO,CAAC,EACRg4B,EAAmB9/C,KAAK4/C,8BAC9B,IAAK,MAAM/3B,KAAW7nB,KAAKiuB,MAAMnuB,KAAK+xB,SACpC/J,EAAK7K,GAC8B,MAAjCjd,KAAKiuB,MAAMnnB,QAAQ8rB,UAAoB/K,EAAQ6tB,QAAU7tB,EAAQ+tB,QAASkK,KACvE,EAEP,OAAOpiD,OAAOgJ,KAAKohB,EACrB,CAUAi4B,cAAAA,CAAe3hC,EAAc3e,EAAM+zC,GACjC,MAAMtB,EAASlyC,KAAKm/C,WAAW/gC,EAAco1B,GACvCx0C,OAAkB2N,IAAVlN,EACVyyC,EAAOxzB,QAAQjf,IACd,EAEL,OAAmB,IAAXT,EACJkzC,EAAOtrC,OAAS,EAChB5H,CACN,CAKA4/C,SAAAA,GACE,MAAMtmB,EAAOt4B,KAAK8G,QACZsgB,EAAOpnB,KAAK2yC,YACZlrB,EAASL,EAAKK,OACdi1B,EAAS,GACf,IAAIv/C,EAAG8gB,EAEP,IAAK9gB,EAAI,EAAG8gB,EAAOmJ,EAAKtnB,KAAK8G,OAAQzJ,EAAI8gB,IAAQ9gB,EAC/Cu/C,EAAOh9B,KAAK+H,EAAOS,iBAAiBloB,KAAK+3C,UAAU56C,GAAGsqB,EAAOK,MAAO3qB,IAGtE,MAAMm/C,EAAehkB,EAAKgkB,aACpBxxC,EAAMwxC,GAAgBT,GAAqBz0B,GAEjD,MAAO,CACLtc,MACA4xC,SACAh5B,MAAO+D,EAAOu4B,YACdr8B,IAAK8D,EAAOw4B,UACZ7D,WAAYp8C,KAAKy/C,iBACjBnsB,MAAO7L,EACP23B,QAAS9mB,EAAK8mB,QAEd5kC,MAAO8hC,EAAe,EAAIhkB,EAAKikB,mBAAqBjkB,EAAKkkB,cAE7D,CAMAuC,wBAAAA,CAAyB//C,GACvB,MAAO2zC,aAAa,OAACjrB,EAAA,SAAQwsB,EAAUl1C,MAAOof,GAAetX,SAAUye,KAAM26B,EAAS,aAAEC,IAAiBngD,KACnGy9C,EAAayC,GAAa,EAC1B9f,EAASpgC,KAAK+3C,UAAU/4C,GACxBu+C,EAASnd,EAAO+c,QAChBiD,EAAW9C,GAAWC,GAC5B,IAGIuB,EAAMx2C,EAHN1K,EAAQwiC,EAAO1Y,EAAOI,MACtBpE,EAAQ,EACR9c,EAASstC,EAAWl0C,KAAKixC,WAAWvpB,EAAQ0Y,EAAQ8T,GAAYt2C,EAGhEgJ,IAAWhJ,IACb8lB,EAAQ9c,EAAShJ,EACjBgJ,EAAShJ,GAGPwiD,IACFxiD,EAAQ2/C,EAAON,SACfr2C,EAAS22C,EAAOL,OAASK,EAAON,SAElB,IAAVr/C,GAAemjB,GAAKnjB,KAAWmjB,GAAKw8B,EAAOL,UAC7Cx5B,EAAQ,GAEVA,GAAS9lB,GAGX,MAAMm/C,EAActgC,GAAcyjC,IAAeE,EAAuB18B,EAAZw8B,EAC5D,IAAI36B,EAAOmC,EAAOQ,iBAAiB60B,GAWnC,GARE+B,EADE9+C,KAAKiuB,MAAMoyB,kBAAkBrhD,GACxB0oB,EAAOQ,iBAAiBxE,EAAQ9c,GAGhC2e,EAGTjd,EAAOw2C,EAAOv5B,EAEV1d,KAAKqZ,IAAI5Y,GAAQ63C,EAAc,CACjC73C,EAAOk1C,GAAQl1C,EAAMof,EAAQ+1B,GAAc0C,EACvCviD,IAAU6/C,IACZl4B,GAAQjd,EAAO,GAEjB,MAAMg4C,EAAa54B,EAAO64B,mBAAmB,GACvCC,EAAW94B,EAAO64B,mBAAmB,GACrCz1C,EAAMjD,KAAKiD,IAAIw1C,EAAYE,GAC3B31C,EAAMhD,KAAKgD,IAAIy1C,EAAYE,GACjCj7B,EAAO1d,KAAKgD,IAAIhD,KAAKiD,IAAIya,EAAM1a,GAAMC,GACrCg0C,EAAOv5B,EAAOjd,EAEV4rC,IAAakM,IAEfhgB,EAAOwS,QAAQlrB,EAAOI,MAAMqrB,cAAc/0B,GAAgBsJ,EAAO+4B,iBAAiB3B,GAAQp3B,EAAO+4B,iBAAiBl7B,G,CAItH,GAAIA,IAASmC,EAAOQ,iBAAiBu1B,GAAa,CAChD,MAAMiD,EAAW3/B,GAAKzY,GAAQof,EAAOi5B,qBAAqBlD,GAAc,EACxEl4B,GAAQm7B,EACRp4C,GAAQo4C,C,CAGV,MAAO,CACLp4C,OACAid,OACAu5B,OACAI,OAAQJ,EAAOx2C,EAAO,EAE1B,CAKA22C,wBAAAA,CAAyBjgD,EAAOm9C,GAC9B,MAAM7oB,EAAQ6oB,EAAM7oB,MACdxsB,EAAU9G,KAAK8G,QACfy4C,EAAWz4C,EAAQy4C,SACnBqB,EAAkB3jC,GAAenW,EAAQ85C,gBAAiBC,KAChE,IAAI3B,EAAQ52C,EACZ,MAAMw4C,EAAY9gD,KAAK0/C,gBACvB,GAAIvD,EAAMiD,QAAS,CACjB,MAAMhD,EAAamD,EAAWv/C,KAAKy/C,eAAezgD,GAASm9C,EAAMC,WAC3D7uC,EAAiC,SAAzBzG,EAAQw1C,aAClBK,GAA0B39C,EAAOm9C,EAAOr1C,EAASs1C,EAAa0E,GAC9D5E,GAAyBl9C,EAAOm9C,EAAOr1C,EAASs1C,EAAa0E,GAC3DC,EAA0C,MAAjC/gD,KAAKiuB,MAAMnnB,QAAQ8rB,UAAoB5yB,KAAKu1C,aAAaG,QAAU11C,KAAKu1C,aAAaK,QAC9FoL,EAAahhD,KAAK2/C,WAAWjhC,QAAQzB,GAAe8jC,EAAQ/gD,KAAK4/C,gCACjEqB,EAAajhD,KAAK+/C,eAAe//C,KAAKhB,MAAOgB,KAAK2yC,YAAYzB,MAAOqO,EAAWvgD,OAAQ2N,GAAaq0C,EAC3G9B,EAAS3xC,EAAMmW,MAASnW,EAAMkvC,MAAQwE,EAAe1zC,EAAMkvC,MAAQ,EACnEn0C,EAAOT,KAAKiD,IAAI81C,EAAiBrzC,EAAMkvC,MAAQlvC,EAAMiN,M,MAGrD0kC,EAAS5rB,EAAMpL,iBAAiBloB,KAAK+3C,UAAU/4C,GAAOs0B,EAAMxL,MAAO9oB,GACnEsJ,EAAOT,KAAKiD,IAAI81C,EAAiBzE,EAAMrxC,IAAMqxC,EAAM3hC,OAIrD,MAAO,CACL+K,KAAM25B,EAAS52C,EAAO,EACtBw2C,KAAMI,EAAS52C,EAAO,EACtB42C,SACA52C,OAEJ,CAEA0kC,IAAAA,GACE,MAAM5lB,EAAOpnB,KAAK2yC,YACZjrB,EAASN,EAAKM,OACdw5B,EAAQ95B,EAAKtnB,KACbme,EAAOijC,EAAMt6C,OACnB,IAAIzJ,EAAI,EAER,KAAOA,EAAI8gB,IAAQ9gB,EACsB,OAAnC6C,KAAK+3C,UAAU56C,GAAGuqB,EAAOI,OAAmBo5B,EAAM/jD,GAAG82C,QACvDiN,EAAM/jD,GAAG6vC,KAAKhtC,KAAK3B,KAGzB,GAEFZ,EAAAA,GAAAA,GAxaqB+gD,GAAsB,KAE7B,QAAM/gD,EAAAA,GAAAA,GAFC+gD,GAAsB,WAOvB,CAChBxJ,oBAAoB,EACpBC,gBAAiB,MAEjBsH,mBAAoB,GACpBC,cAAe,GACf4C,SAAS,EAET7yB,WAAY,CACVf,QAAS,CACP7rB,KAAM,SACNusB,WAAY,CAAC,IAAK,IAAK,OAAQ,QAAS,eAG5CzuB,EAAAA,GAAAA,GArBiB+gD,GAAsB,YA0BtB,CACjBjrB,OAAQ,CACN4tB,QAAS,CACPxhD,KAAM,WACNsvB,QAAQ,EACRK,KAAM,CACJL,QAAQ,IAGZmyB,QAAS,CACPzhD,KAAM,SACNuvB,aAAa,MCnSN,MAAMmyB,WAAyBlN,GAiC5Ce,UAAAA,GACEl1C,KAAK40C,qBAAsB,EAC3B6J,MAAMvJ,YACR,CAMAsC,kBAAAA,CAAmBpwB,EAAMtnB,EAAM4jB,EAAO1c,GACpC,MAAMo5B,EAASqe,MAAMjH,mBAAmBpwB,EAAMtnB,EAAM4jB,EAAO1c,GAC3D,IAAK,IAAI7J,EAAI,EAAGA,EAAIijC,EAAOx5B,OAAQzJ,IACjCijC,EAAOjjC,GAAGggD,QAAUn9C,KAAK+4C,0BAA0B57C,EAAIumB,GAAO6S,OAEhE,OAAO6J,CACT,CAMAkX,cAAAA,CAAelwB,EAAMtnB,EAAM4jB,EAAO1c,GAChC,MAAMo5B,EAASqe,MAAMnH,eAAelwB,EAAMtnB,EAAM4jB,EAAO1c,GACvD,IAAK,IAAI7J,EAAI,EAAGA,EAAIijC,EAAOx5B,OAAQzJ,IAAK,CACtC,MAAM2B,EAAOgB,EAAK4jB,EAAQvmB,GAC1BijC,EAAOjjC,GAAGggD,QAAUlgC,GAAene,EAAK,GAAIkB,KAAK+4C,0BAA0B57C,EAAIumB,GAAO6S,OACxF,CACA,OAAO6J,CACT,CAMAmX,eAAAA,CAAgBnwB,EAAMtnB,EAAM4jB,EAAO1c,GACjC,MAAMo5B,EAASqe,MAAMlH,gBAAgBnwB,EAAMtnB,EAAM4jB,EAAO1c,GACxD,IAAK,IAAI7J,EAAI,EAAGA,EAAIijC,EAAOx5B,OAAQzJ,IAAK,CACtC,MAAM2B,EAAOgB,EAAK4jB,EAAQvmB,GAC1BijC,EAAOjjC,GAAGggD,QAAUlgC,GAAene,GAAQA,EAAK7B,IAAM6B,EAAK7B,EAAG+C,KAAK+4C,0BAA0B57C,EAAIumB,GAAO6S,OAC1G,CACA,OAAO6J,CACT,CAKAsY,cAAAA,GACE,MAAM54C,EAAOE,KAAK2yC,YAAY7yC,KAE9B,IAAI+K,EAAM,EACV,IAAK,IAAI1N,EAAI2C,EAAK8G,OAAS,EAAGzJ,GAAK,IAAKA,EACtC0N,EAAMhD,KAAKgD,IAAIA,EAAK/K,EAAK3C,GAAGmL,KAAKtI,KAAK+4C,0BAA0B57C,IAAM,GAExE,OAAO0N,EAAM,GAAKA,CACpB,CAKA8tC,gBAAAA,CAAiB35C,GACf,MAAMooB,EAAOpnB,KAAK2yC,YACZ+E,EAAS13C,KAAKiuB,MAAMnuB,KAAK43C,QAAU,IACnC,OAAClvB,EAAA,OAAQC,GAAUrB,EACnBgZ,EAASpgC,KAAK+3C,UAAU/4C,GACxBwP,EAAIga,EAAOqwB,iBAAiBzY,EAAO5xB,GACnC6Q,EAAIoJ,EAAOowB,iBAAiBzY,EAAO/gB,GACnCpiB,EAAImjC,EAAO+c,QAEjB,MAAO,CACLvE,MAAOlB,EAAO14C,IAAU,GACxBpB,MAAO,IAAM4Q,EAAI,KAAO6Q,GAAKpiB,EAAI,KAAOA,EAAI,IAAM,IAEtD,CAEA+xC,MAAAA,CAAOlc,GACL,MAAMzL,EAASrnB,KAAK2yC,YAAY7yC,KAGhCE,KAAK86C,eAAezzB,EAAQ,EAAGA,EAAOzgB,OAAQksB,EAChD,CAEAgoB,cAAAA,CAAezzB,EAAQ3D,EAAO1c,EAAO8rB,GACnC,MAAM0jB,EAAiB,UAAT1jB,GACR,OAACrL,EAAA,OAAQC,GAAU1nB,KAAK2yC,aACxB,cAACgH,EAAa,eAAED,GAAkB15C,KAAK65C,kBAAkBn2B,EAAOoP,GAChE+f,EAAQprB,EAAOK,KACfgrB,EAAQprB,EAAOI,KAErB,IAAK,IAAI3qB,EAAIumB,EAAOvmB,EAAIumB,EAAQ1c,EAAO7J,IAAK,CAC1C,MAAMkrB,EAAQhB,EAAOlqB,GACfijC,GAAUoW,GAASx2C,KAAK+3C,UAAU56C,GAClC+uB,EAAa,CAAC,EACdgW,EAAShW,EAAW2mB,GAAS2D,EAAQ/uB,EAAO84B,mBAAmB,IAAO94B,EAAOS,iBAAiBkY,EAAOyS,IACrG1Q,EAASjW,EAAW4mB,GAAS0D,EAAQ9uB,EAAOi3B,eAAiBj3B,EAAOQ,iBAAiBkY,EAAO0S,IAElG5mB,EAAWsU,KAAOxe,MAAMkgB,IAAWlgB,MAAMmgB,GAErCuX,IACFxtB,EAAWplB,QAAU6yC,GAAiB35C,KAAK+4C,0BAA0B57C,EAAGkrB,EAAM8D,OAAS,SAAW2G,GAE9F0jB,IACFtqB,EAAWplB,QAAQyvB,OAAS,IAIhCv2B,KAAKi6C,cAAc5xB,EAAOlrB,EAAG+uB,EAAY4G,EAC3C,CACF,CAOAimB,yBAAAA,CAA0B/5C,EAAO8zB,GAC/B,MAAMsN,EAASpgC,KAAK+3C,UAAU/4C,GAC9B,IAAI+lB,EAAS05B,MAAM1F,0BAA0B/5C,EAAO8zB,GAGhD/N,EAAOorB,UACTprB,EAASrnB,OAAOkd,OAAO,CAAC,EAAGmK,EAAQ,CAACorB,SAAS,KAI/C,MAAM5Z,EAASxR,EAAOwR,OAMtB,MALa,WAATzD,IACF/N,EAAOwR,OAAS,GAElBxR,EAAOwR,QAAUtZ,GAAemjB,GAAUA,EAAO+c,QAAS5mB,GAEnDxR,CACT,EC9JF,SAASu8B,GAAkBhrB,EAAUirB,EAAeC,GAClD,IAAIC,EAAS,EACTC,EAAS,EACT/c,EAAU,EACVC,EAAU,EAEd,GAAI2c,EAAgBjhC,GAAK,CACvB,MAAMqhC,EAAarrB,EACbsrB,EAAWD,EAAaJ,EACxBM,EAASh6C,KAAKuiB,IAAIu3B,GAClBG,EAASj6C,KAAKshB,IAAIw4B,GAClBI,EAAOl6C,KAAKuiB,IAAIw3B,GAChBI,EAAOn6C,KAAKshB,IAAIy4B,GAChBK,EAAUA,CAACh/B,EAAOvX,EAAGC,IAAM8X,GAAcR,EAAO0+B,EAAYC,GAAU,GAAQ,EAAI/5C,KAAKgD,IAAIa,EAAGA,EAAI81C,EAAQ71C,EAAGA,EAAI61C,GACjHU,EAAUA,CAACj/B,EAAOvX,EAAGC,IAAM8X,GAAcR,EAAO0+B,EAAYC,GAAU,IAAS,EAAI/5C,KAAKiD,IAAIY,EAAGA,EAAI81C,EAAQ71C,EAAGA,EAAI61C,GAClHW,EAAOF,EAAQ,EAAGJ,EAAQE,GAC1BK,EAAOH,EAAQthC,GAASmhC,EAAQE,GAChCK,EAAOH,EAAQ7hC,GAAIwhC,EAAQE,GAC3BO,EAAOJ,EAAQ7hC,GAAKM,GAASmhC,EAAQE,GAC3CP,GAAUU,EAAOE,GAAQ,EACzBX,GAAUU,EAAOE,GAAQ,EACzB3d,IAAYwd,EAAOE,GAAQ,EAC3Bzd,IAAYwd,EAAOE,GAAQ,C,CAE7B,MAAO,CAACb,SAAQC,SAAQ/c,UAASC,UACnC,EDsIAnnC,EAAAA,GAAAA,GArKqB4jD,GAAyB,KAEhC,WAAS5jD,EAAAA,GAAAA,GAFF4jD,GAAyB,WAO1B,CAChBrM,oBAAoB,EACpBC,gBAAiB,QAEjB1oB,WAAY,CACVf,QAAS,CACP7rB,KAAM,SACNusB,WAAY,CAAC,IAAK,IAAK,cAAe,eAG1CzuB,EAAAA,GAAAA,GAjBiB4jD,GAAyB,YAsBzB,CACjB9tB,OAAQ,CACN/kB,EAAG,CACD7O,KAAM,UAER0f,EAAG,CACD1f,KAAM,aCKC,MAAM4iD,WAA2BpO,GA6F9Ct3C,WAAAA,CAAYoxB,EAAO7P,GACjBqgC,MAAMxwB,EAAO7P,GAEbpe,KAAK40C,qBAAsB,EAC3B50C,KAAKwiD,iBAAc71C,EACnB3M,KAAKyiD,iBAAc91C,EACnB3M,KAAK2kC,aAAUh4B,EACf3M,KAAK4kC,aAAUj4B,CACjB,CAEAwoC,UAAAA,GAAc,CAKd9U,KAAAA,CAAM3c,EAAO1c,GACX,MAAMlH,EAAOE,KAAKu1C,aAAaz1C,KACzBsnB,EAAOpnB,KAAK2yC,YAElB,IAAsB,IAAlB3yC,KAAKmgC,SACP/Y,EAAKO,QAAU7nB,MACV,CACL,IAOI3C,EAAG8gB,EAPHykC,EAAUvlD,IAAO2C,EAAK3C,GAE1B,GAAIyf,GAAS9c,EAAK4jB,IAAS,CACzB,MAAM,IAAC3kB,EAAM,SAAWiB,KAAKmgC,SAC7BuiB,EAAUvlD,IAAOyiB,GAAiB9f,EAAK3C,GAAI4B,E,CAI7C,IAAK5B,EAAIumB,EAAOzF,EAAOyF,EAAQ1c,EAAO7J,EAAI8gB,IAAQ9gB,EAChDiqB,EAAKO,QAAQxqB,GAAKulD,EAAOvlD,E,CAG/B,CAKAwlD,YAAAA,GACE,OAAOrgC,GAAUtiB,KAAK8G,QAAQwvB,SAAW,GAC3C,CAKAssB,iBAAAA,GACE,OAAOtgC,GAAUtiB,KAAK8G,QAAQy6C,cAChC,CAMAsB,mBAAAA,GACE,IAAI/3C,EAAMwV,GACNzV,GAAOyV,GAEX,IAAK,IAAInjB,EAAI,EAAGA,EAAI6C,KAAKiuB,MAAMnuB,KAAK+xB,SAASjrB,SAAUzJ,EACrD,GAAI6C,KAAKiuB,MAAM60B,iBAAiB3lD,IAAM6C,KAAKiuB,MAAMooB,eAAel5C,GAAGwC,OAASK,KAAKs0C,MAAO,CACtF,MAAM5B,EAAa1yC,KAAKiuB,MAAMooB,eAAel5C,GAAGu1C,WAC1Cpc,EAAWoc,EAAWiQ,eACtBpB,EAAgB7O,EAAWkQ,oBAEjC93C,EAAMjD,KAAKiD,IAAIA,EAAKwrB,GACpBzrB,EAAMhD,KAAKgD,IAAIA,EAAKyrB,EAAWirB,E,CAInC,MAAO,CACLjrB,SAAUxrB,EACVy2C,cAAe12C,EAAMC,EAEzB,CAKAkkC,MAAAA,CAAOlc,GACL,MAAM7E,EAAQjuB,KAAKiuB,OACb,UAACwd,GAAaxd,EACd7G,EAAOpnB,KAAK2yC,YACZoQ,EAAO37B,EAAKtnB,KACZkjD,EAAUhjD,KAAKijD,oBAAsBjjD,KAAKkjD,aAAaH,GAAQ/iD,KAAK8G,QAAQk8C,QAC5EG,EAAUt7C,KAAKgD,KAAKhD,KAAKiD,IAAI2gC,EAAUzb,MAAOyb,EAAU5V,QAAUmtB,GAAW,EAAG,GAChFxB,EAAS35C,KAAKiD,IAAIoS,GAAald,KAAK8G,QAAQ06C,OAAQ2B,GAAU,GAC9DC,EAAcpjD,KAAKqjD,eAAerjD,KAAKhB,QAKvC,cAACuiD,EAAA,SAAejrB,GAAYt2B,KAAK6iD,uBACjC,OAACpB,EAAA,OAAQC,EAAA,QAAQ/c,EAAA,QAASC,GAAW0c,GAAkBhrB,EAAUirB,EAAeC,GAChFxnB,GAAYyR,EAAUzb,MAAQgzB,GAAWvB,EACzCjc,GAAaiG,EAAU5V,OAASmtB,GAAWtB,EAC3C4B,EAAYz7C,KAAKgD,IAAIhD,KAAKiD,IAAIkvB,EAAUwL,GAAa,EAAG,GACxDid,EAAcnlC,GAAYtd,KAAK8G,QAAQyvB,OAAQ+sB,GAC/Cd,EAAc36C,KAAKgD,IAAI43C,EAAcjB,EAAQ,GAC7C+B,GAAgBd,EAAcD,GAAexiD,KAAKwjD,gCACxDxjD,KAAK2kC,QAAUA,EAAU8d,EACzBziD,KAAK4kC,QAAUA,EAAU6d,EAEzBr7B,EAAKlf,MAAQlI,KAAKyjD,iBAElBzjD,KAAKyiD,YAAcA,EAAcc,EAAevjD,KAAK0jD,qBAAqB1jD,KAAKhB,OAC/EgB,KAAKwiD,YAAc36C,KAAKgD,IAAI7K,KAAKyiD,YAAcc,EAAeH,EAAa,GAE3EpjD,KAAK86C,eAAeiI,EAAM,EAAGA,EAAKn8C,OAAQksB,EAC5C,CAKA6wB,cAAAA,CAAexmD,EAAGq5C,GAChB,MAAMle,EAAOt4B,KAAK8G,QACZsgB,EAAOpnB,KAAK2yC,YACZ4O,EAAgBvhD,KAAK4iD,oBAC3B,OAAIpM,GAAUle,EAAKlM,UAAUw3B,gBAAmB5jD,KAAKiuB,MAAMoyB,kBAAkBljD,IAA0B,OAApBiqB,EAAKO,QAAQxqB,IAAeiqB,EAAKtnB,KAAK3C,GAAG82C,OACnH,EAEFj0C,KAAK6jD,uBAAuBz8B,EAAKO,QAAQxqB,GAAKokD,EAAgBjhC,GACvE,CAEAw6B,cAAAA,CAAeiI,EAAMr/B,EAAO1c,EAAO8rB,GACjC,MAAM0jB,EAAiB,UAAT1jB,EACR7E,EAAQjuB,KAAKiuB,MACbwd,EAAYxd,EAAMwd,UAClBnT,EAAOrK,EAAMnnB,QACbg9C,EAAgBxrB,EAAKlM,UACrB23B,GAAWtY,EAAU1kB,KAAO0kB,EAAUzkB,OAAS,EAC/Cg9B,GAAWvY,EAAU5e,IAAM4e,EAAU3e,QAAU,EAC/Cm3B,EAAezN,GAASsN,EAAcG,aACtCzB,EAAcyB,EAAe,EAAIjkD,KAAKwiD,YACtCC,EAAcwB,EAAe,EAAIjkD,KAAKyiD,aACtC,cAAC9I,EAAa,eAAED,GAAkB15C,KAAK65C,kBAAkBn2B,EAAOoP,GACtE,IACI31B,EADAwkD,EAAa3hD,KAAK2iD,eAGtB,IAAKxlD,EAAI,EAAGA,EAAIumB,IAASvmB,EACvBwkD,GAAc3hD,KAAK2jD,eAAexmD,EAAGq5C,GAGvC,IAAKr5C,EAAIumB,EAAOvmB,EAAIumB,EAAQ1c,IAAS7J,EAAG,CACtC,MAAMokD,EAAgBvhD,KAAK2jD,eAAexmD,EAAGq5C,GACvC3f,EAAMksB,EAAK5lD,GACX+uB,EAAa,CACjB1d,EAAGu1C,EAAU/jD,KAAK2kC,QAClBtlB,EAAG2kC,EAAUhkD,KAAK4kC,QAClB+c,aACAC,SAAUD,EAAaJ,EACvBA,gBACAkB,cACAD,eAEE9I,IACFxtB,EAAWplB,QAAU6yC,GAAiB35C,KAAK+4C,0BAA0B57C,EAAG05B,EAAI1K,OAAS,SAAW2G,IAElG6uB,GAAcJ,EAEdvhD,KAAKi6C,cAAcpjB,EAAK15B,EAAG+uB,EAAY4G,EACzC,CACF,CAEA2wB,cAAAA,GACE,MAAMr8B,EAAOpnB,KAAK2yC,YACZuR,EAAW98B,EAAKtnB,KACtB,IACI3C,EADA+K,EAAQ,EAGZ,IAAK/K,EAAI,EAAGA,EAAI+mD,EAASt9C,OAAQzJ,IAAK,CACpC,MAAMS,EAAQwpB,EAAKO,QAAQxqB,GACb,OAAVS,GAAmBokB,MAAMpkB,KAAUoC,KAAKiuB,MAAMoyB,kBAAkBljD,IAAO+mD,EAAS/mD,GAAG82C,SACrF/rC,GAASL,KAAKqZ,IAAItjB,GAEtB,CAEA,OAAOsK,CACT,CAEA27C,sBAAAA,CAAuBjmD,GACrB,MAAMsK,EAAQlI,KAAK2yC,YAAYzqC,MAC/B,OAAIA,EAAQ,IAAM8Z,MAAMpkB,GACf0iB,IAAOzY,KAAKqZ,IAAItjB,GAASsK,GAE3B,CACT,CAEAywC,gBAAAA,CAAiB35C,GACf,MAAMooB,EAAOpnB,KAAK2yC,YACZ1kB,EAAQjuB,KAAKiuB,MACbypB,EAASzpB,EAAMnuB,KAAK43C,QAAU,GAC9B95C,EAAQ8vB,GAAatG,EAAKO,QAAQ3oB,GAAQivB,EAAMnnB,QAAQomB,QAE9D,MAAO,CACL0rB,MAAOlB,EAAO14C,IAAU,GACxBpB,QAEJ,CAEAqlD,iBAAAA,CAAkBF,GAChB,IAAIl4C,EAAM,EACV,MAAMojB,EAAQjuB,KAAKiuB,MACnB,IAAI9wB,EAAG8gB,EAAMmJ,EAAMsrB,EAAY5rC,EAE/B,IAAKi8C,EAEH,IAAK5lD,EAAI,EAAG8gB,EAAOgQ,EAAMnuB,KAAK+xB,SAASjrB,OAAQzJ,EAAI8gB,IAAQ9gB,EACzD,GAAI8wB,EAAM60B,iBAAiB3lD,GAAI,CAC7BiqB,EAAO6G,EAAMooB,eAAel5C,GAC5B4lD,EAAO37B,EAAKtnB,KACZ4yC,EAAatrB,EAAKsrB,WAClB,K,CAKN,IAAKqQ,EACH,OAAO,EAGT,IAAK5lD,EAAI,EAAG8gB,EAAO8kC,EAAKn8C,OAAQzJ,EAAI8gB,IAAQ9gB,EAC1C2J,EAAU4rC,EAAWqG,0BAA0B57C,GACnB,UAAxB2J,EAAQq9C,cACVt5C,EAAMhD,KAAKgD,IAAIA,EAAK/D,EAAQswB,aAAe,EAAGtwB,EAAQs9C,kBAAoB,IAG9E,OAAOv5C,CACT,CAEAq4C,YAAAA,CAAaH,GACX,IAAIl4C,EAAM,EAEV,IAAK,IAAI1N,EAAI,EAAG8gB,EAAO8kC,EAAKn8C,OAAQzJ,EAAI8gB,IAAQ9gB,EAAG,CACjD,MAAM2J,EAAU9G,KAAK+4C,0BAA0B57C,GAC/C0N,EAAMhD,KAAKgD,IAAIA,EAAK/D,EAAQmoB,QAAU,EAAGnoB,EAAQu9C,aAAe,EAClE,CACA,OAAOx5C,CACT,CAMA64C,oBAAAA,CAAqBtlC,GACnB,IAAIkmC,EAAmB,EAEvB,IAAK,IAAInnD,EAAI,EAAGA,EAAIihB,IAAgBjhB,EAC9B6C,KAAKiuB,MAAM60B,iBAAiB3lD,KAC9BmnD,GAAoBtkD,KAAKqjD,eAAelmD,IAI5C,OAAOmnD,CACT,CAKAjB,cAAAA,CAAejlC,GACb,OAAOvW,KAAKgD,IAAIoS,GAAejd,KAAKiuB,MAAMnuB,KAAK+xB,SAASzT,GAAc5C,OAAQ,GAAI,EACpF,CAMAgoC,6BAAAA,GACE,OAAOxjD,KAAK0jD,qBAAqB1jD,KAAKiuB,MAAMnuB,KAAK+xB,SAASjrB,SAAW,CACvE,GACFnJ,EAAAA,GAAAA,GA1WqB8kD,GAA2B,KAElC,aAAW9kD,EAAAA,GAAAA,GAFJ8kD,GAA2B,WAO5B,CAChBvN,oBAAoB,EACpBC,gBAAiB,MACjB7oB,UAAW,CAETw3B,eAAe,EAEfK,cAAc,GAEhB13B,WAAY,CACVf,QAAS,CACP7rB,KAAM,SACNusB,WAAY,CAAC,gBAAiB,WAAY,cAAe,cAAe,aAAc,IAAK,IAAK,SAAU,cAAe,aAI7Hs1B,OAAQ,MAGRlrB,SAAU,EAGVirB,cAAe,IAGfhrB,OAAQ,OAGRysB,QAAS,EAETpwB,UAAW,OACXn1B,EAAAA,GAAAA,GAtCiB8kD,GAA2B,cAwCzB,CACnBt2B,YAAcxsB,GAAkB,YAATA,EACvBusB,WAAavsB,GAAkB,YAATA,IAAuBA,EAAKwxB,WAAW,gBAAkBxxB,EAAKwxB,WAAW,sBAC/FxzB,EAAAA,GAAAA,GA3CiB8kD,GAA2B,YAgD3B,CACjBpc,YAAa,EAGb/S,QAAS,CACPmxB,OAAQ,CACN7M,OAAQ,CACN8M,cAAAA,CAAev2B,GACb,MAAMnuB,EAAOmuB,EAAMnuB,MACZ43C,QAAQ,WAACrhB,EAAA,UAAYoC,EAAA,MAAWld,EAAK,gBAAEkpC,EAAA,aAAiBC,IAAiBz2B,EAAMs2B,OAAOz9C,QAC7F,OAAIhH,EAAK43C,OAAO9wC,QAAU9G,EAAK+xB,SAASjrB,OAC/B9G,EAAK43C,OAAO/pC,IAAI,CAACirC,EAAOz7C,KAC7B,MAAMiqB,EAAO6G,EAAMooB,eAAe,GAC5BnvC,EAAQkgB,EAAKsrB,WAAW3O,SAAS5mC,GAEvC,MAAO,CACL8yB,KAAM2oB,EACNpgB,UAAWtxB,EAAMyqB,gBACjBgzB,UAAWppC,EACX04B,QAAShmB,EAAMoyB,kBAAkBljD,GACjCynD,SAAU19C,EAAMkkC,WAChByZ,eAAgB39C,EAAMmkC,iBACtByZ,SAAU59C,EAAMokC,gBAChB/b,UAAWroB,EAAMkwB,YACjBiC,YAAanyB,EAAM0qB,YACnB6G,UAAWA,EACXpC,WAAYA,EACZquB,aAAcD,IAAoBC,GAAgBx9C,EAAMw9C,cAExD1lD,MAAO7B,KAIN,EACT,GAGF+B,OAAAA,CAAQhC,EAAG6nD,EAAYR,GACrBA,EAAOt2B,MAAM+2B,qBAAqBD,EAAW/lD,OAC7CulD,EAAOt2B,MAAM+gB,QACf,MCvHO,MAAMiW,WAAuB9Q,GA6B1Ce,UAAAA,GACEl1C,KAAK40C,qBAAsB,EAC3B50C,KAAK60C,oBAAqB,EAC1B4J,MAAMvJ,YACR,CAEAlG,MAAAA,CAAOlc,GACL,MAAM1L,EAAOpnB,KAAK2yC,aACX9qB,QAAS+Q,EAAM94B,KAAMunB,EAAS,GAAE,SAAE69B,GAAY99B,EAE/CE,EAAqBtnB,KAAKiuB,MAAM2rB,oBACtC,IAAI,MAACl2B,EAAA,MAAO1c,GAASmgB,GAAiCC,EAAMC,EAAQC,GAEpEtnB,KAAK00C,WAAahxB,EAClB1jB,KAAK20C,WAAa3tC,EAEduhB,GAAoBnB,KACtB1D,EAAQ,EACR1c,EAAQqgB,EAAOzgB,QAIjBgyB,EAAK2R,OAASvqC,KAAKiuB,MACnB2K,EAAK8R,cAAgB1qC,KAAKhB,MAC1B45B,EAAKusB,aAAeD,EAASC,WAC7BvsB,EAAKvR,OAASA,EAEd,MAAMvgB,EAAU9G,KAAK84C,6BAA6BhmB,GAC7C9yB,KAAK8G,QAAQ0sB,WAChB1sB,EAAQswB,YAAc,GAExBtwB,EAAQ+hC,QAAU7oC,KAAK8G,QAAQ+hC,QAC/B7oC,KAAKi6C,cAAcrhB,OAAMjsB,EAAW,CAClCy4C,UAAW99B,EACXxgB,WACCgsB,GAGH9yB,KAAK86C,eAAezzB,EAAQ3D,EAAO1c,EAAO8rB,EAC5C,CAEAgoB,cAAAA,CAAezzB,EAAQ3D,EAAO1c,EAAO8rB,GACnC,MAAM0jB,EAAiB,UAAT1jB,GACR,OAACrL,EAAA,OAAQC,EAAA,SAAQwsB,EAAA,SAAUgR,GAAYllD,KAAK2yC,aAC5C,cAACgH,EAAa,eAAED,GAAkB15C,KAAK65C,kBAAkBn2B,EAAOoP,GAChE+f,EAAQprB,EAAOK,KACfgrB,EAAQprB,EAAOI,MACf,SAACF,EAAA,QAAUihB,GAAW7oC,KAAK8G,QAC3Bu+C,EAAetjC,GAAS6F,GAAYA,EAAWrqB,OAAOkjB,kBACtD6kC,EAAetlD,KAAKiuB,MAAM2rB,qBAAuBpD,GAAkB,SAAT1jB,EAC1DnP,EAAMD,EAAQ1c,EACdu+C,EAAcl+B,EAAOzgB,OAC3B,IAAI4+C,EAAa9hC,EAAQ,GAAK1jB,KAAK+3C,UAAUr0B,EAAQ,GAErD,IAAK,IAAIvmB,EAAI,EAAGA,EAAIooD,IAAepoD,EAAG,CACpC,MAAMkrB,EAAQhB,EAAOlqB,GACf+uB,EAAao5B,EAAej9B,EAAQ,GAE1C,GAAIlrB,EAAIumB,GAASvmB,GAAKwmB,EAAK,CACzBuI,EAAWsU,MAAO,EAClB,Q,CAGF,MAAMJ,EAASpgC,KAAK+3C,UAAU56C,GACxBsoD,EAAWhpC,GAAc2jB,EAAO0S,IAChC5Q,EAAShW,EAAW2mB,GAASprB,EAAOS,iBAAiBkY,EAAOyS,GAAQ11C,GACpEglC,EAASjW,EAAW4mB,GAAS0D,GAASiP,EAAW/9B,EAAOi3B,eAAiBj3B,EAAOQ,iBAAiBgsB,EAAWl0C,KAAKixC,WAAWvpB,EAAQ0Y,EAAQ8T,GAAY9T,EAAO0S,GAAQ31C,GAE7K+uB,EAAWsU,KAAOxe,MAAMkgB,IAAWlgB,MAAMmgB,IAAWsjB,EACpDv5B,EAAW4d,KAAO3sC,EAAI,GAAK0K,KAAMqZ,IAAIkf,EAAOyS,GAAS2S,EAAW3S,IAAWwS,EACvExc,IACF3c,EAAWkU,OAASA,EACpBlU,EAAWunB,IAAMyR,EAASplD,KAAK3C,IAG7Bu8C,IACFxtB,EAAWplB,QAAU6yC,GAAiB35C,KAAK+4C,0BAA0B57C,EAAGkrB,EAAM8D,OAAS,SAAW2G,IAG/FwyB,GACHtlD,KAAKi6C,cAAc5xB,EAAOlrB,EAAG+uB,EAAY4G,GAG3C0yB,EAAaplB,CACf,CACF,CAKAsY,cAAAA,GACE,MAAMtxB,EAAOpnB,KAAK2yC,YACZ9qB,EAAUT,EAAKS,QACfgI,EAAShI,EAAQ/gB,SAAW+gB,EAAQ/gB,QAAQswB,aAAe,EAC3Dt3B,EAAOsnB,EAAKtnB,MAAQ,GAC1B,IAAKA,EAAK8G,OACR,OAAOipB,EAET,MAAM8Q,EAAa7gC,EAAK,GAAGwI,KAAKtI,KAAK+4C,0BAA0B,IACzD2M,EAAY5lD,EAAKA,EAAK8G,OAAS,GAAG0B,KAAKtI,KAAK+4C,0BAA0Bj5C,EAAK8G,OAAS,IAC1F,OAAOiB,KAAKgD,IAAIglB,EAAQ8Q,EAAY+kB,GAAa,CACnD,CAEA1Y,IAAAA,GACE,MAAM5lB,EAAOpnB,KAAK2yC,YAClBvrB,EAAKS,QAAQ89B,oBAAoB3lD,KAAKiuB,MAAMwd,UAAWrkB,EAAKK,OAAOK,MACnE22B,MAAMzR,MACR,GACFvvC,EAAAA,GAAAA,GAzIqBwnD,GAAuB,KAE9B,SAAOxnD,EAAAA,GAAAA,GAFAwnD,GAAuB,WAOxB,CAChBjQ,mBAAoB,OACpBC,gBAAiB,QAEjBzhB,UAAU,EACV5L,UAAU,KACVnqB,EAAAA,GAAAA,GAbiBwnD,GAAuB,YAkBvB,CACjB1xB,OAAQ,CACN4tB,QAAS,CACPxhD,KAAM,YAERyhD,QAAS,CACPzhD,KAAM,aC1BC,MAAMimD,WAA4BzR,GAoF/Ct3C,WAAAA,CAAYoxB,EAAO7P,GACjBqgC,MAAMxwB,EAAO7P,GAEbpe,KAAKwiD,iBAAc71C,EACnB3M,KAAKyiD,iBAAc91C,CACrB,CAEAgsC,gBAAAA,CAAiB35C,GACf,MAAMooB,EAAOpnB,KAAK2yC,YACZ1kB,EAAQjuB,KAAKiuB,MACbypB,EAASzpB,EAAMnuB,KAAK43C,QAAU,GAC9B95C,EAAQ8vB,GAAatG,EAAKO,QAAQ3oB,GAAO/B,EAAGgxB,EAAMnnB,QAAQomB,QAEhE,MAAO,CACL0rB,MAAOlB,EAAO14C,IAAU,GACxBpB,QAEJ,CAEA25C,eAAAA,CAAgBnwB,EAAMtnB,EAAM4jB,EAAO1c,GACjC,OAAOk5B,GAA4B2lB,KAAK7lD,KAAjCkgC,CAAuC9Y,EAAMtnB,EAAM4jB,EAAO1c,EACnE,CAEAgoC,MAAAA,CAAOlc,GACL,MAAMiwB,EAAO/iD,KAAK2yC,YAAY7yC,KAE9BE,KAAK8lD,gBACL9lD,KAAK86C,eAAeiI,EAAM,EAAGA,EAAKn8C,OAAQksB,EAC5C,CAKAslB,SAAAA,GACE,MAAMhxB,EAAOpnB,KAAK2yC,YACZplC,EAAQ,CAACzC,IAAKvN,OAAOkjB,kBAAmB5V,IAAKtN,OAAOy0C,mBAgB1D,OAdA5qB,EAAKtnB,KAAKulB,QAAQ,CAACue,EAAS5kC,KAC1B,MAAMohC,EAASpgC,KAAK+3C,UAAU/4C,GAAO/B,GAEhC+kB,MAAMoe,IAAWpgC,KAAKiuB,MAAMoyB,kBAAkBrhD,KAC7CohC,EAAS7yB,EAAMzC,MACjByC,EAAMzC,IAAMs1B,GAGVA,EAAS7yB,EAAM1C,MACjB0C,EAAM1C,IAAMu1B,MAKX7yB,CACT,CAKAu4C,aAAAA,GACE,MAAM73B,EAAQjuB,KAAKiuB,MACbwd,EAAYxd,EAAMwd,UAClBnT,EAAOrK,EAAMnnB,QACbi/C,EAAUl+C,KAAKiD,IAAI2gC,EAAUzkB,MAAQykB,EAAU1kB,KAAM0kB,EAAU3e,OAAS2e,EAAU5e,KAElF41B,EAAc56C,KAAKgD,IAAIk7C,EAAU,EAAG,GACpCvD,EAAc36C,KAAKgD,IAAIytB,EAAK0tB,iBAAmBvD,EAAe,IAAQnqB,EAAK0tB,iBAAoB,EAAG,GAClGzC,GAAgBd,EAAcD,GAAev0B,EAAMg4B,yBAEzDjmD,KAAKyiD,YAAcA,EAAec,EAAevjD,KAAKhB,MACtDgB,KAAKwiD,YAAcxiD,KAAKyiD,YAAcc,CACxC,CAEAzI,cAAAA,CAAeiI,EAAMr/B,EAAO1c,EAAO8rB,GACjC,MAAM0jB,EAAiB,UAAT1jB,EACR7E,EAAQjuB,KAAKiuB,MACbqK,EAAOrK,EAAMnnB,QACbg9C,EAAgBxrB,EAAKlM,UACrBkH,EAAQtzB,KAAK2yC,YAAYyD,OACzB2N,EAAUzwB,EAAM4yB,QAChBlC,EAAU1wB,EAAM6yB,QAChBC,EAAoB9yB,EAAM+yB,cAAc,GAAK,GAAMhmC,GACzD,IACIljB,EADA8lB,EAAQmjC,EAGZ,MAAME,EAAe,IAAMtmD,KAAKumD,uBAEhC,IAAKppD,EAAI,EAAGA,EAAIumB,IAASvmB,EACvB8lB,GAASjjB,KAAKwmD,cAAcrpD,EAAG21B,EAAMwzB,GAEvC,IAAKnpD,EAAIumB,EAAOvmB,EAAIumB,EAAQ1c,EAAO7J,IAAK,CACtC,MAAM05B,EAAMksB,EAAK5lD,GACjB,IAAIwkD,EAAa1+B,EACb2+B,EAAW3+B,EAAQjjB,KAAKwmD,cAAcrpD,EAAG21B,EAAMwzB,GAC/C7D,EAAcx0B,EAAMoyB,kBAAkBljD,GAAKm2B,EAAMmzB,8BAA8BzmD,KAAK+3C,UAAU56C,GAAGF,GAAK,EAC1GgmB,EAAQ2+B,EAEJpL,IACEsN,EAAcG,eAChBxB,EAAc,GAEZqB,EAAcF,gBAChBjC,EAAaC,EAAWwE,IAI5B,MAAMl6B,EAAa,CACjB1d,EAAGu1C,EACH1kC,EAAG2kC,EACHxB,YAAa,EACbC,cACAd,aACAC,WACA96C,QAAS9G,KAAK+4C,0BAA0B57C,EAAG05B,EAAI1K,OAAS,SAAW2G,IAGrE9yB,KAAKi6C,cAAcpjB,EAAK15B,EAAG+uB,EAAY4G,EACzC,CACF,CAEAyzB,oBAAAA,GACE,MAAMn/B,EAAOpnB,KAAK2yC,YAClB,IAAI3rC,EAAQ,EAQZ,OANAogB,EAAKtnB,KAAKulB,QAAQ,CAACue,EAAS5kC,MACrBgjB,MAAMhiB,KAAK+3C,UAAU/4C,GAAO/B,IAAM+C,KAAKiuB,MAAMoyB,kBAAkBrhD,IAClEgI,MAIGA,CACT,CAKAw/C,aAAAA,CAAcxnD,EAAO8zB,EAAMwzB,GACzB,OAAOtmD,KAAKiuB,MAAMoyB,kBAAkBrhD,GAChCsjB,GAAUtiB,KAAK+4C,0BAA0B/5C,EAAO8zB,GAAM7P,OAASqjC,GAC/D,CACN,GACF7oD,EAAAA,GAAAA,GA/NqBmoD,GAA4B,KAEnC,cAAYnoD,EAAAA,GAAAA,GAFLmoD,GAA4B,WAO7B,CAChB3Q,gBAAiB,MACjB7oB,UAAW,CACTw3B,eAAe,EACfK,cAAc,GAEhB13B,WAAY,CACVf,QAAS,CACP7rB,KAAM,SACNusB,WAAY,CAAC,IAAK,IAAK,aAAc,WAAY,cAAe,iBAGpE0G,UAAW,IACX+uB,WAAY,KACZlkD,EAAAA,GAAAA,GArBiBmoD,GAA4B,YA0B5B,CACjBzf,YAAa,EAEb/S,QAAS,CACPmxB,OAAQ,CACN7M,OAAQ,CACN8M,cAAAA,CAAev2B,GACb,MAAMnuB,EAAOmuB,EAAMnuB,KACnB,GAAIA,EAAK43C,OAAO9wC,QAAU9G,EAAK+xB,SAASjrB,OAAQ,CAC9C,MAAO8wC,QAAQ,WAACrhB,EAAA,MAAY9a,IAAU0S,EAAMs2B,OAAOz9C,QAEnD,OAAOhH,EAAK43C,OAAO/pC,IAAI,CAACirC,EAAOz7C,KAC7B,MAAMiqB,EAAO6G,EAAMooB,eAAe,GAC5BnvC,EAAQkgB,EAAKsrB,WAAW3O,SAAS5mC,GAEvC,MAAO,CACL8yB,KAAM2oB,EACNpgB,UAAWtxB,EAAMyqB,gBACjB0H,YAAanyB,EAAM0qB,YACnB+yB,UAAWppC,EACXgU,UAAWroB,EAAMkwB,YACjBf,WAAYA,EACZ4d,QAAShmB,EAAMoyB,kBAAkBljD,GAGjC6B,MAAO7B,I,CAIb,MAAO,EACT,GAGF+B,OAAAA,CAAQhC,EAAG6nD,EAAYR,GACrBA,EAAOt2B,MAAM+2B,qBAAqBD,EAAW/lD,OAC7CulD,EAAOt2B,MAAM+gB,QACf,IAIJzb,OAAQ,CACNt2B,EAAG,CACD0C,KAAM,eACN+mD,WAAY,CACV13B,SAAS,GAEXE,aAAa,EACbI,KAAM,CACJq3B,UAAU,GAEZC,YAAa,CACX53B,SAAS,GAEX2yB,WAAY,MC/EL,MAAMkF,WAAsBtE,KAoB3C9kD,EAAAA,GAAAA,GApBqBopD,GAAsB,KAE7B,QAAMppD,EAAAA,GAAAA,GAFCopD,GAAsB,WAOvB,CAEhBrF,OAAQ,EAGRlrB,SAAU,EAGVirB,cAAe,IAGfhrB,OAAQ,SClBG,MAAMuwB,WAAwB3S,GAmC3CwE,gBAAAA,CAAiB35C,GACf,MAAM0oB,EAAS1nB,KAAK2yC,YAAYjrB,OAC1B0Y,EAASpgC,KAAK+3C,UAAU/4C,GAE9B,MAAO,CACL45C,MAAOlxB,EAAOiwB,YAAY34C,GAC1BpB,MAAO,GAAK8pB,EAAOmxB,iBAAiBzY,EAAO1Y,EAAOI,OAEtD,CAEAyvB,eAAAA,CAAgBnwB,EAAMtnB,EAAM4jB,EAAO1c,GACjC,OAAOk5B,GAA4B2lB,KAAK7lD,KAAjCkgC,CAAuC9Y,EAAMtnB,EAAM4jB,EAAO1c,EACnE,CAEAgoC,MAAAA,CAAOlc,GACL,MAAM1L,EAAOpnB,KAAK2yC,YACZ/Z,EAAOxR,EAAKS,QACZR,EAASD,EAAKtnB,MAAQ,GACtB43C,EAAStwB,EAAKK,OAAOkwB,YAK3B,GAFA/e,EAAKvR,OAASA,EAED,WAATyL,EAAmB,CACrB,MAAMhsB,EAAU9G,KAAK84C,6BAA6BhmB,GAC7C9yB,KAAK8G,QAAQ0sB,WAChB1sB,EAAQswB,YAAc,GAGxB,MAAMlL,EAAa,CACjB+d,OAAO,EACPG,UAAWsN,EAAO9wC,SAAWygB,EAAOzgB,OACpCE,WAGF9G,KAAKi6C,cAAcrhB,OAAMjsB,EAAWuf,EAAY4G,E,CAIlD9yB,KAAK86C,eAAezzB,EAAQ,EAAGA,EAAOzgB,OAAQksB,EAChD,CAEAgoB,cAAAA,CAAezzB,EAAQ3D,EAAO1c,EAAO8rB,GACnC,MAAMQ,EAAQtzB,KAAK2yC,YAAYyD,OACzBI,EAAiB,UAAT1jB,EAEd,IAAK,IAAI31B,EAAIumB,EAAOvmB,EAAIumB,EAAQ1c,EAAO7J,IAAK,CAC1C,MAAMkrB,EAAQhB,EAAOlqB,GACf2J,EAAU9G,KAAK+4C,0BAA0B57C,EAAGkrB,EAAM8D,OAAS,SAAW2G,GACtEi0B,EAAgBzzB,EAAM0zB,yBAAyB7pD,EAAG6C,KAAK+3C,UAAU56C,GAAGF,GAEpEuR,EAAIgoC,EAAQljB,EAAM4yB,QAAUa,EAAcv4C,EAC1C6Q,EAAIm3B,EAAQljB,EAAM6yB,QAAUY,EAAc1nC,EAE1C6M,EAAa,CACjB1d,IACA6Q,IACA4D,MAAO8jC,EAAc9jC,MACrBud,KAAMxe,MAAMxT,IAAMwT,MAAM3C,GACxBvY,WAGF9G,KAAKi6C,cAAc5xB,EAAOlrB,EAAG+uB,EAAY4G,EAC3C,CACF,GACFr1B,EAAAA,GAAAA,GApGqBqpD,GAAwB,KAE/B,UAAQrpD,EAAAA,GAAAA,GAFDqpD,GAAwB,WAOzB,CAChB9R,mBAAoB,OACpBC,gBAAiB,QACjBriB,UAAW,IACXY,UAAU,EACVtB,SAAU,CACR0G,KAAM,CACJzB,KAAM,aAGV15B,EAAAA,GAAAA,GAjBiBqpD,GAAwB,YAsBxB,CACjB3gB,YAAa,EAEb5S,OAAQ,CACNt2B,EAAG,CACD0C,KAAM,mBCzBC,MAAMsnD,WAA0B9S,GAoC7CwE,gBAAAA,CAAiB35C,GACf,MAAMooB,EAAOpnB,KAAK2yC,YACZ+E,EAAS13C,KAAKiuB,MAAMnuB,KAAK43C,QAAU,IACnC,OAAClvB,EAAA,OAAQC,GAAUrB,EACnBgZ,EAASpgC,KAAK+3C,UAAU/4C,GACxBwP,EAAIga,EAAOqwB,iBAAiBzY,EAAO5xB,GACnC6Q,EAAIoJ,EAAOowB,iBAAiBzY,EAAO/gB,GAEzC,MAAO,CACLu5B,MAAOlB,EAAO14C,IAAU,GACxBpB,MAAO,IAAM4Q,EAAI,KAAO6Q,EAAI,IAEhC,CAEA2vB,MAAAA,CAAOlc,GACL,MAAM1L,EAAOpnB,KAAK2yC,aACX7yC,KAAMunB,EAAS,IAAMD,EAEtBE,EAAqBtnB,KAAKiuB,MAAM2rB,oBACtC,IAAI,MAACl2B,EAAA,MAAO1c,GAASmgB,GAAiCC,EAAMC,EAAQC,GAUpE,GARAtnB,KAAK00C,WAAahxB,EAClB1jB,KAAK20C,WAAa3tC,EAEduhB,GAAoBnB,KACtB1D,EAAQ,EACR1c,EAAQqgB,EAAOzgB,QAGb5G,KAAK8G,QAAQ0sB,SAAU,CAGpBxzB,KAAKg1C,oBACRh1C,KAAKo1C,cAEP,MAAOvtB,QAAS+Q,EAAA,SAAMssB,GAAY99B,EAGlCwR,EAAK2R,OAASvqC,KAAKiuB,MACnB2K,EAAK8R,cAAgB1qC,KAAKhB,MAC1B45B,EAAKusB,aAAeD,EAASC,WAC7BvsB,EAAKvR,OAASA,EAEd,MAAMvgB,EAAU9G,KAAK84C,6BAA6BhmB,GAClDhsB,EAAQ+hC,QAAU7oC,KAAK8G,QAAQ+hC,QAC/B7oC,KAAKi6C,cAAcrhB,OAAMjsB,EAAW,CAClCy4C,UAAW99B,EACXxgB,WACCgsB,EACL,MAAW9yB,KAAKg1C,4BAEP5tB,EAAKS,QACZ7nB,KAAKg1C,oBAAqB,GAI5Bh1C,KAAK86C,eAAezzB,EAAQ3D,EAAO1c,EAAO8rB,EAC5C,CAEAsiB,WAAAA,GACE,MAAM,SAAC5hB,GAAYxzB,KAAK8G,SAEnB9G,KAAKg1C,oBAAsBxhB,IAC9BxzB,KAAKg1C,mBAAqBh1C,KAAKiuB,MAAMi5B,SAASC,WAAW,SAG3D1I,MAAMrJ,aACR,CAEA0F,cAAAA,CAAezzB,EAAQ3D,EAAO1c,EAAO8rB,GACnC,MAAM0jB,EAAiB,UAAT1jB,GACR,OAACrL,EAAA,OAAQC,EAAA,SAAQwsB,EAAA,SAAUgR,GAAYllD,KAAK2yC,YAC5CmH,EAAY95C,KAAK+4C,0BAA0Br1B,EAAOoP,GAClD6mB,EAAgB35C,KAAKy5C,iBAAiBK,GACtCJ,EAAiB15C,KAAK05C,eAAe5mB,EAAM6mB,GAC3C9G,EAAQprB,EAAOK,KACfgrB,EAAQprB,EAAOI,MACf,SAACF,EAAA,QAAUihB,GAAW7oC,KAAK8G,QAC3Bu+C,EAAetjC,GAAS6F,GAAYA,EAAWrqB,OAAOkjB,kBACtD6kC,EAAetlD,KAAKiuB,MAAM2rB,qBAAuBpD,GAAkB,SAAT1jB,EAChE,IAAI0yB,EAAa9hC,EAAQ,GAAK1jB,KAAK+3C,UAAUr0B,EAAQ,GAErD,IAAK,IAAIvmB,EAAIumB,EAAOvmB,EAAIumB,EAAQ1c,IAAS7J,EAAG,CAC1C,MAAMkrB,EAAQhB,EAAOlqB,GACfijC,EAASpgC,KAAK+3C,UAAU56C,GACxB+uB,EAAao5B,EAAej9B,EAAQ,GACpCo9B,EAAWhpC,GAAc2jB,EAAO0S,IAChC5Q,EAAShW,EAAW2mB,GAASprB,EAAOS,iBAAiBkY,EAAOyS,GAAQ11C,GACpEglC,EAASjW,EAAW4mB,GAAS0D,GAASiP,EAAW/9B,EAAOi3B,eAAiBj3B,EAAOQ,iBAAiBgsB,EAAWl0C,KAAKixC,WAAWvpB,EAAQ0Y,EAAQ8T,GAAY9T,EAAO0S,GAAQ31C,GAE7K+uB,EAAWsU,KAAOxe,MAAMkgB,IAAWlgB,MAAMmgB,IAAWsjB,EACpDv5B,EAAW4d,KAAO3sC,EAAI,GAAK0K,KAAMqZ,IAAIkf,EAAOyS,GAAS2S,EAAW3S,IAAWwS,EACvExc,IACF3c,EAAWkU,OAASA,EACpBlU,EAAWunB,IAAMyR,EAASplD,KAAK3C,IAG7Bu8C,IACFxtB,EAAWplB,QAAU6yC,GAAiB35C,KAAK+4C,0BAA0B57C,EAAGkrB,EAAM8D,OAAS,SAAW2G,IAG/FwyB,GACHtlD,KAAKi6C,cAAc5xB,EAAOlrB,EAAG+uB,EAAY4G,GAG3C0yB,EAAaplB,CACf,CAEApgC,KAAKg6C,oBAAoBL,EAAe7mB,EAAMgnB,EAChD,CAKApB,cAAAA,GACE,MAAMtxB,EAAOpnB,KAAK2yC,YACZ7yC,EAAOsnB,EAAKtnB,MAAQ,GAE1B,IAAKE,KAAK8G,QAAQ0sB,SAAU,CAC1B,IAAI3oB,EAAM,EACV,IAAK,IAAI1N,EAAI2C,EAAK8G,OAAS,EAAGzJ,GAAK,IAAKA,EACtC0N,EAAMhD,KAAKgD,IAAIA,EAAK/K,EAAK3C,GAAGmL,KAAKtI,KAAK+4C,0BAA0B57C,IAAM,GAExE,OAAO0N,EAAM,GAAKA,C,CAGpB,MAAMgd,EAAUT,EAAKS,QACfgI,EAAShI,EAAQ/gB,SAAW+gB,EAAQ/gB,QAAQswB,aAAe,EAEjE,IAAKt3B,EAAK8G,OACR,OAAOipB,EAGT,MAAM8Q,EAAa7gC,EAAK,GAAGwI,KAAKtI,KAAK+4C,0BAA0B,IACzD2M,EAAY5lD,EAAKA,EAAK8G,OAAS,GAAG0B,KAAKtI,KAAK+4C,0BAA0Bj5C,EAAK8G,OAAS,IAC1F,OAAOiB,KAAKgD,IAAIglB,EAAQ8Q,EAAY+kB,GAAa,CACnD,GACFjoD,EAAAA,GAAAA,GA7KqBwpD,GAA0B,KAEjC,YAAUxpD,EAAAA,GAAAA,GAFHwpD,GAA0B,WAO3B,CAChBjS,oBAAoB,EACpBC,gBAAiB,QACjBzhB,UAAU,EACV2D,MAAM,KACN15B,EAAAA,GAAAA,GAZiBwpD,GAA0B,YAiB1B,CAEjBp0B,YAAa,CACXC,KAAM,SAGRS,OAAQ,CACN/kB,EAAG,CACD7O,KAAM,UAER0f,EAAG,CACD1f,KAAM,aC+Bd,SAASynD,KACP,MAAM,IAAIloB,MAAM,kFAClB,CAQA,MAAMmoB,GAYJ,eAAO3zB,CACL4zB,GAEA5pD,OAAOkd,OAAOysC,GAAgBvqD,UAAWwqD,EAC3C,CAIAzqD,WAAAA,CAAYiK,IAAqBrJ,EAAAA,GAAAA,GAAA,uBAC/BuC,KAAK8G,QAAUA,GAAW,CAAC,CAC7B,CAGAygD,IAAAA,GAAQ,CAERC,OAAAA,GACE,OAAOJ,IACT,CAEA/mB,KAAAA,GACE,OAAO+mB,IACT,CAEAx5B,MAAAA,GACE,OAAOw5B,IACT,CAEAprB,GAAAA,GACE,OAAOorB,IACT,CAEAK,IAAAA,GACE,OAAOL,IACT,CAEAM,OAAAA,GACE,OAAON,IACT,CAEAO,KAAAA,GACE,OAAOP,IACT,EAGF,IAAAQ,GAAe,CACbC,MAAOR,IC9GT,SAASS,GAAaC,EAASjgC,EAAMlqB,EAAOm1B,GAC1C,MAAM,WAAC2f,EAAU,KAAE5yC,EAAA,QAAM0nB,GAAWugC,EAC9BtgC,EAASirB,EAAWC,YAAYlrB,OAChCG,EAAWmgC,EAAQlgC,SAAUkgC,EAAQlgC,QAAQ/gB,QAAUihD,EAAQlgC,QAAQ/gB,QAAQ8gB,SAAkB,KAEvG,GAAIH,GAAUK,IAASL,EAAOK,MAAiB,MAATA,GAAgBN,GAAW1nB,EAAK8G,OAAQ,CAC5E,MAAMohD,EAAevgC,EAAOwgC,eAAiBpjC,GAAgBH,GAC7D,IAAKqO,EAAW,CACd,MAAMrR,EAASsmC,EAAaloD,EAAMgoB,EAAMlqB,GACxC,GAAIgqB,EAAU,CACZ,MAAM,OAACF,GAAUgrB,EAAWC,aACtB,QAAChrB,GAAWogC,EAEZ5/B,EAAuBR,EAC1BhL,MAAM,EAAG+E,EAAO+C,GAAK,GACrB5G,UACAuK,UACCC,IAAU5L,GAAc4L,EAAMX,EAAOI,QACzCpG,EAAO+C,IAAM5c,KAAKgD,IAAI,EAAGsd,GAEzB,MAAMG,EAAuBX,EAC1BhL,MAAM+E,EAAO8C,IACb4D,UACCC,IAAU5L,GAAc4L,EAAMX,EAAOI,QACzCpG,EAAO8C,IAAM3c,KAAKgD,IAAI,EAAGyd,E,CAE3B,OAAO5G,C,CACF,GAAIgxB,EAAW+B,eAAgB,CAIpC,MAAMzQ,EAAKlkC,EAAK,GACVyN,EAA+B,oBAAhBy2B,EAAGkkB,UAA2BlkB,EAAGkkB,SAASpgC,GAC/D,GAAIva,EAAO,CACT,MAAMmW,EAAQskC,EAAaloD,EAAMgoB,EAAMlqB,EAAQ2P,GACzCoW,EAAMqkC,EAAaloD,EAAMgoB,EAAMlqB,EAAQ2P,GAC7C,MAAO,CAACkX,GAAIf,EAAMe,GAAID,GAAIb,EAAIa,G,GAKpC,MAAO,CAACC,GAAI,EAAGD,GAAI1kB,EAAK8G,OAAS,EACnC,CAUA,SAASuhD,GAAyBl6B,EAAOnG,EAAMsgC,EAAUC,EAASt1B,GAChE,MAAMge,EAAW9iB,EAAMq6B,+BACjB1qD,EAAQwqD,EAAStgC,GACvB,IAAK,IAAI3qB,EAAI,EAAG8gB,EAAO8yB,EAASnqC,OAAQzJ,EAAI8gB,IAAQ9gB,EAAG,CACrD,MAAM,MAAC6B,EAAA,KAAOc,GAAQixC,EAAS5zC,IACzB,GAACsnB,EAAA,GAAID,GAAMsjC,GAAa/W,EAAS5zC,GAAI2qB,EAAMlqB,EAAOm1B,GACxD,IAAK,IAAI1Z,EAAIoL,EAAIpL,GAAKmL,IAAMnL,EAAG,CAC7B,MAAMuqB,EAAU9jC,EAAKuZ,GAChBuqB,EAAQpD,MACX6nB,EAAQzkB,EAAS5kC,EAAOqa,EAE5B,CACF,CACF,CAOA,SAASkvC,GAAyBzgC,GAChC,MAAM0gC,GAA8B,IAAvB1gC,EAAKpJ,QAAQ,KACpB+pC,GAA8B,IAAvB3gC,EAAKpJ,QAAQ,KAE1B,OAAO,SAAS2E,EAAKC,GACnB,MAAMolC,EAASF,EAAO3gD,KAAKqZ,IAAImC,EAAI7U,EAAI8U,EAAI9U,GAAK,EAC1Cm6C,EAASF,EAAO5gD,KAAKqZ,IAAImC,EAAIhE,EAAIiE,EAAIjE,GAAK,EAChD,OAAOxX,KAAK8Z,KAAK9Z,KAAKqS,IAAIwuC,EAAQ,GAAK7gD,KAAKqS,IAAIyuC,EAAQ,GAC1D,CACF,CAWA,SAASC,GAAkB36B,EAAOm6B,EAAUtgC,EAAM+gC,EAAkB71B,GAClE,MAAMlN,EAAQ,GAEd,IAAKkN,IAAqB/E,EAAM66B,cAAcV,GAC5C,OAAOtiC,EAGT,MAAMijC,EAAiB,SAASnlB,EAASxlB,EAAcpf,IAChDg0B,GAAqBsE,GAAesM,EAAS3V,EAAMwd,UAAW,KAG/D7H,EAAQolB,QAAQZ,EAAS55C,EAAG45C,EAAS/oC,EAAGwpC,IAC1C/iC,EAAMpG,KAAK,CAACkkB,UAASxlB,eAAcpf,SAEvC,EAGA,OADAmpD,GAAyBl6B,EAAOnG,EAAMsgC,EAAUW,GAAgB,GACzDjjC,CACT,CAUA,SAASmjC,GAAsBh7B,EAAOm6B,EAAUtgC,EAAM+gC,GACpD,IAAI/iC,EAAQ,GAEZ,SAASijC,EAAenlB,EAASxlB,EAAcpf,GAC7C,MAAM,WAAC2iD,EAAA,SAAYC,GAAYhe,EAAQslB,SAAS,CAAC,aAAc,YAAaL,IACtE,MAAC5lC,GAASN,GAAkBihB,EAAS,CAACp1B,EAAG45C,EAAS55C,EAAG6Q,EAAG+oC,EAAS/oC,IAEnEoE,GAAcR,EAAO0+B,EAAYC,IACnC97B,EAAMpG,KAAK,CAACkkB,UAASxlB,eAAcpf,SAEvC,CAGA,OADAmpD,GAAyBl6B,EAAOnG,EAAMsgC,EAAUW,GACzCjjC,CACT,CAYA,SAASqjC,GAAyBl7B,EAAOm6B,EAAUtgC,EAAMiL,EAAW81B,EAAkB71B,GACpF,IAAIlN,EAAQ,GACZ,MAAMsjC,EAAiBb,GAAyBzgC,GAChD,IAAIuhC,EAAc9rD,OAAOkjB,kBAEzB,SAASsoC,EAAenlB,EAASxlB,EAAcpf,GAC7C,MAAMgqD,EAAUplB,EAAQolB,QAAQZ,EAAS55C,EAAG45C,EAAS/oC,EAAGwpC,GACxD,GAAI91B,IAAci2B,EAChB,OAGF,MAAM9J,EAAStb,EAAQ0lB,eAAeT,GAChCU,IAAgBv2B,GAAoB/E,EAAM66B,cAAc5J,GAC9D,IAAKqK,IAAgBP,EACnB,OAGF,MAAM7lC,EAAWimC,EAAehB,EAAUlJ,GACtC/7B,EAAWkmC,GACbvjC,EAAQ,CAAC,CAAC8d,UAASxlB,eAAcpf,UACjCqqD,EAAclmC,GACLA,IAAakmC,GAEtBvjC,EAAMpG,KAAK,CAACkkB,UAASxlB,eAAcpf,SAEvC,CAGA,OADAmpD,GAAyBl6B,EAAOnG,EAAMsgC,EAAUW,GACzCjjC,CACT,CAYA,SAAS0jC,GAAgBv7B,EAAOm6B,EAAUtgC,EAAMiL,EAAW81B,EAAkB71B,GAC3E,OAAKA,GAAqB/E,EAAM66B,cAAcV,GAI9B,MAATtgC,GAAiBiL,EAEpBo2B,GAAyBl7B,EAAOm6B,EAAUtgC,EAAMiL,EAAW81B,EAAkB71B,GAD7Ei2B,GAAsBh7B,EAAOm6B,EAAUtgC,EAAM+gC,GAJxC,EAMX,CAWA,SAASY,GAAax7B,EAAOm6B,EAAUtgC,EAAMiL,EAAW81B,GACtD,MAAM/iC,EAAQ,GACR4jC,EAAuB,MAAT5hC,EAAe,WAAa,WAChD,IAAI6hC,GAAiB,EAWrB,OATAxB,GAAyBl6B,EAAOnG,EAAMsgC,EAAU,CAACxkB,EAASxlB,EAAcpf,KAClE4kC,EAAQ8lB,IAAgB9lB,EAAQ8lB,GAAatB,EAAStgC,GAAO+gC,KAC/D/iC,EAAMpG,KAAK,CAACkkB,UAASxlB,eAAcpf,UACnC2qD,EAAiBA,GAAkB/lB,EAAQolB,QAAQZ,EAAS55C,EAAG45C,EAAS/oC,EAAGwpC,MAM3E91B,IAAc42B,EACT,GAEF7jC,CACT,CAMA,IAAA8jC,GAAe,CAEbzB,4BAGA0B,MAAO,CAYL7qD,KAAAA,CAAMivB,EAAO/wB,EAAG4J,EAAS+hD,GACvB,MAAMT,EAAWnjB,GAAoB/nC,EAAG+wB,GAElCnG,EAAOhhB,EAAQghB,MAAQ,IACvBkL,EAAmBlsB,EAAQksB,mBAAoB,EAC/ClN,EAAQhf,EAAQisB,UAClB61B,GAAkB36B,EAAOm6B,EAAUtgC,EAAM+gC,EAAkB71B,GAC3Dw2B,GAAgBv7B,EAAOm6B,EAAUtgC,GAAM,EAAO+gC,EAAkB71B,GAC9Dd,EAAW,GAEjB,OAAKpM,EAAMlf,QAIXqnB,EAAMq6B,+BAA+BjjC,QAAS+B,IAC5C,MAAMpoB,EAAQ8mB,EAAM,GAAG9mB,MACjB4kC,EAAUxc,EAAKtnB,KAAKd,GAGtB4kC,IAAYA,EAAQpD,MACtBtO,EAASxS,KAAK,CAACkkB,UAASxlB,aAAcgJ,EAAKpoB,MAAOA,YAI/CkzB,GAbE,EAcX,EAYArK,OAAAA,CAAQoG,EAAO/wB,EAAG4J,EAAS+hD,GACzB,MAAMT,EAAWnjB,GAAoB/nC,EAAG+wB,GAClCnG,EAAOhhB,EAAQghB,MAAQ,KACvBkL,EAAmBlsB,EAAQksB,mBAAoB,EACrD,IAAIlN,EAAQhf,EAAQisB,UAChB61B,GAAkB36B,EAAOm6B,EAAUtgC,EAAM+gC,EAAkB71B,GAC7Dw2B,GAAgBv7B,EAAOm6B,EAAUtgC,GAAM,EAAO+gC,EAAkB71B,GAElE,GAAIlN,EAAMlf,OAAS,EAAG,CACpB,MAAMwX,EAAe0H,EAAM,GAAG1H,aACxBte,EAAOmuB,EAAMooB,eAAej4B,GAActe,KAChDgmB,EAAQ,GACR,IAAK,IAAI3oB,EAAI,EAAGA,EAAI2C,EAAK8G,SAAUzJ,EACjC2oB,EAAMpG,KAAK,CAACkkB,QAAS9jC,EAAK3C,GAAIihB,eAAcpf,MAAO7B,G,CAIvD,OAAO2oB,CACT,EAYAuC,KAAAA,CAAM4F,EAAO/wB,EAAG4J,EAAS+hD,GACvB,MAAMT,EAAWnjB,GAAoB/nC,EAAG+wB,GAClCnG,EAAOhhB,EAAQghB,MAAQ,KACvBkL,EAAmBlsB,EAAQksB,mBAAoB,EACrD,OAAO41B,GAAkB36B,EAAOm6B,EAAUtgC,EAAM+gC,EAAkB71B,EACpE,EAWA82B,OAAAA,CAAQ77B,EAAO/wB,EAAG4J,EAAS+hD,GACzB,MAAMT,EAAWnjB,GAAoB/nC,EAAG+wB,GAClCnG,EAAOhhB,EAAQghB,MAAQ,KACvBkL,EAAmBlsB,EAAQksB,mBAAoB,EACrD,OAAOw2B,GAAgBv7B,EAAOm6B,EAAUtgC,EAAMhhB,EAAQisB,UAAW81B,EAAkB71B,EACrF,EAWAxkB,CAAAA,CAAEyf,EAAO/wB,EAAG4J,EAAS+hD,GACnB,MAAMT,EAAWnjB,GAAoB/nC,EAAG+wB,GACxC,OAAOw7B,GAAax7B,EAAOm6B,EAAU,IAAKthD,EAAQisB,UAAW81B,EAC/D,EAWAxpC,CAAAA,CAAE4O,EAAO/wB,EAAG4J,EAAS+hD,GACnB,MAAMT,EAAWnjB,GAAoB/nC,EAAG+wB,GACxC,OAAOw7B,GAAax7B,EAAOm6B,EAAU,IAAKthD,EAAQisB,UAAW81B,EAC/D,ICzXJ,MAAMkB,GAAmB,CAAC,OAAQ,MAAO,QAAS,UAElD,SAASC,GAAiB5nC,EAAOgmC,GAC/B,OAAOhmC,EAAMmd,OAAO90B,GAAKA,EAAE65B,MAAQ8jB,EACrC,CAEA,SAAS6B,GAA4B7nC,EAAO0F,GAC1C,OAAO1F,EAAMmd,OAAO90B,IAA0C,IAArCs/C,GAAiBrrC,QAAQjU,EAAE65B,MAAe75B,EAAEo6B,IAAI/c,OAASA,EACpF,CAEA,SAASoiC,GAAa9nC,EAAOvE,GAC3B,OAAOuE,EAAMR,KAAK,CAAClW,EAAGC,KACpB,MAAMuS,EAAKL,EAAUlS,EAAID,EACnByS,EAAKN,EAAUnS,EAAIC,EACzB,OAAOuS,EAAG1C,SAAW2C,EAAG3C,OACtB0C,EAAGlf,MAAQmf,EAAGnf,MACdkf,EAAG1C,OAAS2C,EAAG3C,QAErB,CAEA,SAAS2uC,GAAUC,GACjB,MAAMC,EAAc,GACpB,IAAIltD,EAAG8gB,EAAM4mB,EAAKP,EAAK4M,EAAOoZ,EAE9B,IAAKntD,EAAI,EAAG8gB,GAAQmsC,GAAS,IAAIxjD,OAAQzJ,EAAI8gB,IAAQ9gB,EACnD0nC,EAAMulB,EAAMjtD,KACVirD,SAAU9jB,EAAKx9B,SAAUoqC,QAAOoZ,cAAc,IAAMzlB,GACtDwlB,EAAY3qC,KAAK,CACf1gB,MAAO7B,EACP0nC,MACAP,MACAsZ,WAAY/Y,EAAI6Y,eAChBliC,OAAQqpB,EAAIrpB,OACZ01B,MAAOA,GAAU5M,EAAM4M,EACvBoZ,gBAGJ,OAAOD,CACT,CAEA,SAASE,GAAYC,GACnB,MAAMtY,EAAS,CAAC,EAChB,IAAK,MAAMuY,KAAQD,EAAS,CAC1B,MAAM,MAACtZ,EAAK,IAAE5M,EAAA,YAAKgmB,GAAeG,EAClC,IAAKvZ,IAAU6Y,GAAiBl7B,SAASyV,GACvC,SAEF,MAAMpG,EAASgU,EAAOhB,KAAWgB,EAAOhB,GAAS,CAAClqC,MAAO,EAAG0jD,OAAQ,EAAGlvC,OAAQ,EAAGlT,KAAM,IACxF41B,EAAOl3B,QACPk3B,EAAO1iB,QAAU8uC,CACnB,CACA,OAAOpY,CACT,CAKA,SAASyY,GAAcH,EAASI,GAC9B,MAAM1Y,EAASqY,GAAYC,IACrB,aAACK,EAAA,cAAcC,GAAiBF,EACtC,IAAIztD,EAAG8gB,EAAM8sC,EACb,IAAK5tD,EAAI,EAAG8gB,EAAOusC,EAAQ5jD,OAAQzJ,EAAI8gB,IAAQ9gB,EAAG,CAChD4tD,EAASP,EAAQrtD,GACjB,MAAM,SAAC6tD,GAAYD,EAAOlmB,IACpBqM,EAAQgB,EAAO6Y,EAAO7Z,OACtBhD,EAASgD,GAAS6Z,EAAOT,YAAcpZ,EAAM11B,OAC/CuvC,EAAOnN,YACTmN,EAAO/6B,MAAQke,EAASA,EAAS2c,EAAeG,GAAYJ,EAAOK,eACnEF,EAAOl1B,OAASi1B,IAEhBC,EAAO/6B,MAAQ66B,EACfE,EAAOl1B,OAASqY,EAASA,EAAS4c,EAAgBE,GAAYJ,EAAOM,gBAEzE,CACA,OAAOhZ,CACT,CAEA,SAASiZ,GAAiBf,GACxB,MAAMC,EAAcF,GAAUC,GACxBY,EAAWd,GAAaG,EAAY9qB,OAAOkrB,GAAQA,EAAK5lB,IAAImmB,WAAW,GACvEjkC,EAAOmjC,GAAaF,GAAiBK,EAAa,SAAS,GAC3DrjC,EAAQkjC,GAAaF,GAAiBK,EAAa,UACnDx9B,EAAMq9B,GAAaF,GAAiBK,EAAa,QAAQ,GACzDv9B,EAASo9B,GAAaF,GAAiBK,EAAa,WACpDe,EAAmBnB,GAA4BI,EAAa,KAC5DgB,EAAiBpB,GAA4BI,EAAa,KAEhE,MAAO,CACLW,WACAM,WAAYvkC,EAAK60B,OAAO/uB,GACxB0+B,eAAgBvkC,EAAM40B,OAAOyP,GAAgBzP,OAAO9uB,GAAQ8uB,OAAOwP,GACnE3f,UAAWue,GAAiBK,EAAa,aACzCmB,SAAUzkC,EAAK60B,OAAO50B,GAAO40B,OAAOyP,GACpCzN,WAAY/wB,EAAI+uB,OAAO9uB,GAAQ8uB,OAAOwP,GAE1C,CAEA,SAASK,GAAeC,EAAYjgB,EAAW//B,EAAGC,GAChD,OAAO9D,KAAKgD,IAAI6gD,EAAWhgD,GAAI+/B,EAAU//B,IAAM7D,KAAKgD,IAAI6gD,EAAW//C,GAAI8/B,EAAU9/B,GACnF,CAEA,SAASggD,GAAiBD,EAAYE,GACpCF,EAAW7+B,IAAMhlB,KAAKgD,IAAI6gD,EAAW7+B,IAAK++B,EAAW/+B,KACrD6+B,EAAW3kC,KAAOlf,KAAKgD,IAAI6gD,EAAW3kC,KAAM6kC,EAAW7kC,MACvD2kC,EAAW5+B,OAASjlB,KAAKgD,IAAI6gD,EAAW5+B,OAAQ8+B,EAAW9+B,QAC3D4+B,EAAW1kC,MAAQnf,KAAKgD,IAAI6gD,EAAW1kC,MAAO4kC,EAAW5kC,MAC3D,CAEA,SAAS6kC,GAAWpgB,EAAWmf,EAAQG,EAAQ7Y,GAC7C,MAAM,IAAC5N,EAAA,IAAKO,GAAOkmB,EACbW,EAAajgB,EAAUigB,WAG7B,IAAK9uC,GAAS0nB,GAAM,CACdymB,EAAOziD,OAETmjC,EAAUnH,IAAQymB,EAAOziD,MAE3B,MAAM4oC,EAAQgB,EAAO6Y,EAAO7Z,QAAU,CAAC5oC,KAAM,EAAGtB,MAAO,GACvDkqC,EAAM5oC,KAAOT,KAAKgD,IAAIqmC,EAAM5oC,KAAMyiD,EAAOnN,WAAa/Y,EAAIhP,OAASgP,EAAI7U,OACvE+6B,EAAOziD,KAAO4oC,EAAM5oC,KAAO4oC,EAAMlqC,MACjCykC,EAAUnH,IAAQymB,EAAOziD,I,CAGvBu8B,EAAIinB,YACNH,GAAiBD,EAAY7mB,EAAIinB,cAGnC,MAAMC,EAAWlkD,KAAKgD,IAAI,EAAG+/C,EAAOoB,WAAaP,GAAeC,EAAYjgB,EAAW,OAAQ,UACzFwgB,EAAYpkD,KAAKgD,IAAI,EAAG+/C,EAAOsB,YAAcT,GAAeC,EAAYjgB,EAAW,MAAO,WAC1F0gB,EAAeJ,IAAatgB,EAAUt+B,EACtCi/C,EAAgBH,IAAcxgB,EAAU7gC,EAK9C,OAJA6gC,EAAUt+B,EAAI4+C,EACdtgB,EAAU7gC,EAAIqhD,EAGPlB,EAAOnN,WACV,CAACyO,KAAMF,EAAcG,MAAOF,GAC5B,CAACC,KAAMD,EAAeE,MAAOH,EACnC,CAEA,SAASI,GAAiB9gB,GACxB,MAAMigB,EAAajgB,EAAUigB,WAE7B,SAASc,EAAUloB,GACjB,MAAMxI,EAASj0B,KAAKgD,IAAI6gD,EAAWpnB,GAAOmH,EAAUnH,GAAM,GAE1D,OADAmH,EAAUnH,IAAQxI,EACXA,CACT,CACA2P,EAAUpsB,GAAKmtC,EAAU,OACzB/gB,EAAUj9B,GAAKg+C,EAAU,QACzBA,EAAU,SACVA,EAAU,SACZ,CAEA,SAASC,GAAW7O,EAAYnS,GAC9B,MAAMigB,EAAajgB,EAAUigB,WAE7B,SAASgB,EAAmBxoB,GAC1B,MAAM1M,EAAS,CAACzQ,KAAM,EAAG8F,IAAK,EAAG7F,MAAO,EAAG8F,OAAQ,GAInD,OAHAoX,EAAU7e,QAASif,IACjB9M,EAAO8M,GAAOz8B,KAAKgD,IAAI4gC,EAAUnH,GAAMonB,EAAWpnB,MAE7C9M,CACT,CAEA,OACIk1B,EADG9O,EACgB,CAAC,OAAQ,SACT,CAAC,MAAO,UACjC,CAEA,SAAS+O,GAASvC,EAAO3e,EAAWmf,EAAQ1Y,GAC1C,MAAM0a,EAAa,GACnB,IAAIzvD,EAAG8gB,EAAM8sC,EAAQlmB,EAAKgoB,EAAO7jC,EAEjC,IAAK7rB,EAAI,EAAG8gB,EAAOmsC,EAAMxjD,OAAQimD,EAAQ,EAAG1vD,EAAI8gB,IAAQ9gB,EAAG,CACzD4tD,EAASX,EAAMjtD,GACf0nC,EAAMkmB,EAAOlmB,IAEbA,EAAImK,OACF+b,EAAO/6B,OAASyb,EAAUt+B,EAC1B49C,EAAOl1B,QAAU4V,EAAU7gC,EAC3B6hD,GAAW1B,EAAOnN,WAAYnS,IAEhC,MAAM,KAAC4gB,EAAA,MAAMC,GAAST,GAAWpgB,EAAWmf,EAAQG,EAAQ7Y,GAI5D2a,GAASR,GAAQO,EAAWhmD,OAG5BoiB,EAAUA,GAAWsjC,EAEhBznB,EAAImmB,UACP4B,EAAWltC,KAAKqrC,EAEpB,CAEA,OAAO8B,GAASF,GAASC,EAAYnhB,EAAWmf,EAAQ1Y,IAAWlpB,CACrE,CAEA,SAAS8jC,GAAWjoB,EAAK9d,EAAM8F,EAAKmD,EAAO6F,GACzCgP,EAAIhY,IAAMA,EACVgY,EAAI9d,KAAOA,EACX8d,EAAI7d,MAAQD,EAAOiJ,EACnB6U,EAAI/X,OAASD,EAAMgJ,EACnBgP,EAAI7U,MAAQA,EACZ6U,EAAIhP,OAASA,CACf,CAEA,SAASk3B,GAAW3C,EAAO3e,EAAWmf,EAAQ1Y,GAC5C,MAAM8a,EAAcpC,EAAOh+B,QAC3B,IAAI,EAACpe,EAAA,EAAG6Q,GAAKosB,EAEb,IAAK,MAAMsf,KAAUX,EAAO,CAC1B,MAAMvlB,EAAMkmB,EAAOlmB,IACbqM,EAAQgB,EAAO6Y,EAAO7Z,QAAU,CAAClqC,MAAO,EAAG0jD,OAAQ,EAAGlvC,OAAQ,GAC9DA,EAASuvC,EAAQT,YAAcpZ,EAAM11B,QAAW,EACtD,GAAIuvC,EAAOnN,WAAY,CACrB,MAAM5tB,EAAQyb,EAAUt+B,EAAIqO,EACtBqa,EAASqb,EAAM5oC,MAAQu8B,EAAIhP,OAC7B7V,GAAQkxB,EAAMxtB,SAChBrE,EAAI6xB,EAAMxtB,OAERmhB,EAAImmB,SACN8B,GAAWjoB,EAAKmoB,EAAYjmC,KAAM1H,EAAGurC,EAAOoB,WAAagB,EAAYhmC,MAAQgmC,EAAYjmC,KAAM8O,GAE/Fi3B,GAAWjoB,EAAK4G,EAAU1kB,KAAOmqB,EAAMwZ,OAAQrrC,EAAG2Q,EAAO6F,GAE3Dqb,EAAMxtB,MAAQrE,EACd6xB,EAAMwZ,QAAU16B,EAChB3Q,EAAIwlB,EAAI/X,M,KACH,CACL,MAAM+I,EAAS4V,EAAU7gC,EAAI4Q,EACvBwU,EAAQkhB,EAAM5oC,MAAQu8B,EAAI7U,MAC5BhQ,GAAQkxB,EAAMxtB,SAChBlV,EAAI0iC,EAAMxtB,OAERmhB,EAAImmB,SACN8B,GAAWjoB,EAAKr2B,EAAGw+C,EAAYngC,IAAKmD,EAAO46B,EAAOsB,YAAcc,EAAYlgC,OAASkgC,EAAYngC,KAEjGigC,GAAWjoB,EAAKr2B,EAAGi9B,EAAU5e,IAAMqkB,EAAMwZ,OAAQ16B,EAAO6F,GAE1Dqb,EAAMxtB,MAAQlV,EACd0iC,EAAMwZ,QAAU70B,EAChBrnB,EAAIq2B,EAAI7d,K,CAEZ,CAEAykB,EAAUj9B,EAAIA,EACdi9B,EAAUpsB,EAAIA,CAChB,CAwBA,IAAAmrC,GAAe,CAQbyC,MAAAA,CAAOh/B,EAAOnvB,GACPmvB,EAAMm8B,QACTn8B,EAAMm8B,MAAQ,IAIhBtrD,EAAKksD,SAAWlsD,EAAKksD,WAAY,EACjClsD,EAAKspD,SAAWtpD,EAAKspD,UAAY,MACjCtpD,EAAK0c,OAAS1c,EAAK0c,QAAU,EAE7B1c,EAAKouD,QAAUpuD,EAAKouD,SAAW,WAC7B,MAAO,CAAC,CACNC,EAAG,EACHngB,IAAAA,CAAKvB,GACH3sC,EAAKkuC,KAAKvB,EACZ,GAEJ,EAEAxd,EAAMm8B,MAAM1qC,KAAK5gB,EACnB,EAOAsuD,SAAAA,CAAUn/B,EAAOo/B,GACf,MAAMruD,EAAQivB,EAAMm8B,MAAQn8B,EAAMm8B,MAAM1rC,QAAQ2uC,IAAe,GAChD,IAAXruD,GACFivB,EAAMm8B,MAAMxkC,OAAO5mB,EAAO,EAE9B,EAQA0wC,SAAAA,CAAUzhB,EAAOnvB,EAAMgI,GACrBhI,EAAKksD,SAAWlkD,EAAQkkD,SACxBlsD,EAAKspD,SAAWthD,EAAQshD,SACxBtpD,EAAK0c,OAAS1U,EAAQ0U,MACxB,EAUAwzB,MAAAA,CAAO/gB,EAAO+B,EAAO6F,EAAQy3B,GAC3B,IAAKr/B,EACH,OAGF,MAAMrB,EAAUuO,GAAUlN,EAAMnnB,QAAQikD,OAAOn+B,SACzCq+B,EAAiBpjD,KAAKgD,IAAImlB,EAAQpD,EAAQoD,MAAO,GACjDk7B,EAAkBrjD,KAAKgD,IAAIgrB,EAASjJ,EAAQiJ,OAAQ,GACpDu0B,EAAQe,GAAiBl9B,EAAMm8B,OAC/BmD,EAAgBnD,EAAMoB,SACtBgC,EAAkBpD,EAAMxM,WAI9BjgC,GAAKsQ,EAAMm8B,MAAOvlB,IACgB,oBAArBA,EAAI4oB,cACb5oB,EAAI4oB,iBA+BR,MAAMC,EAA0BH,EAAc7f,OAAO,CAACxlC,EAAOuiD,IAC3DA,EAAK5lB,IAAI/9B,UAAwC,IAA7B2jD,EAAK5lB,IAAI/9B,QAAQkoB,QAAoB9mB,EAAQA,EAAQ,EAAG,IAAM,EAE9E0iD,EAASltD,OAAO27C,OAAO,CAC3B2S,WAAYh8B,EACZk8B,YAAar2B,EACbjJ,UACAq+B,iBACAC,kBACAL,aAAcI,EAAiB,EAAIyC,EACnC5C,cAAeI,EAAkB,IAE7BQ,EAAahuD,OAAOkd,OAAO,CAAC,EAAGgS,GACrC++B,GAAiBD,EAAYvwB,GAAUmyB,IACvC,MAAM7hB,EAAY/tC,OAAOkd,OAAO,CAC9B8wC,aACAv+C,EAAG89C,EACHrgD,EAAGsgD,EACH18C,EAAGoe,EAAQ7F,KACX1H,EAAGuN,EAAQC,KACVD,GAEGslB,EAASyY,GAAc4C,EAAc3R,OAAO4R,GAAkB5C,GAGpE+B,GAASvC,EAAMY,SAAUvf,EAAWmf,EAAQ1Y,GAG5Cya,GAASY,EAAe9hB,EAAWmf,EAAQ1Y,GAGvCya,GAASa,EAAiB/hB,EAAWmf,EAAQ1Y,IAE/Cya,GAASY,EAAe9hB,EAAWmf,EAAQ1Y,GAG7Cqa,GAAiB9gB,GAGjBshB,GAAW3C,EAAMkB,WAAY7f,EAAWmf,EAAQ1Y,GAGhDzG,EAAUj9B,GAAKi9B,EAAUt+B,EACzBs+B,EAAUpsB,GAAKosB,EAAU7gC,EAEzBmiD,GAAW3C,EAAMmB,eAAgB9f,EAAWmf,EAAQ1Y,GAEpDjkB,EAAMwd,UAAY,CAChB1kB,KAAM0kB,EAAU1kB,KAChB8F,IAAK4e,EAAU5e,IACf7F,MAAOykB,EAAU1kB,KAAO0kB,EAAUt+B,EAClC2f,OAAQ2e,EAAU5e,IAAM4e,EAAU7gC,EAClCirB,OAAQ4V,EAAU7gC,EAClBolB,MAAOyb,EAAUt+B,GAInBwQ,GAAKysC,EAAM3e,UAAYsf,IACrB,MAAMlmB,EAAMkmB,EAAOlmB,IACnBnnC,OAAOkd,OAAOiqB,EAAK5W,EAAMwd,WACzB5G,EAAImK,OAAOvD,EAAUt+B,EAAGs+B,EAAU7gC,EAAG,CAACmc,KAAM,EAAG8F,IAAK,EAAG7F,MAAO,EAAG8F,OAAQ,KAE7E,GC7ba,MAAM6gC,GAOnBC,cAAAA,CAAen4B,EAAQ0Q,GAAc,CAQrC0nB,cAAAA,CAAe97B,GACb,OAAO,CACT,CASAxxB,gBAAAA,CAAiB0tB,EAAOtuB,EAAMulB,GAAW,CAQzCzkB,mBAAAA,CAAoBwtB,EAAOtuB,EAAMulB,GAAW,CAK5C+M,mBAAAA,GACE,OAAO,CACT,CASA+T,cAAAA,CAAepC,EAAS5T,EAAO6F,EAAQsQ,GAGrC,OAFAnW,EAAQnoB,KAAKgD,IAAI,EAAGmlB,GAAS4T,EAAQ5T,OACrC6F,EAASA,GAAU+N,EAAQ/N,OACpB,CACL7F,QACA6F,OAAQhuB,KAAKgD,IAAI,EAAGs7B,EAAct+B,KAAKyZ,MAAM0O,EAAQmW,GAAetQ,GAExE,CAMAi4B,UAAAA,CAAWr4B,GACT,OAAO,CACT,CAMAs4B,YAAAA,CAAave,GAEb,ECrEa,MAAMwe,WAAsBL,GACzCC,cAAAA,CAAe9uD,GAIb,OAAOA,GAAQA,EAAK42B,YAAc52B,EAAK42B,WAAW,OAAS,IAC7D,CACAq4B,YAAAA,CAAave,GACXA,EAAO1oC,QAAQslB,WAAY,CAC7B,ECRF,MAAM6hC,GAAc,WAOdC,GAAc,CAClBC,WAAY,YACZC,UAAW,YACXC,SAAU,UACVC,aAAc,aACdC,YAAa,YACbC,YAAa,YACbC,UAAW,UACXC,aAAc,WACdC,WAAY,YAGRC,GAAgBhxD,GAAmB,OAAVA,GAA4B,KAAVA,EAQjD,SAASixD,GAAWp5B,EAAQ0Q,GAC1B,MAAMj/B,EAAQuuB,EAAOvuB,MAIf4nD,EAAer5B,EAAOs5B,aAAa,UACnCC,EAAcv5B,EAAOs5B,aAAa,SAsBxC,GAnBAt5B,EAAOw4B,IAAe,CACpBzhB,QAAS,CACP3W,OAAQi5B,EACR9+B,MAAOg/B,EACP9nD,MAAO,CACL8nB,QAAS9nB,EAAM8nB,QACf6G,OAAQ3uB,EAAM2uB,OACd7F,MAAO9oB,EAAM8oB,SAQnB9oB,EAAM8nB,QAAU9nB,EAAM8nB,SAAW,QAEjC9nB,EAAMk+B,UAAYl+B,EAAMk+B,WAAa,aAEjCwpB,GAAcI,GAAc,CAC9B,MAAMC,EAAehoB,GAAaxR,EAAQ,cACrB9oB,IAAjBsiD,IACFx5B,EAAOzF,MAAQi/B,E,CAInB,GAAIL,GAAcE,GAChB,GAA4B,KAAxBr5B,EAAOvuB,MAAM2uB,OAIfJ,EAAOI,OAASJ,EAAOzF,OAASmW,GAAe,OAC1C,CACL,MAAM+oB,EAAgBjoB,GAAaxR,EAAQ,eACrB9oB,IAAlBuiD,IACFz5B,EAAOI,OAASq5B,E,CAKtB,OAAOz5B,CACT,CAIA,MAAM05B,KAAuBroB,IAA+B,CAACE,SAAS,GAEtE,SAASooB,GAAY/9B,EAAM1xB,EAAMulB,GAC3BmM,GACFA,EAAK9wB,iBAAiBZ,EAAMulB,EAAUiqC,GAE1C,CAEA,SAASE,GAAephC,EAAOtuB,EAAMulB,GAC/B+I,GAASA,EAAMwH,QACjBxH,EAAMwH,OAAOh1B,oBAAoBd,EAAMulB,EAAUiqC,GAErD,CAEA,SAASG,GAAgBpqB,EAAOjX,GAC9B,MAAMtuB,EAAOuuD,GAAYhpB,EAAMvlC,OAASulC,EAAMvlC,MACxC,EAAC6O,EAAC,EAAE6Q,GAAK4lB,GAAoBC,EAAOjX,GAC1C,MAAO,CACLtuB,OACAsuB,QACAshC,OAAQrqB,EACR12B,OAAS7B,IAAN6B,EAAkBA,EAAI,KACzB6Q,OAAS1S,IAAN0S,EAAkBA,EAAI,KAE7B,CAEA,SAASmwC,GAAiBC,EAAUh6B,GAClC,IAAK,MAAMpE,KAAQo+B,EACjB,GAAIp+B,IAASoE,GAAUpE,EAAKq+B,SAASj6B,GACnC,OAAO,CAGb,CAEA,SAASk6B,GAAqB1hC,EAAOtuB,EAAMulB,GACzC,MAAMuQ,EAASxH,EAAMwH,OACfm6B,EAAW,IAAIC,iBAAiBC,IACpC,IAAIC,GAAU,EACd,IAAK,MAAMjT,KAASgT,EAClBC,EAAUA,GAAWP,GAAiB1S,EAAMkT,WAAYv6B,GACxDs6B,EAAUA,IAAYP,GAAiB1S,EAAMmT,aAAcx6B,GAEzDs6B,GACF7qC,MAIJ,OADA0qC,EAASM,QAAQhtB,SAAU,CAACitB,WAAW,EAAMC,SAAS,IAC/CR,CACT,CAEA,SAASS,GAAqBpiC,EAAOtuB,EAAMulB,GACzC,MAAMuQ,EAASxH,EAAMwH,OACfm6B,EAAW,IAAIC,iBAAiBC,IACpC,IAAIC,GAAU,EACd,IAAK,MAAMjT,KAASgT,EAClBC,EAAUA,GAAWP,GAAiB1S,EAAMmT,aAAcx6B,GAC1Ds6B,EAAUA,IAAYP,GAAiB1S,EAAMkT,WAAYv6B,GAEvDs6B,GACF7qC,MAIJ,OADA0qC,EAASM,QAAQhtB,SAAU,CAACitB,WAAW,EAAMC,SAAS,IAC/CR,CACT,CAEA,MAAMU,GAAqB,IAAItjC,IAC/B,IAAIujC,GAAsB,EAE1B,SAASC,KACP,MAAMC,EAAMrwD,OAAO0xB,iBACf2+B,IAAQF,KAGZA,GAAsBE,EACtBH,GAAmBjrC,QAAQ,CAACgH,EAAQ4B,KAC9BA,EAAMqH,0BAA4Bm7B,GACpCpkC,MAGN,CAEA,SAASqkC,GAA8BziC,EAAO5B,GACvCikC,GAAmBhoD,MACtBlI,OAAOG,iBAAiB,SAAUiwD,IAEpCF,GAAmBvqC,IAAIkI,EAAO5B,EAChC,CAEA,SAASskC,GAAgC1iC,GACvCqiC,GAAmBlxB,OAAOnR,GACrBqiC,GAAmBhoD,MACtBlI,OAAOK,oBAAoB,SAAU+vD,GAEzC,CAEA,SAASI,GAAqB3iC,EAAOtuB,EAAMulB,GACzC,MAAMuQ,EAASxH,EAAMwH,OACfgQ,EAAYhQ,GAAU0N,GAAe1N,GAC3C,IAAKgQ,EACH,OAEF,MAAMpZ,EAASlG,GAAU,CAAC6J,EAAO6F,KAC/B,MAAM1oB,EAAIs4B,EAAUI,YACpB3gB,EAAS8K,EAAO6F,GACZ1oB,EAAIs4B,EAAUI,aAQhB3gB,KAED9kB,QAGGwvD,EAAW,IAAIiB,eAAef,IAClC,MAAMhT,EAAQgT,EAAQ,GAChB9/B,EAAQ8sB,EAAMgU,YAAY9gC,MAC1B6F,EAASinB,EAAMgU,YAAYj7B,OAInB,IAAV7F,GAA0B,IAAX6F,GAGnBxJ,EAAO2D,EAAO6F,KAKhB,OAHA+5B,EAASM,QAAQzqB,GACjBirB,GAA8BziC,EAAO5B,GAE9BujC,CACT,CAEA,SAASmB,GAAgB9iC,EAAOtuB,EAAMiwD,GAChCA,GACFA,EAASoB,aAEE,WAATrxD,GACFgxD,GAAgC1iC,EAEpC,CAEA,SAASgjC,GAAqBhjC,EAAOtuB,EAAMulB,GACzC,MAAMuQ,EAASxH,EAAMwH,OACfmI,EAAQzX,GAAW+e,IAIL,OAAdjX,EAAMwE,KACRvN,EAASoqC,GAAgBpqB,EAAOjX,KAEjCA,GAIH,OAFAmhC,GAAY35B,EAAQ91B,EAAMi+B,GAEnBA,CACT,CAMe,MAAMszB,WAAoBvD,GAOvCC,cAAAA,CAAen4B,EAAQ0Q,GAIrB,MAAMpU,EAAU0D,GAAUA,EAAOC,YAAcD,EAAOC,WAAW,MASjE,OAAI3D,GAAWA,EAAQ0D,SAAWA,GAGhCo5B,GAAWp5B,EAAQ0Q,GACZpU,GAGF,IACT,CAKA87B,cAAAA,CAAe97B,GACb,MAAM0D,EAAS1D,EAAQ0D,OACvB,IAAKA,EAAOw4B,IACV,OAAO,EAGT,MAAMzhB,EAAU/W,EAAOw4B,IAAazhB,QACpC,CAAC,SAAU,SAASnnB,QAAS2V,IAC3B,MAAMp9B,EAAQ4uC,EAAQxR,GAClBve,GAAc7e,GAChB63B,EAAO07B,gBAAgBn2B,GAEvBvF,EAAO27B,aAAap2B,EAAMp9B,KAI9B,MAAMsJ,EAAQslC,EAAQtlC,OAAS,CAAC,EAahC,OAZAxJ,OAAOgJ,KAAKQ,GAAOme,QAAStmB,IAC1B02B,EAAOvuB,MAAMnI,GAAOmI,EAAMnI,KAQ5B02B,EAAOzF,MAAQyF,EAAOzF,aAEfyF,EAAOw4B,KACP,CACT,CAQA1tD,gBAAAA,CAAiB0tB,EAAOtuB,EAAMulB,GAE5BllB,KAAKS,oBAAoBwtB,EAAOtuB,GAEhC,MAAM0xD,EAAUpjC,EAAMqjC,WAAarjC,EAAMqjC,SAAW,CAAC,GAC/CC,EAAW,CACfC,OAAQ7B,GACR8B,OAAQpB,GACRhkC,OAAQukC,IAEJvI,EAAUkJ,EAAS5xD,IAASsxD,GAClCI,EAAQ1xD,GAAQ0oD,EAAQp6B,EAAOtuB,EAAMulB,EACvC,CAOAzkB,mBAAAA,CAAoBwtB,EAAOtuB,GACzB,MAAM0xD,EAAUpjC,EAAMqjC,WAAarjC,EAAMqjC,SAAW,CAAC,GAC/C1zB,EAAQyzB,EAAQ1xD,GAEtB,IAAKi+B,EACH,OAGF,MAAM2zB,EAAW,CACfC,OAAQT,GACRU,OAAQV,GACR1kC,OAAQ0kC,IAEJ1I,EAAUkJ,EAAS5xD,IAAS0vD,GAClChH,EAAQp6B,EAAOtuB,EAAMi+B,GACrByzB,EAAQ1xD,QAAQgN,CAClB,CAEAslB,mBAAAA,GACE,OAAO7xB,OAAO0xB,gBAChB,CAQAkU,cAAAA,CAAevQ,EAAQzF,EAAO6F,EAAQsQ,GACpC,OAAOH,GAAevQ,EAAQzF,EAAO6F,EAAQsQ,EAC/C,CAKA2nB,UAAAA,CAAWr4B,GACT,MAAMgQ,EAAYhQ,GAAU0N,GAAe1N,GAC3C,SAAUgQ,IAAaA,EAAUisB,YACnC,EC9XK,SAASC,GAAgBl8B,GAC9B,OAAKwN,MAAiD,qBAApB2uB,iBAAmCn8B,aAAkBm8B,gBAC9E5D,GAEFkD,EACT,CCLe,MAAMW,GAAAh1D,WAAAA,IAAAY,EAAAA,GAAAA,GAAA,kBAAAA,EAAAA,GAAAA,GAAA,kBAAAA,EAAAA,GAAAA,GAAA,eAOV,IAAKA,EAAAA,GAAAA,GAAA,wBAAAA,EAAAA,GAAAA,GAAA,2BAIdq0D,eAAAA,CAAgBjJ,GACd,MAAM,EAACr6C,EAAA,EAAG6Q,GAAKrf,KAAKkpD,SAAS,CAAC,IAAK,KAAML,GACzC,MAAO,CAACr6C,IAAG6Q,IACb,CAEA0yC,QAAAA,GACE,OAAOhwC,GAAS/hB,KAAKwO,IAAMuT,GAAS/hB,KAAKqf,EAC3C,CASA6pC,QAAAA,CAASxpD,EAAiBsyD,GACxB,MAAM5lB,EAAQpsC,KAAKqwC,YACnB,IAAK2hB,IAAU5lB,EAEb,OAAOpsC,KAET,MAAMuM,EAA+B,CAAC,EAItC,OAHA7M,EAAM2lB,QAAS2V,IACbzuB,EAAIyuB,GAAQoR,EAAMpR,IAASoR,EAAMpR,GAAM7O,SAAWigB,EAAMpR,GAAM8T,IAAM9uC,KAAKg7B,KAEpEzuB,CACT,EC3BK,SAASgkB,GAAS+C,EAAOtF,GAC9B,MAAMikC,EAAW3+B,EAAMxsB,QAAQknB,MACzBkkC,EAAqBC,GAAkB7+B,GACvC8+B,EAAavqD,KAAKiD,IAAImnD,EAASI,eAAiBH,EAAoBA,GACpEI,EAAeL,EAASthC,MAAM4hC,QAAUC,GAAgBxkC,GAAS,GACjEykC,EAAkBH,EAAa1rD,OAC/B8rD,EAAQJ,EAAa,GACrB3tC,EAAO2tC,EAAaG,EAAkB,GACtCE,EAAW,GAGjB,GAAIF,EAAkBL,EAEpB,OADAQ,GAAW5kC,EAAO2kC,EAAUL,EAAcG,EAAkBL,GACrDO,EAGT,MAAM3P,EAAU6P,GAAiBP,EAActkC,EAAOokC,GAEtD,GAAIK,EAAkB,EAAG,CACvB,IAAIt1D,EAAG8gB,EACP,MAAM60C,EAAkBL,EAAkB,EAAI5qD,KAAKC,OAAO6c,EAAO+tC,IAAUD,EAAkB,IAAM,KAEnG,IADAjyB,GAAKxS,EAAO2kC,EAAU3P,EAASvmC,GAAcq2C,GAAmB,EAAIJ,EAAQI,EAAiBJ,GACxFv1D,EAAI,EAAG8gB,EAAOw0C,EAAkB,EAAGt1D,EAAI8gB,EAAM9gB,IAChDqjC,GAAKxS,EAAO2kC,EAAU3P,EAASsP,EAAan1D,GAAIm1D,EAAan1D,EAAI,IAGnE,OADAqjC,GAAKxS,EAAO2kC,EAAU3P,EAASr+B,EAAMlI,GAAcq2C,GAAmB9kC,EAAMpnB,OAAS+d,EAAOmuC,GACrFH,C,CAGT,OADAnyB,GAAKxS,EAAO2kC,EAAU3P,GACf2P,CACT,CAEA,SAASR,GAAkB7+B,GACzB,MAAMrE,EAASqE,EAAMxsB,QAAQmoB,OACvBS,EAAa4D,EAAMy/B,YACnBC,EAAW1/B,EAAMyoB,QAAUrsB,GAAcT,EAAS,EAAI,GACtDgkC,EAAW3/B,EAAM4/B,WAAaxjC,EACpC,OAAO7nB,KAAKyZ,MAAMzZ,KAAKiD,IAAIkoD,EAAUC,GACvC,CAOA,SAASJ,GAAiBP,EAActkC,EAAOokC,GAC7C,MAAMe,EAAmBC,GAAed,GAClCtP,EAAUh1B,EAAMpnB,OAASwrD,EAI/B,IAAKe,EACH,OAAOtrD,KAAKgD,IAAIm4C,EAAS,GAG3B,MAAMqQ,EAAU5xC,GAAW0xC,GAC3B,IAAK,IAAIh2D,EAAI,EAAG8gB,EAAOo1C,EAAQzsD,OAAS,EAAGzJ,EAAI8gB,EAAM9gB,IAAK,CACxD,MAAM+wC,EAASmlB,EAAQl2D,GACvB,GAAI+wC,EAAS8U,EACX,OAAO9U,CAEX,CACA,OAAOrmC,KAAKgD,IAAIm4C,EAAS,EAC3B,CAKA,SAASwP,GAAgBxkC,GACvB,MAAMtM,EAAS,GACf,IAAIvkB,EAAG8gB,EACP,IAAK9gB,EAAI,EAAG8gB,EAAO+P,EAAMpnB,OAAQzJ,EAAI8gB,EAAM9gB,IACrC6wB,EAAM7wB,GAAGwzB,OACXjP,EAAOhC,KAAKviB,GAGhB,OAAOukB,CACT,CAQA,SAASkxC,GAAW5kC,EAAO2kC,EAAUL,EAActP,GACjD,IAEI7lD,EAFA6J,EAAQ,EACR85B,EAAOwxB,EAAa,GAIxB,IADAtP,EAAUn7C,KAAKyrD,KAAKtQ,GACf7lD,EAAI,EAAGA,EAAI6wB,EAAMpnB,OAAQzJ,IACxBA,IAAM2jC,IACR6xB,EAASjzC,KAAKsO,EAAM7wB,IACpB6J,IACA85B,EAAOwxB,EAAatrD,EAAQg8C,GAGlC,CASA,SAASxiB,GAAKxS,EAAO2kC,EAAU3P,EAASuQ,EAAYC,GAClD,MAAM9vC,EAAQzG,GAAes2C,EAAY,GACnC5vC,EAAM9b,KAAKiD,IAAImS,GAAeu2C,EAAUxlC,EAAMpnB,QAASonB,EAAMpnB,QACnE,IACIA,EAAQzJ,EAAG2jC,EADX95B,EAAQ,EAGZg8C,EAAUn7C,KAAKyrD,KAAKtQ,GAChBwQ,IACF5sD,EAAS4sD,EAAWD,EACpBvQ,EAAUp8C,EAASiB,KAAKyZ,MAAM1a,EAASo8C,IAGzCliB,EAAOpd,EAEP,MAAOod,EAAO,EACZ95B,IACA85B,EAAOj5B,KAAKC,MAAM4b,EAAQ1c,EAAQg8C,GAGpC,IAAK7lD,EAAI0K,KAAKgD,IAAI6Y,EAAO,GAAIvmB,EAAIwmB,EAAKxmB,IAChCA,IAAM2jC,IACR6xB,EAASjzC,KAAKsO,EAAM7wB,IACpB6J,IACA85B,EAAOj5B,KAAKC,MAAM4b,EAAQ1c,EAAQg8C,GAGxC,CAMA,SAASoQ,GAAe9zB,GACtB,MAAM9yB,EAAM8yB,EAAI14B,OAChB,IAAIzJ,EAAGsqD,EAEP,GAAIj7C,EAAM,EACR,OAAO,EAGT,IAAKi7C,EAAOnoB,EAAI,GAAIniC,EAAI,EAAGA,EAAIqP,IAAOrP,EACpC,GAAImiC,EAAIniC,GAAKmiC,EAAIniC,EAAI,KAAOsqD,EAC1B,OAAO,EAGX,OAAOA,CACT,ED7HAhqD,EAAAA,GAAAA,GAvCqBo0D,GAAA,WAED,CAAC,IAAEp0D,EAAAA,GAAAA,GAFFo0D,GAAA,qBAGIllD,GEAzB,MAAM8mD,GAAgB7sC,GAAoB,SAAVA,EAAmB,QAAoB,UAAVA,EAAoB,OAASA,EACpF8sC,GAAiBA,CAACpgC,EAAOwqB,EAAM7uB,IAAoB,QAAT6uB,GAA2B,SAATA,EAAkBxqB,EAAMwqB,GAAQ7uB,EAASqE,EAAMwqB,GAAQ7uB,EACnH0kC,GAAgBA,CAACC,EAAavB,IAAkBxqD,KAAKiD,IAAIunD,GAAiBuB,EAAaA,GAY7F,SAASC,GAAOv0B,EAAKw0B,GACnB,MAAMpyC,EAAS,GACTqyC,EAAYz0B,EAAI14B,OAASktD,EACzBtnD,EAAM8yB,EAAI14B,OAChB,IAAIzJ,EAAI,EAER,KAAOA,EAAIqP,EAAKrP,GAAK42D,EACnBryC,EAAOhC,KAAK4f,EAAIz3B,KAAKyZ,MAAMnkB,KAE7B,OAAOukB,CACT,CAOA,SAASsyC,GAAoB1gC,EAAOt0B,EAAOi1D,GACzC,MAAMrtD,EAAS0sB,EAAMtF,MAAMpnB,OACrBstD,EAAarsD,KAAKiD,IAAI9L,EAAO4H,EAAS,GACtC8c,EAAQ4P,EAAM0sB,YACdr8B,EAAM2P,EAAM2sB,UACZh/B,EAAU,KAChB,IACIgO,EADAklC,EAAY7gC,EAAM2oB,gBAAgBiY,GAGtC,KAAID,IAEAhlC,EADa,IAAXroB,EACOiB,KAAKgD,IAAIspD,EAAYzwC,EAAOC,EAAMwwC,GACxB,IAAVn1D,GACCs0B,EAAM2oB,gBAAgB,GAAKkY,GAAa,GAExCA,EAAY7gC,EAAM2oB,gBAAgBiY,EAAa,IAAM,EAEjEC,GAAaD,EAAal1D,EAAQiwB,GAAUA,EAGxCklC,EAAYzwC,EAAQzC,GAAWkzC,EAAYxwC,EAAM1C,IAIvD,OAAOkzC,CACT,CAMA,SAASt/B,GAAeu/B,EAAQxtD,GAC9B+W,GAAKy2C,EAASx/B,IACZ,MAAMP,EAAKO,EAAMP,GACXc,EAAQd,EAAGztB,OAAS,EAC1B,IAAIzJ,EACJ,GAAIg4B,EAAQvuB,EAAQ,CAClB,IAAKzJ,EAAI,EAAGA,EAAIg4B,IAASh4B,SAChBy3B,EAAM90B,KAAKu0B,EAAGl3B,IAEvBk3B,EAAGzO,OAAO,EAAGuP,E,GAGnB,CAKA,SAASk/B,GAAkBvtD,GACzB,OAAOA,EAAQ2oB,UAAY3oB,EAAQ4oB,WAAa,CAClD,CAKA,SAAS4kC,GAAextD,EAASu0B,GAC/B,IAAKv0B,EAAQkoB,QACX,OAAO,EAGT,MAAMoD,EAAOgJ,GAAOt0B,EAAQsrB,KAAMiJ,GAC5BzO,EAAUuO,GAAUr0B,EAAQ8lB,SAC5B+M,EAAQjsB,GAAQ5G,EAAQmpB,MAAQnpB,EAAQmpB,KAAKrpB,OAAS,EAE5D,OAAO+yB,EAASvH,EAAKE,WAAc1F,EAAQiJ,MAC7C,CAEA,SAAS0+B,GAAmB70B,EAAQpM,GAClC,OAAO2I,GAAcyD,EAAQ,CAC3BpM,QACA3zB,KAAM,SAEV,CAEA,SAAS60D,GAAkB90B,EAAQ1gC,EAAOmuC,GACxC,OAAOlR,GAAcyD,EAAQ,CAC3ByN,OACAnuC,QACAW,KAAM,QAEV,CAEA,SAAS80D,GAAW7tC,EAAOwhC,EAAUvqC,GAEnC,IAAItR,EAAMoa,GAAmBC,GAI7B,OAHI/I,GAAyB,UAAbuqC,IAA2BvqC,GAAwB,UAAbuqC,KACpD77C,EAAMknD,GAAalnD,IAEdA,CACT,CAEA,SAASmoD,GAAUphC,EAAOrE,EAAQm5B,EAAUxhC,GAC1C,MAAM,IAACiG,EAAG,KAAE9F,EAAI,OAAE+F,EAAM,MAAE9F,EAAK,MAAEiH,GAASqF,GACpC,UAACmY,EAAA,OAAWlY,GAAUtF,EAC5B,IACI+L,EAAU26B,EAAQC,EADlBt+B,EAAW,EAEf,MAAMT,EAAS/I,EAASD,EAClBmD,EAAQhJ,EAAQD,EAEtB,GAAIuM,EAAMoqB,eAAgB,CAGxB,GAFAiX,EAAS9tC,GAAeD,EAAOG,EAAMC,GAEjCpK,GAASwrC,GAAW,CACtB,MAAMyM,EAAiBn3D,OAAOgJ,KAAK0hD,GAAU,GACvCxqD,EAAQwqD,EAASyM,GACvBD,EAASrhC,EAAOshC,GAAgB3sC,iBAAiBtqB,GAASi4B,EAAS5G,C,MAEnE2lC,EADsB,WAAbxM,GACC3c,EAAU3e,OAAS2e,EAAU5e,KAAO,EAAIgJ,EAAS5G,EAElDykC,GAAepgC,EAAO80B,EAAUn5B,GAE3C+K,EAAWhT,EAAQD,C,KACd,CACL,GAAInK,GAASwrC,GAAW,CACtB,MAAMyM,EAAiBn3D,OAAOgJ,KAAK0hD,GAAU,GACvCxqD,EAAQwqD,EAASyM,GACvBF,EAASphC,EAAOshC,GAAgB3sC,iBAAiBtqB,GAASoyB,EAAQf,C,MAElE0lC,EADsB,WAAbvM,GACC3c,EAAU1kB,KAAO0kB,EAAUzkB,OAAS,EAAIgJ,EAAQf,EAEjDykC,GAAepgC,EAAO80B,EAAUn5B,GAE3C2lC,EAAS/tC,GAAeD,EAAOkG,EAAQD,GACvCyJ,EAAwB,SAAb8xB,GAAuBznC,GAAUA,E,CAE9C,MAAO,CAACg0C,SAAQC,SAAQ56B,WAAU1D,WACpC,CAEe,MAAMw+B,WAAcjD,GAGjCh1D,WAAAA,CAAYyxC,GACVmQ,QAGAz+C,KAAK8J,GAAKwkC,EAAIxkC,GAEd9J,KAAKL,KAAO2uC,EAAI3uC,KAEhBK,KAAK8G,aAAU6F,EAEf3M,KAAKyyB,IAAM6b,EAAI7b,IAEfzyB,KAAKiuB,MAAQqgB,EAAIrgB,MAIjBjuB,KAAK6sB,SAAMlgB,EAEX3M,KAAK8sB,YAASngB,EAEd3M,KAAK+mB,UAAOpa,EAEZ3M,KAAKgnB,WAAQra,EAEb3M,KAAKgwB,WAAQrjB,EAEb3M,KAAK61B,YAASlpB,EACd3M,KAAK+0D,SAAW,CACdhuC,KAAM,EACNC,MAAO,EACP6F,IAAK,EACLC,OAAQ,GAGV9sB,KAAKg6B,cAAWrtB,EAEhB3M,KAAKwlC,eAAY74B,EAEjB3M,KAAKg1D,gBAAaroD,EAElB3M,KAAKi1D,mBAAgBtoD,EAErB3M,KAAKk1D,iBAAcvoD,EAEnB3M,KAAKm1D,kBAAexoD,EAIpB3M,KAAK8nB,UAAOnb,EAEZ3M,KAAKo1D,mBAAgBzoD,EACrB3M,KAAK8K,SAAM6B,EACX3M,KAAK6K,SAAM8B,EACX3M,KAAKq1D,YAAS1oD,EAEd3M,KAAKguB,MAAQ,GAEbhuB,KAAKs1D,eAAiB,KAEtBt1D,KAAKu1D,YAAc,KAEnBv1D,KAAKw1D,YAAc,KACnBx1D,KAAK+7C,QAAU,EACf/7C,KAAKkzD,WAAa,EAClBlzD,KAAKy1D,kBAAoB,CAAC,EAE1Bz1D,KAAKggD,iBAAcrzC,EAEnB3M,KAAKigD,eAAYtzC,EACjB3M,KAAKioD,gBAAiB,EACtBjoD,KAAK01D,cAAW/oD,EAChB3M,KAAK21D,cAAWhpD,EAChB3M,KAAK41D,mBAAgBjpD,EACrB3M,KAAK61D,mBAAgBlpD,EACrB3M,KAAK81D,aAAe,EACpB91D,KAAK+1D,aAAe,EACpB/1D,KAAK1B,OAAS,CAAC,EACf0B,KAAKg2D,mBAAoB,EACzBh2D,KAAK80C,cAAWnoC,CAClB,CAMA46C,IAAAA,CAAKzgD,GACH9G,KAAK8G,QAAUA,EAAQq3B,WAAWn+B,KAAK01B,cAEvC11B,KAAK8nB,KAAOhhB,EAAQghB,KAGpB9nB,KAAK21D,SAAW31D,KAAKqgC,MAAMv5B,EAAQgE,KACnC9K,KAAK01D,SAAW11D,KAAKqgC,MAAMv5B,EAAQ+D,KACnC7K,KAAK61D,cAAgB71D,KAAKqgC,MAAMv5B,EAAQmvD,cACxCj2D,KAAK41D,cAAgB51D,KAAKqgC,MAAMv5B,EAAQovD,aAC1C,CAQA71B,KAAAA,CAAMoT,EAAKz0C,GACT,OAAOy0C,CACT,CAOAxrB,aAAAA,GACE,IAAI,SAAC0tC,EAAQ,SAAED,EAAQ,cAAEG,EAAA,cAAeD,GAAiB51D,KAKzD,OAJA21D,EAAW54C,GAAgB44C,EAAUp4D,OAAOkjB,mBAC5Ci1C,EAAW34C,GAAgB24C,EAAUn4D,OAAOy0C,mBAC5C6jB,EAAgB94C,GAAgB84C,EAAet4D,OAAOkjB,mBACtDm1C,EAAgB74C,GAAgB64C,EAAer4D,OAAOy0C,mBAC/C,CACLlnC,IAAKiS,GAAgB44C,EAAUE,GAC/BhrD,IAAKkS,GAAgB24C,EAAUE,GAC/B7tC,WAAYlL,GAAS84C,GACrB3tC,WAAYnL,GAAS64C,GAEzB,CAQAtd,SAAAA,CAAUpE,GACR,IACIzmC,GADA,IAACzC,EAAA,IAAKD,EAAA,WAAKkd,EAAA,WAAYC,GAAchoB,KAAKioB,gBAG9C,GAAIF,GAAcC,EAChB,MAAO,CAACld,MAAKD,OAGf,MAAMsrD,EAAQn2D,KAAKwyC,0BACnB,IAAK,IAAIr1C,EAAI,EAAG8gB,EAAOk4C,EAAMvvD,OAAQzJ,EAAI8gB,IAAQ9gB,EAC/CoQ,EAAQ4oD,EAAMh5D,GAAGu1C,WAAW0F,UAAUp4C,KAAMg0C,GACvCjsB,IACHjd,EAAMjD,KAAKiD,IAAIA,EAAKyC,EAAMzC,MAEvBkd,IACHnd,EAAMhD,KAAKgD,IAAIA,EAAK0C,EAAM1C,MAQ9B,OAHAC,EAAMkd,GAAcld,EAAMD,EAAMA,EAAMC,EACtCD,EAAMkd,GAAcjd,EAAMD,EAAMC,EAAMD,EAE/B,CACLC,IAAKiS,GAAgBjS,EAAKiS,GAAgBlS,EAAKC,IAC/CD,IAAKkS,GAAgBlS,EAAKkS,GAAgBjS,EAAKD,IAEnD,CAOAihD,UAAAA,GACE,MAAO,CACL/kC,KAAM/mB,KAAKk1D,aAAe,EAC1BroC,IAAK7sB,KAAKg1D,YAAc,EACxBhuC,MAAOhnB,KAAKm1D,cAAgB,EAC5BroC,OAAQ9sB,KAAKi1D,eAAiB,EAElC,CAOAmB,QAAAA,GACE,OAAOp2D,KAAKguB,KACd,CAKA2pB,SAAAA,GACE,MAAM73C,EAAOE,KAAKiuB,MAAMnuB,KACxB,OAAOE,KAAK8G,QAAQ4wC,SAAW13C,KAAK09C,eAAiB59C,EAAKu2D,QAAUv2D,EAAKw2D,UAAYx2D,EAAK43C,QAAU,EACtG,CAKA6e,aAAAA,CAAc9qB,EAAYzrC,KAAKiuB,MAAMwd,WACnC,MAAM3lB,EAAQ9lB,KAAKu1D,cAAgBv1D,KAAKu1D,YAAcv1D,KAAKw2D,mBAAmB/qB,IAC9E,OAAO3lB,CACT,CAGA2nC,YAAAA,GACEztD,KAAK1B,OAAS,CAAC,EACf0B,KAAKg2D,mBAAoB,CAC3B,CAMAS,YAAAA,GACEl5C,GAAKvd,KAAK8G,QAAQ2vD,aAAc,CAACz2D,MACnC,CAUAgvC,MAAAA,CAAOhV,EAAUwL,EAAWY,GAC1B,MAAM,YAAClX,EAAW,MAAEG,EAAOrB,MAAOikC,GAAYjyD,KAAK8G,QAC7C4vD,EAAazE,EAASyE,WAG5B12D,KAAKy2D,eAGLz2D,KAAKg6B,SAAWA,EAChBh6B,KAAKwlC,UAAYA,EACjBxlC,KAAK+0D,SAAW3uB,EAAU1oC,OAAOkd,OAAO,CACtCmM,KAAM,EACNC,MAAO,EACP6F,IAAK,EACLC,OAAQ,GACPsZ,GAEHpmC,KAAKguB,MAAQ,KACbhuB,KAAKw1D,YAAc,KACnBx1D,KAAKs1D,eAAiB,KACtBt1D,KAAKu1D,YAAc,KAGnBv1D,KAAK22D,sBACL32D,KAAK42D,gBACL52D,KAAK62D,qBAEL72D,KAAKkzD,WAAalzD,KAAK09C,eACnB19C,KAAKgwB,MAAQoW,EAAQrf,KAAOqf,EAAQpf,MACpChnB,KAAK61B,OAASuQ,EAAQvZ,IAAMuZ,EAAQtZ,OAGnC9sB,KAAKg2D,oBACRh2D,KAAK82D,mBACL92D,KAAK+2D,sBACL/2D,KAAKg3D,kBACLh3D,KAAKq1D,OAASz5B,GAAU57B,KAAMqvB,EAAOH,GACrClvB,KAAKg2D,mBAAoB,GAG3Bh2D,KAAKi3D,mBAELj3D,KAAKguB,MAAQhuB,KAAKk3D,cAAgB,GAGlCl3D,KAAKm3D,kBAIL,MAAMC,EAAkBV,EAAa12D,KAAKguB,MAAMpnB,OAChD5G,KAAKq3D,sBAAsBD,EAAkBvD,GAAO7zD,KAAKguB,MAAO0oC,GAAc12D,KAAKguB,OAMnFhuB,KAAK0vC,YAGL1vC,KAAKs3D,+BACLt3D,KAAKu3D,yBACLv3D,KAAKw3D,8BAGDvF,EAASjjC,UAAYijC,EAAS1hC,UAAgC,SAApB0hC,EAAS5zC,UACrDre,KAAKguB,MAAQuC,GAASvwB,KAAMA,KAAKguB,OACjChuB,KAAKw1D,YAAc,KACnBx1D,KAAKy3D,iBAGHL,GAEFp3D,KAAKq3D,sBAAsBr3D,KAAKguB,OAGlChuB,KAAK03D,YACL13D,KAAK+J,MACL/J,KAAK23D,WAIL33D,KAAK43D,aACP,CAKAloB,SAAAA,GACE,IACI4Q,EAAYE,EADZqX,EAAgB73D,KAAK8G,QAAQ+W,QAG7B7d,KAAK09C,gBACP4C,EAAatgD,KAAK+mB,KAClBy5B,EAAWxgD,KAAKgnB,QAEhBs5B,EAAatgD,KAAK6sB,IAClB2zB,EAAWxgD,KAAK8sB,OAEhB+qC,GAAiBA,GAEnB73D,KAAKggD,YAAcM,EACnBtgD,KAAKigD,UAAYO,EACjBxgD,KAAKioD,eAAiB4P,EACtB73D,KAAK+7C,QAAUyE,EAAWF,EAC1BtgD,KAAK83D,eAAiB93D,KAAK8G,QAAQixD,aACrC,CAEAH,WAAAA,GACEr6C,GAAKvd,KAAK8G,QAAQ8wD,YAAa,CAAC53D,MAClC,CAIA22D,mBAAAA,GACEp5C,GAAKvd,KAAK8G,QAAQ6vD,oBAAqB,CAAC32D,MAC1C,CACA42D,aAAAA,GAEM52D,KAAK09C,gBAEP19C,KAAKgwB,MAAQhwB,KAAKg6B,SAClBh6B,KAAK+mB,KAAO,EACZ/mB,KAAKgnB,MAAQhnB,KAAKgwB,QAElBhwB,KAAK61B,OAAS71B,KAAKwlC,UAGnBxlC,KAAK6sB,IAAM,EACX7sB,KAAK8sB,OAAS9sB,KAAK61B,QAIrB71B,KAAKk1D,YAAc,EACnBl1D,KAAKg1D,WAAa,EAClBh1D,KAAKm1D,aAAe,EACpBn1D,KAAKi1D,cAAgB,CACvB,CACA4B,kBAAAA,GACEt5C,GAAKvd,KAAK8G,QAAQ+vD,mBAAoB,CAAC72D,MACzC,CAEAg4D,UAAAA,CAAWv4D,GACTO,KAAKiuB,MAAMgqC,cAAcx4D,EAAMO,KAAK01B,cACpCnY,GAAKvd,KAAK8G,QAAQrH,GAAO,CAACO,MAC5B,CAGA82D,gBAAAA,GACE92D,KAAKg4D,WAAW,mBAClB,CACAjB,mBAAAA,GAAuB,CACvBC,eAAAA,GACEh3D,KAAKg4D,WAAW,kBAClB,CAGAf,gBAAAA,GACEj3D,KAAKg4D,WAAW,mBAClB,CAIAd,UAAAA,GACE,MAAO,EACT,CACAC,eAAAA,GACEn3D,KAAKg4D,WAAW,kBAClB,CAEAE,2BAAAA,GACE36C,GAAKvd,KAAK8G,QAAQoxD,4BAA6B,CAACl4D,MAClD,CAKAm4D,kBAAAA,CAAmBnqC,GACjB,MAAMikC,EAAWjyD,KAAK8G,QAAQknB,MAC9B,IAAI7wB,EAAG8gB,EAAMkvB,EACb,IAAKhwC,EAAI,EAAG8gB,EAAO+P,EAAMpnB,OAAQzJ,EAAI8gB,EAAM9gB,IACzCgwC,EAAOnf,EAAM7wB,GACbgwC,EAAKyL,MAAQr7B,GAAK00C,EAAS10C,SAAU,CAAC4vB,EAAKvvC,MAAOT,EAAG6wB,GAAQhuB,KAEjE,CACAo4D,0BAAAA,GACE76C,GAAKvd,KAAK8G,QAAQsxD,2BAA4B,CAACp4D,MACjD,CAIAs3D,4BAAAA,GACE/5C,GAAKvd,KAAK8G,QAAQwwD,6BAA8B,CAACt3D,MACnD,CACAu3D,sBAAAA,GACE,MAAMzwD,EAAU9G,KAAK8G,QACfmrD,EAAWnrD,EAAQknB,MACnBqqC,EAAW1E,GAAc3zD,KAAKguB,MAAMpnB,OAAQE,EAAQknB,MAAMqkC,eAC1DniC,EAAc+hC,EAAS/hC,aAAe,EACtCC,EAAc8hC,EAAS9hC,YAC7B,IACIR,EAAW6V,EAAW8yB,EADtBlD,EAAgBllC,EAGpB,IAAKlwB,KAAKu4D,eAAiBtG,EAASjjC,SAAWkB,GAAeC,GAAekoC,GAAY,IAAMr4D,KAAK09C,eAElG,YADA19C,KAAKo1D,cAAgBllC,GAIvB,MAAMsoC,EAAax4D,KAAKy4D,iBAClBC,EAAgBF,EAAWG,OAAO3oC,MAClC4oC,EAAiBJ,EAAWK,QAAQhjC,OAIpCmE,EAAW/V,GAAYjkB,KAAKiuB,MAAM+B,MAAQ0oC,EAAe,EAAG14D,KAAKg6B,UACvErK,EAAY7oB,EAAQmoB,OAASjvB,KAAKg6B,SAAWq+B,EAAWr+B,GAAYq+B,EAAW,GAG3EK,EAAgB,EAAI/oC,IACtBA,EAAYqK,GAAYq+B,GAAYvxD,EAAQmoB,OAAS,GAAM,IAC3DuW,EAAYxlC,KAAKwlC,UAAY6uB,GAAkBvtD,EAAQwoB,MACvD2iC,EAASrlC,QAAU0nC,GAAextD,EAAQxH,MAAOU,KAAKiuB,MAAMnnB,QAAQsrB,MACpEkmC,EAAmBzwD,KAAK8Z,KAAK+2C,EAAgBA,EAAgBE,EAAiBA,GAC9ExD,EAAgB5yC,GAAU3a,KAAKiD,IAC7BjD,KAAKixD,KAAK70C,IAAau0C,EAAWK,QAAQhjC,OAAS,GAAKlG,GAAY,EAAG,IACvE9nB,KAAKixD,KAAK70C,GAAYuhB,EAAY8yB,GAAmB,EAAG,IAAMzwD,KAAKixD,KAAK70C,GAAY20C,EAAiBN,GAAmB,EAAG,MAE7HlD,EAAgBvtD,KAAKgD,IAAIqlB,EAAaroB,KAAKiD,IAAIqlB,EAAailC,KAG9Dp1D,KAAKo1D,cAAgBA,CACvB,CACAoC,2BAAAA,GACEj6C,GAAKvd,KAAK8G,QAAQ0wD,4BAA6B,CAACx3D,MAClD,CACAy3D,aAAAA,GAAiB,CAIjBC,SAAAA,GACEn6C,GAAKvd,KAAK8G,QAAQ4wD,UAAW,CAAC13D,MAChC,CACA+J,GAAAA,GAEE,MAAMg8C,EAAU,CACd/1B,MAAO,EACP6F,OAAQ,IAGJ,MAAC5H,EAAOnnB,SAAUknB,MAAOikC,EAAU3yD,MAAOy5D,EAAWzpC,KAAM0pC,IAAah5D,KACxEgvB,EAAUhvB,KAAKu4D,aACf7a,EAAe19C,KAAK09C,eAE1B,GAAI1uB,EAAS,CACX,MAAMiqC,EAAc3E,GAAeyE,EAAW9qC,EAAMnnB,QAAQsrB,MAU5D,GATIsrB,GACFqI,EAAQ/1B,MAAQhwB,KAAKg6B,SACrB+rB,EAAQlwB,OAASw+B,GAAkB2E,GAAYC,IAE/ClT,EAAQlwB,OAAS71B,KAAKwlC,UACtBugB,EAAQ/1B,MAAQqkC,GAAkB2E,GAAYC,GAI5ChH,EAASjjC,SAAWhvB,KAAKguB,MAAMpnB,OAAQ,CACzC,MAAM,MAAC8rD,EAAA,KAAO/tC,EAAA,OAAMg0C,EAAA,QAAQE,GAAW74D,KAAKy4D,iBACtCS,EAAiC,EAAnBjH,EAASrlC,QACvBusC,EAAe72C,GAAUtiB,KAAKo1D,eAC9BhrC,EAAMviB,KAAKuiB,IAAI+uC,GACfhwC,EAAMthB,KAAKshB,IAAIgwC,GAErB,GAAIzb,EAAc,CAEhB,MAAM0b,EAAcnH,EAAS7hC,OAAS,EAAIjH,EAAMwvC,EAAO3oC,MAAQ5F,EAAMyuC,EAAQhjC,OAC7EkwB,EAAQlwB,OAAShuB,KAAKiD,IAAI9K,KAAKwlC,UAAWugB,EAAQlwB,OAASujC,EAAcF,E,KACpE,CAGL,MAAMG,EAAapH,EAAS7hC,OAAS,EAAIhG,EAAMuuC,EAAO3oC,MAAQ7G,EAAM0vC,EAAQhjC,OAE5EkwB,EAAQ/1B,MAAQnoB,KAAKiD,IAAI9K,KAAKg6B,SAAU+rB,EAAQ/1B,MAAQqpC,EAAaH,E,CAEvEl5D,KAAKs5D,kBAAkB5G,EAAO/tC,EAAMwE,EAAKiB,E,EAI7CpqB,KAAKu5D,iBAED7b,GACF19C,KAAKgwB,MAAQhwB,KAAK+7C,QAAU9tB,EAAM+B,MAAQhwB,KAAK+0D,SAAShuC,KAAO/mB,KAAK+0D,SAAS/tC,MAC7EhnB,KAAK61B,OAASkwB,EAAQlwB,SAEtB71B,KAAKgwB,MAAQ+1B,EAAQ/1B,MACrBhwB,KAAK61B,OAAS71B,KAAK+7C,QAAU9tB,EAAM4H,OAAS71B,KAAK+0D,SAASloC,IAAM7sB,KAAK+0D,SAASjoC,OAElF,CAEAwsC,iBAAAA,CAAkB5G,EAAO/tC,EAAMwE,EAAKiB,GAClC,MAAO4D,OAAO,MAACpH,EAAA,QAAOgG,GAAQ,SAAEw7B,GAAYpoD,KAAK8G,QAC3C0yD,EAAmC,IAAvBx5D,KAAKo1D,cACjBqE,EAAgC,QAAbrR,GAAoC,MAAdpoD,KAAK8nB,KAEpD,GAAI9nB,KAAK09C,eAAgB,CACvB,MAAMgc,EAAa15D,KAAKi8C,gBAAgB,GAAKj8C,KAAK+mB,KAC5C4yC,EAAc35D,KAAKgnB,MAAQhnB,KAAKi8C,gBAAgBj8C,KAAKguB,MAAMpnB,OAAS,GAC1E,IAAIsuD,EAAc,EACdC,EAAe,EAIfqE,EACEC,GACFvE,EAAc9qC,EAAMsoC,EAAM1iC,MAC1BmlC,EAAehsC,EAAMxE,EAAKkR,SAE1Bq/B,EAAc/rC,EAAMupC,EAAM78B,OAC1Bs/B,EAAe/qC,EAAMzF,EAAKqL,OAET,UAAVpJ,EACTuuC,EAAexwC,EAAKqL,MACD,QAAVpJ,EACTsuC,EAAcxC,EAAM1iC,MACD,UAAVpJ,IACTsuC,EAAcxC,EAAM1iC,MAAQ,EAC5BmlC,EAAexwC,EAAKqL,MAAQ,GAI9BhwB,KAAKk1D,YAAcrtD,KAAKgD,KAAKqqD,EAAcwE,EAAa9sC,GAAW5sB,KAAKgwB,OAAShwB,KAAKgwB,MAAQ0pC,GAAa,GAC3G15D,KAAKm1D,aAAettD,KAAKgD,KAAKsqD,EAAewE,EAAc/sC,GAAW5sB,KAAKgwB,OAAShwB,KAAKgwB,MAAQ2pC,GAAc,E,KAC1G,CACL,IAAI3E,EAAarwC,EAAKkR,OAAS,EAC3Bo/B,EAAgBvC,EAAM78B,OAAS,EAErB,UAAVjP,GACFouC,EAAa,EACbC,EAAgBvC,EAAM78B,QACH,QAAVjP,IACTouC,EAAarwC,EAAKkR,OAClBo/B,EAAgB,GAGlBj1D,KAAKg1D,WAAaA,EAAapoC,EAC/B5sB,KAAKi1D,cAAgBA,EAAgBroC,C,CAEzC,CAMA2sC,cAAAA,GACMv5D,KAAK+0D,WACP/0D,KAAK+0D,SAAShuC,KAAOlf,KAAKgD,IAAI7K,KAAKk1D,YAAal1D,KAAK+0D,SAAShuC,MAC9D/mB,KAAK+0D,SAASloC,IAAMhlB,KAAKgD,IAAI7K,KAAKg1D,WAAYh1D,KAAK+0D,SAASloC,KAC5D7sB,KAAK+0D,SAAS/tC,MAAQnf,KAAKgD,IAAI7K,KAAKm1D,aAAcn1D,KAAK+0D,SAAS/tC,OAChEhnB,KAAK+0D,SAASjoC,OAASjlB,KAAKgD,IAAI7K,KAAKi1D,cAAej1D,KAAK+0D,SAASjoC,QAEtE,CAEA6qC,QAAAA,GACEp6C,GAAKvd,KAAK8G,QAAQ6wD,SAAU,CAAC33D,MAC/B,CAMA09C,YAAAA,GACE,MAAM,KAAC51B,EAAA,SAAMsgC,GAAYpoD,KAAK8G,QAC9B,MAAoB,QAAbshD,GAAmC,WAAbA,GAAkC,MAATtgC,CACxD,CAIA8xC,UAAAA,GACE,OAAO55D,KAAK8G,QAAQkkD,QACtB,CAMAqM,qBAAAA,CAAsBrpC,GAMpB,IAAI7wB,EAAG8gB,EACP,IANAje,KAAKk4D,8BAELl4D,KAAKm4D,mBAAmBnqC,GAInB7wB,EAAI,EAAG8gB,EAAO+P,EAAMpnB,OAAQzJ,EAAI8gB,EAAM9gB,IACrCsf,GAAcuR,EAAM7wB,GAAGy7C,SACzB5qB,EAAMpI,OAAOzoB,EAAG,GAChB8gB,IACA9gB,KAIJ6C,KAAKo4D,4BACP,CAMAK,cAAAA,GACE,IAAID,EAAax4D,KAAKw1D,YAEtB,IAAKgD,EAAY,CACf,MAAM9B,EAAa12D,KAAK8G,QAAQknB,MAAM0oC,WACtC,IAAI1oC,EAAQhuB,KAAKguB,MACb0oC,EAAa1oC,EAAMpnB,SACrBonB,EAAQ6lC,GAAO7lC,EAAO0oC,IAGxB12D,KAAKw1D,YAAcgD,EAAax4D,KAAK65D,mBAAmB7rC,EAAOA,EAAMpnB,OAAQ5G,KAAK8G,QAAQknB,MAAMqkC,c,CAGlG,OAAOmG,CACT,CAQAqB,kBAAAA,CAAmB7rC,EAAOpnB,EAAQyrD,GAChC,MAAM,IAAC5/B,EAAKgjC,kBAAmBrB,GAAUp0D,KACnC85D,EAAS,GACTC,EAAU,GACVhG,EAAYlsD,KAAKyZ,MAAM1a,EAAS+sD,GAAc/sD,EAAQyrD,IAC5D,IAEIl1D,EAAGkc,EAAG0b,EAAM6jB,EAAOohB,EAAUC,EAAYrlC,EAAOtC,EAAYtC,EAAO6F,EAAQqkC,EAF3EC,EAAkB,EAClBC,EAAmB,EAGvB,IAAKj9D,EAAI,EAAGA,EAAIyJ,EAAQzJ,GAAK42D,EAAW,CAQtC,GAPAnb,EAAQ5qB,EAAM7wB,GAAGy7C,MACjBohB,EAAWh6D,KAAKq6D,wBAAwBl9D,GACxCs1B,EAAIL,KAAO6nC,EAAaD,EAASzlC,OACjCK,EAAQw/B,EAAO6F,GAAc7F,EAAO6F,IAAe,CAACn6D,KAAM,CAAC,EAAGu0B,GAAI,IAClE/B,EAAa0nC,EAAS1nC,WACtBtC,EAAQ6F,EAAS,EAEZpZ,GAAcm8B,IAAWlrC,GAAQkrC,IAG/B,GAAIlrC,GAAQkrC,GAEjB,IAAKv/B,EAAI,EAAG0b,EAAO6jB,EAAMhyC,OAAQyS,EAAI0b,IAAQ1b,EAC3C6gD,EAAqCthB,EAAMv/B,GAEtCoD,GAAcy9C,IAAiBxsD,GAAQwsD,KAC1ClqC,EAAQoE,GAAa3B,EAAKmC,EAAM90B,KAAM80B,EAAMP,GAAIrE,EAAOkqC,GACvDrkC,GAAUvD,QATdtC,EAAQoE,GAAa3B,EAAKmC,EAAM90B,KAAM80B,EAAMP,GAAIrE,EAAO4oB,GACvD/iB,EAASvD,EAYXwnC,EAAOp6C,KAAKsQ,GACZ+pC,EAAQr6C,KAAKmW,GACbskC,EAAkBtyD,KAAKgD,IAAImlB,EAAOmqC,GAClCC,EAAmBvyD,KAAKgD,IAAIgrB,EAAQukC,EACtC,CACAvlC,GAAeu/B,EAAQxtD,GAEvB,MAAM+xD,EAASmB,EAAOp7C,QAAQy7C,GACxBtB,EAAUkB,EAAQr7C,QAAQ07C,GAE1BE,EAAWC,IAAA,CAAUvqC,MAAO8pC,EAAOS,IAAQ,EAAG1kC,OAAQkkC,EAAQQ,IAAQ,IAE5E,MAAO,CACL7H,MAAO4H,EAAQ,GACf31C,KAAM21C,EAAQ1zD,EAAS,GACvB+xD,OAAQ2B,EAAQ3B,GAChBE,QAASyB,EAAQzB,GACjBiB,SACAC,UAEJ,CAOAlhB,gBAAAA,CAAiBj7C,GACf,OAAOA,CACT,CASAsqB,gBAAAA,CAAiBtqB,EAAOoB,GACtB,OAAOm5C,GACT,CAQAsI,gBAAAA,CAAiBprB,GAAQ,CAQzB4mB,eAAAA,CAAgBj9C,GACd,MAAMgvB,EAAQhuB,KAAKguB,MACnB,OAAIhvB,EAAQ,GAAKA,EAAQgvB,EAAMpnB,OAAS,EAC/B,KAEF5G,KAAKkoB,iBAAiB8F,EAAMhvB,GAAOpB,MAC5C,CAQA2iD,kBAAAA,CAAmBia,GACbx6D,KAAKioD,iBACPuS,EAAU,EAAIA,GAGhB,MAAMnlC,EAAQr1B,KAAKggD,YAAcwa,EAAUx6D,KAAK+7C,QAChD,OAAO73B,GAAYlkB,KAAK83D,eAAiB1iC,GAAYp1B,KAAKiuB,MAAOoH,EAAO,GAAKA,EAC/E,CAMAolC,kBAAAA,CAAmBplC,GACjB,MAAMmlC,GAAWnlC,EAAQr1B,KAAKggD,aAAehgD,KAAK+7C,QAClD,OAAO/7C,KAAKioD,eAAiB,EAAIuS,EAAUA,CAC7C,CAOA7b,YAAAA,GACE,OAAO3+C,KAAKkoB,iBAAiBloB,KAAK06D,eACpC,CAKAA,YAAAA,GACE,MAAM,IAAC5vD,EAAG,IAAED,GAAO7K,KAEnB,OAAO8K,EAAM,GAAKD,EAAM,EAAIA,EAC1BC,EAAM,GAAKD,EAAM,EAAIC,EACrB,CACJ,CAKA4qB,UAAAA,CAAW12B,GACT,MAAMgvB,EAAQhuB,KAAKguB,OAAS,GAE5B,GAAIhvB,GAAS,GAAKA,EAAQgvB,EAAMpnB,OAAQ,CACtC,MAAMumC,EAAOnf,EAAMhvB,GACnB,OAAOmuC,EAAK2H,WACb3H,EAAK2H,SAAW0f,GAAkBx0D,KAAK01B,aAAc12B,EAAOmuC,G,CAE7D,OAAOntC,KAAK80C,WACZ90C,KAAK80C,SAAWyf,GAAmBv0D,KAAKiuB,MAAMyH,aAAc11B,MAC9D,CAMA+yD,SAAAA,GACE,MAAM4H,EAAc36D,KAAK8G,QAAQknB,MAG3B4sC,EAAMt4C,GAAUtiB,KAAKo1D,eACrBhrC,EAAMviB,KAAKqZ,IAAIrZ,KAAKuiB,IAAIwwC,IACxBzxC,EAAMthB,KAAKqZ,IAAIrZ,KAAKshB,IAAIyxC,IAExBpC,EAAax4D,KAAKy4D,iBAClB7rC,EAAU+tC,EAAYnqC,iBAAmB,EACzCrjB,EAAIqrD,EAAaA,EAAWG,OAAO3oC,MAAQpD,EAAU,EACrDhiB,EAAI4tD,EAAaA,EAAWK,QAAQhjC,OAASjJ,EAAU,EAG7D,OAAO5sB,KAAK09C,eACR9yC,EAAIwf,EAAMjd,EAAIgc,EAAMhc,EAAIid,EAAMxf,EAAIue,EAClCve,EAAIue,EAAMhc,EAAIid,EAAMxf,EAAIwf,EAAMjd,EAAIgc,CACxC,CAMAovC,UAAAA,GACE,MAAMvpC,EAAUhvB,KAAK8G,QAAQkoB,QAE7B,MAAgB,SAAZA,IACOA,EAGJhvB,KAAKwyC,0BAA0B5rC,OAAS,CACjD,CAKAi0D,qBAAAA,CAAsBpvB,GACpB,MAAM3jB,EAAO9nB,KAAK8nB,KACZmG,EAAQjuB,KAAKiuB,MACbnnB,EAAU9G,KAAK8G,SACf,KAACwoB,EAAI,SAAE84B,EAAA,OAAUv4B,GAAU/oB,EAC3BmoB,EAASK,EAAKL,OACdyuB,EAAe19C,KAAK09C,eACpB1vB,EAAQhuB,KAAKguB,MACb4lC,EAAc5lC,EAAMpnB,QAAUqoB,EAAS,EAAI,GAC3C6rC,EAAKzG,GAAkB/kC,GACvBxJ,EAAQ,GAERi1C,EAAalrC,EAAOsO,WAAWn+B,KAAK01B,cACpCslC,EAAYD,EAAW/rC,QAAU+rC,EAAW/qC,MAAQ,EACpDirC,EAAgBD,EAAY,EAC5BE,EAAmB,SAAS7lC,GAChC,OAAOD,GAAYnH,EAAOoH,EAAO2lC,EACnC,EACA,IAAIG,EAAah+D,EAAGg3D,EAAWiH,EAC3BC,EAAKC,EAAKC,EAAKC,EAAKC,EAAIC,EAAIC,EAAIC,EAEpC,GAAiB,QAAbxT,EACF+S,EAAcD,EAAiBl7D,KAAK8sB,QACpCwuC,EAAMt7D,KAAK8sB,OAASguC,EACpBU,EAAML,EAAcF,EACpBS,EAAKR,EAAiBzvB,EAAU5e,KAAOouC,EACvCW,EAAKnwB,EAAU3e,YACV,GAAiB,WAAbs7B,EACT+S,EAAcD,EAAiBl7D,KAAK6sB,KACpC6uC,EAAKjwB,EAAU5e,IACf+uC,EAAKV,EAAiBzvB,EAAU3e,QAAUmuC,EAC1CK,EAAMH,EAAcF,EACpBO,EAAMx7D,KAAK6sB,IAAMiuC,OACZ,GAAiB,SAAb1S,EACT+S,EAAcD,EAAiBl7D,KAAKgnB,OACpCq0C,EAAMr7D,KAAKgnB,MAAQ8zC,EACnBS,EAAMJ,EAAcF,EACpBQ,EAAKP,EAAiBzvB,EAAU1kB,MAAQk0C,EACxCU,EAAKlwB,EAAUzkB,WACV,GAAiB,UAAbohC,EACT+S,EAAcD,EAAiBl7D,KAAK+mB,MACpC00C,EAAKhwB,EAAU1kB,KACf40C,EAAKT,EAAiBzvB,EAAUzkB,OAASi0C,EACzCI,EAAMF,EAAcF,EACpBM,EAAMv7D,KAAK+mB,KAAO+zC,OACb,GAAa,MAAThzC,EAAc,CACvB,GAAiB,WAAbsgC,EACF+S,EAAcD,GAAkBzvB,EAAU5e,IAAM4e,EAAU3e,QAAU,EAAI,SACnE,GAAIlQ,GAASwrC,GAAW,CAC7B,MAAMyM,EAAiBn3D,OAAOgJ,KAAK0hD,GAAU,GACvCxqD,EAAQwqD,EAASyM,GACvBsG,EAAcD,EAAiBl7D,KAAKiuB,MAAMsF,OAAOshC,GAAgB3sC,iBAAiBtqB,G,CAGpF89D,EAAKjwB,EAAU5e,IACf+uC,EAAKnwB,EAAU3e,OACfwuC,EAAMH,EAAcF,EACpBO,EAAMF,EAAMR,C,MACP,GAAa,MAAThzC,EAAc,CACvB,GAAiB,WAAbsgC,EACF+S,EAAcD,GAAkBzvB,EAAU1kB,KAAO0kB,EAAUzkB,OAAS,QAC/D,GAAIpK,GAASwrC,GAAW,CAC7B,MAAMyM,EAAiBn3D,OAAOgJ,KAAK0hD,GAAU,GACvCxqD,EAAQwqD,EAASyM,GACvBsG,EAAcD,EAAiBl7D,KAAKiuB,MAAMsF,OAAOshC,GAAgB3sC,iBAAiBtqB,G,CAGpFy9D,EAAMF,EAAcF,EACpBM,EAAMF,EAAMP,EACZW,EAAKhwB,EAAU1kB,KACf40C,EAAKlwB,EAAUzkB,K,CAGjB,MAAM60C,EAAQ5+C,GAAenW,EAAQknB,MAAMqkC,cAAeuB,GACpDkI,EAAOj0D,KAAKgD,IAAI,EAAGhD,KAAKyrD,KAAKM,EAAciI,IACjD,IAAK1+D,EAAI,EAAGA,EAAIy2D,EAAaz2D,GAAK2+D,EAAM,CACtC,MAAM/pC,EAAU/xB,KAAK01B,WAAWv4B,GAC1B4+D,EAAczsC,EAAK6O,WAAWpM,GAC9BiqC,EAAoBnsC,EAAOsO,WAAWpM,GAEtCxC,EAAYwsC,EAAYxsC,UACxB0sC,EAAYF,EAAYxgD,MACxB6vB,EAAa4wB,EAAkBlsC,MAAQ,GACvCub,EAAmB2wB,EAAkBjsC,WAErCJ,EAAYosC,EAAYpsC,UACxBC,EAAYmsC,EAAYnsC,UACxBssC,EAAiBH,EAAYG,gBAAkB,GAC/CC,EAAuBJ,EAAYI,qBAEzChI,EAAYH,GAAoBh0D,KAAM7C,EAAG8xB,QAGvBtiB,IAAdwnD,IAIJiH,EAAmBhmC,GAAYnH,EAAOkmC,EAAW5kC,GAE7CmuB,EACF2d,EAAME,EAAME,EAAKE,EAAKP,EAEtBE,EAAME,EAAME,EAAKE,EAAKR,EAGxBt1C,EAAMpG,KAAK,CACT27C,MACAC,MACAC,MACAC,MACAC,KACAC,KACAC,KACAC,KACA5rC,MAAOT,EACPhU,MAAO0gD,EACP7wB,aACAC,mBACA1b,YACAC,YACAssC,iBACAC,yBAEJ,CAKA,OAHAn8D,KAAK81D,aAAelC,EACpB5zD,KAAK+1D,aAAeoF,EAEbr1C,CACT,CAKA0wC,kBAAAA,CAAmB/qB,GACjB,MAAM3jB,EAAO9nB,KAAK8nB,KACZhhB,EAAU9G,KAAK8G,SACf,SAACshD,EAAUp6B,MAAO2sC,GAAe7zD,EACjC42C,EAAe19C,KAAK09C,eACpB1vB,EAAQhuB,KAAKguB,OACb,MAACpH,EAAA,WAAOgK,EAAA,QAAYhE,EAAO,OAAEwD,GAAUuqC,EACvCG,EAAKzG,GAAkBvtD,EAAQwoB,MAC/B8sC,EAAiBtB,EAAKluC,EACtByvC,EAAkBjsC,GAAUxD,EAAUwvC,EACtC9lC,GAAYhU,GAAUtiB,KAAKo1D,eAC3BtvC,EAAQ,GACd,IAAI3oB,EAAG8gB,EAAMkvB,EAAMyL,EAAOpqC,EAAG6Q,EAAGoZ,EAAWpD,EAAOjD,EAAME,EAAYgqC,EAAWC,EAC3E7jC,EAAe,SAEnB,GAAiB,QAAb0vB,EACF/oC,EAAIrf,KAAK8sB,OAASuvC,EAClB5jC,EAAYz4B,KAAKw8D,+BACZ,GAAiB,WAAbpU,EACT/oC,EAAIrf,KAAK6sB,IAAMwvC,EACf5jC,EAAYz4B,KAAKw8D,+BACZ,GAAiB,SAAbpU,EAAqB,CAC9B,MAAM77C,EAAMvM,KAAKy8D,wBAAwB3B,GACzCriC,EAAYlsB,EAAIksB,UAChBjqB,EAAIjC,EAAIiC,C,MACH,GAAiB,UAAb45C,EAAsB,CAC/B,MAAM77C,EAAMvM,KAAKy8D,wBAAwB3B,GACzCriC,EAAYlsB,EAAIksB,UAChBjqB,EAAIjC,EAAIiC,C,MACH,GAAa,MAATsZ,EAAc,CACvB,GAAiB,WAAbsgC,EACF/oC,GAAMosB,EAAU5e,IAAM4e,EAAU3e,QAAU,EAAKsvC,OAC1C,GAAIx/C,GAASwrC,GAAW,CAC7B,MAAMyM,EAAiBn3D,OAAOgJ,KAAK0hD,GAAU,GACvCxqD,EAAQwqD,EAASyM,GACvBx1C,EAAIrf,KAAKiuB,MAAMsF,OAAOshC,GAAgB3sC,iBAAiBtqB,GAASw+D,C,CAElE3jC,EAAYz4B,KAAKw8D,yB,MACZ,GAAa,MAAT10C,EAAc,CACvB,GAAiB,WAAbsgC,EACF55C,GAAMi9B,EAAU1kB,KAAO0kB,EAAUzkB,OAAS,EAAKo1C,OAC1C,GAAIx/C,GAASwrC,GAAW,CAC7B,MAAMyM,EAAiBn3D,OAAOgJ,KAAK0hD,GAAU,GACvCxqD,EAAQwqD,EAASyM,GACvBrmD,EAAIxO,KAAKiuB,MAAMsF,OAAOshC,GAAgB3sC,iBAAiBtqB,E,CAEzD66B,EAAYz4B,KAAKy8D,wBAAwB3B,GAAIriC,S,CAGlC,MAAT3Q,IACY,UAAVlB,EACF8R,EAAe,MACI,QAAV9R,IACT8R,EAAe,WAInB,MAAM8/B,EAAax4D,KAAKy4D,iBACxB,IAAKt7D,EAAI,EAAG8gB,EAAO+P,EAAMpnB,OAAQzJ,EAAI8gB,IAAQ9gB,EAAG,CAC9CgwC,EAAOnf,EAAM7wB,GACby7C,EAAQzL,EAAKyL,MAEb,MAAMmjB,EAAcpB,EAAYx8B,WAAWn+B,KAAK01B,WAAWv4B,IAC3Dk4B,EAAQr1B,KAAKi8C,gBAAgB9+C,GAAKw9D,EAAYlqC,YAC9C2B,EAAOpyB,KAAKq6D,wBAAwBl9D,GACpCm1B,EAAaF,EAAKE,WAClBgqC,EAAY5uD,GAAQkrC,GAASA,EAAMhyC,OAAS,EAC5C,MAAM81D,EAAYJ,EAAY,EACxB/gD,EAAQwgD,EAAYxgD,MACpBse,EAAckiC,EAAYzrC,gBAC1BsJ,EAAcmiC,EAAY1rC,gBAChC,IA4CIyJ,EA5CA6iC,EAAgBlkC,EA8CpB,GA5CIilB,GACFlvC,EAAI6mB,EAEc,UAAdoD,IAEAkkC,EADEx/D,IAAM8gB,EAAO,EACEje,KAAK8G,QAAQ+W,QAAoB,OAAV,QACzB,IAAN1gB,EACQ6C,KAAK8G,QAAQ+W,QAAmB,QAAT,OAExB,UAMhB0+C,EAFa,QAAbnU,EACiB,SAAfx3B,GAAsC,IAAb0F,GACbgmC,EAAYhqC,EAAaA,EAAa,EAC5B,WAAf1B,GACK4nC,EAAWK,QAAQhjC,OAAS,EAAI6mC,EAAYpqC,EAAaA,GAEzDkmC,EAAWK,QAAQhjC,OAASvD,EAAa,EAItC,SAAf1B,GAAsC,IAAb0F,EACdhE,EAAa,EACF,WAAf1B,EACI4nC,EAAWK,QAAQhjC,OAAS,EAAI6mC,EAAYpqC,EAE5CkmC,EAAWK,QAAQhjC,OAASymC,EAAYhqC,EAGrDlC,IACFmsC,IAAe,GAEA,IAAbjmC,GAAmBylC,EAAYlrC,oBACjCriB,GAAK8jB,EAAc,EAAKzqB,KAAKshB,IAAImN,MAGnCjX,EAAIgW,EACJknC,GAAc,EAAID,GAAahqC,EAAa,GAK1CypC,EAAYlrC,kBAAmB,CACjC,MAAM+rC,EAAezhC,GAAU4gC,EAAYhrC,iBACrC8E,EAAS2iC,EAAWuB,QAAQ58D,GAC5B6yB,EAAQwoC,EAAWsB,OAAO38D,GAEhC,IAAI0vB,EAAM0vC,EAAaK,EAAa/vC,IAChC9F,EAAO,EAAI61C,EAAa71C,KAE5B,OAAQ2R,GACR,IAAK,SACH7L,GAAOgJ,EAAS,EAChB,MACF,IAAK,SACHhJ,GAAOgJ,EACP,MAKF,OAAQ4C,GACR,IAAK,SACH1R,GAAQiJ,EAAQ,EAChB,MACF,IAAK,QACHjJ,GAAQiJ,EACR,MACF,IAAK,QACC7yB,IAAM8gB,EAAO,EACf8I,GAAQiJ,EACC7yB,EAAI,IACb4pB,GAAQiJ,EAAQ,GAElB,MAKF8J,EAAW,CACT/S,OACA8F,MACAmD,MAAOA,EAAQ4sC,EAAa5sC,MAC5B6F,OAAQA,EAAS+mC,EAAa/mC,OAE9Bta,MAAOwgD,EAAYjrC,c,CAIvBhL,EAAMpG,KAAK,CACTk5B,QACAxmB,OACAmqC,aACAz1D,QAAS,CACPwvB,WACA/a,QACAse,cACAD,cACAnB,UAAWkkC,EACXjkC,eACAH,YAAa,CAAC/pB,EAAG6Q,GACjBya,aAGN,CAEA,OAAOhU,CACT,CAEA02C,uBAAAA,GACE,MAAM,SAACpU,EAAA,MAAUp6B,GAAShuB,KAAK8G,QACzBwvB,GAAYhU,GAAUtiB,KAAKo1D,eAEjC,GAAI9+B,EACF,MAAoB,QAAb8xB,EAAqB,OAAS,QAGvC,IAAIxhC,EAAQ,SAUZ,MARoB,UAAhBoH,EAAMpH,MACRA,EAAQ,OACiB,QAAhBoH,EAAMpH,MACfA,EAAQ,QACiB,UAAhBoH,EAAMpH,QACfA,EAAQ,SAGHA,CACT,CAEA61C,uBAAAA,CAAwB3B,GACtB,MAAM,SAAC1S,EAAUp6B,OAAO,WAAC4C,EAAA,OAAYR,EAAA,QAAQxD,IAAY5sB,KAAK8G,QACxD0xD,EAAax4D,KAAKy4D,iBAClB2D,EAAiBtB,EAAKluC,EACtB+rC,EAASH,EAAWG,OAAO3oC,MAEjC,IAAIyI,EACAjqB,EA0DJ,MAxDiB,SAAb45C,EACEh4B,GACF5hB,EAAIxO,KAAKgnB,MAAQ4F,EAEE,SAAfgE,EACF6H,EAAY,OACY,WAAf7H,GACT6H,EAAY,SACZjqB,GAAMmqD,EAAS,IAEflgC,EAAY,QACZjqB,GAAKmqD,KAGPnqD,EAAIxO,KAAKgnB,MAAQo1C,EAEE,SAAfxrC,EACF6H,EAAY,QACY,WAAf7H,GACT6H,EAAY,SACZjqB,GAAMmqD,EAAS,IAEflgC,EAAY,OACZjqB,EAAIxO,KAAK+mB,OAGS,UAAbqhC,EACLh4B,GACF5hB,EAAIxO,KAAK+mB,KAAO6F,EAEG,SAAfgE,EACF6H,EAAY,QACY,WAAf7H,GACT6H,EAAY,SACZjqB,GAAMmqD,EAAS,IAEflgC,EAAY,OACZjqB,GAAKmqD,KAGPnqD,EAAIxO,KAAK+mB,KAAOq1C,EAEG,SAAfxrC,EACF6H,EAAY,OACY,WAAf7H,GACT6H,EAAY,SACZjqB,GAAKmqD,EAAS,IAEdlgC,EAAY,QACZjqB,EAAIxO,KAAKgnB,QAIbyR,EAAY,QAGP,CAACA,YAAWjqB,IACrB,CAKAquD,iBAAAA,GACE,GAAI78D,KAAK8G,QAAQknB,MAAMoC,OACrB,OAGF,MAAMnC,EAAQjuB,KAAKiuB,MACbm6B,EAAWpoD,KAAK8G,QAAQshD,SAE9B,MAAiB,SAAbA,GAAoC,UAAbA,EAClB,CAACv7B,IAAK,EAAG9F,KAAM/mB,KAAK+mB,KAAM+F,OAAQmB,EAAM4H,OAAQ7O,MAAOhnB,KAAKgnB,OAClD,QAAbohC,GAAmC,WAAbA,EACnB,CAACv7B,IAAK7sB,KAAK6sB,IAAK9F,KAAM,EAAG+F,OAAQ9sB,KAAK8sB,OAAQ9F,MAAOiH,EAAM+B,YADlE,CAGJ,CAKA8sC,cAAAA,GACE,MAAM,IAACrqC,EAAK3rB,SAAS,gBAAC6qB,GAAgB,KAAE5K,EAAI,IAAE8F,EAAA,MAAKmD,EAAA,OAAO6F,GAAU71B,KAChE2xB,IACFc,EAAIqC,OACJrC,EAAI+F,UAAY7G,EAChBc,EAAIgH,SAAS1S,EAAM8F,EAAKmD,EAAO6F,GAC/BpD,EAAIyC,UAER,CAEAyrB,oBAAAA,CAAqB/iD,GACnB,MAAM0xB,EAAOtvB,KAAK8G,QAAQwoB,KAC1B,IAAKtvB,KAAKu4D,eAAiBjpC,EAAKN,QAC9B,OAAO,EAET,MAAMhB,EAAQhuB,KAAKguB,MACbhvB,EAAQgvB,EAAM5F,UAAUprB,GAAKA,EAAEY,QAAUA,GAC/C,GAAIoB,GAAS,EAAG,CACd,MAAMs5B,EAAOhJ,EAAK6O,WAAWn+B,KAAK01B,WAAW12B,IAC7C,OAAOs5B,EAAK/I,S,CAEd,OAAO,CACT,CAKAwtC,QAAAA,CAAStxB,GACP,MAAMnc,EAAOtvB,KAAK8G,QAAQwoB,KACpBmD,EAAMzyB,KAAKyyB,IACX3M,EAAQ9lB,KAAKs1D,iBAAmBt1D,KAAKs1D,eAAiBt1D,KAAK66D,sBAAsBpvB,IACvF,IAAItuC,EAAG8gB,EAEP,MAAM++C,EAAWA,CAAC7uD,EAAIC,EAAIlH,KACnBA,EAAM8oB,OAAU9oB,EAAMqU,QAG3BkX,EAAIqC,OACJrC,EAAIlD,UAAYroB,EAAM8oB,MACtByC,EAAI4G,YAAcnyB,EAAMqU,MACxBkX,EAAIwqC,YAAY/1D,EAAMkkC,YAAc,IACpC3Y,EAAIoyB,eAAiB39C,EAAMmkC,iBAE3B5Y,EAAIkE,YACJlE,EAAIsE,OAAO5oB,EAAGK,EAAGL,EAAGkR,GACpBoT,EAAIuE,OAAO5oB,EAAGI,EAAGJ,EAAGiR,GACpBoT,EAAI4E,SACJ5E,EAAIyC,YAGN,GAAI5F,EAAKN,QACP,IAAK7xB,EAAI,EAAG8gB,EAAO6H,EAAMlf,OAAQzJ,EAAI8gB,IAAQ9gB,EAAG,CAC9C,MAAM2B,EAAOgnB,EAAM3oB,GAEfmyB,EAAKE,iBACPwtC,EACE,CAACxuD,EAAG1P,EAAK28D,GAAIp8C,EAAGvgB,EAAK48D,IACrB,CAACltD,EAAG1P,EAAK68D,GAAIt8C,EAAGvgB,EAAK88D,IACrB98D,GAIAwwB,EAAKG,WACPutC,EACE,CAACxuD,EAAG1P,EAAKu8D,IAAKh8C,EAAGvgB,EAAKw8D,KACtB,CAAC9sD,EAAG1P,EAAKy8D,IAAKl8C,EAAGvgB,EAAK08D,KACtB,CACEjgD,MAAOzc,EAAK8wB,UACZI,MAAOlxB,EAAK6wB,UACZyb,WAAYtsC,EAAKo9D,eACjB7wB,iBAAkBvsC,EAAKq9D,sBAI/B,CAEJ,CAKAe,UAAAA,GACE,MAAM,MAACjvC,EAAA,IAAOwE,EAAK3rB,SAAS,OAAC+oB,EAAM,KAAEP,IAAStvB,KACxC+6D,EAAalrC,EAAOsO,WAAWn+B,KAAK01B,cACpCslC,EAAYnrC,EAAOb,QAAU+rC,EAAW/qC,MAAQ,EACtD,IAAKgrC,EACH,OAEF,MAAMmC,EAAgB7tC,EAAK6O,WAAWn+B,KAAK01B,WAAW,IAAInG,UACpD4rC,EAAcn7D,KAAK+1D,aACzB,IAAI0F,EAAIE,EAAID,EAAIE,EAEZ57D,KAAK09C,gBACP+d,EAAKrmC,GAAYnH,EAAOjuB,KAAK+mB,KAAMi0C,GAAaA,EAAY,EAC5DW,EAAKvmC,GAAYnH,EAAOjuB,KAAKgnB,MAAOm2C,GAAiBA,EAAgB,EACrEzB,EAAKE,EAAKT,IAEVO,EAAKtmC,GAAYnH,EAAOjuB,KAAK6sB,IAAKmuC,GAAaA,EAAY,EAC3DY,EAAKxmC,GAAYnH,EAAOjuB,KAAK8sB,OAAQqwC,GAAiBA,EAAgB,EACtE1B,EAAKE,EAAKR,GAEZ1oC,EAAIqC,OACJrC,EAAIlD,UAAYwrC,EAAW/qC,MAC3ByC,EAAI4G,YAAc0hC,EAAWx/C,MAE7BkX,EAAIkE,YACJlE,EAAIsE,OAAO0kC,EAAIC,GACfjpC,EAAIuE,OAAO2kC,EAAIC,GACfnpC,EAAI4E,SAEJ5E,EAAIyC,SACN,CAKAkoC,UAAAA,CAAW3xB,GACT,MAAMkvB,EAAc36D,KAAK8G,QAAQknB,MAEjC,IAAK2sC,EAAY3rC,QACf,OAGF,MAAMyD,EAAMzyB,KAAKyyB,IAEX8E,EAAOv3B,KAAK68D,oBACdtlC,GACFE,GAAShF,EAAK8E,GAGhB,MAAMzR,EAAQ9lB,KAAKu2D,cAAc9qB,GACjC,IAAK,MAAM3sC,KAAQgnB,EAAO,CACxB,MAAMu3C,EAAoBv+D,EAAKgI,QACzBkzD,EAAWl7D,EAAKszB,KAChBwmB,EAAQ95C,EAAK85C,MACbv5B,EAAIvgB,EAAKy9D,WACf7iC,GAAWjH,EAAKmmB,EAAO,EAAGv5B,EAAG26C,EAAUqD,EACzC,CAEI9lC,GACFG,GAAWjF,EAEf,CAKA6qC,SAAAA,GACE,MAAM,IAAC7qC,EAAK3rB,SAAS,SAACshD,EAAQ,MAAE9oD,EAAK,QAAEue,IAAY7d,KAEnD,IAAKV,EAAM0vB,QACT,OAGF,MAAMoD,EAAOgJ,GAAO97B,EAAM8yB,MACpBxF,EAAUuO,GAAU77B,EAAMstB,SAC1BhG,EAAQtnB,EAAMsnB,MACpB,IAAIqI,EAASmD,EAAKE,WAAa,EAEd,WAAb81B,GAAsC,WAAbA,GAAyBxrC,GAASwrC,IAC7Dn5B,GAAUrC,EAAQE,OACdpf,GAAQpO,EAAM2wB,QAChBhB,GAAUmD,EAAKE,YAAchzB,EAAM2wB,KAAKrpB,OAAS,KAGnDqoB,GAAUrC,EAAQC,IAGpB,MAAM,OAAC8nC,EAAA,OAAQC,EAAA,SAAQ56B,EAAQ,SAAE1D,GAAYo+B,GAAU10D,KAAMivB,EAAQm5B,EAAUxhC,GAE/E8S,GAAWjH,EAAKnzB,EAAM2wB,KAAM,EAAG,EAAGmC,EAAM,CACtC7W,MAAOjc,EAAMic,MACbye,WACA1D,WACAmC,UAAWg8B,GAAW7tC,EAAOwhC,EAAUvqC,GACvC6a,aAAc,SACdH,YAAa,CAACo8B,EAAQC,IAE1B,CAEA5nB,IAAAA,CAAKvB,GACEzrC,KAAKu4D,eAIVv4D,KAAK88D,iBACL98D,KAAK+8D,SAAStxB,GACdzrC,KAAKk9D,aACLl9D,KAAKs9D,YACLt9D,KAAKo9D,WAAW3xB,GAClB,CAMAyhB,OAAAA,GACE,MAAM50B,EAAOt4B,KAAK8G,QACZy2D,EAAKjlC,EAAKtK,OAASsK,EAAKtK,MAAMm/B,GAAK,EACnCqQ,EAAKvgD,GAAeqb,EAAKhJ,MAAQgJ,EAAKhJ,KAAK69B,GAAI,GAC/CsQ,EAAKxgD,GAAeqb,EAAKzI,QAAUyI,EAAKzI,OAAOs9B,EAAG,GAExD,OAAKntD,KAAKu4D,cAAgBv4D,KAAKgtC,OAAS8nB,GAAMh4D,UAAUkwC,KAUjD,CAAC,CACNmgB,EAAGqQ,EACHxwB,KAAOvB,IACLzrC,KAAK88D,iBACL98D,KAAK+8D,SAAStxB,GACdzrC,KAAKs9D,cAEN,CACDnQ,EAAGsQ,EACHzwB,KAAMA,KACJhtC,KAAKk9D,eAEN,CACD/P,EAAGoQ,EACHvwB,KAAOvB,IACLzrC,KAAKo9D,WAAW3xB,MAvBX,CAAC,CACN0hB,EAAGoQ,EACHvwB,KAAOvB,IACLzrC,KAAKgtC,KAAKvB,KAuBlB,CAOA+G,uBAAAA,CAAwB7yC,GACtB,MAAMw2D,EAAQn2D,KAAKiuB,MAAMq6B,+BACnBvH,EAAS/gD,KAAK8nB,KAAO,SACrBpG,EAAS,GACf,IAAIvkB,EAAG8gB,EAEP,IAAK9gB,EAAI,EAAG8gB,EAAOk4C,EAAMvvD,OAAQzJ,EAAI8gB,IAAQ9gB,EAAG,CAC9C,MAAMiqB,EAAO+uC,EAAMh5D,GACfiqB,EAAK25B,KAAY/gD,KAAK8J,IAAQnK,GAAQynB,EAAKznB,OAASA,GACtD+hB,EAAOhC,KAAK0H,EAEhB,CACA,OAAO1F,CACT,CAOA24C,uBAAAA,CAAwBr7D,GACtB,MAAMs5B,EAAOt4B,KAAK8G,QAAQknB,MAAMmQ,WAAWn+B,KAAK01B,WAAW12B,IAC3D,OAAOo8B,GAAO9C,EAAKlG,KACrB,CAKAsrC,UAAAA,GACE,MAAMC,EAAW39D,KAAKq6D,wBAAwB,GAAG/nC,WACjD,OAAQtyB,KAAK09C,eAAiB19C,KAAKgwB,MAAQhwB,KAAK61B,QAAU8nC,CAC5D,ECrqDa,MAAMC,GACnB/gE,WAAAA,CAAY8C,EAAM4xB,EAAOmC,GACvB1zB,KAAKL,KAAOA,EACZK,KAAKuxB,MAAQA,EACbvxB,KAAK0zB,SAAWA,EAChB1zB,KAAK8lB,MAAQpoB,OAAO6gB,OAAO,KAC7B,CAEAs/C,SAAAA,CAAUl+D,GACR,OAAOjC,OAAOZ,UAAUghE,cAAc1gE,KAAK4C,KAAKL,KAAK7C,UAAW6C,EAAK7C,UACvE,CAMAihE,QAAAA,CAASj/D,GACP,MAAM6b,EAAQjd,OAAO4/B,eAAex+B,GACpC,IAAIk/D,EAEAC,GAAkBtjD,KAEpBqjD,EAAch+D,KAAK+9D,SAASpjD,IAG9B,MAAMmL,EAAQ9lB,KAAK8lB,MACbhc,EAAKhL,EAAKgL,GACVynB,EAAQvxB,KAAKuxB,MAAQ,IAAMznB,EAEjC,IAAKA,EACH,MAAM,IAAIo1B,MAAM,2BAA6BpgC,GAG/C,OAAIgL,KAAMgc,IAKVA,EAAMhc,GAAMhL,EACZo/D,GAAiBp/D,EAAMyyB,EAAOysC,GAC1Bh+D,KAAK0zB,UACP/H,GAAS+H,SAAS50B,EAAKgL,GAAIhL,EAAKoyB,YANzBK,CAUX,CAMAhE,GAAAA,CAAIzjB,GACF,OAAO9J,KAAK8lB,MAAMhc,EACpB,CAKAq0D,UAAAA,CAAWr/D,GACT,MAAMgnB,EAAQ9lB,KAAK8lB,MACbhc,EAAKhL,EAAKgL,GACVynB,EAAQvxB,KAAKuxB,MAEfznB,KAAMgc,UACDA,EAAMhc,GAGXynB,GAASznB,KAAM6hB,GAAS4F,YACnB5F,GAAS4F,GAAOznB,GACnB9J,KAAK0zB,iBACAxC,GAAUpnB,GAGvB,EAGF,SAASo0D,GAAiBp/D,EAAMyyB,EAAOysC,GAErC,MAAMI,EAAet/C,GAAMphB,OAAO6gB,OAAO,MAAO,CAC9Cy/C,EAAcryC,GAAS4B,IAAIywC,GAAe,CAAC,EAC3CryC,GAAS4B,IAAIgE,GACbzyB,EAAK6sB,WAGPA,GAAS5F,IAAIwL,EAAO6sC,GAEhBt/D,EAAKu/D,eACPC,GAAc/sC,EAAOzyB,EAAKu/D,eAGxBv/D,EAAKqyB,aACPxF,GAASG,SAASyF,EAAOzyB,EAAKqyB,YAElC,CAEA,SAASmtC,GAAc/sC,EAAOgtC,GAC5B7gE,OAAOgJ,KAAK63D,GAAQl5C,QAAQhD,IAC1B,MAAMm8C,EAAgBn8C,EAAS7C,MAAM,KAC/Bi/C,EAAaD,EAAc38C,MAC3B68C,EAAc,CAACntC,GAAOqqB,OAAO4iB,GAAer/B,KAAK,KACjD5f,EAAQg/C,EAAOl8C,GAAU7C,MAAM,KAC/BoU,EAAarU,EAAMsC,MACnB8R,EAAcpU,EAAM4f,KAAK,KAC/BxT,GAASqF,MAAM0tC,EAAaD,EAAY9qC,EAAaC,IAEzD,CAEA,SAASqqC,GAAkBtjD,GACzB,MAAO,OAAQA,GAAS,aAAcA,CACxC,CC1GO,MAAMgkD,GACX9hE,WAAAA,GACEmD,KAAK4+D,YAAc,IAAIhB,GAAczpB,GAAmB,YAAY,GACpEn0C,KAAKkyB,SAAW,IAAI0rC,GAAc/L,GAAS,YAC3C7xD,KAAKozB,QAAU,IAAIwqC,GAAclgE,OAAQ,WACzCsC,KAAKuzB,OAAS,IAAIqqC,GAAc9I,GAAO,UAGvC90D,KAAK6+D,iBAAmB,CAAC7+D,KAAK4+D,YAAa5+D,KAAKuzB,OAAQvzB,KAAKkyB,SAC/D,CAKA8J,GAAAA,IAAOz8B,GACLS,KAAK8+D,MAAM,WAAYv/D,EACzB,CAEAuuC,MAAAA,IAAUvuC,GACRS,KAAK8+D,MAAM,aAAcv/D,EAC3B,CAKAw/D,cAAAA,IAAkBx/D,GAChBS,KAAK8+D,MAAM,WAAYv/D,EAAMS,KAAK4+D,YACpC,CAKAxpB,WAAAA,IAAe71C,GACbS,KAAK8+D,MAAM,WAAYv/D,EAAMS,KAAKkyB,SACpC,CAKA8sC,UAAAA,IAAcz/D,GACZS,KAAK8+D,MAAM,WAAYv/D,EAAMS,KAAKozB,QACpC,CAKA6rC,SAAAA,IAAa1/D,GACXS,KAAK8+D,MAAM,WAAYv/D,EAAMS,KAAKuzB,OACpC,CAMA2rC,aAAAA,CAAcp1D,GACZ,OAAO9J,KAAKm/D,KAAKr1D,EAAI9J,KAAK4+D,YAAa,aACzC,CAMAzX,UAAAA,CAAWr9C,GACT,OAAO9J,KAAKm/D,KAAKr1D,EAAI9J,KAAKkyB,SAAU,UACtC,CAMAktC,SAAAA,CAAUt1D,GACR,OAAO9J,KAAKm/D,KAAKr1D,EAAI9J,KAAKozB,QAAS,SACrC,CAMAisC,QAAAA,CAASv1D,GACP,OAAO9J,KAAKm/D,KAAKr1D,EAAI9J,KAAKuzB,OAAQ,QACpC,CAKA+rC,iBAAAA,IAAqB//D,GACnBS,KAAK8+D,MAAM,aAAcv/D,EAAMS,KAAK4+D,YACtC,CAKAW,cAAAA,IAAkBhgE,GAChBS,KAAK8+D,MAAM,aAAcv/D,EAAMS,KAAKkyB,SACtC,CAKAstC,aAAAA,IAAiBjgE,GACfS,KAAK8+D,MAAM,aAAcv/D,EAAMS,KAAKozB,QACtC,CAKAqsC,YAAAA,IAAgBlgE,GACdS,KAAK8+D,MAAM,aAAcv/D,EAAMS,KAAKuzB,OACtC,CAKAurC,KAAAA,CAAMx5C,EAAQ/lB,EAAMmgE,GAClB,IAAIngE,GAAM8lB,QAAQs6C,IAChB,MAAMC,EAAMF,GAAiB1/D,KAAK6/D,oBAAoBF,GAClDD,GAAiBE,EAAI/B,UAAU8B,IAASC,IAAQ5/D,KAAKozB,SAAWusC,EAAI71D,GACtE9J,KAAK8/D,MAAMx6C,EAAQs6C,EAAKD,GAMxBhiD,GAAKgiD,EAAK7gE,IAOR,MAAMihE,EAAUL,GAAiB1/D,KAAK6/D,oBAAoB/gE,GAC1DkB,KAAK8/D,MAAMx6C,EAAQy6C,EAASjhE,MAIpC,CAKAghE,KAAAA,CAAMx6C,EAAQ4hC,EAAU8Y,GACtB,MAAMC,EAAcngD,GAAYwF,GAChC/H,GAAKyiD,EAAU,SAAWC,GAAc,GAAID,GAC5C9Y,EAAS5hC,GAAQ06C,GACjBziD,GAAKyiD,EAAU,QAAUC,GAAc,GAAID,EAC7C,CAKAH,mBAAAA,CAAoBlgE,GAClB,IAAK,IAAIxC,EAAI,EAAGA,EAAI6C,KAAK6+D,iBAAiBj4D,OAAQzJ,IAAK,CACrD,MAAMyiE,EAAM5/D,KAAK6+D,iBAAiB1hE,GAClC,GAAIyiE,EAAI/B,UAAUl+D,GAChB,OAAOigE,CAEX,CAEA,OAAO5/D,KAAKozB,OACd,CAKA+rC,IAAAA,CAAKr1D,EAAI41D,EAAe//D,GACtB,MAAMb,EAAO4gE,EAAcnyC,IAAIzjB,GAC/B,QAAa6C,IAAT7N,EACF,MAAM,IAAIogC,MAAM,IAAMp1B,EAAK,yBAA2BnK,EAAO,KAE/D,OAAOb,CACT,EAKF,IAAAooD,GAA+B,IAAIyX,GCtKpB,MAAMuB,GACnBrjE,WAAAA,GACEmD,KAAKmgE,WAAQxzD,CACf,CAYAyzD,MAAAA,CAAOnyC,EAAOoyC,EAAM9gE,EAAMggC,GAMxB,GALa,eAAT8gC,IACFrgE,KAAKmgE,MAAQngE,KAAKsgE,mBAAmBryC,GAAO,GAC5CjuB,KAAKmsC,QAAQnsC,KAAKmgE,MAAOlyC,EAAO,iBAGfthB,IAAf3M,KAAKmgE,MACP,OAGF,MAAMhvC,EAAcoO,EAASv/B,KAAKyxB,aAAaxD,GAAOsR,OAAOA,GAAUv/B,KAAKyxB,aAAaxD,GACnFvM,EAAS1hB,KAAKmsC,QAAQhb,EAAalD,EAAOoyC,EAAM9gE,GAOtD,MALa,iBAAT8gE,IACFrgE,KAAKmsC,QAAQhb,EAAalD,EAAO,QACjCjuB,KAAKmsC,QAAQnsC,KAAKmgE,MAAOlyC,EAAO,aAChCjuB,KAAKmgE,WAAQxzD,GAER+U,CACT,CAKAyqB,OAAAA,CAAQhb,EAAalD,EAAOoyC,EAAM9gE,GAChCA,EAAOA,GAAQ,CAAC,EAChB,IAAK,MAAMghE,KAAcpvC,EAAa,CACpC,MAAMqvC,EAASD,EAAWC,OACpBl7C,EAASk7C,EAAOH,GAChBzV,EAAS,CAAC38B,EAAO1uB,EAAMghE,EAAWz5D,SACxC,IAA6C,IAAzCyW,GAAa+H,EAAQslC,EAAQ4V,IAAqBjhE,EAAKkhE,WACzD,OAAO,CAEX,CAEA,OAAO,CACT,CAEAC,UAAAA,GAMOjkD,GAAczc,KAAK1B,UACtB0B,KAAK2gE,UAAY3gE,KAAK1B,OACtB0B,KAAK1B,YAASqO,EAElB,CAMA8kB,YAAAA,CAAaxD,GACX,GAAIjuB,KAAK1B,OACP,OAAO0B,KAAK1B,OAGd,MAAM6yB,EAAcnxB,KAAK1B,OAAS0B,KAAKsgE,mBAAmBryC,GAI1D,OAFAjuB,KAAK4gE,oBAAoB3yC,GAElBkD,CACT,CAEAmvC,kBAAAA,CAAmBryC,EAAOuiB,GACxB,MAAMhB,EAASvhB,GAASA,EAAMuhB,OACxB1oC,EAAUmW,GAAeuyB,EAAO1oC,SAAW0oC,EAAO1oC,QAAQssB,QAAS,CAAC,GACpEA,EAAUytC,GAAWrxB,GAE3B,OAAmB,IAAZ1oC,GAAsB0pC,EAAWswB,GAAkB7yC,EAAOmF,EAAStsB,EAAS0pC,GAAhD,EACrC,CAMAowB,mBAAAA,CAAoB3yC,GAClB,MAAM8yC,EAAsB/gE,KAAK2gE,WAAa,GACxCxvC,EAAcnxB,KAAK1B,OACnBmpD,EAAOA,CAAC/7C,EAAGC,IAAMD,EAAE6zB,OAAO/wB,IAAM7C,EAAEq1D,KAAK3hD,GAAK7Q,EAAEgyD,OAAO12D,KAAOuV,EAAEmhD,OAAO12D,KAC3E9J,KAAKmsC,QAAQsb,EAAKsZ,EAAqB5vC,GAAclD,EAAO,QAC5DjuB,KAAKmsC,QAAQsb,EAAKt2B,EAAa4vC,GAAsB9yC,EAAO,QAC9D,EAMF,SAAS4yC,GAAWrxB,GAClB,MAAMyxB,EAAW,CAAC,EACZ7tC,EAAU,GACV1sB,EAAOhJ,OAAOgJ,KAAKwgD,GAAS9zB,QAAQtN,OAC1C,IAAK,IAAI3oB,EAAI,EAAGA,EAAIuJ,EAAKE,OAAQzJ,IAC/Bi2B,EAAQ1T,KAAKwnC,GAASkY,UAAU14D,EAAKvJ,KAGvC,MAAM82B,EAAQub,EAAOpc,SAAW,GAChC,IAAK,IAAIj2B,EAAI,EAAGA,EAAI82B,EAAMrtB,OAAQzJ,IAAK,CACrC,MAAMqjE,EAASvsC,EAAM92B,IAEY,IAA7Bi2B,EAAQ1U,QAAQ8hD,KAClBptC,EAAQ1T,KAAK8gD,GACbS,EAAST,EAAO12D,KAAM,EAE1B,CAEA,MAAO,CAACspB,UAAS6tC,WACnB,CAEA,SAASC,GAAQp6D,EAAS0pC,GACxB,OAAKA,IAAmB,IAAZ1pC,GAGI,IAAZA,EACK,CAAC,EAEHA,EALE,IAMX,CAEA,SAASg6D,GAAkB7yC,GAAO,QAACmF,EAAO,SAAE6tC,GAAWn6D,EAAS0pC,GAC9D,MAAM9uB,EAAS,GACTqQ,EAAU9D,EAAMyH,aAEtB,IAAK,MAAM8qC,KAAUptC,EAAS,CAC5B,MAAMtpB,EAAK02D,EAAO12D,GACZwuB,EAAO4oC,GAAQp6D,EAAQgD,GAAK0mC,GACrB,OAATlY,GAGJ5W,EAAOhC,KAAK,CACV8gD,SACA15D,QAASq6D,GAAWlzC,EAAMuhB,OAAQ,CAACgxB,SAAQvsC,MAAOgtC,EAASn3D,IAAMwuB,EAAMvG,IAE3E,CAEA,OAAOrQ,CACT,CAEA,SAASy/C,GAAW3xB,GAAQ,OAACgxB,EAAM,MAAEvsC,GAAQqE,EAAMvG,GACjD,MAAMrrB,EAAO8oC,EAAO4xB,gBAAgBZ,GAC9BpkC,EAASoT,EAAO2H,gBAAgB7e,EAAM5xB,GAK5C,OAJIutB,GAASusC,EAAO70C,UAElByQ,EAAO1c,KAAK8gD,EAAO70C,UAEd6jB,EAAO4H,eAAehb,EAAQrK,EAAS,CAAC,IAAK,CAElDwM,YAAY,EACZC,WAAW,EACXF,SAAS,GAEb,CCvLO,SAAS+iC,GAAa1hE,EAAMmH,GACjC,MAAMw6D,EAAkB31C,GAASkG,SAASlyB,IAAS,CAAC,EAC9C4hE,GAAkBz6D,EAAQ+qB,UAAY,CAAC,GAAGlyB,IAAS,CAAC,EAC1D,OAAO4hE,EAAe3uC,WAAa9rB,EAAQ8rB,WAAa0uC,EAAgB1uC,WAAa,GACvF,CAEA,SAAS4uC,GAA0B13D,EAAI8oB,GACrC,IAAI9K,EAAOhe,EAMX,MALW,YAAPA,EACFge,EAAO8K,EACS,YAAP9oB,IACTge,EAAqB,MAAd8K,EAAoB,IAAM,KAE5B9K,CACT,CAEA,SAAS25C,GAA0B35C,EAAM8K,GACvC,OAAO9K,IAAS8K,EAAY,UAAY,SAC1C,CAEA,SAAS8uC,GAAc53D,GACrB,GAAW,MAAPA,GAAqB,MAAPA,GAAqB,MAAPA,EAC9B,OAAOA,CAEX,CAEA,SAAS63D,GAAiBvZ,GACxB,MAAiB,QAAbA,GAAmC,WAAbA,EACjB,IAEQ,SAAbA,GAAoC,UAAbA,EAClB,SADT,CAGF,CAEO,SAASwZ,GAAc93D,KAAO+3D,GACnC,GAAIH,GAAc53D,GAChB,OAAOA,EAET,IAAK,MAAMwuB,KAAQupC,EAAc,CAC/B,MAAM/5C,EAAOwQ,EAAKxQ,MACb65C,GAAiBrpC,EAAK8vB,WACtBt+C,EAAGlD,OAAS,GAAK86D,GAAc53D,EAAG,GAAG+P,eAC1C,GAAIiO,EACF,OAAOA,CAEX,CACA,MAAM,IAAIoX,MAAM,6BAA6Bp1B,uDAC/C,CAEA,SAASg4D,GAAmBh4D,EAAIge,EAAMD,GACpC,GAAIA,EAAQC,EAAO,YAAche,EAC/B,MAAO,CAACge,OAEZ,CAEA,SAASi6C,GAAyBj4D,EAAI0lC,GACpC,GAAIA,EAAO1vC,MAAQ0vC,EAAO1vC,KAAK+xB,SAAU,CACvC,MAAMmwC,EAAUxyB,EAAO1vC,KAAK+xB,SAAS0N,OAAQ1zB,GAAMA,EAAE6pC,UAAY5rC,GAAM+B,EAAE+pC,UAAY9rC,GACrF,GAAIk4D,EAAQp7D,OACV,OAAOk7D,GAAmBh4D,EAAI,IAAKk4D,EAAQ,KAAOF,GAAmBh4D,EAAI,IAAKk4D,EAAQ,G,CAG1F,MAAO,CAAC,CACV,CAEA,SAASC,GAAiBzyB,EAAQ1oC,GAChC,MAAMo7D,EAAgBhxC,GAAUse,EAAO7vC,OAAS,CAAC4zB,OAAQ,CAAC,GACpD4uC,EAAer7D,EAAQysB,QAAU,CAAC,EAClC6uC,EAAiBf,GAAa7xB,EAAO7vC,KAAMmH,GAC3CysB,EAAS71B,OAAO6gB,OAAO,MAqC7B,OAlCA7gB,OAAOgJ,KAAKy7D,GAAc98C,QAAQvb,IAChC,MAAMu4D,EAAYF,EAAar4D,GAC/B,IAAK8S,GAASylD,GACZ,OAAO/mC,QAAQgnC,MAAM,0CAA0Cx4D,KAEjE,GAAIu4D,EAAUtkC,OACZ,OAAOzC,QAAQC,KAAK,kDAAkDzxB,KAExE,MAAMge,EAAO85C,GAAc93D,EAAIu4D,EAAWN,GAAyBj4D,EAAI0lC,GAAS7jB,GAAS4H,OAAO8uC,EAAU1iE,OACpG4iE,EAAYd,GAA0B35C,EAAMs6C,GAC5CI,EAAsBN,EAAc3uC,QAAU,CAAC,EACrDA,EAAOzpB,GAAMmV,GAAQvhB,OAAO6gB,OAAO,MAAO,CAAC,CAACuJ,QAAOu6C,EAAWG,EAAoB16C,GAAO06C,EAAoBD,OAI/G/yB,EAAO1vC,KAAK+xB,SAASxM,QAAQwC,IAC3B,MAAMloB,EAAOkoB,EAAQloB,MAAQ6vC,EAAO7vC,KAC9BizB,EAAY/K,EAAQ+K,WAAayuC,GAAa1hE,EAAMmH,GACpDw6D,EAAkBpwC,GAAUvxB,IAAS,CAAC,EACtC6iE,EAAsBlB,EAAgB/tC,QAAU,CAAC,EACvD71B,OAAOgJ,KAAK87D,GAAqBn9C,QAAQo9C,IACvC,MAAM36C,EAAO05C,GAA0BiB,EAAW7vC,GAC5C9oB,EAAK+d,EAAQC,EAAO,WAAaA,EACvCyL,EAAOzpB,GAAMypB,EAAOzpB,IAAOpM,OAAO6gB,OAAO,MACzCU,GAAQsU,EAAOzpB,GAAK,CAAC,CAACge,QAAOq6C,EAAar4D,GAAK04D,EAAoBC,SAKvE/kE,OAAOgJ,KAAK6sB,GAAQlO,QAAQtmB,IAC1B,MAAMu0B,EAAQC,EAAOx0B,GACrBkgB,GAAQqU,EAAO,CAAC3H,GAAS4H,OAAOD,EAAM3zB,MAAOgsB,GAAS2H,UAGjDC,CACT,CAEA,SAASmvC,GAAYlzB,GACnB,MAAM1oC,EAAU0oC,EAAO1oC,UAAY0oC,EAAO1oC,QAAU,CAAC,GAErDA,EAAQssB,QAAUnW,GAAenW,EAAQssB,QAAS,CAAC,GACnDtsB,EAAQysB,OAAS0uC,GAAiBzyB,EAAQ1oC,EAC5C,CAEA,SAAS67D,GAAS7iE,GAIhB,OAHAA,EAAOA,GAAQ,CAAC,EAChBA,EAAK+xB,SAAW/xB,EAAK+xB,UAAY,GACjC/xB,EAAK43C,OAAS53C,EAAK43C,QAAU,GACtB53C,CACT,CAEA,SAAS8iE,GAAWpzB,GAMlB,OALAA,EAASA,GAAU,CAAC,EACpBA,EAAO1vC,KAAO6iE,GAASnzB,EAAO1vC,MAE9B4iE,GAAYlzB,GAELA,CACT,CAEA,MAAMqzB,GAAW,IAAI71C,IACf81C,GAAa,IAAI98C,IAEvB,SAAS+8C,GAAW51C,EAAU61C,GAC5B,IAAIt8D,EAAOm8D,GAASt1C,IAAIJ,GAMxB,OALKzmB,IACHA,EAAOs8D,IACPH,GAAS98C,IAAIoH,EAAUzmB,GACvBo8D,GAAW9mC,IAAIt1B,IAEVA,CACT,CAEA,MAAMu8D,GAAaA,CAACl9C,EAAK1K,EAAKtc,KAC5B,MAAMu5B,EAAO1Y,GAAiBvE,EAAKtc,QACtB4N,IAAT2rB,GACFvS,EAAIiW,IAAI1D,IAIG,MAAM4qC,GACnBrmE,WAAAA,CAAY2yC,GACVxvC,KAAKmjE,QAAUP,GAAWpzB,GAC1BxvC,KAAKojE,YAAc,IAAIp2C,IACvBhtB,KAAKqjE,eAAiB,IAAIr2C,GAC5B,CAEA,YAAIgF,GACF,OAAOhyB,KAAKmjE,QAAQnxC,QACtB,CAEA,QAAIryB,GACF,OAAOK,KAAKmjE,QAAQxjE,IACtB,CAEA,QAAIA,CAAKA,GACPK,KAAKmjE,QAAQxjE,KAAOA,CACtB,CAEA,QAAIG,GACF,OAAOE,KAAKmjE,QAAQrjE,IACtB,CAEA,QAAIA,CAAKA,GACPE,KAAKmjE,QAAQrjE,KAAO6iE,GAAS7iE,EAC/B,CAEA,WAAIgH,GACF,OAAO9G,KAAKmjE,QAAQr8D,OACtB,CAEA,WAAIA,CAAQA,GACV9G,KAAKmjE,QAAQr8D,QAAUA,CACzB,CAEA,WAAIssB,GACF,OAAOpzB,KAAKmjE,QAAQ/vC,OACtB,CAEA4b,MAAAA,GACE,MAAMQ,EAASxvC,KAAKmjE,QACpBnjE,KAAKsjE,aACLZ,GAAYlzB,EACd,CAEA8zB,UAAAA,GACEtjE,KAAKojE,YAAYG,QACjBvjE,KAAKqjE,eAAeE,OACtB,CAQArsB,gBAAAA,CAAiBssB,GACf,OAAOT,GAAWS,EAChB,IAAM,CAAC,CACL,YAAYA,IACZ,KAEN,CASAhqB,yBAAAA,CAA0BgqB,EAAajqB,GACrC,OAAOwpB,GAAW,GAAGS,gBAA0BjqB,IAC7C,IAAM,CACJ,CACE,YAAYiqB,iBAA2BjqB,IACvC,eAAeA,KAGjB,CACE,YAAYiqB,IACZ,KAGR,CAUArqB,uBAAAA,CAAwBqqB,EAAavqB,GACnC,OAAO8pB,GAAW,GAAGS,KAAevqB,IAClC,IAAM,CAAC,CACL,YAAYuqB,cAAwBvqB,IACpC,YAAYuqB,IACZ,YAAYvqB,IACZ,KAEN,CAOAmoB,eAAAA,CAAgBZ,GACd,MAAM12D,EAAK02D,EAAO12D,GACZnK,EAAOK,KAAKL,KAClB,OAAOojE,GAAW,GAAGpjE,YAAemK,IAClC,IAAM,CAAC,CACL,WAAWA,OACR02D,EAAOiD,wBAA0B,KAE1C,CAKAC,aAAAA,CAAcC,EAAWC,GACvB,MAAMR,EAAcpjE,KAAKojE,YACzB,IAAIxuC,EAAQwuC,EAAY71C,IAAIo2C,GAK5B,OAJK/uC,IAASgvC,IACZhvC,EAAQ,IAAI5H,IACZo2C,EAAYr9C,IAAI49C,EAAW/uC,IAEtBA,CACT,CAQAuiB,eAAAA,CAAgBwsB,EAAWE,EAAUD,GACnC,MAAM,QAAC98D,EAAO,KAAEnH,GAAQK,KAClB40B,EAAQ50B,KAAK0jE,cAAcC,EAAWC,GACtC/vB,EAASjf,EAAMrH,IAAIs2C,GACzB,GAAIhwB,EACF,OAAOA,EAGT,MAAMzX,EAAS,IAAIpW,IAEnB69C,EAASx+C,QAAQ3e,IACXi9D,IACFvnC,EAAOJ,IAAI2nC,GACXj9D,EAAK2e,QAAQtmB,GAAOkkE,GAAW7mC,EAAQunC,EAAW5kE,KAEpD2H,EAAK2e,QAAQtmB,GAAOkkE,GAAW7mC,EAAQt1B,EAAS/H,IAChD2H,EAAK2e,QAAQtmB,GAAOkkE,GAAW7mC,EAAQlL,GAAUvxB,IAAS,CAAC,EAAGZ,IAC9D2H,EAAK2e,QAAQtmB,GAAOkkE,GAAW7mC,EAAQzQ,GAAU5sB,IACjD2H,EAAK2e,QAAQtmB,GAAOkkE,GAAW7mC,EAAQjL,GAAapyB,MAGtD,MAAMqjB,EAAQ3U,MAAM0M,KAAKiiB,GAOzB,OANqB,IAAjBha,EAAMxb,QACRwb,EAAM1C,KAAKhiB,OAAO6gB,OAAO,OAEvBukD,GAAW3iD,IAAI0jD,IACjBjvC,EAAM7O,IAAI89C,EAAUzhD,GAEfA,CACT,CAMA0hD,iBAAAA,GACE,MAAM,QAACh9D,EAAO,KAAEnH,GAAQK,KAExB,MAAO,CACL8G,EACAoqB,GAAUvxB,IAAS,CAAC,EACpBgsB,GAASkG,SAASlyB,IAAS,CAAC,EAC5B,CAACA,QACDgsB,GACAwF,GAEJ,CASAioB,mBAAAA,CAAoBhd,EAAQ1iB,EAAOqY,EAASsK,EAAW,CAAC,KACtD,MAAM3a,EAAS,CAACyuB,SAAS,IACnB,SAACtwB,EAAQ,YAAEkkD,GAAeC,GAAYhkE,KAAKqjE,eAAgBjnC,EAAQC,GACzE,IAAIv1B,EAAU+Y,EACd,GAAIokD,GAAYpkD,EAAUnG,GAAQ,CAChCgI,EAAOyuB,SAAU,EACjBpe,EAAU9R,GAAW8R,GAAWA,IAAYA,EAE5C,MAAMmyC,EAAclkE,KAAKo3C,eAAehb,EAAQrK,EAASgyC,GACzDj9D,EAAU62B,GAAe9d,EAAUkS,EAASmyC,E,CAG9C,IAAK,MAAMlpC,KAAQthB,EACjBgI,EAAOsZ,GAAQl0B,EAAQk0B,GAEzB,OAAOtZ,CACT,CAQA01B,cAAAA,CAAehb,EAAQrK,EAASsK,EAAW,CAAC,IAAKyB,GAC/C,MAAM,SAACje,GAAYmkD,GAAYhkE,KAAKqjE,eAAgBjnC,EAAQC,GAC5D,OAAOzf,GAASmV,GACZ4L,GAAe9d,EAAUkS,OAASplB,EAAWmxB,GAC7Cje,CACN,EAGF,SAASmkD,GAAYG,EAAe/nC,EAAQC,GAC1C,IAAIzH,EAAQuvC,EAAc52C,IAAI6O,GACzBxH,IACHA,EAAQ,IAAI5H,IACZm3C,EAAcp+C,IAAIqW,EAAQxH,IAE5B,MAAMzH,EAAWkP,EAAS8C,OAC1B,IAAI0U,EAASjf,EAAMrH,IAAIJ,GACvB,IAAK0mB,EAAQ,CACX,MAAMh0B,EAAWsc,GAAgBC,EAAQC,GACzCwX,EAAS,CACPh0B,WACAkkD,YAAa1nC,EAASkD,OAAO3jB,IAAMA,EAAE/B,cAAcgV,SAAS,WAE9D+F,EAAM7O,IAAIoH,EAAU0mB,E,CAEtB,OAAOA,CACT,CAEA,MAAMuwB,GAAcxmE,GAASgf,GAAShf,IACjCF,OAAOmyC,oBAAoBjyC,GAAOojE,KAAMjiE,GAAQkhB,GAAWriB,EAAMmB,KAEtE,SAASklE,GAAYrmC,EAAOlkB,GAC1B,MAAM,aAACglB,EAAY,YAAEC,GAAelN,GAAamM,GAEjD,IAAK,MAAM5C,KAAQthB,EAAO,CACxB,MAAM6kB,EAAaG,EAAa1D,GAC1BwD,EAAYG,EAAY3D,GACxBp9B,GAAS4gC,GAAaD,IAAeX,EAAM5C,GACjD,GAAKuD,IAAete,GAAWriB,IAAUwmE,GAAYxmE,KAC/C4gC,GAAa9wB,GAAQ9P,GACzB,OAAO,CAEX,CACA,OAAO,CACT,C,eC9YA,MAAMymE,GAAkB,CAAC,MAAO,SAAU,OAAQ,QAAS,aAC3D,SAASC,GAAqBlc,EAAUtgC,GACtC,MAAoB,QAAbsgC,GAAmC,WAAbA,IAAiE,IAAvCic,GAAgB3lD,QAAQ0pC,IAA6B,MAATtgC,CACrG,CAEA,SAASy8C,GAAcC,EAAIC,GACzB,OAAO,SAAS/4D,EAAGC,GACjB,OAAOD,EAAE84D,KAAQ74D,EAAE64D,GACf94D,EAAE+4D,GAAM94D,EAAE84D,GACV/4D,EAAE84D,GAAM74D,EAAE64D,EAChB,CACF,CAEA,SAASE,GAAqB3yC,GAC5B,MAAM9D,EAAQ8D,EAAQ9D,MAChB0hB,EAAmB1hB,EAAMnnB,QAAQslB,UAEvC6B,EAAMgqC,cAAc,eACpB16C,GAAaoyB,GAAoBA,EAAiBg1B,WAAY,CAAC5yC,GAAU9D,EAC3E,CAEA,SAAS22C,GAAoB7yC,GAC3B,MAAM9D,EAAQ8D,EAAQ9D,MAChB0hB,EAAmB1hB,EAAMnnB,QAAQslB,UACvC7O,GAAaoyB,GAAoBA,EAAiBk1B,WAAY,CAAC9yC,GAAU9D,EAC3E,CAMA,SAAS62C,GAAUhmE,GAYjB,OAXImkC,MAAqC,kBAATnkC,EAC9BA,EAAOokC,SAAS6hC,eAAejmE,GACtBA,GAAQA,EAAK8H,SAEtB9H,EAAOA,EAAK,IAGVA,GAAQA,EAAK22B,SAEf32B,EAAOA,EAAK22B,QAEP32B,CACT,CAEA,MAAMkmE,GAAY,CAAC,EACbC,GAAYlmE,IAChB,MAAM02B,EAASqvC,GAAU/lE,GACzB,OAAOrB,OAAOqnB,OAAOigD,IAAWzlC,OAAQ3zB,GAAMA,EAAE6pB,SAAWA,GAAQ5T,OAGrE,SAASqjD,GAAgB7pD,EAAKqI,EAAOm3B,GACnC,MAAMn0C,EAAOhJ,OAAOgJ,KAAK2U,GACzB,IAAK,MAAMtc,KAAO2H,EAAM,CACtB,MAAMy+D,GAAUpmE,EAChB,GAAIomE,GAAUzhD,EAAO,CACnB,MAAM9lB,EAAQyd,EAAItc,UACXsc,EAAItc,IACP87C,EAAO,GAAKsqB,EAASzhD,KACvBrI,EAAI8pD,EAAStqB,GAAQj9C,E,CAG3B,CACF,CASA,SAASwnE,GAAmBloE,EAAGmoE,EAAWC,EAAaC,GACrD,OAAKD,GAA0B,aAAXpoE,EAAEyC,KAGlB4lE,EACKF,EAEFnoE,EALE,IAMX,CAEA,MAAMsoE,GASJ,eAAOzH,IAAYj4C,GACjBohC,GAASlrB,OAAOlW,GAChB2/C,IACF,CAEA,iBAAOtH,IAAcr4C,GACnBohC,GAASpZ,UAAUhoB,GACnB2/C,IACF,CAGA5oE,WAAAA,CAAYiC,EAAM4mE,GAChB,MAAMl2B,EAASxvC,KAAKwvC,OAAS,IAAI0zB,GAAOwC,GAClCC,EAAgBb,GAAUhmE,GAC1B8mE,EAAgBX,GAASU,GAC/B,GAAIC,EACF,MAAM,IAAI1mC,MACR,4CAA+C0mC,EAAc97D,GAA7D,kDACgD87D,EAAcnwC,OAAO3rB,GAAK,oBAI9E,MAAMhD,EAAU0oC,EAAO4H,eAAe5H,EAAOs0B,oBAAqB9jE,KAAK01B,cAEvE11B,KAAKgyB,SAAW,IAAKwd,EAAOxd,UAAY2/B,GAAgBgU,IACxD3lE,KAAKgyB,SAAS+7B,aAAave,GAE3B,MAAMzd,EAAU/xB,KAAKgyB,SAAS47B,eAAe+X,EAAe7+D,EAAQq/B,aAC9D1Q,EAAS1D,GAAWA,EAAQ0D,OAC5BI,EAASJ,GAAUA,EAAOI,OAC1B7F,EAAQyF,GAAUA,EAAOzF,MAE/BhwB,KAAK8J,GAAK0S,KACVxc,KAAKyyB,IAAMV,EACX/xB,KAAKy1B,OAASA,EACdz1B,KAAKgwB,MAAQA,EACbhwB,KAAK61B,OAASA,EACd71B,KAAK6lE,SAAW/+D,EAIhB9G,KAAK8lE,aAAe9lE,KAAKmmC,YACzBnmC,KAAKktD,QAAU,GACfltD,KAAK+lE,UAAY,GACjB/lE,KAAK4yC,aAAUjmC,EACf3M,KAAKoqD,MAAQ,GACbpqD,KAAKs1B,6BAA0B3oB,EAC/B3M,KAAKyrC,eAAY9+B,EACjB3M,KAAKitC,QAAU,GACfjtC,KAAKgmE,gBAAar5D,EAClB3M,KAAKimE,WAAa,CAAC,EAEnBjmE,KAAKkmE,0BAAuBv5D,EAC5B3M,KAAKmmE,gBAAkB,GACvBnmE,KAAKuzB,OAAS,CAAC,EACfvzB,KAAKomE,SAAW,IAAIlG,GACpBlgE,KAAKsxD,SAAW,CAAC,EACjBtxD,KAAKqmE,eAAiB,CAAC,EACvBrmE,KAAKsmE,UAAW,EAChBtmE,KAAK45C,yBAAsBjtC,EAC3B3M,KAAK80C,cAAWnoC,EAChB3M,KAAKumE,UAAYjgD,GAASwM,GAAQ9yB,KAAKgvC,OAAOlc,GAAOhsB,EAAQ0/D,aAAe,GAC5ExmE,KAAKi7C,aAAe,GAGpB+pB,GAAUhlE,KAAK8J,IAAM9J,KAEhB+xB,GAAY0D,GASjBsY,GAASP,OAAOxtC,KAAM,WAAY0kE,IAClC32B,GAASP,OAAOxtC,KAAM,WAAY4kE,IAElC5kE,KAAKymE,cACDzmE,KAAKsmE,UACPtmE,KAAKgvC,UATL1T,QAAQgnC,MAAM,oEAWlB,CAEA,eAAIn8B,GACF,MAAOr/B,SAAS,YAACq/B,EAAW,oBAAElT,GAAoB,MAAEjD,EAAA,OAAO6F,EAAM,aAAEiwC,GAAgB9lE,KACnF,OAAKyc,GAAc0pB,GAKflT,GAAuB6yC,EAElBA,EAIFjwC,EAAS7F,EAAQ6F,EAAS,KATxBsQ,CAUX,CAEA,QAAIrmC,GACF,OAAOE,KAAKwvC,OAAO1vC,IACrB,CAEA,QAAIA,CAAKA,GACPE,KAAKwvC,OAAO1vC,KAAOA,CACrB,CAEA,WAAIgH,GACF,OAAO9G,KAAK6lE,QACd,CAEA,WAAI/+D,CAAQA,GACV9G,KAAKwvC,OAAO1oC,QAAUA,CACxB,CAEA,YAAIogD,GACF,OAAOA,EACT,CAKAuf,WAAAA,GAeE,OAbAzmE,KAAKi4D,cAAc,cAEfj4D,KAAK8G,QAAQusB,WACfrzB,KAAKqsB,SAELka,GAAYvmC,KAAMA,KAAK8G,QAAQgrB,kBAGjC9xB,KAAK0mE,aAGL1mE,KAAKi4D,cAAc,aAEZj4D,IACT,CAEAujE,KAAAA,GAEE,OADA/tC,GAAYx1B,KAAKy1B,OAAQz1B,KAAKyyB,KACvBzyB,IACT,CAEA8pC,IAAAA,GAEE,OADAiE,GAASjE,KAAK9pC,MACPA,IACT,CAOAqsB,MAAAA,CAAO2D,EAAO6F,GACPkY,GAAShB,QAAQ/sC,MAGpBA,KAAK2mE,kBAAoB,CAAC32C,QAAO6F,UAFjC71B,KAAK4mE,QAAQ52C,EAAO6F,EAIxB,CAEA+wC,OAAAA,CAAQ52C,EAAO6F,GACb,MAAM/uB,EAAU9G,KAAK8G,QACf2uB,EAASz1B,KAAKy1B,OACd0Q,EAAcr/B,EAAQmsB,qBAAuBjzB,KAAKmmC,YAClD0gC,EAAU7mE,KAAKgyB,SAASgU,eAAevQ,EAAQzF,EAAO6F,EAAQsQ,GAC9D2gC,EAAWhgE,EAAQgrB,kBAAoB9xB,KAAKgyB,SAASC,sBACrDa,EAAO9yB,KAAKgwB,MAAQ,SAAW,SAErChwB,KAAKgwB,MAAQ62C,EAAQ72C,MACrBhwB,KAAK61B,OAASgxC,EAAQhxC,OACtB71B,KAAK8lE,aAAe9lE,KAAKmmC,YACpBI,GAAYvmC,KAAM8mE,GAAU,KAIjC9mE,KAAKi4D,cAAc,SAAU,CAAC3vD,KAAMu+D,IAEpCtpD,GAAazW,EAAQigE,SAAU,CAAC/mE,KAAM6mE,GAAU7mE,MAE5CA,KAAKsmE,UACHtmE,KAAKumE,UAAUzzC,IAEjB9yB,KAAK5B,SAGX,CAEA4oE,mBAAAA,GACE,MAAMlgE,EAAU9G,KAAK8G,QACfmgE,EAAgBngE,EAAQysB,QAAU,CAAC,EAEzC5V,GAAKspD,EAAe,CAACC,EAAanmB,KAChCmmB,EAAYp9D,GAAKi3C,GAErB,CAKAomB,mBAAAA,GACE,MAAMrgE,EAAU9G,KAAK8G,QACfsgE,EAAYtgE,EAAQysB,OACpBA,EAASvzB,KAAKuzB,OACd8zC,EAAU3pE,OAAOgJ,KAAK6sB,GAAQma,OAAO,CAACryB,EAAKvR,KAC/CuR,EAAIvR,IAAM,EACHuR,GACN,CAAC,GACJ,IAAIyK,EAAQ,GAERshD,IACFthD,EAAQA,EAAM81B,OACZl+C,OAAOgJ,KAAK0gE,GAAWz5D,IAAK7D,IAC1B,MAAM+3D,EAAeuF,EAAUt9D,GACzBge,EAAO85C,GAAc93D,EAAI+3D,GACzByF,EAAoB,MAATx/C,EACX41B,EAAwB,MAAT51B,EACrB,MAAO,CACLhhB,QAAS+6D,EACT0F,UAAWD,EAAW,YAAc5pB,EAAe,SAAW,OAC9D8pB,MAAOF,EAAW,eAAiB5pB,EAAe,WAAa,cAMvE//B,GAAKmI,EAAQhnB,IACX,MAAM+iE,EAAe/iE,EAAKgI,QACpBgD,EAAK+3D,EAAa/3D,GAClBge,EAAO85C,GAAc93D,EAAI+3D,GACzB4F,EAAYxqD,GAAe4kD,EAAaliE,KAAMb,EAAK0oE,YAE3B76D,IAA1Bk1D,EAAazZ,UAA0Bkc,GAAqBzC,EAAazZ,SAAUtgC,KAAUw8C,GAAqBxlE,EAAKyoE,aACzH1F,EAAazZ,SAAWtpD,EAAKyoE,WAG/BF,EAAQv9D,IAAM,EACd,IAAIwpB,EAAQ,KACZ,GAAIxpB,KAAMypB,GAAUA,EAAOzpB,GAAInK,OAAS8nE,EACtCn0C,EAAQC,EAAOzpB,OACV,CACL,MAAM49D,EAAaxgB,GAASmY,SAASoI,GACrCn0C,EAAQ,IAAIo0C,EAAW,CACrB59D,KACAnK,KAAM8nE,EACNh1C,IAAKzyB,KAAKyyB,IACVxE,MAAOjuB,OAETuzB,EAAOD,EAAMxpB,IAAMwpB,C,CAGrBA,EAAMi0B,KAAKsa,EAAc/6D,KAG3B6W,GAAK0pD,EAAS,CAACM,EAAY79D,KACpB69D,UACIp0C,EAAOzpB,KAIlB6T,GAAK4V,EAASD,IACZk3B,GAAQ9a,UAAU1vC,KAAMszB,EAAOA,EAAMxsB,SACrC0jD,GAAQyC,OAAOjtD,KAAMszB,IAEzB,CAKAs0C,eAAAA,GACE,MAAM72B,EAAW/wC,KAAK+lE,UAChBrrB,EAAU16C,KAAKF,KAAK+xB,SAASjrB,OAC7B6zC,EAAU1J,EAASnqC,OAGzB,GADAmqC,EAASnvB,KAAK,CAAClW,EAAGC,IAAMD,EAAE1M,MAAQ2M,EAAE3M,OAChCy7C,EAAUC,EAAS,CACrB,IAAK,IAAIv9C,EAAIu9C,EAASv9C,EAAIs9C,IAAWt9C,EACnC6C,KAAK6nE,oBAAoB1qE,GAE3B4zC,EAASnrB,OAAO80B,EAASD,EAAUC,E,CAErC16C,KAAKmmE,gBAAkBp1B,EAASp0B,MAAM,GAAGiF,KAAK2iD,GAAc,QAAS,SACvE,CAKAuD,2BAAAA,GACE,MAAO/B,UAAWh1B,EAAUjxC,MAAM,SAAC+xB,IAAa7xB,KAC5C+wC,EAASnqC,OAASirB,EAASjrB,eACtB5G,KAAK4yC,QAEd7B,EAAS1rB,QAAQ,CAAC+B,EAAMpoB,KACmC,IAArD6yB,EAAS0N,OAAO/wB,GAAKA,IAAM4Y,EAAK89B,UAAUt+C,QAC5C5G,KAAK6nE,oBAAoB7oE,IAG/B,CAEA+oE,wBAAAA,GACE,MAAMC,EAAiB,GACjBn2C,EAAW7xB,KAAKF,KAAK+xB,SAC3B,IAAI10B,EAAG8gB,EAIP,IAFAje,KAAK8nE,8BAEA3qE,EAAI,EAAG8gB,EAAO4T,EAASjrB,OAAQzJ,EAAI8gB,EAAM9gB,IAAK,CACjD,MAAM0qB,EAAUgK,EAAS10B,GACzB,IAAIiqB,EAAOpnB,KAAKq2C,eAAel5C,GAC/B,MAAMwC,EAAOkoB,EAAQloB,MAAQK,KAAKwvC,OAAO7vC,KAazC,GAXIynB,EAAKznB,MAAQynB,EAAKznB,OAASA,IAC7BK,KAAK6nE,oBAAoB1qE,GACzBiqB,EAAOpnB,KAAKq2C,eAAel5C,IAE7BiqB,EAAKznB,KAAOA,EACZynB,EAAKwL,UAAY/K,EAAQ+K,WAAayuC,GAAa1hE,EAAMK,KAAK8G,SAC9DsgB,EAAK6gD,MAAQpgD,EAAQogD,OAAS,EAC9B7gD,EAAKpoB,MAAQ7B,EACbiqB,EAAKwxB,MAAQ,GAAK/wB,EAAQ+wB,MAC1BxxB,EAAKoF,QAAUxsB,KAAK8iD,iBAAiB3lD,GAEjCiqB,EAAKsrB,WACPtrB,EAAKsrB,WAAW4C,YAAYn4C,GAC5BiqB,EAAKsrB,WAAWyC,iBACX,CACL,MAAM+yB,EAAkBhhB,GAASgY,cAAcv/D,IACzC,mBAACq1C,EAAA,gBAAoBC,GAAmBtpB,GAASkG,SAASlyB,GAChEjC,OAAOkd,OAAOstD,EAAiB,CAC7BjzB,gBAAiBiS,GAASC,WAAWlS,GACrCD,mBAAoBA,GAAsBkS,GAASC,WAAWnS,KAEhE5tB,EAAKsrB,WAAa,IAAIw1B,EAAgBloE,KAAM7C,GAC5C6qE,EAAetoD,KAAK0H,EAAKsrB,W,CAE7B,CAGA,OADA1yC,KAAK4nE,kBACEI,CACT,CAMAG,cAAAA,GACExqD,GAAK3d,KAAKF,KAAK+xB,SAAU,CAAChK,EAASzJ,KACjCpe,KAAKq2C,eAAej4B,GAAcs0B,WAAW8D,SAC5Cx2C,KACL,CAKAw2C,KAAAA,GACEx2C,KAAKmoE,iBACLnoE,KAAKi4D,cAAc,QACrB,CAEAjpB,MAAAA,CAAOlc,GACL,MAAM0c,EAASxvC,KAAKwvC,OAEpBA,EAAOR,SACP,MAAMloC,EAAU9G,KAAK6lE,SAAWr2B,EAAO4H,eAAe5H,EAAOs0B,oBAAqB9jE,KAAK01B,cACjF0yC,EAAgBpoE,KAAK45C,qBAAuB9yC,EAAQslB,UAU1D,GARApsB,KAAKqoE,gBACLroE,KAAKsoE,sBACLtoE,KAAKuoE,uBAILvoE,KAAKomE,SAAS1F,cAEuD,IAAjE1gE,KAAKi4D,cAAc,eAAgB,CAACnlC,OAAM2tC,YAAY,IACxD,OAIF,MAAMuH,EAAiBhoE,KAAK+nE,2BAE5B/nE,KAAKi4D,cAAc,wBAGnB,IAAI3K,EAAa,EACjB,IAAK,IAAInwD,EAAI,EAAG8gB,EAAOje,KAAKF,KAAK+xB,SAASjrB,OAAQzJ,EAAI8gB,EAAM9gB,IAAK,CAC/D,MAAM,WAACu1C,GAAc1yC,KAAKq2C,eAAel5C,GACnCq5C,GAAS4xB,IAAyD,IAAxCJ,EAAetpD,QAAQg0B,GAGvDA,EAAWkE,sBAAsBJ,GACjC8W,EAAazlD,KAAKgD,KAAK6nC,EAAWgG,iBAAkB4U,EACtD,CACAA,EAAattD,KAAKwoE,YAAc1hE,EAAQikD,OAAOp+B,YAAc2gC,EAAa,EAC1EttD,KAAKyoE,cAAcnb,GAGd8a,GAGHzqD,GAAKqqD,EAAiBt1B,IACpBA,EAAW8D,UAIfx2C,KAAK0oE,gBAAgB51C,GAGrB9yB,KAAKi4D,cAAc,cAAe,CAACnlC,SAEnC9yB,KAAKktD,QAAQtrC,KAAK2iD,GAAc,IAAK,SAGrC,MAAM,QAACt3B,EAAO,WAAE+4B,GAAchmE,KAC1BgmE,EACFhmE,KAAK2oE,cAAc3C,GAAY,GACtB/4B,EAAQrmC,QACjB5G,KAAK4oE,mBAAmB37B,EAASA,GAAS,GAG5CjtC,KAAK5B,QACP,CAKAiqE,aAAAA,GACE1qD,GAAK3d,KAAKuzB,OAASD,IACjBk3B,GAAQ4C,UAAUptD,KAAMszB,KAG1BtzB,KAAKgnE,sBACLhnE,KAAKmnE,qBACP,CAKAmB,mBAAAA,GACE,MAAMxhE,EAAU9G,KAAK8G,QACf+hE,EAAiB,IAAI7iD,IAAItoB,OAAOgJ,KAAK1G,KAAKimE,aAC1C6C,EAAY,IAAI9iD,IAAIlf,EAAQqrB,QAE7BjS,GAAU2oD,EAAgBC,MAAgB9oE,KAAKkmE,uBAAyBp/D,EAAQusB,aAEnFrzB,KAAK+oE,eACL/oE,KAAK0mE,aAET,CAKA6B,oBAAAA,GACE,MAAM,eAAClC,GAAkBrmE,KACnBgpE,EAAUhpE,KAAKipE,0BAA4B,GACjD,IAAK,MAAM,OAAC3jD,EAAM,MAAE5B,EAAA,MAAO1c,KAAUgiE,EAAS,CAC5C,MAAMnuB,EAAkB,oBAAXv1B,GAAgCte,EAAQA,EACrDk+D,GAAgBmB,EAAgB3iD,EAAOm3B,EACzC,CACF,CAKAouB,sBAAAA,GACE,MAAMhuB,EAAej7C,KAAKi7C,aAC1B,IAAKA,IAAiBA,EAAar0C,OACjC,OAGF5G,KAAKi7C,aAAe,GACpB,MAAMiuB,EAAelpE,KAAKF,KAAK+xB,SAASjrB,OAClCuiE,EAAW5O,GAAQ,IAAIv0C,IAC3Bi1B,EACG1b,OAAO3zB,GAAKA,EAAE,KAAO2uD,GACrB5sD,IAAI,CAAC/B,EAAGzO,IAAMA,EAAI,IAAMyO,EAAEga,OAAO,GAAGuZ,KAAK,OAGxCiqC,EAAYD,EAAQ,GAC1B,IAAK,IAAIhsE,EAAI,EAAGA,EAAI+rE,EAAc/rE,IAChC,IAAK+iB,GAAUkpD,EAAWD,EAAQhsE,IAChC,OAGJ,OAAOsQ,MAAM0M,KAAKivD,GACfz7D,IAAI/B,GAAKA,EAAE4T,MAAM,MACjB7R,IAAIjC,IAAA,CAAO4Z,OAAQ5Z,EAAE,GAAIgY,OAAQhY,EAAE,GAAI1E,OAAQ0E,EAAE,KACtD,CAOA+8D,aAAAA,CAAcnb,GACZ,IAA+D,IAA3DttD,KAAKi4D,cAAc,eAAgB,CAACwI,YAAY,IAClD,OAGFjW,GAAQxb,OAAOhvC,KAAMA,KAAKgwB,MAAOhwB,KAAK61B,OAAQy3B,GAE9C,MAAM/1B,EAAOv3B,KAAKyrC,UACZ49B,EAAS9xC,EAAKvH,OAAS,GAAKuH,EAAK1B,QAAU,EAEjD71B,KAAKktD,QAAU,GACfvvC,GAAK3d,KAAKoqD,MAAQvlB,IACZwkC,GAA2B,cAAjBxkC,EAAIujB,WAOdvjB,EAAI6K,WACN7K,EAAI6K,YAEN1vC,KAAKktD,QAAQxtC,QAAQmlB,EAAIqoB,aACxBltD,MAEHA,KAAKktD,QAAQ7nC,QAAQ,CAACvmB,EAAME,KAC1BF,EAAKwqE,KAAOtqE,IAGdgB,KAAKi4D,cAAc,cACrB,CAOAyQ,eAAAA,CAAgB51C,GACd,IAA6E,IAAzE9yB,KAAKi4D,cAAc,uBAAwB,CAACnlC,OAAM2tC,YAAY,IAAlE,CAIA,IAAK,IAAItjE,EAAI,EAAG8gB,EAAOje,KAAKF,KAAK+xB,SAASjrB,OAAQzJ,EAAI8gB,IAAQ9gB,EAC5D6C,KAAKq2C,eAAel5C,GAAGu1C,WAAWhD,YAGpC,IAAK,IAAIvyC,EAAI,EAAG8gB,EAAOje,KAAKF,KAAK+xB,SAASjrB,OAAQzJ,EAAI8gB,IAAQ9gB,EAC5D6C,KAAKupE,eAAepsE,EAAG8iB,GAAW6S,GAAQA,EAAK,CAAC1U,aAAcjhB,IAAM21B,GAGtE9yB,KAAKi4D,cAAc,sBAAuB,CAACnlC,Q,CAC7C,CAOAy2C,cAAAA,CAAevqE,EAAO8zB,GACpB,MAAM1L,EAAOpnB,KAAKq2C,eAAer3C,GAC3BO,EAAO,CAAC6nB,OAAMpoB,QAAO8zB,OAAM2tC,YAAY,IAEW,IAApDzgE,KAAKi4D,cAAc,sBAAuB14D,KAI9C6nB,EAAKsrB,WAAW/F,QAAQ7Z,GAExBvzB,EAAKkhE,YAAa,EAClBzgE,KAAKi4D,cAAc,qBAAsB14D,GAC3C,CAEAnB,MAAAA,IACiE,IAA3D4B,KAAKi4D,cAAc,eAAgB,CAACwI,YAAY,MAIhD1yB,GAAS5tB,IAAIngB,MACXA,KAAKsmE,WAAav4B,GAAShB,QAAQ/sC,OACrC+tC,GAASrqB,MAAM1jB,OAGjBA,KAAKgtC,OACL03B,GAAqB,CAACz2C,MAAOjuB,QAEjC,CAEAgtC,IAAAA,GACE,IAAI7vC,EACJ,GAAI6C,KAAK2mE,kBAAmB,CAC1B,MAAM,MAAC32C,EAAA,OAAO6F,GAAU71B,KAAK2mE,kBAE7B3mE,KAAK2mE,kBAAoB,KACzB3mE,KAAK4mE,QAAQ52C,EAAO6F,E,CAItB,GAFA71B,KAAKujE,QAEDvjE,KAAKgwB,OAAS,GAAKhwB,KAAK61B,QAAU,EACpC,OAGF,IAA6D,IAAzD71B,KAAKi4D,cAAc,aAAc,CAACwI,YAAY,IAChD,OAMF,MAAM+I,EAASxpE,KAAKktD,QACpB,IAAK/vD,EAAI,EAAGA,EAAIqsE,EAAO5iE,QAAU4iE,EAAOrsE,GAAGgwD,GAAK,IAAKhwD,EACnDqsE,EAAOrsE,GAAG6vC,KAAKhtC,KAAKyrC,WAMtB,IAHAzrC,KAAKypE,gBAGEtsE,EAAIqsE,EAAO5iE,SAAUzJ,EAC1BqsE,EAAOrsE,GAAG6vC,KAAKhtC,KAAKyrC,WAGtBzrC,KAAKi4D,cAAc,YACrB,CAKAjnB,sBAAAA,CAAuBF,GACrB,MAAMC,EAAW/wC,KAAKmmE,gBAChBzkD,EAAS,GACf,IAAIvkB,EAAG8gB,EAEP,IAAK9gB,EAAI,EAAG8gB,EAAO8yB,EAASnqC,OAAQzJ,EAAI8gB,IAAQ9gB,EAAG,CACjD,MAAMiqB,EAAO2pB,EAAS5zC,GACjB2zC,IAAiB1pB,EAAKoF,SACzB9K,EAAOhC,KAAK0H,EAEhB,CAEA,OAAO1F,CACT,CAMA4mC,4BAAAA,GACE,OAAOtoD,KAAKgxC,wBAAuB,EACrC,CAOAy4B,aAAAA,GACE,IAAqE,IAAjEzpE,KAAKi4D,cAAc,qBAAsB,CAACwI,YAAY,IACxD,OAGF,MAAM1vB,EAAW/wC,KAAKsoD,+BACtB,IAAK,IAAInrD,EAAI4zC,EAASnqC,OAAS,EAAGzJ,GAAK,IAAKA,EAC1C6C,KAAK0pE,aAAa34B,EAAS5zC,IAG7B6C,KAAKi4D,cAAc,oBACrB,CAOAyR,YAAAA,CAAatiD,GACX,MAAMqL,EAAMzyB,KAAKyyB,IACXlzB,EAAO,CACX6nB,OACApoB,MAAOooB,EAAKpoB,MACZyhE,YAAY,GAGRrxC,EAAOwc,GAAmB5rC,KAAMonB,IAEgB,IAAlDpnB,KAAKi4D,cAAc,oBAAqB14D,KAIxC6vB,GACFqI,GAAShF,EAAKrD,GAGhBhI,EAAKsrB,WAAW1F,OAEZ5d,GACFsI,GAAWjF,GAGblzB,EAAKkhE,YAAa,EAClBzgE,KAAKi4D,cAAc,mBAAoB14D,GACzC,CAOAupD,aAAAA,CAAczgC,GACZ,OAAOiP,GAAejP,EAAOroB,KAAKyrC,UAAWzrC,KAAKwoE,YACpD,CAEAmB,yBAAAA,CAA0BzsE,EAAG41B,EAAMhsB,EAAS+hD,GAC1C,MAAMvjC,EAASskC,GAAYC,MAAM/2B,GACjC,MAAsB,oBAAXxN,EACFA,EAAOtlB,KAAM9C,EAAG4J,EAAS+hD,GAG3B,EACT,CAEAxS,cAAAA,CAAej4B,GACb,MAAMyJ,EAAU7nB,KAAKF,KAAK+xB,SAASzT,GAC7B2yB,EAAW/wC,KAAK+lE,UACtB,IAAI3+C,EAAO2pB,EAASxR,OAAO/wB,GAAKA,GAAKA,EAAE02C,WAAar9B,GAAShG,MAoB7D,OAlBKuF,IACHA,EAAO,CACLznB,KAAM,KACNG,KAAM,GACN+nB,QAAS,KACT6qB,WAAY,KACZuB,OAAQ,KACRyB,QAAS,KACTE,QAAS,KACTqyB,MAAOpgD,GAAWA,EAAQogD,OAAS,EACnCjpE,MAAOof,EACP8mC,SAAUr9B,EACVF,QAAS,GACTH,SAAS,GAEXupB,EAASrxB,KAAK0H,IAGTA,CACT,CAEAsO,UAAAA,GACE,OAAO11B,KAAK80C,WAAa90C,KAAK80C,SAAW7Y,GAAc,KAAM,CAAChO,MAAOjuB,KAAML,KAAM,UACnF,CAEAsmD,sBAAAA,GACE,OAAOjmD,KAAKsoD,+BAA+B1hD,MAC7C,CAEAk8C,gBAAAA,CAAiB1kC,GACf,MAAMyJ,EAAU7nB,KAAKF,KAAK+xB,SAASzT,GACnC,IAAKyJ,EACH,OAAO,EAGT,MAAMT,EAAOpnB,KAAKq2C,eAAej4B,GAIjC,MAA8B,mBAAhBgJ,EAAK6sB,QAAwB7sB,EAAK6sB,QAAUpsB,EAAQosB,MACpE,CAEA21B,oBAAAA,CAAqBxrD,EAAcoO,GACjC,MAAMpF,EAAOpnB,KAAKq2C,eAAej4B,GACjCgJ,EAAK6sB,QAAUznB,CACjB,CAEAw4B,oBAAAA,CAAqBhmD,GACnBgB,KAAKqmE,eAAernE,IAAUgB,KAAKqmE,eAAernE,EACpD,CAEAqhD,iBAAAA,CAAkBrhD,GAChB,OAAQgB,KAAKqmE,eAAernE,EAC9B,CAKA6qE,iBAAAA,CAAkBzrD,EAAco1B,EAAWhnB,GACzC,MAAMsG,EAAOtG,EAAU,OAAS,OAC1BpF,EAAOpnB,KAAKq2C,eAAej4B,GAC3BguB,EAAQhlB,EAAKsrB,WAAW4G,wBAAmB3sC,EAAWmmB,GAExD9S,GAAQwzB,IACVpsB,EAAKtnB,KAAK0zC,GAAWS,QAAUznB,EAC/BxsB,KAAKgvC,WAELhvC,KAAK4pE,qBAAqBxrD,EAAcoO,GAExC4f,EAAM4C,OAAO5nB,EAAM,CAACoF,YACpBxsB,KAAKgvC,OAAQvc,GAAQA,EAAIrU,eAAiBA,EAAe0U,OAAOnmB,GAEpE,CAEA8f,IAAAA,CAAKrO,EAAco1B,GACjBxzC,KAAK6pE,kBAAkBzrD,EAAco1B,GAAW,EAClD,CAEAlnB,IAAAA,CAAKlO,EAAco1B,GACjBxzC,KAAK6pE,kBAAkBzrD,EAAco1B,GAAW,EAClD,CAKAq0B,mBAAAA,CAAoBzpD,GAClB,MAAMgJ,EAAOpnB,KAAK+lE,UAAU3nD,GACxBgJ,GAAQA,EAAKsrB,YACftrB,EAAKsrB,WAAW+D,kBAEXz2C,KAAK+lE,UAAU3nD,EACxB,CAEA0rD,KAAAA,GACE,IAAI3sE,EAAG8gB,EAIP,IAHAje,KAAK8pC,OACLiE,GAASD,OAAO9tC,MAEX7C,EAAI,EAAG8gB,EAAOje,KAAKF,KAAK+xB,SAASjrB,OAAQzJ,EAAI8gB,IAAQ9gB,EACxD6C,KAAK6nE,oBAAoB1qE,EAE7B,CAEA4sE,OAAAA,GACE/pE,KAAKi4D,cAAc,iBACnB,MAAM,OAACxiC,EAAM,IAAEhD,GAAOzyB,KAEtBA,KAAK8pE,QACL9pE,KAAKwvC,OAAO8zB,aAER7tC,IACFz1B,KAAK+oE,eACLvzC,GAAYC,EAAQhD,GACpBzyB,KAAKgyB,SAAS67B,eAAep7B,GAC7BzyB,KAAKy1B,OAAS,KACdz1B,KAAKyyB,IAAM,aAGNuyC,GAAUhlE,KAAK8J,IAEtB9J,KAAKi4D,cAAc,eACrB,CAEA+R,aAAAA,IAAiBzqE,GACf,OAAOS,KAAKy1B,OAAOw0C,aAAa1qE,EAClC,CAKAmnE,UAAAA,GACE1mE,KAAKkqE,iBACDlqE,KAAK8G,QAAQusB,WACfrzB,KAAKmqE,uBAELnqE,KAAKsmE,UAAW,CAEpB,CAKA4D,cAAAA,GACE,MAAM9kD,EAAYplB,KAAKimE,WACjBj0C,EAAWhyB,KAAKgyB,SAEhBo4C,EAAOA,CAACzqE,EAAMulB,KAClB8M,EAASzxB,iBAAiBP,KAAML,EAAMulB,GACtCE,EAAUzlB,GAAQulB,GAGdA,EAAWA,CAAChoB,EAAGsR,EAAG6Q,KACtBniB,EAAEynC,QAAUn2B,EACZtR,EAAE0nC,QAAUvlB,EACZrf,KAAK2oE,cAAczrE,IAGrBygB,GAAK3d,KAAK8G,QAAQqrB,OAASxyB,GAASyqE,EAAKzqE,EAAMulB,GACjD,CAKAilD,oBAAAA,GACOnqE,KAAKkmE,uBACRlmE,KAAKkmE,qBAAuB,CAAC,GAE/B,MAAM9gD,EAAYplB,KAAKkmE,qBACjBl0C,EAAWhyB,KAAKgyB,SAEhBo4C,EAAOA,CAACzqE,EAAMulB,KAClB8M,EAASzxB,iBAAiBP,KAAML,EAAMulB,GACtCE,EAAUzlB,GAAQulB,GAEdmlD,EAAUA,CAAC1qE,EAAMulB,KACjBE,EAAUzlB,KACZqyB,EAASvxB,oBAAoBT,KAAML,EAAMulB,UAClCE,EAAUzlB,KAIfulB,EAAWA,CAAC8K,EAAO6F,KACnB71B,KAAKy1B,QACPz1B,KAAKqsB,OAAO2D,EAAO6F,IAIvB,IAAIy0C,EACJ,MAAMhE,EAAWA,KACf+D,EAAQ,SAAU/D,GAElBtmE,KAAKsmE,UAAW,EAChBtmE,KAAKqsB,SAEL+9C,EAAK,SAAUllD,GACfklD,EAAK,SAAUE,IAGjBA,EAAWA,KACTtqE,KAAKsmE,UAAW,EAEhB+D,EAAQ,SAAUnlD,GAGlBllB,KAAK8pE,QACL9pE,KAAK4mE,QAAQ,EAAG,GAEhBwD,EAAK,SAAU9D,IAGbt0C,EAAS87B,WAAW9tD,KAAKy1B,QAC3B6wC,IAEAgE,GAEJ,CAKAvB,YAAAA,GACEprD,GAAK3d,KAAKimE,WAAY,CAAC/gD,EAAUvlB,KAC/BK,KAAKgyB,SAASvxB,oBAAoBT,KAAML,EAAMulB,KAEhDllB,KAAKimE,WAAa,CAAC,EAEnBtoD,GAAK3d,KAAKkmE,qBAAsB,CAAChhD,EAAUvlB,KACzCK,KAAKgyB,SAASvxB,oBAAoBT,KAAML,EAAMulB,KAEhDllB,KAAKkmE,0BAAuBv5D,CAC9B,CAEA49D,gBAAAA,CAAiBzkD,EAAOgN,EAAMy/B,GAC5B,MAAM1zB,EAAS0zB,EAAU,MAAQ,SACjC,IAAInrC,EAAMtoB,EAAM3B,EAAG8gB,EAOnB,IALa,YAAT6U,IACF1L,EAAOpnB,KAAKq2C,eAAevwB,EAAM,GAAG1H,cACpCgJ,EAAKsrB,WAAW,IAAM7T,EAAS,wBAG5B1hC,EAAI,EAAG8gB,EAAO6H,EAAMlf,OAAQzJ,EAAI8gB,IAAQ9gB,EAAG,CAC9C2B,EAAOgnB,EAAM3oB,GACb,MAAMu1C,EAAa5zC,GAAQkB,KAAKq2C,eAAev3C,EAAKsf,cAAcs0B,WAC9DA,GACFA,EAAW7T,EAAS,cAAc//B,EAAK8kC,QAAS9kC,EAAKsf,aAActf,EAAKE,MAE5E,CACF,CAMAwrE,iBAAAA,GACE,OAAOxqE,KAAKitC,SAAW,EACzB,CAMAw9B,iBAAAA,CAAkBC,GAChB,MAAMC,EAAa3qE,KAAKitC,SAAW,GAC7B9gB,EAASu+C,EAAe/8D,IAAI,EAAEyQ,eAAcpf,YAChD,MAAMooB,EAAOpnB,KAAKq2C,eAAej4B,GACjC,IAAKgJ,EACH,MAAM,IAAI8X,MAAM,6BAA+B9gB,GAGjD,MAAO,CACLA,eACAwlB,QAASxc,EAAKtnB,KAAKd,GACnBA,WAGEgqB,GAAWlL,GAAeqO,EAAQw+C,GAEpC3hD,IACFhpB,KAAKitC,QAAU9gB,EAEfnsB,KAAKgmE,WAAa,KAClBhmE,KAAK4oE,mBAAmBz8C,EAAQw+C,GAEpC,CAWA1S,aAAAA,CAAcoI,EAAM9gE,EAAMggC,GACxB,OAAOv/B,KAAKomE,SAAShG,OAAOpgE,KAAMqgE,EAAM9gE,EAAMggC,EAChD,CAOA8V,eAAAA,CAAgBu1B,GACd,OAA6E,IAAtE5qE,KAAKomE,SAAS9nE,OAAOihC,OAAO3jB,GAAKA,EAAE4kD,OAAO12D,KAAO8gE,GAAUhkE,MACpE,CAKAgiE,kBAAAA,CAAmBz8C,EAAQw+C,EAAYE,GACrC,MAAMC,EAAe9qE,KAAK8G,QAAQyrB,MAC5Bk1B,EAAOA,CAAC/7C,EAAGC,IAAMD,EAAE6zB,OAAO/wB,IAAM7C,EAAEq1D,KAAK3hD,GAAK7Q,EAAE4P,eAAiBiB,EAAEjB,cAAgB5P,EAAExP,QAAUqgB,EAAErgB,QAC/F+rE,EAActjB,EAAKkjB,EAAYx+C,GAC/B6+C,EAAYH,EAAS1+C,EAASs7B,EAAKt7B,EAAQw+C,GAE7CI,EAAYnkE,QACd5G,KAAKuqE,iBAAiBQ,EAAaD,EAAah4C,MAAM,GAGpDk4C,EAAUpkE,QAAUkkE,EAAah4C,MACnC9yB,KAAKuqE,iBAAiBS,EAAWF,EAAah4C,MAAM,EAExD,CAKA61C,aAAAA,CAAczrE,EAAG2tE,GACf,MAAMtrE,EAAO,CACX2lC,MAAOhoC,EACP2tE,SACApK,YAAY,EACZ6E,YAAatlE,KAAK8oD,cAAc5rD,IAE5B+tE,EAAezK,IAAYA,EAAO15D,QAAQqrB,QAAUnyB,KAAK8G,QAAQqrB,QAAQtD,SAAS3xB,EAAEqyD,OAAO5vD,MAEjG,IAA6D,IAAzDK,KAAKi4D,cAAc,cAAe14D,EAAM0rE,GAC1C,OAGF,MAAMjiD,EAAUhpB,KAAKkrE,aAAahuE,EAAG2tE,EAAQtrE,EAAK+lE,aASlD,OAPA/lE,EAAKkhE,YAAa,EAClBzgE,KAAKi4D,cAAc,aAAc14D,EAAM0rE,IAEnCjiD,GAAWzpB,EAAKypB,UAClBhpB,KAAK5B,SAGA4B,IACT,CAUAkrE,YAAAA,CAAahuE,EAAG2tE,EAAQvF,GACtB,MAAOr4B,QAAS09B,EAAa,GAAE,QAAE7jE,GAAW9G,KAetC6oD,EAAmBgiB,EACnB1+C,EAASnsB,KAAKmrE,mBAAmBjuE,EAAGytE,EAAYrF,EAAazc,GAC7D0c,EAAUnlD,GAAcljB,GACxBmoE,EAAYD,GAAmBloE,EAAG8C,KAAKgmE,WAAYV,EAAaC,GAElED,IAGFtlE,KAAKgmE,WAAa,KAGlBzoD,GAAazW,EAAQosB,QAAS,CAACh2B,EAAGivB,EAAQnsB,MAAOA,MAE7CulE,GACFhoD,GAAazW,EAAQ5H,QAAS,CAAChC,EAAGivB,EAAQnsB,MAAOA,OAIrD,MAAMgpB,GAAWlL,GAAeqO,EAAQw+C,GAQxC,OAPI3hD,GAAW6hD,KACb7qE,KAAKitC,QAAU9gB,EACfnsB,KAAK4oE,mBAAmBz8C,EAAQw+C,EAAYE,IAG9C7qE,KAAKgmE,WAAaX,EAEXr8C,CACT,CAUAmiD,kBAAAA,CAAmBjuE,EAAGytE,EAAYrF,EAAazc,GAC7C,GAAe,aAAX3rD,EAAEyC,KACJ,MAAO,GAGT,IAAK2lE,EAEH,OAAOqF,EAGT,MAAMG,EAAe9qE,KAAK8G,QAAQyrB,MAClC,OAAOvyB,KAAK2pE,0BAA0BzsE,EAAG4tE,EAAah4C,KAAMg4C,EAAcjiB,EAC5E,EAIF,SAAS4c,KACP,OAAO9nD,GAAK6nD,GAAMR,UAAY/2C,GAAUA,EAAMm4C,SAAS1F,aACzD,CC5uCA,SAAS0K,GAAS34C,EAA+BmR,EAAqBge,GACpE,MAAM,WAACD,EAAA,EAAYnzC,EAAA,EAAG6Q,EAAA,YAAGojC,EAAA,YAAaD,EAAA,QAAa17C,GAAW88B,GACxD,YAACxM,EAAA,gBAAakU,GAAmBxkC,EACjCukE,EAAiBxjE,KAAKiD,IAAIssB,EAAcqrB,EAAaj/B,GAAgBm+B,EAAaC,IAIxF,GAHAnvB,EAAIkE,YACJlE,EAAIoE,IAAIroB,EAAG6Q,EAAGojC,EAAcrrB,EAAc,EAAGuqB,EAAa0pB,EAAiB,EAAGzpB,EAAWypB,EAAiB,GAEtG7oB,EAAc,EAAG,CACnB,MAAM8oB,EAAiBzjE,KAAKiD,IAAIssB,EAAcorB,EAAah/B,GAAgBm+B,EAAaC,IACxFnvB,EAAIoE,IAAIroB,EAAG6Q,EAAGmjC,EAAcprB,EAAc,EAAGwqB,EAAW0pB,EAAiB,EAAG3pB,EAAa2pB,EAAiB,GAAG,E,KACxG,CACL,MAAMC,EAAY1jE,KAAKiD,IAAIssB,EAAc,EAAGqrB,EAAcj/B,GAAgBm+B,EAAaC,IAEvF,GAAwB,UAApBtW,EACF7Y,EAAIoE,IAAIroB,EAAG6Q,EAAGksD,EAAW3pB,EAAWvhC,GAAK,EAAGshC,EAAathC,GAAK,GAAG,QAC5D,GAAwB,UAApBirB,EAA6B,CACtC,MAAMruC,EAAI,EAAIsuE,EAAYA,EACpBxpB,GAAQ9kD,EAAI4K,KAAKuiB,IAAIw3B,EAAWvhC,GAAK,GAAK7R,EAC1CwzC,GAAQ/kD,EAAI4K,KAAKshB,IAAIy4B,EAAWvhC,GAAK,GAAKhB,EAC1CwiC,EAAS5kD,EAAI4K,KAAKuiB,IAAIu3B,EAAathC,GAAK,GAAK7R,EAC7CszC,EAAS7kD,EAAI4K,KAAKshB,IAAIw4B,EAAathC,GAAK,GAAKhB,EACnDoT,EAAIuE,OAAO+qB,EAAMC,GACjBvvB,EAAIuE,OAAO6qB,EAAQC,E,EAGvBrvB,EAAIqE,YAEJrE,EAAIsE,OAAO,EAAG,GACdtE,EAAIyE,KAAK,EAAG,EAAGzE,EAAIgD,OAAOzF,MAAOyC,EAAIgD,OAAOI,QAE5CpD,EAAIrD,KAAK,UACX,CAGA,SAASo8C,GAAQ/4C,EAA+BmR,EAAqBge,GACnE,MAAM,WAACD,EAAA,YAAY8pB,EAAA,EAAaj9D,EAAA,EAAG6Q,EAAA,YAAGojC,EAAA,YAAaD,GAAe5e,EAClE,IAAI8nC,EAAcD,EAAchpB,EAIhChwB,EAAIkE,YACJlE,EAAIoE,IAAIroB,EAAG6Q,EAAGojC,EAAad,EAAa+pB,EAAa9pB,EAAW8pB,GAC5DlpB,EAAcipB,GAChBC,EAAcD,EAAcjpB,EAC5B/vB,EAAIoE,IAAIroB,EAAG6Q,EAAGmjC,EAAaZ,EAAW8pB,EAAa/pB,EAAa+pB,GAAa,IAE7Ej5C,EAAIoE,IAAIroB,EAAG6Q,EAAGosD,EAAa7pB,EAAWjhC,GAASghC,EAAahhC,IAE9D8R,EAAIqE,YACJrE,EAAIrD,MACN,CAEA,SAASu8C,GAAgB/tE,GACvB,OAAOi9B,GAAkBj9B,EAAO,CAAC,aAAc,WAAY,aAAc,YAC3E,CAKA,SAASguE,GAAkB/0C,EAAiB2rB,EAAqBC,EAAqBopB,GACpF,MAAMnvE,EAAIivE,GAAgB90C,EAAI/vB,QAAQ49C,cAChConB,GAAiBrpB,EAAcD,GAAe,EAC9CupB,EAAalkE,KAAKiD,IAAIghE,EAAeD,EAAarpB,EAAc,GAShEwpB,EAAqBhwD,IACzB,MAAMiwD,GAAiBxpB,EAAc56C,KAAKiD,IAAIghE,EAAe9vD,IAAQ6vD,EAAa,EAClF,OAAO5nD,GAAYjI,EAAK,EAAGnU,KAAKiD,IAAIghE,EAAeG,KAGrD,MAAO,CACLC,WAAYF,EAAkBtvE,EAAEwvE,YAChCC,SAAUH,EAAkBtvE,EAAEyvE,UAC9BC,WAAYnoD,GAAYvnB,EAAE0vE,WAAY,EAAGL,GACzCM,SAAUpoD,GAAYvnB,EAAE2vE,SAAU,EAAGN,GAEzC,CAKA,SAASO,GAAWrvE,EAAWsvE,EAAe/9D,EAAW6Q,GACvD,MAAO,CACL7Q,EAAGA,EAAIvR,EAAI4K,KAAKuiB,IAAImiD,GACpBltD,EAAGA,EAAIpiB,EAAI4K,KAAKshB,IAAIojD,GAExB,CAiBA,SAASC,GACP/5C,EACAmR,EACA3U,EACA+zB,EACAr/B,EACAgjC,GAEA,MAAM,EAACn4C,EAAA,EAAG6Q,EAAGsiC,WAAYj+B,EAAK,YAAE+nD,EAAajpB,YAAaiqB,GAAU7oC,EAE9D6e,EAAc56C,KAAKgD,IAAI+4B,EAAQ6e,YAAcO,EAAU/zB,EAASw8C,EAAa,GAC7EjpB,EAAciqB,EAAS,EAAIA,EAASzpB,EAAU/zB,EAASw8C,EAAc,EAE3E,IAAIiB,EAAgB,EACpB,MAAMjgE,EAAQkX,EAAMD,EAEpB,GAAIs/B,EAAS,CAIX,MAAM2pB,EAAuBF,EAAS,EAAIA,EAASzpB,EAAU,EACvD4pB,EAAuBnqB,EAAc,EAAIA,EAAcO,EAAU,EACjE6pB,GAAsBF,EAAuBC,GAAwB,EACrEE,EAAuC,IAAvBD,EAA2BpgE,EAASogE,GAAuBA,EAAqB7pB,GAAWv2C,EACjHigE,GAAiBjgE,EAAQqgE,GAAiB,C,CAG5C,MAAMC,EAAOllE,KAAKgD,IAAI,KAAO4B,EAAQg2C,EAAcxzB,EAAS5O,IAAMoiC,EAC5DuqB,GAAevgE,EAAQsgE,GAAQ,EAC/BprB,EAAaj+B,EAAQspD,EAAcN,EACnC9qB,EAAWj+B,EAAMqpD,EAAcN,GAC/B,WAACR,EAAA,SAAYC,EAAA,WAAUC,EAAU,SAAEC,GAAYT,GAAkBhoC,EAAS4e,EAAaC,EAAab,EAAWD,GAE/GsrB,EAA2BxqB,EAAcypB,EACzCgB,EAAyBzqB,EAAc0pB,EACvCgB,EAA0BxrB,EAAauqB,EAAae,EACpDG,EAAwBxrB,EAAWuqB,EAAWe,EAE9CG,EAA2B7qB,EAAc4pB,EACzCkB,EAAyB9qB,EAAc6pB,EACvCkB,EAA0B5rB,EAAayqB,EAAaiB,EACpDG,EAAwB5rB,EAAWyqB,EAAWiB,EAIpD,GAFA76C,EAAIkE,YAEAgwB,EAAU,CAEZ,MAAM8mB,GAAyBN,EAA0BC,GAAyB,EAKlF,GAJA36C,EAAIoE,IAAIroB,EAAG6Q,EAAGojC,EAAa0qB,EAAyBM,GACpDh7C,EAAIoE,IAAIroB,EAAG6Q,EAAGojC,EAAagrB,EAAuBL,GAG9CjB,EAAW,EAAG,CAChB,MAAMuB,EAAUpB,GAAWY,EAAwBE,EAAuB5+D,EAAG6Q,GAC7EoT,EAAIoE,IAAI62C,EAAQl/D,EAAGk/D,EAAQruD,EAAG8sD,EAAUiB,EAAuBxrB,EAAWjhC,G,CAI5E,MAAMgtD,EAAKrB,GAAWgB,EAAwB1rB,EAAUpzC,EAAG6Q,GAI3D,GAHAoT,EAAIuE,OAAO22C,EAAGn/D,EAAGm/D,EAAGtuD,GAGhBgtD,EAAW,EAAG,CAChB,MAAMqB,EAAUpB,GAAWgB,EAAwBE,EAAuBh/D,EAAG6Q,GAC7EoT,EAAIoE,IAAI62C,EAAQl/D,EAAGk/D,EAAQruD,EAAGgtD,EAAUzqB,EAAWjhC,GAAS6sD,EAAwB3lE,KAAKwY,G,CAI3F,MAAMutD,GAA0BhsB,EAAYyqB,EAAW7pB,GAAiBb,EAAcyqB,EAAa5pB,IAAiB,EAKpH,GAJA/vB,EAAIoE,IAAIroB,EAAG6Q,EAAGmjC,EAAaZ,EAAYyqB,EAAW7pB,EAAcorB,GAAuB,GACvFn7C,EAAIoE,IAAIroB,EAAG6Q,EAAGmjC,EAAaorB,EAAuBjsB,EAAcyqB,EAAa5pB,GAAc,GAGvF4pB,EAAa,EAAG,CAClB,MAAMsB,EAAUpB,GAAWe,EAA0BE,EAAyB/+D,EAAG6Q,GACjFoT,EAAIoE,IAAI62C,EAAQl/D,EAAGk/D,EAAQruD,EAAG+sD,EAAYmB,EAA0B1lE,KAAKwY,GAAIshC,EAAahhC,G,CAI5F,MAAMktD,EAAKvB,GAAWW,EAA0BtrB,EAAYnzC,EAAG6Q,GAI/D,GAHAoT,EAAIuE,OAAO62C,EAAGr/D,EAAGq/D,EAAGxuD,GAGhB6sD,EAAa,EAAG,CAClB,MAAMwB,EAAUpB,GAAWW,EAA0BE,EAAyB3+D,EAAG6Q,GACjFoT,EAAIoE,IAAI62C,EAAQl/D,EAAGk/D,EAAQruD,EAAG6sD,EAAYvqB,EAAahhC,GAASwsD,E,MAE7D,CACL16C,EAAIsE,OAAOvoB,EAAG6Q,GAEd,MAAMyuD,EAAcjmE,KAAKuiB,IAAI+iD,GAA2B1qB,EAAcj0C,EAChEu/D,EAAclmE,KAAKshB,IAAIgkD,GAA2B1qB,EAAcpjC,EACtEoT,EAAIuE,OAAO82C,EAAaC,GAExB,MAAMC,EAAYnmE,KAAKuiB,IAAIgjD,GAAyB3qB,EAAcj0C,EAC5Dy/D,EAAYpmE,KAAKshB,IAAIikD,GAAyB3qB,EAAcpjC,EAClEoT,EAAIuE,OAAOg3C,EAAWC,E,CAGxBx7C,EAAIqE,WACN,CAEA,SAASo3C,GACPz7C,EACAmR,EACA3U,EACA+zB,EACA2D,GAEA,MAAM,YAACwnB,EAAW,WAAExsB,EAAA,cAAYJ,GAAiB3d,EACjD,IAAIge,EAAWhe,EAAQge,SACvB,GAAIusB,EAAa,CACf3B,GAAQ/5C,EAAKmR,EAAS3U,EAAQ+zB,EAASpB,EAAU+E,GACjD,IAAK,IAAIxpD,EAAI,EAAGA,EAAIgxE,IAAehxE,EACjCs1B,EAAI0E,OAEDnV,MAAMu/B,KACTK,EAAWD,GAAcJ,EAAgBjhC,IAAOA,I,CAKpD,OAFAksD,GAAQ/5C,EAAKmR,EAAS3U,EAAQ+zB,EAASpB,EAAU+E,GACjDl0B,EAAI0E,OACGyqB,CACT,CAEA,SAASsb,GACPzqC,EACAmR,EACA3U,EACA+zB,EACA2D,GAEA,MAAM,YAACwnB,EAAA,WAAaxsB,EAAA,cAAYJ,EAAa,QAAEz6C,GAAW88B,GACpD,YAACxM,EAAW,gBAAEkU,EAAe,WAAEF,EAAU,iBAAEC,EAAgB,aAAEqZ,GAAgB59C,EAC7EsnE,EAAgC,UAAxBtnE,EAAQq9C,YAEtB,IAAK/sB,EACH,OAGF3E,EAAIwqC,YAAY7xB,GAAc,IAC9B3Y,EAAIoyB,eAAiBxZ,EAEjB+iC,GACF37C,EAAIlD,UAA0B,EAAd6H,EAChB3E,EAAIqyB,SAAWxZ,GAAmB,UAElC7Y,EAAIlD,UAAY6H,EAChB3E,EAAIqyB,SAAWxZ,GAAmB,SAGpC,IAAIsW,EAAWhe,EAAQge,SACvB,GAAIusB,EAAa,CACf3B,GAAQ/5C,EAAKmR,EAAS3U,EAAQ+zB,EAASpB,EAAU+E,GACjD,IAAK,IAAIxpD,EAAI,EAAGA,EAAIgxE,IAAehxE,EACjCs1B,EAAI4E,SAEDrV,MAAMu/B,KACTK,EAAWD,GAAcJ,EAAgBjhC,IAAOA,I,CAIhD8tD,GACF5C,GAAQ/4C,EAAKmR,EAASge,GAGpB96C,EAAQunE,UAAYzsB,EAAWD,GAActhC,IAAuB,IAAjBqkC,GAA0C,UAApBpZ,GAC3E8/B,GAAS34C,EAAKmR,EAASge,GAGpBusB,IACH3B,GAAQ/5C,EAAKmR,EAAS3U,EAAQ+zB,EAASpB,EAAU+E,GACjDl0B,EAAI4E,SAER,ED48BA55B,EAAAA,GAAAA,GAvoCM+nE,GAAA,WAEc75C,KAASluB,EAAAA,GAAAA,GAFvB+nE,GAAA,YAGeR,KAAUvnE,EAAAA,GAAAA,GAHzB+nE,GAAA,YAIet0C,KAAUzzB,EAAAA,GAAAA,GAJzB+nE,GAAA,WAKcte,KAASzpD,EAAAA,GAAAA,GALvB+nE,GAAA,UAMa/+D,KAAQhJ,EAAAA,GAAAA,GANrB+nE,GAAA,WAOcP,IC8LL,MAAMqJ,WAAmBzc,GAoCtCh1D,WAAAA,CAAYyxC,GACVmQ,SAAKhhD,EAAAA,GAAAA,GAAC,KAAD,yBAAAA,EAAAA,GAAAA,GAAC,KAAD,oBAAAA,EAAAA,GAAAA,GAAC,KAAD,uBAAAA,EAAAA,GAAAA,GAAC,KAAD,uBAAAA,EAAAA,GAAAA,GAAC,KAAD,uBAAAA,EAAAA,GAAAA,GAAC,KAAD,uBAAAA,EAAAA,GAAAA,GAAC,KAAD,qBAELuC,KAAK8G,aAAU6F,EACf3M,KAAKuhD,mBAAgB50C,EACrB3M,KAAK2hD,gBAAah1C,EAClB3M,KAAK4hD,cAAWj1C,EAChB3M,KAAKwiD,iBAAc71C,EACnB3M,KAAKyiD,iBAAc91C,EACnB3M,KAAKyrE,YAAc,EACnBzrE,KAAKmuE,YAAc,EAEf7/B,GACF5wC,OAAOkd,OAAO5a,KAAMsuC,EAExB,CAEA0a,OAAAA,CAAQulB,EAAgBC,EAAgB3lB,GACtC,MAAMxgC,EAAQroB,KAAKkpD,SAAS,CAAC,IAAK,KAAML,IAClC,MAAC5lC,EAAK,SAAEE,GAAYR,GAAkB0F,EAAO,CAAC7Z,EAAG+/D,EAAQlvD,EAAGmvD,KAC5D,WAAC7sB,EAAA,SAAYC,EAAA,YAAUY,EAAW,YAAEC,EAAW,cAAElB,GAAiBvhD,KAAKkpD,SAAS,CACpF,aACA,WACA,cACA,cACA,iBACCL,GACG4lB,GAAWzuE,KAAK8G,QAAQk8C,QAAUhjD,KAAK8G,QAAQswB,aAAe,EAC9DusB,EAAiB1mC,GAAeskC,EAAeK,EAAWD,GAC1D+sB,EAAiBjrD,GAAcR,EAAO0+B,EAAYC,IAAaD,IAAeC,EAC9E+sB,EAAgBhrB,GAAkBrjC,IAAOouD,EACzCE,EAAezqD,GAAWhB,EAAUq/B,EAAcisB,EAAShsB,EAAcgsB,GAE/E,OAAQE,GAAiBC,CAC3B,CAEAtlB,cAAAA,CAAeT,GACb,MAAM,EAACr6C,EAAC,EAAE6Q,EAAC,WAAEsiC,EAAA,SAAYC,EAAA,YAAUY,EAAA,YAAaC,GAAeziD,KAAKkpD,SAAS,CAC3E,IACA,IACA,aACA,WACA,cACA,eACCL,IACG,OAAC55B,EAAA,QAAQ+zB,GAAWhjD,KAAK8G,QACzB+nE,GAAaltB,EAAaC,GAAY,EACtCktB,GAActsB,EAAcC,EAAcO,EAAU/zB,GAAU,EACpE,MAAO,CACLzgB,EAAGA,EAAI3G,KAAKuiB,IAAIykD,GAAaC,EAC7BzvD,EAAGA,EAAIxX,KAAKshB,IAAI0lD,GAAaC,EAEjC,CAEAhd,eAAAA,CAAgBjJ,GACd,OAAO7oD,KAAKspD,eAAeT,EAC7B,CAEA7b,IAAAA,CAAKva,GACH,MAAM,QAAC3rB,EAAO,cAAEy6C,GAAiBvhD,KAC3BivB,GAAUnoB,EAAQmoB,QAAU,GAAK,EACjC+zB,GAAWl8C,EAAQk8C,SAAW,GAAK,EACnC2D,EAAW7/C,EAAQ6/C,SAIzB,GAHA3mD,KAAKyrE,YAAuC,UAAxB3kE,EAAQq9C,YAA2B,IAAO,EAC9DnkD,KAAKmuE,YAAc5sB,EAAgBjhC,GAAMzY,KAAKyZ,MAAMigC,EAAgBjhC,IAAO,EAErD,IAAlBihC,GAAuBvhD,KAAKwiD,YAAc,GAAKxiD,KAAKyiD,YAAc,EACpE,OAGFhwB,EAAIqC,OAEJ,MAAM+5C,GAAa7uE,KAAK2hD,WAAa3hD,KAAK4hD,UAAY,EACtDnvB,EAAIgE,UAAU5uB,KAAKuiB,IAAIykD,GAAa5/C,EAAQpnB,KAAKshB,IAAI0lD,GAAa5/C,GAClE,MAAM8/C,EAAM,EAAIlnE,KAAKshB,IAAIthB,KAAKiD,IAAIuV,GAAIkhC,GAAiB,IACjDytB,EAAe//C,EAAS8/C,EAE9Bt8C,EAAI+F,UAAY1xB,EAAQ6qB,gBACxBc,EAAI4G,YAAcvyB,EAAQ8qB,YAE1Bs8C,GAAQz7C,EAAKzyB,KAAMgvE,EAAchsB,EAAS2D,GAC1CuW,GAAWzqC,EAAKzyB,KAAMgvE,EAAchsB,EAAS2D,GAE7Cl0B,EAAIyC,SACN,ECxZF,SAAS+5C,GAASx8C,EAAK3rB,EAASI,EAAQJ,GACtC2rB,EAAIy8C,QAAUjyD,GAAe/V,EAAMikC,eAAgBrkC,EAAQqkC,gBAC3D1Y,EAAIwqC,YAAYhgD,GAAe/V,EAAMkkC,WAAYtkC,EAAQskC,aACzD3Y,EAAIoyB,eAAiB5nC,GAAe/V,EAAMmkC,iBAAkBvkC,EAAQukC,kBACpE5Y,EAAIqyB,SAAW7nC,GAAe/V,EAAMokC,gBAAiBxkC,EAAQwkC,iBAC7D7Y,EAAIlD,UAAYtS,GAAe/V,EAAMkwB,YAAatwB,EAAQswB,aAC1D3E,EAAI4G,YAAcpc,GAAe/V,EAAM0qB,YAAa9qB,EAAQ8qB,YAC9D,CAEA,SAASoF,GAAOvE,EAAKmF,EAAUtZ,GAC7BmU,EAAIuE,OAAO1Y,EAAO9P,EAAG8P,EAAOe,EAC9B,CAKA,SAAS8vD,GAAcroE,GACrB,OAAIA,EAAQsoE,QACHz3C,GAGL7wB,EAAQk8B,SAA8C,aAAnCl8B,EAAQg8B,uBACtB/K,GAGFf,EACT,CAEA,SAASq4C,GAAShoD,EAAQwhB,EAAS+hB,EAAS,IAC1C,MAAM5jD,EAAQqgB,EAAOzgB,QACd8c,MAAO4rD,EAAc,EAAG3rD,IAAK4rD,EAAYvoE,EAAQ,GAAK4jD,GACtDlnC,MAAO8rD,EAAc7rD,IAAK8rD,GAAc5mC,EACzCnlB,EAAQ7b,KAAKgD,IAAIykE,EAAaE,GAC9B7rD,EAAM9b,KAAKiD,IAAIykE,EAAWE,GAC1BC,EAAUJ,EAAcE,GAAgBD,EAAYC,GAAgBF,EAAcG,GAAcF,EAAYE,EAElH,MAAO,CACLzoE,QACA0c,QACAtZ,KAAMy+B,EAAQz+B,KACd6T,KAAM0F,EAAMD,IAAUgsD,EAAU1oE,EAAQ2c,EAAMD,EAAQC,EAAMD,EAEhE,CAiBA,SAASisD,GAAYl9C,EAAKmG,EAAMiQ,EAAS+hB,GACvC,MAAM,OAACvjC,EAAA,QAAQvgB,GAAW8xB,GACpB,MAAC5xB,EAAA,MAAO0c,EAAA,KAAOtZ,EAAA,KAAM6T,GAAQoxD,GAAShoD,EAAQwhB,EAAS+hB,GACvDglB,EAAaT,GAAcroE,GAEjC,IACI3J,EAAGkrB,EAAO0a,GADV,KAAC8X,GAAO,EAAI,QAAEh9B,GAAW+sC,GAAU,CAAC,EAGxC,IAAKztD,EAAI,EAAGA,GAAK8gB,IAAQ9gB,EACvBkrB,EAAQhB,GAAQ3D,GAAS7F,EAAUI,EAAO9gB,EAAIA,IAAM6J,GAEhDqhB,EAAMmY,OAGCqa,GACTpoB,EAAIsE,OAAO1O,EAAM7Z,EAAG6Z,EAAMhJ,GAC1Bw7B,GAAO,GAEP+0B,EAAWn9C,EAAKsQ,EAAM1a,EAAOxK,EAAS/W,EAAQsoE,SAGhDrsC,EAAO1a,GAQT,OALIje,IACFie,EAAQhB,GAAQ3D,GAAS7F,EAAUI,EAAO,IAAMjX,GAChD4oE,EAAWn9C,EAAKsQ,EAAM1a,EAAOxK,EAAS/W,EAAQsoE,YAGvChlE,CACX,CAiBA,SAASylE,GAAgBp9C,EAAKmG,EAAMiQ,EAAS+hB,GAC3C,MAAMvjC,EAASuR,EAAKvR,QACd,MAACrgB,EAAK,MAAE0c,EAAK,KAAEzF,GAAQoxD,GAAShoD,EAAQwhB,EAAS+hB,IACjD,KAAC/P,GAAO,EAAI,QAAEh9B,GAAW+sC,GAAU,CAAC,EAC1C,IAEIztD,EAAGkrB,EAAOynD,EAAOxtB,EAAMF,EAAM2tB,EAF7BC,EAAO,EACPC,EAAS,EAGb,MAAMC,EAAclxE,IAAW0kB,GAAS7F,EAAUI,EAAOjf,EAAQA,IAAUgI,EACrEmpE,EAAQA,KACR7tB,IAASF,IAEX3vB,EAAIuE,OAAOg5C,EAAM5tB,GACjB3vB,EAAIuE,OAAOg5C,EAAM1tB,GAGjB7vB,EAAIuE,OAAOg5C,EAAMD,KASrB,IALIl1B,IACFxyB,EAAQhB,EAAO6oD,EAAW,IAC1Bz9C,EAAIsE,OAAO1O,EAAM7Z,EAAG6Z,EAAMhJ,IAGvBliB,EAAI,EAAGA,GAAK8gB,IAAQ9gB,EAAG,CAG1B,GAFAkrB,EAAQhB,EAAO6oD,EAAW/yE,IAEtBkrB,EAAMmY,KAER,SAGF,MAAMhyB,EAAI6Z,EAAM7Z,EACV6Q,EAAIgJ,EAAMhJ,EACV+wD,EAAa,EAAJ5hE,EAEX4hE,IAAWN,GAETzwD,EAAIijC,EACNA,EAAOjjC,EACEA,EAAI+iC,IACbA,EAAO/iC,GAGT2wD,GAAQC,EAASD,EAAOxhE,KAAOyhE,IAE/BE,IAGA19C,EAAIuE,OAAOxoB,EAAG6Q,GAEdywD,EAAQM,EACRH,EAAS,EACT3tB,EAAOF,EAAO/iC,GAGhB0wD,EAAQ1wD,CACV,CACA8wD,GACF,CAOA,SAASE,GAAkBz3C,GACzB,MAAMN,EAAOM,EAAK9xB,QACZskC,EAAa9S,EAAK8S,YAAc9S,EAAK8S,WAAWxkC,OAChD0pE,GAAe13C,EAAKusB,aAAevsB,EAAKqR,QAAU3R,EAAK0K,SAA2C,aAAhC1K,EAAKwK,yBAA0CxK,EAAK82C,UAAYhkC,EACxI,OAAOklC,EAAcT,GAAkBF,EACzC,CAKA,SAASY,GAAwBzpE,GAC/B,OAAIA,EAAQsoE,QACHjoC,GAGLrgC,EAAQk8B,SAA8C,aAAnCl8B,EAAQg8B,uBACtBsE,GAGFF,EACT,CAEA,SAASspC,GAAoB/9C,EAAKmG,EAAMlV,EAAO1c,GAC7C,IAAIypE,EAAO73C,EAAK83C,MACXD,IACHA,EAAO73C,EAAK83C,MAAQ,IAAIC,OACpB/3C,EAAK63C,KAAKA,EAAM/sD,EAAO1c,IACzBypE,EAAK35C,aAGTm4C,GAASx8C,EAAKmG,EAAK9xB,SACnB2rB,EAAI4E,OAAOo5C,EACb,CAEA,SAASG,GAAiBn+C,EAAKmG,EAAMlV,EAAO1c,GAC1C,MAAM,SAACyiC,EAAA,QAAU3iC,GAAW8xB,EACtBi4C,EAAgBR,GAAkBz3C,GAExC,IAAK,MAAMiQ,KAAWY,EACpBwlC,GAASx8C,EAAK3rB,EAAS+hC,EAAQ3hC,OAC/BurB,EAAIkE,YACAk6C,EAAcp+C,EAAKmG,EAAMiQ,EAAS,CAACnlB,QAAOC,IAAKD,EAAQ1c,EAAQ,KACjEyrB,EAAIqE,YAENrE,EAAI4E,QAER,ED8LA55B,EAAAA,GAAAA,GAzHqB6wE,GAAmB,KAE1B,QAAM7wE,EAAAA,GAAAA,GAFC6wE,GAAmB,WAIpB,CAChBnqB,YAAa,SACbvyB,YAAa,OACbwZ,WAAY,GACZC,iBAAkB,EAClBC,qBAAiB3+B,EACjB+3C,aAAc,EACdttB,YAAa,EACbnI,OAAQ,EACR+zB,QAAS,EACT//B,WAAOtW,EACPg6C,UAAU,EACV0nB,UAAU,KACV5wE,EAAAA,GAAAA,GAjBiB6wE,GAAmB,gBAmBf,CACrB38C,gBAAiB,qBACjBl0B,EAAAA,GAAAA,GArBiB6wE,GAAmB,cAuBjB,CACnBriD,aAAa,EACbD,WAAavsB,GAAkB,eAATA,IC5F1B,MAAMqxE,GAA8B,oBAAXH,OAEzB,SAAS3jC,GAAKva,EAAKmG,EAAMlV,EAAO1c,GAC1B8pE,KAAcl4C,EAAK9xB,QAAQ+hC,QAC7B2nC,GAAoB/9C,EAAKmG,EAAMlV,EAAO1c,GAEtC4pE,GAAiBn+C,EAAKmG,EAAMlV,EAAO1c,EAEvC,CAEe,MAAM+pE,WAAoBlf,GAoCvCh1D,WAAAA,CAAYyxC,GACVmQ,QAEAz+C,KAAKolD,UAAW,EAChBplD,KAAK8G,aAAU6F,EACf3M,KAAKuqC,YAAS59B,EACd3M,KAAKiqC,WAAQt9B,EACb3M,KAAKoqC,eAAYz9B,EACjB3M,KAAK0wE,WAAQ/jE,EACb3M,KAAKgxE,aAAUrkE,EACf3M,KAAKixE,eAAYtkE,EACjB3M,KAAKmlD,YAAa,EAClBnlD,KAAKkxE,gBAAiB,EACtBlxE,KAAK0qC,mBAAgB/9B,EAEjB2hC,GACF5wC,OAAOkd,OAAO5a,KAAMsuC,EAExB,CAEAqX,mBAAAA,CAAoBla,EAAW7Y,GAC7B,MAAM9rB,EAAU9G,KAAK8G,QACrB,IAAKA,EAAQk8B,SAA8C,aAAnCl8B,EAAQg8B,0BAA2Ch8B,EAAQsoE,UAAYpvE,KAAKkxE,eAAgB,CAClH,MAAM9mE,EAAOtD,EAAQ8gB,SAAW5nB,KAAKiqC,MAAQjqC,KAAKoqC,UAClDxH,GAA2B5iC,KAAKgxE,QAASlqE,EAAS2kC,EAAWrhC,EAAMwoB,GACnE5yB,KAAKkxE,gBAAiB,C,CAE1B,CAEA,UAAI7pD,CAAOA,GACTrnB,KAAKgxE,QAAU3pD,SACRrnB,KAAKixE,iBACLjxE,KAAK0wE,MACZ1wE,KAAKkxE,gBAAiB,CACxB,CAEA,UAAI7pD,GACF,OAAOrnB,KAAKgxE,OACd,CAEA,YAAIvnC,GACF,OAAOzpC,KAAKixE,YAAcjxE,KAAKixE,UAAYlnC,GAAiB/pC,KAAMA,KAAK8G,QAAQ+hC,SACjF,CAMA6pB,KAAAA,GACE,MAAMjpB,EAAWzpC,KAAKypC,SAChBpiB,EAASrnB,KAAKqnB,OACpB,OAAOoiB,EAAS7iC,QAAUygB,EAAOoiB,EAAS,GAAG/lB,MAC/C,CAMAiB,IAAAA,GACE,MAAM8kB,EAAWzpC,KAAKypC,SAChBpiB,EAASrnB,KAAKqnB,OACdrgB,EAAQyiC,EAAS7iC,OACvB,OAAOI,GAASqgB,EAAOoiB,EAASziC,EAAQ,GAAG2c,IAC7C,CASAvJ,WAAAA,CAAYiO,EAAOhG,GACjB,MAAMvb,EAAU9G,KAAK8G,QACflJ,EAAQyqB,EAAMhG,GACdgF,EAASrnB,KAAKqnB,OACdoiB,EAAWD,GAAexpC,KAAM,CAACqiB,WAAUqB,MAAO9lB,EAAO+lB,IAAK/lB,IAEpE,IAAK6rC,EAAS7iC,OACZ,OAGF,MAAM8a,EAAS,GACTyvD,EAAeZ,GAAwBzpE,GAC7C,IAAI3J,EAAG8gB,EACP,IAAK9gB,EAAI,EAAG8gB,EAAOwrB,EAAS7iC,OAAQzJ,EAAI8gB,IAAQ9gB,EAAG,CACjD,MAAM,MAACumB,EAAA,IAAOC,GAAO8lB,EAAStsC,GACxBgR,EAAKkZ,EAAO3D,GACZtV,EAAKiZ,EAAO1D,GAClB,GAAIxV,IAAOC,EAAI,CACbsT,EAAOhC,KAAKvR,GACZ,Q,CAEF,MAAMnR,EAAI6K,KAAKqZ,KAAKtjB,EAAQuQ,EAAGkU,KAAcjU,EAAGiU,GAAYlU,EAAGkU,KACzD+uD,EAAeD,EAAahjE,EAAIC,EAAIpR,EAAG8J,EAAQsoE,SACrDgC,EAAa/uD,GAAYgG,EAAMhG,GAC/BX,EAAOhC,KAAK0xD,EACd,CACA,OAAyB,IAAlB1vD,EAAO9a,OAAe8a,EAAO,GAAKA,CAC3C,CAgBAiuD,WAAAA,CAAYl9C,EAAKoW,EAAS+hB,GACxB,MAAMimB,EAAgBR,GAAkBrwE,MACxC,OAAO6wE,EAAcp+C,EAAKzyB,KAAM6oC,EAAS+hB,EAC3C,CASA6lB,IAAAA,CAAKh+C,EAAK/O,EAAO1c,GACf,MAAMyiC,EAAWzpC,KAAKypC,SAChBonC,EAAgBR,GAAkBrwE,MACxC,IAAIoK,EAAOpK,KAAKiqC,MAEhBvmB,EAAQA,GAAS,EACjB1c,EAAQA,GAAUhH,KAAKqnB,OAAOzgB,OAAS8c,EAEvC,IAAK,MAAMmlB,KAAWY,EACpBr/B,GAAQymE,EAAcp+C,EAAKzyB,KAAM6oC,EAAS,CAACnlB,QAAOC,IAAKD,EAAQ1c,EAAQ,IAEzE,QAASoD,CACX,CASA4iC,IAAAA,CAAKva,EAAKgZ,EAAW/nB,EAAO1c,GAC1B,MAAMF,EAAU9G,KAAK8G,SAAW,CAAC,EAC3BugB,EAASrnB,KAAKqnB,QAAU,GAE1BA,EAAOzgB,QAAUE,EAAQswB,cAC3B3E,EAAIqC,OAEJkY,GAAKva,EAAKzyB,KAAM0jB,EAAO1c,GAEvByrB,EAAIyC,WAGFl1B,KAAKolD,WAEPplD,KAAKkxE,gBAAiB,EACtBlxE,KAAK0wE,WAAQ/jE,EAEjB,ECjbF,SAAS0kE,GAAQrtC,EAAkBM,EAAaxc,EAAiB+gC,GAC/D,MAAM/hD,EAAUk9B,EAAGl9B,SACZ,CAACghB,GAAOlqB,GAASomC,EAAGklB,SAAS,CAACphC,GAAO+gC,GAE5C,OAAQhhD,KAAKqZ,IAAIojB,EAAM1mC,GAASkJ,EAAQyvB,OAASzvB,EAAQwqE,SAC3D,ED6aA7zE,EAAAA,GAAAA,GA1MqBszE,GAAoB,KAE3B,SAAOtzE,EAAAA,GAAAA,GAFAszE,GAAoB,WAOrB,CAChB5lC,eAAgB,OAChBC,WAAY,GACZC,iBAAkB,EAClBC,gBAAiB,QACjBlU,YAAa,EACboL,iBAAiB,EACjBM,uBAAwB,UACxB3L,MAAM,EACNvP,UAAU,EACVwnD,SAAS,EACTpsC,QAAS,KACTvlC,EAAAA,GAAAA,GAnBiBszE,GAAoB,gBAwBhB,CACrBp/C,gBAAiB,kBACjBC,YAAa,iBACbn0B,EAAAA,GAAAA,GA3BiBszE,GAAoB,cA8BlB,CACnB9kD,aAAa,EACbD,WAAavsB,GAAkB,eAATA,GAAkC,SAATA,IC/PpC,MAAM8xE,WAAqB1f,GA6BxCh1D,WAAAA,CAAYyxC,GACVmQ,SAAKhhD,EAAAA,GAAAA,GAAC,KAAD,kBAAAA,EAAAA,GAAAA,GAAC,KAAD,gBAAAA,EAAAA,GAAAA,GAAC,KAAD,eAELuC,KAAK8G,aAAU6F,EACf3M,KAAKogC,YAASzzB,EACd3M,KAAKwgC,UAAO7zB,EACZ3M,KAAK8pC,UAAOn9B,EAER2hC,GACF5wC,OAAOkd,OAAO5a,KAAMsuC,EAExB,CAEA0a,OAAAA,CAAQwoB,EAAgBC,EAAgB5oB,GACtC,MAAM/hD,EAAU9G,KAAK8G,SACf,EAAC0H,EAAA,EAAG6Q,GAAKrf,KAAKkpD,SAAS,CAAC,IAAK,KAAML,GACzC,OAAShhD,KAAKqS,IAAIs3D,EAAShjE,EAAG,GAAK3G,KAAKqS,IAAIu3D,EAASpyD,EAAG,GAAMxX,KAAKqS,IAAIpT,EAAQwqE,UAAYxqE,EAAQyvB,OAAQ,EAC7G,CAEAm7C,QAAAA,CAASF,EAAgB3oB,GACvB,OAAOwoB,GAAQrxE,KAAMwxE,EAAQ,IAAK3oB,EACpC,CAEA8oB,QAAAA,CAASF,EAAgB5oB,GACvB,OAAOwoB,GAAQrxE,KAAMyxE,EAAQ,IAAK5oB,EACpC,CAEAS,cAAAA,CAAeT,GACb,MAAM,EAACr6C,EAAA,EAAG6Q,GAAKrf,KAAKkpD,SAAS,CAAC,IAAK,KAAML,GACzC,MAAO,CAACr6C,IAAG6Q,IACb,CAEA/W,IAAAA,CAAKxB,GACHA,EAAUA,GAAW9G,KAAK8G,SAAW,CAAC,EACtC,IAAIyvB,EAASzvB,EAAQyvB,QAAU,EAC/BA,EAAS1uB,KAAKgD,IAAI0rB,EAAQA,GAAUzvB,EAAQ8qE,aAAe,GAC3D,MAAMx6C,EAAcb,GAAUzvB,EAAQswB,aAAe,EACrD,OAAgC,GAAxBb,EAASa,EACnB,CAEA4V,IAAAA,CAAKva,EAA+B8E,GAClC,MAAMzwB,EAAU9G,KAAK8G,QAEjB9G,KAAKwgC,MAAQ15B,EAAQyvB,OAAS,KAAQe,GAAet3B,KAAMu3B,EAAMv3B,KAAKsI,KAAKxB,GAAW,KAI1F2rB,EAAI4G,YAAcvyB,EAAQ8qB,YAC1Ba,EAAIlD,UAAYzoB,EAAQswB,YACxB3E,EAAI+F,UAAY1xB,EAAQ6qB,gBACxBmE,GAAUrD,EAAK3rB,EAAS9G,KAAKwO,EAAGxO,KAAKqf,GACvC,CAEA6oC,QAAAA,GACE,MAAMphD,EAAU9G,KAAK8G,SAAW,CAAC,EAEjC,OAAOA,EAAQyvB,OAASzvB,EAAQwqE,SAClC,EC3FF,SAASO,GAAaC,EAAKjpB,GACzB,MAAM,EAACr6C,EAAC,EAAE6Q,EAAC,KAAEkG,EAAA,MAAMyK,EAAA,OAAO6F,GAAmCi8C,EAAI5oB,SAAS,CAAC,IAAK,IAAK,OAAQ,QAAS,UAAWL,GAEjH,IAAI9hC,EAAMC,EAAO6F,EAAKC,EAAQilD,EAgB9B,OAdID,EAAIl0B,YACNm0B,EAAOl8C,EAAS,EAChB9O,EAAOlf,KAAKiD,IAAI0D,EAAG+W,GACnByB,EAAQnf,KAAKgD,IAAI2D,EAAG+W,GACpBsH,EAAMxN,EAAI0yD,EACVjlD,EAASzN,EAAI0yD,IAEbA,EAAO/hD,EAAQ,EACfjJ,EAAOvY,EAAIujE,EACX/qD,EAAQxY,EAAIujE,EACZllD,EAAMhlB,KAAKiD,IAAIuU,EAAGkG,GAClBuH,EAASjlB,KAAKgD,IAAIwU,EAAGkG,IAGhB,CAACwB,OAAM8F,MAAK7F,QAAO8F,SAC5B,CAEA,SAASklD,GAAYxxC,EAAM5iC,EAAOkN,EAAKD,GACrC,OAAO21B,EAAO,EAAIvc,GAAYrmB,EAAOkN,EAAKD,EAC5C,CAEA,SAASonE,GAAiBH,EAAKI,EAAMC,GACnC,MAAMv0E,EAAQk0E,EAAIhrE,QAAQswB,YACpBoJ,EAAOsxC,EAAI/zB,cACXrhD,EAAIu+B,GAAOr9B,GAEjB,MAAO,CACLZ,EAAGg1E,GAAYxxC,EAAK3T,IAAKnwB,EAAEmwB,IAAK,EAAGslD,GACnCl1E,EAAG+0E,GAAYxxC,EAAKxZ,MAAOtqB,EAAEsqB,MAAO,EAAGkrD,GACvCvmE,EAAGqmE,GAAYxxC,EAAK1T,OAAQpwB,EAAEowB,OAAQ,EAAGqlD,GACzCxnE,EAAGqnE,GAAYxxC,EAAKzZ,KAAMrqB,EAAEqqB,KAAM,EAAGmrD,GAEzC,CAEA,SAASE,GAAkBN,EAAKI,EAAMC,GACpC,MAAM,mBAACn0B,GAAsB8zB,EAAI5oB,SAAS,CAAC,uBACrCtrD,EAAQk0E,EAAIhrE,QAAQ49C,aACpBhoD,EAAIw+B,GAAct9B,GAClBy0E,EAAOxqE,KAAKiD,IAAIonE,EAAMC,GACtB3xC,EAAOsxC,EAAI/zB,cAIXu0B,EAAet0B,GAAsBphC,GAAShf,GAEpD,MAAO,CACLu8B,QAAS63C,IAAaM,GAAgB9xC,EAAK3T,KAAO2T,EAAKzZ,KAAMrqB,EAAEy9B,QAAS,EAAGk4C,GAC3E/3C,SAAU03C,IAAaM,GAAgB9xC,EAAK3T,KAAO2T,EAAKxZ,MAAOtqB,EAAE49B,SAAU,EAAG+3C,GAC9Ej4C,WAAY43C,IAAaM,GAAgB9xC,EAAK1T,QAAU0T,EAAKzZ,KAAMrqB,EAAE09B,WAAY,EAAGi4C,GACpFh4C,YAAa23C,IAAaM,GAAgB9xC,EAAK1T,QAAU0T,EAAKxZ,MAAOtqB,EAAE29B,YAAa,EAAGg4C,GAE3F,CAEA,SAASE,GAAcT,GACrB,MAAM3iD,EAAS0iD,GAAaC,GACtB9hD,EAAQb,EAAOnI,MAAQmI,EAAOpI,KAC9B8O,EAAS1G,EAAOrC,OAASqC,EAAOtC,IAChCgD,EAASoiD,GAAiBH,EAAK9hD,EAAQ,EAAG6F,EAAS,GACnDU,EAAS67C,GAAkBN,EAAK9hD,EAAQ,EAAG6F,EAAS,GAE1D,MAAO,CACL28C,MAAO,CACLhkE,EAAG2gB,EAAOpI,KACV1H,EAAG8P,EAAOtC,IACV1f,EAAG6iB,EACHplB,EAAGirB,EACHU,UAEF63C,MAAO,CACL5/D,EAAG2gB,EAAOpI,KAAO8I,EAAOllB,EACxB0U,EAAG8P,EAAOtC,IAAMgD,EAAO7yB,EACvBmQ,EAAG6iB,EAAQH,EAAOllB,EAAIklB,EAAO5yB,EAC7B2N,EAAGirB,EAAShG,EAAO7yB,EAAI6yB,EAAOlkB,EAC9B4qB,OAAQ,CACN4D,QAAStyB,KAAKgD,IAAI,EAAG0rB,EAAO4D,QAAUtyB,KAAKgD,IAAIglB,EAAO7yB,EAAG6yB,EAAOllB,IAChE2vB,SAAUzyB,KAAKgD,IAAI,EAAG0rB,EAAO+D,SAAWzyB,KAAKgD,IAAIglB,EAAO7yB,EAAG6yB,EAAO5yB,IAClEm9B,WAAYvyB,KAAKgD,IAAI,EAAG0rB,EAAO6D,WAAavyB,KAAKgD,IAAIglB,EAAOlkB,EAAGkkB,EAAOllB,IACtE0vB,YAAaxyB,KAAKgD,IAAI,EAAG0rB,EAAO8D,YAAcxyB,KAAKgD,IAAIglB,EAAOlkB,EAAGkkB,EAAO5yB,MAIhF,CAEA,SAAS+rD,GAAQ8oB,EAAKtjE,EAAG6Q,EAAGwpC,GAC1B,MAAM4pB,EAAc,OAANjkE,EACRkkE,EAAc,OAANrzD,EACRszD,EAAWF,GAASC,EACpBvjD,EAAS2iD,IAAQa,GAAYd,GAAaC,EAAKjpB,GAErD,OAAO15B,IACHsjD,GAAStuD,GAAW3V,EAAG2gB,EAAOpI,KAAMoI,EAAOnI,UAC3C0rD,GAASvuD,GAAW9E,EAAG8P,EAAOtC,IAAKsC,EAAOrC,QAChD,CAEA,SAAS8lD,GAAUr8C,GACjB,OAAOA,EAAO4D,SAAW5D,EAAO+D,UAAY/D,EAAO6D,YAAc7D,EAAO8D,WAC1E,CAOA,SAASw4C,GAAkBpgD,EAAKyE,GAC9BzE,EAAIyE,KAAKA,EAAK1oB,EAAG0oB,EAAK7X,EAAG6X,EAAK/pB,EAAG+pB,EAAKtsB,EACxC,CAEA,SAASkoE,GAAY57C,EAAM67C,EAAQC,EAAU,IAC3C,MAAMxkE,EAAI0oB,EAAK1oB,IAAMwkE,EAAQxkE,GAAKukE,EAAS,EACrC1zD,EAAI6X,EAAK7X,IAAM2zD,EAAQ3zD,GAAK0zD,EAAS,EACrC5lE,GAAK+pB,EAAK1oB,EAAI0oB,EAAK/pB,IAAM6lE,EAAQxkE,EAAIwkE,EAAQ7lE,EAAI4lE,EAAS,GAAKvkE,EAC/D5D,GAAKssB,EAAK7X,EAAI6X,EAAKtsB,IAAMooE,EAAQ3zD,EAAI2zD,EAAQpoE,EAAImoE,EAAS,GAAK1zD,EACrE,MAAO,CACL7Q,EAAG0oB,EAAK1oB,EAAIA,EACZ6Q,EAAG6X,EAAK7X,EAAIA,EACZlS,EAAG+pB,EAAK/pB,EAAIA,EACZvC,EAAGssB,EAAKtsB,EAAIA,EACZ2rB,OAAQW,EAAKX,OAEjB,EDhCA94B,EAAAA,GAAAA,GAvFqB8zE,GAAqB,KAE5B,UAMZ9zE,EAAAA,GAAAA,GARmB8zE,GAAqB,WAWtB,CAChBn6C,YAAa,EACbk6C,UAAW,EACXltB,iBAAkB,EAClBwtB,YAAa,EACbv7C,WAAY,SACZE,OAAQ,EACRD,SAAU,KAGZ74B,EAAAA,GAAAA,GArBmB8zE,GAAqB,gBAwBjB,CACrB5/C,gBAAiB,kBACjBC,YAAa,gBC+FF,MAAMqhD,WAAmBphB,GAuBtCh1D,WAAAA,CAAYyxC,GACVmQ,QAEAz+C,KAAK8G,aAAU6F,EACf3M,KAAK49C,gBAAajxC,EAClB3M,KAAKulB,UAAO5Y,EACZ3M,KAAKgwB,WAAQrjB,EACb3M,KAAK61B,YAASlpB,EACd3M,KAAKu+C,mBAAgB5xC,EAEjB2hC,GACF5wC,OAAOkd,OAAO5a,KAAMsuC,EAExB,CAEAtB,IAAAA,CAAKva,GACH,MAAM,cAAC8rB,EAAez3C,SAAS,YAAC8qB,EAAA,gBAAaD,IAAoB3xB,MAC3D,MAACouE,EAAK,MAAEoE,GAASD,GAAcvyE,MAC/BkzE,EAAcN,GAAUJ,EAAMj8C,QAAU2D,GAAqB24C,GAEnEpgD,EAAIqC,OAEA09C,EAAMrlE,IAAMihE,EAAMjhE,GAAKqlE,EAAM5nE,IAAMwjE,EAAMxjE,IAC3C6nB,EAAIkE,YACJu8C,EAAYzgD,EAAKqgD,GAAYN,EAAOj0B,EAAe6vB,IACnD37C,EAAIrD,OACJ8jD,EAAYzgD,EAAKqgD,GAAY1E,GAAQ7vB,EAAei0B,IACpD//C,EAAI+F,UAAY5G,EAChBa,EAAI0E,KAAK,YAGX1E,EAAIkE,YACJu8C,EAAYzgD,EAAKqgD,GAAY1E,EAAO7vB,IACpC9rB,EAAI+F,UAAY7G,EAChBc,EAAI0E,OAEJ1E,EAAIyC,SACN,CAEA8zB,OAAAA,CAAQwoB,EAAQC,EAAQ5oB,GACtB,OAAOG,GAAQhpD,KAAMwxE,EAAQC,EAAQ5oB,EACvC,CAEA6oB,QAAAA,CAASF,EAAQ3oB,GACf,OAAOG,GAAQhpD,KAAMwxE,EAAQ,KAAM3oB,EACrC,CAEA8oB,QAAAA,CAASF,EAAQ5oB,GACf,OAAOG,GAAQhpD,KAAM,KAAMyxE,EAAQ5oB,EACrC,CAEAS,cAAAA,CAAeT,GACb,MAAM,EAACr6C,EAAA,EAAG6Q,EAAA,KAAGkG,EAAI,WAAEq4B,GAAuC59C,KAAKkpD,SAAS,CAAC,IAAK,IAAK,OAAQ,cAAeL,GAC1G,MAAO,CACLr6C,EAAGovC,GAAcpvC,EAAI+W,GAAQ,EAAI/W,EACjC6Q,EAAGu+B,EAAav+B,GAAKA,EAAIkG,GAAQ,EAErC,CAEA2iC,QAAAA,CAASpgC,GACP,MAAgB,MAATA,EAAe9nB,KAAKgwB,MAAQ,EAAIhwB,KAAK61B,OAAS,CACvD,GACFp4B,EAAAA,GAAAA,GArFqBw1E,GAAmB,KAE1B,QAAMx1E,EAAAA,GAAAA,GAFCw1E,GAAmB,WAOpB,CAChBl1B,cAAe,QACf3mB,YAAa,EACbstB,aAAc,EACdnG,cAAe,OACfloB,gBAAY1pB,KACZlP,EAAAA,GAAAA,GAbiBw1E,GAAmB,gBAkBf,CACrBthD,gBAAiB,kBACjBC,YAAa,gBCzIjB,MAAMuhD,GAAaA,CAACC,EAAWzV,KAC7B,IAAI,UAAC0V,EAAY1V,EAAA,SAAU2V,EAAW3V,GAAYyV,EAOlD,OALIA,EAAUG,gBACZF,EAAYxrE,KAAKiD,IAAIuoE,EAAW1V,GAChC2V,EAAWF,EAAUI,iBAAmB3rE,KAAKiD,IAAIwoE,EAAU3V,IAGtD,CACL2V,WACAD,YACAI,WAAY5rE,KAAKgD,IAAI8yD,EAAU0V,KAI7BK,GAAaA,CAAChoE,EAAGC,IAAY,OAAND,GAAoB,OAANC,GAAcD,EAAE0S,eAAiBzS,EAAEyS,cAAgB1S,EAAE1M,QAAU2M,EAAE3M,MAErG,MAAM20E,WAAe9hB,GAK1Bh1D,WAAAA,CAAY2yC,GACViP,QAEAz+C,KAAK4zE,QAAS,EAGd5zE,KAAK6zE,eAAiB,GAKtB7zE,KAAK8zE,aAAe,KAGpB9zE,KAAK+zE,cAAe,EAEpB/zE,KAAKiuB,MAAQuhB,EAAOvhB,MACpBjuB,KAAK8G,QAAU0oC,EAAO1oC,QACtB9G,KAAKyyB,IAAM+c,EAAO/c,IAClBzyB,KAAKg0E,iBAAcrnE,EACnB3M,KAAKi0E,iBAActnE,EACnB3M,KAAKk0E,gBAAavnE,EAClB3M,KAAKwlC,eAAY74B,EACjB3M,KAAKg6B,cAAWrtB,EAChB3M,KAAK6sB,SAAMlgB,EACX3M,KAAK8sB,YAASngB,EACd3M,KAAK+mB,UAAOpa,EACZ3M,KAAKgnB,WAAQra,EACb3M,KAAK61B,YAASlpB,EACd3M,KAAKgwB,WAAQrjB,EACb3M,KAAK+0D,cAAWpoD,EAChB3M,KAAKooD,cAAWz7C,EAChB3M,KAAKwb,YAAS7O,EACd3M,KAAKgrD,cAAWr+C,CAClB,CAEAqiC,MAAAA,CAAOhV,EAAUwL,EAAWY,GAC1BpmC,KAAKg6B,SAAWA,EAChBh6B,KAAKwlC,UAAYA,EACjBxlC,KAAK+0D,SAAW3uB,EAEhBpmC,KAAK42D,gBACL52D,KAAKm0E,cACLn0E,KAAK+J,KACP,CAEA6sD,aAAAA,GACM52D,KAAK09C,gBACP19C,KAAKgwB,MAAQhwB,KAAKg6B,SAClBh6B,KAAK+mB,KAAO/mB,KAAK+0D,SAAShuC,KAC1B/mB,KAAKgnB,MAAQhnB,KAAKgwB,QAElBhwB,KAAK61B,OAAS71B,KAAKwlC,UACnBxlC,KAAK6sB,IAAM7sB,KAAK+0D,SAASloC,IACzB7sB,KAAK8sB,OAAS9sB,KAAK61B,OAEvB,CAEAs+C,WAAAA,GACE,MAAMf,EAAYpzE,KAAK8G,QAAQ4wC,QAAU,CAAC,EAC1C,IAAIs8B,EAAcz2D,GAAK61D,EAAU5uB,eAAgB,CAACxkD,KAAKiuB,OAAQjuB,OAAS,GAEpEozE,EAAU7zC,SACZy0C,EAAcA,EAAYz0C,OAAQzgC,GAASs0E,EAAU7zC,OAAOzgC,EAAMkB,KAAKiuB,MAAMnuB,QAG3EszE,EAAUxxD,OACZoyD,EAAcA,EAAYpyD,KAAK,CAAClW,EAAGC,IAAMynE,EAAUxxD,KAAKlW,EAAGC,EAAG3L,KAAKiuB,MAAMnuB,QAGvEE,KAAK8G,QAAQ+W,SACfm2D,EAAYn2D,UAGd7d,KAAKg0E,YAAcA,CACrB,CAEAjqE,GAAAA,GACE,MAAM,QAACjD,EAAO,IAAE2rB,GAAOzyB,KAMvB,IAAK8G,EAAQkoB,QAEX,YADAhvB,KAAKgwB,MAAQhwB,KAAK61B,OAAS,GAI7B,MAAMu9C,EAAYtsE,EAAQ4wC,OACpB08B,EAAYh5C,GAAOg4C,EAAUhhD,MAC7BurC,EAAWyW,EAAU9rE,KACrB2wD,EAAcj5D,KAAKq0E,uBACnB,SAACf,EAAQ,WAAEG,GAAcN,GAAWC,EAAWzV,GAErD,IAAI3tC,EAAO6F,EAEXpD,EAAIL,KAAOgiD,EAAU7/C,OAEjBv0B,KAAK09C,gBACP1tB,EAAQhwB,KAAKg6B,SACbnE,EAAS71B,KAAKs0E,SAASrb,EAAa0E,EAAU2V,EAAUG,GAAc,KAEtE59C,EAAS71B,KAAKwlC,UACdxV,EAAQhwB,KAAKu0E,SAAStb,EAAamb,EAAWd,EAAUG,GAAc,IAGxEzzE,KAAKgwB,MAAQnoB,KAAKiD,IAAIklB,EAAOlpB,EAAQkzB,UAAYh6B,KAAKg6B,UACtDh6B,KAAK61B,OAAShuB,KAAKiD,IAAI+qB,EAAQ/uB,EAAQ0+B,WAAaxlC,KAAKwlC,UAC3D,CAKA8uC,QAAAA,CAASrb,EAAa0E,EAAU2V,EAAUG,GACxC,MAAM,IAAChhD,EAAG,SAAEuH,EAAUlzB,SAAU4wC,QAAQ,QAAC9qB,KAAa5sB,KAChDw0E,EAAWx0E,KAAK6zE,eAAiB,GAEjCK,EAAal0E,KAAKk0E,WAAa,CAAC,GAChC5hD,EAAamhD,EAAa7mD,EAChC,IAAI6nD,EAAcxb,EAElBxmC,EAAIgG,UAAY,OAChBhG,EAAIiG,aAAe,SAEnB,IAAIg8C,GAAO,EACP7nD,GAAOyF,EAgBX,OAfAtyB,KAAKg0E,YAAY3uD,QAAQ,CAAC0/B,EAAY5nD,KACpC,MAAMyqC,EAAY0rC,EAAY3V,EAAW,EAAKlrC,EAAIgC,YAAYswB,EAAW90B,MAAMD,OAErE,IAAN7yB,GAAW+2E,EAAWA,EAAWttE,OAAS,GAAKghC,EAAY,EAAIhb,EAAUoN,KAC3Ey6C,GAAeniD,EACf4hD,EAAWA,EAAWttE,QAAUzJ,EAAI,EAAI,EAAI,IAAM,EAClD0vB,GAAOyF,EACPoiD,KAGFF,EAASr3E,GAAK,CAAC4pB,KAAM,EAAG8F,MAAK6nD,MAAK1kD,MAAO4X,EAAW/R,OAAQ49C,GAE5DS,EAAWA,EAAWttE,OAAS,IAAMghC,EAAYhb,IAG5C6nD,CACT,CAEAF,QAAAA,CAAStb,EAAamb,EAAWd,EAAUqB,GACzC,MAAM,IAACliD,EAAG,UAAE+S,EAAW1+B,SAAU4wC,QAAQ,QAAC9qB,KAAa5sB,KACjDw0E,EAAWx0E,KAAK6zE,eAAiB,GACjCI,EAAcj0E,KAAKi0E,YAAc,GACjCW,EAAcpvC,EAAYyzB,EAEhC,IAAI4b,EAAajoD,EACbkoD,EAAkB,EAClBC,EAAmB,EAEnBhuD,EAAO,EACPiuD,EAAM,EAyBV,OAvBAh1E,KAAKg0E,YAAY3uD,QAAQ,CAAC0/B,EAAY5nD,KACpC,MAAM,UAACyqC,EAAS,WAAE6rC,GAAcwB,GAAkB3B,EAAUc,EAAW3hD,EAAKsyB,EAAY4vB,GAGpFx3E,EAAI,GAAK43E,EAAmBtB,EAAa,EAAI7mD,EAAUgoD,IACzDC,GAAcC,EAAkBloD,EAChCqnD,EAAYv0D,KAAK,CAACsQ,MAAO8kD,EAAiBj/C,OAAQk/C,IAClDhuD,GAAQ+tD,EAAkBloD,EAC1BooD,IACAF,EAAkBC,EAAmB,GAIvCP,EAASr3E,GAAK,CAAC4pB,OAAM8F,IAAKkoD,EAAkBC,MAAKhlD,MAAO4X,EAAW/R,OAAQ49C,GAG3EqB,EAAkBjtE,KAAKgD,IAAIiqE,EAAiBltC,GAC5CmtC,GAAoBtB,EAAa7mD,IAGnCioD,GAAcC,EACdb,EAAYv0D,KAAK,CAACsQ,MAAO8kD,EAAiBj/C,OAAQk/C,IAE3CF,CACT,CAEAK,cAAAA,GACE,IAAKl1E,KAAK8G,QAAQkoB,QAChB,OAEF,MAAMiqC,EAAcj5D,KAAKq0E,uBAClBR,eAAgBW,EAAU1tE,SAAS,MAAC8f,EAAO8wB,QAAQ,QAAC9qB,GAAQ,IAAE3F,IAAQjnB,KACvEm1E,EAAYptC,GAAc9gB,EAAKjnB,KAAK+mB,KAAM/mB,KAAKgwB,OACrD,GAAIhwB,KAAK09C,eAAgB,CACvB,IAAIg3B,EAAM,EACN3tD,EAAOF,GAAeD,EAAO5mB,KAAK+mB,KAAO6F,EAAS5sB,KAAKgnB,MAAQhnB,KAAKk0E,WAAWQ,IACnF,IAAK,MAAMU,KAAUZ,EACfE,IAAQU,EAAOV,MACjBA,EAAMU,EAAOV,IACb3tD,EAAOF,GAAeD,EAAO5mB,KAAK+mB,KAAO6F,EAAS5sB,KAAKgnB,MAAQhnB,KAAKk0E,WAAWQ,KAEjFU,EAAOvoD,KAAO7sB,KAAK6sB,IAAMosC,EAAcrsC,EACvCwoD,EAAOruD,KAAOouD,EAAUxtC,WAAWwtC,EAAU3mE,EAAEuY,GAAOquD,EAAOplD,OAC7DjJ,GAAQquD,EAAOplD,MAAQpD,C,KAEpB,CACL,IAAIooD,EAAM,EACNnoD,EAAMhG,GAAeD,EAAO5mB,KAAK6sB,IAAMosC,EAAcrsC,EAAS5sB,KAAK8sB,OAAS9sB,KAAKi0E,YAAYe,GAAKn/C,QACtG,IAAK,MAAMu/C,KAAUZ,EACfY,EAAOJ,MAAQA,IACjBA,EAAMI,EAAOJ,IACbnoD,EAAMhG,GAAeD,EAAO5mB,KAAK6sB,IAAMosC,EAAcrsC,EAAS5sB,KAAK8sB,OAAS9sB,KAAKi0E,YAAYe,GAAKn/C,SAEpGu/C,EAAOvoD,IAAMA,EACbuoD,EAAOruD,MAAQ/mB,KAAK+mB,KAAO6F,EAC3BwoD,EAAOruD,KAAOouD,EAAUxtC,WAAWwtC,EAAU3mE,EAAE4mE,EAAOruD,MAAOquD,EAAOplD,OACpEnD,GAAOuoD,EAAOv/C,OAASjJ,C,CAG7B,CAEA8wB,YAAAA,GACE,MAAiC,QAA1B19C,KAAK8G,QAAQshD,UAAgD,WAA1BpoD,KAAK8G,QAAQshD,QACzD,CAEApb,IAAAA,GACE,GAAIhtC,KAAK8G,QAAQkoB,QAAS,CACxB,MAAMyD,EAAMzyB,KAAKyyB,IACjBgF,GAAShF,EAAKzyB,MAEdA,KAAKq1E,QAEL39C,GAAWjF,E,CAEf,CAKA4iD,KAAAA,GACE,MAAOvuE,QAASwxB,EAAA,YAAM27C,EAAA,WAAaC,EAAA,IAAYzhD,GAAOzyB,MAChD,MAAC4mB,EAAO8wB,OAAQ07B,GAAa96C,EAC7Bg9C,EAAe3pD,GAASpQ,MACxB45D,EAAYptC,GAAczP,EAAKrR,IAAKjnB,KAAK+mB,KAAM/mB,KAAKgwB,OACpDokD,EAAYh5C,GAAOg4C,EAAUhhD,OAC7B,QAACxF,GAAWwmD,EACZzV,EAAWyW,EAAU9rE,KACrBitE,EAAe5X,EAAW,EAChC,IAAI6X,EAEJx1E,KAAKs9D,YAGL7qC,EAAIgG,UAAY08C,EAAU18C,UAAU,QACpChG,EAAIiG,aAAe,SACnBjG,EAAIlD,UAAY,GAChBkD,EAAIL,KAAOgiD,EAAU7/C,OAErB,MAAM,SAAC++C,EAAA,UAAUD,EAAA,WAAWI,GAAcN,GAAWC,EAAWzV,GAG1D8X,EAAgB,SAASjnE,EAAG6Q,EAAG0lC,GACnC,GAAI/iC,MAAMsxD,IAAaA,GAAY,GAAKtxD,MAAMqxD,IAAcA,EAAY,EACtE,OAIF5gD,EAAIqC,OAEJ,MAAMvF,EAAYtS,GAAe8nC,EAAWx1B,UAAW,GAUvD,GATAkD,EAAI+F,UAAYvb,GAAe8nC,EAAWvsB,UAAW88C,GACrD7iD,EAAIy8C,QAAUjyD,GAAe8nC,EAAWmqB,QAAS,QACjDz8C,EAAIoyB,eAAiB5nC,GAAe8nC,EAAWF,eAAgB,GAC/DpyB,EAAIqyB,SAAW7nC,GAAe8nC,EAAWD,SAAU,SACnDryB,EAAIlD,UAAYA,EAChBkD,EAAI4G,YAAcpc,GAAe8nC,EAAW1rB,YAAai8C,GAEzD7iD,EAAIwqC,YAAYhgD,GAAe8nC,EAAWH,SAAU,KAEhDwuB,EAAUG,cAAe,CAG3B,MAAMmC,EAAc,CAClBn/C,OAAQ88C,EAAYxrE,KAAK8tE,MAAQ,EACjCt/C,WAAY0uB,EAAW1uB,WACvBC,SAAUyuB,EAAWzuB,SACrBc,YAAa7H,GAETw0B,EAAUoxB,EAAUztC,MAAMl5B,EAAG8kE,EAAW,GACxCtvB,EAAU3kC,EAAIk2D,EAGpBx/C,GAAgBtD,EAAKijD,EAAa3xB,EAASC,EAASovB,EAAUI,iBAAmBF,E,KAC5E,CAGL,MAAMsC,EAAUv2D,EAAIxX,KAAKgD,KAAK8yD,EAAW0V,GAAa,EAAG,GACnDwC,EAAWV,EAAUxtC,WAAWn5B,EAAG8kE,GACnC5uB,EAAexpB,GAAc6pB,EAAWL,cAE9CjyB,EAAIkE,YAEAj5B,OAAOqnB,OAAO2/B,GAAcsc,KAAKv2D,GAAW,IAANA,GACxCyvB,GAAmBzH,EAAK,CACtBjkB,EAAGqnE,EACHx2D,EAAGu2D,EACHzoE,EAAGmmE,EACH1oE,EAAGyoE,EACH98C,OAAQmuB,IAGVjyB,EAAIyE,KAAK2+C,EAAUD,EAAStC,EAAUD,GAGxC5gD,EAAI0E,OACc,IAAd5H,GACFkD,EAAI4E,Q,CAIR5E,EAAIyC,SACN,EAEM+E,EAAW,SAASzrB,EAAG6Q,EAAG0lC,GAC9BrrB,GAAWjH,EAAKsyB,EAAW90B,KAAMzhB,EAAG6Q,EAAKo0D,EAAa,EAAIW,EAAW,CACnEv7C,cAAeksB,EAAW9Q,OAC1Bxb,UAAW08C,EAAU18C,UAAUssB,EAAWtsB,YAE9C,EAGMilB,EAAe19C,KAAK09C,eACpBub,EAAcj5D,KAAKq0E,sBAEvBmB,EADE93B,EACO,CACPlvC,EAAGqY,GAAeD,EAAO5mB,KAAK+mB,KAAO6F,EAAS5sB,KAAKgnB,MAAQktD,EAAW,IACtE70D,EAAGrf,KAAK6sB,IAAMD,EAAUqsC,EACxBrgC,KAAM,GAGC,CACPpqB,EAAGxO,KAAK+mB,KAAO6F,EACfvN,EAAGwH,GAAeD,EAAO5mB,KAAK6sB,IAAMosC,EAAcrsC,EAAS5sB,KAAK8sB,OAASmnD,EAAY,GAAGp+C,QACxF+C,KAAM,GAIVoP,GAAsBhoC,KAAKyyB,IAAK6F,EAAKw9C,eAErC,MAAMxjD,EAAamhD,EAAa7mD,EAChC5sB,KAAKg0E,YAAY3uD,QAAQ,CAAC0/B,EAAY5nD,KACpCs1B,EAAI4G,YAAc0rB,EAAWJ,UAC7BlyB,EAAI+F,UAAYusB,EAAWJ,UAE3B,MAAMnwB,EAAY/B,EAAIgC,YAAYswB,EAAW90B,MAAMD,MAC7CyI,EAAY08C,EAAU18C,UAAUssB,EAAWtsB,YAAcssB,EAAWtsB,UAAY26C,EAAU36C,YAC1FzI,EAAQsjD,EAAWiC,EAAe/gD,EACxC,IAAIhmB,EAAIgnE,EAAOhnE,EACX6Q,EAAIm2D,EAAOn2D,EAEf81D,EAAU1tC,SAASznC,KAAKgwB,OAEpB0tB,EACEvgD,EAAI,GAAKqR,EAAIwhB,EAAQpD,EAAU5sB,KAAKgnB,QACtC3H,EAAIm2D,EAAOn2D,GAAKiT,EAChBkjD,EAAO58C,OACPpqB,EAAIgnE,EAAOhnE,EAAIqY,GAAeD,EAAO5mB,KAAK+mB,KAAO6F,EAAS5sB,KAAKgnB,MAAQktD,EAAWsB,EAAO58C,QAElFz7B,EAAI,GAAKkiB,EAAIiT,EAAatyB,KAAK8sB,SACxCte,EAAIgnE,EAAOhnE,EAAIA,EAAIylE,EAAYuB,EAAO58C,MAAM5I,MAAQpD,EACpD4oD,EAAO58C,OACPvZ,EAAIm2D,EAAOn2D,EAAIwH,GAAeD,EAAO5mB,KAAK6sB,IAAMosC,EAAcrsC,EAAS5sB,KAAK8sB,OAASmnD,EAAYuB,EAAO58C,MAAM/C,SAGhH,MAAMkgD,EAAQZ,EAAU3mE,EAAEA,GAS1B,GAPAinE,EAAcM,EAAO12D,EAAG0lC,GAExBv2C,EAAIsY,GAAO2R,EAAWjqB,EAAI8kE,EAAWiC,EAAc73B,EAAelvC,EAAIwhB,EAAQhwB,KAAKgnB,MAAOsR,EAAKrR,KAG/FgT,EAASk7C,EAAU3mE,EAAEA,GAAI6Q,EAAG0lC,GAExBrH,EACF83B,EAAOhnE,GAAKwhB,EAAQpD,OACf,GAA+B,kBAApBm4B,EAAW90B,KAAmB,CAC9C,MAAM+lD,EAAiB5B,EAAU9hD,WACjCkjD,EAAOn2D,GAAK42D,GAA0BlxB,EAAYixB,GAAkBppD,C,MAEpE4oD,EAAOn2D,GAAKiT,IAIhBgW,GAAqBtoC,KAAKyyB,IAAK6F,EAAKw9C,cACtC,CAKAxY,SAAAA,GACE,MAAMhlC,EAAOt4B,KAAK8G,QACZiyD,EAAYzgC,EAAKh5B,MACjB42E,EAAY96C,GAAO29B,EAAU3mC,MAC7B+jD,EAAeh7C,GAAU49B,EAAUnsC,SAEzC,IAAKmsC,EAAU/pC,QACb,OAGF,MAAMmmD,EAAYptC,GAAczP,EAAKrR,IAAKjnB,KAAK+mB,KAAM/mB,KAAKgwB,OACpDyC,EAAMzyB,KAAKyyB,IACX21B,EAAW2Q,EAAU3Q,SACrBmtB,EAAeW,EAAU5tE,KAAO,EAChC8tE,EAA6BD,EAAatpD,IAAM0oD,EACtD,IAAIl2D,EAIA0H,EAAO/mB,KAAK+mB,KACZiT,EAAWh6B,KAAKgwB,MAEpB,GAAIhwB,KAAK09C,eAEP1jB,EAAWnyB,KAAKgD,OAAO7K,KAAKk0E,YAC5B70D,EAAIrf,KAAK6sB,IAAMupD,EACfrvD,EAAOF,GAAeyR,EAAK1R,MAAOG,EAAM/mB,KAAKgnB,MAAQgT,OAChD,CAEL,MAAMwL,EAAYxlC,KAAKi0E,YAAYvmC,OAAO,CAACC,EAAKrlC,IAAST,KAAKgD,IAAI8iC,EAAKrlC,EAAKutB,QAAS,GACrFxW,EAAI+2D,EAA6BvvD,GAAeyR,EAAK1R,MAAO5mB,KAAK6sB,IAAK7sB,KAAK8sB,OAAS0Y,EAAYlN,EAAKof,OAAO9qB,QAAU5sB,KAAKq0E,sB,CAK7H,MAAM7lE,EAAIqY,GAAeuhC,EAAUrhC,EAAMA,EAAOiT,GAGhDvH,EAAIgG,UAAY08C,EAAU18C,UAAU9R,GAAmByhC,IACvD31B,EAAIiG,aAAe,SACnBjG,EAAI4G,YAAc0/B,EAAUx9C,MAC5BkX,EAAI+F,UAAYugC,EAAUx9C,MAC1BkX,EAAIL,KAAO8jD,EAAU3hD,OAErBmF,GAAWjH,EAAKsmC,EAAU9oC,KAAMzhB,EAAG6Q,EAAG62D,EACxC,CAKA7B,mBAAAA,GACE,MAAMtb,EAAY/4D,KAAK8G,QAAQxH,MACzB42E,EAAY96C,GAAO29B,EAAU3mC,MAC7B+jD,EAAeh7C,GAAU49B,EAAUnsC,SACzC,OAAOmsC,EAAU/pC,QAAUknD,EAAU5jD,WAAa6jD,EAAatgD,OAAS,CAC1E,CAKAwgD,gBAAAA,CAAiB7nE,EAAG6Q,GAClB,IAAIliB,EAAGm5E,EAAQC,EAEf,GAAIpyD,GAAW3V,EAAGxO,KAAK+mB,KAAM/mB,KAAKgnB,QAC7B7C,GAAW9E,EAAGrf,KAAK6sB,IAAK7sB,KAAK8sB,QAGhC,IADAypD,EAAKv2E,KAAK6zE,eACL12E,EAAI,EAAGA,EAAIo5E,EAAG3vE,SAAUzJ,EAG3B,GAFAm5E,EAASC,EAAGp5E,GAERgnB,GAAW3V,EAAG8nE,EAAOvvD,KAAMuvD,EAAOvvD,KAAOuvD,EAAOtmD,QAC/C7L,GAAW9E,EAAGi3D,EAAOzpD,IAAKypD,EAAOzpD,IAAMypD,EAAOzgD,QAEjD,OAAO71B,KAAKg0E,YAAY72E,GAK9B,OAAO,IACT,CAMAq5E,WAAAA,CAAYt5E,GACV,MAAMo7B,EAAOt4B,KAAK8G,QAClB,IAAK2vE,GAAWv5E,EAAEyC,KAAM24B,GACtB,OAIF,MAAMo+C,EAAc12E,KAAKq2E,iBAAiBn5E,EAAEsR,EAAGtR,EAAEmiB,GAEjD,GAAe,cAAXniB,EAAEyC,MAAmC,aAAXzC,EAAEyC,KAAqB,CACnD,MAAMi4B,EAAW53B,KAAK8zE,aAChB6C,EAAWjD,GAAW97C,EAAU8+C,GAClC9+C,IAAa++C,GACfp5D,GAAK+a,EAAKs+C,QAAS,CAAC15E,EAAG06B,EAAU53B,MAAOA,MAG1CA,KAAK8zE,aAAe4C,EAEhBA,IAAgBC,GAClBp5D,GAAK+a,EAAKpF,QAAS,CAACh2B,EAAGw5E,EAAa12E,MAAOA,KAE/C,MAAW02E,GACTn5D,GAAK+a,EAAKp5B,QAAS,CAAChC,EAAGw5E,EAAa12E,MAAOA,KAE/C,EAGF,SAASi1E,GAAkB3B,EAAUc,EAAW3hD,EAAKsyB,EAAY4vB,GAC/D,MAAM/sC,EAAYivC,GAAmB9xB,EAAYuuB,EAAUc,EAAW3hD,GAChEghD,EAAaqD,GAAoBnC,EAAa5vB,EAAYqvB,EAAU9hD,YAC1E,MAAO,CAACsV,YAAW6rC,aACrB,CAEA,SAASoD,GAAmB9xB,EAAYuuB,EAAUc,EAAW3hD,GAC3D,IAAIskD,EAAiBhyB,EAAW90B,KAIhC,OAHI8mD,GAA4C,kBAAnBA,IAC3BA,EAAiBA,EAAerpC,OAAO,CAAChiC,EAAGC,IAAMD,EAAE9E,OAAS+E,EAAE/E,OAAS8E,EAAIC,IAEtE2nE,EAAYc,EAAU9rE,KAAO,EAAKmqB,EAAIgC,YAAYsiD,GAAgB/mD,KAC3E,CAEA,SAAS8mD,GAAoBnC,EAAa5vB,EAAYixB,GACpD,IAAIvC,EAAakB,EAIjB,MAH+B,kBAApB5vB,EAAW90B,OACpBwjD,EAAawC,GAA0BlxB,EAAYixB,IAE9CvC,CACT,CAEA,SAASwC,GAA0BlxB,EAAYixB,GAC7C,MAAM5c,EAAcrU,EAAW90B,KAAO80B,EAAW90B,KAAKrpB,OAAS,EAC/D,OAAOovE,EAAiB5c,CAC1B,CAEA,SAASqd,GAAW92E,EAAM24B,GACxB,QAAc,cAAT34B,GAAiC,aAATA,IAAyB24B,EAAKpF,UAAWoF,EAAKs+C,aAGvEt+C,EAAKp5B,SAAqB,UAATS,GAA6B,YAATA,EAI3C,CAEA,IAAAq3E,GAAe,CACbltE,GAAI,SAMJmtE,SAAUtD,GAEVjwD,KAAAA,CAAMuK,EAAOipD,EAAOpwE,GAClB,MAAMy9C,EAASt2B,EAAMs2B,OAAS,IAAIovB,GAAO,CAAClhD,IAAKxE,EAAMwE,IAAK3rB,UAASmnB,UACnEu8B,GAAQ9a,UAAUzhB,EAAOs2B,EAAQz9C,GACjC0jD,GAAQyC,OAAOh/B,EAAOs2B,EACxB,EAEAza,IAAAA,CAAK7b,GACHu8B,GAAQ4C,UAAUn/B,EAAOA,EAAMs2B,eACxBt2B,EAAMs2B,MACf,EAKAkS,YAAAA,CAAaxoC,EAAOipD,EAAOpwE,GACzB,MAAMy9C,EAASt2B,EAAMs2B,OACrBiG,GAAQ9a,UAAUzhB,EAAOs2B,EAAQz9C,GACjCy9C,EAAOz9C,QAAUA,CACnB,EAIA8wD,WAAAA,CAAY3pC,GACV,MAAMs2B,EAASt2B,EAAMs2B,OACrBA,EAAO4vB,cACP5vB,EAAO2wB,gBACT,EAGAiC,UAAAA,CAAWlpD,EAAO1uB,GACXA,EAAKsrE,QACR58C,EAAMs2B,OAAOiyB,YAAYj3E,EAAK2lC,MAElC,EAEAvZ,SAAU,CACRqD,SAAS,EACTo5B,SAAU,MACVxhC,MAAO,SACPokC,UAAU,EACVntC,SAAS,EACTrC,OAAQ,IAGRtc,OAAAA,CAAQhC,EAAG6nD,EAAYR,GACrB,MAAMvlD,EAAQ+lD,EAAW3mC,aACnBg5D,EAAK7yB,EAAOt2B,MACdmpD,EAAGt0B,iBAAiB9jD,IACtBo4E,EAAG3qD,KAAKztB,GACR+lD,EAAW9Q,QAAS,IAEpBmjC,EAAG9qD,KAAKttB,GACR+lD,EAAW9Q,QAAS,EAExB,EAEA/gB,QAAS,KACT0jD,QAAS,KAETl/B,OAAQ,CACNn8B,MAAQkX,GAAQA,EAAIxE,MAAMnnB,QAAQyU,MAClC+3D,SAAU,GACV1mD,QAAS,GAYT43B,cAAAA,CAAev2B,GACb,MAAM4D,EAAW5D,EAAMnuB,KAAK+xB,UACrB6lB,QAAQ,cAAC67B,EAAA,WAAel9C,EAAU,UAAEoC,EAAA,MAAWld,EAAA,gBAAOkpC,EAAe,aAAEC,IAAiBz2B,EAAMs2B,OAAOz9C,QAE5G,OAAOmnB,EAAM+iB,yBAAyBrjC,IAAKyZ,IACzC,MAAMlgB,EAAQkgB,EAAKsrB,WAAW3O,SAASwvC,EAAgB,OAAI5mE,GACrDyqB,EAAc+D,GAAUj0B,EAAMkwB,aAEpC,MAAO,CACLnH,KAAM4B,EAASzK,EAAKpoB,OAAO45C,MAC3BpgB,UAAWtxB,EAAMyqB,gBACjBgzB,UAAWppC,EACX04B,QAAS7sB,EAAKoF,QACd0iD,QAAShoE,EAAMikC,eACfyZ,SAAU19C,EAAMkkC,WAChByZ,eAAgB39C,EAAMmkC,iBACtByZ,SAAU59C,EAAMokC,gBAChB/b,WAAY6H,EAAYpH,MAAQoH,EAAYvB,QAAU,EACtDwD,YAAanyB,EAAM0qB,YACnByE,WAAYA,GAAcnvB,EAAMmvB,WAChCC,SAAUpvB,EAAMovB,SAChBmC,UAAWA,GAAavxB,EAAMuxB,UAC9BisB,aAAcD,IAAoBC,GAAgBx9C,EAAMw9C,cAGxDtmC,aAAcgJ,EAAKpoB,QAEpBgB,KACL,GAGFV,MAAO,CACLic,MAAQkX,GAAQA,EAAIxE,MAAMnnB,QAAQyU,MAClCyT,SAAS,EACTo5B,SAAU,SACVn4B,KAAM,KAIVkB,YAAa,CACXlF,YAAcxsB,IAAUA,EAAKwxB,WAAW,MACxCymB,OAAQ,CACNzrB,YAAcxsB,IAAU,CAAC,iBAAkB,SAAU,QAAQovB,SAASpvB,MCzsBhE,IAAI43E,QCahB,MAAMC,GAAc,CAIlBC,OAAAA,CAAQzxD,GACN,IAAKA,EAAMlf,OACT,OAAO,EAGT,IAAIzJ,EAAGqP,EACHgrE,EAAO,IAAIxxD,IACX3G,EAAI,EACJrY,EAAQ,EAEZ,IAAK7J,EAAI,EAAGqP,EAAMsZ,EAAMlf,OAAQzJ,EAAIqP,IAAOrP,EAAG,CAC5C,MAAM6mC,EAAKle,EAAM3oB,GAAGymC,QACpB,GAAII,GAAMA,EAAG+tB,WAAY,CACvB,MAAMztB,EAAMN,EAAG8tB,kBACf0lB,EAAKx7C,IAAIsI,EAAI91B,GACb6Q,GAAKilB,EAAIjlB,IACPrY,C,CAEN,CAGA,GAAc,IAAVA,GAA6B,IAAdwwE,EAAKlvE,KACtB,OAAO,EAGT,MAAMmvE,EAAW,IAAID,GAAM9pC,OAAO,CAAChiC,EAAGC,IAAMD,EAAIC,GAAK6rE,EAAKlvE,KAE1D,MAAO,CACLkG,EAAGipE,EACHp4D,EAAGA,EAAIrY,EAEX,EAKA8iD,OAAAA,CAAQhkC,EAAO4xD,GACb,IAAK5xD,EAAMlf,OACT,OAAO,EAGT,IAGIzJ,EAAGqP,EAAKmrE,EAHRnpE,EAAIkpE,EAAclpE,EAClB6Q,EAAIq4D,EAAcr4D,EAClBgqC,EAAc9rD,OAAOkjB,kBAGzB,IAAKtjB,EAAI,EAAGqP,EAAMsZ,EAAMlf,OAAQzJ,EAAIqP,IAAOrP,EAAG,CAC5C,MAAM6mC,EAAKle,EAAM3oB,GAAGymC,QACpB,GAAII,GAAMA,EAAG+tB,WAAY,CACvB,MAAM7S,EAASlb,EAAGslB,iBACZz9C,EAAIuX,GAAsBs0D,EAAex4B,GAE3CrzC,EAAIw9C,IACNA,EAAcx9C,EACd8rE,EAAiB3zC,E,CAGvB,CAEA,GAAI2zC,EAAgB,CAClB,MAAMC,EAAKD,EAAe7lB,kBAC1BtjD,EAAIopE,EAAGppE,EACP6Q,EAAIu4D,EAAGv4D,C,CAGT,MAAO,CACL7Q,IACA6Q,IAEJ,GAIF,SAASw4D,GAAatyD,EAAMuyD,GAU1B,OATIA,IACEpqE,GAAQoqE,GAEVrqE,MAAM3Q,UAAU4iB,KAAKhC,MAAM6H,EAAMuyD,GAEjCvyD,EAAK7F,KAAKo4D,IAIPvyD,CACT,CAQA,SAASwyD,GAAczrE,GACrB,OAAoB,kBAARA,GAAoBA,aAAehP,SAAWgP,EAAIoS,QAAQ,OAAS,EACtEpS,EAAIkT,MAAM,MAEZlT,CACT,CASA,SAAS0rE,GAAkB/pD,EAAOnvB,GAChC,MAAM,QAAC8kC,EAAO,aAAExlB,EAAA,MAAcpf,GAASF,EACjC4zC,EAAazkB,EAAMooB,eAAej4B,GAAcs0B,YAChD,MAACkG,EAAA,MAAOh7C,GAAS80C,EAAWiG,iBAAiB35C,GAEnD,MAAO,CACLivB,QACA2qB,QACAxY,OAAQsS,EAAWqF,UAAU/4C,GAC7By0C,IAAKxlB,EAAMnuB,KAAK+xB,SAASzT,GAActe,KAAKd,GAC5Ci5E,eAAgBr6E,EAChBiqB,QAAS6qB,EAAW6C,aACpB/B,UAAWx0C,EACXof,eACAwlB,UAEJ,CAKA,SAASs0C,GAAeC,EAASrxE,GAC/B,MAAM2rB,EAAM0lD,EAAQlqD,MAAMwE,KACpB,KAAC2lD,EAAI,OAAEC,EAAA,MAAQ/4E,GAAS64E,GACxB,SAAC7E,EAAA,UAAUD,GAAavsE,EACxBwxE,EAAWl9C,GAAOt0B,EAAQwxE,UAC1BpC,EAAY96C,GAAOt0B,EAAQovE,WAC3BqC,EAAan9C,GAAOt0B,EAAQyxE,YAC5BC,EAAiBl5E,EAAMsH,OACvB6xE,EAAkBJ,EAAOzxE,OACzB8xE,EAAoBN,EAAKxxE,OAEzBgmB,EAAUuO,GAAUr0B,EAAQ8lB,SAClC,IAAIiJ,EAASjJ,EAAQiJ,OACjB7F,EAAQ,EAGR2oD,EAAqBP,EAAK1qC,OAAO,CAAC1mC,EAAO4xE,IAAa5xE,EAAQ4xE,EAASC,OAAOjyE,OAASgyE,EAASj/C,MAAM/yB,OAASgyE,EAASE,MAAMlyE,OAAQ,GAQ1I,GAPA+xE,GAAsBR,EAAQY,WAAWnyE,OAASuxE,EAAQa,UAAUpyE,OAEhE4xE,IACF3iD,GAAU2iD,EAAiBtC,EAAU5jD,YACnCkmD,EAAiB,GAAK1xE,EAAQmyE,aAC/BnyE,EAAQoyE,mBAEPP,EAAoB,CAEtB,MAAMQ,EAAiBryE,EAAQsyE,cAAgBvxE,KAAKgD,IAAIwoE,EAAWiF,EAAShmD,YAAcgmD,EAAShmD,WACnGuD,GAAU6iD,EAAoBS,GAC5BR,EAAqBD,GAAqBJ,EAAShmD,YACnDqmD,EAAqB,GAAK7xE,EAAQuyE,W,CAElCZ,IACF5iD,GAAU/uB,EAAQwyE,gBACjBb,EAAkBF,EAAWjmD,YAC5BmmD,EAAkB,GAAK3xE,EAAQyyE,eAInC,IAAIC,EAAe,EACnB,MAAMC,EAAe,SAAS7gD,GAC5B5I,EAAQnoB,KAAKgD,IAAImlB,EAAOyC,EAAIgC,YAAYmE,GAAM5I,MAAQwpD,EACxD,EA+BA,OA7BA/mD,EAAIqC,OAEJrC,EAAIL,KAAO8jD,EAAU3hD,OACrB5W,GAAKw6D,EAAQ74E,MAAOm6E,GAGpBhnD,EAAIL,KAAOkmD,EAAS/jD,OACpB5W,GAAKw6D,EAAQY,WAAWn9B,OAAOu8B,EAAQa,WAAYS,GAGnDD,EAAe1yE,EAAQsyE,cAAiB9F,EAAW,EAAIxsE,EAAQ8kD,WAAc,EAC7EjuC,GAAKy6D,EAAOQ,IACVj7D,GAAKi7D,EAASC,OAAQY,GACtB97D,GAAKi7D,EAASj/C,MAAO8/C,GACrB97D,GAAKi7D,EAASE,MAAOW,KAIvBD,EAAe,EAGf/mD,EAAIL,KAAOmmD,EAAWhkD,OACtB5W,GAAKw6D,EAAQE,OAAQoB,GAErBhnD,EAAIyC,UAGJlF,GAASpD,EAAQoD,MAEV,CAACA,QAAO6F,SACjB,CAEA,SAAS6jD,GAAgBzrD,EAAO3lB,GAC9B,MAAM,EAAC+W,EAAA,OAAGwW,GAAUvtB,EAEpB,OAAI+W,EAAIwW,EAAS,EACR,MACExW,EAAK4O,EAAM4H,OAASA,EAAS,EAC/B,SAEF,QACT,CAEA,SAAS8jD,GAAoBC,EAAQ3rD,EAAOnnB,EAASwB,GACnD,MAAM,EAACkG,EAAA,MAAGwhB,GAAS1nB,EACbuxE,EAAQ/yE,EAAQgzE,UAAYhzE,EAAQizE,aAC1C,MAAe,SAAXH,GAAqBprE,EAAIwhB,EAAQ6pD,EAAQ5rD,EAAM+B,QAIpC,UAAX4pD,GAAsBprE,EAAIwhB,EAAQ6pD,EAAQ,QAA9C,EAGF,CAEA,SAASG,GAAgB/rD,EAAOnnB,EAASwB,EAAM2xE,GAC7C,MAAM,EAACzrE,EAAA,MAAGwhB,GAAS1nB,GACZ0nB,MAAOkqD,EAAYzuC,WAAW,KAAC1kB,EAAI,MAAEC,IAAUiH,EACtD,IAAI2rD,EAAS,SAcb,MAZe,WAAXK,EACFL,EAASprE,IAAMuY,EAAOC,GAAS,EAAI,OAAS,QACnCxY,GAAKwhB,EAAQ,EACtB4pD,EAAS,OACAprE,GAAK0rE,EAAalqD,EAAQ,IACnC4pD,EAAS,SAGPD,GAAoBC,EAAQ3rD,EAAOnnB,EAASwB,KAC9CsxE,EAAS,UAGJA,CACT,CAKA,SAASO,GAAmBlsD,EAAOnnB,EAASwB,GAC1C,MAAM2xE,EAAS3xE,EAAK2xE,QAAUnzE,EAAQmzE,QAAUP,GAAgBzrD,EAAO3lB,GAEvE,MAAO,CACLsxE,OAAQtxE,EAAKsxE,QAAU9yE,EAAQ8yE,QAAUI,GAAgB/rD,EAAOnnB,EAASwB,EAAM2xE,GAC/EA,SAEJ,CAEA,SAASG,GAAO9xE,EAAMsxE,GACpB,IAAI,EAACprE,EAAA,MAAGwhB,GAAS1nB,EAMjB,MALe,UAAXsxE,EACFprE,GAAKwhB,EACe,WAAX4pD,IACTprE,GAAMwhB,EAAQ,GAETxhB,CACT,CAEA,SAAS6rE,GAAO/xE,EAAM2xE,EAAQK,GAE5B,IAAI,EAACj7D,EAAA,OAAGwW,GAAUvtB,EAQlB,MAPe,QAAX2xE,EACF56D,GAAKi7D,EAELj7D,GADoB,WAAX46D,EACJpkD,EAASykD,EAERzkD,EAAS,EAEVxW,CACT,CAKA,SAASk7D,GAAmBzzE,EAASwB,EAAMkyE,EAAWvsD,GACpD,MAAM,UAAC6rD,EAAS,aAAEC,EAAA,aAAc7jD,GAAgBpvB,GAC1C,OAAC8yE,EAAA,OAAQK,GAAUO,EACnBF,EAAiBR,EAAYC,GAC7B,QAAC5/C,EAAO,SAAEG,EAAQ,WAAEF,EAAA,YAAYC,GAAea,GAAchF,GAEnE,IAAI1nB,EAAI4rE,GAAO9xE,EAAMsxE,GACrB,MAAMv6D,EAAIg7D,GAAO/xE,EAAM2xE,EAAQK,GAc/B,MAZe,WAAXL,EACa,SAAXL,EACFprE,GAAK8rE,EACe,UAAXV,IACTprE,GAAK8rE,GAEa,SAAXV,EACTprE,GAAK3G,KAAKgD,IAAIsvB,EAASC,GAAc0/C,EACjB,UAAXF,IACTprE,GAAK3G,KAAKgD,IAAIyvB,EAAUD,GAAey/C,GAGlC,CACLtrE,EAAGyV,GAAYzV,EAAG,EAAGyf,EAAM+B,MAAQ1nB,EAAK0nB,OACxC3Q,EAAG4E,GAAY5E,EAAG,EAAG4O,EAAM4H,OAASvtB,EAAKutB,QAE7C,CAEA,SAAS4kD,GAAYtC,EAASvxD,EAAO9f,GACnC,MAAM8lB,EAAUuO,GAAUr0B,EAAQ8lB,SAElC,MAAiB,WAAVhG,EACHuxD,EAAQ3pE,EAAI2pE,EAAQnoD,MAAQ,EAClB,UAAVpJ,EACEuxD,EAAQ3pE,EAAI2pE,EAAQnoD,MAAQpD,EAAQ5F,MACpCmxD,EAAQ3pE,EAAIoe,EAAQ7F,IAC5B,CAKA,SAAS2zD,GAAwBn9D,GAC/B,OAAOs6D,GAAa,GAAIE,GAAcx6D,GACxC,CAEA,SAASo9D,GAAqBj7C,EAAQy4C,EAASyC,GAC7C,OAAO3+C,GAAcyD,EAAQ,CAC3By4C,UACAyC,eACAj7E,KAAM,WAEV,CAEA,SAASk7E,GAAkBvuC,EAAWva,GACpC,MAAM2B,EAAW3B,GAAWA,EAAQlK,SAAWkK,EAAQlK,QAAQswD,SAAWpmD,EAAQlK,QAAQswD,QAAQ7rC,UAClG,OAAO5Y,EAAW4Y,EAAU5Y,SAASA,GAAY4Y,CACnD,CAEA,MAAMwuC,GAAmB,CAEvBC,YAAax+D,GACbjd,KAAAA,CAAMs7E,GACJ,GAAIA,EAAah0E,OAAS,EAAG,CAC3B,MAAM9H,EAAO87E,EAAa,GACpBljC,EAAS54C,EAAKmvB,MAAMnuB,KAAK43C,OACzBsjC,EAAatjC,EAASA,EAAO9wC,OAAS,EAE5C,GAAI5G,MAAQA,KAAK8G,SAAiC,YAAtB9G,KAAK8G,QAAQgsB,KACvC,OAAOh0B,EAAK+oB,QAAQ+wB,OAAS,GACxB,GAAI95C,EAAK85C,MACd,OAAO95C,EAAK85C,MACP,GAAIoiC,EAAa,GAAKl8E,EAAK00C,UAAYwnC,EAC5C,OAAOtjC,EAAO54C,EAAK00C,U,CAIvB,MAAO,EACT,EACAynC,WAAY1+D,GAGZw8D,WAAYx8D,GAGZ2+D,YAAa3+D,GACbq8B,KAAAA,CAAMuiC,GACJ,GAAIn7E,MAAQA,KAAK8G,SAAiC,YAAtB9G,KAAK8G,QAAQgsB,KACvC,OAAOqoD,EAAYviC,MAAQ,KAAOuiC,EAAYlD,gBAAkBkD,EAAYlD,eAG9E,IAAIr/B,EAAQuiC,EAAYtzD,QAAQ+wB,OAAS,GAErCA,IACFA,GAAS,MAEX,MAAMh7C,EAAQu9E,EAAYlD,eAI1B,OAHKx7D,GAAc7e,KACjBg7C,GAASh7C,GAEJg7C,CACT,EACAwiC,UAAAA,CAAWD,GACT,MAAM/zD,EAAO+zD,EAAYltD,MAAMooB,eAAe8kC,EAAY/8D,cACpDtX,EAAUsgB,EAAKsrB,WAAW3O,SAASo3C,EAAY3nC,WACrD,MAAO,CACL5hB,YAAa9qB,EAAQ8qB,YACrBD,gBAAiB7qB,EAAQ6qB,gBACzByF,YAAatwB,EAAQswB,YACrBgU,WAAYtkC,EAAQskC,WACpBC,iBAAkBvkC,EAAQukC,iBAC1BqZ,aAAc,EAElB,EACA22B,cAAAA,GACE,OAAOr7E,KAAK8G,QAAQw0E,SACtB,EACAC,eAAAA,CAAgBJ,GACd,MAAM/zD,EAAO+zD,EAAYltD,MAAMooB,eAAe8kC,EAAY/8D,cACpDtX,EAAUsgB,EAAKsrB,WAAW3O,SAASo3C,EAAY3nC,WACrD,MAAO,CACLnd,WAAYvvB,EAAQuvB,WACpBC,SAAUxvB,EAAQwvB,SAEtB,EACAklD,WAAYj/D,GAGZy8D,UAAWz8D,GAGXk/D,aAAcl/D,GACd87D,OAAQ97D,GACRm/D,YAAan/D,IAYf,SAASo/D,GAA2BrvC,EAAW7sC,EAAMgzB,EAAKktC,GACxD,MAAMj+C,EAAS4qB,EAAU7sC,GAAMrC,KAAKq1B,EAAKktC,GAEzC,MAAsB,qBAAXj+C,EACFo5D,GAAiBr7E,GAAMrC,KAAKq1B,EAAKktC,GAGnCj+C,CACT,CAEO,MAAMk6D,WAAgB/pB,GAO3Bh1D,WAAAA,CAAY2yC,GACViP,QAEAz+C,KAAK67E,QAAU,EACf77E,KAAKitC,QAAU,GACfjtC,KAAK87E,oBAAiBnvE,EACtB3M,KAAK+7E,WAAQpvE,EACb3M,KAAKg8E,uBAAoBrvE,EACzB3M,KAAKi8E,cAAgB,GACrBj8E,KAAKqwC,iBAAc1jC,EACnB3M,KAAK80C,cAAWnoC,EAChB3M,KAAKiuB,MAAQuhB,EAAOvhB,MACpBjuB,KAAK8G,QAAU0oC,EAAO1oC,QACtB9G,KAAKk8E,gBAAavvE,EAClB3M,KAAKV,WAAQqN,EACb3M,KAAK+4E,gBAAapsE,EAClB3M,KAAKo4E,UAAOzrE,EACZ3M,KAAKg5E,eAAYrsE,EACjB3M,KAAKq4E,YAAS1rE,EACd3M,KAAK45E,YAASjtE,EACd3M,KAAKi6E,YAASttE,EACd3M,KAAKwO,OAAI7B,EACT3M,KAAKqf,OAAI1S,EACT3M,KAAK61B,YAASlpB,EACd3M,KAAKgwB,WAAQrjB,EACb3M,KAAKm8E,YAASxvE,EACd3M,KAAKo8E,YAASzvE,EAGd3M,KAAKq8E,iBAAc1vE,EACnB3M,KAAKs8E,sBAAmB3vE,EACxB3M,KAAKu8E,qBAAkB5vE,CACzB,CAEAuoC,UAAAA,CAAWpuC,GACT9G,KAAK8G,QAAUA,EACf9G,KAAKg8E,uBAAoBrvE,EACzB3M,KAAK80C,cAAWnoC,CAClB,CAKA2sC,kBAAAA,GACE,MAAMzF,EAAS7zC,KAAKg8E,kBAEpB,GAAInoC,EACF,OAAOA,EAGT,MAAM5lB,EAAQjuB,KAAKiuB,MACbnnB,EAAU9G,KAAK8G,QAAQq3B,WAAWn+B,KAAK01B,cACvC4C,EAAOxxB,EAAQyrD,SAAWtkC,EAAMnnB,QAAQslB,WAAatlB,EAAQylB,WAC7DA,EAAa,IAAIgjB,GAAWvvC,KAAKiuB,MAAOqK,GAK9C,OAJIA,EAAKqE,aACP38B,KAAKg8E,kBAAoBt+E,OAAO27C,OAAO9sB,IAGlCA,CACT,CAKAmJ,UAAAA,GACE,OAAO11B,KAAK80C,WACZ90C,KAAK80C,SAAW6lC,GAAqB36E,KAAKiuB,MAAMyH,aAAc11B,KAAMA,KAAKi8E,eAC3E,CAEAO,QAAAA,CAASzqD,EAASjrB,GAChB,MAAM,UAACwlC,GAAaxlC,EAEdi0E,EAAcY,GAA2BrvC,EAAW,cAAetsC,KAAM+xB,GACzEzyB,EAAQq8E,GAA2BrvC,EAAW,QAAStsC,KAAM+xB,GAC7DkpD,EAAaU,GAA2BrvC,EAAW,aAActsC,KAAM+xB,GAE7E,IAAI4H,EAAQ,GAKZ,OAJAA,EAAQk+C,GAAal+C,EAAOo+C,GAAcgD,IAC1CphD,EAAQk+C,GAAal+C,EAAOo+C,GAAcz4E,IAC1Cq6B,EAAQk+C,GAAal+C,EAAOo+C,GAAckD,IAEnCthD,CACT,CAEA8iD,aAAAA,CAAc7B,EAAc9zE,GAC1B,OAAO4zE,GACLiB,GAA2B70E,EAAQwlC,UAAW,aAActsC,KAAM46E,GAEtE,CAEA8B,OAAAA,CAAQ9B,EAAc9zE,GACpB,MAAM,UAACwlC,GAAaxlC,EACd61E,EAAY,GAgBlB,OAdAh/D,GAAKi9D,EAAe7oD,IAClB,MAAM6mD,EAAW,CACfC,OAAQ,GACRl/C,MAAO,GACPm/C,MAAO,IAEH8D,EAAS/B,GAAkBvuC,EAAWva,GAC5C8lD,GAAae,EAASC,OAAQd,GAAc4D,GAA2BiB,EAAQ,cAAe58E,KAAM+xB,KACpG8lD,GAAae,EAASj/C,MAAOgiD,GAA2BiB,EAAQ,QAAS58E,KAAM+xB,IAC/E8lD,GAAae,EAASE,MAAOf,GAAc4D,GAA2BiB,EAAQ,aAAc58E,KAAM+xB,KAElG4qD,EAAUj9D,KAAKk5D,KAGV+D,CACT,CAEAE,YAAAA,CAAajC,EAAc9zE,GACzB,OAAO4zE,GACLiB,GAA2B70E,EAAQwlC,UAAW,YAAatsC,KAAM46E,GAErE,CAGAkC,SAAAA,CAAUlC,EAAc9zE,GACtB,MAAM,UAACwlC,GAAaxlC,EAEd20E,EAAeE,GAA2BrvC,EAAW,eAAgBtsC,KAAM46E,GAC3EvC,EAASsD,GAA2BrvC,EAAW,SAAUtsC,KAAM46E,GAC/Dc,EAAcC,GAA2BrvC,EAAW,cAAetsC,KAAM46E,GAE/E,IAAIjhD,EAAQ,GAKZ,OAJAA,EAAQk+C,GAAal+C,EAAOo+C,GAAc0D,IAC1C9hD,EAAQk+C,GAAal+C,EAAOo+C,GAAcM,IAC1C1+C,EAAQk+C,GAAal+C,EAAOo+C,GAAc2D,IAEnC/hD,CACT,CAKAojD,YAAAA,CAAaj2E,GACX,MAAMqlB,EAASnsB,KAAKitC,QACdntC,EAAOE,KAAKiuB,MAAMnuB,KAClBu8E,EAAc,GACdC,EAAmB,GACnBC,EAAkB,GACxB,IACIp/E,EAAGqP,EADHouE,EAAe,GAGnB,IAAKz9E,EAAI,EAAGqP,EAAM2f,EAAOvlB,OAAQzJ,EAAIqP,IAAOrP,EAC1Cy9E,EAAal7D,KAAKs4D,GAAkBh4E,KAAKiuB,MAAO9B,EAAOhvB,KAyBzD,OArBI2J,EAAQy4B,SACVq7C,EAAeA,EAAar7C,OAAO,CAACqE,EAAS5kC,EAAOojB,IAAUtb,EAAQy4B,OAAOqE,EAAS5kC,EAAOojB,EAAOtiB,KAIlGgH,EAAQk2E,WACVpC,EAAeA,EAAah5D,KAAK,CAAClW,EAAGC,IAAM7E,EAAQk2E,SAAStxE,EAAGC,EAAG7L,KAIpE6d,GAAKi9D,EAAe7oD,IAClB,MAAM6qD,EAAS/B,GAAkB/zE,EAAQwlC,UAAWva,GACpDsqD,EAAY38D,KAAKi8D,GAA2BiB,EAAQ,aAAc58E,KAAM+xB,IACxEuqD,EAAiB58D,KAAKi8D,GAA2BiB,EAAQ,kBAAmB58E,KAAM+xB,IAClFwqD,EAAgB78D,KAAKi8D,GAA2BiB,EAAQ,iBAAkB58E,KAAM+xB,MAGlF/xB,KAAKq8E,YAAcA,EACnBr8E,KAAKs8E,iBAAmBA,EACxBt8E,KAAKu8E,gBAAkBA,EACvBv8E,KAAKk8E,WAAatB,EACXA,CACT,CAEA5rC,MAAAA,CAAOhmB,EAAS6hD,GACd,MAAM/jE,EAAU9G,KAAK8G,QAAQq3B,WAAWn+B,KAAK01B,cACvCvJ,EAASnsB,KAAKitC,QACpB,IAAI/gB,EACA0uD,EAAe,GAEnB,GAAKzuD,EAAOvlB,OAML,CACL,MAAMwhD,EAAWkvB,GAAYxwE,EAAQshD,UAAUhrD,KAAK4C,KAAMmsB,EAAQnsB,KAAK87E,gBACvElB,EAAe56E,KAAK+8E,aAAaj2E,GAEjC9G,KAAKV,MAAQU,KAAKw8E,SAAS5B,EAAc9zE,GACzC9G,KAAK+4E,WAAa/4E,KAAKy8E,cAAc7B,EAAc9zE,GACnD9G,KAAKo4E,KAAOp4E,KAAK08E,QAAQ9B,EAAc9zE,GACvC9G,KAAKg5E,UAAYh5E,KAAK68E,aAAajC,EAAc9zE,GACjD9G,KAAKq4E,OAASr4E,KAAK88E,UAAUlC,EAAc9zE,GAE3C,MAAMwB,EAAOtI,KAAK+7E,MAAQ7D,GAAel4E,KAAM8G,GACzCm2E,EAAkBv/E,OAAOkd,OAAO,CAAC,EAAGwtC,EAAU9/C,GAC9CkyE,EAAYL,GAAmBn6E,KAAKiuB,MAAOnnB,EAASm2E,GACpDC,EAAkB3C,GAAmBzzE,EAASm2E,EAAiBzC,EAAWx6E,KAAKiuB,OAErFjuB,KAAK45E,OAASY,EAAUZ,OACxB55E,KAAKi6E,OAASO,EAAUP,OAExB/tD,EAAa,CACX2vD,QAAS,EACTrtE,EAAG0uE,EAAgB1uE,EACnB6Q,EAAG69D,EAAgB79D,EACnB2Q,MAAO1nB,EAAK0nB,MACZ6F,OAAQvtB,EAAKutB,OACbsmD,OAAQ/zB,EAAS55C,EACjB4tE,OAAQh0B,EAAS/oC,E,MA9BE,IAAjBrf,KAAK67E,UACP3vD,EAAa,CACX2vD,QAAS,IAgCf77E,KAAKi8E,cAAgBrB,EACrB56E,KAAK80C,cAAWnoC,EAEZuf,GACFlsB,KAAKs5C,qBAAqBtK,OAAOhvC,KAAMksB,GAGrClD,GAAWliB,EAAQq2E,UACrBr2E,EAAQq2E,SAAS//E,KAAK4C,KAAM,CAACiuB,MAAOjuB,KAAKiuB,MAAOkqD,QAASn4E,KAAM6qE,UAEnE,CAEAuS,SAAAA,CAAUC,EAAc5qD,EAAKnqB,EAAMxB,GACjC,MAAMw2E,EAAgBt9E,KAAKu9E,iBAAiBF,EAAc/0E,EAAMxB,GAEhE2rB,EAAIuE,OAAOsmD,EAAc7hB,GAAI6hB,EAAc5hB,IAC3CjpC,EAAIuE,OAAOsmD,EAAc3hB,GAAI2hB,EAAc1hB,IAC3CnpC,EAAIuE,OAAOsmD,EAAcE,GAAIF,EAAcG,GAC7C,CAEAF,gBAAAA,CAAiBF,EAAc/0E,EAAMxB,GACnC,MAAM,OAAC8yE,EAAM,OAAEK,GAAUj6E,MACnB,UAAC85E,EAAA,aAAW5jD,GAAgBpvB,GAC5B,QAACqzB,EAAO,SAAEG,EAAQ,WAAEF,EAAA,YAAYC,GAAea,GAAchF,IAC5D1nB,EAAGkvE,EAAKr+D,EAAGs+D,GAAON,GACnB,MAACrtD,EAAA,OAAO6F,GAAUvtB,EACxB,IAAImzD,EAAIE,EAAI6hB,EAAI9hB,EAAIE,EAAI6hB,EAgDxB,MA9Ce,WAAXxD,GACFre,EAAK+hB,EAAO9nD,EAAS,EAEN,SAAX+jD,GACFne,EAAKiiB,EACL/hB,EAAKF,EAAKqe,EAGVpe,EAAKE,EAAKke,EACV2D,EAAK7hB,EAAKke,IAEVre,EAAKiiB,EAAM1tD,EACX2rC,EAAKF,EAAKqe,EAGVpe,EAAKE,EAAKke,EACV2D,EAAK7hB,EAAKke,GAGZ0D,EAAK/hB,IAGHE,EADa,SAAXie,EACG8D,EAAM71E,KAAKgD,IAAIsvB,EAASC,GAAe0/C,EACxB,UAAXF,EACJ8D,EAAM1tD,EAAQnoB,KAAKgD,IAAIyvB,EAAUD,GAAey/C,EAEhD95E,KAAKm8E,OAGG,QAAXlC,GACFve,EAAKiiB,EACL/hB,EAAKF,EAAKoe,EAGVre,EAAKE,EAAKme,EACV0D,EAAK7hB,EAAKme,IAEVpe,EAAKiiB,EAAM9nD,EACX+lC,EAAKF,EAAKoe,EAGVre,EAAKE,EAAKme,EACV0D,EAAK7hB,EAAKme,GAEZ2D,EAAK/hB,GAEA,CAACD,KAAIE,KAAI6hB,KAAI9hB,KAAIE,KAAI6hB,KAC9B,CAEAngB,SAAAA,CAAU/6B,EAAI9P,EAAK3rB,GACjB,MAAMxH,EAAQU,KAAKV,MACbsH,EAAStH,EAAMsH,OACrB,IAAIsvE,EAAW+C,EAAc97E,EAE7B,GAAIyJ,EAAQ,CACV,MAAMuuE,EAAYptC,GAAcjhC,EAAQmgB,IAAKjnB,KAAKwO,EAAGxO,KAAKgwB,OAa1D,IAXAuS,EAAG/zB,EAAIisE,GAAYz6E,KAAM8G,EAAQ2tD,WAAY3tD,GAE7C2rB,EAAIgG,UAAY08C,EAAU18C,UAAU3xB,EAAQ2tD,YAC5ChiC,EAAIiG,aAAe,SAEnBw9C,EAAY96C,GAAOt0B,EAAQovE,WAC3B+C,EAAenyE,EAAQmyE,aAEvBxmD,EAAI+F,UAAY1xB,EAAQ82E,WACxBnrD,EAAIL,KAAO8jD,EAAU3hD,OAEhBp3B,EAAI,EAAGA,EAAIyJ,IAAUzJ,EACxBs1B,EAAIwH,SAAS36B,EAAMnC,GAAIg4E,EAAU3mE,EAAE+zB,EAAG/zB,GAAI+zB,EAAGljB,EAAI62D,EAAU5jD,WAAa,GACxEiQ,EAAGljB,GAAK62D,EAAU5jD,WAAa2mD,EAE3B97E,EAAI,IAAMyJ,IACZ27B,EAAGljB,GAAKvY,EAAQoyE,kBAAoBD,E,CAI5C,CAKA4E,aAAAA,CAAcprD,EAAK8P,EAAIplC,EAAGg4E,EAAWruE,GACnC,MAAMs0E,EAAap7E,KAAKq8E,YAAYl/E,GAC9Bo+E,EAAkBv7E,KAAKs8E,iBAAiBn/E,IACxC,UAACk2E,EAAA,SAAWC,GAAYxsE,EACxBwxE,EAAWl9C,GAAOt0B,EAAQwxE,UAC1BwF,EAASrD,GAAYz6E,KAAM,OAAQ8G,GACnCi3E,EAAY5I,EAAU3mE,EAAEsvE,GACxBE,EAAU3K,EAAYiF,EAAShmD,YAAcgmD,EAAShmD,WAAa+gD,GAAa,EAAI,EACpF4K,EAAS17C,EAAGljB,EAAI2+D,EAEtB,GAAIl3E,EAAQysE,cAAe,CACzB,MAAMmC,EAAc,CAClBn/C,OAAQ1uB,KAAKiD,IAAIwoE,EAAUD,GAAa,EACxCh9C,WAAYklD,EAAgBllD,WAC5BC,SAAUilD,EAAgBjlD,SAC1Bc,YAAa,GAIT2sB,EAAUoxB,EAAUxtC,WAAWo2C,EAAWzK,GAAYA,EAAW,EACjEtvB,EAAUi6B,EAAS5K,EAAY,EAGrC5gD,EAAI4G,YAAcvyB,EAAQo3E,mBAC1BzrD,EAAI+F,UAAY1xB,EAAQo3E,mBACxBpoD,GAAUrD,EAAKijD,EAAa3xB,EAASC,GAGrCvxB,EAAI4G,YAAc+hD,EAAWxpD,YAC7Ba,EAAI+F,UAAY4iD,EAAWzpD,gBAC3BmE,GAAUrD,EAAKijD,EAAa3xB,EAASC,E,KAChC,CAELvxB,EAAIlD,UAAY3S,GAASw+D,EAAWhkD,aAAevvB,KAAKgD,OAAOnN,OAAOqnB,OAAOq2D,EAAWhkD,cAAiBgkD,EAAWhkD,aAAe,EACnI3E,EAAI4G,YAAc+hD,EAAWxpD,YAC7Ba,EAAIwqC,YAAYme,EAAWhwC,YAAc,IACzC3Y,EAAIoyB,eAAiBu2B,EAAW/vC,kBAAoB,EAGpD,MAAM8yC,EAAShJ,EAAUxtC,WAAWo2C,EAAWzK,GACzC8K,EAASjJ,EAAUxtC,WAAWwtC,EAAUztC,MAAMq2C,EAAW,GAAIzK,EAAW,GACxE5uB,EAAexpB,GAAckgD,EAAW12B,cAE1ChnD,OAAOqnB,OAAO2/B,GAAcsc,KAAKv2D,GAAW,IAANA,IACxCgoB,EAAIkE,YACJlE,EAAI+F,UAAY1xB,EAAQo3E,mBACxBhkD,GAAmBzH,EAAK,CACtBjkB,EAAG2vE,EACH9+D,EAAG4+D,EACH9wE,EAAGmmE,EACH1oE,EAAGyoE,EACH98C,OAAQmuB,IAEVjyB,EAAI0E,OACJ1E,EAAI4E,SAGJ5E,EAAI+F,UAAY4iD,EAAWzpD,gBAC3Bc,EAAIkE,YACJuD,GAAmBzH,EAAK,CACtBjkB,EAAG4vE,EACH/+D,EAAG4+D,EAAS,EACZ9wE,EAAGmmE,EAAW,EACd1oE,EAAGyoE,EAAY,EACf98C,OAAQmuB,IAEVjyB,EAAI0E,SAGJ1E,EAAI+F,UAAY1xB,EAAQo3E,mBACxBzrD,EAAIgH,SAAS0kD,EAAQF,EAAQ3K,EAAUD,GACvC5gD,EAAI4rD,WAAWF,EAAQF,EAAQ3K,EAAUD,GAEzC5gD,EAAI+F,UAAY4iD,EAAWzpD,gBAC3Bc,EAAIgH,SAAS2kD,EAAQH,EAAS,EAAG3K,EAAW,EAAGD,EAAY,G,CAK/D5gD,EAAI+F,UAAYx4B,KAAKu8E,gBAAgBp/E,EACvC,CAEAmhF,QAAAA,CAAS/7C,EAAI9P,EAAK3rB,GAChB,MAAM,KAACsxE,GAAQp4E,MACT,YAACq5E,EAAA,UAAakF,EAAA,cAAWnF,EAAA,UAAe/F,EAAA,SAAWC,EAAA,WAAU1nB,GAAc9kD,EAC3EwxE,EAAWl9C,GAAOt0B,EAAQwxE,UAChC,IAAIa,EAAiBb,EAAShmD,WAC1BksD,EAAe,EAEnB,MAAMrJ,EAAYptC,GAAcjhC,EAAQmgB,IAAKjnB,KAAKwO,EAAGxO,KAAKgwB,OAEpDyuD,EAAiB,SAAS7lD,GAC9BnG,EAAIwH,SAASrB,EAAMu8C,EAAU3mE,EAAE+zB,EAAG/zB,EAAIgwE,GAAej8C,EAAGljB,EAAI85D,EAAiB,GAC7E52C,EAAGljB,GAAK85D,EAAiBE,CAC3B,EAEMqF,EAA0BvJ,EAAU18C,UAAU8lD,GACpD,IAAI3F,EAAU+F,EAAWhlD,EAAOx8B,EAAGkc,EAAG4E,EAAM8W,EAiB5C,IAfAtC,EAAIgG,UAAY8lD,EAChB9rD,EAAIiG,aAAe,SACnBjG,EAAIL,KAAOkmD,EAAS/jD,OAEpBgO,EAAG/zB,EAAIisE,GAAYz6E,KAAM0+E,EAAyB53E,GAGlD2rB,EAAI+F,UAAY1xB,EAAQw0E,UACxB39D,GAAK3d,KAAK+4E,WAAY0F,GAEtBD,EAAepF,GAA6C,UAA5BsF,EACd,WAAdH,EAA0BjL,EAAW,EAAI1nB,EAAe0nB,EAAW,EAAI1nB,EACvE,EAGCzuD,EAAI,EAAG8gB,EAAOm6D,EAAKxxE,OAAQzJ,EAAI8gB,IAAQ9gB,EAAG,CAc7C,IAbAy7E,EAAWR,EAAKj7E,GAChBwhF,EAAY3+E,KAAKu8E,gBAAgBp/E,GAEjCs1B,EAAI+F,UAAYmmD,EAChBhhE,GAAKi7D,EAASC,OAAQ4F,GAEtB9kD,EAAQi/C,EAASj/C,MAEby/C,GAAiBz/C,EAAM/yB,SACzB5G,KAAK69E,cAAcprD,EAAK8P,EAAIplC,EAAGg4E,EAAWruE,GAC1CqyE,EAAiBtxE,KAAKgD,IAAIytE,EAAShmD,WAAY+gD,IAG5Ch6D,EAAI,EAAG0b,EAAO4E,EAAM/yB,OAAQyS,EAAI0b,IAAQ1b,EAC3ColE,EAAe9kD,EAAMtgB,IAErB8/D,EAAiBb,EAAShmD,WAG5B3U,GAAKi7D,EAASE,MAAO2F,EACvB,CAGAD,EAAe,EACfrF,EAAiBb,EAAShmD,WAG1B3U,GAAK3d,KAAKg5E,UAAWyF,GACrBl8C,EAAGljB,GAAKg6D,CACV,CAEAuF,UAAAA,CAAWr8C,EAAI9P,EAAK3rB,GAClB,MAAMuxE,EAASr4E,KAAKq4E,OACdzxE,EAASyxE,EAAOzxE,OACtB,IAAI2xE,EAAYp7E,EAEhB,GAAIyJ,EAAQ,CACV,MAAMuuE,EAAYptC,GAAcjhC,EAAQmgB,IAAKjnB,KAAKwO,EAAGxO,KAAKgwB,OAa1D,IAXAuS,EAAG/zB,EAAIisE,GAAYz6E,KAAM8G,EAAQ+3E,YAAa/3E,GAC9Cy7B,EAAGljB,GAAKvY,EAAQwyE,gBAEhB7mD,EAAIgG,UAAY08C,EAAU18C,UAAU3xB,EAAQ+3E,aAC5CpsD,EAAIiG,aAAe,SAEnB6/C,EAAan9C,GAAOt0B,EAAQyxE,YAE5B9lD,EAAI+F,UAAY1xB,EAAQg4E,YACxBrsD,EAAIL,KAAOmmD,EAAWhkD,OAEjBp3B,EAAI,EAAGA,EAAIyJ,IAAUzJ,EACxBs1B,EAAIwH,SAASo+C,EAAOl7E,GAAIg4E,EAAU3mE,EAAE+zB,EAAG/zB,GAAI+zB,EAAGljB,EAAIk5D,EAAWjmD,WAAa,GAC1EiQ,EAAGljB,GAAKk5D,EAAWjmD,WAAaxrB,EAAQyyE,a,CAG9C,CAEAzc,cAAAA,CAAev6B,EAAI9P,EAAKssD,EAAaj4E,GACnC,MAAM,OAAC8yE,EAAM,OAAEK,GAAUj6E,MACnB,EAACwO,EAAA,EAAG6Q,GAAKkjB,GACT,MAACvS,EAAA,OAAO6F,GAAUkpD,GAClB,QAAC5kD,EAAA,SAASG,EAAA,WAAUF,EAAA,YAAYC,GAAea,GAAcp0B,EAAQovB,cAE3EzD,EAAI+F,UAAY1xB,EAAQ6qB,gBACxBc,EAAI4G,YAAcvyB,EAAQ8qB,YAC1Ba,EAAIlD,UAAYzoB,EAAQswB,YAExB3E,EAAIkE,YACJlE,EAAIsE,OAAOvoB,EAAI2rB,EAAS9a,GACT,QAAX46D,GACFj6E,KAAKo9E,UAAU76C,EAAI9P,EAAKssD,EAAaj4E,GAEvC2rB,EAAIuE,OAAOxoB,EAAIwhB,EAAQsK,EAAUjb,GACjCoT,EAAIusD,iBAAiBxwE,EAAIwhB,EAAO3Q,EAAG7Q,EAAIwhB,EAAO3Q,EAAIib,GACnC,WAAX2/C,GAAkC,UAAXL,GACzB55E,KAAKo9E,UAAU76C,EAAI9P,EAAKssD,EAAaj4E,GAEvC2rB,EAAIuE,OAAOxoB,EAAIwhB,EAAO3Q,EAAIwW,EAASwE,GACnC5H,EAAIusD,iBAAiBxwE,EAAIwhB,EAAO3Q,EAAIwW,EAAQrnB,EAAIwhB,EAAQqK,EAAahb,EAAIwW,GAC1D,WAAXokD,GACFj6E,KAAKo9E,UAAU76C,EAAI9P,EAAKssD,EAAaj4E,GAEvC2rB,EAAIuE,OAAOxoB,EAAI4rB,EAAY/a,EAAIwW,GAC/BpD,EAAIusD,iBAAiBxwE,EAAG6Q,EAAIwW,EAAQrnB,EAAG6Q,EAAIwW,EAASuE,GACrC,WAAX6/C,GAAkC,SAAXL,GACzB55E,KAAKo9E,UAAU76C,EAAI9P,EAAKssD,EAAaj4E,GAEvC2rB,EAAIuE,OAAOxoB,EAAG6Q,EAAI8a,GAClB1H,EAAIusD,iBAAiBxwE,EAAG6Q,EAAG7Q,EAAI2rB,EAAS9a,GACxCoT,EAAIqE,YAEJrE,EAAI0E,OAEArwB,EAAQswB,YAAc,GACxB3E,EAAI4E,QAER,CAMA4nD,sBAAAA,CAAuBn4E,GACrB,MAAMmnB,EAAQjuB,KAAKiuB,MACbme,EAAQpsC,KAAKqwC,YACb6uC,EAAQ9yC,GAASA,EAAM59B,EACvB2wE,EAAQ/yC,GAASA,EAAM/sB,EAC7B,GAAI6/D,GAASC,EAAO,CAClB,MAAM/2B,EAAWkvB,GAAYxwE,EAAQshD,UAAUhrD,KAAK4C,KAAMA,KAAKitC,QAASjtC,KAAK87E,gBAC7E,IAAK1zB,EACH,OAEF,MAAM9/C,EAAOtI,KAAK+7E,MAAQ7D,GAAel4E,KAAM8G,GACzCm2E,EAAkBv/E,OAAOkd,OAAO,CAAC,EAAGwtC,EAAUpoD,KAAK+7E,OACnDvB,EAAYL,GAAmBlsD,EAAOnnB,EAASm2E,GAC/C50D,EAAQkyD,GAAmBzzE,EAASm2E,EAAiBzC,EAAWvsD,GAClEixD,EAAMpwC,MAAQzmB,EAAM7Z,GAAK2wE,EAAMrwC,MAAQzmB,EAAMhJ,IAC/Crf,KAAK45E,OAASY,EAAUZ,OACxB55E,KAAKi6E,OAASO,EAAUP,OACxBj6E,KAAKgwB,MAAQ1nB,EAAK0nB,MAClBhwB,KAAK61B,OAASvtB,EAAKutB,OACnB71B,KAAKm8E,OAAS/zB,EAAS55C,EACvBxO,KAAKo8E,OAASh0B,EAAS/oC,EACvBrf,KAAKs5C,qBAAqBtK,OAAOhvC,KAAMqoB,G,CAG7C,CAMA+2D,WAAAA,GACE,QAASp/E,KAAK67E,OAChB,CAEA7uC,IAAAA,CAAKva,GACH,MAAM3rB,EAAU9G,KAAK8G,QAAQq3B,WAAWn+B,KAAK01B,cAC7C,IAAImmD,EAAU77E,KAAK67E,QAEnB,IAAKA,EACH,OAGF77E,KAAKi/E,uBAAuBn4E,GAE5B,MAAMi4E,EAAc,CAClB/uD,MAAOhwB,KAAKgwB,MACZ6F,OAAQ71B,KAAK61B,QAET0M,EAAK,CACT/zB,EAAGxO,KAAKwO,EACR6Q,EAAGrf,KAAKqf,GAIVw8D,EAAUh0E,KAAKqZ,IAAI26D,GAAW,KAAO,EAAIA,EAEzC,MAAMjvD,EAAUuO,GAAUr0B,EAAQ8lB,SAG5ByyD,EAAoBr/E,KAAKV,MAAMsH,QAAU5G,KAAK+4E,WAAWnyE,QAAU5G,KAAKo4E,KAAKxxE,QAAU5G,KAAKg5E,UAAUpyE,QAAU5G,KAAKq4E,OAAOzxE,OAE9HE,EAAQyrD,SAAW8sB,IACrB5sD,EAAIqC,OACJrC,EAAI6sD,YAAczD,EAGlB77E,KAAK88D,eAAev6B,EAAI9P,EAAKssD,EAAaj4E,GAE1CkhC,GAAsBvV,EAAK3rB,EAAQgvE,eAEnCvzC,EAAGljB,GAAKuN,EAAQC,IAGhB7sB,KAAKs9D,UAAU/6B,EAAI9P,EAAK3rB,GAGxB9G,KAAKs+E,SAAS/7C,EAAI9P,EAAK3rB,GAGvB9G,KAAK4+E,WAAWr8C,EAAI9P,EAAK3rB,GAEzBwhC,GAAqB7V,EAAK3rB,EAAQgvE,eAElCrjD,EAAIyC,UAER,CAMAs1C,iBAAAA,GACE,OAAOxqE,KAAKitC,SAAW,EACzB,CAOAw9B,iBAAAA,CAAkBC,EAAgBgN,GAChC,MAAM/M,EAAa3qE,KAAKitC,QAClB9gB,EAASu+C,EAAe/8D,IAAI,EAAEyQ,eAAcpf,YAChD,MAAMooB,EAAOpnB,KAAKiuB,MAAMooB,eAAej4B,GAEvC,IAAKgJ,EACH,MAAM,IAAI8X,MAAM,kCAAoC9gB,GAGtD,MAAO,CACLA,eACAwlB,QAASxc,EAAKtnB,KAAKd,GACnBA,WAGEgqB,GAAWlL,GAAe6sD,EAAYx+C,GACtCozD,EAAkBv/E,KAAKw/E,iBAAiBrzD,EAAQurD,IAElD1uD,GAAWu2D,KACbv/E,KAAKitC,QAAU9gB,EACfnsB,KAAK87E,eAAiBpE,EACtB13E,KAAKy/E,qBAAsB,EAC3Bz/E,KAAKgvC,QAAO,GAEhB,CASAwnC,WAAAA,CAAYt5E,EAAG2tE,EAAQvF,GAAc,GACnC,GAAIuF,GAAU7qE,KAAKy/E,oBACjB,OAAO,EAETz/E,KAAKy/E,qBAAsB,EAE3B,MAAM34E,EAAU9G,KAAK8G,QACf6jE,EAAa3qE,KAAKitC,SAAW,GAC7B9gB,EAASnsB,KAAKmrE,mBAAmBjuE,EAAGytE,EAAYE,EAAQvF,GAKxDia,EAAkBv/E,KAAKw/E,iBAAiBrzD,EAAQjvB,GAGhD8rB,EAAU6hD,IAAW/sD,GAAeqO,EAAQw+C,IAAe4U,EAgBjE,OAbIv2D,IACFhpB,KAAKitC,QAAU9gB,GAEXrlB,EAAQyrD,SAAWzrD,EAAQq2E,YAC7Bn9E,KAAK87E,eAAiB,CACpBttE,EAAGtR,EAAEsR,EACL6Q,EAAGniB,EAAEmiB,GAGPrf,KAAKgvC,QAAO,EAAM67B,KAIf7hD,CACT,CAWAmiD,kBAAAA,CAAmBjuE,EAAGytE,EAAYE,EAAQvF,GACxC,MAAMx+D,EAAU9G,KAAK8G,QAErB,GAAe,aAAX5J,EAAEyC,KACJ,MAAO,GAGT,IAAK2lE,EAGH,OAAOqF,EAAWprC,OAAOpiC,GACvB6C,KAAKiuB,MAAMnuB,KAAK+xB,SAAS10B,EAAEihB,oBACiDzR,IAA5E3M,KAAKiuB,MAAMooB,eAAel5C,EAAEihB,cAAcs0B,WAAWqF,UAAU56C,EAAE6B,QAKrE,MAAMmtB,EAASnsB,KAAKiuB,MAAM07C,0BAA0BzsE,EAAG4J,EAAQgsB,KAAMhsB,EAAS+jE,GAM9E,OAJI/jE,EAAQ+W,SACVsO,EAAOtO,UAGFsO,CACT,CASAqzD,gBAAAA,CAAiBrzD,EAAQjvB,GACvB,MAAM,OAACi/E,EAAA,OAAQC,EAAA,QAAQt1E,GAAW9G,KAC5BooD,EAAWkvB,GAAYxwE,EAAQshD,UAAUhrD,KAAK4C,KAAMmsB,EAAQjvB,GAClE,OAAoB,IAAbkrD,IAAuB+zB,IAAW/zB,EAAS55C,GAAK4tE,IAAWh0B,EAAS/oC,EAC7E,GACD5hB,EAAAA,GAAAA,GA5vBYm+E,GAAgB,cAKNtE,IAyvBvB,IAAAoI,GAAe,CACb51E,GAAI,UACJmtE,SAAU2E,GACVtE,eAEAqI,SAAAA,CAAU1xD,EAAOipD,EAAOpwE,GAClBA,IACFmnB,EAAMkqD,QAAU,IAAIyD,GAAQ,CAAC3tD,QAAOnnB,YAExC,EAEA2vD,YAAAA,CAAaxoC,EAAOipD,EAAOpwE,GACrBmnB,EAAMkqD,SACRlqD,EAAMkqD,QAAQjjC,WAAWpuC,EAE7B,EAEA0vC,KAAAA,CAAMvoB,EAAOipD,EAAOpwE,GACdmnB,EAAMkqD,SACRlqD,EAAMkqD,QAAQjjC,WAAWpuC,EAE7B,EAEA84E,SAAAA,CAAU3xD,GACR,MAAMkqD,EAAUlqD,EAAMkqD,QAEtB,GAAIA,GAAWA,EAAQiH,cAAe,CACpC,MAAM7/E,EAAO,CACX44E,WAGF,IAA8E,IAA1ElqD,EAAMgqC,cAAc,oBAAqB,IAAI14D,EAAMkhE,YAAY,IACjE,OAGF0X,EAAQnrC,KAAK/e,EAAMwE,KAEnBxE,EAAMgqC,cAAc,mBAAoB14D,E,CAE5C,EAEA43E,UAAAA,CAAWlpD,EAAO1uB,GAChB,GAAI0uB,EAAMkqD,QAAS,CAEjB,MAAMtvB,EAAmBtpD,EAAKsrE,OAC1B58C,EAAMkqD,QAAQ3B,YAAYj3E,EAAK2lC,MAAO2jB,EAAkBtpD,EAAK+lE,eAE/D/lE,EAAKypB,SAAU,E,CAGrB,EAEA2C,SAAU,CACR4mC,SAAS,EACT4qB,SAAU,KACV/0B,SAAU,UACVz2B,gBAAiB,kBACjBisD,WAAY,OACZ1H,UAAW,CACT16D,OAAQ,QAEVy9D,aAAc,EACdC,kBAAmB,EACnBzkB,WAAY,OACZ6mB,UAAW,OACXjC,YAAa,EACbf,SAAU,CAAC,EAEXiG,UAAW,OACXO,YAAa,OACbvF,cAAe,EACfD,gBAAiB,EACjBf,WAAY,CACV/8D,OAAQ,QAEVqjE,YAAa,OACbjyD,QAAS,EACTmtD,aAAc,EACdD,UAAW,EACX5jD,aAAc,EACdm9C,UAAWA,CAAC5gD,EAAK6F,IAASA,EAAKggD,SAAShwE,KACxCgrE,SAAUA,CAAC7gD,EAAK6F,IAASA,EAAKggD,SAAShwE,KACvC41E,mBAAoB,OACpB9E,eAAe,EACfxtB,WAAY,EACZh6B,YAAa,gBACbwF,YAAa,EACbhL,UAAW,CACTR,SAAU,IACVC,OAAQ,gBAEVU,WAAY,CACVf,QAAS,CACP7rB,KAAM,SACNusB,WAAY,CAAC,IAAK,IAAK,QAAS,SAAU,SAAU,WAEtD2vD,QAAS,CACPhwD,OAAQ,SACRD,SAAU,MAGd0gB,UAAWwuC,IAGbzc,cAAe,CACbia,SAAU,OACVC,WAAY,OACZrC,UAAW,QAGb/kD,YAAa,CACXlF,YAAcxsB,GAAkB,WAATA,GAA8B,aAATA,GAAgC,aAATA,EACnEusB,YAAY,EACZsgB,UAAW,CACTrgB,aAAa,EACbD,YAAY,GAEdI,UAAW,CACTL,WAAW,GAEbQ,WAAY,CACVR,UAAW,cAKf03C,uBAAwB,CAAC,gBCj0C3B,MAAMoc,GAAcA,CAACnoC,EAAQjE,EAAKz0C,EAAO8gF,KACpB,kBAARrsC,GACTz0C,EAAQ04C,EAAOh4B,KAAK+zB,GAAO,EAC3BqsC,EAAYC,QAAQ,CAAC/gF,QAAO45C,MAAOnF,KAC1BzxB,MAAMyxB,KACfz0C,EAAQ,MAEHA,GAGT,SAASghF,GAAetoC,EAAQjE,EAAKz0C,EAAO8gF,GAC1C,MAAMptB,EAAQhb,EAAOh5B,QAAQ+0B,GAC7B,IAAe,IAAXif,EACF,OAAOmtB,GAAYnoC,EAAQjE,EAAKz0C,EAAO8gF,GAEzC,MAAMn7D,EAAO+yB,EAAOuoC,YAAYxsC,GAChC,OAAOif,IAAU/tC,EAAO3lB,EAAQ0zD,CAClC,CAEA,MAAMwB,GAAaA,CAACl1D,EAAO6L,IAAkB,OAAV7L,EAAiB,KAAOilB,GAAYpc,KAAKC,MAAM9I,GAAQ,EAAG6L,GAE7F,SAASq1E,GAAkBtiF,GACzB,MAAM85C,EAAS13C,KAAK23C,YAEpB,OAAI/5C,GAAS,GAAKA,EAAQ85C,EAAO9wC,OACxB8wC,EAAO95C,GAETA,CACT,CAEe,MAAMuiF,WAAsBrrB,GAazCj4D,WAAAA,CAAYyxC,GACVmQ,MAAMnQ,GAGNtuC,KAAKogF,iBAAczzE,EACnB3M,KAAKqgF,YAAc,EACnBrgF,KAAKsgF,aAAe,EACtB,CAEA/4B,IAAAA,CAAKsa,GACH,MAAM0e,EAAQvgF,KAAKsgF,aACnB,GAAIC,EAAM35E,OAAQ,CAChB,MAAM8wC,EAAS13C,KAAK23C,YACpB,IAAK,MAAM,MAAC34C,EAAA,MAAO45C,KAAU2nC,EACvB7oC,EAAO14C,KAAW45C,GACpBlB,EAAO9xB,OAAO5mB,EAAO,GAGzBgB,KAAKsgF,aAAe,E,CAEtB7hC,MAAM8I,KAAKsa,EACb,CAEAxhC,KAAAA,CAAMoT,EAAKz0C,GACT,GAAIyd,GAAcg3B,GAChB,OAAO,KAET,MAAMiE,EAAS13C,KAAK23C,YAGpB,OAFA34C,EAAQ8d,SAAS9d,IAAU04C,EAAO14C,KAAWy0C,EAAMz0C,EAC/CghF,GAAetoC,EAAQjE,EAAKx2B,GAAeje,EAAOy0C,GAAMzzC,KAAKsgF,cAC1DpsB,GAAWl1D,EAAO04C,EAAO9wC,OAAS,EAC3C,CAEAmwD,mBAAAA,GACE,MAAM,WAAChvC,EAAA,WAAYC,GAAchoB,KAAKioB,gBACtC,IAAI,IAACnd,EAAG,IAAED,GAAO7K,KAAKo4C,WAAU,GAEJ,UAAxBp4C,KAAK8G,QAAQqoB,SACVpH,IACHjd,EAAM,GAEHkd,IACHnd,EAAM7K,KAAK23C,YAAY/wC,OAAS,IAIpC5G,KAAK8K,IAAMA,EACX9K,KAAK6K,IAAMA,CACb,CAEAqsD,UAAAA,GACE,MAAMpsD,EAAM9K,KAAK8K,IACXD,EAAM7K,KAAK6K,IACXokB,EAASjvB,KAAK8G,QAAQmoB,OACtBjB,EAAQ,GACd,IAAI0pB,EAAS13C,KAAK23C,YAGlBD,EAAkB,IAAT5sC,GAAcD,IAAQ6sC,EAAO9wC,OAAS,EAAK8wC,EAASA,EAAO/6B,MAAM7R,EAAKD,EAAM,GAErF7K,KAAKqgF,YAAcx4E,KAAKgD,IAAI6sC,EAAO9wC,QAAUqoB,EAAS,EAAI,GAAI,GAC9DjvB,KAAKogF,YAAcpgF,KAAK8K,KAAOmkB,EAAS,GAAM,GAE9C,IAAK,IAAIrxB,EAAQkN,EAAKlN,GAASiN,EAAKjN,IAClCowB,EAAMtO,KAAK,CAAC9hB,UAEd,OAAOowB,CACT,CAEA6qB,gBAAAA,CAAiBj7C,GACf,OAAOsiF,GAAkB9iF,KAAK4C,KAAMpC,EACtC,CAKA8xC,SAAAA,GACE+O,MAAM/O,YAED1vC,KAAK09C,iBAER19C,KAAKioD,gBAAkBjoD,KAAKioD,eAEhC,CAGA//B,gBAAAA,CAAiBtqB,GAKf,MAJqB,kBAAVA,IACTA,EAAQoC,KAAKqgC,MAAMziC,IAGJ,OAAVA,EAAiBu6C,IAAMn4C,KAAKugD,oBAAoB3iD,EAAQoC,KAAKogF,aAAepgF,KAAKqgF,YAC1F,CAIApkC,eAAAA,CAAgBj9C,GACd,MAAMgvB,EAAQhuB,KAAKguB,MACnB,OAAIhvB,EAAQ,GAAKA,EAAQgvB,EAAMpnB,OAAS,EAC/B,KAEF5G,KAAKkoB,iBAAiB8F,EAAMhvB,GAAOpB,MAC5C,CAEA6iD,gBAAAA,CAAiBprB,GACf,OAAOxtB,KAAKC,MAAM9H,KAAKogF,YAAcpgF,KAAKy6D,mBAAmBplC,GAASr1B,KAAKqgF,YAC7E,CAEA1hC,YAAAA,GACE,OAAO3+C,KAAK8sB,MACd,ECpIF,SAAS0zD,GAAcC,EAAmBC,GACxC,MAAM1yD,EAAQ,GAKR2yD,EAAc,OACd,OAACxxD,EAAM,KAAE2sC,EAAA,IAAMhxD,EAAA,IAAKD,EAAG,UAAE+1E,EAAA,MAAW55E,EAAA,SAAO65E,EAAQ,UAAEC,EAAA,cAAWC,GAAiBN,EACjFO,EAAOllB,GAAQ,EACfmlB,EAAYJ,EAAW,GACtB/1E,IAAKo2E,EAAMr2E,IAAKs2E,GAAQT,EACzB34D,GAActL,GAAc3R,GAC5Bkd,GAAcvL,GAAc5R,GAC5Bu2E,GAAgB3kE,GAAczV,GAC9Bq6E,GAAcF,EAAOD,IAASJ,EAAY,GAChD,IACI5yC,EAAQozC,EAASC,EAASC,EAD1Bx+B,EAAU7hC,IAASggE,EAAOD,GAAQD,EAAYD,GAAQA,EAK1D,GAAIh+B,EAAU29B,IAAgB54D,IAAeC,EAC3C,MAAO,CAAC,CAACpqB,MAAOsjF,GAAO,CAACtjF,MAAOujF,IAGjCK,EAAY35E,KAAKyrD,KAAK6tB,EAAOn+B,GAAWn7C,KAAKyZ,MAAM4/D,EAAOl+B,GACtDw+B,EAAYP,IAEdj+B,EAAU7hC,GAAQqgE,EAAYx+B,EAAUi+B,EAAYD,GAAQA,GAGzDvkE,GAAcmkE,KAEjB1yC,EAASrmC,KAAKqS,IAAI,GAAI0mE,GACtB59B,EAAUn7C,KAAKyrD,KAAKtQ,EAAU9U,GAAUA,GAG3B,UAAX/e,GACFmyD,EAAUz5E,KAAKyZ,MAAM4/D,EAAOl+B,GAAWA,EACvCu+B,EAAU15E,KAAKyrD,KAAK6tB,EAAOn+B,GAAWA,IAEtCs+B,EAAUJ,EACVK,EAAUJ,GAGRp5D,GAAcC,GAAc8zC,GAAQ75C,IAAapX,EAAMC,GAAOgxD,EAAM9Y,EAAU,MAKhFw+B,EAAY35E,KAAKC,MAAMD,KAAKiD,KAAKD,EAAMC,GAAOk4C,EAAS69B,IACvD79B,GAAWn4C,EAAMC,GAAO02E,EACxBF,EAAUx2E,EACVy2E,EAAU12E,GACDu2E,GAITE,EAAUv5D,EAAajd,EAAMw2E,EAC7BC,EAAUv5D,EAAand,EAAM02E,EAC7BC,EAAYx6E,EAAQ,EACpBg8C,GAAWu+B,EAAUD,GAAWE,IAGhCA,GAAaD,EAAUD,GAAWt+B,EAIhCw+B,EADExgE,GAAawgE,EAAW35E,KAAKC,MAAM05E,GAAYx+B,EAAU,KAC/Cn7C,KAAKC,MAAM05E,GAEX35E,KAAKyrD,KAAKkuB,IAM1B,MAAMC,EAAgB55E,KAAKgD,IACzB6X,GAAesgC,GACftgC,GAAe4+D,IAEjBpzC,EAASrmC,KAAKqS,IAAI,GAAIuC,GAAcmkE,GAAaa,EAAgBb,GACjEU,EAAUz5E,KAAKC,MAAMw5E,EAAUpzC,GAAUA,EACzCqzC,EAAU15E,KAAKC,MAAMy5E,EAAUrzC,GAAUA,EAEzC,IAAI70B,EAAI,EAiBR,IAhBI0O,IACEg5D,GAAiBO,IAAYx2E,GAC/BkjB,EAAMtO,KAAK,CAAC9hB,MAAOkN,IAEfw2E,EAAUx2E,GACZuO,IAGE2H,GAAanZ,KAAKC,OAAOw5E,EAAUjoE,EAAI2pC,GAAW9U,GAAUA,EAAQpjC,EAAK42E,GAAkB52E,EAAKu2E,EAAYZ,KAC9GpnE,KAEOioE,EAAUx2E,GACnBuO,KAIGA,EAAImoE,IAAanoE,EAAG,CACzB,MAAM0U,EAAYlmB,KAAKC,OAAOw5E,EAAUjoE,EAAI2pC,GAAW9U,GAAUA,EACjE,GAAIlmB,GAAc+F,EAAYljB,EAC5B,MAEFmjB,EAAMtO,KAAK,CAAC9hB,MAAOmwB,GACrB,CAaA,OAXI/F,GAAc+4D,GAAiBQ,IAAY12E,EAEzCmjB,EAAMpnB,QAAUoa,GAAagN,EAAMA,EAAMpnB,OAAS,GAAGhJ,MAAOiN,EAAK62E,GAAkB72E,EAAKw2E,EAAYZ,IACtGzyD,EAAMA,EAAMpnB,OAAS,GAAGhJ,MAAQiN,EAEhCmjB,EAAMtO,KAAK,CAAC9hB,MAAOiN,IAEXmd,GAAcu5D,IAAY12E,GACpCmjB,EAAMtO,KAAK,CAAC9hB,MAAO2jF,IAGdvzD,CACT,CAEA,SAAS0zD,GAAkB9jF,EAAOyjF,GAAY,WAACzjC,EAAU,YAAE1tB,IACzD,MAAMsG,EAAMlU,GAAU4N,GAChB1V,GAASojC,EAAa/1C,KAAKshB,IAAIqN,GAAO3uB,KAAKuiB,IAAIoM,KAAS,KACxD5vB,EAAS,IAAOy6E,GAAc,GAAKzjF,GAAOgJ,OAChD,OAAOiB,KAAKiD,IAAIu2E,EAAa7mE,EAAO5T,EACtC,EDMAnJ,EAAAA,GAAAA,GA5HqB0iF,GAAsB,KAE7B,aAAW1iF,EAAAA,GAAAA,GAFJ0iF,GAAsB,WAOvB,CAChBnyD,MAAO,CACLzQ,SAAU2iE,MC+GD,MAAMyB,WAAwB7sB,GAE3Cj4D,WAAAA,CAAYyxC,GACVmQ,MAAMnQ,GAGNtuC,KAAK0jB,WAAQ/W,EAEb3M,KAAK2jB,SAAMhX,EAEX3M,KAAKogF,iBAAczzE,EAEnB3M,KAAK4hF,eAAYj1E,EACjB3M,KAAKqgF,YAAc,CACrB,CAEAhgD,KAAAA,CAAMoT,EAAKz0C,GACT,OAAIyd,GAAcg3B,KAGE,kBAARA,GAAoBA,aAAel2C,UAAYuf,UAAU22B,GAF5D,MAMDA,CACV,CAEAouC,sBAAAA,GACE,MAAM,YAAC3yD,GAAelvB,KAAK8G,SACrB,WAACihB,EAAA,WAAYC,GAAchoB,KAAKioB,gBACtC,IAAI,IAACnd,EAAG,IAAED,GAAO7K,KAEjB,MAAM8hF,EAASr3E,GAAMK,EAAMid,EAAajd,EAAML,EACxCs3E,EAASt3E,GAAMI,EAAMmd,EAAand,EAAMJ,EAE9C,GAAIykB,EAAa,CACf,MAAM8yD,EAAUjhE,GAAKjW,GACfm3E,EAAUlhE,GAAKlW,GAEjBm3E,EAAU,GAAKC,EAAU,EAC3BF,EAAO,GACEC,EAAU,GAAKC,EAAU,GAClCH,EAAO,E,CAIX,GAAIh3E,IAAQD,EAAK,CACf,IAAIokB,EAAiB,IAARpkB,EAAY,EAAIhD,KAAKqZ,IAAU,IAANrW,GAEtCk3E,EAAOl3E,EAAMokB,GAERC,GACH4yD,EAAOh3E,EAAMmkB,E,CAGjBjvB,KAAK8K,IAAMA,EACX9K,KAAK6K,IAAMA,CACb,CAEAq3E,YAAAA,GACE,MAAMjwB,EAAWjyD,KAAK8G,QAAQknB,MAE9B,IACI6yD,GADA,cAACxuB,EAAA,SAAe8vB,GAAYlwB,EAkBhC,OAfIkwB,GACFtB,EAAWh5E,KAAKyrD,KAAKtzD,KAAK6K,IAAMs3E,GAAYt6E,KAAKyZ,MAAMthB,KAAK8K,IAAMq3E,GAAY,EAC1EtB,EAAW,MACbvlD,QAAQC,KAAK,UAAUv7B,KAAK8J,sBAAsBq4E,mCAA0CtB,8BAC5FA,EAAW,OAGbA,EAAW7gF,KAAKoiF,mBAChB/vB,EAAgBA,GAAiB,IAG/BA,IACFwuB,EAAWh5E,KAAKiD,IAAIunD,EAAewuB,IAG9BA,CACT,CAKAuB,gBAAAA,GACE,OAAO7kF,OAAOkjB,iBAChB,CAEAy2C,UAAAA,GACE,MAAM5+B,EAAOt4B,KAAK8G,QACZmrD,EAAW35B,EAAKtK,MAMtB,IAAI6yD,EAAW7gF,KAAKkiF,eACpBrB,EAAWh5E,KAAKgD,IAAI,EAAGg2E,GAEvB,MAAMwB,EAA0B,CAC9BxB,WACA1xD,OAAQmJ,EAAKnJ,OACbrkB,IAAKwtB,EAAKxtB,IACVD,IAAKytB,EAAKztB,IACV+1E,UAAW3uB,EAAS2uB,UACpB9kB,KAAM7J,EAASkwB,SACfn7E,MAAOirD,EAASjrD,MAChB85E,UAAW9gF,KAAK09D,aAChB9f,WAAY59C,KAAK09C,eACjBxtB,YAAa+hC,EAAS/hC,aAAe,EACrC6wD,eAA0C,IAA3B9uB,EAAS8uB,eAEpBL,EAAY1gF,KAAKq1D,QAAUr1D,KAC3BguB,EAAQwyD,GAAc6B,EAAyB3B,GAkBrD,MAdoB,UAAhBpoD,EAAKnJ,QACPhN,GAAmB6L,EAAOhuB,KAAM,SAG9Bs4B,EAAKza,SACPmQ,EAAMnQ,UAEN7d,KAAK0jB,MAAQ1jB,KAAK6K,IAClB7K,KAAK2jB,IAAM3jB,KAAK8K,MAEhB9K,KAAK0jB,MAAQ1jB,KAAK8K,IAClB9K,KAAK2jB,IAAM3jB,KAAK6K,KAGXmjB,CACT,CAKA0hB,SAAAA,GACE,MAAM1hB,EAAQhuB,KAAKguB,MACnB,IAAItK,EAAQ1jB,KAAK8K,IACb6Y,EAAM3jB,KAAK6K,IAIf,GAFA4zC,MAAM/O,YAEF1vC,KAAK8G,QAAQmoB,QAAUjB,EAAMpnB,OAAQ,CACvC,MAAMqoB,GAAUtL,EAAMD,GAAS7b,KAAKgD,IAAImjB,EAAMpnB,OAAS,EAAG,GAAK,EAC/D8c,GAASuL,EACTtL,GAAOsL,C,CAETjvB,KAAKogF,YAAc18D,EACnB1jB,KAAK4hF,UAAYj+D,EACjB3jB,KAAKqgF,YAAc18D,EAAMD,CAC3B,CAEAm1B,gBAAAA,CAAiBj7C,GACf,OAAO8vB,GAAa9vB,EAAOoC,KAAKiuB,MAAMnnB,QAAQomB,OAAQltB,KAAK8G,QAAQknB,MAAMJ,OAC3E,EClTa,MAAM00D,WAAoBX,GAcvC5qB,mBAAAA,GACE,MAAM,IAACjsD,EAAG,IAAED,GAAO7K,KAAKo4C,WAAU,GAElCp4C,KAAK8K,IAAM+R,GAAS/R,GAAOA,EAAM,EACjC9K,KAAK6K,IAAMgS,GAAShS,GAAOA,EAAM,EAGjC7K,KAAK6hF,wBACP,CAMAO,gBAAAA,GACE,MAAMxkC,EAAa59C,KAAK09C,eAClB92C,EAASg3C,EAAa59C,KAAKgwB,MAAQhwB,KAAK61B,OACxC3F,EAAc5N,GAAUtiB,KAAK8G,QAAQknB,MAAMkC,aAC3C1V,GAASojC,EAAa/1C,KAAKshB,IAAI+G,GAAeroB,KAAKuiB,IAAI8F,KAAiB,KACxE8pC,EAAWh6D,KAAKq6D,wBAAwB,GAC9C,OAAOxyD,KAAKyrD,KAAK1sD,EAASiB,KAAKiD,IAAI,GAAIkvD,EAAS1nC,WAAa9X,GAC/D,CAGA0N,gBAAAA,CAAiBtqB,GACf,OAAiB,OAAVA,EAAiBu6C,IAAMn4C,KAAKugD,oBAAoB3iD,EAAQoC,KAAKogF,aAAepgF,KAAKqgF,YAC1F,CAEA5/B,gBAAAA,CAAiBprB,GACf,OAAOr1B,KAAKogF,YAAcpgF,KAAKy6D,mBAAmBplC,GAASr1B,KAAKqgF,WAClE,GACF5iF,EAAAA,GAAAA,GA7CqB6kF,GAAoB,KAE3B,WAAS7kF,EAAAA,GAAAA,GAFF6kF,GAAoB,WAOrB,CAChBt0D,MAAO,CACLzQ,SAAUuR,GAAMjB,WAAWC,WCPjC,MAAMy0D,GAAa93E,GAAK5C,KAAKyZ,MAAMR,GAAMrW,IACnC+3E,GAAiBA,CAAC/3E,EAAGwD,IAAMpG,KAAKqS,IAAI,GAAIqoE,GAAW93E,GAAKwD,GAE9D,SAASw0E,GAAQC,GACf,MAAM/zD,EAAS+zD,EAAW76E,KAAKqS,IAAI,GAAIqoE,GAAWG,IAClD,OAAkB,IAAX/zD,CACT,CAEA,SAASg0D,GAAM73E,EAAKD,EAAK+3E,GACvB,MAAMC,EAAYh7E,KAAKqS,IAAI,GAAI0oE,GACzBl/D,EAAQ7b,KAAKyZ,MAAMxW,EAAM+3E,GACzBl/D,EAAM9b,KAAKyrD,KAAKzoD,EAAMg4E,GAC5B,OAAOl/D,EAAMD,CACf,CAEA,SAASo/D,GAASh4E,EAAKD,GACrB,MAAM0C,EAAQ1C,EAAMC,EACpB,IAAI83E,EAAWL,GAAWh1E,GAC1B,MAAOo1E,GAAM73E,EAAKD,EAAK+3E,GAAY,GACjCA,IAEF,MAAOD,GAAM73E,EAAKD,EAAK+3E,GAAY,GACjCA,IAEF,OAAO/6E,KAAKiD,IAAI83E,EAAUL,GAAWz3E,GACvC,CASA,SAASi4E,GAActC,GAAmB,IAAC31E,EAAG,IAAED,IAC9CC,EAAMiS,GAAgB0jE,EAAkB31E,IAAKA,GAC7C,MAAMkjB,EAAQ,GACRg1D,EAAST,GAAWz3E,GAC1B,IAAIm4E,EAAMH,GAASh4E,EAAKD,GACpB+1E,EAAYqC,EAAM,EAAIp7E,KAAKqS,IAAI,GAAIrS,KAAKqZ,IAAI+hE,IAAQ,EACxD,MAAMd,EAAWt6E,KAAKqS,IAAI,GAAI+oE,GACxB19D,EAAOy9D,EAASC,EAAMp7E,KAAKqS,IAAI,GAAI8oE,GAAU,EAC7Ct/D,EAAQ7b,KAAKC,OAAOgD,EAAMya,GAAQq7D,GAAaA,EAC/C3xD,EAASpnB,KAAKyZ,OAAOxW,EAAMya,GAAQ48D,EAAW,IAAMA,EAAW,GACrE,IAAIvzD,EAAc/mB,KAAKyZ,OAAOoC,EAAQuL,GAAUpnB,KAAKqS,IAAI,GAAI+oE,IACzDrlF,EAAQmf,GAAgB0jE,EAAkB31E,IAAKjD,KAAKC,OAAOyd,EAAO0J,EAASL,EAAc/mB,KAAKqS,IAAI,GAAI+oE,IAAQrC,GAAaA,GAC/H,MAAOhjF,EAAQiN,EACbmjB,EAAMtO,KAAK,CAAC9hB,QAAO+yB,MAAO8xD,GAAQ7kF,GAAQgxB,gBACtCA,GAAe,GACjBA,EAAcA,EAAc,GAAK,GAAK,GAEtCA,IAEEA,GAAe,KACjBq0D,IACAr0D,EAAc,EACdgyD,EAAYqC,GAAO,EAAI,EAAIrC,GAE7BhjF,EAAQiK,KAAKC,OAAOyd,EAAO0J,EAASL,EAAc/mB,KAAKqS,IAAI,GAAI+oE,IAAQrC,GAAaA,EAEtF,MAAMsC,EAAWnmE,GAAgB0jE,EAAkB51E,IAAKjN,GAGxD,OAFAowB,EAAMtO,KAAK,CAAC9hB,MAAOslF,EAAUvyD,MAAO8xD,GAAQS,GAAWt0D,gBAEhDZ,CACT,CAEe,MAAMm1D,WAAyBruB,GAiB5Cj4D,WAAAA,CAAYyxC,GACVmQ,MAAMnQ,GAGNtuC,KAAK0jB,WAAQ/W,EAEb3M,KAAK2jB,SAAMhX,EAEX3M,KAAKogF,iBAAczzE,EACnB3M,KAAKqgF,YAAc,CACrB,CAEAhgD,KAAAA,CAAMoT,EAAKz0C,GACT,MAAMpB,EAAQ+jF,GAAgB7kF,UAAUujC,MAAM3iB,MAAM1d,KAAM,CAACyzC,EAAKz0C,IAChE,GAAc,IAAVpB,EAIJ,OAAOif,GAASjf,IAAUA,EAAQ,EAAIA,EAAQ,KAH5CoC,KAAKojF,OAAQ,CAIjB,CAEArsB,mBAAAA,GACE,MAAM,IAACjsD,EAAG,IAAED,GAAO7K,KAAKo4C,WAAU,GAElCp4C,KAAK8K,IAAM+R,GAAS/R,GAAOjD,KAAKgD,IAAI,EAAGC,GAAO,KAC9C9K,KAAK6K,IAAMgS,GAAShS,GAAOhD,KAAKgD,IAAI,EAAGA,GAAO,KAE1C7K,KAAK8G,QAAQooB,cACflvB,KAAKojF,OAAQ,GAKXpjF,KAAKojF,OAASpjF,KAAK8K,MAAQ9K,KAAK61D,gBAAkBh5C,GAAS7c,KAAK21D,YAClE31D,KAAK8K,IAAMA,IAAQ03E,GAAexiF,KAAK8K,IAAK,GAAK03E,GAAexiF,KAAK8K,KAAM,GAAK03E,GAAexiF,KAAK8K,IAAK,IAG3G9K,KAAK6hF,wBACP,CAEAA,sBAAAA,GACE,MAAM,WAAC95D,EAAA,WAAYC,GAAchoB,KAAKioB,gBACtC,IAAInd,EAAM9K,KAAK8K,IACXD,EAAM7K,KAAK6K,IAEf,MAAMi3E,EAASr3E,GAAMK,EAAMid,EAAajd,EAAML,EACxCs3E,EAASt3E,GAAMI,EAAMmd,EAAand,EAAMJ,EAE1CK,IAAQD,IACNC,GAAO,GACTg3E,EAAO,GACPC,EAAO,MAEPD,EAAOU,GAAe13E,GAAM,IAC5Bi3E,EAAOS,GAAe33E,EAAK,MAG3BC,GAAO,GACTg3E,EAAOU,GAAe33E,GAAM,IAE1BA,GAAO,GAETk3E,EAAOS,GAAe13E,EAAK,IAG7B9K,KAAK8K,IAAMA,EACX9K,KAAK6K,IAAMA,CACb,CAEAqsD,UAAAA,GACE,MAAM5+B,EAAOt4B,KAAK8G,QAEZ25E,EAAoB,CACxB31E,IAAK9K,KAAK21D,SACV9qD,IAAK7K,KAAK01D,UAEN1nC,EAAQ+0D,GAActC,EAAmBzgF,MAkB/C,MAdoB,UAAhBs4B,EAAKnJ,QACPhN,GAAmB6L,EAAOhuB,KAAM,SAG9Bs4B,EAAKza,SACPmQ,EAAMnQ,UAEN7d,KAAK0jB,MAAQ1jB,KAAK6K,IAClB7K,KAAK2jB,IAAM3jB,KAAK8K,MAEhB9K,KAAK0jB,MAAQ1jB,KAAK8K,IAClB9K,KAAK2jB,IAAM3jB,KAAK6K,KAGXmjB,CACT,CAMA6qB,gBAAAA,CAAiBj7C,GACf,YAAiB+O,IAAV/O,EACH,IACA8vB,GAAa9vB,EAAOoC,KAAKiuB,MAAMnnB,QAAQomB,OAAQltB,KAAK8G,QAAQknB,MAAMJ,OACxE,CAKA8hB,SAAAA,GACE,MAAMhsB,EAAQ1jB,KAAK8K,IAEnB2zC,MAAM/O,YAEN1vC,KAAKogF,YAAct/D,GAAM4C,GACzB1jB,KAAKqgF,YAAcv/D,GAAM9gB,KAAK6K,KAAOiW,GAAM4C,EAC7C,CAEAwE,gBAAAA,CAAiBtqB,GAIf,YAHc+O,IAAV/O,GAAiC,IAAVA,IACzBA,EAAQoC,KAAK8K,KAED,OAAVlN,GAAkBokB,MAAMpkB,GACnBu6C,IAEFn4C,KAAKugD,mBAAmB3iD,IAAUoC,KAAK8K,IAC1C,GACCgW,GAAMljB,GAASoC,KAAKogF,aAAepgF,KAAKqgF,YAC/C,CAEA5/B,gBAAAA,CAAiBprB,GACf,MAAMmlC,EAAUx6D,KAAKy6D,mBAAmBplC,GACxC,OAAOxtB,KAAKqS,IAAI,GAAIla,KAAKogF,YAAc5lB,EAAUx6D,KAAKqgF,YACxD,ECxNF,SAASgD,GAAsB/qD,GAC7B,MAAM25B,EAAW35B,EAAKtK,MAEtB,GAAIikC,EAASjjC,SAAWsJ,EAAKtJ,QAAS,CACpC,MAAMpC,EAAUuO,GAAU82B,EAASlhC,iBACnC,OAAO9T,GAAeg1C,EAAS7/B,MAAQ6/B,EAAS7/B,KAAK9pB,KAAMqjB,GAASyG,KAAK9pB,MAAQskB,EAAQiJ,M,CAE3F,OAAO,CACT,CAEA,SAASytD,GAAiB7wD,EAAKL,EAAMwmB,GAEnC,OADAA,EAAQlrC,GAAQkrC,GAASA,EAAQ,CAACA,GAC3B,CACLzrC,EAAGunB,GAAajC,EAAKL,EAAKmC,OAAQqkB,GAClChuC,EAAGguC,EAAMhyC,OAASwrB,EAAKE,WAE3B,CAEA,SAASixD,GAAgBtgE,EAAOqhB,EAAKh8B,EAAMwC,EAAKD,GAC9C,OAAIoY,IAAUnY,GAAOmY,IAAUpY,EACtB,CACL6Y,MAAO4gB,EAAOh8B,EAAO,EACrBqb,IAAK2gB,EAAOh8B,EAAO,GAEZ2a,EAAQnY,GAAOmY,EAAQpY,EACzB,CACL6Y,MAAO4gB,EAAMh8B,EACbqb,IAAK2gB,GAIF,CACL5gB,MAAO4gB,EACP3gB,IAAK2gB,EAAMh8B,EAEf,CAKA,SAASk7E,GAAmBlwD,GA8B1B,MAAM8qB,EAAO,CACXzzC,EAAG2oB,EAAMvM,KAAOuM,EAAMmwD,SAAS18D,KAC/B9pB,EAAGq2B,EAAMtM,MAAQsM,EAAMmwD,SAASz8D,MAChChqB,EAAGs2B,EAAMzG,IAAMyG,EAAMmwD,SAAS52D,IAC9BlhB,EAAG2nB,EAAMxG,OAASwG,EAAMmwD,SAAS32D,QAE7B42D,EAAShmF,OAAOkd,OAAO,CAAC,EAAGwjC,GAC3Boa,EAAa,GACb5rC,EAAU,GACV+2D,EAAarwD,EAAMswD,aAAah9E,OAChCi9E,EAAiBvwD,EAAMxsB,QAAQ8/C,YAC/Bk9B,EAAkBD,EAAeE,kBAAoB1jE,GAAKsjE,EAAa,EAE7E,IAAK,IAAIxmF,EAAI,EAAGA,EAAIwmF,EAAYxmF,IAAK,CACnC,MAAMm7B,EAAOurD,EAAe1lD,WAAW7K,EAAM0wD,qBAAqB7mF,IAClEyvB,EAAQzvB,GAAKm7B,EAAK1L,QAClB,MAAMm6B,EAAgBzzB,EAAM2wD,iBAAiB9mF,EAAGm2B,EAAM4wD,YAAct3D,EAAQzvB,GAAI2mF,GAC1EK,EAAS/oD,GAAO9C,EAAKlG,MACrBgyD,EAAWd,GAAiBhwD,EAAMb,IAAK0xD,EAAQ7wD,EAAMswD,aAAazmF,IACxEq7D,EAAWr7D,GAAKinF,EAEhB,MAAMjrB,EAAe31C,GAAgB8P,EAAM+yB,cAAclpD,GAAK2mF,GACxD7gE,EAAQpb,KAAKC,MAAM0a,GAAU22C,IAC7BkrB,EAAUd,GAAgBtgE,EAAO8jC,EAAcv4C,EAAG41E,EAASj3E,EAAG,EAAG,KACjEm3E,EAAUf,GAAgBtgE,EAAO8jC,EAAc1nC,EAAG+kE,EAASx5E,EAAG,GAAI,KACxE25E,GAAab,EAAQtlC,EAAM+a,EAAckrB,EAASC,EACpD,CAEAhxD,EAAMkxD,eACJpmC,EAAKzzC,EAAI+4E,EAAO/4E,EAChB+4E,EAAOzmF,EAAImhD,EAAKnhD,EAChBmhD,EAAKphD,EAAI0mF,EAAO1mF,EAChB0mF,EAAO/3E,EAAIyyC,EAAKzyC,GAIlB2nB,EAAMmxD,iBAAmBC,GAAqBpxD,EAAOklC,EAAY5rC,EACnE,CAEA,SAAS23D,GAAab,EAAQtlC,EAAMn7B,EAAOohE,EAASC,GAClD,MAAMn7D,EAAMthB,KAAKqZ,IAAIrZ,KAAKshB,IAAIlG,IACxBmH,EAAMviB,KAAKqZ,IAAIrZ,KAAKuiB,IAAInH,IAC9B,IAAIzU,EAAI,EACJ6Q,EAAI,EACJglE,EAAQ3gE,MAAQ06B,EAAKzzC,GACvB6D,GAAK4vC,EAAKzzC,EAAI05E,EAAQ3gE,OAASyF,EAC/Bu6D,EAAO/4E,EAAI9C,KAAKiD,IAAI44E,EAAO/4E,EAAGyzC,EAAKzzC,EAAI6D,IAC9B61E,EAAQ1gE,IAAMy6B,EAAKnhD,IAC5BuR,GAAK61E,EAAQ1gE,IAAMy6B,EAAKnhD,GAAKksB,EAC7Bu6D,EAAOzmF,EAAI4K,KAAKgD,IAAI64E,EAAOzmF,EAAGmhD,EAAKnhD,EAAIuR,IAErC81E,EAAQ5gE,MAAQ06B,EAAKphD,GACvBqiB,GAAK++B,EAAKphD,EAAIsnF,EAAQ5gE,OAAS0G,EAC/Bs5D,EAAO1mF,EAAI6K,KAAKiD,IAAI44E,EAAO1mF,EAAGohD,EAAKphD,EAAIqiB,IAC9BilE,EAAQ3gE,IAAMy6B,EAAKzyC,IAC5B0T,GAAKilE,EAAQ3gE,IAAMy6B,EAAKzyC,GAAKye,EAC7Bs5D,EAAO/3E,EAAI9D,KAAKgD,IAAI64E,EAAO/3E,EAAGyyC,EAAKzyC,EAAI0T,GAE3C,CAEA,SAASslE,GAAqBrxD,EAAOt0B,EAAO4lF,GAC1C,MAAMC,EAAgBvxD,EAAM4wD,aACtB,MAACY,EAAA,gBAAOhB,EAAA,QAAiBl3D,EAAO,KAAEtkB,GAAQs8E,EAC1CG,EAAqBzxD,EAAM2wD,iBAAiBjlF,EAAO6lF,EAAgBC,EAAQl4D,EAASk3D,GACpF7gE,EAAQpb,KAAKC,MAAM0a,GAAUgB,GAAgBuhE,EAAmB9hE,MAAQtC,MACxEtB,EAAI2lE,GAAUD,EAAmB1lE,EAAG/W,EAAKsC,EAAGqY,GAC5CwV,EAAYwsD,GAAqBhiE,GACjC8D,EAAOm+D,GAAiBH,EAAmBv2E,EAAGlG,EAAK6E,EAAGsrB,GAC5D,MAAO,CAELjM,SAAS,EAGThe,EAAGu2E,EAAmBv2E,EACtB6Q,IAGAoZ,YAGA1R,OACA8F,IAAKxN,EACL2H,MAAOD,EAAOze,EAAK6E,EACnB2f,OAAQzN,EAAI/W,EAAKsC,EAErB,CAEA,SAASu6E,GAAgBrmF,EAAMy4B,GAC7B,IAAKA,EACH,OAAO,EAET,MAAM,KAACxQ,EAAA,IAAM8F,EAAA,MAAK7F,EAAK,OAAE8F,GAAUhuB,EAC7BsmF,EAAe9tD,GAAe,CAAC9oB,EAAGuY,EAAM1H,EAAGwN,GAAM0K,IAASD,GAAe,CAAC9oB,EAAGuY,EAAM1H,EAAGyN,GAASyK,IACnGD,GAAe,CAAC9oB,EAAGwY,EAAO3H,EAAGwN,GAAM0K,IAASD,GAAe,CAAC9oB,EAAGwY,EAAO3H,EAAGyN,GAASyK,GACpF,OAAQ6tD,CACV,CAEA,SAASV,GAAqBpxD,EAAOklC,EAAY5rC,GAC/C,MAAM9G,EAAQ,GACR69D,EAAarwD,EAAMswD,aAAah9E,OAChC0xB,EAAOhF,EAAMxsB,SACb,kBAACi9E,EAAiB,QAAE/0D,GAAWsJ,EAAKsuB,YACpCg+B,EAAW,CACfE,MAAOzB,GAAsB/qD,GAAQ,EACrCwrD,gBAAiBC,EAAoB1jE,GAAKsjE,EAAa,GAEzD,IAAIpsD,EAEJ,IAAK,IAAIp6B,EAAI,EAAGA,EAAIwmF,EAAYxmF,IAAK,CACnCynF,EAASh4D,QAAUA,EAAQzvB,GAC3BynF,EAASt8E,KAAOkwD,EAAWr7D,GAE3B,MAAM2B,EAAO6lF,GAAqBrxD,EAAOn2B,EAAGynF,GAC5C9+D,EAAMpG,KAAK5gB,GACK,SAAZkwB,IACFlwB,EAAK0tB,QAAU24D,GAAgBrmF,EAAMy4B,GACjCz4B,EAAK0tB,UACP+K,EAAOz4B,GAGb,CACA,OAAOgnB,CACT,CAEA,SAASm/D,GAAqBhiE,GAC5B,OAAc,IAAVA,GAAyB,MAAVA,EACV,SACEA,EAAQ,IACV,OAGF,OACT,CAEA,SAASiiE,GAAiB12E,EAAGrB,EAAGyZ,GAM9B,MALc,UAAVA,EACFpY,GAAKrB,EACc,WAAVyZ,IACTpY,GAAMrB,EAAI,GAELqB,CACT,CAEA,SAASw2E,GAAU3lE,EAAGzU,EAAGqY,GAMvB,OALc,KAAVA,GAA0B,MAAVA,EAClB5D,GAAMzU,EAAI,GACDqY,EAAQ,KAAOA,EAAQ,MAChC5D,GAAKzU,GAEAyU,CACT,CAEA,SAASgmE,GAAkB5yD,EAAK6F,EAAMx5B,GACpC,MAAM,KAACioB,EAAA,IAAM8F,EAAA,MAAK7F,EAAK,OAAE8F,GAAUhuB,GAC7B,cAACgyB,GAAiBwH,EAExB,IAAK7b,GAAcqU,GAAgB,CACjC,MAAM4zB,EAAexpB,GAAc5C,EAAKosB,cAClC93B,EAAUuO,GAAU7C,EAAKvH,iBAC/B0B,EAAI+F,UAAY1H,EAEhB,MAAMw0D,EAAev+D,EAAO6F,EAAQ7F,KAC9Bw+D,EAAc14D,EAAMD,EAAQC,IAC5B24D,EAAgBx+D,EAAQD,EAAO6F,EAAQoD,MACvCy1D,EAAiB34D,EAASD,EAAMD,EAAQiJ,OAE1Cn4B,OAAOqnB,OAAO2/B,GAAcsc,KAAKv2D,GAAW,IAANA,IACxCgoB,EAAIkE,YACJuD,GAAmBzH,EAAK,CACtBjkB,EAAG82E,EACHjmE,EAAGkmE,EACHp4E,EAAGq4E,EACH56E,EAAG66E,EACHlvD,OAAQmuB,IAEVjyB,EAAI0E,QAEJ1E,EAAIgH,SAAS6rD,EAAcC,EAAaC,EAAeC,E,CAG7D,CAEA,SAASC,GAAgBpyD,EAAO0nD,GAC9B,MAAM,IAACvoD,EAAK3rB,SAAS,YAAC8/C,IAAgBtzB,EAEtC,IAAK,IAAIn2B,EAAI69E,EAAa,EAAG79E,GAAK,EAAGA,IAAK,CACxC,MAAM2B,EAAOw0B,EAAMmxD,iBAAiBtnF,GACpC,IAAK2B,EAAK0tB,QAER,SAEF,MAAMuvC,EAAcnV,EAAYzoB,WAAW7K,EAAM0wD,qBAAqB7mF,IACtEkoF,GAAkB5yD,EAAKspC,EAAaj9D,GACpC,MAAMqlF,EAAS/oD,GAAO2gC,EAAY3pC,OAC5B,EAAC5jB,EAAC,EAAE6Q,EAAA,UAAGoZ,GAAa35B,EAE1B46B,GACEjH,EACAa,EAAMswD,aAAazmF,GACnBqR,EACA6Q,EAAK8kE,EAAO7xD,WAAa,EACzB6xD,EACA,CACE5oE,MAAOwgD,EAAYxgD,MACnBkd,UAAWA,EACXC,aAAc,UAGpB,CACF,CAEA,SAASitD,GAAeryD,EAAOiD,EAAQowB,EAAUq0B,GAC/C,MAAM,IAACvoD,GAAOa,EACd,GAAIqzB,EAEFl0B,EAAIoE,IAAIvD,EAAM4yB,QAAS5yB,EAAM6yB,QAAS5vB,EAAQ,EAAGjW,QAC5C,CAEL,IAAIymC,EAAgBzzB,EAAM2wD,iBAAiB,EAAG1tD,GAC9C9D,EAAIsE,OAAOgwB,EAAcv4C,EAAGu4C,EAAc1nC,GAE1C,IAAK,IAAIliB,EAAI,EAAGA,EAAI69E,EAAY79E,IAC9B4pD,EAAgBzzB,EAAM2wD,iBAAiB9mF,EAAGo5B,GAC1C9D,EAAIuE,OAAO+vB,EAAcv4C,EAAGu4C,EAAc1nC,E,CAGhD,CAEA,SAASumE,GAAetyD,EAAOuyD,EAActvD,EAAQykD,EAAYjgB,GAC/D,MAAMtoC,EAAMa,EAAMb,IACZk0B,EAAWk/B,EAAal/B,UAExB,MAACprC,EAAA,UAAOgU,GAAas2D,GAErBl/B,IAAaq0B,IAAgBz/D,IAAUgU,GAAagH,EAAS,IAInE9D,EAAIqC,OACJrC,EAAI4G,YAAc9d,EAClBkX,EAAIlD,UAAYA,EAChBkD,EAAIwqC,YAAYlC,EAAWjrC,MAAQ,IACnC2C,EAAIoyB,eAAiBkW,EAAWhrC,WAEhC0C,EAAIkE,YACJgvD,GAAeryD,EAAOiD,EAAQowB,EAAUq0B,GACxCvoD,EAAIqE,YACJrE,EAAI4E,SACJ5E,EAAIyC,UACN,CAEA,SAAS4wD,GAAwBpmD,EAAQ1gC,EAAO45C,GAC9C,OAAO3c,GAAcyD,EAAQ,CAC3BkZ,QACA55C,QACAW,KAAM,cAEV,ED9GAlC,EAAAA,GAAAA,GAxJqB0lF,GAAyB,KAEhC,gBAAc1lF,EAAAA,GAAAA,GAFP0lF,GAAyB,WAO1B,CAChBn1D,MAAO,CACLzQ,SAAUuR,GAAMjB,WAAWa,YAC3BiC,MAAO,CACL4hC,SAAS,MC6PF,MAAMwzB,WAA0BpE,GA0E7C9kF,WAAAA,CAAYyxC,GACVmQ,MAAMnQ,GAGNtuC,KAAKkmD,aAAUv5C,EAEf3M,KAAKmmD,aAAUx5C,EAEf3M,KAAKkkF,iBAAcv3E,EAEnB3M,KAAK4jF,aAAe,GACpB5jF,KAAKykF,iBAAmB,EAC1B,CAEA7tB,aAAAA,GAEE,MAAMhqC,EAAU5sB,KAAKyjF,SAAWtoD,GAAUkoD,GAAsBrjF,KAAK8G,SAAW,GAC1EqG,EAAInN,KAAKgwB,MAAQhwB,KAAKg6B,SAAWpN,EAAQoD,MACzCplB,EAAI5K,KAAK61B,OAAS71B,KAAKwlC,UAAY5Y,EAAQiJ,OACjD71B,KAAKkmD,QAAUr+C,KAAKyZ,MAAMthB,KAAK+mB,KAAO5Z,EAAI,EAAIyf,EAAQ7F,MACtD/mB,KAAKmmD,QAAUt+C,KAAKyZ,MAAMthB,KAAK6sB,IAAMjiB,EAAI,EAAIgiB,EAAQC,KACrD7sB,KAAKkkF,YAAcr8E,KAAKyZ,MAAMzZ,KAAKiD,IAAIqC,EAAGvC,GAAK,EACjD,CAEAmsD,mBAAAA,GACE,MAAM,IAACjsD,EAAG,IAAED,GAAO7K,KAAKo4C,WAAU,GAElCp4C,KAAK8K,IAAM+R,GAAS/R,KAASkX,MAAMlX,GAAOA,EAAM,EAChD9K,KAAK6K,IAAMgS,GAAShS,KAASmX,MAAMnX,GAAOA,EAAM,EAGhD7K,KAAK6hF,wBACP,CAMAO,gBAAAA,GACE,OAAOv6E,KAAKyrD,KAAKtzD,KAAKkkF,YAAcb,GAAsBrjF,KAAK8G,SACjE,CAEAqxD,kBAAAA,CAAmBnqC,GACjB2zD,GAAgB7kF,UAAUq7D,mBAAmB/6D,KAAK4C,KAAMguB,GAGxDhuB,KAAK4jF,aAAe5jF,KAAK23C,YACtBhqC,IAAI,CAAC/P,EAAOoB,KACX,MAAM45C,EAAQr7B,GAAavd,KAAK8G,QAAQ8/C,YAAYrpC,SAAU,CAAC3f,EAAOoB,GAAQgB,MAC9E,OAAO44C,GAAmB,IAAVA,EAAcA,EAAQ,KAEvCrZ,OAAO,CAAC90B,EAAGtN,IAAM6C,KAAKiuB,MAAMoyB,kBAAkBljD,GACnD,CAEA4M,GAAAA,GACE,MAAMuuB,EAAOt4B,KAAK8G,QAEdwxB,EAAKtJ,SAAWsJ,EAAKsuB,YAAY53B,QACnCw0D,GAAmBxjF,MAEnBA,KAAKwkF,eAAe,EAAG,EAAG,EAAG,EAEjC,CAEAA,cAAAA,CAAewB,EAAcC,EAAeC,EAAaC,GACvDnmF,KAAKkmD,SAAWr+C,KAAKyZ,OAAO0kE,EAAeC,GAAiB,GAC5DjmF,KAAKmmD,SAAWt+C,KAAKyZ,OAAO4kE,EAAcC,GAAkB,GAC5DnmF,KAAKkkF,aAAer8E,KAAKiD,IAAI9K,KAAKkkF,YAAc,EAAGr8E,KAAKgD,IAAIm7E,EAAcC,EAAeC,EAAaC,GACxG,CAEA9/B,aAAAA,CAAcrnD,GACZ,MAAMonF,EAAkB9lE,IAAOtgB,KAAK4jF,aAAah9E,QAAU,GACrD+6C,EAAa3hD,KAAK8G,QAAQ66C,YAAc,EAE9C,OAAOn+B,GAAgBxkB,EAAQonF,EAAkB9jE,GAAUq/B,GAC7D,CAEA8E,6BAAAA,CAA8B7oD,GAC5B,GAAI6e,GAAc7e,GAChB,OAAOu6C,IAIT,MAAMkuC,EAAgBrmF,KAAKkkF,aAAelkF,KAAK6K,IAAM7K,KAAK8K,KAC1D,OAAI9K,KAAK8G,QAAQ+W,SACP7d,KAAK6K,IAAMjN,GAASyoF,GAEtBzoF,EAAQoC,KAAK8K,KAAOu7E,CAC9B,CAEAC,6BAAAA,CAA8BnjE,GAC5B,GAAI1G,GAAc0G,GAChB,OAAOg1B,IAGT,MAAMouC,EAAiBpjE,GAAYnjB,KAAKkkF,aAAelkF,KAAK6K,IAAM7K,KAAK8K,MACvE,OAAO9K,KAAK8G,QAAQ+W,QAAU7d,KAAK6K,IAAM07E,EAAiBvmF,KAAK8K,IAAMy7E,CACvE,CAEAvC,oBAAAA,CAAqBhlF,GACnB,MAAM4nD,EAAc5mD,KAAK4jF,cAAgB,GAEzC,GAAI5kF,GAAS,GAAKA,EAAQ4nD,EAAYhgD,OAAQ,CAC5C,MAAM4/E,EAAa5/B,EAAY5nD,GAC/B,OAAO8mF,GAAwB9lF,KAAK01B,aAAc12B,EAAOwnF,E,CAE7D,CAEAvC,gBAAAA,CAAiBjlF,EAAOynF,EAAoB3C,EAAkB,GAC5D,MAAM7gE,EAAQjjB,KAAKqmD,cAAcrnD,GAAS2hB,GAAUmjE,EACpD,MAAO,CACLt1E,EAAG3G,KAAKuiB,IAAInH,GAASwjE,EAAqBzmF,KAAKkmD,QAC/C7mC,EAAGxX,KAAKshB,IAAIlG,GAASwjE,EAAqBzmF,KAAKmmD,QAC/CljC,QAEJ,CAEA+jC,wBAAAA,CAAyBhoD,EAAOpB,GAC9B,OAAOoC,KAAKikF,iBAAiBjlF,EAAOgB,KAAKymD,8BAA8B7oD,GACzE,CAEA8oF,eAAAA,CAAgB1nF,GACd,OAAOgB,KAAKgnD,yBAAyBhoD,GAAS,EAAGgB,KAAK06D,eACxD,CAEAisB,qBAAAA,CAAsB3nF,GACpB,MAAM,KAAC+nB,EAAA,IAAM8F,EAAA,MAAK7F,EAAK,OAAE8F,GAAU9sB,KAAKykF,iBAAiBzlF,GACzD,MAAO,CACL+nB,OACA8F,MACA7F,QACA8F,SAEJ,CAKAgwC,cAAAA,GACE,MAAM,gBAACnrC,EAAiBrC,MAAM,SAACq3B,IAAa3mD,KAAK8G,QACjD,GAAI6qB,EAAiB,CACnB,MAAMc,EAAMzyB,KAAKyyB,IACjBA,EAAIqC,OACJrC,EAAIkE,YACJgvD,GAAe3lF,KAAMA,KAAKymD,8BAA8BzmD,KAAK4hF,WAAYj7B,EAAU3mD,KAAK4jF,aAAah9E,QACrG6rB,EAAIqE,YACJrE,EAAI+F,UAAY7G,EAChBc,EAAI0E,OACJ1E,EAAIyC,S,CAER,CAKA6nC,QAAAA,GACE,MAAMtqC,EAAMzyB,KAAKyyB,IACX6F,EAAOt4B,KAAK8G,SACZ,WAAC4/C,EAAU,KAAEp3B,EAAA,OAAMO,GAAUyI,EAC7B0iD,EAAah7E,KAAK4jF,aAAah9E,OAErC,IAAIzJ,EAAG8xB,EAAQm5B,EAmBf,GAjBI9vB,EAAKsuB,YAAY53B,SACnB02D,GAAgB1lF,KAAMg7E,GAGpB1rD,EAAKN,SACPhvB,KAAKguB,MAAM3I,QAAQ,CAAC8nB,EAAMnuC,KACxB,GAAc,IAAVA,GAA0B,IAAVA,GAAegB,KAAK8K,IAAM,EAAI,CAChDmkB,EAASjvB,KAAKymD,8BAA8BtZ,EAAKvvC,OACjD,MAAMm0B,EAAU/xB,KAAK01B,WAAW12B,GAC1B+8D,EAAczsC,EAAK6O,WAAWpM,GAC9BiqC,EAAoBnsC,EAAOsO,WAAWpM,GAE5C6zD,GAAe5lF,KAAM+7D,EAAa9sC,EAAQ+rD,EAAYhf,E,IAKxDtV,EAAW13B,QAAS,CAGtB,IAFAyD,EAAIqC,OAEC33B,EAAI69E,EAAa,EAAG79E,GAAK,EAAGA,IAAK,CACpC,MAAM4+D,EAAcrV,EAAWvoB,WAAWn+B,KAAKgkF,qBAAqB7mF,KAC9D,MAACoe,EAAA,UAAOgU,GAAawsC,EAEtBxsC,GAAchU,IAInBkX,EAAIlD,UAAYA,EAChBkD,EAAI4G,YAAc9d,EAElBkX,EAAIwqC,YAAYlB,EAAY3wB,YAC5B3Y,EAAIoyB,eAAiBkX,EAAY1wB,iBAEjCpc,EAASjvB,KAAKymD,8BAA8BnuB,EAAKza,QAAU7d,KAAK8K,IAAM9K,KAAK6K,KAC3Eu9C,EAAWpoD,KAAKikF,iBAAiB9mF,EAAG8xB,GACpCwD,EAAIkE,YACJlE,EAAIsE,OAAO/2B,KAAKkmD,QAASlmD,KAAKmmD,SAC9B1zB,EAAIuE,OAAOoxB,EAAS55C,EAAG45C,EAAS/oC,GAChCoT,EAAI4E,SACN,CAEA5E,EAAIyC,S,CAER,CAKAgoC,UAAAA,GAAc,CAKdE,UAAAA,GACE,MAAM3qC,EAAMzyB,KAAKyyB,IACX6F,EAAOt4B,KAAK8G,QACZmrD,EAAW35B,EAAKtK,MAEtB,IAAKikC,EAASjjC,QACZ,OAGF,MAAM2yB,EAAa3hD,KAAKqmD,cAAc,GACtC,IAAIp3B,EAAQe,EAEZyC,EAAIqC,OACJrC,EAAIgE,UAAUz2B,KAAKkmD,QAASlmD,KAAKmmD,SACjC1zB,EAAIpkB,OAAOszC,GACXlvB,EAAIgG,UAAY,SAChBhG,EAAIiG,aAAe,SAEnB14B,KAAKguB,MAAM3I,QAAQ,CAAC8nB,EAAMnuC,KACxB,GAAe,IAAVA,GAAegB,KAAK8K,KAAO,IAAOwtB,EAAKza,QAC1C,OAGF,MAAMk+C,EAAc9J,EAAS9zB,WAAWn+B,KAAK01B,WAAW12B,IAClDg7D,EAAW5+B,GAAO2gC,EAAY3pC,MAGpC,GAFAnD,EAASjvB,KAAKymD,8BAA8BzmD,KAAKguB,MAAMhvB,GAAOpB,OAE1Dm+D,EAAYlrC,kBAAmB,CACjC4B,EAAIL,KAAO4nC,EAASzlC,OACpBvE,EAAQyC,EAAIgC,YAAY0Y,EAAKyL,OAAO5oB,MACpCyC,EAAI+F,UAAYujC,EAAYjrC,cAE5B,MAAMlE,EAAUuO,GAAU4gC,EAAYhrC,iBACtC0B,EAAIgH,UACDzJ,EAAQ,EAAIpD,EAAQ7F,MACpBkI,EAAS+qC,EAAS1xD,KAAO,EAAIskB,EAAQC,IACtCmD,EAAQpD,EAAQoD,MAChBgqC,EAAS1xD,KAAOskB,EAAQiJ,O,CAI5B6D,GAAWjH,EAAK0a,EAAKyL,MAAO,GAAI3pB,EAAQ+qC,EAAU,CAChDz+C,MAAOwgD,EAAYxgD,MACnBse,YAAakiC,EAAYzrC,gBACzBsJ,YAAamiC,EAAY1rC,oBAI7BoC,EAAIyC,SACN,CAKAooC,SAAAA,GAAa,GACf7/D,EAAAA,GAAAA,GA1VqBsoF,GAA0B,KAEjC,iBAAetoF,EAAAA,GAAAA,GAFRsoF,GAA0B,WAO3B,CAChB/2D,SAAS,EAGT43D,SAAS,EACTx+B,SAAU,YAEV1B,WAAY,CACV13B,SAAS,EACTO,UAAW,EACX6b,WAAY,GACZC,iBAAkB,GAGpB/b,KAAM,CACJq3B,UAAU,GAGZhF,WAAY,EAGZ3zB,MAAO,CAEL6C,mBAAmB,EAEnBtT,SAAUuR,GAAMjB,WAAWC,SAG7B84B,YAAa,CACX91B,mBAAenkB,EAGfokB,gBAAiB,EAGjB/B,SAAS,EAGToD,KAAM,CACJ9pB,KAAM,IAIRiV,QAAAA,CAASq7B,GACP,OAAOA,CACT,EAGAhsB,QAAS,EAGTm3D,mBAAmB,MAErBtmF,EAAAA,GAAAA,GA5DiBsoF,GAA0B,gBA8DtB,CACrB,mBAAoB,cACpB,oBAAqB,QACrB,cAAe,WACftoF,EAAAA,GAAAA,GAlEiBsoF,GAA0B,cAoExB,CACnBr/B,WAAY,CACV36B,UAAW,UCxYjB,MAAM86D,GAAY,CAChBC,YAAa,CAACC,QAAQ,EAAMz+E,KAAM,EAAGq6E,MAAO,KAC5CqE,OAAQ,CAACD,QAAQ,EAAMz+E,KAAM,IAAMq6E,MAAO,IAC1CsE,OAAQ,CAACF,QAAQ,EAAMz+E,KAAM,IAAOq6E,MAAO,IAC3CuE,KAAM,CAACH,QAAQ,EAAMz+E,KAAM,KAASq6E,MAAO,IAC3CwE,IAAK,CAACJ,QAAQ,EAAMz+E,KAAM,MAAUq6E,MAAO,IAC3CyE,KAAM,CAACL,QAAQ,EAAOz+E,KAAM,OAAWq6E,MAAO,GAC9C0E,MAAO,CAACN,QAAQ,EAAMz+E,KAAM,OAASq6E,MAAO,IAC5C2E,QAAS,CAACP,QAAQ,EAAOz+E,KAAM,OAASq6E,MAAO,GAC/C4E,KAAM,CAACR,QAAQ,EAAMz+E,KAAM,SAMvBk/E,GAA6C9pF,OAAOgJ,KAAKmgF,IAM/D,SAASY,GAAO/7E,EAAGC,GACjB,OAAOD,EAAIC,CACb,CAOA,SAAS00B,GAAM/M,EAAOxY,GACpB,GAAI2B,GAAc3B,GAChB,OAAO,KAGT,MAAM4sE,EAAUp0D,EAAMq0D,UAChB,OAACC,EAAA,MAAQ9/E,EAAA,WAAO+/E,GAAcv0D,EAAMw0D,WAC1C,IAAIlqF,EAAQkd,EAaZ,MAXsB,oBAAX8sE,IACThqF,EAAQgqF,EAAOhqF,IAIZif,GAASjf,KACZA,EAA0B,kBAAXgqF,EACXF,EAAQrnD,MAAMziC,EAAOgqF,GACrBF,EAAQrnD,MAAMziC,IAGN,OAAVA,EACK,MAGLkK,IACFlK,EAAkB,SAAVkK,IAAqBia,GAAS8lE,KAA8B,IAAfA,EAEjDH,EAAQhgC,QAAQ9pD,EAAOkK,GADvB4/E,EAAQhgC,QAAQ9pD,EAAO,UAAWiqF,KAIhCjqF,EACV,CAUA,SAASmqF,GAA0BC,EAASl9E,EAAKD,EAAKo9E,GACpD,MAAMhqE,EAAOupE,GAAM5gF,OAEnB,IAAK,IAAIzJ,EAAIqqF,GAAM9oE,QAAQspE,GAAU7qF,EAAI8gB,EAAO,IAAK9gB,EAAG,CACtD,MAAM+qF,EAAWrB,GAAUW,GAAMrqF,IAC3B+wC,EAASg6C,EAASvF,MAAQuF,EAASvF,MAAQplF,OAAO4qF,iBAExD,GAAID,EAASnB,QAAUl/E,KAAKyrD,MAAMzoD,EAAMC,IAAQojC,EAASg6C,EAAS5/E,QAAU2/E,EAC1E,OAAOT,GAAMrqF,EAEjB,CAEA,OAAOqqF,GAAMvpE,EAAO,EACtB,CAWA,SAASmqE,GAA2B90D,EAAO+kC,EAAU2vB,EAASl9E,EAAKD,GACjE,IAAK,IAAI1N,EAAIqqF,GAAM5gF,OAAS,EAAGzJ,GAAKqqF,GAAM9oE,QAAQspE,GAAU7qF,IAAK,CAC/D,MAAM6jF,EAAOwG,GAAMrqF,GACnB,GAAI0pF,GAAU7F,GAAM+F,QAAUzzD,EAAMq0D,SAASlgC,KAAK58C,EAAKC,EAAKk2E,IAAS3oB,EAAW,EAC9E,OAAO2oB,CAEX,CAEA,OAAOwG,GAAMQ,EAAUR,GAAM9oE,QAAQspE,GAAW,EAClD,CAMA,SAASK,GAAmBrH,GAC1B,IAAK,IAAI7jF,EAAIqqF,GAAM9oE,QAAQsiE,GAAQ,EAAG/iE,EAAOupE,GAAM5gF,OAAQzJ,EAAI8gB,IAAQ9gB,EACrE,GAAI0pF,GAAUW,GAAMrqF,IAAI4pF,OACtB,OAAOS,GAAMrqF,EAGnB,CAOA,SAASmrF,GAAQt6D,EAAOu6D,EAAMC,GAC5B,GAAKA,GAEE,GAAIA,EAAW5hF,OAAQ,CAC5B,MAAM,GAAC6d,EAAE,GAAED,GAAMJ,GAAQokE,EAAYD,GAC/BE,EAAYD,EAAW/jE,IAAO8jE,EAAOC,EAAW/jE,GAAM+jE,EAAWhkE,GACvEwJ,EAAMy6D,IAAa,C,OAJnBz6D,EAAMu6D,IAAQ,CAMlB,CASA,SAASG,GAAcp1D,EAAOtF,EAAOrgB,EAAKg7E,GACxC,MAAMjB,EAAUp0D,EAAMq0D,SAChBj1B,GAASg1B,EAAQhgC,QAAQ15B,EAAM,GAAGpwB,MAAO+qF,GACzChkE,EAAOqJ,EAAMA,EAAMpnB,OAAS,GAAGhJ,MACrC,IAAI+yB,EAAO3xB,EAEX,IAAK2xB,EAAQ+hC,EAAO/hC,GAAShM,EAAMgM,GAAS+2D,EAAQ1rD,IAAIrL,EAAO,EAAGg4D,GAChE3pF,EAAQ2O,EAAIgjB,GACR3xB,GAAS,IACXgvB,EAAMhvB,GAAO2xB,OAAQ,GAGzB,OAAO3C,CACT,CAQA,SAAS46D,GAAoBt1D,EAAOvO,EAAQ4jE,GAC1C,MAAM36D,EAAQ,GAERrgB,EAAM,CAAC,EACPsQ,EAAO8G,EAAOne,OACpB,IAAIzJ,EAAGS,EAEP,IAAKT,EAAI,EAAGA,EAAI8gB,IAAQ9gB,EACtBS,EAAQmnB,EAAO5nB,GACfwQ,EAAI/P,GAAST,EAEb6wB,EAAMtO,KAAK,CACT9hB,QACA+yB,OAAO,IAMX,OAAiB,IAAT1S,GAAe0qE,EAAqBD,GAAcp1D,EAAOtF,EAAOrgB,EAAKg7E,GAAzC36D,CACtC,CAEe,MAAM66D,WAAkB/zB,GAgDrCj4D,WAAAA,CAAY6C,GACV++C,MAAM/+C,GAGNM,KAAK1B,OAAS,CACZwB,KAAM,GACN43C,OAAQ,GACRlH,IAAK,IAIPxwC,KAAK8oF,MAAQ,MAEb9oF,KAAK+oF,gBAAap8E,EAClB3M,KAAKgpF,SAAW,CAAC,EACjBhpF,KAAKipF,aAAc,EACnBjpF,KAAK8nF,gBAAan7E,CACpB,CAEA46C,IAAAA,CAAK6f,EAAW9uC,EAAO,IACrB,MAAMiwD,EAAOnhB,EAAUmhB,OAASnhB,EAAUmhB,KAAO,CAAC,GAE5Cb,EAAU1nF,KAAK2nF,SAAW,IAAI//B,GAASC,MAAMuf,EAAUxf,SAASvb,MAEtEq7C,EAAQngC,KAAKjvB,GAMbrZ,GAAQspE,EAAKW,eAAgBxB,EAAQlgC,WAErCxnD,KAAK8nF,WAAa,CAChBF,OAAQW,EAAKX,OACb9/E,MAAOygF,EAAKzgF,MACZ+/E,WAAYU,EAAKV,YAGnBppC,MAAM8I,KAAK6f,GAEXpnE,KAAKipF,YAAc3wD,EAAK6wD,UAC1B,CAOA9oD,KAAAA,CAAMoT,EAAKz0C,GACT,YAAY2N,IAAR8mC,EACK,KAEFpT,GAAMrgC,KAAMyzC,EACrB,CAEAga,YAAAA,GACEhP,MAAMgP,eACNztD,KAAK1B,OAAS,CACZwB,KAAM,GACN43C,OAAQ,GACRlH,IAAK,GAET,CAEAumB,mBAAAA,GACE,MAAMjwD,EAAU9G,KAAK8G,QACf4gF,EAAU1nF,KAAK2nF,SACf3G,EAAOl6E,EAAQyhF,KAAKvH,MAAQ,MAElC,IAAI,IAACl2E,EAAA,IAAKD,EAAA,WAAKkd,EAAA,WAAYC,GAAchoB,KAAKioB,gBAK9C,SAASmhE,EAAaj6D,GACfpH,GAAe/F,MAAMmN,EAAOrkB,OAC/BA,EAAMjD,KAAKiD,IAAIA,EAAKqkB,EAAOrkB,MAExBkd,GAAehG,MAAMmN,EAAOtkB,OAC/BA,EAAMhD,KAAKgD,IAAIA,EAAKskB,EAAOtkB,KAE/B,CAGKkd,GAAeC,IAElBohE,EAAappF,KAAKqpF,mBAIK,UAAnBviF,EAAQqoB,QAA+C,WAAzBroB,EAAQknB,MAAM3P,QAC9C+qE,EAAappF,KAAKo4C,WAAU,KAIhCttC,EAAM+R,GAAS/R,KAASkX,MAAMlX,GAAOA,GAAO48E,EAAQhgC,QAAQ9a,KAAKC,MAAOm0C,GACxEn2E,EAAMgS,GAAShS,KAASmX,MAAMnX,GAAOA,GAAO68E,EAAQ//B,MAAM/a,KAAKC,MAAOm0C,GAAQ,EAG9EhhF,KAAK8K,IAAMjD,KAAKiD,IAAIA,EAAKD,EAAM,GAC/B7K,KAAK6K,IAAMhD,KAAKgD,IAAIC,EAAM,EAAGD,EAC/B,CAKAw+E,eAAAA,GACE,MAAM/pD,EAAMt/B,KAAKspF,qBACjB,IAAIx+E,EAAMvN,OAAOkjB,kBACb5V,EAAMtN,OAAOy0C,kBAMjB,OAJI1S,EAAI14B,SACNkE,EAAMw0B,EAAI,GACVz0B,EAAMy0B,EAAIA,EAAI14B,OAAS,IAElB,CAACkE,MAAKD,MACf,CAKAqsD,UAAAA,GACE,MAAMpwD,EAAU9G,KAAK8G,QACfyiF,EAAWziF,EAAQyhF,KACnBt2B,EAAWnrD,EAAQknB,MACnBw6D,EAAiC,WAApBv2B,EAAS5zC,OAAsBre,KAAKspF,qBAAuBtpF,KAAKwpF,YAE5D,UAAnB1iF,EAAQqoB,QAAsBq5D,EAAW5hF,SAC3C5G,KAAK8K,IAAM9K,KAAK21D,UAAY6yB,EAAW,GACvCxoF,KAAK6K,IAAM7K,KAAK01D,UAAY8yB,EAAWA,EAAW5hF,OAAS,IAG7D,MAAMkE,EAAM9K,KAAK8K,IACXD,EAAM7K,KAAK6K,IAEXmjB,EAAQlJ,GAAe0jE,EAAY19E,EAAKD,GAgB9C,OAXA7K,KAAK8oF,MAAQS,EAASvI,OAAS/uB,EAAS1hC,SACpCw3D,GAA0BwB,EAASvB,QAAShoF,KAAK8K,IAAK9K,KAAK6K,IAAK7K,KAAKypF,kBAAkB3+E,IACvFs9E,GAA2BpoF,KAAMguB,EAAMpnB,OAAQ2iF,EAASvB,QAAShoF,KAAK8K,IAAK9K,KAAK6K,MACpF7K,KAAK+oF,WAAc92B,EAASthC,MAAM4hC,SAA0B,SAAfvyD,KAAK8oF,MAC9CT,GAAmBroF,KAAK8oF,YADyCn8E,EAErE3M,KAAK0pF,YAAYlB,GAEb1hF,EAAQ+W,SACVmQ,EAAMnQ,UAGD+qE,GAAoB5oF,KAAMguB,EAAOhuB,KAAK+oF,WAC/C,CAEAtxB,aAAAA,GAGMz3D,KAAK8G,QAAQ6iF,qBACf3pF,KAAK0pF,YAAY1pF,KAAKguB,MAAMrgB,IAAIw/B,IAASA,EAAKvvC,OAElD,CAUA8rF,WAAAA,CAAYlB,EAAa,IACvB,IAEI91B,EAAO/tC,EAFPjB,EAAQ,EACRC,EAAM,EAGN3jB,KAAK8G,QAAQmoB,QAAUu5D,EAAW5hF,SACpC8rD,EAAQ1yD,KAAK4pF,mBAAmBpB,EAAW,IAEzC9kE,EADwB,IAAtB8kE,EAAW5hF,OACL,EAAI8rD,GAEH1yD,KAAK4pF,mBAAmBpB,EAAW,IAAM91B,GAAS,EAE7D/tC,EAAO3kB,KAAK4pF,mBAAmBpB,EAAWA,EAAW5hF,OAAS,IAE5D+c,EADwB,IAAtB6kE,EAAW5hF,OACP+d,GAECA,EAAO3kB,KAAK4pF,mBAAmBpB,EAAWA,EAAW5hF,OAAS,KAAO,GAGhF,MAAMi1D,EAAQ2sB,EAAW5hF,OAAS,EAAI,GAAM,IAC5C8c,EAAQO,GAAYP,EAAO,EAAGm4C,GAC9Bl4C,EAAMM,GAAYN,EAAK,EAAGk4C,GAE1B77D,KAAKgpF,SAAW,CAACtlE,QAAOC,MAAKuqB,OAAQ,GAAKxqB,EAAQ,EAAIC,GACxD,CASA6lE,SAAAA,GACE,MAAM9B,EAAU1nF,KAAK2nF,SACf78E,EAAM9K,KAAK8K,IACXD,EAAM7K,KAAK6K,IACX/D,EAAU9G,KAAK8G,QACfyiF,EAAWziF,EAAQyhF,KAEnB73D,EAAQ64D,EAASvI,MAAQ+G,GAA0BwB,EAASvB,QAASl9E,EAAKD,EAAK7K,KAAKypF,kBAAkB3+E,IACtGq3E,EAAWllE,GAAenW,EAAQknB,MAAMm0D,SAAU,GAClD0H,EAAoB,SAAVn5D,GAAmB64D,EAAS1B,WACtCiC,EAAa/nE,GAAS8nE,KAAwB,IAAZA,EAClC77D,EAAQ,CAAC,EACf,IACIu6D,EAAMvhF,EADN0rD,EAAQ5nD,EAYZ,GARIg/E,IACFp3B,GAASg1B,EAAQhgC,QAAQgL,EAAO,UAAWm3B,IAI7Cn3B,GAASg1B,EAAQhgC,QAAQgL,EAAOo3B,EAAa,MAAQp5D,GAGjDg3D,EAAQjgC,KAAK58C,EAAKC,EAAK4lB,GAAS,IAASyxD,EAC3C,MAAM,IAAIjjD,MAAMp0B,EAAM,QAAUD,EAAM,uCAAyCs3E,EAAW,IAAMzxD,GAGlG,MAAM83D,EAAsC,SAAzB1hF,EAAQknB,MAAM3P,QAAqBre,KAAK+pF,oBAC3D,IAAKxB,EAAO71B,EAAO1rD,EAAQ,EAAGuhF,EAAO19E,EAAK09E,GAAQb,EAAQ1rD,IAAIusD,EAAMpG,EAAUzxD,GAAQ1pB,IACpFshF,GAAQt6D,EAAOu6D,EAAMC,GAQvB,OALID,IAAS19E,GAA0B,UAAnB/D,EAAQqoB,QAAgC,IAAVnoB,GAChDshF,GAAQt6D,EAAOu6D,EAAMC,GAIhB9qF,OAAOgJ,KAAKsnB,GAAOpM,KAAK6lE,IAAQ95E,IAAIa,IAAMA,EACnD,CAMAqqC,gBAAAA,CAAiBj7C,GACf,MAAM8pF,EAAU1nF,KAAK2nF,SACf4B,EAAWvpF,KAAK8G,QAAQyhF,KAE9B,OAAIgB,EAASS,cACJtC,EAAQ95D,OAAOhwB,EAAO2rF,EAASS,eAEjCtC,EAAQ95D,OAAOhwB,EAAO2rF,EAASL,eAAee,SACvD,CAOAr8D,MAAAA,CAAOhwB,EAAOgwB,GACZ,MAAM9mB,EAAU9G,KAAK8G,QACf0gD,EAAU1gD,EAAQyhF,KAAKW,eACvBlI,EAAOhhF,KAAK8oF,MACZoB,EAAMt8D,GAAU45B,EAAQw5B,GAC9B,OAAOhhF,KAAK2nF,SAAS/5D,OAAOhwB,EAAOssF,EACrC,CAWAC,mBAAAA,CAAoB5B,EAAMvpF,EAAOgvB,EAAOJ,GACtC,MAAM9mB,EAAU9G,KAAK8G,QACfwmB,EAAYxmB,EAAQknB,MAAMzQ,SAEhC,GAAI+P,EACF,OAAO/P,GAAK+P,EAAW,CAACi7D,EAAMvpF,EAAOgvB,GAAQhuB,MAG/C,MAAMwnD,EAAU1gD,EAAQyhF,KAAKW,eACvBlI,EAAOhhF,KAAK8oF,MACZH,EAAY3oF,KAAK+oF,WACjBqB,EAAcpJ,GAAQx5B,EAAQw5B,GAC9BqJ,EAAc1B,GAAanhC,EAAQmhC,GACnCx7C,EAAOnf,EAAMhvB,GACb2xB,EAAQg4D,GAAa0B,GAAel9C,GAAQA,EAAKxc,MAEvD,OAAO3wB,KAAK2nF,SAAS/5D,OAAO26D,EAAM36D,IAAW+C,EAAQ05D,EAAcD,GACrE,CAKAjyB,kBAAAA,CAAmBnqC,GACjB,IAAI7wB,EAAG8gB,EAAMkvB,EAEb,IAAKhwC,EAAI,EAAG8gB,EAAO+P,EAAMpnB,OAAQzJ,EAAI8gB,IAAQ9gB,EAC3CgwC,EAAOnf,EAAM7wB,GACbgwC,EAAKyL,MAAQ54C,KAAKmqF,oBAAoBh9C,EAAKvvC,MAAOT,EAAG6wB,EAEzD,CAMA47D,kBAAAA,CAAmBhsF,GACjB,OAAiB,OAAVA,EAAiBu6C,KAAOv6C,EAAQoC,KAAK8K,MAAQ9K,KAAK6K,IAAM7K,KAAK8K,IACtE,CAMAod,gBAAAA,CAAiBtqB,GACf,MAAM0sF,EAAUtqF,KAAKgpF,SACf1kD,EAAMtkC,KAAK4pF,mBAAmBhsF,GACpC,OAAOoC,KAAKugD,oBAAoB+pC,EAAQ5mE,MAAQ4gB,GAAOgmD,EAAQp8C,OACjE,CAMAuS,gBAAAA,CAAiBprB,GACf,MAAMi1D,EAAUtqF,KAAKgpF,SACf1kD,EAAMtkC,KAAKy6D,mBAAmBplC,GAASi1D,EAAQp8C,OAASo8C,EAAQ3mE,IACtE,OAAO3jB,KAAK8K,IAAMw5B,GAAOtkC,KAAK6K,IAAM7K,KAAK8K,IAC3C,CAOAy/E,aAAAA,CAAc3xC,GACZ,MAAM4xC,EAAYxqF,KAAK8G,QAAQknB,MACzBy8D,EAAiBzqF,KAAKyyB,IAAIgC,YAAYmkB,GAAO5oB,MAC7C/M,EAAQX,GAAUtiB,KAAK09C,eAAiB8sC,EAAUr6D,YAAcq6D,EAAUt6D,aAC1Ew6D,EAAc7iF,KAAKuiB,IAAInH,GACvB0nE,EAAc9iF,KAAKshB,IAAIlG,GACvB2nE,EAAe5qF,KAAKq6D,wBAAwB,GAAG/xD,KAErD,MAAO,CACL6E,EAAIs9E,EAAiBC,EAAgBE,EAAeD,EACpD//E,EAAI6/E,EAAiBE,EAAgBC,EAAeF,EAExD,CAOAjB,iBAAAA,CAAkBoB,GAChB,MAAMtB,EAAWvpF,KAAK8G,QAAQyhF,KACxBW,EAAiBK,EAASL,eAG1Bt7D,EAASs7D,EAAeK,EAASvI,OAASkI,EAAepC,YACzDgE,EAAe9qF,KAAKmqF,oBAAoBU,EAAa,EAAGjC,GAAoB5oF,KAAM,CAAC6qF,GAAc7qF,KAAK+oF,YAAan7D,GACnHtlB,EAAOtI,KAAKuqF,cAAcO,GAG1B7C,EAAWpgF,KAAKyZ,MAAMthB,KAAK09C,eAAiB19C,KAAKgwB,MAAQ1nB,EAAK6E,EAAInN,KAAK61B,OAASvtB,EAAKsC,GAAK,EAChG,OAAOq9E,EAAW,EAAIA,EAAW,CACnC,CAKA8B,iBAAAA,GACE,IACI5sF,EAAG8gB,EADHuqE,EAAaxoF,KAAK1B,OAAOwB,MAAQ,GAGrC,GAAI0oF,EAAW5hF,OACb,OAAO4hF,EAGT,MAAMryB,EAAQn2D,KAAKwyC,0BAEnB,GAAIxyC,KAAKipF,aAAe9yB,EAAMvvD,OAC5B,OAAQ5G,KAAK1B,OAAOwB,KAAOq2D,EAAM,GAAGzjB,WAAW+F,mBAAmBz4C,MAGpE,IAAK7C,EAAI,EAAG8gB,EAAOk4C,EAAMvvD,OAAQzJ,EAAI8gB,IAAQ9gB,EAC3CqrF,EAAaA,EAAW5sC,OAAOua,EAAMh5D,GAAGu1C,WAAW+F,mBAAmBz4C,OAGxE,OAAQA,KAAK1B,OAAOwB,KAAOE,KAAK0oC,UAAU8/C,EAC5C,CAKAc,kBAAAA,GACE,MAAMd,EAAaxoF,KAAK1B,OAAOo5C,QAAU,GACzC,IAAIv6C,EAAG8gB,EAEP,GAAIuqE,EAAW5hF,OACb,OAAO4hF,EAGT,MAAM9wC,EAAS13C,KAAK23C,YACpB,IAAKx6C,EAAI,EAAG8gB,EAAOy5B,EAAO9wC,OAAQzJ,EAAI8gB,IAAQ9gB,EAC5CqrF,EAAW9oE,KAAK2gB,GAAMrgC,KAAM03C,EAAOv6C,KAGrC,OAAQ6C,KAAK1B,OAAOo5C,OAAS13C,KAAKipF,YAAcT,EAAaxoF,KAAK0oC,UAAU8/C,EAC9E,CAMA9/C,SAAAA,CAAU3jB,GAER,OAAOc,GAAad,EAAOnD,KAAK6lE,IAClC,ECtpBF,SAASrtE,GAAYiK,EAAOrI,EAAK6B,GAC/B,IAEIktE,EAAYC,EAAYC,EAAYC,EAFpCzmE,EAAK,EACLD,EAAKH,EAAMzd,OAAS,EAEpBiX,GACE7B,GAAOqI,EAAMI,GAAI6f,KAAOtoB,GAAOqI,EAAMG,GAAI8f,OACzC7f,KAAID,MAAME,GAAaL,EAAO,MAAOrI,MAEvCsoB,IAAKymD,EAAYxC,KAAM0C,GAAc5mE,EAAMI,MAC3C6f,IAAK0mD,EAAYzC,KAAM2C,GAAc7mE,EAAMG,MAEzCxI,GAAOqI,EAAMI,GAAI8jE,MAAQvsE,GAAOqI,EAAMG,GAAI+jE,QAC1C9jE,KAAID,MAAME,GAAaL,EAAO,OAAQrI,MAExCusE,KAAMwC,EAAYzmD,IAAK2mD,GAAc5mE,EAAMI,MAC3C8jE,KAAMyC,EAAY1mD,IAAK4mD,GAAc7mE,EAAMG,KAG/C,MAAM2mE,EAAOH,EAAaD,EAC1B,OAAOI,EAAOF,GAAcC,EAAaD,IAAejvE,EAAM+uE,GAAcI,EAAOF,CACrF,EDmoBAxtF,EAAAA,GAAAA,GA5dqBorF,GAAkB,KAEzB,SAAOprF,EAAAA,GAAAA,GAFAorF,GAAkB,WAOnB,CAQhB15D,OAAQ,OAERy4B,SAAU,CAAC,EACX2gC,KAAM,CACJX,QAAQ,EACR5G,MAAM,EACNl5E,OAAO,EACP+/E,YAAY,EACZG,QAAS,cACTkB,eAAgB,CAAC,GAEnBl7D,MAAO,CASL3P,OAAQ,OAERd,UAAU,EAEVoT,MAAO,CACL4hC,SAAS,MC7MjB,MAAM64B,WAAwBvC,GAY5BhsF,WAAAA,CAAY6C,GACV++C,MAAM/+C,GAGNM,KAAKqrF,OAAS,GAEdrrF,KAAKsrF,aAAU3+E,EAEf3M,KAAKurF,iBAAc5+E,CACrB,CAKA+8E,WAAAA,GACE,MAAMlB,EAAaxoF,KAAKwrF,yBAClBnnE,EAAQrkB,KAAKqrF,OAASrrF,KAAKyrF,iBAAiBjD,GAClDxoF,KAAKsrF,QAAUlxE,GAAYiK,EAAOrkB,KAAK8K,KACvC9K,KAAKurF,YAAcnxE,GAAYiK,EAAOrkB,KAAK6K,KAAO7K,KAAKsrF,QACvD7sC,MAAMirC,YAAYlB,EACpB,CAaAiD,gBAAAA,CAAiBjD,GACf,MAAM,IAAC19E,EAAG,IAAED,GAAO7K,KACb8lB,EAAQ,GACRzB,EAAQ,GACd,IAAIlnB,EAAG8gB,EAAM8kB,EAAM+Y,EAAMhb,EAEzB,IAAK3jC,EAAI,EAAG8gB,EAAOuqE,EAAW5hF,OAAQzJ,EAAI8gB,IAAQ9gB,EAChD2+C,EAAO0sC,EAAWrrF,GACd2+C,GAAQhxC,GAAOgxC,GAAQjxC,GACzBib,EAAMpG,KAAKo8B,GAIf,GAAIh2B,EAAMlf,OAAS,EAEjB,MAAO,CACL,CAAC2hF,KAAMz9E,EAAKw5B,IAAK,GACjB,CAACikD,KAAM19E,EAAKy5B,IAAK,IAIrB,IAAKnnC,EAAI,EAAG8gB,EAAO6H,EAAMlf,OAAQzJ,EAAI8gB,IAAQ9gB,EAC3C2jC,EAAOhb,EAAM3oB,EAAI,GACjB4lC,EAAOjd,EAAM3oB,EAAI,GACjB2+C,EAAOh2B,EAAM3oB,GAGT0K,KAAKC,OAAOg5B,EAAOiC,GAAQ,KAAO+Y,GACpCz3B,EAAM3E,KAAK,CAAC6oE,KAAMzsC,EAAMxX,IAAKnnC,GAAK8gB,EAAO,KAG7C,OAAOoG,CACT,CAQAmlE,SAAAA,GACE,MAAM1+E,EAAM9K,KAAK8K,IACXD,EAAM7K,KAAK6K,IACjB,IAAI29E,EAAa/pC,MAAMsrC,oBAOvB,OANKvB,EAAW35D,SAAS/jB,IAAS09E,EAAW5hF,QAC3C4hF,EAAW5iE,OAAO,EAAG,EAAG9a,GAErB09E,EAAW35D,SAAShkB,IAA8B,IAAtB29E,EAAW5hF,QAC1C4hF,EAAW9oE,KAAK7U,GAEX29E,EAAW5mE,KAAK,CAAClW,EAAGC,IAAMD,EAAIC,EACvC,CAOA6/E,sBAAAA,GACE,IAAIhD,EAAaxoF,KAAK1B,OAAOkyC,KAAO,GAEpC,GAAIg4C,EAAW5hF,OACb,OAAO4hF,EAGT,MAAM1oF,EAAOE,KAAK+pF,oBACZnxC,EAAQ54C,KAAKspF,qBAUnB,OANEd,EAHE1oF,EAAK8G,QAAUgyC,EAAMhyC,OAGV5G,KAAK0oC,UAAU5oC,EAAK87C,OAAOhD,IAE3B94C,EAAK8G,OAAS9G,EAAO84C,EAEpC4vC,EAAaxoF,KAAK1B,OAAOkyC,IAAMg4C,EAExBA,CACT,CAMAoB,kBAAAA,CAAmBhsF,GACjB,OAAQwc,GAAYpa,KAAKqrF,OAAQztF,GAASoC,KAAKsrF,SAAWtrF,KAAKurF,WACjE,CAMA9qC,gBAAAA,CAAiBprB,GACf,MAAMi1D,EAAUtqF,KAAKgpF,SACfxuB,EAAUx6D,KAAKy6D,mBAAmBplC,GAASi1D,EAAQp8C,OAASo8C,EAAQ3mE,IAC1E,OAAOvJ,GAAYpa,KAAKqrF,OAAQ7wB,EAAUx6D,KAAKurF,YAAcvrF,KAAKsrF,SAAS,EAC7E,GACF7tF,EAAAA,GAAAA,GA7IM2tF,GAAwB,KAEhB,eAAa3tF,EAAAA,GAAAA,GAFrB2tF,GAAwB,WAOVvC,GAAUl9D,U,cC/BvB,MAAM+/D,GAAc,CACzB5rF,KAAM,CACJH,KAAMjC,OACNiuF,UAAU,GAEZ7kF,QAAS,CACPnH,KAAMjC,OACNkC,QAASA,KAAA,CAAQ,IAEnBwzB,QAAS,CACPzzB,KAAM8N,MACN7N,QAASA,IAAM,IAEjBgsF,aAAc,CACZjsF,KAAMrC,OACNsC,QAAS,SAEXisF,WAAY,CACVlsF,KAAMrC,OACNsC,aAAS+M,IAIAm/E,GAAY,CACvBC,UAAW,CACTpsF,KAAMrC,QAER0uF,gBAAiB,CACfrsF,KAAMrC,SAIG2uF,GAAQ,CACnBtsF,KAAM,CACJA,KAAMrC,OACNquF,UAAU,GAEZO,aAAc,CACZvsF,KAAMpC,OACNqC,QAAS,MAER8rF,MACAI,ICzCQK,GACI,MAAf1lF,EAAAA,GAAQ,GACJ,CAA6B2lF,EAAc1sF,IACzChC,OAAOkd,OAAOwxE,EAAW,CAAEC,MAAO3sF,IACpC,CAA6B0sF,EAAc1sF,IACzChC,OAAOkd,OAAOwxE,EAAW1sF,GAE1B,SAAS4sF,GAAgBjxE,GAC9B,OAAOkxE,EAAAA,GAAAA,IAAQlxE,IAAOmxE,EAAAA,GAAAA,IAAMnxE,GAAOA,CACrC,CAEO,SAASoxE,GAA6BpxE,GAAQ,IAAAxR,EAAAsxC,UAAAv0C,OAAA,YAAAu0C,UAAA,GAAAA,UAAA,GAAM9/B,EACzD,OAAOkxE,EAAAA,GAAAA,IAAQ1iF,GAAO,IAAIkzB,MAAM1hB,EAAK,IAAMA,CAC7C,CAEO,SAASqxE,GAIdz+D,EAAoC0+D,GACpC,MAAM7lF,EAAUmnB,EAAMnnB,QAElBA,GAAW6lF,GACbjvF,OAAOkd,OAAO9T,EAAS6lF,EAE3B,CAEO,SAASC,GAKdC,EACAC,GAEAD,EAAYn1C,OAASo1C,CACvB,CAEO,SAASC,GAKdF,EACAG,EACApB,GAEA,MAAMqB,EAA8C,GAEpDJ,EAAYh7D,SAAWm7D,EAAar/E,IACjCu/E,IAEC,MAAMC,EAAiBN,EAAYh7D,SAAS2tB,KACzC33B,GACCA,EAAQ+jE,KAAkBsB,EAAYtB,IAI1C,OACGuB,GACAD,EAAYptF,OACbmtF,EAAcp+D,SAASs+D,IAKzBF,EAAcvtE,KAAKytE,GAEnBzvF,OAAOkd,OAAOuyE,EAAgBD,GAEvBC,GAPE,IAAKD,IAUpB,CAEO,SAASE,GAIdttF,EAAuC8rF,GACvC,MAAMyB,EAA4C,CAChD31C,OAAQ,GACR7lB,SAAU,IAMZ,OAHA+6D,GAAUS,EAAUvtF,EAAK43C,QACzBq1C,GAAYM,EAAUvtF,EAAK+xB,SAAU+5D,GAE9ByB,CACT,CC3EO,MAAM7nB,IAAQ8nB,EAAAA,EAAAA,IAAgB,CACnC5tF,MAAOusF,GACPsB,KAAAA,CAAM7tF,EAAO8tF,GAAA,WAAEC,EAAM,MAAEC,GAAVF,EACX,MAAMG,GAAYzkF,EAAAA,GAAAA,IAA8B,MAC1C0kF,GAAWC,EAAAA,GAAAA,IAA2B,MAE5CJ,EAAO,CAAEx/D,MAAO2/D,IAEhB,MAAME,EAAcA,KAClB,IAAKH,EAAU/vF,MAAO,OAEtB,MAAM,KAAE+B,EAAI,KAAEG,EAAI,QAAEgH,EAAO,QAAEssB,EAAO,aAAEw4D,GAAiBlsF,EACjDquF,EAAaX,GAAUttF,EAAM8rF,GAC7BoC,EAAcvB,GAAWsB,EAAYjuF,GAE3C8tF,EAAShwF,MAAQ,IAAIqwF,GAAQN,EAAU/vF,MAAO,CAC5C+B,OACAG,KAAMkuF,EACNlnF,QAAS,IAAKA,GACdssB,aAIE86D,EAAeA,KACnB,MAAMjgE,GAAQu+D,EAAAA,GAAAA,IAAMoB,EAAShwF,OAEzBqwB,IACEvuB,EAAMwsF,aAAe,EACvBxlE,WAAW,KACTuH,EAAM87C,UACN6jB,EAAShwF,MAAQ,MAChB8B,EAAMwsF,eAETj+D,EAAM87C,UACN6jB,EAAShwF,MAAQ,QAKjBoxC,EAAU/gB,IACdA,EAAM+gB,OAAOtvC,EAAMmsF,aAyDrB,OAtDAsC,EAAAA,EAAAA,IAAUL,IAEVM,EAAAA,EAAAA,IAAYF,IAEZG,EAAAA,EAAAA,IACE,CAAC,IAAM3uF,EAAMoH,QAAS,IAAMpH,EAAMI,MAClC,CAGK0tF,EAAAc,KAFH,IAACC,EAAkBC,GACnBhB,GAACiB,EAAkBC,GAAcJ,EAEjC,MAAMrgE,GAAQu+D,EAAAA,GAAAA,IAAMoB,EAAShwF,OAE7B,IAAKqwB,EACH,OAGF,IAAI0gE,GAAe,EAEnB,GAAIJ,EAAkB,CACpB,MAAM5B,EAAcL,GAAaiC,GAC3BK,EAActC,GAAamC,GAE7B9B,GAAeA,IAAgBiC,IACjClC,GAAWz+D,EAAO0+D,GAClBgC,GAAe,E,CAInB,GAAIH,EAAe,CACjB,MAAM1B,EAAaR,GAAakC,EAAc92C,QACxCm3C,EAAavC,GAAaoC,EAAch3C,QACxCs1C,EAAeV,GAAakC,EAAc38D,UAC1Ci9D,EAAexC,GAAaoC,EAAc78D,UAE5Ci7D,IAAe+B,IACjBjC,GAAU3+D,EAAMuhB,OAAO1vC,KAAMgtF,GAC7B6B,GAAe,GAGb3B,GAAgBA,IAAiB8B,IACnC/B,GAAY9+D,EAAMuhB,OAAO1vC,KAAMktF,EAActtF,EAAMksF,cACnD+C,GAAe,E,CAIfA,IACFI,EAAAA,EAAAA,IAAS,KACP//C,EAAO/gB,MAIb,CAAE+gE,MAAM,IAGH,KACEpkF,EAAAA,EAAAA,GACL,SACA,CACEqkF,KAAM,MACN,aAAcvvF,EAAMqsF,UACpB,mBAAoBrsF,EAAMssF,gBAC1B9iF,IAAKykF,GAEP,EAAC/iF,EAAAA,EAAAA,GAAE,IAAK,CAAC,EAAG,CAAC8iF,EAAM9tF,QAAU8tF,EAAM9tF,UAAY,MAGrD,IClHK,SAASsvF,GAKdvvF,EACAwvF,GAIA,OAFAlB,GAAQlwB,SAASoxB,IAEV7B,EAAAA,EAAAA,IAAgB,CACrB5tF,MAAOgsF,GACP6B,KAAAA,CAAM7tF,EAAO8tF,G,IAAA,OAAEC,GAAFD,EACX,MAAMtkF,GAAM2kF,EAAAA,GAAAA,IAA2B,MACjCuB,EAAgBxB,IACpB1kF,EAAItL,MAAQgwF,GAAU3/D,OAKxB,OAFAw/D,EAAO,CAAEx/D,MAAO/kB,IAET,KACE0B,EAAAA,EAAAA,GACL46D,GACA2mB,GACE,CACEjjF,IAAKkmF,GAEP,CACEzvF,UACGD,IAKb,GAEJ,C,MAWa2vF,GAA2BH,GACtC,WACA3sC,I,wFCvDK,MAAM+sC,WAA4BpwD,MACvCriC,WAAAA,CAAYuL,EAASmnF,EAAM7mF,GAAc,EAAOD,EAAa,IAC3Dg2C,MAAMr2C,GACNpI,KAAKP,KAAO,sBACZO,KAAKuvF,KAAOA,EACZvvF,KAAK0I,YAAcA,EACnB1I,KAAKyI,WAAaA,CACpB,EAOF,MAAM+mF,GAAiB,CACrB,IAAK,IAAM,IAAIF,GACb,aACA,eACA,EACA,cAEF,IAAK,IAAM,IAAIA,GACb,aACA,aACA,EACA,cAEF,IAAMG,GAAY,IAAIH,GACpB,WAAWG,IACX,gBACA,EACA,cAEF,IAAK,IAAM,IAAIH,GACb,UACA,gBACA,EACA,sBAEFI,QAASA,IAAM,IAAIJ,GACjB,SACA,iBACA,EACA,cAEFK,MAAOA,IAAM,IAAIL,GACf,QACA,WACA,EACA,KAUJ,SAASM,GAAYttB,EAAOmtB,EAAU,IAEpC,GAAmB,eAAfntB,EAAM7iE,KACR,OAAO+vF,GAAeG,QAIxB,GAAIrtB,aAAiButB,UAAavtB,GAAiC,kBAAjBA,EAAM76D,OAAsB,CAC5E,MAAM4gD,EAAUmnC,GAAeltB,EAAM76D,QACrC,OAAI4gD,EACKA,EAAQonC,GAEV,IAAIH,GACT,SAAShtB,EAAM76D,SACf,cACA,EACA,QAEJ,CAGA,OAAI66D,aAAiBjlE,WAAailE,EAAMl6D,QAAQymB,SAAS,SAChD2gE,GAAeE,UAIjB,IAAIJ,GACThtB,EAAMl6D,SAAW,OACjB,iBACA,EACA,QAEJ,CAOA,MAAM0nF,GAQJjzF,WAAAA,CAAYiK,EAAU,CAAC,GACrB9G,KAAK+vF,UAAYjpF,EAAQipF,WAAa,IACtC/vF,KAAK6kE,WAAa/9D,EAAQ+9D,YAAc,MAAS,GACjD7kE,KAAKgK,QAAUlD,EAAQkD,SAAW,MAAS,GAC3ChK,KAAKgwF,gBAAkB,IACzB,CAUA,qBAAMC,CAAgBC,GAAe,GAEnClwF,KAAKgwF,gBAAkB,IAAIG,gBAC3B,MAAMC,EAAa,GACnB,IAAI5a,EAAS,KACT6a,EAAe,EACfC,EAAa,EAEjB,IACE,EAAG,CAED,GAAItwF,KAAKgwF,gBAAgBO,OAAOC,QAC9B,MAIF,MAAMC,QAAiBzwF,KAAK0wF,WAAWlb,EAAQ0a,GAG/CE,EAAW1wE,QAAQ+wE,EAASE,SAC5Bnb,EAASib,EAASG,WAClBP,GAAgBI,EAASE,QAAQ/pF,OACjC0pF,IAGAtwF,KAAK6kE,WAAW,CACdgsB,MAAO,WACP5oF,QAASooF,EACTC,WAAYA,EACZloF,QAAS,OAAOioF,YAGpB,OAAS7a,IAAWx1E,KAAKgwF,gBAAgBO,OAAOC,SAGhD,GAAIxwF,KAAKgwF,gBAAgBO,OAAOC,QAC9B,MAAMhB,GAAeG,QAGvB,OAAOS,CACT,CAAE,MAAO9tB,GAEP,MAAMwuB,EAAaxuB,aAAiBgtB,GAChChtB,EACAstB,GAAYttB,GAEhB,MADAtiE,KAAKgK,QAAQ8mF,GACPA,CACR,CACF,CAUA,gBAAMJ,CAAWlb,EAAQ0a,GAEvB,MAAMtlC,EAAS,IAAImmC,gBACfvb,GACF5qB,EAAO7kC,IAAI,SAAUyvD,GAEnB0a,GACFtlC,EAAO7kC,IAAI,eAAgB,QAE7B6kC,EAAO7kC,IAAI,QAASzoB,OAAO0C,KAAK+vF,YAEhC,IAEE,MAAMU,QAAiBO,EAAAA,GAAAA,GACrB,0BAA0BpmC,IAC1B,CAAE2lC,OAAQvwF,KAAKgwF,gBAAgBO,SAIjC,IAAKE,EAASn3E,GAAI,CAChB,IAAI23E,EAAe,GACnB,IACE,MAAMC,QAAkBT,EAASU,OACjCF,EAAeC,EAAU5uB,OAAS,EACpC,CAAE,MACA,CAEF,MAAMstB,GAAYa,EAAUQ,EAC9B,CAGA,MAAMnxF,QAAa2wF,EAASU,OAG5B,IAAKrxF,EAAKsxF,QACR,MAAM,IAAI9B,GACRxvF,EAAKwiE,OAAS,OACd,aACA,EACA,SAIJ,MAAO,CACLquB,QAAS7wF,EAAK6wF,SAAW,GACzBC,WAAY9wF,EAAK8wF,YAAc,KAC/BS,eAAgBvxF,EAAKuxF,gBAAkB,EAE3C,CAAE,MAAO/uB,GAEP,GAAIA,aAAiBgtB,GACnB,MAAMhtB,EAGR,MAAMstB,GAAYttB,EACpB,CACF,CAMAgvB,KAAAA,GACMtxF,KAAKgwF,iBACPhwF,KAAKgwF,gBAAgBsB,OAEzB,CAMAC,SAAAA,GACE,QAAOvxF,KAAKgwF,iBAAkBhwF,KAAKgwF,gBAAgBO,OAAOC,OAC5D,CAMAh6C,KAAAA,GACEx2C,KAAKgwF,gBAAkB,IACzB,EAGF,UCvQA,MAAMwB,GAUJ30F,WAAAA,CAAYiK,EAAU,CAAC,GACrB9G,KAAKyxF,UAAY3qF,EAAQ2qF,WAAa,KACtCzxF,KAAK0xF,WAAa5qF,EAAQ4qF,YAAc,EACxC1xF,KAAK2xF,WAAa7qF,EAAQ6qF,YAAc,IACxC3xF,KAAK6kE,WAAa/9D,EAAQ+9D,YAAc,MAAS,GACjD7kE,KAAKgK,QAAUlD,EAAQkD,SAAW,MAAS,GAC3ChK,KAAK4xF,UAAY5xF,KAAK6xF,oBACtB7xF,KAAKwwF,SAAU,CACjB,CAMA,iBAAMsB,GACJ,IACE,MAAMrB,QAAiBO,EAAAA,GAAAA,GAAc,kCACrC,IAAKP,EAASn3E,GACZ,MAAM,IAAI4lB,MAAM,UAElB,MAAMxd,QAAe+uE,EAASU,OAC9B,GAAIzvE,EAAO0vE,QACT,MAAO,CACLK,UAAW/vE,EAAO+vE,WAAa,IAC/BM,aAAcrwE,EAAOqwE,cAAgB,WAGzC,MAAM,IAAI7yD,MAAMxd,EAAO4gD,OAAS,SAClC,CAAE,MAAOA,GAGP,OADAhnC,QAAQC,KAAK,+CAAgD+mC,GACtD,CAAEmvB,UAAW,IAAKM,aAAc,UACzC,CACF,CAeA,aAAMC,GACJhyF,KAAKwwF,SAAU,EAEf,IAEE,IAAKxwF,KAAKyxF,UAAW,CACnB,MAAMjiD,QAAexvC,KAAK8xF,cAC1B9xF,KAAKyxF,UAAYjiD,EAAOiiD,SAC1B,CAGAzxF,KAAK6kE,WAAW,CACdgsB,MAAO,WACPzoF,QAAS,YACTH,QAAS,IAGX,MAAMgqF,EAAY,IAAInC,GAAe,CACnCjrB,WAAajpD,GAAM5b,KAAK6kE,WAAW,IAAKjpD,EAAGi1E,MAAO,aAClD7mF,QAAU9M,GAAM8C,KAAKgK,QAAQ9M,KAGzByzF,QAAgBsB,EAAUhC,iBAAgB,GAEhD,GAAIjwF,KAAKwwF,QACP,MAAM,IAAIlB,GAAoB,QAAS,WAAW,EAAO,IAa3D,GATAtvF,KAAK6kE,WAAW,CACdgsB,MAAO,UACPzoF,QAAS,UACTH,QAAS,EACTC,MAAOyoF,EAAQ/pF,SAGjB5G,KAAKkyF,0BAA0BvB,GAE3B3wF,KAAKwwF,QACP,MAAM,IAAIlB,GAAoB,QAAS,WAAW,EAAO,IAI3D,MAAM6C,EAASnyF,KAAKoyF,gBAAgBzB,GAEpC,IAAK,IAAIxzF,EAAI,EAAGA,EAAIg1F,EAAOvrF,OAAQzJ,IAAK,CACtC,GAAI6C,KAAKwwF,QACP,MAAM,IAAIlB,GAAoB,QAAS,WAAW,EAAO,UAIrDtvF,KAAKqyF,qBAAqBF,EAAOh1F,GAAIA,GAE3C6C,KAAK6kE,WAAW,CACdgsB,MAAO,YACP5oF,QAAS9K,EAAI,EACb+K,MAAOiqF,EAAOvrF,OACdwB,QAAS,UAAUjL,EAAI,KAAKg1F,EAAOvrF,aAEvC,CAmBA,OAhBA5G,KAAK6kE,WAAW,CACdgsB,MAAO,aACPzoF,QAAS,YACTH,QAASkqF,EAAOvrF,OAChBsB,MAAOiqF,EAAOvrF,eAGV5G,KAAKsyF,SAASH,EAAOvrF,OAAQ+pF,EAAQ/pF,QAE3C5G,KAAK6kE,WAAW,CACdgsB,MAAO,YACPzoF,QAAS,YAAYuoF,EAAQ/pF,aAC7BqB,QAAS0oF,EAAQ/pF,OACjBsB,MAAOyoF,EAAQ/pF,SAGV,CAAEwqF,SAAS,EAAMjrF,WAAYwqF,EAAQ/pF,OAC9C,CAAE,MAAO07D,GACP,MAAMwuB,EAAaxuB,aAAiBgtB,GAChChtB,EACA,IAAIgtB,GACFhtB,EAAMl6D,SAAW,SACjB,iBACA,EACA,SAGN,MADApI,KAAKgK,QAAQ8mF,GACPA,CACR,CACF,CAOAoB,yBAAAA,CAA0BvB,GACxBA,EAAQ/uE,KAAK,CAAClW,EAAGC,KACf,MAAM4mF,EAAc7mF,EAAEpB,UAAYoB,EAAEpB,SAASE,WAAc,EACrDgoF,EAAc7mF,EAAErB,UAAYqB,EAAErB,SAASE,WAAc,EAC3D,OAAOgoF,EAAaD,GAExB,CAQAH,eAAAA,CAAgBzB,GACd,MAAMwB,EAAS,GACf,IAAK,IAAIh1F,EAAI,EAAGA,EAAIwzF,EAAQ/pF,OAAQzJ,GAAK6C,KAAKyxF,UAC5CU,EAAOzyE,KAAKixE,EAAQh0E,MAAMxf,EAAGA,EAAI6C,KAAKyxF,YAExC,OAAOU,CACT,CAUA,0BAAME,CAAqB51C,EAAOg2C,GAChC,IAAIC,EAEJ,IAAK,IAAIC,EAAU,EAAGA,GAAW3yF,KAAK0xF,WAAYiB,IAChD,IACE,aAAa3yF,KAAK4yF,YAAYn2C,EAAOg2C,EACvC,CAAE,MAAOnwB,GAIP,GAHAowB,EAAYpwB,EAGRA,aAAiBgtB,KACA,gBAAfhtB,EAAMitB,MACS,cAAfjtB,EAAMitB,MACS,YAAfjtB,EAAMitB,MACR,MAAMjtB,EAKV,GAAIqwB,EAAU3yF,KAAK0xF,WAAY,CAE7B,MAAMnrE,EAAQvmB,KAAK2xF,WAAa9pF,KAAKqS,IAAI,EAAGy4E,EAAU,SAChD3yF,KAAK6yF,MAAMtsE,GAEjBvmB,KAAK6kE,WAAW,CACdgsB,MAAO,WACPzoF,QAAS,MAAMqqF,EAAU,gBAAgBE,KAAW3yF,KAAK0xF,iBACzDzpF,QAASwqF,EACTE,QAASA,GAEb,CACF,CAIF,MAAMD,aAAqBpD,GACvBoD,EACA,IAAIpD,GACF,MAAMmD,EAAU,cAAczyF,KAAK0xF,eACnC,uBACA,EACA,iBAER,CAUA,iBAAMkB,CAAYn2C,EAAOg2C,GACvB,MAAMK,QAAiB9yF,KAAK+yF,kBAAkBt2C,GAE9C,IACE,MAAMg0C,QAAiBO,EAAAA,GAAAA,GAAc,gCAAiC,CACpE1rE,OAAQ,OACR0tE,QAAS,CAAE,eAAgB,oBAC3B5a,KAAMhrD,KAAKC,UAAU,CACnBolE,QAASn1F,OAAOm1F,GAChBb,UAAW5xF,KAAK4xF,UAChB9xF,KAAM28C,EACNq2C,eAIJ,IAAKrC,EAASn3E,GAAI,CAChB,IAAI23E,EAAe,GACnB,IACE,MAAMC,QAAkBT,EAASU,OACjCF,EAAeC,EAAU5uB,OAAS,EACpC,CAAE,MACA,CAEF,MAAMtiE,KAAKizF,gBAAgBxC,EAAShpF,OAAQwpF,EAC9C,CAEA,MAAMvvE,QAAe+uE,EAASU,OAE9B,IAAKzvE,EAAO0vE,QACV,MAAM,IAAI9B,GACR5tE,EAAO4gD,OAAS,SAChB,uBACA,EACA,SAIJ,OAAO5gD,CACT,CAAE,MAAO4gD,GACP,GAAIA,aAAiBgtB,GACnB,MAAMhtB,EAGR,GAAIA,aAAiBjlE,WAAailE,EAAMl6D,QAAQymB,SAAS,SACvD,MAAM,IAAIygE,GACR,SACA,iBACA,EACA,cAGJ,MAAM,IAAIA,GACRhtB,EAAMl6D,SAAW,SACjB,uBACA,EACA,QAEJ,CACF,CAUA,cAAMkqF,CAASY,EAAa/sF,GAC1B,IACE,MAAMsqF,QAAiBO,EAAAA,GAAAA,GAAc,mCAAoC,CACvE1rE,OAAQ,OACR0tE,QAAS,CAAE,eAAgB,oBAC3B5a,KAAMhrD,KAAKC,UAAU,CACnBukE,UAAW5xF,KAAK4xF,UAChBsB,cACA/sF,iBAIJ,IAAKsqF,EAASn3E,GAAI,CAChB,IAAI23E,EAAe,GACnB,IACE,MAAMC,QAAkBT,EAASU,OACjCF,EAAeC,EAAU5uB,OAAS,EACpC,CAAE,MACA,CAEF,MAAMtiE,KAAKizF,gBAAgBxC,EAAShpF,OAAQwpF,EAC9C,CAEA,MAAMvvE,QAAe+uE,EAASU,OAE9B,IAAKzvE,EAAO0vE,QACV,MAAM,IAAI9B,GACR5tE,EAAO4gD,OAAS,SAChB,mBACA,EACA,SAIJ,OAAO5gD,CACT,CAAE,MAAO4gD,GACP,GAAIA,aAAiBgtB,GACnB,MAAMhtB,EAER,MAAM,IAAIgtB,GACRhtB,EAAMl6D,SAAW,SACjB,mBACA,EACA,QAEJ,CACF,CAOAypF,iBAAAA,GACE,MAAO,WAAWjlD,KAAKC,SAAShlC,KAAKsrF,SAASz2E,SAAS,IAAIC,MAAM,IACnE,CAQA,uBAAMo2E,CAAkBjzF,GACtB,MAAMmwB,EAAO7C,KAAKC,UAAUvtB,GACtBszF,EAAU,IAAIC,YACdC,EAAaF,EAAQG,OAAOtjE,GAC5BujE,QAAmBC,OAAOC,OAAOC,OAAO,UAAWL,GACnDM,EAAYnmF,MAAM0M,KAAK,IAAI05E,WAAWL,IAC5C,OAAOI,EAAUjmF,IAAIhC,GAAKA,EAAE+Q,SAAS,IAAIo3E,SAAS,EAAG,MAAM30D,KAAK,GAClE,CASA8zD,eAAAA,CAAgBxrF,EAAQgoF,EAAU,IAChC,OAAQhoF,GACN,KAAK,IACH,OAAO,IAAI6nF,GACT,aACA,eACA,EACA,cAEJ,KAAK,IACH,OAAO,IAAIA,GACT,aACA,aACA,EACA,cAEJ,KAAK,IACH,OAAO,IAAIA,GACT,WAAWG,IACX,gBACA,EACA,cAEJ,KAAK,IACH,OAAO,IAAIH,GACT,QACA,qBACA,EACA,aAEJ,KAAK,IACH,OAAO,IAAIA,GACT,QACA,mBACA,EACA,aAEJ,KAAK,IACL,QACE,OAAO,IAAIA,GACT,UAAUG,GAAWhoF,IACrB,gBACA,EACA,SAGR,CAQAorF,KAAAA,CAAMkB,GACJ,OAAO,IAAI3kD,QAAQ5T,GAAW9U,WAAW8U,EAASu4D,GACpD,CAKAzC,KAAAA,GACEtxF,KAAKwwF,SAAU,CACjB,CAMAh6C,KAAAA,GACEx2C,KAAKwwF,SAAU,EACfxwF,KAAK4xF,UAAY5xF,KAAK6xF,mBACxB,EAGF,UC3cA,MAAMmC,GAMJn3F,WAAAA,CAAYiK,EAAU,CAAC,GACrB9G,KAAK6kE,WAAa/9D,EAAQ+9D,YAAc,MAAS,GACjD7kE,KAAKiyF,UAAY,IACnB,CAcA,oBAAMgC,GAEJj0F,KAAKiyF,UAAY,IAAInC,GAAe,CAClCjrB,WAAajpD,GAAM5b,KAAK6kE,WAAW,IAAKjpD,EAAGi1E,MAAO,eAGpD,MAAMF,QAAgB3wF,KAAKiyF,UAAUhC,iBAAgB,GAGrDjwF,KAAK6kE,WAAW,CAAEgsB,MAAO,WAAYzoF,QAAS,gBAE9C,MAAMa,EAAa,CACjBw/E,UAAW77C,KAAKC,MAChBpmC,QAASytF,GAAAA,GACTp0F,KAAM,CACJq0F,UAAWxD,EAAQ/pF,OACnBwtF,MAAO,CAAC,EACRC,SAAU,CAAC,IAKf,IAAK,MAAMC,KAAU3D,EACnB1nF,EAAWnJ,KAAKs0F,MAAME,EAAOxqF,IAAM,CACjCQ,SAAUgqF,EAAOhqF,SACjB1M,MAAO02F,EAAO12F,OAAS,MAK3B,MAAMy2F,QAAiBr0F,KAAKu0F,gBAC5BtrF,EAAWnJ,KAAKu0F,SAAWA,EAG3Br0F,KAAK6kE,WAAW,CAAEgsB,MAAO,cAAezoF,QAAS,cACjDpI,KAAKw0F,eAAevrF,GAEpB,MAAMwrF,EAAgB/2F,OAAOgJ,KAAK2tF,GAAUztF,OAC5C,MAAO,CAAEwqF,SAAS,EAAM+C,UAAWxD,EAAQ/pF,OAAQ6tF,gBACrD,CAOA,mBAAMF,GACJ,IACE,MAAM9D,QAAiBO,EAAAA,GAAAA,GAAc,8BACrC,IAAKP,EAASn3E,GAEZ,OADAgiB,QAAQC,KAAK,4BAA6Bk1D,EAAShpF,QAC5C,CAAC,EAEV,MAAM3H,QAAa2wF,EAASU,OAE5B,OAAOrxF,EAAKu0F,UAAY,CAAC,CAC3B,CAAE,MAAO/xB,GAEP,OADAhnC,QAAQC,KAAK,4BAA6B+mC,GACnC,CAAC,CACV,CACF,CAOAkyB,cAAAA,CAAe10F,GAEb,MAAMqxF,EAAO/jE,KAAKC,UAAUvtB,EAAM,KAAM,GAGlC40F,EAAO,IAAIC,KAAK,CAACxD,GAAO,CAAExxF,KAAM,qBAGhCi1F,EAAMC,IAAIC,gBAAgBJ,GAG1BhpF,EAAIw3B,SAAS6xD,cAAc,KACjCrpF,EAAEspF,KAAOJ,EAETlpF,EAAEupF,SAAW,kBAAiB,IAAIroD,MAAOsoD,cAAc11E,MAAM,KAAK,UAGlE0jB,SAASk1C,KAAK+c,YAAYzpF,GAC1BA,EAAE0pF,QAGFlyD,SAASk1C,KAAKid,YAAY3pF,GAC1BmpF,IAAIS,gBAAgBV,EACtB,CAKAtD,KAAAA,GACMtxF,KAAKiyF,WACPjyF,KAAKiyF,UAAUX,OAEnB,CAMAC,SAAAA,GACE,QAAOvxF,KAAKiyF,WAAYjyF,KAAKiyF,UAAUV,WACzC,EAGF,UCzIA,MAAMgE,GAUJ14F,WAAAA,CAAYiK,EAAU,CAAC,GACrB9G,KAAKyxF,UAAY3qF,EAAQ2qF,WAAa,GACtCzxF,KAAK0xF,WAAa5qF,EAAQ4qF,YAAc,EACxC1xF,KAAK2xF,WAAa7qF,EAAQ6qF,YAAc,IACxC3xF,KAAK6kE,WAAa/9D,EAAQ+9D,YAAc,MAAS,GACjD7kE,KAAKgK,QAAUlD,EAAQkD,SAAW,MAAS,GAC3ChK,KAAKwwF,SAAU,CACjB,CAQA,aAAMt7D,CAAQjsB,GAIZ,GAHAjJ,KAAKwwF,SAAU,GAGVvnF,IAAeA,EAAWnJ,KAC7B,MAAM,IAAIwvF,GACR,WACA,kBACA,EACA,cAIJ,MAAM,MAAE8E,EAAQ,CAAC,EAAC,SAAEC,EAAW,CAAC,GAAMprF,EAAWnJ,KAC3C01F,EAAc93F,OAAOoyD,QAAQskC,GAC7BqB,EAAiB/3F,OAAOoyD,QAAQukC,GAEhCluF,EAAaqvF,EAAY5uF,OACzB8uF,EAAgBD,EAAe7uF,OAC/B+uF,EAAaxvF,EAAauvF,EAEhC,IAAIE,EAAgB,EAChBC,EAAmB,EACnBC,EAAc,EACdC,EAAiB,EAErB,IAEE/1F,KAAK6kE,WAAW,CACdgsB,MAAO,kBACPzoF,QAAS,cACTH,QAAS,EACTC,MAAOytF,IAGT,MAAMK,EAAah2F,KAAKoyF,gBAAgBoD,EAAax1F,KAAKyxF,WAE1D,IAAK,IAAIt0F,EAAI,EAAGA,EAAI64F,EAAWpvF,OAAQzJ,IAAK,CAC1C,GAAI6C,KAAKwwF,QACP,MAAM,IAAIlB,GAAoB,QAAS,WAAW,EAAO,IAG3D,MAAM7yC,EAAQu5C,EAAW74F,GACnB84F,EAAYv4F,OAAOw4F,YAAYz5C,GAE/B/6B,QAAe1hB,KAAKqyF,qBAAqB,QAAS4D,GACxDL,GAAiBl0E,EAAOy0E,cACxBL,GAAep0E,EAAO00E,YAEtBp2F,KAAK6kE,WAAW,CACdgsB,MAAO,kBACPzoF,QAAS,YAAYwtF,KAAiBzvF,OACtC8B,QAAS2tF,EACT1tF,MAAOytF,EACP3tF,WAAa4tF,EAAgBD,EAAc,IAE/C,CAGA31F,KAAK6kE,WAAW,CACdgsB,MAAO,qBACPzoF,QAAS,cACTH,QAAS2tF,EACT1tF,MAAOytF,IAGT,MAAMU,EAAgBr2F,KAAKoyF,gBAAgBqD,EAAgBz1F,KAAKyxF,WAEhE,IAAK,IAAIt0F,EAAI,EAAGA,EAAIk5F,EAAczvF,OAAQzJ,IAAK,CAC7C,GAAI6C,KAAKwwF,QACP,MAAM,IAAIlB,GAAoB,QAAS,WAAW,EAAO,IAG3D,MAAM7yC,EAAQ45C,EAAcl5F,GACtB84F,EAAYv4F,OAAOw4F,YAAYz5C,GAE/B/6B,QAAe1hB,KAAKqyF,qBAAqB,WAAY4D,GAC3DJ,GAAoBn0E,EAAOy0E,cAC3BJ,GAAkBr0E,EAAO00E,YAEzBp2F,KAAK6kE,WAAW,CACdgsB,MAAO,qBACPzoF,QAAS,YAAYytF,KAAoBH,OACzCztF,QAAS2tF,EAAgBC,EACzB3tF,MAAOytF,EACP3tF,WAAY,GAAM6tF,EAAmBH,EAAiB,IAE1D,CAWA,OARA11F,KAAK6kE,WAAW,CACdgsB,MAAO,YACPzoF,QAAS,OACTH,QAAS0tF,EACTztF,MAAOytF,EACP3tF,WAAY,MAGP,CACLopF,SAAS,EACTwE,gBACAC,mBACAC,cACAC,iBACAO,gBAAiBrtF,EAAWw/E,UAGhC,CAAE,MAAOnmB,GACP,MAAMwuB,EAAaxuB,aAAiBgtB,GAChChtB,EACA,IAAIgtB,GACFhtB,EAAMl6D,SAAW,OACjB,iBACA,EACA,SAGN,MADApI,KAAKgK,QAAQ8mF,GACPA,CACR,CACF,CAKAsB,eAAAA,CAAgBtiC,EAAS2hC,GACvB,MAAMU,EAAS,GACf,IAAK,IAAIh1F,EAAI,EAAGA,EAAI2yD,EAAQlpD,OAAQzJ,GAAKs0F,EACvCU,EAAOzyE,KAAKowC,EAAQnzC,MAAMxf,EAAGA,EAAIs0F,IAEnC,OAAOU,CACT,CAKA,0BAAME,CAAqB1yF,EAAMG,GAC/B,IAAI4yF,EAEJ,IAAK,IAAIC,EAAU,EAAGA,GAAW3yF,KAAK0xF,WAAYiB,IAChD,IACE,aAAa3yF,KAAK4yF,YAAYjzF,EAAMG,EACtC,CAAE,MAAOwiE,GAGP,GAFAowB,EAAYpwB,EAERA,aAAiBgtB,KACA,gBAAfhtB,EAAMitB,MACS,cAAfjtB,EAAMitB,MACS,YAAfjtB,EAAMitB,MACR,MAAMjtB,EAIV,GAAIqwB,EAAU3yF,KAAK0xF,WAAY,CAC7B,MAAMnrE,EAAQvmB,KAAK2xF,WAAa9pF,KAAKqS,IAAI,EAAGy4E,EAAU,SAChD3yF,KAAK6yF,MAAMtsE,EACnB,CACF,CAGF,MAAMmsE,CACR,CAKA,iBAAME,CAAYjzF,EAAMG,GACtB,IACE,MAAM2wF,QAAiBO,EAAAA,GAAAA,GAAc,kCAAmC,CACtE1rE,OAAQ,OACR0tE,QAAS,CAAE,eAAgB,oBAC3B5a,KAAMhrD,KAAKC,UAAU,CAAE1tB,OAAMG,WAG/B,IAAK2wF,EAASn3E,GAAI,CAChB,IAAI23E,EAAe,GACnB,IACE,MAAMC,QAAkBT,EAASU,OACjCF,EAAeC,EAAU5uB,OAAS,EACpC,CAAE,MACA,CAEF,MAAMtiE,KAAKizF,gBAAgBxC,EAAShpF,OAAQwpF,EAC9C,CAEA,MAAMvvE,QAAe+uE,EAASU,OAE9B,IAAKzvE,EAAO0vE,QACV,MAAM,IAAI9B,GACR5tE,EAAO4gD,OAAS,SAChB,wBACA,EACA,SAIJ,OAAO5gD,CACT,CAAE,MAAO4gD,GACP,GAAIA,aAAiBgtB,GACnB,MAAMhtB,EAER,GAAIA,aAAiBjlE,WAAailE,EAAMl6D,QAAQymB,SAAS,SACvD,MAAM,IAAIygE,GACR,SACA,iBACA,EACA,cAGJ,MAAM,IAAIA,GACRhtB,EAAMl6D,SAAW,SACjB,wBACA,EACA,QAEJ,CACF,CAKA6qF,eAAAA,CAAgBxrF,EAAQgoF,EAAU,IAChC,OAAQhoF,GACN,KAAK,IACH,OAAO,IAAI6nF,GACT,aACA,eACA,EACA,cAEJ,KAAK,IACH,OAAO,IAAIA,GACT,aACA,aACA,EACA,cAEJ,KAAK,IACH,OAAO,IAAIA,GACT,WAAWG,IACX,gBACA,EACA,aAEJ,KAAK,IACL,QACE,OAAO,IAAIH,GACT,UAAUG,GAAWhoF,IACrB,gBACA,EACA,SAGR,CAKAorF,KAAAA,CAAMkB,GACJ,OAAO,IAAI3kD,QAAQ5T,GAAW9U,WAAW8U,EAASu4D,GACpD,CAKAzC,KAAAA,GACEtxF,KAAKwwF,SAAU,CACjB,EAGF,UCxSAhrB,GAAQzH,SAASuQ,GAAY,GAAS,IACtC,QACE7uE,KAAM,eACN82F,WAAY,CACVlH,SAAQ,IAEV,IAAAvvF,GACE,MAAO,CACL+I,SAAS,EACTC,YAAY,EACZE,SAAS,EACTM,WAAW,EACXpD,UAAW,CAAC,EACZO,QAAS,MAETmD,WAAY,CACV4sF,QAAQ,EACRC,QAAQ,GAGVC,cAAe,CAAC,UAAW,UAAW,UAAW,UAAW,UAAW,UAAW,UAAW,WAE7FC,WAAY,CAAC,UAAW,UAAW,UAAW,UAAW,UAAW,UAAW,UAAW,WAE1FhvF,cAAc,EACdivF,gBAAiB,GAEjB7uF,mBAAoB,CAClBE,QAAS,EACTC,MAAO,EACPE,QAAS,GACTJ,WAAY,GAEdQ,gBAAiB,KACjBquF,oBAAqB,KAErBC,iBAAkB,KAClBC,uBAAwB,KACxBC,wBAAyB,KAE7B,EACAC,SAAU,CAER,gBAAApwF,GACE,MAAMqwF,EAAQl3F,KAAKkG,UAAUS,cAAgB,CAAC,EAC9C,MAAO,CACL+wC,OAAQh6C,OAAOgJ,KAAKwwF,GACpBrlE,SAAU,CAAC,CACT/xB,KAAMpC,OAAOqnB,OAAOmyE,GACpBvlE,gBAAiB3xB,KAAK02F,cAAc/5E,MAAM,EAAGjf,OAAOgJ,KAAKwwF,GAAOtwF,QAChEwwB,YAAa,IAGnB,EAEA,aAAA7vB,GACE,MAAM4vF,EAAkBn3F,KAAKwH,oBAC7B,MAAO,CACLkwC,OAAQh6C,OAAOgJ,KAAKywF,GACpBtlE,SAAU,CAAC,CACT/xB,KAAMpC,OAAOqnB,OAAOoyE,GACpBxlE,gBAAiB3xB,KAAK22F,WAAWh6E,MAAM,EAAGjf,OAAOgJ,KAAKywF,GAAiBvwF,QACvEwwB,YAAa,IAGnB,EAEA,mBAAA5vB,GACE,MAAM0vF,EAAQl3F,KAAKkG,UAAUoB,WAAa,CAAC,EACrC6vF,EAAkB,CAAC,EACzB,IAAK,MAAO1vF,EAAQT,KAAUtJ,OAAOoyD,QAAQonC,GAAQ,CACnD,MAAME,EAA0B,UAAX3vF,EAAqB,MAAQ,KAClD0vF,EAAgBC,IAAiBD,EAAgBC,IAAiB,GAAKpwF,CACzE,CACA,OAAOmwF,CACT,EAEA,YAAApwF,GACE,MAAO,CACLssB,YAAY,EACZJ,qBAAqB,EACrBuuB,OAAQ,MACR6C,YAAa,EACb0G,OAAQ,CACNn+B,QAAS,IAEXwG,QAAS,CACPmxB,OAAQ,CACNv1B,SAAS,GAEXmpD,QAAS,CACPxmD,gBAAiB,qBACjBisD,WAAY,OACZtC,UAAW,OACX1uD,QAAS,GACTsJ,aAAc,EACdkjD,eAAe,EACfjsB,EAAG,IACH7gB,UAAW,CACTsM,MAAO7mB,IACL,MAAMn0B,EAAQm0B,EAAQ0hB,IAChBvrC,EAAQ6pB,EAAQlK,QAAQ/nB,KAAK4tC,OAAO,CAAChiC,EAAGC,IAAMD,EAAIC,EAAG,GACrD3D,GAAcpK,EAAQsK,EAAQ,KAAKmvF,QAAQ,GACjD,MAAO,IAAIz5F,EAAMwI,qBAAqB4B,UAK9CokB,UAAW,CACTw3B,eAAe,EACfK,cAAc,GAGpB,EAEA,sBAAA97C,GACE,IAAKnI,KAAK2H,eAAiB3H,KAAK62F,oBAAqB,MAAO,GAC5D,GAAwC,IAApC72F,KAAK+H,mBAAmBE,SAAwD,IAAvCjI,KAAK+H,mBAAmBC,WAAkB,MAAO,GAC9F,MAAMinC,EAAUrC,KAAKC,MAAQ7sC,KAAK62F,oBAC5BtpD,EAAWvtC,KAAK+H,mBAAmBC,WAAa,IACtD,GAAIulC,GAAY,EAAG,MAAO,GAC1B,MAAM+pD,EAAiBroD,EAAU1B,EAC3BT,EAAYwqD,EAAiBroD,EACnC,GAAInC,GAAa,EAAG,MAAO,OAC3B,MAAMyqD,EAAU1vF,KAAKyrD,KAAKxmB,EAAY,KACtC,GAAIyqD,EAAU,GAAI,MAAO,KAAKA,MAC9B,MAAMC,EAAU3vF,KAAKyrD,KAAKikC,EAAU,IACpC,GAAIC,EAAU,GAAI,MAAO,KAAKA,OAC9B,MAAMC,EAAQ5vF,KAAKyZ,MAAMk2E,EAAU,IAC7BE,EAAmBF,EAAU,GACnC,MAAO,KAAKC,QAAYC,MAC1B,EAEA,gBAAA9vF,GACE,MAAM+vF,EAAW,CACf,SAAY,SACZ,QAAW,OACX,UAAa,OACb,WAAc,OACd,SAAY,SACZ,YAAe,SACf,gBAAmB,SACnB,mBAAsB,SACtB,UAAa,MACb,SAAY,QAEd,OAAOA,EAAS33F,KAAK42F,kBAAoB52F,KAAK42F,eAChD,GAEF,OAAAt2F,GACEN,KAAKiG,gBACP,EACAlG,QAAS,CAEP,aAAAqH,CAAcpI,GACZ,OAAOgB,KAAK02F,cAAc13F,EAAQgB,KAAK02F,cAAc9vF,OACvD,EAEA,iBAAAc,CAAkB1I,GAChB,OAAOgB,KAAK22F,WAAW33F,EAAQgB,KAAK22F,WAAW/vF,OACjD,EAEA,oBAAMX,GACJjG,KAAK6I,SAAU,EACf,IACE,MAAM4nF,QAAiB,EAAAO,GAAA,GAAc,+BAAgC,CACnE1rE,OAAQ,QAEV,IAAImrE,EAASn3E,GAIX,MAAM,IAAI4lB,MAAM,WAJD,CACf,MAAMp/B,QAAa2wF,EAASU,OAC5BnxF,KAAKkG,UAAYpG,CACnB,CAGF,CAAE,MAAOwiE,GACPhnC,QAAQgnC,MAAM,YAAaA,GAC3BtiE,KAAK43F,SAASt1B,MAAM,WACtB,CAAE,QACAtiE,KAAK6I,SAAU,CACjB,CACF,EAEA,kBAAME,GACJ,GAAI/I,KAAK2H,aACP3H,KAAK43F,SAASC,QAAQ,iBADxB,CAIA73F,KAAK8I,YAAa,EAClB9I,KAAK2H,cAAe,EACpB3H,KAAKwI,gBAAkB,KACvBxI,KAAK62F,oBAAsBjqD,KAAKC,MAChC7sC,KAAK+H,mBAAqB,CACxBE,QAAS,EACTC,MAAO,EACPE,QAAS,GACTJ,WAAY,GAIdhI,KAAK82F,iBAAmB,IAAI,GAAe,CACzCjyB,WAAYt3B,GAAYvtC,KAAK83F,eAAevqD,GAC5CvjC,QAASs4D,GAAStiE,KAAK+3F,YAAYz1B,KAErC,IACE,MAAM5gD,QAAe1hB,KAAK82F,iBAAiB9E,UAG3ChyF,KAAK43F,SAASxG,QAAQ,cAAc1vE,EAAOvb,WAAWC,wBAGtDsgB,WAAW,KACT1mB,KAAKiG,kBACJ,IACL,CAAE,MAAOq8D,GAEP,GAAmB,YAAfA,EAAMitB,KAAoB,CAC5B,MAAMyI,EAAe11B,EAAM75D,WAAa,GAAG65D,EAAMl6D,WAAWk6D,EAAM75D,aAAe65D,EAAMl6D,QACvFpI,KAAK43F,SAASt1B,MAAM01B,GACpBh4F,KAAKwI,gBAAkB,CACrBJ,QAASk6D,EAAMl6D,QACfK,WAAY65D,EAAM75D,WAClBC,YAAa45D,EAAM55D,YAEvB,CACF,CAAE,QACA1I,KAAK8I,YAAa,EAClB9I,KAAK2H,cAAe,EACpB3H,KAAK82F,iBAAmB,KACxB92F,KAAK62F,oBAAsB,IAC7B,CA3CA,CA4CF,EAEA,gBAAM5tF,GACJ,GAAIjJ,KAAK2H,aACP3H,KAAK43F,SAASC,QAAQ,iBADxB,CAIA73F,KAAKgJ,SAAU,EACfhJ,KAAK2H,cAAe,EACpB3H,KAAKwI,gBAAkB,KACvBxI,KAAK62F,oBAAsBjqD,KAAKC,MAChC7sC,KAAK+H,mBAAqB,CACxBE,QAAS,EACTC,MAAO,EACPE,QAAS,GACTJ,WAAY,GAIdhI,KAAK+2F,uBAAyB,IAAI,GAAgB,CAChDlyB,WAAYt3B,GAAYvtC,KAAK83F,eAAevqD,KAE9C,IACE,MAAM7rB,QAAe1hB,KAAK+2F,uBAAuB9C,iBAG3CgE,EAAcv2E,EAAO+yE,cAAgB,EAAI,IAAI/yE,EAAO+yE,qBAAuB,GACjFz0F,KAAK43F,SAASxG,QAAQ,YAAY1vE,EAAOyyE,UAAU/tF,uBAAuB6xF,IAC5E,CAAE,MAAO31B,GAEP,GAAmB,YAAfA,EAAMitB,KAAoB,CAC5B,MAAMyI,EAAe11B,EAAM75D,WAAa,GAAG65D,EAAMl6D,WAAWk6D,EAAM75D,aAAe65D,EAAMl6D,QACvFpI,KAAK43F,SAASt1B,MAAM01B,GACpBh4F,KAAKwI,gBAAkB,CACrBJ,QAASk6D,EAAMl6D,QACfK,WAAY65D,EAAM75D,WAClBC,YAAa45D,EAAM55D,YAEvB,CACF,CAAE,QACA1I,KAAKgJ,SAAU,EACfhJ,KAAK2H,cAAe,EACpB3H,KAAK+2F,uBAAyB,KAC9B/2F,KAAK62F,oBAAsB,IAC7B,CAtCA,CAuCF,EAEA,iBAAAttF,GACMvJ,KAAKsJ,WACTtJ,KAAKk4F,MAAMC,UAAU/C,OACvB,EAEA,sBAAM/rF,CAAiB67B,GACrB,MAAMkzD,EAAOlzD,EAAM5mB,OAAO81E,MAAM,GAChC,GAAKgE,EACL,GAAKA,EAAK34F,KAAK2d,SAAS,SAAxB,CAMA,UACQpd,KAAKq4F,SAAS,sCAAuC,OAAQ,CACjEC,kBAAmB,OACnBC,iBAAkB,KAClB54F,KAAM,kBAEFK,KAAKw4F,YAAYJ,EACzB,CAAE,MAAO91B,GACO,WAAVA,GACFhnC,QAAQgnC,MAAM,UAAWA,EAE7B,CAGAp9B,EAAM5mB,OAAO1gB,MAAQ,EAjBrB,MAFEoC,KAAK43F,SAASt1B,MAAM,iBAoBxB,EAEA,iBAAMk2B,CAAYJ,GAChB,GAAIp4F,KAAK2H,aACP3H,KAAK43F,SAASC,QAAQ,iBADxB,CAIA73F,KAAKsJ,WAAY,EACjBtJ,KAAK2H,cAAe,EACpB3H,KAAKwI,gBAAkB,KACvBxI,KAAK62F,oBAAsBjqD,KAAKC,MAChC7sC,KAAK+H,mBAAqB,CACxBE,QAAS,EACTC,MAAO,EACPE,QAAS,GACTJ,WAAY,GAEd,IAEE,MAAMywF,QAAoBL,EAAKnoE,OAC/B,IAAIhnB,EACJ,IACEA,EAAamkB,KAAKiT,MAAMo4D,EAC1B,CAAE,MAAOC,GACP,MAAM,IAAIx5D,MAAM,0BAClB,CAGAl/B,KAAKg3F,wBAA0B,IAAI,GAAiB,CAClDvF,UAAW,IAEX5sB,WAAYt3B,GAAYvtC,KAAK83F,eAAevqD,GAC5CvjC,QAASs4D,GAAStiE,KAAK+3F,YAAYz1B,KAErC,MAAM5gD,QAAe1hB,KAAKg3F,wBAAwB9hE,QAAQjsB,GAG1DjJ,KAAKsJ,WAAY,EACjBtJ,KAAK2H,cAAe,EACpB3H,KAAKg3F,wBAA0B,KAC/Bh3F,KAAK62F,oBAAsB,KAG3B72F,KAAK43F,SAASxG,QAAQ,YAAY1vE,EAAOk0E,sBAAsBl0E,EAAOm0E,yCAGhE,IAAIzmD,QAAQ5T,GAAW9U,WAAW8U,EAAS,YAC3Cx7B,KAAK+I,cACb,CAAE,MAAOu5D,GAQP,GAPAhnC,QAAQgnC,MAAM,UAAWA,GAGzBtiE,KAAKsJ,WAAY,EACjBtJ,KAAK2H,cAAe,EACpB3H,KAAKg3F,wBAA0B,KAC/Bh3F,KAAK62F,oBAAsB,KACR,YAAfv0B,EAAMitB,KAAoB,CAC5B,MAAMyI,EAAe11B,EAAM75D,WAAa,GAAG65D,EAAMl6D,WAAWk6D,EAAM75D,aAAe65D,EAAMl6D,QACvFpI,KAAK43F,SAASt1B,MAAM,WAAa01B,GACjCh4F,KAAKwI,gBAAkB,CACrBJ,QAASk6D,EAAMl6D,QACfK,WAAY65D,EAAM75D,WAClBC,YAAa45D,EAAM55D,YAEvB,CACF,CA3DA,CA4DF,EAEA,UAAArC,CAAWoiF,GACT,IAAKA,EAAW,MAAO,KACvB,MAAMp8C,EAAO,IAAIO,KAAK67C,GACtB,OAAOp8C,EAAKjmC,eAAe,QAAS,CAClCmhF,KAAM,UACNF,MAAO,UACPF,IAAK,UACLD,KAAM,UACND,OAAQ,WAEZ,EAEA,aAAA5/E,CAAczJ,EAAOsK,GACnB,OAAKA,GAAmB,IAAVA,EACPL,KAAKC,MAAMlK,EAAQsK,EAAQ,KADA,CAEpC,EAEA,UAAA3B,CAAWkiF,GACT,IAAKA,EAAW,MAAO,GACvB,MAAM57C,EAAMD,KAAKC,MACX4a,EAAO5a,EAAM47C,EACb+O,EAAU3vF,KAAKyZ,MAAMmmC,EAAO,KAC5BgwC,EAAQ5vF,KAAKyZ,MAAMmmC,EAAO,MAC1BkxC,EAAO9wF,KAAKyZ,MAAMmmC,EAAO,OAC/B,OAAIkxC,EAAO,EAAU,GAAGA,MACpBlB,EAAQ,EAAU,GAAGA,OACrBD,EAAU,EAAU,GAAGA,OACpB,IACT,EAEA,gBAAAvtF,CAAiBtK,GACfK,KAAK4J,WAAWjK,IAAQ,CAC1B,EAEA,cAAAi5F,CAAej5F,EAAMy4F,GACnB,OAAIp4F,KAAK4J,WAAWjK,OACfy4F,GAAM9tF,UAAUuuF,WACdT,EAAK9tF,SAASuuF,SAAShqE,SAAS,UAAYupE,EAAK9tF,SAASuuF,SAAShqE,SAAS,UACrF,EAEA,YAAAroB,GACEpG,OAAO04F,KAAK,2DAA4D,SAC1E,EAEA,WAAAnvF,CAAYyuF,GACV,IAAKA,EAAM,OAAO,EAElB,GAAIA,EAAK9tF,UAAUuuF,UAAUhqE,SAAS,SAAU,OAAO,EAEvD,MAAMkqE,EAAWX,EAAK9tF,UAAUC,UAAY6tF,EAAKtuF,IAAM,GACjDkvF,EAAYD,EAASE,UAAUF,EAAS9Y,YAAY,KAAO,GAAGpmE,cAC9Dq/E,EAAkB,CAAC,MAAO,OAAQ,MAAO,MAAO,MAAO,OAAQ,MAAO,MAAO,OAAQ,MAAO,OAAQ,OAAQ,QAClH,OAAOA,EAAgBrqE,SAASmqE,EAClC,EAEA,WAAA9uF,CAAYkuF,GACV,IAAKA,EAAM,OAAO,EAElB,GAAIA,EAAK9tF,UAAUuuF,UAAUhqE,SAAS,SAAU,OAAO,EAEvD,MAAMkqE,EAAWX,EAAK9tF,UAAUC,UAAY6tF,EAAKtuF,IAAM,GACjDkvF,EAAYD,EAASE,UAAUF,EAAS9Y,YAAY,KAAO,GAAGpmE,cAC9Ds/E,EAAkB,CAAC,MAAO,OAAQ,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,OAAQ,OACxG,OAAOA,EAAgBtqE,SAASmqE,EAClC,EAEA,gBAAAtvF,CAAiB0uF,GACVA,GAAMtuF,IACX1J,OAAO04F,KAAK,SAAWV,EAAKtuF,GAAI,SAClC,EAEA,cAAAguF,CAAevqD,GACbvtC,KAAK42F,gBAAkBrpD,EAASsjD,MAChC7wF,KAAK+H,mBAAmBK,QAAUmlC,EAASnlC,SAAW,GACtDpI,KAAK+H,mBAAmBE,QAAUslC,EAAStlC,SAAW,EAG/B,aAAnBslC,EAASsjD,OAEX7wF,KAAK+H,mBAAmBG,MAAQqlC,EAASrlC,OAAS,EAE9CqlC,EAASrlC,OAASqlC,EAASrlC,MAAQ,EACrClI,KAAK+H,mBAAmBC,WAAaH,KAAKiD,IAAI,GAAIyiC,EAAStlC,QAAUslC,EAASrlC,MAAQ,IAGtFlI,KAAK+H,mBAAmBC,WAAaH,KAAKiD,IAAI,GAAuC,GAAnCjD,KAAKiZ,MAAMysB,EAAStlC,QAAU,KAEtD,YAAnBslC,EAASsjD,OAElB7wF,KAAK+H,mBAAmBC,WAAa,GACrChI,KAAK+H,mBAAmBG,MAAQqlC,EAASrlC,OAASlI,KAAK+H,mBAAmBG,OAC9C,cAAnBqlC,EAASsjD,OAElB7wF,KAAK+H,mBAAmBG,MAAQqlC,EAASrlC,OAAS,EAC9CqlC,EAASrlC,OAASqlC,EAASrlC,MAAQ,IACrClI,KAAK+H,mBAAmBC,WAAa,GAAKulC,EAAStlC,QAAUslC,EAASrlC,MAAQ,KAEpD,eAAnBqlC,EAASsjD,MAElB7wF,KAAK+H,mBAAmBC,WAAa,GACT,aAAnBulC,EAASsjD,MAElB7wF,KAAK+H,mBAAmBC,WAAa,GACT,gBAAnBulC,EAASsjD,MAElB7wF,KAAK+H,mBAAmBC,WAAa,GACT,oBAAnBulC,EAASsjD,OAElB7wF,KAAK+H,mBAAmBG,MAAQqlC,EAASrlC,OAAS,EAClDlI,KAAK+H,mBAAmBC,WAAaulC,EAASvlC,YAAc,GAChC,uBAAnBulC,EAASsjD,OAElB7wF,KAAK+H,mBAAmBG,MAAQqlC,EAASrlC,OAAS,EAClDlI,KAAK+H,mBAAmBC,WAAaulC,EAASvlC,YAAc,IAChC,cAAnBulC,EAASsjD,MAElB7wF,KAAK+H,mBAAmBC,WAAa,IACT,aAAnBulC,EAASsjD,QAElB7wF,KAAK+H,mBAAmBK,QAAUmlC,EAASnlC,QAE/C,EAEA,WAAA2vF,CAAYz1B,GACVhnC,QAAQgnC,MAAM,UAAWA,GACzBtiE,KAAKwI,gBAAkB,CACrBJ,QAASk6D,EAAMl6D,QACfK,WAAY65D,EAAM75D,WAClBC,YAAa45D,EAAM55D,YAEvB,EAEA,eAAAH,GACMvI,KAAK82F,mBACP92F,KAAK82F,iBAAiBxF,QACtBtxF,KAAK43F,SAASl8D,KAAK,gBAEjB17B,KAAK+2F,yBACP/2F,KAAK+2F,uBAAuBzF,QAC5BtxF,KAAK43F,SAASl8D,KAAK,cAEjB17B,KAAKg3F,0BACPh3F,KAAKg3F,wBAAwB1F,QAC7BtxF,KAAK43F,SAASl8D,KAAK,aAEvB,EAEA,cAAA/yB,GACE3I,KAAKwI,gBAAkB,KACnBxI,KAAK8I,YACP9I,KAAK8I,YAAa,EAClB9I,KAAK2H,cAAe,EACpB3H,KAAKo5F,UAAU,KACbp5F,KAAK+I,kBAEE/I,KAAKgJ,UACdhJ,KAAKgJ,SAAU,EACfhJ,KAAK2H,cAAe,EACpB3H,KAAKo5F,UAAU,KACbp5F,KAAKiJ,eAGX,EAEA,YAAAL,GACE5I,KAAKwI,gBAAkB,IACzB,IC/hBJ,MAAM,IAA2B,OAAgB,GAAQ,CAAC,CAAC,SAAS,IAAQ,CAAC,YAAY,qBAEzF,U,sLCRA,MAAM,GAAa,CAAC,WACb,SAAS,GAAOnK,EAAMC,EAAQC,EAAQC,EAAQC,EAAOC,GAC1D,MAAMC,GAA+B,QAAkB,qBACvD,OAAO,WAAc,QAAoB,MAAO,CAC9CV,OAAO,QAAgB,CAAC,gBAAiB,CACvC,UAAWQ,EAAM46F,UAEnBnyF,OAAO,QAAgB,CACrB8oB,MAAOzxB,EAAOyxB,SAEf,EAAC,QAAoB,MAAO,CAC7B/xB,MAAO,wBACPiB,QAASZ,EAAO,KAAOA,EAAO,GAAK,IAAIiB,IAASb,EAAS46F,gBAAkB56F,EAAS46F,kBAAkB/5F,KACrG,EAAC,QAAoB,OAAQ,CAC9BtB,OAAO,QAAgB,CAAC,sBAAuB,CAC7C,kBAAmBM,EAAOg7F,gBAE3B,QAAiB76F,EAAS86F,cAAe,IAAI,QAAa76F,EAA8B,CACzFU,KAAM,eACNpB,MAAO,2BACH,QAAa,MAAa,CAC9BwB,KAAM,iBACL,CACDG,SAAS,QAAS,IAAM,EAAC,SAAgB,QAAoB,MAAO,CAClE3B,MAAO,yBACPiB,QAASZ,EAAO,KAAOA,EAAO,IAAK,SAAe,OAAU,CAAC,WAC5D,GAAE,SAAW,IAAO,QAAoB,KAAW,MAAM,QAAYC,EAAOuI,QAASgpC,KAC/E,WAAc,QAAoB,MAAO,CAC9C/wC,IAAK+wC,EAAOlyC,MACZK,OAAO,QAAgB,CAAC,uBAAwB,CAC9C,cAAeM,EAAOg7F,aAAezpD,EAAOlyC,SAE9CsB,QAASC,GAAUT,EAAS+6F,aAAa3pD,EAAOlyC,QAC/C,EAAC,QAAYS,EAAKq7F,OAAQ,SAAU,CACrC5pD,OAAQA,GACP,IAAM,CAACA,EAAOzwC,OAAQ,WAAc,QAAaV,EAA8B,CAChFI,IAAK,EACLM,KAAMywC,EAAOzwC,KACbpB,MAAO,eACN,KAAM,EAAG,CAAC,WAAY,QAAoB,IAAI,IAAO,QAAoB,OAAQ,MAAM,QAAiB6xC,EAAO8I,OAAQ,KAAK,IAAQ,GAAI,MACzI,OAAQ,KAAM,CAAC,CAAC,MAAQn6C,EAAM46F,YAClCh4F,EAAG,KACA,EACP,CC1CA,QACE5B,KAAM,eACNC,MAAO,CACL65F,WAAY,CACV55F,KAAM,CAACrC,OAAQC,QACfqC,QAAS,IAEXkH,QAAS,CACPnH,KAAM8N,MACNk+E,UAAU,GAGZgO,YAAa,CACXh6F,KAAMrC,OACNsC,QAAS,OAEXowB,MAAO,CACLrwB,KAAMrC,OACNsC,QAAS,UAGbg6F,MAAO,CAAC,oBAAqB,UAC7B,IAAA95F,GACE,MAAO,CACLu5F,QAAQ,EAEZ,EACApC,SAAU,CACR,YAAAuC,GACE,MAAMK,EAAW75F,KAAK8G,QAAQ04C,KAAKs6C,GAAOA,EAAIl8F,QAAUoC,KAAKu5F,YAC7D,OAAOM,EAAWA,EAASjhD,MAAQ54C,KAAK25F,WAC1C,GAEF,OAAAr5F,GACE4iC,SAAS3iC,iBAAiB,QAASP,KAAK+5F,mBAC1C,EACA,aAAAC,GACE92D,SAASziC,oBAAoB,QAAST,KAAK+5F,mBAC7C,EACAh6F,QAAS,CACP,cAAAu5F,GACEt5F,KAAKq5F,QAAUr5F,KAAKq5F,MACtB,EACA,YAAAI,CAAa77F,GACXoC,KAAKC,MAAM,oBAAqBrC,GAChCoC,KAAKC,MAAM,SAAUrC,GACrBoC,KAAKq5F,QAAS,CAChB,EACA,kBAAAU,CAAmB78F,GACZ8C,KAAKi6F,IAAIvqC,SAASxyD,EAAEohB,UACvBte,KAAKq5F,QAAS,EAElB,IC/CJ,MAAM,IAA2B,OAAgB,GAAQ,CAAC,CAAC,SAAS,IAAQ,CAAC,YAAY,qBAEzF,UCRA,MAAM,GAAa,CACjBp7F,MAAO,mBAEH,GAAa,CACjBA,MAAO,eAEH,GAAa,CACjBA,MAAO,eAEH,GAAa,CACjBA,MAAO,kBAEH,GAAa,CACjBA,MAAO,gBAEH,GAAa,CACjBA,MAAO,eAEH,GAAa,CACjBc,IAAK,EACLd,MAAO,uBAEH,GAAa,CACjBc,IAAK,EACLd,MAAO,iBAEH,GAAa,CAAC,cAAe,gBAC7B,GAAc,CAClBA,MAAO,eAEH,GAAc,CAClBA,MAAO,cAEH,GAAc,CAClBA,MAAO,gBAEH,GAAc,CAClBA,MAAO,aAEH,GAAc,CAClBA,MAAO,aAEH,GAAc,CAClBA,MAAO,aAEH,GAAc,CAClBA,MAAO,aAEH,GAAc,CAClBc,IAAK,EACLd,MAAO,aAEH,GAAc,CAClBA,MAAO,aAEH,GAAc,CAClBc,IAAK,EACLd,MAAO,aAEH,GAAc,CAAC,SACf,GAAc,CAClBA,MAAO,aAEH,GAAc,CAClBA,MAAO,aAEH,GAAc,CAClBc,IAAK,EACLd,MAAO,aAEH,GAAc,CAAC,SACf,GAAc,CAClBA,MAAO,aAEH,GAAc,CAClBA,MAAO,aAEH,GAAc,CAClBA,MAAO,aAEH,GAAc,CAClBA,MAAO,aAEH,GAAc,CAClBA,MAAO,aAEH,GAAc,CAClBA,MAAO,aAEH,GAAc,CAClBc,IAAK,EACLd,MAAO,cAEH,GAAc,CAClBA,MAAO,cAEH,GAAc,CAClBA,MAAO,gBAEH,GAAc,CAClBc,IAAK,EACLd,MAAO,aAEH,GAAc,CAClBA,MAAO,gBAEH,GAAc,CAClBA,MAAO,eAEH,GAAc,CAClBA,MAAO,gBAEF,SAAS,GAAOI,EAAMC,EAAQC,EAAQC,EAAQC,EAAOC,GAC1D,MAAMC,GAA+B,QAAkB,qBACjDiC,EAAwB,KACxBs5F,EAA0B,GAC1Bp0F,EAAuB,KACvBq0F,EAAoB,KACpBC,EAAuB,MACvBv0F,EAAyB,KACzBw0F,EAAuB,MACvBC,EAAuB,MACvBC,EAA0B,MAC1BC,EAAsB,MACtBC,EAA6B,MAC7BC,EAAqB,MACrBC,EAAuB,MACvBC,EAAkC,MAClCC,EAA6B,MAC7B70F,EAAqB,IAC3B,OAAO,UAAiB,WAAc,QAAoB,MAAO,GAAY,EAAC,QAAoB,MAAO,GAAY,EAAC,QAAoB,KAAM,GAAY,CAAC1H,EAAO,MAAQA,EAAO,KAAM,QAAiB,YAAa,KAAK,QAAasC,EAAuB,CAC9PM,QAAS,0BACTC,UAAW,SACV,CACDvB,SAAS,QAAS,IAAM,EAAC,QAAajB,EAA8B,CAClEU,KAAM,kBACNpB,MAAO,gBAEToD,EAAG,OACC,QAAoB,MAAO,GAAY,EAAC,QAAa64F,EAAyB,CAClFX,WAAY96F,EAAMq8F,cAClB,sBAAuBx8F,EAAO,KAAOA,EAAO,GAAKa,GAAUV,EAAMq8F,cAAgB37F,GACjF2H,QAASpI,EAASq8F,cAClBpB,YAAa,SACb3pE,MAAO,SACN,KAAM,EAAG,CAAC,aAAc,aAAa,QAAalqB,EAAsB,CACzEnG,KAAM,UACNT,QAASZ,EAAO,KAAOA,EAAO,GAAKa,GAAUV,EAAMu8F,eAAgB,GACnE/8F,MAAO,WACN,CACD2B,SAAS,QAAS,IAAM,EAAC,QAAajB,EAA8B,CAClEU,KAAM,OACN6H,MAAO,CACL,eAAgB,SAEhB5I,EAAO,MAAQA,EAAO,KAAM,QAAiB,UAAW,MAC5D+C,EAAG,UACI,SAAW,IAAO,QAAoB,KAAW,MAAM,QAAY3C,EAASu8F,iBAAkBC,KAC9F,WAAc,QAAoB,MAAO,CAC9Cn8F,IAAKm8F,EAAYt9F,MACjBK,MAAO,iBACN,EAAC,QAAoB,MAAO,GAAY,EAAC,QAAoB,MAAO,GAAY,EAAC,QAAaU,EAA8B,CAC7HU,KAAMX,EAASy8F,eAAeD,EAAYt9F,OAC1CK,MAAO,cACN,KAAM,EAAG,CAAC,UAAU,QAAoB,OAAQ,MAAM,QAAiBi9F,EAAYtiD,OAAQ,IAAI,QAAauhD,EAAmB,CAChI7xF,KAAM,QACN3I,KAAM,OACN1B,MAAO,iBACN,CACD2B,SAAS,QAAS,IAAM,EAAC,SAAiB,QAAiBlB,EAAS08F,eAAeF,EAAYt9F,OAAOgJ,QAAS,KAC/GvF,EAAG,GACF,QAAS3C,EAAS28F,eAAeH,EAAYt9F,SAAU,WAAc,QAAoB,MAAO,GAAY,CAACU,EAAO,MAAQA,EAAO,KAAM,QAAoB,OAAQ,CACtKL,MAAO,gBACN,QAAS,KAAK,QAAam8F,EAAsB,CAClDb,WAAY76F,EAAS48F,YAAYJ,EAAYt9F,OAAO29F,YAAYhpC,QAChE,sBAAuBpzD,GAAUT,EAAS48F,YAAYJ,EAAYt9F,OAAO29F,YAAYhpC,QAAUpzD,EAC/FmJ,KAAM,QACNc,SAAU1K,EAAS88F,cAClB,KAAM,EAAG,CAAC,aAAc,sBAAuB,iBAAkB,QAAoB,IAAI,KAAS98F,EAAS08F,eAAeF,EAAYt9F,OAAOgJ,OAAS,IAAK,WAAc,QAAoB,MAAO,GAAY,GAAE,SAAW,IAAO,QAAoB,KAAW,MAAM,QAAYlI,EAAS08F,eAAeF,EAAYt9F,OAAQ,CAACqJ,EAASjI,MACrU,WAAc,QAAoB,MAAO,CAC9CD,IAAKkI,EAAQxH,MAAQT,EACrBf,OAAO,QAAgB,CAAC,eAAgB,CAACi9F,EAAYt9F,MAAO,CAC1D,UAAaqJ,EAAQsrD,QACrB,MAAStrD,EAAQw0F,UAEnBC,YAAav8F,GAAUT,EAASi9F,oBAAoBx8F,EAAQ+7F,EAAYt9F,MAAOoB,GAC/E48F,aAAcz8F,GAAUT,EAASm9F,qBAAqBX,EAAYt9F,MAAOoB,IACxE,EAAC,QAAoB,MAAO,CAC7Bf,MAAO,YACP69F,SAAS,EACT5yF,IAAK,QAAQgyF,EAAYt9F,SAASoB,KACjC,KAAM,MAAM,QAAoB,MAAO,GAAa,EAAC,QAAoB,MAAO,GAAa,EAAC,QAAoB,OAAQ,IAAa,QAAiBiI,EAAQxH,MAAQ,SAAU,GAAIwH,EAAQw0F,QAAS,WAAc,QAAatB,EAAmB,CACtPp7F,IAAK,EACLuJ,KAAM,QACN3I,KAAM,WACL,CACDC,SAAS,QAAS,IAAM,IAAKtB,EAAO,MAAQA,EAAO,IAAM,EAAC,QAAiB,QAAS,OACpF+C,EAAG,MACC,QAAoB,IAAI,MAAS,QAAa+4F,EAAsB,CACxEb,WAAYtyF,EAAQsrD,QACpB,sBAAuBpzD,GAAU8H,EAAQsrD,QAAUpzD,EACnDmJ,KAAM,QACNpJ,QAASZ,EAAO,KAAOA,EAAO,IAAK,SAAe,OAAU,CAAC,UAC7D8K,SAAU1K,EAAS88F,cAClB,KAAM,EAAG,CAAC,aAAc,sBAAuB,gBAAgB,QAAoB,MAAO,GAAa,EAAC,QAAoB,MAAO,GAAa,CAAuB,aAAtBN,EAAYt9F,QAAwB,WAAc,QAAoB,KAAW,CACnOmB,IAAK,GACJ,EAAC,QAAoB,MAAO,GAAa,EAAC,QAAaJ,EAA8B,CACtFU,KAAM,QACNpB,MAAO,eACL,QAAoB,OAAQ,GAAa,SAAU,QAAiBS,EAASq9F,SAAS90F,EAAQ+0F,WAAY,KAAM/0F,EAAQg1F,SAAU,WAAc,QAAoB,MAAO,GAAa,EAAC,QAAat9F,EAA8B,CACtOU,KAAM,WACNpB,MAAO,eACL,QAAoB,OAAQ,GAAa,aAAc,QAAiBS,EAASq9F,SAAS90F,EAAQg1F,SAAU,OAAQ,QAAoB,IAAI,IAAQ,KAA6B,SAAtBf,EAAYt9F,QAAoB,WAAc,QAAoB,MAAO,GAAa,EAAC,QAAae,EAA8B,CAC/RU,KAAM,OACNpB,MAAO,eACL,QAAoB,OAAQ,CAC9BA,MAAO,YACPqB,MAAO2H,EAAQi1F,YACd,QAAiBj1F,EAAQi1F,WAAa,WAAY,EAAG,OAAwC,OAAtBhB,EAAYt9F,QAAkB,WAAc,QAAoB,KAAW,CACnJmB,IAAK,GACJ,EAAC,QAAoB,MAAO,GAAa,EAAC,QAAaJ,EAA8B,CACtFU,KAAM,SACNpB,MAAO,eACL,QAAoB,OAAQ,IAAa,QAAiBgJ,EAAQk1F,YAAc,OAAQ,KAAMl1F,EAAQm1F,WAAY,WAAc,QAAoB,MAAO,GAAa,EAAC,QAAaz9F,EAA8B,CACtNU,KAAM,OACNpB,MAAO,eACL,QAAoB,OAAQ,CAC9BA,MAAO,YACPqB,MAAO2H,EAAQm1F,WACd,QAAiBn1F,EAAQm1F,UAAW,EAAG,QAAkB,QAAoB,IAAI,IAAQ,KAA6B,YAAtBlB,EAAYt9F,QAAuB,WAAc,QAAoB,KAAW,CACjLmB,IAAK,GACJ,EAAC,QAAoB,MAAO,GAAa,EAAC,QAAaJ,EAA8B,CACtFU,KAAM,QACNpB,MAAO,eACL,QAAoB,OAAQ,GAAa,SAAU,QAAiBS,EAASq9F,SAAS90F,EAAQ+0F,WAAY,MAAM,QAAoB,MAAO,GAAa,EAAC,QAAar9F,EAA8B,CACtMU,KAAM,UACNpB,MAAO,eACL,QAAoB,OAAQ,GAAa,aAAc,QAAiBS,EAASq9F,SAAS90F,EAAQo1F,YAAa,KAAMp1F,EAAQq1F,UAAW,WAAc,QAAanC,EAAmB,CACxLp7F,IAAK,EACLuJ,KAAM,QACN3I,KAAM,WACL,CACDC,SAAS,QAAS,IAAM,IAAKtB,EAAO,MAAQA,EAAO,IAAM,EAAC,QAAiB,SAAU,OACrF+C,EAAG,MACC,QAAoB,IAAI,IAAQ,KAA6B,gBAAtB65F,EAAYt9F,QAA2B,WAAc,QAAoB,KAAW,CAC/HmB,IAAK,GACJ,EAAC,QAAoB,MAAO,GAAa,EAAC,QAAaJ,EAA8B,CACtFU,KAAM,WACNpB,MAAO,eACL,QAAoB,OAAQ,IAAa,QAAiBgJ,EAAQs1F,MAAQ,SAAU,KAAMt1F,EAAQu1F,YAAa,WAAc,QAAarC,EAAmB,CAC/Jp7F,IAAK,EACLuJ,KAAM,QACN3I,KAAM,WACL,CACDC,SAAS,QAAS,IAAM,IAAKtB,EAAO,MAAQA,EAAO,IAAM,EAAC,QAAiB,MAAO,OAClF+C,EAAG,MACC,QAAoB,IAAI,IAAQ,MAAO,QAAoB,IAAI,KAAS4F,EAAQw1F,OAAOlqC,UAAW,WAAc,QAAoB,MAAO,GAAa,EAAC,QAAa1sD,EAAwB,CAClMmC,WAAYtJ,EAASg+F,mBAAmBz1F,GACxCQ,OAAQ/I,EAASi+F,eAAe11F,GAChC,eAAgB,GACf,KAAM,EAAG,CAAC,aAAc,YAAY,QAAoB,OAAQ,IAAa,QAAiBvI,EAASk+F,aAAa31F,IAAW,OAAQ,QAAoB,IAAI,MAAS,QAAoB,MAAO,GAAa,EAAC,QAAanB,EAAsB,CACrPmqB,KAAM,GACNtwB,KAAM,UACN2I,KAAM,QACNpJ,QAASC,GAAUT,EAASm+F,iBAAiB3B,EAAYt9F,MAAOoB,IAC/D,CACDY,SAAS,QAAS,IAAM,EAAC,QAAajB,EAA8B,CAClEU,KAAM,MACN6H,MAAO,CACL,eAAgB,SAEhB5I,EAAO,MAAQA,EAAO,KAAM,QAAiB,OAAQ,MACzD+C,EAAG,GACF,EAAG,CAAC,aAAa,QAAayE,EAAsB,CACrDmqB,KAAM,GACNtwB,KAAM,UACN2I,KAAM,QACNpJ,QAASC,GAAUT,EAASo+F,eAAe5B,EAAYt9F,MAAOoB,IAC7D,CACDY,SAAS,QAAS,IAAM,EAAC,QAAajB,EAA8B,CAClEU,KAAM,OACN6H,MAAO,CACL,eAAgB,SAEhB5I,EAAO,MAAQA,EAAO,KAAM,QAAiB,OAAQ,MACzD+C,EAAG,GACF,EAAG,CAAC,aAAa,QAAayE,EAAsB,CACrDmqB,KAAM,GACNtwB,KAAM,SACN2I,KAAM,QACNpJ,QAASC,GAAUT,EAASq+F,cAAc7B,EAAYt9F,MAAOoB,GAC7DgC,SAAUiG,EAAQw0F,OACjB,CACD77F,SAAS,QAAS,IAAM,EAAC,QAAajB,EAA8B,CAClEU,KAAM,YACN6H,MAAO,CACL,eAAgB,SAEhB5I,EAAO,MAAQA,EAAO,KAAM,QAAiB,OAAQ,MACzD+C,EAAG,GACF,EAAG,CAAC,UAAW,gBAAiB,GAAI,MACrC,WAAY,WAAc,QAAoB,MAAO,GAAa,EAAC,QAAa1C,EAA8B,CAChHU,KAAM,QACNpB,MAAO,gBACL,QAAoB,OAAQ,KAAM,OAAQ,QAAiBi9F,EAAYtiD,OAAS,MAAO,UACzF,OAAO,QAAa+hD,EAAsB,CAC5CpB,WAAY96F,EAAMu8F,cAClB,sBAAuB18F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMu8F,cAAgB77F,GACnFG,MAAO,QACPrB,MAAO,iBACP,mBAAoB,GACpB++F,SAAUt+F,EAASu+F,cAClB,CACD5kB,QAAQ,QAAS,IAAM,EAAC,QAAavyE,EAAsB,CACzD5G,QAASZ,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMu8F,eAAgB,IACpE,CACDp7F,SAAS,QAAS,IAAM,IAAKtB,EAAO,MAAQA,EAAO,IAAM,EAAC,QAAiB,MAAO,OAClF+C,EAAG,KACD,QAAayE,EAAsB,CACrCnG,KAAM,UACNT,QAASR,EAASw+F,mBACjB,CACDt9F,SAAS,QAAS,IAAM,IAAKtB,EAAO,MAAQA,EAAO,IAAM,EAAC,QAAiB,QAAS,OACpF+C,EAAG,GACF,EAAG,CAAC,cACPzB,SAAS,QAAS,IAAM,EAAC,QAAa86F,EAAoB,CACxDyC,MAAO1+F,EAAM2+F,WACb,iBAAkB,MAClBl0F,IAAK,UACLm0F,MAAO5+F,EAAM6+F,UACZ,CACD19F,SAAS,QAAS,IAAM,EAAC,QAAa26F,EAAyB,CAC7D3hD,MAAO,OACP5d,KAAM,QACL,CACDp7B,SAAS,QAAS,IAAM,EAAC,QAAa06F,EAAsB,CAC1Df,WAAY96F,EAAM2+F,WAAWz9F,KAC7B,sBAAuBrB,EAAO,KAAOA,EAAO,GAAKa,GAAUV,EAAM2+F,WAAWz9F,KAAOR,GACnFw6F,YAAa,UACbzyF,MAAO,CACL,MAAS,QAEXkC,SAAU1K,EAAS6+F,qBAClB,CACD39F,SAAS,QAAS,IAAM,GAAE,SAAW,IAAO,QAAoB,KAAW,MAAM,QAAYnB,EAAM++F,gBAAiBC,KAC3G,WAAc,QAAapD,EAAsB,CACtDt7F,IAAK0+F,EAAG7/F,MACRg7C,MAAO6kD,EAAG7kD,MACVh7C,MAAO6/F,EAAG7/F,OACT,CACDgC,SAAS,QAAS,IAAM,EAAC,QAAajB,EAA8B,CAClEU,KAAMX,EAASy8F,eAAesC,EAAG7/F,OACjCK,MAAO,sBACN,KAAM,EAAG,CAAC,UAAU,QAAiB,KAAM,QAAiBw/F,EAAG7kD,OAAQ,KAC1Ev3C,EAAG,GACF,KAAM,CAAC,QAAS,YACjB,QACJA,EAAG,GACF,EAAG,CAAC,aAAc,eACrBA,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,OACP5d,KAAM,QACL,CACDp7B,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAM2+F,WAAW39F,KAC7B,sBAAuBnB,EAAO,KAAOA,EAAO,GAAKa,GAAUV,EAAM2+F,WAAW39F,KAAON,GACnFw6F,YAAa,WACZ,KAAM,EAAG,CAAC,iBACbt4F,EAAG,IACyB,aAA1B5C,EAAM2+F,WAAWz9F,OAAuB,WAAc,QAAoB,KAAW,CACvFZ,IAAK,GACJ,EAAC,QAAaw7F,EAAyB,CACxC3hD,MAAO,YACP5d,KAAM,YACL,CACDp7B,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAM2+F,WAAWpB,SAC7B,sBAAuB19F,EAAO,KAAOA,EAAO,GAAKa,GAAUV,EAAM2+F,WAAWpB,SAAW78F,GACvFQ,KAAM,WACN,gBAAiB,GACjBg6F,YAAa,iBACZ,KAAM,EAAG,CAAC,iBACbt4F,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,UACP5d,KAAM,UACL,CACDp7B,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAM2+F,WAAWnB,OAC7B,sBAAuB39F,EAAO,KAAOA,EAAO,GAAKa,GAAUV,EAAM2+F,WAAWnB,OAAS98F,GACrFQ,KAAM,WACN,gBAAiB,GACjBg6F,YAAa,eACZ,KAAM,EAAG,CAAC,iBACbt4F,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,QACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAM2+F,WAAWM,SAC7B,sBAAuBp/F,EAAO,KAAOA,EAAO,GAAKa,GAAUV,EAAM2+F,WAAWM,SAAWv+F,GACvFw6F,YAAa,iCACZ,KAAM,EAAG,CAAC,iBACbt4F,EAAG,KACA,KAAiC,OAA1B5C,EAAM2+F,WAAWz9F,OAAiB,WAAc,QAAoB,KAAW,CACzFZ,IAAK,GACJ,EAAC,QAAaw7F,EAAyB,CACxC3hD,MAAO,WACP5d,KAAM,YACL,CACDp7B,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAM2+F,WAAWhB,SAC7B,sBAAuB99F,EAAO,KAAOA,EAAO,GAAKa,GAAUV,EAAM2+F,WAAWhB,SAAWj9F,GACvFw6F,YAAa,8CACZ,KAAM,EAAG,CAAC,iBACbt4F,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,UACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAM2+F,WAAWO,UAC7B,sBAAuBr/F,EAAO,KAAOA,EAAO,GAAKa,GAAUV,EAAM2+F,WAAWO,UAAYx+F,GACxFw6F,YAAa,iDACZ,KAAM,EAAG,CAAC,eAAgBr7F,EAAO,MAAQA,EAAO,KAAM,QAAoB,OAAQ,CACnFL,MAAO,YACN,sCAAuC,MAC1CoD,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,QACP5d,KAAM,cACL,CACDp7B,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAM2+F,WAAWjB,WAC7B,sBAAuB79F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAM2+F,WAAWjB,WAAah9F,GAC3Fw6F,YAAa,YACZ,KAAM,EAAG,CAAC,iBACbt4F,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,QACP5d,KAAM,UACL,CACDp7B,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAM2+F,WAAWQ,OAC7B,sBAAuBt/F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAM2+F,WAAWQ,OAASz+F,GACvFw6F,YAAa,aACZ,KAAM,EAAG,CAAC,iBACbt4F,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,UACP5d,KAAM,eACL,CACDp7B,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAM2+F,WAAWS,YAC7B,sBAAuBv/F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAM2+F,WAAWS,YAAc1+F,GAC5FQ,KAAM,WACN,gBAAiB,GACjBg6F,YAAa,cACZ,KAAM,EAAG,CAAC,iBACbt4F,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,SACP5d,KAAM,mBACL,CACDp7B,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAM2+F,WAAWU,gBAC7B,sBAAuBx/F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAM2+F,WAAWU,gBAAkB3+F,GAChGQ,KAAM,WACN,gBAAiB,GACjBg6F,YAAa,aACZ,KAAM,EAAG,CAAC,iBACbt4F,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,QACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAaw6F,EAAsB,CAC1Db,WAAY96F,EAAM2+F,WAAWW,UAC7B,sBAAuBz/F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAM2+F,WAAWW,UAAY5+F,IACzF,KAAM,EAAG,CAAC,eAAgBb,EAAO,MAAQA,EAAO,KAAM,QAAoB,OAAQ,CACnFL,MAAO,YACN,oBAAqB,MACxBoD,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,QACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAaw6F,EAAsB,CAC1Db,WAAY96F,EAAM2+F,WAAWX,MAAMlqC,QACnC,sBAAuBj0D,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAM2+F,WAAWX,MAAMlqC,QAAUpzD,IAC7F,KAAM,EAAG,CAAC,iBACbkC,EAAG,IACD5C,EAAM2+F,WAAWX,OAAOlqC,UAAW,WAAc,QAAoB,KAAW,CAClFxzD,IAAK,GACJ,EAAC,QAAaw7F,EAAyB,CACxC3hD,MAAO,aACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAa66F,EAA4B,CAChElB,WAAY96F,EAAM2+F,WAAWX,MAAMuB,QACnC,sBAAuB1/F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAM2+F,WAAWX,MAAMuB,QAAU7+F,GAC9F2L,IAAK,GACLgxD,KAAM,EACN8kB,UAAW,GACV,KAAM,EAAG,CAAC,iBACbv/E,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,YACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAa66F,EAA4B,CAChElB,WAAY96F,EAAM2+F,WAAWX,MAAMwB,UACnC,sBAAuB3/F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAM2+F,WAAWX,MAAMwB,UAAY9+F,GAChG2L,IAAK,GACLD,IAAK,IACLixD,KAAM,GACL,KAAM,EAAG,CAAC,iBACbz6D,EAAG,KACA,MAAO,QAAoB,IAAI,IAAQ,KAAiC,YAA1B5C,EAAM2+F,WAAWz9F,OAAsB,WAAc,QAAoB,KAAW,CACrIZ,IAAK,GACJ,EAAC,QAAaw7F,EAAyB,CACxC3hD,MAAO,YACP5d,KAAM,YACL,CACDp7B,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAM2+F,WAAWpB,SAC7B,sBAAuB19F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAM2+F,WAAWpB,SAAW78F,GACzFQ,KAAM,WACN,gBAAiB,GACjBg6F,YAAa,iBACZ,KAAM,EAAG,CAAC,iBACbt4F,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,aACP5d,KAAM,aACL,CACDp7B,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAM2+F,WAAWf,UAC7B,sBAAuB/9F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAM2+F,WAAWf,UAAYl9F,GAC1FQ,KAAM,WACN,gBAAiB,GACjBg6F,YAAa,kBACZ,KAAM,EAAG,CAAC,iBACbt4F,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,QACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAM2+F,WAAWM,SAC7B,sBAAuBp/F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAM2+F,WAAWM,SAAWv+F,GACzFw6F,YAAa,iCACZ,KAAM,EAAG,CAAC,iBACbt4F,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,YACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAaw6F,EAAsB,CAC1Db,WAAY96F,EAAM2+F,WAAWd,QAC7B,sBAAuBh+F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAM2+F,WAAWd,QAAUn9F,IACvF,KAAM,EAAG,CAAC,eAAgBb,EAAO,MAAQA,EAAO,KAAM,QAAoB,OAAQ,CACnFL,MAAO,YACN,yBAA0B,MAC7BoD,EAAG,KACD,QAAoB,MAAO,GAAa,EAAC,QAAa1C,EAA8B,CACtFU,KAAM,uBACN6H,MAAO,CACL,eAAgB,SAEhB5I,EAAO,MAAQA,EAAO,KAAM,QAAiB,oCAAqC,OAAQ,KAAiC,gBAA1BG,EAAM2+F,WAAWz9F,OAA0B,WAAc,QAAoB,KAAW,CAC3LZ,IAAK,GACJ,EAAC,QAAaw7F,EAAyB,CACxC3hD,MAAO,MACP5d,KAAM,QACL,CACDp7B,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAM2+F,WAAWb,KAC7B,sBAAuBj+F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAM2+F,WAAWb,KAAOp9F,GACrFw6F,YAAa,0BACZ,KAAM,EAAG,CAAC,iBACbt4F,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,eACP5d,KAAM,SACL,CACDp7B,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAM2+F,WAAWc,MAC7B,sBAAuB5/F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAM2+F,WAAWc,MAAQ/+F,GACtFQ,KAAM,WACN,gBAAiB,GACjBg6F,YAAa,oBACZ,KAAM,EAAG,CAAC,iBACbt4F,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,QACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAaw6F,EAAsB,CAC1Db,WAAY96F,EAAM2+F,WAAWZ,UAC7B,sBAAuBl+F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAM2+F,WAAWZ,UAAYr9F,IACzF,KAAM,EAAG,CAAC,eAAgBb,EAAO,MAAQA,EAAO,KAAM,QAAoB,OAAQ,CACnFL,MAAO,YACN,gBAAiB,MACpBoD,EAAG,KACA,MAAO,QAAoB,IAAI,KACpCA,EAAG,GACF,EAAG,CAAC,QAAS,YAChBA,EAAG,GACF,EAAG,CAAC,aAAc,cAAc,QAAas5F,EAAsB,CACpEpB,WAAY96F,EAAM0/F,iBAClB,sBAAuB7/F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAM0/F,iBAAmBh/F,GACtFG,MAAO,WAAab,EAAM2/F,gBAAgB3+F,MAAQ,IAClDxB,MAAO,iBACP++F,SAAUt+F,EAAS2/F,iBAClB,CACDhmB,QAAQ,QAAS,IAAM,EAAC,QAAavyE,EAAsB,CACzD5G,QAASZ,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAM0/F,kBAAmB,IACvE,CACDv+F,SAAS,QAAS,IAAM,IAAKtB,EAAO,MAAQA,EAAO,IAAM,EAAC,QAAiB,MAAO,OAClF+C,EAAG,KACD,QAAayE,EAAsB,CACrCnG,KAAM,UACNT,QAASR,EAAS4/F,oBACjB,CACD1+F,SAAS,QAAS,IAAM,IAAKtB,EAAO,MAAQA,EAAO,IAAM,EAAC,QAAiB,MAAO,OAClF+C,EAAG,GACF,EAAG,CAAC,cACPzB,SAAS,QAAS,IAAM,EAAC,QAAai7F,EAA4B,CAChE0D,OAAQ,EACR1uE,OAAQ,IACP,CACDjwB,SAAS,QAAS,IAAM,EAAC,QAAag7F,EAAiC,CACrEhiD,MAAO,QACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,SAAiB,QAAiBnB,EAAM2/F,gBAAgB3+F,MAAO,KACxF4B,EAAG,KACD,QAAau5F,EAAiC,CAChDhiD,MAAO,QACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,SAAiB,QAAiBlB,EAAS8/F,oBAAoB//F,EAAMggG,qBAAsB,KACpHp9F,EAAG,KACD,QAAau5F,EAAiC,CAChDhiD,MAAO,MACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAau6F,EAAmB,CACvDx6F,KAAMlB,EAAM2/F,gBAAgB7rC,QAAU,UAAY,QACjD,CACD3yD,SAAS,QAAS,IAAM,EAAC,SAAiB,QAAiBnB,EAAM2/F,gBAAgB7rC,QAAU,MAAQ,OAAQ,KAC3GlxD,EAAG,GACF,EAAG,CAAC,WACPA,EAAG,IACD5C,EAAM2/F,gBAAgB3C,QAAS,WAAc,QAAab,EAAiC,CAC7F77F,IAAK,EACL65C,MAAO,QACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAau6F,EAAmB,CACvDx6F,KAAM,WACL,CACDC,SAAS,QAAS,IAAM,IAAKtB,EAAO,MAAQA,EAAO,IAAM,EAAC,QAAiB,QAAS,OACpF+C,EAAG,MAELA,EAAG,MACC,QAAoB,IAAI,GAAoC,aAA7B5C,EAAMggG,qBAAqC,WAAc,QAAoB,KAAW,CAC3H1/F,IAAK,GACJ,EAAC,QAAa67F,EAAiC,CAChDhiD,MAAO,aACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,SAAiB,QAAiBlB,EAASq9F,SAASt9F,EAAM2/F,gBAAgBpC,SAAU,KAAM,KACnH36F,EAAG,KACD,QAAau5F,EAAiC,CAChDhiD,MAAO,WACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,SAAiB,QAAiBlB,EAASq9F,SAASt9F,EAAM2/F,gBAAgBnC,OAAQ,IAAK,KAChH56F,EAAG,KACD,QAAau5F,EAAiC,CAChDhiD,MAAO,QACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,SAAiB,QAAiBnB,EAAM2/F,gBAAgBV,UAAY,OAAQ,KACrGr8F,EAAG,KACA,KAAoC,SAA7B5C,EAAMggG,qBAAiC,WAAc,QAAa7D,EAAiC,CAC7G77F,IAAK,EACL65C,MAAO,UACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzD,cAAe/7F,EAAM2/F,gBAAgBlC,WAAa,MAClDwC,SAAU,IACT,KAAM,EAAG,CAAC,kBACbr9F,EAAG,KAC8B,OAA7B5C,EAAMggG,qBAA+B,WAAc,QAAoB,KAAW,CACtF1/F,IAAK,GACJ,EAAC,QAAa67F,EAAiC,CAChDhiD,MAAO,YACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzD,cAAe/7F,EAAM2/F,gBAAgBhC,SACrCsC,SAAU,IACT,KAAM,EAAG,CAAC,kBACbr9F,EAAG,KACD,QAAau5F,EAAiC,CAChDhiD,MAAO,UACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzD,cAAe/7F,EAAM2/F,gBAAgBT,WAAa,MAClDe,SAAU,IACT,KAAM,EAAG,CAAC,kBACbr9F,EAAG,KACD,QAAau5F,EAAiC,CAChDhiD,MAAO,SACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,SAAiB,QAAiBnB,EAAM2/F,gBAAgBjC,YAAa,KAC9F96F,EAAG,KACD,QAAau5F,EAAiC,CAChDhiD,MAAO,SACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,SAAiB,QAAiBnB,EAAM2/F,gBAAgBR,QAAS,KAC1Fv8F,EAAG,KACD,QAAau5F,EAAiC,CAChDhiD,MAAO,QACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,SAAiB,QAAiBnB,EAAM2/F,gBAAgBL,UAAY,IAAM,KAAM,KACzG18F,EAAG,KACA,KAAoC,YAA7B5C,EAAMggG,qBAAoC,WAAc,QAAoB,KAAW,CACjG1/F,IAAK,GACJ,EAAC,QAAa67F,EAAiC,CAChDhiD,MAAO,aACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,SAAiB,QAAiBlB,EAASq9F,SAASt9F,EAAM2/F,gBAAgBpC,SAAU,KAAM,KACnH36F,EAAG,KACD,QAAau5F,EAAiC,CAChDhiD,MAAO,cACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,SAAiB,QAAiBlB,EAASq9F,SAASt9F,EAAM2/F,gBAAgB/B,UAAW,IAAK,KACnHh7F,EAAG,KACD,QAAau5F,EAAiC,CAChDhiD,MAAO,QACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,SAAiB,QAAiBnB,EAAM2/F,gBAAgBV,UAAY,OAAQ,KACrGr8F,EAAG,KACD,QAAau5F,EAAiC,CAChDhiD,MAAO,YACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,SAAiB,QAAiBnB,EAAM2/F,gBAAgB9B,QAAU,IAAM,KAAM,KACvGj7F,EAAG,KACA,KAAoC,gBAA7B5C,EAAMggG,qBAAwC,WAAc,QAAoB,KAAW,CACrG1/F,IAAK,GACJ,EAAC,QAAa67F,EAAiC,CAChDhiD,MAAO,OACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,SAAiB,QAAiBnB,EAAM2/F,gBAAgB7B,MAAO,KACxFl7F,EAAG,KACD,QAAau5F,EAAiC,CAChDhiD,MAAO,QACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,SAAiB,QAAiBnB,EAAM2/F,gBAAgB5B,UAAY,IAAM,KAAM,KACzGn7F,EAAG,KACA,MAAO,QAAoB,IAAI,GAAO5C,EAAM2/F,gBAAgB3B,OAAOlqC,UAAW,WAAc,QAAoB,KAAW,CAC9HxzD,IAAK,GACJ,EAAC,QAAa67F,EAAiC,CAChDhiD,MAAO,QACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,SAAiB,QAAiBnB,EAAM2/F,gBAAgB3B,OAAOuB,SAAW,MAAO,KAC1G38F,EAAG,KACD,QAAau5F,EAAiC,CAChDhiD,MAAO,QACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,SAAiB,QAAiBnB,EAAM2/F,gBAAgB3B,OAAOwB,WAAa,IAAK,KAC1G58F,EAAG,KACD,QAAau5F,EAAiC,KAAM,CACtDhiD,OAAO,QAAS,IAAM,EAAC,QAAoB,OAAQ,GAAa,CAACt6C,EAAO,MAAQA,EAAO,KAAM,QAAiB,UAAW,KAAK,QAAawH,EAAsB,CAC/J64F,KAAM,GACNh/F,KAAM,UACNT,QAASR,EAASkgG,aAClB3gG,MAAO,eACN,CACD2B,SAAS,QAAS,IAAM,EAAC,QAAajB,EAA8B,CAClEU,KAAM,WACNpB,OAAO,QAAgB,CACrB,UAAWQ,EAAMogG,gBAElB,KAAM,EAAG,CAAC,YACbx9F,EAAG,GACF,EAAG,CAAC,gBACPzB,SAAS,QAAS,IAAM,EAAC,QAAoB,MAAO,GAAa,EAAC,QAAaiG,EAAwB,CACrGmC,WAAYtJ,EAASg+F,mBAAmBj+F,EAAM2/F,gBAC9C32F,OAAQ/I,EAASi+F,eAAel+F,EAAM2/F,gBACtC,eAAgB,GAChB,eAAe,EACfxwE,OAAQ,IAAMlvB,EAASk+F,aAAan+F,EAAM2/F,iBACzC,KAAM,EAAG,CAAC,aAAc,SAAU,YAAY,QAAoB,MAAO,CAC1EngG,OAAO,QAAgB,CAAC,aAAc,CACpC,gBAAiBS,EAASogG,gBAAgBrgG,EAAM2/F,qBAEjD,QAAiB1/F,EAASqgG,mBAAmBtgG,EAAM2/F,iBAAkB,OACxE/8F,EAAG,KACA,MAAO,QAAoB,IAAI,KACpCA,EAAG,MAELA,EAAG,GACF,EAAG,CAAC,aAAc,QAAS,cAAc,QAAas5F,EAAsB,CAC7EpB,WAAY96F,EAAMugG,eAClB,sBAAuB1gG,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMugG,eAAiB7/F,GACpFG,MAAO,WAAab,EAAMwgG,aAAax/F,MAAQ,IAC/CxB,MAAO,iBACP,mBAAoB,GACpB++F,SAAUt+F,EAASwgG,eAClB,CACD7mB,QAAQ,QAAS,IAAM,EAAC,QAAavyE,EAAsB,CACzD5G,QAASZ,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMugG,gBAAiB,IACrE,CACDp/F,SAAS,QAAS,IAAM,IAAKtB,EAAO,MAAQA,EAAO,IAAM,EAAC,QAAiB,MAAO,OAClF+C,EAAG,KACD,QAAayE,EAAsB,CACrCnG,KAAM,UACNT,QAASR,EAASygG,oBACjB,CACDv/F,SAAS,QAAS,IAAM,IAAKtB,EAAO,MAAQA,EAAO,IAAM,EAAC,QAAiB,QAAS,OACpF+C,EAAG,GACF,EAAG,CAAC,cACPzB,SAAS,QAAS,IAAM,EAAC,QAAa86F,EAAoB,CACxDyC,MAAO1+F,EAAMwgG,YACb,iBAAkB,MAClB/1F,IAAK,WACLm0F,MAAO5+F,EAAM2gG,WACZ,CACDx/F,SAAS,QAAS,IAAM,EAAC,QAAa26F,EAAyB,CAC7D3hD,MAAO,OACP5d,KAAM,QACL,CACDp7B,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAMwgG,YAAYx/F,KAC9B,sBAAuBnB,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMwgG,YAAYx/F,KAAON,GACtF6B,SAAUvC,EAAMwgG,YAAYxD,OAC3B,KAAM,EAAG,CAAC,aAAc,eAC3Bp6F,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,QACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAaw6F,EAAsB,CAC1Db,WAAY96F,EAAMwgG,YAAY1sC,QAC9B,sBAAuBj0D,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMwgG,YAAY1sC,QAAUpzD,IACxF,KAAM,EAAG,CAAC,iBACbkC,EAAG,IAC4B,aAA7B5C,EAAMggG,qBAAqC,WAAc,QAAoB,KAAW,CAC1F1/F,IAAK,GACJ,EAAC,QAAaw7F,EAAyB,CACxC3hD,MAAO,YACP5d,KAAM,YACL,CACDp7B,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAMwgG,YAAYjD,SAC9B,sBAAuB19F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMwgG,YAAYjD,SAAW78F,GAC1F6B,SAAUvC,EAAMwgG,YAAYxD,MAC5B97F,KAAM,WACN,gBAAiB,IAChB,KAAM,EAAG,CAAC,aAAc,eAC3B0B,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,UACP5d,KAAM,UACL,CACDp7B,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAMwgG,YAAYhD,OAC9B,sBAAuB39F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMwgG,YAAYhD,OAAS98F,GACxF6B,SAAUvC,EAAMwgG,YAAYxD,MAC5B97F,KAAM,WACN,gBAAiB,IAChB,KAAM,EAAG,CAAC,aAAc,eAC3B0B,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,QACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAMwgG,YAAYvB,SAC9B,sBAAuBp/F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMwgG,YAAYvB,SAAWv+F,GAC1Fw6F,YAAa,8BACZ,KAAM,EAAG,CAAC,iBACbt4F,EAAG,KACA,KAAoC,SAA7B5C,EAAMggG,qBAAiC,WAAc,QAAoB,KAAW,CAC9F1/F,IAAK,GACJ,EAAC,QAAaw7F,EAAyB,CACxC3hD,MAAO,UACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAMwgG,YAAY/C,UAC9B,sBAAuB59F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMwgG,YAAY/C,UAAY/8F,IAC1F,KAAM,EAAG,CAAC,iBACbkC,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,QACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAaw6F,EAAsB,CAC1Db,WAAY96F,EAAMwgG,YAAYxC,MAAMlqC,QACpC,sBAAuBj0D,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMwgG,YAAYxC,MAAMlqC,QAAUpzD,GAC/FiK,SAAU9K,EAAO,MAAQA,EAAO,IAAM0d,GAAOtd,EAAS2gG,qBAAqBrjF,EAAKvd,EAAMwgG,eACrF,KAAM,EAAG,CAAC,iBACb59F,EAAG,IACD5C,EAAMwgG,YAAYxC,OAAOlqC,UAAW,WAAc,QAAoB,KAAW,CACnFxzD,IAAK,GACJ,EAAC,QAAaw7F,EAAyB,CACxC3hD,MAAO,aACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAa66F,EAA4B,CAChElB,WAAY96F,EAAMwgG,YAAYxC,MAAMuB,QACpC,sBAAuB1/F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMwgG,YAAYxC,MAAMuB,QAAU7+F,GAC/F2L,IAAK,GACLgxD,KAAM,EACN8kB,UAAW,GACV,KAAM,EAAG,CAAC,iBACbv/E,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,YACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAa66F,EAA4B,CAChElB,WAAY96F,EAAMwgG,YAAYxC,MAAMwB,UACpC,sBAAuB3/F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMwgG,YAAYxC,MAAMwB,UAAY9+F,GACjG2L,IAAK,GACLD,IAAK,IACLixD,KAAM,GACL,KAAM,EAAG,CAAC,iBACbz6D,EAAG,KACA,MAAO,QAAoB,IAAI,IAAQ,KAAoC,OAA7B5C,EAAMggG,qBAA+B,WAAc,QAAoB,KAAW,CACnI1/F,IAAK,GACJ,EAAC,QAAaw7F,EAAyB,CACxC3hD,MAAO,WACP5d,KAAM,YACL,CACDp7B,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAMwgG,YAAY7C,SAC9B,sBAAuB99F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMwgG,YAAY7C,SAAWj9F,GAC1F6B,SAAUvC,EAAMwgG,YAAYxD,OAC3B,KAAM,EAAG,CAAC,aAAc,eAC3Bp6F,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,UACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAMwgG,YAAYtB,UAC9B,sBAAuBr/F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMwgG,YAAYtB,UAAYx+F,GAC3Fw6F,YAAa,iDACZ,KAAM,EAAG,CAAC,eAAgBr7F,EAAO,MAAQA,EAAO,KAAM,QAAoB,OAAQ,CACnFL,MAAO,YACN,sCAAuC,MAC1CoD,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,QACP5d,KAAM,cACL,CACDp7B,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAMwgG,YAAY9C,WAC9B,sBAAuB79F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMwgG,YAAY9C,WAAah9F,GAC5F6B,SAAUvC,EAAMwgG,YAAYxD,OAC3B,KAAM,EAAG,CAAC,aAAc,eAC3Bp6F,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,QACP5d,KAAM,UACL,CACDp7B,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAMwgG,YAAYrB,OAC9B,sBAAuBt/F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMwgG,YAAYrB,OAASz+F,GACxF6B,SAAUvC,EAAMwgG,YAAYxD,OAC3B,KAAM,EAAG,CAAC,aAAc,eAC3Bp6F,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,UACP5d,KAAM,eACL,CACDp7B,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAMwgG,YAAYpB,YAC9B,sBAAuBv/F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMwgG,YAAYpB,YAAc1+F,GAC7F6B,SAAUvC,EAAMwgG,YAAYxD,MAC5B97F,KAAM,WACN,gBAAiB,IAChB,KAAM,EAAG,CAAC,aAAc,eAC3B0B,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,SACP5d,KAAM,mBACL,CACDp7B,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAMwgG,YAAYnB,gBAC9B,sBAAuBx/F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMwgG,YAAYnB,gBAAkB3+F,GACjG6B,SAAUvC,EAAMwgG,YAAYxD,MAC5B97F,KAAM,WACN,gBAAiB,IAChB,KAAM,EAAG,CAAC,aAAc,eAC3B0B,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,QACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAaw6F,EAAsB,CAC1Db,WAAY96F,EAAMwgG,YAAYlB,UAC9B,sBAAuBz/F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMwgG,YAAYlB,UAAY5+F,GAC3F6B,SAAUvC,EAAMwgG,YAAYxD,OAC3B,KAAM,EAAG,CAAC,aAAc,eAC3Bp6F,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,QACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAaw6F,EAAsB,CAC1Db,WAAY96F,EAAMwgG,YAAYxC,MAAMlqC,QACpC,sBAAuBj0D,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMwgG,YAAYxC,MAAMlqC,QAAUpzD,GAC/FiK,SAAU9K,EAAO,MAAQA,EAAO,IAAM0d,GAAOtd,EAAS2gG,qBAAqBrjF,EAAKvd,EAAMwgG,eACrF,KAAM,EAAG,CAAC,iBACb59F,EAAG,IACD5C,EAAMwgG,YAAYxC,OAAOlqC,UAAW,WAAc,QAAoB,KAAW,CACnFxzD,IAAK,GACJ,EAAC,QAAaw7F,EAAyB,CACxC3hD,MAAO,aACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAa66F,EAA4B,CAChElB,WAAY96F,EAAMwgG,YAAYxC,MAAMuB,QACpC,sBAAuB1/F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMwgG,YAAYxC,MAAMuB,QAAU7+F,GAC/F2L,IAAK,GACLgxD,KAAM,EACN8kB,UAAW,GACV,KAAM,EAAG,CAAC,iBACbv/E,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,YACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAa66F,EAA4B,CAChElB,WAAY96F,EAAMwgG,YAAYxC,MAAMwB,UACpC,sBAAuB3/F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMwgG,YAAYxC,MAAMwB,UAAY9+F,GACjG2L,IAAK,GACLD,IAAK,IACLixD,KAAM,GACL,KAAM,EAAG,CAAC,iBACbz6D,EAAG,KACA,MAAO,QAAoB,IAAI,IAAQ,KAAoC,YAA7B5C,EAAMggG,qBAAoC,WAAc,QAAoB,KAAW,CACxI1/F,IAAK,GACJ,EAAC,QAAaw7F,EAAyB,CACxC3hD,MAAO,YACP5d,KAAM,YACL,CACDp7B,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAMwgG,YAAYjD,SAC9B,sBAAuB19F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMwgG,YAAYjD,SAAW78F,GAC1F6B,SAAUvC,EAAMwgG,YAAYxD,MAC5B97F,KAAM,WACN,gBAAiB,IAChB,KAAM,EAAG,CAAC,aAAc,eAC3B0B,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,aACP5d,KAAM,aACL,CACDp7B,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAMwgG,YAAY5C,UAC9B,sBAAuB/9F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMwgG,YAAY5C,UAAYl9F,GAC3F6B,SAAUvC,EAAMwgG,YAAYxD,MAC5B97F,KAAM,WACN,gBAAiB,IAChB,KAAM,EAAG,CAAC,aAAc,eAC3B0B,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,QACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAMwgG,YAAYvB,SAC9B,sBAAuBp/F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMwgG,YAAYvB,SAAWv+F,GAC1Fw6F,YAAa,8BACZ,KAAM,EAAG,CAAC,iBACbt4F,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,YACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAaw6F,EAAsB,CAC1Db,WAAY96F,EAAMwgG,YAAY3C,QAC9B,sBAAuBh+F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMwgG,YAAY3C,QAAUn9F,IACxF,KAAM,EAAG,CAAC,iBACbkC,EAAG,KACA,KAAoC,gBAA7B5C,EAAMggG,qBAAwC,WAAc,QAAoB,KAAW,CACrG1/F,IAAK,GACJ,EAAC,QAAaw7F,EAAyB,CACxC3hD,MAAO,MACP5d,KAAM,QACL,CACDp7B,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAMwgG,YAAY1C,KAC9B,sBAAuBj+F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMwgG,YAAY1C,KAAOp9F,GACtF6B,SAAUvC,EAAMwgG,YAAYxD,OAC3B,KAAM,EAAG,CAAC,aAAc,eAC3Bp6F,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,eACP5d,KAAM,SACL,CACDp7B,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAMwgG,YAAYf,MAC9B,sBAAuB5/F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMwgG,YAAYf,MAAQ/+F,GACvF6B,SAAUvC,EAAMwgG,YAAYxD,MAC5B97F,KAAM,WACN,gBAAiB,IAChB,KAAM,EAAG,CAAC,aAAc,eAC3B0B,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,QACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAaw6F,EAAsB,CAC1Db,WAAY96F,EAAMwgG,YAAYzC,UAC9B,sBAAuBl+F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMwgG,YAAYzC,UAAYr9F,IAC1F,KAAM,EAAG,CAAC,iBACbkC,EAAG,KACA,MAAO,QAAoB,IAAI,KACpCA,EAAG,GACF,EAAG,CAAC,QAAS,YAChBA,EAAG,GACF,EAAG,CAAC,aAAc,QAAS,gBAAiB,CAAC,CAAC2E,EAAoBvH,EAAMoK,UAC7E,CCrkCA,QACE0tF,WAAY,CACV+I,aAAY,IAEd,IAAAx/F,GACE,MAAO,CAELg7F,cAAe,GAEfyE,SAAU,CAAC,CACT3hG,MAAO,WACPg7C,MAAO,YACN,CACDh7C,MAAO,OACPg7C,MAAO,iBACN,CACDh7C,MAAO,KACPg7C,MAAO,MACN,CACDh7C,MAAO,UACPg7C,MAAO,WACN,CACDh7C,MAAO,cACPg7C,MAAO,gBAGT4kD,gBAAiB,CAAC,CAChB5/F,MAAO,WACPg7C,MAAO,YACN,CACDh7C,MAAO,KACPg7C,MAAO,MACN,CACDh7C,MAAO,UACPg7C,MAAO,WACN,CACDh7C,MAAO,cACPg7C,MAAO,gBAGT4mD,iBAAkB,CAChBjE,YAAa,CACXhpC,SAAS,GAEXgtC,SAAU,IAEZE,aAAc,CACZF,SAAU,IAEZG,WAAY,CACVnE,YAAa,CACXhpC,SAAS,GAEXgtC,SAAU,IAEZI,gBAAiB,CACfpE,YAAa,CACXhpC,SAAS,GAEXgtC,SAAU,IAEZK,oBAAqB,CACnBrE,YAAa,CACXhpC,SAAS,GAEXgtC,SAAU,IAGZvE,eAAe,EACfmD,kBAAkB,EAClBa,gBAAgB,EAEhBP,mBAAoB,GACpBoB,qBAAsB,EACtBzB,eAAgB,KAChBa,YAAa,CAAC,EAEd7B,WAAY,CACVz9F,KAAM,GACNF,KAAM,GACN8yD,SAAS,EAETypC,SAAU,GACVC,OAAQ,GACRyB,SAAU,GAEVtB,SAAU,GACVuB,UAAW,GACXxB,WAAY,GACZyB,OAAQ,OACRC,YAAa,GACbC,gBAAiB,GACjBC,WAAW,EACXtB,MAAO,CACLlqC,SAAS,EACTyrC,QAAS,GACTC,UAAW,IAGb5B,UAAW,GACXC,SAAS,EAETC,KAAM,GACN2B,MAAO,GACP1B,WAAW,GAGbc,SAAU,CACR39F,KAAM,CAAC,CACLgsF,UAAU,EACVvjF,QAAS,UACT2nD,QAAS,WAEXtwD,KAAM,CAAC,CACLksF,UAAU,EACVvjF,QAAS,UACT2nD,QAAS,QACR,CACD+vC,QAAS,gCACT13F,QAAS,wBACT2nD,QAAS,SAEXisC,SAAU,CAAC,CACTrQ,UAAU,EACVvjF,QAAS,gBACT2nD,QAAS,SAEXksC,OAAQ,CAAC,CACPtQ,UAAU,EACVvjF,QAAS,cACT2nD,QAAS,SAEXssC,UAAW,CAAC,CACV1Q,UAAU,EACVvjF,QAAS,iBACT2nD,QAAS,SAEXqsC,SAAU,CAAC,CACTzQ,UAAU,EACVvjF,QAAS,eACT2nD,QAAS,SAEXosC,WAAY,CAAC,CACXxQ,UAAU,EACVvjF,QAAS,WACT2nD,QAAS,SAEX6tC,OAAQ,CAAC,CACPjS,UAAU,EACVvjF,QAAS,WACT2nD,QAAS,SAEX8tC,YAAa,CAAC,CACZlS,UAAU,EACVvjF,QAAS,aACT2nD,QAAS,SAEX+tC,gBAAiB,CAAC,CAChBnS,UAAU,EACVvjF,QAAS,YACT2nD,QAAS,SAEXwsC,KAAM,CAAC,CACL5Q,UAAU,EACVvjF,QAAS,SACT2nD,QAAS,SAEXmuC,MAAO,CAAC,CACNvS,UAAU,EACVvjF,QAAS,mBACT2nD,QAAS,UAIbqvC,UAAW,CACT3/F,KAAM,CAAC,CACLksF,UAAU,EACVvjF,QAAS,UACT2nD,QAAS,QACR,CACD+vC,QAAS,gCACT13F,QAAS,wBACT2nD,QAAS,SAEXisC,SAAU,CAAC,CACTrQ,UAAU,EACVvjF,QAAS,gBACT2nD,QAAS,SAEXksC,OAAQ,CAAC,CACPtQ,UAAU,EACVvjF,QAAS,cACT2nD,QAAS,SAEXssC,UAAW,CAAC,CACV1Q,UAAU,EACVvjF,QAAS,iBACT2nD,QAAS,SAEXqsC,SAAU,CAAC,CACTzQ,UAAU,EACVvjF,QAAS,eACT2nD,QAAS,SAEXosC,WAAY,CAAC,CACXxQ,UAAU,EACVvjF,QAAS,WACT2nD,QAAS,SAEX6tC,OAAQ,CAAC,CACPjS,UAAU,EACVvjF,QAAS,WACT2nD,QAAS,SAEX8tC,YAAa,CAAC,CACZlS,UAAU,EACVvjF,QAAS,aACT2nD,QAAS,SAEX+tC,gBAAiB,CAAC,CAChBnS,UAAU,EACVvjF,QAAS,YACT2nD,QAAS,SAEXwsC,KAAM,CAAC,CACL5Q,UAAU,EACVvjF,QAAS,SACT2nD,QAAS,SAEXmuC,MAAO,CAAC,CACNvS,UAAU,EACVvjF,QAAS,mBACT2nD,QAAS,UAIbgwC,WAAY,CAAC,EACblB,cAAc,EAEdh2F,SAAS,EAEb,EACAouF,SAAU,CAER,aAAA8D,GACE,MAAMiF,EAAU,CACdC,SAAU,cACVC,KAAM,QACNC,GAAI,WACJC,QAAS,WACTC,YAAa,SAEf,MAAO,CAAC,CACNziG,MAAO,GACPg7C,MAAO,WACH54C,KAAKu/F,SAAS5xF,IAAI8vF,IAAM,CAC5B7/F,MAAO6/F,EAAG7/F,MACVg7C,MAAO6kD,EAAG7kD,MACVv5C,KAAM2gG,EAAQvC,EAAG7/F,QAAU,YAE/B,EAEA,gBAAAq9F,GACE,OAAKj7F,KAAK86F,cAGH96F,KAAKu/F,SAAShgE,OAAOk+D,GAAMA,EAAG7/F,QAAUoC,KAAK86F,eAF3C96F,KAAKu/F,QAGhB,GAEFx/F,QAAS,CAEP,mBAAA47F,CAAoBz2D,EAAOg2D,EAAal8F,GACtC,MAAMshG,EAAOp7D,EAAMq7D,cACbrpE,EAAOopE,EAAKx7D,wBACZt2B,EAAI02B,EAAMH,QAAU7N,EAAKnQ,KACzB1H,EAAI6lB,EAAMF,QAAU9N,EAAKrK,IACzB2zE,EAAS,QAAQtF,KAAel8F,IAChCyhG,EAASzgG,KAAKk4F,MAAMsI,GACtBC,GAAUA,EAAO,KACnBA,EAAO,GAAGv5F,MAAM20E,QAAU,IAC1B4kB,EAAO,GAAGv5F,MAAM6f,KAAO,GAAGvY,MAC1BiyF,EAAO,GAAGv5F,MAAM2lB,IAAM,GAAGxN,MAE7B,EACA,oBAAAw8E,CAAqBX,EAAal8F,GAChC,MAAMwhG,EAAS,QAAQtF,KAAel8F,IAChCyhG,EAASzgG,KAAKk4F,MAAMsI,GACtBC,GAAUA,EAAO,KACnBA,EAAO,GAAGv5F,MAAM20E,QAAU,IAE9B,EAEA,cAAAsf,CAAex7F,GACb,MAAM+gG,EAAQ,CACZT,SAAU,cACVC,KAAM,QACNC,GAAI,WACJC,QAAS,WACTC,YAAa,SAEf,OAAOK,EAAM/gG,IAAS,QACxB,EAEA,mBAAA6+F,CAAoB7+F,GAClB,MAAMsH,EAAUjH,KAAKu/F,SAAS//C,KAAK5zC,GAAKA,EAAEhO,QAAU+B,GACpD,OAAOsH,EAAUA,EAAQ2xC,MAAQj5C,CACnC,EAEA,cAAAy7F,CAAez7F,GACb,OAAOK,KAAKs7F,YAAY37F,IAAO4/F,UAAY,EAC7C,EAEA,WAAAjE,CAAY37F,GACV,MAAMgO,EAAM,CACVsyF,SAAUjgG,KAAKw/F,iBACfU,KAAMlgG,KAAKy/F,aACXU,GAAIngG,KAAK0/F,WACTU,QAASpgG,KAAK2/F,gBACdU,YAAargG,KAAK4/F,qBAEpB,OAAOjyF,EAAIhO,EACb,EAEA,cAAA07F,CAAe17F,GACb,MAAO,CAAC,WAAY,KAAM,UAAW,eAAekvB,SAASlvB,EAC/D,EAEA,QAAAo8F,CAAS9rE,EAAM0wE,EAAa,GAC1B,OAAK1wE,EACDA,EAAKrpB,QAAuB,EAAb+5F,EAAuB,OACnC1wE,EAAKtT,MAAM,EAAGgkF,GAAc,OAAS1wE,EAAKtT,OAAOgkF,GAFtC,KAGpB,EAEA,gBAAA9D,CAAiBl9F,EAAMX,GACrBgB,KAAKy+F,mBAAqB9+F,EAC1BK,KAAK6/F,oBAAsB7gG,EAC3BgB,KAAKo+F,eAAiBp+F,KAAKo7F,eAAez7F,GAAMX,GAChDgB,KAAKm+F,kBAAmB,CAC1B,EAEA,cAAArB,CAAen9F,EAAMX,GACnBgB,KAAKy+F,mBAAqB9+F,EAC1BK,KAAK6/F,oBAAsB7gG,EAC3B,MAAMiI,EAAUjH,KAAKo7F,eAAez7F,GAAMX,GAC1CgB,KAAKi/F,YAAc7xE,KAAKiT,MAAMjT,KAAKC,UAAUpmB,IAExCjH,KAAKi/F,YAAYxC,QACpBz8F,KAAKi/F,YAAYxC,MAAQ,CACvBlqC,SAAS,EACTyrC,QAAS,GACTC,UAAW,KAGfj+F,KAAKg/F,gBAAiB,CACxB,EAEA,kBAAAV,GACEt+F,KAAKm+F,kBAAmB,EACxBn+F,KAAK88F,eAAe98F,KAAKy+F,mBAAoBz+F,KAAK6/F,oBACpD,EAEA,YAAA5C,GACEj9F,KAAKo9F,WAAa,CAChBz9F,KAAM,GACNF,KAAM,GACN8yD,SAAS,EACTypC,SAAU,GACVC,OAAQ,GACRyB,SAAU,GACVtB,SAAU,GACVD,WAAY,GACZyB,OAAQ,OACRC,YAAa,GACbC,gBAAiB,GACjBC,WAAW,EACXtB,MAAO,CACLlqC,SAAS,EACTyrC,QAAS,GACTC,UAAW,IAEb5B,UAAW,GACXC,SAAS,EACTC,KAAM,GACN2B,MAAO,GACP1B,WAAW,EAEf,EAEA,eAAA6B,GACEr+F,KAAKo+F,eAAiB,IACxB,EAEA,aAAAc,GACEl/F,KAAKi/F,YAAc,CAAC,CACtB,EAEA,mBAAA1B,GAEE,MAAM,KACJ59F,EAAI,KACJF,GACEO,KAAKo9F,WACTp9F,KAAKo9F,WAAa,CAChBz9F,OACAF,OACA8yD,SAAS,EACTypC,SAAU,GACVC,OAAQ,GACRyB,SAAU,GACVtB,SAAU,GACVuB,UAAW,GACXxB,WAAY,GACZyB,OAAQ,OACRC,YAAa,GACbC,gBAAiB,GACjBC,WAAW,EACXtB,MAAO,CACLlqC,SAAS,EACTyrC,QAAS,GACTC,UAAW,IAEb5B,UAAW,GACXC,SAAS,EACTC,KAAM,GACN2B,MAAO,GACP1B,WAAW,EAEf,EAEA,iBAAAU,GACEl9F,KAAKk4F,MAAM0I,QAAQC,SAASzlF,IAC1B,IAAKA,EAAO,OACZ,MAAM,KACJzb,EAAI,KACJF,GACEO,KAAKo9F,WACH/I,EAAWr0F,KAAKs7F,YAAY37F,GAG5BmhG,EAAgB,CAAC,eAAgB,SAAU,SAAU,cAAe,mBAC1E,GAAIA,EAAcjyE,SAASpvB,GAEzB,YADAO,KAAK43F,SAASC,QAAQ,sBAKxB,MAAMkJ,EAAc1M,EAASkL,SAASv+B,KAAKy8B,GAAMA,EAAGh+F,OAASA,GAC7D,GAAIshG,EAEF,YADA/gG,KAAK43F,SAASC,QAAQ,uBAGxB,IAAImJ,EAAiB,CACnBl3F,GAAIuqF,EAASkL,SAAS34F,OAAS,EAC/BnH,KAAMO,KAAKo9F,WAAW39F,KACtBE,KAAMA,EACNshG,SAAU,WACV1uC,SAAS,EACTkpC,OAAO,GAII,aAAT97F,EACFjC,OAAOkd,OAAOomF,EAAgB,CAC5BhF,SAAUh8F,KAAKo9F,WAAWpB,SAC1BC,OAAQj8F,KAAKo9F,WAAWnB,OACxByB,SAAU19F,KAAKo9F,WAAWM,WAEV,OAAT/9F,EACTjC,OAAOkd,OAAOomF,EAAgB,CAC5B5E,SAAUp8F,KAAKo9F,WAAWhB,SAC1BuB,UAAW39F,KAAKo9F,WAAWO,UAC3BxB,WAAYn8F,KAAKo9F,WAAWjB,WAC5ByB,OAAQ59F,KAAKo9F,WAAWQ,OACxBC,YAAa79F,KAAKo9F,WAAWS,YAC7BC,gBAAiB99F,KAAKo9F,WAAWU,gBACjCC,UAAW/9F,KAAKo9F,WAAWW,UAC3BtB,MAAO,IACFz8F,KAAKo9F,WAAWX,SAGL,YAAT98F,EACTjC,OAAOkd,OAAOomF,EAAgB,CAC5BhF,SAAUh8F,KAAKo9F,WAAWpB,SAC1BK,UAAWr8F,KAAKo9F,WAAWf,UAC3BqB,SAAU19F,KAAKo9F,WAAWM,SAC1BpB,QAASt8F,KAAKo9F,WAAWd,UAET,gBAAT38F,GACTjC,OAAOkd,OAAOomF,EAAgB,CAC5BzE,KAAMv8F,KAAKo9F,WAAWb,KACtB2B,MAAOl+F,KAAKo9F,WAAWc,MACvB1B,UAAWx8F,KAAKo9F,WAAWZ,YAG/BnI,EAASkL,SAAS7/E,KAAKshF,GACvBhhG,KAAKg7F,eAAgB,EAErBh7F,KAAKw7F,gBAET,EAEA,kBAAA2D,GACEn/F,KAAKk4F,MAAMgJ,SAASL,SAASzlF,IAC3B,IAAKA,EAAO,OACZ,MAAMi5E,EAAWr0F,KAAKs7F,YAAYt7F,KAAKy+F,oBACjC0C,EAAUnhG,KAAKi/F,YAAYx/F,KAC3B2hG,EAAephG,KAAK6/F,oBACpBwB,EAAiBrhG,KAAKi/F,YAAYxD,MAGxC,IAAK4F,EAAgB,CAEnB,MAAMP,EAAgB,CAAC,eAAgB,SAAU,SAAU,cAAe,mBAC1E,GAAIA,EAAcjyE,SAASsyE,GAEzB,YADAnhG,KAAK43F,SAASC,QAAQ,sBAKxB,MAAMkJ,EAAc1M,EAASkL,SAASv+B,KAAK,CAACy8B,EAAIljC,IAAQA,IAAQ6mC,GAAgB3D,EAAGh+F,OAAS0hG,GAC5F,GAAIJ,EAEF,YADA/gG,KAAK43F,SAASC,QAAQ,sBAG1B,CACAxD,EAASkL,SAASv/F,KAAK6/F,qBAAuB,IACzC7/F,KAAKi/F,aAEVj/F,KAAKg/F,gBAAiB,EAEtBh/F,KAAKw7F,gBAET,EAEA,aAAAuB,CAAcp9F,EAAMX,GAClB,MAAMiI,EAAUjH,KAAKo7F,eAAez7F,GAAMX,GACtCiI,EAAQw0F,MACVz7F,KAAK43F,SAASC,QAAQ,iBAGxB73F,KAAKq4F,SAAS,aAAc,KAAM,CAChCC,kBAAmB,KACnBC,iBAAkB,KAClB54F,KAAM,YACL2wC,KAAK,KACN,MAAM+jD,EAAWr0F,KAAKs7F,YAAY37F,GAClC00F,EAASkL,SAAS35E,OAAO5mB,EAAO,GAEhCq1F,EAASkL,SAASl6E,QAAQ,CAACvmB,EAAM3B,KAC/B2B,EAAKgL,GAAK3M,EAAI,IAGhB6C,KAAKw7F,iBACJ8F,MAAM,OACX,EACA,YAAA9F,GAEE,MAAMnH,EAAW,CACf4L,SAAUjgG,KAAKw/F,iBACfU,KAAMlgG,KAAKy/F,aACXU,GAAIngG,KAAK0/F,WACTU,QAASpgG,KAAK2/F,gBACdU,YAAargG,KAAK4/F,sBAEpB,EAAA5O,GAAA,GAAc,+BAAgC,CAC5C1rE,OAAQ,OACR0tE,QAAS,CACP,eAAgB,oBAElB5a,KAAMhrD,KAAKC,UAAUgnE,KACpB/jD,KAAK,KACNtwC,KAAK43F,SAASxG,QAAQ,UAE1B,EAEA,kBAAMwN,GACJ5+F,KAAK6+F,cAAe,EACpB,IAEE,MAAMpO,QAAiB,EAAAO,GAAA,GAAc,oBAAqB,CACxD1rE,OAAQ,SAEJxlB,QAAa2wF,EAASU,OAC5B,GAAIrxF,EAAKsxF,QACPpxF,KAAK+/F,WAAajgG,EAAK6G,cAAgB,CAAC,MACnC,CAEL,MAAM46F,QAAoB,EAAAvQ,GAAA,GAAc,qBAClCwQ,QAAgBD,EAAYpQ,OAC9BqQ,EAAQpQ,UACVpxF,KAAK+/F,WAAayB,EAAQzB,YAAc,CAAC,EAE7C,CACF,CAAE,MAAOz9B,GACPhnC,QAAQgnC,MAAM,iCAAkCA,EAClD,CAAE,QACAtiE,KAAK6+F,cAAe,CACtB,CACF,EAEA,oBAAM4C,GACJ,IACE,MAAMhR,QAAiB,EAAAO,GAAA,GAAc,qBAC/BlxF,QAAa2wF,EAASU,OACxBrxF,EAAKsxF,UACPpxF,KAAK+/F,WAAajgG,EAAKigG,YAAc,CAAC,EAE1C,CAAE,MAAOz9B,GACPhnC,QAAQgnC,MAAM,8BAA+BA,EAC/C,CACF,EAEA,gBAAAo/B,CAAiBz6F,GACf,MAAMiwF,EAAQl3F,KAAK+/F,WAAW94F,EAAQxH,MACtC,OAAKy3F,GACGA,EAAMyK,QAAU,GAAK,KADV,CAErB,EAEA,kBAAAjF,CAAmBz1F,GACjB,MAAM26F,EAAS5hG,KAAK0hG,iBAAiBz6F,GAC/B+2F,EAAU/2F,EAAQw1F,OAAOuB,SAAW,GACpCh2F,EAAa45F,EAAS5D,EAAU,IACtC,OAAOn2F,KAAKiD,IAAI,IAAKjD,KAAKC,MAAmB,GAAbE,GAAmB,GACrD,EAEA,cAAA20F,CAAe11F,GACb,MAAMe,EAAahI,KAAK08F,mBAAmBz1F,GACrCg3F,EAAYh3F,EAAQw1F,OAAOwB,WAAa,GAC9C,OAAIj2F,GAAci2F,EAAkB,YAChCj2F,GAAc,GAAW,UACtB,SACT,EAEA,YAAA40F,CAAa31F,GACX,MAAM26F,EAAS5hG,KAAK0hG,iBAAiBz6F,GAC/B+2F,EAAU/2F,EAAQw1F,OAAOuB,SAAW,GAC1C,MAAO,GAAG4D,EAAOvK,QAAQ,QAAQ2G,MACnC,EAEA,eAAAc,CAAgB73F,GACd,MAAMe,EAAahI,KAAK08F,mBAAmBz1F,GACrCg3F,EAAYh3F,EAAQw1F,OAAOwB,WAAa,GAC9C,OAAOj2F,GAAci2F,CACvB,EAEA,kBAAAc,CAAmB93F,GACjB,MAAMe,EAAahI,KAAK08F,mBAAmBz1F,GACrCg3F,EAAYh3F,EAAQw1F,OAAOwB,WAAa,GAC9C,OAAIj2F,GAAci2F,EACT,eAAeA,cAEpBj2F,GAAc,GACT,gBAEF,QACT,EAEA,0BAAMq3F,CAAqB9sC,EAAStrD,GAClC,GAAIsrD,GAAWtrD,EAAQxH,KAAM,CAE3B,MAAMy3F,EAAQl3F,KAAK+/F,WAAW94F,EAAQxH,MACjCy3F,GAEHl3F,KAAKq4F,SAAS,uCAAwC,UAAW,CAC/DC,kBAAmB,OACnBC,iBAAkB,SAClB54F,KAAM,SACL2wC,KAAKuxD,gBACA7hG,KAAK8hG,qBACVR,MAAM,KACPthG,KAAK43F,SAASl8D,KAAK,oBAGzB,CACF,EAEA,sBAAMomE,GACJ9hG,KAAK6+F,cAAe,EACpB,IACE7+F,KAAK43F,SAASl8D,KAAK,iBACnB,MAAM+0D,QAAiB,EAAAO,GAAA,GAAc,oBAAqB,CACxD1rE,OAAQ,SAEJxlB,QAAa2wF,EAASU,OACxBrxF,EAAKsxF,SACPpxF,KAAK+/F,WAAajgG,EAAK6G,cAAgB,CAAC,EACxC3G,KAAK43F,SAASxG,QAAQ,WAEtBpxF,KAAK43F,SAASt1B,MAAM,UAAYxiE,EAAKwiE,OAAS,QAElD,CAAE,MAAOA,GACPhnC,QAAQgnC,MAAM,+BAAgCA,GAC9CtiE,KAAK43F,SAASt1B,MAAM,OACtB,CAAE,QACAtiE,KAAK6+F,cAAe,CACtB,CACF,GAEF,OAAAv+F,GACEN,KAAK6I,SAAU,GAEf,EAAAmoF,GAAA,GAAc,gCAAgC1gD,KAAKmgD,GAAYA,EAASU,QAAQ7gD,KAAKxwC,IACnFE,KAAKw/F,iBAAmB1/F,EAAKmgG,SAEzBngG,EAAKogG,MAAQpgG,EAAKogG,KAAKX,WACzBz/F,EAAKogG,KAAKX,SAAWz/F,EAAKogG,KAAKX,SAAS5xF,IAAI1G,IAAW,IAClDA,EACHw1F,MAAOx1F,EAAQw1F,OAAS,CACtBlqC,SAAS,EACTyrC,QAAS,GACTC,UAAW,QAIjBj+F,KAAKy/F,aAAe3/F,EAAKogG,KAErBpgG,EAAKqgG,IAAMrgG,EAAKqgG,GAAGZ,WACrBz/F,EAAKqgG,GAAGZ,SAAWz/F,EAAKqgG,GAAGZ,SAAS5xF,IAAI1G,IAAW,IAC9CA,EACHw1F,MAAOx1F,EAAQw1F,OAAS,CACtBlqC,SAAS,EACTyrC,QAAS,GACTC,UAAW,QAIjBj+F,KAAK0/F,WAAa5/F,EAAKqgG,GAEnBrgG,EAAKsgG,SAAWtgG,EAAKsgG,QAAQb,WAC/Bz/F,EAAKsgG,QAAQb,SAAWz/F,EAAKsgG,QAAQb,SAAS5xF,IAAI1G,IAAW,IACxDA,EACHy2F,SAAUz2F,EAAQy2F,UAAY,OAGlC19F,KAAK2/F,gBAAkB7/F,EAAKsgG,SAAW,CACrC7E,YAAa,CAAC,EACdgE,SAAU,IAGRz/F,EAAKugG,aAAevgG,EAAKugG,YAAYd,WACvCz/F,EAAKugG,YAAYd,SAAWz/F,EAAKugG,YAAYd,SAAS5xF,IAAI1G,IAAW,IAChEA,EACHu1F,UAAWv1F,EAAQu1F,YAAa,MAGpCx8F,KAAK4/F,oBAAsB9/F,EAAKugG,aAAe,CAC7C9E,YAAa,CAAC,EACdgE,SAAU,IAGZv/F,KAAKyhG,mBACJM,QAAQ,KACT/hG,KAAK6I,SAAU,GAEnB,GCtvBF,MAAM,IAA2B,OAAgB,GAAQ,CAAC,CAAC,SAAS,IAAQ,CAAC,YAAY,qBAEzF,U,0BCRA,MAAM,GAAa,CACjB5K,MAAO,aAEF,SAAS,GAAOI,EAAMC,EAAQC,EAAQC,EAAQC,EAAOC,GAC1D,MAAMC,GAA+B,QAAkB,qBACvD,OAAO,WAAc,QAAa,MAAa,CAC7Cc,KAAM,WACL,CACDG,SAAS,QAAS,IAAM,EAAC,SAAgB,QAAoB,MAAO,CAClE3B,OAAO,QAAgB,CAAC,oBAAqB,CAC3C,aAAcM,EAAOsK,WAEvB3J,QAASZ,EAAO,KAAOA,EAAO,GAAK,IAAIiB,IAASb,EAASsjG,aAAetjG,EAASsjG,eAAeziG,KAC/F,CAAChB,EAAOsK,UAAW,WAAc,QAAalK,EAA8B,CAC7EI,IAAK,EACLM,KAAM,UACN4iG,KAAM,QACD,WAAc,QAAatjG,EAA8B,CAC9DI,IAAK,EACLM,KAAM,WACH,QAAoB,OAAQ,IAAY,QAAiBd,EAAOsK,QAAU,MAAQ,MAAO,IAAK,GAAI,CAAC,CAAC,MAAQpK,EAAM+tB,aACvHnrB,EAAG,GAEP,CCxBA,QACE5B,KAAM,qBACNC,MAAO,CACLmJ,QAAS,CACPlJ,KAAME,QACND,SAAS,GAEX0sB,KAAM,CACJ3sB,KAAME,QACND,SAAS,IAGb,IAAAE,GACE,MAAO,CACL0sB,SAAS,EAEb,EACA6hE,MAAO,CACL/hE,KAAM,CACJ41E,WAAW,EACX,OAAA75C,CAAQrsC,GACFA,EAEF0K,WAAW,KACT1mB,KAAKwsB,SAAU,GACd,KAEHxsB,KAAKwsB,SAAU,CAEnB,IAGJzsB,QAAS,CACP,WAAAiiG,GACOhiG,KAAK6I,SACR7I,KAAKC,MAAM,QAEf,IC9BJ,MAAM,IAA2B,OAAgB,GAAQ,CAAC,CAAC,SAAS,IAAQ,CAAC,YAAY,qBAEzF,U,2BCRA,MAAM,GAAa,CACjBhC,MAAO,qBAEH,GAAa,CACjBA,MAAO,kBAEH,GAAa,CACjBA,MAAO,4BAEH,GAAa,CACjBA,MAAO,iBAEH,GAAa,CACjBA,MAAO,yBAEH,GAAa,CACjBA,MAAO,sBAEH,GAAa,CACjBA,MAAO,sBAEH,GAAa,CACjBA,MAAO,iBAEH,GAAa,CACjBA,MAAO,sBAEH,GAAc,CAClBA,MAAO,sBAEH,GAAc,CAClBA,MAAO,qCAEH,GAAc,CAClBA,MAAO,kBAEH,GAAc,CAClBA,MAAO,gBAEH,GAAc,CAClBA,MAAO,kBAEH,GAAc,CAClBA,MAAO,iBAEH,GAAc,CAClBA,MAAO,iBAEH,GAAc,CAClBA,MAAO,gBAEH,GAAc,CAClBiJ,MAAO,CACL,gBAAiB,OACjB,MAAS,YAGP,GAAc,CAClBjJ,MAAO,iBAEF,SAAS,GAAOI,EAAMC,EAAQC,EAAQC,EAAQC,EAAOC,GAC1D,MAAM87F,EAAsB,MACtBD,EAA0B,MAC1BG,EAAqB,MACrB/7F,GAA+B,QAAkB,qBACjDmH,EAAuB,KACvBq8F,EAA6B,MAC7BhI,EAAoB,KACpBiI,EAAsB,MACtBxhG,EAAwB,KACxBw5F,EAAuB,MACvBC,EAAuB,MACvBC,EAAuB,MACvB+H,EAAgC,GAChCC,EAAyB,MACzBC,EAA+B,MAC/B5H,EAAuB,MACvB30F,EAAqB,IAC3B,OAAO,UAAiB,WAAc,QAAoB,MAAO,GAAY,EAAC,QAAoB,MAAO,GAAY,CAAC1H,EAAO,MAAQA,EAAO,KAAM,QAAoB,KAAM,CAC1KL,MAAO,eACN,QAAS,IAAKK,EAAO,MAAQA,EAAO,KAAM,QAAoB,KAAM,CACrEL,MAAO,gBACN,SAAU,KAAK,QAAay8F,EAAoB,CACjDyC,MAAO1+F,EAAM+jG,aAAaC,KAC1BpF,MAAO5+F,EAAMikG,cACbx5F,IAAK,eACL,cAAe,SACd,CACDtJ,SAAS,QAAS,IAAM,EAAC,QAAa26F,EAAyB,CAC7D3hD,MAAO,OACP5d,KAAM,YACL,CACDp7B,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAM+jG,aAAaC,KAAKE,SACpC,sBAAuBrkG,EAAO,KAAOA,EAAO,GAAKa,GAAUV,EAAM+jG,aAAaC,KAAKE,SAAWxjG,GAC9FQ,KAAM,WACN,gBAAiB,GACjBijG,QAASlkG,EAASmkG,oBAClBC,aAAc,gBACb,KAAM,EAAG,CAAC,aAAc,cAC3BzhG,EAAG,KACD,QAAa,MAAa,CAC5B5B,KAAM,aACNqzB,KAAM,UACL,CACDlzB,SAAS,QAAS,IAAM,CAACnB,EAAMskG,sBAAuB,WAAc,QAAaxI,EAAyB,CACxG3hD,MAAO,OACP5d,KAAM,yBACNj8B,IAAK,gBACJ,CACDa,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAM+jG,aAAaC,KAAKO,uBACpC,sBAAuB1kG,EAAO,KAAOA,EAAO,GAAKa,GAAUV,EAAM+jG,aAAaC,KAAKO,uBAAyB7jG,GAC5GQ,KAAM,WACN,gBAAiB,GACjBmjG,aAAc,gBACb,KAAM,EAAG,CAAC,iBACbzhG,EAAG,MACC,QAAoB,IAAI,KAC9BA,EAAG,MAELA,EAAG,GACF,EAAG,CAAC,QAAS,UAAW/C,EAAO,MAAQA,EAAO,KAAM,QAAoB,KAAM,CAC/EL,MAAO,gBACN,SAAU,KAAK,QAAay8F,EAAoB,CACjDyC,MAAO1+F,EAAM+jG,aAAaS,MAC1B5F,MAAO5+F,EAAMykG,eACbh6F,IAAK,gBACL,cAAe,SACd,CACDtJ,SAAS,QAAS,IAAM,EAAC,QAAa26F,EAAyB,CAC7D3hD,MAAO,MACP5d,KAAM,iBACL,CACDp7B,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAM+jG,aAAaS,MAAME,cACrC,sBAAuB7kG,EAAO,KAAOA,EAAO,GAAKa,GAAUV,EAAM+jG,aAAaS,MAAME,cAAgBhkG,GACpG2jG,aAAc,gBACb,KAAM,EAAG,CAAC,iBACbzhG,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,KACP5d,KAAM,iBACL,CACDp7B,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAM+jG,aAAaS,MAAMG,cACrC,sBAAuB9kG,EAAO,KAAOA,EAAO,GAAKa,GAAUV,EAAM+jG,aAAaS,MAAMG,cAAgBjkG,GACpGQ,KAAM,WACN,gBAAiB,GACjBijG,QAASlkG,EAAS2kG,qBAClBP,aAAc,gBACb,KAAM,EAAG,CAAC,aAAc,cAC3BzhG,EAAG,KACD,QAAa,MAAa,CAC5B5B,KAAM,aACNqzB,KAAM,UACL,CACDlzB,SAAS,QAAS,IAAM,CAACnB,EAAM6kG,uBAAwB,WAAc,QAAa/I,EAAyB,CACzG3hD,MAAO,OACP5d,KAAM,0BACNj8B,IAAK,iBACJ,CACDa,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAM+jG,aAAaS,MAAMM,wBACrC,sBAAuBjlG,EAAO,KAAOA,EAAO,GAAKa,GAAUV,EAAM+jG,aAAaS,MAAMM,wBAA0BpkG,GAC9GQ,KAAM,WACN,gBAAiB,GACjBmjG,aAAc,gBACb,KAAM,EAAG,CAAC,iBACbzhG,EAAG,MACC,QAAoB,IAAI,KAC9BA,EAAG,MAELA,EAAG,GACF,EAAG,CAAC,QAAS,WAAW,QAAoB,KAAM,GAAY,CAAC/C,EAAO,MAAQA,EAAO,KAAM,QAAiB,iBAAkB,KAAK,QAAoB,IAAK,GAAY,EAAC,QAAawH,EAAsB,CAC7MnG,KAAM,UACN2I,KAAM,QACNpJ,QAASZ,EAAO,KAAOA,EAAO,GAAKa,GAAUV,EAAM+kG,uBAAwB,GAC3EC,OAAQ,IACP,CACD7jG,SAAS,QAAS,IAAM,EAAC,QAAajB,EAA8B,CAClEU,KAAM,WAERgC,EAAG,SACG,QAAoB,MAAO,GAAY,EAAC,UAAiB,WAAc,QAAa+gG,EAAqB,CAC/GtiG,KAAMrB,EAAMilG,UACZzlG,MAAO,eACN,CACD2B,SAAS,QAAS,IAAM,EAAC,QAAauiG,EAA4B,CAChEnnE,KAAM,OACN4d,MAAO,KACP,eAAgB,UACf,CACDh5C,SAAS,QAAS2xB,GAAS,EAAC,QAAoB,MAAO,IAAY,QAAiBA,EAAMmjD,IAAIj1E,MAAO,KACrG4B,EAAG,KACD,QAAa8gG,EAA4B,CAC3CnnE,KAAM,QACN4d,MAAO,QACP,eAAgB,UACf,CACDh5C,SAAS,QAAS2xB,GAAS,EAAC,QAAoB,MAAO,GAAY,EAAC,QAAoB,OAAQ,IAAY,QAAiBA,EAAMmjD,IAAIwpB,OAAQ,OAC/I78F,EAAG,KACD,QAAa8gG,EAA4B,CAC3CnnE,KAAM,cACN4d,MAAO,KACP,eAAgB,UACf,CACDh5C,SAAS,QAAS2xB,GAAS,EAAC,QAAoB,MAAO,GAAY,GAAE,SAAW,IAAO,QAAoB,KAAW,MAAM,QAAYA,EAAMmjD,IAAIivB,YAAaC,KACtJ,WAAc,QAAazJ,EAAmB,CACnDp7F,IAAK6kG,EACLt7F,KAAM,QACNrK,MAAO,kBACN,CACD2B,SAAS,QAAS,IAAM,EAAC,SAAiB,QAAiBlB,EAASmlG,kBAAkBD,IAAQ,KAC9FviG,EAAG,GACF,QACD,UACJA,EAAG,KACD,QAAa8gG,EAA4B,CAC3CnnE,KAAM,YACN4d,MAAO,OACP,eAAgB,UACf,CACDh5C,SAAS,QAAS2xB,GAAS,EAAC,QAAoB,MAAO,IAAa,QAAiB7yB,EAASolG,WAAWvyE,EAAMmjD,IAAIqvB,YAAa,KAChI1iG,EAAG,KACD,QAAa8gG,EAA4B,CAC3CvpD,MAAO,KACP6iD,MAAO,QACP,eAAgB,UACf,CACD77F,SAAS,QAAS2xB,GAAS,EAAC,QAAoB,MAAO,GAAa,EAAC,QAAazrB,EAAsB,CACtG7H,MAAO,gBACPqK,KAAM,QACNpJ,QAASC,GAAUT,EAASslG,UAAUzyE,EAAMmjD,MAC3C,CACD90E,SAAS,QAAS,IAAM,IAAKtB,EAAO,MAAQA,EAAO,IAAM,EAAC,QAAiB,MAAO,OAClF+C,EAAG,GACF,EAAG,CAAC,aAAa,QAAayE,EAAsB,CACrD7H,MAAO,gBACPqK,KAAM,QACN3I,KAAM,SACNT,QAASC,GAAUT,EAASulG,YAAY1yE,EAAMmjD,IAAI5qE,KACjD,CACDlK,SAAS,QAAS,IAAM,IAAKtB,EAAO,MAAQA,EAAO,IAAM,EAAC,QAAiB,MAAO,OAClF+C,EAAG,GACF,EAAG,CAAC,gBACPA,EAAG,MAELA,EAAG,GACF,EAAG,CAAC,UAAW,CAAC,CAAC2E,EAAoBvH,EAAMylG,qBAAqB,QAAoB,MAAO,GAAa,CAAC5lG,EAAO,MAAQA,EAAO,KAAM,QAAoB,KAAM,CAChKL,MAAO,eACN,QAAS,KAAK,QAAoB,KAAM,GAAa,CAACK,EAAO,MAAQA,EAAO,KAAM,QAAiB,SAAU,KAAK,QAAasC,EAAuB,CACvJM,QAAS,iDACTC,UAAW,OACV,CACDvB,SAAS,QAAS,IAAM,EAAC,QAAajB,EAA8B,CAClEU,KAAM,kBACN6H,MAAO,CACL,cAAe,MACf,OAAU,eAGd7F,EAAG,OACC,QAAaq5F,EAAoB,CACrCyC,MAAO1+F,EAAM0lG,eAAeC,SAC5B,cAAe,SACd,CACDxkG,SAAS,QAAS,IAAM,EAAC,QAAa26F,EAAyB,CAC7D3hD,MAAO,QACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAaw6F,EAAsB,CAC1Db,WAAY96F,EAAM0lG,eAAeC,SAAS7xC,QAC1C,sBAAuBj0D,EAAO,KAAOA,EAAO,GAAKa,GAAUV,EAAM0lG,eAAeC,SAAS7xC,QAAUpzD,IAClG,KAAM,EAAG,CAAC,iBACbkC,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,QACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAa06F,EAAsB,CAC1Df,WAAY96F,EAAM0lG,eAAeC,SAASn9F,QAC1C,sBAAuB3I,EAAO,KAAOA,EAAO,GAAKa,GAAUV,EAAM0lG,eAAeC,SAASn9F,QAAU9H,GACnGw6F,YAAa,WACZ,CACD/5F,SAAS,QAAS,IAAM,EAAC,QAAay6F,EAAsB,CAC1DzhD,MAAO,sBACPh7C,MAAO,yBACL,QAAay8F,EAAsB,CACrCzhD,MAAO,SACPh7C,MAAO,aAETyD,EAAG,GACF,EAAG,CAAC,iBACPA,EAAG,IACyC,wBAA1C5C,EAAM0lG,eAAeC,SAASn9F,UAAqC,WAAc,QAAaszF,EAAyB,CACzHx7F,IAAK,EACL65C,MAAO,WACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAM0lG,eAAeC,SAASC,sBAC1C,sBAAuB/lG,EAAO,KAAOA,EAAO,GAAKa,GAAUV,EAAM0lG,eAAeC,SAASC,sBAAwBllG,IAChH,KAAM,EAAG,CAAC,iBACbkC,EAAG,MACC,QAAoB,IAAI,GAAiD,WAA1C5C,EAAM0lG,eAAeC,SAASn9F,UAAwB,WAAc,QAAaszF,EAAyB,CAC7Ix7F,IAAK,EACL65C,MAAO,UACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAM0lG,eAAeC,SAASE,YAC1C,sBAAuBhmG,EAAO,KAAOA,EAAO,GAAKa,GAAUV,EAAM0lG,eAAeC,SAASE,YAAcnlG,GACvGw6F,YAAa,8BACZ,KAAM,EAAG,CAAC,iBACbt4F,EAAG,MACC,QAAoB,IAAI,KAC9BA,EAAG,GACF,EAAG,CAAC,aAAa,QAAoB,MAAO,GAAa,CAAC/C,EAAO,MAAQA,EAAO,KAAM,QAAoB,KAAM,CACjHL,MAAO,eACN,QAAS,IAAKK,EAAO,MAAQA,EAAO,KAAM,QAAoB,KAAM,CACrEL,MAAO,gBACN,QAAS,KAAK,QAAay8F,EAAoB,CAChDyC,MAAO1+F,EAAM8lG,eACb,cAAe,SACd,CACD3kG,SAAS,QAAS,IAAM,EAAC,QAAa26F,EAAyB,KAAM,CACnE3hD,OAAO,QAAS,IAAM,CAACt6C,EAAO,MAAQA,EAAO,KAAM,QAAiB,UAAW,KAAK,QAAasC,EAAuB,CACtHM,QAAS,6CACTC,UAAW,MACX,cAAe,IACd,CACDvB,SAAS,QAAS,IAAM,EAAC,QAAajB,EAA8B,CAClEU,KAAM,kBACN6H,MAAO,CACL,cAAe,MACf,OAAU,eAGd7F,EAAG,MAELzB,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAM8lG,eAAeC,eACjC,sBAAuBlmG,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAM8lG,eAAeC,eAAiBrlG,IAClG,KAAM,EAAG,CAAC,iBACbkC,EAAG,MAELA,EAAG,GACF,EAAG,CAAC,UAAW/C,EAAO,MAAQA,EAAO,KAAM,QAAoB,KAAM,CACtEL,MAAO,gBACN,SAAU,KAAK,QAAay8F,EAAoB,CACjDyC,MAAO1+F,EAAM8lG,eACb,cAAe,SACd,CACD3kG,SAAS,QAAS,IAAM,EAAC,QAAa26F,EAAyB,KAAM,CACnE3hD,OAAO,QAAS,IAAM,CAACt6C,EAAO,MAAQA,EAAO,KAAM,QAAiB,UAAW,KAAK,QAAasC,EAAuB,CACtHM,QAAS,uCACTC,UAAW,MACX,cAAe,IACd,CACDvB,SAAS,QAAS,IAAM,EAAC,QAAajB,EAA8B,CAClEU,KAAM,kBACN6H,MAAO,CACL,cAAe,MACf,OAAU,eAGd7F,EAAG,MAELzB,SAAS,QAAS,IAAM,EAAC,QAAaw6F,EAAsB,CAC1Db,WAAY96F,EAAM8lG,eAAeE,cACjC,sBAAuBnmG,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAM8lG,eAAeE,cAAgBtlG,IACjG,KAAM,EAAG,CAAC,iBACbkC,EAAG,MAELA,EAAG,GACF,EAAG,CAAC,aAAa,QAAaghG,EAA+B,CAC9D/1E,MAAO7tB,EAAMoK,QACb3J,QAASR,EAAS88F,cACjB,KAAM,EAAG,CAAC,OAAQ,aAAa,QAAab,EAAsB,CACnEpB,WAAY96F,EAAM+kG,sBAClB,sBAAuBllG,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAM+kG,sBAAwBrkG,GAC3FG,MAAO,gBACP0wB,MAAOtxB,EAASgmG,aACf,CACDrsB,QAAQ,QAAS,IAAM,EAAC,QAAoB,OAAQ,GAAa,EAAC,QAAavyE,EAAsB,CACnG5G,QAASZ,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAM+kG,uBAAwB,IAC5E,CACD5jG,SAAS,QAAS,IAAM,IAAKtB,EAAO,MAAQA,EAAO,IAAM,EAAC,QAAiB,MAAO,OAClF+C,EAAG,KACD,QAAayE,EAAsB,CACrCnG,KAAM,UACNT,QAASR,EAASimG,aACjB,CACD/kG,SAAS,QAAS,IAAM,IAAKtB,EAAO,MAAQA,EAAO,IAAM,EAAC,QAAiB,MAAO,OAClF+C,EAAG,GACF,EAAG,CAAC,gBACPzB,SAAS,QAAS,IAAM,EAAC,QAAa86F,EAAoB,CACxDyC,MAAO1+F,EAAMmmG,SACbvH,MAAO5+F,EAAMomG,WACb37F,IAAK,YACL,cAAe,SACd,CACDtJ,SAAS,QAAS,IAAM,EAAC,QAAa26F,EAAyB,CAC7D3hD,MAAO,WACP5d,KAAM,QACL,CACDp7B,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAMmmG,SAASnlG,KAC3B,sBAAuBnB,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMmmG,SAASnlG,KAAON,GACnFw6F,YAAa,cACZ,KAAM,EAAG,CAAC,iBACbt4F,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,KACP5d,KAAM,eACL,CACDp7B,SAAS,QAAS,IAAM,EAAC,QAAa2iG,EAA8B,CAClEhJ,WAAY96F,EAAMmmG,SAASjB,YAC3B,sBAAuBrlG,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMmmG,SAASjB,YAAcxkG,IACzF,CACDS,SAAS,QAAS,IAAM,EAAC,QAAa0iG,EAAwB,CAC5D1pD,MAAO,UACN,CACDh5C,SAAS,QAAS,IAAM,IAAKtB,EAAO,MAAQA,EAAO,IAAM,EAAC,QAAiB,MAAO,OAClF+C,EAAG,KACD,QAAaihG,EAAwB,CACvC1pD,MAAO,UACN,CACDh5C,SAAS,QAAS,IAAM,IAAKtB,EAAO,MAAQA,EAAO,IAAM,EAAC,QAAiB,MAAO,OAClF+C,EAAG,KACD,QAAaihG,EAAwB,CACvC1pD,MAAO,QACN,CACDh5C,SAAS,QAAS,IAAM,IAAKtB,EAAO,MAAQA,EAAO,IAAM,EAAC,QAAiB,MAAO,OAClF+C,EAAG,MAELA,EAAG,GACF,EAAG,CAAC,iBACPA,EAAG,MAELA,EAAG,GACF,EAAG,CAAC,QAAS,YAChBA,EAAG,GACF,EAAG,CAAC,aAAc,WAAW,QAAas5F,EAAsB,CACjEpB,WAAY96F,EAAMqmG,oBAClB,sBAAuBxmG,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMqmG,oBAAsB3lG,GACzFG,MAAO,eACP0wB,MAAOtxB,EAASgmG,aACf,CACDrsB,QAAQ,QAAS,IAAM,EAAC,QAAoB,OAAQ,GAAa,EAAC,QAAavyE,EAAsB,CACnG5G,QAASZ,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMqmG,qBAAsB,IAC1E,CACDllG,SAAS,QAAS,IAAM,IAAKtB,EAAO,MAAQA,EAAO,IAAM,EAAC,QAAiB,MAAO,OAClF+C,EAAG,KACD,QAAayE,EAAsB,CACrCnG,KAAM,UACNT,QAASR,EAASqmG,aACjB,CACDnlG,SAAS,QAAS,IAAM,IAAKtB,EAAO,MAAQA,EAAO,IAAM,EAAC,QAAiB,MAAO,OAClF+C,EAAG,GACF,EAAG,CAAC,gBACPzB,SAAS,QAAS,IAAM,EAAC,QAAa86F,EAAoB,CACxDyC,MAAO1+F,EAAMumG,aACb3H,MAAO5+F,EAAMomG,WACb37F,IAAK,gBACL,cAAe,SACd,CACDtJ,SAAS,QAAS,IAAM,EAAC,QAAa26F,EAAyB,CAC7D3hD,MAAO,YACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAMumG,aAAavlG,KAC/B,sBAAuBnB,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMumG,aAAavlG,KAAON,GACvF6B,SAAU,IACT,KAAM,EAAG,CAAC,iBACbK,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,KACP5d,KAAM,eACL,CACDp7B,SAAS,QAAS,IAAM,EAAC,QAAa2iG,EAA8B,CAClEhJ,WAAY96F,EAAMumG,aAAarB,YAC/B,sBAAuBrlG,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMumG,aAAarB,YAAcxkG,IAC7F,CACDS,SAAS,QAAS,IAAM,EAAC,QAAa0iG,EAAwB,CAC5D1pD,MAAO,UACN,CACDh5C,SAAS,QAAS,IAAM,IAAKtB,EAAO,MAAQA,EAAO,IAAM,EAAC,QAAiB,MAAO,OAClF+C,EAAG,KACD,QAAaihG,EAAwB,CACvC1pD,MAAO,UACN,CACDh5C,SAAS,QAAS,IAAM,IAAKtB,EAAO,MAAQA,EAAO,IAAM,EAAC,QAAiB,MAAO,OAClF+C,EAAG,KACD,QAAaihG,EAAwB,CACvC1pD,MAAO,QACN,CACDh5C,SAAS,QAAS,IAAM,IAAKtB,EAAO,MAAQA,EAAO,IAAM,EAAC,QAAiB,MAAO,OAClF+C,EAAG,MAELA,EAAG,GACF,EAAG,CAAC,iBACPA,EAAG,MAELA,EAAG,GACF,EAAG,CAAC,QAAS,YAChBA,EAAG,GACF,EAAG,CAAC,aAAc,WAAW,QAAas5F,EAAsB,CACjEpB,WAAY96F,EAAMwmG,sBAClB,sBAAuB3mG,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMwmG,sBAAwB9lG,GAC3FG,MAAO,aACP0wB,MAAOtxB,EAASgmG,aACf,CACDrsB,QAAQ,QAAS,IAAM,EAAC,QAAoB,OAAQ,GAAa,EAAC,QAAavyE,EAAsB,CACnGnG,KAAM,UACNT,QAASZ,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMwmG,uBAAwB,IAC5E,CACDrlG,SAAS,QAAS,IAAM,IAAKtB,EAAO,MAAQA,EAAO,IAAM,EAAC,QAAiB,QAAS,OACpF+C,EAAG,QAELzB,SAAS,QAAS,IAAM,EAAC,QAAoB,MAAO,GAAa,EAAC,QAAoB,IAAK,GAAa,EAAC,QAAajB,EAA8B,CAClJU,KAAM,uBACN6H,MAAO,CACL,eAAgB,SAEhB5I,EAAO,MAAQA,EAAO,KAAM,QAAiB,wCAAyC,OAAO,QAAao8F,EAAoB,CAChI,cAAe,SACd,CACD96F,SAAS,QAAS,IAAM,EAAC,QAAa26F,EAAyB,CAC7D3hD,MAAO,YACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAoB,OAAQ,MAAM,QAAiBnB,EAAMymG,aAAazlG,MAAO,KACtG4B,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,WACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAMymG,aAAahH,MAC/B,sBAAuB5/F,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAMymG,aAAahH,MAAQ/+F,GACxFu/F,SAAU,IACT,CACDyG,QAAQ,QAAS,IAAM,EAAC,QAAar/F,EAAsB,CACzD5G,QAASR,EAAS0mG,WACjB,CACDxlG,SAAS,QAAS,IAAM,IAAKtB,EAAO,MAAQA,EAAO,IAAM,EAAC,QAAiB,MAAO,OAClF+C,EAAG,GACF,EAAG,CAAC,cACPA,EAAG,GACF,EAAG,CAAC,iBACPA,EAAG,MAELA,EAAG,QAELA,EAAG,GACF,EAAG,CAAC,aAAc,aAAc,CAAC,CAAC2E,EAAoBvH,EAAMoK,UACjE,C,YCniBA,IACE0tF,WAAY,CACV8O,mBAAkB,IAEpB,IAAAvlG,GACE,MAAO,CACL0iG,aAAc,CACZC,KAAM,CAAC,EACPQ,MAAO,CAAC,GAEVkB,eAAgB,CACdC,SAAU,CAAC,GAEbG,eAAgB,CAAC,EACjBb,UAAW,GAGX76F,SAAS,EACTq7F,cAAc,EAEdoB,gBAAiB,GAEjBC,iBAAkB,GAGlBxC,qBAAqB,EAErBO,sBAAsB,EAItBE,uBAAuB,EACvBsB,qBAAqB,EACrBG,uBAAuB,EACvBL,SAAU,CACRnlG,KAAM,GACN+lG,MAAO,GACP7B,YAAa,IAEfqB,aAAc,CACZl7F,GAAI,GACJrK,KAAM,GACN+lG,MAAO,GACP7B,YAAa,IAEfuB,aAAc,CACZzlG,KAAM,GACNy+F,MAAO,IAETwE,cAAe,CACbC,SAAU,CAAC,CACT8C,UAAW,CAACC,EAAM9nG,EAAO2f,KAEvB,MAAMooF,EAAmB,CAAC,IAAK,IAAK,IAAK,IAAK,KACxCC,EAAkBD,EAAiB3kC,KAAK6kC,GAAQjoG,GAASA,EAAMixB,SAASg3E,IAC1ED,EACFroF,EAAS,IAAI2hB,MAAM,+BAEnB3hB,KAGJwyC,QAAS,SAEXizC,uBAAwB,CAAC,CACvB56F,QAAS,YACT2nD,QAAS,QACR,CACD01C,UAAW,CAACC,EAAM9nG,EAAO2f,KACnB3f,GAASA,IAAUoC,KAAKwiG,aAAaC,KAAKE,SAC5CplF,EAAS,IAAI2hB,MAAM,cAEnB3hB,KAGJwyC,QAAS,UAGbmzC,eAAgB,CACdK,wBAAyB,CAAC,CACxBn7F,QAAS,YACT2nD,QAAS,QACR,CACD01C,UAAW,CAACC,EAAM9nG,EAAO2f,KACnB3f,GAASA,IAAUoC,KAAKwiG,aAAaS,MAAMG,cAC7C7lF,EAAS,IAAI2hB,MAAM,cAEnB3hB,KAGJwyC,QAAS,UAGb80C,WAAY,CACVplG,KAAM,CAAC,CACLksF,UAAU,EACVvjF,QAAS,aACT2nD,QAAS,SAEX4zC,YAAa,CAAC,CACZhY,UAAU,EACVvjF,QAAS,QACT2nD,QAAS,YAIjB,EACAknC,SAAU,CACR,WAAAyN,GACE,OAAOtkG,OAAOC,WAAa,IAAM,MAAQ,KAC3C,GAEFN,QAAS,CACP,mBAAA8iG,GACM7iG,KAAKwiG,aAAaC,KAAKE,WAAa3iG,KAAKslG,gBAC3CtlG,KAAK+iG,qBAAsB,EAE3B/iG,KAAK+iG,qBAAsB,CAE/B,EACA,oBAAAM,GACMrjG,KAAKwiG,aAAaS,MAAMG,gBAAkBpjG,KAAKulG,iBACjDvlG,KAAKsjG,sBAAuB,EAE5BtjG,KAAKsjG,sBAAuB,CAEhC,EAEA,iBAAAO,CAAkBiC,GAChB,MAAMC,EAAgB,CACpB,OAAU,KACV,OAAU,KACV,KAAQ,MAEV,OAAOA,EAAcD,IAAeA,CACtC,EACA,UAAAhC,CAAWkC,GACT,OAAO,IAAIp5D,KAAKo5D,GAAY5/F,eAAe,QAC7C,EACA,mBAAM6/F,GACJjmG,KAAKkkG,cAAe,EACpB,IACE,MAAMzT,QAAiB,EAAAO,GAAA,GAAc,yBAC/BlxF,QAAa2wF,EAASU,OAC5BnxF,KAAK0jG,UAAY5jG,EAAKomG,QAAU,EAClC,CAAE,MAAO5jC,GACPtiE,KAAK43F,SAASt1B,MAAM,cACtB,CAAE,QACAtiE,KAAKkkG,cAAe,CACtB,CACF,EACA,WAAAS,GACE3kG,KAAKk4F,MAAMiO,UAAUtF,SAASgB,UAC5B,GAAKzmF,EACL,IACEpb,KAAK4kG,SAASY,MAAQ,QACtB,MAAM/U,QAAiB,EAAAO,GAAA,GAAc,wBAAyB,CAC5D1rE,OAAQ,OACR0tE,QAAS,CACP,eAAgB,oBAElB5a,KAAMhrD,KAAKC,UAAUrtB,KAAK4kG,YAEtB9kG,QAAa2wF,EAASU,OACxBV,EAASn3E,IACXtZ,KAAKklG,aAAe,CAClBzlG,KAAMK,EAAKL,KACXy+F,MAAOp+F,EAAKo+F,OAEdl+F,KAAKwjG,uBAAwB,EAC7BxjG,KAAKilG,uBAAwB,EAC7BjlG,KAAK4kG,SAAW,CACdnlG,KAAM,GACN+lG,MAAO,GACP7B,YAAa,UAET3jG,KAAKimG,gBACXjmG,KAAK43F,SAASxG,QAAQ,cAEtBpxF,KAAK43F,SAASt1B,MAAMxiE,EAAKwiE,OAAS,YAEtC,CAAE,MAAOA,GACPtiE,KAAK43F,SAASt1B,MAAM,YACtB,GAEJ,EACA,SAAA0hC,CAAU9F,GACRl+F,KAAKglG,aAAe,CAClBl7F,GAAIo0F,EAAMp0F,GACVrK,KAAMy+F,EAAMz+F,KACZ+lG,MAAOtH,EAAMsH,MACb7B,YAAa,IAAIzF,EAAMyF,cAEzB3jG,KAAK8kG,qBAAsB,CAC7B,EACA,WAAAC,GACE/kG,KAAKk4F,MAAMkO,cAAcvF,SAASgB,UAChC,GAAKzmF,EACL,IACE,MAAMq1E,QAAiB,EAAAO,GAAA,GAAc,wBAAyB,CAC5D1rE,OAAQ,MACR0tE,QAAS,CACP,eAAgB,oBAElB5a,KAAMhrD,KAAKC,UAAU,CACnBg5E,QAASrmG,KAAKglG,aAAal7F,GAC3B65F,YAAa3jG,KAAKglG,aAAarB,gBAG7B7jG,QAAa2wF,EAASU,OACxBV,EAASn3E,IACXtZ,KAAK8kG,qBAAsB,QACrB9kG,KAAKimG,gBACXjmG,KAAK43F,SAASxG,QAAQ,gBAEtBpxF,KAAK43F,SAASt1B,MAAMxiE,EAAKwiE,OAAS,YAEtC,CAAE,MAAOA,GACPtiE,KAAK43F,SAASt1B,MAAM,YACtB,GAEJ,EACA,iBAAM2hC,CAAYoC,GAChB,UACQrmG,KAAKq4F,SAAS,uBAAwB,KAAM,CAChDC,kBAAmB,KACnBC,iBAAkB,KAClB54F,KAAM,YAER,MAAM8wF,QAAiB,EAAAO,GAAA,GAAc,4BAA4BqV,IAAW,CAC1E/gF,OAAQ,WAEJxlB,QAAa2wF,EAASU,OACxBV,EAASn3E,UACLtZ,KAAKimG,gBACXjmG,KAAK43F,SAASxG,QAAQ,cAEtBpxF,KAAK43F,SAASt1B,MAAMxiE,EAAKwiE,OAAS,YAEtC,CAAE,MAAOA,GACO,WAAVA,GACFtiE,KAAK43F,SAASt1B,MAAM,YAExB,CACF,EACA,eAAM8iC,GACJ,UACQkB,UAAUC,UAAUC,UAAUxmG,KAAKklG,aAAahH,OACtDl+F,KAAK43F,SAASxG,QAAQ,eACxB,CAAE,MAAO9uB,GACPtiE,KAAK43F,SAASt1B,MAAM,aACtB,CACF,EACA,YAAAk5B,GAEE,IAAIiL,EAAqB,GAGzBA,EAAmB/mF,KAAK,IAAI0vB,QAAQ5T,IAClCx7B,KAAKk4F,MAAMwO,aAAa7F,SAASzlF,IAC/BogB,EAAQpgB,QAKZqrF,EAAmB/mF,KAAK,IAAI0vB,QAAQ5T,IAClCx7B,KAAKk4F,MAAMyO,cAAc9F,SAASzlF,IAChCogB,EAAQpgB,QAKZg0B,QAAQoB,IAAIi2D,GAAoBn2D,KAAKs2D,IACnC,MAAMC,EAAUD,EAAQE,MAAM1rF,GAASA,GACvC,IAAKyrF,EACH,OAEF,MAAMxS,EAAW,CACf0S,KAAM/mG,KAAKwiG,aACXwE,OAAQhnG,KAAKmkG,eACb8C,OAAQjnG,KAAKukG,uBAGRlQ,EAAS0S,KAAKtE,KAAKO,8BACnB3O,EAAS0S,KAAK9D,MAAMM,yBAC3B,EAAAvS,GAAA,GAAc,iCAAkC,CAC9C1rE,OAAQ,OACR0tE,QAAS,CACP,eAAgB,oBAElB5a,KAAMhrD,KAAKC,UAAUgnE,KACpB/jD,KAAK,KACNtwC,KAAK43F,SAASxG,QAAQ,SAEtBpxF,KAAKslG,gBAAkBtlG,KAAKwiG,aAAaC,KAAKE,SAC9C3iG,KAAKulG,iBAAmBvlG,KAAKwiG,aAAaS,MAAMG,cAChDpjG,KAAK+iG,qBAAsB,EAC3B/iG,KAAKsjG,sBAAuB,KAGlC,GAEF,OAAAhjG,GACEN,KAAK6I,SAAU,GAEf,EAAAmoF,GAAA,GAAc,kCAAkC1gD,KAAKmgD,GAAYA,EAASU,QAAQ7gD,KAAKxwC,IACrFE,KAAKwiG,aAAe1iG,EAAKinG,KACzB/mG,KAAKmkG,eAAiBrkG,EAAKknG,OAC3BhnG,KAAKukG,eAAiBzkG,EAAKmnG,OAG3BjnG,KAAKslG,gBAAkBtlG,KAAKwiG,aAAaC,KAAKE,SAC9C3iG,KAAKulG,iBAAmBvlG,KAAKwiG,aAAaS,MAAMG,cAChDpjG,KAAKwiG,aAAaC,KAAKO,uBAAyB,GAChDhjG,KAAKwiG,aAAaS,MAAMM,wBAA0B,GAGlDvjG,KAAKimG,kBACJlE,QAAQ,KACT/hG,KAAK6I,SAAU,GAEnB,GC/TF,MAAM,IAA2B,OAAgB,GAAQ,CAAC,CAAC,SAAS,IAAQ,CAAC,YAAY,qBAEzF,UCRA,MAAM,GAAa,CACjB5K,MAAO,iBAEH,GAAa,CACjBA,MAAO,eAEF,SAAS,GAAOI,EAAMC,EAAQC,EAAQC,EAAQC,EAAOC,GAC1D,MAAMC,GAA+B,QAAkB,qBACjDiC,EAAwB,KACxBy5F,EAAuB,MACvBC,EAAuB,MACvBF,EAAuB,MACvBI,EAAsB,MACtBD,EAA0B,MAC1BG,EAAqB,MACrB2H,EAAgC,GAChCr8F,EAAqB,IAC3B,OAAO,UAAiB,WAAc,QAAoB,MAAO,GAAY,GAAE,SAAW,IAAO,QAAoB,KAAW,MAAM,QAAYtH,EAASwoG,gBAAiB,CAACC,EAAeC,MACnL,WAAc,QAAoB,MAAO,CAC9CroG,IAAKqoG,EACLnpG,MAAO,kBACN,EAAC,QAAoB,KAAM,IAAY,QAAiBmpG,GAAe,IAAI,QAAa1M,EAAoB,CAC7GyC,MAAO1+F,EAAM41F,SACb,cAAe,SACd,CACDz0F,SAAS,QAAS,IAAM,GAAE,SAAW,IAAO,QAAoB,KAAW,MAAM,QAAYunG,EAAe,CAACE,EAASroG,MAC7G,WAAc,QAAau7F,EAAyB,CACzDx7F,IAAKsoG,EAAQv9F,IACZ,CACD8uC,OAAO,QAAS,IAAM,EAAC,SAAiB,QAAiByuD,EAAQzuD,OAAS,IAAK,GAAIyuD,EAAQlvB,UAAW,WAAc,QAAav3E,EAAuB,CACtJ7B,IAAK,EACLmC,QAASmmG,EAAQlvB,QACjBh3E,UAAW,MACX,cAAe,IACd,CACDvB,SAAS,QAAS,IAAM,EAAC,QAAajB,EAA8B,CAClEU,KAAM,kBACN6H,MAAO,CACL,cAAe,MACf,OAAU,eAGd7F,EAAG,GACF,EAAG,CAAC,cAAe,QAAoB,IAAI,KAC9CzB,SAAS,QAAS,IAAM,CAAkB,WAAjBynG,EAAQ1nG,OAAqB,WAAc,QAAa26F,EAAsB,CACrGv7F,IAAK,EACLw6F,WAAY8N,EAAQzpG,MACpB,sBAAuBuB,GAAUkoG,EAAQzpG,MAAQuB,EACjD6B,SAAUqmG,EAAQ5L,MAClB9B,YAAa0N,EAAQ1N,YACrBzyF,MAAO,CACL,MAAS,SAEV,CACDtH,SAAS,QAAS,IAAM,GAAE,SAAW,IAAO,QAAoB,KAAW,MAAM,QAAYynG,EAAQvgG,QAASgpC,KACrG,WAAc,QAAauqD,EAAsB,CACtDt7F,IAAK+wC,EAAOlyC,MACZg7C,MAAO9I,EAAO8I,MACdh7C,MAAOkyC,EAAOlyC,OACb,KAAM,EAAG,CAAC,QAAS,YACpB,QACJyD,EAAG,GACF,KAAM,CAAC,aAAc,sBAAuB,WAAY,iBAAoC,gBAAjBgmG,EAAQ1nG,OAA0B,WAAc,QAAa26F,EAAsB,CAC/Jv7F,IAAK,EACLw6F,WAAY8N,EAAQzpG,MACpB,sBAAuBuB,GAAUkoG,EAAQzpG,MAAQuB,EACjD6B,UAAWtC,EAAS4oG,sBAA+D,IAAvC5oG,EAAS6oG,mBAAmB3gG,OACxE+yF,YAAa,WACb6N,UAAW,GACXtgG,MAAO,CACL,MAAS,SAEV,CACDtH,SAAS,QAAS,IAAM,GAAE,SAAW,IAAO,QAAoB,KAAW,MAAM,QAAYlB,EAAS6oG,mBAAoB9J,KACjH,WAAc,QAAapD,EAAsB,CACtDt7F,IAAK0+F,EAAGh+F,KACRm5C,MAAO6kD,EAAGh+F,KACV7B,MAAO6/F,EAAGh+F,MACT,KAAM,EAAG,CAAC,QAAS,YACpB,QACJ4B,EAAG,GACF,EAAG,CAAC,aAAc,sBAAuB,cAAiC,YAAjBgmG,EAAQ1nG,OAAsB,WAAc,QAAay6F,EAAsB,CACzIr7F,IAAK,EACLw6F,WAAY8N,EAAQzpG,MACpB,sBAAuBuB,GAAUkoG,EAAQzpG,MAAQuB,EACjD6B,SAAUqmG,EAAQ5L,OACjB,KAAM,EAAG,CAAC,aAAc,sBAAuB,gBAAiB,WAAc,QAAajB,EAAqB,CACjHz7F,IAAK,EACLw6F,WAAY8N,EAAQzpG,MACpB,sBAAuBuB,GAAUkoG,EAAQzpG,MAAQuB,EACjD6B,SAAUqmG,EAAQ5L,MAClB9B,YAAa0N,EAAQ1N,aACpB,KAAM,EAAG,CAAC,aAAc,sBAAuB,WAAY,mBAC9Dt4F,EAAG,GACF,QACD,QACJA,EAAG,GACF,KAAM,CAAC,cACR,OAAO,QAAaghG,EAA+B,CACrD/1E,MAAO7tB,EAAMoK,QACb3J,QAASR,EAAS88F,cACjB,KAAM,EAAG,CAAC,OAAQ,eAAgB,CAAC,CAACx1F,EAAoBvH,EAAMoK,UACnE,C,cC9FA,IACE0tF,WAAY,CACV8O,mBAAkB,IAEpB,IAAAvlG,GACE,MAAO,CACLu0F,SAAU,CACR7kD,OAAQ,IAGV3mC,SAAS,EAET4+F,kBAAmB,CAAC,EAExB,EACAxQ,SAAU,CAER,eAAAiQ,GACE,MAAM9nD,EAAU,CAAC,EAUjB,OATIp/C,KAAKq0F,SAAS7kD,QAChBxvC,KAAKq0F,SAAS7kD,OAAOnqB,QAAQgiF,IAC3B,MAAMK,EAAWL,EAAQK,UAAY,OAChCtoD,EAAQsoD,KACXtoD,EAAQsoD,GAAY,IAEtBtoD,EAAQsoD,GAAUhoF,KAAK2nF,KAGpBjoD,CACT,EAEA,oBAAAkoD,GACE,MAAMK,EAAiB3nG,KAAKq0F,SAAS7kD,QAAQgQ,KAAK1yC,GAAc,yBAATA,EAAEhD,IACzD,OAAO69F,GAAgB/pG,OAAS,EAClC,EAEA,kBAAA2pG,GACE,OAAOvnG,KAAKynG,kBAAkBznG,KAAKsnG,uBAAyB,EAC9D,GAEFjZ,MAAO,CAEL,oBAAAiZ,CAAqBM,EAAQC,GAC3B,GAAID,IAAWC,EAAQ,CACrB,MAAMC,EAAqB9nG,KAAKq0F,SAAS7kD,QAAQgQ,KAAK1yC,GAAc,uBAATA,EAAEhD,IAC7D,GAAIg+F,EAAoB,CACtB,MAAMC,EAAiB/nG,KAAKynG,kBAAkBG,IAAW,GACpDG,EAAe/mC,KAAKy8B,GAAMA,EAAGh+F,OAASqoG,EAAmBlqG,SAC5DkqG,EAAmBlqG,MAAQ,GAE/B,CACF,CACF,GAEFmC,QAAS,CACP,YAAAy7F,IACE,EAAAxK,GAAA,GAAc,6BAA8B,CAC1C1rE,OAAQ,OACR0tE,QAAS,CACP,eAAgB,oBAElB5a,KAAMhrD,KAAKC,UAAUrtB,KAAKq0F,YACzB/jD,KAAK,IAAMtwC,KAAK43F,SAASxG,QAAQ,SACtC,EAEA,4BAAM4W,GACJ,IACE,MAAMvX,QAAiBwX,GAAA,EAAM16E,IAAI,iBAC7BkjE,EAAS3wF,OACXE,KAAKynG,kBAAoBhX,EAAS3wF,KAEtC,CAAE,MAAOwiE,GACPhnC,QAAQgnC,MAAM,sCAAuCA,EACvD,CACF,GAEF,OAAAhiE,GACEN,KAAK6I,SAAU,EAEf7I,KAAKgoG,0BAEL,EAAAhX,GAAA,GAAc,8BAA8B1gD,KAAKmgD,GAAYA,EAASU,QAAQ7gD,KAAKxwC,IACjFE,KAAKq0F,SAAWv0F,EAEZE,KAAKq0F,SAAS7kD,QAChBxvC,KAAKq0F,SAAS7kD,OAAOnqB,QAAQgiF,IACN,YAAjBA,EAAQ1nG,OAEmB,kBAAlB0nG,EAAQzpG,MACjBypG,EAAQzpG,MAA0B,SAAlBypG,EAAQzpG,WACG+O,IAAlB06F,EAAQzpG,OAAyC,OAAlBypG,EAAQzpG,QAEhDypG,EAAQzpG,MAAQypG,EAAQznG,UAAW,QAK1CmiG,QAAQ,KACT/hG,KAAK6I,SAAU,GAEnB,GCtGF,MAAM,IAA2B,OAAgB,GAAQ,CAAC,CAAC,SAAS,IAAQ,CAAC,YAAY,qBAEzF,UCRA,MAAM,GAAa,CACjB5K,MAAO,mBAEH,GAAa,CACjBA,MAAO,kBAEH,GAAa,CACjBA,MAAO,eAEH,GAAa,CACjBA,MAAO,eAEH,GAAa,CACjBA,MAAO,eAEH,GAAa,CACjBA,MAAO,eAEH,GAAa,CACjBA,MAAO,eAEF,SAAS,GAAOI,EAAMC,EAAQC,EAAQC,EAAQC,EAAOC,GAC1D,MAAMC,GAA+B,QAAkB,qBACjDiC,EAAwB,KACxBw5F,EAAuB,MACvBG,EAA0B,MAC1BG,EAAqB,MACrBF,EAAsB,MACtBH,EAAuB,MACvBC,EAAuB,MACvB+H,EAAgC,GAChCr8F,EAAqB,IAC3B,OAAO,UAAiB,WAAc,QAAoB,MAAO,GAAY,EAAC,QAAoB,MAAO,GAAY,EAAC,QAAoB,KAAM,GAAY,CAAC1H,EAAO,MAAQA,EAAO,KAAM,QAAiB,SAAU,KAAK,QAAasC,EAAuB,CAC3PM,QAAS,iBACTC,UAAW,SACV,CACDvB,SAAS,QAAS,IAAM,EAAC,QAAajB,EAA8B,CAClEU,KAAM,kBACN6H,MAAO,CACL,cAAe,MACf,OAAU,eAGd7F,EAAG,OACC,QAAaq5F,EAAoB,CACrCyC,MAAO1+F,EAAM41F,SAAS6T,UACtB,cAAe,SACd,CACDtoG,SAAS,QAAS,IAAM,EAAC,QAAa26F,EAAyB,CAC7D3hD,MAAO,MACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAaw6F,EAAsB,CAC1Db,WAAY96F,EAAM41F,SAAS6T,UAAU31C,QACrC,sBAAuBj0D,EAAO,KAAOA,EAAO,GAAKa,GAAUV,EAAM41F,SAAS6T,UAAU31C,QAAUpzD,GAC9F6B,SAAUvC,EAAM41F,SAAS6T,UAAUzM,OAClC,KAAM,EAAG,CAAC,aAAc,eAC3Bp6F,EAAG,MAELA,EAAG,GACF,EAAG,CAAC,WAAW,QAAoB,KAAM,GAAY,CAAC/C,EAAO,MAAQA,EAAO,KAAM,QAAiB,YAAa,KAAK,QAAasC,EAAuB,CAC1JM,QAAS,eACTC,UAAW,SACV,CACDvB,SAAS,QAAS,IAAM,EAAC,QAAajB,EAA8B,CAClEU,KAAM,kBACN6H,MAAO,CACL,cAAe,MACf,OAAU,eAGd7F,EAAG,OACC,QAAaq5F,EAAoB,CACrCyC,MAAO1+F,EAAM41F,SAAS8T,eACtB,cAAe,SACd,CACDvoG,SAAS,QAAS,IAAM,EAAC,QAAa26F,EAAyB,CAC7D3hD,MAAO,MACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAaw6F,EAAsB,CAC1Db,WAAY96F,EAAM41F,SAAS8T,eAAe51C,QAC1C,sBAAuBj0D,EAAO,KAAOA,EAAO,GAAKa,GAAUV,EAAM41F,SAAS8T,eAAe51C,QAAUpzD,GACnG6B,SAAUvC,EAAM41F,SAAS8T,eAAe1M,OACvC,KAAM,EAAG,CAAC,aAAc,eAC3Bp6F,EAAG,KACD,QAAak5F,EAAyB,CACxCv/D,KAAM,6BACL,CACD4d,OAAO,QAAS,IAAM,CAACt6C,EAAO,MAAQA,EAAO,KAAM,QAAoB,OAAQ,KAAM,MAAO,KAAK,QAAasC,EAAuB,CACnIM,QAAS,2FACTC,UAAW,QACX,cAAe,IACd,CACDvB,SAAS,QAAS,IAAM,EAAC,QAAajB,EAA8B,CAClEU,KAAM,kBACN6H,MAAO,CACL,cAAe,MACf,OAAU,eAGd7F,EAAG,MAELzB,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAM41F,SAAS8T,eAAeC,WAC1C,sBAAuB9pG,EAAO,KAAOA,EAAO,GAAKa,GAAUV,EAAM41F,SAAS8T,eAAeC,WAAajpG,GACtG6B,SAAUvC,EAAM41F,SAAS8T,eAAe1M,OACvC,KAAM,EAAG,CAAC,aAAc,eAC3Bp6F,EAAG,MAELA,EAAG,GACF,EAAG,CAAC,WAAW,QAAoB,KAAM,GAAY,CAAC/C,EAAO,MAAQA,EAAO,KAAM,QAAiB,SAAU,KAAK,QAAasC,EAAuB,CACvJM,QAAS,4CACTC,UAAW,QACX,cAAe,IACd,CACDvB,SAAS,QAAS,IAAM,EAAC,QAAajB,EAA8B,CAClEU,KAAM,kBACN6H,MAAO,CACL,cAAe,MACf,OAAU,eAGd7F,EAAG,OACC,QAAaq5F,EAAoB,CACrCyC,MAAO1+F,EAAM41F,SAASgU,aACtB,cAAe,SACd,CACDzoG,SAAS,QAAS,IAAM,EAAC,QAAa26F,EAAyB,CAC7D3hD,MAAO,MACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAaw6F,EAAsB,CAC1Db,WAAY96F,EAAM41F,SAASgU,aAAa91C,QACxC,sBAAuBj0D,EAAO,KAAOA,EAAO,GAAKa,GAAUV,EAAM41F,SAASgU,aAAa91C,QAAUpzD,GACjG6B,SAAUvC,EAAM41F,SAASgU,aAAa5M,OACrC,KAAM,EAAG,CAAC,aAAc,eAC3Bp6F,EAAG,KACD,QAAak5F,EAAyB,CACxCv/D,KAAM,2BACL,CACD4d,OAAO,QAAS,IAAM,CAACt6C,EAAO,MAAQA,EAAO,KAAM,QAAoB,OAAQ,KAAM,QAAS,KAAK,QAAasC,EAAuB,CACrIO,UAAW,QACX,cAAe,IACd,CACDD,SAAS,QAAS,IAAM,IAAK5C,EAAO,MAAQA,EAAO,IAAM,EAAC,QAAoB,MAAO,CACnF4I,MAAO,CACL,YAAa,QACb,cAAe,QAEhB,EAAC,QAAoB,IAAK,CAC3BA,MAAO,CACL,OAAU,cAEX,EAAC,QAAoB,IAAK,KAAM,0BAA0B,QAAoB,IAAK,CACpFA,MAAO,CACL,OAAU,cAEX,8BAA8B,QAAoB,IAAK,CACxDA,MAAO,CACL,OAAU,YACV,MAAS,YAEV,+BAA+B,QAAoB,IAAK,CACzDA,MAAO,CACL,OAAU,IACV,MAAS,YAEV,yCAA0C,OAC7CtH,SAAS,QAAS,IAAM,EAAC,QAAajB,EAA8B,CAClEU,KAAM,kBACN6H,MAAO,CACL,cAAe,MACf,OAAU,eAGd7F,EAAG,MAELzB,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAM41F,SAASgU,aAAaD,WACxC,sBAAuB9pG,EAAO,KAAOA,EAAO,GAAKa,GAAUV,EAAM41F,SAASgU,aAAaD,WAAajpG,GACpG6B,SAAUvC,EAAM41F,SAASgU,aAAa5M,MACtC9B,YAAa,0BACZ,KAAM,EAAG,CAAC,aAAc,eAC3Bt4F,EAAG,MAELA,EAAG,GACF,EAAG,CAAC,WAAW,QAAoB,KAAM,GAAY,CAAC/C,EAAO,MAAQA,EAAO,KAAM,QAAiB,yBAA0B,KAAK,QAAasC,EAAuB,CACvKM,QAAS,iDACTC,UAAW,QACX,cAAe,IACd,CACDvB,SAAS,QAAS,IAAM,EAAC,QAAajB,EAA8B,CAClEU,KAAM,kBACN6H,MAAO,CACL,cAAe,MACf,OAAU,eAGd7F,EAAG,OACC,QAAaq5F,EAAoB,CACrCyC,MAAO1+F,EAAM41F,SAASiU,mBACtB,cAAe,SACd,CACD1oG,SAAS,QAAS,IAAM,EAAC,QAAa26F,EAAyB,CAC7D3hD,MAAO,QACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAM41F,SAASiU,mBAAmBC,WAC9C,sBAAuBjqG,EAAO,KAAOA,EAAO,GAAKa,GAAUV,EAAM41F,SAASiU,mBAAmBC,WAAappG,GAC1G6B,SAAUvC,EAAM41F,SAASiU,mBAAmB7M,OAC3C,KAAM,EAAG,CAAC,aAAc,eAC3Bp6F,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,QACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAM41F,SAASiU,mBAAmBE,SAC9C,sBAAuBlqG,EAAO,KAAOA,EAAO,GAAKa,GAAUV,EAAM41F,SAASiU,mBAAmBE,SAAWrpG,GACxG6B,SAAUvC,EAAM41F,SAASiU,mBAAmB7M,OAC3C,KAAM,EAAG,CAAC,aAAc,eAC3Bp6F,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,WACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAM41F,SAASiU,mBAAmBG,WAC9C,sBAAuBnqG,EAAO,KAAOA,EAAO,GAAKa,GAAUV,EAAM41F,SAASiU,mBAAmBG,WAAatpG,GAC1G6B,SAAUvC,EAAM41F,SAASiU,mBAAmB7M,MAC5C97F,KAAM,WACN,gBAAiB,GACjBmjG,aAAc,gBACb,KAAM,EAAG,CAAC,aAAc,eAC3BzhG,EAAG,MAELA,EAAG,GACF,EAAG,CAAC,WAAW,QAAoB,KAAM,GAAY,CAAC/C,EAAO,MAAQA,EAAO,KAAM,QAAiB,WAAY,KAAK,QAAasC,EAAuB,CACzJM,QAAS,0BACTC,UAAW,QACX,cAAe,IACd,CACDvB,SAAS,QAAS,IAAM,EAAC,QAAajB,EAA8B,CAClEU,KAAM,kBACN6H,MAAO,CACL,cAAe,MACf,OAAU,eAGd7F,EAAG,OACC,QAAaq5F,EAAoB,CACrCyC,MAAO1+F,EAAM41F,SAASqU,OACtB,cAAe,SACd,CACD9oG,SAAS,QAAS,IAAM,EAAC,QAAa26F,EAAyB,CAC7D3hD,MAAO,MACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAaw6F,EAAsB,CAC1Db,WAAY96F,EAAM41F,SAASqU,OAAOn2C,QAClC,sBAAuBj0D,EAAO,KAAOA,EAAO,GAAKa,GAAUV,EAAM41F,SAASqU,OAAOn2C,QAAUpzD,GAC3F6B,SAAUvC,EAAM41F,SAASqU,OAAOjN,OAC/B,KAAM,EAAG,CAAC,aAAc,eAC3Bp6F,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,OACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAM41F,SAASqU,OAAOC,SAClC,sBAAuBrqG,EAAO,KAAOA,EAAO,GAAKa,GAAUV,EAAM41F,SAASqU,OAAOC,SAAWxpG,GAC5F6B,SAAUvC,EAAM41F,SAASqU,OAAOjN,OAC/B,KAAM,EAAG,CAAC,aAAc,eAC3Bp6F,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,MACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAa46F,EAAqB,CACzDjB,WAAY96F,EAAM41F,SAASqU,OAAOE,SAClC,sBAAuBtqG,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAM41F,SAASqU,OAAOE,SAAWzpG,GAC9F6B,SAAUvC,EAAM41F,SAASqU,OAAOjN,MAChC97F,KAAM,WACN,gBAAiB,GACjBmjG,aAAc,gBACb,KAAM,EAAG,CAAC,aAAc,eAC3BzhG,EAAG,KACD,QAAak5F,EAAyB,CACxC3hD,MAAO,QACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAa06F,EAAsB,CAC1Df,WAAY96F,EAAM41F,SAASqU,OAAOG,cAClC,sBAAuBvqG,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAM41F,SAASqU,OAAOG,cAAgB1pG,GACnG6B,SAAUvC,EAAM41F,SAASqU,OAAOjN,MAChC9B,YAAa,OACb6N,UAAW,IACV,CACD5nG,SAAS,QAAS,IAAM,EAAC,QAAay6F,EAAsB,CAC1DzhD,MAAO,WACPh7C,MAAO,cACL,QAAay8F,EAAsB,CACrCzhD,MAAO,gBACPh7C,MAAO,UACL,QAAay8F,EAAsB,CACrCzhD,MAAO,KACPh7C,MAAO,QACL,QAAay8F,EAAsB,CACrCzhD,MAAO,UACPh7C,MAAO,aACL,QAAay8F,EAAsB,CACrCzhD,MAAO,cACPh7C,MAAO,kBAETyD,EAAG,GACF,EAAG,CAAC,aAAc,eACrBA,EAAG,IACD5C,EAAM41F,SAASqU,OAAOG,eAAiBnqG,EAASoqG,kBAAkBliG,OAAS,IAAK,WAAc,QAAa2zF,EAAyB,CACtIx7F,IAAK,EACL65C,MAAO,SACN,CACDh5C,SAAS,QAAS,IAAM,EAAC,QAAa06F,EAAsB,CAC1Df,WAAY96F,EAAM41F,SAASqU,OAAOK,YAClC,sBAAuBzqG,EAAO,MAAQA,EAAO,IAAMa,GAAUV,EAAM41F,SAASqU,OAAOK,YAAc5pG,GACjG6B,SAAUvC,EAAM41F,SAASqU,OAAOjN,MAChC9B,YAAa,OACb6N,UAAW,IACV,CACD5nG,SAAS,QAAS,IAAM,GAAE,SAAW,IAAO,QAAoB,KAAW,MAAM,QAAYlB,EAASoqG,kBAAmBrL,KAChH,WAAc,QAAapD,EAAsB,CACtDt7F,IAAK0+F,EAAGh+F,KACRm5C,MAAO6kD,EAAGh+F,KACV7B,MAAO6/F,EAAGh+F,MACT,KAAM,EAAG,CAAC,QAAS,YACpB,QACJ4B,EAAG,GACF,EAAG,CAAC,aAAc,eACrBA,EAAG,MACC,QAAoB,IAAI,KAC9BA,EAAG,GACF,EAAG,CAAC,aAAa,QAAaghG,EAA+B,CAC9D/1E,MAAO7tB,EAAMoK,QACb3J,QAASR,EAAS88F,cACjB,KAAM,EAAG,CAAC,OAAQ,eAAgB,CAAC,CAACx1F,EAAoBvH,EAAMoK,UACnE,CC9UA,QACE0tF,WAAY,CACV8O,mBAAkB,IAEpB,IAAAvlG,GACE,MAAO,CACLu0F,SAAU,CACR6T,UAAW,CAAC,EACZC,eAAgB,CAAC,EACjBG,mBAAoB,CAAC,EACrBI,OAAQ,CAAC,EACTL,aAAc,CAAC,GAEjBZ,kBAAmB,CAAC,EAGpB5+F,SAAS,EAEb,EACAouF,SAAU,CAER,iBAAA6R,GACE,MAAM5N,EAAcl7F,KAAKq0F,SAASqU,QAAQG,cAC1C,OAAO3N,GAAcl7F,KAAKynG,kBAAkBvM,IAAqB,EACnE,GAEF7M,MAAO,CACL,kCAEMruF,KAAKq0F,SAASqU,SAChB1oG,KAAKq0F,SAASqU,OAAOK,YAAc,GAEvC,GAEFhpG,QAAS,CACP,YAAAy7F,IACE,EAAAxK,GAAA,GAAc,+BAAgC,CAC5C1rE,OAAQ,OACR0tE,QAAS,CACP,eAAgB,oBAElB5a,KAAMhrD,KAAKC,UAAUrtB,KAAKq0F,YACzB/jD,KAAK,IAAMtwC,KAAK43F,SAASxG,QAAQ,SACtC,EACA,4BAAM4W,GACJ,IACE,MAAMvX,QAAiB,EAAAO,GAAA,GAAc,iBACjCP,EAASn3E,KACXtZ,KAAKynG,wBAA0BhX,EAASU,OAE5C,CAAE,MAAO7uB,GACPhnC,QAAQgnC,MAAM,sCAAuCA,EACvD,CACF,GAEF,OAAAhiE,GACEN,KAAK6I,SAAU,GAEf,EAAAmoF,GAAA,GAAc,gCAAgC1gD,KAAKmgD,GAAYA,EAASU,QAAQ7gD,KAAKxwC,IACnFE,KAAKq0F,SAAWv0F,IACfiiG,QAAQ,KACT/hG,KAAK6I,SAAU,IAGjB7I,KAAKgoG,wBACP,GC7DF,MAAM,IAA2B,OAAgB,GAAQ,CAAC,CAAC,SAAS,IAAQ,CAAC,YAAY,qBAEzF,UCDA,IACEvoG,KAAM,eACN,IAAAK,GACE,MAAO,CACLb,YAAa,SACbqC,mBAAmB,EAEvB,EACA+sF,MAAO,CAEL,cAAe,CACb6T,WAAW,EACX,OAAA75C,CAAQ2gD,GACNhpG,KAAKf,YAAc+pG,EAAQxvF,QAAQ,IAAK,IACxCpZ,OAAO6oG,SAAS,EAAG,EACrB,GAEF,WAAAhqG,CAAYiqG,GAEV,MAAMC,EAAO,IAAID,IACjBlpG,KAAKopG,QAAQ1pF,KAAK,CAChBypF,QAEJ,GAEF5S,WAAY,CACV8S,cAAa,IACbC,cAAa,EACbC,aAAY,GACZC,aAAY,GACZC,eAAc,GACdC,WAAU,GACVC,aAAY,IAEd1S,SAAU,CACR,cAAAh2F,GACE,OAAOb,OAAOC,WAAa,GAC7B,EAEA,gBAAAkB,GACE,MAAM4nG,EAAOnpG,KAAK4pG,OAAOT,KAAK3vF,QAAQ,IAAK,IAC3C,OAAQ2vF,GACN,IAAK,SACH,OAAOI,GACT,IAAK,SACH,OAAOC,GACT,IAAK,WACH,OAAOC,GACT,IAAK,OACH,OAAOC,GACT,IAAK,SACH,OAAOC,GACT,QACE,OAAOJ,GAEb,GAEFxpG,QAAS,CACP,YAAAqB,GACEpB,KAAK6pG,OAAOC,OAAO,iBAAkB,MACrC9pG,KAAKopG,QAAQ1pF,KAAK,cACpB,EAEA,cAAAqqF,GACE,MAAMC,EAAc,UACpB5pG,OAAO6pG,SAASd,KAAOa,EACvBhqG,KAAKf,YAAc+qG,EAAYxwF,QAAQ,IAAK,GAC9C,GAEF,OAAAlZ,GAEOF,OAAO6pG,SAASd,MACnBnpG,KAAK+pG,gBAET,GC3EF,MAAM,IAA2B,OAAgB,GAAQ,CAAC,CAAC,SAAS,GAAQ,CAAC,YAAY,qBAEzF,S","sources":["webpack://sanyue_imghub/./node_modules/@babel/runtime/helpers/esm/typeof.js","webpack://sanyue_imghub/./node_modules/@babel/runtime/helpers/esm/toPrimitive.js","webpack://sanyue_imghub/./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js","webpack://sanyue_imghub/./node_modules/@babel/runtime/helpers/esm/defineProperty.js","webpack://sanyue_imghub/./src/components/SysConfigTabs.vue?8637","webpack://sanyue_imghub/./src/components/SysConfigTabs.vue","webpack://sanyue_imghub/./src/components/SysConfigTabs.vue?909a","webpack://sanyue_imghub/./src/views/SystemConfig.vue?5740","webpack://sanyue_imghub/./src/components/SysCogStatus.vue?8436","webpack://sanyue_imghub/./node_modules/@kurkle/color/dist/color.esm.js","webpack://sanyue_imghub/../../src/helpers/helpers.core.ts","webpack://sanyue_imghub/../../src/helpers/helpers.math.ts","webpack://sanyue_imghub/../../src/helpers/helpers.collection.ts","webpack://sanyue_imghub/../../src/helpers/helpers.extras.ts","webpack://sanyue_imghub/../../src/helpers/helpers.easing.ts","webpack://sanyue_imghub/../../src/helpers/helpers.color.ts","webpack://sanyue_imghub/../../src/core/core.animations.defaults.js","webpack://sanyue_imghub/../../src/core/core.layouts.defaults.js","webpack://sanyue_imghub/../../src/helpers/helpers.intl.ts","webpack://sanyue_imghub/../../src/core/core.ticks.js","webpack://sanyue_imghub/../../src/core/core.scale.defaults.js","webpack://sanyue_imghub/../../src/core/core.defaults.js","webpack://sanyue_imghub/../../src/helpers/helpers.canvas.ts","webpack://sanyue_imghub/../../src/helpers/helpers.options.ts","webpack://sanyue_imghub/../../src/helpers/helpers.config.ts","webpack://sanyue_imghub/../../src/helpers/helpers.curve.ts","webpack://sanyue_imghub/../../src/helpers/helpers.dom.ts","webpack://sanyue_imghub/../../src/helpers/helpers.interpolation.ts","webpack://sanyue_imghub/../../src/helpers/helpers.rtl.ts","webpack://sanyue_imghub/../../src/helpers/helpers.segment.js","webpack://sanyue_imghub/../../src/helpers/helpers.dataset.ts","webpack://sanyue_imghub/../src/core/core.animator.js","webpack://sanyue_imghub/../src/core/core.animation.js","webpack://sanyue_imghub/../src/core/core.animations.js","webpack://sanyue_imghub/../src/core/core.datasetController.js","webpack://sanyue_imghub/../src/controllers/controller.bar.js","webpack://sanyue_imghub/../src/controllers/controller.bubble.js","webpack://sanyue_imghub/../src/controllers/controller.doughnut.js","webpack://sanyue_imghub/../src/controllers/controller.line.js","webpack://sanyue_imghub/../src/controllers/controller.polarArea.js","webpack://sanyue_imghub/../src/controllers/controller.pie.js","webpack://sanyue_imghub/../src/controllers/controller.radar.js","webpack://sanyue_imghub/../src/controllers/controller.scatter.js","webpack://sanyue_imghub/../src/core/core.adapters.ts","webpack://sanyue_imghub/../src/core/core.interaction.js","webpack://sanyue_imghub/../src/core/core.layouts.js","webpack://sanyue_imghub/../src/platform/platform.base.js","webpack://sanyue_imghub/../src/platform/platform.basic.js","webpack://sanyue_imghub/../src/platform/platform.dom.js","webpack://sanyue_imghub/../src/platform/index.js","webpack://sanyue_imghub/../src/core/core.element.ts","webpack://sanyue_imghub/../src/core/core.scale.autoskip.js","webpack://sanyue_imghub/../src/core/core.scale.js","webpack://sanyue_imghub/../src/core/core.typedRegistry.js","webpack://sanyue_imghub/../src/core/core.registry.js","webpack://sanyue_imghub/../src/core/core.plugins.js","webpack://sanyue_imghub/../src/core/core.config.js","webpack://sanyue_imghub/../src/core/core.controller.js","webpack://sanyue_imghub/../src/elements/element.arc.ts","webpack://sanyue_imghub/../src/elements/element.line.js","webpack://sanyue_imghub/../src/elements/element.point.ts","webpack://sanyue_imghub/../src/elements/element.bar.js","webpack://sanyue_imghub/../src/plugins/plugin.legend.js","webpack://sanyue_imghub/../src/plugins/plugin.subtitle.js","webpack://sanyue_imghub/../src/plugins/plugin.tooltip.js","webpack://sanyue_imghub/../src/scales/scale.category.js","webpack://sanyue_imghub/../src/scales/scale.linearbase.js","webpack://sanyue_imghub/../src/scales/scale.linear.js","webpack://sanyue_imghub/../src/scales/scale.logarithmic.js","webpack://sanyue_imghub/../src/scales/scale.radialLinear.js","webpack://sanyue_imghub/../src/scales/scale.time.js","webpack://sanyue_imghub/../src/scales/scale.timeseries.js","webpack://sanyue_imghub/../src/props.ts","webpack://sanyue_imghub/../src/utils.ts","webpack://sanyue_imghub/../src/chart.ts","webpack://sanyue_imghub/../src/typedCharts.ts","webpack://sanyue_imghub/./src/utils/batchProcessor.js","webpack://sanyue_imghub/./src/utils/indexRebuilder.js","webpack://sanyue_imghub/./src/utils/backupGenerator.js","webpack://sanyue_imghub/./src/utils/restoreProcessor.js","webpack://sanyue_imghub/./src/components/SysCogStatus.vue","webpack://sanyue_imghub/./src/components/SysCogStatus.vue?535e","webpack://sanyue_imghub/./src/components/CustomSelect.vue?b677","webpack://sanyue_imghub/./src/components/CustomSelect.vue","webpack://sanyue_imghub/./src/components/CustomSelect.vue?9326","webpack://sanyue_imghub/./src/components/SysCogUpload.vue?2dac","webpack://sanyue_imghub/./src/components/SysCogUpload.vue","webpack://sanyue_imghub/./src/components/SysCogUpload.vue?5e68","webpack://sanyue_imghub/./src/components/FloatingSaveButton.vue?ac4d","webpack://sanyue_imghub/./src/components/FloatingSaveButton.vue","webpack://sanyue_imghub/./src/components/FloatingSaveButton.vue?45e6","webpack://sanyue_imghub/./src/components/SysCogSecurity.vue?279c","webpack://sanyue_imghub/./src/components/SysCogSecurity.vue","webpack://sanyue_imghub/./src/components/SysCogSecurity.vue?e29e","webpack://sanyue_imghub/./src/components/SysCogPage.vue?7031","webpack://sanyue_imghub/./src/components/SysCogPage.vue","webpack://sanyue_imghub/./src/components/SysCogPage.vue?c23d","webpack://sanyue_imghub/./src/components/SysCogOthers.vue?3dca","webpack://sanyue_imghub/./src/components/SysCogOthers.vue","webpack://sanyue_imghub/./src/components/SysCogOthers.vue?ad31","webpack://sanyue_imghub/./src/views/SystemConfig.vue","webpack://sanyue_imghub/./src/views/SystemConfig.vue?d269"],"sourcesContent":["function _typeof(o) {\n \"@babel/helpers - typeof\";\n\n return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (o) {\n return typeof o;\n } : function (o) {\n return o && \"function\" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? \"symbol\" : typeof o;\n }, _typeof(o);\n}\nexport { _typeof as default };","import _typeof from \"./typeof.js\";\nfunction toPrimitive(t, r) {\n if (\"object\" != _typeof(t) || !t) return t;\n var e = t[Symbol.toPrimitive];\n if (void 0 !== e) {\n var i = e.call(t, r || \"default\");\n if (\"object\" != _typeof(i)) return i;\n throw new TypeError(\"@@toPrimitive must return a primitive value.\");\n }\n return (\"string\" === r ? String : Number)(t);\n}\nexport { toPrimitive as default };","import _typeof from \"./typeof.js\";\nimport toPrimitive from \"./toPrimitive.js\";\nfunction toPropertyKey(t) {\n var i = toPrimitive(t, \"string\");\n return \"symbol\" == _typeof(i) ? i : i + \"\";\n}\nexport { toPropertyKey as default };","import toPropertyKey from \"./toPropertyKey.js\";\nfunction _defineProperty(e, r, t) {\n return (r = toPropertyKey(r)) in e ? Object.defineProperty(e, r, {\n value: t,\n enumerable: !0,\n configurable: !0,\n writable: !0\n }) : e[r] = t, e;\n}\nexport { _defineProperty as default };","import { renderList as _renderList, Fragment as _Fragment, openBlock as _openBlock, createElementBlock as _createElementBlock, resolveComponent as _resolveComponent, createVNode as _createVNode, toDisplayString as _toDisplayString, createElementVNode as _createElementVNode, normalizeClass as _normalizeClass } from \"vue\";\nconst _hoisted_1 = {\n class: \"menu-list\"\n};\nconst _hoisted_2 = [\"onClick\"];\nconst _hoisted_3 = {\n class: \"menu-text\"\n};\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n return _openBlock(), _createElementBlock(\"div\", {\n class: _normalizeClass([\"sidebar-container\", {\n 'is-collapsed': $props.isCollapse\n }])\n }, [_createElementVNode(\"div\", _hoisted_1, [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($data.menuItems, item => {\n return _openBlock(), _createElementBlock(\"div\", {\n key: item.index,\n class: _normalizeClass([\"menu-item\", {\n 'is-active': $props.activeIndex === item.index\n }]),\n onClick: $event => $options.handleSelect(item.index)\n }, [_createVNode(_component_font_awesome_icon, {\n icon: item.icon,\n class: \"menu-icon\"\n }, null, 8, [\"icon\"]), _createElementVNode(\"span\", _hoisted_3, _toDisplayString(item.title), 1)], 10, _hoisted_2);\n }), 128))]), _createElementVNode(\"div\", {\n class: \"toggle-button\",\n onClick: _cache[0] || (_cache[0] = (...args) => $options.toggleCollapse && $options.toggleCollapse(...args))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: $props.isCollapse ? 'angle-double-right' : 'angle-double-left'\n }, null, 8, [\"icon\"])])], 2);\n}","export default {\n name: 'SysConfigTabs',\n props: {\n activeIndex: {\n type: String,\n default: 'status'\n },\n isCollapse: {\n type: Boolean,\n default: false\n }\n },\n data() {\n return {\n menuItems: [{\n index: 'status',\n icon: 'chart-bar',\n title: '系统状态'\n }, {\n index: 'upload',\n icon: 'cloud-upload',\n title: '上传设置'\n }, {\n index: 'security',\n icon: 'shield',\n title: '安全设置'\n }, {\n index: 'page',\n icon: 'pager',\n title: '网页设置'\n }, {\n index: 'others',\n icon: 'cog',\n title: '其他设置'\n }]\n };\n },\n methods: {\n toggleCollapse() {\n this.$emit('update:isCollapse', !this.isCollapse);\n },\n checkMobile() {\n const isMobile = window.innerWidth <= 768;\n this.$emit('update:isCollapse', isMobile);\n },\n handleSelect(index) {\n this.$emit('update:activeIndex', index);\n }\n },\n mounted() {\n this.checkMobile();\n window.addEventListener('resize', this.checkMobile);\n },\n beforeDestroy() {\n window.removeEventListener('resize', this.checkMobile);\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./SysConfigTabs.vue?vue&type=template&id=5bb00686&scoped=true\"\nimport script from \"./SysConfigTabs.vue?vue&type=script&lang=js\"\nexport * from \"./SysConfigTabs.vue?vue&type=script&lang=js\"\n\nimport \"./SysConfigTabs.vue?vue&type=style&index=0&id=5bb00686&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-5bb00686\"]])\n\nexport default __exports__","import { resolveComponent as _resolveComponent, createVNode as _createVNode, withCtx as _withCtx, createElementVNode as _createElementVNode, resolveDynamicComponent as _resolveDynamicComponent, normalizeClass as _normalizeClass, openBlock as _openBlock, createBlock as _createBlock, createElementBlock as _createElementBlock } from \"vue\";\nconst _hoisted_1 = {\n class: \"container\"\n};\nconst _hoisted_2 = {\n class: \"header-content\"\n};\nconst _hoisted_3 = {\n class: \"header-action\"\n};\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_DashboardTabs = _resolveComponent(\"DashboardTabs\");\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n const _component_el_tooltip = _resolveComponent(\"el-tooltip\");\n const _component_el_header = _resolveComponent(\"el-header\");\n const _component_SysConfigTabs = _resolveComponent(\"SysConfigTabs\");\n return _openBlock(), _createElementBlock(\"div\", _hoisted_1, [_createVNode(_component_el_header, null, {\n default: _withCtx(() => [_createElementVNode(\"div\", _hoisted_2, [_createVNode(_component_DashboardTabs, {\n activeTab: \"systemConfig\"\n }), _createElementVNode(\"div\", _hoisted_3, [_createVNode(_component_el_tooltip, {\n disabled: $options.disableTooltip,\n content: \"退出登录\",\n placement: \"bottom\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"sign-out-alt\",\n class: \"header-icon\",\n onClick: $options.handleLogout\n }, null, 8, [\"onClick\"])]),\n _: 1\n }, 8, [\"disabled\"])])])]),\n _: 1\n }), _createVNode(_component_SysConfigTabs, {\n activeIndex: $data.activeIndex,\n \"onUpdate:activeIndex\": _cache[0] || (_cache[0] = $event => $data.activeIndex = $event),\n isCollapse: $data.isSidebarCollapse,\n \"onUpdate:isCollapse\": _cache[1] || (_cache[1] = $event => $data.isSidebarCollapse = $event)\n }, null, 8, [\"activeIndex\", \"isCollapse\"]), (_openBlock(), _createBlock(_resolveDynamicComponent($options.currentComponent), {\n class: _normalizeClass(['main-container', {\n 'collapsed': $data.isSidebarCollapse\n }])\n }, null, 8, [\"class\"]))]);\n}","import { resolveComponent as _resolveComponent, createVNode as _createVNode, createElementVNode as _createElementVNode, toDisplayString as _toDisplayString, openBlock as _openBlock, createElementBlock as _createElementBlock, createCommentVNode as _createCommentVNode, renderList as _renderList, Fragment as _Fragment, normalizeStyle as _normalizeStyle, createTextVNode as _createTextVNode, withCtx as _withCtx, createBlock as _createBlock, resolveDirective as _resolveDirective, withDirectives as _withDirectives } from \"vue\";\nconst _hoisted_1 = {\n class: \"status-panel\"\n};\nconst _hoisted_2 = {\n class: \"overview-cards\"\n};\nconst _hoisted_3 = {\n class: \"card-icon\"\n};\nconst _hoisted_4 = {\n class: \"card-content\"\n};\nconst _hoisted_5 = {\n class: \"card-value\"\n};\nconst _hoisted_6 = {\n class: \"overview-card index-status\"\n};\nconst _hoisted_7 = {\n class: \"card-icon\"\n};\nconst _hoisted_8 = {\n class: \"card-content\"\n};\nconst _hoisted_9 = {\n class: \"card-value\"\n};\nconst _hoisted_10 = {\n class: \"card-subtitle\"\n};\nconst _hoisted_11 = {\n class: \"card-icon\"\n};\nconst _hoisted_12 = {\n class: \"card-content\"\n};\nconst _hoisted_13 = {\n class: \"card-value\"\n};\nconst _hoisted_14 = {\n class: \"charts-section\"\n};\nconst _hoisted_15 = {\n class: \"chart-card\"\n};\nconst _hoisted_16 = {\n class: \"chart-header\"\n};\nconst _hoisted_17 = {\n class: \"chart-content\"\n};\nconst _hoisted_18 = {\n key: 0,\n class: \"empty-state\"\n};\nconst _hoisted_19 = {\n key: 1,\n class: \"pie-chart-container\"\n};\nconst _hoisted_20 = {\n class: \"pie-chart-wrapper\"\n};\nconst _hoisted_21 = {\n class: \"chart-center-text\"\n};\nconst _hoisted_22 = {\n class: \"center-value\"\n};\nconst _hoisted_23 = {\n class: \"chart-legend\"\n};\nconst _hoisted_24 = {\n class: \"legend-label\"\n};\nconst _hoisted_25 = {\n class: \"legend-value\"\n};\nconst _hoisted_26 = {\n class: \"legend-percent\"\n};\nconst _hoisted_27 = {\n class: \"chart-card\"\n};\nconst _hoisted_28 = {\n class: \"chart-header\"\n};\nconst _hoisted_29 = {\n class: \"chart-content\"\n};\nconst _hoisted_30 = {\n key: 0,\n class: \"empty-state\"\n};\nconst _hoisted_31 = {\n key: 1,\n class: \"pie-chart-container\"\n};\nconst _hoisted_32 = {\n class: \"pie-chart-wrapper\"\n};\nconst _hoisted_33 = {\n class: \"chart-center-text\"\n};\nconst _hoisted_34 = {\n class: \"center-value\"\n};\nconst _hoisted_35 = {\n class: \"chart-legend\"\n};\nconst _hoisted_36 = {\n class: \"legend-label\"\n};\nconst _hoisted_37 = {\n class: \"legend-value\"\n};\nconst _hoisted_38 = {\n class: \"legend-percent\"\n};\nconst _hoisted_39 = {\n class: \"actions-section\"\n};\nconst _hoisted_40 = {\n class: \"action-card\"\n};\nconst _hoisted_41 = {\n class: \"action-header\"\n};\nconst _hoisted_42 = {\n class: \"action-content\"\n};\nconst _hoisted_43 = {\n key: 0,\n class: \"progress-container\"\n};\nconst _hoisted_44 = {\n class: \"progress-header\"\n};\nconst _hoisted_45 = {\n class: \"progress-phase\"\n};\nconst _hoisted_46 = {\n class: \"progress-percentage\"\n};\nconst _hoisted_47 = {\n class: \"progress-details\"\n};\nconst _hoisted_48 = {\n key: 0,\n class: \"progress-count\"\n};\nconst _hoisted_49 = {\n key: 1,\n class: \"progress-time\"\n};\nconst _hoisted_50 = {\n key: 0,\n class: \"progress-message\"\n};\nconst _hoisted_51 = {\n key: 1,\n class: \"error-container\"\n};\nconst _hoisted_52 = {\n class: \"error-icon\"\n};\nconst _hoisted_53 = {\n class: \"error-content\"\n};\nconst _hoisted_54 = {\n class: \"error-message\"\n};\nconst _hoisted_55 = {\n key: 0,\n class: \"error-suggestion\"\n};\nconst _hoisted_56 = {\n class: \"error-actions\"\n};\nconst _hoisted_57 = {\n key: 2,\n class: \"action-buttons\"\n};\nconst _hoisted_58 = {\n class: \"restore-section\"\n};\nconst _hoisted_59 = {\n key: 0,\n class: \"file-info-section\"\n};\nconst _hoisted_60 = [\"src\"];\nconst _hoisted_61 = {\n key: 2,\n class: \"card-bg-fallback\"\n};\nconst _hoisted_62 = {\n class: \"file-card-header\"\n};\nconst _hoisted_63 = {\n class: \"info-card-footer\"\n};\nconst _hoisted_64 = {\n class: \"file-name\"\n};\nconst _hoisted_65 = {\n class: \"file-meta\"\n};\nconst _hoisted_66 = [\"src\"];\nconst _hoisted_67 = {\n key: 2,\n class: \"card-bg-fallback\"\n};\nconst _hoisted_68 = {\n class: \"file-card-header warning\"\n};\nconst _hoisted_69 = {\n class: \"info-card-footer\"\n};\nconst _hoisted_70 = {\n class: \"file-name\"\n};\nconst _hoisted_71 = {\n class: \"file-meta\"\n};\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n const _component_Doughnut = _resolveComponent(\"Doughnut\");\n const _component_el_progress = _resolveComponent(\"el-progress\");\n const _component_el_button = _resolveComponent(\"el-button\");\n const _component_el_tooltip = _resolveComponent(\"el-tooltip\");\n const _component_el_image = _resolveComponent(\"el-image\");\n const _directive_loading = _resolveDirective(\"loading\");\n return _withDirectives((_openBlock(), _createElementBlock(\"div\", _hoisted_1, [_createElementVNode(\"div\", _hoisted_2, [_createElementVNode(\"div\", {\n class: \"overview-card total-files\",\n onClick: _cache[0] || (_cache[0] = (...args) => $options.fetchIndexInfo && $options.fetchIndexInfo(...args))\n }, [_createElementVNode(\"div\", _hoisted_3, [_createVNode(_component_font_awesome_icon, {\n icon: \"database\"\n })]), _createElementVNode(\"div\", _hoisted_4, [_cache[9] || (_cache[9] = _createElementVNode(\"div\", {\n class: \"card-title\"\n }, \"文件总数\", -1)), _createElementVNode(\"div\", _hoisted_5, _toDisplayString($data.indexInfo.totalFiles?.toLocaleString() || '0'), 1), _cache[10] || (_cache[10] = _createElementVNode(\"div\", {\n class: \"card-subtitle\"\n }, \"点击刷新\", -1))])]), _createElementVNode(\"div\", _hoisted_6, [_createElementVNode(\"div\", _hoisted_7, [_createVNode(_component_font_awesome_icon, {\n icon: \"clock\"\n })]), _createElementVNode(\"div\", _hoisted_8, [_cache[11] || (_cache[11] = _createElementVNode(\"div\", {\n class: \"card-title\"\n }, \"索引更新时间\", -1)), _createElementVNode(\"div\", _hoisted_9, _toDisplayString($options.formatTime($data.indexInfo.lastUpdated)), 1), _createElementVNode(\"div\", _hoisted_10, _toDisplayString($options.getTimeAgo($data.indexInfo.lastUpdated)), 1)])]), _createElementVNode(\"div\", {\n class: \"overview-card system-version\",\n onClick: _cache[1] || (_cache[1] = (...args) => $options.openReleases && $options.openReleases(...args))\n }, [_createElementVNode(\"div\", _hoisted_11, [_createVNode(_component_font_awesome_icon, {\n icon: \"code-branch\"\n })]), _createElementVNode(\"div\", _hoisted_12, [_cache[12] || (_cache[12] = _createElementVNode(\"div\", {\n class: \"card-title\"\n }, \"系统版本\", -1)), _createElementVNode(\"div\", _hoisted_13, \"v\" + _toDisplayString($data.version), 1), _cache[13] || (_cache[13] = _createElementVNode(\"div\", {\n class: \"card-subtitle\"\n }, \"点击查看更新日志\", -1))])])]), _createElementVNode(\"div\", _hoisted_14, [_createElementVNode(\"div\", _hoisted_15, [_createElementVNode(\"div\", _hoisted_16, [_createVNode(_component_font_awesome_icon, {\n icon: \"share-alt\"\n }), _cache[14] || (_cache[14] = _createElementVNode(\"span\", null, \"上传渠道分布\", -1))]), _createElementVNode(\"div\", _hoisted_17, [Object.keys($data.indexInfo.channelStats || {}).length === 0 ? (_openBlock(), _createElementBlock(\"div\", _hoisted_18, [_createVNode(_component_font_awesome_icon, {\n icon: \"inbox\"\n }), _cache[15] || (_cache[15] = _createElementVNode(\"span\", null, \"暂无数据\", -1))])) : (_openBlock(), _createElementBlock(\"div\", _hoisted_19, [_createElementVNode(\"div\", _hoisted_20, [_createVNode(_component_Doughnut, {\n data: $options.channelChartData,\n options: $options.chartOptions\n }, null, 8, [\"data\", \"options\"]), _createElementVNode(\"div\", _hoisted_21, [_createElementVNode(\"div\", _hoisted_22, _toDisplayString($data.indexInfo.totalFiles?.toLocaleString() || '0'), 1), _cache[16] || (_cache[16] = _createElementVNode(\"div\", {\n class: \"center-label\"\n }, \"文件总数\", -1))])]), _createElementVNode(\"div\", _hoisted_23, [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($data.indexInfo.channelStats, (count, channel, index) => {\n return _openBlock(), _createElementBlock(\"div\", {\n key: channel,\n class: \"legend-item\"\n }, [_createElementVNode(\"span\", {\n class: \"legend-color\",\n style: _normalizeStyle({\n background: $options.getChartColor(index)\n })\n }, null, 4), _createElementVNode(\"span\", _hoisted_24, _toDisplayString(channel), 1), _createElementVNode(\"span\", _hoisted_25, _toDisplayString(count.toLocaleString()), 1), _createElementVNode(\"span\", _hoisted_26, _toDisplayString($options.getPercentage(count, $data.indexInfo.totalFiles)) + \"%\", 1)]);\n }), 128))])]))])]), _createElementVNode(\"div\", _hoisted_27, [_createElementVNode(\"div\", _hoisted_28, [_createVNode(_component_font_awesome_icon, {\n icon: \"file-alt\"\n }), _cache[17] || (_cache[17] = _createElementVNode(\"span\", null, \"文件状态分布\", -1))]), _createElementVNode(\"div\", _hoisted_29, [Object.keys($data.indexInfo.typeStats || {}).length === 0 ? (_openBlock(), _createElementBlock(\"div\", _hoisted_30, [_createVNode(_component_font_awesome_icon, {\n icon: \"inbox\"\n }), _cache[18] || (_cache[18] = _createElementVNode(\"span\", null, \"暂无数据\", -1))])) : (_openBlock(), _createElementBlock(\"div\", _hoisted_31, [_createElementVNode(\"div\", _hoisted_32, [_createVNode(_component_Doughnut, {\n data: $options.typeChartData,\n options: $options.chartOptions\n }, null, 8, [\"data\", \"options\"]), _createElementVNode(\"div\", _hoisted_33, [_createElementVNode(\"div\", _hoisted_34, _toDisplayString(Object.keys($data.indexInfo.typeStats).length), 1), _cache[19] || (_cache[19] = _createElementVNode(\"div\", {\n class: \"center-label\"\n }, \"状态类型\", -1))])]), _createElementVNode(\"div\", _hoisted_35, [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($options.aggregatedTypeStats, (count, status, index) => {\n return _openBlock(), _createElementBlock(\"div\", {\n key: status,\n class: \"legend-item\"\n }, [_createElementVNode(\"span\", {\n class: \"legend-color\",\n style: _normalizeStyle({\n background: $options.getTypeChartColor(index)\n })\n }, null, 4), _createElementVNode(\"span\", _hoisted_36, _toDisplayString(status), 1), _createElementVNode(\"span\", _hoisted_37, _toDisplayString(count.toLocaleString()), 1), _createElementVNode(\"span\", _hoisted_38, _toDisplayString($options.getPercentage(count, $data.indexInfo.totalFiles)) + \"%\", 1)]);\n }), 128))])]))])])]), _createElementVNode(\"div\", _hoisted_39, [_createElementVNode(\"div\", _hoisted_40, [_createElementVNode(\"div\", _hoisted_41, [_createVNode(_component_font_awesome_icon, {\n icon: \"tools\"\n }), _cache[20] || (_cache[20] = _createElementVNode(\"span\", null, \"系统维护\", -1))]), _createElementVNode(\"div\", _hoisted_42, [$data.isProcessing ? (_openBlock(), _createElementBlock(\"div\", _hoisted_43, [_createElementVNode(\"div\", _hoisted_44, [_createElementVNode(\"span\", _hoisted_45, _toDisplayString($options.phaseDescription), 1), _createElementVNode(\"span\", _hoisted_46, _toDisplayString(Math.round($data.processingProgress.percentage)) + \"%\", 1)]), _createVNode(_component_el_progress, {\n percentage: $data.processingProgress.percentage,\n \"stroke-width\": 12,\n \"show-text\": false,\n class: \"progress-bar\"\n }, null, 8, [\"percentage\"]), _createElementVNode(\"div\", _hoisted_47, [$data.processingProgress.current > 0 ? (_openBlock(), _createElementBlock(\"span\", _hoisted_48, [_createVNode(_component_font_awesome_icon, {\n icon: \"file-alt\"\n }), _createTextVNode(\" \" + _toDisplayString($data.processingProgress.current.toLocaleString()) + \" \", 1), $data.processingProgress.total > 0 ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 0\n }, [_createTextVNode(\" / \" + _toDisplayString($data.processingProgress.total.toLocaleString()), 1)], 64)) : _createCommentVNode(\"\", true), _cache[21] || (_cache[21] = _createTextVNode(\" 条记录 \", -1))])) : _createCommentVNode(\"\", true), $options.estimatedTimeRemaining ? (_openBlock(), _createElementBlock(\"span\", _hoisted_49, [_createVNode(_component_font_awesome_icon, {\n icon: \"clock\"\n }), _createTextVNode(\" \" + _toDisplayString($options.estimatedTimeRemaining), 1)])) : _createCommentVNode(\"\", true)]), $data.processingProgress.message ? (_openBlock(), _createElementBlock(\"div\", _hoisted_50, _toDisplayString($data.processingProgress.message), 1)) : _createCommentVNode(\"\", true), _createVNode(_component_el_button, {\n type: \"danger\",\n plain: \"\",\n size: \"small\",\n onClick: $options.cancelOperation,\n class: \"cancel-btn\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"times\"\n }), _cache[22] || (_cache[22] = _createTextVNode(\" 取消操作 \", -1))]),\n _: 1\n }, 8, [\"onClick\"])])) : $data.processingError ? (_openBlock(), _createElementBlock(\"div\", _hoisted_51, [_createElementVNode(\"div\", _hoisted_52, [_createVNode(_component_font_awesome_icon, {\n icon: \"exclamation-triangle\"\n })]), _createElementVNode(\"div\", _hoisted_53, [_createElementVNode(\"div\", _hoisted_54, _toDisplayString($data.processingError.message), 1), $data.processingError.suggestion ? (_openBlock(), _createElementBlock(\"div\", _hoisted_55, _toDisplayString($data.processingError.suggestion), 1)) : _createCommentVNode(\"\", true)]), _createElementVNode(\"div\", _hoisted_56, [$data.processingError.recoverable ? (_openBlock(), _createBlock(_component_el_button, {\n key: 0,\n type: \"primary\",\n size: \"small\",\n onClick: $options.retryOperation\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"redo\"\n }), _cache[23] || (_cache[23] = _createTextVNode(\" 重试 \", -1))]),\n _: 1\n }, 8, [\"onClick\"])) : _createCommentVNode(\"\", true), _createVNode(_component_el_button, {\n type: \"default\",\n size: \"small\",\n onClick: $options.dismissError\n }, {\n default: _withCtx(() => [...(_cache[24] || (_cache[24] = [_createTextVNode(\" 关闭 \", -1)]))]),\n _: 1\n }, 8, [\"onClick\"])])])) : (_openBlock(), _createElementBlock(\"div\", _hoisted_57, [_createVNode(_component_el_tooltip, {\n content: \"重新扫描所有文件并更新索引数据,适用于数据不一致时的修复\",\n placement: \"top\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_button, {\n type: \"primary\",\n loading: $data.rebuilding,\n disabled: $data.isProcessing,\n onClick: $options.rebuildIndex,\n class: \"action-btn rebuild-btn\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"sync-alt\"\n }), _createTextVNode(\" \" + _toDisplayString($data.rebuilding ? '重建中...' : '重建索引'), 1)]),\n _: 1\n }, 8, [\"loading\", \"disabled\", \"onClick\"])]),\n _: 1\n }), _createVNode(_component_el_tooltip, {\n content: \"备份所有文件元数据和系统设置到JSON文件\",\n placement: \"top\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_button, {\n type: \"success\",\n loading: $data.backing,\n disabled: $data.isProcessing,\n onClick: $options.backupData,\n class: \"action-btn backup-btn\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"download\"\n }), _createTextVNode(\" \" + _toDisplayString($data.backing ? '备份中...' : '备份数据'), 1)]),\n _: 1\n }, 8, [\"loading\", \"disabled\", \"onClick\"])]),\n _: 1\n }), _createVNode(_component_el_tooltip, {\n content: \"从备份文件恢复数据,将覆盖现有的文件元数据和系统设置\",\n placement: \"top\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"div\", _hoisted_58, [_createElementVNode(\"input\", {\n type: \"file\",\n ref: \"fileInput\",\n accept: \".json\",\n onChange: _cache[2] || (_cache[2] = (...args) => $options.handleFileSelect && $options.handleFileSelect(...args)),\n style: {\n \"display\": \"none\"\n }\n }, null, 544), _createVNode(_component_el_button, {\n type: \"warning\",\n loading: $data.restoring,\n disabled: $data.isProcessing,\n onClick: $options.selectRestoreFile,\n class: \"action-btn restore-btn\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"upload\"\n }), _createTextVNode(\" \" + _toDisplayString($data.restoring ? '恢复中...' : '恢复数据'), 1)]),\n _: 1\n }, 8, [\"loading\", \"disabled\", \"onClick\"])])]),\n _: 1\n })]))])])]), $data.indexInfo.newestFile || $data.indexInfo.oldestFile ? (_openBlock(), _createElementBlock(\"div\", _hoisted_59, [$data.indexInfo.newestFile ? (_openBlock(), _createElementBlock(\"div\", {\n key: 0,\n class: \"file-info-card info-card-newest\",\n onClick: _cache[5] || (_cache[5] = $event => $options.openFileInNewTab($data.indexInfo.newestFile))\n }, [$options.isImageFile($data.indexInfo.newestFile) && !$data.loadErrors['newest'] ? (_openBlock(), _createBlock(_component_el_image, {\n key: 0,\n src: '/file/' + $data.indexInfo.newestFile.id + '?from=admin',\n fit: \"cover\",\n class: \"card-bg-media\",\n onError: _cache[3] || (_cache[3] = $event => $options.handleImageError('newest'))\n }, null, 8, [\"src\"])) : $options.isVideoFile($data.indexInfo.newestFile) && !$data.loadErrors['newest'] ? (_openBlock(), _createElementBlock(\"video\", {\n key: 1,\n src: '/file/' + $data.indexInfo.newestFile.id + '?from=admin',\n class: \"card-bg-media\",\n muted: \"\",\n loop: \"\",\n autoplay: \"\",\n onError: _cache[4] || (_cache[4] = $event => $options.handleImageError('newest'))\n }, null, 40, _hoisted_60)) : (_openBlock(), _createElementBlock(\"div\", _hoisted_61, [_createVNode(_component_font_awesome_icon, {\n icon: \"file-alt\",\n class: \"fallback-icon\"\n })])), _createElementVNode(\"div\", _hoisted_62, [_createVNode(_component_font_awesome_icon, {\n icon: \"arrow-up\"\n }), _cache[25] || (_cache[25] = _createElementVNode(\"span\", null, \"最近上传\", -1))]), _createElementVNode(\"div\", _hoisted_63, [_createElementVNode(\"div\", _hoisted_64, _toDisplayString($data.indexInfo.newestFile.metadata?.FileName || $data.indexInfo.newestFile.id), 1), _createElementVNode(\"div\", _hoisted_65, _toDisplayString($options.formatTime($data.indexInfo.newestFile.metadata?.TimeStamp)), 1)])])) : _createCommentVNode(\"\", true), $data.indexInfo.oldestFile ? (_openBlock(), _createElementBlock(\"div\", {\n key: 1,\n class: \"file-info-card info-card-oldest\",\n onClick: _cache[8] || (_cache[8] = $event => $options.openFileInNewTab($data.indexInfo.oldestFile))\n }, [$options.isImageFile($data.indexInfo.oldestFile) && !$data.loadErrors['oldest'] ? (_openBlock(), _createBlock(_component_el_image, {\n key: 0,\n src: '/file/' + $data.indexInfo.oldestFile.id + '?from=admin',\n fit: \"cover\",\n class: \"card-bg-media\",\n onError: _cache[6] || (_cache[6] = $event => $options.handleImageError('oldest'))\n }, null, 8, [\"src\"])) : $options.isVideoFile($data.indexInfo.oldestFile) && !$data.loadErrors['oldest'] ? (_openBlock(), _createElementBlock(\"video\", {\n key: 1,\n src: '/file/' + $data.indexInfo.oldestFile.id + '?from=admin',\n class: \"card-bg-media\",\n muted: \"\",\n loop: \"\",\n autoplay: \"\",\n onError: _cache[7] || (_cache[7] = $event => $options.handleImageError('oldest'))\n }, null, 40, _hoisted_66)) : (_openBlock(), _createElementBlock(\"div\", _hoisted_67, [_createVNode(_component_font_awesome_icon, {\n icon: \"file-alt\",\n class: \"fallback-icon\"\n })])), _createElementVNode(\"div\", _hoisted_68, [_createVNode(_component_font_awesome_icon, {\n icon: \"arrow-down\"\n }), _cache[26] || (_cache[26] = _createElementVNode(\"span\", null, \"最早上传\", -1))]), _createElementVNode(\"div\", _hoisted_69, [_createElementVNode(\"div\", _hoisted_70, _toDisplayString($data.indexInfo.oldestFile.metadata?.FileName || $data.indexInfo.oldestFile.id), 1), _createElementVNode(\"div\", _hoisted_71, _toDisplayString($options.formatTime($data.indexInfo.oldestFile.metadata?.TimeStamp)), 1)])])) : _createCommentVNode(\"\", true)])) : _createCommentVNode(\"\", true)])), [[_directive_loading, $data.loading]]);\n}","/*!\n * @kurkle/color v0.3.4\n * https://github.com/kurkle/color#readme\n * (c) 2024 Jukka Kurkela\n * Released under the MIT License\n */\nfunction round(v) {\n return v + 0.5 | 0;\n}\nconst lim = (v, l, h) => Math.max(Math.min(v, h), l);\nfunction p2b(v) {\n return lim(round(v * 2.55), 0, 255);\n}\nfunction b2p(v) {\n return lim(round(v / 2.55), 0, 100);\n}\nfunction n2b(v) {\n return lim(round(v * 255), 0, 255);\n}\nfunction b2n(v) {\n return lim(round(v / 2.55) / 100, 0, 1);\n}\nfunction n2p(v) {\n return lim(round(v * 100), 0, 100);\n}\n\nconst map$1 = {0: 0, 1: 1, 2: 2, 3: 3, 4: 4, 5: 5, 6: 6, 7: 7, 8: 8, 9: 9, A: 10, B: 11, C: 12, D: 13, E: 14, F: 15, a: 10, b: 11, c: 12, d: 13, e: 14, f: 15};\nconst hex = [...'0123456789ABCDEF'];\nconst h1 = b => hex[b & 0xF];\nconst h2 = b => hex[(b & 0xF0) >> 4] + hex[b & 0xF];\nconst eq = b => ((b & 0xF0) >> 4) === (b & 0xF);\nconst isShort = v => eq(v.r) && eq(v.g) && eq(v.b) && eq(v.a);\nfunction hexParse(str) {\n var len = str.length;\n var ret;\n if (str[0] === '#') {\n if (len === 4 || len === 5) {\n ret = {\n r: 255 & map$1[str[1]] * 17,\n g: 255 & map$1[str[2]] * 17,\n b: 255 & map$1[str[3]] * 17,\n a: len === 5 ? map$1[str[4]] * 17 : 255\n };\n } else if (len === 7 || len === 9) {\n ret = {\n r: map$1[str[1]] << 4 | map$1[str[2]],\n g: map$1[str[3]] << 4 | map$1[str[4]],\n b: map$1[str[5]] << 4 | map$1[str[6]],\n a: len === 9 ? (map$1[str[7]] << 4 | map$1[str[8]]) : 255\n };\n }\n }\n return ret;\n}\nconst alpha = (a, f) => a < 255 ? f(a) : '';\nfunction hexString(v) {\n var f = isShort(v) ? h1 : h2;\n return v\n ? '#' + f(v.r) + f(v.g) + f(v.b) + alpha(v.a, f)\n : undefined;\n}\n\nconst HUE_RE = /^(hsla?|hwb|hsv)\\(\\s*([-+.e\\d]+)(?:deg)?[\\s,]+([-+.e\\d]+)%[\\s,]+([-+.e\\d]+)%(?:[\\s,]+([-+.e\\d]+)(%)?)?\\s*\\)$/;\nfunction hsl2rgbn(h, s, l) {\n const a = s * Math.min(l, 1 - l);\n const f = (n, k = (n + h / 30) % 12) => l - a * Math.max(Math.min(k - 3, 9 - k, 1), -1);\n return [f(0), f(8), f(4)];\n}\nfunction hsv2rgbn(h, s, v) {\n const f = (n, k = (n + h / 60) % 6) => v - v * s * Math.max(Math.min(k, 4 - k, 1), 0);\n return [f(5), f(3), f(1)];\n}\nfunction hwb2rgbn(h, w, b) {\n const rgb = hsl2rgbn(h, 1, 0.5);\n let i;\n if (w + b > 1) {\n i = 1 / (w + b);\n w *= i;\n b *= i;\n }\n for (i = 0; i < 3; i++) {\n rgb[i] *= 1 - w - b;\n rgb[i] += w;\n }\n return rgb;\n}\nfunction hueValue(r, g, b, d, max) {\n if (r === max) {\n return ((g - b) / d) + (g < b ? 6 : 0);\n }\n if (g === max) {\n return (b - r) / d + 2;\n }\n return (r - g) / d + 4;\n}\nfunction rgb2hsl(v) {\n const range = 255;\n const r = v.r / range;\n const g = v.g / range;\n const b = v.b / range;\n const max = Math.max(r, g, b);\n const min = Math.min(r, g, b);\n const l = (max + min) / 2;\n let h, s, d;\n if (max !== min) {\n d = max - min;\n s = l > 0.5 ? d / (2 - max - min) : d / (max + min);\n h = hueValue(r, g, b, d, max);\n h = h * 60 + 0.5;\n }\n return [h | 0, s || 0, l];\n}\nfunction calln(f, a, b, c) {\n return (\n Array.isArray(a)\n ? f(a[0], a[1], a[2])\n : f(a, b, c)\n ).map(n2b);\n}\nfunction hsl2rgb(h, s, l) {\n return calln(hsl2rgbn, h, s, l);\n}\nfunction hwb2rgb(h, w, b) {\n return calln(hwb2rgbn, h, w, b);\n}\nfunction hsv2rgb(h, s, v) {\n return calln(hsv2rgbn, h, s, v);\n}\nfunction hue(h) {\n return (h % 360 + 360) % 360;\n}\nfunction hueParse(str) {\n const m = HUE_RE.exec(str);\n let a = 255;\n let v;\n if (!m) {\n return;\n }\n if (m[5] !== v) {\n a = m[6] ? p2b(+m[5]) : n2b(+m[5]);\n }\n const h = hue(+m[2]);\n const p1 = +m[3] / 100;\n const p2 = +m[4] / 100;\n if (m[1] === 'hwb') {\n v = hwb2rgb(h, p1, p2);\n } else if (m[1] === 'hsv') {\n v = hsv2rgb(h, p1, p2);\n } else {\n v = hsl2rgb(h, p1, p2);\n }\n return {\n r: v[0],\n g: v[1],\n b: v[2],\n a: a\n };\n}\nfunction rotate(v, deg) {\n var h = rgb2hsl(v);\n h[0] = hue(h[0] + deg);\n h = hsl2rgb(h);\n v.r = h[0];\n v.g = h[1];\n v.b = h[2];\n}\nfunction hslString(v) {\n if (!v) {\n return;\n }\n const a = rgb2hsl(v);\n const h = a[0];\n const s = n2p(a[1]);\n const l = n2p(a[2]);\n return v.a < 255\n ? `hsla(${h}, ${s}%, ${l}%, ${b2n(v.a)})`\n : `hsl(${h}, ${s}%, ${l}%)`;\n}\n\nconst map = {\n\tx: 'dark',\n\tZ: 'light',\n\tY: 're',\n\tX: 'blu',\n\tW: 'gr',\n\tV: 'medium',\n\tU: 'slate',\n\tA: 'ee',\n\tT: 'ol',\n\tS: 'or',\n\tB: 'ra',\n\tC: 'lateg',\n\tD: 'ights',\n\tR: 'in',\n\tQ: 'turquois',\n\tE: 'hi',\n\tP: 'ro',\n\tO: 'al',\n\tN: 'le',\n\tM: 'de',\n\tL: 'yello',\n\tF: 'en',\n\tK: 'ch',\n\tG: 'arks',\n\tH: 'ea',\n\tI: 'ightg',\n\tJ: 'wh'\n};\nconst names$1 = {\n\tOiceXe: 'f0f8ff',\n\tantiquewEte: 'faebd7',\n\taqua: 'ffff',\n\taquamarRe: '7fffd4',\n\tazuY: 'f0ffff',\n\tbeige: 'f5f5dc',\n\tbisque: 'ffe4c4',\n\tblack: '0',\n\tblanKedOmond: 'ffebcd',\n\tXe: 'ff',\n\tXeviTet: '8a2be2',\n\tbPwn: 'a52a2a',\n\tburlywood: 'deb887',\n\tcaMtXe: '5f9ea0',\n\tKartYuse: '7fff00',\n\tKocTate: 'd2691e',\n\tcSO: 'ff7f50',\n\tcSnflowerXe: '6495ed',\n\tcSnsilk: 'fff8dc',\n\tcrimson: 'dc143c',\n\tcyan: 'ffff',\n\txXe: '8b',\n\txcyan: '8b8b',\n\txgTMnPd: 'b8860b',\n\txWay: 'a9a9a9',\n\txgYF: '6400',\n\txgYy: 'a9a9a9',\n\txkhaki: 'bdb76b',\n\txmagFta: '8b008b',\n\txTivegYF: '556b2f',\n\txSange: 'ff8c00',\n\txScEd: '9932cc',\n\txYd: '8b0000',\n\txsOmon: 'e9967a',\n\txsHgYF: '8fbc8f',\n\txUXe: '483d8b',\n\txUWay: '2f4f4f',\n\txUgYy: '2f4f4f',\n\txQe: 'ced1',\n\txviTet: '9400d3',\n\tdAppRk: 'ff1493',\n\tdApskyXe: 'bfff',\n\tdimWay: '696969',\n\tdimgYy: '696969',\n\tdodgerXe: '1e90ff',\n\tfiYbrick: 'b22222',\n\tflSOwEte: 'fffaf0',\n\tfoYstWAn: '228b22',\n\tfuKsia: 'ff00ff',\n\tgaRsbSo: 'dcdcdc',\n\tghostwEte: 'f8f8ff',\n\tgTd: 'ffd700',\n\tgTMnPd: 'daa520',\n\tWay: '808080',\n\tgYF: '8000',\n\tgYFLw: 'adff2f',\n\tgYy: '808080',\n\thoneyMw: 'f0fff0',\n\thotpRk: 'ff69b4',\n\tRdianYd: 'cd5c5c',\n\tRdigo: '4b0082',\n\tivSy: 'fffff0',\n\tkhaki: 'f0e68c',\n\tlavFMr: 'e6e6fa',\n\tlavFMrXsh: 'fff0f5',\n\tlawngYF: '7cfc00',\n\tNmoncEffon: 'fffacd',\n\tZXe: 'add8e6',\n\tZcSO: 'f08080',\n\tZcyan: 'e0ffff',\n\tZgTMnPdLw: 'fafad2',\n\tZWay: 'd3d3d3',\n\tZgYF: '90ee90',\n\tZgYy: 'd3d3d3',\n\tZpRk: 'ffb6c1',\n\tZsOmon: 'ffa07a',\n\tZsHgYF: '20b2aa',\n\tZskyXe: '87cefa',\n\tZUWay: '778899',\n\tZUgYy: '778899',\n\tZstAlXe: 'b0c4de',\n\tZLw: 'ffffe0',\n\tlime: 'ff00',\n\tlimegYF: '32cd32',\n\tlRF: 'faf0e6',\n\tmagFta: 'ff00ff',\n\tmaPon: '800000',\n\tVaquamarRe: '66cdaa',\n\tVXe: 'cd',\n\tVScEd: 'ba55d3',\n\tVpurpN: '9370db',\n\tVsHgYF: '3cb371',\n\tVUXe: '7b68ee',\n\tVsprRggYF: 'fa9a',\n\tVQe: '48d1cc',\n\tVviTetYd: 'c71585',\n\tmidnightXe: '191970',\n\tmRtcYam: 'f5fffa',\n\tmistyPse: 'ffe4e1',\n\tmoccasR: 'ffe4b5',\n\tnavajowEte: 'ffdead',\n\tnavy: '80',\n\tTdlace: 'fdf5e6',\n\tTive: '808000',\n\tTivedBb: '6b8e23',\n\tSange: 'ffa500',\n\tSangeYd: 'ff4500',\n\tScEd: 'da70d6',\n\tpOegTMnPd: 'eee8aa',\n\tpOegYF: '98fb98',\n\tpOeQe: 'afeeee',\n\tpOeviTetYd: 'db7093',\n\tpapayawEp: 'ffefd5',\n\tpHKpuff: 'ffdab9',\n\tperu: 'cd853f',\n\tpRk: 'ffc0cb',\n\tplum: 'dda0dd',\n\tpowMrXe: 'b0e0e6',\n\tpurpN: '800080',\n\tYbeccapurpN: '663399',\n\tYd: 'ff0000',\n\tPsybrown: 'bc8f8f',\n\tPyOXe: '4169e1',\n\tsaddNbPwn: '8b4513',\n\tsOmon: 'fa8072',\n\tsandybPwn: 'f4a460',\n\tsHgYF: '2e8b57',\n\tsHshell: 'fff5ee',\n\tsiFna: 'a0522d',\n\tsilver: 'c0c0c0',\n\tskyXe: '87ceeb',\n\tUXe: '6a5acd',\n\tUWay: '708090',\n\tUgYy: '708090',\n\tsnow: 'fffafa',\n\tsprRggYF: 'ff7f',\n\tstAlXe: '4682b4',\n\ttan: 'd2b48c',\n\tteO: '8080',\n\ttEstN: 'd8bfd8',\n\ttomato: 'ff6347',\n\tQe: '40e0d0',\n\tviTet: 'ee82ee',\n\tJHt: 'f5deb3',\n\twEte: 'ffffff',\n\twEtesmoke: 'f5f5f5',\n\tLw: 'ffff00',\n\tLwgYF: '9acd32'\n};\nfunction unpack() {\n const unpacked = {};\n const keys = Object.keys(names$1);\n const tkeys = Object.keys(map);\n let i, j, k, ok, nk;\n for (i = 0; i < keys.length; i++) {\n ok = nk = keys[i];\n for (j = 0; j < tkeys.length; j++) {\n k = tkeys[j];\n nk = nk.replace(k, map[k]);\n }\n k = parseInt(names$1[ok], 16);\n unpacked[nk] = [k >> 16 & 0xFF, k >> 8 & 0xFF, k & 0xFF];\n }\n return unpacked;\n}\n\nlet names;\nfunction nameParse(str) {\n if (!names) {\n names = unpack();\n names.transparent = [0, 0, 0, 0];\n }\n const a = names[str.toLowerCase()];\n return a && {\n r: a[0],\n g: a[1],\n b: a[2],\n a: a.length === 4 ? a[3] : 255\n };\n}\n\nconst RGB_RE = /^rgba?\\(\\s*([-+.\\d]+)(%)?[\\s,]+([-+.e\\d]+)(%)?[\\s,]+([-+.e\\d]+)(%)?(?:[\\s,/]+([-+.e\\d]+)(%)?)?\\s*\\)$/;\nfunction rgbParse(str) {\n const m = RGB_RE.exec(str);\n let a = 255;\n let r, g, b;\n if (!m) {\n return;\n }\n if (m[7] !== r) {\n const v = +m[7];\n a = m[8] ? p2b(v) : lim(v * 255, 0, 255);\n }\n r = +m[1];\n g = +m[3];\n b = +m[5];\n r = 255 & (m[2] ? p2b(r) : lim(r, 0, 255));\n g = 255 & (m[4] ? p2b(g) : lim(g, 0, 255));\n b = 255 & (m[6] ? p2b(b) : lim(b, 0, 255));\n return {\n r: r,\n g: g,\n b: b,\n a: a\n };\n}\nfunction rgbString(v) {\n return v && (\n v.a < 255\n ? `rgba(${v.r}, ${v.g}, ${v.b}, ${b2n(v.a)})`\n : `rgb(${v.r}, ${v.g}, ${v.b})`\n );\n}\n\nconst to = v => v <= 0.0031308 ? v * 12.92 : Math.pow(v, 1.0 / 2.4) * 1.055 - 0.055;\nconst from = v => v <= 0.04045 ? v / 12.92 : Math.pow((v + 0.055) / 1.055, 2.4);\nfunction interpolate(rgb1, rgb2, t) {\n const r = from(b2n(rgb1.r));\n const g = from(b2n(rgb1.g));\n const b = from(b2n(rgb1.b));\n return {\n r: n2b(to(r + t * (from(b2n(rgb2.r)) - r))),\n g: n2b(to(g + t * (from(b2n(rgb2.g)) - g))),\n b: n2b(to(b + t * (from(b2n(rgb2.b)) - b))),\n a: rgb1.a + t * (rgb2.a - rgb1.a)\n };\n}\n\nfunction modHSL(v, i, ratio) {\n if (v) {\n let tmp = rgb2hsl(v);\n tmp[i] = Math.max(0, Math.min(tmp[i] + tmp[i] * ratio, i === 0 ? 360 : 1));\n tmp = hsl2rgb(tmp);\n v.r = tmp[0];\n v.g = tmp[1];\n v.b = tmp[2];\n }\n}\nfunction clone(v, proto) {\n return v ? Object.assign(proto || {}, v) : v;\n}\nfunction fromObject(input) {\n var v = {r: 0, g: 0, b: 0, a: 255};\n if (Array.isArray(input)) {\n if (input.length >= 3) {\n v = {r: input[0], g: input[1], b: input[2], a: 255};\n if (input.length > 3) {\n v.a = n2b(input[3]);\n }\n }\n } else {\n v = clone(input, {r: 0, g: 0, b: 0, a: 1});\n v.a = n2b(v.a);\n }\n return v;\n}\nfunction functionParse(str) {\n if (str.charAt(0) === 'r') {\n return rgbParse(str);\n }\n return hueParse(str);\n}\nclass Color {\n constructor(input) {\n if (input instanceof Color) {\n return input;\n }\n const type = typeof input;\n let v;\n if (type === 'object') {\n v = fromObject(input);\n } else if (type === 'string') {\n v = hexParse(input) || nameParse(input) || functionParse(input);\n }\n this._rgb = v;\n this._valid = !!v;\n }\n get valid() {\n return this._valid;\n }\n get rgb() {\n var v = clone(this._rgb);\n if (v) {\n v.a = b2n(v.a);\n }\n return v;\n }\n set rgb(obj) {\n this._rgb = fromObject(obj);\n }\n rgbString() {\n return this._valid ? rgbString(this._rgb) : undefined;\n }\n hexString() {\n return this._valid ? hexString(this._rgb) : undefined;\n }\n hslString() {\n return this._valid ? hslString(this._rgb) : undefined;\n }\n mix(color, weight) {\n if (color) {\n const c1 = this.rgb;\n const c2 = color.rgb;\n let w2;\n const p = weight === w2 ? 0.5 : weight;\n const w = 2 * p - 1;\n const a = c1.a - c2.a;\n const w1 = ((w * a === -1 ? w : (w + a) / (1 + w * a)) + 1) / 2.0;\n w2 = 1 - w1;\n c1.r = 0xFF & w1 * c1.r + w2 * c2.r + 0.5;\n c1.g = 0xFF & w1 * c1.g + w2 * c2.g + 0.5;\n c1.b = 0xFF & w1 * c1.b + w2 * c2.b + 0.5;\n c1.a = p * c1.a + (1 - p) * c2.a;\n this.rgb = c1;\n }\n return this;\n }\n interpolate(color, t) {\n if (color) {\n this._rgb = interpolate(this._rgb, color._rgb, t);\n }\n return this;\n }\n clone() {\n return new Color(this.rgb);\n }\n alpha(a) {\n this._rgb.a = n2b(a);\n return this;\n }\n clearer(ratio) {\n const rgb = this._rgb;\n rgb.a *= 1 - ratio;\n return this;\n }\n greyscale() {\n const rgb = this._rgb;\n const val = round(rgb.r * 0.3 + rgb.g * 0.59 + rgb.b * 0.11);\n rgb.r = rgb.g = rgb.b = val;\n return this;\n }\n opaquer(ratio) {\n const rgb = this._rgb;\n rgb.a *= 1 + ratio;\n return this;\n }\n negate() {\n const v = this._rgb;\n v.r = 255 - v.r;\n v.g = 255 - v.g;\n v.b = 255 - v.b;\n return this;\n }\n lighten(ratio) {\n modHSL(this._rgb, 2, ratio);\n return this;\n }\n darken(ratio) {\n modHSL(this._rgb, 2, -ratio);\n return this;\n }\n saturate(ratio) {\n modHSL(this._rgb, 1, ratio);\n return this;\n }\n desaturate(ratio) {\n modHSL(this._rgb, 1, -ratio);\n return this;\n }\n rotate(deg) {\n rotate(this._rgb, deg);\n return this;\n }\n}\n\nfunction index_esm(input) {\n return new Color(input);\n}\n\nexport { Color, b2n, b2p, index_esm as default, hexParse, hexString, hsl2rgb, hslString, hsv2rgb, hueParse, hwb2rgb, lim, n2b, n2p, nameParse, p2b, rgb2hsl, rgbParse, rgbString, rotate, round };\n","/**\n * @namespace Chart.helpers\n */\n\nimport type {AnyObject} from '../types/basic.js';\nimport type {ActiveDataPoint, ChartEvent} from '../types/index.js';\n\n/**\n * An empty function that can be used, for example, for optional callback.\n */\nexport function noop() {\n /* noop */\n}\n\n/**\n * Returns a unique id, sequentially generated from a global variable.\n */\nexport const uid = (() => {\n let id = 0;\n return () => id++;\n})();\n\n/**\n * Returns true if `value` is neither null nor undefined, else returns false.\n * @param value - The value to test.\n * @since 2.7.0\n */\nexport function isNullOrUndef(value: unknown): value is null | undefined {\n return value === null || value === undefined;\n}\n\n/**\n * Returns true if `value` is an array (including typed arrays), else returns false.\n * @param value - The value to test.\n * @function\n */\nexport function isArray(value: unknown): value is T[] {\n if (Array.isArray && Array.isArray(value)) {\n return true;\n }\n const type = Object.prototype.toString.call(value);\n if (type.slice(0, 7) === '[object' && type.slice(-6) === 'Array]') {\n return true;\n }\n return false;\n}\n\n/**\n * Returns true if `value` is an object (excluding null), else returns false.\n * @param value - The value to test.\n * @since 2.7.0\n */\nexport function isObject(value: unknown): value is AnyObject {\n return value !== null && Object.prototype.toString.call(value) === '[object Object]';\n}\n\n/**\n * Returns true if `value` is a finite number, else returns false\n * @param value - The value to test.\n */\nfunction isNumberFinite(value: unknown): value is number {\n return (typeof value === 'number' || value instanceof Number) && isFinite(+value);\n}\nexport {\n isNumberFinite as isFinite,\n};\n\n/**\n * Returns `value` if finite, else returns `defaultValue`.\n * @param value - The value to return if defined.\n * @param defaultValue - The value to return if `value` is not finite.\n */\nexport function finiteOrDefault(value: unknown, defaultValue: number) {\n return isNumberFinite(value) ? value : defaultValue;\n}\n\n/**\n * Returns `value` if defined, else returns `defaultValue`.\n * @param value - The value to return if defined.\n * @param defaultValue - The value to return if `value` is undefined.\n */\nexport function valueOrDefault(value: T | undefined, defaultValue: T) {\n return typeof value === 'undefined' ? defaultValue : value;\n}\n\nexport const toPercentage = (value: number | string, dimension: number) =>\n typeof value === 'string' && value.endsWith('%') ?\n parseFloat(value) / 100\n : +value / dimension;\n\nexport const toDimension = (value: number | string, dimension: number) =>\n typeof value === 'string' && value.endsWith('%') ?\n parseFloat(value) / 100 * dimension\n : +value;\n\n/**\n * Calls `fn` with the given `args` in the scope defined by `thisArg` and returns the\n * value returned by `fn`. If `fn` is not a function, this method returns undefined.\n * @param fn - The function to call.\n * @param args - The arguments with which `fn` should be called.\n * @param [thisArg] - The value of `this` provided for the call to `fn`.\n */\nexport function callback R, TA, R>(\n fn: T | undefined,\n args: unknown[],\n thisArg?: TA\n): R | undefined {\n if (fn && typeof fn.call === 'function') {\n return fn.apply(thisArg, args);\n }\n}\n\n/**\n * Note(SB) for performance sake, this method should only be used when loopable type\n * is unknown or in none intensive code (not called often and small loopable). Else\n * it's preferable to use a regular for() loop and save extra function calls.\n * @param loopable - The object or array to be iterated.\n * @param fn - The function to call for each item.\n * @param [thisArg] - The value of `this` provided for the call to `fn`.\n * @param [reverse] - If true, iterates backward on the loopable.\n */\nexport function each(\n loopable: Record,\n fn: (this: TA, v: T, i: string) => void,\n thisArg?: TA,\n reverse?: boolean\n): void;\nexport function each(\n loopable: T[],\n fn: (this: TA, v: T, i: number) => void,\n thisArg?: TA,\n reverse?: boolean\n): void;\nexport function each(\n loopable: T[] | Record,\n fn: (this: TA, v: T, i: any) => void,\n thisArg?: TA,\n reverse?: boolean\n) {\n let i: number, len: number, keys: string[];\n if (isArray(loopable)) {\n len = loopable.length;\n if (reverse) {\n for (i = len - 1; i >= 0; i--) {\n fn.call(thisArg, loopable[i], i);\n }\n } else {\n for (i = 0; i < len; i++) {\n fn.call(thisArg, loopable[i], i);\n }\n }\n } else if (isObject(loopable)) {\n keys = Object.keys(loopable);\n len = keys.length;\n for (i = 0; i < len; i++) {\n fn.call(thisArg, loopable[keys[i]], keys[i]);\n }\n }\n}\n\n/**\n * Returns true if the `a0` and `a1` arrays have the same content, else returns false.\n * @param a0 - The array to compare\n * @param a1 - The array to compare\n * @private\n */\nexport function _elementsEqual(a0: ActiveDataPoint[], a1: ActiveDataPoint[]) {\n let i: number, ilen: number, v0: ActiveDataPoint, v1: ActiveDataPoint;\n\n if (!a0 || !a1 || a0.length !== a1.length) {\n return false;\n }\n\n for (i = 0, ilen = a0.length; i < ilen; ++i) {\n v0 = a0[i];\n v1 = a1[i];\n\n if (v0.datasetIndex !== v1.datasetIndex || v0.index !== v1.index) {\n return false;\n }\n }\n\n return true;\n}\n\n/**\n * Returns a deep copy of `source` without keeping references on objects and arrays.\n * @param source - The value to clone.\n */\nexport function clone(source: T): T {\n if (isArray(source)) {\n return source.map(clone) as unknown as T;\n }\n\n if (isObject(source)) {\n const target = Object.create(null);\n const keys = Object.keys(source);\n const klen = keys.length;\n let k = 0;\n\n for (; k < klen; ++k) {\n target[keys[k]] = clone(source[keys[k]]);\n }\n\n return target;\n }\n\n return source;\n}\n\nfunction isValidKey(key: string) {\n return ['__proto__', 'prototype', 'constructor'].indexOf(key) === -1;\n}\n\n/**\n * The default merger when Chart.helpers.merge is called without merger option.\n * Note(SB): also used by mergeConfig and mergeScaleConfig as fallback.\n * @private\n */\nexport function _merger(key: string, target: AnyObject, source: AnyObject, options: AnyObject) {\n if (!isValidKey(key)) {\n return;\n }\n\n const tval = target[key];\n const sval = source[key];\n\n if (isObject(tval) && isObject(sval)) {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n merge(tval, sval, options);\n } else {\n target[key] = clone(sval);\n }\n}\n\nexport interface MergeOptions {\n merger?: (key: string, target: AnyObject, source: AnyObject, options?: AnyObject) => void;\n}\n\n/**\n * Recursively deep copies `source` properties into `target` with the given `options`.\n * IMPORTANT: `target` is not cloned and will be updated with `source` properties.\n * @param target - The target object in which all sources are merged into.\n * @param source - Object(s) to merge into `target`.\n * @param [options] - Merging options:\n * @param [options.merger] - The merge method (key, target, source, options)\n * @returns The `target` object.\n */\nexport function merge(target: T, source: [], options?: MergeOptions): T;\nexport function merge(target: T, source: S1, options?: MergeOptions): T & S1;\nexport function merge(target: T, source: [S1], options?: MergeOptions): T & S1;\nexport function merge(target: T, source: [S1, S2], options?: MergeOptions): T & S1 & S2;\nexport function merge(target: T, source: [S1, S2, S3], options?: MergeOptions): T & S1 & S2 & S3;\nexport function merge(\n target: T,\n source: [S1, S2, S3, S4],\n options?: MergeOptions\n): T & S1 & S2 & S3 & S4;\nexport function merge(target: T, source: AnyObject[], options?: MergeOptions): AnyObject;\nexport function merge(target: T, source: AnyObject[], options?: MergeOptions): AnyObject {\n const sources = isArray(source) ? source : [source];\n const ilen = sources.length;\n\n if (!isObject(target)) {\n return target as AnyObject;\n }\n\n options = options || {};\n const merger = options.merger || _merger;\n let current: AnyObject;\n\n for (let i = 0; i < ilen; ++i) {\n current = sources[i];\n if (!isObject(current)) {\n continue;\n }\n\n const keys = Object.keys(current);\n for (let k = 0, klen = keys.length; k < klen; ++k) {\n merger(keys[k], target, current, options as AnyObject);\n }\n }\n\n return target;\n}\n\n/**\n * Recursively deep copies `source` properties into `target` *only* if not defined in target.\n * IMPORTANT: `target` is not cloned and will be updated with `source` properties.\n * @param target - The target object in which all sources are merged into.\n * @param source - Object(s) to merge into `target`.\n * @returns The `target` object.\n */\nexport function mergeIf(target: T, source: []): T;\nexport function mergeIf(target: T, source: S1): T & S1;\nexport function mergeIf(target: T, source: [S1]): T & S1;\nexport function mergeIf(target: T, source: [S1, S2]): T & S1 & S2;\nexport function mergeIf(target: T, source: [S1, S2, S3]): T & S1 & S2 & S3;\nexport function mergeIf(target: T, source: [S1, S2, S3, S4]): T & S1 & S2 & S3 & S4;\nexport function mergeIf(target: T, source: AnyObject[]): AnyObject;\nexport function mergeIf(target: T, source: AnyObject[]): AnyObject {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n return merge(target, source, {merger: _mergerIf});\n}\n\n/**\n * Merges source[key] in target[key] only if target[key] is undefined.\n * @private\n */\nexport function _mergerIf(key: string, target: AnyObject, source: AnyObject) {\n if (!isValidKey(key)) {\n return;\n }\n\n const tval = target[key];\n const sval = source[key];\n\n if (isObject(tval) && isObject(sval)) {\n mergeIf(tval, sval);\n } else if (!Object.prototype.hasOwnProperty.call(target, key)) {\n target[key] = clone(sval);\n }\n}\n\n/**\n * @private\n */\nexport function _deprecated(scope: string, value: unknown, previous: string, current: string) {\n if (value !== undefined) {\n console.warn(scope + ': \"' + previous +\n '\" is deprecated. Please use \"' + current + '\" instead');\n }\n}\n\n// resolveObjectKey resolver cache\nconst keyResolvers = {\n // Chart.helpers.core resolveObjectKey should resolve empty key to root object\n '': v => v,\n // default resolvers\n x: o => o.x,\n y: o => o.y\n};\n\n/**\n * @private\n */\nexport function _splitKey(key: string) {\n const parts = key.split('.');\n const keys: string[] = [];\n let tmp = '';\n for (const part of parts) {\n tmp += part;\n if (tmp.endsWith('\\\\')) {\n tmp = tmp.slice(0, -1) + '.';\n } else {\n keys.push(tmp);\n tmp = '';\n }\n }\n return keys;\n}\n\nfunction _getKeyResolver(key: string) {\n const keys = _splitKey(key);\n return obj => {\n for (const k of keys) {\n if (k === '') {\n // For backward compatibility:\n // Chart.helpers.core resolveObjectKey should break at empty key\n break;\n }\n obj = obj && obj[k];\n }\n return obj;\n };\n}\n\nexport function resolveObjectKey(obj: AnyObject, key: string): any {\n const resolver = keyResolvers[key] || (keyResolvers[key] = _getKeyResolver(key));\n return resolver(obj);\n}\n\n/**\n * @private\n */\nexport function _capitalize(str: string) {\n return str.charAt(0).toUpperCase() + str.slice(1);\n}\n\n\nexport const defined = (value: unknown) => typeof value !== 'undefined';\n\nexport const isFunction = (value: unknown): value is (...args: any[]) => any => typeof value === 'function';\n\n// Adapted from https://stackoverflow.com/questions/31128855/comparing-ecma6-sets-for-equality#31129384\nexport const setsEqual = (a: Set, b: Set) => {\n if (a.size !== b.size) {\n return false;\n }\n\n for (const item of a) {\n if (!b.has(item)) {\n return false;\n }\n }\n\n return true;\n};\n\n/**\n * @param e - The event\n * @private\n */\nexport function _isClickEvent(e: ChartEvent) {\n return e.type === 'mouseup' || e.type === 'click' || e.type === 'contextmenu';\n}\n","import type {Point} from '../types/geometric.js';\nimport {isFinite as isFiniteNumber} from './helpers.core.js';\n\n/**\n * @alias Chart.helpers.math\n * @namespace\n */\n\nexport const PI = Math.PI;\nexport const TAU = 2 * PI;\nexport const PITAU = TAU + PI;\nexport const INFINITY = Number.POSITIVE_INFINITY;\nexport const RAD_PER_DEG = PI / 180;\nexport const HALF_PI = PI / 2;\nexport const QUARTER_PI = PI / 4;\nexport const TWO_THIRDS_PI = PI * 2 / 3;\n\nexport const log10 = Math.log10;\nexport const sign = Math.sign;\n\nexport function almostEquals(x: number, y: number, epsilon: number) {\n return Math.abs(x - y) < epsilon;\n}\n\n/**\n * Implementation of the nice number algorithm used in determining where axis labels will go\n */\nexport function niceNum(range: number) {\n const roundedRange = Math.round(range);\n range = almostEquals(range, roundedRange, range / 1000) ? roundedRange : range;\n const niceRange = Math.pow(10, Math.floor(log10(range)));\n const fraction = range / niceRange;\n const niceFraction = fraction <= 1 ? 1 : fraction <= 2 ? 2 : fraction <= 5 ? 5 : 10;\n return niceFraction * niceRange;\n}\n\n/**\n * Returns an array of factors sorted from 1 to sqrt(value)\n * @private\n */\nexport function _factorize(value: number) {\n const result: number[] = [];\n const sqrt = Math.sqrt(value);\n let i: number;\n\n for (i = 1; i < sqrt; i++) {\n if (value % i === 0) {\n result.push(i);\n result.push(value / i);\n }\n }\n if (sqrt === (sqrt | 0)) { // if value is a square number\n result.push(sqrt);\n }\n\n result.sort((a, b) => a - b).pop();\n return result;\n}\n\n/**\n * Verifies that attempting to coerce n to string or number won't throw a TypeError.\n */\nfunction isNonPrimitive(n: unknown) {\n return typeof n === 'symbol' || (typeof n === 'object' && n !== null && !(Symbol.toPrimitive in n || 'toString' in n || 'valueOf' in n));\n}\n\nexport function isNumber(n: unknown): n is number {\n return !isNonPrimitive(n) && !isNaN(parseFloat(n as string)) && isFinite(n as number);\n}\n\nexport function almostWhole(x: number, epsilon: number) {\n const rounded = Math.round(x);\n return ((rounded - epsilon) <= x) && ((rounded + epsilon) >= x);\n}\n\n/**\n * @private\n */\nexport function _setMinAndMaxByKey(\n array: Record[],\n target: { min: number, max: number },\n property: string\n) {\n let i: number, ilen: number, value: number;\n\n for (i = 0, ilen = array.length; i < ilen; i++) {\n value = array[i][property];\n if (!isNaN(value)) {\n target.min = Math.min(target.min, value);\n target.max = Math.max(target.max, value);\n }\n }\n}\n\nexport function toRadians(degrees: number) {\n return degrees * (PI / 180);\n}\n\nexport function toDegrees(radians: number) {\n return radians * (180 / PI);\n}\n\n/**\n * Returns the number of decimal places\n * i.e. the number of digits after the decimal point, of the value of this Number.\n * @param x - A number.\n * @returns The number of decimal places.\n * @private\n */\nexport function _decimalPlaces(x: number) {\n if (!isFiniteNumber(x)) {\n return;\n }\n let e = 1;\n let p = 0;\n while (Math.round(x * e) / e !== x) {\n e *= 10;\n p++;\n }\n return p;\n}\n\n// Gets the angle from vertical upright to the point about a centre.\nexport function getAngleFromPoint(\n centrePoint: Point,\n anglePoint: Point\n) {\n const distanceFromXCenter = anglePoint.x - centrePoint.x;\n const distanceFromYCenter = anglePoint.y - centrePoint.y;\n const radialDistanceFromCenter = Math.sqrt(distanceFromXCenter * distanceFromXCenter + distanceFromYCenter * distanceFromYCenter);\n\n let angle = Math.atan2(distanceFromYCenter, distanceFromXCenter);\n\n if (angle < (-0.5 * PI)) {\n angle += TAU; // make sure the returned angle is in the range of (-PI/2, 3PI/2]\n }\n\n return {\n angle,\n distance: radialDistanceFromCenter\n };\n}\n\nexport function distanceBetweenPoints(pt1: Point, pt2: Point) {\n return Math.sqrt(Math.pow(pt2.x - pt1.x, 2) + Math.pow(pt2.y - pt1.y, 2));\n}\n\n/**\n * Shortest distance between angles, in either direction.\n * @private\n */\nexport function _angleDiff(a: number, b: number) {\n return (a - b + PITAU) % TAU - PI;\n}\n\n/**\n * Normalize angle to be between 0 and 2*PI\n * @private\n */\nexport function _normalizeAngle(a: number) {\n return (a % TAU + TAU) % TAU;\n}\n\n/**\n * @private\n */\nexport function _angleBetween(angle: number, start: number, end: number, sameAngleIsFullCircle?: boolean) {\n const a = _normalizeAngle(angle);\n const s = _normalizeAngle(start);\n const e = _normalizeAngle(end);\n const angleToStart = _normalizeAngle(s - a);\n const angleToEnd = _normalizeAngle(e - a);\n const startToAngle = _normalizeAngle(a - s);\n const endToAngle = _normalizeAngle(a - e);\n return a === s || a === e || (sameAngleIsFullCircle && s === e)\n || (angleToStart > angleToEnd && startToAngle < endToAngle);\n}\n\n/**\n * Limit `value` between `min` and `max`\n * @param value\n * @param min\n * @param max\n * @private\n */\nexport function _limitValue(value: number, min: number, max: number) {\n return Math.max(min, Math.min(max, value));\n}\n\n/**\n * @param {number} value\n * @private\n */\nexport function _int16Range(value: number) {\n return _limitValue(value, -32768, 32767);\n}\n\n/**\n * @param value\n * @param start\n * @param end\n * @param [epsilon]\n * @private\n */\nexport function _isBetween(value: number, start: number, end: number, epsilon = 1e-6) {\n return value >= Math.min(start, end) - epsilon && value <= Math.max(start, end) + epsilon;\n}\n","import {_capitalize} from './helpers.core.js';\n\n/**\n * Binary search\n * @param table - the table search. must be sorted!\n * @param value - value to find\n * @param cmp\n * @private\n */\nexport function _lookup(\n table: number[],\n value: number,\n cmp?: (value: number) => boolean\n): {lo: number, hi: number};\nexport function _lookup(\n table: T[],\n value: number,\n cmp: (value: number) => boolean\n): {lo: number, hi: number};\nexport function _lookup(\n table: unknown[],\n value: number,\n cmp?: (value: number) => boolean\n) {\n cmp = cmp || ((index) => table[index] < value);\n let hi = table.length - 1;\n let lo = 0;\n let mid: number;\n\n while (hi - lo > 1) {\n mid = (lo + hi) >> 1;\n if (cmp(mid)) {\n lo = mid;\n } else {\n hi = mid;\n }\n }\n\n return {lo, hi};\n}\n\n/**\n * Binary search\n * @param table - the table search. must be sorted!\n * @param key - property name for the value in each entry\n * @param value - value to find\n * @param last - lookup last index\n * @private\n */\nexport const _lookupByKey = (\n table: Record[],\n key: string,\n value: number,\n last?: boolean\n) =>\n _lookup(table, value, last\n ? index => {\n const ti = table[index][key];\n return ti < value || ti === value && table[index + 1][key] === value;\n }\n : index => table[index][key] < value);\n\n/**\n * Reverse binary search\n * @param table - the table search. must be sorted!\n * @param key - property name for the value in each entry\n * @param value - value to find\n * @private\n */\nexport const _rlookupByKey = (\n table: Record[],\n key: string,\n value: number\n) =>\n _lookup(table, value, index => table[index][key] >= value);\n\n/**\n * Return subset of `values` between `min` and `max` inclusive.\n * Values are assumed to be in sorted order.\n * @param values - sorted array of values\n * @param min - min value\n * @param max - max value\n */\nexport function _filterBetween(values: number[], min: number, max: number) {\n let start = 0;\n let end = values.length;\n\n while (start < end && values[start] < min) {\n start++;\n }\n while (end > start && values[end - 1] > max) {\n end--;\n }\n\n return start > 0 || end < values.length\n ? values.slice(start, end)\n : values;\n}\n\nconst arrayEvents = ['push', 'pop', 'shift', 'splice', 'unshift'] as const;\n\nexport interface ArrayListener {\n _onDataPush?(...item: T[]): void;\n _onDataPop?(): void;\n _onDataShift?(): void;\n _onDataSplice?(index: number, deleteCount: number, ...items: T[]): void;\n _onDataUnshift?(...item: T[]): void;\n}\n\n/**\n * Hooks the array methods that add or remove values ('push', pop', 'shift', 'splice',\n * 'unshift') and notify the listener AFTER the array has been altered. Listeners are\n * called on the '_onData*' callbacks (e.g. _onDataPush, etc.) with same arguments.\n */\nexport function listenArrayEvents(array: T[], listener: ArrayListener): void;\nexport function listenArrayEvents(array, listener) {\n if (array._chartjs) {\n array._chartjs.listeners.push(listener);\n return;\n }\n\n Object.defineProperty(array, '_chartjs', {\n configurable: true,\n enumerable: false,\n value: {\n listeners: [listener]\n }\n });\n\n arrayEvents.forEach((key) => {\n const method = '_onData' + _capitalize(key);\n const base = array[key];\n\n Object.defineProperty(array, key, {\n configurable: true,\n enumerable: false,\n value(...args) {\n const res = base.apply(this, args);\n\n array._chartjs.listeners.forEach((object) => {\n if (typeof object[method] === 'function') {\n object[method](...args);\n }\n });\n\n return res;\n }\n });\n });\n}\n\n\n/**\n * Removes the given array event listener and cleanup extra attached properties (such as\n * the _chartjs stub and overridden methods) if array doesn't have any more listeners.\n */\nexport function unlistenArrayEvents(array: T[], listener: ArrayListener): void;\nexport function unlistenArrayEvents(array, listener) {\n const stub = array._chartjs;\n if (!stub) {\n return;\n }\n\n const listeners = stub.listeners;\n const index = listeners.indexOf(listener);\n if (index !== -1) {\n listeners.splice(index, 1);\n }\n\n if (listeners.length > 0) {\n return;\n }\n\n arrayEvents.forEach((key) => {\n delete array[key];\n });\n\n delete array._chartjs;\n}\n\n/**\n * @param items\n */\nexport function _arrayUnique(items: T[]) {\n const set = new Set(items);\n\n if (set.size === items.length) {\n return items;\n }\n\n return Array.from(set);\n}\n","import type {ChartMeta, PointElement} from '../types/index.js';\n\nimport {_limitValue} from './helpers.math.js';\nimport {_lookupByKey} from './helpers.collection.js';\nimport {isNullOrUndef} from './helpers.core.js';\n\nexport function fontString(pixelSize: number, fontStyle: string, fontFamily: string) {\n return fontStyle + ' ' + pixelSize + 'px ' + fontFamily;\n}\n\n/**\n* Request animation polyfill\n*/\nexport const requestAnimFrame = (function() {\n if (typeof window === 'undefined') {\n return function(callback) {\n return callback();\n };\n }\n return window.requestAnimationFrame;\n}());\n\n/**\n * Throttles calling `fn` once per animation frame\n * Latest arguments are used on the actual call\n */\nexport function throttled>(\n fn: (...args: TArgs) => void,\n thisArg: any,\n) {\n let argsToUse = [] as TArgs;\n let ticking = false;\n\n return function(...args: TArgs) {\n // Save the args for use later\n argsToUse = args;\n if (!ticking) {\n ticking = true;\n requestAnimFrame.call(window, () => {\n ticking = false;\n fn.apply(thisArg, argsToUse);\n });\n }\n };\n}\n\n/**\n * Debounces calling `fn` for `delay` ms\n */\nexport function debounce>(fn: (...args: TArgs) => void, delay: number) {\n let timeout;\n return function(...args: TArgs) {\n if (delay) {\n clearTimeout(timeout);\n timeout = setTimeout(fn, delay, args);\n } else {\n fn.apply(this, args);\n }\n return delay;\n };\n}\n\n/**\n * Converts 'start' to 'left', 'end' to 'right' and others to 'center'\n * @private\n */\nexport const _toLeftRightCenter = (align: 'start' | 'end' | 'center') => align === 'start' ? 'left' : align === 'end' ? 'right' : 'center';\n\n/**\n * Returns `start`, `end` or `(start + end) / 2` depending on `align`. Defaults to `center`\n * @private\n */\nexport const _alignStartEnd = (align: 'start' | 'end' | 'center', start: number, end: number) => align === 'start' ? start : align === 'end' ? end : (start + end) / 2;\n\n/**\n * Returns `left`, `right` or `(left + right) / 2` depending on `align`. Defaults to `left`\n * @private\n */\nexport const _textX = (align: 'left' | 'right' | 'center', left: number, right: number, rtl: boolean) => {\n const check = rtl ? 'left' : 'right';\n return align === check ? right : align === 'center' ? (left + right) / 2 : left;\n};\n\n/**\n * Return start and count of visible points.\n * @private\n */\nexport function _getStartAndCountOfVisiblePoints(meta: ChartMeta<'line' | 'scatter'>, points: PointElement[], animationsDisabled: boolean) {\n const pointCount = points.length;\n\n let start = 0;\n let count = pointCount;\n\n if (meta._sorted) {\n const {iScale, vScale, _parsed} = meta;\n const spanGaps = meta.dataset ? meta.dataset.options ? meta.dataset.options.spanGaps : null : null;\n const axis = iScale.axis;\n const {min, max, minDefined, maxDefined} = iScale.getUserBounds();\n\n if (minDefined) {\n start = Math.min(\n // @ts-expect-error Need to type _parsed\n _lookupByKey(_parsed, axis, min).lo,\n // @ts-expect-error Need to fix types on _lookupByKey\n animationsDisabled ? pointCount : _lookupByKey(points, axis, iScale.getPixelForValue(min)).lo);\n if (spanGaps) {\n const distanceToDefinedLo = (_parsed\n .slice(0, start + 1)\n .reverse()\n .findIndex(\n point => !isNullOrUndef(point[vScale.axis])));\n start -= Math.max(0, distanceToDefinedLo);\n }\n start = _limitValue(start, 0, pointCount - 1);\n }\n if (maxDefined) {\n let end = Math.max(\n // @ts-expect-error Need to type _parsed\n _lookupByKey(_parsed, iScale.axis, max, true).hi + 1,\n // @ts-expect-error Need to fix types on _lookupByKey\n animationsDisabled ? 0 : _lookupByKey(points, axis, iScale.getPixelForValue(max), true).hi + 1);\n if (spanGaps) {\n const distanceToDefinedHi = (_parsed\n .slice(end - 1)\n .findIndex(\n point => !isNullOrUndef(point[vScale.axis])));\n end += Math.max(0, distanceToDefinedHi);\n }\n count = _limitValue(end, start, pointCount) - start;\n } else {\n count = pointCount - start;\n }\n }\n\n return {start, count};\n}\n\n/**\n * Checks if the scale ranges have changed.\n * @param {object} meta - dataset meta.\n * @returns {boolean}\n * @private\n */\nexport function _scaleRangesChanged(meta) {\n const {xScale, yScale, _scaleRanges} = meta;\n const newRanges = {\n xmin: xScale.min,\n xmax: xScale.max,\n ymin: yScale.min,\n ymax: yScale.max\n };\n if (!_scaleRanges) {\n meta._scaleRanges = newRanges;\n return true;\n }\n const changed = _scaleRanges.xmin !== xScale.min\n\t\t|| _scaleRanges.xmax !== xScale.max\n\t\t|| _scaleRanges.ymin !== yScale.min\n\t\t|| _scaleRanges.ymax !== yScale.max;\n\n Object.assign(_scaleRanges, newRanges);\n return changed;\n}\n","import {PI, TAU, HALF_PI} from './helpers.math.js';\n\nconst atEdge = (t: number) => t === 0 || t === 1;\nconst elasticIn = (t: number, s: number, p: number) => -(Math.pow(2, 10 * (t -= 1)) * Math.sin((t - s) * TAU / p));\nconst elasticOut = (t: number, s: number, p: number) => Math.pow(2, -10 * t) * Math.sin((t - s) * TAU / p) + 1;\n\n/**\n * Easing functions adapted from Robert Penner's easing equations.\n * @namespace Chart.helpers.easing.effects\n * @see http://www.robertpenner.com/easing/\n */\nconst effects = {\n linear: (t: number) => t,\n\n easeInQuad: (t: number) => t * t,\n\n easeOutQuad: (t: number) => -t * (t - 2),\n\n easeInOutQuad: (t: number) => ((t /= 0.5) < 1)\n ? 0.5 * t * t\n : -0.5 * ((--t) * (t - 2) - 1),\n\n easeInCubic: (t: number) => t * t * t,\n\n easeOutCubic: (t: number) => (t -= 1) * t * t + 1,\n\n easeInOutCubic: (t: number) => ((t /= 0.5) < 1)\n ? 0.5 * t * t * t\n : 0.5 * ((t -= 2) * t * t + 2),\n\n easeInQuart: (t: number) => t * t * t * t,\n\n easeOutQuart: (t: number) => -((t -= 1) * t * t * t - 1),\n\n easeInOutQuart: (t: number) => ((t /= 0.5) < 1)\n ? 0.5 * t * t * t * t\n : -0.5 * ((t -= 2) * t * t * t - 2),\n\n easeInQuint: (t: number) => t * t * t * t * t,\n\n easeOutQuint: (t: number) => (t -= 1) * t * t * t * t + 1,\n\n easeInOutQuint: (t: number) => ((t /= 0.5) < 1)\n ? 0.5 * t * t * t * t * t\n : 0.5 * ((t -= 2) * t * t * t * t + 2),\n\n easeInSine: (t: number) => -Math.cos(t * HALF_PI) + 1,\n\n easeOutSine: (t: number) => Math.sin(t * HALF_PI),\n\n easeInOutSine: (t: number) => -0.5 * (Math.cos(PI * t) - 1),\n\n easeInExpo: (t: number) => (t === 0) ? 0 : Math.pow(2, 10 * (t - 1)),\n\n easeOutExpo: (t: number) => (t === 1) ? 1 : -Math.pow(2, -10 * t) + 1,\n\n easeInOutExpo: (t: number) => atEdge(t) ? t : t < 0.5\n ? 0.5 * Math.pow(2, 10 * (t * 2 - 1))\n : 0.5 * (-Math.pow(2, -10 * (t * 2 - 1)) + 2),\n\n easeInCirc: (t: number) => (t >= 1) ? t : -(Math.sqrt(1 - t * t) - 1),\n\n easeOutCirc: (t: number) => Math.sqrt(1 - (t -= 1) * t),\n\n easeInOutCirc: (t: number) => ((t /= 0.5) < 1)\n ? -0.5 * (Math.sqrt(1 - t * t) - 1)\n : 0.5 * (Math.sqrt(1 - (t -= 2) * t) + 1),\n\n easeInElastic: (t: number) => atEdge(t) ? t : elasticIn(t, 0.075, 0.3),\n\n easeOutElastic: (t: number) => atEdge(t) ? t : elasticOut(t, 0.075, 0.3),\n\n easeInOutElastic(t: number) {\n const s = 0.1125;\n const p = 0.45;\n return atEdge(t) ? t :\n t < 0.5\n ? 0.5 * elasticIn(t * 2, s, p)\n : 0.5 + 0.5 * elasticOut(t * 2 - 1, s, p);\n },\n\n easeInBack(t: number) {\n const s = 1.70158;\n return t * t * ((s + 1) * t - s);\n },\n\n easeOutBack(t: number) {\n const s = 1.70158;\n return (t -= 1) * t * ((s + 1) * t + s) + 1;\n },\n\n easeInOutBack(t: number) {\n let s = 1.70158;\n if ((t /= 0.5) < 1) {\n return 0.5 * (t * t * (((s *= (1.525)) + 1) * t - s));\n }\n return 0.5 * ((t -= 2) * t * (((s *= (1.525)) + 1) * t + s) + 2);\n },\n\n easeInBounce: (t: number) => 1 - effects.easeOutBounce(1 - t),\n\n easeOutBounce(t: number) {\n const m = 7.5625;\n const d = 2.75;\n if (t < (1 / d)) {\n return m * t * t;\n }\n if (t < (2 / d)) {\n return m * (t -= (1.5 / d)) * t + 0.75;\n }\n if (t < (2.5 / d)) {\n return m * (t -= (2.25 / d)) * t + 0.9375;\n }\n return m * (t -= (2.625 / d)) * t + 0.984375;\n },\n\n easeInOutBounce: (t: number) => (t < 0.5)\n ? effects.easeInBounce(t * 2) * 0.5\n : effects.easeOutBounce(t * 2 - 1) * 0.5 + 0.5,\n} as const;\n\nexport type EasingFunction = keyof typeof effects\n\nexport default effects;\n","import {Color} from '@kurkle/color';\n\nexport function isPatternOrGradient(value: unknown): value is CanvasPattern | CanvasGradient {\n if (value && typeof value === 'object') {\n const type = value.toString();\n return type === '[object CanvasPattern]' || type === '[object CanvasGradient]';\n }\n\n return false;\n}\n\nexport function color(value: CanvasGradient): CanvasGradient;\nexport function color(value: CanvasPattern): CanvasPattern;\nexport function color(\n value:\n | string\n | { r: number; g: number; b: number; a: number }\n | [number, number, number]\n | [number, number, number, number]\n): Color;\nexport function color(value) {\n return isPatternOrGradient(value) ? value : new Color(value);\n}\n\nexport function getHoverColor(value: CanvasGradient): CanvasGradient;\nexport function getHoverColor(value: CanvasPattern): CanvasPattern;\nexport function getHoverColor(value: string): string;\nexport function getHoverColor(value) {\n return isPatternOrGradient(value)\n ? value\n : new Color(value).saturate(0.5).darken(0.1).hexString();\n}\n","const numbers = ['x', 'y', 'borderWidth', 'radius', 'tension'];\nconst colors = ['color', 'borderColor', 'backgroundColor'];\n\nexport function applyAnimationsDefaults(defaults) {\n defaults.set('animation', {\n delay: undefined,\n duration: 1000,\n easing: 'easeOutQuart',\n fn: undefined,\n from: undefined,\n loop: undefined,\n to: undefined,\n type: undefined,\n });\n\n defaults.describe('animation', {\n _fallback: false,\n _indexable: false,\n _scriptable: (name) => name !== 'onProgress' && name !== 'onComplete' && name !== 'fn',\n });\n\n defaults.set('animations', {\n colors: {\n type: 'color',\n properties: colors\n },\n numbers: {\n type: 'number',\n properties: numbers\n },\n });\n\n defaults.describe('animations', {\n _fallback: 'animation',\n });\n\n defaults.set('transitions', {\n active: {\n animation: {\n duration: 400\n }\n },\n resize: {\n animation: {\n duration: 0\n }\n },\n show: {\n animations: {\n colors: {\n from: 'transparent'\n },\n visible: {\n type: 'boolean',\n duration: 0 // show immediately\n },\n }\n },\n hide: {\n animations: {\n colors: {\n to: 'transparent'\n },\n visible: {\n type: 'boolean',\n easing: 'linear',\n fn: v => v | 0 // for keeping the dataset visible all the way through the animation\n },\n }\n }\n });\n}\n","export function applyLayoutsDefaults(defaults) {\n defaults.set('layout', {\n autoPadding: true,\n padding: {\n top: 0,\n right: 0,\n bottom: 0,\n left: 0\n }\n });\n}\n","\nconst intlCache = new Map();\n\nfunction getNumberFormat(locale: string, options?: Intl.NumberFormatOptions) {\n options = options || {};\n const cacheKey = locale + JSON.stringify(options);\n let formatter = intlCache.get(cacheKey);\n if (!formatter) {\n formatter = new Intl.NumberFormat(locale, options);\n intlCache.set(cacheKey, formatter);\n }\n return formatter;\n}\n\nexport function formatNumber(num: number, locale: string, options?: Intl.NumberFormatOptions) {\n return getNumberFormat(locale, options).format(num);\n}\n","import {isArray} from '../helpers/helpers.core.js';\nimport {formatNumber} from '../helpers/helpers.intl.js';\nimport {log10} from '../helpers/helpers.math.js';\n\n/**\n * Namespace to hold formatters for different types of ticks\n * @namespace Chart.Ticks.formatters\n */\nconst formatters = {\n /**\n * Formatter for value labels\n * @method Chart.Ticks.formatters.values\n * @param value the value to display\n * @return {string|string[]} the label to display\n */\n values(value) {\n return isArray(value) ? /** @type {string[]} */ (value) : '' + value;\n },\n\n /**\n * Formatter for numeric ticks\n * @method Chart.Ticks.formatters.numeric\n * @param tickValue {number} the value to be formatted\n * @param index {number} the position of the tickValue parameter in the ticks array\n * @param ticks {object[]} the list of ticks being converted\n * @return {string} string representation of the tickValue parameter\n */\n numeric(tickValue, index, ticks) {\n if (tickValue === 0) {\n return '0'; // never show decimal places for 0\n }\n\n const locale = this.chart.options.locale;\n let notation;\n let delta = tickValue; // This is used when there are less than 2 ticks as the tick interval.\n\n if (ticks.length > 1) {\n // all ticks are small or there huge numbers; use scientific notation\n const maxTick = Math.max(Math.abs(ticks[0].value), Math.abs(ticks[ticks.length - 1].value));\n if (maxTick < 1e-4 || maxTick > 1e+15) {\n notation = 'scientific';\n }\n\n delta = calculateDelta(tickValue, ticks);\n }\n\n const logDelta = log10(Math.abs(delta));\n\n // When datasets have values approaching Number.MAX_VALUE, the tick calculations might result in\n // infinity and eventually NaN. Passing NaN for minimumFractionDigits or maximumFractionDigits\n // will make the number formatter throw. So instead we check for isNaN and use a fallback value.\n //\n // toFixed has a max of 20 decimal places\n const numDecimal = isNaN(logDelta) ? 1 : Math.max(Math.min(-1 * Math.floor(logDelta), 20), 0);\n\n const options = {notation, minimumFractionDigits: numDecimal, maximumFractionDigits: numDecimal};\n Object.assign(options, this.options.ticks.format);\n\n return formatNumber(tickValue, locale, options);\n },\n\n\n /**\n * Formatter for logarithmic ticks\n * @method Chart.Ticks.formatters.logarithmic\n * @param tickValue {number} the value to be formatted\n * @param index {number} the position of the tickValue parameter in the ticks array\n * @param ticks {object[]} the list of ticks being converted\n * @return {string} string representation of the tickValue parameter\n */\n logarithmic(tickValue, index, ticks) {\n if (tickValue === 0) {\n return '0';\n }\n const remain = ticks[index].significand || (tickValue / (Math.pow(10, Math.floor(log10(tickValue)))));\n if ([1, 2, 3, 5, 10, 15].includes(remain) || index > 0.8 * ticks.length) {\n return formatters.numeric.call(this, tickValue, index, ticks);\n }\n return '';\n }\n\n};\n\n\nfunction calculateDelta(tickValue, ticks) {\n // Figure out how many digits to show\n // The space between the first two ticks might be smaller than normal spacing\n let delta = ticks.length > 3 ? ticks[2].value - ticks[1].value : ticks[1].value - ticks[0].value;\n\n // If we have a number like 2.5 as the delta, figure out how many decimal places we need\n if (Math.abs(delta) >= 1 && tickValue !== Math.floor(tickValue)) {\n // not an integer\n delta = tickValue - Math.floor(tickValue);\n }\n return delta;\n}\n\n/**\n * Namespace to hold static tick generation functions\n * @namespace Chart.Ticks\n */\nexport default {formatters};\n","import Ticks from './core.ticks.js';\n\nexport function applyScaleDefaults(defaults) {\n defaults.set('scale', {\n display: true,\n offset: false,\n reverse: false,\n beginAtZero: false,\n\n /**\n * Scale boundary strategy (bypassed by min/max time options)\n * - `data`: make sure data are fully visible, ticks outside are removed\n * - `ticks`: make sure ticks are fully visible, data outside are truncated\n * @see https://github.com/chartjs/Chart.js/pull/4556\n * @since 3.0.0\n */\n bounds: 'ticks',\n\n clip: true,\n\n /**\n * Addition grace added to max and reduced from min data value.\n * @since 3.0.0\n */\n grace: 0,\n\n // grid line settings\n grid: {\n display: true,\n lineWidth: 1,\n drawOnChartArea: true,\n drawTicks: true,\n tickLength: 8,\n tickWidth: (_ctx, options) => options.lineWidth,\n tickColor: (_ctx, options) => options.color,\n offset: false,\n },\n\n border: {\n display: true,\n dash: [],\n dashOffset: 0.0,\n width: 1\n },\n\n // scale title\n title: {\n // display property\n display: false,\n\n // actual label\n text: '',\n\n // top/bottom padding\n padding: {\n top: 4,\n bottom: 4\n }\n },\n\n // label settings\n ticks: {\n minRotation: 0,\n maxRotation: 50,\n mirror: false,\n textStrokeWidth: 0,\n textStrokeColor: '',\n padding: 3,\n display: true,\n autoSkip: true,\n autoSkipPadding: 3,\n labelOffset: 0,\n // We pass through arrays to be rendered as multiline labels, we convert Others to strings here.\n callback: Ticks.formatters.values,\n minor: {},\n major: {},\n align: 'center',\n crossAlign: 'near',\n\n showLabelBackdrop: false,\n backdropColor: 'rgba(255, 255, 255, 0.75)',\n backdropPadding: 2,\n }\n });\n\n defaults.route('scale.ticks', 'color', '', 'color');\n defaults.route('scale.grid', 'color', '', 'borderColor');\n defaults.route('scale.border', 'color', '', 'borderColor');\n defaults.route('scale.title', 'color', '', 'color');\n\n defaults.describe('scale', {\n _fallback: false,\n _scriptable: (name) => !name.startsWith('before') && !name.startsWith('after') && name !== 'callback' && name !== 'parser',\n _indexable: (name) => name !== 'borderDash' && name !== 'tickBorderDash' && name !== 'dash',\n });\n\n defaults.describe('scales', {\n _fallback: 'scale',\n });\n\n defaults.describe('scale.ticks', {\n _scriptable: (name) => name !== 'backdropPadding' && name !== 'callback',\n _indexable: (name) => name !== 'backdropPadding',\n });\n}\n","import {getHoverColor} from '../helpers/helpers.color.js';\nimport {isObject, merge, valueOrDefault} from '../helpers/helpers.core.js';\nimport {applyAnimationsDefaults} from './core.animations.defaults.js';\nimport {applyLayoutsDefaults} from './core.layouts.defaults.js';\nimport {applyScaleDefaults} from './core.scale.defaults.js';\n\nexport const overrides = Object.create(null);\nexport const descriptors = Object.create(null);\n\n/**\n * @param {object} node\n * @param {string} key\n * @return {object}\n */\nfunction getScope(node, key) {\n if (!key) {\n return node;\n }\n const keys = key.split('.');\n for (let i = 0, n = keys.length; i < n; ++i) {\n const k = keys[i];\n node = node[k] || (node[k] = Object.create(null));\n }\n return node;\n}\n\nfunction set(root, scope, values) {\n if (typeof scope === 'string') {\n return merge(getScope(root, scope), values);\n }\n return merge(getScope(root, ''), scope);\n}\n\n/**\n * Please use the module's default export which provides a singleton instance\n * Note: class is exported for typedoc\n */\nexport class Defaults {\n constructor(_descriptors, _appliers) {\n this.animation = undefined;\n this.backgroundColor = 'rgba(0,0,0,0.1)';\n this.borderColor = 'rgba(0,0,0,0.1)';\n this.color = '#666';\n this.datasets = {};\n this.devicePixelRatio = (context) => context.chart.platform.getDevicePixelRatio();\n this.elements = {};\n this.events = [\n 'mousemove',\n 'mouseout',\n 'click',\n 'touchstart',\n 'touchmove'\n ];\n this.font = {\n family: \"'Helvetica Neue', 'Helvetica', 'Arial', sans-serif\",\n size: 12,\n style: 'normal',\n lineHeight: 1.2,\n weight: null\n };\n this.hover = {};\n this.hoverBackgroundColor = (ctx, options) => getHoverColor(options.backgroundColor);\n this.hoverBorderColor = (ctx, options) => getHoverColor(options.borderColor);\n this.hoverColor = (ctx, options) => getHoverColor(options.color);\n this.indexAxis = 'x';\n this.interaction = {\n mode: 'nearest',\n intersect: true,\n includeInvisible: false\n };\n this.maintainAspectRatio = true;\n this.onHover = null;\n this.onClick = null;\n this.parsing = true;\n this.plugins = {};\n this.responsive = true;\n this.scale = undefined;\n this.scales = {};\n this.showLine = true;\n this.drawActiveElementsOnTop = true;\n\n this.describe(_descriptors);\n this.apply(_appliers);\n }\n\n /**\n\t * @param {string|object} scope\n\t * @param {object} [values]\n\t */\n set(scope, values) {\n return set(this, scope, values);\n }\n\n /**\n\t * @param {string} scope\n\t */\n get(scope) {\n return getScope(this, scope);\n }\n\n /**\n\t * @param {string|object} scope\n\t * @param {object} [values]\n\t */\n describe(scope, values) {\n return set(descriptors, scope, values);\n }\n\n override(scope, values) {\n return set(overrides, scope, values);\n }\n\n /**\n\t * Routes the named defaults to fallback to another scope/name.\n\t * This routing is useful when those target values, like defaults.color, are changed runtime.\n\t * If the values would be copied, the runtime change would not take effect. By routing, the\n\t * fallback is evaluated at each access, so its always up to date.\n\t *\n\t * Example:\n\t *\n\t * \tdefaults.route('elements.arc', 'backgroundColor', '', 'color')\n\t * - reads the backgroundColor from defaults.color when undefined locally\n\t *\n\t * @param {string} scope Scope this route applies to.\n\t * @param {string} name Property name that should be routed to different namespace when not defined here.\n\t * @param {string} targetScope The namespace where those properties should be routed to.\n\t * Empty string ('') is the root of defaults.\n\t * @param {string} targetName The target name in the target scope the property should be routed to.\n\t */\n route(scope, name, targetScope, targetName) {\n const scopeObject = getScope(this, scope);\n const targetScopeObject = getScope(this, targetScope);\n const privateName = '_' + name;\n\n Object.defineProperties(scopeObject, {\n // A private property is defined to hold the actual value, when this property is set in its scope (set in the setter)\n [privateName]: {\n value: scopeObject[name],\n writable: true\n },\n // The actual property is defined as getter/setter so we can do the routing when value is not locally set.\n [name]: {\n enumerable: true,\n get() {\n const local = this[privateName];\n const target = targetScopeObject[targetName];\n if (isObject(local)) {\n return Object.assign({}, target, local);\n }\n return valueOrDefault(local, target);\n },\n set(value) {\n this[privateName] = value;\n }\n }\n });\n }\n\n apply(appliers) {\n appliers.forEach((apply) => apply(this));\n }\n}\n\n// singleton instance\nexport default /* #__PURE__ */ new Defaults({\n _scriptable: (name) => !name.startsWith('on'),\n _indexable: (name) => name !== 'events',\n hover: {\n _fallback: 'interaction'\n },\n interaction: {\n _scriptable: false,\n _indexable: false,\n }\n}, [applyAnimationsDefaults, applyLayoutsDefaults, applyScaleDefaults]);\n","import type {\n Chart,\n Point,\n FontSpec,\n CanvasFontSpec,\n PointStyle,\n RenderTextOpts,\n BackdropOptions\n} from '../types/index.js';\nimport type {\n TRBL,\n SplinePoint,\n RoundedRect,\n TRBLCorners\n} from '../types/geometric.js';\nimport {isArray, isNullOrUndef} from './helpers.core.js';\nimport {PI, TAU, HALF_PI, QUARTER_PI, TWO_THIRDS_PI, RAD_PER_DEG} from './helpers.math.js';\n\n/**\n * Converts the given font object into a CSS font string.\n * @param font - A font object.\n * @return The CSS font string. See https://developer.mozilla.org/en-US/docs/Web/CSS/font\n * @private\n */\nexport function toFontString(font: FontSpec) {\n if (!font || isNullOrUndef(font.size) || isNullOrUndef(font.family)) {\n return null;\n }\n\n return (font.style ? font.style + ' ' : '')\n\t\t+ (font.weight ? font.weight + ' ' : '')\n\t\t+ font.size + 'px '\n\t\t+ font.family;\n}\n\n/**\n * @private\n */\nexport function _measureText(\n ctx: CanvasRenderingContext2D,\n data: Record,\n gc: string[],\n longest: number,\n string: string\n) {\n let textWidth = data[string];\n if (!textWidth) {\n textWidth = data[string] = ctx.measureText(string).width;\n gc.push(string);\n }\n if (textWidth > longest) {\n longest = textWidth;\n }\n return longest;\n}\n\ntype Thing = string | undefined | null\ntype Things = (Thing | Thing[])[]\n\n/**\n * @private\n */\n// eslint-disable-next-line complexity\nexport function _longestText(\n ctx: CanvasRenderingContext2D,\n font: string,\n arrayOfThings: Things,\n cache?: {data?: Record, garbageCollect?: string[], font?: string}\n) {\n cache = cache || {};\n let data = cache.data = cache.data || {};\n let gc = cache.garbageCollect = cache.garbageCollect || [];\n\n if (cache.font !== font) {\n data = cache.data = {};\n gc = cache.garbageCollect = [];\n cache.font = font;\n }\n\n ctx.save();\n\n ctx.font = font;\n let longest = 0;\n const ilen = arrayOfThings.length;\n let i: number, j: number, jlen: number, thing: Thing | Thing[], nestedThing: Thing | Thing[];\n for (i = 0; i < ilen; i++) {\n thing = arrayOfThings[i];\n\n // Undefined strings and arrays should not be measured\n if (thing !== undefined && thing !== null && !isArray(thing)) {\n longest = _measureText(ctx, data, gc, longest, thing);\n } else if (isArray(thing)) {\n // if it is an array lets measure each element\n // to do maybe simplify this function a bit so we can do this more recursively?\n for (j = 0, jlen = thing.length; j < jlen; j++) {\n nestedThing = thing[j];\n // Undefined strings and arrays should not be measured\n if (nestedThing !== undefined && nestedThing !== null && !isArray(nestedThing)) {\n longest = _measureText(ctx, data, gc, longest, nestedThing);\n }\n }\n }\n }\n\n ctx.restore();\n\n const gcLen = gc.length / 2;\n if (gcLen > arrayOfThings.length) {\n for (i = 0; i < gcLen; i++) {\n delete data[gc[i]];\n }\n gc.splice(0, gcLen);\n }\n return longest;\n}\n\n/**\n * Returns the aligned pixel value to avoid anti-aliasing blur\n * @param chart - The chart instance.\n * @param pixel - A pixel value.\n * @param width - The width of the element.\n * @returns The aligned pixel value.\n * @private\n */\nexport function _alignPixel(chart: Chart, pixel: number, width: number) {\n const devicePixelRatio = chart.currentDevicePixelRatio;\n const halfWidth = width !== 0 ? Math.max(width / 2, 0.5) : 0;\n return Math.round((pixel - halfWidth) * devicePixelRatio) / devicePixelRatio + halfWidth;\n}\n\n/**\n * Clears the entire canvas.\n */\nexport function clearCanvas(canvas?: HTMLCanvasElement, ctx?: CanvasRenderingContext2D) {\n if (!ctx && !canvas) {\n return;\n }\n\n ctx = ctx || canvas.getContext('2d');\n\n ctx.save();\n // canvas.width and canvas.height do not consider the canvas transform,\n // while clearRect does\n ctx.resetTransform();\n ctx.clearRect(0, 0, canvas.width, canvas.height);\n ctx.restore();\n}\n\nexport interface DrawPointOptions {\n pointStyle: PointStyle;\n rotation?: number;\n radius: number;\n borderWidth: number;\n}\n\nexport function drawPoint(\n ctx: CanvasRenderingContext2D,\n options: DrawPointOptions,\n x: number,\n y: number\n) {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n drawPointLegend(ctx, options, x, y, null);\n}\n\n// eslint-disable-next-line complexity\nexport function drawPointLegend(\n ctx: CanvasRenderingContext2D,\n options: DrawPointOptions,\n x: number,\n y: number,\n w: number\n) {\n let type: string, xOffset: number, yOffset: number, size: number, cornerRadius: number, width: number, xOffsetW: number, yOffsetW: number;\n const style = options.pointStyle;\n const rotation = options.rotation;\n const radius = options.radius;\n let rad = (rotation || 0) * RAD_PER_DEG;\n\n if (style && typeof style === 'object') {\n type = style.toString();\n if (type === '[object HTMLImageElement]' || type === '[object HTMLCanvasElement]') {\n ctx.save();\n ctx.translate(x, y);\n ctx.rotate(rad);\n ctx.drawImage(style, -style.width / 2, -style.height / 2, style.width, style.height);\n ctx.restore();\n return;\n }\n }\n\n if (isNaN(radius) || radius <= 0) {\n return;\n }\n\n ctx.beginPath();\n\n switch (style) {\n // Default includes circle\n default:\n if (w) {\n ctx.ellipse(x, y, w / 2, radius, 0, 0, TAU);\n } else {\n ctx.arc(x, y, radius, 0, TAU);\n }\n ctx.closePath();\n break;\n case 'triangle':\n width = w ? w / 2 : radius;\n ctx.moveTo(x + Math.sin(rad) * width, y - Math.cos(rad) * radius);\n rad += TWO_THIRDS_PI;\n ctx.lineTo(x + Math.sin(rad) * width, y - Math.cos(rad) * radius);\n rad += TWO_THIRDS_PI;\n ctx.lineTo(x + Math.sin(rad) * width, y - Math.cos(rad) * radius);\n ctx.closePath();\n break;\n case 'rectRounded':\n // NOTE: the rounded rect implementation changed to use `arc` instead of\n // `quadraticCurveTo` since it generates better results when rect is\n // almost a circle. 0.516 (instead of 0.5) produces results with visually\n // closer proportion to the previous impl and it is inscribed in the\n // circle with `radius`. For more details, see the following PRs:\n // https://github.com/chartjs/Chart.js/issues/5597\n // https://github.com/chartjs/Chart.js/issues/5858\n cornerRadius = radius * 0.516;\n size = radius - cornerRadius;\n xOffset = Math.cos(rad + QUARTER_PI) * size;\n xOffsetW = Math.cos(rad + QUARTER_PI) * (w ? w / 2 - cornerRadius : size);\n yOffset = Math.sin(rad + QUARTER_PI) * size;\n yOffsetW = Math.sin(rad + QUARTER_PI) * (w ? w / 2 - cornerRadius : size);\n ctx.arc(x - xOffsetW, y - yOffset, cornerRadius, rad - PI, rad - HALF_PI);\n ctx.arc(x + yOffsetW, y - xOffset, cornerRadius, rad - HALF_PI, rad);\n ctx.arc(x + xOffsetW, y + yOffset, cornerRadius, rad, rad + HALF_PI);\n ctx.arc(x - yOffsetW, y + xOffset, cornerRadius, rad + HALF_PI, rad + PI);\n ctx.closePath();\n break;\n case 'rect':\n if (!rotation) {\n size = Math.SQRT1_2 * radius;\n width = w ? w / 2 : size;\n ctx.rect(x - width, y - size, 2 * width, 2 * size);\n break;\n }\n rad += QUARTER_PI;\n /* falls through */\n case 'rectRot':\n xOffsetW = Math.cos(rad) * (w ? w / 2 : radius);\n xOffset = Math.cos(rad) * radius;\n yOffset = Math.sin(rad) * radius;\n yOffsetW = Math.sin(rad) * (w ? w / 2 : radius);\n ctx.moveTo(x - xOffsetW, y - yOffset);\n ctx.lineTo(x + yOffsetW, y - xOffset);\n ctx.lineTo(x + xOffsetW, y + yOffset);\n ctx.lineTo(x - yOffsetW, y + xOffset);\n ctx.closePath();\n break;\n case 'crossRot':\n rad += QUARTER_PI;\n /* falls through */\n case 'cross':\n xOffsetW = Math.cos(rad) * (w ? w / 2 : radius);\n xOffset = Math.cos(rad) * radius;\n yOffset = Math.sin(rad) * radius;\n yOffsetW = Math.sin(rad) * (w ? w / 2 : radius);\n ctx.moveTo(x - xOffsetW, y - yOffset);\n ctx.lineTo(x + xOffsetW, y + yOffset);\n ctx.moveTo(x + yOffsetW, y - xOffset);\n ctx.lineTo(x - yOffsetW, y + xOffset);\n break;\n case 'star':\n xOffsetW = Math.cos(rad) * (w ? w / 2 : radius);\n xOffset = Math.cos(rad) * radius;\n yOffset = Math.sin(rad) * radius;\n yOffsetW = Math.sin(rad) * (w ? w / 2 : radius);\n ctx.moveTo(x - xOffsetW, y - yOffset);\n ctx.lineTo(x + xOffsetW, y + yOffset);\n ctx.moveTo(x + yOffsetW, y - xOffset);\n ctx.lineTo(x - yOffsetW, y + xOffset);\n rad += QUARTER_PI;\n xOffsetW = Math.cos(rad) * (w ? w / 2 : radius);\n xOffset = Math.cos(rad) * radius;\n yOffset = Math.sin(rad) * radius;\n yOffsetW = Math.sin(rad) * (w ? w / 2 : radius);\n ctx.moveTo(x - xOffsetW, y - yOffset);\n ctx.lineTo(x + xOffsetW, y + yOffset);\n ctx.moveTo(x + yOffsetW, y - xOffset);\n ctx.lineTo(x - yOffsetW, y + xOffset);\n break;\n case 'line':\n xOffset = w ? w / 2 : Math.cos(rad) * radius;\n yOffset = Math.sin(rad) * radius;\n ctx.moveTo(x - xOffset, y - yOffset);\n ctx.lineTo(x + xOffset, y + yOffset);\n break;\n case 'dash':\n ctx.moveTo(x, y);\n ctx.lineTo(x + Math.cos(rad) * (w ? w / 2 : radius), y + Math.sin(rad) * radius);\n break;\n case false:\n ctx.closePath();\n break;\n }\n\n ctx.fill();\n if (options.borderWidth > 0) {\n ctx.stroke();\n }\n}\n\n/**\n * Returns true if the point is inside the rectangle\n * @param point - The point to test\n * @param area - The rectangle\n * @param margin - allowed margin\n * @private\n */\nexport function _isPointInArea(\n point: Point,\n area: TRBL,\n margin?: number\n) {\n margin = margin || 0.5; // margin - default is to match rounded decimals\n\n return !area || (point && point.x > area.left - margin && point.x < area.right + margin &&\n\t\tpoint.y > area.top - margin && point.y < area.bottom + margin);\n}\n\nexport function clipArea(ctx: CanvasRenderingContext2D, area: TRBL) {\n ctx.save();\n ctx.beginPath();\n ctx.rect(area.left, area.top, area.right - area.left, area.bottom - area.top);\n ctx.clip();\n}\n\nexport function unclipArea(ctx: CanvasRenderingContext2D) {\n ctx.restore();\n}\n\n/**\n * @private\n */\nexport function _steppedLineTo(\n ctx: CanvasRenderingContext2D,\n previous: Point,\n target: Point,\n flip?: boolean,\n mode?: string\n) {\n if (!previous) {\n return ctx.lineTo(target.x, target.y);\n }\n if (mode === 'middle') {\n const midpoint = (previous.x + target.x) / 2.0;\n ctx.lineTo(midpoint, previous.y);\n ctx.lineTo(midpoint, target.y);\n } else if (mode === 'after' !== !!flip) {\n ctx.lineTo(previous.x, target.y);\n } else {\n ctx.lineTo(target.x, previous.y);\n }\n ctx.lineTo(target.x, target.y);\n}\n\n/**\n * @private\n */\nexport function _bezierCurveTo(\n ctx: CanvasRenderingContext2D,\n previous: SplinePoint,\n target: SplinePoint,\n flip?: boolean\n) {\n if (!previous) {\n return ctx.lineTo(target.x, target.y);\n }\n ctx.bezierCurveTo(\n flip ? previous.cp1x : previous.cp2x,\n flip ? previous.cp1y : previous.cp2y,\n flip ? target.cp2x : target.cp1x,\n flip ? target.cp2y : target.cp1y,\n target.x,\n target.y);\n}\n\nfunction setRenderOpts(ctx: CanvasRenderingContext2D, opts: RenderTextOpts) {\n if (opts.translation) {\n ctx.translate(opts.translation[0], opts.translation[1]);\n }\n\n if (!isNullOrUndef(opts.rotation)) {\n ctx.rotate(opts.rotation);\n }\n\n if (opts.color) {\n ctx.fillStyle = opts.color;\n }\n\n if (opts.textAlign) {\n ctx.textAlign = opts.textAlign;\n }\n\n if (opts.textBaseline) {\n ctx.textBaseline = opts.textBaseline;\n }\n}\n\nfunction decorateText(\n ctx: CanvasRenderingContext2D,\n x: number,\n y: number,\n line: string,\n opts: RenderTextOpts\n) {\n if (opts.strikethrough || opts.underline) {\n /**\n * Now that IE11 support has been dropped, we can use more\n * of the TextMetrics object. The actual bounding boxes\n * are unflagged in Chrome, Firefox, Edge, and Safari so they\n * can be safely used.\n * See https://developer.mozilla.org/en-US/docs/Web/API/TextMetrics#Browser_compatibility\n */\n const metrics = ctx.measureText(line);\n const left = x - metrics.actualBoundingBoxLeft;\n const right = x + metrics.actualBoundingBoxRight;\n const top = y - metrics.actualBoundingBoxAscent;\n const bottom = y + metrics.actualBoundingBoxDescent;\n const yDecoration = opts.strikethrough ? (top + bottom) / 2 : bottom;\n\n ctx.strokeStyle = ctx.fillStyle;\n ctx.beginPath();\n ctx.lineWidth = opts.decorationWidth || 2;\n ctx.moveTo(left, yDecoration);\n ctx.lineTo(right, yDecoration);\n ctx.stroke();\n }\n}\n\nfunction drawBackdrop(ctx: CanvasRenderingContext2D, opts: BackdropOptions) {\n const oldColor = ctx.fillStyle;\n\n ctx.fillStyle = opts.color as string;\n ctx.fillRect(opts.left, opts.top, opts.width, opts.height);\n ctx.fillStyle = oldColor;\n}\n\n/**\n * Render text onto the canvas\n */\nexport function renderText(\n ctx: CanvasRenderingContext2D,\n text: string | string[],\n x: number,\n y: number,\n font: CanvasFontSpec,\n opts: RenderTextOpts = {}\n) {\n const lines = isArray(text) ? text : [text];\n const stroke = opts.strokeWidth > 0 && opts.strokeColor !== '';\n let i: number, line: string;\n\n ctx.save();\n ctx.font = font.string;\n setRenderOpts(ctx, opts);\n\n for (i = 0; i < lines.length; ++i) {\n line = lines[i];\n\n if (opts.backdrop) {\n drawBackdrop(ctx, opts.backdrop);\n }\n\n if (stroke) {\n if (opts.strokeColor) {\n ctx.strokeStyle = opts.strokeColor;\n }\n\n if (!isNullOrUndef(opts.strokeWidth)) {\n ctx.lineWidth = opts.strokeWidth;\n }\n\n ctx.strokeText(line, x, y, opts.maxWidth);\n }\n\n ctx.fillText(line, x, y, opts.maxWidth);\n decorateText(ctx, x, y, line, opts);\n\n y += Number(font.lineHeight);\n }\n\n ctx.restore();\n}\n\n/**\n * Add a path of a rectangle with rounded corners to the current sub-path\n * @param ctx - Context\n * @param rect - Bounding rect\n */\nexport function addRoundedRectPath(\n ctx: CanvasRenderingContext2D,\n rect: RoundedRect & { radius: TRBLCorners }\n) {\n const {x, y, w, h, radius} = rect;\n\n // top left arc\n ctx.arc(x + radius.topLeft, y + radius.topLeft, radius.topLeft, 1.5 * PI, PI, true);\n\n // line from top left to bottom left\n ctx.lineTo(x, y + h - radius.bottomLeft);\n\n // bottom left arc\n ctx.arc(x + radius.bottomLeft, y + h - radius.bottomLeft, radius.bottomLeft, PI, HALF_PI, true);\n\n // line from bottom left to bottom right\n ctx.lineTo(x + w - radius.bottomRight, y + h);\n\n // bottom right arc\n ctx.arc(x + w - radius.bottomRight, y + h - radius.bottomRight, radius.bottomRight, HALF_PI, 0, true);\n\n // line from bottom right to top right\n ctx.lineTo(x + w, y + radius.topRight);\n\n // top right arc\n ctx.arc(x + w - radius.topRight, y + radius.topRight, radius.topRight, 0, -HALF_PI, true);\n\n // line from top right to top left\n ctx.lineTo(x + radius.topLeft, y);\n}\n","import defaults from '../core/core.defaults.js';\nimport {isArray, isObject, toDimension, valueOrDefault} from './helpers.core.js';\nimport {toFontString} from './helpers.canvas.js';\nimport type {ChartArea, FontSpec, Point} from '../types/index.js';\nimport type {TRBL, TRBLCorners} from '../types/geometric.js';\n\nconst LINE_HEIGHT = /^(normal|(\\d+(?:\\.\\d+)?)(px|em|%)?)$/;\nconst FONT_STYLE = /^(normal|italic|initial|inherit|unset|(oblique( -?[0-9]?[0-9]deg)?))$/;\n\n/**\n * @alias Chart.helpers.options\n * @namespace\n */\n/**\n * Converts the given line height `value` in pixels for a specific font `size`.\n * @param value - The lineHeight to parse (eg. 1.6, '14px', '75%', '1.6em').\n * @param size - The font size (in pixels) used to resolve relative `value`.\n * @returns The effective line height in pixels (size * 1.2 if value is invalid).\n * @see https://developer.mozilla.org/en-US/docs/Web/CSS/line-height\n * @since 2.7.0\n */\nexport function toLineHeight(value: number | string, size: number): number {\n const matches = ('' + value).match(LINE_HEIGHT);\n if (!matches || matches[1] === 'normal') {\n return size * 1.2;\n }\n\n value = +matches[2];\n\n switch (matches[3]) {\n case 'px':\n return value;\n case '%':\n value /= 100;\n break;\n default:\n break;\n }\n\n return size * value;\n}\n\nconst numberOrZero = (v: unknown) => +v || 0;\n\n/**\n * @param value\n * @param props\n */\nexport function _readValueToProps(value: number | Record, props: K[]): Record;\nexport function _readValueToProps(value: number | Record, props: Record): Record;\nexport function _readValueToProps(value: number | Record, props: string[] | Record) {\n const ret = {};\n const objProps = isObject(props);\n const keys = objProps ? Object.keys(props) : props;\n const read = isObject(value)\n ? objProps\n ? prop => valueOrDefault(value[prop], value[props[prop]])\n : prop => value[prop]\n : () => value;\n\n for (const prop of keys) {\n ret[prop] = numberOrZero(read(prop));\n }\n return ret;\n}\n\n/**\n * Converts the given value into a TRBL object.\n * @param value - If a number, set the value to all TRBL component,\n * else, if an object, use defined properties and sets undefined ones to 0.\n * x / y are shorthands for same value for left/right and top/bottom.\n * @returns The padding values (top, right, bottom, left)\n * @since 3.0.0\n */\nexport function toTRBL(value: number | TRBL | Point) {\n return _readValueToProps(value, {top: 'y', right: 'x', bottom: 'y', left: 'x'});\n}\n\n/**\n * Converts the given value into a TRBL corners object (similar with css border-radius).\n * @param value - If a number, set the value to all TRBL corner components,\n * else, if an object, use defined properties and sets undefined ones to 0.\n * @returns The TRBL corner values (topLeft, topRight, bottomLeft, bottomRight)\n * @since 3.0.0\n */\nexport function toTRBLCorners(value: number | TRBLCorners) {\n return _readValueToProps(value, ['topLeft', 'topRight', 'bottomLeft', 'bottomRight']);\n}\n\n/**\n * Converts the given value into a padding object with pre-computed width/height.\n * @param value - If a number, set the value to all TRBL component,\n * else, if an object, use defined properties and sets undefined ones to 0.\n * x / y are shorthands for same value for left/right and top/bottom.\n * @returns The padding values (top, right, bottom, left, width, height)\n * @since 2.7.0\n */\nexport function toPadding(value?: number | TRBL): ChartArea {\n const obj = toTRBL(value) as ChartArea;\n\n obj.width = obj.left + obj.right;\n obj.height = obj.top + obj.bottom;\n\n return obj;\n}\n\n/**\n * Parses font options and returns the font object.\n * @param options - A object that contains font options to be parsed.\n * @param fallback - A object that contains fallback font options.\n * @return The font object.\n * @private\n */\n\nexport function toFont(options: Partial, fallback?: Partial) {\n options = options || {};\n fallback = fallback || defaults.font as FontSpec;\n\n let size = valueOrDefault(options.size, fallback.size);\n\n if (typeof size === 'string') {\n size = parseInt(size, 10);\n }\n let style = valueOrDefault(options.style, fallback.style);\n if (style && !('' + style).match(FONT_STYLE)) {\n console.warn('Invalid font style specified: \"' + style + '\"');\n style = undefined;\n }\n\n const font = {\n family: valueOrDefault(options.family, fallback.family),\n lineHeight: toLineHeight(valueOrDefault(options.lineHeight, fallback.lineHeight), size),\n size,\n style,\n weight: valueOrDefault(options.weight, fallback.weight),\n string: ''\n };\n\n font.string = toFontString(font);\n return font;\n}\n\n/**\n * Evaluates the given `inputs` sequentially and returns the first defined value.\n * @param inputs - An array of values, falling back to the last value.\n * @param context - If defined and the current value is a function, the value\n * is called with `context` as first argument and the result becomes the new input.\n * @param index - If defined and the current value is an array, the value\n * at `index` become the new input.\n * @param info - object to return information about resolution in\n * @param info.cacheable - Will be set to `false` if option is not cacheable.\n * @since 2.7.0\n */\nexport function resolve(inputs: Array, context?: object, index?: number, info?: { cacheable: boolean }) {\n let cacheable = true;\n let i: number, ilen: number, value: unknown;\n\n for (i = 0, ilen = inputs.length; i < ilen; ++i) {\n value = inputs[i];\n if (value === undefined) {\n continue;\n }\n if (context !== undefined && typeof value === 'function') {\n value = value(context);\n cacheable = false;\n }\n if (index !== undefined && isArray(value)) {\n value = value[index % value.length];\n cacheable = false;\n }\n if (value !== undefined) {\n if (info && !cacheable) {\n info.cacheable = false;\n }\n return value;\n }\n }\n}\n\n/**\n * @param minmax\n * @param grace\n * @param beginAtZero\n * @private\n */\nexport function _addGrace(minmax: { min: number; max: number; }, grace: number | string, beginAtZero: boolean) {\n const {min, max} = minmax;\n const change = toDimension(grace, (max - min) / 2);\n const keepZero = (value: number, add: number) => beginAtZero && value === 0 ? 0 : value + add;\n return {\n min: keepZero(min, -Math.abs(change)),\n max: keepZero(max, change)\n };\n}\n\n/**\n * Create a context inheriting parentContext\n * @param parentContext\n * @param context\n * @returns\n */\nexport function createContext(parentContext: null, context: T): T;\nexport function createContext(parentContext: P, context: T): P & T;\nexport function createContext(parentContext: object, context: object) {\n return Object.assign(Object.create(parentContext), context);\n}\n","/* eslint-disable @typescript-eslint/no-use-before-define */\nimport type {AnyObject} from '../types/basic.js';\nimport type {ChartMeta} from '../types/index.js';\nimport type {\n ResolverObjectKey,\n ResolverCache,\n ResolverProxy,\n DescriptorDefaults,\n Descriptor,\n ContextCache,\n ContextProxy\n} from './helpers.config.types.js';\nimport {isArray, isFunction, isObject, resolveObjectKey, _capitalize} from './helpers.core.js';\n\nexport * from './helpers.config.types.js';\n\n/**\n * Creates a Proxy for resolving raw values for options.\n * @param scopes - The option scopes to look for values, in resolution order\n * @param prefixes - The prefixes for values, in resolution order.\n * @param rootScopes - The root option scopes\n * @param fallback - Parent scopes fallback\n * @param getTarget - callback for getting the target for changed values\n * @returns Proxy\n * @private\n */\nexport function _createResolver<\n T extends AnyObject[] = AnyObject[],\n R extends AnyObject[] = T\n>(\n scopes: T,\n prefixes = [''],\n rootScopes?: R,\n fallback?: ResolverObjectKey,\n getTarget = () => scopes[0]\n) {\n const finalRootScopes = rootScopes || scopes;\n if (typeof fallback === 'undefined') {\n fallback = _resolve('_fallback', scopes);\n }\n const cache: ResolverCache = {\n [Symbol.toStringTag]: 'Object',\n _cacheable: true,\n _scopes: scopes,\n _rootScopes: finalRootScopes,\n _fallback: fallback,\n _getTarget: getTarget,\n override: (scope: AnyObject) => _createResolver([scope, ...scopes], prefixes, finalRootScopes, fallback),\n };\n return new Proxy(cache, {\n /**\n * A trap for the delete operator.\n */\n deleteProperty(target, prop: string) {\n delete target[prop]; // remove from cache\n delete target._keys; // remove cached keys\n delete scopes[0][prop]; // remove from top level scope\n return true;\n },\n\n /**\n * A trap for getting property values.\n */\n get(target, prop: string) {\n return _cached(target, prop,\n () => _resolveWithPrefixes(prop, prefixes, scopes, target));\n },\n\n /**\n * A trap for Object.getOwnPropertyDescriptor.\n * Also used by Object.hasOwnProperty.\n */\n getOwnPropertyDescriptor(target, prop) {\n return Reflect.getOwnPropertyDescriptor(target._scopes[0], prop);\n },\n\n /**\n * A trap for Object.getPrototypeOf.\n */\n getPrototypeOf() {\n return Reflect.getPrototypeOf(scopes[0]);\n },\n\n /**\n * A trap for the in operator.\n */\n has(target, prop: string) {\n return getKeysFromAllScopes(target).includes(prop);\n },\n\n /**\n * A trap for Object.getOwnPropertyNames and Object.getOwnPropertySymbols.\n */\n ownKeys(target) {\n return getKeysFromAllScopes(target);\n },\n\n /**\n * A trap for setting property values.\n */\n set(target, prop: string, value) {\n const storage = target._storage || (target._storage = getTarget());\n target[prop] = storage[prop] = value; // set to top level scope + cache\n delete target._keys; // remove cached keys\n return true;\n }\n }) as ResolverProxy;\n}\n\n/**\n * Returns an Proxy for resolving option values with context.\n * @param proxy - The Proxy returned by `_createResolver`\n * @param context - Context object for scriptable/indexable options\n * @param subProxy - The proxy provided for scriptable options\n * @param descriptorDefaults - Defaults for descriptors\n * @private\n */\nexport function _attachContext<\n T extends AnyObject[] = AnyObject[],\n R extends AnyObject[] = T\n>(\n proxy: ResolverProxy,\n context: AnyObject,\n subProxy?: ResolverProxy,\n descriptorDefaults?: DescriptorDefaults\n) {\n const cache: ContextCache = {\n _cacheable: false,\n _proxy: proxy,\n _context: context,\n _subProxy: subProxy,\n _stack: new Set(),\n _descriptors: _descriptors(proxy, descriptorDefaults),\n setContext: (ctx: AnyObject) => _attachContext(proxy, ctx, subProxy, descriptorDefaults),\n override: (scope: AnyObject) => _attachContext(proxy.override(scope), context, subProxy, descriptorDefaults)\n };\n return new Proxy(cache, {\n /**\n * A trap for the delete operator.\n */\n deleteProperty(target, prop) {\n delete target[prop]; // remove from cache\n delete proxy[prop]; // remove from proxy\n return true;\n },\n\n /**\n * A trap for getting property values.\n */\n get(target, prop: string, receiver) {\n return _cached(target, prop,\n () => _resolveWithContext(target, prop, receiver));\n },\n\n /**\n * A trap for Object.getOwnPropertyDescriptor.\n * Also used by Object.hasOwnProperty.\n */\n getOwnPropertyDescriptor(target, prop) {\n return target._descriptors.allKeys\n ? Reflect.has(proxy, prop) ? {enumerable: true, configurable: true} : undefined\n : Reflect.getOwnPropertyDescriptor(proxy, prop);\n },\n\n /**\n * A trap for Object.getPrototypeOf.\n */\n getPrototypeOf() {\n return Reflect.getPrototypeOf(proxy);\n },\n\n /**\n * A trap for the in operator.\n */\n has(target, prop) {\n return Reflect.has(proxy, prop);\n },\n\n /**\n * A trap for Object.getOwnPropertyNames and Object.getOwnPropertySymbols.\n */\n ownKeys() {\n return Reflect.ownKeys(proxy);\n },\n\n /**\n * A trap for setting property values.\n */\n set(target, prop, value) {\n proxy[prop] = value; // set to proxy\n delete target[prop]; // remove from cache\n return true;\n }\n }) as ContextProxy;\n}\n\n/**\n * @private\n */\nexport function _descriptors(\n proxy: ResolverCache,\n defaults: DescriptorDefaults = {scriptable: true, indexable: true}\n): Descriptor {\n const {_scriptable = defaults.scriptable, _indexable = defaults.indexable, _allKeys = defaults.allKeys} = proxy;\n return {\n allKeys: _allKeys,\n scriptable: _scriptable,\n indexable: _indexable,\n isScriptable: isFunction(_scriptable) ? _scriptable : () => _scriptable,\n isIndexable: isFunction(_indexable) ? _indexable : () => _indexable\n };\n}\n\nconst readKey = (prefix: string, name: string) => prefix ? prefix + _capitalize(name) : name;\nconst needsSubResolver = (prop: string, value: unknown) => isObject(value) && prop !== 'adapters' &&\n (Object.getPrototypeOf(value) === null || value.constructor === Object);\n\nfunction _cached(\n target: AnyObject,\n prop: string,\n resolve: () => unknown\n) {\n if (Object.prototype.hasOwnProperty.call(target, prop) || prop === 'constructor') {\n return target[prop];\n }\n\n const value = resolve();\n // cache the resolved value\n target[prop] = value;\n return value;\n}\n\nfunction _resolveWithContext(\n target: ContextCache,\n prop: string,\n receiver: AnyObject\n) {\n const {_proxy, _context, _subProxy, _descriptors: descriptors} = target;\n let value = _proxy[prop]; // resolve from proxy\n\n // resolve with context\n if (isFunction(value) && descriptors.isScriptable(prop)) {\n value = _resolveScriptable(prop, value, target, receiver);\n }\n if (isArray(value) && value.length) {\n value = _resolveArray(prop, value, target, descriptors.isIndexable);\n }\n if (needsSubResolver(prop, value)) {\n // if the resolved value is an object, create a sub resolver for it\n value = _attachContext(value, _context, _subProxy && _subProxy[prop], descriptors);\n }\n return value;\n}\n\nfunction _resolveScriptable(\n prop: string,\n getValue: (ctx: AnyObject, sub: AnyObject) => unknown,\n target: ContextCache,\n receiver: AnyObject\n) {\n const {_proxy, _context, _subProxy, _stack} = target;\n if (_stack.has(prop)) {\n throw new Error('Recursion detected: ' + Array.from(_stack).join('->') + '->' + prop);\n }\n _stack.add(prop);\n let value = getValue(_context, _subProxy || receiver);\n _stack.delete(prop);\n if (needsSubResolver(prop, value)) {\n // When scriptable option returns an object, create a resolver on that.\n value = createSubResolver(_proxy._scopes, _proxy, prop, value);\n }\n return value;\n}\n\nfunction _resolveArray(\n prop: string,\n value: unknown[],\n target: ContextCache,\n isIndexable: (key: string) => boolean\n) {\n const {_proxy, _context, _subProxy, _descriptors: descriptors} = target;\n\n if (typeof _context.index !== 'undefined' && isIndexable(prop)) {\n return value[_context.index % value.length];\n } else if (isObject(value[0])) {\n // Array of objects, return array or resolvers\n const arr = value;\n const scopes = _proxy._scopes.filter(s => s !== arr);\n value = [];\n for (const item of arr) {\n const resolver = createSubResolver(scopes, _proxy, prop, item);\n value.push(_attachContext(resolver, _context, _subProxy && _subProxy[prop], descriptors));\n }\n }\n return value;\n}\n\nfunction resolveFallback(\n fallback: ResolverObjectKey | ((prop: ResolverObjectKey, value: unknown) => ResolverObjectKey),\n prop: ResolverObjectKey,\n value: unknown\n) {\n return isFunction(fallback) ? fallback(prop, value) : fallback;\n}\n\nconst getScope = (key: ResolverObjectKey, parent: AnyObject) => key === true ? parent\n : typeof key === 'string' ? resolveObjectKey(parent, key) : undefined;\n\nfunction addScopes(\n set: Set,\n parentScopes: AnyObject[],\n key: ResolverObjectKey,\n parentFallback: ResolverObjectKey,\n value: unknown\n) {\n for (const parent of parentScopes) {\n const scope = getScope(key, parent);\n if (scope) {\n set.add(scope);\n const fallback = resolveFallback(scope._fallback, key, value);\n if (typeof fallback !== 'undefined' && fallback !== key && fallback !== parentFallback) {\n // When we reach the descriptor that defines a new _fallback, return that.\n // The fallback will resume to that new scope.\n return fallback;\n }\n } else if (scope === false && typeof parentFallback !== 'undefined' && key !== parentFallback) {\n // Fallback to `false` results to `false`, when falling back to different key.\n // For example `interaction` from `hover` or `plugins.tooltip` and `animation` from `animations`\n return null;\n }\n }\n return false;\n}\n\nfunction createSubResolver(\n parentScopes: AnyObject[],\n resolver: ResolverCache,\n prop: ResolverObjectKey,\n value: unknown\n) {\n const rootScopes = resolver._rootScopes;\n const fallback = resolveFallback(resolver._fallback, prop, value);\n const allScopes = [...parentScopes, ...rootScopes];\n const set = new Set();\n set.add(value);\n let key = addScopesFromKey(set, allScopes, prop, fallback || prop, value);\n if (key === null) {\n return false;\n }\n if (typeof fallback !== 'undefined' && fallback !== prop) {\n key = addScopesFromKey(set, allScopes, fallback, key, value);\n if (key === null) {\n return false;\n }\n }\n return _createResolver(Array.from(set), [''], rootScopes, fallback,\n () => subGetTarget(resolver, prop as string, value));\n}\n\nfunction addScopesFromKey(\n set: Set,\n allScopes: AnyObject[],\n key: ResolverObjectKey,\n fallback: ResolverObjectKey,\n item: unknown\n) {\n while (key) {\n key = addScopes(set, allScopes, key, fallback, item);\n }\n return key;\n}\n\nfunction subGetTarget(\n resolver: ResolverCache,\n prop: string,\n value: unknown\n) {\n const parent = resolver._getTarget();\n if (!(prop in parent)) {\n parent[prop] = {};\n }\n const target = parent[prop];\n if (isArray(target) && isObject(value)) {\n // For array of objects, the object is used to store updated values\n return value;\n }\n return target || {};\n}\n\nfunction _resolveWithPrefixes(\n prop: string,\n prefixes: string[],\n scopes: AnyObject[],\n proxy: ResolverProxy\n) {\n let value: unknown;\n for (const prefix of prefixes) {\n value = _resolve(readKey(prefix, prop), scopes);\n if (typeof value !== 'undefined') {\n return needsSubResolver(prop, value)\n ? createSubResolver(scopes, proxy, prop, value)\n : value;\n }\n }\n}\n\nfunction _resolve(key: string, scopes: AnyObject[]) {\n for (const scope of scopes) {\n if (!scope) {\n continue;\n }\n const value = scope[key];\n if (typeof value !== 'undefined') {\n return value;\n }\n }\n}\n\nfunction getKeysFromAllScopes(target: ResolverCache) {\n let keys = target._keys;\n if (!keys) {\n keys = target._keys = resolveKeysFromAllScopes(target._scopes);\n }\n return keys;\n}\n\nfunction resolveKeysFromAllScopes(scopes: AnyObject[]) {\n const set = new Set();\n for (const scope of scopes) {\n for (const key of Object.keys(scope).filter(k => !k.startsWith('_'))) {\n set.add(key);\n }\n }\n return Array.from(set);\n}\n\nexport function _parseObjectDataRadialScale(\n meta: ChartMeta<'line' | 'scatter'>,\n data: AnyObject[],\n start: number,\n count: number\n) {\n const {iScale} = meta;\n const {key = 'r'} = this._parsing;\n const parsed = new Array<{r: unknown}>(count);\n let i: number, ilen: number, index: number, item: AnyObject;\n\n for (i = 0, ilen = count; i < ilen; ++i) {\n index = i + start;\n item = data[index];\n parsed[i] = {\n r: iScale.parse(resolveObjectKey(item, key), index)\n };\n }\n return parsed;\n}\n","import {almostEquals, distanceBetweenPoints, sign} from './helpers.math.js';\nimport {_isPointInArea} from './helpers.canvas.js';\nimport type {ChartArea} from '../types/index.js';\nimport type {SplinePoint} from '../types/geometric.js';\n\nconst EPSILON = Number.EPSILON || 1e-14;\n\ntype OptionalSplinePoint = SplinePoint | false\nconst getPoint = (points: SplinePoint[], i: number): OptionalSplinePoint => i < points.length && !points[i].skip && points[i];\nconst getValueAxis = (indexAxis: 'x' | 'y') => indexAxis === 'x' ? 'y' : 'x';\n\nexport function splineCurve(\n firstPoint: SplinePoint,\n middlePoint: SplinePoint,\n afterPoint: SplinePoint,\n t: number\n): {\n previous: SplinePoint\n next: SplinePoint\n } {\n // Props to Rob Spencer at scaled innovation for his post on splining between points\n // http://scaledinnovation.com/analytics/splines/aboutSplines.html\n\n // This function must also respect \"skipped\" points\n\n const previous = firstPoint.skip ? middlePoint : firstPoint;\n const current = middlePoint;\n const next = afterPoint.skip ? middlePoint : afterPoint;\n const d01 = distanceBetweenPoints(current, previous);\n const d12 = distanceBetweenPoints(next, current);\n\n let s01 = d01 / (d01 + d12);\n let s12 = d12 / (d01 + d12);\n\n // If all points are the same, s01 & s02 will be inf\n s01 = isNaN(s01) ? 0 : s01;\n s12 = isNaN(s12) ? 0 : s12;\n\n const fa = t * s01; // scaling factor for triangle Ta\n const fb = t * s12;\n\n return {\n previous: {\n x: current.x - fa * (next.x - previous.x),\n y: current.y - fa * (next.y - previous.y)\n },\n next: {\n x: current.x + fb * (next.x - previous.x),\n y: current.y + fb * (next.y - previous.y)\n }\n };\n}\n\n/**\n * Adjust tangents to ensure monotonic properties\n */\nfunction monotoneAdjust(points: SplinePoint[], deltaK: number[], mK: number[]) {\n const pointsLen = points.length;\n\n let alphaK: number, betaK: number, tauK: number, squaredMagnitude: number, pointCurrent: OptionalSplinePoint;\n let pointAfter = getPoint(points, 0);\n for (let i = 0; i < pointsLen - 1; ++i) {\n pointCurrent = pointAfter;\n pointAfter = getPoint(points, i + 1);\n if (!pointCurrent || !pointAfter) {\n continue;\n }\n\n if (almostEquals(deltaK[i], 0, EPSILON)) {\n mK[i] = mK[i + 1] = 0;\n continue;\n }\n\n alphaK = mK[i] / deltaK[i];\n betaK = mK[i + 1] / deltaK[i];\n squaredMagnitude = Math.pow(alphaK, 2) + Math.pow(betaK, 2);\n if (squaredMagnitude <= 9) {\n continue;\n }\n\n tauK = 3 / Math.sqrt(squaredMagnitude);\n mK[i] = alphaK * tauK * deltaK[i];\n mK[i + 1] = betaK * tauK * deltaK[i];\n }\n}\n\nfunction monotoneCompute(points: SplinePoint[], mK: number[], indexAxis: 'x' | 'y' = 'x') {\n const valueAxis = getValueAxis(indexAxis);\n const pointsLen = points.length;\n let delta: number, pointBefore: OptionalSplinePoint, pointCurrent: OptionalSplinePoint;\n let pointAfter = getPoint(points, 0);\n\n for (let i = 0; i < pointsLen; ++i) {\n pointBefore = pointCurrent;\n pointCurrent = pointAfter;\n pointAfter = getPoint(points, i + 1);\n if (!pointCurrent) {\n continue;\n }\n\n const iPixel = pointCurrent[indexAxis];\n const vPixel = pointCurrent[valueAxis];\n if (pointBefore) {\n delta = (iPixel - pointBefore[indexAxis]) / 3;\n pointCurrent[`cp1${indexAxis}`] = iPixel - delta;\n pointCurrent[`cp1${valueAxis}`] = vPixel - delta * mK[i];\n }\n if (pointAfter) {\n delta = (pointAfter[indexAxis] - iPixel) / 3;\n pointCurrent[`cp2${indexAxis}`] = iPixel + delta;\n pointCurrent[`cp2${valueAxis}`] = vPixel + delta * mK[i];\n }\n }\n}\n\n/**\n * This function calculates Bézier control points in a similar way than |splineCurve|,\n * but preserves monotonicity of the provided data and ensures no local extremums are added\n * between the dataset discrete points due to the interpolation.\n * See : https://en.wikipedia.org/wiki/Monotone_cubic_interpolation\n */\nexport function splineCurveMonotone(points: SplinePoint[], indexAxis: 'x' | 'y' = 'x') {\n const valueAxis = getValueAxis(indexAxis);\n const pointsLen = points.length;\n const deltaK: number[] = Array(pointsLen).fill(0);\n const mK: number[] = Array(pointsLen);\n\n // Calculate slopes (deltaK) and initialize tangents (mK)\n let i, pointBefore: OptionalSplinePoint, pointCurrent: OptionalSplinePoint;\n let pointAfter = getPoint(points, 0);\n\n for (i = 0; i < pointsLen; ++i) {\n pointBefore = pointCurrent;\n pointCurrent = pointAfter;\n pointAfter = getPoint(points, i + 1);\n if (!pointCurrent) {\n continue;\n }\n\n if (pointAfter) {\n const slopeDelta = pointAfter[indexAxis] - pointCurrent[indexAxis];\n\n // In the case of two points that appear at the same x pixel, slopeDeltaX is 0\n deltaK[i] = slopeDelta !== 0 ? (pointAfter[valueAxis] - pointCurrent[valueAxis]) / slopeDelta : 0;\n }\n mK[i] = !pointBefore ? deltaK[i]\n : !pointAfter ? deltaK[i - 1]\n : (sign(deltaK[i - 1]) !== sign(deltaK[i])) ? 0\n : (deltaK[i - 1] + deltaK[i]) / 2;\n }\n\n monotoneAdjust(points, deltaK, mK);\n\n monotoneCompute(points, mK, indexAxis);\n}\n\nfunction capControlPoint(pt: number, min: number, max: number) {\n return Math.max(Math.min(pt, max), min);\n}\n\nfunction capBezierPoints(points: SplinePoint[], area: ChartArea) {\n let i, ilen, point, inArea, inAreaPrev;\n let inAreaNext = _isPointInArea(points[0], area);\n for (i = 0, ilen = points.length; i < ilen; ++i) {\n inAreaPrev = inArea;\n inArea = inAreaNext;\n inAreaNext = i < ilen - 1 && _isPointInArea(points[i + 1], area);\n if (!inArea) {\n continue;\n }\n point = points[i];\n if (inAreaPrev) {\n point.cp1x = capControlPoint(point.cp1x, area.left, area.right);\n point.cp1y = capControlPoint(point.cp1y, area.top, area.bottom);\n }\n if (inAreaNext) {\n point.cp2x = capControlPoint(point.cp2x, area.left, area.right);\n point.cp2y = capControlPoint(point.cp2y, area.top, area.bottom);\n }\n }\n}\n\n/**\n * @private\n */\nexport function _updateBezierControlPoints(\n points: SplinePoint[],\n options,\n area: ChartArea,\n loop: boolean,\n indexAxis: 'x' | 'y'\n) {\n let i: number, ilen: number, point: SplinePoint, controlPoints: ReturnType;\n\n // Only consider points that are drawn in case the spanGaps option is used\n if (options.spanGaps) {\n points = points.filter((pt) => !pt.skip);\n }\n\n if (options.cubicInterpolationMode === 'monotone') {\n splineCurveMonotone(points, indexAxis);\n } else {\n let prev = loop ? points[points.length - 1] : points[0];\n for (i = 0, ilen = points.length; i < ilen; ++i) {\n point = points[i];\n controlPoints = splineCurve(\n prev,\n point,\n points[Math.min(i + 1, ilen - (loop ? 0 : 1)) % ilen],\n options.tension\n );\n point.cp1x = controlPoints.previous.x;\n point.cp1y = controlPoints.previous.y;\n point.cp2x = controlPoints.next.x;\n point.cp2y = controlPoints.next.y;\n prev = point;\n }\n }\n\n if (options.capBezierPoints) {\n capBezierPoints(points, area);\n }\n}\n","import type {ChartArea, Scale} from '../types/index.js';\nimport type PrivateChart from '../core/core.controller.js';\nimport type {Chart, ChartEvent} from '../types.js';\nimport {INFINITY} from './helpers.math.js';\n\n/**\n * @private\n */\nexport function _isDomSupported(): boolean {\n return typeof window !== 'undefined' && typeof document !== 'undefined';\n}\n\n/**\n * @private\n */\nexport function _getParentNode(domNode: HTMLCanvasElement): HTMLCanvasElement {\n let parent = domNode.parentNode;\n if (parent && parent.toString() === '[object ShadowRoot]') {\n parent = (parent as ShadowRoot).host;\n }\n return parent as HTMLCanvasElement;\n}\n\n/**\n * convert max-width/max-height values that may be percentages into a number\n * @private\n */\n\nfunction parseMaxStyle(styleValue: string | number, node: HTMLElement, parentProperty: string) {\n let valueInPixels: number;\n if (typeof styleValue === 'string') {\n valueInPixels = parseInt(styleValue, 10);\n\n if (styleValue.indexOf('%') !== -1) {\n // percentage * size in dimension\n valueInPixels = (valueInPixels / 100) * node.parentNode[parentProperty];\n }\n } else {\n valueInPixels = styleValue;\n }\n\n return valueInPixels;\n}\n\nconst getComputedStyle = (element: HTMLElement): CSSStyleDeclaration =>\n element.ownerDocument.defaultView.getComputedStyle(element, null);\n\nexport function getStyle(el: HTMLElement, property: string): string {\n return getComputedStyle(el).getPropertyValue(property);\n}\n\nconst positions = ['top', 'right', 'bottom', 'left'];\nfunction getPositionedStyle(styles: CSSStyleDeclaration, style: string, suffix?: string): ChartArea {\n const result = {} as ChartArea;\n suffix = suffix ? '-' + suffix : '';\n for (let i = 0; i < 4; i++) {\n const pos = positions[i];\n result[pos] = parseFloat(styles[style + '-' + pos + suffix]) || 0;\n }\n result.width = result.left + result.right;\n result.height = result.top + result.bottom;\n return result;\n}\n\nconst useOffsetPos = (x: number, y: number, target: HTMLElement | EventTarget) =>\n (x > 0 || y > 0) && (!target || !(target as HTMLElement).shadowRoot);\n\n/**\n * @param e\n * @param canvas\n * @returns Canvas position\n */\nfunction getCanvasPosition(\n e: Event | TouchEvent | MouseEvent,\n canvas: HTMLCanvasElement\n): {\n x: number;\n y: number;\n box: boolean;\n } {\n const touches = (e as TouchEvent).touches;\n const source = (touches && touches.length ? touches[0] : e) as MouseEvent;\n const {offsetX, offsetY} = source as MouseEvent;\n let box = false;\n let x, y;\n if (useOffsetPos(offsetX, offsetY, e.target)) {\n x = offsetX;\n y = offsetY;\n } else {\n const rect = canvas.getBoundingClientRect();\n x = source.clientX - rect.left;\n y = source.clientY - rect.top;\n box = true;\n }\n return {x, y, box};\n}\n\n/**\n * Gets an event's x, y coordinates, relative to the chart area\n * @param event\n * @param chart\n * @returns x and y coordinates of the event\n */\n\nexport function getRelativePosition(\n event: Event | ChartEvent | TouchEvent | MouseEvent,\n chart: Chart | PrivateChart\n): { x: number; y: number } {\n if ('native' in event) {\n return event;\n }\n\n const {canvas, currentDevicePixelRatio} = chart;\n const style = getComputedStyle(canvas);\n const borderBox = style.boxSizing === 'border-box';\n const paddings = getPositionedStyle(style, 'padding');\n const borders = getPositionedStyle(style, 'border', 'width');\n const {x, y, box} = getCanvasPosition(event, canvas);\n const xOffset = paddings.left + (box && borders.left);\n const yOffset = paddings.top + (box && borders.top);\n\n let {width, height} = chart;\n if (borderBox) {\n width -= paddings.width + borders.width;\n height -= paddings.height + borders.height;\n }\n return {\n x: Math.round((x - xOffset) / width * canvas.width / currentDevicePixelRatio),\n y: Math.round((y - yOffset) / height * canvas.height / currentDevicePixelRatio)\n };\n}\n\nfunction getContainerSize(canvas: HTMLCanvasElement, width: number, height: number): Partial {\n let maxWidth: number, maxHeight: number;\n\n if (width === undefined || height === undefined) {\n const container = canvas && _getParentNode(canvas);\n if (!container) {\n width = canvas.clientWidth;\n height = canvas.clientHeight;\n } else {\n const rect = container.getBoundingClientRect(); // this is the border box of the container\n const containerStyle = getComputedStyle(container);\n const containerBorder = getPositionedStyle(containerStyle, 'border', 'width');\n const containerPadding = getPositionedStyle(containerStyle, 'padding');\n width = rect.width - containerPadding.width - containerBorder.width;\n height = rect.height - containerPadding.height - containerBorder.height;\n maxWidth = parseMaxStyle(containerStyle.maxWidth, container, 'clientWidth');\n maxHeight = parseMaxStyle(containerStyle.maxHeight, container, 'clientHeight');\n }\n }\n return {\n width,\n height,\n maxWidth: maxWidth || INFINITY,\n maxHeight: maxHeight || INFINITY\n };\n}\n\nconst round1 = (v: number) => Math.round(v * 10) / 10;\n\n// eslint-disable-next-line complexity\nexport function getMaximumSize(\n canvas: HTMLCanvasElement,\n bbWidth?: number,\n bbHeight?: number,\n aspectRatio?: number\n): { width: number; height: number } {\n const style = getComputedStyle(canvas);\n const margins = getPositionedStyle(style, 'margin');\n const maxWidth = parseMaxStyle(style.maxWidth, canvas, 'clientWidth') || INFINITY;\n const maxHeight = parseMaxStyle(style.maxHeight, canvas, 'clientHeight') || INFINITY;\n const containerSize = getContainerSize(canvas, bbWidth, bbHeight);\n let {width, height} = containerSize;\n\n if (style.boxSizing === 'content-box') {\n const borders = getPositionedStyle(style, 'border', 'width');\n const paddings = getPositionedStyle(style, 'padding');\n width -= paddings.width + borders.width;\n height -= paddings.height + borders.height;\n }\n width = Math.max(0, width - margins.width);\n height = Math.max(0, aspectRatio ? width / aspectRatio : height - margins.height);\n width = round1(Math.min(width, maxWidth, containerSize.maxWidth));\n height = round1(Math.min(height, maxHeight, containerSize.maxHeight));\n if (width && !height) {\n // https://github.com/chartjs/Chart.js/issues/4659\n // If the canvas has width, but no height, default to aspectRatio of 2 (canvas default)\n height = round1(width / 2);\n }\n\n const maintainHeight = bbWidth !== undefined || bbHeight !== undefined;\n\n if (maintainHeight && aspectRatio && containerSize.height && height > containerSize.height) {\n height = containerSize.height;\n width = round1(Math.floor(height * aspectRatio));\n }\n\n return {width, height};\n}\n\n/**\n * @param chart\n * @param forceRatio\n * @param forceStyle\n * @returns True if the canvas context size or transformation has changed.\n */\nexport function retinaScale(\n chart: Chart | PrivateChart,\n forceRatio: number,\n forceStyle?: boolean\n): boolean | void {\n const pixelRatio = forceRatio || 1;\n const deviceHeight = round1(chart.height * pixelRatio);\n const deviceWidth = round1(chart.width * pixelRatio);\n\n (chart as PrivateChart).height = round1(chart.height);\n (chart as PrivateChart).width = round1(chart.width);\n\n const canvas = chart.canvas;\n\n // If no style has been set on the canvas, the render size is used as display size,\n // making the chart visually bigger, so let's enforce it to the \"correct\" values.\n // See https://github.com/chartjs/Chart.js/issues/3575\n if (canvas.style && (forceStyle || (!canvas.style.height && !canvas.style.width))) {\n canvas.style.height = `${chart.height}px`;\n canvas.style.width = `${chart.width}px`;\n }\n\n if (chart.currentDevicePixelRatio !== pixelRatio\n || canvas.height !== deviceHeight\n || canvas.width !== deviceWidth) {\n (chart as PrivateChart).currentDevicePixelRatio = pixelRatio;\n canvas.height = deviceHeight;\n canvas.width = deviceWidth;\n chart.ctx.setTransform(pixelRatio, 0, 0, pixelRatio, 0, 0);\n return true;\n }\n return false;\n}\n\n/**\n * Detects support for options object argument in addEventListener.\n * https://developer.mozilla.org/en-US/docs/Web/API/EventTarget/addEventListener#Safely_detecting_option_support\n * @private\n */\nexport const supportsEventListenerOptions = (function() {\n let passiveSupported = false;\n try {\n const options = {\n get passive() { // This function will be called when the browser attempts to access the passive property.\n passiveSupported = true;\n return false;\n }\n } as EventListenerOptions;\n\n if (_isDomSupported()) {\n window.addEventListener('test', null, options);\n window.removeEventListener('test', null, options);\n }\n } catch (e) {\n // continue regardless of error\n }\n return passiveSupported;\n}());\n\n/**\n * The \"used\" size is the final value of a dimension property after all calculations have\n * been performed. This method uses the computed style of `element` but returns undefined\n * if the computed style is not expressed in pixels. That can happen in some cases where\n * `element` has a size relative to its parent and this last one is not yet displayed,\n * for example because of `display: none` on a parent node.\n * @see https://developer.mozilla.org/en-US/docs/Web/CSS/used_value\n * @returns Size in pixels or undefined if unknown.\n */\n\nexport function readUsedSize(\n element: HTMLElement,\n property: 'width' | 'height'\n): number | undefined {\n const value = getStyle(element, property);\n const matches = value && value.match(/^(\\d+)(\\.\\d+)?px$/);\n return matches ? +matches[1] : undefined;\n}\n","import type {Point, SplinePoint} from '../types/geometric.js';\n\n/**\n * @private\n */\nexport function _pointInLine(p1: Point, p2: Point, t: number, mode?) { // eslint-disable-line @typescript-eslint/no-unused-vars\n return {\n x: p1.x + t * (p2.x - p1.x),\n y: p1.y + t * (p2.y - p1.y)\n };\n}\n\n/**\n * @private\n */\nexport function _steppedInterpolation(\n p1: Point,\n p2: Point,\n t: number, mode: 'middle' | 'after' | unknown\n) {\n return {\n x: p1.x + t * (p2.x - p1.x),\n y: mode === 'middle' ? t < 0.5 ? p1.y : p2.y\n : mode === 'after' ? t < 1 ? p1.y : p2.y\n : t > 0 ? p2.y : p1.y\n };\n}\n\n/**\n * @private\n */\nexport function _bezierInterpolation(p1: SplinePoint, p2: SplinePoint, t: number, mode?) { // eslint-disable-line @typescript-eslint/no-unused-vars\n const cp1 = {x: p1.cp2x, y: p1.cp2y};\n const cp2 = {x: p2.cp1x, y: p2.cp1y};\n const a = _pointInLine(p1, cp1, t);\n const b = _pointInLine(cp1, cp2, t);\n const c = _pointInLine(cp2, p2, t);\n const d = _pointInLine(a, b, t);\n const e = _pointInLine(b, c, t);\n return _pointInLine(d, e, t);\n}\n","export interface RTLAdapter {\n x(x: number): number;\n setWidth(w: number): void;\n textAlign(align: 'center' | 'left' | 'right'): 'center' | 'left' | 'right';\n xPlus(x: number, value: number): number;\n leftForLtr(x: number, itemWidth: number): number;\n}\n\nconst getRightToLeftAdapter = function(rectX: number, width: number): RTLAdapter {\n return {\n x(x) {\n return rectX + rectX + width - x;\n },\n setWidth(w) {\n width = w;\n },\n textAlign(align) {\n if (align === 'center') {\n return align;\n }\n return align === 'right' ? 'left' : 'right';\n },\n xPlus(x, value) {\n return x - value;\n },\n leftForLtr(x, itemWidth) {\n return x - itemWidth;\n },\n };\n};\n\nconst getLeftToRightAdapter = function(): RTLAdapter {\n return {\n x(x) {\n return x;\n },\n setWidth(w) { // eslint-disable-line no-unused-vars\n },\n textAlign(align) {\n return align;\n },\n xPlus(x, value) {\n return x + value;\n },\n leftForLtr(x, _itemWidth) { // eslint-disable-line @typescript-eslint/no-unused-vars\n return x;\n },\n };\n};\n\nexport function getRtlAdapter(rtl: boolean, rectX: number, width: number) {\n return rtl ? getRightToLeftAdapter(rectX, width) : getLeftToRightAdapter();\n}\n\nexport function overrideTextDirection(ctx: CanvasRenderingContext2D, direction: 'ltr' | 'rtl') {\n let style: CSSStyleDeclaration, original: [string, string];\n if (direction === 'ltr' || direction === 'rtl') {\n style = ctx.canvas.style;\n original = [\n style.getPropertyValue('direction'),\n style.getPropertyPriority('direction'),\n ];\n\n style.setProperty('direction', direction, 'important');\n (ctx as { prevTextDirection?: [string, string] }).prevTextDirection = original;\n }\n}\n\nexport function restoreTextDirection(ctx: CanvasRenderingContext2D, original?: [string, string]) {\n if (original !== undefined) {\n delete (ctx as { prevTextDirection?: [string, string] }).prevTextDirection;\n ctx.canvas.style.setProperty('direction', original[0], original[1]);\n }\n}\n","import {_angleBetween, _angleDiff, _isBetween, _normalizeAngle} from './helpers.math.js';\nimport {createContext} from './helpers.options.js';\nimport {isPatternOrGradient} from './helpers.color.js';\n\n/**\n * @typedef { import('../elements/element.line.js').default } LineElement\n * @typedef { import('../elements/element.point.js').default } PointElement\n * @typedef {{start: number, end: number, loop: boolean, style?: any}} Segment\n */\n\nfunction propertyFn(property) {\n if (property === 'angle') {\n return {\n between: _angleBetween,\n compare: _angleDiff,\n normalize: _normalizeAngle,\n };\n }\n return {\n between: _isBetween,\n compare: (a, b) => a - b,\n normalize: x => x\n };\n}\n\nfunction normalizeSegment({start, end, count, loop, style}) {\n return {\n start: start % count,\n end: end % count,\n loop: loop && (end - start + 1) % count === 0,\n style\n };\n}\n\nfunction getSegment(segment, points, bounds) {\n const {property, start: startBound, end: endBound} = bounds;\n const {between, normalize} = propertyFn(property);\n const count = points.length;\n // eslint-disable-next-line prefer-const\n let {start, end, loop} = segment;\n let i, ilen;\n\n if (loop) {\n start += count;\n end += count;\n for (i = 0, ilen = count; i < ilen; ++i) {\n if (!between(normalize(points[start % count][property]), startBound, endBound)) {\n break;\n }\n start--;\n end--;\n }\n start %= count;\n end %= count;\n }\n\n if (end < start) {\n end += count;\n }\n return {start, end, loop, style: segment.style};\n}\n\n/**\n * Returns the sub-segment(s) of a line segment that fall in the given bounds\n * @param {object} segment\n * @param {number} segment.start - start index of the segment, referring the points array\n * @param {number} segment.end - end index of the segment, referring the points array\n * @param {boolean} segment.loop - indicates that the segment is a loop\n * @param {object} [segment.style] - segment style\n * @param {PointElement[]} points - the points that this segment refers to\n * @param {object} [bounds]\n * @param {string} bounds.property - the property of a `PointElement` we are bounding. `x`, `y` or `angle`.\n * @param {number} bounds.start - start value of the property\n * @param {number} bounds.end - end value of the property\n * @private\n **/\nexport function _boundSegment(segment, points, bounds) {\n if (!bounds) {\n return [segment];\n }\n\n const {property, start: startBound, end: endBound} = bounds;\n const count = points.length;\n const {compare, between, normalize} = propertyFn(property);\n const {start, end, loop, style} = getSegment(segment, points, bounds);\n\n const result = [];\n let inside = false;\n let subStart = null;\n let value, point, prevValue;\n\n const startIsBefore = () => between(startBound, prevValue, value) && compare(startBound, prevValue) !== 0;\n const endIsBefore = () => compare(endBound, value) === 0 || between(endBound, prevValue, value);\n const shouldStart = () => inside || startIsBefore();\n const shouldStop = () => !inside || endIsBefore();\n\n for (let i = start, prev = start; i <= end; ++i) {\n point = points[i % count];\n\n if (point.skip) {\n continue;\n }\n\n value = normalize(point[property]);\n\n if (value === prevValue) {\n continue;\n }\n\n inside = between(value, startBound, endBound);\n\n if (subStart === null && shouldStart()) {\n subStart = compare(value, startBound) === 0 ? i : prev;\n }\n\n if (subStart !== null && shouldStop()) {\n result.push(normalizeSegment({start: subStart, end: i, loop, count, style}));\n subStart = null;\n }\n prev = i;\n prevValue = value;\n }\n\n if (subStart !== null) {\n result.push(normalizeSegment({start: subStart, end, loop, count, style}));\n }\n\n return result;\n}\n\n\n/**\n * Returns the segments of the line that are inside given bounds\n * @param {LineElement} line\n * @param {object} [bounds]\n * @param {string} bounds.property - the property we are bounding with. `x`, `y` or `angle`.\n * @param {number} bounds.start - start value of the `property`\n * @param {number} bounds.end - end value of the `property`\n * @private\n */\nexport function _boundSegments(line, bounds) {\n const result = [];\n const segments = line.segments;\n\n for (let i = 0; i < segments.length; i++) {\n const sub = _boundSegment(segments[i], line.points, bounds);\n if (sub.length) {\n result.push(...sub);\n }\n }\n return result;\n}\n\n/**\n * Find start and end index of a line.\n */\nfunction findStartAndEnd(points, count, loop, spanGaps) {\n let start = 0;\n let end = count - 1;\n\n if (loop && !spanGaps) {\n // loop and not spanning gaps, first find a gap to start from\n while (start < count && !points[start].skip) {\n start++;\n }\n }\n\n // find first non skipped point (after the first gap possibly)\n while (start < count && points[start].skip) {\n start++;\n }\n\n // if we looped to count, start needs to be 0\n start %= count;\n\n if (loop) {\n // loop will go past count, if start > 0\n end += start;\n }\n\n while (end > start && points[end % count].skip) {\n end--;\n }\n\n // end could be more than count, normalize\n end %= count;\n\n return {start, end};\n}\n\n/**\n * Compute solid segments from Points, when spanGaps === false\n * @param {PointElement[]} points - the points\n * @param {number} start - start index\n * @param {number} max - max index (can go past count on a loop)\n * @param {boolean} loop - boolean indicating that this would be a loop if no gaps are found\n */\nfunction solidSegments(points, start, max, loop) {\n const count = points.length;\n const result = [];\n let last = start;\n let prev = points[start];\n let end;\n\n for (end = start + 1; end <= max; ++end) {\n const cur = points[end % count];\n if (cur.skip || cur.stop) {\n if (!prev.skip) {\n loop = false;\n result.push({start: start % count, end: (end - 1) % count, loop});\n // @ts-ignore\n start = last = cur.stop ? end : null;\n }\n } else {\n last = end;\n if (prev.skip) {\n start = end;\n }\n }\n prev = cur;\n }\n\n if (last !== null) {\n result.push({start: start % count, end: last % count, loop});\n }\n\n return result;\n}\n\n/**\n * Compute the continuous segments that define the whole line\n * There can be skipped points within a segment, if spanGaps is true.\n * @param {LineElement} line\n * @param {object} [segmentOptions]\n * @return {Segment[]}\n * @private\n */\nexport function _computeSegments(line, segmentOptions) {\n const points = line.points;\n const spanGaps = line.options.spanGaps;\n const count = points.length;\n\n if (!count) {\n return [];\n }\n\n const loop = !!line._loop;\n const {start, end} = findStartAndEnd(points, count, loop, spanGaps);\n\n if (spanGaps === true) {\n return splitByStyles(line, [{start, end, loop}], points, segmentOptions);\n }\n\n const max = end < start ? end + count : end;\n const completeLoop = !!line._fullLoop && start === 0 && end === count - 1;\n return splitByStyles(line, solidSegments(points, start, max, completeLoop), points, segmentOptions);\n}\n\n/**\n * @param {Segment[]} segments\n * @param {PointElement[]} points\n * @param {object} [segmentOptions]\n * @return {Segment[]}\n */\nfunction splitByStyles(line, segments, points, segmentOptions) {\n if (!segmentOptions || !segmentOptions.setContext || !points) {\n return segments;\n }\n return doSplitByStyles(line, segments, points, segmentOptions);\n}\n\n/**\n * @param {LineElement} line\n * @param {Segment[]} segments\n * @param {PointElement[]} points\n * @param {object} [segmentOptions]\n * @return {Segment[]}\n */\nfunction doSplitByStyles(line, segments, points, segmentOptions) {\n const chartContext = line._chart.getContext();\n const baseStyle = readStyle(line.options);\n const {_datasetIndex: datasetIndex, options: {spanGaps}} = line;\n const count = points.length;\n const result = [];\n let prevStyle = baseStyle;\n let start = segments[0].start;\n let i = start;\n\n function addStyle(s, e, l, st) {\n const dir = spanGaps ? -1 : 1;\n if (s === e) {\n return;\n }\n // Style can not start/end on a skipped point, adjust indices accordingly\n s += count;\n while (points[s % count].skip) {\n s -= dir;\n }\n while (points[e % count].skip) {\n e += dir;\n }\n if (s % count !== e % count) {\n result.push({start: s % count, end: e % count, loop: l, style: st});\n prevStyle = st;\n start = e % count;\n }\n }\n\n for (const segment of segments) {\n start = spanGaps ? start : segment.start;\n let prev = points[start % count];\n let style;\n for (i = start + 1; i <= segment.end; i++) {\n const pt = points[i % count];\n style = readStyle(segmentOptions.setContext(createContext(chartContext, {\n type: 'segment',\n p0: prev,\n p1: pt,\n p0DataIndex: (i - 1) % count,\n p1DataIndex: i % count,\n datasetIndex\n })));\n if (styleChanged(style, prevStyle)) {\n addStyle(start, i - 1, segment.loop, prevStyle);\n }\n prev = pt;\n prevStyle = style;\n }\n if (start < i - 1) {\n addStyle(start, i - 1, segment.loop, prevStyle);\n }\n }\n\n return result;\n}\n\nfunction readStyle(options) {\n return {\n backgroundColor: options.backgroundColor,\n borderCapStyle: options.borderCapStyle,\n borderDash: options.borderDash,\n borderDashOffset: options.borderDashOffset,\n borderJoinStyle: options.borderJoinStyle,\n borderWidth: options.borderWidth,\n borderColor: options.borderColor\n };\n}\n\nfunction styleChanged(style, prevStyle) {\n if (!prevStyle) {\n return false;\n }\n const cache = [];\n const replacer = function(key, value) {\n if (!isPatternOrGradient(value)) {\n return value;\n }\n if (!cache.includes(value)) {\n cache.push(value);\n }\n return cache.indexOf(value);\n };\n return JSON.stringify(style, replacer) !== JSON.stringify(prevStyle, replacer);\n}\n","import type {Chart, ChartArea, ChartMeta, Scale, TRBL} from '../types/index.js';\n\nfunction getSizeForArea(scale: Scale, chartArea: ChartArea, field: keyof ChartArea) {\n return scale.options.clip ? scale[field] : chartArea[field];\n}\n\nfunction getDatasetArea(meta: ChartMeta, chartArea: ChartArea): TRBL {\n const {xScale, yScale} = meta;\n if (xScale && yScale) {\n return {\n left: getSizeForArea(xScale, chartArea, 'left'),\n right: getSizeForArea(xScale, chartArea, 'right'),\n top: getSizeForArea(yScale, chartArea, 'top'),\n bottom: getSizeForArea(yScale, chartArea, 'bottom')\n };\n }\n return chartArea;\n}\n\nexport function getDatasetClipArea(chart: Chart, meta: ChartMeta): TRBL | false {\n const clip = meta._clip;\n if (clip.disabled) {\n return false;\n }\n const area = getDatasetArea(meta, chart.chartArea);\n\n return {\n left: clip.left === false ? 0 : area.left - (clip.left === true ? 0 : clip.left),\n right: clip.right === false ? chart.width : area.right + (clip.right === true ? 0 : clip.right),\n top: clip.top === false ? 0 : area.top - (clip.top === true ? 0 : clip.top),\n bottom: clip.bottom === false ? chart.height : area.bottom + (clip.bottom === true ? 0 : clip.bottom)\n };\n}\n","import {requestAnimFrame} from '../helpers/helpers.extras.js';\n\n/**\n * @typedef { import('./core.animation.js').default } Animation\n * @typedef { import('./core.controller.js').default } Chart\n */\n\n/**\n * Please use the module's default export which provides a singleton instance\n * Note: class is export for typedoc\n */\nexport class Animator {\n constructor() {\n this._request = null;\n this._charts = new Map();\n this._running = false;\n this._lastDate = undefined;\n }\n\n /**\n\t * @private\n\t */\n _notify(chart, anims, date, type) {\n const callbacks = anims.listeners[type];\n const numSteps = anims.duration;\n\n callbacks.forEach(fn => fn({\n chart,\n initial: anims.initial,\n numSteps,\n currentStep: Math.min(date - anims.start, numSteps)\n }));\n }\n\n /**\n\t * @private\n\t */\n _refresh() {\n if (this._request) {\n return;\n }\n this._running = true;\n\n this._request = requestAnimFrame.call(window, () => {\n this._update();\n this._request = null;\n\n if (this._running) {\n this._refresh();\n }\n });\n }\n\n /**\n\t * @private\n\t */\n _update(date = Date.now()) {\n let remaining = 0;\n\n this._charts.forEach((anims, chart) => {\n if (!anims.running || !anims.items.length) {\n return;\n }\n const items = anims.items;\n let i = items.length - 1;\n let draw = false;\n let item;\n\n for (; i >= 0; --i) {\n item = items[i];\n\n if (item._active) {\n if (item._total > anims.duration) {\n // if the animation has been updated and its duration prolonged,\n // update to total duration of current animations run (for progress event)\n anims.duration = item._total;\n }\n item.tick(date);\n draw = true;\n } else {\n // Remove the item by replacing it with last item and removing the last\n // A lot faster than splice.\n items[i] = items[items.length - 1];\n items.pop();\n }\n }\n\n if (draw) {\n chart.draw();\n this._notify(chart, anims, date, 'progress');\n }\n\n if (!items.length) {\n anims.running = false;\n this._notify(chart, anims, date, 'complete');\n anims.initial = false;\n }\n\n remaining += items.length;\n });\n\n this._lastDate = date;\n\n if (remaining === 0) {\n this._running = false;\n }\n }\n\n /**\n\t * @private\n\t */\n _getAnims(chart) {\n const charts = this._charts;\n let anims = charts.get(chart);\n if (!anims) {\n anims = {\n running: false,\n initial: true,\n items: [],\n listeners: {\n complete: [],\n progress: []\n }\n };\n charts.set(chart, anims);\n }\n return anims;\n }\n\n /**\n\t * @param {Chart} chart\n\t * @param {string} event - event name\n\t * @param {Function} cb - callback\n\t */\n listen(chart, event, cb) {\n this._getAnims(chart).listeners[event].push(cb);\n }\n\n /**\n\t * Add animations\n\t * @param {Chart} chart\n\t * @param {Animation[]} items - animations\n\t */\n add(chart, items) {\n if (!items || !items.length) {\n return;\n }\n this._getAnims(chart).items.push(...items);\n }\n\n /**\n\t * Counts number of active animations for the chart\n\t * @param {Chart} chart\n\t */\n has(chart) {\n return this._getAnims(chart).items.length > 0;\n }\n\n /**\n\t * Start animating (all charts)\n\t * @param {Chart} chart\n\t */\n start(chart) {\n const anims = this._charts.get(chart);\n if (!anims) {\n return;\n }\n anims.running = true;\n anims.start = Date.now();\n anims.duration = anims.items.reduce((acc, cur) => Math.max(acc, cur._duration), 0);\n this._refresh();\n }\n\n running(chart) {\n if (!this._running) {\n return false;\n }\n const anims = this._charts.get(chart);\n if (!anims || !anims.running || !anims.items.length) {\n return false;\n }\n return true;\n }\n\n /**\n\t * Stop all animations for the chart\n\t * @param {Chart} chart\n\t */\n stop(chart) {\n const anims = this._charts.get(chart);\n if (!anims || !anims.items.length) {\n return;\n }\n const items = anims.items;\n let i = items.length - 1;\n\n for (; i >= 0; --i) {\n items[i].cancel();\n }\n anims.items = [];\n this._notify(chart, anims, Date.now(), 'complete');\n }\n\n /**\n\t * Remove chart from Animator\n\t * @param {Chart} chart\n\t */\n remove(chart) {\n return this._charts.delete(chart);\n }\n}\n\n// singleton instance\nexport default /* #__PURE__ */ new Animator();\n","import effects from '../helpers/helpers.easing.js';\nimport {resolve} from '../helpers/helpers.options.js';\nimport {color as helpersColor} from '../helpers/helpers.color.js';\n\nconst transparent = 'transparent';\nconst interpolators = {\n boolean(from, to, factor) {\n return factor > 0.5 ? to : from;\n },\n /**\n * @param {string} from\n * @param {string} to\n * @param {number} factor\n */\n color(from, to, factor) {\n const c0 = helpersColor(from || transparent);\n const c1 = c0.valid && helpersColor(to || transparent);\n return c1 && c1.valid\n ? c1.mix(c0, factor).hexString()\n : to;\n },\n number(from, to, factor) {\n return from + (to - from) * factor;\n }\n};\n\nexport default class Animation {\n constructor(cfg, target, prop, to) {\n const currentValue = target[prop];\n\n to = resolve([cfg.to, to, currentValue, cfg.from]);\n const from = resolve([cfg.from, currentValue, to]);\n\n this._active = true;\n this._fn = cfg.fn || interpolators[cfg.type || typeof from];\n this._easing = effects[cfg.easing] || effects.linear;\n this._start = Math.floor(Date.now() + (cfg.delay || 0));\n this._duration = this._total = Math.floor(cfg.duration);\n this._loop = !!cfg.loop;\n this._target = target;\n this._prop = prop;\n this._from = from;\n this._to = to;\n this._promises = undefined;\n }\n\n active() {\n return this._active;\n }\n\n update(cfg, to, date) {\n if (this._active) {\n this._notify(false);\n\n const currentValue = this._target[this._prop];\n const elapsed = date - this._start;\n const remain = this._duration - elapsed;\n this._start = date;\n this._duration = Math.floor(Math.max(remain, cfg.duration));\n this._total += elapsed;\n this._loop = !!cfg.loop;\n this._to = resolve([cfg.to, to, currentValue, cfg.from]);\n this._from = resolve([cfg.from, currentValue, to]);\n }\n }\n\n cancel() {\n if (this._active) {\n // update current evaluated value, for smoother animations\n this.tick(Date.now());\n this._active = false;\n this._notify(false);\n }\n }\n\n tick(date) {\n const elapsed = date - this._start;\n const duration = this._duration;\n const prop = this._prop;\n const from = this._from;\n const loop = this._loop;\n const to = this._to;\n let factor;\n\n this._active = from !== to && (loop || (elapsed < duration));\n\n if (!this._active) {\n this._target[prop] = to;\n this._notify(true);\n return;\n }\n\n if (elapsed < 0) {\n this._target[prop] = from;\n return;\n }\n\n factor = (elapsed / duration) % 2;\n factor = loop && factor > 1 ? 2 - factor : factor;\n factor = this._easing(Math.min(1, Math.max(0, factor)));\n\n this._target[prop] = this._fn(from, to, factor);\n }\n\n wait() {\n const promises = this._promises || (this._promises = []);\n return new Promise((res, rej) => {\n promises.push({res, rej});\n });\n }\n\n _notify(resolved) {\n const method = resolved ? 'res' : 'rej';\n const promises = this._promises || [];\n for (let i = 0; i < promises.length; i++) {\n promises[i][method]();\n }\n }\n}\n","import animator from './core.animator.js';\nimport Animation from './core.animation.js';\nimport defaults from './core.defaults.js';\nimport {isArray, isObject} from '../helpers/helpers.core.js';\n\nexport default class Animations {\n constructor(chart, config) {\n this._chart = chart;\n this._properties = new Map();\n this.configure(config);\n }\n\n configure(config) {\n if (!isObject(config)) {\n return;\n }\n\n const animationOptions = Object.keys(defaults.animation);\n const animatedProps = this._properties;\n\n Object.getOwnPropertyNames(config).forEach(key => {\n const cfg = config[key];\n if (!isObject(cfg)) {\n return;\n }\n const resolved = {};\n for (const option of animationOptions) {\n resolved[option] = cfg[option];\n }\n\n (isArray(cfg.properties) && cfg.properties || [key]).forEach((prop) => {\n if (prop === key || !animatedProps.has(prop)) {\n animatedProps.set(prop, resolved);\n }\n });\n });\n }\n\n /**\n\t * Utility to handle animation of `options`.\n\t * @private\n\t */\n _animateOptions(target, values) {\n const newOptions = values.options;\n const options = resolveTargetOptions(target, newOptions);\n if (!options) {\n return [];\n }\n\n const animations = this._createAnimations(options, newOptions);\n if (newOptions.$shared) {\n // Going to shared options:\n // After all animations are done, assign the shared options object to the element\n // So any new updates to the shared options are observed\n awaitAll(target.options.$animations, newOptions).then(() => {\n target.options = newOptions;\n }, () => {\n // rejected, noop\n });\n }\n\n return animations;\n }\n\n /**\n\t * @private\n\t */\n _createAnimations(target, values) {\n const animatedProps = this._properties;\n const animations = [];\n const running = target.$animations || (target.$animations = {});\n const props = Object.keys(values);\n const date = Date.now();\n let i;\n\n for (i = props.length - 1; i >= 0; --i) {\n const prop = props[i];\n if (prop.charAt(0) === '$') {\n continue;\n }\n\n if (prop === 'options') {\n animations.push(...this._animateOptions(target, values));\n continue;\n }\n const value = values[prop];\n let animation = running[prop];\n const cfg = animatedProps.get(prop);\n\n if (animation) {\n if (cfg && animation.active()) {\n // There is an existing active animation, let's update that\n animation.update(cfg, value, date);\n continue;\n } else {\n animation.cancel();\n }\n }\n if (!cfg || !cfg.duration) {\n // not animated, set directly to new value\n target[prop] = value;\n continue;\n }\n\n running[prop] = animation = new Animation(cfg, target, prop, value);\n animations.push(animation);\n }\n return animations;\n }\n\n\n /**\n\t * Update `target` properties to new values, using configured animations\n\t * @param {object} target - object to update\n\t * @param {object} values - new target properties\n\t * @returns {boolean|undefined} - `true` if animations were started\n\t **/\n update(target, values) {\n if (this._properties.size === 0) {\n // Nothing is animated, just apply the new values.\n Object.assign(target, values);\n return;\n }\n\n const animations = this._createAnimations(target, values);\n\n if (animations.length) {\n animator.add(this._chart, animations);\n return true;\n }\n }\n}\n\nfunction awaitAll(animations, properties) {\n const running = [];\n const keys = Object.keys(properties);\n for (let i = 0; i < keys.length; i++) {\n const anim = animations[keys[i]];\n if (anim && anim.active()) {\n running.push(anim.wait());\n }\n }\n // @ts-ignore\n return Promise.all(running);\n}\n\nfunction resolveTargetOptions(target, newOptions) {\n if (!newOptions) {\n return;\n }\n let options = target.options;\n if (!options) {\n target.options = newOptions;\n return;\n }\n if (options.$shared) {\n // Going from shared options to distinct one:\n // Create new options object containing the old shared values and start updating that.\n target.options = options = Object.assign({}, options, {$shared: false, $animations: {}});\n }\n return options;\n}\n","import Animations from './core.animations.js';\nimport defaults from './core.defaults.js';\nimport {isArray, isFinite, isObject, valueOrDefault, resolveObjectKey, defined} from '../helpers/helpers.core.js';\nimport {listenArrayEvents, unlistenArrayEvents} from '../helpers/helpers.collection.js';\nimport {createContext, sign} from '../helpers/index.js';\n\n/**\n * @typedef { import('./core.controller.js').default } Chart\n * @typedef { import('./core.scale.js').default } Scale\n */\n\nfunction scaleClip(scale, allowedOverflow) {\n const opts = scale && scale.options || {};\n const reverse = opts.reverse;\n const min = opts.min === undefined ? allowedOverflow : 0;\n const max = opts.max === undefined ? allowedOverflow : 0;\n return {\n start: reverse ? max : min,\n end: reverse ? min : max\n };\n}\n\nfunction defaultClip(xScale, yScale, allowedOverflow) {\n if (allowedOverflow === false) {\n return false;\n }\n const x = scaleClip(xScale, allowedOverflow);\n const y = scaleClip(yScale, allowedOverflow);\n\n return {\n top: y.end,\n right: x.end,\n bottom: y.start,\n left: x.start\n };\n}\n\nfunction toClip(value) {\n let t, r, b, l;\n\n if (isObject(value)) {\n t = value.top;\n r = value.right;\n b = value.bottom;\n l = value.left;\n } else {\n t = r = b = l = value;\n }\n\n return {\n top: t,\n right: r,\n bottom: b,\n left: l,\n disabled: value === false\n };\n}\n\nfunction getSortedDatasetIndices(chart, filterVisible) {\n const keys = [];\n const metasets = chart._getSortedDatasetMetas(filterVisible);\n let i, ilen;\n\n for (i = 0, ilen = metasets.length; i < ilen; ++i) {\n keys.push(metasets[i].index);\n }\n return keys;\n}\n\nfunction applyStack(stack, value, dsIndex, options = {}) {\n const keys = stack.keys;\n const singleMode = options.mode === 'single';\n let i, ilen, datasetIndex, otherValue;\n\n if (value === null) {\n return;\n }\n\n let found = false;\n for (i = 0, ilen = keys.length; i < ilen; ++i) {\n datasetIndex = +keys[i];\n if (datasetIndex === dsIndex) {\n found = true;\n if (options.all) {\n continue;\n }\n break;\n }\n otherValue = stack.values[datasetIndex];\n if (isFinite(otherValue) && (singleMode || (value === 0 || sign(value) === sign(otherValue)))) {\n value += otherValue;\n }\n }\n\n if (!found && !options.all) {\n return 0;\n }\n\n return value;\n}\n\nfunction convertObjectDataToArray(data, meta) {\n const {iScale, vScale} = meta;\n const iAxisKey = iScale.axis === 'x' ? 'x' : 'y';\n const vAxisKey = vScale.axis === 'x' ? 'x' : 'y';\n const keys = Object.keys(data);\n const adata = new Array(keys.length);\n let i, ilen, key;\n for (i = 0, ilen = keys.length; i < ilen; ++i) {\n key = keys[i];\n adata[i] = {\n [iAxisKey]: key,\n [vAxisKey]: data[key]\n };\n }\n return adata;\n}\n\nfunction isStacked(scale, meta) {\n const stacked = scale && scale.options.stacked;\n return stacked || (stacked === undefined && meta.stack !== undefined);\n}\n\nfunction getStackKey(indexScale, valueScale, meta) {\n return `${indexScale.id}.${valueScale.id}.${meta.stack || meta.type}`;\n}\n\nfunction getUserBounds(scale) {\n const {min, max, minDefined, maxDefined} = scale.getUserBounds();\n return {\n min: minDefined ? min : Number.NEGATIVE_INFINITY,\n max: maxDefined ? max : Number.POSITIVE_INFINITY\n };\n}\n\nfunction getOrCreateStack(stacks, stackKey, indexValue) {\n const subStack = stacks[stackKey] || (stacks[stackKey] = {});\n return subStack[indexValue] || (subStack[indexValue] = {});\n}\n\nfunction getLastIndexInStack(stack, vScale, positive, type) {\n for (const meta of vScale.getMatchingVisibleMetas(type).reverse()) {\n const value = stack[meta.index];\n if ((positive && value > 0) || (!positive && value < 0)) {\n return meta.index;\n }\n }\n\n return null;\n}\n\nfunction updateStacks(controller, parsed) {\n const {chart, _cachedMeta: meta} = controller;\n const stacks = chart._stacks || (chart._stacks = {}); // map structure is {stackKey: {datasetIndex: value}}\n const {iScale, vScale, index: datasetIndex} = meta;\n const iAxis = iScale.axis;\n const vAxis = vScale.axis;\n const key = getStackKey(iScale, vScale, meta);\n const ilen = parsed.length;\n let stack;\n\n for (let i = 0; i < ilen; ++i) {\n const item = parsed[i];\n const {[iAxis]: index, [vAxis]: value} = item;\n const itemStacks = item._stacks || (item._stacks = {});\n stack = itemStacks[vAxis] = getOrCreateStack(stacks, key, index);\n stack[datasetIndex] = value;\n\n stack._top = getLastIndexInStack(stack, vScale, true, meta.type);\n stack._bottom = getLastIndexInStack(stack, vScale, false, meta.type);\n\n const visualValues = stack._visualValues || (stack._visualValues = {});\n visualValues[datasetIndex] = value;\n }\n}\n\nfunction getFirstScaleId(chart, axis) {\n const scales = chart.scales;\n return Object.keys(scales).filter(key => scales[key].axis === axis).shift();\n}\n\nfunction createDatasetContext(parent, index) {\n return createContext(parent,\n {\n active: false,\n dataset: undefined,\n datasetIndex: index,\n index,\n mode: 'default',\n type: 'dataset'\n }\n );\n}\n\nfunction createDataContext(parent, index, element) {\n return createContext(parent, {\n active: false,\n dataIndex: index,\n parsed: undefined,\n raw: undefined,\n element,\n index,\n mode: 'default',\n type: 'data'\n });\n}\n\nfunction clearStacks(meta, items) {\n // Not using meta.index here, because it might be already updated if the dataset changed location\n const datasetIndex = meta.controller.index;\n const axis = meta.vScale && meta.vScale.axis;\n if (!axis) {\n return;\n }\n\n items = items || meta._parsed;\n for (const parsed of items) {\n const stacks = parsed._stacks;\n if (!stacks || stacks[axis] === undefined || stacks[axis][datasetIndex] === undefined) {\n return;\n }\n delete stacks[axis][datasetIndex];\n if (stacks[axis]._visualValues !== undefined && stacks[axis]._visualValues[datasetIndex] !== undefined) {\n delete stacks[axis]._visualValues[datasetIndex];\n }\n }\n}\n\nconst isDirectUpdateMode = (mode) => mode === 'reset' || mode === 'none';\nconst cloneIfNotShared = (cached, shared) => shared ? cached : Object.assign({}, cached);\nconst createStack = (canStack, meta, chart) => canStack && !meta.hidden && meta._stacked\n && {keys: getSortedDatasetIndices(chart, true), values: null};\n\nexport default class DatasetController {\n\n /**\n * @type {any}\n */\n static defaults = {};\n\n /**\n * Element type used to generate a meta dataset (e.g. Chart.element.LineElement).\n */\n static datasetElementType = null;\n\n /**\n * Element type used to generate a meta data (e.g. Chart.element.PointElement).\n */\n static dataElementType = null;\n\n /**\n\t * @param {Chart} chart\n\t * @param {number} datasetIndex\n\t */\n constructor(chart, datasetIndex) {\n this.chart = chart;\n this._ctx = chart.ctx;\n this.index = datasetIndex;\n this._cachedDataOpts = {};\n this._cachedMeta = this.getMeta();\n this._type = this._cachedMeta.type;\n this.options = undefined;\n /** @type {boolean | object} */\n this._parsing = false;\n this._data = undefined;\n this._objectData = undefined;\n this._sharedOptions = undefined;\n this._drawStart = undefined;\n this._drawCount = undefined;\n this.enableOptionSharing = false;\n this.supportsDecimation = false;\n this.$context = undefined;\n this._syncList = [];\n this.datasetElementType = new.target.datasetElementType;\n this.dataElementType = new.target.dataElementType;\n\n this.initialize();\n }\n\n initialize() {\n const meta = this._cachedMeta;\n this.configure();\n this.linkScales();\n meta._stacked = isStacked(meta.vScale, meta);\n this.addElements();\n\n if (this.options.fill && !this.chart.isPluginEnabled('filler')) {\n console.warn(\"Tried to use the 'fill' option without the 'Filler' plugin enabled. Please import and register the 'Filler' plugin and make sure it is not disabled in the options\");\n }\n }\n\n updateIndex(datasetIndex) {\n if (this.index !== datasetIndex) {\n clearStacks(this._cachedMeta);\n }\n this.index = datasetIndex;\n }\n\n linkScales() {\n const chart = this.chart;\n const meta = this._cachedMeta;\n const dataset = this.getDataset();\n\n const chooseId = (axis, x, y, r) => axis === 'x' ? x : axis === 'r' ? r : y;\n\n const xid = meta.xAxisID = valueOrDefault(dataset.xAxisID, getFirstScaleId(chart, 'x'));\n const yid = meta.yAxisID = valueOrDefault(dataset.yAxisID, getFirstScaleId(chart, 'y'));\n const rid = meta.rAxisID = valueOrDefault(dataset.rAxisID, getFirstScaleId(chart, 'r'));\n const indexAxis = meta.indexAxis;\n const iid = meta.iAxisID = chooseId(indexAxis, xid, yid, rid);\n const vid = meta.vAxisID = chooseId(indexAxis, yid, xid, rid);\n meta.xScale = this.getScaleForId(xid);\n meta.yScale = this.getScaleForId(yid);\n meta.rScale = this.getScaleForId(rid);\n meta.iScale = this.getScaleForId(iid);\n meta.vScale = this.getScaleForId(vid);\n }\n\n getDataset() {\n return this.chart.data.datasets[this.index];\n }\n\n getMeta() {\n return this.chart.getDatasetMeta(this.index);\n }\n\n /**\n\t * @param {string} scaleID\n\t * @return {Scale}\n\t */\n getScaleForId(scaleID) {\n return this.chart.scales[scaleID];\n }\n\n /**\n\t * @private\n\t */\n _getOtherScale(scale) {\n const meta = this._cachedMeta;\n return scale === meta.iScale\n ? meta.vScale\n : meta.iScale;\n }\n\n reset() {\n this._update('reset');\n }\n\n /**\n\t * @private\n\t */\n _destroy() {\n const meta = this._cachedMeta;\n if (this._data) {\n unlistenArrayEvents(this._data, this);\n }\n if (meta._stacked) {\n clearStacks(meta);\n }\n }\n\n /**\n\t * @private\n\t */\n _dataCheck() {\n const dataset = this.getDataset();\n const data = dataset.data || (dataset.data = []);\n const _data = this._data;\n\n // In order to correctly handle data addition/deletion animation (and thus simulate\n // real-time charts), we need to monitor these data modifications and synchronize\n // the internal metadata accordingly.\n\n if (isObject(data)) {\n const meta = this._cachedMeta;\n this._data = convertObjectDataToArray(data, meta);\n } else if (_data !== data) {\n if (_data) {\n // This case happens when the user replaced the data array instance.\n unlistenArrayEvents(_data, this);\n // Discard old parsed data and stacks\n const meta = this._cachedMeta;\n clearStacks(meta);\n meta._parsed = [];\n }\n if (data && Object.isExtensible(data)) {\n listenArrayEvents(data, this);\n }\n this._syncList = [];\n this._data = data;\n }\n }\n\n addElements() {\n const meta = this._cachedMeta;\n\n this._dataCheck();\n\n if (this.datasetElementType) {\n meta.dataset = new this.datasetElementType();\n }\n }\n\n buildOrUpdateElements(resetNewElements) {\n const meta = this._cachedMeta;\n const dataset = this.getDataset();\n let stackChanged = false;\n\n this._dataCheck();\n\n // make sure cached _stacked status is current\n const oldStacked = meta._stacked;\n meta._stacked = isStacked(meta.vScale, meta);\n\n // detect change in stack option\n if (meta.stack !== dataset.stack) {\n stackChanged = true;\n // remove values from old stack\n clearStacks(meta);\n meta.stack = dataset.stack;\n }\n\n // Re-sync meta data in case the user replaced the data array or if we missed\n // any updates and so make sure that we handle number of datapoints changing.\n this._resyncElements(resetNewElements);\n\n // if stack changed, update stack values for the whole dataset\n if (stackChanged || oldStacked !== meta._stacked) {\n updateStacks(this, meta._parsed);\n meta._stacked = isStacked(meta.vScale, meta);\n }\n }\n\n /**\n\t * Merges user-supplied and default dataset-level options\n\t * @private\n\t */\n configure() {\n const config = this.chart.config;\n const scopeKeys = config.datasetScopeKeys(this._type);\n const scopes = config.getOptionScopes(this.getDataset(), scopeKeys, true);\n this.options = config.createResolver(scopes, this.getContext());\n this._parsing = this.options.parsing;\n this._cachedDataOpts = {};\n }\n\n /**\n\t * @param {number} start\n\t * @param {number} count\n\t */\n parse(start, count) {\n const {_cachedMeta: meta, _data: data} = this;\n const {iScale, _stacked} = meta;\n const iAxis = iScale.axis;\n\n let sorted = start === 0 && count === data.length ? true : meta._sorted;\n let prev = start > 0 && meta._parsed[start - 1];\n let i, cur, parsed;\n\n if (this._parsing === false) {\n meta._parsed = data;\n meta._sorted = true;\n parsed = data;\n } else {\n if (isArray(data[start])) {\n parsed = this.parseArrayData(meta, data, start, count);\n } else if (isObject(data[start])) {\n parsed = this.parseObjectData(meta, data, start, count);\n } else {\n parsed = this.parsePrimitiveData(meta, data, start, count);\n }\n\n const isNotInOrderComparedToPrev = () => cur[iAxis] === null || (prev && cur[iAxis] < prev[iAxis]);\n for (i = 0; i < count; ++i) {\n meta._parsed[i + start] = cur = parsed[i];\n if (sorted) {\n if (isNotInOrderComparedToPrev()) {\n sorted = false;\n }\n prev = cur;\n }\n }\n meta._sorted = sorted;\n }\n\n if (_stacked) {\n updateStacks(this, parsed);\n }\n }\n\n /**\n\t * Parse array of primitive values\n\t * @param {object} meta - dataset meta\n\t * @param {array} data - data array. Example [1,3,4]\n\t * @param {number} start - start index\n\t * @param {number} count - number of items to parse\n\t * @returns {object} parsed item - item containing index and a parsed value\n\t * for each scale id.\n\t * Example: {xScale0: 0, yScale0: 1}\n\t * @protected\n\t */\n parsePrimitiveData(meta, data, start, count) {\n const {iScale, vScale} = meta;\n const iAxis = iScale.axis;\n const vAxis = vScale.axis;\n const labels = iScale.getLabels();\n const singleScale = iScale === vScale;\n const parsed = new Array(count);\n let i, ilen, index;\n\n for (i = 0, ilen = count; i < ilen; ++i) {\n index = i + start;\n parsed[i] = {\n [iAxis]: singleScale || iScale.parse(labels[index], index),\n [vAxis]: vScale.parse(data[index], index)\n };\n }\n return parsed;\n }\n\n /**\n\t * Parse array of arrays\n\t * @param {object} meta - dataset meta\n\t * @param {array} data - data array. Example [[1,2],[3,4]]\n\t * @param {number} start - start index\n\t * @param {number} count - number of items to parse\n\t * @returns {object} parsed item - item containing index and a parsed value\n\t * for each scale id.\n\t * Example: {x: 0, y: 1}\n\t * @protected\n\t */\n parseArrayData(meta, data, start, count) {\n const {xScale, yScale} = meta;\n const parsed = new Array(count);\n let i, ilen, index, item;\n\n for (i = 0, ilen = count; i < ilen; ++i) {\n index = i + start;\n item = data[index];\n parsed[i] = {\n x: xScale.parse(item[0], index),\n y: yScale.parse(item[1], index)\n };\n }\n return parsed;\n }\n\n /**\n\t * Parse array of objects\n\t * @param {object} meta - dataset meta\n\t * @param {array} data - data array. Example [{x:1, y:5}, {x:2, y:10}]\n\t * @param {number} start - start index\n\t * @param {number} count - number of items to parse\n\t * @returns {object} parsed item - item containing index and a parsed value\n\t * for each scale id. _custom is optional\n\t * Example: {xScale0: 0, yScale0: 1, _custom: {r: 10, foo: 'bar'}}\n\t * @protected\n\t */\n parseObjectData(meta, data, start, count) {\n const {xScale, yScale} = meta;\n const {xAxisKey = 'x', yAxisKey = 'y'} = this._parsing;\n const parsed = new Array(count);\n let i, ilen, index, item;\n\n for (i = 0, ilen = count; i < ilen; ++i) {\n index = i + start;\n item = data[index];\n parsed[i] = {\n x: xScale.parse(resolveObjectKey(item, xAxisKey), index),\n y: yScale.parse(resolveObjectKey(item, yAxisKey), index)\n };\n }\n return parsed;\n }\n\n /**\n\t * @protected\n\t */\n getParsed(index) {\n return this._cachedMeta._parsed[index];\n }\n\n /**\n\t * @protected\n\t */\n getDataElement(index) {\n return this._cachedMeta.data[index];\n }\n\n /**\n\t * @protected\n\t */\n applyStack(scale, parsed, mode) {\n const chart = this.chart;\n const meta = this._cachedMeta;\n const value = parsed[scale.axis];\n const stack = {\n keys: getSortedDatasetIndices(chart, true),\n values: parsed._stacks[scale.axis]._visualValues\n };\n return applyStack(stack, value, meta.index, {mode});\n }\n\n /**\n\t * @protected\n\t */\n updateRangeFromParsed(range, scale, parsed, stack) {\n const parsedValue = parsed[scale.axis];\n let value = parsedValue === null ? NaN : parsedValue;\n const values = stack && parsed._stacks[scale.axis];\n if (stack && values) {\n stack.values = values;\n value = applyStack(stack, parsedValue, this._cachedMeta.index);\n }\n range.min = Math.min(range.min, value);\n range.max = Math.max(range.max, value);\n }\n\n /**\n\t * @protected\n\t */\n getMinMax(scale, canStack) {\n const meta = this._cachedMeta;\n const _parsed = meta._parsed;\n const sorted = meta._sorted && scale === meta.iScale;\n const ilen = _parsed.length;\n const otherScale = this._getOtherScale(scale);\n const stack = createStack(canStack, meta, this.chart);\n const range = {min: Number.POSITIVE_INFINITY, max: Number.NEGATIVE_INFINITY};\n const {min: otherMin, max: otherMax} = getUserBounds(otherScale);\n let i, parsed;\n\n function _skip() {\n parsed = _parsed[i];\n const otherValue = parsed[otherScale.axis];\n return !isFinite(parsed[scale.axis]) || otherMin > otherValue || otherMax < otherValue;\n }\n\n for (i = 0; i < ilen; ++i) {\n if (_skip()) {\n continue;\n }\n this.updateRangeFromParsed(range, scale, parsed, stack);\n if (sorted) {\n // if the data is sorted, we don't need to check further from this end of array\n break;\n }\n }\n if (sorted) {\n // in the sorted case, find first non-skipped value from other end of array\n for (i = ilen - 1; i >= 0; --i) {\n if (_skip()) {\n continue;\n }\n this.updateRangeFromParsed(range, scale, parsed, stack);\n break;\n }\n }\n return range;\n }\n\n getAllParsedValues(scale) {\n const parsed = this._cachedMeta._parsed;\n const values = [];\n let i, ilen, value;\n\n for (i = 0, ilen = parsed.length; i < ilen; ++i) {\n value = parsed[i][scale.axis];\n if (isFinite(value)) {\n values.push(value);\n }\n }\n return values;\n }\n\n /**\n\t * @return {number|boolean}\n\t * @protected\n\t */\n getMaxOverflow() {\n return false;\n }\n\n /**\n\t * @protected\n\t */\n getLabelAndValue(index) {\n const meta = this._cachedMeta;\n const iScale = meta.iScale;\n const vScale = meta.vScale;\n const parsed = this.getParsed(index);\n return {\n label: iScale ? '' + iScale.getLabelForValue(parsed[iScale.axis]) : '',\n value: vScale ? '' + vScale.getLabelForValue(parsed[vScale.axis]) : ''\n };\n }\n\n /**\n\t * @private\n\t */\n _update(mode) {\n const meta = this._cachedMeta;\n this.update(mode || 'default');\n meta._clip = toClip(valueOrDefault(this.options.clip, defaultClip(meta.xScale, meta.yScale, this.getMaxOverflow())));\n }\n\n /**\n\t * @param {string} mode\n\t */\n update(mode) {} // eslint-disable-line no-unused-vars\n\n draw() {\n const ctx = this._ctx;\n const chart = this.chart;\n const meta = this._cachedMeta;\n const elements = meta.data || [];\n const area = chart.chartArea;\n const active = [];\n const start = this._drawStart || 0;\n const count = this._drawCount || (elements.length - start);\n const drawActiveElementsOnTop = this.options.drawActiveElementsOnTop;\n let i;\n\n if (meta.dataset) {\n meta.dataset.draw(ctx, area, start, count);\n }\n\n for (i = start; i < start + count; ++i) {\n const element = elements[i];\n if (element.hidden) {\n continue;\n }\n if (element.active && drawActiveElementsOnTop) {\n active.push(element);\n } else {\n element.draw(ctx, area);\n }\n }\n\n for (i = 0; i < active.length; ++i) {\n active[i].draw(ctx, area);\n }\n }\n\n /**\n\t * Returns a set of predefined style properties that should be used to represent the dataset\n\t * or the data if the index is specified\n\t * @param {number} index - data index\n\t * @param {boolean} [active] - true if hover\n\t * @return {object} style object\n\t */\n getStyle(index, active) {\n const mode = active ? 'active' : 'default';\n return index === undefined && this._cachedMeta.dataset\n ? this.resolveDatasetElementOptions(mode)\n : this.resolveDataElementOptions(index || 0, mode);\n }\n\n /**\n\t * @protected\n\t */\n getContext(index, active, mode) {\n const dataset = this.getDataset();\n let context;\n if (index >= 0 && index < this._cachedMeta.data.length) {\n const element = this._cachedMeta.data[index];\n context = element.$context ||\n (element.$context = createDataContext(this.getContext(), index, element));\n context.parsed = this.getParsed(index);\n context.raw = dataset.data[index];\n context.index = context.dataIndex = index;\n } else {\n context = this.$context ||\n (this.$context = createDatasetContext(this.chart.getContext(), this.index));\n context.dataset = dataset;\n context.index = context.datasetIndex = this.index;\n }\n\n context.active = !!active;\n context.mode = mode;\n return context;\n }\n\n /**\n\t * @param {string} [mode]\n\t * @protected\n\t */\n resolveDatasetElementOptions(mode) {\n return this._resolveElementOptions(this.datasetElementType.id, mode);\n }\n\n /**\n\t * @param {number} index\n\t * @param {string} [mode]\n\t * @protected\n\t */\n resolveDataElementOptions(index, mode) {\n return this._resolveElementOptions(this.dataElementType.id, mode, index);\n }\n\n /**\n\t * @private\n\t */\n _resolveElementOptions(elementType, mode = 'default', index) {\n const active = mode === 'active';\n const cache = this._cachedDataOpts;\n const cacheKey = elementType + '-' + mode;\n const cached = cache[cacheKey];\n const sharing = this.enableOptionSharing && defined(index);\n if (cached) {\n return cloneIfNotShared(cached, sharing);\n }\n const config = this.chart.config;\n const scopeKeys = config.datasetElementScopeKeys(this._type, elementType);\n const prefixes = active ? [`${elementType}Hover`, 'hover', elementType, ''] : [elementType, ''];\n const scopes = config.getOptionScopes(this.getDataset(), scopeKeys);\n const names = Object.keys(defaults.elements[elementType]);\n // context is provided as a function, and is called only if needed,\n // so we don't create a context for each element if not needed.\n const context = () => this.getContext(index, active, mode);\n const values = config.resolveNamedOptions(scopes, names, context, prefixes);\n\n if (values.$shared) {\n // `$shared` indicates this set of options can be shared between multiple elements.\n // Sharing is used to reduce number of properties to change during animation.\n values.$shared = sharing;\n\n // We cache options by `mode`, which can be 'active' for example. This enables us\n // to have the 'active' element options and 'default' options to switch between\n // when interacting.\n cache[cacheKey] = Object.freeze(cloneIfNotShared(values, sharing));\n }\n\n return values;\n }\n\n\n /**\n\t * @private\n\t */\n _resolveAnimations(index, transition, active) {\n const chart = this.chart;\n const cache = this._cachedDataOpts;\n const cacheKey = `animation-${transition}`;\n const cached = cache[cacheKey];\n if (cached) {\n return cached;\n }\n let options;\n if (chart.options.animation !== false) {\n const config = this.chart.config;\n const scopeKeys = config.datasetAnimationScopeKeys(this._type, transition);\n const scopes = config.getOptionScopes(this.getDataset(), scopeKeys);\n options = config.createResolver(scopes, this.getContext(index, active, transition));\n }\n const animations = new Animations(chart, options && options.animations);\n if (options && options._cacheable) {\n cache[cacheKey] = Object.freeze(animations);\n }\n return animations;\n }\n\n /**\n\t * Utility for getting the options object shared between elements\n\t * @protected\n\t */\n getSharedOptions(options) {\n if (!options.$shared) {\n return;\n }\n return this._sharedOptions || (this._sharedOptions = Object.assign({}, options));\n }\n\n /**\n\t * Utility for determining if `options` should be included in the updated properties\n\t * @protected\n\t */\n includeOptions(mode, sharedOptions) {\n return !sharedOptions || isDirectUpdateMode(mode) || this.chart._animationsDisabled;\n }\n\n /**\n * @todo v4, rename to getSharedOptions and remove excess functions\n */\n _getSharedOptions(start, mode) {\n const firstOpts = this.resolveDataElementOptions(start, mode);\n const previouslySharedOptions = this._sharedOptions;\n const sharedOptions = this.getSharedOptions(firstOpts);\n const includeOptions = this.includeOptions(mode, sharedOptions) || (sharedOptions !== previouslySharedOptions);\n this.updateSharedOptions(sharedOptions, mode, firstOpts);\n return {sharedOptions, includeOptions};\n }\n\n /**\n\t * Utility for updating an element with new properties, using animations when appropriate.\n\t * @protected\n\t */\n updateElement(element, index, properties, mode) {\n if (isDirectUpdateMode(mode)) {\n Object.assign(element, properties);\n } else {\n this._resolveAnimations(index, mode).update(element, properties);\n }\n }\n\n /**\n\t * Utility to animate the shared options, that are potentially affecting multiple elements.\n\t * @protected\n\t */\n updateSharedOptions(sharedOptions, mode, newOptions) {\n if (sharedOptions && !isDirectUpdateMode(mode)) {\n this._resolveAnimations(undefined, mode).update(sharedOptions, newOptions);\n }\n }\n\n /**\n\t * @private\n\t */\n _setStyle(element, index, mode, active) {\n element.active = active;\n const options = this.getStyle(index, active);\n this._resolveAnimations(index, mode, active).update(element, {\n // When going from active to inactive, we need to update to the shared options.\n // This way the once hovered element will end up with the same original shared options instance, after animation.\n options: (!active && this.getSharedOptions(options)) || options\n });\n }\n\n removeHoverStyle(element, datasetIndex, index) {\n this._setStyle(element, index, 'active', false);\n }\n\n setHoverStyle(element, datasetIndex, index) {\n this._setStyle(element, index, 'active', true);\n }\n\n /**\n\t * @private\n\t */\n _removeDatasetHoverStyle() {\n const element = this._cachedMeta.dataset;\n\n if (element) {\n this._setStyle(element, undefined, 'active', false);\n }\n }\n\n /**\n\t * @private\n\t */\n _setDatasetHoverStyle() {\n const element = this._cachedMeta.dataset;\n\n if (element) {\n this._setStyle(element, undefined, 'active', true);\n }\n }\n\n /**\n\t * @private\n\t */\n _resyncElements(resetNewElements) {\n const data = this._data;\n const elements = this._cachedMeta.data;\n\n // Apply changes detected through array listeners\n for (const [method, arg1, arg2] of this._syncList) {\n this[method](arg1, arg2);\n }\n this._syncList = [];\n\n const numMeta = elements.length;\n const numData = data.length;\n const count = Math.min(numData, numMeta);\n\n if (count) {\n // TODO: It is not optimal to always parse the old data\n // This is done because we are not detecting direct assignments:\n // chart.data.datasets[0].data[5] = 10;\n // chart.data.datasets[0].data[5].y = 10;\n this.parse(0, count);\n }\n\n if (numData > numMeta) {\n this._insertElements(numMeta, numData - numMeta, resetNewElements);\n } else if (numData < numMeta) {\n this._removeElements(numData, numMeta - numData);\n }\n }\n\n /**\n\t * @private\n\t */\n _insertElements(start, count, resetNewElements = true) {\n const meta = this._cachedMeta;\n const data = meta.data;\n const end = start + count;\n let i;\n\n const move = (arr) => {\n arr.length += count;\n for (i = arr.length - 1; i >= end; i--) {\n arr[i] = arr[i - count];\n }\n };\n move(data);\n\n for (i = start; i < end; ++i) {\n data[i] = new this.dataElementType();\n }\n\n if (this._parsing) {\n move(meta._parsed);\n }\n this.parse(start, count);\n\n if (resetNewElements) {\n this.updateElements(data, start, count, 'reset');\n }\n }\n\n updateElements(element, start, count, mode) {} // eslint-disable-line no-unused-vars\n\n /**\n\t * @private\n\t */\n _removeElements(start, count) {\n const meta = this._cachedMeta;\n if (this._parsing) {\n const removed = meta._parsed.splice(start, count);\n if (meta._stacked) {\n clearStacks(meta, removed);\n }\n }\n meta.data.splice(start, count);\n }\n\n /**\n\t * @private\n */\n _sync(args) {\n if (this._parsing) {\n this._syncList.push(args);\n } else {\n const [method, arg1, arg2] = args;\n this[method](arg1, arg2);\n }\n this.chart._dataChanges.push([this.index, ...args]);\n }\n\n _onDataPush() {\n const count = arguments.length;\n this._sync(['_insertElements', this.getDataset().data.length - count, count]);\n }\n\n _onDataPop() {\n this._sync(['_removeElements', this._cachedMeta.data.length - 1, 1]);\n }\n\n _onDataShift() {\n this._sync(['_removeElements', 0, 1]);\n }\n\n _onDataSplice(start, count) {\n if (count) {\n this._sync(['_removeElements', start, count]);\n }\n const newCount = arguments.length - 2;\n if (newCount) {\n this._sync(['_insertElements', start, newCount]);\n }\n }\n\n _onDataUnshift() {\n this._sync(['_insertElements', 0, arguments.length]);\n }\n}\n","import DatasetController from '../core/core.datasetController.js';\nimport {\n _arrayUnique, isArray, isNullOrUndef,\n valueOrDefault, resolveObjectKey, sign, defined\n} from '../helpers/index.js';\n\nfunction getAllScaleValues(scale, type) {\n if (!scale._cache.$bar) {\n const visibleMetas = scale.getMatchingVisibleMetas(type);\n let values = [];\n\n for (let i = 0, ilen = visibleMetas.length; i < ilen; i++) {\n values = values.concat(visibleMetas[i].controller.getAllParsedValues(scale));\n }\n scale._cache.$bar = _arrayUnique(values.sort((a, b) => a - b));\n }\n return scale._cache.$bar;\n}\n\n/**\n * Computes the \"optimal\" sample size to maintain bars equally sized while preventing overlap.\n * @private\n */\nfunction computeMinSampleSize(meta) {\n const scale = meta.iScale;\n const values = getAllScaleValues(scale, meta.type);\n let min = scale._length;\n let i, ilen, curr, prev;\n const updateMinAndPrev = () => {\n if (curr === 32767 || curr === -32768) {\n // Ignore truncated pixels\n return;\n }\n if (defined(prev)) {\n // curr - prev === 0 is ignored\n min = Math.min(min, Math.abs(curr - prev) || min);\n }\n prev = curr;\n };\n\n for (i = 0, ilen = values.length; i < ilen; ++i) {\n curr = scale.getPixelForValue(values[i]);\n updateMinAndPrev();\n }\n\n prev = undefined;\n for (i = 0, ilen = scale.ticks.length; i < ilen; ++i) {\n curr = scale.getPixelForTick(i);\n updateMinAndPrev();\n }\n\n return min;\n}\n\n/**\n * Computes an \"ideal\" category based on the absolute bar thickness or, if undefined or null,\n * uses the smallest interval (see computeMinSampleSize) that prevents bar overlapping. This\n * mode currently always generates bars equally sized (until we introduce scriptable options?).\n * @private\n */\nfunction computeFitCategoryTraits(index, ruler, options, stackCount) {\n const thickness = options.barThickness;\n let size, ratio;\n\n if (isNullOrUndef(thickness)) {\n size = ruler.min * options.categoryPercentage;\n ratio = options.barPercentage;\n } else {\n // When bar thickness is enforced, category and bar percentages are ignored.\n // Note(SB): we could add support for relative bar thickness (e.g. barThickness: '50%')\n // and deprecate barPercentage since this value is ignored when thickness is absolute.\n size = thickness * stackCount;\n ratio = 1;\n }\n\n return {\n chunk: size / stackCount,\n ratio,\n start: ruler.pixels[index] - (size / 2)\n };\n}\n\n/**\n * Computes an \"optimal\" category that globally arranges bars side by side (no gap when\n * percentage options are 1), based on the previous and following categories. This mode\n * generates bars with different widths when data are not evenly spaced.\n * @private\n */\nfunction computeFlexCategoryTraits(index, ruler, options, stackCount) {\n const pixels = ruler.pixels;\n const curr = pixels[index];\n let prev = index > 0 ? pixels[index - 1] : null;\n let next = index < pixels.length - 1 ? pixels[index + 1] : null;\n const percent = options.categoryPercentage;\n\n if (prev === null) {\n // first data: its size is double based on the next point or,\n // if it's also the last data, we use the scale size.\n prev = curr - (next === null ? ruler.end - ruler.start : next - curr);\n }\n\n if (next === null) {\n // last data: its size is also double based on the previous point.\n next = curr + curr - prev;\n }\n\n const start = curr - (curr - Math.min(prev, next)) / 2 * percent;\n const size = Math.abs(next - prev) / 2 * percent;\n\n return {\n chunk: size / stackCount,\n ratio: options.barPercentage,\n start\n };\n}\n\nfunction parseFloatBar(entry, item, vScale, i) {\n const startValue = vScale.parse(entry[0], i);\n const endValue = vScale.parse(entry[1], i);\n const min = Math.min(startValue, endValue);\n const max = Math.max(startValue, endValue);\n let barStart = min;\n let barEnd = max;\n\n if (Math.abs(min) > Math.abs(max)) {\n barStart = max;\n barEnd = min;\n }\n\n // Store `barEnd` (furthest away from origin) as parsed value,\n // to make stacking straight forward\n item[vScale.axis] = barEnd;\n\n item._custom = {\n barStart,\n barEnd,\n start: startValue,\n end: endValue,\n min,\n max\n };\n}\n\nfunction parseValue(entry, item, vScale, i) {\n if (isArray(entry)) {\n parseFloatBar(entry, item, vScale, i);\n } else {\n item[vScale.axis] = vScale.parse(entry, i);\n }\n return item;\n}\n\nfunction parseArrayOrPrimitive(meta, data, start, count) {\n const iScale = meta.iScale;\n const vScale = meta.vScale;\n const labels = iScale.getLabels();\n const singleScale = iScale === vScale;\n const parsed = [];\n let i, ilen, item, entry;\n\n for (i = start, ilen = start + count; i < ilen; ++i) {\n entry = data[i];\n item = {};\n item[iScale.axis] = singleScale || iScale.parse(labels[i], i);\n parsed.push(parseValue(entry, item, vScale, i));\n }\n return parsed;\n}\n\nfunction isFloatBar(custom) {\n return custom && custom.barStart !== undefined && custom.barEnd !== undefined;\n}\n\nfunction barSign(size, vScale, actualBase) {\n if (size !== 0) {\n return sign(size);\n }\n return (vScale.isHorizontal() ? 1 : -1) * (vScale.min >= actualBase ? 1 : -1);\n}\n\nfunction borderProps(properties) {\n let reverse, start, end, top, bottom;\n if (properties.horizontal) {\n reverse = properties.base > properties.x;\n start = 'left';\n end = 'right';\n } else {\n reverse = properties.base < properties.y;\n start = 'bottom';\n end = 'top';\n }\n if (reverse) {\n top = 'end';\n bottom = 'start';\n } else {\n top = 'start';\n bottom = 'end';\n }\n return {start, end, reverse, top, bottom};\n}\n\nfunction setBorderSkipped(properties, options, stack, index) {\n let edge = options.borderSkipped;\n const res = {};\n\n if (!edge) {\n properties.borderSkipped = res;\n return;\n }\n\n if (edge === true) {\n properties.borderSkipped = {top: true, right: true, bottom: true, left: true};\n return;\n }\n\n const {start, end, reverse, top, bottom} = borderProps(properties);\n\n if (edge === 'middle' && stack) {\n properties.enableBorderRadius = true;\n if ((stack._top || 0) === index) {\n edge = top;\n } else if ((stack._bottom || 0) === index) {\n edge = bottom;\n } else {\n res[parseEdge(bottom, start, end, reverse)] = true;\n edge = top;\n }\n }\n\n res[parseEdge(edge, start, end, reverse)] = true;\n properties.borderSkipped = res;\n}\n\nfunction parseEdge(edge, a, b, reverse) {\n if (reverse) {\n edge = swap(edge, a, b);\n edge = startEnd(edge, b, a);\n } else {\n edge = startEnd(edge, a, b);\n }\n return edge;\n}\n\nfunction swap(orig, v1, v2) {\n return orig === v1 ? v2 : orig === v2 ? v1 : orig;\n}\n\nfunction startEnd(v, start, end) {\n return v === 'start' ? start : v === 'end' ? end : v;\n}\n\nfunction setInflateAmount(properties, {inflateAmount}, ratio) {\n properties.inflateAmount = inflateAmount === 'auto'\n ? ratio === 1 ? 0.33 : 0\n : inflateAmount;\n}\n\nexport default class BarController extends DatasetController {\n\n static id = 'bar';\n\n /**\n * @type {any}\n */\n static defaults = {\n datasetElementType: false,\n dataElementType: 'bar',\n\n categoryPercentage: 0.8,\n barPercentage: 0.9,\n grouped: true,\n\n animations: {\n numbers: {\n type: 'number',\n properties: ['x', 'y', 'base', 'width', 'height']\n }\n }\n };\n\n /**\n * @type {any}\n */\n static overrides = {\n scales: {\n _index_: {\n type: 'category',\n offset: true,\n grid: {\n offset: true\n }\n },\n _value_: {\n type: 'linear',\n beginAtZero: true,\n }\n }\n };\n\n\n /**\n\t * Overriding primitive data parsing since we support mixed primitive/array\n\t * data for float bars\n\t * @protected\n\t */\n parsePrimitiveData(meta, data, start, count) {\n return parseArrayOrPrimitive(meta, data, start, count);\n }\n\n /**\n\t * Overriding array data parsing since we support mixed primitive/array\n\t * data for float bars\n\t * @protected\n\t */\n parseArrayData(meta, data, start, count) {\n return parseArrayOrPrimitive(meta, data, start, count);\n }\n\n /**\n\t * Overriding object data parsing since we support mixed primitive/array\n\t * value-scale data for float bars\n\t * @protected\n\t */\n parseObjectData(meta, data, start, count) {\n const {iScale, vScale} = meta;\n const {xAxisKey = 'x', yAxisKey = 'y'} = this._parsing;\n const iAxisKey = iScale.axis === 'x' ? xAxisKey : yAxisKey;\n const vAxisKey = vScale.axis === 'x' ? xAxisKey : yAxisKey;\n const parsed = [];\n let i, ilen, item, obj;\n for (i = start, ilen = start + count; i < ilen; ++i) {\n obj = data[i];\n item = {};\n item[iScale.axis] = iScale.parse(resolveObjectKey(obj, iAxisKey), i);\n parsed.push(parseValue(resolveObjectKey(obj, vAxisKey), item, vScale, i));\n }\n return parsed;\n }\n\n /**\n\t * @protected\n\t */\n updateRangeFromParsed(range, scale, parsed, stack) {\n super.updateRangeFromParsed(range, scale, parsed, stack);\n const custom = parsed._custom;\n if (custom && scale === this._cachedMeta.vScale) {\n // float bar: only one end of the bar is considered by `super`\n range.min = Math.min(range.min, custom.min);\n range.max = Math.max(range.max, custom.max);\n }\n }\n\n /**\n\t * @return {number|boolean}\n\t * @protected\n\t */\n getMaxOverflow() {\n return 0;\n }\n\n /**\n\t * @protected\n\t */\n getLabelAndValue(index) {\n const meta = this._cachedMeta;\n const {iScale, vScale} = meta;\n const parsed = this.getParsed(index);\n const custom = parsed._custom;\n const value = isFloatBar(custom)\n ? '[' + custom.start + ', ' + custom.end + ']'\n : '' + vScale.getLabelForValue(parsed[vScale.axis]);\n\n return {\n label: '' + iScale.getLabelForValue(parsed[iScale.axis]),\n value\n };\n }\n\n initialize() {\n this.enableOptionSharing = true;\n\n super.initialize();\n\n const meta = this._cachedMeta;\n meta.stack = this.getDataset().stack;\n }\n\n update(mode) {\n const meta = this._cachedMeta;\n this.updateElements(meta.data, 0, meta.data.length, mode);\n }\n\n updateElements(bars, start, count, mode) {\n const reset = mode === 'reset';\n const {index, _cachedMeta: {vScale}} = this;\n const base = vScale.getBasePixel();\n const horizontal = vScale.isHorizontal();\n const ruler = this._getRuler();\n const {sharedOptions, includeOptions} = this._getSharedOptions(start, mode);\n\n for (let i = start; i < start + count; i++) {\n const parsed = this.getParsed(i);\n const vpixels = reset || isNullOrUndef(parsed[vScale.axis]) ? {base, head: base} : this._calculateBarValuePixels(i);\n const ipixels = this._calculateBarIndexPixels(i, ruler);\n const stack = (parsed._stacks || {})[vScale.axis];\n\n const properties = {\n horizontal,\n base: vpixels.base,\n enableBorderRadius: !stack || isFloatBar(parsed._custom) || (index === stack._top || index === stack._bottom),\n x: horizontal ? vpixels.head : ipixels.center,\n y: horizontal ? ipixels.center : vpixels.head,\n height: horizontal ? ipixels.size : Math.abs(vpixels.size),\n width: horizontal ? Math.abs(vpixels.size) : ipixels.size\n };\n\n if (includeOptions) {\n properties.options = sharedOptions || this.resolveDataElementOptions(i, bars[i].active ? 'active' : mode);\n }\n const options = properties.options || bars[i].options;\n setBorderSkipped(properties, options, stack, index);\n setInflateAmount(properties, options, ruler.ratio);\n this.updateElement(bars[i], i, properties, mode);\n }\n }\n\n /**\n\t * Returns the stacks based on groups and bar visibility.\n\t * @param {number} [last] - The dataset index\n\t * @param {number} [dataIndex] - The data index of the ruler\n\t * @returns {string[]} The list of stack IDs\n\t * @private\n\t */\n _getStacks(last, dataIndex) {\n const {iScale} = this._cachedMeta;\n const metasets = iScale.getMatchingVisibleMetas(this._type)\n .filter(meta => meta.controller.options.grouped);\n const stacked = iScale.options.stacked;\n const stacks = [];\n const currentParsed = this._cachedMeta.controller.getParsed(dataIndex);\n const iScaleValue = currentParsed && currentParsed[iScale.axis];\n\n const skipNull = (meta) => {\n const parsed = meta._parsed.find(item => item[iScale.axis] === iScaleValue);\n const val = parsed && parsed[meta.vScale.axis];\n\n if (isNullOrUndef(val) || isNaN(val)) {\n return true;\n }\n };\n\n for (const meta of metasets) {\n if (dataIndex !== undefined && skipNull(meta)) {\n continue;\n }\n\n // stacked | meta.stack\n // | found | not found | undefined\n // false | x | x | x\n // true | | x |\n // undefined | | x | x\n if (stacked === false || stacks.indexOf(meta.stack) === -1 ||\n\t\t\t\t(stacked === undefined && meta.stack === undefined)) {\n stacks.push(meta.stack);\n }\n if (meta.index === last) {\n break;\n }\n }\n\n // No stacks? that means there is no visible data. Let's still initialize an `undefined`\n // stack where possible invisible bars will be located.\n // https://github.com/chartjs/Chart.js/issues/6368\n if (!stacks.length) {\n stacks.push(undefined);\n }\n\n return stacks;\n }\n\n /**\n\t * Returns the effective number of stacks based on groups and bar visibility.\n\t * @private\n\t */\n _getStackCount(index) {\n return this._getStacks(undefined, index).length;\n }\n\n _getAxisCount() {\n return this._getAxis().length;\n }\n\n getFirstScaleIdForIndexAxis() {\n const scales = this.chart.scales;\n const indexScaleId = this.chart.options.indexAxis;\n return Object.keys(scales).filter(key => scales[key].axis === indexScaleId).shift();\n }\n\n _getAxis() {\n const axis = {};\n const firstScaleAxisId = this.getFirstScaleIdForIndexAxis();\n for (const dataset of this.chart.data.datasets) {\n axis[valueOrDefault(\n this.chart.options.indexAxis === 'x' ? dataset.xAxisID : dataset.yAxisID, firstScaleAxisId\n )] = true;\n }\n return Object.keys(axis);\n }\n\n /**\n\t * Returns the stack index for the given dataset based on groups and bar visibility.\n\t * @param {number} [datasetIndex] - The dataset index\n\t * @param {string} [name] - The stack name to find\n * @param {number} [dataIndex]\n\t * @returns {number} The stack index\n\t * @private\n\t */\n _getStackIndex(datasetIndex, name, dataIndex) {\n const stacks = this._getStacks(datasetIndex, dataIndex);\n const index = (name !== undefined)\n ? stacks.indexOf(name)\n : -1; // indexOf returns -1 if element is not present\n\n return (index === -1)\n ? stacks.length - 1\n : index;\n }\n\n /**\n\t * @private\n\t */\n _getRuler() {\n const opts = this.options;\n const meta = this._cachedMeta;\n const iScale = meta.iScale;\n const pixels = [];\n let i, ilen;\n\n for (i = 0, ilen = meta.data.length; i < ilen; ++i) {\n pixels.push(iScale.getPixelForValue(this.getParsed(i)[iScale.axis], i));\n }\n\n const barThickness = opts.barThickness;\n const min = barThickness || computeMinSampleSize(meta);\n\n return {\n min,\n pixels,\n start: iScale._startPixel,\n end: iScale._endPixel,\n stackCount: this._getStackCount(),\n scale: iScale,\n grouped: opts.grouped,\n // bar thickness ratio used for non-grouped bars\n ratio: barThickness ? 1 : opts.categoryPercentage * opts.barPercentage\n };\n }\n\n /**\n\t * Note: pixel values are not clamped to the scale area.\n\t * @private\n\t */\n _calculateBarValuePixels(index) {\n const {_cachedMeta: {vScale, _stacked, index: datasetIndex}, options: {base: baseValue, minBarLength}} = this;\n const actualBase = baseValue || 0;\n const parsed = this.getParsed(index);\n const custom = parsed._custom;\n const floating = isFloatBar(custom);\n let value = parsed[vScale.axis];\n let start = 0;\n let length = _stacked ? this.applyStack(vScale, parsed, _stacked) : value;\n let head, size;\n\n if (length !== value) {\n start = length - value;\n length = value;\n }\n\n if (floating) {\n value = custom.barStart;\n length = custom.barEnd - custom.barStart;\n // bars crossing origin are not stacked\n if (value !== 0 && sign(value) !== sign(custom.barEnd)) {\n start = 0;\n }\n start += value;\n }\n\n const startValue = !isNullOrUndef(baseValue) && !floating ? baseValue : start;\n let base = vScale.getPixelForValue(startValue);\n\n if (this.chart.getDataVisibility(index)) {\n head = vScale.getPixelForValue(start + length);\n } else {\n // When not visible, no height\n head = base;\n }\n\n size = head - base;\n\n if (Math.abs(size) < minBarLength) {\n size = barSign(size, vScale, actualBase) * minBarLength;\n if (value === actualBase) {\n base -= size / 2;\n }\n const startPixel = vScale.getPixelForDecimal(0);\n const endPixel = vScale.getPixelForDecimal(1);\n const min = Math.min(startPixel, endPixel);\n const max = Math.max(startPixel, endPixel);\n base = Math.max(Math.min(base, max), min);\n head = base + size;\n\n if (_stacked && !floating) {\n // visual data coordinates after applying minBarLength\n parsed._stacks[vScale.axis]._visualValues[datasetIndex] = vScale.getValueForPixel(head) - vScale.getValueForPixel(base);\n }\n }\n\n if (base === vScale.getPixelForValue(actualBase)) {\n const halfGrid = sign(size) * vScale.getLineWidthForValue(actualBase) / 2;\n base += halfGrid;\n size -= halfGrid;\n }\n\n return {\n size,\n base,\n head,\n center: head + size / 2\n };\n }\n\n /**\n\t * @private\n\t */\n _calculateBarIndexPixels(index, ruler) {\n const scale = ruler.scale;\n const options = this.options;\n const skipNull = options.skipNull;\n const maxBarThickness = valueOrDefault(options.maxBarThickness, Infinity);\n let center, size;\n const axisCount = this._getAxisCount();\n if (ruler.grouped) {\n const stackCount = skipNull ? this._getStackCount(index) : ruler.stackCount;\n const range = options.barThickness === 'flex'\n ? computeFlexCategoryTraits(index, ruler, options, stackCount * axisCount)\n : computeFitCategoryTraits(index, ruler, options, stackCount * axisCount);\n const axisID = this.chart.options.indexAxis === 'x' ? this.getDataset().xAxisID : this.getDataset().yAxisID;\n const axisNumber = this._getAxis().indexOf(valueOrDefault(axisID, this.getFirstScaleIdForIndexAxis()));\n const stackIndex = this._getStackIndex(this.index, this._cachedMeta.stack, skipNull ? index : undefined) + axisNumber;\n center = range.start + (range.chunk * stackIndex) + (range.chunk / 2);\n size = Math.min(maxBarThickness, range.chunk * range.ratio);\n } else {\n // For non-grouped bar charts, exact pixel values are used\n center = scale.getPixelForValue(this.getParsed(index)[scale.axis], index);\n size = Math.min(maxBarThickness, ruler.min * ruler.ratio);\n }\n\n\n return {\n base: center - size / 2,\n head: center + size / 2,\n center,\n size\n };\n }\n\n draw() {\n const meta = this._cachedMeta;\n const vScale = meta.vScale;\n const rects = meta.data;\n const ilen = rects.length;\n let i = 0;\n\n for (; i < ilen; ++i) {\n if (this.getParsed(i)[vScale.axis] !== null && !rects[i].hidden) {\n rects[i].draw(this._ctx);\n }\n }\n }\n\n}\n","import DatasetController from '../core/core.datasetController.js';\nimport {valueOrDefault} from '../helpers/helpers.core.js';\n\nexport default class BubbleController extends DatasetController {\n\n static id = 'bubble';\n\n /**\n * @type {any}\n */\n static defaults = {\n datasetElementType: false,\n dataElementType: 'point',\n\n animations: {\n numbers: {\n type: 'number',\n properties: ['x', 'y', 'borderWidth', 'radius']\n }\n }\n };\n\n /**\n * @type {any}\n */\n static overrides = {\n scales: {\n x: {\n type: 'linear'\n },\n y: {\n type: 'linear'\n }\n }\n };\n\n initialize() {\n this.enableOptionSharing = true;\n super.initialize();\n }\n\n /**\n\t * Parse array of primitive values\n\t * @protected\n\t */\n parsePrimitiveData(meta, data, start, count) {\n const parsed = super.parsePrimitiveData(meta, data, start, count);\n for (let i = 0; i < parsed.length; i++) {\n parsed[i]._custom = this.resolveDataElementOptions(i + start).radius;\n }\n return parsed;\n }\n\n /**\n\t * Parse array of arrays\n\t * @protected\n\t */\n parseArrayData(meta, data, start, count) {\n const parsed = super.parseArrayData(meta, data, start, count);\n for (let i = 0; i < parsed.length; i++) {\n const item = data[start + i];\n parsed[i]._custom = valueOrDefault(item[2], this.resolveDataElementOptions(i + start).radius);\n }\n return parsed;\n }\n\n /**\n\t * Parse array of objects\n\t * @protected\n\t */\n parseObjectData(meta, data, start, count) {\n const parsed = super.parseObjectData(meta, data, start, count);\n for (let i = 0; i < parsed.length; i++) {\n const item = data[start + i];\n parsed[i]._custom = valueOrDefault(item && item.r && +item.r, this.resolveDataElementOptions(i + start).radius);\n }\n return parsed;\n }\n\n /**\n\t * @protected\n\t */\n getMaxOverflow() {\n const data = this._cachedMeta.data;\n\n let max = 0;\n for (let i = data.length - 1; i >= 0; --i) {\n max = Math.max(max, data[i].size(this.resolveDataElementOptions(i)) / 2);\n }\n return max > 0 && max;\n }\n\n /**\n\t * @protected\n\t */\n getLabelAndValue(index) {\n const meta = this._cachedMeta;\n const labels = this.chart.data.labels || [];\n const {xScale, yScale} = meta;\n const parsed = this.getParsed(index);\n const x = xScale.getLabelForValue(parsed.x);\n const y = yScale.getLabelForValue(parsed.y);\n const r = parsed._custom;\n\n return {\n label: labels[index] || '',\n value: '(' + x + ', ' + y + (r ? ', ' + r : '') + ')'\n };\n }\n\n update(mode) {\n const points = this._cachedMeta.data;\n\n // Update Points\n this.updateElements(points, 0, points.length, mode);\n }\n\n updateElements(points, start, count, mode) {\n const reset = mode === 'reset';\n const {iScale, vScale} = this._cachedMeta;\n const {sharedOptions, includeOptions} = this._getSharedOptions(start, mode);\n const iAxis = iScale.axis;\n const vAxis = vScale.axis;\n\n for (let i = start; i < start + count; i++) {\n const point = points[i];\n const parsed = !reset && this.getParsed(i);\n const properties = {};\n const iPixel = properties[iAxis] = reset ? iScale.getPixelForDecimal(0.5) : iScale.getPixelForValue(parsed[iAxis]);\n const vPixel = properties[vAxis] = reset ? vScale.getBasePixel() : vScale.getPixelForValue(parsed[vAxis]);\n\n properties.skip = isNaN(iPixel) || isNaN(vPixel);\n\n if (includeOptions) {\n properties.options = sharedOptions || this.resolveDataElementOptions(i, point.active ? 'active' : mode);\n\n if (reset) {\n properties.options.radius = 0;\n }\n }\n\n this.updateElement(point, i, properties, mode);\n }\n }\n\n /**\n\t * @param {number} index\n\t * @param {string} [mode]\n\t * @protected\n\t */\n resolveDataElementOptions(index, mode) {\n const parsed = this.getParsed(index);\n let values = super.resolveDataElementOptions(index, mode);\n\n // In case values were cached (and thus frozen), we need to clone the values\n if (values.$shared) {\n values = Object.assign({}, values, {$shared: false});\n }\n\n // Custom radius resolution\n const radius = values.radius;\n if (mode !== 'active') {\n values.radius = 0;\n }\n values.radius += valueOrDefault(parsed && parsed._custom, radius);\n\n return values;\n }\n}\n","import DatasetController from '../core/core.datasetController.js';\nimport {isObject, resolveObjectKey, toPercentage, toDimension, valueOrDefault} from '../helpers/helpers.core.js';\nimport {formatNumber} from '../helpers/helpers.intl.js';\nimport {toRadians, PI, TAU, HALF_PI, _angleBetween} from '../helpers/helpers.math.js';\n\n/**\n * @typedef { import('../core/core.controller.js').default } Chart\n */\n\nfunction getRatioAndOffset(rotation, circumference, cutout) {\n let ratioX = 1;\n let ratioY = 1;\n let offsetX = 0;\n let offsetY = 0;\n // If the chart's circumference isn't a full circle, calculate size as a ratio of the width/height of the arc\n if (circumference < TAU) {\n const startAngle = rotation;\n const endAngle = startAngle + circumference;\n const startX = Math.cos(startAngle);\n const startY = Math.sin(startAngle);\n const endX = Math.cos(endAngle);\n const endY = Math.sin(endAngle);\n const calcMax = (angle, a, b) => _angleBetween(angle, startAngle, endAngle, true) ? 1 : Math.max(a, a * cutout, b, b * cutout);\n const calcMin = (angle, a, b) => _angleBetween(angle, startAngle, endAngle, true) ? -1 : Math.min(a, a * cutout, b, b * cutout);\n const maxX = calcMax(0, startX, endX);\n const maxY = calcMax(HALF_PI, startY, endY);\n const minX = calcMin(PI, startX, endX);\n const minY = calcMin(PI + HALF_PI, startY, endY);\n ratioX = (maxX - minX) / 2;\n ratioY = (maxY - minY) / 2;\n offsetX = -(maxX + minX) / 2;\n offsetY = -(maxY + minY) / 2;\n }\n return {ratioX, ratioY, offsetX, offsetY};\n}\n\nexport default class DoughnutController extends DatasetController {\n\n static id = 'doughnut';\n\n /**\n * @type {any}\n */\n static defaults = {\n datasetElementType: false,\n dataElementType: 'arc',\n animation: {\n // Boolean - Whether we animate the rotation of the Doughnut\n animateRotate: true,\n // Boolean - Whether we animate scaling the Doughnut from the centre\n animateScale: false\n },\n animations: {\n numbers: {\n type: 'number',\n properties: ['circumference', 'endAngle', 'innerRadius', 'outerRadius', 'startAngle', 'x', 'y', 'offset', 'borderWidth', 'spacing']\n },\n },\n // The percentage of the chart that we cut out of the middle.\n cutout: '50%',\n\n // The rotation of the chart, where the first data arc begins.\n rotation: 0,\n\n // The total circumference of the chart.\n circumference: 360,\n\n // The outer radius of the chart\n radius: '100%',\n\n // Spacing between arcs\n spacing: 0,\n\n indexAxis: 'r',\n };\n\n static descriptors = {\n _scriptable: (name) => name !== 'spacing',\n _indexable: (name) => name !== 'spacing' && !name.startsWith('borderDash') && !name.startsWith('hoverBorderDash'),\n };\n\n /**\n * @type {any}\n */\n static overrides = {\n aspectRatio: 1,\n\n // Need to override these to give a nice default\n plugins: {\n legend: {\n labels: {\n generateLabels(chart) {\n const data = chart.data;\n const {labels: {pointStyle, textAlign, color, useBorderRadius, borderRadius}} = chart.legend.options;\n if (data.labels.length && data.datasets.length) {\n return data.labels.map((label, i) => {\n const meta = chart.getDatasetMeta(0);\n const style = meta.controller.getStyle(i);\n\n return {\n text: label,\n fillStyle: style.backgroundColor,\n fontColor: color,\n hidden: !chart.getDataVisibility(i),\n lineDash: style.borderDash,\n lineDashOffset: style.borderDashOffset,\n lineJoin: style.borderJoinStyle,\n lineWidth: style.borderWidth,\n strokeStyle: style.borderColor,\n textAlign: textAlign,\n pointStyle: pointStyle,\n borderRadius: useBorderRadius && (borderRadius || style.borderRadius),\n // Extra data used for toggling the correct item\n index: i\n };\n });\n }\n return [];\n }\n },\n\n onClick(e, legendItem, legend) {\n legend.chart.toggleDataVisibility(legendItem.index);\n legend.chart.update();\n }\n }\n }\n };\n\n constructor(chart, datasetIndex) {\n super(chart, datasetIndex);\n\n this.enableOptionSharing = true;\n this.innerRadius = undefined;\n this.outerRadius = undefined;\n this.offsetX = undefined;\n this.offsetY = undefined;\n }\n\n linkScales() {}\n\n /**\n\t * Override data parsing, since we are not using scales\n\t */\n parse(start, count) {\n const data = this.getDataset().data;\n const meta = this._cachedMeta;\n\n if (this._parsing === false) {\n meta._parsed = data;\n } else {\n let getter = (i) => +data[i];\n\n if (isObject(data[start])) {\n const {key = 'value'} = this._parsing;\n getter = (i) => +resolveObjectKey(data[i], key);\n }\n\n let i, ilen;\n for (i = start, ilen = start + count; i < ilen; ++i) {\n meta._parsed[i] = getter(i);\n }\n }\n }\n\n /**\n\t * @private\n\t */\n _getRotation() {\n return toRadians(this.options.rotation - 90);\n }\n\n /**\n\t * @private\n\t */\n _getCircumference() {\n return toRadians(this.options.circumference);\n }\n\n /**\n\t * Get the maximal rotation & circumference extents\n\t * across all visible datasets.\n\t */\n _getRotationExtents() {\n let min = TAU;\n let max = -TAU;\n\n for (let i = 0; i < this.chart.data.datasets.length; ++i) {\n if (this.chart.isDatasetVisible(i) && this.chart.getDatasetMeta(i).type === this._type) {\n const controller = this.chart.getDatasetMeta(i).controller;\n const rotation = controller._getRotation();\n const circumference = controller._getCircumference();\n\n min = Math.min(min, rotation);\n max = Math.max(max, rotation + circumference);\n }\n }\n\n return {\n rotation: min,\n circumference: max - min,\n };\n }\n\n /**\n\t * @param {string} mode\n\t */\n update(mode) {\n const chart = this.chart;\n const {chartArea} = chart;\n const meta = this._cachedMeta;\n const arcs = meta.data;\n const spacing = this.getMaxBorderWidth() + this.getMaxOffset(arcs) + this.options.spacing;\n const maxSize = Math.max((Math.min(chartArea.width, chartArea.height) - spacing) / 2, 0);\n const cutout = Math.min(toPercentage(this.options.cutout, maxSize), 1);\n const chartWeight = this._getRingWeight(this.index);\n\n // Compute the maximal rotation & circumference limits.\n // If we only consider our dataset, this can cause problems when two datasets\n // are both less than a circle with different rotations (starting angles)\n const {circumference, rotation} = this._getRotationExtents();\n const {ratioX, ratioY, offsetX, offsetY} = getRatioAndOffset(rotation, circumference, cutout);\n const maxWidth = (chartArea.width - spacing) / ratioX;\n const maxHeight = (chartArea.height - spacing) / ratioY;\n const maxRadius = Math.max(Math.min(maxWidth, maxHeight) / 2, 0);\n const outerRadius = toDimension(this.options.radius, maxRadius);\n const innerRadius = Math.max(outerRadius * cutout, 0);\n const radiusLength = (outerRadius - innerRadius) / this._getVisibleDatasetWeightTotal();\n this.offsetX = offsetX * outerRadius;\n this.offsetY = offsetY * outerRadius;\n\n meta.total = this.calculateTotal();\n\n this.outerRadius = outerRadius - radiusLength * this._getRingWeightOffset(this.index);\n this.innerRadius = Math.max(this.outerRadius - radiusLength * chartWeight, 0);\n\n this.updateElements(arcs, 0, arcs.length, mode);\n }\n\n /**\n * @private\n */\n _circumference(i, reset) {\n const opts = this.options;\n const meta = this._cachedMeta;\n const circumference = this._getCircumference();\n if ((reset && opts.animation.animateRotate) || !this.chart.getDataVisibility(i) || meta._parsed[i] === null || meta.data[i].hidden) {\n return 0;\n }\n return this.calculateCircumference(meta._parsed[i] * circumference / TAU);\n }\n\n updateElements(arcs, start, count, mode) {\n const reset = mode === 'reset';\n const chart = this.chart;\n const chartArea = chart.chartArea;\n const opts = chart.options;\n const animationOpts = opts.animation;\n const centerX = (chartArea.left + chartArea.right) / 2;\n const centerY = (chartArea.top + chartArea.bottom) / 2;\n const animateScale = reset && animationOpts.animateScale;\n const innerRadius = animateScale ? 0 : this.innerRadius;\n const outerRadius = animateScale ? 0 : this.outerRadius;\n const {sharedOptions, includeOptions} = this._getSharedOptions(start, mode);\n let startAngle = this._getRotation();\n let i;\n\n for (i = 0; i < start; ++i) {\n startAngle += this._circumference(i, reset);\n }\n\n for (i = start; i < start + count; ++i) {\n const circumference = this._circumference(i, reset);\n const arc = arcs[i];\n const properties = {\n x: centerX + this.offsetX,\n y: centerY + this.offsetY,\n startAngle,\n endAngle: startAngle + circumference,\n circumference,\n outerRadius,\n innerRadius\n };\n if (includeOptions) {\n properties.options = sharedOptions || this.resolveDataElementOptions(i, arc.active ? 'active' : mode);\n }\n startAngle += circumference;\n\n this.updateElement(arc, i, properties, mode);\n }\n }\n\n calculateTotal() {\n const meta = this._cachedMeta;\n const metaData = meta.data;\n let total = 0;\n let i;\n\n for (i = 0; i < metaData.length; i++) {\n const value = meta._parsed[i];\n if (value !== null && !isNaN(value) && this.chart.getDataVisibility(i) && !metaData[i].hidden) {\n total += Math.abs(value);\n }\n }\n\n return total;\n }\n\n calculateCircumference(value) {\n const total = this._cachedMeta.total;\n if (total > 0 && !isNaN(value)) {\n return TAU * (Math.abs(value) / total);\n }\n return 0;\n }\n\n getLabelAndValue(index) {\n const meta = this._cachedMeta;\n const chart = this.chart;\n const labels = chart.data.labels || [];\n const value = formatNumber(meta._parsed[index], chart.options.locale);\n\n return {\n label: labels[index] || '',\n value,\n };\n }\n\n getMaxBorderWidth(arcs) {\n let max = 0;\n const chart = this.chart;\n let i, ilen, meta, controller, options;\n\n if (!arcs) {\n // Find the outmost visible dataset\n for (i = 0, ilen = chart.data.datasets.length; i < ilen; ++i) {\n if (chart.isDatasetVisible(i)) {\n meta = chart.getDatasetMeta(i);\n arcs = meta.data;\n controller = meta.controller;\n break;\n }\n }\n }\n\n if (!arcs) {\n return 0;\n }\n\n for (i = 0, ilen = arcs.length; i < ilen; ++i) {\n options = controller.resolveDataElementOptions(i);\n if (options.borderAlign !== 'inner') {\n max = Math.max(max, options.borderWidth || 0, options.hoverBorderWidth || 0);\n }\n }\n return max;\n }\n\n getMaxOffset(arcs) {\n let max = 0;\n\n for (let i = 0, ilen = arcs.length; i < ilen; ++i) {\n const options = this.resolveDataElementOptions(i);\n max = Math.max(max, options.offset || 0, options.hoverOffset || 0);\n }\n return max;\n }\n\n /**\n\t * Get radius length offset of the dataset in relation to the visible datasets weights. This allows determining the inner and outer radius correctly\n\t * @private\n\t */\n _getRingWeightOffset(datasetIndex) {\n let ringWeightOffset = 0;\n\n for (let i = 0; i < datasetIndex; ++i) {\n if (this.chart.isDatasetVisible(i)) {\n ringWeightOffset += this._getRingWeight(i);\n }\n }\n\n return ringWeightOffset;\n }\n\n /**\n\t * @private\n\t */\n _getRingWeight(datasetIndex) {\n return Math.max(valueOrDefault(this.chart.data.datasets[datasetIndex].weight, 1), 0);\n }\n\n /**\n\t * Returns the sum of all visible data set weights.\n\t * @private\n\t */\n _getVisibleDatasetWeightTotal() {\n return this._getRingWeightOffset(this.chart.data.datasets.length) || 1;\n }\n}\n","import DatasetController from '../core/core.datasetController.js';\nimport {isNullOrUndef} from '../helpers/index.js';\nimport {isNumber} from '../helpers/helpers.math.js';\nimport {_getStartAndCountOfVisiblePoints, _scaleRangesChanged} from '../helpers/helpers.extras.js';\n\nexport default class LineController extends DatasetController {\n\n static id = 'line';\n\n /**\n * @type {any}\n */\n static defaults = {\n datasetElementType: 'line',\n dataElementType: 'point',\n\n showLine: true,\n spanGaps: false,\n };\n\n /**\n * @type {any}\n */\n static overrides = {\n scales: {\n _index_: {\n type: 'category',\n },\n _value_: {\n type: 'linear',\n },\n }\n };\n\n initialize() {\n this.enableOptionSharing = true;\n this.supportsDecimation = true;\n super.initialize();\n }\n\n update(mode) {\n const meta = this._cachedMeta;\n const {dataset: line, data: points = [], _dataset} = meta;\n // @ts-ignore\n const animationsDisabled = this.chart._animationsDisabled;\n let {start, count} = _getStartAndCountOfVisiblePoints(meta, points, animationsDisabled);\n\n this._drawStart = start;\n this._drawCount = count;\n\n if (_scaleRangesChanged(meta)) {\n start = 0;\n count = points.length;\n }\n\n // Update Line\n line._chart = this.chart;\n line._datasetIndex = this.index;\n line._decimated = !!_dataset._decimated;\n line.points = points;\n\n const options = this.resolveDatasetElementOptions(mode);\n if (!this.options.showLine) {\n options.borderWidth = 0;\n }\n options.segment = this.options.segment;\n this.updateElement(line, undefined, {\n animated: !animationsDisabled,\n options\n }, mode);\n\n // Update Points\n this.updateElements(points, start, count, mode);\n }\n\n updateElements(points, start, count, mode) {\n const reset = mode === 'reset';\n const {iScale, vScale, _stacked, _dataset} = this._cachedMeta;\n const {sharedOptions, includeOptions} = this._getSharedOptions(start, mode);\n const iAxis = iScale.axis;\n const vAxis = vScale.axis;\n const {spanGaps, segment} = this.options;\n const maxGapLength = isNumber(spanGaps) ? spanGaps : Number.POSITIVE_INFINITY;\n const directUpdate = this.chart._animationsDisabled || reset || mode === 'none';\n const end = start + count;\n const pointsCount = points.length;\n let prevParsed = start > 0 && this.getParsed(start - 1);\n\n for (let i = 0; i < pointsCount; ++i) {\n const point = points[i];\n const properties = directUpdate ? point : {};\n\n if (i < start || i >= end) {\n properties.skip = true;\n continue;\n }\n\n const parsed = this.getParsed(i);\n const nullData = isNullOrUndef(parsed[vAxis]);\n const iPixel = properties[iAxis] = iScale.getPixelForValue(parsed[iAxis], i);\n const vPixel = properties[vAxis] = reset || nullData ? vScale.getBasePixel() : vScale.getPixelForValue(_stacked ? this.applyStack(vScale, parsed, _stacked) : parsed[vAxis], i);\n\n properties.skip = isNaN(iPixel) || isNaN(vPixel) || nullData;\n properties.stop = i > 0 && (Math.abs(parsed[iAxis] - prevParsed[iAxis])) > maxGapLength;\n if (segment) {\n properties.parsed = parsed;\n properties.raw = _dataset.data[i];\n }\n\n if (includeOptions) {\n properties.options = sharedOptions || this.resolveDataElementOptions(i, point.active ? 'active' : mode);\n }\n\n if (!directUpdate) {\n this.updateElement(point, i, properties, mode);\n }\n\n prevParsed = parsed;\n }\n }\n\n /**\n\t * @protected\n\t */\n getMaxOverflow() {\n const meta = this._cachedMeta;\n const dataset = meta.dataset;\n const border = dataset.options && dataset.options.borderWidth || 0;\n const data = meta.data || [];\n if (!data.length) {\n return border;\n }\n const firstPoint = data[0].size(this.resolveDataElementOptions(0));\n const lastPoint = data[data.length - 1].size(this.resolveDataElementOptions(data.length - 1));\n return Math.max(border, firstPoint, lastPoint) / 2;\n }\n\n draw() {\n const meta = this._cachedMeta;\n meta.dataset.updateControlPoints(this.chart.chartArea, meta.iScale.axis);\n super.draw();\n }\n}\n","import DatasetController from '../core/core.datasetController.js';\nimport {toRadians, PI, formatNumber, _parseObjectDataRadialScale} from '../helpers/index.js';\n\nexport default class PolarAreaController extends DatasetController {\n\n static id = 'polarArea';\n\n /**\n * @type {any}\n */\n static defaults = {\n dataElementType: 'arc',\n animation: {\n animateRotate: true,\n animateScale: true\n },\n animations: {\n numbers: {\n type: 'number',\n properties: ['x', 'y', 'startAngle', 'endAngle', 'innerRadius', 'outerRadius']\n },\n },\n indexAxis: 'r',\n startAngle: 0,\n };\n\n /**\n * @type {any}\n */\n static overrides = {\n aspectRatio: 1,\n\n plugins: {\n legend: {\n labels: {\n generateLabels(chart) {\n const data = chart.data;\n if (data.labels.length && data.datasets.length) {\n const {labels: {pointStyle, color}} = chart.legend.options;\n\n return data.labels.map((label, i) => {\n const meta = chart.getDatasetMeta(0);\n const style = meta.controller.getStyle(i);\n\n return {\n text: label,\n fillStyle: style.backgroundColor,\n strokeStyle: style.borderColor,\n fontColor: color,\n lineWidth: style.borderWidth,\n pointStyle: pointStyle,\n hidden: !chart.getDataVisibility(i),\n\n // Extra data used for toggling the correct item\n index: i\n };\n });\n }\n return [];\n }\n },\n\n onClick(e, legendItem, legend) {\n legend.chart.toggleDataVisibility(legendItem.index);\n legend.chart.update();\n }\n }\n },\n\n scales: {\n r: {\n type: 'radialLinear',\n angleLines: {\n display: false\n },\n beginAtZero: true,\n grid: {\n circular: true\n },\n pointLabels: {\n display: false\n },\n startAngle: 0\n }\n }\n };\n\n constructor(chart, datasetIndex) {\n super(chart, datasetIndex);\n\n this.innerRadius = undefined;\n this.outerRadius = undefined;\n }\n\n getLabelAndValue(index) {\n const meta = this._cachedMeta;\n const chart = this.chart;\n const labels = chart.data.labels || [];\n const value = formatNumber(meta._parsed[index].r, chart.options.locale);\n\n return {\n label: labels[index] || '',\n value,\n };\n }\n\n parseObjectData(meta, data, start, count) {\n return _parseObjectDataRadialScale.bind(this)(meta, data, start, count);\n }\n\n update(mode) {\n const arcs = this._cachedMeta.data;\n\n this._updateRadius();\n this.updateElements(arcs, 0, arcs.length, mode);\n }\n\n /**\n * @protected\n */\n getMinMax() {\n const meta = this._cachedMeta;\n const range = {min: Number.POSITIVE_INFINITY, max: Number.NEGATIVE_INFINITY};\n\n meta.data.forEach((element, index) => {\n const parsed = this.getParsed(index).r;\n\n if (!isNaN(parsed) && this.chart.getDataVisibility(index)) {\n if (parsed < range.min) {\n range.min = parsed;\n }\n\n if (parsed > range.max) {\n range.max = parsed;\n }\n }\n });\n\n return range;\n }\n\n /**\n\t * @private\n\t */\n _updateRadius() {\n const chart = this.chart;\n const chartArea = chart.chartArea;\n const opts = chart.options;\n const minSize = Math.min(chartArea.right - chartArea.left, chartArea.bottom - chartArea.top);\n\n const outerRadius = Math.max(minSize / 2, 0);\n const innerRadius = Math.max(opts.cutoutPercentage ? (outerRadius / 100) * (opts.cutoutPercentage) : 1, 0);\n const radiusLength = (outerRadius - innerRadius) / chart.getVisibleDatasetCount();\n\n this.outerRadius = outerRadius - (radiusLength * this.index);\n this.innerRadius = this.outerRadius - radiusLength;\n }\n\n updateElements(arcs, start, count, mode) {\n const reset = mode === 'reset';\n const chart = this.chart;\n const opts = chart.options;\n const animationOpts = opts.animation;\n const scale = this._cachedMeta.rScale;\n const centerX = scale.xCenter;\n const centerY = scale.yCenter;\n const datasetStartAngle = scale.getIndexAngle(0) - 0.5 * PI;\n let angle = datasetStartAngle;\n let i;\n\n const defaultAngle = 360 / this.countVisibleElements();\n\n for (i = 0; i < start; ++i) {\n angle += this._computeAngle(i, mode, defaultAngle);\n }\n for (i = start; i < start + count; i++) {\n const arc = arcs[i];\n let startAngle = angle;\n let endAngle = angle + this._computeAngle(i, mode, defaultAngle);\n let outerRadius = chart.getDataVisibility(i) ? scale.getDistanceFromCenterForValue(this.getParsed(i).r) : 0;\n angle = endAngle;\n\n if (reset) {\n if (animationOpts.animateScale) {\n outerRadius = 0;\n }\n if (animationOpts.animateRotate) {\n startAngle = endAngle = datasetStartAngle;\n }\n }\n\n const properties = {\n x: centerX,\n y: centerY,\n innerRadius: 0,\n outerRadius,\n startAngle,\n endAngle,\n options: this.resolveDataElementOptions(i, arc.active ? 'active' : mode)\n };\n\n this.updateElement(arc, i, properties, mode);\n }\n }\n\n countVisibleElements() {\n const meta = this._cachedMeta;\n let count = 0;\n\n meta.data.forEach((element, index) => {\n if (!isNaN(this.getParsed(index).r) && this.chart.getDataVisibility(index)) {\n count++;\n }\n });\n\n return count;\n }\n\n /**\n\t * @private\n\t */\n _computeAngle(index, mode, defaultAngle) {\n return this.chart.getDataVisibility(index)\n ? toRadians(this.resolveDataElementOptions(index, mode).angle || defaultAngle)\n : 0;\n }\n}\n","import DoughnutController from './controller.doughnut.js';\n\n// Pie charts are Doughnut chart with different defaults\nexport default class PieController extends DoughnutController {\n\n static id = 'pie';\n\n /**\n * @type {any}\n */\n static defaults = {\n // The percentage of the chart that we cut out of the middle.\n cutout: 0,\n\n // The rotation of the chart, where the first data arc begins.\n rotation: 0,\n\n // The total circumference of the chart.\n circumference: 360,\n\n // The outer radius of the chart\n radius: '100%'\n };\n}\n","import DatasetController from '../core/core.datasetController.js';\nimport {_parseObjectDataRadialScale} from '../helpers/index.js';\n\nexport default class RadarController extends DatasetController {\n\n static id = 'radar';\n\n /**\n * @type {any}\n */\n static defaults = {\n datasetElementType: 'line',\n dataElementType: 'point',\n indexAxis: 'r',\n showLine: true,\n elements: {\n line: {\n fill: 'start'\n }\n },\n };\n\n /**\n * @type {any}\n */\n static overrides = {\n aspectRatio: 1,\n\n scales: {\n r: {\n type: 'radialLinear',\n }\n }\n };\n\n /**\n\t * @protected\n\t */\n getLabelAndValue(index) {\n const vScale = this._cachedMeta.vScale;\n const parsed = this.getParsed(index);\n\n return {\n label: vScale.getLabels()[index],\n value: '' + vScale.getLabelForValue(parsed[vScale.axis])\n };\n }\n\n parseObjectData(meta, data, start, count) {\n return _parseObjectDataRadialScale.bind(this)(meta, data, start, count);\n }\n\n update(mode) {\n const meta = this._cachedMeta;\n const line = meta.dataset;\n const points = meta.data || [];\n const labels = meta.iScale.getLabels();\n\n // Update Line\n line.points = points;\n // In resize mode only point locations change, so no need to set the points or options.\n if (mode !== 'resize') {\n const options = this.resolveDatasetElementOptions(mode);\n if (!this.options.showLine) {\n options.borderWidth = 0;\n }\n\n const properties = {\n _loop: true,\n _fullLoop: labels.length === points.length,\n options\n };\n\n this.updateElement(line, undefined, properties, mode);\n }\n\n // Update Points\n this.updateElements(points, 0, points.length, mode);\n }\n\n updateElements(points, start, count, mode) {\n const scale = this._cachedMeta.rScale;\n const reset = mode === 'reset';\n\n for (let i = start; i < start + count; i++) {\n const point = points[i];\n const options = this.resolveDataElementOptions(i, point.active ? 'active' : mode);\n const pointPosition = scale.getPointPositionForValue(i, this.getParsed(i).r);\n\n const x = reset ? scale.xCenter : pointPosition.x;\n const y = reset ? scale.yCenter : pointPosition.y;\n\n const properties = {\n x,\n y,\n angle: pointPosition.angle,\n skip: isNaN(x) || isNaN(y),\n options\n };\n\n this.updateElement(point, i, properties, mode);\n }\n }\n}\n","import DatasetController from '../core/core.datasetController.js';\nimport {isNullOrUndef} from '../helpers/index.js';\nimport {isNumber} from '../helpers/helpers.math.js';\nimport {_getStartAndCountOfVisiblePoints, _scaleRangesChanged} from '../helpers/helpers.extras.js';\n\nexport default class ScatterController extends DatasetController {\n\n static id = 'scatter';\n\n /**\n * @type {any}\n */\n static defaults = {\n datasetElementType: false,\n dataElementType: 'point',\n showLine: false,\n fill: false\n };\n\n /**\n * @type {any}\n */\n static overrides = {\n\n interaction: {\n mode: 'point'\n },\n\n scales: {\n x: {\n type: 'linear'\n },\n y: {\n type: 'linear'\n }\n }\n };\n\n /**\n\t * @protected\n\t */\n getLabelAndValue(index) {\n const meta = this._cachedMeta;\n const labels = this.chart.data.labels || [];\n const {xScale, yScale} = meta;\n const parsed = this.getParsed(index);\n const x = xScale.getLabelForValue(parsed.x);\n const y = yScale.getLabelForValue(parsed.y);\n\n return {\n label: labels[index] || '',\n value: '(' + x + ', ' + y + ')'\n };\n }\n\n update(mode) {\n const meta = this._cachedMeta;\n const {data: points = []} = meta;\n // @ts-ignore\n const animationsDisabled = this.chart._animationsDisabled;\n let {start, count} = _getStartAndCountOfVisiblePoints(meta, points, animationsDisabled);\n\n this._drawStart = start;\n this._drawCount = count;\n\n if (_scaleRangesChanged(meta)) {\n start = 0;\n count = points.length;\n }\n\n if (this.options.showLine) {\n\n // https://github.com/chartjs/Chart.js/issues/11333\n if (!this.datasetElementType) {\n this.addElements();\n }\n const {dataset: line, _dataset} = meta;\n\n // Update Line\n line._chart = this.chart;\n line._datasetIndex = this.index;\n line._decimated = !!_dataset._decimated;\n line.points = points;\n\n const options = this.resolveDatasetElementOptions(mode);\n options.segment = this.options.segment;\n this.updateElement(line, undefined, {\n animated: !animationsDisabled,\n options\n }, mode);\n } else if (this.datasetElementType) {\n // https://github.com/chartjs/Chart.js/issues/11333\n delete meta.dataset;\n this.datasetElementType = false;\n }\n\n // Update Points\n this.updateElements(points, start, count, mode);\n }\n\n addElements() {\n const {showLine} = this.options;\n\n if (!this.datasetElementType && showLine) {\n this.datasetElementType = this.chart.registry.getElement('line');\n }\n\n super.addElements();\n }\n\n updateElements(points, start, count, mode) {\n const reset = mode === 'reset';\n const {iScale, vScale, _stacked, _dataset} = this._cachedMeta;\n const firstOpts = this.resolveDataElementOptions(start, mode);\n const sharedOptions = this.getSharedOptions(firstOpts);\n const includeOptions = this.includeOptions(mode, sharedOptions);\n const iAxis = iScale.axis;\n const vAxis = vScale.axis;\n const {spanGaps, segment} = this.options;\n const maxGapLength = isNumber(spanGaps) ? spanGaps : Number.POSITIVE_INFINITY;\n const directUpdate = this.chart._animationsDisabled || reset || mode === 'none';\n let prevParsed = start > 0 && this.getParsed(start - 1);\n\n for (let i = start; i < start + count; ++i) {\n const point = points[i];\n const parsed = this.getParsed(i);\n const properties = directUpdate ? point : {};\n const nullData = isNullOrUndef(parsed[vAxis]);\n const iPixel = properties[iAxis] = iScale.getPixelForValue(parsed[iAxis], i);\n const vPixel = properties[vAxis] = reset || nullData ? vScale.getBasePixel() : vScale.getPixelForValue(_stacked ? this.applyStack(vScale, parsed, _stacked) : parsed[vAxis], i);\n\n properties.skip = isNaN(iPixel) || isNaN(vPixel) || nullData;\n properties.stop = i > 0 && (Math.abs(parsed[iAxis] - prevParsed[iAxis])) > maxGapLength;\n if (segment) {\n properties.parsed = parsed;\n properties.raw = _dataset.data[i];\n }\n\n if (includeOptions) {\n properties.options = sharedOptions || this.resolveDataElementOptions(i, point.active ? 'active' : mode);\n }\n\n if (!directUpdate) {\n this.updateElement(point, i, properties, mode);\n }\n\n prevParsed = parsed;\n }\n\n this.updateSharedOptions(sharedOptions, mode, firstOpts);\n }\n\n /**\n\t * @protected\n\t */\n getMaxOverflow() {\n const meta = this._cachedMeta;\n const data = meta.data || [];\n\n if (!this.options.showLine) {\n let max = 0;\n for (let i = data.length - 1; i >= 0; --i) {\n max = Math.max(max, data[i].size(this.resolveDataElementOptions(i)) / 2);\n }\n return max > 0 && max;\n }\n\n const dataset = meta.dataset;\n const border = dataset.options && dataset.options.borderWidth || 0;\n\n if (!data.length) {\n return border;\n }\n\n const firstPoint = data[0].size(this.resolveDataElementOptions(0));\n const lastPoint = data[data.length - 1].size(this.resolveDataElementOptions(data.length - 1));\n return Math.max(border, firstPoint, lastPoint) / 2;\n }\n}\n","/**\n * @namespace Chart._adapters\n * @since 2.8.0\n * @private\n */\n\nimport type {AnyObject} from '../types/basic.js';\nimport type {ChartOptions} from '../types/index.js';\n\nexport type TimeUnit = 'millisecond' | 'second' | 'minute' | 'hour' | 'day' | 'week' | 'month' | 'quarter' | 'year';\n\nexport interface DateAdapter {\n readonly options: T;\n /**\n * Will called with chart options after adapter creation.\n */\n init(this: DateAdapter, chartOptions: ChartOptions): void;\n /**\n * Returns a map of time formats for the supported formatting units defined\n * in Unit as well as 'datetime' representing a detailed date/time string.\n */\n formats(this: DateAdapter): Record;\n /**\n * Parses the given `value` and return the associated timestamp.\n * @param value - the value to parse (usually comes from the data)\n * @param [format] - the expected data format\n */\n parse(this: DateAdapter, value: unknown, format?: string): number | null;\n /**\n * Returns the formatted date in the specified `format` for a given `timestamp`.\n * @param timestamp - the timestamp to format\n * @param format - the date/time token\n */\n format(this: DateAdapter, timestamp: number, format: string): string;\n /**\n * Adds the specified `amount` of `unit` to the given `timestamp`.\n * @param timestamp - the input timestamp\n * @param amount - the amount to add\n * @param unit - the unit as string\n */\n add(this: DateAdapter, timestamp: number, amount: number, unit: TimeUnit): number;\n /**\n * Returns the number of `unit` between the given timestamps.\n * @param a - the input timestamp (reference)\n * @param b - the timestamp to subtract\n * @param unit - the unit as string\n */\n diff(this: DateAdapter, a: number, b: number, unit: TimeUnit): number;\n /**\n * Returns start of `unit` for the given `timestamp`.\n * @param timestamp - the input timestamp\n * @param unit - the unit as string\n * @param [weekday] - the ISO day of the week with 1 being Monday\n * and 7 being Sunday (only needed if param *unit* is `isoWeek`).\n */\n startOf(this: DateAdapter, timestamp: number, unit: TimeUnit | 'isoWeek', weekday?: number | boolean): number;\n /**\n * Returns end of `unit` for the given `timestamp`.\n * @param timestamp - the input timestamp\n * @param unit - the unit as string\n */\n endOf(this: DateAdapter, timestamp: number, unit: TimeUnit): number;\n}\n\nfunction abstract(): T {\n throw new Error('This method is not implemented: Check that a complete date adapter is provided.');\n}\n\n/**\n * Date adapter (current used by the time scale)\n * @namespace Chart._adapters._date\n * @memberof Chart._adapters\n * @private\n */\nclass DateAdapterBase implements DateAdapter {\n\n /**\n * Override default date adapter methods.\n * Accepts type parameter to define options type.\n * @example\n * Chart._adapters._date.override<{myAdapterOption: string}>({\n * init() {\n * console.log(this.options.myAdapterOption);\n * }\n * })\n */\n static override(\n members: Partial, 'options'>>\n ) {\n Object.assign(DateAdapterBase.prototype, members);\n }\n\n readonly options: AnyObject;\n\n constructor(options?: AnyObject) {\n this.options = options || {};\n }\n\n // eslint-disable-next-line @typescript-eslint/no-empty-function\n init() {}\n\n formats(): Record {\n return abstract();\n }\n\n parse(): number | null {\n return abstract();\n }\n\n format(): string {\n return abstract();\n }\n\n add(): number {\n return abstract();\n }\n\n diff(): number {\n return abstract();\n }\n\n startOf(): number {\n return abstract();\n }\n\n endOf(): number {\n return abstract();\n }\n}\n\nexport default {\n _date: DateAdapterBase as {\n new (options?: AnyObject): DateAdapter;\n override(\n members: Partial, 'options'>>\n ): void;\n }\n};\n","import {_lookupByKey, _rlookupByKey} from '../helpers/helpers.collection.js';\nimport {getRelativePosition} from '../helpers/helpers.dom.js';\nimport {_angleBetween, getAngleFromPoint} from '../helpers/helpers.math.js';\nimport {_isPointInArea, isNullOrUndef} from '../helpers/index.js';\n\n/**\n * @typedef { import('./core.controller.js').default } Chart\n * @typedef { import('../types/index.js').ChartEvent } ChartEvent\n * @typedef {{axis?: string, intersect?: boolean, includeInvisible?: boolean}} InteractionOptions\n * @typedef {{datasetIndex: number, index: number, element: import('./core.element.js').default}} InteractionItem\n * @typedef { import('../types/index.js').Point } Point\n */\n\n/**\n * Helper function to do binary search when possible\n * @param {object} metaset - the dataset meta\n * @param {string} axis - the axis mode. x|y|xy|r\n * @param {number} value - the value to find\n * @param {boolean} [intersect] - should the element intersect\n * @returns {{lo:number, hi:number}} indices to search data array between\n */\nfunction binarySearch(metaset, axis, value, intersect) {\n const {controller, data, _sorted} = metaset;\n const iScale = controller._cachedMeta.iScale;\n const spanGaps = metaset.dataset ? metaset.dataset.options ? metaset.dataset.options.spanGaps : null : null;\n\n if (iScale && axis === iScale.axis && axis !== 'r' && _sorted && data.length) {\n const lookupMethod = iScale._reversePixels ? _rlookupByKey : _lookupByKey;\n if (!intersect) {\n const result = lookupMethod(data, axis, value);\n if (spanGaps) {\n const {vScale} = controller._cachedMeta;\n const {_parsed} = metaset;\n\n const distanceToDefinedLo = (_parsed\n .slice(0, result.lo + 1)\n .reverse()\n .findIndex(\n point => !isNullOrUndef(point[vScale.axis])));\n result.lo -= Math.max(0, distanceToDefinedLo);\n\n const distanceToDefinedHi = (_parsed\n .slice(result.hi)\n .findIndex(\n point => !isNullOrUndef(point[vScale.axis])));\n result.hi += Math.max(0, distanceToDefinedHi);\n }\n return result;\n } else if (controller._sharedOptions) {\n // _sharedOptions indicates that each element has equal options -> equal proportions\n // So we can do a ranged binary search based on the range of first element and\n // be confident to get the full range of indices that can intersect with the value.\n const el = data[0];\n const range = typeof el.getRange === 'function' && el.getRange(axis);\n if (range) {\n const start = lookupMethod(data, axis, value - range);\n const end = lookupMethod(data, axis, value + range);\n return {lo: start.lo, hi: end.hi};\n }\n }\n }\n // Default to all elements, when binary search can not be used.\n return {lo: 0, hi: data.length - 1};\n}\n\n/**\n * Helper function to select candidate elements for interaction\n * @param {Chart} chart - the chart\n * @param {string} axis - the axis mode. x|y|xy|r\n * @param {Point} position - the point to be nearest to, in relative coordinates\n * @param {function} handler - the callback to execute for each visible item\n * @param {boolean} [intersect] - consider intersecting items\n */\nfunction evaluateInteractionItems(chart, axis, position, handler, intersect) {\n const metasets = chart.getSortedVisibleDatasetMetas();\n const value = position[axis];\n for (let i = 0, ilen = metasets.length; i < ilen; ++i) {\n const {index, data} = metasets[i];\n const {lo, hi} = binarySearch(metasets[i], axis, value, intersect);\n for (let j = lo; j <= hi; ++j) {\n const element = data[j];\n if (!element.skip) {\n handler(element, index, j);\n }\n }\n }\n}\n\n/**\n * Get a distance metric function for two points based on the\n * axis mode setting\n * @param {string} axis - the axis mode. x|y|xy|r\n */\nfunction getDistanceMetricForAxis(axis) {\n const useX = axis.indexOf('x') !== -1;\n const useY = axis.indexOf('y') !== -1;\n\n return function(pt1, pt2) {\n const deltaX = useX ? Math.abs(pt1.x - pt2.x) : 0;\n const deltaY = useY ? Math.abs(pt1.y - pt2.y) : 0;\n return Math.sqrt(Math.pow(deltaX, 2) + Math.pow(deltaY, 2));\n };\n}\n\n/**\n * Helper function to get the items that intersect the event position\n * @param {Chart} chart - the chart\n * @param {Point} position - the point to be nearest to, in relative coordinates\n * @param {string} axis - the axis mode. x|y|xy|r\n * @param {boolean} [useFinalPosition] - use the element's animation target instead of current position\n * @param {boolean} [includeInvisible] - include invisible points that are outside of the chart area\n * @return {InteractionItem[]} the nearest items\n */\nfunction getIntersectItems(chart, position, axis, useFinalPosition, includeInvisible) {\n const items = [];\n\n if (!includeInvisible && !chart.isPointInArea(position)) {\n return items;\n }\n\n const evaluationFunc = function(element, datasetIndex, index) {\n if (!includeInvisible && !_isPointInArea(element, chart.chartArea, 0)) {\n return;\n }\n if (element.inRange(position.x, position.y, useFinalPosition)) {\n items.push({element, datasetIndex, index});\n }\n };\n\n evaluateInteractionItems(chart, axis, position, evaluationFunc, true);\n return items;\n}\n\n/**\n * Helper function to get the items nearest to the event position for a radial chart\n * @param {Chart} chart - the chart to look at elements from\n * @param {Point} position - the point to be nearest to, in relative coordinates\n * @param {string} axis - the axes along which to measure distance\n * @param {boolean} [useFinalPosition] - use the element's animation target instead of current position\n * @return {InteractionItem[]} the nearest items\n */\nfunction getNearestRadialItems(chart, position, axis, useFinalPosition) {\n let items = [];\n\n function evaluationFunc(element, datasetIndex, index) {\n const {startAngle, endAngle} = element.getProps(['startAngle', 'endAngle'], useFinalPosition);\n const {angle} = getAngleFromPoint(element, {x: position.x, y: position.y});\n\n if (_angleBetween(angle, startAngle, endAngle)) {\n items.push({element, datasetIndex, index});\n }\n }\n\n evaluateInteractionItems(chart, axis, position, evaluationFunc);\n return items;\n}\n\n/**\n * Helper function to get the items nearest to the event position for a cartesian chart\n * @param {Chart} chart - the chart to look at elements from\n * @param {Point} position - the point to be nearest to, in relative coordinates\n * @param {string} axis - the axes along which to measure distance\n * @param {boolean} [intersect] - if true, only consider items that intersect the position\n * @param {boolean} [useFinalPosition] - use the element's animation target instead of current position\n * @param {boolean} [includeInvisible] - include invisible points that are outside of the chart area\n * @return {InteractionItem[]} the nearest items\n */\nfunction getNearestCartesianItems(chart, position, axis, intersect, useFinalPosition, includeInvisible) {\n let items = [];\n const distanceMetric = getDistanceMetricForAxis(axis);\n let minDistance = Number.POSITIVE_INFINITY;\n\n function evaluationFunc(element, datasetIndex, index) {\n const inRange = element.inRange(position.x, position.y, useFinalPosition);\n if (intersect && !inRange) {\n return;\n }\n\n const center = element.getCenterPoint(useFinalPosition);\n const pointInArea = !!includeInvisible || chart.isPointInArea(center);\n if (!pointInArea && !inRange) {\n return;\n }\n\n const distance = distanceMetric(position, center);\n if (distance < minDistance) {\n items = [{element, datasetIndex, index}];\n minDistance = distance;\n } else if (distance === minDistance) {\n // Can have multiple items at the same distance in which case we sort by size\n items.push({element, datasetIndex, index});\n }\n }\n\n evaluateInteractionItems(chart, axis, position, evaluationFunc);\n return items;\n}\n\n/**\n * Helper function to get the items nearest to the event position considering all visible items in the chart\n * @param {Chart} chart - the chart to look at elements from\n * @param {Point} position - the point to be nearest to, in relative coordinates\n * @param {string} axis - the axes along which to measure distance\n * @param {boolean} [intersect] - if true, only consider items that intersect the position\n * @param {boolean} [useFinalPosition] - use the element's animation target instead of current position\n * @param {boolean} [includeInvisible] - include invisible points that are outside of the chart area\n * @return {InteractionItem[]} the nearest items\n */\nfunction getNearestItems(chart, position, axis, intersect, useFinalPosition, includeInvisible) {\n if (!includeInvisible && !chart.isPointInArea(position)) {\n return [];\n }\n\n return axis === 'r' && !intersect\n ? getNearestRadialItems(chart, position, axis, useFinalPosition)\n : getNearestCartesianItems(chart, position, axis, intersect, useFinalPosition, includeInvisible);\n}\n\n/**\n * Helper function to get the items matching along the given X or Y axis\n * @param {Chart} chart - the chart to look at elements from\n * @param {Point} position - the point to be nearest to, in relative coordinates\n * @param {string} axis - the axis to match\n * @param {boolean} [intersect] - if true, only consider items that intersect the position\n * @param {boolean} [useFinalPosition] - use the element's animation target instead of current position\n * @return {InteractionItem[]} the nearest items\n */\nfunction getAxisItems(chart, position, axis, intersect, useFinalPosition) {\n const items = [];\n const rangeMethod = axis === 'x' ? 'inXRange' : 'inYRange';\n let intersectsItem = false;\n\n evaluateInteractionItems(chart, axis, position, (element, datasetIndex, index) => {\n if (element[rangeMethod] && element[rangeMethod](position[axis], useFinalPosition)) {\n items.push({element, datasetIndex, index});\n intersectsItem = intersectsItem || element.inRange(position.x, position.y, useFinalPosition);\n }\n });\n\n // If we want to trigger on an intersect and we don't have any items\n // that intersect the position, return nothing\n if (intersect && !intersectsItem) {\n return [];\n }\n return items;\n}\n\n/**\n * Contains interaction related functions\n * @namespace Chart.Interaction\n */\nexport default {\n // Part of the public API to facilitate developers creating their own modes\n evaluateInteractionItems,\n\n // Helper function for different modes\n modes: {\n /**\n\t\t * Returns items at the same index. If the options.intersect parameter is true, we only return items if we intersect something\n\t\t * If the options.intersect mode is false, we find the nearest item and return the items at the same index as that item\n\t\t * @function Chart.Interaction.modes.index\n\t\t * @since v2.4.0\n\t\t * @param {Chart} chart - the chart we are returning items from\n\t\t * @param {Event} e - the event we are find things at\n\t\t * @param {InteractionOptions} options - options to use\n\t\t * @param {boolean} [useFinalPosition] - use final element position (animation target)\n\t\t * @return {InteractionItem[]} - items that are found\n\t\t */\n index(chart, e, options, useFinalPosition) {\n const position = getRelativePosition(e, chart);\n // Default axis for index mode is 'x' to match old behaviour\n const axis = options.axis || 'x';\n const includeInvisible = options.includeInvisible || false;\n const items = options.intersect\n ? getIntersectItems(chart, position, axis, useFinalPosition, includeInvisible)\n : getNearestItems(chart, position, axis, false, useFinalPosition, includeInvisible);\n const elements = [];\n\n if (!items.length) {\n return [];\n }\n\n chart.getSortedVisibleDatasetMetas().forEach((meta) => {\n const index = items[0].index;\n const element = meta.data[index];\n\n // don't count items that are skipped (null data)\n if (element && !element.skip) {\n elements.push({element, datasetIndex: meta.index, index});\n }\n });\n\n return elements;\n },\n\n /**\n\t\t * Returns items in the same dataset. If the options.intersect parameter is true, we only return items if we intersect something\n\t\t * If the options.intersect is false, we find the nearest item and return the items in that dataset\n\t\t * @function Chart.Interaction.modes.dataset\n\t\t * @param {Chart} chart - the chart we are returning items from\n\t\t * @param {Event} e - the event we are find things at\n\t\t * @param {InteractionOptions} options - options to use\n\t\t * @param {boolean} [useFinalPosition] - use final element position (animation target)\n\t\t * @return {InteractionItem[]} - items that are found\n\t\t */\n dataset(chart, e, options, useFinalPosition) {\n const position = getRelativePosition(e, chart);\n const axis = options.axis || 'xy';\n const includeInvisible = options.includeInvisible || false;\n let items = options.intersect\n ? getIntersectItems(chart, position, axis, useFinalPosition, includeInvisible) :\n getNearestItems(chart, position, axis, false, useFinalPosition, includeInvisible);\n\n if (items.length > 0) {\n const datasetIndex = items[0].datasetIndex;\n const data = chart.getDatasetMeta(datasetIndex).data;\n items = [];\n for (let i = 0; i < data.length; ++i) {\n items.push({element: data[i], datasetIndex, index: i});\n }\n }\n\n return items;\n },\n\n /**\n\t\t * Point mode returns all elements that hit test based on the event position\n\t\t * of the event\n\t\t * @function Chart.Interaction.modes.intersect\n\t\t * @param {Chart} chart - the chart we are returning items from\n\t\t * @param {Event} e - the event we are find things at\n\t\t * @param {InteractionOptions} options - options to use\n\t\t * @param {boolean} [useFinalPosition] - use final element position (animation target)\n\t\t * @return {InteractionItem[]} - items that are found\n\t\t */\n point(chart, e, options, useFinalPosition) {\n const position = getRelativePosition(e, chart);\n const axis = options.axis || 'xy';\n const includeInvisible = options.includeInvisible || false;\n return getIntersectItems(chart, position, axis, useFinalPosition, includeInvisible);\n },\n\n /**\n\t\t * nearest mode returns the element closest to the point\n\t\t * @function Chart.Interaction.modes.intersect\n\t\t * @param {Chart} chart - the chart we are returning items from\n\t\t * @param {Event} e - the event we are find things at\n\t\t * @param {InteractionOptions} options - options to use\n\t\t * @param {boolean} [useFinalPosition] - use final element position (animation target)\n\t\t * @return {InteractionItem[]} - items that are found\n\t\t */\n nearest(chart, e, options, useFinalPosition) {\n const position = getRelativePosition(e, chart);\n const axis = options.axis || 'xy';\n const includeInvisible = options.includeInvisible || false;\n return getNearestItems(chart, position, axis, options.intersect, useFinalPosition, includeInvisible);\n },\n\n /**\n\t\t * x mode returns the elements that hit-test at the current x coordinate\n\t\t * @function Chart.Interaction.modes.x\n\t\t * @param {Chart} chart - the chart we are returning items from\n\t\t * @param {Event} e - the event we are find things at\n\t\t * @param {InteractionOptions} options - options to use\n\t\t * @param {boolean} [useFinalPosition] - use final element position (animation target)\n\t\t * @return {InteractionItem[]} - items that are found\n\t\t */\n x(chart, e, options, useFinalPosition) {\n const position = getRelativePosition(e, chart);\n return getAxisItems(chart, position, 'x', options.intersect, useFinalPosition);\n },\n\n /**\n\t\t * y mode returns the elements that hit-test at the current y coordinate\n\t\t * @function Chart.Interaction.modes.y\n\t\t * @param {Chart} chart - the chart we are returning items from\n\t\t * @param {Event} e - the event we are find things at\n\t\t * @param {InteractionOptions} options - options to use\n\t\t * @param {boolean} [useFinalPosition] - use final element position (animation target)\n\t\t * @return {InteractionItem[]} - items that are found\n\t\t */\n y(chart, e, options, useFinalPosition) {\n const position = getRelativePosition(e, chart);\n return getAxisItems(chart, position, 'y', options.intersect, useFinalPosition);\n }\n }\n};\n","import {defined, each, isObject} from '../helpers/helpers.core.js';\nimport {toPadding} from '../helpers/helpers.options.js';\n\n/**\n * @typedef { import('./core.controller.js').default } Chart\n */\n\nconst STATIC_POSITIONS = ['left', 'top', 'right', 'bottom'];\n\nfunction filterByPosition(array, position) {\n return array.filter(v => v.pos === position);\n}\n\nfunction filterDynamicPositionByAxis(array, axis) {\n return array.filter(v => STATIC_POSITIONS.indexOf(v.pos) === -1 && v.box.axis === axis);\n}\n\nfunction sortByWeight(array, reverse) {\n return array.sort((a, b) => {\n const v0 = reverse ? b : a;\n const v1 = reverse ? a : b;\n return v0.weight === v1.weight ?\n v0.index - v1.index :\n v0.weight - v1.weight;\n });\n}\n\nfunction wrapBoxes(boxes) {\n const layoutBoxes = [];\n let i, ilen, box, pos, stack, stackWeight;\n\n for (i = 0, ilen = (boxes || []).length; i < ilen; ++i) {\n box = boxes[i];\n ({position: pos, options: {stack, stackWeight = 1}} = box);\n layoutBoxes.push({\n index: i,\n box,\n pos,\n horizontal: box.isHorizontal(),\n weight: box.weight,\n stack: stack && (pos + stack),\n stackWeight\n });\n }\n return layoutBoxes;\n}\n\nfunction buildStacks(layouts) {\n const stacks = {};\n for (const wrap of layouts) {\n const {stack, pos, stackWeight} = wrap;\n if (!stack || !STATIC_POSITIONS.includes(pos)) {\n continue;\n }\n const _stack = stacks[stack] || (stacks[stack] = {count: 0, placed: 0, weight: 0, size: 0});\n _stack.count++;\n _stack.weight += stackWeight;\n }\n return stacks;\n}\n\n/**\n * store dimensions used instead of available chartArea in fitBoxes\n **/\nfunction setLayoutDims(layouts, params) {\n const stacks = buildStacks(layouts);\n const {vBoxMaxWidth, hBoxMaxHeight} = params;\n let i, ilen, layout;\n for (i = 0, ilen = layouts.length; i < ilen; ++i) {\n layout = layouts[i];\n const {fullSize} = layout.box;\n const stack = stacks[layout.stack];\n const factor = stack && layout.stackWeight / stack.weight;\n if (layout.horizontal) {\n layout.width = factor ? factor * vBoxMaxWidth : fullSize && params.availableWidth;\n layout.height = hBoxMaxHeight;\n } else {\n layout.width = vBoxMaxWidth;\n layout.height = factor ? factor * hBoxMaxHeight : fullSize && params.availableHeight;\n }\n }\n return stacks;\n}\n\nfunction buildLayoutBoxes(boxes) {\n const layoutBoxes = wrapBoxes(boxes);\n const fullSize = sortByWeight(layoutBoxes.filter(wrap => wrap.box.fullSize), true);\n const left = sortByWeight(filterByPosition(layoutBoxes, 'left'), true);\n const right = sortByWeight(filterByPosition(layoutBoxes, 'right'));\n const top = sortByWeight(filterByPosition(layoutBoxes, 'top'), true);\n const bottom = sortByWeight(filterByPosition(layoutBoxes, 'bottom'));\n const centerHorizontal = filterDynamicPositionByAxis(layoutBoxes, 'x');\n const centerVertical = filterDynamicPositionByAxis(layoutBoxes, 'y');\n\n return {\n fullSize,\n leftAndTop: left.concat(top),\n rightAndBottom: right.concat(centerVertical).concat(bottom).concat(centerHorizontal),\n chartArea: filterByPosition(layoutBoxes, 'chartArea'),\n vertical: left.concat(right).concat(centerVertical),\n horizontal: top.concat(bottom).concat(centerHorizontal)\n };\n}\n\nfunction getCombinedMax(maxPadding, chartArea, a, b) {\n return Math.max(maxPadding[a], chartArea[a]) + Math.max(maxPadding[b], chartArea[b]);\n}\n\nfunction updateMaxPadding(maxPadding, boxPadding) {\n maxPadding.top = Math.max(maxPadding.top, boxPadding.top);\n maxPadding.left = Math.max(maxPadding.left, boxPadding.left);\n maxPadding.bottom = Math.max(maxPadding.bottom, boxPadding.bottom);\n maxPadding.right = Math.max(maxPadding.right, boxPadding.right);\n}\n\nfunction updateDims(chartArea, params, layout, stacks) {\n const {pos, box} = layout;\n const maxPadding = chartArea.maxPadding;\n\n // dynamically placed boxes size is not considered\n if (!isObject(pos)) {\n if (layout.size) {\n // this layout was already counted for, lets first reduce old size\n chartArea[pos] -= layout.size;\n }\n const stack = stacks[layout.stack] || {size: 0, count: 1};\n stack.size = Math.max(stack.size, layout.horizontal ? box.height : box.width);\n layout.size = stack.size / stack.count;\n chartArea[pos] += layout.size;\n }\n\n if (box.getPadding) {\n updateMaxPadding(maxPadding, box.getPadding());\n }\n\n const newWidth = Math.max(0, params.outerWidth - getCombinedMax(maxPadding, chartArea, 'left', 'right'));\n const newHeight = Math.max(0, params.outerHeight - getCombinedMax(maxPadding, chartArea, 'top', 'bottom'));\n const widthChanged = newWidth !== chartArea.w;\n const heightChanged = newHeight !== chartArea.h;\n chartArea.w = newWidth;\n chartArea.h = newHeight;\n\n // return booleans on the changes per direction\n return layout.horizontal\n ? {same: widthChanged, other: heightChanged}\n : {same: heightChanged, other: widthChanged};\n}\n\nfunction handleMaxPadding(chartArea) {\n const maxPadding = chartArea.maxPadding;\n\n function updatePos(pos) {\n const change = Math.max(maxPadding[pos] - chartArea[pos], 0);\n chartArea[pos] += change;\n return change;\n }\n chartArea.y += updatePos('top');\n chartArea.x += updatePos('left');\n updatePos('right');\n updatePos('bottom');\n}\n\nfunction getMargins(horizontal, chartArea) {\n const maxPadding = chartArea.maxPadding;\n\n function marginForPositions(positions) {\n const margin = {left: 0, top: 0, right: 0, bottom: 0};\n positions.forEach((pos) => {\n margin[pos] = Math.max(chartArea[pos], maxPadding[pos]);\n });\n return margin;\n }\n\n return horizontal\n ? marginForPositions(['left', 'right'])\n : marginForPositions(['top', 'bottom']);\n}\n\nfunction fitBoxes(boxes, chartArea, params, stacks) {\n const refitBoxes = [];\n let i, ilen, layout, box, refit, changed;\n\n for (i = 0, ilen = boxes.length, refit = 0; i < ilen; ++i) {\n layout = boxes[i];\n box = layout.box;\n\n box.update(\n layout.width || chartArea.w,\n layout.height || chartArea.h,\n getMargins(layout.horizontal, chartArea)\n );\n const {same, other} = updateDims(chartArea, params, layout, stacks);\n\n // Dimensions changed and there were non full width boxes before this\n // -> we have to refit those\n refit |= same && refitBoxes.length;\n\n // Chart area changed in the opposite direction\n changed = changed || other;\n\n if (!box.fullSize) { // fullSize boxes don't need to be re-fitted in any case\n refitBoxes.push(layout);\n }\n }\n\n return refit && fitBoxes(refitBoxes, chartArea, params, stacks) || changed;\n}\n\nfunction setBoxDims(box, left, top, width, height) {\n box.top = top;\n box.left = left;\n box.right = left + width;\n box.bottom = top + height;\n box.width = width;\n box.height = height;\n}\n\nfunction placeBoxes(boxes, chartArea, params, stacks) {\n const userPadding = params.padding;\n let {x, y} = chartArea;\n\n for (const layout of boxes) {\n const box = layout.box;\n const stack = stacks[layout.stack] || {count: 1, placed: 0, weight: 1};\n const weight = (layout.stackWeight / stack.weight) || 1;\n if (layout.horizontal) {\n const width = chartArea.w * weight;\n const height = stack.size || box.height;\n if (defined(stack.start)) {\n y = stack.start;\n }\n if (box.fullSize) {\n setBoxDims(box, userPadding.left, y, params.outerWidth - userPadding.right - userPadding.left, height);\n } else {\n setBoxDims(box, chartArea.left + stack.placed, y, width, height);\n }\n stack.start = y;\n stack.placed += width;\n y = box.bottom;\n } else {\n const height = chartArea.h * weight;\n const width = stack.size || box.width;\n if (defined(stack.start)) {\n x = stack.start;\n }\n if (box.fullSize) {\n setBoxDims(box, x, userPadding.top, width, params.outerHeight - userPadding.bottom - userPadding.top);\n } else {\n setBoxDims(box, x, chartArea.top + stack.placed, width, height);\n }\n stack.start = x;\n stack.placed += height;\n x = box.right;\n }\n }\n\n chartArea.x = x;\n chartArea.y = y;\n}\n\n/**\n * @interface LayoutItem\n * @typedef {object} LayoutItem\n * @prop {string} position - The position of the item in the chart layout. Possible values are\n * 'left', 'top', 'right', 'bottom', and 'chartArea'\n * @prop {number} weight - The weight used to sort the item. Higher weights are further away from the chart area\n * @prop {boolean} fullSize - if true, and the item is horizontal, then push vertical boxes down\n * @prop {function} isHorizontal - returns true if the layout item is horizontal (ie. top or bottom)\n * @prop {function} update - Takes two parameters: width and height. Returns size of item\n * @prop {function} draw - Draws the element\n * @prop {function} [getPadding] - Returns an object with padding on the edges\n * @prop {number} width - Width of item. Must be valid after update()\n * @prop {number} height - Height of item. Must be valid after update()\n * @prop {number} left - Left edge of the item. Set by layout system and cannot be used in update\n * @prop {number} top - Top edge of the item. Set by layout system and cannot be used in update\n * @prop {number} right - Right edge of the item. Set by layout system and cannot be used in update\n * @prop {number} bottom - Bottom edge of the item. Set by layout system and cannot be used in update\n */\n\n// The layout service is very self explanatory. It's responsible for the layout within a chart.\n// Scales, Legends and Plugins all rely on the layout service and can easily register to be placed anywhere they need\n// It is this service's responsibility of carrying out that layout.\nexport default {\n\n /**\n\t * Register a box to a chart.\n\t * A box is simply a reference to an object that requires layout. eg. Scales, Legend, Title.\n\t * @param {Chart} chart - the chart to use\n\t * @param {LayoutItem} item - the item to add to be laid out\n\t */\n addBox(chart, item) {\n if (!chart.boxes) {\n chart.boxes = [];\n }\n\n // initialize item with default values\n item.fullSize = item.fullSize || false;\n item.position = item.position || 'top';\n item.weight = item.weight || 0;\n // @ts-ignore\n item._layers = item._layers || function() {\n return [{\n z: 0,\n draw(chartArea) {\n item.draw(chartArea);\n }\n }];\n };\n\n chart.boxes.push(item);\n },\n\n /**\n\t * Remove a layoutItem from a chart\n\t * @param {Chart} chart - the chart to remove the box from\n\t * @param {LayoutItem} layoutItem - the item to remove from the layout\n\t */\n removeBox(chart, layoutItem) {\n const index = chart.boxes ? chart.boxes.indexOf(layoutItem) : -1;\n if (index !== -1) {\n chart.boxes.splice(index, 1);\n }\n },\n\n /**\n\t * Sets (or updates) options on the given `item`.\n\t * @param {Chart} chart - the chart in which the item lives (or will be added to)\n\t * @param {LayoutItem} item - the item to configure with the given options\n\t * @param {object} options - the new item options.\n\t */\n configure(chart, item, options) {\n item.fullSize = options.fullSize;\n item.position = options.position;\n item.weight = options.weight;\n },\n\n /**\n\t * Fits boxes of the given chart into the given size by having each box measure itself\n\t * then running a fitting algorithm\n\t * @param {Chart} chart - the chart\n\t * @param {number} width - the width to fit into\n\t * @param {number} height - the height to fit into\n * @param {number} minPadding - minimum padding required for each side of chart area\n\t */\n update(chart, width, height, minPadding) {\n if (!chart) {\n return;\n }\n\n const padding = toPadding(chart.options.layout.padding);\n const availableWidth = Math.max(width - padding.width, 0);\n const availableHeight = Math.max(height - padding.height, 0);\n const boxes = buildLayoutBoxes(chart.boxes);\n const verticalBoxes = boxes.vertical;\n const horizontalBoxes = boxes.horizontal;\n\n // Before any changes are made, notify boxes that an update is about to being\n // This is used to clear any cached data (e.g. scale limits)\n each(chart.boxes, box => {\n if (typeof box.beforeLayout === 'function') {\n box.beforeLayout();\n }\n });\n\n // Essentially we now have any number of boxes on each of the 4 sides.\n // Our canvas looks like the following.\n // The areas L1 and L2 are the left axes. R1 is the right axis, T1 is the top axis and\n // B1 is the bottom axis\n // There are also 4 quadrant-like locations (left to right instead of clockwise) reserved for chart overlays\n // These locations are single-box locations only, when trying to register a chartArea location that is already taken,\n // an error will be thrown.\n //\n // |----------------------------------------------------|\n // | T1 (Full Width) |\n // |----------------------------------------------------|\n // | | | T2 | |\n // | |----|-------------------------------------|----|\n // | | | C1 | | C2 | |\n // | | |----| |----| |\n // | | | | |\n // | L1 | L2 | ChartArea (C0) | R1 |\n // | | | | |\n // | | |----| |----| |\n // | | | C3 | | C4 | |\n // | |----|-------------------------------------|----|\n // | | | B1 | |\n // |----------------------------------------------------|\n // | B2 (Full Width) |\n // |----------------------------------------------------|\n //\n\n const visibleVerticalBoxCount = verticalBoxes.reduce((total, wrap) =>\n wrap.box.options && wrap.box.options.display === false ? total : total + 1, 0) || 1;\n\n const params = Object.freeze({\n outerWidth: width,\n outerHeight: height,\n padding,\n availableWidth,\n availableHeight,\n vBoxMaxWidth: availableWidth / 2 / visibleVerticalBoxCount,\n hBoxMaxHeight: availableHeight / 2\n });\n const maxPadding = Object.assign({}, padding);\n updateMaxPadding(maxPadding, toPadding(minPadding));\n const chartArea = Object.assign({\n maxPadding,\n w: availableWidth,\n h: availableHeight,\n x: padding.left,\n y: padding.top\n }, padding);\n\n const stacks = setLayoutDims(verticalBoxes.concat(horizontalBoxes), params);\n\n // First fit the fullSize boxes, to reduce probability of re-fitting.\n fitBoxes(boxes.fullSize, chartArea, params, stacks);\n\n // Then fit vertical boxes\n fitBoxes(verticalBoxes, chartArea, params, stacks);\n\n // Then fit horizontal boxes\n if (fitBoxes(horizontalBoxes, chartArea, params, stacks)) {\n // if the area changed, re-fit vertical boxes\n fitBoxes(verticalBoxes, chartArea, params, stacks);\n }\n\n handleMaxPadding(chartArea);\n\n // Finally place the boxes to correct coordinates\n placeBoxes(boxes.leftAndTop, chartArea, params, stacks);\n\n // Move to opposite side of chart\n chartArea.x += chartArea.w;\n chartArea.y += chartArea.h;\n\n placeBoxes(boxes.rightAndBottom, chartArea, params, stacks);\n\n chart.chartArea = {\n left: chartArea.left,\n top: chartArea.top,\n right: chartArea.left + chartArea.w,\n bottom: chartArea.top + chartArea.h,\n height: chartArea.h,\n width: chartArea.w,\n };\n\n // Finally update boxes in chartArea (radial scale for example)\n each(boxes.chartArea, (layout) => {\n const box = layout.box;\n Object.assign(box, chart.chartArea);\n box.update(chartArea.w, chartArea.h, {left: 0, top: 0, right: 0, bottom: 0});\n });\n }\n};\n","\n/**\n * @typedef { import('../core/core.controller.js').default } Chart\n */\n\n/**\n * Abstract class that allows abstracting platform dependencies away from the chart.\n */\nexport default class BasePlatform {\n /**\n\t * Called at chart construction time, returns a context2d instance implementing\n\t * the [W3C Canvas 2D Context API standard]{@link https://www.w3.org/TR/2dcontext/}.\n\t * @param {HTMLCanvasElement} canvas - The canvas from which to acquire context (platform specific)\n\t * @param {number} [aspectRatio] - The chart options\n\t */\n acquireContext(canvas, aspectRatio) {} // eslint-disable-line no-unused-vars\n\n /**\n\t * Called at chart destruction time, releases any resources associated to the context\n\t * previously returned by the acquireContext() method.\n\t * @param {CanvasRenderingContext2D} context - The context2d instance\n\t * @returns {boolean} true if the method succeeded, else false\n\t */\n releaseContext(context) { // eslint-disable-line no-unused-vars\n return false;\n }\n\n /**\n\t * Registers the specified listener on the given chart.\n\t * @param {Chart} chart - Chart from which to listen for event\n\t * @param {string} type - The ({@link ChartEvent}) type to listen for\n\t * @param {function} listener - Receives a notification (an object that implements\n\t * the {@link ChartEvent} interface) when an event of the specified type occurs.\n\t */\n addEventListener(chart, type, listener) {} // eslint-disable-line no-unused-vars\n\n /**\n\t * Removes the specified listener previously registered with addEventListener.\n\t * @param {Chart} chart - Chart from which to remove the listener\n\t * @param {string} type - The ({@link ChartEvent}) type to remove\n\t * @param {function} listener - The listener function to remove from the event target.\n\t */\n removeEventListener(chart, type, listener) {} // eslint-disable-line no-unused-vars\n\n /**\n\t * @returns {number} the current devicePixelRatio of the device this platform is connected to.\n\t */\n getDevicePixelRatio() {\n return 1;\n }\n\n /**\n\t * Returns the maximum size in pixels of given canvas element.\n\t * @param {HTMLCanvasElement} element\n\t * @param {number} [width] - content width of parent element\n\t * @param {number} [height] - content height of parent element\n\t * @param {number} [aspectRatio] - aspect ratio to maintain\n\t */\n getMaximumSize(element, width, height, aspectRatio) {\n width = Math.max(0, width || element.width);\n height = height || element.height;\n return {\n width,\n height: Math.max(0, aspectRatio ? Math.floor(width / aspectRatio) : height)\n };\n }\n\n /**\n\t * @param {HTMLCanvasElement} canvas\n\t * @returns {boolean} true if the canvas is attached to the platform, false if not.\n\t */\n isAttached(canvas) { // eslint-disable-line no-unused-vars\n return true;\n }\n\n /**\n * Updates config with platform specific requirements\n * @param {import('../core/core.config.js').default} config\n */\n updateConfig(config) { // eslint-disable-line no-unused-vars\n // no-op\n }\n}\n","/**\n * Platform fallback implementation (minimal).\n * @see https://github.com/chartjs/Chart.js/pull/4591#issuecomment-319575939\n */\n\nimport BasePlatform from './platform.base.js';\n\n/**\n * Platform class for charts without access to the DOM or to many element properties\n * This platform is used by default for any chart passed an OffscreenCanvas.\n * @extends BasePlatform\n */\nexport default class BasicPlatform extends BasePlatform {\n acquireContext(item) {\n // To prevent canvas fingerprinting, some add-ons undefine the getContext\n // method, for example: https://github.com/kkapsner/CanvasBlocker\n // https://github.com/chartjs/Chart.js/issues/2807\n return item && item.getContext && item.getContext('2d') || null;\n }\n updateConfig(config) {\n config.options.animation = false;\n }\n}\n","/**\n * Chart.Platform implementation for targeting a web browser\n */\n\nimport BasePlatform from './platform.base.js';\nimport {_getParentNode, getRelativePosition, supportsEventListenerOptions, readUsedSize, getMaximumSize} from '../helpers/helpers.dom.js';\nimport {throttled} from '../helpers/helpers.extras.js';\nimport {isNullOrUndef} from '../helpers/helpers.core.js';\n\n/**\n * @typedef { import('../core/core.controller.js').default } Chart\n */\n\nconst EXPANDO_KEY = '$chartjs';\n\n/**\n * DOM event types -> Chart.js event types.\n * Note: only events with different types are mapped.\n * @see https://developer.mozilla.org/en-US/docs/Web/Events\n */\nconst EVENT_TYPES = {\n touchstart: 'mousedown',\n touchmove: 'mousemove',\n touchend: 'mouseup',\n pointerenter: 'mouseenter',\n pointerdown: 'mousedown',\n pointermove: 'mousemove',\n pointerup: 'mouseup',\n pointerleave: 'mouseout',\n pointerout: 'mouseout'\n};\n\nconst isNullOrEmpty = value => value === null || value === '';\n/**\n * Initializes the canvas style and render size without modifying the canvas display size,\n * since responsiveness is handled by the controller.resize() method. The config is used\n * to determine the aspect ratio to apply in case no explicit height has been specified.\n * @param {HTMLCanvasElement} canvas\n * @param {number} [aspectRatio]\n */\nfunction initCanvas(canvas, aspectRatio) {\n const style = canvas.style;\n\n // NOTE(SB) canvas.getAttribute('width') !== canvas.width: in the first case it\n // returns null or '' if no explicit value has been set to the canvas attribute.\n const renderHeight = canvas.getAttribute('height');\n const renderWidth = canvas.getAttribute('width');\n\n // Chart.js modifies some canvas values that we want to restore on destroy\n canvas[EXPANDO_KEY] = {\n initial: {\n height: renderHeight,\n width: renderWidth,\n style: {\n display: style.display,\n height: style.height,\n width: style.width\n }\n }\n };\n\n // Force canvas to display as block to avoid extra space caused by inline\n // elements, which would interfere with the responsive resize process.\n // https://github.com/chartjs/Chart.js/issues/2538\n style.display = style.display || 'block';\n // Include possible borders in the size\n style.boxSizing = style.boxSizing || 'border-box';\n\n if (isNullOrEmpty(renderWidth)) {\n const displayWidth = readUsedSize(canvas, 'width');\n if (displayWidth !== undefined) {\n canvas.width = displayWidth;\n }\n }\n\n if (isNullOrEmpty(renderHeight)) {\n if (canvas.style.height === '') {\n // If no explicit render height and style height, let's apply the aspect ratio,\n // which one can be specified by the user but also by charts as default option\n // (i.e. options.aspectRatio). If not specified, use canvas aspect ratio of 2.\n canvas.height = canvas.width / (aspectRatio || 2);\n } else {\n const displayHeight = readUsedSize(canvas, 'height');\n if (displayHeight !== undefined) {\n canvas.height = displayHeight;\n }\n }\n }\n\n return canvas;\n}\n\n// Default passive to true as expected by Chrome for 'touchstart' and 'touchend' events.\n// https://github.com/chartjs/Chart.js/issues/4287\nconst eventListenerOptions = supportsEventListenerOptions ? {passive: true} : false;\n\nfunction addListener(node, type, listener) {\n if (node) {\n node.addEventListener(type, listener, eventListenerOptions);\n }\n}\n\nfunction removeListener(chart, type, listener) {\n if (chart && chart.canvas) {\n chart.canvas.removeEventListener(type, listener, eventListenerOptions);\n }\n}\n\nfunction fromNativeEvent(event, chart) {\n const type = EVENT_TYPES[event.type] || event.type;\n const {x, y} = getRelativePosition(event, chart);\n return {\n type,\n chart,\n native: event,\n x: x !== undefined ? x : null,\n y: y !== undefined ? y : null,\n };\n}\n\nfunction nodeListContains(nodeList, canvas) {\n for (const node of nodeList) {\n if (node === canvas || node.contains(canvas)) {\n return true;\n }\n }\n}\n\nfunction createAttachObserver(chart, type, listener) {\n const canvas = chart.canvas;\n const observer = new MutationObserver(entries => {\n let trigger = false;\n for (const entry of entries) {\n trigger = trigger || nodeListContains(entry.addedNodes, canvas);\n trigger = trigger && !nodeListContains(entry.removedNodes, canvas);\n }\n if (trigger) {\n listener();\n }\n });\n observer.observe(document, {childList: true, subtree: true});\n return observer;\n}\n\nfunction createDetachObserver(chart, type, listener) {\n const canvas = chart.canvas;\n const observer = new MutationObserver(entries => {\n let trigger = false;\n for (const entry of entries) {\n trigger = trigger || nodeListContains(entry.removedNodes, canvas);\n trigger = trigger && !nodeListContains(entry.addedNodes, canvas);\n }\n if (trigger) {\n listener();\n }\n });\n observer.observe(document, {childList: true, subtree: true});\n return observer;\n}\n\nconst drpListeningCharts = new Map();\nlet oldDevicePixelRatio = 0;\n\nfunction onWindowResize() {\n const dpr = window.devicePixelRatio;\n if (dpr === oldDevicePixelRatio) {\n return;\n }\n oldDevicePixelRatio = dpr;\n drpListeningCharts.forEach((resize, chart) => {\n if (chart.currentDevicePixelRatio !== dpr) {\n resize();\n }\n });\n}\n\nfunction listenDevicePixelRatioChanges(chart, resize) {\n if (!drpListeningCharts.size) {\n window.addEventListener('resize', onWindowResize);\n }\n drpListeningCharts.set(chart, resize);\n}\n\nfunction unlistenDevicePixelRatioChanges(chart) {\n drpListeningCharts.delete(chart);\n if (!drpListeningCharts.size) {\n window.removeEventListener('resize', onWindowResize);\n }\n}\n\nfunction createResizeObserver(chart, type, listener) {\n const canvas = chart.canvas;\n const container = canvas && _getParentNode(canvas);\n if (!container) {\n return;\n }\n const resize = throttled((width, height) => {\n const w = container.clientWidth;\n listener(width, height);\n if (w < container.clientWidth) {\n // If the container size shrank during chart resize, let's assume\n // scrollbar appeared. So we resize again with the scrollbar visible -\n // effectively making chart smaller and the scrollbar hidden again.\n // Because we are inside `throttled`, and currently `ticking`, scroll\n // events are ignored during this whole 2 resize process.\n // If we assumed wrong and something else happened, we are resizing\n // twice in a frame (potential performance issue)\n listener();\n }\n }, window);\n\n // @ts-ignore until https://github.com/microsoft/TypeScript/issues/37861 implemented\n const observer = new ResizeObserver(entries => {\n const entry = entries[0];\n const width = entry.contentRect.width;\n const height = entry.contentRect.height;\n // When its container's display is set to 'none' the callback will be called with a\n // size of (0, 0), which will cause the chart to lose its original height, so skip\n // resizing in such case.\n if (width === 0 && height === 0) {\n return;\n }\n resize(width, height);\n });\n observer.observe(container);\n listenDevicePixelRatioChanges(chart, resize);\n\n return observer;\n}\n\nfunction releaseObserver(chart, type, observer) {\n if (observer) {\n observer.disconnect();\n }\n if (type === 'resize') {\n unlistenDevicePixelRatioChanges(chart);\n }\n}\n\nfunction createProxyAndListen(chart, type, listener) {\n const canvas = chart.canvas;\n const proxy = throttled((event) => {\n // This case can occur if the chart is destroyed while waiting\n // for the throttled function to occur. We prevent crashes by checking\n // for a destroyed chart\n if (chart.ctx !== null) {\n listener(fromNativeEvent(event, chart));\n }\n }, chart);\n\n addListener(canvas, type, proxy);\n\n return proxy;\n}\n\n/**\n * Platform class for charts that can access the DOM and global window/document properties\n * @extends BasePlatform\n */\nexport default class DomPlatform extends BasePlatform {\n\n /**\n\t * @param {HTMLCanvasElement} canvas\n\t * @param {number} [aspectRatio]\n\t * @return {CanvasRenderingContext2D|null}\n\t */\n acquireContext(canvas, aspectRatio) {\n // To prevent canvas fingerprinting, some add-ons undefine the getContext\n // method, for example: https://github.com/kkapsner/CanvasBlocker\n // https://github.com/chartjs/Chart.js/issues/2807\n const context = canvas && canvas.getContext && canvas.getContext('2d');\n\n // `instanceof HTMLCanvasElement/CanvasRenderingContext2D` fails when the canvas is\n // inside an iframe or when running in a protected environment. We could guess the\n // types from their toString() value but let's keep things flexible and assume it's\n // a sufficient condition if the canvas has a context2D which has canvas as `canvas`.\n // https://github.com/chartjs/Chart.js/issues/3887\n // https://github.com/chartjs/Chart.js/issues/4102\n // https://github.com/chartjs/Chart.js/issues/4152\n if (context && context.canvas === canvas) {\n // Load platform resources on first chart creation, to make it possible to\n // import the library before setting platform options.\n initCanvas(canvas, aspectRatio);\n return context;\n }\n\n return null;\n }\n\n /**\n\t * @param {CanvasRenderingContext2D} context\n\t */\n releaseContext(context) {\n const canvas = context.canvas;\n if (!canvas[EXPANDO_KEY]) {\n return false;\n }\n\n const initial = canvas[EXPANDO_KEY].initial;\n ['height', 'width'].forEach((prop) => {\n const value = initial[prop];\n if (isNullOrUndef(value)) {\n canvas.removeAttribute(prop);\n } else {\n canvas.setAttribute(prop, value);\n }\n });\n\n const style = initial.style || {};\n Object.keys(style).forEach((key) => {\n canvas.style[key] = style[key];\n });\n\n // The canvas render size might have been changed (and thus the state stack discarded),\n // we can't use save() and restore() to restore the initial state. So make sure that at\n // least the canvas context is reset to the default state by setting the canvas width.\n // https://www.w3.org/TR/2011/WD-html5-20110525/the-canvas-element.html\n // eslint-disable-next-line no-self-assign\n canvas.width = canvas.width;\n\n delete canvas[EXPANDO_KEY];\n return true;\n }\n\n /**\n\t *\n\t * @param {Chart} chart\n\t * @param {string} type\n\t * @param {function} listener\n\t */\n addEventListener(chart, type, listener) {\n // Can have only one listener per type, so make sure previous is removed\n this.removeEventListener(chart, type);\n\n const proxies = chart.$proxies || (chart.$proxies = {});\n const handlers = {\n attach: createAttachObserver,\n detach: createDetachObserver,\n resize: createResizeObserver\n };\n const handler = handlers[type] || createProxyAndListen;\n proxies[type] = handler(chart, type, listener);\n }\n\n\n /**\n\t * @param {Chart} chart\n\t * @param {string} type\n\t */\n removeEventListener(chart, type) {\n const proxies = chart.$proxies || (chart.$proxies = {});\n const proxy = proxies[type];\n\n if (!proxy) {\n return;\n }\n\n const handlers = {\n attach: releaseObserver,\n detach: releaseObserver,\n resize: releaseObserver\n };\n const handler = handlers[type] || removeListener;\n handler(chart, type, proxy);\n proxies[type] = undefined;\n }\n\n getDevicePixelRatio() {\n return window.devicePixelRatio;\n }\n\n /**\n\t * @param {HTMLCanvasElement} canvas\n\t * @param {number} [width] - content width of parent element\n\t * @param {number} [height] - content height of parent element\n\t * @param {number} [aspectRatio] - aspect ratio to maintain\n\t */\n getMaximumSize(canvas, width, height, aspectRatio) {\n return getMaximumSize(canvas, width, height, aspectRatio);\n }\n\n /**\n\t * @param {HTMLCanvasElement} canvas\n\t */\n isAttached(canvas) {\n const container = canvas && _getParentNode(canvas);\n return !!(container && container.isConnected);\n }\n}\n","import {_isDomSupported} from '../helpers/index.js';\nimport BasePlatform from './platform.base.js';\nimport BasicPlatform from './platform.basic.js';\nimport DomPlatform from './platform.dom.js';\n\nexport function _detectPlatform(canvas) {\n if (!_isDomSupported() || (typeof OffscreenCanvas !== 'undefined' && canvas instanceof OffscreenCanvas)) {\n return BasicPlatform;\n }\n return DomPlatform;\n}\n\nexport {BasePlatform, BasicPlatform, DomPlatform};\n","import type {AnyObject} from '../types/basic.js';\nimport type {Point} from '../types/geometric.js';\nimport type {Animation} from '../types/animation.js';\nimport {isNumber} from '../helpers/helpers.math.js';\n\nexport default class Element {\n\n static defaults = {};\n static defaultRoutes = undefined;\n\n x: number;\n y: number;\n active = false;\n options: O;\n $animations: Record;\n\n tooltipPosition(useFinalPosition: boolean): Point {\n const {x, y} = this.getProps(['x', 'y'], useFinalPosition);\n return {x, y} as Point;\n }\n\n hasValue() {\n return isNumber(this.x) && isNumber(this.y);\n }\n\n /**\n * Gets the current or final value of each prop. Can return extra properties (whole object).\n * @param props - properties to get\n * @param [final] - get the final value (animation target)\n */\n getProps

(props: P, final?: boolean): Pick;\n getProps

(props: P[], final?: boolean): Partial>;\n getProps(props: string[], final?: boolean): Partial> {\n const anims = this.$animations;\n if (!final || !anims) {\n // let's not create an object, if not needed\n return this as Record;\n }\n const ret: Record = {};\n props.forEach((prop) => {\n ret[prop] = anims[prop] && anims[prop].active() ? anims[prop]._to : this[prop as string];\n });\n return ret;\n }\n}\n","import {isNullOrUndef, valueOrDefault} from '../helpers/helpers.core.js';\nimport {_factorize} from '../helpers/helpers.math.js';\n\n\n/**\n * @typedef { import('./core.controller.js').default } Chart\n * @typedef {{value:number | string, label?:string, major?:boolean, $context?:any}} Tick\n */\n\n/**\n * Returns a subset of ticks to be plotted to avoid overlapping labels.\n * @param {import('./core.scale.js').default} scale\n * @param {Tick[]} ticks\n * @return {Tick[]}\n * @private\n */\nexport function autoSkip(scale, ticks) {\n const tickOpts = scale.options.ticks;\n const determinedMaxTicks = determineMaxTicks(scale);\n const ticksLimit = Math.min(tickOpts.maxTicksLimit || determinedMaxTicks, determinedMaxTicks);\n const majorIndices = tickOpts.major.enabled ? getMajorIndices(ticks) : [];\n const numMajorIndices = majorIndices.length;\n const first = majorIndices[0];\n const last = majorIndices[numMajorIndices - 1];\n const newTicks = [];\n\n // If there are too many major ticks to display them all\n if (numMajorIndices > ticksLimit) {\n skipMajors(ticks, newTicks, majorIndices, numMajorIndices / ticksLimit);\n return newTicks;\n }\n\n const spacing = calculateSpacing(majorIndices, ticks, ticksLimit);\n\n if (numMajorIndices > 0) {\n let i, ilen;\n const avgMajorSpacing = numMajorIndices > 1 ? Math.round((last - first) / (numMajorIndices - 1)) : null;\n skip(ticks, newTicks, spacing, isNullOrUndef(avgMajorSpacing) ? 0 : first - avgMajorSpacing, first);\n for (i = 0, ilen = numMajorIndices - 1; i < ilen; i++) {\n skip(ticks, newTicks, spacing, majorIndices[i], majorIndices[i + 1]);\n }\n skip(ticks, newTicks, spacing, last, isNullOrUndef(avgMajorSpacing) ? ticks.length : last + avgMajorSpacing);\n return newTicks;\n }\n skip(ticks, newTicks, spacing);\n return newTicks;\n}\n\nfunction determineMaxTicks(scale) {\n const offset = scale.options.offset;\n const tickLength = scale._tickSize();\n const maxScale = scale._length / tickLength + (offset ? 0 : 1);\n const maxChart = scale._maxLength / tickLength;\n return Math.floor(Math.min(maxScale, maxChart));\n}\n\n/**\n * @param {number[]} majorIndices\n * @param {Tick[]} ticks\n * @param {number} ticksLimit\n */\nfunction calculateSpacing(majorIndices, ticks, ticksLimit) {\n const evenMajorSpacing = getEvenSpacing(majorIndices);\n const spacing = ticks.length / ticksLimit;\n\n // If the major ticks are evenly spaced apart, place the minor ticks\n // so that they divide the major ticks into even chunks\n if (!evenMajorSpacing) {\n return Math.max(spacing, 1);\n }\n\n const factors = _factorize(evenMajorSpacing);\n for (let i = 0, ilen = factors.length - 1; i < ilen; i++) {\n const factor = factors[i];\n if (factor > spacing) {\n return factor;\n }\n }\n return Math.max(spacing, 1);\n}\n\n/**\n * @param {Tick[]} ticks\n */\nfunction getMajorIndices(ticks) {\n const result = [];\n let i, ilen;\n for (i = 0, ilen = ticks.length; i < ilen; i++) {\n if (ticks[i].major) {\n result.push(i);\n }\n }\n return result;\n}\n\n/**\n * @param {Tick[]} ticks\n * @param {Tick[]} newTicks\n * @param {number[]} majorIndices\n * @param {number} spacing\n */\nfunction skipMajors(ticks, newTicks, majorIndices, spacing) {\n let count = 0;\n let next = majorIndices[0];\n let i;\n\n spacing = Math.ceil(spacing);\n for (i = 0; i < ticks.length; i++) {\n if (i === next) {\n newTicks.push(ticks[i]);\n count++;\n next = majorIndices[count * spacing];\n }\n }\n}\n\n/**\n * @param {Tick[]} ticks\n * @param {Tick[]} newTicks\n * @param {number} spacing\n * @param {number} [majorStart]\n * @param {number} [majorEnd]\n */\nfunction skip(ticks, newTicks, spacing, majorStart, majorEnd) {\n const start = valueOrDefault(majorStart, 0);\n const end = Math.min(valueOrDefault(majorEnd, ticks.length), ticks.length);\n let count = 0;\n let length, i, next;\n\n spacing = Math.ceil(spacing);\n if (majorEnd) {\n length = majorEnd - majorStart;\n spacing = length / Math.floor(length / spacing);\n }\n\n next = start;\n\n while (next < 0) {\n count++;\n next = Math.round(start + count * spacing);\n }\n\n for (i = Math.max(start, 0); i < end; i++) {\n if (i === next) {\n newTicks.push(ticks[i]);\n count++;\n next = Math.round(start + count * spacing);\n }\n }\n}\n\n\n/**\n * @param {number[]} arr\n */\nfunction getEvenSpacing(arr) {\n const len = arr.length;\n let i, diff;\n\n if (len < 2) {\n return false;\n }\n\n for (diff = arr[0], i = 1; i < len; ++i) {\n if (arr[i] - arr[i - 1] !== diff) {\n return false;\n }\n }\n return diff;\n}\n","import Element from './core.element.js';\nimport {_alignPixel, _measureText, renderText, clipArea, unclipArea} from '../helpers/helpers.canvas.js';\nimport {callback as call, each, finiteOrDefault, isArray, isFinite, isNullOrUndef, isObject, valueOrDefault} from '../helpers/helpers.core.js';\nimport {toDegrees, toRadians, _int16Range, _limitValue, HALF_PI} from '../helpers/helpers.math.js';\nimport {_alignStartEnd, _toLeftRightCenter} from '../helpers/helpers.extras.js';\nimport {createContext, toFont, toPadding, _addGrace} from '../helpers/helpers.options.js';\nimport {autoSkip} from './core.scale.autoskip.js';\n\nconst reverseAlign = (align) => align === 'left' ? 'right' : align === 'right' ? 'left' : align;\nconst offsetFromEdge = (scale, edge, offset) => edge === 'top' || edge === 'left' ? scale[edge] + offset : scale[edge] - offset;\nconst getTicksLimit = (ticksLength, maxTicksLimit) => Math.min(maxTicksLimit || ticksLength, ticksLength);\n\n/**\n * @typedef { import('../types/index.js').Chart } Chart\n * @typedef {{value:number | string, label?:string, major?:boolean, $context?:any}} Tick\n */\n\n/**\n * Returns a new array containing numItems from arr\n * @param {any[]} arr\n * @param {number} numItems\n */\nfunction sample(arr, numItems) {\n const result = [];\n const increment = arr.length / numItems;\n const len = arr.length;\n let i = 0;\n\n for (; i < len; i += increment) {\n result.push(arr[Math.floor(i)]);\n }\n return result;\n}\n\n/**\n * @param {Scale} scale\n * @param {number} index\n * @param {boolean} offsetGridLines\n */\nfunction getPixelForGridLine(scale, index, offsetGridLines) {\n const length = scale.ticks.length;\n const validIndex = Math.min(index, length - 1);\n const start = scale._startPixel;\n const end = scale._endPixel;\n const epsilon = 1e-6; // 1e-6 is margin in pixels for accumulated error.\n let lineValue = scale.getPixelForTick(validIndex);\n let offset;\n\n if (offsetGridLines) {\n if (length === 1) {\n offset = Math.max(lineValue - start, end - lineValue);\n } else if (index === 0) {\n offset = (scale.getPixelForTick(1) - lineValue) / 2;\n } else {\n offset = (lineValue - scale.getPixelForTick(validIndex - 1)) / 2;\n }\n lineValue += validIndex < index ? offset : -offset;\n\n // Return undefined if the pixel is out of the range\n if (lineValue < start - epsilon || lineValue > end + epsilon) {\n return;\n }\n }\n return lineValue;\n}\n\n/**\n * @param {object} caches\n * @param {number} length\n */\nfunction garbageCollect(caches, length) {\n each(caches, (cache) => {\n const gc = cache.gc;\n const gcLen = gc.length / 2;\n let i;\n if (gcLen > length) {\n for (i = 0; i < gcLen; ++i) {\n delete cache.data[gc[i]];\n }\n gc.splice(0, gcLen);\n }\n });\n}\n\n/**\n * @param {object} options\n */\nfunction getTickMarkLength(options) {\n return options.drawTicks ? options.tickLength : 0;\n}\n\n/**\n * @param {object} options\n */\nfunction getTitleHeight(options, fallback) {\n if (!options.display) {\n return 0;\n }\n\n const font = toFont(options.font, fallback);\n const padding = toPadding(options.padding);\n const lines = isArray(options.text) ? options.text.length : 1;\n\n return (lines * font.lineHeight) + padding.height;\n}\n\nfunction createScaleContext(parent, scale) {\n return createContext(parent, {\n scale,\n type: 'scale'\n });\n}\n\nfunction createTickContext(parent, index, tick) {\n return createContext(parent, {\n tick,\n index,\n type: 'tick'\n });\n}\n\nfunction titleAlign(align, position, reverse) {\n /** @type {CanvasTextAlign} */\n let ret = _toLeftRightCenter(align);\n if ((reverse && position !== 'right') || (!reverse && position === 'right')) {\n ret = reverseAlign(ret);\n }\n return ret;\n}\n\nfunction titleArgs(scale, offset, position, align) {\n const {top, left, bottom, right, chart} = scale;\n const {chartArea, scales} = chart;\n let rotation = 0;\n let maxWidth, titleX, titleY;\n const height = bottom - top;\n const width = right - left;\n\n if (scale.isHorizontal()) {\n titleX = _alignStartEnd(align, left, right);\n\n if (isObject(position)) {\n const positionAxisID = Object.keys(position)[0];\n const value = position[positionAxisID];\n titleY = scales[positionAxisID].getPixelForValue(value) + height - offset;\n } else if (position === 'center') {\n titleY = (chartArea.bottom + chartArea.top) / 2 + height - offset;\n } else {\n titleY = offsetFromEdge(scale, position, offset);\n }\n maxWidth = right - left;\n } else {\n if (isObject(position)) {\n const positionAxisID = Object.keys(position)[0];\n const value = position[positionAxisID];\n titleX = scales[positionAxisID].getPixelForValue(value) - width + offset;\n } else if (position === 'center') {\n titleX = (chartArea.left + chartArea.right) / 2 - width + offset;\n } else {\n titleX = offsetFromEdge(scale, position, offset);\n }\n titleY = _alignStartEnd(align, bottom, top);\n rotation = position === 'left' ? -HALF_PI : HALF_PI;\n }\n return {titleX, titleY, maxWidth, rotation};\n}\n\nexport default class Scale extends Element {\n\n // eslint-disable-next-line max-statements\n constructor(cfg) {\n super();\n\n /** @type {string} */\n this.id = cfg.id;\n /** @type {string} */\n this.type = cfg.type;\n /** @type {any} */\n this.options = undefined;\n /** @type {CanvasRenderingContext2D} */\n this.ctx = cfg.ctx;\n /** @type {Chart} */\n this.chart = cfg.chart;\n\n // implements box\n /** @type {number} */\n this.top = undefined;\n /** @type {number} */\n this.bottom = undefined;\n /** @type {number} */\n this.left = undefined;\n /** @type {number} */\n this.right = undefined;\n /** @type {number} */\n this.width = undefined;\n /** @type {number} */\n this.height = undefined;\n this._margins = {\n left: 0,\n right: 0,\n top: 0,\n bottom: 0\n };\n /** @type {number} */\n this.maxWidth = undefined;\n /** @type {number} */\n this.maxHeight = undefined;\n /** @type {number} */\n this.paddingTop = undefined;\n /** @type {number} */\n this.paddingBottom = undefined;\n /** @type {number} */\n this.paddingLeft = undefined;\n /** @type {number} */\n this.paddingRight = undefined;\n\n // scale-specific properties\n /** @type {string=} */\n this.axis = undefined;\n /** @type {number=} */\n this.labelRotation = undefined;\n this.min = undefined;\n this.max = undefined;\n this._range = undefined;\n /** @type {Tick[]} */\n this.ticks = [];\n /** @type {object[]|null} */\n this._gridLineItems = null;\n /** @type {object[]|null} */\n this._labelItems = null;\n /** @type {object|null} */\n this._labelSizes = null;\n this._length = 0;\n this._maxLength = 0;\n this._longestTextCache = {};\n /** @type {number} */\n this._startPixel = undefined;\n /** @type {number} */\n this._endPixel = undefined;\n this._reversePixels = false;\n this._userMax = undefined;\n this._userMin = undefined;\n this._suggestedMax = undefined;\n this._suggestedMin = undefined;\n this._ticksLength = 0;\n this._borderValue = 0;\n this._cache = {};\n this._dataLimitsCached = false;\n this.$context = undefined;\n }\n\n /**\n\t * @param {any} options\n\t * @since 3.0\n\t */\n init(options) {\n this.options = options.setContext(this.getContext());\n\n this.axis = options.axis;\n\n // parse min/max value, so we can properly determine min/max for other scales\n this._userMin = this.parse(options.min);\n this._userMax = this.parse(options.max);\n this._suggestedMin = this.parse(options.suggestedMin);\n this._suggestedMax = this.parse(options.suggestedMax);\n }\n\n /**\n\t * Parse a supported input value to internal representation.\n\t * @param {*} raw\n\t * @param {number} [index]\n\t * @since 3.0\n\t */\n parse(raw, index) { // eslint-disable-line no-unused-vars\n return raw;\n }\n\n /**\n\t * @return {{min: number, max: number, minDefined: boolean, maxDefined: boolean}}\n\t * @protected\n\t * @since 3.0\n\t */\n getUserBounds() {\n let {_userMin, _userMax, _suggestedMin, _suggestedMax} = this;\n _userMin = finiteOrDefault(_userMin, Number.POSITIVE_INFINITY);\n _userMax = finiteOrDefault(_userMax, Number.NEGATIVE_INFINITY);\n _suggestedMin = finiteOrDefault(_suggestedMin, Number.POSITIVE_INFINITY);\n _suggestedMax = finiteOrDefault(_suggestedMax, Number.NEGATIVE_INFINITY);\n return {\n min: finiteOrDefault(_userMin, _suggestedMin),\n max: finiteOrDefault(_userMax, _suggestedMax),\n minDefined: isFinite(_userMin),\n maxDefined: isFinite(_userMax)\n };\n }\n\n /**\n\t * @param {boolean} canStack\n\t * @return {{min: number, max: number}}\n\t * @protected\n\t * @since 3.0\n\t */\n getMinMax(canStack) {\n let {min, max, minDefined, maxDefined} = this.getUserBounds();\n let range;\n\n if (minDefined && maxDefined) {\n return {min, max};\n }\n\n const metas = this.getMatchingVisibleMetas();\n for (let i = 0, ilen = metas.length; i < ilen; ++i) {\n range = metas[i].controller.getMinMax(this, canStack);\n if (!minDefined) {\n min = Math.min(min, range.min);\n }\n if (!maxDefined) {\n max = Math.max(max, range.max);\n }\n }\n\n // Make sure min <= max when only min or max is defined by user and the data is outside that range\n min = maxDefined && min > max ? max : min;\n max = minDefined && min > max ? min : max;\n\n return {\n min: finiteOrDefault(min, finiteOrDefault(max, min)),\n max: finiteOrDefault(max, finiteOrDefault(min, max))\n };\n }\n\n /**\n\t * Get the padding needed for the scale\n\t * @return {{top: number, left: number, bottom: number, right: number}} the necessary padding\n\t * @private\n\t */\n getPadding() {\n return {\n left: this.paddingLeft || 0,\n top: this.paddingTop || 0,\n right: this.paddingRight || 0,\n bottom: this.paddingBottom || 0\n };\n }\n\n /**\n\t * Returns the scale tick objects\n\t * @return {Tick[]}\n\t * @since 2.7\n\t */\n getTicks() {\n return this.ticks;\n }\n\n /**\n\t * @return {string[]}\n\t */\n getLabels() {\n const data = this.chart.data;\n return this.options.labels || (this.isHorizontal() ? data.xLabels : data.yLabels) || data.labels || [];\n }\n\n /**\n * @return {import('../types.js').LabelItem[]}\n */\n getLabelItems(chartArea = this.chart.chartArea) {\n const items = this._labelItems || (this._labelItems = this._computeLabelItems(chartArea));\n return items;\n }\n\n // When a new layout is created, reset the data limits cache\n beforeLayout() {\n this._cache = {};\n this._dataLimitsCached = false;\n }\n\n // These methods are ordered by lifecycle. Utilities then follow.\n // Any function defined here is inherited by all scale types.\n // Any function can be extended by the scale type\n\n beforeUpdate() {\n call(this.options.beforeUpdate, [this]);\n }\n\n /**\n\t * @param {number} maxWidth - the max width in pixels\n\t * @param {number} maxHeight - the max height in pixels\n\t * @param {{top: number, left: number, bottom: number, right: number}} margins - the space between the edge of the other scales and edge of the chart\n\t * This space comes from two sources:\n\t * - padding - space that's required to show the labels at the edges of the scale\n\t * - thickness of scales or legends in another orientation\n\t */\n update(maxWidth, maxHeight, margins) {\n const {beginAtZero, grace, ticks: tickOpts} = this.options;\n const sampleSize = tickOpts.sampleSize;\n\n // Update Lifecycle - Probably don't want to ever extend or overwrite this function ;)\n this.beforeUpdate();\n\n // Absorb the master measurements\n this.maxWidth = maxWidth;\n this.maxHeight = maxHeight;\n this._margins = margins = Object.assign({\n left: 0,\n right: 0,\n top: 0,\n bottom: 0\n }, margins);\n\n this.ticks = null;\n this._labelSizes = null;\n this._gridLineItems = null;\n this._labelItems = null;\n\n // Dimensions\n this.beforeSetDimensions();\n this.setDimensions();\n this.afterSetDimensions();\n\n this._maxLength = this.isHorizontal()\n ? this.width + margins.left + margins.right\n : this.height + margins.top + margins.bottom;\n\n // Data min/max\n if (!this._dataLimitsCached) {\n this.beforeDataLimits();\n this.determineDataLimits();\n this.afterDataLimits();\n this._range = _addGrace(this, grace, beginAtZero);\n this._dataLimitsCached = true;\n }\n\n this.beforeBuildTicks();\n\n this.ticks = this.buildTicks() || [];\n\n // Allow modification of ticks in callback.\n this.afterBuildTicks();\n\n // Compute tick rotation and fit using a sampled subset of labels\n // We generally don't need to compute the size of every single label for determining scale size\n const samplingEnabled = sampleSize < this.ticks.length;\n this._convertTicksToLabels(samplingEnabled ? sample(this.ticks, sampleSize) : this.ticks);\n\n // configure is called twice, once here, once from core.controller.updateLayout.\n // Here we haven't been positioned yet, but dimensions are correct.\n // Variables set in configure are needed for calculateLabelRotation, and\n // it's ok that coordinates are not correct there, only dimensions matter.\n this.configure();\n\n // Tick Rotation\n this.beforeCalculateLabelRotation();\n this.calculateLabelRotation(); // Preconditions: number of ticks and sizes of largest labels must be calculated beforehand\n this.afterCalculateLabelRotation();\n\n // Auto-skip\n if (tickOpts.display && (tickOpts.autoSkip || tickOpts.source === 'auto')) {\n this.ticks = autoSkip(this, this.ticks);\n this._labelSizes = null;\n this.afterAutoSkip();\n }\n\n if (samplingEnabled) {\n // Generate labels using all non-skipped ticks\n this._convertTicksToLabels(this.ticks);\n }\n\n this.beforeFit();\n this.fit(); // Preconditions: label rotation and label sizes must be calculated beforehand\n this.afterFit();\n\n // IMPORTANT: after this point, we consider that `this.ticks` will NEVER change!\n\n this.afterUpdate();\n }\n\n /**\n\t * @protected\n\t */\n configure() {\n let reversePixels = this.options.reverse;\n let startPixel, endPixel;\n\n if (this.isHorizontal()) {\n startPixel = this.left;\n endPixel = this.right;\n } else {\n startPixel = this.top;\n endPixel = this.bottom;\n // by default vertical scales are from bottom to top, so pixels are reversed\n reversePixels = !reversePixels;\n }\n this._startPixel = startPixel;\n this._endPixel = endPixel;\n this._reversePixels = reversePixels;\n this._length = endPixel - startPixel;\n this._alignToPixels = this.options.alignToPixels;\n }\n\n afterUpdate() {\n call(this.options.afterUpdate, [this]);\n }\n\n //\n\n beforeSetDimensions() {\n call(this.options.beforeSetDimensions, [this]);\n }\n setDimensions() {\n // Set the unconstrained dimension before label rotation\n if (this.isHorizontal()) {\n // Reset position before calculating rotation\n this.width = this.maxWidth;\n this.left = 0;\n this.right = this.width;\n } else {\n this.height = this.maxHeight;\n\n // Reset position before calculating rotation\n this.top = 0;\n this.bottom = this.height;\n }\n\n // Reset padding\n this.paddingLeft = 0;\n this.paddingTop = 0;\n this.paddingRight = 0;\n this.paddingBottom = 0;\n }\n afterSetDimensions() {\n call(this.options.afterSetDimensions, [this]);\n }\n\n _callHooks(name) {\n this.chart.notifyPlugins(name, this.getContext());\n call(this.options[name], [this]);\n }\n\n // Data limits\n beforeDataLimits() {\n this._callHooks('beforeDataLimits');\n }\n determineDataLimits() {}\n afterDataLimits() {\n this._callHooks('afterDataLimits');\n }\n\n //\n beforeBuildTicks() {\n this._callHooks('beforeBuildTicks');\n }\n /**\n\t * @return {object[]} the ticks\n\t */\n buildTicks() {\n return [];\n }\n afterBuildTicks() {\n this._callHooks('afterBuildTicks');\n }\n\n beforeTickToLabelConversion() {\n call(this.options.beforeTickToLabelConversion, [this]);\n }\n /**\n\t * Convert ticks to label strings\n\t * @param {Tick[]} ticks\n\t */\n generateTickLabels(ticks) {\n const tickOpts = this.options.ticks;\n let i, ilen, tick;\n for (i = 0, ilen = ticks.length; i < ilen; i++) {\n tick = ticks[i];\n tick.label = call(tickOpts.callback, [tick.value, i, ticks], this);\n }\n }\n afterTickToLabelConversion() {\n call(this.options.afterTickToLabelConversion, [this]);\n }\n\n //\n\n beforeCalculateLabelRotation() {\n call(this.options.beforeCalculateLabelRotation, [this]);\n }\n calculateLabelRotation() {\n const options = this.options;\n const tickOpts = options.ticks;\n const numTicks = getTicksLimit(this.ticks.length, options.ticks.maxTicksLimit);\n const minRotation = tickOpts.minRotation || 0;\n const maxRotation = tickOpts.maxRotation;\n let labelRotation = minRotation;\n let tickWidth, maxHeight, maxLabelDiagonal;\n\n if (!this._isVisible() || !tickOpts.display || minRotation >= maxRotation || numTicks <= 1 || !this.isHorizontal()) {\n this.labelRotation = minRotation;\n return;\n }\n\n const labelSizes = this._getLabelSizes();\n const maxLabelWidth = labelSizes.widest.width;\n const maxLabelHeight = labelSizes.highest.height;\n\n // Estimate the width of each grid based on the canvas width, the maximum\n // label width and the number of tick intervals\n const maxWidth = _limitValue(this.chart.width - maxLabelWidth, 0, this.maxWidth);\n tickWidth = options.offset ? this.maxWidth / numTicks : maxWidth / (numTicks - 1);\n\n // Allow 3 pixels x2 padding either side for label readability\n if (maxLabelWidth + 6 > tickWidth) {\n tickWidth = maxWidth / (numTicks - (options.offset ? 0.5 : 1));\n maxHeight = this.maxHeight - getTickMarkLength(options.grid)\n\t\t\t\t- tickOpts.padding - getTitleHeight(options.title, this.chart.options.font);\n maxLabelDiagonal = Math.sqrt(maxLabelWidth * maxLabelWidth + maxLabelHeight * maxLabelHeight);\n labelRotation = toDegrees(Math.min(\n Math.asin(_limitValue((labelSizes.highest.height + 6) / tickWidth, -1, 1)),\n Math.asin(_limitValue(maxHeight / maxLabelDiagonal, -1, 1)) - Math.asin(_limitValue(maxLabelHeight / maxLabelDiagonal, -1, 1))\n ));\n labelRotation = Math.max(minRotation, Math.min(maxRotation, labelRotation));\n }\n\n this.labelRotation = labelRotation;\n }\n afterCalculateLabelRotation() {\n call(this.options.afterCalculateLabelRotation, [this]);\n }\n afterAutoSkip() {}\n\n //\n\n beforeFit() {\n call(this.options.beforeFit, [this]);\n }\n fit() {\n // Reset\n const minSize = {\n width: 0,\n height: 0\n };\n\n const {chart, options: {ticks: tickOpts, title: titleOpts, grid: gridOpts}} = this;\n const display = this._isVisible();\n const isHorizontal = this.isHorizontal();\n\n if (display) {\n const titleHeight = getTitleHeight(titleOpts, chart.options.font);\n if (isHorizontal) {\n minSize.width = this.maxWidth;\n minSize.height = getTickMarkLength(gridOpts) + titleHeight;\n } else {\n minSize.height = this.maxHeight; // fill all the height\n minSize.width = getTickMarkLength(gridOpts) + titleHeight;\n }\n\n // Don't bother fitting the ticks if we are not showing the labels\n if (tickOpts.display && this.ticks.length) {\n const {first, last, widest, highest} = this._getLabelSizes();\n const tickPadding = tickOpts.padding * 2;\n const angleRadians = toRadians(this.labelRotation);\n const cos = Math.cos(angleRadians);\n const sin = Math.sin(angleRadians);\n\n if (isHorizontal) {\n // A horizontal axis is more constrained by the height.\n const labelHeight = tickOpts.mirror ? 0 : sin * widest.width + cos * highest.height;\n minSize.height = Math.min(this.maxHeight, minSize.height + labelHeight + tickPadding);\n } else {\n // A vertical axis is more constrained by the width. Labels are the\n // dominant factor here, so get that length first and account for padding\n const labelWidth = tickOpts.mirror ? 0 : cos * widest.width + sin * highest.height;\n\n minSize.width = Math.min(this.maxWidth, minSize.width + labelWidth + tickPadding);\n }\n this._calculatePadding(first, last, sin, cos);\n }\n }\n\n this._handleMargins();\n\n if (isHorizontal) {\n this.width = this._length = chart.width - this._margins.left - this._margins.right;\n this.height = minSize.height;\n } else {\n this.width = minSize.width;\n this.height = this._length = chart.height - this._margins.top - this._margins.bottom;\n }\n }\n\n _calculatePadding(first, last, sin, cos) {\n const {ticks: {align, padding}, position} = this.options;\n const isRotated = this.labelRotation !== 0;\n const labelsBelowTicks = position !== 'top' && this.axis === 'x';\n\n if (this.isHorizontal()) {\n const offsetLeft = this.getPixelForTick(0) - this.left;\n const offsetRight = this.right - this.getPixelForTick(this.ticks.length - 1);\n let paddingLeft = 0;\n let paddingRight = 0;\n\n // Ensure that our ticks are always inside the canvas. When rotated, ticks are right aligned\n // which means that the right padding is dominated by the font height\n if (isRotated) {\n if (labelsBelowTicks) {\n paddingLeft = cos * first.width;\n paddingRight = sin * last.height;\n } else {\n paddingLeft = sin * first.height;\n paddingRight = cos * last.width;\n }\n } else if (align === 'start') {\n paddingRight = last.width;\n } else if (align === 'end') {\n paddingLeft = first.width;\n } else if (align !== 'inner') {\n paddingLeft = first.width / 2;\n paddingRight = last.width / 2;\n }\n\n // Adjust padding taking into account changes in offsets\n this.paddingLeft = Math.max((paddingLeft - offsetLeft + padding) * this.width / (this.width - offsetLeft), 0);\n this.paddingRight = Math.max((paddingRight - offsetRight + padding) * this.width / (this.width - offsetRight), 0);\n } else {\n let paddingTop = last.height / 2;\n let paddingBottom = first.height / 2;\n\n if (align === 'start') {\n paddingTop = 0;\n paddingBottom = first.height;\n } else if (align === 'end') {\n paddingTop = last.height;\n paddingBottom = 0;\n }\n\n this.paddingTop = paddingTop + padding;\n this.paddingBottom = paddingBottom + padding;\n }\n }\n\n /**\n\t * Handle margins and padding interactions\n\t * @private\n\t */\n _handleMargins() {\n if (this._margins) {\n this._margins.left = Math.max(this.paddingLeft, this._margins.left);\n this._margins.top = Math.max(this.paddingTop, this._margins.top);\n this._margins.right = Math.max(this.paddingRight, this._margins.right);\n this._margins.bottom = Math.max(this.paddingBottom, this._margins.bottom);\n }\n }\n\n afterFit() {\n call(this.options.afterFit, [this]);\n }\n\n // Shared Methods\n /**\n\t * @return {boolean}\n\t */\n isHorizontal() {\n const {axis, position} = this.options;\n return position === 'top' || position === 'bottom' || axis === 'x';\n }\n /**\n\t * @return {boolean}\n\t */\n isFullSize() {\n return this.options.fullSize;\n }\n\n /**\n\t * @param {Tick[]} ticks\n\t * @private\n\t */\n _convertTicksToLabels(ticks) {\n this.beforeTickToLabelConversion();\n\n this.generateTickLabels(ticks);\n\n // Ticks should be skipped when callback returns null or undef, so lets remove those.\n let i, ilen;\n for (i = 0, ilen = ticks.length; i < ilen; i++) {\n if (isNullOrUndef(ticks[i].label)) {\n ticks.splice(i, 1);\n ilen--;\n i--;\n }\n }\n\n this.afterTickToLabelConversion();\n }\n\n /**\n\t * @return {{ first: object, last: object, widest: object, highest: object, widths: Array, heights: array }}\n\t * @private\n\t */\n _getLabelSizes() {\n let labelSizes = this._labelSizes;\n\n if (!labelSizes) {\n const sampleSize = this.options.ticks.sampleSize;\n let ticks = this.ticks;\n if (sampleSize < ticks.length) {\n ticks = sample(ticks, sampleSize);\n }\n\n this._labelSizes = labelSizes = this._computeLabelSizes(ticks, ticks.length, this.options.ticks.maxTicksLimit);\n }\n\n return labelSizes;\n }\n\n /**\n\t * Returns {width, height, offset} objects for the first, last, widest, highest tick\n\t * labels where offset indicates the anchor point offset from the top in pixels.\n\t * @return {{ first: object, last: object, widest: object, highest: object, widths: Array, heights: array }}\n\t * @private\n\t */\n _computeLabelSizes(ticks, length, maxTicksLimit) {\n const {ctx, _longestTextCache: caches} = this;\n const widths = [];\n const heights = [];\n const increment = Math.floor(length / getTicksLimit(length, maxTicksLimit));\n let widestLabelSize = 0;\n let highestLabelSize = 0;\n let i, j, jlen, label, tickFont, fontString, cache, lineHeight, width, height, nestedLabel;\n\n for (i = 0; i < length; i += increment) {\n label = ticks[i].label;\n tickFont = this._resolveTickFontOptions(i);\n ctx.font = fontString = tickFont.string;\n cache = caches[fontString] = caches[fontString] || {data: {}, gc: []};\n lineHeight = tickFont.lineHeight;\n width = height = 0;\n // Undefined labels and arrays should not be measured\n if (!isNullOrUndef(label) && !isArray(label)) {\n width = _measureText(ctx, cache.data, cache.gc, width, label);\n height = lineHeight;\n } else if (isArray(label)) {\n // if it is an array let's measure each element\n for (j = 0, jlen = label.length; j < jlen; ++j) {\n nestedLabel = /** @type {string} */ (label[j]);\n // Undefined labels and arrays should not be measured\n if (!isNullOrUndef(nestedLabel) && !isArray(nestedLabel)) {\n width = _measureText(ctx, cache.data, cache.gc, width, nestedLabel);\n height += lineHeight;\n }\n }\n }\n widths.push(width);\n heights.push(height);\n widestLabelSize = Math.max(width, widestLabelSize);\n highestLabelSize = Math.max(height, highestLabelSize);\n }\n garbageCollect(caches, length);\n\n const widest = widths.indexOf(widestLabelSize);\n const highest = heights.indexOf(highestLabelSize);\n\n const valueAt = (idx) => ({width: widths[idx] || 0, height: heights[idx] || 0});\n\n return {\n first: valueAt(0),\n last: valueAt(length - 1),\n widest: valueAt(widest),\n highest: valueAt(highest),\n widths,\n heights,\n };\n }\n\n /**\n\t * Used to get the label to display in the tooltip for the given value\n\t * @param {*} value\n\t * @return {string}\n\t */\n getLabelForValue(value) {\n return value;\n }\n\n /**\n\t * Returns the location of the given data point. Value can either be an index or a numerical value\n\t * The coordinate (0, 0) is at the upper-left corner of the canvas\n\t * @param {*} value\n\t * @param {number} [index]\n\t * @return {number}\n\t */\n getPixelForValue(value, index) { // eslint-disable-line no-unused-vars\n return NaN;\n }\n\n /**\n\t * Used to get the data value from a given pixel. This is the inverse of getPixelForValue\n\t * The coordinate (0, 0) is at the upper-left corner of the canvas\n\t * @param {number} pixel\n\t * @return {*}\n\t */\n getValueForPixel(pixel) {} // eslint-disable-line no-unused-vars\n\n /**\n\t * Returns the location of the tick at the given index\n\t * The coordinate (0, 0) is at the upper-left corner of the canvas\n\t * @param {number} index\n\t * @return {number}\n\t */\n getPixelForTick(index) {\n const ticks = this.ticks;\n if (index < 0 || index > ticks.length - 1) {\n return null;\n }\n return this.getPixelForValue(ticks[index].value);\n }\n\n /**\n\t * Utility for getting the pixel location of a percentage of scale\n\t * The coordinate (0, 0) is at the upper-left corner of the canvas\n\t * @param {number} decimal\n\t * @return {number}\n\t */\n getPixelForDecimal(decimal) {\n if (this._reversePixels) {\n decimal = 1 - decimal;\n }\n\n const pixel = this._startPixel + decimal * this._length;\n return _int16Range(this._alignToPixels ? _alignPixel(this.chart, pixel, 0) : pixel);\n }\n\n /**\n\t * @param {number} pixel\n\t * @return {number}\n\t */\n getDecimalForPixel(pixel) {\n const decimal = (pixel - this._startPixel) / this._length;\n return this._reversePixels ? 1 - decimal : decimal;\n }\n\n /**\n\t * Returns the pixel for the minimum chart value\n\t * The coordinate (0, 0) is at the upper-left corner of the canvas\n\t * @return {number}\n\t */\n getBasePixel() {\n return this.getPixelForValue(this.getBaseValue());\n }\n\n /**\n\t * @return {number}\n\t */\n getBaseValue() {\n const {min, max} = this;\n\n return min < 0 && max < 0 ? max :\n min > 0 && max > 0 ? min :\n 0;\n }\n\n /**\n\t * @protected\n\t */\n getContext(index) {\n const ticks = this.ticks || [];\n\n if (index >= 0 && index < ticks.length) {\n const tick = ticks[index];\n return tick.$context ||\n\t\t\t\t(tick.$context = createTickContext(this.getContext(), index, tick));\n }\n return this.$context ||\n\t\t\t(this.$context = createScaleContext(this.chart.getContext(), this));\n }\n\n /**\n\t * @return {number}\n\t * @private\n\t */\n _tickSize() {\n const optionTicks = this.options.ticks;\n\n // Calculate space needed by label in axis direction.\n const rot = toRadians(this.labelRotation);\n const cos = Math.abs(Math.cos(rot));\n const sin = Math.abs(Math.sin(rot));\n\n const labelSizes = this._getLabelSizes();\n const padding = optionTicks.autoSkipPadding || 0;\n const w = labelSizes ? labelSizes.widest.width + padding : 0;\n const h = labelSizes ? labelSizes.highest.height + padding : 0;\n\n // Calculate space needed for 1 tick in axis direction.\n return this.isHorizontal()\n ? h * cos > w * sin ? w / cos : h / sin\n : h * sin < w * cos ? h / cos : w / sin;\n }\n\n /**\n\t * @return {boolean}\n\t * @private\n\t */\n _isVisible() {\n const display = this.options.display;\n\n if (display !== 'auto') {\n return !!display;\n }\n\n return this.getMatchingVisibleMetas().length > 0;\n }\n\n /**\n\t * @private\n\t */\n _computeGridLineItems(chartArea) {\n const axis = this.axis;\n const chart = this.chart;\n const options = this.options;\n const {grid, position, border} = options;\n const offset = grid.offset;\n const isHorizontal = this.isHorizontal();\n const ticks = this.ticks;\n const ticksLength = ticks.length + (offset ? 1 : 0);\n const tl = getTickMarkLength(grid);\n const items = [];\n\n const borderOpts = border.setContext(this.getContext());\n const axisWidth = borderOpts.display ? borderOpts.width : 0;\n const axisHalfWidth = axisWidth / 2;\n const alignBorderValue = function(pixel) {\n return _alignPixel(chart, pixel, axisWidth);\n };\n let borderValue, i, lineValue, alignedLineValue;\n let tx1, ty1, tx2, ty2, x1, y1, x2, y2;\n\n if (position === 'top') {\n borderValue = alignBorderValue(this.bottom);\n ty1 = this.bottom - tl;\n ty2 = borderValue - axisHalfWidth;\n y1 = alignBorderValue(chartArea.top) + axisHalfWidth;\n y2 = chartArea.bottom;\n } else if (position === 'bottom') {\n borderValue = alignBorderValue(this.top);\n y1 = chartArea.top;\n y2 = alignBorderValue(chartArea.bottom) - axisHalfWidth;\n ty1 = borderValue + axisHalfWidth;\n ty2 = this.top + tl;\n } else if (position === 'left') {\n borderValue = alignBorderValue(this.right);\n tx1 = this.right - tl;\n tx2 = borderValue - axisHalfWidth;\n x1 = alignBorderValue(chartArea.left) + axisHalfWidth;\n x2 = chartArea.right;\n } else if (position === 'right') {\n borderValue = alignBorderValue(this.left);\n x1 = chartArea.left;\n x2 = alignBorderValue(chartArea.right) - axisHalfWidth;\n tx1 = borderValue + axisHalfWidth;\n tx2 = this.left + tl;\n } else if (axis === 'x') {\n if (position === 'center') {\n borderValue = alignBorderValue((chartArea.top + chartArea.bottom) / 2 + 0.5);\n } else if (isObject(position)) {\n const positionAxisID = Object.keys(position)[0];\n const value = position[positionAxisID];\n borderValue = alignBorderValue(this.chart.scales[positionAxisID].getPixelForValue(value));\n }\n\n y1 = chartArea.top;\n y2 = chartArea.bottom;\n ty1 = borderValue + axisHalfWidth;\n ty2 = ty1 + tl;\n } else if (axis === 'y') {\n if (position === 'center') {\n borderValue = alignBorderValue((chartArea.left + chartArea.right) / 2);\n } else if (isObject(position)) {\n const positionAxisID = Object.keys(position)[0];\n const value = position[positionAxisID];\n borderValue = alignBorderValue(this.chart.scales[positionAxisID].getPixelForValue(value));\n }\n\n tx1 = borderValue - axisHalfWidth;\n tx2 = tx1 - tl;\n x1 = chartArea.left;\n x2 = chartArea.right;\n }\n\n const limit = valueOrDefault(options.ticks.maxTicksLimit, ticksLength);\n const step = Math.max(1, Math.ceil(ticksLength / limit));\n for (i = 0; i < ticksLength; i += step) {\n const context = this.getContext(i);\n const optsAtIndex = grid.setContext(context);\n const optsAtIndexBorder = border.setContext(context);\n\n const lineWidth = optsAtIndex.lineWidth;\n const lineColor = optsAtIndex.color;\n const borderDash = optsAtIndexBorder.dash || [];\n const borderDashOffset = optsAtIndexBorder.dashOffset;\n\n const tickWidth = optsAtIndex.tickWidth;\n const tickColor = optsAtIndex.tickColor;\n const tickBorderDash = optsAtIndex.tickBorderDash || [];\n const tickBorderDashOffset = optsAtIndex.tickBorderDashOffset;\n\n lineValue = getPixelForGridLine(this, i, offset);\n\n // Skip if the pixel is out of the range\n if (lineValue === undefined) {\n continue;\n }\n\n alignedLineValue = _alignPixel(chart, lineValue, lineWidth);\n\n if (isHorizontal) {\n tx1 = tx2 = x1 = x2 = alignedLineValue;\n } else {\n ty1 = ty2 = y1 = y2 = alignedLineValue;\n }\n\n items.push({\n tx1,\n ty1,\n tx2,\n ty2,\n x1,\n y1,\n x2,\n y2,\n width: lineWidth,\n color: lineColor,\n borderDash,\n borderDashOffset,\n tickWidth,\n tickColor,\n tickBorderDash,\n tickBorderDashOffset,\n });\n }\n\n this._ticksLength = ticksLength;\n this._borderValue = borderValue;\n\n return items;\n }\n\n /**\n\t * @private\n\t */\n _computeLabelItems(chartArea) {\n const axis = this.axis;\n const options = this.options;\n const {position, ticks: optionTicks} = options;\n const isHorizontal = this.isHorizontal();\n const ticks = this.ticks;\n const {align, crossAlign, padding, mirror} = optionTicks;\n const tl = getTickMarkLength(options.grid);\n const tickAndPadding = tl + padding;\n const hTickAndPadding = mirror ? -padding : tickAndPadding;\n const rotation = -toRadians(this.labelRotation);\n const items = [];\n let i, ilen, tick, label, x, y, textAlign, pixel, font, lineHeight, lineCount, textOffset;\n let textBaseline = 'middle';\n\n if (position === 'top') {\n y = this.bottom - hTickAndPadding;\n textAlign = this._getXAxisLabelAlignment();\n } else if (position === 'bottom') {\n y = this.top + hTickAndPadding;\n textAlign = this._getXAxisLabelAlignment();\n } else if (position === 'left') {\n const ret = this._getYAxisLabelAlignment(tl);\n textAlign = ret.textAlign;\n x = ret.x;\n } else if (position === 'right') {\n const ret = this._getYAxisLabelAlignment(tl);\n textAlign = ret.textAlign;\n x = ret.x;\n } else if (axis === 'x') {\n if (position === 'center') {\n y = ((chartArea.top + chartArea.bottom) / 2) + tickAndPadding;\n } else if (isObject(position)) {\n const positionAxisID = Object.keys(position)[0];\n const value = position[positionAxisID];\n y = this.chart.scales[positionAxisID].getPixelForValue(value) + tickAndPadding;\n }\n textAlign = this._getXAxisLabelAlignment();\n } else if (axis === 'y') {\n if (position === 'center') {\n x = ((chartArea.left + chartArea.right) / 2) - tickAndPadding;\n } else if (isObject(position)) {\n const positionAxisID = Object.keys(position)[0];\n const value = position[positionAxisID];\n x = this.chart.scales[positionAxisID].getPixelForValue(value);\n }\n textAlign = this._getYAxisLabelAlignment(tl).textAlign;\n }\n\n if (axis === 'y') {\n if (align === 'start') {\n textBaseline = 'top';\n } else if (align === 'end') {\n textBaseline = 'bottom';\n }\n }\n\n const labelSizes = this._getLabelSizes();\n for (i = 0, ilen = ticks.length; i < ilen; ++i) {\n tick = ticks[i];\n label = tick.label;\n\n const optsAtIndex = optionTicks.setContext(this.getContext(i));\n pixel = this.getPixelForTick(i) + optionTicks.labelOffset;\n font = this._resolveTickFontOptions(i);\n lineHeight = font.lineHeight;\n lineCount = isArray(label) ? label.length : 1;\n const halfCount = lineCount / 2;\n const color = optsAtIndex.color;\n const strokeColor = optsAtIndex.textStrokeColor;\n const strokeWidth = optsAtIndex.textStrokeWidth;\n let tickTextAlign = textAlign;\n\n if (isHorizontal) {\n x = pixel;\n\n if (textAlign === 'inner') {\n if (i === ilen - 1) {\n tickTextAlign = !this.options.reverse ? 'right' : 'left';\n } else if (i === 0) {\n tickTextAlign = !this.options.reverse ? 'left' : 'right';\n } else {\n tickTextAlign = 'center';\n }\n }\n\n if (position === 'top') {\n if (crossAlign === 'near' || rotation !== 0) {\n textOffset = -lineCount * lineHeight + lineHeight / 2;\n } else if (crossAlign === 'center') {\n textOffset = -labelSizes.highest.height / 2 - halfCount * lineHeight + lineHeight;\n } else {\n textOffset = -labelSizes.highest.height + lineHeight / 2;\n }\n } else {\n // eslint-disable-next-line no-lonely-if\n if (crossAlign === 'near' || rotation !== 0) {\n textOffset = lineHeight / 2;\n } else if (crossAlign === 'center') {\n textOffset = labelSizes.highest.height / 2 - halfCount * lineHeight;\n } else {\n textOffset = labelSizes.highest.height - lineCount * lineHeight;\n }\n }\n if (mirror) {\n textOffset *= -1;\n }\n if (rotation !== 0 && !optsAtIndex.showLabelBackdrop) {\n x += (lineHeight / 2) * Math.sin(rotation);\n }\n } else {\n y = pixel;\n textOffset = (1 - lineCount) * lineHeight / 2;\n }\n\n let backdrop;\n\n if (optsAtIndex.showLabelBackdrop) {\n const labelPadding = toPadding(optsAtIndex.backdropPadding);\n const height = labelSizes.heights[i];\n const width = labelSizes.widths[i];\n\n let top = textOffset - labelPadding.top;\n let left = 0 - labelPadding.left;\n\n switch (textBaseline) {\n case 'middle':\n top -= height / 2;\n break;\n case 'bottom':\n top -= height;\n break;\n default:\n break;\n }\n\n switch (textAlign) {\n case 'center':\n left -= width / 2;\n break;\n case 'right':\n left -= width;\n break;\n case 'inner':\n if (i === ilen - 1) {\n left -= width;\n } else if (i > 0) {\n left -= width / 2;\n }\n break;\n default:\n break;\n }\n\n backdrop = {\n left,\n top,\n width: width + labelPadding.width,\n height: height + labelPadding.height,\n\n color: optsAtIndex.backdropColor,\n };\n }\n\n items.push({\n label,\n font,\n textOffset,\n options: {\n rotation,\n color,\n strokeColor,\n strokeWidth,\n textAlign: tickTextAlign,\n textBaseline,\n translation: [x, y],\n backdrop,\n }\n });\n }\n\n return items;\n }\n\n _getXAxisLabelAlignment() {\n const {position, ticks} = this.options;\n const rotation = -toRadians(this.labelRotation);\n\n if (rotation) {\n return position === 'top' ? 'left' : 'right';\n }\n\n let align = 'center';\n\n if (ticks.align === 'start') {\n align = 'left';\n } else if (ticks.align === 'end') {\n align = 'right';\n } else if (ticks.align === 'inner') {\n align = 'inner';\n }\n\n return align;\n }\n\n _getYAxisLabelAlignment(tl) {\n const {position, ticks: {crossAlign, mirror, padding}} = this.options;\n const labelSizes = this._getLabelSizes();\n const tickAndPadding = tl + padding;\n const widest = labelSizes.widest.width;\n\n let textAlign;\n let x;\n\n if (position === 'left') {\n if (mirror) {\n x = this.right + padding;\n\n if (crossAlign === 'near') {\n textAlign = 'left';\n } else if (crossAlign === 'center') {\n textAlign = 'center';\n x += (widest / 2);\n } else {\n textAlign = 'right';\n x += widest;\n }\n } else {\n x = this.right - tickAndPadding;\n\n if (crossAlign === 'near') {\n textAlign = 'right';\n } else if (crossAlign === 'center') {\n textAlign = 'center';\n x -= (widest / 2);\n } else {\n textAlign = 'left';\n x = this.left;\n }\n }\n } else if (position === 'right') {\n if (mirror) {\n x = this.left + padding;\n\n if (crossAlign === 'near') {\n textAlign = 'right';\n } else if (crossAlign === 'center') {\n textAlign = 'center';\n x -= (widest / 2);\n } else {\n textAlign = 'left';\n x -= widest;\n }\n } else {\n x = this.left + tickAndPadding;\n\n if (crossAlign === 'near') {\n textAlign = 'left';\n } else if (crossAlign === 'center') {\n textAlign = 'center';\n x += widest / 2;\n } else {\n textAlign = 'right';\n x = this.right;\n }\n }\n } else {\n textAlign = 'right';\n }\n\n return {textAlign, x};\n }\n\n /**\n\t * @private\n\t */\n _computeLabelArea() {\n if (this.options.ticks.mirror) {\n return;\n }\n\n const chart = this.chart;\n const position = this.options.position;\n\n if (position === 'left' || position === 'right') {\n return {top: 0, left: this.left, bottom: chart.height, right: this.right};\n } if (position === 'top' || position === 'bottom') {\n return {top: this.top, left: 0, bottom: this.bottom, right: chart.width};\n }\n }\n\n /**\n * @protected\n */\n drawBackground() {\n const {ctx, options: {backgroundColor}, left, top, width, height} = this;\n if (backgroundColor) {\n ctx.save();\n ctx.fillStyle = backgroundColor;\n ctx.fillRect(left, top, width, height);\n ctx.restore();\n }\n }\n\n getLineWidthForValue(value) {\n const grid = this.options.grid;\n if (!this._isVisible() || !grid.display) {\n return 0;\n }\n const ticks = this.ticks;\n const index = ticks.findIndex(t => t.value === value);\n if (index >= 0) {\n const opts = grid.setContext(this.getContext(index));\n return opts.lineWidth;\n }\n return 0;\n }\n\n /**\n\t * @protected\n\t */\n drawGrid(chartArea) {\n const grid = this.options.grid;\n const ctx = this.ctx;\n const items = this._gridLineItems || (this._gridLineItems = this._computeGridLineItems(chartArea));\n let i, ilen;\n\n const drawLine = (p1, p2, style) => {\n if (!style.width || !style.color) {\n return;\n }\n ctx.save();\n ctx.lineWidth = style.width;\n ctx.strokeStyle = style.color;\n ctx.setLineDash(style.borderDash || []);\n ctx.lineDashOffset = style.borderDashOffset;\n\n ctx.beginPath();\n ctx.moveTo(p1.x, p1.y);\n ctx.lineTo(p2.x, p2.y);\n ctx.stroke();\n ctx.restore();\n };\n\n if (grid.display) {\n for (i = 0, ilen = items.length; i < ilen; ++i) {\n const item = items[i];\n\n if (grid.drawOnChartArea) {\n drawLine(\n {x: item.x1, y: item.y1},\n {x: item.x2, y: item.y2},\n item\n );\n }\n\n if (grid.drawTicks) {\n drawLine(\n {x: item.tx1, y: item.ty1},\n {x: item.tx2, y: item.ty2},\n {\n color: item.tickColor,\n width: item.tickWidth,\n borderDash: item.tickBorderDash,\n borderDashOffset: item.tickBorderDashOffset\n }\n );\n }\n }\n }\n }\n\n /**\n\t * @protected\n\t */\n drawBorder() {\n const {chart, ctx, options: {border, grid}} = this;\n const borderOpts = border.setContext(this.getContext());\n const axisWidth = border.display ? borderOpts.width : 0;\n if (!axisWidth) {\n return;\n }\n const lastLineWidth = grid.setContext(this.getContext(0)).lineWidth;\n const borderValue = this._borderValue;\n let x1, x2, y1, y2;\n\n if (this.isHorizontal()) {\n x1 = _alignPixel(chart, this.left, axisWidth) - axisWidth / 2;\n x2 = _alignPixel(chart, this.right, lastLineWidth) + lastLineWidth / 2;\n y1 = y2 = borderValue;\n } else {\n y1 = _alignPixel(chart, this.top, axisWidth) - axisWidth / 2;\n y2 = _alignPixel(chart, this.bottom, lastLineWidth) + lastLineWidth / 2;\n x1 = x2 = borderValue;\n }\n ctx.save();\n ctx.lineWidth = borderOpts.width;\n ctx.strokeStyle = borderOpts.color;\n\n ctx.beginPath();\n ctx.moveTo(x1, y1);\n ctx.lineTo(x2, y2);\n ctx.stroke();\n\n ctx.restore();\n }\n\n /**\n\t * @protected\n\t */\n drawLabels(chartArea) {\n const optionTicks = this.options.ticks;\n\n if (!optionTicks.display) {\n return;\n }\n\n const ctx = this.ctx;\n\n const area = this._computeLabelArea();\n if (area) {\n clipArea(ctx, area);\n }\n\n const items = this.getLabelItems(chartArea);\n for (const item of items) {\n const renderTextOptions = item.options;\n const tickFont = item.font;\n const label = item.label;\n const y = item.textOffset;\n renderText(ctx, label, 0, y, tickFont, renderTextOptions);\n }\n\n if (area) {\n unclipArea(ctx);\n }\n }\n\n /**\n\t * @protected\n\t */\n drawTitle() {\n const {ctx, options: {position, title, reverse}} = this;\n\n if (!title.display) {\n return;\n }\n\n const font = toFont(title.font);\n const padding = toPadding(title.padding);\n const align = title.align;\n let offset = font.lineHeight / 2;\n\n if (position === 'bottom' || position === 'center' || isObject(position)) {\n offset += padding.bottom;\n if (isArray(title.text)) {\n offset += font.lineHeight * (title.text.length - 1);\n }\n } else {\n offset += padding.top;\n }\n\n const {titleX, titleY, maxWidth, rotation} = titleArgs(this, offset, position, align);\n\n renderText(ctx, title.text, 0, 0, font, {\n color: title.color,\n maxWidth,\n rotation,\n textAlign: titleAlign(align, position, reverse),\n textBaseline: 'middle',\n translation: [titleX, titleY],\n });\n }\n\n draw(chartArea) {\n if (!this._isVisible()) {\n return;\n }\n\n this.drawBackground();\n this.drawGrid(chartArea);\n this.drawBorder();\n this.drawTitle();\n this.drawLabels(chartArea);\n }\n\n /**\n\t * @return {object[]}\n\t * @private\n\t */\n _layers() {\n const opts = this.options;\n const tz = opts.ticks && opts.ticks.z || 0;\n const gz = valueOrDefault(opts.grid && opts.grid.z, -1);\n const bz = valueOrDefault(opts.border && opts.border.z, 0);\n\n if (!this._isVisible() || this.draw !== Scale.prototype.draw) {\n // backward compatibility: draw has been overridden by custom scale\n return [{\n z: tz,\n draw: (chartArea) => {\n this.draw(chartArea);\n }\n }];\n }\n\n return [{\n z: gz,\n draw: (chartArea) => {\n this.drawBackground();\n this.drawGrid(chartArea);\n this.drawTitle();\n }\n }, {\n z: bz,\n draw: () => {\n this.drawBorder();\n }\n }, {\n z: tz,\n draw: (chartArea) => {\n this.drawLabels(chartArea);\n }\n }];\n }\n\n /**\n\t * Returns visible dataset metas that are attached to this scale\n\t * @param {string} [type] - if specified, also filter by dataset type\n\t * @return {object[]}\n\t */\n getMatchingVisibleMetas(type) {\n const metas = this.chart.getSortedVisibleDatasetMetas();\n const axisID = this.axis + 'AxisID';\n const result = [];\n let i, ilen;\n\n for (i = 0, ilen = metas.length; i < ilen; ++i) {\n const meta = metas[i];\n if (meta[axisID] === this.id && (!type || meta.type === type)) {\n result.push(meta);\n }\n }\n return result;\n }\n\n /**\n\t * @param {number} index\n\t * @return {object}\n\t * @protected\n \t */\n _resolveTickFontOptions(index) {\n const opts = this.options.ticks.setContext(this.getContext(index));\n return toFont(opts.font);\n }\n\n /**\n * @protected\n */\n _maxDigits() {\n const fontSize = this._resolveTickFontOptions(0).lineHeight;\n return (this.isHorizontal() ? this.width : this.height) / fontSize;\n }\n}\n","import {merge} from '../helpers/index.js';\nimport defaults, {overrides} from './core.defaults.js';\n\n/**\n * @typedef {{id: string, defaults: any, overrides?: any, defaultRoutes: any}} IChartComponent\n */\n\nexport default class TypedRegistry {\n constructor(type, scope, override) {\n this.type = type;\n this.scope = scope;\n this.override = override;\n this.items = Object.create(null);\n }\n\n isForType(type) {\n return Object.prototype.isPrototypeOf.call(this.type.prototype, type.prototype);\n }\n\n /**\n\t * @param {IChartComponent} item\n\t * @returns {string} The scope where items defaults were registered to.\n\t */\n register(item) {\n const proto = Object.getPrototypeOf(item);\n let parentScope;\n\n if (isIChartComponent(proto)) {\n // Make sure the parent is registered and note the scope where its defaults are.\n parentScope = this.register(proto);\n }\n\n const items = this.items;\n const id = item.id;\n const scope = this.scope + '.' + id;\n\n if (!id) {\n throw new Error('class does not have id: ' + item);\n }\n\n if (id in items) {\n // already registered\n return scope;\n }\n\n items[id] = item;\n registerDefaults(item, scope, parentScope);\n if (this.override) {\n defaults.override(item.id, item.overrides);\n }\n\n return scope;\n }\n\n /**\n\t * @param {string} id\n\t * @returns {object?}\n\t */\n get(id) {\n return this.items[id];\n }\n\n /**\n\t * @param {IChartComponent} item\n\t */\n unregister(item) {\n const items = this.items;\n const id = item.id;\n const scope = this.scope;\n\n if (id in items) {\n delete items[id];\n }\n\n if (scope && id in defaults[scope]) {\n delete defaults[scope][id];\n if (this.override) {\n delete overrides[id];\n }\n }\n }\n}\n\nfunction registerDefaults(item, scope, parentScope) {\n // Inherit the parent's defaults and keep existing defaults\n const itemDefaults = merge(Object.create(null), [\n parentScope ? defaults.get(parentScope) : {},\n defaults.get(scope),\n item.defaults\n ]);\n\n defaults.set(scope, itemDefaults);\n\n if (item.defaultRoutes) {\n routeDefaults(scope, item.defaultRoutes);\n }\n\n if (item.descriptors) {\n defaults.describe(scope, item.descriptors);\n }\n}\n\nfunction routeDefaults(scope, routes) {\n Object.keys(routes).forEach(property => {\n const propertyParts = property.split('.');\n const sourceName = propertyParts.pop();\n const sourceScope = [scope].concat(propertyParts).join('.');\n const parts = routes[property].split('.');\n const targetName = parts.pop();\n const targetScope = parts.join('.');\n defaults.route(sourceScope, sourceName, targetScope, targetName);\n });\n}\n\nfunction isIChartComponent(proto) {\n return 'id' in proto && 'defaults' in proto;\n}\n","import DatasetController from './core.datasetController.js';\nimport Element from './core.element.js';\nimport Scale from './core.scale.js';\nimport TypedRegistry from './core.typedRegistry.js';\nimport {each, callback as call, _capitalize} from '../helpers/helpers.core.js';\n\n/**\n * Please use the module's default export which provides a singleton instance\n * Note: class is exported for typedoc\n */\nexport class Registry {\n constructor() {\n this.controllers = new TypedRegistry(DatasetController, 'datasets', true);\n this.elements = new TypedRegistry(Element, 'elements');\n this.plugins = new TypedRegistry(Object, 'plugins');\n this.scales = new TypedRegistry(Scale, 'scales');\n // Order is important, Scale has Element in prototype chain,\n // so Scales must be before Elements. Plugins are a fallback, so not listed here.\n this._typedRegistries = [this.controllers, this.scales, this.elements];\n }\n\n /**\n\t * @param {...any} args\n\t */\n add(...args) {\n this._each('register', args);\n }\n\n remove(...args) {\n this._each('unregister', args);\n }\n\n /**\n\t * @param {...typeof DatasetController} args\n\t */\n addControllers(...args) {\n this._each('register', args, this.controllers);\n }\n\n /**\n\t * @param {...typeof Element} args\n\t */\n addElements(...args) {\n this._each('register', args, this.elements);\n }\n\n /**\n\t * @param {...any} args\n\t */\n addPlugins(...args) {\n this._each('register', args, this.plugins);\n }\n\n /**\n\t * @param {...typeof Scale} args\n\t */\n addScales(...args) {\n this._each('register', args, this.scales);\n }\n\n /**\n\t * @param {string} id\n\t * @returns {typeof DatasetController}\n\t */\n getController(id) {\n return this._get(id, this.controllers, 'controller');\n }\n\n /**\n\t * @param {string} id\n\t * @returns {typeof Element}\n\t */\n getElement(id) {\n return this._get(id, this.elements, 'element');\n }\n\n /**\n\t * @param {string} id\n\t * @returns {object}\n\t */\n getPlugin(id) {\n return this._get(id, this.plugins, 'plugin');\n }\n\n /**\n\t * @param {string} id\n\t * @returns {typeof Scale}\n\t */\n getScale(id) {\n return this._get(id, this.scales, 'scale');\n }\n\n /**\n\t * @param {...typeof DatasetController} args\n\t */\n removeControllers(...args) {\n this._each('unregister', args, this.controllers);\n }\n\n /**\n\t * @param {...typeof Element} args\n\t */\n removeElements(...args) {\n this._each('unregister', args, this.elements);\n }\n\n /**\n\t * @param {...any} args\n\t */\n removePlugins(...args) {\n this._each('unregister', args, this.plugins);\n }\n\n /**\n\t * @param {...typeof Scale} args\n\t */\n removeScales(...args) {\n this._each('unregister', args, this.scales);\n }\n\n /**\n\t * @private\n\t */\n _each(method, args, typedRegistry) {\n [...args].forEach(arg => {\n const reg = typedRegistry || this._getRegistryForType(arg);\n if (typedRegistry || reg.isForType(arg) || (reg === this.plugins && arg.id)) {\n this._exec(method, reg, arg);\n } else {\n // Handle loopable args\n // Use case:\n // import * as plugins from './plugins.js';\n // Chart.register(plugins);\n each(arg, item => {\n // If there are mixed types in the loopable, make sure those are\n // registered in correct registry\n // Use case: (treemap exporting controller, elements etc)\n // import * as treemap from 'chartjs-chart-treemap.js';\n // Chart.register(treemap);\n\n const itemReg = typedRegistry || this._getRegistryForType(item);\n this._exec(method, itemReg, item);\n });\n }\n });\n }\n\n /**\n\t * @private\n\t */\n _exec(method, registry, component) {\n const camelMethod = _capitalize(method);\n call(component['before' + camelMethod], [], component); // beforeRegister / beforeUnregister\n registry[method](component);\n call(component['after' + camelMethod], [], component); // afterRegister / afterUnregister\n }\n\n /**\n\t * @private\n\t */\n _getRegistryForType(type) {\n for (let i = 0; i < this._typedRegistries.length; i++) {\n const reg = this._typedRegistries[i];\n if (reg.isForType(type)) {\n return reg;\n }\n }\n // plugins is the fallback registry\n return this.plugins;\n }\n\n /**\n\t * @private\n\t */\n _get(id, typedRegistry, type) {\n const item = typedRegistry.get(id);\n if (item === undefined) {\n throw new Error('\"' + id + '\" is not a registered ' + type + '.');\n }\n return item;\n }\n\n}\n\n// singleton instance\nexport default /* #__PURE__ */ new Registry();\n","import registry from './core.registry.js';\nimport {callback as callCallback, isNullOrUndef, valueOrDefault} from '../helpers/helpers.core.js';\n\n/**\n * @typedef { import('./core.controller.js').default } Chart\n * @typedef { import('../types/index.js').ChartEvent } ChartEvent\n * @typedef { import('../plugins/plugin.tooltip.js').default } Tooltip\n */\n\n/**\n * @callback filterCallback\n * @param {{plugin: object, options: object}} value\n * @param {number} [index]\n * @param {array} [array]\n * @param {object} [thisArg]\n * @return {boolean}\n */\n\n\nexport default class PluginService {\n constructor() {\n this._init = undefined;\n }\n\n /**\n\t * Calls enabled plugins for `chart` on the specified hook and with the given args.\n\t * This method immediately returns as soon as a plugin explicitly returns false. The\n\t * returned value can be used, for instance, to interrupt the current action.\n\t * @param {Chart} chart - The chart instance for which plugins should be called.\n\t * @param {string} hook - The name of the plugin method to call (e.g. 'beforeUpdate').\n\t * @param {object} [args] - Extra arguments to apply to the hook call.\n * @param {filterCallback} [filter] - Filtering function for limiting which plugins are notified\n\t * @returns {boolean} false if any of the plugins return false, else returns true.\n\t */\n notify(chart, hook, args, filter) {\n if (hook === 'beforeInit') {\n this._init = this._createDescriptors(chart, true);\n this._notify(this._init, chart, 'install');\n }\n\n if (this._init === undefined) { // Do not trigger events before install\n return;\n }\n\n const descriptors = filter ? this._descriptors(chart).filter(filter) : this._descriptors(chart);\n const result = this._notify(descriptors, chart, hook, args);\n\n if (hook === 'afterDestroy') {\n this._notify(descriptors, chart, 'stop');\n this._notify(this._init, chart, 'uninstall');\n this._init = undefined; // Do not trigger events after uninstall\n }\n return result;\n }\n\n /**\n\t * @private\n\t */\n _notify(descriptors, chart, hook, args) {\n args = args || {};\n for (const descriptor of descriptors) {\n const plugin = descriptor.plugin;\n const method = plugin[hook];\n const params = [chart, args, descriptor.options];\n if (callCallback(method, params, plugin) === false && args.cancelable) {\n return false;\n }\n }\n\n return true;\n }\n\n invalidate() {\n // When plugins are registered, there is the possibility of a double\n // invalidate situation. In this case, we only want to invalidate once.\n // If we invalidate multiple times, the `_oldCache` is lost and all of the\n // plugins are restarted without being correctly stopped.\n // See https://github.com/chartjs/Chart.js/issues/8147\n if (!isNullOrUndef(this._cache)) {\n this._oldCache = this._cache;\n this._cache = undefined;\n }\n }\n\n /**\n\t * @param {Chart} chart\n\t * @private\n\t */\n _descriptors(chart) {\n if (this._cache) {\n return this._cache;\n }\n\n const descriptors = this._cache = this._createDescriptors(chart);\n\n this._notifyStateChanges(chart);\n\n return descriptors;\n }\n\n _createDescriptors(chart, all) {\n const config = chart && chart.config;\n const options = valueOrDefault(config.options && config.options.plugins, {});\n const plugins = allPlugins(config);\n // options === false => all plugins are disabled\n return options === false && !all ? [] : createDescriptors(chart, plugins, options, all);\n }\n\n /**\n\t * @param {Chart} chart\n\t * @private\n\t */\n _notifyStateChanges(chart) {\n const previousDescriptors = this._oldCache || [];\n const descriptors = this._cache;\n const diff = (a, b) => a.filter(x => !b.some(y => x.plugin.id === y.plugin.id));\n this._notify(diff(previousDescriptors, descriptors), chart, 'stop');\n this._notify(diff(descriptors, previousDescriptors), chart, 'start');\n }\n}\n\n/**\n * @param {import('./core.config.js').default} config\n */\nfunction allPlugins(config) {\n const localIds = {};\n const plugins = [];\n const keys = Object.keys(registry.plugins.items);\n for (let i = 0; i < keys.length; i++) {\n plugins.push(registry.getPlugin(keys[i]));\n }\n\n const local = config.plugins || [];\n for (let i = 0; i < local.length; i++) {\n const plugin = local[i];\n\n if (plugins.indexOf(plugin) === -1) {\n plugins.push(plugin);\n localIds[plugin.id] = true;\n }\n }\n\n return {plugins, localIds};\n}\n\nfunction getOpts(options, all) {\n if (!all && options === false) {\n return null;\n }\n if (options === true) {\n return {};\n }\n return options;\n}\n\nfunction createDescriptors(chart, {plugins, localIds}, options, all) {\n const result = [];\n const context = chart.getContext();\n\n for (const plugin of plugins) {\n const id = plugin.id;\n const opts = getOpts(options[id], all);\n if (opts === null) {\n continue;\n }\n result.push({\n plugin,\n options: pluginOpts(chart.config, {plugin, local: localIds[id]}, opts, context)\n });\n }\n\n return result;\n}\n\nfunction pluginOpts(config, {plugin, local}, opts, context) {\n const keys = config.pluginScopeKeys(plugin);\n const scopes = config.getOptionScopes(opts, keys);\n if (local && plugin.defaults) {\n // make sure plugin defaults are in scopes for local (not registered) plugins\n scopes.push(plugin.defaults);\n }\n return config.createResolver(scopes, context, [''], {\n // These are just defaults that plugins can override\n scriptable: false,\n indexable: false,\n allKeys: true\n });\n}\n","import defaults, {overrides, descriptors} from './core.defaults.js';\nimport {mergeIf, resolveObjectKey, isArray, isFunction, valueOrDefault, isObject} from '../helpers/helpers.core.js';\nimport {_attachContext, _createResolver, _descriptors} from '../helpers/helpers.config.js';\n\nexport function getIndexAxis(type, options) {\n const datasetDefaults = defaults.datasets[type] || {};\n const datasetOptions = (options.datasets || {})[type] || {};\n return datasetOptions.indexAxis || options.indexAxis || datasetDefaults.indexAxis || 'x';\n}\n\nfunction getAxisFromDefaultScaleID(id, indexAxis) {\n let axis = id;\n if (id === '_index_') {\n axis = indexAxis;\n } else if (id === '_value_') {\n axis = indexAxis === 'x' ? 'y' : 'x';\n }\n return axis;\n}\n\nfunction getDefaultScaleIDFromAxis(axis, indexAxis) {\n return axis === indexAxis ? '_index_' : '_value_';\n}\n\nfunction idMatchesAxis(id) {\n if (id === 'x' || id === 'y' || id === 'r') {\n return id;\n }\n}\n\nfunction axisFromPosition(position) {\n if (position === 'top' || position === 'bottom') {\n return 'x';\n }\n if (position === 'left' || position === 'right') {\n return 'y';\n }\n}\n\nexport function determineAxis(id, ...scaleOptions) {\n if (idMatchesAxis(id)) {\n return id;\n }\n for (const opts of scaleOptions) {\n const axis = opts.axis\n || axisFromPosition(opts.position)\n || id.length > 1 && idMatchesAxis(id[0].toLowerCase());\n if (axis) {\n return axis;\n }\n }\n throw new Error(`Cannot determine type of '${id}' axis. Please provide 'axis' or 'position' option.`);\n}\n\nfunction getAxisFromDataset(id, axis, dataset) {\n if (dataset[axis + 'AxisID'] === id) {\n return {axis};\n }\n}\n\nfunction retrieveAxisFromDatasets(id, config) {\n if (config.data && config.data.datasets) {\n const boundDs = config.data.datasets.filter((d) => d.xAxisID === id || d.yAxisID === id);\n if (boundDs.length) {\n return getAxisFromDataset(id, 'x', boundDs[0]) || getAxisFromDataset(id, 'y', boundDs[0]);\n }\n }\n return {};\n}\n\nfunction mergeScaleConfig(config, options) {\n const chartDefaults = overrides[config.type] || {scales: {}};\n const configScales = options.scales || {};\n const chartIndexAxis = getIndexAxis(config.type, options);\n const scales = Object.create(null);\n\n // First figure out first scale id's per axis.\n Object.keys(configScales).forEach(id => {\n const scaleConf = configScales[id];\n if (!isObject(scaleConf)) {\n return console.error(`Invalid scale configuration for scale: ${id}`);\n }\n if (scaleConf._proxy) {\n return console.warn(`Ignoring resolver passed as options for scale: ${id}`);\n }\n const axis = determineAxis(id, scaleConf, retrieveAxisFromDatasets(id, config), defaults.scales[scaleConf.type]);\n const defaultId = getDefaultScaleIDFromAxis(axis, chartIndexAxis);\n const defaultScaleOptions = chartDefaults.scales || {};\n scales[id] = mergeIf(Object.create(null), [{axis}, scaleConf, defaultScaleOptions[axis], defaultScaleOptions[defaultId]]);\n });\n\n // Then merge dataset defaults to scale configs\n config.data.datasets.forEach(dataset => {\n const type = dataset.type || config.type;\n const indexAxis = dataset.indexAxis || getIndexAxis(type, options);\n const datasetDefaults = overrides[type] || {};\n const defaultScaleOptions = datasetDefaults.scales || {};\n Object.keys(defaultScaleOptions).forEach(defaultID => {\n const axis = getAxisFromDefaultScaleID(defaultID, indexAxis);\n const id = dataset[axis + 'AxisID'] || axis;\n scales[id] = scales[id] || Object.create(null);\n mergeIf(scales[id], [{axis}, configScales[id], defaultScaleOptions[defaultID]]);\n });\n });\n\n // apply scale defaults, if not overridden by dataset defaults\n Object.keys(scales).forEach(key => {\n const scale = scales[key];\n mergeIf(scale, [defaults.scales[scale.type], defaults.scale]);\n });\n\n return scales;\n}\n\nfunction initOptions(config) {\n const options = config.options || (config.options = {});\n\n options.plugins = valueOrDefault(options.plugins, {});\n options.scales = mergeScaleConfig(config, options);\n}\n\nfunction initData(data) {\n data = data || {};\n data.datasets = data.datasets || [];\n data.labels = data.labels || [];\n return data;\n}\n\nfunction initConfig(config) {\n config = config || {};\n config.data = initData(config.data);\n\n initOptions(config);\n\n return config;\n}\n\nconst keyCache = new Map();\nconst keysCached = new Set();\n\nfunction cachedKeys(cacheKey, generate) {\n let keys = keyCache.get(cacheKey);\n if (!keys) {\n keys = generate();\n keyCache.set(cacheKey, keys);\n keysCached.add(keys);\n }\n return keys;\n}\n\nconst addIfFound = (set, obj, key) => {\n const opts = resolveObjectKey(obj, key);\n if (opts !== undefined) {\n set.add(opts);\n }\n};\n\nexport default class Config {\n constructor(config) {\n this._config = initConfig(config);\n this._scopeCache = new Map();\n this._resolverCache = new Map();\n }\n\n get platform() {\n return this._config.platform;\n }\n\n get type() {\n return this._config.type;\n }\n\n set type(type) {\n this._config.type = type;\n }\n\n get data() {\n return this._config.data;\n }\n\n set data(data) {\n this._config.data = initData(data);\n }\n\n get options() {\n return this._config.options;\n }\n\n set options(options) {\n this._config.options = options;\n }\n\n get plugins() {\n return this._config.plugins;\n }\n\n update() {\n const config = this._config;\n this.clearCache();\n initOptions(config);\n }\n\n clearCache() {\n this._scopeCache.clear();\n this._resolverCache.clear();\n }\n\n /**\n * Returns the option scope keys for resolving dataset options.\n * These keys do not include the dataset itself, because it is not under options.\n * @param {string} datasetType\n * @return {string[][]}\n */\n datasetScopeKeys(datasetType) {\n return cachedKeys(datasetType,\n () => [[\n `datasets.${datasetType}`,\n ''\n ]]);\n }\n\n /**\n * Returns the option scope keys for resolving dataset animation options.\n * These keys do not include the dataset itself, because it is not under options.\n * @param {string} datasetType\n * @param {string} transition\n * @return {string[][]}\n */\n datasetAnimationScopeKeys(datasetType, transition) {\n return cachedKeys(`${datasetType}.transition.${transition}`,\n () => [\n [\n `datasets.${datasetType}.transitions.${transition}`,\n `transitions.${transition}`,\n ],\n // The following are used for looking up the `animations` and `animation` keys\n [\n `datasets.${datasetType}`,\n ''\n ]\n ]);\n }\n\n /**\n * Returns the options scope keys for resolving element options that belong\n * to an dataset. These keys do not include the dataset itself, because it\n * is not under options.\n * @param {string} datasetType\n * @param {string} elementType\n * @return {string[][]}\n */\n datasetElementScopeKeys(datasetType, elementType) {\n return cachedKeys(`${datasetType}-${elementType}`,\n () => [[\n `datasets.${datasetType}.elements.${elementType}`,\n `datasets.${datasetType}`,\n `elements.${elementType}`,\n ''\n ]]);\n }\n\n /**\n * Returns the options scope keys for resolving plugin options.\n * @param {{id: string, additionalOptionScopes?: string[]}} plugin\n * @return {string[][]}\n */\n pluginScopeKeys(plugin) {\n const id = plugin.id;\n const type = this.type;\n return cachedKeys(`${type}-plugin-${id}`,\n () => [[\n `plugins.${id}`,\n ...plugin.additionalOptionScopes || [],\n ]]);\n }\n\n /**\n * @private\n */\n _cachedScopes(mainScope, resetCache) {\n const _scopeCache = this._scopeCache;\n let cache = _scopeCache.get(mainScope);\n if (!cache || resetCache) {\n cache = new Map();\n _scopeCache.set(mainScope, cache);\n }\n return cache;\n }\n\n /**\n * Resolves the objects from options and defaults for option value resolution.\n * @param {object} mainScope - The main scope object for options\n * @param {string[][]} keyLists - The arrays of keys in resolution order\n * @param {boolean} [resetCache] - reset the cache for this mainScope\n */\n getOptionScopes(mainScope, keyLists, resetCache) {\n const {options, type} = this;\n const cache = this._cachedScopes(mainScope, resetCache);\n const cached = cache.get(keyLists);\n if (cached) {\n return cached;\n }\n\n const scopes = new Set();\n\n keyLists.forEach(keys => {\n if (mainScope) {\n scopes.add(mainScope);\n keys.forEach(key => addIfFound(scopes, mainScope, key));\n }\n keys.forEach(key => addIfFound(scopes, options, key));\n keys.forEach(key => addIfFound(scopes, overrides[type] || {}, key));\n keys.forEach(key => addIfFound(scopes, defaults, key));\n keys.forEach(key => addIfFound(scopes, descriptors, key));\n });\n\n const array = Array.from(scopes);\n if (array.length === 0) {\n array.push(Object.create(null));\n }\n if (keysCached.has(keyLists)) {\n cache.set(keyLists, array);\n }\n return array;\n }\n\n /**\n * Returns the option scopes for resolving chart options\n * @return {object[]}\n */\n chartOptionScopes() {\n const {options, type} = this;\n\n return [\n options,\n overrides[type] || {},\n defaults.datasets[type] || {}, // https://github.com/chartjs/Chart.js/issues/8531\n {type},\n defaults,\n descriptors\n ];\n }\n\n /**\n * @param {object[]} scopes\n * @param {string[]} names\n * @param {function|object} context\n * @param {string[]} [prefixes]\n * @return {object}\n */\n resolveNamedOptions(scopes, names, context, prefixes = ['']) {\n const result = {$shared: true};\n const {resolver, subPrefixes} = getResolver(this._resolverCache, scopes, prefixes);\n let options = resolver;\n if (needContext(resolver, names)) {\n result.$shared = false;\n context = isFunction(context) ? context() : context;\n // subResolver is passed to scriptable options. It should not resolve to hover options.\n const subResolver = this.createResolver(scopes, context, subPrefixes);\n options = _attachContext(resolver, context, subResolver);\n }\n\n for (const prop of names) {\n result[prop] = options[prop];\n }\n return result;\n }\n\n /**\n * @param {object[]} scopes\n * @param {object} [context]\n * @param {string[]} [prefixes]\n * @param {{scriptable: boolean, indexable: boolean, allKeys?: boolean}} [descriptorDefaults]\n */\n createResolver(scopes, context, prefixes = [''], descriptorDefaults) {\n const {resolver} = getResolver(this._resolverCache, scopes, prefixes);\n return isObject(context)\n ? _attachContext(resolver, context, undefined, descriptorDefaults)\n : resolver;\n }\n}\n\nfunction getResolver(resolverCache, scopes, prefixes) {\n let cache = resolverCache.get(scopes);\n if (!cache) {\n cache = new Map();\n resolverCache.set(scopes, cache);\n }\n const cacheKey = prefixes.join();\n let cached = cache.get(cacheKey);\n if (!cached) {\n const resolver = _createResolver(scopes, prefixes);\n cached = {\n resolver,\n subPrefixes: prefixes.filter(p => !p.toLowerCase().includes('hover'))\n };\n cache.set(cacheKey, cached);\n }\n return cached;\n}\n\nconst hasFunction = value => isObject(value)\n && Object.getOwnPropertyNames(value).some((key) => isFunction(value[key]));\n\nfunction needContext(proxy, names) {\n const {isScriptable, isIndexable} = _descriptors(proxy);\n\n for (const prop of names) {\n const scriptable = isScriptable(prop);\n const indexable = isIndexable(prop);\n const value = (indexable || scriptable) && proxy[prop];\n if ((scriptable && (isFunction(value) || hasFunction(value)))\n || (indexable && isArray(value))) {\n return true;\n }\n }\n return false;\n}\n","import animator from './core.animator.js';\nimport defaults, {overrides} from './core.defaults.js';\nimport Interaction from './core.interaction.js';\nimport layouts from './core.layouts.js';\nimport {_detectPlatform} from '../platform/index.js';\nimport PluginService from './core.plugins.js';\nimport registry from './core.registry.js';\nimport Config, {determineAxis, getIndexAxis} from './core.config.js';\nimport {each, callback as callCallback, uid, valueOrDefault, _elementsEqual, isNullOrUndef, setsEqual, defined, isFunction, _isClickEvent} from '../helpers/helpers.core.js';\nimport {clearCanvas, clipArea, createContext, unclipArea, _isPointInArea, _isDomSupported, retinaScale, getDatasetClipArea} from '../helpers/index.js';\n// @ts-ignore\nimport {version} from '../../package.json';\nimport {debounce} from '../helpers/helpers.extras.js';\n\n/**\n * @typedef { import('../types/index.js').ChartEvent } ChartEvent\n * @typedef { import('../types/index.js').Point } Point\n */\n\nconst KNOWN_POSITIONS = ['top', 'bottom', 'left', 'right', 'chartArea'];\nfunction positionIsHorizontal(position, axis) {\n return position === 'top' || position === 'bottom' || (KNOWN_POSITIONS.indexOf(position) === -1 && axis === 'x');\n}\n\nfunction compare2Level(l1, l2) {\n return function(a, b) {\n return a[l1] === b[l1]\n ? a[l2] - b[l2]\n : a[l1] - b[l1];\n };\n}\n\nfunction onAnimationsComplete(context) {\n const chart = context.chart;\n const animationOptions = chart.options.animation;\n\n chart.notifyPlugins('afterRender');\n callCallback(animationOptions && animationOptions.onComplete, [context], chart);\n}\n\nfunction onAnimationProgress(context) {\n const chart = context.chart;\n const animationOptions = chart.options.animation;\n callCallback(animationOptions && animationOptions.onProgress, [context], chart);\n}\n\n/**\n * Chart.js can take a string id of a canvas element, a 2d context, or a canvas element itself.\n * Attempt to unwrap the item passed into the chart constructor so that it is a canvas element (if possible).\n */\nfunction getCanvas(item) {\n if (_isDomSupported() && typeof item === 'string') {\n item = document.getElementById(item);\n } else if (item && item.length) {\n // Support for array based queries (such as jQuery)\n item = item[0];\n }\n\n if (item && item.canvas) {\n // Support for any object associated to a canvas (including a context2d)\n item = item.canvas;\n }\n return item;\n}\n\nconst instances = {};\nconst getChart = (key) => {\n const canvas = getCanvas(key);\n return Object.values(instances).filter((c) => c.canvas === canvas).pop();\n};\n\nfunction moveNumericKeys(obj, start, move) {\n const keys = Object.keys(obj);\n for (const key of keys) {\n const intKey = +key;\n if (intKey >= start) {\n const value = obj[key];\n delete obj[key];\n if (move > 0 || intKey > start) {\n obj[intKey + move] = value;\n }\n }\n }\n}\n\n/**\n * @param {ChartEvent} e\n * @param {ChartEvent|null} lastEvent\n * @param {boolean} inChartArea\n * @param {boolean} isClick\n * @returns {ChartEvent|null}\n */\nfunction determineLastEvent(e, lastEvent, inChartArea, isClick) {\n if (!inChartArea || e.type === 'mouseout') {\n return null;\n }\n if (isClick) {\n return lastEvent;\n }\n return e;\n}\n\nclass Chart {\n\n static defaults = defaults;\n static instances = instances;\n static overrides = overrides;\n static registry = registry;\n static version = version;\n static getChart = getChart;\n\n static register(...items) {\n registry.add(...items);\n invalidatePlugins();\n }\n\n static unregister(...items) {\n registry.remove(...items);\n invalidatePlugins();\n }\n\n // eslint-disable-next-line max-statements\n constructor(item, userConfig) {\n const config = this.config = new Config(userConfig);\n const initialCanvas = getCanvas(item);\n const existingChart = getChart(initialCanvas);\n if (existingChart) {\n throw new Error(\n 'Canvas is already in use. Chart with ID \\'' + existingChart.id + '\\'' +\n\t\t\t\t' must be destroyed before the canvas with ID \\'' + existingChart.canvas.id + '\\' can be reused.'\n );\n }\n\n const options = config.createResolver(config.chartOptionScopes(), this.getContext());\n\n this.platform = new (config.platform || _detectPlatform(initialCanvas))();\n this.platform.updateConfig(config);\n\n const context = this.platform.acquireContext(initialCanvas, options.aspectRatio);\n const canvas = context && context.canvas;\n const height = canvas && canvas.height;\n const width = canvas && canvas.width;\n\n this.id = uid();\n this.ctx = context;\n this.canvas = canvas;\n this.width = width;\n this.height = height;\n this._options = options;\n // Store the previously used aspect ratio to determine if a resize\n // is needed during updates. Do this after _options is set since\n // aspectRatio uses a getter\n this._aspectRatio = this.aspectRatio;\n this._layers = [];\n this._metasets = [];\n this._stacks = undefined;\n this.boxes = [];\n this.currentDevicePixelRatio = undefined;\n this.chartArea = undefined;\n this._active = [];\n this._lastEvent = undefined;\n this._listeners = {};\n /** @type {?{attach?: function, detach?: function, resize?: function}} */\n this._responsiveListeners = undefined;\n this._sortedMetasets = [];\n this.scales = {};\n this._plugins = new PluginService();\n this.$proxies = {};\n this._hiddenIndices = {};\n this.attached = false;\n this._animationsDisabled = undefined;\n this.$context = undefined;\n this._doResize = debounce(mode => this.update(mode), options.resizeDelay || 0);\n this._dataChanges = [];\n\n // Add the chart instance to the global namespace\n instances[this.id] = this;\n\n if (!context || !canvas) {\n // The given item is not a compatible context2d element, let's return before finalizing\n // the chart initialization but after setting basic chart / controller properties that\n // can help to figure out that the chart is not valid (e.g chart.canvas !== null);\n // https://github.com/chartjs/Chart.js/issues/2807\n console.error(\"Failed to create chart: can't acquire context from the given item\");\n return;\n }\n\n animator.listen(this, 'complete', onAnimationsComplete);\n animator.listen(this, 'progress', onAnimationProgress);\n\n this._initialize();\n if (this.attached) {\n this.update();\n }\n }\n\n get aspectRatio() {\n const {options: {aspectRatio, maintainAspectRatio}, width, height, _aspectRatio} = this;\n if (!isNullOrUndef(aspectRatio)) {\n // If aspectRatio is defined in options, use that.\n return aspectRatio;\n }\n\n if (maintainAspectRatio && _aspectRatio) {\n // If maintainAspectRatio is truthly and we had previously determined _aspectRatio, use that\n return _aspectRatio;\n }\n\n // Calculate\n return height ? width / height : null;\n }\n\n get data() {\n return this.config.data;\n }\n\n set data(data) {\n this.config.data = data;\n }\n\n get options() {\n return this._options;\n }\n\n set options(options) {\n this.config.options = options;\n }\n\n get registry() {\n return registry;\n }\n\n /**\n\t * @private\n\t */\n _initialize() {\n // Before init plugin notification\n this.notifyPlugins('beforeInit');\n\n if (this.options.responsive) {\n this.resize();\n } else {\n retinaScale(this, this.options.devicePixelRatio);\n }\n\n this.bindEvents();\n\n // After init plugin notification\n this.notifyPlugins('afterInit');\n\n return this;\n }\n\n clear() {\n clearCanvas(this.canvas, this.ctx);\n return this;\n }\n\n stop() {\n animator.stop(this);\n return this;\n }\n\n /**\n\t * Resize the chart to its container or to explicit dimensions.\n\t * @param {number} [width]\n\t * @param {number} [height]\n\t */\n resize(width, height) {\n if (!animator.running(this)) {\n this._resize(width, height);\n } else {\n this._resizeBeforeDraw = {width, height};\n }\n }\n\n _resize(width, height) {\n const options = this.options;\n const canvas = this.canvas;\n const aspectRatio = options.maintainAspectRatio && this.aspectRatio;\n const newSize = this.platform.getMaximumSize(canvas, width, height, aspectRatio);\n const newRatio = options.devicePixelRatio || this.platform.getDevicePixelRatio();\n const mode = this.width ? 'resize' : 'attach';\n\n this.width = newSize.width;\n this.height = newSize.height;\n this._aspectRatio = this.aspectRatio;\n if (!retinaScale(this, newRatio, true)) {\n return;\n }\n\n this.notifyPlugins('resize', {size: newSize});\n\n callCallback(options.onResize, [this, newSize], this);\n\n if (this.attached) {\n if (this._doResize(mode)) {\n // The resize update is delayed, only draw without updating.\n this.render();\n }\n }\n }\n\n ensureScalesHaveIDs() {\n const options = this.options;\n const scalesOptions = options.scales || {};\n\n each(scalesOptions, (axisOptions, axisID) => {\n axisOptions.id = axisID;\n });\n }\n\n /**\n\t * Builds a map of scale ID to scale object for future lookup.\n\t */\n buildOrUpdateScales() {\n const options = this.options;\n const scaleOpts = options.scales;\n const scales = this.scales;\n const updated = Object.keys(scales).reduce((obj, id) => {\n obj[id] = false;\n return obj;\n }, {});\n let items = [];\n\n if (scaleOpts) {\n items = items.concat(\n Object.keys(scaleOpts).map((id) => {\n const scaleOptions = scaleOpts[id];\n const axis = determineAxis(id, scaleOptions);\n const isRadial = axis === 'r';\n const isHorizontal = axis === 'x';\n return {\n options: scaleOptions,\n dposition: isRadial ? 'chartArea' : isHorizontal ? 'bottom' : 'left',\n dtype: isRadial ? 'radialLinear' : isHorizontal ? 'category' : 'linear'\n };\n })\n );\n }\n\n each(items, (item) => {\n const scaleOptions = item.options;\n const id = scaleOptions.id;\n const axis = determineAxis(id, scaleOptions);\n const scaleType = valueOrDefault(scaleOptions.type, item.dtype);\n\n if (scaleOptions.position === undefined || positionIsHorizontal(scaleOptions.position, axis) !== positionIsHorizontal(item.dposition)) {\n scaleOptions.position = item.dposition;\n }\n\n updated[id] = true;\n let scale = null;\n if (id in scales && scales[id].type === scaleType) {\n scale = scales[id];\n } else {\n const scaleClass = registry.getScale(scaleType);\n scale = new scaleClass({\n id,\n type: scaleType,\n ctx: this.ctx,\n chart: this\n });\n scales[scale.id] = scale;\n }\n\n scale.init(scaleOptions, options);\n });\n // clear up discarded scales\n each(updated, (hasUpdated, id) => {\n if (!hasUpdated) {\n delete scales[id];\n }\n });\n\n each(scales, (scale) => {\n layouts.configure(this, scale, scale.options);\n layouts.addBox(this, scale);\n });\n }\n\n /**\n\t * @private\n\t */\n _updateMetasets() {\n const metasets = this._metasets;\n const numData = this.data.datasets.length;\n const numMeta = metasets.length;\n\n metasets.sort((a, b) => a.index - b.index);\n if (numMeta > numData) {\n for (let i = numData; i < numMeta; ++i) {\n this._destroyDatasetMeta(i);\n }\n metasets.splice(numData, numMeta - numData);\n }\n this._sortedMetasets = metasets.slice(0).sort(compare2Level('order', 'index'));\n }\n\n /**\n\t * @private\n\t */\n _removeUnreferencedMetasets() {\n const {_metasets: metasets, data: {datasets}} = this;\n if (metasets.length > datasets.length) {\n delete this._stacks;\n }\n metasets.forEach((meta, index) => {\n if (datasets.filter(x => x === meta._dataset).length === 0) {\n this._destroyDatasetMeta(index);\n }\n });\n }\n\n buildOrUpdateControllers() {\n const newControllers = [];\n const datasets = this.data.datasets;\n let i, ilen;\n\n this._removeUnreferencedMetasets();\n\n for (i = 0, ilen = datasets.length; i < ilen; i++) {\n const dataset = datasets[i];\n let meta = this.getDatasetMeta(i);\n const type = dataset.type || this.config.type;\n\n if (meta.type && meta.type !== type) {\n this._destroyDatasetMeta(i);\n meta = this.getDatasetMeta(i);\n }\n meta.type = type;\n meta.indexAxis = dataset.indexAxis || getIndexAxis(type, this.options);\n meta.order = dataset.order || 0;\n meta.index = i;\n meta.label = '' + dataset.label;\n meta.visible = this.isDatasetVisible(i);\n\n if (meta.controller) {\n meta.controller.updateIndex(i);\n meta.controller.linkScales();\n } else {\n const ControllerClass = registry.getController(type);\n const {datasetElementType, dataElementType} = defaults.datasets[type];\n Object.assign(ControllerClass, {\n dataElementType: registry.getElement(dataElementType),\n datasetElementType: datasetElementType && registry.getElement(datasetElementType)\n });\n meta.controller = new ControllerClass(this, i);\n newControllers.push(meta.controller);\n }\n }\n\n this._updateMetasets();\n return newControllers;\n }\n\n /**\n\t * Reset the elements of all datasets\n\t * @private\n\t */\n _resetElements() {\n each(this.data.datasets, (dataset, datasetIndex) => {\n this.getDatasetMeta(datasetIndex).controller.reset();\n }, this);\n }\n\n /**\n\t* Resets the chart back to its state before the initial animation\n\t*/\n reset() {\n this._resetElements();\n this.notifyPlugins('reset');\n }\n\n update(mode) {\n const config = this.config;\n\n config.update();\n const options = this._options = config.createResolver(config.chartOptionScopes(), this.getContext());\n const animsDisabled = this._animationsDisabled = !options.animation;\n\n this._updateScales();\n this._checkEventBindings();\n this._updateHiddenIndices();\n\n // plugins options references might have change, let's invalidate the cache\n // https://github.com/chartjs/Chart.js/issues/5111#issuecomment-355934167\n this._plugins.invalidate();\n\n if (this.notifyPlugins('beforeUpdate', {mode, cancelable: true}) === false) {\n return;\n }\n\n // Make sure dataset controllers are updated and new controllers are reset\n const newControllers = this.buildOrUpdateControllers();\n\n this.notifyPlugins('beforeElementsUpdate');\n\n // Make sure all dataset controllers have correct meta data counts\n let minPadding = 0;\n for (let i = 0, ilen = this.data.datasets.length; i < ilen; i++) {\n const {controller} = this.getDatasetMeta(i);\n const reset = !animsDisabled && newControllers.indexOf(controller) === -1;\n // New controllers will be reset after the layout pass, so we only want to modify\n // elements added to new datasets\n controller.buildOrUpdateElements(reset);\n minPadding = Math.max(+controller.getMaxOverflow(), minPadding);\n }\n minPadding = this._minPadding = options.layout.autoPadding ? minPadding : 0;\n this._updateLayout(minPadding);\n\n // Only reset the controllers if we have animations\n if (!animsDisabled) {\n // Can only reset the new controllers after the scales have been updated\n // Reset is done to get the starting point for the initial animation\n each(newControllers, (controller) => {\n controller.reset();\n });\n }\n\n this._updateDatasets(mode);\n\n // Do this before render so that any plugins that need final scale updates can use it\n this.notifyPlugins('afterUpdate', {mode});\n\n this._layers.sort(compare2Level('z', '_idx'));\n\n // Replay last event from before update, or set hover styles on active elements\n const {_active, _lastEvent} = this;\n if (_lastEvent) {\n this._eventHandler(_lastEvent, true);\n } else if (_active.length) {\n this._updateHoverStyles(_active, _active, true);\n }\n\n this.render();\n }\n\n /**\n * @private\n */\n _updateScales() {\n each(this.scales, (scale) => {\n layouts.removeBox(this, scale);\n });\n\n this.ensureScalesHaveIDs();\n this.buildOrUpdateScales();\n }\n\n /**\n * @private\n */\n _checkEventBindings() {\n const options = this.options;\n const existingEvents = new Set(Object.keys(this._listeners));\n const newEvents = new Set(options.events);\n\n if (!setsEqual(existingEvents, newEvents) || !!this._responsiveListeners !== options.responsive) {\n // The configured events have changed. Rebind.\n this.unbindEvents();\n this.bindEvents();\n }\n }\n\n /**\n * @private\n */\n _updateHiddenIndices() {\n const {_hiddenIndices} = this;\n const changes = this._getUniformDataChanges() || [];\n for (const {method, start, count} of changes) {\n const move = method === '_removeElements' ? -count : count;\n moveNumericKeys(_hiddenIndices, start, move);\n }\n }\n\n /**\n * @private\n */\n _getUniformDataChanges() {\n const _dataChanges = this._dataChanges;\n if (!_dataChanges || !_dataChanges.length) {\n return;\n }\n\n this._dataChanges = [];\n const datasetCount = this.data.datasets.length;\n const makeSet = (idx) => new Set(\n _dataChanges\n .filter(c => c[0] === idx)\n .map((c, i) => i + ',' + c.splice(1).join(','))\n );\n\n const changeSet = makeSet(0);\n for (let i = 1; i < datasetCount; i++) {\n if (!setsEqual(changeSet, makeSet(i))) {\n return;\n }\n }\n return Array.from(changeSet)\n .map(c => c.split(','))\n .map(a => ({method: a[1], start: +a[2], count: +a[3]}));\n }\n\n /**\n\t * Updates the chart layout unless a plugin returns `false` to the `beforeLayout`\n\t * hook, in which case, plugins will not be called on `afterLayout`.\n\t * @private\n\t */\n _updateLayout(minPadding) {\n if (this.notifyPlugins('beforeLayout', {cancelable: true}) === false) {\n return;\n }\n\n layouts.update(this, this.width, this.height, minPadding);\n\n const area = this.chartArea;\n const noArea = area.width <= 0 || area.height <= 0;\n\n this._layers = [];\n each(this.boxes, (box) => {\n if (noArea && box.position === 'chartArea') {\n // Skip drawing and configuring chartArea boxes when chartArea is zero or negative\n return;\n }\n\n // configure is called twice, once in core.scale.update and once here.\n // Here the boxes are fully updated and at their final positions.\n if (box.configure) {\n box.configure();\n }\n this._layers.push(...box._layers());\n }, this);\n\n this._layers.forEach((item, index) => {\n item._idx = index;\n });\n\n this.notifyPlugins('afterLayout');\n }\n\n /**\n\t * Updates all datasets unless a plugin returns `false` to the `beforeDatasetsUpdate`\n\t * hook, in which case, plugins will not be called on `afterDatasetsUpdate`.\n\t * @private\n\t */\n _updateDatasets(mode) {\n if (this.notifyPlugins('beforeDatasetsUpdate', {mode, cancelable: true}) === false) {\n return;\n }\n\n for (let i = 0, ilen = this.data.datasets.length; i < ilen; ++i) {\n this.getDatasetMeta(i).controller.configure();\n }\n\n for (let i = 0, ilen = this.data.datasets.length; i < ilen; ++i) {\n this._updateDataset(i, isFunction(mode) ? mode({datasetIndex: i}) : mode);\n }\n\n this.notifyPlugins('afterDatasetsUpdate', {mode});\n }\n\n /**\n\t * Updates dataset at index unless a plugin returns `false` to the `beforeDatasetUpdate`\n\t * hook, in which case, plugins will not be called on `afterDatasetUpdate`.\n\t * @private\n\t */\n _updateDataset(index, mode) {\n const meta = this.getDatasetMeta(index);\n const args = {meta, index, mode, cancelable: true};\n\n if (this.notifyPlugins('beforeDatasetUpdate', args) === false) {\n return;\n }\n\n meta.controller._update(mode);\n\n args.cancelable = false;\n this.notifyPlugins('afterDatasetUpdate', args);\n }\n\n render() {\n if (this.notifyPlugins('beforeRender', {cancelable: true}) === false) {\n return;\n }\n\n if (animator.has(this)) {\n if (this.attached && !animator.running(this)) {\n animator.start(this);\n }\n } else {\n this.draw();\n onAnimationsComplete({chart: this});\n }\n }\n\n draw() {\n let i;\n if (this._resizeBeforeDraw) {\n const {width, height} = this._resizeBeforeDraw;\n // Unset pending resize request now to avoid possible recursion within _resize\n this._resizeBeforeDraw = null;\n this._resize(width, height);\n }\n this.clear();\n\n if (this.width <= 0 || this.height <= 0) {\n return;\n }\n\n if (this.notifyPlugins('beforeDraw', {cancelable: true}) === false) {\n return;\n }\n\n // Because of plugin hooks (before/afterDatasetsDraw), datasets can't\n // currently be part of layers. Instead, we draw\n // layers <= 0 before(default, backward compat), and the rest after\n const layers = this._layers;\n for (i = 0; i < layers.length && layers[i].z <= 0; ++i) {\n layers[i].draw(this.chartArea);\n }\n\n this._drawDatasets();\n\n // Rest of layers\n for (; i < layers.length; ++i) {\n layers[i].draw(this.chartArea);\n }\n\n this.notifyPlugins('afterDraw');\n }\n\n /**\n\t * @private\n\t */\n _getSortedDatasetMetas(filterVisible) {\n const metasets = this._sortedMetasets;\n const result = [];\n let i, ilen;\n\n for (i = 0, ilen = metasets.length; i < ilen; ++i) {\n const meta = metasets[i];\n if (!filterVisible || meta.visible) {\n result.push(meta);\n }\n }\n\n return result;\n }\n\n /**\n\t * Gets the visible dataset metas in drawing order\n\t * @return {object[]}\n\t */\n getSortedVisibleDatasetMetas() {\n return this._getSortedDatasetMetas(true);\n }\n\n /**\n\t * Draws all datasets unless a plugin returns `false` to the `beforeDatasetsDraw`\n\t * hook, in which case, plugins will not be called on `afterDatasetsDraw`.\n\t * @private\n\t */\n _drawDatasets() {\n if (this.notifyPlugins('beforeDatasetsDraw', {cancelable: true}) === false) {\n return;\n }\n\n const metasets = this.getSortedVisibleDatasetMetas();\n for (let i = metasets.length - 1; i >= 0; --i) {\n this._drawDataset(metasets[i]);\n }\n\n this.notifyPlugins('afterDatasetsDraw');\n }\n\n /**\n\t * Draws dataset at index unless a plugin returns `false` to the `beforeDatasetDraw`\n\t * hook, in which case, plugins will not be called on `afterDatasetDraw`.\n\t * @private\n\t */\n _drawDataset(meta) {\n const ctx = this.ctx;\n const args = {\n meta,\n index: meta.index,\n cancelable: true\n };\n // @ts-expect-error\n const clip = getDatasetClipArea(this, meta);\n\n if (this.notifyPlugins('beforeDatasetDraw', args) === false) {\n return;\n }\n\n if (clip) {\n clipArea(ctx, clip);\n }\n\n meta.controller.draw();\n\n if (clip) {\n unclipArea(ctx);\n }\n\n args.cancelable = false;\n this.notifyPlugins('afterDatasetDraw', args);\n }\n\n /**\n * Checks whether the given point is in the chart area.\n * @param {Point} point - in relative coordinates (see, e.g., getRelativePosition)\n * @returns {boolean}\n */\n isPointInArea(point) {\n return _isPointInArea(point, this.chartArea, this._minPadding);\n }\n\n getElementsAtEventForMode(e, mode, options, useFinalPosition) {\n const method = Interaction.modes[mode];\n if (typeof method === 'function') {\n return method(this, e, options, useFinalPosition);\n }\n\n return [];\n }\n\n getDatasetMeta(datasetIndex) {\n const dataset = this.data.datasets[datasetIndex];\n const metasets = this._metasets;\n let meta = metasets.filter(x => x && x._dataset === dataset).pop();\n\n if (!meta) {\n meta = {\n type: null,\n data: [],\n dataset: null,\n controller: null,\n hidden: null,\t\t\t// See isDatasetVisible() comment\n xAxisID: null,\n yAxisID: null,\n order: dataset && dataset.order || 0,\n index: datasetIndex,\n _dataset: dataset,\n _parsed: [],\n _sorted: false\n };\n metasets.push(meta);\n }\n\n return meta;\n }\n\n getContext() {\n return this.$context || (this.$context = createContext(null, {chart: this, type: 'chart'}));\n }\n\n getVisibleDatasetCount() {\n return this.getSortedVisibleDatasetMetas().length;\n }\n\n isDatasetVisible(datasetIndex) {\n const dataset = this.data.datasets[datasetIndex];\n if (!dataset) {\n return false;\n }\n\n const meta = this.getDatasetMeta(datasetIndex);\n\n // meta.hidden is a per chart dataset hidden flag override with 3 states: if true or false,\n // the dataset.hidden value is ignored, else if null, the dataset hidden state is returned.\n return typeof meta.hidden === 'boolean' ? !meta.hidden : !dataset.hidden;\n }\n\n setDatasetVisibility(datasetIndex, visible) {\n const meta = this.getDatasetMeta(datasetIndex);\n meta.hidden = !visible;\n }\n\n toggleDataVisibility(index) {\n this._hiddenIndices[index] = !this._hiddenIndices[index];\n }\n\n getDataVisibility(index) {\n return !this._hiddenIndices[index];\n }\n\n /**\n\t * @private\n\t */\n _updateVisibility(datasetIndex, dataIndex, visible) {\n const mode = visible ? 'show' : 'hide';\n const meta = this.getDatasetMeta(datasetIndex);\n const anims = meta.controller._resolveAnimations(undefined, mode);\n\n if (defined(dataIndex)) {\n meta.data[dataIndex].hidden = !visible;\n this.update();\n } else {\n this.setDatasetVisibility(datasetIndex, visible);\n // Animate visible state, so hide animation can be seen. This could be handled better if update / updateDataset returned a Promise.\n anims.update(meta, {visible});\n this.update((ctx) => ctx.datasetIndex === datasetIndex ? mode : undefined);\n }\n }\n\n hide(datasetIndex, dataIndex) {\n this._updateVisibility(datasetIndex, dataIndex, false);\n }\n\n show(datasetIndex, dataIndex) {\n this._updateVisibility(datasetIndex, dataIndex, true);\n }\n\n /**\n\t * @private\n\t */\n _destroyDatasetMeta(datasetIndex) {\n const meta = this._metasets[datasetIndex];\n if (meta && meta.controller) {\n meta.controller._destroy();\n }\n delete this._metasets[datasetIndex];\n }\n\n _stop() {\n let i, ilen;\n this.stop();\n animator.remove(this);\n\n for (i = 0, ilen = this.data.datasets.length; i < ilen; ++i) {\n this._destroyDatasetMeta(i);\n }\n }\n\n destroy() {\n this.notifyPlugins('beforeDestroy');\n const {canvas, ctx} = this;\n\n this._stop();\n this.config.clearCache();\n\n if (canvas) {\n this.unbindEvents();\n clearCanvas(canvas, ctx);\n this.platform.releaseContext(ctx);\n this.canvas = null;\n this.ctx = null;\n }\n\n delete instances[this.id];\n\n this.notifyPlugins('afterDestroy');\n }\n\n toBase64Image(...args) {\n return this.canvas.toDataURL(...args);\n }\n\n /**\n\t * @private\n\t */\n bindEvents() {\n this.bindUserEvents();\n if (this.options.responsive) {\n this.bindResponsiveEvents();\n } else {\n this.attached = true;\n }\n }\n\n /**\n * @private\n */\n bindUserEvents() {\n const listeners = this._listeners;\n const platform = this.platform;\n\n const _add = (type, listener) => {\n platform.addEventListener(this, type, listener);\n listeners[type] = listener;\n };\n\n const listener = (e, x, y) => {\n e.offsetX = x;\n e.offsetY = y;\n this._eventHandler(e);\n };\n\n each(this.options.events, (type) => _add(type, listener));\n }\n\n /**\n * @private\n */\n bindResponsiveEvents() {\n if (!this._responsiveListeners) {\n this._responsiveListeners = {};\n }\n const listeners = this._responsiveListeners;\n const platform = this.platform;\n\n const _add = (type, listener) => {\n platform.addEventListener(this, type, listener);\n listeners[type] = listener;\n };\n const _remove = (type, listener) => {\n if (listeners[type]) {\n platform.removeEventListener(this, type, listener);\n delete listeners[type];\n }\n };\n\n const listener = (width, height) => {\n if (this.canvas) {\n this.resize(width, height);\n }\n };\n\n let detached; // eslint-disable-line prefer-const\n const attached = () => {\n _remove('attach', attached);\n\n this.attached = true;\n this.resize();\n\n _add('resize', listener);\n _add('detach', detached);\n };\n\n detached = () => {\n this.attached = false;\n\n _remove('resize', listener);\n\n // Stop animating and remove metasets, so when re-attached, the animations start from beginning.\n this._stop();\n this._resize(0, 0);\n\n _add('attach', attached);\n };\n\n if (platform.isAttached(this.canvas)) {\n attached();\n } else {\n detached();\n }\n }\n\n /**\n\t * @private\n\t */\n unbindEvents() {\n each(this._listeners, (listener, type) => {\n this.platform.removeEventListener(this, type, listener);\n });\n this._listeners = {};\n\n each(this._responsiveListeners, (listener, type) => {\n this.platform.removeEventListener(this, type, listener);\n });\n this._responsiveListeners = undefined;\n }\n\n updateHoverStyle(items, mode, enabled) {\n const prefix = enabled ? 'set' : 'remove';\n let meta, item, i, ilen;\n\n if (mode === 'dataset') {\n meta = this.getDatasetMeta(items[0].datasetIndex);\n meta.controller['_' + prefix + 'DatasetHoverStyle']();\n }\n\n for (i = 0, ilen = items.length; i < ilen; ++i) {\n item = items[i];\n const controller = item && this.getDatasetMeta(item.datasetIndex).controller;\n if (controller) {\n controller[prefix + 'HoverStyle'](item.element, item.datasetIndex, item.index);\n }\n }\n }\n\n /**\n\t * Get active (hovered) elements\n\t * @returns array\n\t */\n getActiveElements() {\n return this._active || [];\n }\n\n /**\n\t * Set active (hovered) elements\n\t * @param {array} activeElements New active data points\n\t */\n setActiveElements(activeElements) {\n const lastActive = this._active || [];\n const active = activeElements.map(({datasetIndex, index}) => {\n const meta = this.getDatasetMeta(datasetIndex);\n if (!meta) {\n throw new Error('No dataset found at index ' + datasetIndex);\n }\n\n return {\n datasetIndex,\n element: meta.data[index],\n index,\n };\n });\n const changed = !_elementsEqual(active, lastActive);\n\n if (changed) {\n this._active = active;\n // Make sure we don't use the previous mouse event to override the active elements in update.\n this._lastEvent = null;\n this._updateHoverStyles(active, lastActive);\n }\n }\n\n /**\n\t * Calls enabled plugins on the specified hook and with the given args.\n\t * This method immediately returns as soon as a plugin explicitly returns false. The\n\t * returned value can be used, for instance, to interrupt the current action.\n\t * @param {string} hook - The name of the plugin method to call (e.g. 'beforeUpdate').\n\t * @param {Object} [args] - Extra arguments to apply to the hook call.\n * @param {import('./core.plugins.js').filterCallback} [filter] - Filtering function for limiting which plugins are notified\n\t * @returns {boolean} false if any of the plugins return false, else returns true.\n\t */\n notifyPlugins(hook, args, filter) {\n return this._plugins.notify(this, hook, args, filter);\n }\n\n /**\n * Check if a plugin with the specific ID is registered and enabled\n * @param {string} pluginId - The ID of the plugin of which to check if it is enabled\n * @returns {boolean}\n */\n isPluginEnabled(pluginId) {\n return this._plugins._cache.filter(p => p.plugin.id === pluginId).length === 1;\n }\n\n /**\n\t * @private\n\t */\n _updateHoverStyles(active, lastActive, replay) {\n const hoverOptions = this.options.hover;\n const diff = (a, b) => a.filter(x => !b.some(y => x.datasetIndex === y.datasetIndex && x.index === y.index));\n const deactivated = diff(lastActive, active);\n const activated = replay ? active : diff(active, lastActive);\n\n if (deactivated.length) {\n this.updateHoverStyle(deactivated, hoverOptions.mode, false);\n }\n\n if (activated.length && hoverOptions.mode) {\n this.updateHoverStyle(activated, hoverOptions.mode, true);\n }\n }\n\n /**\n\t * @private\n\t */\n _eventHandler(e, replay) {\n const args = {\n event: e,\n replay,\n cancelable: true,\n inChartArea: this.isPointInArea(e)\n };\n const eventFilter = (plugin) => (plugin.options.events || this.options.events).includes(e.native.type);\n\n if (this.notifyPlugins('beforeEvent', args, eventFilter) === false) {\n return;\n }\n\n const changed = this._handleEvent(e, replay, args.inChartArea);\n\n args.cancelable = false;\n this.notifyPlugins('afterEvent', args, eventFilter);\n\n if (changed || args.changed) {\n this.render();\n }\n\n return this;\n }\n\n /**\n\t * Handle an event\n\t * @param {ChartEvent} e the event to handle\n\t * @param {boolean} [replay] - true if the event was replayed by `update`\n * @param {boolean} [inChartArea] - true if the event is inside chartArea\n\t * @return {boolean} true if the chart needs to re-render\n\t * @private\n\t */\n _handleEvent(e, replay, inChartArea) {\n const {_active: lastActive = [], options} = this;\n\n // If the event is replayed from `update`, we should evaluate with the final positions.\n //\n // The `replay`:\n // It's the last event (excluding click) that has occurred before `update`.\n // So mouse has not moved. It's also over the chart, because there is a `replay`.\n //\n // The why:\n // If animations are active, the elements haven't moved yet compared to state before update.\n // But if they will, we are activating the elements that would be active, if this check\n // was done after the animations have completed. => \"final positions\".\n // If there is no animations, the \"final\" and \"current\" positions are equal.\n // This is done so we do not have to evaluate the active elements each animation frame\n // - it would be expensive.\n const useFinalPosition = replay;\n const active = this._getActiveElements(e, lastActive, inChartArea, useFinalPosition);\n const isClick = _isClickEvent(e);\n const lastEvent = determineLastEvent(e, this._lastEvent, inChartArea, isClick);\n\n if (inChartArea) {\n // Set _lastEvent to null while we are processing the event handlers.\n // This prevents recursion if the handler calls chart.update()\n this._lastEvent = null;\n\n // Invoke onHover hook\n callCallback(options.onHover, [e, active, this], this);\n\n if (isClick) {\n callCallback(options.onClick, [e, active, this], this);\n }\n }\n\n const changed = !_elementsEqual(active, lastActive);\n if (changed || replay) {\n this._active = active;\n this._updateHoverStyles(active, lastActive, replay);\n }\n\n this._lastEvent = lastEvent;\n\n return changed;\n }\n\n /**\n * @param {ChartEvent} e - The event\n * @param {import('../types/index.js').ActiveElement[]} lastActive - Previously active elements\n * @param {boolean} inChartArea - Is the event inside chartArea\n * @param {boolean} useFinalPosition - Should the evaluation be done with current or final (after animation) element positions\n * @returns {import('../types/index.js').ActiveElement[]} - The active elements\n * @pravate\n */\n _getActiveElements(e, lastActive, inChartArea, useFinalPosition) {\n if (e.type === 'mouseout') {\n return [];\n }\n\n if (!inChartArea) {\n // Let user control the active elements outside chartArea. Eg. using Legend.\n return lastActive;\n }\n\n const hoverOptions = this.options.hover;\n return this.getElementsAtEventForMode(e, hoverOptions.mode, hoverOptions, useFinalPosition);\n }\n}\n\n// @ts-ignore\nfunction invalidatePlugins() {\n return each(Chart.instances, (chart) => chart._plugins.invalidate());\n}\n\nexport default Chart;\n","import Element from '../core/core.element.js';\nimport {_angleBetween, getAngleFromPoint, TAU, HALF_PI, valueOrDefault} from '../helpers/index.js';\nimport {PI, _angleDiff, _normalizeAngle, _isBetween, _limitValue} from '../helpers/helpers.math.js';\nimport {_readValueToProps} from '../helpers/helpers.options.js';\nimport type {ArcOptions, Point} from '../types/index.js';\n\nfunction clipSelf(ctx: CanvasRenderingContext2D, element: ArcElement, endAngle: number) {\n const {startAngle, x, y, outerRadius, innerRadius, options} = element;\n const {borderWidth, borderJoinStyle} = options;\n const outerAngleClip = Math.min(borderWidth / outerRadius, _normalizeAngle(startAngle - endAngle));\n ctx.beginPath();\n ctx.arc(x, y, outerRadius - borderWidth / 2, startAngle + outerAngleClip / 2, endAngle - outerAngleClip / 2);\n\n if (innerRadius > 0) {\n const innerAngleClip = Math.min(borderWidth / innerRadius, _normalizeAngle(startAngle - endAngle));\n ctx.arc(x, y, innerRadius + borderWidth / 2, endAngle - innerAngleClip / 2, startAngle + innerAngleClip / 2, true);\n } else {\n const clipWidth = Math.min(borderWidth / 2, outerRadius * _normalizeAngle(startAngle - endAngle));\n\n if (borderJoinStyle === 'round') {\n ctx.arc(x, y, clipWidth, endAngle - PI / 2, startAngle + PI / 2, true);\n } else if (borderJoinStyle === 'bevel') {\n const r = 2 * clipWidth * clipWidth;\n const endX = -r * Math.cos(endAngle + PI / 2) + x;\n const endY = -r * Math.sin(endAngle + PI / 2) + y;\n const startX = r * Math.cos(startAngle + PI / 2) + x;\n const startY = r * Math.sin(startAngle + PI / 2) + y;\n ctx.lineTo(endX, endY);\n ctx.lineTo(startX, startY);\n }\n }\n ctx.closePath();\n\n ctx.moveTo(0, 0);\n ctx.rect(0, 0, ctx.canvas.width, ctx.canvas.height);\n\n ctx.clip('evenodd');\n}\n\n\nfunction clipArc(ctx: CanvasRenderingContext2D, element: ArcElement, endAngle: number) {\n const {startAngle, pixelMargin, x, y, outerRadius, innerRadius} = element;\n let angleMargin = pixelMargin / outerRadius;\n\n // Draw an inner border by clipping the arc and drawing a double-width border\n // Enlarge the clipping arc by 0.33 pixels to eliminate glitches between borders\n ctx.beginPath();\n ctx.arc(x, y, outerRadius, startAngle - angleMargin, endAngle + angleMargin);\n if (innerRadius > pixelMargin) {\n angleMargin = pixelMargin / innerRadius;\n ctx.arc(x, y, innerRadius, endAngle + angleMargin, startAngle - angleMargin, true);\n } else {\n ctx.arc(x, y, pixelMargin, endAngle + HALF_PI, startAngle - HALF_PI);\n }\n ctx.closePath();\n ctx.clip();\n}\n\nfunction toRadiusCorners(value) {\n return _readValueToProps(value, ['outerStart', 'outerEnd', 'innerStart', 'innerEnd']);\n}\n\n/**\n * Parse border radius from the provided options\n */\nfunction parseBorderRadius(arc: ArcElement, innerRadius: number, outerRadius: number, angleDelta: number) {\n const o = toRadiusCorners(arc.options.borderRadius);\n const halfThickness = (outerRadius - innerRadius) / 2;\n const innerLimit = Math.min(halfThickness, angleDelta * innerRadius / 2);\n\n // Outer limits are complicated. We want to compute the available angular distance at\n // a radius of outerRadius - borderRadius because for small angular distances, this term limits.\n // We compute at r = outerRadius - borderRadius because this circle defines the center of the border corners.\n //\n // If the borderRadius is large, that value can become negative.\n // This causes the outer borders to lose their radius entirely, which is rather unexpected. To solve that, if borderRadius > outerRadius\n // we know that the thickness term will dominate and compute the limits at that point\n const computeOuterLimit = (val) => {\n const outerArcLimit = (outerRadius - Math.min(halfThickness, val)) * angleDelta / 2;\n return _limitValue(val, 0, Math.min(halfThickness, outerArcLimit));\n };\n\n return {\n outerStart: computeOuterLimit(o.outerStart),\n outerEnd: computeOuterLimit(o.outerEnd),\n innerStart: _limitValue(o.innerStart, 0, innerLimit),\n innerEnd: _limitValue(o.innerEnd, 0, innerLimit),\n };\n}\n\n/**\n * Convert (r, 𝜃) to (x, y)\n */\nfunction rThetaToXY(r: number, theta: number, x: number, y: number) {\n return {\n x: x + r * Math.cos(theta),\n y: y + r * Math.sin(theta),\n };\n}\n\n\n/**\n * Path the arc, respecting border radius by separating into left and right halves.\n *\n * Start End\n *\n * 1--->a--->2 Outer\n * / \\\n * 8 3\n * | |\n * | |\n * 7 4\n * \\ /\n * 6<---b<---5 Inner\n */\nfunction pathArc(\n ctx: CanvasRenderingContext2D,\n element: ArcElement,\n offset: number,\n spacing: number,\n end: number,\n circular: boolean,\n) {\n const {x, y, startAngle: start, pixelMargin, innerRadius: innerR} = element;\n\n const outerRadius = Math.max(element.outerRadius + spacing + offset - pixelMargin, 0);\n const innerRadius = innerR > 0 ? innerR + spacing + offset + pixelMargin : 0;\n\n let spacingOffset = 0;\n const alpha = end - start;\n\n if (spacing) {\n // When spacing is present, it is the same for all items\n // So we adjust the start and end angle of the arc such that\n // the distance is the same as it would be without the spacing\n const noSpacingInnerRadius = innerR > 0 ? innerR - spacing : 0;\n const noSpacingOuterRadius = outerRadius > 0 ? outerRadius - spacing : 0;\n const avNogSpacingRadius = (noSpacingInnerRadius + noSpacingOuterRadius) / 2;\n const adjustedAngle = avNogSpacingRadius !== 0 ? (alpha * avNogSpacingRadius) / (avNogSpacingRadius + spacing) : alpha;\n spacingOffset = (alpha - adjustedAngle) / 2;\n }\n\n const beta = Math.max(0.001, alpha * outerRadius - offset / PI) / outerRadius;\n const angleOffset = (alpha - beta) / 2;\n const startAngle = start + angleOffset + spacingOffset;\n const endAngle = end - angleOffset - spacingOffset;\n const {outerStart, outerEnd, innerStart, innerEnd} = parseBorderRadius(element, innerRadius, outerRadius, endAngle - startAngle);\n\n const outerStartAdjustedRadius = outerRadius - outerStart;\n const outerEndAdjustedRadius = outerRadius - outerEnd;\n const outerStartAdjustedAngle = startAngle + outerStart / outerStartAdjustedRadius;\n const outerEndAdjustedAngle = endAngle - outerEnd / outerEndAdjustedRadius;\n\n const innerStartAdjustedRadius = innerRadius + innerStart;\n const innerEndAdjustedRadius = innerRadius + innerEnd;\n const innerStartAdjustedAngle = startAngle + innerStart / innerStartAdjustedRadius;\n const innerEndAdjustedAngle = endAngle - innerEnd / innerEndAdjustedRadius;\n\n ctx.beginPath();\n\n if (circular) {\n // The first arc segments from point 1 to point a to point 2\n const outerMidAdjustedAngle = (outerStartAdjustedAngle + outerEndAdjustedAngle) / 2;\n ctx.arc(x, y, outerRadius, outerStartAdjustedAngle, outerMidAdjustedAngle);\n ctx.arc(x, y, outerRadius, outerMidAdjustedAngle, outerEndAdjustedAngle);\n\n // The corner segment from point 2 to point 3\n if (outerEnd > 0) {\n const pCenter = rThetaToXY(outerEndAdjustedRadius, outerEndAdjustedAngle, x, y);\n ctx.arc(pCenter.x, pCenter.y, outerEnd, outerEndAdjustedAngle, endAngle + HALF_PI);\n }\n\n // The line from point 3 to point 4\n const p4 = rThetaToXY(innerEndAdjustedRadius, endAngle, x, y);\n ctx.lineTo(p4.x, p4.y);\n\n // The corner segment from point 4 to point 5\n if (innerEnd > 0) {\n const pCenter = rThetaToXY(innerEndAdjustedRadius, innerEndAdjustedAngle, x, y);\n ctx.arc(pCenter.x, pCenter.y, innerEnd, endAngle + HALF_PI, innerEndAdjustedAngle + Math.PI);\n }\n\n // The inner arc from point 5 to point b to point 6\n const innerMidAdjustedAngle = ((endAngle - (innerEnd / innerRadius)) + (startAngle + (innerStart / innerRadius))) / 2;\n ctx.arc(x, y, innerRadius, endAngle - (innerEnd / innerRadius), innerMidAdjustedAngle, true);\n ctx.arc(x, y, innerRadius, innerMidAdjustedAngle, startAngle + (innerStart / innerRadius), true);\n\n // The corner segment from point 6 to point 7\n if (innerStart > 0) {\n const pCenter = rThetaToXY(innerStartAdjustedRadius, innerStartAdjustedAngle, x, y);\n ctx.arc(pCenter.x, pCenter.y, innerStart, innerStartAdjustedAngle + Math.PI, startAngle - HALF_PI);\n }\n\n // The line from point 7 to point 8\n const p8 = rThetaToXY(outerStartAdjustedRadius, startAngle, x, y);\n ctx.lineTo(p8.x, p8.y);\n\n // The corner segment from point 8 to point 1\n if (outerStart > 0) {\n const pCenter = rThetaToXY(outerStartAdjustedRadius, outerStartAdjustedAngle, x, y);\n ctx.arc(pCenter.x, pCenter.y, outerStart, startAngle - HALF_PI, outerStartAdjustedAngle);\n }\n } else {\n ctx.moveTo(x, y);\n\n const outerStartX = Math.cos(outerStartAdjustedAngle) * outerRadius + x;\n const outerStartY = Math.sin(outerStartAdjustedAngle) * outerRadius + y;\n ctx.lineTo(outerStartX, outerStartY);\n\n const outerEndX = Math.cos(outerEndAdjustedAngle) * outerRadius + x;\n const outerEndY = Math.sin(outerEndAdjustedAngle) * outerRadius + y;\n ctx.lineTo(outerEndX, outerEndY);\n }\n\n ctx.closePath();\n}\n\nfunction drawArc(\n ctx: CanvasRenderingContext2D,\n element: ArcElement,\n offset: number,\n spacing: number,\n circular: boolean,\n) {\n const {fullCircles, startAngle, circumference} = element;\n let endAngle = element.endAngle;\n if (fullCircles) {\n pathArc(ctx, element, offset, spacing, endAngle, circular);\n for (let i = 0; i < fullCircles; ++i) {\n ctx.fill();\n }\n if (!isNaN(circumference)) {\n endAngle = startAngle + (circumference % TAU || TAU);\n }\n }\n pathArc(ctx, element, offset, spacing, endAngle, circular);\n ctx.fill();\n return endAngle;\n}\n\nfunction drawBorder(\n ctx: CanvasRenderingContext2D,\n element: ArcElement,\n offset: number,\n spacing: number,\n circular: boolean,\n) {\n const {fullCircles, startAngle, circumference, options} = element;\n const {borderWidth, borderJoinStyle, borderDash, borderDashOffset, borderRadius} = options;\n const inner = options.borderAlign === 'inner';\n\n if (!borderWidth) {\n return;\n }\n\n ctx.setLineDash(borderDash || []);\n ctx.lineDashOffset = borderDashOffset;\n\n if (inner) {\n ctx.lineWidth = borderWidth * 2;\n ctx.lineJoin = borderJoinStyle || 'round';\n } else {\n ctx.lineWidth = borderWidth;\n ctx.lineJoin = borderJoinStyle || 'bevel';\n }\n\n let endAngle = element.endAngle;\n if (fullCircles) {\n pathArc(ctx, element, offset, spacing, endAngle, circular);\n for (let i = 0; i < fullCircles; ++i) {\n ctx.stroke();\n }\n if (!isNaN(circumference)) {\n endAngle = startAngle + (circumference % TAU || TAU);\n }\n }\n\n if (inner) {\n clipArc(ctx, element, endAngle);\n }\n\n if (options.selfJoin && endAngle - startAngle >= PI && borderRadius === 0 && borderJoinStyle !== 'miter') {\n clipSelf(ctx, element, endAngle);\n }\n\n if (!fullCircles) {\n pathArc(ctx, element, offset, spacing, endAngle, circular);\n ctx.stroke();\n }\n}\n\nexport interface ArcProps extends Point {\n startAngle: number;\n endAngle: number;\n innerRadius: number;\n outerRadius: number;\n circumference: number;\n}\n\nexport default class ArcElement extends Element {\n\n static id = 'arc';\n\n static defaults = {\n borderAlign: 'center',\n borderColor: '#fff',\n borderDash: [],\n borderDashOffset: 0,\n borderJoinStyle: undefined,\n borderRadius: 0,\n borderWidth: 2,\n offset: 0,\n spacing: 0,\n angle: undefined,\n circular: true,\n selfJoin: false,\n };\n\n static defaultRoutes = {\n backgroundColor: 'backgroundColor'\n };\n\n static descriptors = {\n _scriptable: true,\n _indexable: (name) => name !== 'borderDash'\n };\n\n circumference: number;\n endAngle: number;\n fullCircles: number;\n innerRadius: number;\n outerRadius: number;\n pixelMargin: number;\n startAngle: number;\n\n constructor(cfg) {\n super();\n\n this.options = undefined;\n this.circumference = undefined;\n this.startAngle = undefined;\n this.endAngle = undefined;\n this.innerRadius = undefined;\n this.outerRadius = undefined;\n this.pixelMargin = 0;\n this.fullCircles = 0;\n\n if (cfg) {\n Object.assign(this, cfg);\n }\n }\n\n inRange(chartX: number, chartY: number, useFinalPosition: boolean) {\n const point = this.getProps(['x', 'y'], useFinalPosition);\n const {angle, distance} = getAngleFromPoint(point, {x: chartX, y: chartY});\n const {startAngle, endAngle, innerRadius, outerRadius, circumference} = this.getProps([\n 'startAngle',\n 'endAngle',\n 'innerRadius',\n 'outerRadius',\n 'circumference'\n ], useFinalPosition);\n const rAdjust = (this.options.spacing + this.options.borderWidth) / 2;\n const _circumference = valueOrDefault(circumference, endAngle - startAngle);\n const nonZeroBetween = _angleBetween(angle, startAngle, endAngle) && startAngle !== endAngle;\n const betweenAngles = _circumference >= TAU || nonZeroBetween;\n const withinRadius = _isBetween(distance, innerRadius + rAdjust, outerRadius + rAdjust);\n\n return (betweenAngles && withinRadius);\n }\n\n getCenterPoint(useFinalPosition: boolean) {\n const {x, y, startAngle, endAngle, innerRadius, outerRadius} = this.getProps([\n 'x',\n 'y',\n 'startAngle',\n 'endAngle',\n 'innerRadius',\n 'outerRadius'\n ], useFinalPosition);\n const {offset, spacing} = this.options;\n const halfAngle = (startAngle + endAngle) / 2;\n const halfRadius = (innerRadius + outerRadius + spacing + offset) / 2;\n return {\n x: x + Math.cos(halfAngle) * halfRadius,\n y: y + Math.sin(halfAngle) * halfRadius\n };\n }\n\n tooltipPosition(useFinalPosition: boolean) {\n return this.getCenterPoint(useFinalPosition);\n }\n\n draw(ctx: CanvasRenderingContext2D) {\n const {options, circumference} = this;\n const offset = (options.offset || 0) / 4;\n const spacing = (options.spacing || 0) / 2;\n const circular = options.circular;\n this.pixelMargin = (options.borderAlign === 'inner') ? 0.33 : 0;\n this.fullCircles = circumference > TAU ? Math.floor(circumference / TAU) : 0;\n\n if (circumference === 0 || this.innerRadius < 0 || this.outerRadius < 0) {\n return;\n }\n\n ctx.save();\n\n const halfAngle = (this.startAngle + this.endAngle) / 2;\n ctx.translate(Math.cos(halfAngle) * offset, Math.sin(halfAngle) * offset);\n const fix = 1 - Math.sin(Math.min(PI, circumference || 0));\n const radiusOffset = offset * fix;\n\n ctx.fillStyle = options.backgroundColor;\n ctx.strokeStyle = options.borderColor;\n\n drawArc(ctx, this, radiusOffset, spacing, circular);\n drawBorder(ctx, this, radiusOffset, spacing, circular);\n\n ctx.restore();\n }\n}\n","import Element from '../core/core.element.js';\nimport {_bezierInterpolation, _pointInLine, _steppedInterpolation} from '../helpers/helpers.interpolation.js';\nimport {_computeSegments, _boundSegments} from '../helpers/helpers.segment.js';\nimport {_steppedLineTo, _bezierCurveTo} from '../helpers/helpers.canvas.js';\nimport {_updateBezierControlPoints} from '../helpers/helpers.curve.js';\nimport {valueOrDefault} from '../helpers/index.js';\n\n/**\n * @typedef { import('./element.point.js').default } PointElement\n */\n\nfunction setStyle(ctx, options, style = options) {\n ctx.lineCap = valueOrDefault(style.borderCapStyle, options.borderCapStyle);\n ctx.setLineDash(valueOrDefault(style.borderDash, options.borderDash));\n ctx.lineDashOffset = valueOrDefault(style.borderDashOffset, options.borderDashOffset);\n ctx.lineJoin = valueOrDefault(style.borderJoinStyle, options.borderJoinStyle);\n ctx.lineWidth = valueOrDefault(style.borderWidth, options.borderWidth);\n ctx.strokeStyle = valueOrDefault(style.borderColor, options.borderColor);\n}\n\nfunction lineTo(ctx, previous, target) {\n ctx.lineTo(target.x, target.y);\n}\n\n/**\n * @returns {any}\n */\nfunction getLineMethod(options) {\n if (options.stepped) {\n return _steppedLineTo;\n }\n\n if (options.tension || options.cubicInterpolationMode === 'monotone') {\n return _bezierCurveTo;\n }\n\n return lineTo;\n}\n\nfunction pathVars(points, segment, params = {}) {\n const count = points.length;\n const {start: paramsStart = 0, end: paramsEnd = count - 1} = params;\n const {start: segmentStart, end: segmentEnd} = segment;\n const start = Math.max(paramsStart, segmentStart);\n const end = Math.min(paramsEnd, segmentEnd);\n const outside = paramsStart < segmentStart && paramsEnd < segmentStart || paramsStart > segmentEnd && paramsEnd > segmentEnd;\n\n return {\n count,\n start,\n loop: segment.loop,\n ilen: end < start && !outside ? count + end - start : end - start\n };\n}\n\n/**\n * Create path from points, grouping by truncated x-coordinate\n * Points need to be in order by x-coordinate for this to work efficiently\n * @param {CanvasRenderingContext2D|Path2D} ctx - Context\n * @param {LineElement} line\n * @param {object} segment\n * @param {number} segment.start - start index of the segment, referring the points array\n * @param {number} segment.end - end index of the segment, referring the points array\n * @param {boolean} segment.loop - indicates that the segment is a loop\n * @param {object} params\n * @param {boolean} params.move - move to starting point (vs line to it)\n * @param {boolean} params.reverse - path the segment from end to start\n * @param {number} params.start - limit segment to points starting from `start` index\n * @param {number} params.end - limit segment to points ending at `start` + `count` index\n */\nfunction pathSegment(ctx, line, segment, params) {\n const {points, options} = line;\n const {count, start, loop, ilen} = pathVars(points, segment, params);\n const lineMethod = getLineMethod(options);\n // eslint-disable-next-line prefer-const\n let {move = true, reverse} = params || {};\n let i, point, prev;\n\n for (i = 0; i <= ilen; ++i) {\n point = points[(start + (reverse ? ilen - i : i)) % count];\n\n if (point.skip) {\n // If there is a skipped point inside a segment, spanGaps must be true\n continue;\n } else if (move) {\n ctx.moveTo(point.x, point.y);\n move = false;\n } else {\n lineMethod(ctx, prev, point, reverse, options.stepped);\n }\n\n prev = point;\n }\n\n if (loop) {\n point = points[(start + (reverse ? ilen : 0)) % count];\n lineMethod(ctx, prev, point, reverse, options.stepped);\n }\n\n return !!loop;\n}\n\n/**\n * Create path from points, grouping by truncated x-coordinate\n * Points need to be in order by x-coordinate for this to work efficiently\n * @param {CanvasRenderingContext2D|Path2D} ctx - Context\n * @param {LineElement} line\n * @param {object} segment\n * @param {number} segment.start - start index of the segment, referring the points array\n * @param {number} segment.end - end index of the segment, referring the points array\n * @param {boolean} segment.loop - indicates that the segment is a loop\n * @param {object} params\n * @param {boolean} params.move - move to starting point (vs line to it)\n * @param {boolean} params.reverse - path the segment from end to start\n * @param {number} params.start - limit segment to points starting from `start` index\n * @param {number} params.end - limit segment to points ending at `start` + `count` index\n */\nfunction fastPathSegment(ctx, line, segment, params) {\n const points = line.points;\n const {count, start, ilen} = pathVars(points, segment, params);\n const {move = true, reverse} = params || {};\n let avgX = 0;\n let countX = 0;\n let i, point, prevX, minY, maxY, lastY;\n\n const pointIndex = (index) => (start + (reverse ? ilen - index : index)) % count;\n const drawX = () => {\n if (minY !== maxY) {\n // Draw line to maxY and minY, using the average x-coordinate\n ctx.lineTo(avgX, maxY);\n ctx.lineTo(avgX, minY);\n // Line to y-value of last point in group. So the line continues\n // from correct position. Not using move, to have solid path.\n ctx.lineTo(avgX, lastY);\n }\n };\n\n if (move) {\n point = points[pointIndex(0)];\n ctx.moveTo(point.x, point.y);\n }\n\n for (i = 0; i <= ilen; ++i) {\n point = points[pointIndex(i)];\n\n if (point.skip) {\n // If there is a skipped point inside a segment, spanGaps must be true\n continue;\n }\n\n const x = point.x;\n const y = point.y;\n const truncX = x | 0; // truncated x-coordinate\n\n if (truncX === prevX) {\n // Determine `minY` / `maxY` and `avgX` while we stay within same x-position\n if (y < minY) {\n minY = y;\n } else if (y > maxY) {\n maxY = y;\n }\n // For first point in group, countX is `0`, so average will be `x` / 1.\n avgX = (countX * avgX + x) / ++countX;\n } else {\n drawX();\n // Draw line to next x-position, using the first (or only)\n // y-value in that group\n ctx.lineTo(x, y);\n\n prevX = truncX;\n countX = 0;\n minY = maxY = y;\n }\n // Keep track of the last y-value in group\n lastY = y;\n }\n drawX();\n}\n\n/**\n * @param {LineElement} line - the line\n * @returns {function}\n * @private\n */\nfunction _getSegmentMethod(line) {\n const opts = line.options;\n const borderDash = opts.borderDash && opts.borderDash.length;\n const useFastPath = !line._decimated && !line._loop && !opts.tension && opts.cubicInterpolationMode !== 'monotone' && !opts.stepped && !borderDash;\n return useFastPath ? fastPathSegment : pathSegment;\n}\n\n/**\n * @private\n */\nfunction _getInterpolationMethod(options) {\n if (options.stepped) {\n return _steppedInterpolation;\n }\n\n if (options.tension || options.cubicInterpolationMode === 'monotone') {\n return _bezierInterpolation;\n }\n\n return _pointInLine;\n}\n\nfunction strokePathWithCache(ctx, line, start, count) {\n let path = line._path;\n if (!path) {\n path = line._path = new Path2D();\n if (line.path(path, start, count)) {\n path.closePath();\n }\n }\n setStyle(ctx, line.options);\n ctx.stroke(path);\n}\n\nfunction strokePathDirect(ctx, line, start, count) {\n const {segments, options} = line;\n const segmentMethod = _getSegmentMethod(line);\n\n for (const segment of segments) {\n setStyle(ctx, options, segment.style);\n ctx.beginPath();\n if (segmentMethod(ctx, line, segment, {start, end: start + count - 1})) {\n ctx.closePath();\n }\n ctx.stroke();\n }\n}\n\nconst usePath2D = typeof Path2D === 'function';\n\nfunction draw(ctx, line, start, count) {\n if (usePath2D && !line.options.segment) {\n strokePathWithCache(ctx, line, start, count);\n } else {\n strokePathDirect(ctx, line, start, count);\n }\n}\n\nexport default class LineElement extends Element {\n\n static id = 'line';\n\n /**\n * @type {any}\n */\n static defaults = {\n borderCapStyle: 'butt',\n borderDash: [],\n borderDashOffset: 0,\n borderJoinStyle: 'miter',\n borderWidth: 3,\n capBezierPoints: true,\n cubicInterpolationMode: 'default',\n fill: false,\n spanGaps: false,\n stepped: false,\n tension: 0,\n };\n\n /**\n * @type {any}\n */\n static defaultRoutes = {\n backgroundColor: 'backgroundColor',\n borderColor: 'borderColor'\n };\n\n\n static descriptors = {\n _scriptable: true,\n _indexable: (name) => name !== 'borderDash' && name !== 'fill',\n };\n\n\n constructor(cfg) {\n super();\n\n this.animated = true;\n this.options = undefined;\n this._chart = undefined;\n this._loop = undefined;\n this._fullLoop = undefined;\n this._path = undefined;\n this._points = undefined;\n this._segments = undefined;\n this._decimated = false;\n this._pointsUpdated = false;\n this._datasetIndex = undefined;\n\n if (cfg) {\n Object.assign(this, cfg);\n }\n }\n\n updateControlPoints(chartArea, indexAxis) {\n const options = this.options;\n if ((options.tension || options.cubicInterpolationMode === 'monotone') && !options.stepped && !this._pointsUpdated) {\n const loop = options.spanGaps ? this._loop : this._fullLoop;\n _updateBezierControlPoints(this._points, options, chartArea, loop, indexAxis);\n this._pointsUpdated = true;\n }\n }\n\n set points(points) {\n this._points = points;\n delete this._segments;\n delete this._path;\n this._pointsUpdated = false;\n }\n\n get points() {\n return this._points;\n }\n\n get segments() {\n return this._segments || (this._segments = _computeSegments(this, this.options.segment));\n }\n\n /**\n\t * First non-skipped point on this line\n\t * @returns {PointElement|undefined}\n\t */\n first() {\n const segments = this.segments;\n const points = this.points;\n return segments.length && points[segments[0].start];\n }\n\n /**\n\t * Last non-skipped point on this line\n\t * @returns {PointElement|undefined}\n\t */\n last() {\n const segments = this.segments;\n const points = this.points;\n const count = segments.length;\n return count && points[segments[count - 1].end];\n }\n\n /**\n\t * Interpolate a point in this line at the same value on `property` as\n\t * the reference `point` provided\n\t * @param {PointElement} point - the reference point\n\t * @param {string} property - the property to match on\n\t * @returns {PointElement|undefined}\n\t */\n interpolate(point, property) {\n const options = this.options;\n const value = point[property];\n const points = this.points;\n const segments = _boundSegments(this, {property, start: value, end: value});\n\n if (!segments.length) {\n return;\n }\n\n const result = [];\n const _interpolate = _getInterpolationMethod(options);\n let i, ilen;\n for (i = 0, ilen = segments.length; i < ilen; ++i) {\n const {start, end} = segments[i];\n const p1 = points[start];\n const p2 = points[end];\n if (p1 === p2) {\n result.push(p1);\n continue;\n }\n const t = Math.abs((value - p1[property]) / (p2[property] - p1[property]));\n const interpolated = _interpolate(p1, p2, t, options.stepped);\n interpolated[property] = point[property];\n result.push(interpolated);\n }\n return result.length === 1 ? result[0] : result;\n }\n\n /**\n\t * Append a segment of this line to current path.\n\t * @param {CanvasRenderingContext2D} ctx\n\t * @param {object} segment\n\t * @param {number} segment.start - start index of the segment, referring the points array\n \t * @param {number} segment.end - end index of the segment, referring the points array\n \t * @param {boolean} segment.loop - indicates that the segment is a loop\n\t * @param {object} params\n\t * @param {boolean} params.move - move to starting point (vs line to it)\n\t * @param {boolean} params.reverse - path the segment from end to start\n\t * @param {number} params.start - limit segment to points starting from `start` index\n\t * @param {number} params.end - limit segment to points ending at `start` + `count` index\n\t * @returns {undefined|boolean} - true if the segment is a full loop (path should be closed)\n\t */\n pathSegment(ctx, segment, params) {\n const segmentMethod = _getSegmentMethod(this);\n return segmentMethod(ctx, this, segment, params);\n }\n\n /**\n\t * Append all segments of this line to current path.\n\t * @param {CanvasRenderingContext2D|Path2D} ctx\n\t * @param {number} [start]\n\t * @param {number} [count]\n\t * @returns {undefined|boolean} - true if line is a full loop (path should be closed)\n\t */\n path(ctx, start, count) {\n const segments = this.segments;\n const segmentMethod = _getSegmentMethod(this);\n let loop = this._loop;\n\n start = start || 0;\n count = count || (this.points.length - start);\n\n for (const segment of segments) {\n loop &= segmentMethod(ctx, this, segment, {start, end: start + count - 1});\n }\n return !!loop;\n }\n\n /**\n\t * Draw\n\t * @param {CanvasRenderingContext2D} ctx\n\t * @param {object} chartArea\n\t * @param {number} [start]\n\t * @param {number} [count]\n\t */\n draw(ctx, chartArea, start, count) {\n const options = this.options || {};\n const points = this.points || [];\n\n if (points.length && options.borderWidth) {\n ctx.save();\n\n draw(ctx, this, start, count);\n\n ctx.restore();\n }\n\n if (this.animated) {\n // When line is animated, the control points and path are not cached.\n this._pointsUpdated = false;\n this._path = undefined;\n }\n }\n}\n","import Element from '../core/core.element.js';\nimport {drawPoint, _isPointInArea} from '../helpers/helpers.canvas.js';\nimport type {\n CartesianParsedData,\n ChartArea,\n Point,\n PointHoverOptions,\n PointOptions,\n} from '../types/index.js';\n\nfunction inRange(el: PointElement, pos: number, axis: 'x' | 'y', useFinalPosition?: boolean) {\n const options = el.options;\n const {[axis]: value} = el.getProps([axis], useFinalPosition);\n\n return (Math.abs(pos - value) < options.radius + options.hitRadius);\n}\n\nexport type PointProps = Point\n\nexport default class PointElement extends Element {\n\n static id = 'point';\n\n parsed: CartesianParsedData;\n skip?: boolean;\n stop?: boolean;\n\n /**\n * @type {any}\n */\n static defaults = {\n borderWidth: 1,\n hitRadius: 1,\n hoverBorderWidth: 1,\n hoverRadius: 4,\n pointStyle: 'circle',\n radius: 3,\n rotation: 0\n };\n\n /**\n * @type {any}\n */\n static defaultRoutes = {\n backgroundColor: 'backgroundColor',\n borderColor: 'borderColor'\n };\n\n constructor(cfg) {\n super();\n\n this.options = undefined;\n this.parsed = undefined;\n this.skip = undefined;\n this.stop = undefined;\n\n if (cfg) {\n Object.assign(this, cfg);\n }\n }\n\n inRange(mouseX: number, mouseY: number, useFinalPosition?: boolean) {\n const options = this.options;\n const {x, y} = this.getProps(['x', 'y'], useFinalPosition);\n return ((Math.pow(mouseX - x, 2) + Math.pow(mouseY - y, 2)) < Math.pow(options.hitRadius + options.radius, 2));\n }\n\n inXRange(mouseX: number, useFinalPosition?: boolean) {\n return inRange(this, mouseX, 'x', useFinalPosition);\n }\n\n inYRange(mouseY: number, useFinalPosition?: boolean) {\n return inRange(this, mouseY, 'y', useFinalPosition);\n }\n\n getCenterPoint(useFinalPosition?: boolean) {\n const {x, y} = this.getProps(['x', 'y'], useFinalPosition);\n return {x, y};\n }\n\n size(options?: Partial) {\n options = options || this.options || {};\n let radius = options.radius || 0;\n radius = Math.max(radius, radius && options.hoverRadius || 0);\n const borderWidth = radius && options.borderWidth || 0;\n return (radius + borderWidth) * 2;\n }\n\n draw(ctx: CanvasRenderingContext2D, area: ChartArea) {\n const options = this.options;\n\n if (this.skip || options.radius < 0.1 || !_isPointInArea(this, area, this.size(options) / 2)) {\n return;\n }\n\n ctx.strokeStyle = options.borderColor;\n ctx.lineWidth = options.borderWidth;\n ctx.fillStyle = options.backgroundColor;\n drawPoint(ctx, options, this.x, this.y);\n }\n\n getRange() {\n const options = this.options || {};\n // @ts-expect-error Fallbacks should never be hit in practice\n return options.radius + options.hitRadius;\n }\n}\n","import Element from '../core/core.element.js';\nimport {isObject, _isBetween, _limitValue} from '../helpers/index.js';\nimport {addRoundedRectPath} from '../helpers/helpers.canvas.js';\nimport {toTRBL, toTRBLCorners} from '../helpers/helpers.options.js';\n\n/** @typedef {{ x: number, y: number, base: number, horizontal: boolean, width: number, height: number }} BarProps */\n\n/**\n * Helper function to get the bounds of the bar regardless of the orientation\n * @param {BarElement} bar the bar\n * @param {boolean} [useFinalPosition]\n * @return {object} bounds of the bar\n * @private\n */\nfunction getBarBounds(bar, useFinalPosition) {\n const {x, y, base, width, height} = /** @type {BarProps} */ (bar.getProps(['x', 'y', 'base', 'width', 'height'], useFinalPosition));\n\n let left, right, top, bottom, half;\n\n if (bar.horizontal) {\n half = height / 2;\n left = Math.min(x, base);\n right = Math.max(x, base);\n top = y - half;\n bottom = y + half;\n } else {\n half = width / 2;\n left = x - half;\n right = x + half;\n top = Math.min(y, base);\n bottom = Math.max(y, base);\n }\n\n return {left, top, right, bottom};\n}\n\nfunction skipOrLimit(skip, value, min, max) {\n return skip ? 0 : _limitValue(value, min, max);\n}\n\nfunction parseBorderWidth(bar, maxW, maxH) {\n const value = bar.options.borderWidth;\n const skip = bar.borderSkipped;\n const o = toTRBL(value);\n\n return {\n t: skipOrLimit(skip.top, o.top, 0, maxH),\n r: skipOrLimit(skip.right, o.right, 0, maxW),\n b: skipOrLimit(skip.bottom, o.bottom, 0, maxH),\n l: skipOrLimit(skip.left, o.left, 0, maxW)\n };\n}\n\nfunction parseBorderRadius(bar, maxW, maxH) {\n const {enableBorderRadius} = bar.getProps(['enableBorderRadius']);\n const value = bar.options.borderRadius;\n const o = toTRBLCorners(value);\n const maxR = Math.min(maxW, maxH);\n const skip = bar.borderSkipped;\n\n // If the value is an object, assume the user knows what they are doing\n // and apply as directed.\n const enableBorder = enableBorderRadius || isObject(value);\n\n return {\n topLeft: skipOrLimit(!enableBorder || skip.top || skip.left, o.topLeft, 0, maxR),\n topRight: skipOrLimit(!enableBorder || skip.top || skip.right, o.topRight, 0, maxR),\n bottomLeft: skipOrLimit(!enableBorder || skip.bottom || skip.left, o.bottomLeft, 0, maxR),\n bottomRight: skipOrLimit(!enableBorder || skip.bottom || skip.right, o.bottomRight, 0, maxR)\n };\n}\n\nfunction boundingRects(bar) {\n const bounds = getBarBounds(bar);\n const width = bounds.right - bounds.left;\n const height = bounds.bottom - bounds.top;\n const border = parseBorderWidth(bar, width / 2, height / 2);\n const radius = parseBorderRadius(bar, width / 2, height / 2);\n\n return {\n outer: {\n x: bounds.left,\n y: bounds.top,\n w: width,\n h: height,\n radius\n },\n inner: {\n x: bounds.left + border.l,\n y: bounds.top + border.t,\n w: width - border.l - border.r,\n h: height - border.t - border.b,\n radius: {\n topLeft: Math.max(0, radius.topLeft - Math.max(border.t, border.l)),\n topRight: Math.max(0, radius.topRight - Math.max(border.t, border.r)),\n bottomLeft: Math.max(0, radius.bottomLeft - Math.max(border.b, border.l)),\n bottomRight: Math.max(0, radius.bottomRight - Math.max(border.b, border.r)),\n }\n }\n };\n}\n\nfunction inRange(bar, x, y, useFinalPosition) {\n const skipX = x === null;\n const skipY = y === null;\n const skipBoth = skipX && skipY;\n const bounds = bar && !skipBoth && getBarBounds(bar, useFinalPosition);\n\n return bounds\n\t\t&& (skipX || _isBetween(x, bounds.left, bounds.right))\n\t\t&& (skipY || _isBetween(y, bounds.top, bounds.bottom));\n}\n\nfunction hasRadius(radius) {\n return radius.topLeft || radius.topRight || radius.bottomLeft || radius.bottomRight;\n}\n\n/**\n * Add a path of a rectangle to the current sub-path\n * @param {CanvasRenderingContext2D} ctx Context\n * @param {*} rect Bounding rect\n */\nfunction addNormalRectPath(ctx, rect) {\n ctx.rect(rect.x, rect.y, rect.w, rect.h);\n}\n\nfunction inflateRect(rect, amount, refRect = {}) {\n const x = rect.x !== refRect.x ? -amount : 0;\n const y = rect.y !== refRect.y ? -amount : 0;\n const w = (rect.x + rect.w !== refRect.x + refRect.w ? amount : 0) - x;\n const h = (rect.y + rect.h !== refRect.y + refRect.h ? amount : 0) - y;\n return {\n x: rect.x + x,\n y: rect.y + y,\n w: rect.w + w,\n h: rect.h + h,\n radius: rect.radius\n };\n}\n\nexport default class BarElement extends Element {\n\n static id = 'bar';\n\n /**\n * @type {any}\n */\n static defaults = {\n borderSkipped: 'start',\n borderWidth: 0,\n borderRadius: 0,\n inflateAmount: 'auto',\n pointStyle: undefined\n };\n\n /**\n * @type {any}\n */\n static defaultRoutes = {\n backgroundColor: 'backgroundColor',\n borderColor: 'borderColor'\n };\n\n constructor(cfg) {\n super();\n\n this.options = undefined;\n this.horizontal = undefined;\n this.base = undefined;\n this.width = undefined;\n this.height = undefined;\n this.inflateAmount = undefined;\n\n if (cfg) {\n Object.assign(this, cfg);\n }\n }\n\n draw(ctx) {\n const {inflateAmount, options: {borderColor, backgroundColor}} = this;\n const {inner, outer} = boundingRects(this);\n const addRectPath = hasRadius(outer.radius) ? addRoundedRectPath : addNormalRectPath;\n\n ctx.save();\n\n if (outer.w !== inner.w || outer.h !== inner.h) {\n ctx.beginPath();\n addRectPath(ctx, inflateRect(outer, inflateAmount, inner));\n ctx.clip();\n addRectPath(ctx, inflateRect(inner, -inflateAmount, outer));\n ctx.fillStyle = borderColor;\n ctx.fill('evenodd');\n }\n\n ctx.beginPath();\n addRectPath(ctx, inflateRect(inner, inflateAmount));\n ctx.fillStyle = backgroundColor;\n ctx.fill();\n\n ctx.restore();\n }\n\n inRange(mouseX, mouseY, useFinalPosition) {\n return inRange(this, mouseX, mouseY, useFinalPosition);\n }\n\n inXRange(mouseX, useFinalPosition) {\n return inRange(this, mouseX, null, useFinalPosition);\n }\n\n inYRange(mouseY, useFinalPosition) {\n return inRange(this, null, mouseY, useFinalPosition);\n }\n\n getCenterPoint(useFinalPosition) {\n const {x, y, base, horizontal} = /** @type {BarProps} */ (this.getProps(['x', 'y', 'base', 'horizontal'], useFinalPosition));\n return {\n x: horizontal ? (x + base) / 2 : x,\n y: horizontal ? y : (y + base) / 2\n };\n }\n\n getRange(axis) {\n return axis === 'x' ? this.width / 2 : this.height / 2;\n }\n}\n","import defaults from '../core/core.defaults.js';\nimport Element from '../core/core.element.js';\nimport layouts from '../core/core.layouts.js';\nimport {addRoundedRectPath, drawPointLegend, renderText} from '../helpers/helpers.canvas.js';\nimport {\n _isBetween,\n callback as call,\n clipArea,\n getRtlAdapter,\n overrideTextDirection,\n restoreTextDirection,\n toFont,\n toPadding,\n unclipArea,\n valueOrDefault,\n} from '../helpers/index.js';\nimport {_alignStartEnd, _textX, _toLeftRightCenter} from '../helpers/helpers.extras.js';\nimport {toTRBLCorners} from '../helpers/helpers.options.js';\n\n/**\n * @typedef { import('../types/index.js').ChartEvent } ChartEvent\n */\n\nconst getBoxSize = (labelOpts, fontSize) => {\n let {boxHeight = fontSize, boxWidth = fontSize} = labelOpts;\n\n if (labelOpts.usePointStyle) {\n boxHeight = Math.min(boxHeight, fontSize);\n boxWidth = labelOpts.pointStyleWidth || Math.min(boxWidth, fontSize);\n }\n\n return {\n boxWidth,\n boxHeight,\n itemHeight: Math.max(fontSize, boxHeight)\n };\n};\n\nconst itemsEqual = (a, b) => a !== null && b !== null && a.datasetIndex === b.datasetIndex && a.index === b.index;\n\nexport class Legend extends Element {\n\n /**\n\t * @param {{ ctx: any; options: any; chart: any; }} config\n\t */\n constructor(config) {\n super();\n\n this._added = false;\n\n // Contains hit boxes for each dataset (in dataset order)\n this.legendHitBoxes = [];\n\n /**\n \t\t * @private\n \t\t */\n this._hoveredItem = null;\n\n // Are we in doughnut mode which has a different data type\n this.doughnutMode = false;\n\n this.chart = config.chart;\n this.options = config.options;\n this.ctx = config.ctx;\n this.legendItems = undefined;\n this.columnSizes = undefined;\n this.lineWidths = undefined;\n this.maxHeight = undefined;\n this.maxWidth = undefined;\n this.top = undefined;\n this.bottom = undefined;\n this.left = undefined;\n this.right = undefined;\n this.height = undefined;\n this.width = undefined;\n this._margins = undefined;\n this.position = undefined;\n this.weight = undefined;\n this.fullSize = undefined;\n }\n\n update(maxWidth, maxHeight, margins) {\n this.maxWidth = maxWidth;\n this.maxHeight = maxHeight;\n this._margins = margins;\n\n this.setDimensions();\n this.buildLabels();\n this.fit();\n }\n\n setDimensions() {\n if (this.isHorizontal()) {\n this.width = this.maxWidth;\n this.left = this._margins.left;\n this.right = this.width;\n } else {\n this.height = this.maxHeight;\n this.top = this._margins.top;\n this.bottom = this.height;\n }\n }\n\n buildLabels() {\n const labelOpts = this.options.labels || {};\n let legendItems = call(labelOpts.generateLabels, [this.chart], this) || [];\n\n if (labelOpts.filter) {\n legendItems = legendItems.filter((item) => labelOpts.filter(item, this.chart.data));\n }\n\n if (labelOpts.sort) {\n legendItems = legendItems.sort((a, b) => labelOpts.sort(a, b, this.chart.data));\n }\n\n if (this.options.reverse) {\n legendItems.reverse();\n }\n\n this.legendItems = legendItems;\n }\n\n fit() {\n const {options, ctx} = this;\n\n // The legend may not be displayed for a variety of reasons including\n // the fact that the defaults got set to `false`.\n // When the legend is not displayed, there are no guarantees that the options\n // are correctly formatted so we need to bail out as early as possible.\n if (!options.display) {\n this.width = this.height = 0;\n return;\n }\n\n const labelOpts = options.labels;\n const labelFont = toFont(labelOpts.font);\n const fontSize = labelFont.size;\n const titleHeight = this._computeTitleHeight();\n const {boxWidth, itemHeight} = getBoxSize(labelOpts, fontSize);\n\n let width, height;\n\n ctx.font = labelFont.string;\n\n if (this.isHorizontal()) {\n width = this.maxWidth; // fill all the width\n height = this._fitRows(titleHeight, fontSize, boxWidth, itemHeight) + 10;\n } else {\n height = this.maxHeight; // fill all the height\n width = this._fitCols(titleHeight, labelFont, boxWidth, itemHeight) + 10;\n }\n\n this.width = Math.min(width, options.maxWidth || this.maxWidth);\n this.height = Math.min(height, options.maxHeight || this.maxHeight);\n }\n\n /**\n\t * @private\n\t */\n _fitRows(titleHeight, fontSize, boxWidth, itemHeight) {\n const {ctx, maxWidth, options: {labels: {padding}}} = this;\n const hitboxes = this.legendHitBoxes = [];\n // Width of each line of legend boxes. Labels wrap onto multiple lines when there are too many to fit on one\n const lineWidths = this.lineWidths = [0];\n const lineHeight = itemHeight + padding;\n let totalHeight = titleHeight;\n\n ctx.textAlign = 'left';\n ctx.textBaseline = 'middle';\n\n let row = -1;\n let top = -lineHeight;\n this.legendItems.forEach((legendItem, i) => {\n const itemWidth = boxWidth + (fontSize / 2) + ctx.measureText(legendItem.text).width;\n\n if (i === 0 || lineWidths[lineWidths.length - 1] + itemWidth + 2 * padding > maxWidth) {\n totalHeight += lineHeight;\n lineWidths[lineWidths.length - (i > 0 ? 0 : 1)] = 0;\n top += lineHeight;\n row++;\n }\n\n hitboxes[i] = {left: 0, top, row, width: itemWidth, height: itemHeight};\n\n lineWidths[lineWidths.length - 1] += itemWidth + padding;\n });\n\n return totalHeight;\n }\n\n _fitCols(titleHeight, labelFont, boxWidth, _itemHeight) {\n const {ctx, maxHeight, options: {labels: {padding}}} = this;\n const hitboxes = this.legendHitBoxes = [];\n const columnSizes = this.columnSizes = [];\n const heightLimit = maxHeight - titleHeight;\n\n let totalWidth = padding;\n let currentColWidth = 0;\n let currentColHeight = 0;\n\n let left = 0;\n let col = 0;\n\n this.legendItems.forEach((legendItem, i) => {\n const {itemWidth, itemHeight} = calculateItemSize(boxWidth, labelFont, ctx, legendItem, _itemHeight);\n\n // If too tall, go to new column\n if (i > 0 && currentColHeight + itemHeight + 2 * padding > heightLimit) {\n totalWidth += currentColWidth + padding;\n columnSizes.push({width: currentColWidth, height: currentColHeight}); // previous column size\n left += currentColWidth + padding;\n col++;\n currentColWidth = currentColHeight = 0;\n }\n\n // Store the hitbox width and height here. Final position will be updated in `draw`\n hitboxes[i] = {left, top: currentColHeight, col, width: itemWidth, height: itemHeight};\n\n // Get max width\n currentColWidth = Math.max(currentColWidth, itemWidth);\n currentColHeight += itemHeight + padding;\n });\n\n totalWidth += currentColWidth;\n columnSizes.push({width: currentColWidth, height: currentColHeight}); // previous column size\n\n return totalWidth;\n }\n\n adjustHitBoxes() {\n if (!this.options.display) {\n return;\n }\n const titleHeight = this._computeTitleHeight();\n const {legendHitBoxes: hitboxes, options: {align, labels: {padding}, rtl}} = this;\n const rtlHelper = getRtlAdapter(rtl, this.left, this.width);\n if (this.isHorizontal()) {\n let row = 0;\n let left = _alignStartEnd(align, this.left + padding, this.right - this.lineWidths[row]);\n for (const hitbox of hitboxes) {\n if (row !== hitbox.row) {\n row = hitbox.row;\n left = _alignStartEnd(align, this.left + padding, this.right - this.lineWidths[row]);\n }\n hitbox.top += this.top + titleHeight + padding;\n hitbox.left = rtlHelper.leftForLtr(rtlHelper.x(left), hitbox.width);\n left += hitbox.width + padding;\n }\n } else {\n let col = 0;\n let top = _alignStartEnd(align, this.top + titleHeight + padding, this.bottom - this.columnSizes[col].height);\n for (const hitbox of hitboxes) {\n if (hitbox.col !== col) {\n col = hitbox.col;\n top = _alignStartEnd(align, this.top + titleHeight + padding, this.bottom - this.columnSizes[col].height);\n }\n hitbox.top = top;\n hitbox.left += this.left + padding;\n hitbox.left = rtlHelper.leftForLtr(rtlHelper.x(hitbox.left), hitbox.width);\n top += hitbox.height + padding;\n }\n }\n }\n\n isHorizontal() {\n return this.options.position === 'top' || this.options.position === 'bottom';\n }\n\n draw() {\n if (this.options.display) {\n const ctx = this.ctx;\n clipArea(ctx, this);\n\n this._draw();\n\n unclipArea(ctx);\n }\n }\n\n /**\n\t * @private\n\t */\n _draw() {\n const {options: opts, columnSizes, lineWidths, ctx} = this;\n const {align, labels: labelOpts} = opts;\n const defaultColor = defaults.color;\n const rtlHelper = getRtlAdapter(opts.rtl, this.left, this.width);\n const labelFont = toFont(labelOpts.font);\n const {padding} = labelOpts;\n const fontSize = labelFont.size;\n const halfFontSize = fontSize / 2;\n let cursor;\n\n this.drawTitle();\n\n // Canvas setup\n ctx.textAlign = rtlHelper.textAlign('left');\n ctx.textBaseline = 'middle';\n ctx.lineWidth = 0.5;\n ctx.font = labelFont.string;\n\n const {boxWidth, boxHeight, itemHeight} = getBoxSize(labelOpts, fontSize);\n\n // current position\n const drawLegendBox = function(x, y, legendItem) {\n if (isNaN(boxWidth) || boxWidth <= 0 || isNaN(boxHeight) || boxHeight < 0) {\n return;\n }\n\n // Set the ctx for the box\n ctx.save();\n\n const lineWidth = valueOrDefault(legendItem.lineWidth, 1);\n ctx.fillStyle = valueOrDefault(legendItem.fillStyle, defaultColor);\n ctx.lineCap = valueOrDefault(legendItem.lineCap, 'butt');\n ctx.lineDashOffset = valueOrDefault(legendItem.lineDashOffset, 0);\n ctx.lineJoin = valueOrDefault(legendItem.lineJoin, 'miter');\n ctx.lineWidth = lineWidth;\n ctx.strokeStyle = valueOrDefault(legendItem.strokeStyle, defaultColor);\n\n ctx.setLineDash(valueOrDefault(legendItem.lineDash, []));\n\n if (labelOpts.usePointStyle) {\n // Recalculate x and y for drawPoint() because its expecting\n // x and y to be center of figure (instead of top left)\n const drawOptions = {\n radius: boxHeight * Math.SQRT2 / 2,\n pointStyle: legendItem.pointStyle,\n rotation: legendItem.rotation,\n borderWidth: lineWidth\n };\n const centerX = rtlHelper.xPlus(x, boxWidth / 2);\n const centerY = y + halfFontSize;\n\n // Draw pointStyle as legend symbol\n drawPointLegend(ctx, drawOptions, centerX, centerY, labelOpts.pointStyleWidth && boxWidth);\n } else {\n // Draw box as legend symbol\n // Adjust position when boxHeight < fontSize (want it centered)\n const yBoxTop = y + Math.max((fontSize - boxHeight) / 2, 0);\n const xBoxLeft = rtlHelper.leftForLtr(x, boxWidth);\n const borderRadius = toTRBLCorners(legendItem.borderRadius);\n\n ctx.beginPath();\n\n if (Object.values(borderRadius).some(v => v !== 0)) {\n addRoundedRectPath(ctx, {\n x: xBoxLeft,\n y: yBoxTop,\n w: boxWidth,\n h: boxHeight,\n radius: borderRadius,\n });\n } else {\n ctx.rect(xBoxLeft, yBoxTop, boxWidth, boxHeight);\n }\n\n ctx.fill();\n if (lineWidth !== 0) {\n ctx.stroke();\n }\n }\n\n ctx.restore();\n };\n\n const fillText = function(x, y, legendItem) {\n renderText(ctx, legendItem.text, x, y + (itemHeight / 2), labelFont, {\n strikethrough: legendItem.hidden,\n textAlign: rtlHelper.textAlign(legendItem.textAlign)\n });\n };\n\n // Horizontal\n const isHorizontal = this.isHorizontal();\n const titleHeight = this._computeTitleHeight();\n if (isHorizontal) {\n cursor = {\n x: _alignStartEnd(align, this.left + padding, this.right - lineWidths[0]),\n y: this.top + padding + titleHeight,\n line: 0\n };\n } else {\n cursor = {\n x: this.left + padding,\n y: _alignStartEnd(align, this.top + titleHeight + padding, this.bottom - columnSizes[0].height),\n line: 0\n };\n }\n\n overrideTextDirection(this.ctx, opts.textDirection);\n\n const lineHeight = itemHeight + padding;\n this.legendItems.forEach((legendItem, i) => {\n ctx.strokeStyle = legendItem.fontColor; // for strikethrough effect\n ctx.fillStyle = legendItem.fontColor; // render in correct colour\n\n const textWidth = ctx.measureText(legendItem.text).width;\n const textAlign = rtlHelper.textAlign(legendItem.textAlign || (legendItem.textAlign = labelOpts.textAlign));\n const width = boxWidth + halfFontSize + textWidth;\n let x = cursor.x;\n let y = cursor.y;\n\n rtlHelper.setWidth(this.width);\n\n if (isHorizontal) {\n if (i > 0 && x + width + padding > this.right) {\n y = cursor.y += lineHeight;\n cursor.line++;\n x = cursor.x = _alignStartEnd(align, this.left + padding, this.right - lineWidths[cursor.line]);\n }\n } else if (i > 0 && y + lineHeight > this.bottom) {\n x = cursor.x = x + columnSizes[cursor.line].width + padding;\n cursor.line++;\n y = cursor.y = _alignStartEnd(align, this.top + titleHeight + padding, this.bottom - columnSizes[cursor.line].height);\n }\n\n const realX = rtlHelper.x(x);\n\n drawLegendBox(realX, y, legendItem);\n\n x = _textX(textAlign, x + boxWidth + halfFontSize, isHorizontal ? x + width : this.right, opts.rtl);\n\n // Fill the actual label\n fillText(rtlHelper.x(x), y, legendItem);\n\n if (isHorizontal) {\n cursor.x += width + padding;\n } else if (typeof legendItem.text !== 'string') {\n const fontLineHeight = labelFont.lineHeight;\n cursor.y += calculateLegendItemHeight(legendItem, fontLineHeight) + padding;\n } else {\n cursor.y += lineHeight;\n }\n });\n\n restoreTextDirection(this.ctx, opts.textDirection);\n }\n\n /**\n\t * @protected\n\t */\n drawTitle() {\n const opts = this.options;\n const titleOpts = opts.title;\n const titleFont = toFont(titleOpts.font);\n const titlePadding = toPadding(titleOpts.padding);\n\n if (!titleOpts.display) {\n return;\n }\n\n const rtlHelper = getRtlAdapter(opts.rtl, this.left, this.width);\n const ctx = this.ctx;\n const position = titleOpts.position;\n const halfFontSize = titleFont.size / 2;\n const topPaddingPlusHalfFontSize = titlePadding.top + halfFontSize;\n let y;\n\n // These defaults are used when the legend is vertical.\n // When horizontal, they are computed below.\n let left = this.left;\n let maxWidth = this.width;\n\n if (this.isHorizontal()) {\n // Move left / right so that the title is above the legend lines\n maxWidth = Math.max(...this.lineWidths);\n y = this.top + topPaddingPlusHalfFontSize;\n left = _alignStartEnd(opts.align, left, this.right - maxWidth);\n } else {\n // Move down so that the title is above the legend stack in every alignment\n const maxHeight = this.columnSizes.reduce((acc, size) => Math.max(acc, size.height), 0);\n y = topPaddingPlusHalfFontSize + _alignStartEnd(opts.align, this.top, this.bottom - maxHeight - opts.labels.padding - this._computeTitleHeight());\n }\n\n // Now that we know the left edge of the inner legend box, compute the correct\n // X coordinate from the title alignment\n const x = _alignStartEnd(position, left, left + maxWidth);\n\n // Canvas setup\n ctx.textAlign = rtlHelper.textAlign(_toLeftRightCenter(position));\n ctx.textBaseline = 'middle';\n ctx.strokeStyle = titleOpts.color;\n ctx.fillStyle = titleOpts.color;\n ctx.font = titleFont.string;\n\n renderText(ctx, titleOpts.text, x, y, titleFont);\n }\n\n /**\n\t * @private\n\t */\n _computeTitleHeight() {\n const titleOpts = this.options.title;\n const titleFont = toFont(titleOpts.font);\n const titlePadding = toPadding(titleOpts.padding);\n return titleOpts.display ? titleFont.lineHeight + titlePadding.height : 0;\n }\n\n /**\n\t * @private\n\t */\n _getLegendItemAt(x, y) {\n let i, hitBox, lh;\n\n if (_isBetween(x, this.left, this.right)\n && _isBetween(y, this.top, this.bottom)) {\n // See if we are touching one of the dataset boxes\n lh = this.legendHitBoxes;\n for (i = 0; i < lh.length; ++i) {\n hitBox = lh[i];\n\n if (_isBetween(x, hitBox.left, hitBox.left + hitBox.width)\n && _isBetween(y, hitBox.top, hitBox.top + hitBox.height)) {\n // Touching an element\n return this.legendItems[i];\n }\n }\n }\n\n return null;\n }\n\n /**\n\t * Handle an event\n\t * @param {ChartEvent} e - The event to handle\n\t */\n handleEvent(e) {\n const opts = this.options;\n if (!isListened(e.type, opts)) {\n return;\n }\n\n // Chart event already has relative position in it\n const hoveredItem = this._getLegendItemAt(e.x, e.y);\n\n if (e.type === 'mousemove' || e.type === 'mouseout') {\n const previous = this._hoveredItem;\n const sameItem = itemsEqual(previous, hoveredItem);\n if (previous && !sameItem) {\n call(opts.onLeave, [e, previous, this], this);\n }\n\n this._hoveredItem = hoveredItem;\n\n if (hoveredItem && !sameItem) {\n call(opts.onHover, [e, hoveredItem, this], this);\n }\n } else if (hoveredItem) {\n call(opts.onClick, [e, hoveredItem, this], this);\n }\n }\n}\n\nfunction calculateItemSize(boxWidth, labelFont, ctx, legendItem, _itemHeight) {\n const itemWidth = calculateItemWidth(legendItem, boxWidth, labelFont, ctx);\n const itemHeight = calculateItemHeight(_itemHeight, legendItem, labelFont.lineHeight);\n return {itemWidth, itemHeight};\n}\n\nfunction calculateItemWidth(legendItem, boxWidth, labelFont, ctx) {\n let legendItemText = legendItem.text;\n if (legendItemText && typeof legendItemText !== 'string') {\n legendItemText = legendItemText.reduce((a, b) => a.length > b.length ? a : b);\n }\n return boxWidth + (labelFont.size / 2) + ctx.measureText(legendItemText).width;\n}\n\nfunction calculateItemHeight(_itemHeight, legendItem, fontLineHeight) {\n let itemHeight = _itemHeight;\n if (typeof legendItem.text !== 'string') {\n itemHeight = calculateLegendItemHeight(legendItem, fontLineHeight);\n }\n return itemHeight;\n}\n\nfunction calculateLegendItemHeight(legendItem, fontLineHeight) {\n const labelHeight = legendItem.text ? legendItem.text.length : 0;\n return fontLineHeight * labelHeight;\n}\n\nfunction isListened(type, opts) {\n if ((type === 'mousemove' || type === 'mouseout') && (opts.onHover || opts.onLeave)) {\n return true;\n }\n if (opts.onClick && (type === 'click' || type === 'mouseup')) {\n return true;\n }\n return false;\n}\n\nexport default {\n id: 'legend',\n\n /**\n\t * For tests\n\t * @private\n\t */\n _element: Legend,\n\n start(chart, _args, options) {\n const legend = chart.legend = new Legend({ctx: chart.ctx, options, chart});\n layouts.configure(chart, legend, options);\n layouts.addBox(chart, legend);\n },\n\n stop(chart) {\n layouts.removeBox(chart, chart.legend);\n delete chart.legend;\n },\n\n // During the beforeUpdate step, the layout configuration needs to run\n // This ensures that if the legend position changes (via an option update)\n // the layout system respects the change. See https://github.com/chartjs/Chart.js/issues/7527\n beforeUpdate(chart, _args, options) {\n const legend = chart.legend;\n layouts.configure(chart, legend, options);\n legend.options = options;\n },\n\n // The labels need to be built after datasets are updated to ensure that colors\n // and other styling are correct. See https://github.com/chartjs/Chart.js/issues/6968\n afterUpdate(chart) {\n const legend = chart.legend;\n legend.buildLabels();\n legend.adjustHitBoxes();\n },\n\n\n afterEvent(chart, args) {\n if (!args.replay) {\n chart.legend.handleEvent(args.event);\n }\n },\n\n defaults: {\n display: true,\n position: 'top',\n align: 'center',\n fullSize: true,\n reverse: false,\n weight: 1000,\n\n // a callback that will handle\n onClick(e, legendItem, legend) {\n const index = legendItem.datasetIndex;\n const ci = legend.chart;\n if (ci.isDatasetVisible(index)) {\n ci.hide(index);\n legendItem.hidden = true;\n } else {\n ci.show(index);\n legendItem.hidden = false;\n }\n },\n\n onHover: null,\n onLeave: null,\n\n labels: {\n color: (ctx) => ctx.chart.options.color,\n boxWidth: 40,\n padding: 10,\n // Generates labels shown in the legend\n // Valid properties to return:\n // text : text to display\n // fillStyle : fill of coloured box\n // strokeStyle: stroke of coloured box\n // hidden : if this legend item refers to a hidden item\n // lineCap : cap style for line\n // lineDash\n // lineDashOffset :\n // lineJoin :\n // lineWidth :\n generateLabels(chart) {\n const datasets = chart.data.datasets;\n const {labels: {usePointStyle, pointStyle, textAlign, color, useBorderRadius, borderRadius}} = chart.legend.options;\n\n return chart._getSortedDatasetMetas().map((meta) => {\n const style = meta.controller.getStyle(usePointStyle ? 0 : undefined);\n const borderWidth = toPadding(style.borderWidth);\n\n return {\n text: datasets[meta.index].label,\n fillStyle: style.backgroundColor,\n fontColor: color,\n hidden: !meta.visible,\n lineCap: style.borderCapStyle,\n lineDash: style.borderDash,\n lineDashOffset: style.borderDashOffset,\n lineJoin: style.borderJoinStyle,\n lineWidth: (borderWidth.width + borderWidth.height) / 4,\n strokeStyle: style.borderColor,\n pointStyle: pointStyle || style.pointStyle,\n rotation: style.rotation,\n textAlign: textAlign || style.textAlign,\n borderRadius: useBorderRadius && (borderRadius || style.borderRadius),\n\n // Below is extra data used for toggling the datasets\n datasetIndex: meta.index\n };\n }, this);\n }\n },\n\n title: {\n color: (ctx) => ctx.chart.options.color,\n display: false,\n position: 'center',\n text: '',\n }\n },\n\n descriptors: {\n _scriptable: (name) => !name.startsWith('on'),\n labels: {\n _scriptable: (name) => !['generateLabels', 'filter', 'sort'].includes(name),\n }\n },\n};\n","import {Title} from './plugin.title.js';\nimport layouts from '../core/core.layouts.js';\n\nconst map = new WeakMap();\n\nexport default {\n id: 'subtitle',\n\n start(chart, _args, options) {\n const title = new Title({\n ctx: chart.ctx,\n options,\n chart\n });\n\n layouts.configure(chart, title, options);\n layouts.addBox(chart, title);\n map.set(chart, title);\n },\n\n stop(chart) {\n layouts.removeBox(chart, map.get(chart));\n map.delete(chart);\n },\n\n beforeUpdate(chart, _args, options) {\n const title = map.get(chart);\n layouts.configure(chart, title, options);\n title.options = options;\n },\n\n defaults: {\n align: 'center',\n display: false,\n font: {\n weight: 'normal',\n },\n fullSize: true,\n padding: 0,\n position: 'top',\n text: '',\n weight: 1500 // by default greater than legend (1000) and smaller than title (2000)\n },\n\n defaultRoutes: {\n color: 'color'\n },\n\n descriptors: {\n _scriptable: true,\n _indexable: false,\n },\n};\n","import Animations from '../core/core.animations.js';\nimport Element from '../core/core.element.js';\nimport {addRoundedRectPath} from '../helpers/helpers.canvas.js';\nimport {each, noop, isNullOrUndef, isArray, _elementsEqual, isObject} from '../helpers/helpers.core.js';\nimport {toFont, toPadding, toTRBLCorners} from '../helpers/helpers.options.js';\nimport {getRtlAdapter, overrideTextDirection, restoreTextDirection} from '../helpers/helpers.rtl.js';\nimport {distanceBetweenPoints, _limitValue} from '../helpers/helpers.math.js';\nimport {createContext, drawPoint} from '../helpers/index.js';\n\n/**\n * @typedef { import('../platform/platform.base.js').Chart } Chart\n * @typedef { import('../types/index.js').ChartEvent } ChartEvent\n * @typedef { import('../types/index.js').ActiveElement } ActiveElement\n * @typedef { import('../core/core.interaction.js').InteractionItem } InteractionItem\n */\n\nconst positioners = {\n /**\n\t * Average mode places the tooltip at the average position of the elements shown\n\t */\n average(items) {\n if (!items.length) {\n return false;\n }\n\n let i, len;\n let xSet = new Set();\n let y = 0;\n let count = 0;\n\n for (i = 0, len = items.length; i < len; ++i) {\n const el = items[i].element;\n if (el && el.hasValue()) {\n const pos = el.tooltipPosition();\n xSet.add(pos.x);\n y += pos.y;\n ++count;\n }\n }\n\n // No visible items where found, return false so we don't have to divide by 0 which reduces in NaN\n if (count === 0 || xSet.size === 0) {\n return false;\n }\n\n const xAverage = [...xSet].reduce((a, b) => a + b) / xSet.size;\n\n return {\n x: xAverage,\n y: y / count\n };\n },\n\n /**\n\t * Gets the tooltip position nearest of the item nearest to the event position\n\t */\n nearest(items, eventPosition) {\n if (!items.length) {\n return false;\n }\n\n let x = eventPosition.x;\n let y = eventPosition.y;\n let minDistance = Number.POSITIVE_INFINITY;\n let i, len, nearestElement;\n\n for (i = 0, len = items.length; i < len; ++i) {\n const el = items[i].element;\n if (el && el.hasValue()) {\n const center = el.getCenterPoint();\n const d = distanceBetweenPoints(eventPosition, center);\n\n if (d < minDistance) {\n minDistance = d;\n nearestElement = el;\n }\n }\n }\n\n if (nearestElement) {\n const tp = nearestElement.tooltipPosition();\n x = tp.x;\n y = tp.y;\n }\n\n return {\n x,\n y\n };\n }\n};\n\n// Helper to push or concat based on if the 2nd parameter is an array or not\nfunction pushOrConcat(base, toPush) {\n if (toPush) {\n if (isArray(toPush)) {\n // base = base.concat(toPush);\n Array.prototype.push.apply(base, toPush);\n } else {\n base.push(toPush);\n }\n }\n\n return base;\n}\n\n/**\n * Returns array of strings split by newline\n * @param {*} str - The value to split by newline.\n * @returns {string|string[]} value if newline present - Returned from String split() method\n * @function\n */\nfunction splitNewlines(str) {\n if ((typeof str === 'string' || str instanceof String) && str.indexOf('\\n') > -1) {\n return str.split('\\n');\n }\n return str;\n}\n\n\n/**\n * Private helper to create a tooltip item model\n * @param {Chart} chart\n * @param {ActiveElement} item - {element, index, datasetIndex} to create the tooltip item for\n * @return new tooltip item\n */\nfunction createTooltipItem(chart, item) {\n const {element, datasetIndex, index} = item;\n const controller = chart.getDatasetMeta(datasetIndex).controller;\n const {label, value} = controller.getLabelAndValue(index);\n\n return {\n chart,\n label,\n parsed: controller.getParsed(index),\n raw: chart.data.datasets[datasetIndex].data[index],\n formattedValue: value,\n dataset: controller.getDataset(),\n dataIndex: index,\n datasetIndex,\n element\n };\n}\n\n/**\n * Get the size of the tooltip\n */\nfunction getTooltipSize(tooltip, options) {\n const ctx = tooltip.chart.ctx;\n const {body, footer, title} = tooltip;\n const {boxWidth, boxHeight} = options;\n const bodyFont = toFont(options.bodyFont);\n const titleFont = toFont(options.titleFont);\n const footerFont = toFont(options.footerFont);\n const titleLineCount = title.length;\n const footerLineCount = footer.length;\n const bodyLineItemCount = body.length;\n\n const padding = toPadding(options.padding);\n let height = padding.height;\n let width = 0;\n\n // Count of all lines in the body\n let combinedBodyLength = body.reduce((count, bodyItem) => count + bodyItem.before.length + bodyItem.lines.length + bodyItem.after.length, 0);\n combinedBodyLength += tooltip.beforeBody.length + tooltip.afterBody.length;\n\n if (titleLineCount) {\n height += titleLineCount * titleFont.lineHeight\n\t\t\t+ (titleLineCount - 1) * options.titleSpacing\n\t\t\t+ options.titleMarginBottom;\n }\n if (combinedBodyLength) {\n // Body lines may include some extra height depending on boxHeight\n const bodyLineHeight = options.displayColors ? Math.max(boxHeight, bodyFont.lineHeight) : bodyFont.lineHeight;\n height += bodyLineItemCount * bodyLineHeight\n\t\t\t+ (combinedBodyLength - bodyLineItemCount) * bodyFont.lineHeight\n\t\t\t+ (combinedBodyLength - 1) * options.bodySpacing;\n }\n if (footerLineCount) {\n height += options.footerMarginTop\n\t\t\t+ footerLineCount * footerFont.lineHeight\n\t\t\t+ (footerLineCount - 1) * options.footerSpacing;\n }\n\n // Title width\n let widthPadding = 0;\n const maxLineWidth = function(line) {\n width = Math.max(width, ctx.measureText(line).width + widthPadding);\n };\n\n ctx.save();\n\n ctx.font = titleFont.string;\n each(tooltip.title, maxLineWidth);\n\n // Body width\n ctx.font = bodyFont.string;\n each(tooltip.beforeBody.concat(tooltip.afterBody), maxLineWidth);\n\n // Body lines may include some extra width due to the color box\n widthPadding = options.displayColors ? (boxWidth + 2 + options.boxPadding) : 0;\n each(body, (bodyItem) => {\n each(bodyItem.before, maxLineWidth);\n each(bodyItem.lines, maxLineWidth);\n each(bodyItem.after, maxLineWidth);\n });\n\n // Reset back to 0\n widthPadding = 0;\n\n // Footer width\n ctx.font = footerFont.string;\n each(tooltip.footer, maxLineWidth);\n\n ctx.restore();\n\n // Add padding\n width += padding.width;\n\n return {width, height};\n}\n\nfunction determineYAlign(chart, size) {\n const {y, height} = size;\n\n if (y < height / 2) {\n return 'top';\n } else if (y > (chart.height - height / 2)) {\n return 'bottom';\n }\n return 'center';\n}\n\nfunction doesNotFitWithAlign(xAlign, chart, options, size) {\n const {x, width} = size;\n const caret = options.caretSize + options.caretPadding;\n if (xAlign === 'left' && x + width + caret > chart.width) {\n return true;\n }\n\n if (xAlign === 'right' && x - width - caret < 0) {\n return true;\n }\n}\n\nfunction determineXAlign(chart, options, size, yAlign) {\n const {x, width} = size;\n const {width: chartWidth, chartArea: {left, right}} = chart;\n let xAlign = 'center';\n\n if (yAlign === 'center') {\n xAlign = x <= (left + right) / 2 ? 'left' : 'right';\n } else if (x <= width / 2) {\n xAlign = 'left';\n } else if (x >= chartWidth - width / 2) {\n xAlign = 'right';\n }\n\n if (doesNotFitWithAlign(xAlign, chart, options, size)) {\n xAlign = 'center';\n }\n\n return xAlign;\n}\n\n/**\n * Helper to get the alignment of a tooltip given the size\n */\nfunction determineAlignment(chart, options, size) {\n const yAlign = size.yAlign || options.yAlign || determineYAlign(chart, size);\n\n return {\n xAlign: size.xAlign || options.xAlign || determineXAlign(chart, options, size, yAlign),\n yAlign\n };\n}\n\nfunction alignX(size, xAlign) {\n let {x, width} = size;\n if (xAlign === 'right') {\n x -= width;\n } else if (xAlign === 'center') {\n x -= (width / 2);\n }\n return x;\n}\n\nfunction alignY(size, yAlign, paddingAndSize) {\n // eslint-disable-next-line prefer-const\n let {y, height} = size;\n if (yAlign === 'top') {\n y += paddingAndSize;\n } else if (yAlign === 'bottom') {\n y -= height + paddingAndSize;\n } else {\n y -= (height / 2);\n }\n return y;\n}\n\n/**\n * Helper to get the location a tooltip needs to be placed at given the initial position (via the vm) and the size and alignment\n */\nfunction getBackgroundPoint(options, size, alignment, chart) {\n const {caretSize, caretPadding, cornerRadius} = options;\n const {xAlign, yAlign} = alignment;\n const paddingAndSize = caretSize + caretPadding;\n const {topLeft, topRight, bottomLeft, bottomRight} = toTRBLCorners(cornerRadius);\n\n let x = alignX(size, xAlign);\n const y = alignY(size, yAlign, paddingAndSize);\n\n if (yAlign === 'center') {\n if (xAlign === 'left') {\n x += paddingAndSize;\n } else if (xAlign === 'right') {\n x -= paddingAndSize;\n }\n } else if (xAlign === 'left') {\n x -= Math.max(topLeft, bottomLeft) + caretSize;\n } else if (xAlign === 'right') {\n x += Math.max(topRight, bottomRight) + caretSize;\n }\n\n return {\n x: _limitValue(x, 0, chart.width - size.width),\n y: _limitValue(y, 0, chart.height - size.height)\n };\n}\n\nfunction getAlignedX(tooltip, align, options) {\n const padding = toPadding(options.padding);\n\n return align === 'center'\n ? tooltip.x + tooltip.width / 2\n : align === 'right'\n ? tooltip.x + tooltip.width - padding.right\n : tooltip.x + padding.left;\n}\n\n/**\n * Helper to build before and after body lines\n */\nfunction getBeforeAfterBodyLines(callback) {\n return pushOrConcat([], splitNewlines(callback));\n}\n\nfunction createTooltipContext(parent, tooltip, tooltipItems) {\n return createContext(parent, {\n tooltip,\n tooltipItems,\n type: 'tooltip'\n });\n}\n\nfunction overrideCallbacks(callbacks, context) {\n const override = context && context.dataset && context.dataset.tooltip && context.dataset.tooltip.callbacks;\n return override ? callbacks.override(override) : callbacks;\n}\n\nconst defaultCallbacks = {\n // Args are: (tooltipItems, data)\n beforeTitle: noop,\n title(tooltipItems) {\n if (tooltipItems.length > 0) {\n const item = tooltipItems[0];\n const labels = item.chart.data.labels;\n const labelCount = labels ? labels.length : 0;\n\n if (this && this.options && this.options.mode === 'dataset') {\n return item.dataset.label || '';\n } else if (item.label) {\n return item.label;\n } else if (labelCount > 0 && item.dataIndex < labelCount) {\n return labels[item.dataIndex];\n }\n }\n\n return '';\n },\n afterTitle: noop,\n\n // Args are: (tooltipItems, data)\n beforeBody: noop,\n\n // Args are: (tooltipItem, data)\n beforeLabel: noop,\n label(tooltipItem) {\n if (this && this.options && this.options.mode === 'dataset') {\n return tooltipItem.label + ': ' + tooltipItem.formattedValue || tooltipItem.formattedValue;\n }\n\n let label = tooltipItem.dataset.label || '';\n\n if (label) {\n label += ': ';\n }\n const value = tooltipItem.formattedValue;\n if (!isNullOrUndef(value)) {\n label += value;\n }\n return label;\n },\n labelColor(tooltipItem) {\n const meta = tooltipItem.chart.getDatasetMeta(tooltipItem.datasetIndex);\n const options = meta.controller.getStyle(tooltipItem.dataIndex);\n return {\n borderColor: options.borderColor,\n backgroundColor: options.backgroundColor,\n borderWidth: options.borderWidth,\n borderDash: options.borderDash,\n borderDashOffset: options.borderDashOffset,\n borderRadius: 0,\n };\n },\n labelTextColor() {\n return this.options.bodyColor;\n },\n labelPointStyle(tooltipItem) {\n const meta = tooltipItem.chart.getDatasetMeta(tooltipItem.datasetIndex);\n const options = meta.controller.getStyle(tooltipItem.dataIndex);\n return {\n pointStyle: options.pointStyle,\n rotation: options.rotation,\n };\n },\n afterLabel: noop,\n\n // Args are: (tooltipItems, data)\n afterBody: noop,\n\n // Args are: (tooltipItems, data)\n beforeFooter: noop,\n footer: noop,\n afterFooter: noop\n};\n\n/**\n * Invoke callback from object with context and arguments.\n * If callback returns `undefined`, then will be invoked default callback.\n * @param {Record} callbacks\n * @param {keyof typeof defaultCallbacks} name\n * @param {*} ctx\n * @param {*} arg\n * @returns {any}\n */\nfunction invokeCallbackWithFallback(callbacks, name, ctx, arg) {\n const result = callbacks[name].call(ctx, arg);\n\n if (typeof result === 'undefined') {\n return defaultCallbacks[name].call(ctx, arg);\n }\n\n return result;\n}\n\nexport class Tooltip extends Element {\n\n /**\n * @namespace Chart.Tooltip.positioners\n */\n static positioners = positioners;\n\n constructor(config) {\n super();\n\n this.opacity = 0;\n this._active = [];\n this._eventPosition = undefined;\n this._size = undefined;\n this._cachedAnimations = undefined;\n this._tooltipItems = [];\n this.$animations = undefined;\n this.$context = undefined;\n this.chart = config.chart;\n this.options = config.options;\n this.dataPoints = undefined;\n this.title = undefined;\n this.beforeBody = undefined;\n this.body = undefined;\n this.afterBody = undefined;\n this.footer = undefined;\n this.xAlign = undefined;\n this.yAlign = undefined;\n this.x = undefined;\n this.y = undefined;\n this.height = undefined;\n this.width = undefined;\n this.caretX = undefined;\n this.caretY = undefined;\n // TODO: V4, make this private, rename to `_labelStyles`, and combine with `labelPointStyles`\n // and `labelTextColors` to create a single variable\n this.labelColors = undefined;\n this.labelPointStyles = undefined;\n this.labelTextColors = undefined;\n }\n\n initialize(options) {\n this.options = options;\n this._cachedAnimations = undefined;\n this.$context = undefined;\n }\n\n /**\n\t * @private\n\t */\n _resolveAnimations() {\n const cached = this._cachedAnimations;\n\n if (cached) {\n return cached;\n }\n\n const chart = this.chart;\n const options = this.options.setContext(this.getContext());\n const opts = options.enabled && chart.options.animation && options.animations;\n const animations = new Animations(this.chart, opts);\n if (opts._cacheable) {\n this._cachedAnimations = Object.freeze(animations);\n }\n\n return animations;\n }\n\n /**\n\t * @protected\n\t */\n getContext() {\n return this.$context ||\n\t\t\t(this.$context = createTooltipContext(this.chart.getContext(), this, this._tooltipItems));\n }\n\n getTitle(context, options) {\n const {callbacks} = options;\n\n const beforeTitle = invokeCallbackWithFallback(callbacks, 'beforeTitle', this, context);\n const title = invokeCallbackWithFallback(callbacks, 'title', this, context);\n const afterTitle = invokeCallbackWithFallback(callbacks, 'afterTitle', this, context);\n\n let lines = [];\n lines = pushOrConcat(lines, splitNewlines(beforeTitle));\n lines = pushOrConcat(lines, splitNewlines(title));\n lines = pushOrConcat(lines, splitNewlines(afterTitle));\n\n return lines;\n }\n\n getBeforeBody(tooltipItems, options) {\n return getBeforeAfterBodyLines(\n invokeCallbackWithFallback(options.callbacks, 'beforeBody', this, tooltipItems)\n );\n }\n\n getBody(tooltipItems, options) {\n const {callbacks} = options;\n const bodyItems = [];\n\n each(tooltipItems, (context) => {\n const bodyItem = {\n before: [],\n lines: [],\n after: []\n };\n const scoped = overrideCallbacks(callbacks, context);\n pushOrConcat(bodyItem.before, splitNewlines(invokeCallbackWithFallback(scoped, 'beforeLabel', this, context)));\n pushOrConcat(bodyItem.lines, invokeCallbackWithFallback(scoped, 'label', this, context));\n pushOrConcat(bodyItem.after, splitNewlines(invokeCallbackWithFallback(scoped, 'afterLabel', this, context)));\n\n bodyItems.push(bodyItem);\n });\n\n return bodyItems;\n }\n\n getAfterBody(tooltipItems, options) {\n return getBeforeAfterBodyLines(\n invokeCallbackWithFallback(options.callbacks, 'afterBody', this, tooltipItems)\n );\n }\n\n // Get the footer and beforeFooter and afterFooter lines\n getFooter(tooltipItems, options) {\n const {callbacks} = options;\n\n const beforeFooter = invokeCallbackWithFallback(callbacks, 'beforeFooter', this, tooltipItems);\n const footer = invokeCallbackWithFallback(callbacks, 'footer', this, tooltipItems);\n const afterFooter = invokeCallbackWithFallback(callbacks, 'afterFooter', this, tooltipItems);\n\n let lines = [];\n lines = pushOrConcat(lines, splitNewlines(beforeFooter));\n lines = pushOrConcat(lines, splitNewlines(footer));\n lines = pushOrConcat(lines, splitNewlines(afterFooter));\n\n return lines;\n }\n\n /**\n\t * @private\n\t */\n _createItems(options) {\n const active = this._active;\n const data = this.chart.data;\n const labelColors = [];\n const labelPointStyles = [];\n const labelTextColors = [];\n let tooltipItems = [];\n let i, len;\n\n for (i = 0, len = active.length; i < len; ++i) {\n tooltipItems.push(createTooltipItem(this.chart, active[i]));\n }\n\n // If the user provided a filter function, use it to modify the tooltip items\n if (options.filter) {\n tooltipItems = tooltipItems.filter((element, index, array) => options.filter(element, index, array, data));\n }\n\n // If the user provided a sorting function, use it to modify the tooltip items\n if (options.itemSort) {\n tooltipItems = tooltipItems.sort((a, b) => options.itemSort(a, b, data));\n }\n\n // Determine colors for boxes\n each(tooltipItems, (context) => {\n const scoped = overrideCallbacks(options.callbacks, context);\n labelColors.push(invokeCallbackWithFallback(scoped, 'labelColor', this, context));\n labelPointStyles.push(invokeCallbackWithFallback(scoped, 'labelPointStyle', this, context));\n labelTextColors.push(invokeCallbackWithFallback(scoped, 'labelTextColor', this, context));\n });\n\n this.labelColors = labelColors;\n this.labelPointStyles = labelPointStyles;\n this.labelTextColors = labelTextColors;\n this.dataPoints = tooltipItems;\n return tooltipItems;\n }\n\n update(changed, replay) {\n const options = this.options.setContext(this.getContext());\n const active = this._active;\n let properties;\n let tooltipItems = [];\n\n if (!active.length) {\n if (this.opacity !== 0) {\n properties = {\n opacity: 0\n };\n }\n } else {\n const position = positioners[options.position].call(this, active, this._eventPosition);\n tooltipItems = this._createItems(options);\n\n this.title = this.getTitle(tooltipItems, options);\n this.beforeBody = this.getBeforeBody(tooltipItems, options);\n this.body = this.getBody(tooltipItems, options);\n this.afterBody = this.getAfterBody(tooltipItems, options);\n this.footer = this.getFooter(tooltipItems, options);\n\n const size = this._size = getTooltipSize(this, options);\n const positionAndSize = Object.assign({}, position, size);\n const alignment = determineAlignment(this.chart, options, positionAndSize);\n const backgroundPoint = getBackgroundPoint(options, positionAndSize, alignment, this.chart);\n\n this.xAlign = alignment.xAlign;\n this.yAlign = alignment.yAlign;\n\n properties = {\n opacity: 1,\n x: backgroundPoint.x,\n y: backgroundPoint.y,\n width: size.width,\n height: size.height,\n caretX: position.x,\n caretY: position.y\n };\n }\n\n this._tooltipItems = tooltipItems;\n this.$context = undefined;\n\n if (properties) {\n this._resolveAnimations().update(this, properties);\n }\n\n if (changed && options.external) {\n options.external.call(this, {chart: this.chart, tooltip: this, replay});\n }\n }\n\n drawCaret(tooltipPoint, ctx, size, options) {\n const caretPosition = this.getCaretPosition(tooltipPoint, size, options);\n\n ctx.lineTo(caretPosition.x1, caretPosition.y1);\n ctx.lineTo(caretPosition.x2, caretPosition.y2);\n ctx.lineTo(caretPosition.x3, caretPosition.y3);\n }\n\n getCaretPosition(tooltipPoint, size, options) {\n const {xAlign, yAlign} = this;\n const {caretSize, cornerRadius} = options;\n const {topLeft, topRight, bottomLeft, bottomRight} = toTRBLCorners(cornerRadius);\n const {x: ptX, y: ptY} = tooltipPoint;\n const {width, height} = size;\n let x1, x2, x3, y1, y2, y3;\n\n if (yAlign === 'center') {\n y2 = ptY + (height / 2);\n\n if (xAlign === 'left') {\n x1 = ptX;\n x2 = x1 - caretSize;\n\n // Left draws bottom -> top, this y1 is on the bottom\n y1 = y2 + caretSize;\n y3 = y2 - caretSize;\n } else {\n x1 = ptX + width;\n x2 = x1 + caretSize;\n\n // Right draws top -> bottom, thus y1 is on the top\n y1 = y2 - caretSize;\n y3 = y2 + caretSize;\n }\n\n x3 = x1;\n } else {\n if (xAlign === 'left') {\n x2 = ptX + Math.max(topLeft, bottomLeft) + (caretSize);\n } else if (xAlign === 'right') {\n x2 = ptX + width - Math.max(topRight, bottomRight) - caretSize;\n } else {\n x2 = this.caretX;\n }\n\n if (yAlign === 'top') {\n y1 = ptY;\n y2 = y1 - caretSize;\n\n // Top draws left -> right, thus x1 is on the left\n x1 = x2 - caretSize;\n x3 = x2 + caretSize;\n } else {\n y1 = ptY + height;\n y2 = y1 + caretSize;\n\n // Bottom draws right -> left, thus x1 is on the right\n x1 = x2 + caretSize;\n x3 = x2 - caretSize;\n }\n y3 = y1;\n }\n return {x1, x2, x3, y1, y2, y3};\n }\n\n drawTitle(pt, ctx, options) {\n const title = this.title;\n const length = title.length;\n let titleFont, titleSpacing, i;\n\n if (length) {\n const rtlHelper = getRtlAdapter(options.rtl, this.x, this.width);\n\n pt.x = getAlignedX(this, options.titleAlign, options);\n\n ctx.textAlign = rtlHelper.textAlign(options.titleAlign);\n ctx.textBaseline = 'middle';\n\n titleFont = toFont(options.titleFont);\n titleSpacing = options.titleSpacing;\n\n ctx.fillStyle = options.titleColor;\n ctx.font = titleFont.string;\n\n for (i = 0; i < length; ++i) {\n ctx.fillText(title[i], rtlHelper.x(pt.x), pt.y + titleFont.lineHeight / 2);\n pt.y += titleFont.lineHeight + titleSpacing; // Line Height and spacing\n\n if (i + 1 === length) {\n pt.y += options.titleMarginBottom - titleSpacing; // If Last, add margin, remove spacing\n }\n }\n }\n }\n\n /**\n\t * @private\n\t */\n _drawColorBox(ctx, pt, i, rtlHelper, options) {\n const labelColor = this.labelColors[i];\n const labelPointStyle = this.labelPointStyles[i];\n const {boxHeight, boxWidth} = options;\n const bodyFont = toFont(options.bodyFont);\n const colorX = getAlignedX(this, 'left', options);\n const rtlColorX = rtlHelper.x(colorX);\n const yOffSet = boxHeight < bodyFont.lineHeight ? (bodyFont.lineHeight - boxHeight) / 2 : 0;\n const colorY = pt.y + yOffSet;\n\n if (options.usePointStyle) {\n const drawOptions = {\n radius: Math.min(boxWidth, boxHeight) / 2, // fit the circle in the box\n pointStyle: labelPointStyle.pointStyle,\n rotation: labelPointStyle.rotation,\n borderWidth: 1\n };\n // Recalculate x and y for drawPoint() because its expecting\n // x and y to be center of figure (instead of top left)\n const centerX = rtlHelper.leftForLtr(rtlColorX, boxWidth) + boxWidth / 2;\n const centerY = colorY + boxHeight / 2;\n\n // Fill the point with white so that colours merge nicely if the opacity is < 1\n ctx.strokeStyle = options.multiKeyBackground;\n ctx.fillStyle = options.multiKeyBackground;\n drawPoint(ctx, drawOptions, centerX, centerY);\n\n // Draw the point\n ctx.strokeStyle = labelColor.borderColor;\n ctx.fillStyle = labelColor.backgroundColor;\n drawPoint(ctx, drawOptions, centerX, centerY);\n } else {\n // Border\n ctx.lineWidth = isObject(labelColor.borderWidth) ? Math.max(...Object.values(labelColor.borderWidth)) : (labelColor.borderWidth || 1); // TODO, v4 remove fallback\n ctx.strokeStyle = labelColor.borderColor;\n ctx.setLineDash(labelColor.borderDash || []);\n ctx.lineDashOffset = labelColor.borderDashOffset || 0;\n\n // Fill a white rect so that colours merge nicely if the opacity is < 1\n const outerX = rtlHelper.leftForLtr(rtlColorX, boxWidth);\n const innerX = rtlHelper.leftForLtr(rtlHelper.xPlus(rtlColorX, 1), boxWidth - 2);\n const borderRadius = toTRBLCorners(labelColor.borderRadius);\n\n if (Object.values(borderRadius).some(v => v !== 0)) {\n ctx.beginPath();\n ctx.fillStyle = options.multiKeyBackground;\n addRoundedRectPath(ctx, {\n x: outerX,\n y: colorY,\n w: boxWidth,\n h: boxHeight,\n radius: borderRadius,\n });\n ctx.fill();\n ctx.stroke();\n\n // Inner square\n ctx.fillStyle = labelColor.backgroundColor;\n ctx.beginPath();\n addRoundedRectPath(ctx, {\n x: innerX,\n y: colorY + 1,\n w: boxWidth - 2,\n h: boxHeight - 2,\n radius: borderRadius,\n });\n ctx.fill();\n } else {\n // Normal rect\n ctx.fillStyle = options.multiKeyBackground;\n ctx.fillRect(outerX, colorY, boxWidth, boxHeight);\n ctx.strokeRect(outerX, colorY, boxWidth, boxHeight);\n // Inner square\n ctx.fillStyle = labelColor.backgroundColor;\n ctx.fillRect(innerX, colorY + 1, boxWidth - 2, boxHeight - 2);\n }\n }\n\n // restore fillStyle\n ctx.fillStyle = this.labelTextColors[i];\n }\n\n drawBody(pt, ctx, options) {\n const {body} = this;\n const {bodySpacing, bodyAlign, displayColors, boxHeight, boxWidth, boxPadding} = options;\n const bodyFont = toFont(options.bodyFont);\n let bodyLineHeight = bodyFont.lineHeight;\n let xLinePadding = 0;\n\n const rtlHelper = getRtlAdapter(options.rtl, this.x, this.width);\n\n const fillLineOfText = function(line) {\n ctx.fillText(line, rtlHelper.x(pt.x + xLinePadding), pt.y + bodyLineHeight / 2);\n pt.y += bodyLineHeight + bodySpacing;\n };\n\n const bodyAlignForCalculation = rtlHelper.textAlign(bodyAlign);\n let bodyItem, textColor, lines, i, j, ilen, jlen;\n\n ctx.textAlign = bodyAlign;\n ctx.textBaseline = 'middle';\n ctx.font = bodyFont.string;\n\n pt.x = getAlignedX(this, bodyAlignForCalculation, options);\n\n // Before body lines\n ctx.fillStyle = options.bodyColor;\n each(this.beforeBody, fillLineOfText);\n\n xLinePadding = displayColors && bodyAlignForCalculation !== 'right'\n ? bodyAlign === 'center' ? (boxWidth / 2 + boxPadding) : (boxWidth + 2 + boxPadding)\n : 0;\n\n // Draw body lines now\n for (i = 0, ilen = body.length; i < ilen; ++i) {\n bodyItem = body[i];\n textColor = this.labelTextColors[i];\n\n ctx.fillStyle = textColor;\n each(bodyItem.before, fillLineOfText);\n\n lines = bodyItem.lines;\n // Draw Legend-like boxes if needed\n if (displayColors && lines.length) {\n this._drawColorBox(ctx, pt, i, rtlHelper, options);\n bodyLineHeight = Math.max(bodyFont.lineHeight, boxHeight);\n }\n\n for (j = 0, jlen = lines.length; j < jlen; ++j) {\n fillLineOfText(lines[j]);\n // Reset for any lines that don't include colorbox\n bodyLineHeight = bodyFont.lineHeight;\n }\n\n each(bodyItem.after, fillLineOfText);\n }\n\n // Reset back to 0 for after body\n xLinePadding = 0;\n bodyLineHeight = bodyFont.lineHeight;\n\n // After body lines\n each(this.afterBody, fillLineOfText);\n pt.y -= bodySpacing; // Remove last body spacing\n }\n\n drawFooter(pt, ctx, options) {\n const footer = this.footer;\n const length = footer.length;\n let footerFont, i;\n\n if (length) {\n const rtlHelper = getRtlAdapter(options.rtl, this.x, this.width);\n\n pt.x = getAlignedX(this, options.footerAlign, options);\n pt.y += options.footerMarginTop;\n\n ctx.textAlign = rtlHelper.textAlign(options.footerAlign);\n ctx.textBaseline = 'middle';\n\n footerFont = toFont(options.footerFont);\n\n ctx.fillStyle = options.footerColor;\n ctx.font = footerFont.string;\n\n for (i = 0; i < length; ++i) {\n ctx.fillText(footer[i], rtlHelper.x(pt.x), pt.y + footerFont.lineHeight / 2);\n pt.y += footerFont.lineHeight + options.footerSpacing;\n }\n }\n }\n\n drawBackground(pt, ctx, tooltipSize, options) {\n const {xAlign, yAlign} = this;\n const {x, y} = pt;\n const {width, height} = tooltipSize;\n const {topLeft, topRight, bottomLeft, bottomRight} = toTRBLCorners(options.cornerRadius);\n\n ctx.fillStyle = options.backgroundColor;\n ctx.strokeStyle = options.borderColor;\n ctx.lineWidth = options.borderWidth;\n\n ctx.beginPath();\n ctx.moveTo(x + topLeft, y);\n if (yAlign === 'top') {\n this.drawCaret(pt, ctx, tooltipSize, options);\n }\n ctx.lineTo(x + width - topRight, y);\n ctx.quadraticCurveTo(x + width, y, x + width, y + topRight);\n if (yAlign === 'center' && xAlign === 'right') {\n this.drawCaret(pt, ctx, tooltipSize, options);\n }\n ctx.lineTo(x + width, y + height - bottomRight);\n ctx.quadraticCurveTo(x + width, y + height, x + width - bottomRight, y + height);\n if (yAlign === 'bottom') {\n this.drawCaret(pt, ctx, tooltipSize, options);\n }\n ctx.lineTo(x + bottomLeft, y + height);\n ctx.quadraticCurveTo(x, y + height, x, y + height - bottomLeft);\n if (yAlign === 'center' && xAlign === 'left') {\n this.drawCaret(pt, ctx, tooltipSize, options);\n }\n ctx.lineTo(x, y + topLeft);\n ctx.quadraticCurveTo(x, y, x + topLeft, y);\n ctx.closePath();\n\n ctx.fill();\n\n if (options.borderWidth > 0) {\n ctx.stroke();\n }\n }\n\n /**\n\t * Update x/y animation targets when _active elements are animating too\n\t * @private\n\t */\n _updateAnimationTarget(options) {\n const chart = this.chart;\n const anims = this.$animations;\n const animX = anims && anims.x;\n const animY = anims && anims.y;\n if (animX || animY) {\n const position = positioners[options.position].call(this, this._active, this._eventPosition);\n if (!position) {\n return;\n }\n const size = this._size = getTooltipSize(this, options);\n const positionAndSize = Object.assign({}, position, this._size);\n const alignment = determineAlignment(chart, options, positionAndSize);\n const point = getBackgroundPoint(options, positionAndSize, alignment, chart);\n if (animX._to !== point.x || animY._to !== point.y) {\n this.xAlign = alignment.xAlign;\n this.yAlign = alignment.yAlign;\n this.width = size.width;\n this.height = size.height;\n this.caretX = position.x;\n this.caretY = position.y;\n this._resolveAnimations().update(this, point);\n }\n }\n }\n\n /**\n * Determine if the tooltip will draw anything\n * @returns {boolean} True if the tooltip will render\n */\n _willRender() {\n return !!this.opacity;\n }\n\n draw(ctx) {\n const options = this.options.setContext(this.getContext());\n let opacity = this.opacity;\n\n if (!opacity) {\n return;\n }\n\n this._updateAnimationTarget(options);\n\n const tooltipSize = {\n width: this.width,\n height: this.height\n };\n const pt = {\n x: this.x,\n y: this.y\n };\n\n // IE11/Edge does not like very small opacities, so snap to 0\n opacity = Math.abs(opacity) < 1e-3 ? 0 : opacity;\n\n const padding = toPadding(options.padding);\n\n // Truthy/falsey value for empty tooltip\n const hasTooltipContent = this.title.length || this.beforeBody.length || this.body.length || this.afterBody.length || this.footer.length;\n\n if (options.enabled && hasTooltipContent) {\n ctx.save();\n ctx.globalAlpha = opacity;\n\n // Draw Background\n this.drawBackground(pt, ctx, tooltipSize, options);\n\n overrideTextDirection(ctx, options.textDirection);\n\n pt.y += padding.top;\n\n // Titles\n this.drawTitle(pt, ctx, options);\n\n // Body\n this.drawBody(pt, ctx, options);\n\n // Footer\n this.drawFooter(pt, ctx, options);\n\n restoreTextDirection(ctx, options.textDirection);\n\n ctx.restore();\n }\n }\n\n /**\n\t * Get active elements in the tooltip\n\t * @returns {Array} Array of elements that are active in the tooltip\n\t */\n getActiveElements() {\n return this._active || [];\n }\n\n /**\n\t * Set active elements in the tooltip\n\t * @param {array} activeElements Array of active datasetIndex/index pairs.\n\t * @param {object} eventPosition Synthetic event position used in positioning\n\t */\n setActiveElements(activeElements, eventPosition) {\n const lastActive = this._active;\n const active = activeElements.map(({datasetIndex, index}) => {\n const meta = this.chart.getDatasetMeta(datasetIndex);\n\n if (!meta) {\n throw new Error('Cannot find a dataset at index ' + datasetIndex);\n }\n\n return {\n datasetIndex,\n element: meta.data[index],\n index,\n };\n });\n const changed = !_elementsEqual(lastActive, active);\n const positionChanged = this._positionChanged(active, eventPosition);\n\n if (changed || positionChanged) {\n this._active = active;\n this._eventPosition = eventPosition;\n this._ignoreReplayEvents = true;\n this.update(true);\n }\n }\n\n /**\n\t * Handle an event\n\t * @param {ChartEvent} e - The event to handle\n\t * @param {boolean} [replay] - This is a replayed event (from update)\n\t * @param {boolean} [inChartArea] - The event is inside chartArea\n\t * @returns {boolean} true if the tooltip changed\n\t */\n handleEvent(e, replay, inChartArea = true) {\n if (replay && this._ignoreReplayEvents) {\n return false;\n }\n this._ignoreReplayEvents = false;\n\n const options = this.options;\n const lastActive = this._active || [];\n const active = this._getActiveElements(e, lastActive, replay, inChartArea);\n\n // When there are multiple items shown, but the tooltip position is nearest mode\n // an update may need to be made because our position may have changed even though\n // the items are the same as before.\n const positionChanged = this._positionChanged(active, e);\n\n // Remember Last Actives\n const changed = replay || !_elementsEqual(active, lastActive) || positionChanged;\n\n // Only handle target event on tooltip change\n if (changed) {\n this._active = active;\n\n if (options.enabled || options.external) {\n this._eventPosition = {\n x: e.x,\n y: e.y\n };\n\n this.update(true, replay);\n }\n }\n\n return changed;\n }\n\n /**\n\t * Helper for determining the active elements for event\n\t * @param {ChartEvent} e - The event to handle\n\t * @param {InteractionItem[]} lastActive - Previously active elements\n\t * @param {boolean} [replay] - This is a replayed event (from update)\n\t * @param {boolean} [inChartArea] - The event is inside chartArea\n\t * @returns {InteractionItem[]} - Active elements\n\t * @private\n\t */\n _getActiveElements(e, lastActive, replay, inChartArea) {\n const options = this.options;\n\n if (e.type === 'mouseout') {\n return [];\n }\n\n if (!inChartArea) {\n // Let user control the active elements outside chartArea. Eg. using Legend.\n // But make sure that active elements are still valid.\n return lastActive.filter(i =>\n this.chart.data.datasets[i.datasetIndex] &&\n this.chart.getDatasetMeta(i.datasetIndex).controller.getParsed(i.index) !== undefined\n );\n }\n\n // Find Active Elements for tooltips\n const active = this.chart.getElementsAtEventForMode(e, options.mode, options, replay);\n\n if (options.reverse) {\n active.reverse();\n }\n\n return active;\n }\n\n /**\n\t * Determine if the active elements + event combination changes the\n\t * tooltip position\n\t * @param {array} active - Active elements\n\t * @param {ChartEvent} e - Event that triggered the position change\n\t * @returns {boolean} True if the position has changed\n\t */\n _positionChanged(active, e) {\n const {caretX, caretY, options} = this;\n const position = positioners[options.position].call(this, active, e);\n return position !== false && (caretX !== position.x || caretY !== position.y);\n }\n}\n\nexport default {\n id: 'tooltip',\n _element: Tooltip,\n positioners,\n\n afterInit(chart, _args, options) {\n if (options) {\n chart.tooltip = new Tooltip({chart, options});\n }\n },\n\n beforeUpdate(chart, _args, options) {\n if (chart.tooltip) {\n chart.tooltip.initialize(options);\n }\n },\n\n reset(chart, _args, options) {\n if (chart.tooltip) {\n chart.tooltip.initialize(options);\n }\n },\n\n afterDraw(chart) {\n const tooltip = chart.tooltip;\n\n if (tooltip && tooltip._willRender()) {\n const args = {\n tooltip\n };\n\n if (chart.notifyPlugins('beforeTooltipDraw', {...args, cancelable: true}) === false) {\n return;\n }\n\n tooltip.draw(chart.ctx);\n\n chart.notifyPlugins('afterTooltipDraw', args);\n }\n },\n\n afterEvent(chart, args) {\n if (chart.tooltip) {\n // If the event is replayed from `update`, we should evaluate with the final positions.\n const useFinalPosition = args.replay;\n if (chart.tooltip.handleEvent(args.event, useFinalPosition, args.inChartArea)) {\n // notify chart about the change, so it will render\n args.changed = true;\n }\n }\n },\n\n defaults: {\n enabled: true,\n external: null,\n position: 'average',\n backgroundColor: 'rgba(0,0,0,0.8)',\n titleColor: '#fff',\n titleFont: {\n weight: 'bold',\n },\n titleSpacing: 2,\n titleMarginBottom: 6,\n titleAlign: 'left',\n bodyColor: '#fff',\n bodySpacing: 2,\n bodyFont: {\n },\n bodyAlign: 'left',\n footerColor: '#fff',\n footerSpacing: 2,\n footerMarginTop: 6,\n footerFont: {\n weight: 'bold',\n },\n footerAlign: 'left',\n padding: 6,\n caretPadding: 2,\n caretSize: 5,\n cornerRadius: 6,\n boxHeight: (ctx, opts) => opts.bodyFont.size,\n boxWidth: (ctx, opts) => opts.bodyFont.size,\n multiKeyBackground: '#fff',\n displayColors: true,\n boxPadding: 0,\n borderColor: 'rgba(0,0,0,0)',\n borderWidth: 0,\n animation: {\n duration: 400,\n easing: 'easeOutQuart',\n },\n animations: {\n numbers: {\n type: 'number',\n properties: ['x', 'y', 'width', 'height', 'caretX', 'caretY'],\n },\n opacity: {\n easing: 'linear',\n duration: 200\n }\n },\n callbacks: defaultCallbacks\n },\n\n defaultRoutes: {\n bodyFont: 'font',\n footerFont: 'font',\n titleFont: 'font'\n },\n\n descriptors: {\n _scriptable: (name) => name !== 'filter' && name !== 'itemSort' && name !== 'external',\n _indexable: false,\n callbacks: {\n _scriptable: false,\n _indexable: false,\n },\n animation: {\n _fallback: false\n },\n animations: {\n _fallback: 'animation'\n }\n },\n\n // Resolve additionally from `interaction` options and defaults.\n additionalOptionScopes: ['interaction']\n};\n","import Scale from '../core/core.scale.js';\nimport {isNullOrUndef, valueOrDefault, _limitValue} from '../helpers/index.js';\n\nconst addIfString = (labels, raw, index, addedLabels) => {\n if (typeof raw === 'string') {\n index = labels.push(raw) - 1;\n addedLabels.unshift({index, label: raw});\n } else if (isNaN(raw)) {\n index = null;\n }\n return index;\n};\n\nfunction findOrAddLabel(labels, raw, index, addedLabels) {\n const first = labels.indexOf(raw);\n if (first === -1) {\n return addIfString(labels, raw, index, addedLabels);\n }\n const last = labels.lastIndexOf(raw);\n return first !== last ? index : first;\n}\n\nconst validIndex = (index, max) => index === null ? null : _limitValue(Math.round(index), 0, max);\n\nfunction _getLabelForValue(value) {\n const labels = this.getLabels();\n\n if (value >= 0 && value < labels.length) {\n return labels[value];\n }\n return value;\n}\n\nexport default class CategoryScale extends Scale {\n\n static id = 'category';\n\n /**\n * @type {any}\n */\n static defaults = {\n ticks: {\n callback: _getLabelForValue\n }\n };\n\n constructor(cfg) {\n super(cfg);\n\n /** @type {number} */\n this._startValue = undefined;\n this._valueRange = 0;\n this._addedLabels = [];\n }\n\n init(scaleOptions) {\n const added = this._addedLabels;\n if (added.length) {\n const labels = this.getLabels();\n for (const {index, label} of added) {\n if (labels[index] === label) {\n labels.splice(index, 1);\n }\n }\n this._addedLabels = [];\n }\n super.init(scaleOptions);\n }\n\n parse(raw, index) {\n if (isNullOrUndef(raw)) {\n return null;\n }\n const labels = this.getLabels();\n index = isFinite(index) && labels[index] === raw ? index\n : findOrAddLabel(labels, raw, valueOrDefault(index, raw), this._addedLabels);\n return validIndex(index, labels.length - 1);\n }\n\n determineDataLimits() {\n const {minDefined, maxDefined} = this.getUserBounds();\n let {min, max} = this.getMinMax(true);\n\n if (this.options.bounds === 'ticks') {\n if (!minDefined) {\n min = 0;\n }\n if (!maxDefined) {\n max = this.getLabels().length - 1;\n }\n }\n\n this.min = min;\n this.max = max;\n }\n\n buildTicks() {\n const min = this.min;\n const max = this.max;\n const offset = this.options.offset;\n const ticks = [];\n let labels = this.getLabels();\n\n // If we are viewing some subset of labels, slice the original array\n labels = (min === 0 && max === labels.length - 1) ? labels : labels.slice(min, max + 1);\n\n this._valueRange = Math.max(labels.length - (offset ? 0 : 1), 1);\n this._startValue = this.min - (offset ? 0.5 : 0);\n\n for (let value = min; value <= max; value++) {\n ticks.push({value});\n }\n return ticks;\n }\n\n getLabelForValue(value) {\n return _getLabelForValue.call(this, value);\n }\n\n /**\n\t * @protected\n\t */\n configure() {\n super.configure();\n\n if (!this.isHorizontal()) {\n // For backward compatibility, vertical category scale reverse is inverted.\n this._reversePixels = !this._reversePixels;\n }\n }\n\n // Used to get data value locations. Value can either be an index or a numerical value\n getPixelForValue(value) {\n if (typeof value !== 'number') {\n value = this.parse(value);\n }\n\n return value === null ? NaN : this.getPixelForDecimal((value - this._startValue) / this._valueRange);\n }\n\n // Must override base implementation because it calls getPixelForValue\n // and category scale can have duplicate values\n getPixelForTick(index) {\n const ticks = this.ticks;\n if (index < 0 || index > ticks.length - 1) {\n return null;\n }\n return this.getPixelForValue(ticks[index].value);\n }\n\n getValueForPixel(pixel) {\n return Math.round(this._startValue + this.getDecimalForPixel(pixel) * this._valueRange);\n }\n\n getBasePixel() {\n return this.bottom;\n }\n}\n","import {isNullOrUndef} from '../helpers/helpers.core.js';\nimport {almostEquals, almostWhole, niceNum, _decimalPlaces, _setMinAndMaxByKey, sign, toRadians} from '../helpers/helpers.math.js';\nimport Scale from '../core/core.scale.js';\nimport {formatNumber} from '../helpers/helpers.intl.js';\n\n/**\n * Generate a set of linear ticks for an axis\n * 1. If generationOptions.min, generationOptions.max, and generationOptions.step are defined:\n * if (max - min) / step is an integer, ticks are generated as [min, min + step, ..., max]\n * Note that the generationOptions.maxCount setting is respected in this scenario\n *\n * 2. If generationOptions.min, generationOptions.max, and generationOptions.count is defined\n * spacing = (max - min) / count\n * Ticks are generated as [min, min + spacing, ..., max]\n *\n * 3. If generationOptions.count is defined\n * spacing = (niceMax - niceMin) / count\n *\n * 4. Compute optimal spacing of ticks using niceNum algorithm\n *\n * @param generationOptions the options used to generate the ticks\n * @param dataRange the range of the data\n * @returns {object[]} array of tick objects\n */\nfunction generateTicks(generationOptions, dataRange) {\n const ticks = [];\n // To get a \"nice\" value for the tick spacing, we will use the appropriately named\n // \"nice number\" algorithm. See https://stackoverflow.com/questions/8506881/nice-label-algorithm-for-charts-with-minimum-ticks\n // for details.\n\n const MIN_SPACING = 1e-14;\n const {bounds, step, min, max, precision, count, maxTicks, maxDigits, includeBounds} = generationOptions;\n const unit = step || 1;\n const maxSpaces = maxTicks - 1;\n const {min: rmin, max: rmax} = dataRange;\n const minDefined = !isNullOrUndef(min);\n const maxDefined = !isNullOrUndef(max);\n const countDefined = !isNullOrUndef(count);\n const minSpacing = (rmax - rmin) / (maxDigits + 1);\n let spacing = niceNum((rmax - rmin) / maxSpaces / unit) * unit;\n let factor, niceMin, niceMax, numSpaces;\n\n // Beyond MIN_SPACING floating point numbers being to lose precision\n // such that we can't do the math necessary to generate ticks\n if (spacing < MIN_SPACING && !minDefined && !maxDefined) {\n return [{value: rmin}, {value: rmax}];\n }\n\n numSpaces = Math.ceil(rmax / spacing) - Math.floor(rmin / spacing);\n if (numSpaces > maxSpaces) {\n // If the calculated num of spaces exceeds maxNumSpaces, recalculate it\n spacing = niceNum(numSpaces * spacing / maxSpaces / unit) * unit;\n }\n\n if (!isNullOrUndef(precision)) {\n // If the user specified a precision, round to that number of decimal places\n factor = Math.pow(10, precision);\n spacing = Math.ceil(spacing * factor) / factor;\n }\n\n if (bounds === 'ticks') {\n niceMin = Math.floor(rmin / spacing) * spacing;\n niceMax = Math.ceil(rmax / spacing) * spacing;\n } else {\n niceMin = rmin;\n niceMax = rmax;\n }\n\n if (minDefined && maxDefined && step && almostWhole((max - min) / step, spacing / 1000)) {\n // Case 1: If min, max and stepSize are set and they make an evenly spaced scale use it.\n // spacing = step;\n // numSpaces = (max - min) / spacing;\n // Note that we round here to handle the case where almostWhole translated an FP error\n numSpaces = Math.round(Math.min((max - min) / spacing, maxTicks));\n spacing = (max - min) / numSpaces;\n niceMin = min;\n niceMax = max;\n } else if (countDefined) {\n // Cases 2 & 3, we have a count specified. Handle optional user defined edges to the range.\n // Sometimes these are no-ops, but it makes the code a lot clearer\n // and when a user defined range is specified, we want the correct ticks\n niceMin = minDefined ? min : niceMin;\n niceMax = maxDefined ? max : niceMax;\n numSpaces = count - 1;\n spacing = (niceMax - niceMin) / numSpaces;\n } else {\n // Case 4\n numSpaces = (niceMax - niceMin) / spacing;\n\n // If very close to our rounded value, use it.\n if (almostEquals(numSpaces, Math.round(numSpaces), spacing / 1000)) {\n numSpaces = Math.round(numSpaces);\n } else {\n numSpaces = Math.ceil(numSpaces);\n }\n }\n\n // The spacing will have changed in cases 1, 2, and 3 so the factor cannot be computed\n // until this point\n const decimalPlaces = Math.max(\n _decimalPlaces(spacing),\n _decimalPlaces(niceMin)\n );\n factor = Math.pow(10, isNullOrUndef(precision) ? decimalPlaces : precision);\n niceMin = Math.round(niceMin * factor) / factor;\n niceMax = Math.round(niceMax * factor) / factor;\n\n let j = 0;\n if (minDefined) {\n if (includeBounds && niceMin !== min) {\n ticks.push({value: min});\n\n if (niceMin < min) {\n j++; // Skip niceMin\n }\n // If the next nice tick is close to min, skip it\n if (almostEquals(Math.round((niceMin + j * spacing) * factor) / factor, min, relativeLabelSize(min, minSpacing, generationOptions))) {\n j++;\n }\n } else if (niceMin < min) {\n j++;\n }\n }\n\n for (; j < numSpaces; ++j) {\n const tickValue = Math.round((niceMin + j * spacing) * factor) / factor;\n if (maxDefined && tickValue > max) {\n break;\n }\n ticks.push({value: tickValue});\n }\n\n if (maxDefined && includeBounds && niceMax !== max) {\n // If the previous tick is too close to max, replace it with max, else add max\n if (ticks.length && almostEquals(ticks[ticks.length - 1].value, max, relativeLabelSize(max, minSpacing, generationOptions))) {\n ticks[ticks.length - 1].value = max;\n } else {\n ticks.push({value: max});\n }\n } else if (!maxDefined || niceMax === max) {\n ticks.push({value: niceMax});\n }\n\n return ticks;\n}\n\nfunction relativeLabelSize(value, minSpacing, {horizontal, minRotation}) {\n const rad = toRadians(minRotation);\n const ratio = (horizontal ? Math.sin(rad) : Math.cos(rad)) || 0.001;\n const length = 0.75 * minSpacing * ('' + value).length;\n return Math.min(minSpacing / ratio, length);\n}\n\nexport default class LinearScaleBase extends Scale {\n\n constructor(cfg) {\n super(cfg);\n\n /** @type {number} */\n this.start = undefined;\n /** @type {number} */\n this.end = undefined;\n /** @type {number} */\n this._startValue = undefined;\n /** @type {number} */\n this._endValue = undefined;\n this._valueRange = 0;\n }\n\n parse(raw, index) { // eslint-disable-line no-unused-vars\n if (isNullOrUndef(raw)) {\n return null;\n }\n if ((typeof raw === 'number' || raw instanceof Number) && !isFinite(+raw)) {\n return null;\n }\n\n return +raw;\n }\n\n handleTickRangeOptions() {\n const {beginAtZero} = this.options;\n const {minDefined, maxDefined} = this.getUserBounds();\n let {min, max} = this;\n\n const setMin = v => (min = minDefined ? min : v);\n const setMax = v => (max = maxDefined ? max : v);\n\n if (beginAtZero) {\n const minSign = sign(min);\n const maxSign = sign(max);\n\n if (minSign < 0 && maxSign < 0) {\n setMax(0);\n } else if (minSign > 0 && maxSign > 0) {\n setMin(0);\n }\n }\n\n if (min === max) {\n let offset = max === 0 ? 1 : Math.abs(max * 0.05);\n\n setMax(max + offset);\n\n if (!beginAtZero) {\n setMin(min - offset);\n }\n }\n this.min = min;\n this.max = max;\n }\n\n getTickLimit() {\n const tickOpts = this.options.ticks;\n // eslint-disable-next-line prefer-const\n let {maxTicksLimit, stepSize} = tickOpts;\n let maxTicks;\n\n if (stepSize) {\n maxTicks = Math.ceil(this.max / stepSize) - Math.floor(this.min / stepSize) + 1;\n if (maxTicks > 1000) {\n console.warn(`scales.${this.id}.ticks.stepSize: ${stepSize} would result generating up to ${maxTicks} ticks. Limiting to 1000.`);\n maxTicks = 1000;\n }\n } else {\n maxTicks = this.computeTickLimit();\n maxTicksLimit = maxTicksLimit || 11;\n }\n\n if (maxTicksLimit) {\n maxTicks = Math.min(maxTicksLimit, maxTicks);\n }\n\n return maxTicks;\n }\n\n /**\n\t * @protected\n\t */\n computeTickLimit() {\n return Number.POSITIVE_INFINITY;\n }\n\n buildTicks() {\n const opts = this.options;\n const tickOpts = opts.ticks;\n\n // Figure out what the max number of ticks we can support it is based on the size of\n // the axis area. For now, we say that the minimum tick spacing in pixels must be 40\n // We also limit the maximum number of ticks to 11 which gives a nice 10 squares on\n // the graph. Make sure we always have at least 2 ticks\n let maxTicks = this.getTickLimit();\n maxTicks = Math.max(2, maxTicks);\n\n const numericGeneratorOptions = {\n maxTicks,\n bounds: opts.bounds,\n min: opts.min,\n max: opts.max,\n precision: tickOpts.precision,\n step: tickOpts.stepSize,\n count: tickOpts.count,\n maxDigits: this._maxDigits(),\n horizontal: this.isHorizontal(),\n minRotation: tickOpts.minRotation || 0,\n includeBounds: tickOpts.includeBounds !== false\n };\n const dataRange = this._range || this;\n const ticks = generateTicks(numericGeneratorOptions, dataRange);\n\n // At this point, we need to update our max and min given the tick values,\n // since we probably have expanded the range of the scale\n if (opts.bounds === 'ticks') {\n _setMinAndMaxByKey(ticks, this, 'value');\n }\n\n if (opts.reverse) {\n ticks.reverse();\n\n this.start = this.max;\n this.end = this.min;\n } else {\n this.start = this.min;\n this.end = this.max;\n }\n\n return ticks;\n }\n\n /**\n\t * @protected\n\t */\n configure() {\n const ticks = this.ticks;\n let start = this.min;\n let end = this.max;\n\n super.configure();\n\n if (this.options.offset && ticks.length) {\n const offset = (end - start) / Math.max(ticks.length - 1, 1) / 2;\n start -= offset;\n end += offset;\n }\n this._startValue = start;\n this._endValue = end;\n this._valueRange = end - start;\n }\n\n getLabelForValue(value) {\n return formatNumber(value, this.chart.options.locale, this.options.ticks.format);\n }\n}\n","import {isFinite} from '../helpers/helpers.core.js';\nimport LinearScaleBase from './scale.linearbase.js';\nimport Ticks from '../core/core.ticks.js';\nimport {toRadians} from '../helpers/index.js';\n\nexport default class LinearScale extends LinearScaleBase {\n\n static id = 'linear';\n\n /**\n * @type {any}\n */\n static defaults = {\n ticks: {\n callback: Ticks.formatters.numeric\n }\n };\n\n\n determineDataLimits() {\n const {min, max} = this.getMinMax(true);\n\n this.min = isFinite(min) ? min : 0;\n this.max = isFinite(max) ? max : 1;\n\n // Common base implementation to handle min, max, beginAtZero\n this.handleTickRangeOptions();\n }\n\n /**\n\t * Returns the maximum number of ticks based on the scale dimension\n\t * @protected\n \t */\n computeTickLimit() {\n const horizontal = this.isHorizontal();\n const length = horizontal ? this.width : this.height;\n const minRotation = toRadians(this.options.ticks.minRotation);\n const ratio = (horizontal ? Math.sin(minRotation) : Math.cos(minRotation)) || 0.001;\n const tickFont = this._resolveTickFontOptions(0);\n return Math.ceil(length / Math.min(40, tickFont.lineHeight / ratio));\n }\n\n // Utils\n getPixelForValue(value) {\n return value === null ? NaN : this.getPixelForDecimal((value - this._startValue) / this._valueRange);\n }\n\n getValueForPixel(pixel) {\n return this._startValue + this.getDecimalForPixel(pixel) * this._valueRange;\n }\n}\n","import {finiteOrDefault, isFinite} from '../helpers/helpers.core.js';\nimport {formatNumber} from '../helpers/helpers.intl.js';\nimport {_setMinAndMaxByKey, log10} from '../helpers/helpers.math.js';\nimport Scale from '../core/core.scale.js';\nimport LinearScaleBase from './scale.linearbase.js';\nimport Ticks from '../core/core.ticks.js';\n\nconst log10Floor = v => Math.floor(log10(v));\nconst changeExponent = (v, m) => Math.pow(10, log10Floor(v) + m);\n\nfunction isMajor(tickVal) {\n const remain = tickVal / (Math.pow(10, log10Floor(tickVal)));\n return remain === 1;\n}\n\nfunction steps(min, max, rangeExp) {\n const rangeStep = Math.pow(10, rangeExp);\n const start = Math.floor(min / rangeStep);\n const end = Math.ceil(max / rangeStep);\n return end - start;\n}\n\nfunction startExp(min, max) {\n const range = max - min;\n let rangeExp = log10Floor(range);\n while (steps(min, max, rangeExp) > 10) {\n rangeExp++;\n }\n while (steps(min, max, rangeExp) < 10) {\n rangeExp--;\n }\n return Math.min(rangeExp, log10Floor(min));\n}\n\n\n/**\n * Generate a set of logarithmic ticks\n * @param generationOptions the options used to generate the ticks\n * @param dataRange the range of the data\n * @returns {object[]} array of tick objects\n */\nfunction generateTicks(generationOptions, {min, max}) {\n min = finiteOrDefault(generationOptions.min, min);\n const ticks = [];\n const minExp = log10Floor(min);\n let exp = startExp(min, max);\n let precision = exp < 0 ? Math.pow(10, Math.abs(exp)) : 1;\n const stepSize = Math.pow(10, exp);\n const base = minExp > exp ? Math.pow(10, minExp) : 0;\n const start = Math.round((min - base) * precision) / precision;\n const offset = Math.floor((min - base) / stepSize / 10) * stepSize * 10;\n let significand = Math.floor((start - offset) / Math.pow(10, exp));\n let value = finiteOrDefault(generationOptions.min, Math.round((base + offset + significand * Math.pow(10, exp)) * precision) / precision);\n while (value < max) {\n ticks.push({value, major: isMajor(value), significand});\n if (significand >= 10) {\n significand = significand < 15 ? 15 : 20;\n } else {\n significand++;\n }\n if (significand >= 20) {\n exp++;\n significand = 2;\n precision = exp >= 0 ? 1 : precision;\n }\n value = Math.round((base + offset + significand * Math.pow(10, exp)) * precision) / precision;\n }\n const lastTick = finiteOrDefault(generationOptions.max, value);\n ticks.push({value: lastTick, major: isMajor(lastTick), significand});\n\n return ticks;\n}\n\nexport default class LogarithmicScale extends Scale {\n\n static id = 'logarithmic';\n\n /**\n * @type {any}\n */\n static defaults = {\n ticks: {\n callback: Ticks.formatters.logarithmic,\n major: {\n enabled: true\n }\n }\n };\n\n\n constructor(cfg) {\n super(cfg);\n\n /** @type {number} */\n this.start = undefined;\n /** @type {number} */\n this.end = undefined;\n /** @type {number} */\n this._startValue = undefined;\n this._valueRange = 0;\n }\n\n parse(raw, index) {\n const value = LinearScaleBase.prototype.parse.apply(this, [raw, index]);\n if (value === 0) {\n this._zero = true;\n return undefined;\n }\n return isFinite(value) && value > 0 ? value : null;\n }\n\n determineDataLimits() {\n const {min, max} = this.getMinMax(true);\n\n this.min = isFinite(min) ? Math.max(0, min) : null;\n this.max = isFinite(max) ? Math.max(0, max) : null;\n\n if (this.options.beginAtZero) {\n this._zero = true;\n }\n\n // if data has `0` in it or `beginAtZero` is true, min (non zero) value is at bottom\n // of scale, and it does not equal suggestedMin, lower the min bound by one exp.\n if (this._zero && this.min !== this._suggestedMin && !isFinite(this._userMin)) {\n this.min = min === changeExponent(this.min, 0) ? changeExponent(this.min, -1) : changeExponent(this.min, 0);\n }\n\n this.handleTickRangeOptions();\n }\n\n handleTickRangeOptions() {\n const {minDefined, maxDefined} = this.getUserBounds();\n let min = this.min;\n let max = this.max;\n\n const setMin = v => (min = minDefined ? min : v);\n const setMax = v => (max = maxDefined ? max : v);\n\n if (min === max) {\n if (min <= 0) { // includes null\n setMin(1);\n setMax(10);\n } else {\n setMin(changeExponent(min, -1));\n setMax(changeExponent(max, +1));\n }\n }\n if (min <= 0) {\n setMin(changeExponent(max, -1));\n }\n if (max <= 0) {\n\n setMax(changeExponent(min, +1));\n }\n\n this.min = min;\n this.max = max;\n }\n\n buildTicks() {\n const opts = this.options;\n\n const generationOptions = {\n min: this._userMin,\n max: this._userMax\n };\n const ticks = generateTicks(generationOptions, this);\n\n // At this point, we need to update our max and min given the tick values,\n // since we probably have expanded the range of the scale\n if (opts.bounds === 'ticks') {\n _setMinAndMaxByKey(ticks, this, 'value');\n }\n\n if (opts.reverse) {\n ticks.reverse();\n\n this.start = this.max;\n this.end = this.min;\n } else {\n this.start = this.min;\n this.end = this.max;\n }\n\n return ticks;\n }\n\n /**\n\t * @param {number} value\n\t * @return {string}\n\t */\n getLabelForValue(value) {\n return value === undefined\n ? '0'\n : formatNumber(value, this.chart.options.locale, this.options.ticks.format);\n }\n\n /**\n\t * @protected\n\t */\n configure() {\n const start = this.min;\n\n super.configure();\n\n this._startValue = log10(start);\n this._valueRange = log10(this.max) - log10(start);\n }\n\n getPixelForValue(value) {\n if (value === undefined || value === 0) {\n value = this.min;\n }\n if (value === null || isNaN(value)) {\n return NaN;\n }\n return this.getPixelForDecimal(value === this.min\n ? 0\n : (log10(value) - this._startValue) / this._valueRange);\n }\n\n getValueForPixel(pixel) {\n const decimal = this.getDecimalForPixel(pixel);\n return Math.pow(10, this._startValue + decimal * this._valueRange);\n }\n}\n","import defaults from '../core/core.defaults.js';\nimport {_longestText, addRoundedRectPath, renderText, _isPointInArea} from '../helpers/helpers.canvas.js';\nimport {HALF_PI, TAU, toDegrees, toRadians, _normalizeAngle, PI} from '../helpers/helpers.math.js';\nimport LinearScaleBase from './scale.linearbase.js';\nimport Ticks from '../core/core.ticks.js';\nimport {valueOrDefault, isArray, isFinite, callback as callCallback, isNullOrUndef} from '../helpers/helpers.core.js';\nimport {createContext, toFont, toPadding, toTRBLCorners} from '../helpers/helpers.options.js';\n\nfunction getTickBackdropHeight(opts) {\n const tickOpts = opts.ticks;\n\n if (tickOpts.display && opts.display) {\n const padding = toPadding(tickOpts.backdropPadding);\n return valueOrDefault(tickOpts.font && tickOpts.font.size, defaults.font.size) + padding.height;\n }\n return 0;\n}\n\nfunction measureLabelSize(ctx, font, label) {\n label = isArray(label) ? label : [label];\n return {\n w: _longestText(ctx, font.string, label),\n h: label.length * font.lineHeight\n };\n}\n\nfunction determineLimits(angle, pos, size, min, max) {\n if (angle === min || angle === max) {\n return {\n start: pos - (size / 2),\n end: pos + (size / 2)\n };\n } else if (angle < min || angle > max) {\n return {\n start: pos - size,\n end: pos\n };\n }\n\n return {\n start: pos,\n end: pos + size\n };\n}\n\n/**\n * Helper function to fit a radial linear scale with point labels\n */\nfunction fitWithPointLabels(scale) {\n\n // Right, this is really confusing and there is a lot of maths going on here\n // The gist of the problem is here: https://gist.github.com/nnnick/696cc9c55f4b0beb8fe9\n //\n // Reaction: https://dl.dropboxusercontent.com/u/34601363/toomuchscience.gif\n //\n // Solution:\n //\n // We assume the radius of the polygon is half the size of the canvas at first\n // at each index we check if the text overlaps.\n //\n // Where it does, we store that angle and that index.\n //\n // After finding the largest index and angle we calculate how much we need to remove\n // from the shape radius to move the point inwards by that x.\n //\n // We average the left and right distances to get the maximum shape radius that can fit in the box\n // along with labels.\n //\n // Once we have that, we can find the centre point for the chart, by taking the x text protrusion\n // on each side, removing that from the size, halving it and adding the left x protrusion width.\n //\n // This will mean we have a shape fitted to the canvas, as large as it can be with the labels\n // and position it in the most space efficient manner\n //\n // https://dl.dropboxusercontent.com/u/34601363/yeahscience.gif\n\n // Get maximum radius of the polygon. Either half the height (minus the text width) or half the width.\n // Use this to calculate the offset + change. - Make sure L/R protrusion is at least 0 to stop issues with centre points\n const orig = {\n l: scale.left + scale._padding.left,\n r: scale.right - scale._padding.right,\n t: scale.top + scale._padding.top,\n b: scale.bottom - scale._padding.bottom\n };\n const limits = Object.assign({}, orig);\n const labelSizes = [];\n const padding = [];\n const valueCount = scale._pointLabels.length;\n const pointLabelOpts = scale.options.pointLabels;\n const additionalAngle = pointLabelOpts.centerPointLabels ? PI / valueCount : 0;\n\n for (let i = 0; i < valueCount; i++) {\n const opts = pointLabelOpts.setContext(scale.getPointLabelContext(i));\n padding[i] = opts.padding;\n const pointPosition = scale.getPointPosition(i, scale.drawingArea + padding[i], additionalAngle);\n const plFont = toFont(opts.font);\n const textSize = measureLabelSize(scale.ctx, plFont, scale._pointLabels[i]);\n labelSizes[i] = textSize;\n\n const angleRadians = _normalizeAngle(scale.getIndexAngle(i) + additionalAngle);\n const angle = Math.round(toDegrees(angleRadians));\n const hLimits = determineLimits(angle, pointPosition.x, textSize.w, 0, 180);\n const vLimits = determineLimits(angle, pointPosition.y, textSize.h, 90, 270);\n updateLimits(limits, orig, angleRadians, hLimits, vLimits);\n }\n\n scale.setCenterPoint(\n orig.l - limits.l,\n limits.r - orig.r,\n orig.t - limits.t,\n limits.b - orig.b\n );\n\n // Now that text size is determined, compute the full positions\n scale._pointLabelItems = buildPointLabelItems(scale, labelSizes, padding);\n}\n\nfunction updateLimits(limits, orig, angle, hLimits, vLimits) {\n const sin = Math.abs(Math.sin(angle));\n const cos = Math.abs(Math.cos(angle));\n let x = 0;\n let y = 0;\n if (hLimits.start < orig.l) {\n x = (orig.l - hLimits.start) / sin;\n limits.l = Math.min(limits.l, orig.l - x);\n } else if (hLimits.end > orig.r) {\n x = (hLimits.end - orig.r) / sin;\n limits.r = Math.max(limits.r, orig.r + x);\n }\n if (vLimits.start < orig.t) {\n y = (orig.t - vLimits.start) / cos;\n limits.t = Math.min(limits.t, orig.t - y);\n } else if (vLimits.end > orig.b) {\n y = (vLimits.end - orig.b) / cos;\n limits.b = Math.max(limits.b, orig.b + y);\n }\n}\n\nfunction createPointLabelItem(scale, index, itemOpts) {\n const outerDistance = scale.drawingArea;\n const {extra, additionalAngle, padding, size} = itemOpts;\n const pointLabelPosition = scale.getPointPosition(index, outerDistance + extra + padding, additionalAngle);\n const angle = Math.round(toDegrees(_normalizeAngle(pointLabelPosition.angle + HALF_PI)));\n const y = yForAngle(pointLabelPosition.y, size.h, angle);\n const textAlign = getTextAlignForAngle(angle);\n const left = leftForTextAlign(pointLabelPosition.x, size.w, textAlign);\n return {\n // if to draw or overlapped\n visible: true,\n\n // Text position\n x: pointLabelPosition.x,\n y,\n\n // Text rendering data\n textAlign,\n\n // Bounding box\n left,\n top: y,\n right: left + size.w,\n bottom: y + size.h\n };\n}\n\nfunction isNotOverlapped(item, area) {\n if (!area) {\n return true;\n }\n const {left, top, right, bottom} = item;\n const apexesInArea = _isPointInArea({x: left, y: top}, area) || _isPointInArea({x: left, y: bottom}, area) ||\n _isPointInArea({x: right, y: top}, area) || _isPointInArea({x: right, y: bottom}, area);\n return !apexesInArea;\n}\n\nfunction buildPointLabelItems(scale, labelSizes, padding) {\n const items = [];\n const valueCount = scale._pointLabels.length;\n const opts = scale.options;\n const {centerPointLabels, display} = opts.pointLabels;\n const itemOpts = {\n extra: getTickBackdropHeight(opts) / 2,\n additionalAngle: centerPointLabels ? PI / valueCount : 0\n };\n let area;\n\n for (let i = 0; i < valueCount; i++) {\n itemOpts.padding = padding[i];\n itemOpts.size = labelSizes[i];\n\n const item = createPointLabelItem(scale, i, itemOpts);\n items.push(item);\n if (display === 'auto') {\n item.visible = isNotOverlapped(item, area);\n if (item.visible) {\n area = item;\n }\n }\n }\n return items;\n}\n\nfunction getTextAlignForAngle(angle) {\n if (angle === 0 || angle === 180) {\n return 'center';\n } else if (angle < 180) {\n return 'left';\n }\n\n return 'right';\n}\n\nfunction leftForTextAlign(x, w, align) {\n if (align === 'right') {\n x -= w;\n } else if (align === 'center') {\n x -= (w / 2);\n }\n return x;\n}\n\nfunction yForAngle(y, h, angle) {\n if (angle === 90 || angle === 270) {\n y -= (h / 2);\n } else if (angle > 270 || angle < 90) {\n y -= h;\n }\n return y;\n}\n\nfunction drawPointLabelBox(ctx, opts, item) {\n const {left, top, right, bottom} = item;\n const {backdropColor} = opts;\n\n if (!isNullOrUndef(backdropColor)) {\n const borderRadius = toTRBLCorners(opts.borderRadius);\n const padding = toPadding(opts.backdropPadding);\n ctx.fillStyle = backdropColor;\n\n const backdropLeft = left - padding.left;\n const backdropTop = top - padding.top;\n const backdropWidth = right - left + padding.width;\n const backdropHeight = bottom - top + padding.height;\n\n if (Object.values(borderRadius).some(v => v !== 0)) {\n ctx.beginPath();\n addRoundedRectPath(ctx, {\n x: backdropLeft,\n y: backdropTop,\n w: backdropWidth,\n h: backdropHeight,\n radius: borderRadius,\n });\n ctx.fill();\n } else {\n ctx.fillRect(backdropLeft, backdropTop, backdropWidth, backdropHeight);\n }\n }\n}\n\nfunction drawPointLabels(scale, labelCount) {\n const {ctx, options: {pointLabels}} = scale;\n\n for (let i = labelCount - 1; i >= 0; i--) {\n const item = scale._pointLabelItems[i];\n if (!item.visible) {\n // overlapping\n continue;\n }\n const optsAtIndex = pointLabels.setContext(scale.getPointLabelContext(i));\n drawPointLabelBox(ctx, optsAtIndex, item);\n const plFont = toFont(optsAtIndex.font);\n const {x, y, textAlign} = item;\n\n renderText(\n ctx,\n scale._pointLabels[i],\n x,\n y + (plFont.lineHeight / 2),\n plFont,\n {\n color: optsAtIndex.color,\n textAlign: textAlign,\n textBaseline: 'middle'\n }\n );\n }\n}\n\nfunction pathRadiusLine(scale, radius, circular, labelCount) {\n const {ctx} = scale;\n if (circular) {\n // Draw circular arcs between the points\n ctx.arc(scale.xCenter, scale.yCenter, radius, 0, TAU);\n } else {\n // Draw straight lines connecting each index\n let pointPosition = scale.getPointPosition(0, radius);\n ctx.moveTo(pointPosition.x, pointPosition.y);\n\n for (let i = 1; i < labelCount; i++) {\n pointPosition = scale.getPointPosition(i, radius);\n ctx.lineTo(pointPosition.x, pointPosition.y);\n }\n }\n}\n\nfunction drawRadiusLine(scale, gridLineOpts, radius, labelCount, borderOpts) {\n const ctx = scale.ctx;\n const circular = gridLineOpts.circular;\n\n const {color, lineWidth} = gridLineOpts;\n\n if ((!circular && !labelCount) || !color || !lineWidth || radius < 0) {\n return;\n }\n\n ctx.save();\n ctx.strokeStyle = color;\n ctx.lineWidth = lineWidth;\n ctx.setLineDash(borderOpts.dash || []);\n ctx.lineDashOffset = borderOpts.dashOffset;\n\n ctx.beginPath();\n pathRadiusLine(scale, radius, circular, labelCount);\n ctx.closePath();\n ctx.stroke();\n ctx.restore();\n}\n\nfunction createPointLabelContext(parent, index, label) {\n return createContext(parent, {\n label,\n index,\n type: 'pointLabel'\n });\n}\n\nexport default class RadialLinearScale extends LinearScaleBase {\n\n static id = 'radialLinear';\n\n /**\n * @type {any}\n */\n static defaults = {\n display: true,\n\n // Boolean - Whether to animate scaling the chart from the centre\n animate: true,\n position: 'chartArea',\n\n angleLines: {\n display: true,\n lineWidth: 1,\n borderDash: [],\n borderDashOffset: 0.0\n },\n\n grid: {\n circular: false\n },\n\n startAngle: 0,\n\n // label settings\n ticks: {\n // Boolean - Show a backdrop to the scale label\n showLabelBackdrop: true,\n\n callback: Ticks.formatters.numeric\n },\n\n pointLabels: {\n backdropColor: undefined,\n\n // Number - The backdrop padding above & below the label in pixels\n backdropPadding: 2,\n\n // Boolean - if true, show point labels\n display: true,\n\n // Number - Point label font size in pixels\n font: {\n size: 10\n },\n\n // Function - Used to convert point labels\n callback(label) {\n return label;\n },\n\n // Number - Additionl padding between scale and pointLabel\n padding: 5,\n\n // Boolean - if true, center point labels to slices in polar chart\n centerPointLabels: false\n }\n };\n\n static defaultRoutes = {\n 'angleLines.color': 'borderColor',\n 'pointLabels.color': 'color',\n 'ticks.color': 'color'\n };\n\n static descriptors = {\n angleLines: {\n _fallback: 'grid'\n }\n };\n\n constructor(cfg) {\n super(cfg);\n\n /** @type {number} */\n this.xCenter = undefined;\n /** @type {number} */\n this.yCenter = undefined;\n /** @type {number} */\n this.drawingArea = undefined;\n /** @type {string[]} */\n this._pointLabels = [];\n this._pointLabelItems = [];\n }\n\n setDimensions() {\n // Set the unconstrained dimension before label rotation\n const padding = this._padding = toPadding(getTickBackdropHeight(this.options) / 2);\n const w = this.width = this.maxWidth - padding.width;\n const h = this.height = this.maxHeight - padding.height;\n this.xCenter = Math.floor(this.left + w / 2 + padding.left);\n this.yCenter = Math.floor(this.top + h / 2 + padding.top);\n this.drawingArea = Math.floor(Math.min(w, h) / 2);\n }\n\n determineDataLimits() {\n const {min, max} = this.getMinMax(false);\n\n this.min = isFinite(min) && !isNaN(min) ? min : 0;\n this.max = isFinite(max) && !isNaN(max) ? max : 0;\n\n // Common base implementation to handle min, max, beginAtZero\n this.handleTickRangeOptions();\n }\n\n /**\n\t * Returns the maximum number of ticks based on the scale dimension\n\t * @protected\n\t */\n computeTickLimit() {\n return Math.ceil(this.drawingArea / getTickBackdropHeight(this.options));\n }\n\n generateTickLabels(ticks) {\n LinearScaleBase.prototype.generateTickLabels.call(this, ticks);\n\n // Point labels\n this._pointLabels = this.getLabels()\n .map((value, index) => {\n const label = callCallback(this.options.pointLabels.callback, [value, index], this);\n return label || label === 0 ? label : '';\n })\n .filter((v, i) => this.chart.getDataVisibility(i));\n }\n\n fit() {\n const opts = this.options;\n\n if (opts.display && opts.pointLabels.display) {\n fitWithPointLabels(this);\n } else {\n this.setCenterPoint(0, 0, 0, 0);\n }\n }\n\n setCenterPoint(leftMovement, rightMovement, topMovement, bottomMovement) {\n this.xCenter += Math.floor((leftMovement - rightMovement) / 2);\n this.yCenter += Math.floor((topMovement - bottomMovement) / 2);\n this.drawingArea -= Math.min(this.drawingArea / 2, Math.max(leftMovement, rightMovement, topMovement, bottomMovement));\n }\n\n getIndexAngle(index) {\n const angleMultiplier = TAU / (this._pointLabels.length || 1);\n const startAngle = this.options.startAngle || 0;\n\n return _normalizeAngle(index * angleMultiplier + toRadians(startAngle));\n }\n\n getDistanceFromCenterForValue(value) {\n if (isNullOrUndef(value)) {\n return NaN;\n }\n\n // Take into account half font size + the yPadding of the top value\n const scalingFactor = this.drawingArea / (this.max - this.min);\n if (this.options.reverse) {\n return (this.max - value) * scalingFactor;\n }\n return (value - this.min) * scalingFactor;\n }\n\n getValueForDistanceFromCenter(distance) {\n if (isNullOrUndef(distance)) {\n return NaN;\n }\n\n const scaledDistance = distance / (this.drawingArea / (this.max - this.min));\n return this.options.reverse ? this.max - scaledDistance : this.min + scaledDistance;\n }\n\n getPointLabelContext(index) {\n const pointLabels = this._pointLabels || [];\n\n if (index >= 0 && index < pointLabels.length) {\n const pointLabel = pointLabels[index];\n return createPointLabelContext(this.getContext(), index, pointLabel);\n }\n }\n\n getPointPosition(index, distanceFromCenter, additionalAngle = 0) {\n const angle = this.getIndexAngle(index) - HALF_PI + additionalAngle;\n return {\n x: Math.cos(angle) * distanceFromCenter + this.xCenter,\n y: Math.sin(angle) * distanceFromCenter + this.yCenter,\n angle\n };\n }\n\n getPointPositionForValue(index, value) {\n return this.getPointPosition(index, this.getDistanceFromCenterForValue(value));\n }\n\n getBasePosition(index) {\n return this.getPointPositionForValue(index || 0, this.getBaseValue());\n }\n\n getPointLabelPosition(index) {\n const {left, top, right, bottom} = this._pointLabelItems[index];\n return {\n left,\n top,\n right,\n bottom,\n };\n }\n\n /**\n\t * @protected\n\t */\n drawBackground() {\n const {backgroundColor, grid: {circular}} = this.options;\n if (backgroundColor) {\n const ctx = this.ctx;\n ctx.save();\n ctx.beginPath();\n pathRadiusLine(this, this.getDistanceFromCenterForValue(this._endValue), circular, this._pointLabels.length);\n ctx.closePath();\n ctx.fillStyle = backgroundColor;\n ctx.fill();\n ctx.restore();\n }\n }\n\n /**\n\t * @protected\n\t */\n drawGrid() {\n const ctx = this.ctx;\n const opts = this.options;\n const {angleLines, grid, border} = opts;\n const labelCount = this._pointLabels.length;\n\n let i, offset, position;\n\n if (opts.pointLabels.display) {\n drawPointLabels(this, labelCount);\n }\n\n if (grid.display) {\n this.ticks.forEach((tick, index) => {\n if (index !== 0 || (index === 0 && this.min < 0)) {\n offset = this.getDistanceFromCenterForValue(tick.value);\n const context = this.getContext(index);\n const optsAtIndex = grid.setContext(context);\n const optsAtIndexBorder = border.setContext(context);\n\n drawRadiusLine(this, optsAtIndex, offset, labelCount, optsAtIndexBorder);\n }\n });\n }\n\n if (angleLines.display) {\n ctx.save();\n\n for (i = labelCount - 1; i >= 0; i--) {\n const optsAtIndex = angleLines.setContext(this.getPointLabelContext(i));\n const {color, lineWidth} = optsAtIndex;\n\n if (!lineWidth || !color) {\n continue;\n }\n\n ctx.lineWidth = lineWidth;\n ctx.strokeStyle = color;\n\n ctx.setLineDash(optsAtIndex.borderDash);\n ctx.lineDashOffset = optsAtIndex.borderDashOffset;\n\n offset = this.getDistanceFromCenterForValue(opts.reverse ? this.min : this.max);\n position = this.getPointPosition(i, offset);\n ctx.beginPath();\n ctx.moveTo(this.xCenter, this.yCenter);\n ctx.lineTo(position.x, position.y);\n ctx.stroke();\n }\n\n ctx.restore();\n }\n }\n\n /**\n\t * @protected\n\t */\n drawBorder() {}\n\n /**\n\t * @protected\n\t */\n drawLabels() {\n const ctx = this.ctx;\n const opts = this.options;\n const tickOpts = opts.ticks;\n\n if (!tickOpts.display) {\n return;\n }\n\n const startAngle = this.getIndexAngle(0);\n let offset, width;\n\n ctx.save();\n ctx.translate(this.xCenter, this.yCenter);\n ctx.rotate(startAngle);\n ctx.textAlign = 'center';\n ctx.textBaseline = 'middle';\n\n this.ticks.forEach((tick, index) => {\n if ((index === 0 && this.min >= 0) && !opts.reverse) {\n return;\n }\n\n const optsAtIndex = tickOpts.setContext(this.getContext(index));\n const tickFont = toFont(optsAtIndex.font);\n offset = this.getDistanceFromCenterForValue(this.ticks[index].value);\n\n if (optsAtIndex.showLabelBackdrop) {\n ctx.font = tickFont.string;\n width = ctx.measureText(tick.label).width;\n ctx.fillStyle = optsAtIndex.backdropColor;\n\n const padding = toPadding(optsAtIndex.backdropPadding);\n ctx.fillRect(\n -width / 2 - padding.left,\n -offset - tickFont.size / 2 - padding.top,\n width + padding.width,\n tickFont.size + padding.height\n );\n }\n\n renderText(ctx, tick.label, 0, -offset, tickFont, {\n color: optsAtIndex.color,\n strokeColor: optsAtIndex.textStrokeColor,\n strokeWidth: optsAtIndex.textStrokeWidth,\n });\n });\n\n ctx.restore();\n }\n\n /**\n\t * @protected\n\t */\n drawTitle() {}\n}\n","import adapters from '../core/core.adapters.js';\nimport {callback as call, isFinite, isNullOrUndef, mergeIf, valueOrDefault} from '../helpers/helpers.core.js';\nimport {toRadians, isNumber, _limitValue} from '../helpers/helpers.math.js';\nimport Scale from '../core/core.scale.js';\nimport {_arrayUnique, _filterBetween, _lookup} from '../helpers/helpers.collection.js';\n\n/**\n * @typedef { import('../core/core.adapters.js').TimeUnit } Unit\n * @typedef {{common: boolean, size: number, steps?: number}} Interval\n * @typedef { import('../core/core.adapters.js').DateAdapter } DateAdapter\n */\n\n/**\n * @type {Object}\n */\nconst INTERVALS = {\n millisecond: {common: true, size: 1, steps: 1000},\n second: {common: true, size: 1000, steps: 60},\n minute: {common: true, size: 60000, steps: 60},\n hour: {common: true, size: 3600000, steps: 24},\n day: {common: true, size: 86400000, steps: 30},\n week: {common: false, size: 604800000, steps: 4},\n month: {common: true, size: 2.628e9, steps: 12},\n quarter: {common: false, size: 7.884e9, steps: 4},\n year: {common: true, size: 3.154e10}\n};\n\n/**\n * @type {Unit[]}\n */\nconst UNITS = /** @type Unit[] */ /* #__PURE__ */ (Object.keys(INTERVALS));\n\n/**\n * @param {number} a\n * @param {number} b\n */\nfunction sorter(a, b) {\n return a - b;\n}\n\n/**\n * @param {TimeScale} scale\n * @param {*} input\n * @return {number}\n */\nfunction parse(scale, input) {\n if (isNullOrUndef(input)) {\n return null;\n }\n\n const adapter = scale._adapter;\n const {parser, round, isoWeekday} = scale._parseOpts;\n let value = input;\n\n if (typeof parser === 'function') {\n value = parser(value);\n }\n\n // Only parse if it's not a timestamp already\n if (!isFinite(value)) {\n value = typeof parser === 'string'\n ? adapter.parse(value, parser)\n : adapter.parse(value);\n }\n\n if (value === null) {\n return null;\n }\n\n if (round) {\n value = round === 'week' && (isNumber(isoWeekday) || isoWeekday === true)\n ? adapter.startOf(value, 'isoWeek', isoWeekday)\n : adapter.startOf(value, round);\n }\n\n return +value;\n}\n\n/**\n * Figures out what unit results in an appropriate number of auto-generated ticks\n * @param {Unit} minUnit\n * @param {number} min\n * @param {number} max\n * @param {number} capacity\n * @return {object}\n */\nfunction determineUnitForAutoTicks(minUnit, min, max, capacity) {\n const ilen = UNITS.length;\n\n for (let i = UNITS.indexOf(minUnit); i < ilen - 1; ++i) {\n const interval = INTERVALS[UNITS[i]];\n const factor = interval.steps ? interval.steps : Number.MAX_SAFE_INTEGER;\n\n if (interval.common && Math.ceil((max - min) / (factor * interval.size)) <= capacity) {\n return UNITS[i];\n }\n }\n\n return UNITS[ilen - 1];\n}\n\n/**\n * Figures out what unit to format a set of ticks with\n * @param {TimeScale} scale\n * @param {number} numTicks\n * @param {Unit} minUnit\n * @param {number} min\n * @param {number} max\n * @return {Unit}\n */\nfunction determineUnitForFormatting(scale, numTicks, minUnit, min, max) {\n for (let i = UNITS.length - 1; i >= UNITS.indexOf(minUnit); i--) {\n const unit = UNITS[i];\n if (INTERVALS[unit].common && scale._adapter.diff(max, min, unit) >= numTicks - 1) {\n return unit;\n }\n }\n\n return UNITS[minUnit ? UNITS.indexOf(minUnit) : 0];\n}\n\n/**\n * @param {Unit} unit\n * @return {object}\n */\nfunction determineMajorUnit(unit) {\n for (let i = UNITS.indexOf(unit) + 1, ilen = UNITS.length; i < ilen; ++i) {\n if (INTERVALS[UNITS[i]].common) {\n return UNITS[i];\n }\n }\n}\n\n/**\n * @param {object} ticks\n * @param {number} time\n * @param {number[]} [timestamps] - if defined, snap to these timestamps\n */\nfunction addTick(ticks, time, timestamps) {\n if (!timestamps) {\n ticks[time] = true;\n } else if (timestamps.length) {\n const {lo, hi} = _lookup(timestamps, time);\n const timestamp = timestamps[lo] >= time ? timestamps[lo] : timestamps[hi];\n ticks[timestamp] = true;\n }\n}\n\n/**\n * @param {TimeScale} scale\n * @param {object[]} ticks\n * @param {object} map\n * @param {Unit} majorUnit\n * @return {object[]}\n */\nfunction setMajorTicks(scale, ticks, map, majorUnit) {\n const adapter = scale._adapter;\n const first = +adapter.startOf(ticks[0].value, majorUnit);\n const last = ticks[ticks.length - 1].value;\n let major, index;\n\n for (major = first; major <= last; major = +adapter.add(major, 1, majorUnit)) {\n index = map[major];\n if (index >= 0) {\n ticks[index].major = true;\n }\n }\n return ticks;\n}\n\n/**\n * @param {TimeScale} scale\n * @param {number[]} values\n * @param {Unit|undefined} [majorUnit]\n * @return {object[]}\n */\nfunction ticksFromTimestamps(scale, values, majorUnit) {\n const ticks = [];\n /** @type {Object} */\n const map = {};\n const ilen = values.length;\n let i, value;\n\n for (i = 0; i < ilen; ++i) {\n value = values[i];\n map[value] = i;\n\n ticks.push({\n value,\n major: false\n });\n }\n\n // We set the major ticks separately from the above loop because calling startOf for every tick\n // is expensive when there is a large number of ticks\n return (ilen === 0 || !majorUnit) ? ticks : setMajorTicks(scale, ticks, map, majorUnit);\n}\n\nexport default class TimeScale extends Scale {\n\n static id = 'time';\n\n /**\n * @type {any}\n */\n static defaults = {\n /**\n * Scale boundary strategy (bypassed by min/max time options)\n * - `data`: make sure data are fully visible, ticks outside are removed\n * - `ticks`: make sure ticks are fully visible, data outside are truncated\n * @see https://github.com/chartjs/Chart.js/pull/4556\n * @since 2.7.0\n */\n bounds: 'data',\n\n adapters: {},\n time: {\n parser: false, // false == a pattern string from or a custom callback that converts its argument to a timestamp\n unit: false, // false == automatic or override with week, month, year, etc.\n round: false, // none, or override with week, month, year, etc.\n isoWeekday: false, // override week start day\n minUnit: 'millisecond',\n displayFormats: {}\n },\n ticks: {\n /**\n * Ticks generation input values:\n * - 'auto': generates \"optimal\" ticks based on scale size and time options.\n * - 'data': generates ticks from data (including labels from data {t|x|y} objects).\n * - 'labels': generates ticks from user given `data.labels` values ONLY.\n * @see https://github.com/chartjs/Chart.js/pull/4507\n * @since 2.7.0\n */\n source: 'auto',\n\n callback: false,\n\n major: {\n enabled: false\n }\n }\n };\n\n /**\n\t * @param {object} props\n\t */\n constructor(props) {\n super(props);\n\n /** @type {{data: number[], labels: number[], all: number[]}} */\n this._cache = {\n data: [],\n labels: [],\n all: []\n };\n\n /** @type {Unit} */\n this._unit = 'day';\n /** @type {Unit=} */\n this._majorUnit = undefined;\n this._offsets = {};\n this._normalized = false;\n this._parseOpts = undefined;\n }\n\n init(scaleOpts, opts = {}) {\n const time = scaleOpts.time || (scaleOpts.time = {});\n /** @type {DateAdapter} */\n const adapter = this._adapter = new adapters._date(scaleOpts.adapters.date);\n\n adapter.init(opts);\n\n // Backward compatibility: before introducing adapter, `displayFormats` was\n // supposed to contain *all* unit/string pairs but this can't be resolved\n // when loading the scale (adapters are loaded afterward), so let's populate\n // missing formats on update\n mergeIf(time.displayFormats, adapter.formats());\n\n this._parseOpts = {\n parser: time.parser,\n round: time.round,\n isoWeekday: time.isoWeekday\n };\n\n super.init(scaleOpts);\n\n this._normalized = opts.normalized;\n }\n\n /**\n\t * @param {*} raw\n\t * @param {number?} [index]\n\t * @return {number}\n\t */\n parse(raw, index) { // eslint-disable-line no-unused-vars\n if (raw === undefined) {\n return null;\n }\n return parse(this, raw);\n }\n\n beforeLayout() {\n super.beforeLayout();\n this._cache = {\n data: [],\n labels: [],\n all: []\n };\n }\n\n determineDataLimits() {\n const options = this.options;\n const adapter = this._adapter;\n const unit = options.time.unit || 'day';\n // eslint-disable-next-line prefer-const\n let {min, max, minDefined, maxDefined} = this.getUserBounds();\n\n /**\n\t\t * @param {object} bounds\n\t\t */\n function _applyBounds(bounds) {\n if (!minDefined && !isNaN(bounds.min)) {\n min = Math.min(min, bounds.min);\n }\n if (!maxDefined && !isNaN(bounds.max)) {\n max = Math.max(max, bounds.max);\n }\n }\n\n // If we have user provided `min` and `max` labels / data bounds can be ignored\n if (!minDefined || !maxDefined) {\n // Labels are always considered, when user did not force bounds\n _applyBounds(this._getLabelBounds());\n\n // If `bounds` is `'ticks'` and `ticks.source` is `'labels'`,\n // data bounds are ignored (and don't need to be determined)\n if (options.bounds !== 'ticks' || options.ticks.source !== 'labels') {\n _applyBounds(this.getMinMax(false));\n }\n }\n\n min = isFinite(min) && !isNaN(min) ? min : +adapter.startOf(Date.now(), unit);\n max = isFinite(max) && !isNaN(max) ? max : +adapter.endOf(Date.now(), unit) + 1;\n\n // Make sure that max is strictly higher than min (required by the timeseries lookup table)\n this.min = Math.min(min, max - 1);\n this.max = Math.max(min + 1, max);\n }\n\n /**\n\t * @private\n\t */\n _getLabelBounds() {\n const arr = this.getLabelTimestamps();\n let min = Number.POSITIVE_INFINITY;\n let max = Number.NEGATIVE_INFINITY;\n\n if (arr.length) {\n min = arr[0];\n max = arr[arr.length - 1];\n }\n return {min, max};\n }\n\n /**\n\t * @return {object[]}\n\t */\n buildTicks() {\n const options = this.options;\n const timeOpts = options.time;\n const tickOpts = options.ticks;\n const timestamps = tickOpts.source === 'labels' ? this.getLabelTimestamps() : this._generate();\n\n if (options.bounds === 'ticks' && timestamps.length) {\n this.min = this._userMin || timestamps[0];\n this.max = this._userMax || timestamps[timestamps.length - 1];\n }\n\n const min = this.min;\n const max = this.max;\n\n const ticks = _filterBetween(timestamps, min, max);\n\n // PRIVATE\n // determineUnitForFormatting relies on the number of ticks so we don't use it when\n // autoSkip is enabled because we don't yet know what the final number of ticks will be\n this._unit = timeOpts.unit || (tickOpts.autoSkip\n ? determineUnitForAutoTicks(timeOpts.minUnit, this.min, this.max, this._getLabelCapacity(min))\n : determineUnitForFormatting(this, ticks.length, timeOpts.minUnit, this.min, this.max));\n this._majorUnit = !tickOpts.major.enabled || this._unit === 'year' ? undefined\n : determineMajorUnit(this._unit);\n this.initOffsets(timestamps);\n\n if (options.reverse) {\n ticks.reverse();\n }\n\n return ticksFromTimestamps(this, ticks, this._majorUnit);\n }\n\n afterAutoSkip() {\n // Offsets for bar charts need to be handled with the auto skipped\n // ticks. Once ticks have been skipped, we re-compute the offsets.\n if (this.options.offsetAfterAutoskip) {\n this.initOffsets(this.ticks.map(tick => +tick.value));\n }\n }\n\n /**\n\t * Returns the start and end offsets from edges in the form of {start, end}\n\t * where each value is a relative width to the scale and ranges between 0 and 1.\n\t * They add extra margins on the both sides by scaling down the original scale.\n\t * Offsets are added when the `offset` option is true.\n\t * @param {number[]} timestamps\n\t * @protected\n\t */\n initOffsets(timestamps = []) {\n let start = 0;\n let end = 0;\n let first, last;\n\n if (this.options.offset && timestamps.length) {\n first = this.getDecimalForValue(timestamps[0]);\n if (timestamps.length === 1) {\n start = 1 - first;\n } else {\n start = (this.getDecimalForValue(timestamps[1]) - first) / 2;\n }\n last = this.getDecimalForValue(timestamps[timestamps.length - 1]);\n if (timestamps.length === 1) {\n end = last;\n } else {\n end = (last - this.getDecimalForValue(timestamps[timestamps.length - 2])) / 2;\n }\n }\n const limit = timestamps.length < 3 ? 0.5 : 0.25;\n start = _limitValue(start, 0, limit);\n end = _limitValue(end, 0, limit);\n\n this._offsets = {start, end, factor: 1 / (start + 1 + end)};\n }\n\n /**\n\t * Generates a maximum of `capacity` timestamps between min and max, rounded to the\n\t * `minor` unit using the given scale time `options`.\n\t * Important: this method can return ticks outside the min and max range, it's the\n\t * responsibility of the calling code to clamp values if needed.\n\t * @protected\n\t */\n _generate() {\n const adapter = this._adapter;\n const min = this.min;\n const max = this.max;\n const options = this.options;\n const timeOpts = options.time;\n // @ts-ignore\n const minor = timeOpts.unit || determineUnitForAutoTicks(timeOpts.minUnit, min, max, this._getLabelCapacity(min));\n const stepSize = valueOrDefault(options.ticks.stepSize, 1);\n const weekday = minor === 'week' ? timeOpts.isoWeekday : false;\n const hasWeekday = isNumber(weekday) || weekday === true;\n const ticks = {};\n let first = min;\n let time, count;\n\n // For 'week' unit, handle the first day of week option\n if (hasWeekday) {\n first = +adapter.startOf(first, 'isoWeek', weekday);\n }\n\n // Align first ticks on unit\n first = +adapter.startOf(first, hasWeekday ? 'day' : minor);\n\n // Prevent browser from freezing in case user options request millions of milliseconds\n if (adapter.diff(max, min, minor) > 100000 * stepSize) {\n throw new Error(min + ' and ' + max + ' are too far apart with stepSize of ' + stepSize + ' ' + minor);\n }\n\n const timestamps = options.ticks.source === 'data' && this.getDataTimestamps();\n for (time = first, count = 0; time < max; time = +adapter.add(time, stepSize, minor), count++) {\n addTick(ticks, time, timestamps);\n }\n\n if (time === max || options.bounds === 'ticks' || count === 1) {\n addTick(ticks, time, timestamps);\n }\n\n // @ts-ignore\n return Object.keys(ticks).sort(sorter).map(x => +x);\n }\n\n /**\n\t * @param {number} value\n\t * @return {string}\n\t */\n getLabelForValue(value) {\n const adapter = this._adapter;\n const timeOpts = this.options.time;\n\n if (timeOpts.tooltipFormat) {\n return adapter.format(value, timeOpts.tooltipFormat);\n }\n return adapter.format(value, timeOpts.displayFormats.datetime);\n }\n\n /**\n\t * @param {number} value\n\t * @param {string|undefined} format\n\t * @return {string}\n\t */\n format(value, format) {\n const options = this.options;\n const formats = options.time.displayFormats;\n const unit = this._unit;\n const fmt = format || formats[unit];\n return this._adapter.format(value, fmt);\n }\n\n /**\n\t * Function to format an individual tick mark\n\t * @param {number} time\n\t * @param {number} index\n\t * @param {object[]} ticks\n\t * @param {string|undefined} [format]\n\t * @return {string}\n\t * @private\n\t */\n _tickFormatFunction(time, index, ticks, format) {\n const options = this.options;\n const formatter = options.ticks.callback;\n\n if (formatter) {\n return call(formatter, [time, index, ticks], this);\n }\n\n const formats = options.time.displayFormats;\n const unit = this._unit;\n const majorUnit = this._majorUnit;\n const minorFormat = unit && formats[unit];\n const majorFormat = majorUnit && formats[majorUnit];\n const tick = ticks[index];\n const major = majorUnit && majorFormat && tick && tick.major;\n\n return this._adapter.format(time, format || (major ? majorFormat : minorFormat));\n }\n\n /**\n\t * @param {object[]} ticks\n\t */\n generateTickLabels(ticks) {\n let i, ilen, tick;\n\n for (i = 0, ilen = ticks.length; i < ilen; ++i) {\n tick = ticks[i];\n tick.label = this._tickFormatFunction(tick.value, i, ticks);\n }\n }\n\n /**\n\t * @param {number} value - Milliseconds since epoch (1 January 1970 00:00:00 UTC)\n\t * @return {number}\n\t */\n getDecimalForValue(value) {\n return value === null ? NaN : (value - this.min) / (this.max - this.min);\n }\n\n /**\n\t * @param {number} value - Milliseconds since epoch (1 January 1970 00:00:00 UTC)\n\t * @return {number}\n\t */\n getPixelForValue(value) {\n const offsets = this._offsets;\n const pos = this.getDecimalForValue(value);\n return this.getPixelForDecimal((offsets.start + pos) * offsets.factor);\n }\n\n /**\n\t * @param {number} pixel\n\t * @return {number}\n\t */\n getValueForPixel(pixel) {\n const offsets = this._offsets;\n const pos = this.getDecimalForPixel(pixel) / offsets.factor - offsets.end;\n return this.min + pos * (this.max - this.min);\n }\n\n /**\n\t * @param {string} label\n\t * @return {{w:number, h:number}}\n\t * @private\n\t */\n _getLabelSize(label) {\n const ticksOpts = this.options.ticks;\n const tickLabelWidth = this.ctx.measureText(label).width;\n const angle = toRadians(this.isHorizontal() ? ticksOpts.maxRotation : ticksOpts.minRotation);\n const cosRotation = Math.cos(angle);\n const sinRotation = Math.sin(angle);\n const tickFontSize = this._resolveTickFontOptions(0).size;\n\n return {\n w: (tickLabelWidth * cosRotation) + (tickFontSize * sinRotation),\n h: (tickLabelWidth * sinRotation) + (tickFontSize * cosRotation)\n };\n }\n\n /**\n\t * @param {number} exampleTime\n\t * @return {number}\n\t * @private\n\t */\n _getLabelCapacity(exampleTime) {\n const timeOpts = this.options.time;\n const displayFormats = timeOpts.displayFormats;\n\n // pick the longest format (milliseconds) for guesstimation\n const format = displayFormats[timeOpts.unit] || displayFormats.millisecond;\n const exampleLabel = this._tickFormatFunction(exampleTime, 0, ticksFromTimestamps(this, [exampleTime], this._majorUnit), format);\n const size = this._getLabelSize(exampleLabel);\n // subtract 1 - if offset then there's one less label than tick\n // if not offset then one half label padding is added to each end leaving room for one less label\n const capacity = Math.floor(this.isHorizontal() ? this.width / size.w : this.height / size.h) - 1;\n return capacity > 0 ? capacity : 1;\n }\n\n /**\n\t * @protected\n\t */\n getDataTimestamps() {\n let timestamps = this._cache.data || [];\n let i, ilen;\n\n if (timestamps.length) {\n return timestamps;\n }\n\n const metas = this.getMatchingVisibleMetas();\n\n if (this._normalized && metas.length) {\n return (this._cache.data = metas[0].controller.getAllParsedValues(this));\n }\n\n for (i = 0, ilen = metas.length; i < ilen; ++i) {\n timestamps = timestamps.concat(metas[i].controller.getAllParsedValues(this));\n }\n\n return (this._cache.data = this.normalize(timestamps));\n }\n\n /**\n\t * @protected\n\t */\n getLabelTimestamps() {\n const timestamps = this._cache.labels || [];\n let i, ilen;\n\n if (timestamps.length) {\n return timestamps;\n }\n\n const labels = this.getLabels();\n for (i = 0, ilen = labels.length; i < ilen; ++i) {\n timestamps.push(parse(this, labels[i]));\n }\n\n return (this._cache.labels = this._normalized ? timestamps : this.normalize(timestamps));\n }\n\n /**\n\t * @param {number[]} values\n\t * @protected\n\t */\n normalize(values) {\n // It seems to be somewhat faster to do sorting first\n return _arrayUnique(values.sort(sorter));\n }\n}\n","import TimeScale from './scale.time.js';\nimport {_lookupByKey} from '../helpers/helpers.collection.js';\n\n/**\n * Linearly interpolates the given source `val` using the table. If value is out of bounds, values\n * at edges are used for the interpolation.\n * @param {object} table\n * @param {number} val\n * @param {boolean} [reverse] lookup time based on position instead of vice versa\n * @return {object}\n */\nfunction interpolate(table, val, reverse) {\n let lo = 0;\n let hi = table.length - 1;\n let prevSource, nextSource, prevTarget, nextTarget;\n if (reverse) {\n if (val >= table[lo].pos && val <= table[hi].pos) {\n ({lo, hi} = _lookupByKey(table, 'pos', val));\n }\n ({pos: prevSource, time: prevTarget} = table[lo]);\n ({pos: nextSource, time: nextTarget} = table[hi]);\n } else {\n if (val >= table[lo].time && val <= table[hi].time) {\n ({lo, hi} = _lookupByKey(table, 'time', val));\n }\n ({time: prevSource, pos: prevTarget} = table[lo]);\n ({time: nextSource, pos: nextTarget} = table[hi]);\n }\n\n const span = nextSource - prevSource;\n return span ? prevTarget + (nextTarget - prevTarget) * (val - prevSource) / span : prevTarget;\n}\n\nclass TimeSeriesScale extends TimeScale {\n\n static id = 'timeseries';\n\n /**\n * @type {any}\n */\n static defaults = TimeScale.defaults;\n\n /**\n\t * @param {object} props\n\t */\n constructor(props) {\n super(props);\n\n /** @type {object[]} */\n this._table = [];\n /** @type {number} */\n this._minPos = undefined;\n /** @type {number} */\n this._tableRange = undefined;\n }\n\n /**\n\t * @protected\n\t */\n initOffsets() {\n const timestamps = this._getTimestampsForTable();\n const table = this._table = this.buildLookupTable(timestamps);\n this._minPos = interpolate(table, this.min);\n this._tableRange = interpolate(table, this.max) - this._minPos;\n super.initOffsets(timestamps);\n }\n\n /**\n\t * Returns an array of {time, pos} objects used to interpolate a specific `time` or position\n\t * (`pos`) on the scale, by searching entries before and after the requested value. `pos` is\n\t * a decimal between 0 and 1: 0 being the start of the scale (left or top) and 1 the other\n\t * extremity (left + width or top + height). Note that it would be more optimized to directly\n\t * store pre-computed pixels, but the scale dimensions are not guaranteed at the time we need\n\t * to create the lookup table. The table ALWAYS contains at least two items: min and max.\n\t * @param {number[]} timestamps\n\t * @return {object[]}\n\t * @protected\n\t */\n buildLookupTable(timestamps) {\n const {min, max} = this;\n const items = [];\n const table = [];\n let i, ilen, prev, curr, next;\n\n for (i = 0, ilen = timestamps.length; i < ilen; ++i) {\n curr = timestamps[i];\n if (curr >= min && curr <= max) {\n items.push(curr);\n }\n }\n\n if (items.length < 2) {\n // In case there is less that 2 timestamps between min and max, the scale is defined by min and max\n return [\n {time: min, pos: 0},\n {time: max, pos: 1}\n ];\n }\n\n for (i = 0, ilen = items.length; i < ilen; ++i) {\n next = items[i + 1];\n prev = items[i - 1];\n curr = items[i];\n\n // only add points that breaks the scale linearity\n if (Math.round((next + prev) / 2) !== curr) {\n table.push({time: curr, pos: i / (ilen - 1)});\n }\n }\n return table;\n }\n\n /**\n * Generates all timestamps defined in the data.\n * Important: this method can return ticks outside the min and max range, it's the\n * responsibility of the calling code to clamp values if needed.\n * @protected\n */\n _generate() {\n const min = this.min;\n const max = this.max;\n let timestamps = super.getDataTimestamps();\n if (!timestamps.includes(min) || !timestamps.length) {\n timestamps.splice(0, 0, min);\n }\n if (!timestamps.includes(max) || timestamps.length === 1) {\n timestamps.push(max);\n }\n return timestamps.sort((a, b) => a - b);\n }\n\n /**\n\t * Returns all timestamps\n\t * @return {number[]}\n\t * @private\n\t */\n _getTimestampsForTable() {\n let timestamps = this._cache.all || [];\n\n if (timestamps.length) {\n return timestamps;\n }\n\n const data = this.getDataTimestamps();\n const label = this.getLabelTimestamps();\n if (data.length && label.length) {\n // If combining labels and data (data might not contain all labels),\n // we need to recheck uniqueness and sort\n timestamps = this.normalize(data.concat(label));\n } else {\n timestamps = data.length ? data : label;\n }\n timestamps = this._cache.all = timestamps;\n\n return timestamps;\n }\n\n /**\n\t * @param {number} value - Milliseconds since epoch (1 January 1970 00:00:00 UTC)\n\t * @return {number}\n\t */\n getDecimalForValue(value) {\n return (interpolate(this._table, value) - this._minPos) / this._tableRange;\n }\n\n /**\n\t * @param {number} pixel\n\t * @return {number}\n\t */\n getValueForPixel(pixel) {\n const offsets = this._offsets;\n const decimal = this.getDecimalForPixel(pixel) / offsets.factor - offsets.end;\n return interpolate(this._table, decimal * this._tableRange + this._minPos, true);\n }\n}\n\nexport default TimeSeriesScale;\n","import type { PropType } from 'vue'\nimport type {\n ChartType,\n ChartData,\n ChartOptions,\n Plugin,\n UpdateMode\n} from 'chart.js'\n\nexport const CommonProps = {\n data: {\n type: Object as PropType,\n required: true\n },\n options: {\n type: Object as PropType,\n default: () => ({})\n },\n plugins: {\n type: Array as PropType,\n default: () => []\n },\n datasetIdKey: {\n type: String,\n default: 'label'\n },\n updateMode: {\n type: String as PropType,\n default: undefined\n }\n} as const\n\nexport const A11yProps = {\n ariaLabel: {\n type: String\n },\n ariaDescribedby: {\n type: String\n }\n} as const\n\nexport const Props = {\n type: {\n type: String as PropType,\n required: true\n },\n destroyDelay: {\n type: Number,\n default: 0 // No delay by default\n },\n ...CommonProps,\n ...A11yProps\n} as const\n","import { isProxy, toRaw, version } from 'vue'\nimport type {\n Chart,\n ChartType,\n ChartData,\n ChartDataset,\n ChartOptions,\n DefaultDataPoint\n} from 'chart.js'\n\nexport const compatProps =\n version[0] === '2'\n ? (internals: I, props: T) =>\n Object.assign(internals, { attrs: props }) as unknown as I & T\n : (internals: I, props: T) =>\n Object.assign(internals, props)\n\nexport function toRawIfProxy(obj: T) {\n return isProxy(obj) ? toRaw(obj) : obj\n}\n\nexport function cloneProxy(obj: T, src = obj) {\n return isProxy(src) ? new Proxy(obj, {}) : obj\n}\n\nexport function setOptions<\n TType extends ChartType = ChartType,\n TData = DefaultDataPoint,\n TLabel = unknown\n>(chart: Chart, nextOptions: ChartOptions) {\n const options = chart.options\n\n if (options && nextOptions) {\n Object.assign(options, nextOptions)\n }\n}\n\nexport function setLabels<\n TType extends ChartType = ChartType,\n TData = DefaultDataPoint,\n TLabel = unknown\n>(\n currentData: ChartData,\n nextLabels: TLabel[] | undefined\n) {\n currentData.labels = nextLabels\n}\n\nexport function setDatasets<\n TType extends ChartType = ChartType,\n TData = DefaultDataPoint,\n TLabel = unknown\n>(\n currentData: ChartData,\n nextDatasets: ChartDataset[],\n datasetIdKey: string\n) {\n const addedDatasets: ChartDataset[] = []\n\n currentData.datasets = nextDatasets.map(\n (nextDataset: Record) => {\n // given the new set, find it's current match\n const currentDataset = currentData.datasets.find(\n (dataset: Record) =>\n dataset[datasetIdKey] === nextDataset[datasetIdKey]\n )\n\n // There is no original to update, so simply add new one\n if (\n !currentDataset ||\n !nextDataset.data ||\n addedDatasets.includes(currentDataset)\n ) {\n return { ...nextDataset } as ChartDataset\n }\n\n addedDatasets.push(currentDataset)\n\n Object.assign(currentDataset, nextDataset)\n\n return currentDataset\n }\n )\n}\n\nexport function cloneData<\n TType extends ChartType = ChartType,\n TData = DefaultDataPoint,\n TLabel = unknown\n>(data: ChartData, datasetIdKey: string) {\n const nextData: ChartData = {\n labels: [],\n datasets: []\n }\n\n setLabels(nextData, data.labels)\n setDatasets(nextData, data.datasets, datasetIdKey)\n\n return nextData\n}\n\n/**\n * Get dataset from mouse click event\n * @param chart - Chart.js instance\n * @param event - Mouse click event\n * @returns Dataset\n */\nexport function getDatasetAtEvent(chart: Chart, event: MouseEvent) {\n return chart.getElementsAtEventForMode(\n event,\n 'dataset',\n { intersect: true },\n false\n )\n}\n\n/**\n * Get single dataset element from mouse click event\n * @param chart - Chart.js instance\n * @param event - Mouse click event\n * @returns Dataset\n */\nexport function getElementAtEvent(chart: Chart, event: MouseEvent) {\n return chart.getElementsAtEventForMode(\n event,\n 'nearest',\n { intersect: true },\n false\n )\n}\n\n/**\n * Get all dataset elements from mouse click event\n * @param chart - Chart.js instance\n * @param event - Mouse click event\n * @returns Dataset\n */\nexport function getElementsAtEvent(chart: Chart, event: MouseEvent) {\n return chart.getElementsAtEventForMode(\n event,\n 'index',\n { intersect: true },\n false\n )\n}\n","import { Chart as ChartJS } from 'chart.js'\nimport {\n defineComponent,\n h,\n nextTick,\n onUnmounted,\n onMounted,\n ref,\n shallowRef,\n toRaw,\n watch\n} from 'vue'\n\nimport type { ChartComponent } from './types.js'\nimport { Props } from './props.js'\nimport {\n cloneData,\n setLabels,\n setDatasets,\n setOptions,\n toRawIfProxy,\n cloneProxy\n} from './utils.js'\n\nexport const Chart = defineComponent({\n props: Props,\n setup(props, { expose, slots }) {\n const canvasRef = ref(null)\n const chartRef = shallowRef(null)\n\n expose({ chart: chartRef })\n\n const renderChart = () => {\n if (!canvasRef.value) return\n\n const { type, data, options, plugins, datasetIdKey } = props\n const clonedData = cloneData(data, datasetIdKey)\n const proxiedData = cloneProxy(clonedData, data)\n\n chartRef.value = new ChartJS(canvasRef.value, {\n type,\n data: proxiedData,\n options: { ...options },\n plugins\n })\n }\n\n const destroyChart = () => {\n const chart = toRaw(chartRef.value)\n\n if (chart) {\n if (props.destroyDelay > 0) {\n setTimeout(() => {\n chart.destroy()\n chartRef.value = null\n }, props.destroyDelay)\n } else {\n chart.destroy()\n chartRef.value = null\n }\n }\n }\n\n const update = (chart: ChartJS) => {\n chart.update(props.updateMode)\n }\n\n onMounted(renderChart)\n\n onUnmounted(destroyChart)\n\n watch(\n [() => props.options, () => props.data],\n (\n [nextOptionsProxy, nextDataProxy],\n [prevOptionsProxy, prevDataProxy]\n ) => {\n const chart = toRaw(chartRef.value)\n\n if (!chart) {\n return\n }\n\n let shouldUpdate = false\n\n if (nextOptionsProxy) {\n const nextOptions = toRawIfProxy(nextOptionsProxy)\n const prevOptions = toRawIfProxy(prevOptionsProxy)\n\n if (nextOptions && nextOptions !== prevOptions) {\n setOptions(chart, nextOptions)\n shouldUpdate = true\n }\n }\n\n if (nextDataProxy) {\n const nextLabels = toRawIfProxy(nextDataProxy.labels)\n const prevLabels = toRawIfProxy(prevDataProxy.labels)\n const nextDatasets = toRawIfProxy(nextDataProxy.datasets)\n const prevDatasets = toRawIfProxy(prevDataProxy.datasets)\n\n if (nextLabels !== prevLabels) {\n setLabels(chart.config.data, nextLabels)\n shouldUpdate = true\n }\n\n if (nextDatasets && nextDatasets !== prevDatasets) {\n setDatasets(chart.config.data, nextDatasets, props.datasetIdKey)\n shouldUpdate = true\n }\n }\n\n if (shouldUpdate) {\n nextTick(() => {\n update(chart)\n })\n }\n },\n { deep: true }\n )\n\n return () => {\n return h(\n 'canvas',\n {\n role: 'img',\n 'aria-label': props.ariaLabel,\n 'aria-describedby': props.ariaDescribedby,\n ref: canvasRef\n },\n [h('p', {}, [slots.default ? slots.default() : ''])]\n )\n }\n }\n}) as ChartComponent\n","import { defineComponent, shallowRef, h } from 'vue'\nimport type { ChartType, ChartComponentLike, DefaultDataPoint } from 'chart.js'\nimport {\n Chart as ChartJS,\n BarController,\n BubbleController,\n DoughnutController,\n LineController,\n PieController,\n PolarAreaController,\n RadarController,\n ScatterController\n} from 'chart.js'\nimport type { DistributiveArray } from 'chart.js/dist/types/utils'\nimport type { TypedChartComponent, ChartComponentRef } from './types.js'\nimport { CommonProps } from './props.js'\nimport { Chart } from './chart.js'\nimport { compatProps } from './utils.js'\n\nexport function createTypedChart<\n TType extends ChartType = ChartType,\n TData = DefaultDataPoint,\n TLabel = unknown\n>(\n type: TType,\n registerables: ChartComponentLike\n): TypedChartComponent {\n ChartJS.register(registerables)\n\n return defineComponent({\n props: CommonProps,\n setup(props, { expose }) {\n const ref = shallowRef(null)\n const reforwardRef = (chartRef: ChartComponentRef) => {\n ref.value = chartRef?.chart\n }\n\n expose({ chart: ref })\n\n return () => {\n return h(\n Chart,\n compatProps(\n {\n ref: reforwardRef as any\n },\n {\n type,\n ...props\n }\n )\n )\n }\n }\n }) as any\n}\n\nexport interface ExtendedDataPoint {\n [key: string]: string | number | null | ExtendedDataPoint\n}\n\nexport const Bar = /* #__PURE__ */ createTypedChart<\n 'bar',\n DefaultDataPoint<'bar'> | DistributiveArray\n>('bar', BarController)\n\nexport const Doughnut = /* #__PURE__ */ createTypedChart(\n 'doughnut',\n DoughnutController\n)\n\nexport const Line = /* #__PURE__ */ createTypedChart('line', LineController)\n\nexport const Pie = /* #__PURE__ */ createTypedChart('pie', PieController)\n\nexport const PolarArea = /* #__PURE__ */ createTypedChart(\n 'polarArea',\n PolarAreaController\n)\n\nexport const Radar = /* #__PURE__ */ createTypedChart('radar', RadarController)\n\nexport const Bubble = /* #__PURE__ */ createTypedChart(\n 'bubble',\n BubbleController\n)\n\nexport const Scatter = /* #__PURE__ */ createTypedChart(\n 'scatter',\n ScatterController\n)\n","/**\r\n * BatchProcessor - 批量数据处理类\r\n * \r\n * 处理批量数据获取和处理的核心类,使用 cursor 分页机制获取所有数据。\r\n * 支持进度回调和取消功能。\r\n */\r\n\r\nimport fetchWithAuth from '@/utils/fetchWithAuth';\r\n\r\n/**\r\n * 批量操作错误类\r\n * 提供错误代码、是否可恢复、建议操作等信息\r\n */\r\nexport class BatchOperationError extends Error {\r\n constructor(message, code, recoverable = false, suggestion = '') {\r\n super(message);\r\n this.name = 'BatchOperationError';\r\n this.code = code;\r\n this.recoverable = recoverable;\r\n this.suggestion = suggestion;\r\n }\r\n}\r\n\r\n/**\r\n * 错误处理器映射\r\n * 根据 HTTP 状态码返回对应的错误对象\r\n */\r\nconst ERROR_HANDLERS = {\r\n 401: () => new BatchOperationError(\r\n '认证失败,请重新登录',\r\n 'AUTH_FAILED',\r\n false,\r\n '请刷新页面并重新登录'\r\n ),\r\n 403: () => new BatchOperationError(\r\n '权限不足或请求被拒绝',\r\n 'FORBIDDEN',\r\n false,\r\n '请确认您有管理员权限'\r\n ),\r\n 400: (details) => new BatchOperationError(\r\n `请求数据无效: ${details}`,\r\n 'INVALID_DATA',\r\n true,\r\n '请检查数据格式后重试'\r\n ),\r\n 500: () => new BatchOperationError(\r\n '服务器内部错误',\r\n 'SERVER_ERROR',\r\n true,\r\n '请稍后重试,如果问题持续请联系管理员'\r\n ),\r\n NETWORK: () => new BatchOperationError(\r\n '网络连接失败',\r\n 'NETWORK_ERROR',\r\n true,\r\n '请检查网络连接后重试'\r\n ),\r\n ABORT: () => new BatchOperationError(\r\n '操作已取消',\r\n 'ABORTED',\r\n false,\r\n ''\r\n )\r\n};\r\n\r\n/**\r\n * 根据错误创建 BatchOperationError\r\n * @param {Error|Response} error - 原始错误或响应对象\r\n * @param {string} details - 错误详情\r\n * @returns {BatchOperationError}\r\n */\r\nfunction createError(error, details = '') {\r\n // 处理取消操作\r\n if (error.name === 'AbortError') {\r\n return ERROR_HANDLERS.ABORT();\r\n }\r\n \r\n // 处理 HTTP 响应错误\r\n if (error instanceof Response || (error && typeof error.status === 'number')) {\r\n const handler = ERROR_HANDLERS[error.status];\r\n if (handler) {\r\n return handler(details);\r\n }\r\n return new BatchOperationError(\r\n `请求失败: ${error.status}`,\r\n 'HTTP_ERROR',\r\n true,\r\n '请稍后重试'\r\n );\r\n }\r\n \r\n // 处理网络错误\r\n if (error instanceof TypeError && error.message.includes('fetch')) {\r\n return ERROR_HANDLERS.NETWORK();\r\n }\r\n \r\n // 其他错误\r\n return new BatchOperationError(\r\n error.message || '未知错误',\r\n 'UNKNOWN_ERROR',\r\n true,\r\n '请稍后重试'\r\n );\r\n}\r\n\r\n/**\r\n * BatchProcessor 类\r\n * \r\n * 用于批量获取和处理数据的核心类\r\n */\r\nclass BatchProcessor {\r\n /**\r\n * 创建 BatchProcessor 实例\r\n * @param {Object} options - 配置选项\r\n * @param {number} options.batchSize - 每批数据量,默认 1000\r\n * @param {Function} options.onProgress - 进度回调函数\r\n * @param {Function} options.onError - 错误回调函数\r\n */\r\n constructor(options = {}) {\r\n this.batchSize = options.batchSize || 1000;\r\n this.onProgress = options.onProgress || (() => {});\r\n this.onError = options.onError || (() => {});\r\n this.abortController = null;\r\n }\r\n\r\n /**\r\n * 获取所有数据记录\r\n * 使用 cursor 分页机制循环获取所有数据,直到没有更多数据或操作被取消\r\n * \r\n * @param {boolean} includeValue - 是否包含分块文件的 value 数据\r\n * @returns {Promise} 所有记录的数组\r\n * @throws {BatchOperationError} 当发生错误时抛出\r\n */\r\n async fetchAllRecords(includeValue = false) {\r\n // 创建新的 AbortController 用于取消操作\r\n this.abortController = new AbortController();\r\n const allRecords = [];\r\n let cursor = null;\r\n let totalFetched = 0;\r\n let batchCount = 0;\r\n\r\n try {\r\n do {\r\n // 检查是否已取消\r\n if (this.abortController.signal.aborted) {\r\n break;\r\n }\r\n\r\n // 获取一批数据\r\n const response = await this.fetchBatch(cursor, includeValue);\r\n \r\n // 合并数据到总数组\r\n allRecords.push(...response.records);\r\n cursor = response.nextCursor;\r\n totalFetched += response.records.length;\r\n batchCount++;\r\n\r\n // 调用进度回调\r\n this.onProgress({\r\n phase: 'fetching',\r\n current: totalFetched,\r\n batchCount: batchCount,\r\n message: `已获取 ${totalFetched} 条记录...`\r\n });\r\n\r\n } while (cursor && !this.abortController.signal.aborted);\r\n\r\n // 如果是因为取消而退出循环,抛出取消错误\r\n if (this.abortController.signal.aborted) {\r\n throw ERROR_HANDLERS.ABORT();\r\n }\r\n\r\n return allRecords;\r\n } catch (error) {\r\n // 调用错误回调\r\n const batchError = error instanceof BatchOperationError \r\n ? error \r\n : createError(error);\r\n this.onError(batchError);\r\n throw batchError;\r\n }\r\n }\r\n\r\n /**\r\n * 获取单批数据\r\n * \r\n * @param {string|null} cursor - 分页游标,首次请求为 null\r\n * @param {boolean} includeValue - 是否包含分块文件的 value 数据\r\n * @returns {Promise} 包含 records 和 nextCursor 的响应对象\r\n * @throws {BatchOperationError} 当请求失败时抛出\r\n */\r\n async fetchBatch(cursor, includeValue) {\r\n // 构建查询参数\r\n const params = new URLSearchParams();\r\n if (cursor) {\r\n params.set('cursor', cursor);\r\n }\r\n if (includeValue) {\r\n params.set('includeValue', 'true');\r\n }\r\n params.set('limit', String(this.batchSize));\r\n\r\n try {\r\n // 发送请求,传入 abort signal 支持取消\r\n const response = await fetchWithAuth(\r\n `/api/manage/batch/list?${params}`,\r\n { signal: this.abortController.signal }\r\n );\r\n\r\n // 检查响应状态\r\n if (!response.ok) {\r\n let errorDetails = '';\r\n try {\r\n const errorData = await response.json();\r\n errorDetails = errorData.error || '';\r\n } catch {\r\n // 忽略 JSON 解析错误\r\n }\r\n throw createError(response, errorDetails);\r\n }\r\n\r\n // 解析响应数据\r\n const data = await response.json();\r\n \r\n // 验证响应格式\r\n if (!data.success) {\r\n throw new BatchOperationError(\r\n data.error || '请求失败',\r\n 'API_ERROR',\r\n true,\r\n '请稍后重试'\r\n );\r\n }\r\n\r\n return {\r\n records: data.records || [],\r\n nextCursor: data.nextCursor || null,\r\n totalProcessed: data.totalProcessed || 0\r\n };\r\n } catch (error) {\r\n // 如果已经是 BatchOperationError,直接抛出\r\n if (error instanceof BatchOperationError) {\r\n throw error;\r\n }\r\n // 否则转换为 BatchOperationError\r\n throw createError(error);\r\n }\r\n }\r\n\r\n /**\r\n * 取消当前操作\r\n * 调用此方法将中止正在进行的 fetch 请求\r\n */\r\n abort() {\r\n if (this.abortController) {\r\n this.abortController.abort();\r\n }\r\n }\r\n\r\n /**\r\n * 检查操作是否已被取消\r\n * @returns {boolean}\r\n */\r\n isAborted() {\r\n return this.abortController ? this.abortController.signal.aborted : false;\r\n }\r\n\r\n /**\r\n * 重置处理器状态\r\n * 在开始新的批量操作前调用\r\n */\r\n reset() {\r\n this.abortController = null;\r\n }\r\n}\r\n\r\nexport default BatchProcessor;\r\n","/**\r\n * IndexRebuilder - 索引重建类\r\n * \r\n * 处理索引重建的完整流程,包括数据获取、排序、分块上传和完成。\r\n */\r\n\r\nimport fetchWithAuth from '@/utils/fetchWithAuth';\r\nimport BatchProcessor, { BatchOperationError } from '@/utils/batchProcessor';\r\n\r\n/**\r\n * IndexRebuilder 类\r\n * \r\n * 用于重建索引的核心类,协调数据获取、排序和分块上传\r\n */\r\nclass IndexRebuilder {\r\n /**\r\n * 创建 IndexRebuilder 实例\r\n * @param {Object} options - 配置选项\r\n * @param {number} options.chunkSize - 每个分块的记录数,默认从后端获取\r\n * @param {number} options.maxRetries - 分块上传最大重试次数,默认 3\r\n * @param {number} options.retryDelay - 重试延迟基数(毫秒),默认 1000\r\n * @param {Function} options.onProgress - 进度回调函数\r\n * @param {Function} options.onError - 错误回调函数\r\n */\r\n constructor(options = {}) {\r\n this.chunkSize = options.chunkSize || null; // 从后端获取\r\n this.maxRetries = options.maxRetries || 3;\r\n this.retryDelay = options.retryDelay || 1000;\r\n this.onProgress = options.onProgress || (() => {});\r\n this.onError = options.onError || (() => {});\r\n this.sessionId = this.generateSessionId();\r\n this.aborted = false;\r\n }\r\n\r\n /**\r\n * 从后端获取索引配置(分块大小等)\r\n * @returns {Promise} 配置对象 { chunkSize, databaseType }\r\n */\r\n async fetchConfig() {\r\n try {\r\n const response = await fetchWithAuth('/api/manage/batch/index/config');\r\n if (!response.ok) {\r\n throw new Error('获取配置失败');\r\n }\r\n const result = await response.json();\r\n if (result.success) {\r\n return {\r\n chunkSize: result.chunkSize || 500,\r\n databaseType: result.databaseType || 'unknown'\r\n };\r\n }\r\n throw new Error(result.error || '获取配置失败');\r\n } catch (error) {\r\n // 获取失败时使用保守的默认值(兼容 D1)\r\n console.warn('Failed to fetch index config, using default:', error);\r\n return { chunkSize: 500, databaseType: 'unknown' };\r\n }\r\n }\r\n\r\n /**\r\n * 执行索引重建\r\n * \r\n * 完整流程:\r\n * 1. 获取配置(分块大小)\r\n * 2. 获取所有记录\r\n * 3. 按时间戳降序排序\r\n * 4. 分块上传\r\n * 5. 完成重建\r\n * \r\n * @returns {Promise} 重建结果 { success: boolean, totalFiles: number }\r\n * @throws {BatchOperationError} 当发生错误时抛出\r\n */\r\n async rebuild() {\r\n this.aborted = false;\r\n \r\n try {\r\n // 获取配置(分块大小)\r\n if (!this.chunkSize) {\r\n const config = await this.fetchConfig();\r\n this.chunkSize = config.chunkSize;\r\n }\r\n\r\n // 获取所有记录\r\n this.onProgress({ \r\n phase: 'fetching', \r\n message: '正在获取数据...',\r\n current: 0\r\n });\r\n \r\n const processor = new BatchProcessor({\r\n onProgress: (p) => this.onProgress({ ...p, phase: 'fetching' }),\r\n onError: (e) => this.onError(e)\r\n });\r\n \r\n const records = await processor.fetchAllRecords(false);\r\n \r\n if (this.aborted) {\r\n throw new BatchOperationError('操作已取消', 'ABORTED', false, '');\r\n }\r\n\r\n // 排序(按时间戳降序)\r\n this.onProgress({ \r\n phase: 'sorting', \r\n message: '正在排序...',\r\n current: 0,\r\n total: records.length\r\n });\r\n \r\n this.sortByTimestampDescending(records);\r\n \r\n if (this.aborted) {\r\n throw new BatchOperationError('操作已取消', 'ABORTED', false, '');\r\n }\r\n\r\n // 分块上传\r\n const chunks = this.splitIntoChunks(records);\r\n \r\n for (let i = 0; i < chunks.length; i++) {\r\n if (this.aborted) {\r\n throw new BatchOperationError('操作已取消', 'ABORTED', false, '');\r\n }\r\n \r\n // 使用重试机制上传分块\r\n await this.uploadChunkWithRetry(chunks[i], i);\r\n \r\n this.onProgress({\r\n phase: 'uploading',\r\n current: i + 1,\r\n total: chunks.length,\r\n message: `正在上传分块 ${i + 1}/${chunks.length}...`\r\n });\r\n }\r\n\r\n // 完成重建\r\n this.onProgress({ \r\n phase: 'finalizing', \r\n message: '正在完成重建...',\r\n current: chunks.length,\r\n total: chunks.length\r\n });\r\n \r\n await this.finalize(chunks.length, records.length);\r\n\r\n this.onProgress({\r\n phase: 'completed',\r\n message: `索引重建完成,共 ${records.length} 个文件`,\r\n current: records.length,\r\n total: records.length\r\n });\r\n\r\n return { success: true, totalFiles: records.length };\r\n } catch (error) {\r\n const batchError = error instanceof BatchOperationError \r\n ? error \r\n : new BatchOperationError(\r\n error.message || '索引重建失败',\r\n 'REBUILD_ERROR',\r\n true,\r\n '请稍后重试'\r\n );\r\n this.onError(batchError);\r\n throw batchError;\r\n }\r\n }\r\n\r\n /**\r\n * 按时间戳降序排序记录\r\n * \r\n * @param {Array} records - 要排序的记录数组(原地排序)\r\n */\r\n sortByTimestampDescending(records) {\r\n records.sort((a, b) => {\r\n const timestampA = (a.metadata && a.metadata.TimeStamp) || 0;\r\n const timestampB = (b.metadata && b.metadata.TimeStamp) || 0;\r\n return timestampB - timestampA;\r\n });\r\n }\r\n\r\n /**\r\n * 将记录分割为多个块\r\n * \r\n * @param {Array} records - 要分割的记录数组\r\n * @returns {Array} 分块后的二维数组\r\n */\r\n splitIntoChunks(records) {\r\n const chunks = [];\r\n for (let i = 0; i < records.length; i += this.chunkSize) {\r\n chunks.push(records.slice(i, i + this.chunkSize));\r\n }\r\n return chunks;\r\n }\r\n\r\n /**\r\n * 带重试机制的分块上传\r\n * \r\n * @param {Array} chunk - 要上传的分块数据\r\n * @param {number} chunkId - 分块 ID\r\n * @returns {Promise} 上传响应\r\n * @throws {BatchOperationError} 当所有重试都失败时抛出\r\n */\r\n async uploadChunkWithRetry(chunk, chunkId) {\r\n let lastError;\r\n \r\n for (let attempt = 1; attempt <= this.maxRetries; attempt++) {\r\n try {\r\n return await this.uploadChunk(chunk, chunkId);\r\n } catch (error) {\r\n lastError = error;\r\n \r\n // 不重试的错误类型\r\n if (error instanceof BatchOperationError) {\r\n if (error.code === 'AUTH_FAILED' || \r\n error.code === 'FORBIDDEN' || \r\n error.code === 'ABORTED') {\r\n throw error;\r\n }\r\n }\r\n \r\n // 如果还有重试机会,等待后重试\r\n if (attempt < this.maxRetries) {\r\n // 指数退避\r\n const delay = this.retryDelay * Math.pow(2, attempt - 1);\r\n await this.sleep(delay);\r\n \r\n this.onProgress({\r\n phase: 'retrying',\r\n message: `分块 ${chunkId + 1} 上传失败,正在重试 (${attempt}/${this.maxRetries})...`,\r\n current: chunkId,\r\n attempt: attempt\r\n });\r\n }\r\n }\r\n }\r\n \r\n // 所有重试都失败\r\n throw lastError instanceof BatchOperationError \r\n ? lastError \r\n : new BatchOperationError(\r\n `分块 ${chunkId + 1} 上传失败,已重试 ${this.maxRetries} 次`,\r\n 'CHUNK_UPLOAD_FAILED',\r\n false,\r\n '请检查网络连接后重新开始重建'\r\n );\r\n }\r\n\r\n /**\r\n * 上传单个分块\r\n * \r\n * @param {Array} chunk - 要上传的分块数据\r\n * @param {number} chunkId - 分块 ID\r\n * @returns {Promise} 上传响应\r\n * @throws {BatchOperationError} 当上传失败时抛出\r\n */\r\n async uploadChunk(chunk, chunkId) {\r\n const checksum = await this.calculateChecksum(chunk);\r\n \r\n try {\r\n const response = await fetchWithAuth('/api/manage/batch/index/chunk', {\r\n method: 'POST',\r\n headers: { 'Content-Type': 'application/json' },\r\n body: JSON.stringify({\r\n chunkId: String(chunkId),\r\n sessionId: this.sessionId,\r\n data: chunk,\r\n checksum\r\n })\r\n });\r\n\r\n if (!response.ok) {\r\n let errorDetails = '';\r\n try {\r\n const errorData = await response.json();\r\n errorDetails = errorData.error || '';\r\n } catch {\r\n // 忽略 JSON 解析错误\r\n }\r\n throw this.createHttpError(response.status, errorDetails);\r\n }\r\n\r\n const result = await response.json();\r\n \r\n if (!result.success) {\r\n throw new BatchOperationError(\r\n result.error || '分块上传失败',\r\n 'CHUNK_UPLOAD_FAILED',\r\n true,\r\n '请稍后重试'\r\n );\r\n }\r\n\r\n return result;\r\n } catch (error) {\r\n if (error instanceof BatchOperationError) {\r\n throw error;\r\n }\r\n // 网络错误\r\n if (error instanceof TypeError && error.message.includes('fetch')) {\r\n throw new BatchOperationError(\r\n '网络连接失败',\r\n 'NETWORK_ERROR',\r\n true,\r\n '请检查网络连接后重试'\r\n );\r\n }\r\n throw new BatchOperationError(\r\n error.message || '分块上传失败',\r\n 'CHUNK_UPLOAD_FAILED',\r\n true,\r\n '请稍后重试'\r\n );\r\n }\r\n }\r\n\r\n /**\r\n * 完成索引重建\r\n * \r\n * @param {number} totalChunks - 总分块数\r\n * @param {number} totalFiles - 总文件数\r\n * @returns {Promise} 完成响应\r\n * @throws {BatchOperationError} 当完成请求失败时抛出\r\n */\r\n async finalize(totalChunks, totalFiles) {\r\n try {\r\n const response = await fetchWithAuth('/api/manage/batch/index/finalize', {\r\n method: 'POST',\r\n headers: { 'Content-Type': 'application/json' },\r\n body: JSON.stringify({\r\n sessionId: this.sessionId,\r\n totalChunks,\r\n totalFiles\r\n })\r\n });\r\n\r\n if (!response.ok) {\r\n let errorDetails = '';\r\n try {\r\n const errorData = await response.json();\r\n errorDetails = errorData.error || '';\r\n } catch {\r\n // 忽略 JSON 解析错误\r\n }\r\n throw this.createHttpError(response.status, errorDetails);\r\n }\r\n\r\n const result = await response.json();\r\n \r\n if (!result.success) {\r\n throw new BatchOperationError(\r\n result.error || '索引完成失败',\r\n 'FINALIZE_FAILED',\r\n true,\r\n '请稍后重试'\r\n );\r\n }\r\n\r\n return result;\r\n } catch (error) {\r\n if (error instanceof BatchOperationError) {\r\n throw error;\r\n }\r\n throw new BatchOperationError(\r\n error.message || '索引完成失败',\r\n 'FINALIZE_FAILED',\r\n true,\r\n '请稍后重试'\r\n );\r\n }\r\n }\r\n\r\n /**\r\n * 生成唯一的会话 ID\r\n * \r\n * @returns {string} 会话 ID\r\n */\r\n generateSessionId() {\r\n return `rebuild_${Date.now()}_${Math.random().toString(36).slice(2)}`;\r\n }\r\n\r\n /**\r\n * 计算数据的 SHA-256 校验和\r\n * \r\n * @param {Array} data - 要计算校验和的数据\r\n * @returns {Promise} 十六进制格式的校验和\r\n */\r\n async calculateChecksum(data) {\r\n const text = JSON.stringify(data);\r\n const encoder = new TextEncoder();\r\n const dataBuffer = encoder.encode(text);\r\n const hashBuffer = await crypto.subtle.digest('SHA-256', dataBuffer);\r\n const hashArray = Array.from(new Uint8Array(hashBuffer));\r\n return hashArray.map(b => b.toString(16).padStart(2, '0')).join('');\r\n }\r\n\r\n /**\r\n * 根据 HTTP 状态码创建错误对象\r\n * \r\n * @param {number} status - HTTP 状态码\r\n * @param {string} details - 错误详情\r\n * @returns {BatchOperationError}\r\n */\r\n createHttpError(status, details = '') {\r\n switch (status) {\r\n case 401:\r\n return new BatchOperationError(\r\n '认证失败,请重新登录',\r\n 'AUTH_FAILED',\r\n false,\r\n '请刷新页面并重新登录'\r\n );\r\n case 403:\r\n return new BatchOperationError(\r\n '权限不足或请求被拒绝',\r\n 'FORBIDDEN',\r\n false,\r\n '请确认您有管理员权限'\r\n );\r\n case 400:\r\n return new BatchOperationError(\r\n `请求数据无效: ${details}`,\r\n 'INVALID_DATA',\r\n true,\r\n '请检查数据格式后重试'\r\n );\r\n case 404:\r\n return new BatchOperationError(\r\n '会话不存在',\r\n 'SESSION_NOT_FOUND',\r\n false,\r\n '请重新开始索引重建'\r\n );\r\n case 410:\r\n return new BatchOperationError(\r\n '会话已过期',\r\n 'SESSION_EXPIRED',\r\n false,\r\n '请重新开始索引重建'\r\n );\r\n case 500:\r\n default:\r\n return new BatchOperationError(\r\n `服务器错误: ${details || status}`,\r\n 'SERVER_ERROR',\r\n true,\r\n '请稍后重试'\r\n );\r\n }\r\n }\r\n\r\n /**\r\n * 延迟执行\r\n * \r\n * @param {number} ms - 延迟毫秒数\r\n * @returns {Promise}\r\n */\r\n sleep(ms) {\r\n return new Promise(resolve => setTimeout(resolve, ms));\r\n }\r\n\r\n /**\r\n * 取消当前操作\r\n */\r\n abort() {\r\n this.aborted = true;\r\n }\r\n\r\n /**\r\n * 重置重建器状态\r\n * 在开始新的重建操作前调用\r\n */\r\n reset() {\r\n this.aborted = false;\r\n this.sessionId = this.generateSessionId();\r\n }\r\n}\r\n\r\nexport default IndexRebuilder;\r\n","/**\r\n * BackupGenerator - 备份数据生成类\r\n * \r\n * 处理前端辅助备份功能,获取所有文件记录(包含分块文件的 value),\r\n * 构建完整的备份 JSON 文件,并触发浏览器下载。\r\n */\r\n\r\nimport BatchProcessor from '@/utils/batchProcessor';\r\nimport fetchWithAuth from '@/utils/fetchWithAuth';\r\nimport packageInfo from '../../package.json'\r\n\r\n/**\r\n * BackupGenerator 类\r\n * \r\n * 用于生成和下载备份数据的类\r\n */\r\nclass BackupGenerator {\r\n /**\r\n * 创建 BackupGenerator 实例\r\n * @param {Object} options - 配置选项\r\n * @param {Function} options.onProgress - 进度回调函数\r\n */\r\n constructor(options = {}) {\r\n this.onProgress = options.onProgress || (() => {});\r\n this.processor = null;\r\n }\r\n\r\n /**\r\n * 生成并下载备份\r\n * \r\n * 完整流程:\r\n * 1. 获取所有文件记录(包含分块文件的 value)\r\n * 2. 构建备份数据结构\r\n * 3. 获取系统设置\r\n * 4. 生成并触发下载\r\n * \r\n * @returns {Promise} 包含 success 和 fileCount 的结果对象\r\n * @throws {Error} 当备份过程中发生错误时抛出\r\n */\r\n async generateBackup() {\r\n // 获取所有文件记录(包含分块文件的 value)\r\n this.processor = new BatchProcessor({\r\n onProgress: (p) => this.onProgress({ ...p, phase: 'fetching' })\r\n });\r\n\r\n const records = await this.processor.fetchAllRecords(true);\r\n\r\n // 构建备份数据\r\n this.onProgress({ phase: 'building', message: '正在构建备份数据...' });\r\n\r\n const backupData = {\r\n timestamp: Date.now(),\r\n version: packageInfo.version,\r\n data: {\r\n fileCount: records.length,\r\n files: {},\r\n settings: {}\r\n }\r\n };\r\n\r\n // 将记录转换为以 id 为键的对象格式\r\n for (const record of records) {\r\n backupData.data.files[record.id] = {\r\n metadata: record.metadata,\r\n value: record.value || null\r\n };\r\n }\r\n\r\n // 3. 获取系统设置\r\n const settings = await this.fetchSettings();\r\n backupData.data.settings = settings;\r\n\r\n // 生成下载\r\n this.onProgress({ phase: 'downloading', message: '正在生成下载...' });\r\n this.downloadBackup(backupData);\r\n\r\n const settingsCount = Object.keys(settings).length;\r\n return { success: true, fileCount: records.length, settingsCount };\r\n }\r\n\r\n /**\r\n * 获取系统设置\r\n * \r\n * @returns {Promise} 系统设置对象,失败时返回空对象\r\n */\r\n async fetchSettings() {\r\n try {\r\n const response = await fetchWithAuth('/api/manage/batch/settings');\r\n if (!response.ok) {\r\n console.warn('Failed to fetch settings:', response.status);\r\n return {};\r\n }\r\n const data = await response.json();\r\n // 返回 settings 字段,而不是整个响应\r\n return data.settings || {};\r\n } catch (error) {\r\n console.warn('Failed to fetch settings:', error);\r\n return {};\r\n }\r\n }\r\n\r\n /**\r\n * 触发浏览器下载备份文件\r\n * \r\n * @param {Object} data - 备份数据对象\r\n */\r\n downloadBackup(data) {\r\n // 将数据转换为格式化的 JSON 字符串\r\n const json = JSON.stringify(data, null, 2);\r\n \r\n // 创建 Blob 对象\r\n const blob = new Blob([json], { type: 'application/json' });\r\n \r\n // 创建下载 URL\r\n const url = URL.createObjectURL(blob);\r\n\r\n // 创建临时下载链接\r\n const a = document.createElement('a');\r\n a.href = url;\r\n // 使用日期作为文件名的一部分\r\n a.download = `imgbed_backup_${new Date().toISOString().split('T')[0]}.json`;\r\n \r\n // 触发下载\r\n document.body.appendChild(a);\r\n a.click();\r\n \r\n // 清理\r\n document.body.removeChild(a);\r\n URL.revokeObjectURL(url);\r\n }\r\n\r\n /**\r\n * 取消当前备份操作\r\n */\r\n abort() {\r\n if (this.processor) {\r\n this.processor.abort();\r\n }\r\n }\r\n\r\n /**\r\n * 检查操作是否已被取消\r\n * @returns {boolean}\r\n */\r\n isAborted() {\r\n return this.processor ? this.processor.isAborted() : false;\r\n }\r\n}\r\n\r\nexport default BackupGenerator;\r\n","/**\r\n * RestoreProcessor - 分批恢复数据类\r\n * \r\n * 将备份数据分批上传到后端进行恢复,避免 CPU 超时\r\n */\r\n\r\nimport fetchWithAuth from '@/utils/fetchWithAuth';\r\nimport { BatchOperationError } from '@/utils/batchProcessor';\r\n\r\n/**\r\n * RestoreProcessor 类\r\n */\r\nclass RestoreProcessor {\r\n /**\r\n * 创建 RestoreProcessor 实例\r\n * @param {Object} options - 配置选项\r\n * @param {number} options.chunkSize - 每批数据量,默认 50\r\n * @param {number} options.maxRetries - 最大重试次数,默认 3\r\n * @param {number} options.retryDelay - 重试延迟基数(毫秒),默认 1000\r\n * @param {Function} options.onProgress - 进度回调函数\r\n * @param {Function} options.onError - 错误回调函数\r\n */\r\n constructor(options = {}) {\r\n this.chunkSize = options.chunkSize || 50;\r\n this.maxRetries = options.maxRetries || 3;\r\n this.retryDelay = options.retryDelay || 1000;\r\n this.onProgress = options.onProgress || (() => {});\r\n this.onError = options.onError || (() => {});\r\n this.aborted = false;\r\n }\r\n\r\n /**\r\n * 执行恢复操作\r\n * \r\n * @param {Object} backupData - 备份数据对象\r\n * @returns {Promise} 恢复结果\r\n */\r\n async restore(backupData) {\r\n this.aborted = false;\r\n\r\n // 验证备份数据格式\r\n if (!backupData || !backupData.data) {\r\n throw new BatchOperationError(\r\n '备份文件格式无效',\r\n 'INVALID_BACKUP',\r\n false,\r\n '请选择有效的备份文件'\r\n );\r\n }\r\n\r\n const { files = {}, settings = {} } = backupData.data;\r\n const fileEntries = Object.entries(files);\r\n const settingEntries = Object.entries(settings);\r\n \r\n const totalFiles = fileEntries.length;\r\n const totalSettings = settingEntries.length;\r\n const totalItems = totalFiles + totalSettings;\r\n\r\n let restoredFiles = 0;\r\n let restoredSettings = 0;\r\n let failedFiles = 0;\r\n let failedSettings = 0;\r\n\r\n try {\r\n // 1. 分批恢复文件数据\r\n this.onProgress({\r\n phase: 'restoring_files',\r\n message: '正在恢复文件数据...',\r\n current: 0,\r\n total: totalItems\r\n });\r\n\r\n const fileChunks = this.splitIntoChunks(fileEntries, this.chunkSize);\r\n \r\n for (let i = 0; i < fileChunks.length; i++) {\r\n if (this.aborted) {\r\n throw new BatchOperationError('操作已取消', 'ABORTED', false, '');\r\n }\r\n\r\n const chunk = fileChunks[i];\r\n const chunkData = Object.fromEntries(chunk);\r\n \r\n const result = await this.uploadChunkWithRetry('files', chunkData);\r\n restoredFiles += result.restoredCount;\r\n failedFiles += result.failedCount;\r\n\r\n this.onProgress({\r\n phase: 'restoring_files',\r\n message: `正在恢复文件数据 ${restoredFiles}/${totalFiles}...`,\r\n current: restoredFiles,\r\n total: totalItems,\r\n percentage: (restoredFiles / totalItems) * 80\r\n });\r\n }\r\n\r\n // 2. 分批恢复系统设置\r\n this.onProgress({\r\n phase: 'restoring_settings',\r\n message: '正在恢复系统设置...',\r\n current: restoredFiles,\r\n total: totalItems\r\n });\r\n\r\n const settingChunks = this.splitIntoChunks(settingEntries, this.chunkSize);\r\n \r\n for (let i = 0; i < settingChunks.length; i++) {\r\n if (this.aborted) {\r\n throw new BatchOperationError('操作已取消', 'ABORTED', false, '');\r\n }\r\n\r\n const chunk = settingChunks[i];\r\n const chunkData = Object.fromEntries(chunk);\r\n \r\n const result = await this.uploadChunkWithRetry('settings', chunkData);\r\n restoredSettings += result.restoredCount;\r\n failedSettings += result.failedCount;\r\n\r\n this.onProgress({\r\n phase: 'restoring_settings',\r\n message: `正在恢复系统设置 ${restoredSettings}/${totalSettings}...`,\r\n current: restoredFiles + restoredSettings,\r\n total: totalItems,\r\n percentage: 80 + (restoredSettings / totalSettings) * 20\r\n });\r\n }\r\n\r\n // 3. 完成\r\n this.onProgress({\r\n phase: 'completed',\r\n message: '恢复完成',\r\n current: totalItems,\r\n total: totalItems,\r\n percentage: 100\r\n });\r\n\r\n return {\r\n success: true,\r\n restoredFiles,\r\n restoredSettings,\r\n failedFiles,\r\n failedSettings,\r\n backupTimestamp: backupData.timestamp\r\n };\r\n\r\n } catch (error) {\r\n const batchError = error instanceof BatchOperationError\r\n ? error\r\n : new BatchOperationError(\r\n error.message || '恢复失败',\r\n 'RESTORE_ERROR',\r\n true,\r\n '请稍后重试'\r\n );\r\n this.onError(batchError);\r\n throw batchError;\r\n }\r\n }\r\n\r\n /**\r\n * 将数组分割为多个块\r\n */\r\n splitIntoChunks(entries, chunkSize) {\r\n const chunks = [];\r\n for (let i = 0; i < entries.length; i += chunkSize) {\r\n chunks.push(entries.slice(i, i + chunkSize));\r\n }\r\n return chunks;\r\n }\r\n\r\n /**\r\n * 带重试机制的分块上传\r\n */\r\n async uploadChunkWithRetry(type, data) {\r\n let lastError;\r\n\r\n for (let attempt = 1; attempt <= this.maxRetries; attempt++) {\r\n try {\r\n return await this.uploadChunk(type, data);\r\n } catch (error) {\r\n lastError = error;\r\n\r\n if (error instanceof BatchOperationError) {\r\n if (error.code === 'AUTH_FAILED' ||\r\n error.code === 'FORBIDDEN' ||\r\n error.code === 'ABORTED') {\r\n throw error;\r\n }\r\n }\r\n\r\n if (attempt < this.maxRetries) {\r\n const delay = this.retryDelay * Math.pow(2, attempt - 1);\r\n await this.sleep(delay);\r\n }\r\n }\r\n }\r\n\r\n throw lastError;\r\n }\r\n\r\n /**\r\n * 上传单个分块\r\n */\r\n async uploadChunk(type, data) {\r\n try {\r\n const response = await fetchWithAuth('/api/manage/batch/restore/chunk', {\r\n method: 'POST',\r\n headers: { 'Content-Type': 'application/json' },\r\n body: JSON.stringify({ type, data })\r\n });\r\n\r\n if (!response.ok) {\r\n let errorDetails = '';\r\n try {\r\n const errorData = await response.json();\r\n errorDetails = errorData.error || '';\r\n } catch {\r\n // 忽略 JSON 解析错误\r\n }\r\n throw this.createHttpError(response.status, errorDetails);\r\n }\r\n\r\n const result = await response.json();\r\n\r\n if (!result.success) {\r\n throw new BatchOperationError(\r\n result.error || '恢复分块失败',\r\n 'CHUNK_RESTORE_FAILED',\r\n true,\r\n '请稍后重试'\r\n );\r\n }\r\n\r\n return result;\r\n } catch (error) {\r\n if (error instanceof BatchOperationError) {\r\n throw error;\r\n }\r\n if (error instanceof TypeError && error.message.includes('fetch')) {\r\n throw new BatchOperationError(\r\n '网络连接失败',\r\n 'NETWORK_ERROR',\r\n true,\r\n '请检查网络连接后重试'\r\n );\r\n }\r\n throw new BatchOperationError(\r\n error.message || '恢复分块失败',\r\n 'CHUNK_RESTORE_FAILED',\r\n true,\r\n '请稍后重试'\r\n );\r\n }\r\n }\r\n\r\n /**\r\n * 根据 HTTP 状态码创建错误对象\r\n */\r\n createHttpError(status, details = '') {\r\n switch (status) {\r\n case 401:\r\n return new BatchOperationError(\r\n '认证失败,请重新登录',\r\n 'AUTH_FAILED',\r\n false,\r\n '请刷新页面并重新登录'\r\n );\r\n case 403:\r\n return new BatchOperationError(\r\n '权限不足或请求被拒绝',\r\n 'FORBIDDEN',\r\n false,\r\n '请确认您有管理员权限'\r\n );\r\n case 400:\r\n return new BatchOperationError(\r\n `请求数据无效: ${details}`,\r\n 'INVALID_DATA',\r\n true,\r\n '请检查备份文件格式'\r\n );\r\n case 500:\r\n default:\r\n return new BatchOperationError(\r\n `服务器错误: ${details || status}`,\r\n 'SERVER_ERROR',\r\n true,\r\n '请稍后重试'\r\n );\r\n }\r\n }\r\n\r\n /**\r\n * 延迟执行\r\n */\r\n sleep(ms) {\r\n return new Promise(resolve => setTimeout(resolve, ms));\r\n }\r\n\r\n /**\r\n * 取消当前操作\r\n */\r\n abort() {\r\n this.aborted = true;\r\n }\r\n}\r\n\r\nexport default RestoreProcessor;\r\n","import \"core-js/modules/es.iterator.constructor.js\";\nimport \"core-js/modules/es.iterator.reduce.js\";\nimport \"core-js/modules/esnext.json.parse.js\";\nimport fetchWithAuth from '@/utils/fetchWithAuth';\nimport packageInfo from '../../package.json';\nimport { Doughnut } from 'vue-chartjs';\nimport { Chart as ChartJS, ArcElement, Tooltip, Legend } from 'chart.js';\nimport IndexRebuilder from '@/utils/indexRebuilder';\nimport BackupGenerator from '@/utils/backupGenerator';\nimport RestoreProcessor from '@/utils/restoreProcessor';\nChartJS.register(ArcElement, Tooltip, Legend);\nexport default {\n name: 'SysCogStatus',\n components: {\n Doughnut\n },\n data() {\n return {\n loading: false,\n rebuilding: false,\n backing: false,\n restoring: false,\n indexInfo: {},\n version: packageInfo.version,\n // 从package.json获取版本号\n loadErrors: {\n newest: false,\n oldest: false\n },\n // 渠道图表颜色\n channelColors: ['#8B5CF6', '#EC4899', '#06B6D4', '#10B981', '#F59E0B', '#EF4444', '#6366F1', '#84CC16'],\n // 状态图表颜色\n typeColors: ['#10B981', '#3B82F6', '#F59E0B', '#EF4444', '#8B5CF6', '#EC4899', '#06B6D4', '#84CC16'],\n // 批量操作进度状态\n isProcessing: false,\n processingPhase: '',\n // fetching, sorting, uploading, finalizing, building, downloading, completed\n processingProgress: {\n current: 0,\n total: 0,\n message: '',\n percentage: 0\n },\n processingError: null,\n processingStartTime: null,\n // 当前处理器实例(用于取消操作)\n currentRebuilder: null,\n currentBackupGenerator: null,\n currentRestoreProcessor: null\n };\n },\n computed: {\n // 渠道分布图表数据\n channelChartData() {\n const stats = this.indexInfo.channelStats || {};\n return {\n labels: Object.keys(stats),\n datasets: [{\n data: Object.values(stats),\n backgroundColor: this.channelColors.slice(0, Object.keys(stats).length),\n borderWidth: 0\n }]\n };\n },\n // 文件状态图表数据 - 将Block映射为\"已屏蔽\",其余为\"正常\"\n typeChartData() {\n const aggregatedStats = this.aggregatedTypeStats;\n return {\n labels: Object.keys(aggregatedStats),\n datasets: [{\n data: Object.values(aggregatedStats),\n backgroundColor: this.typeColors.slice(0, Object.keys(aggregatedStats).length),\n borderWidth: 0\n }]\n };\n },\n // 聚合后的状态统计:Block -> 已屏蔽,其余 -> 正常\n aggregatedTypeStats() {\n const stats = this.indexInfo.typeStats || {};\n const aggregatedStats = {};\n for (const [status, count] of Object.entries(stats)) {\n const mappedStatus = status === 'Block' ? '已屏蔽' : '正常';\n aggregatedStats[mappedStatus] = (aggregatedStats[mappedStatus] || 0) + count;\n }\n return aggregatedStats;\n },\n // 图表配置\n chartOptions() {\n return {\n responsive: true,\n maintainAspectRatio: true,\n cutout: '65%',\n hoverOffset: 8,\n layout: {\n padding: 10\n },\n plugins: {\n legend: {\n display: false\n },\n tooltip: {\n backgroundColor: 'rgba(0, 0, 0, 0.8)',\n titleColor: '#fff',\n bodyColor: '#fff',\n padding: 12,\n cornerRadius: 8,\n displayColors: true,\n z: 100,\n callbacks: {\n label: context => {\n const value = context.raw;\n const total = context.dataset.data.reduce((a, b) => a + b, 0);\n const percentage = (value / total * 100).toFixed(1);\n return ` ${value.toLocaleString()} (${percentage}%)`;\n }\n }\n }\n },\n animation: {\n animateRotate: true,\n animateScale: true\n }\n };\n },\n // 预计剩余时间(Requirements 9.2)\n estimatedTimeRemaining() {\n if (!this.isProcessing || !this.processingStartTime) return '';\n if (this.processingProgress.current === 0 || this.processingProgress.percentage === 0) return '';\n const elapsed = Date.now() - this.processingStartTime;\n const progress = this.processingProgress.percentage / 100;\n if (progress <= 0) return '';\n const totalEstimated = elapsed / progress;\n const remaining = totalEstimated - elapsed;\n if (remaining <= 0) return '即将完成';\n const seconds = Math.ceil(remaining / 1000);\n if (seconds < 60) return `约 ${seconds} 秒`;\n const minutes = Math.ceil(seconds / 60);\n if (minutes < 60) return `约 ${minutes} 分钟`;\n const hours = Math.floor(minutes / 60);\n const remainingMinutes = minutes % 60;\n return `约 ${hours} 小时 ${remainingMinutes} 分钟`;\n },\n // 处理阶段描述\n phaseDescription() {\n const phaseMap = {\n 'fetching': '正在获取数据',\n 'sorting': '正在排序',\n 'uploading': '正在上传',\n 'finalizing': '正在完成',\n 'building': '正在构建备份',\n 'downloading': '正在生成下载',\n 'restoring_files': '正在恢复文件',\n 'restoring_settings': '正在恢复设置',\n 'completed': '已完成',\n 'retrying': '正在重试'\n };\n return phaseMap[this.processingPhase] || this.processingPhase;\n }\n },\n mounted() {\n this.fetchIndexInfo();\n },\n methods: {\n // 获取渠道图表颜色\n getChartColor(index) {\n return this.channelColors[index % this.channelColors.length];\n },\n // 获取状态图表颜色\n getTypeChartColor(index) {\n return this.typeColors[index % this.typeColors.length];\n },\n // 获取索引信息\n async fetchIndexInfo() {\n this.loading = true;\n try {\n const response = await fetchWithAuth('/api/manage/list?action=info', {\n method: 'GET'\n });\n if (response.ok) {\n const data = await response.json();\n this.indexInfo = data;\n } else {\n throw new Error('API请求失败');\n }\n } catch (error) {\n console.error('获取索引信息失败:', error);\n this.$message.error('获取索引信息失败');\n } finally {\n this.loading = false;\n }\n },\n // 重建索引 - 使用前端辅助重建流程 (Requirements 3.6, 9.1, 9.2, 9.3, 9.4)\n async rebuildIndex() {\n if (this.isProcessing) {\n this.$message.warning('已有操作正在进行中');\n return;\n }\n this.rebuilding = true;\n this.isProcessing = true;\n this.processingError = null;\n this.processingStartTime = Date.now();\n this.processingProgress = {\n current: 0,\n total: 0,\n message: '',\n percentage: 0\n };\n\n // 创建 IndexRebuilder 实例\n this.currentRebuilder = new IndexRebuilder({\n onProgress: progress => this.handleProgress(progress),\n onError: error => this.handleError(error)\n });\n try {\n const result = await this.currentRebuilder.rebuild();\n\n // 成功完成 (Requirement 9.4)\n this.$message.success(`索引重建完成!共处理 ${result.totalFiles.toLocaleString()} 个文件`);\n\n // 刷新索引信息\n setTimeout(() => {\n this.fetchIndexInfo();\n }, 1000);\n } catch (error) {\n // 错误处理 (Requirement 9.3)\n if (error.code !== 'ABORTED') {\n const errorMessage = error.suggestion ? `${error.message}。${error.suggestion}` : error.message;\n this.$message.error(errorMessage);\n this.processingError = {\n message: error.message,\n suggestion: error.suggestion,\n recoverable: error.recoverable\n };\n }\n } finally {\n this.rebuilding = false;\n this.isProcessing = false;\n this.currentRebuilder = null;\n this.processingStartTime = null;\n }\n },\n // 备份数据 - 使用前端辅助备份流程 (Requirements 4.6, 9.1, 9.2, 9.3, 9.4)\n async backupData() {\n if (this.isProcessing) {\n this.$message.warning('已有操作正在进行中');\n return;\n }\n this.backing = true;\n this.isProcessing = true;\n this.processingError = null;\n this.processingStartTime = Date.now();\n this.processingProgress = {\n current: 0,\n total: 0,\n message: '',\n percentage: 0\n };\n\n // 创建 BackupGenerator 实例\n this.currentBackupGenerator = new BackupGenerator({\n onProgress: progress => this.handleProgress(progress)\n });\n try {\n const result = await this.currentBackupGenerator.generateBackup();\n\n // 成功完成 (Requirement 9.4)\n const settingsMsg = result.settingsCount > 0 ? `,${result.settingsCount} 个设置项` : '';\n this.$message.success(`备份完成!共备份 ${result.fileCount.toLocaleString()} 个文件${settingsMsg}`);\n } catch (error) {\n // 错误处理 (Requirement 9.3)\n if (error.code !== 'ABORTED') {\n const errorMessage = error.suggestion ? `${error.message}。${error.suggestion}` : error.message;\n this.$message.error(errorMessage);\n this.processingError = {\n message: error.message,\n suggestion: error.suggestion,\n recoverable: error.recoverable\n };\n }\n } finally {\n this.backing = false;\n this.isProcessing = false;\n this.currentBackupGenerator = null;\n this.processingStartTime = null;\n }\n },\n // 选择恢复文件\n selectRestoreFile() {\n if (this.restoring) return;\n this.$refs.fileInput.click();\n },\n // 处理文件选择\n async handleFileSelect(event) {\n const file = event.target.files[0];\n if (!file) return;\n if (!file.name.endsWith('.json')) {\n this.$message.error('请选择JSON格式的备份文件');\n return;\n }\n\n // 确认恢复操作\n try {\n await this.$confirm('恢复操作将覆盖现有的文件元数据和系统设置,此操作不可逆。确定要继续吗?', '确认恢复', {\n confirmButtonText: '确定恢复',\n cancelButtonText: '取消',\n type: 'warning'\n });\n await this.restoreData(file);\n } catch (error) {\n if (error !== 'cancel') {\n console.error('确认恢复失败:', error);\n }\n }\n\n // 清除文件选择\n event.target.value = '';\n },\n // 恢复数据 - 使用前端辅助分批恢复流程\n async restoreData(file) {\n if (this.isProcessing) {\n this.$message.warning('已有操作正在进行中');\n return;\n }\n this.restoring = true;\n this.isProcessing = true;\n this.processingError = null;\n this.processingStartTime = Date.now();\n this.processingProgress = {\n current: 0,\n total: 0,\n message: '',\n percentage: 0\n };\n try {\n // 解析备份文件\n const fileContent = await file.text();\n let backupData;\n try {\n backupData = JSON.parse(fileContent);\n } catch (parseError) {\n throw new Error('备份文件格式无效,请选择有效的 JSON 文件');\n }\n\n // 创建 RestoreProcessor 实例\n this.currentRestoreProcessor = new RestoreProcessor({\n chunkSize: 100,\n // 每批恢复 100 条\n onProgress: progress => this.handleProgress(progress),\n onError: error => this.handleError(error)\n });\n const result = await this.currentRestoreProcessor.restore(backupData);\n\n // 恢复完成,重置恢复状态\n this.restoring = false;\n this.isProcessing = false;\n this.currentRestoreProcessor = null;\n this.processingStartTime = null;\n\n // 显示恢复成功消息\n this.$message.success(`恢复完成!已恢复 ${result.restoredFiles} 个文件和 ${result.restoredSettings} 个设置项,正在重建索引...`);\n\n // 短暂延迟后自动开始重建索引\n await new Promise(resolve => setTimeout(resolve, 500));\n await this.rebuildIndex();\n } catch (error) {\n console.error('恢复数据失败:', error);\n\n // 出错时重置状态\n this.restoring = false;\n this.isProcessing = false;\n this.currentRestoreProcessor = null;\n this.processingStartTime = null;\n if (error.code !== 'ABORTED') {\n const errorMessage = error.suggestion ? `${error.message}。${error.suggestion}` : error.message;\n this.$message.error('恢复数据失败: ' + errorMessage);\n this.processingError = {\n message: error.message,\n suggestion: error.suggestion,\n recoverable: error.recoverable\n };\n }\n }\n },\n // 格式化时间\n formatTime(timestamp) {\n if (!timestamp) return '未知';\n const date = new Date(timestamp);\n return date.toLocaleString('zh-CN', {\n year: 'numeric',\n month: '2-digit',\n day: '2-digit',\n hour: '2-digit',\n minute: '2-digit'\n });\n },\n // 计算百分比\n getPercentage(value, total) {\n if (!total || total === 0) return 0;\n return Math.round(value / total * 100);\n },\n // 计算时间差\n getTimeAgo(timestamp) {\n if (!timestamp) return '';\n const now = Date.now();\n const diff = now - timestamp;\n const minutes = Math.floor(diff / 60000);\n const hours = Math.floor(diff / 3600000);\n const days = Math.floor(diff / 86400000);\n if (days > 0) return `${days}天前`;\n if (hours > 0) return `${hours}小时前`;\n if (minutes > 0) return `${minutes}分钟前`;\n return '刚刚';\n },\n // 图片加载失败处理\n handleImageError(type) {\n this.loadErrors[type] = true;\n },\n // 检查是否应该显示预览图\n isValidPreview(type, file) {\n if (this.loadErrors[type]) return false;\n if (!file?.metadata?.FileType) return false;\n return file.metadata.FileType.includes('image') || file.metadata.FileType.includes('video');\n },\n // 打开发布页面\n openReleases() {\n window.open('https://github.com/MarSeventh/CloudFlare-ImgBed/releases', '_blank');\n },\n // 判断是否为图片文件\n isImageFile(file) {\n if (!file) return false;\n // 优先通过 FileType 判断\n if (file.metadata?.FileType?.includes('image')) return true;\n // 通过文件名后缀判断\n const fileName = file.metadata?.FileName || file.id || '';\n const extension = fileName.substring(fileName.lastIndexOf('.') + 1).toLowerCase();\n const imageExtensions = ['jpg', 'jpeg', 'png', 'gif', 'bmp', 'webp', 'svg', 'ico', 'tiff', 'tif', 'avif', 'heic', 'heif'];\n return imageExtensions.includes(extension);\n },\n // 判断是否为视频文件\n isVideoFile(file) {\n if (!file) return false;\n // 优先通过 FileType 判断\n if (file.metadata?.FileType?.includes('video')) return true;\n // 通过文件名后缀判断\n const fileName = file.metadata?.FileName || file.id || '';\n const extension = fileName.substring(fileName.lastIndexOf('.') + 1).toLowerCase();\n const videoExtensions = ['mp4', 'webm', 'ogg', 'avi', 'mov', 'flv', 'wmv', 'mkv', 'm4v', '3gp', 'mpeg', 'mpg'];\n return videoExtensions.includes(extension);\n },\n // 在新窗口打开文件\n openFileInNewTab(file) {\n if (!file?.id) return;\n window.open('/file/' + file.id, '_blank');\n },\n // 处理进度更新 (Requirements 3.6, 4.6, 9.1, 9.2)\n handleProgress(progress) {\n this.processingPhase = progress.phase;\n this.processingProgress.message = progress.message || '';\n this.processingProgress.current = progress.current || 0;\n\n // 根据不同阶段计算进度百分比\n if (progress.phase === 'fetching') {\n // 获取阶段:基于已获取的记录数估算(假设总数未知时显示已获取数量)\n this.processingProgress.total = progress.total || 0;\n // 获取阶段占总进度的 60%\n if (progress.total && progress.total > 0) {\n this.processingProgress.percentage = Math.min(60, progress.current / progress.total * 60);\n } else {\n // 未知总数时,使用对数增长模拟进度\n this.processingProgress.percentage = Math.min(50, Math.log10(progress.current + 1) * 15);\n }\n } else if (progress.phase === 'sorting') {\n // 排序阶段:占 60-70%\n this.processingProgress.percentage = 65;\n this.processingProgress.total = progress.total || this.processingProgress.total;\n } else if (progress.phase === 'uploading') {\n // 上传阶段:占 70-95%\n this.processingProgress.total = progress.total || 0;\n if (progress.total && progress.total > 0) {\n this.processingProgress.percentage = 70 + progress.current / progress.total * 25;\n }\n } else if (progress.phase === 'finalizing') {\n // 完成阶段:95-100%\n this.processingProgress.percentage = 97;\n } else if (progress.phase === 'building') {\n // 构建备份阶段:70-90%\n this.processingProgress.percentage = 80;\n } else if (progress.phase === 'downloading') {\n // 下载阶段:90-100%\n this.processingProgress.percentage = 95;\n } else if (progress.phase === 'restoring_files') {\n // 恢复文件阶段:0-80%\n this.processingProgress.total = progress.total || 0;\n this.processingProgress.percentage = progress.percentage || 0;\n } else if (progress.phase === 'restoring_settings') {\n // 恢复设置阶段:80-100%\n this.processingProgress.total = progress.total || 0;\n this.processingProgress.percentage = progress.percentage || 80;\n } else if (progress.phase === 'completed') {\n // 完成\n this.processingProgress.percentage = 100;\n } else if (progress.phase === 'retrying') {\n // 重试阶段:保持当前进度\n this.processingProgress.message = progress.message;\n }\n },\n // 处理错误 (Requirement 9.3)\n handleError(error) {\n console.error('批量操作错误:', error);\n this.processingError = {\n message: error.message,\n suggestion: error.suggestion,\n recoverable: error.recoverable\n };\n },\n // 取消当前操作 (Requirement 2.4)\n cancelOperation() {\n if (this.currentRebuilder) {\n this.currentRebuilder.abort();\n this.$message.info('正在取消索引重建...');\n }\n if (this.currentBackupGenerator) {\n this.currentBackupGenerator.abort();\n this.$message.info('正在取消备份...');\n }\n if (this.currentRestoreProcessor) {\n this.currentRestoreProcessor.abort();\n this.$message.info('正在取消恢复...');\n }\n },\n // 重试操作\n retryOperation() {\n this.processingError = null;\n if (this.rebuilding) {\n this.rebuilding = false;\n this.isProcessing = false;\n this.$nextTick(() => {\n this.rebuildIndex();\n });\n } else if (this.backing) {\n this.backing = false;\n this.isProcessing = false;\n this.$nextTick(() => {\n this.backupData();\n });\n }\n },\n // 关闭错误提示\n dismissError() {\n this.processingError = null;\n }\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./SysCogStatus.vue?vue&type=template&id=68ed43d0&scoped=true\"\nimport script from \"./SysCogStatus.vue?vue&type=script&lang=js\"\nexport * from \"./SysCogStatus.vue?vue&type=script&lang=js\"\n\nimport \"./SysCogStatus.vue?vue&type=style&index=0&id=68ed43d0&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-68ed43d0\"]])\n\nexport default __exports__","import { toDisplayString as _toDisplayString, normalizeClass as _normalizeClass, createElementVNode as _createElementVNode, resolveComponent as _resolveComponent, createVNode as _createVNode, renderList as _renderList, Fragment as _Fragment, openBlock as _openBlock, createElementBlock as _createElementBlock, renderSlot as _renderSlot, createBlock as _createBlock, createCommentVNode as _createCommentVNode, vShow as _vShow, withModifiers as _withModifiers, withDirectives as _withDirectives, Transition as _Transition, withCtx as _withCtx, normalizeStyle as _normalizeStyle } from \"vue\";\nconst _hoisted_1 = [\"onClick\"];\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n return _openBlock(), _createElementBlock(\"div\", {\n class: _normalizeClass([\"custom-select\", {\n 'is-open': $data.isOpen\n }]),\n style: _normalizeStyle({\n width: $props.width\n })\n }, [_createElementVNode(\"div\", {\n class: \"custom-select-trigger\",\n onClick: _cache[0] || (_cache[0] = (...args) => $options.toggleDropdown && $options.toggleDropdown(...args))\n }, [_createElementVNode(\"span\", {\n class: _normalizeClass([\"custom-select-value\", {\n 'is-placeholder': !$props.modelValue\n }])\n }, _toDisplayString($options.displayLabel), 3), _createVNode(_component_font_awesome_icon, {\n icon: \"chevron-down\",\n class: \"custom-select-arrow\"\n })]), _createVNode(_Transition, {\n name: \"dropdown-fade\"\n }, {\n default: _withCtx(() => [_withDirectives(_createElementVNode(\"div\", {\n class: \"custom-select-dropdown\",\n onClick: _cache[1] || (_cache[1] = _withModifiers(() => {}, [\"stop\"]))\n }, [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($props.options, option => {\n return _openBlock(), _createElementBlock(\"div\", {\n key: option.value,\n class: _normalizeClass([\"custom-select-option\", {\n 'is-selected': $props.modelValue === option.value\n }]),\n onClick: $event => $options.selectOption(option.value)\n }, [_renderSlot(_ctx.$slots, \"option\", {\n option: option\n }, () => [option.icon ? (_openBlock(), _createBlock(_component_font_awesome_icon, {\n key: 0,\n icon: option.icon,\n class: \"option-icon\"\n }, null, 8, [\"icon\"])) : _createCommentVNode(\"\", true), _createElementVNode(\"span\", null, _toDisplayString(option.label), 1)], true)], 10, _hoisted_1);\n }), 128))], 512), [[_vShow, $data.isOpen]])]),\n _: 3\n })], 6);\n}","import \"core-js/modules/es.iterator.constructor.js\";\nimport \"core-js/modules/es.iterator.find.js\";\nexport default {\n name: 'CustomSelect',\n props: {\n modelValue: {\n type: [String, Number],\n default: ''\n },\n options: {\n type: Array,\n required: true\n // 格式: [{ value: '', label: '', icon?: '' }]\n },\n placeholder: {\n type: String,\n default: '请选择'\n },\n width: {\n type: String,\n default: '160px'\n }\n },\n emits: ['update:modelValue', 'change'],\n data() {\n return {\n isOpen: false\n };\n },\n computed: {\n displayLabel() {\n const selected = this.options.find(opt => opt.value === this.modelValue);\n return selected ? selected.label : this.placeholder;\n }\n },\n mounted() {\n document.addEventListener('click', this.handleClickOutside);\n },\n beforeUnmount() {\n document.removeEventListener('click', this.handleClickOutside);\n },\n methods: {\n toggleDropdown() {\n this.isOpen = !this.isOpen;\n },\n selectOption(value) {\n this.$emit('update:modelValue', value);\n this.$emit('change', value);\n this.isOpen = false;\n },\n handleClickOutside(e) {\n if (!this.$el.contains(e.target)) {\n this.isOpen = false;\n }\n }\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./CustomSelect.vue?vue&type=template&id=6c59d112&scoped=true\"\nimport script from \"./CustomSelect.vue?vue&type=script&lang=js\"\nexport * from \"./CustomSelect.vue?vue&type=script&lang=js\"\n\nimport \"./CustomSelect.vue?vue&type=style&index=0&id=6c59d112&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-6c59d112\"]])\n\nexport default __exports__","import { resolveComponent as _resolveComponent, createVNode as _createVNode, withCtx as _withCtx, createTextVNode as _createTextVNode, createElementVNode as _createElementVNode, renderList as _renderList, Fragment as _Fragment, openBlock as _openBlock, createElementBlock as _createElementBlock, toDisplayString as _toDisplayString, createCommentVNode as _createCommentVNode, createBlock as _createBlock, withModifiers as _withModifiers, normalizeClass as _normalizeClass, resolveDirective as _resolveDirective, withDirectives as _withDirectives } from \"vue\";\nconst _hoisted_1 = {\n class: \"upload-settings\"\n};\nconst _hoisted_2 = {\n class: \"page-header\"\n};\nconst _hoisted_3 = {\n class: \"first-title\"\n};\nconst _hoisted_4 = {\n class: \"header-actions\"\n};\nconst _hoisted_5 = {\n class: \"group-header\"\n};\nconst _hoisted_6 = {\n class: \"group-title\"\n};\nconst _hoisted_7 = {\n key: 0,\n class: \"load-balance-switch\"\n};\nconst _hoisted_8 = {\n key: 0,\n class: \"channel-cards\"\n};\nconst _hoisted_9 = [\"onMousemove\", \"onMouseleave\"];\nconst _hoisted_10 = {\n class: \"card-header\"\n};\nconst _hoisted_11 = {\n class: \"card-title\"\n};\nconst _hoisted_12 = {\n class: \"channel-name\"\n};\nconst _hoisted_13 = {\n class: \"card-body\"\n};\nconst _hoisted_14 = {\n class: \"card-info\"\n};\nconst _hoisted_15 = {\n class: \"info-item\"\n};\nconst _hoisted_16 = {\n class: \"info-text\"\n};\nconst _hoisted_17 = {\n key: 0,\n class: \"info-item\"\n};\nconst _hoisted_18 = {\n class: \"info-text\"\n};\nconst _hoisted_19 = {\n key: 1,\n class: \"info-item\"\n};\nconst _hoisted_20 = [\"title\"];\nconst _hoisted_21 = {\n class: \"info-item\"\n};\nconst _hoisted_22 = {\n class: \"info-text\"\n};\nconst _hoisted_23 = {\n key: 0,\n class: \"info-item\"\n};\nconst _hoisted_24 = [\"title\"];\nconst _hoisted_25 = {\n class: \"info-item\"\n};\nconst _hoisted_26 = {\n class: \"info-text\"\n};\nconst _hoisted_27 = {\n class: \"info-item\"\n};\nconst _hoisted_28 = {\n class: \"info-text\"\n};\nconst _hoisted_29 = {\n class: \"info-item\"\n};\nconst _hoisted_30 = {\n class: \"info-text\"\n};\nconst _hoisted_31 = {\n key: 0,\n class: \"quota-mini\"\n};\nconst _hoisted_32 = {\n class: \"quota-text\"\n};\nconst _hoisted_33 = {\n class: \"card-actions\"\n};\nconst _hoisted_34 = {\n key: 1,\n class: \"empty-tip\"\n};\nconst _hoisted_35 = {\n class: \"form-warning\"\n};\nconst _hoisted_36 = {\n class: \"quota-label\"\n};\nconst _hoisted_37 = {\n class: \"quota-status\"\n};\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n const _component_el_tooltip = _resolveComponent(\"el-tooltip\");\n const _component_CustomSelect = _resolveComponent(\"CustomSelect\");\n const _component_el_button = _resolveComponent(\"el-button\");\n const _component_el_tag = _resolveComponent(\"el-tag\");\n const _component_el_switch = _resolveComponent(\"el-switch\");\n const _component_el_progress = _resolveComponent(\"el-progress\");\n const _component_el_option = _resolveComponent(\"el-option\");\n const _component_el_select = _resolveComponent(\"el-select\");\n const _component_el_form_item = _resolveComponent(\"el-form-item\");\n const _component_el_input = _resolveComponent(\"el-input\");\n const _component_el_input_number = _resolveComponent(\"el-input-number\");\n const _component_el_form = _resolveComponent(\"el-form\");\n const _component_el_dialog = _resolveComponent(\"el-dialog\");\n const _component_el_descriptions_item = _resolveComponent(\"el-descriptions-item\");\n const _component_el_descriptions = _resolveComponent(\"el-descriptions\");\n const _directive_loading = _resolveDirective(\"loading\");\n return _withDirectives((_openBlock(), _createElementBlock(\"div\", _hoisted_1, [_createElementVNode(\"div\", _hoisted_2, [_createElementVNode(\"h3\", _hoisted_3, [_cache[59] || (_cache[59] = _createTextVNode(\" 上传渠道管理 \", -1)), _createVNode(_component_el_tooltip, {\n content: \"管理所有上传渠道的配置,点击卡片查看详情或编辑\",\n placement: \"right\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"question-circle\",\n class: \"help-icon\"\n })]),\n _: 1\n })]), _createElementVNode(\"div\", _hoisted_4, [_createVNode(_component_CustomSelect, {\n modelValue: $data.channelFilter,\n \"onUpdate:modelValue\": _cache[0] || (_cache[0] = $event => $data.channelFilter = $event),\n options: $options.filterOptions,\n placeholder: \"筛选渠道类型\",\n width: \"160px\"\n }, null, 8, [\"modelValue\", \"options\"]), _createVNode(_component_el_button, {\n type: \"primary\",\n onClick: _cache[1] || (_cache[1] = $event => $data.showAddDialog = true),\n class: \"add-btn\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"plus\",\n style: {\n \"margin-right\": \"6px\"\n }\n }), _cache[60] || (_cache[60] = _createTextVNode(\" 添加渠道 \", -1))]),\n _: 1\n })])]), (_openBlock(true), _createElementBlock(_Fragment, null, _renderList($options.filteredChannels, channelType => {\n return _openBlock(), _createElementBlock(\"div\", {\n key: channelType.value,\n class: \"channel-group\"\n }, [_createElementVNode(\"div\", _hoisted_5, [_createElementVNode(\"div\", _hoisted_6, [_createVNode(_component_font_awesome_icon, {\n icon: $options.getChannelIcon(channelType.value),\n class: \"group-icon\"\n }, null, 8, [\"icon\"]), _createElementVNode(\"span\", null, _toDisplayString(channelType.label), 1), _createVNode(_component_el_tag, {\n size: \"small\",\n type: \"info\",\n class: \"channel-count\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($options.getChannelList(channelType.value).length), 1)]),\n _: 2\n }, 1024)]), $options.hasLoadBalance(channelType.value) ? (_openBlock(), _createElementBlock(\"div\", _hoisted_7, [_cache[61] || (_cache[61] = _createElementVNode(\"span\", {\n class: \"switch-label\"\n }, \"负载均衡\", -1)), _createVNode(_component_el_switch, {\n modelValue: $options.getSettings(channelType.value).loadBalance.enabled,\n \"onUpdate:modelValue\": $event => $options.getSettings(channelType.value).loadBalance.enabled = $event,\n size: \"small\",\n onChange: $options.saveSettings\n }, null, 8, [\"modelValue\", \"onUpdate:modelValue\", \"onChange\"])])) : _createCommentVNode(\"\", true)]), $options.getChannelList(channelType.value).length > 0 ? (_openBlock(), _createElementBlock(\"div\", _hoisted_8, [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($options.getChannelList(channelType.value), (channel, index) => {\n return _openBlock(), _createElementBlock(\"div\", {\n key: channel.name || index,\n class: _normalizeClass([\"channel-card\", [channelType.value, {\n 'disabled': !channel.enabled,\n 'fixed': channel.fixed\n }]]),\n onMousemove: $event => $options.handleCardMouseMove($event, channelType.value, index),\n onMouseleave: $event => $options.handleCardMouseLeave(channelType.value, index)\n }, [_createElementVNode(\"div\", {\n class: \"card-glow\",\n ref_for: true,\n ref: `glow-${channelType.value}-${index}`\n }, null, 512), _createElementVNode(\"div\", _hoisted_10, [_createElementVNode(\"div\", _hoisted_11, [_createElementVNode(\"span\", _hoisted_12, _toDisplayString(channel.name || '未命名渠道'), 1), channel.fixed ? (_openBlock(), _createBlock(_component_el_tag, {\n key: 0,\n size: \"small\",\n type: \"warning\"\n }, {\n default: _withCtx(() => [...(_cache[62] || (_cache[62] = [_createTextVNode(\"环境变量\", -1)]))]),\n _: 1\n })) : _createCommentVNode(\"\", true)]), _createVNode(_component_el_switch, {\n modelValue: channel.enabled,\n \"onUpdate:modelValue\": $event => channel.enabled = $event,\n size: \"small\",\n onClick: _cache[2] || (_cache[2] = _withModifiers(() => {}, [\"stop\"])),\n onChange: $options.saveSettings\n }, null, 8, [\"modelValue\", \"onUpdate:modelValue\", \"onChange\"])]), _createElementVNode(\"div\", _hoisted_13, [_createElementVNode(\"div\", _hoisted_14, [channelType.value === 'telegram' ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 0\n }, [_createElementVNode(\"div\", _hoisted_15, [_createVNode(_component_font_awesome_icon, {\n icon: \"robot\",\n class: \"info-icon\"\n }), _createElementVNode(\"span\", _hoisted_16, \"Bot: \" + _toDisplayString($options.maskText(channel.botToken)), 1)]), channel.chatId ? (_openBlock(), _createElementBlock(\"div\", _hoisted_17, [_createVNode(_component_font_awesome_icon, {\n icon: \"comments\",\n class: \"info-icon\"\n }), _createElementVNode(\"span\", _hoisted_18, \"Channel: \" + _toDisplayString($options.maskText(channel.chatId)), 1)])) : _createCommentVNode(\"\", true)], 64)) : channelType.value === 'cfr2' ? (_openBlock(), _createElementBlock(\"div\", _hoisted_19, [_createVNode(_component_font_awesome_icon, {\n icon: \"link\",\n class: \"info-icon\"\n }), _createElementVNode(\"span\", {\n class: \"info-text\",\n title: channel.publicUrl\n }, _toDisplayString(channel.publicUrl || '未设置公开链接'), 9, _hoisted_20)])) : channelType.value === 's3' ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 2\n }, [_createElementVNode(\"div\", _hoisted_21, [_createVNode(_component_font_awesome_icon, {\n icon: \"server\",\n class: \"info-icon\"\n }), _createElementVNode(\"span\", _hoisted_22, _toDisplayString(channel.bucketName || '未设置'), 1)]), channel.endpoint ? (_openBlock(), _createElementBlock(\"div\", _hoisted_23, [_createVNode(_component_font_awesome_icon, {\n icon: \"link\",\n class: \"info-icon\"\n }), _createElementVNode(\"span\", {\n class: \"info-text\",\n title: channel.endpoint\n }, _toDisplayString(channel.endpoint), 9, _hoisted_24)])) : _createCommentVNode(\"\", true)], 64)) : channelType.value === 'discord' ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 3\n }, [_createElementVNode(\"div\", _hoisted_25, [_createVNode(_component_font_awesome_icon, {\n icon: \"robot\",\n class: \"info-icon\"\n }), _createElementVNode(\"span\", _hoisted_26, \"Bot: \" + _toDisplayString($options.maskText(channel.botToken)), 1)]), _createElementVNode(\"div\", _hoisted_27, [_createVNode(_component_font_awesome_icon, {\n icon: \"hashtag\",\n class: \"info-icon\"\n }), _createElementVNode(\"span\", _hoisted_28, \"Channel: \" + _toDisplayString($options.maskText(channel.channelId)), 1)]), channel.isNitro ? (_openBlock(), _createBlock(_component_el_tag, {\n key: 0,\n size: \"small\",\n type: \"success\"\n }, {\n default: _withCtx(() => [...(_cache[63] || (_cache[63] = [_createTextVNode(\"Nitro\", -1)]))]),\n _: 1\n })) : _createCommentVNode(\"\", true)], 64)) : channelType.value === 'huggingface' ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 4\n }, [_createElementVNode(\"div\", _hoisted_29, [_createVNode(_component_font_awesome_icon, {\n icon: \"database\",\n class: \"info-icon\"\n }), _createElementVNode(\"span\", _hoisted_30, _toDisplayString(channel.repo || '未设置仓库'), 1)]), channel.isPrivate ? (_openBlock(), _createBlock(_component_el_tag, {\n key: 0,\n size: \"small\",\n type: \"warning\"\n }, {\n default: _withCtx(() => [...(_cache[64] || (_cache[64] = [_createTextVNode(\"私有\", -1)]))]),\n _: 1\n })) : _createCommentVNode(\"\", true)], 64)) : _createCommentVNode(\"\", true)]), channel.quota?.enabled ? (_openBlock(), _createElementBlock(\"div\", _hoisted_31, [_createVNode(_component_el_progress, {\n percentage: $options.getQuotaPercentage(channel),\n status: $options.getQuotaStatus(channel),\n \"stroke-width\": 6\n }, null, 8, [\"percentage\", \"status\"]), _createElementVNode(\"span\", _hoisted_32, _toDisplayString($options.getQuotaText(channel)), 1)])) : _createCommentVNode(\"\", true)]), _createElementVNode(\"div\", _hoisted_33, [_createVNode(_component_el_button, {\n text: \"\",\n type: \"primary\",\n size: \"small\",\n onClick: $event => $options.openDetailDialog(channelType.value, index)\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"eye\",\n style: {\n \"margin-right\": \"4px\"\n }\n }), _cache[65] || (_cache[65] = _createTextVNode(\"详情 \", -1))]),\n _: 1\n }, 8, [\"onClick\"]), _createVNode(_component_el_button, {\n text: \"\",\n type: \"primary\",\n size: \"small\",\n onClick: $event => $options.openEditDialog(channelType.value, index)\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"edit\",\n style: {\n \"margin-right\": \"4px\"\n }\n }), _cache[66] || (_cache[66] = _createTextVNode(\"编辑 \", -1))]),\n _: 1\n }, 8, [\"onClick\"]), _createVNode(_component_el_button, {\n text: \"\",\n type: \"danger\",\n size: \"small\",\n onClick: $event => $options.deleteChannel(channelType.value, index),\n disabled: channel.fixed\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"trash-alt\",\n style: {\n \"margin-right\": \"4px\"\n }\n }), _cache[67] || (_cache[67] = _createTextVNode(\"删除 \", -1))]),\n _: 1\n }, 8, [\"onClick\", \"disabled\"])])], 42, _hoisted_9);\n }), 128))])) : (_openBlock(), _createElementBlock(\"div\", _hoisted_34, [_createVNode(_component_font_awesome_icon, {\n icon: \"inbox\",\n class: \"empty-icon\"\n }), _createElementVNode(\"span\", null, \"暂无 \" + _toDisplayString(channelType.label) + \" 渠道\", 1)]))]);\n }), 128)), _createVNode(_component_el_dialog, {\n modelValue: $data.showAddDialog,\n \"onUpdate:modelValue\": _cache[26] || (_cache[26] = $event => $data.showAddDialog = $event),\n title: \"添加新渠道\",\n class: \"channel-dialog\",\n \"destroy-on-close\": \"\",\n onClosed: $options.resetAddForm\n }, {\n footer: _withCtx(() => [_createVNode(_component_el_button, {\n onClick: _cache[25] || (_cache[25] = $event => $data.showAddDialog = false)\n }, {\n default: _withCtx(() => [...(_cache[73] || (_cache[73] = [_createTextVNode(\"取消\", -1)]))]),\n _: 1\n }), _createVNode(_component_el_button, {\n type: \"primary\",\n onClick: $options.confirmAddChannel\n }, {\n default: _withCtx(() => [...(_cache[74] || (_cache[74] = [_createTextVNode(\"确认添加\", -1)]))]),\n _: 1\n }, 8, [\"onClick\"])]),\n default: _withCtx(() => [_createVNode(_component_el_form, {\n model: $data.newChannel,\n \"label-position\": \"top\",\n ref: \"addForm\",\n rules: $data.addRules\n }, {\n default: _withCtx(() => [_createVNode(_component_el_form_item, {\n label: \"渠道类型\",\n prop: \"type\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_select, {\n modelValue: $data.newChannel.type,\n \"onUpdate:modelValue\": _cache[3] || (_cache[3] = $event => $data.newChannel.type = $event),\n placeholder: \"请选择渠道类型\",\n style: {\n \"width\": \"100%\"\n },\n onChange: $options.onChannelTypeChange\n }, {\n default: _withCtx(() => [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($data.addableChannels, ch => {\n return _openBlock(), _createBlock(_component_el_option, {\n key: ch.value,\n label: ch.label,\n value: ch.value\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: $options.getChannelIcon(ch.value),\n class: \"select-option-icon\"\n }, null, 8, [\"icon\"]), _createTextVNode(\" \" + _toDisplayString(ch.label), 1)]),\n _: 2\n }, 1032, [\"label\", \"value\"]);\n }), 128))]),\n _: 1\n }, 8, [\"modelValue\", \"onChange\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"渠道名称\",\n prop: \"name\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.newChannel.name,\n \"onUpdate:modelValue\": _cache[4] || (_cache[4] = $event => $data.newChannel.name = $event),\n placeholder: \"请输入渠道名称\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), $data.newChannel.type === 'telegram' ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 0\n }, [_createVNode(_component_el_form_item, {\n label: \"Bot Token\",\n prop: \"botToken\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.newChannel.botToken,\n \"onUpdate:modelValue\": _cache[5] || (_cache[5] = $event => $data.newChannel.botToken = $event),\n type: \"password\",\n \"show-password\": \"\",\n placeholder: \"请输入 Bot Token\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"Chat ID\",\n prop: \"chatId\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.newChannel.chatId,\n \"onUpdate:modelValue\": _cache[6] || (_cache[6] = $event => $data.newChannel.chatId = $event),\n type: \"password\",\n \"show-password\": \"\",\n placeholder: \"请输入 Chat ID\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"代理域名\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.newChannel.proxyUrl,\n \"onUpdate:modelValue\": _cache[7] || (_cache[7] = $event => $data.newChannel.proxyUrl = $event),\n placeholder: \"可选,例如: your-proxy.example.com\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n })], 64)) : $data.newChannel.type === 's3' ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 1\n }, [_createVNode(_component_el_form_item, {\n label: \"Endpoint\",\n prop: \"endpoint\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.newChannel.endpoint,\n \"onUpdate:modelValue\": _cache[8] || (_cache[8] = $event => $data.newChannel.endpoint = $event),\n placeholder: \"例如: https://s3.us-east-005.backblazeb2.com\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"CDN 域名\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.newChannel.cdnDomain,\n \"onUpdate:modelValue\": _cache[9] || (_cache[9] = $event => $data.newChannel.cdnDomain = $event),\n placeholder: \"如果有 CDN,请配置 CDN 域名,例如:https://cdn.example.com\"\n }, null, 8, [\"modelValue\"]), _cache[68] || (_cache[68] = _createElementVNode(\"span\", {\n class: \"form-tip\"\n }, \"可选配置。配置后将优先通过 CDN 读取文件,提高访问速度和降低成本\", -1))]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"存储桶名称\",\n prop: \"bucketName\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.newChannel.bucketName,\n \"onUpdate:modelValue\": _cache[10] || (_cache[10] = $event => $data.newChannel.bucketName = $event),\n placeholder: \"请输入存储桶名称\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"存储桶区域\",\n prop: \"region\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.newChannel.region,\n \"onUpdate:modelValue\": _cache[11] || (_cache[11] = $event => $data.newChannel.region = $event),\n placeholder: \"默认填写 auto\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"访问密钥 ID\",\n prop: \"accessKeyId\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.newChannel.accessKeyId,\n \"onUpdate:modelValue\": _cache[12] || (_cache[12] = $event => $data.newChannel.accessKeyId = $event),\n type: \"password\",\n \"show-password\": \"\",\n placeholder: \"请输入访问密钥 ID\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"机密访问密钥\",\n prop: \"secretAccessKey\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.newChannel.secretAccessKey,\n \"onUpdate:modelValue\": _cache[13] || (_cache[13] = $event => $data.newChannel.secretAccessKey = $event),\n type: \"password\",\n \"show-password\": \"\",\n placeholder: \"请输入机密访问密钥\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"路径风格\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_switch, {\n modelValue: $data.newChannel.pathStyle,\n \"onUpdate:modelValue\": _cache[14] || (_cache[14] = $event => $data.newChannel.pathStyle = $event)\n }, null, 8, [\"modelValue\"]), _cache[69] || (_cache[69] = _createElementVNode(\"span\", {\n class: \"form-tip\"\n }, \"使用 OpenList 时需开启\", -1))]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"容量限制\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_switch, {\n modelValue: $data.newChannel.quota.enabled,\n \"onUpdate:modelValue\": _cache[15] || (_cache[15] = $event => $data.newChannel.quota.enabled = $event)\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), $data.newChannel.quota?.enabled ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 0\n }, [_createVNode(_component_el_form_item, {\n label: \"容量上限 (GB)\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input_number, {\n modelValue: $data.newChannel.quota.limitGB,\n \"onUpdate:modelValue\": _cache[16] || (_cache[16] = $event => $data.newChannel.quota.limitGB = $event),\n min: 0.1,\n step: 1,\n precision: 1\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"停用阈值 (%)\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input_number, {\n modelValue: $data.newChannel.quota.threshold,\n \"onUpdate:modelValue\": _cache[17] || (_cache[17] = $event => $data.newChannel.quota.threshold = $event),\n min: 50,\n max: 100,\n step: 5\n }, null, 8, [\"modelValue\"])]),\n _: 1\n })], 64)) : _createCommentVNode(\"\", true)], 64)) : $data.newChannel.type === 'discord' ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 2\n }, [_createVNode(_component_el_form_item, {\n label: \"Bot Token\",\n prop: \"botToken\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.newChannel.botToken,\n \"onUpdate:modelValue\": _cache[18] || (_cache[18] = $event => $data.newChannel.botToken = $event),\n type: \"password\",\n \"show-password\": \"\",\n placeholder: \"请输入 Bot Token\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"Channel ID\",\n prop: \"channelId\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.newChannel.channelId,\n \"onUpdate:modelValue\": _cache[19] || (_cache[19] = $event => $data.newChannel.channelId = $event),\n type: \"password\",\n \"show-password\": \"\",\n placeholder: \"请输入 Channel ID\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"代理域名\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.newChannel.proxyUrl,\n \"onUpdate:modelValue\": _cache[20] || (_cache[20] = $event => $data.newChannel.proxyUrl = $event),\n placeholder: \"可选,例如: your-proxy.example.com\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"Nitro 会员\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_switch, {\n modelValue: $data.newChannel.isNitro,\n \"onUpdate:modelValue\": _cache[21] || (_cache[21] = $event => $data.newChannel.isNitro = $event)\n }, null, 8, [\"modelValue\"]), _cache[70] || (_cache[70] = _createElementVNode(\"span\", {\n class: \"form-tip\"\n }, \"会员单文件限制 25MB,否则为 10MB\", -1))]),\n _: 1\n }), _createElementVNode(\"div\", _hoisted_35, [_createVNode(_component_font_awesome_icon, {\n icon: \"exclamation-triangle\",\n style: {\n \"margin-right\": \"6px\"\n }\n }), _cache[71] || (_cache[71] = _createTextVNode(\" Discord 有接口频率限制,不建议将其用作大规模并发场景 \", -1))])], 64)) : $data.newChannel.type === 'huggingface' ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 3\n }, [_createVNode(_component_el_form_item, {\n label: \"仓库名\",\n prop: \"repo\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.newChannel.repo,\n \"onUpdate:modelValue\": _cache[22] || (_cache[22] = $event => $data.newChannel.repo = $event),\n placeholder: \"格式: username/repo-name\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"Access Token\",\n prop: \"token\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.newChannel.token,\n \"onUpdate:modelValue\": _cache[23] || (_cache[23] = $event => $data.newChannel.token = $event),\n type: \"password\",\n \"show-password\": \"\",\n placeholder: \"请输入 Access Token\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"私有仓库\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_switch, {\n modelValue: $data.newChannel.isPrivate,\n \"onUpdate:modelValue\": _cache[24] || (_cache[24] = $event => $data.newChannel.isPrivate = $event)\n }, null, 8, [\"modelValue\"]), _cache[72] || (_cache[72] = _createElementVNode(\"span\", {\n class: \"form-tip\"\n }, \"私有仓库限制 100GB\", -1))]),\n _: 1\n })], 64)) : _createCommentVNode(\"\", true)]),\n _: 1\n }, 8, [\"model\", \"rules\"])]),\n _: 1\n }, 8, [\"modelValue\", \"onClosed\"]), _createVNode(_component_el_dialog, {\n modelValue: $data.showDetailDialog,\n \"onUpdate:modelValue\": _cache[28] || (_cache[28] = $event => $data.showDetailDialog = $event),\n title: '渠道详情 - ' + ($data.currentChannel?.name || ''),\n class: \"channel-dialog\",\n onClosed: $options.resetDetailData\n }, {\n footer: _withCtx(() => [_createVNode(_component_el_button, {\n onClick: _cache[27] || (_cache[27] = $event => $data.showDetailDialog = false)\n }, {\n default: _withCtx(() => [...(_cache[77] || (_cache[77] = [_createTextVNode(\"关闭\", -1)]))]),\n _: 1\n }), _createVNode(_component_el_button, {\n type: \"primary\",\n onClick: $options.openEditFromDetail\n }, {\n default: _withCtx(() => [...(_cache[78] || (_cache[78] = [_createTextVNode(\"编辑\", -1)]))]),\n _: 1\n }, 8, [\"onClick\"])]),\n default: _withCtx(() => [_createVNode(_component_el_descriptions, {\n column: 1,\n border: \"\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_descriptions_item, {\n label: \"渠道名称\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($data.currentChannel?.name), 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"渠道类型\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($options.getChannelTypeLabel($data.currentChannelType)), 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"状态\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_tag, {\n type: $data.currentChannel?.enabled ? 'success' : 'info'\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($data.currentChannel?.enabled ? '已启用' : '已禁用'), 1)]),\n _: 1\n }, 8, [\"type\"])]),\n _: 1\n }), $data.currentChannel?.fixed ? (_openBlock(), _createBlock(_component_el_descriptions_item, {\n key: 0,\n label: \"配置来源\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_tag, {\n type: \"warning\"\n }, {\n default: _withCtx(() => [...(_cache[75] || (_cache[75] = [_createTextVNode(\"环境变量\", -1)]))]),\n _: 1\n })]),\n _: 1\n })) : _createCommentVNode(\"\", true), $data.currentChannelType === 'telegram' ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 1\n }, [_createVNode(_component_el_descriptions_item, {\n label: \"Bot Token\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($options.maskText($data.currentChannel?.botToken, 10)), 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"Chat ID\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($options.maskText($data.currentChannel?.chatId, 6)), 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"代理域名\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($data.currentChannel?.proxyUrl || '未设置'), 1)]),\n _: 1\n })], 64)) : $data.currentChannelType === 'cfr2' ? (_openBlock(), _createBlock(_component_el_descriptions_item, {\n key: 2,\n label: \"公开访问链接\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n \"model-value\": $data.currentChannel?.publicUrl || '未设置',\n readonly: \"\"\n }, null, 8, [\"model-value\"])]),\n _: 1\n })) : $data.currentChannelType === 's3' ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 3\n }, [_createVNode(_component_el_descriptions_item, {\n label: \"Endpoint\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n \"model-value\": $data.currentChannel?.endpoint,\n readonly: \"\"\n }, null, 8, [\"model-value\"])]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"CDN 域名\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n \"model-value\": $data.currentChannel?.cdnDomain || '未设置',\n readonly: \"\"\n }, null, 8, [\"model-value\"])]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"存储桶名称\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($data.currentChannel?.bucketName), 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"存储桶区域\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($data.currentChannel?.region), 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"路径风格\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($data.currentChannel?.pathStyle ? '是' : '否'), 1)]),\n _: 1\n })], 64)) : $data.currentChannelType === 'discord' ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 4\n }, [_createVNode(_component_el_descriptions_item, {\n label: \"Bot Token\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($options.maskText($data.currentChannel?.botToken, 10)), 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"Channel ID\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($options.maskText($data.currentChannel?.channelId, 6)), 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"代理域名\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($data.currentChannel?.proxyUrl || '未设置'), 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"Nitro 会员\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($data.currentChannel?.isNitro ? '是' : '否'), 1)]),\n _: 1\n })], 64)) : $data.currentChannelType === 'huggingface' ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 5\n }, [_createVNode(_component_el_descriptions_item, {\n label: \"仓库名\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($data.currentChannel?.repo), 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"私有仓库\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($data.currentChannel?.isPrivate ? '是' : '否'), 1)]),\n _: 1\n })], 64)) : _createCommentVNode(\"\", true), $data.currentChannel?.quota?.enabled ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 6\n }, [_createVNode(_component_el_descriptions_item, {\n label: \"容量限制\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($data.currentChannel?.quota?.limitGB) + \" GB\", 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"停用阈值\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($data.currentChannel?.quota?.threshold) + \"%\", 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, null, {\n label: _withCtx(() => [_createElementVNode(\"span\", _hoisted_36, [_cache[76] || (_cache[76] = _createTextVNode(\" 当前用量 \", -1)), _createVNode(_component_el_button, {\n link: \"\",\n type: \"primary\",\n onClick: $options.refreshQuota,\n class: \"refresh-btn\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"sync-alt\",\n class: _normalizeClass({\n 'fa-spin': $data.quotaLoading\n })\n }, null, 8, [\"class\"])]),\n _: 1\n }, 8, [\"onClick\"])])]),\n default: _withCtx(() => [_createElementVNode(\"div\", _hoisted_37, [_createVNode(_component_el_progress, {\n percentage: $options.getQuotaPercentage($data.currentChannel),\n status: $options.getQuotaStatus($data.currentChannel),\n \"stroke-width\": 16,\n \"text-inside\": true,\n format: () => $options.getQuotaText($data.currentChannel)\n }, null, 8, [\"percentage\", \"status\", \"format\"]), _createElementVNode(\"div\", {\n class: _normalizeClass([\"quota-info\", {\n 'quota-warning': $options.isQuotaExceeded($data.currentChannel)\n }])\n }, _toDisplayString($options.getQuotaStatusText($data.currentChannel)), 3)])]),\n _: 1\n })], 64)) : _createCommentVNode(\"\", true)]),\n _: 1\n })]),\n _: 1\n }, 8, [\"modelValue\", \"title\", \"onClosed\"]), _createVNode(_component_el_dialog, {\n modelValue: $data.showEditDialog,\n \"onUpdate:modelValue\": _cache[58] || (_cache[58] = $event => $data.showEditDialog = $event),\n title: '编辑渠道 - ' + ($data.editChannel?.name || ''),\n class: \"channel-dialog\",\n \"destroy-on-close\": \"\",\n onClosed: $options.resetEditData\n }, {\n footer: _withCtx(() => [_createVNode(_component_el_button, {\n onClick: _cache[57] || (_cache[57] = $event => $data.showEditDialog = false)\n }, {\n default: _withCtx(() => [...(_cache[80] || (_cache[80] = [_createTextVNode(\"取消\", -1)]))]),\n _: 1\n }), _createVNode(_component_el_button, {\n type: \"primary\",\n onClick: $options.confirmEditChannel\n }, {\n default: _withCtx(() => [...(_cache[81] || (_cache[81] = [_createTextVNode(\"保存修改\", -1)]))]),\n _: 1\n }, 8, [\"onClick\"])]),\n default: _withCtx(() => [_createVNode(_component_el_form, {\n model: $data.editChannel,\n \"label-position\": \"top\",\n ref: \"editForm\",\n rules: $data.editRules\n }, {\n default: _withCtx(() => [_createVNode(_component_el_form_item, {\n label: \"渠道名称\",\n prop: \"name\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.editChannel.name,\n \"onUpdate:modelValue\": _cache[29] || (_cache[29] = $event => $data.editChannel.name = $event),\n disabled: $data.editChannel.fixed\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"启用渠道\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_switch, {\n modelValue: $data.editChannel.enabled,\n \"onUpdate:modelValue\": _cache[30] || (_cache[30] = $event => $data.editChannel.enabled = $event)\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), $data.currentChannelType === 'telegram' ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 0\n }, [_createVNode(_component_el_form_item, {\n label: \"Bot Token\",\n prop: \"botToken\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.editChannel.botToken,\n \"onUpdate:modelValue\": _cache[31] || (_cache[31] = $event => $data.editChannel.botToken = $event),\n disabled: $data.editChannel.fixed,\n type: \"password\",\n \"show-password\": \"\"\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"Chat ID\",\n prop: \"chatId\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.editChannel.chatId,\n \"onUpdate:modelValue\": _cache[32] || (_cache[32] = $event => $data.editChannel.chatId = $event),\n disabled: $data.editChannel.fixed,\n type: \"password\",\n \"show-password\": \"\"\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"代理域名\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.editChannel.proxyUrl,\n \"onUpdate:modelValue\": _cache[33] || (_cache[33] = $event => $data.editChannel.proxyUrl = $event),\n placeholder: \"例如: your-proxy.example.com\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n })], 64)) : $data.currentChannelType === 'cfr2' ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 1\n }, [_createVNode(_component_el_form_item, {\n label: \"公开访问链接\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.editChannel.publicUrl,\n \"onUpdate:modelValue\": _cache[34] || (_cache[34] = $event => $data.editChannel.publicUrl = $event)\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"容量限制\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_switch, {\n modelValue: $data.editChannel.quota.enabled,\n \"onUpdate:modelValue\": _cache[35] || (_cache[35] = $event => $data.editChannel.quota.enabled = $event),\n onChange: _cache[36] || (_cache[36] = val => $options.onQuotaEnabledChange(val, $data.editChannel))\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), $data.editChannel.quota?.enabled ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 0\n }, [_createVNode(_component_el_form_item, {\n label: \"容量上限 (GB)\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input_number, {\n modelValue: $data.editChannel.quota.limitGB,\n \"onUpdate:modelValue\": _cache[37] || (_cache[37] = $event => $data.editChannel.quota.limitGB = $event),\n min: 0.1,\n step: 1,\n precision: 1\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"停用阈值 (%)\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input_number, {\n modelValue: $data.editChannel.quota.threshold,\n \"onUpdate:modelValue\": _cache[38] || (_cache[38] = $event => $data.editChannel.quota.threshold = $event),\n min: 50,\n max: 100,\n step: 5\n }, null, 8, [\"modelValue\"])]),\n _: 1\n })], 64)) : _createCommentVNode(\"\", true)], 64)) : $data.currentChannelType === 's3' ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 2\n }, [_createVNode(_component_el_form_item, {\n label: \"Endpoint\",\n prop: \"endpoint\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.editChannel.endpoint,\n \"onUpdate:modelValue\": _cache[39] || (_cache[39] = $event => $data.editChannel.endpoint = $event),\n disabled: $data.editChannel.fixed\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"CDN 域名\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.editChannel.cdnDomain,\n \"onUpdate:modelValue\": _cache[40] || (_cache[40] = $event => $data.editChannel.cdnDomain = $event),\n placeholder: \"如果有 CDN,请配置 CDN 域名,例如:https://cdn.example.com\"\n }, null, 8, [\"modelValue\"]), _cache[79] || (_cache[79] = _createElementVNode(\"span\", {\n class: \"form-tip\"\n }, \"可选配置。配置后将优先通过 CDN 读取文件,提高访问速度和降低成本\", -1))]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"存储桶名称\",\n prop: \"bucketName\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.editChannel.bucketName,\n \"onUpdate:modelValue\": _cache[41] || (_cache[41] = $event => $data.editChannel.bucketName = $event),\n disabled: $data.editChannel.fixed\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"存储桶区域\",\n prop: \"region\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.editChannel.region,\n \"onUpdate:modelValue\": _cache[42] || (_cache[42] = $event => $data.editChannel.region = $event),\n disabled: $data.editChannel.fixed\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"访问密钥 ID\",\n prop: \"accessKeyId\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.editChannel.accessKeyId,\n \"onUpdate:modelValue\": _cache[43] || (_cache[43] = $event => $data.editChannel.accessKeyId = $event),\n disabled: $data.editChannel.fixed,\n type: \"password\",\n \"show-password\": \"\"\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"机密访问密钥\",\n prop: \"secretAccessKey\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.editChannel.secretAccessKey,\n \"onUpdate:modelValue\": _cache[44] || (_cache[44] = $event => $data.editChannel.secretAccessKey = $event),\n disabled: $data.editChannel.fixed,\n type: \"password\",\n \"show-password\": \"\"\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"路径风格\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_switch, {\n modelValue: $data.editChannel.pathStyle,\n \"onUpdate:modelValue\": _cache[45] || (_cache[45] = $event => $data.editChannel.pathStyle = $event),\n disabled: $data.editChannel.fixed\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"容量限制\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_switch, {\n modelValue: $data.editChannel.quota.enabled,\n \"onUpdate:modelValue\": _cache[46] || (_cache[46] = $event => $data.editChannel.quota.enabled = $event),\n onChange: _cache[47] || (_cache[47] = val => $options.onQuotaEnabledChange(val, $data.editChannel))\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), $data.editChannel.quota?.enabled ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 0\n }, [_createVNode(_component_el_form_item, {\n label: \"容量上限 (GB)\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input_number, {\n modelValue: $data.editChannel.quota.limitGB,\n \"onUpdate:modelValue\": _cache[48] || (_cache[48] = $event => $data.editChannel.quota.limitGB = $event),\n min: 0.1,\n step: 1,\n precision: 1\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"停用阈值 (%)\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input_number, {\n modelValue: $data.editChannel.quota.threshold,\n \"onUpdate:modelValue\": _cache[49] || (_cache[49] = $event => $data.editChannel.quota.threshold = $event),\n min: 50,\n max: 100,\n step: 5\n }, null, 8, [\"modelValue\"])]),\n _: 1\n })], 64)) : _createCommentVNode(\"\", true)], 64)) : $data.currentChannelType === 'discord' ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 3\n }, [_createVNode(_component_el_form_item, {\n label: \"Bot Token\",\n prop: \"botToken\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.editChannel.botToken,\n \"onUpdate:modelValue\": _cache[50] || (_cache[50] = $event => $data.editChannel.botToken = $event),\n disabled: $data.editChannel.fixed,\n type: \"password\",\n \"show-password\": \"\"\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"Channel ID\",\n prop: \"channelId\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.editChannel.channelId,\n \"onUpdate:modelValue\": _cache[51] || (_cache[51] = $event => $data.editChannel.channelId = $event),\n disabled: $data.editChannel.fixed,\n type: \"password\",\n \"show-password\": \"\"\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"代理域名\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.editChannel.proxyUrl,\n \"onUpdate:modelValue\": _cache[52] || (_cache[52] = $event => $data.editChannel.proxyUrl = $event),\n placeholder: \"例如: your-proxy.example.com\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"Nitro 会员\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_switch, {\n modelValue: $data.editChannel.isNitro,\n \"onUpdate:modelValue\": _cache[53] || (_cache[53] = $event => $data.editChannel.isNitro = $event)\n }, null, 8, [\"modelValue\"])]),\n _: 1\n })], 64)) : $data.currentChannelType === 'huggingface' ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 4\n }, [_createVNode(_component_el_form_item, {\n label: \"仓库名\",\n prop: \"repo\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.editChannel.repo,\n \"onUpdate:modelValue\": _cache[54] || (_cache[54] = $event => $data.editChannel.repo = $event),\n disabled: $data.editChannel.fixed\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"Access Token\",\n prop: \"token\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.editChannel.token,\n \"onUpdate:modelValue\": _cache[55] || (_cache[55] = $event => $data.editChannel.token = $event),\n disabled: $data.editChannel.fixed,\n type: \"password\",\n \"show-password\": \"\"\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"私有仓库\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_switch, {\n modelValue: $data.editChannel.isPrivate,\n \"onUpdate:modelValue\": _cache[56] || (_cache[56] = $event => $data.editChannel.isPrivate = $event)\n }, null, 8, [\"modelValue\"])]),\n _: 1\n })], 64)) : _createCommentVNode(\"\", true)]),\n _: 1\n }, 8, [\"model\", \"rules\"])]),\n _: 1\n }, 8, [\"modelValue\", \"title\", \"onClosed\"])])), [[_directive_loading, $data.loading]]);\n}","import \"core-js/modules/es.array.push.js\";\nimport \"core-js/modules/es.iterator.constructor.js\";\nimport \"core-js/modules/es.iterator.filter.js\";\nimport \"core-js/modules/es.iterator.find.js\";\nimport \"core-js/modules/es.iterator.for-each.js\";\nimport \"core-js/modules/es.iterator.map.js\";\nimport \"core-js/modules/es.iterator.some.js\";\nimport \"core-js/modules/es.json.stringify.js\";\nimport \"core-js/modules/esnext.json.parse.js\";\nimport fetchWithAuth from '@/utils/fetchWithAuth';\nimport CustomSelect from '@/components/CustomSelect.vue';\nexport default {\n components: {\n CustomSelect\n },\n data() {\n return {\n // 渠道类型筛选\n channelFilter: '',\n // 渠道类型列表\n channels: [{\n value: 'telegram',\n label: 'Telegram'\n }, {\n value: 'cfr2',\n label: 'CloudFlare R2'\n }, {\n value: 's3',\n label: 'S3'\n }, {\n value: 'discord',\n label: 'Discord'\n }, {\n value: 'huggingface',\n label: 'HuggingFace'\n }],\n // 可添加的渠道类型(排除 cfr2,因为只能通过绑定 R2 或 S3 添加)\n addableChannels: [{\n value: 'telegram',\n label: 'Telegram'\n }, {\n value: 's3',\n label: 'S3'\n }, {\n value: 'discord',\n label: 'Discord'\n }, {\n value: 'huggingface',\n label: 'HuggingFace'\n }],\n // 各渠道配置\n telegramSettings: {\n loadBalance: {\n enabled: false\n },\n channels: []\n },\n cfr2Settings: {\n channels: []\n },\n s3Settings: {\n loadBalance: {\n enabled: false\n },\n channels: []\n },\n discordSettings: {\n loadBalance: {\n enabled: false\n },\n channels: []\n },\n huggingfaceSettings: {\n loadBalance: {\n enabled: false\n },\n channels: []\n },\n // 弹窗控制\n showAddDialog: false,\n showDetailDialog: false,\n showEditDialog: false,\n // 当前操作的渠道\n currentChannelType: '',\n currentChannelIndex: -1,\n currentChannel: null,\n editChannel: {},\n // 新增渠道表单\n newChannel: {\n type: '',\n name: '',\n enabled: true,\n // Telegram\n botToken: '',\n chatId: '',\n proxyUrl: '',\n // S3\n endpoint: '',\n cdnDomain: '',\n bucketName: '',\n region: 'auto',\n accessKeyId: '',\n secretAccessKey: '',\n pathStyle: false,\n quota: {\n enabled: false,\n limitGB: 10,\n threshold: 95\n },\n // Discord\n channelId: '',\n isNitro: false,\n // HuggingFace\n repo: '',\n token: '',\n isPrivate: false\n },\n // 添加表单验证规则\n addRules: {\n type: [{\n required: true,\n message: '请选择渠道类型',\n trigger: 'change'\n }],\n name: [{\n required: true,\n message: '请输入渠道名称',\n trigger: 'blur'\n }, {\n pattern: /^[\\u4e00-\\u9fa5a-zA-Z0-9_-]+$/,\n message: '渠道名称只能包含中英文、数字、下划线和横线',\n trigger: 'blur'\n }],\n botToken: [{\n required: true,\n message: '请输入 Bot Token',\n trigger: 'blur'\n }],\n chatId: [{\n required: true,\n message: '请输入 Chat ID',\n trigger: 'blur'\n }],\n channelId: [{\n required: true,\n message: '请输入 Channel ID',\n trigger: 'blur'\n }],\n endpoint: [{\n required: true,\n message: '请输入 Endpoint',\n trigger: 'blur'\n }],\n bucketName: [{\n required: true,\n message: '请输入存储桶名称',\n trigger: 'blur'\n }],\n region: [{\n required: true,\n message: '请输入存储桶区域',\n trigger: 'blur'\n }],\n accessKeyId: [{\n required: true,\n message: '请输入访问密钥 ID',\n trigger: 'blur'\n }],\n secretAccessKey: [{\n required: true,\n message: '请输入机密访问密钥',\n trigger: 'blur'\n }],\n repo: [{\n required: true,\n message: '请输入仓库名',\n trigger: 'blur'\n }],\n token: [{\n required: true,\n message: '请输入 Access Token',\n trigger: 'blur'\n }]\n },\n // 编辑表单验证规则\n editRules: {\n name: [{\n required: true,\n message: '请输入渠道名称',\n trigger: 'blur'\n }, {\n pattern: /^[\\u4e00-\\u9fa5a-zA-Z0-9_-]+$/,\n message: '渠道名称只能包含中英文、数字、下划线和横线',\n trigger: 'blur'\n }],\n botToken: [{\n required: true,\n message: '请输入 Bot Token',\n trigger: 'blur'\n }],\n chatId: [{\n required: true,\n message: '请输入 Chat ID',\n trigger: 'blur'\n }],\n channelId: [{\n required: true,\n message: '请输入 Channel ID',\n trigger: 'blur'\n }],\n endpoint: [{\n required: true,\n message: '请输入 Endpoint',\n trigger: 'blur'\n }],\n bucketName: [{\n required: true,\n message: '请输入存储桶名称',\n trigger: 'blur'\n }],\n region: [{\n required: true,\n message: '请输入存储桶区域',\n trigger: 'blur'\n }],\n accessKeyId: [{\n required: true,\n message: '请输入访问密钥 ID',\n trigger: 'blur'\n }],\n secretAccessKey: [{\n required: true,\n message: '请输入机密访问密钥',\n trigger: 'blur'\n }],\n repo: [{\n required: true,\n message: '请输入仓库名',\n trigger: 'blur'\n }],\n token: [{\n required: true,\n message: '请输入 Access Token',\n trigger: 'blur'\n }]\n },\n // 容量统计数据\n quotaStats: {},\n quotaLoading: false,\n // 加载状态\n loading: false\n };\n },\n computed: {\n // 筛选下拉框选项\n filterOptions() {\n const iconMap = {\n telegram: 'paper-plane',\n cfr2: 'cloud',\n s3: 'database',\n discord: 'comments',\n huggingface: 'robot'\n };\n return [{\n value: '',\n label: '全部类型'\n }, ...this.channels.map(ch => ({\n value: ch.value,\n label: ch.label,\n icon: iconMap[ch.value] || 'server'\n }))];\n },\n // 根据筛选条件过滤渠道类型\n filteredChannels() {\n if (!this.channelFilter) {\n return this.channels;\n }\n return this.channels.filter(ch => ch.value === this.channelFilter);\n }\n },\n methods: {\n // 卡片光斑跟随鼠标\n handleCardMouseMove(event, channelType, index) {\n const card = event.currentTarget;\n const rect = card.getBoundingClientRect();\n const x = event.clientX - rect.left;\n const y = event.clientY - rect.top;\n const refKey = `glow-${channelType}-${index}`;\n const glowEl = this.$refs[refKey];\n if (glowEl && glowEl[0]) {\n glowEl[0].style.opacity = '1';\n glowEl[0].style.left = `${x}px`;\n glowEl[0].style.top = `${y}px`;\n }\n },\n handleCardMouseLeave(channelType, index) {\n const refKey = `glow-${channelType}-${index}`;\n const glowEl = this.$refs[refKey];\n if (glowEl && glowEl[0]) {\n glowEl[0].style.opacity = '0';\n }\n },\n // 获取渠道图标\n getChannelIcon(type) {\n const icons = {\n telegram: 'paper-plane',\n cfr2: 'cloud',\n s3: 'database',\n discord: 'comments',\n huggingface: 'robot'\n };\n return icons[type] || 'server';\n },\n // 获取渠道类型标签\n getChannelTypeLabel(type) {\n const channel = this.channels.find(c => c.value === type);\n return channel ? channel.label : type;\n },\n // 获取渠道列表\n getChannelList(type) {\n return this.getSettings(type)?.channels || [];\n },\n // 获取渠道设置对象\n getSettings(type) {\n const map = {\n telegram: this.telegramSettings,\n cfr2: this.cfr2Settings,\n s3: this.s3Settings,\n discord: this.discordSettings,\n huggingface: this.huggingfaceSettings\n };\n return map[type];\n },\n // 是否有负载均衡选项\n hasLoadBalance(type) {\n return ['telegram', 's3', 'discord', 'huggingface'].includes(type);\n },\n // 文本脱敏\n maskText(text, showLength = 4) {\n if (!text) return '未设置';\n if (text.length <= showLength * 2) return '****';\n return text.slice(0, showLength) + '****' + text.slice(-showLength);\n },\n // 打开详情弹窗\n openDetailDialog(type, index) {\n this.currentChannelType = type;\n this.currentChannelIndex = index;\n this.currentChannel = this.getChannelList(type)[index];\n this.showDetailDialog = true;\n },\n // 打开编辑弹窗\n openEditDialog(type, index) {\n this.currentChannelType = type;\n this.currentChannelIndex = index;\n const channel = this.getChannelList(type)[index];\n this.editChannel = JSON.parse(JSON.stringify(channel));\n // 确保 quota 对象存在\n if (!this.editChannel.quota) {\n this.editChannel.quota = {\n enabled: false,\n limitGB: 10,\n threshold: 95\n };\n }\n this.showEditDialog = true;\n },\n // 从详情页打开编辑\n openEditFromDetail() {\n this.showDetailDialog = false;\n this.openEditDialog(this.currentChannelType, this.currentChannelIndex);\n },\n // 重置添加表单\n resetAddForm() {\n this.newChannel = {\n type: '',\n name: '',\n enabled: true,\n botToken: '',\n chatId: '',\n proxyUrl: '',\n endpoint: '',\n bucketName: '',\n region: 'auto',\n accessKeyId: '',\n secretAccessKey: '',\n pathStyle: false,\n quota: {\n enabled: false,\n limitGB: 10,\n threshold: 95\n },\n channelId: '',\n isNitro: false,\n repo: '',\n token: '',\n isPrivate: false\n };\n },\n // 重置详情弹窗数据\n resetDetailData() {\n this.currentChannel = null;\n },\n // 重置编辑弹窗数据\n resetEditData() {\n this.editChannel = {};\n },\n // 渠道类型变更时重置表单\n onChannelTypeChange() {\n // 保留 type 和 name,重置其他字段\n const {\n type,\n name\n } = this.newChannel;\n this.newChannel = {\n type,\n name,\n enabled: true,\n botToken: '',\n chatId: '',\n proxyUrl: '',\n endpoint: '',\n cdnDomain: '',\n bucketName: '',\n region: 'auto',\n accessKeyId: '',\n secretAccessKey: '',\n pathStyle: false,\n quota: {\n enabled: false,\n limitGB: 10,\n threshold: 95\n },\n channelId: '',\n isNitro: false,\n repo: '',\n token: '',\n isPrivate: false\n };\n },\n // 确认添加渠道\n confirmAddChannel() {\n this.$refs.addForm.validate(valid => {\n if (!valid) return;\n const {\n type,\n name\n } = this.newChannel;\n const settings = this.getSettings(type);\n\n // 检查是否为保留名称({type}_env)\n const reservedNames = ['Telegram_env', 'R2_env', 'S3_env', 'Discord_env', 'HuggingFace_env'];\n if (reservedNames.includes(name)) {\n this.$message.warning('该名称为系统保留名称,请使用其他名称');\n return;\n }\n\n // 检查名称是否重复\n const isDuplicate = settings.channels.some(ch => ch.name === name);\n if (isDuplicate) {\n this.$message.warning('该类型下已存在同名渠道,请使用其他名称');\n return;\n }\n let newChannelData = {\n id: settings.channels.length + 1,\n name: this.newChannel.name,\n type: type,\n savePath: 'database',\n enabled: true,\n fixed: false\n };\n\n // 根据类型添加特定字段\n if (type === 'telegram') {\n Object.assign(newChannelData, {\n botToken: this.newChannel.botToken,\n chatId: this.newChannel.chatId,\n proxyUrl: this.newChannel.proxyUrl\n });\n } else if (type === 's3') {\n Object.assign(newChannelData, {\n endpoint: this.newChannel.endpoint,\n cdnDomain: this.newChannel.cdnDomain,\n bucketName: this.newChannel.bucketName,\n region: this.newChannel.region,\n accessKeyId: this.newChannel.accessKeyId,\n secretAccessKey: this.newChannel.secretAccessKey,\n pathStyle: this.newChannel.pathStyle,\n quota: {\n ...this.newChannel.quota\n }\n });\n } else if (type === 'discord') {\n Object.assign(newChannelData, {\n botToken: this.newChannel.botToken,\n channelId: this.newChannel.channelId,\n proxyUrl: this.newChannel.proxyUrl,\n isNitro: this.newChannel.isNitro\n });\n } else if (type === 'huggingface') {\n Object.assign(newChannelData, {\n repo: this.newChannel.repo,\n token: this.newChannel.token,\n isPrivate: this.newChannel.isPrivate\n });\n }\n settings.channels.push(newChannelData);\n this.showAddDialog = false;\n // 自动保存全部设置\n this.saveSettings();\n });\n },\n // 确认编辑渠道\n confirmEditChannel() {\n this.$refs.editForm.validate(valid => {\n if (!valid) return;\n const settings = this.getSettings(this.currentChannelType);\n const newName = this.editChannel.name;\n const currentIndex = this.currentChannelIndex;\n const isFixedChannel = this.editChannel.fixed;\n\n // 非环境变量渠道才检查名称\n if (!isFixedChannel) {\n // 检查是否为保留名称({type}_env)\n const reservedNames = ['Telegram_env', 'R2_env', 'S3_env', 'Discord_env', 'HuggingFace_env'];\n if (reservedNames.includes(newName)) {\n this.$message.warning('该名称为系统保留名称,请使用其他名称');\n return;\n }\n\n // 检查名称是否与其他渠道重复(排除当前编辑的渠道)\n const isDuplicate = settings.channels.some((ch, idx) => idx !== currentIndex && ch.name === newName);\n if (isDuplicate) {\n this.$message.warning('该类型下已存在同名渠道,请使用其他名称');\n return;\n }\n }\n settings.channels[this.currentChannelIndex] = {\n ...this.editChannel\n };\n this.showEditDialog = false;\n // 自动保存全部设置\n this.saveSettings();\n });\n },\n // 删除渠道\n deleteChannel(type, index) {\n const channel = this.getChannelList(type)[index];\n if (channel.fixed) {\n this.$message.warning('环境变量配置的渠道无法删除');\n return;\n }\n this.$confirm('确定要删除该渠道吗?', '提示', {\n confirmButtonText: '确定',\n cancelButtonText: '取消',\n type: 'warning'\n }).then(() => {\n const settings = this.getSettings(type);\n settings.channels.splice(index, 1);\n // 重新调整 id\n settings.channels.forEach((item, i) => {\n item.id = i + 1;\n });\n // 自动保存\n this.saveSettings();\n }).catch(() => {});\n },\n saveSettings() {\n // 保存设置\n const settings = {\n telegram: this.telegramSettings,\n cfr2: this.cfr2Settings,\n s3: this.s3Settings,\n discord: this.discordSettings,\n huggingface: this.huggingfaceSettings\n };\n fetchWithAuth('/api/manage/sysConfig/upload', {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json'\n },\n body: JSON.stringify(settings)\n }).then(() => {\n this.$message.success('设置已保存');\n });\n },\n // 获取容量统计(重新计算)\n async refreshQuota() {\n this.quotaLoading = true;\n try {\n // 使用 POST 请求重新统计容量(会触发索引重建)\n const response = await fetchWithAuth('/api/manage/quota', {\n method: 'POST'\n });\n const data = await response.json();\n if (data.success) {\n this.quotaStats = data.channelStats || {};\n } else {\n // 如果重新统计失败,尝试获取已有数据\n const getResponse = await fetchWithAuth('/api/manage/quota');\n const getData = await getResponse.json();\n if (getData.success) {\n this.quotaStats = getData.quotaStats || {};\n }\n }\n } catch (error) {\n console.error('Failed to refresh quota stats:', error);\n } finally {\n this.quotaLoading = false;\n }\n },\n // 获取容量统计(仅读取,不重建索引)\n async loadQuotaStats() {\n try {\n const response = await fetchWithAuth('/api/manage/quota');\n const data = await response.json();\n if (data.success) {\n this.quotaStats = data.quotaStats || {};\n }\n } catch (error) {\n console.error('Failed to load quota stats:', error);\n }\n },\n // 获取渠道已用容量 (GB)\n getChannelUsedGB(channel) {\n const stats = this.quotaStats[channel.name];\n if (!stats) return 0;\n return (stats.usedMB || 0) / 1024;\n },\n // 获取容量百分比\n getQuotaPercentage(channel) {\n const usedGB = this.getChannelUsedGB(channel);\n const limitGB = channel.quota?.limitGB || 10;\n const percentage = usedGB / limitGB * 100;\n return Math.min(100, Math.round(percentage * 10) / 10);\n },\n // 获取进度条状态\n getQuotaStatus(channel) {\n const percentage = this.getQuotaPercentage(channel);\n const threshold = channel.quota?.threshold || 95;\n if (percentage >= threshold) return 'exception';\n if (percentage >= 80) return 'warning';\n return 'success';\n },\n // 获取容量文本\n getQuotaText(channel) {\n const usedGB = this.getChannelUsedGB(channel);\n const limitGB = channel.quota?.limitGB || 10;\n return `${usedGB.toFixed(2)} / ${limitGB} GB`;\n },\n // 判断是否超过阈值\n isQuotaExceeded(channel) {\n const percentage = this.getQuotaPercentage(channel);\n const threshold = channel.quota?.threshold || 95;\n return percentage >= threshold;\n },\n // 获取状态文本\n getQuotaStatusText(channel) {\n const percentage = this.getQuotaPercentage(channel);\n const threshold = channel.quota?.threshold || 95;\n if (percentage >= threshold) {\n return `⚠️ 已达到容量阈值 (${threshold}%),渠道写入已暂停`;\n }\n if (percentage >= 80) {\n return `⚡ 容量使用较高,接近阈值`;\n }\n return `✓ 容量正常`;\n },\n // 容量限制开关变化时\n async onQuotaEnabledChange(enabled, channel) {\n if (enabled && channel.name) {\n // 首次启用时,检查是否有该渠道的统计数据\n const stats = this.quotaStats[channel.name];\n if (!stats) {\n // 没有统计数据,提示用户需要重新统计\n this.$confirm('首次启用容量限制需要统计现有文件容量,这可能需要一些时间。是否立即统计?', '初始化容量统计', {\n confirmButtonText: '立即统计',\n cancelButtonText: '稍后手动统计',\n type: 'info'\n }).then(async () => {\n await this.recalculateQuota();\n }).catch(() => {\n this.$message.info('您可以稍后点击刷新按钮手动统计');\n });\n }\n }\n },\n // 重新统计容量\n async recalculateQuota() {\n this.quotaLoading = true;\n try {\n this.$message.info('正在统计容量,请稍候...');\n const response = await fetchWithAuth('/api/manage/quota', {\n method: 'POST'\n });\n const data = await response.json();\n if (data.success) {\n this.quotaStats = data.channelStats || {};\n this.$message.success('容量统计完成');\n } else {\n this.$message.error('统计失败: ' + (data.error || '未知错误'));\n }\n } catch (error) {\n console.error('Failed to recalculate quota:', error);\n this.$message.error('统计失败');\n } finally {\n this.quotaLoading = false;\n }\n }\n },\n mounted() {\n this.loading = true;\n // 获取上传设置\n fetchWithAuth('/api/manage/sysConfig/upload').then(response => response.json()).then(data => {\n this.telegramSettings = data.telegram;\n // 确保 R2 渠道有 quota 默认值\n if (data.cfr2 && data.cfr2.channels) {\n data.cfr2.channels = data.cfr2.channels.map(channel => ({\n ...channel,\n quota: channel.quota || {\n enabled: false,\n limitGB: 10,\n threshold: 95\n }\n }));\n }\n this.cfr2Settings = data.cfr2;\n // 确保 S3 渠道有 quota 默认值\n if (data.s3 && data.s3.channels) {\n data.s3.channels = data.s3.channels.map(channel => ({\n ...channel,\n quota: channel.quota || {\n enabled: false,\n limitGB: 10,\n threshold: 95\n }\n }));\n }\n this.s3Settings = data.s3;\n // 确保 Discord 渠道有默认值\n if (data.discord && data.discord.channels) {\n data.discord.channels = data.discord.channels.map(channel => ({\n ...channel,\n proxyUrl: channel.proxyUrl || ''\n }));\n }\n this.discordSettings = data.discord || {\n loadBalance: {},\n channels: []\n };\n // 确保 HuggingFace 渠道有默认值\n if (data.huggingface && data.huggingface.channels) {\n data.huggingface.channels = data.huggingface.channels.map(channel => ({\n ...channel,\n isPrivate: channel.isPrivate || false\n }));\n }\n this.huggingfaceSettings = data.huggingface || {\n loadBalance: {},\n channels: []\n };\n // 加载容量统计(仅读取,不重建索引)\n this.loadQuotaStats();\n }).finally(() => {\n this.loading = false;\n });\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./SysCogUpload.vue?vue&type=template&id=89234e52&scoped=true\"\nimport script from \"./SysCogUpload.vue?vue&type=script&lang=js\"\nexport * from \"./SysCogUpload.vue?vue&type=script&lang=js\"\n\nimport \"./SysCogUpload.vue?vue&type=style&index=0&id=89234e52&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-89234e52\"]])\n\nexport default __exports__","import { resolveComponent as _resolveComponent, openBlock as _openBlock, createBlock as _createBlock, createCommentVNode as _createCommentVNode, toDisplayString as _toDisplayString, createElementVNode as _createElementVNode, vShow as _vShow, normalizeClass as _normalizeClass, withDirectives as _withDirectives, Transition as _Transition, withCtx as _withCtx } from \"vue\";\nconst _hoisted_1 = {\n class: \"save-text\"\n};\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n return _openBlock(), _createBlock(_Transition, {\n name: \"fade-up\"\n }, {\n default: _withCtx(() => [_withDirectives(_createElementVNode(\"div\", {\n class: _normalizeClass([\"floating-save-btn\", {\n 'is-loading': $props.loading\n }]),\n onClick: _cache[0] || (_cache[0] = (...args) => $options.handleClick && $options.handleClick(...args))\n }, [$props.loading ? (_openBlock(), _createBlock(_component_font_awesome_icon, {\n key: 0,\n icon: \"spinner\",\n spin: \"\"\n })) : (_openBlock(), _createBlock(_component_font_awesome_icon, {\n key: 1,\n icon: \"save\"\n })), _createElementVNode(\"span\", _hoisted_1, _toDisplayString($props.loading ? '保存中' : '保存'), 1)], 2), [[_vShow, $data.visible]])]),\n _: 1\n });\n}","export default {\n name: 'FloatingSaveButton',\n props: {\n loading: {\n type: Boolean,\n default: false\n },\n show: {\n type: Boolean,\n default: true\n }\n },\n data() {\n return {\n visible: false\n };\n },\n watch: {\n show: {\n immediate: true,\n handler(val) {\n if (val) {\n // 延迟显示,等待 Element Plus 加载遮罩淡出动画完成\n setTimeout(() => {\n this.visible = true;\n }, 600);\n } else {\n this.visible = false;\n }\n }\n }\n },\n methods: {\n handleClick() {\n if (!this.loading) {\n this.$emit('click');\n }\n }\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./FloatingSaveButton.vue?vue&type=template&id=27fc6cc8&scoped=true\"\nimport script from \"./FloatingSaveButton.vue?vue&type=script&lang=js\"\nexport * from \"./FloatingSaveButton.vue?vue&type=script&lang=js\"\n\nimport \"./FloatingSaveButton.vue?vue&type=style&index=0&id=27fc6cc8&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-27fc6cc8\"]])\n\nexport default __exports__","import { createElementVNode as _createElementVNode, resolveComponent as _resolveComponent, createVNode as _createVNode, withCtx as _withCtx, openBlock as _openBlock, createBlock as _createBlock, createCommentVNode as _createCommentVNode, Transition as _Transition, createTextVNode as _createTextVNode, toDisplayString as _toDisplayString, renderList as _renderList, Fragment as _Fragment, createElementBlock as _createElementBlock, resolveDirective as _resolveDirective, withDirectives as _withDirectives } from \"vue\";\nconst _hoisted_1 = {\n class: \"security-settings\"\n};\nconst _hoisted_2 = {\n class: \"first-settings\"\n};\nconst _hoisted_3 = {\n class: \"second-title token-title\"\n};\nconst _hoisted_4 = {\n class: \"token-actions\"\n};\nconst _hoisted_5 = {\n class: \"token-table-container\"\n};\nconst _hoisted_6 = {\n class: \"table-cell-content\"\n};\nconst _hoisted_7 = {\n class: \"table-cell-content\"\n};\nconst _hoisted_8 = {\n class: \"token-display\"\n};\nconst _hoisted_9 = {\n class: \"table-cell-content\"\n};\nconst _hoisted_10 = {\n class: \"table-cell-content\"\n};\nconst _hoisted_11 = {\n class: \"table-cell-content action-buttons\"\n};\nconst _hoisted_12 = {\n class: \"first-settings\"\n};\nconst _hoisted_13 = {\n class: \"second-title\"\n};\nconst _hoisted_14 = {\n class: \"first-settings\"\n};\nconst _hoisted_15 = {\n class: \"dialog-footer\"\n};\nconst _hoisted_16 = {\n class: \"dialog-footer\"\n};\nconst _hoisted_17 = {\n class: \"token-result\"\n};\nconst _hoisted_18 = {\n style: {\n \"margin-bottom\": \"15px\",\n \"color\": \"#e6a23c\"\n }\n};\nconst _hoisted_19 = {\n class: \"dialog-footer\"\n};\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_el_input = _resolveComponent(\"el-input\");\n const _component_el_form_item = _resolveComponent(\"el-form-item\");\n const _component_el_form = _resolveComponent(\"el-form\");\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n const _component_el_button = _resolveComponent(\"el-button\");\n const _component_el_table_column = _resolveComponent(\"el-table-column\");\n const _component_el_tag = _resolveComponent(\"el-tag\");\n const _component_el_table = _resolveComponent(\"el-table\");\n const _component_el_tooltip = _resolveComponent(\"el-tooltip\");\n const _component_el_switch = _resolveComponent(\"el-switch\");\n const _component_el_option = _resolveComponent(\"el-option\");\n const _component_el_select = _resolveComponent(\"el-select\");\n const _component_FloatingSaveButton = _resolveComponent(\"FloatingSaveButton\");\n const _component_el_checkbox = _resolveComponent(\"el-checkbox\");\n const _component_el_checkbox_group = _resolveComponent(\"el-checkbox-group\");\n const _component_el_dialog = _resolveComponent(\"el-dialog\");\n const _directive_loading = _resolveDirective(\"loading\");\n return _withDirectives((_openBlock(), _createElementBlock(\"div\", _hoisted_1, [_createElementVNode(\"div\", _hoisted_2, [_cache[26] || (_cache[26] = _createElementVNode(\"h3\", {\n class: \"first-title\"\n }, \"认证管理\", -1)), _cache[27] || (_cache[27] = _createElementVNode(\"h4\", {\n class: \"second-title\"\n }, \"用户端认证\", -1)), _createVNode(_component_el_form, {\n model: $data.authSettings.user,\n rules: $data.userPassRules,\n ref: \"userPassForm\",\n \"label-width\": \"120px\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_form_item, {\n label: \"上传密码\",\n prop: \"authCode\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.authSettings.user.authCode,\n \"onUpdate:modelValue\": _cache[0] || (_cache[0] = $event => $data.authSettings.user.authCode = $event),\n type: \"password\",\n \"show-password\": \"\",\n onInput: $options.handleUserPassInput,\n autocomplete: \"new-password\"\n }, null, 8, [\"modelValue\", \"onInput\"])]),\n _: 1\n }), _createVNode(_Transition, {\n name: \"fade-slide\",\n mode: \"out-in\"\n }, {\n default: _withCtx(() => [$data.showUserPassConfirm ? (_openBlock(), _createBlock(_component_el_form_item, {\n label: \"确认密码\",\n prop: \"confirmNewUserPassword\",\n key: \"user-confirm\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.authSettings.user.confirmNewUserPassword,\n \"onUpdate:modelValue\": _cache[1] || (_cache[1] = $event => $data.authSettings.user.confirmNewUserPassword = $event),\n type: \"password\",\n \"show-password\": \"\",\n autocomplete: \"new-password\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n })) : _createCommentVNode(\"\", true)]),\n _: 1\n })]),\n _: 1\n }, 8, [\"model\", \"rules\"]), _cache[28] || (_cache[28] = _createElementVNode(\"h4\", {\n class: \"second-title\"\n }, \"管理端认证\", -1)), _createVNode(_component_el_form, {\n model: $data.authSettings.admin,\n rules: $data.adminPassRules,\n ref: \"adminPassForm\",\n \"label-width\": \"120px\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_form_item, {\n label: \"用户名\",\n prop: \"adminUsername\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.authSettings.admin.adminUsername,\n \"onUpdate:modelValue\": _cache[2] || (_cache[2] = $event => $data.authSettings.admin.adminUsername = $event),\n autocomplete: \"new-password\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"密码\",\n prop: \"adminPassword\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.authSettings.admin.adminPassword,\n \"onUpdate:modelValue\": _cache[3] || (_cache[3] = $event => $data.authSettings.admin.adminPassword = $event),\n type: \"password\",\n \"show-password\": \"\",\n onInput: $options.handleAdminPassInput,\n autocomplete: \"new-password\"\n }, null, 8, [\"modelValue\", \"onInput\"])]),\n _: 1\n }), _createVNode(_Transition, {\n name: \"fade-slide\",\n mode: \"out-in\"\n }, {\n default: _withCtx(() => [$data.showAdminPassConfirm ? (_openBlock(), _createBlock(_component_el_form_item, {\n label: \"确认密码\",\n prop: \"confirmNewAdminPassword\",\n key: \"admin-confirm\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.authSettings.admin.confirmNewAdminPassword,\n \"onUpdate:modelValue\": _cache[4] || (_cache[4] = $event => $data.authSettings.admin.confirmNewAdminPassword = $event),\n type: \"password\",\n \"show-password\": \"\",\n autocomplete: \"new-password\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n })) : _createCommentVNode(\"\", true)]),\n _: 1\n })]),\n _: 1\n }, 8, [\"model\", \"rules\"]), _createElementVNode(\"h4\", _hoisted_3, [_cache[23] || (_cache[23] = _createTextVNode(\"API Token 管理 \", -1)), _createElementVNode(\"a\", _hoisted_4, [_createVNode(_component_el_button, {\n type: \"primary\",\n size: \"small\",\n onClick: _cache[5] || (_cache[5] = $event => $data.showCreateTokenDialog = true),\n circle: \"\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"plus\"\n })]),\n _: 1\n })])]), _createElementVNode(\"div\", _hoisted_5, [_withDirectives((_openBlock(), _createBlock(_component_el_table, {\n data: $data.apiTokens,\n class: \"token-table\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_table_column, {\n prop: \"name\",\n label: \"名称\",\n \"header-align\": \"center\"\n }, {\n default: _withCtx(scope => [_createElementVNode(\"div\", _hoisted_6, _toDisplayString(scope.row.name), 1)]),\n _: 1\n }), _createVNode(_component_el_table_column, {\n prop: \"token\",\n label: \"Token\",\n \"header-align\": \"center\"\n }, {\n default: _withCtx(scope => [_createElementVNode(\"div\", _hoisted_7, [_createElementVNode(\"span\", _hoisted_8, _toDisplayString(scope.row.token), 1)])]),\n _: 1\n }), _createVNode(_component_el_table_column, {\n prop: \"permissions\",\n label: \"权限\",\n \"header-align\": \"center\"\n }, {\n default: _withCtx(scope => [_createElementVNode(\"div\", _hoisted_9, [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList(scope.row.permissions, perm => {\n return _openBlock(), _createBlock(_component_el_tag, {\n key: perm,\n size: \"small\",\n class: \"permission-tag\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($options.getPermissionText(perm)), 1)]),\n _: 2\n }, 1024);\n }), 128))])]),\n _: 1\n }), _createVNode(_component_el_table_column, {\n prop: \"createdAt\",\n label: \"创建时间\",\n \"header-align\": \"center\"\n }, {\n default: _withCtx(scope => [_createElementVNode(\"div\", _hoisted_10, _toDisplayString($options.formatDate(scope.row.createdAt)), 1)]),\n _: 1\n }), _createVNode(_component_el_table_column, {\n label: \"操作\",\n fixed: \"right\",\n \"header-align\": \"center\"\n }, {\n default: _withCtx(scope => [_createElementVNode(\"div\", _hoisted_11, [_createVNode(_component_el_button, {\n class: \"action-button\",\n size: \"small\",\n onClick: $event => $options.editToken(scope.row)\n }, {\n default: _withCtx(() => [...(_cache[24] || (_cache[24] = [_createTextVNode(\"编辑\", -1)]))]),\n _: 1\n }, 8, [\"onClick\"]), _createVNode(_component_el_button, {\n class: \"action-button\",\n size: \"small\",\n type: \"danger\",\n onClick: $event => $options.deleteToken(scope.row.id)\n }, {\n default: _withCtx(() => [...(_cache[25] || (_cache[25] = [_createTextVNode(\"删除\", -1)]))]),\n _: 1\n }, 8, [\"onClick\"])])]),\n _: 1\n })]),\n _: 1\n }, 8, [\"data\"])), [[_directive_loading, $data.tokenLoading]])])]), _createElementVNode(\"div\", _hoisted_12, [_cache[30] || (_cache[30] = _createElementVNode(\"h3\", {\n class: \"first-title\"\n }, \"上传管理\", -1)), _createElementVNode(\"h4\", _hoisted_13, [_cache[29] || (_cache[29] = _createTextVNode(\"图像审查 \", -1)), _createVNode(_component_el_tooltip, {\n content: \"仅对非分块上传文件生效,支持 nsfwjs 和 moderatecontent.com 渠道\",\n placement: \"top\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"question-circle\",\n style: {\n \"margin-left\": \"5px\",\n \"cursor\": \"pointer\"\n }\n })]),\n _: 1\n })]), _createVNode(_component_el_form, {\n model: $data.uploadSettings.moderate,\n \"label-width\": \"120px\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_form_item, {\n label: \"开启审查\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_switch, {\n modelValue: $data.uploadSettings.moderate.enabled,\n \"onUpdate:modelValue\": _cache[6] || (_cache[6] = $event => $data.uploadSettings.moderate.enabled = $event)\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"审查渠道\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_select, {\n modelValue: $data.uploadSettings.moderate.channel,\n \"onUpdate:modelValue\": _cache[7] || (_cache[7] = $event => $data.uploadSettings.moderate.channel = $event),\n placeholder: \"请选择审查渠道\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_option, {\n label: \"moderatecontent.com\",\n value: \"moderatecontent.com\"\n }), _createVNode(_component_el_option, {\n label: \"nsfwjs\",\n value: \"nsfwjs\"\n })]),\n _: 1\n }, 8, [\"modelValue\"])]),\n _: 1\n }), $data.uploadSettings.moderate.channel === 'moderatecontent.com' ? (_openBlock(), _createBlock(_component_el_form_item, {\n key: 0,\n label: \"API Key\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.uploadSettings.moderate.moderateContentApiKey,\n \"onUpdate:modelValue\": _cache[8] || (_cache[8] = $event => $data.uploadSettings.moderate.moderateContentApiKey = $event)\n }, null, 8, [\"modelValue\"])]),\n _: 1\n })) : _createCommentVNode(\"\", true), $data.uploadSettings.moderate.channel === 'nsfwjs' ? (_openBlock(), _createBlock(_component_el_form_item, {\n key: 1,\n label: \"API 路径\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.uploadSettings.moderate.nsfwApiPath,\n \"onUpdate:modelValue\": _cache[9] || (_cache[9] = $event => $data.uploadSettings.moderate.nsfwApiPath = $event),\n placeholder: \"https://nsfwjs.your.domain\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n })) : _createCommentVNode(\"\", true)]),\n _: 1\n }, 8, [\"model\"])]), _createElementVNode(\"div\", _hoisted_14, [_cache[33] || (_cache[33] = _createElementVNode(\"h3\", {\n class: \"first-title\"\n }, \"访问管理\", -1)), _cache[34] || (_cache[34] = _createElementVNode(\"h4\", {\n class: \"second-title\"\n }, \"域名过滤\", -1)), _createVNode(_component_el_form, {\n model: $data.accessSettings,\n \"label-width\": \"120px\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_form_item, null, {\n label: _withCtx(() => [_cache[31] || (_cache[31] = _createTextVNode(\" 放行域名 \", -1)), _createVNode(_component_el_tooltip, {\n content: \"1.针对访问域名设置权限
2.留空默认全部放行,多个域名请用英文逗号分隔\",\n placement: \"top\",\n \"raw-content\": \"\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"question-circle\",\n style: {\n \"margin-left\": \"5px\",\n \"cursor\": \"pointer\"\n }\n })]),\n _: 1\n })]),\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.accessSettings.allowedDomains,\n \"onUpdate:modelValue\": _cache[10] || (_cache[10] = $event => $data.accessSettings.allowedDomains = $event)\n }, null, 8, [\"modelValue\"])]),\n _: 1\n })]),\n _: 1\n }, 8, [\"model\"]), _cache[35] || (_cache[35] = _createElementVNode(\"h4\", {\n class: \"second-title\"\n }, \"白名单模式\", -1)), _createVNode(_component_el_form, {\n model: $data.accessSettings,\n \"label-width\": \"120px\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_form_item, null, {\n label: _withCtx(() => [_cache[32] || (_cache[32] = _createTextVNode(\" 是否开启 \", -1)), _createVNode(_component_el_tooltip, {\n content: \"1.针对文件设置权限
2.开启后,仅被加入白名单的文件可被访问\",\n placement: \"top\",\n \"raw-content\": \"\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"question-circle\",\n style: {\n \"margin-left\": \"5px\",\n \"cursor\": \"pointer\"\n }\n })]),\n _: 1\n })]),\n default: _withCtx(() => [_createVNode(_component_el_switch, {\n modelValue: $data.accessSettings.whiteListMode,\n \"onUpdate:modelValue\": _cache[11] || (_cache[11] = $event => $data.accessSettings.whiteListMode = $event)\n }, null, 8, [\"modelValue\"])]),\n _: 1\n })]),\n _: 1\n }, 8, [\"model\"])]), _createVNode(_component_FloatingSaveButton, {\n show: !$data.loading,\n onClick: $options.saveSettings\n }, null, 8, [\"show\", \"onClick\"]), _createVNode(_component_el_dialog, {\n modelValue: $data.showCreateTokenDialog,\n \"onUpdate:modelValue\": _cache[15] || (_cache[15] = $event => $data.showCreateTokenDialog = $event),\n title: \"创建新 API Token\",\n width: $options.dialogWidth\n }, {\n footer: _withCtx(() => [_createElementVNode(\"span\", _hoisted_15, [_createVNode(_component_el_button, {\n onClick: _cache[14] || (_cache[14] = $event => $data.showCreateTokenDialog = false)\n }, {\n default: _withCtx(() => [...(_cache[39] || (_cache[39] = [_createTextVNode(\"取消\", -1)]))]),\n _: 1\n }), _createVNode(_component_el_button, {\n type: \"primary\",\n onClick: $options.createToken\n }, {\n default: _withCtx(() => [...(_cache[40] || (_cache[40] = [_createTextVNode(\"创建\", -1)]))]),\n _: 1\n }, 8, [\"onClick\"])])]),\n default: _withCtx(() => [_createVNode(_component_el_form, {\n model: $data.newToken,\n rules: $data.tokenRules,\n ref: \"tokenForm\",\n \"label-width\": \"100px\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_form_item, {\n label: \"Token 名称\",\n prop: \"name\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.newToken.name,\n \"onUpdate:modelValue\": _cache[12] || (_cache[12] = $event => $data.newToken.name = $event),\n placeholder: \"请输入Token名称\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"权限\",\n prop: \"permissions\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_checkbox_group, {\n modelValue: $data.newToken.permissions,\n \"onUpdate:modelValue\": _cache[13] || (_cache[13] = $event => $data.newToken.permissions = $event)\n }, {\n default: _withCtx(() => [_createVNode(_component_el_checkbox, {\n label: \"upload\"\n }, {\n default: _withCtx(() => [...(_cache[36] || (_cache[36] = [_createTextVNode(\"上传\", -1)]))]),\n _: 1\n }), _createVNode(_component_el_checkbox, {\n label: \"delete\"\n }, {\n default: _withCtx(() => [...(_cache[37] || (_cache[37] = [_createTextVNode(\"删除\", -1)]))]),\n _: 1\n }), _createVNode(_component_el_checkbox, {\n label: \"list\"\n }, {\n default: _withCtx(() => [...(_cache[38] || (_cache[38] = [_createTextVNode(\"列出\", -1)]))]),\n _: 1\n })]),\n _: 1\n }, 8, [\"modelValue\"])]),\n _: 1\n })]),\n _: 1\n }, 8, [\"model\", \"rules\"])]),\n _: 1\n }, 8, [\"modelValue\", \"width\"]), _createVNode(_component_el_dialog, {\n modelValue: $data.showEditTokenDialog,\n \"onUpdate:modelValue\": _cache[19] || (_cache[19] = $event => $data.showEditTokenDialog = $event),\n title: \"编辑 API Token\",\n width: $options.dialogWidth\n }, {\n footer: _withCtx(() => [_createElementVNode(\"span\", _hoisted_16, [_createVNode(_component_el_button, {\n onClick: _cache[18] || (_cache[18] = $event => $data.showEditTokenDialog = false)\n }, {\n default: _withCtx(() => [...(_cache[44] || (_cache[44] = [_createTextVNode(\"取消\", -1)]))]),\n _: 1\n }), _createVNode(_component_el_button, {\n type: \"primary\",\n onClick: $options.updateToken\n }, {\n default: _withCtx(() => [...(_cache[45] || (_cache[45] = [_createTextVNode(\"更新\", -1)]))]),\n _: 1\n }, 8, [\"onClick\"])])]),\n default: _withCtx(() => [_createVNode(_component_el_form, {\n model: $data.editingToken,\n rules: $data.tokenRules,\n ref: \"editTokenForm\",\n \"label-width\": \"100px\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_form_item, {\n label: \"Token 名称\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.editingToken.name,\n \"onUpdate:modelValue\": _cache[16] || (_cache[16] = $event => $data.editingToken.name = $event),\n disabled: \"\"\n }, null, 8, [\"modelValue\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"权限\",\n prop: \"permissions\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_checkbox_group, {\n modelValue: $data.editingToken.permissions,\n \"onUpdate:modelValue\": _cache[17] || (_cache[17] = $event => $data.editingToken.permissions = $event)\n }, {\n default: _withCtx(() => [_createVNode(_component_el_checkbox, {\n label: \"upload\"\n }, {\n default: _withCtx(() => [...(_cache[41] || (_cache[41] = [_createTextVNode(\"上传\", -1)]))]),\n _: 1\n }), _createVNode(_component_el_checkbox, {\n label: \"delete\"\n }, {\n default: _withCtx(() => [...(_cache[42] || (_cache[42] = [_createTextVNode(\"删除\", -1)]))]),\n _: 1\n }), _createVNode(_component_el_checkbox, {\n label: \"list\"\n }, {\n default: _withCtx(() => [...(_cache[43] || (_cache[43] = [_createTextVNode(\"列出\", -1)]))]),\n _: 1\n })]),\n _: 1\n }, 8, [\"modelValue\"])]),\n _: 1\n })]),\n _: 1\n }, 8, [\"model\", \"rules\"])]),\n _: 1\n }, 8, [\"modelValue\", \"width\"]), _createVNode(_component_el_dialog, {\n modelValue: $data.showTokenResultDialog,\n \"onUpdate:modelValue\": _cache[22] || (_cache[22] = $event => $data.showTokenResultDialog = $event),\n title: \"Token 创建成功\",\n width: $options.dialogWidth\n }, {\n footer: _withCtx(() => [_createElementVNode(\"span\", _hoisted_19, [_createVNode(_component_el_button, {\n type: \"primary\",\n onClick: _cache[21] || (_cache[21] = $event => $data.showTokenResultDialog = false)\n }, {\n default: _withCtx(() => [...(_cache[48] || (_cache[48] = [_createTextVNode(\"我已保存\", -1)]))]),\n _: 1\n })])]),\n default: _withCtx(() => [_createElementVNode(\"div\", _hoisted_17, [_createElementVNode(\"p\", _hoisted_18, [_createVNode(_component_font_awesome_icon, {\n icon: \"exclamation-triangle\",\n style: {\n \"margin-right\": \"5px\"\n }\n }), _cache[46] || (_cache[46] = _createTextVNode(\" 请妥善保存以下Token,关闭此窗口后将无法再次查看完整Token! \", -1))]), _createVNode(_component_el_form, {\n \"label-width\": \"100px\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_form_item, {\n label: \"Token 名称\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"span\", null, _toDisplayString($data.createdToken.name), 1)]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"完整Token\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.createdToken.token,\n \"onUpdate:modelValue\": _cache[20] || (_cache[20] = $event => $data.createdToken.token = $event),\n readonly: \"\"\n }, {\n append: _withCtx(() => [_createVNode(_component_el_button, {\n onClick: $options.copyToken\n }, {\n default: _withCtx(() => [...(_cache[47] || (_cache[47] = [_createTextVNode(\"复制\", -1)]))]),\n _: 1\n }, 8, [\"onClick\"])]),\n _: 1\n }, 8, [\"modelValue\"])]),\n _: 1\n })]),\n _: 1\n })])]),\n _: 1\n }, 8, [\"modelValue\", \"width\"])])), [[_directive_loading, $data.loading]]);\n}","import \"core-js/modules/es.array.push.js\";\nimport \"core-js/modules/es.iterator.constructor.js\";\nimport \"core-js/modules/es.iterator.every.js\";\nimport \"core-js/modules/es.json.stringify.js\";\nimport fetchWithAuth from '@/utils/fetchWithAuth';\nimport FloatingSaveButton from '@/components/FloatingSaveButton.vue';\nexport default {\n components: {\n FloatingSaveButton\n },\n data() {\n return {\n authSettings: {\n user: {},\n admin: {}\n },\n uploadSettings: {\n moderate: {}\n },\n accessSettings: {},\n apiTokens: [],\n // API Token列表\n // 加载状态\n loading: true,\n tokenLoading: false,\n // 修改密码相关\n oriUserPassword: '',\n // 原上传密码\n oriAdminPassword: '',\n // 原管理端密码\n\n showUserPassConfirm: false,\n // 显示用户密码确认框\n showAdminPassConfirm: false,\n // 显示管理密码确认框\n\n // Token对话框相关\n showCreateTokenDialog: false,\n showEditTokenDialog: false,\n showTokenResultDialog: false,\n newToken: {\n name: '',\n owner: '',\n permissions: []\n },\n editingToken: {\n id: '',\n name: '',\n owner: '',\n permissions: []\n },\n createdToken: {\n name: '',\n token: ''\n },\n userPassRules: {\n authCode: [{\n validator: (rule, value, callback) => {\n // URL保留字符列表\n const urlReservedChars = ['%', '&', '?', '#', '/'];\n const hasReservedChar = urlReservedChars.some(char => value && value.includes(char));\n if (hasReservedChar) {\n callback(new Error('密码不能包含部分URL保留字符: % & ? # /'));\n } else {\n callback();\n }\n },\n trigger: 'blur'\n }],\n confirmNewUserPassword: [{\n message: '请再次输入上传密码',\n trigger: 'blur'\n }, {\n validator: (rule, value, callback) => {\n if (value && value !== this.authSettings.user.authCode) {\n callback(new Error('两次输入密码不一致'));\n } else {\n callback();\n }\n },\n trigger: 'blur'\n }]\n },\n adminPassRules: {\n confirmNewAdminPassword: [{\n message: '请再次输入管理密码',\n trigger: 'blur'\n }, {\n validator: (rule, value, callback) => {\n if (value && value !== this.authSettings.admin.adminPassword) {\n callback(new Error('两次输入密码不一致'));\n } else {\n callback();\n }\n },\n trigger: 'blur'\n }]\n },\n tokenRules: {\n name: [{\n required: true,\n message: '请输入Token名称',\n trigger: 'blur'\n }],\n permissions: [{\n required: true,\n message: '请选择权限',\n trigger: 'change'\n }]\n }\n };\n },\n computed: {\n dialogWidth() {\n return window.innerWidth > 768 ? '50%' : '90%';\n }\n },\n methods: {\n handleUserPassInput() {\n if (this.authSettings.user.authCode !== this.oriUserPassword) {\n this.showUserPassConfirm = true;\n } else {\n this.showUserPassConfirm = false;\n }\n },\n handleAdminPassInput() {\n if (this.authSettings.admin.adminPassword !== this.oriAdminPassword) {\n this.showAdminPassConfirm = true;\n } else {\n this.showAdminPassConfirm = false;\n }\n },\n // Token相关方法\n getPermissionText(permission) {\n const permissionMap = {\n 'upload': '上传',\n 'delete': '删除',\n 'list': '列出'\n };\n return permissionMap[permission] || permission;\n },\n formatDate(dateString) {\n return new Date(dateString).toLocaleString('zh-CN');\n },\n async loadApiTokens() {\n this.tokenLoading = true;\n try {\n const response = await fetchWithAuth('/api/manage/apiTokens');\n const data = await response.json();\n this.apiTokens = data.tokens || [];\n } catch (error) {\n this.$message.error('获取Token列表失败');\n } finally {\n this.tokenLoading = false;\n }\n },\n createToken() {\n this.$refs.tokenForm.validate(async valid => {\n if (!valid) return;\n try {\n this.newToken.owner = 'admin'; // 默认所有Token归属管理员\n const response = await fetchWithAuth('/api/manage/apiTokens', {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json'\n },\n body: JSON.stringify(this.newToken)\n });\n const data = await response.json();\n if (response.ok) {\n this.createdToken = {\n name: data.name,\n token: data.token\n };\n this.showCreateTokenDialog = false;\n this.showTokenResultDialog = true;\n this.newToken = {\n name: '',\n owner: '',\n permissions: []\n };\n await this.loadApiTokens();\n this.$message.success('Token创建成功');\n } else {\n this.$message.error(data.error || 'Token创建失败');\n }\n } catch (error) {\n this.$message.error('Token创建失败');\n }\n });\n },\n editToken(token) {\n this.editingToken = {\n id: token.id,\n name: token.name,\n owner: token.owner,\n permissions: [...token.permissions]\n };\n this.showEditTokenDialog = true;\n },\n updateToken() {\n this.$refs.editTokenForm.validate(async valid => {\n if (!valid) return;\n try {\n const response = await fetchWithAuth('/api/manage/apiTokens', {\n method: 'PUT',\n headers: {\n 'Content-Type': 'application/json'\n },\n body: JSON.stringify({\n tokenId: this.editingToken.id,\n permissions: this.editingToken.permissions\n })\n });\n const data = await response.json();\n if (response.ok) {\n this.showEditTokenDialog = false;\n await this.loadApiTokens();\n this.$message.success('Token权限更新成功');\n } else {\n this.$message.error(data.error || 'Token更新失败');\n }\n } catch (error) {\n this.$message.error('Token更新失败');\n }\n });\n },\n async deleteToken(tokenId) {\n try {\n await this.$confirm('此操作将永久删除该Token,是否继续?', '提示', {\n confirmButtonText: '确定',\n cancelButtonText: '取消',\n type: 'warning'\n });\n const response = await fetchWithAuth(`/api/manage/apiTokens?id=${tokenId}`, {\n method: 'DELETE'\n });\n const data = await response.json();\n if (response.ok) {\n await this.loadApiTokens();\n this.$message.success('Token删除成功');\n } else {\n this.$message.error(data.error || 'Token删除失败');\n }\n } catch (error) {\n if (error !== 'cancel') {\n this.$message.error('Token删除失败');\n }\n }\n },\n async copyToken() {\n try {\n await navigator.clipboard.writeText(this.createdToken.token);\n this.$message.success('Token已复制到剪贴板');\n } catch (error) {\n this.$message.error('复制失败,请手动复制');\n }\n },\n saveSettings() {\n // 所有表单的Promise数组\n let validationPromises = [];\n\n // 验证用户密码表单\n validationPromises.push(new Promise(resolve => {\n this.$refs.userPassForm.validate(valid => {\n resolve(valid);\n });\n }));\n\n // 验证管理密码表单\n validationPromises.push(new Promise(resolve => {\n this.$refs.adminPassForm.validate(valid => {\n resolve(valid);\n });\n }));\n\n // 等待所有验证完成\n Promise.all(validationPromises).then(results => {\n const isValid = results.every(valid => valid);\n if (!isValid) {\n return;\n }\n const settings = {\n auth: this.authSettings,\n upload: this.uploadSettings,\n access: this.accessSettings\n };\n // 不保存确认密码相关字段\n delete settings.auth.user.confirmNewUserPassword;\n delete settings.auth.admin.confirmNewAdminPassword;\n fetchWithAuth('/api/manage/sysConfig/security', {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json'\n },\n body: JSON.stringify(settings)\n }).then(() => {\n this.$message.success('设置已保存');\n // 更新原密码\n this.oriUserPassword = this.authSettings.user.authCode;\n this.oriAdminPassword = this.authSettings.admin.adminPassword;\n this.showUserPassConfirm = false;\n this.showAdminPassConfirm = false;\n });\n });\n }\n },\n mounted() {\n this.loading = true;\n // 获取上传设置\n fetchWithAuth('/api/manage/sysConfig/security').then(response => response.json()).then(data => {\n this.authSettings = data.auth;\n this.uploadSettings = data.upload;\n this.accessSettings = data.access;\n\n // 保存原密码\n this.oriUserPassword = this.authSettings.user.authCode;\n this.oriAdminPassword = this.authSettings.admin.adminPassword;\n this.authSettings.user.confirmNewUserPassword = '';\n this.authSettings.admin.confirmNewAdminPassword = '';\n\n // 加载API Token列表\n this.loadApiTokens();\n }).finally(() => {\n this.loading = false;\n });\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./SysCogSecurity.vue?vue&type=template&id=fdf607e4&scoped=true\"\nimport script from \"./SysCogSecurity.vue?vue&type=script&lang=js\"\nexport * from \"./SysCogSecurity.vue?vue&type=script&lang=js\"\n\nimport \"./SysCogSecurity.vue?vue&type=style&index=0&id=fdf607e4&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-fdf607e4\"]])\n\nexport default __exports__","import { renderList as _renderList, Fragment as _Fragment, openBlock as _openBlock, createElementBlock as _createElementBlock, toDisplayString as _toDisplayString, createElementVNode as _createElementVNode, resolveComponent as _resolveComponent, createVNode as _createVNode, withCtx as _withCtx, createBlock as _createBlock, createCommentVNode as _createCommentVNode, createTextVNode as _createTextVNode, resolveDirective as _resolveDirective, withDirectives as _withDirectives } from \"vue\";\nconst _hoisted_1 = {\n class: \"page-settings\"\n};\nconst _hoisted_2 = {\n class: \"first-title\"\n};\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n const _component_el_tooltip = _resolveComponent(\"el-tooltip\");\n const _component_el_option = _resolveComponent(\"el-option\");\n const _component_el_select = _resolveComponent(\"el-select\");\n const _component_el_switch = _resolveComponent(\"el-switch\");\n const _component_el_input = _resolveComponent(\"el-input\");\n const _component_el_form_item = _resolveComponent(\"el-form-item\");\n const _component_el_form = _resolveComponent(\"el-form\");\n const _component_FloatingSaveButton = _resolveComponent(\"FloatingSaveButton\");\n const _directive_loading = _resolveDirective(\"loading\");\n return _withDirectives((_openBlock(), _createElementBlock(\"div\", _hoisted_1, [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($options.groupedSettings, (categoryGroup, categoryName) => {\n return _openBlock(), _createElementBlock(\"div\", {\n key: categoryName,\n class: \"first-settings\"\n }, [_createElementVNode(\"h3\", _hoisted_2, _toDisplayString(categoryName), 1), _createVNode(_component_el_form, {\n model: $data.settings,\n \"label-width\": \"150px\"\n }, {\n default: _withCtx(() => [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList(categoryGroup, (setting, index) => {\n return _openBlock(), _createBlock(_component_el_form_item, {\n key: setting.id\n }, {\n label: _withCtx(() => [_createTextVNode(_toDisplayString(setting.label) + \" \", 1), setting.tooltip ? (_openBlock(), _createBlock(_component_el_tooltip, {\n key: 0,\n content: setting.tooltip,\n placement: \"top\",\n \"raw-content\": \"\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"question-circle\",\n style: {\n \"margin-left\": \"5px\",\n \"cursor\": \"pointer\"\n }\n })]),\n _: 1\n }, 8, [\"content\"])) : _createCommentVNode(\"\", true)]),\n default: _withCtx(() => [setting.type === 'select' ? (_openBlock(), _createBlock(_component_el_select, {\n key: 0,\n modelValue: setting.value,\n \"onUpdate:modelValue\": $event => setting.value = $event,\n disabled: setting.fixed,\n placeholder: setting.placeholder,\n style: {\n \"width\": \"100%\"\n }\n }, {\n default: _withCtx(() => [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList(setting.options, option => {\n return _openBlock(), _createBlock(_component_el_option, {\n key: option.value,\n label: option.label,\n value: option.value\n }, null, 8, [\"label\", \"value\"]);\n }), 128))]),\n _: 2\n }, 1032, [\"modelValue\", \"onUpdate:modelValue\", \"disabled\", \"placeholder\"])) : setting.type === 'channelName' ? (_openBlock(), _createBlock(_component_el_select, {\n key: 1,\n modelValue: setting.value,\n \"onUpdate:modelValue\": $event => setting.value = $event,\n disabled: !$options.currentUploadChannel || $options.currentChannelList.length === 0,\n placeholder: \"请先选择上传渠道\",\n clearable: \"\",\n style: {\n \"width\": \"100%\"\n }\n }, {\n default: _withCtx(() => [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($options.currentChannelList, ch => {\n return _openBlock(), _createBlock(_component_el_option, {\n key: ch.name,\n label: ch.name,\n value: ch.name\n }, null, 8, [\"label\", \"value\"]);\n }), 128))]),\n _: 1\n }, 8, [\"modelValue\", \"onUpdate:modelValue\", \"disabled\"])) : setting.type === 'boolean' ? (_openBlock(), _createBlock(_component_el_switch, {\n key: 2,\n modelValue: setting.value,\n \"onUpdate:modelValue\": $event => setting.value = $event,\n disabled: setting.fixed\n }, null, 8, [\"modelValue\", \"onUpdate:modelValue\", \"disabled\"])) : (_openBlock(), _createBlock(_component_el_input, {\n key: 3,\n modelValue: setting.value,\n \"onUpdate:modelValue\": $event => setting.value = $event,\n disabled: setting.fixed,\n placeholder: setting.placeholder\n }, null, 8, [\"modelValue\", \"onUpdate:modelValue\", \"disabled\", \"placeholder\"]))]),\n _: 2\n }, 1024);\n }), 128))]),\n _: 2\n }, 1032, [\"model\"])]);\n }), 128)), _createVNode(_component_FloatingSaveButton, {\n show: !$data.loading,\n onClick: $options.saveSettings\n }, null, 8, [\"show\", \"onClick\"])])), [[_directive_loading, $data.loading]]);\n}","import \"core-js/modules/es.array.push.js\";\nimport \"core-js/modules/es.iterator.constructor.js\";\nimport \"core-js/modules/es.iterator.find.js\";\nimport \"core-js/modules/es.iterator.for-each.js\";\nimport \"core-js/modules/es.iterator.some.js\";\nimport \"core-js/modules/es.json.stringify.js\";\nimport fetchWithAuth from '@/utils/fetchWithAuth';\nimport axios from '@/utils/axios';\nimport FloatingSaveButton from '@/components/FloatingSaveButton.vue';\nexport default {\n components: {\n FloatingSaveButton\n },\n data() {\n return {\n settings: {\n config: []\n },\n // 加载状态\n loading: true,\n // 可用渠道列表\n availableChannels: {}\n };\n },\n computed: {\n // 根据category将配置项分组\n groupedSettings() {\n const grouped = {};\n if (this.settings.config) {\n this.settings.config.forEach(setting => {\n const category = setting.category || '其他设置';\n if (!grouped[category]) {\n grouped[category] = [];\n }\n grouped[category].push(setting);\n });\n }\n return grouped;\n },\n // 当前选择的上传渠道\n currentUploadChannel() {\n const channelSetting = this.settings.config?.find(s => s.id === 'defaultUploadChannel');\n return channelSetting?.value || '';\n },\n // 当前渠道类型对应的渠道列表\n currentChannelList() {\n return this.availableChannels[this.currentUploadChannel] || [];\n }\n },\n watch: {\n // 监听上传渠道变化,清空渠道名称(如果不在新列表中)\n currentUploadChannel(newVal, oldVal) {\n if (newVal !== oldVal) {\n const channelNameSetting = this.settings.config?.find(s => s.id === 'defaultChannelName');\n if (channelNameSetting) {\n const newChannelList = this.availableChannels[newVal] || [];\n if (!newChannelList.some(ch => ch.name === channelNameSetting.value)) {\n channelNameSetting.value = '';\n }\n }\n }\n }\n },\n methods: {\n saveSettings() {\n fetchWithAuth('/api/manage/sysConfig/page', {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json'\n },\n body: JSON.stringify(this.settings)\n }).then(() => this.$message.success('设置已保存'));\n },\n // 获取可用渠道列表\n async fetchAvailableChannels() {\n try {\n const response = await axios.get('/api/channels');\n if (response.data) {\n this.availableChannels = response.data;\n }\n } catch (error) {\n console.error('Failed to fetch available channels:', error);\n }\n }\n },\n mounted() {\n this.loading = true;\n // 获取可用渠道列表\n this.fetchAvailableChannels();\n // 获取上传设置\n fetchWithAuth('/api/manage/sysConfig/page').then(response => response.json()).then(data => {\n this.settings = data;\n // 处理布尔类型的值初始化\n if (this.settings.config) {\n this.settings.config.forEach(setting => {\n if (setting.type === 'boolean') {\n // 将字符串转换为布尔值\n if (typeof setting.value === 'string') {\n setting.value = setting.value === 'true';\n } else if (setting.value === undefined || setting.value === null) {\n // 如果没有值,使用默认值\n setting.value = setting.default || false;\n }\n }\n });\n }\n }).finally(() => {\n this.loading = false;\n });\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./SysCogPage.vue?vue&type=template&id=44bd640d&scoped=true\"\nimport script from \"./SysCogPage.vue?vue&type=script&lang=js\"\nexport * from \"./SysCogPage.vue?vue&type=script&lang=js\"\n\nimport \"./SysCogPage.vue?vue&type=style&index=0&id=44bd640d&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-44bd640d\"]])\n\nexport default __exports__","import { resolveComponent as _resolveComponent, createVNode as _createVNode, withCtx as _withCtx, createTextVNode as _createTextVNode, createElementVNode as _createElementVNode, renderList as _renderList, Fragment as _Fragment, openBlock as _openBlock, createElementBlock as _createElementBlock, createBlock as _createBlock, createCommentVNode as _createCommentVNode, resolveDirective as _resolveDirective, withDirectives as _withDirectives } from \"vue\";\nconst _hoisted_1 = {\n class: \"others-settings\"\n};\nconst _hoisted_2 = {\n class: \"first-settings\"\n};\nconst _hoisted_3 = {\n class: \"first-title\"\n};\nconst _hoisted_4 = {\n class: \"first-title\"\n};\nconst _hoisted_5 = {\n class: \"first-title\"\n};\nconst _hoisted_6 = {\n class: \"first-title\"\n};\nconst _hoisted_7 = {\n class: \"first-title\"\n};\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n const _component_el_tooltip = _resolveComponent(\"el-tooltip\");\n const _component_el_switch = _resolveComponent(\"el-switch\");\n const _component_el_form_item = _resolveComponent(\"el-form-item\");\n const _component_el_form = _resolveComponent(\"el-form\");\n const _component_el_input = _resolveComponent(\"el-input\");\n const _component_el_option = _resolveComponent(\"el-option\");\n const _component_el_select = _resolveComponent(\"el-select\");\n const _component_FloatingSaveButton = _resolveComponent(\"FloatingSaveButton\");\n const _directive_loading = _resolveDirective(\"loading\");\n return _withDirectives((_openBlock(), _createElementBlock(\"div\", _hoisted_1, [_createElementVNode(\"div\", _hoisted_2, [_createElementVNode(\"h3\", _hoisted_3, [_cache[13] || (_cache[13] = _createTextVNode(\"远端遥测 \", -1)), _createVNode(_component_el_tooltip, {\n content: \"便于问题查找和定位,建议开启\",\n placement: \"right\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"question-circle\",\n style: {\n \"margin-left\": \"5px\",\n \"cursor\": \"pointer\"\n }\n })]),\n _: 1\n })]), _createVNode(_component_el_form, {\n model: $data.settings.telemetry,\n \"label-width\": \"120px\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_form_item, {\n label: \"启用\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_switch, {\n modelValue: $data.settings.telemetry.enabled,\n \"onUpdate:modelValue\": _cache[0] || (_cache[0] = $event => $data.settings.telemetry.enabled = $event),\n disabled: $data.settings.telemetry.fixed\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n })]),\n _: 1\n }, 8, [\"model\"]), _createElementVNode(\"h3\", _hoisted_4, [_cache[14] || (_cache[14] = _createTextVNode(\"随机图像API \", -1)), _createVNode(_component_el_tooltip, {\n content: \"API具体用法请查阅文档\",\n placement: \"right\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"question-circle\",\n style: {\n \"margin-left\": \"5px\",\n \"cursor\": \"pointer\"\n }\n })]),\n _: 1\n })]), _createVNode(_component_el_form, {\n model: $data.settings.randomImageAPI,\n \"label-width\": \"120px\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_form_item, {\n label: \"启用\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_switch, {\n modelValue: $data.settings.randomImageAPI.enabled,\n \"onUpdate:modelValue\": _cache[1] || (_cache[1] = $event => $data.settings.randomImageAPI.enabled = $event),\n disabled: $data.settings.randomImageAPI.fixed\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n prop: \"randomImageAPI.allowedDir\"\n }, {\n label: _withCtx(() => [_cache[15] || (_cache[15] = _createElementVNode(\"span\", null, \"目录\", -1)), _createVNode(_component_el_tooltip, {\n content: \"1. 开放随机图权限的目录,默认为根目录,多个目录用逗号分隔
2. 目录均采用绝对路径,例如/img/cover,表示该目录及其所有子目录的文件可被随机图API访问\",\n placement: \"right\",\n \"raw-content\": \"\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"question-circle\",\n style: {\n \"margin-left\": \"5px\",\n \"cursor\": \"pointer\"\n }\n })]),\n _: 1\n })]),\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.settings.randomImageAPI.allowedDir,\n \"onUpdate:modelValue\": _cache[2] || (_cache[2] = $event => $data.settings.randomImageAPI.allowedDir = $event),\n disabled: $data.settings.randomImageAPI.fixed\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n })]),\n _: 1\n }, 8, [\"model\"]), _createElementVNode(\"h3\", _hoisted_5, [_cache[16] || (_cache[16] = _createTextVNode(\"访客图库 \", -1)), _createVNode(_component_el_tooltip, {\n content: \"启用后,访客可通过 /browse 路径浏览指定目录的图片(只读,无法删除/移动)\",\n placement: \"right\",\n \"raw-content\": \"\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"question-circle\",\n style: {\n \"margin-left\": \"5px\",\n \"cursor\": \"pointer\"\n }\n })]),\n _: 1\n })]), _createVNode(_component_el_form, {\n model: $data.settings.publicBrowse,\n \"label-width\": \"120px\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_form_item, {\n label: \"启用\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_switch, {\n modelValue: $data.settings.publicBrowse.enabled,\n \"onUpdate:modelValue\": _cache[3] || (_cache[3] = $event => $data.settings.publicBrowse.enabled = $event),\n disabled: $data.settings.publicBrowse.fixed\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n prop: \"publicBrowse.allowedDir\"\n }, {\n label: _withCtx(() => [_cache[18] || (_cache[18] = _createElementVNode(\"span\", null, \"开放目录\", -1)), _createVNode(_component_el_tooltip, {\n placement: \"right\",\n \"raw-content\": \"\"\n }, {\n content: _withCtx(() => [...(_cache[17] || (_cache[17] = [_createElementVNode(\"div\", {\n style: {\n \"max-width\": \"320px\",\n \"line-height\": \"1.6\"\n }\n }, [_createElementVNode(\"p\", {\n style: {\n \"margin\": \"0 0 8px 0\"\n }\n }, [_createElementVNode(\"b\", null, \"允许公开浏览的目录,多个目录用逗号分隔\")]), _createElementVNode(\"p\", {\n style: {\n \"margin\": \"0 0 8px 0\"\n }\n }, \"示例:wallpaper,photos,album\"), _createElementVNode(\"p\", {\n style: {\n \"margin\": \"0 0 8px 0\",\n \"color\": \"#909399\"\n }\n }, \"支持子目录:2026/lucky,2026/rich\"), _createElementVNode(\"p\", {\n style: {\n \"margin\": \"0\",\n \"color\": \"#67c23a\"\n }\n }, \"访问链接:https://你的域名/browse/2026/lucky\")], -1)]))]),\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"question-circle\",\n style: {\n \"margin-left\": \"5px\",\n \"cursor\": \"pointer\"\n }\n })]),\n _: 1\n })]),\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.settings.publicBrowse.allowedDir,\n \"onUpdate:modelValue\": _cache[4] || (_cache[4] = $event => $data.settings.publicBrowse.allowedDir = $event),\n disabled: $data.settings.publicBrowse.fixed,\n placeholder: \"wallpaper,photos,album\"\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n })]),\n _: 1\n }, 8, [\"model\"]), _createElementVNode(\"h3\", _hoisted_6, [_cache[19] || (_cache[19] = _createTextVNode(\"CloudFlare API Token \", -1)), _createVNode(_component_el_tooltip, {\n content: \"设置后可以使后端拉黑、删除等操作不受CDN缓存限制
建议设置,设置方式请查阅文档\",\n placement: \"right\",\n \"raw-content\": \"\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"question-circle\",\n style: {\n \"margin-left\": \"5px\",\n \"cursor\": \"pointer\"\n }\n })]),\n _: 1\n })]), _createVNode(_component_el_form, {\n model: $data.settings.cloudflareApiToken,\n \"label-width\": \"120px\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_form_item, {\n label: \"区域ID\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.settings.cloudflareApiToken.CF_ZONE_ID,\n \"onUpdate:modelValue\": _cache[5] || (_cache[5] = $event => $data.settings.cloudflareApiToken.CF_ZONE_ID = $event),\n disabled: $data.settings.cloudflareApiToken.fixed\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"账户邮箱\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.settings.cloudflareApiToken.CF_EMAIL,\n \"onUpdate:modelValue\": _cache[6] || (_cache[6] = $event => $data.settings.cloudflareApiToken.CF_EMAIL = $event),\n disabled: $data.settings.cloudflareApiToken.fixed\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"API Key\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.settings.cloudflareApiToken.CF_API_KEY,\n \"onUpdate:modelValue\": _cache[7] || (_cache[7] = $event => $data.settings.cloudflareApiToken.CF_API_KEY = $event),\n disabled: $data.settings.cloudflareApiToken.fixed,\n type: \"password\",\n \"show-password\": \"\",\n autocomplete: \"new-password\"\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n })]),\n _: 1\n }, 8, [\"model\"]), _createElementVNode(\"h3\", _hoisted_7, [_cache[20] || (_cache[20] = _createTextVNode(\"WebDAV \", -1)), _createVNode(_component_el_tooltip, {\n content: \"启用后,可以通过WebDAV协议访问和管理图片\",\n placement: \"right\",\n \"raw-content\": \"\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"question-circle\",\n style: {\n \"margin-left\": \"5px\",\n \"cursor\": \"pointer\"\n }\n })]),\n _: 1\n })]), _createVNode(_component_el_form, {\n model: $data.settings.webDAV,\n \"label-width\": \"120px\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_form_item, {\n label: \"启用\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_switch, {\n modelValue: $data.settings.webDAV.enabled,\n \"onUpdate:modelValue\": _cache[8] || (_cache[8] = $event => $data.settings.webDAV.enabled = $event),\n disabled: $data.settings.webDAV.fixed\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"用户名\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.settings.webDAV.username,\n \"onUpdate:modelValue\": _cache[9] || (_cache[9] = $event => $data.settings.webDAV.username = $event),\n disabled: $data.settings.webDAV.fixed\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"密码\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $data.settings.webDAV.password,\n \"onUpdate:modelValue\": _cache[10] || (_cache[10] = $event => $data.settings.webDAV.password = $event),\n disabled: $data.settings.webDAV.fixed,\n type: \"password\",\n \"show-password\": \"\",\n autocomplete: \"new-password\"\n }, null, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), _createVNode(_component_el_form_item, {\n label: \"上传渠道\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_select, {\n modelValue: $data.settings.webDAV.uploadChannel,\n \"onUpdate:modelValue\": _cache[11] || (_cache[11] = $event => $data.settings.webDAV.uploadChannel = $event),\n disabled: $data.settings.webDAV.fixed,\n placeholder: \"默认渠道\",\n clearable: \"\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_option, {\n label: \"Telegram\",\n value: \"telegram\"\n }), _createVNode(_component_el_option, {\n label: \"Cloudflare R2\",\n value: \"cfr2\"\n }), _createVNode(_component_el_option, {\n label: \"S3\",\n value: \"s3\"\n }), _createVNode(_component_el_option, {\n label: \"Discord\",\n value: \"discord\"\n }), _createVNode(_component_el_option, {\n label: \"HuggingFace\",\n value: \"huggingface\"\n })]),\n _: 1\n }, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n }), $data.settings.webDAV.uploadChannel && $options.webdavChannelList.length > 1 ? (_openBlock(), _createBlock(_component_el_form_item, {\n key: 0,\n label: \"指定渠道名\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_select, {\n modelValue: $data.settings.webDAV.channelName,\n \"onUpdate:modelValue\": _cache[12] || (_cache[12] = $event => $data.settings.webDAV.channelName = $event),\n disabled: $data.settings.webDAV.fixed,\n placeholder: \"自动选择\",\n clearable: \"\"\n }, {\n default: _withCtx(() => [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($options.webdavChannelList, ch => {\n return _openBlock(), _createBlock(_component_el_option, {\n key: ch.name,\n label: ch.name,\n value: ch.name\n }, null, 8, [\"label\", \"value\"]);\n }), 128))]),\n _: 1\n }, 8, [\"modelValue\", \"disabled\"])]),\n _: 1\n })) : _createCommentVNode(\"\", true)]),\n _: 1\n }, 8, [\"model\"])]), _createVNode(_component_FloatingSaveButton, {\n show: !$data.loading,\n onClick: $options.saveSettings\n }, null, 8, [\"show\", \"onClick\"])])), [[_directive_loading, $data.loading]]);\n}","import \"core-js/modules/es.json.stringify.js\";\nimport fetchWithAuth from '@/utils/fetchWithAuth';\nimport FloatingSaveButton from '@/components/FloatingSaveButton.vue';\nexport default {\n components: {\n FloatingSaveButton\n },\n data() {\n return {\n settings: {\n telemetry: {},\n randomImageAPI: {},\n cloudflareApiToken: {},\n webDAV: {},\n publicBrowse: {}\n },\n availableChannels: {},\n // 可用渠道列表\n // 加载状态\n loading: true\n };\n },\n computed: {\n // WebDAV 当前渠道类型对应的渠道列表\n webdavChannelList() {\n const channelType = this.settings.webDAV?.uploadChannel;\n return channelType ? this.availableChannels[channelType] || [] : [];\n }\n },\n watch: {\n 'settings.webDAV.uploadChannel'() {\n // 切换渠道类型时清空指定的渠道名称\n if (this.settings.webDAV) {\n this.settings.webDAV.channelName = '';\n }\n }\n },\n methods: {\n saveSettings() {\n fetchWithAuth('/api/manage/sysConfig/others', {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json'\n },\n body: JSON.stringify(this.settings)\n }).then(() => this.$message.success('设置已保存'));\n },\n async fetchAvailableChannels() {\n try {\n const response = await fetchWithAuth('/api/channels');\n if (response.ok) {\n this.availableChannels = await response.json();\n }\n } catch (error) {\n console.error('Failed to fetch available channels:', error);\n }\n }\n },\n mounted() {\n this.loading = true;\n // 获取上传设置\n fetchWithAuth('/api/manage/sysConfig/others').then(response => response.json()).then(data => {\n this.settings = data;\n }).finally(() => {\n this.loading = false;\n });\n // 获取可用渠道列表\n this.fetchAvailableChannels();\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./SysCogOthers.vue?vue&type=template&id=0cedb60a&scoped=true\"\nimport script from \"./SysCogOthers.vue?vue&type=script&lang=js\"\nexport * from \"./SysCogOthers.vue?vue&type=script&lang=js\"\n\nimport \"./SysCogOthers.vue?vue&type=style&index=0&id=0cedb60a&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-0cedb60a\"]])\n\nexport default __exports__","import \"core-js/modules/es.array.push.js\";\nimport DashboardTabs from '@/components/DashboardTabs.vue';\nimport SysConfigTabs from '@/components/SysConfigTabs.vue';\nimport SysCogStatus from '@/components/SysCogStatus.vue';\nimport SysCogUpload from '@/components/SysCogUpload.vue';\nimport SysCogSecurity from '@/components/SysCogSecurity.vue';\nimport SysCogPage from '@/components/SysCogPage.vue';\nimport SysCogOthers from '@/components/SysCogOthers.vue';\nexport default {\n name: 'SystemConfig',\n data() {\n return {\n activeIndex: 'status',\n isSidebarCollapse: false\n };\n },\n watch: {\n // 监听锚点变化\n '$route.hash': {\n immediate: true,\n handler(newHash) {\n this.activeIndex = newHash.replace('#', '');\n window.scrollTo(0, 0); // 滚动到页面顶部\n }\n },\n activeIndex(newIndex) {\n // 更新锚点\n const hash = `#${newIndex}`;\n this.$router.push({\n hash\n });\n }\n },\n components: {\n DashboardTabs,\n SysConfigTabs,\n SysCogStatus,\n SysCogUpload,\n SysCogSecurity,\n SysCogPage,\n SysCogOthers\n },\n computed: {\n disableTooltip() {\n return window.innerWidth < 768;\n },\n // 根据锚点动态返回对应的组件\n currentComponent() {\n const hash = this.$route.hash.replace('#', '');\n switch (hash) {\n case 'status':\n return SysCogStatus;\n case 'upload':\n return SysCogUpload;\n case 'security':\n return SysCogSecurity;\n case 'page':\n return SysCogPage;\n case 'others':\n return SysCogOthers;\n default:\n return SysCogStatus;\n }\n }\n },\n methods: {\n handleLogout() {\n this.$store.commit('setCredentials', null);\n this.$router.push('/adminLogin');\n },\n // 设置默认锚点\n setDefaultHash() {\n const defaultHash = '#status'; // 默认锚点\n window.location.hash = defaultHash;\n this.activeIndex = defaultHash.replace('#', '');\n }\n },\n mounted() {\n // 如果 URL 中没有锚点,则设置默认锚点\n if (!window.location.hash) {\n this.setDefaultHash();\n }\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./SystemConfig.vue?vue&type=template&id=4cdf1dc2&scoped=true\"\nimport script from \"./SystemConfig.vue?vue&type=script&lang=js\"\nexport * from \"./SystemConfig.vue?vue&type=script&lang=js\"\n\nimport \"./SystemConfig.vue?vue&type=style&index=0&id=4cdf1dc2&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-4cdf1dc2\"]])\n\nexport default __exports__"],"names":["_typeof","o","Symbol","iterator","constructor","prototype","toPrimitive","t","r","e","i","call","TypeError","String","Number","toPropertyKey","_defineProperty","Object","defineProperty","value","enumerable","configurable","writable","_hoisted_1","class","_hoisted_2","_hoisted_3","render","_ctx","_cache","$props","$setup","$data","$options","_component_font_awesome_icon","isCollapse","menuItems","item","key","index","activeIndex","onClick","$event","handleSelect","icon","title","args","toggleCollapse","name","props","type","default","Boolean","data","methods","this","$emit","checkMobile","isMobile","window","innerWidth","mounted","addEventListener","beforeDestroy","removeEventListener","__exports__","_component_DashboardTabs","_component_el_tooltip","_component_el_header","_component_SysConfigTabs","activeTab","disabled","disableTooltip","content","placement","handleLogout","_","isSidebarCollapse","currentComponent","_hoisted_4","_hoisted_5","_hoisted_6","_hoisted_7","_hoisted_8","_hoisted_9","_hoisted_10","_hoisted_11","_hoisted_12","_hoisted_13","_hoisted_14","_hoisted_15","_hoisted_16","_hoisted_17","_hoisted_18","_hoisted_19","_hoisted_20","_hoisted_21","_hoisted_22","_hoisted_23","_hoisted_24","_hoisted_25","_hoisted_26","_hoisted_27","_hoisted_28","_hoisted_29","_hoisted_30","_hoisted_31","_hoisted_32","_hoisted_33","_hoisted_34","_hoisted_35","_hoisted_36","_hoisted_37","_hoisted_38","_hoisted_39","_hoisted_40","_hoisted_41","_hoisted_42","_hoisted_43","_hoisted_44","_hoisted_45","_hoisted_46","_hoisted_47","_hoisted_48","_hoisted_49","_hoisted_50","_hoisted_51","_hoisted_52","_hoisted_53","_hoisted_54","_hoisted_55","_hoisted_56","_hoisted_57","_hoisted_58","_hoisted_59","_hoisted_60","_hoisted_61","_hoisted_62","_hoisted_63","_hoisted_64","_hoisted_65","_hoisted_66","_hoisted_67","_hoisted_68","_hoisted_69","_hoisted_70","_hoisted_71","_component_Doughnut","_component_el_progress","_component_el_button","_component_el_image","_directive_loading","fetchIndexInfo","indexInfo","totalFiles","toLocaleString","formatTime","lastUpdated","getTimeAgo","openReleases","version","keys","channelStats","length","channelChartData","options","chartOptions","count","channel","style","background","getChartColor","getPercentage","typeStats","typeChartData","aggregatedTypeStats","status","getTypeChartColor","isProcessing","phaseDescription","Math","round","processingProgress","percentage","current","total","estimatedTimeRemaining","message","plain","size","cancelOperation","processingError","suggestion","recoverable","retryOperation","dismissError","loading","rebuilding","rebuildIndex","backing","backupData","ref","accept","onChange","handleFileSelect","restoring","selectRestoreFile","newestFile","oldestFile","openFileInNewTab","isImageFile","loadErrors","src","id","fit","onError","handleImageError","isVideoFile","muted","loop","autoplay","metadata","FileName","TimeStamp","v","lim","l","h","max","min","p2b","n2b","b2n","n2p","map$1","A","B","C","D","E","F","a","b","c","d","f","hex","h1","h2","eq","isShort","g","hexParse","str","ret","len","alpha","hexString","undefined","HUE_RE","hsl2rgbn","s","n","k","hsv2rgbn","hwb2rgbn","w","rgb","hueValue","rgb2hsl","range","calln","Array","isArray","map","hsl2rgb","hwb2rgb","hsv2rgb","hue","hueParse","m","exec","p1","p2","rotate","deg","hslString","x","Z","Y","X","W","V","U","T","S","R","Q","P","O","N","M","L","K","G","H","I","J","names$1","OiceXe","antiquewEte","aqua","aquamarRe","azuY","beige","bisque","black","blanKedOmond","Xe","XeviTet","bPwn","burlywood","caMtXe","KartYuse","KocTate","cSO","cSnflowerXe","cSnsilk","crimson","cyan","xXe","xcyan","xgTMnPd","xWay","xgYF","xgYy","xkhaki","xmagFta","xTivegYF","xSange","xScEd","xYd","xsOmon","xsHgYF","xUXe","xUWay","xUgYy","xQe","xviTet","dAppRk","dApskyXe","dimWay","dimgYy","dodgerXe","fiYbrick","flSOwEte","foYstWAn","fuKsia","gaRsbSo","ghostwEte","gTd","gTMnPd","Way","gYF","gYFLw","gYy","honeyMw","hotpRk","RdianYd","Rdigo","ivSy","khaki","lavFMr","lavFMrXsh","lawngYF","NmoncEffon","ZXe","ZcSO","Zcyan","ZgTMnPdLw","ZWay","ZgYF","ZgYy","ZpRk","ZsOmon","ZsHgYF","ZskyXe","ZUWay","ZUgYy","ZstAlXe","ZLw","lime","limegYF","lRF","magFta","maPon","VaquamarRe","VXe","VScEd","VpurpN","VsHgYF","VUXe","VsprRggYF","VQe","VviTetYd","midnightXe","mRtcYam","mistyPse","moccasR","navajowEte","navy","Tdlace","Tive","TivedBb","Sange","SangeYd","ScEd","pOegTMnPd","pOegYF","pOeQe","pOeviTetYd","papayawEp","pHKpuff","peru","pRk","plum","powMrXe","purpN","YbeccapurpN","Yd","Psybrown","PyOXe","saddNbPwn","sOmon","sandybPwn","sHgYF","sHshell","siFna","silver","skyXe","UXe","UWay","UgYy","snow","sprRggYF","stAlXe","tan","teO","tEstN","tomato","Qe","viTet","JHt","wEte","wEtesmoke","Lw","LwgYF","unpack","unpacked","tkeys","j","ok","nk","replace","parseInt","names","nameParse","transparent","toLowerCase","RGB_RE","rgbParse","rgbString","to","pow","from","interpolate","rgb1","rgb2","modHSL","ratio","tmp","clone","proto","assign","fromObject","input","functionParse","charAt","Color","_rgb","_valid","valid","obj","mix","color","weight","c1","c2","w2","p","w1","clearer","greyscale","val","opaquer","negate","lighten","darken","saturate","desaturate","noop","uid","isNullOrUndef","toString","slice","isObject","isNumberFinite","isFinite","finiteOrDefault","defaultValue","valueOrDefault","toPercentage","dimension","endsWith","parseFloat","toDimension","callback","fn","thisArg","apply","each","loopable","reverse","_elementsEqual","a0","a1","ilen","v0","v1","datasetIndex","source","target","create","klen","isValidKey","indexOf","_merger","tval","sval","merge","sources","merger","mergeIf","_mergerIf","hasOwnProperty","keyResolvers","y","_splitKey","parts","split","part","push","_getKeyResolver","resolveObjectKey","resolver","_capitalize","toUpperCase","defined","isFunction","setsEqual","has","_isClickEvent","PI","TAU","PITAU","INFINITY","POSITIVE_INFINITY","RAD_PER_DEG","HALF_PI","QUARTER_PI","TWO_THIRDS_PI","log10","sign","almostEquals","epsilon","abs","niceNum","roundedRange","niceRange","floor","fraction","niceFraction","_factorize","result","sqrt","sort","pop","isNonPrimitive","isNumber","isNaN","almostWhole","rounded","_setMinAndMaxByKey","array","property","toRadians","degrees","toDegrees","radians","_decimalPlaces","getAngleFromPoint","centrePoint","anglePoint","distanceFromXCenter","distanceFromYCenter","radialDistanceFromCenter","angle","atan2","distance","distanceBetweenPoints","pt1","pt2","_angleDiff","_normalizeAngle","_angleBetween","start","end","sameAngleIsFullCircle","angleToStart","angleToEnd","startToAngle","endToAngle","_limitValue","_int16Range","_isBetween","_lookup","table","cmp","mid","hi","lo","_lookupByKey","last","ti","_rlookupByKey","_filterBetween","values","arrayEvents","listenArrayEvents","listener","_chartjs","listeners","forEach","method","base","res","object","unlistenArrayEvents","stub","splice","_arrayUnique","items","set","Set","requestAnimFrame","requestAnimationFrame","throttled","argsToUse","ticking","debounce","delay","timeout","clearTimeout","setTimeout","_toLeftRightCenter","align","_alignStartEnd","_textX","left","right","rtl","check","_getStartAndCountOfVisiblePoints","meta","points","animationsDisabled","pointCount","_sorted","iScale","vScale","_parsed","spanGaps","dataset","axis","minDefined","maxDefined","getUserBounds","getPixelForValue","distanceToDefinedLo","findIndex","point","distanceToDefinedHi","_scaleRangesChanged","xScale","yScale","_scaleRanges","newRanges","xmin","xmax","ymin","ymax","changed","atEdge","elasticIn","sin","elasticOut","effects","linear","easeInQuad","easeOutQuad","easeInOutQuad","easeInCubic","easeOutCubic","easeInOutCubic","easeInQuart","easeOutQuart","easeInOutQuart","easeInQuint","easeOutQuint","easeInOutQuint","easeInSine","cos","easeOutSine","easeInOutSine","easeInExpo","easeOutExpo","easeInOutExpo","easeInCirc","easeOutCirc","easeInOutCirc","easeInElastic","easeOutElastic","easeInOutElastic","easeInBack","easeOutBack","easeInOutBack","easeInBounce","easeOutBounce","easeInOutBounce","isPatternOrGradient","getHoverColor","numbers","colors","applyAnimationsDefaults","defaults","duration","easing","describe","_fallback","_indexable","_scriptable","properties","active","animation","resize","show","animations","visible","hide","applyLayoutsDefaults","autoPadding","padding","top","bottom","intlCache","Map","getNumberFormat","locale","cacheKey","JSON","stringify","formatter","get","Intl","NumberFormat","formatNumber","num","format","formatters","numeric","tickValue","ticks","chart","notation","delta","maxTick","calculateDelta","logDelta","numDecimal","minimumFractionDigits","maximumFractionDigits","logarithmic","remain","significand","includes","Ticks","applyScaleDefaults","display","offset","beginAtZero","bounds","clip","grace","grid","lineWidth","drawOnChartArea","drawTicks","tickLength","tickWidth","tickColor","border","dash","dashOffset","width","text","minRotation","maxRotation","mirror","textStrokeWidth","textStrokeColor","autoSkip","autoSkipPadding","labelOffset","minor","major","crossAlign","showLabelBackdrop","backdropColor","backdropPadding","route","startsWith","overrides","descriptors","getScope$1","node","root","scope","Defaults","_descriptors","_appliers","backgroundColor","borderColor","datasets","devicePixelRatio","context","platform","getDevicePixelRatio","elements","events","font","family","lineHeight","hover","hoverBackgroundColor","ctx","hoverBorderColor","hoverColor","indexAxis","interaction","mode","intersect","includeInvisible","maintainAspectRatio","onHover","parsing","plugins","responsive","scale","scales","showLine","drawActiveElementsOnTop","override","targetScope","targetName","scopeObject","targetScopeObject","privateName","defineProperties","local","appliers","toFontString","_measureText","gc","longest","string","textWidth","measureText","_longestText","arrayOfThings","cache","garbageCollect","save","jlen","thing","nestedThing","restore","gcLen","_alignPixel","pixel","currentDevicePixelRatio","halfWidth","clearCanvas","canvas","getContext","resetTransform","clearRect","height","drawPoint","drawPointLegend","xOffset","yOffset","cornerRadius","xOffsetW","yOffsetW","pointStyle","rotation","radius","rad","translate","drawImage","beginPath","ellipse","arc","closePath","moveTo","lineTo","SQRT1_2","rect","fill","borderWidth","stroke","_isPointInArea","area","margin","clipArea","unclipArea","_steppedLineTo","previous","flip","midpoint","_bezierCurveTo","bezierCurveTo","cp1x","cp2x","cp1y","cp2y","setRenderOpts","opts","translation","fillStyle","textAlign","textBaseline","decorateText","line","strikethrough","underline","metrics","actualBoundingBoxLeft","actualBoundingBoxRight","actualBoundingBoxAscent","actualBoundingBoxDescent","yDecoration","strokeStyle","decorationWidth","drawBackdrop","oldColor","fillRect","renderText","lines","strokeWidth","strokeColor","backdrop","strokeText","maxWidth","fillText","addRoundedRectPath","topLeft","bottomLeft","bottomRight","topRight","LINE_HEIGHT","FONT_STYLE","toLineHeight","matches","match","numberOrZero","_readValueToProps","objProps","read","prop","toTRBL","toTRBLCorners","toPadding","toFont","fallback","console","warn","resolve","inputs","info","cacheable","_addGrace","minmax","change","keepZero","add","createContext","parentContext","_createResolver","scopes","prefixes","rootScopes","getTarget","finalRootScopes","_resolve","toStringTag","_cacheable","_scopes","_rootScopes","_getTarget","Proxy","deleteProperty","_keys","_cached","_resolveWithPrefixes","getOwnPropertyDescriptor","Reflect","getPrototypeOf","getKeysFromAllScopes","ownKeys","storage","_storage","_attachContext","proxy","subProxy","descriptorDefaults","_proxy","_context","_subProxy","_stack","setContext","receiver","_resolveWithContext","allKeys","scriptable","indexable","_allKeys","isScriptable","isIndexable","readKey","prefix","needsSubResolver","_resolveScriptable","_resolveArray","getValue","Error","join","delete","createSubResolver","arr","filter","resolveFallback","getScope","parent","addScopes","parentScopes","parentFallback","allScopes","addScopesFromKey","subGetTarget","resolveKeysFromAllScopes","_parseObjectDataRadialScale","_parsing","parsed","parse","EPSILON","getPoint","skip","getValueAxis","splineCurve","firstPoint","middlePoint","afterPoint","next","d01","d12","s01","s12","fa","fb","monotoneAdjust","deltaK","mK","pointsLen","alphaK","betaK","tauK","squaredMagnitude","pointCurrent","pointAfter","monotoneCompute","valueAxis","pointBefore","iPixel","vPixel","splineCurveMonotone","slopeDelta","capControlPoint","pt","capBezierPoints","inArea","inAreaPrev","inAreaNext","_updateBezierControlPoints","controlPoints","cubicInterpolationMode","prev","tension","_isDomSupported","document","_getParentNode","domNode","parentNode","host","parseMaxStyle","styleValue","parentProperty","valueInPixels","getComputedStyle","element","ownerDocument","defaultView","getStyle","el","getPropertyValue","positions","getPositionedStyle","styles","suffix","pos","useOffsetPos","shadowRoot","getCanvasPosition","touches","offsetX","offsetY","box","getBoundingClientRect","clientX","clientY","getRelativePosition","event","borderBox","boxSizing","paddings","borders","getContainerSize","maxHeight","container","containerStyle","containerBorder","containerPadding","clientWidth","clientHeight","round1","getMaximumSize","bbWidth","bbHeight","aspectRatio","margins","containerSize","maintainHeight","retinaScale","forceRatio","forceStyle","pixelRatio","deviceHeight","deviceWidth","setTransform","supportsEventListenerOptions","passiveSupported","passive","readUsedSize","_pointInLine","_steppedInterpolation","_bezierInterpolation","cp1","cp2","getRightToLeftAdapter","rectX","setWidth","xPlus","leftForLtr","itemWidth","getLeftToRightAdapter","_itemWidth","getRtlAdapter","overrideTextDirection","direction","original","getPropertyPriority","setProperty","prevTextDirection","restoreTextDirection","propertyFn","between","compare","normalize","normalizeSegment","getSegment","segment","startBound","endBound","_boundSegment","prevValue","inside","subStart","startIsBefore","endIsBefore","shouldStart","shouldStop","_boundSegments","segments","sub","findStartAndEnd","solidSegments","cur","stop","_computeSegments","segmentOptions","_loop","splitByStyles","completeLoop","_fullLoop","doSplitByStyles","chartContext","_chart","baseStyle","readStyle","_datasetIndex","prevStyle","addStyle","st","dir","p0","p0DataIndex","p1DataIndex","styleChanged","borderCapStyle","borderDash","borderDashOffset","borderJoinStyle","replacer","getSizeForArea","chartArea","field","getDatasetArea","getDatasetClipArea","_clip","Animator","_request","_charts","_running","_lastDate","_notify","anims","date","callbacks","numSteps","initial","currentStep","_refresh","_update","Date","now","remaining","running","draw","_active","_total","tick","_getAnims","charts","complete","progress","listen","cb","reduce","acc","_duration","cancel","remove","animator","interpolators","boolean","factor","c0","number","Animation","cfg","currentValue","_fn","_easing","_start","_target","_prop","_from","_to","_promises","update","elapsed","wait","promises","Promise","rej","resolved","Animations","config","_properties","configure","animationOptions","animatedProps","getOwnPropertyNames","option","_animateOptions","newOptions","resolveTargetOptions","_createAnimations","$shared","awaitAll","$animations","then","anim","all","scaleClip","allowedOverflow","defaultClip","toClip","getSortedDatasetIndices","filterVisible","metasets","_getSortedDatasetMetas","applyStack","stack","dsIndex","singleMode","otherValue","found","convertObjectDataToArray","iAxisKey","vAxisKey","adata","isStacked","stacked","getStackKey","indexScale","valueScale","NEGATIVE_INFINITY","getOrCreateStack","stacks","stackKey","indexValue","subStack","getLastIndexInStack","positive","getMatchingVisibleMetas","updateStacks","controller","_cachedMeta","_stacks","iAxis","vAxis","itemStacks","_top","_bottom","visualValues","_visualValues","getFirstScaleId","shift","createDatasetContext","createDataContext","dataIndex","raw","clearStacks","isDirectUpdateMode","cloneIfNotShared","cached","shared","createStack","canStack","hidden","_stacked","DatasetController","_cachedDataOpts","getMeta","_type","_data","_objectData","_sharedOptions","_drawStart","_drawCount","enableOptionSharing","supportsDecimation","$context","_syncList","datasetElementType","dataElementType","initialize","linkScales","addElements","isPluginEnabled","updateIndex","getDataset","chooseId","xid","xAxisID","yid","yAxisID","rid","rAxisID","iid","iAxisID","vid","vAxisID","getScaleForId","rScale","getDatasetMeta","scaleID","_getOtherScale","reset","_destroy","_dataCheck","isExtensible","buildOrUpdateElements","resetNewElements","stackChanged","oldStacked","_resyncElements","scopeKeys","datasetScopeKeys","getOptionScopes","createResolver","sorted","parseArrayData","parseObjectData","parsePrimitiveData","isNotInOrderComparedToPrev","labels","getLabels","singleScale","xAxisKey","yAxisKey","getParsed","getDataElement","updateRangeFromParsed","parsedValue","NaN","getMinMax","otherScale","otherMin","otherMax","_skip","getAllParsedValues","getMaxOverflow","getLabelAndValue","label","getLabelForValue","resolveDatasetElementOptions","resolveDataElementOptions","_resolveElementOptions","elementType","sharing","datasetElementScopeKeys","resolveNamedOptions","freeze","_resolveAnimations","transition","datasetAnimationScopeKeys","getSharedOptions","includeOptions","sharedOptions","_animationsDisabled","_getSharedOptions","firstOpts","previouslySharedOptions","updateSharedOptions","updateElement","_setStyle","removeHoverStyle","setHoverStyle","_removeDatasetHoverStyle","_setDatasetHoverStyle","arg1","arg2","numMeta","numData","_insertElements","_removeElements","move","updateElements","removed","_sync","_dataChanges","_onDataPush","arguments","_onDataPop","_onDataShift","_onDataSplice","newCount","_onDataUnshift","getAllScaleValues","$bar","visibleMetas","concat","computeMinSampleSize","curr","_length","updateMinAndPrev","getPixelForTick","computeFitCategoryTraits","ruler","stackCount","thickness","barThickness","categoryPercentage","barPercentage","chunk","pixels","computeFlexCategoryTraits","percent","parseFloatBar","entry","startValue","endValue","barStart","barEnd","_custom","parseValue","parseArrayOrPrimitive","isFloatBar","custom","barSign","actualBase","isHorizontal","borderProps","horizontal","setBorderSkipped","edge","borderSkipped","enableBorderRadius","parseEdge","swap","startEnd","orig","v2","setInflateAmount","inflateAmount","BarController","super","bars","getBasePixel","_getRuler","vpixels","head","_calculateBarValuePixels","ipixels","_calculateBarIndexPixels","center","_getStacks","grouped","currentParsed","iScaleValue","skipNull","find","_getStackCount","_getAxisCount","_getAxis","getFirstScaleIdForIndexAxis","indexScaleId","firstScaleAxisId","_getStackIndex","_startPixel","_endPixel","baseValue","minBarLength","floating","getDataVisibility","startPixel","getPixelForDecimal","endPixel","getValueForPixel","halfGrid","getLineWidthForValue","maxBarThickness","Infinity","axisCount","axisID","axisNumber","stackIndex","rects","_index_","_value_","BubbleController","getRatioAndOffset","circumference","cutout","ratioX","ratioY","startAngle","endAngle","startX","startY","endX","endY","calcMax","calcMin","maxX","maxY","minX","minY","DoughnutController","innerRadius","outerRadius","getter","_getRotation","_getCircumference","_getRotationExtents","isDatasetVisible","arcs","spacing","getMaxBorderWidth","getMaxOffset","maxSize","chartWeight","_getRingWeight","maxRadius","radiusLength","_getVisibleDatasetWeightTotal","calculateTotal","_getRingWeightOffset","_circumference","animateRotate","calculateCircumference","animationOpts","centerX","centerY","animateScale","metaData","borderAlign","hoverBorderWidth","hoverOffset","ringWeightOffset","legend","generateLabels","useBorderRadius","borderRadius","fontColor","lineDash","lineDashOffset","lineJoin","legendItem","toggleDataVisibility","LineController","_dataset","_decimated","animated","maxGapLength","directUpdate","pointsCount","prevParsed","nullData","lastPoint","updateControlPoints","PolarAreaController","bind","_updateRadius","minSize","cutoutPercentage","getVisibleDatasetCount","xCenter","yCenter","datasetStartAngle","getIndexAngle","defaultAngle","countVisibleElements","_computeAngle","getDistanceFromCenterForValue","angleLines","circular","pointLabels","PieController","RadarController","pointPosition","getPointPositionForValue","ScatterController","registry","getElement","abstract","DateAdapterBase","members","init","formats","diff","startOf","endOf","adapters","_date","binarySearch","metaset","lookupMethod","_reversePixels","getRange","evaluateInteractionItems","position","handler","getSortedVisibleDatasetMetas","getDistanceMetricForAxis","useX","useY","deltaX","deltaY","getIntersectItems","useFinalPosition","isPointInArea","evaluationFunc","inRange","getNearestRadialItems","getProps","getNearestCartesianItems","distanceMetric","minDistance","getCenterPoint","pointInArea","getNearestItems","getAxisItems","rangeMethod","intersectsItem","Interaction","modes","nearest","STATIC_POSITIONS","filterByPosition","filterDynamicPositionByAxis","sortByWeight","wrapBoxes","boxes","layoutBoxes","stackWeight","buildStacks","layouts","wrap","placed","setLayoutDims","params","vBoxMaxWidth","hBoxMaxHeight","layout","fullSize","availableWidth","availableHeight","buildLayoutBoxes","centerHorizontal","centerVertical","leftAndTop","rightAndBottom","vertical","getCombinedMax","maxPadding","updateMaxPadding","boxPadding","updateDims","getPadding","newWidth","outerWidth","newHeight","outerHeight","widthChanged","heightChanged","same","other","handleMaxPadding","updatePos","getMargins","marginForPositions","fitBoxes","refitBoxes","refit","setBoxDims","placeBoxes","userPadding","addBox","_layers","z","removeBox","layoutItem","minPadding","verticalBoxes","horizontalBoxes","beforeLayout","visibleVerticalBoxCount","BasePlatform","acquireContext","releaseContext","isAttached","updateConfig","BasicPlatform","EXPANDO_KEY","EVENT_TYPES","touchstart","touchmove","touchend","pointerenter","pointerdown","pointermove","pointerup","pointerleave","pointerout","isNullOrEmpty","initCanvas","renderHeight","getAttribute","renderWidth","displayWidth","displayHeight","eventListenerOptions","addListener","removeListener","fromNativeEvent","native","nodeListContains","nodeList","contains","createAttachObserver","observer","MutationObserver","entries","trigger","addedNodes","removedNodes","observe","childList","subtree","createDetachObserver","drpListeningCharts","oldDevicePixelRatio","onWindowResize","dpr","listenDevicePixelRatioChanges","unlistenDevicePixelRatioChanges","createResizeObserver","ResizeObserver","contentRect","releaseObserver","disconnect","createProxyAndListen","DomPlatform","removeAttribute","setAttribute","proxies","$proxies","handlers","attach","detach","isConnected","_detectPlatform","OffscreenCanvas","Element","tooltipPosition","hasValue","final","tickOpts","determinedMaxTicks","determineMaxTicks","ticksLimit","maxTicksLimit","majorIndices","enabled","getMajorIndices","numMajorIndices","first","newTicks","skipMajors","calculateSpacing","avgMajorSpacing","_tickSize","maxScale","maxChart","_maxLength","evenMajorSpacing","getEvenSpacing","factors","ceil","majorStart","majorEnd","reverseAlign","offsetFromEdge","getTicksLimit","ticksLength","sample","numItems","increment","getPixelForGridLine","offsetGridLines","validIndex","lineValue","caches","getTickMarkLength","getTitleHeight","createScaleContext","createTickContext","titleAlign","titleArgs","titleX","titleY","positionAxisID","Scale","_margins","paddingTop","paddingBottom","paddingLeft","paddingRight","labelRotation","_range","_gridLineItems","_labelItems","_labelSizes","_longestTextCache","_userMax","_userMin","_suggestedMax","_suggestedMin","_ticksLength","_borderValue","_dataLimitsCached","suggestedMin","suggestedMax","metas","getTicks","xLabels","yLabels","getLabelItems","_computeLabelItems","beforeUpdate","sampleSize","beforeSetDimensions","setDimensions","afterSetDimensions","beforeDataLimits","determineDataLimits","afterDataLimits","beforeBuildTicks","buildTicks","afterBuildTicks","samplingEnabled","_convertTicksToLabels","beforeCalculateLabelRotation","calculateLabelRotation","afterCalculateLabelRotation","afterAutoSkip","beforeFit","afterFit","afterUpdate","reversePixels","_alignToPixels","alignToPixels","_callHooks","notifyPlugins","beforeTickToLabelConversion","generateTickLabels","afterTickToLabelConversion","numTicks","maxLabelDiagonal","_isVisible","labelSizes","_getLabelSizes","maxLabelWidth","widest","maxLabelHeight","highest","asin","titleOpts","gridOpts","titleHeight","tickPadding","angleRadians","labelHeight","labelWidth","_calculatePadding","_handleMargins","isRotated","labelsBelowTicks","offsetLeft","offsetRight","isFullSize","_computeLabelSizes","widths","heights","tickFont","fontString","nestedLabel","widestLabelSize","highestLabelSize","_resolveTickFontOptions","valueAt","idx","decimal","getDecimalForPixel","getBaseValue","optionTicks","rot","_computeGridLineItems","tl","borderOpts","axisWidth","axisHalfWidth","alignBorderValue","borderValue","alignedLineValue","tx1","ty1","tx2","ty2","x1","y1","x2","y2","limit","step","optsAtIndex","optsAtIndexBorder","lineColor","tickBorderDash","tickBorderDashOffset","tickAndPadding","hTickAndPadding","lineCount","textOffset","_getXAxisLabelAlignment","_getYAxisLabelAlignment","halfCount","tickTextAlign","labelPadding","_computeLabelArea","drawBackground","drawGrid","drawLine","setLineDash","drawBorder","lastLineWidth","drawLabels","renderTextOptions","drawTitle","tz","gz","bz","_maxDigits","fontSize","TypedRegistry","isForType","isPrototypeOf","register","parentScope","isIChartComponent","registerDefaults","unregister","itemDefaults","defaultRoutes","routeDefaults","routes","propertyParts","sourceName","sourceScope","Registry","controllers","_typedRegistries","_each","addControllers","addPlugins","addScales","getController","_get","getPlugin","getScale","removeControllers","removeElements","removePlugins","removeScales","typedRegistry","arg","reg","_getRegistryForType","_exec","itemReg","component","camelMethod","PluginService","_init","notify","hook","_createDescriptors","descriptor","plugin","cancelable","invalidate","_oldCache","_notifyStateChanges","allPlugins","createDescriptors","previousDescriptors","some","localIds","getOpts","pluginOpts","pluginScopeKeys","getIndexAxis","datasetDefaults","datasetOptions","getAxisFromDefaultScaleID","getDefaultScaleIDFromAxis","idMatchesAxis","axisFromPosition","determineAxis","scaleOptions","getAxisFromDataset","retrieveAxisFromDatasets","boundDs","mergeScaleConfig","chartDefaults","configScales","chartIndexAxis","scaleConf","error","defaultId","defaultScaleOptions","defaultID","initOptions","initData","initConfig","keyCache","keysCached","cachedKeys","generate","addIfFound","Config","_config","_scopeCache","_resolverCache","clearCache","clear","datasetType","additionalOptionScopes","_cachedScopes","mainScope","resetCache","keyLists","chartOptionScopes","subPrefixes","getResolver","needContext","subResolver","resolverCache","hasFunction","KNOWN_POSITIONS","positionIsHorizontal","compare2Level","l1","l2","onAnimationsComplete","onComplete","onAnimationProgress","onProgress","getCanvas","getElementById","instances","getChart","moveNumericKeys","intKey","determineLastEvent","lastEvent","inChartArea","isClick","Chart","invalidatePlugins","userConfig","initialCanvas","existingChart","_options","_aspectRatio","_metasets","_lastEvent","_listeners","_responsiveListeners","_sortedMetasets","_plugins","_hiddenIndices","attached","_doResize","resizeDelay","_initialize","bindEvents","_resizeBeforeDraw","_resize","newSize","newRatio","onResize","ensureScalesHaveIDs","scalesOptions","axisOptions","buildOrUpdateScales","scaleOpts","updated","isRadial","dposition","dtype","scaleType","scaleClass","hasUpdated","_updateMetasets","_destroyDatasetMeta","_removeUnreferencedMetasets","buildOrUpdateControllers","newControllers","order","ControllerClass","_resetElements","animsDisabled","_updateScales","_checkEventBindings","_updateHiddenIndices","_minPadding","_updateLayout","_updateDatasets","_eventHandler","_updateHoverStyles","existingEvents","newEvents","unbindEvents","changes","_getUniformDataChanges","datasetCount","makeSet","changeSet","noArea","_idx","_updateDataset","layers","_drawDatasets","_drawDataset","getElementsAtEventForMode","setDatasetVisibility","_updateVisibility","_stop","destroy","toBase64Image","toDataURL","bindUserEvents","bindResponsiveEvents","_add","_remove","detached","updateHoverStyle","getActiveElements","setActiveElements","activeElements","lastActive","pluginId","replay","hoverOptions","deactivated","activated","eventFilter","_handleEvent","_getActiveElements","clipSelf","outerAngleClip","innerAngleClip","clipWidth","clipArc","pixelMargin","angleMargin","toRadiusCorners","parseBorderRadius$1","angleDelta","halfThickness","innerLimit","computeOuterLimit","outerArcLimit","outerStart","outerEnd","innerStart","innerEnd","rThetaToXY","theta","pathArc","innerR","spacingOffset","noSpacingInnerRadius","noSpacingOuterRadius","avNogSpacingRadius","adjustedAngle","beta","angleOffset","outerStartAdjustedRadius","outerEndAdjustedRadius","outerStartAdjustedAngle","outerEndAdjustedAngle","innerStartAdjustedRadius","innerEndAdjustedRadius","innerStartAdjustedAngle","innerEndAdjustedAngle","outerMidAdjustedAngle","pCenter","p4","innerMidAdjustedAngle","p8","outerStartX","outerStartY","outerEndX","outerEndY","drawArc","fullCircles","inner","selfJoin","ArcElement","chartX","chartY","rAdjust","nonZeroBetween","betweenAngles","withinRadius","halfAngle","halfRadius","fix","radiusOffset","setStyle","lineCap","getLineMethod","stepped","pathVars","paramsStart","paramsEnd","segmentStart","segmentEnd","outside","pathSegment","lineMethod","fastPathSegment","prevX","lastY","avgX","countX","pointIndex","drawX","truncX","_getSegmentMethod","useFastPath","_getInterpolationMethod","strokePathWithCache","path","_path","Path2D","strokePathDirect","segmentMethod","usePath2D","LineElement","_points","_segments","_pointsUpdated","_interpolate","interpolated","inRange$1","hitRadius","PointElement","mouseX","mouseY","inXRange","inYRange","hoverRadius","getBarBounds","bar","half","skipOrLimit","parseBorderWidth","maxW","maxH","parseBorderRadius","maxR","enableBorder","boundingRects","outer","skipX","skipY","skipBoth","hasRadius","addNormalRectPath","inflateRect","amount","refRect","BarElement","addRectPath","getBoxSize","labelOpts","boxHeight","boxWidth","usePointStyle","pointStyleWidth","itemHeight","itemsEqual","Legend","_added","legendHitBoxes","_hoveredItem","doughnutMode","legendItems","columnSizes","lineWidths","buildLabels","labelFont","_computeTitleHeight","_fitRows","_fitCols","hitboxes","totalHeight","row","_itemHeight","heightLimit","totalWidth","currentColWidth","currentColHeight","col","calculateItemSize","adjustHitBoxes","rtlHelper","hitbox","_draw","defaultColor","halfFontSize","cursor","drawLegendBox","drawOptions","SQRT2","yBoxTop","xBoxLeft","textDirection","realX","fontLineHeight","calculateLegendItemHeight","titleFont","titlePadding","topPaddingPlusHalfFontSize","_getLegendItemAt","hitBox","lh","handleEvent","isListened","hoveredItem","sameItem","onLeave","calculateItemWidth","calculateItemHeight","legendItemText","plugin_legend","_element","_args","afterEvent","ci","WeakMap","positioners","average","xSet","xAverage","eventPosition","nearestElement","tp","pushOrConcat","toPush","splitNewlines","createTooltipItem","formattedValue","getTooltipSize","tooltip","body","footer","bodyFont","footerFont","titleLineCount","footerLineCount","bodyLineItemCount","combinedBodyLength","bodyItem","before","after","beforeBody","afterBody","titleSpacing","titleMarginBottom","bodyLineHeight","displayColors","bodySpacing","footerMarginTop","footerSpacing","widthPadding","maxLineWidth","determineYAlign","doesNotFitWithAlign","xAlign","caret","caretSize","caretPadding","determineXAlign","yAlign","chartWidth","determineAlignment","alignX","alignY","paddingAndSize","getBackgroundPoint","alignment","getAlignedX","getBeforeAfterBodyLines","createTooltipContext","tooltipItems","overrideCallbacks","defaultCallbacks","beforeTitle","labelCount","afterTitle","beforeLabel","tooltipItem","labelColor","labelTextColor","bodyColor","labelPointStyle","afterLabel","beforeFooter","afterFooter","invokeCallbackWithFallback","Tooltip","opacity","_eventPosition","_size","_cachedAnimations","_tooltipItems","dataPoints","caretX","caretY","labelColors","labelPointStyles","labelTextColors","getTitle","getBeforeBody","getBody","bodyItems","scoped","getAfterBody","getFooter","_createItems","itemSort","positionAndSize","backgroundPoint","external","drawCaret","tooltipPoint","caretPosition","getCaretPosition","x3","y3","ptX","ptY","titleColor","_drawColorBox","colorX","rtlColorX","yOffSet","colorY","multiKeyBackground","outerX","innerX","strokeRect","drawBody","bodyAlign","xLinePadding","fillLineOfText","bodyAlignForCalculation","textColor","drawFooter","footerAlign","footerColor","tooltipSize","quadraticCurveTo","_updateAnimationTarget","animX","animY","_willRender","hasTooltipContent","globalAlpha","positionChanged","_positionChanged","_ignoreReplayEvents","plugin_tooltip","afterInit","afterDraw","addIfString","addedLabels","unshift","findOrAddLabel","lastIndexOf","_getLabelForValue","CategoryScale","_startValue","_valueRange","_addedLabels","added","generateTicks$1","generationOptions","dataRange","MIN_SPACING","precision","maxTicks","maxDigits","includeBounds","unit","maxSpaces","rmin","rmax","countDefined","minSpacing","niceMin","niceMax","numSpaces","decimalPlaces","relativeLabelSize","LinearScaleBase","_endValue","handleTickRangeOptions","setMin","setMax","minSign","maxSign","getTickLimit","stepSize","computeTickLimit","numericGeneratorOptions","LinearScale","log10Floor","changeExponent","isMajor","tickVal","steps","rangeExp","rangeStep","startExp","generateTicks","minExp","exp","lastTick","LogarithmicScale","_zero","getTickBackdropHeight","measureLabelSize","determineLimits","fitWithPointLabels","_padding","limits","valueCount","_pointLabels","pointLabelOpts","additionalAngle","centerPointLabels","getPointLabelContext","getPointPosition","drawingArea","plFont","textSize","hLimits","vLimits","updateLimits","setCenterPoint","_pointLabelItems","buildPointLabelItems","createPointLabelItem","itemOpts","outerDistance","extra","pointLabelPosition","yForAngle","getTextAlignForAngle","leftForTextAlign","isNotOverlapped","apexesInArea","drawPointLabelBox","backdropLeft","backdropTop","backdropWidth","backdropHeight","drawPointLabels","pathRadiusLine","drawRadiusLine","gridLineOpts","createPointLabelContext","RadialLinearScale","leftMovement","rightMovement","topMovement","bottomMovement","angleMultiplier","scalingFactor","getValueForDistanceFromCenter","scaledDistance","pointLabel","distanceFromCenter","getBasePosition","getPointLabelPosition","animate","INTERVALS","millisecond","common","second","minute","hour","day","week","month","quarter","year","UNITS","sorter","adapter","_adapter","parser","isoWeekday","_parseOpts","determineUnitForAutoTicks","minUnit","capacity","interval","MAX_SAFE_INTEGER","determineUnitForFormatting","determineMajorUnit","addTick","time","timestamps","timestamp","setMajorTicks","majorUnit","ticksFromTimestamps","TimeScale","_unit","_majorUnit","_offsets","_normalized","displayFormats","normalized","_applyBounds","_getLabelBounds","getLabelTimestamps","timeOpts","_generate","_getLabelCapacity","initOffsets","offsetAfterAutoskip","getDecimalForValue","weekday","hasWeekday","getDataTimestamps","tooltipFormat","datetime","fmt","_tickFormatFunction","minorFormat","majorFormat","offsets","_getLabelSize","ticksOpts","tickLabelWidth","cosRotation","sinRotation","tickFontSize","exampleTime","exampleLabel","prevSource","nextSource","prevTarget","nextTarget","span","TimeSeriesScale","_table","_minPos","_tableRange","_getTimestampsForTable","buildLookupTable","CommonProps","required","datasetIdKey","updateMode","A11yProps","ariaLabel","ariaDescribedby","Props","destroyDelay","compatProps","internals","attrs","toRawIfProxy","isProxy","toRaw","cloneProxy","setOptions","nextOptions","setLabels","currentData","nextLabels","setDatasets","nextDatasets","addedDatasets","nextDataset","currentDataset","cloneData","nextData","defineComponent","setup","param","expose","slots","canvasRef","chartRef","shallowRef","renderChart","clonedData","proxiedData","Chart$1","destroyChart","onMounted","onUnmounted","watch","param1","nextOptionsProxy","nextDataProxy","prevOptionsProxy","prevDataProxy","shouldUpdate","prevOptions","prevLabels","prevDatasets","nextTick","deep","role","createTypedChart","registerables","reforwardRef","Doughnut","BatchOperationError","code","ERROR_HANDLERS","details","NETWORK","ABORT","createError","Response","BatchProcessor","batchSize","abortController","fetchAllRecords","includeValue","AbortController","allRecords","totalFetched","batchCount","signal","aborted","response","fetchBatch","records","nextCursor","phase","batchError","URLSearchParams","fetchWithAuth","errorDetails","errorData","json","success","totalProcessed","abort","isAborted","IndexRebuilder","chunkSize","maxRetries","retryDelay","sessionId","generateSessionId","fetchConfig","databaseType","rebuild","processor","sortByTimestampDescending","chunks","splitIntoChunks","uploadChunkWithRetry","finalize","timestampA","timestampB","chunkId","lastError","attempt","uploadChunk","sleep","checksum","calculateChecksum","headers","createHttpError","totalChunks","random","encoder","TextEncoder","dataBuffer","encode","hashBuffer","crypto","subtle","digest","hashArray","Uint8Array","padStart","ms","BackupGenerator","generateBackup","packageInfo","fileCount","files","settings","record","fetchSettings","downloadBackup","settingsCount","blob","Blob","url","URL","createObjectURL","createElement","href","download","toISOString","appendChild","click","removeChild","revokeObjectURL","RestoreProcessor","fileEntries","settingEntries","totalSettings","totalItems","restoredFiles","restoredSettings","failedFiles","failedSettings","fileChunks","chunkData","fromEntries","restoredCount","failedCount","settingChunks","backupTimestamp","components","newest","oldest","channelColors","typeColors","processingPhase","processingStartTime","currentRebuilder","currentBackupGenerator","currentRestoreProcessor","computed","stats","aggregatedStats","mappedStatus","toFixed","totalEstimated","seconds","minutes","hours","remainingMinutes","phaseMap","$message","warning","handleProgress","handleError","errorMessage","settingsMsg","$refs","fileInput","file","$confirm","confirmButtonText","cancelButtonText","restoreData","fileContent","parseError","days","isValidPreview","FileType","open","fileName","extension","substring","imageExtensions","videoExtensions","$nextTick","isOpen","toggleDropdown","modelValue","displayLabel","selectOption","$slots","placeholder","emits","selected","opt","handleClickOutside","beforeUnmount","$el","_component_CustomSelect","_component_el_tag","_component_el_switch","_component_el_option","_component_el_select","_component_el_form_item","_component_el_input","_component_el_input_number","_component_el_form","_component_el_dialog","_component_el_descriptions_item","_component_el_descriptions","channelFilter","filterOptions","showAddDialog","filteredChannels","channelType","getChannelIcon","getChannelList","hasLoadBalance","getSettings","loadBalance","saveSettings","fixed","onMousemove","handleCardMouseMove","onMouseleave","handleCardMouseLeave","ref_for","maskText","botToken","chatId","publicUrl","bucketName","endpoint","channelId","isNitro","repo","isPrivate","quota","getQuotaPercentage","getQuotaStatus","getQuotaText","openDetailDialog","openEditDialog","deleteChannel","onClosed","resetAddForm","confirmAddChannel","model","newChannel","rules","addRules","onChannelTypeChange","addableChannels","ch","proxyUrl","cdnDomain","region","accessKeyId","secretAccessKey","pathStyle","limitGB","threshold","token","showDetailDialog","currentChannel","resetDetailData","openEditFromDetail","column","getChannelTypeLabel","currentChannelType","readonly","link","refreshQuota","quotaLoading","isQuotaExceeded","getQuotaStatusText","showEditDialog","editChannel","resetEditData","confirmEditChannel","editRules","onQuotaEnabledChange","CustomSelect","channels","telegramSettings","cfr2Settings","s3Settings","discordSettings","huggingfaceSettings","currentChannelIndex","pattern","quotaStats","iconMap","telegram","cfr2","s3","discord","huggingface","card","currentTarget","refKey","glowEl","icons","showLength","addForm","validate","reservedNames","isDuplicate","newChannelData","savePath","editForm","newName","currentIndex","isFixedChannel","catch","getResponse","getData","loadQuotaStats","getChannelUsedGB","usedMB","usedGB","async","recalculateQuota","finally","handleClick","spin","immediate","_component_el_table_column","_component_el_table","_component_FloatingSaveButton","_component_el_checkbox","_component_el_checkbox_group","authSettings","user","userPassRules","authCode","onInput","handleUserPassInput","autocomplete","showUserPassConfirm","confirmNewUserPassword","admin","adminPassRules","adminUsername","adminPassword","handleAdminPassInput","showAdminPassConfirm","confirmNewAdminPassword","showCreateTokenDialog","circle","apiTokens","permissions","perm","getPermissionText","formatDate","createdAt","editToken","deleteToken","tokenLoading","uploadSettings","moderate","moderateContentApiKey","nsfwApiPath","accessSettings","allowedDomains","whiteListMode","dialogWidth","createToken","newToken","tokenRules","showEditTokenDialog","updateToken","editingToken","showTokenResultDialog","createdToken","append","copyToken","FloatingSaveButton","oriUserPassword","oriAdminPassword","owner","validator","rule","urlReservedChars","hasReservedChar","char","permission","permissionMap","dateString","loadApiTokens","tokens","tokenForm","editTokenForm","tokenId","navigator","clipboard","writeText","validationPromises","userPassForm","adminPassForm","results","isValid","every","auth","upload","access","groupedSettings","categoryGroup","categoryName","setting","currentUploadChannel","currentChannelList","clearable","availableChannels","category","channelSetting","newVal","oldVal","channelNameSetting","newChannelList","fetchAvailableChannels","axios","telemetry","randomImageAPI","allowedDir","publicBrowse","cloudflareApiToken","CF_ZONE_ID","CF_EMAIL","CF_API_KEY","webDAV","username","password","uploadChannel","webdavChannelList","channelName","newHash","scrollTo","newIndex","hash","$router","DashboardTabs","SysConfigTabs","SysCogStatus","SysCogUpload","SysCogSecurity","SysCogPage","SysCogOthers","$route","$store","commit","setDefaultHash","defaultHash","location"],"ignoreList":[],"sourceRoot":""} \ No newline at end of file diff --git a/js/226.478c43ad.js.map.gz b/js/407.f0b5dee5.js.map.gz similarity index 61% rename from js/226.478c43ad.js.map.gz rename to js/407.f0b5dee5.js.map.gz index 6754b03..718b089 100644 Binary files a/js/226.478c43ad.js.map.gz and b/js/407.f0b5dee5.js.map.gz differ diff --git a/js/488.c52f99c6.js b/js/488.c52f99c6.js deleted file mode 100644 index 45a1e9b..0000000 --- a/js/488.c52f99c6.js +++ /dev/null @@ -1,2 +0,0 @@ -(self["webpackChunksanyue_imghub"]=self["webpackChunksanyue_imghub"]||[]).push([[488],{415:function(e,t,i){"use strict";i(5331),i(3565)},2388:function(e,t,i){"use strict";function a(e){if(!e||""===e.trim())return{valid:!0};if("/"===e)return{valid:!0};if(!e.startsWith("/"))return{valid:!1,error:'目标目录必须以 "/" 开头'};const t=/[\\:\*\?"'<>\| \(\)\[\]\{\}#%\^`~;@&=\+\$,]/;return t.test(e)?{valid:!1,error:"目标目录包含非法字符,请使用合法的路径格式"}:e.includes("//")?{valid:!1,error:"目标目录不能包含连续的斜杠"}:{valid:!0}}i.d(t,{G:function(){return a}})},2907:function(e,t,i){"use strict";i(5331),i(6808),i(6711)},3565:function(e,t,i){"use strict";i(5331)},4280:function(e,t,i){"use strict";i.r(t),i.d(t,{default:function(){return yi}});var a=i(6768),n=i(5130),s=i(4232);const r={class:"mobile-drawer-header"},o={class:"mobile-drawer-content"},l=["onClick"];function c(e,t,i,c,d,h){const u=(0,a.g2)("font-awesome-icon");return(0,a.uX)(),(0,a.Wv)(a.Im,{to:"body"},[(0,a.bF)(n.eB,{name:"drawer-slide"},{default:(0,a.k6)(()=>[i.modelValue?((0,a.uX)(),(0,a.CE)("div",{key:0,class:"mobile-drawer-overlay",onClick:t[3]||(t[3]=(...e)=>h.close&&h.close(...e))},[(0,a.Lk)("div",{class:"mobile-drawer",onClick:t[2]||(t[2]=(0,n.D$)(()=>{},["stop"]))},[(0,a.Lk)("div",r,[t[4]||(t[4]=(0,a.Lk)("span",{class:"mobile-drawer-title"},"目录导航",-1)),(0,a.bF)(u,{icon:"times",class:"mobile-drawer-close",onClick:h.close},null,8,["onClick"])]),(0,a.Lk)("div",o,[(0,a.Lk)("div",{class:(0,s.C4)(["mobile-drawer-item",{active:!i.currentPath}]),onClick:t[0]||(t[0]=e=>h.navigate(""))},[(0,a.bF)(u,{icon:"home",class:"mobile-drawer-item-icon"}),t[5]||(t[5]=(0,a.Lk)("span",null,"根目录",-1))],2),((0,a.uX)(!0),(0,a.CE)(a.FK,null,(0,a.pI)(h.pathParts,(e,t)=>((0,a.uX)(),(0,a.CE)("div",{key:t,class:(0,s.C4)(["mobile-drawer-item",{active:t===h.pathParts.length-1}]),style:(0,s.Tr)({paddingLeft:16*(t+1)+16+"px"}),onClick:e=>h.navigate(h.pathParts.slice(0,t+1).join("/"))},[(0,a.bF)(u,{icon:"folder",class:"mobile-drawer-item-icon"}),(0,a.Lk)("span",null,(0,s.v_)(e),1)],14,l))),128)),i.currentPath?((0,a.uX)(),(0,a.CE)("div",{key:0,class:"mobile-drawer-back",onClick:t[1]||(t[1]=(...e)=>h.goBack&&h.goBack(...e))},[(0,a.bF)(u,{icon:"arrow-left",class:"mobile-drawer-item-icon"}),t[6]||(t[6]=(0,a.Lk)("span",null,"返回上一级",-1))])):(0,a.Q3)("",!0)])])])):(0,a.Q3)("",!0)]),_:1})])}i(8111),i(2489);var d={name:"MobileDirectoryDrawer",props:{modelValue:{type:Boolean,default:!1},currentPath:{type:String,default:""}},emits:["update:modelValue","navigate","goBack"],computed:{pathParts(){return this.currentPath.split("/").filter(Boolean)}},methods:{close(){this.$emit("update:modelValue",!1)},navigate(e){this.$emit("navigate",e),this.close()},goBack(){this.$emit("goBack"),this.close()}}},h=i(1241);const u=(0,h.A)(d,[["render",c],["__scopeId","data-v-2d8e83ec"]]);var f=u;const m={class:"bottom-sheet-header"},p={class:"bottom-sheet-title"},g={class:"bottom-sheet-content"};function b(e,t,i,r,o,l){const c=(0,a.g2)("font-awesome-icon");return(0,a.uX)(),(0,a.Wv)(a.Im,{to:"body"},[(0,a.bF)(n.eB,{name:"bottom-sheet"},{default:(0,a.k6)(()=>[i.modelValue?((0,a.uX)(),(0,a.CE)("div",{key:0,class:"bottom-sheet-overlay",onClick:t[9]||(t[9]=(...e)=>l.close&&l.close(...e))},[(0,a.Lk)("div",{class:"bottom-sheet",onClick:t[8]||(t[8]=(0,n.D$)(()=>{},["stop"]))},[(0,a.Lk)("div",m,[t[10]||(t[10]=(0,a.Lk)("div",{class:"bottom-sheet-handle"},null,-1)),(0,a.Lk)("span",p,(0,s.v_)(i.title),1)]),(0,a.Lk)("div",g,[i.isFolder?((0,a.uX)(),(0,a.CE)(a.FK,{key:1},[(0,a.Lk)("div",{class:"bottom-sheet-item",onClick:t[5]||(t[5]=e=>l.handleAction("folderCopy"))},[(0,a.bF)(c,{icon:"copy",class:"bottom-sheet-icon"}),t[16]||(t[16]=(0,a.Lk)("span",null,"复制链接",-1))]),(0,a.Lk)("div",{class:"bottom-sheet-item",onClick:t[6]||(t[6]=e=>l.handleAction("move"))},[(0,a.bF)(c,{icon:"file-export",class:"bottom-sheet-icon"}),t[17]||(t[17]=(0,a.Lk)("span",null,"移动文件夹",-1))])],64)):((0,a.uX)(),(0,a.CE)(a.FK,{key:0},[(0,a.Lk)("div",{class:"bottom-sheet-item",onClick:t[0]||(t[0]=e=>l.handleAction("detail"))},[(0,a.bF)(c,{icon:"info-circle",class:"bottom-sheet-icon"}),t[11]||(t[11]=(0,a.Lk)("span",null,"查看详情",-1))]),(0,a.Lk)("div",{class:"bottom-sheet-item",onClick:t[1]||(t[1]=e=>l.handleAction("copy"))},[(0,a.bF)(c,{icon:"copy",class:"bottom-sheet-icon"}),t[12]||(t[12]=(0,a.Lk)("span",null,"复制链接",-1))]),(0,a.Lk)("div",{class:"bottom-sheet-item",onClick:t[2]||(t[2]=e=>l.handleAction("download"))},[(0,a.bF)(c,{icon:"download",class:"bottom-sheet-icon"}),t[13]||(t[13]=(0,a.Lk)("span",null,"下载文件",-1))]),(0,a.Lk)("div",{class:"bottom-sheet-item",onClick:t[3]||(t[3]=e=>l.handleAction("move"))},[(0,a.bF)(c,{icon:"file-export",class:"bottom-sheet-icon"}),t[14]||(t[14]=(0,a.Lk)("span",null,"移动文件",-1))]),(0,a.Lk)("div",{class:"bottom-sheet-item",onClick:t[4]||(t[4]=e=>l.handleAction("tag"))},[(0,a.bF)(c,{icon:"tags",class:"bottom-sheet-icon"}),t[15]||(t[15]=(0,a.Lk)("span",null,"标签管理",-1))])],64)),(0,a.Lk)("div",{class:"bottom-sheet-item bottom-sheet-danger",onClick:t[7]||(t[7]=e=>l.handleAction("delete"))},[(0,a.bF)(c,{icon:"trash-alt",class:"bottom-sheet-icon"}),(0,a.Lk)("span",null,(0,s.v_)(i.isFolder?"删除文件夹":"删除文件"),1)])])])])):(0,a.Q3)("",!0)]),_:1})])}var v={name:"MobileActionSheet",props:{modelValue:{type:Boolean,default:!1},title:{type:String,default:""},isFolder:{type:Boolean,default:!1}},emits:["update:modelValue","action"],methods:{close(){this.$emit("update:modelValue",!1)},handleAction(e){this.$emit("action",e),this.close()}}};const k=(0,h.A)(v,[["render",b],["__scopeId","data-v-7579ad69"]]);var _=k,y=i(9267),w=(i(5331),i(5616),i(4275)),F=i(9559),C=i(2687),T=(i(8785),i(9623)),x=(i(6711),i(47));i(9648);const S={class:"batch-tag-container"},L={class:"tab-content"},E={class:"tab-description"},A={class:"input-section"},I={key:0,class:"suggestions-panel"},D=["onClick"],z={class:"tags-to-add-section"},U={key:0,class:"tags-container"},B={key:1,class:"empty-message"},W={class:"action-buttons"},P={class:"tab-content"},$={key:0,class:"common-tags-section"},O={class:"tags-container"},R={key:1,class:"empty-message"},N={class:"tab-content"},M={class:"tab-description"},j={class:"action-buttons"};function V(e,t,i,r,o,l){const c=(0,a.g2)("font-awesome-icon"),d=x.S2,h=T.WK,u=C.u,f=w.v$,m=F.KR,p=w.q,g=y.kZ;return(0,a.uX)(),(0,a.Wv)(g,{title:"批量标签管理",modelValue:l.visible,"onUpdate:modelValue":t[2]||(t[2]=e=>l.visible=e),width:l.dialogWidth,onClose:l.handleClose},{default:(0,a.k6)(()=>[(0,a.Lk)("div",S,[(0,a.bF)(p,{modelValue:o.activeTab,"onUpdate:modelValue":t[1]||(t[1]=e=>o.activeTab=e),type:"border-card"},{default:(0,a.k6)(()=>[(0,a.bF)(f,{label:"添加",name:"add"},{default:(0,a.k6)(()=>[(0,a.Lk)("div",L,[(0,a.Lk)("p",E,"为选中的 "+(0,s.v_)(l.fileCount)+" 个文件添加标签",1),(0,a.Lk)("div",A,[(0,a.bF)(h,{modelValue:o.inputTag,"onUpdate:modelValue":t[0]||(t[0]=e=>o.inputTag=e),placeholder:"输入标签名称",onKeyup:(0,n.jR)(l.handleAddInputTag,["enter"]),onInput:l.handleInputChange,clearable:""},{append:(0,a.k6)(()=>[(0,a.bF)(d,{onClick:l.handleAddInputTag,type:"primary"},{default:(0,a.k6)(()=>[(0,a.bF)(c,{icon:"plus"})]),_:1},8,["onClick"])]),_:1},8,["modelValue","onKeyup","onInput"]),o.showSuggestions&&o.suggestions.length>0?((0,a.uX)(),(0,a.CE)("div",I,[((0,a.uX)(!0),(0,a.CE)(a.FK,null,(0,a.pI)(o.suggestions,e=>((0,a.uX)(),(0,a.CE)("div",{key:e,class:"suggestion-item",onClick:t=>l.selectSuggestion(e)},(0,s.v_)(e),9,D))),128))])):(0,a.Q3)("",!0)]),(0,a.Lk)("div",z,[t[3]||(t[3]=(0,a.Lk)("h4",null,"待添加的标签",-1)),o.tagsToAdd.length>0?((0,a.uX)(),(0,a.CE)("div",U,[((0,a.uX)(!0),(0,a.CE)(a.FK,null,(0,a.pI)(o.tagsToAdd,e=>((0,a.uX)(),(0,a.Wv)(u,{key:e,closable:"",onClose:t=>l.removeFromToAdd(e),class:"tag-item"},{default:(0,a.k6)(()=>[(0,a.eW)((0,s.v_)(e),1)]),_:2},1032,["onClose"]))),128))])):((0,a.uX)(),(0,a.CE)("div",B," 暂无待添加标签 "))]),(0,a.Lk)("div",W,[(0,a.bF)(d,{type:"primary",onClick:l.executeAddTags,loading:o.loading,disabled:0===o.tagsToAdd.length},{default:(0,a.k6)(()=>[...t[4]||(t[4]=[(0,a.eW)(" 添加到所有文件 ",-1)])]),_:1},8,["onClick","loading","disabled"])])])]),_:1}),(0,a.bF)(f,{label:"移除",name:"remove"},{default:(0,a.k6)(()=>[(0,a.Lk)("div",P,[t[6]||(t[6]=(0,a.Lk)("p",{class:"tab-description"},"移除选中文件的共有标签",-1)),o.commonTags.length>0?((0,a.uX)(),(0,a.CE)("div",$,[t[5]||(t[5]=(0,a.Lk)("h4",null,"共有标签",-1)),(0,a.Lk)("div",O,[((0,a.uX)(!0),(0,a.CE)(a.FK,null,(0,a.pI)(o.commonTags,e=>((0,a.uX)(),(0,a.Wv)(u,{key:e,closable:"",onClose:t=>l.handleRemoveCommonTag(e),class:"tag-item",type:"warning"},{default:(0,a.k6)(()=>[(0,a.eW)((0,s.v_)(e),1)]),_:2},1032,["onClose"]))),128))])])):((0,a.uX)(),(0,a.CE)("div",R," 选中的文件没有共有标签 "))])]),_:1}),(0,a.bF)(f,{label:"清空",name:"clear"},{default:(0,a.k6)(()=>[(0,a.Lk)("div",N,[(0,a.Lk)("p",M,"清空选中的 "+(0,s.v_)(l.fileCount)+" 个文件的所有标签",1),(0,a.bF)(m,{title:"⚠️警告",type:"warning",description:"此操作将清空所有选中文件的标签,且不可恢复",closable:!1,style:{"margin-bottom":"20px"},center:""}),(0,a.Lk)("div",j,[(0,a.bF)(d,{type:"danger",onClick:l.handleClearAllTags,loading:o.loading},{default:(0,a.k6)(()=>[...t[7]||(t[7]=[(0,a.eW)(" 确认清空所有标签 ",-1)])]),_:1},8,["onClick","loading"])])])]),_:1})]),_:1},8,["modelValue"])])]),_:1},8,["modelValue","width","onClose"])}i(4114),i(1701),i(3110);var X=i(1219),Z=i(2933),K=i(797),G={name:"BatchTagDialog",props:{modelValue:{type:Boolean,default:!1},selectedFiles:{type:Array,required:!0,default:()=>[]}},emits:["update:modelValue","tagsUpdated"],data(){return{activeTab:"add",inputTag:"",tagsToAdd:[],commonTags:[],suggestions:[],showSuggestions:!1,loading:!1,debounceTimer:null}},computed:{visible:{get(){return this.modelValue},set(e){this.$emit("update:modelValue",e)}},dialogWidth(){return window.innerWidth<768?"90%":"600px"},selectedFilesOnly(){return this.selectedFiles.filter(e=>!e.isFolder)},fileCount(){return this.selectedFilesOnly.length},fileIds(){return this.selectedFilesOnly.map(e=>e.name)}},watch:{visible(e){e?this.loadCommonTags():this.resetData()},activeTab(e){"remove"===e&&this.loadCommonTags()}},methods:{resetData(){this.tagsToAdd=[],this.inputTag="",this.showSuggestions=!1,this.activeTab="add"},async loadCommonTags(){if(0!==this.selectedFilesOnly.length)try{const e=this.selectedFilesOnly.map(e=>(0,K.A)(`/api/manage/tags/${encodeURIComponent(e.name)}`,{method:"GET"})),t=await Promise.all(e),i=[];for(const a of t)if(a.ok){const e=await a.json();i.push(e.tags||[])}i.length>0?this.commonTags=i[0].filter(e=>i.every(t=>t.includes(e))):this.commonTags=[]}catch(e){console.error("Error loading common tags:",e),X.nk.error("加载共有标签失败")}else this.commonTags=[]},handleInputChange(){clearTimeout(this.debounceTimer),this.inputTag&&0!==this.inputTag.trim().length?this.debounceTimer=setTimeout(()=>{this.fetchSuggestions()},300):this.showSuggestions=!1},async fetchSuggestions(){try{const e=this.inputTag.trim().toLowerCase(),t=await(0,K.A)(`/api/manage/tags/autocomplete?prefix=${encodeURIComponent(e)}&limit=10`,{method:"GET"});if(t.ok){const e=await t.json();this.suggestions=(e.tags||[]).filter(e=>!this.tagsToAdd.includes(e)),this.showSuggestions=this.suggestions.length>0}}catch(e){console.error("Error fetching suggestions:",e)}},selectSuggestion(e){this.inputTag=e,this.showSuggestions=!1,this.handleAddInputTag()},handleAddInputTag(){const e=this.inputTag.trim();if(e){if(this.tagsToAdd.includes(e))return X.nk.warning("标签已在列表中"),this.inputTag="",void(this.showSuggestions=!1);this.tagsToAdd.push(e),this.inputTag="",this.showSuggestions=!1}},removeFromToAdd(e){const t=this.tagsToAdd.indexOf(e);t>-1&&this.tagsToAdd.splice(t,1)},async executeAddTags(){if(0!==this.tagsToAdd.length){this.loading=!0;try{const e=await(0,K.A)("/api/manage/tags/batch",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({fileIds:this.fileIds,action:"add",tags:this.tagsToAdd})});if(!e.ok)throw new Error("批量添加标签失败");{const t=await e.json();if(!(t.success||t.updated>0))throw new Error("批量添加标签失败");X.nk.success(`成功为 ${t.updated} 个文件添加标签`),this.$emit("tagsUpdated"),this.tagsToAdd=[]}}catch(e){console.error("Error adding tags:",e),X.nk.error("批量添加标签失败")}finally{this.loading=!1}}else X.nk.warning("请先添加要批量添加的标签")},async handleRemoveCommonTag(e){this.loading=!0;try{const t=await(0,K.A)("/api/manage/tags/batch",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({fileIds:this.fileIds,action:"remove",tags:[e]})});if(!t.ok)throw new Error("移除标签失败");{const e=await t.json();if(!(e.success||e.updated>0))throw new Error("移除标签失败");X.nk.success(`成功从 ${e.updated} 个文件中移除标签`),this.$emit("tagsUpdated"),await this.loadCommonTags()}}catch(t){console.error("Error removing tag:",t),X.nk.error("移除标签失败")}finally{this.loading=!1}},handleClearAllTags(){Z.s.confirm(`确定要清空选中的 ${this.fileCount} 个文件的所有标签吗?此操作不可恢复。`,"确认清空",{confirmButtonText:"确定",cancelButtonText:"取消",type:"warning"}).then(()=>{this.executeClearTags()}).catch(()=>{X.nk.info("已取消清空操作")})},async executeClearTags(){this.loading=!0;try{const e=await(0,K.A)("/api/manage/tags/batch",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({fileIds:this.fileIds,action:"set",tags:[]})});if(!e.ok)throw new Error("清空标签失败");{const t=await e.json();if(!(t.success||t.updated>0))throw new Error("清空标签失败");X.nk.success(`成功清空 ${t.updated} 个文件的标签`),this.$emit("tagsUpdated"),this.commonTags=[]}}catch(e){console.error("Error clearing tags:",e),X.nk.error("清空标签失败")}finally{this.loading=!1}},handleClose(){this.visible=!1}}};const H=(0,h.A)(G,[["render",V],["__scopeId","data-v-dacf7742"]]);var q=H,Q=i(813);i(4896);const Y={class:"tag-management-container"},J={class:"input-section"},ee={key:0,class:"suggestions-panel"},te=["onClick"],ie={class:"current-tags-section"},ae={key:0,class:"tags-container"},ne={key:1,class:"empty-message"},se={class:"popular-tags-section"},re={key:0,class:"tags-container"},oe={key:1,class:"empty-message"},le={key:2,class:"empty-message"},ce={class:"dialog-footer"};function de(e,t,i,r,o,l){const c=(0,a.g2)("font-awesome-icon"),d=x.S2,h=T.WK,u=C.u,f=(0,a.g2)("Loading"),m=Q.tk,p=y.kZ;return(0,a.uX)(),(0,a.Wv)(p,{title:"标签管理",modelValue:l.visible,"onUpdate:modelValue":t[1]||(t[1]=e=>l.visible=e),width:l.dialogWidth,onClose:l.handleClose},{footer:(0,a.k6)(()=>[(0,a.Lk)("span",ce,[(0,a.bF)(d,{onClick:l.handleClose},{default:(0,a.k6)(()=>[...t[5]||(t[5]=[(0,a.eW)("关闭",-1)])]),_:1},8,["onClick"])])]),default:(0,a.k6)(()=>[(0,a.Lk)("div",Y,[(0,a.Lk)("div",J,[(0,a.bF)(h,{modelValue:o.inputTag,"onUpdate:modelValue":t[0]||(t[0]=e=>o.inputTag=e),placeholder:"输入标签名称",onKeyup:(0,n.jR)(l.handleAddTag,["enter"]),onInput:l.handleInputChange,clearable:""},{append:(0,a.k6)(()=>[(0,a.bF)(d,{onClick:l.handleAddTag,type:"primary"},{default:(0,a.k6)(()=>[(0,a.bF)(c,{icon:"plus"})]),_:1},8,["onClick"])]),_:1},8,["modelValue","onKeyup","onInput"]),o.showSuggestions&&o.suggestions.length>0?((0,a.uX)(),(0,a.CE)("div",ee,[((0,a.uX)(!0),(0,a.CE)(a.FK,null,(0,a.pI)(o.suggestions,e=>((0,a.uX)(),(0,a.CE)("div",{key:e,class:"suggestion-item",onClick:t=>l.selectSuggestion(e)},(0,s.v_)(e),9,te))),128))])):(0,a.Q3)("",!0)]),(0,a.Lk)("div",ie,[t[2]||(t[2]=(0,a.Lk)("h4",null,"当前标签",-1)),o.currentTags.length>0?((0,a.uX)(),(0,a.CE)("div",ae,[((0,a.uX)(!0),(0,a.CE)(a.FK,null,(0,a.pI)(o.currentTags,e=>((0,a.uX)(),(0,a.Wv)(u,{key:e,closable:"",onClose:t=>l.handleRemoveTag(e),class:"tag-item"},{default:(0,a.k6)(()=>[(0,a.eW)((0,s.v_)(e),1)]),_:2},1032,["onClose"]))),128))])):((0,a.uX)(),(0,a.CE)("div",ne," 暂无标签 "))]),(0,a.Lk)("div",se,[t[4]||(t[4]=(0,a.Lk)("h4",null,"常用标签",-1)),o.popularTags.length>0?((0,a.uX)(),(0,a.CE)("div",re,[((0,a.uX)(!0),(0,a.CE)(a.FK,null,(0,a.pI)(o.popularTags,e=>((0,a.uX)(),(0,a.Wv)(u,{key:e,onClick:t=>l.handleAddPopularTag(e),class:"tag-item clickable",type:"info"},{default:(0,a.k6)(()=>[(0,a.eW)((0,s.v_)(e),1)]),_:2},1032,["onClick"]))),128))])):o.loadingPopularTags?((0,a.uX)(),(0,a.CE)("div",oe,[(0,a.bF)(m,{class:"is-loading"},{default:(0,a.k6)(()=>[(0,a.bF)(f)]),_:1}),t[3]||(t[3]=(0,a.eW)(" 加载中... ",-1))])):((0,a.uX)(),(0,a.CE)("div",le," 暂无常用标签 "))])])]),_:1},8,["modelValue","width","onClose"])}var he=i(7477),ue={name:"TagManagementDialog",components:{Loading:he.Loading},props:{modelValue:{type:Boolean,default:!1},fileId:{type:String,required:!0}},emits:["update:modelValue","tagsUpdated"],data(){return{currentTags:[],inputTag:"",suggestions:[],popularTags:[],showSuggestions:!1,loading:!1,loadingPopularTags:!1,debounceTimer:null}},computed:{visible:{get(){return this.modelValue},set(e){this.$emit("update:modelValue",e)}},dialogWidth(){return window.innerWidth<768?"90%":"500px"}},watch:{visible(e){e&&(this.loadFileTags(),this.loadPopularTags())}},methods:{async loadFileTags(){try{const e=await(0,K.A)(`/api/manage/tags/${encodeURIComponent(this.fileId)}`,{method:"GET"});if(!e.ok)throw new Error("Failed to load tags");{const t=await e.json();this.currentTags=t.tags||[]}}catch(e){console.error("Error loading file tags:",e),X.nk.error("加载标签失败")}},async loadPopularTags(){this.loadingPopularTags=!0;try{const e=await(0,K.A)("/api/manage/tags/autocomplete?limit=20",{method:"GET"});if(e.ok){const t=await e.json();this.popularTags=(t.tags||[]).filter(e=>!this.currentTags.includes(e))}}catch(e){console.error("Error loading popular tags:",e)}finally{this.loadingPopularTags=!1}},handleInputChange(){clearTimeout(this.debounceTimer),this.inputTag&&0!==this.inputTag.trim().length?this.debounceTimer=setTimeout(()=>{this.fetchSuggestions()},300):this.showSuggestions=!1},async fetchSuggestions(){try{const e=this.inputTag.trim().toLowerCase(),t=await(0,K.A)(`/api/manage/tags/autocomplete?prefix=${encodeURIComponent(e)}&limit=10`,{method:"GET"});if(t.ok){const e=await t.json();this.suggestions=(e.tags||[]).filter(e=>!this.currentTags.includes(e)),this.showSuggestions=this.suggestions.length>0}}catch(e){console.error("Error fetching suggestions:",e)}},selectSuggestion(e){this.inputTag=e,this.showSuggestions=!1,this.handleAddTag()},async handleAddTag(){const e=this.inputTag.trim();if(e){if(this.currentTags.includes(e))return X.nk.warning("标签已存在"),this.inputTag="",void(this.showSuggestions=!1);try{const t=await(0,K.A)(`/api/manage/tags/${encodeURIComponent(this.fileId)}`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({action:"add",tags:[e]})});if(!t.ok){const e=await t.json();throw new Error(e.message||"添加标签失败")}{const e=await t.json();this.currentTags=e.tags||[],this.inputTag="",this.showSuggestions=!1,X.nk.success("标签添加成功"),this.$emit("tagsUpdated",this.currentTags),this.loadPopularTags()}}catch(t){console.error("Error adding tag:",t),X.nk.error(t.message||"添加标签失败")}}},async handleRemoveTag(e){try{const t=await(0,K.A)(`/api/manage/tags/${encodeURIComponent(this.fileId)}`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({action:"remove",tags:[e]})});if(!t.ok)throw new Error("删除标签失败");{const e=await t.json();this.currentTags=e.tags||[],X.nk.success("标签删除成功"),this.$emit("tagsUpdated",this.currentTags),this.loadPopularTags()}}catch(t){console.error("Error removing tag:",t),X.nk.error("删除标签失败")}},handleAddPopularTag(e){this.inputTag=e,this.handleAddTag()},handleClose(){this.visible=!1,this.inputTag="",this.showSuggestions=!1,this.currentTags=[],this.popularTags=[]}}};const fe=(0,h.A)(ue,[["render",de],["__scopeId","data-v-8b4291b4"]]);var me=fe,pe=i(5558),ge=(i(8075),i(6810)),be=(i(4396),i(4885),i(9869)),ve=(i(415),i(3565),i(7009));i(8450);const ke={class:"detail-actions"},_e={class:"preview-section"},ye={class:"preview-content"},we=["src"],Fe=["src"],Ce={key:0,style:{display:"flex","flex-wrap":"wrap",gap:"5px"}},Te={key:1,style:{color:"#909399"}};function xe(e,t,i,n,r,o){const l=(0,a.g2)("font-awesome-icon"),c=x.S2,d=T.WK,h=w.v$,u=w.q,f=ve.Zq,m=be.MF,p=C.u,g=be.TS,b=y.kZ;return(0,a.uX)(),(0,a.Wv)(b,{title:"文件详情",modelValue:o.visible,"onUpdate:modelValue":t[14]||(t[14]=e=>o.visible=e),width:o.dialogWidth},{default:(0,a.k6)(()=>[(0,a.Lk)("div",ke,[(0,a.bF)(c,{type:"primary",onClick:t[0]||(t[0]=t=>e.$emit("download")),round:"",size:"small",class:"detail-action"},{default:(0,a.k6)(()=>[(0,a.bF)(l,{icon:"download",style:{"margin-right":"3px"}}),t[15]||(t[15]=(0,a.eW)(" 下载 ",-1))]),_:1}),(0,a.bF)(c,{type:"primary",onClick:t[1]||(t[1]=t=>e.$emit("tagManagement")),round:"",size:"small",class:"detail-action"},{default:(0,a.k6)(()=>[(0,a.bF)(l,{icon:"tags",style:{"margin-right":"3px"}}),t[16]||(t[16]=(0,a.eW)(" 标签 ",-1))]),_:1}),(0,a.bF)(c,{type:"primary",onClick:t[2]||(t[2]=t=>e.$emit("block")),round:"",size:"small",class:"detail-action"},{default:(0,a.k6)(()=>[(0,a.bF)(l,{icon:"ban",style:{"margin-right":"3px"}}),t[17]||(t[17]=(0,a.eW)(" 黑名单 ",-1))]),_:1}),(0,a.bF)(c,{type:"primary",onClick:t[3]||(t[3]=t=>e.$emit("white")),round:"",size:"small",class:"detail-action"},{default:(0,a.k6)(()=>[(0,a.bF)(l,{icon:"user-plus",style:{"margin-right":"3px"}}),t[18]||(t[18]=(0,a.eW)(" 白名单 ",-1))]),_:1}),(0,a.bF)(c,{type:"danger",onClick:t[4]||(t[4]=t=>e.$emit("delete")),round:"",size:"small",class:"detail-action"},{default:(0,a.k6)(()=>[(0,a.bF)(l,{icon:"trash-alt",style:{"margin-right":"3px"}}),t[19]||(t[19]=(0,a.eW)(" 删除 ",-1))]),_:1})]),(0,a.bF)(u,{modelValue:r.activeTab,"onUpdate:modelValue":t[12]||(t[12]=e=>r.activeTab=e),onTabClick:o.handleTabClick,style:{"margin-bottom":"10px"}},{default:(0,a.k6)(()=>[(0,a.bF)(h,{label:"原始链接",name:"originUrl"},{default:(0,a.k6)(()=>[(0,a.bF)(d,{modelValue:i.urls.originUrl,"onUpdate:modelValue":t[5]||(t[5]=e=>i.urls.originUrl=e),readonly:"",onClick:o.handleUrlClick},null,8,["modelValue","onClick"])]),_:1}),(0,a.bF)(h,{label:"Markdown",name:"mdUrl"},{default:(0,a.k6)(()=>[(0,a.bF)(d,{modelValue:i.urls.mdUrl,"onUpdate:modelValue":t[6]||(t[6]=e=>i.urls.mdUrl=e),readonly:"",onClick:o.handleUrlClick},null,8,["modelValue","onClick"])]),_:1}),(0,a.bF)(h,{label:"HTML",name:"htmlUrl"},{default:(0,a.k6)(()=>[(0,a.bF)(d,{modelValue:i.urls.htmlUrl,"onUpdate:modelValue":t[7]||(t[7]=e=>i.urls.htmlUrl=e),readonly:"",onClick:o.handleUrlClick},null,8,["modelValue","onClick"])]),_:1}),(0,a.bF)(h,{label:"BBCode",name:"bbUrl"},{default:(0,a.k6)(()=>[(0,a.bF)(d,{modelValue:i.urls.bbUrl,"onUpdate:modelValue":t[8]||(t[8]=e=>i.urls.bbUrl=e),readonly:"",onClick:o.handleUrlClick},null,8,["modelValue","onClick"])]),_:1}),i.file?.metadata?.TgFileId?((0,a.uX)(),(0,a.Wv)(h,{key:0,label:"TG File ID",name:"tgId"},{default:(0,a.k6)(()=>[(0,a.bF)(d,{modelValue:i.urls.tgId,"onUpdate:modelValue":t[9]||(t[9]=e=>i.urls.tgId=e),readonly:"",onClick:o.handleUrlClick},null,8,["modelValue","onClick"])]),_:1})):(0,a.Q3)("",!0),i.file?.metadata?.S3Location?((0,a.uX)(),(0,a.Wv)(h,{key:1,label:"S3 Location",name:"s3Location"},{default:(0,a.k6)(()=>[(0,a.bF)(d,{modelValue:i.urls.S3Location,"onUpdate:modelValue":t[10]||(t[10]=e=>i.urls.S3Location=e),readonly:"",onClick:o.handleUrlClick},null,8,["modelValue","onClick"])]),_:1})):(0,a.Q3)("",!0),i.file?.metadata?.S3CdnFileUrl?((0,a.uX)(),(0,a.Wv)(h,{key:2,label:"S3 CDN URL",name:"s3CdnFileUrl"},{default:(0,a.k6)(()=>[(0,a.bF)(d,{modelValue:i.urls.S3CdnFileUrl,"onUpdate:modelValue":t[11]||(t[11]=e=>i.urls.S3CdnFileUrl=e),readonly:"",onClick:o.handleUrlClick},null,8,["modelValue","onClick"])]),_:1})):(0,a.Q3)("",!0)]),_:1},8,["modelValue","onTabClick"]),(0,a.Lk)("div",_e,[(0,a.Lk)("div",ye,[o.isVideo?((0,a.uX)(),(0,a.CE)("video",{key:0,src:i.fileLink,autoplay:"",muted:"",loop:"",class:"video-preview",onClick:t[13]||(t[13]=(...e)=>o.openImageLink&&o.openImageLink(...e))},null,8,we)):o.isAudio?((0,a.uX)(),(0,a.CE)("audio",{key:1,src:i.fileLink,controls:"",autoplay:"",class:"audio-preview"},null,8,Fe)):o.isImage?((0,a.uX)(),(0,a.Wv)(f,{key:2,src:i.fileLink,"preview-src-list":[i.fileLink],"preview-teleported":!0,fit:"contain",lazy:"",class:"image-preview"},null,8,["src","preview-src-list"])):((0,a.uX)(),(0,a.Wv)(l,{key:3,icon:"file",class:"file-icon-detail"}))])]),(0,a.bF)(g,{border:"",column:o.descColumn},{default:(0,a.k6)(()=>[(0,a.bF)(m,{label:"文件名"},{default:(0,a.k6)(()=>[(0,a.eW)((0,s.v_)(i.file?.metadata?.FileName||i.file?.name),1)]),_:1}),(0,a.bF)(m,{label:"文件类型"},{default:(0,a.k6)(()=>[(0,a.eW)((0,s.v_)(i.file?.metadata?.FileType||"未知"),1)]),_:1}),(0,a.bF)(m,{label:"文件大小"},{default:(0,a.k6)(()=>[(0,a.eW)((0,s.v_)(i.file?.metadata?.FileSize?i.file.metadata.FileSize+" MB":"未知"),1)]),_:1}),(0,a.bF)(m,{label:"上传时间"},{default:(0,a.k6)(()=>[(0,a.eW)((0,s.v_)(o.uploadTime),1)]),_:1}),(0,a.bF)(m,{label:"渠道类型/名称"},{default:(0,a.k6)(()=>[(0,a.eW)((0,s.v_)(i.file?.metadata?.Channel||"未知")+" / "+(0,s.v_)(i.file?.metadata?.ChannelName||"-"),1)]),_:1}),(0,a.bF)(m,{label:"访问状态/审查"},{default:(0,a.k6)(()=>[(0,a.eW)((0,s.v_)(o.accessType)+" / "+(0,s.v_)(i.file?.metadata?.Label||"无"),1)]),_:1}),(0,a.bF)(m,{label:"上传IP"},{default:(0,a.k6)(()=>[(0,a.eW)((0,s.v_)(i.file?.metadata?.UploadIP||"未知"),1)]),_:1}),(0,a.bF)(m,{label:"上传地址"},{default:(0,a.k6)(()=>[(0,a.eW)((0,s.v_)(i.file?.metadata?.UploadAddress||"未知"),1)]),_:1}),(0,a.bF)(m,{label:"文件标签"},{default:(0,a.k6)(()=>[i.file?.metadata?.Tags&&i.file?.metadata?.Tags.length>0?((0,a.uX)(),(0,a.CE)("div",Ce,[((0,a.uX)(!0),(0,a.CE)(a.FK,null,(0,a.pI)(i.file?.metadata?.Tags,e=>((0,a.uX)(),(0,a.Wv)(p,{key:e,size:"small"},{default:(0,a.k6)(()=>[(0,a.eW)((0,s.v_)(e),1)]),_:2},1024))),128))])):((0,a.uX)(),(0,a.CE)("span",Te,"暂无标签"))]),_:1})]),_:1},8,["column"])]),_:1},8,["modelValue","width"])}var Se={name:"FileDetailDialog",props:{modelValue:{type:Boolean,default:!1},file:{type:Object,default:null},fileLink:{type:String,default:""},urls:{type:Object,default:()=>({originUrl:"",mdUrl:"",htmlUrl:"",bbUrl:"",tgId:"",S3Location:"",S3CdnFileUrl:""})}},emits:["update:modelValue","download","tagManagement","block","white","delete"],data(){return{activeTab:"originUrl"}},computed:{visible:{get(){return this.modelValue},set(e){this.$emit("update:modelValue",e)}},dialogWidth(){return window.innerWidth<768?"95%":"900px"},descColumn(){return window.innerWidth<768?1:2},isVideo(){const e=this.file?.metadata?.FileType?.toLowerCase()||"";if(e.includes("video"))return!0;const t=this.file?.name?.toLowerCase()||"";return t.endsWith(".mp4")||t.endsWith(".webm")||t.endsWith(".mov")||t.endsWith(".avi")},isAudio(){const e=this.file?.metadata?.FileType?.toLowerCase()||"";if(e.includes("audio"))return!0;const t=this.file?.name?.toLowerCase()||"";return t.endsWith(".mp3")||t.endsWith(".wav")||t.endsWith(".ogg")||t.endsWith(".flac")},isImage(){const e=this.file?.metadata?.FileType?.toLowerCase()||"";if(e.includes("image"))return!0;const t=this.file?.name?.toLowerCase()||"";return t.endsWith(".jpg")||t.endsWith(".jpeg")||t.endsWith(".png")||t.endsWith(".gif")||t.endsWith(".webp")||t.endsWith(".svg")||t.endsWith(".bmp")||t.endsWith(".avif")||t.endsWith(".heic")||t.endsWith(".heif")},uploadTime(){return this.file?.metadata?.TimeStamp?new Date(this.file.metadata.TimeStamp).toLocaleString():"未知"},accessType(){const e=this.file?.metadata?.ListType,t=this.file?.metadata?.Label;return"White"===e?"正常(白名单)":"Block"===e?"已屏蔽(黑名单)":"adult"===t?"已屏蔽(审查不通过)":"正常"}},methods:{handleVideoClick(e){const t=e.target;t.paused?t.play():t.pause()},handleTabClick(){},handleUrlClick(e){const t=e.target;t.select(),navigator.clipboard.writeText(t.value).then(()=>{X.nk.success("链接已复制")})},openImageLink(){if(this.fileLink){const e=this.fileLink.replace(/\?from=admin$/,"");window.open(e,"_blank")}}}};const Le=(0,h.A)(Se,[["render",xe],["__scopeId","data-v-0dc381fc"]]);var Ee=Le,Ae=i(4880),Ie=(i(4318),i(7815)),De=(i(2907),i(8507));i(213);const ze={class:"list-col list-col-checkbox"},Ue=["src"],Be=["src"],We=["title"],Pe={class:"filename-start"},$e={class:"filename-end"},Oe={class:"list-col list-col-tags"},Re={key:1,class:"list-empty"},Ne={class:"list-col list-col-channel"},Me={class:"list-col list-col-channel-name"},je={key:0,class:"channel-name-box"},Ve={key:1,class:"list-empty"},Xe={class:"list-col list-col-address"},Ze={key:0,class:"address-box"},Ke={key:1,class:"list-empty"},Ge={class:"list-col list-col-size"},He={class:"list-col list-col-date"},qe={class:"list-col list-col-actions"};function Qe(e,t,i,r,o,l){const c=(0,a.g2)("font-awesome-icon"),d=De.R7;return(0,a.uX)(),(0,a.CE)("div",{class:"list-item",onTouchstart:t[9]||(t[9]=t=>e.$emit("touchstart",t)),onTouchend:t[10]||(t[10]=t=>e.$emit("touchend",t)),onTouchmove:t[11]||(t[11]=t=>e.$emit("touchmove",t))},[(0,a.Lk)("div",ze,[(0,a.Lk)("span",{class:(0,s.C4)(["custom-checkbox",{checked:o.localSelected}]),onClick:t[0]||(t[0]=(0,n.D$)((...e)=>l.toggleSelect&&l.toggleSelect(...e),["stop"]))},[o.localSelected?((0,a.uX)(),(0,a.Wv)(c,{key:0,icon:"check",class:"check-icon"})):(0,a.Q3)("",!0)],2)]),(0,a.Lk)("div",{class:"list-col list-col-preview",onClick:t[1]||(t[1]=(...e)=>l.handlePreviewClick&&l.handlePreviewClick(...e))},[l.isFolder?((0,a.uX)(),(0,a.Wv)(c,{key:0,icon:"folder-open",class:"list-folder-icon"})):l.isVideo?((0,a.uX)(),(0,a.CE)("video",{key:1,src:i.fileLink,class:"list-preview-img",muted:"",preload:"metadata"},null,8,Ue)):l.isImage?((0,a.uX)(),(0,a.CE)("img",{key:2,src:i.fileLink,class:"list-preview-img",loading:"lazy",decoding:"async"},null,8,Be)):((0,a.uX)(),(0,a.Wv)(c,{key:3,icon:"file",class:"list-file-icon"}))]),(0,a.Lk)("div",{class:"list-col list-col-name",onClick:t[2]||(t[2]=(...e)=>l.handlePreviewClick&&l.handlePreviewClick(...e))},[(0,a.Lk)("span",{class:"filename-ellipsis",title:l.displayName},[(0,a.Lk)("span",Pe,(0,s.v_)(l.fileNameStart),1),(0,a.Lk)("span",$e,(0,s.v_)(l.fileNameEnd),1)],8,We)]),(0,a.Lk)("div",Oe,[!l.isFolder&&i.item.metadata?.Tags&&i.item.metadata.Tags.length>0?((0,a.uX)(),(0,a.CE)(a.FK,{key:0},[((0,a.uX)(!0),(0,a.CE)(a.FK,null,(0,a.pI)(i.item.metadata.Tags.slice(0,3),(e,t)=>((0,a.uX)(),(0,a.CE)("span",{key:t,class:"color-tag",style:(0,s.Tr)({background:l.getTagColor(t)})},(0,s.v_)(e),5))),128)),i.item.metadata.Tags.length>3?((0,a.uX)(),(0,a.CE)("span",{key:0,class:"color-tag color-tag-more",style:(0,s.Tr)({background:l.getTagColor(3)})},"+"+(0,s.v_)(i.item.metadata.Tags.length-3),5)):(0,a.Q3)("",!0)],64)):((0,a.uX)(),(0,a.CE)("span",Re,"-"))]),(0,a.Lk)("div",Ne,(0,s.v_)(l.isFolder?"-":i.item.metadata?.Channel||i.item.channelTag||"-"),1),(0,a.Lk)("div",Me,[!l.isFolder&&i.item.metadata?.ChannelName?((0,a.uX)(),(0,a.CE)("div",je,(0,s.v_)(i.item.metadata.ChannelName),1)):((0,a.uX)(),(0,a.CE)("span",Ve,"-"))]),(0,a.Lk)("div",Xe,[!l.isFolder&&i.item.metadata?.UploadIP?((0,a.uX)(),(0,a.CE)("div",Ze,(0,s.v_)(i.item.metadata.UploadIP),1)):((0,a.uX)(),(0,a.CE)("span",Ke,"-"))]),(0,a.Lk)("div",Ge,(0,s.v_)(l.isFolder?"-":i.item.metadata?.FileSize?i.item.metadata.FileSize+" MB":"-"),1),(0,a.Lk)("div",He,(0,s.v_)(l.uploadDate),1),(0,a.Lk)("div",qe,[l.isFolder?((0,a.uX)(),(0,a.CE)(a.FK,{key:1},[(0,a.bF)(d,{content:"复制链接",placement:"top"},{default:(0,a.k6)(()=>[(0,a.Lk)("button",{class:"list-action-btn",onClick:t[6]||(t[6]=(0,n.D$)(t=>e.$emit("folderCopy"),["stop"]))},[(0,a.bF)(c,{icon:"copy"})])]),_:1}),(0,a.bF)(d,{content:"移动",placement:"top"},{default:(0,a.k6)(()=>[(0,a.Lk)("button",{class:"list-action-btn",onClick:t[7]||(t[7]=(0,n.D$)(t=>e.$emit("move"),["stop"]))},[(0,a.bF)(c,{icon:"file-export"})])]),_:1})],64)):((0,a.uX)(),(0,a.CE)(a.FK,{key:0},[(0,a.bF)(d,{content:"复制链接",placement:"top"},{default:(0,a.k6)(()=>[(0,a.Lk)("button",{class:"list-action-btn",onClick:t[3]||(t[3]=(0,n.D$)(t=>e.$emit("copy"),["stop"]))},[(0,a.bF)(c,{icon:"copy"})])]),_:1}),(0,a.bF)(d,{content:"下载",placement:"top"},{default:(0,a.k6)(()=>[(0,a.Lk)("button",{class:"list-action-btn",onClick:t[4]||(t[4]=(0,n.D$)(t=>e.$emit("download"),["stop"]))},[(0,a.bF)(c,{icon:"download"})])]),_:1}),(0,a.bF)(d,{content:"移动",placement:"top"},{default:(0,a.k6)(()=>[(0,a.Lk)("button",{class:"list-action-btn",onClick:t[5]||(t[5]=(0,n.D$)(t=>e.$emit("move"),["stop"]))},[(0,a.bF)(c,{icon:"file-export"})])]),_:1})],64)),(0,a.bF)(d,{content:"删除",placement:"top"},{default:(0,a.k6)(()=>[(0,a.Lk)("button",{class:"list-action-btn list-action-danger",onClick:t[8]||(t[8]=(0,n.D$)(t=>e.$emit("delete"),["stop"]))},[(0,a.bF)(c,{icon:"trash-alt"})])]),_:1})])],32)}var Ye={name:"FileListItem",props:{item:{type:Object,required:!0},selected:{type:Boolean,default:!1},fileLink:{type:String,default:""}},emits:["update:selected","enter","detail","copy","folderCopy","move","delete","download","touchstart","touchend","touchmove"],data(){return{localSelected:this.selected,tagColors:["#f472b6","#a78bfa","#60a5fa","#34d399"]}},computed:{isFolder(){return this.item.name?.endsWith("/")},isVideo(){const e=this.item.name?.toLowerCase()||"";return e.endsWith(".mp4")||e.endsWith(".webm")||e.endsWith(".mov")||e.endsWith(".avi")},isImage(){const e=this.item.name?.toLowerCase()||"";return e.endsWith(".jpg")||e.endsWith(".jpeg")||e.endsWith(".png")||e.endsWith(".gif")||e.endsWith(".webp")||e.endsWith(".svg")||e.endsWith(".bmp")},displayName(){if(this.isFolder){const e=this.item.name.split("/").filter(Boolean);return e[e.length-1]||this.item.name}return this.item.metadata?.FileName||this.getFileName(this.item.name)},fileNameStart(){const e=this.displayName;return e.length<=20?e:e.slice(0,-8)},fileNameEnd(){const e=this.displayName;return e.length<=20?"":e.slice(-8)},uploadDate(){return this.item.uploaded?new Date(this.item.uploaded).toLocaleDateString():this.item.metadata?.TimeStamp?new Date(this.item.metadata.TimeStamp).toLocaleDateString():"-"}},watch:{selected(e){this.localSelected=e}},methods:{toggleSelect(){this.localSelected=!this.localSelected,this.$emit("update:selected",this.localSelected)},handlePreviewClick(){this.isFolder?this.$emit("enter"):this.$emit("detail")},getFileName(e){const t=(e||"").split("/");return t[t.length-1]},getTagColor(e){return this.tagColors[e%this.tagColors.length]}}};const Je=(0,h.A)(Ye,[["render",Qe],["__scopeId","data-v-9968e9fe"]]);var et=Je,tt=i(683),it=(i(5385),i(850));i(8736);const at={class:"file-short-info"},nt={key:0,class:"success-tag"},st={key:1,class:"fail-tag"},rt={key:2,class:"success-tag"},ot={key:3,class:"primary-tag"},lt={key:0,style:{"margin-left":"2px"}},ct={key:0,class:"skeleton-wrapper"},dt=["src"],ht={key:3,class:"file-preview"},ut={class:"card-bottom-overlay"},ft={class:"file-name-row"},mt={class:"file-name"},pt={class:"action-bar"},gt={class:"action-bar-left"},bt={class:"action-bar-right"};function vt(e,t,i,r,o,l){const c=it.dI,d=(0,a.g2)("font-awesome-icon"),h=ve.Zq,u=De.R7,f=tt.Ik;return(0,a.uX)(),(0,a.Wv)(f,{class:"img-card",onTouchstart:t[17]||(t[17]=t=>e.$emit("touchstart",t)),onTouchend:t[18]||(t[18]=t=>e.$emit("touchend",t)),onTouchmove:t[19]||(t[19]=t=>e.$emit("touchmove",t))},{default:(0,a.k6)(()=>[(0,a.bF)(c,{modelValue:o.localSelected,"onUpdate:modelValue":t[0]||(t[0]=e=>o.localSelected=e),onChange:t[1]||(t[1]=t=>e.$emit("update:selected",o.localSelected))},null,8,["modelValue"]),(0,a.Lk)("div",at,["White"===i.item.metadata?.ListType?((0,a.uX)(),(0,a.CE)("div",nt,(0,s.v_)(l.channelTag),1)):"Block"===i.item.metadata?.ListType||"adult"===i.item.metadata?.Label?((0,a.uX)(),(0,a.CE)("div",st,(0,s.v_)(l.channelTag),1)):((0,a.uX)(),(0,a.CE)("div",rt,(0,s.v_)(l.channelTag),1)),i.item.metadata?.Tags&&i.item.metadata?.Tags.length>0?((0,a.uX)(),(0,a.CE)("div",ot,[(0,a.bF)(d,{icon:"tag",style:{"margin-right":"3px","font-size":"12px"}}),(0,a.eW)(" "+(0,s.v_)(i.item.metadata.Tags[0])+" ",1),i.item.metadata.Tags.length>1?((0,a.uX)(),(0,a.CE)("span",lt," (+"+(0,s.v_)(i.item.metadata.Tags.length-1)+") ",1)):(0,a.Q3)("",!0)])):(0,a.Q3)("",!0)]),l.isVideo?((0,a.uX)(),(0,a.CE)(a.FK,{key:0},[o.videoLoading?((0,a.uX)(),(0,a.CE)("div",ct)):o.videoError?((0,a.uX)(),(0,a.CE)("div",{key:1,class:"error-wrapper",onClick:t[2]||(t[2]=t=>e.$emit("detail"))},[(0,a.bF)(d,{icon:"exclamation-triangle",class:"error-icon"}),t[20]||(t[20]=(0,a.Lk)("span",{class:"error-text"},"加载失败",-1))])):(0,a.Q3)("",!0),(0,a.bo)((0,a.Lk)("video",{src:i.fileLink,muted:"",loop:"",preload:"metadata",class:"video-preview",onClick:t[3]||(t[3]=(...e)=>l.handleVideoClick&&l.handleVideoClick(...e)),onMouseenter:t[4]||(t[4]=e=>l.handleVideoHover(e,!0)),onMouseleave:t[5]||(t[5]=e=>l.handleVideoHover(e,!1)),onFullscreenchange:t[6]||(t[6]=(...e)=>l.handleFullscreenChange&&l.handleFullscreenChange(...e)),onWebkitfullscreenchange:t[7]||(t[7]=(...e)=>l.handleFullscreenChange&&l.handleFullscreenChange(...e)),onLoadeddata:t[8]||(t[8]=e=>o.videoLoading=!1),onError:t[9]||(t[9]=(...e)=>l.handleVideoError&&l.handleVideoError(...e))},null,40,dt),[[n.aG,!o.videoLoading&&!o.videoError]])],64)):l.isAudio?((0,a.uX)(),(0,a.CE)("div",{key:1,class:"file-preview audio-card-preview",onClick:t[10]||(t[10]=t=>e.$emit("detail"))},[(0,a.bF)(d,{icon:"music",class:"file-icon audio-icon"})])):l.isImage?((0,a.uX)(),(0,a.Wv)(h,{key:2,"preview-teleported":!0,src:i.fileLink,"preview-src-list":i.previewSrcList,fit:"cover",lazy:"",class:"image-preview"},{placeholder:(0,a.k6)(()=>[...t[21]||(t[21]=[(0,a.Lk)("div",{class:"skeleton-wrapper"},null,-1)])]),error:(0,a.k6)(()=>[(0,a.Lk)("div",{class:"error-wrapper",onClick:t[11]||(t[11]=(0,n.D$)(t=>e.$emit("detail"),["stop"]))},[(0,a.bF)(d,{icon:"image",class:"error-icon"}),t[22]||(t[22]=(0,a.Lk)("span",{class:"error-text"},"加载失败",-1))])]),_:1},8,["src","preview-src-list"])):((0,a.uX)(),(0,a.CE)("div",ht,[(0,a.bF)(d,{icon:"file",class:"file-icon"})])),(0,a.Lk)("div",ut,[(0,a.Lk)("div",ft,[(0,a.Lk)("span",mt,(0,s.v_)(l.displayName),1)]),(0,a.Lk)("div",pt,[(0,a.Lk)("div",gt,[(0,a.bF)(u,{disabled:i.disableTooltip,content:"详情",placement:"top"},{default:(0,a.k6)(()=>[(0,a.Lk)("button",{class:"action-btn",onClick:t[12]||(t[12]=(0,n.D$)(t=>e.$emit("detail"),["stop"]))},[(0,a.bF)(d,{icon:"info-circle"})])]),_:1},8,["disabled"])]),(0,a.Lk)("div",bt,[(0,a.bF)(u,{disabled:i.disableTooltip,content:"移动",placement:"top"},{default:(0,a.k6)(()=>[(0,a.Lk)("button",{class:"action-btn",onClick:t[13]||(t[13]=(0,n.D$)(t=>e.$emit("move"),["stop"]))},[(0,a.bF)(d,{icon:"file-export"})])]),_:1},8,["disabled"]),(0,a.bF)(u,{disabled:i.disableTooltip,content:"删除",placement:"top"},{default:(0,a.k6)(()=>[(0,a.Lk)("button",{class:"action-btn action-btn-danger",onClick:t[14]||(t[14]=(0,n.D$)(t=>e.$emit("delete"),["stop"]))},[(0,a.bF)(d,{icon:"trash-alt"})])]),_:1},8,["disabled"]),(0,a.bF)(u,{disabled:i.disableTooltip,content:"下载",placement:"top"},{default:(0,a.k6)(()=>[(0,a.Lk)("button",{class:"action-btn",onClick:t[15]||(t[15]=(0,n.D$)(t=>e.$emit("download"),["stop"]))},[(0,a.bF)(d,{icon:"download"})])]),_:1},8,["disabled"]),(0,a.bF)(u,{disabled:i.disableTooltip,content:"复制链接",placement:"top"},{default:(0,a.k6)(()=>[(0,a.Lk)("button",{class:"action-btn",onClick:t[16]||(t[16]=(0,n.D$)(t=>e.$emit("copy"),["stop"]))},[(0,a.bF)(d,{icon:"copy"})])]),_:1},8,["disabled"])])])])]),_:1})}var kt={name:"FileCard",props:{item:{type:Object,required:!0},selected:{type:Boolean,default:!1},fileLink:{type:String,required:!0},previewSrcList:{type:Array,default:()=>[]},disableTooltip:{type:Boolean,default:!1}},emits:["update:selected","detail","copy","move","delete","download","touchstart","touchend","touchmove"],data(){return{localSelected:this.selected,videoLoading:!0,videoError:!1}},computed:{channelTag(){return this.item.channelTag||""},isVideo(){const e=this.item.metadata?.FileType?.toLowerCase()||"";if(e.includes("video"))return!0;const t=this.item.name?.toLowerCase()||"";return t.endsWith(".mp4")||t.endsWith(".webm")||t.endsWith(".mov")||t.endsWith(".avi")},isAudio(){const e=this.item.metadata?.FileType?.toLowerCase()||"";if(e.includes("audio"))return!0;const t=this.item.name?.toLowerCase()||"";return t.endsWith(".mp3")||t.endsWith(".wav")||t.endsWith(".ogg")||t.endsWith(".flac")},isImage(){const e=this.item.metadata?.FileType?.toLowerCase()||"";if(e.includes("image"))return!0;const t=this.item.name?.toLowerCase()||"";return t.endsWith(".jpg")||t.endsWith(".jpeg")||t.endsWith(".png")||t.endsWith(".gif")||t.endsWith(".webp")||t.endsWith(".svg")||t.endsWith(".bmp")||t.endsWith(".avif")||t.endsWith(".heic")||t.endsWith(".heif")},displayName(){const e=this.item.metadata?.FileName||this.item.name||"",t=e.split("/");return t[t.length-1]}},watch:{selected(e){this.localSelected=e},fileLink(){this.videoLoading=!0,this.videoError=!1}},methods:{handleVideoError(){this.videoLoading=!1,this.videoError=!0},handleVideoClick(e){const t=e.target;t.requestFullscreen?t.requestFullscreen():t.webkitRequestFullscreen?t.webkitRequestFullscreen():t.mozRequestFullScreen?t.mozRequestFullScreen():t.msRequestFullscreen&&t.msRequestFullscreen()},handleFullscreenChange(e){const t=e.target,i=document.fullscreenElement||document.webkitFullscreenElement||document.mozFullScreenElement||document.msFullscreenElement;i?(t.muted=!1,t.loop=!1):(t.muted=!0,t.loop=!0,t.pause(),t.currentTime=0)},handleVideoHover(e,t){const i=e.target;t?i.play().catch(()=>{}):(i.pause(),i.currentTime=0)}}};const _t=(0,h.A)(kt,[["render",vt],["__scopeId","data-v-ddf49ce2"]]);var yt=_t;const wt={class:"card-bottom-overlay"},Ft={class:"file-name-row"},Ct={class:"file-name"},Tt={key:0,class:"action-bar"},xt={class:"action-bar-right"};function St(e,t,i,r,o,l){const c=it.dI,d=(0,a.g2)("font-awesome-icon"),h=De.R7,u=tt.Ik;return(0,a.uX)(),(0,a.Wv)(u,{class:"img-card folder-card",onTouchstart:t[6]||(t[6]=t=>e.$emit("touchstart",t)),onTouchend:t[7]||(t[7]=t=>e.$emit("touchend",t)),onTouchmove:t[8]||(t[8]=t=>e.$emit("touchmove",t))},{default:(0,a.k6)(()=>[(0,a.bF)(c,{modelValue:o.localSelected,"onUpdate:modelValue":t[0]||(t[0]=e=>o.localSelected=e),onChange:t[1]||(t[1]=t=>e.$emit("update:selected",o.localSelected))},null,8,["modelValue"]),(0,a.Lk)("div",{class:"folder-icon",onClick:t[2]||(t[2]=t=>e.$emit("enter"))},[(0,a.bF)(d,{icon:"folder-open",class:"folder-icon-svg"})]),(0,a.Lk)("div",wt,[(0,a.Lk)("div",Ft,[(0,a.Lk)("span",Ct,(0,s.v_)(l.folderName),1)]),i.showActions?((0,a.uX)(),(0,a.CE)("div",Tt,[t[9]||(t[9]=(0,a.Lk)("div",{class:"action-bar-left"},null,-1)),(0,a.Lk)("div",xt,[(0,a.bF)(h,{disabled:i.disableTooltip,content:"复制链接",placement:"top"},{default:(0,a.k6)(()=>[(0,a.Lk)("button",{class:"action-btn",onClick:t[3]||(t[3]=(0,n.D$)(t=>e.$emit("copy"),["stop"]))},[(0,a.bF)(d,{icon:"copy"})])]),_:1},8,["disabled"]),(0,a.bF)(h,{disabled:i.disableTooltip,content:"移动",placement:"top"},{default:(0,a.k6)(()=>[(0,a.Lk)("button",{class:"action-btn",onClick:t[4]||(t[4]=(0,n.D$)(t=>e.$emit("move"),["stop"]))},[(0,a.bF)(d,{icon:"file-export"})])]),_:1},8,["disabled"]),(0,a.bF)(h,{disabled:i.disableTooltip,content:"删除",placement:"top"},{default:(0,a.k6)(()=>[(0,a.Lk)("button",{class:"action-btn action-btn-danger",onClick:t[5]||(t[5]=(0,n.D$)(t=>e.$emit("delete"),["stop"]))},[(0,a.bF)(d,{icon:"trash-alt"})])]),_:1},8,["disabled"])])])):(0,a.Q3)("",!0)])]),_:1})}var Lt={name:"FolderCard",props:{name:{type:String,required:!0},selected:{type:Boolean,default:!1},showActions:{type:Boolean,default:!0},disableTooltip:{type:Boolean,default:!1}},emits:["update:selected","enter","copy","move","delete","touchstart","touchend","touchmove"],data(){return{localSelected:this.selected}},computed:{folderName(){const e=this.name.split("/").filter(Boolean);return e[e.length-1]||this.name}},watch:{selected(e){this.localSelected=e}}};const Et=(0,h.A)(Lt,[["render",St],["__scopeId","data-v-20e5d6b4"]]);var At=Et;function It(e,t,i,n,s,r){return"card"===i.type?((0,a.uX)(!0),(0,a.CE)(a.FK,{key:0},(0,a.pI)(i.count,e=>((0,a.uX)(),(0,a.CE)("div",{key:"skeleton-"+e,class:"skeleton-card"},[...t[0]||(t[0]=[(0,a.Lk)("div",{class:"skeleton-image"},null,-1),(0,a.Lk)("div",{class:"skeleton-info"},[(0,a.Lk)("div",{class:"skeleton-text"})],-1)])]))),128)):"list"===i.type?((0,a.uX)(!0),(0,a.CE)(a.FK,{key:1},(0,a.pI)(i.count,e=>((0,a.uX)(),(0,a.CE)("div",{key:"list-skeleton-"+e,class:"list-item skeleton-list-item"},[...t[1]||(t[1]=[(0,a.Fv)('
',10)])]))),128)):(0,a.Q3)("",!0)}var Dt={name:"SkeletonLoader",props:{type:{type:String,default:"card",validator:e=>["card","list"].includes(e)},count:{type:Number,default:15}}};const zt=(0,h.A)(Dt,[["render",It],["__scopeId","data-v-71848b62"]]);var Ut=zt,Bt=i(1095),Wt=(i(7128),i(2086)),Pt=(i(670),i(8830),i(3597),i(6011));const $t={class:"container"},Ot={class:"header-content"},Rt={class:"search-card"},Nt={class:"actions"},Mt={class:"el-dropdown-link"},jt={class:"el-dropdown-link"},Vt={class:"el-dropdown-link"},Xt={class:"breadcrumb-container"},Zt={class:"mobile-directory-path"},Kt={class:"breadcrumb desktop-only"},Gt=["title"],Ht={key:0,class:"content"},qt={key:1,class:"list-view"},Qt={class:"list-header"},Yt={class:"list-col list-col-checkbox"},Jt={class:"pagination-container"},ei={class:"pagination-center"},ti={class:"pagination-right"},ii={class:"page-total"},ai={class:"page-jump"},ni={class:"dialog-section"},si={class:"section-content"},ri={class:"dialog-section"},oi={class:"section-header"},li={class:"section-content"},ci={class:"setting-item"},di={key:0,class:"setting-item"},hi={class:"dialog-action"};function ui(e,t,i,r,o,l){const c=Pt.A,d=(0,a.g2)("font-awesome-icon"),h=T.WK,u=Wt.c6,m=Wt.Iy,p=Wt.dW,g=De.R7,b=Ae.bZ,v=Bt.WZ,k=Bt.vp,w=Ut,F=At,C=yt,S=et,L=Ie.aQ,E=x.S2,A=Ae.ZO,I=Ae.lX,D=Ee,z=ge.ll,U=ge.MQ,B=pe.qi,W=y.kZ,P=me,$=q,O=_,R=f;return(0,a.uX)(),(0,a.CE)("div",$t,[(0,a.bF)(I,null,{default:(0,a.k6)(()=>[(0,a.bF)(b,null,{default:(0,a.k6)(()=>[(0,a.Lk)("div",Ot,[(0,a.bF)(c,{activeTab:"dashboard"}),(0,a.Lk)("div",Rt,[(0,a.bF)(h,{modelValue:o.tempSearch,"onUpdate:modelValue":t[0]||(t[0]=e=>o.tempSearch=e),size:"mini",placeholder:"搜索:#标签 -#排除标签",onKeyup:(0,n.jR)(l.handleSearch,["enter"])},{suffix:(0,a.k6)(()=>[(0,a.bF)(d,{icon:"search",class:"search-icon",onClick:l.handleSearch},null,8,["onClick"])]),_:1},8,["modelValue","onKeyup"])]),(0,a.Lk)("div",Nt,[(0,a.bF)(p,{onCommand:l.sort,"hide-on-click":!1},{dropdown:(0,a.k6)(()=>[(0,a.bF)(m,null,{default:(0,a.k6)(()=>[(0,a.bF)(u,{command:"dateDesc"},{default:(0,a.k6)(()=>[...t[21]||(t[21]=[(0,a.eW)("按时间倒序",-1)])]),_:1}),(0,a.bF)(u,{command:"nameAsc"},{default:(0,a.k6)(()=>[...t[22]||(t[22]=[(0,a.eW)("按名称升序",-1)])]),_:1})]),_:1})]),default:(0,a.k6)(()=>[(0,a.Lk)("span",Mt,[(0,a.bF)(d,{icon:l.sortIcon,class:"header-icon"},null,8,["icon"])])]),_:1},8,["onCommand"]),(0,a.bF)(g,{disabled:l.disableTooltip,content:"全选此页",placement:"bottom"},{default:(0,a.k6)(()=>[(0,a.bF)(d,{icon:l.selectPageIcon,class:"header-icon",onClick:l.handleSelectPage},null,8,["icon","onClick"])]),_:1},8,["disabled"]),(0,a.bF)(p,{onCommand:l.handleBatchAction,"hide-on-click":!1,disabled:0===o.selectedFiles.length},{dropdown:(0,a.k6)(()=>[(0,a.bF)(m,null,{default:(0,a.k6)(()=>[(0,a.bF)(u,{command:"copy"},{default:(0,a.k6)(()=>[(0,a.bF)(d,{icon:"copy",class:"batch-action-item-icon"}),t[23]||(t[23]=(0,a.eW)(" 复制 ",-1))]),_:1}),(0,a.bF)(u,{command:"delete"},{default:(0,a.k6)(()=>[(0,a.bF)(d,{icon:"trash-alt",class:"batch-action-item-icon"}),t[24]||(t[24]=(0,a.eW)(" 删除 ",-1))]),_:1}),(0,a.bF)(u,{command:"download"},{default:(0,a.k6)(()=>[(0,a.bF)(d,{icon:"download",class:"batch-action-item-icon"}),t[25]||(t[25]=(0,a.eW)(" 下载 ",-1))]),_:1}),(0,a.bF)(u,{command:"move"},{default:(0,a.k6)(()=>[(0,a.bF)(d,{icon:"file-export",class:"batch-action-item-icon"}),t[26]||(t[26]=(0,a.eW)(" 移动 ",-1))]),_:1}),(0,a.bF)(u,{command:"tagManagement"},{default:(0,a.k6)(()=>[(0,a.bF)(d,{icon:"tags",class:"batch-action-item-icon"}),t[27]||(t[27]=(0,a.eW)(" 标签管理 ",-1))]),_:1}),(0,a.bF)(u,{command:"ban"},{default:(0,a.k6)(()=>[(0,a.bF)(d,{icon:"ban",class:"batch-action-item-icon"}),t[28]||(t[28]=(0,a.eW)(" 加入黑名单 ",-1))]),_:1}),(0,a.bF)(u,{command:"white"},{default:(0,a.k6)(()=>[(0,a.bF)(d,{icon:"user-plus",class:"batch-action-item-icon"}),t[29]||(t[29]=(0,a.eW)(" 加入白名单 ",-1))]),_:1})]),_:1})]),default:(0,a.k6)(()=>[(0,a.Lk)("span",jt,[(0,a.bF)(d,{icon:"ellipsis-h",class:(0,s.C4)(["header-icon",{disabled:0===o.selectedFiles.length}])},null,8,["class"])])]),_:1},8,["onCommand","disabled"]),(0,a.bF)(g,{disabled:l.disableTooltip,content:"链接格式",placement:"bottom"},{default:(0,a.k6)(()=>[(0,a.Lk)("span",Vt,[(0,a.bF)(d,{icon:"link",class:"header-icon",onClick:t[1]||(t[1]=e=>o.showUrlDialog=!0)})])]),_:1},8,["disabled"]),(0,a.bF)(g,{disabled:l.disableTooltip,content:"card"===o.viewMode?"列表视图":"卡片视图",placement:"bottom"},{default:(0,a.k6)(()=>[(0,a.bF)(d,{icon:"card"===o.viewMode?"list":"th-large",class:"header-icon",onClick:l.toggleViewMode},null,8,["icon","onClick"])]),_:1},8,["disabled","content"]),(0,a.bF)(g,{disabled:l.disableTooltip,content:"退出登录",placement:"bottom"},{default:(0,a.k6)(()=>[(0,a.bF)(d,{icon:"sign-out-alt",class:"header-icon",onClick:l.handleLogout},null,8,["onClick"])]),_:1},8,["disabled"])])])]),_:1}),(0,a.bF)(A,{class:"main-container"},{default:(0,a.k6)(()=>[(0,a.Lk)("div",Xt,[(0,a.Lk)("div",{class:"mobile-directory-trigger",onClick:t[2]||(t[2]=e=>o.showMobileDirectoryDrawer=!0)},[(0,a.bF)(d,{icon:"folder-open",class:"mobile-directory-icon"}),(0,a.Lk)("span",Zt,(0,s.v_)(o.currentPath&&o.currentPath.split("/").filter(Boolean).length>0?o.currentPath.split("/").filter(Boolean).pop():"根目录"),1),(0,a.bF)(d,{icon:"chevron-down",class:"mobile-directory-arrow"})]),(0,a.Lk)("div",Kt,[(0,a.bF)(k,{separator:"/"},{default:(0,a.k6)(()=>[(0,a.bF)(v,{onClick:t[3]||(t[3]=e=>l.navigateToFolder(""))},{default:(0,a.k6)(()=>[(0,a.bF)(d,{icon:"home",class:"breadcrumb-home-icon"})]),_:1}),((0,a.uX)(!0),(0,a.CE)(a.FK,null,(0,a.pI)(o.currentPath.split("/").filter(Boolean),(e,t)=>((0,a.uX)(),(0,a.Wv)(v,{key:t,onClick:e=>l.navigateToFolder(o.currentPath.split("/").filter(Boolean).slice(0,t+1).join("/"))},{default:(0,a.k6)(()=>[(0,a.eW)((0,s.v_)(e),1)]),_:2},1032,["onClick"]))),128))]),_:1})]),(0,a.Lk)("span",{class:"stats-badge",title:`共 ${e.$data.Number} 个文件`},[(0,a.bF)(d,{icon:"database",class:"stats-badge-icon"}),(0,a.eW)(" "+(0,s.v_)(o.Number),1)],8,Gt)]),"card"===o.viewMode?((0,a.uX)(),(0,a.CE)("div",Ht,[o.loading?((0,a.uX)(),(0,a.Wv)(w,{key:0,type:"card",count:15})):((0,a.uX)(!0),(0,a.CE)(a.FK,{key:1},(0,a.pI)(l.paginatedTableData,(e,t)=>((0,a.uX)(),(0,a.CE)(a.FK,{key:t},[l.isFolder(e)?((0,a.uX)(),(0,a.Wv)(F,{key:0,name:e.name,selected:e.selected,"onUpdate:selected":t=>e.selected=t,showActions:!o.isSearchMode,disableTooltip:l.disableTooltip,onEnter:t=>l.enterFolder(e.name),onCopy:t=>l.handleFolderCopy(e.name),onMove:i=>l.handleMove(t,e.name),onDelete:i=>l.handleDelete(t,e.name),onTouchstart:i=>l.handleFolderTouchStart(e,t),onTouchend:l.handleTouchEnd,onTouchmove:l.handleTouchEnd},null,8,["name","selected","onUpdate:selected","showActions","disableTooltip","onEnter","onCopy","onMove","onDelete","onTouchstart","onTouchend","onTouchmove"])):((0,a.uX)(),(0,a.Wv)(C,{key:1,item:e,selected:e.selected,"onUpdate:selected":t=>e.selected=t,fileLink:l.getFileLink(e.name),previewSrcList:e.previewSrcList,disableTooltip:l.disableTooltip,onDetail:i=>l.openDetailDialog(t,e.name),onCopy:i=>l.handleCopy(t,e.name),onMove:i=>l.handleMove(t,e.name),onDelete:i=>l.handleDelete(t,e.name),onDownload:t=>l.handleDownload(e.name),onTouchstart:i=>l.handleTouchStart(e,t),onTouchend:l.handleTouchEnd,onTouchmove:l.handleTouchEnd},null,8,["item","selected","onUpdate:selected","fileLink","previewSrcList","disableTooltip","onDetail","onCopy","onMove","onDelete","onDownload","onTouchstart","onTouchend","onTouchmove"]))],64))),128))])):((0,a.uX)(),(0,a.CE)("div",qt,[(0,a.Lk)("div",Qt,[(0,a.Lk)("div",Yt,[(0,a.Lk)("span",{class:(0,s.C4)(["custom-checkbox",{checked:l.isSelectAll,indeterminate:l.isIndeterminate}]),onClick:t[4]||(t[4]=e=>l.handleSelectAllPage(!l.isSelectAll))},[l.isSelectAll?((0,a.uX)(),(0,a.Wv)(d,{key:0,icon:"check",class:"check-icon"})):l.isIndeterminate?((0,a.uX)(),(0,a.Wv)(d,{key:1,icon:"minus",class:"check-icon"})):(0,a.Q3)("",!0)],2)]),t[30]||(t[30]=(0,a.Lk)("div",{class:"list-col list-col-preview"},"预览",-1)),t[31]||(t[31]=(0,a.Lk)("div",{class:"list-col list-col-name"},"文件名",-1)),t[32]||(t[32]=(0,a.Lk)("div",{class:"list-col list-col-tags"},"标签",-1)),t[33]||(t[33]=(0,a.Lk)("div",{class:"list-col list-col-channel"},"渠道类型",-1)),t[34]||(t[34]=(0,a.Lk)("div",{class:"list-col list-col-channel-name"},"渠道名称",-1)),t[35]||(t[35]=(0,a.Lk)("div",{class:"list-col list-col-address"},"上传地址",-1)),t[36]||(t[36]=(0,a.Lk)("div",{class:"list-col list-col-size"},"大小",-1)),t[37]||(t[37]=(0,a.Lk)("div",{class:"list-col list-col-date"},"上传时间",-1)),t[38]||(t[38]=(0,a.Lk)("div",{class:"list-col list-col-actions"},"操作",-1))]),o.loading?((0,a.uX)(),(0,a.Wv)(w,{key:0,type:"list",count:15})):((0,a.uX)(!0),(0,a.CE)(a.FK,{key:1},(0,a.pI)(l.paginatedTableData,(e,t)=>((0,a.uX)(),(0,a.Wv)(S,{key:t,item:e,selected:e.selected,"onUpdate:selected":t=>e.selected=t,fileLink:l.getFileLink(e.name),onEnter:t=>l.enterFolder(e.name),onDetail:i=>l.openDetailDialog(t,e.name),onCopy:i=>l.handleCopy(t,e.name),onFolderCopy:t=>l.handleFolderCopy(e.name),onMove:i=>l.handleMove(t,e.name),onDelete:i=>l.handleDelete(t,e.name),onDownload:t=>l.handleDownload(e.name),onTouchstart:i=>l.isFolder(e)?l.handleFolderTouchStart(e,t):l.handleTouchStart(e,t),onTouchend:l.handleTouchEnd,onTouchmove:l.handleTouchEnd},null,8,["item","selected","onUpdate:selected","fileLink","onEnter","onDetail","onCopy","onFolderCopy","onMove","onDelete","onDownload","onTouchstart","onTouchend","onTouchmove"]))),128))])),(0,a.Lk)("div",Jt,[(0,a.Lk)("div",ei,[(0,a.bF)(L,{background:"",layout:"prev, pager, next",total:l.filteredTableData.length,"page-size":o.pageSize,"current-page":o.currentPage,"pager-count":l.pagerCount,onCurrentChange:l.handlePageChange},null,8,["total","page-size","current-page","pager-count","onCurrentChange"]),(0,a.bF)(E,{type:"primary",onClick:l.refreshFileList,class:"refresh-btn"},{default:(0,a.k6)(()=>[(0,a.bF)(d,{icon:"sync",class:(0,s.C4)({"fa-spin":o.refreshLoading})},null,8,["class"])]),_:1},8,["onClick"]),o.currentPage===Math.ceil(l.filteredTableData.length/o.pageSize)?((0,a.uX)(),(0,a.Wv)(E,{key:0,type:"primary",onClick:l.loadMoreData,loading:o.loading,class:"load-more"},{default:(0,a.k6)(()=>[...t[39]||(t[39]=[(0,a.eW)(" 加载更多 ",-1)])]),_:1},8,["onClick","loading"])):(0,a.Q3)("",!0)]),(0,a.Lk)("div",ti,[(0,a.Lk)("span",ii,"共 "+(0,s.v_)(l.realTotalPages)+" 页",1),(0,a.Lk)("div",ai,[t[41]||(t[41]=(0,a.Lk)("span",null,"跳至",-1)),(0,a.bF)(h,{modelValue:o.jumpPage,"onUpdate:modelValue":t[5]||(t[5]=e=>o.jumpPage=e),size:"small",class:"jump-input",onKeyup:(0,n.jR)(l.handleJumpPage,["enter"])},null,8,["modelValue","onKeyup"]),(0,a.bF)(E,{size:"small",type:"primary",onClick:l.handleJumpPage,class:"jump-btn"},{default:(0,a.k6)(()=>[...t[40]||(t[40]=[(0,a.eW)("GO",-1)])]),_:1},8,["onClick"])])])])]),_:1})]),_:1}),(0,a.bF)(D,{modelValue:o.showdetailDialog,"onUpdate:modelValue":t[6]||(t[6]=e=>o.showdetailDialog=e),file:o.detailFile,fileLink:l.getFileLink(o.detailFile?.name),urls:l.allUrl,onDownload:t[7]||(t[7]=e=>l.handleDownload(o.detailFile?.name)),onTagManagement:t[8]||(t[8]=e=>l.handleTagManagement(o.detailFile?.name)),onBlock:t[9]||(t[9]=e=>l.handleBlock(o.detailFile?.name)),onWhite:t[10]||(t[10]=e=>l.handleWhite(o.detailFile?.name)),onDelete:t[11]||(t[11]=e=>l.handleDetailDelete(o.detailFile?.name))},null,8,["modelValue","file","fileLink","urls"]),(0,a.bF)(W,{title:"链接格式",modelValue:o.showUrlDialog,"onUpdate:modelValue":t[16]||(t[16]=e=>o.showUrlDialog=e),width:l.dialogWidth,"show-close":!1,class:"settings-dialog"},{default:(0,a.k6)(()=>[(0,a.Lk)("div",ni,[t[48]||(t[48]=(0,a.Lk)("div",{class:"section-header"},[(0,a.Lk)("span",{class:"section-title"},"默认复制链接")],-1)),(0,a.Lk)("div",si,[(0,a.bF)(U,{modelValue:o.defaultUrlFormat,"onUpdate:modelValue":t[12]||(t[12]=e=>o.defaultUrlFormat=e),class:"radio-card-group grid-2x2"},{default:(0,a.k6)(()=>[(0,a.bF)(z,{label:"originUrl",class:"radio-card"},{default:(0,a.k6)(()=>[(0,a.bF)(d,{icon:"link",class:"radio-icon"}),t[42]||(t[42]=(0,a.Lk)("span",null,"原始链接",-1))]),_:1}),(0,a.bF)(z,{label:"mdUrl",class:"radio-card"},{default:(0,a.k6)(()=>[(0,a.bF)(d,{icon:"code",class:"radio-icon"}),t[43]||(t[43]=(0,a.Lk)("span",null,"Markdown",-1))]),_:1}),(0,a.bF)(z,{label:"htmlUrl",class:"radio-card"},{default:(0,a.k6)(()=>[(0,a.bF)(d,{icon:"code-branch",class:"radio-icon"}),t[44]||(t[44]=(0,a.Lk)("span",null,"HTML",-1))]),_:1}),(0,a.bF)(z,{label:"bbUrl",class:"radio-card"},{default:(0,a.k6)(()=>[(0,a.bF)(d,{icon:"quote-right",class:"radio-icon"}),t[45]||(t[45]=(0,a.Lk)("span",null,"BBCode",-1))]),_:1}),(0,a.bF)(z,{label:"tgId",class:"radio-card"},{default:(0,a.k6)(()=>[(0,a.bF)(d,{icon:"paper-plane",class:"radio-icon"}),t[46]||(t[46]=(0,a.Lk)("span",null,"TG File ID",-1))]),_:1}),(0,a.bF)(z,{label:"s3Location",class:"radio-card"},{default:(0,a.k6)(()=>[(0,a.bF)(d,{icon:"cloud",class:"radio-icon"}),t[47]||(t[47]=(0,a.Lk)("span",null,"S3链接",-1))]),_:1})]),_:1},8,["modelValue"])])]),(0,a.Lk)("div",ri,[(0,a.Lk)("div",oi,[t[49]||(t[49]=(0,a.Lk)("span",{class:"section-title"},"自定义链接",-1)),(0,a.bF)(g,{content:"默认链接为https://your.domain/file/xxx.jpg
如果启用自定义链接格式,只保留xxx.jpg部分,其他部分请自行输入",placement:"top","raw-content":""},{default:(0,a.k6)(()=>[(0,a.bF)(d,{icon:"question-circle",class:"section-help-icon"})]),_:1})]),(0,a.Lk)("div",li,[(0,a.Lk)("div",ci,[t[50]||(t[50]=(0,a.Lk)("span",{class:"setting-label"},"启用自定义",-1)),(0,a.bF)(B,{modelValue:o.useCustomUrl,"onUpdate:modelValue":t[13]||(t[13]=e=>o.useCustomUrl=e),"active-value":"true","inactive-value":"false"},null,8,["modelValue"])]),"true"===o.useCustomUrl?((0,a.uX)(),(0,a.CE)("div",di,[t[51]||(t[51]=(0,a.Lk)("span",{class:"setting-label"},"自定义前缀",-1)),(0,a.bF)(h,{modelValue:o.customUrlPrefix,"onUpdate:modelValue":t[14]||(t[14]=e=>o.customUrlPrefix=e),placeholder:"请输入自定义链接前缀",class:"setting-input"},null,8,["modelValue"])])):(0,a.Q3)("",!0)])]),(0,a.Lk)("div",hi,[(0,a.bF)(E,{type:"primary",onClick:t[15]||(t[15]=e=>o.showUrlDialog=!1),class:"confirm-btn"},{default:(0,a.k6)(()=>[...t[52]||(t[52]=[(0,a.eW)("确定",-1)])]),_:1})])]),_:1},8,["modelValue","width"]),(0,a.bF)(P,{modelValue:o.showTagDialog,"onUpdate:modelValue":t[17]||(t[17]=e=>o.showTagDialog=e),fileId:o.currentTagFile,onTagsUpdated:l.handleTagsUpdated},null,8,["modelValue","fileId","onTagsUpdated"]),(0,a.bF)($,{modelValue:o.showBatchTagDialog,"onUpdate:modelValue":t[18]||(t[18]=e=>o.showBatchTagDialog=e),selectedFiles:o.selectedFiles,onTagsUpdated:l.handleBatchTagsUpdated},null,8,["modelValue","selectedFiles","onTagsUpdated"]),(0,a.bF)(O,{modelValue:o.showMobileActionModal,"onUpdate:modelValue":t[19]||(t[19]=e=>o.showMobileActionModal=e),title:o.mobileActionIsFolder?l.getFolderName(o.mobileActionFile?.name||""):o.mobileActionFile?.metadata?.FileName||l.getFileName(o.mobileActionFile?.name||""),isFolder:o.mobileActionIsFolder,onAction:l.handleMobileAction},null,8,["modelValue","title","isFolder","onAction"]),(0,a.bF)(R,{modelValue:o.showMobileDirectoryDrawer,"onUpdate:modelValue":t[20]||(t[20]=e=>o.showMobileDirectoryDrawer=e),currentPath:o.currentPath,onNavigate:l.navigateToFolder,onGoBack:l.handleGoBack},null,8,["modelValue","currentPath","onNavigate","onGoBack"])])}i(1148),i(116),i(7588),i(3579),i(7642),i(8004),i(3853),i(5876),i(2475),i(5024),i(1698),i(4603),i(7566),i(8721);var fi=i(8401),mi=i(4813),pi=i.n(mi);i(8335);class gi{constructor(){this.FILE_LIST_PATH="data/fileList.json"}getLocalFileList(){try{const e=localStorage.getItem(this.FILE_LIST_PATH);return e?JSON.parse(e):{files:[],directories:[]}}catch(e){return console.error("Error reading local file list:",e),{files:[],directories:[]}}}saveFileList(e){try{return localStorage.setItem(this.FILE_LIST_PATH,JSON.stringify(e)),!0}catch(t){return console.error("Error saving file list:",t),!1}}addFile(e){try{const t=this.getLocalFileList();return t.files.push(e),this.saveFileList(t)}catch(t){return console.error("Error adding file:",t),!1}}addFolder(e){try{const t=this.getLocalFileList();return!t.directories.includes(e)&&(t.directories.push(e),this.saveFileList(t))}catch(t){return console.error("Error adding folder:",t),!1}}moveFile(e,t,i=!1,a=""){try{let n=this.getLocalFileList();if(i){const t=n.directories.indexOf(e);-1!==t&&n.directories.splice(t,1)}else{const t=n.files.findIndex(t=>t.name===e);-1!==t&&n.files.splice(t,1)}if(t.startsWith(a)){const e=t.substring(a.length).split("/");if(e.length>1){const t=a+e[0];n.directories.includes(t)||n.directories.push(t)}}return this.saveFileList(n)}catch(n){return console.error("Error moving file:",n),!1}}removeFile(e){try{let t=this.getLocalFileList();return t.files=t.files.filter(t=>t.name!==e),this.saveFileList(t)}catch(t){return console.error("Error removing file:",t),!1}}removeFolder(e){try{let t=this.getLocalFileList();return t.files=t.files.filter(t=>!t.name.startsWith(e+"/")),t.directories=t.directories.filter(t=>t!==e),this.saveFileList(t)}catch(t){return console.error("Error removing folder:",t),!1}}getFilesInFolder(e){try{const t=this.getLocalFileList(),i=t.files.filter(t=>t.name.startsWith(e+"/")),a=t.directories.filter(t=>t.startsWith(e+"/"));return{files:i,directories:a}}catch(t){return console.error("Error getting files in folder:",t),{files:[],directories:[]}}}async refreshFileList(e,t="",i="",a=""){t=t.trim();try{let n=`/api/manage/list?count=60&dir=${e}&search=${encodeURIComponent(t)}`;i&&(n+=`&includeTags=${encodeURIComponent(i)}`),a&&(n+=`&excludeTags=${encodeURIComponent(a)}`);const s=await(0,K.A)(n,{method:"GET"}),r=await s.json();return r.isIndexedResponse||X.nk.warning("索引构建中,当前搜索和排序结果可能不准确,请稍后再试。"),this.saveFileList(r)}catch(n){return console.error("Error refreshing file list:",n),!1}}async loadMoreFiles(e,t="",i="",a="",n=60){t=t.trim();try{const s=this.getLocalFileList(),r=s.files.length;let o=`/api/manage/list?dir=${e}&start=${r}&count=${n}&search=${encodeURIComponent(t)}`;i&&(o+=`&includeTags=${encodeURIComponent(i)}`),a&&(o+=`&excludeTags=${encodeURIComponent(a)}`);const l=await(0,K.A)(o,{method:"GET"}),c=await l.json();return s.files.push(...c.files),this.saveFileList(s)}catch(s){return console.error("Error loading more files:",s),{files:[],directories:[]}}}}const bi=new gi;var vi=i(2388),ki={data(){return{Number:0,directFileCount:0,directFolderCount:0,showLogoutButton:!1,tableData:[],tempSearch:"",search:"",searchKeywords:"",searchIncludeTags:"",searchExcludeTags:"",isSearchMode:!1,currentPage:1,pageSize:15,selectedFiles:[],sortOption:"dateDesc",isUploading:!1,showdetailDialog:!1,detailFile:null,activeUrlTab:"originUrl",defaultUrlFormat:"originUrl",showUrlDialog:!1,useCustomUrl:"false",customUrlPrefix:"",loading:!1,currentPath:"",refreshLoading:!1,showTagDialog:!1,showBatchTagDialog:!1,currentTagFile:"",viewMode:"card",showMobileActionModal:!1,mobileActionFile:null,mobileActionIndex:-1,mobileActionIsFolder:!1,longPressTimer:null,showMobileDirectoryDrawer:!1,jumpPage:""}},components:{DashboardTabs:Pt.A,TagManagementDialog:me,BatchTagDialog:q,SkeletonLoader:Ut,FileCard:yt,FolderCard:At,FileListItem:et,FileDetailDialog:Ee,MobileActionSheet:_,MobileDirectoryDrawer:f},computed:{...(0,fi.L8)(["adminUrlSettings","userConfig"]),filteredTableData(){return this.tableData},totalPages(){return Math.ceil(this.filteredTableData.length/this.pageSize)||1},realTotalPages(){const e=this.directFolderCount+this.directFileCount;return Math.ceil(e/this.pageSize)||1},paginatedTableData(){const e=this.sortData(this.filteredTableData),t=(this.currentPage-1)*this.pageSize,i=t+this.pageSize;let a=e.slice(t,i);const n=a.filter(e=>this.isImage(e)).map(e=>this.getFileLink(e.name));return a.forEach(e=>{this.isImage(e)&&(e.previewSrcList=n.slice(n.indexOf(this.getFileLink(e.name))).concat(n.slice(0,n.indexOf(this.getFileLink(e.name)))))}),a.forEach(e=>{"TelegramNew"===e.metadata?.Channel?e.channelTag="TG":"CloudflareR2"===e.metadata?.Channel?e.channelTag="R2":"S3"===e.metadata?.Channel?e.channelTag="S3":"Discord"===e.metadata?.Channel?e.channelTag="DC":"HuggingFace"===e.metadata?.Channel?e.channelTag="HF":"External"===e.metadata?.Channel?e.channelTag="外链":e.channelTag="未知"}),a},sortIcon(){return"dateDesc"===this.sortOption?"sort-amount-down":"sort-alpha-up"},dialogWidth(){return window.innerWidth>768?"50%":"90%"},detailDialogWidth(){return window.innerWidth>768?"70%":"90%"},accessType(){return"White"===this.detailFile?.metadata?.ListType?"正常":"Block"===this.detailFile?.metadata?.ListType||"adult"===this.detailFile?.metadata?.Label?"受限":"正常"},allUrl(){return"External"===this.detailFile?.metadata?.Channel?{originUrl:`${this.detailFile?.metadata?.ExternalLink}`,mdUrl:`![${this.detailFile?.metadata?.FileName||this.detailFile?.name}](${this.detailFile?.metadata?.ExternalLink})`,htmlUrl:`${this.detailFile?.metadata?.FileName||this.detailFile?.name}`,bbUrl:`[img]${this.detailFile?.metadata?.ExternalLink}[/img]`,tgId:this.detailFile?.metadata?.TgFileId||"未知",S3Location:this.detailFile?.metadata?.S3Location||"未知",S3CdnFileUrl:this.detailFile?.metadata?.S3CdnFileUrl||"未知"}:{originUrl:`${this.rootUrl}${this.detailFile?.name}`,mdUrl:`![${this.detailFile?.metadata?.FileName||this.detailFile?.name}](${this.rootUrl}${this.detailFile?.name})`,htmlUrl:`${this.detailFile?.metadata?.FileName||this.detailFile?.name}`,bbUrl:`[img]${this.rootUrl}${this.detailFile?.name}[/img]`,tgId:this.detailFile?.metadata?.TgFileId||"未知",S3Location:this.detailFile?.metadata?.S3Location||"未知",S3CdnFileUrl:this.detailFile?.metadata?.S3CdnFileUrl||"未知"}},tableColumnNum(){return window.innerWidth>768?3:1},tablePreviewSpan(){return window.innerWidth>768?2:1},disableTooltip(){return window.innerWidth<768},selectPage(){return this.paginatedTableData.every(e=>e.selected)},selectedPageFiles(){return this.paginatedTableData.some(e=>e.selected)},selectPageIcon(){return this.selectPage?"check-square":this.selectedPageFiles?"minus-square":"square"},rootUrl(){return"true"===this.useCustomUrl?this.customUrlPrefix:this.userConfig?.urlPrefix||`${document.location.origin}/file/`},isSelectAll:{get(){return this.paginatedTableData.length>0&&this.paginatedTableData.every(e=>e.selected)},set(e){this.paginatedTableData.forEach(t=>t.selected=e)}},isIndeterminate(){const e=this.paginatedTableData.filter(e=>e.selected).length;return e>0&&ee.selected&&!this.selectedFiles.includes(e))),this.selectedFiles=this.selectedFiles.filter(e=>e.selected),this.selectedFiles=this.selectedFiles.filter(t=>e.includes(t))},deep:!0},sortOption(e){localStorage.setItem("sortOption",e)},defaultUrlFormat(e){localStorage.setItem("defaultUrlFormat",e)},showdetailDialog(e){e&&(this.activeUrlTab=this.defaultUrlFormat||"originUrl")},customUrlPrefix(e){this.$store.commit("setAdminUrlSettings",{key:"customUrlPrefix",value:e})},useCustomUrl(e){this.$store.commit("setAdminUrlSettings",{key:"useCustomUrl",value:e})},currentPath(e){this.tableData.forEach(e=>e.selected=!1)}},methods:{toggleViewMode(){this.viewMode="card"===this.viewMode?"list":"card",localStorage.setItem("viewMode",this.viewMode)},handleSelectAllPage(e){this.paginatedTableData.forEach(t=>t.selected=e)},handleTouchStart(e,t){this.longPressTimer=setTimeout(()=>{this.mobileActionFile=e,this.mobileActionIndex=t,this.mobileActionIsFolder=!1,this.showMobileActionModal=!0},500)},handleTouchEnd(){this.longPressTimer&&(clearTimeout(this.longPressTimer),this.longPressTimer=null)},handleFolderTouchStart(e,t){this.longPressTimer=setTimeout(()=>{this.mobileActionFile=e,this.mobileActionIndex=t,this.mobileActionIsFolder=!0,this.showMobileActionModal=!0},500)},handleMobileAction(e){const t=this.mobileActionFile,i=this.mobileActionIndex;if(this.showMobileActionModal=!1,t)switch(e){case"detail":this.openDetailDialog(i,t.name);break;case"copy":this.handleCopy(i,t.name);break;case"folderCopy":this.handleFolderCopy(t.name);break;case"download":this.handleDownload(t.name);break;case"move":this.handleMove(i,t.name);break;case"delete":this.handleDelete(i,t.name);break;case"tag":this.handleTagManagement(t.name);break}},handleGoBack(){const e=this.currentPath.split("/").filter(Boolean);if(e.length>0){e.pop();const t=e.join("/");this.navigateToFolder(t)}this.showMobileDirectoryDrawer=!1},getTagColor(e){const t=["linear-gradient(135deg, #667eea 0%, #764ba2 100%)","linear-gradient(135deg, #f093fb 0%, #f5576c 100%)","linear-gradient(135deg, #4facfe 0%, #00f2fe 100%)","linear-gradient(135deg, #43e97b 0%, #38f9d7 100%)","linear-gradient(135deg, #fa709a 0%, #fee140 100%)","linear-gradient(135deg, #a8edea 0%, #fed6e3 100%)"];return t[e%t.length]},handleVideoHover(e,t){const i=e.target;t?i.play().catch(()=>{}):(i.pause(),i.currentTime=0)},formatFileSize(e){if(!e||0===e)return"-";if(e=Number(e),isNaN(e))return"-";const t=["B","KB","MB","GB","TB"];let i=0;while(e>=1024&&i0?1:0)+" "+t[i]},handleSearch(){if(this.search=this.tempSearch,this.isSearchMode=""!==this.search.trim(),this.currentPage=1,this.search&&this.search.trim()){const e=[],t=[];let i=this.search;const a=/-#([\w\u4e00-\u9fa5\u3040-\u309f\u30a0-\u30ff\uac00-\ud7af\.\+\-]+)/g;i=i.replace(a,(e,i)=>(t.push(i.toLowerCase())," "));const n=/#([\w\u4e00-\u9fa5\u3040-\u309f\u30a0-\u30ff\uac00-\ud7af\.\+\-]+)/g;i=i.replace(n,(t,i)=>(e.push(i.toLowerCase())," ")),this.searchKeywords=i.replace(/\s+/g," ").trim(),this.searchIncludeTags=e.join(","),this.searchExcludeTags=t.join(","),console.log("Search keywords:",this.searchKeywords),console.log("Include tags:",this.searchIncludeTags),console.log("Exclude tags:",this.searchExcludeTags)}else this.searchKeywords="",this.searchIncludeTags="",this.searchExcludeTags="";this.refreshFileList()},handleDownload(e){const t=document.createElement("a");t.href=this.getFileLink(e),t.download=e,t.click()},openDetailDialog(e,t){this.detailFile=this.paginatedTableData[e],this.showdetailDialog=!0},handleTabClick(e){this.activeUrlTab=e.props.name},handleUrlClick(e){navigator.clipboard.writeText(e.target.value).then(()=>{this.$message({type:"success",message:"复制成功"})}).catch(()=>{this.$message({type:"error",message:"复制失败"})})},handleDetailDelete(e){this.$confirm("此操作将永久删除该文件, 是否继续?","提示",{confirmButtonText:"确定",cancelButtonText:"取消",type:"warning"}).then(()=>{(0,K.A)(`/api/manage/delete/${e}`,{method:"GET"}).then(t=>{if(!t.ok)return Promise.reject("请求失败");{const t=this.tableData.findIndex(t=>t.name===e);-1!==t&&this.tableData.splice(t,1)}}).then(()=>{this.updateStats(-1,!1),this.$message.success("删除成功"),this.showdetailDialog=!1}).catch(()=>this.$message.error("删除失败"))}).catch(()=>console.log("已取消删除"))},handleBlock(e){this.$confirm("此操作将把该文件加入黑名单, 是否继续?","提示",{confirmButtonText:"确定",cancelButtonText:"取消",type:"warning"}).then(()=>{(0,K.A)(`/api/manage/block/${e}`,{method:"GET"}).then(t=>{if(!t.ok)return Promise.reject("请求失败");{const t=this.tableData.findIndex(t=>t.name===e);-1!==t&&(this.tableData[t].metadata.ListType="Block")}}).then(()=>{this.$message.success("加入黑名单成功")}).catch(()=>this.$message.error("加入黑名单失败"))}).catch(()=>console.log("已取消加入黑名单"))},handleWhite(e){this.$confirm("此操作将把该文件加入白名单, 是否继续?","提示",{confirmButtonText:"确定",cancelButtonText:"取消",type:"warning"}).then(()=>{(0,K.A)(`/api/manage/white/${e}`,{method:"GET"}).then(t=>{if(!t.ok)return Promise.reject("请求失败");{const t=this.tableData.findIndex(t=>t.name===e);-1!==t&&(this.tableData[t].metadata.ListType="White")}}).then(()=>{this.$message.success("加入白名单成功")}).catch(()=>this.$message.error("加入白名单失败"))}).catch(()=>console.log("已取消加入白名单"))},handleDelete(e,t){const i=this.tableData.find(e=>e.name===t).isFolder;this.$confirm(`此操作将永久删除${i?"文件夹":"该文件"}, 是否继续?`,"提示",{confirmButtonText:"确定",cancelButtonText:"取消",type:"warning"}).then(()=>{(0,K.A)(`/api/manage/delete/${t}?folder=${i}`,{method:"GET"}).then(e=>{if(!e.ok)return Promise.reject("请求失败");{const e=this.tableData.findIndex(e=>e.name===t);-1!==e&&this.tableData.splice(e,1)}}).then(()=>{this.updateStats(-1,!1),bi.removeFile(t),this.$message.success("删除成功")}).catch(()=>this.$message.error("删除失败"))}).catch(()=>console.log("已取消删除"))},handleBatchDelete(){this.$confirm("此操作将永久删除选中的文件及文件夹, 是否继续?","提示",{confirmButtonText:"确定",cancelButtonText:"取消",type:"warning"}).then(()=>{const e=this.selectedFiles.map(e=>{const t=e.isFolder;return(0,K.A)(`/api/manage/delete/${e.name}?folder=${t}`,{method:"GET"})});Promise.all(e).then(e=>{let t=0;e.forEach((e,i)=>{if(e.ok){t++;const e=this.tableData.findIndex(e=>e.name===this.selectedFiles[i].name);-1!==e&&this.tableData.splice(e,1),bi.removeFile(this.selectedFiles[i].name)}}),this.selectedFiles=[],this.updateStats(-t,!1),this.$message.success("批量删除成功")}).catch(()=>this.$message.error("批量删除失败"))}).catch(()=>console.log("已取消批量删除"))},async handleBatchCopy(){const e=this.selectedFiles.filter(e=>!e.isFolder),t=this.selectedFiles.filter(e=>e.isFolder);let i=null;t.length>0&&(i=this.$loading({lock:!0,text:"正在获取文件列表..."}));try{let n=[...e];for(const e of t)try{const t=await(0,K.A)(`/api/manage/list?dir=${encodeURIComponent(e.name)}&recursive=true&count=-1`,{method:"GET"}),i=await t.json();i.files&&i.files.length>0&&(n=n.concat(i.files))}catch(a){console.error(`获取文件夹 ${e.name} 内容失败:`,a)}if(i&&i.close(),0===n.length)return void this.$message.warning("没有可复制的链接");const s=n.map(e=>this.generateFileLink(e.name,e.metadata)).filter(e=>e);if(0===s.length)return void this.$message.warning("没有可复制的链接");const r=s.join("\n");navigator.clipboard?(await navigator.clipboard.writeText(r),this.$message.success(`批量复制 ${s.length} 个链接成功`)):this.copyToClipboardFallback(r)}catch(a){i&&i.close(),console.error("批量复制链接失败:",a),this.$message.error("批量复制链接失败,请重试")}},copyToClipboardFallback(e){const t=document.createElement("textarea");document.body.appendChild(t),t.style.position="fixed",t.style.clip="rect(0 0 0 0)",t.style.top="10px",t.value=e,t.select(),document.execCommand("copy"),document.body.removeChild(t),this.$message.success("批量复制链接成功")},handleCopy(e,t){let i="";if("External"===this.paginatedTableData[e].metadata?.Channel)switch(this.defaultUrlFormat){case"originUrl":i=this.paginatedTableData[e].metadata?.ExternalLink;break;case"mdUrl":i=`![${this.paginatedTableData[e].metadata?.FileName||t}](${this.paginatedTableData[e].metadata?.ExternalLink})`;break;case"htmlUrl":i=`${this.paginatedTableData[e].metadata?.FileName||t}`;break;case"bbUrl":i=`[img]${this.paginatedTableData[e].metadata?.ExternalLink}[/img]`;break;case"tgId":i=this.paginatedTableData[e].metadata?.TgFileId||"none";break;case"s3Location":i=this.paginatedTableData[e].metadata?.S3Location||"none";break}else switch(this.defaultUrlFormat){case"originUrl":i=`${this.rootUrl}${t}`;break;case"mdUrl":i=`![${this.paginatedTableData[e].metadata?.FileName||t}](${this.rootUrl}${t})`;break;case"htmlUrl":i=`${this.paginatedTableData[e].metadata?.FileName||t}`;break;case"bbUrl":i=`[img]${this.rootUrl}${t}[/img]`;break;case"tgId":i=this.paginatedTableData[e].metadata?.TgFileId||"none";break;case"s3Location":i=this.paginatedTableData[e].metadata?.S3Location||"none";break}navigator.clipboard?navigator.clipboard.writeText(i).then(()=>this.$message.success("复制文件链接成功")):this.copyToClipboardFallback(i)},async loadMoreData(){this.loading=!0;try{await bi.loadMoreFiles(this.currentPath,this.searchKeywords,this.searchIncludeTags,this.searchExcludeTags),await this.fetchFileList()}catch(e){this.$message.error("加载更多文件失败,请检查网络连接")}finally{this.loading=!1}},updateStats(e,t=!1){t?this.Number=e:this.Number+=e},sort(e){this.sortOption=e},sortData(e){const t=e.filter(e=>e.isFolder),i=e.filter(e=>!e.isFolder);return"dateDesc"===this.sortOption?(t.sort((e,t)=>new Date(t.metadata?.TimeStamp)-new Date(e.metadata?.TimeStamp)),i.sort((e,t)=>new Date(t.metadata?.TimeStamp)-new Date(e.metadata?.TimeStamp))):(t.sort((e,t)=>e.name.localeCompare(t.name)),i.sort((e,t)=>e.name.localeCompare(t.name))),t.concat(i)},handleVideoClick(e){const t=e.target;t.requestFullscreen?t.requestFullscreen():t.webkitRequestFullscreen?t.webkitRequestFullscreen():t.mozRequestFullScreen?t.mozRequestFullScreen():t.msRequestFullscreen&&t.msRequestFullscreen()},handleLogout(){this.$store.commit("setCredentials",null),this.$router.push("/adminLogin")},handleSelectPage(){this.selectPage?this.paginatedTableData.forEach(e=>e.selected=!1):this.paginatedTableData.forEach(e=>e.selected=!0)},handleBatchAction(e){"copy"===e?this.handleBatchCopy():"delete"===e?this.handleBatchDelete():"download"===e?this.handleBatchDownload():"move"===e?this.handleBatchMove():"tagManagement"===e?this.handleBatchTagManagement():"ban"===e?this.handleBatchBlock():"white"===e&&this.handleBatchWhite()},handleMove(e,t){this.$prompt("请输入新的目录","移动文件",{confirmButtonText:"确定",cancelButtonText:"取消",inputValue:"/",beforeClose:(e,t,i)=>{if("confirm"===e){const e=t.inputValue,a=(0,vi.G)(e);if(!a.valid)return void this.$message.error(a.error);i()}else i()}}).then(({value:e})=>{const i=e.replace(/^\/+/,"")+(e.endsWith("/")||""===e?"":"/"),a=this.tableData.find(e=>e.name===t).isFolder;i!==this.currentPath?(0,K.A)(`/api/manage/move/${t}?folder=${a}&dist=${i}`,{method:"GET"}).then(e=>{if(!e.ok)return Promise.reject("请求失败");{const e=this.tableData.findIndex(e=>e.name===t);if(-1!==e){const n=i+t.split("/").pop();bi.moveFile(t,n,a,this.currentPath),this.tableData.splice(e,1),this.$nextTick(()=>{const e=[...this.tableData];this.tableData=[],this.$nextTick(()=>{this.tableData=e})})}this.updateStats(-1,!1),this.$message.success("移动成功")}}).then(()=>{this.refreshLocalFileList()}).catch(()=>this.$message.error("移动失败")):this.$message.warning("目标文件夹不能是当前文件夹")}).catch(()=>console.log("已取消移动文件"))},handleBatchMove(){this.$prompt("请输入新的目录","移动文件",{confirmButtonText:"确定",cancelButtonText:"取消",inputValue:"/",beforeClose:(e,t,i)=>{if("confirm"===e){const e=t.inputValue,a=(0,vi.G)(e);if(!a.valid)return void this.$message.error(a.error);i()}else i()}}).then(({value:e})=>{const t=e.replace(/^\/+/,"")+(e.endsWith("/")||""===e?"":"/");if(t===this.currentPath)return void this.$message.warning("目标文件夹不能是当前文件夹");const i=this.selectedFiles.map(e=>{const i=e.isFolder;return(0,K.A)(`/api/manage/move/${e.name}?folder=${i}&dist=${t}`,{method:"GET"})});Promise.all(i).then(e=>{let i=0;e.forEach((e,a)=>{if(e.ok){i++;const e=this.selectedFiles[a];e.selected=!1;const n=this.tableData.findIndex(t=>t.name===e.name);if(-1!==n){const i=t+e.name.split("/").pop();bi.moveFile(e.name,i,e.isFolder,this.currentPath),this.tableData.splice(n,1)}}}),this.$nextTick(()=>{const e=[...this.tableData];this.tableData=[],this.$nextTick(()=>{this.tableData=e})}),this.updateStats(-i,!1),this.$message.success("移动成功")}).then(()=>{this.refreshLocalFileList()}).catch(()=>this.$message.error("移动失败"))}).catch(()=>console.log("已取消移动文件"))},handleBatchBlock(){this.$confirm("此操作将把选中的文件加入黑名单, 是否继续?","提示",{confirmButtonText:"确定",cancelButtonText:"取消",type:"warning"}).then(()=>{const e=this.selectedFiles.map(e=>e.isFolder?Promise.resolve({ok:!1}):(0,K.A)(`/api/manage/block/${e.name}`,{method:"GET"}));Promise.all(e).then(e=>{e.forEach((e,t)=>{if(e.ok){const e=this.tableData.findIndex(e=>e.name===this.selectedFiles[t].name);-1!==e&&(this.tableData[e].metadata.ListType="Block")}}),this.$message.success("批量加入黑名单成功")}).catch(()=>this.$message.error("批量加入黑名单失败"))}).catch(()=>console.log("已取消批量加入黑名单"))},handleBatchWhite(){this.$confirm("此操作将把选中的文件加入白名单, 是否继续?","提示",{confirmButtonText:"确定",cancelButtonText:"取消",type:"warning"}).then(()=>{const e=this.selectedFiles.map(e=>e.isFolder?Promise.resolve({ok:!1}):(0,K.A)(`/api/manage/white/${e.name}`,{method:"GET"}));Promise.all(e).then(e=>{e.forEach((e,t)=>{if(e.ok){const e=this.tableData.findIndex(e=>e.name===this.selectedFiles[t].name);-1!==e&&(this.tableData[e].metadata.ListType="White")}}),this.$message.success("批量加入白名单成功")}).catch(()=>this.$message.error("批量加入白名单失败"))}).catch(()=>console.log("已取消批量加入白名单"))},handleBatchDownload(){const e=new(pi()),t=e.folder("files"),i={},a=this.selectedFiles.map(async e=>{if(e.isFolder)return;const a=await fetch(this.getFileLink(e.name)),n=await a.blob();let s=e.metadata?.FileName||e.name;if(i[s]){const t=s.substring(s.lastIndexOf(".")),a=s.substring(0,s.lastIndexOf("."));s=`${a}(${i[s]})${t}`,i[e.name]++}else i[s]=1;t.file(s,n)});Promise.all(a).then(()=>e.generateAsync({type:"blob"})).then(e=>{const t=document.createElement("a");t.href=URL.createObjectURL(e),t.download="files.zip",t.click()})},isVideo(e){if(this.isAudio(e))return!1;let t=e.metadata?.FileType?.includes("video");if(!t){const i=["mp4","webm","ogg","avi","mov","flv","wmv","mkv","rmvb","3gp","mpg","mpeg","m4v","f4v","rm","asf","dat","ts","vob","swf","divx","xvid","m2ts","mts","m2v","3g2","3gp2","3gpp","3gpp2","mpe","m1v","mpv","mpv2","mp2v","m2t","m2ts","m2v","m4v"],a=e.name.substring(e.name.lastIndexOf(".")+1).toLowerCase();t=i.includes(a)}return t},isAudio(e){let t=e.metadata?.FileType?.includes("audio");if(!t){const i=["mp3","wav","flac","aac","ogg","wma","m4a","ape","aiff","alac","opus","mid","midi","m4b","m4p","m4r","amr","au","ra","ram"],a=e.name.substring(e.name.lastIndexOf(".")+1).toLowerCase();t=i.includes(a)}return t},isImage(e){let t=e.metadata?.FileType?.includes("image");if(!t){const i=["jpg","jpeg","png","gif","bmp","webp","svg","ico","tiff","tif","psd","ai","eps","raw","cr2","nef","orf","sr2","dng","arw","rw2","raf","pef","x3f","srf","erf","mrw","nrw","kdc","dcr","mef","mos","crw","raf","rwl","srw","3fr","fff","iiq","qtk","bay","k25","kdc","dcs","drf","dng","erf","kdc","mdc","mef","mos","mrw","nef","nrw","orf","pef","ptx","pxn","r3d","raf","raw","rwl","rw2","rwz","sr2","srf","x3f"],a=e.name.substring(e.name.lastIndexOf(".")+1).toLowerCase();t=i.includes(a)}return t},getFileLink(e){const t=`/file/${e}?from=admin`;return t},handlePageChange(e){this.currentPage=e,this.currentPage===Math.ceil(this.tableData.length/this.pageSize)&&this.loadMoreData()},handleJumpPage(){const e=parseInt(this.jumpPage);isNaN(e)||e<1?this.$message.warning("请输入有效的页码"):e>this.realTotalPages?this.$message.warning(`页码不能超过 ${this.realTotalPages}`):(e>this.totalPages?(this.$message.info("正在加载数据,请稍候..."),this.loadMoreDataUntilPage(e)):this.currentPage=e,this.jumpPage="")},async loadMoreDataUntilPage(e){this.loading=!0;try{const t=e*this.pageSize,i=this.filteredTableData.filter(e=>e.isFolder).length,a=this.filteredTableData.filter(e=>!e.isFolder).length,n=Math.max(0,t-i-a);n>0&&(await bi.loadMoreFiles(this.currentPath,this.searchKeywords,this.searchIncludeTags,this.searchExcludeTags,n),await this.fetchFileList()),this.currentPage=Math.min(e,this.totalPages)}catch(t){this.$message.error("加载数据失败,请检查网络连接")}finally{this.loading=!1}},isFolder(e){if(e.isFolder)return!0;let t=e.name;if(t.startsWith("http")&&(t=t.split("/file/")[1]),t&&t.includes("/")){const e=this.currentPath?t.substring(this.currentPath.length):t;return""===this.currentPath?!t.split("/")[0].includes("."):e.includes("/")}return!1},getFolderName(e){let t="";if(e&&e.includes("/")){const i=e.split("/");if(""===this.currentPath)t=i[0];else{const i=e.substring(this.currentPath.length);t=i.split("/")[0]}}else t=e;const i=20;if(t.length>i){const e=Math.floor((i-3)/2),a=Math.ceil((i-3)/2);return`${t.substring(0,e)}...${t.substring(t.length-a)}`}return t},getFileName(e){let t=e.split("/").pop();const i=20;if(t.length>i){const e=Math.floor((i-3)/2),a=Math.ceil((i-3)/2);return`${t.substring(0,e)}...${t.substring(t.length-a)}`}return t},getFileNameStart(e){if(!e)return"";if(e.length<=30)return e;const t=e.lastIndexOf(".");if(t>0){const i=e.substring(0,t),a=Math.min(i.length,Math.floor(.6*e.length));return i.substring(0,a)}return e.substring(0,Math.floor(.6*e.length))},getFileNameEnd(e){if(!e)return"";if(e.length<=30)return"";const t=e.lastIndexOf(".");if(t>0){const i=e.substring(t),a=e.substring(0,t),n=Math.min(8,Math.floor(.2*a.length));return"…"+a.substring(a.length-n)+i}const i=Math.min(10,Math.floor(.3*e.length));return"…"+e.substring(e.length-i)},enterFolder(e){this.currentPath=e+(e.endsWith("/")?"":"/"),this.refreshFileList()},navigateToFolder(e){this.currentPath=e?e+(e.endsWith("/")?"":"/"):"",this.refreshFileList()},async fetchFileList(){this.loading=!0;try{const e=bi.getLocalFileList(),t=new Set(e.directories||[]),i=e.files||[],a=Array.from(t).map(e=>({name:e,isFolder:!0,selected:!1,metadata:{FileName:e.split("/").pop()}})),n=i.map(e=>({name:e.name,isFolder:!1,selected:!1,metadata:e.metadata}));this.tableData=[...a,...n],this.updateStats(e.totalCount,!0),this.directFileCount=e.directFileCount||0,this.directFolderCount=e.directFolderCount||0}catch(e){console.error("Error fetching file list:",e),this.$message.error("获取文件列表失败")}finally{this.loading=!1}},async refreshFileList(){this.refreshLoading=!0,this.loading=!0;try{const e=await bi.refreshFileList(this.currentPath,this.searchKeywords,this.searchIncludeTags,this.searchExcludeTags);if(!e)throw new Error("Refresh failed");await this.fetchFileList()}catch(e){console.error("Error refreshing file list:",e),this.$message.error("刷新失败,请重试")}finally{this.refreshLoading=!1,this.loading=!1}},async refreshLocalFileList(){this.refreshLoading=!0,this.loading=!0;try{await this.fetchFileList()}catch(e){console.error("Error refreshing local file list:",e),this.$message.error("刷新失败,请重试")}finally{this.refreshLoading=!1,this.loading=!1}},handleTagManagement(e){this.currentTagFile=e,this.showTagDialog=!0},handleBatchTagManagement(){0!==this.selectedFiles.length?this.showBatchTagDialog=!0:this.$message.warning("请先选择文件")},async handleTagsUpdated(e){const t=this.tableData.findIndex(e=>e.name===this.currentTagFile);-1!==t&&(this.tableData[t].metadata||(this.tableData[t].metadata={}),this.tableData[t].metadata.Tags=e,this.showdetailDialog&&this.detailFile?.name===this.currentTagFile&&(this.detailFile.metadata||(this.detailFile.metadata={}),this.detailFile.metadata.Tags=e))},async handleBatchTagsUpdated(){await this.refreshLocalFileList()},generateFileLink(e,t){const i="External"===t?.Channel,a=i?t?.ExternalLink:`${this.rootUrl}${e}`,n=t?.FileName||e;switch(this.defaultUrlFormat){case"originUrl":return a;case"mdUrl":return`![${n}](${a})`;case"htmlUrl":return`${n}`;case"bbUrl":return`[img]${a}[/img]`;case"tgId":return t?.TgFileId||"";case"s3Location":return t?.S3Location||"";default:return a}},async handleFolderCopy(e){const t=this.$loading({lock:!0,text:"正在获取文件列表..."});try{const i=await(0,K.A)(`/api/manage/list?dir=${encodeURIComponent(e)}&recursive=true&count=-1`,{method:"GET"}),a=await i.json();if(t.close(),!a.files||0===a.files.length)return void this.$message.warning("文件夹为空,没有可复制的链接");const n=a.files.map(e=>this.generateFileLink(e.name,e.metadata)).filter(e=>e);if(0===n.length)return void this.$message.warning("没有可复制的链接");const s=n.join("\n");navigator.clipboard?(await navigator.clipboard.writeText(s),this.$message.success(`已复制 ${n.length} 个文件链接`)):(this.copyToClipboardFallback(s),this.$message.success(`已复制 ${n.length} 个文件链接`))}catch(i){t.close(),console.error("复制文件夹链接失败:",i),this.$message.error("复制文件夹链接失败,请重试")}}},mounted(){this.loading=!0,(0,K.A)("/api/manage/check",{method:"GET"}).then(e=>e.text()).then(e=>{if("true"==e)return this.showLogoutButton=!0,!0;if("Not using basic auth."==e)return!0;throw new Error("Unauthorized")}).then(()=>this.refreshFileList()).catch(e=>{"Unauthorized"!==e.message&&this.$message.error("同步数据时出错,请检查网络连接")}).finally(()=>{this.loading=!1}),this.customUrlPrefix=this.adminUrlSettings.customUrlPrefix,this.useCustomUrl=this.adminUrlSettings.useCustomUrl}};const _i=(0,h.A)(ki,[["render",ui],["__scopeId","data-v-6028d7b0"]]);var yi=_i},4396:function(e,t,i){"use strict";i(5331),i(4885)},4813:function(e,t,i){i(4114),i(6573),i(8100),i(7936),i(8111),i(2489),i(7588),i(9577),i(1549),i(9797),i(9631),i(5623),i(9848),function(t){e.exports=t()}(function(){return function e(t,i,a){function n(r,o){if(!i[r]){if(!t[r]){var l=void 0;if(!o&&l)return require(r,!0);if(s)return s(r,!0);var c=new Error("Cannot find module '"+r+"'");throw c.code="MODULE_NOT_FOUND",c}var d=i[r]={exports:{}};t[r][0].call(d.exports,function(e){var i=t[r][1][e];return n(i||e)},d,d.exports,e,t,i,a)}return i[r].exports}for(var s=void 0,r=0;r>2,o=(3&t)<<4|i>>4,l=1>6:64,c=2>4,i=(15&r)<<4|(o=s.indexOf(e.charAt(c++)))>>2,a=(3&o)<<6|(l=s.indexOf(e.charAt(c++))),u[d++]=t,64!==o&&(u[d++]=i),64!==l&&(u[d++]=a);return u}},{"./support":30,"./utils":32}],2:[function(e,t,i){"use strict";var a=e("./external"),n=e("./stream/DataWorker"),s=e("./stream/Crc32Probe"),r=e("./stream/DataLengthProbe");function o(e,t,i,a,n){this.compressedSize=e,this.uncompressedSize=t,this.crc32=i,this.compression=a,this.compressedContent=n}o.prototype={getContentWorker:function(){var e=new n(a.Promise.resolve(this.compressedContent)).pipe(this.compression.uncompressWorker()).pipe(new r("data_length")),t=this;return e.on("end",function(){if(this.streamInfo.data_length!==t.uncompressedSize)throw new Error("Bug : uncompressed data size mismatch")}),e},getCompressedWorker:function(){return new n(a.Promise.resolve(this.compressedContent)).withStreamInfo("compressedSize",this.compressedSize).withStreamInfo("uncompressedSize",this.uncompressedSize).withStreamInfo("crc32",this.crc32).withStreamInfo("compression",this.compression)}},o.createWorkerFrom=function(e,t,i){return e.pipe(new s).pipe(new r("uncompressedSize")).pipe(t.compressWorker(i)).pipe(new r("compressedSize")).withStreamInfo("compression",t)},t.exports=o},{"./external":6,"./stream/Crc32Probe":25,"./stream/DataLengthProbe":26,"./stream/DataWorker":27}],3:[function(e,t,i){"use strict";var a=e("./stream/GenericWorker");i.STORE={magic:"\0\0",compressWorker:function(){return new a("STORE compression")},uncompressWorker:function(){return new a("STORE decompression")}},i.DEFLATE=e("./flate")},{"./flate":7,"./stream/GenericWorker":28}],4:[function(e,t,i){"use strict";var a=e("./utils"),n=function(){for(var e,t=[],i=0;i<256;i++){e=i;for(var a=0;a<8;a++)e=1&e?3988292384^e>>>1:e>>>1;t[i]=e}return t}();t.exports=function(e,t){return void 0!==e&&e.length?"string"!==a.getTypeOf(e)?function(e,t,i,a){var s=n,r=a+i;e^=-1;for(var o=a;o>>8^s[255&(e^t[o])];return-1^e}(0|t,e,e.length,0):function(e,t,i,a){var s=n,r=a+i;e^=-1;for(var o=a;o>>8^s[255&(e^t.charCodeAt(o))];return-1^e}(0|t,e,e.length,0):0}},{"./utils":32}],5:[function(e,t,i){"use strict";i.base64=!1,i.binary=!1,i.dir=!1,i.createFolders=!0,i.date=null,i.compression=null,i.compressionOptions=null,i.comment=null,i.unixPermissions=null,i.dosPermissions=null},{}],6:[function(e,t,i){"use strict";var a=null;a="undefined"!=typeof Promise?Promise:e("lie"),t.exports={Promise:a}},{lie:37}],7:[function(e,t,i){"use strict";var a="undefined"!=typeof Uint8Array&&"undefined"!=typeof Uint16Array&&"undefined"!=typeof Uint32Array,n=e("pako"),s=e("./utils"),r=e("./stream/GenericWorker"),o=a?"uint8array":"array";function l(e,t){r.call(this,"FlateWorker/"+e),this._pako=null,this._pakoAction=e,this._pakoOptions=t,this.meta={}}i.magic="\b\0",s.inherits(l,r),l.prototype.processChunk=function(e){this.meta=e.meta,null===this._pako&&this._createPako(),this._pako.push(s.transformTo(o,e.data),!1)},l.prototype.flush=function(){r.prototype.flush.call(this),null===this._pako&&this._createPako(),this._pako.push([],!0)},l.prototype.cleanUp=function(){r.prototype.cleanUp.call(this),this._pako=null},l.prototype._createPako=function(){this._pako=new n[this._pakoAction]({raw:!0,level:this._pakoOptions.level||-1});var e=this;this._pako.onData=function(t){e.push({data:t,meta:e.meta})}},i.compressWorker=function(e){return new l("Deflate",e)},i.uncompressWorker=function(){return new l("Inflate",{})}},{"./stream/GenericWorker":28,"./utils":32,pako:38}],8:[function(e,t,i){"use strict";function a(e,t){var i,a="";for(i=0;i>>=8;return a}function n(e,t,i,n,r,d){var h,u,f=e.file,m=e.compression,p=d!==o.utf8encode,g=s.transformTo("string",d(f.name)),b=s.transformTo("string",o.utf8encode(f.name)),v=f.comment,k=s.transformTo("string",d(v)),_=s.transformTo("string",o.utf8encode(v)),y=b.length!==f.name.length,w=_.length!==v.length,F="",C="",T="",x=f.dir,S=f.date,L={crc32:0,compressedSize:0,uncompressedSize:0};t&&!i||(L.crc32=e.crc32,L.compressedSize=e.compressedSize,L.uncompressedSize=e.uncompressedSize);var E=0;t&&(E|=8),p||!y&&!w||(E|=2048);var A=0,I=0;x&&(A|=16),"UNIX"===r?(I=798,A|=function(e,t){var i=e;return e||(i=t?16893:33204),(65535&i)<<16}(f.unixPermissions,x)):(I=20,A|=function(e){return 63&(e||0)}(f.dosPermissions)),h=S.getUTCHours(),h<<=6,h|=S.getUTCMinutes(),h<<=5,h|=S.getUTCSeconds()/2,u=S.getUTCFullYear()-1980,u<<=4,u|=S.getUTCMonth()+1,u<<=5,u|=S.getUTCDate(),y&&(C=a(1,1)+a(l(g),4)+b,F+="up"+a(C.length,2)+C),w&&(T=a(1,1)+a(l(k),4)+_,F+="uc"+a(T.length,2)+T);var D="";return D+="\n\0",D+=a(E,2),D+=m.magic,D+=a(h,2),D+=a(u,2),D+=a(L.crc32,4),D+=a(L.compressedSize,4),D+=a(L.uncompressedSize,4),D+=a(g.length,2),D+=a(F.length,2),{fileRecord:c.LOCAL_FILE_HEADER+D+g+F,dirRecord:c.CENTRAL_FILE_HEADER+a(I,2)+D+a(k.length,2)+"\0\0\0\0"+a(A,4)+a(n,4)+g+F+k}}var s=e("../utils"),r=e("../stream/GenericWorker"),o=e("../utf8"),l=e("../crc32"),c=e("../signature");function d(e,t,i,a){r.call(this,"ZipFileWorker"),this.bytesWritten=0,this.zipComment=t,this.zipPlatform=i,this.encodeFileName=a,this.streamFiles=e,this.accumulate=!1,this.contentBuffer=[],this.dirRecords=[],this.currentSourceOffset=0,this.entriesCount=0,this.currentFile=null,this._sources=[]}s.inherits(d,r),d.prototype.push=function(e){var t=e.meta.percent||0,i=this.entriesCount,a=this._sources.length;this.accumulate?this.contentBuffer.push(e):(this.bytesWritten+=e.data.length,r.prototype.push.call(this,{data:e.data,meta:{currentFile:this.currentFile,percent:i?(t+100*(i-a-1))/i:100}}))},d.prototype.openedSource=function(e){this.currentSourceOffset=this.bytesWritten,this.currentFile=e.file.name;var t=this.streamFiles&&!e.file.dir;if(t){var i=n(e,t,!1,this.currentSourceOffset,this.zipPlatform,this.encodeFileName);this.push({data:i.fileRecord,meta:{percent:0}})}else this.accumulate=!0},d.prototype.closedSource=function(e){this.accumulate=!1;var t=this.streamFiles&&!e.file.dir,i=n(e,t,!0,this.currentSourceOffset,this.zipPlatform,this.encodeFileName);if(this.dirRecords.push(i.dirRecord),t)this.push({data:function(e){return c.DATA_DESCRIPTOR+a(e.crc32,4)+a(e.compressedSize,4)+a(e.uncompressedSize,4)}(e),meta:{percent:100}});else for(this.push({data:i.fileRecord,meta:{percent:0}});this.contentBuffer.length;)this.push(this.contentBuffer.shift());this.currentFile=null},d.prototype.flush=function(){for(var e=this.bytesWritten,t=0;t=this.index;t--)i=(i<<8)+this.byteAt(t);return this.index+=e,i},readString:function(e){return a.transformTo("string",this.readData(e))},readData:function(){},lastIndexOfSignature:function(){},readAndCheckSignature:function(){},readDate:function(){var e=this.readInt(4);return new Date(Date.UTC(1980+(e>>25&127),(e>>21&15)-1,e>>16&31,e>>11&31,e>>5&63,(31&e)<<1))}},t.exports=n},{"../utils":32}],19:[function(e,t,i){"use strict";var a=e("./Uint8ArrayReader");function n(e){a.call(this,e)}e("../utils").inherits(n,a),n.prototype.readData=function(e){this.checkOffset(e);var t=this.data.slice(this.zero+this.index,this.zero+this.index+e);return this.index+=e,t},t.exports=n},{"../utils":32,"./Uint8ArrayReader":21}],20:[function(e,t,i){"use strict";var a=e("./DataReader");function n(e){a.call(this,e)}e("../utils").inherits(n,a),n.prototype.byteAt=function(e){return this.data.charCodeAt(this.zero+e)},n.prototype.lastIndexOfSignature=function(e){return this.data.lastIndexOf(e)-this.zero},n.prototype.readAndCheckSignature=function(e){return e===this.readData(4)},n.prototype.readData=function(e){this.checkOffset(e);var t=this.data.slice(this.zero+this.index,this.zero+this.index+e);return this.index+=e,t},t.exports=n},{"../utils":32,"./DataReader":18}],21:[function(e,t,i){"use strict";var a=e("./ArrayReader");function n(e){a.call(this,e)}e("../utils").inherits(n,a),n.prototype.readData=function(e){if(this.checkOffset(e),0===e)return new Uint8Array(0);var t=this.data.subarray(this.zero+this.index,this.zero+this.index+e);return this.index+=e,t},t.exports=n},{"../utils":32,"./ArrayReader":17}],22:[function(e,t,i){"use strict";var a=e("../utils"),n=e("../support"),s=e("./ArrayReader"),r=e("./StringReader"),o=e("./NodeBufferReader"),l=e("./Uint8ArrayReader");t.exports=function(e){var t=a.getTypeOf(e);return a.checkSupport(t),"string"!==t||n.uint8array?"nodebuffer"===t?new o(e):n.uint8array?new l(a.transformTo("uint8array",e)):new s(a.transformTo("array",e)):new r(e)}},{"../support":30,"../utils":32,"./ArrayReader":17,"./NodeBufferReader":19,"./StringReader":20,"./Uint8ArrayReader":21}],23:[function(e,t,i){"use strict";i.LOCAL_FILE_HEADER="PK",i.CENTRAL_FILE_HEADER="PK",i.CENTRAL_DIRECTORY_END="PK",i.ZIP64_CENTRAL_DIRECTORY_LOCATOR="PK",i.ZIP64_CENTRAL_DIRECTORY_END="PK",i.DATA_DESCRIPTOR="PK\b"},{}],24:[function(e,t,i){"use strict";var a=e("./GenericWorker"),n=e("../utils");function s(e){a.call(this,"ConvertWorker to "+e),this.destType=e}n.inherits(s,a),s.prototype.processChunk=function(e){this.push({data:n.transformTo(this.destType,e.data),meta:e.meta})},t.exports=s},{"../utils":32,"./GenericWorker":28}],25:[function(e,t,i){"use strict";var a=e("./GenericWorker"),n=e("../crc32");function s(){a.call(this,"Crc32Probe"),this.withStreamInfo("crc32",0)}e("../utils").inherits(s,a),s.prototype.processChunk=function(e){this.streamInfo.crc32=n(e.data,this.streamInfo.crc32||0),this.push(e)},t.exports=s},{"../crc32":4,"../utils":32,"./GenericWorker":28}],26:[function(e,t,i){"use strict";var a=e("../utils"),n=e("./GenericWorker");function s(e){n.call(this,"DataLengthProbe for "+e),this.propName=e,this.withStreamInfo(e,0)}a.inherits(s,n),s.prototype.processChunk=function(e){if(e){var t=this.streamInfo[this.propName]||0;this.streamInfo[this.propName]=t+e.data.length}n.prototype.processChunk.call(this,e)},t.exports=s},{"../utils":32,"./GenericWorker":28}],27:[function(e,t,i){"use strict";var a=e("../utils"),n=e("./GenericWorker");function s(e){n.call(this,"DataWorker");var t=this;this.dataIsReady=!1,this.index=0,this.max=0,this.data=null,this.type="",this._tickScheduled=!1,e.then(function(e){t.dataIsReady=!0,t.data=e,t.max=e&&e.length||0,t.type=a.getTypeOf(e),t.isPaused||t._tickAndRepeat()},function(e){t.error(e)})}a.inherits(s,n),s.prototype.cleanUp=function(){n.prototype.cleanUp.call(this),this.data=null},s.prototype.resume=function(){return!!n.prototype.resume.call(this)&&(!this._tickScheduled&&this.dataIsReady&&(this._tickScheduled=!0,a.delay(this._tickAndRepeat,[],this)),!0)},s.prototype._tickAndRepeat=function(){this._tickScheduled=!1,this.isPaused||this.isFinished||(this._tick(),this.isFinished||(a.delay(this._tickAndRepeat,[],this),this._tickScheduled=!0))},s.prototype._tick=function(){if(this.isPaused||this.isFinished)return!1;var e=null,t=Math.min(this.max,this.index+16384);if(this.index>=this.max)return this.end();switch(this.type){case"string":e=this.data.substring(this.index,t);break;case"uint8array":e=this.data.subarray(this.index,t);break;case"array":case"nodebuffer":e=this.data.slice(this.index,t)}return this.index=t,this.push({data:e,meta:{percent:this.max?this.index/this.max*100:0}})},t.exports=s},{"../utils":32,"./GenericWorker":28}],28:[function(e,t,i){"use strict";function a(e){this.name=e||"default",this.streamInfo={},this.generatedError=null,this.extraStreamInfo={},this.isPaused=!0,this.isFinished=!1,this.isLocked=!1,this._listeners={data:[],end:[],error:[]},this.previous=null}a.prototype={push:function(e){this.emit("data",e)},end:function(){if(this.isFinished)return!1;this.flush();try{this.emit("end"),this.cleanUp(),this.isFinished=!0}catch(e){this.emit("error",e)}return!0},error:function(e){return!this.isFinished&&(this.isPaused?this.generatedError=e:(this.isFinished=!0,this.emit("error",e),this.previous&&this.previous.error(e),this.cleanUp()),!0)},on:function(e,t){return this._listeners[e].push(t),this},cleanUp:function(){this.streamInfo=this.generatedError=this.extraStreamInfo=null,this._listeners=[]},emit:function(e,t){if(this._listeners[e])for(var i=0;i "+e:e}},t.exports=a},{}],29:[function(e,t,i){"use strict";var a=e("../utils"),n=e("./ConvertWorker"),s=e("./GenericWorker"),r=e("../base64"),o=e("../support"),l=e("../external"),c=null;if(o.nodestream)try{c=e("../nodejs/NodejsStreamOutputAdapter")}catch(e){}function d(e,t){return new l.Promise(function(i,n){var s=[],o=e._internalType,l=e._outputType,c=e._mimeType;e.on("data",function(e,i){s.push(e),t&&t(i)}).on("error",function(e){s=[],n(e)}).on("end",function(){try{var e=function(e,t,i){switch(e){case"blob":return a.newBlob(a.transformTo("arraybuffer",t),i);case"base64":return r.encode(t);default:return a.transformTo(e,t)}}(l,function(e,t){var i,a=0,n=null,s=0;for(i=0;i>>6:(i<65536?t[r++]=224|i>>>12:(t[r++]=240|i>>>18,t[r++]=128|i>>>12&63),t[r++]=128|i>>>6&63),t[r++]=128|63&i);return t}(e)},i.utf8decode=function(e){return n.nodebuffer?a.transformTo("nodebuffer",e).toString("utf-8"):function(e){var t,i,n,s,r=e.length,l=new Array(2*r);for(t=i=0;t>10&1023,l[i++]=56320|1023&n)}return l.length!==i&&(l.subarray?l=l.subarray(0,i):l.length=i),a.applyFromCharCode(l)}(e=a.transformTo(n.uint8array?"uint8array":"array",e))},a.inherits(c,r),c.prototype.processChunk=function(e){var t=a.transformTo(n.uint8array?"uint8array":"array",e.data);if(this.leftOver&&this.leftOver.length){if(n.uint8array){var s=t;(t=new Uint8Array(s.length+this.leftOver.length)).set(this.leftOver,0),t.set(s,this.leftOver.length)}else t=this.leftOver.concat(t);this.leftOver=null}var r=function(e,t){var i;for((t=t||e.length)>e.length&&(t=e.length),i=t-1;0<=i&&128==(192&e[i]);)i--;return i<0||0===i?t:i+o[e[i]]>t?i:t}(t),l=t;r!==t.length&&(n.uint8array?(l=t.subarray(0,r),this.leftOver=t.subarray(r,t.length)):(l=t.slice(0,r),this.leftOver=t.slice(r,t.length))),this.push({data:i.utf8decode(l),meta:e.meta})},c.prototype.flush=function(){this.leftOver&&this.leftOver.length&&(this.push({data:i.utf8decode(this.leftOver),meta:{}}),this.leftOver=null)},i.Utf8DecodeWorker=c,a.inherits(d,r),d.prototype.processChunk=function(e){this.push({data:i.utf8encode(e.data),meta:e.meta})},i.Utf8EncodeWorker=d},{"./nodejsUtils":14,"./stream/GenericWorker":28,"./support":30,"./utils":32}],32:[function(e,t,i){"use strict";var a=e("./support"),n=e("./base64"),s=e("./nodejsUtils"),r=e("./external");function o(e){return e}function l(e,t){for(var i=0;i>8;this.dir=!!(16&this.externalFileAttributes),0==e&&(this.dosPermissions=63&this.externalFileAttributes),3==e&&(this.unixPermissions=this.externalFileAttributes>>16&65535),this.dir||"/"!==this.fileNameStr.slice(-1)||(this.dir=!0)},parseZIP64ExtraField:function(){if(this.extraFields[1]){var e=a(this.extraFields[1].value);this.uncompressedSize===n.MAX_VALUE_32BITS&&(this.uncompressedSize=e.readInt(8)),this.compressedSize===n.MAX_VALUE_32BITS&&(this.compressedSize=e.readInt(8)),this.localHeaderOffset===n.MAX_VALUE_32BITS&&(this.localHeaderOffset=e.readInt(8)),this.diskNumberStart===n.MAX_VALUE_32BITS&&(this.diskNumberStart=e.readInt(4))}},readExtraFields:function(e){var t,i,a,n=e.index+this.extraFieldsLength;for(this.extraFields||(this.extraFields={});e.index+4>>6:(i<65536?t[r++]=224|i>>>12:(t[r++]=240|i>>>18,t[r++]=128|i>>>12&63),t[r++]=128|i>>>6&63),t[r++]=128|63&i);return t},i.buf2binstring=function(e){return l(e,e.length)},i.binstring2buf=function(e){for(var t=new a.Buf8(e.length),i=0,n=t.length;i>10&1023,c[a++]=56320|1023&n)}return l(c,a)},i.utf8border=function(e,t){var i;for((t=t||e.length)>e.length&&(t=e.length),i=t-1;0<=i&&128==(192&e[i]);)i--;return i<0||0===i?t:i+r[e[i]]>t?i:t}},{"./common":41}],43:[function(e,t,i){"use strict";t.exports=function(e,t,i,a){for(var n=65535&e,s=e>>>16&65535,r=0;0!==i;){for(i-=r=2e3>>1:e>>>1;t[i]=e}return t}();t.exports=function(e,t,i,n){var s=a,r=n+i;e^=-1;for(var o=n;o>>8^s[255&(e^t[o])];return-1^e}},{}],46:[function(e,t,i){"use strict";var a,n=e("../utils/common"),s=e("./trees"),r=e("./adler32"),o=e("./crc32"),l=e("./messages"),c=0,d=4,h=0,u=-2,f=-1,m=4,p=2,g=8,b=9,v=286,k=30,_=19,y=2*v+1,w=15,F=3,C=258,T=C+F+1,x=42,S=113,L=1,E=2,A=3,I=4;function D(e,t){return e.msg=l[t],t}function z(e){return(e<<1)-(4e.avail_out&&(i=e.avail_out),0!==i&&(n.arraySet(e.output,t.pending_buf,t.pending_out,i,e.next_out),e.next_out+=i,t.pending_out+=i,e.total_out+=i,e.avail_out-=i,t.pending-=i,0===t.pending&&(t.pending_out=0))}function W(e,t){s._tr_flush_block(e,0<=e.block_start?e.block_start:-1,e.strstart-e.block_start,t),e.block_start=e.strstart,B(e.strm)}function P(e,t){e.pending_buf[e.pending++]=t}function $(e,t){e.pending_buf[e.pending++]=t>>>8&255,e.pending_buf[e.pending++]=255&t}function O(e,t){var i,a,n=e.max_chain_length,s=e.strstart,r=e.prev_length,o=e.nice_match,l=e.strstart>e.w_size-T?e.strstart-(e.w_size-T):0,c=e.window,d=e.w_mask,h=e.prev,u=e.strstart+C,f=c[s+r-1],m=c[s+r];e.prev_length>=e.good_match&&(n>>=2),o>e.lookahead&&(o=e.lookahead);do{if(c[(i=t)+r]===m&&c[i+r-1]===f&&c[i]===c[s]&&c[++i]===c[s+1]){s+=2,i++;do{}while(c[++s]===c[++i]&&c[++s]===c[++i]&&c[++s]===c[++i]&&c[++s]===c[++i]&&c[++s]===c[++i]&&c[++s]===c[++i]&&c[++s]===c[++i]&&c[++s]===c[++i]&&sl&&0!=--n);return r<=e.lookahead?r:e.lookahead}function R(e){var t,i,a,s,l,c,d,h,u,f,m=e.w_size;do{if(s=e.window_size-e.lookahead-e.strstart,e.strstart>=m+(m-T)){for(n.arraySet(e.window,e.window,m,m,0),e.match_start-=m,e.strstart-=m,e.block_start-=m,t=i=e.hash_size;a=e.head[--t],e.head[t]=m<=a?a-m:0,--i;);for(t=i=m;a=e.prev[--t],e.prev[t]=m<=a?a-m:0,--i;);s+=m}if(0===e.strm.avail_in)break;if(c=e.strm,d=e.window,h=e.strstart+e.lookahead,u=s,f=void 0,f=c.avail_in,u=F)for(l=e.strstart-e.insert,e.ins_h=e.window[l],e.ins_h=(e.ins_h<=F&&(e.ins_h=(e.ins_h<=F)if(a=s._tr_tally(e,e.strstart-e.match_start,e.match_length-F),e.lookahead-=e.match_length,e.match_length<=e.max_lazy_match&&e.lookahead>=F){for(e.match_length--;e.strstart++,e.ins_h=(e.ins_h<=F&&(e.ins_h=(e.ins_h<=F&&e.match_length<=e.prev_length){for(n=e.strstart+e.lookahead-F,a=s._tr_tally(e,e.strstart-1-e.prev_match,e.prev_length-F),e.lookahead-=e.prev_length-1,e.prev_length-=2;++e.strstart<=n&&(e.ins_h=(e.ins_h<e.pending_buf_size-5&&(i=e.pending_buf_size-5);;){if(e.lookahead<=1){if(R(e),0===e.lookahead&&t===c)return L;if(0===e.lookahead)break}e.strstart+=e.lookahead,e.lookahead=0;var a=e.block_start+i;if((0===e.strstart||e.strstart>=a)&&(e.lookahead=e.strstart-a,e.strstart=a,W(e,!1),0===e.strm.avail_out))return L;if(e.strstart-e.block_start>=e.w_size-T&&(W(e,!1),0===e.strm.avail_out))return L}return e.insert=0,t===d?(W(e,!0),0===e.strm.avail_out?A:I):(e.strstart>e.block_start&&(W(e,!1),e.strm.avail_out),L)}),new j(4,4,8,4,N),new j(4,5,16,8,N),new j(4,6,32,32,N),new j(4,4,16,16,M),new j(8,16,32,32,M),new j(8,16,128,128,M),new j(8,32,128,256,M),new j(32,128,258,1024,M),new j(32,258,258,4096,M)],i.deflateInit=function(e,t){return K(e,t,g,15,8,0)},i.deflateInit2=K,i.deflateReset=Z,i.deflateResetKeep=X,i.deflateSetHeader=function(e,t){return e&&e.state?2!==e.state.wrap?u:(e.state.gzhead=t,h):u},i.deflate=function(e,t){var i,n,r,l;if(!e||!e.state||5>8&255),P(n,n.gzhead.time>>16&255),P(n,n.gzhead.time>>24&255),P(n,9===n.level?2:2<=n.strategy||n.level<2?4:0),P(n,255&n.gzhead.os),n.gzhead.extra&&n.gzhead.extra.length&&(P(n,255&n.gzhead.extra.length),P(n,n.gzhead.extra.length>>8&255)),n.gzhead.hcrc&&(e.adler=o(e.adler,n.pending_buf,n.pending,0)),n.gzindex=0,n.status=69):(P(n,0),P(n,0),P(n,0),P(n,0),P(n,0),P(n,9===n.level?2:2<=n.strategy||n.level<2?4:0),P(n,3),n.status=S);else{var f=g+(n.w_bits-8<<4)<<8;f|=(2<=n.strategy||n.level<2?0:n.level<6?1:6===n.level?2:3)<<6,0!==n.strstart&&(f|=32),f+=31-f%31,n.status=S,$(n,f),0!==n.strstart&&($(n,e.adler>>>16),$(n,65535&e.adler)),e.adler=1}if(69===n.status)if(n.gzhead.extra){for(r=n.pending;n.gzindex<(65535&n.gzhead.extra.length)&&(n.pending!==n.pending_buf_size||(n.gzhead.hcrc&&n.pending>r&&(e.adler=o(e.adler,n.pending_buf,n.pending-r,r)),B(e),r=n.pending,n.pending!==n.pending_buf_size));)P(n,255&n.gzhead.extra[n.gzindex]),n.gzindex++;n.gzhead.hcrc&&n.pending>r&&(e.adler=o(e.adler,n.pending_buf,n.pending-r,r)),n.gzindex===n.gzhead.extra.length&&(n.gzindex=0,n.status=73)}else n.status=73;if(73===n.status)if(n.gzhead.name){r=n.pending;do{if(n.pending===n.pending_buf_size&&(n.gzhead.hcrc&&n.pending>r&&(e.adler=o(e.adler,n.pending_buf,n.pending-r,r)),B(e),r=n.pending,n.pending===n.pending_buf_size)){l=1;break}l=n.gzindexr&&(e.adler=o(e.adler,n.pending_buf,n.pending-r,r)),0===l&&(n.gzindex=0,n.status=91)}else n.status=91;if(91===n.status)if(n.gzhead.comment){r=n.pending;do{if(n.pending===n.pending_buf_size&&(n.gzhead.hcrc&&n.pending>r&&(e.adler=o(e.adler,n.pending_buf,n.pending-r,r)),B(e),r=n.pending,n.pending===n.pending_buf_size)){l=1;break}l=n.gzindexr&&(e.adler=o(e.adler,n.pending_buf,n.pending-r,r)),0===l&&(n.status=103)}else n.status=103;if(103===n.status&&(n.gzhead.hcrc?(n.pending+2>n.pending_buf_size&&B(e),n.pending+2<=n.pending_buf_size&&(P(n,255&e.adler),P(n,e.adler>>8&255),e.adler=0,n.status=S)):n.status=S),0!==n.pending){if(B(e),0===e.avail_out)return n.last_flush=-1,h}else if(0===e.avail_in&&z(t)<=z(i)&&t!==d)return D(e,-5);if(666===n.status&&0!==e.avail_in)return D(e,-5);if(0!==e.avail_in||0!==n.lookahead||t!==c&&666!==n.status){var m=2===n.strategy?function(e,t){for(var i;;){if(0===e.lookahead&&(R(e),0===e.lookahead)){if(t===c)return L;break}if(e.match_length=0,i=s._tr_tally(e,0,e.window[e.strstart]),e.lookahead--,e.strstart++,i&&(W(e,!1),0===e.strm.avail_out))return L}return e.insert=0,t===d?(W(e,!0),0===e.strm.avail_out?A:I):e.last_lit&&(W(e,!1),0===e.strm.avail_out)?L:E}(n,t):3===n.strategy?function(e,t){for(var i,a,n,r,o=e.window;;){if(e.lookahead<=C){if(R(e),e.lookahead<=C&&t===c)return L;if(0===e.lookahead)break}if(e.match_length=0,e.lookahead>=F&&0e.lookahead&&(e.match_length=e.lookahead)}if(e.match_length>=F?(i=s._tr_tally(e,1,e.match_length-F),e.lookahead-=e.match_length,e.strstart+=e.match_length,e.match_length=0):(i=s._tr_tally(e,0,e.window[e.strstart]),e.lookahead--,e.strstart++),i&&(W(e,!1),0===e.strm.avail_out))return L}return e.insert=0,t===d?(W(e,!0),0===e.strm.avail_out?A:I):e.last_lit&&(W(e,!1),0===e.strm.avail_out)?L:E}(n,t):a[n.level].func(n,t);if(m!==A&&m!==I||(n.status=666),m===L||m===A)return 0===e.avail_out&&(n.last_flush=-1),h;if(m===E&&(1===t?s._tr_align(n):5!==t&&(s._tr_stored_block(n,0,0,!1),3===t&&(U(n.head),0===n.lookahead&&(n.strstart=0,n.block_start=0,n.insert=0))),B(e),0===e.avail_out))return n.last_flush=-1,h}return t!==d?h:n.wrap<=0?1:(2===n.wrap?(P(n,255&e.adler),P(n,e.adler>>8&255),P(n,e.adler>>16&255),P(n,e.adler>>24&255),P(n,255&e.total_in),P(n,e.total_in>>8&255),P(n,e.total_in>>16&255),P(n,e.total_in>>24&255)):($(n,e.adler>>>16),$(n,65535&e.adler)),B(e),0=i.w_size&&(0===o&&(U(i.head),i.strstart=0,i.block_start=0,i.insert=0),f=new n.Buf8(i.w_size),n.arraySet(f,t,m-i.w_size,i.w_size,0),t=f,m=i.w_size),l=e.avail_in,c=e.next_in,d=e.input,e.avail_in=m,e.next_in=0,e.input=t,R(i);i.lookahead>=F;){for(a=i.strstart,s=i.lookahead-(F-1);i.ins_h=(i.ins_h<>>=_=k>>>24,m-=_,0===(_=k>>>16&255))x[s++]=65535&k;else{if(!(16&_)){if(0==(64&_)){k=p[(65535&k)+(f&(1<<_)-1)];continue t}if(32&_){i.mode=12;break e}e.msg="invalid literal/length code",i.mode=30;break e}y=65535&k,(_&=15)&&(m<_&&(f+=T[a++]<>>=_,m-=_),m<15&&(f+=T[a++]<>>=_=k>>>24,m-=_,!(16&(_=k>>>16&255))){if(0==(64&_)){k=g[(65535&k)+(f&(1<<_)-1)];continue i}e.msg="invalid distance code",i.mode=30;break e}if(w=65535&k,m<(_&=15)&&(f+=T[a++]<>>=_,m-=_,(_=s-r)>3,f&=(1<<(m-=y<<3))-1,e.next_in=a,e.next_out=s,e.avail_in=a>>24&255)+(e>>>8&65280)+((65280&e)<<8)+((255&e)<<24)}function g(){this.mode=0,this.last=!1,this.wrap=0,this.havedict=!1,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 a.Buf16(320),this.work=new a.Buf16(288),this.lendyn=null,this.distdyn=null,this.sane=0,this.back=0,this.was=0}function b(e){var t;return e&&e.state?(t=e.state,e.total_in=e.total_out=t.total=0,e.msg="",t.wrap&&(e.adler=1&t.wrap),t.mode=u,t.last=0,t.havedict=0,t.dmax=32768,t.head=null,t.hold=0,t.bits=0,t.lencode=t.lendyn=new a.Buf32(f),t.distcode=t.distdyn=new a.Buf32(m),t.sane=1,t.back=-1,d):h}function v(e){var t;return e&&e.state?((t=e.state).wsize=0,t.whave=0,t.wnext=0,b(e)):h}function k(e,t){var i,a;return e&&e.state?(a=e.state,t<0?(i=0,t=-t):(i=1+(t>>4),t<48&&(t&=15)),t&&(t<8||15=r.wsize?(a.arraySet(r.window,t,i-r.wsize,r.wsize,0),r.wnext=0,r.whave=r.wsize):(n<(s=r.wsize-r.wnext)&&(s=n),a.arraySet(r.window,t,i-n,s,r.wnext),(n-=s)?(a.arraySet(r.window,t,i-n,n,0),r.wnext=n,r.whave=r.wsize):(r.wnext+=s,r.wnext===r.wsize&&(r.wnext=0),r.whave>>8&255,i.check=s(i.check,R,2,0),y=_=0,i.mode=2;break}if(i.flags=0,i.head&&(i.head.done=!1),!(1&i.wrap)||(((255&_)<<8)+(_>>8))%31){e.msg="incorrect header check",i.mode=30;break}if(8!=(15&_)){e.msg="unknown compression method",i.mode=30;break}if(y-=4,B=8+(15&(_>>>=4)),0===i.wbits)i.wbits=B;else if(B>i.wbits){e.msg="invalid window size",i.mode=30;break}i.dmax=1<>8&1),512&i.flags&&(R[0]=255&_,R[1]=_>>>8&255,i.check=s(i.check,R,2,0)),y=_=0,i.mode=3;case 3:for(;y<32;){if(0===v)break e;v--,_+=f[g++]<>>8&255,R[2]=_>>>16&255,R[3]=_>>>24&255,i.check=s(i.check,R,4,0)),y=_=0,i.mode=4;case 4:for(;y<16;){if(0===v)break e;v--,_+=f[g++]<>8),512&i.flags&&(R[0]=255&_,R[1]=_>>>8&255,i.check=s(i.check,R,2,0)),y=_=0,i.mode=5;case 5:if(1024&i.flags){for(;y<16;){if(0===v)break e;v--,_+=f[g++]<>>8&255,i.check=s(i.check,R,2,0)),y=_=0}else i.head&&(i.head.extra=null);i.mode=6;case 6:if(1024&i.flags&&(v<(x=i.length)&&(x=v),x&&(i.head&&(B=i.head.extra_len-i.length,i.head.extra||(i.head.extra=new Array(i.head.extra_len)),a.arraySet(i.head.extra,f,g,x,B)),512&i.flags&&(i.check=s(i.check,f,x,g)),v-=x,g+=x,i.length-=x),i.length))break e;i.length=0,i.mode=7;case 7:if(2048&i.flags){if(0===v)break e;for(x=0;B=f[g+x++],i.head&&B&&i.length<65536&&(i.head.name+=String.fromCharCode(B)),B&&x>9&1,i.head.done=!0),e.adler=i.check=0,i.mode=12;break;case 10:for(;y<32;){if(0===v)break e;v--,_+=f[g++]<>>=7&y,y-=7&y,i.mode=27;break}for(;y<3;){if(0===v)break e;v--,_+=f[g++]<>>=1)){case 0:i.mode=14;break;case 1:if(C(i),i.mode=20,6!==t)break;_>>>=2,y-=2;break e;case 2:i.mode=17;break;case 3:e.msg="invalid block type",i.mode=30}_>>>=2,y-=2;break;case 14:for(_>>>=7&y,y-=7&y;y<32;){if(0===v)break e;v--,_+=f[g++]<>>16^65535)){e.msg="invalid stored block lengths",i.mode=30;break}if(i.length=65535&_,y=_=0,i.mode=15,6===t)break e;case 15:i.mode=16;case 16:if(x=i.length){if(v>>=5,y-=5,i.ndist=1+(31&_),_>>>=5,y-=5,i.ncode=4+(15&_),_>>>=4,y-=4,286>>=3,y-=3}for(;i.have<19;)i.lens[N[i.have++]]=0;if(i.lencode=i.lendyn,i.lenbits=7,P={bits:i.lenbits},W=o(0,i.lens,0,19,i.lencode,0,i.work,P),i.lenbits=P.bits,W){e.msg="invalid code lengths set",i.mode=30;break}i.have=0,i.mode=19;case 19:for(;i.have>>16&255,I=65535&O,!((E=O>>>24)<=y);){if(0===v)break e;v--,_+=f[g++]<>>=E,y-=E,i.lens[i.have++]=I;else{if(16===I){for($=E+2;y<$;){if(0===v)break e;v--,_+=f[g++]<>>=E,y-=E,0===i.have){e.msg="invalid bit length repeat",i.mode=30;break}B=i.lens[i.have-1],x=3+(3&_),_>>>=2,y-=2}else if(17===I){for($=E+3;y<$;){if(0===v)break e;v--,_+=f[g++]<>>=E)),_>>>=3,y-=3}else{for($=E+7;y<$;){if(0===v)break e;v--,_+=f[g++]<>>=E)),_>>>=7,y-=7}if(i.have+x>i.nlen+i.ndist){e.msg="invalid bit length repeat",i.mode=30;break}for(;x--;)i.lens[i.have++]=B}}if(30===i.mode)break;if(0===i.lens[256]){e.msg="invalid code -- missing end-of-block",i.mode=30;break}if(i.lenbits=9,P={bits:i.lenbits},W=o(l,i.lens,0,i.nlen,i.lencode,0,i.work,P),i.lenbits=P.bits,W){e.msg="invalid literal/lengths set",i.mode=30;break}if(i.distbits=6,i.distcode=i.distdyn,P={bits:i.distbits},W=o(c,i.lens,i.nlen,i.ndist,i.distcode,0,i.work,P),i.distbits=P.bits,W){e.msg="invalid distances set",i.mode=30;break}if(i.mode=20,6===t)break e;case 20:i.mode=21;case 21:if(6<=v&&258<=k){e.next_out=b,e.avail_out=k,e.next_in=g,e.avail_in=v,i.hold=_,i.bits=y,r(e,F),b=e.next_out,m=e.output,k=e.avail_out,g=e.next_in,f=e.input,v=e.avail_in,_=i.hold,y=i.bits,12===i.mode&&(i.back=-1);break}for(i.back=0;A=(O=i.lencode[_&(1<>>16&255,I=65535&O,!((E=O>>>24)<=y);){if(0===v)break e;v--,_+=f[g++]<>D)])>>>16&255,I=65535&O,!(D+(E=O>>>24)<=y);){if(0===v)break e;v--,_+=f[g++]<>>=D,y-=D,i.back+=D}if(_>>>=E,y-=E,i.back+=E,i.length=I,0===A){i.mode=26;break}if(32&A){i.back=-1,i.mode=12;break}if(64&A){e.msg="invalid literal/length code",i.mode=30;break}i.extra=15&A,i.mode=22;case 22:if(i.extra){for($=i.extra;y<$;){if(0===v)break e;v--,_+=f[g++]<>>=i.extra,y-=i.extra,i.back+=i.extra}i.was=i.length,i.mode=23;case 23:for(;A=(O=i.distcode[_&(1<>>16&255,I=65535&O,!((E=O>>>24)<=y);){if(0===v)break e;v--,_+=f[g++]<>D)])>>>16&255,I=65535&O,!(D+(E=O>>>24)<=y);){if(0===v)break e;v--,_+=f[g++]<>>=D,y-=D,i.back+=D}if(_>>>=E,y-=E,i.back+=E,64&A){e.msg="invalid distance code",i.mode=30;break}i.offset=I,i.extra=15&A,i.mode=24;case 24:if(i.extra){for($=i.extra;y<$;){if(0===v)break e;v--,_+=f[g++]<>>=i.extra,y-=i.extra,i.back+=i.extra}if(i.offset>i.dmax){e.msg="invalid distance too far back",i.mode=30;break}i.mode=25;case 25:if(0===k)break e;if(x=F-k,i.offset>x){if((x=i.offset-x)>i.whave&&i.sane){e.msg="invalid distance too far back",i.mode=30;break}S=x>i.wnext?(x-=i.wnext,i.wsize-x):i.wnext-x,x>i.length&&(x=i.length),L=i.window}else L=m,S=b-i.offset,x=i.length;for(kv?(_=P[$+h[C]],z[U+h[C]]):(_=96,0),f=1<>E)+(m-=f)]=k<<24|_<<16|y,0!==m;);for(f=1<>=1;if(0!==f?(D&=f-1,D+=f):D=0,C++,0==--B[F]){if(F===x)break;F=t[i+h[C]]}if(S>>7)]}function P(e,t){e.pending_buf[e.pending++]=255&t,e.pending_buf[e.pending++]=t>>>8&255}function $(e,t,i){e.bi_valid>p-i?(e.bi_buf|=t<>p-e.bi_valid,e.bi_valid+=i-p):(e.bi_buf|=t<>>=1,i<<=1,0<--t;);return i>>>1}function N(e,t,i){var a,n,s=new Array(m+1),r=0;for(a=1;a<=m;a++)s[a]=r=r+i[a-1]<<1;for(n=0;n<=t;n++){var o=e[2*n+1];0!==o&&(e[2*n]=R(s[o]++,o))}}function M(e){var t;for(t=0;t>1;1<=i;i--)X(e,s,i);for(n=l;i=e.heap[1],e.heap[1]=e.heap[e.heap_len--],X(e,s,1),a=e.heap[1],e.heap[--e.heap_max]=i,e.heap[--e.heap_max]=a,s[2*n]=s[2*i]+s[2*a],e.depth[n]=(e.depth[i]>=e.depth[a]?e.depth[i]:e.depth[a])+1,s[2*i+1]=s[2*a+1]=n,e.heap[1]=n++,X(e,s,1),2<=e.heap_len;);e.heap[--e.heap_max]=e.heap[1],function(e,t){var i,a,n,s,r,o,l=t.dyn_tree,c=t.max_code,d=t.stat_desc.static_tree,h=t.stat_desc.has_stree,u=t.stat_desc.extra_bits,p=t.stat_desc.extra_base,g=t.stat_desc.max_length,b=0;for(s=0;s<=m;s++)e.bl_count[s]=0;for(l[2*e.heap[e.heap_max]+1]=0,i=e.heap_max+1;i>=7;a>>=1)if(1&i&&0!==e.dyn_ltree[2*t])return n;if(0!==e.dyn_ltree[18]||0!==e.dyn_ltree[20]||0!==e.dyn_ltree[26])return s;for(t=32;t>>3,(o=e.static_len+3+7>>>3)<=r&&(r=o)):r=o=i+5,i+4<=r&&-1!==t?Q(e,t,i,a):4===e.strategy||o===r?($(e,2+(a?1:0),3),Z(e,T,x)):($(e,4+(a?1:0),3),function(e,t,i,a){var n;for($(e,t-257,5),$(e,i-1,5),$(e,a-4,4),n=0;n>>8&255,e.pending_buf[e.d_buf+2*e.last_lit+1]=255&t,e.pending_buf[e.l_buf+e.last_lit]=255&i,e.last_lit++,0===t?e.dyn_ltree[2*i]++:(e.matches++,t--,e.dyn_ltree[2*(L[i]+c+1)]++,e.dyn_dtree[2*W(t)]++),e.last_lit===e.lit_bufsize-1},i._tr_align=function(e){$(e,2,3),O(e,b,T),function(e){16===e.bi_valid?(P(e,e.bi_buf),e.bi_buf=0,e.bi_valid=0):8<=e.bi_valid&&(e.pending_buf[e.pending++]=255&e.bi_buf,e.bi_buf>>=8,e.bi_valid-=8)}(e)}},{"../utils/common":41}],53:[function(e,t,i){"use strict";t.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(e,t,a){(function(e){!function(e,t){"use strict";if(!e.setImmediate){var i,a,n,s,r=1,o={},l=!1,c=e.document,d=Object.getPrototypeOf&&Object.getPrototypeOf(e);d=d&&d.setTimeout?d:e,i="[object process]"==={}.toString.call(e.process)?function(e){process.nextTick(function(){u(e)})}:function(){if(e.postMessage&&!e.importScripts){var t=!0,i=e.onmessage;return e.onmessage=function(){t=!1},e.postMessage("","*"),e.onmessage=i,t}}()?(s="setImmediate$"+Math.random()+"$",e.addEventListener?e.addEventListener("message",f,!1):e.attachEvent("onmessage",f),function(t){e.postMessage(s+t,"*")}):e.MessageChannel?((n=new MessageChannel).port1.onmessage=function(e){u(e.data)},function(e){n.port2.postMessage(e)}):c&&"onreadystatechange"in c.createElement("script")?(a=c.documentElement,function(e){var t=c.createElement("script");t.onreadystatechange=function(){u(e),t.onreadystatechange=null,a.removeChild(t),t=null},a.appendChild(t)}):function(e){setTimeout(u,0,e)},d.setImmediate=function(e){"function"!=typeof e&&(e=new Function(""+e));for(var t=new Array(arguments.length-1),a=0;a | 空格 ( ) [ ] { } # % ^ ` ~ ; @ & = + $ ,\r\n const invalidChars = /[\\\\:\\*\\?\"'<>\\| \\(\\)\\[\\]\\{\\}#%\\^`~;@&=\\+\\$,]/;\r\n if (invalidChars.test(path)) {\r\n return { \r\n valid: false, \r\n error: '目标目录包含非法字符,请使用合法的路径格式' \r\n };\r\n }\r\n \r\n // 检查路径是否包含连续的斜杠\r\n if (path.includes('//')) {\r\n return { \r\n valid: false, \r\n error: '目标目录不能包含连续的斜杠' \r\n };\r\n }\r\n \r\n return { valid: true };\r\n}\r\n","import { createElementVNode as _createElementVNode, resolveComponent as _resolveComponent, createVNode as _createVNode, normalizeClass as _normalizeClass, renderList as _renderList, Fragment as _Fragment, openBlock as _openBlock, createElementBlock as _createElementBlock, toDisplayString as _toDisplayString, normalizeStyle as _normalizeStyle, createCommentVNode as _createCommentVNode, withModifiers as _withModifiers, Transition as _Transition, withCtx as _withCtx, Teleport as _Teleport, createBlock as _createBlock } from \"vue\";\nconst _hoisted_1 = {\n class: \"mobile-drawer-header\"\n};\nconst _hoisted_2 = {\n class: \"mobile-drawer-content\"\n};\nconst _hoisted_3 = [\"onClick\"];\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n return _openBlock(), _createBlock(_Teleport, {\n to: \"body\"\n }, [_createVNode(_Transition, {\n name: \"drawer-slide\"\n }, {\n default: _withCtx(() => [$props.modelValue ? (_openBlock(), _createElementBlock(\"div\", {\n key: 0,\n class: \"mobile-drawer-overlay\",\n onClick: _cache[3] || (_cache[3] = (...args) => $options.close && $options.close(...args))\n }, [_createElementVNode(\"div\", {\n class: \"mobile-drawer\",\n onClick: _cache[2] || (_cache[2] = _withModifiers(() => {}, [\"stop\"]))\n }, [_createElementVNode(\"div\", _hoisted_1, [_cache[4] || (_cache[4] = _createElementVNode(\"span\", {\n class: \"mobile-drawer-title\"\n }, \"目录导航\", -1)), _createVNode(_component_font_awesome_icon, {\n icon: \"times\",\n class: \"mobile-drawer-close\",\n onClick: $options.close\n }, null, 8, [\"onClick\"])]), _createElementVNode(\"div\", _hoisted_2, [_createElementVNode(\"div\", {\n class: _normalizeClass([\"mobile-drawer-item\", {\n active: !$props.currentPath\n }]),\n onClick: _cache[0] || (_cache[0] = $event => $options.navigate(''))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"home\",\n class: \"mobile-drawer-item-icon\"\n }), _cache[5] || (_cache[5] = _createElementVNode(\"span\", null, \"根目录\", -1))], 2), (_openBlock(true), _createElementBlock(_Fragment, null, _renderList($options.pathParts, (folder, index) => {\n return _openBlock(), _createElementBlock(\"div\", {\n key: index,\n class: _normalizeClass([\"mobile-drawer-item\", {\n active: index === $options.pathParts.length - 1\n }]),\n style: _normalizeStyle({\n paddingLeft: (index + 1) * 16 + 16 + 'px'\n }),\n onClick: $event => $options.navigate($options.pathParts.slice(0, index + 1).join('/'))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"folder\",\n class: \"mobile-drawer-item-icon\"\n }), _createElementVNode(\"span\", null, _toDisplayString(folder), 1)], 14, _hoisted_3);\n }), 128)), $props.currentPath ? (_openBlock(), _createElementBlock(\"div\", {\n key: 0,\n class: \"mobile-drawer-back\",\n onClick: _cache[1] || (_cache[1] = (...args) => $options.goBack && $options.goBack(...args))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"arrow-left\",\n class: \"mobile-drawer-item-icon\"\n }), _cache[6] || (_cache[6] = _createElementVNode(\"span\", null, \"返回上一级\", -1))])) : _createCommentVNode(\"\", true)])])])) : _createCommentVNode(\"\", true)]),\n _: 1\n })]);\n}","import \"core-js/modules/es.iterator.constructor.js\";\nimport \"core-js/modules/es.iterator.filter.js\";\nexport default {\n name: 'MobileDirectoryDrawer',\n props: {\n modelValue: {\n type: Boolean,\n default: false\n },\n currentPath: {\n type: String,\n default: ''\n }\n },\n emits: ['update:modelValue', 'navigate', 'goBack'],\n computed: {\n pathParts() {\n return this.currentPath.split('/').filter(Boolean);\n }\n },\n methods: {\n close() {\n this.$emit('update:modelValue', false);\n },\n navigate(path) {\n this.$emit('navigate', path);\n this.close();\n },\n goBack() {\n this.$emit('goBack');\n this.close();\n }\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./MobileDirectoryDrawer.vue?vue&type=template&id=2d8e83ec&scoped=true\"\nimport script from \"./MobileDirectoryDrawer.vue?vue&type=script&lang=js\"\nexport * from \"./MobileDirectoryDrawer.vue?vue&type=script&lang=js\"\n\nimport \"./MobileDirectoryDrawer.vue?vue&type=style&index=0&id=2d8e83ec&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-2d8e83ec\"]])\n\nexport default __exports__","import { createElementVNode as _createElementVNode, toDisplayString as _toDisplayString, resolveComponent as _resolveComponent, createVNode as _createVNode, Fragment as _Fragment, openBlock as _openBlock, createElementBlock as _createElementBlock, createCommentVNode as _createCommentVNode, withModifiers as _withModifiers, Transition as _Transition, withCtx as _withCtx, Teleport as _Teleport, createBlock as _createBlock } from \"vue\";\nconst _hoisted_1 = {\n class: \"bottom-sheet-header\"\n};\nconst _hoisted_2 = {\n class: \"bottom-sheet-title\"\n};\nconst _hoisted_3 = {\n class: \"bottom-sheet-content\"\n};\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n return _openBlock(), _createBlock(_Teleport, {\n to: \"body\"\n }, [_createVNode(_Transition, {\n name: \"bottom-sheet\"\n }, {\n default: _withCtx(() => [$props.modelValue ? (_openBlock(), _createElementBlock(\"div\", {\n key: 0,\n class: \"bottom-sheet-overlay\",\n onClick: _cache[9] || (_cache[9] = (...args) => $options.close && $options.close(...args))\n }, [_createElementVNode(\"div\", {\n class: \"bottom-sheet\",\n onClick: _cache[8] || (_cache[8] = _withModifiers(() => {}, [\"stop\"]))\n }, [_createElementVNode(\"div\", _hoisted_1, [_cache[10] || (_cache[10] = _createElementVNode(\"div\", {\n class: \"bottom-sheet-handle\"\n }, null, -1)), _createElementVNode(\"span\", _hoisted_2, _toDisplayString($props.title), 1)]), _createElementVNode(\"div\", _hoisted_3, [!$props.isFolder ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 0\n }, [_createElementVNode(\"div\", {\n class: \"bottom-sheet-item\",\n onClick: _cache[0] || (_cache[0] = $event => $options.handleAction('detail'))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"info-circle\",\n class: \"bottom-sheet-icon\"\n }), _cache[11] || (_cache[11] = _createElementVNode(\"span\", null, \"查看详情\", -1))]), _createElementVNode(\"div\", {\n class: \"bottom-sheet-item\",\n onClick: _cache[1] || (_cache[1] = $event => $options.handleAction('copy'))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"copy\",\n class: \"bottom-sheet-icon\"\n }), _cache[12] || (_cache[12] = _createElementVNode(\"span\", null, \"复制链接\", -1))]), _createElementVNode(\"div\", {\n class: \"bottom-sheet-item\",\n onClick: _cache[2] || (_cache[2] = $event => $options.handleAction('download'))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"download\",\n class: \"bottom-sheet-icon\"\n }), _cache[13] || (_cache[13] = _createElementVNode(\"span\", null, \"下载文件\", -1))]), _createElementVNode(\"div\", {\n class: \"bottom-sheet-item\",\n onClick: _cache[3] || (_cache[3] = $event => $options.handleAction('move'))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"file-export\",\n class: \"bottom-sheet-icon\"\n }), _cache[14] || (_cache[14] = _createElementVNode(\"span\", null, \"移动文件\", -1))]), _createElementVNode(\"div\", {\n class: \"bottom-sheet-item\",\n onClick: _cache[4] || (_cache[4] = $event => $options.handleAction('tag'))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"tags\",\n class: \"bottom-sheet-icon\"\n }), _cache[15] || (_cache[15] = _createElementVNode(\"span\", null, \"标签管理\", -1))])], 64)) : (_openBlock(), _createElementBlock(_Fragment, {\n key: 1\n }, [_createElementVNode(\"div\", {\n class: \"bottom-sheet-item\",\n onClick: _cache[5] || (_cache[5] = $event => $options.handleAction('folderCopy'))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"copy\",\n class: \"bottom-sheet-icon\"\n }), _cache[16] || (_cache[16] = _createElementVNode(\"span\", null, \"复制链接\", -1))]), _createElementVNode(\"div\", {\n class: \"bottom-sheet-item\",\n onClick: _cache[6] || (_cache[6] = $event => $options.handleAction('move'))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"file-export\",\n class: \"bottom-sheet-icon\"\n }), _cache[17] || (_cache[17] = _createElementVNode(\"span\", null, \"移动文件夹\", -1))])], 64)), _createElementVNode(\"div\", {\n class: \"bottom-sheet-item bottom-sheet-danger\",\n onClick: _cache[7] || (_cache[7] = $event => $options.handleAction('delete'))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"trash-alt\",\n class: \"bottom-sheet-icon\"\n }), _createElementVNode(\"span\", null, _toDisplayString($props.isFolder ? '删除文件夹' : '删除文件'), 1)])])])])) : _createCommentVNode(\"\", true)]),\n _: 1\n })]);\n}","export default {\n name: 'MobileActionSheet',\n props: {\n modelValue: {\n type: Boolean,\n default: false\n },\n title: {\n type: String,\n default: ''\n },\n isFolder: {\n type: Boolean,\n default: false\n }\n },\n emits: ['update:modelValue', 'action'],\n methods: {\n close() {\n this.$emit('update:modelValue', false);\n },\n handleAction(action) {\n this.$emit('action', action);\n this.close();\n }\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./MobileActionSheet.vue?vue&type=template&id=7579ad69&scoped=true\"\nimport script from \"./MobileActionSheet.vue?vue&type=script&lang=js\"\nexport * from \"./MobileActionSheet.vue?vue&type=script&lang=js\"\n\nimport \"./MobileActionSheet.vue?vue&type=style&index=0&id=7579ad69&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-7579ad69\"]])\n\nexport default __exports__","import { toDisplayString as _toDisplayString, createElementVNode as _createElementVNode, resolveComponent as _resolveComponent, createVNode as _createVNode, withCtx as _withCtx, withKeys as _withKeys, renderList as _renderList, Fragment as _Fragment, openBlock as _openBlock, createElementBlock as _createElementBlock, createCommentVNode as _createCommentVNode, createTextVNode as _createTextVNode, createBlock as _createBlock } from \"vue\";\nconst _hoisted_1 = {\n class: \"batch-tag-container\"\n};\nconst _hoisted_2 = {\n class: \"tab-content\"\n};\nconst _hoisted_3 = {\n class: \"tab-description\"\n};\nconst _hoisted_4 = {\n class: \"input-section\"\n};\nconst _hoisted_5 = {\n key: 0,\n class: \"suggestions-panel\"\n};\nconst _hoisted_6 = [\"onClick\"];\nconst _hoisted_7 = {\n class: \"tags-to-add-section\"\n};\nconst _hoisted_8 = {\n key: 0,\n class: \"tags-container\"\n};\nconst _hoisted_9 = {\n key: 1,\n class: \"empty-message\"\n};\nconst _hoisted_10 = {\n class: \"action-buttons\"\n};\nconst _hoisted_11 = {\n class: \"tab-content\"\n};\nconst _hoisted_12 = {\n key: 0,\n class: \"common-tags-section\"\n};\nconst _hoisted_13 = {\n class: \"tags-container\"\n};\nconst _hoisted_14 = {\n key: 1,\n class: \"empty-message\"\n};\nconst _hoisted_15 = {\n class: \"tab-content\"\n};\nconst _hoisted_16 = {\n class: \"tab-description\"\n};\nconst _hoisted_17 = {\n class: \"action-buttons\"\n};\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n const _component_el_button = _resolveComponent(\"el-button\");\n const _component_el_input = _resolveComponent(\"el-input\");\n const _component_el_tag = _resolveComponent(\"el-tag\");\n const _component_el_tab_pane = _resolveComponent(\"el-tab-pane\");\n const _component_el_alert = _resolveComponent(\"el-alert\");\n const _component_el_tabs = _resolveComponent(\"el-tabs\");\n const _component_el_dialog = _resolveComponent(\"el-dialog\");\n return _openBlock(), _createBlock(_component_el_dialog, {\n title: \"批量标签管理\",\n modelValue: $options.visible,\n \"onUpdate:modelValue\": _cache[2] || (_cache[2] = $event => $options.visible = $event),\n width: $options.dialogWidth,\n onClose: $options.handleClose\n }, {\n default: _withCtx(() => [_createElementVNode(\"div\", _hoisted_1, [_createVNode(_component_el_tabs, {\n modelValue: $data.activeTab,\n \"onUpdate:modelValue\": _cache[1] || (_cache[1] = $event => $data.activeTab = $event),\n type: \"border-card\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_tab_pane, {\n label: \"添加\",\n name: \"add\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"div\", _hoisted_2, [_createElementVNode(\"p\", _hoisted_3, \"为选中的 \" + _toDisplayString($options.fileCount) + \" 个文件添加标签\", 1), _createElementVNode(\"div\", _hoisted_4, [_createVNode(_component_el_input, {\n modelValue: $data.inputTag,\n \"onUpdate:modelValue\": _cache[0] || (_cache[0] = $event => $data.inputTag = $event),\n placeholder: \"输入标签名称\",\n onKeyup: _withKeys($options.handleAddInputTag, [\"enter\"]),\n onInput: $options.handleInputChange,\n clearable: \"\"\n }, {\n append: _withCtx(() => [_createVNode(_component_el_button, {\n onClick: $options.handleAddInputTag,\n type: \"primary\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"plus\"\n })]),\n _: 1\n }, 8, [\"onClick\"])]),\n _: 1\n }, 8, [\"modelValue\", \"onKeyup\", \"onInput\"]), $data.showSuggestions && $data.suggestions.length > 0 ? (_openBlock(), _createElementBlock(\"div\", _hoisted_5, [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($data.suggestions, tag => {\n return _openBlock(), _createElementBlock(\"div\", {\n key: tag,\n class: \"suggestion-item\",\n onClick: $event => $options.selectSuggestion(tag)\n }, _toDisplayString(tag), 9, _hoisted_6);\n }), 128))])) : _createCommentVNode(\"\", true)]), _createElementVNode(\"div\", _hoisted_7, [_cache[3] || (_cache[3] = _createElementVNode(\"h4\", null, \"待添加的标签\", -1)), $data.tagsToAdd.length > 0 ? (_openBlock(), _createElementBlock(\"div\", _hoisted_8, [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($data.tagsToAdd, tag => {\n return _openBlock(), _createBlock(_component_el_tag, {\n key: tag,\n closable: \"\",\n onClose: $event => $options.removeFromToAdd(tag),\n class: \"tag-item\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString(tag), 1)]),\n _: 2\n }, 1032, [\"onClose\"]);\n }), 128))])) : (_openBlock(), _createElementBlock(\"div\", _hoisted_9, \" 暂无待添加标签 \"))]), _createElementVNode(\"div\", _hoisted_10, [_createVNode(_component_el_button, {\n type: \"primary\",\n onClick: $options.executeAddTags,\n loading: $data.loading,\n disabled: $data.tagsToAdd.length === 0\n }, {\n default: _withCtx(() => [...(_cache[4] || (_cache[4] = [_createTextVNode(\" 添加到所有文件 \", -1)]))]),\n _: 1\n }, 8, [\"onClick\", \"loading\", \"disabled\"])])])]),\n _: 1\n }), _createVNode(_component_el_tab_pane, {\n label: \"移除\",\n name: \"remove\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"div\", _hoisted_11, [_cache[6] || (_cache[6] = _createElementVNode(\"p\", {\n class: \"tab-description\"\n }, \"移除选中文件的共有标签\", -1)), $data.commonTags.length > 0 ? (_openBlock(), _createElementBlock(\"div\", _hoisted_12, [_cache[5] || (_cache[5] = _createElementVNode(\"h4\", null, \"共有标签\", -1)), _createElementVNode(\"div\", _hoisted_13, [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($data.commonTags, tag => {\n return _openBlock(), _createBlock(_component_el_tag, {\n key: tag,\n closable: \"\",\n onClose: $event => $options.handleRemoveCommonTag(tag),\n class: \"tag-item\",\n type: \"warning\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString(tag), 1)]),\n _: 2\n }, 1032, [\"onClose\"]);\n }), 128))])])) : (_openBlock(), _createElementBlock(\"div\", _hoisted_14, \" 选中的文件没有共有标签 \"))])]),\n _: 1\n }), _createVNode(_component_el_tab_pane, {\n label: \"清空\",\n name: \"clear\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"div\", _hoisted_15, [_createElementVNode(\"p\", _hoisted_16, \"清空选中的 \" + _toDisplayString($options.fileCount) + \" 个文件的所有标签\", 1), _createVNode(_component_el_alert, {\n title: \"⚠️警告\",\n type: \"warning\",\n description: \"此操作将清空所有选中文件的标签,且不可恢复\",\n closable: false,\n style: {\n \"margin-bottom\": \"20px\"\n },\n center: \"\"\n }), _createElementVNode(\"div\", _hoisted_17, [_createVNode(_component_el_button, {\n type: \"danger\",\n onClick: $options.handleClearAllTags,\n loading: $data.loading\n }, {\n default: _withCtx(() => [...(_cache[7] || (_cache[7] = [_createTextVNode(\" 确认清空所有标签 \", -1)]))]),\n _: 1\n }, 8, [\"onClick\", \"loading\"])])])]),\n _: 1\n })]),\n _: 1\n }, 8, [\"modelValue\"])])]),\n _: 1\n }, 8, [\"modelValue\", \"width\", \"onClose\"]);\n}","import \"core-js/modules/es.array.push.js\";\nimport \"core-js/modules/es.iterator.constructor.js\";\nimport \"core-js/modules/es.iterator.filter.js\";\nimport \"core-js/modules/es.iterator.map.js\";\nimport \"core-js/modules/es.json.stringify.js\";\nimport { ElMessage, ElMessageBox } from 'element-plus';\nimport fetchWithAuth from '@/utils/fetchWithAuth';\nexport default {\n name: 'BatchTagDialog',\n props: {\n modelValue: {\n type: Boolean,\n default: false\n },\n selectedFiles: {\n type: Array,\n required: true,\n default: () => []\n }\n },\n emits: ['update:modelValue', 'tagsUpdated'],\n data() {\n return {\n activeTab: 'add',\n inputTag: '',\n tagsToAdd: [],\n commonTags: [],\n suggestions: [],\n showSuggestions: false,\n loading: false,\n debounceTimer: null\n };\n },\n computed: {\n visible: {\n get() {\n return this.modelValue;\n },\n set(val) {\n this.$emit('update:modelValue', val);\n }\n },\n dialogWidth() {\n return window.innerWidth < 768 ? '90%' : '600px';\n },\n selectedFilesOnly() {\n // 排除文件夹,只保留文件\n return this.selectedFiles.filter(file => !file.isFolder);\n },\n fileCount() {\n return this.selectedFilesOnly.length;\n },\n fileIds() {\n return this.selectedFilesOnly.map(file => file.name);\n }\n },\n watch: {\n visible(newVal) {\n if (newVal) {\n this.loadCommonTags();\n } else {\n this.resetData();\n }\n },\n activeTab(newTab) {\n if (newTab === 'remove') {\n this.loadCommonTags();\n }\n }\n },\n methods: {\n resetData() {\n this.tagsToAdd = [];\n this.inputTag = '';\n this.showSuggestions = false;\n this.activeTab = 'add';\n },\n async loadCommonTags() {\n if (this.selectedFilesOnly.length === 0) {\n this.commonTags = [];\n return;\n }\n try {\n // 获取所有文件的标签\n const tagPromises = this.selectedFilesOnly.map(file => fetchWithAuth(`/api/manage/tags/${encodeURIComponent(file.name)}`, {\n method: 'GET'\n }));\n const responses = await Promise.all(tagPromises);\n const allTags = [];\n for (const response of responses) {\n if (response.ok) {\n const data = await response.json();\n allTags.push(data.tags || []);\n }\n }\n\n // 找出共有标签\n if (allTags.length > 0) {\n this.commonTags = allTags[0].filter(tag => allTags.every(tags => tags.includes(tag)));\n } else {\n this.commonTags = [];\n }\n } catch (error) {\n console.error('Error loading common tags:', error);\n ElMessage.error('加载共有标签失败');\n }\n },\n handleInputChange() {\n clearTimeout(this.debounceTimer);\n if (!this.inputTag || this.inputTag.trim().length === 0) {\n this.showSuggestions = false;\n return;\n }\n this.debounceTimer = setTimeout(() => {\n this.fetchSuggestions();\n }, 300);\n },\n async fetchSuggestions() {\n try {\n const prefix = this.inputTag.trim().toLowerCase();\n const response = await fetchWithAuth(`/api/manage/tags/autocomplete?prefix=${encodeURIComponent(prefix)}&limit=10`, {\n method: 'GET'\n });\n if (response.ok) {\n const data = await response.json();\n this.suggestions = (data.tags || []).filter(tag => !this.tagsToAdd.includes(tag));\n this.showSuggestions = this.suggestions.length > 0;\n }\n } catch (error) {\n console.error('Error fetching suggestions:', error);\n }\n },\n selectSuggestion(tag) {\n this.inputTag = tag;\n this.showSuggestions = false;\n this.handleAddInputTag();\n },\n handleAddInputTag() {\n const tag = this.inputTag.trim();\n if (!tag) {\n return;\n }\n if (this.tagsToAdd.includes(tag)) {\n ElMessage.warning('标签已在列表中');\n this.inputTag = '';\n this.showSuggestions = false;\n return;\n }\n this.tagsToAdd.push(tag);\n this.inputTag = '';\n this.showSuggestions = false;\n },\n removeFromToAdd(tag) {\n const index = this.tagsToAdd.indexOf(tag);\n if (index > -1) {\n this.tagsToAdd.splice(index, 1);\n }\n },\n async executeAddTags() {\n if (this.tagsToAdd.length === 0) {\n ElMessage.warning('请先添加要批量添加的标签');\n return;\n }\n this.loading = true;\n try {\n const response = await fetchWithAuth('/api/manage/tags/batch', {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json'\n },\n body: JSON.stringify({\n fileIds: this.fileIds,\n action: 'add',\n tags: this.tagsToAdd\n })\n });\n if (response.ok) {\n const data = await response.json();\n if (data.success || data.updated > 0) {\n ElMessage.success(`成功为 ${data.updated} 个文件添加标签`);\n this.$emit('tagsUpdated');\n this.tagsToAdd = [];\n } else {\n throw new Error('批量添加标签失败');\n }\n } else {\n throw new Error('批量添加标签失败');\n }\n } catch (error) {\n console.error('Error adding tags:', error);\n ElMessage.error('批量添加标签失败');\n } finally {\n this.loading = false;\n }\n },\n async handleRemoveCommonTag(tag) {\n this.loading = true;\n try {\n const response = await fetchWithAuth('/api/manage/tags/batch', {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json'\n },\n body: JSON.stringify({\n fileIds: this.fileIds,\n action: 'remove',\n tags: [tag]\n })\n });\n if (response.ok) {\n const data = await response.json();\n if (data.success || data.updated > 0) {\n ElMessage.success(`成功从 ${data.updated} 个文件中移除标签`);\n this.$emit('tagsUpdated');\n await this.loadCommonTags();\n } else {\n throw new Error('移除标签失败');\n }\n } else {\n throw new Error('移除标签失败');\n }\n } catch (error) {\n console.error('Error removing tag:', error);\n ElMessage.error('移除标签失败');\n } finally {\n this.loading = false;\n }\n },\n handleClearAllTags() {\n ElMessageBox.confirm(`确定要清空选中的 ${this.fileCount} 个文件的所有标签吗?此操作不可恢复。`, '确认清空', {\n confirmButtonText: '确定',\n cancelButtonText: '取消',\n type: 'warning'\n }).then(() => {\n this.executeClearTags();\n }).catch(() => {\n ElMessage.info('已取消清空操作');\n });\n },\n async executeClearTags() {\n this.loading = true;\n try {\n const response = await fetchWithAuth('/api/manage/tags/batch', {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json'\n },\n body: JSON.stringify({\n fileIds: this.fileIds,\n action: 'set',\n tags: []\n })\n });\n if (response.ok) {\n const data = await response.json();\n if (data.success || data.updated > 0) {\n ElMessage.success(`成功清空 ${data.updated} 个文件的标签`);\n this.$emit('tagsUpdated');\n this.commonTags = [];\n } else {\n throw new Error('清空标签失败');\n }\n } else {\n throw new Error('清空标签失败');\n }\n } catch (error) {\n console.error('Error clearing tags:', error);\n ElMessage.error('清空标签失败');\n } finally {\n this.loading = false;\n }\n },\n handleClose() {\n this.visible = false;\n }\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./BatchTagDialog.vue?vue&type=template&id=dacf7742&scoped=true\"\nimport script from \"./BatchTagDialog.vue?vue&type=script&lang=js\"\nexport * from \"./BatchTagDialog.vue?vue&type=script&lang=js\"\n\nimport \"./BatchTagDialog.vue?vue&type=style&index=0&id=dacf7742&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-dacf7742\"]])\n\nexport default __exports__","import { resolveComponent as _resolveComponent, createVNode as _createVNode, withCtx as _withCtx, withKeys as _withKeys, renderList as _renderList, Fragment as _Fragment, openBlock as _openBlock, createElementBlock as _createElementBlock, toDisplayString as _toDisplayString, createCommentVNode as _createCommentVNode, createElementVNode as _createElementVNode, createTextVNode as _createTextVNode, createBlock as _createBlock } from \"vue\";\nconst _hoisted_1 = {\n class: \"tag-management-container\"\n};\nconst _hoisted_2 = {\n class: \"input-section\"\n};\nconst _hoisted_3 = {\n key: 0,\n class: \"suggestions-panel\"\n};\nconst _hoisted_4 = [\"onClick\"];\nconst _hoisted_5 = {\n class: \"current-tags-section\"\n};\nconst _hoisted_6 = {\n key: 0,\n class: \"tags-container\"\n};\nconst _hoisted_7 = {\n key: 1,\n class: \"empty-message\"\n};\nconst _hoisted_8 = {\n class: \"popular-tags-section\"\n};\nconst _hoisted_9 = {\n key: 0,\n class: \"tags-container\"\n};\nconst _hoisted_10 = {\n key: 1,\n class: \"empty-message\"\n};\nconst _hoisted_11 = {\n key: 2,\n class: \"empty-message\"\n};\nconst _hoisted_12 = {\n class: \"dialog-footer\"\n};\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n const _component_el_button = _resolveComponent(\"el-button\");\n const _component_el_input = _resolveComponent(\"el-input\");\n const _component_el_tag = _resolveComponent(\"el-tag\");\n const _component_Loading = _resolveComponent(\"Loading\");\n const _component_el_icon = _resolveComponent(\"el-icon\");\n const _component_el_dialog = _resolveComponent(\"el-dialog\");\n return _openBlock(), _createBlock(_component_el_dialog, {\n title: \"标签管理\",\n modelValue: $options.visible,\n \"onUpdate:modelValue\": _cache[1] || (_cache[1] = $event => $options.visible = $event),\n width: $options.dialogWidth,\n onClose: $options.handleClose\n }, {\n footer: _withCtx(() => [_createElementVNode(\"span\", _hoisted_12, [_createVNode(_component_el_button, {\n onClick: $options.handleClose\n }, {\n default: _withCtx(() => [...(_cache[5] || (_cache[5] = [_createTextVNode(\"关闭\", -1)]))]),\n _: 1\n }, 8, [\"onClick\"])])]),\n default: _withCtx(() => [_createElementVNode(\"div\", _hoisted_1, [_createElementVNode(\"div\", _hoisted_2, [_createVNode(_component_el_input, {\n modelValue: $data.inputTag,\n \"onUpdate:modelValue\": _cache[0] || (_cache[0] = $event => $data.inputTag = $event),\n placeholder: \"输入标签名称\",\n onKeyup: _withKeys($options.handleAddTag, [\"enter\"]),\n onInput: $options.handleInputChange,\n clearable: \"\"\n }, {\n append: _withCtx(() => [_createVNode(_component_el_button, {\n onClick: $options.handleAddTag,\n type: \"primary\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"plus\"\n })]),\n _: 1\n }, 8, [\"onClick\"])]),\n _: 1\n }, 8, [\"modelValue\", \"onKeyup\", \"onInput\"]), $data.showSuggestions && $data.suggestions.length > 0 ? (_openBlock(), _createElementBlock(\"div\", _hoisted_3, [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($data.suggestions, tag => {\n return _openBlock(), _createElementBlock(\"div\", {\n key: tag,\n class: \"suggestion-item\",\n onClick: $event => $options.selectSuggestion(tag)\n }, _toDisplayString(tag), 9, _hoisted_4);\n }), 128))])) : _createCommentVNode(\"\", true)]), _createElementVNode(\"div\", _hoisted_5, [_cache[2] || (_cache[2] = _createElementVNode(\"h4\", null, \"当前标签\", -1)), $data.currentTags.length > 0 ? (_openBlock(), _createElementBlock(\"div\", _hoisted_6, [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($data.currentTags, tag => {\n return _openBlock(), _createBlock(_component_el_tag, {\n key: tag,\n closable: \"\",\n onClose: $event => $options.handleRemoveTag(tag),\n class: \"tag-item\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString(tag), 1)]),\n _: 2\n }, 1032, [\"onClose\"]);\n }), 128))])) : (_openBlock(), _createElementBlock(\"div\", _hoisted_7, \" 暂无标签 \"))]), _createElementVNode(\"div\", _hoisted_8, [_cache[4] || (_cache[4] = _createElementVNode(\"h4\", null, \"常用标签\", -1)), $data.popularTags.length > 0 ? (_openBlock(), _createElementBlock(\"div\", _hoisted_9, [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($data.popularTags, tag => {\n return _openBlock(), _createBlock(_component_el_tag, {\n key: tag,\n onClick: $event => $options.handleAddPopularTag(tag),\n class: \"tag-item clickable\",\n type: \"info\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString(tag), 1)]),\n _: 2\n }, 1032, [\"onClick\"]);\n }), 128))])) : $data.loadingPopularTags ? (_openBlock(), _createElementBlock(\"div\", _hoisted_10, [_createVNode(_component_el_icon, {\n class: \"is-loading\"\n }, {\n default: _withCtx(() => [_createVNode(_component_Loading)]),\n _: 1\n }), _cache[3] || (_cache[3] = _createTextVNode(\" 加载中... \", -1))])) : (_openBlock(), _createElementBlock(\"div\", _hoisted_11, \" 暂无常用标签 \"))])])]),\n _: 1\n }, 8, [\"modelValue\", \"width\", \"onClose\"]);\n}","import \"core-js/modules/es.iterator.constructor.js\";\nimport \"core-js/modules/es.iterator.filter.js\";\nimport \"core-js/modules/es.json.stringify.js\";\nimport { ElMessage } from 'element-plus';\nimport { Loading } from '@element-plus/icons-vue';\nimport fetchWithAuth from '@/utils/fetchWithAuth';\nexport default {\n name: 'TagManagementDialog',\n components: {\n Loading\n },\n props: {\n modelValue: {\n type: Boolean,\n default: false\n },\n fileId: {\n type: String,\n required: true\n }\n },\n emits: ['update:modelValue', 'tagsUpdated'],\n data() {\n return {\n currentTags: [],\n inputTag: '',\n suggestions: [],\n popularTags: [],\n showSuggestions: false,\n loading: false,\n loadingPopularTags: false,\n debounceTimer: null\n };\n },\n computed: {\n visible: {\n get() {\n return this.modelValue;\n },\n set(val) {\n this.$emit('update:modelValue', val);\n }\n },\n dialogWidth() {\n return window.innerWidth < 768 ? '90%' : '500px';\n }\n },\n watch: {\n visible(newVal) {\n if (newVal) {\n this.loadFileTags();\n this.loadPopularTags();\n }\n }\n },\n methods: {\n async loadFileTags() {\n try {\n const response = await fetchWithAuth(`/api/manage/tags/${encodeURIComponent(this.fileId)}`, {\n method: 'GET'\n });\n if (response.ok) {\n const data = await response.json();\n this.currentTags = data.tags || [];\n } else {\n throw new Error('Failed to load tags');\n }\n } catch (error) {\n console.error('Error loading file tags:', error);\n ElMessage.error('加载标签失败');\n }\n },\n async loadPopularTags() {\n this.loadingPopularTags = true;\n try {\n const response = await fetchWithAuth('/api/manage/tags/autocomplete?limit=20', {\n method: 'GET'\n });\n if (response.ok) {\n const data = await response.json();\n this.popularTags = (data.tags || []).filter(tag => !this.currentTags.includes(tag));\n }\n } catch (error) {\n console.error('Error loading popular tags:', error);\n } finally {\n this.loadingPopularTags = false;\n }\n },\n handleInputChange() {\n clearTimeout(this.debounceTimer);\n if (!this.inputTag || this.inputTag.trim().length === 0) {\n this.showSuggestions = false;\n return;\n }\n this.debounceTimer = setTimeout(() => {\n this.fetchSuggestions();\n }, 300);\n },\n async fetchSuggestions() {\n try {\n const prefix = this.inputTag.trim().toLowerCase();\n const response = await fetchWithAuth(`/api/manage/tags/autocomplete?prefix=${encodeURIComponent(prefix)}&limit=10`, {\n method: 'GET'\n });\n if (response.ok) {\n const data = await response.json();\n this.suggestions = (data.tags || []).filter(tag => !this.currentTags.includes(tag));\n this.showSuggestions = this.suggestions.length > 0;\n }\n } catch (error) {\n console.error('Error fetching suggestions:', error);\n }\n },\n selectSuggestion(tag) {\n this.inputTag = tag;\n this.showSuggestions = false;\n this.handleAddTag();\n },\n async handleAddTag() {\n const tag = this.inputTag.trim();\n if (!tag) {\n return;\n }\n if (this.currentTags.includes(tag)) {\n ElMessage.warning('标签已存在');\n this.inputTag = '';\n this.showSuggestions = false;\n return;\n }\n try {\n const response = await fetchWithAuth(`/api/manage/tags/${encodeURIComponent(this.fileId)}`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json'\n },\n body: JSON.stringify({\n action: 'add',\n tags: [tag]\n })\n });\n if (response.ok) {\n const data = await response.json();\n this.currentTags = data.tags || [];\n this.inputTag = '';\n this.showSuggestions = false;\n ElMessage.success('标签添加成功');\n this.$emit('tagsUpdated', this.currentTags);\n\n // 重新加载常用标签\n this.loadPopularTags();\n } else {\n const error = await response.json();\n throw new Error(error.message || '添加标签失败');\n }\n } catch (error) {\n console.error('Error adding tag:', error);\n ElMessage.error(error.message || '添加标签失败');\n }\n },\n async handleRemoveTag(tag) {\n try {\n const response = await fetchWithAuth(`/api/manage/tags/${encodeURIComponent(this.fileId)}`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json'\n },\n body: JSON.stringify({\n action: 'remove',\n tags: [tag]\n })\n });\n if (response.ok) {\n const data = await response.json();\n this.currentTags = data.tags || [];\n ElMessage.success('标签删除成功');\n this.$emit('tagsUpdated', this.currentTags);\n\n // 重新加载常用标签\n this.loadPopularTags();\n } else {\n throw new Error('删除标签失败');\n }\n } catch (error) {\n console.error('Error removing tag:', error);\n ElMessage.error('删除标签失败');\n }\n },\n handleAddPopularTag(tag) {\n this.inputTag = tag;\n this.handleAddTag();\n },\n handleClose() {\n this.visible = false;\n this.inputTag = '';\n this.showSuggestions = false;\n this.currentTags = [];\n this.popularTags = [];\n }\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./TagManagementDialog.vue?vue&type=template&id=8b4291b4&scoped=true\"\nimport script from \"./TagManagementDialog.vue?vue&type=script&lang=js\"\nexport * from \"./TagManagementDialog.vue?vue&type=script&lang=js\"\n\nimport \"./TagManagementDialog.vue?vue&type=style&index=0&id=8b4291b4&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-8b4291b4\"]])\n\nexport default __exports__","import { resolveComponent as _resolveComponent, createVNode as _createVNode, createTextVNode as _createTextVNode, withCtx as _withCtx, createElementVNode as _createElementVNode, openBlock as _openBlock, createBlock as _createBlock, createCommentVNode as _createCommentVNode, createElementBlock as _createElementBlock, toDisplayString as _toDisplayString, renderList as _renderList, Fragment as _Fragment } from \"vue\";\nconst _hoisted_1 = {\n class: \"detail-actions\"\n};\nconst _hoisted_2 = {\n class: \"preview-section\"\n};\nconst _hoisted_3 = {\n class: \"preview-content\"\n};\nconst _hoisted_4 = [\"src\"];\nconst _hoisted_5 = [\"src\"];\nconst _hoisted_6 = {\n key: 0,\n style: {\n \"display\": \"flex\",\n \"flex-wrap\": \"wrap\",\n \"gap\": \"5px\"\n }\n};\nconst _hoisted_7 = {\n key: 1,\n style: {\n \"color\": \"#909399\"\n }\n};\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n const _component_el_button = _resolveComponent(\"el-button\");\n const _component_el_input = _resolveComponent(\"el-input\");\n const _component_el_tab_pane = _resolveComponent(\"el-tab-pane\");\n const _component_el_tabs = _resolveComponent(\"el-tabs\");\n const _component_el_image = _resolveComponent(\"el-image\");\n const _component_el_descriptions_item = _resolveComponent(\"el-descriptions-item\");\n const _component_el_tag = _resolveComponent(\"el-tag\");\n const _component_el_descriptions = _resolveComponent(\"el-descriptions\");\n const _component_el_dialog = _resolveComponent(\"el-dialog\");\n return _openBlock(), _createBlock(_component_el_dialog, {\n title: \"文件详情\",\n modelValue: $options.visible,\n \"onUpdate:modelValue\": _cache[14] || (_cache[14] = $event => $options.visible = $event),\n width: $options.dialogWidth\n }, {\n default: _withCtx(() => [_createElementVNode(\"div\", _hoisted_1, [_createVNode(_component_el_button, {\n type: \"primary\",\n onClick: _cache[0] || (_cache[0] = $event => _ctx.$emit('download')),\n round: \"\",\n size: \"small\",\n class: \"detail-action\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"download\",\n style: {\n \"margin-right\": \"3px\"\n }\n }), _cache[15] || (_cache[15] = _createTextVNode(\" 下载 \", -1))]),\n _: 1\n }), _createVNode(_component_el_button, {\n type: \"primary\",\n onClick: _cache[1] || (_cache[1] = $event => _ctx.$emit('tagManagement')),\n round: \"\",\n size: \"small\",\n class: \"detail-action\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"tags\",\n style: {\n \"margin-right\": \"3px\"\n }\n }), _cache[16] || (_cache[16] = _createTextVNode(\" 标签 \", -1))]),\n _: 1\n }), _createVNode(_component_el_button, {\n type: \"primary\",\n onClick: _cache[2] || (_cache[2] = $event => _ctx.$emit('block')),\n round: \"\",\n size: \"small\",\n class: \"detail-action\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"ban\",\n style: {\n \"margin-right\": \"3px\"\n }\n }), _cache[17] || (_cache[17] = _createTextVNode(\" 黑名单 \", -1))]),\n _: 1\n }), _createVNode(_component_el_button, {\n type: \"primary\",\n onClick: _cache[3] || (_cache[3] = $event => _ctx.$emit('white')),\n round: \"\",\n size: \"small\",\n class: \"detail-action\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"user-plus\",\n style: {\n \"margin-right\": \"3px\"\n }\n }), _cache[18] || (_cache[18] = _createTextVNode(\" 白名单 \", -1))]),\n _: 1\n }), _createVNode(_component_el_button, {\n type: \"danger\",\n onClick: _cache[4] || (_cache[4] = $event => _ctx.$emit('delete')),\n round: \"\",\n size: \"small\",\n class: \"detail-action\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"trash-alt\",\n style: {\n \"margin-right\": \"3px\"\n }\n }), _cache[19] || (_cache[19] = _createTextVNode(\" 删除 \", -1))]),\n _: 1\n })]), _createVNode(_component_el_tabs, {\n modelValue: $data.activeTab,\n \"onUpdate:modelValue\": _cache[12] || (_cache[12] = $event => $data.activeTab = $event),\n onTabClick: $options.handleTabClick,\n style: {\n \"margin-bottom\": \"10px\"\n }\n }, {\n default: _withCtx(() => [_createVNode(_component_el_tab_pane, {\n label: \"原始链接\",\n name: \"originUrl\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $props.urls.originUrl,\n \"onUpdate:modelValue\": _cache[5] || (_cache[5] = $event => $props.urls.originUrl = $event),\n readonly: \"\",\n onClick: $options.handleUrlClick\n }, null, 8, [\"modelValue\", \"onClick\"])]),\n _: 1\n }), _createVNode(_component_el_tab_pane, {\n label: \"Markdown\",\n name: \"mdUrl\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $props.urls.mdUrl,\n \"onUpdate:modelValue\": _cache[6] || (_cache[6] = $event => $props.urls.mdUrl = $event),\n readonly: \"\",\n onClick: $options.handleUrlClick\n }, null, 8, [\"modelValue\", \"onClick\"])]),\n _: 1\n }), _createVNode(_component_el_tab_pane, {\n label: \"HTML\",\n name: \"htmlUrl\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $props.urls.htmlUrl,\n \"onUpdate:modelValue\": _cache[7] || (_cache[7] = $event => $props.urls.htmlUrl = $event),\n readonly: \"\",\n onClick: $options.handleUrlClick\n }, null, 8, [\"modelValue\", \"onClick\"])]),\n _: 1\n }), _createVNode(_component_el_tab_pane, {\n label: \"BBCode\",\n name: \"bbUrl\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $props.urls.bbUrl,\n \"onUpdate:modelValue\": _cache[8] || (_cache[8] = $event => $props.urls.bbUrl = $event),\n readonly: \"\",\n onClick: $options.handleUrlClick\n }, null, 8, [\"modelValue\", \"onClick\"])]),\n _: 1\n }), $props.file?.metadata?.TgFileId ? (_openBlock(), _createBlock(_component_el_tab_pane, {\n key: 0,\n label: \"TG File ID\",\n name: \"tgId\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $props.urls.tgId,\n \"onUpdate:modelValue\": _cache[9] || (_cache[9] = $event => $props.urls.tgId = $event),\n readonly: \"\",\n onClick: $options.handleUrlClick\n }, null, 8, [\"modelValue\", \"onClick\"])]),\n _: 1\n })) : _createCommentVNode(\"\", true), $props.file?.metadata?.S3Location ? (_openBlock(), _createBlock(_component_el_tab_pane, {\n key: 1,\n label: \"S3 Location\",\n name: \"s3Location\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $props.urls.S3Location,\n \"onUpdate:modelValue\": _cache[10] || (_cache[10] = $event => $props.urls.S3Location = $event),\n readonly: \"\",\n onClick: $options.handleUrlClick\n }, null, 8, [\"modelValue\", \"onClick\"])]),\n _: 1\n })) : _createCommentVNode(\"\", true), $props.file?.metadata?.S3CdnFileUrl ? (_openBlock(), _createBlock(_component_el_tab_pane, {\n key: 2,\n label: \"S3 CDN URL\",\n name: \"s3CdnFileUrl\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $props.urls.S3CdnFileUrl,\n \"onUpdate:modelValue\": _cache[11] || (_cache[11] = $event => $props.urls.S3CdnFileUrl = $event),\n readonly: \"\",\n onClick: $options.handleUrlClick\n }, null, 8, [\"modelValue\", \"onClick\"])]),\n _: 1\n })) : _createCommentVNode(\"\", true)]),\n _: 1\n }, 8, [\"modelValue\", \"onTabClick\"]), _createElementVNode(\"div\", _hoisted_2, [_createElementVNode(\"div\", _hoisted_3, [$options.isVideo ? (_openBlock(), _createElementBlock(\"video\", {\n key: 0,\n src: $props.fileLink,\n autoplay: \"\",\n muted: \"\",\n loop: \"\",\n class: \"video-preview\",\n onClick: _cache[13] || (_cache[13] = (...args) => $options.openImageLink && $options.openImageLink(...args))\n }, null, 8, _hoisted_4)) : $options.isAudio ? (_openBlock(), _createElementBlock(\"audio\", {\n key: 1,\n src: $props.fileLink,\n controls: \"\",\n autoplay: \"\",\n class: \"audio-preview\"\n }, null, 8, _hoisted_5)) : $options.isImage ? (_openBlock(), _createBlock(_component_el_image, {\n key: 2,\n src: $props.fileLink,\n \"preview-src-list\": [$props.fileLink],\n \"preview-teleported\": true,\n fit: \"contain\",\n lazy: \"\",\n class: \"image-preview\"\n }, null, 8, [\"src\", \"preview-src-list\"])) : (_openBlock(), _createBlock(_component_font_awesome_icon, {\n key: 3,\n icon: \"file\",\n class: \"file-icon-detail\"\n }))])]), _createVNode(_component_el_descriptions, {\n border: \"\",\n column: $options.descColumn\n }, {\n default: _withCtx(() => [_createVNode(_component_el_descriptions_item, {\n label: \"文件名\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($props.file?.metadata?.FileName || $props.file?.name), 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"文件类型\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($props.file?.metadata?.FileType || '未知'), 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"文件大小\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($props.file?.metadata?.FileSize ? $props.file.metadata.FileSize + ' MB' : '未知'), 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"上传时间\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($options.uploadTime), 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"渠道类型/名称\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($props.file?.metadata?.Channel || '未知') + \" / \" + _toDisplayString($props.file?.metadata?.ChannelName || '-'), 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"访问状态/审查\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($options.accessType) + \" / \" + _toDisplayString($props.file?.metadata?.Label || '无'), 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"上传IP\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($props.file?.metadata?.UploadIP || '未知'), 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"上传地址\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($props.file?.metadata?.UploadAddress || '未知'), 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"文件标签\"\n }, {\n default: _withCtx(() => [$props.file?.metadata?.Tags && $props.file?.metadata?.Tags.length > 0 ? (_openBlock(), _createElementBlock(\"div\", _hoisted_6, [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($props.file?.metadata?.Tags, tag => {\n return _openBlock(), _createBlock(_component_el_tag, {\n key: tag,\n size: \"small\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString(tag), 1)]),\n _: 2\n }, 1024);\n }), 128))])) : (_openBlock(), _createElementBlock(\"span\", _hoisted_7, \"暂无标签\"))]),\n _: 1\n })]),\n _: 1\n }, 8, [\"column\"])]),\n _: 1\n }, 8, [\"modelValue\", \"width\"]);\n}","import { ElMessage } from 'element-plus';\nexport default {\n name: 'FileDetailDialog',\n props: {\n modelValue: {\n type: Boolean,\n default: false\n },\n file: {\n type: Object,\n default: null\n },\n fileLink: {\n type: String,\n default: ''\n },\n urls: {\n type: Object,\n default: () => ({\n originUrl: '',\n mdUrl: '',\n htmlUrl: '',\n bbUrl: '',\n tgId: '',\n S3Location: '',\n S3CdnFileUrl: ''\n })\n }\n },\n emits: ['update:modelValue', 'download', 'tagManagement', 'block', 'white', 'delete'],\n data() {\n return {\n activeTab: 'originUrl'\n };\n },\n computed: {\n visible: {\n get() {\n return this.modelValue;\n },\n set(val) {\n this.$emit('update:modelValue', val);\n }\n },\n dialogWidth() {\n return window.innerWidth < 768 ? '95%' : '900px';\n },\n descColumn() {\n return window.innerWidth < 768 ? 1 : 2;\n },\n isVideo() {\n // 先通过 content-type 判断\n const fileType = this.file?.metadata?.FileType?.toLowerCase() || '';\n if (fileType.includes('video')) return true;\n // 再通过文件后缀判断\n const name = this.file?.name?.toLowerCase() || '';\n return name.endsWith('.mp4') || name.endsWith('.webm') || name.endsWith('.mov') || name.endsWith('.avi');\n },\n isAudio() {\n // 先通过 content-type 判断\n const fileType = this.file?.metadata?.FileType?.toLowerCase() || '';\n if (fileType.includes('audio')) return true;\n // 再通过文件后缀判断\n const name = this.file?.name?.toLowerCase() || '';\n return name.endsWith('.mp3') || name.endsWith('.wav') || name.endsWith('.ogg') || name.endsWith('.flac');\n },\n isImage() {\n // 先通过 content-type 判断\n const fileType = this.file?.metadata?.FileType?.toLowerCase() || '';\n if (fileType.includes('image')) return true;\n // 再通过文件后缀判断\n const name = this.file?.name?.toLowerCase() || '';\n return name.endsWith('.jpg') || name.endsWith('.jpeg') || name.endsWith('.png') || name.endsWith('.gif') || name.endsWith('.webp') || name.endsWith('.svg') || name.endsWith('.bmp') || name.endsWith('.avif') || name.endsWith('.heic') || name.endsWith('.heif');\n },\n uploadTime() {\n if (this.file?.metadata?.TimeStamp) {\n return new Date(this.file.metadata.TimeStamp).toLocaleString();\n }\n return '未知';\n },\n accessType() {\n const listType = this.file?.metadata?.ListType;\n const label = this.file?.metadata?.Label;\n if (listType === 'White') return '正常(白名单)';\n if (listType === 'Block') return '已屏蔽(黑名单)';\n if (label === 'adult') return '已屏蔽(审查不通过)';\n return '正常';\n }\n },\n methods: {\n handleVideoClick(e) {\n const video = e.target;\n if (video.paused) video.play();else video.pause();\n },\n handleTabClick() {},\n handleUrlClick(e) {\n const input = e.target;\n input.select();\n navigator.clipboard.writeText(input.value).then(() => {\n ElMessage.success('链接已复制');\n });\n },\n openImageLink() {\n if (this.fileLink) {\n // 移除 ?from=admin 参数\n const cleanUrl = this.fileLink.replace(/\\?from=admin$/, '');\n window.open(cleanUrl, '_blank');\n }\n }\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./FileDetailDialog.vue?vue&type=template&id=0dc381fc&scoped=true\"\nimport script from \"./FileDetailDialog.vue?vue&type=script&lang=js\"\nexport * from \"./FileDetailDialog.vue?vue&type=script&lang=js\"\n\nimport \"./FileDetailDialog.vue?vue&type=style&index=0&id=0dc381fc&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-0dc381fc\"]])\n\nexport default __exports__","import { resolveComponent as _resolveComponent, openBlock as _openBlock, createBlock as _createBlock, createCommentVNode as _createCommentVNode, withModifiers as _withModifiers, normalizeClass as _normalizeClass, createElementVNode as _createElementVNode, createElementBlock as _createElementBlock, toDisplayString as _toDisplayString, renderList as _renderList, Fragment as _Fragment, normalizeStyle as _normalizeStyle, createVNode as _createVNode, withCtx as _withCtx } from \"vue\";\nconst _hoisted_1 = {\n class: \"list-col list-col-checkbox\"\n};\nconst _hoisted_2 = [\"src\"];\nconst _hoisted_3 = [\"src\"];\nconst _hoisted_4 = [\"title\"];\nconst _hoisted_5 = {\n class: \"filename-start\"\n};\nconst _hoisted_6 = {\n class: \"filename-end\"\n};\nconst _hoisted_7 = {\n class: \"list-col list-col-tags\"\n};\nconst _hoisted_8 = {\n key: 1,\n class: \"list-empty\"\n};\nconst _hoisted_9 = {\n class: \"list-col list-col-channel\"\n};\nconst _hoisted_10 = {\n class: \"list-col list-col-channel-name\"\n};\nconst _hoisted_11 = {\n key: 0,\n class: \"channel-name-box\"\n};\nconst _hoisted_12 = {\n key: 1,\n class: \"list-empty\"\n};\nconst _hoisted_13 = {\n class: \"list-col list-col-address\"\n};\nconst _hoisted_14 = {\n key: 0,\n class: \"address-box\"\n};\nconst _hoisted_15 = {\n key: 1,\n class: \"list-empty\"\n};\nconst _hoisted_16 = {\n class: \"list-col list-col-size\"\n};\nconst _hoisted_17 = {\n class: \"list-col list-col-date\"\n};\nconst _hoisted_18 = {\n class: \"list-col list-col-actions\"\n};\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n const _component_el_tooltip = _resolveComponent(\"el-tooltip\");\n return _openBlock(), _createElementBlock(\"div\", {\n class: \"list-item\",\n onTouchstart: _cache[9] || (_cache[9] = $event => _ctx.$emit('touchstart', $event)),\n onTouchend: _cache[10] || (_cache[10] = $event => _ctx.$emit('touchend', $event)),\n onTouchmove: _cache[11] || (_cache[11] = $event => _ctx.$emit('touchmove', $event))\n }, [_createElementVNode(\"div\", _hoisted_1, [_createElementVNode(\"span\", {\n class: _normalizeClass([\"custom-checkbox\", {\n 'checked': $data.localSelected\n }]),\n onClick: _cache[0] || (_cache[0] = _withModifiers((...args) => $options.toggleSelect && $options.toggleSelect(...args), [\"stop\"]))\n }, [$data.localSelected ? (_openBlock(), _createBlock(_component_font_awesome_icon, {\n key: 0,\n icon: \"check\",\n class: \"check-icon\"\n })) : _createCommentVNode(\"\", true)], 2)]), _createElementVNode(\"div\", {\n class: \"list-col list-col-preview\",\n onClick: _cache[1] || (_cache[1] = (...args) => $options.handlePreviewClick && $options.handlePreviewClick(...args))\n }, [$options.isFolder ? (_openBlock(), _createBlock(_component_font_awesome_icon, {\n key: 0,\n icon: \"folder-open\",\n class: \"list-folder-icon\"\n })) : $options.isVideo ? (_openBlock(), _createElementBlock(\"video\", {\n key: 1,\n src: $props.fileLink,\n class: \"list-preview-img\",\n muted: \"\",\n preload: \"metadata\"\n }, null, 8, _hoisted_2)) : $options.isImage ? (_openBlock(), _createElementBlock(\"img\", {\n key: 2,\n src: $props.fileLink,\n class: \"list-preview-img\",\n loading: \"lazy\",\n decoding: \"async\"\n }, null, 8, _hoisted_3)) : (_openBlock(), _createBlock(_component_font_awesome_icon, {\n key: 3,\n icon: \"file\",\n class: \"list-file-icon\"\n }))]), _createElementVNode(\"div\", {\n class: \"list-col list-col-name\",\n onClick: _cache[2] || (_cache[2] = (...args) => $options.handlePreviewClick && $options.handlePreviewClick(...args))\n }, [_createElementVNode(\"span\", {\n class: \"filename-ellipsis\",\n title: $options.displayName\n }, [_createElementVNode(\"span\", _hoisted_5, _toDisplayString($options.fileNameStart), 1), _createElementVNode(\"span\", _hoisted_6, _toDisplayString($options.fileNameEnd), 1)], 8, _hoisted_4)]), _createElementVNode(\"div\", _hoisted_7, [!$options.isFolder && $props.item.metadata?.Tags && $props.item.metadata.Tags.length > 0 ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 0\n }, [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($props.item.metadata.Tags.slice(0, 3), (tag, tagIndex) => {\n return _openBlock(), _createElementBlock(\"span\", {\n key: tagIndex,\n class: \"color-tag\",\n style: _normalizeStyle({\n background: $options.getTagColor(tagIndex)\n })\n }, _toDisplayString(tag), 5);\n }), 128)), $props.item.metadata.Tags.length > 3 ? (_openBlock(), _createElementBlock(\"span\", {\n key: 0,\n class: \"color-tag color-tag-more\",\n style: _normalizeStyle({\n background: $options.getTagColor(3)\n })\n }, \"+\" + _toDisplayString($props.item.metadata.Tags.length - 3), 5)) : _createCommentVNode(\"\", true)], 64)) : (_openBlock(), _createElementBlock(\"span\", _hoisted_8, \"-\"))]), _createElementVNode(\"div\", _hoisted_9, _toDisplayString($options.isFolder ? '-' : $props.item.metadata?.Channel || $props.item.channelTag || '-'), 1), _createElementVNode(\"div\", _hoisted_10, [!$options.isFolder && $props.item.metadata?.ChannelName ? (_openBlock(), _createElementBlock(\"div\", _hoisted_11, _toDisplayString($props.item.metadata.ChannelName), 1)) : (_openBlock(), _createElementBlock(\"span\", _hoisted_12, \"-\"))]), _createElementVNode(\"div\", _hoisted_13, [!$options.isFolder && $props.item.metadata?.UploadIP ? (_openBlock(), _createElementBlock(\"div\", _hoisted_14, _toDisplayString($props.item.metadata.UploadIP), 1)) : (_openBlock(), _createElementBlock(\"span\", _hoisted_15, \"-\"))]), _createElementVNode(\"div\", _hoisted_16, _toDisplayString($options.isFolder ? '-' : $props.item.metadata?.FileSize ? $props.item.metadata.FileSize + ' MB' : '-'), 1), _createElementVNode(\"div\", _hoisted_17, _toDisplayString($options.uploadDate), 1), _createElementVNode(\"div\", _hoisted_18, [!$options.isFolder ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 0\n }, [_createVNode(_component_el_tooltip, {\n content: \"复制链接\",\n placement: \"top\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"button\", {\n class: \"list-action-btn\",\n onClick: _cache[3] || (_cache[3] = _withModifiers($event => _ctx.$emit('copy'), [\"stop\"]))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"copy\"\n })])]),\n _: 1\n }), _createVNode(_component_el_tooltip, {\n content: \"下载\",\n placement: \"top\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"button\", {\n class: \"list-action-btn\",\n onClick: _cache[4] || (_cache[4] = _withModifiers($event => _ctx.$emit('download'), [\"stop\"]))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"download\"\n })])]),\n _: 1\n }), _createVNode(_component_el_tooltip, {\n content: \"移动\",\n placement: \"top\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"button\", {\n class: \"list-action-btn\",\n onClick: _cache[5] || (_cache[5] = _withModifiers($event => _ctx.$emit('move'), [\"stop\"]))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"file-export\"\n })])]),\n _: 1\n })], 64)) : (_openBlock(), _createElementBlock(_Fragment, {\n key: 1\n }, [_createVNode(_component_el_tooltip, {\n content: \"复制链接\",\n placement: \"top\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"button\", {\n class: \"list-action-btn\",\n onClick: _cache[6] || (_cache[6] = _withModifiers($event => _ctx.$emit('folderCopy'), [\"stop\"]))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"copy\"\n })])]),\n _: 1\n }), _createVNode(_component_el_tooltip, {\n content: \"移动\",\n placement: \"top\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"button\", {\n class: \"list-action-btn\",\n onClick: _cache[7] || (_cache[7] = _withModifiers($event => _ctx.$emit('move'), [\"stop\"]))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"file-export\"\n })])]),\n _: 1\n })], 64)), _createVNode(_component_el_tooltip, {\n content: \"删除\",\n placement: \"top\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"button\", {\n class: \"list-action-btn list-action-danger\",\n onClick: _cache[8] || (_cache[8] = _withModifiers($event => _ctx.$emit('delete'), [\"stop\"]))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"trash-alt\"\n })])]),\n _: 1\n })])], 32);\n}","import \"core-js/modules/es.iterator.constructor.js\";\nimport \"core-js/modules/es.iterator.filter.js\";\nexport default {\n name: 'FileListItem',\n props: {\n item: {\n type: Object,\n required: true\n },\n selected: {\n type: Boolean,\n default: false\n },\n fileLink: {\n type: String,\n default: ''\n }\n },\n emits: ['update:selected', 'enter', 'detail', 'copy', 'folderCopy', 'move', 'delete', 'download', 'touchstart', 'touchend', 'touchmove'],\n data() {\n return {\n localSelected: this.selected,\n tagColors: ['#f472b6', '#a78bfa', '#60a5fa', '#34d399']\n };\n },\n computed: {\n isFolder() {\n return this.item.name?.endsWith('/');\n },\n isVideo() {\n const name = this.item.name?.toLowerCase() || '';\n return name.endsWith('.mp4') || name.endsWith('.webm') || name.endsWith('.mov') || name.endsWith('.avi');\n },\n isImage() {\n const name = this.item.name?.toLowerCase() || '';\n return name.endsWith('.jpg') || name.endsWith('.jpeg') || name.endsWith('.png') || name.endsWith('.gif') || name.endsWith('.webp') || name.endsWith('.svg') || name.endsWith('.bmp');\n },\n displayName() {\n if (this.isFolder) {\n const parts = this.item.name.split('/').filter(Boolean);\n return parts[parts.length - 1] || this.item.name;\n }\n return this.item.metadata?.FileName || this.getFileName(this.item.name);\n },\n fileNameStart() {\n const name = this.displayName;\n if (name.length <= 20) return name;\n return name.slice(0, -8);\n },\n fileNameEnd() {\n const name = this.displayName;\n if (name.length <= 20) return '';\n return name.slice(-8);\n },\n uploadDate() {\n if (this.item.uploaded) {\n return new Date(this.item.uploaded).toLocaleDateString();\n }\n if (this.item.metadata?.TimeStamp) {\n return new Date(this.item.metadata.TimeStamp).toLocaleDateString();\n }\n return '-';\n }\n },\n watch: {\n selected(val) {\n this.localSelected = val;\n }\n },\n methods: {\n toggleSelect() {\n this.localSelected = !this.localSelected;\n this.$emit('update:selected', this.localSelected);\n },\n handlePreviewClick() {\n if (this.isFolder) {\n this.$emit('enter');\n } else {\n this.$emit('detail');\n }\n },\n getFileName(name) {\n const parts = (name || '').split('/');\n return parts[parts.length - 1];\n },\n getTagColor(index) {\n return this.tagColors[index % this.tagColors.length];\n }\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./FileListItem.vue?vue&type=template&id=9968e9fe&scoped=true\"\nimport script from \"./FileListItem.vue?vue&type=script&lang=js\"\nexport * from \"./FileListItem.vue?vue&type=script&lang=js\"\n\nimport \"./FileListItem.vue?vue&type=style&index=0&id=9968e9fe&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-9968e9fe\"]])\n\nexport default __exports__","import { resolveComponent as _resolveComponent, createVNode as _createVNode, toDisplayString as _toDisplayString, openBlock as _openBlock, createElementBlock as _createElementBlock, createCommentVNode as _createCommentVNode, createTextVNode as _createTextVNode, createElementVNode as _createElementVNode, vShow as _vShow, withDirectives as _withDirectives, Fragment as _Fragment, withModifiers as _withModifiers, withCtx as _withCtx, createBlock as _createBlock } from \"vue\";\nconst _hoisted_1 = {\n class: \"file-short-info\"\n};\nconst _hoisted_2 = {\n key: 0,\n class: \"success-tag\"\n};\nconst _hoisted_3 = {\n key: 1,\n class: \"fail-tag\"\n};\nconst _hoisted_4 = {\n key: 2,\n class: \"success-tag\"\n};\nconst _hoisted_5 = {\n key: 3,\n class: \"primary-tag\"\n};\nconst _hoisted_6 = {\n key: 0,\n style: {\n \"margin-left\": \"2px\"\n }\n};\nconst _hoisted_7 = {\n key: 0,\n class: \"skeleton-wrapper\"\n};\nconst _hoisted_8 = [\"src\"];\nconst _hoisted_9 = {\n key: 3,\n class: \"file-preview\"\n};\nconst _hoisted_10 = {\n class: \"card-bottom-overlay\"\n};\nconst _hoisted_11 = {\n class: \"file-name-row\"\n};\nconst _hoisted_12 = {\n class: \"file-name\"\n};\nconst _hoisted_13 = {\n class: \"action-bar\"\n};\nconst _hoisted_14 = {\n class: \"action-bar-left\"\n};\nconst _hoisted_15 = {\n class: \"action-bar-right\"\n};\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_el_checkbox = _resolveComponent(\"el-checkbox\");\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n const _component_el_image = _resolveComponent(\"el-image\");\n const _component_el_tooltip = _resolveComponent(\"el-tooltip\");\n const _component_el_card = _resolveComponent(\"el-card\");\n return _openBlock(), _createBlock(_component_el_card, {\n class: \"img-card\",\n onTouchstart: _cache[17] || (_cache[17] = $event => _ctx.$emit('touchstart', $event)),\n onTouchend: _cache[18] || (_cache[18] = $event => _ctx.$emit('touchend', $event)),\n onTouchmove: _cache[19] || (_cache[19] = $event => _ctx.$emit('touchmove', $event))\n }, {\n default: _withCtx(() => [_createVNode(_component_el_checkbox, {\n modelValue: $data.localSelected,\n \"onUpdate:modelValue\": _cache[0] || (_cache[0] = $event => $data.localSelected = $event),\n onChange: _cache[1] || (_cache[1] = $event => _ctx.$emit('update:selected', $data.localSelected))\n }, null, 8, [\"modelValue\"]), _createElementVNode(\"div\", _hoisted_1, [$props.item.metadata?.ListType === 'White' ? (_openBlock(), _createElementBlock(\"div\", _hoisted_2, _toDisplayString($options.channelTag), 1)) : $props.item.metadata?.ListType === 'Block' || $props.item.metadata?.Label === 'adult' ? (_openBlock(), _createElementBlock(\"div\", _hoisted_3, _toDisplayString($options.channelTag), 1)) : (_openBlock(), _createElementBlock(\"div\", _hoisted_4, _toDisplayString($options.channelTag), 1)), $props.item.metadata?.Tags && $props.item.metadata?.Tags.length > 0 ? (_openBlock(), _createElementBlock(\"div\", _hoisted_5, [_createVNode(_component_font_awesome_icon, {\n icon: \"tag\",\n style: {\n \"margin-right\": \"3px\",\n \"font-size\": \"12px\"\n }\n }), _createTextVNode(\" \" + _toDisplayString($props.item.metadata.Tags[0]) + \" \", 1), $props.item.metadata.Tags.length > 1 ? (_openBlock(), _createElementBlock(\"span\", _hoisted_6, \" (+\" + _toDisplayString($props.item.metadata.Tags.length - 1) + \") \", 1)) : _createCommentVNode(\"\", true)])) : _createCommentVNode(\"\", true)]), $options.isVideo ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 0\n }, [$data.videoLoading ? (_openBlock(), _createElementBlock(\"div\", _hoisted_7)) : $data.videoError ? (_openBlock(), _createElementBlock(\"div\", {\n key: 1,\n class: \"error-wrapper\",\n onClick: _cache[2] || (_cache[2] = $event => _ctx.$emit('detail'))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"exclamation-triangle\",\n class: \"error-icon\"\n }), _cache[20] || (_cache[20] = _createElementVNode(\"span\", {\n class: \"error-text\"\n }, \"加载失败\", -1))])) : _createCommentVNode(\"\", true), _withDirectives(_createElementVNode(\"video\", {\n src: $props.fileLink,\n muted: \"\",\n loop: \"\",\n preload: \"metadata\",\n class: \"video-preview\",\n onClick: _cache[3] || (_cache[3] = (...args) => $options.handleVideoClick && $options.handleVideoClick(...args)),\n onMouseenter: _cache[4] || (_cache[4] = $event => $options.handleVideoHover($event, true)),\n onMouseleave: _cache[5] || (_cache[5] = $event => $options.handleVideoHover($event, false)),\n onFullscreenchange: _cache[6] || (_cache[6] = (...args) => $options.handleFullscreenChange && $options.handleFullscreenChange(...args)),\n onWebkitfullscreenchange: _cache[7] || (_cache[7] = (...args) => $options.handleFullscreenChange && $options.handleFullscreenChange(...args)),\n onLoadeddata: _cache[8] || (_cache[8] = $event => $data.videoLoading = false),\n onError: _cache[9] || (_cache[9] = (...args) => $options.handleVideoError && $options.handleVideoError(...args))\n }, null, 40, _hoisted_8), [[_vShow, !$data.videoLoading && !$data.videoError]])], 64)) : $options.isAudio ? (_openBlock(), _createElementBlock(\"div\", {\n key: 1,\n class: \"file-preview audio-card-preview\",\n onClick: _cache[10] || (_cache[10] = $event => _ctx.$emit('detail'))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"music\",\n class: \"file-icon audio-icon\"\n })])) : $options.isImage ? (_openBlock(), _createBlock(_component_el_image, {\n key: 2,\n \"preview-teleported\": true,\n src: $props.fileLink,\n \"preview-src-list\": $props.previewSrcList,\n fit: \"cover\",\n lazy: \"\",\n class: \"image-preview\"\n }, {\n placeholder: _withCtx(() => [...(_cache[21] || (_cache[21] = [_createElementVNode(\"div\", {\n class: \"skeleton-wrapper\"\n }, null, -1)]))]),\n error: _withCtx(() => [_createElementVNode(\"div\", {\n class: \"error-wrapper\",\n onClick: _cache[11] || (_cache[11] = _withModifiers($event => _ctx.$emit('detail'), [\"stop\"]))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"image\",\n class: \"error-icon\"\n }), _cache[22] || (_cache[22] = _createElementVNode(\"span\", {\n class: \"error-text\"\n }, \"加载失败\", -1))])]),\n _: 1\n }, 8, [\"src\", \"preview-src-list\"])) : (_openBlock(), _createElementBlock(\"div\", _hoisted_9, [_createVNode(_component_font_awesome_icon, {\n icon: \"file\",\n class: \"file-icon\"\n })])), _createElementVNode(\"div\", _hoisted_10, [_createElementVNode(\"div\", _hoisted_11, [_createElementVNode(\"span\", _hoisted_12, _toDisplayString($options.displayName), 1)]), _createElementVNode(\"div\", _hoisted_13, [_createElementVNode(\"div\", _hoisted_14, [_createVNode(_component_el_tooltip, {\n disabled: $props.disableTooltip,\n content: \"详情\",\n placement: \"top\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"button\", {\n class: \"action-btn\",\n onClick: _cache[12] || (_cache[12] = _withModifiers($event => _ctx.$emit('detail'), [\"stop\"]))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"info-circle\"\n })])]),\n _: 1\n }, 8, [\"disabled\"])]), _createElementVNode(\"div\", _hoisted_15, [_createVNode(_component_el_tooltip, {\n disabled: $props.disableTooltip,\n content: \"移动\",\n placement: \"top\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"button\", {\n class: \"action-btn\",\n onClick: _cache[13] || (_cache[13] = _withModifiers($event => _ctx.$emit('move'), [\"stop\"]))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"file-export\"\n })])]),\n _: 1\n }, 8, [\"disabled\"]), _createVNode(_component_el_tooltip, {\n disabled: $props.disableTooltip,\n content: \"删除\",\n placement: \"top\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"button\", {\n class: \"action-btn action-btn-danger\",\n onClick: _cache[14] || (_cache[14] = _withModifiers($event => _ctx.$emit('delete'), [\"stop\"]))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"trash-alt\"\n })])]),\n _: 1\n }, 8, [\"disabled\"]), _createVNode(_component_el_tooltip, {\n disabled: $props.disableTooltip,\n content: \"下载\",\n placement: \"top\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"button\", {\n class: \"action-btn\",\n onClick: _cache[15] || (_cache[15] = _withModifiers($event => _ctx.$emit('download'), [\"stop\"]))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"download\"\n })])]),\n _: 1\n }, 8, [\"disabled\"]), _createVNode(_component_el_tooltip, {\n disabled: $props.disableTooltip,\n content: \"复制链接\",\n placement: \"top\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"button\", {\n class: \"action-btn\",\n onClick: _cache[16] || (_cache[16] = _withModifiers($event => _ctx.$emit('copy'), [\"stop\"]))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"copy\"\n })])]),\n _: 1\n }, 8, [\"disabled\"])])])])]),\n _: 1\n });\n}","export default {\n name: 'FileCard',\n props: {\n item: {\n type: Object,\n required: true\n },\n selected: {\n type: Boolean,\n default: false\n },\n fileLink: {\n type: String,\n required: true\n },\n previewSrcList: {\n type: Array,\n default: () => []\n },\n disableTooltip: {\n type: Boolean,\n default: false\n }\n },\n emits: ['update:selected', 'detail', 'copy', 'move', 'delete', 'download', 'touchstart', 'touchend', 'touchmove'],\n data() {\n return {\n localSelected: this.selected,\n videoLoading: true,\n videoError: false\n };\n },\n computed: {\n channelTag() {\n return this.item.channelTag || '';\n },\n isVideo() {\n // 先通过 content-type 判断\n const fileType = this.item.metadata?.FileType?.toLowerCase() || '';\n if (fileType.includes('video')) return true;\n // 再通过文件后缀判断\n const name = this.item.name?.toLowerCase() || '';\n return name.endsWith('.mp4') || name.endsWith('.webm') || name.endsWith('.mov') || name.endsWith('.avi');\n },\n isAudio() {\n // 先通过 content-type 判断\n const fileType = this.item.metadata?.FileType?.toLowerCase() || '';\n if (fileType.includes('audio')) return true;\n // 再通过文件后缀判断\n const name = this.item.name?.toLowerCase() || '';\n return name.endsWith('.mp3') || name.endsWith('.wav') || name.endsWith('.ogg') || name.endsWith('.flac');\n },\n isImage() {\n // 先通过 content-type 判断\n const fileType = this.item.metadata?.FileType?.toLowerCase() || '';\n if (fileType.includes('image')) return true;\n // 再通过文件后缀判断\n const name = this.item.name?.toLowerCase() || '';\n return name.endsWith('.jpg') || name.endsWith('.jpeg') || name.endsWith('.png') || name.endsWith('.gif') || name.endsWith('.webp') || name.endsWith('.svg') || name.endsWith('.bmp') || name.endsWith('.avif') || name.endsWith('.heic') || name.endsWith('.heif');\n },\n displayName() {\n const fileName = this.item.metadata?.FileName || this.item.name || '';\n const parts = fileName.split('/');\n return parts[parts.length - 1];\n }\n },\n watch: {\n selected(val) {\n this.localSelected = val;\n },\n fileLink() {\n // 链接变化时重置加载状态\n this.videoLoading = true;\n this.videoError = false;\n }\n },\n methods: {\n handleVideoError() {\n this.videoLoading = false;\n this.videoError = true;\n },\n handleVideoClick(e) {\n const video = e.target;\n if (video.requestFullscreen) {\n video.requestFullscreen();\n } else if (video.webkitRequestFullscreen) {\n video.webkitRequestFullscreen();\n } else if (video.mozRequestFullScreen) {\n video.mozRequestFullScreen();\n } else if (video.msRequestFullscreen) {\n video.msRequestFullscreen();\n }\n },\n handleFullscreenChange(e) {\n const video = e.target;\n const isFullscreen = document.fullscreenElement || document.webkitFullscreenElement || document.mozFullScreenElement || document.msFullscreenElement;\n if (isFullscreen) {\n // 进入全屏:取消静音和循环\n video.muted = false;\n video.loop = false;\n } else {\n // 退出全屏:恢复静音和循环,暂停并重置\n video.muted = true;\n video.loop = true;\n video.pause();\n video.currentTime = 0;\n }\n },\n handleVideoHover(e, isEnter) {\n const video = e.target;\n if (isEnter) {\n video.play().catch(() => {});\n } else {\n video.pause();\n video.currentTime = 0;\n }\n }\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./FileCard.vue?vue&type=template&id=ddf49ce2&scoped=true\"\nimport script from \"./FileCard.vue?vue&type=script&lang=js\"\nexport * from \"./FileCard.vue?vue&type=script&lang=js\"\n\nimport \"./FileCard.vue?vue&type=style&index=0&id=ddf49ce2&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-ddf49ce2\"]])\n\nexport default __exports__","import { resolveComponent as _resolveComponent, createVNode as _createVNode, createElementVNode as _createElementVNode, toDisplayString as _toDisplayString, withModifiers as _withModifiers, withCtx as _withCtx, openBlock as _openBlock, createElementBlock as _createElementBlock, createCommentVNode as _createCommentVNode, createBlock as _createBlock } from \"vue\";\nconst _hoisted_1 = {\n class: \"card-bottom-overlay\"\n};\nconst _hoisted_2 = {\n class: \"file-name-row\"\n};\nconst _hoisted_3 = {\n class: \"file-name\"\n};\nconst _hoisted_4 = {\n key: 0,\n class: \"action-bar\"\n};\nconst _hoisted_5 = {\n class: \"action-bar-right\"\n};\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_el_checkbox = _resolveComponent(\"el-checkbox\");\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n const _component_el_tooltip = _resolveComponent(\"el-tooltip\");\n const _component_el_card = _resolveComponent(\"el-card\");\n return _openBlock(), _createBlock(_component_el_card, {\n class: \"img-card folder-card\",\n onTouchstart: _cache[6] || (_cache[6] = $event => _ctx.$emit('touchstart', $event)),\n onTouchend: _cache[7] || (_cache[7] = $event => _ctx.$emit('touchend', $event)),\n onTouchmove: _cache[8] || (_cache[8] = $event => _ctx.$emit('touchmove', $event))\n }, {\n default: _withCtx(() => [_createVNode(_component_el_checkbox, {\n modelValue: $data.localSelected,\n \"onUpdate:modelValue\": _cache[0] || (_cache[0] = $event => $data.localSelected = $event),\n onChange: _cache[1] || (_cache[1] = $event => _ctx.$emit('update:selected', $data.localSelected))\n }, null, 8, [\"modelValue\"]), _createElementVNode(\"div\", {\n class: \"folder-icon\",\n onClick: _cache[2] || (_cache[2] = $event => _ctx.$emit('enter'))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"folder-open\",\n class: \"folder-icon-svg\"\n })]), _createElementVNode(\"div\", _hoisted_1, [_createElementVNode(\"div\", _hoisted_2, [_createElementVNode(\"span\", _hoisted_3, _toDisplayString($options.folderName), 1)]), $props.showActions ? (_openBlock(), _createElementBlock(\"div\", _hoisted_4, [_cache[9] || (_cache[9] = _createElementVNode(\"div\", {\n class: \"action-bar-left\"\n }, null, -1)), _createElementVNode(\"div\", _hoisted_5, [_createVNode(_component_el_tooltip, {\n disabled: $props.disableTooltip,\n content: \"复制链接\",\n placement: \"top\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"button\", {\n class: \"action-btn\",\n onClick: _cache[3] || (_cache[3] = _withModifiers($event => _ctx.$emit('copy'), [\"stop\"]))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"copy\"\n })])]),\n _: 1\n }, 8, [\"disabled\"]), _createVNode(_component_el_tooltip, {\n disabled: $props.disableTooltip,\n content: \"移动\",\n placement: \"top\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"button\", {\n class: \"action-btn\",\n onClick: _cache[4] || (_cache[4] = _withModifiers($event => _ctx.$emit('move'), [\"stop\"]))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"file-export\"\n })])]),\n _: 1\n }, 8, [\"disabled\"]), _createVNode(_component_el_tooltip, {\n disabled: $props.disableTooltip,\n content: \"删除\",\n placement: \"top\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"button\", {\n class: \"action-btn action-btn-danger\",\n onClick: _cache[5] || (_cache[5] = _withModifiers($event => _ctx.$emit('delete'), [\"stop\"]))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"trash-alt\"\n })])]),\n _: 1\n }, 8, [\"disabled\"])])])) : _createCommentVNode(\"\", true)])]),\n _: 1\n });\n}","import \"core-js/modules/es.iterator.constructor.js\";\nimport \"core-js/modules/es.iterator.filter.js\";\nexport default {\n name: 'FolderCard',\n props: {\n name: {\n type: String,\n required: true\n },\n selected: {\n type: Boolean,\n default: false\n },\n showActions: {\n type: Boolean,\n default: true\n },\n disableTooltip: {\n type: Boolean,\n default: false\n }\n },\n emits: ['update:selected', 'enter', 'copy', 'move', 'delete', 'touchstart', 'touchend', 'touchmove'],\n data() {\n return {\n localSelected: this.selected\n };\n },\n computed: {\n folderName() {\n const parts = this.name.split('/').filter(Boolean);\n return parts[parts.length - 1] || this.name;\n }\n },\n watch: {\n selected(val) {\n this.localSelected = val;\n }\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./FolderCard.vue?vue&type=template&id=20e5d6b4&scoped=true\"\nimport script from \"./FolderCard.vue?vue&type=script&lang=js\"\nexport * from \"./FolderCard.vue?vue&type=script&lang=js\"\n\nimport \"./FolderCard.vue?vue&type=style&index=0&id=20e5d6b4&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-20e5d6b4\"]])\n\nexport default __exports__","import { renderList as _renderList, Fragment as _Fragment, openBlock as _openBlock, createElementBlock as _createElementBlock, createElementVNode as _createElementVNode, createCommentVNode as _createCommentVNode, createStaticVNode as _createStaticVNode } from \"vue\";\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n return $props.type === 'card' ? (_openBlock(true), _createElementBlock(_Fragment, {\n key: 0\n }, _renderList($props.count, i => {\n return _openBlock(), _createElementBlock(\"div\", {\n key: 'skeleton-' + i,\n class: \"skeleton-card\"\n }, [...(_cache[0] || (_cache[0] = [_createElementVNode(\"div\", {\n class: \"skeleton-image\"\n }, null, -1), _createElementVNode(\"div\", {\n class: \"skeleton-info\"\n }, [_createElementVNode(\"div\", {\n class: \"skeleton-text\"\n })], -1)]))]);\n }), 128)) : $props.type === 'list' ? (_openBlock(true), _createElementBlock(_Fragment, {\n key: 1\n }, _renderList($props.count, i => {\n return _openBlock(), _createElementBlock(\"div\", {\n key: 'list-skeleton-' + i,\n class: \"list-item skeleton-list-item\"\n }, [...(_cache[1] || (_cache[1] = [_createStaticVNode(\"
\", 10)]))]);\n }), 128)) : _createCommentVNode(\"\", true);\n}","export default {\n name: 'SkeletonLoader',\n props: {\n type: {\n type: String,\n default: 'card',\n validator: value => ['card', 'list'].includes(value)\n },\n count: {\n type: Number,\n default: 15\n }\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./SkeletonLoader.vue?vue&type=template&id=71848b62&scoped=true\"\nimport script from \"./SkeletonLoader.vue?vue&type=script&lang=js\"\nexport * from \"./SkeletonLoader.vue?vue&type=script&lang=js\"\n\nimport \"./SkeletonLoader.vue?vue&type=style&index=0&id=71848b62&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-71848b62\"]])\n\nexport default __exports__","import \"core-js/modules/es.iterator.constructor.js\";\nimport \"core-js/modules/es.iterator.filter.js\";\nimport { resolveComponent as _resolveComponent, createVNode as _createVNode, withKeys as _withKeys, withCtx as _withCtx, createElementVNode as _createElementVNode, createTextVNode as _createTextVNode, normalizeClass as _normalizeClass, toDisplayString as _toDisplayString, renderList as _renderList, Fragment as _Fragment, openBlock as _openBlock, createElementBlock as _createElementBlock, createBlock as _createBlock, createCommentVNode as _createCommentVNode } from \"vue\";\nconst _hoisted_1 = {\n class: \"container\"\n};\nconst _hoisted_2 = {\n class: \"header-content\"\n};\nconst _hoisted_3 = {\n class: \"search-card\"\n};\nconst _hoisted_4 = {\n class: \"actions\"\n};\nconst _hoisted_5 = {\n class: \"el-dropdown-link\"\n};\nconst _hoisted_6 = {\n class: \"el-dropdown-link\"\n};\nconst _hoisted_7 = {\n class: \"el-dropdown-link\"\n};\nconst _hoisted_8 = {\n class: \"breadcrumb-container\"\n};\nconst _hoisted_9 = {\n class: \"mobile-directory-path\"\n};\nconst _hoisted_10 = {\n class: \"breadcrumb desktop-only\"\n};\nconst _hoisted_11 = [\"title\"];\nconst _hoisted_12 = {\n key: 0,\n class: \"content\"\n};\nconst _hoisted_13 = {\n key: 1,\n class: \"list-view\"\n};\nconst _hoisted_14 = {\n class: \"list-header\"\n};\nconst _hoisted_15 = {\n class: \"list-col list-col-checkbox\"\n};\nconst _hoisted_16 = {\n class: \"pagination-container\"\n};\nconst _hoisted_17 = {\n class: \"pagination-center\"\n};\nconst _hoisted_18 = {\n class: \"pagination-right\"\n};\nconst _hoisted_19 = {\n class: \"page-total\"\n};\nconst _hoisted_20 = {\n class: \"page-jump\"\n};\nconst _hoisted_21 = {\n class: \"dialog-section\"\n};\nconst _hoisted_22 = {\n class: \"section-content\"\n};\nconst _hoisted_23 = {\n class: \"dialog-section\"\n};\nconst _hoisted_24 = {\n class: \"section-header\"\n};\nconst _hoisted_25 = {\n class: \"section-content\"\n};\nconst _hoisted_26 = {\n class: \"setting-item\"\n};\nconst _hoisted_27 = {\n key: 0,\n class: \"setting-item\"\n};\nconst _hoisted_28 = {\n class: \"dialog-action\"\n};\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_DashboardTabs = _resolveComponent(\"DashboardTabs\");\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n const _component_el_input = _resolveComponent(\"el-input\");\n const _component_el_dropdown_item = _resolveComponent(\"el-dropdown-item\");\n const _component_el_dropdown_menu = _resolveComponent(\"el-dropdown-menu\");\n const _component_el_dropdown = _resolveComponent(\"el-dropdown\");\n const _component_el_tooltip = _resolveComponent(\"el-tooltip\");\n const _component_el_header = _resolveComponent(\"el-header\");\n const _component_el_breadcrumb_item = _resolveComponent(\"el-breadcrumb-item\");\n const _component_el_breadcrumb = _resolveComponent(\"el-breadcrumb\");\n const _component_SkeletonLoader = _resolveComponent(\"SkeletonLoader\");\n const _component_FolderCard = _resolveComponent(\"FolderCard\");\n const _component_FileCard = _resolveComponent(\"FileCard\");\n const _component_FileListItem = _resolveComponent(\"FileListItem\");\n const _component_el_pagination = _resolveComponent(\"el-pagination\");\n const _component_el_button = _resolveComponent(\"el-button\");\n const _component_el_main = _resolveComponent(\"el-main\");\n const _component_el_container = _resolveComponent(\"el-container\");\n const _component_FileDetailDialog = _resolveComponent(\"FileDetailDialog\");\n const _component_el_radio = _resolveComponent(\"el-radio\");\n const _component_el_radio_group = _resolveComponent(\"el-radio-group\");\n const _component_el_switch = _resolveComponent(\"el-switch\");\n const _component_el_dialog = _resolveComponent(\"el-dialog\");\n const _component_TagManagementDialog = _resolveComponent(\"TagManagementDialog\");\n const _component_BatchTagDialog = _resolveComponent(\"BatchTagDialog\");\n const _component_MobileActionSheet = _resolveComponent(\"MobileActionSheet\");\n const _component_MobileDirectoryDrawer = _resolveComponent(\"MobileDirectoryDrawer\");\n return _openBlock(), _createElementBlock(\"div\", _hoisted_1, [_createVNode(_component_el_container, null, {\n default: _withCtx(() => [_createVNode(_component_el_header, null, {\n default: _withCtx(() => [_createElementVNode(\"div\", _hoisted_2, [_createVNode(_component_DashboardTabs, {\n activeTab: \"dashboard\"\n }), _createElementVNode(\"div\", _hoisted_3, [_createVNode(_component_el_input, {\n modelValue: $data.tempSearch,\n \"onUpdate:modelValue\": _cache[0] || (_cache[0] = $event => $data.tempSearch = $event),\n size: \"mini\",\n placeholder: \"搜索:#标签 -#排除标签\",\n onKeyup: _withKeys($options.handleSearch, [\"enter\"])\n }, {\n suffix: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"search\",\n class: \"search-icon\",\n onClick: $options.handleSearch\n }, null, 8, [\"onClick\"])]),\n _: 1\n }, 8, [\"modelValue\", \"onKeyup\"])]), _createElementVNode(\"div\", _hoisted_4, [_createVNode(_component_el_dropdown, {\n onCommand: $options.sort,\n \"hide-on-click\": false\n }, {\n dropdown: _withCtx(() => [_createVNode(_component_el_dropdown_menu, null, {\n default: _withCtx(() => [_createVNode(_component_el_dropdown_item, {\n command: \"dateDesc\"\n }, {\n default: _withCtx(() => [...(_cache[21] || (_cache[21] = [_createTextVNode(\"按时间倒序\", -1)]))]),\n _: 1\n }), _createVNode(_component_el_dropdown_item, {\n command: \"nameAsc\"\n }, {\n default: _withCtx(() => [...(_cache[22] || (_cache[22] = [_createTextVNode(\"按名称升序\", -1)]))]),\n _: 1\n })]),\n _: 1\n })]),\n default: _withCtx(() => [_createElementVNode(\"span\", _hoisted_5, [_createVNode(_component_font_awesome_icon, {\n icon: $options.sortIcon,\n class: \"header-icon\"\n }, null, 8, [\"icon\"])])]),\n _: 1\n }, 8, [\"onCommand\"]), _createVNode(_component_el_tooltip, {\n disabled: $options.disableTooltip,\n content: \"全选此页\",\n placement: \"bottom\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: $options.selectPageIcon,\n class: \"header-icon\",\n onClick: $options.handleSelectPage\n }, null, 8, [\"icon\", \"onClick\"])]),\n _: 1\n }, 8, [\"disabled\"]), _createVNode(_component_el_dropdown, {\n onCommand: $options.handleBatchAction,\n \"hide-on-click\": false,\n disabled: $data.selectedFiles.length === 0\n }, {\n dropdown: _withCtx(() => [_createVNode(_component_el_dropdown_menu, null, {\n default: _withCtx(() => [_createVNode(_component_el_dropdown_item, {\n command: \"copy\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"copy\",\n class: \"batch-action-item-icon\"\n }), _cache[23] || (_cache[23] = _createTextVNode(\" 复制 \", -1))]),\n _: 1\n }), _createVNode(_component_el_dropdown_item, {\n command: \"delete\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"trash-alt\",\n class: \"batch-action-item-icon\"\n }), _cache[24] || (_cache[24] = _createTextVNode(\" 删除 \", -1))]),\n _: 1\n }), _createVNode(_component_el_dropdown_item, {\n command: \"download\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"download\",\n class: \"batch-action-item-icon\"\n }), _cache[25] || (_cache[25] = _createTextVNode(\" 下载 \", -1))]),\n _: 1\n }), _createVNode(_component_el_dropdown_item, {\n command: \"move\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"file-export\",\n class: \"batch-action-item-icon\"\n }), _cache[26] || (_cache[26] = _createTextVNode(\" 移动 \", -1))]),\n _: 1\n }), _createVNode(_component_el_dropdown_item, {\n command: \"tagManagement\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"tags\",\n class: \"batch-action-item-icon\"\n }), _cache[27] || (_cache[27] = _createTextVNode(\" 标签管理 \", -1))]),\n _: 1\n }), _createVNode(_component_el_dropdown_item, {\n command: \"ban\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"ban\",\n class: \"batch-action-item-icon\"\n }), _cache[28] || (_cache[28] = _createTextVNode(\" 加入黑名单 \", -1))]),\n _: 1\n }), _createVNode(_component_el_dropdown_item, {\n command: \"white\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"user-plus\",\n class: \"batch-action-item-icon\"\n }), _cache[29] || (_cache[29] = _createTextVNode(\" 加入白名单 \", -1))]),\n _: 1\n })]),\n _: 1\n })]),\n default: _withCtx(() => [_createElementVNode(\"span\", _hoisted_6, [_createVNode(_component_font_awesome_icon, {\n icon: \"ellipsis-h\",\n class: _normalizeClass([\"header-icon\", {\n disabled: $data.selectedFiles.length === 0\n }])\n }, null, 8, [\"class\"])])]),\n _: 1\n }, 8, [\"onCommand\", \"disabled\"]), _createVNode(_component_el_tooltip, {\n disabled: $options.disableTooltip,\n content: \"链接格式\",\n placement: \"bottom\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"span\", _hoisted_7, [_createVNode(_component_font_awesome_icon, {\n icon: \"link\",\n class: \"header-icon\",\n onClick: _cache[1] || (_cache[1] = $event => $data.showUrlDialog = true)\n })])]),\n _: 1\n }, 8, [\"disabled\"]), _createVNode(_component_el_tooltip, {\n disabled: $options.disableTooltip,\n content: $data.viewMode === 'card' ? '列表视图' : '卡片视图',\n placement: \"bottom\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: $data.viewMode === 'card' ? 'list' : 'th-large',\n class: \"header-icon\",\n onClick: $options.toggleViewMode\n }, null, 8, [\"icon\", \"onClick\"])]),\n _: 1\n }, 8, [\"disabled\", \"content\"]), _createVNode(_component_el_tooltip, {\n disabled: $options.disableTooltip,\n content: \"退出登录\",\n placement: \"bottom\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"sign-out-alt\",\n class: \"header-icon\",\n onClick: $options.handleLogout\n }, null, 8, [\"onClick\"])]),\n _: 1\n }, 8, [\"disabled\"])])])]),\n _: 1\n }), _createVNode(_component_el_main, {\n class: \"main-container\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"div\", _hoisted_8, [_createElementVNode(\"div\", {\n class: \"mobile-directory-trigger\",\n onClick: _cache[2] || (_cache[2] = $event => $data.showMobileDirectoryDrawer = true)\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"folder-open\",\n class: \"mobile-directory-icon\"\n }), _createElementVNode(\"span\", _hoisted_9, _toDisplayString($data.currentPath && $data.currentPath.split('/').filter(Boolean).length > 0 ? $data.currentPath.split('/').filter(Boolean).pop() : '根目录'), 1), _createVNode(_component_font_awesome_icon, {\n icon: \"chevron-down\",\n class: \"mobile-directory-arrow\"\n })]), _createElementVNode(\"div\", _hoisted_10, [_createVNode(_component_el_breadcrumb, {\n separator: \"/\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_breadcrumb_item, {\n onClick: _cache[3] || (_cache[3] = $event => $options.navigateToFolder(''))\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"home\",\n class: \"breadcrumb-home-icon\"\n })]),\n _: 1\n }), (_openBlock(true), _createElementBlock(_Fragment, null, _renderList($data.currentPath.split('/').filter(Boolean), (folder, index) => {\n return _openBlock(), _createBlock(_component_el_breadcrumb_item, {\n key: index,\n onClick: $event => $options.navigateToFolder($data.currentPath.split('/').filter(Boolean).slice(0, index + 1).join('/'))\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString(folder), 1)]),\n _: 2\n }, 1032, [\"onClick\"]);\n }), 128))]),\n _: 1\n })]), _createElementVNode(\"span\", {\n class: \"stats-badge\",\n title: `共 ${_ctx.$data.Number} 个文件`\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"database\",\n class: \"stats-badge-icon\"\n }), _createTextVNode(\" \" + _toDisplayString($data.Number), 1)], 8, _hoisted_11)]), $data.viewMode === 'card' ? (_openBlock(), _createElementBlock(\"div\", _hoisted_12, [$data.loading ? (_openBlock(), _createBlock(_component_SkeletonLoader, {\n key: 0,\n type: \"card\",\n count: 15\n })) : (_openBlock(true), _createElementBlock(_Fragment, {\n key: 1\n }, _renderList($options.paginatedTableData, (item, index) => {\n return _openBlock(), _createElementBlock(_Fragment, {\n key: index\n }, [$options.isFolder(item) ? (_openBlock(), _createBlock(_component_FolderCard, {\n key: 0,\n name: item.name,\n selected: item.selected,\n \"onUpdate:selected\": $event => item.selected = $event,\n showActions: !$data.isSearchMode,\n disableTooltip: $options.disableTooltip,\n onEnter: $event => $options.enterFolder(item.name),\n onCopy: $event => $options.handleFolderCopy(item.name),\n onMove: $event => $options.handleMove(index, item.name),\n onDelete: $event => $options.handleDelete(index, item.name),\n onTouchstart: $event => $options.handleFolderTouchStart(item, index),\n onTouchend: $options.handleTouchEnd,\n onTouchmove: $options.handleTouchEnd\n }, null, 8, [\"name\", \"selected\", \"onUpdate:selected\", \"showActions\", \"disableTooltip\", \"onEnter\", \"onCopy\", \"onMove\", \"onDelete\", \"onTouchstart\", \"onTouchend\", \"onTouchmove\"])) : (_openBlock(), _createBlock(_component_FileCard, {\n key: 1,\n item: item,\n selected: item.selected,\n \"onUpdate:selected\": $event => item.selected = $event,\n fileLink: $options.getFileLink(item.name),\n previewSrcList: item.previewSrcList,\n disableTooltip: $options.disableTooltip,\n onDetail: $event => $options.openDetailDialog(index, item.name),\n onCopy: $event => $options.handleCopy(index, item.name),\n onMove: $event => $options.handleMove(index, item.name),\n onDelete: $event => $options.handleDelete(index, item.name),\n onDownload: $event => $options.handleDownload(item.name),\n onTouchstart: $event => $options.handleTouchStart(item, index),\n onTouchend: $options.handleTouchEnd,\n onTouchmove: $options.handleTouchEnd\n }, null, 8, [\"item\", \"selected\", \"onUpdate:selected\", \"fileLink\", \"previewSrcList\", \"disableTooltip\", \"onDetail\", \"onCopy\", \"onMove\", \"onDelete\", \"onDownload\", \"onTouchstart\", \"onTouchend\", \"onTouchmove\"]))], 64);\n }), 128))])) : (_openBlock(), _createElementBlock(\"div\", _hoisted_13, [_createElementVNode(\"div\", _hoisted_14, [_createElementVNode(\"div\", _hoisted_15, [_createElementVNode(\"span\", {\n class: _normalizeClass([\"custom-checkbox\", {\n 'checked': $options.isSelectAll,\n 'indeterminate': $options.isIndeterminate\n }]),\n onClick: _cache[4] || (_cache[4] = $event => $options.handleSelectAllPage(!$options.isSelectAll))\n }, [$options.isSelectAll ? (_openBlock(), _createBlock(_component_font_awesome_icon, {\n key: 0,\n icon: \"check\",\n class: \"check-icon\"\n })) : $options.isIndeterminate ? (_openBlock(), _createBlock(_component_font_awesome_icon, {\n key: 1,\n icon: \"minus\",\n class: \"check-icon\"\n })) : _createCommentVNode(\"\", true)], 2)]), _cache[30] || (_cache[30] = _createElementVNode(\"div\", {\n class: \"list-col list-col-preview\"\n }, \"预览\", -1)), _cache[31] || (_cache[31] = _createElementVNode(\"div\", {\n class: \"list-col list-col-name\"\n }, \"文件名\", -1)), _cache[32] || (_cache[32] = _createElementVNode(\"div\", {\n class: \"list-col list-col-tags\"\n }, \"标签\", -1)), _cache[33] || (_cache[33] = _createElementVNode(\"div\", {\n class: \"list-col list-col-channel\"\n }, \"渠道类型\", -1)), _cache[34] || (_cache[34] = _createElementVNode(\"div\", {\n class: \"list-col list-col-channel-name\"\n }, \"渠道名称\", -1)), _cache[35] || (_cache[35] = _createElementVNode(\"div\", {\n class: \"list-col list-col-address\"\n }, \"上传地址\", -1)), _cache[36] || (_cache[36] = _createElementVNode(\"div\", {\n class: \"list-col list-col-size\"\n }, \"大小\", -1)), _cache[37] || (_cache[37] = _createElementVNode(\"div\", {\n class: \"list-col list-col-date\"\n }, \"上传时间\", -1)), _cache[38] || (_cache[38] = _createElementVNode(\"div\", {\n class: \"list-col list-col-actions\"\n }, \"操作\", -1))]), $data.loading ? (_openBlock(), _createBlock(_component_SkeletonLoader, {\n key: 0,\n type: \"list\",\n count: 15\n })) : (_openBlock(true), _createElementBlock(_Fragment, {\n key: 1\n }, _renderList($options.paginatedTableData, (item, index) => {\n return _openBlock(), _createBlock(_component_FileListItem, {\n key: index,\n item: item,\n selected: item.selected,\n \"onUpdate:selected\": $event => item.selected = $event,\n fileLink: $options.getFileLink(item.name),\n onEnter: $event => $options.enterFolder(item.name),\n onDetail: $event => $options.openDetailDialog(index, item.name),\n onCopy: $event => $options.handleCopy(index, item.name),\n onFolderCopy: $event => $options.handleFolderCopy(item.name),\n onMove: $event => $options.handleMove(index, item.name),\n onDelete: $event => $options.handleDelete(index, item.name),\n onDownload: $event => $options.handleDownload(item.name),\n onTouchstart: $event => $options.isFolder(item) ? $options.handleFolderTouchStart(item, index) : $options.handleTouchStart(item, index),\n onTouchend: $options.handleTouchEnd,\n onTouchmove: $options.handleTouchEnd\n }, null, 8, [\"item\", \"selected\", \"onUpdate:selected\", \"fileLink\", \"onEnter\", \"onDetail\", \"onCopy\", \"onFolderCopy\", \"onMove\", \"onDelete\", \"onDownload\", \"onTouchstart\", \"onTouchend\", \"onTouchmove\"]);\n }), 128))])), _createElementVNode(\"div\", _hoisted_16, [_createElementVNode(\"div\", _hoisted_17, [_createVNode(_component_el_pagination, {\n background: \"\",\n layout: \"prev, pager, next\",\n total: $options.filteredTableData.length,\n \"page-size\": $data.pageSize,\n \"current-page\": $data.currentPage,\n \"pager-count\": $options.pagerCount,\n onCurrentChange: $options.handlePageChange\n }, null, 8, [\"total\", \"page-size\", \"current-page\", \"pager-count\", \"onCurrentChange\"]), _createVNode(_component_el_button, {\n type: \"primary\",\n onClick: $options.refreshFileList,\n class: \"refresh-btn\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"sync\",\n class: _normalizeClass({\n 'fa-spin': $data.refreshLoading\n })\n }, null, 8, [\"class\"])]),\n _: 1\n }, 8, [\"onClick\"]), $data.currentPage === Math.ceil($options.filteredTableData.length / $data.pageSize) ? (_openBlock(), _createBlock(_component_el_button, {\n key: 0,\n type: \"primary\",\n onClick: $options.loadMoreData,\n loading: $data.loading,\n class: \"load-more\"\n }, {\n default: _withCtx(() => [...(_cache[39] || (_cache[39] = [_createTextVNode(\" 加载更多 \", -1)]))]),\n _: 1\n }, 8, [\"onClick\", \"loading\"])) : _createCommentVNode(\"\", true)]), _createElementVNode(\"div\", _hoisted_18, [_createElementVNode(\"span\", _hoisted_19, \"共 \" + _toDisplayString($options.realTotalPages) + \" 页\", 1), _createElementVNode(\"div\", _hoisted_20, [_cache[41] || (_cache[41] = _createElementVNode(\"span\", null, \"跳至\", -1)), _createVNode(_component_el_input, {\n modelValue: $data.jumpPage,\n \"onUpdate:modelValue\": _cache[5] || (_cache[5] = $event => $data.jumpPage = $event),\n size: \"small\",\n class: \"jump-input\",\n onKeyup: _withKeys($options.handleJumpPage, [\"enter\"])\n }, null, 8, [\"modelValue\", \"onKeyup\"]), _createVNode(_component_el_button, {\n size: \"small\",\n type: \"primary\",\n onClick: $options.handleJumpPage,\n class: \"jump-btn\"\n }, {\n default: _withCtx(() => [...(_cache[40] || (_cache[40] = [_createTextVNode(\"GO\", -1)]))]),\n _: 1\n }, 8, [\"onClick\"])])])])]),\n _: 1\n })]),\n _: 1\n }), _createVNode(_component_FileDetailDialog, {\n modelValue: $data.showdetailDialog,\n \"onUpdate:modelValue\": _cache[6] || (_cache[6] = $event => $data.showdetailDialog = $event),\n file: $data.detailFile,\n fileLink: $options.getFileLink($data.detailFile?.name),\n urls: $options.allUrl,\n onDownload: _cache[7] || (_cache[7] = $event => $options.handleDownload($data.detailFile?.name)),\n onTagManagement: _cache[8] || (_cache[8] = $event => $options.handleTagManagement($data.detailFile?.name)),\n onBlock: _cache[9] || (_cache[9] = $event => $options.handleBlock($data.detailFile?.name)),\n onWhite: _cache[10] || (_cache[10] = $event => $options.handleWhite($data.detailFile?.name)),\n onDelete: _cache[11] || (_cache[11] = $event => $options.handleDetailDelete($data.detailFile?.name))\n }, null, 8, [\"modelValue\", \"file\", \"fileLink\", \"urls\"]), _createVNode(_component_el_dialog, {\n title: \"链接格式\",\n modelValue: $data.showUrlDialog,\n \"onUpdate:modelValue\": _cache[16] || (_cache[16] = $event => $data.showUrlDialog = $event),\n width: $options.dialogWidth,\n \"show-close\": false,\n class: \"settings-dialog\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"div\", _hoisted_21, [_cache[48] || (_cache[48] = _createElementVNode(\"div\", {\n class: \"section-header\"\n }, [_createElementVNode(\"span\", {\n class: \"section-title\"\n }, \"默认复制链接\")], -1)), _createElementVNode(\"div\", _hoisted_22, [_createVNode(_component_el_radio_group, {\n modelValue: $data.defaultUrlFormat,\n \"onUpdate:modelValue\": _cache[12] || (_cache[12] = $event => $data.defaultUrlFormat = $event),\n class: \"radio-card-group grid-2x2\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_radio, {\n label: \"originUrl\",\n class: \"radio-card\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"link\",\n class: \"radio-icon\"\n }), _cache[42] || (_cache[42] = _createElementVNode(\"span\", null, \"原始链接\", -1))]),\n _: 1\n }), _createVNode(_component_el_radio, {\n label: \"mdUrl\",\n class: \"radio-card\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"code\",\n class: \"radio-icon\"\n }), _cache[43] || (_cache[43] = _createElementVNode(\"span\", null, \"Markdown\", -1))]),\n _: 1\n }), _createVNode(_component_el_radio, {\n label: \"htmlUrl\",\n class: \"radio-card\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"code-branch\",\n class: \"radio-icon\"\n }), _cache[44] || (_cache[44] = _createElementVNode(\"span\", null, \"HTML\", -1))]),\n _: 1\n }), _createVNode(_component_el_radio, {\n label: \"bbUrl\",\n class: \"radio-card\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"quote-right\",\n class: \"radio-icon\"\n }), _cache[45] || (_cache[45] = _createElementVNode(\"span\", null, \"BBCode\", -1))]),\n _: 1\n }), _createVNode(_component_el_radio, {\n label: \"tgId\",\n class: \"radio-card\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"paper-plane\",\n class: \"radio-icon\"\n }), _cache[46] || (_cache[46] = _createElementVNode(\"span\", null, \"TG File ID\", -1))]),\n _: 1\n }), _createVNode(_component_el_radio, {\n label: \"s3Location\",\n class: \"radio-card\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"cloud\",\n class: \"radio-icon\"\n }), _cache[47] || (_cache[47] = _createElementVNode(\"span\", null, \"S3链接\", -1))]),\n _: 1\n })]),\n _: 1\n }, 8, [\"modelValue\"])])]), _createElementVNode(\"div\", _hoisted_23, [_createElementVNode(\"div\", _hoisted_24, [_cache[49] || (_cache[49] = _createElementVNode(\"span\", {\n class: \"section-title\"\n }, \"自定义链接\", -1)), _createVNode(_component_el_tooltip, {\n content: \"默认链接为https://your.domain/file/xxx.jpg
如果启用自定义链接格式,只保留xxx.jpg部分,其他部分请自行输入\",\n placement: \"top\",\n \"raw-content\": \"\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"question-circle\",\n class: \"section-help-icon\"\n })]),\n _: 1\n })]), _createElementVNode(\"div\", _hoisted_25, [_createElementVNode(\"div\", _hoisted_26, [_cache[50] || (_cache[50] = _createElementVNode(\"span\", {\n class: \"setting-label\"\n }, \"启用自定义\", -1)), _createVNode(_component_el_switch, {\n modelValue: $data.useCustomUrl,\n \"onUpdate:modelValue\": _cache[13] || (_cache[13] = $event => $data.useCustomUrl = $event),\n \"active-value\": \"true\",\n \"inactive-value\": \"false\"\n }, null, 8, [\"modelValue\"])]), $data.useCustomUrl === 'true' ? (_openBlock(), _createElementBlock(\"div\", _hoisted_27, [_cache[51] || (_cache[51] = _createElementVNode(\"span\", {\n class: \"setting-label\"\n }, \"自定义前缀\", -1)), _createVNode(_component_el_input, {\n modelValue: $data.customUrlPrefix,\n \"onUpdate:modelValue\": _cache[14] || (_cache[14] = $event => $data.customUrlPrefix = $event),\n placeholder: \"请输入自定义链接前缀\",\n class: \"setting-input\"\n }, null, 8, [\"modelValue\"])])) : _createCommentVNode(\"\", true)])]), _createElementVNode(\"div\", _hoisted_28, [_createVNode(_component_el_button, {\n type: \"primary\",\n onClick: _cache[15] || (_cache[15] = $event => $data.showUrlDialog = false),\n class: \"confirm-btn\"\n }, {\n default: _withCtx(() => [...(_cache[52] || (_cache[52] = [_createTextVNode(\"确定\", -1)]))]),\n _: 1\n })])]),\n _: 1\n }, 8, [\"modelValue\", \"width\"]), _createVNode(_component_TagManagementDialog, {\n modelValue: $data.showTagDialog,\n \"onUpdate:modelValue\": _cache[17] || (_cache[17] = $event => $data.showTagDialog = $event),\n fileId: $data.currentTagFile,\n onTagsUpdated: $options.handleTagsUpdated\n }, null, 8, [\"modelValue\", \"fileId\", \"onTagsUpdated\"]), _createVNode(_component_BatchTagDialog, {\n modelValue: $data.showBatchTagDialog,\n \"onUpdate:modelValue\": _cache[18] || (_cache[18] = $event => $data.showBatchTagDialog = $event),\n selectedFiles: $data.selectedFiles,\n onTagsUpdated: $options.handleBatchTagsUpdated\n }, null, 8, [\"modelValue\", \"selectedFiles\", \"onTagsUpdated\"]), _createVNode(_component_MobileActionSheet, {\n modelValue: $data.showMobileActionModal,\n \"onUpdate:modelValue\": _cache[19] || (_cache[19] = $event => $data.showMobileActionModal = $event),\n title: $data.mobileActionIsFolder ? $options.getFolderName($data.mobileActionFile?.name || '') : $data.mobileActionFile?.metadata?.FileName || $options.getFileName($data.mobileActionFile?.name || ''),\n isFolder: $data.mobileActionIsFolder,\n onAction: $options.handleMobileAction\n }, null, 8, [\"modelValue\", \"title\", \"isFolder\", \"onAction\"]), _createVNode(_component_MobileDirectoryDrawer, {\n modelValue: $data.showMobileDirectoryDrawer,\n \"onUpdate:modelValue\": _cache[20] || (_cache[20] = $event => $data.showMobileDirectoryDrawer = $event),\n currentPath: $data.currentPath,\n onNavigate: $options.navigateToFolder,\n onGoBack: $options.handleGoBack\n }, null, 8, [\"modelValue\", \"currentPath\", \"onNavigate\", \"onGoBack\"])]);\n}","// 文件管理器工具类\r\nimport fetchWithAuth from '@/utils/fetchWithAuth';\r\nimport { ElMessage } from 'element-plus';\r\n\r\nclass FileManager {\r\n constructor() {\r\n this.FILE_LIST_PATH = 'data/fileList.json';\r\n }\r\n\r\n // 从本地存储读取文件列表\r\n getLocalFileList() {\r\n try {\r\n const fileList = localStorage.getItem(this.FILE_LIST_PATH);\r\n return fileList ? JSON.parse(fileList) : { files: [], directories: [] };\r\n } catch (error) {\r\n console.error('Error reading local file list:', error);\r\n return { files: [], directories: [] };\r\n }\r\n }\r\n\r\n // 保存文件列表到本地存储\r\n saveFileList(fileList) {\r\n try {\r\n localStorage.setItem(this.FILE_LIST_PATH, JSON.stringify(fileList));\r\n return true;\r\n } catch (error) {\r\n console.error('Error saving file list:', error);\r\n return false;\r\n }\r\n }\r\n\r\n // 添加新文件到列表\r\n addFile(newFile) {\r\n try {\r\n const fileList = this.getLocalFileList();\r\n fileList.files.push(newFile);\r\n return this.saveFileList(fileList);\r\n } catch (error) {\r\n console.error('Error adding file:', error);\r\n return false;\r\n }\r\n }\r\n\r\n // 添加新文件夹\r\n addFolder(folderName) {\r\n try {\r\n const fileList = this.getLocalFileList();\r\n if (!fileList.directories.includes(folderName)) {\r\n fileList.directories.push(folderName);\r\n return this.saveFileList(fileList);\r\n }\r\n return false; // 文件夹已存在\r\n } catch (error) {\r\n console.error('Error adding folder:', error);\r\n return false;\r\n }\r\n }\r\n\r\n // 移动文件或文件夹\r\n moveFile(oldPath, newPath, isFolder = false, currentPath = '') {\r\n try {\r\n let fileList = this.getLocalFileList();\r\n \r\n if (isFolder) {\r\n // 更新目录列表\r\n const oldFolderIndex = fileList.directories.indexOf(oldPath);\r\n if (oldFolderIndex !== -1) {\r\n fileList.directories.splice(oldFolderIndex, 1);\r\n }\r\n\r\n } else {\r\n // 移动单个文件\r\n const fileIndex = fileList.files.findIndex(file => file.name === oldPath);\r\n if (fileIndex !== -1) {\r\n // 从旧位置移除\r\n fileList.files.splice(fileIndex, 1);\r\n }\r\n\r\n }\r\n\r\n // 如果新路径包含当前目录的直接子目录,则添加直接子目录\r\n if (newPath.startsWith(currentPath)) {\r\n const pathArray = newPath.substring(currentPath.length).split('/');\r\n if (pathArray.length > 1) {\r\n const newFolder = currentPath + pathArray[0];\r\n if (!fileList.directories.includes(newFolder)) {\r\n fileList.directories.push(newFolder);\r\n }\r\n }\r\n }\r\n\r\n return this.saveFileList(fileList);\r\n } catch (error) {\r\n console.error('Error moving file:', error);\r\n return false;\r\n }\r\n }\r\n\r\n // 从列表中删除文件\r\n removeFile(fileName) {\r\n try {\r\n let fileList = this.getLocalFileList();\r\n fileList.files = fileList.files.filter(file => file.name !== fileName);\r\n return this.saveFileList(fileList);\r\n } catch (error) {\r\n console.error('Error removing file:', error);\r\n return false;\r\n }\r\n }\r\n\r\n // 从列表中删除文件夹(同时删除该文件夹下的所有文件)\r\n removeFolder(folderName) {\r\n try {\r\n let fileList = this.getLocalFileList();\r\n fileList.files = fileList.files.filter(file => !file.name.startsWith(folderName + '/'));\r\n fileList.directories = fileList.directories.filter(dir => dir !== folderName);\r\n return this.saveFileList(fileList);\r\n } catch (error) {\r\n console.error('Error removing folder:', error);\r\n return false;\r\n }\r\n }\r\n\r\n // 获取指定目录下的文件和子目录\r\n getFilesInFolder(folderName) {\r\n try {\r\n const fileList = this.getLocalFileList();\r\n const files = fileList.files.filter(file => file.name.startsWith(folderName + '/'));\r\n const subdirectories = fileList.directories.filter(dir => dir.startsWith(folderName + '/'));\r\n return { files, directories: subdirectories };\r\n } catch (error) {\r\n console.error('Error getting files in folder:', error);\r\n return { files: [], directories: [] };\r\n }\r\n }\r\n\r\n // 更新文件列表\r\n async refreshFileList(dir, search = '', includeTags = '', excludeTags = '') {\r\n search = search.trim();\r\n try {\r\n let url = `/api/manage/list?count=60&dir=${dir}&search=${encodeURIComponent(search)}`;\r\n if (includeTags) {\r\n url += `&includeTags=${encodeURIComponent(includeTags)}`;\r\n }\r\n if (excludeTags) {\r\n url += `&excludeTags=${encodeURIComponent(excludeTags)}`;\r\n }\r\n \r\n const response = await fetchWithAuth(url, {\r\n method: 'GET',\r\n });\r\n const newFileList = await response.json();\r\n if (!newFileList.isIndexedResponse) {\r\n ElMessage.warning('索引构建中,当前搜索和排序结果可能不准确,请稍后再试。');\r\n }\r\n // 保存包含新字段的完整数据\r\n return this.saveFileList(newFileList);\r\n } catch (error) {\r\n console.error('Error refreshing file list:', error);\r\n return false;\r\n }\r\n }\r\n\r\n // 读取更多数据\r\n async loadMoreFiles(dir, search = '', includeTags = '', excludeTags = '', count = 60) {\r\n search = search.trim();\r\n try {\r\n const fileList = this.getLocalFileList();\r\n const start = fileList.files.length;\r\n\r\n let url = `/api/manage/list?dir=${dir}&start=${start}&count=${count}&search=${encodeURIComponent(search)}`;\r\n if (includeTags) {\r\n url += `&includeTags=${encodeURIComponent(includeTags)}`;\r\n }\r\n if (excludeTags) {\r\n url += `&excludeTags=${encodeURIComponent(excludeTags)}`;\r\n }\r\n\r\n const response = await fetchWithAuth(url, {\r\n method: 'GET',\r\n });\r\n \r\n const moreFiles = await response.json();\r\n fileList.files.push(...moreFiles.files);\r\n return this.saveFileList(fileList);\r\n } catch (error) {\r\n console.error('Error loading more files:', error);\r\n return { files: [], directories: [] };\r\n }\r\n }\r\n}\r\n\r\nexport const fileManager = new FileManager();\r\n","import \"core-js/modules/es.array.push.js\";\nimport \"core-js/modules/es.iterator.constructor.js\";\nimport \"core-js/modules/es.iterator.every.js\";\nimport \"core-js/modules/es.iterator.filter.js\";\nimport \"core-js/modules/es.iterator.find.js\";\nimport \"core-js/modules/es.iterator.for-each.js\";\nimport \"core-js/modules/es.iterator.map.js\";\nimport \"core-js/modules/es.iterator.some.js\";\nimport \"core-js/modules/es.set.difference.v2.js\";\nimport \"core-js/modules/es.set.intersection.v2.js\";\nimport \"core-js/modules/es.set.is-disjoint-from.v2.js\";\nimport \"core-js/modules/es.set.is-subset-of.v2.js\";\nimport \"core-js/modules/es.set.is-superset-of.v2.js\";\nimport \"core-js/modules/es.set.symmetric-difference.v2.js\";\nimport \"core-js/modules/es.set.union.v2.js\";\nimport \"core-js/modules/web.url-search-params.delete.js\";\nimport \"core-js/modules/web.url-search-params.has.js\";\nimport \"core-js/modules/web.url-search-params.size.js\";\nimport { mapGetters } from 'vuex';\nimport JSZip from 'jszip';\nimport DashboardTabs from '@/components/DashboardTabs.vue';\nimport TagManagementDialog from '@/components/TagManagementDialog.vue';\nimport BatchTagDialog from '@/components/BatchTagDialog.vue';\nimport SkeletonLoader from '@/components/SkeletonLoader.vue';\nimport FileCard from '@/components/FileCard.vue';\nimport FolderCard from '@/components/FolderCard.vue';\nimport FileListItem from '@/components/FileListItem.vue';\nimport FileDetailDialog from '@/components/FileDetailDialog.vue';\nimport MobileActionSheet from '@/components/MobileActionSheet.vue';\nimport MobileDirectoryDrawer from '@/components/MobileDirectoryDrawer.vue';\nimport { fileManager } from '@/utils/fileManager';\nimport fetchWithAuth from '@/utils/fetchWithAuth';\nimport { validateFolderPath } from '@/utils/pathValidator';\nexport default {\n data() {\n return {\n Number: 0,\n directFileCount: 0,\n // 当前目录直接子文件数量\n directFolderCount: 0,\n // 当前目录直接子文件夹数量\n showLogoutButton: false,\n tableData: [],\n tempSearch: '',\n search: '',\n searchKeywords: '',\n // Keywords only (without tag filters) for backend search\n searchIncludeTags: '',\n // 包含的标签,逗号分隔\n searchExcludeTags: '',\n // 排除的标签,逗号分隔\n isSearchMode: false,\n currentPage: 1,\n pageSize: 15,\n selectedFiles: [],\n sortOption: 'dateDesc',\n isUploading: false,\n showdetailDialog: false,\n detailFile: null,\n activeUrlTab: 'originUrl',\n defaultUrlFormat: 'originUrl',\n showUrlDialog: false,\n useCustomUrl: 'false',\n // 是否启用自定义链接\n customUrlPrefix: '',\n // 自定义链接前缀\n loading: false,\n // 加载状态\n currentPath: '',\n // 当前文件夹路径\n refreshLoading: false,\n showTagDialog: false,\n // 标签管理对话框\n showBatchTagDialog: false,\n // 批量标签管理对话框\n currentTagFile: '',\n // 当前标签管理的文件\n viewMode: 'card',\n // 视图模式:card 或 list\n showMobileActionModal: false,\n // 移动端操作模态框\n mobileActionFile: null,\n // 当前移动端操作的文件\n mobileActionIndex: -1,\n // 当前移动端操作的文件索引\n mobileActionIsFolder: false,\n // 是否为文件夹操作\n longPressTimer: null,\n // 长按计时器\n showMobileDirectoryDrawer: false,\n // 移动端目录抽屉\n jumpPage: '' // 跳转页码输入\n };\n },\n components: {\n DashboardTabs,\n TagManagementDialog,\n BatchTagDialog,\n SkeletonLoader,\n FileCard,\n FolderCard,\n FileListItem,\n FileDetailDialog,\n MobileActionSheet,\n MobileDirectoryDrawer\n },\n computed: {\n ...mapGetters(['adminUrlSettings', 'userConfig']),\n filteredTableData() {\n return this.tableData;\n },\n totalPages() {\n return Math.ceil(this.filteredTableData.length / this.pageSize) || 1;\n },\n // 基于当前文件夹直接子文件和子文件夹数量计算的真实总页数\n realTotalPages() {\n const total = this.directFolderCount + this.directFileCount;\n return Math.ceil(total / this.pageSize) || 1;\n },\n paginatedTableData() {\n const sortedData = this.sortData(this.filteredTableData);\n const start = (this.currentPage - 1) * this.pageSize;\n const end = start + this.pageSize;\n let data = sortedData.slice(start, end);\n // 增加previewSrcList属性,用于预览图片\n const fullList = data.filter(file => this.isImage(file)).map(file => this.getFileLink(file.name));\n data.forEach(file => {\n if (this.isImage(file)) {\n // 重新排序,索引大于等于当前索引的元素在前,否则在后\n file.previewSrcList = fullList.slice(fullList.indexOf(this.getFileLink(file.name))).concat(fullList.slice(0, fullList.indexOf(this.getFileLink(file.name))));\n }\n });\n // 增加channelTag属性,用于显示渠道信息\n data.forEach(file => {\n if (file.metadata?.Channel === 'TelegramNew') {\n file.channelTag = 'TG';\n } else if (file.metadata?.Channel === 'CloudflareR2') {\n file.channelTag = 'R2';\n } else if (file.metadata?.Channel === 'S3') {\n file.channelTag = 'S3';\n } else if (file.metadata?.Channel === 'Discord') {\n file.channelTag = 'DC';\n } else if (file.metadata?.Channel === 'HuggingFace') {\n file.channelTag = 'HF';\n } else if (file.metadata?.Channel === 'External') {\n file.channelTag = '外链';\n } else {\n file.channelTag = '未知';\n }\n });\n return data;\n },\n sortIcon() {\n return this.sortOption === 'dateDesc' ? 'sort-amount-down' : 'sort-alpha-up';\n },\n dialogWidth() {\n return window.innerWidth > 768 ? '50%' : '90%';\n },\n detailDialogWidth() {\n return window.innerWidth > 768 ? '70%' : '90%';\n },\n accessType() {\n if (this.detailFile?.metadata?.ListType === 'White') {\n return '正常';\n } else if (this.detailFile?.metadata?.ListType === 'Block' || this.detailFile?.metadata?.Label === 'adult') {\n return '受限';\n } else {\n return '正常';\n }\n },\n allUrl() {\n // 外链图片均采用外链\n if (this.detailFile?.metadata?.Channel === 'External') {\n return {\n 'originUrl': `${this.detailFile?.metadata?.ExternalLink}`,\n 'mdUrl': `![${this.detailFile?.metadata?.FileName || this.detailFile?.name}](${this.detailFile?.metadata?.ExternalLink})`,\n 'htmlUrl': `\"${this.detailFile?.metadata?.FileName`,\n 'bbUrl': `[img]${this.detailFile?.metadata?.ExternalLink}[/img]`,\n 'tgId': this.detailFile?.metadata?.TgFileId || '未知',\n 'S3Location': this.detailFile?.metadata?.S3Location || '未知',\n 'S3CdnFileUrl': this.detailFile?.metadata?.S3CdnFileUrl || '未知'\n };\n } else {\n return {\n 'originUrl': `${this.rootUrl}${this.detailFile?.name}`,\n 'mdUrl': `![${this.detailFile?.metadata?.FileName || this.detailFile?.name}](${this.rootUrl}${this.detailFile?.name})`,\n 'htmlUrl': `\"${this.detailFile?.metadata?.FileName`,\n 'bbUrl': `[img]${this.rootUrl}${this.detailFile?.name}[/img]`,\n 'tgId': this.detailFile?.metadata?.TgFileId || '未知',\n 'S3Location': this.detailFile?.metadata?.S3Location || '未知',\n 'S3CdnFileUrl': this.detailFile?.metadata?.S3CdnFileUrl || '未知'\n };\n }\n },\n tableColumnNum() {\n return window.innerWidth > 768 ? 3 : 1;\n },\n tablePreviewSpan() {\n return window.innerWidth > 768 ? 2 : 1;\n },\n disableTooltip() {\n return window.innerWidth < 768;\n },\n selectPage() {\n // 如果当前页所有文件都被选中,则返回 true,否则返回 false\n return this.paginatedTableData.every(file => file.selected);\n },\n selectedPageFiles() {\n // 如果当前页有文件被选中,则返回 true,否则返回 false\n return this.paginatedTableData.some(file => file.selected);\n },\n selectPageIcon() {\n // 全选为 true 时,返回 check-square;部分选中为 minus-square;全不选为 square\n return this.selectPage ? 'check-square' : this.selectedPageFiles ? 'minus-square' : 'square';\n },\n rootUrl() {\n // 链接前缀,优先级:用户自定义 > urlPrefix > 默认\n return this.useCustomUrl === 'true' ? this.customUrlPrefix : this.userConfig?.urlPrefix || `${document.location.origin}/file/`;\n },\n isSelectAll: {\n get() {\n return this.paginatedTableData.length > 0 && this.paginatedTableData.every(file => file.selected);\n },\n set(val) {\n this.paginatedTableData.forEach(file => file.selected = val);\n }\n },\n isIndeterminate() {\n const selectedCount = this.paginatedTableData.filter(file => file.selected).length;\n return selectedCount > 0 && selectedCount < this.paginatedTableData.length;\n },\n pagerCount() {\n return window.innerWidth < 768 ? 3 : 7;\n }\n },\n watch: {\n tableData: {\n handler(newData) {\n // selectedFiles 增加 newData中新选中,不包含在 selectedFiles 中的文件\n this.selectedFiles = this.selectedFiles.concat(newData.filter(file => file.selected && !this.selectedFiles.includes(file)));\n // selectedFiles 删掉 newData 中已取消选中的文件\n this.selectedFiles = this.selectedFiles.filter(file => file.selected);\n // selectedFiles 删掉 tableData 中已删除的文件\n this.selectedFiles = this.selectedFiles.filter(file => newData.includes(file));\n },\n deep: true\n },\n sortOption(newOption) {\n localStorage.setItem('sortOption', newOption);\n },\n defaultUrlFormat(newFormat) {\n localStorage.setItem('defaultUrlFormat', newFormat);\n },\n showdetailDialog(newVal) {\n if (newVal) {\n this.activeUrlTab = this.defaultUrlFormat || 'originUrl';\n }\n },\n customUrlPrefix(val) {\n this.$store.commit('setAdminUrlSettings', {\n key: 'customUrlPrefix',\n value: val\n });\n },\n useCustomUrl(val) {\n this.$store.commit('setAdminUrlSettings', {\n key: 'useCustomUrl',\n value: val\n });\n },\n currentPath(val) {\n // 页面切换时,取消选择的内容\n this.tableData.forEach(file => file.selected = false);\n }\n },\n methods: {\n // 切换视图模式\n toggleViewMode() {\n this.viewMode = this.viewMode === 'card' ? 'list' : 'card';\n localStorage.setItem('viewMode', this.viewMode);\n },\n // 列表视图全选当前页\n handleSelectAllPage(val) {\n this.paginatedTableData.forEach(file => file.selected = val);\n },\n // 移动端长按开始\n handleTouchStart(item, index) {\n this.longPressTimer = setTimeout(() => {\n this.mobileActionFile = item;\n this.mobileActionIndex = index;\n this.mobileActionIsFolder = false;\n this.showMobileActionModal = true;\n }, 500); // 500ms 长按触发\n },\n // 移动端长按结束/取消\n handleTouchEnd() {\n if (this.longPressTimer) {\n clearTimeout(this.longPressTimer);\n this.longPressTimer = null;\n }\n },\n // 文件夹长按开始\n handleFolderTouchStart(item, index) {\n this.longPressTimer = setTimeout(() => {\n this.mobileActionFile = item;\n this.mobileActionIndex = index;\n this.mobileActionIsFolder = true;\n this.showMobileActionModal = true;\n }, 500);\n },\n // 处理移动端操作\n handleMobileAction(action) {\n const file = this.mobileActionFile;\n const index = this.mobileActionIndex;\n this.showMobileActionModal = false;\n if (!file) return;\n switch (action) {\n case 'detail':\n this.openDetailDialog(index, file.name);\n break;\n case 'copy':\n this.handleCopy(index, file.name);\n break;\n case 'folderCopy':\n this.handleFolderCopy(file.name);\n break;\n case 'download':\n this.handleDownload(file.name);\n break;\n case 'move':\n this.handleMove(index, file.name);\n break;\n case 'delete':\n this.handleDelete(index, file.name);\n break;\n case 'tag':\n this.handleTagManagement(file.name);\n break;\n }\n },\n // 返回上一级目录\n handleGoBack() {\n const pathParts = this.currentPath.split('/').filter(Boolean);\n if (pathParts.length > 0) {\n pathParts.pop();\n const parentPath = pathParts.join('/');\n this.navigateToFolder(parentPath);\n }\n this.showMobileDirectoryDrawer = false;\n },\n // 获取标签颜色\n getTagColor(index) {\n const colors = ['linear-gradient(135deg, #667eea 0%, #764ba2 100%)', 'linear-gradient(135deg, #f093fb 0%, #f5576c 100%)', 'linear-gradient(135deg, #4facfe 0%, #00f2fe 100%)', 'linear-gradient(135deg, #43e97b 0%, #38f9d7 100%)', 'linear-gradient(135deg, #fa709a 0%, #fee140 100%)', 'linear-gradient(135deg, #a8edea 0%, #fed6e3 100%)'];\n return colors[index % colors.length];\n },\n // 视频hover播放控制\n handleVideoHover(event, isEnter) {\n const video = event.target;\n if (isEnter) {\n video.play().catch(() => {});\n } else {\n video.pause();\n video.currentTime = 0;\n }\n },\n // 格式化文件大小\n formatFileSize(bytes) {\n if (!bytes || bytes === 0) return '-';\n bytes = Number(bytes);\n if (isNaN(bytes)) return '-';\n const units = ['B', 'KB', 'MB', 'GB', 'TB'];\n let i = 0;\n while (bytes >= 1024 && i < units.length - 1) {\n bytes /= 1024;\n i++;\n }\n return bytes.toFixed(i > 0 ? 1 : 0) + ' ' + units[i];\n },\n handleSearch() {\n this.search = this.tempSearch;\n this.isSearchMode = this.search.trim() !== '';\n this.currentPage = 1; // 重置到第一页\n\n // 解析搜索字符串,提取标签和关键字\n // 支持 #tag 表示包含标签,-#tag 表示排除标签\n if (this.search && this.search.trim()) {\n const includeTags = [];\n const excludeTags = [];\n\n // 匹配 -#tag 和 #tag\n let searchText = this.search;\n\n // 先匹配排除标签 -#tag\n const excludeTagRegex = /-#([\\w\\u4e00-\\u9fa5\\u3040-\\u309f\\u30a0-\\u30ff\\uac00-\\ud7af\\.\\+\\-]+)/g;\n searchText = searchText.replace(excludeTagRegex, (match, tag) => {\n excludeTags.push(tag.toLowerCase());\n return ' ';\n });\n\n // 再匹配包含标签 #tag\n const includeTagRegex = /#([\\w\\u4e00-\\u9fa5\\u3040-\\u309f\\u30a0-\\u30ff\\uac00-\\ud7af\\.\\+\\-]+)/g;\n searchText = searchText.replace(includeTagRegex, (match, tag) => {\n includeTags.push(tag.toLowerCase());\n return ' ';\n });\n\n // 清理剩余的关键字(去除多余空格)\n this.searchKeywords = searchText.replace(/\\s+/g, ' ').trim();\n\n // 构建标签查询字符串\n this.searchIncludeTags = includeTags.join(',');\n this.searchExcludeTags = excludeTags.join(',');\n console.log('Search keywords:', this.searchKeywords);\n console.log('Include tags:', this.searchIncludeTags);\n console.log('Exclude tags:', this.searchExcludeTags);\n } else {\n this.searchKeywords = '';\n this.searchIncludeTags = '';\n this.searchExcludeTags = '';\n }\n this.refreshFileList();\n },\n handleDownload(key) {\n const link = document.createElement('a');\n link.href = this.getFileLink(key);\n link.download = key;\n link.click();\n },\n openDetailDialog(index, key) {\n this.detailFile = this.paginatedTableData[index];\n this.showdetailDialog = true;\n },\n handleTabClick(tab) {\n this.activeUrlTab = tab.props.name;\n },\n handleUrlClick(event) {\n // 复制到剪贴板\n navigator.clipboard.writeText(event.target.value).then(() => {\n this.$message({\n type: 'success',\n message: '复制成功'\n });\n }).catch(() => {\n this.$message({\n type: 'error',\n message: '复制失败'\n });\n });\n },\n handleDetailDelete(key) {\n this.$confirm('此操作将永久删除该文件, 是否继续?', '提示', {\n confirmButtonText: '确定',\n cancelButtonText: '取消',\n type: 'warning'\n }).then(() => {\n fetchWithAuth(`/api/manage/delete/${key}`, {\n method: 'GET'\n }).then(response => {\n if (response.ok) {\n const fileIndex = this.tableData.findIndex(file => file.name === key);\n if (fileIndex !== -1) {\n this.tableData.splice(fileIndex, 1);\n }\n } else {\n return Promise.reject('请求失败');\n }\n }).then(() => {\n this.updateStats(-1, false);\n this.$message.success('删除成功');\n this.showdetailDialog = false;\n }).catch(() => this.$message.error('删除失败'));\n }).catch(() => console.log('已取消删除'));\n },\n handleBlock(key) {\n this.$confirm('此操作将把该文件加入黑名单, 是否继续?', '提示', {\n confirmButtonText: '确定',\n cancelButtonText: '取消',\n type: 'warning'\n }).then(() => {\n fetchWithAuth(`/api/manage/block/${key}`, {\n method: 'GET'\n }).then(response => {\n if (response.ok) {\n const fileIndex = this.tableData.findIndex(file => file.name === key);\n if (fileIndex !== -1) {\n this.tableData[fileIndex].metadata.ListType = 'Block';\n }\n } else {\n return Promise.reject('请求失败');\n }\n }).then(() => {\n this.$message.success('加入黑名单成功');\n }).catch(() => this.$message.error('加入黑名单失败'));\n }).catch(() => console.log('已取消加入黑名单'));\n },\n handleWhite(key) {\n this.$confirm('此操作将把该文件加入白名单, 是否继续?', '提示', {\n confirmButtonText: '确定',\n cancelButtonText: '取消',\n type: 'warning'\n }).then(() => {\n fetchWithAuth(`/api/manage/white/${key}`, {\n method: 'GET'\n }).then(response => {\n if (response.ok) {\n const fileIndex = this.tableData.findIndex(file => file.name === key);\n if (fileIndex !== -1) {\n this.tableData[fileIndex].metadata.ListType = 'White';\n }\n } else {\n return Promise.reject('请求失败');\n }\n }).then(() => {\n this.$message.success('加入白名单成功');\n }).catch(() => this.$message.error('加入白名单失败'));\n }).catch(() => console.log('已取消加入白名单'));\n },\n handleDelete(index, key) {\n // 判断是否为文件夹\n const isFolder = this.tableData.find(file => file.name === key).isFolder;\n this.$confirm(`此操作将永久删除${isFolder ? '文件夹' : '该文件'}, 是否继续?`, '提示', {\n confirmButtonText: '确定',\n cancelButtonText: '取消',\n type: 'warning'\n }).then(() => {\n fetchWithAuth(`/api/manage/delete/${key}?folder=${isFolder}`, {\n method: 'GET'\n }).then(response => {\n if (response.ok) {\n const fileIndex = this.tableData.findIndex(file => file.name === key);\n if (fileIndex !== -1) {\n this.tableData.splice(fileIndex, 1);\n }\n } else {\n return Promise.reject('请求失败');\n }\n }).then(() => {\n this.updateStats(-1, false);\n fileManager.removeFile(key);\n this.$message.success('删除成功');\n }).catch(() => this.$message.error('删除失败'));\n }).catch(() => console.log('已取消删除'));\n },\n handleBatchDelete() {\n this.$confirm('此操作将永久删除选中的文件及文件夹, 是否继续?', '提示', {\n confirmButtonText: '确定',\n cancelButtonText: '取消',\n type: 'warning'\n }).then(() => {\n const promises = this.selectedFiles.map(file => {\n const isFolder = file.isFolder;\n return fetchWithAuth(`/api/manage/delete/${file.name}?folder=${isFolder}`, {\n method: 'GET'\n });\n });\n Promise.all(promises).then(results => {\n let successNum = 0;\n results.forEach((response, index) => {\n if (response.ok) {\n successNum++;\n const fileIndex = this.tableData.findIndex(file => file.name === this.selectedFiles[index].name);\n if (fileIndex !== -1) {\n this.tableData.splice(fileIndex, 1);\n }\n fileManager.removeFile(this.selectedFiles[index].name);\n }\n });\n this.selectedFiles = [];\n this.updateStats(-successNum, false);\n this.$message.success('批量删除成功');\n }).catch(() => this.$message.error('批量删除失败'));\n }).catch(() => console.log('已取消批量删除'));\n },\n async handleBatchCopy() {\n // 分离文件和文件夹\n const files = this.selectedFiles.filter(item => !item.isFolder);\n const folders = this.selectedFiles.filter(item => item.isFolder);\n\n // 如果有文件夹,显示加载状态\n let loading = null;\n if (folders.length > 0) {\n loading = this.$loading({\n lock: true,\n text: '正在获取文件列表...'\n });\n }\n try {\n // 收集所有文件(包括文件夹内的文件)\n let allFiles = [...files];\n\n // 递归获取所有文件夹内的文件\n for (const folder of folders) {\n try {\n const response = await fetchWithAuth(`/api/manage/list?dir=${encodeURIComponent(folder.name)}&recursive=true&count=-1`, {\n method: 'GET'\n });\n const data = await response.json();\n if (data.files && data.files.length > 0) {\n allFiles = allFiles.concat(data.files);\n }\n } catch (error) {\n console.error(`获取文件夹 ${folder.name} 内容失败:`, error);\n }\n }\n if (loading) loading.close();\n if (allFiles.length === 0) {\n this.$message.warning('没有可复制的链接');\n return;\n }\n\n // 生成所有链接\n const links = allFiles.map(file => {\n return this.generateFileLink(file.name, file.metadata);\n }).filter(link => link); // 过滤掉空链接\n\n if (links.length === 0) {\n this.$message.warning('没有可复制的链接');\n return;\n }\n\n // 复制到剪贴板\n const text = links.join('\\n');\n if (navigator.clipboard) {\n await navigator.clipboard.writeText(text);\n this.$message.success(`批量复制 ${links.length} 个链接成功`);\n } else {\n this.copyToClipboardFallback(text);\n }\n } catch (error) {\n if (loading) loading.close();\n console.error('批量复制链接失败:', error);\n this.$message.error('批量复制链接失败,请重试');\n }\n },\n copyToClipboardFallback(text) {\n const textarea = document.createElement('textarea');\n document.body.appendChild(textarea);\n textarea.style.position = 'fixed';\n textarea.style.clip = 'rect(0 0 0 0)';\n textarea.style.top = '10px';\n textarea.value = text;\n textarea.select();\n document.execCommand('copy');\n document.body.removeChild(textarea);\n this.$message.success('批量复制链接成功');\n },\n handleCopy(index, key) {\n let text = '';\n if (this.paginatedTableData[index].metadata?.Channel === 'External') {\n switch (this.defaultUrlFormat) {\n case 'originUrl':\n text = this.paginatedTableData[index].metadata?.ExternalLink;\n break;\n case 'mdUrl':\n text = `![${this.paginatedTableData[index].metadata?.FileName || key}](${this.paginatedTableData[index].metadata?.ExternalLink})`;\n break;\n case 'htmlUrl':\n text = `\"${this.paginatedTableData[index].metadata?.FileName`;\n break;\n case 'bbUrl':\n text = `[img]${this.paginatedTableData[index].metadata?.ExternalLink}[/img]`;\n break;\n case 'tgId':\n text = this.paginatedTableData[index].metadata?.TgFileId || 'none';\n break;\n case 's3Location':\n text = this.paginatedTableData[index].metadata?.S3Location || 'none';\n break;\n }\n } else {\n switch (this.defaultUrlFormat) {\n case 'originUrl':\n text = `${this.rootUrl}${key}`;\n break;\n case 'mdUrl':\n text = `![${this.paginatedTableData[index].metadata?.FileName || key}](${this.rootUrl}${key})`;\n break;\n case 'htmlUrl':\n text = `\"${this.paginatedTableData[index].metadata?.FileName`;\n break;\n case 'bbUrl':\n text = `[img]${this.rootUrl}${key}[/img]`;\n break;\n case 'tgId':\n text = this.paginatedTableData[index].metadata?.TgFileId || 'none';\n break;\n case 's3Location':\n text = this.paginatedTableData[index].metadata?.S3Location || 'none';\n break;\n }\n }\n navigator.clipboard ? navigator.clipboard.writeText(text).then(() => this.$message.success('复制文件链接成功')) : this.copyToClipboardFallback(text);\n },\n async loadMoreData() {\n this.loading = true;\n try {\n // 传递标签参数到后端\n await fileManager.loadMoreFiles(this.currentPath, this.searchKeywords, this.searchIncludeTags, this.searchExcludeTags);\n // 获取新的文件列表后\n await this.fetchFileList();\n } catch (error) {\n this.$message.error('加载更多文件失败,请检查网络连接');\n } finally {\n this.loading = false;\n }\n },\n updateStats(num, init = false) {\n if (init) {\n this.Number = num;\n } else {\n this.Number += num;\n }\n },\n sort(command) {\n this.sortOption = command;\n },\n sortData(data) {\n // 文件夹始终在前\n const folders = data.filter(file => file.isFolder);\n const files = data.filter(file => !file.isFolder);\n if (this.sortOption === 'dateDesc') {\n // 按时间降序\n folders.sort((a, b) => new Date(b.metadata?.TimeStamp) - new Date(a.metadata?.TimeStamp));\n files.sort((a, b) => new Date(b.metadata?.TimeStamp) - new Date(a.metadata?.TimeStamp));\n } else {\n // 按文件名升序\n folders.sort((a, b) => a.name.localeCompare(b.name));\n files.sort((a, b) => a.name.localeCompare(b.name));\n }\n return folders.concat(files);\n },\n handleVideoClick(event) {\n const videoElement = event.target;\n if (videoElement.requestFullscreen) {\n videoElement.requestFullscreen();\n } else if (videoElement.webkitRequestFullscreen) {\n // Safari/Old Chrome\n videoElement.webkitRequestFullscreen();\n } else if (videoElement.mozRequestFullScreen) {\n // Firefox\n videoElement.mozRequestFullScreen();\n } else if (videoElement.msRequestFullscreen) {\n // IE/Edge\n videoElement.msRequestFullscreen();\n }\n },\n handleLogout() {\n this.$store.commit('setCredentials', null);\n this.$router.push('/adminLogin');\n },\n handleSelectPage() {\n if (this.selectPage) {\n this.paginatedTableData.forEach(file => file.selected = false);\n } else {\n this.paginatedTableData.forEach(file => file.selected = true);\n }\n },\n handleBatchAction(command) {\n if (command === 'copy') {\n this.handleBatchCopy();\n } else if (command === 'delete') {\n this.handleBatchDelete();\n } else if (command === 'download') {\n this.handleBatchDownload();\n } else if (command === 'move') {\n this.handleBatchMove();\n } else if (command === 'tagManagement') {\n this.handleBatchTagManagement();\n } else if (command === 'ban') {\n this.handleBatchBlock();\n } else if (command === 'white') {\n this.handleBatchWhite();\n }\n },\n handleMove(index, key) {\n // 弹窗输入新的文件夹路径\n this.$prompt('请输入新的目录', '移动文件', {\n confirmButtonText: '确定',\n cancelButtonText: '取消',\n inputValue: '/',\n beforeClose: (action, instance, done) => {\n if (action === 'confirm') {\n const value = instance.inputValue;\n // 使用共享验证器验证路径\n const validation = validateFolderPath(value);\n if (!validation.valid) {\n this.$message.error(validation.error);\n return; // 验证失败,不关闭弹窗\n }\n done(); // 验证通过,关闭弹窗\n } else {\n done(); // 取消操作,直接关闭\n }\n }\n }).then(({\n value\n }) => {\n // 去掉开头的 /,结尾若没有 /,则加上\n const newPath = value.replace(/^\\/+/, '') + (value.endsWith('/') ? '' : value === '' ? '' : '/');\n const isFolder = this.tableData.find(file => file.name === key).isFolder;\n // 判断目标文件夹是否是当前文件夹\n if (newPath === this.currentPath) {\n this.$message.warning('目标文件夹不能是当前文件夹');\n return;\n }\n fetchWithAuth(`/api/manage/move/${key}?folder=${isFolder}&dist=${newPath}`, {\n method: 'GET'\n }).then(response => {\n if (response.ok) {\n const fileIndex = this.tableData.findIndex(file => file.name === key);\n if (fileIndex !== -1) {\n // 更新本地文件管理器\n const newKey = newPath + key.split('/').pop();\n fileManager.moveFile(key, newKey, isFolder, this.currentPath);\n // 移除文件\n this.tableData.splice(fileIndex, 1);\n // 强制重新渲染内容\n this.$nextTick(() => {\n // 创建临时数组\n const tempData = [...this.tableData];\n // 清空数组\n this.tableData = [];\n // 在下一个tick中恢复数据\n this.$nextTick(() => {\n this.tableData = tempData;\n });\n });\n }\n this.updateStats(-1, false);\n this.$message.success('移动成功');\n } else {\n return Promise.reject('请求失败');\n }\n }).then(() => {\n // 刷新本地文件列表\n this.refreshLocalFileList();\n }).catch(() => this.$message.error('移动失败'));\n }).catch(() => console.log('已取消移动文件'));\n },\n handleBatchMove() {\n // 弹窗输入新的文件夹路径\n this.$prompt('请输入新的目录', '移动文件', {\n confirmButtonText: '确定',\n cancelButtonText: '取消',\n inputValue: '/',\n beforeClose: (action, instance, done) => {\n if (action === 'confirm') {\n const value = instance.inputValue;\n // 使用共享验证器验证路径\n const validation = validateFolderPath(value);\n if (!validation.valid) {\n this.$message.error(validation.error);\n return; // 验证失败,不关闭弹窗\n }\n done(); // 验证通过,关闭弹窗\n } else {\n done(); // 取消操作,直接关闭\n }\n }\n }).then(({\n value\n }) => {\n // 去掉开头的 /,结尾若没有 /,则加上\n const newPath = value.replace(/^\\/+/, '') + (value.endsWith('/') ? '' : value === '' ? '' : '/');\n // 判断目标文件夹是否是当前文件夹\n if (newPath === this.currentPath) {\n this.$message.warning('目标文件夹不能是当前文件夹');\n return;\n }\n const promises = this.selectedFiles.map(file => {\n const isFolder = file.isFolder;\n return fetchWithAuth(`/api/manage/move/${file.name}?folder=${isFolder}&dist=${newPath}`, {\n method: 'GET'\n });\n });\n Promise.all(promises).then(results => {\n let successNum = 0;\n results.forEach((response, index) => {\n if (response.ok) {\n successNum++;\n const file = this.selectedFiles[index];\n file.selected = false;\n const fileIndex = this.tableData.findIndex(f => f.name === file.name);\n if (fileIndex !== -1) {\n // 更新本地文件管理器\n const newKey = newPath + file.name.split('/').pop();\n fileManager.moveFile(file.name, newKey, file.isFolder, this.currentPath);\n // 移除文件\n this.tableData.splice(fileIndex, 1);\n }\n }\n });\n // 强制重新渲染内容\n this.$nextTick(() => {\n // 创建临时数组\n const tempData = [...this.tableData];\n // 清空数组\n this.tableData = [];\n // 在下一个tick中恢复数据\n this.$nextTick(() => {\n this.tableData = tempData;\n });\n });\n this.updateStats(-successNum, false);\n this.$message.success('移动成功');\n }).then(() => {\n // 刷新本地文件列表\n this.refreshLocalFileList();\n }).catch(() => this.$message.error('移动失败'));\n }).catch(() => console.log('已取消移动文件'));\n },\n handleBatchBlock() {\n this.$confirm('此操作将把选中的文件加入黑名单, 是否继续?', '提示', {\n confirmButtonText: '确定',\n cancelButtonText: '取消',\n type: 'warning'\n }).then(() => {\n // 跳过文件夹\n const promises = this.selectedFiles.map(file => {\n if (file.isFolder) {\n return Promise.resolve({\n ok: false\n });\n }\n return fetchWithAuth(`/api/manage/block/${file.name}`, {\n method: 'GET'\n });\n });\n Promise.all(promises).then(results => {\n results.forEach((response, index) => {\n if (response.ok) {\n const fileIndex = this.tableData.findIndex(file => file.name === this.selectedFiles[index].name);\n if (fileIndex !== -1) {\n this.tableData[fileIndex].metadata.ListType = 'Block';\n }\n }\n });\n this.$message.success('批量加入黑名单成功');\n }).catch(() => this.$message.error('批量加入黑名单失败'));\n }).catch(() => console.log('已取消批量加入黑名单'));\n },\n handleBatchWhite() {\n this.$confirm('此操作将把选中的文件加入白名单, 是否继续?', '提示', {\n confirmButtonText: '确定',\n cancelButtonText: '取消',\n type: 'warning'\n }).then(() => {\n // 跳过文件夹\n const promises = this.selectedFiles.map(file => {\n if (file.isFolder) {\n return Promise.resolve({\n ok: false\n });\n }\n return fetchWithAuth(`/api/manage/white/${file.name}`, {\n method: 'GET'\n });\n });\n Promise.all(promises).then(results => {\n results.forEach((response, index) => {\n if (response.ok) {\n const fileIndex = this.tableData.findIndex(file => file.name === this.selectedFiles[index].name);\n if (fileIndex !== -1) {\n this.tableData[fileIndex].metadata.ListType = 'White';\n }\n }\n });\n this.$message.success('批量加入白名单成功');\n }).catch(() => this.$message.error('批量加入白名单失败'));\n }).catch(() => console.log('已取消批量加入白名单'));\n },\n handleBatchDownload() {\n // 将选中文件打包成 zip 文件下载\n const zip = new JSZip();\n const folder = zip.folder('files');\n // 构造Promise数组,等待所有文件下载完成后再打包\n const fileNameCount = {}; // 用于跟踪文件名出现的次数\n\n const downloadPromises = this.selectedFiles.map(async file => {\n // 跳过文件夹\n if (file.isFolder) {\n return;\n }\n const response = await fetch(this.getFileLink(file.name));\n const blob = await response.blob();\n // 检查文件名是否已经存在\n let fileName = file.metadata?.FileName || file.name;\n if (fileNameCount[fileName]) {\n // 如果已经存在,则在文件名后加上编号\n const extension = fileName.substring(fileName.lastIndexOf('.'));\n const baseName = fileName.substring(0, fileName.lastIndexOf('.'));\n fileName = `${baseName}(${fileNameCount[fileName]})${extension}`;\n fileNameCount[file.name]++;\n } else {\n // 如果不存在,则初始化为1\n fileNameCount[fileName] = 1;\n }\n // 将文件添加到 zip 文件夹中\n folder.file(fileName, blob);\n });\n Promise.all(downloadPromises).then(() => zip.generateAsync({\n type: 'blob'\n })).then(blob => {\n const link = document.createElement('a');\n link.href = URL.createObjectURL(blob);\n link.download = 'files.zip';\n link.click();\n });\n },\n isVideo(file) {\n // 排除音频文件\n if (this.isAudio(file)) return false;\n let flag = file.metadata?.FileType?.includes('video');\n // 用文件名后缀判断是否为视频文件\n if (!flag) {\n const videoExtensions = ['mp4', 'webm', 'ogg', 'avi', 'mov', 'flv', 'wmv', 'mkv', 'rmvb', '3gp', 'mpg', 'mpeg', 'm4v', 'f4v', 'rm', 'asf', 'dat', 'ts', 'vob', 'swf', 'divx', 'xvid', 'm2ts', 'mts', 'm2v', '3g2', '3gp2', '3gpp', '3gpp2', 'mpe', 'm1v', 'mpv', 'mpv2', 'mp2v', 'm2t', 'm2ts', 'm2v', 'm4v'];\n const extension = file.name.substring(file.name.lastIndexOf('.') + 1).toLowerCase();\n flag = videoExtensions.includes(extension);\n }\n return flag;\n },\n isAudio(file) {\n let flag = file.metadata?.FileType?.includes('audio');\n // 用文件名后缀判断是否为音频文件\n if (!flag) {\n const audioExtensions = ['mp3', 'wav', 'flac', 'aac', 'ogg', 'wma', 'm4a', 'ape', 'aiff', 'alac', 'opus', 'mid', 'midi', 'm4b', 'm4p', 'm4r', 'amr', 'au', 'ra', 'ram'];\n const extension = file.name.substring(file.name.lastIndexOf('.') + 1).toLowerCase();\n flag = audioExtensions.includes(extension);\n }\n return flag;\n },\n isImage(file) {\n let flag = file.metadata?.FileType?.includes('image');\n // 用文件名后缀判断是否为图片文件\n if (!flag) {\n const imageExtensions = ['jpg', 'jpeg', 'png', 'gif', 'bmp', 'webp', 'svg', 'ico', 'tiff', 'tif', 'psd', 'ai', 'eps', 'raw', 'cr2', 'nef', 'orf', 'sr2', 'dng', 'arw', 'rw2', 'raf', 'pef', 'x3f', 'srf', 'erf', 'mrw', 'nrw', 'kdc', 'dcr', 'mef', 'mos', 'crw', 'raf', 'rwl', 'srw', '3fr', 'fff', 'iiq', 'qtk', 'bay', 'k25', 'kdc', 'dcs', 'drf', 'dng', 'erf', 'kdc', 'mdc', 'mef', 'mos', 'mrw', 'nef', 'nrw', 'orf', 'pef', 'ptx', 'pxn', 'r3d', 'raf', 'raw', 'rwl', 'rw2', 'rwz', 'sr2', 'srf', 'x3f'];\n const extension = file.name.substring(file.name.lastIndexOf('.') + 1).toLowerCase();\n flag = imageExtensions.includes(extension);\n }\n return flag;\n },\n getFileLink(filename) {\n const fileLink = process.env.NODE_ENV === 'production' ? `/file/${filename}?from=admin` : `/api/file/${filename}?from=admin`;\n return fileLink;\n },\n handlePageChange(page) {\n this.currentPage = page;\n // 到最后一页时,加载更多数据\n if (this.currentPage === Math.ceil(this.tableData.length / this.pageSize)) {\n this.loadMoreData();\n }\n },\n // 跳转到指定页码\n handleJumpPage() {\n const page = parseInt(this.jumpPage);\n if (isNaN(page) || page < 1) {\n this.$message.warning('请输入有效的页码');\n return;\n }\n if (page > this.realTotalPages) {\n this.$message.warning(`页码不能超过 ${this.realTotalPages}`);\n return;\n }\n // 如果目标页超过当前已加载的页数,需要先加载更多数据\n if (page > this.totalPages) {\n this.$message.info('正在加载数据,请稍候...');\n this.loadMoreDataUntilPage(page);\n } else {\n this.currentPage = page;\n }\n this.jumpPage = '';\n },\n // 加载数据直到指定页\n async loadMoreDataUntilPage(targetPage) {\n this.loading = true;\n try {\n // 计算目标页需要的文件数量(不包含文件夹)\n // 目标页最后一个项目的索引 = targetPage * pageSize\n // 需要的文件数 = 目标索引 - 已有文件夹数量\n const targetIndex = targetPage * this.pageSize;\n const currentFolderCount = this.filteredTableData.filter(item => item.isFolder).length;\n const currentFileCount = this.filteredTableData.filter(item => !item.isFolder).length;\n\n // 需要加载的文件数量 = 目标位置需要的文件数 - 当前已加载的文件数\n const neededFileCount = Math.max(0, targetIndex - currentFolderCount - currentFileCount);\n if (neededFileCount > 0) {\n await fileManager.loadMoreFiles(this.currentPath, this.searchKeywords, this.searchIncludeTags, this.searchExcludeTags, neededFileCount);\n await this.fetchFileList();\n }\n this.currentPage = Math.min(targetPage, this.totalPages);\n } catch (error) {\n this.$message.error('加载数据失败,请检查网络连接');\n } finally {\n this.loading = false;\n }\n },\n // 判断是否为文件夹\n isFolder(item) {\n // 如果是已经标记为文件夹的项目,直接返回true\n if (item.isFolder) {\n return true;\n }\n\n // 获取真实的文件路径(去除URL前缀)\n let path = item.name;\n if (path.startsWith('http')) {\n path = path.split('/file/')[1];\n }\n\n // 如果文件名包含'/',需要判断是否是当前路径下的文件\n if (path && path.includes('/')) {\n // 获取相对于当前路径的部分\n const relativePath = this.currentPath ? path.substring(this.currentPath.length) : path;\n\n // 如果在根目录,第一个斜杠前的部分就是文件夹\n if (this.currentPath === '') {\n return !path.split('/')[0].includes('.');\n }\n\n // 如果在子文件夹中,检查相对路径是否还包含其他文件夹\n return relativePath.includes('/');\n }\n return false;\n },\n // 获取文件夹名称\n getFolderName(path) {\n let folderName = '';\n // 如果是文件夹路径,只返回最后一级文件夹名\n if (path && path.includes('/')) {\n const parts = path.split('/');\n // 如果是根目录下的文件夹\n if (this.currentPath === '') {\n folderName = parts[0];\n } else {\n // 如果是子文件夹\n const relativePath = path.substring(this.currentPath.length);\n folderName = relativePath.split('/')[0];\n }\n } else {\n folderName = path;\n }\n const maxLength = 20; // Adjust max length as needed\n if (folderName.length > maxLength) {\n const startLength = Math.floor((maxLength - 3) / 2);\n const endLength = Math.ceil((maxLength - 3) / 2);\n return `${folderName.substring(0, startLength)}...${folderName.substring(folderName.length - endLength)}`;\n }\n return folderName;\n },\n // 获取文件名称(去除路径和URL前缀)\n getFileName(path) {\n let fileName = path.split('/').pop();\n const maxLength = 20; // Adjust max length as needed, ensure it fits in one line\n if (fileName.length > maxLength) {\n const startLength = Math.floor((maxLength - 3) / 2);\n const endLength = Math.ceil((maxLength - 3) / 2);\n return `${fileName.substring(0, startLength)}...${fileName.substring(fileName.length - endLength)}`;\n }\n return fileName;\n },\n // 获取文件名前半部分(用于中间省略效果)\n getFileNameStart(name) {\n if (!name) return '';\n // 如果文件名较短,返回全部\n if (name.length <= 30) return name;\n // 保留开头部分(约60%的长度用于显示前半部分)\n const dotIndex = name.lastIndexOf('.');\n if (dotIndex > 0) {\n // 有扩展名的情况:返回文件名主体部分\n const baseName = name.substring(0, dotIndex);\n const keepLength = Math.min(baseName.length, Math.floor(name.length * 0.6));\n return baseName.substring(0, keepLength);\n }\n // 无扩展名的情况\n return name.substring(0, Math.floor(name.length * 0.6));\n },\n // 获取文件名后半部分(用于中间省略效果)\n getFileNameEnd(name) {\n if (!name) return '';\n // 如果文件名较短,返回空\n if (name.length <= 30) return '';\n // 保留末尾部分(包含扩展名)\n const dotIndex = name.lastIndexOf('.');\n if (dotIndex > 0) {\n // 有扩展名的情况:返回最后几个字符 + 扩展名\n const ext = name.substring(dotIndex);\n const baseName = name.substring(0, dotIndex);\n const keepLength = Math.min(8, Math.floor(baseName.length * 0.2));\n return '…' + baseName.substring(baseName.length - keepLength) + ext;\n }\n // 无扩展名的情况\n const keepLength = Math.min(10, Math.floor(name.length * 0.3));\n return '…' + name.substring(name.length - keepLength);\n },\n // 进入文件夹\n enterFolder(folderPath) {\n // 确保路径末尾有 '/'\n this.currentPath = folderPath + (folderPath.endsWith('/') ? '' : '/');\n // 刷新文件列表,到指定currentPath下\n this.refreshFileList();\n },\n // 导航到指定文件夹\n navigateToFolder(path) {\n // 确保空路径时不添加 '/'\n this.currentPath = path ? path + (path.endsWith('/') ? '' : '/') : '';\n // 刷新文件列表,到指定currentPath下\n this.refreshFileList();\n },\n // 获取文件列表\n async fetchFileList() {\n this.loading = true;\n try {\n // 从本地存储获取数据\n const data = fileManager.getLocalFileList();\n\n // 解析返回的数据\n const folders = new Set(data.directories || []);\n const files = data.files || [];\n\n // 处理文件夹数据\n const folderItems = Array.from(folders).map(folder => ({\n name: folder,\n isFolder: true,\n selected: false,\n metadata: {\n FileName: folder.split('/').pop()\n }\n }));\n\n // 处理文件数据\n const fileItems = files.map(file => ({\n name: file.name,\n isFolder: false,\n selected: false,\n metadata: file.metadata\n }));\n\n // 更新表格数据\n this.tableData = [...folderItems, ...fileItems];\n\n // 更新统计信息\n this.updateStats(data.totalCount, true);\n\n // 更新直接文件和文件夹数量\n this.directFileCount = data.directFileCount || 0;\n this.directFolderCount = data.directFolderCount || 0;\n } catch (error) {\n console.error('Error fetching file list:', error);\n this.$message.error('获取文件列表失败');\n } finally {\n this.loading = false;\n }\n },\n // 刷新文件列表\n async refreshFileList() {\n this.refreshLoading = true;\n this.loading = true;\n try {\n // 传递标签参数到后端\n const success = await fileManager.refreshFileList(this.currentPath, this.searchKeywords, this.searchIncludeTags, this.searchExcludeTags);\n if (success) {\n await this.fetchFileList();\n } else {\n throw new Error('Refresh failed');\n }\n } catch (error) {\n console.error('Error refreshing file list:', error);\n this.$message.error('刷新失败,请重试');\n } finally {\n this.refreshLoading = false;\n this.loading = false;\n }\n },\n // 刷新本地文件列表\n async refreshLocalFileList() {\n this.refreshLoading = true;\n this.loading = true;\n try {\n await this.fetchFileList();\n } catch (error) {\n console.error('Error refreshing local file list:', error);\n this.$message.error('刷新失败,请重试');\n } finally {\n this.refreshLoading = false;\n this.loading = false;\n }\n },\n // Tag management methods\n handleTagManagement(fileId) {\n this.currentTagFile = fileId;\n this.showTagDialog = true;\n },\n handleBatchTagManagement() {\n if (this.selectedFiles.length === 0) {\n this.$message.warning('请先选择文件');\n return;\n }\n this.showBatchTagDialog = true;\n },\n async handleTagsUpdated(tags) {\n // 更新本地文件数据中的标签\n const fileIndex = this.tableData.findIndex(file => file.name === this.currentTagFile);\n if (fileIndex !== -1) {\n // 更新 tableData 中的标签\n if (!this.tableData[fileIndex].metadata) {\n this.tableData[fileIndex].metadata = {};\n }\n this.tableData[fileIndex].metadata.Tags = tags;\n\n // 如果详情对话框正在显示这个文件,也更新详情数据\n if (this.showdetailDialog && this.detailFile?.name === this.currentTagFile) {\n if (!this.detailFile.metadata) {\n this.detailFile.metadata = {};\n }\n this.detailFile.metadata.Tags = tags;\n }\n }\n },\n async handleBatchTagsUpdated() {\n // 刷新文件列表以显示更新后的标签\n await this.refreshLocalFileList();\n },\n // 生成单个文件链接\n generateFileLink(key, metadata) {\n const isExternal = metadata?.Channel === 'External';\n const baseUrl = isExternal ? metadata?.ExternalLink : `${this.rootUrl}${key}`;\n const fileName = metadata?.FileName || key;\n switch (this.defaultUrlFormat) {\n case 'originUrl':\n return baseUrl;\n case 'mdUrl':\n return `![${fileName}](${baseUrl})`;\n case 'htmlUrl':\n return `\"${fileName}\"`;\n case 'bbUrl':\n return `[img]${baseUrl}[/img]`;\n case 'tgId':\n return metadata?.TgFileId || '';\n case 's3Location':\n return metadata?.S3Location || '';\n default:\n return baseUrl;\n }\n },\n // 复制文件夹中所有文件的链接\n async handleFolderCopy(folderName) {\n // 显示加载状态\n const loading = this.$loading({\n lock: true,\n text: '正在获取文件列表...'\n });\n try {\n // 调用 list API 递归获取文件夹内所有文件\n const response = await fetchWithAuth(`/api/manage/list?dir=${encodeURIComponent(folderName)}&recursive=true&count=-1`, {\n method: 'GET'\n });\n const data = await response.json();\n loading.close();\n if (!data.files || data.files.length === 0) {\n this.$message.warning('文件夹为空,没有可复制的链接');\n return;\n }\n\n // 根据当前链接格式生成所有文件链接\n const links = data.files.map(file => {\n return this.generateFileLink(file.name, file.metadata);\n }).filter(link => link); // 过滤掉空链接\n\n if (links.length === 0) {\n this.$message.warning('没有可复制的链接');\n return;\n }\n\n // 复制到剪贴板\n const text = links.join('\\n');\n if (navigator.clipboard) {\n await navigator.clipboard.writeText(text);\n this.$message.success(`已复制 ${links.length} 个文件链接`);\n } else {\n this.copyToClipboardFallback(text);\n this.$message.success(`已复制 ${links.length} 个文件链接`);\n }\n } catch (error) {\n loading.close();\n console.error('复制文件夹链接失败:', error);\n this.$message.error('复制文件夹链接失败,请重试');\n }\n }\n },\n mounted() {\n this.loading = true;\n fetchWithAuth(\"/api/manage/check\", {\n method: 'GET'\n }).then(response => response.text()).then(result => {\n if (result == \"true\") {\n this.showLogoutButton = true;\n return true;\n } else if (result == \"Not using basic auth.\") {\n return true;\n } else {\n throw new Error('Unauthorized');\n }\n }).then(() => {\n // 首次加载时刷新文件列表\n return this.refreshFileList();\n }).catch(err => {\n if (err.message !== 'Unauthorized') {\n this.$message.error('同步数据时出错,请检查网络连接');\n }\n }).finally(() => {\n this.loading = false;\n });\n\n // 读取自定义链接设置项\n this.customUrlPrefix = this.adminUrlSettings.customUrlPrefix;\n this.useCustomUrl = this.adminUrlSettings.useCustomUrl;\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./AdminDashBoard.vue?vue&type=template&id=6028d7b0&scoped=true\"\nimport script from \"./AdminDashBoard.vue?vue&type=script&lang=js\"\nexport * from \"./AdminDashBoard.vue?vue&type=script&lang=js\"\n\nimport \"./AdminDashBoard.vue?vue&type=style&index=0&id=6028d7b0&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-6028d7b0\"]])\n\nexport default __exports__","/*!\n\nJSZip v3.10.1 - A JavaScript class for generating and reading zip files\n\n\n(c) 2009-2016 Stuart Knightley \nDual licenced under the MIT license or GPLv3. See https://raw.github.com/Stuk/jszip/main/LICENSE.markdown.\n\nJSZip uses the library pako released under the MIT license :\nhttps://github.com/nodeca/pako/blob/main/LICENSE\n*/\n\n!function(e){if(\"object\"==typeof exports&&\"undefined\"!=typeof module)module.exports=e();else if(\"function\"==typeof define&&define.amd)define([],e);else{(\"undefined\"!=typeof window?window:\"undefined\"!=typeof global?global:\"undefined\"!=typeof self?self:this).JSZip=e()}}(function(){return function s(a,o,h){function u(r,e){if(!o[r]){if(!a[r]){var t=\"function\"==typeof require&&require;if(!e&&t)return t(r,!0);if(l)return l(r,!0);var n=new Error(\"Cannot find module '\"+r+\"'\");throw n.code=\"MODULE_NOT_FOUND\",n}var i=o[r]={exports:{}};a[r][0].call(i.exports,function(e){var t=a[r][1][e];return u(t||e)},i,i.exports,s,a,o,h)}return o[r].exports}for(var l=\"function\"==typeof require&&require,e=0;e>2,s=(3&t)<<4|r>>4,a=1>6:64,o=2>4,r=(15&i)<<4|(s=p.indexOf(e.charAt(o++)))>>2,n=(3&s)<<6|(a=p.indexOf(e.charAt(o++))),l[h++]=t,64!==s&&(l[h++]=r),64!==a&&(l[h++]=n);return l}},{\"./support\":30,\"./utils\":32}],2:[function(e,t,r){\"use strict\";var n=e(\"./external\"),i=e(\"./stream/DataWorker\"),s=e(\"./stream/Crc32Probe\"),a=e(\"./stream/DataLengthProbe\");function o(e,t,r,n,i){this.compressedSize=e,this.uncompressedSize=t,this.crc32=r,this.compression=n,this.compressedContent=i}o.prototype={getContentWorker:function(){var e=new i(n.Promise.resolve(this.compressedContent)).pipe(this.compression.uncompressWorker()).pipe(new a(\"data_length\")),t=this;return e.on(\"end\",function(){if(this.streamInfo.data_length!==t.uncompressedSize)throw new Error(\"Bug : uncompressed data size mismatch\")}),e},getCompressedWorker:function(){return new i(n.Promise.resolve(this.compressedContent)).withStreamInfo(\"compressedSize\",this.compressedSize).withStreamInfo(\"uncompressedSize\",this.uncompressedSize).withStreamInfo(\"crc32\",this.crc32).withStreamInfo(\"compression\",this.compression)}},o.createWorkerFrom=function(e,t,r){return e.pipe(new s).pipe(new a(\"uncompressedSize\")).pipe(t.compressWorker(r)).pipe(new a(\"compressedSize\")).withStreamInfo(\"compression\",t)},t.exports=o},{\"./external\":6,\"./stream/Crc32Probe\":25,\"./stream/DataLengthProbe\":26,\"./stream/DataWorker\":27}],3:[function(e,t,r){\"use strict\";var n=e(\"./stream/GenericWorker\");r.STORE={magic:\"\\0\\0\",compressWorker:function(){return new n(\"STORE compression\")},uncompressWorker:function(){return new n(\"STORE decompression\")}},r.DEFLATE=e(\"./flate\")},{\"./flate\":7,\"./stream/GenericWorker\":28}],4:[function(e,t,r){\"use strict\";var n=e(\"./utils\");var o=function(){for(var e,t=[],r=0;r<256;r++){e=r;for(var n=0;n<8;n++)e=1&e?3988292384^e>>>1:e>>>1;t[r]=e}return t}();t.exports=function(e,t){return void 0!==e&&e.length?\"string\"!==n.getTypeOf(e)?function(e,t,r,n){var i=o,s=n+r;e^=-1;for(var a=n;a>>8^i[255&(e^t[a])];return-1^e}(0|t,e,e.length,0):function(e,t,r,n){var i=o,s=n+r;e^=-1;for(var a=n;a>>8^i[255&(e^t.charCodeAt(a))];return-1^e}(0|t,e,e.length,0):0}},{\"./utils\":32}],5:[function(e,t,r){\"use strict\";r.base64=!1,r.binary=!1,r.dir=!1,r.createFolders=!0,r.date=null,r.compression=null,r.compressionOptions=null,r.comment=null,r.unixPermissions=null,r.dosPermissions=null},{}],6:[function(e,t,r){\"use strict\";var n=null;n=\"undefined\"!=typeof Promise?Promise:e(\"lie\"),t.exports={Promise:n}},{lie:37}],7:[function(e,t,r){\"use strict\";var n=\"undefined\"!=typeof Uint8Array&&\"undefined\"!=typeof Uint16Array&&\"undefined\"!=typeof Uint32Array,i=e(\"pako\"),s=e(\"./utils\"),a=e(\"./stream/GenericWorker\"),o=n?\"uint8array\":\"array\";function h(e,t){a.call(this,\"FlateWorker/\"+e),this._pako=null,this._pakoAction=e,this._pakoOptions=t,this.meta={}}r.magic=\"\\b\\0\",s.inherits(h,a),h.prototype.processChunk=function(e){this.meta=e.meta,null===this._pako&&this._createPako(),this._pako.push(s.transformTo(o,e.data),!1)},h.prototype.flush=function(){a.prototype.flush.call(this),null===this._pako&&this._createPako(),this._pako.push([],!0)},h.prototype.cleanUp=function(){a.prototype.cleanUp.call(this),this._pako=null},h.prototype._createPako=function(){this._pako=new i[this._pakoAction]({raw:!0,level:this._pakoOptions.level||-1});var t=this;this._pako.onData=function(e){t.push({data:e,meta:t.meta})}},r.compressWorker=function(e){return new h(\"Deflate\",e)},r.uncompressWorker=function(){return new h(\"Inflate\",{})}},{\"./stream/GenericWorker\":28,\"./utils\":32,pako:38}],8:[function(e,t,r){\"use strict\";function A(e,t){var r,n=\"\";for(r=0;r>>=8;return n}function n(e,t,r,n,i,s){var a,o,h=e.file,u=e.compression,l=s!==O.utf8encode,f=I.transformTo(\"string\",s(h.name)),c=I.transformTo(\"string\",O.utf8encode(h.name)),d=h.comment,p=I.transformTo(\"string\",s(d)),m=I.transformTo(\"string\",O.utf8encode(d)),_=c.length!==h.name.length,g=m.length!==d.length,b=\"\",v=\"\",y=\"\",w=h.dir,k=h.date,x={crc32:0,compressedSize:0,uncompressedSize:0};t&&!r||(x.crc32=e.crc32,x.compressedSize=e.compressedSize,x.uncompressedSize=e.uncompressedSize);var S=0;t&&(S|=8),l||!_&&!g||(S|=2048);var z=0,C=0;w&&(z|=16),\"UNIX\"===i?(C=798,z|=function(e,t){var r=e;return e||(r=t?16893:33204),(65535&r)<<16}(h.unixPermissions,w)):(C=20,z|=function(e){return 63&(e||0)}(h.dosPermissions)),a=k.getUTCHours(),a<<=6,a|=k.getUTCMinutes(),a<<=5,a|=k.getUTCSeconds()/2,o=k.getUTCFullYear()-1980,o<<=4,o|=k.getUTCMonth()+1,o<<=5,o|=k.getUTCDate(),_&&(v=A(1,1)+A(B(f),4)+c,b+=\"up\"+A(v.length,2)+v),g&&(y=A(1,1)+A(B(p),4)+m,b+=\"uc\"+A(y.length,2)+y);var E=\"\";return E+=\"\\n\\0\",E+=A(S,2),E+=u.magic,E+=A(a,2),E+=A(o,2),E+=A(x.crc32,4),E+=A(x.compressedSize,4),E+=A(x.uncompressedSize,4),E+=A(f.length,2),E+=A(b.length,2),{fileRecord:R.LOCAL_FILE_HEADER+E+f+b,dirRecord:R.CENTRAL_FILE_HEADER+A(C,2)+E+A(p.length,2)+\"\\0\\0\\0\\0\"+A(z,4)+A(n,4)+f+b+p}}var I=e(\"../utils\"),i=e(\"../stream/GenericWorker\"),O=e(\"../utf8\"),B=e(\"../crc32\"),R=e(\"../signature\");function s(e,t,r,n){i.call(this,\"ZipFileWorker\"),this.bytesWritten=0,this.zipComment=t,this.zipPlatform=r,this.encodeFileName=n,this.streamFiles=e,this.accumulate=!1,this.contentBuffer=[],this.dirRecords=[],this.currentSourceOffset=0,this.entriesCount=0,this.currentFile=null,this._sources=[]}I.inherits(s,i),s.prototype.push=function(e){var t=e.meta.percent||0,r=this.entriesCount,n=this._sources.length;this.accumulate?this.contentBuffer.push(e):(this.bytesWritten+=e.data.length,i.prototype.push.call(this,{data:e.data,meta:{currentFile:this.currentFile,percent:r?(t+100*(r-n-1))/r:100}}))},s.prototype.openedSource=function(e){this.currentSourceOffset=this.bytesWritten,this.currentFile=e.file.name;var t=this.streamFiles&&!e.file.dir;if(t){var r=n(e,t,!1,this.currentSourceOffset,this.zipPlatform,this.encodeFileName);this.push({data:r.fileRecord,meta:{percent:0}})}else this.accumulate=!0},s.prototype.closedSource=function(e){this.accumulate=!1;var t=this.streamFiles&&!e.file.dir,r=n(e,t,!0,this.currentSourceOffset,this.zipPlatform,this.encodeFileName);if(this.dirRecords.push(r.dirRecord),t)this.push({data:function(e){return R.DATA_DESCRIPTOR+A(e.crc32,4)+A(e.compressedSize,4)+A(e.uncompressedSize,4)}(e),meta:{percent:100}});else for(this.push({data:r.fileRecord,meta:{percent:0}});this.contentBuffer.length;)this.push(this.contentBuffer.shift());this.currentFile=null},s.prototype.flush=function(){for(var e=this.bytesWritten,t=0;t=this.index;t--)r=(r<<8)+this.byteAt(t);return this.index+=e,r},readString:function(e){return n.transformTo(\"string\",this.readData(e))},readData:function(){},lastIndexOfSignature:function(){},readAndCheckSignature:function(){},readDate:function(){var e=this.readInt(4);return new Date(Date.UTC(1980+(e>>25&127),(e>>21&15)-1,e>>16&31,e>>11&31,e>>5&63,(31&e)<<1))}},t.exports=i},{\"../utils\":32}],19:[function(e,t,r){\"use strict\";var n=e(\"./Uint8ArrayReader\");function i(e){n.call(this,e)}e(\"../utils\").inherits(i,n),i.prototype.readData=function(e){this.checkOffset(e);var t=this.data.slice(this.zero+this.index,this.zero+this.index+e);return this.index+=e,t},t.exports=i},{\"../utils\":32,\"./Uint8ArrayReader\":21}],20:[function(e,t,r){\"use strict\";var n=e(\"./DataReader\");function i(e){n.call(this,e)}e(\"../utils\").inherits(i,n),i.prototype.byteAt=function(e){return this.data.charCodeAt(this.zero+e)},i.prototype.lastIndexOfSignature=function(e){return this.data.lastIndexOf(e)-this.zero},i.prototype.readAndCheckSignature=function(e){return e===this.readData(4)},i.prototype.readData=function(e){this.checkOffset(e);var t=this.data.slice(this.zero+this.index,this.zero+this.index+e);return this.index+=e,t},t.exports=i},{\"../utils\":32,\"./DataReader\":18}],21:[function(e,t,r){\"use strict\";var n=e(\"./ArrayReader\");function i(e){n.call(this,e)}e(\"../utils\").inherits(i,n),i.prototype.readData=function(e){if(this.checkOffset(e),0===e)return new Uint8Array(0);var t=this.data.subarray(this.zero+this.index,this.zero+this.index+e);return this.index+=e,t},t.exports=i},{\"../utils\":32,\"./ArrayReader\":17}],22:[function(e,t,r){\"use strict\";var n=e(\"../utils\"),i=e(\"../support\"),s=e(\"./ArrayReader\"),a=e(\"./StringReader\"),o=e(\"./NodeBufferReader\"),h=e(\"./Uint8ArrayReader\");t.exports=function(e){var t=n.getTypeOf(e);return n.checkSupport(t),\"string\"!==t||i.uint8array?\"nodebuffer\"===t?new o(e):i.uint8array?new h(n.transformTo(\"uint8array\",e)):new s(n.transformTo(\"array\",e)):new a(e)}},{\"../support\":30,\"../utils\":32,\"./ArrayReader\":17,\"./NodeBufferReader\":19,\"./StringReader\":20,\"./Uint8ArrayReader\":21}],23:[function(e,t,r){\"use strict\";r.LOCAL_FILE_HEADER=\"PK\u0003\u0004\",r.CENTRAL_FILE_HEADER=\"PK\u0001\u0002\",r.CENTRAL_DIRECTORY_END=\"PK\u0005\u0006\",r.ZIP64_CENTRAL_DIRECTORY_LOCATOR=\"PK\u0006\u0007\",r.ZIP64_CENTRAL_DIRECTORY_END=\"PK\u0006\u0006\",r.DATA_DESCRIPTOR=\"PK\u0007\\b\"},{}],24:[function(e,t,r){\"use strict\";var n=e(\"./GenericWorker\"),i=e(\"../utils\");function s(e){n.call(this,\"ConvertWorker to \"+e),this.destType=e}i.inherits(s,n),s.prototype.processChunk=function(e){this.push({data:i.transformTo(this.destType,e.data),meta:e.meta})},t.exports=s},{\"../utils\":32,\"./GenericWorker\":28}],25:[function(e,t,r){\"use strict\";var n=e(\"./GenericWorker\"),i=e(\"../crc32\");function s(){n.call(this,\"Crc32Probe\"),this.withStreamInfo(\"crc32\",0)}e(\"../utils\").inherits(s,n),s.prototype.processChunk=function(e){this.streamInfo.crc32=i(e.data,this.streamInfo.crc32||0),this.push(e)},t.exports=s},{\"../crc32\":4,\"../utils\":32,\"./GenericWorker\":28}],26:[function(e,t,r){\"use strict\";var n=e(\"../utils\"),i=e(\"./GenericWorker\");function s(e){i.call(this,\"DataLengthProbe for \"+e),this.propName=e,this.withStreamInfo(e,0)}n.inherits(s,i),s.prototype.processChunk=function(e){if(e){var t=this.streamInfo[this.propName]||0;this.streamInfo[this.propName]=t+e.data.length}i.prototype.processChunk.call(this,e)},t.exports=s},{\"../utils\":32,\"./GenericWorker\":28}],27:[function(e,t,r){\"use strict\";var n=e(\"../utils\"),i=e(\"./GenericWorker\");function s(e){i.call(this,\"DataWorker\");var t=this;this.dataIsReady=!1,this.index=0,this.max=0,this.data=null,this.type=\"\",this._tickScheduled=!1,e.then(function(e){t.dataIsReady=!0,t.data=e,t.max=e&&e.length||0,t.type=n.getTypeOf(e),t.isPaused||t._tickAndRepeat()},function(e){t.error(e)})}n.inherits(s,i),s.prototype.cleanUp=function(){i.prototype.cleanUp.call(this),this.data=null},s.prototype.resume=function(){return!!i.prototype.resume.call(this)&&(!this._tickScheduled&&this.dataIsReady&&(this._tickScheduled=!0,n.delay(this._tickAndRepeat,[],this)),!0)},s.prototype._tickAndRepeat=function(){this._tickScheduled=!1,this.isPaused||this.isFinished||(this._tick(),this.isFinished||(n.delay(this._tickAndRepeat,[],this),this._tickScheduled=!0))},s.prototype._tick=function(){if(this.isPaused||this.isFinished)return!1;var e=null,t=Math.min(this.max,this.index+16384);if(this.index>=this.max)return this.end();switch(this.type){case\"string\":e=this.data.substring(this.index,t);break;case\"uint8array\":e=this.data.subarray(this.index,t);break;case\"array\":case\"nodebuffer\":e=this.data.slice(this.index,t)}return this.index=t,this.push({data:e,meta:{percent:this.max?this.index/this.max*100:0}})},t.exports=s},{\"../utils\":32,\"./GenericWorker\":28}],28:[function(e,t,r){\"use strict\";function n(e){this.name=e||\"default\",this.streamInfo={},this.generatedError=null,this.extraStreamInfo={},this.isPaused=!0,this.isFinished=!1,this.isLocked=!1,this._listeners={data:[],end:[],error:[]},this.previous=null}n.prototype={push:function(e){this.emit(\"data\",e)},end:function(){if(this.isFinished)return!1;this.flush();try{this.emit(\"end\"),this.cleanUp(),this.isFinished=!0}catch(e){this.emit(\"error\",e)}return!0},error:function(e){return!this.isFinished&&(this.isPaused?this.generatedError=e:(this.isFinished=!0,this.emit(\"error\",e),this.previous&&this.previous.error(e),this.cleanUp()),!0)},on:function(e,t){return this._listeners[e].push(t),this},cleanUp:function(){this.streamInfo=this.generatedError=this.extraStreamInfo=null,this._listeners=[]},emit:function(e,t){if(this._listeners[e])for(var r=0;r \"+e:e}},t.exports=n},{}],29:[function(e,t,r){\"use strict\";var h=e(\"../utils\"),i=e(\"./ConvertWorker\"),s=e(\"./GenericWorker\"),u=e(\"../base64\"),n=e(\"../support\"),a=e(\"../external\"),o=null;if(n.nodestream)try{o=e(\"../nodejs/NodejsStreamOutputAdapter\")}catch(e){}function l(e,o){return new a.Promise(function(t,r){var n=[],i=e._internalType,s=e._outputType,a=e._mimeType;e.on(\"data\",function(e,t){n.push(e),o&&o(t)}).on(\"error\",function(e){n=[],r(e)}).on(\"end\",function(){try{var e=function(e,t,r){switch(e){case\"blob\":return h.newBlob(h.transformTo(\"arraybuffer\",t),r);case\"base64\":return u.encode(t);default:return h.transformTo(e,t)}}(s,function(e,t){var r,n=0,i=null,s=0;for(r=0;r>>6:(r<65536?t[s++]=224|r>>>12:(t[s++]=240|r>>>18,t[s++]=128|r>>>12&63),t[s++]=128|r>>>6&63),t[s++]=128|63&r);return t}(e)},s.utf8decode=function(e){return h.nodebuffer?o.transformTo(\"nodebuffer\",e).toString(\"utf-8\"):function(e){var t,r,n,i,s=e.length,a=new Array(2*s);for(t=r=0;t>10&1023,a[r++]=56320|1023&n)}return a.length!==r&&(a.subarray?a=a.subarray(0,r):a.length=r),o.applyFromCharCode(a)}(e=o.transformTo(h.uint8array?\"uint8array\":\"array\",e))},o.inherits(a,n),a.prototype.processChunk=function(e){var t=o.transformTo(h.uint8array?\"uint8array\":\"array\",e.data);if(this.leftOver&&this.leftOver.length){if(h.uint8array){var r=t;(t=new Uint8Array(r.length+this.leftOver.length)).set(this.leftOver,0),t.set(r,this.leftOver.length)}else t=this.leftOver.concat(t);this.leftOver=null}var n=function(e,t){var r;for((t=t||e.length)>e.length&&(t=e.length),r=t-1;0<=r&&128==(192&e[r]);)r--;return r<0?t:0===r?t:r+u[e[r]]>t?r:t}(t),i=t;n!==t.length&&(h.uint8array?(i=t.subarray(0,n),this.leftOver=t.subarray(n,t.length)):(i=t.slice(0,n),this.leftOver=t.slice(n,t.length))),this.push({data:s.utf8decode(i),meta:e.meta})},a.prototype.flush=function(){this.leftOver&&this.leftOver.length&&(this.push({data:s.utf8decode(this.leftOver),meta:{}}),this.leftOver=null)},s.Utf8DecodeWorker=a,o.inherits(l,n),l.prototype.processChunk=function(e){this.push({data:s.utf8encode(e.data),meta:e.meta})},s.Utf8EncodeWorker=l},{\"./nodejsUtils\":14,\"./stream/GenericWorker\":28,\"./support\":30,\"./utils\":32}],32:[function(e,t,a){\"use strict\";var o=e(\"./support\"),h=e(\"./base64\"),r=e(\"./nodejsUtils\"),u=e(\"./external\");function n(e){return e}function l(e,t){for(var r=0;r>8;this.dir=!!(16&this.externalFileAttributes),0==e&&(this.dosPermissions=63&this.externalFileAttributes),3==e&&(this.unixPermissions=this.externalFileAttributes>>16&65535),this.dir||\"/\"!==this.fileNameStr.slice(-1)||(this.dir=!0)},parseZIP64ExtraField:function(){if(this.extraFields[1]){var e=n(this.extraFields[1].value);this.uncompressedSize===s.MAX_VALUE_32BITS&&(this.uncompressedSize=e.readInt(8)),this.compressedSize===s.MAX_VALUE_32BITS&&(this.compressedSize=e.readInt(8)),this.localHeaderOffset===s.MAX_VALUE_32BITS&&(this.localHeaderOffset=e.readInt(8)),this.diskNumberStart===s.MAX_VALUE_32BITS&&(this.diskNumberStart=e.readInt(4))}},readExtraFields:function(e){var t,r,n,i=e.index+this.extraFieldsLength;for(this.extraFields||(this.extraFields={});e.index+4>>6:(r<65536?t[s++]=224|r>>>12:(t[s++]=240|r>>>18,t[s++]=128|r>>>12&63),t[s++]=128|r>>>6&63),t[s++]=128|63&r);return t},r.buf2binstring=function(e){return l(e,e.length)},r.binstring2buf=function(e){for(var t=new h.Buf8(e.length),r=0,n=t.length;r>10&1023,o[n++]=56320|1023&i)}return l(o,n)},r.utf8border=function(e,t){var r;for((t=t||e.length)>e.length&&(t=e.length),r=t-1;0<=r&&128==(192&e[r]);)r--;return r<0?t:0===r?t:r+u[e[r]]>t?r:t}},{\"./common\":41}],43:[function(e,t,r){\"use strict\";t.exports=function(e,t,r,n){for(var i=65535&e|0,s=e>>>16&65535|0,a=0;0!==r;){for(r-=a=2e3>>1:e>>>1;t[r]=e}return t}();t.exports=function(e,t,r,n){var i=o,s=n+r;e^=-1;for(var a=n;a>>8^i[255&(e^t[a])];return-1^e}},{}],46:[function(e,t,r){\"use strict\";var h,c=e(\"../utils/common\"),u=e(\"./trees\"),d=e(\"./adler32\"),p=e(\"./crc32\"),n=e(\"./messages\"),l=0,f=4,m=0,_=-2,g=-1,b=4,i=2,v=8,y=9,s=286,a=30,o=19,w=2*s+1,k=15,x=3,S=258,z=S+x+1,C=42,E=113,A=1,I=2,O=3,B=4;function R(e,t){return e.msg=n[t],t}function T(e){return(e<<1)-(4e.avail_out&&(r=e.avail_out),0!==r&&(c.arraySet(e.output,t.pending_buf,t.pending_out,r,e.next_out),e.next_out+=r,t.pending_out+=r,e.total_out+=r,e.avail_out-=r,t.pending-=r,0===t.pending&&(t.pending_out=0))}function N(e,t){u._tr_flush_block(e,0<=e.block_start?e.block_start:-1,e.strstart-e.block_start,t),e.block_start=e.strstart,F(e.strm)}function U(e,t){e.pending_buf[e.pending++]=t}function P(e,t){e.pending_buf[e.pending++]=t>>>8&255,e.pending_buf[e.pending++]=255&t}function L(e,t){var r,n,i=e.max_chain_length,s=e.strstart,a=e.prev_length,o=e.nice_match,h=e.strstart>e.w_size-z?e.strstart-(e.w_size-z):0,u=e.window,l=e.w_mask,f=e.prev,c=e.strstart+S,d=u[s+a-1],p=u[s+a];e.prev_length>=e.good_match&&(i>>=2),o>e.lookahead&&(o=e.lookahead);do{if(u[(r=t)+a]===p&&u[r+a-1]===d&&u[r]===u[s]&&u[++r]===u[s+1]){s+=2,r++;do{}while(u[++s]===u[++r]&&u[++s]===u[++r]&&u[++s]===u[++r]&&u[++s]===u[++r]&&u[++s]===u[++r]&&u[++s]===u[++r]&&u[++s]===u[++r]&&u[++s]===u[++r]&&sh&&0!=--i);return a<=e.lookahead?a:e.lookahead}function j(e){var t,r,n,i,s,a,o,h,u,l,f=e.w_size;do{if(i=e.window_size-e.lookahead-e.strstart,e.strstart>=f+(f-z)){for(c.arraySet(e.window,e.window,f,f,0),e.match_start-=f,e.strstart-=f,e.block_start-=f,t=r=e.hash_size;n=e.head[--t],e.head[t]=f<=n?n-f:0,--r;);for(t=r=f;n=e.prev[--t],e.prev[t]=f<=n?n-f:0,--r;);i+=f}if(0===e.strm.avail_in)break;if(a=e.strm,o=e.window,h=e.strstart+e.lookahead,u=i,l=void 0,l=a.avail_in,u=x)for(s=e.strstart-e.insert,e.ins_h=e.window[s],e.ins_h=(e.ins_h<=x&&(e.ins_h=(e.ins_h<=x)if(n=u._tr_tally(e,e.strstart-e.match_start,e.match_length-x),e.lookahead-=e.match_length,e.match_length<=e.max_lazy_match&&e.lookahead>=x){for(e.match_length--;e.strstart++,e.ins_h=(e.ins_h<=x&&(e.ins_h=(e.ins_h<=x&&e.match_length<=e.prev_length){for(i=e.strstart+e.lookahead-x,n=u._tr_tally(e,e.strstart-1-e.prev_match,e.prev_length-x),e.lookahead-=e.prev_length-1,e.prev_length-=2;++e.strstart<=i&&(e.ins_h=(e.ins_h<e.pending_buf_size-5&&(r=e.pending_buf_size-5);;){if(e.lookahead<=1){if(j(e),0===e.lookahead&&t===l)return A;if(0===e.lookahead)break}e.strstart+=e.lookahead,e.lookahead=0;var n=e.block_start+r;if((0===e.strstart||e.strstart>=n)&&(e.lookahead=e.strstart-n,e.strstart=n,N(e,!1),0===e.strm.avail_out))return A;if(e.strstart-e.block_start>=e.w_size-z&&(N(e,!1),0===e.strm.avail_out))return A}return e.insert=0,t===f?(N(e,!0),0===e.strm.avail_out?O:B):(e.strstart>e.block_start&&(N(e,!1),e.strm.avail_out),A)}),new M(4,4,8,4,Z),new M(4,5,16,8,Z),new M(4,6,32,32,Z),new M(4,4,16,16,W),new M(8,16,32,32,W),new M(8,16,128,128,W),new M(8,32,128,256,W),new M(32,128,258,1024,W),new M(32,258,258,4096,W)],r.deflateInit=function(e,t){return Y(e,t,v,15,8,0)},r.deflateInit2=Y,r.deflateReset=K,r.deflateResetKeep=G,r.deflateSetHeader=function(e,t){return e&&e.state?2!==e.state.wrap?_:(e.state.gzhead=t,m):_},r.deflate=function(e,t){var r,n,i,s;if(!e||!e.state||5>8&255),U(n,n.gzhead.time>>16&255),U(n,n.gzhead.time>>24&255),U(n,9===n.level?2:2<=n.strategy||n.level<2?4:0),U(n,255&n.gzhead.os),n.gzhead.extra&&n.gzhead.extra.length&&(U(n,255&n.gzhead.extra.length),U(n,n.gzhead.extra.length>>8&255)),n.gzhead.hcrc&&(e.adler=p(e.adler,n.pending_buf,n.pending,0)),n.gzindex=0,n.status=69):(U(n,0),U(n,0),U(n,0),U(n,0),U(n,0),U(n,9===n.level?2:2<=n.strategy||n.level<2?4:0),U(n,3),n.status=E);else{var a=v+(n.w_bits-8<<4)<<8;a|=(2<=n.strategy||n.level<2?0:n.level<6?1:6===n.level?2:3)<<6,0!==n.strstart&&(a|=32),a+=31-a%31,n.status=E,P(n,a),0!==n.strstart&&(P(n,e.adler>>>16),P(n,65535&e.adler)),e.adler=1}if(69===n.status)if(n.gzhead.extra){for(i=n.pending;n.gzindex<(65535&n.gzhead.extra.length)&&(n.pending!==n.pending_buf_size||(n.gzhead.hcrc&&n.pending>i&&(e.adler=p(e.adler,n.pending_buf,n.pending-i,i)),F(e),i=n.pending,n.pending!==n.pending_buf_size));)U(n,255&n.gzhead.extra[n.gzindex]),n.gzindex++;n.gzhead.hcrc&&n.pending>i&&(e.adler=p(e.adler,n.pending_buf,n.pending-i,i)),n.gzindex===n.gzhead.extra.length&&(n.gzindex=0,n.status=73)}else n.status=73;if(73===n.status)if(n.gzhead.name){i=n.pending;do{if(n.pending===n.pending_buf_size&&(n.gzhead.hcrc&&n.pending>i&&(e.adler=p(e.adler,n.pending_buf,n.pending-i,i)),F(e),i=n.pending,n.pending===n.pending_buf_size)){s=1;break}s=n.gzindexi&&(e.adler=p(e.adler,n.pending_buf,n.pending-i,i)),0===s&&(n.gzindex=0,n.status=91)}else n.status=91;if(91===n.status)if(n.gzhead.comment){i=n.pending;do{if(n.pending===n.pending_buf_size&&(n.gzhead.hcrc&&n.pending>i&&(e.adler=p(e.adler,n.pending_buf,n.pending-i,i)),F(e),i=n.pending,n.pending===n.pending_buf_size)){s=1;break}s=n.gzindexi&&(e.adler=p(e.adler,n.pending_buf,n.pending-i,i)),0===s&&(n.status=103)}else n.status=103;if(103===n.status&&(n.gzhead.hcrc?(n.pending+2>n.pending_buf_size&&F(e),n.pending+2<=n.pending_buf_size&&(U(n,255&e.adler),U(n,e.adler>>8&255),e.adler=0,n.status=E)):n.status=E),0!==n.pending){if(F(e),0===e.avail_out)return n.last_flush=-1,m}else if(0===e.avail_in&&T(t)<=T(r)&&t!==f)return R(e,-5);if(666===n.status&&0!==e.avail_in)return R(e,-5);if(0!==e.avail_in||0!==n.lookahead||t!==l&&666!==n.status){var o=2===n.strategy?function(e,t){for(var r;;){if(0===e.lookahead&&(j(e),0===e.lookahead)){if(t===l)return A;break}if(e.match_length=0,r=u._tr_tally(e,0,e.window[e.strstart]),e.lookahead--,e.strstart++,r&&(N(e,!1),0===e.strm.avail_out))return A}return e.insert=0,t===f?(N(e,!0),0===e.strm.avail_out?O:B):e.last_lit&&(N(e,!1),0===e.strm.avail_out)?A:I}(n,t):3===n.strategy?function(e,t){for(var r,n,i,s,a=e.window;;){if(e.lookahead<=S){if(j(e),e.lookahead<=S&&t===l)return A;if(0===e.lookahead)break}if(e.match_length=0,e.lookahead>=x&&0e.lookahead&&(e.match_length=e.lookahead)}if(e.match_length>=x?(r=u._tr_tally(e,1,e.match_length-x),e.lookahead-=e.match_length,e.strstart+=e.match_length,e.match_length=0):(r=u._tr_tally(e,0,e.window[e.strstart]),e.lookahead--,e.strstart++),r&&(N(e,!1),0===e.strm.avail_out))return A}return e.insert=0,t===f?(N(e,!0),0===e.strm.avail_out?O:B):e.last_lit&&(N(e,!1),0===e.strm.avail_out)?A:I}(n,t):h[n.level].func(n,t);if(o!==O&&o!==B||(n.status=666),o===A||o===O)return 0===e.avail_out&&(n.last_flush=-1),m;if(o===I&&(1===t?u._tr_align(n):5!==t&&(u._tr_stored_block(n,0,0,!1),3===t&&(D(n.head),0===n.lookahead&&(n.strstart=0,n.block_start=0,n.insert=0))),F(e),0===e.avail_out))return n.last_flush=-1,m}return t!==f?m:n.wrap<=0?1:(2===n.wrap?(U(n,255&e.adler),U(n,e.adler>>8&255),U(n,e.adler>>16&255),U(n,e.adler>>24&255),U(n,255&e.total_in),U(n,e.total_in>>8&255),U(n,e.total_in>>16&255),U(n,e.total_in>>24&255)):(P(n,e.adler>>>16),P(n,65535&e.adler)),F(e),0=r.w_size&&(0===s&&(D(r.head),r.strstart=0,r.block_start=0,r.insert=0),u=new c.Buf8(r.w_size),c.arraySet(u,t,l-r.w_size,r.w_size,0),t=u,l=r.w_size),a=e.avail_in,o=e.next_in,h=e.input,e.avail_in=l,e.next_in=0,e.input=t,j(r);r.lookahead>=x;){for(n=r.strstart,i=r.lookahead-(x-1);r.ins_h=(r.ins_h<>>=y=v>>>24,p-=y,0===(y=v>>>16&255))C[s++]=65535&v;else{if(!(16&y)){if(0==(64&y)){v=m[(65535&v)+(d&(1<>>=y,p-=y),p<15&&(d+=z[n++]<>>=y=v>>>24,p-=y,!(16&(y=v>>>16&255))){if(0==(64&y)){v=_[(65535&v)+(d&(1<>>=y,p-=y,(y=s-a)>3,d&=(1<<(p-=w<<3))-1,e.next_in=n,e.next_out=s,e.avail_in=n>>24&255)+(e>>>8&65280)+((65280&e)<<8)+((255&e)<<24)}function s(){this.mode=0,this.last=!1,this.wrap=0,this.havedict=!1,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 I.Buf16(320),this.work=new I.Buf16(288),this.lendyn=null,this.distdyn=null,this.sane=0,this.back=0,this.was=0}function a(e){var t;return e&&e.state?(t=e.state,e.total_in=e.total_out=t.total=0,e.msg=\"\",t.wrap&&(e.adler=1&t.wrap),t.mode=P,t.last=0,t.havedict=0,t.dmax=32768,t.head=null,t.hold=0,t.bits=0,t.lencode=t.lendyn=new I.Buf32(n),t.distcode=t.distdyn=new I.Buf32(i),t.sane=1,t.back=-1,N):U}function o(e){var t;return e&&e.state?((t=e.state).wsize=0,t.whave=0,t.wnext=0,a(e)):U}function h(e,t){var r,n;return e&&e.state?(n=e.state,t<0?(r=0,t=-t):(r=1+(t>>4),t<48&&(t&=15)),t&&(t<8||15=s.wsize?(I.arraySet(s.window,t,r-s.wsize,s.wsize,0),s.wnext=0,s.whave=s.wsize):(n<(i=s.wsize-s.wnext)&&(i=n),I.arraySet(s.window,t,r-n,i,s.wnext),(n-=i)?(I.arraySet(s.window,t,r-n,n,0),s.wnext=n,s.whave=s.wsize):(s.wnext+=i,s.wnext===s.wsize&&(s.wnext=0),s.whave>>8&255,r.check=B(r.check,E,2,0),l=u=0,r.mode=2;break}if(r.flags=0,r.head&&(r.head.done=!1),!(1&r.wrap)||(((255&u)<<8)+(u>>8))%31){e.msg=\"incorrect header check\",r.mode=30;break}if(8!=(15&u)){e.msg=\"unknown compression method\",r.mode=30;break}if(l-=4,k=8+(15&(u>>>=4)),0===r.wbits)r.wbits=k;else if(k>r.wbits){e.msg=\"invalid window size\",r.mode=30;break}r.dmax=1<>8&1),512&r.flags&&(E[0]=255&u,E[1]=u>>>8&255,r.check=B(r.check,E,2,0)),l=u=0,r.mode=3;case 3:for(;l<32;){if(0===o)break e;o--,u+=n[s++]<>>8&255,E[2]=u>>>16&255,E[3]=u>>>24&255,r.check=B(r.check,E,4,0)),l=u=0,r.mode=4;case 4:for(;l<16;){if(0===o)break e;o--,u+=n[s++]<>8),512&r.flags&&(E[0]=255&u,E[1]=u>>>8&255,r.check=B(r.check,E,2,0)),l=u=0,r.mode=5;case 5:if(1024&r.flags){for(;l<16;){if(0===o)break e;o--,u+=n[s++]<>>8&255,r.check=B(r.check,E,2,0)),l=u=0}else r.head&&(r.head.extra=null);r.mode=6;case 6:if(1024&r.flags&&(o<(d=r.length)&&(d=o),d&&(r.head&&(k=r.head.extra_len-r.length,r.head.extra||(r.head.extra=new Array(r.head.extra_len)),I.arraySet(r.head.extra,n,s,d,k)),512&r.flags&&(r.check=B(r.check,n,d,s)),o-=d,s+=d,r.length-=d),r.length))break e;r.length=0,r.mode=7;case 7:if(2048&r.flags){if(0===o)break e;for(d=0;k=n[s+d++],r.head&&k&&r.length<65536&&(r.head.name+=String.fromCharCode(k)),k&&d>9&1,r.head.done=!0),e.adler=r.check=0,r.mode=12;break;case 10:for(;l<32;){if(0===o)break e;o--,u+=n[s++]<>>=7&l,l-=7&l,r.mode=27;break}for(;l<3;){if(0===o)break e;o--,u+=n[s++]<>>=1)){case 0:r.mode=14;break;case 1:if(j(r),r.mode=20,6!==t)break;u>>>=2,l-=2;break e;case 2:r.mode=17;break;case 3:e.msg=\"invalid block type\",r.mode=30}u>>>=2,l-=2;break;case 14:for(u>>>=7&l,l-=7&l;l<32;){if(0===o)break e;o--,u+=n[s++]<>>16^65535)){e.msg=\"invalid stored block lengths\",r.mode=30;break}if(r.length=65535&u,l=u=0,r.mode=15,6===t)break e;case 15:r.mode=16;case 16:if(d=r.length){if(o>>=5,l-=5,r.ndist=1+(31&u),u>>>=5,l-=5,r.ncode=4+(15&u),u>>>=4,l-=4,286>>=3,l-=3}for(;r.have<19;)r.lens[A[r.have++]]=0;if(r.lencode=r.lendyn,r.lenbits=7,S={bits:r.lenbits},x=T(0,r.lens,0,19,r.lencode,0,r.work,S),r.lenbits=S.bits,x){e.msg=\"invalid code lengths set\",r.mode=30;break}r.have=0,r.mode=19;case 19:for(;r.have>>16&255,b=65535&C,!((_=C>>>24)<=l);){if(0===o)break e;o--,u+=n[s++]<>>=_,l-=_,r.lens[r.have++]=b;else{if(16===b){for(z=_+2;l>>=_,l-=_,0===r.have){e.msg=\"invalid bit length repeat\",r.mode=30;break}k=r.lens[r.have-1],d=3+(3&u),u>>>=2,l-=2}else if(17===b){for(z=_+3;l>>=_)),u>>>=3,l-=3}else{for(z=_+7;l>>=_)),u>>>=7,l-=7}if(r.have+d>r.nlen+r.ndist){e.msg=\"invalid bit length repeat\",r.mode=30;break}for(;d--;)r.lens[r.have++]=k}}if(30===r.mode)break;if(0===r.lens[256]){e.msg=\"invalid code -- missing end-of-block\",r.mode=30;break}if(r.lenbits=9,S={bits:r.lenbits},x=T(D,r.lens,0,r.nlen,r.lencode,0,r.work,S),r.lenbits=S.bits,x){e.msg=\"invalid literal/lengths set\",r.mode=30;break}if(r.distbits=6,r.distcode=r.distdyn,S={bits:r.distbits},x=T(F,r.lens,r.nlen,r.ndist,r.distcode,0,r.work,S),r.distbits=S.bits,x){e.msg=\"invalid distances set\",r.mode=30;break}if(r.mode=20,6===t)break e;case 20:r.mode=21;case 21:if(6<=o&&258<=h){e.next_out=a,e.avail_out=h,e.next_in=s,e.avail_in=o,r.hold=u,r.bits=l,R(e,c),a=e.next_out,i=e.output,h=e.avail_out,s=e.next_in,n=e.input,o=e.avail_in,u=r.hold,l=r.bits,12===r.mode&&(r.back=-1);break}for(r.back=0;g=(C=r.lencode[u&(1<>>16&255,b=65535&C,!((_=C>>>24)<=l);){if(0===o)break e;o--,u+=n[s++]<>v)])>>>16&255,b=65535&C,!(v+(_=C>>>24)<=l);){if(0===o)break e;o--,u+=n[s++]<>>=v,l-=v,r.back+=v}if(u>>>=_,l-=_,r.back+=_,r.length=b,0===g){r.mode=26;break}if(32&g){r.back=-1,r.mode=12;break}if(64&g){e.msg=\"invalid literal/length code\",r.mode=30;break}r.extra=15&g,r.mode=22;case 22:if(r.extra){for(z=r.extra;l>>=r.extra,l-=r.extra,r.back+=r.extra}r.was=r.length,r.mode=23;case 23:for(;g=(C=r.distcode[u&(1<>>16&255,b=65535&C,!((_=C>>>24)<=l);){if(0===o)break e;o--,u+=n[s++]<>v)])>>>16&255,b=65535&C,!(v+(_=C>>>24)<=l);){if(0===o)break e;o--,u+=n[s++]<>>=v,l-=v,r.back+=v}if(u>>>=_,l-=_,r.back+=_,64&g){e.msg=\"invalid distance code\",r.mode=30;break}r.offset=b,r.extra=15&g,r.mode=24;case 24:if(r.extra){for(z=r.extra;l>>=r.extra,l-=r.extra,r.back+=r.extra}if(r.offset>r.dmax){e.msg=\"invalid distance too far back\",r.mode=30;break}r.mode=25;case 25:if(0===h)break e;if(d=c-h,r.offset>d){if((d=r.offset-d)>r.whave&&r.sane){e.msg=\"invalid distance too far back\",r.mode=30;break}p=d>r.wnext?(d-=r.wnext,r.wsize-d):r.wnext-d,d>r.length&&(d=r.length),m=r.window}else m=i,p=a-r.offset,d=r.length;for(hd?(m=R[T+a[v]],A[I+a[v]]):(m=96,0),h=1<>S)+(u-=h)]=p<<24|m<<16|_|0,0!==u;);for(h=1<>=1;if(0!==h?(E&=h-1,E+=h):E=0,v++,0==--O[b]){if(b===w)break;b=t[r+a[v]]}if(k>>7)]}function U(e,t){e.pending_buf[e.pending++]=255&t,e.pending_buf[e.pending++]=t>>>8&255}function P(e,t,r){e.bi_valid>d-r?(e.bi_buf|=t<>d-e.bi_valid,e.bi_valid+=r-d):(e.bi_buf|=t<>>=1,r<<=1,0<--t;);return r>>>1}function Z(e,t,r){var n,i,s=new Array(g+1),a=0;for(n=1;n<=g;n++)s[n]=a=a+r[n-1]<<1;for(i=0;i<=t;i++){var o=e[2*i+1];0!==o&&(e[2*i]=j(s[o]++,o))}}function W(e){var t;for(t=0;t>1;1<=r;r--)G(e,s,r);for(i=h;r=e.heap[1],e.heap[1]=e.heap[e.heap_len--],G(e,s,1),n=e.heap[1],e.heap[--e.heap_max]=r,e.heap[--e.heap_max]=n,s[2*i]=s[2*r]+s[2*n],e.depth[i]=(e.depth[r]>=e.depth[n]?e.depth[r]:e.depth[n])+1,s[2*r+1]=s[2*n+1]=i,e.heap[1]=i++,G(e,s,1),2<=e.heap_len;);e.heap[--e.heap_max]=e.heap[1],function(e,t){var r,n,i,s,a,o,h=t.dyn_tree,u=t.max_code,l=t.stat_desc.static_tree,f=t.stat_desc.has_stree,c=t.stat_desc.extra_bits,d=t.stat_desc.extra_base,p=t.stat_desc.max_length,m=0;for(s=0;s<=g;s++)e.bl_count[s]=0;for(h[2*e.heap[e.heap_max]+1]=0,r=e.heap_max+1;r<_;r++)p<(s=h[2*h[2*(n=e.heap[r])+1]+1]+1)&&(s=p,m++),h[2*n+1]=s,u>=7;n>>=1)if(1&r&&0!==e.dyn_ltree[2*t])return o;if(0!==e.dyn_ltree[18]||0!==e.dyn_ltree[20]||0!==e.dyn_ltree[26])return h;for(t=32;t>>3,(s=e.static_len+3+7>>>3)<=i&&(i=s)):i=s=r+5,r+4<=i&&-1!==t?J(e,t,r,n):4===e.strategy||s===i?(P(e,2+(n?1:0),3),K(e,z,C)):(P(e,4+(n?1:0),3),function(e,t,r,n){var i;for(P(e,t-257,5),P(e,r-1,5),P(e,n-4,4),i=0;i>>8&255,e.pending_buf[e.d_buf+2*e.last_lit+1]=255&t,e.pending_buf[e.l_buf+e.last_lit]=255&r,e.last_lit++,0===t?e.dyn_ltree[2*r]++:(e.matches++,t--,e.dyn_ltree[2*(A[r]+u+1)]++,e.dyn_dtree[2*N(t)]++),e.last_lit===e.lit_bufsize-1},r._tr_align=function(e){P(e,2,3),L(e,m,z),function(e){16===e.bi_valid?(U(e,e.bi_buf),e.bi_buf=0,e.bi_valid=0):8<=e.bi_valid&&(e.pending_buf[e.pending++]=255&e.bi_buf,e.bi_buf>>=8,e.bi_valid-=8)}(e)}},{\"../utils/common\":41}],53:[function(e,t,r){\"use strict\";t.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(e,t,r){(function(e){!function(r,n){\"use strict\";if(!r.setImmediate){var i,s,t,a,o=1,h={},u=!1,l=r.document,e=Object.getPrototypeOf&&Object.getPrototypeOf(r);e=e&&e.setTimeout?e:r,i=\"[object process]\"==={}.toString.call(r.process)?function(e){process.nextTick(function(){c(e)})}:function(){if(r.postMessage&&!r.importScripts){var e=!0,t=r.onmessage;return r.onmessage=function(){e=!1},r.postMessage(\"\",\"*\"),r.onmessage=t,e}}()?(a=\"setImmediate$\"+Math.random()+\"$\",r.addEventListener?r.addEventListener(\"message\",d,!1):r.attachEvent(\"onmessage\",d),function(e){r.postMessage(a+e,\"*\")}):r.MessageChannel?((t=new MessageChannel).port1.onmessage=function(e){c(e.data)},function(e){t.port2.postMessage(e)}):l&&\"onreadystatechange\"in l.createElement(\"script\")?(s=l.documentElement,function(e){var t=l.createElement(\"script\");t.onreadystatechange=function(){c(e),t.onreadystatechange=null,s.removeChild(t),t=null},s.appendChild(t)}):function(e){setTimeout(c,0,e)},e.setImmediate=function(e){\"function\"!=typeof e&&(e=new Function(\"\"+e));for(var t=new Array(arguments.length-1),r=0;r[a.modelValue?((0,i.uX)(),(0,i.CE)("div",{key:0,class:"mobile-drawer-overlay",onClick:t[3]||(t[3]=(...e)=>h.close&&h.close(...e))},[(0,i.Lk)("div",{class:"mobile-drawer",onClick:t[2]||(t[2]=(0,n.D$)(()=>{},["stop"]))},[(0,i.Lk)("div",r,[t[4]||(t[4]=(0,i.Lk)("span",{class:"mobile-drawer-title"},"目录导航",-1)),(0,i.bF)(u,{icon:"times",class:"mobile-drawer-close",onClick:h.close},null,8,["onClick"])]),(0,i.Lk)("div",o,[(0,i.Lk)("div",{class:(0,s.C4)(["mobile-drawer-item",{active:!a.currentPath}]),onClick:t[0]||(t[0]=e=>h.navigate(""))},[(0,i.bF)(u,{icon:"home",class:"mobile-drawer-item-icon"}),t[5]||(t[5]=(0,i.Lk)("span",null,"根目录",-1))],2),((0,i.uX)(!0),(0,i.CE)(i.FK,null,(0,i.pI)(h.pathParts,(e,t)=>((0,i.uX)(),(0,i.CE)("div",{key:t,class:(0,s.C4)(["mobile-drawer-item",{active:t===h.pathParts.length-1}]),style:(0,s.Tr)({paddingLeft:16*(t+1)+16+"px"}),onClick:e=>h.navigate(h.pathParts.slice(0,t+1).join("/"))},[(0,i.bF)(u,{icon:"folder",class:"mobile-drawer-item-icon"}),(0,i.Lk)("span",null,(0,s.v_)(e),1)],14,l))),128)),a.currentPath?((0,i.uX)(),(0,i.CE)("div",{key:0,class:"mobile-drawer-back",onClick:t[1]||(t[1]=(...e)=>h.goBack&&h.goBack(...e))},[(0,i.bF)(u,{icon:"arrow-left",class:"mobile-drawer-item-icon"}),t[6]||(t[6]=(0,i.Lk)("span",null,"返回上一级",-1))])):(0,i.Q3)("",!0)])])])):(0,i.Q3)("",!0)]),_:1})])}a(8111),a(2489);var d={name:"MobileDirectoryDrawer",props:{modelValue:{type:Boolean,default:!1},currentPath:{type:String,default:""}},emits:["update:modelValue","navigate","goBack"],computed:{pathParts(){return this.currentPath.split("/").filter(Boolean)}},methods:{close(){this.$emit("update:modelValue",!1)},navigate(e){this.$emit("navigate",e),this.close()},goBack(){this.$emit("goBack"),this.close()}}},h=a(1241);const u=(0,h.A)(d,[["render",c],["__scopeId","data-v-2d8e83ec"]]);var f=u;const m={class:"bottom-sheet-header"},p={class:"bottom-sheet-title"},g={class:"bottom-sheet-content"};function b(e,t,a,r,o,l){const c=(0,i.g2)("font-awesome-icon");return(0,i.uX)(),(0,i.Wv)(i.Im,{to:"body"},[(0,i.bF)(n.eB,{name:"bottom-sheet"},{default:(0,i.k6)(()=>[a.modelValue?((0,i.uX)(),(0,i.CE)("div",{key:0,class:"bottom-sheet-overlay",onClick:t[9]||(t[9]=(...e)=>l.close&&l.close(...e))},[(0,i.Lk)("div",{class:"bottom-sheet",onClick:t[8]||(t[8]=(0,n.D$)(()=>{},["stop"]))},[(0,i.Lk)("div",m,[t[10]||(t[10]=(0,i.Lk)("div",{class:"bottom-sheet-handle"},null,-1)),(0,i.Lk)("span",p,(0,s.v_)(a.title),1)]),(0,i.Lk)("div",g,[a.isFolder?((0,i.uX)(),(0,i.CE)(i.FK,{key:1},[(0,i.Lk)("div",{class:"bottom-sheet-item",onClick:t[5]||(t[5]=e=>l.handleAction("folderCopy"))},[(0,i.bF)(c,{icon:"copy",class:"bottom-sheet-icon"}),t[16]||(t[16]=(0,i.Lk)("span",null,"复制链接",-1))]),(0,i.Lk)("div",{class:"bottom-sheet-item",onClick:t[6]||(t[6]=e=>l.handleAction("move"))},[(0,i.bF)(c,{icon:"file-export",class:"bottom-sheet-icon"}),t[17]||(t[17]=(0,i.Lk)("span",null,"移动文件夹",-1))])],64)):((0,i.uX)(),(0,i.CE)(i.FK,{key:0},[(0,i.Lk)("div",{class:"bottom-sheet-item",onClick:t[0]||(t[0]=e=>l.handleAction("detail"))},[(0,i.bF)(c,{icon:"info-circle",class:"bottom-sheet-icon"}),t[11]||(t[11]=(0,i.Lk)("span",null,"查看详情",-1))]),(0,i.Lk)("div",{class:"bottom-sheet-item",onClick:t[1]||(t[1]=e=>l.handleAction("copy"))},[(0,i.bF)(c,{icon:"copy",class:"bottom-sheet-icon"}),t[12]||(t[12]=(0,i.Lk)("span",null,"复制链接",-1))]),(0,i.Lk)("div",{class:"bottom-sheet-item",onClick:t[2]||(t[2]=e=>l.handleAction("download"))},[(0,i.bF)(c,{icon:"download",class:"bottom-sheet-icon"}),t[13]||(t[13]=(0,i.Lk)("span",null,"下载文件",-1))]),(0,i.Lk)("div",{class:"bottom-sheet-item",onClick:t[3]||(t[3]=e=>l.handleAction("move"))},[(0,i.bF)(c,{icon:"file-export",class:"bottom-sheet-icon"}),t[14]||(t[14]=(0,i.Lk)("span",null,"移动文件",-1))]),(0,i.Lk)("div",{class:"bottom-sheet-item",onClick:t[4]||(t[4]=e=>l.handleAction("tag"))},[(0,i.bF)(c,{icon:"tags",class:"bottom-sheet-icon"}),t[15]||(t[15]=(0,i.Lk)("span",null,"标签管理",-1))])],64)),(0,i.Lk)("div",{class:"bottom-sheet-item bottom-sheet-danger",onClick:t[7]||(t[7]=e=>l.handleAction("delete"))},[(0,i.bF)(c,{icon:"trash-alt",class:"bottom-sheet-icon"}),(0,i.Lk)("span",null,(0,s.v_)(a.isFolder?"删除文件夹":"删除文件"),1)])])])])):(0,i.Q3)("",!0)]),_:1})])}var v={name:"MobileActionSheet",props:{modelValue:{type:Boolean,default:!1},title:{type:String,default:""},isFolder:{type:Boolean,default:!1}},emits:["update:modelValue","action"],methods:{close(){this.$emit("update:modelValue",!1)},handleAction(e){this.$emit("action",e),this.close()}}};const k=(0,h.A)(v,[["render",b],["__scopeId","data-v-7579ad69"]]);var y=k,_=a(9267),w=(a(5331),a(5616),a(4275)),F=a(9559),C=a(2687),T=(a(8785),a(9623)),x=(a(6711),a(47));a(9648);const S={class:"batch-tag-container"},L={class:"tab-content"},E={class:"tab-description"},A={class:"input-section"},I={key:0,class:"suggestions-panel"},D=["onClick"],U={class:"tags-to-add-section"},z={key:0,class:"tags-container"},B={key:1,class:"empty-message"},O={class:"action-buttons"},W={class:"tab-content"},$={key:0,class:"common-tags-section"},P={class:"tags-container"},R={key:1,class:"empty-message"},N={class:"tab-content"},j={class:"tab-description"},V={class:"action-buttons"};function M(e,t,a,r,o,l){const c=(0,i.g2)("font-awesome-icon"),d=x.S2,h=T.WK,u=C.u,f=w.v$,m=F.KR,p=w.q,g=_.kZ;return(0,i.uX)(),(0,i.Wv)(g,{title:"批量标签管理",modelValue:l.visible,"onUpdate:modelValue":t[2]||(t[2]=e=>l.visible=e),width:l.dialogWidth,onClose:l.handleClose},{default:(0,i.k6)(()=>[(0,i.Lk)("div",S,[(0,i.bF)(p,{modelValue:o.activeTab,"onUpdate:modelValue":t[1]||(t[1]=e=>o.activeTab=e),type:"border-card"},{default:(0,i.k6)(()=>[(0,i.bF)(f,{label:"添加",name:"add"},{default:(0,i.k6)(()=>[(0,i.Lk)("div",L,[(0,i.Lk)("p",E,"为选中的 "+(0,s.v_)(l.fileCount)+" 个文件添加标签",1),(0,i.Lk)("div",A,[(0,i.bF)(h,{modelValue:o.inputTag,"onUpdate:modelValue":t[0]||(t[0]=e=>o.inputTag=e),placeholder:"输入标签名称",onKeyup:(0,n.jR)(l.handleAddInputTag,["enter"]),onInput:l.handleInputChange,clearable:""},{append:(0,i.k6)(()=>[(0,i.bF)(d,{onClick:l.handleAddInputTag,type:"primary"},{default:(0,i.k6)(()=>[(0,i.bF)(c,{icon:"plus"})]),_:1},8,["onClick"])]),_:1},8,["modelValue","onKeyup","onInput"]),o.showSuggestions&&o.suggestions.length>0?((0,i.uX)(),(0,i.CE)("div",I,[((0,i.uX)(!0),(0,i.CE)(i.FK,null,(0,i.pI)(o.suggestions,e=>((0,i.uX)(),(0,i.CE)("div",{key:e,class:"suggestion-item",onClick:t=>l.selectSuggestion(e)},(0,s.v_)(e),9,D))),128))])):(0,i.Q3)("",!0)]),(0,i.Lk)("div",U,[t[3]||(t[3]=(0,i.Lk)("h4",null,"待添加的标签",-1)),o.tagsToAdd.length>0?((0,i.uX)(),(0,i.CE)("div",z,[((0,i.uX)(!0),(0,i.CE)(i.FK,null,(0,i.pI)(o.tagsToAdd,e=>((0,i.uX)(),(0,i.Wv)(u,{key:e,closable:"",onClose:t=>l.removeFromToAdd(e),class:"tag-item"},{default:(0,i.k6)(()=>[(0,i.eW)((0,s.v_)(e),1)]),_:2},1032,["onClose"]))),128))])):((0,i.uX)(),(0,i.CE)("div",B," 暂无待添加标签 "))]),(0,i.Lk)("div",O,[(0,i.bF)(d,{type:"primary",onClick:l.executeAddTags,loading:o.loading,disabled:0===o.tagsToAdd.length},{default:(0,i.k6)(()=>[...t[4]||(t[4]=[(0,i.eW)(" 添加到所有文件 ",-1)])]),_:1},8,["onClick","loading","disabled"])])])]),_:1}),(0,i.bF)(f,{label:"移除",name:"remove"},{default:(0,i.k6)(()=>[(0,i.Lk)("div",W,[t[6]||(t[6]=(0,i.Lk)("p",{class:"tab-description"},"移除选中文件的共有标签",-1)),o.commonTags.length>0?((0,i.uX)(),(0,i.CE)("div",$,[t[5]||(t[5]=(0,i.Lk)("h4",null,"共有标签",-1)),(0,i.Lk)("div",P,[((0,i.uX)(!0),(0,i.CE)(i.FK,null,(0,i.pI)(o.commonTags,e=>((0,i.uX)(),(0,i.Wv)(u,{key:e,closable:"",onClose:t=>l.handleRemoveCommonTag(e),class:"tag-item",type:"warning"},{default:(0,i.k6)(()=>[(0,i.eW)((0,s.v_)(e),1)]),_:2},1032,["onClose"]))),128))])])):((0,i.uX)(),(0,i.CE)("div",R," 选中的文件没有共有标签 "))])]),_:1}),(0,i.bF)(f,{label:"清空",name:"clear"},{default:(0,i.k6)(()=>[(0,i.Lk)("div",N,[(0,i.Lk)("p",j,"清空选中的 "+(0,s.v_)(l.fileCount)+" 个文件的所有标签",1),(0,i.bF)(m,{title:"⚠️警告",type:"warning",description:"此操作将清空所有选中文件的标签,且不可恢复",closable:!1,style:{"margin-bottom":"20px"},center:""}),(0,i.Lk)("div",V,[(0,i.bF)(d,{type:"danger",onClick:l.handleClearAllTags,loading:o.loading},{default:(0,i.k6)(()=>[...t[7]||(t[7]=[(0,i.eW)(" 确认清空所有标签 ",-1)])]),_:1},8,["onClick","loading"])])])]),_:1})]),_:1},8,["modelValue"])])]),_:1},8,["modelValue","width","onClose"])}a(4114),a(1701),a(3110);var X=a(1219),Z=a(2933),K=a(797),G={name:"BatchTagDialog",props:{modelValue:{type:Boolean,default:!1},selectedFiles:{type:Array,required:!0,default:()=>[]}},emits:["update:modelValue","tagsUpdated"],data(){return{activeTab:"add",inputTag:"",tagsToAdd:[],commonTags:[],suggestions:[],showSuggestions:!1,loading:!1,debounceTimer:null}},computed:{visible:{get(){return this.modelValue},set(e){this.$emit("update:modelValue",e)}},dialogWidth(){return window.innerWidth<768?"90%":"600px"},selectedFilesOnly(){return this.selectedFiles.filter(e=>!e.isFolder)},fileCount(){return this.selectedFilesOnly.length},fileIds(){return this.selectedFilesOnly.map(e=>e.name)}},watch:{visible(e){e?this.loadCommonTags():this.resetData()},activeTab(e){"remove"===e&&this.loadCommonTags()}},methods:{resetData(){this.tagsToAdd=[],this.inputTag="",this.showSuggestions=!1,this.activeTab="add"},async loadCommonTags(){if(0!==this.selectedFilesOnly.length)try{const e=this.selectedFilesOnly.map(e=>(0,K.A)(`/api/manage/tags/${encodeURIComponent(e.name)}`,{method:"GET"})),t=await Promise.all(e),a=[];for(const i of t)if(i.ok){const e=await i.json();a.push(e.tags||[])}a.length>0?this.commonTags=a[0].filter(e=>a.every(t=>t.includes(e))):this.commonTags=[]}catch(e){console.error("Error loading common tags:",e),X.nk.error("加载共有标签失败")}else this.commonTags=[]},handleInputChange(){clearTimeout(this.debounceTimer),this.inputTag&&0!==this.inputTag.trim().length?this.debounceTimer=setTimeout(()=>{this.fetchSuggestions()},300):this.showSuggestions=!1},async fetchSuggestions(){try{const e=this.inputTag.trim().toLowerCase(),t=await(0,K.A)(`/api/manage/tags/autocomplete?prefix=${encodeURIComponent(e)}&limit=10`,{method:"GET"});if(t.ok){const e=await t.json();this.suggestions=(e.tags||[]).filter(e=>!this.tagsToAdd.includes(e)),this.showSuggestions=this.suggestions.length>0}}catch(e){console.error("Error fetching suggestions:",e)}},selectSuggestion(e){this.inputTag=e,this.showSuggestions=!1,this.handleAddInputTag()},handleAddInputTag(){const e=this.inputTag.trim();if(e){if(this.tagsToAdd.includes(e))return X.nk.warning("标签已在列表中"),this.inputTag="",void(this.showSuggestions=!1);this.tagsToAdd.push(e),this.inputTag="",this.showSuggestions=!1}},removeFromToAdd(e){const t=this.tagsToAdd.indexOf(e);t>-1&&this.tagsToAdd.splice(t,1)},async executeAddTags(){if(0!==this.tagsToAdd.length){this.loading=!0;try{const e=await(0,K.A)("/api/manage/tags/batch",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({fileIds:this.fileIds,action:"add",tags:this.tagsToAdd})});if(!e.ok)throw new Error("批量添加标签失败");{const t=await e.json();if(!(t.success||t.updated>0))throw new Error("批量添加标签失败");X.nk.success(`成功为 ${t.updated} 个文件添加标签`),this.$emit("tagsUpdated"),this.tagsToAdd=[]}}catch(e){console.error("Error adding tags:",e),X.nk.error("批量添加标签失败")}finally{this.loading=!1}}else X.nk.warning("请先添加要批量添加的标签")},async handleRemoveCommonTag(e){this.loading=!0;try{const t=await(0,K.A)("/api/manage/tags/batch",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({fileIds:this.fileIds,action:"remove",tags:[e]})});if(!t.ok)throw new Error("移除标签失败");{const e=await t.json();if(!(e.success||e.updated>0))throw new Error("移除标签失败");X.nk.success(`成功从 ${e.updated} 个文件中移除标签`),this.$emit("tagsUpdated"),await this.loadCommonTags()}}catch(t){console.error("Error removing tag:",t),X.nk.error("移除标签失败")}finally{this.loading=!1}},handleClearAllTags(){Z.s.confirm(`确定要清空选中的 ${this.fileCount} 个文件的所有标签吗?此操作不可恢复。`,"确认清空",{confirmButtonText:"确定",cancelButtonText:"取消",type:"warning"}).then(()=>{this.executeClearTags()}).catch(()=>{X.nk.info("已取消清空操作")})},async executeClearTags(){this.loading=!0;try{const e=await(0,K.A)("/api/manage/tags/batch",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({fileIds:this.fileIds,action:"set",tags:[]})});if(!e.ok)throw new Error("清空标签失败");{const t=await e.json();if(!(t.success||t.updated>0))throw new Error("清空标签失败");X.nk.success(`成功清空 ${t.updated} 个文件的标签`),this.$emit("tagsUpdated"),this.commonTags=[]}}catch(e){console.error("Error clearing tags:",e),X.nk.error("清空标签失败")}finally{this.loading=!1}},handleClose(){this.visible=!1}}};const H=(0,h.A)(G,[["render",M],["__scopeId","data-v-dacf7742"]]);var q=H,Q=a(813);a(4896);const Y={class:"tag-management-container"},J={class:"input-section"},ee={key:0,class:"suggestions-panel"},te=["onClick"],ae={class:"current-tags-section"},ie={key:0,class:"tags-container"},ne={key:1,class:"empty-message"},se={class:"popular-tags-section"},re={key:0,class:"tags-container"},oe={key:1,class:"empty-message"},le={key:2,class:"empty-message"},ce={class:"dialog-footer"};function de(e,t,a,r,o,l){const c=(0,i.g2)("font-awesome-icon"),d=x.S2,h=T.WK,u=C.u,f=(0,i.g2)("Loading"),m=Q.tk,p=_.kZ;return(0,i.uX)(),(0,i.Wv)(p,{title:"标签管理",modelValue:l.visible,"onUpdate:modelValue":t[1]||(t[1]=e=>l.visible=e),width:l.dialogWidth,onClose:l.handleClose},{footer:(0,i.k6)(()=>[(0,i.Lk)("span",ce,[(0,i.bF)(d,{onClick:l.handleClose},{default:(0,i.k6)(()=>[...t[5]||(t[5]=[(0,i.eW)("关闭",-1)])]),_:1},8,["onClick"])])]),default:(0,i.k6)(()=>[(0,i.Lk)("div",Y,[(0,i.Lk)("div",J,[(0,i.bF)(h,{modelValue:o.inputTag,"onUpdate:modelValue":t[0]||(t[0]=e=>o.inputTag=e),placeholder:"输入标签名称",onKeyup:(0,n.jR)(l.handleAddTag,["enter"]),onInput:l.handleInputChange,clearable:""},{append:(0,i.k6)(()=>[(0,i.bF)(d,{onClick:l.handleAddTag,type:"primary"},{default:(0,i.k6)(()=>[(0,i.bF)(c,{icon:"plus"})]),_:1},8,["onClick"])]),_:1},8,["modelValue","onKeyup","onInput"]),o.showSuggestions&&o.suggestions.length>0?((0,i.uX)(),(0,i.CE)("div",ee,[((0,i.uX)(!0),(0,i.CE)(i.FK,null,(0,i.pI)(o.suggestions,e=>((0,i.uX)(),(0,i.CE)("div",{key:e,class:"suggestion-item",onClick:t=>l.selectSuggestion(e)},(0,s.v_)(e),9,te))),128))])):(0,i.Q3)("",!0)]),(0,i.Lk)("div",ae,[t[2]||(t[2]=(0,i.Lk)("h4",null,"当前标签",-1)),o.currentTags.length>0?((0,i.uX)(),(0,i.CE)("div",ie,[((0,i.uX)(!0),(0,i.CE)(i.FK,null,(0,i.pI)(o.currentTags,e=>((0,i.uX)(),(0,i.Wv)(u,{key:e,closable:"",onClose:t=>l.handleRemoveTag(e),class:"tag-item"},{default:(0,i.k6)(()=>[(0,i.eW)((0,s.v_)(e),1)]),_:2},1032,["onClose"]))),128))])):((0,i.uX)(),(0,i.CE)("div",ne," 暂无标签 "))]),(0,i.Lk)("div",se,[t[4]||(t[4]=(0,i.Lk)("h4",null,"常用标签",-1)),o.popularTags.length>0?((0,i.uX)(),(0,i.CE)("div",re,[((0,i.uX)(!0),(0,i.CE)(i.FK,null,(0,i.pI)(o.popularTags,e=>((0,i.uX)(),(0,i.Wv)(u,{key:e,onClick:t=>l.handleAddPopularTag(e),class:"tag-item clickable",type:"info"},{default:(0,i.k6)(()=>[(0,i.eW)((0,s.v_)(e),1)]),_:2},1032,["onClick"]))),128))])):o.loadingPopularTags?((0,i.uX)(),(0,i.CE)("div",oe,[(0,i.bF)(m,{class:"is-loading"},{default:(0,i.k6)(()=>[(0,i.bF)(f)]),_:1}),t[3]||(t[3]=(0,i.eW)(" 加载中... ",-1))])):((0,i.uX)(),(0,i.CE)("div",le," 暂无常用标签 "))])])]),_:1},8,["modelValue","width","onClose"])}var he=a(7477),ue={name:"TagManagementDialog",components:{Loading:he.Loading},props:{modelValue:{type:Boolean,default:!1},fileId:{type:String,required:!0}},emits:["update:modelValue","tagsUpdated"],data(){return{currentTags:[],inputTag:"",suggestions:[],popularTags:[],showSuggestions:!1,loading:!1,loadingPopularTags:!1,debounceTimer:null}},computed:{visible:{get(){return this.modelValue},set(e){this.$emit("update:modelValue",e)}},dialogWidth(){return window.innerWidth<768?"90%":"500px"}},watch:{visible(e){e&&(this.loadFileTags(),this.loadPopularTags())}},methods:{async loadFileTags(){try{const e=await(0,K.A)(`/api/manage/tags/${encodeURIComponent(this.fileId)}`,{method:"GET"});if(!e.ok)throw new Error("Failed to load tags");{const t=await e.json();this.currentTags=t.tags||[]}}catch(e){console.error("Error loading file tags:",e),X.nk.error("加载标签失败")}},async loadPopularTags(){this.loadingPopularTags=!0;try{const e=await(0,K.A)("/api/manage/tags/autocomplete?limit=20",{method:"GET"});if(e.ok){const t=await e.json();this.popularTags=(t.tags||[]).filter(e=>!this.currentTags.includes(e))}}catch(e){console.error("Error loading popular tags:",e)}finally{this.loadingPopularTags=!1}},handleInputChange(){clearTimeout(this.debounceTimer),this.inputTag&&0!==this.inputTag.trim().length?this.debounceTimer=setTimeout(()=>{this.fetchSuggestions()},300):this.showSuggestions=!1},async fetchSuggestions(){try{const e=this.inputTag.trim().toLowerCase(),t=await(0,K.A)(`/api/manage/tags/autocomplete?prefix=${encodeURIComponent(e)}&limit=10`,{method:"GET"});if(t.ok){const e=await t.json();this.suggestions=(e.tags||[]).filter(e=>!this.currentTags.includes(e)),this.showSuggestions=this.suggestions.length>0}}catch(e){console.error("Error fetching suggestions:",e)}},selectSuggestion(e){this.inputTag=e,this.showSuggestions=!1,this.handleAddTag()},async handleAddTag(){const e=this.inputTag.trim();if(e){if(this.currentTags.includes(e))return X.nk.warning("标签已存在"),this.inputTag="",void(this.showSuggestions=!1);try{const t=await(0,K.A)(`/api/manage/tags/${encodeURIComponent(this.fileId)}`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({action:"add",tags:[e]})});if(!t.ok){const e=await t.json();throw new Error(e.message||"添加标签失败")}{const e=await t.json();this.currentTags=e.tags||[],this.inputTag="",this.showSuggestions=!1,X.nk.success("标签添加成功"),this.$emit("tagsUpdated",this.currentTags),this.loadPopularTags()}}catch(t){console.error("Error adding tag:",t),X.nk.error(t.message||"添加标签失败")}}},async handleRemoveTag(e){try{const t=await(0,K.A)(`/api/manage/tags/${encodeURIComponent(this.fileId)}`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({action:"remove",tags:[e]})});if(!t.ok)throw new Error("删除标签失败");{const e=await t.json();this.currentTags=e.tags||[],X.nk.success("标签删除成功"),this.$emit("tagsUpdated",this.currentTags),this.loadPopularTags()}}catch(t){console.error("Error removing tag:",t),X.nk.error("删除标签失败")}},handleAddPopularTag(e){this.inputTag=e,this.handleAddTag()},handleClose(){this.visible=!1,this.inputTag="",this.showSuggestions=!1,this.currentTags=[],this.popularTags=[]}}};const fe=(0,h.A)(ue,[["render",de],["__scopeId","data-v-8b4291b4"]]);var me=fe,pe=a(5558),ge=(a(8075),a(6810)),be=(a(4396),a(4885),a(9869)),ve=(a(415),a(3565),a(7009));a(8450);const ke={class:"detail-actions"},ye={class:"preview-section"},_e={class:"preview-content"},we=["src"],Fe=["src"],Ce={key:0,style:{display:"flex","flex-wrap":"wrap",gap:"5px"}},Te={key:1,style:{color:"#909399"}};function xe(e,t,a,n,r,o){const l=(0,i.g2)("font-awesome-icon"),c=x.S2,d=T.WK,h=w.v$,u=w.q,f=ve.Zq,m=be.MF,p=C.u,g=be.TS,b=_.kZ;return(0,i.uX)(),(0,i.Wv)(b,{title:"文件详情",modelValue:o.visible,"onUpdate:modelValue":t[14]||(t[14]=e=>o.visible=e),width:o.dialogWidth},{default:(0,i.k6)(()=>[(0,i.Lk)("div",ke,[(0,i.bF)(c,{type:"primary",onClick:t[0]||(t[0]=t=>e.$emit("download")),round:"",size:"small",class:"detail-action"},{default:(0,i.k6)(()=>[(0,i.bF)(l,{icon:"download",style:{"margin-right":"3px"}}),t[15]||(t[15]=(0,i.eW)(" 下载 ",-1))]),_:1}),(0,i.bF)(c,{type:"primary",onClick:t[1]||(t[1]=t=>e.$emit("tagManagement")),round:"",size:"small",class:"detail-action"},{default:(0,i.k6)(()=>[(0,i.bF)(l,{icon:"tags",style:{"margin-right":"3px"}}),t[16]||(t[16]=(0,i.eW)(" 标签 ",-1))]),_:1}),(0,i.bF)(c,{type:"primary",onClick:t[2]||(t[2]=t=>e.$emit("block")),round:"",size:"small",class:"detail-action"},{default:(0,i.k6)(()=>[(0,i.bF)(l,{icon:"ban",style:{"margin-right":"3px"}}),t[17]||(t[17]=(0,i.eW)(" 黑名单 ",-1))]),_:1}),(0,i.bF)(c,{type:"primary",onClick:t[3]||(t[3]=t=>e.$emit("white")),round:"",size:"small",class:"detail-action"},{default:(0,i.k6)(()=>[(0,i.bF)(l,{icon:"user-plus",style:{"margin-right":"3px"}}),t[18]||(t[18]=(0,i.eW)(" 白名单 ",-1))]),_:1}),(0,i.bF)(c,{type:"danger",onClick:t[4]||(t[4]=t=>e.$emit("delete")),round:"",size:"small",class:"detail-action"},{default:(0,i.k6)(()=>[(0,i.bF)(l,{icon:"trash-alt",style:{"margin-right":"3px"}}),t[19]||(t[19]=(0,i.eW)(" 删除 ",-1))]),_:1})]),(0,i.bF)(u,{modelValue:r.activeTab,"onUpdate:modelValue":t[12]||(t[12]=e=>r.activeTab=e),onTabClick:o.handleTabClick,style:{"margin-bottom":"10px"}},{default:(0,i.k6)(()=>[(0,i.bF)(h,{label:"原始链接",name:"originUrl"},{default:(0,i.k6)(()=>[(0,i.bF)(d,{modelValue:a.urls.originUrl,"onUpdate:modelValue":t[5]||(t[5]=e=>a.urls.originUrl=e),readonly:"",onClick:o.handleUrlClick},null,8,["modelValue","onClick"])]),_:1}),(0,i.bF)(h,{label:"Markdown",name:"mdUrl"},{default:(0,i.k6)(()=>[(0,i.bF)(d,{modelValue:a.urls.mdUrl,"onUpdate:modelValue":t[6]||(t[6]=e=>a.urls.mdUrl=e),readonly:"",onClick:o.handleUrlClick},null,8,["modelValue","onClick"])]),_:1}),(0,i.bF)(h,{label:"HTML",name:"htmlUrl"},{default:(0,i.k6)(()=>[(0,i.bF)(d,{modelValue:a.urls.htmlUrl,"onUpdate:modelValue":t[7]||(t[7]=e=>a.urls.htmlUrl=e),readonly:"",onClick:o.handleUrlClick},null,8,["modelValue","onClick"])]),_:1}),(0,i.bF)(h,{label:"BBCode",name:"bbUrl"},{default:(0,i.k6)(()=>[(0,i.bF)(d,{modelValue:a.urls.bbUrl,"onUpdate:modelValue":t[8]||(t[8]=e=>a.urls.bbUrl=e),readonly:"",onClick:o.handleUrlClick},null,8,["modelValue","onClick"])]),_:1}),a.file?.metadata?.TgFileId?((0,i.uX)(),(0,i.Wv)(h,{key:0,label:"TG File ID",name:"tgId"},{default:(0,i.k6)(()=>[(0,i.bF)(d,{modelValue:a.urls.tgId,"onUpdate:modelValue":t[9]||(t[9]=e=>a.urls.tgId=e),readonly:"",onClick:o.handleUrlClick},null,8,["modelValue","onClick"])]),_:1})):(0,i.Q3)("",!0),a.file?.metadata?.S3Location?((0,i.uX)(),(0,i.Wv)(h,{key:1,label:"S3 Location",name:"s3Location"},{default:(0,i.k6)(()=>[(0,i.bF)(d,{modelValue:a.urls.S3Location,"onUpdate:modelValue":t[10]||(t[10]=e=>a.urls.S3Location=e),readonly:"",onClick:o.handleUrlClick},null,8,["modelValue","onClick"])]),_:1})):(0,i.Q3)("",!0),a.file?.metadata?.S3CdnFileUrl?((0,i.uX)(),(0,i.Wv)(h,{key:2,label:"S3 CDN URL",name:"s3CdnFileUrl"},{default:(0,i.k6)(()=>[(0,i.bF)(d,{modelValue:a.urls.S3CdnFileUrl,"onUpdate:modelValue":t[11]||(t[11]=e=>a.urls.S3CdnFileUrl=e),readonly:"",onClick:o.handleUrlClick},null,8,["modelValue","onClick"])]),_:1})):(0,i.Q3)("",!0)]),_:1},8,["modelValue","onTabClick"]),(0,i.Lk)("div",ye,[(0,i.Lk)("div",_e,[o.isVideo?((0,i.uX)(),(0,i.CE)("video",{key:0,src:a.fileLink,autoplay:"",muted:"",loop:"",class:"video-preview",onClick:t[13]||(t[13]=(...e)=>o.openImageLink&&o.openImageLink(...e))},null,8,we)):o.isAudio?((0,i.uX)(),(0,i.CE)("audio",{key:1,src:a.fileLink,controls:"",autoplay:"",class:"audio-preview"},null,8,Fe)):o.isImage?((0,i.uX)(),(0,i.Wv)(f,{key:2,src:a.fileLink,"preview-src-list":[a.fileLink],"preview-teleported":!0,fit:"contain",lazy:"",class:"image-preview"},null,8,["src","preview-src-list"])):((0,i.uX)(),(0,i.Wv)(l,{key:3,icon:"file",class:"file-icon-detail"}))])]),(0,i.bF)(g,{border:"",column:o.descColumn},{default:(0,i.k6)(()=>[(0,i.bF)(m,{label:"文件名"},{default:(0,i.k6)(()=>[(0,i.eW)((0,s.v_)(a.file?.metadata?.FileName||a.file?.name),1)]),_:1}),(0,i.bF)(m,{label:"文件类型"},{default:(0,i.k6)(()=>[(0,i.eW)((0,s.v_)(a.file?.metadata?.FileType||"未知"),1)]),_:1}),(0,i.bF)(m,{label:"文件大小"},{default:(0,i.k6)(()=>[(0,i.eW)((0,s.v_)(a.file?.metadata?.FileSize?a.file.metadata.FileSize+" MB":"未知"),1)]),_:1}),(0,i.bF)(m,{label:"上传时间"},{default:(0,i.k6)(()=>[(0,i.eW)((0,s.v_)(o.uploadTime),1)]),_:1}),(0,i.bF)(m,{label:"渠道类型/名称"},{default:(0,i.k6)(()=>[(0,i.eW)((0,s.v_)(a.file?.metadata?.Channel||"未知")+" / "+(0,s.v_)(a.file?.metadata?.ChannelName||"-"),1)]),_:1}),(0,i.bF)(m,{label:"访问状态/审查"},{default:(0,i.k6)(()=>[(0,i.eW)((0,s.v_)(o.accessType)+" / "+(0,s.v_)(a.file?.metadata?.Label||"无"),1)]),_:1}),(0,i.bF)(m,{label:"上传IP"},{default:(0,i.k6)(()=>[(0,i.eW)((0,s.v_)(a.file?.metadata?.UploadIP||"未知"),1)]),_:1}),(0,i.bF)(m,{label:"上传地址"},{default:(0,i.k6)(()=>[(0,i.eW)((0,s.v_)(a.file?.metadata?.UploadAddress||"未知"),1)]),_:1}),(0,i.bF)(m,{label:"文件标签"},{default:(0,i.k6)(()=>[a.file?.metadata?.Tags&&a.file?.metadata?.Tags.length>0?((0,i.uX)(),(0,i.CE)("div",Ce,[((0,i.uX)(!0),(0,i.CE)(i.FK,null,(0,i.pI)(a.file?.metadata?.Tags,e=>((0,i.uX)(),(0,i.Wv)(p,{key:e,size:"small"},{default:(0,i.k6)(()=>[(0,i.eW)((0,s.v_)(e),1)]),_:2},1024))),128))])):((0,i.uX)(),(0,i.CE)("span",Te,"暂无标签"))]),_:1})]),_:1},8,["column"])]),_:1},8,["modelValue","width"])}var Se={name:"FileDetailDialog",props:{modelValue:{type:Boolean,default:!1},file:{type:Object,default:null},fileLink:{type:String,default:""},urls:{type:Object,default:()=>({originUrl:"",mdUrl:"",htmlUrl:"",bbUrl:"",tgId:"",S3Location:"",S3CdnFileUrl:""})}},emits:["update:modelValue","download","tagManagement","block","white","delete"],data(){return{activeTab:"originUrl"}},computed:{visible:{get(){return this.modelValue},set(e){this.$emit("update:modelValue",e)}},dialogWidth(){return window.innerWidth<768?"95%":"900px"},descColumn(){return window.innerWidth<768?1:2},isVideo(){const e=this.file?.metadata?.FileType?.toLowerCase()||"";if(e.includes("video"))return!0;const t=this.file?.name?.toLowerCase()||"";return t.endsWith(".mp4")||t.endsWith(".webm")||t.endsWith(".mov")||t.endsWith(".avi")},isAudio(){const e=this.file?.metadata?.FileType?.toLowerCase()||"";if(e.includes("audio"))return!0;const t=this.file?.name?.toLowerCase()||"";return t.endsWith(".mp3")||t.endsWith(".wav")||t.endsWith(".ogg")||t.endsWith(".flac")},isImage(){const e=this.file?.metadata?.FileType?.toLowerCase()||"";if(e.includes("image"))return!0;const t=this.file?.name?.toLowerCase()||"";return t.endsWith(".jpg")||t.endsWith(".jpeg")||t.endsWith(".png")||t.endsWith(".gif")||t.endsWith(".webp")||t.endsWith(".svg")||t.endsWith(".bmp")||t.endsWith(".avif")||t.endsWith(".heic")||t.endsWith(".heif")},uploadTime(){return this.file?.metadata?.TimeStamp?new Date(this.file.metadata.TimeStamp).toLocaleString():"未知"},accessType(){const e=this.file?.metadata?.ListType,t=this.file?.metadata?.Label;return"White"===e?"正常(白名单)":"Block"===e?"已屏蔽(黑名单)":"adult"===t?"已屏蔽(审查不通过)":"正常"}},methods:{handleVideoClick(e){const t=e.target;t.paused?t.play():t.pause()},handleTabClick(){},handleUrlClick(e){const t=e.target;t.select(),navigator.clipboard.writeText(t.value).then(()=>{X.nk.success("链接已复制")})},openImageLink(){if(this.fileLink){const e=this.fileLink.replace(/\?from=admin$/,"");window.open(e,"_blank")}}}};const Le=(0,h.A)(Se,[["render",xe],["__scopeId","data-v-0dc381fc"]]);var Ee=Le,Ae=a(4880),Ie=(a(4318),a(7815)),De=(a(2907),a(8507));a(213);const Ue={class:"list-col list-col-checkbox"},ze=["src"],Be=["src"],Oe=["title"],We={class:"filename-start"},$e={class:"filename-end"},Pe={class:"list-col list-col-tags"},Re={key:1,class:"list-empty"},Ne={class:"list-col list-col-channel"},je={class:"list-col list-col-channel-name"},Ve={key:0,class:"channel-name-box"},Me={key:1,class:"list-empty"},Xe={class:"list-col list-col-address"},Ze={key:0,class:"address-box"},Ke={key:1,class:"list-empty"},Ge={class:"list-col list-col-size"},He={class:"list-col list-col-date"},qe={class:"list-col list-col-actions"};function Qe(e,t,a,r,o,l){const c=(0,i.g2)("font-awesome-icon"),d=De.R7;return(0,i.uX)(),(0,i.CE)("div",{class:"list-item",onTouchstart:t[9]||(t[9]=t=>e.$emit("touchstart",t)),onTouchend:t[10]||(t[10]=t=>e.$emit("touchend",t)),onTouchmove:t[11]||(t[11]=t=>e.$emit("touchmove",t))},[(0,i.Lk)("div",Ue,[(0,i.Lk)("span",{class:(0,s.C4)(["custom-checkbox",{checked:o.localSelected}]),onClick:t[0]||(t[0]=(0,n.D$)((...e)=>l.toggleSelect&&l.toggleSelect(...e),["stop"]))},[o.localSelected?((0,i.uX)(),(0,i.Wv)(c,{key:0,icon:"check",class:"check-icon"})):(0,i.Q3)("",!0)],2)]),(0,i.Lk)("div",{class:"list-col list-col-preview",onClick:t[1]||(t[1]=(...e)=>l.handlePreviewClick&&l.handlePreviewClick(...e))},[l.isFolder?((0,i.uX)(),(0,i.Wv)(c,{key:0,icon:"folder-open",class:"list-folder-icon"})):l.isVideo?((0,i.uX)(),(0,i.CE)("video",{key:1,src:a.fileLink,class:"list-preview-img",muted:"",preload:"metadata"},null,8,ze)):l.isImage?((0,i.uX)(),(0,i.CE)("img",{key:2,src:a.fileLink,class:"list-preview-img",loading:"lazy",decoding:"async"},null,8,Be)):((0,i.uX)(),(0,i.Wv)(c,{key:3,icon:"file",class:"list-file-icon"}))]),(0,i.Lk)("div",{class:"list-col list-col-name",onClick:t[2]||(t[2]=(...e)=>l.handlePreviewClick&&l.handlePreviewClick(...e))},[(0,i.Lk)("span",{class:"filename-ellipsis",title:l.displayName},[(0,i.Lk)("span",We,(0,s.v_)(l.fileNameStart),1),(0,i.Lk)("span",$e,(0,s.v_)(l.fileNameEnd),1)],8,Oe)]),(0,i.Lk)("div",Pe,[!l.isFolder&&a.item.metadata?.Tags&&a.item.metadata.Tags.length>0?((0,i.uX)(),(0,i.CE)(i.FK,{key:0},[((0,i.uX)(!0),(0,i.CE)(i.FK,null,(0,i.pI)(a.item.metadata.Tags.slice(0,3),(e,t)=>((0,i.uX)(),(0,i.CE)("span",{key:t,class:"color-tag",style:(0,s.Tr)({background:l.getTagColor(t)})},(0,s.v_)(e),5))),128)),a.item.metadata.Tags.length>3?((0,i.uX)(),(0,i.CE)("span",{key:0,class:"color-tag color-tag-more",style:(0,s.Tr)({background:l.getTagColor(3)})},"+"+(0,s.v_)(a.item.metadata.Tags.length-3),5)):(0,i.Q3)("",!0)],64)):((0,i.uX)(),(0,i.CE)("span",Re,"-"))]),(0,i.Lk)("div",Ne,(0,s.v_)(l.isFolder?"-":a.item.metadata?.Channel||a.item.channelTag||"-"),1),(0,i.Lk)("div",je,[!l.isFolder&&a.item.metadata?.ChannelName?((0,i.uX)(),(0,i.CE)("div",Ve,(0,s.v_)(a.item.metadata.ChannelName),1)):((0,i.uX)(),(0,i.CE)("span",Me,"-"))]),(0,i.Lk)("div",Xe,[!l.isFolder&&a.item.metadata?.UploadIP?((0,i.uX)(),(0,i.CE)("div",Ze,(0,s.v_)(a.item.metadata.UploadIP),1)):((0,i.uX)(),(0,i.CE)("span",Ke,"-"))]),(0,i.Lk)("div",Ge,(0,s.v_)(l.isFolder?"-":a.item.metadata?.FileSize?a.item.metadata.FileSize+" MB":"-"),1),(0,i.Lk)("div",He,(0,s.v_)(l.uploadDate),1),(0,i.Lk)("div",qe,[l.isFolder?((0,i.uX)(),(0,i.CE)(i.FK,{key:1},[(0,i.bF)(d,{content:"复制链接",placement:"top"},{default:(0,i.k6)(()=>[(0,i.Lk)("button",{class:"list-action-btn",onClick:t[6]||(t[6]=(0,n.D$)(t=>e.$emit("folderCopy"),["stop"]))},[(0,i.bF)(c,{icon:"copy"})])]),_:1}),(0,i.bF)(d,{content:"移动",placement:"top"},{default:(0,i.k6)(()=>[(0,i.Lk)("button",{class:"list-action-btn",onClick:t[7]||(t[7]=(0,n.D$)(t=>e.$emit("move"),["stop"]))},[(0,i.bF)(c,{icon:"file-export"})])]),_:1})],64)):((0,i.uX)(),(0,i.CE)(i.FK,{key:0},[(0,i.bF)(d,{content:"复制链接",placement:"top"},{default:(0,i.k6)(()=>[(0,i.Lk)("button",{class:"list-action-btn",onClick:t[3]||(t[3]=(0,n.D$)(t=>e.$emit("copy"),["stop"]))},[(0,i.bF)(c,{icon:"copy"})])]),_:1}),(0,i.bF)(d,{content:"下载",placement:"top"},{default:(0,i.k6)(()=>[(0,i.Lk)("button",{class:"list-action-btn",onClick:t[4]||(t[4]=(0,n.D$)(t=>e.$emit("download"),["stop"]))},[(0,i.bF)(c,{icon:"download"})])]),_:1}),(0,i.bF)(d,{content:"移动",placement:"top"},{default:(0,i.k6)(()=>[(0,i.Lk)("button",{class:"list-action-btn",onClick:t[5]||(t[5]=(0,n.D$)(t=>e.$emit("move"),["stop"]))},[(0,i.bF)(c,{icon:"file-export"})])]),_:1})],64)),(0,i.bF)(d,{content:"删除",placement:"top"},{default:(0,i.k6)(()=>[(0,i.Lk)("button",{class:"list-action-btn list-action-danger",onClick:t[8]||(t[8]=(0,n.D$)(t=>e.$emit("delete"),["stop"]))},[(0,i.bF)(c,{icon:"trash-alt"})])]),_:1})])],32)}var Ye={name:"FileListItem",props:{item:{type:Object,required:!0},selected:{type:Boolean,default:!1},fileLink:{type:String,default:""}},emits:["update:selected","enter","detail","copy","folderCopy","move","delete","download","touchstart","touchend","touchmove"],data(){return{localSelected:this.selected,tagColors:["#f472b6","#a78bfa","#60a5fa","#34d399"]}},computed:{isFolder(){return this.item.name?.endsWith("/")},isVideo(){const e=this.item.name?.toLowerCase()||"";return e.endsWith(".mp4")||e.endsWith(".webm")||e.endsWith(".mov")||e.endsWith(".avi")},isImage(){const e=this.item.name?.toLowerCase()||"";return e.endsWith(".jpg")||e.endsWith(".jpeg")||e.endsWith(".png")||e.endsWith(".gif")||e.endsWith(".webp")||e.endsWith(".svg")||e.endsWith(".bmp")},displayName(){if(this.isFolder){const e=this.item.name.split("/").filter(Boolean);return e[e.length-1]||this.item.name}return this.item.metadata?.FileName||this.getFileName(this.item.name)},fileNameStart(){const e=this.displayName;return e.length<=20?e:e.slice(0,-8)},fileNameEnd(){const e=this.displayName;return e.length<=20?"":e.slice(-8)},uploadDate(){return this.item.uploaded?new Date(this.item.uploaded).toLocaleDateString():this.item.metadata?.TimeStamp?new Date(this.item.metadata.TimeStamp).toLocaleDateString():"-"}},watch:{selected(e){this.localSelected=e}},methods:{toggleSelect(){this.localSelected=!this.localSelected,this.$emit("update:selected",this.localSelected)},handlePreviewClick(){this.isFolder?this.$emit("enter"):this.$emit("detail")},getFileName(e){const t=(e||"").split("/");return t[t.length-1]},getTagColor(e){return this.tagColors[e%this.tagColors.length]}}};const Je=(0,h.A)(Ye,[["render",Qe],["__scopeId","data-v-9968e9fe"]]);var et=Je,tt=a(683),at=(a(5385),a(850));a(8736);const it={class:"file-short-info"},nt={key:0,class:"success-tag"},st={key:1,class:"fail-tag"},rt={key:2,class:"success-tag"},ot={key:3,class:"primary-tag"},lt={key:0,style:{"margin-left":"2px"}},ct={key:0,class:"skeleton-wrapper"},dt=["src"],ht={key:3,class:"file-preview"},ut={class:"card-bottom-overlay"},ft={class:"file-name-row"},mt={class:"file-name"},pt={class:"action-bar"},gt={class:"action-bar-left"},bt={class:"action-bar-right"};function vt(e,t,a,r,o,l){const c=at.dI,d=(0,i.g2)("font-awesome-icon"),h=ve.Zq,u=De.R7,f=tt.Ik;return(0,i.uX)(),(0,i.Wv)(f,{class:"img-card",onTouchstart:t[17]||(t[17]=t=>e.$emit("touchstart",t)),onTouchend:t[18]||(t[18]=t=>e.$emit("touchend",t)),onTouchmove:t[19]||(t[19]=t=>e.$emit("touchmove",t))},{default:(0,i.k6)(()=>[(0,i.bF)(c,{modelValue:o.localSelected,"onUpdate:modelValue":t[0]||(t[0]=e=>o.localSelected=e),onChange:t[1]||(t[1]=t=>e.$emit("update:selected",o.localSelected))},null,8,["modelValue"]),(0,i.Lk)("div",it,["White"===a.item.metadata?.ListType?((0,i.uX)(),(0,i.CE)("div",nt,(0,s.v_)(l.channelTag),1)):"Block"===a.item.metadata?.ListType||"adult"===a.item.metadata?.Label?((0,i.uX)(),(0,i.CE)("div",st,(0,s.v_)(l.channelTag),1)):((0,i.uX)(),(0,i.CE)("div",rt,(0,s.v_)(l.channelTag),1)),a.item.metadata?.Tags&&a.item.metadata?.Tags.length>0?((0,i.uX)(),(0,i.CE)("div",ot,[(0,i.bF)(d,{icon:"tag",style:{"margin-right":"3px","font-size":"12px"}}),(0,i.eW)(" "+(0,s.v_)(a.item.metadata.Tags[0])+" ",1),a.item.metadata.Tags.length>1?((0,i.uX)(),(0,i.CE)("span",lt," (+"+(0,s.v_)(a.item.metadata.Tags.length-1)+") ",1)):(0,i.Q3)("",!0)])):(0,i.Q3)("",!0)]),l.isVideo?((0,i.uX)(),(0,i.CE)(i.FK,{key:0},[o.videoLoading?((0,i.uX)(),(0,i.CE)("div",ct)):o.videoError?((0,i.uX)(),(0,i.CE)("div",{key:1,class:"error-wrapper",onClick:t[2]||(t[2]=t=>e.$emit("detail"))},[(0,i.bF)(d,{icon:"exclamation-triangle",class:"error-icon"}),t[20]||(t[20]=(0,i.Lk)("span",{class:"error-text"},"加载失败",-1))])):(0,i.Q3)("",!0),(0,i.bo)((0,i.Lk)("video",{src:a.fileLink,muted:"",loop:"",preload:"metadata",class:"video-preview",onClick:t[3]||(t[3]=(...e)=>l.handleVideoClick&&l.handleVideoClick(...e)),onMouseenter:t[4]||(t[4]=e=>l.handleVideoHover(e,!0)),onMouseleave:t[5]||(t[5]=e=>l.handleVideoHover(e,!1)),onFullscreenchange:t[6]||(t[6]=(...e)=>l.handleFullscreenChange&&l.handleFullscreenChange(...e)),onWebkitfullscreenchange:t[7]||(t[7]=(...e)=>l.handleFullscreenChange&&l.handleFullscreenChange(...e)),onLoadeddata:t[8]||(t[8]=e=>o.videoLoading=!1),onError:t[9]||(t[9]=(...e)=>l.handleVideoError&&l.handleVideoError(...e))},null,40,dt),[[n.aG,!o.videoLoading&&!o.videoError]])],64)):l.isAudio?((0,i.uX)(),(0,i.CE)("div",{key:1,class:"file-preview audio-card-preview",onClick:t[10]||(t[10]=t=>e.$emit("detail"))},[(0,i.bF)(d,{icon:"music",class:"file-icon audio-icon"})])):l.isImage?((0,i.uX)(),(0,i.Wv)(h,{key:2,"preview-teleported":!0,src:a.fileLink,"preview-src-list":a.previewSrcList,fit:"cover",lazy:"",class:"image-preview"},{placeholder:(0,i.k6)(()=>[...t[21]||(t[21]=[(0,i.Lk)("div",{class:"skeleton-wrapper"},null,-1)])]),error:(0,i.k6)(()=>[(0,i.Lk)("div",{class:"error-wrapper",onClick:t[11]||(t[11]=(0,n.D$)(t=>e.$emit("detail"),["stop"]))},[(0,i.bF)(d,{icon:"image",class:"error-icon"}),t[22]||(t[22]=(0,i.Lk)("span",{class:"error-text"},"加载失败",-1))])]),_:1},8,["src","preview-src-list"])):((0,i.uX)(),(0,i.CE)("div",ht,[(0,i.bF)(d,{icon:"file",class:"file-icon"})])),(0,i.Lk)("div",ut,[(0,i.Lk)("div",ft,[(0,i.Lk)("span",mt,(0,s.v_)(l.displayName),1)]),(0,i.Lk)("div",pt,[(0,i.Lk)("div",gt,[(0,i.bF)(u,{disabled:a.disableTooltip,content:"详情",placement:"top"},{default:(0,i.k6)(()=>[(0,i.Lk)("button",{class:"action-btn",onClick:t[12]||(t[12]=(0,n.D$)(t=>e.$emit("detail"),["stop"]))},[(0,i.bF)(d,{icon:"info-circle"})])]),_:1},8,["disabled"])]),(0,i.Lk)("div",bt,[(0,i.bF)(u,{disabled:a.disableTooltip,content:"移动",placement:"top"},{default:(0,i.k6)(()=>[(0,i.Lk)("button",{class:"action-btn",onClick:t[13]||(t[13]=(0,n.D$)(t=>e.$emit("move"),["stop"]))},[(0,i.bF)(d,{icon:"file-export"})])]),_:1},8,["disabled"]),(0,i.bF)(u,{disabled:a.disableTooltip,content:"删除",placement:"top"},{default:(0,i.k6)(()=>[(0,i.Lk)("button",{class:"action-btn action-btn-danger",onClick:t[14]||(t[14]=(0,n.D$)(t=>e.$emit("delete"),["stop"]))},[(0,i.bF)(d,{icon:"trash-alt"})])]),_:1},8,["disabled"]),(0,i.bF)(u,{disabled:a.disableTooltip,content:"下载",placement:"top"},{default:(0,i.k6)(()=>[(0,i.Lk)("button",{class:"action-btn",onClick:t[15]||(t[15]=(0,n.D$)(t=>e.$emit("download"),["stop"]))},[(0,i.bF)(d,{icon:"download"})])]),_:1},8,["disabled"]),(0,i.bF)(u,{disabled:a.disableTooltip,content:"复制链接",placement:"top"},{default:(0,i.k6)(()=>[(0,i.Lk)("button",{class:"action-btn",onClick:t[16]||(t[16]=(0,n.D$)(t=>e.$emit("copy"),["stop"]))},[(0,i.bF)(d,{icon:"copy"})])]),_:1},8,["disabled"])])])])]),_:1})}var kt={name:"FileCard",props:{item:{type:Object,required:!0},selected:{type:Boolean,default:!1},fileLink:{type:String,required:!0},previewSrcList:{type:Array,default:()=>[]},disableTooltip:{type:Boolean,default:!1}},emits:["update:selected","detail","copy","move","delete","download","touchstart","touchend","touchmove"],data(){return{localSelected:this.selected,videoLoading:!0,videoError:!1}},computed:{channelTag(){return this.item.channelTag||""},isVideo(){const e=this.item.metadata?.FileType?.toLowerCase()||"";if(e.includes("video"))return!0;const t=this.item.name?.toLowerCase()||"";return t.endsWith(".mp4")||t.endsWith(".webm")||t.endsWith(".mov")||t.endsWith(".avi")},isAudio(){const e=this.item.metadata?.FileType?.toLowerCase()||"";if(e.includes("audio"))return!0;const t=this.item.name?.toLowerCase()||"";return t.endsWith(".mp3")||t.endsWith(".wav")||t.endsWith(".ogg")||t.endsWith(".flac")},isImage(){const e=this.item.metadata?.FileType?.toLowerCase()||"";if(e.includes("image"))return!0;const t=this.item.name?.toLowerCase()||"";return t.endsWith(".jpg")||t.endsWith(".jpeg")||t.endsWith(".png")||t.endsWith(".gif")||t.endsWith(".webp")||t.endsWith(".svg")||t.endsWith(".bmp")||t.endsWith(".avif")||t.endsWith(".heic")||t.endsWith(".heif")},displayName(){const e=this.item.metadata?.FileName||this.item.name||"",t=e.split("/");return t[t.length-1]}},watch:{selected(e){this.localSelected=e},fileLink(){this.videoLoading=!0,this.videoError=!1}},methods:{handleVideoError(){this.videoLoading=!1,this.videoError=!0},handleVideoClick(e){const t=e.target;t.requestFullscreen?t.requestFullscreen():t.webkitRequestFullscreen?t.webkitRequestFullscreen():t.mozRequestFullScreen?t.mozRequestFullScreen():t.msRequestFullscreen&&t.msRequestFullscreen()},handleFullscreenChange(e){const t=e.target,a=document.fullscreenElement||document.webkitFullscreenElement||document.mozFullScreenElement||document.msFullscreenElement;a?(t.muted=!1,t.loop=!1):(t.muted=!0,t.loop=!0,t.pause(),t.currentTime=0)},handleVideoHover(e,t){const a=e.target;t?a.play().catch(()=>{}):(a.pause(),a.currentTime=0)}}};const yt=(0,h.A)(kt,[["render",vt],["__scopeId","data-v-ddf49ce2"]]);var _t=yt;const wt={class:"card-bottom-overlay"},Ft={class:"file-name-row"},Ct={class:"file-name"},Tt={key:0,class:"action-bar"},xt={class:"action-bar-right"};function St(e,t,a,r,o,l){const c=at.dI,d=(0,i.g2)("font-awesome-icon"),h=De.R7,u=tt.Ik;return(0,i.uX)(),(0,i.Wv)(u,{class:"img-card folder-card",onTouchstart:t[6]||(t[6]=t=>e.$emit("touchstart",t)),onTouchend:t[7]||(t[7]=t=>e.$emit("touchend",t)),onTouchmove:t[8]||(t[8]=t=>e.$emit("touchmove",t))},{default:(0,i.k6)(()=>[(0,i.bF)(c,{modelValue:o.localSelected,"onUpdate:modelValue":t[0]||(t[0]=e=>o.localSelected=e),onChange:t[1]||(t[1]=t=>e.$emit("update:selected",o.localSelected))},null,8,["modelValue"]),(0,i.Lk)("div",{class:"folder-icon",onClick:t[2]||(t[2]=t=>e.$emit("enter"))},[(0,i.bF)(d,{icon:"folder-open",class:"folder-icon-svg"})]),(0,i.Lk)("div",wt,[(0,i.Lk)("div",Ft,[(0,i.Lk)("span",Ct,(0,s.v_)(l.folderName),1)]),a.showActions?((0,i.uX)(),(0,i.CE)("div",Tt,[t[9]||(t[9]=(0,i.Lk)("div",{class:"action-bar-left"},null,-1)),(0,i.Lk)("div",xt,[(0,i.bF)(h,{disabled:a.disableTooltip,content:"复制链接",placement:"top"},{default:(0,i.k6)(()=>[(0,i.Lk)("button",{class:"action-btn",onClick:t[3]||(t[3]=(0,n.D$)(t=>e.$emit("copy"),["stop"]))},[(0,i.bF)(d,{icon:"copy"})])]),_:1},8,["disabled"]),(0,i.bF)(h,{disabled:a.disableTooltip,content:"移动",placement:"top"},{default:(0,i.k6)(()=>[(0,i.Lk)("button",{class:"action-btn",onClick:t[4]||(t[4]=(0,n.D$)(t=>e.$emit("move"),["stop"]))},[(0,i.bF)(d,{icon:"file-export"})])]),_:1},8,["disabled"]),(0,i.bF)(h,{disabled:a.disableTooltip,content:"删除",placement:"top"},{default:(0,i.k6)(()=>[(0,i.Lk)("button",{class:"action-btn action-btn-danger",onClick:t[5]||(t[5]=(0,n.D$)(t=>e.$emit("delete"),["stop"]))},[(0,i.bF)(d,{icon:"trash-alt"})])]),_:1},8,["disabled"])])])):(0,i.Q3)("",!0)])]),_:1})}var Lt={name:"FolderCard",props:{name:{type:String,required:!0},selected:{type:Boolean,default:!1},showActions:{type:Boolean,default:!0},disableTooltip:{type:Boolean,default:!1}},emits:["update:selected","enter","copy","move","delete","touchstart","touchend","touchmove"],data(){return{localSelected:this.selected}},computed:{folderName(){const e=this.name.split("/").filter(Boolean);return e[e.length-1]||this.name}},watch:{selected(e){this.localSelected=e}}};const Et=(0,h.A)(Lt,[["render",St],["__scopeId","data-v-20e5d6b4"]]);var At=Et;function It(e,t,a,n,s,r){return"card"===a.type?((0,i.uX)(!0),(0,i.CE)(i.FK,{key:0},(0,i.pI)(a.count,e=>((0,i.uX)(),(0,i.CE)("div",{key:"skeleton-"+e,class:"skeleton-card"},[...t[0]||(t[0]=[(0,i.Lk)("div",{class:"skeleton-image"},null,-1),(0,i.Lk)("div",{class:"skeleton-info"},[(0,i.Lk)("div",{class:"skeleton-text"})],-1)])]))),128)):"list"===a.type?((0,i.uX)(!0),(0,i.CE)(i.FK,{key:1},(0,i.pI)(a.count,e=>((0,i.uX)(),(0,i.CE)("div",{key:"list-skeleton-"+e,class:"list-item skeleton-list-item"},[...t[1]||(t[1]=[(0,i.Fv)('
',10)])]))),128)):(0,i.Q3)("",!0)}var Dt={name:"SkeletonLoader",props:{type:{type:String,default:"card",validator:e=>["card","list"].includes(e)},count:{type:Number,default:15}}};const Ut=(0,h.A)(Dt,[["render",It],["__scopeId","data-v-71848b62"]]);var zt=Ut,Bt=a(1095),Ot=(a(7128),a(2086)),Wt=(a(670),a(8830),a(3597),a(9187),a(5407));a(2099);const $t={class:"el-dropdown-link filter-trigger"},Pt={class:"filter-section"},Rt={class:"filter-options"},Nt={class:"filter-section"},jt={class:"filter-options"},Vt={class:"filter-section"},Mt={class:"filter-options"},Xt={class:"filter-section"},Zt={class:"filter-options"},Kt={class:"filter-section"},Gt={class:"filter-options"},Ht={key:0,class:"filter-section"},qt={class:"filter-options"},Qt={key:0,class:"channel-divider"},Yt={class:"channel-group-title"},Jt={class:"filter-actions"};function ea(e,t,a,n,r,o){const l=(0,i.g2)("font-awesome-icon"),c=Wt.z_,d=at.dI,h=at.o5,u=x.S2,f=Ot.Iy,m=Ot.dW;return(0,i.uX)(),(0,i.Wv)(m,{"hide-on-click":!1,trigger:"click",class:"filter-dropdown",ref:"dropdownRef"},{dropdown:(0,i.k6)(()=>[(0,i.bF)(f,{class:"filter-dropdown-menu"},{default:(0,i.k6)(()=>[(0,i.Lk)("div",Pt,[t[12]||(t[12]=(0,i.Lk)("div",{class:"filter-title"},"访问状态",-1)),(0,i.Lk)("div",Rt,[(0,i.bF)(h,{modelValue:r.localFilters.accessStatus,"onUpdate:modelValue":t[0]||(t[0]=e=>r.localFilters.accessStatus=e),onChange:t[1]||(t[1]=e=>o.handleFilterChange("accessStatus"))},{default:(0,i.k6)(()=>[((0,i.uX)(!0),(0,i.CE)(i.FK,null,(0,i.pI)(r.accessStatusOptions,e=>((0,i.uX)(),(0,i.Wv)(d,{key:"accessStatus-"+e.value,label:e.value},{default:(0,i.k6)(()=>[(0,i.eW)((0,s.v_)(e.label),1)]),_:2},1032,["label"]))),128))]),_:1},8,["modelValue"])])]),(0,i.Lk)("div",Nt,[t[13]||(t[13]=(0,i.Lk)("div",{class:"filter-title"},"黑白名单",-1)),(0,i.Lk)("div",jt,[(0,i.bF)(h,{modelValue:r.localFilters.listType,"onUpdate:modelValue":t[2]||(t[2]=e=>r.localFilters.listType=e),onChange:t[3]||(t[3]=e=>o.handleFilterChange("listType"))},{default:(0,i.k6)(()=>[((0,i.uX)(!0),(0,i.CE)(i.FK,null,(0,i.pI)(r.listTypeOptions,e=>((0,i.uX)(),(0,i.Wv)(d,{key:"listType-"+e.value,label:e.value},{default:(0,i.k6)(()=>[(0,i.eW)((0,s.v_)(e.label),1)]),_:2},1032,["label"]))),128))]),_:1},8,["modelValue"])])]),(0,i.Lk)("div",Vt,[t[14]||(t[14]=(0,i.Lk)("div",{class:"filter-title"},"审查结果",-1)),(0,i.Lk)("div",Mt,[(0,i.bF)(h,{modelValue:r.localFilters.label,"onUpdate:modelValue":t[4]||(t[4]=e=>r.localFilters.label=e),onChange:t[5]||(t[5]=e=>o.handleFilterChange("label"))},{default:(0,i.k6)(()=>[((0,i.uX)(!0),(0,i.CE)(i.FK,null,(0,i.pI)(r.labelOptions,e=>((0,i.uX)(),(0,i.Wv)(d,{key:"label-"+e.value,label:e.value},{default:(0,i.k6)(()=>[(0,i.eW)((0,s.v_)(e.label),1)]),_:2},1032,["label"]))),128))]),_:1},8,["modelValue"])])]),(0,i.Lk)("div",Xt,[t[15]||(t[15]=(0,i.Lk)("div",{class:"filter-title"},"文件类型",-1)),(0,i.Lk)("div",Zt,[(0,i.bF)(h,{modelValue:r.localFilters.fileType,"onUpdate:modelValue":t[6]||(t[6]=e=>r.localFilters.fileType=e),onChange:t[7]||(t[7]=e=>o.handleFilterChange("fileType"))},{default:(0,i.k6)(()=>[((0,i.uX)(!0),(0,i.CE)(i.FK,null,(0,i.pI)(r.fileTypeOptions,e=>((0,i.uX)(),(0,i.Wv)(d,{key:"fileType-"+e.value,label:e.value},{default:(0,i.k6)(()=>[(0,i.eW)((0,s.v_)(e.label),1)]),_:2},1032,["label"]))),128))]),_:1},8,["modelValue"])])]),(0,i.Lk)("div",Kt,[t[16]||(t[16]=(0,i.Lk)("div",{class:"filter-title"},"渠道类型",-1)),(0,i.Lk)("div",Gt,[(0,i.bF)(h,{modelValue:r.localFilters.channel,"onUpdate:modelValue":t[8]||(t[8]=e=>r.localFilters.channel=e),onChange:t[9]||(t[9]=e=>o.handleFilterChange("channel"))},{default:(0,i.k6)(()=>[((0,i.uX)(!0),(0,i.CE)(i.FK,null,(0,i.pI)(r.channelOptions,e=>((0,i.uX)(),(0,i.Wv)(d,{key:"channel-"+e.value,label:e.value},{default:(0,i.k6)(()=>[(0,i.eW)((0,s.v_)(e.label),1)]),_:2},1032,["label"]))),128))]),_:1},8,["modelValue"])])]),a.channelNameOptions.length>0?((0,i.uX)(),(0,i.CE)("div",Ht,[t[17]||(t[17]=(0,i.Lk)("div",{class:"filter-title"},"渠道名称",-1)),(0,i.Lk)("div",qt,[(0,i.bF)(h,{modelValue:r.localFilters.channelName,"onUpdate:modelValue":t[10]||(t[10]=e=>r.localFilters.channelName=e),onChange:t[11]||(t[11]=e=>o.handleFilterChange("channelName"))},{default:(0,i.k6)(()=>[((0,i.uX)(!0),(0,i.CE)(i.FK,null,(0,i.pI)(o.groupedChannelNames,(e,t)=>((0,i.uX)(),(0,i.CE)(i.FK,{key:"group-"+e.type},[t>0?((0,i.uX)(),(0,i.CE)("div",Qt)):(0,i.Q3)("",!0),(0,i.Lk)("div",Yt,(0,s.v_)(e.typeLabel),1),((0,i.uX)(!0),(0,i.CE)(i.FK,null,(0,i.pI)(e.channels,e=>((0,i.uX)(),(0,i.Wv)(d,{key:"channelName-"+e.type+"-"+e.name,label:e.type+":"+e.name},{default:(0,i.k6)(()=>[(0,i.eW)((0,s.v_)(e.name),1)]),_:2},1032,["label"]))),128))],64))),128))]),_:1},8,["modelValue"])])])):(0,i.Q3)("",!0),(0,i.Lk)("div",Jt,[(0,i.bF)(u,{size:"small",onClick:o.clearFilters,disabled:0===o.activeFilterCount},{default:(0,i.k6)(()=>[...t[18]||(t[18]=[(0,i.eW)("清除筛选",-1)])]),_:1},8,["onClick","disabled"])])]),_:1})]),default:(0,i.k6)(()=>[(0,i.Lk)("span",$t,[(0,i.bF)(c,{value:o.activeFilterCount,hidden:0===o.activeFilterCount,class:"filter-badge"},{default:(0,i.k6)(()=>[(0,i.bF)(l,{icon:"filter",class:"header-icon"})]),_:1},8,["value","hidden"])])]),_:1},512)}a(7588),a(8237);var ta={name:"FilterDropdown",props:{filters:{type:Object,default:()=>({accessStatus:[],listType:[],label:[],fileType:[],channel:[],channelName:[]})},channelNameOptions:{type:Array,default:()=>[]}},emits:["update:filters","change"],data(){return{accessStatusOptions:[{label:"正常",value:"normal"},{label:"已屏蔽",value:"blocked"}],listTypeOptions:[{label:"白名单",value:"White"},{label:"黑名单",value:"Block"},{label:"未设置",value:"None"}],labelOptions:[{label:"正常",value:"normal"},{label:"12+内容",value:"teen"},{label:"成人内容",value:"adult"}],fileTypeOptions:[{label:"图片",value:"image"},{label:"视频",value:"video"},{label:"音频",value:"audio"},{label:"其他",value:"other"}],channelOptions:[{label:"Telegram",value:"TelegramNew"},{label:"Cloudflare R2",value:"CloudflareR2"},{label:"S3",value:"S3"},{label:"Discord",value:"Discord"},{label:"HuggingFace",value:"HuggingFace"},{label:"外链",value:"External"}],localFilters:{accessStatus:[],listType:[],label:[],fileType:[],channel:[],channelName:[]}}},computed:{activeFilterCount(){return Object.values(this.localFilters).reduce((e,t)=>e+t.length,0)},groupedChannelNames(){const e={};return this.channelNameOptions.forEach(t=>{e[t.type]||(e[t.type]={type:t.type,typeLabel:t.typeLabel,channels:[]}),e[t.type].channels.push(t)}),Object.values(e)}},watch:{filters:{handler(e){this.localFilters={accessStatus:Array.isArray(e.accessStatus)?[...e.accessStatus]:[],listType:Array.isArray(e.listType)?[...e.listType]:[],label:Array.isArray(e.label)?[...e.label]:[],fileType:Array.isArray(e.fileType)?[...e.fileType]:[],channel:Array.isArray(e.channel)?[...e.channel]:[],channelName:Array.isArray(e.channelName)?[...e.channelName]:[]}},immediate:!0,deep:!0}},methods:{handleFilterChange(e){this.$emit("update:filters",{...this.localFilters}),this.$emit("change",{type:e,filters:{...this.localFilters}})},clearFilters(){this.localFilters={accessStatus:[],listType:[],label:[],fileType:[],channel:[],channelName:[]},this.$emit("update:filters",{...this.localFilters}),this.$emit("change",{type:"clear",filters:{...this.localFilters}})}}};const aa=(0,h.A)(ta,[["render",ea],["__scopeId","data-v-062d5f10"]]);var ia=aa,na=a(6011);const sa={class:"container"},ra={class:"header-content"},oa={class:"search-area"},la={class:"search-card"},ca={class:"actions"},da={class:"el-dropdown-link"},ha={class:"el-dropdown-link"},ua={class:"el-dropdown-link"},fa={class:"breadcrumb-container"},ma={class:"mobile-directory-path"},pa={class:"breadcrumb desktop-only"},ga=["title"],ba={key:0,class:"content"},va={key:1,class:"empty-state"},ka={class:"empty-text"},ya={class:"empty-hint"},_a={key:1,class:"list-view"},wa={class:"list-header"},Fa={class:"list-col list-col-checkbox"},Ca={key:1,class:"empty-state list-empty"},Ta={class:"empty-text"},xa={class:"empty-hint"},Sa={class:"pagination-container"},La={class:"pagination-center"},Ea={class:"pagination-right"},Aa={class:"page-total"},Ia={class:"page-jump"},Da={class:"dialog-section"},Ua={class:"section-content"},za={class:"dialog-section"},Ba={class:"section-header"},Oa={class:"section-content"},Wa={class:"setting-item"},$a={key:0,class:"setting-item"},Pa={class:"dialog-action"};function Ra(e,t,a,r,o,l){const c=na.A,d=(0,i.g2)("font-awesome-icon"),h=T.WK,u=ia,m=Ot.c6,p=Ot.Iy,g=Ot.dW,b=De.R7,v=Ae.bZ,k=Bt.WZ,w=Bt.vp,F=zt,C=At,S=_t,L=et,E=Ie.aQ,A=x.S2,I=Ae.ZO,D=Ae.lX,U=Ee,z=ge.ll,B=ge.MQ,O=pe.qi,W=_.kZ,$=me,P=q,R=y,N=f;return(0,i.uX)(),(0,i.CE)("div",sa,[(0,i.bF)(D,null,{default:(0,i.k6)(()=>[(0,i.bF)(v,null,{default:(0,i.k6)(()=>[(0,i.Lk)("div",ra,[(0,i.bF)(c,{activeTab:"dashboard"}),(0,i.Lk)("div",oa,[(0,i.Lk)("div",la,[(0,i.bF)(h,{modelValue:o.tempSearch,"onUpdate:modelValue":t[0]||(t[0]=e=>o.tempSearch=e),size:"mini",placeholder:"搜索:#标签 -#排除标签",onKeyup:(0,n.jR)(l.handleSearch,["enter"])},{suffix:(0,i.k6)(()=>[(0,i.bF)(d,{icon:"search",class:"search-icon",onClick:l.handleSearch},null,8,["onClick"])]),_:1},8,["modelValue","onKeyup"])]),(0,i.bF)(u,{filters:o.filters,"onUpdate:filters":t[1]||(t[1]=e=>o.filters=e),channelNameOptions:o.channelNameOptions,onChange:l.handleFilterChange},null,8,["filters","channelNameOptions","onChange"])]),(0,i.Lk)("div",ca,[(0,i.bF)(g,{onCommand:l.sort,"hide-on-click":!1},{dropdown:(0,i.k6)(()=>[(0,i.bF)(p,null,{default:(0,i.k6)(()=>[(0,i.bF)(m,{command:"dateDesc"},{default:(0,i.k6)(()=>[...t[22]||(t[22]=[(0,i.eW)("按时间倒序",-1)])]),_:1}),(0,i.bF)(m,{command:"nameAsc"},{default:(0,i.k6)(()=>[...t[23]||(t[23]=[(0,i.eW)("按名称升序",-1)])]),_:1})]),_:1})]),default:(0,i.k6)(()=>[(0,i.Lk)("span",da,[(0,i.bF)(d,{icon:l.sortIcon,class:"header-icon"},null,8,["icon"])])]),_:1},8,["onCommand"]),(0,i.bF)(b,{disabled:l.disableTooltip,content:"全选此页",placement:"bottom"},{default:(0,i.k6)(()=>[(0,i.bF)(d,{icon:l.selectPageIcon,class:"header-icon",onClick:l.handleSelectPage},null,8,["icon","onClick"])]),_:1},8,["disabled"]),(0,i.bF)(g,{onCommand:l.handleBatchAction,"hide-on-click":!1,disabled:0===o.selectedFiles.length},{dropdown:(0,i.k6)(()=>[(0,i.bF)(p,null,{default:(0,i.k6)(()=>[(0,i.bF)(m,{command:"copy"},{default:(0,i.k6)(()=>[(0,i.bF)(d,{icon:"copy",class:"batch-action-item-icon"}),t[24]||(t[24]=(0,i.eW)(" 复制 ",-1))]),_:1}),(0,i.bF)(m,{command:"delete"},{default:(0,i.k6)(()=>[(0,i.bF)(d,{icon:"trash-alt",class:"batch-action-item-icon"}),t[25]||(t[25]=(0,i.eW)(" 删除 ",-1))]),_:1}),(0,i.bF)(m,{command:"download"},{default:(0,i.k6)(()=>[(0,i.bF)(d,{icon:"download",class:"batch-action-item-icon"}),t[26]||(t[26]=(0,i.eW)(" 下载 ",-1))]),_:1}),(0,i.bF)(m,{command:"move"},{default:(0,i.k6)(()=>[(0,i.bF)(d,{icon:"file-export",class:"batch-action-item-icon"}),t[27]||(t[27]=(0,i.eW)(" 移动 ",-1))]),_:1}),(0,i.bF)(m,{command:"tagManagement"},{default:(0,i.k6)(()=>[(0,i.bF)(d,{icon:"tags",class:"batch-action-item-icon"}),t[28]||(t[28]=(0,i.eW)(" 标签管理 ",-1))]),_:1}),(0,i.bF)(m,{command:"ban"},{default:(0,i.k6)(()=>[(0,i.bF)(d,{icon:"ban",class:"batch-action-item-icon"}),t[29]||(t[29]=(0,i.eW)(" 加入黑名单 ",-1))]),_:1}),(0,i.bF)(m,{command:"white"},{default:(0,i.k6)(()=>[(0,i.bF)(d,{icon:"user-plus",class:"batch-action-item-icon"}),t[30]||(t[30]=(0,i.eW)(" 加入白名单 ",-1))]),_:1})]),_:1})]),default:(0,i.k6)(()=>[(0,i.Lk)("span",ha,[(0,i.bF)(d,{icon:"ellipsis-h",class:(0,s.C4)(["header-icon",{disabled:0===o.selectedFiles.length}])},null,8,["class"])])]),_:1},8,["onCommand","disabled"]),(0,i.bF)(b,{disabled:l.disableTooltip,content:"链接格式",placement:"bottom"},{default:(0,i.k6)(()=>[(0,i.Lk)("span",ua,[(0,i.bF)(d,{icon:"link",class:"header-icon",onClick:t[2]||(t[2]=e=>o.showUrlDialog=!0)})])]),_:1},8,["disabled"]),(0,i.bF)(b,{disabled:l.disableTooltip,content:"card"===o.viewMode?"列表视图":"卡片视图",placement:"bottom"},{default:(0,i.k6)(()=>[(0,i.bF)(d,{icon:"card"===o.viewMode?"list":"th-large",class:"header-icon",onClick:l.toggleViewMode},null,8,["icon","onClick"])]),_:1},8,["disabled","content"]),(0,i.bF)(b,{disabled:l.disableTooltip,content:"退出登录",placement:"bottom"},{default:(0,i.k6)(()=>[(0,i.bF)(d,{icon:"sign-out-alt",class:"header-icon",onClick:l.handleLogout},null,8,["onClick"])]),_:1},8,["disabled"])])])]),_:1}),(0,i.bF)(I,{class:"main-container"},{default:(0,i.k6)(()=>[(0,i.Lk)("div",fa,[(0,i.Lk)("div",{class:"mobile-directory-trigger",onClick:t[3]||(t[3]=e=>o.showMobileDirectoryDrawer=!0)},[(0,i.bF)(d,{icon:"folder-open",class:"mobile-directory-icon"}),(0,i.Lk)("span",ma,(0,s.v_)(o.currentPath&&o.currentPath.split("/").filter(Boolean).length>0?o.currentPath.split("/").filter(Boolean).pop():"根目录"),1),(0,i.bF)(d,{icon:"chevron-down",class:"mobile-directory-arrow"})]),(0,i.Lk)("div",pa,[(0,i.bF)(w,{separator:"/"},{default:(0,i.k6)(()=>[(0,i.bF)(k,{onClick:t[4]||(t[4]=e=>l.navigateToFolder(""))},{default:(0,i.k6)(()=>[(0,i.bF)(d,{icon:"home",class:"breadcrumb-home-icon"})]),_:1}),((0,i.uX)(!0),(0,i.CE)(i.FK,null,(0,i.pI)(o.currentPath.split("/").filter(Boolean),(e,t)=>((0,i.uX)(),(0,i.Wv)(k,{key:t,onClick:e=>l.navigateToFolder(o.currentPath.split("/").filter(Boolean).slice(0,t+1).join("/"))},{default:(0,i.k6)(()=>[(0,i.eW)((0,s.v_)(e),1)]),_:2},1032,["onClick"]))),128))]),_:1})]),(0,i.Lk)("span",{class:"stats-badge",title:`共 ${e.$data.Number} 个文件`},[(0,i.bF)(d,{icon:"database",class:"stats-badge-icon"}),(0,i.eW)(" "+(0,s.v_)(o.Number),1)],8,ga)]),"card"===o.viewMode?((0,i.uX)(),(0,i.CE)("div",ba,[o.loading?((0,i.uX)(),(0,i.Wv)(F,{key:0,type:"card",count:15})):0===l.paginatedTableData.length?((0,i.uX)(),(0,i.CE)("div",va,[(0,i.bF)(d,{icon:"folder-open",class:"empty-icon"}),(0,i.Lk)("p",ka,(0,s.v_)(l.hasSearchOrFilter?"未找到匹配的文件或文件夹":"当前目录为空"),1),(0,i.Lk)("p",ya,(0,s.v_)(l.hasSearchOrFilter?"尝试调整搜索条件或筛选器":"上传文件后将显示在这里"),1)])):((0,i.uX)(!0),(0,i.CE)(i.FK,{key:2},(0,i.pI)(l.paginatedTableData,(e,t)=>((0,i.uX)(),(0,i.CE)(i.FK,{key:t},[l.isFolder(e)?((0,i.uX)(),(0,i.Wv)(C,{key:0,name:e.name,selected:e.selected,"onUpdate:selected":t=>e.selected=t,showActions:!o.isSearchMode,disableTooltip:l.disableTooltip,onEnter:t=>l.enterFolder(e.name),onCopy:t=>l.handleFolderCopy(e.name),onMove:a=>l.handleMove(t,e.name),onDelete:a=>l.handleDelete(t,e.name),onTouchstart:a=>l.handleFolderTouchStart(e,t),onTouchend:l.handleTouchEnd,onTouchmove:l.handleTouchEnd},null,8,["name","selected","onUpdate:selected","showActions","disableTooltip","onEnter","onCopy","onMove","onDelete","onTouchstart","onTouchend","onTouchmove"])):((0,i.uX)(),(0,i.Wv)(S,{key:1,item:e,selected:e.selected,"onUpdate:selected":t=>e.selected=t,fileLink:l.getFileLink(e.name),previewSrcList:e.previewSrcList,disableTooltip:l.disableTooltip,onDetail:a=>l.openDetailDialog(t,e.name),onCopy:a=>l.handleCopy(t,e.name),onMove:a=>l.handleMove(t,e.name),onDelete:a=>l.handleDelete(t,e.name),onDownload:t=>l.handleDownload(e.name),onTouchstart:a=>l.handleTouchStart(e,t),onTouchend:l.handleTouchEnd,onTouchmove:l.handleTouchEnd},null,8,["item","selected","onUpdate:selected","fileLink","previewSrcList","disableTooltip","onDetail","onCopy","onMove","onDelete","onDownload","onTouchstart","onTouchend","onTouchmove"]))],64))),128))])):((0,i.uX)(),(0,i.CE)("div",_a,[(0,i.Lk)("div",wa,[(0,i.Lk)("div",Fa,[(0,i.Lk)("span",{class:(0,s.C4)(["custom-checkbox",{checked:l.isSelectAll,indeterminate:l.isIndeterminate}]),onClick:t[5]||(t[5]=e=>l.handleSelectAllPage(!l.isSelectAll))},[l.isSelectAll?((0,i.uX)(),(0,i.Wv)(d,{key:0,icon:"check",class:"check-icon"})):l.isIndeterminate?((0,i.uX)(),(0,i.Wv)(d,{key:1,icon:"minus",class:"check-icon"})):(0,i.Q3)("",!0)],2)]),t[31]||(t[31]=(0,i.Lk)("div",{class:"list-col list-col-preview"},"预览",-1)),t[32]||(t[32]=(0,i.Lk)("div",{class:"list-col list-col-name"},"文件名",-1)),t[33]||(t[33]=(0,i.Lk)("div",{class:"list-col list-col-tags"},"标签",-1)),t[34]||(t[34]=(0,i.Lk)("div",{class:"list-col list-col-channel"},"渠道类型",-1)),t[35]||(t[35]=(0,i.Lk)("div",{class:"list-col list-col-channel-name"},"渠道名称",-1)),t[36]||(t[36]=(0,i.Lk)("div",{class:"list-col list-col-address"},"上传地址",-1)),t[37]||(t[37]=(0,i.Lk)("div",{class:"list-col list-col-size"},"大小",-1)),t[38]||(t[38]=(0,i.Lk)("div",{class:"list-col list-col-date"},"上传时间",-1)),t[39]||(t[39]=(0,i.Lk)("div",{class:"list-col list-col-actions"},"操作",-1))]),o.loading?((0,i.uX)(),(0,i.Wv)(F,{key:0,type:"list",count:15})):0===l.paginatedTableData.length?((0,i.uX)(),(0,i.CE)("div",Ca,[(0,i.bF)(d,{icon:"folder-open",class:"empty-icon"}),(0,i.Lk)("p",Ta,(0,s.v_)(l.hasSearchOrFilter?"未找到匹配的文件或文件夹":"当前目录为空"),1),(0,i.Lk)("p",xa,(0,s.v_)(l.hasSearchOrFilter?"尝试调整搜索条件或筛选器":"上传文件后将显示在这里"),1)])):((0,i.uX)(!0),(0,i.CE)(i.FK,{key:2},(0,i.pI)(l.paginatedTableData,(e,t)=>((0,i.uX)(),(0,i.Wv)(L,{key:t,item:e,selected:e.selected,"onUpdate:selected":t=>e.selected=t,fileLink:l.getFileLink(e.name),onEnter:t=>l.enterFolder(e.name),onDetail:a=>l.openDetailDialog(t,e.name),onCopy:a=>l.handleCopy(t,e.name),onFolderCopy:t=>l.handleFolderCopy(e.name),onMove:a=>l.handleMove(t,e.name),onDelete:a=>l.handleDelete(t,e.name),onDownload:t=>l.handleDownload(e.name),onTouchstart:a=>l.isFolder(e)?l.handleFolderTouchStart(e,t):l.handleTouchStart(e,t),onTouchend:l.handleTouchEnd,onTouchmove:l.handleTouchEnd},null,8,["item","selected","onUpdate:selected","fileLink","onEnter","onDetail","onCopy","onFolderCopy","onMove","onDelete","onDownload","onTouchstart","onTouchend","onTouchmove"]))),128))])),(0,i.Lk)("div",Sa,[(0,i.Lk)("div",La,[(0,i.bF)(E,{background:"",layout:"prev, pager, next",total:l.filteredTableData.length,"page-size":o.pageSize,"current-page":o.currentPage,"pager-count":l.pagerCount,onCurrentChange:l.handlePageChange},null,8,["total","page-size","current-page","pager-count","onCurrentChange"]),(0,i.bF)(A,{type:"primary",onClick:l.refreshFileList,class:"refresh-btn"},{default:(0,i.k6)(()=>[(0,i.bF)(d,{icon:"sync",class:(0,s.C4)({"fa-spin":o.refreshLoading})},null,8,["class"])]),_:1},8,["onClick"]),o.currentPage===Math.ceil(l.filteredTableData.length/o.pageSize)?((0,i.uX)(),(0,i.Wv)(A,{key:0,type:"primary",onClick:l.loadMoreData,loading:o.loading,class:"load-more"},{default:(0,i.k6)(()=>[...t[40]||(t[40]=[(0,i.eW)(" 加载更多 ",-1)])]),_:1},8,["onClick","loading"])):(0,i.Q3)("",!0)]),(0,i.Lk)("div",Ea,[(0,i.Lk)("span",Aa,"共 "+(0,s.v_)(l.realTotalPages)+" 页",1),(0,i.Lk)("div",Ia,[t[42]||(t[42]=(0,i.Lk)("span",null,"跳至",-1)),(0,i.bF)(h,{modelValue:o.jumpPage,"onUpdate:modelValue":t[6]||(t[6]=e=>o.jumpPage=e),size:"small",class:"jump-input",onKeyup:(0,n.jR)(l.handleJumpPage,["enter"])},null,8,["modelValue","onKeyup"]),(0,i.bF)(A,{size:"small",type:"primary",onClick:l.handleJumpPage,class:"jump-btn"},{default:(0,i.k6)(()=>[...t[41]||(t[41]=[(0,i.eW)("GO",-1)])]),_:1},8,["onClick"])])])])]),_:1})]),_:1}),(0,i.bF)(U,{modelValue:o.showdetailDialog,"onUpdate:modelValue":t[7]||(t[7]=e=>o.showdetailDialog=e),file:o.detailFile,fileLink:l.getFileLink(o.detailFile?.name),urls:l.allUrl,onDownload:t[8]||(t[8]=e=>l.handleDownload(o.detailFile?.name)),onTagManagement:t[9]||(t[9]=e=>l.handleTagManagement(o.detailFile?.name)),onBlock:t[10]||(t[10]=e=>l.handleBlock(o.detailFile?.name)),onWhite:t[11]||(t[11]=e=>l.handleWhite(o.detailFile?.name)),onDelete:t[12]||(t[12]=e=>l.handleDetailDelete(o.detailFile?.name))},null,8,["modelValue","file","fileLink","urls"]),(0,i.bF)(W,{title:"链接格式",modelValue:o.showUrlDialog,"onUpdate:modelValue":t[17]||(t[17]=e=>o.showUrlDialog=e),width:l.dialogWidth,"show-close":!1,class:"settings-dialog"},{default:(0,i.k6)(()=>[(0,i.Lk)("div",Da,[t[49]||(t[49]=(0,i.Lk)("div",{class:"section-header"},[(0,i.Lk)("span",{class:"section-title"},"默认复制链接")],-1)),(0,i.Lk)("div",Ua,[(0,i.bF)(B,{modelValue:o.defaultUrlFormat,"onUpdate:modelValue":t[13]||(t[13]=e=>o.defaultUrlFormat=e),class:"radio-card-group grid-2x2"},{default:(0,i.k6)(()=>[(0,i.bF)(z,{label:"originUrl",class:"radio-card"},{default:(0,i.k6)(()=>[(0,i.bF)(d,{icon:"link",class:"radio-icon"}),t[43]||(t[43]=(0,i.Lk)("span",null,"原始链接",-1))]),_:1}),(0,i.bF)(z,{label:"mdUrl",class:"radio-card"},{default:(0,i.k6)(()=>[(0,i.bF)(d,{icon:"code",class:"radio-icon"}),t[44]||(t[44]=(0,i.Lk)("span",null,"Markdown",-1))]),_:1}),(0,i.bF)(z,{label:"htmlUrl",class:"radio-card"},{default:(0,i.k6)(()=>[(0,i.bF)(d,{icon:"code-branch",class:"radio-icon"}),t[45]||(t[45]=(0,i.Lk)("span",null,"HTML",-1))]),_:1}),(0,i.bF)(z,{label:"bbUrl",class:"radio-card"},{default:(0,i.k6)(()=>[(0,i.bF)(d,{icon:"quote-right",class:"radio-icon"}),t[46]||(t[46]=(0,i.Lk)("span",null,"BBCode",-1))]),_:1}),(0,i.bF)(z,{label:"tgId",class:"radio-card"},{default:(0,i.k6)(()=>[(0,i.bF)(d,{icon:"paper-plane",class:"radio-icon"}),t[47]||(t[47]=(0,i.Lk)("span",null,"TG File ID",-1))]),_:1}),(0,i.bF)(z,{label:"s3Location",class:"radio-card"},{default:(0,i.k6)(()=>[(0,i.bF)(d,{icon:"cloud",class:"radio-icon"}),t[48]||(t[48]=(0,i.Lk)("span",null,"S3链接",-1))]),_:1})]),_:1},8,["modelValue"])])]),(0,i.Lk)("div",za,[(0,i.Lk)("div",Ba,[t[50]||(t[50]=(0,i.Lk)("span",{class:"section-title"},"自定义链接",-1)),(0,i.bF)(b,{content:"默认链接为https://your.domain/file/xxx.jpg
如果启用自定义链接格式,只保留xxx.jpg部分,其他部分请自行输入",placement:"top","raw-content":""},{default:(0,i.k6)(()=>[(0,i.bF)(d,{icon:"question-circle",class:"section-help-icon"})]),_:1})]),(0,i.Lk)("div",Oa,[(0,i.Lk)("div",Wa,[t[51]||(t[51]=(0,i.Lk)("span",{class:"setting-label"},"启用自定义",-1)),(0,i.bF)(O,{modelValue:o.useCustomUrl,"onUpdate:modelValue":t[14]||(t[14]=e=>o.useCustomUrl=e),"active-value":"true","inactive-value":"false"},null,8,["modelValue"])]),"true"===o.useCustomUrl?((0,i.uX)(),(0,i.CE)("div",$a,[t[52]||(t[52]=(0,i.Lk)("span",{class:"setting-label"},"自定义前缀",-1)),(0,i.bF)(h,{modelValue:o.customUrlPrefix,"onUpdate:modelValue":t[15]||(t[15]=e=>o.customUrlPrefix=e),placeholder:"请输入自定义链接前缀",class:"setting-input"},null,8,["modelValue"])])):(0,i.Q3)("",!0)])]),(0,i.Lk)("div",Pa,[(0,i.bF)(A,{type:"primary",onClick:t[16]||(t[16]=e=>o.showUrlDialog=!1),class:"confirm-btn"},{default:(0,i.k6)(()=>[...t[53]||(t[53]=[(0,i.eW)("确定",-1)])]),_:1})])]),_:1},8,["modelValue","width"]),(0,i.bF)($,{modelValue:o.showTagDialog,"onUpdate:modelValue":t[18]||(t[18]=e=>o.showTagDialog=e),fileId:o.currentTagFile,onTagsUpdated:l.handleTagsUpdated},null,8,["modelValue","fileId","onTagsUpdated"]),(0,i.bF)(P,{modelValue:o.showBatchTagDialog,"onUpdate:modelValue":t[19]||(t[19]=e=>o.showBatchTagDialog=e),selectedFiles:o.selectedFiles,onTagsUpdated:l.handleBatchTagsUpdated},null,8,["modelValue","selectedFiles","onTagsUpdated"]),(0,i.bF)(R,{modelValue:o.showMobileActionModal,"onUpdate:modelValue":t[20]||(t[20]=e=>o.showMobileActionModal=e),title:o.mobileActionIsFolder?l.getFolderName(o.mobileActionFile?.name||""):o.mobileActionFile?.metadata?.FileName||l.getFileName(o.mobileActionFile?.name||""),isFolder:o.mobileActionIsFolder,onAction:l.handleMobileAction},null,8,["modelValue","title","isFolder","onAction"]),(0,i.bF)(N,{modelValue:o.showMobileDirectoryDrawer,"onUpdate:modelValue":t[21]||(t[21]=e=>o.showMobileDirectoryDrawer=e),currentPath:o.currentPath,onNavigate:l.navigateToFolder,onGoBack:l.handleGoBack},null,8,["modelValue","currentPath","onNavigate","onGoBack"])])}a(1148),a(116),a(3579),a(7642),a(8004),a(3853),a(5876),a(2475),a(5024),a(1698),a(4603),a(7566),a(8721);var Na=a(8401),ja=a(4813),Va=a.n(ja);a(8335);class Ma{constructor(){this.FILE_LIST_PATH="data/fileList.json"}getLocalFileList(){try{const e=localStorage.getItem(this.FILE_LIST_PATH);return e?JSON.parse(e):{files:[],directories:[]}}catch(e){return console.error("Error reading local file list:",e),{files:[],directories:[]}}}saveFileList(e){try{return localStorage.setItem(this.FILE_LIST_PATH,JSON.stringify(e)),!0}catch(t){return console.error("Error saving file list:",t),!1}}addFile(e){try{const t=this.getLocalFileList();return t.files.push(e),this.saveFileList(t)}catch(t){return console.error("Error adding file:",t),!1}}addFolder(e){try{const t=this.getLocalFileList();return!t.directories.includes(e)&&(t.directories.push(e),this.saveFileList(t))}catch(t){return console.error("Error adding folder:",t),!1}}moveFile(e,t,a=!1,i=""){try{let n=this.getLocalFileList();if(a){const t=n.directories.indexOf(e);-1!==t&&n.directories.splice(t,1)}else{const t=n.files.findIndex(t=>t.name===e);-1!==t&&n.files.splice(t,1)}if(t.startsWith(i)){const e=t.substring(i.length).split("/");if(e.length>1){const t=i+e[0];n.directories.includes(t)||n.directories.push(t)}}return this.saveFileList(n)}catch(n){return console.error("Error moving file:",n),!1}}removeFile(e){try{let t=this.getLocalFileList();return t.files=t.files.filter(t=>t.name!==e),this.saveFileList(t)}catch(t){return console.error("Error removing file:",t),!1}}removeFolder(e){try{let t=this.getLocalFileList();return t.files=t.files.filter(t=>!t.name.startsWith(e+"/")),t.directories=t.directories.filter(t=>t!==e),this.saveFileList(t)}catch(t){return console.error("Error removing folder:",t),!1}}getFilesInFolder(e){try{const t=this.getLocalFileList(),a=t.files.filter(t=>t.name.startsWith(e+"/")),i=t.directories.filter(t=>t.startsWith(e+"/"));return{files:a,directories:i}}catch(t){return console.error("Error getting files in folder:",t),{files:[],directories:[]}}}buildFilterParams(e){let t="";return e.accessStatus&&e.accessStatus.length>0&&(t+=`&accessStatus=${encodeURIComponent(e.accessStatus.join(","))}`),e.listType&&e.listType.length>0&&(t+=`&listType=${encodeURIComponent(e.listType.join(","))}`),e.label&&e.label.length>0&&(t+=`&label=${encodeURIComponent(e.label.join(","))}`),e.fileType&&e.fileType.length>0&&(t+=`&fileType=${encodeURIComponent(e.fileType.join(","))}`),e.channel&&e.channel.length>0&&(t+=`&channel=${encodeURIComponent(e.channel.join(","))}`),e.channelName&&e.channelName.length>0&&(t+=`&channelName=${encodeURIComponent(e.channelName.join(","))}`),t}async refreshFileList(e,t="",a="",i="",n={}){t=t.trim();try{let s=`/api/manage/list?count=60&dir=${e}&search=${encodeURIComponent(t)}`;a&&(s+=`&includeTags=${encodeURIComponent(a)}`),i&&(s+=`&excludeTags=${encodeURIComponent(i)}`),s+=this.buildFilterParams(n);const r=await(0,K.A)(s,{method:"GET"}),o=await r.json();return o.isIndexedResponse||X.nk.warning("索引构建中,当前搜索和排序结果可能不准确,请稍后再试。"),this.saveFileList(o)}catch(s){return console.error("Error refreshing file list:",s),!1}}async loadMoreFiles(e,t="",a="",i="",n=60,s={}){t=t.trim();try{const r=this.getLocalFileList(),o=r.files.length;let l=`/api/manage/list?dir=${e}&start=${o}&count=${n}&search=${encodeURIComponent(t)}`;a&&(l+=`&includeTags=${encodeURIComponent(a)}`),i&&(l+=`&excludeTags=${encodeURIComponent(i)}`),l+=this.buildFilterParams(s);const c=await(0,K.A)(l,{method:"GET"}),d=await c.json();return r.files.push(...d.files),this.saveFileList(r)}catch(r){return console.error("Error loading more files:",r),{files:[],directories:[]}}}}const Xa=new Ma;var Za=a(2388),Ka={data(){return{Number:0,directFileCount:0,directFolderCount:0,showLogoutButton:!1,tableData:[],tempSearch:"",search:"",searchKeywords:"",searchIncludeTags:"",searchExcludeTags:"",isSearchMode:!1,currentPage:1,pageSize:15,selectedFiles:[],sortOption:"dateDesc",isUploading:!1,showdetailDialog:!1,detailFile:null,activeUrlTab:"originUrl",defaultUrlFormat:"originUrl",showUrlDialog:!1,useCustomUrl:"false",customUrlPrefix:"",loading:!1,currentPath:"",refreshLoading:!1,showTagDialog:!1,showBatchTagDialog:!1,currentTagFile:"",viewMode:"card",showMobileActionModal:!1,mobileActionFile:null,mobileActionIndex:-1,mobileActionIsFolder:!1,longPressTimer:null,showMobileDirectoryDrawer:!1,jumpPage:"",filters:{accessStatus:[],listType:[],label:[],fileType:[],channel:[],channelName:[]},channelNameOptions:[]}},components:{DashboardTabs:na.A,TagManagementDialog:me,BatchTagDialog:q,SkeletonLoader:zt,FileCard:_t,FolderCard:At,FileListItem:et,FileDetailDialog:Ee,MobileActionSheet:y,MobileDirectoryDrawer:f,FilterDropdown:ia},computed:{...(0,Na.L8)(["adminUrlSettings","userConfig"]),filteredTableData(){return this.tableData},totalPages(){return Math.ceil(this.filteredTableData.length/this.pageSize)||1},realTotalPages(){const e=this.directFolderCount+this.directFileCount;return Math.ceil(e/this.pageSize)||1},activeFilterCount(){return Object.values(this.filters).reduce((e,t)=>e+(Array.isArray(t)?t.length:0),0)},hasSearchOrFilter(){return this.isSearchMode||this.activeFilterCount>0},paginatedTableData(){const e=this.sortData(this.filteredTableData),t=(this.currentPage-1)*this.pageSize,a=t+this.pageSize;let i=e.slice(t,a);const n=i.filter(e=>this.isImage(e)).map(e=>this.getFileLink(e.name));return i.forEach(e=>{this.isImage(e)&&(e.previewSrcList=n.slice(n.indexOf(this.getFileLink(e.name))).concat(n.slice(0,n.indexOf(this.getFileLink(e.name)))))}),i.forEach(e=>{"TelegramNew"===e.metadata?.Channel?e.channelTag="TG":"CloudflareR2"===e.metadata?.Channel?e.channelTag="R2":"S3"===e.metadata?.Channel?e.channelTag="S3":"Discord"===e.metadata?.Channel?e.channelTag="DC":"HuggingFace"===e.metadata?.Channel?e.channelTag="HF":"External"===e.metadata?.Channel?e.channelTag="外链":e.channelTag="未知"}),i},sortIcon(){return"dateDesc"===this.sortOption?"sort-amount-down":"sort-alpha-up"},dialogWidth(){return window.innerWidth>768?"50%":"90%"},detailDialogWidth(){return window.innerWidth>768?"70%":"90%"},accessType(){return"White"===this.detailFile?.metadata?.ListType?"正常":"Block"===this.detailFile?.metadata?.ListType||"adult"===this.detailFile?.metadata?.Label?"受限":"正常"},allUrl(){return"External"===this.detailFile?.metadata?.Channel?{originUrl:`${this.detailFile?.metadata?.ExternalLink}`,mdUrl:`![${this.detailFile?.metadata?.FileName||this.detailFile?.name}](${this.detailFile?.metadata?.ExternalLink})`,htmlUrl:`${this.detailFile?.metadata?.FileName||this.detailFile?.name}`,bbUrl:`[img]${this.detailFile?.metadata?.ExternalLink}[/img]`,tgId:this.detailFile?.metadata?.TgFileId||"未知",S3Location:this.detailFile?.metadata?.S3Location||"未知",S3CdnFileUrl:this.detailFile?.metadata?.S3CdnFileUrl||"未知"}:{originUrl:`${this.rootUrl}${this.detailFile?.name}`,mdUrl:`![${this.detailFile?.metadata?.FileName||this.detailFile?.name}](${this.rootUrl}${this.detailFile?.name})`,htmlUrl:`${this.detailFile?.metadata?.FileName||this.detailFile?.name}`,bbUrl:`[img]${this.rootUrl}${this.detailFile?.name}[/img]`,tgId:this.detailFile?.metadata?.TgFileId||"未知",S3Location:this.detailFile?.metadata?.S3Location||"未知",S3CdnFileUrl:this.detailFile?.metadata?.S3CdnFileUrl||"未知"}},tableColumnNum(){return window.innerWidth>768?3:1},tablePreviewSpan(){return window.innerWidth>768?2:1},disableTooltip(){return window.innerWidth<768},selectPage(){return this.paginatedTableData.every(e=>e.selected)},selectedPageFiles(){return this.paginatedTableData.some(e=>e.selected)},selectPageIcon(){return this.selectPage?"check-square":this.selectedPageFiles?"minus-square":"square"},rootUrl(){return"true"===this.useCustomUrl?this.customUrlPrefix:this.userConfig?.urlPrefix||`${document.location.origin}/file/`},isSelectAll:{get(){return this.paginatedTableData.length>0&&this.paginatedTableData.every(e=>e.selected)},set(e){this.paginatedTableData.forEach(t=>t.selected=e)}},isIndeterminate(){const e=this.paginatedTableData.filter(e=>e.selected).length;return e>0&&ee.selected&&!this.selectedFiles.includes(e))),this.selectedFiles=this.selectedFiles.filter(e=>e.selected),this.selectedFiles=this.selectedFiles.filter(t=>e.includes(t))},deep:!0},sortOption(e){localStorage.setItem("sortOption",e)},defaultUrlFormat(e){localStorage.setItem("defaultUrlFormat",e)},showdetailDialog(e){e&&(this.activeUrlTab=this.defaultUrlFormat||"originUrl")},customUrlPrefix(e){this.$store.commit("setAdminUrlSettings",{key:"customUrlPrefix",value:e})},useCustomUrl(e){this.$store.commit("setAdminUrlSettings",{key:"useCustomUrl",value:e})},currentPath(e){this.tableData.forEach(e=>e.selected=!1)}},methods:{toggleViewMode(){this.viewMode="card"===this.viewMode?"list":"card",localStorage.setItem("viewMode",this.viewMode)},handleSelectAllPage(e){this.paginatedTableData.forEach(t=>t.selected=e)},handleTouchStart(e,t){this.longPressTimer=setTimeout(()=>{this.mobileActionFile=e,this.mobileActionIndex=t,this.mobileActionIsFolder=!1,this.showMobileActionModal=!0},500)},handleTouchEnd(){this.longPressTimer&&(clearTimeout(this.longPressTimer),this.longPressTimer=null)},handleFolderTouchStart(e,t){this.longPressTimer=setTimeout(()=>{this.mobileActionFile=e,this.mobileActionIndex=t,this.mobileActionIsFolder=!0,this.showMobileActionModal=!0},500)},handleMobileAction(e){const t=this.mobileActionFile,a=this.mobileActionIndex;if(this.showMobileActionModal=!1,t)switch(e){case"detail":this.openDetailDialog(a,t.name);break;case"copy":this.handleCopy(a,t.name);break;case"folderCopy":this.handleFolderCopy(t.name);break;case"download":this.handleDownload(t.name);break;case"move":this.handleMove(a,t.name);break;case"delete":this.handleDelete(a,t.name);break;case"tag":this.handleTagManagement(t.name);break}},handleGoBack(){const e=this.currentPath.split("/").filter(Boolean);if(e.length>0){e.pop();const t=e.join("/");this.navigateToFolder(t)}this.showMobileDirectoryDrawer=!1},getTagColor(e){const t=["linear-gradient(135deg, #667eea 0%, #764ba2 100%)","linear-gradient(135deg, #f093fb 0%, #f5576c 100%)","linear-gradient(135deg, #4facfe 0%, #00f2fe 100%)","linear-gradient(135deg, #43e97b 0%, #38f9d7 100%)","linear-gradient(135deg, #fa709a 0%, #fee140 100%)","linear-gradient(135deg, #a8edea 0%, #fed6e3 100%)"];return t[e%t.length]},handleVideoHover(e,t){const a=e.target;t?a.play().catch(()=>{}):(a.pause(),a.currentTime=0)},formatFileSize(e){if(!e||0===e)return"-";if(e=Number(e),isNaN(e))return"-";const t=["B","KB","MB","GB","TB"];let a=0;while(e>=1024&&a0?1:0)+" "+t[a]},handleSearch(){if(this.search=this.tempSearch,this.isSearchMode=""!==this.search.trim(),this.currentPage=1,this.search&&this.search.trim()){const e=[],t=[];let a=this.search;const i=/-#([\w\u4e00-\u9fa5\u3040-\u309f\u30a0-\u30ff\uac00-\ud7af\.\+\-]+)/g;a=a.replace(i,(e,a)=>(t.push(a.toLowerCase())," "));const n=/#([\w\u4e00-\u9fa5\u3040-\u309f\u30a0-\u30ff\uac00-\ud7af\.\+\-]+)/g;a=a.replace(n,(t,a)=>(e.push(a.toLowerCase())," ")),this.searchKeywords=a.replace(/\s+/g," ").trim(),this.searchIncludeTags=e.join(","),this.searchExcludeTags=t.join(","),console.log("Search keywords:",this.searchKeywords),console.log("Include tags:",this.searchIncludeTags),console.log("Exclude tags:",this.searchExcludeTags)}else this.searchKeywords="",this.searchIncludeTags="",this.searchExcludeTags="";this.refreshFileList()},handleFilterChange({type:e,filters:t}){this.filters=t,this.currentPage=1,this.refreshFileList()},clearFilters(){this.filters={listType:[],label:[],fileType:[],channel:[],channelName:[]},this.currentPage=1,this.refreshFileList()},async extractChannelNames(){try{const e=await(0,K.A)("/api/channels?includeDisabled=true",{method:"GET"});if(e.ok){const t=await e.json(),a=[],i={TelegramNew:"Telegram",CloudflareR2:"Cloudflare R2",S3:"S3",Discord:"Discord",HuggingFace:"HuggingFace"};Object.entries(t).forEach(([e,t])=>{Array.isArray(t)&&t.length>0&&t.forEach(e=>{e.name&&a.push({name:e.name,type:e.type,typeLabel:i[e.type]||e.type,value:`${e.type}:${e.name}`})})}),a.sort((e,t)=>e.type!==t.type?e.type.localeCompare(t.type):e.name.localeCompare(t.name)),this.channelNameOptions=a}}catch(e){console.error("Failed to fetch channel names:",e)}},handleDownload(e){const t=document.createElement("a");t.href=this.getFileLink(e),t.download=e,t.click()},openDetailDialog(e,t){this.detailFile=this.paginatedTableData[e],this.showdetailDialog=!0},handleTabClick(e){this.activeUrlTab=e.props.name},handleUrlClick(e){navigator.clipboard.writeText(e.target.value).then(()=>{this.$message({type:"success",message:"复制成功"})}).catch(()=>{this.$message({type:"error",message:"复制失败"})})},handleDetailDelete(e){this.$confirm("此操作将永久删除该文件, 是否继续?","提示",{confirmButtonText:"确定",cancelButtonText:"取消",type:"warning"}).then(()=>{(0,K.A)(`/api/manage/delete/${e}`,{method:"GET"}).then(t=>{if(!t.ok)return Promise.reject("请求失败");{const t=this.tableData.findIndex(t=>t.name===e);-1!==t&&this.tableData.splice(t,1)}}).then(()=>{this.updateStats(-1,!1),this.$message.success("删除成功"),this.showdetailDialog=!1}).catch(()=>this.$message.error("删除失败"))}).catch(()=>console.log("已取消删除"))},handleBlock(e){this.$confirm("此操作将把该文件加入黑名单, 是否继续?","提示",{confirmButtonText:"确定",cancelButtonText:"取消",type:"warning"}).then(()=>{(0,K.A)(`/api/manage/block/${e}`,{method:"GET"}).then(t=>{if(!t.ok)return Promise.reject("请求失败");{const t=this.tableData.findIndex(t=>t.name===e);-1!==t&&(this.tableData[t].metadata.ListType="Block")}}).then(()=>{this.$message.success("加入黑名单成功")}).catch(()=>this.$message.error("加入黑名单失败"))}).catch(()=>console.log("已取消加入黑名单"))},handleWhite(e){this.$confirm("此操作将把该文件加入白名单, 是否继续?","提示",{confirmButtonText:"确定",cancelButtonText:"取消",type:"warning"}).then(()=>{(0,K.A)(`/api/manage/white/${e}`,{method:"GET"}).then(t=>{if(!t.ok)return Promise.reject("请求失败");{const t=this.tableData.findIndex(t=>t.name===e);-1!==t&&(this.tableData[t].metadata.ListType="White")}}).then(()=>{this.$message.success("加入白名单成功")}).catch(()=>this.$message.error("加入白名单失败"))}).catch(()=>console.log("已取消加入白名单"))},handleDelete(e,t){const a=this.tableData.find(e=>e.name===t).isFolder;this.$confirm(`此操作将永久删除${a?"文件夹":"该文件"}, 是否继续?`,"提示",{confirmButtonText:"确定",cancelButtonText:"取消",type:"warning"}).then(()=>{(0,K.A)(`/api/manage/delete/${t}?folder=${a}`,{method:"GET"}).then(e=>{if(!e.ok)return Promise.reject("请求失败");{const e=this.tableData.findIndex(e=>e.name===t);-1!==e&&this.tableData.splice(e,1)}}).then(()=>{this.updateStats(-1,!1),Xa.removeFile(t),this.$message.success("删除成功")}).catch(()=>this.$message.error("删除失败"))}).catch(()=>console.log("已取消删除"))},handleBatchDelete(){this.$confirm("此操作将永久删除选中的文件及文件夹, 是否继续?","提示",{confirmButtonText:"确定",cancelButtonText:"取消",type:"warning"}).then(()=>{const e=this.selectedFiles.map(e=>{const t=e.isFolder;return(0,K.A)(`/api/manage/delete/${e.name}?folder=${t}`,{method:"GET"})});Promise.all(e).then(e=>{let t=0;e.forEach((e,a)=>{if(e.ok){t++;const e=this.tableData.findIndex(e=>e.name===this.selectedFiles[a].name);-1!==e&&this.tableData.splice(e,1),Xa.removeFile(this.selectedFiles[a].name)}}),this.selectedFiles=[],this.updateStats(-t,!1),this.$message.success("批量删除成功")}).catch(()=>this.$message.error("批量删除失败"))}).catch(()=>console.log("已取消批量删除"))},async handleBatchCopy(){const e=this.selectedFiles.filter(e=>!e.isFolder),t=this.selectedFiles.filter(e=>e.isFolder);let a=null;t.length>0&&(a=this.$loading({lock:!0,text:"正在获取文件列表..."}));try{let n=[...e];for(const e of t)try{const t=await(0,K.A)(`/api/manage/list?dir=${encodeURIComponent(e.name)}&recursive=true&count=-1`,{method:"GET"}),a=await t.json();a.files&&a.files.length>0&&(n=n.concat(a.files))}catch(i){console.error(`获取文件夹 ${e.name} 内容失败:`,i)}if(a&&a.close(),0===n.length)return void this.$message.warning("没有可复制的链接");const s=n.map(e=>this.generateFileLink(e.name,e.metadata)).filter(e=>e);if(0===s.length)return void this.$message.warning("没有可复制的链接");const r=s.join("\n");navigator.clipboard?(await navigator.clipboard.writeText(r),this.$message.success(`批量复制 ${s.length} 个链接成功`)):this.copyToClipboardFallback(r)}catch(i){a&&a.close(),console.error("批量复制链接失败:",i),this.$message.error("批量复制链接失败,请重试")}},copyToClipboardFallback(e){const t=document.createElement("textarea");document.body.appendChild(t),t.style.position="fixed",t.style.clip="rect(0 0 0 0)",t.style.top="10px",t.value=e,t.select(),document.execCommand("copy"),document.body.removeChild(t),this.$message.success("批量复制链接成功")},handleCopy(e,t){let a="";if("External"===this.paginatedTableData[e].metadata?.Channel)switch(this.defaultUrlFormat){case"originUrl":a=this.paginatedTableData[e].metadata?.ExternalLink;break;case"mdUrl":a=`![${this.paginatedTableData[e].metadata?.FileName||t}](${this.paginatedTableData[e].metadata?.ExternalLink})`;break;case"htmlUrl":a=`${this.paginatedTableData[e].metadata?.FileName||t}`;break;case"bbUrl":a=`[img]${this.paginatedTableData[e].metadata?.ExternalLink}[/img]`;break;case"tgId":a=this.paginatedTableData[e].metadata?.TgFileId||"none";break;case"s3Location":a=this.paginatedTableData[e].metadata?.S3Location||"none";break}else switch(this.defaultUrlFormat){case"originUrl":a=`${this.rootUrl}${t}`;break;case"mdUrl":a=`![${this.paginatedTableData[e].metadata?.FileName||t}](${this.rootUrl}${t})`;break;case"htmlUrl":a=`${this.paginatedTableData[e].metadata?.FileName||t}`;break;case"bbUrl":a=`[img]${this.rootUrl}${t}[/img]`;break;case"tgId":a=this.paginatedTableData[e].metadata?.TgFileId||"none";break;case"s3Location":a=this.paginatedTableData[e].metadata?.S3Location||"none";break}navigator.clipboard?navigator.clipboard.writeText(a).then(()=>this.$message.success("复制文件链接成功")):this.copyToClipboardFallback(a)},async loadMoreData(){this.loading=!0;try{await Xa.loadMoreFiles(this.currentPath,this.searchKeywords,this.searchIncludeTags,this.searchExcludeTags,60,this.filters),await this.fetchFileList()}catch(e){this.$message.error("加载更多文件失败,请检查网络连接")}finally{this.loading=!1}},updateStats(e,t=!1){t?this.Number=e:this.Number+=e},sort(e){this.sortOption=e},sortData(e){const t=e.filter(e=>e.isFolder),a=e.filter(e=>!e.isFolder);return"dateDesc"===this.sortOption?(t.sort((e,t)=>new Date(t.metadata?.TimeStamp)-new Date(e.metadata?.TimeStamp)),a.sort((e,t)=>new Date(t.metadata?.TimeStamp)-new Date(e.metadata?.TimeStamp))):(t.sort((e,t)=>e.name.localeCompare(t.name)),a.sort((e,t)=>e.name.localeCompare(t.name))),t.concat(a)},handleVideoClick(e){const t=e.target;t.requestFullscreen?t.requestFullscreen():t.webkitRequestFullscreen?t.webkitRequestFullscreen():t.mozRequestFullScreen?t.mozRequestFullScreen():t.msRequestFullscreen&&t.msRequestFullscreen()},handleLogout(){this.$store.commit("setCredentials",null),this.$router.push("/adminLogin")},handleSelectPage(){this.selectPage?this.paginatedTableData.forEach(e=>e.selected=!1):this.paginatedTableData.forEach(e=>e.selected=!0)},handleBatchAction(e){"copy"===e?this.handleBatchCopy():"delete"===e?this.handleBatchDelete():"download"===e?this.handleBatchDownload():"move"===e?this.handleBatchMove():"tagManagement"===e?this.handleBatchTagManagement():"ban"===e?this.handleBatchBlock():"white"===e&&this.handleBatchWhite()},handleMove(e,t){this.$prompt("请输入新的目录","移动文件",{confirmButtonText:"确定",cancelButtonText:"取消",inputValue:"/",beforeClose:(e,t,a)=>{if("confirm"===e){const e=t.inputValue,i=(0,Za.G)(e);if(!i.valid)return void this.$message.error(i.error);a()}else a()}}).then(({value:e})=>{const a=e.replace(/^\/+/,"")+(e.endsWith("/")||""===e?"":"/"),i=this.tableData.find(e=>e.name===t).isFolder;a!==this.currentPath?(0,K.A)(`/api/manage/move/${t}?folder=${i}&dist=${a}`,{method:"GET"}).then(e=>{if(!e.ok)return Promise.reject("请求失败");{const e=this.tableData.findIndex(e=>e.name===t);if(-1!==e){const n=a+t.split("/").pop();Xa.moveFile(t,n,i,this.currentPath),this.tableData.splice(e,1),this.$nextTick(()=>{const e=[...this.tableData];this.tableData=[],this.$nextTick(()=>{this.tableData=e})})}this.updateStats(-1,!1),this.$message.success("移动成功")}}).then(()=>{this.refreshLocalFileList()}).catch(()=>this.$message.error("移动失败")):this.$message.warning("目标文件夹不能是当前文件夹")}).catch(()=>console.log("已取消移动文件"))},handleBatchMove(){this.$prompt("请输入新的目录","移动文件",{confirmButtonText:"确定",cancelButtonText:"取消",inputValue:"/",beforeClose:(e,t,a)=>{if("confirm"===e){const e=t.inputValue,i=(0,Za.G)(e);if(!i.valid)return void this.$message.error(i.error);a()}else a()}}).then(({value:e})=>{const t=e.replace(/^\/+/,"")+(e.endsWith("/")||""===e?"":"/");if(t===this.currentPath)return void this.$message.warning("目标文件夹不能是当前文件夹");const a=this.selectedFiles.map(e=>{const a=e.isFolder;return(0,K.A)(`/api/manage/move/${e.name}?folder=${a}&dist=${t}`,{method:"GET"})});Promise.all(a).then(e=>{let a=0;e.forEach((e,i)=>{if(e.ok){a++;const e=this.selectedFiles[i];e.selected=!1;const n=this.tableData.findIndex(t=>t.name===e.name);if(-1!==n){const a=t+e.name.split("/").pop();Xa.moveFile(e.name,a,e.isFolder,this.currentPath),this.tableData.splice(n,1)}}}),this.$nextTick(()=>{const e=[...this.tableData];this.tableData=[],this.$nextTick(()=>{this.tableData=e})}),this.updateStats(-a,!1),this.$message.success("移动成功")}).then(()=>{this.refreshLocalFileList()}).catch(()=>this.$message.error("移动失败"))}).catch(()=>console.log("已取消移动文件"))},handleBatchBlock(){this.$confirm("此操作将把选中的文件加入黑名单, 是否继续?","提示",{confirmButtonText:"确定",cancelButtonText:"取消",type:"warning"}).then(()=>{const e=this.selectedFiles.map(e=>e.isFolder?Promise.resolve({ok:!1}):(0,K.A)(`/api/manage/block/${e.name}`,{method:"GET"}));Promise.all(e).then(e=>{e.forEach((e,t)=>{if(e.ok){const e=this.tableData.findIndex(e=>e.name===this.selectedFiles[t].name);-1!==e&&(this.tableData[e].metadata.ListType="Block")}}),this.$message.success("批量加入黑名单成功")}).catch(()=>this.$message.error("批量加入黑名单失败"))}).catch(()=>console.log("已取消批量加入黑名单"))},handleBatchWhite(){this.$confirm("此操作将把选中的文件加入白名单, 是否继续?","提示",{confirmButtonText:"确定",cancelButtonText:"取消",type:"warning"}).then(()=>{const e=this.selectedFiles.map(e=>e.isFolder?Promise.resolve({ok:!1}):(0,K.A)(`/api/manage/white/${e.name}`,{method:"GET"}));Promise.all(e).then(e=>{e.forEach((e,t)=>{if(e.ok){const e=this.tableData.findIndex(e=>e.name===this.selectedFiles[t].name);-1!==e&&(this.tableData[e].metadata.ListType="White")}}),this.$message.success("批量加入白名单成功")}).catch(()=>this.$message.error("批量加入白名单失败"))}).catch(()=>console.log("已取消批量加入白名单"))},handleBatchDownload(){const e=new(Va()),t=e.folder("files"),a={},i=this.selectedFiles.map(async e=>{if(e.isFolder)return;const i=await fetch(this.getFileLink(e.name)),n=await i.blob();let s=e.metadata?.FileName||e.name;if(a[s]){const t=s.substring(s.lastIndexOf(".")),i=s.substring(0,s.lastIndexOf("."));s=`${i}(${a[s]})${t}`,a[e.name]++}else a[s]=1;t.file(s,n)});Promise.all(i).then(()=>e.generateAsync({type:"blob"})).then(e=>{const t=document.createElement("a");t.href=URL.createObjectURL(e),t.download="files.zip",t.click()})},isVideo(e){if(this.isAudio(e))return!1;let t=e.metadata?.FileType?.includes("video");if(!t){const a=["mp4","webm","ogg","avi","mov","flv","wmv","mkv","rmvb","3gp","mpg","mpeg","m4v","f4v","rm","asf","dat","ts","vob","swf","divx","xvid","m2ts","mts","m2v","3g2","3gp2","3gpp","3gpp2","mpe","m1v","mpv","mpv2","mp2v","m2t","m2ts","m2v","m4v"],i=e.name.substring(e.name.lastIndexOf(".")+1).toLowerCase();t=a.includes(i)}return t},isAudio(e){let t=e.metadata?.FileType?.includes("audio");if(!t){const a=["mp3","wav","flac","aac","ogg","wma","m4a","ape","aiff","alac","opus","mid","midi","m4b","m4p","m4r","amr","au","ra","ram"],i=e.name.substring(e.name.lastIndexOf(".")+1).toLowerCase();t=a.includes(i)}return t},isImage(e){let t=e.metadata?.FileType?.includes("image");if(!t){const a=["jpg","jpeg","png","gif","bmp","webp","svg","ico","tiff","tif","psd","ai","eps","raw","cr2","nef","orf","sr2","dng","arw","rw2","raf","pef","x3f","srf","erf","mrw","nrw","kdc","dcr","mef","mos","crw","raf","rwl","srw","3fr","fff","iiq","qtk","bay","k25","kdc","dcs","drf","dng","erf","kdc","mdc","mef","mos","mrw","nef","nrw","orf","pef","ptx","pxn","r3d","raf","raw","rwl","rw2","rwz","sr2","srf","x3f"],i=e.name.substring(e.name.lastIndexOf(".")+1).toLowerCase();t=a.includes(i)}return t},getFileLink(e){const t=`/file/${e}?from=admin`;return t},handlePageChange(e){this.currentPage=e,this.currentPage===Math.ceil(this.tableData.length/this.pageSize)&&this.loadMoreData()},handleJumpPage(){const e=parseInt(this.jumpPage);isNaN(e)||e<1?this.$message.warning("请输入有效的页码"):e>this.realTotalPages?this.$message.warning(`页码不能超过 ${this.realTotalPages}`):(e>this.totalPages?(this.$message.info("正在加载数据,请稍候..."),this.loadMoreDataUntilPage(e)):this.currentPage=e,this.jumpPage="")},async loadMoreDataUntilPage(e){this.loading=!0;try{const t=e*this.pageSize,a=this.filteredTableData.filter(e=>e.isFolder).length,i=this.filteredTableData.filter(e=>!e.isFolder).length,n=Math.max(0,t-a-i);n>0&&(await Xa.loadMoreFiles(this.currentPath,this.searchKeywords,this.searchIncludeTags,this.searchExcludeTags,n,this.filters),await this.fetchFileList()),this.currentPage=Math.min(e,this.totalPages)}catch(t){this.$message.error("加载数据失败,请检查网络连接")}finally{this.loading=!1}},isFolder(e){if(e.isFolder)return!0;let t=e.name;if(t.startsWith("http")&&(t=t.split("/file/")[1]),t&&t.includes("/")){const e=this.currentPath?t.substring(this.currentPath.length):t;return""===this.currentPath?!t.split("/")[0].includes("."):e.includes("/")}return!1},getFolderName(e){let t="";if(e&&e.includes("/")){const a=e.split("/");if(""===this.currentPath)t=a[0];else{const a=e.substring(this.currentPath.length);t=a.split("/")[0]}}else t=e;const a=20;if(t.length>a){const e=Math.floor((a-3)/2),i=Math.ceil((a-3)/2);return`${t.substring(0,e)}...${t.substring(t.length-i)}`}return t},getFileName(e){let t=e.split("/").pop();const a=20;if(t.length>a){const e=Math.floor((a-3)/2),i=Math.ceil((a-3)/2);return`${t.substring(0,e)}...${t.substring(t.length-i)}`}return t},getFileNameStart(e){if(!e)return"";if(e.length<=30)return e;const t=e.lastIndexOf(".");if(t>0){const a=e.substring(0,t),i=Math.min(a.length,Math.floor(.6*e.length));return a.substring(0,i)}return e.substring(0,Math.floor(.6*e.length))},getFileNameEnd(e){if(!e)return"";if(e.length<=30)return"";const t=e.lastIndexOf(".");if(t>0){const a=e.substring(t),i=e.substring(0,t),n=Math.min(8,Math.floor(.2*i.length));return"…"+i.substring(i.length-n)+a}const a=Math.min(10,Math.floor(.3*e.length));return"…"+e.substring(e.length-a)},enterFolder(e){this.currentPath=e+(e.endsWith("/")?"":"/"),this.refreshFileList()},navigateToFolder(e){this.currentPath=e?e+(e.endsWith("/")?"":"/"):"",this.refreshFileList()},async fetchFileList(){this.loading=!0;try{const e=Xa.getLocalFileList(),t=new Set(e.directories||[]),a=e.files||[],i=Array.from(t).map(e=>({name:e,isFolder:!0,selected:!1,metadata:{FileName:e.split("/").pop()}})),n=a.map(e=>({name:e.name,isFolder:!1,selected:!1,metadata:e.metadata}));this.tableData=[...i,...n],this.updateStats(e.totalCount,!0),this.directFileCount=e.directFileCount||0,this.directFolderCount=e.directFolderCount||0}catch(e){console.error("Error fetching file list:",e),this.$message.error("获取文件列表失败")}finally{this.loading=!1}},async refreshFileList(){this.refreshLoading=!0,this.loading=!0;try{const e=await Xa.refreshFileList(this.currentPath,this.searchKeywords,this.searchIncludeTags,this.searchExcludeTags,this.filters);if(!e)throw new Error("Refresh failed");await this.fetchFileList()}catch(e){console.error("Error refreshing file list:",e),this.$message.error("刷新失败,请重试")}finally{this.refreshLoading=!1,this.loading=!1}},async refreshLocalFileList(){this.refreshLoading=!0,this.loading=!0;try{await this.fetchFileList()}catch(e){console.error("Error refreshing local file list:",e),this.$message.error("刷新失败,请重试")}finally{this.refreshLoading=!1,this.loading=!1}},handleTagManagement(e){this.currentTagFile=e,this.showTagDialog=!0},handleBatchTagManagement(){0!==this.selectedFiles.length?this.showBatchTagDialog=!0:this.$message.warning("请先选择文件")},async handleTagsUpdated(e){const t=this.tableData.findIndex(e=>e.name===this.currentTagFile);-1!==t&&(this.tableData[t].metadata||(this.tableData[t].metadata={}),this.tableData[t].metadata.Tags=e,this.showdetailDialog&&this.detailFile?.name===this.currentTagFile&&(this.detailFile.metadata||(this.detailFile.metadata={}),this.detailFile.metadata.Tags=e))},async handleBatchTagsUpdated(){await this.refreshLocalFileList()},generateFileLink(e,t){const a="External"===t?.Channel,i=a?t?.ExternalLink:`${this.rootUrl}${e}`,n=t?.FileName||e;switch(this.defaultUrlFormat){case"originUrl":return i;case"mdUrl":return`![${n}](${i})`;case"htmlUrl":return`${n}`;case"bbUrl":return`[img]${i}[/img]`;case"tgId":return t?.TgFileId||"";case"s3Location":return t?.S3Location||"";default:return i}},async handleFolderCopy(e){const t=this.$loading({lock:!0,text:"正在获取文件列表..."});try{const a=await(0,K.A)(`/api/manage/list?dir=${encodeURIComponent(e)}&recursive=true&count=-1`,{method:"GET"}),i=await a.json();if(t.close(),!i.files||0===i.files.length)return void this.$message.warning("文件夹为空,没有可复制的链接");const n=i.files.map(e=>this.generateFileLink(e.name,e.metadata)).filter(e=>e);if(0===n.length)return void this.$message.warning("没有可复制的链接");const s=n.join("\n");navigator.clipboard?(await navigator.clipboard.writeText(s),this.$message.success(`已复制 ${n.length} 个文件链接`)):(this.copyToClipboardFallback(s),this.$message.success(`已复制 ${n.length} 个文件链接`))}catch(a){t.close(),console.error("复制文件夹链接失败:",a),this.$message.error("复制文件夹链接失败,请重试")}}},mounted(){this.loading=!0,(0,K.A)("/api/manage/check",{method:"GET"}).then(e=>e.text()).then(e=>{if("true"==e)return this.showLogoutButton=!0,!0;if("Not using basic auth."==e)return!0;throw new Error("Unauthorized")}).then(()=>this.refreshFileList()).then(()=>this.extractChannelNames()).catch(e=>{"Unauthorized"!==e.message&&this.$message.error("同步数据时出错,请检查网络连接")}).finally(()=>{this.loading=!1}),this.customUrlPrefix=this.adminUrlSettings.customUrlPrefix,this.useCustomUrl=this.adminUrlSettings.useCustomUrl}};const Ga=(0,h.A)(Ka,[["render",Ra],["__scopeId","data-v-5c4ee283"]]);var Ha=Ga},415:function(e,t,a){"use strict";a(5331),a(3565)},2388:function(e,t,a){"use strict";function i(e){if(!e||""===e.trim())return{valid:!0};if("/"===e)return{valid:!0};if(!e.startsWith("/"))return{valid:!1,error:'目标目录必须以 "/" 开头'};const t=/[\\:\*\?"'<>\| \(\)\[\]\{\}#%\^`~;@&=\+\$,]/;return t.test(e)?{valid:!1,error:"目标目录包含非法字符,请使用合法的路径格式"}:e.includes("//")?{valid:!1,error:"目标目录不能包含连续的斜杠"}:{valid:!0}}a.d(t,{G:function(){return i}})},2907:function(e,t,a){"use strict";a(5331),a(6808),a(6711)},3565:function(e,t,a){"use strict";a(5331)},4396:function(e,t,a){"use strict";a(5331),a(4885)},4813:function(e,t,a){a(4114),a(6573),a(8100),a(7936),a(8111),a(2489),a(7588),a(9577),a(1549),a(9797),a(9631),a(5623),a(9848),function(t){e.exports=t()}(function(){return function e(t,a,i){function n(r,o){if(!a[r]){if(!t[r]){var l=void 0;if(!o&&l)return require(r,!0);if(s)return s(r,!0);var c=new Error("Cannot find module '"+r+"'");throw c.code="MODULE_NOT_FOUND",c}var d=a[r]={exports:{}};t[r][0].call(d.exports,function(e){var a=t[r][1][e];return n(a||e)},d,d.exports,e,t,a,i)}return a[r].exports}for(var s=void 0,r=0;r>2,o=(3&t)<<4|a>>4,l=1>6:64,c=2>4,a=(15&r)<<4|(o=s.indexOf(e.charAt(c++)))>>2,i=(3&o)<<6|(l=s.indexOf(e.charAt(c++))),u[d++]=t,64!==o&&(u[d++]=a),64!==l&&(u[d++]=i);return u}},{"./support":30,"./utils":32}],2:[function(e,t,a){"use strict";var i=e("./external"),n=e("./stream/DataWorker"),s=e("./stream/Crc32Probe"),r=e("./stream/DataLengthProbe");function o(e,t,a,i,n){this.compressedSize=e,this.uncompressedSize=t,this.crc32=a,this.compression=i,this.compressedContent=n}o.prototype={getContentWorker:function(){var e=new n(i.Promise.resolve(this.compressedContent)).pipe(this.compression.uncompressWorker()).pipe(new r("data_length")),t=this;return e.on("end",function(){if(this.streamInfo.data_length!==t.uncompressedSize)throw new Error("Bug : uncompressed data size mismatch")}),e},getCompressedWorker:function(){return new n(i.Promise.resolve(this.compressedContent)).withStreamInfo("compressedSize",this.compressedSize).withStreamInfo("uncompressedSize",this.uncompressedSize).withStreamInfo("crc32",this.crc32).withStreamInfo("compression",this.compression)}},o.createWorkerFrom=function(e,t,a){return e.pipe(new s).pipe(new r("uncompressedSize")).pipe(t.compressWorker(a)).pipe(new r("compressedSize")).withStreamInfo("compression",t)},t.exports=o},{"./external":6,"./stream/Crc32Probe":25,"./stream/DataLengthProbe":26,"./stream/DataWorker":27}],3:[function(e,t,a){"use strict";var i=e("./stream/GenericWorker");a.STORE={magic:"\0\0",compressWorker:function(){return new i("STORE compression")},uncompressWorker:function(){return new i("STORE decompression")}},a.DEFLATE=e("./flate")},{"./flate":7,"./stream/GenericWorker":28}],4:[function(e,t,a){"use strict";var i=e("./utils"),n=function(){for(var e,t=[],a=0;a<256;a++){e=a;for(var i=0;i<8;i++)e=1&e?3988292384^e>>>1:e>>>1;t[a]=e}return t}();t.exports=function(e,t){return void 0!==e&&e.length?"string"!==i.getTypeOf(e)?function(e,t,a,i){var s=n,r=i+a;e^=-1;for(var o=i;o>>8^s[255&(e^t[o])];return-1^e}(0|t,e,e.length,0):function(e,t,a,i){var s=n,r=i+a;e^=-1;for(var o=i;o>>8^s[255&(e^t.charCodeAt(o))];return-1^e}(0|t,e,e.length,0):0}},{"./utils":32}],5:[function(e,t,a){"use strict";a.base64=!1,a.binary=!1,a.dir=!1,a.createFolders=!0,a.date=null,a.compression=null,a.compressionOptions=null,a.comment=null,a.unixPermissions=null,a.dosPermissions=null},{}],6:[function(e,t,a){"use strict";var i=null;i="undefined"!=typeof Promise?Promise:e("lie"),t.exports={Promise:i}},{lie:37}],7:[function(e,t,a){"use strict";var i="undefined"!=typeof Uint8Array&&"undefined"!=typeof Uint16Array&&"undefined"!=typeof Uint32Array,n=e("pako"),s=e("./utils"),r=e("./stream/GenericWorker"),o=i?"uint8array":"array";function l(e,t){r.call(this,"FlateWorker/"+e),this._pako=null,this._pakoAction=e,this._pakoOptions=t,this.meta={}}a.magic="\b\0",s.inherits(l,r),l.prototype.processChunk=function(e){this.meta=e.meta,null===this._pako&&this._createPako(),this._pako.push(s.transformTo(o,e.data),!1)},l.prototype.flush=function(){r.prototype.flush.call(this),null===this._pako&&this._createPako(),this._pako.push([],!0)},l.prototype.cleanUp=function(){r.prototype.cleanUp.call(this),this._pako=null},l.prototype._createPako=function(){this._pako=new n[this._pakoAction]({raw:!0,level:this._pakoOptions.level||-1});var e=this;this._pako.onData=function(t){e.push({data:t,meta:e.meta})}},a.compressWorker=function(e){return new l("Deflate",e)},a.uncompressWorker=function(){return new l("Inflate",{})}},{"./stream/GenericWorker":28,"./utils":32,pako:38}],8:[function(e,t,a){"use strict";function i(e,t){var a,i="";for(a=0;a>>=8;return i}function n(e,t,a,n,r,d){var h,u,f=e.file,m=e.compression,p=d!==o.utf8encode,g=s.transformTo("string",d(f.name)),b=s.transformTo("string",o.utf8encode(f.name)),v=f.comment,k=s.transformTo("string",d(v)),y=s.transformTo("string",o.utf8encode(v)),_=b.length!==f.name.length,w=y.length!==v.length,F="",C="",T="",x=f.dir,S=f.date,L={crc32:0,compressedSize:0,uncompressedSize:0};t&&!a||(L.crc32=e.crc32,L.compressedSize=e.compressedSize,L.uncompressedSize=e.uncompressedSize);var E=0;t&&(E|=8),p||!_&&!w||(E|=2048);var A=0,I=0;x&&(A|=16),"UNIX"===r?(I=798,A|=function(e,t){var a=e;return e||(a=t?16893:33204),(65535&a)<<16}(f.unixPermissions,x)):(I=20,A|=function(e){return 63&(e||0)}(f.dosPermissions)),h=S.getUTCHours(),h<<=6,h|=S.getUTCMinutes(),h<<=5,h|=S.getUTCSeconds()/2,u=S.getUTCFullYear()-1980,u<<=4,u|=S.getUTCMonth()+1,u<<=5,u|=S.getUTCDate(),_&&(C=i(1,1)+i(l(g),4)+b,F+="up"+i(C.length,2)+C),w&&(T=i(1,1)+i(l(k),4)+y,F+="uc"+i(T.length,2)+T);var D="";return D+="\n\0",D+=i(E,2),D+=m.magic,D+=i(h,2),D+=i(u,2),D+=i(L.crc32,4),D+=i(L.compressedSize,4),D+=i(L.uncompressedSize,4),D+=i(g.length,2),D+=i(F.length,2),{fileRecord:c.LOCAL_FILE_HEADER+D+g+F,dirRecord:c.CENTRAL_FILE_HEADER+i(I,2)+D+i(k.length,2)+"\0\0\0\0"+i(A,4)+i(n,4)+g+F+k}}var s=e("../utils"),r=e("../stream/GenericWorker"),o=e("../utf8"),l=e("../crc32"),c=e("../signature");function d(e,t,a,i){r.call(this,"ZipFileWorker"),this.bytesWritten=0,this.zipComment=t,this.zipPlatform=a,this.encodeFileName=i,this.streamFiles=e,this.accumulate=!1,this.contentBuffer=[],this.dirRecords=[],this.currentSourceOffset=0,this.entriesCount=0,this.currentFile=null,this._sources=[]}s.inherits(d,r),d.prototype.push=function(e){var t=e.meta.percent||0,a=this.entriesCount,i=this._sources.length;this.accumulate?this.contentBuffer.push(e):(this.bytesWritten+=e.data.length,r.prototype.push.call(this,{data:e.data,meta:{currentFile:this.currentFile,percent:a?(t+100*(a-i-1))/a:100}}))},d.prototype.openedSource=function(e){this.currentSourceOffset=this.bytesWritten,this.currentFile=e.file.name;var t=this.streamFiles&&!e.file.dir;if(t){var a=n(e,t,!1,this.currentSourceOffset,this.zipPlatform,this.encodeFileName);this.push({data:a.fileRecord,meta:{percent:0}})}else this.accumulate=!0},d.prototype.closedSource=function(e){this.accumulate=!1;var t=this.streamFiles&&!e.file.dir,a=n(e,t,!0,this.currentSourceOffset,this.zipPlatform,this.encodeFileName);if(this.dirRecords.push(a.dirRecord),t)this.push({data:function(e){return c.DATA_DESCRIPTOR+i(e.crc32,4)+i(e.compressedSize,4)+i(e.uncompressedSize,4)}(e),meta:{percent:100}});else for(this.push({data:a.fileRecord,meta:{percent:0}});this.contentBuffer.length;)this.push(this.contentBuffer.shift());this.currentFile=null},d.prototype.flush=function(){for(var e=this.bytesWritten,t=0;t=this.index;t--)a=(a<<8)+this.byteAt(t);return this.index+=e,a},readString:function(e){return i.transformTo("string",this.readData(e))},readData:function(){},lastIndexOfSignature:function(){},readAndCheckSignature:function(){},readDate:function(){var e=this.readInt(4);return new Date(Date.UTC(1980+(e>>25&127),(e>>21&15)-1,e>>16&31,e>>11&31,e>>5&63,(31&e)<<1))}},t.exports=n},{"../utils":32}],19:[function(e,t,a){"use strict";var i=e("./Uint8ArrayReader");function n(e){i.call(this,e)}e("../utils").inherits(n,i),n.prototype.readData=function(e){this.checkOffset(e);var t=this.data.slice(this.zero+this.index,this.zero+this.index+e);return this.index+=e,t},t.exports=n},{"../utils":32,"./Uint8ArrayReader":21}],20:[function(e,t,a){"use strict";var i=e("./DataReader");function n(e){i.call(this,e)}e("../utils").inherits(n,i),n.prototype.byteAt=function(e){return this.data.charCodeAt(this.zero+e)},n.prototype.lastIndexOfSignature=function(e){return this.data.lastIndexOf(e)-this.zero},n.prototype.readAndCheckSignature=function(e){return e===this.readData(4)},n.prototype.readData=function(e){this.checkOffset(e);var t=this.data.slice(this.zero+this.index,this.zero+this.index+e);return this.index+=e,t},t.exports=n},{"../utils":32,"./DataReader":18}],21:[function(e,t,a){"use strict";var i=e("./ArrayReader");function n(e){i.call(this,e)}e("../utils").inherits(n,i),n.prototype.readData=function(e){if(this.checkOffset(e),0===e)return new Uint8Array(0);var t=this.data.subarray(this.zero+this.index,this.zero+this.index+e);return this.index+=e,t},t.exports=n},{"../utils":32,"./ArrayReader":17}],22:[function(e,t,a){"use strict";var i=e("../utils"),n=e("../support"),s=e("./ArrayReader"),r=e("./StringReader"),o=e("./NodeBufferReader"),l=e("./Uint8ArrayReader");t.exports=function(e){var t=i.getTypeOf(e);return i.checkSupport(t),"string"!==t||n.uint8array?"nodebuffer"===t?new o(e):n.uint8array?new l(i.transformTo("uint8array",e)):new s(i.transformTo("array",e)):new r(e)}},{"../support":30,"../utils":32,"./ArrayReader":17,"./NodeBufferReader":19,"./StringReader":20,"./Uint8ArrayReader":21}],23:[function(e,t,a){"use strict";a.LOCAL_FILE_HEADER="PK",a.CENTRAL_FILE_HEADER="PK",a.CENTRAL_DIRECTORY_END="PK",a.ZIP64_CENTRAL_DIRECTORY_LOCATOR="PK",a.ZIP64_CENTRAL_DIRECTORY_END="PK",a.DATA_DESCRIPTOR="PK\b"},{}],24:[function(e,t,a){"use strict";var i=e("./GenericWorker"),n=e("../utils");function s(e){i.call(this,"ConvertWorker to "+e),this.destType=e}n.inherits(s,i),s.prototype.processChunk=function(e){this.push({data:n.transformTo(this.destType,e.data),meta:e.meta})},t.exports=s},{"../utils":32,"./GenericWorker":28}],25:[function(e,t,a){"use strict";var i=e("./GenericWorker"),n=e("../crc32");function s(){i.call(this,"Crc32Probe"),this.withStreamInfo("crc32",0)}e("../utils").inherits(s,i),s.prototype.processChunk=function(e){this.streamInfo.crc32=n(e.data,this.streamInfo.crc32||0),this.push(e)},t.exports=s},{"../crc32":4,"../utils":32,"./GenericWorker":28}],26:[function(e,t,a){"use strict";var i=e("../utils"),n=e("./GenericWorker");function s(e){n.call(this,"DataLengthProbe for "+e),this.propName=e,this.withStreamInfo(e,0)}i.inherits(s,n),s.prototype.processChunk=function(e){if(e){var t=this.streamInfo[this.propName]||0;this.streamInfo[this.propName]=t+e.data.length}n.prototype.processChunk.call(this,e)},t.exports=s},{"../utils":32,"./GenericWorker":28}],27:[function(e,t,a){"use strict";var i=e("../utils"),n=e("./GenericWorker");function s(e){n.call(this,"DataWorker");var t=this;this.dataIsReady=!1,this.index=0,this.max=0,this.data=null,this.type="",this._tickScheduled=!1,e.then(function(e){t.dataIsReady=!0,t.data=e,t.max=e&&e.length||0,t.type=i.getTypeOf(e),t.isPaused||t._tickAndRepeat()},function(e){t.error(e)})}i.inherits(s,n),s.prototype.cleanUp=function(){n.prototype.cleanUp.call(this),this.data=null},s.prototype.resume=function(){return!!n.prototype.resume.call(this)&&(!this._tickScheduled&&this.dataIsReady&&(this._tickScheduled=!0,i.delay(this._tickAndRepeat,[],this)),!0)},s.prototype._tickAndRepeat=function(){this._tickScheduled=!1,this.isPaused||this.isFinished||(this._tick(),this.isFinished||(i.delay(this._tickAndRepeat,[],this),this._tickScheduled=!0))},s.prototype._tick=function(){if(this.isPaused||this.isFinished)return!1;var e=null,t=Math.min(this.max,this.index+16384);if(this.index>=this.max)return this.end();switch(this.type){case"string":e=this.data.substring(this.index,t);break;case"uint8array":e=this.data.subarray(this.index,t);break;case"array":case"nodebuffer":e=this.data.slice(this.index,t)}return this.index=t,this.push({data:e,meta:{percent:this.max?this.index/this.max*100:0}})},t.exports=s},{"../utils":32,"./GenericWorker":28}],28:[function(e,t,a){"use strict";function i(e){this.name=e||"default",this.streamInfo={},this.generatedError=null,this.extraStreamInfo={},this.isPaused=!0,this.isFinished=!1,this.isLocked=!1,this._listeners={data:[],end:[],error:[]},this.previous=null}i.prototype={push:function(e){this.emit("data",e)},end:function(){if(this.isFinished)return!1;this.flush();try{this.emit("end"),this.cleanUp(),this.isFinished=!0}catch(e){this.emit("error",e)}return!0},error:function(e){return!this.isFinished&&(this.isPaused?this.generatedError=e:(this.isFinished=!0,this.emit("error",e),this.previous&&this.previous.error(e),this.cleanUp()),!0)},on:function(e,t){return this._listeners[e].push(t),this},cleanUp:function(){this.streamInfo=this.generatedError=this.extraStreamInfo=null,this._listeners=[]},emit:function(e,t){if(this._listeners[e])for(var a=0;a "+e:e}},t.exports=i},{}],29:[function(e,t,a){"use strict";var i=e("../utils"),n=e("./ConvertWorker"),s=e("./GenericWorker"),r=e("../base64"),o=e("../support"),l=e("../external"),c=null;if(o.nodestream)try{c=e("../nodejs/NodejsStreamOutputAdapter")}catch(e){}function d(e,t){return new l.Promise(function(a,n){var s=[],o=e._internalType,l=e._outputType,c=e._mimeType;e.on("data",function(e,a){s.push(e),t&&t(a)}).on("error",function(e){s=[],n(e)}).on("end",function(){try{var e=function(e,t,a){switch(e){case"blob":return i.newBlob(i.transformTo("arraybuffer",t),a);case"base64":return r.encode(t);default:return i.transformTo(e,t)}}(l,function(e,t){var a,i=0,n=null,s=0;for(a=0;a>>6:(a<65536?t[r++]=224|a>>>12:(t[r++]=240|a>>>18,t[r++]=128|a>>>12&63),t[r++]=128|a>>>6&63),t[r++]=128|63&a);return t}(e)},a.utf8decode=function(e){return n.nodebuffer?i.transformTo("nodebuffer",e).toString("utf-8"):function(e){var t,a,n,s,r=e.length,l=new Array(2*r);for(t=a=0;t>10&1023,l[a++]=56320|1023&n)}return l.length!==a&&(l.subarray?l=l.subarray(0,a):l.length=a),i.applyFromCharCode(l)}(e=i.transformTo(n.uint8array?"uint8array":"array",e))},i.inherits(c,r),c.prototype.processChunk=function(e){var t=i.transformTo(n.uint8array?"uint8array":"array",e.data);if(this.leftOver&&this.leftOver.length){if(n.uint8array){var s=t;(t=new Uint8Array(s.length+this.leftOver.length)).set(this.leftOver,0),t.set(s,this.leftOver.length)}else t=this.leftOver.concat(t);this.leftOver=null}var r=function(e,t){var a;for((t=t||e.length)>e.length&&(t=e.length),a=t-1;0<=a&&128==(192&e[a]);)a--;return a<0||0===a?t:a+o[e[a]]>t?a:t}(t),l=t;r!==t.length&&(n.uint8array?(l=t.subarray(0,r),this.leftOver=t.subarray(r,t.length)):(l=t.slice(0,r),this.leftOver=t.slice(r,t.length))),this.push({data:a.utf8decode(l),meta:e.meta})},c.prototype.flush=function(){this.leftOver&&this.leftOver.length&&(this.push({data:a.utf8decode(this.leftOver),meta:{}}),this.leftOver=null)},a.Utf8DecodeWorker=c,i.inherits(d,r),d.prototype.processChunk=function(e){this.push({data:a.utf8encode(e.data),meta:e.meta})},a.Utf8EncodeWorker=d},{"./nodejsUtils":14,"./stream/GenericWorker":28,"./support":30,"./utils":32}],32:[function(e,t,a){"use strict";var i=e("./support"),n=e("./base64"),s=e("./nodejsUtils"),r=e("./external");function o(e){return e}function l(e,t){for(var a=0;a>8;this.dir=!!(16&this.externalFileAttributes),0==e&&(this.dosPermissions=63&this.externalFileAttributes),3==e&&(this.unixPermissions=this.externalFileAttributes>>16&65535),this.dir||"/"!==this.fileNameStr.slice(-1)||(this.dir=!0)},parseZIP64ExtraField:function(){if(this.extraFields[1]){var e=i(this.extraFields[1].value);this.uncompressedSize===n.MAX_VALUE_32BITS&&(this.uncompressedSize=e.readInt(8)),this.compressedSize===n.MAX_VALUE_32BITS&&(this.compressedSize=e.readInt(8)),this.localHeaderOffset===n.MAX_VALUE_32BITS&&(this.localHeaderOffset=e.readInt(8)),this.diskNumberStart===n.MAX_VALUE_32BITS&&(this.diskNumberStart=e.readInt(4))}},readExtraFields:function(e){var t,a,i,n=e.index+this.extraFieldsLength;for(this.extraFields||(this.extraFields={});e.index+4>>6:(a<65536?t[r++]=224|a>>>12:(t[r++]=240|a>>>18,t[r++]=128|a>>>12&63),t[r++]=128|a>>>6&63),t[r++]=128|63&a);return t},a.buf2binstring=function(e){return l(e,e.length)},a.binstring2buf=function(e){for(var t=new i.Buf8(e.length),a=0,n=t.length;a>10&1023,c[i++]=56320|1023&n)}return l(c,i)},a.utf8border=function(e,t){var a;for((t=t||e.length)>e.length&&(t=e.length),a=t-1;0<=a&&128==(192&e[a]);)a--;return a<0||0===a?t:a+r[e[a]]>t?a:t}},{"./common":41}],43:[function(e,t,a){"use strict";t.exports=function(e,t,a,i){for(var n=65535&e,s=e>>>16&65535,r=0;0!==a;){for(a-=r=2e3>>1:e>>>1;t[a]=e}return t}();t.exports=function(e,t,a,n){var s=i,r=n+a;e^=-1;for(var o=n;o>>8^s[255&(e^t[o])];return-1^e}},{}],46:[function(e,t,a){"use strict";var i,n=e("../utils/common"),s=e("./trees"),r=e("./adler32"),o=e("./crc32"),l=e("./messages"),c=0,d=4,h=0,u=-2,f=-1,m=4,p=2,g=8,b=9,v=286,k=30,y=19,_=2*v+1,w=15,F=3,C=258,T=C+F+1,x=42,S=113,L=1,E=2,A=3,I=4;function D(e,t){return e.msg=l[t],t}function U(e){return(e<<1)-(4e.avail_out&&(a=e.avail_out),0!==a&&(n.arraySet(e.output,t.pending_buf,t.pending_out,a,e.next_out),e.next_out+=a,t.pending_out+=a,e.total_out+=a,e.avail_out-=a,t.pending-=a,0===t.pending&&(t.pending_out=0))}function O(e,t){s._tr_flush_block(e,0<=e.block_start?e.block_start:-1,e.strstart-e.block_start,t),e.block_start=e.strstart,B(e.strm)}function W(e,t){e.pending_buf[e.pending++]=t}function $(e,t){e.pending_buf[e.pending++]=t>>>8&255,e.pending_buf[e.pending++]=255&t}function P(e,t){var a,i,n=e.max_chain_length,s=e.strstart,r=e.prev_length,o=e.nice_match,l=e.strstart>e.w_size-T?e.strstart-(e.w_size-T):0,c=e.window,d=e.w_mask,h=e.prev,u=e.strstart+C,f=c[s+r-1],m=c[s+r];e.prev_length>=e.good_match&&(n>>=2),o>e.lookahead&&(o=e.lookahead);do{if(c[(a=t)+r]===m&&c[a+r-1]===f&&c[a]===c[s]&&c[++a]===c[s+1]){s+=2,a++;do{}while(c[++s]===c[++a]&&c[++s]===c[++a]&&c[++s]===c[++a]&&c[++s]===c[++a]&&c[++s]===c[++a]&&c[++s]===c[++a]&&c[++s]===c[++a]&&c[++s]===c[++a]&&sl&&0!=--n);return r<=e.lookahead?r:e.lookahead}function R(e){var t,a,i,s,l,c,d,h,u,f,m=e.w_size;do{if(s=e.window_size-e.lookahead-e.strstart,e.strstart>=m+(m-T)){for(n.arraySet(e.window,e.window,m,m,0),e.match_start-=m,e.strstart-=m,e.block_start-=m,t=a=e.hash_size;i=e.head[--t],e.head[t]=m<=i?i-m:0,--a;);for(t=a=m;i=e.prev[--t],e.prev[t]=m<=i?i-m:0,--a;);s+=m}if(0===e.strm.avail_in)break;if(c=e.strm,d=e.window,h=e.strstart+e.lookahead,u=s,f=void 0,f=c.avail_in,u=F)for(l=e.strstart-e.insert,e.ins_h=e.window[l],e.ins_h=(e.ins_h<=F&&(e.ins_h=(e.ins_h<=F)if(i=s._tr_tally(e,e.strstart-e.match_start,e.match_length-F),e.lookahead-=e.match_length,e.match_length<=e.max_lazy_match&&e.lookahead>=F){for(e.match_length--;e.strstart++,e.ins_h=(e.ins_h<=F&&(e.ins_h=(e.ins_h<=F&&e.match_length<=e.prev_length){for(n=e.strstart+e.lookahead-F,i=s._tr_tally(e,e.strstart-1-e.prev_match,e.prev_length-F),e.lookahead-=e.prev_length-1,e.prev_length-=2;++e.strstart<=n&&(e.ins_h=(e.ins_h<e.pending_buf_size-5&&(a=e.pending_buf_size-5);;){if(e.lookahead<=1){if(R(e),0===e.lookahead&&t===c)return L;if(0===e.lookahead)break}e.strstart+=e.lookahead,e.lookahead=0;var i=e.block_start+a;if((0===e.strstart||e.strstart>=i)&&(e.lookahead=e.strstart-i,e.strstart=i,O(e,!1),0===e.strm.avail_out))return L;if(e.strstart-e.block_start>=e.w_size-T&&(O(e,!1),0===e.strm.avail_out))return L}return e.insert=0,t===d?(O(e,!0),0===e.strm.avail_out?A:I):(e.strstart>e.block_start&&(O(e,!1),e.strm.avail_out),L)}),new V(4,4,8,4,N),new V(4,5,16,8,N),new V(4,6,32,32,N),new V(4,4,16,16,j),new V(8,16,32,32,j),new V(8,16,128,128,j),new V(8,32,128,256,j),new V(32,128,258,1024,j),new V(32,258,258,4096,j)],a.deflateInit=function(e,t){return K(e,t,g,15,8,0)},a.deflateInit2=K,a.deflateReset=Z,a.deflateResetKeep=X,a.deflateSetHeader=function(e,t){return e&&e.state?2!==e.state.wrap?u:(e.state.gzhead=t,h):u},a.deflate=function(e,t){var a,n,r,l;if(!e||!e.state||5>8&255),W(n,n.gzhead.time>>16&255),W(n,n.gzhead.time>>24&255),W(n,9===n.level?2:2<=n.strategy||n.level<2?4:0),W(n,255&n.gzhead.os),n.gzhead.extra&&n.gzhead.extra.length&&(W(n,255&n.gzhead.extra.length),W(n,n.gzhead.extra.length>>8&255)),n.gzhead.hcrc&&(e.adler=o(e.adler,n.pending_buf,n.pending,0)),n.gzindex=0,n.status=69):(W(n,0),W(n,0),W(n,0),W(n,0),W(n,0),W(n,9===n.level?2:2<=n.strategy||n.level<2?4:0),W(n,3),n.status=S);else{var f=g+(n.w_bits-8<<4)<<8;f|=(2<=n.strategy||n.level<2?0:n.level<6?1:6===n.level?2:3)<<6,0!==n.strstart&&(f|=32),f+=31-f%31,n.status=S,$(n,f),0!==n.strstart&&($(n,e.adler>>>16),$(n,65535&e.adler)),e.adler=1}if(69===n.status)if(n.gzhead.extra){for(r=n.pending;n.gzindex<(65535&n.gzhead.extra.length)&&(n.pending!==n.pending_buf_size||(n.gzhead.hcrc&&n.pending>r&&(e.adler=o(e.adler,n.pending_buf,n.pending-r,r)),B(e),r=n.pending,n.pending!==n.pending_buf_size));)W(n,255&n.gzhead.extra[n.gzindex]),n.gzindex++;n.gzhead.hcrc&&n.pending>r&&(e.adler=o(e.adler,n.pending_buf,n.pending-r,r)),n.gzindex===n.gzhead.extra.length&&(n.gzindex=0,n.status=73)}else n.status=73;if(73===n.status)if(n.gzhead.name){r=n.pending;do{if(n.pending===n.pending_buf_size&&(n.gzhead.hcrc&&n.pending>r&&(e.adler=o(e.adler,n.pending_buf,n.pending-r,r)),B(e),r=n.pending,n.pending===n.pending_buf_size)){l=1;break}l=n.gzindexr&&(e.adler=o(e.adler,n.pending_buf,n.pending-r,r)),0===l&&(n.gzindex=0,n.status=91)}else n.status=91;if(91===n.status)if(n.gzhead.comment){r=n.pending;do{if(n.pending===n.pending_buf_size&&(n.gzhead.hcrc&&n.pending>r&&(e.adler=o(e.adler,n.pending_buf,n.pending-r,r)),B(e),r=n.pending,n.pending===n.pending_buf_size)){l=1;break}l=n.gzindexr&&(e.adler=o(e.adler,n.pending_buf,n.pending-r,r)),0===l&&(n.status=103)}else n.status=103;if(103===n.status&&(n.gzhead.hcrc?(n.pending+2>n.pending_buf_size&&B(e),n.pending+2<=n.pending_buf_size&&(W(n,255&e.adler),W(n,e.adler>>8&255),e.adler=0,n.status=S)):n.status=S),0!==n.pending){if(B(e),0===e.avail_out)return n.last_flush=-1,h}else if(0===e.avail_in&&U(t)<=U(a)&&t!==d)return D(e,-5);if(666===n.status&&0!==e.avail_in)return D(e,-5);if(0!==e.avail_in||0!==n.lookahead||t!==c&&666!==n.status){var m=2===n.strategy?function(e,t){for(var a;;){if(0===e.lookahead&&(R(e),0===e.lookahead)){if(t===c)return L;break}if(e.match_length=0,a=s._tr_tally(e,0,e.window[e.strstart]),e.lookahead--,e.strstart++,a&&(O(e,!1),0===e.strm.avail_out))return L}return e.insert=0,t===d?(O(e,!0),0===e.strm.avail_out?A:I):e.last_lit&&(O(e,!1),0===e.strm.avail_out)?L:E}(n,t):3===n.strategy?function(e,t){for(var a,i,n,r,o=e.window;;){if(e.lookahead<=C){if(R(e),e.lookahead<=C&&t===c)return L;if(0===e.lookahead)break}if(e.match_length=0,e.lookahead>=F&&0e.lookahead&&(e.match_length=e.lookahead)}if(e.match_length>=F?(a=s._tr_tally(e,1,e.match_length-F),e.lookahead-=e.match_length,e.strstart+=e.match_length,e.match_length=0):(a=s._tr_tally(e,0,e.window[e.strstart]),e.lookahead--,e.strstart++),a&&(O(e,!1),0===e.strm.avail_out))return L}return e.insert=0,t===d?(O(e,!0),0===e.strm.avail_out?A:I):e.last_lit&&(O(e,!1),0===e.strm.avail_out)?L:E}(n,t):i[n.level].func(n,t);if(m!==A&&m!==I||(n.status=666),m===L||m===A)return 0===e.avail_out&&(n.last_flush=-1),h;if(m===E&&(1===t?s._tr_align(n):5!==t&&(s._tr_stored_block(n,0,0,!1),3===t&&(z(n.head),0===n.lookahead&&(n.strstart=0,n.block_start=0,n.insert=0))),B(e),0===e.avail_out))return n.last_flush=-1,h}return t!==d?h:n.wrap<=0?1:(2===n.wrap?(W(n,255&e.adler),W(n,e.adler>>8&255),W(n,e.adler>>16&255),W(n,e.adler>>24&255),W(n,255&e.total_in),W(n,e.total_in>>8&255),W(n,e.total_in>>16&255),W(n,e.total_in>>24&255)):($(n,e.adler>>>16),$(n,65535&e.adler)),B(e),0=a.w_size&&(0===o&&(z(a.head),a.strstart=0,a.block_start=0,a.insert=0),f=new n.Buf8(a.w_size),n.arraySet(f,t,m-a.w_size,a.w_size,0),t=f,m=a.w_size),l=e.avail_in,c=e.next_in,d=e.input,e.avail_in=m,e.next_in=0,e.input=t,R(a);a.lookahead>=F;){for(i=a.strstart,s=a.lookahead-(F-1);a.ins_h=(a.ins_h<>>=y=k>>>24,m-=y,0===(y=k>>>16&255))x[s++]=65535&k;else{if(!(16&y)){if(0==(64&y)){k=p[(65535&k)+(f&(1<>>=y,m-=y),m<15&&(f+=T[i++]<>>=y=k>>>24,m-=y,!(16&(y=k>>>16&255))){if(0==(64&y)){k=g[(65535&k)+(f&(1<>>=y,m-=y,(y=s-r)>3,f&=(1<<(m-=_<<3))-1,e.next_in=i,e.next_out=s,e.avail_in=i>>24&255)+(e>>>8&65280)+((65280&e)<<8)+((255&e)<<24)}function g(){this.mode=0,this.last=!1,this.wrap=0,this.havedict=!1,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 i.Buf16(320),this.work=new i.Buf16(288),this.lendyn=null,this.distdyn=null,this.sane=0,this.back=0,this.was=0}function b(e){var t;return e&&e.state?(t=e.state,e.total_in=e.total_out=t.total=0,e.msg="",t.wrap&&(e.adler=1&t.wrap),t.mode=u,t.last=0,t.havedict=0,t.dmax=32768,t.head=null,t.hold=0,t.bits=0,t.lencode=t.lendyn=new i.Buf32(f),t.distcode=t.distdyn=new i.Buf32(m),t.sane=1,t.back=-1,d):h}function v(e){var t;return e&&e.state?((t=e.state).wsize=0,t.whave=0,t.wnext=0,b(e)):h}function k(e,t){var a,i;return e&&e.state?(i=e.state,t<0?(a=0,t=-t):(a=1+(t>>4),t<48&&(t&=15)),t&&(t<8||15=r.wsize?(i.arraySet(r.window,t,a-r.wsize,r.wsize,0),r.wnext=0,r.whave=r.wsize):(n<(s=r.wsize-r.wnext)&&(s=n),i.arraySet(r.window,t,a-n,s,r.wnext),(n-=s)?(i.arraySet(r.window,t,a-n,n,0),r.wnext=n,r.whave=r.wsize):(r.wnext+=s,r.wnext===r.wsize&&(r.wnext=0),r.whave>>8&255,a.check=s(a.check,R,2,0),_=y=0,a.mode=2;break}if(a.flags=0,a.head&&(a.head.done=!1),!(1&a.wrap)||(((255&y)<<8)+(y>>8))%31){e.msg="incorrect header check",a.mode=30;break}if(8!=(15&y)){e.msg="unknown compression method",a.mode=30;break}if(_-=4,B=8+(15&(y>>>=4)),0===a.wbits)a.wbits=B;else if(B>a.wbits){e.msg="invalid window size",a.mode=30;break}a.dmax=1<>8&1),512&a.flags&&(R[0]=255&y,R[1]=y>>>8&255,a.check=s(a.check,R,2,0)),_=y=0,a.mode=3;case 3:for(;_<32;){if(0===v)break e;v--,y+=f[g++]<<_,_+=8}a.head&&(a.head.time=y),512&a.flags&&(R[0]=255&y,R[1]=y>>>8&255,R[2]=y>>>16&255,R[3]=y>>>24&255,a.check=s(a.check,R,4,0)),_=y=0,a.mode=4;case 4:for(;_<16;){if(0===v)break e;v--,y+=f[g++]<<_,_+=8}a.head&&(a.head.xflags=255&y,a.head.os=y>>8),512&a.flags&&(R[0]=255&y,R[1]=y>>>8&255,a.check=s(a.check,R,2,0)),_=y=0,a.mode=5;case 5:if(1024&a.flags){for(;_<16;){if(0===v)break e;v--,y+=f[g++]<<_,_+=8}a.length=y,a.head&&(a.head.extra_len=y),512&a.flags&&(R[0]=255&y,R[1]=y>>>8&255,a.check=s(a.check,R,2,0)),_=y=0}else a.head&&(a.head.extra=null);a.mode=6;case 6:if(1024&a.flags&&(v<(x=a.length)&&(x=v),x&&(a.head&&(B=a.head.extra_len-a.length,a.head.extra||(a.head.extra=new Array(a.head.extra_len)),i.arraySet(a.head.extra,f,g,x,B)),512&a.flags&&(a.check=s(a.check,f,x,g)),v-=x,g+=x,a.length-=x),a.length))break e;a.length=0,a.mode=7;case 7:if(2048&a.flags){if(0===v)break e;for(x=0;B=f[g+x++],a.head&&B&&a.length<65536&&(a.head.name+=String.fromCharCode(B)),B&&x>9&1,a.head.done=!0),e.adler=a.check=0,a.mode=12;break;case 10:for(;_<32;){if(0===v)break e;v--,y+=f[g++]<<_,_+=8}e.adler=a.check=p(y),_=y=0,a.mode=11;case 11:if(0===a.havedict)return e.next_out=b,e.avail_out=k,e.next_in=g,e.avail_in=v,a.hold=y,a.bits=_,2;e.adler=a.check=1,a.mode=12;case 12:if(5===t||6===t)break e;case 13:if(a.last){y>>>=7&_,_-=7&_,a.mode=27;break}for(;_<3;){if(0===v)break e;v--,y+=f[g++]<<_,_+=8}switch(a.last=1&y,_-=1,3&(y>>>=1)){case 0:a.mode=14;break;case 1:if(C(a),a.mode=20,6!==t)break;y>>>=2,_-=2;break e;case 2:a.mode=17;break;case 3:e.msg="invalid block type",a.mode=30}y>>>=2,_-=2;break;case 14:for(y>>>=7&_,_-=7&_;_<32;){if(0===v)break e;v--,y+=f[g++]<<_,_+=8}if((65535&y)!=(y>>>16^65535)){e.msg="invalid stored block lengths",a.mode=30;break}if(a.length=65535&y,_=y=0,a.mode=15,6===t)break e;case 15:a.mode=16;case 16:if(x=a.length){if(v>>=5,_-=5,a.ndist=1+(31&y),y>>>=5,_-=5,a.ncode=4+(15&y),y>>>=4,_-=4,286>>=3,_-=3}for(;a.have<19;)a.lens[N[a.have++]]=0;if(a.lencode=a.lendyn,a.lenbits=7,W={bits:a.lenbits},O=o(0,a.lens,0,19,a.lencode,0,a.work,W),a.lenbits=W.bits,O){e.msg="invalid code lengths set",a.mode=30;break}a.have=0,a.mode=19;case 19:for(;a.have>>16&255,I=65535&P,!((E=P>>>24)<=_);){if(0===v)break e;v--,y+=f[g++]<<_,_+=8}if(I<16)y>>>=E,_-=E,a.lens[a.have++]=I;else{if(16===I){for($=E+2;_<$;){if(0===v)break e;v--,y+=f[g++]<<_,_+=8}if(y>>>=E,_-=E,0===a.have){e.msg="invalid bit length repeat",a.mode=30;break}B=a.lens[a.have-1],x=3+(3&y),y>>>=2,_-=2}else if(17===I){for($=E+3;_<$;){if(0===v)break e;v--,y+=f[g++]<<_,_+=8}_-=E,B=0,x=3+(7&(y>>>=E)),y>>>=3,_-=3}else{for($=E+7;_<$;){if(0===v)break e;v--,y+=f[g++]<<_,_+=8}_-=E,B=0,x=11+(127&(y>>>=E)),y>>>=7,_-=7}if(a.have+x>a.nlen+a.ndist){e.msg="invalid bit length repeat",a.mode=30;break}for(;x--;)a.lens[a.have++]=B}}if(30===a.mode)break;if(0===a.lens[256]){e.msg="invalid code -- missing end-of-block",a.mode=30;break}if(a.lenbits=9,W={bits:a.lenbits},O=o(l,a.lens,0,a.nlen,a.lencode,0,a.work,W),a.lenbits=W.bits,O){e.msg="invalid literal/lengths set",a.mode=30;break}if(a.distbits=6,a.distcode=a.distdyn,W={bits:a.distbits},O=o(c,a.lens,a.nlen,a.ndist,a.distcode,0,a.work,W),a.distbits=W.bits,O){e.msg="invalid distances set",a.mode=30;break}if(a.mode=20,6===t)break e;case 20:a.mode=21;case 21:if(6<=v&&258<=k){e.next_out=b,e.avail_out=k,e.next_in=g,e.avail_in=v,a.hold=y,a.bits=_,r(e,F),b=e.next_out,m=e.output,k=e.avail_out,g=e.next_in,f=e.input,v=e.avail_in,y=a.hold,_=a.bits,12===a.mode&&(a.back=-1);break}for(a.back=0;A=(P=a.lencode[y&(1<>>16&255,I=65535&P,!((E=P>>>24)<=_);){if(0===v)break e;v--,y+=f[g++]<<_,_+=8}if(A&&0==(240&A)){for(D=E,U=A,z=I;A=(P=a.lencode[z+((y&(1<>D)])>>>16&255,I=65535&P,!(D+(E=P>>>24)<=_);){if(0===v)break e;v--,y+=f[g++]<<_,_+=8}y>>>=D,_-=D,a.back+=D}if(y>>>=E,_-=E,a.back+=E,a.length=I,0===A){a.mode=26;break}if(32&A){a.back=-1,a.mode=12;break}if(64&A){e.msg="invalid literal/length code",a.mode=30;break}a.extra=15&A,a.mode=22;case 22:if(a.extra){for($=a.extra;_<$;){if(0===v)break e;v--,y+=f[g++]<<_,_+=8}a.length+=y&(1<>>=a.extra,_-=a.extra,a.back+=a.extra}a.was=a.length,a.mode=23;case 23:for(;A=(P=a.distcode[y&(1<>>16&255,I=65535&P,!((E=P>>>24)<=_);){if(0===v)break e;v--,y+=f[g++]<<_,_+=8}if(0==(240&A)){for(D=E,U=A,z=I;A=(P=a.distcode[z+((y&(1<>D)])>>>16&255,I=65535&P,!(D+(E=P>>>24)<=_);){if(0===v)break e;v--,y+=f[g++]<<_,_+=8}y>>>=D,_-=D,a.back+=D}if(y>>>=E,_-=E,a.back+=E,64&A){e.msg="invalid distance code",a.mode=30;break}a.offset=I,a.extra=15&A,a.mode=24;case 24:if(a.extra){for($=a.extra;_<$;){if(0===v)break e;v--,y+=f[g++]<<_,_+=8}a.offset+=y&(1<>>=a.extra,_-=a.extra,a.back+=a.extra}if(a.offset>a.dmax){e.msg="invalid distance too far back",a.mode=30;break}a.mode=25;case 25:if(0===k)break e;if(x=F-k,a.offset>x){if((x=a.offset-x)>a.whave&&a.sane){e.msg="invalid distance too far back",a.mode=30;break}S=x>a.wnext?(x-=a.wnext,a.wsize-x):a.wnext-x,x>a.length&&(x=a.length),L=a.window}else L=m,S=b-a.offset,x=a.length;for(kv?(y=W[$+h[C]],U[z+h[C]]):(y=96,0),f=1<>E)+(m-=f)]=k<<24|y<<16|_,0!==m;);for(f=1<>=1;if(0!==f?(D&=f-1,D+=f):D=0,C++,0==--B[F]){if(F===x)break;F=t[a+h[C]]}if(S>>7)]}function W(e,t){e.pending_buf[e.pending++]=255&t,e.pending_buf[e.pending++]=t>>>8&255}function $(e,t,a){e.bi_valid>p-a?(e.bi_buf|=t<>p-e.bi_valid,e.bi_valid+=a-p):(e.bi_buf|=t<>>=1,a<<=1,0<--t;);return a>>>1}function N(e,t,a){var i,n,s=new Array(m+1),r=0;for(i=1;i<=m;i++)s[i]=r=r+a[i-1]<<1;for(n=0;n<=t;n++){var o=e[2*n+1];0!==o&&(e[2*n]=R(s[o]++,o))}}function j(e){var t;for(t=0;t>1;1<=a;a--)X(e,s,a);for(n=l;a=e.heap[1],e.heap[1]=e.heap[e.heap_len--],X(e,s,1),i=e.heap[1],e.heap[--e.heap_max]=a,e.heap[--e.heap_max]=i,s[2*n]=s[2*a]+s[2*i],e.depth[n]=(e.depth[a]>=e.depth[i]?e.depth[a]:e.depth[i])+1,s[2*a+1]=s[2*i+1]=n,e.heap[1]=n++,X(e,s,1),2<=e.heap_len;);e.heap[--e.heap_max]=e.heap[1],function(e,t){var a,i,n,s,r,o,l=t.dyn_tree,c=t.max_code,d=t.stat_desc.static_tree,h=t.stat_desc.has_stree,u=t.stat_desc.extra_bits,p=t.stat_desc.extra_base,g=t.stat_desc.max_length,b=0;for(s=0;s<=m;s++)e.bl_count[s]=0;for(l[2*e.heap[e.heap_max]+1]=0,a=e.heap_max+1;a>=7;i>>=1)if(1&a&&0!==e.dyn_ltree[2*t])return n;if(0!==e.dyn_ltree[18]||0!==e.dyn_ltree[20]||0!==e.dyn_ltree[26])return s;for(t=32;t>>3,(o=e.static_len+3+7>>>3)<=r&&(r=o)):r=o=a+5,a+4<=r&&-1!==t?Q(e,t,a,i):4===e.strategy||o===r?($(e,2+(i?1:0),3),Z(e,T,x)):($(e,4+(i?1:0),3),function(e,t,a,i){var n;for($(e,t-257,5),$(e,a-1,5),$(e,i-4,4),n=0;n>>8&255,e.pending_buf[e.d_buf+2*e.last_lit+1]=255&t,e.pending_buf[e.l_buf+e.last_lit]=255&a,e.last_lit++,0===t?e.dyn_ltree[2*a]++:(e.matches++,t--,e.dyn_ltree[2*(L[a]+c+1)]++,e.dyn_dtree[2*O(t)]++),e.last_lit===e.lit_bufsize-1},a._tr_align=function(e){$(e,2,3),P(e,b,T),function(e){16===e.bi_valid?(W(e,e.bi_buf),e.bi_buf=0,e.bi_valid=0):8<=e.bi_valid&&(e.pending_buf[e.pending++]=255&e.bi_buf,e.bi_buf>>=8,e.bi_valid-=8)}(e)}},{"../utils/common":41}],53:[function(e,t,a){"use strict";t.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(e,t,i){(function(e){!function(e,t){"use strict";if(!e.setImmediate){var a,i,n,s,r=1,o={},l=!1,c=e.document,d=Object.getPrototypeOf&&Object.getPrototypeOf(e);d=d&&d.setTimeout?d:e,a="[object process]"==={}.toString.call(e.process)?function(e){process.nextTick(function(){u(e)})}:function(){if(e.postMessage&&!e.importScripts){var t=!0,a=e.onmessage;return e.onmessage=function(){t=!1},e.postMessage("","*"),e.onmessage=a,t}}()?(s="setImmediate$"+Math.random()+"$",e.addEventListener?e.addEventListener("message",f,!1):e.attachEvent("onmessage",f),function(t){e.postMessage(s+t,"*")}):e.MessageChannel?((n=new MessageChannel).port1.onmessage=function(e){u(e.data)},function(e){n.port2.postMessage(e)}):c&&"onreadystatechange"in c.createElement("script")?(i=c.documentElement,function(e){var t=c.createElement("script");t.onreadystatechange=function(){u(e),t.onreadystatechange=null,i.removeChild(t),t=null},i.appendChild(t)}):function(e){setTimeout(u,0,e)},d.setImmediate=function(e){"function"!=typeof e&&(e=new Function(""+e));for(var t=new Array(arguments.length-1),i=0;i [$props.modelValue ? (_openBlock(), _createElementBlock(\"div\", {\n key: 0,\n class: \"mobile-drawer-overlay\",\n onClick: _cache[3] || (_cache[3] = (...args) => $options.close && $options.close(...args))\n }, [_createElementVNode(\"div\", {\n class: \"mobile-drawer\",\n onClick: _cache[2] || (_cache[2] = _withModifiers(() => {}, [\"stop\"]))\n }, [_createElementVNode(\"div\", _hoisted_1, [_cache[4] || (_cache[4] = _createElementVNode(\"span\", {\n class: \"mobile-drawer-title\"\n }, \"目录导航\", -1)), _createVNode(_component_font_awesome_icon, {\n icon: \"times\",\n class: \"mobile-drawer-close\",\n onClick: $options.close\n }, null, 8, [\"onClick\"])]), _createElementVNode(\"div\", _hoisted_2, [_createElementVNode(\"div\", {\n class: _normalizeClass([\"mobile-drawer-item\", {\n active: !$props.currentPath\n }]),\n onClick: _cache[0] || (_cache[0] = $event => $options.navigate(''))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"home\",\n class: \"mobile-drawer-item-icon\"\n }), _cache[5] || (_cache[5] = _createElementVNode(\"span\", null, \"根目录\", -1))], 2), (_openBlock(true), _createElementBlock(_Fragment, null, _renderList($options.pathParts, (folder, index) => {\n return _openBlock(), _createElementBlock(\"div\", {\n key: index,\n class: _normalizeClass([\"mobile-drawer-item\", {\n active: index === $options.pathParts.length - 1\n }]),\n style: _normalizeStyle({\n paddingLeft: (index + 1) * 16 + 16 + 'px'\n }),\n onClick: $event => $options.navigate($options.pathParts.slice(0, index + 1).join('/'))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"folder\",\n class: \"mobile-drawer-item-icon\"\n }), _createElementVNode(\"span\", null, _toDisplayString(folder), 1)], 14, _hoisted_3);\n }), 128)), $props.currentPath ? (_openBlock(), _createElementBlock(\"div\", {\n key: 0,\n class: \"mobile-drawer-back\",\n onClick: _cache[1] || (_cache[1] = (...args) => $options.goBack && $options.goBack(...args))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"arrow-left\",\n class: \"mobile-drawer-item-icon\"\n }), _cache[6] || (_cache[6] = _createElementVNode(\"span\", null, \"返回上一级\", -1))])) : _createCommentVNode(\"\", true)])])])) : _createCommentVNode(\"\", true)]),\n _: 1\n })]);\n}","import \"core-js/modules/es.iterator.constructor.js\";\nimport \"core-js/modules/es.iterator.filter.js\";\nexport default {\n name: 'MobileDirectoryDrawer',\n props: {\n modelValue: {\n type: Boolean,\n default: false\n },\n currentPath: {\n type: String,\n default: ''\n }\n },\n emits: ['update:modelValue', 'navigate', 'goBack'],\n computed: {\n pathParts() {\n return this.currentPath.split('/').filter(Boolean);\n }\n },\n methods: {\n close() {\n this.$emit('update:modelValue', false);\n },\n navigate(path) {\n this.$emit('navigate', path);\n this.close();\n },\n goBack() {\n this.$emit('goBack');\n this.close();\n }\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./MobileDirectoryDrawer.vue?vue&type=template&id=2d8e83ec&scoped=true\"\nimport script from \"./MobileDirectoryDrawer.vue?vue&type=script&lang=js\"\nexport * from \"./MobileDirectoryDrawer.vue?vue&type=script&lang=js\"\n\nimport \"./MobileDirectoryDrawer.vue?vue&type=style&index=0&id=2d8e83ec&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-2d8e83ec\"]])\n\nexport default __exports__","import { createElementVNode as _createElementVNode, toDisplayString as _toDisplayString, resolveComponent as _resolveComponent, createVNode as _createVNode, Fragment as _Fragment, openBlock as _openBlock, createElementBlock as _createElementBlock, createCommentVNode as _createCommentVNode, withModifiers as _withModifiers, Transition as _Transition, withCtx as _withCtx, Teleport as _Teleport, createBlock as _createBlock } from \"vue\";\nconst _hoisted_1 = {\n class: \"bottom-sheet-header\"\n};\nconst _hoisted_2 = {\n class: \"bottom-sheet-title\"\n};\nconst _hoisted_3 = {\n class: \"bottom-sheet-content\"\n};\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n return _openBlock(), _createBlock(_Teleport, {\n to: \"body\"\n }, [_createVNode(_Transition, {\n name: \"bottom-sheet\"\n }, {\n default: _withCtx(() => [$props.modelValue ? (_openBlock(), _createElementBlock(\"div\", {\n key: 0,\n class: \"bottom-sheet-overlay\",\n onClick: _cache[9] || (_cache[9] = (...args) => $options.close && $options.close(...args))\n }, [_createElementVNode(\"div\", {\n class: \"bottom-sheet\",\n onClick: _cache[8] || (_cache[8] = _withModifiers(() => {}, [\"stop\"]))\n }, [_createElementVNode(\"div\", _hoisted_1, [_cache[10] || (_cache[10] = _createElementVNode(\"div\", {\n class: \"bottom-sheet-handle\"\n }, null, -1)), _createElementVNode(\"span\", _hoisted_2, _toDisplayString($props.title), 1)]), _createElementVNode(\"div\", _hoisted_3, [!$props.isFolder ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 0\n }, [_createElementVNode(\"div\", {\n class: \"bottom-sheet-item\",\n onClick: _cache[0] || (_cache[0] = $event => $options.handleAction('detail'))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"info-circle\",\n class: \"bottom-sheet-icon\"\n }), _cache[11] || (_cache[11] = _createElementVNode(\"span\", null, \"查看详情\", -1))]), _createElementVNode(\"div\", {\n class: \"bottom-sheet-item\",\n onClick: _cache[1] || (_cache[1] = $event => $options.handleAction('copy'))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"copy\",\n class: \"bottom-sheet-icon\"\n }), _cache[12] || (_cache[12] = _createElementVNode(\"span\", null, \"复制链接\", -1))]), _createElementVNode(\"div\", {\n class: \"bottom-sheet-item\",\n onClick: _cache[2] || (_cache[2] = $event => $options.handleAction('download'))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"download\",\n class: \"bottom-sheet-icon\"\n }), _cache[13] || (_cache[13] = _createElementVNode(\"span\", null, \"下载文件\", -1))]), _createElementVNode(\"div\", {\n class: \"bottom-sheet-item\",\n onClick: _cache[3] || (_cache[3] = $event => $options.handleAction('move'))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"file-export\",\n class: \"bottom-sheet-icon\"\n }), _cache[14] || (_cache[14] = _createElementVNode(\"span\", null, \"移动文件\", -1))]), _createElementVNode(\"div\", {\n class: \"bottom-sheet-item\",\n onClick: _cache[4] || (_cache[4] = $event => $options.handleAction('tag'))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"tags\",\n class: \"bottom-sheet-icon\"\n }), _cache[15] || (_cache[15] = _createElementVNode(\"span\", null, \"标签管理\", -1))])], 64)) : (_openBlock(), _createElementBlock(_Fragment, {\n key: 1\n }, [_createElementVNode(\"div\", {\n class: \"bottom-sheet-item\",\n onClick: _cache[5] || (_cache[5] = $event => $options.handleAction('folderCopy'))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"copy\",\n class: \"bottom-sheet-icon\"\n }), _cache[16] || (_cache[16] = _createElementVNode(\"span\", null, \"复制链接\", -1))]), _createElementVNode(\"div\", {\n class: \"bottom-sheet-item\",\n onClick: _cache[6] || (_cache[6] = $event => $options.handleAction('move'))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"file-export\",\n class: \"bottom-sheet-icon\"\n }), _cache[17] || (_cache[17] = _createElementVNode(\"span\", null, \"移动文件夹\", -1))])], 64)), _createElementVNode(\"div\", {\n class: \"bottom-sheet-item bottom-sheet-danger\",\n onClick: _cache[7] || (_cache[7] = $event => $options.handleAction('delete'))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"trash-alt\",\n class: \"bottom-sheet-icon\"\n }), _createElementVNode(\"span\", null, _toDisplayString($props.isFolder ? '删除文件夹' : '删除文件'), 1)])])])])) : _createCommentVNode(\"\", true)]),\n _: 1\n })]);\n}","export default {\n name: 'MobileActionSheet',\n props: {\n modelValue: {\n type: Boolean,\n default: false\n },\n title: {\n type: String,\n default: ''\n },\n isFolder: {\n type: Boolean,\n default: false\n }\n },\n emits: ['update:modelValue', 'action'],\n methods: {\n close() {\n this.$emit('update:modelValue', false);\n },\n handleAction(action) {\n this.$emit('action', action);\n this.close();\n }\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./MobileActionSheet.vue?vue&type=template&id=7579ad69&scoped=true\"\nimport script from \"./MobileActionSheet.vue?vue&type=script&lang=js\"\nexport * from \"./MobileActionSheet.vue?vue&type=script&lang=js\"\n\nimport \"./MobileActionSheet.vue?vue&type=style&index=0&id=7579ad69&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-7579ad69\"]])\n\nexport default __exports__","import { toDisplayString as _toDisplayString, createElementVNode as _createElementVNode, resolveComponent as _resolveComponent, createVNode as _createVNode, withCtx as _withCtx, withKeys as _withKeys, renderList as _renderList, Fragment as _Fragment, openBlock as _openBlock, createElementBlock as _createElementBlock, createCommentVNode as _createCommentVNode, createTextVNode as _createTextVNode, createBlock as _createBlock } from \"vue\";\nconst _hoisted_1 = {\n class: \"batch-tag-container\"\n};\nconst _hoisted_2 = {\n class: \"tab-content\"\n};\nconst _hoisted_3 = {\n class: \"tab-description\"\n};\nconst _hoisted_4 = {\n class: \"input-section\"\n};\nconst _hoisted_5 = {\n key: 0,\n class: \"suggestions-panel\"\n};\nconst _hoisted_6 = [\"onClick\"];\nconst _hoisted_7 = {\n class: \"tags-to-add-section\"\n};\nconst _hoisted_8 = {\n key: 0,\n class: \"tags-container\"\n};\nconst _hoisted_9 = {\n key: 1,\n class: \"empty-message\"\n};\nconst _hoisted_10 = {\n class: \"action-buttons\"\n};\nconst _hoisted_11 = {\n class: \"tab-content\"\n};\nconst _hoisted_12 = {\n key: 0,\n class: \"common-tags-section\"\n};\nconst _hoisted_13 = {\n class: \"tags-container\"\n};\nconst _hoisted_14 = {\n key: 1,\n class: \"empty-message\"\n};\nconst _hoisted_15 = {\n class: \"tab-content\"\n};\nconst _hoisted_16 = {\n class: \"tab-description\"\n};\nconst _hoisted_17 = {\n class: \"action-buttons\"\n};\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n const _component_el_button = _resolveComponent(\"el-button\");\n const _component_el_input = _resolveComponent(\"el-input\");\n const _component_el_tag = _resolveComponent(\"el-tag\");\n const _component_el_tab_pane = _resolveComponent(\"el-tab-pane\");\n const _component_el_alert = _resolveComponent(\"el-alert\");\n const _component_el_tabs = _resolveComponent(\"el-tabs\");\n const _component_el_dialog = _resolveComponent(\"el-dialog\");\n return _openBlock(), _createBlock(_component_el_dialog, {\n title: \"批量标签管理\",\n modelValue: $options.visible,\n \"onUpdate:modelValue\": _cache[2] || (_cache[2] = $event => $options.visible = $event),\n width: $options.dialogWidth,\n onClose: $options.handleClose\n }, {\n default: _withCtx(() => [_createElementVNode(\"div\", _hoisted_1, [_createVNode(_component_el_tabs, {\n modelValue: $data.activeTab,\n \"onUpdate:modelValue\": _cache[1] || (_cache[1] = $event => $data.activeTab = $event),\n type: \"border-card\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_tab_pane, {\n label: \"添加\",\n name: \"add\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"div\", _hoisted_2, [_createElementVNode(\"p\", _hoisted_3, \"为选中的 \" + _toDisplayString($options.fileCount) + \" 个文件添加标签\", 1), _createElementVNode(\"div\", _hoisted_4, [_createVNode(_component_el_input, {\n modelValue: $data.inputTag,\n \"onUpdate:modelValue\": _cache[0] || (_cache[0] = $event => $data.inputTag = $event),\n placeholder: \"输入标签名称\",\n onKeyup: _withKeys($options.handleAddInputTag, [\"enter\"]),\n onInput: $options.handleInputChange,\n clearable: \"\"\n }, {\n append: _withCtx(() => [_createVNode(_component_el_button, {\n onClick: $options.handleAddInputTag,\n type: \"primary\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"plus\"\n })]),\n _: 1\n }, 8, [\"onClick\"])]),\n _: 1\n }, 8, [\"modelValue\", \"onKeyup\", \"onInput\"]), $data.showSuggestions && $data.suggestions.length > 0 ? (_openBlock(), _createElementBlock(\"div\", _hoisted_5, [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($data.suggestions, tag => {\n return _openBlock(), _createElementBlock(\"div\", {\n key: tag,\n class: \"suggestion-item\",\n onClick: $event => $options.selectSuggestion(tag)\n }, _toDisplayString(tag), 9, _hoisted_6);\n }), 128))])) : _createCommentVNode(\"\", true)]), _createElementVNode(\"div\", _hoisted_7, [_cache[3] || (_cache[3] = _createElementVNode(\"h4\", null, \"待添加的标签\", -1)), $data.tagsToAdd.length > 0 ? (_openBlock(), _createElementBlock(\"div\", _hoisted_8, [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($data.tagsToAdd, tag => {\n return _openBlock(), _createBlock(_component_el_tag, {\n key: tag,\n closable: \"\",\n onClose: $event => $options.removeFromToAdd(tag),\n class: \"tag-item\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString(tag), 1)]),\n _: 2\n }, 1032, [\"onClose\"]);\n }), 128))])) : (_openBlock(), _createElementBlock(\"div\", _hoisted_9, \" 暂无待添加标签 \"))]), _createElementVNode(\"div\", _hoisted_10, [_createVNode(_component_el_button, {\n type: \"primary\",\n onClick: $options.executeAddTags,\n loading: $data.loading,\n disabled: $data.tagsToAdd.length === 0\n }, {\n default: _withCtx(() => [...(_cache[4] || (_cache[4] = [_createTextVNode(\" 添加到所有文件 \", -1)]))]),\n _: 1\n }, 8, [\"onClick\", \"loading\", \"disabled\"])])])]),\n _: 1\n }), _createVNode(_component_el_tab_pane, {\n label: \"移除\",\n name: \"remove\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"div\", _hoisted_11, [_cache[6] || (_cache[6] = _createElementVNode(\"p\", {\n class: \"tab-description\"\n }, \"移除选中文件的共有标签\", -1)), $data.commonTags.length > 0 ? (_openBlock(), _createElementBlock(\"div\", _hoisted_12, [_cache[5] || (_cache[5] = _createElementVNode(\"h4\", null, \"共有标签\", -1)), _createElementVNode(\"div\", _hoisted_13, [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($data.commonTags, tag => {\n return _openBlock(), _createBlock(_component_el_tag, {\n key: tag,\n closable: \"\",\n onClose: $event => $options.handleRemoveCommonTag(tag),\n class: \"tag-item\",\n type: \"warning\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString(tag), 1)]),\n _: 2\n }, 1032, [\"onClose\"]);\n }), 128))])])) : (_openBlock(), _createElementBlock(\"div\", _hoisted_14, \" 选中的文件没有共有标签 \"))])]),\n _: 1\n }), _createVNode(_component_el_tab_pane, {\n label: \"清空\",\n name: \"clear\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"div\", _hoisted_15, [_createElementVNode(\"p\", _hoisted_16, \"清空选中的 \" + _toDisplayString($options.fileCount) + \" 个文件的所有标签\", 1), _createVNode(_component_el_alert, {\n title: \"⚠️警告\",\n type: \"warning\",\n description: \"此操作将清空所有选中文件的标签,且不可恢复\",\n closable: false,\n style: {\n \"margin-bottom\": \"20px\"\n },\n center: \"\"\n }), _createElementVNode(\"div\", _hoisted_17, [_createVNode(_component_el_button, {\n type: \"danger\",\n onClick: $options.handleClearAllTags,\n loading: $data.loading\n }, {\n default: _withCtx(() => [...(_cache[7] || (_cache[7] = [_createTextVNode(\" 确认清空所有标签 \", -1)]))]),\n _: 1\n }, 8, [\"onClick\", \"loading\"])])])]),\n _: 1\n })]),\n _: 1\n }, 8, [\"modelValue\"])])]),\n _: 1\n }, 8, [\"modelValue\", \"width\", \"onClose\"]);\n}","import \"core-js/modules/es.array.push.js\";\nimport \"core-js/modules/es.iterator.constructor.js\";\nimport \"core-js/modules/es.iterator.filter.js\";\nimport \"core-js/modules/es.iterator.map.js\";\nimport \"core-js/modules/es.json.stringify.js\";\nimport { ElMessage, ElMessageBox } from 'element-plus';\nimport fetchWithAuth from '@/utils/fetchWithAuth';\nexport default {\n name: 'BatchTagDialog',\n props: {\n modelValue: {\n type: Boolean,\n default: false\n },\n selectedFiles: {\n type: Array,\n required: true,\n default: () => []\n }\n },\n emits: ['update:modelValue', 'tagsUpdated'],\n data() {\n return {\n activeTab: 'add',\n inputTag: '',\n tagsToAdd: [],\n commonTags: [],\n suggestions: [],\n showSuggestions: false,\n loading: false,\n debounceTimer: null\n };\n },\n computed: {\n visible: {\n get() {\n return this.modelValue;\n },\n set(val) {\n this.$emit('update:modelValue', val);\n }\n },\n dialogWidth() {\n return window.innerWidth < 768 ? '90%' : '600px';\n },\n selectedFilesOnly() {\n // 排除文件夹,只保留文件\n return this.selectedFiles.filter(file => !file.isFolder);\n },\n fileCount() {\n return this.selectedFilesOnly.length;\n },\n fileIds() {\n return this.selectedFilesOnly.map(file => file.name);\n }\n },\n watch: {\n visible(newVal) {\n if (newVal) {\n this.loadCommonTags();\n } else {\n this.resetData();\n }\n },\n activeTab(newTab) {\n if (newTab === 'remove') {\n this.loadCommonTags();\n }\n }\n },\n methods: {\n resetData() {\n this.tagsToAdd = [];\n this.inputTag = '';\n this.showSuggestions = false;\n this.activeTab = 'add';\n },\n async loadCommonTags() {\n if (this.selectedFilesOnly.length === 0) {\n this.commonTags = [];\n return;\n }\n try {\n // 获取所有文件的标签\n const tagPromises = this.selectedFilesOnly.map(file => fetchWithAuth(`/api/manage/tags/${encodeURIComponent(file.name)}`, {\n method: 'GET'\n }));\n const responses = await Promise.all(tagPromises);\n const allTags = [];\n for (const response of responses) {\n if (response.ok) {\n const data = await response.json();\n allTags.push(data.tags || []);\n }\n }\n\n // 找出共有标签\n if (allTags.length > 0) {\n this.commonTags = allTags[0].filter(tag => allTags.every(tags => tags.includes(tag)));\n } else {\n this.commonTags = [];\n }\n } catch (error) {\n console.error('Error loading common tags:', error);\n ElMessage.error('加载共有标签失败');\n }\n },\n handleInputChange() {\n clearTimeout(this.debounceTimer);\n if (!this.inputTag || this.inputTag.trim().length === 0) {\n this.showSuggestions = false;\n return;\n }\n this.debounceTimer = setTimeout(() => {\n this.fetchSuggestions();\n }, 300);\n },\n async fetchSuggestions() {\n try {\n const prefix = this.inputTag.trim().toLowerCase();\n const response = await fetchWithAuth(`/api/manage/tags/autocomplete?prefix=${encodeURIComponent(prefix)}&limit=10`, {\n method: 'GET'\n });\n if (response.ok) {\n const data = await response.json();\n this.suggestions = (data.tags || []).filter(tag => !this.tagsToAdd.includes(tag));\n this.showSuggestions = this.suggestions.length > 0;\n }\n } catch (error) {\n console.error('Error fetching suggestions:', error);\n }\n },\n selectSuggestion(tag) {\n this.inputTag = tag;\n this.showSuggestions = false;\n this.handleAddInputTag();\n },\n handleAddInputTag() {\n const tag = this.inputTag.trim();\n if (!tag) {\n return;\n }\n if (this.tagsToAdd.includes(tag)) {\n ElMessage.warning('标签已在列表中');\n this.inputTag = '';\n this.showSuggestions = false;\n return;\n }\n this.tagsToAdd.push(tag);\n this.inputTag = '';\n this.showSuggestions = false;\n },\n removeFromToAdd(tag) {\n const index = this.tagsToAdd.indexOf(tag);\n if (index > -1) {\n this.tagsToAdd.splice(index, 1);\n }\n },\n async executeAddTags() {\n if (this.tagsToAdd.length === 0) {\n ElMessage.warning('请先添加要批量添加的标签');\n return;\n }\n this.loading = true;\n try {\n const response = await fetchWithAuth('/api/manage/tags/batch', {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json'\n },\n body: JSON.stringify({\n fileIds: this.fileIds,\n action: 'add',\n tags: this.tagsToAdd\n })\n });\n if (response.ok) {\n const data = await response.json();\n if (data.success || data.updated > 0) {\n ElMessage.success(`成功为 ${data.updated} 个文件添加标签`);\n this.$emit('tagsUpdated');\n this.tagsToAdd = [];\n } else {\n throw new Error('批量添加标签失败');\n }\n } else {\n throw new Error('批量添加标签失败');\n }\n } catch (error) {\n console.error('Error adding tags:', error);\n ElMessage.error('批量添加标签失败');\n } finally {\n this.loading = false;\n }\n },\n async handleRemoveCommonTag(tag) {\n this.loading = true;\n try {\n const response = await fetchWithAuth('/api/manage/tags/batch', {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json'\n },\n body: JSON.stringify({\n fileIds: this.fileIds,\n action: 'remove',\n tags: [tag]\n })\n });\n if (response.ok) {\n const data = await response.json();\n if (data.success || data.updated > 0) {\n ElMessage.success(`成功从 ${data.updated} 个文件中移除标签`);\n this.$emit('tagsUpdated');\n await this.loadCommonTags();\n } else {\n throw new Error('移除标签失败');\n }\n } else {\n throw new Error('移除标签失败');\n }\n } catch (error) {\n console.error('Error removing tag:', error);\n ElMessage.error('移除标签失败');\n } finally {\n this.loading = false;\n }\n },\n handleClearAllTags() {\n ElMessageBox.confirm(`确定要清空选中的 ${this.fileCount} 个文件的所有标签吗?此操作不可恢复。`, '确认清空', {\n confirmButtonText: '确定',\n cancelButtonText: '取消',\n type: 'warning'\n }).then(() => {\n this.executeClearTags();\n }).catch(() => {\n ElMessage.info('已取消清空操作');\n });\n },\n async executeClearTags() {\n this.loading = true;\n try {\n const response = await fetchWithAuth('/api/manage/tags/batch', {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json'\n },\n body: JSON.stringify({\n fileIds: this.fileIds,\n action: 'set',\n tags: []\n })\n });\n if (response.ok) {\n const data = await response.json();\n if (data.success || data.updated > 0) {\n ElMessage.success(`成功清空 ${data.updated} 个文件的标签`);\n this.$emit('tagsUpdated');\n this.commonTags = [];\n } else {\n throw new Error('清空标签失败');\n }\n } else {\n throw new Error('清空标签失败');\n }\n } catch (error) {\n console.error('Error clearing tags:', error);\n ElMessage.error('清空标签失败');\n } finally {\n this.loading = false;\n }\n },\n handleClose() {\n this.visible = false;\n }\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./BatchTagDialog.vue?vue&type=template&id=dacf7742&scoped=true\"\nimport script from \"./BatchTagDialog.vue?vue&type=script&lang=js\"\nexport * from \"./BatchTagDialog.vue?vue&type=script&lang=js\"\n\nimport \"./BatchTagDialog.vue?vue&type=style&index=0&id=dacf7742&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-dacf7742\"]])\n\nexport default __exports__","import { resolveComponent as _resolveComponent, createVNode as _createVNode, withCtx as _withCtx, withKeys as _withKeys, renderList as _renderList, Fragment as _Fragment, openBlock as _openBlock, createElementBlock as _createElementBlock, toDisplayString as _toDisplayString, createCommentVNode as _createCommentVNode, createElementVNode as _createElementVNode, createTextVNode as _createTextVNode, createBlock as _createBlock } from \"vue\";\nconst _hoisted_1 = {\n class: \"tag-management-container\"\n};\nconst _hoisted_2 = {\n class: \"input-section\"\n};\nconst _hoisted_3 = {\n key: 0,\n class: \"suggestions-panel\"\n};\nconst _hoisted_4 = [\"onClick\"];\nconst _hoisted_5 = {\n class: \"current-tags-section\"\n};\nconst _hoisted_6 = {\n key: 0,\n class: \"tags-container\"\n};\nconst _hoisted_7 = {\n key: 1,\n class: \"empty-message\"\n};\nconst _hoisted_8 = {\n class: \"popular-tags-section\"\n};\nconst _hoisted_9 = {\n key: 0,\n class: \"tags-container\"\n};\nconst _hoisted_10 = {\n key: 1,\n class: \"empty-message\"\n};\nconst _hoisted_11 = {\n key: 2,\n class: \"empty-message\"\n};\nconst _hoisted_12 = {\n class: \"dialog-footer\"\n};\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n const _component_el_button = _resolveComponent(\"el-button\");\n const _component_el_input = _resolveComponent(\"el-input\");\n const _component_el_tag = _resolveComponent(\"el-tag\");\n const _component_Loading = _resolveComponent(\"Loading\");\n const _component_el_icon = _resolveComponent(\"el-icon\");\n const _component_el_dialog = _resolveComponent(\"el-dialog\");\n return _openBlock(), _createBlock(_component_el_dialog, {\n title: \"标签管理\",\n modelValue: $options.visible,\n \"onUpdate:modelValue\": _cache[1] || (_cache[1] = $event => $options.visible = $event),\n width: $options.dialogWidth,\n onClose: $options.handleClose\n }, {\n footer: _withCtx(() => [_createElementVNode(\"span\", _hoisted_12, [_createVNode(_component_el_button, {\n onClick: $options.handleClose\n }, {\n default: _withCtx(() => [...(_cache[5] || (_cache[5] = [_createTextVNode(\"关闭\", -1)]))]),\n _: 1\n }, 8, [\"onClick\"])])]),\n default: _withCtx(() => [_createElementVNode(\"div\", _hoisted_1, [_createElementVNode(\"div\", _hoisted_2, [_createVNode(_component_el_input, {\n modelValue: $data.inputTag,\n \"onUpdate:modelValue\": _cache[0] || (_cache[0] = $event => $data.inputTag = $event),\n placeholder: \"输入标签名称\",\n onKeyup: _withKeys($options.handleAddTag, [\"enter\"]),\n onInput: $options.handleInputChange,\n clearable: \"\"\n }, {\n append: _withCtx(() => [_createVNode(_component_el_button, {\n onClick: $options.handleAddTag,\n type: \"primary\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"plus\"\n })]),\n _: 1\n }, 8, [\"onClick\"])]),\n _: 1\n }, 8, [\"modelValue\", \"onKeyup\", \"onInput\"]), $data.showSuggestions && $data.suggestions.length > 0 ? (_openBlock(), _createElementBlock(\"div\", _hoisted_3, [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($data.suggestions, tag => {\n return _openBlock(), _createElementBlock(\"div\", {\n key: tag,\n class: \"suggestion-item\",\n onClick: $event => $options.selectSuggestion(tag)\n }, _toDisplayString(tag), 9, _hoisted_4);\n }), 128))])) : _createCommentVNode(\"\", true)]), _createElementVNode(\"div\", _hoisted_5, [_cache[2] || (_cache[2] = _createElementVNode(\"h4\", null, \"当前标签\", -1)), $data.currentTags.length > 0 ? (_openBlock(), _createElementBlock(\"div\", _hoisted_6, [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($data.currentTags, tag => {\n return _openBlock(), _createBlock(_component_el_tag, {\n key: tag,\n closable: \"\",\n onClose: $event => $options.handleRemoveTag(tag),\n class: \"tag-item\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString(tag), 1)]),\n _: 2\n }, 1032, [\"onClose\"]);\n }), 128))])) : (_openBlock(), _createElementBlock(\"div\", _hoisted_7, \" 暂无标签 \"))]), _createElementVNode(\"div\", _hoisted_8, [_cache[4] || (_cache[4] = _createElementVNode(\"h4\", null, \"常用标签\", -1)), $data.popularTags.length > 0 ? (_openBlock(), _createElementBlock(\"div\", _hoisted_9, [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($data.popularTags, tag => {\n return _openBlock(), _createBlock(_component_el_tag, {\n key: tag,\n onClick: $event => $options.handleAddPopularTag(tag),\n class: \"tag-item clickable\",\n type: \"info\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString(tag), 1)]),\n _: 2\n }, 1032, [\"onClick\"]);\n }), 128))])) : $data.loadingPopularTags ? (_openBlock(), _createElementBlock(\"div\", _hoisted_10, [_createVNode(_component_el_icon, {\n class: \"is-loading\"\n }, {\n default: _withCtx(() => [_createVNode(_component_Loading)]),\n _: 1\n }), _cache[3] || (_cache[3] = _createTextVNode(\" 加载中... \", -1))])) : (_openBlock(), _createElementBlock(\"div\", _hoisted_11, \" 暂无常用标签 \"))])])]),\n _: 1\n }, 8, [\"modelValue\", \"width\", \"onClose\"]);\n}","import \"core-js/modules/es.iterator.constructor.js\";\nimport \"core-js/modules/es.iterator.filter.js\";\nimport \"core-js/modules/es.json.stringify.js\";\nimport { ElMessage } from 'element-plus';\nimport { Loading } from '@element-plus/icons-vue';\nimport fetchWithAuth from '@/utils/fetchWithAuth';\nexport default {\n name: 'TagManagementDialog',\n components: {\n Loading\n },\n props: {\n modelValue: {\n type: Boolean,\n default: false\n },\n fileId: {\n type: String,\n required: true\n }\n },\n emits: ['update:modelValue', 'tagsUpdated'],\n data() {\n return {\n currentTags: [],\n inputTag: '',\n suggestions: [],\n popularTags: [],\n showSuggestions: false,\n loading: false,\n loadingPopularTags: false,\n debounceTimer: null\n };\n },\n computed: {\n visible: {\n get() {\n return this.modelValue;\n },\n set(val) {\n this.$emit('update:modelValue', val);\n }\n },\n dialogWidth() {\n return window.innerWidth < 768 ? '90%' : '500px';\n }\n },\n watch: {\n visible(newVal) {\n if (newVal) {\n this.loadFileTags();\n this.loadPopularTags();\n }\n }\n },\n methods: {\n async loadFileTags() {\n try {\n const response = await fetchWithAuth(`/api/manage/tags/${encodeURIComponent(this.fileId)}`, {\n method: 'GET'\n });\n if (response.ok) {\n const data = await response.json();\n this.currentTags = data.tags || [];\n } else {\n throw new Error('Failed to load tags');\n }\n } catch (error) {\n console.error('Error loading file tags:', error);\n ElMessage.error('加载标签失败');\n }\n },\n async loadPopularTags() {\n this.loadingPopularTags = true;\n try {\n const response = await fetchWithAuth('/api/manage/tags/autocomplete?limit=20', {\n method: 'GET'\n });\n if (response.ok) {\n const data = await response.json();\n this.popularTags = (data.tags || []).filter(tag => !this.currentTags.includes(tag));\n }\n } catch (error) {\n console.error('Error loading popular tags:', error);\n } finally {\n this.loadingPopularTags = false;\n }\n },\n handleInputChange() {\n clearTimeout(this.debounceTimer);\n if (!this.inputTag || this.inputTag.trim().length === 0) {\n this.showSuggestions = false;\n return;\n }\n this.debounceTimer = setTimeout(() => {\n this.fetchSuggestions();\n }, 300);\n },\n async fetchSuggestions() {\n try {\n const prefix = this.inputTag.trim().toLowerCase();\n const response = await fetchWithAuth(`/api/manage/tags/autocomplete?prefix=${encodeURIComponent(prefix)}&limit=10`, {\n method: 'GET'\n });\n if (response.ok) {\n const data = await response.json();\n this.suggestions = (data.tags || []).filter(tag => !this.currentTags.includes(tag));\n this.showSuggestions = this.suggestions.length > 0;\n }\n } catch (error) {\n console.error('Error fetching suggestions:', error);\n }\n },\n selectSuggestion(tag) {\n this.inputTag = tag;\n this.showSuggestions = false;\n this.handleAddTag();\n },\n async handleAddTag() {\n const tag = this.inputTag.trim();\n if (!tag) {\n return;\n }\n if (this.currentTags.includes(tag)) {\n ElMessage.warning('标签已存在');\n this.inputTag = '';\n this.showSuggestions = false;\n return;\n }\n try {\n const response = await fetchWithAuth(`/api/manage/tags/${encodeURIComponent(this.fileId)}`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json'\n },\n body: JSON.stringify({\n action: 'add',\n tags: [tag]\n })\n });\n if (response.ok) {\n const data = await response.json();\n this.currentTags = data.tags || [];\n this.inputTag = '';\n this.showSuggestions = false;\n ElMessage.success('标签添加成功');\n this.$emit('tagsUpdated', this.currentTags);\n\n // 重新加载常用标签\n this.loadPopularTags();\n } else {\n const error = await response.json();\n throw new Error(error.message || '添加标签失败');\n }\n } catch (error) {\n console.error('Error adding tag:', error);\n ElMessage.error(error.message || '添加标签失败');\n }\n },\n async handleRemoveTag(tag) {\n try {\n const response = await fetchWithAuth(`/api/manage/tags/${encodeURIComponent(this.fileId)}`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json'\n },\n body: JSON.stringify({\n action: 'remove',\n tags: [tag]\n })\n });\n if (response.ok) {\n const data = await response.json();\n this.currentTags = data.tags || [];\n ElMessage.success('标签删除成功');\n this.$emit('tagsUpdated', this.currentTags);\n\n // 重新加载常用标签\n this.loadPopularTags();\n } else {\n throw new Error('删除标签失败');\n }\n } catch (error) {\n console.error('Error removing tag:', error);\n ElMessage.error('删除标签失败');\n }\n },\n handleAddPopularTag(tag) {\n this.inputTag = tag;\n this.handleAddTag();\n },\n handleClose() {\n this.visible = false;\n this.inputTag = '';\n this.showSuggestions = false;\n this.currentTags = [];\n this.popularTags = [];\n }\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./TagManagementDialog.vue?vue&type=template&id=8b4291b4&scoped=true\"\nimport script from \"./TagManagementDialog.vue?vue&type=script&lang=js\"\nexport * from \"./TagManagementDialog.vue?vue&type=script&lang=js\"\n\nimport \"./TagManagementDialog.vue?vue&type=style&index=0&id=8b4291b4&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-8b4291b4\"]])\n\nexport default __exports__","import { resolveComponent as _resolveComponent, createVNode as _createVNode, createTextVNode as _createTextVNode, withCtx as _withCtx, createElementVNode as _createElementVNode, openBlock as _openBlock, createBlock as _createBlock, createCommentVNode as _createCommentVNode, createElementBlock as _createElementBlock, toDisplayString as _toDisplayString, renderList as _renderList, Fragment as _Fragment } from \"vue\";\nconst _hoisted_1 = {\n class: \"detail-actions\"\n};\nconst _hoisted_2 = {\n class: \"preview-section\"\n};\nconst _hoisted_3 = {\n class: \"preview-content\"\n};\nconst _hoisted_4 = [\"src\"];\nconst _hoisted_5 = [\"src\"];\nconst _hoisted_6 = {\n key: 0,\n style: {\n \"display\": \"flex\",\n \"flex-wrap\": \"wrap\",\n \"gap\": \"5px\"\n }\n};\nconst _hoisted_7 = {\n key: 1,\n style: {\n \"color\": \"#909399\"\n }\n};\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n const _component_el_button = _resolveComponent(\"el-button\");\n const _component_el_input = _resolveComponent(\"el-input\");\n const _component_el_tab_pane = _resolveComponent(\"el-tab-pane\");\n const _component_el_tabs = _resolveComponent(\"el-tabs\");\n const _component_el_image = _resolveComponent(\"el-image\");\n const _component_el_descriptions_item = _resolveComponent(\"el-descriptions-item\");\n const _component_el_tag = _resolveComponent(\"el-tag\");\n const _component_el_descriptions = _resolveComponent(\"el-descriptions\");\n const _component_el_dialog = _resolveComponent(\"el-dialog\");\n return _openBlock(), _createBlock(_component_el_dialog, {\n title: \"文件详情\",\n modelValue: $options.visible,\n \"onUpdate:modelValue\": _cache[14] || (_cache[14] = $event => $options.visible = $event),\n width: $options.dialogWidth\n }, {\n default: _withCtx(() => [_createElementVNode(\"div\", _hoisted_1, [_createVNode(_component_el_button, {\n type: \"primary\",\n onClick: _cache[0] || (_cache[0] = $event => _ctx.$emit('download')),\n round: \"\",\n size: \"small\",\n class: \"detail-action\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"download\",\n style: {\n \"margin-right\": \"3px\"\n }\n }), _cache[15] || (_cache[15] = _createTextVNode(\" 下载 \", -1))]),\n _: 1\n }), _createVNode(_component_el_button, {\n type: \"primary\",\n onClick: _cache[1] || (_cache[1] = $event => _ctx.$emit('tagManagement')),\n round: \"\",\n size: \"small\",\n class: \"detail-action\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"tags\",\n style: {\n \"margin-right\": \"3px\"\n }\n }), _cache[16] || (_cache[16] = _createTextVNode(\" 标签 \", -1))]),\n _: 1\n }), _createVNode(_component_el_button, {\n type: \"primary\",\n onClick: _cache[2] || (_cache[2] = $event => _ctx.$emit('block')),\n round: \"\",\n size: \"small\",\n class: \"detail-action\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"ban\",\n style: {\n \"margin-right\": \"3px\"\n }\n }), _cache[17] || (_cache[17] = _createTextVNode(\" 黑名单 \", -1))]),\n _: 1\n }), _createVNode(_component_el_button, {\n type: \"primary\",\n onClick: _cache[3] || (_cache[3] = $event => _ctx.$emit('white')),\n round: \"\",\n size: \"small\",\n class: \"detail-action\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"user-plus\",\n style: {\n \"margin-right\": \"3px\"\n }\n }), _cache[18] || (_cache[18] = _createTextVNode(\" 白名单 \", -1))]),\n _: 1\n }), _createVNode(_component_el_button, {\n type: \"danger\",\n onClick: _cache[4] || (_cache[4] = $event => _ctx.$emit('delete')),\n round: \"\",\n size: \"small\",\n class: \"detail-action\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"trash-alt\",\n style: {\n \"margin-right\": \"3px\"\n }\n }), _cache[19] || (_cache[19] = _createTextVNode(\" 删除 \", -1))]),\n _: 1\n })]), _createVNode(_component_el_tabs, {\n modelValue: $data.activeTab,\n \"onUpdate:modelValue\": _cache[12] || (_cache[12] = $event => $data.activeTab = $event),\n onTabClick: $options.handleTabClick,\n style: {\n \"margin-bottom\": \"10px\"\n }\n }, {\n default: _withCtx(() => [_createVNode(_component_el_tab_pane, {\n label: \"原始链接\",\n name: \"originUrl\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $props.urls.originUrl,\n \"onUpdate:modelValue\": _cache[5] || (_cache[5] = $event => $props.urls.originUrl = $event),\n readonly: \"\",\n onClick: $options.handleUrlClick\n }, null, 8, [\"modelValue\", \"onClick\"])]),\n _: 1\n }), _createVNode(_component_el_tab_pane, {\n label: \"Markdown\",\n name: \"mdUrl\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $props.urls.mdUrl,\n \"onUpdate:modelValue\": _cache[6] || (_cache[6] = $event => $props.urls.mdUrl = $event),\n readonly: \"\",\n onClick: $options.handleUrlClick\n }, null, 8, [\"modelValue\", \"onClick\"])]),\n _: 1\n }), _createVNode(_component_el_tab_pane, {\n label: \"HTML\",\n name: \"htmlUrl\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $props.urls.htmlUrl,\n \"onUpdate:modelValue\": _cache[7] || (_cache[7] = $event => $props.urls.htmlUrl = $event),\n readonly: \"\",\n onClick: $options.handleUrlClick\n }, null, 8, [\"modelValue\", \"onClick\"])]),\n _: 1\n }), _createVNode(_component_el_tab_pane, {\n label: \"BBCode\",\n name: \"bbUrl\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $props.urls.bbUrl,\n \"onUpdate:modelValue\": _cache[8] || (_cache[8] = $event => $props.urls.bbUrl = $event),\n readonly: \"\",\n onClick: $options.handleUrlClick\n }, null, 8, [\"modelValue\", \"onClick\"])]),\n _: 1\n }), $props.file?.metadata?.TgFileId ? (_openBlock(), _createBlock(_component_el_tab_pane, {\n key: 0,\n label: \"TG File ID\",\n name: \"tgId\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $props.urls.tgId,\n \"onUpdate:modelValue\": _cache[9] || (_cache[9] = $event => $props.urls.tgId = $event),\n readonly: \"\",\n onClick: $options.handleUrlClick\n }, null, 8, [\"modelValue\", \"onClick\"])]),\n _: 1\n })) : _createCommentVNode(\"\", true), $props.file?.metadata?.S3Location ? (_openBlock(), _createBlock(_component_el_tab_pane, {\n key: 1,\n label: \"S3 Location\",\n name: \"s3Location\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $props.urls.S3Location,\n \"onUpdate:modelValue\": _cache[10] || (_cache[10] = $event => $props.urls.S3Location = $event),\n readonly: \"\",\n onClick: $options.handleUrlClick\n }, null, 8, [\"modelValue\", \"onClick\"])]),\n _: 1\n })) : _createCommentVNode(\"\", true), $props.file?.metadata?.S3CdnFileUrl ? (_openBlock(), _createBlock(_component_el_tab_pane, {\n key: 2,\n label: \"S3 CDN URL\",\n name: \"s3CdnFileUrl\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_input, {\n modelValue: $props.urls.S3CdnFileUrl,\n \"onUpdate:modelValue\": _cache[11] || (_cache[11] = $event => $props.urls.S3CdnFileUrl = $event),\n readonly: \"\",\n onClick: $options.handleUrlClick\n }, null, 8, [\"modelValue\", \"onClick\"])]),\n _: 1\n })) : _createCommentVNode(\"\", true)]),\n _: 1\n }, 8, [\"modelValue\", \"onTabClick\"]), _createElementVNode(\"div\", _hoisted_2, [_createElementVNode(\"div\", _hoisted_3, [$options.isVideo ? (_openBlock(), _createElementBlock(\"video\", {\n key: 0,\n src: $props.fileLink,\n autoplay: \"\",\n muted: \"\",\n loop: \"\",\n class: \"video-preview\",\n onClick: _cache[13] || (_cache[13] = (...args) => $options.openImageLink && $options.openImageLink(...args))\n }, null, 8, _hoisted_4)) : $options.isAudio ? (_openBlock(), _createElementBlock(\"audio\", {\n key: 1,\n src: $props.fileLink,\n controls: \"\",\n autoplay: \"\",\n class: \"audio-preview\"\n }, null, 8, _hoisted_5)) : $options.isImage ? (_openBlock(), _createBlock(_component_el_image, {\n key: 2,\n src: $props.fileLink,\n \"preview-src-list\": [$props.fileLink],\n \"preview-teleported\": true,\n fit: \"contain\",\n lazy: \"\",\n class: \"image-preview\"\n }, null, 8, [\"src\", \"preview-src-list\"])) : (_openBlock(), _createBlock(_component_font_awesome_icon, {\n key: 3,\n icon: \"file\",\n class: \"file-icon-detail\"\n }))])]), _createVNode(_component_el_descriptions, {\n border: \"\",\n column: $options.descColumn\n }, {\n default: _withCtx(() => [_createVNode(_component_el_descriptions_item, {\n label: \"文件名\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($props.file?.metadata?.FileName || $props.file?.name), 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"文件类型\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($props.file?.metadata?.FileType || '未知'), 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"文件大小\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($props.file?.metadata?.FileSize ? $props.file.metadata.FileSize + ' MB' : '未知'), 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"上传时间\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($options.uploadTime), 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"渠道类型/名称\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($props.file?.metadata?.Channel || '未知') + \" / \" + _toDisplayString($props.file?.metadata?.ChannelName || '-'), 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"访问状态/审查\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($options.accessType) + \" / \" + _toDisplayString($props.file?.metadata?.Label || '无'), 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"上传IP\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($props.file?.metadata?.UploadIP || '未知'), 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"上传地址\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString($props.file?.metadata?.UploadAddress || '未知'), 1)]),\n _: 1\n }), _createVNode(_component_el_descriptions_item, {\n label: \"文件标签\"\n }, {\n default: _withCtx(() => [$props.file?.metadata?.Tags && $props.file?.metadata?.Tags.length > 0 ? (_openBlock(), _createElementBlock(\"div\", _hoisted_6, [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($props.file?.metadata?.Tags, tag => {\n return _openBlock(), _createBlock(_component_el_tag, {\n key: tag,\n size: \"small\"\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString(tag), 1)]),\n _: 2\n }, 1024);\n }), 128))])) : (_openBlock(), _createElementBlock(\"span\", _hoisted_7, \"暂无标签\"))]),\n _: 1\n })]),\n _: 1\n }, 8, [\"column\"])]),\n _: 1\n }, 8, [\"modelValue\", \"width\"]);\n}","import { ElMessage } from 'element-plus';\nexport default {\n name: 'FileDetailDialog',\n props: {\n modelValue: {\n type: Boolean,\n default: false\n },\n file: {\n type: Object,\n default: null\n },\n fileLink: {\n type: String,\n default: ''\n },\n urls: {\n type: Object,\n default: () => ({\n originUrl: '',\n mdUrl: '',\n htmlUrl: '',\n bbUrl: '',\n tgId: '',\n S3Location: '',\n S3CdnFileUrl: ''\n })\n }\n },\n emits: ['update:modelValue', 'download', 'tagManagement', 'block', 'white', 'delete'],\n data() {\n return {\n activeTab: 'originUrl'\n };\n },\n computed: {\n visible: {\n get() {\n return this.modelValue;\n },\n set(val) {\n this.$emit('update:modelValue', val);\n }\n },\n dialogWidth() {\n return window.innerWidth < 768 ? '95%' : '900px';\n },\n descColumn() {\n return window.innerWidth < 768 ? 1 : 2;\n },\n isVideo() {\n // 先通过 content-type 判断\n const fileType = this.file?.metadata?.FileType?.toLowerCase() || '';\n if (fileType.includes('video')) return true;\n // 再通过文件后缀判断\n const name = this.file?.name?.toLowerCase() || '';\n return name.endsWith('.mp4') || name.endsWith('.webm') || name.endsWith('.mov') || name.endsWith('.avi');\n },\n isAudio() {\n // 先通过 content-type 判断\n const fileType = this.file?.metadata?.FileType?.toLowerCase() || '';\n if (fileType.includes('audio')) return true;\n // 再通过文件后缀判断\n const name = this.file?.name?.toLowerCase() || '';\n return name.endsWith('.mp3') || name.endsWith('.wav') || name.endsWith('.ogg') || name.endsWith('.flac');\n },\n isImage() {\n // 先通过 content-type 判断\n const fileType = this.file?.metadata?.FileType?.toLowerCase() || '';\n if (fileType.includes('image')) return true;\n // 再通过文件后缀判断\n const name = this.file?.name?.toLowerCase() || '';\n return name.endsWith('.jpg') || name.endsWith('.jpeg') || name.endsWith('.png') || name.endsWith('.gif') || name.endsWith('.webp') || name.endsWith('.svg') || name.endsWith('.bmp') || name.endsWith('.avif') || name.endsWith('.heic') || name.endsWith('.heif');\n },\n uploadTime() {\n if (this.file?.metadata?.TimeStamp) {\n return new Date(this.file.metadata.TimeStamp).toLocaleString();\n }\n return '未知';\n },\n accessType() {\n const listType = this.file?.metadata?.ListType;\n const label = this.file?.metadata?.Label;\n if (listType === 'White') return '正常(白名单)';\n if (listType === 'Block') return '已屏蔽(黑名单)';\n if (label === 'adult') return '已屏蔽(审查不通过)';\n return '正常';\n }\n },\n methods: {\n handleVideoClick(e) {\n const video = e.target;\n if (video.paused) video.play();else video.pause();\n },\n handleTabClick() {},\n handleUrlClick(e) {\n const input = e.target;\n input.select();\n navigator.clipboard.writeText(input.value).then(() => {\n ElMessage.success('链接已复制');\n });\n },\n openImageLink() {\n if (this.fileLink) {\n // 移除 ?from=admin 参数\n const cleanUrl = this.fileLink.replace(/\\?from=admin$/, '');\n window.open(cleanUrl, '_blank');\n }\n }\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./FileDetailDialog.vue?vue&type=template&id=0dc381fc&scoped=true\"\nimport script from \"./FileDetailDialog.vue?vue&type=script&lang=js\"\nexport * from \"./FileDetailDialog.vue?vue&type=script&lang=js\"\n\nimport \"./FileDetailDialog.vue?vue&type=style&index=0&id=0dc381fc&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-0dc381fc\"]])\n\nexport default __exports__","import { resolveComponent as _resolveComponent, openBlock as _openBlock, createBlock as _createBlock, createCommentVNode as _createCommentVNode, withModifiers as _withModifiers, normalizeClass as _normalizeClass, createElementVNode as _createElementVNode, createElementBlock as _createElementBlock, toDisplayString as _toDisplayString, renderList as _renderList, Fragment as _Fragment, normalizeStyle as _normalizeStyle, createVNode as _createVNode, withCtx as _withCtx } from \"vue\";\nconst _hoisted_1 = {\n class: \"list-col list-col-checkbox\"\n};\nconst _hoisted_2 = [\"src\"];\nconst _hoisted_3 = [\"src\"];\nconst _hoisted_4 = [\"title\"];\nconst _hoisted_5 = {\n class: \"filename-start\"\n};\nconst _hoisted_6 = {\n class: \"filename-end\"\n};\nconst _hoisted_7 = {\n class: \"list-col list-col-tags\"\n};\nconst _hoisted_8 = {\n key: 1,\n class: \"list-empty\"\n};\nconst _hoisted_9 = {\n class: \"list-col list-col-channel\"\n};\nconst _hoisted_10 = {\n class: \"list-col list-col-channel-name\"\n};\nconst _hoisted_11 = {\n key: 0,\n class: \"channel-name-box\"\n};\nconst _hoisted_12 = {\n key: 1,\n class: \"list-empty\"\n};\nconst _hoisted_13 = {\n class: \"list-col list-col-address\"\n};\nconst _hoisted_14 = {\n key: 0,\n class: \"address-box\"\n};\nconst _hoisted_15 = {\n key: 1,\n class: \"list-empty\"\n};\nconst _hoisted_16 = {\n class: \"list-col list-col-size\"\n};\nconst _hoisted_17 = {\n class: \"list-col list-col-date\"\n};\nconst _hoisted_18 = {\n class: \"list-col list-col-actions\"\n};\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n const _component_el_tooltip = _resolveComponent(\"el-tooltip\");\n return _openBlock(), _createElementBlock(\"div\", {\n class: \"list-item\",\n onTouchstart: _cache[9] || (_cache[9] = $event => _ctx.$emit('touchstart', $event)),\n onTouchend: _cache[10] || (_cache[10] = $event => _ctx.$emit('touchend', $event)),\n onTouchmove: _cache[11] || (_cache[11] = $event => _ctx.$emit('touchmove', $event))\n }, [_createElementVNode(\"div\", _hoisted_1, [_createElementVNode(\"span\", {\n class: _normalizeClass([\"custom-checkbox\", {\n 'checked': $data.localSelected\n }]),\n onClick: _cache[0] || (_cache[0] = _withModifiers((...args) => $options.toggleSelect && $options.toggleSelect(...args), [\"stop\"]))\n }, [$data.localSelected ? (_openBlock(), _createBlock(_component_font_awesome_icon, {\n key: 0,\n icon: \"check\",\n class: \"check-icon\"\n })) : _createCommentVNode(\"\", true)], 2)]), _createElementVNode(\"div\", {\n class: \"list-col list-col-preview\",\n onClick: _cache[1] || (_cache[1] = (...args) => $options.handlePreviewClick && $options.handlePreviewClick(...args))\n }, [$options.isFolder ? (_openBlock(), _createBlock(_component_font_awesome_icon, {\n key: 0,\n icon: \"folder-open\",\n class: \"list-folder-icon\"\n })) : $options.isVideo ? (_openBlock(), _createElementBlock(\"video\", {\n key: 1,\n src: $props.fileLink,\n class: \"list-preview-img\",\n muted: \"\",\n preload: \"metadata\"\n }, null, 8, _hoisted_2)) : $options.isImage ? (_openBlock(), _createElementBlock(\"img\", {\n key: 2,\n src: $props.fileLink,\n class: \"list-preview-img\",\n loading: \"lazy\",\n decoding: \"async\"\n }, null, 8, _hoisted_3)) : (_openBlock(), _createBlock(_component_font_awesome_icon, {\n key: 3,\n icon: \"file\",\n class: \"list-file-icon\"\n }))]), _createElementVNode(\"div\", {\n class: \"list-col list-col-name\",\n onClick: _cache[2] || (_cache[2] = (...args) => $options.handlePreviewClick && $options.handlePreviewClick(...args))\n }, [_createElementVNode(\"span\", {\n class: \"filename-ellipsis\",\n title: $options.displayName\n }, [_createElementVNode(\"span\", _hoisted_5, _toDisplayString($options.fileNameStart), 1), _createElementVNode(\"span\", _hoisted_6, _toDisplayString($options.fileNameEnd), 1)], 8, _hoisted_4)]), _createElementVNode(\"div\", _hoisted_7, [!$options.isFolder && $props.item.metadata?.Tags && $props.item.metadata.Tags.length > 0 ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 0\n }, [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($props.item.metadata.Tags.slice(0, 3), (tag, tagIndex) => {\n return _openBlock(), _createElementBlock(\"span\", {\n key: tagIndex,\n class: \"color-tag\",\n style: _normalizeStyle({\n background: $options.getTagColor(tagIndex)\n })\n }, _toDisplayString(tag), 5);\n }), 128)), $props.item.metadata.Tags.length > 3 ? (_openBlock(), _createElementBlock(\"span\", {\n key: 0,\n class: \"color-tag color-tag-more\",\n style: _normalizeStyle({\n background: $options.getTagColor(3)\n })\n }, \"+\" + _toDisplayString($props.item.metadata.Tags.length - 3), 5)) : _createCommentVNode(\"\", true)], 64)) : (_openBlock(), _createElementBlock(\"span\", _hoisted_8, \"-\"))]), _createElementVNode(\"div\", _hoisted_9, _toDisplayString($options.isFolder ? '-' : $props.item.metadata?.Channel || $props.item.channelTag || '-'), 1), _createElementVNode(\"div\", _hoisted_10, [!$options.isFolder && $props.item.metadata?.ChannelName ? (_openBlock(), _createElementBlock(\"div\", _hoisted_11, _toDisplayString($props.item.metadata.ChannelName), 1)) : (_openBlock(), _createElementBlock(\"span\", _hoisted_12, \"-\"))]), _createElementVNode(\"div\", _hoisted_13, [!$options.isFolder && $props.item.metadata?.UploadIP ? (_openBlock(), _createElementBlock(\"div\", _hoisted_14, _toDisplayString($props.item.metadata.UploadIP), 1)) : (_openBlock(), _createElementBlock(\"span\", _hoisted_15, \"-\"))]), _createElementVNode(\"div\", _hoisted_16, _toDisplayString($options.isFolder ? '-' : $props.item.metadata?.FileSize ? $props.item.metadata.FileSize + ' MB' : '-'), 1), _createElementVNode(\"div\", _hoisted_17, _toDisplayString($options.uploadDate), 1), _createElementVNode(\"div\", _hoisted_18, [!$options.isFolder ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 0\n }, [_createVNode(_component_el_tooltip, {\n content: \"复制链接\",\n placement: \"top\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"button\", {\n class: \"list-action-btn\",\n onClick: _cache[3] || (_cache[3] = _withModifiers($event => _ctx.$emit('copy'), [\"stop\"]))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"copy\"\n })])]),\n _: 1\n }), _createVNode(_component_el_tooltip, {\n content: \"下载\",\n placement: \"top\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"button\", {\n class: \"list-action-btn\",\n onClick: _cache[4] || (_cache[4] = _withModifiers($event => _ctx.$emit('download'), [\"stop\"]))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"download\"\n })])]),\n _: 1\n }), _createVNode(_component_el_tooltip, {\n content: \"移动\",\n placement: \"top\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"button\", {\n class: \"list-action-btn\",\n onClick: _cache[5] || (_cache[5] = _withModifiers($event => _ctx.$emit('move'), [\"stop\"]))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"file-export\"\n })])]),\n _: 1\n })], 64)) : (_openBlock(), _createElementBlock(_Fragment, {\n key: 1\n }, [_createVNode(_component_el_tooltip, {\n content: \"复制链接\",\n placement: \"top\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"button\", {\n class: \"list-action-btn\",\n onClick: _cache[6] || (_cache[6] = _withModifiers($event => _ctx.$emit('folderCopy'), [\"stop\"]))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"copy\"\n })])]),\n _: 1\n }), _createVNode(_component_el_tooltip, {\n content: \"移动\",\n placement: \"top\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"button\", {\n class: \"list-action-btn\",\n onClick: _cache[7] || (_cache[7] = _withModifiers($event => _ctx.$emit('move'), [\"stop\"]))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"file-export\"\n })])]),\n _: 1\n })], 64)), _createVNode(_component_el_tooltip, {\n content: \"删除\",\n placement: \"top\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"button\", {\n class: \"list-action-btn list-action-danger\",\n onClick: _cache[8] || (_cache[8] = _withModifiers($event => _ctx.$emit('delete'), [\"stop\"]))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"trash-alt\"\n })])]),\n _: 1\n })])], 32);\n}","import \"core-js/modules/es.iterator.constructor.js\";\nimport \"core-js/modules/es.iterator.filter.js\";\nexport default {\n name: 'FileListItem',\n props: {\n item: {\n type: Object,\n required: true\n },\n selected: {\n type: Boolean,\n default: false\n },\n fileLink: {\n type: String,\n default: ''\n }\n },\n emits: ['update:selected', 'enter', 'detail', 'copy', 'folderCopy', 'move', 'delete', 'download', 'touchstart', 'touchend', 'touchmove'],\n data() {\n return {\n localSelected: this.selected,\n tagColors: ['#f472b6', '#a78bfa', '#60a5fa', '#34d399']\n };\n },\n computed: {\n isFolder() {\n return this.item.name?.endsWith('/');\n },\n isVideo() {\n const name = this.item.name?.toLowerCase() || '';\n return name.endsWith('.mp4') || name.endsWith('.webm') || name.endsWith('.mov') || name.endsWith('.avi');\n },\n isImage() {\n const name = this.item.name?.toLowerCase() || '';\n return name.endsWith('.jpg') || name.endsWith('.jpeg') || name.endsWith('.png') || name.endsWith('.gif') || name.endsWith('.webp') || name.endsWith('.svg') || name.endsWith('.bmp');\n },\n displayName() {\n if (this.isFolder) {\n const parts = this.item.name.split('/').filter(Boolean);\n return parts[parts.length - 1] || this.item.name;\n }\n return this.item.metadata?.FileName || this.getFileName(this.item.name);\n },\n fileNameStart() {\n const name = this.displayName;\n if (name.length <= 20) return name;\n return name.slice(0, -8);\n },\n fileNameEnd() {\n const name = this.displayName;\n if (name.length <= 20) return '';\n return name.slice(-8);\n },\n uploadDate() {\n if (this.item.uploaded) {\n return new Date(this.item.uploaded).toLocaleDateString();\n }\n if (this.item.metadata?.TimeStamp) {\n return new Date(this.item.metadata.TimeStamp).toLocaleDateString();\n }\n return '-';\n }\n },\n watch: {\n selected(val) {\n this.localSelected = val;\n }\n },\n methods: {\n toggleSelect() {\n this.localSelected = !this.localSelected;\n this.$emit('update:selected', this.localSelected);\n },\n handlePreviewClick() {\n if (this.isFolder) {\n this.$emit('enter');\n } else {\n this.$emit('detail');\n }\n },\n getFileName(name) {\n const parts = (name || '').split('/');\n return parts[parts.length - 1];\n },\n getTagColor(index) {\n return this.tagColors[index % this.tagColors.length];\n }\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./FileListItem.vue?vue&type=template&id=9968e9fe&scoped=true\"\nimport script from \"./FileListItem.vue?vue&type=script&lang=js\"\nexport * from \"./FileListItem.vue?vue&type=script&lang=js\"\n\nimport \"./FileListItem.vue?vue&type=style&index=0&id=9968e9fe&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-9968e9fe\"]])\n\nexport default __exports__","import { resolveComponent as _resolveComponent, createVNode as _createVNode, toDisplayString as _toDisplayString, openBlock as _openBlock, createElementBlock as _createElementBlock, createCommentVNode as _createCommentVNode, createTextVNode as _createTextVNode, createElementVNode as _createElementVNode, vShow as _vShow, withDirectives as _withDirectives, Fragment as _Fragment, withModifiers as _withModifiers, withCtx as _withCtx, createBlock as _createBlock } from \"vue\";\nconst _hoisted_1 = {\n class: \"file-short-info\"\n};\nconst _hoisted_2 = {\n key: 0,\n class: \"success-tag\"\n};\nconst _hoisted_3 = {\n key: 1,\n class: \"fail-tag\"\n};\nconst _hoisted_4 = {\n key: 2,\n class: \"success-tag\"\n};\nconst _hoisted_5 = {\n key: 3,\n class: \"primary-tag\"\n};\nconst _hoisted_6 = {\n key: 0,\n style: {\n \"margin-left\": \"2px\"\n }\n};\nconst _hoisted_7 = {\n key: 0,\n class: \"skeleton-wrapper\"\n};\nconst _hoisted_8 = [\"src\"];\nconst _hoisted_9 = {\n key: 3,\n class: \"file-preview\"\n};\nconst _hoisted_10 = {\n class: \"card-bottom-overlay\"\n};\nconst _hoisted_11 = {\n class: \"file-name-row\"\n};\nconst _hoisted_12 = {\n class: \"file-name\"\n};\nconst _hoisted_13 = {\n class: \"action-bar\"\n};\nconst _hoisted_14 = {\n class: \"action-bar-left\"\n};\nconst _hoisted_15 = {\n class: \"action-bar-right\"\n};\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_el_checkbox = _resolveComponent(\"el-checkbox\");\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n const _component_el_image = _resolveComponent(\"el-image\");\n const _component_el_tooltip = _resolveComponent(\"el-tooltip\");\n const _component_el_card = _resolveComponent(\"el-card\");\n return _openBlock(), _createBlock(_component_el_card, {\n class: \"img-card\",\n onTouchstart: _cache[17] || (_cache[17] = $event => _ctx.$emit('touchstart', $event)),\n onTouchend: _cache[18] || (_cache[18] = $event => _ctx.$emit('touchend', $event)),\n onTouchmove: _cache[19] || (_cache[19] = $event => _ctx.$emit('touchmove', $event))\n }, {\n default: _withCtx(() => [_createVNode(_component_el_checkbox, {\n modelValue: $data.localSelected,\n \"onUpdate:modelValue\": _cache[0] || (_cache[0] = $event => $data.localSelected = $event),\n onChange: _cache[1] || (_cache[1] = $event => _ctx.$emit('update:selected', $data.localSelected))\n }, null, 8, [\"modelValue\"]), _createElementVNode(\"div\", _hoisted_1, [$props.item.metadata?.ListType === 'White' ? (_openBlock(), _createElementBlock(\"div\", _hoisted_2, _toDisplayString($options.channelTag), 1)) : $props.item.metadata?.ListType === 'Block' || $props.item.metadata?.Label === 'adult' ? (_openBlock(), _createElementBlock(\"div\", _hoisted_3, _toDisplayString($options.channelTag), 1)) : (_openBlock(), _createElementBlock(\"div\", _hoisted_4, _toDisplayString($options.channelTag), 1)), $props.item.metadata?.Tags && $props.item.metadata?.Tags.length > 0 ? (_openBlock(), _createElementBlock(\"div\", _hoisted_5, [_createVNode(_component_font_awesome_icon, {\n icon: \"tag\",\n style: {\n \"margin-right\": \"3px\",\n \"font-size\": \"12px\"\n }\n }), _createTextVNode(\" \" + _toDisplayString($props.item.metadata.Tags[0]) + \" \", 1), $props.item.metadata.Tags.length > 1 ? (_openBlock(), _createElementBlock(\"span\", _hoisted_6, \" (+\" + _toDisplayString($props.item.metadata.Tags.length - 1) + \") \", 1)) : _createCommentVNode(\"\", true)])) : _createCommentVNode(\"\", true)]), $options.isVideo ? (_openBlock(), _createElementBlock(_Fragment, {\n key: 0\n }, [$data.videoLoading ? (_openBlock(), _createElementBlock(\"div\", _hoisted_7)) : $data.videoError ? (_openBlock(), _createElementBlock(\"div\", {\n key: 1,\n class: \"error-wrapper\",\n onClick: _cache[2] || (_cache[2] = $event => _ctx.$emit('detail'))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"exclamation-triangle\",\n class: \"error-icon\"\n }), _cache[20] || (_cache[20] = _createElementVNode(\"span\", {\n class: \"error-text\"\n }, \"加载失败\", -1))])) : _createCommentVNode(\"\", true), _withDirectives(_createElementVNode(\"video\", {\n src: $props.fileLink,\n muted: \"\",\n loop: \"\",\n preload: \"metadata\",\n class: \"video-preview\",\n onClick: _cache[3] || (_cache[3] = (...args) => $options.handleVideoClick && $options.handleVideoClick(...args)),\n onMouseenter: _cache[4] || (_cache[4] = $event => $options.handleVideoHover($event, true)),\n onMouseleave: _cache[5] || (_cache[5] = $event => $options.handleVideoHover($event, false)),\n onFullscreenchange: _cache[6] || (_cache[6] = (...args) => $options.handleFullscreenChange && $options.handleFullscreenChange(...args)),\n onWebkitfullscreenchange: _cache[7] || (_cache[7] = (...args) => $options.handleFullscreenChange && $options.handleFullscreenChange(...args)),\n onLoadeddata: _cache[8] || (_cache[8] = $event => $data.videoLoading = false),\n onError: _cache[9] || (_cache[9] = (...args) => $options.handleVideoError && $options.handleVideoError(...args))\n }, null, 40, _hoisted_8), [[_vShow, !$data.videoLoading && !$data.videoError]])], 64)) : $options.isAudio ? (_openBlock(), _createElementBlock(\"div\", {\n key: 1,\n class: \"file-preview audio-card-preview\",\n onClick: _cache[10] || (_cache[10] = $event => _ctx.$emit('detail'))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"music\",\n class: \"file-icon audio-icon\"\n })])) : $options.isImage ? (_openBlock(), _createBlock(_component_el_image, {\n key: 2,\n \"preview-teleported\": true,\n src: $props.fileLink,\n \"preview-src-list\": $props.previewSrcList,\n fit: \"cover\",\n lazy: \"\",\n class: \"image-preview\"\n }, {\n placeholder: _withCtx(() => [...(_cache[21] || (_cache[21] = [_createElementVNode(\"div\", {\n class: \"skeleton-wrapper\"\n }, null, -1)]))]),\n error: _withCtx(() => [_createElementVNode(\"div\", {\n class: \"error-wrapper\",\n onClick: _cache[11] || (_cache[11] = _withModifiers($event => _ctx.$emit('detail'), [\"stop\"]))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"image\",\n class: \"error-icon\"\n }), _cache[22] || (_cache[22] = _createElementVNode(\"span\", {\n class: \"error-text\"\n }, \"加载失败\", -1))])]),\n _: 1\n }, 8, [\"src\", \"preview-src-list\"])) : (_openBlock(), _createElementBlock(\"div\", _hoisted_9, [_createVNode(_component_font_awesome_icon, {\n icon: \"file\",\n class: \"file-icon\"\n })])), _createElementVNode(\"div\", _hoisted_10, [_createElementVNode(\"div\", _hoisted_11, [_createElementVNode(\"span\", _hoisted_12, _toDisplayString($options.displayName), 1)]), _createElementVNode(\"div\", _hoisted_13, [_createElementVNode(\"div\", _hoisted_14, [_createVNode(_component_el_tooltip, {\n disabled: $props.disableTooltip,\n content: \"详情\",\n placement: \"top\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"button\", {\n class: \"action-btn\",\n onClick: _cache[12] || (_cache[12] = _withModifiers($event => _ctx.$emit('detail'), [\"stop\"]))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"info-circle\"\n })])]),\n _: 1\n }, 8, [\"disabled\"])]), _createElementVNode(\"div\", _hoisted_15, [_createVNode(_component_el_tooltip, {\n disabled: $props.disableTooltip,\n content: \"移动\",\n placement: \"top\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"button\", {\n class: \"action-btn\",\n onClick: _cache[13] || (_cache[13] = _withModifiers($event => _ctx.$emit('move'), [\"stop\"]))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"file-export\"\n })])]),\n _: 1\n }, 8, [\"disabled\"]), _createVNode(_component_el_tooltip, {\n disabled: $props.disableTooltip,\n content: \"删除\",\n placement: \"top\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"button\", {\n class: \"action-btn action-btn-danger\",\n onClick: _cache[14] || (_cache[14] = _withModifiers($event => _ctx.$emit('delete'), [\"stop\"]))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"trash-alt\"\n })])]),\n _: 1\n }, 8, [\"disabled\"]), _createVNode(_component_el_tooltip, {\n disabled: $props.disableTooltip,\n content: \"下载\",\n placement: \"top\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"button\", {\n class: \"action-btn\",\n onClick: _cache[15] || (_cache[15] = _withModifiers($event => _ctx.$emit('download'), [\"stop\"]))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"download\"\n })])]),\n _: 1\n }, 8, [\"disabled\"]), _createVNode(_component_el_tooltip, {\n disabled: $props.disableTooltip,\n content: \"复制链接\",\n placement: \"top\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"button\", {\n class: \"action-btn\",\n onClick: _cache[16] || (_cache[16] = _withModifiers($event => _ctx.$emit('copy'), [\"stop\"]))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"copy\"\n })])]),\n _: 1\n }, 8, [\"disabled\"])])])])]),\n _: 1\n });\n}","export default {\n name: 'FileCard',\n props: {\n item: {\n type: Object,\n required: true\n },\n selected: {\n type: Boolean,\n default: false\n },\n fileLink: {\n type: String,\n required: true\n },\n previewSrcList: {\n type: Array,\n default: () => []\n },\n disableTooltip: {\n type: Boolean,\n default: false\n }\n },\n emits: ['update:selected', 'detail', 'copy', 'move', 'delete', 'download', 'touchstart', 'touchend', 'touchmove'],\n data() {\n return {\n localSelected: this.selected,\n videoLoading: true,\n videoError: false\n };\n },\n computed: {\n channelTag() {\n return this.item.channelTag || '';\n },\n isVideo() {\n // 先通过 content-type 判断\n const fileType = this.item.metadata?.FileType?.toLowerCase() || '';\n if (fileType.includes('video')) return true;\n // 再通过文件后缀判断\n const name = this.item.name?.toLowerCase() || '';\n return name.endsWith('.mp4') || name.endsWith('.webm') || name.endsWith('.mov') || name.endsWith('.avi');\n },\n isAudio() {\n // 先通过 content-type 判断\n const fileType = this.item.metadata?.FileType?.toLowerCase() || '';\n if (fileType.includes('audio')) return true;\n // 再通过文件后缀判断\n const name = this.item.name?.toLowerCase() || '';\n return name.endsWith('.mp3') || name.endsWith('.wav') || name.endsWith('.ogg') || name.endsWith('.flac');\n },\n isImage() {\n // 先通过 content-type 判断\n const fileType = this.item.metadata?.FileType?.toLowerCase() || '';\n if (fileType.includes('image')) return true;\n // 再通过文件后缀判断\n const name = this.item.name?.toLowerCase() || '';\n return name.endsWith('.jpg') || name.endsWith('.jpeg') || name.endsWith('.png') || name.endsWith('.gif') || name.endsWith('.webp') || name.endsWith('.svg') || name.endsWith('.bmp') || name.endsWith('.avif') || name.endsWith('.heic') || name.endsWith('.heif');\n },\n displayName() {\n const fileName = this.item.metadata?.FileName || this.item.name || '';\n const parts = fileName.split('/');\n return parts[parts.length - 1];\n }\n },\n watch: {\n selected(val) {\n this.localSelected = val;\n },\n fileLink() {\n // 链接变化时重置加载状态\n this.videoLoading = true;\n this.videoError = false;\n }\n },\n methods: {\n handleVideoError() {\n this.videoLoading = false;\n this.videoError = true;\n },\n handleVideoClick(e) {\n const video = e.target;\n if (video.requestFullscreen) {\n video.requestFullscreen();\n } else if (video.webkitRequestFullscreen) {\n video.webkitRequestFullscreen();\n } else if (video.mozRequestFullScreen) {\n video.mozRequestFullScreen();\n } else if (video.msRequestFullscreen) {\n video.msRequestFullscreen();\n }\n },\n handleFullscreenChange(e) {\n const video = e.target;\n const isFullscreen = document.fullscreenElement || document.webkitFullscreenElement || document.mozFullScreenElement || document.msFullscreenElement;\n if (isFullscreen) {\n // 进入全屏:取消静音和循环\n video.muted = false;\n video.loop = false;\n } else {\n // 退出全屏:恢复静音和循环,暂停并重置\n video.muted = true;\n video.loop = true;\n video.pause();\n video.currentTime = 0;\n }\n },\n handleVideoHover(e, isEnter) {\n const video = e.target;\n if (isEnter) {\n video.play().catch(() => {});\n } else {\n video.pause();\n video.currentTime = 0;\n }\n }\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./FileCard.vue?vue&type=template&id=ddf49ce2&scoped=true\"\nimport script from \"./FileCard.vue?vue&type=script&lang=js\"\nexport * from \"./FileCard.vue?vue&type=script&lang=js\"\n\nimport \"./FileCard.vue?vue&type=style&index=0&id=ddf49ce2&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-ddf49ce2\"]])\n\nexport default __exports__","import { resolveComponent as _resolveComponent, createVNode as _createVNode, createElementVNode as _createElementVNode, toDisplayString as _toDisplayString, withModifiers as _withModifiers, withCtx as _withCtx, openBlock as _openBlock, createElementBlock as _createElementBlock, createCommentVNode as _createCommentVNode, createBlock as _createBlock } from \"vue\";\nconst _hoisted_1 = {\n class: \"card-bottom-overlay\"\n};\nconst _hoisted_2 = {\n class: \"file-name-row\"\n};\nconst _hoisted_3 = {\n class: \"file-name\"\n};\nconst _hoisted_4 = {\n key: 0,\n class: \"action-bar\"\n};\nconst _hoisted_5 = {\n class: \"action-bar-right\"\n};\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_el_checkbox = _resolveComponent(\"el-checkbox\");\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n const _component_el_tooltip = _resolveComponent(\"el-tooltip\");\n const _component_el_card = _resolveComponent(\"el-card\");\n return _openBlock(), _createBlock(_component_el_card, {\n class: \"img-card folder-card\",\n onTouchstart: _cache[6] || (_cache[6] = $event => _ctx.$emit('touchstart', $event)),\n onTouchend: _cache[7] || (_cache[7] = $event => _ctx.$emit('touchend', $event)),\n onTouchmove: _cache[8] || (_cache[8] = $event => _ctx.$emit('touchmove', $event))\n }, {\n default: _withCtx(() => [_createVNode(_component_el_checkbox, {\n modelValue: $data.localSelected,\n \"onUpdate:modelValue\": _cache[0] || (_cache[0] = $event => $data.localSelected = $event),\n onChange: _cache[1] || (_cache[1] = $event => _ctx.$emit('update:selected', $data.localSelected))\n }, null, 8, [\"modelValue\"]), _createElementVNode(\"div\", {\n class: \"folder-icon\",\n onClick: _cache[2] || (_cache[2] = $event => _ctx.$emit('enter'))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"folder-open\",\n class: \"folder-icon-svg\"\n })]), _createElementVNode(\"div\", _hoisted_1, [_createElementVNode(\"div\", _hoisted_2, [_createElementVNode(\"span\", _hoisted_3, _toDisplayString($options.folderName), 1)]), $props.showActions ? (_openBlock(), _createElementBlock(\"div\", _hoisted_4, [_cache[9] || (_cache[9] = _createElementVNode(\"div\", {\n class: \"action-bar-left\"\n }, null, -1)), _createElementVNode(\"div\", _hoisted_5, [_createVNode(_component_el_tooltip, {\n disabled: $props.disableTooltip,\n content: \"复制链接\",\n placement: \"top\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"button\", {\n class: \"action-btn\",\n onClick: _cache[3] || (_cache[3] = _withModifiers($event => _ctx.$emit('copy'), [\"stop\"]))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"copy\"\n })])]),\n _: 1\n }, 8, [\"disabled\"]), _createVNode(_component_el_tooltip, {\n disabled: $props.disableTooltip,\n content: \"移动\",\n placement: \"top\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"button\", {\n class: \"action-btn\",\n onClick: _cache[4] || (_cache[4] = _withModifiers($event => _ctx.$emit('move'), [\"stop\"]))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"file-export\"\n })])]),\n _: 1\n }, 8, [\"disabled\"]), _createVNode(_component_el_tooltip, {\n disabled: $props.disableTooltip,\n content: \"删除\",\n placement: \"top\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"button\", {\n class: \"action-btn action-btn-danger\",\n onClick: _cache[5] || (_cache[5] = _withModifiers($event => _ctx.$emit('delete'), [\"stop\"]))\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"trash-alt\"\n })])]),\n _: 1\n }, 8, [\"disabled\"])])])) : _createCommentVNode(\"\", true)])]),\n _: 1\n });\n}","import \"core-js/modules/es.iterator.constructor.js\";\nimport \"core-js/modules/es.iterator.filter.js\";\nexport default {\n name: 'FolderCard',\n props: {\n name: {\n type: String,\n required: true\n },\n selected: {\n type: Boolean,\n default: false\n },\n showActions: {\n type: Boolean,\n default: true\n },\n disableTooltip: {\n type: Boolean,\n default: false\n }\n },\n emits: ['update:selected', 'enter', 'copy', 'move', 'delete', 'touchstart', 'touchend', 'touchmove'],\n data() {\n return {\n localSelected: this.selected\n };\n },\n computed: {\n folderName() {\n const parts = this.name.split('/').filter(Boolean);\n return parts[parts.length - 1] || this.name;\n }\n },\n watch: {\n selected(val) {\n this.localSelected = val;\n }\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./FolderCard.vue?vue&type=template&id=20e5d6b4&scoped=true\"\nimport script from \"./FolderCard.vue?vue&type=script&lang=js\"\nexport * from \"./FolderCard.vue?vue&type=script&lang=js\"\n\nimport \"./FolderCard.vue?vue&type=style&index=0&id=20e5d6b4&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-20e5d6b4\"]])\n\nexport default __exports__","import { renderList as _renderList, Fragment as _Fragment, openBlock as _openBlock, createElementBlock as _createElementBlock, createElementVNode as _createElementVNode, createCommentVNode as _createCommentVNode, createStaticVNode as _createStaticVNode } from \"vue\";\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n return $props.type === 'card' ? (_openBlock(true), _createElementBlock(_Fragment, {\n key: 0\n }, _renderList($props.count, i => {\n return _openBlock(), _createElementBlock(\"div\", {\n key: 'skeleton-' + i,\n class: \"skeleton-card\"\n }, [...(_cache[0] || (_cache[0] = [_createElementVNode(\"div\", {\n class: \"skeleton-image\"\n }, null, -1), _createElementVNode(\"div\", {\n class: \"skeleton-info\"\n }, [_createElementVNode(\"div\", {\n class: \"skeleton-text\"\n })], -1)]))]);\n }), 128)) : $props.type === 'list' ? (_openBlock(true), _createElementBlock(_Fragment, {\n key: 1\n }, _renderList($props.count, i => {\n return _openBlock(), _createElementBlock(\"div\", {\n key: 'list-skeleton-' + i,\n class: \"list-item skeleton-list-item\"\n }, [...(_cache[1] || (_cache[1] = [_createStaticVNode(\"
\", 10)]))]);\n }), 128)) : _createCommentVNode(\"\", true);\n}","export default {\n name: 'SkeletonLoader',\n props: {\n type: {\n type: String,\n default: 'card',\n validator: value => ['card', 'list'].includes(value)\n },\n count: {\n type: Number,\n default: 15\n }\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./SkeletonLoader.vue?vue&type=template&id=71848b62&scoped=true\"\nimport script from \"./SkeletonLoader.vue?vue&type=script&lang=js\"\nexport * from \"./SkeletonLoader.vue?vue&type=script&lang=js\"\n\nimport \"./SkeletonLoader.vue?vue&type=style&index=0&id=71848b62&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-71848b62\"]])\n\nexport default __exports__","import { resolveComponent as _resolveComponent, createVNode as _createVNode, withCtx as _withCtx, createElementVNode as _createElementVNode, renderList as _renderList, Fragment as _Fragment, openBlock as _openBlock, createElementBlock as _createElementBlock, toDisplayString as _toDisplayString, createTextVNode as _createTextVNode, createBlock as _createBlock, createCommentVNode as _createCommentVNode } from \"vue\";\nconst _hoisted_1 = {\n class: \"el-dropdown-link filter-trigger\"\n};\nconst _hoisted_2 = {\n class: \"filter-section\"\n};\nconst _hoisted_3 = {\n class: \"filter-options\"\n};\nconst _hoisted_4 = {\n class: \"filter-section\"\n};\nconst _hoisted_5 = {\n class: \"filter-options\"\n};\nconst _hoisted_6 = {\n class: \"filter-section\"\n};\nconst _hoisted_7 = {\n class: \"filter-options\"\n};\nconst _hoisted_8 = {\n class: \"filter-section\"\n};\nconst _hoisted_9 = {\n class: \"filter-options\"\n};\nconst _hoisted_10 = {\n class: \"filter-section\"\n};\nconst _hoisted_11 = {\n class: \"filter-options\"\n};\nconst _hoisted_12 = {\n key: 0,\n class: \"filter-section\"\n};\nconst _hoisted_13 = {\n class: \"filter-options\"\n};\nconst _hoisted_14 = {\n key: 0,\n class: \"channel-divider\"\n};\nconst _hoisted_15 = {\n class: \"channel-group-title\"\n};\nconst _hoisted_16 = {\n class: \"filter-actions\"\n};\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n const _component_el_badge = _resolveComponent(\"el-badge\");\n const _component_el_checkbox = _resolveComponent(\"el-checkbox\");\n const _component_el_checkbox_group = _resolveComponent(\"el-checkbox-group\");\n const _component_el_button = _resolveComponent(\"el-button\");\n const _component_el_dropdown_menu = _resolveComponent(\"el-dropdown-menu\");\n const _component_el_dropdown = _resolveComponent(\"el-dropdown\");\n return _openBlock(), _createBlock(_component_el_dropdown, {\n \"hide-on-click\": false,\n trigger: \"click\",\n class: \"filter-dropdown\",\n ref: \"dropdownRef\"\n }, {\n dropdown: _withCtx(() => [_createVNode(_component_el_dropdown_menu, {\n class: \"filter-dropdown-menu\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"div\", _hoisted_2, [_cache[12] || (_cache[12] = _createElementVNode(\"div\", {\n class: \"filter-title\"\n }, \"访问状态\", -1)), _createElementVNode(\"div\", _hoisted_3, [_createVNode(_component_el_checkbox_group, {\n modelValue: $data.localFilters.accessStatus,\n \"onUpdate:modelValue\": _cache[0] || (_cache[0] = $event => $data.localFilters.accessStatus = $event),\n onChange: _cache[1] || (_cache[1] = $event => $options.handleFilterChange('accessStatus'))\n }, {\n default: _withCtx(() => [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($data.accessStatusOptions, option => {\n return _openBlock(), _createBlock(_component_el_checkbox, {\n key: 'accessStatus-' + option.value,\n label: option.value\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString(option.label), 1)]),\n _: 2\n }, 1032, [\"label\"]);\n }), 128))]),\n _: 1\n }, 8, [\"modelValue\"])])]), _createElementVNode(\"div\", _hoisted_4, [_cache[13] || (_cache[13] = _createElementVNode(\"div\", {\n class: \"filter-title\"\n }, \"黑白名单\", -1)), _createElementVNode(\"div\", _hoisted_5, [_createVNode(_component_el_checkbox_group, {\n modelValue: $data.localFilters.listType,\n \"onUpdate:modelValue\": _cache[2] || (_cache[2] = $event => $data.localFilters.listType = $event),\n onChange: _cache[3] || (_cache[3] = $event => $options.handleFilterChange('listType'))\n }, {\n default: _withCtx(() => [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($data.listTypeOptions, option => {\n return _openBlock(), _createBlock(_component_el_checkbox, {\n key: 'listType-' + option.value,\n label: option.value\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString(option.label), 1)]),\n _: 2\n }, 1032, [\"label\"]);\n }), 128))]),\n _: 1\n }, 8, [\"modelValue\"])])]), _createElementVNode(\"div\", _hoisted_6, [_cache[14] || (_cache[14] = _createElementVNode(\"div\", {\n class: \"filter-title\"\n }, \"审查结果\", -1)), _createElementVNode(\"div\", _hoisted_7, [_createVNode(_component_el_checkbox_group, {\n modelValue: $data.localFilters.label,\n \"onUpdate:modelValue\": _cache[4] || (_cache[4] = $event => $data.localFilters.label = $event),\n onChange: _cache[5] || (_cache[5] = $event => $options.handleFilterChange('label'))\n }, {\n default: _withCtx(() => [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($data.labelOptions, option => {\n return _openBlock(), _createBlock(_component_el_checkbox, {\n key: 'label-' + option.value,\n label: option.value\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString(option.label), 1)]),\n _: 2\n }, 1032, [\"label\"]);\n }), 128))]),\n _: 1\n }, 8, [\"modelValue\"])])]), _createElementVNode(\"div\", _hoisted_8, [_cache[15] || (_cache[15] = _createElementVNode(\"div\", {\n class: \"filter-title\"\n }, \"文件类型\", -1)), _createElementVNode(\"div\", _hoisted_9, [_createVNode(_component_el_checkbox_group, {\n modelValue: $data.localFilters.fileType,\n \"onUpdate:modelValue\": _cache[6] || (_cache[6] = $event => $data.localFilters.fileType = $event),\n onChange: _cache[7] || (_cache[7] = $event => $options.handleFilterChange('fileType'))\n }, {\n default: _withCtx(() => [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($data.fileTypeOptions, option => {\n return _openBlock(), _createBlock(_component_el_checkbox, {\n key: 'fileType-' + option.value,\n label: option.value\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString(option.label), 1)]),\n _: 2\n }, 1032, [\"label\"]);\n }), 128))]),\n _: 1\n }, 8, [\"modelValue\"])])]), _createElementVNode(\"div\", _hoisted_10, [_cache[16] || (_cache[16] = _createElementVNode(\"div\", {\n class: \"filter-title\"\n }, \"渠道类型\", -1)), _createElementVNode(\"div\", _hoisted_11, [_createVNode(_component_el_checkbox_group, {\n modelValue: $data.localFilters.channel,\n \"onUpdate:modelValue\": _cache[8] || (_cache[8] = $event => $data.localFilters.channel = $event),\n onChange: _cache[9] || (_cache[9] = $event => $options.handleFilterChange('channel'))\n }, {\n default: _withCtx(() => [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($data.channelOptions, option => {\n return _openBlock(), _createBlock(_component_el_checkbox, {\n key: 'channel-' + option.value,\n label: option.value\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString(option.label), 1)]),\n _: 2\n }, 1032, [\"label\"]);\n }), 128))]),\n _: 1\n }, 8, [\"modelValue\"])])]), $props.channelNameOptions.length > 0 ? (_openBlock(), _createElementBlock(\"div\", _hoisted_12, [_cache[17] || (_cache[17] = _createElementVNode(\"div\", {\n class: \"filter-title\"\n }, \"渠道名称\", -1)), _createElementVNode(\"div\", _hoisted_13, [_createVNode(_component_el_checkbox_group, {\n modelValue: $data.localFilters.channelName,\n \"onUpdate:modelValue\": _cache[10] || (_cache[10] = $event => $data.localFilters.channelName = $event),\n onChange: _cache[11] || (_cache[11] = $event => $options.handleFilterChange('channelName'))\n }, {\n default: _withCtx(() => [(_openBlock(true), _createElementBlock(_Fragment, null, _renderList($options.groupedChannelNames, (group, index) => {\n return _openBlock(), _createElementBlock(_Fragment, {\n key: 'group-' + group.type\n }, [index > 0 ? (_openBlock(), _createElementBlock(\"div\", _hoisted_14)) : _createCommentVNode(\"\", true), _createElementVNode(\"div\", _hoisted_15, _toDisplayString(group.typeLabel), 1), (_openBlock(true), _createElementBlock(_Fragment, null, _renderList(group.channels, option => {\n return _openBlock(), _createBlock(_component_el_checkbox, {\n key: 'channelName-' + option.type + '-' + option.name,\n label: option.type + ':' + option.name\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString(option.name), 1)]),\n _: 2\n }, 1032, [\"label\"]);\n }), 128))], 64);\n }), 128))]),\n _: 1\n }, 8, [\"modelValue\"])])])) : _createCommentVNode(\"\", true), _createElementVNode(\"div\", _hoisted_16, [_createVNode(_component_el_button, {\n size: \"small\",\n onClick: $options.clearFilters,\n disabled: $options.activeFilterCount === 0\n }, {\n default: _withCtx(() => [...(_cache[18] || (_cache[18] = [_createTextVNode(\"清除筛选\", -1)]))]),\n _: 1\n }, 8, [\"onClick\", \"disabled\"])])]),\n _: 1\n })]),\n default: _withCtx(() => [_createElementVNode(\"span\", _hoisted_1, [_createVNode(_component_el_badge, {\n value: $options.activeFilterCount,\n hidden: $options.activeFilterCount === 0,\n class: \"filter-badge\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"filter\",\n class: \"header-icon\"\n })]),\n _: 1\n }, 8, [\"value\", \"hidden\"])])]),\n _: 1\n }, 512);\n}","import \"core-js/modules/es.array.push.js\";\nimport \"core-js/modules/es.iterator.constructor.js\";\nimport \"core-js/modules/es.iterator.for-each.js\";\nimport \"core-js/modules/es.iterator.reduce.js\";\nexport default {\n name: 'FilterDropdown',\n props: {\n filters: {\n type: Object,\n default: () => ({\n accessStatus: [],\n // 访问状态: 'normal'(正常), 'blocked'(已屏蔽)\n listType: [],\n // 黑白名单: 'White', 'Block', 'none'\n label: [],\n fileType: [],\n channel: [],\n channelName: []\n })\n },\n channelNameOptions: {\n type: Array,\n default: () => []\n }\n },\n emits: ['update:filters', 'change'],\n data() {\n return {\n // 访问状态选项(综合判断 ListType 和 Label)\n // 正常: ListType !== 'Block' && Label !== 'adult'\n // 已屏蔽: ListType === 'Block' || Label === 'adult'\n accessStatusOptions: [{\n label: '正常',\n value: 'normal'\n }, {\n label: '已屏蔽',\n value: 'blocked'\n }],\n // 黑白名单选项(直接使用 ListType 字段值)\n listTypeOptions: [{\n label: '白名单',\n value: 'White'\n }, {\n label: '黑名单',\n value: 'Block'\n }, {\n label: '未设置',\n value: 'None'\n }],\n // 审查结果选项\n // 参考 FileDetailDialog: adult=已屏蔽(审查不通过), 其他=正常\n labelOptions: [{\n label: '正常',\n value: 'normal'\n }, {\n label: '12+内容',\n value: 'teen'\n }, {\n label: '成人内容',\n value: 'adult'\n }],\n fileTypeOptions: [{\n label: '图片',\n value: 'image'\n }, {\n label: '视频',\n value: 'video'\n }, {\n label: '音频',\n value: 'audio'\n }, {\n label: '其他',\n value: 'other'\n }],\n channelOptions: [{\n label: 'Telegram',\n value: 'TelegramNew'\n }, {\n label: 'Cloudflare R2',\n value: 'CloudflareR2'\n }, {\n label: 'S3',\n value: 'S3'\n }, {\n label: 'Discord',\n value: 'Discord'\n }, {\n label: 'HuggingFace',\n value: 'HuggingFace'\n }, {\n label: '外链',\n value: 'External'\n }],\n localFilters: {\n accessStatus: [],\n listType: [],\n label: [],\n fileType: [],\n channel: [],\n channelName: []\n }\n };\n },\n computed: {\n activeFilterCount() {\n return Object.values(this.localFilters).reduce((count, arr) => count + arr.length, 0);\n },\n // 按类型分组渠道名称\n groupedChannelNames() {\n const groups = {};\n this.channelNameOptions.forEach(option => {\n if (!groups[option.type]) {\n groups[option.type] = {\n type: option.type,\n typeLabel: option.typeLabel,\n channels: []\n };\n }\n groups[option.type].channels.push(option);\n });\n return Object.values(groups);\n }\n },\n watch: {\n filters: {\n handler(newFilters) {\n this.localFilters = {\n accessStatus: Array.isArray(newFilters.accessStatus) ? [...newFilters.accessStatus] : [],\n listType: Array.isArray(newFilters.listType) ? [...newFilters.listType] : [],\n label: Array.isArray(newFilters.label) ? [...newFilters.label] : [],\n fileType: Array.isArray(newFilters.fileType) ? [...newFilters.fileType] : [],\n channel: Array.isArray(newFilters.channel) ? [...newFilters.channel] : [],\n channelName: Array.isArray(newFilters.channelName) ? [...newFilters.channelName] : []\n };\n },\n immediate: true,\n deep: true\n }\n },\n methods: {\n handleFilterChange(type) {\n this.$emit('update:filters', {\n ...this.localFilters\n });\n this.$emit('change', {\n type,\n filters: {\n ...this.localFilters\n }\n });\n },\n clearFilters() {\n this.localFilters = {\n accessStatus: [],\n listType: [],\n label: [],\n fileType: [],\n channel: [],\n channelName: []\n };\n this.$emit('update:filters', {\n ...this.localFilters\n });\n this.$emit('change', {\n type: 'clear',\n filters: {\n ...this.localFilters\n }\n });\n }\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./FilterDropdown.vue?vue&type=template&id=062d5f10&scoped=true\"\nimport script from \"./FilterDropdown.vue?vue&type=script&lang=js\"\nexport * from \"./FilterDropdown.vue?vue&type=script&lang=js\"\n\nimport \"./FilterDropdown.vue?vue&type=style&index=0&id=062d5f10&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-062d5f10\"]])\n\nexport default __exports__","import \"core-js/modules/es.iterator.constructor.js\";\nimport \"core-js/modules/es.iterator.filter.js\";\nimport { resolveComponent as _resolveComponent, createVNode as _createVNode, withKeys as _withKeys, withCtx as _withCtx, createElementVNode as _createElementVNode, createTextVNode as _createTextVNode, normalizeClass as _normalizeClass, toDisplayString as _toDisplayString, renderList as _renderList, Fragment as _Fragment, openBlock as _openBlock, createElementBlock as _createElementBlock, createBlock as _createBlock, createCommentVNode as _createCommentVNode } from \"vue\";\nconst _hoisted_1 = {\n class: \"container\"\n};\nconst _hoisted_2 = {\n class: \"header-content\"\n};\nconst _hoisted_3 = {\n class: \"search-area\"\n};\nconst _hoisted_4 = {\n class: \"search-card\"\n};\nconst _hoisted_5 = {\n class: \"actions\"\n};\nconst _hoisted_6 = {\n class: \"el-dropdown-link\"\n};\nconst _hoisted_7 = {\n class: \"el-dropdown-link\"\n};\nconst _hoisted_8 = {\n class: \"el-dropdown-link\"\n};\nconst _hoisted_9 = {\n class: \"breadcrumb-container\"\n};\nconst _hoisted_10 = {\n class: \"mobile-directory-path\"\n};\nconst _hoisted_11 = {\n class: \"breadcrumb desktop-only\"\n};\nconst _hoisted_12 = [\"title\"];\nconst _hoisted_13 = {\n key: 0,\n class: \"content\"\n};\nconst _hoisted_14 = {\n key: 1,\n class: \"empty-state\"\n};\nconst _hoisted_15 = {\n class: \"empty-text\"\n};\nconst _hoisted_16 = {\n class: \"empty-hint\"\n};\nconst _hoisted_17 = {\n key: 1,\n class: \"list-view\"\n};\nconst _hoisted_18 = {\n class: \"list-header\"\n};\nconst _hoisted_19 = {\n class: \"list-col list-col-checkbox\"\n};\nconst _hoisted_20 = {\n key: 1,\n class: \"empty-state list-empty\"\n};\nconst _hoisted_21 = {\n class: \"empty-text\"\n};\nconst _hoisted_22 = {\n class: \"empty-hint\"\n};\nconst _hoisted_23 = {\n class: \"pagination-container\"\n};\nconst _hoisted_24 = {\n class: \"pagination-center\"\n};\nconst _hoisted_25 = {\n class: \"pagination-right\"\n};\nconst _hoisted_26 = {\n class: \"page-total\"\n};\nconst _hoisted_27 = {\n class: \"page-jump\"\n};\nconst _hoisted_28 = {\n class: \"dialog-section\"\n};\nconst _hoisted_29 = {\n class: \"section-content\"\n};\nconst _hoisted_30 = {\n class: \"dialog-section\"\n};\nconst _hoisted_31 = {\n class: \"section-header\"\n};\nconst _hoisted_32 = {\n class: \"section-content\"\n};\nconst _hoisted_33 = {\n class: \"setting-item\"\n};\nconst _hoisted_34 = {\n key: 0,\n class: \"setting-item\"\n};\nconst _hoisted_35 = {\n class: \"dialog-action\"\n};\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_DashboardTabs = _resolveComponent(\"DashboardTabs\");\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n const _component_el_input = _resolveComponent(\"el-input\");\n const _component_FilterDropdown = _resolveComponent(\"FilterDropdown\");\n const _component_el_dropdown_item = _resolveComponent(\"el-dropdown-item\");\n const _component_el_dropdown_menu = _resolveComponent(\"el-dropdown-menu\");\n const _component_el_dropdown = _resolveComponent(\"el-dropdown\");\n const _component_el_tooltip = _resolveComponent(\"el-tooltip\");\n const _component_el_header = _resolveComponent(\"el-header\");\n const _component_el_breadcrumb_item = _resolveComponent(\"el-breadcrumb-item\");\n const _component_el_breadcrumb = _resolveComponent(\"el-breadcrumb\");\n const _component_SkeletonLoader = _resolveComponent(\"SkeletonLoader\");\n const _component_FolderCard = _resolveComponent(\"FolderCard\");\n const _component_FileCard = _resolveComponent(\"FileCard\");\n const _component_FileListItem = _resolveComponent(\"FileListItem\");\n const _component_el_pagination = _resolveComponent(\"el-pagination\");\n const _component_el_button = _resolveComponent(\"el-button\");\n const _component_el_main = _resolveComponent(\"el-main\");\n const _component_el_container = _resolveComponent(\"el-container\");\n const _component_FileDetailDialog = _resolveComponent(\"FileDetailDialog\");\n const _component_el_radio = _resolveComponent(\"el-radio\");\n const _component_el_radio_group = _resolveComponent(\"el-radio-group\");\n const _component_el_switch = _resolveComponent(\"el-switch\");\n const _component_el_dialog = _resolveComponent(\"el-dialog\");\n const _component_TagManagementDialog = _resolveComponent(\"TagManagementDialog\");\n const _component_BatchTagDialog = _resolveComponent(\"BatchTagDialog\");\n const _component_MobileActionSheet = _resolveComponent(\"MobileActionSheet\");\n const _component_MobileDirectoryDrawer = _resolveComponent(\"MobileDirectoryDrawer\");\n return _openBlock(), _createElementBlock(\"div\", _hoisted_1, [_createVNode(_component_el_container, null, {\n default: _withCtx(() => [_createVNode(_component_el_header, null, {\n default: _withCtx(() => [_createElementVNode(\"div\", _hoisted_2, [_createVNode(_component_DashboardTabs, {\n activeTab: \"dashboard\"\n }), _createElementVNode(\"div\", _hoisted_3, [_createElementVNode(\"div\", _hoisted_4, [_createVNode(_component_el_input, {\n modelValue: $data.tempSearch,\n \"onUpdate:modelValue\": _cache[0] || (_cache[0] = $event => $data.tempSearch = $event),\n size: \"mini\",\n placeholder: \"搜索:#标签 -#排除标签\",\n onKeyup: _withKeys($options.handleSearch, [\"enter\"])\n }, {\n suffix: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"search\",\n class: \"search-icon\",\n onClick: $options.handleSearch\n }, null, 8, [\"onClick\"])]),\n _: 1\n }, 8, [\"modelValue\", \"onKeyup\"])]), _createVNode(_component_FilterDropdown, {\n filters: $data.filters,\n \"onUpdate:filters\": _cache[1] || (_cache[1] = $event => $data.filters = $event),\n channelNameOptions: $data.channelNameOptions,\n onChange: $options.handleFilterChange\n }, null, 8, [\"filters\", \"channelNameOptions\", \"onChange\"])]), _createElementVNode(\"div\", _hoisted_5, [_createVNode(_component_el_dropdown, {\n onCommand: $options.sort,\n \"hide-on-click\": false\n }, {\n dropdown: _withCtx(() => [_createVNode(_component_el_dropdown_menu, null, {\n default: _withCtx(() => [_createVNode(_component_el_dropdown_item, {\n command: \"dateDesc\"\n }, {\n default: _withCtx(() => [...(_cache[22] || (_cache[22] = [_createTextVNode(\"按时间倒序\", -1)]))]),\n _: 1\n }), _createVNode(_component_el_dropdown_item, {\n command: \"nameAsc\"\n }, {\n default: _withCtx(() => [...(_cache[23] || (_cache[23] = [_createTextVNode(\"按名称升序\", -1)]))]),\n _: 1\n })]),\n _: 1\n })]),\n default: _withCtx(() => [_createElementVNode(\"span\", _hoisted_6, [_createVNode(_component_font_awesome_icon, {\n icon: $options.sortIcon,\n class: \"header-icon\"\n }, null, 8, [\"icon\"])])]),\n _: 1\n }, 8, [\"onCommand\"]), _createVNode(_component_el_tooltip, {\n disabled: $options.disableTooltip,\n content: \"全选此页\",\n placement: \"bottom\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: $options.selectPageIcon,\n class: \"header-icon\",\n onClick: $options.handleSelectPage\n }, null, 8, [\"icon\", \"onClick\"])]),\n _: 1\n }, 8, [\"disabled\"]), _createVNode(_component_el_dropdown, {\n onCommand: $options.handleBatchAction,\n \"hide-on-click\": false,\n disabled: $data.selectedFiles.length === 0\n }, {\n dropdown: _withCtx(() => [_createVNode(_component_el_dropdown_menu, null, {\n default: _withCtx(() => [_createVNode(_component_el_dropdown_item, {\n command: \"copy\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"copy\",\n class: \"batch-action-item-icon\"\n }), _cache[24] || (_cache[24] = _createTextVNode(\" 复制 \", -1))]),\n _: 1\n }), _createVNode(_component_el_dropdown_item, {\n command: \"delete\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"trash-alt\",\n class: \"batch-action-item-icon\"\n }), _cache[25] || (_cache[25] = _createTextVNode(\" 删除 \", -1))]),\n _: 1\n }), _createVNode(_component_el_dropdown_item, {\n command: \"download\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"download\",\n class: \"batch-action-item-icon\"\n }), _cache[26] || (_cache[26] = _createTextVNode(\" 下载 \", -1))]),\n _: 1\n }), _createVNode(_component_el_dropdown_item, {\n command: \"move\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"file-export\",\n class: \"batch-action-item-icon\"\n }), _cache[27] || (_cache[27] = _createTextVNode(\" 移动 \", -1))]),\n _: 1\n }), _createVNode(_component_el_dropdown_item, {\n command: \"tagManagement\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"tags\",\n class: \"batch-action-item-icon\"\n }), _cache[28] || (_cache[28] = _createTextVNode(\" 标签管理 \", -1))]),\n _: 1\n }), _createVNode(_component_el_dropdown_item, {\n command: \"ban\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"ban\",\n class: \"batch-action-item-icon\"\n }), _cache[29] || (_cache[29] = _createTextVNode(\" 加入黑名单 \", -1))]),\n _: 1\n }), _createVNode(_component_el_dropdown_item, {\n command: \"white\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"user-plus\",\n class: \"batch-action-item-icon\"\n }), _cache[30] || (_cache[30] = _createTextVNode(\" 加入白名单 \", -1))]),\n _: 1\n })]),\n _: 1\n })]),\n default: _withCtx(() => [_createElementVNode(\"span\", _hoisted_7, [_createVNode(_component_font_awesome_icon, {\n icon: \"ellipsis-h\",\n class: _normalizeClass([\"header-icon\", {\n disabled: $data.selectedFiles.length === 0\n }])\n }, null, 8, [\"class\"])])]),\n _: 1\n }, 8, [\"onCommand\", \"disabled\"]), _createVNode(_component_el_tooltip, {\n disabled: $options.disableTooltip,\n content: \"链接格式\",\n placement: \"bottom\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"span\", _hoisted_8, [_createVNode(_component_font_awesome_icon, {\n icon: \"link\",\n class: \"header-icon\",\n onClick: _cache[2] || (_cache[2] = $event => $data.showUrlDialog = true)\n })])]),\n _: 1\n }, 8, [\"disabled\"]), _createVNode(_component_el_tooltip, {\n disabled: $options.disableTooltip,\n content: $data.viewMode === 'card' ? '列表视图' : '卡片视图',\n placement: \"bottom\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: $data.viewMode === 'card' ? 'list' : 'th-large',\n class: \"header-icon\",\n onClick: $options.toggleViewMode\n }, null, 8, [\"icon\", \"onClick\"])]),\n _: 1\n }, 8, [\"disabled\", \"content\"]), _createVNode(_component_el_tooltip, {\n disabled: $options.disableTooltip,\n content: \"退出登录\",\n placement: \"bottom\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"sign-out-alt\",\n class: \"header-icon\",\n onClick: $options.handleLogout\n }, null, 8, [\"onClick\"])]),\n _: 1\n }, 8, [\"disabled\"])])])]),\n _: 1\n }), _createVNode(_component_el_main, {\n class: \"main-container\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"div\", _hoisted_9, [_createElementVNode(\"div\", {\n class: \"mobile-directory-trigger\",\n onClick: _cache[3] || (_cache[3] = $event => $data.showMobileDirectoryDrawer = true)\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"folder-open\",\n class: \"mobile-directory-icon\"\n }), _createElementVNode(\"span\", _hoisted_10, _toDisplayString($data.currentPath && $data.currentPath.split('/').filter(Boolean).length > 0 ? $data.currentPath.split('/').filter(Boolean).pop() : '根目录'), 1), _createVNode(_component_font_awesome_icon, {\n icon: \"chevron-down\",\n class: \"mobile-directory-arrow\"\n })]), _createElementVNode(\"div\", _hoisted_11, [_createVNode(_component_el_breadcrumb, {\n separator: \"/\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_breadcrumb_item, {\n onClick: _cache[4] || (_cache[4] = $event => $options.navigateToFolder(''))\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"home\",\n class: \"breadcrumb-home-icon\"\n })]),\n _: 1\n }), (_openBlock(true), _createElementBlock(_Fragment, null, _renderList($data.currentPath.split('/').filter(Boolean), (folder, index) => {\n return _openBlock(), _createBlock(_component_el_breadcrumb_item, {\n key: index,\n onClick: $event => $options.navigateToFolder($data.currentPath.split('/').filter(Boolean).slice(0, index + 1).join('/'))\n }, {\n default: _withCtx(() => [_createTextVNode(_toDisplayString(folder), 1)]),\n _: 2\n }, 1032, [\"onClick\"]);\n }), 128))]),\n _: 1\n })]), _createElementVNode(\"span\", {\n class: \"stats-badge\",\n title: `共 ${_ctx.$data.Number} 个文件`\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"database\",\n class: \"stats-badge-icon\"\n }), _createTextVNode(\" \" + _toDisplayString($data.Number), 1)], 8, _hoisted_12)]), $data.viewMode === 'card' ? (_openBlock(), _createElementBlock(\"div\", _hoisted_13, [$data.loading ? (_openBlock(), _createBlock(_component_SkeletonLoader, {\n key: 0,\n type: \"card\",\n count: 15\n })) : $options.paginatedTableData.length === 0 ? (_openBlock(), _createElementBlock(\"div\", _hoisted_14, [_createVNode(_component_font_awesome_icon, {\n icon: \"folder-open\",\n class: \"empty-icon\"\n }), _createElementVNode(\"p\", _hoisted_15, _toDisplayString($options.hasSearchOrFilter ? '未找到匹配的文件或文件夹' : '当前目录为空'), 1), _createElementVNode(\"p\", _hoisted_16, _toDisplayString($options.hasSearchOrFilter ? '尝试调整搜索条件或筛选器' : '上传文件后将显示在这里'), 1)])) : (_openBlock(true), _createElementBlock(_Fragment, {\n key: 2\n }, _renderList($options.paginatedTableData, (item, index) => {\n return _openBlock(), _createElementBlock(_Fragment, {\n key: index\n }, [$options.isFolder(item) ? (_openBlock(), _createBlock(_component_FolderCard, {\n key: 0,\n name: item.name,\n selected: item.selected,\n \"onUpdate:selected\": $event => item.selected = $event,\n showActions: !$data.isSearchMode,\n disableTooltip: $options.disableTooltip,\n onEnter: $event => $options.enterFolder(item.name),\n onCopy: $event => $options.handleFolderCopy(item.name),\n onMove: $event => $options.handleMove(index, item.name),\n onDelete: $event => $options.handleDelete(index, item.name),\n onTouchstart: $event => $options.handleFolderTouchStart(item, index),\n onTouchend: $options.handleTouchEnd,\n onTouchmove: $options.handleTouchEnd\n }, null, 8, [\"name\", \"selected\", \"onUpdate:selected\", \"showActions\", \"disableTooltip\", \"onEnter\", \"onCopy\", \"onMove\", \"onDelete\", \"onTouchstart\", \"onTouchend\", \"onTouchmove\"])) : (_openBlock(), _createBlock(_component_FileCard, {\n key: 1,\n item: item,\n selected: item.selected,\n \"onUpdate:selected\": $event => item.selected = $event,\n fileLink: $options.getFileLink(item.name),\n previewSrcList: item.previewSrcList,\n disableTooltip: $options.disableTooltip,\n onDetail: $event => $options.openDetailDialog(index, item.name),\n onCopy: $event => $options.handleCopy(index, item.name),\n onMove: $event => $options.handleMove(index, item.name),\n onDelete: $event => $options.handleDelete(index, item.name),\n onDownload: $event => $options.handleDownload(item.name),\n onTouchstart: $event => $options.handleTouchStart(item, index),\n onTouchend: $options.handleTouchEnd,\n onTouchmove: $options.handleTouchEnd\n }, null, 8, [\"item\", \"selected\", \"onUpdate:selected\", \"fileLink\", \"previewSrcList\", \"disableTooltip\", \"onDetail\", \"onCopy\", \"onMove\", \"onDelete\", \"onDownload\", \"onTouchstart\", \"onTouchend\", \"onTouchmove\"]))], 64);\n }), 128))])) : (_openBlock(), _createElementBlock(\"div\", _hoisted_17, [_createElementVNode(\"div\", _hoisted_18, [_createElementVNode(\"div\", _hoisted_19, [_createElementVNode(\"span\", {\n class: _normalizeClass([\"custom-checkbox\", {\n 'checked': $options.isSelectAll,\n 'indeterminate': $options.isIndeterminate\n }]),\n onClick: _cache[5] || (_cache[5] = $event => $options.handleSelectAllPage(!$options.isSelectAll))\n }, [$options.isSelectAll ? (_openBlock(), _createBlock(_component_font_awesome_icon, {\n key: 0,\n icon: \"check\",\n class: \"check-icon\"\n })) : $options.isIndeterminate ? (_openBlock(), _createBlock(_component_font_awesome_icon, {\n key: 1,\n icon: \"minus\",\n class: \"check-icon\"\n })) : _createCommentVNode(\"\", true)], 2)]), _cache[31] || (_cache[31] = _createElementVNode(\"div\", {\n class: \"list-col list-col-preview\"\n }, \"预览\", -1)), _cache[32] || (_cache[32] = _createElementVNode(\"div\", {\n class: \"list-col list-col-name\"\n }, \"文件名\", -1)), _cache[33] || (_cache[33] = _createElementVNode(\"div\", {\n class: \"list-col list-col-tags\"\n }, \"标签\", -1)), _cache[34] || (_cache[34] = _createElementVNode(\"div\", {\n class: \"list-col list-col-channel\"\n }, \"渠道类型\", -1)), _cache[35] || (_cache[35] = _createElementVNode(\"div\", {\n class: \"list-col list-col-channel-name\"\n }, \"渠道名称\", -1)), _cache[36] || (_cache[36] = _createElementVNode(\"div\", {\n class: \"list-col list-col-address\"\n }, \"上传地址\", -1)), _cache[37] || (_cache[37] = _createElementVNode(\"div\", {\n class: \"list-col list-col-size\"\n }, \"大小\", -1)), _cache[38] || (_cache[38] = _createElementVNode(\"div\", {\n class: \"list-col list-col-date\"\n }, \"上传时间\", -1)), _cache[39] || (_cache[39] = _createElementVNode(\"div\", {\n class: \"list-col list-col-actions\"\n }, \"操作\", -1))]), $data.loading ? (_openBlock(), _createBlock(_component_SkeletonLoader, {\n key: 0,\n type: \"list\",\n count: 15\n })) : $options.paginatedTableData.length === 0 ? (_openBlock(), _createElementBlock(\"div\", _hoisted_20, [_createVNode(_component_font_awesome_icon, {\n icon: \"folder-open\",\n class: \"empty-icon\"\n }), _createElementVNode(\"p\", _hoisted_21, _toDisplayString($options.hasSearchOrFilter ? '未找到匹配的文件或文件夹' : '当前目录为空'), 1), _createElementVNode(\"p\", _hoisted_22, _toDisplayString($options.hasSearchOrFilter ? '尝试调整搜索条件或筛选器' : '上传文件后将显示在这里'), 1)])) : (_openBlock(true), _createElementBlock(_Fragment, {\n key: 2\n }, _renderList($options.paginatedTableData, (item, index) => {\n return _openBlock(), _createBlock(_component_FileListItem, {\n key: index,\n item: item,\n selected: item.selected,\n \"onUpdate:selected\": $event => item.selected = $event,\n fileLink: $options.getFileLink(item.name),\n onEnter: $event => $options.enterFolder(item.name),\n onDetail: $event => $options.openDetailDialog(index, item.name),\n onCopy: $event => $options.handleCopy(index, item.name),\n onFolderCopy: $event => $options.handleFolderCopy(item.name),\n onMove: $event => $options.handleMove(index, item.name),\n onDelete: $event => $options.handleDelete(index, item.name),\n onDownload: $event => $options.handleDownload(item.name),\n onTouchstart: $event => $options.isFolder(item) ? $options.handleFolderTouchStart(item, index) : $options.handleTouchStart(item, index),\n onTouchend: $options.handleTouchEnd,\n onTouchmove: $options.handleTouchEnd\n }, null, 8, [\"item\", \"selected\", \"onUpdate:selected\", \"fileLink\", \"onEnter\", \"onDetail\", \"onCopy\", \"onFolderCopy\", \"onMove\", \"onDelete\", \"onDownload\", \"onTouchstart\", \"onTouchend\", \"onTouchmove\"]);\n }), 128))])), _createElementVNode(\"div\", _hoisted_23, [_createElementVNode(\"div\", _hoisted_24, [_createVNode(_component_el_pagination, {\n background: \"\",\n layout: \"prev, pager, next\",\n total: $options.filteredTableData.length,\n \"page-size\": $data.pageSize,\n \"current-page\": $data.currentPage,\n \"pager-count\": $options.pagerCount,\n onCurrentChange: $options.handlePageChange\n }, null, 8, [\"total\", \"page-size\", \"current-page\", \"pager-count\", \"onCurrentChange\"]), _createVNode(_component_el_button, {\n type: \"primary\",\n onClick: $options.refreshFileList,\n class: \"refresh-btn\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"sync\",\n class: _normalizeClass({\n 'fa-spin': $data.refreshLoading\n })\n }, null, 8, [\"class\"])]),\n _: 1\n }, 8, [\"onClick\"]), $data.currentPage === Math.ceil($options.filteredTableData.length / $data.pageSize) ? (_openBlock(), _createBlock(_component_el_button, {\n key: 0,\n type: \"primary\",\n onClick: $options.loadMoreData,\n loading: $data.loading,\n class: \"load-more\"\n }, {\n default: _withCtx(() => [...(_cache[40] || (_cache[40] = [_createTextVNode(\" 加载更多 \", -1)]))]),\n _: 1\n }, 8, [\"onClick\", \"loading\"])) : _createCommentVNode(\"\", true)]), _createElementVNode(\"div\", _hoisted_25, [_createElementVNode(\"span\", _hoisted_26, \"共 \" + _toDisplayString($options.realTotalPages) + \" 页\", 1), _createElementVNode(\"div\", _hoisted_27, [_cache[42] || (_cache[42] = _createElementVNode(\"span\", null, \"跳至\", -1)), _createVNode(_component_el_input, {\n modelValue: $data.jumpPage,\n \"onUpdate:modelValue\": _cache[6] || (_cache[6] = $event => $data.jumpPage = $event),\n size: \"small\",\n class: \"jump-input\",\n onKeyup: _withKeys($options.handleJumpPage, [\"enter\"])\n }, null, 8, [\"modelValue\", \"onKeyup\"]), _createVNode(_component_el_button, {\n size: \"small\",\n type: \"primary\",\n onClick: $options.handleJumpPage,\n class: \"jump-btn\"\n }, {\n default: _withCtx(() => [...(_cache[41] || (_cache[41] = [_createTextVNode(\"GO\", -1)]))]),\n _: 1\n }, 8, [\"onClick\"])])])])]),\n _: 1\n })]),\n _: 1\n }), _createVNode(_component_FileDetailDialog, {\n modelValue: $data.showdetailDialog,\n \"onUpdate:modelValue\": _cache[7] || (_cache[7] = $event => $data.showdetailDialog = $event),\n file: $data.detailFile,\n fileLink: $options.getFileLink($data.detailFile?.name),\n urls: $options.allUrl,\n onDownload: _cache[8] || (_cache[8] = $event => $options.handleDownload($data.detailFile?.name)),\n onTagManagement: _cache[9] || (_cache[9] = $event => $options.handleTagManagement($data.detailFile?.name)),\n onBlock: _cache[10] || (_cache[10] = $event => $options.handleBlock($data.detailFile?.name)),\n onWhite: _cache[11] || (_cache[11] = $event => $options.handleWhite($data.detailFile?.name)),\n onDelete: _cache[12] || (_cache[12] = $event => $options.handleDetailDelete($data.detailFile?.name))\n }, null, 8, [\"modelValue\", \"file\", \"fileLink\", \"urls\"]), _createVNode(_component_el_dialog, {\n title: \"链接格式\",\n modelValue: $data.showUrlDialog,\n \"onUpdate:modelValue\": _cache[17] || (_cache[17] = $event => $data.showUrlDialog = $event),\n width: $options.dialogWidth,\n \"show-close\": false,\n class: \"settings-dialog\"\n }, {\n default: _withCtx(() => [_createElementVNode(\"div\", _hoisted_28, [_cache[49] || (_cache[49] = _createElementVNode(\"div\", {\n class: \"section-header\"\n }, [_createElementVNode(\"span\", {\n class: \"section-title\"\n }, \"默认复制链接\")], -1)), _createElementVNode(\"div\", _hoisted_29, [_createVNode(_component_el_radio_group, {\n modelValue: $data.defaultUrlFormat,\n \"onUpdate:modelValue\": _cache[13] || (_cache[13] = $event => $data.defaultUrlFormat = $event),\n class: \"radio-card-group grid-2x2\"\n }, {\n default: _withCtx(() => [_createVNode(_component_el_radio, {\n label: \"originUrl\",\n class: \"radio-card\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"link\",\n class: \"radio-icon\"\n }), _cache[43] || (_cache[43] = _createElementVNode(\"span\", null, \"原始链接\", -1))]),\n _: 1\n }), _createVNode(_component_el_radio, {\n label: \"mdUrl\",\n class: \"radio-card\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"code\",\n class: \"radio-icon\"\n }), _cache[44] || (_cache[44] = _createElementVNode(\"span\", null, \"Markdown\", -1))]),\n _: 1\n }), _createVNode(_component_el_radio, {\n label: \"htmlUrl\",\n class: \"radio-card\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"code-branch\",\n class: \"radio-icon\"\n }), _cache[45] || (_cache[45] = _createElementVNode(\"span\", null, \"HTML\", -1))]),\n _: 1\n }), _createVNode(_component_el_radio, {\n label: \"bbUrl\",\n class: \"radio-card\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"quote-right\",\n class: \"radio-icon\"\n }), _cache[46] || (_cache[46] = _createElementVNode(\"span\", null, \"BBCode\", -1))]),\n _: 1\n }), _createVNode(_component_el_radio, {\n label: \"tgId\",\n class: \"radio-card\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"paper-plane\",\n class: \"radio-icon\"\n }), _cache[47] || (_cache[47] = _createElementVNode(\"span\", null, \"TG File ID\", -1))]),\n _: 1\n }), _createVNode(_component_el_radio, {\n label: \"s3Location\",\n class: \"radio-card\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"cloud\",\n class: \"radio-icon\"\n }), _cache[48] || (_cache[48] = _createElementVNode(\"span\", null, \"S3链接\", -1))]),\n _: 1\n })]),\n _: 1\n }, 8, [\"modelValue\"])])]), _createElementVNode(\"div\", _hoisted_30, [_createElementVNode(\"div\", _hoisted_31, [_cache[50] || (_cache[50] = _createElementVNode(\"span\", {\n class: \"section-title\"\n }, \"自定义链接\", -1)), _createVNode(_component_el_tooltip, {\n content: \"默认链接为https://your.domain/file/xxx.jpg
如果启用自定义链接格式,只保留xxx.jpg部分,其他部分请自行输入\",\n placement: \"top\",\n \"raw-content\": \"\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"question-circle\",\n class: \"section-help-icon\"\n })]),\n _: 1\n })]), _createElementVNode(\"div\", _hoisted_32, [_createElementVNode(\"div\", _hoisted_33, [_cache[51] || (_cache[51] = _createElementVNode(\"span\", {\n class: \"setting-label\"\n }, \"启用自定义\", -1)), _createVNode(_component_el_switch, {\n modelValue: $data.useCustomUrl,\n \"onUpdate:modelValue\": _cache[14] || (_cache[14] = $event => $data.useCustomUrl = $event),\n \"active-value\": \"true\",\n \"inactive-value\": \"false\"\n }, null, 8, [\"modelValue\"])]), $data.useCustomUrl === 'true' ? (_openBlock(), _createElementBlock(\"div\", _hoisted_34, [_cache[52] || (_cache[52] = _createElementVNode(\"span\", {\n class: \"setting-label\"\n }, \"自定义前缀\", -1)), _createVNode(_component_el_input, {\n modelValue: $data.customUrlPrefix,\n \"onUpdate:modelValue\": _cache[15] || (_cache[15] = $event => $data.customUrlPrefix = $event),\n placeholder: \"请输入自定义链接前缀\",\n class: \"setting-input\"\n }, null, 8, [\"modelValue\"])])) : _createCommentVNode(\"\", true)])]), _createElementVNode(\"div\", _hoisted_35, [_createVNode(_component_el_button, {\n type: \"primary\",\n onClick: _cache[16] || (_cache[16] = $event => $data.showUrlDialog = false),\n class: \"confirm-btn\"\n }, {\n default: _withCtx(() => [...(_cache[53] || (_cache[53] = [_createTextVNode(\"确定\", -1)]))]),\n _: 1\n })])]),\n _: 1\n }, 8, [\"modelValue\", \"width\"]), _createVNode(_component_TagManagementDialog, {\n modelValue: $data.showTagDialog,\n \"onUpdate:modelValue\": _cache[18] || (_cache[18] = $event => $data.showTagDialog = $event),\n fileId: $data.currentTagFile,\n onTagsUpdated: $options.handleTagsUpdated\n }, null, 8, [\"modelValue\", \"fileId\", \"onTagsUpdated\"]), _createVNode(_component_BatchTagDialog, {\n modelValue: $data.showBatchTagDialog,\n \"onUpdate:modelValue\": _cache[19] || (_cache[19] = $event => $data.showBatchTagDialog = $event),\n selectedFiles: $data.selectedFiles,\n onTagsUpdated: $options.handleBatchTagsUpdated\n }, null, 8, [\"modelValue\", \"selectedFiles\", \"onTagsUpdated\"]), _createVNode(_component_MobileActionSheet, {\n modelValue: $data.showMobileActionModal,\n \"onUpdate:modelValue\": _cache[20] || (_cache[20] = $event => $data.showMobileActionModal = $event),\n title: $data.mobileActionIsFolder ? $options.getFolderName($data.mobileActionFile?.name || '') : $data.mobileActionFile?.metadata?.FileName || $options.getFileName($data.mobileActionFile?.name || ''),\n isFolder: $data.mobileActionIsFolder,\n onAction: $options.handleMobileAction\n }, null, 8, [\"modelValue\", \"title\", \"isFolder\", \"onAction\"]), _createVNode(_component_MobileDirectoryDrawer, {\n modelValue: $data.showMobileDirectoryDrawer,\n \"onUpdate:modelValue\": _cache[21] || (_cache[21] = $event => $data.showMobileDirectoryDrawer = $event),\n currentPath: $data.currentPath,\n onNavigate: $options.navigateToFolder,\n onGoBack: $options.handleGoBack\n }, null, 8, [\"modelValue\", \"currentPath\", \"onNavigate\", \"onGoBack\"])]);\n}","// 文件管理器工具类\r\nimport fetchWithAuth from '@/utils/fetchWithAuth';\r\nimport { ElMessage } from 'element-plus';\r\n\r\nclass FileManager {\r\n constructor() {\r\n this.FILE_LIST_PATH = 'data/fileList.json';\r\n }\r\n\r\n // 从本地存储读取文件列表\r\n getLocalFileList() {\r\n try {\r\n const fileList = localStorage.getItem(this.FILE_LIST_PATH);\r\n return fileList ? JSON.parse(fileList) : { files: [], directories: [] };\r\n } catch (error) {\r\n console.error('Error reading local file list:', error);\r\n return { files: [], directories: [] };\r\n }\r\n }\r\n\r\n // 保存文件列表到本地存储\r\n saveFileList(fileList) {\r\n try {\r\n localStorage.setItem(this.FILE_LIST_PATH, JSON.stringify(fileList));\r\n return true;\r\n } catch (error) {\r\n console.error('Error saving file list:', error);\r\n return false;\r\n }\r\n }\r\n\r\n // 添加新文件到列表\r\n addFile(newFile) {\r\n try {\r\n const fileList = this.getLocalFileList();\r\n fileList.files.push(newFile);\r\n return this.saveFileList(fileList);\r\n } catch (error) {\r\n console.error('Error adding file:', error);\r\n return false;\r\n }\r\n }\r\n\r\n // 添加新文件夹\r\n addFolder(folderName) {\r\n try {\r\n const fileList = this.getLocalFileList();\r\n if (!fileList.directories.includes(folderName)) {\r\n fileList.directories.push(folderName);\r\n return this.saveFileList(fileList);\r\n }\r\n return false; // 文件夹已存在\r\n } catch (error) {\r\n console.error('Error adding folder:', error);\r\n return false;\r\n }\r\n }\r\n\r\n // 移动文件或文件夹\r\n moveFile(oldPath, newPath, isFolder = false, currentPath = '') {\r\n try {\r\n let fileList = this.getLocalFileList();\r\n \r\n if (isFolder) {\r\n // 更新目录列表\r\n const oldFolderIndex = fileList.directories.indexOf(oldPath);\r\n if (oldFolderIndex !== -1) {\r\n fileList.directories.splice(oldFolderIndex, 1);\r\n }\r\n\r\n } else {\r\n // 移动单个文件\r\n const fileIndex = fileList.files.findIndex(file => file.name === oldPath);\r\n if (fileIndex !== -1) {\r\n // 从旧位置移除\r\n fileList.files.splice(fileIndex, 1);\r\n }\r\n\r\n }\r\n\r\n // 如果新路径包含当前目录的直接子目录,则添加直接子目录\r\n if (newPath.startsWith(currentPath)) {\r\n const pathArray = newPath.substring(currentPath.length).split('/');\r\n if (pathArray.length > 1) {\r\n const newFolder = currentPath + pathArray[0];\r\n if (!fileList.directories.includes(newFolder)) {\r\n fileList.directories.push(newFolder);\r\n }\r\n }\r\n }\r\n\r\n return this.saveFileList(fileList);\r\n } catch (error) {\r\n console.error('Error moving file:', error);\r\n return false;\r\n }\r\n }\r\n\r\n // 从列表中删除文件\r\n removeFile(fileName) {\r\n try {\r\n let fileList = this.getLocalFileList();\r\n fileList.files = fileList.files.filter(file => file.name !== fileName);\r\n return this.saveFileList(fileList);\r\n } catch (error) {\r\n console.error('Error removing file:', error);\r\n return false;\r\n }\r\n }\r\n\r\n // 从列表中删除文件夹(同时删除该文件夹下的所有文件)\r\n removeFolder(folderName) {\r\n try {\r\n let fileList = this.getLocalFileList();\r\n fileList.files = fileList.files.filter(file => !file.name.startsWith(folderName + '/'));\r\n fileList.directories = fileList.directories.filter(dir => dir !== folderName);\r\n return this.saveFileList(fileList);\r\n } catch (error) {\r\n console.error('Error removing folder:', error);\r\n return false;\r\n }\r\n }\r\n\r\n // 获取指定目录下的文件和子目录\r\n getFilesInFolder(folderName) {\r\n try {\r\n const fileList = this.getLocalFileList();\r\n const files = fileList.files.filter(file => file.name.startsWith(folderName + '/'));\r\n const subdirectories = fileList.directories.filter(dir => dir.startsWith(folderName + '/'));\r\n return { files, directories: subdirectories };\r\n } catch (error) {\r\n console.error('Error getting files in folder:', error);\r\n return { files: [], directories: [] };\r\n }\r\n }\r\n\r\n // 构建筛选参数URL\r\n buildFilterParams(filters) {\r\n let params = '';\r\n // 访问状态筛选(综合判断)\r\n if (filters.accessStatus && filters.accessStatus.length > 0) {\r\n params += `&accessStatus=${encodeURIComponent(filters.accessStatus.join(','))}`;\r\n }\r\n // 黑白名单筛选(直接使用 ListType 字段)\r\n if (filters.listType && filters.listType.length > 0) {\r\n params += `&listType=${encodeURIComponent(filters.listType.join(','))}`;\r\n }\r\n if (filters.label && filters.label.length > 0) {\r\n params += `&label=${encodeURIComponent(filters.label.join(','))}`;\r\n }\r\n if (filters.fileType && filters.fileType.length > 0) {\r\n params += `&fileType=${encodeURIComponent(filters.fileType.join(','))}`;\r\n }\r\n if (filters.channel && filters.channel.length > 0) {\r\n params += `&channel=${encodeURIComponent(filters.channel.join(','))}`;\r\n }\r\n if (filters.channelName && filters.channelName.length > 0) {\r\n params += `&channelName=${encodeURIComponent(filters.channelName.join(','))}`;\r\n }\r\n return params;\r\n }\r\n\r\n // 更新文件列表\r\n async refreshFileList(dir, search = '', includeTags = '', excludeTags = '', filters = {}) {\r\n search = search.trim();\r\n try {\r\n let url = `/api/manage/list?count=60&dir=${dir}&search=${encodeURIComponent(search)}`;\r\n if (includeTags) {\r\n url += `&includeTags=${encodeURIComponent(includeTags)}`;\r\n }\r\n if (excludeTags) {\r\n url += `&excludeTags=${encodeURIComponent(excludeTags)}`;\r\n }\r\n // 添加筛选参数(支持多选)\r\n url += this.buildFilterParams(filters);\r\n \r\n const response = await fetchWithAuth(url, {\r\n method: 'GET',\r\n });\r\n const newFileList = await response.json();\r\n if (!newFileList.isIndexedResponse) {\r\n ElMessage.warning('索引构建中,当前搜索和排序结果可能不准确,请稍后再试。');\r\n }\r\n // 保存包含新字段的完整数据\r\n return this.saveFileList(newFileList);\r\n } catch (error) {\r\n console.error('Error refreshing file list:', error);\r\n return false;\r\n }\r\n }\r\n\r\n // 读取更多数据\r\n async loadMoreFiles(dir, search = '', includeTags = '', excludeTags = '', count = 60, filters = {}) {\r\n search = search.trim();\r\n try {\r\n const fileList = this.getLocalFileList();\r\n const start = fileList.files.length;\r\n\r\n let url = `/api/manage/list?dir=${dir}&start=${start}&count=${count}&search=${encodeURIComponent(search)}`;\r\n if (includeTags) {\r\n url += `&includeTags=${encodeURIComponent(includeTags)}`;\r\n }\r\n if (excludeTags) {\r\n url += `&excludeTags=${encodeURIComponent(excludeTags)}`;\r\n }\r\n // 添加筛选参数(支持多选)\r\n url += this.buildFilterParams(filters);\r\n\r\n const response = await fetchWithAuth(url, {\r\n method: 'GET',\r\n });\r\n \r\n const moreFiles = await response.json();\r\n fileList.files.push(...moreFiles.files);\r\n return this.saveFileList(fileList);\r\n } catch (error) {\r\n console.error('Error loading more files:', error);\r\n return { files: [], directories: [] };\r\n }\r\n }\r\n}\r\n\r\nexport const fileManager = new FileManager();\r\n","import \"core-js/modules/es.array.push.js\";\nimport \"core-js/modules/es.iterator.constructor.js\";\nimport \"core-js/modules/es.iterator.every.js\";\nimport \"core-js/modules/es.iterator.filter.js\";\nimport \"core-js/modules/es.iterator.find.js\";\nimport \"core-js/modules/es.iterator.for-each.js\";\nimport \"core-js/modules/es.iterator.map.js\";\nimport \"core-js/modules/es.iterator.reduce.js\";\nimport \"core-js/modules/es.iterator.some.js\";\nimport \"core-js/modules/es.set.difference.v2.js\";\nimport \"core-js/modules/es.set.intersection.v2.js\";\nimport \"core-js/modules/es.set.is-disjoint-from.v2.js\";\nimport \"core-js/modules/es.set.is-subset-of.v2.js\";\nimport \"core-js/modules/es.set.is-superset-of.v2.js\";\nimport \"core-js/modules/es.set.symmetric-difference.v2.js\";\nimport \"core-js/modules/es.set.union.v2.js\";\nimport \"core-js/modules/web.url-search-params.delete.js\";\nimport \"core-js/modules/web.url-search-params.has.js\";\nimport \"core-js/modules/web.url-search-params.size.js\";\nimport { mapGetters } from 'vuex';\nimport JSZip from 'jszip';\nimport DashboardTabs from '@/components/DashboardTabs.vue';\nimport TagManagementDialog from '@/components/TagManagementDialog.vue';\nimport BatchTagDialog from '@/components/BatchTagDialog.vue';\nimport SkeletonLoader from '@/components/SkeletonLoader.vue';\nimport FileCard from '@/components/FileCard.vue';\nimport FolderCard from '@/components/FolderCard.vue';\nimport FileListItem from '@/components/FileListItem.vue';\nimport FileDetailDialog from '@/components/FileDetailDialog.vue';\nimport MobileActionSheet from '@/components/MobileActionSheet.vue';\nimport MobileDirectoryDrawer from '@/components/MobileDirectoryDrawer.vue';\nimport FilterDropdown from '@/components/FilterDropdown.vue';\nimport { fileManager } from '@/utils/fileManager';\nimport fetchWithAuth from '@/utils/fetchWithAuth';\nimport { validateFolderPath } from '@/utils/pathValidator';\nexport default {\n data() {\n return {\n Number: 0,\n directFileCount: 0,\n // 当前目录直接子文件数量\n directFolderCount: 0,\n // 当前目录直接子文件夹数量\n showLogoutButton: false,\n tableData: [],\n tempSearch: '',\n search: '',\n searchKeywords: '',\n // Keywords only (without tag filters) for backend search\n searchIncludeTags: '',\n // 包含的标签,逗号分隔\n searchExcludeTags: '',\n // 排除的标签,逗号分隔\n isSearchMode: false,\n currentPage: 1,\n pageSize: 15,\n selectedFiles: [],\n sortOption: 'dateDesc',\n isUploading: false,\n showdetailDialog: false,\n detailFile: null,\n activeUrlTab: 'originUrl',\n defaultUrlFormat: 'originUrl',\n showUrlDialog: false,\n useCustomUrl: 'false',\n // 是否启用自定义链接\n customUrlPrefix: '',\n // 自定义链接前缀\n loading: false,\n // 加载状态\n currentPath: '',\n // 当前文件夹路径\n refreshLoading: false,\n showTagDialog: false,\n // 标签管理对话框\n showBatchTagDialog: false,\n // 批量标签管理对话框\n currentTagFile: '',\n // 当前标签管理的文件\n viewMode: 'card',\n // 视图模式:card 或 list\n showMobileActionModal: false,\n // 移动端操作模态框\n mobileActionFile: null,\n // 当前移动端操作的文件\n mobileActionIndex: -1,\n // 当前移动端操作的文件索引\n mobileActionIsFolder: false,\n // 是否为文件夹操作\n longPressTimer: null,\n // 长按计时器\n showMobileDirectoryDrawer: false,\n // 移动端目录抽屉\n jumpPage: '',\n // 跳转页码输入\n // 筛选相关状态(数组形式支持多选)\n filters: {\n accessStatus: [],\n // 访问状态: 'normal'(正常), 'blocked'(已屏蔽)\n listType: [],\n // 黑白名单: 'White', 'Block', 'None'\n label: [],\n // 审查结果: 'normal', 'teen', 'adult'\n fileType: [],\n // 文件类型: 'image', 'video', 'audio', 'other'\n channel: [],\n // 渠道类型: 'TelegramNew', 'CloudflareR2', 'S3', 'Discord', 'HuggingFace', 'External'\n channelName: [] // 渠道名称: 动态获取\n },\n channelNameOptions: [] // 动态从文件列表中提取\n };\n },\n components: {\n DashboardTabs,\n TagManagementDialog,\n BatchTagDialog,\n SkeletonLoader,\n FileCard,\n FolderCard,\n FileListItem,\n FileDetailDialog,\n MobileActionSheet,\n MobileDirectoryDrawer,\n FilterDropdown\n },\n computed: {\n ...mapGetters(['adminUrlSettings', 'userConfig']),\n filteredTableData() {\n return this.tableData;\n },\n totalPages() {\n return Math.ceil(this.filteredTableData.length / this.pageSize) || 1;\n },\n // 基于当前文件夹直接子文件和子文件夹数量计算的真实总页数\n realTotalPages() {\n const total = this.directFolderCount + this.directFileCount;\n return Math.ceil(total / this.pageSize) || 1;\n },\n // 计算当前激活的筛选条件数量(数组形式)\n activeFilterCount() {\n return Object.values(this.filters).reduce((count, arr) => count + (Array.isArray(arr) ? arr.length : 0), 0);\n },\n // 判断是否处于搜索或筛选模式\n hasSearchOrFilter() {\n return this.isSearchMode || this.activeFilterCount > 0;\n },\n paginatedTableData() {\n const sortedData = this.sortData(this.filteredTableData);\n const start = (this.currentPage - 1) * this.pageSize;\n const end = start + this.pageSize;\n let data = sortedData.slice(start, end);\n // 增加previewSrcList属性,用于预览图片\n const fullList = data.filter(file => this.isImage(file)).map(file => this.getFileLink(file.name));\n data.forEach(file => {\n if (this.isImage(file)) {\n // 重新排序,索引大于等于当前索引的元素在前,否则在后\n file.previewSrcList = fullList.slice(fullList.indexOf(this.getFileLink(file.name))).concat(fullList.slice(0, fullList.indexOf(this.getFileLink(file.name))));\n }\n });\n // 增加channelTag属性,用于显示渠道信息\n data.forEach(file => {\n if (file.metadata?.Channel === 'TelegramNew') {\n file.channelTag = 'TG';\n } else if (file.metadata?.Channel === 'CloudflareR2') {\n file.channelTag = 'R2';\n } else if (file.metadata?.Channel === 'S3') {\n file.channelTag = 'S3';\n } else if (file.metadata?.Channel === 'Discord') {\n file.channelTag = 'DC';\n } else if (file.metadata?.Channel === 'HuggingFace') {\n file.channelTag = 'HF';\n } else if (file.metadata?.Channel === 'External') {\n file.channelTag = '外链';\n } else {\n file.channelTag = '未知';\n }\n });\n return data;\n },\n sortIcon() {\n return this.sortOption === 'dateDesc' ? 'sort-amount-down' : 'sort-alpha-up';\n },\n dialogWidth() {\n return window.innerWidth > 768 ? '50%' : '90%';\n },\n detailDialogWidth() {\n return window.innerWidth > 768 ? '70%' : '90%';\n },\n accessType() {\n if (this.detailFile?.metadata?.ListType === 'White') {\n return '正常';\n } else if (this.detailFile?.metadata?.ListType === 'Block' || this.detailFile?.metadata?.Label === 'adult') {\n return '受限';\n } else {\n return '正常';\n }\n },\n allUrl() {\n // 外链图片均采用外链\n if (this.detailFile?.metadata?.Channel === 'External') {\n return {\n 'originUrl': `${this.detailFile?.metadata?.ExternalLink}`,\n 'mdUrl': `![${this.detailFile?.metadata?.FileName || this.detailFile?.name}](${this.detailFile?.metadata?.ExternalLink})`,\n 'htmlUrl': `\"${this.detailFile?.metadata?.FileName`,\n 'bbUrl': `[img]${this.detailFile?.metadata?.ExternalLink}[/img]`,\n 'tgId': this.detailFile?.metadata?.TgFileId || '未知',\n 'S3Location': this.detailFile?.metadata?.S3Location || '未知',\n 'S3CdnFileUrl': this.detailFile?.metadata?.S3CdnFileUrl || '未知'\n };\n } else {\n return {\n 'originUrl': `${this.rootUrl}${this.detailFile?.name}`,\n 'mdUrl': `![${this.detailFile?.metadata?.FileName || this.detailFile?.name}](${this.rootUrl}${this.detailFile?.name})`,\n 'htmlUrl': `\"${this.detailFile?.metadata?.FileName`,\n 'bbUrl': `[img]${this.rootUrl}${this.detailFile?.name}[/img]`,\n 'tgId': this.detailFile?.metadata?.TgFileId || '未知',\n 'S3Location': this.detailFile?.metadata?.S3Location || '未知',\n 'S3CdnFileUrl': this.detailFile?.metadata?.S3CdnFileUrl || '未知'\n };\n }\n },\n tableColumnNum() {\n return window.innerWidth > 768 ? 3 : 1;\n },\n tablePreviewSpan() {\n return window.innerWidth > 768 ? 2 : 1;\n },\n disableTooltip() {\n return window.innerWidth < 768;\n },\n selectPage() {\n // 如果当前页所有文件都被选中,则返回 true,否则返回 false\n return this.paginatedTableData.every(file => file.selected);\n },\n selectedPageFiles() {\n // 如果当前页有文件被选中,则返回 true,否则返回 false\n return this.paginatedTableData.some(file => file.selected);\n },\n selectPageIcon() {\n // 全选为 true 时,返回 check-square;部分选中为 minus-square;全不选为 square\n return this.selectPage ? 'check-square' : this.selectedPageFiles ? 'minus-square' : 'square';\n },\n rootUrl() {\n // 链接前缀,优先级:用户自定义 > urlPrefix > 默认\n return this.useCustomUrl === 'true' ? this.customUrlPrefix : this.userConfig?.urlPrefix || `${document.location.origin}/file/`;\n },\n isSelectAll: {\n get() {\n return this.paginatedTableData.length > 0 && this.paginatedTableData.every(file => file.selected);\n },\n set(val) {\n this.paginatedTableData.forEach(file => file.selected = val);\n }\n },\n isIndeterminate() {\n const selectedCount = this.paginatedTableData.filter(file => file.selected).length;\n return selectedCount > 0 && selectedCount < this.paginatedTableData.length;\n },\n pagerCount() {\n return window.innerWidth < 768 ? 3 : 7;\n }\n },\n watch: {\n tableData: {\n handler(newData) {\n // selectedFiles 增加 newData中新选中,不包含在 selectedFiles 中的文件\n this.selectedFiles = this.selectedFiles.concat(newData.filter(file => file.selected && !this.selectedFiles.includes(file)));\n // selectedFiles 删掉 newData 中已取消选中的文件\n this.selectedFiles = this.selectedFiles.filter(file => file.selected);\n // selectedFiles 删掉 tableData 中已删除的文件\n this.selectedFiles = this.selectedFiles.filter(file => newData.includes(file));\n },\n deep: true\n },\n sortOption(newOption) {\n localStorage.setItem('sortOption', newOption);\n },\n defaultUrlFormat(newFormat) {\n localStorage.setItem('defaultUrlFormat', newFormat);\n },\n showdetailDialog(newVal) {\n if (newVal) {\n this.activeUrlTab = this.defaultUrlFormat || 'originUrl';\n }\n },\n customUrlPrefix(val) {\n this.$store.commit('setAdminUrlSettings', {\n key: 'customUrlPrefix',\n value: val\n });\n },\n useCustomUrl(val) {\n this.$store.commit('setAdminUrlSettings', {\n key: 'useCustomUrl',\n value: val\n });\n },\n currentPath(val) {\n // 页面切换时,取消选择的内容\n this.tableData.forEach(file => file.selected = false);\n }\n },\n methods: {\n // 切换视图模式\n toggleViewMode() {\n this.viewMode = this.viewMode === 'card' ? 'list' : 'card';\n localStorage.setItem('viewMode', this.viewMode);\n },\n // 列表视图全选当前页\n handleSelectAllPage(val) {\n this.paginatedTableData.forEach(file => file.selected = val);\n },\n // 移动端长按开始\n handleTouchStart(item, index) {\n this.longPressTimer = setTimeout(() => {\n this.mobileActionFile = item;\n this.mobileActionIndex = index;\n this.mobileActionIsFolder = false;\n this.showMobileActionModal = true;\n }, 500); // 500ms 长按触发\n },\n // 移动端长按结束/取消\n handleTouchEnd() {\n if (this.longPressTimer) {\n clearTimeout(this.longPressTimer);\n this.longPressTimer = null;\n }\n },\n // 文件夹长按开始\n handleFolderTouchStart(item, index) {\n this.longPressTimer = setTimeout(() => {\n this.mobileActionFile = item;\n this.mobileActionIndex = index;\n this.mobileActionIsFolder = true;\n this.showMobileActionModal = true;\n }, 500);\n },\n // 处理移动端操作\n handleMobileAction(action) {\n const file = this.mobileActionFile;\n const index = this.mobileActionIndex;\n this.showMobileActionModal = false;\n if (!file) return;\n switch (action) {\n case 'detail':\n this.openDetailDialog(index, file.name);\n break;\n case 'copy':\n this.handleCopy(index, file.name);\n break;\n case 'folderCopy':\n this.handleFolderCopy(file.name);\n break;\n case 'download':\n this.handleDownload(file.name);\n break;\n case 'move':\n this.handleMove(index, file.name);\n break;\n case 'delete':\n this.handleDelete(index, file.name);\n break;\n case 'tag':\n this.handleTagManagement(file.name);\n break;\n }\n },\n // 返回上一级目录\n handleGoBack() {\n const pathParts = this.currentPath.split('/').filter(Boolean);\n if (pathParts.length > 0) {\n pathParts.pop();\n const parentPath = pathParts.join('/');\n this.navigateToFolder(parentPath);\n }\n this.showMobileDirectoryDrawer = false;\n },\n // 获取标签颜色\n getTagColor(index) {\n const colors = ['linear-gradient(135deg, #667eea 0%, #764ba2 100%)', 'linear-gradient(135deg, #f093fb 0%, #f5576c 100%)', 'linear-gradient(135deg, #4facfe 0%, #00f2fe 100%)', 'linear-gradient(135deg, #43e97b 0%, #38f9d7 100%)', 'linear-gradient(135deg, #fa709a 0%, #fee140 100%)', 'linear-gradient(135deg, #a8edea 0%, #fed6e3 100%)'];\n return colors[index % colors.length];\n },\n // 视频hover播放控制\n handleVideoHover(event, isEnter) {\n const video = event.target;\n if (isEnter) {\n video.play().catch(() => {});\n } else {\n video.pause();\n video.currentTime = 0;\n }\n },\n // 格式化文件大小\n formatFileSize(bytes) {\n if (!bytes || bytes === 0) return '-';\n bytes = Number(bytes);\n if (isNaN(bytes)) return '-';\n const units = ['B', 'KB', 'MB', 'GB', 'TB'];\n let i = 0;\n while (bytes >= 1024 && i < units.length - 1) {\n bytes /= 1024;\n i++;\n }\n return bytes.toFixed(i > 0 ? 1 : 0) + ' ' + units[i];\n },\n handleSearch() {\n this.search = this.tempSearch;\n this.isSearchMode = this.search.trim() !== '';\n this.currentPage = 1; // 重置到第一页\n\n // 解析搜索字符串,提取标签和关键字\n // 支持 #tag 表示包含标签,-#tag 表示排除标签\n if (this.search && this.search.trim()) {\n const includeTags = [];\n const excludeTags = [];\n\n // 匹配 -#tag 和 #tag\n let searchText = this.search;\n\n // 先匹配排除标签 -#tag\n const excludeTagRegex = /-#([\\w\\u4e00-\\u9fa5\\u3040-\\u309f\\u30a0-\\u30ff\\uac00-\\ud7af\\.\\+\\-]+)/g;\n searchText = searchText.replace(excludeTagRegex, (match, tag) => {\n excludeTags.push(tag.toLowerCase());\n return ' ';\n });\n\n // 再匹配包含标签 #tag\n const includeTagRegex = /#([\\w\\u4e00-\\u9fa5\\u3040-\\u309f\\u30a0-\\u30ff\\uac00-\\ud7af\\.\\+\\-]+)/g;\n searchText = searchText.replace(includeTagRegex, (match, tag) => {\n includeTags.push(tag.toLowerCase());\n return ' ';\n });\n\n // 清理剩余的关键字(去除多余空格)\n this.searchKeywords = searchText.replace(/\\s+/g, ' ').trim();\n\n // 构建标签查询字符串\n this.searchIncludeTags = includeTags.join(',');\n this.searchExcludeTags = excludeTags.join(',');\n console.log('Search keywords:', this.searchKeywords);\n console.log('Include tags:', this.searchIncludeTags);\n console.log('Exclude tags:', this.searchExcludeTags);\n } else {\n this.searchKeywords = '';\n this.searchIncludeTags = '';\n this.searchExcludeTags = '';\n }\n this.refreshFileList();\n },\n // 处理筛选变化(来自 FilterDropdown 组件)\n handleFilterChange({\n type,\n filters\n }) {\n this.filters = filters;\n this.currentPage = 1; // 重置到第一页\n this.refreshFileList();\n },\n // 清除所有筛选条件\n clearFilters() {\n this.filters = {\n listType: [],\n label: [],\n fileType: [],\n channel: [],\n channelName: []\n };\n this.currentPage = 1;\n this.refreshFileList();\n },\n // 从 API 获取所有渠道名称\n async extractChannelNames() {\n try {\n const response = await fetchWithAuth('/api/channels?includeDisabled=true', {\n method: 'GET'\n });\n if (response.ok) {\n const channels = await response.json();\n const channelOptions = [];\n\n // 类型映射(显示名称)\n const typeLabels = {\n TelegramNew: 'Telegram',\n CloudflareR2: 'Cloudflare R2',\n S3: 'S3',\n Discord: 'Discord',\n HuggingFace: 'HuggingFace'\n };\n\n // 按类型提取渠道名称\n Object.entries(channels).forEach(([type, channelList]) => {\n if (Array.isArray(channelList) && channelList.length > 0) {\n channelList.forEach(channel => {\n if (channel.name) {\n channelOptions.push({\n name: channel.name,\n type: channel.type,\n typeLabel: typeLabels[channel.type] || channel.type,\n // 使用 type:name 作为唯一标识\n value: `${channel.type}:${channel.name}`\n });\n }\n });\n }\n });\n\n // 按类型和名称排序\n channelOptions.sort((a, b) => {\n if (a.type !== b.type) {\n return a.type.localeCompare(b.type);\n }\n return a.name.localeCompare(b.name);\n });\n this.channelNameOptions = channelOptions;\n }\n } catch (error) {\n console.error('Failed to fetch channel names:', error);\n }\n },\n handleDownload(key) {\n const link = document.createElement('a');\n link.href = this.getFileLink(key);\n link.download = key;\n link.click();\n },\n openDetailDialog(index, key) {\n this.detailFile = this.paginatedTableData[index];\n this.showdetailDialog = true;\n },\n handleTabClick(tab) {\n this.activeUrlTab = tab.props.name;\n },\n handleUrlClick(event) {\n // 复制到剪贴板\n navigator.clipboard.writeText(event.target.value).then(() => {\n this.$message({\n type: 'success',\n message: '复制成功'\n });\n }).catch(() => {\n this.$message({\n type: 'error',\n message: '复制失败'\n });\n });\n },\n handleDetailDelete(key) {\n this.$confirm('此操作将永久删除该文件, 是否继续?', '提示', {\n confirmButtonText: '确定',\n cancelButtonText: '取消',\n type: 'warning'\n }).then(() => {\n fetchWithAuth(`/api/manage/delete/${key}`, {\n method: 'GET'\n }).then(response => {\n if (response.ok) {\n const fileIndex = this.tableData.findIndex(file => file.name === key);\n if (fileIndex !== -1) {\n this.tableData.splice(fileIndex, 1);\n }\n } else {\n return Promise.reject('请求失败');\n }\n }).then(() => {\n this.updateStats(-1, false);\n this.$message.success('删除成功');\n this.showdetailDialog = false;\n }).catch(() => this.$message.error('删除失败'));\n }).catch(() => console.log('已取消删除'));\n },\n handleBlock(key) {\n this.$confirm('此操作将把该文件加入黑名单, 是否继续?', '提示', {\n confirmButtonText: '确定',\n cancelButtonText: '取消',\n type: 'warning'\n }).then(() => {\n fetchWithAuth(`/api/manage/block/${key}`, {\n method: 'GET'\n }).then(response => {\n if (response.ok) {\n const fileIndex = this.tableData.findIndex(file => file.name === key);\n if (fileIndex !== -1) {\n this.tableData[fileIndex].metadata.ListType = 'Block';\n }\n } else {\n return Promise.reject('请求失败');\n }\n }).then(() => {\n this.$message.success('加入黑名单成功');\n }).catch(() => this.$message.error('加入黑名单失败'));\n }).catch(() => console.log('已取消加入黑名单'));\n },\n handleWhite(key) {\n this.$confirm('此操作将把该文件加入白名单, 是否继续?', '提示', {\n confirmButtonText: '确定',\n cancelButtonText: '取消',\n type: 'warning'\n }).then(() => {\n fetchWithAuth(`/api/manage/white/${key}`, {\n method: 'GET'\n }).then(response => {\n if (response.ok) {\n const fileIndex = this.tableData.findIndex(file => file.name === key);\n if (fileIndex !== -1) {\n this.tableData[fileIndex].metadata.ListType = 'White';\n }\n } else {\n return Promise.reject('请求失败');\n }\n }).then(() => {\n this.$message.success('加入白名单成功');\n }).catch(() => this.$message.error('加入白名单失败'));\n }).catch(() => console.log('已取消加入白名单'));\n },\n handleDelete(index, key) {\n // 判断是否为文件夹\n const isFolder = this.tableData.find(file => file.name === key).isFolder;\n this.$confirm(`此操作将永久删除${isFolder ? '文件夹' : '该文件'}, 是否继续?`, '提示', {\n confirmButtonText: '确定',\n cancelButtonText: '取消',\n type: 'warning'\n }).then(() => {\n fetchWithAuth(`/api/manage/delete/${key}?folder=${isFolder}`, {\n method: 'GET'\n }).then(response => {\n if (response.ok) {\n const fileIndex = this.tableData.findIndex(file => file.name === key);\n if (fileIndex !== -1) {\n this.tableData.splice(fileIndex, 1);\n }\n } else {\n return Promise.reject('请求失败');\n }\n }).then(() => {\n this.updateStats(-1, false);\n fileManager.removeFile(key);\n this.$message.success('删除成功');\n }).catch(() => this.$message.error('删除失败'));\n }).catch(() => console.log('已取消删除'));\n },\n handleBatchDelete() {\n this.$confirm('此操作将永久删除选中的文件及文件夹, 是否继续?', '提示', {\n confirmButtonText: '确定',\n cancelButtonText: '取消',\n type: 'warning'\n }).then(() => {\n const promises = this.selectedFiles.map(file => {\n const isFolder = file.isFolder;\n return fetchWithAuth(`/api/manage/delete/${file.name}?folder=${isFolder}`, {\n method: 'GET'\n });\n });\n Promise.all(promises).then(results => {\n let successNum = 0;\n results.forEach((response, index) => {\n if (response.ok) {\n successNum++;\n const fileIndex = this.tableData.findIndex(file => file.name === this.selectedFiles[index].name);\n if (fileIndex !== -1) {\n this.tableData.splice(fileIndex, 1);\n }\n fileManager.removeFile(this.selectedFiles[index].name);\n }\n });\n this.selectedFiles = [];\n this.updateStats(-successNum, false);\n this.$message.success('批量删除成功');\n }).catch(() => this.$message.error('批量删除失败'));\n }).catch(() => console.log('已取消批量删除'));\n },\n async handleBatchCopy() {\n // 分离文件和文件夹\n const files = this.selectedFiles.filter(item => !item.isFolder);\n const folders = this.selectedFiles.filter(item => item.isFolder);\n\n // 如果有文件夹,显示加载状态\n let loading = null;\n if (folders.length > 0) {\n loading = this.$loading({\n lock: true,\n text: '正在获取文件列表...'\n });\n }\n try {\n // 收集所有文件(包括文件夹内的文件)\n let allFiles = [...files];\n\n // 递归获取所有文件夹内的文件\n for (const folder of folders) {\n try {\n const response = await fetchWithAuth(`/api/manage/list?dir=${encodeURIComponent(folder.name)}&recursive=true&count=-1`, {\n method: 'GET'\n });\n const data = await response.json();\n if (data.files && data.files.length > 0) {\n allFiles = allFiles.concat(data.files);\n }\n } catch (error) {\n console.error(`获取文件夹 ${folder.name} 内容失败:`, error);\n }\n }\n if (loading) loading.close();\n if (allFiles.length === 0) {\n this.$message.warning('没有可复制的链接');\n return;\n }\n\n // 生成所有链接\n const links = allFiles.map(file => {\n return this.generateFileLink(file.name, file.metadata);\n }).filter(link => link); // 过滤掉空链接\n\n if (links.length === 0) {\n this.$message.warning('没有可复制的链接');\n return;\n }\n\n // 复制到剪贴板\n const text = links.join('\\n');\n if (navigator.clipboard) {\n await navigator.clipboard.writeText(text);\n this.$message.success(`批量复制 ${links.length} 个链接成功`);\n } else {\n this.copyToClipboardFallback(text);\n }\n } catch (error) {\n if (loading) loading.close();\n console.error('批量复制链接失败:', error);\n this.$message.error('批量复制链接失败,请重试');\n }\n },\n copyToClipboardFallback(text) {\n const textarea = document.createElement('textarea');\n document.body.appendChild(textarea);\n textarea.style.position = 'fixed';\n textarea.style.clip = 'rect(0 0 0 0)';\n textarea.style.top = '10px';\n textarea.value = text;\n textarea.select();\n document.execCommand('copy');\n document.body.removeChild(textarea);\n this.$message.success('批量复制链接成功');\n },\n handleCopy(index, key) {\n let text = '';\n if (this.paginatedTableData[index].metadata?.Channel === 'External') {\n switch (this.defaultUrlFormat) {\n case 'originUrl':\n text = this.paginatedTableData[index].metadata?.ExternalLink;\n break;\n case 'mdUrl':\n text = `![${this.paginatedTableData[index].metadata?.FileName || key}](${this.paginatedTableData[index].metadata?.ExternalLink})`;\n break;\n case 'htmlUrl':\n text = `\"${this.paginatedTableData[index].metadata?.FileName`;\n break;\n case 'bbUrl':\n text = `[img]${this.paginatedTableData[index].metadata?.ExternalLink}[/img]`;\n break;\n case 'tgId':\n text = this.paginatedTableData[index].metadata?.TgFileId || 'none';\n break;\n case 's3Location':\n text = this.paginatedTableData[index].metadata?.S3Location || 'none';\n break;\n }\n } else {\n switch (this.defaultUrlFormat) {\n case 'originUrl':\n text = `${this.rootUrl}${key}`;\n break;\n case 'mdUrl':\n text = `![${this.paginatedTableData[index].metadata?.FileName || key}](${this.rootUrl}${key})`;\n break;\n case 'htmlUrl':\n text = `\"${this.paginatedTableData[index].metadata?.FileName`;\n break;\n case 'bbUrl':\n text = `[img]${this.rootUrl}${key}[/img]`;\n break;\n case 'tgId':\n text = this.paginatedTableData[index].metadata?.TgFileId || 'none';\n break;\n case 's3Location':\n text = this.paginatedTableData[index].metadata?.S3Location || 'none';\n break;\n }\n }\n navigator.clipboard ? navigator.clipboard.writeText(text).then(() => this.$message.success('复制文件链接成功')) : this.copyToClipboardFallback(text);\n },\n async loadMoreData() {\n this.loading = true;\n try {\n // 传递标签参数和筛选参数到后端\n await fileManager.loadMoreFiles(this.currentPath, this.searchKeywords, this.searchIncludeTags, this.searchExcludeTags, 60, this.filters);\n // 获取新的文件列表后\n await this.fetchFileList();\n } catch (error) {\n this.$message.error('加载更多文件失败,请检查网络连接');\n } finally {\n this.loading = false;\n }\n },\n updateStats(num, init = false) {\n if (init) {\n this.Number = num;\n } else {\n this.Number += num;\n }\n },\n sort(command) {\n this.sortOption = command;\n },\n sortData(data) {\n // 文件夹始终在前\n const folders = data.filter(file => file.isFolder);\n const files = data.filter(file => !file.isFolder);\n if (this.sortOption === 'dateDesc') {\n // 按时间降序\n folders.sort((a, b) => new Date(b.metadata?.TimeStamp) - new Date(a.metadata?.TimeStamp));\n files.sort((a, b) => new Date(b.metadata?.TimeStamp) - new Date(a.metadata?.TimeStamp));\n } else {\n // 按文件名升序\n folders.sort((a, b) => a.name.localeCompare(b.name));\n files.sort((a, b) => a.name.localeCompare(b.name));\n }\n return folders.concat(files);\n },\n handleVideoClick(event) {\n const videoElement = event.target;\n if (videoElement.requestFullscreen) {\n videoElement.requestFullscreen();\n } else if (videoElement.webkitRequestFullscreen) {\n // Safari/Old Chrome\n videoElement.webkitRequestFullscreen();\n } else if (videoElement.mozRequestFullScreen) {\n // Firefox\n videoElement.mozRequestFullScreen();\n } else if (videoElement.msRequestFullscreen) {\n // IE/Edge\n videoElement.msRequestFullscreen();\n }\n },\n handleLogout() {\n this.$store.commit('setCredentials', null);\n this.$router.push('/adminLogin');\n },\n handleSelectPage() {\n if (this.selectPage) {\n this.paginatedTableData.forEach(file => file.selected = false);\n } else {\n this.paginatedTableData.forEach(file => file.selected = true);\n }\n },\n handleBatchAction(command) {\n if (command === 'copy') {\n this.handleBatchCopy();\n } else if (command === 'delete') {\n this.handleBatchDelete();\n } else if (command === 'download') {\n this.handleBatchDownload();\n } else if (command === 'move') {\n this.handleBatchMove();\n } else if (command === 'tagManagement') {\n this.handleBatchTagManagement();\n } else if (command === 'ban') {\n this.handleBatchBlock();\n } else if (command === 'white') {\n this.handleBatchWhite();\n }\n },\n handleMove(index, key) {\n // 弹窗输入新的文件夹路径\n this.$prompt('请输入新的目录', '移动文件', {\n confirmButtonText: '确定',\n cancelButtonText: '取消',\n inputValue: '/',\n beforeClose: (action, instance, done) => {\n if (action === 'confirm') {\n const value = instance.inputValue;\n // 使用共享验证器验证路径\n const validation = validateFolderPath(value);\n if (!validation.valid) {\n this.$message.error(validation.error);\n return; // 验证失败,不关闭弹窗\n }\n done(); // 验证通过,关闭弹窗\n } else {\n done(); // 取消操作,直接关闭\n }\n }\n }).then(({\n value\n }) => {\n // 去掉开头的 /,结尾若没有 /,则加上\n const newPath = value.replace(/^\\/+/, '') + (value.endsWith('/') ? '' : value === '' ? '' : '/');\n const isFolder = this.tableData.find(file => file.name === key).isFolder;\n // 判断目标文件夹是否是当前文件夹\n if (newPath === this.currentPath) {\n this.$message.warning('目标文件夹不能是当前文件夹');\n return;\n }\n fetchWithAuth(`/api/manage/move/${key}?folder=${isFolder}&dist=${newPath}`, {\n method: 'GET'\n }).then(response => {\n if (response.ok) {\n const fileIndex = this.tableData.findIndex(file => file.name === key);\n if (fileIndex !== -1) {\n // 更新本地文件管理器\n const newKey = newPath + key.split('/').pop();\n fileManager.moveFile(key, newKey, isFolder, this.currentPath);\n // 移除文件\n this.tableData.splice(fileIndex, 1);\n // 强制重新渲染内容\n this.$nextTick(() => {\n // 创建临时数组\n const tempData = [...this.tableData];\n // 清空数组\n this.tableData = [];\n // 在下一个tick中恢复数据\n this.$nextTick(() => {\n this.tableData = tempData;\n });\n });\n }\n this.updateStats(-1, false);\n this.$message.success('移动成功');\n } else {\n return Promise.reject('请求失败');\n }\n }).then(() => {\n // 刷新本地文件列表\n this.refreshLocalFileList();\n }).catch(() => this.$message.error('移动失败'));\n }).catch(() => console.log('已取消移动文件'));\n },\n handleBatchMove() {\n // 弹窗输入新的文件夹路径\n this.$prompt('请输入新的目录', '移动文件', {\n confirmButtonText: '确定',\n cancelButtonText: '取消',\n inputValue: '/',\n beforeClose: (action, instance, done) => {\n if (action === 'confirm') {\n const value = instance.inputValue;\n // 使用共享验证器验证路径\n const validation = validateFolderPath(value);\n if (!validation.valid) {\n this.$message.error(validation.error);\n return; // 验证失败,不关闭弹窗\n }\n done(); // 验证通过,关闭弹窗\n } else {\n done(); // 取消操作,直接关闭\n }\n }\n }).then(({\n value\n }) => {\n // 去掉开头的 /,结尾若没有 /,则加上\n const newPath = value.replace(/^\\/+/, '') + (value.endsWith('/') ? '' : value === '' ? '' : '/');\n // 判断目标文件夹是否是当前文件夹\n if (newPath === this.currentPath) {\n this.$message.warning('目标文件夹不能是当前文件夹');\n return;\n }\n const promises = this.selectedFiles.map(file => {\n const isFolder = file.isFolder;\n return fetchWithAuth(`/api/manage/move/${file.name}?folder=${isFolder}&dist=${newPath}`, {\n method: 'GET'\n });\n });\n Promise.all(promises).then(results => {\n let successNum = 0;\n results.forEach((response, index) => {\n if (response.ok) {\n successNum++;\n const file = this.selectedFiles[index];\n file.selected = false;\n const fileIndex = this.tableData.findIndex(f => f.name === file.name);\n if (fileIndex !== -1) {\n // 更新本地文件管理器\n const newKey = newPath + file.name.split('/').pop();\n fileManager.moveFile(file.name, newKey, file.isFolder, this.currentPath);\n // 移除文件\n this.tableData.splice(fileIndex, 1);\n }\n }\n });\n // 强制重新渲染内容\n this.$nextTick(() => {\n // 创建临时数组\n const tempData = [...this.tableData];\n // 清空数组\n this.tableData = [];\n // 在下一个tick中恢复数据\n this.$nextTick(() => {\n this.tableData = tempData;\n });\n });\n this.updateStats(-successNum, false);\n this.$message.success('移动成功');\n }).then(() => {\n // 刷新本地文件列表\n this.refreshLocalFileList();\n }).catch(() => this.$message.error('移动失败'));\n }).catch(() => console.log('已取消移动文件'));\n },\n handleBatchBlock() {\n this.$confirm('此操作将把选中的文件加入黑名单, 是否继续?', '提示', {\n confirmButtonText: '确定',\n cancelButtonText: '取消',\n type: 'warning'\n }).then(() => {\n // 跳过文件夹\n const promises = this.selectedFiles.map(file => {\n if (file.isFolder) {\n return Promise.resolve({\n ok: false\n });\n }\n return fetchWithAuth(`/api/manage/block/${file.name}`, {\n method: 'GET'\n });\n });\n Promise.all(promises).then(results => {\n results.forEach((response, index) => {\n if (response.ok) {\n const fileIndex = this.tableData.findIndex(file => file.name === this.selectedFiles[index].name);\n if (fileIndex !== -1) {\n this.tableData[fileIndex].metadata.ListType = 'Block';\n }\n }\n });\n this.$message.success('批量加入黑名单成功');\n }).catch(() => this.$message.error('批量加入黑名单失败'));\n }).catch(() => console.log('已取消批量加入黑名单'));\n },\n handleBatchWhite() {\n this.$confirm('此操作将把选中的文件加入白名单, 是否继续?', '提示', {\n confirmButtonText: '确定',\n cancelButtonText: '取消',\n type: 'warning'\n }).then(() => {\n // 跳过文件夹\n const promises = this.selectedFiles.map(file => {\n if (file.isFolder) {\n return Promise.resolve({\n ok: false\n });\n }\n return fetchWithAuth(`/api/manage/white/${file.name}`, {\n method: 'GET'\n });\n });\n Promise.all(promises).then(results => {\n results.forEach((response, index) => {\n if (response.ok) {\n const fileIndex = this.tableData.findIndex(file => file.name === this.selectedFiles[index].name);\n if (fileIndex !== -1) {\n this.tableData[fileIndex].metadata.ListType = 'White';\n }\n }\n });\n this.$message.success('批量加入白名单成功');\n }).catch(() => this.$message.error('批量加入白名单失败'));\n }).catch(() => console.log('已取消批量加入白名单'));\n },\n handleBatchDownload() {\n // 将选中文件打包成 zip 文件下载\n const zip = new JSZip();\n const folder = zip.folder('files');\n // 构造Promise数组,等待所有文件下载完成后再打包\n const fileNameCount = {}; // 用于跟踪文件名出现的次数\n\n const downloadPromises = this.selectedFiles.map(async file => {\n // 跳过文件夹\n if (file.isFolder) {\n return;\n }\n const response = await fetch(this.getFileLink(file.name));\n const blob = await response.blob();\n // 检查文件名是否已经存在\n let fileName = file.metadata?.FileName || file.name;\n if (fileNameCount[fileName]) {\n // 如果已经存在,则在文件名后加上编号\n const extension = fileName.substring(fileName.lastIndexOf('.'));\n const baseName = fileName.substring(0, fileName.lastIndexOf('.'));\n fileName = `${baseName}(${fileNameCount[fileName]})${extension}`;\n fileNameCount[file.name]++;\n } else {\n // 如果不存在,则初始化为1\n fileNameCount[fileName] = 1;\n }\n // 将文件添加到 zip 文件夹中\n folder.file(fileName, blob);\n });\n Promise.all(downloadPromises).then(() => zip.generateAsync({\n type: 'blob'\n })).then(blob => {\n const link = document.createElement('a');\n link.href = URL.createObjectURL(blob);\n link.download = 'files.zip';\n link.click();\n });\n },\n isVideo(file) {\n // 排除音频文件\n if (this.isAudio(file)) return false;\n let flag = file.metadata?.FileType?.includes('video');\n // 用文件名后缀判断是否为视频文件\n if (!flag) {\n const videoExtensions = ['mp4', 'webm', 'ogg', 'avi', 'mov', 'flv', 'wmv', 'mkv', 'rmvb', '3gp', 'mpg', 'mpeg', 'm4v', 'f4v', 'rm', 'asf', 'dat', 'ts', 'vob', 'swf', 'divx', 'xvid', 'm2ts', 'mts', 'm2v', '3g2', '3gp2', '3gpp', '3gpp2', 'mpe', 'm1v', 'mpv', 'mpv2', 'mp2v', 'm2t', 'm2ts', 'm2v', 'm4v'];\n const extension = file.name.substring(file.name.lastIndexOf('.') + 1).toLowerCase();\n flag = videoExtensions.includes(extension);\n }\n return flag;\n },\n isAudio(file) {\n let flag = file.metadata?.FileType?.includes('audio');\n // 用文件名后缀判断是否为音频文件\n if (!flag) {\n const audioExtensions = ['mp3', 'wav', 'flac', 'aac', 'ogg', 'wma', 'm4a', 'ape', 'aiff', 'alac', 'opus', 'mid', 'midi', 'm4b', 'm4p', 'm4r', 'amr', 'au', 'ra', 'ram'];\n const extension = file.name.substring(file.name.lastIndexOf('.') + 1).toLowerCase();\n flag = audioExtensions.includes(extension);\n }\n return flag;\n },\n isImage(file) {\n let flag = file.metadata?.FileType?.includes('image');\n // 用文件名后缀判断是否为图片文件\n if (!flag) {\n const imageExtensions = ['jpg', 'jpeg', 'png', 'gif', 'bmp', 'webp', 'svg', 'ico', 'tiff', 'tif', 'psd', 'ai', 'eps', 'raw', 'cr2', 'nef', 'orf', 'sr2', 'dng', 'arw', 'rw2', 'raf', 'pef', 'x3f', 'srf', 'erf', 'mrw', 'nrw', 'kdc', 'dcr', 'mef', 'mos', 'crw', 'raf', 'rwl', 'srw', '3fr', 'fff', 'iiq', 'qtk', 'bay', 'k25', 'kdc', 'dcs', 'drf', 'dng', 'erf', 'kdc', 'mdc', 'mef', 'mos', 'mrw', 'nef', 'nrw', 'orf', 'pef', 'ptx', 'pxn', 'r3d', 'raf', 'raw', 'rwl', 'rw2', 'rwz', 'sr2', 'srf', 'x3f'];\n const extension = file.name.substring(file.name.lastIndexOf('.') + 1).toLowerCase();\n flag = imageExtensions.includes(extension);\n }\n return flag;\n },\n getFileLink(filename) {\n const fileLink = process.env.NODE_ENV === 'production' ? `/file/${filename}?from=admin` : `/api/file/${filename}?from=admin`;\n return fileLink;\n },\n handlePageChange(page) {\n this.currentPage = page;\n // 到最后一页时,加载更多数据\n if (this.currentPage === Math.ceil(this.tableData.length / this.pageSize)) {\n this.loadMoreData();\n }\n },\n // 跳转到指定页码\n handleJumpPage() {\n const page = parseInt(this.jumpPage);\n if (isNaN(page) || page < 1) {\n this.$message.warning('请输入有效的页码');\n return;\n }\n if (page > this.realTotalPages) {\n this.$message.warning(`页码不能超过 ${this.realTotalPages}`);\n return;\n }\n // 如果目标页超过当前已加载的页数,需要先加载更多数据\n if (page > this.totalPages) {\n this.$message.info('正在加载数据,请稍候...');\n this.loadMoreDataUntilPage(page);\n } else {\n this.currentPage = page;\n }\n this.jumpPage = '';\n },\n // 加载数据直到指定页\n async loadMoreDataUntilPage(targetPage) {\n this.loading = true;\n try {\n // 计算目标页需要的文件数量(不包含文件夹)\n // 目标页最后一个项目的索引 = targetPage * pageSize\n // 需要的文件数 = 目标索引 - 已有文件夹数量\n const targetIndex = targetPage * this.pageSize;\n const currentFolderCount = this.filteredTableData.filter(item => item.isFolder).length;\n const currentFileCount = this.filteredTableData.filter(item => !item.isFolder).length;\n\n // 需要加载的文件数量 = 目标位置需要的文件数 - 当前已加载的文件数\n const neededFileCount = Math.max(0, targetIndex - currentFolderCount - currentFileCount);\n if (neededFileCount > 0) {\n await fileManager.loadMoreFiles(this.currentPath, this.searchKeywords, this.searchIncludeTags, this.searchExcludeTags, neededFileCount, this.filters);\n await this.fetchFileList();\n }\n this.currentPage = Math.min(targetPage, this.totalPages);\n } catch (error) {\n this.$message.error('加载数据失败,请检查网络连接');\n } finally {\n this.loading = false;\n }\n },\n // 判断是否为文件夹\n isFolder(item) {\n // 如果是已经标记为文件夹的项目,直接返回true\n if (item.isFolder) {\n return true;\n }\n\n // 获取真实的文件路径(去除URL前缀)\n let path = item.name;\n if (path.startsWith('http')) {\n path = path.split('/file/')[1];\n }\n\n // 如果文件名包含'/',需要判断是否是当前路径下的文件\n if (path && path.includes('/')) {\n // 获取相对于当前路径的部分\n const relativePath = this.currentPath ? path.substring(this.currentPath.length) : path;\n\n // 如果在根目录,第一个斜杠前的部分就是文件夹\n if (this.currentPath === '') {\n return !path.split('/')[0].includes('.');\n }\n\n // 如果在子文件夹中,检查相对路径是否还包含其他文件夹\n return relativePath.includes('/');\n }\n return false;\n },\n // 获取文件夹名称\n getFolderName(path) {\n let folderName = '';\n // 如果是文件夹路径,只返回最后一级文件夹名\n if (path && path.includes('/')) {\n const parts = path.split('/');\n // 如果是根目录下的文件夹\n if (this.currentPath === '') {\n folderName = parts[0];\n } else {\n // 如果是子文件夹\n const relativePath = path.substring(this.currentPath.length);\n folderName = relativePath.split('/')[0];\n }\n } else {\n folderName = path;\n }\n const maxLength = 20; // Adjust max length as needed\n if (folderName.length > maxLength) {\n const startLength = Math.floor((maxLength - 3) / 2);\n const endLength = Math.ceil((maxLength - 3) / 2);\n return `${folderName.substring(0, startLength)}...${folderName.substring(folderName.length - endLength)}`;\n }\n return folderName;\n },\n // 获取文件名称(去除路径和URL前缀)\n getFileName(path) {\n let fileName = path.split('/').pop();\n const maxLength = 20; // Adjust max length as needed, ensure it fits in one line\n if (fileName.length > maxLength) {\n const startLength = Math.floor((maxLength - 3) / 2);\n const endLength = Math.ceil((maxLength - 3) / 2);\n return `${fileName.substring(0, startLength)}...${fileName.substring(fileName.length - endLength)}`;\n }\n return fileName;\n },\n // 获取文件名前半部分(用于中间省略效果)\n getFileNameStart(name) {\n if (!name) return '';\n // 如果文件名较短,返回全部\n if (name.length <= 30) return name;\n // 保留开头部分(约60%的长度用于显示前半部分)\n const dotIndex = name.lastIndexOf('.');\n if (dotIndex > 0) {\n // 有扩展名的情况:返回文件名主体部分\n const baseName = name.substring(0, dotIndex);\n const keepLength = Math.min(baseName.length, Math.floor(name.length * 0.6));\n return baseName.substring(0, keepLength);\n }\n // 无扩展名的情况\n return name.substring(0, Math.floor(name.length * 0.6));\n },\n // 获取文件名后半部分(用于中间省略效果)\n getFileNameEnd(name) {\n if (!name) return '';\n // 如果文件名较短,返回空\n if (name.length <= 30) return '';\n // 保留末尾部分(包含扩展名)\n const dotIndex = name.lastIndexOf('.');\n if (dotIndex > 0) {\n // 有扩展名的情况:返回最后几个字符 + 扩展名\n const ext = name.substring(dotIndex);\n const baseName = name.substring(0, dotIndex);\n const keepLength = Math.min(8, Math.floor(baseName.length * 0.2));\n return '…' + baseName.substring(baseName.length - keepLength) + ext;\n }\n // 无扩展名的情况\n const keepLength = Math.min(10, Math.floor(name.length * 0.3));\n return '…' + name.substring(name.length - keepLength);\n },\n // 进入文件夹\n enterFolder(folderPath) {\n // 确保路径末尾有 '/'\n this.currentPath = folderPath + (folderPath.endsWith('/') ? '' : '/');\n // 刷新文件列表,到指定currentPath下\n this.refreshFileList();\n },\n // 导航到指定文件夹\n navigateToFolder(path) {\n // 确保空路径时不添加 '/'\n this.currentPath = path ? path + (path.endsWith('/') ? '' : '/') : '';\n // 刷新文件列表,到指定currentPath下\n this.refreshFileList();\n },\n // 获取文件列表\n async fetchFileList() {\n this.loading = true;\n try {\n // 从本地存储获取数据\n const data = fileManager.getLocalFileList();\n\n // 解析返回的数据\n const folders = new Set(data.directories || []);\n const files = data.files || [];\n\n // 处理文件夹数据\n const folderItems = Array.from(folders).map(folder => ({\n name: folder,\n isFolder: true,\n selected: false,\n metadata: {\n FileName: folder.split('/').pop()\n }\n }));\n\n // 处理文件数据\n const fileItems = files.map(file => ({\n name: file.name,\n isFolder: false,\n selected: false,\n metadata: file.metadata\n }));\n\n // 更新表格数据\n this.tableData = [...folderItems, ...fileItems];\n\n // 更新统计信息\n this.updateStats(data.totalCount, true);\n\n // 更新直接文件和文件夹数量\n this.directFileCount = data.directFileCount || 0;\n this.directFolderCount = data.directFolderCount || 0;\n } catch (error) {\n console.error('Error fetching file list:', error);\n this.$message.error('获取文件列表失败');\n } finally {\n this.loading = false;\n }\n },\n // 刷新文件列表\n async refreshFileList() {\n this.refreshLoading = true;\n this.loading = true;\n try {\n // 传递标签参数和筛选参数到后端\n const success = await fileManager.refreshFileList(this.currentPath, this.searchKeywords, this.searchIncludeTags, this.searchExcludeTags, this.filters);\n if (success) {\n await this.fetchFileList();\n } else {\n throw new Error('Refresh failed');\n }\n } catch (error) {\n console.error('Error refreshing file list:', error);\n this.$message.error('刷新失败,请重试');\n } finally {\n this.refreshLoading = false;\n this.loading = false;\n }\n },\n // 刷新本地文件列表\n async refreshLocalFileList() {\n this.refreshLoading = true;\n this.loading = true;\n try {\n await this.fetchFileList();\n } catch (error) {\n console.error('Error refreshing local file list:', error);\n this.$message.error('刷新失败,请重试');\n } finally {\n this.refreshLoading = false;\n this.loading = false;\n }\n },\n // Tag management methods\n handleTagManagement(fileId) {\n this.currentTagFile = fileId;\n this.showTagDialog = true;\n },\n handleBatchTagManagement() {\n if (this.selectedFiles.length === 0) {\n this.$message.warning('请先选择文件');\n return;\n }\n this.showBatchTagDialog = true;\n },\n async handleTagsUpdated(tags) {\n // 更新本地文件数据中的标签\n const fileIndex = this.tableData.findIndex(file => file.name === this.currentTagFile);\n if (fileIndex !== -1) {\n // 更新 tableData 中的标签\n if (!this.tableData[fileIndex].metadata) {\n this.tableData[fileIndex].metadata = {};\n }\n this.tableData[fileIndex].metadata.Tags = tags;\n\n // 如果详情对话框正在显示这个文件,也更新详情数据\n if (this.showdetailDialog && this.detailFile?.name === this.currentTagFile) {\n if (!this.detailFile.metadata) {\n this.detailFile.metadata = {};\n }\n this.detailFile.metadata.Tags = tags;\n }\n }\n },\n async handleBatchTagsUpdated() {\n // 刷新文件列表以显示更新后的标签\n await this.refreshLocalFileList();\n },\n // 生成单个文件链接\n generateFileLink(key, metadata) {\n const isExternal = metadata?.Channel === 'External';\n const baseUrl = isExternal ? metadata?.ExternalLink : `${this.rootUrl}${key}`;\n const fileName = metadata?.FileName || key;\n switch (this.defaultUrlFormat) {\n case 'originUrl':\n return baseUrl;\n case 'mdUrl':\n return `![${fileName}](${baseUrl})`;\n case 'htmlUrl':\n return `\"${fileName}\"`;\n case 'bbUrl':\n return `[img]${baseUrl}[/img]`;\n case 'tgId':\n return metadata?.TgFileId || '';\n case 's3Location':\n return metadata?.S3Location || '';\n default:\n return baseUrl;\n }\n },\n // 复制文件夹中所有文件的链接\n async handleFolderCopy(folderName) {\n // 显示加载状态\n const loading = this.$loading({\n lock: true,\n text: '正在获取文件列表...'\n });\n try {\n // 调用 list API 递归获取文件夹内所有文件\n const response = await fetchWithAuth(`/api/manage/list?dir=${encodeURIComponent(folderName)}&recursive=true&count=-1`, {\n method: 'GET'\n });\n const data = await response.json();\n loading.close();\n if (!data.files || data.files.length === 0) {\n this.$message.warning('文件夹为空,没有可复制的链接');\n return;\n }\n\n // 根据当前链接格式生成所有文件链接\n const links = data.files.map(file => {\n return this.generateFileLink(file.name, file.metadata);\n }).filter(link => link); // 过滤掉空链接\n\n if (links.length === 0) {\n this.$message.warning('没有可复制的链接');\n return;\n }\n\n // 复制到剪贴板\n const text = links.join('\\n');\n if (navigator.clipboard) {\n await navigator.clipboard.writeText(text);\n this.$message.success(`已复制 ${links.length} 个文件链接`);\n } else {\n this.copyToClipboardFallback(text);\n this.$message.success(`已复制 ${links.length} 个文件链接`);\n }\n } catch (error) {\n loading.close();\n console.error('复制文件夹链接失败:', error);\n this.$message.error('复制文件夹链接失败,请重试');\n }\n }\n },\n mounted() {\n this.loading = true;\n fetchWithAuth(\"/api/manage/check\", {\n method: 'GET'\n }).then(response => response.text()).then(result => {\n if (result == \"true\") {\n this.showLogoutButton = true;\n return true;\n } else if (result == \"Not using basic auth.\") {\n return true;\n } else {\n throw new Error('Unauthorized');\n }\n }).then(() => {\n // 首次加载时刷新文件列表\n return this.refreshFileList();\n }).then(() => {\n // 获取所有渠道名称\n return this.extractChannelNames();\n }).catch(err => {\n if (err.message !== 'Unauthorized') {\n this.$message.error('同步数据时出错,请检查网络连接');\n }\n }).finally(() => {\n this.loading = false;\n });\n\n // 读取自定义链接设置项\n this.customUrlPrefix = this.adminUrlSettings.customUrlPrefix;\n this.useCustomUrl = this.adminUrlSettings.useCustomUrl;\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./AdminDashBoard.vue?vue&type=template&id=5c4ee283&scoped=true\"\nimport script from \"./AdminDashBoard.vue?vue&type=script&lang=js\"\nexport * from \"./AdminDashBoard.vue?vue&type=script&lang=js\"\n\nimport \"./AdminDashBoard.vue?vue&type=style&index=0&id=5c4ee283&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-5c4ee283\"]])\n\nexport default __exports__","/**\r\n * 路径验证器模块\r\n * 提供共享的文件夹路径验证功能,供 AdminDashBoard 和 UploadHome 共同使用\r\n */\r\n\r\n/**\r\n * 验证文件夹路径的合法性\r\n * @param {string} path - 要验证的路径\r\n * @returns {{ valid: boolean, error?: string }} 验证结果\r\n */\r\nexport function validateFolderPath(path) {\r\n // 如果路径为空或仅为空白字符,返回有效(表示根目录)\r\n if (!path || path.trim() === '') {\r\n return { valid: true };\r\n }\r\n \r\n // 如果路径仅为 \"/\",返回有效(表示根目录)\r\n if (path === '/') {\r\n return { valid: true };\r\n }\r\n \r\n // 检查路径是否以 \"/\" 开头\r\n if (!path.startsWith('/')) {\r\n return { \r\n valid: false, \r\n error: '目标目录必须以 \"/\" 开头' \r\n };\r\n }\r\n \r\n // 检查路径是否包含非法字符\r\n // 非法字符包括: \\ : * ? \" ' < > | 空格 ( ) [ ] { } # % ^ ` ~ ; @ & = + $ ,\r\n const invalidChars = /[\\\\:\\*\\?\"'<>\\| \\(\\)\\[\\]\\{\\}#%\\^`~;@&=\\+\\$,]/;\r\n if (invalidChars.test(path)) {\r\n return { \r\n valid: false, \r\n error: '目标目录包含非法字符,请使用合法的路径格式' \r\n };\r\n }\r\n \r\n // 检查路径是否包含连续的斜杠\r\n if (path.includes('//')) {\r\n return { \r\n valid: false, \r\n error: '目标目录不能包含连续的斜杠' \r\n };\r\n }\r\n \r\n return { valid: true };\r\n}\r\n","/*!\n\nJSZip v3.10.1 - A JavaScript class for generating and reading zip files\n\n\n(c) 2009-2016 Stuart Knightley \nDual licenced under the MIT license or GPLv3. See https://raw.github.com/Stuk/jszip/main/LICENSE.markdown.\n\nJSZip uses the library pako released under the MIT license :\nhttps://github.com/nodeca/pako/blob/main/LICENSE\n*/\n\n!function(e){if(\"object\"==typeof exports&&\"undefined\"!=typeof module)module.exports=e();else if(\"function\"==typeof define&&define.amd)define([],e);else{(\"undefined\"!=typeof window?window:\"undefined\"!=typeof global?global:\"undefined\"!=typeof self?self:this).JSZip=e()}}(function(){return function s(a,o,h){function u(r,e){if(!o[r]){if(!a[r]){var t=\"function\"==typeof require&&require;if(!e&&t)return t(r,!0);if(l)return l(r,!0);var n=new Error(\"Cannot find module '\"+r+\"'\");throw n.code=\"MODULE_NOT_FOUND\",n}var i=o[r]={exports:{}};a[r][0].call(i.exports,function(e){var t=a[r][1][e];return u(t||e)},i,i.exports,s,a,o,h)}return o[r].exports}for(var l=\"function\"==typeof require&&require,e=0;e>2,s=(3&t)<<4|r>>4,a=1>6:64,o=2>4,r=(15&i)<<4|(s=p.indexOf(e.charAt(o++)))>>2,n=(3&s)<<6|(a=p.indexOf(e.charAt(o++))),l[h++]=t,64!==s&&(l[h++]=r),64!==a&&(l[h++]=n);return l}},{\"./support\":30,\"./utils\":32}],2:[function(e,t,r){\"use strict\";var n=e(\"./external\"),i=e(\"./stream/DataWorker\"),s=e(\"./stream/Crc32Probe\"),a=e(\"./stream/DataLengthProbe\");function o(e,t,r,n,i){this.compressedSize=e,this.uncompressedSize=t,this.crc32=r,this.compression=n,this.compressedContent=i}o.prototype={getContentWorker:function(){var e=new i(n.Promise.resolve(this.compressedContent)).pipe(this.compression.uncompressWorker()).pipe(new a(\"data_length\")),t=this;return e.on(\"end\",function(){if(this.streamInfo.data_length!==t.uncompressedSize)throw new Error(\"Bug : uncompressed data size mismatch\")}),e},getCompressedWorker:function(){return new i(n.Promise.resolve(this.compressedContent)).withStreamInfo(\"compressedSize\",this.compressedSize).withStreamInfo(\"uncompressedSize\",this.uncompressedSize).withStreamInfo(\"crc32\",this.crc32).withStreamInfo(\"compression\",this.compression)}},o.createWorkerFrom=function(e,t,r){return e.pipe(new s).pipe(new a(\"uncompressedSize\")).pipe(t.compressWorker(r)).pipe(new a(\"compressedSize\")).withStreamInfo(\"compression\",t)},t.exports=o},{\"./external\":6,\"./stream/Crc32Probe\":25,\"./stream/DataLengthProbe\":26,\"./stream/DataWorker\":27}],3:[function(e,t,r){\"use strict\";var n=e(\"./stream/GenericWorker\");r.STORE={magic:\"\\0\\0\",compressWorker:function(){return new n(\"STORE compression\")},uncompressWorker:function(){return new n(\"STORE decompression\")}},r.DEFLATE=e(\"./flate\")},{\"./flate\":7,\"./stream/GenericWorker\":28}],4:[function(e,t,r){\"use strict\";var n=e(\"./utils\");var o=function(){for(var e,t=[],r=0;r<256;r++){e=r;for(var n=0;n<8;n++)e=1&e?3988292384^e>>>1:e>>>1;t[r]=e}return t}();t.exports=function(e,t){return void 0!==e&&e.length?\"string\"!==n.getTypeOf(e)?function(e,t,r,n){var i=o,s=n+r;e^=-1;for(var a=n;a>>8^i[255&(e^t[a])];return-1^e}(0|t,e,e.length,0):function(e,t,r,n){var i=o,s=n+r;e^=-1;for(var a=n;a>>8^i[255&(e^t.charCodeAt(a))];return-1^e}(0|t,e,e.length,0):0}},{\"./utils\":32}],5:[function(e,t,r){\"use strict\";r.base64=!1,r.binary=!1,r.dir=!1,r.createFolders=!0,r.date=null,r.compression=null,r.compressionOptions=null,r.comment=null,r.unixPermissions=null,r.dosPermissions=null},{}],6:[function(e,t,r){\"use strict\";var n=null;n=\"undefined\"!=typeof Promise?Promise:e(\"lie\"),t.exports={Promise:n}},{lie:37}],7:[function(e,t,r){\"use strict\";var n=\"undefined\"!=typeof Uint8Array&&\"undefined\"!=typeof Uint16Array&&\"undefined\"!=typeof Uint32Array,i=e(\"pako\"),s=e(\"./utils\"),a=e(\"./stream/GenericWorker\"),o=n?\"uint8array\":\"array\";function h(e,t){a.call(this,\"FlateWorker/\"+e),this._pako=null,this._pakoAction=e,this._pakoOptions=t,this.meta={}}r.magic=\"\\b\\0\",s.inherits(h,a),h.prototype.processChunk=function(e){this.meta=e.meta,null===this._pako&&this._createPako(),this._pako.push(s.transformTo(o,e.data),!1)},h.prototype.flush=function(){a.prototype.flush.call(this),null===this._pako&&this._createPako(),this._pako.push([],!0)},h.prototype.cleanUp=function(){a.prototype.cleanUp.call(this),this._pako=null},h.prototype._createPako=function(){this._pako=new i[this._pakoAction]({raw:!0,level:this._pakoOptions.level||-1});var t=this;this._pako.onData=function(e){t.push({data:e,meta:t.meta})}},r.compressWorker=function(e){return new h(\"Deflate\",e)},r.uncompressWorker=function(){return new h(\"Inflate\",{})}},{\"./stream/GenericWorker\":28,\"./utils\":32,pako:38}],8:[function(e,t,r){\"use strict\";function A(e,t){var r,n=\"\";for(r=0;r>>=8;return n}function n(e,t,r,n,i,s){var a,o,h=e.file,u=e.compression,l=s!==O.utf8encode,f=I.transformTo(\"string\",s(h.name)),c=I.transformTo(\"string\",O.utf8encode(h.name)),d=h.comment,p=I.transformTo(\"string\",s(d)),m=I.transformTo(\"string\",O.utf8encode(d)),_=c.length!==h.name.length,g=m.length!==d.length,b=\"\",v=\"\",y=\"\",w=h.dir,k=h.date,x={crc32:0,compressedSize:0,uncompressedSize:0};t&&!r||(x.crc32=e.crc32,x.compressedSize=e.compressedSize,x.uncompressedSize=e.uncompressedSize);var S=0;t&&(S|=8),l||!_&&!g||(S|=2048);var z=0,C=0;w&&(z|=16),\"UNIX\"===i?(C=798,z|=function(e,t){var r=e;return e||(r=t?16893:33204),(65535&r)<<16}(h.unixPermissions,w)):(C=20,z|=function(e){return 63&(e||0)}(h.dosPermissions)),a=k.getUTCHours(),a<<=6,a|=k.getUTCMinutes(),a<<=5,a|=k.getUTCSeconds()/2,o=k.getUTCFullYear()-1980,o<<=4,o|=k.getUTCMonth()+1,o<<=5,o|=k.getUTCDate(),_&&(v=A(1,1)+A(B(f),4)+c,b+=\"up\"+A(v.length,2)+v),g&&(y=A(1,1)+A(B(p),4)+m,b+=\"uc\"+A(y.length,2)+y);var E=\"\";return E+=\"\\n\\0\",E+=A(S,2),E+=u.magic,E+=A(a,2),E+=A(o,2),E+=A(x.crc32,4),E+=A(x.compressedSize,4),E+=A(x.uncompressedSize,4),E+=A(f.length,2),E+=A(b.length,2),{fileRecord:R.LOCAL_FILE_HEADER+E+f+b,dirRecord:R.CENTRAL_FILE_HEADER+A(C,2)+E+A(p.length,2)+\"\\0\\0\\0\\0\"+A(z,4)+A(n,4)+f+b+p}}var I=e(\"../utils\"),i=e(\"../stream/GenericWorker\"),O=e(\"../utf8\"),B=e(\"../crc32\"),R=e(\"../signature\");function s(e,t,r,n){i.call(this,\"ZipFileWorker\"),this.bytesWritten=0,this.zipComment=t,this.zipPlatform=r,this.encodeFileName=n,this.streamFiles=e,this.accumulate=!1,this.contentBuffer=[],this.dirRecords=[],this.currentSourceOffset=0,this.entriesCount=0,this.currentFile=null,this._sources=[]}I.inherits(s,i),s.prototype.push=function(e){var t=e.meta.percent||0,r=this.entriesCount,n=this._sources.length;this.accumulate?this.contentBuffer.push(e):(this.bytesWritten+=e.data.length,i.prototype.push.call(this,{data:e.data,meta:{currentFile:this.currentFile,percent:r?(t+100*(r-n-1))/r:100}}))},s.prototype.openedSource=function(e){this.currentSourceOffset=this.bytesWritten,this.currentFile=e.file.name;var t=this.streamFiles&&!e.file.dir;if(t){var r=n(e,t,!1,this.currentSourceOffset,this.zipPlatform,this.encodeFileName);this.push({data:r.fileRecord,meta:{percent:0}})}else this.accumulate=!0},s.prototype.closedSource=function(e){this.accumulate=!1;var t=this.streamFiles&&!e.file.dir,r=n(e,t,!0,this.currentSourceOffset,this.zipPlatform,this.encodeFileName);if(this.dirRecords.push(r.dirRecord),t)this.push({data:function(e){return R.DATA_DESCRIPTOR+A(e.crc32,4)+A(e.compressedSize,4)+A(e.uncompressedSize,4)}(e),meta:{percent:100}});else for(this.push({data:r.fileRecord,meta:{percent:0}});this.contentBuffer.length;)this.push(this.contentBuffer.shift());this.currentFile=null},s.prototype.flush=function(){for(var e=this.bytesWritten,t=0;t=this.index;t--)r=(r<<8)+this.byteAt(t);return this.index+=e,r},readString:function(e){return n.transformTo(\"string\",this.readData(e))},readData:function(){},lastIndexOfSignature:function(){},readAndCheckSignature:function(){},readDate:function(){var e=this.readInt(4);return new Date(Date.UTC(1980+(e>>25&127),(e>>21&15)-1,e>>16&31,e>>11&31,e>>5&63,(31&e)<<1))}},t.exports=i},{\"../utils\":32}],19:[function(e,t,r){\"use strict\";var n=e(\"./Uint8ArrayReader\");function i(e){n.call(this,e)}e(\"../utils\").inherits(i,n),i.prototype.readData=function(e){this.checkOffset(e);var t=this.data.slice(this.zero+this.index,this.zero+this.index+e);return this.index+=e,t},t.exports=i},{\"../utils\":32,\"./Uint8ArrayReader\":21}],20:[function(e,t,r){\"use strict\";var n=e(\"./DataReader\");function i(e){n.call(this,e)}e(\"../utils\").inherits(i,n),i.prototype.byteAt=function(e){return this.data.charCodeAt(this.zero+e)},i.prototype.lastIndexOfSignature=function(e){return this.data.lastIndexOf(e)-this.zero},i.prototype.readAndCheckSignature=function(e){return e===this.readData(4)},i.prototype.readData=function(e){this.checkOffset(e);var t=this.data.slice(this.zero+this.index,this.zero+this.index+e);return this.index+=e,t},t.exports=i},{\"../utils\":32,\"./DataReader\":18}],21:[function(e,t,r){\"use strict\";var n=e(\"./ArrayReader\");function i(e){n.call(this,e)}e(\"../utils\").inherits(i,n),i.prototype.readData=function(e){if(this.checkOffset(e),0===e)return new Uint8Array(0);var t=this.data.subarray(this.zero+this.index,this.zero+this.index+e);return this.index+=e,t},t.exports=i},{\"../utils\":32,\"./ArrayReader\":17}],22:[function(e,t,r){\"use strict\";var n=e(\"../utils\"),i=e(\"../support\"),s=e(\"./ArrayReader\"),a=e(\"./StringReader\"),o=e(\"./NodeBufferReader\"),h=e(\"./Uint8ArrayReader\");t.exports=function(e){var t=n.getTypeOf(e);return n.checkSupport(t),\"string\"!==t||i.uint8array?\"nodebuffer\"===t?new o(e):i.uint8array?new h(n.transformTo(\"uint8array\",e)):new s(n.transformTo(\"array\",e)):new a(e)}},{\"../support\":30,\"../utils\":32,\"./ArrayReader\":17,\"./NodeBufferReader\":19,\"./StringReader\":20,\"./Uint8ArrayReader\":21}],23:[function(e,t,r){\"use strict\";r.LOCAL_FILE_HEADER=\"PK\u0003\u0004\",r.CENTRAL_FILE_HEADER=\"PK\u0001\u0002\",r.CENTRAL_DIRECTORY_END=\"PK\u0005\u0006\",r.ZIP64_CENTRAL_DIRECTORY_LOCATOR=\"PK\u0006\u0007\",r.ZIP64_CENTRAL_DIRECTORY_END=\"PK\u0006\u0006\",r.DATA_DESCRIPTOR=\"PK\u0007\\b\"},{}],24:[function(e,t,r){\"use strict\";var n=e(\"./GenericWorker\"),i=e(\"../utils\");function s(e){n.call(this,\"ConvertWorker to \"+e),this.destType=e}i.inherits(s,n),s.prototype.processChunk=function(e){this.push({data:i.transformTo(this.destType,e.data),meta:e.meta})},t.exports=s},{\"../utils\":32,\"./GenericWorker\":28}],25:[function(e,t,r){\"use strict\";var n=e(\"./GenericWorker\"),i=e(\"../crc32\");function s(){n.call(this,\"Crc32Probe\"),this.withStreamInfo(\"crc32\",0)}e(\"../utils\").inherits(s,n),s.prototype.processChunk=function(e){this.streamInfo.crc32=i(e.data,this.streamInfo.crc32||0),this.push(e)},t.exports=s},{\"../crc32\":4,\"../utils\":32,\"./GenericWorker\":28}],26:[function(e,t,r){\"use strict\";var n=e(\"../utils\"),i=e(\"./GenericWorker\");function s(e){i.call(this,\"DataLengthProbe for \"+e),this.propName=e,this.withStreamInfo(e,0)}n.inherits(s,i),s.prototype.processChunk=function(e){if(e){var t=this.streamInfo[this.propName]||0;this.streamInfo[this.propName]=t+e.data.length}i.prototype.processChunk.call(this,e)},t.exports=s},{\"../utils\":32,\"./GenericWorker\":28}],27:[function(e,t,r){\"use strict\";var n=e(\"../utils\"),i=e(\"./GenericWorker\");function s(e){i.call(this,\"DataWorker\");var t=this;this.dataIsReady=!1,this.index=0,this.max=0,this.data=null,this.type=\"\",this._tickScheduled=!1,e.then(function(e){t.dataIsReady=!0,t.data=e,t.max=e&&e.length||0,t.type=n.getTypeOf(e),t.isPaused||t._tickAndRepeat()},function(e){t.error(e)})}n.inherits(s,i),s.prototype.cleanUp=function(){i.prototype.cleanUp.call(this),this.data=null},s.prototype.resume=function(){return!!i.prototype.resume.call(this)&&(!this._tickScheduled&&this.dataIsReady&&(this._tickScheduled=!0,n.delay(this._tickAndRepeat,[],this)),!0)},s.prototype._tickAndRepeat=function(){this._tickScheduled=!1,this.isPaused||this.isFinished||(this._tick(),this.isFinished||(n.delay(this._tickAndRepeat,[],this),this._tickScheduled=!0))},s.prototype._tick=function(){if(this.isPaused||this.isFinished)return!1;var e=null,t=Math.min(this.max,this.index+16384);if(this.index>=this.max)return this.end();switch(this.type){case\"string\":e=this.data.substring(this.index,t);break;case\"uint8array\":e=this.data.subarray(this.index,t);break;case\"array\":case\"nodebuffer\":e=this.data.slice(this.index,t)}return this.index=t,this.push({data:e,meta:{percent:this.max?this.index/this.max*100:0}})},t.exports=s},{\"../utils\":32,\"./GenericWorker\":28}],28:[function(e,t,r){\"use strict\";function n(e){this.name=e||\"default\",this.streamInfo={},this.generatedError=null,this.extraStreamInfo={},this.isPaused=!0,this.isFinished=!1,this.isLocked=!1,this._listeners={data:[],end:[],error:[]},this.previous=null}n.prototype={push:function(e){this.emit(\"data\",e)},end:function(){if(this.isFinished)return!1;this.flush();try{this.emit(\"end\"),this.cleanUp(),this.isFinished=!0}catch(e){this.emit(\"error\",e)}return!0},error:function(e){return!this.isFinished&&(this.isPaused?this.generatedError=e:(this.isFinished=!0,this.emit(\"error\",e),this.previous&&this.previous.error(e),this.cleanUp()),!0)},on:function(e,t){return this._listeners[e].push(t),this},cleanUp:function(){this.streamInfo=this.generatedError=this.extraStreamInfo=null,this._listeners=[]},emit:function(e,t){if(this._listeners[e])for(var r=0;r \"+e:e}},t.exports=n},{}],29:[function(e,t,r){\"use strict\";var h=e(\"../utils\"),i=e(\"./ConvertWorker\"),s=e(\"./GenericWorker\"),u=e(\"../base64\"),n=e(\"../support\"),a=e(\"../external\"),o=null;if(n.nodestream)try{o=e(\"../nodejs/NodejsStreamOutputAdapter\")}catch(e){}function l(e,o){return new a.Promise(function(t,r){var n=[],i=e._internalType,s=e._outputType,a=e._mimeType;e.on(\"data\",function(e,t){n.push(e),o&&o(t)}).on(\"error\",function(e){n=[],r(e)}).on(\"end\",function(){try{var e=function(e,t,r){switch(e){case\"blob\":return h.newBlob(h.transformTo(\"arraybuffer\",t),r);case\"base64\":return u.encode(t);default:return h.transformTo(e,t)}}(s,function(e,t){var r,n=0,i=null,s=0;for(r=0;r>>6:(r<65536?t[s++]=224|r>>>12:(t[s++]=240|r>>>18,t[s++]=128|r>>>12&63),t[s++]=128|r>>>6&63),t[s++]=128|63&r);return t}(e)},s.utf8decode=function(e){return h.nodebuffer?o.transformTo(\"nodebuffer\",e).toString(\"utf-8\"):function(e){var t,r,n,i,s=e.length,a=new Array(2*s);for(t=r=0;t>10&1023,a[r++]=56320|1023&n)}return a.length!==r&&(a.subarray?a=a.subarray(0,r):a.length=r),o.applyFromCharCode(a)}(e=o.transformTo(h.uint8array?\"uint8array\":\"array\",e))},o.inherits(a,n),a.prototype.processChunk=function(e){var t=o.transformTo(h.uint8array?\"uint8array\":\"array\",e.data);if(this.leftOver&&this.leftOver.length){if(h.uint8array){var r=t;(t=new Uint8Array(r.length+this.leftOver.length)).set(this.leftOver,0),t.set(r,this.leftOver.length)}else t=this.leftOver.concat(t);this.leftOver=null}var n=function(e,t){var r;for((t=t||e.length)>e.length&&(t=e.length),r=t-1;0<=r&&128==(192&e[r]);)r--;return r<0?t:0===r?t:r+u[e[r]]>t?r:t}(t),i=t;n!==t.length&&(h.uint8array?(i=t.subarray(0,n),this.leftOver=t.subarray(n,t.length)):(i=t.slice(0,n),this.leftOver=t.slice(n,t.length))),this.push({data:s.utf8decode(i),meta:e.meta})},a.prototype.flush=function(){this.leftOver&&this.leftOver.length&&(this.push({data:s.utf8decode(this.leftOver),meta:{}}),this.leftOver=null)},s.Utf8DecodeWorker=a,o.inherits(l,n),l.prototype.processChunk=function(e){this.push({data:s.utf8encode(e.data),meta:e.meta})},s.Utf8EncodeWorker=l},{\"./nodejsUtils\":14,\"./stream/GenericWorker\":28,\"./support\":30,\"./utils\":32}],32:[function(e,t,a){\"use strict\";var o=e(\"./support\"),h=e(\"./base64\"),r=e(\"./nodejsUtils\"),u=e(\"./external\");function n(e){return e}function l(e,t){for(var r=0;r>8;this.dir=!!(16&this.externalFileAttributes),0==e&&(this.dosPermissions=63&this.externalFileAttributes),3==e&&(this.unixPermissions=this.externalFileAttributes>>16&65535),this.dir||\"/\"!==this.fileNameStr.slice(-1)||(this.dir=!0)},parseZIP64ExtraField:function(){if(this.extraFields[1]){var e=n(this.extraFields[1].value);this.uncompressedSize===s.MAX_VALUE_32BITS&&(this.uncompressedSize=e.readInt(8)),this.compressedSize===s.MAX_VALUE_32BITS&&(this.compressedSize=e.readInt(8)),this.localHeaderOffset===s.MAX_VALUE_32BITS&&(this.localHeaderOffset=e.readInt(8)),this.diskNumberStart===s.MAX_VALUE_32BITS&&(this.diskNumberStart=e.readInt(4))}},readExtraFields:function(e){var t,r,n,i=e.index+this.extraFieldsLength;for(this.extraFields||(this.extraFields={});e.index+4>>6:(r<65536?t[s++]=224|r>>>12:(t[s++]=240|r>>>18,t[s++]=128|r>>>12&63),t[s++]=128|r>>>6&63),t[s++]=128|63&r);return t},r.buf2binstring=function(e){return l(e,e.length)},r.binstring2buf=function(e){for(var t=new h.Buf8(e.length),r=0,n=t.length;r>10&1023,o[n++]=56320|1023&i)}return l(o,n)},r.utf8border=function(e,t){var r;for((t=t||e.length)>e.length&&(t=e.length),r=t-1;0<=r&&128==(192&e[r]);)r--;return r<0?t:0===r?t:r+u[e[r]]>t?r:t}},{\"./common\":41}],43:[function(e,t,r){\"use strict\";t.exports=function(e,t,r,n){for(var i=65535&e|0,s=e>>>16&65535|0,a=0;0!==r;){for(r-=a=2e3>>1:e>>>1;t[r]=e}return t}();t.exports=function(e,t,r,n){var i=o,s=n+r;e^=-1;for(var a=n;a>>8^i[255&(e^t[a])];return-1^e}},{}],46:[function(e,t,r){\"use strict\";var h,c=e(\"../utils/common\"),u=e(\"./trees\"),d=e(\"./adler32\"),p=e(\"./crc32\"),n=e(\"./messages\"),l=0,f=4,m=0,_=-2,g=-1,b=4,i=2,v=8,y=9,s=286,a=30,o=19,w=2*s+1,k=15,x=3,S=258,z=S+x+1,C=42,E=113,A=1,I=2,O=3,B=4;function R(e,t){return e.msg=n[t],t}function T(e){return(e<<1)-(4e.avail_out&&(r=e.avail_out),0!==r&&(c.arraySet(e.output,t.pending_buf,t.pending_out,r,e.next_out),e.next_out+=r,t.pending_out+=r,e.total_out+=r,e.avail_out-=r,t.pending-=r,0===t.pending&&(t.pending_out=0))}function N(e,t){u._tr_flush_block(e,0<=e.block_start?e.block_start:-1,e.strstart-e.block_start,t),e.block_start=e.strstart,F(e.strm)}function U(e,t){e.pending_buf[e.pending++]=t}function P(e,t){e.pending_buf[e.pending++]=t>>>8&255,e.pending_buf[e.pending++]=255&t}function L(e,t){var r,n,i=e.max_chain_length,s=e.strstart,a=e.prev_length,o=e.nice_match,h=e.strstart>e.w_size-z?e.strstart-(e.w_size-z):0,u=e.window,l=e.w_mask,f=e.prev,c=e.strstart+S,d=u[s+a-1],p=u[s+a];e.prev_length>=e.good_match&&(i>>=2),o>e.lookahead&&(o=e.lookahead);do{if(u[(r=t)+a]===p&&u[r+a-1]===d&&u[r]===u[s]&&u[++r]===u[s+1]){s+=2,r++;do{}while(u[++s]===u[++r]&&u[++s]===u[++r]&&u[++s]===u[++r]&&u[++s]===u[++r]&&u[++s]===u[++r]&&u[++s]===u[++r]&&u[++s]===u[++r]&&u[++s]===u[++r]&&sh&&0!=--i);return a<=e.lookahead?a:e.lookahead}function j(e){var t,r,n,i,s,a,o,h,u,l,f=e.w_size;do{if(i=e.window_size-e.lookahead-e.strstart,e.strstart>=f+(f-z)){for(c.arraySet(e.window,e.window,f,f,0),e.match_start-=f,e.strstart-=f,e.block_start-=f,t=r=e.hash_size;n=e.head[--t],e.head[t]=f<=n?n-f:0,--r;);for(t=r=f;n=e.prev[--t],e.prev[t]=f<=n?n-f:0,--r;);i+=f}if(0===e.strm.avail_in)break;if(a=e.strm,o=e.window,h=e.strstart+e.lookahead,u=i,l=void 0,l=a.avail_in,u=x)for(s=e.strstart-e.insert,e.ins_h=e.window[s],e.ins_h=(e.ins_h<=x&&(e.ins_h=(e.ins_h<=x)if(n=u._tr_tally(e,e.strstart-e.match_start,e.match_length-x),e.lookahead-=e.match_length,e.match_length<=e.max_lazy_match&&e.lookahead>=x){for(e.match_length--;e.strstart++,e.ins_h=(e.ins_h<=x&&(e.ins_h=(e.ins_h<=x&&e.match_length<=e.prev_length){for(i=e.strstart+e.lookahead-x,n=u._tr_tally(e,e.strstart-1-e.prev_match,e.prev_length-x),e.lookahead-=e.prev_length-1,e.prev_length-=2;++e.strstart<=i&&(e.ins_h=(e.ins_h<e.pending_buf_size-5&&(r=e.pending_buf_size-5);;){if(e.lookahead<=1){if(j(e),0===e.lookahead&&t===l)return A;if(0===e.lookahead)break}e.strstart+=e.lookahead,e.lookahead=0;var n=e.block_start+r;if((0===e.strstart||e.strstart>=n)&&(e.lookahead=e.strstart-n,e.strstart=n,N(e,!1),0===e.strm.avail_out))return A;if(e.strstart-e.block_start>=e.w_size-z&&(N(e,!1),0===e.strm.avail_out))return A}return e.insert=0,t===f?(N(e,!0),0===e.strm.avail_out?O:B):(e.strstart>e.block_start&&(N(e,!1),e.strm.avail_out),A)}),new M(4,4,8,4,Z),new M(4,5,16,8,Z),new M(4,6,32,32,Z),new M(4,4,16,16,W),new M(8,16,32,32,W),new M(8,16,128,128,W),new M(8,32,128,256,W),new M(32,128,258,1024,W),new M(32,258,258,4096,W)],r.deflateInit=function(e,t){return Y(e,t,v,15,8,0)},r.deflateInit2=Y,r.deflateReset=K,r.deflateResetKeep=G,r.deflateSetHeader=function(e,t){return e&&e.state?2!==e.state.wrap?_:(e.state.gzhead=t,m):_},r.deflate=function(e,t){var r,n,i,s;if(!e||!e.state||5>8&255),U(n,n.gzhead.time>>16&255),U(n,n.gzhead.time>>24&255),U(n,9===n.level?2:2<=n.strategy||n.level<2?4:0),U(n,255&n.gzhead.os),n.gzhead.extra&&n.gzhead.extra.length&&(U(n,255&n.gzhead.extra.length),U(n,n.gzhead.extra.length>>8&255)),n.gzhead.hcrc&&(e.adler=p(e.adler,n.pending_buf,n.pending,0)),n.gzindex=0,n.status=69):(U(n,0),U(n,0),U(n,0),U(n,0),U(n,0),U(n,9===n.level?2:2<=n.strategy||n.level<2?4:0),U(n,3),n.status=E);else{var a=v+(n.w_bits-8<<4)<<8;a|=(2<=n.strategy||n.level<2?0:n.level<6?1:6===n.level?2:3)<<6,0!==n.strstart&&(a|=32),a+=31-a%31,n.status=E,P(n,a),0!==n.strstart&&(P(n,e.adler>>>16),P(n,65535&e.adler)),e.adler=1}if(69===n.status)if(n.gzhead.extra){for(i=n.pending;n.gzindex<(65535&n.gzhead.extra.length)&&(n.pending!==n.pending_buf_size||(n.gzhead.hcrc&&n.pending>i&&(e.adler=p(e.adler,n.pending_buf,n.pending-i,i)),F(e),i=n.pending,n.pending!==n.pending_buf_size));)U(n,255&n.gzhead.extra[n.gzindex]),n.gzindex++;n.gzhead.hcrc&&n.pending>i&&(e.adler=p(e.adler,n.pending_buf,n.pending-i,i)),n.gzindex===n.gzhead.extra.length&&(n.gzindex=0,n.status=73)}else n.status=73;if(73===n.status)if(n.gzhead.name){i=n.pending;do{if(n.pending===n.pending_buf_size&&(n.gzhead.hcrc&&n.pending>i&&(e.adler=p(e.adler,n.pending_buf,n.pending-i,i)),F(e),i=n.pending,n.pending===n.pending_buf_size)){s=1;break}s=n.gzindexi&&(e.adler=p(e.adler,n.pending_buf,n.pending-i,i)),0===s&&(n.gzindex=0,n.status=91)}else n.status=91;if(91===n.status)if(n.gzhead.comment){i=n.pending;do{if(n.pending===n.pending_buf_size&&(n.gzhead.hcrc&&n.pending>i&&(e.adler=p(e.adler,n.pending_buf,n.pending-i,i)),F(e),i=n.pending,n.pending===n.pending_buf_size)){s=1;break}s=n.gzindexi&&(e.adler=p(e.adler,n.pending_buf,n.pending-i,i)),0===s&&(n.status=103)}else n.status=103;if(103===n.status&&(n.gzhead.hcrc?(n.pending+2>n.pending_buf_size&&F(e),n.pending+2<=n.pending_buf_size&&(U(n,255&e.adler),U(n,e.adler>>8&255),e.adler=0,n.status=E)):n.status=E),0!==n.pending){if(F(e),0===e.avail_out)return n.last_flush=-1,m}else if(0===e.avail_in&&T(t)<=T(r)&&t!==f)return R(e,-5);if(666===n.status&&0!==e.avail_in)return R(e,-5);if(0!==e.avail_in||0!==n.lookahead||t!==l&&666!==n.status){var o=2===n.strategy?function(e,t){for(var r;;){if(0===e.lookahead&&(j(e),0===e.lookahead)){if(t===l)return A;break}if(e.match_length=0,r=u._tr_tally(e,0,e.window[e.strstart]),e.lookahead--,e.strstart++,r&&(N(e,!1),0===e.strm.avail_out))return A}return e.insert=0,t===f?(N(e,!0),0===e.strm.avail_out?O:B):e.last_lit&&(N(e,!1),0===e.strm.avail_out)?A:I}(n,t):3===n.strategy?function(e,t){for(var r,n,i,s,a=e.window;;){if(e.lookahead<=S){if(j(e),e.lookahead<=S&&t===l)return A;if(0===e.lookahead)break}if(e.match_length=0,e.lookahead>=x&&0e.lookahead&&(e.match_length=e.lookahead)}if(e.match_length>=x?(r=u._tr_tally(e,1,e.match_length-x),e.lookahead-=e.match_length,e.strstart+=e.match_length,e.match_length=0):(r=u._tr_tally(e,0,e.window[e.strstart]),e.lookahead--,e.strstart++),r&&(N(e,!1),0===e.strm.avail_out))return A}return e.insert=0,t===f?(N(e,!0),0===e.strm.avail_out?O:B):e.last_lit&&(N(e,!1),0===e.strm.avail_out)?A:I}(n,t):h[n.level].func(n,t);if(o!==O&&o!==B||(n.status=666),o===A||o===O)return 0===e.avail_out&&(n.last_flush=-1),m;if(o===I&&(1===t?u._tr_align(n):5!==t&&(u._tr_stored_block(n,0,0,!1),3===t&&(D(n.head),0===n.lookahead&&(n.strstart=0,n.block_start=0,n.insert=0))),F(e),0===e.avail_out))return n.last_flush=-1,m}return t!==f?m:n.wrap<=0?1:(2===n.wrap?(U(n,255&e.adler),U(n,e.adler>>8&255),U(n,e.adler>>16&255),U(n,e.adler>>24&255),U(n,255&e.total_in),U(n,e.total_in>>8&255),U(n,e.total_in>>16&255),U(n,e.total_in>>24&255)):(P(n,e.adler>>>16),P(n,65535&e.adler)),F(e),0=r.w_size&&(0===s&&(D(r.head),r.strstart=0,r.block_start=0,r.insert=0),u=new c.Buf8(r.w_size),c.arraySet(u,t,l-r.w_size,r.w_size,0),t=u,l=r.w_size),a=e.avail_in,o=e.next_in,h=e.input,e.avail_in=l,e.next_in=0,e.input=t,j(r);r.lookahead>=x;){for(n=r.strstart,i=r.lookahead-(x-1);r.ins_h=(r.ins_h<>>=y=v>>>24,p-=y,0===(y=v>>>16&255))C[s++]=65535&v;else{if(!(16&y)){if(0==(64&y)){v=m[(65535&v)+(d&(1<>>=y,p-=y),p<15&&(d+=z[n++]<>>=y=v>>>24,p-=y,!(16&(y=v>>>16&255))){if(0==(64&y)){v=_[(65535&v)+(d&(1<>>=y,p-=y,(y=s-a)>3,d&=(1<<(p-=w<<3))-1,e.next_in=n,e.next_out=s,e.avail_in=n>>24&255)+(e>>>8&65280)+((65280&e)<<8)+((255&e)<<24)}function s(){this.mode=0,this.last=!1,this.wrap=0,this.havedict=!1,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 I.Buf16(320),this.work=new I.Buf16(288),this.lendyn=null,this.distdyn=null,this.sane=0,this.back=0,this.was=0}function a(e){var t;return e&&e.state?(t=e.state,e.total_in=e.total_out=t.total=0,e.msg=\"\",t.wrap&&(e.adler=1&t.wrap),t.mode=P,t.last=0,t.havedict=0,t.dmax=32768,t.head=null,t.hold=0,t.bits=0,t.lencode=t.lendyn=new I.Buf32(n),t.distcode=t.distdyn=new I.Buf32(i),t.sane=1,t.back=-1,N):U}function o(e){var t;return e&&e.state?((t=e.state).wsize=0,t.whave=0,t.wnext=0,a(e)):U}function h(e,t){var r,n;return e&&e.state?(n=e.state,t<0?(r=0,t=-t):(r=1+(t>>4),t<48&&(t&=15)),t&&(t<8||15=s.wsize?(I.arraySet(s.window,t,r-s.wsize,s.wsize,0),s.wnext=0,s.whave=s.wsize):(n<(i=s.wsize-s.wnext)&&(i=n),I.arraySet(s.window,t,r-n,i,s.wnext),(n-=i)?(I.arraySet(s.window,t,r-n,n,0),s.wnext=n,s.whave=s.wsize):(s.wnext+=i,s.wnext===s.wsize&&(s.wnext=0),s.whave>>8&255,r.check=B(r.check,E,2,0),l=u=0,r.mode=2;break}if(r.flags=0,r.head&&(r.head.done=!1),!(1&r.wrap)||(((255&u)<<8)+(u>>8))%31){e.msg=\"incorrect header check\",r.mode=30;break}if(8!=(15&u)){e.msg=\"unknown compression method\",r.mode=30;break}if(l-=4,k=8+(15&(u>>>=4)),0===r.wbits)r.wbits=k;else if(k>r.wbits){e.msg=\"invalid window size\",r.mode=30;break}r.dmax=1<>8&1),512&r.flags&&(E[0]=255&u,E[1]=u>>>8&255,r.check=B(r.check,E,2,0)),l=u=0,r.mode=3;case 3:for(;l<32;){if(0===o)break e;o--,u+=n[s++]<>>8&255,E[2]=u>>>16&255,E[3]=u>>>24&255,r.check=B(r.check,E,4,0)),l=u=0,r.mode=4;case 4:for(;l<16;){if(0===o)break e;o--,u+=n[s++]<>8),512&r.flags&&(E[0]=255&u,E[1]=u>>>8&255,r.check=B(r.check,E,2,0)),l=u=0,r.mode=5;case 5:if(1024&r.flags){for(;l<16;){if(0===o)break e;o--,u+=n[s++]<>>8&255,r.check=B(r.check,E,2,0)),l=u=0}else r.head&&(r.head.extra=null);r.mode=6;case 6:if(1024&r.flags&&(o<(d=r.length)&&(d=o),d&&(r.head&&(k=r.head.extra_len-r.length,r.head.extra||(r.head.extra=new Array(r.head.extra_len)),I.arraySet(r.head.extra,n,s,d,k)),512&r.flags&&(r.check=B(r.check,n,d,s)),o-=d,s+=d,r.length-=d),r.length))break e;r.length=0,r.mode=7;case 7:if(2048&r.flags){if(0===o)break e;for(d=0;k=n[s+d++],r.head&&k&&r.length<65536&&(r.head.name+=String.fromCharCode(k)),k&&d>9&1,r.head.done=!0),e.adler=r.check=0,r.mode=12;break;case 10:for(;l<32;){if(0===o)break e;o--,u+=n[s++]<>>=7&l,l-=7&l,r.mode=27;break}for(;l<3;){if(0===o)break e;o--,u+=n[s++]<>>=1)){case 0:r.mode=14;break;case 1:if(j(r),r.mode=20,6!==t)break;u>>>=2,l-=2;break e;case 2:r.mode=17;break;case 3:e.msg=\"invalid block type\",r.mode=30}u>>>=2,l-=2;break;case 14:for(u>>>=7&l,l-=7&l;l<32;){if(0===o)break e;o--,u+=n[s++]<>>16^65535)){e.msg=\"invalid stored block lengths\",r.mode=30;break}if(r.length=65535&u,l=u=0,r.mode=15,6===t)break e;case 15:r.mode=16;case 16:if(d=r.length){if(o>>=5,l-=5,r.ndist=1+(31&u),u>>>=5,l-=5,r.ncode=4+(15&u),u>>>=4,l-=4,286>>=3,l-=3}for(;r.have<19;)r.lens[A[r.have++]]=0;if(r.lencode=r.lendyn,r.lenbits=7,S={bits:r.lenbits},x=T(0,r.lens,0,19,r.lencode,0,r.work,S),r.lenbits=S.bits,x){e.msg=\"invalid code lengths set\",r.mode=30;break}r.have=0,r.mode=19;case 19:for(;r.have>>16&255,b=65535&C,!((_=C>>>24)<=l);){if(0===o)break e;o--,u+=n[s++]<>>=_,l-=_,r.lens[r.have++]=b;else{if(16===b){for(z=_+2;l>>=_,l-=_,0===r.have){e.msg=\"invalid bit length repeat\",r.mode=30;break}k=r.lens[r.have-1],d=3+(3&u),u>>>=2,l-=2}else if(17===b){for(z=_+3;l>>=_)),u>>>=3,l-=3}else{for(z=_+7;l>>=_)),u>>>=7,l-=7}if(r.have+d>r.nlen+r.ndist){e.msg=\"invalid bit length repeat\",r.mode=30;break}for(;d--;)r.lens[r.have++]=k}}if(30===r.mode)break;if(0===r.lens[256]){e.msg=\"invalid code -- missing end-of-block\",r.mode=30;break}if(r.lenbits=9,S={bits:r.lenbits},x=T(D,r.lens,0,r.nlen,r.lencode,0,r.work,S),r.lenbits=S.bits,x){e.msg=\"invalid literal/lengths set\",r.mode=30;break}if(r.distbits=6,r.distcode=r.distdyn,S={bits:r.distbits},x=T(F,r.lens,r.nlen,r.ndist,r.distcode,0,r.work,S),r.distbits=S.bits,x){e.msg=\"invalid distances set\",r.mode=30;break}if(r.mode=20,6===t)break e;case 20:r.mode=21;case 21:if(6<=o&&258<=h){e.next_out=a,e.avail_out=h,e.next_in=s,e.avail_in=o,r.hold=u,r.bits=l,R(e,c),a=e.next_out,i=e.output,h=e.avail_out,s=e.next_in,n=e.input,o=e.avail_in,u=r.hold,l=r.bits,12===r.mode&&(r.back=-1);break}for(r.back=0;g=(C=r.lencode[u&(1<>>16&255,b=65535&C,!((_=C>>>24)<=l);){if(0===o)break e;o--,u+=n[s++]<>v)])>>>16&255,b=65535&C,!(v+(_=C>>>24)<=l);){if(0===o)break e;o--,u+=n[s++]<>>=v,l-=v,r.back+=v}if(u>>>=_,l-=_,r.back+=_,r.length=b,0===g){r.mode=26;break}if(32&g){r.back=-1,r.mode=12;break}if(64&g){e.msg=\"invalid literal/length code\",r.mode=30;break}r.extra=15&g,r.mode=22;case 22:if(r.extra){for(z=r.extra;l>>=r.extra,l-=r.extra,r.back+=r.extra}r.was=r.length,r.mode=23;case 23:for(;g=(C=r.distcode[u&(1<>>16&255,b=65535&C,!((_=C>>>24)<=l);){if(0===o)break e;o--,u+=n[s++]<>v)])>>>16&255,b=65535&C,!(v+(_=C>>>24)<=l);){if(0===o)break e;o--,u+=n[s++]<>>=v,l-=v,r.back+=v}if(u>>>=_,l-=_,r.back+=_,64&g){e.msg=\"invalid distance code\",r.mode=30;break}r.offset=b,r.extra=15&g,r.mode=24;case 24:if(r.extra){for(z=r.extra;l>>=r.extra,l-=r.extra,r.back+=r.extra}if(r.offset>r.dmax){e.msg=\"invalid distance too far back\",r.mode=30;break}r.mode=25;case 25:if(0===h)break e;if(d=c-h,r.offset>d){if((d=r.offset-d)>r.whave&&r.sane){e.msg=\"invalid distance too far back\",r.mode=30;break}p=d>r.wnext?(d-=r.wnext,r.wsize-d):r.wnext-d,d>r.length&&(d=r.length),m=r.window}else m=i,p=a-r.offset,d=r.length;for(hd?(m=R[T+a[v]],A[I+a[v]]):(m=96,0),h=1<>S)+(u-=h)]=p<<24|m<<16|_|0,0!==u;);for(h=1<>=1;if(0!==h?(E&=h-1,E+=h):E=0,v++,0==--O[b]){if(b===w)break;b=t[r+a[v]]}if(k>>7)]}function U(e,t){e.pending_buf[e.pending++]=255&t,e.pending_buf[e.pending++]=t>>>8&255}function P(e,t,r){e.bi_valid>d-r?(e.bi_buf|=t<>d-e.bi_valid,e.bi_valid+=r-d):(e.bi_buf|=t<>>=1,r<<=1,0<--t;);return r>>>1}function Z(e,t,r){var n,i,s=new Array(g+1),a=0;for(n=1;n<=g;n++)s[n]=a=a+r[n-1]<<1;for(i=0;i<=t;i++){var o=e[2*i+1];0!==o&&(e[2*i]=j(s[o]++,o))}}function W(e){var t;for(t=0;t>1;1<=r;r--)G(e,s,r);for(i=h;r=e.heap[1],e.heap[1]=e.heap[e.heap_len--],G(e,s,1),n=e.heap[1],e.heap[--e.heap_max]=r,e.heap[--e.heap_max]=n,s[2*i]=s[2*r]+s[2*n],e.depth[i]=(e.depth[r]>=e.depth[n]?e.depth[r]:e.depth[n])+1,s[2*r+1]=s[2*n+1]=i,e.heap[1]=i++,G(e,s,1),2<=e.heap_len;);e.heap[--e.heap_max]=e.heap[1],function(e,t){var r,n,i,s,a,o,h=t.dyn_tree,u=t.max_code,l=t.stat_desc.static_tree,f=t.stat_desc.has_stree,c=t.stat_desc.extra_bits,d=t.stat_desc.extra_base,p=t.stat_desc.max_length,m=0;for(s=0;s<=g;s++)e.bl_count[s]=0;for(h[2*e.heap[e.heap_max]+1]=0,r=e.heap_max+1;r<_;r++)p<(s=h[2*h[2*(n=e.heap[r])+1]+1]+1)&&(s=p,m++),h[2*n+1]=s,u>=7;n>>=1)if(1&r&&0!==e.dyn_ltree[2*t])return o;if(0!==e.dyn_ltree[18]||0!==e.dyn_ltree[20]||0!==e.dyn_ltree[26])return h;for(t=32;t>>3,(s=e.static_len+3+7>>>3)<=i&&(i=s)):i=s=r+5,r+4<=i&&-1!==t?J(e,t,r,n):4===e.strategy||s===i?(P(e,2+(n?1:0),3),K(e,z,C)):(P(e,4+(n?1:0),3),function(e,t,r,n){var i;for(P(e,t-257,5),P(e,r-1,5),P(e,n-4,4),i=0;i>>8&255,e.pending_buf[e.d_buf+2*e.last_lit+1]=255&t,e.pending_buf[e.l_buf+e.last_lit]=255&r,e.last_lit++,0===t?e.dyn_ltree[2*r]++:(e.matches++,t--,e.dyn_ltree[2*(A[r]+u+1)]++,e.dyn_dtree[2*N(t)]++),e.last_lit===e.lit_bufsize-1},r._tr_align=function(e){P(e,2,3),L(e,m,z),function(e){16===e.bi_valid?(U(e,e.bi_buf),e.bi_buf=0,e.bi_valid=0):8<=e.bi_valid&&(e.pending_buf[e.pending++]=255&e.bi_buf,e.bi_buf>>=8,e.bi_valid-=8)}(e)}},{\"../utils/common\":41}],53:[function(e,t,r){\"use strict\";t.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(e,t,r){(function(e){!function(r,n){\"use strict\";if(!r.setImmediate){var i,s,t,a,o=1,h={},u=!1,l=r.document,e=Object.getPrototypeOf&&Object.getPrototypeOf(r);e=e&&e.setTimeout?e:r,i=\"[object process]\"==={}.toString.call(r.process)?function(e){process.nextTick(function(){c(e)})}:function(){if(r.postMessage&&!r.importScripts){var e=!0,t=r.onmessage;return r.onmessage=function(){e=!1},r.postMessage(\"\",\"*\"),r.onmessage=t,e}}()?(a=\"setImmediate$\"+Math.random()+\"$\",r.addEventListener?r.addEventListener(\"message\",d,!1):r.attachEvent(\"onmessage\",d),function(e){r.postMessage(a+e,\"*\")}):r.MessageChannel?((t=new MessageChannel).port1.onmessage=function(e){c(e.data)},function(e){t.port2.postMessage(e)}):l&&\"onreadystatechange\"in l.createElement(\"script\")?(s=l.documentElement,function(e){var t=l.createElement(\"script\");t.onreadystatechange=function(){c(e),t.onreadystatechange=null,s.removeChild(t),t=null},s.appendChild(t)}):function(e){setTimeout(c,0,e)},e.setImmediate=function(e){\"function\"!=typeof e&&(e=new Function(\"\"+e));for(var t=new Array(arguments.length-1),r=0;r[(0,i.bF)(f,{icon:"home"})]),_:1},8,["onClick"])]),(0,i.Lk)("div",c,[(0,i.Lk)("div",d,[(0,i.bF)(f,{icon:"shield-alt",class:"shield-icon"}),(0,i.Lk)("div",u,[(0,i.bF)(f,{icon:"clock",class:"clock-icon"})])])]),(0,i.Lk)("div",g,[t[7]||(t[7]=(0,i.Lk)("h1",{class:"status-title"},"白名单模式已启用",-1)),t[8]||(t[8]=(0,i.Lk)("p",{class:"status-description"}," 抱歉,当前已开启白名单模式,上传的图片需要审核通过后才能展示,请等待审核通过后再进行访问。 ",-1)),t[9]||(t[9]=(0,i.Lk)("p",{class:"status-description-en"}," Sorry, the whitelist mode is currently enabled, the uploaded images need to be audited before they can be displayed, please wait for the audit to be passed before visiting. ",-1)),(0,i.Lk)("div",h,[(0,i.bF)(v,{type:"primary",size:"large",class:"action-btn primary-btn",onClick:y.goHome},{default:(0,i.k6)(()=>[(0,i.bF)(f,{icon:"home",class:"btn-icon"}),t[2]||(t[2]=(0,i.eW)(" 返回首页 ",-1))]),_:1},8,["onClick"]),(0,i.bF)(v,{size:"large",class:"action-btn secondary-btn",onClick:y.goBack},{default:(0,i.k6)(()=>[(0,i.bF)(f,{icon:"arrow-left",class:"btn-icon"}),t[3]||(t[3]=(0,i.eW)(" 返回上页 ",-1))]),_:1},8,["onClick"])]),(0,i.Lk)("div",p,[t[6]||(t[6]=(0,i.Lk)("p",{class:"help-text"},"您可以尝试:",-1)),(0,i.Lk)("div",m,[(0,i.Lk)("a",{href:"javascript:void(0)",onClick:t[0]||(t[0]=(...e)=>y.goHome&&y.goHome(...e)),class:"quick-link"},[(0,i.bF)(f,{icon:"cloud-upload-alt"}),t[4]||(t[4]=(0,i.eW)(" 图片上传 ",-1))]),(0,i.Lk)("a",{href:"javascript:void(0)",onClick:t[1]||(t[1]=(...e)=>y.refreshPage&&y.refreshPage(...e)),class:"quick-link"},[(0,i.bF)(f,{icon:"redo"}),t[5]||(t[5]=(0,i.eW)(" 刷新页面 ",-1))])])]),t[10]||(t[10]=(0,i.Lk)("div",{class:"powered-by"},[(0,i.Lk)("p",null,[(0,i.eW)("Powered By: "),(0,i.Lk)("a",{href:"https://github.com/MarSeventh/CloudFlare-ImgBed",class:"project-link"}," CloudFlare-ImgBed ")])],-1))])]),t[11]||(t[11]=(0,i.Fv)('
',1))])}a(4114);var b=a(4354),y=a(8401),f=a(8903),v={name:"WhiteListOn",mixins:[f.A],computed:{...(0,y.L8)(["useDarkMode","userConfig"])},setup(){(0,b.u)({title:"White List On",meta:[{name:"robots",content:"noindex, nofollow"},{name:"viewport",content:"width=device-width, initial-scale=1"},{charset:"UTF-8"}]})},mounted(){this.initializeBackground("uploadBkImg",".whitelist-container",!1,!0)},beforeUnmount(){this.clearBackgroundInterval()},methods:{goHome(){this.$router.push("/")},goBack(){window.history.length>1?this.$router.go(-1):this.$router.push("/")},refreshPage(){window.location.reload()}}},I=a(1241);const B=(0,I.A)(v,[["render",k],["__scopeId","data-v-ca56fa40"]]);var W=B},7835:function(e,t,a){e.exports=a.p+"img/background-light.f17603bc.jpg"},8351:function(e,t,a){e.exports=a.p+"img/background.ea1b7ee7.jpg"},8903:function(e,t,a){var n=a(8401);t.A={data(){return{bingWallPaperIndex:0,customWallPaperIndex:0,backgroundInterval:null,backgroundInitParams:null}},computed:{...(0,n.L8)(["userConfig","bingWallPapers","useDarkMode"]),bkInterval(){return this.userConfig?.bkInterval||3e3},bkOpacity(){return this.userConfig?.bkOpacity||1},backgroundImagesTemplate(){return'\n Background Image\n Background Image\n '},backgroundImagesStyles(){return"\n .background-image1 {\n position: fixed;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n object-fit: cover;\n z-index: -1;\n opacity: 0;\n transition: opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1), filter 0.3s ease;\n filter: var(--background-image-filter, brightness(1));\n }\n .background-image2 {\n position: fixed;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n object-fit: cover;\n z-index: -1;\n opacity: 0;\n transition: opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1), filter 0.3s ease;\n filter: var(--background-image-filter, brightness(1));\n }\n "}},watch:{useDarkMode(e,t){e!==t&&this.backgroundInitParams&&this.$nextTick(()=>{this.smoothThemeTransition(this.backgroundInitParams.configKey,this.backgroundInitParams.containerSelector,this.backgroundInitParams.useDefaultBackground,this.backgroundInitParams.autoCreateElements)})}},mounted(){this.injectBackgroundStyles()},beforeUnmount(){this.backgroundInterval&&clearInterval(this.backgroundInterval),this.clearBackgroundImages(!0),this.removeBackgroundStyles()},methods:{injectBackgroundStyles(){const e="background-manager-styles";if(!document.getElementById(e)){const t=document.createElement("style");t.id=e,t.textContent=this.backgroundImagesStyles,document.head.appendChild(t)}},removeBackgroundStyles(){const e="background-manager-styles",t=document.getElementById(e);t&&t.remove()},createBackgroundElements(e){if(!e)return void console.warn("未提供有效的容器元素");if(document.getElementById("bg1")||document.getElementById("bg2"))return;const t=document.createElement("img");t.id="bg1",t.className="background-image1",t.alt="Background Image";const a=document.createElement("img");a.id="bg2",a.className="background-image2",a.alt="Background Image",e.insertBefore(t,e.firstChild),e.insertBefore(a,e.firstChild)},initializeBackground(e,t=".login",a=!1,n=!1){if(this.backgroundInitParams={configKey:e,containerSelector:t,useDefaultBackground:a,autoCreateElements:n},n){const e=document.querySelector(t);!e||document.getElementById("bg1")&&document.getElementById("bg2")||this.createBackgroundElements(e)}const i=document.getElementById("bg1"),s=document.getElementById("bg2");if(!i||!s)return void console.warn("背景图元素 #bg1 或 #bg2 未找到,请确保页面中包含这些元素或启用 autoCreateElements");const o=this.userConfig?.[e];"bing"===o?this.setupBingWallpaper(i,s,t):Array.isArray(o)&&o.length>1?this.setupCustomWallpaperCarousel(i,s,o,t):Array.isArray(o)&&1===o.length?this.setupSingleCustomWallpaper(i,o[0],t):a&&this.setupDefaultWallpaper(i,t)},setupBingWallpaper(e,t,a){this.$store.dispatch("fetchBingWallPapers").then(()=>{0!==this.bingWallPapers.length&&(this.loadBackgroundImage(e,this.bingWallPapers[this.bingWallPaperIndex]?.url,a),this.backgroundInterval=setInterval(()=>{this.switchBingWallpaper(e,t)},this.bkInterval))})},setupCustomWallpaperCarousel(e,t,a,n){this.loadBackgroundImage(e,a[this.customWallPaperIndex],n),this.backgroundInterval=setInterval(()=>{this.switchCustomWallpaper(e,t,a)},this.bkInterval)},setupSingleCustomWallpaper(e,t,a){this.loadBackgroundImage(e,t,a)},setupDefaultWallpaper(e,t){const n=this.useDarkMode,i=a(n?8351:7835);this.loadBackgroundImage(e,i,t)},loadBackgroundImage(e,t,a){e.src=t,e.onload=()=>{e.style.opacity=this.bkOpacity;const t=document.querySelector(a);t&&(t.style.background="transparent")}},switchBingWallpaper(e,t){if(0===this.bingWallPapers.length)return;const a=0!=e.style.opacity?e:t,n=0!=e.style.opacity?t:e;a.style.opacity=0,this.bingWallPaperIndex=(this.bingWallPaperIndex+1)%this.bingWallPapers.length,n.src=this.bingWallPapers[this.bingWallPaperIndex]?.url,n.onload=()=>{n.style.opacity=this.bkOpacity}},switchCustomWallpaper(e,t,a){const n=0!=e.style.opacity?e:t,i=0!=e.style.opacity?t:e;n.style.opacity=0,this.customWallPaperIndex=(this.customWallPaperIndex+1)%a.length,i.src=a[this.customWallPaperIndex],i.onload=()=>{i.style.opacity=this.bkOpacity}},clearBackgroundInterval(){this.backgroundInterval&&(clearInterval(this.backgroundInterval),this.backgroundInterval=null)},clearBackgroundImages(e=!1){const t=document.getElementById("bg1"),a=document.getElementById("bg2");e?(t&&(t.style.transition="none",t.style.opacity=0,t.src="",setTimeout(()=>{t&&(t.style.transition="opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1)")},50)),a&&(a.style.transition="none",a.style.opacity=0,a.src="",setTimeout(()=>{a&&(a.style.transition="opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1)")},50))):(t&&(t.style.opacity=0,setTimeout(()=>{t&&(t.src="")},800)),a&&(a.style.opacity=0,setTimeout(()=>{a&&(a.src="")},800)))},smoothThemeTransition(e,t=".login",n=!1,i=!1){const s=this.userConfig?.[e];if(!n||void 0!==s)return void this.reinitializeBackground(e,t,n,i);const o=document.getElementById("bg1"),r=document.getElementById("bg2");if(!o||!r)return void this.reinitializeBackground(e,t,n,i);const l=0!=o.style.opacity?o:r,c=0!=o.style.opacity?r:o,d=this.useDarkMode,u=a(d?8351:7835),g=new Image;g.onload=()=>{c.src=u,c.onload=()=>{l.style.opacity=0,setTimeout(()=>{c.style.opacity=this.bkOpacity;const e=document.querySelector(t);e&&(e.style.background="transparent")},50)}},g.onerror=()=>{console.warn("主题背景图预加载失败,回退到直接切换"),this.reinitializeBackground(e,t,n,i)},g.src=u},reinitializeBackground(e,t=".login",a=!1,n=!1){this.clearBackgroundInterval(),this.clearBackgroundImages(!0),this.bingWallPaperIndex=0,this.customWallPaperIndex=0,setTimeout(()=>{this.initializeBackground(e,t,a,n)},100)}}}}}]); -//# sourceMappingURL=988.c78ed6a8.js.map \ No newline at end of file +"use strict";(self["webpackChunksanyue_imghub"]=self["webpackChunksanyue_imghub"]||[]).push([[845],{7226:function(e,t,a){a.r(t),a.d(t,{default:function(){return W}});var n=a(47),i=(a(5331),a(9648),a(6768));const s={class:"whitelist-container"},o=["innerHTML"],r={class:"whitelist-content"},l={class:"back-button-wrapper"},c={class:"status-animation"},d={class:"status-icon"},u={class:"status-badge"},g={class:"status-info"},h={class:"status-actions"},p={class:"help-info"},m={class:"quick-links"};function k(e,t,a,k,b,y){const f=(0,i.g2)("font-awesome-icon"),v=n.S2;return(0,i.uX)(),(0,i.CE)("div",s,[(0,i.Lk)("div",{class:"background-wrapper",innerHTML:e.backgroundImagesTemplate},null,8,o),(0,i.Lk)("div",r,[(0,i.Lk)("div",l,[(0,i.bF)(v,{class:"back-button",onClick:y.goHome,circle:"",size:"large"},{default:(0,i.k6)(()=>[(0,i.bF)(f,{icon:"home"})]),_:1},8,["onClick"])]),(0,i.Lk)("div",c,[(0,i.Lk)("div",d,[(0,i.bF)(f,{icon:"shield-alt",class:"shield-icon"}),(0,i.Lk)("div",u,[(0,i.bF)(f,{icon:"clock",class:"clock-icon"})])])]),(0,i.Lk)("div",g,[t[7]||(t[7]=(0,i.Lk)("h1",{class:"status-title"},"白名单模式已启用",-1)),t[8]||(t[8]=(0,i.Lk)("p",{class:"status-description"}," 抱歉,当前已开启白名单模式,上传的图片需要审核通过后才能展示,请等待审核通过后再进行访问。 ",-1)),t[9]||(t[9]=(0,i.Lk)("p",{class:"status-description-en"}," Sorry, the whitelist mode is currently enabled, the uploaded images need to be audited before they can be displayed, please wait for the audit to be passed before visiting. ",-1)),(0,i.Lk)("div",h,[(0,i.bF)(v,{type:"primary",size:"large",class:"action-btn primary-btn",onClick:y.goHome},{default:(0,i.k6)(()=>[(0,i.bF)(f,{icon:"home",class:"btn-icon"}),t[2]||(t[2]=(0,i.eW)(" 返回首页 ",-1))]),_:1},8,["onClick"]),(0,i.bF)(v,{size:"large",class:"action-btn secondary-btn",onClick:y.goBack},{default:(0,i.k6)(()=>[(0,i.bF)(f,{icon:"arrow-left",class:"btn-icon"}),t[3]||(t[3]=(0,i.eW)(" 返回上页 ",-1))]),_:1},8,["onClick"])]),(0,i.Lk)("div",p,[t[6]||(t[6]=(0,i.Lk)("p",{class:"help-text"},"您可以尝试:",-1)),(0,i.Lk)("div",m,[(0,i.Lk)("a",{href:"javascript:void(0)",onClick:t[0]||(t[0]=(...e)=>y.goHome&&y.goHome(...e)),class:"quick-link"},[(0,i.bF)(f,{icon:"cloud-upload-alt"}),t[4]||(t[4]=(0,i.eW)(" 图片上传 ",-1))]),(0,i.Lk)("a",{href:"javascript:void(0)",onClick:t[1]||(t[1]=(...e)=>y.refreshPage&&y.refreshPage(...e)),class:"quick-link"},[(0,i.bF)(f,{icon:"redo"}),t[5]||(t[5]=(0,i.eW)(" 刷新页面 ",-1))])])]),t[10]||(t[10]=(0,i.Lk)("div",{class:"powered-by"},[(0,i.Lk)("p",null,[(0,i.eW)("Powered By: "),(0,i.Lk)("a",{href:"https://github.com/MarSeventh/CloudFlare-ImgBed",class:"project-link"}," CloudFlare-ImgBed ")])],-1))])]),t[11]||(t[11]=(0,i.Fv)('
',1))])}a(4114);var b=a(4354),y=a(8401),f=a(8903),v={name:"WhiteListOn",mixins:[f.A],computed:{...(0,y.L8)(["useDarkMode","userConfig"])},setup(){(0,b.u)({title:"White List On",meta:[{name:"robots",content:"noindex, nofollow"},{name:"viewport",content:"width=device-width, initial-scale=1"},{charset:"UTF-8"}]})},mounted(){this.initializeBackground("uploadBkImg",".whitelist-container",!1,!0)},beforeUnmount(){this.clearBackgroundInterval()},methods:{goHome(){this.$router.push("/")},goBack(){window.history.length>1?this.$router.go(-1):this.$router.push("/")},refreshPage(){window.location.reload()}}},I=a(1241);const B=(0,I.A)(v,[["render",k],["__scopeId","data-v-ca56fa40"]]);var W=B},7835:function(e,t,a){e.exports=a.p+"img/background-light.f17603bc.jpg"},8351:function(e,t,a){e.exports=a.p+"img/background.ea1b7ee7.jpg"},8903:function(e,t,a){var n=a(8401);t.A={data(){return{bingWallPaperIndex:0,customWallPaperIndex:0,backgroundInterval:null,backgroundInitParams:null}},computed:{...(0,n.L8)(["userConfig","bingWallPapers","useDarkMode"]),bkInterval(){return this.userConfig?.bkInterval||3e3},bkOpacity(){return this.userConfig?.bkOpacity||1},backgroundImagesTemplate(){return'\n Background Image\n Background Image\n '},backgroundImagesStyles(){return"\n .background-image1 {\n position: fixed;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n object-fit: cover;\n z-index: -1;\n opacity: 0;\n transition: opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1), filter 0.3s ease;\n filter: var(--background-image-filter, brightness(1));\n }\n .background-image2 {\n position: fixed;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n object-fit: cover;\n z-index: -1;\n opacity: 0;\n transition: opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1), filter 0.3s ease;\n filter: var(--background-image-filter, brightness(1));\n }\n "}},watch:{useDarkMode(e,t){e!==t&&this.backgroundInitParams&&this.$nextTick(()=>{this.smoothThemeTransition(this.backgroundInitParams.configKey,this.backgroundInitParams.containerSelector,this.backgroundInitParams.useDefaultBackground,this.backgroundInitParams.autoCreateElements)})}},mounted(){this.injectBackgroundStyles()},beforeUnmount(){this.backgroundInterval&&clearInterval(this.backgroundInterval),this.clearBackgroundImages(!0),this.removeBackgroundStyles()},methods:{injectBackgroundStyles(){const e="background-manager-styles";if(!document.getElementById(e)){const t=document.createElement("style");t.id=e,t.textContent=this.backgroundImagesStyles,document.head.appendChild(t)}},removeBackgroundStyles(){const e="background-manager-styles",t=document.getElementById(e);t&&t.remove()},createBackgroundElements(e){if(!e)return void console.warn("未提供有效的容器元素");if(document.getElementById("bg1")||document.getElementById("bg2"))return;const t=document.createElement("img");t.id="bg1",t.className="background-image1",t.alt="Background Image";const a=document.createElement("img");a.id="bg2",a.className="background-image2",a.alt="Background Image",e.insertBefore(t,e.firstChild),e.insertBefore(a,e.firstChild)},initializeBackground(e,t=".login",a=!1,n=!1){if(this.backgroundInitParams={configKey:e,containerSelector:t,useDefaultBackground:a,autoCreateElements:n},n){const e=document.querySelector(t);!e||document.getElementById("bg1")&&document.getElementById("bg2")||this.createBackgroundElements(e)}const i=document.getElementById("bg1"),s=document.getElementById("bg2");if(!i||!s)return void console.warn("背景图元素 #bg1 或 #bg2 未找到,请确保页面中包含这些元素或启用 autoCreateElements");const o=this.userConfig?.[e];"bing"===o?this.setupBingWallpaper(i,s,t):Array.isArray(o)&&o.length>1?this.setupCustomWallpaperCarousel(i,s,o,t):Array.isArray(o)&&1===o.length?this.setupSingleCustomWallpaper(i,o[0],t):a&&this.setupDefaultWallpaper(i,t)},setupBingWallpaper(e,t,a){this.$store.dispatch("fetchBingWallPapers").then(()=>{0!==this.bingWallPapers.length&&(this.loadBackgroundImage(e,this.bingWallPapers[this.bingWallPaperIndex]?.url,a),this.backgroundInterval=setInterval(()=>{this.switchBingWallpaper(e,t)},this.bkInterval))})},setupCustomWallpaperCarousel(e,t,a,n){this.loadBackgroundImage(e,a[this.customWallPaperIndex],n),this.backgroundInterval=setInterval(()=>{this.switchCustomWallpaper(e,t,a)},this.bkInterval)},setupSingleCustomWallpaper(e,t,a){this.loadBackgroundImage(e,t,a)},setupDefaultWallpaper(e,t){const n=this.useDarkMode,i=a(n?8351:7835);this.loadBackgroundImage(e,i,t)},loadBackgroundImage(e,t,a){e.src=t,e.onload=()=>{e.style.opacity=this.bkOpacity;const t=document.querySelector(a);t&&(t.style.background="transparent")}},switchBingWallpaper(e,t){if(0===this.bingWallPapers.length)return;const a=0!=e.style.opacity?e:t,n=0!=e.style.opacity?t:e;a.style.opacity=0,this.bingWallPaperIndex=(this.bingWallPaperIndex+1)%this.bingWallPapers.length,n.src=this.bingWallPapers[this.bingWallPaperIndex]?.url,n.onload=()=>{n.style.opacity=this.bkOpacity}},switchCustomWallpaper(e,t,a){const n=0!=e.style.opacity?e:t,i=0!=e.style.opacity?t:e;n.style.opacity=0,this.customWallPaperIndex=(this.customWallPaperIndex+1)%a.length,i.src=a[this.customWallPaperIndex],i.onload=()=>{i.style.opacity=this.bkOpacity}},clearBackgroundInterval(){this.backgroundInterval&&(clearInterval(this.backgroundInterval),this.backgroundInterval=null)},clearBackgroundImages(e=!1){const t=document.getElementById("bg1"),a=document.getElementById("bg2");e?(t&&(t.style.transition="none",t.style.opacity=0,t.src="",setTimeout(()=>{t&&(t.style.transition="opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1)")},50)),a&&(a.style.transition="none",a.style.opacity=0,a.src="",setTimeout(()=>{a&&(a.style.transition="opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1)")},50))):(t&&(t.style.opacity=0,setTimeout(()=>{t&&(t.src="")},800)),a&&(a.style.opacity=0,setTimeout(()=>{a&&(a.src="")},800)))},smoothThemeTransition(e,t=".login",n=!1,i=!1){const s=this.userConfig?.[e];if(!n||void 0!==s)return void this.reinitializeBackground(e,t,n,i);const o=document.getElementById("bg1"),r=document.getElementById("bg2");if(!o||!r)return void this.reinitializeBackground(e,t,n,i);const l=0!=o.style.opacity?o:r,c=0!=o.style.opacity?r:o,d=this.useDarkMode,u=a(d?8351:7835),g=new Image;g.onload=()=>{c.src=u,c.onload=()=>{l.style.opacity=0,setTimeout(()=>{c.style.opacity=this.bkOpacity;const e=document.querySelector(t);e&&(e.style.background="transparent")},50)}},g.onerror=()=>{console.warn("主题背景图预加载失败,回退到直接切换"),this.reinitializeBackground(e,t,n,i)},g.src=u},reinitializeBackground(e,t=".login",a=!1,n=!1){this.clearBackgroundInterval(),this.clearBackgroundImages(!0),this.bingWallPaperIndex=0,this.customWallPaperIndex=0,setTimeout(()=>{this.initializeBackground(e,t,a,n)},100)}}}}}]); +//# sourceMappingURL=845.1bb9a557.js.map \ No newline at end of file diff --git a/js/845.1bb9a557.js.gz b/js/845.1bb9a557.js.gz new file mode 100644 index 0000000..6d443a3 Binary files /dev/null and b/js/845.1bb9a557.js.gz differ diff --git a/js/988.c78ed6a8.js.map b/js/845.1bb9a557.js.map similarity index 99% rename from js/988.c78ed6a8.js.map rename to js/845.1bb9a557.js.map index 6d173dd..bb1263a 100644 --- a/js/988.c78ed6a8.js.map +++ b/js/845.1bb9a557.js.map @@ -1 +1 @@ -{"version":3,"file":"js/988.c78ed6a8.js","mappings":"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","sources":["webpack://sanyue_imghub/./src/views/WhiteListOn.vue?8ff1","webpack://sanyue_imghub/./src/views/WhiteListOn.vue","webpack://sanyue_imghub/./src/views/WhiteListOn.vue?05e5","webpack://sanyue_imghub/./src/mixins/backgroundManager.js"],"sourcesContent":["import { createElementVNode as _createElementVNode, resolveComponent as _resolveComponent, createVNode as _createVNode, withCtx as _withCtx, createTextVNode as _createTextVNode, createStaticVNode as _createStaticVNode, openBlock as _openBlock, createElementBlock as _createElementBlock } from \"vue\";\nconst _hoisted_1 = {\n class: \"whitelist-container\"\n};\nconst _hoisted_2 = [\"innerHTML\"];\nconst _hoisted_3 = {\n class: \"whitelist-content\"\n};\nconst _hoisted_4 = {\n class: \"back-button-wrapper\"\n};\nconst _hoisted_5 = {\n class: \"status-animation\"\n};\nconst _hoisted_6 = {\n class: \"status-icon\"\n};\nconst _hoisted_7 = {\n class: \"status-badge\"\n};\nconst _hoisted_8 = {\n class: \"status-info\"\n};\nconst _hoisted_9 = {\n class: \"status-actions\"\n};\nconst _hoisted_10 = {\n class: \"help-info\"\n};\nconst _hoisted_11 = {\n class: \"quick-links\"\n};\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n const _component_el_button = _resolveComponent(\"el-button\");\n return _openBlock(), _createElementBlock(\"div\", _hoisted_1, [_createElementVNode(\"div\", {\n class: \"background-wrapper\",\n innerHTML: _ctx.backgroundImagesTemplate\n }, null, 8, _hoisted_2), _createElementVNode(\"div\", _hoisted_3, [_createElementVNode(\"div\", _hoisted_4, [_createVNode(_component_el_button, {\n class: \"back-button\",\n onClick: $options.goHome,\n circle: \"\",\n size: \"large\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"home\"\n })]),\n _: 1\n }, 8, [\"onClick\"])]), _createElementVNode(\"div\", _hoisted_5, [_createElementVNode(\"div\", _hoisted_6, [_createVNode(_component_font_awesome_icon, {\n icon: \"shield-alt\",\n class: \"shield-icon\"\n }), _createElementVNode(\"div\", _hoisted_7, [_createVNode(_component_font_awesome_icon, {\n icon: \"clock\",\n class: \"clock-icon\"\n })])])]), _createElementVNode(\"div\", _hoisted_8, [_cache[7] || (_cache[7] = _createElementVNode(\"h1\", {\n class: \"status-title\"\n }, \"白名单模式已启用\", -1)), _cache[8] || (_cache[8] = _createElementVNode(\"p\", {\n class: \"status-description\"\n }, \" 抱歉,当前已开启白名单模式,上传的图片需要审核通过后才能展示,请等待审核通过后再进行访问。 \", -1)), _cache[9] || (_cache[9] = _createElementVNode(\"p\", {\n class: \"status-description-en\"\n }, \" Sorry, the whitelist mode is currently enabled, the uploaded images need to be audited before they can be displayed, please wait for the audit to be passed before visiting. \", -1)), _createElementVNode(\"div\", _hoisted_9, [_createVNode(_component_el_button, {\n type: \"primary\",\n size: \"large\",\n class: \"action-btn primary-btn\",\n onClick: $options.goHome\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"home\",\n class: \"btn-icon\"\n }), _cache[2] || (_cache[2] = _createTextVNode(\" 返回首页 \", -1))]),\n _: 1\n }, 8, [\"onClick\"]), _createVNode(_component_el_button, {\n size: \"large\",\n class: \"action-btn secondary-btn\",\n onClick: $options.goBack\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"arrow-left\",\n class: \"btn-icon\"\n }), _cache[3] || (_cache[3] = _createTextVNode(\" 返回上页 \", -1))]),\n _: 1\n }, 8, [\"onClick\"])]), _createElementVNode(\"div\", _hoisted_10, [_cache[6] || (_cache[6] = _createElementVNode(\"p\", {\n class: \"help-text\"\n }, \"您可以尝试:\", -1)), _createElementVNode(\"div\", _hoisted_11, [_createElementVNode(\"a\", {\n href: \"javascript:void(0)\",\n onClick: _cache[0] || (_cache[0] = (...args) => $options.goHome && $options.goHome(...args)),\n class: \"quick-link\"\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"cloud-upload-alt\"\n }), _cache[4] || (_cache[4] = _createTextVNode(\" 图片上传 \", -1))]), _createElementVNode(\"a\", {\n href: \"javascript:void(0)\",\n onClick: _cache[1] || (_cache[1] = (...args) => $options.refreshPage && $options.refreshPage(...args)),\n class: \"quick-link\"\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"redo\"\n }), _cache[5] || (_cache[5] = _createTextVNode(\" 刷新页面 \", -1))])])]), _cache[10] || (_cache[10] = _createElementVNode(\"div\", {\n class: \"powered-by\"\n }, [_createElementVNode(\"p\", null, [_createTextVNode(\"Powered By: \"), _createElementVNode(\"a\", {\n href: \"https://github.com/MarSeventh/CloudFlare-ImgBed\",\n class: \"project-link\"\n }, \" CloudFlare-ImgBed \")])], -1))])]), _cache[11] || (_cache[11] = _createStaticVNode(\"
\", 1))]);\n}","import \"core-js/modules/es.array.push.js\";\nimport { useHead } from '@vueuse/head';\nimport { mapGetters } from 'vuex';\nimport backgroundManager from '@/mixins/backgroundManager';\nexport default {\n name: 'WhiteListOn',\n mixins: [backgroundManager],\n computed: {\n ...mapGetters(['useDarkMode', 'userConfig'])\n },\n setup() {\n useHead({\n title: 'White List On',\n meta: [{\n name: 'robots',\n content: 'noindex, nofollow'\n }, {\n name: 'viewport',\n content: 'width=device-width, initial-scale=1'\n }, {\n charset: 'UTF-8'\n }]\n });\n },\n mounted() {\n // 初始化背景图\n this.initializeBackground('uploadBkImg', '.whitelist-container', false, true);\n },\n beforeUnmount() {\n // 清理背景轮播定时器\n this.clearBackgroundInterval();\n },\n methods: {\n goHome() {\n this.$router.push('/');\n },\n goBack() {\n if (window.history.length > 1) {\n this.$router.go(-1);\n } else {\n this.$router.push('/');\n }\n },\n refreshPage() {\n window.location.reload();\n }\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./WhiteListOn.vue?vue&type=template&id=ca56fa40&scoped=true\"\nimport script from \"./WhiteListOn.vue?vue&type=script&lang=js\"\nexport * from \"./WhiteListOn.vue?vue&type=script&lang=js\"\n\nimport \"./WhiteListOn.vue?vue&type=style&index=0&id=ca56fa40&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-ca56fa40\"]])\n\nexport default __exports__","/**\r\n * 背景图管理 Mixin\r\n * 用于统一管理页面背景图的加载和轮播逻辑\r\n */\r\n\r\nimport { mapGetters } from 'vuex'\r\n\r\nexport default {\r\n data() {\r\n return {\r\n bingWallPaperIndex: 0,\r\n customWallPaperIndex: 0,\r\n backgroundInterval: null, // 存储轮播定时器\r\n // 存储初始化参数,用于主题切换时重新初始化\r\n backgroundInitParams: null,\r\n }\r\n },\r\n computed: {\r\n ...mapGetters(['userConfig', 'bingWallPapers', 'useDarkMode']),\r\n bkInterval() {\r\n return this.userConfig?.bkInterval || 3000\r\n },\r\n bkOpacity() {\r\n return this.userConfig?.bkOpacity || 1\r\n },\r\n // 提供背景图片元素的模板\r\n backgroundImagesTemplate() {\r\n return `\r\n \"Background\r\n \"Background\r\n `\r\n },\r\n // 提供背景图片的CSS样式\r\n backgroundImagesStyles() {\r\n return `\r\n .background-image1 {\r\n position: fixed;\r\n top: 0;\r\n left: 0;\r\n width: 100%;\r\n height: 100%;\r\n object-fit: cover;\r\n z-index: -1;\r\n opacity: 0;\r\n transition: opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1), filter 0.3s ease;\r\n filter: var(--background-image-filter, brightness(1));\r\n }\r\n .background-image2 {\r\n position: fixed;\r\n top: 0;\r\n left: 0;\r\n width: 100%;\r\n height: 100%;\r\n object-fit: cover;\r\n z-index: -1;\r\n opacity: 0;\r\n transition: opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1), filter 0.3s ease;\r\n filter: var(--background-image-filter, brightness(1));\r\n }\r\n `\r\n }\r\n },\r\n\r\n watch: {\r\n // 监听深色模式切换\r\n useDarkMode(newVal, oldVal) {\r\n // 只有在值真正改变且已经初始化过背景时才平滑切换主题\r\n if (newVal !== oldVal && this.backgroundInitParams) {\r\n this.$nextTick(() => {\r\n this.smoothThemeTransition(\r\n this.backgroundInitParams.configKey,\r\n this.backgroundInitParams.containerSelector,\r\n this.backgroundInitParams.useDefaultBackground,\r\n this.backgroundInitParams.autoCreateElements\r\n )\r\n })\r\n }\r\n }\r\n },\r\n\r\n mounted() {\r\n // 动态注入背景图片的CSS样式\r\n this.injectBackgroundStyles()\r\n },\r\n\r\n beforeUnmount() {\r\n // 组件销毁前清除定时器\r\n if (this.backgroundInterval) {\r\n clearInterval(this.backgroundInterval)\r\n }\r\n // 立即清除背景图片,不使用过渡效果\r\n this.clearBackgroundImages(true)\r\n // 移除动态注入的样式\r\n this.removeBackgroundStyles()\r\n },\r\n\r\n methods: {\r\n /**\r\n * 动态注入背景图片样式\r\n */\r\n injectBackgroundStyles() {\r\n const styleId = 'background-manager-styles'\r\n if (!document.getElementById(styleId)) {\r\n const style = document.createElement('style')\r\n style.id = styleId\r\n style.textContent = this.backgroundImagesStyles\r\n document.head.appendChild(style)\r\n }\r\n },\r\n\r\n /**\r\n * 移除动态注入的样式\r\n */\r\n removeBackgroundStyles() {\r\n const styleId = 'background-manager-styles'\r\n const existingStyle = document.getElementById(styleId)\r\n if (existingStyle) {\r\n existingStyle.remove()\r\n }\r\n },\r\n\r\n /**\r\n * 动态创建背景图片元素\r\n * @param {HTMLElement} container - 要插入背景图片的容器元素\r\n */\r\n createBackgroundElements(container) {\r\n if (!container) {\r\n console.warn('未提供有效的容器元素')\r\n return\r\n }\r\n\r\n // 检查是否已经存在背景图片元素\r\n if (document.getElementById('bg1') || document.getElementById('bg2')) {\r\n return\r\n }\r\n\r\n // 创建 bg1 元素\r\n const bg1 = document.createElement('img')\r\n bg1.id = 'bg1'\r\n bg1.className = 'background-image1'\r\n bg1.alt = 'Background Image'\r\n \r\n // 创建 bg2 元素\r\n const bg2 = document.createElement('img')\r\n bg2.id = 'bg2'\r\n bg2.className = 'background-image2'\r\n bg2.alt = 'Background Image'\r\n\r\n // 将元素插入到容器的开头\r\n container.insertBefore(bg1, container.firstChild)\r\n container.insertBefore(bg2, container.firstChild)\r\n },\r\n /**\r\n * 初始化背景图\r\n * @param {string} configKey - 用户配置中的背景图配置键名\r\n * @param {string} containerSelector - 容器选择器,用于设置透明背景\r\n * @param {boolean} useDefaultBackground - 是否使用默认背景图\r\n * @param {boolean} autoCreateElements - 是否自动创建背景元素\r\n */\r\n initializeBackground(configKey, containerSelector = '.login', useDefaultBackground = false, autoCreateElements = false) {\r\n // 保存初始化参数,用于主题切换时重新初始化\r\n this.backgroundInitParams = {\r\n configKey,\r\n containerSelector,\r\n useDefaultBackground,\r\n autoCreateElements\r\n }\r\n\r\n // 如果需要自动创建元素且元素不存在,则创建\r\n if (autoCreateElements) {\r\n const container = document.querySelector(containerSelector)\r\n if (container && (!document.getElementById('bg1') || !document.getElementById('bg2'))) {\r\n this.createBackgroundElements(container)\r\n }\r\n }\r\n\r\n const bg1 = document.getElementById('bg1')\r\n const bg2 = document.getElementById('bg2')\r\n \r\n if (!bg1 || !bg2) {\r\n console.warn('背景图元素 #bg1 或 #bg2 未找到,请确保页面中包含这些元素或启用 autoCreateElements')\r\n return\r\n }\r\n\r\n const backgroundConfig = this.userConfig?.[configKey]\r\n\r\n if (backgroundConfig === 'bing') {\r\n this.setupBingWallpaper(bg1, bg2, containerSelector)\r\n } else if (Array.isArray(backgroundConfig) && backgroundConfig.length > 1) {\r\n this.setupCustomWallpaperCarousel(bg1, bg2, backgroundConfig, containerSelector)\r\n } else if (Array.isArray(backgroundConfig) && backgroundConfig.length === 1) {\r\n this.setupSingleCustomWallpaper(bg1, backgroundConfig[0], containerSelector)\r\n } else if (useDefaultBackground) {\r\n this.setupDefaultWallpaper(bg1, containerSelector)\r\n }\r\n },\r\n\r\n /**\r\n * 设置 Bing 壁纸轮播\r\n */\r\n setupBingWallpaper(bg1, bg2, containerSelector) {\r\n this.$store.dispatch('fetchBingWallPapers').then(() => {\r\n if (this.bingWallPapers.length === 0) return\r\n\r\n this.loadBackgroundImage(bg1, this.bingWallPapers[this.bingWallPaperIndex]?.url, containerSelector)\r\n \r\n this.backgroundInterval = setInterval(() => {\r\n this.switchBingWallpaper(bg1, bg2)\r\n }, this.bkInterval)\r\n })\r\n },\r\n\r\n /**\r\n * 设置自定义壁纸轮播\r\n */\r\n setupCustomWallpaperCarousel(bg1, bg2, wallpapers, containerSelector) {\r\n this.loadBackgroundImage(bg1, wallpapers[this.customWallPaperIndex], containerSelector)\r\n \r\n this.backgroundInterval = setInterval(() => {\r\n this.switchCustomWallpaper(bg1, bg2, wallpapers)\r\n }, this.bkInterval)\r\n },\r\n\r\n /**\r\n * 设置单张自定义壁纸\r\n */\r\n setupSingleCustomWallpaper(bg1, wallpaperUrl, containerSelector) {\r\n this.loadBackgroundImage(bg1, wallpaperUrl, containerSelector)\r\n },\r\n\r\n /**\r\n * 设置默认壁纸\r\n */\r\n setupDefaultWallpaper(bg1, containerSelector) {\r\n // 根据当前深色模式状态选择背景图\r\n const isDark = this.useDarkMode\r\n const defaultImage = isDark \r\n ? require('@/assets/background.jpg') \r\n : require('@/assets/background-light.jpg')\r\n \r\n this.loadBackgroundImage(bg1, defaultImage, containerSelector)\r\n },\r\n\r\n /**\r\n * 加载背景图片\r\n */\r\n loadBackgroundImage(imgElement, imageSrc, containerSelector) {\r\n imgElement.src = imageSrc\r\n imgElement.onload = () => {\r\n imgElement.style.opacity = this.bkOpacity\r\n // 设置容器背景为透明\r\n const container = document.querySelector(containerSelector)\r\n if (container) {\r\n container.style.background = 'transparent'\r\n }\r\n }\r\n },\r\n\r\n /**\r\n * 切换 Bing 壁纸\r\n */\r\n switchBingWallpaper(bg1, bg2) {\r\n if (this.bingWallPapers.length === 0) return\r\n\r\n const curBg = bg1.style.opacity != 0 ? bg1 : bg2\r\n const nextBg = bg1.style.opacity != 0 ? bg2 : bg1\r\n \r\n curBg.style.opacity = 0\r\n this.bingWallPaperIndex = (this.bingWallPaperIndex + 1) % this.bingWallPapers.length\r\n \r\n nextBg.src = this.bingWallPapers[this.bingWallPaperIndex]?.url\r\n nextBg.onload = () => {\r\n nextBg.style.opacity = this.bkOpacity\r\n }\r\n },\r\n\r\n /**\r\n * 切换自定义壁纸\r\n */\r\n switchCustomWallpaper(bg1, bg2, wallpapers) {\r\n const curBg = bg1.style.opacity != 0 ? bg1 : bg2\r\n const nextBg = bg1.style.opacity != 0 ? bg2 : bg1\r\n \r\n curBg.style.opacity = 0\r\n this.customWallPaperIndex = (this.customWallPaperIndex + 1) % wallpapers.length\r\n \r\n nextBg.src = wallpapers[this.customWallPaperIndex]\r\n nextBg.onload = () => {\r\n nextBg.style.opacity = this.bkOpacity\r\n }\r\n },\r\n\r\n /**\r\n * 清除背景轮播定时器\r\n */\r\n clearBackgroundInterval() {\r\n if (this.backgroundInterval) {\r\n clearInterval(this.backgroundInterval)\r\n this.backgroundInterval = null\r\n }\r\n },\r\n\r\n /**\r\n * 清除背景图片显示(带过渡效果)\r\n * @param {boolean} immediate - 是否立即清除,不使用过渡效果\r\n */\r\n clearBackgroundImages(immediate = false) {\r\n const bg1 = document.getElementById('bg1')\r\n const bg2 = document.getElementById('bg2')\r\n \r\n if (immediate) {\r\n // 立即清除,不使用过渡效果\r\n if (bg1) {\r\n bg1.style.transition = 'none'\r\n bg1.style.opacity = 0\r\n bg1.src = ''\r\n // 恢复过渡效果\r\n setTimeout(() => {\r\n if (bg1) bg1.style.transition = 'opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1)'\r\n }, 50)\r\n }\r\n if (bg2) {\r\n bg2.style.transition = 'none'\r\n bg2.style.opacity = 0\r\n bg2.src = ''\r\n // 恢复过渡效果\r\n setTimeout(() => {\r\n if (bg2) bg2.style.transition = 'opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1)'\r\n }, 50)\r\n }\r\n } else {\r\n // 使用过渡效果淡出\r\n if (bg1) {\r\n bg1.style.opacity = 0\r\n setTimeout(() => {\r\n if (bg1) bg1.src = ''\r\n }, 800) // 等待过渡完成后清除src\r\n }\r\n if (bg2) {\r\n bg2.style.opacity = 0\r\n setTimeout(() => {\r\n if (bg2) bg2.src = ''\r\n }, 800) // 等待过渡完成后清除src\r\n }\r\n }\r\n },\r\n\r\n /**\r\n * 平滑主题切换(用于响应主题模式变化)\r\n * @param {string} configKey - 用户配置中的背景图配置键名\r\n * @param {string} containerSelector - 容器选择器\r\n * @param {boolean} useDefaultBackground - 是否使用默认背景图\r\n * @param {boolean} autoCreateElements - 是否自动创建背景元素\r\n */\r\n smoothThemeTransition(configKey, containerSelector = '.login', useDefaultBackground = false, autoCreateElements = false) {\r\n const backgroundConfig = this.userConfig?.[configKey]\r\n \r\n // 如果不是默认背景配置,则直接重新初始化(自定义背景不受主题影响)\r\n if (!useDefaultBackground || backgroundConfig !== undefined) {\r\n this.reinitializeBackground(configKey, containerSelector, useDefaultBackground, autoCreateElements)\r\n return\r\n }\r\n\r\n // 对于默认背景,执行平滑过渡\r\n const bg1 = document.getElementById('bg1')\r\n const bg2 = document.getElementById('bg2')\r\n \r\n if (!bg1 || !bg2) {\r\n // 如果背景元素不存在,直接重新初始化\r\n this.reinitializeBackground(configKey, containerSelector, useDefaultBackground, autoCreateElements)\r\n return\r\n }\r\n\r\n // 确定当前显示的背景和下一个背景\r\n const currentBg = bg1.style.opacity != 0 ? bg1 : bg2\r\n const nextBg = bg1.style.opacity != 0 ? bg2 : bg1\r\n\r\n // 获取新主题对应的背景图\r\n const isDark = this.useDarkMode\r\n const newThemeImage = isDark \r\n ? require('@/assets/background.jpg') \r\n : require('@/assets/background-light.jpg')\r\n\r\n // 预加载新背景图\r\n const preloadImg = new Image()\r\n preloadImg.onload = () => {\r\n // 设置下一个背景的图片源\r\n nextBg.src = newThemeImage\r\n \r\n // 等待图片加载完成后执行淡入淡出过渡\r\n nextBg.onload = () => {\r\n // 淡出当前背景\r\n currentBg.style.opacity = 0\r\n \r\n // 稍微延迟后淡入新背景,确保过渡效果平滑\r\n setTimeout(() => {\r\n nextBg.style.opacity = this.bkOpacity\r\n \r\n // 设置容器背景为透明\r\n const container = document.querySelector(containerSelector)\r\n if (container) {\r\n container.style.background = 'transparent'\r\n }\r\n }, 50) // 50ms 延迟,让淡出效果先开始\r\n }\r\n }\r\n \r\n preloadImg.onerror = () => {\r\n // 如果预加载失败,回退到直接重新初始化\r\n console.warn('主题背景图预加载失败,回退到直接切换')\r\n this.reinitializeBackground(configKey, containerSelector, useDefaultBackground, autoCreateElements)\r\n }\r\n \r\n preloadImg.src = newThemeImage\r\n },\r\n\r\n /**\r\n * 重新初始化背景图(用于响应配置变化)\r\n */\r\n reinitializeBackground(configKey, containerSelector = '.login', useDefaultBackground = false, autoCreateElements = false) {\r\n this.clearBackgroundInterval()\r\n this.clearBackgroundImages(true) // 使用立即清除\r\n this.bingWallPaperIndex = 0\r\n this.customWallPaperIndex = 0\r\n \r\n // 延迟一小段时间确保清理完成\r\n setTimeout(() => {\r\n this.initializeBackground(configKey, containerSelector, useDefaultBackground, autoCreateElements)\r\n }, 100)\r\n }\r\n }\r\n}\r\n"],"names":["_hoisted_1","class","_hoisted_2","_hoisted_3","_hoisted_4","_hoisted_5","_hoisted_6","_hoisted_7","_hoisted_8","_hoisted_9","_hoisted_10","_hoisted_11","render","_ctx","_cache","$props","$setup","$data","$options","_component_font_awesome_icon","_component_el_button","innerHTML","backgroundImagesTemplate","onClick","goHome","circle","size","default","icon","_","type","goBack","href","args","refreshPage","name","mixins","backgroundManager","computed","setup","u","title","meta","content","charset","mounted","this","initializeBackground","beforeUnmount","clearBackgroundInterval","methods","$router","push","window","history","length","go","location","reload","__exports__","data","bingWallPaperIndex","customWallPaperIndex","backgroundInterval","backgroundInitParams","mapGetters","bkInterval","userConfig","bkOpacity","backgroundImagesStyles","watch","useDarkMode","newVal","oldVal","$nextTick","smoothThemeTransition","configKey","containerSelector","useDefaultBackground","autoCreateElements","injectBackgroundStyles","clearInterval","clearBackgroundImages","removeBackgroundStyles","styleId","document","getElementById","style","createElement","id","textContent","head","appendChild","existingStyle","remove","createBackgroundElements","container","console","warn","bg1","className","alt","bg2","insertBefore","firstChild","querySelector","backgroundConfig","setupBingWallpaper","Array","isArray","setupCustomWallpaperCarousel","setupSingleCustomWallpaper","setupDefaultWallpaper","$store","dispatch","then","bingWallPapers","loadBackgroundImage","url","setInterval","switchBingWallpaper","wallpapers","switchCustomWallpaper","wallpaperUrl","isDark","defaultImage","require","imgElement","imageSrc","src","onload","opacity","background","curBg","nextBg","immediate","transition","setTimeout","undefined","reinitializeBackground","currentBg","newThemeImage","preloadImg","Image","onerror"],"ignoreList":[],"sourceRoot":""} \ No newline at end of file +{"version":3,"file":"js/845.1bb9a557.js","mappings":"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","sources":["webpack://sanyue_imghub/./src/views/WhiteListOn.vue?8ff1","webpack://sanyue_imghub/./src/views/WhiteListOn.vue","webpack://sanyue_imghub/./src/views/WhiteListOn.vue?05e5","webpack://sanyue_imghub/./src/mixins/backgroundManager.js"],"sourcesContent":["import { createElementVNode as _createElementVNode, resolveComponent as _resolveComponent, createVNode as _createVNode, withCtx as _withCtx, createTextVNode as _createTextVNode, createStaticVNode as _createStaticVNode, openBlock as _openBlock, createElementBlock as _createElementBlock } from \"vue\";\nconst _hoisted_1 = {\n class: \"whitelist-container\"\n};\nconst _hoisted_2 = [\"innerHTML\"];\nconst _hoisted_3 = {\n class: \"whitelist-content\"\n};\nconst _hoisted_4 = {\n class: \"back-button-wrapper\"\n};\nconst _hoisted_5 = {\n class: \"status-animation\"\n};\nconst _hoisted_6 = {\n class: \"status-icon\"\n};\nconst _hoisted_7 = {\n class: \"status-badge\"\n};\nconst _hoisted_8 = {\n class: \"status-info\"\n};\nconst _hoisted_9 = {\n class: \"status-actions\"\n};\nconst _hoisted_10 = {\n class: \"help-info\"\n};\nconst _hoisted_11 = {\n class: \"quick-links\"\n};\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_font_awesome_icon = _resolveComponent(\"font-awesome-icon\");\n const _component_el_button = _resolveComponent(\"el-button\");\n return _openBlock(), _createElementBlock(\"div\", _hoisted_1, [_createElementVNode(\"div\", {\n class: \"background-wrapper\",\n innerHTML: _ctx.backgroundImagesTemplate\n }, null, 8, _hoisted_2), _createElementVNode(\"div\", _hoisted_3, [_createElementVNode(\"div\", _hoisted_4, [_createVNode(_component_el_button, {\n class: \"back-button\",\n onClick: $options.goHome,\n circle: \"\",\n size: \"large\"\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"home\"\n })]),\n _: 1\n }, 8, [\"onClick\"])]), _createElementVNode(\"div\", _hoisted_5, [_createElementVNode(\"div\", _hoisted_6, [_createVNode(_component_font_awesome_icon, {\n icon: \"shield-alt\",\n class: \"shield-icon\"\n }), _createElementVNode(\"div\", _hoisted_7, [_createVNode(_component_font_awesome_icon, {\n icon: \"clock\",\n class: \"clock-icon\"\n })])])]), _createElementVNode(\"div\", _hoisted_8, [_cache[7] || (_cache[7] = _createElementVNode(\"h1\", {\n class: \"status-title\"\n }, \"白名单模式已启用\", -1)), _cache[8] || (_cache[8] = _createElementVNode(\"p\", {\n class: \"status-description\"\n }, \" 抱歉,当前已开启白名单模式,上传的图片需要审核通过后才能展示,请等待审核通过后再进行访问。 \", -1)), _cache[9] || (_cache[9] = _createElementVNode(\"p\", {\n class: \"status-description-en\"\n }, \" Sorry, the whitelist mode is currently enabled, the uploaded images need to be audited before they can be displayed, please wait for the audit to be passed before visiting. \", -1)), _createElementVNode(\"div\", _hoisted_9, [_createVNode(_component_el_button, {\n type: \"primary\",\n size: \"large\",\n class: \"action-btn primary-btn\",\n onClick: $options.goHome\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"home\",\n class: \"btn-icon\"\n }), _cache[2] || (_cache[2] = _createTextVNode(\" 返回首页 \", -1))]),\n _: 1\n }, 8, [\"onClick\"]), _createVNode(_component_el_button, {\n size: \"large\",\n class: \"action-btn secondary-btn\",\n onClick: $options.goBack\n }, {\n default: _withCtx(() => [_createVNode(_component_font_awesome_icon, {\n icon: \"arrow-left\",\n class: \"btn-icon\"\n }), _cache[3] || (_cache[3] = _createTextVNode(\" 返回上页 \", -1))]),\n _: 1\n }, 8, [\"onClick\"])]), _createElementVNode(\"div\", _hoisted_10, [_cache[6] || (_cache[6] = _createElementVNode(\"p\", {\n class: \"help-text\"\n }, \"您可以尝试:\", -1)), _createElementVNode(\"div\", _hoisted_11, [_createElementVNode(\"a\", {\n href: \"javascript:void(0)\",\n onClick: _cache[0] || (_cache[0] = (...args) => $options.goHome && $options.goHome(...args)),\n class: \"quick-link\"\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"cloud-upload-alt\"\n }), _cache[4] || (_cache[4] = _createTextVNode(\" 图片上传 \", -1))]), _createElementVNode(\"a\", {\n href: \"javascript:void(0)\",\n onClick: _cache[1] || (_cache[1] = (...args) => $options.refreshPage && $options.refreshPage(...args)),\n class: \"quick-link\"\n }, [_createVNode(_component_font_awesome_icon, {\n icon: \"redo\"\n }), _cache[5] || (_cache[5] = _createTextVNode(\" 刷新页面 \", -1))])])]), _cache[10] || (_cache[10] = _createElementVNode(\"div\", {\n class: \"powered-by\"\n }, [_createElementVNode(\"p\", null, [_createTextVNode(\"Powered By: \"), _createElementVNode(\"a\", {\n href: \"https://github.com/MarSeventh/CloudFlare-ImgBed\",\n class: \"project-link\"\n }, \" CloudFlare-ImgBed \")])], -1))])]), _cache[11] || (_cache[11] = _createStaticVNode(\"
\", 1))]);\n}","import \"core-js/modules/es.array.push.js\";\nimport { useHead } from '@vueuse/head';\nimport { mapGetters } from 'vuex';\nimport backgroundManager from '@/mixins/backgroundManager';\nexport default {\n name: 'WhiteListOn',\n mixins: [backgroundManager],\n computed: {\n ...mapGetters(['useDarkMode', 'userConfig'])\n },\n setup() {\n useHead({\n title: 'White List On',\n meta: [{\n name: 'robots',\n content: 'noindex, nofollow'\n }, {\n name: 'viewport',\n content: 'width=device-width, initial-scale=1'\n }, {\n charset: 'UTF-8'\n }]\n });\n },\n mounted() {\n // 初始化背景图\n this.initializeBackground('uploadBkImg', '.whitelist-container', false, true);\n },\n beforeUnmount() {\n // 清理背景轮播定时器\n this.clearBackgroundInterval();\n },\n methods: {\n goHome() {\n this.$router.push('/');\n },\n goBack() {\n if (window.history.length > 1) {\n this.$router.go(-1);\n } else {\n this.$router.push('/');\n }\n },\n refreshPage() {\n window.location.reload();\n }\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./WhiteListOn.vue?vue&type=template&id=ca56fa40&scoped=true\"\nimport script from \"./WhiteListOn.vue?vue&type=script&lang=js\"\nexport * from \"./WhiteListOn.vue?vue&type=script&lang=js\"\n\nimport \"./WhiteListOn.vue?vue&type=style&index=0&id=ca56fa40&scoped=true&lang=css\"\n\nimport exportComponent from \"../../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render],['__scopeId',\"data-v-ca56fa40\"]])\n\nexport default __exports__","/**\r\n * 背景图管理 Mixin\r\n * 用于统一管理页面背景图的加载和轮播逻辑\r\n */\r\n\r\nimport { mapGetters } from 'vuex'\r\n\r\nexport default {\r\n data() {\r\n return {\r\n bingWallPaperIndex: 0,\r\n customWallPaperIndex: 0,\r\n backgroundInterval: null, // 存储轮播定时器\r\n // 存储初始化参数,用于主题切换时重新初始化\r\n backgroundInitParams: null,\r\n }\r\n },\r\n computed: {\r\n ...mapGetters(['userConfig', 'bingWallPapers', 'useDarkMode']),\r\n bkInterval() {\r\n return this.userConfig?.bkInterval || 3000\r\n },\r\n bkOpacity() {\r\n return this.userConfig?.bkOpacity || 1\r\n },\r\n // 提供背景图片元素的模板\r\n backgroundImagesTemplate() {\r\n return `\r\n \"Background\r\n \"Background\r\n `\r\n },\r\n // 提供背景图片的CSS样式\r\n backgroundImagesStyles() {\r\n return `\r\n .background-image1 {\r\n position: fixed;\r\n top: 0;\r\n left: 0;\r\n width: 100%;\r\n height: 100%;\r\n object-fit: cover;\r\n z-index: -1;\r\n opacity: 0;\r\n transition: opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1), filter 0.3s ease;\r\n filter: var(--background-image-filter, brightness(1));\r\n }\r\n .background-image2 {\r\n position: fixed;\r\n top: 0;\r\n left: 0;\r\n width: 100%;\r\n height: 100%;\r\n object-fit: cover;\r\n z-index: -1;\r\n opacity: 0;\r\n transition: opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1), filter 0.3s ease;\r\n filter: var(--background-image-filter, brightness(1));\r\n }\r\n `\r\n }\r\n },\r\n\r\n watch: {\r\n // 监听深色模式切换\r\n useDarkMode(newVal, oldVal) {\r\n // 只有在值真正改变且已经初始化过背景时才平滑切换主题\r\n if (newVal !== oldVal && this.backgroundInitParams) {\r\n this.$nextTick(() => {\r\n this.smoothThemeTransition(\r\n this.backgroundInitParams.configKey,\r\n this.backgroundInitParams.containerSelector,\r\n this.backgroundInitParams.useDefaultBackground,\r\n this.backgroundInitParams.autoCreateElements\r\n )\r\n })\r\n }\r\n }\r\n },\r\n\r\n mounted() {\r\n // 动态注入背景图片的CSS样式\r\n this.injectBackgroundStyles()\r\n },\r\n\r\n beforeUnmount() {\r\n // 组件销毁前清除定时器\r\n if (this.backgroundInterval) {\r\n clearInterval(this.backgroundInterval)\r\n }\r\n // 立即清除背景图片,不使用过渡效果\r\n this.clearBackgroundImages(true)\r\n // 移除动态注入的样式\r\n this.removeBackgroundStyles()\r\n },\r\n\r\n methods: {\r\n /**\r\n * 动态注入背景图片样式\r\n */\r\n injectBackgroundStyles() {\r\n const styleId = 'background-manager-styles'\r\n if (!document.getElementById(styleId)) {\r\n const style = document.createElement('style')\r\n style.id = styleId\r\n style.textContent = this.backgroundImagesStyles\r\n document.head.appendChild(style)\r\n }\r\n },\r\n\r\n /**\r\n * 移除动态注入的样式\r\n */\r\n removeBackgroundStyles() {\r\n const styleId = 'background-manager-styles'\r\n const existingStyle = document.getElementById(styleId)\r\n if (existingStyle) {\r\n existingStyle.remove()\r\n }\r\n },\r\n\r\n /**\r\n * 动态创建背景图片元素\r\n * @param {HTMLElement} container - 要插入背景图片的容器元素\r\n */\r\n createBackgroundElements(container) {\r\n if (!container) {\r\n console.warn('未提供有效的容器元素')\r\n return\r\n }\r\n\r\n // 检查是否已经存在背景图片元素\r\n if (document.getElementById('bg1') || document.getElementById('bg2')) {\r\n return\r\n }\r\n\r\n // 创建 bg1 元素\r\n const bg1 = document.createElement('img')\r\n bg1.id = 'bg1'\r\n bg1.className = 'background-image1'\r\n bg1.alt = 'Background Image'\r\n \r\n // 创建 bg2 元素\r\n const bg2 = document.createElement('img')\r\n bg2.id = 'bg2'\r\n bg2.className = 'background-image2'\r\n bg2.alt = 'Background Image'\r\n\r\n // 将元素插入到容器的开头\r\n container.insertBefore(bg1, container.firstChild)\r\n container.insertBefore(bg2, container.firstChild)\r\n },\r\n /**\r\n * 初始化背景图\r\n * @param {string} configKey - 用户配置中的背景图配置键名\r\n * @param {string} containerSelector - 容器选择器,用于设置透明背景\r\n * @param {boolean} useDefaultBackground - 是否使用默认背景图\r\n * @param {boolean} autoCreateElements - 是否自动创建背景元素\r\n */\r\n initializeBackground(configKey, containerSelector = '.login', useDefaultBackground = false, autoCreateElements = false) {\r\n // 保存初始化参数,用于主题切换时重新初始化\r\n this.backgroundInitParams = {\r\n configKey,\r\n containerSelector,\r\n useDefaultBackground,\r\n autoCreateElements\r\n }\r\n\r\n // 如果需要自动创建元素且元素不存在,则创建\r\n if (autoCreateElements) {\r\n const container = document.querySelector(containerSelector)\r\n if (container && (!document.getElementById('bg1') || !document.getElementById('bg2'))) {\r\n this.createBackgroundElements(container)\r\n }\r\n }\r\n\r\n const bg1 = document.getElementById('bg1')\r\n const bg2 = document.getElementById('bg2')\r\n \r\n if (!bg1 || !bg2) {\r\n console.warn('背景图元素 #bg1 或 #bg2 未找到,请确保页面中包含这些元素或启用 autoCreateElements')\r\n return\r\n }\r\n\r\n const backgroundConfig = this.userConfig?.[configKey]\r\n\r\n if (backgroundConfig === 'bing') {\r\n this.setupBingWallpaper(bg1, bg2, containerSelector)\r\n } else if (Array.isArray(backgroundConfig) && backgroundConfig.length > 1) {\r\n this.setupCustomWallpaperCarousel(bg1, bg2, backgroundConfig, containerSelector)\r\n } else if (Array.isArray(backgroundConfig) && backgroundConfig.length === 1) {\r\n this.setupSingleCustomWallpaper(bg1, backgroundConfig[0], containerSelector)\r\n } else if (useDefaultBackground) {\r\n this.setupDefaultWallpaper(bg1, containerSelector)\r\n }\r\n },\r\n\r\n /**\r\n * 设置 Bing 壁纸轮播\r\n */\r\n setupBingWallpaper(bg1, bg2, containerSelector) {\r\n this.$store.dispatch('fetchBingWallPapers').then(() => {\r\n if (this.bingWallPapers.length === 0) return\r\n\r\n this.loadBackgroundImage(bg1, this.bingWallPapers[this.bingWallPaperIndex]?.url, containerSelector)\r\n \r\n this.backgroundInterval = setInterval(() => {\r\n this.switchBingWallpaper(bg1, bg2)\r\n }, this.bkInterval)\r\n })\r\n },\r\n\r\n /**\r\n * 设置自定义壁纸轮播\r\n */\r\n setupCustomWallpaperCarousel(bg1, bg2, wallpapers, containerSelector) {\r\n this.loadBackgroundImage(bg1, wallpapers[this.customWallPaperIndex], containerSelector)\r\n \r\n this.backgroundInterval = setInterval(() => {\r\n this.switchCustomWallpaper(bg1, bg2, wallpapers)\r\n }, this.bkInterval)\r\n },\r\n\r\n /**\r\n * 设置单张自定义壁纸\r\n */\r\n setupSingleCustomWallpaper(bg1, wallpaperUrl, containerSelector) {\r\n this.loadBackgroundImage(bg1, wallpaperUrl, containerSelector)\r\n },\r\n\r\n /**\r\n * 设置默认壁纸\r\n */\r\n setupDefaultWallpaper(bg1, containerSelector) {\r\n // 根据当前深色模式状态选择背景图\r\n const isDark = this.useDarkMode\r\n const defaultImage = isDark \r\n ? require('@/assets/background.jpg') \r\n : require('@/assets/background-light.jpg')\r\n \r\n this.loadBackgroundImage(bg1, defaultImage, containerSelector)\r\n },\r\n\r\n /**\r\n * 加载背景图片\r\n */\r\n loadBackgroundImage(imgElement, imageSrc, containerSelector) {\r\n imgElement.src = imageSrc\r\n imgElement.onload = () => {\r\n imgElement.style.opacity = this.bkOpacity\r\n // 设置容器背景为透明\r\n const container = document.querySelector(containerSelector)\r\n if (container) {\r\n container.style.background = 'transparent'\r\n }\r\n }\r\n },\r\n\r\n /**\r\n * 切换 Bing 壁纸\r\n */\r\n switchBingWallpaper(bg1, bg2) {\r\n if (this.bingWallPapers.length === 0) return\r\n\r\n const curBg = bg1.style.opacity != 0 ? bg1 : bg2\r\n const nextBg = bg1.style.opacity != 0 ? bg2 : bg1\r\n \r\n curBg.style.opacity = 0\r\n this.bingWallPaperIndex = (this.bingWallPaperIndex + 1) % this.bingWallPapers.length\r\n \r\n nextBg.src = this.bingWallPapers[this.bingWallPaperIndex]?.url\r\n nextBg.onload = () => {\r\n nextBg.style.opacity = this.bkOpacity\r\n }\r\n },\r\n\r\n /**\r\n * 切换自定义壁纸\r\n */\r\n switchCustomWallpaper(bg1, bg2, wallpapers) {\r\n const curBg = bg1.style.opacity != 0 ? bg1 : bg2\r\n const nextBg = bg1.style.opacity != 0 ? bg2 : bg1\r\n \r\n curBg.style.opacity = 0\r\n this.customWallPaperIndex = (this.customWallPaperIndex + 1) % wallpapers.length\r\n \r\n nextBg.src = wallpapers[this.customWallPaperIndex]\r\n nextBg.onload = () => {\r\n nextBg.style.opacity = this.bkOpacity\r\n }\r\n },\r\n\r\n /**\r\n * 清除背景轮播定时器\r\n */\r\n clearBackgroundInterval() {\r\n if (this.backgroundInterval) {\r\n clearInterval(this.backgroundInterval)\r\n this.backgroundInterval = null\r\n }\r\n },\r\n\r\n /**\r\n * 清除背景图片显示(带过渡效果)\r\n * @param {boolean} immediate - 是否立即清除,不使用过渡效果\r\n */\r\n clearBackgroundImages(immediate = false) {\r\n const bg1 = document.getElementById('bg1')\r\n const bg2 = document.getElementById('bg2')\r\n \r\n if (immediate) {\r\n // 立即清除,不使用过渡效果\r\n if (bg1) {\r\n bg1.style.transition = 'none'\r\n bg1.style.opacity = 0\r\n bg1.src = ''\r\n // 恢复过渡效果\r\n setTimeout(() => {\r\n if (bg1) bg1.style.transition = 'opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1)'\r\n }, 50)\r\n }\r\n if (bg2) {\r\n bg2.style.transition = 'none'\r\n bg2.style.opacity = 0\r\n bg2.src = ''\r\n // 恢复过渡效果\r\n setTimeout(() => {\r\n if (bg2) bg2.style.transition = 'opacity 0.8s cubic-bezier(0.4, 0, 0.2, 1)'\r\n }, 50)\r\n }\r\n } else {\r\n // 使用过渡效果淡出\r\n if (bg1) {\r\n bg1.style.opacity = 0\r\n setTimeout(() => {\r\n if (bg1) bg1.src = ''\r\n }, 800) // 等待过渡完成后清除src\r\n }\r\n if (bg2) {\r\n bg2.style.opacity = 0\r\n setTimeout(() => {\r\n if (bg2) bg2.src = ''\r\n }, 800) // 等待过渡完成后清除src\r\n }\r\n }\r\n },\r\n\r\n /**\r\n * 平滑主题切换(用于响应主题模式变化)\r\n * @param {string} configKey - 用户配置中的背景图配置键名\r\n * @param {string} containerSelector - 容器选择器\r\n * @param {boolean} useDefaultBackground - 是否使用默认背景图\r\n * @param {boolean} autoCreateElements - 是否自动创建背景元素\r\n */\r\n smoothThemeTransition(configKey, containerSelector = '.login', useDefaultBackground = false, autoCreateElements = false) {\r\n const backgroundConfig = this.userConfig?.[configKey]\r\n \r\n // 如果不是默认背景配置,则直接重新初始化(自定义背景不受主题影响)\r\n if (!useDefaultBackground || backgroundConfig !== undefined) {\r\n this.reinitializeBackground(configKey, containerSelector, useDefaultBackground, autoCreateElements)\r\n return\r\n }\r\n\r\n // 对于默认背景,执行平滑过渡\r\n const bg1 = document.getElementById('bg1')\r\n const bg2 = document.getElementById('bg2')\r\n \r\n if (!bg1 || !bg2) {\r\n // 如果背景元素不存在,直接重新初始化\r\n this.reinitializeBackground(configKey, containerSelector, useDefaultBackground, autoCreateElements)\r\n return\r\n }\r\n\r\n // 确定当前显示的背景和下一个背景\r\n const currentBg = bg1.style.opacity != 0 ? bg1 : bg2\r\n const nextBg = bg1.style.opacity != 0 ? bg2 : bg1\r\n\r\n // 获取新主题对应的背景图\r\n const isDark = this.useDarkMode\r\n const newThemeImage = isDark \r\n ? require('@/assets/background.jpg') \r\n : require('@/assets/background-light.jpg')\r\n\r\n // 预加载新背景图\r\n const preloadImg = new Image()\r\n preloadImg.onload = () => {\r\n // 设置下一个背景的图片源\r\n nextBg.src = newThemeImage\r\n \r\n // 等待图片加载完成后执行淡入淡出过渡\r\n nextBg.onload = () => {\r\n // 淡出当前背景\r\n currentBg.style.opacity = 0\r\n \r\n // 稍微延迟后淡入新背景,确保过渡效果平滑\r\n setTimeout(() => {\r\n nextBg.style.opacity = this.bkOpacity\r\n \r\n // 设置容器背景为透明\r\n const container = document.querySelector(containerSelector)\r\n if (container) {\r\n container.style.background = 'transparent'\r\n }\r\n }, 50) // 50ms 延迟,让淡出效果先开始\r\n }\r\n }\r\n \r\n preloadImg.onerror = () => {\r\n // 如果预加载失败,回退到直接重新初始化\r\n console.warn('主题背景图预加载失败,回退到直接切换')\r\n this.reinitializeBackground(configKey, containerSelector, useDefaultBackground, autoCreateElements)\r\n }\r\n \r\n preloadImg.src = newThemeImage\r\n },\r\n\r\n /**\r\n * 重新初始化背景图(用于响应配置变化)\r\n */\r\n reinitializeBackground(configKey, containerSelector = '.login', useDefaultBackground = false, autoCreateElements = false) {\r\n this.clearBackgroundInterval()\r\n this.clearBackgroundImages(true) // 使用立即清除\r\n this.bingWallPaperIndex = 0\r\n this.customWallPaperIndex = 0\r\n \r\n // 延迟一小段时间确保清理完成\r\n setTimeout(() => {\r\n this.initializeBackground(configKey, containerSelector, useDefaultBackground, autoCreateElements)\r\n }, 100)\r\n }\r\n }\r\n}\r\n"],"names":["_hoisted_1","class","_hoisted_2","_hoisted_3","_hoisted_4","_hoisted_5","_hoisted_6","_hoisted_7","_hoisted_8","_hoisted_9","_hoisted_10","_hoisted_11","render","_ctx","_cache","$props","$setup","$data","$options","_component_font_awesome_icon","_component_el_button","innerHTML","backgroundImagesTemplate","onClick","goHome","circle","size","default","icon","_","type","goBack","href","args","refreshPage","name","mixins","backgroundManager","computed","setup","u","title","meta","content","charset","mounted","this","initializeBackground","beforeUnmount","clearBackgroundInterval","methods","$router","push","window","history","length","go","location","reload","__exports__","data","bingWallPaperIndex","customWallPaperIndex","backgroundInterval","backgroundInitParams","mapGetters","bkInterval","userConfig","bkOpacity","backgroundImagesStyles","watch","useDarkMode","newVal","oldVal","$nextTick","smoothThemeTransition","configKey","containerSelector","useDefaultBackground","autoCreateElements","injectBackgroundStyles","clearInterval","clearBackgroundImages","removeBackgroundStyles","styleId","document","getElementById","style","createElement","id","textContent","head","appendChild","existingStyle","remove","createBackgroundElements","container","console","warn","bg1","className","alt","bg2","insertBefore","firstChild","querySelector","backgroundConfig","setupBingWallpaper","Array","isArray","setupCustomWallpaperCarousel","setupSingleCustomWallpaper","setupDefaultWallpaper","$store","dispatch","then","bingWallPapers","loadBackgroundImage","url","setInterval","switchBingWallpaper","wallpapers","switchCustomWallpaper","wallpaperUrl","isDark","defaultImage","require","imgElement","imageSrc","src","onload","opacity","background","curBg","nextBg","immediate","transition","setTimeout","undefined","reinitializeBackground","currentBg","newThemeImage","preloadImg","Image","onerror"],"ignoreList":[],"sourceRoot":""} \ No newline at end of file diff --git a/js/845.1bb9a557.js.map.gz b/js/845.1bb9a557.js.map.gz new file mode 100644 index 0000000..8219ef2 Binary files /dev/null and b/js/845.1bb9a557.js.map.gz differ diff --git a/js/845.97c9b302.js.gz b/js/845.97c9b302.js.gz deleted file mode 100644 index d2398c5..0000000 Binary files a/js/845.97c9b302.js.gz and /dev/null differ diff --git a/js/845.97c9b302.js.map.gz b/js/845.97c9b302.js.map.gz deleted file mode 100644 index 31dbb49..0000000 Binary files a/js/845.97c9b302.js.map.gz and /dev/null differ diff --git a/js/988.c78ed6a8.js.gz b/js/988.c78ed6a8.js.gz deleted file mode 100644 index 06a019c..0000000 Binary files a/js/988.c78ed6a8.js.gz and /dev/null differ diff --git a/js/988.c78ed6a8.js.map.gz b/js/988.c78ed6a8.js.map.gz deleted file mode 100644 index aae779f..0000000 Binary files a/js/988.c78ed6a8.js.map.gz and /dev/null differ diff --git a/js/app.09577eca.js.gz b/js/app.09577eca.js.gz deleted file mode 100644 index 8f694a8..0000000 Binary files a/js/app.09577eca.js.gz and /dev/null differ diff --git a/js/app.09577eca.js.map.gz b/js/app.09577eca.js.map.gz deleted file mode 100644 index 6bf5470..0000000 Binary files a/js/app.09577eca.js.map.gz and /dev/null differ diff --git a/js/app.09577eca.js b/js/app.f4ce2fc3.js similarity index 57% rename from js/app.09577eca.js rename to js/app.f4ce2fc3.js index 191d5e7..e0ef19a 100644 --- a/js/app.09577eca.js +++ b/js/app.f4ce2fc3.js @@ -1,2 +1,2 @@ -(function(){"use strict";var e={457:function(e,t,o){o(4114);var n=o(4373),r=o(4570),a=o.n(r),s=o(6915),i=o(1219);const l=n.A.create({baseURL:"/"});l.interceptors.request.use(e=>{if(e.withAuthCode){const t=a().get("authCode");t&&(e.headers["authCode"]=t)}return e},e=>Promise.reject(e)),l.interceptors.response.use(e=>e,e=>(e.config?.withAuthCode&&401===e.response?.status&&(i.nk.error("认证失败,请重新登录!"),s.A.push("/login")),Promise.reject(e))),t.A=l},2885:function(e,t,o){o(8111),o(7588);var n=o(5130),r=o(3888),a=o(4068),s=(o(9436),o(372),o(8950)),i=o(2353),l=o(292),c=o(6768);function u(e,t,o,n,r,a){const s=(0,c.g2)("router-view");return(0,c.uX)(),(0,c.Wv)(s)}var d=o(8401),m=o(3785),p={data(){return{osInstance:null,imageViewerObserver:null}},computed:{...(0,d.L8)(["userConfig","useDarkMode"])},mounted(){this.$nextTick(()=>{this.initOverlayScrollbars(),this.setupImageViewerObserver()})},beforeUnmount(){this.imageViewerObserver&&this.imageViewerObserver.disconnect()},watch:{useDarkMode(){this.setSiteIcon()}},methods:{initOverlayScrollbars(){try{if(m.ae.valid(document.body))return void(this.osInstance=(0,m.ae)(document.body));this.osInstance=(0,m.ae)(document.body,{scrollbars:{theme:"os-theme-dark",visibility:"auto",autoHide:"scroll",autoHideDelay:600,dragScroll:!0,clickScroll:!0},overflow:{x:"hidden",y:"scroll"}}),console.log("OverlayScrollbars initialized successfully")}catch(e){console.error("Failed to initialize OverlayScrollbars:",e)}},setupImageViewerObserver(){this.imageViewerObserver=new MutationObserver(e=>{const t=document.querySelector(".el-image-viewer__wrapper");t?this.osInstance&&this.osInstance.options({overflow:{x:"hidden",y:"hidden"}}):this.osInstance&&this.osInstance.options({overflow:{x:"hidden",y:"scroll"}})}),this.imageViewerObserver.observe(document.body,{childList:!0,subtree:!0})},setSiteIcon(){const e=document.querySelectorAll('link[rel="icon"], link[rel="apple-touch-icon"], link[rel="mask-icon"]');e.forEach(e=>e.remove());const t=document.createElement("link"),o=document.createElement("link"),n=document.createElement("link");t.rel="icon",o.rel="apple-touch-icon",n.rel="mask-icon",this.useDarkMode?(t.href=this.userConfig?.siteIcon||"/logo-dark.png",o.href=this.userConfig?.siteIcon||"/logo-dark.png",n.href=this.userConfig?.siteIcon||"/logo-dark.png"):(t.href=this.userConfig?.siteIcon||"/logo.png",o.href=this.userConfig?.siteIcon||"/logo.png",n.href=this.userConfig?.siteIcon||"/logo.png"),document.head.appendChild(t),document.head.appendChild(o),document.head.appendChild(n)}}},f=o(1241);const h=(0,f.A)(p,[["render",u]]);var g=h,b=o(6915),v=o(5507),y=o(7477);o(1862),o(635);s.Yv.add(i.X7I);const C=(0,n.Ef)(g),k=(0,r.Zf)();C.component("font-awesome-icon",l.gc);for(const[M,E]of Object.entries(y))C.component(M,E);const A=()=>{const e=document.documentElement;let t;if(v.A.state.cusDarkMode&&null!==v.A.state.useDarkMode)t=v.A.state.useDarkMode;else{if(t=window.matchMedia("(prefers-color-scheme: dark)").matches,!t){const e=new Date,o=e.getHours();t=o>=22||o<6}v.A.commit("setUseDarkMode",t)}t?e.classList.add("dark"):e.classList.remove("dark")},w=e=>{const t=document.documentElement;e?t.classList.add("dark"):t.classList.remove("dark")},U=e=>{document.title=e?.siteTitle||"Sanyue ImgHub"},S=(e,t)=>{const o=document.querySelectorAll('link[rel="icon"], link[rel="apple-touch-icon"], link[rel="mask-icon"]');o.forEach(e=>e.remove());const n=document.createElement("link"),r=document.createElement("link"),a=document.createElement("link");n.rel="icon",r.rel="apple-touch-icon",a.rel="mask-icon",e?(n.href=t?.siteIcon||"/logo-dark.png",r.href=t?.siteIcon||"/logo-dark.png",a.href=t?.siteIcon||"/logo-dark.png"):(n.href=t?.siteIcon||"/logo.png",r.href=t?.siteIcon||"/logo.png",a.href=t?.siteIcon||"/logo.png"),document.head.appendChild(n),document.head.appendChild(r),document.head.appendChild(a)};v.A.dispatch("fetchUserConfig").then(()=>{A(),U(v.A.getters.userConfig),S(v.A.state.useDarkMode,v.A.getters.userConfig),v.A.subscribe((e,t)=>{"setUseDarkMode"===e.type&&v.A.state.cusDarkMode&&(w(t.useDarkMode),S(t.useDarkMode,v.A.getters.userConfig)),"setCusDarkMode"!==e.type||e.payload||(A(),S(v.A.state.useDarkMode,v.A.getters.userConfig))}),C.use(v.A).use(b.A).use(a.A).mount("#app")}).catch(e=>{console.error("Failed to load user configuration:",e),C.use(v.A).use(b.A).use(a.A).use(k).mount("#app")})},5507:function(e,t,o){o(8111),o(1701);var n=o(8401),r=o(457),a=o(5131);t.A=(0,n.y$)({state:{userConfig:null,bingWallPapers:[],credentials:null,uploadMethod:"default",uploadCopyUrlForm:"",compressConfig:{customerCompress:void 0,compressQuality:void 0,compressBar:void 0,serverCompress:void 0,convertToWebp:void 0},storeUploadChannel:"",storeChannelName:null,storeAutoRetry:!0,storeUploadNameType:"",uploadFolder:"",customUrlSettings:{useCustomUrl:"false",customUrlPrefix:""},adminUrlSettings:{useCustomUrl:"false",customUrlPrefix:""},autoReUpload:!0,useDarkMode:null,cusDarkMode:!1},getters:{userConfig:e=>e.userConfig,bingWallPapers:e=>e.bingWallPapers,credentials:e=>e.credentials,storeUploadMethod:e=>e.uploadMethod,uploadCopyUrlForm:e=>e.uploadCopyUrlForm,compressConfig:e=>e.compressConfig,storeUploadChannel:e=>e.storeUploadChannel,storeChannelName:e=>e.storeChannelName,storeUploadNameType:e=>e.storeUploadNameType,customUrlSettings:e=>e.customUrlSettings,storeAutoRetry:e=>e.storeAutoRetry,adminUrlSettings:e=>e.adminUrlSettings,storeUploadFolder:e=>e.uploadFolder||localStorage.getItem("uploadFolder")||"",useDarkMode:e=>e.useDarkMode,cusDarkMode:e=>e.cusDarkMode,storeAutoReUpload:e=>e.autoReUpload},mutations:{setUserConfig(e,t){e.userConfig=t},setBingWallPapers(e,t){e.bingWallPapers=t},setCredentials(e,t){e.credentials=t},setUploadMethod(e,t){e.uploadMethod=t},setUploadCopyUrlForm(e,t){e.uploadCopyUrlForm=t},setCompressConfig(e,{key:t,value:o}){e.compressConfig[t]=o},setStoreUploadChannel(e,t){e.storeUploadChannel=t},setStoreChannelName(e,t){e.storeChannelName=t},setStoreUploadNameType(e,t){e.storeUploadNameType=t},setCustomUrlSettings(e,{key:t,value:o}){e.customUrlSettings[t]=o},setStoreAutoRetry(e,t){e.storeAutoRetry=t},setAdminUrlSettings(e,{key:t,value:o}){e.adminUrlSettings[t]=o},setUseDarkMode(e,t){e.useDarkMode=t},setCusDarkMode(e,t){e.cusDarkMode=t},setStoreUploadFolder(e,t){e.uploadFolder=t,localStorage.setItem("uploadFolder",t)},setStoreAutoReUpload(e,t){e.autoReUpload=t}},actions:{async fetchUserConfig({commit:e}){try{const t=await r.A.get("/api/userConfig");e("setUserConfig",t.data)}catch(t){console.log(t)}},async fetchBingWallPapers({commit:e}){try{const t=await r.A.get("/api/bing/wallpaper"),o=t.data.data,n=o.map(e=>({url:"https://www.bing.com"+e.url}));await Promise.all(n.map(e=>new Promise((t,o)=>{const n=new Image;n.onload=t,n.onerror=o,n.src=e.url}))),e("setBingWallPapers",n)}catch(t){console.log(t)}}},modules:{},plugins:[(0,a.A)()]})},6915:function(e,t,o){o(4979);var n=o(8512),r=o(1219),a=o(4570),s=o.n(a),i=o(5507),l=o(457);const c=(e,t,o)=>{const n=i.A.getters.credentials;if(null===n&&"adminLogin"!==e.name){const e=btoa("unset:unset");l.A.get("/api/manage/check",{headers:{Authorization:"Basic "+e},withCredentials:!0}).then(t=>{if(200!==t.status)throw new Error("认证失败!");i.A.commit("setCredentials",e),o()}).catch(e=>{r.nk.error("请先认证!"),o({name:"adminLogin"})})}else o()},u=(e,t,o)=>{let n=s().get("authCode");null===n&&"login"!==e.name?l.A.post("/api/login",{authCode:"unset"}).then(e=>{if(200!==e.status)throw new Error("认证失败!");s().set("authCode","unset","14d"),n="unset",o()}).catch(e=>{r.nk.error("请先认证!"),o({name:"login"})}):o()},d=[{path:"/",name:"home",component:()=>Promise.all([o.e(275),o.e(600),o.e(23)]).then(o.bind(o,9811)),beforeEnter:u},{path:"/login",name:"login",component:()=>Promise.all([o.e(600),o.e(100)]).then(o.bind(o,2560))},{path:"/dashboard",name:"dashboard",component:()=>Promise.all([o.e(275),o.e(456),o.e(488)]).then(o.bind(o,4280)),beforeEnter:c},{path:"/customerConfig",name:"customerConfig",component:()=>Promise.all([o.e(275),o.e(456),o.e(119),o.e(419)]).then(o.bind(o,8419)),beforeEnter:c},{path:"/systemConfig",name:"systemConfig",component:()=>Promise.all([o.e(275),o.e(456),o.e(119),o.e(226)]).then(o.bind(o,5226)),beforeEnter:c},{path:"/adminLogin",name:"adminLogin",component:()=>Promise.all([o.e(600),o.e(214)]).then(o.bind(o,3950))},{path:"/blockimg",name:"blockimg",component:()=>o.e(917).then(o.bind(o,4917))},{path:"/whiteliston",name:"whiteliston",component:()=>o.e(988).then(o.bind(o,7226))},{path:"/browse/:dir*",name:"publicBrowse",component:()=>o.e(667).then(o.bind(o,9667))},{path:"/:pathMatch(.*)*",name:"notFound",component:()=>o.e(845).then(o.bind(o,8226))}],m=(0,n.aE)({history:(0,n.LA)("/"),routes:d});t.A=m}},t={};function o(n){var r=t[n];if(void 0!==r)return r.exports;var a=t[n]={exports:{}};return e[n].call(a.exports,a,a.exports,o),a.exports}o.m=e,function(){var e=[];o.O=function(t,n,r,a){if(!n){var s=1/0;for(u=0;u=a)&&Object.keys(o.O).every(function(e){return o.O[e](n[l])})?n.splice(l--,1):(i=!1,a0&&e[u-1][2]>a;u--)e[u]=e[u-1];e[u]=[n,r,a]}}(),function(){o.n=function(e){var t=e&&e.__esModule?function(){return e["default"]}:function(){return e};return o.d(t,{a:t}),t}}(),function(){o.d=function(e,t){for(var n in t)o.o(t,n)&&!o.o(e,n)&&Object.defineProperty(e,n,{enumerable:!0,get:t[n]})}}(),function(){o.f={},o.e=function(e){return Promise.all(Object.keys(o.f).reduce(function(t,n){return o.f[n](e,t),t},[]))}}(),function(){o.u=function(e){return"js/"+e+"."+{23:"180d02c4",100:"d7a2e066",214:"e7ecaacc",226:"478c43ad",419:"714823b1",456:"bfb68f0d",488:"c52f99c6",600:"3d796c41",667:"bbd60d43",845:"97c9b302",917:"833cbf86",988:"c78ed6a8"}[e]+".js"}}(),function(){o.miniCssF=function(e){return"css/"+e+"."+{23:"e63939dd",100:"07b87787",119:"2a856832",214:"07b87787",226:"a32a5829",275:"bf4b380e",419:"605c1f2d",488:"085a2879",667:"a3c83e09",845:"6548e7b4",917:"8529ad1e",988:"6b45e8e3"}[e]+".css"}}(),function(){o.g=function(){if("object"===typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"===typeof window)return window}}()}(),function(){o.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)}}(),function(){var e={},t="sanyue_imghub:";o.l=function(n,r,a,s){if(e[n])e[n].push(r);else{var i,l;if(void 0!==a)for(var c=document.getElementsByTagName("script"),u=0;u{if(e.withAuthCode){const t=a().get("authCode");t&&(e.headers["authCode"]=t)}return e},e=>Promise.reject(e)),l.interceptors.response.use(e=>e,e=>(e.config?.withAuthCode&&401===e.response?.status&&(i.nk.error("认证失败,请重新登录!"),s.A.push("/login")),Promise.reject(e))),t.A=l},2885:function(e,t,o){o(8111),o(7588);var n=o(5130),r=o(3888),a=o(4068),s=(o(5412),o(372),o(8950)),i=o(2353),l=o(292),c=o(6768);function u(e,t,o,n,r,a){const s=(0,c.g2)("router-view");return(0,c.uX)(),(0,c.Wv)(s)}var d=o(8401),m=o(3785),p={data(){return{osInstance:null,imageViewerObserver:null}},computed:{...(0,d.L8)(["userConfig","useDarkMode"])},mounted(){this.$nextTick(()=>{this.initOverlayScrollbars(),this.setupImageViewerObserver()})},beforeUnmount(){this.imageViewerObserver&&this.imageViewerObserver.disconnect()},watch:{useDarkMode(){this.setSiteIcon()}},methods:{initOverlayScrollbars(){try{if(m.ae.valid(document.body))return void(this.osInstance=(0,m.ae)(document.body));this.osInstance=(0,m.ae)(document.body,{scrollbars:{theme:"os-theme-dark",visibility:"auto",autoHide:"scroll",autoHideDelay:600,dragScroll:!0,clickScroll:!0},overflow:{x:"hidden",y:"scroll"}}),console.log("OverlayScrollbars initialized successfully")}catch(e){console.error("Failed to initialize OverlayScrollbars:",e)}},setupImageViewerObserver(){this.imageViewerObserver=new MutationObserver(e=>{const t=document.querySelector(".el-image-viewer__wrapper");t?this.osInstance&&this.osInstance.options({overflow:{x:"hidden",y:"hidden"}}):this.osInstance&&this.osInstance.options({overflow:{x:"hidden",y:"scroll"}})}),this.imageViewerObserver.observe(document.body,{childList:!0,subtree:!0})},setSiteIcon(){const e=document.querySelectorAll('link[rel="icon"], link[rel="apple-touch-icon"], link[rel="mask-icon"]');e.forEach(e=>e.remove());const t=document.createElement("link"),o=document.createElement("link"),n=document.createElement("link");t.rel="icon",o.rel="apple-touch-icon",n.rel="mask-icon",this.useDarkMode?(t.href=this.userConfig?.siteIcon||"/logo-dark.png",o.href=this.userConfig?.siteIcon||"/logo-dark.png",n.href=this.userConfig?.siteIcon||"/logo-dark.png"):(t.href=this.userConfig?.siteIcon||"/logo.png",o.href=this.userConfig?.siteIcon||"/logo.png",n.href=this.userConfig?.siteIcon||"/logo.png"),document.head.appendChild(t),document.head.appendChild(o),document.head.appendChild(n)}}},f=o(1241);const h=(0,f.A)(p,[["render",u]]);var g=h,b=o(6915),v=o(5507),y=o(7477);o(1862),o(635);s.Yv.add(i.X7I);const C=(0,n.Ef)(g),k=(0,r.Zf)();C.component("font-awesome-icon",l.gc);for(const[M,E]of Object.entries(y))C.component(M,E);const A=()=>{const e=document.documentElement;let t;if(v.A.state.cusDarkMode&&null!==v.A.state.useDarkMode)t=v.A.state.useDarkMode;else{if(t=window.matchMedia("(prefers-color-scheme: dark)").matches,!t){const e=new Date,o=e.getHours();t=o>=22||o<6}v.A.commit("setUseDarkMode",t)}t?e.classList.add("dark"):e.classList.remove("dark")},w=e=>{const t=document.documentElement;e?t.classList.add("dark"):t.classList.remove("dark")},U=e=>{document.title=e?.siteTitle||"Sanyue ImgHub"},S=(e,t)=>{const o=document.querySelectorAll('link[rel="icon"], link[rel="apple-touch-icon"], link[rel="mask-icon"]');o.forEach(e=>e.remove());const n=document.createElement("link"),r=document.createElement("link"),a=document.createElement("link");n.rel="icon",r.rel="apple-touch-icon",a.rel="mask-icon",e?(n.href=t?.siteIcon||"/logo-dark.png",r.href=t?.siteIcon||"/logo-dark.png",a.href=t?.siteIcon||"/logo-dark.png"):(n.href=t?.siteIcon||"/logo.png",r.href=t?.siteIcon||"/logo.png",a.href=t?.siteIcon||"/logo.png"),document.head.appendChild(n),document.head.appendChild(r),document.head.appendChild(a)};v.A.dispatch("fetchUserConfig").then(()=>{A(),U(v.A.getters.userConfig),S(v.A.state.useDarkMode,v.A.getters.userConfig),v.A.subscribe((e,t)=>{"setUseDarkMode"===e.type&&v.A.state.cusDarkMode&&(w(t.useDarkMode),S(t.useDarkMode,v.A.getters.userConfig)),"setCusDarkMode"!==e.type||e.payload||(A(),S(v.A.state.useDarkMode,v.A.getters.userConfig))}),C.use(v.A).use(b.A).use(a.A).mount("#app")}).catch(e=>{console.error("Failed to load user configuration:",e),C.use(v.A).use(b.A).use(a.A).use(k).mount("#app")})},5507:function(e,t,o){o(8111),o(1701);var n=o(8401),r=o(457),a=o(5131);t.A=(0,n.y$)({state:{userConfig:null,bingWallPapers:[],credentials:null,uploadMethod:"default",uploadCopyUrlForm:"",compressConfig:{customerCompress:void 0,compressQuality:void 0,compressBar:void 0,serverCompress:void 0,convertToWebp:void 0},storeUploadChannel:"",storeChannelName:null,storeAutoRetry:!0,storeUploadNameType:"",uploadFolder:"",customUrlSettings:{useCustomUrl:"false",customUrlPrefix:""},adminUrlSettings:{useCustomUrl:"false",customUrlPrefix:""},autoReUpload:!0,useDarkMode:null,cusDarkMode:!1},getters:{userConfig:e=>e.userConfig,bingWallPapers:e=>e.bingWallPapers,credentials:e=>e.credentials,storeUploadMethod:e=>e.uploadMethod,uploadCopyUrlForm:e=>e.uploadCopyUrlForm,compressConfig:e=>e.compressConfig,storeUploadChannel:e=>e.storeUploadChannel,storeChannelName:e=>e.storeChannelName,storeUploadNameType:e=>e.storeUploadNameType,customUrlSettings:e=>e.customUrlSettings,storeAutoRetry:e=>e.storeAutoRetry,adminUrlSettings:e=>e.adminUrlSettings,storeUploadFolder:e=>e.uploadFolder||localStorage.getItem("uploadFolder")||"",useDarkMode:e=>e.useDarkMode,cusDarkMode:e=>e.cusDarkMode,storeAutoReUpload:e=>e.autoReUpload},mutations:{setUserConfig(e,t){e.userConfig=t},setBingWallPapers(e,t){e.bingWallPapers=t},setCredentials(e,t){e.credentials=t},setUploadMethod(e,t){e.uploadMethod=t},setUploadCopyUrlForm(e,t){e.uploadCopyUrlForm=t},setCompressConfig(e,{key:t,value:o}){e.compressConfig[t]=o},setStoreUploadChannel(e,t){e.storeUploadChannel=t},setStoreChannelName(e,t){e.storeChannelName=t},setStoreUploadNameType(e,t){e.storeUploadNameType=t},setCustomUrlSettings(e,{key:t,value:o}){e.customUrlSettings[t]=o},setStoreAutoRetry(e,t){e.storeAutoRetry=t},setAdminUrlSettings(e,{key:t,value:o}){e.adminUrlSettings[t]=o},setUseDarkMode(e,t){e.useDarkMode=t},setCusDarkMode(e,t){e.cusDarkMode=t},setStoreUploadFolder(e,t){e.uploadFolder=t,localStorage.setItem("uploadFolder",t)},setStoreAutoReUpload(e,t){e.autoReUpload=t}},actions:{async fetchUserConfig({commit:e}){try{const t=await r.A.get("/api/userConfig");e("setUserConfig",t.data)}catch(t){console.log(t)}},async fetchBingWallPapers({commit:e}){try{const t=await r.A.get("/api/bing/wallpaper"),o=t.data.data,n=o.map(e=>({url:"https://www.bing.com"+e.url}));await Promise.all(n.map(e=>new Promise((t,o)=>{const n=new Image;n.onload=t,n.onerror=o,n.src=e.url}))),e("setBingWallPapers",n)}catch(t){console.log(t)}}},modules:{},plugins:[(0,a.A)()]})},6915:function(e,t,o){o(4979);var n=o(8512),r=o(1219),a=o(4570),s=o.n(a),i=o(5507),l=o(457);const c=(e,t,o)=>{const n=i.A.getters.credentials;if(null===n&&"adminLogin"!==e.name){const e=btoa("unset:unset");l.A.get("/api/manage/check",{headers:{Authorization:"Basic "+e},withCredentials:!0}).then(t=>{if(200!==t.status)throw new Error("认证失败!");i.A.commit("setCredentials",e),o()}).catch(e=>{r.nk.error("请先认证!"),o({name:"adminLogin"})})}else o()},u=(e,t,o)=>{let n=s().get("authCode");null===n&&"login"!==e.name?l.A.post("/api/login",{authCode:"unset"}).then(e=>{if(200!==e.status)throw new Error("认证失败!");s().set("authCode","unset","14d"),n="unset",o()}).catch(e=>{r.nk.error("请先认证!"),o({name:"login"})}):o()},d=[{path:"/",name:"home",component:()=>Promise.all([o.e(275),o.e(600),o.e(23)]).then(o.bind(o,9811)),beforeEnter:u},{path:"/login",name:"login",component:()=>Promise.all([o.e(600),o.e(100)]).then(o.bind(o,2560))},{path:"/dashboard",name:"dashboard",component:()=>Promise.all([o.e(275),o.e(456),o.e(743)]).then(o.bind(o,35)),beforeEnter:c},{path:"/customerConfig",name:"customerConfig",component:()=>Promise.all([o.e(275),o.e(456),o.e(119),o.e(419)]).then(o.bind(o,8419)),beforeEnter:c},{path:"/systemConfig",name:"systemConfig",component:()=>Promise.all([o.e(275),o.e(456),o.e(119),o.e(407)]).then(o.bind(o,6407)),beforeEnter:c},{path:"/adminLogin",name:"adminLogin",component:()=>Promise.all([o.e(600),o.e(214)]).then(o.bind(o,3950))},{path:"/blockimg",name:"blockimg",component:()=>o.e(917).then(o.bind(o,4917))},{path:"/whiteliston",name:"whiteliston",component:()=>o.e(845).then(o.bind(o,7226))},{path:"/browse/:dir*",name:"publicBrowse",component:()=>o.e(667).then(o.bind(o,9667))},{path:"/:pathMatch(.*)*",name:"notFound",component:()=>o.e(226).then(o.bind(o,8226))}],m=(0,n.aE)({history:(0,n.LA)("/"),routes:d});t.A=m}},t={};function o(n){var r=t[n];if(void 0!==r)return r.exports;var a=t[n]={exports:{}};return e[n].call(a.exports,a,a.exports,o),a.exports}o.m=e,function(){var e=[];o.O=function(t,n,r,a){if(!n){var s=1/0;for(u=0;u=a)&&Object.keys(o.O).every(function(e){return o.O[e](n[l])})?n.splice(l--,1):(i=!1,a0&&e[u-1][2]>a;u--)e[u]=e[u-1];e[u]=[n,r,a]}}(),function(){o.n=function(e){var t=e&&e.__esModule?function(){return e["default"]}:function(){return e};return o.d(t,{a:t}),t}}(),function(){o.d=function(e,t){for(var n in t)o.o(t,n)&&!o.o(e,n)&&Object.defineProperty(e,n,{enumerable:!0,get:t[n]})}}(),function(){o.f={},o.e=function(e){return Promise.all(Object.keys(o.f).reduce(function(t,n){return o.f[n](e,t),t},[]))}}(),function(){o.u=function(e){return"js/"+e+"."+{23:"180d02c4",100:"d7a2e066",214:"e7ecaacc",226:"f737e39a",407:"f0b5dee5",419:"714823b1",456:"bfb68f0d",600:"3d796c41",667:"bbd60d43",743:"5066c4a0",845:"1bb9a557",917:"833cbf86"}[e]+".js"}}(),function(){o.miniCssF=function(e){return"css/"+e+"."+{23:"e63939dd",100:"07b87787",119:"2a856832",214:"07b87787",226:"6548e7b4",275:"bf4b380e",407:"a32a5829",419:"605c1f2d",667:"a3c83e09",743:"ab3d1775",845:"6b45e8e3",917:"8529ad1e"}[e]+".css"}}(),function(){o.g=function(){if("object"===typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"===typeof window)return window}}()}(),function(){o.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)}}(),function(){var e={},t="sanyue_imghub:";o.l=function(n,r,a,s){if(e[n])e[n].push(r);else{var i,l;if(void 0!==a)for(var c=document.getElementsByTagName("script"),u=0;u {\r\n // 如果配置中标记了withAuthCode,则添加authCode到header\r\n if (config.withAuthCode) {\r\n const authCode = cookies.get('authCode');\r\n if (authCode) {\r\n config.headers['authCode'] = authCode;\r\n }\r\n }\r\n return config;\r\n },\r\n (error) => {\r\n return Promise.reject(error);\r\n }\r\n);\r\n\r\n// 响应拦截器\r\ninstance.interceptors.response.use(\r\n (response) => {\r\n return response;\r\n },\r\n (error) => {\r\n // 如果请求配置了withAuthCode且返回401,则跳转到登录页\r\n if (error.config?.withAuthCode && error.response?.status === 401) {\r\n ElMessage.error('认证失败,请重新登录!');\r\n router.push('/login');\r\n }\r\n return Promise.reject(error);\r\n }\r\n);\r\n\r\nexport default instance;\r\n","import { resolveComponent as _resolveComponent, openBlock as _openBlock, createBlock as _createBlock } from \"vue\";\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_router_view = _resolveComponent(\"router-view\");\n return _openBlock(), _createBlock(_component_router_view);\n}","import \"core-js/modules/es.iterator.constructor.js\";\nimport \"core-js/modules/es.iterator.for-each.js\";\nimport { mapGetters } from 'vuex';\nimport { OverlayScrollbars } from 'overlayscrollbars';\nexport default {\n data() {\n return {\n osInstance: null,\n imageViewerObserver: null\n };\n },\n computed: {\n ...mapGetters(['userConfig', 'useDarkMode'])\n },\n mounted() {\n // 初始化 OverlayScrollbars 悬浮滚动条\n this.$nextTick(() => {\n this.initOverlayScrollbars();\n this.setupImageViewerObserver();\n });\n },\n beforeUnmount() {\n // 清理 MutationObserver\n if (this.imageViewerObserver) {\n this.imageViewerObserver.disconnect();\n }\n },\n watch: {\n useDarkMode() {\n this.setSiteIcon();\n }\n },\n methods: {\n initOverlayScrollbars() {\n try {\n // 检查是否已经初始化\n if (OverlayScrollbars.valid(document.body)) {\n this.osInstance = OverlayScrollbars(document.body);\n return;\n }\n\n // 应用到 body 实现全局悬浮滚动条\n this.osInstance = OverlayScrollbars(document.body, {\n scrollbars: {\n theme: 'os-theme-dark',\n visibility: 'auto',\n autoHide: 'scroll',\n autoHideDelay: 600,\n dragScroll: true,\n clickScroll: true\n },\n overflow: {\n x: 'hidden',\n y: 'scroll'\n }\n });\n console.log('OverlayScrollbars initialized successfully');\n } catch (error) {\n console.error('Failed to initialize OverlayScrollbars:', error);\n }\n },\n setupImageViewerObserver() {\n // 监听图片预览器的打开/关闭,动态控制 OverlayScrollbars\n this.imageViewerObserver = new MutationObserver(mutations => {\n const imageViewer = document.querySelector('.el-image-viewer__wrapper');\n if (imageViewer) {\n // 图片预览器打开,禁用滚动\n if (this.osInstance) {\n this.osInstance.options({\n overflow: {\n x: 'hidden',\n y: 'hidden'\n }\n });\n }\n } else {\n // 图片预览器关闭,恢复滚动\n if (this.osInstance) {\n this.osInstance.options({\n overflow: {\n x: 'hidden',\n y: 'scroll'\n }\n });\n }\n }\n });\n this.imageViewerObserver.observe(document.body, {\n childList: true,\n subtree: true\n });\n },\n setSiteIcon() {\n // 同时更改 icon apple-touch-icon 和 mask-icon\n const existingIcons = document.querySelectorAll('link[rel=\"icon\"], link[rel=\"apple-touch-icon\"], link[rel=\"mask-icon\"]');\n existingIcons.forEach(icon => icon.remove());\n const iconLink = document.createElement('link');\n const appleIconLink = document.createElement('link');\n const maskIconLink = document.createElement('link');\n iconLink.rel = 'icon';\n appleIconLink.rel = 'apple-touch-icon';\n maskIconLink.rel = 'mask-icon';\n if (this.useDarkMode) {\n iconLink.href = this.userConfig?.siteIcon || '/logo-dark.png';\n appleIconLink.href = this.userConfig?.siteIcon || '/logo-dark.png';\n maskIconLink.href = this.userConfig?.siteIcon || '/logo-dark.png';\n } else {\n iconLink.href = this.userConfig?.siteIcon || '/logo.png';\n appleIconLink.href = this.userConfig?.siteIcon || '/logo.png';\n maskIconLink.href = this.userConfig?.siteIcon || '/logo.png';\n }\n document.head.appendChild(iconLink);\n document.head.appendChild(appleIconLink);\n document.head.appendChild(maskIconLink);\n }\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./App.vue?vue&type=template&id=7df82a17\"\nimport script from \"./App.vue?vue&type=script&lang=js\"\nexport * from \"./App.vue?vue&type=script&lang=js\"\n\nimport exportComponent from \"../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render]])\n\nexport default __exports__","import { createApp } from 'vue'\r\nimport { createHead } from '@vueuse/head'; // 导入 createHead\r\nimport ElementPlus from 'element-plus'\r\nimport 'element-plus/es/components/message/style/css'\r\nimport 'element-plus/es/components/message-box/style/css'\r\n\r\nimport { library } from '@fortawesome/fontawesome-svg-core';\r\nimport { fas } from '@fortawesome/free-solid-svg-icons'; // 引入所有 solid 图标\r\nimport { FontAwesomeIcon } from '@fortawesome/vue-fontawesome';\r\n\r\nimport App from './App.vue'\r\nimport router from './router'\r\nimport store from './store'\r\n\r\nimport * as ElementPlusIconsVue from '@element-plus/icons-vue'\r\nimport 'element-plus/theme-chalk/dark/css-vars.css'\r\nimport './styles/global.css'\r\n\r\n// OverlayScrollbars 悬浮滚动条\r\nimport 'overlayscrollbars/overlayscrollbars.css'\r\n\r\n\r\nlibrary.add(fas);\r\n\r\nconst app = createApp(App);\r\nconst head = createHead(); // 创建 head 对象\r\n\r\napp.component('font-awesome-icon', FontAwesomeIcon);\r\nfor (const [key, component] of Object.entries(ElementPlusIconsVue)) {\r\n app.component(key, component)\r\n}\r\n\r\n// 根据 useDarkMode 的值添加或移除 dark 类\r\nconst initDarkModeClass = () => {\r\n const htmlElement = document.documentElement;\r\n let isDarkMode;\r\n\r\n // 判断用户是否是自定义模式\r\n if (store.state.cusDarkMode && store.state.useDarkMode !== null) {\r\n // 用户手动设置了暗色模式\r\n isDarkMode = store.state.useDarkMode;\r\n } else {\r\n // 跟随系统模式或时间\r\n isDarkMode = window.matchMedia('(prefers-color-scheme: dark)').matches;\r\n if (!isDarkMode) {\r\n const now = new Date();\r\n const hour = now.getHours();\r\n isDarkMode = hour >= 22 || hour < 6;\r\n }\r\n // 更新 useDarkMode 的值\r\n store.commit('setUseDarkMode', isDarkMode);\r\n }\r\n\r\n if (isDarkMode) {\r\n htmlElement.classList.add('dark');\r\n } else {\r\n htmlElement.classList.remove('dark');\r\n }\r\n};\r\n\r\nconst applyDarkModeClass = (isDarkMode) => {\r\n const htmlElement = document.documentElement;\r\n if (isDarkMode) {\r\n htmlElement.classList.add('dark');\r\n } else {\r\n htmlElement.classList.remove('dark');\r\n }\r\n};\r\n\r\n// 预设网站标题的函数\r\nconst presetSiteTitle = (userConfig) => {\r\n document.title = userConfig?.siteTitle || 'Sanyue ImgHub';\r\n};\r\n\r\n// 预设网站图标的函数\r\nconst presetSiteIcon = (isDarkMode, userConfig) => {\r\n // 同时更改 icon apple-touch-icon 和 mask-icon\r\n const existingIcons = document.querySelectorAll('link[rel=\"icon\"], link[rel=\"apple-touch-icon\"], link[rel=\"mask-icon\"]');\r\n existingIcons.forEach(icon => icon.remove());\r\n\r\n const iconLink = document.createElement('link');\r\n const appleIconLink = document.createElement('link');\r\n const maskIconLink = document.createElement('link');\r\n iconLink.rel = 'icon';\r\n appleIconLink.rel = 'apple-touch-icon';\r\n maskIconLink.rel = 'mask-icon';\r\n\r\n if (isDarkMode) {\r\n iconLink.href = userConfig?.siteIcon || '/logo-dark.png';\r\n appleIconLink.href = userConfig?.siteIcon || '/logo-dark.png';\r\n maskIconLink.href = userConfig?.siteIcon || '/logo-dark.png';\r\n } else {\r\n iconLink.href = userConfig?.siteIcon || '/logo.png';\r\n appleIconLink.href = userConfig?.siteIcon || '/logo.png';\r\n maskIconLink.href = userConfig?.siteIcon || '/logo.png';\r\n }\r\n\r\n document.head.appendChild(iconLink);\r\n document.head.appendChild(appleIconLink);\r\n document.head.appendChild(maskIconLink);\r\n};\r\n\r\nstore.dispatch('fetchUserConfig').then(() => {\r\n // 初始化时应用 dark 模式\r\n initDarkModeClass();\r\n\r\n // 预设网站标题和图标\r\n presetSiteTitle(store.getters.userConfig);\r\n presetSiteIcon(store.state.useDarkMode, store.getters.userConfig);\r\n\r\n // 监听 useDarkMode 和 cusDarkMode 的变化\r\n store.subscribe((mutation, state) => {\r\n if (mutation.type === 'setUseDarkMode' && store.state.cusDarkMode) {\r\n applyDarkModeClass(state.useDarkMode);\r\n // 同时更新网站图标\r\n presetSiteIcon(state.useDarkMode, store.getters.userConfig);\r\n }\r\n\r\n // 监听 cusDarkMode 变化,当设置为 false 时重新初始化\r\n if (mutation.type === 'setCusDarkMode' && !mutation.payload) {\r\n // 切换到跟随系统模式,重新初始化\r\n initDarkModeClass();\r\n // 同时更新网站图标\r\n presetSiteIcon(store.state.useDarkMode, store.getters.userConfig);\r\n }\r\n });\r\n\r\n app.use(store).use(router).use(ElementPlus).mount('#app');\r\n}).catch(error => {\r\n console.error('Failed to load user configuration:', error);\r\n app.use(store).use(router).use(ElementPlus).use(head).mount('#app');\r\n})\r\n","import { createStore } from 'vuex'\r\nimport axios from '@/utils/axios';\r\nimport createPersistedState from 'vuex-persistedstate';\r\n\r\nexport default createStore({\r\n state: {\r\n userConfig: null,\r\n bingWallPapers: [],\r\n credentials: null,\r\n uploadMethod: 'default',\r\n uploadCopyUrlForm: '',\r\n compressConfig: {\r\n customerCompress: undefined,\r\n compressQuality: undefined,\r\n compressBar: undefined,\r\n serverCompress: undefined,\r\n convertToWebp: undefined,\r\n },\r\n storeUploadChannel: '',\r\n storeChannelName: null, // 指定的渠道名称,null表示从未选择,''表示用户主动清空\r\n storeAutoRetry: true,\r\n storeUploadNameType: '',\r\n uploadFolder: '',\r\n customUrlSettings: {\r\n useCustomUrl: 'false',\r\n customUrlPrefix: '',\r\n },\r\n adminUrlSettings: {\r\n useCustomUrl: 'false',\r\n customUrlPrefix: '',\r\n },\r\n autoReUpload: true,\r\n // 深色模式\r\n useDarkMode: null,\r\n cusDarkMode: false,\r\n },\r\n getters: {\r\n userConfig: state => state.userConfig,\r\n bingWallPapers: state => state.bingWallPapers,\r\n credentials: state => state.credentials,\r\n storeUploadMethod: state => state.uploadMethod,\r\n uploadCopyUrlForm: state => state.uploadCopyUrlForm,\r\n compressConfig: state => state.compressConfig,\r\n storeUploadChannel: state => state.storeUploadChannel,\r\n storeChannelName: state => state.storeChannelName,\r\n storeUploadNameType: state => state.storeUploadNameType,\r\n customUrlSettings: state => state.customUrlSettings,\r\n storeAutoRetry: state => state.storeAutoRetry,\r\n adminUrlSettings: state => state.adminUrlSettings,\r\n storeUploadFolder: (state) => {\r\n return state.uploadFolder || localStorage.getItem('uploadFolder') || ''\r\n },\r\n useDarkMode: state => state.useDarkMode,\r\n cusDarkMode: state => state.cusDarkMode,\r\n storeAutoReUpload: state => state.autoReUpload,\r\n },\r\n mutations: {\r\n setUserConfig(state, userConfig) {\r\n state.userConfig = userConfig;\r\n },\r\n setBingWallPapers(state, bingWallPapers) {\r\n state.bingWallPapers = bingWallPapers;\r\n },\r\n setCredentials(state, credentials) {\r\n state.credentials = credentials;\r\n },\r\n setUploadMethod(state, uploadMethod) {\r\n state.uploadMethod = uploadMethod;\r\n },\r\n setUploadCopyUrlForm(state, uploadCopyUrlForm) {\r\n state.uploadCopyUrlForm = uploadCopyUrlForm;\r\n },\r\n setCompressConfig(state, { key, value }) {\r\n state.compressConfig[key] = value;\r\n },\r\n setStoreUploadChannel(state, uploadChannel) {\r\n state.storeUploadChannel = uploadChannel;\r\n },\r\n setStoreChannelName(state, channelName) {\r\n state.storeChannelName = channelName;\r\n },\r\n setStoreUploadNameType(state, storeUploadNameType) {\r\n state.storeUploadNameType = storeUploadNameType;\r\n },\r\n setCustomUrlSettings(state, { key, value }) {\r\n state.customUrlSettings[key] = value;\r\n },\r\n setStoreAutoRetry(state, storeAutoRetry) {\r\n state.storeAutoRetry = storeAutoRetry;\r\n },\r\n setAdminUrlSettings(state, { key, value }) {\r\n state.adminUrlSettings[key] = value;\r\n },\r\n setUseDarkMode(state, useDarkMode) {\r\n state.useDarkMode = useDarkMode;\r\n },\r\n setCusDarkMode(state, cusDarkMode) {\r\n state.cusDarkMode = cusDarkMode;\r\n },\r\n setStoreUploadFolder(state, folder) {\r\n state.uploadFolder = folder\r\n localStorage.setItem('uploadFolder', folder)\r\n },\r\n setStoreAutoReUpload(state, autoReUpload) {\r\n state.autoReUpload = autoReUpload;\r\n }\r\n },\r\n actions: {\r\n async fetchUserConfig({ commit }) {\r\n try {\r\n const response = await axios.get('/api/userConfig');\r\n commit('setUserConfig', response.data);\r\n } catch (error) {\r\n console.log(error);\r\n }\r\n },\r\n async fetchBingWallPapers({ commit }) {\r\n try {\r\n const response = await axios.get('/api/bing/wallpaper');\r\n const wallpapers = response.data.data;\r\n const bingWallPapers = wallpapers.map(wallpaper => {\r\n return {\r\n url: 'https://www.bing.com' + wallpaper.url,\r\n };\r\n }\r\n );\r\n\r\n //预加载图片,阻塞直到图片加载完成\r\n await Promise.all(bingWallPapers.map(wallpaper => {\r\n return new Promise((resolve, reject) => {\r\n const img = new Image();\r\n img.onload = resolve;\r\n img.onerror = reject;\r\n img.src = wallpaper.url;\r\n });\r\n }));\r\n commit('setBingWallPapers', bingWallPapers);\r\n } catch (error) {\r\n console.log(error);\r\n }\r\n }\r\n },\r\n modules: {\r\n },\r\n plugins: [createPersistedState()]\r\n})\r\n","import { createRouter, createWebHistory } from 'vue-router'\r\nimport { ElMessage } from 'element-plus'\r\nimport cookies from 'vue-cookies'\r\nimport store from '../store'\r\nimport axios from '@/utils/axios'\r\n\r\n// 通用的管理员认证守卫\r\nconst adminAuthGuard = (to, from, next) => {\r\n // 从store中获取凭据\r\n const credentials = store.getters.credentials\r\n if (credentials === null && to.name !== 'adminLogin') {\r\n // 尝试未设置密码的情况\r\n const credentials = btoa('unset:unset')\r\n axios.get('/api/manage/check', {\r\n headers: {\r\n 'Authorization': 'Basic ' + credentials\r\n },\r\n withCredentials: true\r\n }).then(res => {\r\n if (res.status !== 200) {\r\n throw new Error('认证失败!')\r\n }\r\n store.commit('setCredentials', credentials)\r\n next()\r\n }).catch(err => {\r\n ElMessage.error('请先认证!')\r\n next({ name: 'adminLogin' })\r\n })\r\n } else {\r\n next()\r\n }\r\n}\r\n\r\n// 通用的用户认证守卫\r\nconst userAuthGuard = (to, from, next) => {\r\n let authCode = cookies.get('authCode');\r\n if (authCode === null && to.name !== 'login') {\r\n // 尝试未设置密码的情况\r\n axios.post('/api/login', {\r\n authCode: 'unset'\r\n }).then(res => {\r\n if (res.status !== 200) {\r\n throw new Error('认证失败!')\r\n }\r\n cookies.set('authCode', 'unset', '14d')\r\n authCode = 'unset'\r\n next()\r\n }).catch(err => {\r\n ElMessage.error('请先认证!')\r\n next({ name: 'login' })\r\n })\r\n } else {\r\n next()\r\n }\r\n}\r\n\r\nconst routes = [\r\n {\r\n path: '/',\r\n name: 'home',\r\n component: () => import('../views/UploadHome.vue'),\r\n beforeEnter: userAuthGuard\r\n },\r\n {\r\n path: '/login',\r\n name: 'login',\r\n component: () => import('../views/Login.vue')\r\n },\r\n {\r\n path: '/dashboard',\r\n name: 'dashboard',\r\n component: () => import('../views/AdminDashBoard.vue'),\r\n beforeEnter: adminAuthGuard\r\n },\r\n {\r\n path: '/customerConfig',\r\n name: 'customerConfig',\r\n component: () => import('../views/CustomerConfig.vue'),\r\n beforeEnter: adminAuthGuard\r\n },\r\n {\r\n path: '/systemConfig',\r\n name: 'systemConfig',\r\n component: () => import('../views/SystemConfig.vue'),\r\n beforeEnter: adminAuthGuard\r\n },\r\n {\r\n path: '/adminLogin',\r\n name: 'adminLogin',\r\n component: () => import('../views/AdminLogin.vue'),\r\n },\r\n {\r\n path: '/blockimg',\r\n name: 'blockimg',\r\n component: () => import('../views/BlockImage.vue'),\r\n },\r\n {\r\n path: '/whiteliston',\r\n name: 'whiteliston',\r\n component: () => import('../views/WhiteListOn.vue'),\r\n },\r\n {\r\n path: '/browse/:dir*',\r\n name: 'publicBrowse',\r\n component: () => import('../views/PublicBrowse.vue'),\r\n },\r\n {\r\n path: '/:pathMatch(.*)*',\r\n name: 'notFound',\r\n component: () => import('../views/NotFound.vue'),\r\n },\r\n]\r\n\r\nconst router = createRouter({\r\n history: createWebHistory(process.env.BASE_URL),\r\n routes\r\n})\r\n\r\nexport default router\r\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n// expose the modules object (__webpack_modules__)\n__webpack_require__.m = __webpack_modules__;\n\n","var deferred = [];\n__webpack_require__.O = function(result, chunkIds, fn, priority) {\n\tif(chunkIds) {\n\t\tpriority = priority || 0;\n\t\tfor(var i = deferred.length; i > 0 && deferred[i - 1][2] > priority; i--) deferred[i] = deferred[i - 1];\n\t\tdeferred[i] = [chunkIds, fn, priority];\n\t\treturn;\n\t}\n\tvar notFulfilled = Infinity;\n\tfor (var i = 0; i < deferred.length; i++) {\n\t\tvar chunkIds = deferred[i][0];\n\t\tvar fn = deferred[i][1];\n\t\tvar priority = deferred[i][2];\n\t\tvar fulfilled = true;\n\t\tfor (var j = 0; j < chunkIds.length; j++) {\n\t\t\tif ((priority & 1 === 0 || notFulfilled >= priority) && Object.keys(__webpack_require__.O).every(function(key) { return __webpack_require__.O[key](chunkIds[j]); })) {\n\t\t\t\tchunkIds.splice(j--, 1);\n\t\t\t} else {\n\t\t\t\tfulfilled = false;\n\t\t\t\tif(priority < notFulfilled) notFulfilled = priority;\n\t\t\t}\n\t\t}\n\t\tif(fulfilled) {\n\t\t\tdeferred.splice(i--, 1)\n\t\t\tvar r = fn();\n\t\t\tif (r !== undefined) result = r;\n\t\t}\n\t}\n\treturn result;\n};","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = function(module) {\n\tvar getter = module && module.__esModule ?\n\t\tfunction() { return module['default']; } :\n\t\tfunction() { return module; };\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = function(exports, definition) {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.f = {};\n// This file contains only the entry chunk.\n// The chunk loading function for additional chunks\n__webpack_require__.e = function(chunkId) {\n\treturn Promise.all(Object.keys(__webpack_require__.f).reduce(function(promises, key) {\n\t\t__webpack_require__.f[key](chunkId, promises);\n\t\treturn promises;\n\t}, []));\n};","// This function allow to reference async chunks\n__webpack_require__.u = function(chunkId) {\n\t// return url for filenames based on template\n\treturn \"js/\" + chunkId + \".\" + {\"23\":\"180d02c4\",\"100\":\"d7a2e066\",\"214\":\"e7ecaacc\",\"226\":\"478c43ad\",\"419\":\"714823b1\",\"456\":\"bfb68f0d\",\"488\":\"c52f99c6\",\"600\":\"3d796c41\",\"667\":\"bbd60d43\",\"845\":\"97c9b302\",\"917\":\"833cbf86\",\"988\":\"c78ed6a8\"}[chunkId] + \".js\";\n};","// This function allow to reference async chunks\n__webpack_require__.miniCssF = function(chunkId) {\n\t// return url for filenames based on template\n\treturn \"css/\" + chunkId + \".\" + {\"23\":\"e63939dd\",\"100\":\"07b87787\",\"119\":\"2a856832\",\"214\":\"07b87787\",\"226\":\"a32a5829\",\"275\":\"bf4b380e\",\"419\":\"605c1f2d\",\"488\":\"085a2879\",\"667\":\"a3c83e09\",\"845\":\"6548e7b4\",\"917\":\"8529ad1e\",\"988\":\"6b45e8e3\"}[chunkId] + \".css\";\n};","__webpack_require__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","__webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); }","var inProgress = {};\nvar dataWebpackPrefix = \"sanyue_imghub:\";\n// loadScript function to load a script via script tag\n__webpack_require__.l = function(url, done, key, chunkId) {\n\tif(inProgress[url]) { inProgress[url].push(done); return; }\n\tvar script, needAttach;\n\tif(key !== undefined) {\n\t\tvar scripts = document.getElementsByTagName(\"script\");\n\t\tfor(var i = 0; i < scripts.length; i++) {\n\t\t\tvar s = scripts[i];\n\t\t\tif(s.getAttribute(\"src\") == url || s.getAttribute(\"data-webpack\") == dataWebpackPrefix + key) { script = s; break; }\n\t\t}\n\t}\n\tif(!script) {\n\t\tneedAttach = true;\n\t\tscript = document.createElement('script');\n\n\t\tscript.charset = 'utf-8';\n\t\tif (__webpack_require__.nc) {\n\t\t\tscript.setAttribute(\"nonce\", __webpack_require__.nc);\n\t\t}\n\t\tscript.setAttribute(\"data-webpack\", dataWebpackPrefix + key);\n\n\t\tscript.src = url;\n\t}\n\tinProgress[url] = [done];\n\tvar onScriptComplete = function(prev, event) {\n\t\t// avoid mem leaks in IE.\n\t\tscript.onerror = script.onload = null;\n\t\tclearTimeout(timeout);\n\t\tvar doneFns = inProgress[url];\n\t\tdelete inProgress[url];\n\t\tscript.parentNode && script.parentNode.removeChild(script);\n\t\tdoneFns && doneFns.forEach(function(fn) { return fn(event); });\n\t\tif(prev) return prev(event);\n\t}\n\tvar timeout = setTimeout(onScriptComplete.bind(null, undefined, { type: 'timeout', target: script }), 120000);\n\tscript.onerror = onScriptComplete.bind(null, script.onerror);\n\tscript.onload = onScriptComplete.bind(null, script.onload);\n\tneedAttach && document.head.appendChild(script);\n};","// define __esModule on exports\n__webpack_require__.r = function(exports) {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","__webpack_require__.p = \"/\";","if (typeof document === \"undefined\") return;\nvar createStylesheet = function(chunkId, fullhref, oldTag, resolve, reject) {\n\tvar linkTag = document.createElement(\"link\");\n\n\tlinkTag.rel = \"stylesheet\";\n\tlinkTag.type = \"text/css\";\n\tif (__webpack_require__.nc) {\n\t\tlinkTag.nonce = __webpack_require__.nc;\n\t}\n\tvar onLinkComplete = function(event) {\n\t\t// avoid mem leaks.\n\t\tlinkTag.onerror = linkTag.onload = null;\n\t\tif (event.type === 'load') {\n\t\t\tresolve();\n\t\t} else {\n\t\t\tvar errorType = event && event.type;\n\t\t\tvar realHref = event && event.target && event.target.href || fullhref;\n\t\t\tvar err = new Error(\"Loading CSS chunk \" + chunkId + \" failed.\\n(\" + errorType + \": \" + realHref + \")\");\n\t\t\terr.name = \"ChunkLoadError\";\n\t\t\terr.code = \"CSS_CHUNK_LOAD_FAILED\";\n\t\t\terr.type = errorType;\n\t\t\terr.request = realHref;\n\t\t\tif (linkTag.parentNode) linkTag.parentNode.removeChild(linkTag)\n\t\t\treject(err);\n\t\t}\n\t}\n\tlinkTag.onerror = linkTag.onload = onLinkComplete;\n\tlinkTag.href = fullhref;\n\n\n\tif (oldTag) {\n\t\toldTag.parentNode.insertBefore(linkTag, oldTag.nextSibling);\n\t} else {\n\t\tdocument.head.appendChild(linkTag);\n\t}\n\treturn linkTag;\n};\nvar findStylesheet = function(href, fullhref) {\n\tvar existingLinkTags = document.getElementsByTagName(\"link\");\n\tfor(var i = 0; i < existingLinkTags.length; i++) {\n\t\tvar tag = existingLinkTags[i];\n\t\tvar dataHref = tag.getAttribute(\"data-href\") || tag.getAttribute(\"href\");\n\t\tif(tag.rel === \"stylesheet\" && (dataHref === href || dataHref === fullhref)) return tag;\n\t}\n\tvar existingStyleTags = document.getElementsByTagName(\"style\");\n\tfor(var i = 0; i < existingStyleTags.length; i++) {\n\t\tvar tag = existingStyleTags[i];\n\t\tvar dataHref = tag.getAttribute(\"data-href\");\n\t\tif(dataHref === href || dataHref === fullhref) return tag;\n\t}\n};\nvar loadStylesheet = function(chunkId) {\n\treturn new Promise(function(resolve, reject) {\n\t\tvar href = __webpack_require__.miniCssF(chunkId);\n\t\tvar fullhref = __webpack_require__.p + href;\n\t\tif(findStylesheet(href, fullhref)) return resolve();\n\t\tcreateStylesheet(chunkId, fullhref, null, resolve, reject);\n\t});\n}\n// object to store loaded CSS chunks\nvar installedCssChunks = {\n\t524: 0\n};\n\n__webpack_require__.f.miniCss = function(chunkId, promises) {\n\tvar cssChunks = {\"23\":1,\"100\":1,\"119\":1,\"214\":1,\"226\":1,\"275\":1,\"419\":1,\"488\":1,\"667\":1,\"845\":1,\"917\":1,\"988\":1};\n\tif(installedCssChunks[chunkId]) promises.push(installedCssChunks[chunkId]);\n\telse if(installedCssChunks[chunkId] !== 0 && cssChunks[chunkId]) {\n\t\tpromises.push(installedCssChunks[chunkId] = loadStylesheet(chunkId).then(function() {\n\t\t\tinstalledCssChunks[chunkId] = 0;\n\t\t}, function(e) {\n\t\t\tdelete installedCssChunks[chunkId];\n\t\t\tthrow e;\n\t\t}));\n\t}\n};\n\n// no hmr\n\n// no prefetching\n\n// no preloaded","// no baseURI\n\n// object to store loaded and loading chunks\n// undefined = chunk not loaded, null = chunk preloaded/prefetched\n// [resolve, reject, Promise] = chunk loading, 0 = chunk loaded\nvar installedChunks = {\n\t524: 0\n};\n\n__webpack_require__.f.j = function(chunkId, promises) {\n\t\t// JSONP chunk loading for javascript\n\t\tvar installedChunkData = __webpack_require__.o(installedChunks, chunkId) ? installedChunks[chunkId] : undefined;\n\t\tif(installedChunkData !== 0) { // 0 means \"already installed\".\n\n\t\t\t// a Promise means \"currently loading\".\n\t\t\tif(installedChunkData) {\n\t\t\t\tpromises.push(installedChunkData[2]);\n\t\t\t} else {\n\t\t\t\tif(!/^(119|275)$/.test(chunkId)) {\n\t\t\t\t\t// setup Promise in chunk cache\n\t\t\t\t\tvar promise = new Promise(function(resolve, reject) { installedChunkData = installedChunks[chunkId] = [resolve, reject]; });\n\t\t\t\t\tpromises.push(installedChunkData[2] = promise);\n\n\t\t\t\t\t// start chunk loading\n\t\t\t\t\tvar url = __webpack_require__.p + __webpack_require__.u(chunkId);\n\t\t\t\t\t// create error before stack unwound to get useful stacktrace later\n\t\t\t\t\tvar error = new Error();\n\t\t\t\t\tvar loadingEnded = function(event) {\n\t\t\t\t\t\tif(__webpack_require__.o(installedChunks, chunkId)) {\n\t\t\t\t\t\t\tinstalledChunkData = installedChunks[chunkId];\n\t\t\t\t\t\t\tif(installedChunkData !== 0) installedChunks[chunkId] = undefined;\n\t\t\t\t\t\t\tif(installedChunkData) {\n\t\t\t\t\t\t\t\tvar errorType = event && (event.type === 'load' ? 'missing' : event.type);\n\t\t\t\t\t\t\t\tvar realSrc = event && event.target && event.target.src;\n\t\t\t\t\t\t\t\terror.message = 'Loading chunk ' + chunkId + ' failed.\\n(' + errorType + ': ' + realSrc + ')';\n\t\t\t\t\t\t\t\terror.name = 'ChunkLoadError';\n\t\t\t\t\t\t\t\terror.type = errorType;\n\t\t\t\t\t\t\t\terror.request = realSrc;\n\t\t\t\t\t\t\t\tinstalledChunkData[1](error);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t};\n\t\t\t\t\t__webpack_require__.l(url, loadingEnded, \"chunk-\" + chunkId, chunkId);\n\t\t\t\t} else installedChunks[chunkId] = 0;\n\t\t\t}\n\t\t}\n};\n\n// no prefetching\n\n// no preloaded\n\n// no HMR\n\n// no HMR manifest\n\n__webpack_require__.O.j = function(chunkId) { return installedChunks[chunkId] === 0; };\n\n// install a JSONP callback for chunk loading\nvar webpackJsonpCallback = function(parentChunkLoadingFunction, data) {\n\tvar chunkIds = data[0];\n\tvar moreModules = data[1];\n\tvar runtime = data[2];\n\t// add \"moreModules\" to the modules object,\n\t// then flag all \"chunkIds\" as loaded and fire callback\n\tvar moduleId, chunkId, i = 0;\n\tif(chunkIds.some(function(id) { return installedChunks[id] !== 0; })) {\n\t\tfor(moduleId in moreModules) {\n\t\t\tif(__webpack_require__.o(moreModules, moduleId)) {\n\t\t\t\t__webpack_require__.m[moduleId] = moreModules[moduleId];\n\t\t\t}\n\t\t}\n\t\tif(runtime) var result = runtime(__webpack_require__);\n\t}\n\tif(parentChunkLoadingFunction) parentChunkLoadingFunction(data);\n\tfor(;i < chunkIds.length; i++) {\n\t\tchunkId = chunkIds[i];\n\t\tif(__webpack_require__.o(installedChunks, chunkId) && installedChunks[chunkId]) {\n\t\t\tinstalledChunks[chunkId][0]();\n\t\t}\n\t\tinstalledChunks[chunkId] = 0;\n\t}\n\treturn __webpack_require__.O(result);\n}\n\nvar chunkLoadingGlobal = self[\"webpackChunksanyue_imghub\"] = self[\"webpackChunksanyue_imghub\"] || [];\nchunkLoadingGlobal.forEach(webpackJsonpCallback.bind(null, 0));\nchunkLoadingGlobal.push = webpackJsonpCallback.bind(null, chunkLoadingGlobal.push.bind(chunkLoadingGlobal));","// startup\n// Load entry module and return exports\n// This entry module depends on other loaded chunks and execution need to be delayed\nvar __webpack_exports__ = __webpack_require__.O(undefined, [504], function() { return __webpack_require__(2885); })\n__webpack_exports__ = __webpack_require__.O(__webpack_exports__);\n"],"names":["instance","axios","create","baseURL","interceptors","request","use","config","withAuthCode","authCode","cookies","headers","error","Promise","reject","response","status","ElMessage","router","push","render","_ctx","_cache","$props","$setup","$data","$options","_component_router_view","data","osInstance","imageViewerObserver","computed","mounted","this","$nextTick","initOverlayScrollbars","setupImageViewerObserver","beforeUnmount","disconnect","watch","useDarkMode","setSiteIcon","methods","valid","document","body","scrollbars","theme","visibility","autoHide","autoHideDelay","dragScroll","clickScroll","overflow","x","y","console","log","MutationObserver","mutations","imageViewer","querySelector","options","observe","childList","subtree","existingIcons","querySelectorAll","forEach","icon","remove","iconLink","createElement","appleIconLink","maskIconLink","rel","href","userConfig","siteIcon","head","appendChild","__exports__","library","add","fas","app","createApp","App","createHead","component","FontAwesomeIcon","key","Object","entries","ElementPlusIconsVue","initDarkModeClass","htmlElement","documentElement","isDarkMode","store","state","cusDarkMode","window","matchMedia","matches","now","Date","hour","getHours","commit","classList","applyDarkModeClass","presetSiteTitle","title","siteTitle","presetSiteIcon","dispatch","then","getters","subscribe","mutation","type","payload","ElementPlus","mount","catch","createStore","bingWallPapers","credentials","uploadMethod","uploadCopyUrlForm","compressConfig","customerCompress","undefined","compressQuality","compressBar","serverCompress","convertToWebp","storeUploadChannel","storeChannelName","storeAutoRetry","storeUploadNameType","uploadFolder","customUrlSettings","useCustomUrl","customUrlPrefix","adminUrlSettings","autoReUpload","storeUploadMethod","storeUploadFolder","localStorage","getItem","storeAutoReUpload","setUserConfig","setBingWallPapers","setCredentials","setUploadMethod","setUploadCopyUrlForm","setCompressConfig","value","setStoreUploadChannel","uploadChannel","setStoreChannelName","channelName","setStoreUploadNameType","setCustomUrlSettings","setStoreAutoRetry","setAdminUrlSettings","setUseDarkMode","setCusDarkMode","setStoreUploadFolder","folder","setItem","setStoreAutoReUpload","actions","fetchUserConfig","get","fetchBingWallPapers","wallpapers","map","wallpaper","url","all","resolve","img","Image","onload","onerror","src","modules","plugins","createPersistedState","adminAuthGuard","to","from","next","name","btoa","withCredentials","res","Error","err","userAuthGuard","post","routes","path","beforeEnter","createRouter","history","createWebHistory","process","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","exports","module","__webpack_modules__","call","m","deferred","O","result","chunkIds","fn","priority","notFulfilled","Infinity","i","length","fulfilled","j","keys","every","splice","r","n","getter","__esModule","d","a","definition","o","defineProperty","enumerable","f","e","chunkId","reduce","promises","u","miniCssF","g","globalThis","Function","obj","prop","prototype","hasOwnProperty","inProgress","dataWebpackPrefix","l","done","script","needAttach","scripts","getElementsByTagName","s","getAttribute","charset","nc","setAttribute","onScriptComplete","prev","event","clearTimeout","timeout","doneFns","parentNode","removeChild","setTimeout","bind","target","Symbol","toStringTag","p","createStylesheet","fullhref","oldTag","linkTag","nonce","onLinkComplete","errorType","realHref","code","insertBefore","nextSibling","findStylesheet","existingLinkTags","tag","dataHref","existingStyleTags","loadStylesheet","installedCssChunks","miniCss","cssChunks","installedChunks","installedChunkData","test","promise","loadingEnded","realSrc","message","webpackJsonpCallback","parentChunkLoadingFunction","moreModules","runtime","some","id","chunkLoadingGlobal","self","__webpack_exports__"],"ignoreList":[],"sourceRoot":""} \ No newline at end of file +{"version":3,"file":"js/app.f4ce2fc3.js","mappings":"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","sources":["webpack://sanyue_imghub/./src/utils/axios.js","webpack://sanyue_imghub/./src/App.vue?eaa6","webpack://sanyue_imghub/./src/App.vue","webpack://sanyue_imghub/./src/App.vue?a135","webpack://sanyue_imghub/./src/main.js","webpack://sanyue_imghub/./src/store/index.js","webpack://sanyue_imghub/./src/router/index.js","webpack://sanyue_imghub/webpack/bootstrap","webpack://sanyue_imghub/webpack/runtime/chunk loaded","webpack://sanyue_imghub/webpack/runtime/compat get default export","webpack://sanyue_imghub/webpack/runtime/define property getters","webpack://sanyue_imghub/webpack/runtime/ensure chunk","webpack://sanyue_imghub/webpack/runtime/get javascript chunk filename","webpack://sanyue_imghub/webpack/runtime/get mini-css chunk filename","webpack://sanyue_imghub/webpack/runtime/global","webpack://sanyue_imghub/webpack/runtime/hasOwnProperty shorthand","webpack://sanyue_imghub/webpack/runtime/load script","webpack://sanyue_imghub/webpack/runtime/make namespace object","webpack://sanyue_imghub/webpack/runtime/publicPath","webpack://sanyue_imghub/webpack/runtime/css loading","webpack://sanyue_imghub/webpack/runtime/jsonp chunk loading","webpack://sanyue_imghub/webpack/startup"],"sourcesContent":["import axios from 'axios';\r\nimport cookies from 'vue-cookies';\r\nimport router from '@/router/index';\r\nimport { ElMessage } from 'element-plus'\r\n\r\n// 创建axios实例\r\nconst instance = axios.create({\r\n baseURL: process.env.NODE_ENV === 'production' ? '/' : '/api',\r\n});\r\n\r\n// 请求拦截器\r\ninstance.interceptors.request.use(\r\n (config) => {\r\n // 如果配置中标记了withAuthCode,则添加authCode到header\r\n if (config.withAuthCode) {\r\n const authCode = cookies.get('authCode');\r\n if (authCode) {\r\n config.headers['authCode'] = authCode;\r\n }\r\n }\r\n return config;\r\n },\r\n (error) => {\r\n return Promise.reject(error);\r\n }\r\n);\r\n\r\n// 响应拦截器\r\ninstance.interceptors.response.use(\r\n (response) => {\r\n return response;\r\n },\r\n (error) => {\r\n // 如果请求配置了withAuthCode且返回401,则跳转到登录页\r\n if (error.config?.withAuthCode && error.response?.status === 401) {\r\n ElMessage.error('认证失败,请重新登录!');\r\n router.push('/login');\r\n }\r\n return Promise.reject(error);\r\n }\r\n);\r\n\r\nexport default instance;\r\n","import { resolveComponent as _resolveComponent, openBlock as _openBlock, createBlock as _createBlock } from \"vue\";\nexport function render(_ctx, _cache, $props, $setup, $data, $options) {\n const _component_router_view = _resolveComponent(\"router-view\");\n return _openBlock(), _createBlock(_component_router_view);\n}","import \"core-js/modules/es.iterator.constructor.js\";\nimport \"core-js/modules/es.iterator.for-each.js\";\nimport { mapGetters } from 'vuex';\nimport { OverlayScrollbars } from 'overlayscrollbars';\nexport default {\n data() {\n return {\n osInstance: null,\n imageViewerObserver: null\n };\n },\n computed: {\n ...mapGetters(['userConfig', 'useDarkMode'])\n },\n mounted() {\n // 初始化 OverlayScrollbars 悬浮滚动条\n this.$nextTick(() => {\n this.initOverlayScrollbars();\n this.setupImageViewerObserver();\n });\n },\n beforeUnmount() {\n // 清理 MutationObserver\n if (this.imageViewerObserver) {\n this.imageViewerObserver.disconnect();\n }\n },\n watch: {\n useDarkMode() {\n this.setSiteIcon();\n }\n },\n methods: {\n initOverlayScrollbars() {\n try {\n // 检查是否已经初始化\n if (OverlayScrollbars.valid(document.body)) {\n this.osInstance = OverlayScrollbars(document.body);\n return;\n }\n\n // 应用到 body 实现全局悬浮滚动条\n this.osInstance = OverlayScrollbars(document.body, {\n scrollbars: {\n theme: 'os-theme-dark',\n visibility: 'auto',\n autoHide: 'scroll',\n autoHideDelay: 600,\n dragScroll: true,\n clickScroll: true\n },\n overflow: {\n x: 'hidden',\n y: 'scroll'\n }\n });\n console.log('OverlayScrollbars initialized successfully');\n } catch (error) {\n console.error('Failed to initialize OverlayScrollbars:', error);\n }\n },\n setupImageViewerObserver() {\n // 监听图片预览器的打开/关闭,动态控制 OverlayScrollbars\n this.imageViewerObserver = new MutationObserver(mutations => {\n const imageViewer = document.querySelector('.el-image-viewer__wrapper');\n if (imageViewer) {\n // 图片预览器打开,禁用滚动\n if (this.osInstance) {\n this.osInstance.options({\n overflow: {\n x: 'hidden',\n y: 'hidden'\n }\n });\n }\n } else {\n // 图片预览器关闭,恢复滚动\n if (this.osInstance) {\n this.osInstance.options({\n overflow: {\n x: 'hidden',\n y: 'scroll'\n }\n });\n }\n }\n });\n this.imageViewerObserver.observe(document.body, {\n childList: true,\n subtree: true\n });\n },\n setSiteIcon() {\n // 同时更改 icon apple-touch-icon 和 mask-icon\n const existingIcons = document.querySelectorAll('link[rel=\"icon\"], link[rel=\"apple-touch-icon\"], link[rel=\"mask-icon\"]');\n existingIcons.forEach(icon => icon.remove());\n const iconLink = document.createElement('link');\n const appleIconLink = document.createElement('link');\n const maskIconLink = document.createElement('link');\n iconLink.rel = 'icon';\n appleIconLink.rel = 'apple-touch-icon';\n maskIconLink.rel = 'mask-icon';\n if (this.useDarkMode) {\n iconLink.href = this.userConfig?.siteIcon || '/logo-dark.png';\n appleIconLink.href = this.userConfig?.siteIcon || '/logo-dark.png';\n maskIconLink.href = this.userConfig?.siteIcon || '/logo-dark.png';\n } else {\n iconLink.href = this.userConfig?.siteIcon || '/logo.png';\n appleIconLink.href = this.userConfig?.siteIcon || '/logo.png';\n maskIconLink.href = this.userConfig?.siteIcon || '/logo.png';\n }\n document.head.appendChild(iconLink);\n document.head.appendChild(appleIconLink);\n document.head.appendChild(maskIconLink);\n }\n }\n};","/* unplugin-vue-components disabled */import { render } from \"./App.vue?vue&type=template&id=7df82a17\"\nimport script from \"./App.vue?vue&type=script&lang=js\"\nexport * from \"./App.vue?vue&type=script&lang=js\"\n\nimport exportComponent from \"../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render]])\n\nexport default __exports__","import { createApp } from 'vue'\r\nimport { createHead } from '@vueuse/head'; // 导入 createHead\r\nimport ElementPlus from 'element-plus'\r\nimport 'element-plus/es/components/message/style/css'\r\nimport 'element-plus/es/components/message-box/style/css'\r\n\r\nimport { library } from '@fortawesome/fontawesome-svg-core';\r\nimport { fas } from '@fortawesome/free-solid-svg-icons'; // 引入所有 solid 图标\r\nimport { FontAwesomeIcon } from '@fortawesome/vue-fontawesome';\r\n\r\nimport App from './App.vue'\r\nimport router from './router'\r\nimport store from './store'\r\n\r\nimport * as ElementPlusIconsVue from '@element-plus/icons-vue'\r\nimport 'element-plus/theme-chalk/dark/css-vars.css'\r\nimport './styles/global.css'\r\n\r\n// OverlayScrollbars 悬浮滚动条\r\nimport 'overlayscrollbars/overlayscrollbars.css'\r\n\r\n\r\nlibrary.add(fas);\r\n\r\nconst app = createApp(App);\r\nconst head = createHead(); // 创建 head 对象\r\n\r\napp.component('font-awesome-icon', FontAwesomeIcon);\r\nfor (const [key, component] of Object.entries(ElementPlusIconsVue)) {\r\n app.component(key, component)\r\n}\r\n\r\n// 根据 useDarkMode 的值添加或移除 dark 类\r\nconst initDarkModeClass = () => {\r\n const htmlElement = document.documentElement;\r\n let isDarkMode;\r\n\r\n // 判断用户是否是自定义模式\r\n if (store.state.cusDarkMode && store.state.useDarkMode !== null) {\r\n // 用户手动设置了暗色模式\r\n isDarkMode = store.state.useDarkMode;\r\n } else {\r\n // 跟随系统模式或时间\r\n isDarkMode = window.matchMedia('(prefers-color-scheme: dark)').matches;\r\n if (!isDarkMode) {\r\n const now = new Date();\r\n const hour = now.getHours();\r\n isDarkMode = hour >= 22 || hour < 6;\r\n }\r\n // 更新 useDarkMode 的值\r\n store.commit('setUseDarkMode', isDarkMode);\r\n }\r\n\r\n if (isDarkMode) {\r\n htmlElement.classList.add('dark');\r\n } else {\r\n htmlElement.classList.remove('dark');\r\n }\r\n};\r\n\r\nconst applyDarkModeClass = (isDarkMode) => {\r\n const htmlElement = document.documentElement;\r\n if (isDarkMode) {\r\n htmlElement.classList.add('dark');\r\n } else {\r\n htmlElement.classList.remove('dark');\r\n }\r\n};\r\n\r\n// 预设网站标题的函数\r\nconst presetSiteTitle = (userConfig) => {\r\n document.title = userConfig?.siteTitle || 'Sanyue ImgHub';\r\n};\r\n\r\n// 预设网站图标的函数\r\nconst presetSiteIcon = (isDarkMode, userConfig) => {\r\n // 同时更改 icon apple-touch-icon 和 mask-icon\r\n const existingIcons = document.querySelectorAll('link[rel=\"icon\"], link[rel=\"apple-touch-icon\"], link[rel=\"mask-icon\"]');\r\n existingIcons.forEach(icon => icon.remove());\r\n\r\n const iconLink = document.createElement('link');\r\n const appleIconLink = document.createElement('link');\r\n const maskIconLink = document.createElement('link');\r\n iconLink.rel = 'icon';\r\n appleIconLink.rel = 'apple-touch-icon';\r\n maskIconLink.rel = 'mask-icon';\r\n\r\n if (isDarkMode) {\r\n iconLink.href = userConfig?.siteIcon || '/logo-dark.png';\r\n appleIconLink.href = userConfig?.siteIcon || '/logo-dark.png';\r\n maskIconLink.href = userConfig?.siteIcon || '/logo-dark.png';\r\n } else {\r\n iconLink.href = userConfig?.siteIcon || '/logo.png';\r\n appleIconLink.href = userConfig?.siteIcon || '/logo.png';\r\n maskIconLink.href = userConfig?.siteIcon || '/logo.png';\r\n }\r\n\r\n document.head.appendChild(iconLink);\r\n document.head.appendChild(appleIconLink);\r\n document.head.appendChild(maskIconLink);\r\n};\r\n\r\nstore.dispatch('fetchUserConfig').then(() => {\r\n // 初始化时应用 dark 模式\r\n initDarkModeClass();\r\n\r\n // 预设网站标题和图标\r\n presetSiteTitle(store.getters.userConfig);\r\n presetSiteIcon(store.state.useDarkMode, store.getters.userConfig);\r\n\r\n // 监听 useDarkMode 和 cusDarkMode 的变化\r\n store.subscribe((mutation, state) => {\r\n if (mutation.type === 'setUseDarkMode' && store.state.cusDarkMode) {\r\n applyDarkModeClass(state.useDarkMode);\r\n // 同时更新网站图标\r\n presetSiteIcon(state.useDarkMode, store.getters.userConfig);\r\n }\r\n\r\n // 监听 cusDarkMode 变化,当设置为 false 时重新初始化\r\n if (mutation.type === 'setCusDarkMode' && !mutation.payload) {\r\n // 切换到跟随系统模式,重新初始化\r\n initDarkModeClass();\r\n // 同时更新网站图标\r\n presetSiteIcon(store.state.useDarkMode, store.getters.userConfig);\r\n }\r\n });\r\n\r\n app.use(store).use(router).use(ElementPlus).mount('#app');\r\n}).catch(error => {\r\n console.error('Failed to load user configuration:', error);\r\n app.use(store).use(router).use(ElementPlus).use(head).mount('#app');\r\n})\r\n","import { createStore } from 'vuex'\r\nimport axios from '@/utils/axios';\r\nimport createPersistedState from 'vuex-persistedstate';\r\n\r\nexport default createStore({\r\n state: {\r\n userConfig: null,\r\n bingWallPapers: [],\r\n credentials: null,\r\n uploadMethod: 'default',\r\n uploadCopyUrlForm: '',\r\n compressConfig: {\r\n customerCompress: undefined,\r\n compressQuality: undefined,\r\n compressBar: undefined,\r\n serverCompress: undefined,\r\n convertToWebp: undefined,\r\n },\r\n storeUploadChannel: '',\r\n storeChannelName: null, // 指定的渠道名称,null表示从未选择,''表示用户主动清空\r\n storeAutoRetry: true,\r\n storeUploadNameType: '',\r\n uploadFolder: '',\r\n customUrlSettings: {\r\n useCustomUrl: 'false',\r\n customUrlPrefix: '',\r\n },\r\n adminUrlSettings: {\r\n useCustomUrl: 'false',\r\n customUrlPrefix: '',\r\n },\r\n autoReUpload: true,\r\n // 深色模式\r\n useDarkMode: null,\r\n cusDarkMode: false,\r\n },\r\n getters: {\r\n userConfig: state => state.userConfig,\r\n bingWallPapers: state => state.bingWallPapers,\r\n credentials: state => state.credentials,\r\n storeUploadMethod: state => state.uploadMethod,\r\n uploadCopyUrlForm: state => state.uploadCopyUrlForm,\r\n compressConfig: state => state.compressConfig,\r\n storeUploadChannel: state => state.storeUploadChannel,\r\n storeChannelName: state => state.storeChannelName,\r\n storeUploadNameType: state => state.storeUploadNameType,\r\n customUrlSettings: state => state.customUrlSettings,\r\n storeAutoRetry: state => state.storeAutoRetry,\r\n adminUrlSettings: state => state.adminUrlSettings,\r\n storeUploadFolder: (state) => {\r\n return state.uploadFolder || localStorage.getItem('uploadFolder') || ''\r\n },\r\n useDarkMode: state => state.useDarkMode,\r\n cusDarkMode: state => state.cusDarkMode,\r\n storeAutoReUpload: state => state.autoReUpload,\r\n },\r\n mutations: {\r\n setUserConfig(state, userConfig) {\r\n state.userConfig = userConfig;\r\n },\r\n setBingWallPapers(state, bingWallPapers) {\r\n state.bingWallPapers = bingWallPapers;\r\n },\r\n setCredentials(state, credentials) {\r\n state.credentials = credentials;\r\n },\r\n setUploadMethod(state, uploadMethod) {\r\n state.uploadMethod = uploadMethod;\r\n },\r\n setUploadCopyUrlForm(state, uploadCopyUrlForm) {\r\n state.uploadCopyUrlForm = uploadCopyUrlForm;\r\n },\r\n setCompressConfig(state, { key, value }) {\r\n state.compressConfig[key] = value;\r\n },\r\n setStoreUploadChannel(state, uploadChannel) {\r\n state.storeUploadChannel = uploadChannel;\r\n },\r\n setStoreChannelName(state, channelName) {\r\n state.storeChannelName = channelName;\r\n },\r\n setStoreUploadNameType(state, storeUploadNameType) {\r\n state.storeUploadNameType = storeUploadNameType;\r\n },\r\n setCustomUrlSettings(state, { key, value }) {\r\n state.customUrlSettings[key] = value;\r\n },\r\n setStoreAutoRetry(state, storeAutoRetry) {\r\n state.storeAutoRetry = storeAutoRetry;\r\n },\r\n setAdminUrlSettings(state, { key, value }) {\r\n state.adminUrlSettings[key] = value;\r\n },\r\n setUseDarkMode(state, useDarkMode) {\r\n state.useDarkMode = useDarkMode;\r\n },\r\n setCusDarkMode(state, cusDarkMode) {\r\n state.cusDarkMode = cusDarkMode;\r\n },\r\n setStoreUploadFolder(state, folder) {\r\n state.uploadFolder = folder\r\n localStorage.setItem('uploadFolder', folder)\r\n },\r\n setStoreAutoReUpload(state, autoReUpload) {\r\n state.autoReUpload = autoReUpload;\r\n }\r\n },\r\n actions: {\r\n async fetchUserConfig({ commit }) {\r\n try {\r\n const response = await axios.get('/api/userConfig');\r\n commit('setUserConfig', response.data);\r\n } catch (error) {\r\n console.log(error);\r\n }\r\n },\r\n async fetchBingWallPapers({ commit }) {\r\n try {\r\n const response = await axios.get('/api/bing/wallpaper');\r\n const wallpapers = response.data.data;\r\n const bingWallPapers = wallpapers.map(wallpaper => {\r\n return {\r\n url: 'https://www.bing.com' + wallpaper.url,\r\n };\r\n }\r\n );\r\n\r\n //预加载图片,阻塞直到图片加载完成\r\n await Promise.all(bingWallPapers.map(wallpaper => {\r\n return new Promise((resolve, reject) => {\r\n const img = new Image();\r\n img.onload = resolve;\r\n img.onerror = reject;\r\n img.src = wallpaper.url;\r\n });\r\n }));\r\n commit('setBingWallPapers', bingWallPapers);\r\n } catch (error) {\r\n console.log(error);\r\n }\r\n }\r\n },\r\n modules: {\r\n },\r\n plugins: [createPersistedState()]\r\n})\r\n","import { createRouter, createWebHistory } from 'vue-router'\r\nimport { ElMessage } from 'element-plus'\r\nimport cookies from 'vue-cookies'\r\nimport store from '../store'\r\nimport axios from '@/utils/axios'\r\n\r\n// 通用的管理员认证守卫\r\nconst adminAuthGuard = (to, from, next) => {\r\n // 从store中获取凭据\r\n const credentials = store.getters.credentials\r\n if (credentials === null && to.name !== 'adminLogin') {\r\n // 尝试未设置密码的情况\r\n const credentials = btoa('unset:unset')\r\n axios.get('/api/manage/check', {\r\n headers: {\r\n 'Authorization': 'Basic ' + credentials\r\n },\r\n withCredentials: true\r\n }).then(res => {\r\n if (res.status !== 200) {\r\n throw new Error('认证失败!')\r\n }\r\n store.commit('setCredentials', credentials)\r\n next()\r\n }).catch(err => {\r\n ElMessage.error('请先认证!')\r\n next({ name: 'adminLogin' })\r\n })\r\n } else {\r\n next()\r\n }\r\n}\r\n\r\n// 通用的用户认证守卫\r\nconst userAuthGuard = (to, from, next) => {\r\n let authCode = cookies.get('authCode');\r\n if (authCode === null && to.name !== 'login') {\r\n // 尝试未设置密码的情况\r\n axios.post('/api/login', {\r\n authCode: 'unset'\r\n }).then(res => {\r\n if (res.status !== 200) {\r\n throw new Error('认证失败!')\r\n }\r\n cookies.set('authCode', 'unset', '14d')\r\n authCode = 'unset'\r\n next()\r\n }).catch(err => {\r\n ElMessage.error('请先认证!')\r\n next({ name: 'login' })\r\n })\r\n } else {\r\n next()\r\n }\r\n}\r\n\r\nconst routes = [\r\n {\r\n path: '/',\r\n name: 'home',\r\n component: () => import('../views/UploadHome.vue'),\r\n beforeEnter: userAuthGuard\r\n },\r\n {\r\n path: '/login',\r\n name: 'login',\r\n component: () => import('../views/Login.vue')\r\n },\r\n {\r\n path: '/dashboard',\r\n name: 'dashboard',\r\n component: () => import('../views/AdminDashBoard.vue'),\r\n beforeEnter: adminAuthGuard\r\n },\r\n {\r\n path: '/customerConfig',\r\n name: 'customerConfig',\r\n component: () => import('../views/CustomerConfig.vue'),\r\n beforeEnter: adminAuthGuard\r\n },\r\n {\r\n path: '/systemConfig',\r\n name: 'systemConfig',\r\n component: () => import('../views/SystemConfig.vue'),\r\n beforeEnter: adminAuthGuard\r\n },\r\n {\r\n path: '/adminLogin',\r\n name: 'adminLogin',\r\n component: () => import('../views/AdminLogin.vue'),\r\n },\r\n {\r\n path: '/blockimg',\r\n name: 'blockimg',\r\n component: () => import('../views/BlockImage.vue'),\r\n },\r\n {\r\n path: '/whiteliston',\r\n name: 'whiteliston',\r\n component: () => import('../views/WhiteListOn.vue'),\r\n },\r\n {\r\n path: '/browse/:dir*',\r\n name: 'publicBrowse',\r\n component: () => import('../views/PublicBrowse.vue'),\r\n },\r\n {\r\n path: '/:pathMatch(.*)*',\r\n name: 'notFound',\r\n component: () => import('../views/NotFound.vue'),\r\n },\r\n]\r\n\r\nconst router = createRouter({\r\n history: createWebHistory(process.env.BASE_URL),\r\n routes\r\n})\r\n\r\nexport default router\r\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n// expose the modules object (__webpack_modules__)\n__webpack_require__.m = __webpack_modules__;\n\n","var deferred = [];\n__webpack_require__.O = function(result, chunkIds, fn, priority) {\n\tif(chunkIds) {\n\t\tpriority = priority || 0;\n\t\tfor(var i = deferred.length; i > 0 && deferred[i - 1][2] > priority; i--) deferred[i] = deferred[i - 1];\n\t\tdeferred[i] = [chunkIds, fn, priority];\n\t\treturn;\n\t}\n\tvar notFulfilled = Infinity;\n\tfor (var i = 0; i < deferred.length; i++) {\n\t\tvar chunkIds = deferred[i][0];\n\t\tvar fn = deferred[i][1];\n\t\tvar priority = deferred[i][2];\n\t\tvar fulfilled = true;\n\t\tfor (var j = 0; j < chunkIds.length; j++) {\n\t\t\tif ((priority & 1 === 0 || notFulfilled >= priority) && Object.keys(__webpack_require__.O).every(function(key) { return __webpack_require__.O[key](chunkIds[j]); })) {\n\t\t\t\tchunkIds.splice(j--, 1);\n\t\t\t} else {\n\t\t\t\tfulfilled = false;\n\t\t\t\tif(priority < notFulfilled) notFulfilled = priority;\n\t\t\t}\n\t\t}\n\t\tif(fulfilled) {\n\t\t\tdeferred.splice(i--, 1)\n\t\t\tvar r = fn();\n\t\t\tif (r !== undefined) result = r;\n\t\t}\n\t}\n\treturn result;\n};","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = function(module) {\n\tvar getter = module && module.__esModule ?\n\t\tfunction() { return module['default']; } :\n\t\tfunction() { return module; };\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = function(exports, definition) {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.f = {};\n// This file contains only the entry chunk.\n// The chunk loading function for additional chunks\n__webpack_require__.e = function(chunkId) {\n\treturn Promise.all(Object.keys(__webpack_require__.f).reduce(function(promises, key) {\n\t\t__webpack_require__.f[key](chunkId, promises);\n\t\treturn promises;\n\t}, []));\n};","// This function allow to reference async chunks\n__webpack_require__.u = function(chunkId) {\n\t// return url for filenames based on template\n\treturn \"js/\" + chunkId + \".\" + {\"23\":\"180d02c4\",\"100\":\"d7a2e066\",\"214\":\"e7ecaacc\",\"226\":\"f737e39a\",\"407\":\"f0b5dee5\",\"419\":\"714823b1\",\"456\":\"bfb68f0d\",\"600\":\"3d796c41\",\"667\":\"bbd60d43\",\"743\":\"5066c4a0\",\"845\":\"1bb9a557\",\"917\":\"833cbf86\"}[chunkId] + \".js\";\n};","// This function allow to reference async chunks\n__webpack_require__.miniCssF = function(chunkId) {\n\t// return url for filenames based on template\n\treturn \"css/\" + chunkId + \".\" + {\"23\":\"e63939dd\",\"100\":\"07b87787\",\"119\":\"2a856832\",\"214\":\"07b87787\",\"226\":\"6548e7b4\",\"275\":\"bf4b380e\",\"407\":\"a32a5829\",\"419\":\"605c1f2d\",\"667\":\"a3c83e09\",\"743\":\"ab3d1775\",\"845\":\"6b45e8e3\",\"917\":\"8529ad1e\"}[chunkId] + \".css\";\n};","__webpack_require__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","__webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); }","var inProgress = {};\nvar dataWebpackPrefix = \"sanyue_imghub:\";\n// loadScript function to load a script via script tag\n__webpack_require__.l = function(url, done, key, chunkId) {\n\tif(inProgress[url]) { inProgress[url].push(done); return; }\n\tvar script, needAttach;\n\tif(key !== undefined) {\n\t\tvar scripts = document.getElementsByTagName(\"script\");\n\t\tfor(var i = 0; i < scripts.length; i++) {\n\t\t\tvar s = scripts[i];\n\t\t\tif(s.getAttribute(\"src\") == url || s.getAttribute(\"data-webpack\") == dataWebpackPrefix + key) { script = s; break; }\n\t\t}\n\t}\n\tif(!script) {\n\t\tneedAttach = true;\n\t\tscript = document.createElement('script');\n\n\t\tscript.charset = 'utf-8';\n\t\tif (__webpack_require__.nc) {\n\t\t\tscript.setAttribute(\"nonce\", __webpack_require__.nc);\n\t\t}\n\t\tscript.setAttribute(\"data-webpack\", dataWebpackPrefix + key);\n\n\t\tscript.src = url;\n\t}\n\tinProgress[url] = [done];\n\tvar onScriptComplete = function(prev, event) {\n\t\t// avoid mem leaks in IE.\n\t\tscript.onerror = script.onload = null;\n\t\tclearTimeout(timeout);\n\t\tvar doneFns = inProgress[url];\n\t\tdelete inProgress[url];\n\t\tscript.parentNode && script.parentNode.removeChild(script);\n\t\tdoneFns && doneFns.forEach(function(fn) { return fn(event); });\n\t\tif(prev) return prev(event);\n\t}\n\tvar timeout = setTimeout(onScriptComplete.bind(null, undefined, { type: 'timeout', target: script }), 120000);\n\tscript.onerror = onScriptComplete.bind(null, script.onerror);\n\tscript.onload = onScriptComplete.bind(null, script.onload);\n\tneedAttach && document.head.appendChild(script);\n};","// define __esModule on exports\n__webpack_require__.r = function(exports) {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","__webpack_require__.p = \"/\";","if (typeof document === \"undefined\") return;\nvar createStylesheet = function(chunkId, fullhref, oldTag, resolve, reject) {\n\tvar linkTag = document.createElement(\"link\");\n\n\tlinkTag.rel = \"stylesheet\";\n\tlinkTag.type = \"text/css\";\n\tif (__webpack_require__.nc) {\n\t\tlinkTag.nonce = __webpack_require__.nc;\n\t}\n\tvar onLinkComplete = function(event) {\n\t\t// avoid mem leaks.\n\t\tlinkTag.onerror = linkTag.onload = null;\n\t\tif (event.type === 'load') {\n\t\t\tresolve();\n\t\t} else {\n\t\t\tvar errorType = event && event.type;\n\t\t\tvar realHref = event && event.target && event.target.href || fullhref;\n\t\t\tvar err = new Error(\"Loading CSS chunk \" + chunkId + \" failed.\\n(\" + errorType + \": \" + realHref + \")\");\n\t\t\terr.name = \"ChunkLoadError\";\n\t\t\terr.code = \"CSS_CHUNK_LOAD_FAILED\";\n\t\t\terr.type = errorType;\n\t\t\terr.request = realHref;\n\t\t\tif (linkTag.parentNode) linkTag.parentNode.removeChild(linkTag)\n\t\t\treject(err);\n\t\t}\n\t}\n\tlinkTag.onerror = linkTag.onload = onLinkComplete;\n\tlinkTag.href = fullhref;\n\n\n\tif (oldTag) {\n\t\toldTag.parentNode.insertBefore(linkTag, oldTag.nextSibling);\n\t} else {\n\t\tdocument.head.appendChild(linkTag);\n\t}\n\treturn linkTag;\n};\nvar findStylesheet = function(href, fullhref) {\n\tvar existingLinkTags = document.getElementsByTagName(\"link\");\n\tfor(var i = 0; i < existingLinkTags.length; i++) {\n\t\tvar tag = existingLinkTags[i];\n\t\tvar dataHref = tag.getAttribute(\"data-href\") || tag.getAttribute(\"href\");\n\t\tif(tag.rel === \"stylesheet\" && (dataHref === href || dataHref === fullhref)) return tag;\n\t}\n\tvar existingStyleTags = document.getElementsByTagName(\"style\");\n\tfor(var i = 0; i < existingStyleTags.length; i++) {\n\t\tvar tag = existingStyleTags[i];\n\t\tvar dataHref = tag.getAttribute(\"data-href\");\n\t\tif(dataHref === href || dataHref === fullhref) return tag;\n\t}\n};\nvar loadStylesheet = function(chunkId) {\n\treturn new Promise(function(resolve, reject) {\n\t\tvar href = __webpack_require__.miniCssF(chunkId);\n\t\tvar fullhref = __webpack_require__.p + href;\n\t\tif(findStylesheet(href, fullhref)) return resolve();\n\t\tcreateStylesheet(chunkId, fullhref, null, resolve, reject);\n\t});\n}\n// object to store loaded CSS chunks\nvar installedCssChunks = {\n\t524: 0\n};\n\n__webpack_require__.f.miniCss = function(chunkId, promises) {\n\tvar cssChunks = {\"23\":1,\"100\":1,\"119\":1,\"214\":1,\"226\":1,\"275\":1,\"407\":1,\"419\":1,\"667\":1,\"743\":1,\"845\":1,\"917\":1};\n\tif(installedCssChunks[chunkId]) promises.push(installedCssChunks[chunkId]);\n\telse if(installedCssChunks[chunkId] !== 0 && cssChunks[chunkId]) {\n\t\tpromises.push(installedCssChunks[chunkId] = loadStylesheet(chunkId).then(function() {\n\t\t\tinstalledCssChunks[chunkId] = 0;\n\t\t}, function(e) {\n\t\t\tdelete installedCssChunks[chunkId];\n\t\t\tthrow e;\n\t\t}));\n\t}\n};\n\n// no hmr\n\n// no prefetching\n\n// no preloaded","// no baseURI\n\n// object to store loaded and loading chunks\n// undefined = chunk not loaded, null = chunk preloaded/prefetched\n// [resolve, reject, Promise] = chunk loading, 0 = chunk loaded\nvar installedChunks = {\n\t524: 0\n};\n\n__webpack_require__.f.j = function(chunkId, promises) {\n\t\t// JSONP chunk loading for javascript\n\t\tvar installedChunkData = __webpack_require__.o(installedChunks, chunkId) ? installedChunks[chunkId] : undefined;\n\t\tif(installedChunkData !== 0) { // 0 means \"already installed\".\n\n\t\t\t// a Promise means \"currently loading\".\n\t\t\tif(installedChunkData) {\n\t\t\t\tpromises.push(installedChunkData[2]);\n\t\t\t} else {\n\t\t\t\tif(!/^(119|275)$/.test(chunkId)) {\n\t\t\t\t\t// setup Promise in chunk cache\n\t\t\t\t\tvar promise = new Promise(function(resolve, reject) { installedChunkData = installedChunks[chunkId] = [resolve, reject]; });\n\t\t\t\t\tpromises.push(installedChunkData[2] = promise);\n\n\t\t\t\t\t// start chunk loading\n\t\t\t\t\tvar url = __webpack_require__.p + __webpack_require__.u(chunkId);\n\t\t\t\t\t// create error before stack unwound to get useful stacktrace later\n\t\t\t\t\tvar error = new Error();\n\t\t\t\t\tvar loadingEnded = function(event) {\n\t\t\t\t\t\tif(__webpack_require__.o(installedChunks, chunkId)) {\n\t\t\t\t\t\t\tinstalledChunkData = installedChunks[chunkId];\n\t\t\t\t\t\t\tif(installedChunkData !== 0) installedChunks[chunkId] = undefined;\n\t\t\t\t\t\t\tif(installedChunkData) {\n\t\t\t\t\t\t\t\tvar errorType = event && (event.type === 'load' ? 'missing' : event.type);\n\t\t\t\t\t\t\t\tvar realSrc = event && event.target && event.target.src;\n\t\t\t\t\t\t\t\terror.message = 'Loading chunk ' + chunkId + ' failed.\\n(' + errorType + ': ' + realSrc + ')';\n\t\t\t\t\t\t\t\terror.name = 'ChunkLoadError';\n\t\t\t\t\t\t\t\terror.type = errorType;\n\t\t\t\t\t\t\t\terror.request = realSrc;\n\t\t\t\t\t\t\t\tinstalledChunkData[1](error);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t};\n\t\t\t\t\t__webpack_require__.l(url, loadingEnded, \"chunk-\" + chunkId, chunkId);\n\t\t\t\t} else installedChunks[chunkId] = 0;\n\t\t\t}\n\t\t}\n};\n\n// no prefetching\n\n// no preloaded\n\n// no HMR\n\n// no HMR manifest\n\n__webpack_require__.O.j = function(chunkId) { return installedChunks[chunkId] === 0; };\n\n// install a JSONP callback for chunk loading\nvar webpackJsonpCallback = function(parentChunkLoadingFunction, data) {\n\tvar chunkIds = data[0];\n\tvar moreModules = data[1];\n\tvar runtime = data[2];\n\t// add \"moreModules\" to the modules object,\n\t// then flag all \"chunkIds\" as loaded and fire callback\n\tvar moduleId, chunkId, i = 0;\n\tif(chunkIds.some(function(id) { return installedChunks[id] !== 0; })) {\n\t\tfor(moduleId in moreModules) {\n\t\t\tif(__webpack_require__.o(moreModules, moduleId)) {\n\t\t\t\t__webpack_require__.m[moduleId] = moreModules[moduleId];\n\t\t\t}\n\t\t}\n\t\tif(runtime) var result = runtime(__webpack_require__);\n\t}\n\tif(parentChunkLoadingFunction) parentChunkLoadingFunction(data);\n\tfor(;i < chunkIds.length; i++) {\n\t\tchunkId = chunkIds[i];\n\t\tif(__webpack_require__.o(installedChunks, chunkId) && installedChunks[chunkId]) {\n\t\t\tinstalledChunks[chunkId][0]();\n\t\t}\n\t\tinstalledChunks[chunkId] = 0;\n\t}\n\treturn __webpack_require__.O(result);\n}\n\nvar chunkLoadingGlobal = self[\"webpackChunksanyue_imghub\"] = self[\"webpackChunksanyue_imghub\"] || [];\nchunkLoadingGlobal.forEach(webpackJsonpCallback.bind(null, 0));\nchunkLoadingGlobal.push = webpackJsonpCallback.bind(null, chunkLoadingGlobal.push.bind(chunkLoadingGlobal));","// startup\n// Load entry module and return exports\n// This entry module depends on other loaded chunks and execution need to be delayed\nvar __webpack_exports__ = __webpack_require__.O(undefined, [504], function() { return __webpack_require__(2885); })\n__webpack_exports__ = __webpack_require__.O(__webpack_exports__);\n"],"names":["instance","axios","create","baseURL","interceptors","request","use","config","withAuthCode","authCode","cookies","headers","error","Promise","reject","response","status","ElMessage","router","push","render","_ctx","_cache","$props","$setup","$data","$options","_component_router_view","data","osInstance","imageViewerObserver","computed","mounted","this","$nextTick","initOverlayScrollbars","setupImageViewerObserver","beforeUnmount","disconnect","watch","useDarkMode","setSiteIcon","methods","valid","document","body","scrollbars","theme","visibility","autoHide","autoHideDelay","dragScroll","clickScroll","overflow","x","y","console","log","MutationObserver","mutations","imageViewer","querySelector","options","observe","childList","subtree","existingIcons","querySelectorAll","forEach","icon","remove","iconLink","createElement","appleIconLink","maskIconLink","rel","href","userConfig","siteIcon","head","appendChild","__exports__","library","add","fas","app","createApp","App","createHead","component","FontAwesomeIcon","key","Object","entries","ElementPlusIconsVue","initDarkModeClass","htmlElement","documentElement","isDarkMode","store","state","cusDarkMode","window","matchMedia","matches","now","Date","hour","getHours","commit","classList","applyDarkModeClass","presetSiteTitle","title","siteTitle","presetSiteIcon","dispatch","then","getters","subscribe","mutation","type","payload","ElementPlus","mount","catch","createStore","bingWallPapers","credentials","uploadMethod","uploadCopyUrlForm","compressConfig","customerCompress","undefined","compressQuality","compressBar","serverCompress","convertToWebp","storeUploadChannel","storeChannelName","storeAutoRetry","storeUploadNameType","uploadFolder","customUrlSettings","useCustomUrl","customUrlPrefix","adminUrlSettings","autoReUpload","storeUploadMethod","storeUploadFolder","localStorage","getItem","storeAutoReUpload","setUserConfig","setBingWallPapers","setCredentials","setUploadMethod","setUploadCopyUrlForm","setCompressConfig","value","setStoreUploadChannel","uploadChannel","setStoreChannelName","channelName","setStoreUploadNameType","setCustomUrlSettings","setStoreAutoRetry","setAdminUrlSettings","setUseDarkMode","setCusDarkMode","setStoreUploadFolder","folder","setItem","setStoreAutoReUpload","actions","fetchUserConfig","get","fetchBingWallPapers","wallpapers","map","wallpaper","url","all","resolve","img","Image","onload","onerror","src","modules","plugins","createPersistedState","adminAuthGuard","to","from","next","name","btoa","withCredentials","res","Error","err","userAuthGuard","post","routes","path","beforeEnter","createRouter","history","createWebHistory","process","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","exports","module","__webpack_modules__","call","m","deferred","O","result","chunkIds","fn","priority","notFulfilled","Infinity","i","length","fulfilled","j","keys","every","splice","r","n","getter","__esModule","d","a","definition","o","defineProperty","enumerable","f","e","chunkId","reduce","promises","u","miniCssF","g","globalThis","Function","obj","prop","prototype","hasOwnProperty","inProgress","dataWebpackPrefix","l","done","script","needAttach","scripts","getElementsByTagName","s","getAttribute","charset","nc","setAttribute","onScriptComplete","prev","event","clearTimeout","timeout","doneFns","parentNode","removeChild","setTimeout","bind","target","Symbol","toStringTag","p","createStylesheet","fullhref","oldTag","linkTag","nonce","onLinkComplete","errorType","realHref","code","insertBefore","nextSibling","findStylesheet","existingLinkTags","tag","dataHref","existingStyleTags","loadStylesheet","installedCssChunks","miniCss","cssChunks","installedChunks","installedChunkData","test","promise","loadingEnded","realSrc","message","webpackJsonpCallback","parentChunkLoadingFunction","moreModules","runtime","some","id","chunkLoadingGlobal","self","__webpack_exports__"],"ignoreList":[],"sourceRoot":""} \ No newline at end of file diff --git a/js/app.f4ce2fc3.js.map.gz b/js/app.f4ce2fc3.js.map.gz new file mode 100644 index 0000000..0e588b8 Binary files /dev/null and b/js/app.f4ce2fc3.js.map.gz differ diff --git a/js/chunk-vendors.780b6559.js.gz b/js/chunk-vendors.780b6559.js.gz deleted file mode 100644 index cc4d4d1..0000000 Binary files a/js/chunk-vendors.780b6559.js.gz and /dev/null differ diff --git a/js/chunk-vendors.780b6559.js.map.gz b/js/chunk-vendors.780b6559.js.map.gz deleted file mode 100644 index e0ba00f..0000000 Binary files a/js/chunk-vendors.780b6559.js.map.gz and /dev/null differ diff --git a/js/chunk-vendors.780b6559.js b/js/chunk-vendors.92518219.js similarity index 90% rename from js/chunk-vendors.780b6559.js rename to js/chunk-vendors.92518219.js index f2b4317..4cd189c 100644 --- a/js/chunk-vendors.780b6559.js +++ b/js/chunk-vendors.92518219.js @@ -1,4 +1,4 @@ -(self["webpackChunksanyue_imghub"]=self["webpackChunksanyue_imghub"]||[]).push([[504],{17:function(e,t,l){"use strict";l.d(t,{qE:function(){return C},AI:function(){return v},bW:function(){return S},uA:function(){return v},D_:function(){return k},oc:function(){return h},C8:function(){return g},Tn:function(){return b},un:function(){return L},Kg:function(){return y},lQ:function(){return w},jN:function(){return N},V7:function(){return T},x_:function(){return x},rd:function(){return W},Uo:function(){return E},xD:function(){return _},k3:function(){return O},TO:function(){return B}});l(4114),l(8111),l(1148),l(2489),l(116),l(7588),l(1701),l(8237),l(3579),l(7642),l(8004),l(3853),l(5876),l(2475),l(5024),l(1698);var n=l(144),a=l(6768);var o,c=Object.defineProperty,r=Object.defineProperties,s=Object.getOwnPropertyDescriptors,i=Object.getOwnPropertySymbols,u=Object.prototype.hasOwnProperty,d=Object.prototype.propertyIsEnumerable,f=(e,t,l)=>t in e?c(e,t,{enumerable:!0,configurable:!0,writable:!0,value:l}):e[t]=l,p=(e,t)=>{for(var l in t||(t={}))u.call(t,l)&&f(e,l,t[l]);if(i)for(var l of i(t))d.call(t,l)&&f(e,l,t[l]);return e},m=(e,t)=>r(e,s(t));function v(e,t){var l;const o=(0,n.IJ)();return(0,a.nT)(()=>{o.value=e()},m(p({},t),{flush:null!=(l=null==t?void 0:t.flush)?l:"sync"})),(0,n.tB)(o)}const h="undefined"!==typeof window,g=e=>"undefined"!==typeof e,b=(Object.prototype.toString,e=>"function"===typeof e),y=e=>"string"===typeof e,C=(e,t,l)=>Math.min(l,Math.max(t,e)),w=()=>{},L=h&&(null==(o=null==window?void 0:window.navigator)?void 0:o.userAgent)&&/iP(ad|hone|od)/.test(window.navigator.userAgent);function x(e){return"function"===typeof e?e():(0,n.R1)(e)}function M(e,t){function l(...l){return new Promise((n,a)=>{Promise.resolve(e(()=>t.apply(this,l),{fn:t,thisArg:this,args:l})).then(n).catch(a)})}return l}function z(e,t={}){let l,n,a=w;const o=e=>{clearTimeout(e),a(),a=w},c=c=>{const r=x(e),s=x(t.maxWait);return l&&o(l),r<=0||void 0!==s&&s<=0?(n&&(o(n),n=null),Promise.resolve(c())):new Promise((e,i)=>{a=t.rejectOnCancel?i:e,s&&!n&&(n=setTimeout(()=>{l&&o(l),n=null,e(c())},s)),l=setTimeout(()=>{n&&o(n),n=null,e(c())},r)})};return c}function R(e,t=!0,l=!0,n=!1){let a,o,c=0,r=!0,s=w;const i=()=>{a&&(clearTimeout(a),a=void 0,s(),s=w)},u=u=>{const d=x(e),f=Date.now()-c,p=()=>o=u();return i(),d<=0?(c=Date.now(),p()):(f>d&&(l||!r)?(c=Date.now(),p()):t&&(o=new Promise((e,t)=>{s=n?t:e,a=setTimeout(()=>{c=Date.now(),r=!0,e(p()),i()},Math.max(0,d-f))})),l||a||(a=setTimeout(()=>r=!0,d)),r=!1,o)};return u}function k(e){return e}function S(e,t){let l,o,c;const r=(0,n.KR)(!0),s=()=>{r.value=!0,c()};(0,a.wB)(e,s,{flush:"sync"});const i=b(t)?t:t.get,u=b(t)?void 0:t.set,d=(0,n.rY)((e,t)=>(o=e,c=t,{get(){return r.value&&(l=i(),r.value=!1),o(),l},set(e){null==u||u(e)}}));return Object.isExtensible(d)&&(d.trigger=s),d}function E(e){return!!(0,n.o5)()&&((0,n.jr)(e),!0)}Object.defineProperty,Object.getOwnPropertySymbols,Object.prototype.hasOwnProperty,Object.prototype.propertyIsEnumerable;function A(e){if(!(0,n.i9)(e))return(0,n.Kh)(e);const t=new Proxy({},{get(t,l,a){return(0,n.R1)(Reflect.get(e.value,l,a))},set(t,l,a){return(0,n.i9)(e.value[l])&&!(0,n.i9)(a)?e.value[l].value=a:e.value[l]=a,!0},deleteProperty(t,l){return Reflect.deleteProperty(e.value,l)},has(t,l){return Reflect.has(e.value,l)},ownKeys(){return Object.keys(e.value)},getOwnPropertyDescriptor(){return{enumerable:!0,configurable:!0}}});return(0,n.Kh)(t)}function N(e){return A((0,a.EW)(e))}function _(e,t=200,l={}){return M(z(t,l),e)}function T(e,t=200,l={}){const o=(0,n.KR)(e.value),c=_(()=>{o.value=e.value},t,l);return(0,a.wB)(e,()=>c()),o}function O(e,t=200,l=!1,n=!0,a=!1){return M(R(t,l,n,a),e)}Object.defineProperty,Object.defineProperties,Object.getOwnPropertyDescriptors,Object.getOwnPropertySymbols,Object.prototype.hasOwnProperty,Object.prototype.propertyIsEnumerable;function W(e,t=!0){(0,a.nI)()?(0,a.sV)(e):t?e():(0,a.dY)(e)}Object.defineProperty,Object.getOwnPropertySymbols,Object.prototype.hasOwnProperty,Object.prototype.propertyIsEnumerable;function B(e,t,l={}){const{immediate:a=!0}=l,o=(0,n.KR)(!1);let c=null;function r(){c&&(clearTimeout(c),c=null)}function s(){o.value=!1,r()}function i(...l){r(),o.value=!0,c=setTimeout(()=>{o.value=!1,c=null,e(...l)},x(t))}return a&&(o.value=!0,h&&i()),E(s),{isPending:(0,n.tB)(o),start:i,stop:s}}Object.defineProperty,Object.getOwnPropertySymbols,Object.prototype.hasOwnProperty,Object.prototype.propertyIsEnumerable;Object.getOwnPropertySymbols,Object.prototype.hasOwnProperty,Object.prototype.propertyIsEnumerable;Object.getOwnPropertySymbols,Object.prototype.hasOwnProperty,Object.prototype.propertyIsEnumerable;Object.defineProperty,Object.defineProperties,Object.getOwnPropertyDescriptors,Object.getOwnPropertySymbols,Object.prototype.hasOwnProperty,Object.prototype.propertyIsEnumerable;Object.defineProperty,Object.defineProperties,Object.getOwnPropertyDescriptors,Object.getOwnPropertySymbols,Object.prototype.hasOwnProperty,Object.prototype.propertyIsEnumerable;Object.defineProperty,Object.defineProperties,Object.getOwnPropertyDescriptors,Object.getOwnPropertySymbols,Object.prototype.hasOwnProperty,Object.prototype.propertyIsEnumerable;Object.defineProperty,Object.defineProperties,Object.getOwnPropertyDescriptors,Object.getOwnPropertySymbols,Object.prototype.hasOwnProperty,Object.prototype.propertyIsEnumerable;Object.defineProperty,Object.defineProperties,Object.getOwnPropertyDescriptors,Object.getOwnPropertySymbols,Object.prototype.hasOwnProperty,Object.prototype.propertyIsEnumerable},34:function(e,t,l){"use strict";var n=l(4901);e.exports=function(e){return"object"==typeof e?null!==e:n(e)}},37:function(e,t,l){"use strict";var n=l(9937),a=l(5867),o=l(7431);function c(e,t){return(0,o.A)((0,a.A)(e,t,n.A),e+"")}t.A=c},47:function(e,t,l){"use strict";l.d(t,{S2:function(){return S},fg:function(){return E}});var n=l(6768),a=l(144),o=l(4232),c=l(813);const r=Symbol("buttonGroupContextKey");var s=l(261),i=l(8114),u=l(4216),d=l(2436);const f=(e,t)=>{(0,s.b)({from:"type.text",replacement:"link",version:"3.0.0",scope:"props",ref:"https://element-plus.org/en-US/component/button.html#button-attributes"},(0,n.EW)(()=>"text"===e.type));const l=(0,n.WQ)(r,void 0),o=(0,i.H3)("button"),{form:c}=(0,u.j)(),f=(0,d.NV)((0,n.EW)(()=>null==l?void 0:l.size)),p=(0,d.CB)(),m=(0,a.KR)(),v=(0,n.Ht)(),h=(0,n.EW)(()=>{var t;return e.type||(null==l?void 0:l.type)||(null==(t=o.value)?void 0:t.type)||""}),g=(0,n.EW)(()=>{var t,l,n;return null!=(n=null!=(l=e.autoInsertSpace)?l:null==(t=o.value)?void 0:t.autoInsertSpace)&&n}),b=(0,n.EW)(()=>{var t,l,n;return null!=(n=null!=(l=e.plain)?l:null==(t=o.value)?void 0:t.plain)&&n}),y=(0,n.EW)(()=>{var t,l,n;return null!=(n=null!=(l=e.round)?l:null==(t=o.value)?void 0:t.round)&&n}),C=(0,n.EW)(()=>{var t,l,n;return null!=(n=null!=(l=e.text)?l:null==(t=o.value)?void 0:t.text)&&n}),w=(0,n.EW)(()=>"button"===e.tag?{ariaDisabled:p.value||e.loading,disabled:p.value||e.loading,autofocus:e.autofocus,type:e.nativeType}:{}),L=(0,n.EW)(()=>{var e;const t=null==(e=v.default)?void 0:e.call(v);if(g.value&&1===(null==t?void 0:t.length)){const e=t[0];if((null==e?void 0:e.type)===n.EY){const t=e.children;return/^\p{Unified_Ideograph}{2}$/u.test(t.trim())}}return!1}),x=l=>{p.value||e.loading?l.stopPropagation():("reset"===e.nativeType&&(null==c||c.resetFields()),t("click",l))};return{_disabled:p,_size:f,_type:h,_ref:m,_props:w,_plain:b,_round:y,_text:C,shouldAddSpace:L,handleClick:x}};var p=l(1585),m=l(1513),v=l(3513);function h(e,t=20){return e.mix("#141414",t).toString()}function g(e){const t=(0,d.CB)(),l=(0,v.DU)("button");return(0,n.EW)(()=>{let n={},a=e.color;if(a){const o=a.match(/var\((.*?)\)/);o&&(a=window.getComputedStyle(window.document.documentElement).getPropertyValue(o[1]));const c=new m.q(a),r=e.dark?c.tint(20).toString():h(c,20);if(e.plain)n=l.cssVarBlock({"bg-color":e.dark?h(c,90):c.tint(90).toString(),"text-color":a,"border-color":e.dark?h(c,50):c.tint(50).toString(),"hover-text-color":`var(${l.cssVarName("color-white")})`,"hover-bg-color":a,"hover-border-color":a,"active-bg-color":r,"active-text-color":`var(${l.cssVarName("color-white")})`,"active-border-color":r}),t.value&&(n[l.cssVarBlockName("disabled-bg-color")]=e.dark?h(c,90):c.tint(90).toString(),n[l.cssVarBlockName("disabled-text-color")]=e.dark?h(c,50):c.tint(50).toString(),n[l.cssVarBlockName("disabled-border-color")]=e.dark?h(c,80):c.tint(80).toString());else{const o=e.dark?h(c,30):c.tint(30).toString(),s=c.isDark()?`var(${l.cssVarName("color-white")})`:`var(${l.cssVarName("color-black")})`;if(n=l.cssVarBlock({"bg-color":a,"text-color":s,"border-color":a,"hover-bg-color":o,"hover-text-color":s,"hover-border-color":o,"active-bg-color":r,"active-border-color":r}),t.value){const t=e.dark?h(c,50):c.tint(50).toString();n[l.cssVarBlockName("disabled-bg-color")]=t,n[l.cssVarBlockName("disabled-text-color")]=e.dark?"rgba(255, 255, 255, 0.5)":`var(${l.cssVarName("color-white")})`,n[l.cssVarBlockName("disabled-border-color")]=t}}}return n})}var b=l(9077);const y=(0,n.pM)({name:"ElButton"}),C=(0,n.pM)({...y,props:p.D$,emits:p.ro,setup(e,{expose:t,emit:l}){const r=e,s=g(r),i=(0,v.DU)("button"),{_ref:u,_size:d,_type:p,_disabled:m,_props:h,_plain:b,_round:y,_text:C,shouldAddSpace:w,handleClick:L}=f(r,l),x=(0,n.EW)(()=>[i.b(),i.m(p.value),i.m(d.value),i.is("disabled",m.value),i.is("loading",r.loading),i.is("plain",b.value),i.is("round",y.value),i.is("circle",r.circle),i.is("text",C.value),i.is("link",r.link),i.is("has-bg",r.bg)]);return t({ref:u,size:d,type:p,disabled:m,shouldAddSpace:w}),(e,t)=>((0,n.uX)(),(0,n.Wv)((0,n.$y)(e.tag),(0,n.v6)({ref_key:"_ref",ref:u},(0,a.R1)(h),{class:(0,a.R1)(x),style:(0,a.R1)(s),onClick:(0,a.R1)(L)}),{default:(0,n.k6)(()=>[e.loading?((0,n.uX)(),(0,n.CE)(n.FK,{key:0},[e.$slots.loading?(0,n.RG)(e.$slots,"loading",{key:0}):((0,n.uX)(),(0,n.Wv)((0,a.R1)(c.tk),{key:1,class:(0,o.C4)((0,a.R1)(i).is("loading"))},{default:(0,n.k6)(()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)(e.loadingIcon)))]),_:1},8,["class"]))],64)):e.icon||e.$slots.icon?((0,n.uX)(),(0,n.Wv)((0,a.R1)(c.tk),{key:1},{default:(0,n.k6)(()=>[e.icon?((0,n.uX)(),(0,n.Wv)((0,n.$y)(e.icon),{key:0})):(0,n.RG)(e.$slots,"icon",{key:1})]),_:3})):(0,n.Q3)("v-if",!0),e.$slots.default?((0,n.uX)(),(0,n.CE)("span",{key:2,class:(0,o.C4)({[(0,a.R1)(i).em("text","expand")]:(0,a.R1)(w)})},[(0,n.RG)(e.$slots,"default")],2)):(0,n.Q3)("v-if",!0)]),_:3},16,["class","style","onClick"]))}});var w=(0,b.A)(C,[["__file","button.vue"]]),L=l(7378);const x={size:p.D$.size,type:p.D$.type,direction:{type:(0,L.jq)(String),values:["horizontal","vertical"],default:"horizontal"}},M=(0,n.pM)({name:"ElButtonGroup"}),z=(0,n.pM)({...M,props:x,setup(e){const t=e;(0,n.Gt)(r,(0,a.Kh)({size:(0,a.lW)(t,"size"),type:(0,a.lW)(t,"type")}));const l=(0,v.DU)("button");return(e,c)=>((0,n.uX)(),(0,n.CE)("div",{class:(0,o.C4)([(0,a.R1)(l).b("group"),(0,a.R1)(l).bm("group",t.direction)])},[(0,n.RG)(e.$slots,"default")],2))}});var R=(0,b.A)(z,[["__file","button-group.vue"]]),k=l(5376);const S=(0,k.GU)(w,{ButtonGroup:R}),E=(0,k.WM)(R)},81:function(e,t,l){"use strict";var n=l(9565),a=l(9306),o=l(8551),c=l(6823),r=l(851),s=TypeError;e.exports=function(e,t){var l=arguments.length<2?r(e):t;if(a(l))return o(n(l,e));throw new s(c(e)+" is not iterable")}},90:function(e,t,l){"use strict";l.d(t,{s:function(){return a}});var n=l(7378);const a=(0,n.b_)({arrowOffset:{type:Number,default:5}})},116:function(e,t,l){"use strict";var n=l(6518),a=l(9565),o=l(2652),c=l(9306),r=l(8551),s=l(1767),i=l(9539),u=l(4549),d=u("find",TypeError);n({target:"Iterator",proto:!0,real:!0,forced:d},{find:function(e){r(this);try{c(e)}catch(n){i(this,"throw",n)}if(d)return a(d,this,e);var t=s(this),l=0;return o(t,function(t,n){if(e(t,l++))return n(t)},{IS_RECORD:!0,INTERRUPTED:!0}).result}})},144:function(e,t,l){"use strict";l.d(t,{C4:function(){return R},EW:function(){return Ge},Gc:function(){return we},IG:function(){return Ee},IJ:function(){return Oe},KR:function(){return Te},Kh:function(){return Ce},Pr:function(){return Ve},QW:function(){return He},R1:function(){return De},Tm:function(){return ze},X2:function(){return d},a1:function(){return Ne},bl:function(){return k},fE:function(){return Re},g8:function(){return Me},hV:function(){return tt},hZ:function(){return D},i9:function(){return _e},jr:function(){return i},ju:function(){return ke},lJ:function(){return Ae},lW:function(){return Xe},mu:function(){return Ie},o5:function(){return s},qA:function(){return P},rY:function(){return $e},tB:function(){return Le},u4:function(){return I},uY:function(){return r},ux:function(){return Se},wB:function(){return et},yC:function(){return c}});l(4114),l(8111),l(2489),l(7588),l(1701),l(3579),l(7642),l(8004),l(3853),l(5876),l(2475),l(5024),l(1698);var n=l(4232);let a,o;class c{constructor(e=!1){this.detached=e,this._active=!0,this._on=0,this.effects=[],this.cleanups=[],this._isPaused=!1,this.parent=a,!e&&a&&(this.index=(a.scopes||(a.scopes=[])).push(this)-1)}get active(){return this._active}pause(){if(this._active){let e,t;if(this._isPaused=!0,this.scopes)for(e=0,t=this.scopes.length;e0&&0===--this._on&&(a=this.prevScope,this.prevScope=void 0)}stop(e){if(this._active){let t,l;for(this._active=!1,t=0,l=this.effects.length;t0)return;if(p){let e=p;p=void 0;while(e){const t=e.next;e.next=void 0,e.flags&=-9,e=t}}let e;while(f){let l=f;f=void 0;while(l){const n=l.next;if(l.next=void 0,l.flags&=-9,1&l.flags)try{l.trigger()}catch(t){e||(e=t)}l=n}}if(e)throw e}function b(e){for(let t=e.deps;t;t=t.nextDep)t.version=-1,t.prevActiveLink=t.dep.activeLink,t.dep.activeLink=t}function y(e){let t,l=e.depsTail,n=l;while(n){const e=n.prevDep;-1===n.version?(n===l&&(l=e),L(n),x(n)):t=n,n.dep.activeLink=n.prevActiveLink,n.prevActiveLink=void 0,n=e}e.deps=t,e.depsTail=l}function C(e){for(let t=e.deps;t;t=t.nextDep)if(t.dep.version!==t.version||t.dep.computed&&(w(t.dep.computed)||t.dep.version!==t.version))return!0;return!!e._dirty}function w(e){if(4&e.flags&&!(16&e.flags))return;if(e.flags&=-17,e.globalVersion===E)return;if(e.globalVersion=E,!e.isSSR&&128&e.flags&&(!e.deps&&!e._dirty||!C(e)))return;e.flags|=2;const t=e.dep,l=o,a=M;o=e,M=!0;try{b(e);const l=e.fn(e._value);(0===t.version||(0,n.$H)(l,e._value))&&(e.flags|=128,e._value=l,t.version++)}catch(c){throw t.version++,c}finally{o=l,M=a,y(e),e.flags&=-3}}function L(e,t=!1){const{dep:l,prevSub:n,nextSub:a}=e;if(n&&(n.nextSub=a,e.prevSub=void 0),a&&(a.prevSub=n,e.nextSub=void 0),l.subs===e&&(l.subs=n,!n&&l.computed)){l.computed.flags&=-5;for(let e=l.computed.deps;e;e=e.nextDep)L(e,!0)}t||--l.sc||!l.map||l.map.delete(l.key)}function x(e){const{prevDep:t,nextDep:l}=e;t&&(t.nextDep=l,e.prevDep=void 0),l&&(l.prevDep=t,e.nextDep=void 0)}let M=!0;const z=[];function R(){z.push(M),M=!1}function k(){const e=z.pop();M=void 0===e||e}function S(e){const{cleanup:t}=e;if(e.cleanup=void 0,t){const e=o;o=void 0;try{t()}finally{o=e}}}let E=0;class A{constructor(e,t){this.sub=e,this.dep=t,this.version=t.version,this.nextDep=this.prevDep=this.nextSub=this.prevSub=this.prevActiveLink=void 0}}class N{constructor(e){this.computed=e,this.version=0,this.activeLink=void 0,this.subs=void 0,this.map=void 0,this.key=void 0,this.sc=0,this.__v_skip=!0}track(e){if(!o||!M||o===this.computed)return;let t=this.activeLink;if(void 0===t||t.sub!==o)t=this.activeLink=new A(o,this),o.deps?(t.prevDep=o.depsTail,o.depsTail.nextDep=t,o.depsTail=t):o.deps=o.depsTail=t,_(t);else if(-1===t.version&&(t.version=this.version,t.nextDep)){const e=t.nextDep;e.prevDep=t.prevDep,t.prevDep&&(t.prevDep.nextDep=e),t.prevDep=o.depsTail,t.nextDep=void 0,o.depsTail.nextDep=t,o.depsTail=t,o.deps===t&&(o.deps=e)}return t}trigger(e){this.version++,E++,this.notify(e)}notify(e){h();try{0;for(let e=this.subs;e;e=e.prevSub)e.sub.notify()&&e.sub.dep.notify()}finally{g()}}}function _(e){if(e.dep.sc++,4&e.sub.flags){const t=e.dep.computed;if(t&&!e.dep.subs){t.flags|=20;for(let e=t.deps;e;e=e.nextDep)_(e)}const l=e.dep.subs;l!==e&&(e.prevSub=l,l&&(l.nextSub=e)),e.dep.subs=e}}const T=new WeakMap,O=Symbol(""),W=Symbol(""),B=Symbol("");function I(e,t,l){if(M&&o){let t=T.get(e);t||T.set(e,t=new Map);let n=t.get(l);n||(t.set(l,n=new N),n.map=t,n.key=l),n.track()}}function D(e,t,l,a,o,c){const r=T.get(e);if(!r)return void E++;const s=e=>{e&&e.trigger()};if(h(),"clear"===t)r.forEach(s);else{const o=(0,n.cy)(e),c=o&&(0,n.yI)(l);if(o&&"length"===l){const e=Number(a);r.forEach((t,l)=>{("length"===l||l===B||!(0,n.Bm)(l)&&l>=e)&&s(t)})}else switch((void 0!==l||r.has(void 0))&&s(r.get(l)),c&&s(r.get(B)),t){case"add":o?c&&s(r.get("length")):(s(r.get(O)),(0,n.CE)(e)&&s(r.get(W)));break;case"delete":o||(s(r.get(O)),(0,n.CE)(e)&&s(r.get(W)));break;case"set":(0,n.CE)(e)&&s(r.get(O));break}}g()}function F(e,t){const l=T.get(e);return l&&l.get(t)}function V(e){const t=Se(e);return t===e?t:(I(t,"iterate",B),Re(e)?t:t.map(Ae))}function P(e){return I(e=Se(e),"iterate",B),e}function $(e,t){return ze(e)?Me(e)?Ne(Ae(t)):Ne(t):Ae(t)}const H={__proto__:null,[Symbol.iterator](){return j(this,Symbol.iterator,e=>$(this,e))},concat(...e){return V(this).concat(...e.map(e=>(0,n.cy)(e)?V(e):e))},entries(){return j(this,"entries",e=>(e[1]=$(this,e[1]),e))},every(e,t){return X(this,"every",e,t,void 0,arguments)},filter(e,t){return X(this,"filter",e,t,e=>e.map(e=>$(this,e)),arguments)},find(e,t){return X(this,"find",e,t,e=>$(this,e),arguments)},findIndex(e,t){return X(this,"findIndex",e,t,void 0,arguments)},findLast(e,t){return X(this,"findLast",e,t,e=>$(this,e),arguments)},findLastIndex(e,t){return X(this,"findLastIndex",e,t,void 0,arguments)},forEach(e,t){return X(this,"forEach",e,t,void 0,arguments)},includes(...e){return q(this,"includes",e)},indexOf(...e){return q(this,"indexOf",e)},join(e){return V(this).join(e)},lastIndexOf(...e){return q(this,"lastIndexOf",e)},map(e,t){return X(this,"map",e,t,void 0,arguments)},pop(){return G(this,"pop")},push(...e){return G(this,"push",e)},reduce(e,...t){return U(this,"reduce",e,t)},reduceRight(e,...t){return U(this,"reduceRight",e,t)},shift(){return G(this,"shift")},some(e,t){return X(this,"some",e,t,void 0,arguments)},splice(...e){return G(this,"splice",e)},toReversed(){return V(this).toReversed()},toSorted(e){return V(this).toSorted(e)},toSpliced(...e){return V(this).toSpliced(...e)},unshift(...e){return G(this,"unshift",e)},values(){return j(this,"values",e=>$(this,e))}};function j(e,t,l){const n=P(e),a=n[t]();return n===e||Re(e)||(a._next=a.next,a.next=()=>{const e=a._next();return e.done||(e.value=l(e.value)),e}),a}const K=Array.prototype;function X(e,t,l,n,a,o){const c=P(e),r=c!==e&&!Re(e),s=c[t];if(s!==K[t]){const t=s.apply(e,o);return r?Ae(t):t}let i=l;c!==e&&(r?i=function(t,n){return l.call(this,$(e,t),n,e)}:l.length>2&&(i=function(t,n){return l.call(this,t,n,e)}));const u=s.call(c,i,n);return r&&a?a(u):u}function U(e,t,l,n){const a=P(e);let o=l;return a!==e&&(Re(e)?l.length>3&&(o=function(t,n,a){return l.call(this,t,n,a,e)}):o=function(t,n,a){return l.call(this,t,$(e,n),a,e)}),a[t](o,...n)}function q(e,t,l){const n=Se(e);I(n,"iterate",B);const a=n[t](...l);return-1!==a&&!1!==a||!ke(l[0])?a:(l[0]=Se(l[0]),n[t](...l))}function G(e,t,l=[]){R(),h();const n=Se(e)[t].apply(e,l);return g(),k(),n}const Y=(0,n.pD)("__proto__,__v_isRef,__isVue"),Q=new Set(Object.getOwnPropertyNames(Symbol).filter(e=>"arguments"!==e&&"caller"!==e).map(e=>Symbol[e]).filter(n.Bm));function Z(e){(0,n.Bm)(e)||(e=String(e));const t=Se(this);return I(t,"has",e),t.hasOwnProperty(e)}class J{constructor(e=!1,t=!1){this._isReadonly=e,this._isShallow=t}get(e,t,l){if("__v_skip"===t)return e["__v_skip"];const a=this._isReadonly,o=this._isShallow;if("__v_isReactive"===t)return!a;if("__v_isReadonly"===t)return a;if("__v_isShallow"===t)return o;if("__v_raw"===t)return l===(a?o?ge:he:o?ve:me).get(e)||Object.getPrototypeOf(e)===Object.getPrototypeOf(l)?e:void 0;const c=(0,n.cy)(e);if(!a){let e;if(c&&(e=H[t]))return e;if("hasOwnProperty"===t)return Z}const r=Reflect.get(e,t,_e(e)?e:l);if((0,n.Bm)(t)?Q.has(t):Y(t))return r;if(a||I(e,"get",t),o)return r;if(_e(r)){const e=c&&(0,n.yI)(t)?r:r.value;return a&&(0,n.Gv)(e)?Le(e):e}return(0,n.Gv)(r)?a?Le(r):Ce(r):r}}class ee extends J{constructor(e=!1){super(!1,e)}set(e,t,l,a){let o=e[t];const c=(0,n.cy)(e)&&(0,n.yI)(t);if(!this._isShallow){const e=ze(o);if(Re(l)||ze(l)||(o=Se(o),l=Se(l)),!c&&_e(o)&&!_e(l))return e||(o.value=l),!0}const r=c?Number(t)e,ce=e=>Reflect.getPrototypeOf(e);function re(e,t,l){return function(...a){const o=this["__v_raw"],c=Se(o),r=(0,n.CE)(c),s="entries"===e||e===Symbol.iterator&&r,i="keys"===e&&r,u=o[e](...a),d=l?oe:t?Ne:Ae;return!t&&I(c,"iterate",i?W:O),{next(){const{value:e,done:t}=u.next();return t?{value:e,done:t}:{value:s?[d(e[0]),d(e[1])]:d(e),done:t}},[Symbol.iterator](){return this}}}}function se(e){return function(...t){return"delete"!==e&&("clear"===e?void 0:this)}}function ie(e,t){const l={get(l){const a=this["__v_raw"],o=Se(a),c=Se(l);e||((0,n.$H)(l,c)&&I(o,"get",l),I(o,"get",c));const{has:r}=ce(o),s=t?oe:e?Ne:Ae;return r.call(o,l)?s(a.get(l)):r.call(o,c)?s(a.get(c)):void(a!==o&&a.get(l))},get size(){const t=this["__v_raw"];return!e&&I(Se(t),"iterate",O),t.size},has(t){const l=this["__v_raw"],a=Se(l),o=Se(t);return e||((0,n.$H)(t,o)&&I(a,"has",t),I(a,"has",o)),t===o?l.has(t):l.has(t)||l.has(o)},forEach(l,n){const a=this,o=a["__v_raw"],c=Se(o),r=t?oe:e?Ne:Ae;return!e&&I(c,"iterate",O),o.forEach((e,t)=>l.call(n,r(e),r(t),a))}};(0,n.X$)(l,e?{add:se("add"),set:se("set"),delete:se("delete"),clear:se("clear")}:{add(e){t||Re(e)||ze(e)||(e=Se(e));const l=Se(this),n=ce(l),a=n.has.call(l,e);return a||(l.add(e),D(l,"add",e,e)),this},set(e,l){t||Re(l)||ze(l)||(l=Se(l));const a=Se(this),{has:o,get:c}=ce(a);let r=o.call(a,e);r||(e=Se(e),r=o.call(a,e));const s=c.call(a,e);return a.set(e,l),r?(0,n.$H)(l,s)&&D(a,"set",e,l,s):D(a,"add",e,l),this},delete(e){const t=Se(this),{has:l,get:n}=ce(t);let a=l.call(t,e);a||(e=Se(e),a=l.call(t,e));const o=n?n.call(t,e):void 0,c=t.delete(e);return a&&D(t,"delete",e,void 0,o),c},clear(){const e=Se(this),t=0!==e.size,l=void 0,n=e.clear();return t&&D(e,"clear",void 0,void 0,l),n}});const a=["keys","values","entries",Symbol.iterator];return a.forEach(n=>{l[n]=re(n,e,t)}),l}function ue(e,t){const l=ie(e,t);return(t,a,o)=>"__v_isReactive"===a?!e:"__v_isReadonly"===a?e:"__v_raw"===a?t:Reflect.get((0,n.$3)(l,a)&&a in t?l:t,a,o)}const de={get:ue(!1,!1)},fe={get:ue(!1,!0)},pe={get:ue(!0,!1)};const me=new WeakMap,ve=new WeakMap,he=new WeakMap,ge=new WeakMap;function be(e){switch(e){case"Object":case"Array":return 1;case"Map":case"Set":case"WeakMap":case"WeakSet":return 2;default:return 0}}function ye(e){return e["__v_skip"]||!Object.isExtensible(e)?0:be((0,n.Zf)(e))}function Ce(e){return ze(e)?e:xe(e,!1,le,de,me)}function we(e){return xe(e,!1,ae,fe,ve)}function Le(e){return xe(e,!0,ne,pe,he)}function xe(e,t,l,a,o){if(!(0,n.Gv)(e))return e;if(e["__v_raw"]&&(!t||!e["__v_isReactive"]))return e;const c=ye(e);if(0===c)return e;const r=o.get(e);if(r)return r;const s=new Proxy(e,2===c?a:l);return o.set(e,s),s}function Me(e){return ze(e)?Me(e["__v_raw"]):!(!e||!e["__v_isReactive"])}function ze(e){return!(!e||!e["__v_isReadonly"])}function Re(e){return!(!e||!e["__v_isShallow"])}function ke(e){return!!e&&!!e["__v_raw"]}function Se(e){const t=e&&e["__v_raw"];return t?Se(t):e}function Ee(e){return!(0,n.$3)(e,"__v_skip")&&Object.isExtensible(e)&&(0,n.yQ)(e,"__v_skip",!0),e}const Ae=e=>(0,n.Gv)(e)?Ce(e):e,Ne=e=>(0,n.Gv)(e)?Le(e):e;function _e(e){return!!e&&!0===e["__v_isRef"]}function Te(e){return We(e,!1)}function Oe(e){return We(e,!0)}function We(e,t){return _e(e)?e:new Be(e,t)}class Be{constructor(e,t){this.dep=new N,this["__v_isRef"]=!0,this["__v_isShallow"]=!1,this._rawValue=t?e:Se(e),this._value=t?e:Ae(e),this["__v_isShallow"]=t}get value(){return this.dep.track(),this._value}set value(e){const t=this._rawValue,l=this["__v_isShallow"]||Re(e)||ze(e);e=l?e:Se(e),(0,n.$H)(e,t)&&(this._rawValue=e,this._value=l?e:Ae(e),this.dep.trigger())}}function Ie(e){e.dep&&e.dep.trigger()}function De(e){return _e(e)?e.value:e}const Fe={get:(e,t,l)=>"__v_raw"===t?e:De(Reflect.get(e,t,l)),set:(e,t,l,n)=>{const a=e[t];return _e(a)&&!_e(l)?(a.value=l,!0):Reflect.set(e,t,l,n)}};function Ve(e){return Me(e)?e:new Proxy(e,Fe)}class Pe{constructor(e){this["__v_isRef"]=!0,this._value=void 0;const t=this.dep=new N,{get:l,set:n}=e(t.track.bind(t),t.trigger.bind(t));this._get=l,this._set=n}get value(){return this._value=this._get()}set value(e){this._set(e)}}function $e(e){return new Pe(e)}function He(e){const t=(0,n.cy)(e)?new Array(e.length):{};for(const l in e)t[l]=Ue(e,l);return t}class je{constructor(e,t,l){this._object=e,this._key=t,this._defaultValue=l,this["__v_isRef"]=!0,this._value=void 0,this._raw=Se(e);let a=!0,o=e;if(!(0,n.cy)(e)||!(0,n.yI)(String(t)))do{a=!ke(o)||Re(o)}while(a&&(o=o["__v_raw"]));this._shallow=a}get value(){let e=this._object[this._key];return this._shallow&&(e=De(e)),this._value=void 0===e?this._defaultValue:e}set value(e){if(this._shallow&&_e(this._raw[this._key])){const t=this._object[this._key];if(_e(t))return void(t.value=e)}this._object[this._key]=e}get dep(){return F(this._raw,this._key)}}class Ke{constructor(e){this._getter=e,this["__v_isRef"]=!0,this["__v_isReadonly"]=!0,this._value=void 0}get value(){return this._value=this._getter()}}function Xe(e,t,l){return _e(e)?e:(0,n.Tn)(e)?new Ke(e):(0,n.Gv)(e)&&arguments.length>1?Ue(e,t,l):Te(e)}function Ue(e,t,l){return new je(e,t,l)}class qe{constructor(e,t,l){this.fn=e,this.setter=t,this._value=void 0,this.dep=new N(this),this.__v_isRef=!0,this.deps=void 0,this.depsTail=void 0,this.flags=16,this.globalVersion=E-1,this.next=void 0,this.effect=this,this["__v_isReadonly"]=!t,this.isSSR=l}notify(){if(this.flags|=16,!(8&this.flags||o===this))return v(this,!0),!0}get value(){const e=this.dep.track();return w(this),e&&(e.version=this.dep.version),this._value}set value(e){this.setter&&this.setter(e)}}function Ge(e,t,l=!1){let a,o;(0,n.Tn)(e)?a=e:(a=e.get,o=e.set);const c=new qe(a,o,l);return c}const Ye={},Qe=new WeakMap;let Ze;function Je(e,t=!1,l=Ze){if(l){let t=Qe.get(l);t||Qe.set(l,t=[]),t.push(e)}else 0}function et(e,t,l=n.MZ){const{immediate:a,deep:o,once:c,scheduler:r,augmentJob:i,call:u}=l,f=e=>o?e:Re(e)||!1===o||0===o?tt(e,1):tt(e);let p,m,v,h,g=!1,b=!1;if(_e(e)?(m=()=>e.value,g=Re(e)):Me(e)?(m=()=>f(e),g=!0):(0,n.cy)(e)?(b=!0,g=e.some(e=>Me(e)||Re(e)),m=()=>e.map(e=>_e(e)?e.value:Me(e)?f(e):(0,n.Tn)(e)?u?u(e,2):e():void 0)):m=(0,n.Tn)(e)?t?u?()=>u(e,2):e:()=>{if(v){R();try{v()}finally{k()}}const t=Ze;Ze=p;try{return u?u(e,3,[h]):e(h)}finally{Ze=t}}:n.tE,t&&o){const e=m,t=!0===o?1/0:o;m=()=>tt(e(),t)}const y=s(),C=()=>{p.stop(),y&&y.active&&(0,n.TF)(y.effects,p)};if(c&&t){const e=t;t=(...t)=>{e(...t),C()}}let w=b?new Array(e.length).fill(Ye):Ye;const L=e=>{if(1&p.flags&&(p.dirty||e))if(t){const e=p.run();if(o||g||(b?e.some((e,t)=>(0,n.$H)(e,w[t])):(0,n.$H)(e,w))){v&&v();const l=Ze;Ze=p;try{const l=[e,w===Ye?void 0:b&&w[0]===Ye?[]:w,h];w=e,u?u(t,3,l):t(...l)}finally{Ze=l}}}else p.run()};return i&&i(L),p=new d(m),p.scheduler=r?()=>r(L,!1):L,h=e=>Je(e,!1,p),v=p.onStop=()=>{const e=Qe.get(p);if(e){if(u)u(e,4);else for(const t of e)t();Qe.delete(p)}},t?a?L(!0):w=p.run():r?r(L.bind(null,!0),!0):p.run(),C.pause=p.pause.bind(p),C.resume=p.resume.bind(p),C.stop=C,C}function tt(e,t=1/0,l){if(t<=0||!(0,n.Gv)(e)||e["__v_skip"])return e;if(l=l||new Map,(l.get(e)||0)>=t)return e;if(l.set(e,t),t--,_e(e))tt(e.value,t,l);else if((0,n.cy)(e))for(let n=0;n{tt(e,t,l)});else if((0,n.Qd)(e)){for(const n in e)tt(e[n],t,l);for(const n of Object.getOwnPropertySymbols(e))Object.prototype.propertyIsEnumerable.call(e,n)&&tt(e[n],t,l)}return e}},168:function(e,t){"use strict";function l(e){var t=typeof e;return null!=e&&("object"==t||"function"==t)}t.A=l},203:function(e,t,l){"use strict";var n=l(1018),a=l(5014),o=l(2676),c=l(168),r=l(3708);function s(e,t,l,s){if(!(0,c.A)(e))return e;t=(0,a.A)(t,e);var i=-1,u=t.length,d=u-1,f=e;while(null!=f&&++i{(0,n.wB)(()=>(0,a.R1)(i),n=>{n&&(0,o.U)(l,`[${s}] ${e} is about to be deprecated in version ${c}, please use ${t} instead.\nFor more detail, please visit: ${r}\n`)},{immediate:!0})}},283:function(e,t,l){"use strict";var n=l(9504),a=l(9039),o=l(4901),c=l(9297),r=l(3724),s=l(350).CONFIGURABLE,i=l(3706),u=l(1181),d=u.enforce,f=u.get,p=String,m=Object.defineProperty,v=n("".slice),h=n("".replace),g=n([].join),b=r&&!a(function(){return 8!==m(function(){},"length",{value:8}).length}),y=String(String).split("String"),C=e.exports=function(e,t,l){"Symbol("===v(p(t),0,7)&&(t="["+h(p(t),/^Symbol\(([^)]*)\).*$/,"$1")+"]"),l&&l.getter&&(t="get "+t),l&&l.setter&&(t="set "+t),(!c(e,"name")||s&&e.name!==t)&&(r?m(e,"name",{value:t,configurable:!0}):e.name=t),b&&l&&c(l,"arity")&&e.length!==l.arity&&m(e,"length",{value:l.arity});try{l&&c(l,"constructor")&&l.constructor?r&&m(e,"prototype",{writable:!1}):e.prototype&&(e.prototype=void 0)}catch(a){}var n=d(e);return c(n,"source")||(n.source=g(y,"string"==typeof t?t:"")),e};Function.prototype.toString=C(function(){return o(this)&&f(this).source||i(this)},"toString")},292:function(e,t,l){"use strict";l.d(t,{gc:function(){return N}});l(4114),l(8111),l(2489),l(7588),l(1701),l(8237);var n=l(6768),a=l(8950);function o(e,t){(null==t||t>e.length)&&(t=e.length);for(var l=0,n=Array(t);l0||!Array.isArray(t)&&t?r({},e,t):{}}function C(e){var t,l=(t={"fa-spin":e.spin,"fa-pulse":e.pulse,"fa-fw":e.fixedWidth,"fa-border":e.border,"fa-li":e.listItem,"fa-inverse":e.inverse,"fa-flip":!0===e.flip,"fa-flip-horizontal":"horizontal"===e.flip||"both"===e.flip,"fa-flip-vertical":"vertical"===e.flip||"both"===e.flip},r(r(r(r(r(r(r(r(r(r(t,"fa-".concat(e.size),null!==e.size),"fa-rotate-".concat(e.rotation),null!==e.rotation),"fa-rotate-by",e.rotateBy),"fa-pull-".concat(e.pull),null!==e.pull),"fa-swap-opacity",e.swapOpacity),"fa-bounce",e.bounce),"fa-shake",e.shake),"fa-beat",e.beat),"fa-fade",e.fade),"fa-beat-fade",e.beatFade),r(r(r(r(t,"fa-flash",e.flash),"fa-spin-pulse",e.spinPulse),"fa-spin-reverse",e.spinReverse),"fa-width-auto",e.widthAuto));return Object.keys(l).map(function(e){return l[e]?e:null}).filter(function(e){return e})}var w="undefined"!==typeof globalThis?globalThis:"undefined"!==typeof window?window:"undefined"!==typeof l.g?l.g:"undefined"!==typeof self?self:{},L={exports:{}};(function(e){(function(t){var l=function(e,t,n){if(!i(t)||d(t)||f(t)||p(t)||s(t))return t;var a,o=0,c=0;if(u(t))for(a=[],c=t.length;o1&&void 0!==arguments[1]?arguments[1]:{},l=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};if("string"===typeof e)return e;var a=(e.children||[]).map(function(e){return k(e)}),o=Object.keys(e.attributes||{}).reduce(function(t,l){var n=e.attributes[l];switch(l){case"class":t.class=R(n);break;case"style":t.style=z(n);break;default:t.attrs[l]=n}return t},{attrs:{},class:{},style:{}});l.class;var c=l.style,r=void 0===c?{}:c,s=f(l,M);return(0,n.h)(e.tag,d(d(d({},t),{},{class:o.class,style:d(d({},o.style),r)},o.attrs),s),a)}var S=!1;try{S=!0}catch(_){}function E(){var e;!S&&console&&"function"===typeof console.error&&(e=console).error.apply(e,arguments)}function A(e){return e&&"object"===g(e)&&e.prefix&&e.iconName&&e.icon?e:a.qg.icon?a.qg.icon(e):null===e?null:"object"===g(e)&&e.prefix&&e.iconName?e:Array.isArray(e)&&2===e.length?{prefix:e[0],iconName:e[1]}:"string"===typeof e?{prefix:"fas",iconName:e}:void 0}var N=(0,n.pM)({name:"FontAwesomeIcon",props:{border:{type:Boolean,default:!1},fixedWidth:{type:Boolean,default:!1},flip:{type:[Boolean,String],default:!1,validator:function(e){return[!0,!1,"horizontal","vertical","both"].indexOf(e)>-1}},icon:{type:[Object,Array,String],required:!0},mask:{type:[Object,Array,String],default:null},maskId:{type:String,default:null},listItem:{type:Boolean,default:!1},pull:{type:String,default:null,validator:function(e){return["right","left"].indexOf(e)>-1}},pulse:{type:Boolean,default:!1},rotation:{type:[String,Number],default:null,validator:function(e){return[90,180,270].indexOf(Number.parseInt(e,10))>-1}},rotateBy:{type:Boolean,default:!1},swapOpacity:{type:Boolean,default:!1},size:{type:String,default:null,validator:function(e){return["2xs","xs","sm","lg","xl","2xl","1x","2x","3x","4x","5x","6x","7x","8x","9x","10x"].indexOf(e)>-1}},spin:{type:Boolean,default:!1},transform:{type:[String,Object],default:null},symbol:{type:[Boolean,String],default:!1},title:{type:String,default:null},titleId:{type:String,default:null},inverse:{type:Boolean,default:!1},bounce:{type:Boolean,default:!1},shake:{type:Boolean,default:!1},beat:{type:Boolean,default:!1},fade:{type:Boolean,default:!1},beatFade:{type:Boolean,default:!1},flash:{type:Boolean,default:!1},spinPulse:{type:Boolean,default:!1},spinReverse:{type:Boolean,default:!1},widthAuto:{type:Boolean,default:!1}},setup:function(e,t){var l=t.attrs,o=(0,n.EW)(function(){return A(e.icon)}),c=(0,n.EW)(function(){return y("classes",C(e))}),r=(0,n.EW)(function(){return y("transform","string"===typeof e.transform?a.qg.transform(e.transform):e.transform)}),s=(0,n.EW)(function(){return y("mask",A(e.mask))}),i=(0,n.EW)(function(){var t=d(d(d(d({},c.value),r.value),s.value),{},{symbol:e.symbol,maskId:e.maskId});return t.title=e.title,t.titleId=e.titleId,(0,a.Kk)(o.value,t)});(0,n.wB)(i,function(e){if(!e)return E("Could not find one or more icon(s)",o.value,s.value)},{immediate:!0});var u=(0,n.EW)(function(){return i.value?k(i.value.abstract[0],{},l):null});return function(){return u.value}}});(0,n.pM)({name:"FontAwesomeLayers",props:{fixedWidth:{type:Boolean,default:!1}},setup:function(e,t){var l=t.slots,o=a.$W.familyPrefix,c=(0,n.EW)(function(){return["".concat(o,"-layers")].concat(m(e.fixedWidth?["".concat(o,"-fw")]:[]))});return function(){return(0,n.h)("div",{class:c.value},l.default?l.default():[])}}}),(0,n.pM)({name:"FontAwesomeLayersText",props:{value:{type:[String,Number],default:""},transform:{type:[String,Object],default:null},counter:{type:Boolean,default:!1},position:{type:String,default:null,validator:function(e){return["bottom-left","bottom-right","top-left","top-right"].indexOf(e)>-1}}},setup:function(e,t){var l=t.attrs,o=a.$W.familyPrefix,c=(0,n.EW)(function(){return y("classes",[].concat(m(e.counter?["".concat(o,"-layers-counter")]:[]),m(e.position?["".concat(o,"-layers-").concat(e.position)]:[])))}),r=(0,n.EW)(function(){return y("transform","string"===typeof e.transform?a.qg.transform(e.transform):e.transform)}),s=(0,n.EW)(function(){var t=(0,a.Qq)(e.value.toString(),d(d({},r.value),c.value)),l=t.abstract;return e.counter&&(l[0].attributes.class=l[0].attributes.class.replace("fa-layers-text","")),l[0]}),i=(0,n.EW)(function(){return k(s.value,{},l)});return function(){return i.value}}})},339:function(e,t,l){"use strict";var n="object"==typeof l.g&&l.g&&l.g.Object===Object&&l.g;t.A=n},350:function(e,t,l){"use strict";var n=l(3724),a=l(9297),o=Function.prototype,c=n&&Object.getOwnPropertyDescriptor,r=a(o,"name"),s=r&&"something"===function(){}.name,i=r&&(!n||n&&c(o,"name").configurable);e.exports={EXISTS:r,PROPER:s,CONFIGURABLE:i}},372:function(e,t,l){"use strict";l(5331),l(9648),l(6711),l(7197)},397:function(e,t,l){"use strict";var n=l(7751);e.exports=n("document","documentElement")},421:function(e){"use strict";e.exports={}},456:function(e,t,l){"use strict";var n=l(6518),a=l(4576),o=l(9504),c=l(4154),r=l(5169),s=o(1.1.toString),i=a.Uint8Array,u=!i||!i.prototype.toHex||!function(){try{var e=new i([255,255,255,255,255,255,255,255]);return"ffffffffffffffff"===e.toHex()}catch(t){return!1}}();i&&n({target:"Uint8Array",proto:!0,forced:u},{toHex:function(){c(this),r(this.buffer);for(var e="",t=0,l=this.length;t{var r;return(0,n.uX)(),(0,n.CE)("div",{class:(0,a.C4)([(0,o.R1)(l).b(),(0,o.R1)(l).is(`${e.shadow||(null==(r=(0,o.R1)(t))?void 0:r.shadow)||"always"}-shadow`)])},[e.$slots.header||e.header?((0,n.uX)(),(0,n.CE)("div",{key:0,class:(0,a.C4)([(0,o.R1)(l).e("header"),e.headerClass])},[(0,n.RG)(e.$slots,"header",{},()=>[(0,n.eW)((0,a.v_)(e.header),1)])],2)):(0,n.Q3)("v-if",!0),(0,n.Lk)("div",{class:(0,a.C4)([(0,o.R1)(l).e("body"),e.bodyClass]),style:(0,a.Tr)(e.bodyStyle)},[(0,n.RG)(e.$slots,"default")],6),e.$slots.footer||e.footer?((0,n.uX)(),(0,n.CE)("div",{key:1,class:(0,a.C4)([(0,o.R1)(l).e("footer"),e.footerClass])},[(0,n.RG)(e.$slots,"footer",{},()=>[(0,n.eW)((0,a.v_)(e.footer),1)])],2)):(0,n.Q3)("v-if",!0)],2)}}});var p=(0,s.A)(f,[["__file","card.vue"]]),m=l(5376);const v=(0,m.GU)(p)},684:function(e){"use strict";e.exports=function(e,t){var l="function"==typeof Iterator&&Iterator.prototype[e];if(l)try{l.call({next:null},t).next()}catch(n){return!0}}},729:function(e,t){"use strict";var l=Object.prototype;function n(e){var t=e&&e.constructor,n="function"==typeof t&&t.prototype||l;return e===n}t.A=n},741:function(e){"use strict";var t=Math.ceil,l=Math.floor;e.exports=Math.trunc||function(e){var n=+e;return(n>0?l:t)(n)}},754:function(e,t,l){"use strict";l.d(t,{A:function(){return g}});var n=/\s/;function a(e){var t=e.length;while(t--&&n.test(e.charAt(t)));return t}var o=a,c=/^\s+/;function r(e){return e?e.slice(0,o(e)+1).replace(c,""):e}var s=r,i=l(168),u=l(8095),d=NaN,f=/^[-+]0x[0-9a-f]+$/i,p=/^0b[01]+$/i,m=/^0o[0-7]+$/i,v=parseInt;function h(e){if("number"==typeof e)return e;if((0,u.A)(e))return d;if((0,i.A)(e)){var t="function"==typeof e.valueOf?e.valueOf():e;e=(0,i.A)(t)?t+"":t}if("string"!=typeof e)return 0===e?e:+e;e=s(e);var l=p.test(e);return l||m.test(e)?v(e.slice(2),l?2:8):f.test(e)?d:+e}var g=h},757:function(e,t,l){"use strict";var n=l(7751),a=l(4901),o=l(1625),c=l(7040),r=Object;e.exports=c?function(e){return"symbol"==typeof e}:function(e){var t=n("Symbol");return a(t)&&o(t.prototype,r(e))}},782:function(e,t,l){"use strict";l.d(t,{d:function(){return a},p:function(){return n}});const n=Symbol("popper"),a=Symbol("popperContent")},793:function(e,t,l){"use strict";l.d(t,{G:function(){return r},Y:function(){return s}});var n=l(6768),a=l(144),o=l(9615),c=l(9195);const r={label:"label",value:"value",disabled:"disabled",options:"options"};function s(e){const t=(0,a.KR)({...r,...e.props});let l={...e.props};(0,n.wB)(()=>e.props,e=>{(0,c.A)(e,l)||(t.value={...r,...e},l={...e})},{deep:!0});const s=e=>(0,o.A)(e,t.value.label),i=e=>(0,o.A)(e,t.value.value),u=e=>(0,o.A)(e,t.value.disabled),d=e=>(0,o.A)(e,t.value.options);return{aliasProps:t,getLabel:s,getValue:i,getDisabled:u,getOptions:d}}},813:function(e,t,l){"use strict";l.d(t,{tk:function(){return m}});var n=l(6768),a=l(144),o=l(7378);const c=(0,o.b_)({size:{type:(0,o.jq)([Number,String])},color:{type:String}});var r=l(9077),s=l(3513),i=l(3558);const u=(0,n.pM)({name:"ElIcon",inheritAttrs:!1}),d=(0,n.pM)({...u,props:c,setup(e){const t=e,l=(0,s.DU)("icon"),o=(0,n.EW)(()=>{const{size:e,color:l}=t,n=(0,i._V)(e);return n||l?{fontSize:n,"--color":l}:{}});return(e,t)=>((0,n.uX)(),(0,n.CE)("i",(0,n.v6)({class:(0,a.R1)(l).b(),style:(0,a.R1)(o)},e.$attrs),[(0,n.RG)(e.$slots,"default")],16))}});var f=(0,r.A)(d,[["__file","icon.vue"]]),p=l(5376);const m=(0,p.GU)(f)},844:function(e,t,l){"use strict";l.d(t,{p:function(){return c}});var n=l(4461),a=l(7378),o=l(515);const c=(0,a.b_)({...n.X,disabled:Boolean,trigger:{type:(0,a.jq)([String,Array]),default:"hover"},triggerKeys:{type:(0,a.jq)(Array),default:()=>[o.R.enter,o.R.numpadEnter,o.R.space]},focusOnTarget:Boolean})},850:function(e,t,l){"use strict";l.d(t,{dI:function(){return H},$n:function(){return j},o5:function(){return K}});var n=l(6768),a=l(144),o=l(4232),c=l(5130),r=l(3845),s=l(8501),i=l(2056),u=l(2235);const d={modelValue:{type:[Number,String,Boolean],default:void 0},label:{type:[String,Boolean,Number,Object],default:void 0},value:{type:[String,Boolean,Number,Object],default:void 0},indeterminate:Boolean,disabled:{type:Boolean,default:void 0},checked:Boolean,name:{type:String,default:void 0},trueValue:{type:[String,Number],default:void 0},falseValue:{type:[String,Number],default:void 0},trueLabel:{type:[String,Number],default:void 0},falseLabel:{type:[String,Number],default:void 0},id:{type:String,default:void 0},border:Boolean,size:r.mU,tabindex:[String,Number],validateEvent:{type:Boolean,default:!0},ariaLabel:String,...(0,s.l)(["ariaControls"])},f={[i.l4]:e=>(0,o.Kg)(e)||(0,u.Et)(e)||(0,u.Lm)(e),change:e=>(0,o.Kg)(e)||(0,u.Et)(e)||(0,u.Lm)(e)};var p=l(9077);l(4114);const m=Symbol("checkboxGroupContextKey");var v=l(7254),h=l(2436);const g=({model:e,isChecked:t})=>{const l=(0,n.WQ)(m,void 0),a=(0,n.WQ)(v.F,void 0),o=(0,n.EW)(()=>{var n,a;const o=null==(n=null==l?void 0:l.max)?void 0:n.value,c=null==(a=null==l?void 0:l.min)?void 0:a.value;return!(0,u.b0)(o)&&e.value.length>=o&&!t.value||!(0,u.b0)(c)&&e.value.length<=c&&t.value}),c=(0,h.CB)((0,n.EW)(()=>{var e,t;return void 0===l?null!=(e=null==a?void 0:a.disabled)?e:o.value:(null==(t=l.disabled)?void 0:t.value)||o.value}));return{isDisabled:c,isLimitDisabled:o}};l(8111),l(3579);var b=l(4216),y=l(6894);const C=(e,{model:t,isLimitExceeded:l,hasOwnLabel:a,isDisabled:o,isLabeledByFormItem:c})=>{const r=(0,n.WQ)(m,void 0),{formItem:s}=(0,b.j)(),{emit:u}=(0,n.nI)();function d(t){var l,n,a,o;return[!0,e.trueValue,e.trueLabel].includes(t)?null==(n=null!=(l=e.trueValue)?l:e.trueLabel)||n:null!=(o=null!=(a=e.falseValue)?a:e.falseLabel)&&o}function f(e,t){u(i.YU,d(e),t)}function p(e){if(l.value)return;const t=e.target;u(i.YU,d(t.checked),e)}async function v(r){if(!l.value&&!a.value&&!o.value&&c.value){const l=r.composedPath(),a=l.some(e=>"LABEL"===e.tagName);a||(t.value=d([!1,e.falseValue,e.falseLabel].includes(t.value)),await(0,n.dY)(),f(t.value,r))}}const h=(0,n.EW)(()=>(null==r?void 0:r.validateEvent)||e.validateEvent);return(0,n.wB)(()=>e.modelValue,()=>{h.value&&(null==s||s.validate("change").catch(e=>(0,y.U)(e)))}),{handleChange:p,onClickRoot:v}},w=e=>{const t=(0,a.KR)(!1),{emit:l}=(0,n.nI)(),c=(0,n.WQ)(m,void 0),r=(0,n.EW)(()=>!1===(0,u.b0)(c)),s=(0,a.KR)(!1),d=(0,n.EW)({get(){var l,n;return r.value?null==(l=null==c?void 0:c.modelValue)?void 0:l.value:null!=(n=e.modelValue)?n:t.value},set(e){var n,a;r.value&&(0,o.cy)(e)?(s.value=void 0!==(null==(n=null==c?void 0:c.max)?void 0:n.value)&&e.length>(null==c?void 0:c.max.value)&&e.length>d.value.length,!1===s.value&&(null==(a=null==c?void 0:c.changeEvent)||a.call(c,e))):(l(i.l4,e),t.value=e)}});return{model:d,isGroup:r,isLimitExceeded:s}};l(1701);var L=l(9195);const x=(e,t,{model:l})=>{const c=(0,n.WQ)(m,void 0),r=(0,a.KR)(!1),s=(0,n.EW)(()=>(0,u.Xj)(e.value)?e.label:e.value),i=(0,n.EW)(()=>{const t=l.value;return(0,u.Lm)(t)?t:(0,o.cy)(t)?(0,o.Gv)(s.value)?t.map(a.ux).some(e=>(0,L.A)(e,s.value)):t.map(a.ux).includes(s.value):null!==t&&void 0!==t?t===e.trueValue||t===e.trueLabel:!!t}),d=(0,h.NV)((0,n.EW)(()=>{var e;return null==(e=null==c?void 0:c.size)?void 0:e.value}),{prop:!0}),f=(0,h.NV)((0,n.EW)(()=>{var e;return null==(e=null==c?void 0:c.size)?void 0:e.value})),p=(0,n.EW)(()=>!!t.default||!(0,u.Xj)(s.value));return{checkboxButtonSize:d,isChecked:i,isFocused:r,checkboxSize:f,hasOwnLabel:p,actualValue:s}};var M=l(261);const z=(e,t)=>{const{formItem:l}=(0,b.j)(),{model:a,isGroup:c,isLimitExceeded:r}=w(e),{isFocused:s,isChecked:i,checkboxButtonSize:d,checkboxSize:f,hasOwnLabel:p,actualValue:m}=x(e,t,{model:a}),{isDisabled:v}=g({model:a,isChecked:i}),{inputId:h,isLabeledByFormItem:y}=(0,b.W)(e,{formItemContext:l,disableIdGeneration:p,disableIdManagement:c}),{handleChange:L,onClickRoot:z}=C(e,{model:a,isLimitExceeded:r,hasOwnLabel:p,isDisabled:v,isLabeledByFormItem:y}),R=()=>{function t(){var t,l;(0,o.cy)(a.value)&&!a.value.includes(m.value)?a.value.push(m.value):a.value=null==(l=null!=(t=e.trueValue)?t:e.trueLabel)||l}e.checked&&t()};return R(),(0,M.b)({from:"label act as value",replacement:"value",version:"3.0.0",scope:"el-checkbox",ref:"https://element-plus.org/en-US/component/checkbox.html"},(0,n.EW)(()=>c.value&&(0,u.Xj)(e.value))),(0,M.b)({from:"true-label",replacement:"true-value",version:"3.0.0",scope:"el-checkbox",ref:"https://element-plus.org/en-US/component/checkbox.html"},(0,n.EW)(()=>!!e.trueLabel)),(0,M.b)({from:"false-label",replacement:"false-value",version:"3.0.0",scope:"el-checkbox",ref:"https://element-plus.org/en-US/component/checkbox.html"},(0,n.EW)(()=>!!e.falseLabel)),{inputId:h,isLabeledByFormItem:y,isChecked:i,isDisabled:v,isFocused:s,checkboxButtonSize:d,checkboxSize:f,hasOwnLabel:p,model:a,actualValue:m,handleChange:L,onClickRoot:z}};var R=l(3513);const k=(0,n.pM)({name:"ElCheckbox"}),S=(0,n.pM)({...k,props:d,emits:f,setup(e){const t=e,l=(0,n.Ht)(),{inputId:r,isLabeledByFormItem:s,isChecked:i,isDisabled:u,isFocused:d,checkboxSize:f,hasOwnLabel:p,model:m,actualValue:v,handleChange:h,onClickRoot:g}=z(t,l),b=(0,n.EW)(()=>{var e,l,n,a;return t.trueValue||t.falseValue||t.trueLabel||t.falseLabel?{"true-value":null==(l=null!=(e=t.trueValue)?e:t.trueLabel)||l,"false-value":null!=(a=null!=(n=t.falseValue)?n:t.falseLabel)&&a}:{value:v.value}}),y=(0,R.DU)("checkbox"),C=(0,n.EW)(()=>[y.b(),y.m(f.value),y.is("disabled",u.value),y.is("bordered",t.border),y.is("checked",i.value)]),w=(0,n.EW)(()=>[y.e("input"),y.is("disabled",u.value),y.is("checked",i.value),y.is("indeterminate",t.indeterminate),y.is("focus",d.value)]);return(e,t)=>((0,n.uX)(),(0,n.Wv)((0,n.$y)(!(0,a.R1)(p)&&(0,a.R1)(s)?"span":"label"),{for:!(0,a.R1)(p)&&(0,a.R1)(s)?null:(0,a.R1)(r),class:(0,o.C4)((0,a.R1)(C)),"aria-controls":e.indeterminate?e.ariaControls:null,"aria-checked":e.indeterminate?"mixed":void 0,"aria-label":e.ariaLabel,onClick:(0,a.R1)(g)},{default:(0,n.k6)(()=>[(0,n.Lk)("span",{class:(0,o.C4)((0,a.R1)(w))},[(0,n.bo)((0,n.Lk)("input",(0,n.v6)({id:(0,a.R1)(r),"onUpdate:modelValue":e=>(0,a.i9)(m)?m.value=e:null,class:(0,a.R1)(y).e("original"),type:"checkbox",indeterminate:e.indeterminate,name:e.name,tabindex:e.tabindex,disabled:(0,a.R1)(u)},(0,a.R1)(b),{onChange:(0,a.R1)(h),onFocus:e=>d.value=!0,onBlur:e=>d.value=!1,onClick:(0,c.D$)(()=>{},["stop"])}),null,16,["id","onUpdate:modelValue","indeterminate","name","tabindex","disabled","onChange","onFocus","onBlur","onClick"]),[[c.lH,(0,a.R1)(m)]]),(0,n.Lk)("span",{class:(0,o.C4)((0,a.R1)(y).e("inner"))},null,2)],2),(0,a.R1)(p)?((0,n.uX)(),(0,n.CE)("span",{key:0,class:(0,o.C4)((0,a.R1)(y).e("label"))},[(0,n.RG)(e.$slots,"default"),e.$slots.default?(0,n.Q3)("v-if",!0):((0,n.uX)(),(0,n.CE)(n.FK,{key:0},[(0,n.eW)((0,o.v_)(e.label),1)],64))],2)):(0,n.Q3)("v-if",!0)]),_:3},8,["for","class","aria-controls","aria-checked","aria-label","onClick"]))}});var E=(0,p.A)(S,[["__file","checkbox.vue"]]);const A=(0,n.pM)({name:"ElCheckboxButton"}),N=(0,n.pM)({...A,props:d,emits:f,setup(e){const t=e,l=(0,n.Ht)(),{isFocused:r,isChecked:s,isDisabled:i,checkboxButtonSize:u,model:d,actualValue:f,handleChange:p}=z(t,l),v=(0,n.EW)(()=>{var e,l,n,a;return t.trueValue||t.falseValue||t.trueLabel||t.falseLabel?{"true-value":null==(l=null!=(e=t.trueValue)?e:t.trueLabel)||l,"false-value":null!=(a=null!=(n=t.falseValue)?n:t.falseLabel)&&a}:{value:f.value}}),h=(0,n.WQ)(m,void 0),g=(0,R.DU)("checkbox"),b=(0,n.EW)(()=>{var e,t,l,n;const a=null!=(t=null==(e=null==h?void 0:h.fill)?void 0:e.value)?t:"";return{backgroundColor:a,borderColor:a,color:null!=(n=null==(l=null==h?void 0:h.textColor)?void 0:l.value)?n:"",boxShadow:a?`-1px 0 0 0 ${a}`:void 0}}),y=(0,n.EW)(()=>[g.b("button"),g.bm("button",u.value),g.is("disabled",i.value),g.is("checked",s.value),g.is("focus",r.value)]);return(e,t)=>((0,n.uX)(),(0,n.CE)("label",{class:(0,o.C4)((0,a.R1)(y))},[(0,n.bo)((0,n.Lk)("input",(0,n.v6)({"onUpdate:modelValue":e=>(0,a.i9)(d)?d.value=e:null,class:(0,a.R1)(g).be("button","original"),type:"checkbox",name:e.name,tabindex:e.tabindex,disabled:(0,a.R1)(i)},(0,a.R1)(v),{onChange:(0,a.R1)(p),onFocus:e=>r.value=!0,onBlur:e=>r.value=!1,onClick:(0,c.D$)(()=>{},["stop"])}),null,16,["onUpdate:modelValue","name","tabindex","disabled","onChange","onFocus","onBlur","onClick"]),[[c.lH,(0,a.R1)(d)]]),e.$slots.default||e.label?((0,n.uX)(),(0,n.CE)("span",{key:0,class:(0,o.C4)((0,a.R1)(g).be("button","inner")),style:(0,o.Tr)((0,a.R1)(s)?(0,a.R1)(b):void 0)},[(0,n.RG)(e.$slots,"default",{},()=>[(0,n.eW)((0,o.v_)(e.label),1)])],6)):(0,n.Q3)("v-if",!0)],2))}});var _=(0,p.A)(N,[["__file","checkbox-button.vue"]]),T=l(1074),O=l(1996),W=l(7378);const B=(0,W.b_)({modelValue:{type:(0,W.jq)(Array),default:()=>[]},disabled:{type:Boolean,default:void 0},min:Number,max:Number,size:r.mU,fill:String,textColor:String,tag:{type:String,default:"div"},validateEvent:{type:Boolean,default:!0},options:{type:(0,W.jq)(Array)},props:{type:(0,W.jq)(Object),default:()=>D},type:{type:String,values:["checkbox","button"],default:"checkbox"},...(0,s.l)(["ariaLabel"])}),I={[i.l4]:e=>(0,o.cy)(e),change:e=>(0,o.cy)(e)},D={label:"label",value:"value",disabled:"disabled"},F=(0,n.pM)({name:"ElCheckboxGroup"}),V=(0,n.pM)({...F,props:B,emits:I,setup(e,{emit:t}){const l=e,c=(0,R.DU)("checkbox"),r=(0,h.CB)(),{formItem:s}=(0,b.j)(),{inputId:u,isLabeledByFormItem:d}=(0,b.W)(l,{formItemContext:s}),f=async e=>{t(i.l4,e),await(0,n.dY)(),t(i.YU,e)},p=(0,n.EW)({get(){return l.modelValue},set(e){f(e)}}),v=(0,n.EW)(()=>({...D,...l.props})),g=e=>{const{label:t,value:l,disabled:n}=v.value,a={label:e[t],value:e[l],disabled:e[n]};return{...(0,T.A)(e,[t,l,n]),...a}},C=(0,n.EW)(()=>"button"===l.type?_:E);return(0,n.Gt)(m,{...(0,O.A)((0,a.QW)(l),["size","min","max","validateEvent","fill","textColor"]),disabled:r,modelValue:p,changeEvent:f}),(0,n.wB)(()=>l.modelValue,(e,t)=>{l.validateEvent&&!(0,L.A)(e,t)&&(null==s||s.validate("change").catch(e=>(0,y.U)(e)))}),(e,t)=>{var l;return(0,n.uX)(),(0,n.Wv)((0,n.$y)(e.tag),{id:(0,a.R1)(u),class:(0,o.C4)((0,a.R1)(c).b("group")),role:"group","aria-label":(0,a.R1)(d)?void 0:e.ariaLabel||"checkbox-group","aria-labelledby":(0,a.R1)(d)?null==(l=(0,a.R1)(s))?void 0:l.labelId:void 0},{default:(0,n.k6)(()=>[(0,n.RG)(e.$slots,"default",{},()=>[((0,n.uX)(!0),(0,n.CE)(n.FK,null,(0,n.pI)(e.options,(e,t)=>((0,n.uX)(),(0,n.Wv)((0,n.$y)((0,a.R1)(C)),(0,n.v6)({key:t},g(e)),null,16))),128))])]),_:3},8,["id","class","aria-label","aria-labelledby"])}}});var P=(0,p.A)(V,[["__file","checkbox-group.vue"]]),$=l(5376);const H=(0,$.GU)(E,{CheckboxButton:_,CheckboxGroup:P}),j=(0,$.WM)(_),K=(0,$.WM)(P)},851:function(e,t,l){"use strict";var n=l(6955),a=l(5966),o=l(4117),c=l(6269),r=l(8227),s=r("iterator");e.exports=function(e){if(!o(e))return a(e,s)||a(e,"@@iterator")||c[n(e)]}},944:function(e){"use strict";var t=TypeError;e.exports=function(e){var l=e&&e.alphabet;if(void 0===l||"base64"===l||"base64url"===l)return l||"base64";throw new t("Incorrect `alphabet` option")}},971:function(e,t,l){"use strict";l.d(t,{IO:function(){return a},xt:function(){return c},yt:function(){return o}});var n=l(6768);const a=Symbol("elForwardRef"),o=e=>{const t=t=>{e.value=t};(0,n.Gt)(a,{setForwardRef:t})},c=e=>({mounted(t){e(t)},updated(t){e(t)},unmounted(){e(null)}})},1018:function(e,t,l){"use strict";var n=l(5061),a=l(6841),o=Object.prototype,c=o.hasOwnProperty;function r(e,t,l){var o=e[t];c.call(e,t)&&(0,a.A)(o,l)&&(void 0!==l||t in e)||(0,n.A)(e,t,l)}t.A=r},1072:function(e,t,l){"use strict";var n=l(1828),a=l(8727);e.exports=Object.keys||function(e){return n(e,a)}},1074:function(e,t,l){"use strict";l.d(t,{A:function(){return R}});var n=l(5347),a=l(7529),o=l(5014);function c(e){var t=null==e?0:e.length;return t?e[t-1]:void 0}var r=c,s=l(2623);function i(e,t,l){var n=-1,a=e.length;t<0&&(t=-t>a?0:a+t),l=l>a?a:l,l<0&&(l+=a),a=t>l?0:l-t>>>0,t>>>=0;var o=Array(a);while(++n1),t}),(0,h.A)(e,(0,w.A)(e),l),c&&(l=(0,a.A)(l,L|x|M,y));var r=t.length;while(r--)v(l,t[r]);return l}),R=z},1095:function(e,t,l){"use strict";l.d(t,{vp:function(){return L},WZ:function(){return x}});var n=l(6768),a=l(144),o=l(4232);const c=Symbol("breadcrumbKey");var r=l(7378),s=l(464);const i=(0,r.b_)({separator:{type:String,default:"/"},separatorIcon:{type:s.Ze}});var u=l(9077),d=l(6268),f=l(3513);const p=(0,n.pM)({name:"ElBreadcrumb"}),m=(0,n.pM)({...p,props:i,setup(e){const t=e,{t:l}=(0,d.Ym)(),r=(0,f.DU)("breadcrumb"),s=(0,a.KR)();return(0,n.Gt)(c,t),(0,n.sV)(()=>{const e=s.value.querySelectorAll(`.${r.e("item")}`);e.length&&e[e.length-1].setAttribute("aria-current","page")}),(e,t)=>((0,n.uX)(),(0,n.CE)("div",{ref_key:"breadcrumb",ref:s,class:(0,o.C4)((0,a.R1)(r).b()),"aria-label":(0,a.R1)(l)("el.breadcrumb.label"),role:"navigation"},[(0,n.RG)(e.$slots,"default")],10,["aria-label"]))}});var v=(0,u.A)(m,[["__file","breadcrumb.vue"]]),h=(l(4114),l(813));const g=(0,r.b_)({to:{type:(0,r.jq)([String,Object]),default:""},replace:Boolean}),b=(0,n.pM)({name:"ElBreadcrumbItem"}),y=(0,n.pM)({...b,props:g,setup(e){const t=e,l=(0,n.nI)(),r=(0,n.WQ)(c,void 0),s=(0,f.DU)("breadcrumb"),i=l.appContext.config.globalProperties.$router,u=(0,a.KR)(),d=()=>{t.to&&i&&(t.replace?i.replace(t.to):i.push(t.to))};return(e,t)=>{var l,c;return(0,n.uX)(),(0,n.CE)("span",{class:(0,o.C4)((0,a.R1)(s).e("item"))},[(0,n.Lk)("span",{ref_key:"link",ref:u,class:(0,o.C4)([(0,a.R1)(s).e("inner"),(0,a.R1)(s).is("link",!!e.to)]),role:"link",onClick:d},[(0,n.RG)(e.$slots,"default")],2),(null==(l=(0,a.R1)(r))?void 0:l.separatorIcon)?((0,n.uX)(),(0,n.Wv)((0,a.R1)(h.tk),{key:0,class:(0,o.C4)((0,a.R1)(s).e("separator"))},{default:(0,n.k6)(()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)((0,a.R1)(r).separatorIcon)))]),_:1},8,["class"])):((0,n.uX)(),(0,n.CE)("span",{key:1,class:(0,o.C4)((0,a.R1)(s).e("separator")),role:"presentation"},(0,o.v_)(null==(c=(0,a.R1)(r))?void 0:c.separator),3))],2)}}});var C=(0,u.A)(y,[["__file","breadcrumb-item.vue"]]),w=l(5376);const L=(0,w.GU)(v,{BreadcrumbItem:C}),x=(0,w.WM)(C)},1108:function(e,t,l){"use strict";var n=l(6955);e.exports=function(e){var t=n(e);return"BigInt64Array"===t||"BigUint64Array"===t}},1120:function(e,t,l){"use strict";l.d(t,{A:function(){return f}});var n=l(9578);function a(){return!1}var o=a,c="object"==typeof exports&&exports&&!exports.nodeType&&exports,r=c&&"object"==typeof module&&module&&!module.nodeType&&module,s=r&&r.exports===c,i=s?n.A.Buffer:void 0,u=i?i.isBuffer:void 0,d=u||o,f=d},1125:function(e,t,l){"use strict";var n=l(3925),a=String,o=TypeError;e.exports=function(e){if(n(e))return e;throw new o("Can't set "+a(e)+" as a prototype")}},1148:function(e,t,l){"use strict";var n=l(6518),a=l(9565),o=l(2652),c=l(9306),r=l(8551),s=l(1767),i=l(9539),u=l(4549),d=u("every",TypeError);n({target:"Iterator",proto:!0,real:!0,forced:d},{every:function(e){r(this);try{c(e)}catch(n){i(this,"throw",n)}if(d)return a(d,this,e);var t=s(this),l=0;return!o(t,function(t,n){if(!e(t,l++))return n()},{IS_RECORD:!0,INTERRUPTED:!0}).stopped}})},1154:function(e,t){"use strict";function l(e){var t=-1,l=null==e?0:e.length,n={};while(++t!0},C=(0,o.Gc)({}),w=e=>(C[e]||(C[e]=(0,o.Gc)([])),C[e]),L=(e,t)=>{const l=C[t]||[],n=l.findIndex(t=>t.id===e),a=l[n];let o;return n>0&&(o=l[n-1]),{current:a,prev:o}},x=(e,t)=>{const{prev:l}=L(e,t);return l?l.vm.exposed.bottom.value:0},M=(e,t,l)=>{const n=C[l]||[],a=n.findIndex(t=>t.id===e);return a>0?16:t};var z=l(9077),R=l(8114),k=l(4225),S=l(515);const E=(0,n.pM)({name:"ElMessage"}),A=(0,n.pM)({...E,props:b,emits:y,setup(e,{expose:t,emit:l}){const d=e,{Close:p}=f.Nk,m=(0,o.KR)(!1),{ns:v,zIndex:g}=(0,R.ht)("message"),{currentZIndex:b,nextZIndex:y}=g,C=(0,o.KR)(),w=(0,o.KR)(!1),L=(0,o.KR)(0);let z;const E=(0,n.EW)(()=>d.type?"error"===d.type?"danger":d.type:"info"),A=(0,n.EW)(()=>{const e=d.type;return{[v.bm("icon",e)]:e&&f.rz[e]}}),N=(0,n.EW)(()=>d.icon||f.rz[d.type]||""),_=(0,n.EW)(()=>d.placement||h),T=(0,n.EW)(()=>x(d.id,_.value)),O=(0,n.EW)(()=>M(d.id,d.offset,_.value)+T.value),W=(0,n.EW)(()=>L.value+O.value),B=(0,n.EW)(()=>_.value.includes("left")?v.is("left"):_.value.includes("right")?v.is("right"):v.is("center")),I=(0,n.EW)(()=>_.value.startsWith("top")?"top":"bottom"),D=(0,n.EW)(()=>({[I.value]:`${O.value}px`,zIndex:b.value}));function F(){0!==d.duration&&({stop:z}=(0,r.TO)(()=>{P()},d.duration))}function V(){null==z||z()}function P(){w.value=!1,(0,n.dY)(()=>{var e;m.value||(null==(e=d.onClose)||e.call(d),l("destroy"))})}function $(e){const t=(0,k.CG)(e);t===S.R.esc&&P()}return(0,n.sV)(()=>{F(),y(),w.value=!0}),(0,n.wB)(()=>d.repeatNum,()=>{V(),F()}),(0,s.MLh)(document,"keydown",$),(0,s.wYm)(C,()=>{L.value=C.value.getBoundingClientRect().height}),t({visible:w,bottom:W,close:P}),(e,t)=>((0,n.uX)(),(0,n.Wv)(a.eB,{name:(0,o.R1)(v).b("fade"),onBeforeEnter:e=>m.value=!0,onBeforeLeave:e.onClose,onAfterLeave:t=>e.$emit("destroy"),persisted:""},{default:(0,n.k6)(()=>[(0,n.bo)((0,n.Lk)("div",{id:e.id,ref_key:"messageRef",ref:C,class:(0,c.C4)([(0,o.R1)(v).b(),{[(0,o.R1)(v).m(e.type)]:e.type},(0,o.R1)(v).is("closable",e.showClose),(0,o.R1)(v).is("plain",e.plain),(0,o.R1)(v).is("bottom","bottom"===(0,o.R1)(I)),(0,o.R1)(B),e.customClass]),style:(0,c.Tr)((0,o.R1)(D)),role:"alert",onMouseenter:V,onMouseleave:F},[e.repeatNum>1?((0,n.uX)(),(0,n.Wv)((0,o.R1)(i.z_),{key:0,value:e.repeatNum,type:(0,o.R1)(E),class:(0,c.C4)((0,o.R1)(v).e("badge"))},null,8,["value","type","class"])):(0,n.Q3)("v-if",!0),(0,o.R1)(N)?((0,n.uX)(),(0,n.Wv)((0,o.R1)(u.tk),{key:1,class:(0,c.C4)([(0,o.R1)(v).e("icon"),(0,o.R1)(A)])},{default:(0,n.k6)(()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)((0,o.R1)(N))))]),_:1},8,["class"])):(0,n.Q3)("v-if",!0),(0,n.RG)(e.$slots,"default",{},()=>[e.dangerouslyUseHTMLString?((0,n.uX)(),(0,n.CE)(n.FK,{key:1},[(0,n.Q3)(" Caution here, message could've been compromised, never use user's input as message "),(0,n.Lk)("p",{class:(0,c.C4)((0,o.R1)(v).e("content")),innerHTML:e.message},null,10,["innerHTML"])],2112)):((0,n.uX)(),(0,n.CE)("p",{key:0,class:(0,c.C4)((0,o.R1)(v).e("content"))},(0,c.v_)(e.message),3))]),e.showClose?((0,n.uX)(),(0,n.Wv)((0,o.R1)(u.tk),{key:2,class:(0,c.C4)((0,o.R1)(v).e("closeBtn")),onClick:(0,a.D$)(P,["stop"])},{default:(0,n.k6)(()=>[(0,n.bF)((0,o.R1)(p))]),_:1},8,["class","onClick"])):(0,n.Q3)("v-if",!0)],46,["id"]),[[a.aG,w.value]])]),_:3},8,["name","onBeforeEnter","onBeforeLeave","onAfterLeave"]))}});var N=(0,z.A)(A,[["__file","message.vue"]]),_=l(1588),T=l(2235),O=l(6894);let W=1;const B=e=>{const t=e.appendTo;if(t){if((0,c.Kg)(e.appendTo)){let t=document.querySelector(e.appendTo);(0,T.vq)(t)||((0,O.U)("ElMessage","the appendTo option is not an HTMLElement. Falling back to document.body."),t=document.body),e.appendTo=t}}else e.appendTo=document.body},I=e=>{!e.placement&&(0,c.Kg)(_.k.placement)&&_.k.placement&&(e.placement=_.k.placement),e.placement||(e.placement=h),v.includes(e.placement)||((0,O.U)("ElMessage",`Invalid placement: ${e.placement}. Falling back to '${h}'.`),e.placement=h)},D=e=>{const t=!e||(0,c.Kg)(e)||(0,n.vv)(e)||(0,c.Tn)(e)?{message:e}:e,l={...g,...t};return B(l),I(l),(0,T.Lm)(_.k.grouping)&&!l.grouping&&(l.grouping=_.k.grouping),(0,T.Et)(_.k.duration)&&3e3===l.duration&&(l.duration=_.k.duration),(0,T.Et)(_.k.offset)&&16===l.offset&&(l.offset=_.k.offset),(0,T.Lm)(_.k.showClose)&&!l.showClose&&(l.showClose=_.k.showClose),(0,T.Lm)(_.k.plain)&&!l.plain&&(l.plain=_.k.plain),l},F=e=>{const t=e.props.placement||h,l=C[t],n=l.indexOf(e);if(-1===n)return;l.splice(n,1);const{handler:a}=e;a.close()},V=({appendTo:e,...t},l)=>{const o="message_"+W++,r=t.onClose,s=document.createElement("div"),i={...t,id:o,onClose:()=>{null==r||r(),F(p)},onDestroy:()=>{(0,a.XX)(null,s)}},u=(0,n.bF)(N,i,(0,c.Tn)(i.message)||(0,n.vv)(i.message)?{default:(0,c.Tn)(i.message)?i.message:()=>i.message}:null);u.appContext=l||P._context,(0,a.XX)(u,s),e.appendChild(s.firstElementChild);const d=u.component,f={close:()=>{d.exposed.close()}},p={id:o,vnode:u,vm:d,handler:f,props:u.component.props};return p},P=(e={},t)=>{if(!r.oc)return{close:()=>{}};const l=D(e),n=w(l.placement||h);if(l.grouping&&n.length){const e=n.find(({vnode:e})=>{var t;return(null==(t=e.props)?void 0:t.message)===l.message});if(e)return e.props.repeatNum+=1,e.props.type=l.type,e.handler}if((0,T.Et)(_.k.max)&&n.length>=_.k.max)return{close:()=>{}};const a=V(l,t);return n.push(a),a.handler};function $(e){for(const t in C)if((0,c.$3)(C,t)){const l=[...C[t]];for(const t of l)e&&e!==t.props.type||t.handler.close()}}function H(e){if(!C[e])return;const t=[...C[e]];t.forEach(e=>e.handler.close())}m.forEach(e=>{P[e]=(t={},l)=>{const n=D(t);return P({...n,type:e},l)}}),P.closeAll=$,P.closeAllByPlacement=H,P._context=null;var j=l(5376);const K=(0,j._u)(P,"$message")},1241:function(e,t){"use strict";t.A=(e,t)=>{const l=e.__vccOpts||e;for(const[n,a]of t)l[n]=a;return l}},1254:function(e,t,l){"use strict";l.d(t,{A:function(){return u}});var n=l(168),a=Object.create,o=function(){function e(){}return function(t){if(!(0,n.A)(t))return{};if(a)return a(t);e.prototype=t;var l=new e;return e.prototype=void 0,l}}(),c=o,r=l(9092),s=l(729);function i(e){return"function"!=typeof e.constructor||(0,s.A)(e)?{}:c((0,r.A)(e))}var u=i},1291:function(e,t,l){"use strict";var n=l(741);e.exports=function(e){var t=+e;return t!==t||0===t?0:n(t)}},1305:function(e,t,l){"use strict";l.d(t,{Bi:function(){return d},Sj:function(){return u}});var n=l(6768),a=l(144),o=l(17),c=l(3513),r=l(6894);const s={prefix:Math.floor(1e4*Math.random()),current:0},i=Symbol("elIdInjection"),u=()=>(0,n.nI)()?(0,n.WQ)(i,s):s,d=e=>{const t=u();o.oc||t!==s||(0,r.U)("IdInjection","Looks like you are using server rendering, you must provide a id provider to ensure the hydration process to be succeed\nusage: app.provide(ID_INJECTION_KEY, {\n prefix: number,\n current: number,\n})");const l=(0,c.E9)(),n=(0,o.AI)(()=>(0,a.R1)(e)||`${l.value}-id-${t.prefix}-${t.current++}`);return n}},1385:function(e,t,l){"use strict";var n=l(9539);e.exports=function(e,t,l){for(var a=e.length-1;a>=0;a--)if(void 0!==e[a])try{l=n(e[a].iterator,t,l)}catch(o){t="throw",l=o}if("throw"===t)throw l;return l}},1418:function(e,t,l){"use strict";l.d(t,{lq:function(){return N}});var n=l(6768),a=l(144),o=l(4232),c=l(5130),r=l(6032),s=l(9623),i=l(813),u=l(7477),d=l(7378),f=l(3845),p=l(2235),m=l(8501),v=l(2056);const h=(0,d.b_)({id:{type:String,default:void 0},step:{type:Number,default:1},stepStrictly:Boolean,max:{type:Number,default:Number.MAX_SAFE_INTEGER},min:{type:Number,default:Number.MIN_SAFE_INTEGER},modelValue:{type:[Number,null]},readonly:Boolean,disabled:{type:Boolean,default:void 0},size:f.mU,controls:{type:Boolean,default:!0},controlsPosition:{type:String,default:"",values:["","right"]},valueOnClear:{type:[String,Number,null],validator:e=>null===e||(0,p.Et)(e)||["min","max"].includes(e),default:null},name:String,placeholder:String,precision:{type:Number,validator:e=>e>=0&&e===Number.parseInt(`${e}`,10)},validateEvent:{type:Boolean,default:!0},...(0,m.l)(["ariaLabel"]),inputmode:{type:(0,d.jq)(String),default:void 0},align:{type:(0,d.jq)(String),default:"center"},disabledScientific:Boolean}),g={[v.YU]:(e,t)=>t!==e,blur:e=>e instanceof FocusEvent,focus:e=>e instanceof FocusEvent,[v.qs]:e=>(0,p.Et)(e)||(0,r.A)(e),[v.l4]:e=>(0,p.Et)(e)||(0,r.A)(e)};var b=l(9077),y=l(4436),C=l(4225),w=l(6268),L=l(3513),x=l(4216),M=l(6894),z=l(2436),R=l(515);const k=(0,n.pM)({name:"ElInputNumber"}),S=(0,n.pM)({...k,props:h,emits:g,setup(e,{expose:t,emit:l}){const d=e,{t:f}=(0,w.Ym)(),m=(0,L.DU)("input-number"),h=(0,a.KR)(),g=(0,a.Kh)({currentValue:d.modelValue,userInput:null}),{formItem:b}=(0,x.j)(),k=(0,n.EW)(()=>(0,p.Et)(d.modelValue)&&d.modelValue<=d.min),S=(0,n.EW)(()=>(0,p.Et)(d.modelValue)&&d.modelValue>=d.max),E=(0,n.EW)(()=>{const e=W(d.step);return(0,p.b0)(d.precision)?Math.max(W(d.modelValue),e):(e>d.precision&&(0,M.U)("InputNumber","precision should not be less than the decimal places of step"),d.precision)}),A=(0,n.EW)(()=>d.controls&&"right"===d.controlsPosition),N=(0,z.NV)(),_=(0,z.CB)(),T=(0,n.EW)(()=>{if(null!==g.userInput)return g.userInput;let e=g.currentValue;if((0,r.A)(e))return"";if((0,p.Et)(e)){if(Number.isNaN(e))return"";(0,p.b0)(d.precision)||(e=e.toFixed(d.precision))}return e}),O=(e,t)=>{if((0,p.b0)(t)&&(t=E.value),0===t)return Math.round(e);let l=String(e);const n=l.indexOf(".");if(-1===n)return e;const a=l.replace(".","").split(""),o=a[n+t];if(!o)return e;const c=l.length;return"5"===l.charAt(c-1)&&(l=`${l.slice(0,Math.max(0,c-1))}6`),Number.parseFloat(Number(l).toFixed(t))},W=e=>{if((0,r.A)(e))return 0;const t=e.toString(),l=t.indexOf(".");let n=0;return-1!==l&&(n=t.length-l-1),n},B=(e,t=1)=>(0,p.Et)(e)?e>=Number.MAX_SAFE_INTEGER&&1===t?((0,M.U)("InputNumber","The value has reached the maximum safe integer limit."),e):e<=Number.MIN_SAFE_INTEGER&&-1===t?((0,M.U)("InputNumber","The value has reached the minimum safe integer limit."),e):O(e+d.step*t):g.currentValue,I=e=>{const t=(0,C.CG)(e),l=(0,C.K)(e);if(d.disabledScientific&&["e","E"].includes(l))e.preventDefault();else switch(t){case R.R.up:e.preventDefault(),D();break;case R.R.down:e.preventDefault(),F();break}},D=()=>{if(d.readonly||_.value||S.value)return;const e=Number(T.value)||0,t=B(e);P(t),l(v.qs,g.currentValue),q()},F=()=>{if(d.readonly||_.value||k.value)return;const e=Number(T.value)||0,t=B(e,-1);P(t),l(v.qs,g.currentValue),q()},V=(e,t)=>{const{max:n,min:a,step:c,precision:s,stepStrictly:i,valueOnClear:u}=d;nn||fn?n:a,t&&l(v.l4,f)),f},P=(e,t=!0)=>{var n;const a=g.currentValue,o=V(e);t?(g.userInput=null,a===o&&e||(l(v.l4,o),a!==o&&l(v.YU,o,a),d.validateEvent&&(null==(n=null==b?void 0:b.validate)||n.call(b,"change").catch(e=>(0,M.U)(e))),g.currentValue=o)):l(v.l4,o)},$=e=>{g.userInput=e;const t=""===e?null:Number(e);l(v.qs,t),P(t,!1)},H=e=>{const t=""!==e?Number(e):"";((0,p.Et)(t)&&!Number.isNaN(t)||""===e)&&P(t),q(),g.userInput=null},j=()=>{var e,t;null==(t=null==(e=h.value)?void 0:e.focus)||t.call(e)},K=()=>{var e,t;null==(t=null==(e=h.value)?void 0:e.blur)||t.call(e)},X=e=>{l("focus",e)},U=e=>{var t,n;g.userInput=null,null===g.currentValue&&(null==(t=h.value)?void 0:t.input)&&(h.value.input.value=""),l("blur",e),d.validateEvent&&(null==(n=null==b?void 0:b.validate)||n.call(b,"blur").catch(e=>(0,M.U)(e)))},q=()=>{g.currentValue!==d.modelValue&&(g.currentValue=d.modelValue)},G=e=>{document.activeElement===e.target&&e.preventDefault()};return(0,n.wB)(()=>d.modelValue,(e,t)=>{const l=V(e,!0);null===g.userInput&&l!==t&&(g.currentValue=l)},{immediate:!0}),(0,n.wB)(()=>d.precision,()=>{g.currentValue=V(d.modelValue)}),(0,n.sV)(()=>{var e;const{min:t,max:n,modelValue:a}=d,o=null==(e=h.value)?void 0:e.input;if(o.setAttribute("role","spinbutton"),Number.isFinite(n)?o.setAttribute("aria-valuemax",String(n)):o.removeAttribute("aria-valuemax"),Number.isFinite(t)?o.setAttribute("aria-valuemin",String(t)):o.removeAttribute("aria-valuemin"),o.setAttribute("aria-valuenow",g.currentValue||0===g.currentValue?String(g.currentValue):""),o.setAttribute("aria-disabled",String(_.value)),!(0,p.Et)(a)&&null!=a){let e=Number(a);Number.isNaN(e)&&(e=null),l(v.l4,e)}o.addEventListener("wheel",G,{passive:!1})}),(0,n.$u)(()=>{var e,t;const l=null==(e=h.value)?void 0:e.input;null==l||l.setAttribute("aria-valuenow",`${null!=(t=g.currentValue)?t:""}`)}),t({focus:j,blur:K}),(e,t)=>((0,n.uX)(),(0,n.CE)("div",{class:(0,o.C4)([(0,a.R1)(m).b(),(0,a.R1)(m).m((0,a.R1)(N)),(0,a.R1)(m).is("disabled",(0,a.R1)(_)),(0,a.R1)(m).is("without-controls",!e.controls),(0,a.R1)(m).is("controls-right",(0,a.R1)(A)),(0,a.R1)(m).is(e.align,!!e.align)]),onDragstart:(0,c.D$)(()=>{},["prevent"])},[e.controls?(0,n.bo)(((0,n.uX)(),(0,n.CE)("span",{key:0,role:"button","aria-label":(0,a.R1)(f)("el.inputNumber.decrease"),class:(0,o.C4)([(0,a.R1)(m).e("decrease"),(0,a.R1)(m).is("disabled",(0,a.R1)(k))]),onKeydown:(0,c.jR)(F,["enter"])},[(0,n.RG)(e.$slots,"decrease-icon",{},()=>[(0,n.bF)((0,a.R1)(i.tk),null,{default:(0,n.k6)(()=>[(0,a.R1)(A)?((0,n.uX)(),(0,n.Wv)((0,a.R1)(u.ArrowDown),{key:0})):((0,n.uX)(),(0,n.Wv)((0,a.R1)(u.Minus),{key:1}))]),_:1})])],42,["aria-label","onKeydown"])),[[(0,a.R1)(y.wc),F]]):(0,n.Q3)("v-if",!0),e.controls?(0,n.bo)(((0,n.uX)(),(0,n.CE)("span",{key:1,role:"button","aria-label":(0,a.R1)(f)("el.inputNumber.increase"),class:(0,o.C4)([(0,a.R1)(m).e("increase"),(0,a.R1)(m).is("disabled",(0,a.R1)(S))]),onKeydown:(0,c.jR)(D,["enter"])},[(0,n.RG)(e.$slots,"increase-icon",{},()=>[(0,n.bF)((0,a.R1)(i.tk),null,{default:(0,n.k6)(()=>[(0,a.R1)(A)?((0,n.uX)(),(0,n.Wv)((0,a.R1)(u.ArrowUp),{key:0})):((0,n.uX)(),(0,n.Wv)((0,a.R1)(u.Plus),{key:1}))]),_:1})])],42,["aria-label","onKeydown"])),[[(0,a.R1)(y.wc),D]]):(0,n.Q3)("v-if",!0),(0,n.bF)((0,a.R1)(s.WK),{id:e.id,ref_key:"input",ref:h,type:"number",step:e.step,"model-value":(0,a.R1)(T),placeholder:e.placeholder,readonly:e.readonly,disabled:(0,a.R1)(_),size:(0,a.R1)(N),max:e.max,min:e.min,name:e.name,"aria-label":e.ariaLabel,"validate-event":!1,inputmode:e.inputmode,onKeydown:I,onBlur:U,onFocus:X,onInput:$,onChange:H},(0,n.eX)({_:2},[e.$slots.prefix?{name:"prefix",fn:(0,n.k6)(()=>[(0,n.RG)(e.$slots,"prefix")])}:void 0,e.$slots.suffix?{name:"suffix",fn:(0,n.k6)(()=>[(0,n.RG)(e.$slots,"suffix")])}:void 0]),1032,["id","step","model-value","placeholder","readonly","disabled","size","max","min","name","aria-label","inputmode"])],42,["onDragstart"]))}});var E=(0,b.A)(S,[["__file","input-number.vue"]]),A=l(5376);const N=(0,A.GU)(E)},1513:function(e,t,l){"use strict";l.d(t,{q:function(){return _}});l(4114);function n(e,t){o(e)&&(e="100%");var l=c(e);return e=360===t?e:Math.min(t,Math.max(0,parseFloat(e))),l&&(e=parseInt(String(e*t),10)/100),Math.abs(e-t)<1e-6?1:(e=360===t?(e<0?e%t+t:e%t)/parseFloat(String(t)):e%t/parseFloat(String(t)),e)}function a(e){return Math.min(1,Math.max(0,e))}function o(e){return"string"===typeof e&&-1!==e.indexOf(".")&&1===parseFloat(e)}function c(e){return"string"===typeof e&&-1!==e.indexOf("%")}function r(e){return e=parseFloat(e),(isNaN(e)||e<0||e>1)&&(e=1),e}function s(e){return e<=1?"".concat(100*Number(e),"%"):e}function i(e){return 1===e.length?"0"+e:String(e)}function u(e,t,l){return{r:255*n(e,255),g:255*n(t,255),b:255*n(l,255)}}function d(e,t,l){e=n(e,255),t=n(t,255),l=n(l,255);var a=Math.max(e,t,l),o=Math.min(e,t,l),c=0,r=0,s=(a+o)/2;if(a===o)r=0,c=0;else{var i=a-o;switch(r=s>.5?i/(2-a-o):i/(a+o),a){case e:c=(t-l)/i+(t1&&(l-=1),l<1/6?e+6*l*(t-e):l<.5?t:l<2/3?e+(t-e)*(2/3-l)*6:e}function p(e,t,l){var a,o,c;if(e=n(e,360),t=n(t,100),l=n(l,100),0===t)o=l,c=l,a=l;else{var r=l<.5?l*(1+t):l+t-l*t,s=2*l-r;a=f(s,r,e+1/3),o=f(s,r,e),c=f(s,r,e-1/3)}return{r:255*a,g:255*o,b:255*c}}function m(e,t,l){e=n(e,255),t=n(t,255),l=n(l,255);var a=Math.max(e,t,l),o=Math.min(e,t,l),c=0,r=a,s=a-o,i=0===a?0:s/a;if(a===o)c=0;else{switch(a){case e:c=(t-l)/s+(t>16,g:(65280&e)>>8,b:255&e}}var L={aliceblue:"#f0f8ff",antiquewhite:"#faebd7",aqua:"#00ffff",aquamarine:"#7fffd4",azure:"#f0ffff",beige:"#f5f5dc",bisque:"#ffe4c4",black:"#000000",blanchedalmond:"#ffebcd",blue:"#0000ff",blueviolet:"#8a2be2",brown:"#a52a2a",burlywood:"#deb887",cadetblue:"#5f9ea0",chartreuse:"#7fff00",chocolate:"#d2691e",coral:"#ff7f50",cornflowerblue:"#6495ed",cornsilk:"#fff8dc",crimson:"#dc143c",cyan:"#00ffff",darkblue:"#00008b",darkcyan:"#008b8b",darkgoldenrod:"#b8860b",darkgray:"#a9a9a9",darkgreen:"#006400",darkgrey:"#a9a9a9",darkkhaki:"#bdb76b",darkmagenta:"#8b008b",darkolivegreen:"#556b2f",darkorange:"#ff8c00",darkorchid:"#9932cc",darkred:"#8b0000",darksalmon:"#e9967a",darkseagreen:"#8fbc8f",darkslateblue:"#483d8b",darkslategray:"#2f4f4f",darkslategrey:"#2f4f4f",darkturquoise:"#00ced1",darkviolet:"#9400d3",deeppink:"#ff1493",deepskyblue:"#00bfff",dimgray:"#696969",dimgrey:"#696969",dodgerblue:"#1e90ff",firebrick:"#b22222",floralwhite:"#fffaf0",forestgreen:"#228b22",fuchsia:"#ff00ff",gainsboro:"#dcdcdc",ghostwhite:"#f8f8ff",goldenrod:"#daa520",gold:"#ffd700",gray:"#808080",green:"#008000",greenyellow:"#adff2f",grey:"#808080",honeydew:"#f0fff0",hotpink:"#ff69b4",indianred:"#cd5c5c",indigo:"#4b0082",ivory:"#fffff0",khaki:"#f0e68c",lavenderblush:"#fff0f5",lavender:"#e6e6fa",lawngreen:"#7cfc00",lemonchiffon:"#fffacd",lightblue:"#add8e6",lightcoral:"#f08080",lightcyan:"#e0ffff",lightgoldenrodyellow:"#fafad2",lightgray:"#d3d3d3",lightgreen:"#90ee90",lightgrey:"#d3d3d3",lightpink:"#ffb6c1",lightsalmon:"#ffa07a",lightseagreen:"#20b2aa",lightskyblue:"#87cefa",lightslategray:"#778899",lightslategrey:"#778899",lightsteelblue:"#b0c4de",lightyellow:"#ffffe0",lime:"#00ff00",limegreen:"#32cd32",linen:"#faf0e6",magenta:"#ff00ff",maroon:"#800000",mediumaquamarine:"#66cdaa",mediumblue:"#0000cd",mediumorchid:"#ba55d3",mediumpurple:"#9370db",mediumseagreen:"#3cb371",mediumslateblue:"#7b68ee",mediumspringgreen:"#00fa9a",mediumturquoise:"#48d1cc",mediumvioletred:"#c71585",midnightblue:"#191970",mintcream:"#f5fffa",mistyrose:"#ffe4e1",moccasin:"#ffe4b5",navajowhite:"#ffdead",navy:"#000080",oldlace:"#fdf5e6",olive:"#808000",olivedrab:"#6b8e23",orange:"#ffa500",orangered:"#ff4500",orchid:"#da70d6",palegoldenrod:"#eee8aa",palegreen:"#98fb98",paleturquoise:"#afeeee",palevioletred:"#db7093",papayawhip:"#ffefd5",peachpuff:"#ffdab9",peru:"#cd853f",pink:"#ffc0cb",plum:"#dda0dd",powderblue:"#b0e0e6",purple:"#800080",rebeccapurple:"#663399",red:"#ff0000",rosybrown:"#bc8f8f",royalblue:"#4169e1",saddlebrown:"#8b4513",salmon:"#fa8072",sandybrown:"#f4a460",seagreen:"#2e8b57",seashell:"#fff5ee",sienna:"#a0522d",silver:"#c0c0c0",skyblue:"#87ceeb",slateblue:"#6a5acd",slategray:"#708090",slategrey:"#708090",snow:"#fffafa",springgreen:"#00ff7f",steelblue:"#4682b4",tan:"#d2b48c",teal:"#008080",thistle:"#d8bfd8",tomato:"#ff6347",turquoise:"#40e0d0",violet:"#ee82ee",wheat:"#f5deb3",white:"#ffffff",whitesmoke:"#f5f5f5",yellow:"#ffff00",yellowgreen:"#9acd32"};function x(e){var t={r:0,g:0,b:0},l=1,n=null,a=null,o=null,c=!1,i=!1;return"string"===typeof e&&(e=A(e)),"object"===typeof e&&(N(e.r)&&N(e.g)&&N(e.b)?(t=u(e.r,e.g,e.b),c=!0,i="%"===String(e.r).substr(-1)?"prgb":"rgb"):N(e.h)&&N(e.s)&&N(e.v)?(n=s(e.s),a=s(e.v),t=v(e.h,n,a),c=!0,i="hsv"):N(e.h)&&N(e.s)&&N(e.l)&&(n=s(e.s),o=s(e.l),t=p(e.h,n,o),c=!0,i="hsl"),Object.prototype.hasOwnProperty.call(e,"a")&&(l=e.a)),l=r(l),{ok:c,format:e.format||i,r:Math.min(255,Math.max(t.r,0)),g:Math.min(255,Math.max(t.g,0)),b:Math.min(255,Math.max(t.b,0)),a:l}}var M="[-\\+]?\\d+%?",z="[-\\+]?\\d*\\.\\d+%?",R="(?:".concat(z,")|(?:").concat(M,")"),k="[\\s|\\(]+(".concat(R,")[,|\\s]+(").concat(R,")[,|\\s]+(").concat(R,")\\s*\\)?"),S="[\\s|\\(]+(".concat(R,")[,|\\s]+(").concat(R,")[,|\\s]+(").concat(R,")[,|\\s]+(").concat(R,")\\s*\\)?"),E={CSS_UNIT:new RegExp(R),rgb:new RegExp("rgb"+k),rgba:new RegExp("rgba"+S),hsl:new RegExp("hsl"+k),hsla:new RegExp("hsla"+S),hsv:new RegExp("hsv"+k),hsva:new RegExp("hsva"+S),hex3:/^#?([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,hex6:/^#?([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/,hex4:/^#?([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,hex8:/^#?([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/};function A(e){if(e=e.trim().toLowerCase(),0===e.length)return!1;var t=!1;if(L[e])e=L[e],t=!0;else if("transparent"===e)return{r:0,g:0,b:0,a:0,format:"name"};var l=E.rgb.exec(e);return l?{r:l[1],g:l[2],b:l[3]}:(l=E.rgba.exec(e),l?{r:l[1],g:l[2],b:l[3],a:l[4]}:(l=E.hsl.exec(e),l?{h:l[1],s:l[2],l:l[3]}:(l=E.hsla.exec(e),l?{h:l[1],s:l[2],l:l[3],a:l[4]}:(l=E.hsv.exec(e),l?{h:l[1],s:l[2],v:l[3]}:(l=E.hsva.exec(e),l?{h:l[1],s:l[2],v:l[3],a:l[4]}:(l=E.hex8.exec(e),l?{r:C(l[1]),g:C(l[2]),b:C(l[3]),a:y(l[4]),format:t?"name":"hex8"}:(l=E.hex6.exec(e),l?{r:C(l[1]),g:C(l[2]),b:C(l[3]),format:t?"name":"hex"}:(l=E.hex4.exec(e),l?{r:C(l[1]+l[1]),g:C(l[2]+l[2]),b:C(l[3]+l[3]),a:y(l[4]+l[4]),format:t?"name":"hex8"}:(l=E.hex3.exec(e),!!l&&{r:C(l[1]+l[1]),g:C(l[2]+l[2]),b:C(l[3]+l[3]),format:t?"name":"hex"})))))))))}function N(e){return Boolean(E.CSS_UNIT.exec(String(e)))}var _=function(){function e(t,l){var n;if(void 0===t&&(t=""),void 0===l&&(l={}),t instanceof e)return t;"number"===typeof t&&(t=w(t)),this.originalInput=t;var a=x(t);this.originalInput=t,this.r=a.r,this.g=a.g,this.b=a.b,this.a=a.a,this.roundA=Math.round(100*this.a)/100,this.format=null!==(n=l.format)&&void 0!==n?n:a.format,this.gradientType=l.gradientType,this.r<1&&(this.r=Math.round(this.r)),this.g<1&&(this.g=Math.round(this.g)),this.b<1&&(this.b=Math.round(this.b)),this.isValid=a.ok}return e.prototype.isDark=function(){return this.getBrightness()<128},e.prototype.isLight=function(){return!this.isDark()},e.prototype.getBrightness=function(){var e=this.toRgb();return(299*e.r+587*e.g+114*e.b)/1e3},e.prototype.getLuminance=function(){var e,t,l,n=this.toRgb(),a=n.r/255,o=n.g/255,c=n.b/255;return e=a<=.03928?a/12.92:Math.pow((a+.055)/1.055,2.4),t=o<=.03928?o/12.92:Math.pow((o+.055)/1.055,2.4),l=c<=.03928?c/12.92:Math.pow((c+.055)/1.055,2.4),.2126*e+.7152*t+.0722*l},e.prototype.getAlpha=function(){return this.a},e.prototype.setAlpha=function(e){return this.a=r(e),this.roundA=Math.round(100*this.a)/100,this},e.prototype.isMonochrome=function(){var e=this.toHsl().s;return 0===e},e.prototype.toHsv=function(){var e=m(this.r,this.g,this.b);return{h:360*e.h,s:e.s,v:e.v,a:this.a}},e.prototype.toHsvString=function(){var e=m(this.r,this.g,this.b),t=Math.round(360*e.h),l=Math.round(100*e.s),n=Math.round(100*e.v);return 1===this.a?"hsv(".concat(t,", ").concat(l,"%, ").concat(n,"%)"):"hsva(".concat(t,", ").concat(l,"%, ").concat(n,"%, ").concat(this.roundA,")")},e.prototype.toHsl=function(){var e=d(this.r,this.g,this.b);return{h:360*e.h,s:e.s,l:e.l,a:this.a}},e.prototype.toHslString=function(){var e=d(this.r,this.g,this.b),t=Math.round(360*e.h),l=Math.round(100*e.s),n=Math.round(100*e.l);return 1===this.a?"hsl(".concat(t,", ").concat(l,"%, ").concat(n,"%)"):"hsla(".concat(t,", ").concat(l,"%, ").concat(n,"%, ").concat(this.roundA,")")},e.prototype.toHex=function(e){return void 0===e&&(e=!1),h(this.r,this.g,this.b,e)},e.prototype.toHexString=function(e){return void 0===e&&(e=!1),"#"+this.toHex(e)},e.prototype.toHex8=function(e){return void 0===e&&(e=!1),g(this.r,this.g,this.b,this.a,e)},e.prototype.toHex8String=function(e){return void 0===e&&(e=!1),"#"+this.toHex8(e)},e.prototype.toHexShortString=function(e){return void 0===e&&(e=!1),1===this.a?this.toHexString(e):this.toHex8String(e)},e.prototype.toRgb=function(){return{r:Math.round(this.r),g:Math.round(this.g),b:Math.round(this.b),a:this.a}},e.prototype.toRgbString=function(){var e=Math.round(this.r),t=Math.round(this.g),l=Math.round(this.b);return 1===this.a?"rgb(".concat(e,", ").concat(t,", ").concat(l,")"):"rgba(".concat(e,", ").concat(t,", ").concat(l,", ").concat(this.roundA,")")},e.prototype.toPercentageRgb=function(){var e=function(e){return"".concat(Math.round(100*n(e,255)),"%")};return{r:e(this.r),g:e(this.g),b:e(this.b),a:this.a}},e.prototype.toPercentageRgbString=function(){var e=function(e){return Math.round(100*n(e,255))};return 1===this.a?"rgb(".concat(e(this.r),"%, ").concat(e(this.g),"%, ").concat(e(this.b),"%)"):"rgba(".concat(e(this.r),"%, ").concat(e(this.g),"%, ").concat(e(this.b),"%, ").concat(this.roundA,")")},e.prototype.toName=function(){if(0===this.a)return"transparent";if(this.a<1)return!1;for(var e="#"+h(this.r,this.g,this.b,!1),t=0,l=Object.entries(L);t=0,a=!t&&n&&(e.startsWith("hex")||"name"===e);return a?"name"===e&&0===this.a?this.toName():this.toRgbString():("rgb"===e&&(l=this.toRgbString()),"prgb"===e&&(l=this.toPercentageRgbString()),"hex"!==e&&"hex6"!==e||(l=this.toHexString()),"hex3"===e&&(l=this.toHexString(!0)),"hex4"===e&&(l=this.toHex8String(!0)),"hex8"===e&&(l=this.toHex8String()),"name"===e&&(l=this.toName()),"hsl"===e&&(l=this.toHslString()),"hsv"===e&&(l=this.toHsvString()),l||this.toHexString())},e.prototype.toNumber=function(){return(Math.round(this.r)<<16)+(Math.round(this.g)<<8)+Math.round(this.b)},e.prototype.clone=function(){return new e(this.toString())},e.prototype.lighten=function(t){void 0===t&&(t=10);var l=this.toHsl();return l.l+=t/100,l.l=a(l.l),new e(l)},e.prototype.brighten=function(t){void 0===t&&(t=10);var l=this.toRgb();return l.r=Math.max(0,Math.min(255,l.r-Math.round(-t/100*255))),l.g=Math.max(0,Math.min(255,l.g-Math.round(-t/100*255))),l.b=Math.max(0,Math.min(255,l.b-Math.round(-t/100*255))),new e(l)},e.prototype.darken=function(t){void 0===t&&(t=10);var l=this.toHsl();return l.l-=t/100,l.l=a(l.l),new e(l)},e.prototype.tint=function(e){return void 0===e&&(e=10),this.mix("white",e)},e.prototype.shade=function(e){return void 0===e&&(e=10),this.mix("black",e)},e.prototype.desaturate=function(t){void 0===t&&(t=10);var l=this.toHsl();return l.s-=t/100,l.s=a(l.s),new e(l)},e.prototype.saturate=function(t){void 0===t&&(t=10);var l=this.toHsl();return l.s+=t/100,l.s=a(l.s),new e(l)},e.prototype.greyscale=function(){return this.desaturate(100)},e.prototype.spin=function(t){var l=this.toHsl(),n=(l.h+t)%360;return l.h=n<0?360+n:n,new e(l)},e.prototype.mix=function(t,l){void 0===l&&(l=50);var n=this.toRgb(),a=new e(t).toRgb(),o=l/100,c={r:(a.r-n.r)*o+n.r,g:(a.g-n.g)*o+n.g,b:(a.b-n.b)*o+n.b,a:(a.a-n.a)*o+n.a};return new e(c)},e.prototype.analogous=function(t,l){void 0===t&&(t=6),void 0===l&&(l=30);var n=this.toHsl(),a=360/l,o=[this];for(n.h=(n.h-(a*t>>1)+720)%360;--t;)n.h=(n.h+a)%360,o.push(new e(n));return o},e.prototype.complement=function(){var t=this.toHsl();return t.h=(t.h+180)%360,new e(t)},e.prototype.monochromatic=function(t){void 0===t&&(t=6);var l=this.toHsv(),n=l.h,a=l.s,o=l.v,c=[],r=1/t;while(t--)c.push(new e({h:n,s:a,v:o})),o=(o+r)%1;return c},e.prototype.splitcomplement=function(){var t=this.toHsl(),l=t.h;return[this,new e({h:(l+72)%360,s:t.s,l:t.l}),new e({h:(l+216)%360,s:t.s,l:t.l})]},e.prototype.onBackground=function(t){var l=this.toRgb(),n=new e(t).toRgb(),a=l.a+n.a*(1-l.a);return new e({r:(l.r*l.a+n.r*n.a*(1-l.a))/a,g:(l.g*l.a+n.g*n.a*(1-l.a))/a,b:(l.b*l.a+n.b*n.a*(1-l.a))/a,a:a})},e.prototype.triad=function(){return this.polyad(3)},e.prototype.tetrad=function(){return this.polyad(4)},e.prototype.polyad=function(t){for(var l=this.toHsl(),n=l.h,a=[this],o=360/t,c=1;c92||"NODE"===c&&o>94||"BROWSER"===c&&o>97)return!1;var e=new ArrayBuffer(8),t=r(e,{transfer:[e]});return 0!==e.byteLength||8!==t.byteLength})},1549:function(e,t,l){"use strict";l(6632)},1576:function(e){!function(t,l){e.exports=l()}(0,function(){"use strict";var e=1e3,t=6e4,l=36e5,n="millisecond",a="second",o="minute",c="hour",r="day",s="week",i="month",u="quarter",d="year",f="date",p="Invalid Date",m=/^(\d{4})[-/]?(\d{1,2})?[-/]?(\d{0,2})[Tt\s]*(\d{1,2})?:?(\d{1,2})?:?(\d{1,2})?[.:]?(\d+)?$/,v=/\[([^\]]+)]|Y{1,4}|M{1,4}|D{1,2}|d{1,4}|H{1,2}|h{1,2}|a|A|m{1,2}|s{1,2}|Z{1,2}|SSS/g,h={name:"en",weekdays:"Sunday_Monday_Tuesday_Wednesday_Thursday_Friday_Saturday".split("_"),months:"January_February_March_April_May_June_July_August_September_October_November_December".split("_"),ordinal:function(e){var t=["th","st","nd","rd"],l=e%100;return"["+e+(t[(l-20)%10]||t[l]||t[0])+"]"}},g=function(e,t,l){var n=String(e);return!n||n.length>=t?e:""+Array(t+1-n.length).join(l)+e},b={s:g,z:function(e){var t=-e.utcOffset(),l=Math.abs(t),n=Math.floor(l/60),a=l%60;return(t<=0?"+":"-")+g(n,2,"0")+":"+g(a,2,"0")},m:function e(t,l){if(t.date()1)return e(c[0])}else{var r=t.name;C[r]=t,a=r}return!n&&a&&(y=a),a||!n&&y},M=function(e,t){if(L(e))return e.clone();var l="object"==typeof t?t:{};return l.date=e,l.args=arguments,new R(l)},z=b;z.l=x,z.i=L,z.w=function(e,t){return M(e,{locale:t.$L,utc:t.$u,x:t.$x,$offset:t.$offset})};var R=function(){function h(e){this.$L=x(e.locale,null,!0),this.parse(e),this.$x=this.$x||e.x||{},this[w]=!0}var g=h.prototype;return g.parse=function(e){this.$d=function(e){var t=e.date,l=e.utc;if(null===t)return new Date(NaN);if(z.u(t))return new Date;if(t instanceof Date)return new Date(t);if("string"==typeof t&&!/Z$/i.test(t)){var n=t.match(m);if(n){var a=n[2]-1||0,o=(n[7]||"0").substring(0,3);return l?new Date(Date.UTC(n[1],a,n[3]||1,n[4]||0,n[5]||0,n[6]||0,o)):new Date(n[1],a,n[3]||1,n[4]||0,n[5]||0,n[6]||0,o)}}return new Date(t)}(e),this.init()},g.init=function(){var e=this.$d;this.$y=e.getFullYear(),this.$M=e.getMonth(),this.$D=e.getDate(),this.$W=e.getDay(),this.$H=e.getHours(),this.$m=e.getMinutes(),this.$s=e.getSeconds(),this.$ms=e.getMilliseconds()},g.$utils=function(){return z},g.isValid=function(){return!(this.$d.toString()===p)},g.isSame=function(e,t){var l=M(e);return this.startOf(t)<=l&&l<=this.endOf(t)},g.isAfter=function(e,t){return M(e)n.Loading},plain:{type:Boolean,default:void 0},text:{type:Boolean,default:void 0},link:Boolean,bg:Boolean,autofocus:Boolean,round:{type:Boolean,default:void 0},circle:Boolean,color:String,dark:Boolean,autoInsertSpace:{type:Boolean,default:void 0},tag:{type:(0,a.jq)([String,Object]),default:"button"}}),u={click:e=>e instanceof MouseEvent}},1588:function(e,t,l){"use strict";l.d(t,{A:function(){return u},k:function(){return i}});var n=l(6768),a=l(8114),o=l(9180),c=l(7378),r=l(3845);const s=(0,c.b_)({a11y:{type:Boolean,default:!0},locale:{type:(0,c.jq)(Object)},size:r.mU,button:{type:(0,c.jq)(Object)},card:{type:(0,c.jq)(Object)},dialog:{type:(0,c.jq)(Object)},link:{type:(0,c.jq)(Object)},experimentalFeatures:{type:(0,c.jq)(Object)},keyboardNavigation:{type:Boolean,default:!0},message:{type:(0,c.jq)(Object)},zIndex:Number,namespace:{type:String,default:"el"},...o.bs}),i={placement:"top"},u=(0,n.pM)({name:"ElConfigProvider",props:s,setup(e,{slots:t}){const l=(0,a.Vh)(e);return(0,n.wB)(()=>e.message,e=>{var t,n;Object.assign(i,null!=(n=null==(t=null==l?void 0:l.value)?void 0:t.message)?n:{},null!=e?e:{})},{immediate:!0,deep:!0}),()=>(0,n.RG)(t,"default",{config:null==l?void 0:l.value})}})},1591:function(e,t,l){"use strict";l.d(t,{A:function(){return b}});var n=l(2990),a=Object.prototype,o=a.hasOwnProperty,c=a.toString,r=n.A?n.A.toStringTag:void 0;function s(e){var t=o.call(e,r),l=e[r];try{e[r]=void 0;var n=!0}catch(s){}var a=c.call(e);return n&&(t?e[r]=l:delete e[r]),a}var i=s,u=Object.prototype,d=u.toString;function f(e){return d.call(e)}var p=f,m="[object Null]",v="[object Undefined]",h=n.A?n.A.toStringTag:void 0;function g(e){return null==e?void 0===e?v:m:h&&h in Object(e)?i(e):p(e)}var b=g},1625:function(e,t,l){"use strict";var n=l(9504);e.exports=n({}.isPrototypeOf)},1698:function(e,t,l){"use strict";var n=l(6518),a=l(4204),o=l(9835),c=l(4916),r=!c("union")||!o("union");n({target:"Set",proto:!0,real:!0,forced:r},{union:a})},1701:function(e,t,l){"use strict";var n=l(6518),a=l(9565),o=l(9306),c=l(8551),r=l(1767),s=l(9462),i=l(6319),u=l(9539),d=l(684),f=l(4549),p=l(6395),m=!p&&!d("map",function(){}),v=!p&&!m&&f("map",TypeError),h=p||m||v,g=s(function(){var e=this.iterator,t=c(a(this.next,e)),l=this.done=!!t.done;if(!l)return i(e,this.mapper,[t.value,this.counter++],!0)});n({target:"Iterator",proto:!0,real:!0,forced:h},{map:function(e){c(this);try{o(e)}catch(t){u(this,"throw",t)}return v?a(v,this,e):new g(r(this),{mapper:e})}})},1767:function(e){"use strict";e.exports=function(e){return{iterator:e,next:e.next,done:!1}}},1801:function(e,t,l){"use strict";function n(e,t){var l=-1,n=null==e?0:e.length,a=0,o=[];while(++li)a(n,l=t[i++])&&(~c(u,l)||s(u,l));return u}},1862:function(){},1939:function(e,t,l){"use strict";l.d(t,{K:function(){return s}});var n=l(6768),a=l(144),o=l(7687),c=l(6340),r=l(4232);function s(e,{disabled:t,beforeFocus:l,afterFocus:s,beforeBlur:i,afterBlur:u}={}){const d=(0,n.nI)(),{emit:f}=d,p=(0,a.IJ)(),m=(0,a.KR)(!1),v=e=>{const n=!!(0,r.Tn)(l)&&l(e);(0,a.R1)(t)||m.value||n||(m.value=!0,f("focus",e),null==s||s())},h=e=>{var l;const n=!!(0,r.Tn)(i)&&i(e);(0,a.R1)(t)||e.relatedTarget&&(null==(l=p.value)?void 0:l.contains(e.relatedTarget))||n||(m.value=!1,f("blur",e),null==u||u())},g=l=>{var n,o;(0,a.R1)(t)||(0,c.tp)(l.target)||(null==(n=p.value)?void 0:n.contains(document.activeElement))&&p.value!==document.activeElement||null==(o=e.value)||o.focus()};return(0,n.wB)([p,()=>(0,a.R1)(t)],([e,t])=>{e&&(t?e.removeAttribute("tabindex"):e.setAttribute("tabindex","-1"))}),(0,o.MLh)(p,"focus",v,!0),(0,o.MLh)(p,"blur",h,!0),(0,o.MLh)(p,"click",g,!0),{isFocused:m,wrapperRef:p,handleFocus:v,handleBlur:h}}},1968:function(e,t,l){"use strict";l.d(t,{r:function(){return a}});var n=l(4232);const a=e=>{if(!e)return{onClick:n.tE,onMousedown:n.tE,onMouseup:n.tE};let t=!1,l=!1;const a=n=>{t&&l&&e(n),t=l=!1},o=e=>{t=e.target===e.currentTarget},c=e=>{l=e.target===e.currentTarget};return{onClick:a,onMousedown:o,onMouseup:c}}},1996:function(e,t,l){"use strict";l.d(t,{A:function(){return p}});var n=l(2623),a=l(203),o=l(5014);function c(e,t,l){var c=-1,r=t.length,s={};while(++c((0,o.cy)(e)||(0,o.Kg)(e))&&(0,i.Lm)(t)&&(0,o.Kg)(l)};l(2489),l(1701);var p=l(5951),m=l(6894);const v="ElForm";function h(){const e=(0,a.KR)([]),t=(0,n.EW)(()=>{if(!e.value.length)return"0";const t=Math.max(...e.value);return t?`${t}px`:""});function l(l){const n=e.value.indexOf(l);return-1===n&&"0"===t.value&&(0,m.U)(v,`unexpected width ${l}`),n}function o(t,n){if(t&&n){const a=l(n);e.value.splice(a,1,t)}else t&&e.value.push(t)}function c(t){const n=l(t);n>-1&&e.value.splice(n,1)}return{autoLabelWidth:t,registerLabelWidth:o,deregisterLabelWidth:c}}const g=(e,t)=>{const l=(0,p.A)(t).map(e=>(0,o.cy)(e)?e.join("."):e);return l.length>0?e.filter(e=>e.propString&&l.includes(e.propString)):e};var b=l(9077),y=l(2436),C=l(3513);const w="ElForm",L=(0,n.pM)({name:w}),x=(0,n.pM)({...L,props:d,emits:f,setup(e,{expose:t,emit:l}){const r=e,s=(0,a.KR)(),i=(0,a.Kh)([]),u=(0,y.NV)(),d=(0,C.DU)("form"),f=(0,n.EW)(()=>{const{labelPosition:e,inline:t}=r;return[d.b(),d.m(u.value||"default"),{[d.m(`label-${e}`)]:e,[d.m("inline")]:t}]}),p=e=>g(i,[e])[0],v=e=>{i.push(e)},b=e=>{e.prop&&i.splice(i.indexOf(e),1)},L=(e=[])=>{r.model?g(i,e).forEach(e=>e.resetField()):(0,m.U)(w,"model is required for resetFields to work.")},x=(e=[])=>{g(i,e).forEach(e=>e.clearValidate())},M=(0,n.EW)(()=>{const e=!!r.model;return e||(0,m.U)(w,"model is required for validate to work."),e}),z=e=>{if(0===i.length)return[];const t=g(i,e);return t.length?t:((0,m.U)(w,"please pass correct props!"),[])},R=async e=>S(void 0,e),k=async(e=[])=>{if(!M.value)return!1;const t=z(e);if(0===t.length)return!0;let l={};for(const a of t)try{await a.validate(""),"error"!==a.validateState||a.error||a.resetField()}catch(n){l={...l,...n}}return 0===Object.keys(l).length||Promise.reject(l)},S=async(e=[],t)=>{let l=!1;const n=!(0,o.Tn)(t);try{return l=await k(e),!0===l&&await(null==t?void 0:t(l)),l}catch(a){if(a instanceof Error)throw a;const e=a;if(r.scrollToError&&s.value){const e=s.value.querySelector(`.${d.b()}-item.is-error`);null==e||e.scrollIntoView(r.scrollIntoViewOptions)}return!l&&await(null==t?void 0:t(!1,e)),n&&Promise.reject(e)}},E=e=>{var t;const l=p(e);l&&(null==(t=l.$el)||t.scrollIntoView(r.scrollIntoViewOptions))};return(0,n.wB)(()=>r.rules,()=>{r.validateOnRuleChange&&R().catch(e=>(0,m.U)(e))},{deep:!0,flush:"post"}),(0,n.Gt)(c.F,(0,a.Kh)({...(0,a.QW)(r),emit:l,resetFields:L,clearValidate:x,validateField:S,getField:p,addField:v,removeField:b,...h()})),t({validate:R,validateField:S,resetFields:L,clearValidate:x,scrollToField:E,getField:p,fields:i}),(e,t)=>((0,n.uX)(),(0,n.CE)("form",{ref_key:"formRef",ref:s,class:(0,o.C4)((0,a.R1)(f))},[(0,n.RG)(e.$slots,"default")],2))}});var M=(0,b.A)(x,[["__file","form.vue"]]),z=(l(3579),l(5130));l(1148),l(3110),l(8335);function R(){return R=Object.assign?Object.assign.bind():function(e){for(var t=1;t1?t-1:0),n=1;n=o)return e;switch(e){case"%s":return String(l[a++]);case"%d":return Number(l[a++]);case"%j":try{return JSON.stringify(l[a++])}catch(t){return"[Circular]"}default:return e}});return c}return e}function D(e){return"string"===e||"url"===e||"hex"===e||"email"===e||"date"===e||"pattern"===e}function F(e,t){return void 0===e||null===e||(!("array"!==t||!Array.isArray(e)||e.length)||!(!D(t)||"string"!==typeof e||e))}function V(e,t,l){var n=[],a=0,o=e.length;function c(e){n.push.apply(n,e||[]),a++,a===o&&l(n)}e.forEach(function(e){t(e,c)})}function P(e,t,l){var n=0,a=e.length;function o(c){if(c&&c.length)l(c);else{var r=n;n+=1,r()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]+\.)+[a-zA-Z\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]{2,}))$/,hex:/^#?([a-f0-9]{6}|[a-f0-9]{3})$/i},ee={integer:function(e){return ee.number(e)&&parseInt(e,10)===e},float:function(e){return ee.number(e)&&!ee.integer(e)},array:function(e){return Array.isArray(e)},regexp:function(e){if(e instanceof RegExp)return!0;try{return!!new RegExp(e)}catch(t){return!1}},date:function(e){return"function"===typeof e.getTime&&"function"===typeof e.getMonth&&"function"===typeof e.getYear&&!isNaN(e.getTime())},number:function(e){return!isNaN(e)&&"number"===typeof e},object:function(e){return"object"===typeof e&&!ee.array(e)},method:function(e){return"function"===typeof e},email:function(e){return"string"===typeof e&&e.length<=320&&!!e.match(J.email)},url:function(e){return"string"===typeof e&&e.length<=2048&&!!e.match(Z())},hex:function(e){return"string"===typeof e&&!!e.match(J.hex)}},te=function(e,t,l,n,a){if(e.required&&void 0===t)Y(e,t,l,n,a);else{var o=["integer","float","array","regexp","object","method","email","number","date","url","hex"],c=e.type;o.indexOf(c)>-1?ee[c](t)||n.push(I(a.messages.types[c],e.fullField,e.type)):c&&typeof t!==e.type&&n.push(I(a.messages.types[c],e.fullField,e.type))}},le=function(e,t,l,n,a){var o="number"===typeof e.len,c="number"===typeof e.min,r="number"===typeof e.max,s=/[\uD800-\uDBFF][\uDC00-\uDFFF]/g,i=t,u=null,d="number"===typeof t,f="string"===typeof t,p=Array.isArray(t);if(d?u="number":f?u="string":p&&(u="array"),!u)return!1;p&&(i=t.length),f&&(i=t.replace(s,"_").length),o?i!==e.len&&n.push(I(a.messages[u].len,e.fullField,e.len)):c&&!r&&ie.max?n.push(I(a.messages[u].max,e.fullField,e.max)):c&&r&&(ie.max)&&n.push(I(a.messages[u].range,e.fullField,e.min,e.max))},ne="enum",ae=function(e,t,l,n,a){e[ne]=Array.isArray(e[ne])?e[ne]:[],-1===e[ne].indexOf(t)&&n.push(I(a.messages[ne],e.fullField,e[ne].join(", ")))},oe=function(e,t,l,n,a){if(e.pattern)if(e.pattern instanceof RegExp)e.pattern.lastIndex=0,e.pattern.test(t)||n.push(I(a.messages.pattern.mismatch,e.fullField,t,e.pattern));else if("string"===typeof e.pattern){var o=new RegExp(e.pattern);o.test(t)||n.push(I(a.messages.pattern.mismatch,e.fullField,t,e.pattern))}},ce={required:Y,whitespace:Q,type:te,range:le,enum:ae,pattern:oe},re=function(e,t,l,n,a){var o=[],c=e.required||!e.required&&n.hasOwnProperty(e.field);if(c){if(F(t,"string")&&!e.required)return l();ce.required(e,t,n,o,a,"string"),F(t,"string")||(ce.type(e,t,n,o,a),ce.range(e,t,n,o,a),ce.pattern(e,t,n,o,a),!0===e.whitespace&&ce.whitespace(e,t,n,o,a))}l(o)},se=function(e,t,l,n,a){var o=[],c=e.required||!e.required&&n.hasOwnProperty(e.field);if(c){if(F(t)&&!e.required)return l();ce.required(e,t,n,o,a),void 0!==t&&ce.type(e,t,n,o,a)}l(o)},ie=function(e,t,l,n,a){var o=[],c=e.required||!e.required&&n.hasOwnProperty(e.field);if(c){if(""===t&&(t=void 0),F(t)&&!e.required)return l();ce.required(e,t,n,o,a),void 0!==t&&(ce.type(e,t,n,o,a),ce.range(e,t,n,o,a))}l(o)},ue=function(e,t,l,n,a){var o=[],c=e.required||!e.required&&n.hasOwnProperty(e.field);if(c){if(F(t)&&!e.required)return l();ce.required(e,t,n,o,a),void 0!==t&&ce.type(e,t,n,o,a)}l(o)},de=function(e,t,l,n,a){var o=[],c=e.required||!e.required&&n.hasOwnProperty(e.field);if(c){if(F(t)&&!e.required)return l();ce.required(e,t,n,o,a),F(t)||ce.type(e,t,n,o,a)}l(o)},fe=function(e,t,l,n,a){var o=[],c=e.required||!e.required&&n.hasOwnProperty(e.field);if(c){if(F(t)&&!e.required)return l();ce.required(e,t,n,o,a),void 0!==t&&(ce.type(e,t,n,o,a),ce.range(e,t,n,o,a))}l(o)},pe=function(e,t,l,n,a){var o=[],c=e.required||!e.required&&n.hasOwnProperty(e.field);if(c){if(F(t)&&!e.required)return l();ce.required(e,t,n,o,a),void 0!==t&&(ce.type(e,t,n,o,a),ce.range(e,t,n,o,a))}l(o)},me=function(e,t,l,n,a){var o=[],c=e.required||!e.required&&n.hasOwnProperty(e.field);if(c){if((void 0===t||null===t)&&!e.required)return l();ce.required(e,t,n,o,a,"array"),void 0!==t&&null!==t&&(ce.type(e,t,n,o,a),ce.range(e,t,n,o,a))}l(o)},ve=function(e,t,l,n,a){var o=[],c=e.required||!e.required&&n.hasOwnProperty(e.field);if(c){if(F(t)&&!e.required)return l();ce.required(e,t,n,o,a),void 0!==t&&ce.type(e,t,n,o,a)}l(o)},he="enum",ge=function(e,t,l,n,a){var o=[],c=e.required||!e.required&&n.hasOwnProperty(e.field);if(c){if(F(t)&&!e.required)return l();ce.required(e,t,n,o,a),void 0!==t&&ce[he](e,t,n,o,a)}l(o)},be=function(e,t,l,n,a){var o=[],c=e.required||!e.required&&n.hasOwnProperty(e.field);if(c){if(F(t,"string")&&!e.required)return l();ce.required(e,t,n,o,a),F(t,"string")||ce.pattern(e,t,n,o,a)}l(o)},ye=function(e,t,l,n,a){var o=[],c=e.required||!e.required&&n.hasOwnProperty(e.field);if(c){if(F(t,"date")&&!e.required)return l();var r;if(ce.required(e,t,n,o,a),!F(t,"date"))r=t instanceof Date?t:new Date(t),ce.type(e,r,n,o,a),r&&ce.range(e,r.getTime(),n,o,a)}l(o)},Ce=function(e,t,l,n,a){var o=[],c=Array.isArray(t)?"array":typeof t;ce.required(e,t,n,o,a,c),l(o)},we=function(e,t,l,n,a){var o=e.type,c=[],r=e.required||!e.required&&n.hasOwnProperty(e.field);if(r){if(F(t,o)&&!e.required)return l();ce.required(e,t,n,c,a,o),F(t,o)||ce.type(e,t,n,c,a)}l(c)},Le=function(e,t,l,n,a){var o=[],c=e.required||!e.required&&n.hasOwnProperty(e.field);if(c){if(F(t)&&!e.required)return l();ce.required(e,t,n,o,a)}l(o)},xe={string:re,method:se,number:ie,boolean:ue,regexp:de,integer:fe,float:pe,array:me,object:ve,enum:ge,pattern:be,date:ye,url:we,hex:we,email:we,required:Ce,any:Le};function Me(){return{default:"Validation error on field %s",required:"%s is required",enum:"%s must be one of %s",whitespace:"%s cannot be empty",date:{format:"%s date %s is invalid for format %s",parse:"%s date could not be parsed, %s is invalid ",invalid:"%s date %s is invalid"},types:{string:"%s is not a %s",method:"%s is not a %s (function)",array:"%s is not an %s",object:"%s is not an %s",number:"%s is not a %s",date:"%s is not a %s",boolean:"%s is not a %s",integer:"%s is not an %s",float:"%s is not a %s",regexp:"%s is not a valid %s",email:"%s is not a valid %s",url:"%s is not a valid %s",hex:"%s is not a valid %s"},string:{len:"%s must be exactly %s characters",min:"%s must be at least %s characters",max:"%s cannot be longer than %s characters",range:"%s must be between %s and %s characters"},number:{len:"%s must equal %s",min:"%s cannot be less than %s",max:"%s cannot be greater than %s",range:"%s must be between %s and %s"},array:{len:"%s must be exactly %s in length",min:"%s cannot be less than %s in length",max:"%s cannot be greater than %s in length",range:"%s must be between %s and %s in length"},pattern:{mismatch:"%s value %s does not match pattern %s"},clone:function(){var e=JSON.parse(JSON.stringify(this));return e.clone=this.clone,e}}}var ze=Me(),Re=function(){function e(e){this.rules=null,this._messages=ze,this.define(e)}var t=e.prototype;return t.define=function(e){var t=this;if(!e)throw new Error("Cannot configure a schema with no rules");if("object"!==typeof e||Array.isArray(e))throw new Error("Rules must be an object");this.rules={},Object.keys(e).forEach(function(l){var n=e[l];t.rules[l]=Array.isArray(n)?n:[n]})},t.messages=function(e){return e&&(this._messages=q(Me(),e)),this._messages},t.validate=function(t,l,n){var a=this;void 0===l&&(l={}),void 0===n&&(n=function(){});var o=t,c=l,r=n;if("function"===typeof c&&(r=c,c={}),!this.rules||0===Object.keys(this.rules).length)return r&&r(null,o),Promise.resolve(o);function s(e){var t=[],l={};function n(e){var l;Array.isArray(e)?t=(l=t).concat.apply(l,e):t.push(e)}for(var a=0;a");const r=(0,C.DU)("form"),s=(0,a.KR)(),i=(0,a.KR)(0),u=()=>{var e;if(null==(e=s.value)?void 0:e.firstElementChild){const e=window.getComputedStyle(s.value.firstElementChild).width;return Math.ceil(Number.parseFloat(e))}return 0},d=(a="update")=>{(0,n.dY)(()=>{t.default&&e.isAutoWidth&&("update"===a?i.value=u():"remove"===a&&(null==l||l.deregisterLabelWidth(i.value)))})},f=()=>d("update");return(0,n.sV)(()=>{f()}),(0,n.xo)(()=>{d("remove")}),(0,n.$u)(()=>f()),(0,n.wB)(i,(t,n)=>{e.updateAll&&(null==l||l.registerLabelWidth(t,n))}),(0,Oe.wYm)((0,n.EW)(()=>{var e,t;return null!=(t=null==(e=s.value)?void 0:e.firstElementChild)?t:null}),f),()=>{var a,c;if(!t)return null;const{isAutoWidth:u}=e;if(u){const e=null==l?void 0:l.autoLabelWidth,c=null==o?void 0:o.hasLabel,u={};if(c&&e&&"auto"!==e){const t=Math.max(0,Number.parseInt(e,10)-i.value),n=o.labelPosition||l.labelPosition,a="left"===n?"marginRight":"marginLeft";t&&(u[a]=`${t}px`)}return(0,n.bF)("div",{ref:s,class:[r.be("item","label-wrap")],style:u},[null==(a=t.default)?void 0:a.call(t)])}return(0,n.bF)(n.FK,{ref:s},[null==(c=t.default)?void 0:c.call(t)])}}}),Ie=l(1305),De=l(4340),Fe=l(3558);const Ve=(0,n.pM)({name:"ElFormItem"}),Pe=(0,n.pM)({...Ve,props:Te,setup(e,{expose:t}){const l=e,r=(0,n.Ht)(),s=(0,n.WQ)(c.F,void 0),u=(0,n.WQ)(c.w,void 0),d=(0,y.NV)(void 0,{formItem:!1}),f=(0,C.DU)("form-item"),m=(0,Ie.Bi)().value,v=(0,a.KR)([]),h=(0,a.KR)(""),g=(0,Ne.V7)(h,100),b=(0,a.KR)(""),w=(0,a.KR)();let L,x=!1;const M=(0,n.EW)(()=>l.labelPosition||(null==s?void 0:s.labelPosition)),R=(0,n.EW)(()=>{var e;if("top"===M.value)return{};const t=(0,Fe._V)(null!=(e=l.labelWidth)?e:null==s?void 0:s.labelWidth);return{width:t}}),k=(0,n.EW)(()=>{var e;if("top"===M.value||(null==s?void 0:s.inline))return{};if(!l.label&&!l.labelWidth&&W)return{};const t=(0,Fe._V)(null!=(e=l.labelWidth)?e:null==s?void 0:s.labelWidth);return l.label||r.label?{}:{marginLeft:t}}),S=(0,n.EW)(()=>[f.b(),f.m(d.value),f.is("error","error"===h.value),f.is("validating","validating"===h.value),f.is("success","success"===h.value),f.is("required",V.value||l.required),f.is("no-asterisk",null==s?void 0:s.hideRequiredAsterisk),"right"===(null==s?void 0:s.requireAsteriskPosition)?"asterisk-right":"asterisk-left",{[f.m("feedback")]:null==s?void 0:s.statusIcon,[f.m(`label-${M.value}`)]:M.value}]),E=(0,n.EW)(()=>(0,i.Lm)(l.inlineMessage)?l.inlineMessage:(null==s?void 0:s.inlineMessage)||!1),A=(0,n.EW)(()=>[f.e("error"),{[f.em("error","inline")]:E.value}]),N=(0,n.EW)(()=>l.prop?(0,o.cy)(l.prop)?l.prop.join("."):l.prop:""),_=(0,n.EW)(()=>!(!l.label&&!r.label)),T=(0,n.EW)(()=>{var e;return null!=(e=l.for)?e:1===v.value.length?v.value[0]:void 0}),O=(0,n.EW)(()=>!T.value&&_.value),W=!!u,B=(0,n.EW)(()=>{const e=null==s?void 0:s.model;if(e&&l.prop)return(0,De.GT)(e,l.prop).value}),I=(0,n.EW)(()=>{const{required:e}=l,t=[];l.rules&&t.push(...(0,p.A)(l.rules));const n=null==s?void 0:s.rules;if(n&&l.prop){const e=(0,De.GT)(n,l.prop).value;e&&t.push(...(0,p.A)(e))}if(void 0!==e){const l=t.map((e,t)=>[e,t]).filter(([e])=>"required"in e);if(l.length>0)for(const[n,a]of l)n.required!==e&&(t[a]={...n,required:e});else t.push({required:e})}return t}),D=(0,n.EW)(()=>I.value.length>0),F=e=>{const t=I.value;return t.filter(t=>!t.trigger||!e||((0,o.cy)(t.trigger)?t.trigger.includes(e):t.trigger===e)).map(({trigger:e,...t})=>t)},V=(0,n.EW)(()=>I.value.some(e=>e.required)),P=(0,n.EW)(()=>{var e;return"error"===g.value&&l.showMessage&&(null==(e=null==s?void 0:s.showMessage)||e)}),$=(0,n.EW)(()=>`${l.label||""}${(null==s?void 0:s.labelSuffix)||""}`),H=e=>{h.value=e},j=e=>{var t,n;const{errors:a,fields:o}=e;a&&o||console.error(e),H("error"),b.value=a?null!=(n=null==(t=null==a?void 0:a[0])?void 0:t.message)?n:`${l.prop} is required`:"",null==s||s.emit("validate",l.prop,!1,b.value)},K=()=>{H("success"),null==s||s.emit("validate",l.prop,!0,"")},X=async e=>{const t=N.value,l=new Re({[t]:e});return l.validate({[t]:B.value},{firstFields:!0}).then(()=>(K(),!0)).catch(e=>(j(e),Promise.reject(e)))},U=async(e,t)=>{if(x||!l.prop)return!1;const n=(0,o.Tn)(t);if(!D.value)return null==t||t(!1),!1;const a=F(e);return 0===a.length?(null==t||t(!0),!0):(H("validating"),X(a).then(()=>(null==t||t(!0),!0)).catch(e=>{const{fields:l}=e;return null==t||t(!1,l),!n&&Promise.reject(l)}))},q=()=>{H(""),b.value="",x=!1},G=async()=>{const e=null==s?void 0:s.model;if(!e||!l.prop)return;const t=(0,De.GT)(e,l.prop);x=!0,t.value=Ae(L),await(0,n.dY)(),q(),x=!1},Y=e=>{v.value.includes(e)||v.value.push(e)},Q=e=>{v.value=v.value.filter(t=>t!==e)};(0,n.wB)(()=>l.error,e=>{b.value=e||"",H(e?"error":"")},{immediate:!0}),(0,n.wB)(()=>l.validateStatus,e=>H(e||""));const Z=(0,a.Kh)({...(0,a.QW)(l),$el:w,size:d,validateMessage:b,validateState:h,labelId:m,inputIds:v,isGroup:O,hasLabel:_,fieldValue:B,addInputId:Y,removeInputId:Q,resetField:G,clearValidate:q,validate:U,propString:N});return(0,n.Gt)(c.w,Z),(0,n.sV)(()=>{l.prop&&(null==s||s.addField(Z),L=Ae(B.value))}),(0,n.xo)(()=>{null==s||s.removeField(Z)}),t({size:d,validateMessage:b,validateState:h,validate:U,clearValidate:q,resetField:G}),(e,t)=>{var l;return(0,n.uX)(),(0,n.CE)("div",{ref_key:"formItemRef",ref:w,class:(0,o.C4)((0,a.R1)(S)),role:(0,a.R1)(O)?"group":void 0,"aria-labelledby":(0,a.R1)(O)?(0,a.R1)(m):void 0},[(0,n.bF)((0,a.R1)(Be),{"is-auto-width":"auto"===(0,a.R1)(R).width,"update-all":"auto"===(null==(l=(0,a.R1)(s))?void 0:l.labelWidth)},{default:(0,n.k6)(()=>[e.label||e.$slots.label?((0,n.uX)(),(0,n.Wv)((0,n.$y)((0,a.R1)(T)?"label":"div"),{key:0,id:(0,a.R1)(m),for:(0,a.R1)(T),class:(0,o.C4)((0,a.R1)(f).e("label")),style:(0,o.Tr)((0,a.R1)(R))},{default:(0,n.k6)(()=>[(0,n.RG)(e.$slots,"label",{label:(0,a.R1)($)},()=>[(0,n.eW)((0,o.v_)((0,a.R1)($)),1)])]),_:3},8,["id","for","class","style"])):(0,n.Q3)("v-if",!0)]),_:3},8,["is-auto-width","update-all"]),(0,n.Lk)("div",{class:(0,o.C4)((0,a.R1)(f).e("content")),style:(0,o.Tr)((0,a.R1)(k))},[(0,n.RG)(e.$slots,"default"),(0,n.bF)(z.F,{name:`${(0,a.R1)(f).namespace.value}-zoom-in-top`},{default:(0,n.k6)(()=>[(0,a.R1)(P)?(0,n.RG)(e.$slots,"error",{key:0,error:b.value},()=>[(0,n.Lk)("div",{class:(0,o.C4)((0,a.R1)(A))},(0,o.v_)(b.value),3)]):(0,n.Q3)("v-if",!0)]),_:3},8,["name"])],6)],10,["role","aria-labelledby"])}}});var $e=(0,b.A)(Pe,[["__file","form-item.vue"]]),He=l(5376);const je=(0,He.GU)(M,{FormItem:$e}),Ke=(0,He.WM)($e)},2056:function(e,t,l){"use strict";l.d(t,{YU:function(){return a},l4:function(){return n},qs:function(){return o}});const n="update:modelValue",a="change",o="input"},2086:function(e,t,l){"use strict";l.d(t,{dW:function(){return we},c6:function(){return Le},Iy:function(){return xe}});var n=l(6768),a=l(144),o=l(4232),c=l(47),r=l(8507),s=l(8559),i=l(813),u=(l(8111),l(2489),l(116),l(1701),l(7687)),d=l(9077);const f=(0,n.pM)({inheritAttrs:!1});function p(e,t,l,a,o,c){return(0,n.RG)(e.$slots,"default")}var m=(0,d.A)(f,[["render",p],["__file","collection.vue"]]);const v=(0,n.pM)({name:"ElCollectionItem",inheritAttrs:!1});function h(e,t,l,a,o,c){return(0,n.RG)(e.$slots,"default")}var g=(0,d.A)(v,[["render",h],["__file","collection-item.vue"]]);const b="data-el-collection-item",y=e=>{const t=`El${e}Collection`,l=`${t}Item`,o=Symbol(t),c=Symbol(l),r={...m,name:t,setup(){const e=(0,a.KR)(),t=new Map,l=()=>{const l=(0,a.R1)(e);if(!l)return[];const n=Array.from(l.querySelectorAll(`[${b}]`)),o=[...t.values()];return o.sort((e,t)=>n.indexOf(e.ref)-n.indexOf(t.ref))};(0,n.Gt)(o,{itemMap:t,getItems:l,collectionRef:e})}},s={...g,name:l,setup(e,{attrs:t}){const l=(0,a.KR)(),r=(0,n.WQ)(o,void 0);(0,n.Gt)(c,{collectionItemRef:l}),(0,n.sV)(()=>{const e=(0,a.R1)(l);e&&r.itemMap.set(e,{ref:e,...t})}),(0,n.xo)(()=>{const e=(0,a.R1)(l);r.itemMap.delete(e)})}};return{COLLECTION_INJECTION_KEY:o,COLLECTION_ITEM_INJECTION_KEY:c,ElCollection:r,ElCollectionItem:s}};var C=l(7378);const w=(0,C.b_)({style:{type:(0,C.jq)([String,Array,Object])},currentTabId:{type:(0,C.jq)(String)},defaultCurrentTabId:String,loop:Boolean,dir:{type:String,values:["ltr","rtl"],default:"ltr"},orientation:{type:(0,C.jq)(String)},onBlur:Function,onFocus:Function,onMousedown:Function}),{ElCollection:L,ElCollectionItem:x,COLLECTION_INJECTION_KEY:M,COLLECTION_ITEM_INJECTION_KEY:z}=y("RovingFocusGroup"),R=Symbol("elRovingFocusGroup"),k=Symbol("elRovingFocusGroupItem");var S=l(4225),E=l(515);const A={ArrowLeft:"prev",ArrowUp:"prev",ArrowRight:"next",ArrowDown:"next",PageUp:"first",Home:"first",PageDown:"last",End:"last"},N=(e,t)=>{if("rtl"!==t)return e;switch(e){case E.R.right:return E.R.left;case E.R.left:return E.R.right;default:return e}},_=(e,t,l)=>{const n=(0,S.CG)(e),a=N(n,l);if(("vertical"!==t||![E.R.left,E.R.right].includes(a))&&("horizontal"!==t||![E.R.up,E.R.down].includes(a)))return A[a]},T=(e,t)=>e.map((l,n)=>e[(n+t)%e.length]),O=e=>{const{activeElement:t}=document;for(const l of e){if(l===t)return;if(l.focus(),t!==document.activeElement)return}},W="currentTabIdChange",B="rovingFocusGroup.entryFocus",I={bubbles:!1,cancelable:!0},D=(0,n.pM)({name:"ElRovingFocusGroupImpl",inheritAttrs:!1,props:w,emits:[W,"entryFocus"],setup(e,{emit:t}){var l;const o=(0,a.KR)(null!=(l=e.currentTabId||e.defaultCurrentTabId)?l:null),c=(0,a.KR)(!1),r=(0,a.KR)(!1),s=(0,a.KR)(),{getItems:i}=(0,n.WQ)(M,void 0),d=(0,n.EW)(()=>[{outline:"none"},e.style]),f=e=>{t(W,e)},p=()=>{c.value=!0},m=(0,S.mK)(t=>{var l;null==(l=e.onMousedown)||l.call(e,t)},()=>{r.value=!0}),v=(0,S.mK)(t=>{var l;null==(l=e.onFocus)||l.call(e,t)},e=>{const t=!(0,a.R1)(r),{target:l,currentTarget:n}=e;if(l===n&&t&&!(0,a.R1)(c)){const e=new Event(B,I);if(null==n||n.dispatchEvent(e),!e.defaultPrevented){const e=i().filter(e=>e.focusable),t=e.find(e=>e.active),l=e.find(e=>e.id===(0,a.R1)(o)),n=[t,l,...e].filter(Boolean),c=n.map(e=>e.ref);O(c)}}r.value=!1}),h=(0,S.mK)(t=>{var l;null==(l=e.onBlur)||l.call(e,t)},()=>{c.value=!1}),g=(...e)=>{t("entryFocus",...e)},b=t=>{const l=_(t);if(l){t.preventDefault();const a=i().filter(e=>e.focusable);let o=a.map(e=>e.ref);switch(l){case"last":o.reverse();break;case"prev":case"next":{"prev"===l&&o.reverse();const n=o.indexOf(t.currentTarget);o=e.loop?T(o,n+1):o.slice(n+1);break}}(0,n.dY)(()=>{O(o)})}};(0,n.Gt)(R,{currentTabbedId:(0,a.tB)(o),loop:(0,a.lW)(e,"loop"),tabIndex:(0,n.EW)(()=>(0,a.R1)(c)?-1:0),rovingFocusGroupRef:s,rovingFocusGroupRootStyle:d,orientation:(0,a.lW)(e,"orientation"),dir:(0,a.lW)(e,"dir"),onItemFocus:f,onItemShiftTab:p,onBlur:h,onFocus:v,onMousedown:m,onKeydown:b}),(0,n.wB)(()=>e.currentTabId,e=>{o.value=null!=e?e:null}),(0,u.MLh)(s,B,g)}});function F(e,t,l,a,o,c){return(0,n.RG)(e.$slots,"default")}var V=(0,d.A)(D,[["render",F],["__file","roving-focus-group-impl.vue"]]);const P=(0,n.pM)({name:"ElRovingFocusGroup",components:{ElFocusGroupCollection:L,ElRovingFocusGroupImpl:V}});function $(e,t,l,a,c,r){const s=(0,n.g2)("el-roving-focus-group-impl"),i=(0,n.g2)("el-focus-group-collection");return(0,n.uX)(),(0,n.Wv)(i,null,{default:(0,n.k6)(()=>[(0,n.bF)(s,(0,o._B)((0,n.Ng)(e.$attrs)),{default:(0,n.k6)(()=>[(0,n.RG)(e.$slots,"default")]),_:3},16)]),_:3})}var H=(0,d.A)(P,[["render",$],["__file","roving-focus-group.vue"]]),j=l(7477),K=l(3219);const X=Symbol("elDropdown"),U="elDropdown";var q=l(3158),G=l(3513),Y=l(6268),Q=l(3558),Z=l(5951),J=l(1305),ee=l(2436);const{ButtonGroup:te}=c.S2,le=(0,n.pM)({name:"ElDropdown",components:{ElButton:c.S2,ElButtonGroup:te,ElScrollbar:s.kA,ElTooltip:r.R7,ElRovingFocusGroup:H,ElOnlyChild:q.D,ElIcon:i.tk,ArrowDown:j.ArrowDown},props:K.Qy,emits:["visible-change","click","command"],setup(e,{emit:t}){const l=(0,n.nI)(),o=(0,G.DU)("dropdown"),{t:c}=(0,Y.Ym)(),r=(0,a.KR)(),s=(0,a.KR)(),i=(0,a.KR)(),u=(0,a.KR)(),d=(0,a.KR)(null),f=(0,a.KR)(null),p=(0,a.KR)(!1),m=(0,n.EW)(()=>({maxHeight:(0,Q._V)(e.maxHeight)})),v=(0,n.EW)(()=>[o.m(L.value)]),h=(0,n.EW)(()=>(0,Z.A)(e.trigger)),g=(0,J.Bi)().value,b=(0,n.EW)(()=>e.id||g);function y(){var e;null==(e=i.value)||e.onClose(void 0,0)}function C(){var e;null==(e=i.value)||e.onClose()}function w(){var e;null==(e=i.value)||e.onOpen()}const L=(0,ee.NV)();function x(...e){t("command",...e)}function M(){}function z(){const e=(0,a.R1)(u);h.value.includes("hover")&&(null==e||e.focus({preventScroll:!0})),f.value=null}function R(e){f.value=e}function k(){t("visible-change",!0)}function S(e){var t;p.value="keydown"===(null==e?void 0:e.type),null==(t=u.value)||t.focus()}function E(){t("visible-change",!1)}(0,n.Gt)(X,{contentRef:u,role:(0,n.EW)(()=>e.role),triggerId:b,isUsingKeyboard:p,onItemEnter:M,onItemLeave:z,handleClose:C}),(0,n.Gt)(U,{instance:l,dropdownSize:L,handleClick:y,commandHandler:x,trigger:(0,a.lW)(e,"trigger"),hideOnClick:(0,a.lW)(e,"hideOnClick")});const A=e=>{t("click",e)};return{t:c,ns:o,scrollbar:d,wrapStyle:m,dropdownTriggerKls:v,dropdownSize:L,triggerId:b,currentTabId:f,handleCurrentTabIdChange:R,handlerMainButtonClick:A,handleClose:C,handleOpen:w,handleBeforeShowTooltip:k,handleShowTooltip:S,handleBeforeHideTooltip:E,popperRef:i,contentRef:u,triggeringElementRef:r,referenceElementRef:s}}});function ne(e,t,l,a,c,r){var s;const i=(0,n.g2)("el-roving-focus-group"),u=(0,n.g2)("el-scrollbar"),d=(0,n.g2)("el-only-child"),f=(0,n.g2)("el-tooltip"),p=(0,n.g2)("el-button"),m=(0,n.g2)("arrow-down"),v=(0,n.g2)("el-icon"),h=(0,n.g2)("el-button-group");return(0,n.uX)(),(0,n.CE)("div",{class:(0,o.C4)([e.ns.b(),e.ns.is("disabled",e.disabled)])},[(0,n.bF)(f,{ref:"popperRef",role:e.role,effect:e.effect,"fallback-placements":["bottom","top"],"popper-options":e.popperOptions,"gpu-acceleration":!1,placement:e.placement,"popper-class":[e.ns.e("popper"),e.popperClass],"popper-style":e.popperStyle,trigger:e.trigger,"trigger-keys":e.triggerKeys,"trigger-target-el":e.contentRef,"show-arrow":e.showArrow,"show-after":"hover"===e.trigger?e.showTimeout:0,"hide-after":"hover"===e.trigger?e.hideTimeout:0,"virtual-ref":null!=(s=e.virtualRef)?s:e.triggeringElementRef,"virtual-triggering":e.virtualTriggering||e.splitButton,disabled:e.disabled,transition:`${e.ns.namespace.value}-zoom-in-top`,teleported:e.teleported,pure:"","focus-on-target":"",persistent:e.persistent,onBeforeShow:e.handleBeforeShowTooltip,onShow:e.handleShowTooltip,onBeforeHide:e.handleBeforeHideTooltip},(0,n.eX)({content:(0,n.k6)(()=>[(0,n.bF)(u,{ref:"scrollbar","wrap-style":e.wrapStyle,tag:"div","view-class":e.ns.e("list")},{default:(0,n.k6)(()=>[(0,n.bF)(i,{loop:e.loop,"current-tab-id":e.currentTabId,orientation:"horizontal",onCurrentTabIdChange:e.handleCurrentTabIdChange},{default:(0,n.k6)(()=>[(0,n.RG)(e.$slots,"dropdown")]),_:3},8,["loop","current-tab-id","onCurrentTabIdChange"])]),_:3},8,["wrap-style","view-class"])]),_:2},[e.splitButton?void 0:{name:"default",fn:(0,n.k6)(()=>[(0,n.bF)(d,{id:e.triggerId,ref:"triggeringElementRef",role:"button",tabindex:e.tabindex},{default:(0,n.k6)(()=>[(0,n.RG)(e.$slots,"default")]),_:3},8,["id","tabindex"])])}]),1032,["role","effect","popper-options","placement","popper-class","popper-style","trigger","trigger-keys","trigger-target-el","show-arrow","show-after","hide-after","virtual-ref","virtual-triggering","disabled","transition","teleported","persistent","onBeforeShow","onShow","onBeforeHide"]),e.splitButton?((0,n.uX)(),(0,n.Wv)(h,{key:0},{default:(0,n.k6)(()=>[(0,n.bF)(p,(0,n.v6)({ref:"referenceElementRef"},e.buttonProps,{size:e.dropdownSize,type:e.type,disabled:e.disabled,tabindex:e.tabindex,onClick:e.handlerMainButtonClick}),{default:(0,n.k6)(()=>[(0,n.RG)(e.$slots,"default")]),_:3},16,["size","type","disabled","tabindex","onClick"]),(0,n.bF)(p,(0,n.v6)({id:e.triggerId,ref:"triggeringElementRef"},e.buttonProps,{role:"button",size:e.dropdownSize,type:e.type,class:e.ns.e("caret-button"),disabled:e.disabled,tabindex:e.tabindex,"aria-label":e.t("el.dropdown.toggleDropdown")}),{default:(0,n.k6)(()=>[(0,n.bF)(v,{class:(0,o.C4)(e.ns.e("icon"))},{default:(0,n.k6)(()=>[(0,n.bF)(m)]),_:1},8,["class"])]),_:1},16,["id","size","type","class","disabled","tabindex","aria-label"])]),_:3})):(0,n.Q3)("v-if",!0)],2)}var ae=(0,d.A)(le,[["render",ne],["__file","dropdown.vue"]]);const oe=(0,n.pM)({components:{ElRovingFocusCollectionItem:x},props:{focusable:{type:Boolean,default:!0},active:Boolean},emits:["mousedown","focus","keydown"],setup(e,{emit:t}){const{currentTabbedId:l,onItemFocus:o,onItemShiftTab:c,onKeydown:r}=(0,n.WQ)(R,void 0),s=(0,J.Bi)(),i=(0,a.KR)(),u=(0,S.mK)(e=>{t("mousedown",e)},t=>{e.focusable?o((0,a.R1)(s)):t.preventDefault()}),d=(0,S.mK)(e=>{t("focus",e)},()=>{o((0,a.R1)(s))}),f=(0,S.mK)(e=>{t("keydown",e)},e=>{const{shiftKey:t,target:l,currentTarget:n}=e,a=(0,S.CG)(e);a===E.R.tab&&t?c():l===n&&r(e)}),p=(0,n.EW)(()=>l.value===(0,a.R1)(s));return(0,n.Gt)(k,{rovingFocusGroupItemRef:i,tabIndex:(0,n.EW)(()=>(0,a.R1)(p)?0:-1),handleMousedown:u,handleFocus:d,handleKeydown:f}),{id:s,handleKeydown:f,handleFocus:d,handleMousedown:u}}});function ce(e,t,l,a,o,c){const r=(0,n.g2)("el-roving-focus-collection-item");return(0,n.uX)(),(0,n.Wv)(r,{id:e.id,focusable:e.focusable,active:e.active},{default:(0,n.k6)(()=>[(0,n.RG)(e.$slots,"default")]),_:3},8,["id","focusable","active"])}var re=(0,d.A)(oe,[["render",ce],["__file","roving-focus-item.vue"]]),se=l(5130),ie=l(4425);const ue=(0,n.pM)({name:"DropdownItemImpl",components:{ElIcon:i.tk},props:K.dv,emits:["pointermove","pointerleave","click","clickimpl"],setup(e,{emit:t}){const l=(0,G.DU)("dropdown"),{role:a}=(0,n.WQ)(X,void 0),{collectionItemRef:o}=(0,n.WQ)(z,void 0),{rovingFocusGroupItemRef:c,tabIndex:r,handleFocus:s,handleKeydown:i,handleMousedown:u}=(0,n.WQ)(k,void 0),d=(0,ie.t)(o,c),f=(0,n.EW)(()=>"menu"===a.value?"menuitem":"navigation"===a.value?"link":"button"),p=(0,S.mK)(e=>{const l=(0,S.CG)(e);if([E.R.enter,E.R.numpadEnter,E.R.space].includes(l))return e.preventDefault(),e.stopImmediatePropagation(),t("clickimpl",e),!0},i);return{ns:l,itemRef:d,dataset:{[b]:""},role:f,tabIndex:r,handleFocus:s,handleKeydown:p,handleMousedown:u}}});function de(e,t,l,a,c,r){const s=(0,n.g2)("el-icon");return(0,n.uX)(),(0,n.CE)(n.FK,null,[e.divided?((0,n.uX)(),(0,n.CE)("li",{key:0,role:"separator",class:(0,o.C4)(e.ns.bem("menu","item","divided"))},null,2)):(0,n.Q3)("v-if",!0),(0,n.Lk)("li",(0,n.v6)({ref:e.itemRef},{...e.dataset,...e.$attrs},{"aria-disabled":e.disabled,class:[e.ns.be("menu","item"),e.ns.is("disabled",e.disabled)],tabindex:e.tabIndex,role:e.role,onClick:t=>e.$emit("clickimpl",t),onFocus:e.handleFocus,onKeydown:(0,se.D$)(e.handleKeydown,["self"]),onMousedown:e.handleMousedown,onPointermove:t=>e.$emit("pointermove",t),onPointerleave:t=>e.$emit("pointerleave",t)}),[e.icon?((0,n.uX)(),(0,n.Wv)(s,{key:0},{default:(0,n.k6)(()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)(e.icon)))]),_:1})):(0,n.Q3)("v-if",!0),(0,n.RG)(e.$slots,"default")],16,["aria-disabled","tabindex","role","onClick","onFocus","onKeydown","onMousedown","onPointermove","onPointerleave"])],64)}var fe=(0,d.A)(ue,[["render",de],["__file","dropdown-item-impl.vue"]]);const pe=()=>{const e=(0,n.WQ)(U,{}),t=(0,n.EW)(()=>null==e?void 0:e.dropdownSize);return{elDropdown:e,_elDropdownSize:t}},me=(0,n.pM)({name:"ElDropdownItem",components:{ElRovingFocusItem:re,ElDropdownItemImpl:fe},inheritAttrs:!1,props:K.dv,emits:["pointermove","pointerleave","click"],setup(e,{emit:t,attrs:l}){const{elDropdown:a}=pe(),o=(0,n.nI)(),{onItemEnter:c,onItemLeave:r}=(0,n.WQ)(X,void 0),s=(0,S.mK)(e=>(t("pointermove",e),e.defaultPrevented),(0,S.Iv)(t=>{if(e.disabled)return void r(t);const l=t.currentTarget;l===document.activeElement||l.contains(document.activeElement)||(c(t),t.defaultPrevented||null==l||l.focus({preventScroll:!0}))})),i=(0,S.mK)(e=>(t("pointerleave",e),e.defaultPrevented),(0,S.Iv)(r)),u=(0,S.mK)(l=>{if(!e.disabled)return t("click",l),"keydown"!==l.type&&l.defaultPrevented},t=>{var l,n,c;e.disabled?t.stopImmediatePropagation():((null==(l=null==a?void 0:a.hideOnClick)?void 0:l.value)&&(null==(n=a.handleClick)||n.call(a)),null==(c=a.commandHandler)||c.call(a,e.command,o,t))}),d=(0,n.EW)(()=>({...e,...l}));return{handleClick:u,handlePointerMove:s,handlePointerLeave:i,propsAndAttrs:d}}});function ve(e,t,l,a,o,c){const r=(0,n.g2)("el-dropdown-item-impl"),s=(0,n.g2)("el-roving-focus-item");return(0,n.uX)(),(0,n.Wv)(s,{focusable:!e.disabled},{default:(0,n.k6)(()=>[(0,n.bF)(r,(0,n.v6)(e.propsAndAttrs,{onPointerleave:e.handlePointerLeave,onPointermove:e.handlePointerMove,onClickimpl:e.handleClick}),{default:(0,n.k6)(()=>[(0,n.RG)(e.$slots,"default")]),_:3},16,["onPointerleave","onPointermove","onClickimpl"])]),_:3},8,["focusable"])}var he=(0,d.A)(me,[["render",ve],["__file","dropdown-item.vue"]]);const ge=(0,n.pM)({name:"ElDropdownMenu",props:K.hR,setup(e){const t=(0,G.DU)("dropdown"),{_elDropdownSize:l}=pe(),a=l.value,{contentRef:o,role:c,triggerId:r,isUsingKeyboard:s,handleClose:i}=(0,n.WQ)(X,void 0),{rovingFocusGroupRef:u,rovingFocusGroupRootStyle:d,onBlur:f,onFocus:p,onKeydown:m,onMousedown:v}=(0,n.WQ)(R,void 0),{collectionRef:h}=(0,n.WQ)(M,void 0),g=(0,n.EW)(()=>[t.b("menu"),t.bm("menu",null==a?void 0:a.value)]),b=(0,ie.t)(o,u,h),y=(0,S.mK)(t=>{var l;null==(l=e.onKeydown)||l.call(e,t)},e=>{const{currentTarget:t,target:l}=e,n=(0,S.CG)(e);if(t.contains(l),E.R.tab===n)return i();m(e)});function C(e){s.value&&p(e)}return{size:a,rovingFocusGroupRootStyle:d,dropdownKls:g,role:c,triggerId:r,dropdownListWrapperRef:b,handleKeydown:y,onBlur:f,handleFocus:C,onMousedown:v}}});function be(e,t,l,a,c,r){return(0,n.uX)(),(0,n.CE)("ul",{ref:e.dropdownListWrapperRef,class:(0,o.C4)(e.dropdownKls),style:(0,o.Tr)(e.rovingFocusGroupRootStyle),tabindex:-1,role:e.role,"aria-labelledby":e.triggerId,onFocusin:e.handleFocus,onFocusout:e.onBlur,onKeydown:(0,se.D$)(e.handleKeydown,["self"]),onMousedown:(0,se.D$)(e.onMousedown,["self"])},[(0,n.RG)(e.$slots,"default")],46,["role","aria-labelledby","onFocusin","onFocusout","onKeydown","onMousedown"])}var ye=(0,d.A)(ge,[["render",be],["__file","dropdown-menu.vue"]]),Ce=l(5376);const we=(0,Ce.GU)(ae,{DropdownItem:he,DropdownMenu:ye}),Le=(0,Ce.WM)(he),xe=(0,Ce.WM)(ye)},2106:function(e,t,l){"use strict";var n=l(283),a=l(4913);e.exports=function(e,t,l){return l.get&&n(l.get,t,{getter:!0}),l.set&&n(l.set,t,{setter:!0}),a.f(e,t,l)}},2132:function(e,t,l){"use strict";var n=l(1821),a=l(9092),o=l(1801),c=l(6054),r=Object.getOwnPropertySymbols,s=r?function(e){var t=[];while(e)(0,n.A)(t,(0,o.A)(e)),e=(0,a.A)(e);return t}:c.A;t.A=s},2140:function(e,t,l){"use strict";var n=l(8227),a=n("toStringTag"),o={};o[a]="z",e.exports="[object z]"===String(o)},2142:function(e,t,l){"use strict";l.d(t,{A:function(){return s}});l(4114),l(8111),l(3579);var n=l(17),a=l(4232),o=l(2235);const c=new Map;if(n.oc){let e;document.addEventListener("mousedown",t=>e=t),document.addEventListener("mouseup",t=>{if(e){for(const l of c.values())for(const{documentHandler:n}of l)n(t,e);e=void 0}})}function r(e,t){let l=[];return(0,a.cy)(t.arg)?l=t.arg:(0,o.vq)(t.arg)&&l.push(t.arg),function(n,a){const o=t.instance.popperRef,c=n.target,r=null==a?void 0:a.target,s=!t||!t.instance,i=!c||!r,u=e.contains(c)||e.contains(r),d=e===c,f=l.length&&l.some(e=>null==e?void 0:e.contains(c))||l.length&&l.includes(r),p=o&&(o.contains(c)||o.contains(r));s||i||u||d||f||p||t.value(n,a)}}const s={beforeMount(e,t){c.has(e)||c.set(e,[]),c.get(e).push({documentHandler:r(e,t),bindingFn:t.value})},updated(e,t){c.has(e)||c.set(e,[]);const l=c.get(e),n=l.findIndex(e=>e.bindingFn===t.oldValue),a={documentHandler:r(e,t),bindingFn:t.value};n>=0?l.splice(n,1,a):l.push(a)},unmounted(e){c.delete(e)}}},2195:function(e,t,l){"use strict";var n=l(9504),a=n({}.toString),o=n("".slice);e.exports=function(e){return o(a(e),8,-1)}},2211:function(e,t,l){"use strict";var n=l(9039);e.exports=!n(function(){function e(){}return e.prototype.constructor=null,Object.getPrototypeOf(new e)!==e.prototype})},2235:function(e,t,l){"use strict";l.d(t,{Et:function(){return r},Hp:function(){return d},Im:function(){return s},Lm:function(){return c},Xj:function(){return u},b0:function(){return o},l6:function(){return f},vq:function(){return i}});var n=l(4232),a=l(6032);const o=e=>void 0===e,c=e=>"boolean"===typeof e,r=e=>"number"===typeof e,s=e=>!e&&0!==e||(0,n.cy)(e)&&0===e.length||(0,n.Gv)(e)&&!Object.keys(e).length,i=e=>"undefined"!==typeof Element&&e instanceof Element,u=e=>(0,a.A)(e),d=e=>!!(0,n.Kg)(e)&&!Number.isNaN(Number(e)),f=e=>e===window},2251:function(e,t,l){"use strict";l.d(t,{E:function(){return s}});var n=l(5420),a=l(8782),o=l(8299),c=l(7378),r=l(8501);const s=(0,c.b_)({...n.m,...a.yh,appendTo:{type:o.k.to.type},content:{type:String,default:""},rawContent:Boolean,persistent:Boolean,visible:{type:(0,c.jq)(Boolean),default:null},transition:String,teleported:{type:Boolean,default:!0},disabled:Boolean,...(0,r.l)(["ariaLabel"])})},2261:function(e,t,l){"use strict";l.d(t,{ZH:function(){return o},qr:function(){return a}});var n=l(4232);const a=(e="")=>e.replace(/[|\\{}()[\]^$+*?.]/g,"\\$&").replace(/-/g,"\\x2d"),o=e=>(0,n.ZH)(e)},2303:function(e,t,l){"use strict";var n=l(4576),a=l(9504),o=n.Uint8Array,c=n.SyntaxError,r=n.parseInt,s=Math.min,i=/[^\da-f]/i,u=a(i.exec),d=a("".slice);e.exports=function(e,t){var l=e.length;if(l%2!==0)throw new c("String should be an even number of characters");var n=t?s(t.length,l/2):l/2,a=t||new o(n),f=0,p=0;while(p0&&l(s)?t>1?u(s,t-1,l,a,o):(0,n.A)(o,s):a||(o[o.length]=s)}return o}var d=u},2317:function(e,t,l){l(8111),l(1701),function(t,l){e.exports=l()}(0,function(){"use strict";return function(e,t,l){var n=t.prototype,a=function(e){return e&&(e.indexOf?e:e.s)},o=function(e,t,l,n,o){var c=e.name?e:e.$locale(),r=a(c[t]),s=a(c[l]),i=r||s.map(function(e){return e.slice(0,n)});if(!o)return i;var u=c.weekStart;return i.map(function(e,t){return i[(t+(u||0))%7]})},c=function(){return l.Ls[l.locale()]},r=function(e,t){return e.formats[t]||function(e){return e.replace(/(\[[^\]]+])|(MMMM|MM|DD|dddd)/g,function(e,t,l){return t||l.slice(1)})}(e.formats[t.toUpperCase()])},s=function(){var e=this;return{months:function(t){return t?t.format("MMMM"):o(e,"months")},monthsShort:function(t){return t?t.format("MMM"):o(e,"monthsShort","months",3)},firstDayOfWeek:function(){return e.$locale().weekStart||0},weekdays:function(t){return t?t.format("dddd"):o(e,"weekdays")},weekdaysMin:function(t){return t?t.format("dd"):o(e,"weekdaysMin","weekdays",2)},weekdaysShort:function(t){return t?t.format("ddd"):o(e,"weekdaysShort","weekdays",3)},longDateFormat:function(t){return r(e.$locale(),t)},meridiem:this.$locale().meridiem,ordinal:this.$locale().ordinal}};n.localeData=function(){return s.bind(this)()},l.localeData=function(){var e=c();return{firstDayOfWeek:function(){return e.weekStart||0},weekdays:function(){return l.weekdays()},weekdaysShort:function(){return l.weekdaysShort()},weekdaysMin:function(){return l.weekdaysMin()},months:function(){return l.months()},monthsShort:function(){return l.monthsShort()},longDateFormat:function(t){return r(e,t)},meridiem:e.meridiem,ordinal:e.ordinal}},l.months=function(){return o(c(),"months")},l.monthsShort=function(){return o(c(),"monthsShort","months",3)},l.weekdays=function(e){return o(c(),"weekdays",null,null,e)},l.weekdaysShort=function(e){return o(c(),"weekdaysShort","weekdays",3,e)},l.weekdaysMin=function(e){return o(c(),"weekdaysMin","weekdays",2,e)}}})},2353:function(e,t,l){"use strict";l.d(t,{X7I:function(){return SW}}); +(self["webpackChunksanyue_imghub"]=self["webpackChunksanyue_imghub"]||[]).push([[504],{17:function(e,t,l){"use strict";l.d(t,{qE:function(){return C},AI:function(){return v},bW:function(){return S},uA:function(){return v},D_:function(){return k},oc:function(){return h},C8:function(){return g},Tn:function(){return b},un:function(){return L},Kg:function(){return y},lQ:function(){return w},jN:function(){return N},V7:function(){return T},x_:function(){return x},rd:function(){return W},Uo:function(){return E},xD:function(){return _},k3:function(){return O},TO:function(){return B}});l(4114),l(8111),l(1148),l(2489),l(116),l(7588),l(1701),l(8237),l(3579),l(7642),l(8004),l(3853),l(5876),l(2475),l(5024),l(1698);var n=l(144),a=l(6768);var o,c=Object.defineProperty,r=Object.defineProperties,s=Object.getOwnPropertyDescriptors,i=Object.getOwnPropertySymbols,u=Object.prototype.hasOwnProperty,d=Object.prototype.propertyIsEnumerable,f=(e,t,l)=>t in e?c(e,t,{enumerable:!0,configurable:!0,writable:!0,value:l}):e[t]=l,p=(e,t)=>{for(var l in t||(t={}))u.call(t,l)&&f(e,l,t[l]);if(i)for(var l of i(t))d.call(t,l)&&f(e,l,t[l]);return e},m=(e,t)=>r(e,s(t));function v(e,t){var l;const o=(0,n.IJ)();return(0,a.nT)(()=>{o.value=e()},m(p({},t),{flush:null!=(l=null==t?void 0:t.flush)?l:"sync"})),(0,n.tB)(o)}const h="undefined"!==typeof window,g=e=>"undefined"!==typeof e,b=(Object.prototype.toString,e=>"function"===typeof e),y=e=>"string"===typeof e,C=(e,t,l)=>Math.min(l,Math.max(t,e)),w=()=>{},L=h&&(null==(o=null==window?void 0:window.navigator)?void 0:o.userAgent)&&/iP(ad|hone|od)/.test(window.navigator.userAgent);function x(e){return"function"===typeof e?e():(0,n.R1)(e)}function M(e,t){function l(...l){return new Promise((n,a)=>{Promise.resolve(e(()=>t.apply(this,l),{fn:t,thisArg:this,args:l})).then(n).catch(a)})}return l}function z(e,t={}){let l,n,a=w;const o=e=>{clearTimeout(e),a(),a=w},c=c=>{const r=x(e),s=x(t.maxWait);return l&&o(l),r<=0||void 0!==s&&s<=0?(n&&(o(n),n=null),Promise.resolve(c())):new Promise((e,i)=>{a=t.rejectOnCancel?i:e,s&&!n&&(n=setTimeout(()=>{l&&o(l),n=null,e(c())},s)),l=setTimeout(()=>{n&&o(n),n=null,e(c())},r)})};return c}function R(e,t=!0,l=!0,n=!1){let a,o,c=0,r=!0,s=w;const i=()=>{a&&(clearTimeout(a),a=void 0,s(),s=w)},u=u=>{const d=x(e),f=Date.now()-c,p=()=>o=u();return i(),d<=0?(c=Date.now(),p()):(f>d&&(l||!r)?(c=Date.now(),p()):t&&(o=new Promise((e,t)=>{s=n?t:e,a=setTimeout(()=>{c=Date.now(),r=!0,e(p()),i()},Math.max(0,d-f))})),l||a||(a=setTimeout(()=>r=!0,d)),r=!1,o)};return u}function k(e){return e}function S(e,t){let l,o,c;const r=(0,n.KR)(!0),s=()=>{r.value=!0,c()};(0,a.wB)(e,s,{flush:"sync"});const i=b(t)?t:t.get,u=b(t)?void 0:t.set,d=(0,n.rY)((e,t)=>(o=e,c=t,{get(){return r.value&&(l=i(),r.value=!1),o(),l},set(e){null==u||u(e)}}));return Object.isExtensible(d)&&(d.trigger=s),d}function E(e){return!!(0,n.o5)()&&((0,n.jr)(e),!0)}Object.defineProperty,Object.getOwnPropertySymbols,Object.prototype.hasOwnProperty,Object.prototype.propertyIsEnumerable;function A(e){if(!(0,n.i9)(e))return(0,n.Kh)(e);const t=new Proxy({},{get(t,l,a){return(0,n.R1)(Reflect.get(e.value,l,a))},set(t,l,a){return(0,n.i9)(e.value[l])&&!(0,n.i9)(a)?e.value[l].value=a:e.value[l]=a,!0},deleteProperty(t,l){return Reflect.deleteProperty(e.value,l)},has(t,l){return Reflect.has(e.value,l)},ownKeys(){return Object.keys(e.value)},getOwnPropertyDescriptor(){return{enumerable:!0,configurable:!0}}});return(0,n.Kh)(t)}function N(e){return A((0,a.EW)(e))}function _(e,t=200,l={}){return M(z(t,l),e)}function T(e,t=200,l={}){const o=(0,n.KR)(e.value),c=_(()=>{o.value=e.value},t,l);return(0,a.wB)(e,()=>c()),o}function O(e,t=200,l=!1,n=!0,a=!1){return M(R(t,l,n,a),e)}Object.defineProperty,Object.defineProperties,Object.getOwnPropertyDescriptors,Object.getOwnPropertySymbols,Object.prototype.hasOwnProperty,Object.prototype.propertyIsEnumerable;function W(e,t=!0){(0,a.nI)()?(0,a.sV)(e):t?e():(0,a.dY)(e)}Object.defineProperty,Object.getOwnPropertySymbols,Object.prototype.hasOwnProperty,Object.prototype.propertyIsEnumerable;function B(e,t,l={}){const{immediate:a=!0}=l,o=(0,n.KR)(!1);let c=null;function r(){c&&(clearTimeout(c),c=null)}function s(){o.value=!1,r()}function i(...l){r(),o.value=!0,c=setTimeout(()=>{o.value=!1,c=null,e(...l)},x(t))}return a&&(o.value=!0,h&&i()),E(s),{isPending:(0,n.tB)(o),start:i,stop:s}}Object.defineProperty,Object.getOwnPropertySymbols,Object.prototype.hasOwnProperty,Object.prototype.propertyIsEnumerable;Object.getOwnPropertySymbols,Object.prototype.hasOwnProperty,Object.prototype.propertyIsEnumerable;Object.getOwnPropertySymbols,Object.prototype.hasOwnProperty,Object.prototype.propertyIsEnumerable;Object.defineProperty,Object.defineProperties,Object.getOwnPropertyDescriptors,Object.getOwnPropertySymbols,Object.prototype.hasOwnProperty,Object.prototype.propertyIsEnumerable;Object.defineProperty,Object.defineProperties,Object.getOwnPropertyDescriptors,Object.getOwnPropertySymbols,Object.prototype.hasOwnProperty,Object.prototype.propertyIsEnumerable;Object.defineProperty,Object.defineProperties,Object.getOwnPropertyDescriptors,Object.getOwnPropertySymbols,Object.prototype.hasOwnProperty,Object.prototype.propertyIsEnumerable;Object.defineProperty,Object.defineProperties,Object.getOwnPropertyDescriptors,Object.getOwnPropertySymbols,Object.prototype.hasOwnProperty,Object.prototype.propertyIsEnumerable;Object.defineProperty,Object.defineProperties,Object.getOwnPropertyDescriptors,Object.getOwnPropertySymbols,Object.prototype.hasOwnProperty,Object.prototype.propertyIsEnumerable},34:function(e,t,l){"use strict";var n=l(4901);e.exports=function(e){return"object"==typeof e?null!==e:n(e)}},37:function(e,t,l){"use strict";var n=l(9937),a=l(5867),o=l(7431);function c(e,t){return(0,o.A)((0,a.A)(e,t,n.A),e+"")}t.A=c},47:function(e,t,l){"use strict";l.d(t,{S2:function(){return S},fg:function(){return E}});var n=l(6768),a=l(144),o=l(4232),c=l(813);const r=Symbol("buttonGroupContextKey");var s=l(261),i=l(8114),u=l(4216),d=l(2436);const f=(e,t)=>{(0,s.b)({from:"type.text",replacement:"link",version:"3.0.0",scope:"props",ref:"https://element-plus.org/en-US/component/button.html#button-attributes"},(0,n.EW)(()=>"text"===e.type));const l=(0,n.WQ)(r,void 0),o=(0,i.H3)("button"),{form:c}=(0,u.j)(),f=(0,d.NV)((0,n.EW)(()=>null==l?void 0:l.size)),p=(0,d.CB)(),m=(0,a.KR)(),v=(0,n.Ht)(),h=(0,n.EW)(()=>{var t;return e.type||(null==l?void 0:l.type)||(null==(t=o.value)?void 0:t.type)||""}),g=(0,n.EW)(()=>{var t,l,n;return null!=(n=null!=(l=e.autoInsertSpace)?l:null==(t=o.value)?void 0:t.autoInsertSpace)&&n}),b=(0,n.EW)(()=>{var t,l,n;return null!=(n=null!=(l=e.plain)?l:null==(t=o.value)?void 0:t.plain)&&n}),y=(0,n.EW)(()=>{var t,l,n;return null!=(n=null!=(l=e.round)?l:null==(t=o.value)?void 0:t.round)&&n}),C=(0,n.EW)(()=>{var t,l,n;return null!=(n=null!=(l=e.text)?l:null==(t=o.value)?void 0:t.text)&&n}),w=(0,n.EW)(()=>"button"===e.tag?{ariaDisabled:p.value||e.loading,disabled:p.value||e.loading,autofocus:e.autofocus,type:e.nativeType}:{}),L=(0,n.EW)(()=>{var e;const t=null==(e=v.default)?void 0:e.call(v);if(g.value&&1===(null==t?void 0:t.length)){const e=t[0];if((null==e?void 0:e.type)===n.EY){const t=e.children;return/^\p{Unified_Ideograph}{2}$/u.test(t.trim())}}return!1}),x=l=>{p.value||e.loading?l.stopPropagation():("reset"===e.nativeType&&(null==c||c.resetFields()),t("click",l))};return{_disabled:p,_size:f,_type:h,_ref:m,_props:w,_plain:b,_round:y,_text:C,shouldAddSpace:L,handleClick:x}};var p=l(1585),m=l(1513),v=l(3513);function h(e,t=20){return e.mix("#141414",t).toString()}function g(e){const t=(0,d.CB)(),l=(0,v.DU)("button");return(0,n.EW)(()=>{let n={},a=e.color;if(a){const o=a.match(/var\((.*?)\)/);o&&(a=window.getComputedStyle(window.document.documentElement).getPropertyValue(o[1]));const c=new m.q(a),r=e.dark?c.tint(20).toString():h(c,20);if(e.plain)n=l.cssVarBlock({"bg-color":e.dark?h(c,90):c.tint(90).toString(),"text-color":a,"border-color":e.dark?h(c,50):c.tint(50).toString(),"hover-text-color":`var(${l.cssVarName("color-white")})`,"hover-bg-color":a,"hover-border-color":a,"active-bg-color":r,"active-text-color":`var(${l.cssVarName("color-white")})`,"active-border-color":r}),t.value&&(n[l.cssVarBlockName("disabled-bg-color")]=e.dark?h(c,90):c.tint(90).toString(),n[l.cssVarBlockName("disabled-text-color")]=e.dark?h(c,50):c.tint(50).toString(),n[l.cssVarBlockName("disabled-border-color")]=e.dark?h(c,80):c.tint(80).toString());else{const o=e.dark?h(c,30):c.tint(30).toString(),s=c.isDark()?`var(${l.cssVarName("color-white")})`:`var(${l.cssVarName("color-black")})`;if(n=l.cssVarBlock({"bg-color":a,"text-color":s,"border-color":a,"hover-bg-color":o,"hover-text-color":s,"hover-border-color":o,"active-bg-color":r,"active-border-color":r}),t.value){const t=e.dark?h(c,50):c.tint(50).toString();n[l.cssVarBlockName("disabled-bg-color")]=t,n[l.cssVarBlockName("disabled-text-color")]=e.dark?"rgba(255, 255, 255, 0.5)":`var(${l.cssVarName("color-white")})`,n[l.cssVarBlockName("disabled-border-color")]=t}}}return n})}var b=l(9077);const y=(0,n.pM)({name:"ElButton"}),C=(0,n.pM)({...y,props:p.D$,emits:p.ro,setup(e,{expose:t,emit:l}){const r=e,s=g(r),i=(0,v.DU)("button"),{_ref:u,_size:d,_type:p,_disabled:m,_props:h,_plain:b,_round:y,_text:C,shouldAddSpace:w,handleClick:L}=f(r,l),x=(0,n.EW)(()=>[i.b(),i.m(p.value),i.m(d.value),i.is("disabled",m.value),i.is("loading",r.loading),i.is("plain",b.value),i.is("round",y.value),i.is("circle",r.circle),i.is("text",C.value),i.is("link",r.link),i.is("has-bg",r.bg)]);return t({ref:u,size:d,type:p,disabled:m,shouldAddSpace:w}),(e,t)=>((0,n.uX)(),(0,n.Wv)((0,n.$y)(e.tag),(0,n.v6)({ref_key:"_ref",ref:u},(0,a.R1)(h),{class:(0,a.R1)(x),style:(0,a.R1)(s),onClick:(0,a.R1)(L)}),{default:(0,n.k6)(()=>[e.loading?((0,n.uX)(),(0,n.CE)(n.FK,{key:0},[e.$slots.loading?(0,n.RG)(e.$slots,"loading",{key:0}):((0,n.uX)(),(0,n.Wv)((0,a.R1)(c.tk),{key:1,class:(0,o.C4)((0,a.R1)(i).is("loading"))},{default:(0,n.k6)(()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)(e.loadingIcon)))]),_:1},8,["class"]))],64)):e.icon||e.$slots.icon?((0,n.uX)(),(0,n.Wv)((0,a.R1)(c.tk),{key:1},{default:(0,n.k6)(()=>[e.icon?((0,n.uX)(),(0,n.Wv)((0,n.$y)(e.icon),{key:0})):(0,n.RG)(e.$slots,"icon",{key:1})]),_:3})):(0,n.Q3)("v-if",!0),e.$slots.default?((0,n.uX)(),(0,n.CE)("span",{key:2,class:(0,o.C4)({[(0,a.R1)(i).em("text","expand")]:(0,a.R1)(w)})},[(0,n.RG)(e.$slots,"default")],2)):(0,n.Q3)("v-if",!0)]),_:3},16,["class","style","onClick"]))}});var w=(0,b.A)(C,[["__file","button.vue"]]),L=l(7378);const x={size:p.D$.size,type:p.D$.type,direction:{type:(0,L.jq)(String),values:["horizontal","vertical"],default:"horizontal"}},M=(0,n.pM)({name:"ElButtonGroup"}),z=(0,n.pM)({...M,props:x,setup(e){const t=e;(0,n.Gt)(r,(0,a.Kh)({size:(0,a.lW)(t,"size"),type:(0,a.lW)(t,"type")}));const l=(0,v.DU)("button");return(e,c)=>((0,n.uX)(),(0,n.CE)("div",{class:(0,o.C4)([(0,a.R1)(l).b("group"),(0,a.R1)(l).bm("group",t.direction)])},[(0,n.RG)(e.$slots,"default")],2))}});var R=(0,b.A)(z,[["__file","button-group.vue"]]),k=l(5376);const S=(0,k.GU)(w,{ButtonGroup:R}),E=(0,k.WM)(R)},81:function(e,t,l){"use strict";var n=l(9565),a=l(9306),o=l(8551),c=l(6823),r=l(851),s=TypeError;e.exports=function(e,t){var l=arguments.length<2?r(e):t;if(a(l))return o(n(l,e));throw new s(c(e)+" is not iterable")}},90:function(e,t,l){"use strict";l.d(t,{s:function(){return a}});var n=l(7378);const a=(0,n.b_)({arrowOffset:{type:Number,default:5}})},116:function(e,t,l){"use strict";var n=l(6518),a=l(9565),o=l(2652),c=l(9306),r=l(8551),s=l(1767),i=l(9539),u=l(4549),d=u("find",TypeError);n({target:"Iterator",proto:!0,real:!0,forced:d},{find:function(e){r(this);try{c(e)}catch(n){i(this,"throw",n)}if(d)return a(d,this,e);var t=s(this),l=0;return o(t,function(t,n){if(e(t,l++))return n(t)},{IS_RECORD:!0,INTERRUPTED:!0}).result}})},144:function(e,t,l){"use strict";l.d(t,{C4:function(){return R},EW:function(){return Ge},Gc:function(){return we},IG:function(){return Ee},IJ:function(){return Oe},KR:function(){return Te},Kh:function(){return Ce},Pr:function(){return Ve},QW:function(){return He},R1:function(){return De},Tm:function(){return ze},X2:function(){return d},a1:function(){return Ne},bl:function(){return k},fE:function(){return Re},g8:function(){return Me},hV:function(){return tt},hZ:function(){return D},i9:function(){return _e},jr:function(){return i},ju:function(){return ke},lJ:function(){return Ae},lW:function(){return Xe},mu:function(){return Ie},o5:function(){return s},qA:function(){return P},rY:function(){return $e},tB:function(){return Le},u4:function(){return I},uY:function(){return r},ux:function(){return Se},wB:function(){return et},yC:function(){return c}});l(4114),l(8111),l(2489),l(7588),l(1701),l(3579),l(7642),l(8004),l(3853),l(5876),l(2475),l(5024),l(1698);var n=l(4232);let a,o;class c{constructor(e=!1){this.detached=e,this._active=!0,this._on=0,this.effects=[],this.cleanups=[],this._isPaused=!1,this.parent=a,!e&&a&&(this.index=(a.scopes||(a.scopes=[])).push(this)-1)}get active(){return this._active}pause(){if(this._active){let e,t;if(this._isPaused=!0,this.scopes)for(e=0,t=this.scopes.length;e0&&0===--this._on&&(a=this.prevScope,this.prevScope=void 0)}stop(e){if(this._active){let t,l;for(this._active=!1,t=0,l=this.effects.length;t0)return;if(p){let e=p;p=void 0;while(e){const t=e.next;e.next=void 0,e.flags&=-9,e=t}}let e;while(f){let l=f;f=void 0;while(l){const n=l.next;if(l.next=void 0,l.flags&=-9,1&l.flags)try{l.trigger()}catch(t){e||(e=t)}l=n}}if(e)throw e}function b(e){for(let t=e.deps;t;t=t.nextDep)t.version=-1,t.prevActiveLink=t.dep.activeLink,t.dep.activeLink=t}function y(e){let t,l=e.depsTail,n=l;while(n){const e=n.prevDep;-1===n.version?(n===l&&(l=e),L(n),x(n)):t=n,n.dep.activeLink=n.prevActiveLink,n.prevActiveLink=void 0,n=e}e.deps=t,e.depsTail=l}function C(e){for(let t=e.deps;t;t=t.nextDep)if(t.dep.version!==t.version||t.dep.computed&&(w(t.dep.computed)||t.dep.version!==t.version))return!0;return!!e._dirty}function w(e){if(4&e.flags&&!(16&e.flags))return;if(e.flags&=-17,e.globalVersion===E)return;if(e.globalVersion=E,!e.isSSR&&128&e.flags&&(!e.deps&&!e._dirty||!C(e)))return;e.flags|=2;const t=e.dep,l=o,a=M;o=e,M=!0;try{b(e);const l=e.fn(e._value);(0===t.version||(0,n.$H)(l,e._value))&&(e.flags|=128,e._value=l,t.version++)}catch(c){throw t.version++,c}finally{o=l,M=a,y(e),e.flags&=-3}}function L(e,t=!1){const{dep:l,prevSub:n,nextSub:a}=e;if(n&&(n.nextSub=a,e.prevSub=void 0),a&&(a.prevSub=n,e.nextSub=void 0),l.subs===e&&(l.subs=n,!n&&l.computed)){l.computed.flags&=-5;for(let e=l.computed.deps;e;e=e.nextDep)L(e,!0)}t||--l.sc||!l.map||l.map.delete(l.key)}function x(e){const{prevDep:t,nextDep:l}=e;t&&(t.nextDep=l,e.prevDep=void 0),l&&(l.prevDep=t,e.nextDep=void 0)}let M=!0;const z=[];function R(){z.push(M),M=!1}function k(){const e=z.pop();M=void 0===e||e}function S(e){const{cleanup:t}=e;if(e.cleanup=void 0,t){const e=o;o=void 0;try{t()}finally{o=e}}}let E=0;class A{constructor(e,t){this.sub=e,this.dep=t,this.version=t.version,this.nextDep=this.prevDep=this.nextSub=this.prevSub=this.prevActiveLink=void 0}}class N{constructor(e){this.computed=e,this.version=0,this.activeLink=void 0,this.subs=void 0,this.map=void 0,this.key=void 0,this.sc=0,this.__v_skip=!0}track(e){if(!o||!M||o===this.computed)return;let t=this.activeLink;if(void 0===t||t.sub!==o)t=this.activeLink=new A(o,this),o.deps?(t.prevDep=o.depsTail,o.depsTail.nextDep=t,o.depsTail=t):o.deps=o.depsTail=t,_(t);else if(-1===t.version&&(t.version=this.version,t.nextDep)){const e=t.nextDep;e.prevDep=t.prevDep,t.prevDep&&(t.prevDep.nextDep=e),t.prevDep=o.depsTail,t.nextDep=void 0,o.depsTail.nextDep=t,o.depsTail=t,o.deps===t&&(o.deps=e)}return t}trigger(e){this.version++,E++,this.notify(e)}notify(e){h();try{0;for(let e=this.subs;e;e=e.prevSub)e.sub.notify()&&e.sub.dep.notify()}finally{g()}}}function _(e){if(e.dep.sc++,4&e.sub.flags){const t=e.dep.computed;if(t&&!e.dep.subs){t.flags|=20;for(let e=t.deps;e;e=e.nextDep)_(e)}const l=e.dep.subs;l!==e&&(e.prevSub=l,l&&(l.nextSub=e)),e.dep.subs=e}}const T=new WeakMap,O=Symbol(""),W=Symbol(""),B=Symbol("");function I(e,t,l){if(M&&o){let t=T.get(e);t||T.set(e,t=new Map);let n=t.get(l);n||(t.set(l,n=new N),n.map=t,n.key=l),n.track()}}function D(e,t,l,a,o,c){const r=T.get(e);if(!r)return void E++;const s=e=>{e&&e.trigger()};if(h(),"clear"===t)r.forEach(s);else{const o=(0,n.cy)(e),c=o&&(0,n.yI)(l);if(o&&"length"===l){const e=Number(a);r.forEach((t,l)=>{("length"===l||l===B||!(0,n.Bm)(l)&&l>=e)&&s(t)})}else switch((void 0!==l||r.has(void 0))&&s(r.get(l)),c&&s(r.get(B)),t){case"add":o?c&&s(r.get("length")):(s(r.get(O)),(0,n.CE)(e)&&s(r.get(W)));break;case"delete":o||(s(r.get(O)),(0,n.CE)(e)&&s(r.get(W)));break;case"set":(0,n.CE)(e)&&s(r.get(O));break}}g()}function F(e,t){const l=T.get(e);return l&&l.get(t)}function V(e){const t=Se(e);return t===e?t:(I(t,"iterate",B),Re(e)?t:t.map(Ae))}function P(e){return I(e=Se(e),"iterate",B),e}function $(e,t){return ze(e)?Me(e)?Ne(Ae(t)):Ne(t):Ae(t)}const H={__proto__:null,[Symbol.iterator](){return j(this,Symbol.iterator,e=>$(this,e))},concat(...e){return V(this).concat(...e.map(e=>(0,n.cy)(e)?V(e):e))},entries(){return j(this,"entries",e=>(e[1]=$(this,e[1]),e))},every(e,t){return X(this,"every",e,t,void 0,arguments)},filter(e,t){return X(this,"filter",e,t,e=>e.map(e=>$(this,e)),arguments)},find(e,t){return X(this,"find",e,t,e=>$(this,e),arguments)},findIndex(e,t){return X(this,"findIndex",e,t,void 0,arguments)},findLast(e,t){return X(this,"findLast",e,t,e=>$(this,e),arguments)},findLastIndex(e,t){return X(this,"findLastIndex",e,t,void 0,arguments)},forEach(e,t){return X(this,"forEach",e,t,void 0,arguments)},includes(...e){return q(this,"includes",e)},indexOf(...e){return q(this,"indexOf",e)},join(e){return V(this).join(e)},lastIndexOf(...e){return q(this,"lastIndexOf",e)},map(e,t){return X(this,"map",e,t,void 0,arguments)},pop(){return G(this,"pop")},push(...e){return G(this,"push",e)},reduce(e,...t){return U(this,"reduce",e,t)},reduceRight(e,...t){return U(this,"reduceRight",e,t)},shift(){return G(this,"shift")},some(e,t){return X(this,"some",e,t,void 0,arguments)},splice(...e){return G(this,"splice",e)},toReversed(){return V(this).toReversed()},toSorted(e){return V(this).toSorted(e)},toSpliced(...e){return V(this).toSpliced(...e)},unshift(...e){return G(this,"unshift",e)},values(){return j(this,"values",e=>$(this,e))}};function j(e,t,l){const n=P(e),a=n[t]();return n===e||Re(e)||(a._next=a.next,a.next=()=>{const e=a._next();return e.done||(e.value=l(e.value)),e}),a}const K=Array.prototype;function X(e,t,l,n,a,o){const c=P(e),r=c!==e&&!Re(e),s=c[t];if(s!==K[t]){const t=s.apply(e,o);return r?Ae(t):t}let i=l;c!==e&&(r?i=function(t,n){return l.call(this,$(e,t),n,e)}:l.length>2&&(i=function(t,n){return l.call(this,t,n,e)}));const u=s.call(c,i,n);return r&&a?a(u):u}function U(e,t,l,n){const a=P(e);let o=l;return a!==e&&(Re(e)?l.length>3&&(o=function(t,n,a){return l.call(this,t,n,a,e)}):o=function(t,n,a){return l.call(this,t,$(e,n),a,e)}),a[t](o,...n)}function q(e,t,l){const n=Se(e);I(n,"iterate",B);const a=n[t](...l);return-1!==a&&!1!==a||!ke(l[0])?a:(l[0]=Se(l[0]),n[t](...l))}function G(e,t,l=[]){R(),h();const n=Se(e)[t].apply(e,l);return g(),k(),n}const Y=(0,n.pD)("__proto__,__v_isRef,__isVue"),Q=new Set(Object.getOwnPropertyNames(Symbol).filter(e=>"arguments"!==e&&"caller"!==e).map(e=>Symbol[e]).filter(n.Bm));function Z(e){(0,n.Bm)(e)||(e=String(e));const t=Se(this);return I(t,"has",e),t.hasOwnProperty(e)}class J{constructor(e=!1,t=!1){this._isReadonly=e,this._isShallow=t}get(e,t,l){if("__v_skip"===t)return e["__v_skip"];const a=this._isReadonly,o=this._isShallow;if("__v_isReactive"===t)return!a;if("__v_isReadonly"===t)return a;if("__v_isShallow"===t)return o;if("__v_raw"===t)return l===(a?o?ge:he:o?ve:me).get(e)||Object.getPrototypeOf(e)===Object.getPrototypeOf(l)?e:void 0;const c=(0,n.cy)(e);if(!a){let e;if(c&&(e=H[t]))return e;if("hasOwnProperty"===t)return Z}const r=Reflect.get(e,t,_e(e)?e:l);if((0,n.Bm)(t)?Q.has(t):Y(t))return r;if(a||I(e,"get",t),o)return r;if(_e(r)){const e=c&&(0,n.yI)(t)?r:r.value;return a&&(0,n.Gv)(e)?Le(e):e}return(0,n.Gv)(r)?a?Le(r):Ce(r):r}}class ee extends J{constructor(e=!1){super(!1,e)}set(e,t,l,a){let o=e[t];const c=(0,n.cy)(e)&&(0,n.yI)(t);if(!this._isShallow){const e=ze(o);if(Re(l)||ze(l)||(o=Se(o),l=Se(l)),!c&&_e(o)&&!_e(l))return e||(o.value=l),!0}const r=c?Number(t)e,ce=e=>Reflect.getPrototypeOf(e);function re(e,t,l){return function(...a){const o=this["__v_raw"],c=Se(o),r=(0,n.CE)(c),s="entries"===e||e===Symbol.iterator&&r,i="keys"===e&&r,u=o[e](...a),d=l?oe:t?Ne:Ae;return!t&&I(c,"iterate",i?W:O),{next(){const{value:e,done:t}=u.next();return t?{value:e,done:t}:{value:s?[d(e[0]),d(e[1])]:d(e),done:t}},[Symbol.iterator](){return this}}}}function se(e){return function(...t){return"delete"!==e&&("clear"===e?void 0:this)}}function ie(e,t){const l={get(l){const a=this["__v_raw"],o=Se(a),c=Se(l);e||((0,n.$H)(l,c)&&I(o,"get",l),I(o,"get",c));const{has:r}=ce(o),s=t?oe:e?Ne:Ae;return r.call(o,l)?s(a.get(l)):r.call(o,c)?s(a.get(c)):void(a!==o&&a.get(l))},get size(){const t=this["__v_raw"];return!e&&I(Se(t),"iterate",O),t.size},has(t){const l=this["__v_raw"],a=Se(l),o=Se(t);return e||((0,n.$H)(t,o)&&I(a,"has",t),I(a,"has",o)),t===o?l.has(t):l.has(t)||l.has(o)},forEach(l,n){const a=this,o=a["__v_raw"],c=Se(o),r=t?oe:e?Ne:Ae;return!e&&I(c,"iterate",O),o.forEach((e,t)=>l.call(n,r(e),r(t),a))}};(0,n.X$)(l,e?{add:se("add"),set:se("set"),delete:se("delete"),clear:se("clear")}:{add(e){t||Re(e)||ze(e)||(e=Se(e));const l=Se(this),n=ce(l),a=n.has.call(l,e);return a||(l.add(e),D(l,"add",e,e)),this},set(e,l){t||Re(l)||ze(l)||(l=Se(l));const a=Se(this),{has:o,get:c}=ce(a);let r=o.call(a,e);r||(e=Se(e),r=o.call(a,e));const s=c.call(a,e);return a.set(e,l),r?(0,n.$H)(l,s)&&D(a,"set",e,l,s):D(a,"add",e,l),this},delete(e){const t=Se(this),{has:l,get:n}=ce(t);let a=l.call(t,e);a||(e=Se(e),a=l.call(t,e));const o=n?n.call(t,e):void 0,c=t.delete(e);return a&&D(t,"delete",e,void 0,o),c},clear(){const e=Se(this),t=0!==e.size,l=void 0,n=e.clear();return t&&D(e,"clear",void 0,void 0,l),n}});const a=["keys","values","entries",Symbol.iterator];return a.forEach(n=>{l[n]=re(n,e,t)}),l}function ue(e,t){const l=ie(e,t);return(t,a,o)=>"__v_isReactive"===a?!e:"__v_isReadonly"===a?e:"__v_raw"===a?t:Reflect.get((0,n.$3)(l,a)&&a in t?l:t,a,o)}const de={get:ue(!1,!1)},fe={get:ue(!1,!0)},pe={get:ue(!0,!1)};const me=new WeakMap,ve=new WeakMap,he=new WeakMap,ge=new WeakMap;function be(e){switch(e){case"Object":case"Array":return 1;case"Map":case"Set":case"WeakMap":case"WeakSet":return 2;default:return 0}}function ye(e){return e["__v_skip"]||!Object.isExtensible(e)?0:be((0,n.Zf)(e))}function Ce(e){return ze(e)?e:xe(e,!1,le,de,me)}function we(e){return xe(e,!1,ae,fe,ve)}function Le(e){return xe(e,!0,ne,pe,he)}function xe(e,t,l,a,o){if(!(0,n.Gv)(e))return e;if(e["__v_raw"]&&(!t||!e["__v_isReactive"]))return e;const c=ye(e);if(0===c)return e;const r=o.get(e);if(r)return r;const s=new Proxy(e,2===c?a:l);return o.set(e,s),s}function Me(e){return ze(e)?Me(e["__v_raw"]):!(!e||!e["__v_isReactive"])}function ze(e){return!(!e||!e["__v_isReadonly"])}function Re(e){return!(!e||!e["__v_isShallow"])}function ke(e){return!!e&&!!e["__v_raw"]}function Se(e){const t=e&&e["__v_raw"];return t?Se(t):e}function Ee(e){return!(0,n.$3)(e,"__v_skip")&&Object.isExtensible(e)&&(0,n.yQ)(e,"__v_skip",!0),e}const Ae=e=>(0,n.Gv)(e)?Ce(e):e,Ne=e=>(0,n.Gv)(e)?Le(e):e;function _e(e){return!!e&&!0===e["__v_isRef"]}function Te(e){return We(e,!1)}function Oe(e){return We(e,!0)}function We(e,t){return _e(e)?e:new Be(e,t)}class Be{constructor(e,t){this.dep=new N,this["__v_isRef"]=!0,this["__v_isShallow"]=!1,this._rawValue=t?e:Se(e),this._value=t?e:Ae(e),this["__v_isShallow"]=t}get value(){return this.dep.track(),this._value}set value(e){const t=this._rawValue,l=this["__v_isShallow"]||Re(e)||ze(e);e=l?e:Se(e),(0,n.$H)(e,t)&&(this._rawValue=e,this._value=l?e:Ae(e),this.dep.trigger())}}function Ie(e){e.dep&&e.dep.trigger()}function De(e){return _e(e)?e.value:e}const Fe={get:(e,t,l)=>"__v_raw"===t?e:De(Reflect.get(e,t,l)),set:(e,t,l,n)=>{const a=e[t];return _e(a)&&!_e(l)?(a.value=l,!0):Reflect.set(e,t,l,n)}};function Ve(e){return Me(e)?e:new Proxy(e,Fe)}class Pe{constructor(e){this["__v_isRef"]=!0,this._value=void 0;const t=this.dep=new N,{get:l,set:n}=e(t.track.bind(t),t.trigger.bind(t));this._get=l,this._set=n}get value(){return this._value=this._get()}set value(e){this._set(e)}}function $e(e){return new Pe(e)}function He(e){const t=(0,n.cy)(e)?new Array(e.length):{};for(const l in e)t[l]=Ue(e,l);return t}class je{constructor(e,t,l){this._object=e,this._key=t,this._defaultValue=l,this["__v_isRef"]=!0,this._value=void 0,this._raw=Se(e);let a=!0,o=e;if(!(0,n.cy)(e)||!(0,n.yI)(String(t)))do{a=!ke(o)||Re(o)}while(a&&(o=o["__v_raw"]));this._shallow=a}get value(){let e=this._object[this._key];return this._shallow&&(e=De(e)),this._value=void 0===e?this._defaultValue:e}set value(e){if(this._shallow&&_e(this._raw[this._key])){const t=this._object[this._key];if(_e(t))return void(t.value=e)}this._object[this._key]=e}get dep(){return F(this._raw,this._key)}}class Ke{constructor(e){this._getter=e,this["__v_isRef"]=!0,this["__v_isReadonly"]=!0,this._value=void 0}get value(){return this._value=this._getter()}}function Xe(e,t,l){return _e(e)?e:(0,n.Tn)(e)?new Ke(e):(0,n.Gv)(e)&&arguments.length>1?Ue(e,t,l):Te(e)}function Ue(e,t,l){return new je(e,t,l)}class qe{constructor(e,t,l){this.fn=e,this.setter=t,this._value=void 0,this.dep=new N(this),this.__v_isRef=!0,this.deps=void 0,this.depsTail=void 0,this.flags=16,this.globalVersion=E-1,this.next=void 0,this.effect=this,this["__v_isReadonly"]=!t,this.isSSR=l}notify(){if(this.flags|=16,!(8&this.flags||o===this))return v(this,!0),!0}get value(){const e=this.dep.track();return w(this),e&&(e.version=this.dep.version),this._value}set value(e){this.setter&&this.setter(e)}}function Ge(e,t,l=!1){let a,o;(0,n.Tn)(e)?a=e:(a=e.get,o=e.set);const c=new qe(a,o,l);return c}const Ye={},Qe=new WeakMap;let Ze;function Je(e,t=!1,l=Ze){if(l){let t=Qe.get(l);t||Qe.set(l,t=[]),t.push(e)}else 0}function et(e,t,l=n.MZ){const{immediate:a,deep:o,once:c,scheduler:r,augmentJob:i,call:u}=l,f=e=>o?e:Re(e)||!1===o||0===o?tt(e,1):tt(e);let p,m,v,h,g=!1,b=!1;if(_e(e)?(m=()=>e.value,g=Re(e)):Me(e)?(m=()=>f(e),g=!0):(0,n.cy)(e)?(b=!0,g=e.some(e=>Me(e)||Re(e)),m=()=>e.map(e=>_e(e)?e.value:Me(e)?f(e):(0,n.Tn)(e)?u?u(e,2):e():void 0)):m=(0,n.Tn)(e)?t?u?()=>u(e,2):e:()=>{if(v){R();try{v()}finally{k()}}const t=Ze;Ze=p;try{return u?u(e,3,[h]):e(h)}finally{Ze=t}}:n.tE,t&&o){const e=m,t=!0===o?1/0:o;m=()=>tt(e(),t)}const y=s(),C=()=>{p.stop(),y&&y.active&&(0,n.TF)(y.effects,p)};if(c&&t){const e=t;t=(...t)=>{e(...t),C()}}let w=b?new Array(e.length).fill(Ye):Ye;const L=e=>{if(1&p.flags&&(p.dirty||e))if(t){const e=p.run();if(o||g||(b?e.some((e,t)=>(0,n.$H)(e,w[t])):(0,n.$H)(e,w))){v&&v();const l=Ze;Ze=p;try{const l=[e,w===Ye?void 0:b&&w[0]===Ye?[]:w,h];w=e,u?u(t,3,l):t(...l)}finally{Ze=l}}}else p.run()};return i&&i(L),p=new d(m),p.scheduler=r?()=>r(L,!1):L,h=e=>Je(e,!1,p),v=p.onStop=()=>{const e=Qe.get(p);if(e){if(u)u(e,4);else for(const t of e)t();Qe.delete(p)}},t?a?L(!0):w=p.run():r?r(L.bind(null,!0),!0):p.run(),C.pause=p.pause.bind(p),C.resume=p.resume.bind(p),C.stop=C,C}function tt(e,t=1/0,l){if(t<=0||!(0,n.Gv)(e)||e["__v_skip"])return e;if(l=l||new Map,(l.get(e)||0)>=t)return e;if(l.set(e,t),t--,_e(e))tt(e.value,t,l);else if((0,n.cy)(e))for(let n=0;n{tt(e,t,l)});else if((0,n.Qd)(e)){for(const n in e)tt(e[n],t,l);for(const n of Object.getOwnPropertySymbols(e))Object.prototype.propertyIsEnumerable.call(e,n)&&tt(e[n],t,l)}return e}},168:function(e,t){"use strict";function l(e){var t=typeof e;return null!=e&&("object"==t||"function"==t)}t.A=l},203:function(e,t,l){"use strict";var n=l(1018),a=l(5014),o=l(2676),c=l(168),r=l(3708);function s(e,t,l,s){if(!(0,c.A)(e))return e;t=(0,a.A)(t,e);var i=-1,u=t.length,d=u-1,f=e;while(null!=f&&++i{(0,n.wB)(()=>(0,a.R1)(i),n=>{n&&(0,o.U)(l,`[${s}] ${e} is about to be deprecated in version ${c}, please use ${t} instead.\nFor more detail, please visit: ${r}\n`)},{immediate:!0})}},283:function(e,t,l){"use strict";var n=l(9504),a=l(9039),o=l(4901),c=l(9297),r=l(3724),s=l(350).CONFIGURABLE,i=l(3706),u=l(1181),d=u.enforce,f=u.get,p=String,m=Object.defineProperty,v=n("".slice),h=n("".replace),g=n([].join),b=r&&!a(function(){return 8!==m(function(){},"length",{value:8}).length}),y=String(String).split("String"),C=e.exports=function(e,t,l){"Symbol("===v(p(t),0,7)&&(t="["+h(p(t),/^Symbol\(([^)]*)\).*$/,"$1")+"]"),l&&l.getter&&(t="get "+t),l&&l.setter&&(t="set "+t),(!c(e,"name")||s&&e.name!==t)&&(r?m(e,"name",{value:t,configurable:!0}):e.name=t),b&&l&&c(l,"arity")&&e.length!==l.arity&&m(e,"length",{value:l.arity});try{l&&c(l,"constructor")&&l.constructor?r&&m(e,"prototype",{writable:!1}):e.prototype&&(e.prototype=void 0)}catch(a){}var n=d(e);return c(n,"source")||(n.source=g(y,"string"==typeof t?t:"")),e};Function.prototype.toString=C(function(){return o(this)&&f(this).source||i(this)},"toString")},292:function(e,t,l){"use strict";l.d(t,{gc:function(){return N}});l(4114),l(8111),l(2489),l(7588),l(1701),l(8237);var n=l(6768),a=l(8950);function o(e,t){(null==t||t>e.length)&&(t=e.length);for(var l=0,n=Array(t);l0||!Array.isArray(t)&&t?r({},e,t):{}}function C(e){var t,l=(t={"fa-spin":e.spin,"fa-pulse":e.pulse,"fa-fw":e.fixedWidth,"fa-border":e.border,"fa-li":e.listItem,"fa-inverse":e.inverse,"fa-flip":!0===e.flip,"fa-flip-horizontal":"horizontal"===e.flip||"both"===e.flip,"fa-flip-vertical":"vertical"===e.flip||"both"===e.flip},r(r(r(r(r(r(r(r(r(r(t,"fa-".concat(e.size),null!==e.size),"fa-rotate-".concat(e.rotation),null!==e.rotation),"fa-rotate-by",e.rotateBy),"fa-pull-".concat(e.pull),null!==e.pull),"fa-swap-opacity",e.swapOpacity),"fa-bounce",e.bounce),"fa-shake",e.shake),"fa-beat",e.beat),"fa-fade",e.fade),"fa-beat-fade",e.beatFade),r(r(r(r(t,"fa-flash",e.flash),"fa-spin-pulse",e.spinPulse),"fa-spin-reverse",e.spinReverse),"fa-width-auto",e.widthAuto));return Object.keys(l).map(function(e){return l[e]?e:null}).filter(function(e){return e})}var w="undefined"!==typeof globalThis?globalThis:"undefined"!==typeof window?window:"undefined"!==typeof l.g?l.g:"undefined"!==typeof self?self:{},L={exports:{}};(function(e){(function(t){var l=function(e,t,n){if(!i(t)||d(t)||f(t)||p(t)||s(t))return t;var a,o=0,c=0;if(u(t))for(a=[],c=t.length;o1&&void 0!==arguments[1]?arguments[1]:{},l=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};if("string"===typeof e)return e;var a=(e.children||[]).map(function(e){return k(e)}),o=Object.keys(e.attributes||{}).reduce(function(t,l){var n=e.attributes[l];switch(l){case"class":t.class=R(n);break;case"style":t.style=z(n);break;default:t.attrs[l]=n}return t},{attrs:{},class:{},style:{}});l.class;var c=l.style,r=void 0===c?{}:c,s=f(l,M);return(0,n.h)(e.tag,d(d(d({},t),{},{class:o.class,style:d(d({},o.style),r)},o.attrs),s),a)}var S=!1;try{S=!0}catch(_){}function E(){var e;!S&&console&&"function"===typeof console.error&&(e=console).error.apply(e,arguments)}function A(e){return e&&"object"===g(e)&&e.prefix&&e.iconName&&e.icon?e:a.qg.icon?a.qg.icon(e):null===e?null:"object"===g(e)&&e.prefix&&e.iconName?e:Array.isArray(e)&&2===e.length?{prefix:e[0],iconName:e[1]}:"string"===typeof e?{prefix:"fas",iconName:e}:void 0}var N=(0,n.pM)({name:"FontAwesomeIcon",props:{border:{type:Boolean,default:!1},fixedWidth:{type:Boolean,default:!1},flip:{type:[Boolean,String],default:!1,validator:function(e){return[!0,!1,"horizontal","vertical","both"].indexOf(e)>-1}},icon:{type:[Object,Array,String],required:!0},mask:{type:[Object,Array,String],default:null},maskId:{type:String,default:null},listItem:{type:Boolean,default:!1},pull:{type:String,default:null,validator:function(e){return["right","left"].indexOf(e)>-1}},pulse:{type:Boolean,default:!1},rotation:{type:[String,Number],default:null,validator:function(e){return[90,180,270].indexOf(Number.parseInt(e,10))>-1}},rotateBy:{type:Boolean,default:!1},swapOpacity:{type:Boolean,default:!1},size:{type:String,default:null,validator:function(e){return["2xs","xs","sm","lg","xl","2xl","1x","2x","3x","4x","5x","6x","7x","8x","9x","10x"].indexOf(e)>-1}},spin:{type:Boolean,default:!1},transform:{type:[String,Object],default:null},symbol:{type:[Boolean,String],default:!1},title:{type:String,default:null},titleId:{type:String,default:null},inverse:{type:Boolean,default:!1},bounce:{type:Boolean,default:!1},shake:{type:Boolean,default:!1},beat:{type:Boolean,default:!1},fade:{type:Boolean,default:!1},beatFade:{type:Boolean,default:!1},flash:{type:Boolean,default:!1},spinPulse:{type:Boolean,default:!1},spinReverse:{type:Boolean,default:!1},widthAuto:{type:Boolean,default:!1}},setup:function(e,t){var l=t.attrs,o=(0,n.EW)(function(){return A(e.icon)}),c=(0,n.EW)(function(){return y("classes",C(e))}),r=(0,n.EW)(function(){return y("transform","string"===typeof e.transform?a.qg.transform(e.transform):e.transform)}),s=(0,n.EW)(function(){return y("mask",A(e.mask))}),i=(0,n.EW)(function(){var t=d(d(d(d({},c.value),r.value),s.value),{},{symbol:e.symbol,maskId:e.maskId});return t.title=e.title,t.titleId=e.titleId,(0,a.Kk)(o.value,t)});(0,n.wB)(i,function(e){if(!e)return E("Could not find one or more icon(s)",o.value,s.value)},{immediate:!0});var u=(0,n.EW)(function(){return i.value?k(i.value.abstract[0],{},l):null});return function(){return u.value}}});(0,n.pM)({name:"FontAwesomeLayers",props:{fixedWidth:{type:Boolean,default:!1}},setup:function(e,t){var l=t.slots,o=a.$W.familyPrefix,c=(0,n.EW)(function(){return["".concat(o,"-layers")].concat(m(e.fixedWidth?["".concat(o,"-fw")]:[]))});return function(){return(0,n.h)("div",{class:c.value},l.default?l.default():[])}}}),(0,n.pM)({name:"FontAwesomeLayersText",props:{value:{type:[String,Number],default:""},transform:{type:[String,Object],default:null},counter:{type:Boolean,default:!1},position:{type:String,default:null,validator:function(e){return["bottom-left","bottom-right","top-left","top-right"].indexOf(e)>-1}}},setup:function(e,t){var l=t.attrs,o=a.$W.familyPrefix,c=(0,n.EW)(function(){return y("classes",[].concat(m(e.counter?["".concat(o,"-layers-counter")]:[]),m(e.position?["".concat(o,"-layers-").concat(e.position)]:[])))}),r=(0,n.EW)(function(){return y("transform","string"===typeof e.transform?a.qg.transform(e.transform):e.transform)}),s=(0,n.EW)(function(){var t=(0,a.Qq)(e.value.toString(),d(d({},r.value),c.value)),l=t.abstract;return e.counter&&(l[0].attributes.class=l[0].attributes.class.replace("fa-layers-text","")),l[0]}),i=(0,n.EW)(function(){return k(s.value,{},l)});return function(){return i.value}}})},339:function(e,t,l){"use strict";var n="object"==typeof l.g&&l.g&&l.g.Object===Object&&l.g;t.A=n},350:function(e,t,l){"use strict";var n=l(3724),a=l(9297),o=Function.prototype,c=n&&Object.getOwnPropertyDescriptor,r=a(o,"name"),s=r&&"something"===function(){}.name,i=r&&(!n||n&&c(o,"name").configurable);e.exports={EXISTS:r,PROPER:s,CONFIGURABLE:i}},372:function(e,t,l){"use strict";l(5331),l(9648),l(6711),l(7197)},397:function(e,t,l){"use strict";var n=l(7751);e.exports=n("document","documentElement")},421:function(e){"use strict";e.exports={}},456:function(e,t,l){"use strict";var n=l(6518),a=l(4576),o=l(9504),c=l(4154),r=l(5169),s=o(1.1.toString),i=a.Uint8Array,u=!i||!i.prototype.toHex||!function(){try{var e=new i([255,255,255,255,255,255,255,255]);return"ffffffffffffffff"===e.toHex()}catch(t){return!1}}();i&&n({target:"Uint8Array",proto:!0,forced:u},{toHex:function(){c(this),r(this.buffer);for(var e="",t=0,l=this.length;t{var r;return(0,n.uX)(),(0,n.CE)("div",{class:(0,a.C4)([(0,o.R1)(l).b(),(0,o.R1)(l).is(`${e.shadow||(null==(r=(0,o.R1)(t))?void 0:r.shadow)||"always"}-shadow`)])},[e.$slots.header||e.header?((0,n.uX)(),(0,n.CE)("div",{key:0,class:(0,a.C4)([(0,o.R1)(l).e("header"),e.headerClass])},[(0,n.RG)(e.$slots,"header",{},()=>[(0,n.eW)((0,a.v_)(e.header),1)])],2)):(0,n.Q3)("v-if",!0),(0,n.Lk)("div",{class:(0,a.C4)([(0,o.R1)(l).e("body"),e.bodyClass]),style:(0,a.Tr)(e.bodyStyle)},[(0,n.RG)(e.$slots,"default")],6),e.$slots.footer||e.footer?((0,n.uX)(),(0,n.CE)("div",{key:1,class:(0,a.C4)([(0,o.R1)(l).e("footer"),e.footerClass])},[(0,n.RG)(e.$slots,"footer",{},()=>[(0,n.eW)((0,a.v_)(e.footer),1)])],2)):(0,n.Q3)("v-if",!0)],2)}}});var p=(0,s.A)(f,[["__file","card.vue"]]),m=l(5376);const v=(0,m.GU)(p)},684:function(e){"use strict";e.exports=function(e,t){var l="function"==typeof Iterator&&Iterator.prototype[e];if(l)try{l.call({next:null},t).next()}catch(n){return!0}}},729:function(e,t){"use strict";var l=Object.prototype;function n(e){var t=e&&e.constructor,n="function"==typeof t&&t.prototype||l;return e===n}t.A=n},741:function(e){"use strict";var t=Math.ceil,l=Math.floor;e.exports=Math.trunc||function(e){var n=+e;return(n>0?l:t)(n)}},754:function(e,t,l){"use strict";l.d(t,{A:function(){return g}});var n=/\s/;function a(e){var t=e.length;while(t--&&n.test(e.charAt(t)));return t}var o=a,c=/^\s+/;function r(e){return e?e.slice(0,o(e)+1).replace(c,""):e}var s=r,i=l(168),u=l(8095),d=NaN,f=/^[-+]0x[0-9a-f]+$/i,p=/^0b[01]+$/i,m=/^0o[0-7]+$/i,v=parseInt;function h(e){if("number"==typeof e)return e;if((0,u.A)(e))return d;if((0,i.A)(e)){var t="function"==typeof e.valueOf?e.valueOf():e;e=(0,i.A)(t)?t+"":t}if("string"!=typeof e)return 0===e?e:+e;e=s(e);var l=p.test(e);return l||m.test(e)?v(e.slice(2),l?2:8):f.test(e)?d:+e}var g=h},757:function(e,t,l){"use strict";var n=l(7751),a=l(4901),o=l(1625),c=l(7040),r=Object;e.exports=c?function(e){return"symbol"==typeof e}:function(e){var t=n("Symbol");return a(t)&&o(t.prototype,r(e))}},782:function(e,t,l){"use strict";l.d(t,{d:function(){return a},p:function(){return n}});const n=Symbol("popper"),a=Symbol("popperContent")},793:function(e,t,l){"use strict";l.d(t,{G:function(){return r},Y:function(){return s}});var n=l(6768),a=l(144),o=l(9615),c=l(9195);const r={label:"label",value:"value",disabled:"disabled",options:"options"};function s(e){const t=(0,a.KR)({...r,...e.props});let l={...e.props};(0,n.wB)(()=>e.props,e=>{(0,c.A)(e,l)||(t.value={...r,...e},l={...e})},{deep:!0});const s=e=>(0,o.A)(e,t.value.label),i=e=>(0,o.A)(e,t.value.value),u=e=>(0,o.A)(e,t.value.disabled),d=e=>(0,o.A)(e,t.value.options);return{aliasProps:t,getLabel:s,getValue:i,getDisabled:u,getOptions:d}}},813:function(e,t,l){"use strict";l.d(t,{tk:function(){return m}});var n=l(6768),a=l(144),o=l(7378);const c=(0,o.b_)({size:{type:(0,o.jq)([Number,String])},color:{type:String}});var r=l(9077),s=l(3513),i=l(3558);const u=(0,n.pM)({name:"ElIcon",inheritAttrs:!1}),d=(0,n.pM)({...u,props:c,setup(e){const t=e,l=(0,s.DU)("icon"),o=(0,n.EW)(()=>{const{size:e,color:l}=t,n=(0,i._V)(e);return n||l?{fontSize:n,"--color":l}:{}});return(e,t)=>((0,n.uX)(),(0,n.CE)("i",(0,n.v6)({class:(0,a.R1)(l).b(),style:(0,a.R1)(o)},e.$attrs),[(0,n.RG)(e.$slots,"default")],16))}});var f=(0,r.A)(d,[["__file","icon.vue"]]),p=l(5376);const m=(0,p.GU)(f)},844:function(e,t,l){"use strict";l.d(t,{p:function(){return c}});var n=l(4461),a=l(7378),o=l(515);const c=(0,a.b_)({...n.X,disabled:Boolean,trigger:{type:(0,a.jq)([String,Array]),default:"hover"},triggerKeys:{type:(0,a.jq)(Array),default:()=>[o.R.enter,o.R.numpadEnter,o.R.space]},focusOnTarget:Boolean})},850:function(e,t,l){"use strict";l.d(t,{dI:function(){return H},$n:function(){return j},o5:function(){return K}});var n=l(6768),a=l(144),o=l(4232),c=l(5130),r=l(3845),s=l(8501),i=l(2056),u=l(2235);const d={modelValue:{type:[Number,String,Boolean],default:void 0},label:{type:[String,Boolean,Number,Object],default:void 0},value:{type:[String,Boolean,Number,Object],default:void 0},indeterminate:Boolean,disabled:{type:Boolean,default:void 0},checked:Boolean,name:{type:String,default:void 0},trueValue:{type:[String,Number],default:void 0},falseValue:{type:[String,Number],default:void 0},trueLabel:{type:[String,Number],default:void 0},falseLabel:{type:[String,Number],default:void 0},id:{type:String,default:void 0},border:Boolean,size:r.mU,tabindex:[String,Number],validateEvent:{type:Boolean,default:!0},ariaLabel:String,...(0,s.l)(["ariaControls"])},f={[i.l4]:e=>(0,o.Kg)(e)||(0,u.Et)(e)||(0,u.Lm)(e),change:e=>(0,o.Kg)(e)||(0,u.Et)(e)||(0,u.Lm)(e)};var p=l(9077);l(4114);const m=Symbol("checkboxGroupContextKey");var v=l(7254),h=l(2436);const g=({model:e,isChecked:t})=>{const l=(0,n.WQ)(m,void 0),a=(0,n.WQ)(v.F,void 0),o=(0,n.EW)(()=>{var n,a;const o=null==(n=null==l?void 0:l.max)?void 0:n.value,c=null==(a=null==l?void 0:l.min)?void 0:a.value;return!(0,u.b0)(o)&&e.value.length>=o&&!t.value||!(0,u.b0)(c)&&e.value.length<=c&&t.value}),c=(0,h.CB)((0,n.EW)(()=>{var e,t;return void 0===l?null!=(e=null==a?void 0:a.disabled)?e:o.value:(null==(t=l.disabled)?void 0:t.value)||o.value}));return{isDisabled:c,isLimitDisabled:o}};l(8111),l(3579);var b=l(4216),y=l(6894);const C=(e,{model:t,isLimitExceeded:l,hasOwnLabel:a,isDisabled:o,isLabeledByFormItem:c})=>{const r=(0,n.WQ)(m,void 0),{formItem:s}=(0,b.j)(),{emit:u}=(0,n.nI)();function d(t){var l,n,a,o;return[!0,e.trueValue,e.trueLabel].includes(t)?null==(n=null!=(l=e.trueValue)?l:e.trueLabel)||n:null!=(o=null!=(a=e.falseValue)?a:e.falseLabel)&&o}function f(e,t){u(i.YU,d(e),t)}function p(e){if(l.value)return;const t=e.target;u(i.YU,d(t.checked),e)}async function v(r){if(!l.value&&!a.value&&!o.value&&c.value){const l=r.composedPath(),a=l.some(e=>"LABEL"===e.tagName);a||(t.value=d([!1,e.falseValue,e.falseLabel].includes(t.value)),await(0,n.dY)(),f(t.value,r))}}const h=(0,n.EW)(()=>(null==r?void 0:r.validateEvent)||e.validateEvent);return(0,n.wB)(()=>e.modelValue,()=>{h.value&&(null==s||s.validate("change").catch(e=>(0,y.U)(e)))}),{handleChange:p,onClickRoot:v}},w=e=>{const t=(0,a.KR)(!1),{emit:l}=(0,n.nI)(),c=(0,n.WQ)(m,void 0),r=(0,n.EW)(()=>!1===(0,u.b0)(c)),s=(0,a.KR)(!1),d=(0,n.EW)({get(){var l,n;return r.value?null==(l=null==c?void 0:c.modelValue)?void 0:l.value:null!=(n=e.modelValue)?n:t.value},set(e){var n,a;r.value&&(0,o.cy)(e)?(s.value=void 0!==(null==(n=null==c?void 0:c.max)?void 0:n.value)&&e.length>(null==c?void 0:c.max.value)&&e.length>d.value.length,!1===s.value&&(null==(a=null==c?void 0:c.changeEvent)||a.call(c,e))):(l(i.l4,e),t.value=e)}});return{model:d,isGroup:r,isLimitExceeded:s}};l(1701);var L=l(9195);const x=(e,t,{model:l})=>{const c=(0,n.WQ)(m,void 0),r=(0,a.KR)(!1),s=(0,n.EW)(()=>(0,u.Xj)(e.value)?e.label:e.value),i=(0,n.EW)(()=>{const t=l.value;return(0,u.Lm)(t)?t:(0,o.cy)(t)?(0,o.Gv)(s.value)?t.map(a.ux).some(e=>(0,L.A)(e,s.value)):t.map(a.ux).includes(s.value):null!==t&&void 0!==t?t===e.trueValue||t===e.trueLabel:!!t}),d=(0,h.NV)((0,n.EW)(()=>{var e;return null==(e=null==c?void 0:c.size)?void 0:e.value}),{prop:!0}),f=(0,h.NV)((0,n.EW)(()=>{var e;return null==(e=null==c?void 0:c.size)?void 0:e.value})),p=(0,n.EW)(()=>!!t.default||!(0,u.Xj)(s.value));return{checkboxButtonSize:d,isChecked:i,isFocused:r,checkboxSize:f,hasOwnLabel:p,actualValue:s}};var M=l(261);const z=(e,t)=>{const{formItem:l}=(0,b.j)(),{model:a,isGroup:c,isLimitExceeded:r}=w(e),{isFocused:s,isChecked:i,checkboxButtonSize:d,checkboxSize:f,hasOwnLabel:p,actualValue:m}=x(e,t,{model:a}),{isDisabled:v}=g({model:a,isChecked:i}),{inputId:h,isLabeledByFormItem:y}=(0,b.W)(e,{formItemContext:l,disableIdGeneration:p,disableIdManagement:c}),{handleChange:L,onClickRoot:z}=C(e,{model:a,isLimitExceeded:r,hasOwnLabel:p,isDisabled:v,isLabeledByFormItem:y}),R=()=>{function t(){var t,l;(0,o.cy)(a.value)&&!a.value.includes(m.value)?a.value.push(m.value):a.value=null==(l=null!=(t=e.trueValue)?t:e.trueLabel)||l}e.checked&&t()};return R(),(0,M.b)({from:"label act as value",replacement:"value",version:"3.0.0",scope:"el-checkbox",ref:"https://element-plus.org/en-US/component/checkbox.html"},(0,n.EW)(()=>c.value&&(0,u.Xj)(e.value))),(0,M.b)({from:"true-label",replacement:"true-value",version:"3.0.0",scope:"el-checkbox",ref:"https://element-plus.org/en-US/component/checkbox.html"},(0,n.EW)(()=>!!e.trueLabel)),(0,M.b)({from:"false-label",replacement:"false-value",version:"3.0.0",scope:"el-checkbox",ref:"https://element-plus.org/en-US/component/checkbox.html"},(0,n.EW)(()=>!!e.falseLabel)),{inputId:h,isLabeledByFormItem:y,isChecked:i,isDisabled:v,isFocused:s,checkboxButtonSize:d,checkboxSize:f,hasOwnLabel:p,model:a,actualValue:m,handleChange:L,onClickRoot:z}};var R=l(3513);const k=(0,n.pM)({name:"ElCheckbox"}),S=(0,n.pM)({...k,props:d,emits:f,setup(e){const t=e,l=(0,n.Ht)(),{inputId:r,isLabeledByFormItem:s,isChecked:i,isDisabled:u,isFocused:d,checkboxSize:f,hasOwnLabel:p,model:m,actualValue:v,handleChange:h,onClickRoot:g}=z(t,l),b=(0,n.EW)(()=>{var e,l,n,a;return t.trueValue||t.falseValue||t.trueLabel||t.falseLabel?{"true-value":null==(l=null!=(e=t.trueValue)?e:t.trueLabel)||l,"false-value":null!=(a=null!=(n=t.falseValue)?n:t.falseLabel)&&a}:{value:v.value}}),y=(0,R.DU)("checkbox"),C=(0,n.EW)(()=>[y.b(),y.m(f.value),y.is("disabled",u.value),y.is("bordered",t.border),y.is("checked",i.value)]),w=(0,n.EW)(()=>[y.e("input"),y.is("disabled",u.value),y.is("checked",i.value),y.is("indeterminate",t.indeterminate),y.is("focus",d.value)]);return(e,t)=>((0,n.uX)(),(0,n.Wv)((0,n.$y)(!(0,a.R1)(p)&&(0,a.R1)(s)?"span":"label"),{for:!(0,a.R1)(p)&&(0,a.R1)(s)?null:(0,a.R1)(r),class:(0,o.C4)((0,a.R1)(C)),"aria-controls":e.indeterminate?e.ariaControls:null,"aria-checked":e.indeterminate?"mixed":void 0,"aria-label":e.ariaLabel,onClick:(0,a.R1)(g)},{default:(0,n.k6)(()=>[(0,n.Lk)("span",{class:(0,o.C4)((0,a.R1)(w))},[(0,n.bo)((0,n.Lk)("input",(0,n.v6)({id:(0,a.R1)(r),"onUpdate:modelValue":e=>(0,a.i9)(m)?m.value=e:null,class:(0,a.R1)(y).e("original"),type:"checkbox",indeterminate:e.indeterminate,name:e.name,tabindex:e.tabindex,disabled:(0,a.R1)(u)},(0,a.R1)(b),{onChange:(0,a.R1)(h),onFocus:e=>d.value=!0,onBlur:e=>d.value=!1,onClick:(0,c.D$)(()=>{},["stop"])}),null,16,["id","onUpdate:modelValue","indeterminate","name","tabindex","disabled","onChange","onFocus","onBlur","onClick"]),[[c.lH,(0,a.R1)(m)]]),(0,n.Lk)("span",{class:(0,o.C4)((0,a.R1)(y).e("inner"))},null,2)],2),(0,a.R1)(p)?((0,n.uX)(),(0,n.CE)("span",{key:0,class:(0,o.C4)((0,a.R1)(y).e("label"))},[(0,n.RG)(e.$slots,"default"),e.$slots.default?(0,n.Q3)("v-if",!0):((0,n.uX)(),(0,n.CE)(n.FK,{key:0},[(0,n.eW)((0,o.v_)(e.label),1)],64))],2)):(0,n.Q3)("v-if",!0)]),_:3},8,["for","class","aria-controls","aria-checked","aria-label","onClick"]))}});var E=(0,p.A)(S,[["__file","checkbox.vue"]]);const A=(0,n.pM)({name:"ElCheckboxButton"}),N=(0,n.pM)({...A,props:d,emits:f,setup(e){const t=e,l=(0,n.Ht)(),{isFocused:r,isChecked:s,isDisabled:i,checkboxButtonSize:u,model:d,actualValue:f,handleChange:p}=z(t,l),v=(0,n.EW)(()=>{var e,l,n,a;return t.trueValue||t.falseValue||t.trueLabel||t.falseLabel?{"true-value":null==(l=null!=(e=t.trueValue)?e:t.trueLabel)||l,"false-value":null!=(a=null!=(n=t.falseValue)?n:t.falseLabel)&&a}:{value:f.value}}),h=(0,n.WQ)(m,void 0),g=(0,R.DU)("checkbox"),b=(0,n.EW)(()=>{var e,t,l,n;const a=null!=(t=null==(e=null==h?void 0:h.fill)?void 0:e.value)?t:"";return{backgroundColor:a,borderColor:a,color:null!=(n=null==(l=null==h?void 0:h.textColor)?void 0:l.value)?n:"",boxShadow:a?`-1px 0 0 0 ${a}`:void 0}}),y=(0,n.EW)(()=>[g.b("button"),g.bm("button",u.value),g.is("disabled",i.value),g.is("checked",s.value),g.is("focus",r.value)]);return(e,t)=>((0,n.uX)(),(0,n.CE)("label",{class:(0,o.C4)((0,a.R1)(y))},[(0,n.bo)((0,n.Lk)("input",(0,n.v6)({"onUpdate:modelValue":e=>(0,a.i9)(d)?d.value=e:null,class:(0,a.R1)(g).be("button","original"),type:"checkbox",name:e.name,tabindex:e.tabindex,disabled:(0,a.R1)(i)},(0,a.R1)(v),{onChange:(0,a.R1)(p),onFocus:e=>r.value=!0,onBlur:e=>r.value=!1,onClick:(0,c.D$)(()=>{},["stop"])}),null,16,["onUpdate:modelValue","name","tabindex","disabled","onChange","onFocus","onBlur","onClick"]),[[c.lH,(0,a.R1)(d)]]),e.$slots.default||e.label?((0,n.uX)(),(0,n.CE)("span",{key:0,class:(0,o.C4)((0,a.R1)(g).be("button","inner")),style:(0,o.Tr)((0,a.R1)(s)?(0,a.R1)(b):void 0)},[(0,n.RG)(e.$slots,"default",{},()=>[(0,n.eW)((0,o.v_)(e.label),1)])],6)):(0,n.Q3)("v-if",!0)],2))}});var _=(0,p.A)(N,[["__file","checkbox-button.vue"]]),T=l(1074),O=l(1996),W=l(7378);const B=(0,W.b_)({modelValue:{type:(0,W.jq)(Array),default:()=>[]},disabled:{type:Boolean,default:void 0},min:Number,max:Number,size:r.mU,fill:String,textColor:String,tag:{type:String,default:"div"},validateEvent:{type:Boolean,default:!0},options:{type:(0,W.jq)(Array)},props:{type:(0,W.jq)(Object),default:()=>D},type:{type:String,values:["checkbox","button"],default:"checkbox"},...(0,s.l)(["ariaLabel"])}),I={[i.l4]:e=>(0,o.cy)(e),change:e=>(0,o.cy)(e)},D={label:"label",value:"value",disabled:"disabled"},F=(0,n.pM)({name:"ElCheckboxGroup"}),V=(0,n.pM)({...F,props:B,emits:I,setup(e,{emit:t}){const l=e,c=(0,R.DU)("checkbox"),r=(0,h.CB)(),{formItem:s}=(0,b.j)(),{inputId:u,isLabeledByFormItem:d}=(0,b.W)(l,{formItemContext:s}),f=async e=>{t(i.l4,e),await(0,n.dY)(),t(i.YU,e)},p=(0,n.EW)({get(){return l.modelValue},set(e){f(e)}}),v=(0,n.EW)(()=>({...D,...l.props})),g=e=>{const{label:t,value:l,disabled:n}=v.value,a={label:e[t],value:e[l],disabled:e[n]};return{...(0,T.A)(e,[t,l,n]),...a}},C=(0,n.EW)(()=>"button"===l.type?_:E);return(0,n.Gt)(m,{...(0,O.A)((0,a.QW)(l),["size","min","max","validateEvent","fill","textColor"]),disabled:r,modelValue:p,changeEvent:f}),(0,n.wB)(()=>l.modelValue,(e,t)=>{l.validateEvent&&!(0,L.A)(e,t)&&(null==s||s.validate("change").catch(e=>(0,y.U)(e)))}),(e,t)=>{var l;return(0,n.uX)(),(0,n.Wv)((0,n.$y)(e.tag),{id:(0,a.R1)(u),class:(0,o.C4)((0,a.R1)(c).b("group")),role:"group","aria-label":(0,a.R1)(d)?void 0:e.ariaLabel||"checkbox-group","aria-labelledby":(0,a.R1)(d)?null==(l=(0,a.R1)(s))?void 0:l.labelId:void 0},{default:(0,n.k6)(()=>[(0,n.RG)(e.$slots,"default",{},()=>[((0,n.uX)(!0),(0,n.CE)(n.FK,null,(0,n.pI)(e.options,(e,t)=>((0,n.uX)(),(0,n.Wv)((0,n.$y)((0,a.R1)(C)),(0,n.v6)({key:t},g(e)),null,16))),128))])]),_:3},8,["id","class","aria-label","aria-labelledby"])}}});var P=(0,p.A)(V,[["__file","checkbox-group.vue"]]),$=l(5376);const H=(0,$.GU)(E,{CheckboxButton:_,CheckboxGroup:P}),j=(0,$.WM)(_),K=(0,$.WM)(P)},851:function(e,t,l){"use strict";var n=l(6955),a=l(5966),o=l(4117),c=l(6269),r=l(8227),s=r("iterator");e.exports=function(e){if(!o(e))return a(e,s)||a(e,"@@iterator")||c[n(e)]}},944:function(e){"use strict";var t=TypeError;e.exports=function(e){var l=e&&e.alphabet;if(void 0===l||"base64"===l||"base64url"===l)return l||"base64";throw new t("Incorrect `alphabet` option")}},971:function(e,t,l){"use strict";l.d(t,{IO:function(){return a},xt:function(){return c},yt:function(){return o}});var n=l(6768);const a=Symbol("elForwardRef"),o=e=>{const t=t=>{e.value=t};(0,n.Gt)(a,{setForwardRef:t})},c=e=>({mounted(t){e(t)},updated(t){e(t)},unmounted(){e(null)}})},1018:function(e,t,l){"use strict";var n=l(5061),a=l(6841),o=Object.prototype,c=o.hasOwnProperty;function r(e,t,l){var o=e[t];c.call(e,t)&&(0,a.A)(o,l)&&(void 0!==l||t in e)||(0,n.A)(e,t,l)}t.A=r},1072:function(e,t,l){"use strict";var n=l(1828),a=l(8727);e.exports=Object.keys||function(e){return n(e,a)}},1074:function(e,t,l){"use strict";l.d(t,{A:function(){return R}});var n=l(5347),a=l(7529),o=l(5014);function c(e){var t=null==e?0:e.length;return t?e[t-1]:void 0}var r=c,s=l(2623);function i(e,t,l){var n=-1,a=e.length;t<0&&(t=-t>a?0:a+t),l=l>a?a:l,l<0&&(l+=a),a=t>l?0:l-t>>>0,t>>>=0;var o=Array(a);while(++n1),t}),(0,h.A)(e,(0,w.A)(e),l),c&&(l=(0,a.A)(l,L|x|M,y));var r=t.length;while(r--)v(l,t[r]);return l}),R=z},1095:function(e,t,l){"use strict";l.d(t,{vp:function(){return L},WZ:function(){return x}});var n=l(6768),a=l(144),o=l(4232);const c=Symbol("breadcrumbKey");var r=l(7378),s=l(464);const i=(0,r.b_)({separator:{type:String,default:"/"},separatorIcon:{type:s.Ze}});var u=l(9077),d=l(6268),f=l(3513);const p=(0,n.pM)({name:"ElBreadcrumb"}),m=(0,n.pM)({...p,props:i,setup(e){const t=e,{t:l}=(0,d.Ym)(),r=(0,f.DU)("breadcrumb"),s=(0,a.KR)();return(0,n.Gt)(c,t),(0,n.sV)(()=>{const e=s.value.querySelectorAll(`.${r.e("item")}`);e.length&&e[e.length-1].setAttribute("aria-current","page")}),(e,t)=>((0,n.uX)(),(0,n.CE)("div",{ref_key:"breadcrumb",ref:s,class:(0,o.C4)((0,a.R1)(r).b()),"aria-label":(0,a.R1)(l)("el.breadcrumb.label"),role:"navigation"},[(0,n.RG)(e.$slots,"default")],10,["aria-label"]))}});var v=(0,u.A)(m,[["__file","breadcrumb.vue"]]),h=(l(4114),l(813));const g=(0,r.b_)({to:{type:(0,r.jq)([String,Object]),default:""},replace:Boolean}),b=(0,n.pM)({name:"ElBreadcrumbItem"}),y=(0,n.pM)({...b,props:g,setup(e){const t=e,l=(0,n.nI)(),r=(0,n.WQ)(c,void 0),s=(0,f.DU)("breadcrumb"),i=l.appContext.config.globalProperties.$router,u=(0,a.KR)(),d=()=>{t.to&&i&&(t.replace?i.replace(t.to):i.push(t.to))};return(e,t)=>{var l,c;return(0,n.uX)(),(0,n.CE)("span",{class:(0,o.C4)((0,a.R1)(s).e("item"))},[(0,n.Lk)("span",{ref_key:"link",ref:u,class:(0,o.C4)([(0,a.R1)(s).e("inner"),(0,a.R1)(s).is("link",!!e.to)]),role:"link",onClick:d},[(0,n.RG)(e.$slots,"default")],2),(null==(l=(0,a.R1)(r))?void 0:l.separatorIcon)?((0,n.uX)(),(0,n.Wv)((0,a.R1)(h.tk),{key:0,class:(0,o.C4)((0,a.R1)(s).e("separator"))},{default:(0,n.k6)(()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)((0,a.R1)(r).separatorIcon)))]),_:1},8,["class"])):((0,n.uX)(),(0,n.CE)("span",{key:1,class:(0,o.C4)((0,a.R1)(s).e("separator")),role:"presentation"},(0,o.v_)(null==(c=(0,a.R1)(r))?void 0:c.separator),3))],2)}}});var C=(0,u.A)(y,[["__file","breadcrumb-item.vue"]]),w=l(5376);const L=(0,w.GU)(v,{BreadcrumbItem:C}),x=(0,w.WM)(C)},1108:function(e,t,l){"use strict";var n=l(6955);e.exports=function(e){var t=n(e);return"BigInt64Array"===t||"BigUint64Array"===t}},1120:function(e,t,l){"use strict";l.d(t,{A:function(){return f}});var n=l(9578);function a(){return!1}var o=a,c="object"==typeof exports&&exports&&!exports.nodeType&&exports,r=c&&"object"==typeof module&&module&&!module.nodeType&&module,s=r&&r.exports===c,i=s?n.A.Buffer:void 0,u=i?i.isBuffer:void 0,d=u||o,f=d},1125:function(e,t,l){"use strict";var n=l(3925),a=String,o=TypeError;e.exports=function(e){if(n(e))return e;throw new o("Can't set "+a(e)+" as a prototype")}},1148:function(e,t,l){"use strict";var n=l(6518),a=l(9565),o=l(2652),c=l(9306),r=l(8551),s=l(1767),i=l(9539),u=l(4549),d=u("every",TypeError);n({target:"Iterator",proto:!0,real:!0,forced:d},{every:function(e){r(this);try{c(e)}catch(n){i(this,"throw",n)}if(d)return a(d,this,e);var t=s(this),l=0;return!o(t,function(t,n){if(!e(t,l++))return n()},{IS_RECORD:!0,INTERRUPTED:!0}).stopped}})},1154:function(e,t){"use strict";function l(e){var t=-1,l=null==e?0:e.length,n={};while(++t!0},C=(0,o.Gc)({}),w=e=>(C[e]||(C[e]=(0,o.Gc)([])),C[e]),L=(e,t)=>{const l=C[t]||[],n=l.findIndex(t=>t.id===e),a=l[n];let o;return n>0&&(o=l[n-1]),{current:a,prev:o}},x=(e,t)=>{const{prev:l}=L(e,t);return l?l.vm.exposed.bottom.value:0},M=(e,t,l)=>{const n=C[l]||[],a=n.findIndex(t=>t.id===e);return a>0?16:t};var z=l(9077),R=l(8114),k=l(4225),S=l(515);const E=(0,n.pM)({name:"ElMessage"}),A=(0,n.pM)({...E,props:b,emits:y,setup(e,{expose:t,emit:l}){const d=e,{Close:p}=f.Nk,m=(0,o.KR)(!1),{ns:v,zIndex:g}=(0,R.ht)("message"),{currentZIndex:b,nextZIndex:y}=g,C=(0,o.KR)(),w=(0,o.KR)(!1),L=(0,o.KR)(0);let z;const E=(0,n.EW)(()=>d.type?"error"===d.type?"danger":d.type:"info"),A=(0,n.EW)(()=>{const e=d.type;return{[v.bm("icon",e)]:e&&f.rz[e]}}),N=(0,n.EW)(()=>d.icon||f.rz[d.type]||""),_=(0,n.EW)(()=>d.placement||h),T=(0,n.EW)(()=>x(d.id,_.value)),O=(0,n.EW)(()=>M(d.id,d.offset,_.value)+T.value),W=(0,n.EW)(()=>L.value+O.value),B=(0,n.EW)(()=>_.value.includes("left")?v.is("left"):_.value.includes("right")?v.is("right"):v.is("center")),I=(0,n.EW)(()=>_.value.startsWith("top")?"top":"bottom"),D=(0,n.EW)(()=>({[I.value]:`${O.value}px`,zIndex:b.value}));function F(){0!==d.duration&&({stop:z}=(0,r.TO)(()=>{P()},d.duration))}function V(){null==z||z()}function P(){w.value=!1,(0,n.dY)(()=>{var e;m.value||(null==(e=d.onClose)||e.call(d),l("destroy"))})}function $(e){const t=(0,k.CG)(e);t===S.R.esc&&P()}return(0,n.sV)(()=>{F(),y(),w.value=!0}),(0,n.wB)(()=>d.repeatNum,()=>{V(),F()}),(0,s.MLh)(document,"keydown",$),(0,s.wYm)(C,()=>{L.value=C.value.getBoundingClientRect().height}),t({visible:w,bottom:W,close:P}),(e,t)=>((0,n.uX)(),(0,n.Wv)(a.eB,{name:(0,o.R1)(v).b("fade"),onBeforeEnter:e=>m.value=!0,onBeforeLeave:e.onClose,onAfterLeave:t=>e.$emit("destroy"),persisted:""},{default:(0,n.k6)(()=>[(0,n.bo)((0,n.Lk)("div",{id:e.id,ref_key:"messageRef",ref:C,class:(0,c.C4)([(0,o.R1)(v).b(),{[(0,o.R1)(v).m(e.type)]:e.type},(0,o.R1)(v).is("closable",e.showClose),(0,o.R1)(v).is("plain",e.plain),(0,o.R1)(v).is("bottom","bottom"===(0,o.R1)(I)),(0,o.R1)(B),e.customClass]),style:(0,c.Tr)((0,o.R1)(D)),role:"alert",onMouseenter:V,onMouseleave:F},[e.repeatNum>1?((0,n.uX)(),(0,n.Wv)((0,o.R1)(i.z_),{key:0,value:e.repeatNum,type:(0,o.R1)(E),class:(0,c.C4)((0,o.R1)(v).e("badge"))},null,8,["value","type","class"])):(0,n.Q3)("v-if",!0),(0,o.R1)(N)?((0,n.uX)(),(0,n.Wv)((0,o.R1)(u.tk),{key:1,class:(0,c.C4)([(0,o.R1)(v).e("icon"),(0,o.R1)(A)])},{default:(0,n.k6)(()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)((0,o.R1)(N))))]),_:1},8,["class"])):(0,n.Q3)("v-if",!0),(0,n.RG)(e.$slots,"default",{},()=>[e.dangerouslyUseHTMLString?((0,n.uX)(),(0,n.CE)(n.FK,{key:1},[(0,n.Q3)(" Caution here, message could've been compromised, never use user's input as message "),(0,n.Lk)("p",{class:(0,c.C4)((0,o.R1)(v).e("content")),innerHTML:e.message},null,10,["innerHTML"])],2112)):((0,n.uX)(),(0,n.CE)("p",{key:0,class:(0,c.C4)((0,o.R1)(v).e("content"))},(0,c.v_)(e.message),3))]),e.showClose?((0,n.uX)(),(0,n.Wv)((0,o.R1)(u.tk),{key:2,class:(0,c.C4)((0,o.R1)(v).e("closeBtn")),onClick:(0,a.D$)(P,["stop"])},{default:(0,n.k6)(()=>[(0,n.bF)((0,o.R1)(p))]),_:1},8,["class","onClick"])):(0,n.Q3)("v-if",!0)],46,["id"]),[[a.aG,w.value]])]),_:3},8,["name","onBeforeEnter","onBeforeLeave","onAfterLeave"]))}});var N=(0,z.A)(A,[["__file","message.vue"]]),_=l(1588),T=l(2235),O=l(6894);let W=1;const B=e=>{const t=e.appendTo;if(t){if((0,c.Kg)(e.appendTo)){let t=document.querySelector(e.appendTo);(0,T.vq)(t)||((0,O.U)("ElMessage","the appendTo option is not an HTMLElement. Falling back to document.body."),t=document.body),e.appendTo=t}}else e.appendTo=document.body},I=e=>{!e.placement&&(0,c.Kg)(_.k.placement)&&_.k.placement&&(e.placement=_.k.placement),e.placement||(e.placement=h),v.includes(e.placement)||((0,O.U)("ElMessage",`Invalid placement: ${e.placement}. Falling back to '${h}'.`),e.placement=h)},D=e=>{const t=!e||(0,c.Kg)(e)||(0,n.vv)(e)||(0,c.Tn)(e)?{message:e}:e,l={...g,...t};return B(l),I(l),(0,T.Lm)(_.k.grouping)&&!l.grouping&&(l.grouping=_.k.grouping),(0,T.Et)(_.k.duration)&&3e3===l.duration&&(l.duration=_.k.duration),(0,T.Et)(_.k.offset)&&16===l.offset&&(l.offset=_.k.offset),(0,T.Lm)(_.k.showClose)&&!l.showClose&&(l.showClose=_.k.showClose),(0,T.Lm)(_.k.plain)&&!l.plain&&(l.plain=_.k.plain),l},F=e=>{const t=e.props.placement||h,l=C[t],n=l.indexOf(e);if(-1===n)return;l.splice(n,1);const{handler:a}=e;a.close()},V=({appendTo:e,...t},l)=>{const o="message_"+W++,r=t.onClose,s=document.createElement("div"),i={...t,id:o,onClose:()=>{null==r||r(),F(p)},onDestroy:()=>{(0,a.XX)(null,s)}},u=(0,n.bF)(N,i,(0,c.Tn)(i.message)||(0,n.vv)(i.message)?{default:(0,c.Tn)(i.message)?i.message:()=>i.message}:null);u.appContext=l||P._context,(0,a.XX)(u,s),e.appendChild(s.firstElementChild);const d=u.component,f={close:()=>{d.exposed.close()}},p={id:o,vnode:u,vm:d,handler:f,props:u.component.props};return p},P=(e={},t)=>{if(!r.oc)return{close:()=>{}};const l=D(e),n=w(l.placement||h);if(l.grouping&&n.length){const e=n.find(({vnode:e})=>{var t;return(null==(t=e.props)?void 0:t.message)===l.message});if(e)return e.props.repeatNum+=1,e.props.type=l.type,e.handler}if((0,T.Et)(_.k.max)&&n.length>=_.k.max)return{close:()=>{}};const a=V(l,t);return n.push(a),a.handler};function $(e){for(const t in C)if((0,c.$3)(C,t)){const l=[...C[t]];for(const t of l)e&&e!==t.props.type||t.handler.close()}}function H(e){if(!C[e])return;const t=[...C[e]];t.forEach(e=>e.handler.close())}m.forEach(e=>{P[e]=(t={},l)=>{const n=D(t);return P({...n,type:e},l)}}),P.closeAll=$,P.closeAllByPlacement=H,P._context=null;var j=l(5376);const K=(0,j._u)(P,"$message")},1241:function(e,t){"use strict";t.A=(e,t)=>{const l=e.__vccOpts||e;for(const[n,a]of t)l[n]=a;return l}},1254:function(e,t,l){"use strict";l.d(t,{A:function(){return u}});var n=l(168),a=Object.create,o=function(){function e(){}return function(t){if(!(0,n.A)(t))return{};if(a)return a(t);e.prototype=t;var l=new e;return e.prototype=void 0,l}}(),c=o,r=l(9092),s=l(729);function i(e){return"function"!=typeof e.constructor||(0,s.A)(e)?{}:c((0,r.A)(e))}var u=i},1291:function(e,t,l){"use strict";var n=l(741);e.exports=function(e){var t=+e;return t!==t||0===t?0:n(t)}},1305:function(e,t,l){"use strict";l.d(t,{Bi:function(){return d},Sj:function(){return u}});var n=l(6768),a=l(144),o=l(17),c=l(3513),r=l(6894);const s={prefix:Math.floor(1e4*Math.random()),current:0},i=Symbol("elIdInjection"),u=()=>(0,n.nI)()?(0,n.WQ)(i,s):s,d=e=>{const t=u();o.oc||t!==s||(0,r.U)("IdInjection","Looks like you are using server rendering, you must provide a id provider to ensure the hydration process to be succeed\nusage: app.provide(ID_INJECTION_KEY, {\n prefix: number,\n current: number,\n})");const l=(0,c.E9)(),n=(0,o.AI)(()=>(0,a.R1)(e)||`${l.value}-id-${t.prefix}-${t.current++}`);return n}},1385:function(e,t,l){"use strict";var n=l(9539);e.exports=function(e,t,l){for(var a=e.length-1;a>=0;a--)if(void 0!==e[a])try{l=n(e[a].iterator,t,l)}catch(o){t="throw",l=o}if("throw"===t)throw l;return l}},1418:function(e,t,l){"use strict";l.d(t,{lq:function(){return N}});var n=l(6768),a=l(144),o=l(4232),c=l(5130),r=l(6032),s=l(9623),i=l(813),u=l(7477),d=l(7378),f=l(3845),p=l(2235),m=l(8501),v=l(2056);const h=(0,d.b_)({id:{type:String,default:void 0},step:{type:Number,default:1},stepStrictly:Boolean,max:{type:Number,default:Number.MAX_SAFE_INTEGER},min:{type:Number,default:Number.MIN_SAFE_INTEGER},modelValue:{type:[Number,null]},readonly:Boolean,disabled:{type:Boolean,default:void 0},size:f.mU,controls:{type:Boolean,default:!0},controlsPosition:{type:String,default:"",values:["","right"]},valueOnClear:{type:[String,Number,null],validator:e=>null===e||(0,p.Et)(e)||["min","max"].includes(e),default:null},name:String,placeholder:String,precision:{type:Number,validator:e=>e>=0&&e===Number.parseInt(`${e}`,10)},validateEvent:{type:Boolean,default:!0},...(0,m.l)(["ariaLabel"]),inputmode:{type:(0,d.jq)(String),default:void 0},align:{type:(0,d.jq)(String),default:"center"},disabledScientific:Boolean}),g={[v.YU]:(e,t)=>t!==e,blur:e=>e instanceof FocusEvent,focus:e=>e instanceof FocusEvent,[v.qs]:e=>(0,p.Et)(e)||(0,r.A)(e),[v.l4]:e=>(0,p.Et)(e)||(0,r.A)(e)};var b=l(9077),y=l(4436),C=l(4225),w=l(6268),L=l(3513),x=l(4216),M=l(6894),z=l(2436),R=l(515);const k=(0,n.pM)({name:"ElInputNumber"}),S=(0,n.pM)({...k,props:h,emits:g,setup(e,{expose:t,emit:l}){const d=e,{t:f}=(0,w.Ym)(),m=(0,L.DU)("input-number"),h=(0,a.KR)(),g=(0,a.Kh)({currentValue:d.modelValue,userInput:null}),{formItem:b}=(0,x.j)(),k=(0,n.EW)(()=>(0,p.Et)(d.modelValue)&&d.modelValue<=d.min),S=(0,n.EW)(()=>(0,p.Et)(d.modelValue)&&d.modelValue>=d.max),E=(0,n.EW)(()=>{const e=W(d.step);return(0,p.b0)(d.precision)?Math.max(W(d.modelValue),e):(e>d.precision&&(0,M.U)("InputNumber","precision should not be less than the decimal places of step"),d.precision)}),A=(0,n.EW)(()=>d.controls&&"right"===d.controlsPosition),N=(0,z.NV)(),_=(0,z.CB)(),T=(0,n.EW)(()=>{if(null!==g.userInput)return g.userInput;let e=g.currentValue;if((0,r.A)(e))return"";if((0,p.Et)(e)){if(Number.isNaN(e))return"";(0,p.b0)(d.precision)||(e=e.toFixed(d.precision))}return e}),O=(e,t)=>{if((0,p.b0)(t)&&(t=E.value),0===t)return Math.round(e);let l=String(e);const n=l.indexOf(".");if(-1===n)return e;const a=l.replace(".","").split(""),o=a[n+t];if(!o)return e;const c=l.length;return"5"===l.charAt(c-1)&&(l=`${l.slice(0,Math.max(0,c-1))}6`),Number.parseFloat(Number(l).toFixed(t))},W=e=>{if((0,r.A)(e))return 0;const t=e.toString(),l=t.indexOf(".");let n=0;return-1!==l&&(n=t.length-l-1),n},B=(e,t=1)=>(0,p.Et)(e)?e>=Number.MAX_SAFE_INTEGER&&1===t?((0,M.U)("InputNumber","The value has reached the maximum safe integer limit."),e):e<=Number.MIN_SAFE_INTEGER&&-1===t?((0,M.U)("InputNumber","The value has reached the minimum safe integer limit."),e):O(e+d.step*t):g.currentValue,I=e=>{const t=(0,C.CG)(e),l=(0,C.K)(e);if(d.disabledScientific&&["e","E"].includes(l))e.preventDefault();else switch(t){case R.R.up:e.preventDefault(),D();break;case R.R.down:e.preventDefault(),F();break}},D=()=>{if(d.readonly||_.value||S.value)return;const e=Number(T.value)||0,t=B(e);P(t),l(v.qs,g.currentValue),q()},F=()=>{if(d.readonly||_.value||k.value)return;const e=Number(T.value)||0,t=B(e,-1);P(t),l(v.qs,g.currentValue),q()},V=(e,t)=>{const{max:n,min:a,step:c,precision:s,stepStrictly:i,valueOnClear:u}=d;nn||fn?n:a,t&&l(v.l4,f)),f},P=(e,t=!0)=>{var n;const a=g.currentValue,o=V(e);t?(g.userInput=null,a===o&&e||(l(v.l4,o),a!==o&&l(v.YU,o,a),d.validateEvent&&(null==(n=null==b?void 0:b.validate)||n.call(b,"change").catch(e=>(0,M.U)(e))),g.currentValue=o)):l(v.l4,o)},$=e=>{g.userInput=e;const t=""===e?null:Number(e);l(v.qs,t),P(t,!1)},H=e=>{const t=""!==e?Number(e):"";((0,p.Et)(t)&&!Number.isNaN(t)||""===e)&&P(t),q(),g.userInput=null},j=()=>{var e,t;null==(t=null==(e=h.value)?void 0:e.focus)||t.call(e)},K=()=>{var e,t;null==(t=null==(e=h.value)?void 0:e.blur)||t.call(e)},X=e=>{l("focus",e)},U=e=>{var t,n;g.userInput=null,null===g.currentValue&&(null==(t=h.value)?void 0:t.input)&&(h.value.input.value=""),l("blur",e),d.validateEvent&&(null==(n=null==b?void 0:b.validate)||n.call(b,"blur").catch(e=>(0,M.U)(e)))},q=()=>{g.currentValue!==d.modelValue&&(g.currentValue=d.modelValue)},G=e=>{document.activeElement===e.target&&e.preventDefault()};return(0,n.wB)(()=>d.modelValue,(e,t)=>{const l=V(e,!0);null===g.userInput&&l!==t&&(g.currentValue=l)},{immediate:!0}),(0,n.wB)(()=>d.precision,()=>{g.currentValue=V(d.modelValue)}),(0,n.sV)(()=>{var e;const{min:t,max:n,modelValue:a}=d,o=null==(e=h.value)?void 0:e.input;if(o.setAttribute("role","spinbutton"),Number.isFinite(n)?o.setAttribute("aria-valuemax",String(n)):o.removeAttribute("aria-valuemax"),Number.isFinite(t)?o.setAttribute("aria-valuemin",String(t)):o.removeAttribute("aria-valuemin"),o.setAttribute("aria-valuenow",g.currentValue||0===g.currentValue?String(g.currentValue):""),o.setAttribute("aria-disabled",String(_.value)),!(0,p.Et)(a)&&null!=a){let e=Number(a);Number.isNaN(e)&&(e=null),l(v.l4,e)}o.addEventListener("wheel",G,{passive:!1})}),(0,n.$u)(()=>{var e,t;const l=null==(e=h.value)?void 0:e.input;null==l||l.setAttribute("aria-valuenow",`${null!=(t=g.currentValue)?t:""}`)}),t({focus:j,blur:K}),(e,t)=>((0,n.uX)(),(0,n.CE)("div",{class:(0,o.C4)([(0,a.R1)(m).b(),(0,a.R1)(m).m((0,a.R1)(N)),(0,a.R1)(m).is("disabled",(0,a.R1)(_)),(0,a.R1)(m).is("without-controls",!e.controls),(0,a.R1)(m).is("controls-right",(0,a.R1)(A)),(0,a.R1)(m).is(e.align,!!e.align)]),onDragstart:(0,c.D$)(()=>{},["prevent"])},[e.controls?(0,n.bo)(((0,n.uX)(),(0,n.CE)("span",{key:0,role:"button","aria-label":(0,a.R1)(f)("el.inputNumber.decrease"),class:(0,o.C4)([(0,a.R1)(m).e("decrease"),(0,a.R1)(m).is("disabled",(0,a.R1)(k))]),onKeydown:(0,c.jR)(F,["enter"])},[(0,n.RG)(e.$slots,"decrease-icon",{},()=>[(0,n.bF)((0,a.R1)(i.tk),null,{default:(0,n.k6)(()=>[(0,a.R1)(A)?((0,n.uX)(),(0,n.Wv)((0,a.R1)(u.ArrowDown),{key:0})):((0,n.uX)(),(0,n.Wv)((0,a.R1)(u.Minus),{key:1}))]),_:1})])],42,["aria-label","onKeydown"])),[[(0,a.R1)(y.wc),F]]):(0,n.Q3)("v-if",!0),e.controls?(0,n.bo)(((0,n.uX)(),(0,n.CE)("span",{key:1,role:"button","aria-label":(0,a.R1)(f)("el.inputNumber.increase"),class:(0,o.C4)([(0,a.R1)(m).e("increase"),(0,a.R1)(m).is("disabled",(0,a.R1)(S))]),onKeydown:(0,c.jR)(D,["enter"])},[(0,n.RG)(e.$slots,"increase-icon",{},()=>[(0,n.bF)((0,a.R1)(i.tk),null,{default:(0,n.k6)(()=>[(0,a.R1)(A)?((0,n.uX)(),(0,n.Wv)((0,a.R1)(u.ArrowUp),{key:0})):((0,n.uX)(),(0,n.Wv)((0,a.R1)(u.Plus),{key:1}))]),_:1})])],42,["aria-label","onKeydown"])),[[(0,a.R1)(y.wc),D]]):(0,n.Q3)("v-if",!0),(0,n.bF)((0,a.R1)(s.WK),{id:e.id,ref_key:"input",ref:h,type:"number",step:e.step,"model-value":(0,a.R1)(T),placeholder:e.placeholder,readonly:e.readonly,disabled:(0,a.R1)(_),size:(0,a.R1)(N),max:e.max,min:e.min,name:e.name,"aria-label":e.ariaLabel,"validate-event":!1,inputmode:e.inputmode,onKeydown:I,onBlur:U,onFocus:X,onInput:$,onChange:H},(0,n.eX)({_:2},[e.$slots.prefix?{name:"prefix",fn:(0,n.k6)(()=>[(0,n.RG)(e.$slots,"prefix")])}:void 0,e.$slots.suffix?{name:"suffix",fn:(0,n.k6)(()=>[(0,n.RG)(e.$slots,"suffix")])}:void 0]),1032,["id","step","model-value","placeholder","readonly","disabled","size","max","min","name","aria-label","inputmode"])],42,["onDragstart"]))}});var E=(0,b.A)(S,[["__file","input-number.vue"]]),A=l(5376);const N=(0,A.GU)(E)},1513:function(e,t,l){"use strict";l.d(t,{q:function(){return _}});l(4114);function n(e,t){o(e)&&(e="100%");var l=c(e);return e=360===t?e:Math.min(t,Math.max(0,parseFloat(e))),l&&(e=parseInt(String(e*t),10)/100),Math.abs(e-t)<1e-6?1:(e=360===t?(e<0?e%t+t:e%t)/parseFloat(String(t)):e%t/parseFloat(String(t)),e)}function a(e){return Math.min(1,Math.max(0,e))}function o(e){return"string"===typeof e&&-1!==e.indexOf(".")&&1===parseFloat(e)}function c(e){return"string"===typeof e&&-1!==e.indexOf("%")}function r(e){return e=parseFloat(e),(isNaN(e)||e<0||e>1)&&(e=1),e}function s(e){return e<=1?"".concat(100*Number(e),"%"):e}function i(e){return 1===e.length?"0"+e:String(e)}function u(e,t,l){return{r:255*n(e,255),g:255*n(t,255),b:255*n(l,255)}}function d(e,t,l){e=n(e,255),t=n(t,255),l=n(l,255);var a=Math.max(e,t,l),o=Math.min(e,t,l),c=0,r=0,s=(a+o)/2;if(a===o)r=0,c=0;else{var i=a-o;switch(r=s>.5?i/(2-a-o):i/(a+o),a){case e:c=(t-l)/i+(t1&&(l-=1),l<1/6?e+6*l*(t-e):l<.5?t:l<2/3?e+(t-e)*(2/3-l)*6:e}function p(e,t,l){var a,o,c;if(e=n(e,360),t=n(t,100),l=n(l,100),0===t)o=l,c=l,a=l;else{var r=l<.5?l*(1+t):l+t-l*t,s=2*l-r;a=f(s,r,e+1/3),o=f(s,r,e),c=f(s,r,e-1/3)}return{r:255*a,g:255*o,b:255*c}}function m(e,t,l){e=n(e,255),t=n(t,255),l=n(l,255);var a=Math.max(e,t,l),o=Math.min(e,t,l),c=0,r=a,s=a-o,i=0===a?0:s/a;if(a===o)c=0;else{switch(a){case e:c=(t-l)/s+(t>16,g:(65280&e)>>8,b:255&e}}var L={aliceblue:"#f0f8ff",antiquewhite:"#faebd7",aqua:"#00ffff",aquamarine:"#7fffd4",azure:"#f0ffff",beige:"#f5f5dc",bisque:"#ffe4c4",black:"#000000",blanchedalmond:"#ffebcd",blue:"#0000ff",blueviolet:"#8a2be2",brown:"#a52a2a",burlywood:"#deb887",cadetblue:"#5f9ea0",chartreuse:"#7fff00",chocolate:"#d2691e",coral:"#ff7f50",cornflowerblue:"#6495ed",cornsilk:"#fff8dc",crimson:"#dc143c",cyan:"#00ffff",darkblue:"#00008b",darkcyan:"#008b8b",darkgoldenrod:"#b8860b",darkgray:"#a9a9a9",darkgreen:"#006400",darkgrey:"#a9a9a9",darkkhaki:"#bdb76b",darkmagenta:"#8b008b",darkolivegreen:"#556b2f",darkorange:"#ff8c00",darkorchid:"#9932cc",darkred:"#8b0000",darksalmon:"#e9967a",darkseagreen:"#8fbc8f",darkslateblue:"#483d8b",darkslategray:"#2f4f4f",darkslategrey:"#2f4f4f",darkturquoise:"#00ced1",darkviolet:"#9400d3",deeppink:"#ff1493",deepskyblue:"#00bfff",dimgray:"#696969",dimgrey:"#696969",dodgerblue:"#1e90ff",firebrick:"#b22222",floralwhite:"#fffaf0",forestgreen:"#228b22",fuchsia:"#ff00ff",gainsboro:"#dcdcdc",ghostwhite:"#f8f8ff",goldenrod:"#daa520",gold:"#ffd700",gray:"#808080",green:"#008000",greenyellow:"#adff2f",grey:"#808080",honeydew:"#f0fff0",hotpink:"#ff69b4",indianred:"#cd5c5c",indigo:"#4b0082",ivory:"#fffff0",khaki:"#f0e68c",lavenderblush:"#fff0f5",lavender:"#e6e6fa",lawngreen:"#7cfc00",lemonchiffon:"#fffacd",lightblue:"#add8e6",lightcoral:"#f08080",lightcyan:"#e0ffff",lightgoldenrodyellow:"#fafad2",lightgray:"#d3d3d3",lightgreen:"#90ee90",lightgrey:"#d3d3d3",lightpink:"#ffb6c1",lightsalmon:"#ffa07a",lightseagreen:"#20b2aa",lightskyblue:"#87cefa",lightslategray:"#778899",lightslategrey:"#778899",lightsteelblue:"#b0c4de",lightyellow:"#ffffe0",lime:"#00ff00",limegreen:"#32cd32",linen:"#faf0e6",magenta:"#ff00ff",maroon:"#800000",mediumaquamarine:"#66cdaa",mediumblue:"#0000cd",mediumorchid:"#ba55d3",mediumpurple:"#9370db",mediumseagreen:"#3cb371",mediumslateblue:"#7b68ee",mediumspringgreen:"#00fa9a",mediumturquoise:"#48d1cc",mediumvioletred:"#c71585",midnightblue:"#191970",mintcream:"#f5fffa",mistyrose:"#ffe4e1",moccasin:"#ffe4b5",navajowhite:"#ffdead",navy:"#000080",oldlace:"#fdf5e6",olive:"#808000",olivedrab:"#6b8e23",orange:"#ffa500",orangered:"#ff4500",orchid:"#da70d6",palegoldenrod:"#eee8aa",palegreen:"#98fb98",paleturquoise:"#afeeee",palevioletred:"#db7093",papayawhip:"#ffefd5",peachpuff:"#ffdab9",peru:"#cd853f",pink:"#ffc0cb",plum:"#dda0dd",powderblue:"#b0e0e6",purple:"#800080",rebeccapurple:"#663399",red:"#ff0000",rosybrown:"#bc8f8f",royalblue:"#4169e1",saddlebrown:"#8b4513",salmon:"#fa8072",sandybrown:"#f4a460",seagreen:"#2e8b57",seashell:"#fff5ee",sienna:"#a0522d",silver:"#c0c0c0",skyblue:"#87ceeb",slateblue:"#6a5acd",slategray:"#708090",slategrey:"#708090",snow:"#fffafa",springgreen:"#00ff7f",steelblue:"#4682b4",tan:"#d2b48c",teal:"#008080",thistle:"#d8bfd8",tomato:"#ff6347",turquoise:"#40e0d0",violet:"#ee82ee",wheat:"#f5deb3",white:"#ffffff",whitesmoke:"#f5f5f5",yellow:"#ffff00",yellowgreen:"#9acd32"};function x(e){var t={r:0,g:0,b:0},l=1,n=null,a=null,o=null,c=!1,i=!1;return"string"===typeof e&&(e=A(e)),"object"===typeof e&&(N(e.r)&&N(e.g)&&N(e.b)?(t=u(e.r,e.g,e.b),c=!0,i="%"===String(e.r).substr(-1)?"prgb":"rgb"):N(e.h)&&N(e.s)&&N(e.v)?(n=s(e.s),a=s(e.v),t=v(e.h,n,a),c=!0,i="hsv"):N(e.h)&&N(e.s)&&N(e.l)&&(n=s(e.s),o=s(e.l),t=p(e.h,n,o),c=!0,i="hsl"),Object.prototype.hasOwnProperty.call(e,"a")&&(l=e.a)),l=r(l),{ok:c,format:e.format||i,r:Math.min(255,Math.max(t.r,0)),g:Math.min(255,Math.max(t.g,0)),b:Math.min(255,Math.max(t.b,0)),a:l}}var M="[-\\+]?\\d+%?",z="[-\\+]?\\d*\\.\\d+%?",R="(?:".concat(z,")|(?:").concat(M,")"),k="[\\s|\\(]+(".concat(R,")[,|\\s]+(").concat(R,")[,|\\s]+(").concat(R,")\\s*\\)?"),S="[\\s|\\(]+(".concat(R,")[,|\\s]+(").concat(R,")[,|\\s]+(").concat(R,")[,|\\s]+(").concat(R,")\\s*\\)?"),E={CSS_UNIT:new RegExp(R),rgb:new RegExp("rgb"+k),rgba:new RegExp("rgba"+S),hsl:new RegExp("hsl"+k),hsla:new RegExp("hsla"+S),hsv:new RegExp("hsv"+k),hsva:new RegExp("hsva"+S),hex3:/^#?([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,hex6:/^#?([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/,hex4:/^#?([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,hex8:/^#?([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/};function A(e){if(e=e.trim().toLowerCase(),0===e.length)return!1;var t=!1;if(L[e])e=L[e],t=!0;else if("transparent"===e)return{r:0,g:0,b:0,a:0,format:"name"};var l=E.rgb.exec(e);return l?{r:l[1],g:l[2],b:l[3]}:(l=E.rgba.exec(e),l?{r:l[1],g:l[2],b:l[3],a:l[4]}:(l=E.hsl.exec(e),l?{h:l[1],s:l[2],l:l[3]}:(l=E.hsla.exec(e),l?{h:l[1],s:l[2],l:l[3],a:l[4]}:(l=E.hsv.exec(e),l?{h:l[1],s:l[2],v:l[3]}:(l=E.hsva.exec(e),l?{h:l[1],s:l[2],v:l[3],a:l[4]}:(l=E.hex8.exec(e),l?{r:C(l[1]),g:C(l[2]),b:C(l[3]),a:y(l[4]),format:t?"name":"hex8"}:(l=E.hex6.exec(e),l?{r:C(l[1]),g:C(l[2]),b:C(l[3]),format:t?"name":"hex"}:(l=E.hex4.exec(e),l?{r:C(l[1]+l[1]),g:C(l[2]+l[2]),b:C(l[3]+l[3]),a:y(l[4]+l[4]),format:t?"name":"hex8"}:(l=E.hex3.exec(e),!!l&&{r:C(l[1]+l[1]),g:C(l[2]+l[2]),b:C(l[3]+l[3]),format:t?"name":"hex"})))))))))}function N(e){return Boolean(E.CSS_UNIT.exec(String(e)))}var _=function(){function e(t,l){var n;if(void 0===t&&(t=""),void 0===l&&(l={}),t instanceof e)return t;"number"===typeof t&&(t=w(t)),this.originalInput=t;var a=x(t);this.originalInput=t,this.r=a.r,this.g=a.g,this.b=a.b,this.a=a.a,this.roundA=Math.round(100*this.a)/100,this.format=null!==(n=l.format)&&void 0!==n?n:a.format,this.gradientType=l.gradientType,this.r<1&&(this.r=Math.round(this.r)),this.g<1&&(this.g=Math.round(this.g)),this.b<1&&(this.b=Math.round(this.b)),this.isValid=a.ok}return e.prototype.isDark=function(){return this.getBrightness()<128},e.prototype.isLight=function(){return!this.isDark()},e.prototype.getBrightness=function(){var e=this.toRgb();return(299*e.r+587*e.g+114*e.b)/1e3},e.prototype.getLuminance=function(){var e,t,l,n=this.toRgb(),a=n.r/255,o=n.g/255,c=n.b/255;return e=a<=.03928?a/12.92:Math.pow((a+.055)/1.055,2.4),t=o<=.03928?o/12.92:Math.pow((o+.055)/1.055,2.4),l=c<=.03928?c/12.92:Math.pow((c+.055)/1.055,2.4),.2126*e+.7152*t+.0722*l},e.prototype.getAlpha=function(){return this.a},e.prototype.setAlpha=function(e){return this.a=r(e),this.roundA=Math.round(100*this.a)/100,this},e.prototype.isMonochrome=function(){var e=this.toHsl().s;return 0===e},e.prototype.toHsv=function(){var e=m(this.r,this.g,this.b);return{h:360*e.h,s:e.s,v:e.v,a:this.a}},e.prototype.toHsvString=function(){var e=m(this.r,this.g,this.b),t=Math.round(360*e.h),l=Math.round(100*e.s),n=Math.round(100*e.v);return 1===this.a?"hsv(".concat(t,", ").concat(l,"%, ").concat(n,"%)"):"hsva(".concat(t,", ").concat(l,"%, ").concat(n,"%, ").concat(this.roundA,")")},e.prototype.toHsl=function(){var e=d(this.r,this.g,this.b);return{h:360*e.h,s:e.s,l:e.l,a:this.a}},e.prototype.toHslString=function(){var e=d(this.r,this.g,this.b),t=Math.round(360*e.h),l=Math.round(100*e.s),n=Math.round(100*e.l);return 1===this.a?"hsl(".concat(t,", ").concat(l,"%, ").concat(n,"%)"):"hsla(".concat(t,", ").concat(l,"%, ").concat(n,"%, ").concat(this.roundA,")")},e.prototype.toHex=function(e){return void 0===e&&(e=!1),h(this.r,this.g,this.b,e)},e.prototype.toHexString=function(e){return void 0===e&&(e=!1),"#"+this.toHex(e)},e.prototype.toHex8=function(e){return void 0===e&&(e=!1),g(this.r,this.g,this.b,this.a,e)},e.prototype.toHex8String=function(e){return void 0===e&&(e=!1),"#"+this.toHex8(e)},e.prototype.toHexShortString=function(e){return void 0===e&&(e=!1),1===this.a?this.toHexString(e):this.toHex8String(e)},e.prototype.toRgb=function(){return{r:Math.round(this.r),g:Math.round(this.g),b:Math.round(this.b),a:this.a}},e.prototype.toRgbString=function(){var e=Math.round(this.r),t=Math.round(this.g),l=Math.round(this.b);return 1===this.a?"rgb(".concat(e,", ").concat(t,", ").concat(l,")"):"rgba(".concat(e,", ").concat(t,", ").concat(l,", ").concat(this.roundA,")")},e.prototype.toPercentageRgb=function(){var e=function(e){return"".concat(Math.round(100*n(e,255)),"%")};return{r:e(this.r),g:e(this.g),b:e(this.b),a:this.a}},e.prototype.toPercentageRgbString=function(){var e=function(e){return Math.round(100*n(e,255))};return 1===this.a?"rgb(".concat(e(this.r),"%, ").concat(e(this.g),"%, ").concat(e(this.b),"%)"):"rgba(".concat(e(this.r),"%, ").concat(e(this.g),"%, ").concat(e(this.b),"%, ").concat(this.roundA,")")},e.prototype.toName=function(){if(0===this.a)return"transparent";if(this.a<1)return!1;for(var e="#"+h(this.r,this.g,this.b,!1),t=0,l=Object.entries(L);t=0,a=!t&&n&&(e.startsWith("hex")||"name"===e);return a?"name"===e&&0===this.a?this.toName():this.toRgbString():("rgb"===e&&(l=this.toRgbString()),"prgb"===e&&(l=this.toPercentageRgbString()),"hex"!==e&&"hex6"!==e||(l=this.toHexString()),"hex3"===e&&(l=this.toHexString(!0)),"hex4"===e&&(l=this.toHex8String(!0)),"hex8"===e&&(l=this.toHex8String()),"name"===e&&(l=this.toName()),"hsl"===e&&(l=this.toHslString()),"hsv"===e&&(l=this.toHsvString()),l||this.toHexString())},e.prototype.toNumber=function(){return(Math.round(this.r)<<16)+(Math.round(this.g)<<8)+Math.round(this.b)},e.prototype.clone=function(){return new e(this.toString())},e.prototype.lighten=function(t){void 0===t&&(t=10);var l=this.toHsl();return l.l+=t/100,l.l=a(l.l),new e(l)},e.prototype.brighten=function(t){void 0===t&&(t=10);var l=this.toRgb();return l.r=Math.max(0,Math.min(255,l.r-Math.round(-t/100*255))),l.g=Math.max(0,Math.min(255,l.g-Math.round(-t/100*255))),l.b=Math.max(0,Math.min(255,l.b-Math.round(-t/100*255))),new e(l)},e.prototype.darken=function(t){void 0===t&&(t=10);var l=this.toHsl();return l.l-=t/100,l.l=a(l.l),new e(l)},e.prototype.tint=function(e){return void 0===e&&(e=10),this.mix("white",e)},e.prototype.shade=function(e){return void 0===e&&(e=10),this.mix("black",e)},e.prototype.desaturate=function(t){void 0===t&&(t=10);var l=this.toHsl();return l.s-=t/100,l.s=a(l.s),new e(l)},e.prototype.saturate=function(t){void 0===t&&(t=10);var l=this.toHsl();return l.s+=t/100,l.s=a(l.s),new e(l)},e.prototype.greyscale=function(){return this.desaturate(100)},e.prototype.spin=function(t){var l=this.toHsl(),n=(l.h+t)%360;return l.h=n<0?360+n:n,new e(l)},e.prototype.mix=function(t,l){void 0===l&&(l=50);var n=this.toRgb(),a=new e(t).toRgb(),o=l/100,c={r:(a.r-n.r)*o+n.r,g:(a.g-n.g)*o+n.g,b:(a.b-n.b)*o+n.b,a:(a.a-n.a)*o+n.a};return new e(c)},e.prototype.analogous=function(t,l){void 0===t&&(t=6),void 0===l&&(l=30);var n=this.toHsl(),a=360/l,o=[this];for(n.h=(n.h-(a*t>>1)+720)%360;--t;)n.h=(n.h+a)%360,o.push(new e(n));return o},e.prototype.complement=function(){var t=this.toHsl();return t.h=(t.h+180)%360,new e(t)},e.prototype.monochromatic=function(t){void 0===t&&(t=6);var l=this.toHsv(),n=l.h,a=l.s,o=l.v,c=[],r=1/t;while(t--)c.push(new e({h:n,s:a,v:o})),o=(o+r)%1;return c},e.prototype.splitcomplement=function(){var t=this.toHsl(),l=t.h;return[this,new e({h:(l+72)%360,s:t.s,l:t.l}),new e({h:(l+216)%360,s:t.s,l:t.l})]},e.prototype.onBackground=function(t){var l=this.toRgb(),n=new e(t).toRgb(),a=l.a+n.a*(1-l.a);return new e({r:(l.r*l.a+n.r*n.a*(1-l.a))/a,g:(l.g*l.a+n.g*n.a*(1-l.a))/a,b:(l.b*l.a+n.b*n.a*(1-l.a))/a,a:a})},e.prototype.triad=function(){return this.polyad(3)},e.prototype.tetrad=function(){return this.polyad(4)},e.prototype.polyad=function(t){for(var l=this.toHsl(),n=l.h,a=[this],o=360/t,c=1;c92||"NODE"===c&&o>94||"BROWSER"===c&&o>97)return!1;var e=new ArrayBuffer(8),t=r(e,{transfer:[e]});return 0!==e.byteLength||8!==t.byteLength})},1549:function(e,t,l){"use strict";l(6632)},1576:function(e){!function(t,l){e.exports=l()}(0,function(){"use strict";var e=1e3,t=6e4,l=36e5,n="millisecond",a="second",o="minute",c="hour",r="day",s="week",i="month",u="quarter",d="year",f="date",p="Invalid Date",m=/^(\d{4})[-/]?(\d{1,2})?[-/]?(\d{0,2})[Tt\s]*(\d{1,2})?:?(\d{1,2})?:?(\d{1,2})?[.:]?(\d+)?$/,v=/\[([^\]]+)]|Y{1,4}|M{1,4}|D{1,2}|d{1,4}|H{1,2}|h{1,2}|a|A|m{1,2}|s{1,2}|Z{1,2}|SSS/g,h={name:"en",weekdays:"Sunday_Monday_Tuesday_Wednesday_Thursday_Friday_Saturday".split("_"),months:"January_February_March_April_May_June_July_August_September_October_November_December".split("_"),ordinal:function(e){var t=["th","st","nd","rd"],l=e%100;return"["+e+(t[(l-20)%10]||t[l]||t[0])+"]"}},g=function(e,t,l){var n=String(e);return!n||n.length>=t?e:""+Array(t+1-n.length).join(l)+e},b={s:g,z:function(e){var t=-e.utcOffset(),l=Math.abs(t),n=Math.floor(l/60),a=l%60;return(t<=0?"+":"-")+g(n,2,"0")+":"+g(a,2,"0")},m:function e(t,l){if(t.date()1)return e(c[0])}else{var r=t.name;C[r]=t,a=r}return!n&&a&&(y=a),a||!n&&y},M=function(e,t){if(L(e))return e.clone();var l="object"==typeof t?t:{};return l.date=e,l.args=arguments,new R(l)},z=b;z.l=x,z.i=L,z.w=function(e,t){return M(e,{locale:t.$L,utc:t.$u,x:t.$x,$offset:t.$offset})};var R=function(){function h(e){this.$L=x(e.locale,null,!0),this.parse(e),this.$x=this.$x||e.x||{},this[w]=!0}var g=h.prototype;return g.parse=function(e){this.$d=function(e){var t=e.date,l=e.utc;if(null===t)return new Date(NaN);if(z.u(t))return new Date;if(t instanceof Date)return new Date(t);if("string"==typeof t&&!/Z$/i.test(t)){var n=t.match(m);if(n){var a=n[2]-1||0,o=(n[7]||"0").substring(0,3);return l?new Date(Date.UTC(n[1],a,n[3]||1,n[4]||0,n[5]||0,n[6]||0,o)):new Date(n[1],a,n[3]||1,n[4]||0,n[5]||0,n[6]||0,o)}}return new Date(t)}(e),this.init()},g.init=function(){var e=this.$d;this.$y=e.getFullYear(),this.$M=e.getMonth(),this.$D=e.getDate(),this.$W=e.getDay(),this.$H=e.getHours(),this.$m=e.getMinutes(),this.$s=e.getSeconds(),this.$ms=e.getMilliseconds()},g.$utils=function(){return z},g.isValid=function(){return!(this.$d.toString()===p)},g.isSame=function(e,t){var l=M(e);return this.startOf(t)<=l&&l<=this.endOf(t)},g.isAfter=function(e,t){return M(e)n.Loading},plain:{type:Boolean,default:void 0},text:{type:Boolean,default:void 0},link:Boolean,bg:Boolean,autofocus:Boolean,round:{type:Boolean,default:void 0},circle:Boolean,color:String,dark:Boolean,autoInsertSpace:{type:Boolean,default:void 0},tag:{type:(0,a.jq)([String,Object]),default:"button"}}),u={click:e=>e instanceof MouseEvent}},1588:function(e,t,l){"use strict";l.d(t,{A:function(){return u},k:function(){return i}});var n=l(6768),a=l(8114),o=l(9180),c=l(7378),r=l(3845);const s=(0,c.b_)({a11y:{type:Boolean,default:!0},locale:{type:(0,c.jq)(Object)},size:r.mU,button:{type:(0,c.jq)(Object)},card:{type:(0,c.jq)(Object)},dialog:{type:(0,c.jq)(Object)},link:{type:(0,c.jq)(Object)},experimentalFeatures:{type:(0,c.jq)(Object)},keyboardNavigation:{type:Boolean,default:!0},message:{type:(0,c.jq)(Object)},zIndex:Number,namespace:{type:String,default:"el"},...o.bs}),i={placement:"top"},u=(0,n.pM)({name:"ElConfigProvider",props:s,setup(e,{slots:t}){const l=(0,a.Vh)(e);return(0,n.wB)(()=>e.message,e=>{var t,n;Object.assign(i,null!=(n=null==(t=null==l?void 0:l.value)?void 0:t.message)?n:{},null!=e?e:{})},{immediate:!0,deep:!0}),()=>(0,n.RG)(t,"default",{config:null==l?void 0:l.value})}})},1591:function(e,t,l){"use strict";l.d(t,{A:function(){return b}});var n=l(2990),a=Object.prototype,o=a.hasOwnProperty,c=a.toString,r=n.A?n.A.toStringTag:void 0;function s(e){var t=o.call(e,r),l=e[r];try{e[r]=void 0;var n=!0}catch(s){}var a=c.call(e);return n&&(t?e[r]=l:delete e[r]),a}var i=s,u=Object.prototype,d=u.toString;function f(e){return d.call(e)}var p=f,m="[object Null]",v="[object Undefined]",h=n.A?n.A.toStringTag:void 0;function g(e){return null==e?void 0===e?v:m:h&&h in Object(e)?i(e):p(e)}var b=g},1625:function(e,t,l){"use strict";var n=l(9504);e.exports=n({}.isPrototypeOf)},1698:function(e,t,l){"use strict";var n=l(6518),a=l(4204),o=l(9835),c=l(4916),r=!c("union")||!o("union");n({target:"Set",proto:!0,real:!0,forced:r},{union:a})},1701:function(e,t,l){"use strict";var n=l(6518),a=l(9565),o=l(9306),c=l(8551),r=l(1767),s=l(9462),i=l(6319),u=l(9539),d=l(684),f=l(4549),p=l(6395),m=!p&&!d("map",function(){}),v=!p&&!m&&f("map",TypeError),h=p||m||v,g=s(function(){var e=this.iterator,t=c(a(this.next,e)),l=this.done=!!t.done;if(!l)return i(e,this.mapper,[t.value,this.counter++],!0)});n({target:"Iterator",proto:!0,real:!0,forced:h},{map:function(e){c(this);try{o(e)}catch(t){u(this,"throw",t)}return v?a(v,this,e):new g(r(this),{mapper:e})}})},1767:function(e){"use strict";e.exports=function(e){return{iterator:e,next:e.next,done:!1}}},1801:function(e,t,l){"use strict";function n(e,t){var l=-1,n=null==e?0:e.length,a=0,o=[];while(++li)a(n,l=t[i++])&&(~c(u,l)||s(u,l));return u}},1862:function(){},1939:function(e,t,l){"use strict";l.d(t,{K:function(){return s}});var n=l(6768),a=l(144),o=l(7687),c=l(6340),r=l(4232);function s(e,{disabled:t,beforeFocus:l,afterFocus:s,beforeBlur:i,afterBlur:u}={}){const d=(0,n.nI)(),{emit:f}=d,p=(0,a.IJ)(),m=(0,a.KR)(!1),v=e=>{const n=!!(0,r.Tn)(l)&&l(e);(0,a.R1)(t)||m.value||n||(m.value=!0,f("focus",e),null==s||s())},h=e=>{var l;const n=!!(0,r.Tn)(i)&&i(e);(0,a.R1)(t)||e.relatedTarget&&(null==(l=p.value)?void 0:l.contains(e.relatedTarget))||n||(m.value=!1,f("blur",e),null==u||u())},g=l=>{var n,o;(0,a.R1)(t)||(0,c.tp)(l.target)||(null==(n=p.value)?void 0:n.contains(document.activeElement))&&p.value!==document.activeElement||null==(o=e.value)||o.focus()};return(0,n.wB)([p,()=>(0,a.R1)(t)],([e,t])=>{e&&(t?e.removeAttribute("tabindex"):e.setAttribute("tabindex","-1"))}),(0,o.MLh)(p,"focus",v,!0),(0,o.MLh)(p,"blur",h,!0),(0,o.MLh)(p,"click",g,!0),{isFocused:m,wrapperRef:p,handleFocus:v,handleBlur:h}}},1968:function(e,t,l){"use strict";l.d(t,{r:function(){return a}});var n=l(4232);const a=e=>{if(!e)return{onClick:n.tE,onMousedown:n.tE,onMouseup:n.tE};let t=!1,l=!1;const a=n=>{t&&l&&e(n),t=l=!1},o=e=>{t=e.target===e.currentTarget},c=e=>{l=e.target===e.currentTarget};return{onClick:a,onMousedown:o,onMouseup:c}}},1996:function(e,t,l){"use strict";l.d(t,{A:function(){return p}});var n=l(2623),a=l(203),o=l(5014);function c(e,t,l){var c=-1,r=t.length,s={};while(++c((0,o.cy)(e)||(0,o.Kg)(e))&&(0,i.Lm)(t)&&(0,o.Kg)(l)};l(2489),l(1701);var p=l(5951),m=l(6894);const v="ElForm";function h(){const e=(0,a.KR)([]),t=(0,n.EW)(()=>{if(!e.value.length)return"0";const t=Math.max(...e.value);return t?`${t}px`:""});function l(l){const n=e.value.indexOf(l);return-1===n&&"0"===t.value&&(0,m.U)(v,`unexpected width ${l}`),n}function o(t,n){if(t&&n){const a=l(n);e.value.splice(a,1,t)}else t&&e.value.push(t)}function c(t){const n=l(t);n>-1&&e.value.splice(n,1)}return{autoLabelWidth:t,registerLabelWidth:o,deregisterLabelWidth:c}}const g=(e,t)=>{const l=(0,p.A)(t).map(e=>(0,o.cy)(e)?e.join("."):e);return l.length>0?e.filter(e=>e.propString&&l.includes(e.propString)):e};var b=l(9077),y=l(2436),C=l(3513);const w="ElForm",L=(0,n.pM)({name:w}),x=(0,n.pM)({...L,props:d,emits:f,setup(e,{expose:t,emit:l}){const r=e,s=(0,a.KR)(),i=(0,a.Kh)([]),u=(0,y.NV)(),d=(0,C.DU)("form"),f=(0,n.EW)(()=>{const{labelPosition:e,inline:t}=r;return[d.b(),d.m(u.value||"default"),{[d.m(`label-${e}`)]:e,[d.m("inline")]:t}]}),p=e=>g(i,[e])[0],v=e=>{i.push(e)},b=e=>{e.prop&&i.splice(i.indexOf(e),1)},L=(e=[])=>{r.model?g(i,e).forEach(e=>e.resetField()):(0,m.U)(w,"model is required for resetFields to work.")},x=(e=[])=>{g(i,e).forEach(e=>e.clearValidate())},M=(0,n.EW)(()=>{const e=!!r.model;return e||(0,m.U)(w,"model is required for validate to work."),e}),z=e=>{if(0===i.length)return[];const t=g(i,e);return t.length?t:((0,m.U)(w,"please pass correct props!"),[])},R=async e=>S(void 0,e),k=async(e=[])=>{if(!M.value)return!1;const t=z(e);if(0===t.length)return!0;let l={};for(const a of t)try{await a.validate(""),"error"!==a.validateState||a.error||a.resetField()}catch(n){l={...l,...n}}return 0===Object.keys(l).length||Promise.reject(l)},S=async(e=[],t)=>{let l=!1;const n=!(0,o.Tn)(t);try{return l=await k(e),!0===l&&await(null==t?void 0:t(l)),l}catch(a){if(a instanceof Error)throw a;const e=a;if(r.scrollToError&&s.value){const e=s.value.querySelector(`.${d.b()}-item.is-error`);null==e||e.scrollIntoView(r.scrollIntoViewOptions)}return!l&&await(null==t?void 0:t(!1,e)),n&&Promise.reject(e)}},E=e=>{var t;const l=p(e);l&&(null==(t=l.$el)||t.scrollIntoView(r.scrollIntoViewOptions))};return(0,n.wB)(()=>r.rules,()=>{r.validateOnRuleChange&&R().catch(e=>(0,m.U)(e))},{deep:!0,flush:"post"}),(0,n.Gt)(c.F,(0,a.Kh)({...(0,a.QW)(r),emit:l,resetFields:L,clearValidate:x,validateField:S,getField:p,addField:v,removeField:b,...h()})),t({validate:R,validateField:S,resetFields:L,clearValidate:x,scrollToField:E,getField:p,fields:i}),(e,t)=>((0,n.uX)(),(0,n.CE)("form",{ref_key:"formRef",ref:s,class:(0,o.C4)((0,a.R1)(f))},[(0,n.RG)(e.$slots,"default")],2))}});var M=(0,b.A)(x,[["__file","form.vue"]]),z=(l(3579),l(5130));l(1148),l(3110),l(8335);function R(){return R=Object.assign?Object.assign.bind():function(e){for(var t=1;t1?t-1:0),n=1;n=o)return e;switch(e){case"%s":return String(l[a++]);case"%d":return Number(l[a++]);case"%j":try{return JSON.stringify(l[a++])}catch(t){return"[Circular]"}default:return e}});return c}return e}function D(e){return"string"===e||"url"===e||"hex"===e||"email"===e||"date"===e||"pattern"===e}function F(e,t){return void 0===e||null===e||(!("array"!==t||!Array.isArray(e)||e.length)||!(!D(t)||"string"!==typeof e||e))}function V(e,t,l){var n=[],a=0,o=e.length;function c(e){n.push.apply(n,e||[]),a++,a===o&&l(n)}e.forEach(function(e){t(e,c)})}function P(e,t,l){var n=0,a=e.length;function o(c){if(c&&c.length)l(c);else{var r=n;n+=1,r()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]+\.)+[a-zA-Z\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]{2,}))$/,hex:/^#?([a-f0-9]{6}|[a-f0-9]{3})$/i},ee={integer:function(e){return ee.number(e)&&parseInt(e,10)===e},float:function(e){return ee.number(e)&&!ee.integer(e)},array:function(e){return Array.isArray(e)},regexp:function(e){if(e instanceof RegExp)return!0;try{return!!new RegExp(e)}catch(t){return!1}},date:function(e){return"function"===typeof e.getTime&&"function"===typeof e.getMonth&&"function"===typeof e.getYear&&!isNaN(e.getTime())},number:function(e){return!isNaN(e)&&"number"===typeof e},object:function(e){return"object"===typeof e&&!ee.array(e)},method:function(e){return"function"===typeof e},email:function(e){return"string"===typeof e&&e.length<=320&&!!e.match(J.email)},url:function(e){return"string"===typeof e&&e.length<=2048&&!!e.match(Z())},hex:function(e){return"string"===typeof e&&!!e.match(J.hex)}},te=function(e,t,l,n,a){if(e.required&&void 0===t)Y(e,t,l,n,a);else{var o=["integer","float","array","regexp","object","method","email","number","date","url","hex"],c=e.type;o.indexOf(c)>-1?ee[c](t)||n.push(I(a.messages.types[c],e.fullField,e.type)):c&&typeof t!==e.type&&n.push(I(a.messages.types[c],e.fullField,e.type))}},le=function(e,t,l,n,a){var o="number"===typeof e.len,c="number"===typeof e.min,r="number"===typeof e.max,s=/[\uD800-\uDBFF][\uDC00-\uDFFF]/g,i=t,u=null,d="number"===typeof t,f="string"===typeof t,p=Array.isArray(t);if(d?u="number":f?u="string":p&&(u="array"),!u)return!1;p&&(i=t.length),f&&(i=t.replace(s,"_").length),o?i!==e.len&&n.push(I(a.messages[u].len,e.fullField,e.len)):c&&!r&&ie.max?n.push(I(a.messages[u].max,e.fullField,e.max)):c&&r&&(ie.max)&&n.push(I(a.messages[u].range,e.fullField,e.min,e.max))},ne="enum",ae=function(e,t,l,n,a){e[ne]=Array.isArray(e[ne])?e[ne]:[],-1===e[ne].indexOf(t)&&n.push(I(a.messages[ne],e.fullField,e[ne].join(", ")))},oe=function(e,t,l,n,a){if(e.pattern)if(e.pattern instanceof RegExp)e.pattern.lastIndex=0,e.pattern.test(t)||n.push(I(a.messages.pattern.mismatch,e.fullField,t,e.pattern));else if("string"===typeof e.pattern){var o=new RegExp(e.pattern);o.test(t)||n.push(I(a.messages.pattern.mismatch,e.fullField,t,e.pattern))}},ce={required:Y,whitespace:Q,type:te,range:le,enum:ae,pattern:oe},re=function(e,t,l,n,a){var o=[],c=e.required||!e.required&&n.hasOwnProperty(e.field);if(c){if(F(t,"string")&&!e.required)return l();ce.required(e,t,n,o,a,"string"),F(t,"string")||(ce.type(e,t,n,o,a),ce.range(e,t,n,o,a),ce.pattern(e,t,n,o,a),!0===e.whitespace&&ce.whitespace(e,t,n,o,a))}l(o)},se=function(e,t,l,n,a){var o=[],c=e.required||!e.required&&n.hasOwnProperty(e.field);if(c){if(F(t)&&!e.required)return l();ce.required(e,t,n,o,a),void 0!==t&&ce.type(e,t,n,o,a)}l(o)},ie=function(e,t,l,n,a){var o=[],c=e.required||!e.required&&n.hasOwnProperty(e.field);if(c){if(""===t&&(t=void 0),F(t)&&!e.required)return l();ce.required(e,t,n,o,a),void 0!==t&&(ce.type(e,t,n,o,a),ce.range(e,t,n,o,a))}l(o)},ue=function(e,t,l,n,a){var o=[],c=e.required||!e.required&&n.hasOwnProperty(e.field);if(c){if(F(t)&&!e.required)return l();ce.required(e,t,n,o,a),void 0!==t&&ce.type(e,t,n,o,a)}l(o)},de=function(e,t,l,n,a){var o=[],c=e.required||!e.required&&n.hasOwnProperty(e.field);if(c){if(F(t)&&!e.required)return l();ce.required(e,t,n,o,a),F(t)||ce.type(e,t,n,o,a)}l(o)},fe=function(e,t,l,n,a){var o=[],c=e.required||!e.required&&n.hasOwnProperty(e.field);if(c){if(F(t)&&!e.required)return l();ce.required(e,t,n,o,a),void 0!==t&&(ce.type(e,t,n,o,a),ce.range(e,t,n,o,a))}l(o)},pe=function(e,t,l,n,a){var o=[],c=e.required||!e.required&&n.hasOwnProperty(e.field);if(c){if(F(t)&&!e.required)return l();ce.required(e,t,n,o,a),void 0!==t&&(ce.type(e,t,n,o,a),ce.range(e,t,n,o,a))}l(o)},me=function(e,t,l,n,a){var o=[],c=e.required||!e.required&&n.hasOwnProperty(e.field);if(c){if((void 0===t||null===t)&&!e.required)return l();ce.required(e,t,n,o,a,"array"),void 0!==t&&null!==t&&(ce.type(e,t,n,o,a),ce.range(e,t,n,o,a))}l(o)},ve=function(e,t,l,n,a){var o=[],c=e.required||!e.required&&n.hasOwnProperty(e.field);if(c){if(F(t)&&!e.required)return l();ce.required(e,t,n,o,a),void 0!==t&&ce.type(e,t,n,o,a)}l(o)},he="enum",ge=function(e,t,l,n,a){var o=[],c=e.required||!e.required&&n.hasOwnProperty(e.field);if(c){if(F(t)&&!e.required)return l();ce.required(e,t,n,o,a),void 0!==t&&ce[he](e,t,n,o,a)}l(o)},be=function(e,t,l,n,a){var o=[],c=e.required||!e.required&&n.hasOwnProperty(e.field);if(c){if(F(t,"string")&&!e.required)return l();ce.required(e,t,n,o,a),F(t,"string")||ce.pattern(e,t,n,o,a)}l(o)},ye=function(e,t,l,n,a){var o=[],c=e.required||!e.required&&n.hasOwnProperty(e.field);if(c){if(F(t,"date")&&!e.required)return l();var r;if(ce.required(e,t,n,o,a),!F(t,"date"))r=t instanceof Date?t:new Date(t),ce.type(e,r,n,o,a),r&&ce.range(e,r.getTime(),n,o,a)}l(o)},Ce=function(e,t,l,n,a){var o=[],c=Array.isArray(t)?"array":typeof t;ce.required(e,t,n,o,a,c),l(o)},we=function(e,t,l,n,a){var o=e.type,c=[],r=e.required||!e.required&&n.hasOwnProperty(e.field);if(r){if(F(t,o)&&!e.required)return l();ce.required(e,t,n,c,a,o),F(t,o)||ce.type(e,t,n,c,a)}l(c)},Le=function(e,t,l,n,a){var o=[],c=e.required||!e.required&&n.hasOwnProperty(e.field);if(c){if(F(t)&&!e.required)return l();ce.required(e,t,n,o,a)}l(o)},xe={string:re,method:se,number:ie,boolean:ue,regexp:de,integer:fe,float:pe,array:me,object:ve,enum:ge,pattern:be,date:ye,url:we,hex:we,email:we,required:Ce,any:Le};function Me(){return{default:"Validation error on field %s",required:"%s is required",enum:"%s must be one of %s",whitespace:"%s cannot be empty",date:{format:"%s date %s is invalid for format %s",parse:"%s date could not be parsed, %s is invalid ",invalid:"%s date %s is invalid"},types:{string:"%s is not a %s",method:"%s is not a %s (function)",array:"%s is not an %s",object:"%s is not an %s",number:"%s is not a %s",date:"%s is not a %s",boolean:"%s is not a %s",integer:"%s is not an %s",float:"%s is not a %s",regexp:"%s is not a valid %s",email:"%s is not a valid %s",url:"%s is not a valid %s",hex:"%s is not a valid %s"},string:{len:"%s must be exactly %s characters",min:"%s must be at least %s characters",max:"%s cannot be longer than %s characters",range:"%s must be between %s and %s characters"},number:{len:"%s must equal %s",min:"%s cannot be less than %s",max:"%s cannot be greater than %s",range:"%s must be between %s and %s"},array:{len:"%s must be exactly %s in length",min:"%s cannot be less than %s in length",max:"%s cannot be greater than %s in length",range:"%s must be between %s and %s in length"},pattern:{mismatch:"%s value %s does not match pattern %s"},clone:function(){var e=JSON.parse(JSON.stringify(this));return e.clone=this.clone,e}}}var ze=Me(),Re=function(){function e(e){this.rules=null,this._messages=ze,this.define(e)}var t=e.prototype;return t.define=function(e){var t=this;if(!e)throw new Error("Cannot configure a schema with no rules");if("object"!==typeof e||Array.isArray(e))throw new Error("Rules must be an object");this.rules={},Object.keys(e).forEach(function(l){var n=e[l];t.rules[l]=Array.isArray(n)?n:[n]})},t.messages=function(e){return e&&(this._messages=q(Me(),e)),this._messages},t.validate=function(t,l,n){var a=this;void 0===l&&(l={}),void 0===n&&(n=function(){});var o=t,c=l,r=n;if("function"===typeof c&&(r=c,c={}),!this.rules||0===Object.keys(this.rules).length)return r&&r(null,o),Promise.resolve(o);function s(e){var t=[],l={};function n(e){var l;Array.isArray(e)?t=(l=t).concat.apply(l,e):t.push(e)}for(var a=0;a");const r=(0,C.DU)("form"),s=(0,a.KR)(),i=(0,a.KR)(0),u=()=>{var e;if(null==(e=s.value)?void 0:e.firstElementChild){const e=window.getComputedStyle(s.value.firstElementChild).width;return Math.ceil(Number.parseFloat(e))}return 0},d=(a="update")=>{(0,n.dY)(()=>{t.default&&e.isAutoWidth&&("update"===a?i.value=u():"remove"===a&&(null==l||l.deregisterLabelWidth(i.value)))})},f=()=>d("update");return(0,n.sV)(()=>{f()}),(0,n.xo)(()=>{d("remove")}),(0,n.$u)(()=>f()),(0,n.wB)(i,(t,n)=>{e.updateAll&&(null==l||l.registerLabelWidth(t,n))}),(0,Oe.wYm)((0,n.EW)(()=>{var e,t;return null!=(t=null==(e=s.value)?void 0:e.firstElementChild)?t:null}),f),()=>{var a,c;if(!t)return null;const{isAutoWidth:u}=e;if(u){const e=null==l?void 0:l.autoLabelWidth,c=null==o?void 0:o.hasLabel,u={};if(c&&e&&"auto"!==e){const t=Math.max(0,Number.parseInt(e,10)-i.value),n=o.labelPosition||l.labelPosition,a="left"===n?"marginRight":"marginLeft";t&&(u[a]=`${t}px`)}return(0,n.bF)("div",{ref:s,class:[r.be("item","label-wrap")],style:u},[null==(a=t.default)?void 0:a.call(t)])}return(0,n.bF)(n.FK,{ref:s},[null==(c=t.default)?void 0:c.call(t)])}}}),Ie=l(1305),De=l(4340),Fe=l(3558);const Ve=(0,n.pM)({name:"ElFormItem"}),Pe=(0,n.pM)({...Ve,props:Te,setup(e,{expose:t}){const l=e,r=(0,n.Ht)(),s=(0,n.WQ)(c.F,void 0),u=(0,n.WQ)(c.w,void 0),d=(0,y.NV)(void 0,{formItem:!1}),f=(0,C.DU)("form-item"),m=(0,Ie.Bi)().value,v=(0,a.KR)([]),h=(0,a.KR)(""),g=(0,Ne.V7)(h,100),b=(0,a.KR)(""),w=(0,a.KR)();let L,x=!1;const M=(0,n.EW)(()=>l.labelPosition||(null==s?void 0:s.labelPosition)),R=(0,n.EW)(()=>{var e;if("top"===M.value)return{};const t=(0,Fe._V)(null!=(e=l.labelWidth)?e:null==s?void 0:s.labelWidth);return{width:t}}),k=(0,n.EW)(()=>{var e;if("top"===M.value||(null==s?void 0:s.inline))return{};if(!l.label&&!l.labelWidth&&W)return{};const t=(0,Fe._V)(null!=(e=l.labelWidth)?e:null==s?void 0:s.labelWidth);return l.label||r.label?{}:{marginLeft:t}}),S=(0,n.EW)(()=>[f.b(),f.m(d.value),f.is("error","error"===h.value),f.is("validating","validating"===h.value),f.is("success","success"===h.value),f.is("required",V.value||l.required),f.is("no-asterisk",null==s?void 0:s.hideRequiredAsterisk),"right"===(null==s?void 0:s.requireAsteriskPosition)?"asterisk-right":"asterisk-left",{[f.m("feedback")]:null==s?void 0:s.statusIcon,[f.m(`label-${M.value}`)]:M.value}]),E=(0,n.EW)(()=>(0,i.Lm)(l.inlineMessage)?l.inlineMessage:(null==s?void 0:s.inlineMessage)||!1),A=(0,n.EW)(()=>[f.e("error"),{[f.em("error","inline")]:E.value}]),N=(0,n.EW)(()=>l.prop?(0,o.cy)(l.prop)?l.prop.join("."):l.prop:""),_=(0,n.EW)(()=>!(!l.label&&!r.label)),T=(0,n.EW)(()=>{var e;return null!=(e=l.for)?e:1===v.value.length?v.value[0]:void 0}),O=(0,n.EW)(()=>!T.value&&_.value),W=!!u,B=(0,n.EW)(()=>{const e=null==s?void 0:s.model;if(e&&l.prop)return(0,De.GT)(e,l.prop).value}),I=(0,n.EW)(()=>{const{required:e}=l,t=[];l.rules&&t.push(...(0,p.A)(l.rules));const n=null==s?void 0:s.rules;if(n&&l.prop){const e=(0,De.GT)(n,l.prop).value;e&&t.push(...(0,p.A)(e))}if(void 0!==e){const l=t.map((e,t)=>[e,t]).filter(([e])=>"required"in e);if(l.length>0)for(const[n,a]of l)n.required!==e&&(t[a]={...n,required:e});else t.push({required:e})}return t}),D=(0,n.EW)(()=>I.value.length>0),F=e=>{const t=I.value;return t.filter(t=>!t.trigger||!e||((0,o.cy)(t.trigger)?t.trigger.includes(e):t.trigger===e)).map(({trigger:e,...t})=>t)},V=(0,n.EW)(()=>I.value.some(e=>e.required)),P=(0,n.EW)(()=>{var e;return"error"===g.value&&l.showMessage&&(null==(e=null==s?void 0:s.showMessage)||e)}),$=(0,n.EW)(()=>`${l.label||""}${(null==s?void 0:s.labelSuffix)||""}`),H=e=>{h.value=e},j=e=>{var t,n;const{errors:a,fields:o}=e;a&&o||console.error(e),H("error"),b.value=a?null!=(n=null==(t=null==a?void 0:a[0])?void 0:t.message)?n:`${l.prop} is required`:"",null==s||s.emit("validate",l.prop,!1,b.value)},K=()=>{H("success"),null==s||s.emit("validate",l.prop,!0,"")},X=async e=>{const t=N.value,l=new Re({[t]:e});return l.validate({[t]:B.value},{firstFields:!0}).then(()=>(K(),!0)).catch(e=>(j(e),Promise.reject(e)))},U=async(e,t)=>{if(x||!l.prop)return!1;const n=(0,o.Tn)(t);if(!D.value)return null==t||t(!1),!1;const a=F(e);return 0===a.length?(null==t||t(!0),!0):(H("validating"),X(a).then(()=>(null==t||t(!0),!0)).catch(e=>{const{fields:l}=e;return null==t||t(!1,l),!n&&Promise.reject(l)}))},q=()=>{H(""),b.value="",x=!1},G=async()=>{const e=null==s?void 0:s.model;if(!e||!l.prop)return;const t=(0,De.GT)(e,l.prop);x=!0,t.value=Ae(L),await(0,n.dY)(),q(),x=!1},Y=e=>{v.value.includes(e)||v.value.push(e)},Q=e=>{v.value=v.value.filter(t=>t!==e)};(0,n.wB)(()=>l.error,e=>{b.value=e||"",H(e?"error":"")},{immediate:!0}),(0,n.wB)(()=>l.validateStatus,e=>H(e||""));const Z=(0,a.Kh)({...(0,a.QW)(l),$el:w,size:d,validateMessage:b,validateState:h,labelId:m,inputIds:v,isGroup:O,hasLabel:_,fieldValue:B,addInputId:Y,removeInputId:Q,resetField:G,clearValidate:q,validate:U,propString:N});return(0,n.Gt)(c.w,Z),(0,n.sV)(()=>{l.prop&&(null==s||s.addField(Z),L=Ae(B.value))}),(0,n.xo)(()=>{null==s||s.removeField(Z)}),t({size:d,validateMessage:b,validateState:h,validate:U,clearValidate:q,resetField:G}),(e,t)=>{var l;return(0,n.uX)(),(0,n.CE)("div",{ref_key:"formItemRef",ref:w,class:(0,o.C4)((0,a.R1)(S)),role:(0,a.R1)(O)?"group":void 0,"aria-labelledby":(0,a.R1)(O)?(0,a.R1)(m):void 0},[(0,n.bF)((0,a.R1)(Be),{"is-auto-width":"auto"===(0,a.R1)(R).width,"update-all":"auto"===(null==(l=(0,a.R1)(s))?void 0:l.labelWidth)},{default:(0,n.k6)(()=>[e.label||e.$slots.label?((0,n.uX)(),(0,n.Wv)((0,n.$y)((0,a.R1)(T)?"label":"div"),{key:0,id:(0,a.R1)(m),for:(0,a.R1)(T),class:(0,o.C4)((0,a.R1)(f).e("label")),style:(0,o.Tr)((0,a.R1)(R))},{default:(0,n.k6)(()=>[(0,n.RG)(e.$slots,"label",{label:(0,a.R1)($)},()=>[(0,n.eW)((0,o.v_)((0,a.R1)($)),1)])]),_:3},8,["id","for","class","style"])):(0,n.Q3)("v-if",!0)]),_:3},8,["is-auto-width","update-all"]),(0,n.Lk)("div",{class:(0,o.C4)((0,a.R1)(f).e("content")),style:(0,o.Tr)((0,a.R1)(k))},[(0,n.RG)(e.$slots,"default"),(0,n.bF)(z.F,{name:`${(0,a.R1)(f).namespace.value}-zoom-in-top`},{default:(0,n.k6)(()=>[(0,a.R1)(P)?(0,n.RG)(e.$slots,"error",{key:0,error:b.value},()=>[(0,n.Lk)("div",{class:(0,o.C4)((0,a.R1)(A))},(0,o.v_)(b.value),3)]):(0,n.Q3)("v-if",!0)]),_:3},8,["name"])],6)],10,["role","aria-labelledby"])}}});var $e=(0,b.A)(Pe,[["__file","form-item.vue"]]),He=l(5376);const je=(0,He.GU)(M,{FormItem:$e}),Ke=(0,He.WM)($e)},2056:function(e,t,l){"use strict";l.d(t,{YU:function(){return a},l4:function(){return n},qs:function(){return o}});const n="update:modelValue",a="change",o="input"},2086:function(e,t,l){"use strict";l.d(t,{dW:function(){return we},c6:function(){return Le},Iy:function(){return xe}});var n=l(6768),a=l(144),o=l(4232),c=l(47),r=l(8507),s=l(8559),i=l(813),u=(l(8111),l(2489),l(116),l(1701),l(7687)),d=l(9077);const f=(0,n.pM)({inheritAttrs:!1});function p(e,t,l,a,o,c){return(0,n.RG)(e.$slots,"default")}var m=(0,d.A)(f,[["render",p],["__file","collection.vue"]]);const v=(0,n.pM)({name:"ElCollectionItem",inheritAttrs:!1});function h(e,t,l,a,o,c){return(0,n.RG)(e.$slots,"default")}var g=(0,d.A)(v,[["render",h],["__file","collection-item.vue"]]);const b="data-el-collection-item",y=e=>{const t=`El${e}Collection`,l=`${t}Item`,o=Symbol(t),c=Symbol(l),r={...m,name:t,setup(){const e=(0,a.KR)(),t=new Map,l=()=>{const l=(0,a.R1)(e);if(!l)return[];const n=Array.from(l.querySelectorAll(`[${b}]`)),o=[...t.values()];return o.sort((e,t)=>n.indexOf(e.ref)-n.indexOf(t.ref))};(0,n.Gt)(o,{itemMap:t,getItems:l,collectionRef:e})}},s={...g,name:l,setup(e,{attrs:t}){const l=(0,a.KR)(),r=(0,n.WQ)(o,void 0);(0,n.Gt)(c,{collectionItemRef:l}),(0,n.sV)(()=>{const e=(0,a.R1)(l);e&&r.itemMap.set(e,{ref:e,...t})}),(0,n.xo)(()=>{const e=(0,a.R1)(l);r.itemMap.delete(e)})}};return{COLLECTION_INJECTION_KEY:o,COLLECTION_ITEM_INJECTION_KEY:c,ElCollection:r,ElCollectionItem:s}};var C=l(7378);const w=(0,C.b_)({style:{type:(0,C.jq)([String,Array,Object])},currentTabId:{type:(0,C.jq)(String)},defaultCurrentTabId:String,loop:Boolean,dir:{type:String,values:["ltr","rtl"],default:"ltr"},orientation:{type:(0,C.jq)(String)},onBlur:Function,onFocus:Function,onMousedown:Function}),{ElCollection:L,ElCollectionItem:x,COLLECTION_INJECTION_KEY:M,COLLECTION_ITEM_INJECTION_KEY:z}=y("RovingFocusGroup"),R=Symbol("elRovingFocusGroup"),k=Symbol("elRovingFocusGroupItem");var S=l(4225),E=l(515);const A={ArrowLeft:"prev",ArrowUp:"prev",ArrowRight:"next",ArrowDown:"next",PageUp:"first",Home:"first",PageDown:"last",End:"last"},N=(e,t)=>{if("rtl"!==t)return e;switch(e){case E.R.right:return E.R.left;case E.R.left:return E.R.right;default:return e}},_=(e,t,l)=>{const n=(0,S.CG)(e),a=N(n,l);if(("vertical"!==t||![E.R.left,E.R.right].includes(a))&&("horizontal"!==t||![E.R.up,E.R.down].includes(a)))return A[a]},T=(e,t)=>e.map((l,n)=>e[(n+t)%e.length]),O=e=>{const{activeElement:t}=document;for(const l of e){if(l===t)return;if(l.focus(),t!==document.activeElement)return}},W="currentTabIdChange",B="rovingFocusGroup.entryFocus",I={bubbles:!1,cancelable:!0},D=(0,n.pM)({name:"ElRovingFocusGroupImpl",inheritAttrs:!1,props:w,emits:[W,"entryFocus"],setup(e,{emit:t}){var l;const o=(0,a.KR)(null!=(l=e.currentTabId||e.defaultCurrentTabId)?l:null),c=(0,a.KR)(!1),r=(0,a.KR)(!1),s=(0,a.KR)(),{getItems:i}=(0,n.WQ)(M,void 0),d=(0,n.EW)(()=>[{outline:"none"},e.style]),f=e=>{t(W,e)},p=()=>{c.value=!0},m=(0,S.mK)(t=>{var l;null==(l=e.onMousedown)||l.call(e,t)},()=>{r.value=!0}),v=(0,S.mK)(t=>{var l;null==(l=e.onFocus)||l.call(e,t)},e=>{const t=!(0,a.R1)(r),{target:l,currentTarget:n}=e;if(l===n&&t&&!(0,a.R1)(c)){const e=new Event(B,I);if(null==n||n.dispatchEvent(e),!e.defaultPrevented){const e=i().filter(e=>e.focusable),t=e.find(e=>e.active),l=e.find(e=>e.id===(0,a.R1)(o)),n=[t,l,...e].filter(Boolean),c=n.map(e=>e.ref);O(c)}}r.value=!1}),h=(0,S.mK)(t=>{var l;null==(l=e.onBlur)||l.call(e,t)},()=>{c.value=!1}),g=(...e)=>{t("entryFocus",...e)},b=t=>{const l=_(t);if(l){t.preventDefault();const a=i().filter(e=>e.focusable);let o=a.map(e=>e.ref);switch(l){case"last":o.reverse();break;case"prev":case"next":{"prev"===l&&o.reverse();const n=o.indexOf(t.currentTarget);o=e.loop?T(o,n+1):o.slice(n+1);break}}(0,n.dY)(()=>{O(o)})}};(0,n.Gt)(R,{currentTabbedId:(0,a.tB)(o),loop:(0,a.lW)(e,"loop"),tabIndex:(0,n.EW)(()=>(0,a.R1)(c)?-1:0),rovingFocusGroupRef:s,rovingFocusGroupRootStyle:d,orientation:(0,a.lW)(e,"orientation"),dir:(0,a.lW)(e,"dir"),onItemFocus:f,onItemShiftTab:p,onBlur:h,onFocus:v,onMousedown:m,onKeydown:b}),(0,n.wB)(()=>e.currentTabId,e=>{o.value=null!=e?e:null}),(0,u.MLh)(s,B,g)}});function F(e,t,l,a,o,c){return(0,n.RG)(e.$slots,"default")}var V=(0,d.A)(D,[["render",F],["__file","roving-focus-group-impl.vue"]]);const P=(0,n.pM)({name:"ElRovingFocusGroup",components:{ElFocusGroupCollection:L,ElRovingFocusGroupImpl:V}});function $(e,t,l,a,c,r){const s=(0,n.g2)("el-roving-focus-group-impl"),i=(0,n.g2)("el-focus-group-collection");return(0,n.uX)(),(0,n.Wv)(i,null,{default:(0,n.k6)(()=>[(0,n.bF)(s,(0,o._B)((0,n.Ng)(e.$attrs)),{default:(0,n.k6)(()=>[(0,n.RG)(e.$slots,"default")]),_:3},16)]),_:3})}var H=(0,d.A)(P,[["render",$],["__file","roving-focus-group.vue"]]),j=l(7477),K=l(3219);const X=Symbol("elDropdown"),U="elDropdown";var q=l(3158),G=l(3513),Y=l(6268),Q=l(3558),Z=l(5951),J=l(1305),ee=l(2436);const{ButtonGroup:te}=c.S2,le=(0,n.pM)({name:"ElDropdown",components:{ElButton:c.S2,ElButtonGroup:te,ElScrollbar:s.kA,ElTooltip:r.R7,ElRovingFocusGroup:H,ElOnlyChild:q.D,ElIcon:i.tk,ArrowDown:j.ArrowDown},props:K.Qy,emits:["visible-change","click","command"],setup(e,{emit:t}){const l=(0,n.nI)(),o=(0,G.DU)("dropdown"),{t:c}=(0,Y.Ym)(),r=(0,a.KR)(),s=(0,a.KR)(),i=(0,a.KR)(),u=(0,a.KR)(),d=(0,a.KR)(null),f=(0,a.KR)(null),p=(0,a.KR)(!1),m=(0,n.EW)(()=>({maxHeight:(0,Q._V)(e.maxHeight)})),v=(0,n.EW)(()=>[o.m(L.value)]),h=(0,n.EW)(()=>(0,Z.A)(e.trigger)),g=(0,J.Bi)().value,b=(0,n.EW)(()=>e.id||g);function y(){var e;null==(e=i.value)||e.onClose(void 0,0)}function C(){var e;null==(e=i.value)||e.onClose()}function w(){var e;null==(e=i.value)||e.onOpen()}const L=(0,ee.NV)();function x(...e){t("command",...e)}function M(){}function z(){const e=(0,a.R1)(u);h.value.includes("hover")&&(null==e||e.focus({preventScroll:!0})),f.value=null}function R(e){f.value=e}function k(){t("visible-change",!0)}function S(e){var t;p.value="keydown"===(null==e?void 0:e.type),null==(t=u.value)||t.focus()}function E(){t("visible-change",!1)}(0,n.Gt)(X,{contentRef:u,role:(0,n.EW)(()=>e.role),triggerId:b,isUsingKeyboard:p,onItemEnter:M,onItemLeave:z,handleClose:C}),(0,n.Gt)(U,{instance:l,dropdownSize:L,handleClick:y,commandHandler:x,trigger:(0,a.lW)(e,"trigger"),hideOnClick:(0,a.lW)(e,"hideOnClick")});const A=e=>{t("click",e)};return{t:c,ns:o,scrollbar:d,wrapStyle:m,dropdownTriggerKls:v,dropdownSize:L,triggerId:b,currentTabId:f,handleCurrentTabIdChange:R,handlerMainButtonClick:A,handleClose:C,handleOpen:w,handleBeforeShowTooltip:k,handleShowTooltip:S,handleBeforeHideTooltip:E,popperRef:i,contentRef:u,triggeringElementRef:r,referenceElementRef:s}}});function ne(e,t,l,a,c,r){var s;const i=(0,n.g2)("el-roving-focus-group"),u=(0,n.g2)("el-scrollbar"),d=(0,n.g2)("el-only-child"),f=(0,n.g2)("el-tooltip"),p=(0,n.g2)("el-button"),m=(0,n.g2)("arrow-down"),v=(0,n.g2)("el-icon"),h=(0,n.g2)("el-button-group");return(0,n.uX)(),(0,n.CE)("div",{class:(0,o.C4)([e.ns.b(),e.ns.is("disabled",e.disabled)])},[(0,n.bF)(f,{ref:"popperRef",role:e.role,effect:e.effect,"fallback-placements":["bottom","top"],"popper-options":e.popperOptions,"gpu-acceleration":!1,placement:e.placement,"popper-class":[e.ns.e("popper"),e.popperClass],"popper-style":e.popperStyle,trigger:e.trigger,"trigger-keys":e.triggerKeys,"trigger-target-el":e.contentRef,"show-arrow":e.showArrow,"show-after":"hover"===e.trigger?e.showTimeout:0,"hide-after":"hover"===e.trigger?e.hideTimeout:0,"virtual-ref":null!=(s=e.virtualRef)?s:e.triggeringElementRef,"virtual-triggering":e.virtualTriggering||e.splitButton,disabled:e.disabled,transition:`${e.ns.namespace.value}-zoom-in-top`,teleported:e.teleported,pure:"","focus-on-target":"",persistent:e.persistent,onBeforeShow:e.handleBeforeShowTooltip,onShow:e.handleShowTooltip,onBeforeHide:e.handleBeforeHideTooltip},(0,n.eX)({content:(0,n.k6)(()=>[(0,n.bF)(u,{ref:"scrollbar","wrap-style":e.wrapStyle,tag:"div","view-class":e.ns.e("list")},{default:(0,n.k6)(()=>[(0,n.bF)(i,{loop:e.loop,"current-tab-id":e.currentTabId,orientation:"horizontal",onCurrentTabIdChange:e.handleCurrentTabIdChange},{default:(0,n.k6)(()=>[(0,n.RG)(e.$slots,"dropdown")]),_:3},8,["loop","current-tab-id","onCurrentTabIdChange"])]),_:3},8,["wrap-style","view-class"])]),_:2},[e.splitButton?void 0:{name:"default",fn:(0,n.k6)(()=>[(0,n.bF)(d,{id:e.triggerId,ref:"triggeringElementRef",role:"button",tabindex:e.tabindex},{default:(0,n.k6)(()=>[(0,n.RG)(e.$slots,"default")]),_:3},8,["id","tabindex"])])}]),1032,["role","effect","popper-options","placement","popper-class","popper-style","trigger","trigger-keys","trigger-target-el","show-arrow","show-after","hide-after","virtual-ref","virtual-triggering","disabled","transition","teleported","persistent","onBeforeShow","onShow","onBeforeHide"]),e.splitButton?((0,n.uX)(),(0,n.Wv)(h,{key:0},{default:(0,n.k6)(()=>[(0,n.bF)(p,(0,n.v6)({ref:"referenceElementRef"},e.buttonProps,{size:e.dropdownSize,type:e.type,disabled:e.disabled,tabindex:e.tabindex,onClick:e.handlerMainButtonClick}),{default:(0,n.k6)(()=>[(0,n.RG)(e.$slots,"default")]),_:3},16,["size","type","disabled","tabindex","onClick"]),(0,n.bF)(p,(0,n.v6)({id:e.triggerId,ref:"triggeringElementRef"},e.buttonProps,{role:"button",size:e.dropdownSize,type:e.type,class:e.ns.e("caret-button"),disabled:e.disabled,tabindex:e.tabindex,"aria-label":e.t("el.dropdown.toggleDropdown")}),{default:(0,n.k6)(()=>[(0,n.bF)(v,{class:(0,o.C4)(e.ns.e("icon"))},{default:(0,n.k6)(()=>[(0,n.bF)(m)]),_:1},8,["class"])]),_:1},16,["id","size","type","class","disabled","tabindex","aria-label"])]),_:3})):(0,n.Q3)("v-if",!0)],2)}var ae=(0,d.A)(le,[["render",ne],["__file","dropdown.vue"]]);const oe=(0,n.pM)({components:{ElRovingFocusCollectionItem:x},props:{focusable:{type:Boolean,default:!0},active:Boolean},emits:["mousedown","focus","keydown"],setup(e,{emit:t}){const{currentTabbedId:l,onItemFocus:o,onItemShiftTab:c,onKeydown:r}=(0,n.WQ)(R,void 0),s=(0,J.Bi)(),i=(0,a.KR)(),u=(0,S.mK)(e=>{t("mousedown",e)},t=>{e.focusable?o((0,a.R1)(s)):t.preventDefault()}),d=(0,S.mK)(e=>{t("focus",e)},()=>{o((0,a.R1)(s))}),f=(0,S.mK)(e=>{t("keydown",e)},e=>{const{shiftKey:t,target:l,currentTarget:n}=e,a=(0,S.CG)(e);a===E.R.tab&&t?c():l===n&&r(e)}),p=(0,n.EW)(()=>l.value===(0,a.R1)(s));return(0,n.Gt)(k,{rovingFocusGroupItemRef:i,tabIndex:(0,n.EW)(()=>(0,a.R1)(p)?0:-1),handleMousedown:u,handleFocus:d,handleKeydown:f}),{id:s,handleKeydown:f,handleFocus:d,handleMousedown:u}}});function ce(e,t,l,a,o,c){const r=(0,n.g2)("el-roving-focus-collection-item");return(0,n.uX)(),(0,n.Wv)(r,{id:e.id,focusable:e.focusable,active:e.active},{default:(0,n.k6)(()=>[(0,n.RG)(e.$slots,"default")]),_:3},8,["id","focusable","active"])}var re=(0,d.A)(oe,[["render",ce],["__file","roving-focus-item.vue"]]),se=l(5130),ie=l(4425);const ue=(0,n.pM)({name:"DropdownItemImpl",components:{ElIcon:i.tk},props:K.dv,emits:["pointermove","pointerleave","click","clickimpl"],setup(e,{emit:t}){const l=(0,G.DU)("dropdown"),{role:a}=(0,n.WQ)(X,void 0),{collectionItemRef:o}=(0,n.WQ)(z,void 0),{rovingFocusGroupItemRef:c,tabIndex:r,handleFocus:s,handleKeydown:i,handleMousedown:u}=(0,n.WQ)(k,void 0),d=(0,ie.t)(o,c),f=(0,n.EW)(()=>"menu"===a.value?"menuitem":"navigation"===a.value?"link":"button"),p=(0,S.mK)(e=>{const l=(0,S.CG)(e);if([E.R.enter,E.R.numpadEnter,E.R.space].includes(l))return e.preventDefault(),e.stopImmediatePropagation(),t("clickimpl",e),!0},i);return{ns:l,itemRef:d,dataset:{[b]:""},role:f,tabIndex:r,handleFocus:s,handleKeydown:p,handleMousedown:u}}});function de(e,t,l,a,c,r){const s=(0,n.g2)("el-icon");return(0,n.uX)(),(0,n.CE)(n.FK,null,[e.divided?((0,n.uX)(),(0,n.CE)("li",{key:0,role:"separator",class:(0,o.C4)(e.ns.bem("menu","item","divided"))},null,2)):(0,n.Q3)("v-if",!0),(0,n.Lk)("li",(0,n.v6)({ref:e.itemRef},{...e.dataset,...e.$attrs},{"aria-disabled":e.disabled,class:[e.ns.be("menu","item"),e.ns.is("disabled",e.disabled)],tabindex:e.tabIndex,role:e.role,onClick:t=>e.$emit("clickimpl",t),onFocus:e.handleFocus,onKeydown:(0,se.D$)(e.handleKeydown,["self"]),onMousedown:e.handleMousedown,onPointermove:t=>e.$emit("pointermove",t),onPointerleave:t=>e.$emit("pointerleave",t)}),[e.icon?((0,n.uX)(),(0,n.Wv)(s,{key:0},{default:(0,n.k6)(()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)(e.icon)))]),_:1})):(0,n.Q3)("v-if",!0),(0,n.RG)(e.$slots,"default")],16,["aria-disabled","tabindex","role","onClick","onFocus","onKeydown","onMousedown","onPointermove","onPointerleave"])],64)}var fe=(0,d.A)(ue,[["render",de],["__file","dropdown-item-impl.vue"]]);const pe=()=>{const e=(0,n.WQ)(U,{}),t=(0,n.EW)(()=>null==e?void 0:e.dropdownSize);return{elDropdown:e,_elDropdownSize:t}},me=(0,n.pM)({name:"ElDropdownItem",components:{ElRovingFocusItem:re,ElDropdownItemImpl:fe},inheritAttrs:!1,props:K.dv,emits:["pointermove","pointerleave","click"],setup(e,{emit:t,attrs:l}){const{elDropdown:a}=pe(),o=(0,n.nI)(),{onItemEnter:c,onItemLeave:r}=(0,n.WQ)(X,void 0),s=(0,S.mK)(e=>(t("pointermove",e),e.defaultPrevented),(0,S.Iv)(t=>{if(e.disabled)return void r(t);const l=t.currentTarget;l===document.activeElement||l.contains(document.activeElement)||(c(t),t.defaultPrevented||null==l||l.focus({preventScroll:!0}))})),i=(0,S.mK)(e=>(t("pointerleave",e),e.defaultPrevented),(0,S.Iv)(r)),u=(0,S.mK)(l=>{if(!e.disabled)return t("click",l),"keydown"!==l.type&&l.defaultPrevented},t=>{var l,n,c;e.disabled?t.stopImmediatePropagation():((null==(l=null==a?void 0:a.hideOnClick)?void 0:l.value)&&(null==(n=a.handleClick)||n.call(a)),null==(c=a.commandHandler)||c.call(a,e.command,o,t))}),d=(0,n.EW)(()=>({...e,...l}));return{handleClick:u,handlePointerMove:s,handlePointerLeave:i,propsAndAttrs:d}}});function ve(e,t,l,a,o,c){const r=(0,n.g2)("el-dropdown-item-impl"),s=(0,n.g2)("el-roving-focus-item");return(0,n.uX)(),(0,n.Wv)(s,{focusable:!e.disabled},{default:(0,n.k6)(()=>[(0,n.bF)(r,(0,n.v6)(e.propsAndAttrs,{onPointerleave:e.handlePointerLeave,onPointermove:e.handlePointerMove,onClickimpl:e.handleClick}),{default:(0,n.k6)(()=>[(0,n.RG)(e.$slots,"default")]),_:3},16,["onPointerleave","onPointermove","onClickimpl"])]),_:3},8,["focusable"])}var he=(0,d.A)(me,[["render",ve],["__file","dropdown-item.vue"]]);const ge=(0,n.pM)({name:"ElDropdownMenu",props:K.hR,setup(e){const t=(0,G.DU)("dropdown"),{_elDropdownSize:l}=pe(),a=l.value,{contentRef:o,role:c,triggerId:r,isUsingKeyboard:s,handleClose:i}=(0,n.WQ)(X,void 0),{rovingFocusGroupRef:u,rovingFocusGroupRootStyle:d,onBlur:f,onFocus:p,onKeydown:m,onMousedown:v}=(0,n.WQ)(R,void 0),{collectionRef:h}=(0,n.WQ)(M,void 0),g=(0,n.EW)(()=>[t.b("menu"),t.bm("menu",null==a?void 0:a.value)]),b=(0,ie.t)(o,u,h),y=(0,S.mK)(t=>{var l;null==(l=e.onKeydown)||l.call(e,t)},e=>{const{currentTarget:t,target:l}=e,n=(0,S.CG)(e);if(t.contains(l),E.R.tab===n)return i();m(e)});function C(e){s.value&&p(e)}return{size:a,rovingFocusGroupRootStyle:d,dropdownKls:g,role:c,triggerId:r,dropdownListWrapperRef:b,handleKeydown:y,onBlur:f,handleFocus:C,onMousedown:v}}});function be(e,t,l,a,c,r){return(0,n.uX)(),(0,n.CE)("ul",{ref:e.dropdownListWrapperRef,class:(0,o.C4)(e.dropdownKls),style:(0,o.Tr)(e.rovingFocusGroupRootStyle),tabindex:-1,role:e.role,"aria-labelledby":e.triggerId,onFocusin:e.handleFocus,onFocusout:e.onBlur,onKeydown:(0,se.D$)(e.handleKeydown,["self"]),onMousedown:(0,se.D$)(e.onMousedown,["self"])},[(0,n.RG)(e.$slots,"default")],46,["role","aria-labelledby","onFocusin","onFocusout","onKeydown","onMousedown"])}var ye=(0,d.A)(ge,[["render",be],["__file","dropdown-menu.vue"]]),Ce=l(5376);const we=(0,Ce.GU)(ae,{DropdownItem:he,DropdownMenu:ye}),Le=(0,Ce.WM)(he),xe=(0,Ce.WM)(ye)},2099:function(e,t,l){"use strict";l(5331)},2106:function(e,t,l){"use strict";var n=l(283),a=l(4913);e.exports=function(e,t,l){return l.get&&n(l.get,t,{getter:!0}),l.set&&n(l.set,t,{setter:!0}),a.f(e,t,l)}},2132:function(e,t,l){"use strict";var n=l(1821),a=l(9092),o=l(1801),c=l(6054),r=Object.getOwnPropertySymbols,s=r?function(e){var t=[];while(e)(0,n.A)(t,(0,o.A)(e)),e=(0,a.A)(e);return t}:c.A;t.A=s},2140:function(e,t,l){"use strict";var n=l(8227),a=n("toStringTag"),o={};o[a]="z",e.exports="[object z]"===String(o)},2142:function(e,t,l){"use strict";l.d(t,{A:function(){return s}});l(4114),l(8111),l(3579);var n=l(17),a=l(4232),o=l(2235);const c=new Map;if(n.oc){let e;document.addEventListener("mousedown",t=>e=t),document.addEventListener("mouseup",t=>{if(e){for(const l of c.values())for(const{documentHandler:n}of l)n(t,e);e=void 0}})}function r(e,t){let l=[];return(0,a.cy)(t.arg)?l=t.arg:(0,o.vq)(t.arg)&&l.push(t.arg),function(n,a){const o=t.instance.popperRef,c=n.target,r=null==a?void 0:a.target,s=!t||!t.instance,i=!c||!r,u=e.contains(c)||e.contains(r),d=e===c,f=l.length&&l.some(e=>null==e?void 0:e.contains(c))||l.length&&l.includes(r),p=o&&(o.contains(c)||o.contains(r));s||i||u||d||f||p||t.value(n,a)}}const s={beforeMount(e,t){c.has(e)||c.set(e,[]),c.get(e).push({documentHandler:r(e,t),bindingFn:t.value})},updated(e,t){c.has(e)||c.set(e,[]);const l=c.get(e),n=l.findIndex(e=>e.bindingFn===t.oldValue),a={documentHandler:r(e,t),bindingFn:t.value};n>=0?l.splice(n,1,a):l.push(a)},unmounted(e){c.delete(e)}}},2195:function(e,t,l){"use strict";var n=l(9504),a=n({}.toString),o=n("".slice);e.exports=function(e){return o(a(e),8,-1)}},2211:function(e,t,l){"use strict";var n=l(9039);e.exports=!n(function(){function e(){}return e.prototype.constructor=null,Object.getPrototypeOf(new e)!==e.prototype})},2235:function(e,t,l){"use strict";l.d(t,{Et:function(){return r},Hp:function(){return d},Im:function(){return s},Lm:function(){return c},Xj:function(){return u},b0:function(){return o},l6:function(){return f},vq:function(){return i}});var n=l(4232),a=l(6032);const o=e=>void 0===e,c=e=>"boolean"===typeof e,r=e=>"number"===typeof e,s=e=>!e&&0!==e||(0,n.cy)(e)&&0===e.length||(0,n.Gv)(e)&&!Object.keys(e).length,i=e=>"undefined"!==typeof Element&&e instanceof Element,u=e=>(0,a.A)(e),d=e=>!!(0,n.Kg)(e)&&!Number.isNaN(Number(e)),f=e=>e===window},2251:function(e,t,l){"use strict";l.d(t,{E:function(){return s}});var n=l(5420),a=l(8782),o=l(8299),c=l(7378),r=l(8501);const s=(0,c.b_)({...n.m,...a.yh,appendTo:{type:o.k.to.type},content:{type:String,default:""},rawContent:Boolean,persistent:Boolean,visible:{type:(0,c.jq)(Boolean),default:null},transition:String,teleported:{type:Boolean,default:!0},disabled:Boolean,...(0,r.l)(["ariaLabel"])})},2261:function(e,t,l){"use strict";l.d(t,{ZH:function(){return o},qr:function(){return a}});var n=l(4232);const a=(e="")=>e.replace(/[|\\{}()[\]^$+*?.]/g,"\\$&").replace(/-/g,"\\x2d"),o=e=>(0,n.ZH)(e)},2303:function(e,t,l){"use strict";var n=l(4576),a=l(9504),o=n.Uint8Array,c=n.SyntaxError,r=n.parseInt,s=Math.min,i=/[^\da-f]/i,u=a(i.exec),d=a("".slice);e.exports=function(e,t){var l=e.length;if(l%2!==0)throw new c("String should be an even number of characters");var n=t?s(t.length,l/2):l/2,a=t||new o(n),f=0,p=0;while(p0&&l(s)?t>1?u(s,t-1,l,a,o):(0,n.A)(o,s):a||(o[o.length]=s)}return o}var d=u},2317:function(e,t,l){l(8111),l(1701),function(t,l){e.exports=l()}(0,function(){"use strict";return function(e,t,l){var n=t.prototype,a=function(e){return e&&(e.indexOf?e:e.s)},o=function(e,t,l,n,o){var c=e.name?e:e.$locale(),r=a(c[t]),s=a(c[l]),i=r||s.map(function(e){return e.slice(0,n)});if(!o)return i;var u=c.weekStart;return i.map(function(e,t){return i[(t+(u||0))%7]})},c=function(){return l.Ls[l.locale()]},r=function(e,t){return e.formats[t]||function(e){return e.replace(/(\[[^\]]+])|(MMMM|MM|DD|dddd)/g,function(e,t,l){return t||l.slice(1)})}(e.formats[t.toUpperCase()])},s=function(){var e=this;return{months:function(t){return t?t.format("MMMM"):o(e,"months")},monthsShort:function(t){return t?t.format("MMM"):o(e,"monthsShort","months",3)},firstDayOfWeek:function(){return e.$locale().weekStart||0},weekdays:function(t){return t?t.format("dddd"):o(e,"weekdays")},weekdaysMin:function(t){return t?t.format("dd"):o(e,"weekdaysMin","weekdays",2)},weekdaysShort:function(t){return t?t.format("ddd"):o(e,"weekdaysShort","weekdays",3)},longDateFormat:function(t){return r(e.$locale(),t)},meridiem:this.$locale().meridiem,ordinal:this.$locale().ordinal}};n.localeData=function(){return s.bind(this)()},l.localeData=function(){var e=c();return{firstDayOfWeek:function(){return e.weekStart||0},weekdays:function(){return l.weekdays()},weekdaysShort:function(){return l.weekdaysShort()},weekdaysMin:function(){return l.weekdaysMin()},months:function(){return l.months()},monthsShort:function(){return l.monthsShort()},longDateFormat:function(t){return r(e,t)},meridiem:e.meridiem,ordinal:e.ordinal}},l.months=function(){return o(c(),"months")},l.monthsShort=function(){return o(c(),"monthsShort","months",3)},l.weekdays=function(e){return o(c(),"weekdays",null,null,e)},l.weekdaysShort=function(e){return o(c(),"weekdaysShort","weekdays",3,e)},l.weekdaysMin=function(e){return o(c(),"weekdaysMin","weekdays",2,e)}}})},2353:function(e,t,l){"use strict";l.d(t,{X7I:function(){return SW}}); /*! * Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com * License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License) @@ -26,7 +26,7 @@ function n(e){const t=Object.create(null);for(const l of e.split(","))t[l]=1;ret * (c) 2018-present Yuxi (Evan) You and Vue contributors * @license MIT **/ -let c;const r="undefined"!==typeof window&&window.trustedTypes;if(r)try{c=r.createPolicy("vue",{createHTML:e=>e})}catch(Ke){}const s=c?e=>c.createHTML(e):e=>e,i="http://www.w3.org/2000/svg",u="http://www.w3.org/1998/Math/MathML",d="undefined"!==typeof document?document:null,f=d&&d.createElement("template"),p={insert:(e,t,l)=>{t.insertBefore(e,l||null)},remove:e=>{const t=e.parentNode;t&&t.removeChild(e)},createElement:(e,t,l,n)=>{const a="svg"===t?d.createElementNS(i,e):"mathml"===t?d.createElementNS(u,e):l?d.createElement(e,{is:l}):d.createElement(e);return"select"===e&&n&&null!=n.multiple&&a.setAttribute("multiple",n.multiple),a},createText:e=>d.createTextNode(e),createComment:e=>d.createComment(e),setText:(e,t)=>{e.nodeValue=t},setElementText:(e,t)=>{e.textContent=t},parentNode:e=>e.parentNode,nextSibling:e=>e.nextSibling,querySelector:e=>d.querySelector(e),setScopeId(e,t){e.setAttribute(t,"")},insertStaticContent(e,t,l,n,a,o){const c=l?l.previousSibling:t.lastChild;if(a&&(a===o||a.nextSibling)){while(1)if(t.insertBefore(a.cloneNode(!0),l),a===o||!(a=a.nextSibling))break}else{f.innerHTML=s("svg"===n?`${e}`:"mathml"===n?`${e}`:e);const a=f.content;if("svg"===n||"mathml"===n){const e=a.firstChild;while(e.firstChild)a.appendChild(e.firstChild);a.removeChild(e)}t.insertBefore(a,l)}return[c?c.nextSibling:t.firstChild,l?l.previousSibling:t.lastChild]}},m="transition",v="animation",h=Symbol("_vtc"),g={name:String,type:String,css:{type:Boolean,default:!0},duration:[String,Number,Object],enterFromClass:String,enterActiveClass:String,enterToClass:String,appearFromClass:String,appearActiveClass:String,appearToClass:String,leaveFromClass:String,leaveActiveClass:String,leaveToClass:String},b=(0,a.X$)({},n.QP,g),y=e=>(e.displayName="Transition",e.props=b,e),C=y((e,{slots:t})=>(0,n.h)(n.pR,x(e),t)),w=(e,t=[])=>{(0,a.cy)(e)?e.forEach(e=>e(...t)):e&&e(...t)},L=e=>!!e&&((0,a.cy)(e)?e.some(e=>e.length>1):e.length>1);function x(e){const t={};for(const a in e)a in g||(t[a]=e[a]);if(!1===e.css)return t;const{name:l="v",type:n,duration:o,enterFromClass:c=`${l}-enter-from`,enterActiveClass:r=`${l}-enter-active`,enterToClass:s=`${l}-enter-to`,appearFromClass:i=c,appearActiveClass:u=r,appearToClass:d=s,leaveFromClass:f=`${l}-leave-from`,leaveActiveClass:p=`${l}-leave-active`,leaveToClass:m=`${l}-leave-to`}=e,v=M(o),h=v&&v[0],b=v&&v[1],{onBeforeEnter:y,onEnter:C,onEnterCancelled:x,onLeave:z,onLeaveCancelled:E,onBeforeAppear:N=y,onAppear:_=C,onAppearCancelled:T=x}=t,W=(e,t,l,n)=>{e._enterCancelled=n,k(e,t?d:s),k(e,t?u:r),l&&l()},B=(e,t)=>{e._isLeaving=!1,k(e,f),k(e,m),k(e,p),t&&t()},I=e=>(t,l)=>{const a=e?_:C,o=()=>W(t,e,l);w(a,[t,o]),S(()=>{k(t,e?i:c),R(t,e?d:s),L(a)||A(t,n,h,o)})};return(0,a.X$)(t,{onBeforeEnter(e){w(y,[e]),R(e,c),R(e,r)},onBeforeAppear(e){w(N,[e]),R(e,i),R(e,u)},onEnter:I(!1),onAppear:I(!0),onLeave(e,t){e._isLeaving=!0;const l=()=>B(e,t);R(e,f),e._enterCancelled?(R(e,p),O(e)):(O(e),R(e,p)),S(()=>{e._isLeaving&&(k(e,f),R(e,m),L(z)||A(e,n,b,l))}),w(z,[e,l])},onEnterCancelled(e){W(e,!1,void 0,!0),w(x,[e])},onAppearCancelled(e){W(e,!0,void 0,!0),w(T,[e])},onLeaveCancelled(e){B(e),w(E,[e])}})}function M(e){if(null==e)return null;if((0,a.Gv)(e))return[z(e.enter),z(e.leave)];{const t=z(e);return[t,t]}}function z(e){const t=(0,a.Ro)(e);return t}function R(e,t){t.split(/\s+/).forEach(t=>t&&e.classList.add(t)),(e[h]||(e[h]=new Set)).add(t)}function k(e,t){t.split(/\s+/).forEach(t=>t&&e.classList.remove(t));const l=e[h];l&&(l.delete(t),l.size||(e[h]=void 0))}function S(e){requestAnimationFrame(()=>{requestAnimationFrame(e)})}let E=0;function A(e,t,l,n){const a=e._endId=++E,o=()=>{a===e._endId&&n()};if(null!=l)return setTimeout(o,l);const{type:c,timeout:r,propCount:s}=N(e,t);if(!c)return n();const i=c+"end";let u=0;const d=()=>{e.removeEventListener(i,f),o()},f=t=>{t.target===e&&++u>=s&&d()};setTimeout(()=>{u(l[e]||"").split(", "),a=n(`${m}Delay`),o=n(`${m}Duration`),c=_(a,o),r=n(`${v}Delay`),s=n(`${v}Duration`),i=_(r,s);let u=null,d=0,f=0;t===m?c>0&&(u=m,d=c,f=o.length):t===v?i>0&&(u=v,d=i,f=s.length):(d=Math.max(c,i),u=d>0?c>i?m:v:null,f=u?u===m?o.length:s.length:0);const p=u===m&&/\b(?:transform|all)(?:,|$)/.test(n(`${m}Property`).toString());return{type:u,timeout:d,propCount:f,hasTransform:p}}function _(e,t){while(e.lengthT(t)+T(e[l])))}function T(e){return"auto"===e?0:1e3*Number(e.slice(0,-1).replace(",","."))}function O(e){const t=e?e.ownerDocument:document;return t.body.offsetHeight}function W(e,t,l){const n=e[h];n&&(t=(t?[t,...n]:[...n]).join(" ")),null==t?e.removeAttribute("class"):l?e.setAttribute("class",t):e.className=t}const B=Symbol("_vod"),I=Symbol("_vsh"),D={name:"show",beforeMount(e,{value:t},{transition:l}){e[B]="none"===e.style.display?"":e.style.display,l&&t?l.beforeEnter(e):F(e,t)},mounted(e,{value:t},{transition:l}){l&&t&&l.enter(e)},updated(e,{value:t,oldValue:l},{transition:n}){!t!==!l&&(n?t?(n.beforeEnter(e),F(e,!0),n.enter(e)):n.leave(e,()=>{F(e,!1)}):F(e,t))},beforeUnmount(e,{value:t}){F(e,t)}};function F(e,t){e.style.display=t?e[B]:"none",e[I]=!t}const V=Symbol("");const P=/(?:^|;)\s*display\s*:/;function $(e,t,l){const n=e.style,o=(0,a.Kg)(l);let c=!1;if(l&&!o){if(t)if((0,a.Kg)(t))for(const e of t.split(";")){const t=e.slice(0,e.indexOf(":")).trim();null==l[t]&&j(n,t,"")}else for(const e in t)null==l[e]&&j(n,e,"");for(const e in l)"display"===e&&(c=!0),j(n,e,l[e])}else if(o){if(t!==l){const e=n[V];e&&(l+=";"+e),n.cssText=l,c=P.test(l)}}else t&&e.removeAttribute("style");B in e&&(e[B]=c?n.display:"",e[I]&&(n.display="none"))}const H=/\s*!important$/;function j(e,t,l){if((0,a.cy)(l))l.forEach(l=>j(e,t,l));else if(null==l&&(l=""),t.startsWith("--"))e.setProperty(t,l);else{const n=U(e,t);H.test(l)?e.setProperty((0,a.Tg)(n),l.replace(H,""),"important"):e[n]=l}}const K=["Webkit","Moz","ms"],X={};function U(e,t){const l=X[t];if(l)return l;let n=(0,a.PT)(t);if("filter"!==n&&n in e)return X[t]=n;n=(0,a.ZH)(n);for(let a=0;ane||(ae.then(()=>ne=0),ne=Date.now());function ce(e,t){const l=e=>{if(e._vts){if(e._vts<=l.attached)return}else e._vts=Date.now();(0,n.qL)(re(e,l.value),t,5,[e])};return l.value=e,l.attached=oe(),l}function re(e,t){if((0,a.cy)(t)){const l=e.stopImmediatePropagation;return e.stopImmediatePropagation=()=>{l.call(e),e._stopped=!0},t.map(e=>t=>!t._stopped&&e&&e(t))}return t}const se=e=>111===e.charCodeAt(0)&&110===e.charCodeAt(1)&&e.charCodeAt(2)>96&&e.charCodeAt(2)<123,ie=(e,t,l,n,o,c)=>{const r="svg"===o;"class"===t?W(e,n,r):"style"===t?$(e,l,n):(0,a.Mp)(t)?(0,a.CP)(t)||ee(e,t,l,n,c):("."===t[0]?(t=t.slice(1),1):"^"===t[0]?(t=t.slice(1),0):ue(e,t,n,r))?(Y(e,t,n),e.tagName.includes("-")||"value"!==t&&"checked"!==t&&"selected"!==t||G(e,t,n,r,c,"value"!==t)):!e._isVueCE||!/[A-Z]/.test(t)&&(0,a.Kg)(n)?("true-value"===t?e._trueValue=n:"false-value"===t&&(e._falseValue=n),G(e,t,n,r)):Y(e,(0,a.PT)(t),n,c,t)};function ue(e,t,l,n){if(n)return"innerHTML"===t||"textContent"===t||!!(t in e&&se(t)&&(0,a.Tn)(l));if("spellcheck"===t||"draggable"===t||"translate"===t||"autocorrect"===t)return!1;if("sandbox"===t&&"IFRAME"===e.tagName)return!1;if("form"===t)return!1;if("list"===t&&"INPUT"===e.tagName)return!1;if("type"===t&&"TEXTAREA"===e.tagName)return!1;if("width"===t||"height"===t){const t=e.tagName;if("IMG"===t||"VIDEO"===t||"CANVAS"===t||"SOURCE"===t)return!1}return(!se(t)||!(0,a.Kg)(l))&&t in e}"undefined"!==typeof HTMLElement&&HTMLElement;const de=new WeakMap,fe=new WeakMap,pe=Symbol("_moveCb"),me=Symbol("_enterCb"),ve=e=>(delete e.props.mode,e),he=ve({name:"TransitionGroup",props:(0,a.X$)({},b,{tag:String,moveClass:String}),setup(e,{slots:t}){const l=(0,n.nI)(),a=(0,n.Gy)();let c,r;return(0,n.$u)(()=>{if(!c.length)return;const t=e.moveClass||`${e.name||"v"}-move`;if(!we(c[0].el,l.vnode.el,t))return void(c=[]);c.forEach(be),c.forEach(ye);const n=c.filter(Ce);O(l.vnode.el),n.forEach(e=>{const l=e.el,n=l.style;R(l,t),n.transform=n.webkitTransform=n.transitionDuration="";const a=l[pe]=e=>{e&&e.target!==l||e&&!e.propertyName.endsWith("transform")||(l.removeEventListener("transitionend",a),l[pe]=null,k(l,t))};l.addEventListener("transitionend",a)}),c=[]}),()=>{const s=(0,o.ux)(e),i=x(s);let u=s.tag||n.FK;if(c=[],r)for(let e=0;e{e.split(/\s+/).forEach(e=>e&&n.classList.remove(e))}),l.split(/\s+/).forEach(e=>e&&n.classList.add(e)),n.style.display="none";const o=1===t.nodeType?t:t.parentNode;o.appendChild(n);const{hasTransform:c}=N(n);return o.removeChild(n),c}const Le=e=>{const t=e.props["onUpdate:modelValue"]||!1;return(0,a.cy)(t)?e=>(0,a.DY)(t,e):t};function xe(e){e.target.composing=!0}function Me(e){const t=e.target;t.composing&&(t.composing=!1,t.dispatchEvent(new Event("input")))}const ze=Symbol("_assign");function Re(e,t,l){return t&&(e=e.trim()),l&&(e=(0,a.bB)(e)),e}const ke={created(e,{modifiers:{lazy:t,trim:l,number:n}},a){e[ze]=Le(a);const o=n||a.props&&"number"===a.props.type;Q(e,t?"change":"input",t=>{t.target.composing||e[ze](Re(e.value,l,o))}),(l||o)&&Q(e,"change",()=>{e.value=Re(e.value,l,o)}),t||(Q(e,"compositionstart",xe),Q(e,"compositionend",Me),Q(e,"change",Me))},mounted(e,{value:t}){e.value=null==t?"":t},beforeUpdate(e,{value:t,oldValue:l,modifiers:{lazy:n,trim:o,number:c}},r){if(e[ze]=Le(r),e.composing)return;const s=!c&&"number"!==e.type||/^0\d/.test(e.value)?e.value:(0,a.bB)(e.value),i=null==t?"":t;if(s!==i){if(document.activeElement===e&&"range"!==e.type){if(n&&t===l)return;if(o&&e.value.trim()===i)return}e.value=i}}},Se={deep:!0,created(e,t,l){e[ze]=Le(l),Q(e,"change",()=>{const t=e._modelValue,l=Ne(e),n=e.checked,o=e[ze];if((0,a.cy)(t)){const e=(0,a.u3)(t,l),c=-1!==e;if(n&&!c)o(t.concat(l));else if(!n&&c){const l=[...t];l.splice(e,1),o(l)}}else if((0,a.vM)(t)){const e=new Set(t);n?e.add(l):e.delete(l),o(e)}else o(_e(e,n))})},mounted:Ee,beforeUpdate(e,t,l){e[ze]=Le(l),Ee(e,t,l)}};function Ee(e,{value:t,oldValue:l},n){let o;if(e._modelValue=t,(0,a.cy)(t))o=(0,a.u3)(t,n.props.value)>-1;else if((0,a.vM)(t))o=t.has(n.props.value);else{if(t===l)return;o=(0,a.BX)(t,_e(e,!0))}e.checked!==o&&(e.checked=o)}const Ae={created(e,{value:t},l){e.checked=(0,a.BX)(t,l.props.value),e[ze]=Le(l),Q(e,"change",()=>{e[ze](Ne(e))})},beforeUpdate(e,{value:t,oldValue:l},n){e[ze]=Le(n),t!==l&&(e.checked=(0,a.BX)(t,n.props.value))}};function Ne(e){return"_value"in e?e._value:e.value}function _e(e,t){const l=t?"_trueValue":"_falseValue";return l in e?e[l]:t}const Te=["ctrl","shift","alt","meta"],Oe={stop:e=>e.stopPropagation(),prevent:e=>e.preventDefault(),self:e=>e.target!==e.currentTarget,ctrl:e=>!e.ctrlKey,shift:e=>!e.shiftKey,alt:e=>!e.altKey,meta:e=>!e.metaKey,left:e=>"button"in e&&0!==e.button,middle:e=>"button"in e&&1!==e.button,right:e=>"button"in e&&2!==e.button,exact:(e,t)=>Te.some(l=>e[`${l}Key`]&&!t.includes(l))},We=(e,t)=>{const l=e._withMods||(e._withMods={}),n=t.join(".");return l[n]||(l[n]=(l,...n)=>{for(let e=0;e{const l=e._withKeys||(e._withKeys={}),n=t.join(".");return l[n]||(l[n]=l=>{if(!("key"in l))return;const n=(0,a.Tg)(l.key);return t.some(e=>e===n||Be[e]===n)?e(l):void 0})},De=(0,a.X$)({patchProp:ie},p);let Fe;function Ve(){return Fe||(Fe=(0,n.K9)(De))}const Pe=(...e)=>{Ve().render(...e)},$e=(...e)=>{const t=Ve().createApp(...e);const{mount:l}=t;return t.mount=e=>{const n=je(e);if(!n)return;const o=t._component;(0,a.Tn)(o)||o.render||o.template||(o.template=n.innerHTML),1===n.nodeType&&(n.textContent="");const c=l(n,!1,He(n));return n instanceof Element&&(n.removeAttribute("v-cloak"),n.setAttribute("data-v-app","")),c},t};function He(e){return e instanceof SVGElement?"svg":"function"===typeof MathMLElement&&e instanceof MathMLElement?"mathml":void 0}function je(e){if((0,a.Kg)(e)){const t=document.querySelector(e);return t}return e}},5131:function(e,t,l){"use strict";l(8111),l(2489),l(7588),l(1701),l(8237),l(3110),l(8335);var n=function(e){return function(e){return!!e&&"object"==typeof e}(e)&&!function(e){var t=Object.prototype.toString.call(e);return"[object RegExp]"===t||"[object Date]"===t||function(e){return e.$$typeof===a}(e)}(e)},a="function"==typeof Symbol&&Symbol.for?Symbol.for("react.element"):60103;function o(e,t){return!1!==t.clone&&t.isMergeableObject(e)?i(Array.isArray(e)?[]:{},e,t):e}function c(e,t,l){return e.concat(t).map(function(e){return o(e,l)})}function r(e){return Object.keys(e).concat(function(e){return Object.getOwnPropertySymbols?Object.getOwnPropertySymbols(e).filter(function(t){return e.propertyIsEnumerable(t)}):[]}(e))}function s(e,t){try{return t in e}catch(e){return!1}}function i(e,t,l){(l=l||{}).arrayMerge=l.arrayMerge||c,l.isMergeableObject=l.isMergeableObject||n,l.cloneUnlessOtherwiseSpecified=o;var a=Array.isArray(t);return a===Array.isArray(e)?a?l.arrayMerge(e,t,l):function(e,t,l){var n={};return l.isMergeableObject(e)&&r(e).forEach(function(t){n[t]=o(e[t],l)}),r(t).forEach(function(a){(function(e,t){return s(e,t)&&!(Object.hasOwnProperty.call(e,t)&&Object.propertyIsEnumerable.call(e,t))})(e,a)||(n[a]=s(e,a)&&l.isMergeableObject(t[a])?function(e,t){if(!t.customMerge)return i;var l=t.customMerge(e);return"function"==typeof l?l:i}(a,l)(e[a],t[a],l):o(t[a],l))}),n}(e,t,l):o(t,l)}i.all=function(e,t){if(!Array.isArray(e))throw new Error("first argument should be an array");return e.reduce(function(e,l){return i(e,l,t)},{})};var u=i;function d(e){var t=(e=e||{}).storage||window&&window.localStorage,l=e.key||"vuex";function n(e,t){var l=t.getItem(e);try{return"string"==typeof l?JSON.parse(l):"object"==typeof l?l:void 0}catch(e){}}function a(){return!0}function o(e,t,l){return l.setItem(e,JSON.stringify(t))}function c(e,t){return Array.isArray(t)?t.reduce(function(t,l){return function(e,t,l){return!/^(__proto__|constructor|prototype)$/.test(t)&&((t=t.split?t.split("."):t.slice(0)).slice(0,-1).reduce(function(e,t){return e[t]=e[t]||{}},e)[t.pop()]=l),e}(t,l,(n=e,void 0===(n=((a=l).split?a.split("."):a).reduce(function(e,t){return e&&e[t]},n))?void 0:n));var n,a},{}):e}function r(e){return function(t){return e.subscribe(t)}}(e.assertStorage||function(){t.setItem("@@",1),t.removeItem("@@")})(t);var s,i=function(){return(e.getState||n)(l,t)};return e.fetchBeforeUse&&(s=i()),function(n){e.fetchBeforeUse||(s=i()),"object"==typeof s&&null!==s&&(n.replaceState(e.overwrite?s:u(n.state,s,{arrayMerge:e.arrayMerger||function(e,t){return t},clone:!1})),(e.rehydrated||function(){})(n)),(e.subscriber||r)(n)(function(n,r){(e.filter||a)(n)&&(e.setState||o)(l,(e.reducer||c)(r,e.paths),t)})}}t.A=d},5169:function(e,t,l){"use strict";var n=l(3238),a=TypeError;e.exports=function(e){if(n(e))throw new a("ArrayBuffer is detached");return e}},5170:function(e,t,l){"use strict";var n=l(6706),a=l(4402);e.exports=n(a.proto,"size","get")||function(e){return e.size}},5318:function(e,t,l){"use strict";l.d(t,{A:function(){return p}});l(4114);function n(e,t){var l=-1,n=Array(e);while(++l-1&&e%1==0&&e<=l}t.A=n},5376:function(e,t,l){"use strict";l.d(t,{GU:function(){return a},PZ:function(){return c},WM:function(){return r},_u:function(){return o}});var n=l(4232);const a=(e,t)=>{if(e.install=l=>{for(const n of[e,...Object.values(null!=t?t:{})])l.component(n.name,n)},t)for(const[l,n]of Object.entries(t))e[l]=n;return e},o=(e,t)=>(e.install=l=>{e._context=l._context,l.config.globalProperties[t]=e},e),c=(e,t)=>(e.install=l=>{l.directive(t,e)},e),r=e=>(e.install=n.tE,e)},5397:function(e,t,l){"use strict";var n=l(7055),a=l(7750);e.exports=function(e){return n(a(e))}},5407:function(e,t,l){"use strict";l.d(t,{z_:function(){return g}});var n=l(6768),a=l(4232),o=l(144),c=l(5130),r=l(7378);const s=(0,r.b_)({value:{type:[String,Number],default:""},max:{type:Number,default:99},isDot:Boolean,hidden:Boolean,type:{type:String,values:["primary","success","warning","info","danger"],default:"danger"},showZero:{type:Boolean,default:!0},color:String,badgeStyle:{type:(0,r.jq)([String,Object,Array])},offset:{type:(0,r.jq)(Array),default:[0,0]},badgeClass:{type:String}});var i=l(9077),u=l(3513),d=l(2235),f=l(3558);const p=(0,n.pM)({name:"ElBadge"}),m=(0,n.pM)({...p,props:s,setup(e,{expose:t}){const l=e,r=(0,u.DU)("badge"),s=(0,n.EW)(()=>l.isDot?"":(0,d.Et)(l.value)&&(0,d.Et)(l.max)&&l.max{var e;return[{backgroundColor:l.color,marginRight:(0,f._V)(-l.offset[0]),marginTop:(0,f._V)(l.offset[1])},null!=(e=l.badgeStyle)?e:{}]});return t({content:s}),(e,t)=>((0,n.uX)(),(0,n.CE)("div",{class:(0,a.C4)((0,o.R1)(r).b())},[(0,n.RG)(e.$slots,"default"),(0,n.bF)(c.eB,{name:`${(0,o.R1)(r).namespace.value}-zoom-in-center`,persisted:""},{default:(0,n.k6)(()=>[(0,n.bo)((0,n.Lk)("sup",{class:(0,a.C4)([(0,o.R1)(r).e("content"),(0,o.R1)(r).em("content",e.type),(0,o.R1)(r).is("fixed",!!e.$slots.default),(0,o.R1)(r).is("dot",e.isDot),(0,o.R1)(r).is("hide-zero",!e.showZero&&0===e.value),e.badgeClass]),style:(0,a.Tr)((0,o.R1)(i))},[(0,n.RG)(e.$slots,"content",{value:(0,o.R1)(s)},()=>[(0,n.eW)((0,a.v_)((0,o.R1)(s)),1)])],6),[[c.aG,!e.hidden&&((0,o.R1)(s)||e.isDot||e.$slots.content)]])]),_:3},8,["name"])],2))}});var v=(0,i.A)(m,[["__file","badge.vue"]]),h=l(5376);const g=(0,h.GU)(v)},5420:function(e,t,l){"use strict";l.d(t,{M:function(){return i},m:function(){return s}});var n=l(144),a=l(17);function o(){let e;const t=(t,n)=>{l(),e=window.setTimeout(t,n)},l=()=>window.clearTimeout(e);return(0,a.Uo)(()=>l()),{registerTimeout:t,cancelTimeout:l}}var c=l(7378),r=l(2235);const s=(0,c.b_)({showAfter:{type:Number,default:0},hideAfter:{type:Number,default:200},autoClose:{type:Number,default:0}}),i=({showAfter:e,hideAfter:t,autoClose:l,open:a,close:c})=>{const{registerTimeout:s}=o(),{registerTimeout:i,cancelTimeout:u}=o(),d=(t,o=(0,n.R1)(e))=>{s(()=>{a(t);const e=(0,n.R1)(l);(0,r.Et)(e)&&e>0&&i(()=>{c(t)},e)},o)},f=(e,l=(0,n.R1)(t))=>{u(),s(()=>{c(e)},l)};return{onOpen:d,onClose:f}}},5431:function(e,t,l){"use strict";l.d(t,{V:function(){return o},m:function(){return a}});var n=l(17);const a=e=>n.oc?window.requestAnimationFrame(e):setTimeout(e,16),o=e=>n.oc?window.cancelAnimationFrame(e):clearTimeout(e)},5445:function(e,t,l){"use strict";l.d(t,{A:function(){return f}});var n=l(6768),a=l(144),o=l(5130),c=l(8114),r=l(3558);function s(e,t){let l;const s=(0,a.KR)(!1),i=(0,a.Kh)({...e,originalPosition:"",originalOverflow:"",visible:!1});function u(e){i.text=e}function d(){const e=i.parent,t=g.ns;if(!e.vLoadingAddClassList){let l=e.getAttribute("loading-number");l=Number.parseInt(l)-1,l?e.setAttribute("loading-number",l.toString()):((0,r.vy)(e,t.bm("parent","relative")),e.removeAttribute("loading-number")),(0,r.vy)(e,t.bm("parent","hidden"))}f(),h.unmount()}function f(){var e,t;null==(t=null==(e=g.$el)?void 0:e.parentNode)||t.removeChild(g.$el)}function p(){var t;e.beforeClose&&!e.beforeClose()||(s.value=!0,clearTimeout(l),l=setTimeout(m,400),i.visible=!1,null==(t=e.closed)||t.call(e))}function m(){if(!s.value)return;const e=i.parent;s.value=!1,e.vLoadingAddClassList=void 0,d()}const v=(0,n.pM)({name:"ElLoading",setup(e,{expose:t}){const{ns:l,zIndex:a}=(0,c.ht)("loading");return t({ns:l,zIndex:a}),()=>{const e=i.spinner||i.svg,t=(0,n.h)("svg",{class:"circular",viewBox:i.svgViewBox?i.svgViewBox:"0 0 50 50",...e?{innerHTML:e}:{}},[(0,n.h)("circle",{class:"path",cx:"25",cy:"25",r:"20",fill:"none"})]),a=i.text?(0,n.h)("p",{class:l.b("text")},[i.text]):void 0;return(0,n.h)(o.eB,{name:l.b("fade"),onAfterLeave:m},{default:(0,n.k6)(()=>[(0,n.bo)((0,n.bF)("div",{style:{backgroundColor:i.background||""},class:[l.b("mask"),i.customClass,l.is("fullscreen",i.fullscreen)]},[(0,n.h)("div",{class:l.b("spinner")},[t,a])]),[[o.aG,i.visible]])])})}}}),h=(0,o.Ef)(v);Object.assign(h._context,null!=t?t:{});const g=h.mount(document.createElement("div"));return{...(0,a.QW)(i),setText:u,removeElLoadingChild:f,close:p,handleAfterLeave:m,vm:g,get $el(){return g.$el}}}var i=l(17),u=l(4232);let d;const f=function(e={},t){if(!i.oc)return;const l=p(e);if(l.fullscreen&&d)return d;const a=s({...l,closed:()=>{var e;null==(e=l.closed)||e.call(l),l.fullscreen&&(d=void 0)}},null!=t?t:f._context);m(l,l.parent,a),v(l,l.parent,a),l.parent.vLoadingAddClassList=()=>v(l,l.parent,a);let o=l.parent.getAttribute("loading-number");return o=o?`${Number.parseInt(o)+1}`:"1",l.parent.setAttribute("loading-number",o),l.parent.appendChild(a.$el),(0,n.dY)(()=>a.visible.value=l.visible),l.fullscreen&&(d=a),a},p=e=>{var t,l,n,a;let o;return o=(0,u.Kg)(e.target)?null!=(t=document.querySelector(e.target))?t:document.body:e.target||document.body,{parent:o===document.body||e.body?document.body:o,background:e.background||"",svg:e.svg||"",svgViewBox:e.svgViewBox||"",spinner:e.spinner||!1,text:e.text||"",fullscreen:o===document.body&&(null==(l=e.fullscreen)||l),lock:null!=(n=e.lock)&&n,customClass:e.customClass||"",visible:null==(a=e.visible)||a,beforeClose:e.beforeClose,closed:e.closed,target:o}},m=async(e,t,l)=>{const{nextZIndex:a}=l.vm.zIndex||l.vm._.exposed.zIndex,o={};if(e.fullscreen)l.originalPosition.value=(0,r.gd)(document.body,"position"),l.originalOverflow.value=(0,r.gd)(document.body,"overflow"),o.zIndex=a();else if(e.parent===document.body){l.originalPosition.value=(0,r.gd)(document.body,"position"),await(0,n.dY)();for(const t of["top","left"]){const l="top"===t?"scrollTop":"scrollLeft";o[t]=e.target.getBoundingClientRect()[t]+document.body[l]+document.documentElement[l]-Number.parseInt((0,r.gd)(document.body,`margin-${t}`),10)+"px"}for(const t of["height","width"])o[t]=`${e.target.getBoundingClientRect()[t]}px`}else l.originalPosition.value=(0,r.gd)(t,"position");for(const[n,c]of Object.entries(o))l.$el.style[n]=c},v=(e,t,l)=>{const n=l.vm.ns||l.vm._.exposed.ns;["absolute","fixed","sticky"].includes(l.originalPosition.value)?(0,r.vy)(t,n.bm("parent","relative")):(0,r.iQ)(t,n.bm("parent","relative")),e.fullscreen&&e.lock?(0,r.iQ)(t,n.bm("parent","hidden")):(0,r.vy)(t,n.bm("parent","hidden"))};f._context=null},5454:function(e,t,l){"use strict";var n=l(4672),a=l(2132),o=l(6636);function c(e){return(0,n.A)(e,o.A,a.A)}t.A=c},5488:function(e,t,l){"use strict";l.d(t,{o:function(){return c}});var n=l(144),a=l(6768);const o=e=>/([\uAC00-\uD7AF\u3130-\u318F])+/gi.test(e);function c({afterComposition:e,emit:t}){const l=(0,n.KR)(!1),c=e=>{null==t||t("compositionstart",e),l.value=!0},r=e=>{var n;null==t||t("compositionupdate",e);const a=null==(n=e.target)?void 0:n.value,c=a[a.length-1]||"";l.value=!o(c)},s=n=>{null==t||t("compositionend",n),l.value&&(l.value=!1,(0,a.dY)(()=>e(n)))},i=e=>{"compositionend"===e.type?s(e):r(e)};return{isComposing:l,handleComposition:i,handleCompositionStart:c,handleCompositionUpdate:r,handleCompositionEnd:s}}},5513:function(e,t,l){"use strict";l.d(t,{Q:function(){return o},k:function(){return c}});var n=l(7378),a=l(464);const o=(0,n.b_)({center:Boolean,alignCenter:{type:Boolean,default:void 0},closeIcon:{type:a.Ze},draggable:{type:Boolean,default:void 0},overflow:{type:Boolean,default:void 0},fullscreen:Boolean,headerClass:String,bodyClass:String,footerClass:String,showClose:{type:Boolean,default:!0},title:{type:String,default:""},ariaLevel:{type:String,default:"2"}}),c={close:()=>!0}},5558:function(e,t,l){"use strict";l.d(t,{qi:function(){return S}});var n=l(6768),a=l(144),o=l(4232),c=l(5130),r=l(813),s=l(7477),i=l(3027),u=l(7378),d=l(464),f=l(8501),p=l(2056),m=l(2235);const v=(0,u.b_)({modelValue:{type:[Boolean,String,Number],default:!1},disabled:{type:Boolean,default:void 0},loading:Boolean,size:{type:String,validator:i.x},width:{type:[String,Number],default:""},inlinePrompt:Boolean,inactiveActionIcon:{type:d.Ze},activeActionIcon:{type:d.Ze},activeIcon:{type:d.Ze},inactiveIcon:{type:d.Ze},activeText:{type:String,default:""},inactiveText:{type:String,default:""},activeValue:{type:[Boolean,String,Number],default:!0},inactiveValue:{type:[Boolean,String,Number],default:!1},name:{type:String,default:""},validateEvent:{type:Boolean,default:!0},beforeChange:{type:(0,u.jq)(Function)},id:String,tabindex:{type:[String,Number]},...(0,f.l)(["ariaLabel"])}),h={[p.l4]:e=>(0,m.Lm)(e)||(0,o.Kg)(e)||(0,m.Et)(e),[p.YU]:e=>(0,m.Lm)(e)||(0,o.Kg)(e)||(0,m.Et)(e),[p.qs]:e=>(0,m.Lm)(e)||(0,o.Kg)(e)||(0,m.Et)(e)};var g=l(9077),b=l(4216),y=l(2436),C=l(3513),w=l(3558),L=l(6894);const x="ElSwitch",M=(0,n.pM)({name:x}),z=(0,n.pM)({...M,props:v,emits:h,setup(e,{expose:t,emit:l}){const i=e,{formItem:u}=(0,b.j)(),d=(0,y.NV)(),f=(0,C.DU)("switch"),{inputId:v}=(0,b.W)(i,{formItemContext:u}),h=(0,y.CB)((0,n.EW)(()=>{if(i.loading)return!0})),g=(0,a.KR)(!1!==i.modelValue),M=(0,a.IJ)(),z=(0,n.EW)(()=>[f.b(),f.m(d.value),f.is("disabled",h.value),f.is("checked",A.value)]),R=(0,n.EW)(()=>[f.e("label"),f.em("label","left"),f.is("active",!A.value)]),k=(0,n.EW)(()=>[f.e("label"),f.em("label","right"),f.is("active",A.value)]),S=(0,n.EW)(()=>({width:(0,w._V)(i.width)}));(0,n.wB)(()=>i.modelValue,()=>{g.value=!0});const E=(0,n.EW)(()=>!!g.value&&i.modelValue),A=(0,n.EW)(()=>E.value===i.activeValue);[i.activeValue,i.inactiveValue].includes(E.value)||(l(p.l4,i.inactiveValue),l(p.YU,i.inactiveValue),l(p.qs,i.inactiveValue)),(0,n.wB)(A,e=>{var t;M.value.checked=e,i.validateEvent&&(null==(t=null==u?void 0:u.validate)||t.call(u,"change").catch(e=>(0,L.U)(e)))});const N=()=>{const e=A.value?i.inactiveValue:i.activeValue;l(p.l4,e),l(p.YU,e),l(p.qs,e),(0,n.dY)(()=>{M.value.checked=A.value})},_=()=>{if(h.value)return;const{beforeChange:e}=i;if(!e)return void N();const t=e(),l=[(0,o.yL)(t),(0,m.Lm)(t)].includes(!0);l||(0,L.$)(x,"beforeChange must return type `Promise` or `boolean`"),(0,o.yL)(t)?t.then(e=>{e&&N()}).catch(e=>{(0,L.U)(x,`some error occurred: ${e}`)}):t&&N()},T=()=>{var e,t;null==(t=null==(e=M.value)?void 0:e.focus)||t.call(e)};return(0,n.sV)(()=>{M.value.checked=A.value}),t({focus:T,checked:A}),(e,t)=>((0,n.uX)(),(0,n.CE)("div",{class:(0,o.C4)((0,a.R1)(z)),onClick:(0,c.D$)(_,["prevent"])},[(0,n.Lk)("input",{id:(0,a.R1)(v),ref_key:"input",ref:M,class:(0,o.C4)((0,a.R1)(f).e("input")),type:"checkbox",role:"switch","aria-checked":(0,a.R1)(A),"aria-disabled":(0,a.R1)(h),"aria-label":e.ariaLabel,name:e.name,"true-value":e.activeValue,"false-value":e.inactiveValue,disabled:(0,a.R1)(h),tabindex:e.tabindex,onChange:N,onKeydown:(0,c.jR)(_,["enter"])},null,42,["id","aria-checked","aria-disabled","aria-label","name","true-value","false-value","disabled","tabindex","onKeydown"]),e.inlinePrompt||!e.inactiveIcon&&!e.inactiveText?(0,n.Q3)("v-if",!0):((0,n.uX)(),(0,n.CE)("span",{key:0,class:(0,o.C4)((0,a.R1)(R))},[e.inactiveIcon?((0,n.uX)(),(0,n.Wv)((0,a.R1)(r.tk),{key:0},{default:(0,n.k6)(()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)(e.inactiveIcon)))]),_:1})):(0,n.Q3)("v-if",!0),!e.inactiveIcon&&e.inactiveText?((0,n.uX)(),(0,n.CE)("span",{key:1,"aria-hidden":(0,a.R1)(A)},(0,o.v_)(e.inactiveText),9,["aria-hidden"])):(0,n.Q3)("v-if",!0)],2)),(0,n.Lk)("span",{class:(0,o.C4)((0,a.R1)(f).e("core")),style:(0,o.Tr)((0,a.R1)(S))},[e.inlinePrompt?((0,n.uX)(),(0,n.CE)("div",{key:0,class:(0,o.C4)((0,a.R1)(f).e("inner"))},[e.activeIcon||e.inactiveIcon?((0,n.uX)(),(0,n.Wv)((0,a.R1)(r.tk),{key:0,class:(0,o.C4)((0,a.R1)(f).is("icon"))},{default:(0,n.k6)(()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)((0,a.R1)(A)?e.activeIcon:e.inactiveIcon)))]),_:1},8,["class"])):e.activeText||e.inactiveText?((0,n.uX)(),(0,n.CE)("span",{key:1,class:(0,o.C4)((0,a.R1)(f).is("text")),"aria-hidden":!(0,a.R1)(A)},(0,o.v_)((0,a.R1)(A)?e.activeText:e.inactiveText),11,["aria-hidden"])):(0,n.Q3)("v-if",!0)],2)):(0,n.Q3)("v-if",!0),(0,n.Lk)("div",{class:(0,o.C4)((0,a.R1)(f).e("action"))},[e.loading?((0,n.uX)(),(0,n.Wv)((0,a.R1)(r.tk),{key:0,class:(0,o.C4)((0,a.R1)(f).is("loading"))},{default:(0,n.k6)(()=>[(0,n.bF)((0,a.R1)(s.Loading))]),_:1},8,["class"])):(0,a.R1)(A)?(0,n.RG)(e.$slots,"active-action",{key:1},()=>[e.activeActionIcon?((0,n.uX)(),(0,n.Wv)((0,a.R1)(r.tk),{key:0},{default:(0,n.k6)(()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)(e.activeActionIcon)))]),_:1})):(0,n.Q3)("v-if",!0)]):(0,a.R1)(A)?(0,n.Q3)("v-if",!0):(0,n.RG)(e.$slots,"inactive-action",{key:2},()=>[e.inactiveActionIcon?((0,n.uX)(),(0,n.Wv)((0,a.R1)(r.tk),{key:0},{default:(0,n.k6)(()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)(e.inactiveActionIcon)))]),_:1})):(0,n.Q3)("v-if",!0)])],2)],6),e.inlinePrompt||!e.activeIcon&&!e.activeText?(0,n.Q3)("v-if",!0):((0,n.uX)(),(0,n.CE)("span",{key:1,class:(0,o.C4)((0,a.R1)(k))},[e.activeIcon?((0,n.uX)(),(0,n.Wv)((0,a.R1)(r.tk),{key:0},{default:(0,n.k6)(()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)(e.activeIcon)))]),_:1})):(0,n.Q3)("v-if",!0),!e.activeIcon&&e.activeText?((0,n.uX)(),(0,n.CE)("span",{key:1,"aria-hidden":!(0,a.R1)(A)},(0,o.v_)(e.activeText),9,["aria-hidden"])):(0,n.Q3)("v-if",!0)],2))],10,["onClick"]))}});var R=(0,g.A)(z,[["__file","switch.vue"]]),k=l(5376);const S=(0,k.GU)(R)},5610:function(e,t,l){"use strict";var n=l(1291),a=Math.max,o=Math.min;e.exports=function(e,t){var l=n(e);return l<0?a(l+t,0):o(l,t)}},5623:function(e,t,l){"use strict";l(456)},5636:function(e,t,l){"use strict";var n=l(4576),a=l(9504),o=l(6706),c=l(7696),r=l(5169),s=l(7394),i=l(4483),u=l(1548),d=n.structuredClone,f=n.ArrayBuffer,p=n.DataView,m=Math.min,v=f.prototype,h=p.prototype,g=a(v.slice),b=o(v,"resizable","get"),y=o(v,"maxByteLength","get"),C=a(h.getInt8),w=a(h.setInt8);e.exports=(u||i)&&function(e,t,l){var n,a=s(e),o=void 0===t?a:c(t),v=!b||!b(e);if(r(e),u&&(e=d(e,{transfer:[e]}),a===o&&(l||v)))return e;if(a>=o&&(!l||v))n=g(e,0,o);else{var h=l&&!v&&y?{maxByteLength:y(e)}:void 0;n=new f(o,h);for(var L=new p(e),x=new p(n),M=m(o,a),z=0;z=52?l-1:l}}})},5810:function(e,t,l){"use strict";var n=l(34),a=l(1181).get;e.exports=function(e){if(!n(e))return!1;var t=a(e);return!!t&&"RawJSON"===t.type}},5854:function(e,t,l){"use strict";var n=l(2777),a=TypeError;e.exports=function(e){var t=n(e,"number");if("number"==typeof t)throw new a("Can't convert number to bigint");return BigInt(t)}},5856:function(e,t,l){"use strict";var n=l(7529),a=1,o=4;function c(e){return(0,n.A)(e,a|o)}t.A=c},5867:function(e,t,l){"use strict";function n(e,t,l){switch(l.length){case 0:return e.call(t);case 1:return e.call(t,l[0]);case 2:return e.call(t,l[0],l[1]);case 3:return e.call(t,l[0],l[1],l[2])}return e.apply(t,l)}l.d(t,{A:function(){return r}});var a=n,o=Math.max;function c(e,t,l){return t=o(void 0===t?e.length-1:t,0),function(){var n=arguments,c=-1,r=o(n.length-t,0),s=Array(r);while(++c[...new Set(e)],o=e=>(0,n.cy)(e)?e[0]:e,c=e=>e||0===e?(0,n.cy)(e)?e:[e]:[]},6018:function(e,t,l){"use strict";l.d(t,{P9:function(){return Ce},EL:function(){return we},AV:function(){return ye}});l(4114),l(8111),l(7588),l(1701),l(8237);var n=l(6768),a=l(144),o=l(4232),c=l(5130),r=l(8507),s=l(8559),i=l(2687),u=l(813),d=l(793),f=(l(3579),l(5951)),p=l(9615),m=l(9195),v=l(4344),h=l(7378);const g="ElOption",b=(0,h.b_)({value:{type:[String,Number,Boolean,Object],required:!0},label:{type:[String,Number]},created:Boolean,disabled:Boolean});var y=l(2261),C=l(6894);function w(e,t){const l=(0,n.WQ)(v.u);l||(0,C.$)(g,"usage: ");const c=(0,n.WQ)(v.P,{disabled:!1}),r=(0,n.EW)(()=>b((0,f.A)(l.props.modelValue),e.value)),s=(0,n.EW)(()=>{var e;if(l.props.multiple){const t=(0,f.A)(null!=(e=l.props.modelValue)?e:[]);return!r.value&&t.length>=l.props.multipleLimit&&l.props.multipleLimit>0}return!1}),i=(0,n.EW)(()=>{var t;return null!=(t=e.label)?t:(0,o.Gv)(e.value)?"":e.value}),u=(0,n.EW)(()=>e.value||e.label||""),d=(0,n.EW)(()=>e.disabled||t.groupDisabled||s.value),h=(0,n.nI)(),b=(t=[],n)=>{if((0,o.Gv)(e.value)){const e=l.props.valueKey;return t&&t.some(t=>(0,a.ux)((0,p.A)(t,e))===(0,p.A)(n,e))}return t&&t.includes(n)},w=()=>{d.value||(l.states.hoveringIndex=l.optionsArray.indexOf(h.proxy))},L=l=>{const n=new RegExp((0,y.qr)(l),"i");t.visible=n.test(String(i.value))||e.created};return(0,n.wB)(()=>i.value,()=>{e.created||l.props.remote||l.setSelected()}),(0,n.wB)(()=>e.value,(t,n)=>{const{remote:a,valueKey:c}=l.props,r=a?t!==n:!(0,m.A)(t,n);if(r&&(l.onOptionDestroy(n,h.proxy),l.onOptionCreate(h.proxy)),!e.created&&!a){if(c&&(0,o.Gv)(t)&&(0,o.Gv)(n)&&t[c]===n[c])return;l.setSelected()}}),(0,n.wB)(()=>c.disabled,()=>{t.groupDisabled=c.disabled},{immediate:!0}),{select:l,currentLabel:i,currentValue:u,itemSelected:r,isDisabled:d,hoverItem:w,updateOption:L}}var L=l(9077),x=l(3513),M=l(1305);const z=(0,n.pM)({name:g,componentName:g,props:b,setup(e){const t=(0,x.DU)("select"),l=(0,M.Bi)(),o=(0,n.EW)(()=>[t.be("dropdown","item"),t.is("disabled",(0,a.R1)(i)),t.is("selected",(0,a.R1)(s)),t.is("hovering",(0,a.R1)(m))]),c=(0,a.Kh)({index:-1,groupDisabled:!1,visible:!0,hover:!1}),{currentLabel:r,itemSelected:s,isDisabled:i,select:u,hoverItem:d,updateOption:f}=w(e,c),{visible:p,hover:m}=(0,a.QW)(c),v=(0,n.nI)().proxy;function h(){i.value||u.handleOptionSelect(v)}return u.onOptionCreate(v),(0,n.xo)(()=>{const e=v.value;(0,n.dY)(()=>{const{selected:t}=u.states,l=t.some(e=>e.value===v.value);u.states.cachedOptions.get(e)!==v||l||u.states.cachedOptions.delete(e)}),u.onOptionDestroy(e,v)}),{ns:t,id:l,containerKls:o,currentLabel:r,itemSelected:s,isDisabled:i,select:u,visible:p,hover:m,states:c,hoverItem:d,updateOption:f,selectOptionClick:h}}});function R(e,t){return(0,n.bo)(((0,n.uX)(),(0,n.CE)("li",{id:e.id,class:(0,o.C4)(e.containerKls),role:"option","aria-disabled":e.isDisabled||void 0,"aria-selected":e.itemSelected,onMousemove:e.hoverItem,onClick:(0,c.D$)(e.selectOptionClick,["stop"])},[(0,n.RG)(e.$slots,"default",{},()=>[(0,n.Lk)("span",null,(0,o.v_)(e.currentLabel),1)])],42,["id","aria-disabled","aria-selected","onMousemove","onClick"])),[[c.aG,e.visible]])}var k=(0,L.A)(z,[["render",R],["__file","option.vue"]]),S=l(7687),E=l(2934);const A=(0,n.pM)({name:"ElSelectDropdown",componentName:"ElSelectDropdown",setup(){const e=(0,n.WQ)(v.u),t=(0,x.DU)("select"),l=(0,n.EW)(()=>e.props.popperClass),o=(0,n.EW)(()=>e.props.multiple),c=(0,n.EW)(()=>e.props.fitInputWidth),r=(0,a.KR)("");function s(){var t;const l=null==(t=e.selectRef)?void 0:t.offsetWidth;r.value=l?l-E.f+"px":""}return(0,n.sV)(()=>{s(),(0,S.wYm)(e.selectRef,s)}),{ns:t,minWidth:r,popperClass:l,isMultiple:o,isFitInputWidth:c}}});function N(e,t,l,a,c,r){return(0,n.uX)(),(0,n.CE)("div",{class:(0,o.C4)([e.ns.b("dropdown"),e.ns.is("multiple",e.isMultiple),e.popperClass]),style:(0,o.Tr)({[e.isFitInputWidth?"width":"minWidth"]:e.minWidth})},[e.$slots.header?((0,n.uX)(),(0,n.CE)("div",{key:0,class:(0,o.C4)(e.ns.be("dropdown","header"))},[(0,n.RG)(e.$slots,"header")],2)):(0,n.Q3)("v-if",!0),(0,n.RG)(e.$slots,"default"),e.$slots.footer?((0,n.uX)(),(0,n.CE)("div",{key:1,class:(0,o.C4)(e.ns.be("dropdown","footer"))},[(0,n.RG)(e.$slots,"footer")],2)):(0,n.Q3)("v-if",!0)],6)}var _=(0,L.A)(A,[["render",N],["__file","select-dropdown.vue"]]),T=(l(1148),l(2489),l(116),l(2762)),O=l(6032),W=l(8096),B=l(17),I=l(6268),D=l(4216),F=l(9180),V=l(5488),P=l(2436),$=l(1939),H=l(464),j=l(2235),K=l(4225),X=l(515),U=l(2056),q=l(8587);const G=(e,t)=>{const{t:l}=(0,I.Ym)(),c=(0,M.Bi)(),r=(0,x.DU)("select"),s=(0,x.DU)("input"),i=(0,a.Kh)({inputValue:"",options:new Map,cachedOptions:new Map,optionValues:[],selected:[],selectionWidth:0,collapseItemWidth:0,selectedLabel:"",hoveringIndex:-1,previousQuery:null,inputHovering:!1,menuVisibleOnFocus:!1,isBeforeHide:!1}),u=(0,a.KR)(),d=(0,a.KR)(),v=(0,a.KR)(),h=(0,a.KR)(),g=(0,a.KR)(),b=(0,a.KR)(),y=(0,a.KR)(),w=(0,a.KR)(),L=(0,a.KR)(),z=(0,a.KR)(),R=(0,a.KR)(),k=(0,a.KR)(!1),A=(0,a.KR)(),N=(0,a.KR)(!1),{form:_,formItem:G}=(0,D.j)(),{inputId:Y}=(0,D.W)(e,{formItemContext:G}),{valueOnClear:Q,isEmptyValue:Z}=(0,F.fQ)(e),{isComposing:J,handleCompositionStart:ee,handleCompositionUpdate:te,handleCompositionEnd:le}=(0,V.o)({afterComposition:e=>De(e)}),ne=(0,P.CB)(),{wrapperRef:ae,isFocused:oe,handleBlur:ce}=(0,$.K)(g,{disabled:ne,afterFocus(){e.automaticDropdown&&!k.value&&(k.value=!0,i.menuVisibleOnFocus=!0)},beforeBlur(e){var t,l;return(null==(t=v.value)?void 0:t.isFocusInsideContent(e))||(null==(l=h.value)?void 0:l.isFocusInsideContent(e))},afterBlur(){var t;k.value=!1,i.menuVisibleOnFocus=!1,e.validateEvent&&(null==(t=null==G?void 0:G.validate)||t.call(G,"blur").catch(e=>(0,C.U)(e)))}}),re=(0,n.EW)(()=>(0,o.cy)(e.modelValue)?e.modelValue.length>0:!Z(e.modelValue)),se=(0,n.EW)(()=>{var e;return null!=(e=null==_?void 0:_.statusIcon)&&e}),ie=(0,n.EW)(()=>e.clearable&&!ne.value&&re.value&&(oe.value||i.inputHovering)),ue=(0,n.EW)(()=>e.remote&&e.filterable&&!e.remoteShowSuffix?"":e.suffixIcon),de=(0,n.EW)(()=>r.is("reverse",!(!ue.value||!k.value))),fe=(0,n.EW)(()=>(null==G?void 0:G.validateState)||""),pe=(0,n.EW)(()=>fe.value&&H.vK[fe.value]),me=(0,n.EW)(()=>e.remote?e.debounce:0),ve=(0,n.EW)(()=>e.remote&&!i.inputValue&&0===i.options.size),he=(0,n.EW)(()=>e.loading?e.loadingText||l("el.select.loading"):e.filterable&&i.inputValue&&i.options.size>0&&0===ge.value?e.noMatchText||l("el.select.noMatch"):0===i.options.size?e.noDataText||l("el.select.noData"):null),ge=(0,n.EW)(()=>be.value.filter(e=>e.visible).length),be=(0,n.EW)(()=>{const e=Array.from(i.options.values()),t=[];return i.optionValues.forEach(l=>{const n=e.findIndex(e=>e.value===l);n>-1&&t.push(e[n])}),t.length>=e.length?t:e}),ye=(0,n.EW)(()=>Array.from(i.cachedOptions.values())),Ce=(0,n.EW)(()=>{const t=be.value.filter(e=>!e.created).some(e=>e.currentLabel===i.inputValue);return e.filterable&&e.allowCreate&&""!==i.inputValue&&!t}),we=()=>{e.filterable&&(0,o.Tn)(e.filterMethod)||e.filterable&&e.remote&&(0,o.Tn)(e.remoteMethod)||be.value.forEach(e=>{var t;null==(t=e.updateOption)||t.call(e,i.inputValue)})},Le=(0,P.NV)(),xe=(0,n.EW)(()=>["small"].includes(Le.value)?"small":"default"),Me=(0,n.EW)({get(){return k.value&&(e.loading||!ve.value)&&(!N.value||!(0,j.Im)(i.previousQuery))},set(e){k.value=e}}),ze=(0,n.EW)(()=>{if(e.multiple&&!(0,j.b0)(e.modelValue))return 0===(0,f.A)(e.modelValue).length&&!i.inputValue;const t=(0,o.cy)(e.modelValue)?e.modelValue[0]:e.modelValue;return!e.filterable&&!(0,j.b0)(t)||!i.inputValue}),Re=(0,n.EW)(()=>{var t;const n=null!=(t=e.placeholder)?t:l("el.select.placeholder");return e.multiple||!re.value?n:i.selectedLabel}),ke=(0,n.EW)(()=>B.un?null:"mouseenter");(0,n.wB)(()=>e.modelValue,(t,l)=>{e.multiple&&e.filterable&&!e.reserveKeyword&&(i.inputValue="",Se("")),Ae(),!(0,m.A)(t,l)&&e.validateEvent&&(null==G||G.validate("change").catch(e=>(0,C.U)(e)))},{flush:"post",deep:!0}),(0,n.wB)(()=>k.value,e=>{e?Se(i.inputValue):(i.inputValue="",i.previousQuery=null,i.isBeforeHide=!0)}),(0,n.wB)(()=>i.options.entries(),()=>{B.oc&&(Ae(),e.defaultFirstOption&&(e.filterable||e.remote)&&ge.value&&Ee())},{flush:"post"}),(0,n.wB)([()=>i.hoveringIndex,be],([e])=>{(0,j.Et)(e)&&e>-1?A.value=be.value[e]||{}:A.value={},be.value.forEach(e=>{e.hover=A.value===e})}),(0,n.nT)(()=>{i.isBeforeHide||we()});const Se=t=>{i.previousQuery===t||J.value||(i.previousQuery=t,e.filterable&&(0,o.Tn)(e.filterMethod)?e.filterMethod(t):e.filterable&&e.remote&&(0,o.Tn)(e.remoteMethod)&&e.remoteMethod(t),e.defaultFirstOption&&(e.filterable||e.remote)&&ge.value?(0,n.dY)(Ee):(0,n.dY)(_e))},Ee=()=>{const e=be.value.filter(e=>e.visible&&!e.disabled&&!e.states.groupDisabled),t=e.find(e=>e.created),l=e[0],n=be.value.map(e=>e.value);i.hoveringIndex=Xe(n,t||l)},Ae=()=>{if(!e.multiple){const t=(0,o.cy)(e.modelValue)?e.modelValue[0]:e.modelValue,l=Ne(t);return i.selectedLabel=l.currentLabel,void(i.selected=[l])}i.selectedLabel="";const t=[];(0,j.b0)(e.modelValue)||(0,f.A)(e.modelValue).forEach(e=>{t.push(Ne(e))}),i.selected=t},Ne=t=>{let l;const n=(0,o.Qd)(t);for(let o=i.cachedOptions.size-1;o>=0;o--){const a=ye.value[o],c=n?(0,p.A)(a.value,e.valueKey)===(0,p.A)(t,e.valueKey):a.value===t;if(c){l={index:be.value.filter(e=>!e.created).indexOf(a),value:t,currentLabel:a.currentLabel,get isDisabled(){return a.isDisabled}};break}}if(l)return l;const a=n?t.label:null!=t?t:"",c={index:-1,value:t,currentLabel:a};return c},_e=()=>{const e=i.selected.length;if(e>0){const t=i.selected[e-1];i.hoveringIndex=be.value.findIndex(e=>ot(t)===ot(e))}else i.hoveringIndex=-1},Te=()=>{i.selectionWidth=Number.parseFloat(window.getComputedStyle(d.value).width)},Oe=()=>{i.collapseItemWidth=z.value.getBoundingClientRect().width},We=()=>{var e,t;null==(t=null==(e=v.value)?void 0:e.updatePopper)||t.call(e)},Be=()=>{var e,t;null==(t=null==(e=h.value)?void 0:e.updatePopper)||t.call(e)},Ie=()=>{i.inputValue.length>0&&!k.value&&(k.value=!0),Se(i.inputValue)},De=t=>{if(i.inputValue=t.target.value,!e.remote)return Ie();N.value=!0,Fe()},Fe=(0,B.xD)(()=>{Ie(),N.value=!1},me),Ve=l=>{(0,m.A)(e.modelValue,l)||t(U.YU,l)},Pe=e=>(0,T.A)(e,e=>{const t=i.cachedOptions.get(e);return!(null==t?void 0:t.disabled)&&!(null==t?void 0:t.states.groupDisabled)}),$e=l=>{const n=(0,K.CG)(l);if(e.multiple&&n!==X.R.delete&&l.target.value.length<=0){const l=(0,f.A)(e.modelValue).slice(),n=Pe(l);if(n<0)return;const a=l[n];l.splice(n,1),t(U.l4,l),Ve(l),t("remove-tag",a)}},He=(l,n)=>{const a=i.selected.indexOf(n);if(a>-1&&!ne.value){const l=(0,f.A)(e.modelValue).slice();l.splice(a,1),t(U.l4,l),Ve(l),t("remove-tag",n.value)}l.stopPropagation(),Ze()},je=l=>{l.stopPropagation();const n=e.multiple?[]:Q.value;if(e.multiple)for(const e of i.selected)e.isDisabled&&n.push(e.value);t(U.l4,n),Ve(n),i.hoveringIndex=-1,k.value=!1,t("clear"),Ze()},Ke=l=>{var a;if(e.multiple){const n=(0,f.A)(null!=(a=e.modelValue)?a:[]).slice(),o=Xe(n,l);o>-1?n.splice(o,1):(e.multipleLimit<=0||n.length{Ue(l)})},Xe=(t,l)=>(0,j.b0)(l)?-1:(0,o.Gv)(l.value)?t.findIndex(t=>(0,m.A)((0,p.A)(t,e.valueKey),ot(l))):t.indexOf(l.value),Ue=e=>{var t,l,n,a,c;const s=(0,o.cy)(e)?e[e.length-1]:e;let i=null;if(!(0,O.A)(null==s?void 0:s.value)){const e=be.value.filter(e=>e.value===s.value);e.length>0&&(i=e[0].$el)}if(v.value&&i){const e=null==(a=null==(n=null==(l=null==(t=v.value)?void 0:t.popperRef)?void 0:l.contentRef)?void 0:n.querySelector)?void 0:a.call(n,`.${r.be("dropdown","wrap")}`);e&&(0,q.Rt)(e,i)}null==(c=R.value)||c.handleScroll()},qe=e=>{i.options.set(e.value,e),i.cachedOptions.set(e.value,e)},Ge=(e,t)=>{i.options.get(e)===t&&i.options.delete(e)},Ye=(0,n.EW)(()=>{var e,t;return null==(t=null==(e=v.value)?void 0:e.popperRef)?void 0:t.contentRef}),Qe=()=>{i.isBeforeHide=!1,(0,n.dY)(()=>{var e;null==(e=R.value)||e.update(),Ue(i.selected)})},Ze=()=>{var e;null==(e=g.value)||e.focus()},Je=()=>{var e;if(k.value)return k.value=!1,void(0,n.dY)(()=>{var e;return null==(e=g.value)?void 0:e.blur()});null==(e=g.value)||e.blur()},et=e=>{je(e)},tt=e=>{if(k.value=!1,oe.value){const t=new FocusEvent("blur",e);(0,n.dY)(()=>ce(t))}},lt=()=>{i.inputValue.length>0?i.inputValue="":k.value=!1},nt=t=>{var l;ne.value||e.filterable&&k.value&&t&&!(null==(l=y.value)?void 0:l.contains(t.target))||(B.un&&(i.inputHovering=!0),i.menuVisibleOnFocus?i.menuVisibleOnFocus=!1:k.value=!k.value)},at=()=>{if(k.value){const e=be.value[i.hoveringIndex];e&&!e.isDisabled&&Ke(e)}else nt()},ot=t=>(0,o.Gv)(t.value)?(0,p.A)(t.value,e.valueKey):t.value,ct=(0,n.EW)(()=>be.value.filter(e=>e.visible).every(e=>e.isDisabled)),rt=(0,n.EW)(()=>e.multiple?e.collapseTags?i.selected.slice(0,e.maxCollapseTags):i.selected:[]),st=(0,n.EW)(()=>e.multiple&&e.collapseTags?i.selected.slice(e.maxCollapseTags):[]),it=e=>{if(k.value){if(0!==i.options.size&&0!==ge.value&&!J.value&&!ct.value){"next"===e?(i.hoveringIndex++,i.hoveringIndex===i.options.size&&(i.hoveringIndex=0)):"prev"===e&&(i.hoveringIndex--,i.hoveringIndex<0&&(i.hoveringIndex=i.options.size-1));const t=be.value[i.hoveringIndex];!t.isDisabled&&t.visible||it(e),(0,n.dY)(()=>Ue(A.value))}}else k.value=!0},ut=(e,t,l,n)=>{for(let a=t;a>=0&&a{var l;const a=i.options.size;if(0===a)return;const o=(0,W.A)(e,0,a-1),c=be.value,r="up"===t?-1:1,s=null!=(l=ut(c,o,r,a))?l:ut(c,o-r,-r,a);null!=s&&(i.hoveringIndex=s,(0,n.dY)(()=>Ue(A.value)))},ft=e=>{const t=(0,K.CG)(e);let l=!0;switch(t){case X.R.up:it("prev");break;case X.R.down:it("next");break;case X.R.enter:case X.R.numpadEnter:J.value||at();break;case X.R.esc:lt();break;case X.R.backspace:return l=!1,void $e(e);case X.R.home:if(!k.value)return;dt(0,"down");break;case X.R.end:if(!k.value)return;dt(i.options.size-1,"up");break;case X.R.pageUp:if(!k.value)return;dt(i.hoveringIndex-10,"up");break;case X.R.pageDown:if(!k.value)return;dt(i.hoveringIndex+10,"down");break;default:l=!1;break}l&&(e.preventDefault(),e.stopPropagation())},pt=()=>{if(!d.value)return 0;const e=window.getComputedStyle(d.value);return Number.parseFloat(e.gap||"6px")},mt=(0,n.EW)(()=>{const t=pt(),l=e.filterable?t+E.R:0,n=z.value&&1===e.maxCollapseTags?i.selectionWidth-i.collapseItemWidth-t-l:i.selectionWidth-l;return{maxWidth:`${n}px`}}),vt=(0,n.EW)(()=>({maxWidth:`${i.selectionWidth}px`})),ht=e=>{t("popup-scroll",e)};let gt;return(0,S.wYm)(d,Te),(0,S.wYm)(ae,We),(0,S.wYm)(L,Be),(0,S.wYm)(z,Oe),(0,n.wB)(()=>Me.value,e=>{e?gt=(0,S.wYm)(w,We).stop:(null==gt||gt(),gt=void 0),t("visible-change",e)}),(0,n.sV)(()=>{Ae()}),{inputId:Y,contentId:c,nsSelect:r,nsInput:s,states:i,isFocused:oe,expanded:k,optionsArray:be,hoverOption:A,selectSize:Le,filteredOptionsCount:ge,updateTooltip:We,updateTagTooltip:Be,debouncedOnInputChange:Fe,onInput:De,deletePrevTag:$e,deleteTag:He,deleteSelected:je,handleOptionSelect:Ke,scrollToOption:Ue,hasModelValue:re,shouldShowPlaceholder:ze,currentPlaceholder:Re,mouseEnterEventName:ke,needStatusIcon:se,showClearBtn:ie,iconComponent:ue,iconReverse:de,validateState:fe,validateIcon:pe,showNewOption:Ce,updateOptions:we,collapseTagSize:xe,setSelected:Ae,selectDisabled:ne,emptyText:he,handleCompositionStart:ee,handleCompositionUpdate:te,handleCompositionEnd:le,handleKeydown:ft,onOptionCreate:qe,onOptionDestroy:Ge,handleMenuEnter:Qe,focus:Ze,blur:Je,handleClearClick:et,handleClickOutside:tt,handleEsc:lt,toggleMenu:nt,selectOption:at,getValueKey:ot,navigateOptions:it,dropdownMenuVisible:Me,showTagList:rt,collapseTagList:st,popupScroll:ht,getOption:Ne,tagStyle:mt,collapseTagStyle:vt,popperRef:Ye,inputRef:g,tooltipRef:v,tagTooltipRef:h,prefixRef:b,suffixRef:y,selectRef:u,wrapperRef:ae,selectionRef:d,scrollbarRef:R,menuRef:w,tagMenuRef:L,collapseItemRef:z}};var Y=(0,n.pM)({name:"ElOptions",setup(e,{slots:t}){const l=(0,n.WQ)(v.u);let a=[];return()=>{var e,n;const c=null==(e=t.default)?void 0:e.call(t),r=[];function s(e){(0,o.cy)(e)&&e.forEach(e=>{var t,l,n,a;const c=null==(t=(null==e?void 0:e.type)||{})?void 0:t.name;"ElOptionGroup"===c?s((0,o.Kg)(e.children)||(0,o.cy)(e.children)||!(0,o.Tn)(null==(l=e.children)?void 0:l.default)?e.children:null==(n=e.children)?void 0:n.default()):"ElOption"===c?r.push(null==(a=e.props)?void 0:a.value):(0,o.cy)(e.children)&&s(e.children)})}return c.length&&s(null==(n=c[0])?void 0:n.children),(0,m.A)(r,a)||(a=r,l&&(l.states.optionValues=r)),c}}}),Q=l(6484),Z=l(7477),J=l(9825),ee=l(3845),te=l(2251),le=l(3829),ne=l(8501);const ae=(0,h.b_)({name:String,id:String,modelValue:{type:(0,h.jq)([Array,String,Number,Boolean,Object]),default:void 0},autocomplete:{type:String,default:"off"},automaticDropdown:Boolean,size:ee.mU,effect:{type:(0,h.jq)(String),default:"light"},disabled:{type:Boolean,default:void 0},clearable:Boolean,filterable:Boolean,allowCreate:Boolean,loading:Boolean,popperClass:{type:String,default:""},popperStyle:{type:(0,h.jq)([String,Object])},popperOptions:{type:(0,h.jq)(Object),default:()=>({})},remote:Boolean,debounce:{type:Number,default:300},loadingText:String,noMatchText:String,noDataText:String,remoteMethod:{type:(0,h.jq)(Function)},filterMethod:{type:(0,h.jq)(Function)},multiple:Boolean,multipleLimit:{type:Number,default:0},placeholder:{type:String},defaultFirstOption:Boolean,reserveKeyword:{type:Boolean,default:!0},valueKey:{type:String,default:"value"},collapseTags:Boolean,collapseTagsTooltip:Boolean,maxCollapseTags:{type:Number,default:1},teleported:te.E.teleported,persistent:{type:Boolean,default:!0},clearIcon:{type:H.Ze,default:Z.CircleClose},fitInputWidth:Boolean,suffixIcon:{type:H.Ze,default:Z.ArrowDown},tagType:{...le.z.type,default:"info"},tagEffect:{...le.z.effect,default:"light"},validateEvent:{type:Boolean,default:!0},remoteShowSuffix:Boolean,showArrow:{type:Boolean,default:!0},offset:{type:Number,default:12},placement:{type:(0,h.jq)(String),values:Q.DD,default:"bottom-start"},fallbackPlacements:{type:(0,h.jq)(Array),default:["bottom-start","top-start","right","left"]},tabindex:{type:[String,Number],default:0},appendTo:te.E.appendTo,options:{type:(0,h.jq)(Array)},props:{type:(0,h.jq)(Object),default:()=>d.G},...F.bs,...(0,ne.l)(["ariaLabel"])}),oe=(U.l4,U.YU,J.f.scroll,(0,n.pM)({name:"ElOptionGroup",componentName:"ElOptionGroup",props:{label:String,disabled:Boolean},setup(e){const t=(0,x.DU)("select"),l=(0,a.KR)(),c=(0,n.nI)(),r=(0,a.KR)([]);(0,n.Gt)(v.P,(0,a.Kh)({...(0,a.QW)(e)}));const s=(0,n.EW)(()=>r.value.some(e=>!0===e.visible)),i=e=>{var t;return"ElOption"===e.type.name&&!!(null==(t=e.component)?void 0:t.proxy)},u=e=>{const t=(0,f.A)(e),l=[];return t.forEach(e=>{var t;(0,n.vv)(e)&&(i(e)?l.push(e.component.proxy):(0,o.cy)(e.children)&&e.children.length?l.push(...u(e.children)):(null==(t=e.component)?void 0:t.subTree)&&l.push(...u(e.component.subTree)))}),l},d=()=>{r.value=u(c.subTree)};return(0,n.sV)(()=>{d()}),(0,S.P1n)(l,d,{attributes:!0,subtree:!0,childList:!0}),{groupRef:l,visible:s,ns:t}}}));function ce(e,t,l,a,r,s){return(0,n.bo)(((0,n.uX)(),(0,n.CE)("ul",{ref:"groupRef",class:(0,o.C4)(e.ns.be("group","wrap"))},[(0,n.Lk)("li",{class:(0,o.C4)(e.ns.be("group","title"))},(0,o.v_)(e.label),3),(0,n.Lk)("li",null,[(0,n.Lk)("ul",{class:(0,o.C4)(e.ns.b("group"))},[(0,n.RG)(e.$slots,"default")],2)])],2)),[[c.aG,e.visible]])}var re=(0,L.A)(oe,[["render",ce],["__file","option-group.vue"]]),se=l(2142),ie=l(3337),ue=l(6139);const de="ElSelect",fe=new WeakMap,pe=e=>(...t)=>{var l,n;const a=t[0];if(!a||a.includes('Slot "default" invoked outside of the render function')&&(null==(l=t[2])?void 0:l.includes("ElTreeSelect")))return;const o=null==(n=fe.get(e))?void 0:n.originalWarnHandler;o?o(...t):console.warn(...t)},me=e=>{let t=fe.get(e);return t||(t={originalWarnHandler:e.config.warnHandler,handler:pe(e),count:0},fe.set(e,t)),t},ve=(0,n.pM)({name:de,componentName:de,components:{ElSelectMenu:_,ElOption:k,ElOptions:Y,ElOptionGroup:re,ElTag:i.u,ElScrollbar:s.kA,ElTooltip:r.R7,ElIcon:u.tk},directives:{ClickOutside:se.A},props:ae,emits:[U.l4,U.YU,"remove-tag","clear","visible-change","focus","blur","popup-scroll"],setup(e,{emit:t,slots:l}){const c=(0,n.nI)(),r=me(c.appContext);r.count+=1,c.appContext.config.warnHandler=r.handler;const s=(0,n.EW)(()=>{const{modelValue:t,multiple:l}=e,n=l?[]:void 0;return(0,o.cy)(t)?l?t:n:l?n:t}),i=(0,a.Kh)({...(0,a.QW)(e),modelValue:s}),u=G(i,t),{calculatorRef:f,inputStyle:p}=(0,ie.v)(),{getLabel:m,getValue:h,getOptions:g,getDisabled:b}=(0,d.Y)(e),y=e=>({label:m(e),value:h(e),disabled:b(e)}),C=e=>e.reduce((e,t)=>(e.push(t),t.children&&t.children.length>0&&e.push(...C(t.children)),e),[]),w=e=>{const t=(0,ue.CW)(e||[]);t.forEach(e=>{var t;if((0,o.Gv)(e)&&("ElOption"===e.type.name||"ElTree"===e.type.name)){const l=e.type.name;if("ElTree"===l){const l=(null==(t=e.props)?void 0:t.data)||[],n=C(l);n.forEach(e=>{e.currentLabel=e.label||((0,o.Gv)(e.value)?"":e.value),u.onOptionCreate(e)})}else if("ElOption"===l){const t={...e.props};t.currentLabel=t.label||((0,o.Gv)(t.value)?"":t.value),u.onOptionCreate(t)}}})};(0,n.wB)(()=>{var e;return[null==(e=l.default)?void 0:e.call(l),s.value]},()=>{var t;e.persistent||u.expanded.value||(u.states.options.clear(),w(null==(t=l.default)?void 0:t.call(l)))},{immediate:!0}),(0,n.Gt)(v.u,(0,a.Kh)({props:i,states:u.states,selectRef:u.selectRef,optionsArray:u.optionsArray,setSelected:u.setSelected,handleOptionSelect:u.handleOptionSelect,onOptionCreate:u.onOptionCreate,onOptionDestroy:u.onOptionDestroy}));const L=(0,n.EW)(()=>e.multiple?u.states.selected.map(e=>e.currentLabel):u.states.selectedLabel);return(0,n.xo)(()=>{const e=fe.get(c.appContext);e&&(e.count-=1,e.count<=0&&(c.appContext.config.warnHandler=e.originalWarnHandler,fe.delete(c.appContext)))}),{...u,modelValue:s,selectedLabel:L,calculatorRef:f,inputStyle:p,getLabel:m,getValue:h,getOptions:g,getDisabled:b,getOptionProps:y}}});function he(e,t){const l=(0,n.g2)("el-tag"),a=(0,n.g2)("el-tooltip"),r=(0,n.g2)("el-icon"),s=(0,n.g2)("el-option"),i=(0,n.g2)("el-option-group"),u=(0,n.g2)("el-options"),d=(0,n.g2)("el-scrollbar"),f=(0,n.g2)("el-select-menu"),p=(0,n.gN)("click-outside");return(0,n.bo)(((0,n.uX)(),(0,n.CE)("div",{ref:"selectRef",class:(0,o.C4)([e.nsSelect.b(),e.nsSelect.m(e.selectSize)]),[(0,o.rU)(e.mouseEnterEventName)]:t=>e.states.inputHovering=!0,onMouseleave:t=>e.states.inputHovering=!1},[(0,n.bF)(a,{ref:"tooltipRef",visible:e.dropdownMenuVisible,placement:e.placement,teleported:e.teleported,"popper-class":[e.nsSelect.e("popper"),e.popperClass],"popper-style":e.popperStyle,"popper-options":e.popperOptions,"fallback-placements":e.fallbackPlacements,effect:e.effect,pure:"",trigger:"click",transition:`${e.nsSelect.namespace.value}-zoom-in-top`,"stop-popper-mouse-event":!1,"gpu-acceleration":!1,persistent:e.persistent,"append-to":e.appendTo,"show-arrow":e.showArrow,offset:e.offset,onBeforeShow:e.handleMenuEnter,onHide:t=>e.states.isBeforeHide=!1},{default:(0,n.k6)(()=>{var t;return[(0,n.Lk)("div",{ref:"wrapperRef",class:(0,o.C4)([e.nsSelect.e("wrapper"),e.nsSelect.is("focused",e.isFocused),e.nsSelect.is("hovering",e.states.inputHovering),e.nsSelect.is("filterable",e.filterable),e.nsSelect.is("disabled",e.selectDisabled)]),onClick:(0,c.D$)(e.toggleMenu,["prevent"])},[e.$slots.prefix?((0,n.uX)(),(0,n.CE)("div",{key:0,ref:"prefixRef",class:(0,o.C4)(e.nsSelect.e("prefix"))},[(0,n.RG)(e.$slots,"prefix")],2)):(0,n.Q3)("v-if",!0),(0,n.Lk)("div",{ref:"selectionRef",class:(0,o.C4)([e.nsSelect.e("selection"),e.nsSelect.is("near",e.multiple&&!e.$slots.prefix&&!!e.states.selected.length)])},[e.multiple?(0,n.RG)(e.$slots,"tag",{key:0,data:e.states.selected,deleteTag:e.deleteTag,selectDisabled:e.selectDisabled},()=>[((0,n.uX)(!0),(0,n.CE)(n.FK,null,(0,n.pI)(e.showTagList,t=>((0,n.uX)(),(0,n.CE)("div",{key:e.getValueKey(t),class:(0,o.C4)(e.nsSelect.e("selected-item"))},[(0,n.bF)(l,{closable:!e.selectDisabled&&!t.isDisabled,size:e.collapseTagSize,type:e.tagType,effect:e.tagEffect,"disable-transitions":"",style:(0,o.Tr)(e.tagStyle),onClose:l=>e.deleteTag(l,t)},{default:(0,n.k6)(()=>[(0,n.Lk)("span",{class:(0,o.C4)(e.nsSelect.e("tags-text"))},[(0,n.RG)(e.$slots,"label",{index:t.index,label:t.currentLabel,value:t.value},()=>[(0,n.eW)((0,o.v_)(t.currentLabel),1)])],2)]),_:2},1032,["closable","size","type","effect","style","onClose"])],2))),128)),e.collapseTags&&e.states.selected.length>e.maxCollapseTags?((0,n.uX)(),(0,n.Wv)(a,{key:0,ref:"tagTooltipRef",disabled:e.dropdownMenuVisible||!e.collapseTagsTooltip,"fallback-placements":["bottom","top","right","left"],effect:e.effect,placement:"bottom","popper-class":e.popperClass,"popper-style":e.popperStyle,teleported:e.teleported},{default:(0,n.k6)(()=>[(0,n.Lk)("div",{ref:"collapseItemRef",class:(0,o.C4)(e.nsSelect.e("selected-item"))},[(0,n.bF)(l,{closable:!1,size:e.collapseTagSize,type:e.tagType,effect:e.tagEffect,"disable-transitions":"",style:(0,o.Tr)(e.collapseTagStyle)},{default:(0,n.k6)(()=>[(0,n.Lk)("span",{class:(0,o.C4)(e.nsSelect.e("tags-text"))}," + "+(0,o.v_)(e.states.selected.length-e.maxCollapseTags),3)]),_:1},8,["size","type","effect","style"])],2)]),content:(0,n.k6)(()=>[(0,n.Lk)("div",{ref:"tagMenuRef",class:(0,o.C4)(e.nsSelect.e("selection"))},[((0,n.uX)(!0),(0,n.CE)(n.FK,null,(0,n.pI)(e.collapseTagList,t=>((0,n.uX)(),(0,n.CE)("div",{key:e.getValueKey(t),class:(0,o.C4)(e.nsSelect.e("selected-item"))},[(0,n.bF)(l,{class:"in-tooltip",closable:!e.selectDisabled&&!t.isDisabled,size:e.collapseTagSize,type:e.tagType,effect:e.tagEffect,"disable-transitions":"",onClose:l=>e.deleteTag(l,t)},{default:(0,n.k6)(()=>[(0,n.Lk)("span",{class:(0,o.C4)(e.nsSelect.e("tags-text"))},[(0,n.RG)(e.$slots,"label",{index:t.index,label:t.currentLabel,value:t.value},()=>[(0,n.eW)((0,o.v_)(t.currentLabel),1)])],2)]),_:2},1032,["closable","size","type","effect","onClose"])],2))),128))],2)]),_:3},8,["disabled","effect","popper-class","popper-style","teleported"])):(0,n.Q3)("v-if",!0)]):(0,n.Q3)("v-if",!0),(0,n.Lk)("div",{class:(0,o.C4)([e.nsSelect.e("selected-item"),e.nsSelect.e("input-wrapper"),e.nsSelect.is("hidden",!e.filterable||e.selectDisabled)])},[(0,n.bo)((0,n.Lk)("input",{id:e.inputId,ref:"inputRef","onUpdate:modelValue":t=>e.states.inputValue=t,type:"text",name:e.name,class:(0,o.C4)([e.nsSelect.e("input"),e.nsSelect.is(e.selectSize)]),disabled:e.selectDisabled,autocomplete:e.autocomplete,style:(0,o.Tr)(e.inputStyle),tabindex:e.tabindex,role:"combobox",readonly:!e.filterable,spellcheck:"false","aria-activedescendant":(null==(t=e.hoverOption)?void 0:t.id)||"","aria-controls":e.contentId,"aria-expanded":e.dropdownMenuVisible,"aria-label":e.ariaLabel,"aria-autocomplete":"none","aria-haspopup":"listbox",onKeydown:e.handleKeydown,onCompositionstart:e.handleCompositionStart,onCompositionupdate:e.handleCompositionUpdate,onCompositionend:e.handleCompositionEnd,onInput:e.onInput,onClick:(0,c.D$)(e.toggleMenu,["stop"])},null,46,["id","onUpdate:modelValue","name","disabled","autocomplete","tabindex","readonly","aria-activedescendant","aria-controls","aria-expanded","aria-label","onKeydown","onCompositionstart","onCompositionupdate","onCompositionend","onInput","onClick"]),[[c.Jo,e.states.inputValue]]),e.filterable?((0,n.uX)(),(0,n.CE)("span",{key:0,ref:"calculatorRef","aria-hidden":"true",class:(0,o.C4)(e.nsSelect.e("input-calculator")),textContent:(0,o.v_)(e.states.inputValue)},null,10,["textContent"])):(0,n.Q3)("v-if",!0)],2),e.shouldShowPlaceholder?((0,n.uX)(),(0,n.CE)("div",{key:1,class:(0,o.C4)([e.nsSelect.e("selected-item"),e.nsSelect.e("placeholder"),e.nsSelect.is("transparent",!e.hasModelValue||e.expanded&&!e.states.inputValue)])},[e.hasModelValue?(0,n.RG)(e.$slots,"label",{key:0,index:e.getOption(e.modelValue).index,label:e.currentPlaceholder,value:e.modelValue},()=>[(0,n.Lk)("span",null,(0,o.v_)(e.currentPlaceholder),1)]):((0,n.uX)(),(0,n.CE)("span",{key:1},(0,o.v_)(e.currentPlaceholder),1))],2)):(0,n.Q3)("v-if",!0)],2),(0,n.Lk)("div",{ref:"suffixRef",class:(0,o.C4)(e.nsSelect.e("suffix"))},[e.iconComponent&&!e.showClearBtn?((0,n.uX)(),(0,n.Wv)(r,{key:0,class:(0,o.C4)([e.nsSelect.e("caret"),e.nsSelect.e("icon"),e.iconReverse])},{default:(0,n.k6)(()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)(e.iconComponent)))]),_:1},8,["class"])):(0,n.Q3)("v-if",!0),e.showClearBtn&&e.clearIcon?((0,n.uX)(),(0,n.Wv)(r,{key:1,class:(0,o.C4)([e.nsSelect.e("caret"),e.nsSelect.e("icon"),e.nsSelect.e("clear")]),onClick:e.handleClearClick},{default:(0,n.k6)(()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)(e.clearIcon)))]),_:1},8,["class","onClick"])):(0,n.Q3)("v-if",!0),e.validateState&&e.validateIcon&&e.needStatusIcon?((0,n.uX)(),(0,n.Wv)(r,{key:2,class:(0,o.C4)([e.nsInput.e("icon"),e.nsInput.e("validateIcon"),e.nsInput.is("loading","validating"===e.validateState)])},{default:(0,n.k6)(()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)(e.validateIcon)))]),_:1},8,["class"])):(0,n.Q3)("v-if",!0)],2)],10,["onClick"])]}),content:(0,n.k6)(()=>[(0,n.bF)(f,{ref:"menuRef"},{default:(0,n.k6)(()=>[e.$slots.header?((0,n.uX)(),(0,n.CE)("div",{key:0,class:(0,o.C4)(e.nsSelect.be("dropdown","header")),onClick:(0,c.D$)(()=>{},["stop"])},[(0,n.RG)(e.$slots,"header")],10,["onClick"])):(0,n.Q3)("v-if",!0),(0,n.bo)((0,n.bF)(d,{id:e.contentId,ref:"scrollbarRef",tag:"ul","wrap-class":e.nsSelect.be("dropdown","wrap"),"view-class":e.nsSelect.be("dropdown","list"),class:(0,o.C4)([e.nsSelect.is("empty",0===e.filteredOptionsCount)]),role:"listbox","aria-label":e.ariaLabel,"aria-orientation":"vertical",onScroll:e.popupScroll},{default:(0,n.k6)(()=>[e.showNewOption?((0,n.uX)(),(0,n.Wv)(s,{key:0,value:e.states.inputValue,created:!0},null,8,["value"])):(0,n.Q3)("v-if",!0),(0,n.bF)(u,null,{default:(0,n.k6)(()=>[(0,n.RG)(e.$slots,"default",{},()=>[((0,n.uX)(!0),(0,n.CE)(n.FK,null,(0,n.pI)(e.options,(t,l)=>{var a;return(0,n.uX)(),(0,n.CE)(n.FK,{key:l},[(null==(a=e.getOptions(t))?void 0:a.length)?((0,n.uX)(),(0,n.Wv)(i,{key:0,label:e.getLabel(t),disabled:e.getDisabled(t)},{default:(0,n.k6)(()=>[((0,n.uX)(!0),(0,n.CE)(n.FK,null,(0,n.pI)(e.getOptions(t),t=>((0,n.uX)(),(0,n.Wv)(s,(0,n.v6)({key:e.getValue(t)},e.getOptionProps(t)),null,16))),128))]),_:2},1032,["label","disabled"])):((0,n.uX)(),(0,n.Wv)(s,(0,o._B)((0,n.v6)({key:1},e.getOptionProps(t))),null,16))],64)}),128))])]),_:3})]),_:3},8,["id","wrap-class","view-class","class","aria-label","onScroll"]),[[c.aG,e.states.options.size>0&&!e.loading]]),e.$slots.loading&&e.loading?((0,n.uX)(),(0,n.CE)("div",{key:1,class:(0,o.C4)(e.nsSelect.be("dropdown","loading"))},[(0,n.RG)(e.$slots,"loading")],2)):e.loading||0===e.filteredOptionsCount?((0,n.uX)(),(0,n.CE)("div",{key:2,class:(0,o.C4)(e.nsSelect.be("dropdown","empty"))},[(0,n.RG)(e.$slots,"empty",{},()=>[(0,n.Lk)("span",null,(0,o.v_)(e.emptyText),1)])],2)):(0,n.Q3)("v-if",!0),e.$slots.footer?((0,n.uX)(),(0,n.CE)("div",{key:3,class:(0,o.C4)(e.nsSelect.be("dropdown","footer")),onClick:(0,c.D$)(()=>{},["stop"])},[(0,n.RG)(e.$slots,"footer")],10,["onClick"])):(0,n.Q3)("v-if",!0)]),_:3},512)]),_:3},8,["visible","placement","teleported","popper-class","popper-style","popper-options","fallback-placements","effect","transition","persistent","append-to","show-arrow","offset","onBeforeShow","onHide"])],16,["onMouseleave"])),[[p,e.handleClickOutside,e.popperRef]])}var ge=(0,L.A)(ve,[["render",he],["__file","select.vue"]]),be=l(5376);const ye=(0,be.GU)(ge,{Option:k,OptionGroup:re}),Ce=(0,be.WM)(k),we=(0,be.WM)(re)},6032:function(e,t){"use strict";function l(e){return null==e}t.A=l},6054:function(e,t){"use strict";function l(){return[]}t.A=l},6062:function(e,t,l){"use strict";var n=l(7162),a=l(9578),o=(0,n.A)(a.A,"Map");t.A=o},6080:function(e,t,l){"use strict";var n=l(7476),a=l(9306),o=l(616),c=n(n.bind);e.exports=function(e,t){return a(e),void 0===t?e:o?c(e,t):function(){return e.apply(t,arguments)}}},6110:function(e,t,l){l(8111),l(1701),function(t,l){e.exports=l()}(0,function(){"use strict";var e={LTS:"h:mm:ss A",LT:"h:mm A",L:"MM/DD/YYYY",LL:"MMMM D, YYYY",LLL:"MMMM D, YYYY h:mm A",LLLL:"dddd, MMMM D, YYYY h:mm A"},t=/(\[[^[]*\])|([-_:/.,()\s]+)|(A|a|Q|YYYY|YY?|ww?|MM?M?M?|Do|DD?|hh?|HH?|mm?|ss?|S{1,3}|z|ZZ?)/g,l=/\d/,n=/\d\d/,a=/\d\d?/,o=/\d*[^-_:/,()\s\d]+/,c={},r=function(e){return(e=+e)+(e>68?1900:2e3)},s=function(e){return function(t){this[e]=+t}},i=[/[+-]\d\d:?(\d\d)?|Z/,function(e){(this.zone||(this.zone={})).offset=function(e){if(!e)return 0;if("Z"===e)return 0;var t=e.match(/([+-]|\d\d)/g),l=60*t[1]+(+t[2]||0);return 0===l?0:"+"===t[0]?-l:l}(e)}],u=function(e){var t=c[e];return t&&(t.indexOf?t:t.s.concat(t.f))},d=function(e,t){var l,n=c.meridiem;if(n){for(var a=1;a<=24;a+=1)if(e.indexOf(n(a,0,t))>-1){l=a>12;break}}else l=e===(t?"pm":"PM");return l},f={A:[o,function(e){this.afternoon=d(e,!1)}],a:[o,function(e){this.afternoon=d(e,!0)}],Q:[l,function(e){this.month=3*(e-1)+1}],S:[l,function(e){this.milliseconds=100*+e}],SS:[n,function(e){this.milliseconds=10*+e}],SSS:[/\d{3}/,function(e){this.milliseconds=+e}],s:[a,s("seconds")],ss:[a,s("seconds")],m:[a,s("minutes")],mm:[a,s("minutes")],H:[a,s("hours")],h:[a,s("hours")],HH:[a,s("hours")],hh:[a,s("hours")],D:[a,s("day")],DD:[n,s("day")],Do:[o,function(e){var t=c.ordinal,l=e.match(/\d+/);if(this.day=l[0],t)for(var n=1;n<=31;n+=1)t(n).replace(/\[|\]/g,"")===e&&(this.day=n)}],w:[a,s("week")],ww:[n,s("week")],M:[a,s("month")],MM:[n,s("month")],MMM:[o,function(e){var t=u("months"),l=(u("monthsShort")||t.map(function(e){return e.slice(0,3)})).indexOf(e)+1;if(l<1)throw new Error;this.month=l%12||l}],MMMM:[o,function(e){var t=u("months").indexOf(e)+1;if(t<1)throw new Error;this.month=t%12||t}],Y:[/[+-]?\d+/,s("year")],YY:[n,function(e){this.year=r(e)}],YYYY:[/\d{4}/,s("year")],Z:i,ZZ:i};function p(l){var n,a;n=l,a=c&&c.formats;for(var o=(l=n.replace(/(\[[^\]]+])|(LTS?|l{1,4}|L{1,4})/g,function(t,l,n){var o=n&&n.toUpperCase();return l||a[n]||e[n]||a[o].replace(/(\[[^\]]+])|(MMMM|MM|DD|dddd)/g,function(e,t,l){return t||l.slice(1)})})).match(t),r=o.length,s=0;s-1)return new Date(("X"===t?1e3:1)*e);var a=p(t)(e),o=a.year,c=a.month,r=a.day,s=a.hours,i=a.minutes,u=a.seconds,d=a.milliseconds,f=a.zone,m=a.week,v=new Date,h=r||(o||c?1:v.getDate()),g=o||v.getFullYear(),b=0;o&&!c||(b=c>0?c-1:v.getMonth());var y,C=s||0,w=i||0,L=u||0,x=d||0;return f?new Date(Date.UTC(g,b,h,C,w,L,x+60*f.offset*1e3)):l?new Date(Date.UTC(g,b,h,C,w,L,x)):(y=new Date(g,b,h,C,w,L,x),m&&(y=n(y).week(m).toDate()),y)}catch(e){return new Date("")}}(t,r,n,l),this.init(),d&&!0!==d&&(this.$L=this.locale(d).$L),u&&t!=this.format(r)&&(this.$d=new Date("")),c={}}else if(r instanceof Array)for(var f=r.length,m=1;m<=f;m+=1){o[1]=r[m-1];var v=l.apply(this,o);if(v.isValid()){this.$d=v.$d,this.$L=v.$L,this.init();break}m===f&&(this.$d=new Date(""))}else a.call(this,e)}}})},6119:function(e,t,l){"use strict";var n=l(5745),a=l(3392),o=n("keys");e.exports=function(e){return o[e]||(o[e]=a(e))}},6125:function(e,t,l){"use strict";l.d(t,{Ft:function(){return o},WB:function(){return a}});var n=l(7378);const a=["dialog","grid","group","listbox","menu","navigation","tooltip","tree"],o=(0,n.b_)({role:{type:String,values:a,default:"tooltip"}})},6139:function(e,t,l){"use strict";l.d(t,{CW:function(){return f},Yn:function(){return r},jO:function(){return u},oh:function(){return d},zv:function(){return s}});l(4114),l(8111),l(7588);var n=l(6768),a=l(4232),o=l(6894);const c="utils/vue/vnode";var r=(e=>(e[e["TEXT"]=1]="TEXT",e[e["CLASS"]=2]="CLASS",e[e["STYLE"]=4]="STYLE",e[e["PROPS"]=8]="PROPS",e[e["FULL_PROPS"]=16]="FULL_PROPS",e[e["HYDRATE_EVENTS"]=32]="HYDRATE_EVENTS",e[e["STABLE_FRAGMENT"]=64]="STABLE_FRAGMENT",e[e["KEYED_FRAGMENT"]=128]="KEYED_FRAGMENT",e[e["UNKEYED_FRAGMENT"]=256]="UNKEYED_FRAGMENT",e[e["NEED_PATCH"]=512]="NEED_PATCH",e[e["DYNAMIC_SLOTS"]=1024]="DYNAMIC_SLOTS",e[e["HOISTED"]=-1]="HOISTED",e[e["BAIL"]=-2]="BAIL",e))(r||{});function s(e){return(0,n.vv)(e)&&e.type===n.FK}function i(e){return(0,n.vv)(e)&&e.type===n.Mw}function u(e){return(0,n.vv)(e)&&!s(e)&&!i(e)}const d=e=>{if(!(0,n.vv)(e))return(0,o.U)(c,"[getNormalizedProps] must be a VNode"),{};const t=e.props||{},l=((0,n.vv)(e.type)?e.type.props:void 0)||{},r={};return Object.keys(l).forEach(e=>{(0,a.$3)(l[e],"default")&&(r[e]=l[e].default)}),Object.keys(t).forEach(e=>{r[(0,a.PT)(e)]=t[e]}),r},f=e=>{const t=(0,a.cy)(e)?e:[e],l=[];return t.forEach(e=>{var t;(0,a.cy)(e)?l.push(...f(e)):(0,n.vv)(e)&&(null==(t=e.component)?void 0:t.subTree)?l.push(e,...f(e.component.subTree)):(0,n.vv)(e)&&(0,a.cy)(e.children)?l.push(...f(e.children)):(0,n.vv)(e)&&2===e.shapeFlag?l.push(...f(e.type())):l.push(e)}),l}},6149:function(e,t,l){"use strict";l.d(t,{$:function(){return d},p:function(){return f}});var n=l(7477),a=l(3845),o=l(464),c=l(6769),r=l(8501),s=l(2056),i=l(7378),u=l(4232);const d=(0,i.b_)({id:{type:String,default:void 0},size:a.mU,disabled:{type:Boolean,default:void 0},modelValue:{type:(0,i.jq)([String,Number,Object]),default:""},modelModifiers:{type:(0,i.jq)(Object),default:()=>({})},maxlength:{type:[String,Number]},minlength:{type:[String,Number]},type:{type:(0,i.jq)(String),default:"text"},resize:{type:String,values:["none","both","horizontal","vertical"]},autosize:{type:(0,i.jq)([Boolean,Object]),default:!1},autocomplete:{type:(0,i.jq)(String),default:"off"},formatter:{type:Function},parser:{type:Function},placeholder:{type:String},form:{type:String},readonly:Boolean,clearable:Boolean,clearIcon:{type:o.Ze,default:n.CircleClose},showPassword:Boolean,showWordLimit:Boolean,wordLimitPosition:{type:String,values:["inside","outside"],default:"inside"},suffixIcon:{type:o.Ze},prefixIcon:{type:o.Ze},containerRole:{type:String,default:void 0},tabindex:{type:[String,Number],default:0},validateEvent:{type:Boolean,default:!0},inputStyle:{type:(0,i.jq)([Object,Array,String]),default:()=>(0,c.f)({})},autofocus:Boolean,rows:{type:Number,default:2},...(0,r.l)(["ariaLabel"]),inputmode:{type:(0,i.jq)(String),default:void 0},name:String}),f={[s.l4]:e=>(0,u.Kg)(e),input:e=>(0,u.Kg)(e),change:(e,t)=>(0,u.Kg)(e)&&(t instanceof Event||void 0===t),focus:e=>e instanceof FocusEvent,blur:e=>e instanceof FocusEvent,clear:()=>!0,mouseleave:e=>e instanceof MouseEvent,mouseenter:e=>e instanceof MouseEvent,keydown:e=>e instanceof Event,compositionstart:e=>e instanceof CompositionEvent,compositionupdate:e=>e instanceof CompositionEvent,compositionend:e=>e instanceof CompositionEvent}},6162:function(e,t,l){"use strict";l.d(t,{A:function(){return f}});var n=l(1591),a=l(2799),o="[object Arguments]";function c(e){return(0,a.A)(e)&&(0,n.A)(e)==o}var r=c,s=Object.prototype,i=s.hasOwnProperty,u=s.propertyIsEnumerable,d=r(function(){return arguments}())?r:function(e){return(0,a.A)(e)&&i.call(e,"callee")&&!u.call(e,"callee")},f=d},6166:function(e,t,l){"use strict";l.d(t,{A:function(){return m}});var n=l(5318),a=(l(4114),l(729)),o=l(9314),c=(0,o.A)(Object.keys,Object),r=c,s=Object.prototype,i=s.hasOwnProperty;function u(e){if(!(0,a.A)(e))return r(e);var t=[];for(var l in Object(e))i.call(e,l)&&"constructor"!=l&&t.push(l);return t}var d=u,f=l(1805);function p(e){return(0,f.A)(e)?(0,n.A)(e):d(e)}var m=p},6193:function(e,t,l){"use strict";var n=l(4215);e.exports="NODE"===n},6198:function(e,t,l){"use strict";var n=l(8014);e.exports=function(e){return n(e.length)}},6200:function(e,t,l){"use strict";l.d(t,{A:function(){return k}});l(6573),l(8100),l(7936);var n=l(7162),a=l(9578),o=(0,n.A)(a.A,"DataView"),c=o,r=l(6062),s=(0,n.A)(a.A,"Promise"),i=s,u=l(3452),d=(0,n.A)(a.A,"WeakMap"),f=d,p=l(1591),m=l(3534),v="[object Map]",h="[object Object]",g="[object Promise]",b="[object Set]",y="[object WeakMap]",C="[object DataView]",w=(0,m.A)(c),L=(0,m.A)(r.A),x=(0,m.A)(i),M=(0,m.A)(u.A),z=(0,m.A)(f),R=p.A;(c&&R(new c(new ArrayBuffer(1)))!=C||r.A&&R(new r.A)!=v||i&&R(i.resolve())!=g||u.A&&R(new u.A)!=b||f&&R(new f)!=y)&&(R=function(e){var t=(0,p.A)(e),l=t==h?e.constructor:void 0,n=l?(0,m.A)(l):"";if(n)switch(n){case w:return C;case L:return v;case x:return g;case M:return b;case z:return y}return t});var k=R},6268:function(e,t,l){"use strict";l.d(t,{vx:function(){return u},Ym:function(){return d}});var n=l(144),a=l(6768),o=l(9615),c={name:"en",el:{breadcrumb:{label:"Breadcrumb"},colorpicker:{confirm:"OK",clear:"Clear",defaultLabel:"color picker",description:"current color is {color}. press enter to select a new color.",alphaLabel:"pick alpha value",alphaDescription:"alpha {alpha}, current color is {color}",hueLabel:"pick hue value",hueDescription:"hue {hue}, current color is {color}",svLabel:"pick saturation and brightness value",svDescription:"saturation {saturation}, brightness {brightness}, current color is {color}",predefineDescription:"select {value} as the color"},datepicker:{now:"Now",today:"Today",cancel:"Cancel",clear:"Clear",confirm:"OK",dateTablePrompt:"Use the arrow keys and enter to select the day of the month",monthTablePrompt:"Use the arrow keys and enter to select the month",yearTablePrompt:"Use the arrow keys and enter to select the year",selectedDate:"Selected date",selectDate:"Select date",selectTime:"Select time",startDate:"Start Date",startTime:"Start Time",endDate:"End Date",endTime:"End Time",prevYear:"Previous Year",nextYear:"Next Year",prevMonth:"Previous Month",nextMonth:"Next Month",year:"",month1:"January",month2:"February",month3:"March",month4:"April",month5:"May",month6:"June",month7:"July",month8:"August",month9:"September",month10:"October",month11:"November",month12:"December",weeks:{sun:"Sun",mon:"Mon",tue:"Tue",wed:"Wed",thu:"Thu",fri:"Fri",sat:"Sat"},weeksFull:{sun:"Sunday",mon:"Monday",tue:"Tuesday",wed:"Wednesday",thu:"Thursday",fri:"Friday",sat:"Saturday"},months:{jan:"Jan",feb:"Feb",mar:"Mar",apr:"Apr",may:"May",jun:"Jun",jul:"Jul",aug:"Aug",sep:"Sep",oct:"Oct",nov:"Nov",dec:"Dec"}},inputNumber:{decrease:"decrease number",increase:"increase number"},select:{loading:"Loading",noMatch:"No matching data",noData:"No data",placeholder:"Select"},mention:{loading:"Loading"},dropdown:{toggleDropdown:"Toggle Dropdown"},cascader:{noMatch:"No matching data",loading:"Loading",placeholder:"Select",noData:"No data"},pagination:{goto:"Go to",pagesize:"/page",total:"Total {total}",pageClassifier:"",page:"Page",prev:"Go to previous page",next:"Go to next page",currentPage:"page {pager}",prevPages:"Previous {pager} pages",nextPages:"Next {pager} pages",deprecationWarning:"Deprecated usages detected, please refer to the el-pagination documentation for more details"},dialog:{close:"Close this dialog"},drawer:{close:"Close this dialog"},messagebox:{title:"Message",confirm:"OK",cancel:"Cancel",error:"Illegal input",close:"Close this dialog"},upload:{deleteTip:"press delete to remove",delete:"Delete",preview:"Preview",continue:"Continue"},slider:{defaultLabel:"slider between {min} and {max}",defaultRangeStartLabel:"pick start value",defaultRangeEndLabel:"pick end value"},table:{emptyText:"No Data",confirmFilter:"Confirm",resetFilter:"Reset",clearFilter:"All",sumText:"Sum",selectAllLabel:"Select all rows",selectRowLabel:"Select this row",expandRowLabel:"Expand this row",collapseRowLabel:"Collapse this row",sortLabel:"Sort by {column}",filterLabel:"Filter by {column}"},tag:{close:"Close this tag"},tour:{next:"Next",previous:"Previous",finish:"Finish",close:"Close this dialog"},tree:{emptyText:"No Data"},transfer:{noMatch:"No matching data",noData:"No data",titles:["List 1","List 2"],filterPlaceholder:"Enter keyword",noCheckedFormat:"{total} items",hasCheckedFormat:"{checked}/{total} checked"},image:{error:"FAILED"},pageHeader:{title:"Back"},popconfirm:{confirmButtonText:"Yes",cancelButtonText:"No"},carousel:{leftArrow:"Carousel arrow left",rightArrow:"Carousel arrow right",indicator:"Carousel switch to index {index}"}}};const r=e=>(t,l)=>s(t,l,(0,n.R1)(e)),s=(e,t,l)=>(0,o.A)(l,e,e).replace(/\{(\w+)\}/g,(e,l)=>{var n;return`${null!=(n=null==t?void 0:t[l])?n:`{${l}}`}`}),i=e=>{const t=(0,a.EW)(()=>(0,n.R1)(e).name),l=(0,n.i9)(e)?e:(0,n.KR)(e);return{lang:t,locale:l,t:r(e)}},u=Symbol("localeContextKey"),d=e=>{const t=e||(0,a.WQ)(u,(0,n.KR)());return i((0,a.EW)(()=>t.value||c))}},6269:function(e){"use strict";e.exports={}},6279:function(e,t,l){"use strict";var n=l(6840);e.exports=function(e,t,l){for(var a in t)n(e,a,t[a],l);return e}},6301:function(e,t,l){"use strict";l.d(t,{A:function(){return f}});var n=l(168),a=l(9578),o=function(){return a.A.Date.now()},c=o,r=l(754),s="Expected a function",i=Math.max,u=Math.min;function d(e,t,l){var a,o,d,f,p,m,v=0,h=!1,g=!1,b=!0;if("function"!=typeof e)throw new TypeError(s);function y(t){var l=a,n=o;return a=o=void 0,v=t,f=e.apply(n,l),f}function C(e){return v=e,p=setTimeout(x,t),h?y(e):f}function w(e){var l=e-m,n=e-v,a=t-l;return g?u(a,d-n):a}function L(e){var l=e-m,n=e-v;return void 0===m||l>=t||l<0||g&&n>=d}function x(){var e=c();if(L(e))return M(e);p=setTimeout(x,w(e))}function M(e){return p=void 0,b&&a?y(e):(a=o=void 0,f)}function z(){void 0!==p&&clearTimeout(p),v=0,a=m=o=p=void 0}function R(){return void 0===p?f:M(c())}function k(){var e=c(),l=L(e);if(a=arguments,o=this,m=e,l){if(void 0===p)return C(m);if(g)return clearTimeout(p),p=setTimeout(x,t),y(m)}return void 0===p&&(p=setTimeout(x,t)),f}return t=(0,r.A)(t)||0,(0,n.A)(l)&&(h=!!l.leading,g="maxWait"in l,d=g?i((0,r.A)(l.maxWait)||0,t):d,b="trailing"in l?!!l.trailing:b),k.cancel=z,k.flush=R,k}var f=d},6319:function(e,t,l){"use strict";var n=l(8551),a=l(9539);e.exports=function(e,t,l,o){try{return o?t(n(l)[0],l[1]):t(l)}catch(c){a(e,"throw",c)}}},6340:function(e,t,l){"use strict";l.d(t,{Hl:function(){return s},Lw:function(){return f},pW:function(){return d},rQ:function(){return u},tp:function(){return r},uG:function(){return c},xe:function(){return i}});l(8111),l(2489);const n='a[href],button:not([disabled]),button:not([hidden]),:not([tabindex="-1"]),input:not([disabled]),input:not([type="hidden"]),select:not([disabled]),textarea:not([disabled])',a=e=>"undefined"!==typeof Element&&e instanceof Element,o=e=>{const t=getComputedStyle(e);return"fixed"!==t.position&&null!==e.offsetParent},c=e=>Array.from(e.querySelectorAll(n)).filter(e=>r(e)&&o(e)),r=e=>{if(e.tabIndex>0||0===e.tabIndex&&null!==e.getAttribute("tabIndex"))return!0;if(e.tabIndex<0||e.hasAttribute("disabled")||"true"===e.getAttribute("aria-disabled"))return!1;switch(e.nodeName){case"A":return!!e.href&&"ignore"!==e.rel;case"INPUT":return!("hidden"===e.type||"file"===e.type);case"BUTTON":case"SELECT":case"TEXTAREA":return!0;default:return!1}},s=function(e,t,...l){let n;n=t.includes("mouse")||t.includes("click")?"MouseEvents":t.includes("key")?"KeyboardEvent":"HTMLEvents";const a=document.createEvent(n);return a.initEvent(t,...l),e.dispatchEvent(a),e},i=e=>!e.getAttribute("aria-owns"),u=(e,t,l)=>{const{parentNode:n}=e;if(!n)return null;const a=n.querySelectorAll(l),o=Array.prototype.indexOf.call(a,e);return a[o+t]||null},d=(e,t)=>{if(!e||!e.focus)return;let l=!1;!a(e)||r(e)||e.getAttribute("tabindex")||(e.setAttribute("tabindex","-1"),l=!0),e.focus(t),a(e)&&l&&e.removeAttribute("tabindex")},f=e=>{e&&(d(e),!i(e)&&e.click())}},6368:function(e,t,l){"use strict";var n=l(6518),a=l(4576),o=l(9225).clear;n({global:!0,bind:!0,enumerable:!0,forced:a.clearImmediate!==o},{clearImmediate:o})},6395:function(e){"use strict";e.exports=!1},6484:function(e,t,l){"use strict";l.d(t,{DD:function(){return h},n4:function(){return rt}});l(4114),l(8111),l(1148),l(2489),l(116),l(7588),l(1701),l(8237),l(3579),l(7642),l(8004),l(3853),l(5876),l(2475),l(5024),l(1698);var n="top",a="bottom",o="right",c="left",r="auto",s=[n,a,o,c],i="start",u="end",d="clippingParents",f="viewport",p="popper",m="reference",v=s.reduce(function(e,t){return e.concat([t+"-"+i,t+"-"+u])},[]),h=[].concat(s,[r]).reduce(function(e,t){return e.concat([t,t+"-"+i,t+"-"+u])},[]),g="beforeRead",b="read",y="afterRead",C="beforeMain",w="main",L="afterMain",x="beforeWrite",M="write",z="afterWrite",R=[g,b,y,C,w,L,x,M,z];function k(e){return e?(e.nodeName||"").toLowerCase():null}function S(e){if(null==e)return window;if("[object Window]"!==e.toString()){var t=e.ownerDocument;return t&&t.defaultView||window}return e}function E(e){var t=S(e).Element;return e instanceof t||e instanceof Element}function A(e){var t=S(e).HTMLElement;return e instanceof t||e instanceof HTMLElement}function N(e){if("undefined"==typeof ShadowRoot)return!1;var t=S(e).ShadowRoot;return e instanceof t||e instanceof ShadowRoot}function _(e){var t=e.state;Object.keys(t.elements).forEach(function(e){var l=t.styles[e]||{},n=t.attributes[e]||{},a=t.elements[e];!A(a)||!k(a)||(Object.assign(a.style,l),Object.keys(n).forEach(function(e){var t=n[e];!1===t?a.removeAttribute(e):a.setAttribute(e,!0===t?"":t)}))})}function T(e){var t=e.state,l={popper:{position:t.options.strategy,left:"0",top:"0",margin:"0"},arrow:{position:"absolute"},reference:{}};return Object.assign(t.elements.popper.style,l.popper),t.styles=l,t.elements.arrow&&Object.assign(t.elements.arrow.style,l.arrow),function(){Object.keys(t.elements).forEach(function(e){var n=t.elements[e],a=t.attributes[e]||{},o=Object.keys(t.styles.hasOwnProperty(e)?t.styles[e]:l[e]),c=o.reduce(function(e,t){return e[t]="",e},{});!A(n)||!k(n)||(Object.assign(n.style,c),Object.keys(a).forEach(function(e){n.removeAttribute(e)}))})}}var O={name:"applyStyles",enabled:!0,phase:"write",fn:_,effect:T,requires:["computeStyles"]};function W(e){return e.split("-")[0]}var B=Math.max,I=Math.min,D=Math.round;function F(e,t){void 0===t&&(t=!1);var l=e.getBoundingClientRect(),n=1,a=1;if(A(e)&&t){var o=e.offsetHeight,c=e.offsetWidth;c>0&&(n=D(l.width)/c||1),o>0&&(a=D(l.height)/o||1)}return{width:l.width/n,height:l.height/a,top:l.top/a,right:l.right/n,bottom:l.bottom/a,left:l.left/n,x:l.left/n,y:l.top/a}}function V(e){var t=F(e),l=e.offsetWidth,n=e.offsetHeight;return Math.abs(t.width-l)<=1&&(l=t.width),Math.abs(t.height-n)<=1&&(n=t.height),{x:e.offsetLeft,y:e.offsetTop,width:l,height:n}}function P(e,t){var l=t.getRootNode&&t.getRootNode();if(e.contains(t))return!0;if(l&&N(l)){var n=t;do{if(n&&e.isSameNode(n))return!0;n=n.parentNode||n.host}while(n)}return!1}function $(e){return S(e).getComputedStyle(e)}function H(e){return["table","td","th"].indexOf(k(e))>=0}function j(e){return((E(e)?e.ownerDocument:e.document)||window.document).documentElement}function K(e){return"html"===k(e)?e:e.assignedSlot||e.parentNode||(N(e)?e.host:null)||j(e)}function X(e){return A(e)&&"fixed"!==$(e).position?e.offsetParent:null}function U(e){var t=-1!==navigator.userAgent.toLowerCase().indexOf("firefox"),l=-1!==navigator.userAgent.indexOf("Trident");if(l&&A(e)){var n=$(e);if("fixed"===n.position)return null}var a=K(e);for(N(a)&&(a=a.host);A(a)&&["html","body"].indexOf(k(a))<0;){var o=$(a);if("none"!==o.transform||"none"!==o.perspective||"paint"===o.contain||-1!==["transform","perspective"].indexOf(o.willChange)||t&&"filter"===o.willChange||t&&o.filter&&"none"!==o.filter)return a;a=a.parentNode}return null}function q(e){for(var t=S(e),l=X(e);l&&H(l)&&"static"===$(l).position;)l=X(l);return l&&("html"===k(l)||"body"===k(l)&&"static"===$(l).position)?t:l||U(e)||t}function G(e){return["top","bottom"].indexOf(e)>=0?"x":"y"}function Y(e,t,l){return B(e,I(t,l))}function Q(e,t,l){var n=Y(e,t,l);return n>l?l:n}function Z(){return{top:0,right:0,bottom:0,left:0}}function J(e){return Object.assign({},Z(),e)}function ee(e,t){return t.reduce(function(t,l){return t[l]=e,t},{})}var te=function(e,t){return e="function"==typeof e?e(Object.assign({},t.rects,{placement:t.placement})):e,J("number"!=typeof e?e:ee(e,s))};function le(e){var t,l=e.state,r=e.name,s=e.options,i=l.elements.arrow,u=l.modifiersData.popperOffsets,d=W(l.placement),f=G(d),p=[c,o].indexOf(d)>=0,m=p?"height":"width";if(i&&u){var v=te(s.padding,l),h=V(i),g="y"===f?n:c,b="y"===f?a:o,y=l.rects.reference[m]+l.rects.reference[f]-u[f]-l.rects.popper[m],C=u[f]-l.rects.reference[f],w=q(i),L=w?"y"===f?w.clientHeight||0:w.clientWidth||0:0,x=y/2-C/2,M=v[g],z=L-h[m]-v[b],R=L/2-h[m]/2+x,k=Y(M,R,z),S=f;l.modifiersData[r]=(t={},t[S]=k,t.centerOffset=k-R,t)}}function ne(e){var t=e.state,l=e.options,n=l.element,a=void 0===n?"[data-popper-arrow]":n;null!=a&&("string"==typeof a&&(a=t.elements.popper.querySelector(a),!a)||!P(t.elements.popper,a)||(t.elements.arrow=a))}var ae={name:"arrow",enabled:!0,phase:"main",fn:le,effect:ne,requires:["popperOffsets"],requiresIfExists:["preventOverflow"]};function oe(e){return e.split("-")[1]}var ce={top:"auto",right:"auto",bottom:"auto",left:"auto"};function re(e){var t=e.x,l=e.y,n=window,a=n.devicePixelRatio||1;return{x:D(t*a)/a||0,y:D(l*a)/a||0}}function se(e){var t,l=e.popper,r=e.popperRect,s=e.placement,i=e.variation,d=e.offsets,f=e.position,p=e.gpuAcceleration,m=e.adaptive,v=e.roundOffsets,h=e.isFixed,g=d.x,b=void 0===g?0:g,y=d.y,C=void 0===y?0:y,w="function"==typeof v?v({x:b,y:C}):{x:b,y:C};b=w.x,C=w.y;var L=d.hasOwnProperty("x"),x=d.hasOwnProperty("y"),M=c,z=n,R=window;if(m){var k=q(l),E="clientHeight",A="clientWidth";if(k===S(l)&&(k=j(l),"static"!==$(k).position&&"absolute"===f&&(E="scrollHeight",A="scrollWidth")),s===n||(s===c||s===o)&&i===u){z=a;var N=h&&k===R&&R.visualViewport?R.visualViewport.height:k[E];C-=N-r.height,C*=p?1:-1}if(s===c||(s===n||s===a)&&i===u){M=o;var _=h&&k===R&&R.visualViewport?R.visualViewport.width:k[A];b-=_-r.width,b*=p?1:-1}}var T,O=Object.assign({position:f},m&&ce),W=!0===v?re({x:b,y:C}):{x:b,y:C};return b=W.x,C=W.y,p?Object.assign({},O,(T={},T[z]=x?"0":"",T[M]=L?"0":"",T.transform=(R.devicePixelRatio||1)<=1?"translate("+b+"px, "+C+"px)":"translate3d("+b+"px, "+C+"px, 0)",T)):Object.assign({},O,(t={},t[z]=x?C+"px":"",t[M]=L?b+"px":"",t.transform="",t))}function ie(e){var t=e.state,l=e.options,n=l.gpuAcceleration,a=void 0===n||n,o=l.adaptive,c=void 0===o||o,r=l.roundOffsets,s=void 0===r||r,i={placement:W(t.placement),variation:oe(t.placement),popper:t.elements.popper,popperRect:t.rects.popper,gpuAcceleration:a,isFixed:"fixed"===t.options.strategy};null!=t.modifiersData.popperOffsets&&(t.styles.popper=Object.assign({},t.styles.popper,se(Object.assign({},i,{offsets:t.modifiersData.popperOffsets,position:t.options.strategy,adaptive:c,roundOffsets:s})))),null!=t.modifiersData.arrow&&(t.styles.arrow=Object.assign({},t.styles.arrow,se(Object.assign({},i,{offsets:t.modifiersData.arrow,position:"absolute",adaptive:!1,roundOffsets:s})))),t.attributes.popper=Object.assign({},t.attributes.popper,{"data-popper-placement":t.placement})}var ue={name:"computeStyles",enabled:!0,phase:"beforeWrite",fn:ie,data:{}},de={passive:!0};function fe(e){var t=e.state,l=e.instance,n=e.options,a=n.scroll,o=void 0===a||a,c=n.resize,r=void 0===c||c,s=S(t.elements.popper),i=[].concat(t.scrollParents.reference,t.scrollParents.popper);return o&&i.forEach(function(e){e.addEventListener("scroll",l.update,de)}),r&&s.addEventListener("resize",l.update,de),function(){o&&i.forEach(function(e){e.removeEventListener("scroll",l.update,de)}),r&&s.removeEventListener("resize",l.update,de)}}var pe={name:"eventListeners",enabled:!0,phase:"write",fn:function(){},effect:fe,data:{}},me={left:"right",right:"left",bottom:"top",top:"bottom"};function ve(e){return e.replace(/left|right|bottom|top/g,function(e){return me[e]})}var he={start:"end",end:"start"};function ge(e){return e.replace(/start|end/g,function(e){return he[e]})}function be(e){var t=S(e),l=t.pageXOffset,n=t.pageYOffset;return{scrollLeft:l,scrollTop:n}}function ye(e){return F(j(e)).left+be(e).scrollLeft}function Ce(e){var t=S(e),l=j(e),n=t.visualViewport,a=l.clientWidth,o=l.clientHeight,c=0,r=0;return n&&(a=n.width,o=n.height,/^((?!chrome|android).)*safari/i.test(navigator.userAgent)||(c=n.offsetLeft,r=n.offsetTop)),{width:a,height:o,x:c+ye(e),y:r}}function we(e){var t,l=j(e),n=be(e),a=null==(t=e.ownerDocument)?void 0:t.body,o=B(l.scrollWidth,l.clientWidth,a?a.scrollWidth:0,a?a.clientWidth:0),c=B(l.scrollHeight,l.clientHeight,a?a.scrollHeight:0,a?a.clientHeight:0),r=-n.scrollLeft+ye(e),s=-n.scrollTop;return"rtl"===$(a||l).direction&&(r+=B(l.clientWidth,a?a.clientWidth:0)-o),{width:o,height:c,x:r,y:s}}function Le(e){var t=$(e),l=t.overflow,n=t.overflowX,a=t.overflowY;return/auto|scroll|overlay|hidden/.test(l+a+n)}function xe(e){return["html","body","#document"].indexOf(k(e))>=0?e.ownerDocument.body:A(e)&&Le(e)?e:xe(K(e))}function Me(e,t){var l;void 0===t&&(t=[]);var n=xe(e),a=n===(null==(l=e.ownerDocument)?void 0:l.body),o=S(n),c=a?[o].concat(o.visualViewport||[],Le(n)?n:[]):n,r=t.concat(c);return a?r:r.concat(Me(K(c)))}function ze(e){return Object.assign({},e,{left:e.x,top:e.y,right:e.x+e.width,bottom:e.y+e.height})}function Re(e){var t=F(e);return t.top=t.top+e.clientTop,t.left=t.left+e.clientLeft,t.bottom=t.top+e.clientHeight,t.right=t.left+e.clientWidth,t.width=e.clientWidth,t.height=e.clientHeight,t.x=t.left,t.y=t.top,t}function ke(e,t){return t===f?ze(Ce(e)):E(t)?Re(t):ze(we(j(e)))}function Se(e){var t=Me(K(e)),l=["absolute","fixed"].indexOf($(e).position)>=0,n=l&&A(e)?q(e):e;return E(n)?t.filter(function(e){return E(e)&&P(e,n)&&"body"!==k(e)}):[]}function Ee(e,t,l){var n="clippingParents"===t?Se(e):[].concat(t),a=[].concat(n,[l]),o=a[0],c=a.reduce(function(t,l){var n=ke(e,l);return t.top=B(n.top,t.top),t.right=I(n.right,t.right),t.bottom=I(n.bottom,t.bottom),t.left=B(n.left,t.left),t},ke(e,o));return c.width=c.right-c.left,c.height=c.bottom-c.top,c.x=c.left,c.y=c.top,c}function Ae(e){var t,l=e.reference,r=e.element,s=e.placement,d=s?W(s):null,f=s?oe(s):null,p=l.x+l.width/2-r.width/2,m=l.y+l.height/2-r.height/2;switch(d){case n:t={x:p,y:l.y-r.height};break;case a:t={x:p,y:l.y+l.height};break;case o:t={x:l.x+l.width,y:m};break;case c:t={x:l.x-r.width,y:m};break;default:t={x:l.x,y:l.y}}var v=d?G(d):null;if(null!=v){var h="y"===v?"height":"width";switch(f){case i:t[v]=t[v]-(l[h]/2-r[h]/2);break;case u:t[v]=t[v]+(l[h]/2-r[h]/2);break}}return t}function Ne(e,t){void 0===t&&(t={});var l=t,c=l.placement,r=void 0===c?e.placement:c,i=l.boundary,u=void 0===i?d:i,v=l.rootBoundary,h=void 0===v?f:v,g=l.elementContext,b=void 0===g?p:g,y=l.altBoundary,C=void 0!==y&&y,w=l.padding,L=void 0===w?0:w,x=J("number"!=typeof L?L:ee(L,s)),M=b===p?m:p,z=e.rects.popper,R=e.elements[C?M:b],k=Ee(E(R)?R:R.contextElement||j(e.elements.popper),u,h),S=F(e.elements.reference),A=Ae({reference:S,element:z,strategy:"absolute",placement:r}),N=ze(Object.assign({},z,A)),_=b===p?N:S,T={top:k.top-_.top+x.top,bottom:_.bottom-k.bottom+x.bottom,left:k.left-_.left+x.left,right:_.right-k.right+x.right},O=e.modifiersData.offset;if(b===p&&O){var W=O[r];Object.keys(T).forEach(function(e){var t=[o,a].indexOf(e)>=0?1:-1,l=[n,a].indexOf(e)>=0?"y":"x";T[e]+=W[l]*t})}return T}function _e(e,t){void 0===t&&(t={});var l=t,n=l.placement,a=l.boundary,o=l.rootBoundary,c=l.padding,r=l.flipVariations,i=l.allowedAutoPlacements,u=void 0===i?h:i,d=oe(n),f=d?r?v:v.filter(function(e){return oe(e)===d}):s,p=f.filter(function(e){return u.indexOf(e)>=0});0===p.length&&(p=f);var m=p.reduce(function(t,l){return t[l]=Ne(e,{placement:l,boundary:a,rootBoundary:o,padding:c})[W(l)],t},{});return Object.keys(m).sort(function(e,t){return m[e]-m[t]})}function Te(e){if(W(e)===r)return[];var t=ve(e);return[ge(e),t,ge(t)]}function Oe(e){var t=e.state,l=e.options,s=e.name;if(!t.modifiersData[s]._skip){for(var u=l.mainAxis,d=void 0===u||u,f=l.altAxis,p=void 0===f||f,m=l.fallbackPlacements,v=l.padding,h=l.boundary,g=l.rootBoundary,b=l.altBoundary,y=l.flipVariations,C=void 0===y||y,w=l.allowedAutoPlacements,L=t.options.placement,x=W(L),M=x===L,z=m||(M||!C?[ve(L)]:Te(L)),R=[L].concat(z).reduce(function(e,l){return e.concat(W(l)===r?_e(t,{placement:l,boundary:h,rootBoundary:g,padding:v,flipVariations:C,allowedAutoPlacements:w}):l)},[]),k=t.rects.reference,S=t.rects.popper,E=new Map,A=!0,N=R[0],_=0;_=0,D=I?"width":"height",F=Ne(t,{placement:T,boundary:h,rootBoundary:g,altBoundary:b,padding:v}),V=I?B?o:c:B?a:n;k[D]>S[D]&&(V=ve(V));var P=ve(V),$=[];if(d&&$.push(F[O]<=0),p&&$.push(F[V]<=0,F[P]<=0),$.every(function(e){return e})){N=T,A=!1;break}E.set(T,$)}if(A)for(var H=C?3:1,j=function(e){var t=R.find(function(t){var l=E.get(t);if(l)return l.slice(0,e).every(function(e){return e})});if(t)return N=t,"break"},K=H;K>0;K--){var X=j(K);if("break"===X)break}t.placement!==N&&(t.modifiersData[s]._skip=!0,t.placement=N,t.reset=!0)}}var We={name:"flip",enabled:!0,phase:"main",fn:Oe,requiresIfExists:["offset"],data:{_skip:!1}};function Be(e,t,l){return void 0===l&&(l={x:0,y:0}),{top:e.top-t.height-l.y,right:e.right-t.width+l.x,bottom:e.bottom-t.height+l.y,left:e.left-t.width-l.x}}function Ie(e){return[n,o,a,c].some(function(t){return e[t]>=0})}function De(e){var t=e.state,l=e.name,n=t.rects.reference,a=t.rects.popper,o=t.modifiersData.preventOverflow,c=Ne(t,{elementContext:"reference"}),r=Ne(t,{altBoundary:!0}),s=Be(c,n),i=Be(r,a,o),u=Ie(s),d=Ie(i);t.modifiersData[l]={referenceClippingOffsets:s,popperEscapeOffsets:i,isReferenceHidden:u,hasPopperEscaped:d},t.attributes.popper=Object.assign({},t.attributes.popper,{"data-popper-reference-hidden":u,"data-popper-escaped":d})}var Fe={name:"hide",enabled:!0,phase:"main",requiresIfExists:["preventOverflow"],fn:De};function Ve(e,t,l){var a=W(e),r=[c,n].indexOf(a)>=0?-1:1,s="function"==typeof l?l(Object.assign({},t,{placement:e})):l,i=s[0],u=s[1];return i=i||0,u=(u||0)*r,[c,o].indexOf(a)>=0?{x:u,y:i}:{x:i,y:u}}function Pe(e){var t=e.state,l=e.options,n=e.name,a=l.offset,o=void 0===a?[0,0]:a,c=h.reduce(function(e,l){return e[l]=Ve(l,t.rects,o),e},{}),r=c[t.placement],s=r.x,i=r.y;null!=t.modifiersData.popperOffsets&&(t.modifiersData.popperOffsets.x+=s,t.modifiersData.popperOffsets.y+=i),t.modifiersData[n]=c}var $e={name:"offset",enabled:!0,phase:"main",requires:["popperOffsets"],fn:Pe};function He(e){var t=e.state,l=e.name;t.modifiersData[l]=Ae({reference:t.rects.reference,element:t.rects.popper,strategy:"absolute",placement:t.placement})}var je={name:"popperOffsets",enabled:!0,phase:"read",fn:He,data:{}};function Ke(e){return"x"===e?"y":"x"}function Xe(e){var t=e.state,l=e.options,r=e.name,s=l.mainAxis,u=void 0===s||s,d=l.altAxis,f=void 0!==d&&d,p=l.boundary,m=l.rootBoundary,v=l.altBoundary,h=l.padding,g=l.tether,b=void 0===g||g,y=l.tetherOffset,C=void 0===y?0:y,w=Ne(t,{boundary:p,rootBoundary:m,padding:h,altBoundary:v}),L=W(t.placement),x=oe(t.placement),M=!x,z=G(L),R=Ke(z),k=t.modifiersData.popperOffsets,S=t.rects.reference,E=t.rects.popper,A="function"==typeof C?C(Object.assign({},t.rects,{placement:t.placement})):C,N="number"==typeof A?{mainAxis:A,altAxis:A}:Object.assign({mainAxis:0,altAxis:0},A),_=t.modifiersData.offset?t.modifiersData.offset[t.placement]:null,T={x:0,y:0};if(k){if(u){var O,D="y"===z?n:c,F="y"===z?a:o,P="y"===z?"height":"width",$=k[z],H=$+w[D],j=$-w[F],K=b?-E[P]/2:0,X=x===i?S[P]:E[P],U=x===i?-E[P]:-S[P],J=t.elements.arrow,ee=b&&J?V(J):{width:0,height:0},te=t.modifiersData["arrow#persistent"]?t.modifiersData["arrow#persistent"].padding:Z(),le=te[D],ne=te[F],ae=Y(0,S[P],ee[P]),ce=M?S[P]/2-K-ae-le-N.mainAxis:X-ae-le-N.mainAxis,re=M?-S[P]/2+K+ae+ne+N.mainAxis:U+ae+ne+N.mainAxis,se=t.elements.arrow&&q(t.elements.arrow),ie=se?"y"===z?se.clientTop||0:se.clientLeft||0:0,ue=null!=(O=null==_?void 0:_[z])?O:0,de=$+ce-ue-ie,fe=$+re-ue,pe=Y(b?I(H,de):H,$,b?B(j,fe):j);k[z]=pe,T[z]=pe-$}if(f){var me,ve="x"===z?n:c,he="x"===z?a:o,ge=k[R],be="y"===R?"height":"width",ye=ge+w[ve],Ce=ge-w[he],we=-1!==[n,c].indexOf(L),Le=null!=(me=null==_?void 0:_[R])?me:0,xe=we?ye:ge-S[be]-E[be]-Le+N.altAxis,Me=we?ge+S[be]+E[be]-Le-N.altAxis:Ce,ze=b&&we?Q(xe,ge,Me):Y(b?xe:ye,ge,b?Me:Ce);k[R]=ze,T[R]=ze-ge}t.modifiersData[r]=T}}var Ue={name:"preventOverflow",enabled:!0,phase:"main",fn:Xe,requiresIfExists:["offset"]};function qe(e){return{scrollLeft:e.scrollLeft,scrollTop:e.scrollTop}}function Ge(e){return e!==S(e)&&A(e)?qe(e):be(e)}function Ye(e){var t=e.getBoundingClientRect(),l=D(t.width)/e.offsetWidth||1,n=D(t.height)/e.offsetHeight||1;return 1!==l||1!==n}function Qe(e,t,l){void 0===l&&(l=!1);var n=A(t),a=A(t)&&Ye(t),o=j(t),c=F(e,a),r={scrollLeft:0,scrollTop:0},s={x:0,y:0};return(n||!n&&!l)&&(("body"!==k(t)||Le(o))&&(r=Ge(t)),A(t)?(s=F(t,!0),s.x+=t.clientLeft,s.y+=t.clientTop):o&&(s.x=ye(o))),{x:c.left+r.scrollLeft-s.x,y:c.top+r.scrollTop-s.y,width:c.width,height:c.height}}function Ze(e){var t=new Map,l=new Set,n=[];function a(e){l.add(e.name);var o=[].concat(e.requires||[],e.requiresIfExists||[]);o.forEach(function(e){if(!l.has(e)){var n=t.get(e);n&&a(n)}}),n.push(e)}return e.forEach(function(e){t.set(e.name,e)}),e.forEach(function(e){l.has(e.name)||a(e)}),n}function Je(e){var t=Ze(e);return R.reduce(function(e,l){return e.concat(t.filter(function(e){return e.phase===l}))},[])}function et(e){var t;return function(){return t||(t=new Promise(function(l){Promise.resolve().then(function(){t=void 0,l(e())})})),t}}function tt(e){var t=e.reduce(function(e,t){var l=e[t.name];return e[t.name]=l?Object.assign({},l,t,{options:Object.assign({},l.options,t.options),data:Object.assign({},l.data,t.data)}):t,e},{});return Object.keys(t).map(function(e){return t[e]})}var lt={placement:"bottom",modifiers:[],strategy:"absolute"};function nt(){for(var e=arguments.length,t=new Array(e),l=0;l1?arguments[1]:void 0,this,this.length);return{read:t.read,written:t.written}}})},6636:function(e,t,l){"use strict";l.d(t,{A:function(){return m}});var n=l(5318),a=(l(4114),l(168)),o=l(729);function c(e){var t=[];if(null!=e)for(var l in Object(e))t.push(l);return t}var r=c,s=Object.prototype,i=s.hasOwnProperty;function u(e){if(!(0,a.A)(e))return r(e);var t=(0,o.A)(e),l=[];for(var n in e)("constructor"!=n||!t&&i.call(e,n))&&l.push(n);return l}var d=u,f=l(1805);function p(e){return(0,f.A)(e)?(0,n.A)(e,!0):d(e)}var m=p},6690:function(e,t,l){"use strict";var n=l(1805),a=l(2799);function o(e){return(0,a.A)(e)&&(0,n.A)(e)}t.A=o},6697:function(e,t,l){"use strict";l.d(t,{Cg:function(){return g},KR:function(){return b},N9:function(){return C},OX:function(){return c},Tc:function(){return n},U4:function(){return w},UZ:function(){return i},Wc:function(){return r},Y5:function(){return f},YF:function(){return s},bx:function(){return p},k0:function(){return o},rX:function(){return h},sr:function(){return y},tT:function(){return m},v_:function(){return d},xG:function(){return a},zf:function(){return v},zj:function(){return u}});const n=50,a="itemRendered",o="scroll",c="forward",r="backward",s="auto",i="smart",u="start",d="center",f="end",p="horizontal",m="vertical",v="ltr",h="rtl",g="negative",b="positive-ascending",y="positive-descending",C={[p]:"left",[m]:"top"},w=20},6699:function(e,t,l){"use strict";var n=l(3724),a=l(4913),o=l(6980);e.exports=n?function(e,t,l){return a.f(e,t,o(1,l))}:function(e,t,l){return e[t]=l,e}},6706:function(e,t,l){"use strict";var n=l(9504),a=l(9306);e.exports=function(e,t,l){try{return n(a(Object.getOwnPropertyDescriptor(e,t)[l]))}catch(o){}}},6711:function(e,t,l){"use strict";l(5331)},6714:function(e,t,l){"use strict";l.d(t,{_q:function(){return f}});var n=l(6768),a=l(1968),o=l(6139),c=l(7378),r=l(3513);const s=(0,c.b_)({mask:{type:Boolean,default:!0},customMaskEvent:Boolean,overlayClass:{type:(0,c.jq)([String,Array,Object])},zIndex:{type:(0,c.jq)([String,Number])}}),i={click:e=>e instanceof MouseEvent},u="overlay";var d=(0,n.pM)({name:"ElOverlay",props:s,emits:i,setup(e,{slots:t,emit:l}){const c=(0,r.DU)(u),s=e=>{l("click",e)},{onClick:i,onMousedown:d,onMouseup:f}=(0,a.r)(e.customMaskEvent?void 0:s);return()=>e.mask?(0,n.bF)("div",{class:[c.b(),e.overlayClass],style:{zIndex:e.zIndex},onClick:i,onMousedown:d,onMouseup:f},[(0,n.RG)(t,"default")],o.Yn.STYLE|o.Yn.CLASS|o.Yn.PROPS,["onClick","onMouseup","onMousedown"]):(0,n.h)("div",{class:e.overlayClass,style:{zIndex:e.zIndex,position:"fixed",top:"0px",right:"0px",bottom:"0px",left:"0px"}},[(0,n.RG)(t,"default")])}});const f=d},6768:function(e,t,l){"use strict";l.d(t,{$u:function(){return Me},$y:function(){return We},CE:function(){return zl},Df:function(){return ae},E3:function(){return Wl},EW:function(){return pn},EY:function(){return vl},FK:function(){return ml},Fv:function(){return Il},Gt:function(){return gt},Gy:function(){return X},Ht:function(){return qe},Ic:function(){return xe},Im:function(){return P},K9:function(){return nl},KC:function(){return we},Lk:function(){return Nl},MZ:function(){return ne},Mw:function(){return hl},Ng:function(){return Ol},OA:function(){return Ge},OW:function(){return ee},Q3:function(){return Dl},QP:function(){return q},R8:function(){return hn},RG:function(){return Pe},Tb:function(){return He},WQ:function(){return bt},Wv:function(){return Rl},Y4:function(){return me},bF:function(){return _l},bo:function(){return E},dY:function(){return h},eW:function(){return Bl},eX:function(){return Ve},g2:function(){return Te},gN:function(){return Be},h:function(){return mn},hi:function(){return Re},k6:function(){return S},n:function(){return pe},nI:function(){return ql},nT:function(){return wt},pI:function(){return Fe},pM:function(){return oe},pR:function(){return Z},qL:function(){return c},rE:function(){return vn},sV:function(){return Le},uX:function(){return Cl},v6:function(){return $l},vv:function(){return kl},wB:function(){return Lt},xo:function(){return ze}});l(4114),l(8111),l(1148),l(2489),l(7588),l(1701),l(8237),l(3579),l(3110),l(7642),l(8004),l(3853),l(5876),l(2475),l(5024),l(1698);var n=l(144),a=l(4232);function o(e,t,l,n){try{return n?e(...n):e()}catch(a){r(a,t,l)}}function c(e,t,l,n){if((0,a.Tn)(e)){const c=o(e,t,l,n);return c&&(0,a.yL)(c)&&c.catch(e=>{r(e,t,l)}),c}if((0,a.cy)(e)){const a=[];for(let o=0;o>>1,a=i[n],o=x(a);o=x(l)?i.push(e):i.splice(g(t),0,e),e.flags|=1,y()}}function y(){v||(v=m.then(M))}function C(e){(0,a.cy)(e)?d.push(...e):f&&-1===e.id?f.splice(p+1,0,e):1&e.flags||(d.push(e),e.flags|=1),y()}function w(e,t,l=u+1){for(0;lx(e)-x(t));if(d.length=0,f)return void f.push(...e);for(f=e,p=0;pnull==e.id?2&e.flags?-1:1/0:e.id;function M(e){a.tE;try{for(u=0;u{n._d&&xl(-1);const a=k(t);let o;try{o=e(...l)}finally{k(a),n._d&&xl(1)}return o};return n._n=!0,n._c=!0,n._d=!0,n}function E(e,t){if(null===z)return e;const l=un(z),o=e.dirs||(e.dirs=[]);for(let c=0;ce.__isTeleport,T=e=>e&&(e.disabled||""===e.disabled),O=e=>e&&(e.defer||""===e.defer),W=e=>"undefined"!==typeof SVGElement&&e instanceof SVGElement,B=e=>"function"===typeof MathMLElement&&e instanceof MathMLElement,I=(e,t)=>{const l=e&&e.to;if((0,a.Kg)(l)){if(t){const e=t(l);return e}return null}return l},D={name:"Teleport",__isTeleport:!0,process(e,t,l,n,a,o,c,r,s,i){const{mc:u,pc:d,pbc:f,o:{insert:p,querySelector:m,createText:v,createComment:h}}=i,g=T(t.props);let{shapeFlag:b,children:y,dynamicChildren:C}=t;if(null==e){const e=t.el=v(""),i=t.anchor=v("");p(e,l,n),p(i,l,n);const d=(e,t)=>{16&b&&u(y,e,t,a,o,c,r,s)},f=()=>{const e=t.target=I(t.props,m),l=H(e,t,v,p);e&&("svg"!==c&&W(e)?c="svg":"mathml"!==c&&B(e)&&(c="mathml"),a&&a.isCE&&(a.ce._teleportTargets||(a.ce._teleportTargets=new Set)).add(e),g||(d(e,l),$(t,!1)))};g&&(d(l,i),$(t,!0)),O(t.props)?(t.el.__isMounted=!1,ll(()=>{f(),delete t.el.__isMounted},o)):f()}else{if(O(t.props)&&!1===e.el.__isMounted)return void ll(()=>{D.process(e,t,l,n,a,o,c,r,s,i)},o);t.el=e.el,t.targetStart=e.targetStart;const u=t.anchor=e.anchor,p=t.target=e.target,v=t.targetAnchor=e.targetAnchor,h=T(e.props),b=h?l:p,y=h?u:v;if("svg"===c||W(p)?c="svg":("mathml"===c||B(p))&&(c="mathml"),C?(f(e.dynamicChildren,C,b,a,o,c,r),sl(e,t,!0)):s||d(e,t,b,y,a,o,c,r,!1),g)h?t.props&&e.props&&t.props.to!==e.props.to&&(t.props.to=e.props.to):F(t,l,u,i,1);else if((t.props&&t.props.to)!==(e.props&&e.props.to)){const e=t.target=I(t.props,m);e&&F(t,e,null,i,0)}else h&&F(t,p,v,i,1);$(t,g)}},remove(e,t,l,{um:n,o:{remove:a}},o){const{shapeFlag:c,children:r,anchor:s,targetStart:i,targetAnchor:u,target:d,props:f}=e;if(d&&(a(i),a(u)),o&&a(s),16&c){const e=o||!T(f);for(let a=0;a{e.isMounted=!0}),ze(()=>{e.isUnmounting=!0}),e}const U=[Function,Array],q={mode:String,appear:Boolean,persisted:Boolean,onBeforeEnter:U,onEnter:U,onAfterEnter:U,onEnterCancelled:U,onBeforeLeave:U,onLeave:U,onAfterLeave:U,onLeaveCancelled:U,onBeforeAppear:U,onAppear:U,onAfterAppear:U,onAppearCancelled:U},G=e=>{const t=e.subTree;return t.component?G(t.component):t},Y={name:"BaseTransition",props:q,setup(e,{slots:t}){const l=ql(),a=X();return()=>{const o=t.default&&ae(t.default(),!0);if(!o||!o.length)return;const c=Q(o),r=(0,n.ux)(e),{mode:s}=r;if(a.isLeaving)return te(c);const i=le(c);if(!i)return te(c);let u=ee(i,r,a,l,e=>u=e);i.type!==hl&&ne(i,u);let d=l.subTree&&le(l.subTree);if(d&&d.type!==hl&&!Sl(d,i)&&G(l).type!==hl){let e=ee(d,r,a,l);if(ne(d,e),"out-in"===s&&i.type!==hl)return a.isLeaving=!0,e.afterLeave=()=>{a.isLeaving=!1,8&l.job.flags||l.update(),delete e.afterLeave,d=void 0},te(c);"in-out"===s&&i.type!==hl?e.delayLeave=(e,t,l)=>{const n=J(a,d);n[String(d.key)]=d,e[j]=()=>{t(),e[j]=void 0,delete u.delayedLeave,d=void 0},u.delayedLeave=()=>{l(),delete u.delayedLeave,d=void 0}}:d=void 0}else d&&(d=void 0);return c}}};function Q(e){let t=e[0];if(e.length>1){let l=!1;for(const n of e)if(n.type!==hl){0,t=n,l=!0;break}}return t}const Z=Y;function J(e,t){const{leavingVNodes:l}=e;let n=l.get(t.type);return n||(n=Object.create(null),l.set(t.type,n)),n}function ee(e,t,l,n,o){const{appear:r,mode:s,persisted:i=!1,onBeforeEnter:u,onEnter:d,onAfterEnter:f,onEnterCancelled:p,onBeforeLeave:m,onLeave:v,onAfterLeave:h,onLeaveCancelled:g,onBeforeAppear:b,onAppear:y,onAfterAppear:C,onAppearCancelled:w}=t,L=String(e.key),x=J(l,e),M=(e,t)=>{e&&c(e,n,9,t)},z=(e,t)=>{const l=t[1];M(e,t),(0,a.cy)(e)?e.every(e=>e.length<=1)&&l():e.length<=1&&l()},R={mode:s,persisted:i,beforeEnter(t){let n=u;if(!l.isMounted){if(!r)return;n=b||u}t[j]&&t[j](!0);const a=x[L];a&&Sl(e,a)&&a.el[j]&&a.el[j](),M(n,[t])},enter(e){let t=d,n=f,a=p;if(!l.isMounted){if(!r)return;t=y||d,n=C||f,a=w||p}let o=!1;const c=e[K]=t=>{o||(o=!0,M(t?a:n,[e]),R.delayedLeave&&R.delayedLeave(),e[K]=void 0)};t?z(t,[e,c]):c()},leave(t,n){const a=String(e.key);if(t[K]&&t[K](!0),l.isUnmounting)return n();M(m,[t]);let o=!1;const c=t[j]=l=>{o||(o=!0,n(),M(l?g:h,[t]),t[j]=void 0,x[a]===e&&delete x[a])};x[a]=e,v?z(v,[t,c]):c()},clone(e){const a=ee(e,t,l,n,o);return o&&o(a),a}};return R}function te(e){if(de(e))return e=Wl(e),e.children=null,e}function le(e){if(!de(e))return _(e.type)&&e.children?Q(e.children):e;if(e.component)return e.component.subTree;const{shapeFlag:t,children:l}=e;if(l){if(16&t)return l[0];if(32&t&&(0,a.Tn)(l.default))return l.default()}}function ne(e,t){6&e.shapeFlag&&e.component?(e.transition=t,ne(e.component.subTree,t)):128&e.shapeFlag?(e.ssContent.transition=t.clone(e.ssContent),e.ssFallback.transition=t.clone(e.ssFallback)):e.transition=t}function ae(e,t=!1,l){let n=[],a=0;for(let o=0;o1)for(let o=0;o(0,a.X$)({name:e.name},t,{setup:e}))():e}function ce(e){e.ids=[e.ids[0]+e.ids[2]+++"-",0,0]}const re=new WeakMap;function se(e,t,l,c,r=!1){if((0,a.cy)(e))return void e.forEach((e,n)=>se(e,t&&((0,a.cy)(t)?t[n]:t),l,c,r));if(ue(c)&&!r)return void(512&c.shapeFlag&&c.type.__asyncResolved&&c.component.subTree.component&&se(e,t,l,c.component.subTree));const s=4&c.shapeFlag?un(c.component):c.el,i=r?null:s,{i:u,r:d}=e;const f=t&&t.r,p=u.refs===a.MZ?u.refs={}:u.refs,m=u.setupState,v=(0,n.ux)(m),h=m===a.MZ?a.NO:e=>(0,a.$3)(v,e),g=e=>!0;if(null!=f&&f!==d)if(ie(t),(0,a.Kg)(f))p[f]=null,h(f)&&(m[f]=null);else if((0,n.i9)(f)){g(f)&&(f.value=null);const e=t;e.k&&(p[e.k]=null)}if((0,a.Tn)(d))o(d,u,12,[i,p]);else{const t=(0,a.Kg)(d),o=(0,n.i9)(d);if(t||o){const n=()=>{if(e.f){const l=t?h(d)?m[d]:p[d]:g(d)||!e.k?d.value:p[e.k];if(r)(0,a.cy)(l)&&(0,a.TF)(l,s);else if((0,a.cy)(l))l.includes(s)||l.push(s);else if(t)p[d]=[s],h(d)&&(m[d]=p[d]);else{const t=[s];g(d)&&(d.value=t),e.k&&(p[e.k]=t)}}else t?(p[d]=i,h(d)&&(m[d]=i)):o&&(g(d)&&(d.value=i),e.k&&(p[e.k]=i))};if(i){const t=()=>{n(),re.delete(e)};t.id=-1,re.set(e,t),ll(t,l)}else ie(e),n()}else 0}}function ie(e){const t=re.get(e);t&&(t.flags|=8,re.delete(e))}(0,a.We)().requestIdleCallback,(0,a.We)().cancelIdleCallback;const ue=e=>!!e.type.__asyncLoader;const de=e=>e.type.__isKeepAlive;RegExp,RegExp;function fe(e,t){return(0,a.cy)(e)?e.some(e=>fe(e,t)):(0,a.Kg)(e)?e.split(",").includes(t):!!(0,a.gd)(e)&&(e.lastIndex=0,e.test(t))}function pe(e,t){ve(e,"a",t)}function me(e,t){ve(e,"da",t)}function ve(e,t,l=Ul){const n=e.__wdc||(e.__wdc=()=>{let t=l;while(t){if(t.isDeactivated)return;t=t.parent}return e()});if(ye(t,n,l),l){let e=l.parent;while(e&&e.parent)de(e.parent.vnode)&&he(n,t,l,e),e=e.parent}}function he(e,t,l,n){const o=ye(t,e,n,!0);Re(()=>{(0,a.TF)(n[t],o)},l)}function ge(e){e.shapeFlag&=-257,e.shapeFlag&=-513}function be(e){return 128&e.shapeFlag?e.ssContent:e}function ye(e,t,l=Ul,a=!1){if(l){const o=l[e]||(l[e]=[]),r=t.__weh||(t.__weh=(...a)=>{(0,n.C4)();const o=Ql(l),r=c(t,l,e,a);return o(),(0,n.bl)(),r});return a?o.unshift(r):o.push(r),r}}const Ce=e=>(t,l=Ul)=>{ln&&"sp"!==e||ye(e,(...e)=>t(...e),l)},we=Ce("bm"),Le=Ce("m"),xe=Ce("bu"),Me=Ce("u"),ze=Ce("bum"),Re=Ce("um"),ke=Ce("sp"),Se=Ce("rtg"),Ee=Ce("rtc");function Ae(e,t=Ul){ye("ec",e,t)}const Ne="components",_e="directives";function Te(e,t){return Ie(Ne,e,!0,t)||e}const Oe=Symbol.for("v-ndc");function We(e){return(0,a.Kg)(e)?Ie(Ne,e,!1)||e:e||Oe}function Be(e){return Ie(_e,e)}function Ie(e,t,l=!0,n=!1){const o=z||Ul;if(o){const l=o.type;if(e===Ne){const e=dn(l,!1);if(e&&(e===t||e===(0,a.PT)(t)||e===(0,a.ZH)((0,a.PT)(t))))return l}const c=De(o[e]||l[e],t)||De(o.appContext[e],t);return!c&&n?l:c}}function De(e,t){return e&&(e[t]||e[(0,a.PT)(t)]||e[(0,a.ZH)((0,a.PT)(t))])}function Fe(e,t,l,o){let c;const r=l&&l[o],s=(0,a.cy)(e);if(s||(0,a.Kg)(e)){const l=s&&(0,n.g8)(e);let a=!1,o=!1;l&&(a=!(0,n.fE)(e),o=(0,n.Tm)(e),e=(0,n.qA)(e)),c=new Array(e.length);for(let s=0,i=e.length;st(e,l,void 0,r&&r[l]));else{const l=Object.keys(e);c=new Array(l.length);for(let n=0,a=l.length;n{const t=n.fn(...e);return t&&(t.key=n.key),t}:n.fn)}return e}function Pe(e,t,l={},n,o){if(z.ce||z.parent&&ue(z.parent)&&z.parent.ce){const e=Object.keys(l).length>0;return"default"!==t&&(l.name=t),Cl(),Rl(ml,null,[_l("slot",l,n&&n())],e?-2:64)}let c=e[t];c&&c._c&&(c._d=!1),Cl();const r=c&&$e(c(l)),s=l.key||r&&r.key,i=Rl(ml,{key:(s&&!(0,a.Bm)(s)?s:`_${t}`)+(!r&&n?"_fb":"")},r||(n?n():[]),r&&1===e._?64:-2);return!o&&i.scopeId&&(i.slotScopeIds=[i.scopeId+"-s"]),c&&c._c&&(c._d=!0),i}function $e(e){return e.some(e=>!kl(e)||e.type!==hl&&!(e.type===ml&&!$e(e.children)))?e:null}function He(e,t){const l={};for(const n in e)l[t&&/[A-Z]/.test(n)?`on:${n}`:(0,a.rU)(n)]=e[n];return l}const je=e=>e?Jl(e)?un(e):je(e.parent):null,Ke=(0,a.X$)(Object.create(null),{$:e=>e,$el:e=>e.vnode.el,$data:e=>e.data,$props:e=>e.props,$attrs:e=>e.attrs,$slots:e=>e.slots,$refs:e=>e.refs,$parent:e=>je(e.parent),$root:e=>je(e.root),$host:e=>e.ce,$emit:e=>e.emit,$options:e=>nt(e),$forceUpdate:e=>e.f||(e.f=()=>{b(e.update)}),$nextTick:e=>e.n||(e.n=h.bind(e.proxy)),$watch:e=>Mt.bind(e)}),Xe=(e,t)=>e!==a.MZ&&!e.__isScriptSetup&&(0,a.$3)(e,t),Ue={get({_:e},t){if("__v_skip"===t)return!0;const{ctx:l,setupState:o,data:c,props:r,accessCache:s,type:i,appContext:u}=e;if("$"!==t[0]){const e=s[t];if(void 0!==e)switch(e){case 1:return o[t];case 2:return c[t];case 4:return l[t];case 3:return r[t]}else{if(Xe(o,t))return s[t]=1,o[t];if(c!==a.MZ&&(0,a.$3)(c,t))return s[t]=2,c[t];if((0,a.$3)(r,t))return s[t]=3,r[t];if(l!==a.MZ&&(0,a.$3)(l,t))return s[t]=4,l[t];Ze&&(s[t]=0)}}const d=Ke[t];let f,p;return d?("$attrs"===t&&(0,n.u4)(e.attrs,"get",""),d(e)):(f=i.__cssModules)&&(f=f[t])?f:l!==a.MZ&&(0,a.$3)(l,t)?(s[t]=4,l[t]):(p=u.config.globalProperties,(0,a.$3)(p,t)?p[t]:void 0)},set({_:e},t,l){const{data:n,setupState:o,ctx:c}=e;return Xe(o,t)?(o[t]=l,!0):n!==a.MZ&&(0,a.$3)(n,t)?(n[t]=l,!0):!(0,a.$3)(e.props,t)&&(("$"!==t[0]||!(t.slice(1)in e))&&(c[t]=l,!0))},has({_:{data:e,setupState:t,accessCache:l,ctx:n,appContext:o,props:c,type:r}},s){let i;return!!(l[s]||e!==a.MZ&&"$"!==s[0]&&(0,a.$3)(e,s)||Xe(t,s)||(0,a.$3)(c,s)||(0,a.$3)(n,s)||(0,a.$3)(Ke,s)||(0,a.$3)(o.config.globalProperties,s)||(i=r.__cssModules)&&i[s])},defineProperty(e,t,l){return null!=l.get?e._.accessCache[t]=0:(0,a.$3)(l,"value")&&this.set(e,t,l.value,null),Reflect.defineProperty(e,t,l)}};function qe(){return Ye("useSlots").slots}function Ge(){return Ye("useAttrs").attrs}function Ye(e){const t=ql();return t.setupContext||(t.setupContext=sn(t))}function Qe(e){return(0,a.cy)(e)?e.reduce((e,t)=>(e[t]=null,e),{}):e}let Ze=!0;function Je(e){const t=nt(e),l=e.proxy,o=e.ctx;Ze=!1,t.beforeCreate&&tt(t.beforeCreate,e,"bc");const{data:c,computed:r,methods:s,watch:i,provide:u,inject:d,created:f,beforeMount:p,mounted:m,beforeUpdate:v,updated:h,activated:g,deactivated:b,beforeDestroy:y,beforeUnmount:C,destroyed:w,unmounted:L,render:x,renderTracked:M,renderTriggered:z,errorCaptured:R,serverPrefetch:k,expose:S,inheritAttrs:E,components:A,directives:N,filters:_}=t,T=null;if(d&&et(d,o,T),s)for(const n in s){const e=s[n];(0,a.Tn)(e)&&(o[n]=e.bind(l))}if(c){0;const t=c.call(l,l);0,(0,a.Gv)(t)&&(e.data=(0,n.Kh)(t))}if(Ze=!0,r)for(const n in r){const e=r[n],t=(0,a.Tn)(e)?e.bind(l,l):(0,a.Tn)(e.get)?e.get.bind(l,l):a.tE;0;const c=!(0,a.Tn)(e)&&(0,a.Tn)(e.set)?e.set.bind(l):a.tE,s=pn({get:t,set:c});Object.defineProperty(o,n,{enumerable:!0,configurable:!0,get:()=>s.value,set:e=>s.value=e})}if(i)for(const n in i)lt(i[n],o,l,n);if(u){const e=(0,a.Tn)(u)?u.call(l):u;Reflect.ownKeys(e).forEach(t=>{gt(t,e[t])})}function O(e,t){(0,a.cy)(t)?t.forEach(t=>e(t.bind(l))):t&&e(t.bind(l))}if(f&&tt(f,e,"c"),O(we,p),O(Le,m),O(xe,v),O(Me,h),O(pe,g),O(me,b),O(Ae,R),O(Ee,M),O(Se,z),O(ze,C),O(Re,L),O(ke,k),(0,a.cy)(S))if(S.length){const t=e.exposed||(e.exposed={});S.forEach(e=>{Object.defineProperty(t,e,{get:()=>l[e],set:t=>l[e]=t,enumerable:!0})})}else e.exposed||(e.exposed={});x&&e.render===a.tE&&(e.render=x),null!=E&&(e.inheritAttrs=E),A&&(e.components=A),N&&(e.directives=N),k&&ce(e)}function et(e,t,l=a.tE){(0,a.cy)(e)&&(e=st(e));for(const o in e){const l=e[o];let c;c=(0,a.Gv)(l)?"default"in l?bt(l.from||o,l.default,!0):bt(l.from||o):bt(l),(0,n.i9)(c)?Object.defineProperty(t,o,{enumerable:!0,configurable:!0,get:()=>c.value,set:e=>c.value=e}):t[o]=c}}function tt(e,t,l){c((0,a.cy)(e)?e.map(e=>e.bind(t.proxy)):e.bind(t.proxy),t,l)}function lt(e,t,l,n){let o=n.includes(".")?zt(l,n):()=>l[n];if((0,a.Kg)(e)){const l=t[e];(0,a.Tn)(l)&&Lt(o,l)}else if((0,a.Tn)(e))Lt(o,e.bind(l));else if((0,a.Gv)(e))if((0,a.cy)(e))e.forEach(e=>lt(e,t,l,n));else{const n=(0,a.Tn)(e.handler)?e.handler.bind(l):t[e.handler];(0,a.Tn)(n)&&Lt(o,n,e)}else 0}function nt(e){const t=e.type,{mixins:l,extends:n}=t,{mixins:o,optionsCache:c,config:{optionMergeStrategies:r}}=e.appContext,s=c.get(t);let i;return s?i=s:o.length||l||n?(i={},o.length&&o.forEach(e=>at(i,e,r,!0)),at(i,t,r)):i=t,(0,a.Gv)(t)&&c.set(t,i),i}function at(e,t,l,n=!1){const{mixins:a,extends:o}=t;o&&at(e,o,l,!0),a&&a.forEach(t=>at(e,t,l,!0));for(const c in t)if(n&&"expose"===c);else{const n=ot[c]||l&&l[c];e[c]=n?n(e[c],t[c]):t[c]}return e}const ot={data:ct,props:dt,emits:dt,methods:ut,computed:ut,beforeCreate:it,created:it,beforeMount:it,mounted:it,beforeUpdate:it,updated:it,beforeDestroy:it,beforeUnmount:it,destroyed:it,unmounted:it,activated:it,deactivated:it,errorCaptured:it,serverPrefetch:it,components:ut,directives:ut,watch:ft,provide:ct,inject:rt};function ct(e,t){return t?e?function(){return(0,a.X$)((0,a.Tn)(e)?e.call(this,this):e,(0,a.Tn)(t)?t.call(this,this):t)}:t:e}function rt(e,t){return ut(st(e),st(t))}function st(e){if((0,a.cy)(e)){const t={};for(let l=0;l1)return l&&(0,a.Tn)(t)?t.call(n&&n.proxy):t}else 0}const yt=Symbol.for("v-scx"),Ct=()=>{{const e=bt(yt);return e}};function wt(e,t){return xt(e,null,t)}function Lt(e,t,l){return xt(e,t,l)}function xt(e,t,l=a.MZ){const{immediate:o,deep:r,flush:s,once:i}=l;const u=(0,a.X$)({},l);const d=t&&o||!t&&"post"!==s;let f;if(ln)if("sync"===s){const e=Ct();f=e.__watcherHandles||(e.__watcherHandles=[])}else if(!d){const e=()=>{};return e.stop=a.tE,e.resume=a.tE,e.pause=a.tE,e}const p=Ul;u.call=(e,t,l)=>c(e,p,t,l);let m=!1;"post"===s?u.scheduler=e=>{ll(e,p&&p.suspense)}:"sync"!==s&&(m=!0,u.scheduler=(e,t)=>{t?e():b(e)}),u.augmentJob=e=>{t&&(e.flags|=4),m&&(e.flags|=2,p&&(e.id=p.uid,e.i=p))};const v=(0,n.wB)(e,t,u);return ln&&(f?f.push(v):d&&v()),v}function Mt(e,t,l){const n=this.proxy,o=(0,a.Kg)(e)?e.includes(".")?zt(n,e):()=>n[e]:e.bind(n,n);let c;(0,a.Tn)(t)?c=t:(c=t.handler,l=t);const r=Ql(this),s=xt(o,c.bind(n),l);return r(),s}function zt(e,t){const l=t.split(".");return()=>{let t=e;for(let e=0;e"modelValue"===t||"model-value"===t?e.modelModifiers:e[`${t}Modifiers`]||e[`${(0,a.PT)(t)}Modifiers`]||e[`${(0,a.Tg)(t)}Modifiers`];function kt(e,t,...l){if(e.isUnmounted)return;const n=e.vnode.props||a.MZ;let o=l;const r=t.startsWith("update:"),s=r&&Rt(n,t.slice(7));let i;s&&(s.trim&&(o=l.map(e=>(0,a.Kg)(e)?e.trim():e)),s.number&&(o=l.map(a.bB)));let u=n[i=(0,a.rU)(t)]||n[i=(0,a.rU)((0,a.PT)(t))];!u&&r&&(u=n[i=(0,a.rU)((0,a.Tg)(t))]),u&&c(u,e,6,o);const d=n[i+"Once"];if(d){if(e.emitted){if(e.emitted[i])return}else e.emitted={};e.emitted[i]=!0,c(d,e,6,o)}}const St=new WeakMap;function Et(e,t,l=!1){const n=l?St:t.emitsCache,o=n.get(e);if(void 0!==o)return o;const c=e.emits;let r={},s=!1;if(!(0,a.Tn)(e)){const n=e=>{const l=Et(e,t,!0);l&&(s=!0,(0,a.X$)(r,l))};!l&&t.mixins.length&&t.mixins.forEach(n),e.extends&&n(e.extends),e.mixins&&e.mixins.forEach(n)}return c||s?((0,a.cy)(c)?c.forEach(e=>r[e]=null):(0,a.X$)(r,c),(0,a.Gv)(e)&&n.set(e,r),r):((0,a.Gv)(e)&&n.set(e,null),null)}function At(e,t){return!(!e||!(0,a.Mp)(t))&&(t=t.slice(2).replace(/Once$/,""),(0,a.$3)(e,t[0].toLowerCase()+t.slice(1))||(0,a.$3)(e,(0,a.Tg)(t))||(0,a.$3)(e,t))}function Nt(e){const{type:t,vnode:l,proxy:n,withProxy:o,propsOptions:[c],slots:s,attrs:i,emit:u,render:d,renderCache:f,props:p,data:m,setupState:v,ctx:h,inheritAttrs:g}=e,b=k(e);let y,C;try{if(4&l.shapeFlag){const e=o||n,t=e;y=Fl(d.call(t,e,f,p,v,m,h)),C=i}else{const e=t;0,y=Fl(e.length>1?e(p,{attrs:i,slots:s,emit:u}):e(p,null)),C=t.props?i:_t(i)}}catch(L){bl.length=0,r(L,e,1),y=_l(hl)}let w=y;if(C&&!1!==g){const e=Object.keys(C),{shapeFlag:t}=w;e.length&&7&t&&(c&&e.some(a.CP)&&(C=Tt(C,c)),w=Wl(w,C,!1,!0))}return l.dirs&&(w=Wl(w,null,!1,!0),w.dirs=w.dirs?w.dirs.concat(l.dirs):l.dirs),l.transition&&ne(w,l.transition),y=w,k(b),y}const _t=e=>{let t;for(const l in e)("class"===l||"style"===l||(0,a.Mp)(l))&&((t||(t={}))[l]=e[l]);return t},Tt=(e,t)=>{const l={};for(const n in e)(0,a.CP)(n)&&n.slice(9)in t||(l[n]=e[n]);return l};function Ot(e,t,l){const{props:n,children:a,component:o}=e,{props:c,children:r,patchFlag:s}=t,i=o.emitsOptions;if(t.dirs||t.transition)return!0;if(!(l&&s>=0))return!(!a&&!r||r&&r.$stable)||n!==c&&(n?!c||Wt(n,c,i):!!c);if(1024&s)return!0;if(16&s)return n?Wt(n,c,i):!!c;if(8&s){const e=t.dynamicProps;for(let t=0;tObject.create(It),Ft=e=>Object.getPrototypeOf(e)===It;function Vt(e,t,l,a=!1){const o={},c=Dt();e.propsDefaults=Object.create(null),$t(e,t,o,c);for(const n in e.propsOptions[0])n in o||(o[n]=void 0);l?e.props=a?o:(0,n.Gc)(o):e.type.props?e.props=o:e.props=c,e.attrs=c}function Pt(e,t,l,o){const{props:c,attrs:r,vnode:{patchFlag:s}}=e,i=(0,n.ux)(c),[u]=e.propsOptions;let d=!1;if(!(o||s>0)||16&s){let n;$t(e,t,c,r)&&(d=!0);for(const o in i)t&&((0,a.$3)(t,o)||(n=(0,a.Tg)(o))!==o&&(0,a.$3)(t,n))||(u?!l||void 0===l[o]&&void 0===l[n]||(c[o]=Ht(u,i,o,void 0,e,!0)):delete c[o]);if(r!==i)for(const e in r)t&&(0,a.$3)(t,e)||(delete r[e],d=!0)}else if(8&s){const l=e.vnode.dynamicProps;for(let n=0;n{i=!0;const[l,n]=Kt(e,t,!0);(0,a.X$)(r,l),n&&s.push(...n)};!l&&t.mixins.length&&t.mixins.forEach(n),e.extends&&n(e.extends),e.mixins&&e.mixins.forEach(n)}if(!c&&!i)return(0,a.Gv)(e)&&n.set(e,a.Oj),a.Oj;if((0,a.cy)(c))for(let d=0;d"_"===e||"_ctx"===e||"$stable"===e,qt=e=>(0,a.cy)(e)?e.map(Fl):[Fl(e)],Gt=(e,t,l)=>{if(t._n)return t;const n=S((...e)=>qt(t(...e)),l);return n._c=!1,n},Yt=(e,t,l)=>{const n=e._ctx;for(const o in e){if(Ut(o))continue;const l=e[o];if((0,a.Tn)(l))t[o]=Gt(o,l,n);else if(null!=l){0;const e=qt(l);t[o]=()=>e}}},Qt=(e,t)=>{const l=qt(t);e.slots.default=()=>l},Zt=(e,t,l)=>{for(const n in t)!l&&Ut(n)||(e[n]=t[n])},Jt=(e,t,l)=>{const n=e.slots=Dt();if(32&e.vnode.shapeFlag){const e=t._;e?(Zt(n,t,l),l&&(0,a.yQ)(n,"_",e,!0)):Yt(t,n)}else t&&Qt(e,t)},el=(e,t,l)=>{const{vnode:n,slots:o}=e;let c=!0,r=a.MZ;if(32&n.shapeFlag){const e=t._;e?l&&1===e?c=!1:Zt(o,t,l):(c=!t.$stable,Yt(t,o)),r=t}else t&&(Qt(e,t),r={default:1});if(c)for(const a in o)Ut(a)||null!=r[a]||delete o[a]};function tl(){}const ll=pl;function nl(e){return al(e)}function al(e,t){tl();const l=(0,a.We)();l.__VUE__=!0;const{insert:o,remove:c,patchProp:r,createElement:s,createText:i,createComment:u,setText:d,setElementText:f,parentNode:p,nextSibling:m,setScopeId:v=a.tE,insertStaticContent:h}=e,g=(e,t,l,n=null,a=null,o=null,c=void 0,r=null,s=!!t.dynamicChildren)=>{if(e===t)return;e&&!Sl(e,t)&&(n=Q(e),X(e,a,o,!0),e=null),-2===t.patchFlag&&(s=!1,t.dynamicChildren=null);const{type:i,ref:u,shapeFlag:d}=t;switch(i){case vl:y(e,t,l,n);break;case hl:C(e,t,l,n);break;case gl:null==e&&x(t,l,n,c);break;case ml:W(e,t,l,n,a,o,c,r,s);break;default:1&d?R(e,t,l,n,a,o,c,r,s):6&d?B(e,t,l,n,a,o,c,r,s):(64&d||128&d)&&i.process(e,t,l,n,a,o,c,r,s,ee)}null!=u&&a?se(u,e&&e.ref,o,t||e,!t):null==u&&e&&null!=e.ref&&se(e.ref,null,o,e,!0)},y=(e,t,l,n)=>{if(null==e)o(t.el=i(t.children),l,n);else{const l=t.el=e.el;t.children!==e.children&&d(l,t.children)}},C=(e,t,l,n)=>{null==e?o(t.el=u(t.children||""),l,n):t.el=e.el},x=(e,t,l,n)=>{[e.el,e.anchor]=h(e.children,t,l,n,e.el,e.anchor)},M=({el:e,anchor:t},l,n)=>{let a;while(e&&e!==t)a=m(e),o(e,l,n),e=a;o(t,l,n)},z=({el:e,anchor:t})=>{let l;while(e&&e!==t)l=m(e),c(e),e=l;c(t)},R=(e,t,l,n,a,o,c,r,s)=>{if("svg"===t.type?c="svg":"math"===t.type&&(c="mathml"),null==e)k(t,l,n,a,o,c,r,s);else{const l=e.el&&e.el._isVueCE?e.el:null;try{l&&l._beginPatch(),_(e,t,a,o,c,r,s)}finally{l&&l._endPatch()}}},k=(e,t,l,n,c,i,u,d)=>{let p,m;const{props:v,shapeFlag:h,transition:g,dirs:b}=e;if(p=e.el=s(e.type,i,v&&v.is,v),8&h?f(p,e.children):16&h&&E(e.children,p,null,n,c,ol(e,i),u,d),b&&A(e,null,n,"created"),S(p,e,e.scopeId,u,n),v){for(const e in v)"value"===e||(0,a.SU)(e)||r(p,e,null,v[e],i,n);"value"in v&&r(p,"value",null,v.value,i),(m=v.onVnodeBeforeMount)&&Hl(m,n,e)}b&&A(e,null,n,"beforeMount");const y=rl(c,g);y&&g.beforeEnter(p),o(p,t,l),((m=v&&v.onVnodeMounted)||y||b)&&ll(()=>{m&&Hl(m,n,e),y&&g.enter(p),b&&A(e,null,n,"mounted")},c)},S=(e,t,l,n,a)=>{if(l&&v(e,l),n)for(let o=0;o{for(let i=s;i{const i=t.el=e.el;let{patchFlag:u,dynamicChildren:d,dirs:p}=t;u|=16&e.patchFlag;const m=e.props||a.MZ,v=t.props||a.MZ;let h;if(l&&cl(l,!1),(h=v.onVnodeBeforeUpdate)&&Hl(h,l,t,e),p&&A(t,e,l,"beforeUpdate"),l&&cl(l,!0),(m.innerHTML&&null==v.innerHTML||m.textContent&&null==v.textContent)&&f(i,""),d?T(e.dynamicChildren,d,i,l,n,ol(t,o),c):s||P(e,t,i,null,l,n,ol(t,o),c,!1),u>0){if(16&u)O(i,m,v,l,o);else if(2&u&&m.class!==v.class&&r(i,"class",null,v.class,o),4&u&&r(i,"style",m.style,v.style,o),8&u){const e=t.dynamicProps;for(let t=0;t{h&&Hl(h,l,t,e),p&&A(t,e,l,"updated")},n)},T=(e,t,l,n,a,o,c)=>{for(let r=0;r{if(t!==l){if(t!==a.MZ)for(const c in t)(0,a.SU)(c)||c in l||r(e,c,t[c],null,o,n);for(const c in l){if((0,a.SU)(c))continue;const s=l[c],i=t[c];s!==i&&"value"!==c&&r(e,c,i,s,o,n)}"value"in l&&r(e,"value",t.value,l.value,o)}},W=(e,t,l,n,a,c,r,s,u)=>{const d=t.el=e?e.el:i(""),f=t.anchor=e?e.anchor:i("");let{patchFlag:p,dynamicChildren:m,slotScopeIds:v}=t;v&&(s=s?s.concat(v):v),null==e?(o(d,l,n),o(f,l,n),E(t.children||[],l,f,a,c,r,s,u)):p>0&&64&p&&m&&e.dynamicChildren?(T(e.dynamicChildren,m,l,a,c,r,s),(null!=t.key||a&&t===a.subTree)&&sl(e,t,!0)):P(e,t,l,f,a,c,r,s,u)},B=(e,t,l,n,a,o,c,r,s)=>{t.slotScopeIds=r,null==e?512&t.shapeFlag?a.ctx.activate(t,l,n,c,s):I(t,l,n,a,o,c,s):D(e,t,s)},I=(e,t,l,n,a,o,c)=>{const r=e.component=Xl(e,n,a);if(de(e)&&(r.ctx.renderer=ee),nn(r,!1,c),r.asyncDep){if(a&&a.registerDep(r,F,c),!e.el){const n=r.subTree=_l(hl);C(null,n,t,l),e.placeholder=n.el}}else F(r,e,t,l,a,o,c)},D=(e,t,l)=>{const n=t.component=e.component;if(Ot(e,t,l)){if(n.asyncDep&&!n.asyncResolved)return void V(n,t,l);n.next=t,n.update()}else t.el=e.el,n.vnode=t},F=(e,t,l,o,c,r,s)=>{const i=()=>{if(e.isMounted){let{next:t,bu:l,u:n,parent:o,vnode:u}=e;{const l=ul(e);if(l)return t&&(t.el=u.el,V(e,t,s)),void l.asyncDep.then(()=>{e.isUnmounted||i()})}let d,f=t;0,cl(e,!1),t?(t.el=u.el,V(e,t,s)):t=u,l&&(0,a.DY)(l),(d=t.props&&t.props.onVnodeBeforeUpdate)&&Hl(d,o,t,u),cl(e,!0);const m=Nt(e);0;const v=e.subTree;e.subTree=m,g(v,m,p(v.el),Q(v),e,c,r),t.el=m.el,null===f&&Bt(e,m.el),n&&ll(n,c),(d=t.props&&t.props.onVnodeUpdated)&&ll(()=>Hl(d,o,t,u),c)}else{let n;const{el:s,props:i}=t,{bm:u,m:d,parent:f,root:p,type:m}=e,v=ue(t);if(cl(e,!1),u&&(0,a.DY)(u),!v&&(n=i&&i.onVnodeBeforeMount)&&Hl(n,f,t),cl(e,!0),s&&le){const t=()=>{e.subTree=Nt(e),le(s,e.subTree,e,c,null)};v&&m.__asyncHydrate?m.__asyncHydrate(s,e,t):t()}else{p.ce&&!1!==p.ce._def.shadowRoot&&p.ce._injectChildStyle(m);const n=e.subTree=Nt(e);0,g(null,n,l,o,e,c,r),t.el=n.el}if(d&&ll(d,c),!v&&(n=i&&i.onVnodeMounted)){const e=t;ll(()=>Hl(n,f,e),c)}(256&t.shapeFlag||f&&ue(f.vnode)&&256&f.vnode.shapeFlag)&&e.a&&ll(e.a,c),e.isMounted=!0,t=l=o=null}};e.scope.on();const u=e.effect=new n.X2(i);e.scope.off();const d=e.update=u.run.bind(u),f=e.job=u.runIfDirty.bind(u);f.i=e,f.id=e.uid,u.scheduler=()=>b(f),cl(e,!0),d()},V=(e,t,l)=>{t.component=e;const a=e.vnode.props;e.vnode=t,e.next=null,Pt(e,t.props,a,l),el(e,t.children,l),(0,n.C4)(),w(e),(0,n.bl)()},P=(e,t,l,n,a,o,c,r,s=!1)=>{const i=e&&e.children,u=e?e.shapeFlag:0,d=t.children,{patchFlag:p,shapeFlag:m}=t;if(p>0){if(128&p)return void H(i,d,l,n,a,o,c,r,s);if(256&p)return void $(i,d,l,n,a,o,c,r,s)}8&m?(16&u&&Y(i,a,o),d!==i&&f(l,d)):16&u?16&m?H(i,d,l,n,a,o,c,r,s):Y(i,a,o,!0):(8&u&&f(l,""),16&m&&E(d,l,n,a,o,c,r,s))},$=(e,t,l,n,o,c,r,s,i)=>{e=e||a.Oj,t=t||a.Oj;const u=e.length,d=t.length,f=Math.min(u,d);let p;for(p=0;pd?Y(e,o,c,!0,!1,f):E(t,l,n,o,c,r,s,i,f)},H=(e,t,l,n,o,c,r,s,i)=>{let u=0;const d=t.length;let f=e.length-1,p=d-1;while(u<=f&&u<=p){const n=e[u],a=t[u]=i?Vl(t[u]):Fl(t[u]);if(!Sl(n,a))break;g(n,a,l,null,o,c,r,s,i),u++}while(u<=f&&u<=p){const n=e[f],a=t[p]=i?Vl(t[p]):Fl(t[p]);if(!Sl(n,a))break;g(n,a,l,null,o,c,r,s,i),f--,p--}if(u>f){if(u<=p){const e=p+1,a=ep)while(u<=f)X(e[u],o,c,!0),u++;else{const m=u,v=u,h=new Map;for(u=v;u<=p;u++){const e=t[u]=i?Vl(t[u]):Fl(t[u]);null!=e.key&&h.set(e.key,u)}let b,y=0;const C=p-v+1;let w=!1,L=0;const x=new Array(C);for(u=0;u=C){X(n,o,c,!0);continue}let a;if(null!=n.key)a=h.get(n.key);else for(b=v;b<=p;b++)if(0===x[b-v]&&Sl(n,t[b])){a=b;break}void 0===a?X(n,o,c,!0):(x[a-v]=u+1,a>=L?L=a:w=!0,g(n,t[a],l,null,o,c,r,s,i),y++)}const M=w?il(x):a.Oj;for(b=M.length-1,u=C-1;u>=0;u--){const e=v+u,a=t[e],f=t[e+1],p=e+1{const{el:r,type:s,transition:i,children:u,shapeFlag:d}=e;if(6&d)return void K(e.component.subTree,t,l,n);if(128&d)return void e.suspense.move(t,l,n);if(64&d)return void s.move(e,t,l,ee);if(s===ml){o(r,t,l);for(let e=0;ei.enter(r),a);else{const{leave:n,delayLeave:a,afterLeave:s}=i,u=()=>{e.ctx.isUnmounted?c(r):o(r,t,l)},d=()=>{r._isLeaving&&r[j](!0),n(r,()=>{u(),s&&s()})};a?a(r,u,d):d()}else o(r,t,l)},X=(e,t,l,a=!1,o=!1)=>{const{type:c,props:r,ref:s,children:i,dynamicChildren:u,shapeFlag:d,patchFlag:f,dirs:p,cacheIndex:m}=e;if(-2===f&&(o=!1),null!=s&&((0,n.C4)(),se(s,null,l,e,!0),(0,n.bl)()),null!=m&&(t.renderCache[m]=void 0),256&d)return void t.ctx.deactivate(e);const v=1&d&&p,h=!ue(e);let g;if(h&&(g=r&&r.onVnodeBeforeUnmount)&&Hl(g,t,e),6&d)G(e.component,l,a);else{if(128&d)return void e.suspense.unmount(l,a);v&&A(e,null,t,"beforeUnmount"),64&d?e.type.remove(e,t,l,ee,a):u&&!u.hasOnce&&(c!==ml||f>0&&64&f)?Y(u,t,l,!1,!0):(c===ml&&384&f||!o&&16&d)&&Y(i,t,l),a&&U(e)}(h&&(g=r&&r.onVnodeUnmounted)||v)&&ll(()=>{g&&Hl(g,t,e),v&&A(e,null,t,"unmounted")},l)},U=e=>{const{type:t,el:l,anchor:n,transition:a}=e;if(t===ml)return void q(l,n);if(t===gl)return void z(e);const o=()=>{c(l),a&&!a.persisted&&a.afterLeave&&a.afterLeave()};if(1&e.shapeFlag&&a&&!a.persisted){const{leave:t,delayLeave:n}=a,c=()=>t(l,o);n?n(e.el,o,c):c()}else o()},q=(e,t)=>{let l;while(e!==t)l=m(e),c(e),e=l;c(t)},G=(e,t,l)=>{const{bum:n,scope:o,job:c,subTree:r,um:s,m:i,a:u}=e;dl(i),dl(u),n&&(0,a.DY)(n),o.stop(),c&&(c.flags|=8,X(r,e,t,l)),s&&ll(s,t),ll(()=>{e.isUnmounted=!0},t)},Y=(e,t,l,n=!1,a=!1,o=0)=>{for(let c=o;c{if(6&e.shapeFlag)return Q(e.component.subTree);if(128&e.shapeFlag)return e.suspense.next();const t=m(e.anchor||e.el),l=t&&t[N];return l?m(l):t};let Z=!1;const J=(e,t,l)=>{null==e?t._vnode&&X(t._vnode,null,null,!0):g(t._vnode||null,e,t,null,null,null,l),t._vnode=e,Z||(Z=!0,w(),L(),Z=!1)},ee={p:g,um:X,m:K,r:U,mt:I,mc:E,pc:P,pbc:T,n:Q,o:e};let te,le;return t&&([te,le]=t(ee)),{render:J,hydrate:te,createApp:vt(J,te)}}function ol({type:e,props:t},l){return"svg"===l&&"foreignObject"===e||"mathml"===l&&"annotation-xml"===e&&t&&t.encoding&&t.encoding.includes("html")?void 0:l}function cl({effect:e,job:t},l){l?(e.flags|=32,t.flags|=4):(e.flags&=-33,t.flags&=-5)}function rl(e,t){return(!e||e&&!e.pendingBranch)&&t&&!t.persisted}function sl(e,t,l=!1){const n=e.children,o=t.children;if((0,a.cy)(n)&&(0,a.cy)(o))for(let a=0;a>1,e[l[r]]0&&(t[n]=l[o-1]),l[o]=n)}}o=l.length,c=l[o-1];while(o-- >0)l[o]=c,c=t[c];return l}function ul(e){const t=e.subTree.component;if(t)return t.asyncDep&&!t.asyncResolved?t:ul(t)}function dl(e){if(e)for(let t=0;te.__isSuspense;function pl(e,t){t&&t.pendingBranch?(0,a.cy)(e)?t.effects.push(...e):t.effects.push(e):C(e)}const ml=Symbol.for("v-fgt"),vl=Symbol.for("v-txt"),hl=Symbol.for("v-cmt"),gl=Symbol.for("v-stc"),bl=[];let yl=null;function Cl(e=!1){bl.push(yl=e?null:[])}function wl(){bl.pop(),yl=bl[bl.length-1]||null}let Ll=1;function xl(e,t=!1){Ll+=e,e<0&&yl&&t&&(yl.hasOnce=!0)}function Ml(e){return e.dynamicChildren=Ll>0?yl||a.Oj:null,wl(),Ll>0&&yl&&yl.push(e),e}function zl(e,t,l,n,a,o){return Ml(Nl(e,t,l,n,a,o,!0))}function Rl(e,t,l,n,a){return Ml(_l(e,t,l,n,a,!0))}function kl(e){return!!e&&!0===e.__v_isVNode}function Sl(e,t){return e.type===t.type&&e.key===t.key}const El=({key:e})=>null!=e?e:null,Al=({ref:e,ref_key:t,ref_for:l})=>("number"===typeof e&&(e=""+e),null!=e?(0,a.Kg)(e)||(0,n.i9)(e)||(0,a.Tn)(e)?{i:z,r:e,k:t,f:!!l}:e:null);function Nl(e,t=null,l=null,n=0,o=null,c=(e===ml?0:1),r=!1,s=!1){const i={__v_isVNode:!0,__v_skip:!0,type:e,props:t,key:t&&El(t),ref:t&&Al(t),scopeId:R,slotScopeIds:null,children:l,component:null,suspense:null,ssContent:null,ssFallback:null,dirs:null,transition:null,el:null,anchor:null,target:null,targetStart:null,targetAnchor:null,staticCount:0,shapeFlag:c,patchFlag:n,dynamicProps:o,dynamicChildren:null,appContext:null,ctx:z};return s?(Pl(i,l),128&c&&e.normalize(i)):l&&(i.shapeFlag|=(0,a.Kg)(l)?8:16),Ll>0&&!r&&yl&&(i.patchFlag>0||6&c)&&32!==i.patchFlag&&yl.push(i),i}const _l=Tl;function Tl(e,t=null,l=null,o=0,c=null,r=!1){if(e&&e!==Oe||(e=hl),kl(e)){const n=Wl(e,t,!0);return l&&Pl(n,l),Ll>0&&!r&&yl&&(6&n.shapeFlag?yl[yl.indexOf(e)]=n:yl.push(n)),n.patchFlag=-2,n}if(fn(e)&&(e=e.__vccOpts),t){t=Ol(t);let{class:e,style:l}=t;e&&!(0,a.Kg)(e)&&(t.class=(0,a.C4)(e)),(0,a.Gv)(l)&&((0,n.ju)(l)&&!(0,a.cy)(l)&&(l=(0,a.X$)({},l)),t.style=(0,a.Tr)(l))}const s=(0,a.Kg)(e)?1:fl(e)?128:_(e)?64:(0,a.Gv)(e)?4:(0,a.Tn)(e)?2:0;return Nl(e,t,l,o,c,s,r,!0)}function Ol(e){return e?(0,n.ju)(e)||Ft(e)?(0,a.X$)({},e):e:null}function Wl(e,t,l=!1,n=!1){const{props:o,ref:c,patchFlag:r,children:s,transition:i}=e,u=t?$l(o||{},t):o,d={__v_isVNode:!0,__v_skip:!0,type:e.type,props:u,key:u&&El(u),ref:t&&t.ref?l&&c?(0,a.cy)(c)?c.concat(Al(t)):[c,Al(t)]:Al(t):c,scopeId:e.scopeId,slotScopeIds:e.slotScopeIds,children:s,target:e.target,targetStart:e.targetStart,targetAnchor:e.targetAnchor,staticCount:e.staticCount,shapeFlag:e.shapeFlag,patchFlag:t&&e.type!==ml?-1===r?16:16|r:r,dynamicProps:e.dynamicProps,dynamicChildren:e.dynamicChildren,appContext:e.appContext,dirs:e.dirs,transition:i,component:e.component,suspense:e.suspense,ssContent:e.ssContent&&Wl(e.ssContent),ssFallback:e.ssFallback&&Wl(e.ssFallback),placeholder:e.placeholder,el:e.el,anchor:e.anchor,ctx:e.ctx,ce:e.ce};return i&&n&&ne(d,i.clone(d)),d}function Bl(e=" ",t=0){return _l(vl,null,e,t)}function Il(e,t){const l=_l(gl,null,e);return l.staticCount=t,l}function Dl(e="",t=!1){return t?(Cl(),Rl(hl,null,e)):_l(hl,null,e)}function Fl(e){return null==e||"boolean"===typeof e?_l(hl):(0,a.cy)(e)?_l(ml,null,e.slice()):kl(e)?Vl(e):_l(vl,null,String(e))}function Vl(e){return null===e.el&&-1!==e.patchFlag||e.memo?e:Wl(e)}function Pl(e,t){let l=0;const{shapeFlag:n}=e;if(null==t)t=null;else if((0,a.cy)(t))l=16;else if("object"===typeof t){if(65&n){const l=t.default;return void(l&&(l._c&&(l._d=!1),Pl(e,l()),l._c&&(l._d=!0)))}{l=32;const n=t._;n||Ft(t)?3===n&&z&&(1===z.slots._?t._=1:(t._=2,e.patchFlag|=1024)):t._ctx=z}}else(0,a.Tn)(t)?(t={default:t,_ctx:z},l=32):(t=String(t),64&n?(l=16,t=[Bl(t)]):l=8);e.children=t,e.shapeFlag|=l}function $l(...e){const t={};for(let l=0;lUl||z;let Gl,Yl;{const e=(0,a.We)(),t=(t,l)=>{let n;return(n=e[t])||(n=e[t]=[]),n.push(l),e=>{n.length>1?n.forEach(t=>t(e)):n[0](e)}};Gl=t("__VUE_INSTANCE_SETTERS__",e=>Ul=e),Yl=t("__VUE_SSR_SETTERS__",e=>ln=e)}const Ql=e=>{const t=Ul;return Gl(e),e.scope.on(),()=>{e.scope.off(),Gl(t)}},Zl=()=>{Ul&&Ul.scope.off(),Gl(null)};function Jl(e){return 4&e.vnode.shapeFlag}let en,tn,ln=!1;function nn(e,t=!1,l=!1){t&&Yl(t);const{props:n,children:a}=e.vnode,o=Jl(e);Vt(e,n,o,t),Jt(e,a,l||t);const c=o?an(e,t):void 0;return t&&Yl(!1),c}function an(e,t){const l=e.type;e.accessCache=Object.create(null),e.proxy=new Proxy(e.ctx,Ue);const{setup:c}=l;if(c){(0,n.C4)();const l=e.setupContext=c.length>1?sn(e):null,s=Ql(e),i=o(c,e,0,[e.props,l]),u=(0,a.yL)(i);if((0,n.bl)(),s(),!u&&!e.sp||ue(e)||ce(e),u){if(i.then(Zl,Zl),t)return i.then(l=>{on(e,l,t)}).catch(t=>{r(t,e,0)});e.asyncDep=i}else on(e,i,t)}else cn(e,t)}function on(e,t,l){(0,a.Tn)(t)?e.type.__ssrInlineRender?e.ssrRender=t:e.render=t:(0,a.Gv)(t)&&(e.setupState=(0,n.Pr)(t)),cn(e,l)}function cn(e,t,l){const o=e.type;if(!e.render){if(!t&&en&&!o.render){const t=o.template||nt(e).template;if(t){0;const{isCustomElement:l,compilerOptions:n}=e.appContext.config,{delimiters:c,compilerOptions:r}=o,s=(0,a.X$)((0,a.X$)({isCustomElement:l,delimiters:c},n),r);o.render=en(t,s)}}e.render=o.render||a.tE,tn&&tn(e)}{const t=Ql(e);(0,n.C4)();try{Je(e)}finally{(0,n.bl)(),t()}}}const rn={get(e,t){return(0,n.u4)(e,"get",""),e[t]}};function sn(e){const t=t=>{e.exposed=t||{}};return{attrs:new Proxy(e.attrs,rn),slots:e.slots,emit:e.emit,expose:t}}function un(e){return e.exposed?e.exposeProxy||(e.exposeProxy=new Proxy((0,n.Pr)((0,n.IG)(e.exposed)),{get(t,l){return l in t?t[l]:l in Ke?Ke[l](e):void 0},has(e,t){return t in e||t in Ke}})):e.proxy}function dn(e,t=!0){return(0,a.Tn)(e)?e.displayName||e.name:e.name||t&&e.__name}function fn(e){return(0,a.Tn)(e)&&"__vccOpts"in e}const pn=(e,t)=>{const l=(0,n.EW)(e,t,ln);return l};function mn(e,t,l){try{xl(-1);const n=arguments.length;return 2===n?(0,a.Gv)(t)&&!(0,a.cy)(t)?kl(t)?_l(e,null,[t]):_l(e,t):_l(e,null,t):(n>3?l=Array.prototype.slice.call(arguments,2):3===n&&kl(l)&&(l=[l]),_l(e,t,l))}finally{xl(1)}}const vn="3.5.25",hn=a.tE},6769:function(e,t,l){"use strict";l.d(t,{f:function(){return n}});const n=e=>e},6801:function(e,t,l){"use strict";var n=l(3724),a=l(8686),o=l(4913),c=l(8551),r=l(5397),s=l(1072);t.f=n&&!a?Object.defineProperties:function(e,t){c(e);var l,n=r(t),a=s(t),i=a.length,u=0;while(i>u)o.f(e,l=a[u++],n[l]);return e}},6810:function(e,t,l){"use strict";l.d(t,{ll:function(){return V},Zh:function(){return $},MQ:function(){return P}});var n=l(6768),a=l(4232),o=l(144),c=l(5130),r=l(7378),s=l(3845),i=l(2056),u=l(2235);const d=(0,r.b_)({modelValue:{type:[String,Number,Boolean],default:void 0},size:s.mU,disabled:{type:Boolean,default:void 0},label:{type:[String,Number,Boolean],default:void 0},value:{type:[String,Number,Boolean],default:void 0},name:{type:String,default:void 0}}),f=(0,r.b_)({...d,border:Boolean}),p={[i.l4]:e=>(0,a.Kg)(e)||(0,u.Et)(e)||(0,u.Lm)(e),[i.YU]:e=>(0,a.Kg)(e)||(0,u.Et)(e)||(0,u.Lm)(e)},m=Symbol("radioGroupKey");var v=l(2436),h=l(261);const g=(e,t)=>{const l=(0,o.KR)(),a=(0,n.WQ)(m,void 0),c=(0,n.EW)(()=>!!a),r=(0,n.EW)(()=>(0,u.Xj)(e.value)?e.label:e.value),s=(0,n.EW)({get(){return c.value?a.modelValue:e.modelValue},set(n){c.value?a.changeEvent(n):t&&t(i.l4,n),l.value.checked=e.modelValue===r.value}}),d=(0,v.NV)((0,n.EW)(()=>null==a?void 0:a.size)),f=(0,v.CB)((0,n.EW)(()=>null==a?void 0:a.disabled)),p=(0,o.KR)(!1),g=(0,n.EW)(()=>f.value||c.value&&s.value!==r.value?-1:0);return(0,h.b)({from:"label act as value",replacement:"value",version:"3.0.0",scope:"el-radio",ref:"https://element-plus.org/en-US/component/radio.html"},(0,n.EW)(()=>c.value&&(0,u.Xj)(e.value))),{radioRef:l,isGroup:c,radioGroup:a,focus:p,size:d,disabled:f,tabIndex:g,modelValue:s,actualValue:r}};var b=l(9077),y=l(3513);const C=(0,n.pM)({name:"ElRadio"}),w=(0,n.pM)({...C,props:f,emits:p,setup(e,{emit:t}){const l=e,r=(0,y.DU)("radio"),{radioRef:s,radioGroup:u,focus:d,size:f,disabled:p,modelValue:m,actualValue:v}=g(l,t);function h(){(0,n.dY)(()=>t(i.YU,m.value))}return(e,t)=>{var l;return(0,n.uX)(),(0,n.CE)("label",{class:(0,a.C4)([(0,o.R1)(r).b(),(0,o.R1)(r).is("disabled",(0,o.R1)(p)),(0,o.R1)(r).is("focus",(0,o.R1)(d)),(0,o.R1)(r).is("bordered",e.border),(0,o.R1)(r).is("checked",(0,o.R1)(m)===(0,o.R1)(v)),(0,o.R1)(r).m((0,o.R1)(f))])},[(0,n.Lk)("span",{class:(0,a.C4)([(0,o.R1)(r).e("input"),(0,o.R1)(r).is("disabled",(0,o.R1)(p)),(0,o.R1)(r).is("checked",(0,o.R1)(m)===(0,o.R1)(v))])},[(0,n.bo)((0,n.Lk)("input",{ref_key:"radioRef",ref:s,"onUpdate:modelValue":e=>(0,o.i9)(m)?m.value=e:null,class:(0,a.C4)((0,o.R1)(r).e("original")),value:(0,o.R1)(v),name:e.name||(null==(l=(0,o.R1)(u))?void 0:l.name),disabled:(0,o.R1)(p),checked:(0,o.R1)(m)===(0,o.R1)(v),type:"radio",onFocus:e=>d.value=!0,onBlur:e=>d.value=!1,onChange:h,onClick:(0,c.D$)(()=>{},["stop"])},null,42,["onUpdate:modelValue","value","name","disabled","checked","onFocus","onBlur","onClick"]),[[c.XL,(0,o.R1)(m)]]),(0,n.Lk)("span",{class:(0,a.C4)((0,o.R1)(r).e("inner"))},null,2)],2),(0,n.Lk)("span",{class:(0,a.C4)((0,o.R1)(r).e("label")),onKeydown:(0,c.D$)(()=>{},["stop"])},[(0,n.RG)(e.$slots,"default",{},()=>[(0,n.eW)((0,a.v_)(e.label),1)])],42,["onKeydown"])],2)}}});var L=(0,b.A)(w,[["__file","radio.vue"]]);const x=(0,r.b_)({...d}),M=(0,n.pM)({name:"ElRadioButton"}),z=(0,n.pM)({...M,props:x,setup(e){const t=e,l=(0,y.DU)("radio"),{radioRef:r,focus:s,size:i,disabled:u,modelValue:d,radioGroup:f,actualValue:p}=g(t),m=(0,n.EW)(()=>({backgroundColor:(null==f?void 0:f.fill)||"",borderColor:(null==f?void 0:f.fill)||"",boxShadow:(null==f?void 0:f.fill)?`-1px 0 0 0 ${f.fill}`:"",color:(null==f?void 0:f.textColor)||""}));return(e,t)=>{var v;return(0,n.uX)(),(0,n.CE)("label",{class:(0,a.C4)([(0,o.R1)(l).b("button"),(0,o.R1)(l).is("active",(0,o.R1)(d)===(0,o.R1)(p)),(0,o.R1)(l).is("disabled",(0,o.R1)(u)),(0,o.R1)(l).is("focus",(0,o.R1)(s)),(0,o.R1)(l).bm("button",(0,o.R1)(i))])},[(0,n.bo)((0,n.Lk)("input",{ref_key:"radioRef",ref:r,"onUpdate:modelValue":e=>(0,o.i9)(d)?d.value=e:null,class:(0,a.C4)((0,o.R1)(l).be("button","original-radio")),value:(0,o.R1)(p),type:"radio",name:e.name||(null==(v=(0,o.R1)(f))?void 0:v.name),disabled:(0,o.R1)(u),onFocus:e=>s.value=!0,onBlur:e=>s.value=!1,onClick:(0,c.D$)(()=>{},["stop"])},null,42,["onUpdate:modelValue","value","name","disabled","onFocus","onBlur","onClick"]),[[c.XL,(0,o.R1)(d)]]),(0,n.Lk)("span",{class:(0,a.C4)((0,o.R1)(l).be("button","inner")),style:(0,a.Tr)((0,o.R1)(d)===(0,o.R1)(p)?(0,o.R1)(m):{}),onKeydown:(0,c.D$)(()=>{},["stop"])},[(0,n.RG)(e.$slots,"default",{},()=>[(0,n.eW)((0,a.v_)(e.label),1)])],46,["onKeydown"])],2)}}});var R=(0,b.A)(z,[["__file","radio-button.vue"]]),k=(l(8111),l(3579),l(8501));const S=(0,r.b_)({id:{type:String,default:void 0},size:s.mU,disabled:{type:Boolean,default:void 0},modelValue:{type:[String,Number,Boolean],default:void 0},fill:{type:String,default:""},textColor:{type:String,default:""},name:{type:String,default:void 0},validateEvent:{type:Boolean,default:!0},options:{type:(0,r.jq)(Array)},props:{type:(0,r.jq)(Object),default:()=>A},type:{type:String,values:["radio","button"],default:"radio"},...(0,k.l)(["ariaLabel"])}),E=p,A={label:"label",value:"value",disabled:"disabled"};var N=l(1074),_=l(9195),T=l(1305),O=l(4216),W=l(6894);const B=(0,n.pM)({name:"ElRadioGroup"}),I=(0,n.pM)({...B,props:S,emits:E,setup(e,{emit:t}){const l=e,c=(0,y.DU)("radio"),r=(0,T.Bi)(),s=(0,o.KR)(),{formItem:u}=(0,O.j)(),{inputId:d,isLabeledByFormItem:f}=(0,O.W)(l,{formItemContext:u}),p=e=>{t(i.l4,e),(0,n.dY)(()=>t(i.YU,e))};(0,n.sV)(()=>{const e=s.value.querySelectorAll("[type=radio]"),t=e[0];!Array.from(e).some(e=>e.checked)&&t&&(t.tabIndex=0)});const v=(0,n.EW)(()=>l.name||r.value),h=(0,n.EW)(()=>({...A,...l.props})),g=e=>{const{label:t,value:l,disabled:n}=h.value,a={label:e[t],value:e[l],disabled:e[n]};return{...(0,N.A)(e,[t,l,n]),...a}},b=(0,n.EW)(()=>"button"===l.type?R:L);return(0,n.Gt)(m,(0,o.Kh)({...(0,o.QW)(l),changeEvent:p,name:v})),(0,n.wB)(()=>l.modelValue,(e,t)=>{l.validateEvent&&!(0,_.A)(e,t)&&(null==u||u.validate("change").catch(e=>(0,W.U)(e)))}),(e,t)=>((0,n.uX)(),(0,n.CE)("div",{id:(0,o.R1)(d),ref_key:"radioGroupRef",ref:s,class:(0,a.C4)((0,o.R1)(c).b("group")),role:"radiogroup","aria-label":(0,o.R1)(f)?void 0:e.ariaLabel||"radio-group","aria-labelledby":(0,o.R1)(f)?(0,o.R1)(u).labelId:void 0},[(0,n.RG)(e.$slots,"default",{},()=>[((0,n.uX)(!0),(0,n.CE)(n.FK,null,(0,n.pI)(e.options,(e,t)=>((0,n.uX)(),(0,n.Wv)((0,n.$y)((0,o.R1)(b)),(0,n.v6)({key:t},g(e)),null,16))),128))])],10,["id","aria-label","aria-labelledby"]))}});var D=(0,b.A)(I,[["__file","radio-group.vue"]]),F=l(5376);const V=(0,F.GU)(L,{RadioButton:R,RadioGroup:D}),P=(0,F.WM)(D),$=(0,F.WM)(R)},6823:function(e){"use strict";var t=String;e.exports=function(e){try{return t(e)}catch(l){return"Object"}}},6834:function(e,t,l){"use strict";l.d(t,{A:function(){return I}});l(4114);var n=l(6768),a=l(144),o=l(6032),c=l(3291),r=l(6340);const s=(0,a.KR)(),i=(0,a.KR)(0),u=(0,a.KR)(0);let d=0;const f=e=>{const t=[],l=document.createTreeWalker(e,NodeFilter.SHOW_ELEMENT,{acceptNode:e=>{const t="INPUT"===e.tagName&&"hidden"===e.type;return e.disabled||e.hidden||t?NodeFilter.FILTER_SKIP:e.tabIndex>=0||e===document.activeElement?NodeFilter.FILTER_ACCEPT:NodeFilter.FILTER_SKIP}});while(l.nextNode())t.push(l.currentNode);return t},p=(e,t)=>{for(const l of e)if(!m(l,t))return l},m=(e,t)=>{if("hidden"===getComputedStyle(e).visibility)return!0;while(e){if(t&&e===t)return!1;if("none"===getComputedStyle(e).display)return!0;e=e.parentElement}return!1},v=e=>{const t=f(e),l=p(t,e),n=p(t.reverse(),e);return[l,n]},h=e=>e instanceof HTMLInputElement&&"select"in e,g=(e,t)=>{if(e){const l=document.activeElement;(0,r.pW)(e,{preventScroll:!0}),u.value=window.performance.now(),e!==l&&h(e)&&t&&e.select()}};function b(e,t){const l=[...e],n=e.indexOf(t);return-1!==n&&l.splice(n,1),l}const y=()=>{let e=[];const t=t=>{const l=e[0];l&&t!==l&&l.pause(),e=b(e,t),e.unshift(t)},l=t=>{var l,n;e=b(e,t),null==(n=null==(l=e[0])?void 0:l.resume)||n.call(l)};return{push:t,remove:l}},C=(e,t=!1)=>{const l=document.activeElement;for(const n of e)if(g(n,t),document.activeElement!==l)return},w=y(),L=()=>i.value>u.value,x=()=>{s.value="pointer",i.value=window.performance.now()},M=()=>{s.value="keyboard",i.value=window.performance.now()},z=()=>((0,n.sV)(()=>{0===d&&(document.addEventListener("mousedown",x),document.addEventListener("touchstart",x),document.addEventListener("keydown",M)),d++}),(0,n.xo)(()=>{d--,d<=0&&(document.removeEventListener("mousedown",x),document.removeEventListener("touchstart",x),document.removeEventListener("keydown",M))}),{focusReason:s,lastUserFocusTimestamp:i,lastAutomatedFocusTimestamp:u}),R=e=>new CustomEvent(c.d,{...c.oV,detail:e});var k=l(9077),S=(l(8111),l(2489),l(7588),l(17)),E=l(4225),A=l(515);let N=[];const _=e=>{const t=(0,E.CG)(e);t===A.R.esc&&N.forEach(t=>t(e))},T=e=>{(0,n.sV)(()=>{0===N.length&&document.addEventListener("keydown",_),S.oc&&N.push(e)}),(0,n.xo)(()=>{N=N.filter(t=>t!==e),0===N.length&&S.oc&&document.removeEventListener("keydown",_)})};var O=l(4232);const W=(0,n.pM)({name:"ElFocusTrap",inheritAttrs:!1,props:{loop:Boolean,trapped:Boolean,focusTrapEl:Object,focusStartEl:{type:[Object,String],default:"first"}},emits:[c.NP,c.fI,"focusin","focusout","focusout-prevented","release-requested"],setup(e,{emit:t}){const l=(0,a.KR)();let r,s;const{focusReason:i}=z();T(l=>{e.trapped&&!u.paused&&t("release-requested",l)});const u={paused:!1,pause(){this.paused=!0},resume(){this.paused=!1}},d=l=>{if(!e.loop&&!e.trapped)return;if(u.paused)return;const{altKey:n,ctrlKey:a,metaKey:o,currentTarget:c,shiftKey:r}=l,{loop:s}=e,d=(0,E.CG)(l),f=d===A.R.tab&&!n&&!a&&!o,p=document.activeElement;if(f&&p){const e=c,[n,a]=v(e),o=n&&a;if(o)if(r||p!==a){if(r&&[n,e].includes(p)){const e=R({focusReason:i.value});t("focusout-prevented",e),e.defaultPrevented||(l.preventDefault(),s&&g(a,!0))}}else{const e=R({focusReason:i.value});t("focusout-prevented",e),e.defaultPrevented||(l.preventDefault(),s&&g(n,!0))}else if(p===e){const e=R({focusReason:i.value});t("focusout-prevented",e),e.defaultPrevented||l.preventDefault()}}};(0,n.Gt)(c.r3,{focusTrapRef:l,onKeydown:d}),(0,n.wB)(()=>e.focusTrapEl,e=>{e&&(l.value=e)},{immediate:!0}),(0,n.wB)([l],([e],[t])=>{e&&(e.addEventListener("keydown",d),e.addEventListener("focusin",h),e.addEventListener("focusout",b)),t&&(t.removeEventListener("keydown",d),t.removeEventListener("focusin",h),t.removeEventListener("focusout",b))});const p=e=>{t(c.NP,e)},m=e=>t(c.fI,e),h=n=>{const o=(0,a.R1)(l);if(!o)return;const c=n.target,i=n.relatedTarget,d=c&&o.contains(c);if(!e.trapped){const e=i&&o.contains(i);e||(r=i)}d&&t("focusin",n),u.paused||e.trapped&&(d?s=c:g(s,!0))},b=n=>{const c=(0,a.R1)(l);if(!u.paused&&c)if(e.trapped){const l=n.relatedTarget;(0,o.A)(l)||c.contains(l)||setTimeout(()=>{if(!u.paused&&e.trapped){const e=R({focusReason:i.value});t("focusout-prevented",e),e.defaultPrevented||g(s,!0)}},0)}else{const e=n.target,l=e&&c.contains(e);l||t("focusout",n)}};async function y(){await(0,n.dY)();const t=(0,a.R1)(l);if(t){w.push(u);const l=t.contains(document.activeElement)?r:document.activeElement;r=l;const a=t.contains(l);if(!a){const a=new Event(c.Ll,c.MP);t.addEventListener(c.Ll,p),t.dispatchEvent(a),a.defaultPrevented||(0,n.dY)(()=>{let n=e.focusStartEl;(0,O.Kg)(n)||(g(n),document.activeElement!==n&&(n="first")),"first"===n&&C(f(t),!0),document.activeElement!==l&&"container"!==n||g(t)})}}}function x(){const e=(0,a.R1)(l);if(e){e.removeEventListener(c.Ll,p);const t=new CustomEvent(c.aw,{...c.MP,detail:{focusReason:i.value}});e.addEventListener(c.aw,m),e.dispatchEvent(t),t.defaultPrevented||"keyboard"!=i.value&&L()&&!e.contains(document.activeElement)||g(null!=r?r:document.body),e.removeEventListener(c.aw,m),w.remove(u),r=null,s=null}}return(0,n.sV)(()=>{e.trapped&&y(),(0,n.wB)(()=>e.trapped,e=>{e?y():x()})}),(0,n.xo)(()=>{e.trapped&&x(),l.value&&(l.value.removeEventListener("keydown",d),l.value.removeEventListener("focusin",h),l.value.removeEventListener("focusout",b),l.value=void 0),r=null,s=null}),{onKeydown:d}}});function B(e,t,l,a,o,c){return(0,n.RG)(e.$slots,"default",{handleKeydown:e.onKeydown})}var I=(0,k.A)(W,[["render",B],["__file","focus-trap.vue"]])},6837:function(e){"use strict";var t=TypeError,l=9007199254740991;e.exports=function(e){if(e>l)throw t("Maximum allowed index exceeded");return e}},6840:function(e,t,l){"use strict";var n=l(4901),a=l(4913),o=l(283),c=l(9433);e.exports=function(e,t,l,r){r||(r={});var s=r.enumerable,i=void 0!==r.name?r.name:t;if(n(l)&&o(l,i,r),r.global)s?e[t]=l:c(t,l);else{try{r.unsafe?e[t]&&(s=!0):delete e[t]}catch(u){}s?e[t]=l:a.f(e,t,{value:l,enumerable:!1,configurable:!r.nonConfigurable,writable:!r.nonWritable})}return e}},6841:function(e,t){"use strict";function l(e,t){return e===t||e!==e&&t!==t}t.A=l},6865:function(e,t,l){"use strict";function n(e,t){return null!=e&&t in Object(e)}l.d(t,{A:function(){return m}});var a=n,o=l(5014),c=l(6162),r=l(3506),s=l(2676),i=l(5351),u=l(3708);function d(e,t,l){t=(0,o.A)(t,e);var n=-1,a=t.length,d=!1;while(++n(0,d.f)([])},previewTeleported:Boolean,zIndex:{type:Number},initialIndex:{type:Number,default:0},infinite:{type:Boolean,default:!0},closeOnPressEscape:{type:Boolean,default:!0},zoomRate:{type:Number,default:1.2},scale:{type:Number,default:1},minScale:{type:Number,default:.2},maxScale:{type:Number,default:7},showProgress:Boolean,crossorigin:{type:(0,u.jq)(String)}}),m={load:e=>e instanceof Event,error:e=>e instanceof Event,switch:e=>(0,f.Et)(e),close:()=>!0,show:()=>!0};var v=l(9077),h=l(6268),g=l(3513),b=l(3716),y=l(8587);const C=(0,n.pM)({name:"ElImage",inheritAttrs:!1}),w=(0,n.pM)({...C,props:p,emits:m,setup(e,{expose:t,emit:l}){const u=e,{t:d}=(0,h.Ym)(),p=(0,g.DU)("image"),m=(0,n.OA)(),v=(0,n.EW)(()=>(0,s.A)(Object.entries(m).filter(([e])=>/^(data-|on[A-Z])/i.test(e)||["id","style"].includes(e)))),C=(0,b.O)({excludeListeners:!0,excludeKeys:(0,n.EW)(()=>Object.keys(v.value))}),w=(0,a.KR)(),L=(0,a.KR)(!1),x=(0,a.KR)(!0),M=(0,a.KR)(!1),z=(0,a.KR)(),R=(0,a.KR)(),k=c.oc&&"loading"in HTMLImageElement.prototype;let S;const E=(0,n.EW)(()=>[p.e("inner"),N.value&&p.e("preview"),x.value&&p.is("loading")]),A=(0,n.EW)(()=>{const{fit:e}=u;return c.oc&&e?{objectFit:e}:{}}),N=(0,n.EW)(()=>{const{previewSrcList:e}=u;return(0,o.cy)(e)&&e.length>0}),_=(0,n.EW)(()=>{const{previewSrcList:e,initialIndex:t}=u;let l=t;return t>e.length-1&&(l=0),l}),T=(0,n.EW)(()=>"eager"!==u.loading&&(!k&&"lazy"===u.loading||u.lazy)),O=()=>{c.oc&&(x.value=!0,L.value=!1,w.value=u.src)};function W(e){x.value=!1,L.value=!1,l("load",e)}function B(e){x.value=!1,L.value=!0,l("error",e)}function I(e){e&&(O(),V())}const D=(0,c.k3)(I,200,!0);async function F(){var e;if(!c.oc)return;await(0,n.dY)();const{scrollContainer:t}=u;if((0,f.vq)(t))R.value=t;else if((0,o.Kg)(t)&&""!==t)R.value=null!=(e=document.querySelector(t))?e:void 0;else if(z.value){const e=(0,y.Bo)(z.value);R.value=(0,f.l6)(e)?void 0:e}const{stop:l}=(0,r.BLq)(z,([e])=>{D(e.isIntersecting)},{root:R});S=l}function V(){c.oc&&D&&(null==S||S(),R.value=void 0,S=void 0)}function P(){N.value&&(M.value=!0,l("show"))}function $(){M.value=!1,l("close")}function H(e){l("switch",e)}return(0,n.wB)(()=>u.src,()=>{T.value?(x.value=!0,L.value=!1,V(),F()):O()}),(0,n.sV)(()=>{T.value?F():O()}),t({showPreview:P}),(e,t)=>((0,n.uX)(),(0,n.CE)("div",(0,n.v6)({ref_key:"container",ref:z},(0,a.R1)(v),{class:[(0,a.R1)(p).b(),e.$attrs.class]}),[L.value?(0,n.RG)(e.$slots,"error",{key:0},()=>[(0,n.Lk)("div",{class:(0,o.C4)((0,a.R1)(p).e("error"))},(0,o.v_)((0,a.R1)(d)("el.image.error")),3)]):((0,n.uX)(),(0,n.CE)(n.FK,{key:1},[void 0!==w.value?((0,n.uX)(),(0,n.CE)("img",(0,n.v6)({key:0},(0,a.R1)(C),{src:w.value,loading:e.loading,style:(0,a.R1)(A),class:(0,a.R1)(E),crossorigin:e.crossorigin,onClick:P,onLoad:W,onError:B}),null,16,["src","loading","crossorigin"])):(0,n.Q3)("v-if",!0),x.value?((0,n.uX)(),(0,n.CE)("div",{key:1,class:(0,o.C4)((0,a.R1)(p).e("wrapper"))},[(0,n.RG)(e.$slots,"placeholder",{},()=>[(0,n.Lk)("div",{class:(0,o.C4)((0,a.R1)(p).e("placeholder"))},null,2)])],2)):(0,n.Q3)("v-if",!0)],64)),(0,a.R1)(N)?((0,n.uX)(),(0,n.CE)(n.FK,{key:2},[M.value?((0,n.uX)(),(0,n.Wv)((0,a.R1)(i.Tg),{key:0,"z-index":e.zIndex,"initial-index":(0,a.R1)(_),infinite:e.infinite,"zoom-rate":e.zoomRate,"min-scale":e.minScale,"max-scale":e.maxScale,"show-progress":e.showProgress,"url-list":e.previewSrcList,scale:e.scale,crossorigin:e.crossorigin,"hide-on-click-modal":e.hideOnClickModal,teleported:e.previewTeleported,"close-on-press-escape":e.closeOnPressEscape,onClose:$,onSwitch:H},(0,n.eX)({toolbar:(0,n.k6)(t=>[(0,n.RG)(e.$slots,"toolbar",(0,o._B)((0,n.Ng)(t)))]),default:(0,n.k6)(()=>[e.$slots.viewer?((0,n.uX)(),(0,n.CE)("div",{key:0},[(0,n.RG)(e.$slots,"viewer")])):(0,n.Q3)("v-if",!0)]),_:2},[e.$slots.progress?{name:"progress",fn:(0,n.k6)(t=>[(0,n.RG)(e.$slots,"progress",(0,o._B)((0,n.Ng)(t)))])}:void 0,e.$slots["viewer-error"]?{name:"viewer-error",fn:(0,n.k6)(t=>[(0,n.RG)(e.$slots,"viewer-error",(0,o._B)((0,n.Ng)(t)))])}:void 0]),1032,["z-index","initial-index","infinite","zoom-rate","min-scale","max-scale","show-progress","url-list","scale","crossorigin","hide-on-click-modal","teleported","close-on-press-escape"])):(0,n.Q3)("v-if",!0)],64)):(0,n.Q3)("v-if",!0)],16))}});var L=(0,v.A)(w,[["__file","image.vue"]]),x=l(5376);const M=(0,x.GU)(L)},7017:function(e,t,l){"use strict";l.d(t,{Ap:function(){return o},Rd:function(){return n},rc:function(){return a}});const n=4,a={vertical:{offset:"offsetHeight",scroll:"scrollTop",scrollSize:"scrollHeight",size:"height",key:"vertical",axis:"Y",client:"clientY",direction:"top"},horizontal:{offset:"offsetWidth",scroll:"scrollLeft",scrollSize:"scrollWidth",size:"width",key:"horizontal",axis:"X",client:"clientX",direction:"left"}},o=({move:e,size:t,bar:l})=>({[l.size]:t,transform:`translate${l.axis}(${e}%)`})},7023:function(e,t,l){"use strict";l.d(t,{W:function(){return r}});l(4114),l(8111),l(2489),l(1701),l(3579);var n=l(6768),a=l(144),o=l(6139);const c=(e,t,l)=>{const a=(0,o.CW)(e.subTree).filter(e=>{var l;return(0,n.vv)(e)&&(null==(l=e.type)?void 0:l.name)===t&&!!e.component}),c=a.map(e=>e.component.uid);return c.map(e=>l[e]).filter(e=>!!e)},r=(e,t)=>{const l=(0,a.IJ)({}),o=(0,a.IJ)([]),r=new WeakMap,s=e=>{l.value[e.uid]=e,(0,a.mu)(l),(0,n.sV)(()=>{const t=e.getVnode().el,n=t.parentNode;if(!r.has(n)){r.set(n,[]);const e=n.insertBefore.bind(n);n.insertBefore=(t,o)=>{const c=r.get(n).some(e=>t===e||o===e);return c&&(0,a.mu)(l),e(t,o)}}r.get(n).push(t)})},i=e=>{delete l.value[e.uid],(0,a.mu)(l);const t=e.getVnode().el,n=t.parentNode,o=r.get(n),c=o.indexOf(t);o.splice(c,1)},u=()=>{o.value=c(e,t,l.value)},d=e=>e.render(),f=(0,n.pM)({setup(e,{slots:t}){return()=>(u(),t.default?(0,n.h)(d,{render:t.default}):null)}});return{children:o,addChild:s,removeChild:i,ChildrenSorter:f}}},7040:function(e,t,l){"use strict";var n=l(4495);e.exports=n&&!Symbol.sham&&"symbol"==typeof Symbol.iterator},7055:function(e,t,l){"use strict";var n=l(9504),a=l(9039),o=l(2195),c=Object,r=n("".split);e.exports=a(function(){return!c("z").propertyIsEnumerable(0)})?function(e){return"String"===o(e)?r(e,""):c(e)}:c},7063:function(e,t,l){"use strict";l.d(t,{A:function(){return r}});var n=l(6697),a=l(5431),o=l(2808);const c={[n.bx]:"deltaX",[n.tT]:"deltaY"},r=({atEndEdge:e,atStartEdge:t,layout:l},n)=>{let r,s=0;const i=l=>{const n=l<0&&t.value||l>0&&e.value;return n},u=e=>{(0,a.V)(r);const t=e[c[l.value]];i(s)&&i(s+t)||(s+=t,(0,o.gm)()||e.preventDefault(),r=(0,a.m)(()=>{n(s),s=0}))};return{hasReachedEdge:i,onWheel:u}}},7080:function(e,t,l){"use strict";var n=l(4402).has;e.exports=function(e){return n(e),e}},7083:function(e,t,l){"use strict";var n=l(1591),a=l(168),o="[object AsyncFunction]",c="[object Function]",r="[object GeneratorFunction]",s="[object Proxy]";function i(e){if(!(0,a.A)(e))return!1;var t=(0,n.A)(e);return t==c||t==r||t==o||t==s}t.A=i},7138:function(e,t,l){"use strict";l.d(t,{Up:function(){return Xl},o8:function(){return Ul}});var n=l(6768),a=l(4232),o=l(5130),c=l(6301),r=l(8559),s=(l(8111),l(7588),l(4114),l(116),l(1701),l(144));function i(e){return null===e}var u=i,d=(l(2489),l(3579),l(8237),l(2308)),f=l(5347),p=l(7582);function m(e){return function(t,l,n){var a=-1,o=Object(t),c=n(t),r=c.length;while(r--){var s=c[e?r:++a];if(!1===l(o[s],s,o))break}return t}}var v=m,h=v(),g=h,b=l(6166);function y(e,t){return e&&g(e,t,b.A)}var C=y,w=l(1805);function L(e,t){return function(l,n){if(null==l)return l;if(!(0,w.A)(l))return e(l,n);var a=l.length,o=t?a:-1,c=Object(l);while(t?o--:++o1?l[a-1]:void 0,c=a>2?l[2]:void 0;o=e.length>3&&"function"==typeof o?(a--,o):void 0,c&&ue(l[0],l[1],c)&&(o=a<3?void 0:o,a=1),t=Object(t);while(++n(0,a.Kg)(t)?(0,O.A)(l,t):t(l,n,e)):("$key"!==t&&(0,a.Gv)(l)&&"$value"in l&&(l=l.$value),[(0,a.Gv)(l)?t?(0,O.A)(l,t):null:l])},r=function(e,t){var l,a,o,c,r,s;if(n)return n(e.value,t.value);for(let n=0,i=null!=(a=null==(l=e.key)?void 0:l.length)?a:0;n(null==(s=t.key)?void 0:s[n]))return 1}return 0};return e.map((e,t)=>({value:e,index:t,key:c?c(e,t):null})).sort((e,t)=>{let n=r(e,t);return n||(n=e.index-t.index),n*+l}).map(e=>e.value)},we=function(e,t){let l=null;return e.columns.forEach(e=>{e.id===t&&(l=e)}),l},Le=function(e,t){let l=null;for(let n=0;n{if(!e)throw new Error("Row is required when get row identity");if((0,a.Kg)(t)){if(!t.includes("."))return`${e[t]}`;const l=t.split(".");let n=e;for(const e of l)n=n[e];return`${n}`}return(0,a.Tn)(t)?t.call(null,e):""},ze=function(e,t,l=!1,n="children"){const o=e||[],c={};return o.forEach((e,o)=>{if(c[Me(e,t)]={row:e,index:o},l){const l=e[n];(0,a.cy)(l)&&Object.assign(c,ze(l,t,!0,n))}}),c};function Re(e,t){const l={};let n;for(n in e)l[n]=e[n];for(n in t)if((0,a.$3)(t,n)){const e=t[n];(0,ge.b0)(e)||(l[n]=e)}return l}function ke(e){return""===e||(0,ge.b0)(e)||(e=Number.parseInt(e,10),Number.isNaN(e)&&(e="")),e}function Se(e){return""===e||(0,ge.b0)(e)||(e=ke(e),Number.isNaN(e)&&(e=80)),e}function Ee(e){return(0,ge.Et)(e)?e:(0,a.Kg)(e)?/^\d+(?:px)?$/.test(e)?Number.parseInt(e,10):e:null}function Ae(...e){return 0===e.length?e=>e:1===e.length?e[0]:e.reduce((e,t)=>(...l)=>e(t(...l)))}function Ne(e,t,l,n,o,c,r){let s=null!=c?c:0,i=!1;const u=()=>{if(!r)return e.indexOf(t);const l=Me(t,r);return e.findIndex(e=>Me(e,r)===l)},d=u(),f=-1!==d,p=null==o?void 0:o.call(null,t,s),m=l=>{"add"===l?e.push(t):e.splice(d,1),i=!0},v=e=>{let t=0;const l=(null==n?void 0:n.children)&&e[n.children];return l&&(0,a.cy)(l)&&(t+=l.length,l.forEach(e=>{t+=v(e)})),t};return o&&!p||((0,ge.Lm)(l)?l&&!f?m("add"):!l&&f&&m("remove"):m(f?"remove":"add")),!(null==n?void 0:n.checkStrictly)&&(null==n?void 0:n.children)&&(0,a.cy)(t[n.children])&&t[n.children].forEach(t=>{const a=Ne(e,t,null!=l?l:!f,n,o,s+1,r);s+=v(t)+1,a&&(i=a)}),i}function _e(e,t,l="children",n="hasChildren",o=!1){const c=e=>!((0,a.cy)(e)&&e.length);function r(e,a,s){t(e,a,s),a.forEach(e=>{if(e[n]&&o)return void t(e,null,s+1);const a=e[l];c(a)||r(e,a,s+1)})}e.forEach(e=>{if(e[n]&&o)return void t(e,null,0);const a=e[l];c(a)||r(e,a,0)})}const Te=(e,t,l,o)=>{const c={strategy:"fixed",...e.popperOptions},r=(0,a.Tn)(null==o?void 0:o.tooltipFormatter)?o.tooltipFormatter({row:l,column:o,cellValue:(0,be.GT)(l,o.property).value}):void 0;return(0,n.vv)(r)?{slotContent:r,content:null,...e,popperOptions:c}:{slotContent:null,content:null!=r?r:t,...e,popperOptions:c}};let Oe=null;function We(e,t,l,a,c,r){var s;const i=Te(e,t,l,a),u={...i,slotContent:void 0};if((null==Oe?void 0:Oe.trigger)===c){const e=null==(s=Oe.vm)?void 0:s.component;return me(null==e?void 0:e.props,u),void(e&&i.slotContent&&(e.slots.content=()=>[i.slotContent]))}null==Oe||Oe();const d=null==r?void 0:r.refs.tableWrapper,f=null==d?void 0:d.dataset.prefix,p=(0,n.bF)(ve.R7,{virtualTriggering:!0,virtualRef:c,appendTo:d,placement:"top",transition:"none",offset:0,hideAfter:0,...u},i.slotContent?{content:()=>i.slotContent}:void 0);p.appContext={...r.appContext,...r};const m=document.createElement("div");(0,o.XX)(p,m),p.component.exposed.onOpen();const v=null==d?void 0:d.querySelector(`.${f}-scrollbar__wrap`);Oe=()=>{var e,t;(null==(t=null==(e=p.component)?void 0:e.exposed)?void 0:t.onClose)&&p.component.exposed.onClose(),(0,o.XX)(null,m);const l=Oe;null==v||v.removeEventListener("scroll",l),l.trigger=void 0,l.vm=void 0,Oe=null},Oe.trigger=null!=c?c:void 0,Oe.vm=p,null==v||v.addEventListener("scroll",Oe)}function Be(e){return e.children?_(e.children,Be):[e]}function Ie(e,t){return e+t.colSpan}const De=(e,t,l,n)=>{let a=0,o=e;const c=l.states.columns.value;if(n){const t=Be(n[e]),l=c.slice(0,c.indexOf(t[0]));a=l.reduce(Ie,0),o=a+t.reduce(Ie,0)-1}else a=e;let r;switch(t){case"left":o=c.length-l.states.rightFixedLeafColumnsLength.value&&(r="right");break;default:o=c.length-l.states.rightFixedLeafColumnsLength.value&&(r="right")}return r?{direction:r,start:a,after:o}:{}},Fe=(e,t,l,n,a,o=0)=>{const c=[],{direction:r,start:s,after:i}=De(t,l,n,a);if(r){const t="left"===r;c.push(`${e}-fixed-column--${r}`),t&&i+o===n.states.fixedLeafColumnsLength.value-1?c.push("is-last-column"):t||s-o!==n.states.columns.value.length-n.states.rightFixedLeafColumnsLength.value||c.push("is-first-column")}return c};function Ve(e,t){return e+(u(t.realWidth)||Number.isNaN(t.realWidth)?Number(t.width):t.realWidth)}const Pe=(e,t,l,n)=>{const{direction:a,start:o=0,after:c=0}=De(e,t,l,n);if(!a)return;const r={},s="left"===a,i=l.states.columns.value;return s?r.left=i.slice(0,o).reduce(Ve,0):r.right=i.slice(c+1).reverse().reduce(Ve,0),r},$e=(e,t)=>{e&&(Number.isNaN(e[t])||(e[t]=`${e[t]}px`))};function He(e){return e.some(e=>!(0,n.vv)(e)||e.type!==n.Mw&&!(e.type===n.FK&&!He(e.children)))?e:null}function je(e){const t=(0,n.nI)(),l=(0,s.KR)(!1),a=(0,s.KR)([]),o=()=>{const t=e.data.value||[],n=e.rowKey.value;if(l.value)a.value=t.slice();else if(n){const e=ze(a.value,n);a.value=t.reduce((t,l)=>{const a=Me(l,n),o=e[a];return o&&t.push(l),t},[])}else a.value=[]},c=(l,n)=>{const o=Ne(a.value,l,n,void 0,void 0,void 0,e.rowKey.value);o&&t.emit("expand-change",l,a.value.slice())},r=l=>{t.store.assertRowKey();const n=e.data.value||[],o=e.rowKey.value,c=ze(n,o);a.value=l.reduce((e,t)=>{const l=c[t];return l&&e.push(l.row),e},[])},i=t=>{const l=e.rowKey.value;if(l){const e=ze(a.value,l);return!!e[Me(t,l)]}return a.value.includes(t)};return{updateExpandRows:o,toggleRowExpansion:c,setExpandRowKeys:r,isRowExpanded:i,states:{expandRows:a,defaultExpandAll:l}}}function Ke(e){const t=(0,n.nI)(),l=(0,s.KR)(null),a=(0,s.KR)(null),o=e=>{t.store.assertRowKey(),l.value=e,r(e)},c=()=>{l.value=null},r=l=>{var n;const{data:o,rowKey:c}=e;let r=null;c.value&&(r=null!=(n=((0,s.R1)(o)||[]).find(e=>Me(e,c.value)===l))?n:null),a.value=null!=r?r:null,t.emit("current-change",a.value,null)},i=e=>{const l=a.value;if(e&&e!==l)return a.value=e,void t.emit("current-change",a.value,l);!e&&l&&(a.value=null,t.emit("current-change",null,l))},d=()=>{const n=e.rowKey.value,o=e.data.value||[],s=a.value;if(s&&!o.includes(s)){if(n){const e=Me(s,n);r(e)}else a.value=null;u(a.value)&&t.emit("current-change",null,s)}else l.value&&(r(l.value),c())};return{setCurrentRowKey:o,restoreCurrentRowKey:c,setCurrentRowByKey:r,updateCurrentRow:i,updateCurrentRowData:d,states:{_currentRowKey:l,currentRow:a}}}function Xe(e){const t=(0,s.KR)([]),l=(0,s.KR)({}),o=(0,s.KR)(16),c=(0,s.KR)(!1),r=(0,s.KR)({}),i=(0,s.KR)("hasChildren"),u=(0,s.KR)("children"),d=(0,s.KR)(!1),f=(0,n.nI)(),p=(0,n.EW)(()=>{if(!e.rowKey.value)return{};const t=e.data.value||[];return v(t)}),m=(0,n.EW)(()=>{const t=e.rowKey.value,l=Object.keys(r.value),n={};return l.length?(l.forEach(e=>{if(r.value[e].length){const l={children:[]};r.value[e].forEach(e=>{const a=Me(e,t);l.children.push(a),e[i.value]&&!n[a]&&(n[a]={children:[]})}),n[e]=l}}),n):n}),v=t=>{const l=e.rowKey.value,n={};return _e(t,(e,t,o)=>{const r=Me(e,l);(0,a.cy)(t)?n[r]={children:t.map(e=>Me(e,l)),level:o}:c.value&&(n[r]={children:[],lazy:!0,level:o})},u.value,i.value,c.value),n},h=(e=!1,n)=>{var a,o;n||(n=null==(a=f.store)?void 0:a.states.defaultExpandAll.value);const r=p.value,i=m.value,u=Object.keys(r),d={};if(u.length){const a=(0,s.R1)(l),o=[],f=(l,a)=>{if(e)return t.value?n||t.value.includes(a):!(!n&&!(null==l?void 0:l.expanded));{const e=n||t.value&&t.value.includes(a);return!(!(null==l?void 0:l.expanded)&&!e)}};u.forEach(e=>{const t=a[e],l={...r[e]};if(l.expanded=f(t,e),l.lazy){const{loaded:n=!1,loading:a=!1}=t||{};l.loaded=!!n,l.loading=!!a,o.push(e)}d[e]=l});const p=Object.keys(i);c.value&&p.length&&o.length&&p.forEach(e=>{var t;const l=a[e],n=i[e].children;if(o.includes(e)){if(0!==(null==(t=d[e].children)?void 0:t.length))throw new Error("[ElTable]children must be an empty array.");d[e].children=n}else{const{loaded:t=!1,loading:a=!1}=l||{};d[e]={lazy:!0,loaded:!!t,loading:!!a,expanded:f(l,e),children:n,level:void 0}}})}l.value=d,null==(o=f.store)||o.updateTableScrollY()};(0,n.wB)(()=>t.value,()=>{h(!0)}),(0,n.wB)(()=>p.value,()=>{h()}),(0,n.wB)(()=>m.value,()=>{h()});const g=e=>{t.value=e,h()},b=e=>c.value&&e&&"loaded"in e&&!e.loaded,y=(t,n)=>{f.store.assertRowKey();const a=e.rowKey.value,o=Me(t,a),c=o&&l.value[o];if(o&&c&&"expanded"in c){const e=c.expanded;n=(0,ge.b0)(n)?!c.expanded:n,l.value[o].expanded=n,e!==n&&f.emit("expand-change",t,n),n&&b(c)&&w(t,o,c),f.store.updateTableScrollY()}},C=t=>{f.store.assertRowKey();const n=e.rowKey.value,a=Me(t,n),o=l.value[a];b(o)?w(t,a,o):y(t,void 0)},w=(e,t,n)=>{const{load:o}=f.props;o&&!l.value[t].loaded&&(l.value[t].loading=!0,o(e,n,n=>{if(!(0,a.cy)(n))throw new TypeError("[ElTable] data must be an array");l.value[t].loading=!1,l.value[t].loaded=!0,l.value[t].expanded=!0,n.length&&(r.value[t]=n),f.emit("expand-change",e,!0)}))},L=(e,t)=>{const{lazy:l,rowKey:n}=f.props;if(l){if(!n)throw new Error("[Table] rowKey is required in updateKeyChild");r.value[e]&&(r.value[e]=t)}};return{loadData:w,loadOrToggle:C,toggleTreeExpansion:y,updateTreeExpandKeys:g,updateTreeData:h,updateKeyChildren:L,normalize:v,states:{expandRowKeys:t,treeData:l,indent:o,lazy:c,lazyTreeNodeMap:r,lazyColumnIdentifier:i,childrenColumnName:u,checkStrictly:d}}}const Ue=(e,t)=>{const l=t.sortingColumn;return!l||(0,a.Kg)(l.sortable)?e:Ce(e,t.sortProp,t.sortOrder,l.sortMethod,l.sortBy)},qe=e=>{const t=[];return e.forEach(e=>{e.children&&e.children.length>0?t.push.apply(t,qe(e.children)):t.push(e)}),t};function Ge(){var e;const t=(0,n.nI)(),{size:l}=(0,s.QW)(null==(e=t.proxy)?void 0:e.$props),o=(0,s.KR)(null),c=(0,s.KR)([]),r=(0,s.KR)([]),i=(0,s.KR)(!1),u=(0,s.KR)([]),d=(0,s.KR)([]),f=(0,s.KR)([]),p=(0,s.KR)([]),m=(0,s.KR)([]),v=(0,s.KR)([]),h=(0,s.KR)([]),g=(0,s.KR)([]),b=[],y=(0,s.KR)(0),C=(0,s.KR)(0),w=(0,s.KR)(0),L=(0,s.KR)(!1),x=(0,s.KR)([]),M=(0,s.KR)(!1),z=(0,s.KR)(!1),R=(0,s.KR)(null),k=(0,s.KR)({}),S=(0,s.KR)(null),E=(0,s.KR)(null),A=(0,s.KR)(null),N=(0,s.KR)(null),_=(0,s.KR)(null),O=(0,n.EW)(()=>o.value?ze(x.value,o.value):void 0);(0,n.wB)(c,()=>{var e;if(t.state){D(!1);const l="auto"===t.props.tableLayout;l&&(null==(e=t.refs.tableHeaderRef)||e.updateFixedColumnStyle())}},{deep:!0});const W=()=>{if(!o.value)throw new Error("[ElTable] prop row-key is required")},B=e=>{var t;null==(t=e.children)||t.forEach(t=>{t.fixed=e.fixed,B(t)})},I=()=>{u.value.forEach(e=>{B(e)}),p.value=u.value.filter(e=>[!0,"left"].includes(e.fixed));const e=u.value.find(e=>"selection"===e.type);let t;if(e&&"right"!==e.fixed&&!p.value.includes(e)){const l=u.value.indexOf(e);0===l&&p.value.length&&(p.value.unshift(e),t=!0)}m.value=u.value.filter(e=>"right"===e.fixed);const l=u.value.filter(e=>(!t||"selection"!==e.type)&&!e.fixed);d.value=Array.from(p.value).concat(l).concat(m.value);const n=qe(l),a=qe(p.value),o=qe(m.value);y.value=n.length,C.value=a.length,w.value=o.length,f.value=Array.from(a).concat(n).concat(o),i.value=p.value.length>0||m.value.length>0},D=(e,l=!1)=>{e&&I(),l?t.state.doLayout():t.state.debouncedUpdateLayout()},F=e=>O.value?!!O.value[Me(e,o.value)]:x.value.includes(e),V=()=>{L.value=!1;const e=x.value;x.value=[],e.length&&t.emit("selection-change",[])},P=()=>{var e,l;let n;if(o.value){n=[];const r=null==(l=null==(e=null==t?void 0:t.store)?void 0:e.states)?void 0:l.childrenColumnName.value,s=ze(c.value,o.value,!0,r);for(const e in O.value)(0,a.$3)(O.value,e)&&!s[e]&&n.push(O.value[e].row)}else n=x.value.filter(e=>!c.value.includes(e));if(n.length){const e=x.value.filter(e=>!n.includes(e));x.value=e,t.emit("selection-change",e.slice())}},$=()=>(x.value||[]).slice(),H=(e,l,n=!0,a=!1)=>{var r,s,i,u;const d={children:null==(s=null==(r=null==t?void 0:t.store)?void 0:r.states)?void 0:s.childrenColumnName.value,checkStrictly:null==(u=null==(i=null==t?void 0:t.store)?void 0:i.states)?void 0:u.checkStrictly.value},f=Ne(x.value,e,l,d,a?void 0:R.value,c.value.indexOf(e),o.value);if(f){const l=(x.value||[]).slice();n&&t.emit("select",l,e),t.emit("selection-change",l)}},j=()=>{var e,l;const n=z.value?!L.value:!(L.value||x.value.length);L.value=n;let a=!1,o=0;const r=null==(l=null==(e=null==t?void 0:t.store)?void 0:e.states)?void 0:l.rowKey.value,{childrenColumnName:s}=t.store.states,i={children:s.value,checkStrictly:!1};c.value.forEach((e,t)=>{const l=t+o;Ne(x.value,e,n,i,R.value,l,r)&&(a=!0),o+=X(Me(e,r))}),a&&t.emit("selection-change",x.value?x.value.slice():[]),t.emit("select-all",(x.value||[]).slice())},K=()=>{var e;if(0===(null==(e=c.value)?void 0:e.length))return void(L.value=!1);const{childrenColumnName:l}=t.store.states;let n=0,a=0;const o=e=>{var t;for(const c of e){const e=R.value&&R.value.call(null,c,n);if(F(c))a++;else if(!R.value||e)return!1;if(n++,(null==(t=c[l.value])?void 0:t.length)&&!o(c[l.value]))return!1}return!0},r=o(c.value||[]);L.value=0!==a&&r},X=e=>{var l;if(!t||!t.store)return 0;const{treeData:n}=t.store.states;let a=0;const o=null==(l=n.value[e])?void 0:l.children;return o&&(a+=o.length,o.forEach(e=>{a+=X(e)})),a},U=(e,t)=>{const l={};return(0,T.A)(e).forEach(e=>{k.value[e.id]=t,l[e.columnKey||e.id]=t}),l},q=(e,t,l)=>{E.value&&E.value!==e&&(E.value.order=null),E.value=e,A.value=t,N.value=l},G=()=>{let e=(0,s.R1)(r);Object.keys(k.value).forEach(t=>{const l=k.value[t];if(!l||0===l.length)return;const n=we({columns:f.value},t);n&&n.filterMethod&&(e=e.filter(e=>l.some(t=>n.filterMethod.call(null,t,e,n))))}),S.value=e},Y=()=>{var e;c.value=Ue(null!=(e=S.value)?e:[],{sortingColumn:E.value,sortProp:A.value,sortOrder:N.value})},Q=(e=void 0)=>{(null==e?void 0:e.filter)||G(),Y()},Z=e=>{const{tableHeaderRef:l}=t.refs;if(!l)return;const n=Object.assign({},l.filterPanels),o=Object.keys(n);if(o.length)if((0,a.Kg)(e)&&(e=[e]),(0,a.cy)(e)){const l=e.map(e=>Le({columns:f.value},e));o.forEach(e=>{const t=l.find(t=>t.id===e);t&&(t.filteredValue=[])}),t.store.commit("filterChange",{column:l,values:[],silent:!0,multi:!0})}else o.forEach(e=>{const t=f.value.find(t=>t.id===e);t&&(t.filteredValue=[])}),k.value={},t.store.commit("filterChange",{column:{},values:[],silent:!0})},J=()=>{E.value&&(q(null,null,null),t.store.commit("changeSortCondition",{silent:!0}))},{setExpandRowKeys:ee,toggleRowExpansion:te,updateExpandRows:le,states:ne,isRowExpanded:ae}=je({data:c,rowKey:o}),{updateTreeExpandKeys:oe,toggleTreeExpansion:ce,updateTreeData:re,updateKeyChildren:se,loadOrToggle:ie,states:ue}=Xe({data:c,rowKey:o}),{updateCurrentRowData:de,updateCurrentRow:fe,setCurrentRowKey:pe,states:me}=Ke({data:c,rowKey:o}),ve=e=>{ee(e),oe(e)},he=(e,t)=>{const l=f.value.some(({type:e})=>"expand"===e);l?te(e,t):ce(e,t)};return{assertRowKey:W,updateColumns:I,scheduleLayout:D,isSelected:F,clearSelection:V,cleanSelection:P,getSelectionRows:$,toggleRowSelection:H,_toggleAllSelection:j,toggleAllSelection:null,updateAllSelected:K,updateFilters:U,updateCurrentRow:fe,updateSort:q,execFilter:G,execSort:Y,execQuery:Q,clearFilter:Z,clearSort:J,toggleRowExpansion:te,setExpandRowKeysAdapter:ve,setCurrentRowKey:pe,toggleRowExpansionAdapter:he,isRowExpanded:ae,updateExpandRows:le,updateCurrentRowData:de,loadOrToggle:ie,updateTreeData:re,updateKeyChildren:se,states:{tableSize:l,rowKey:o,data:c,_data:r,isComplex:i,_columns:u,originColumns:d,columns:f,fixedColumns:p,rightFixedColumns:m,leafColumns:v,fixedLeafColumns:h,rightFixedLeafColumns:g,updateOrderFns:b,leafColumnsLength:y,fixedLeafColumnsLength:C,rightFixedLeafColumnsLength:w,isAllSelected:L,selection:x,reserveSelection:M,selectOnIndeterminate:z,selectable:R,filters:k,filteredData:S,sortingColumn:E,sortProp:A,sortOrder:N,hoverRow:_,...ne,...ue,...me}}}var Ye=l(3513),Qe=l(6268);function Ze(e,t){return e.map(e=>{var l;return e.id===t.id?t:((null==(l=e.children)?void 0:l.length)&&(e.children=Ze(e.children,t)),e)})}function Je(e){e.forEach(e=>{var t,l;e.no=null==(t=e.getColumnIndex)?void 0:t.call(e),(null==(l=e.children)?void 0:l.length)&&Je(e.children)}),e.sort((e,t)=>e.no-t.no)}function et(){const e=(0,n.nI)(),t=Ge(),l=(0,Ye.DU)("table"),{t:a}=(0,Qe.Ym)(),o={setData(t,l){const n=(0,s.R1)(t._data)!==l;t.data.value=l,t._data.value=l,e.store.execQuery(),e.store.updateCurrentRowData(),e.store.updateExpandRows(),e.store.updateTreeData(e.store.states.defaultExpandAll.value),(0,s.R1)(t.reserveSelection)?e.store.assertRowKey():n?e.store.clearSelection():e.store.cleanSelection(),e.store.updateAllSelected(),e.$ready&&e.store.scheduleLayout()},insertColumn(t,l,n,a){var o;const c=(0,s.R1)(t._columns);let r=[];n?(n&&!n.children&&(n.children=[]),null==(o=n.children)||o.push(l),r=Ze(c,n)):(c.push(l),r=c),Je(r),t._columns.value=r,t.updateOrderFns.push(a),"selection"===l.type&&(t.selectable.value=l.selectable,t.reserveSelection.value=l.reserveSelection),e.$ready&&(e.store.updateColumns(),e.store.scheduleLayout())},updateColumnOrder(t,l){var n;const a=null==(n=l.getColumnIndex)?void 0:n.call(l);a!==l.no&&(Je(t._columns.value),e.$ready&&e.store.updateColumns())},removeColumn(t,l,a,o){var c;const r=(0,s.R1)(t._columns)||[];if(a)null==(c=a.children)||c.splice(a.children.findIndex(e=>e.id===l.id),1),(0,n.dY)(()=>{var e;0===(null==(e=a.children)?void 0:e.length)&&delete a.children}),t._columns.value=Ze(r,a);else{const e=r.indexOf(l);e>-1&&(r.splice(e,1),t._columns.value=r)}const i=t.updateOrderFns.indexOf(o);i>-1&&t.updateOrderFns.splice(i,1),e.$ready&&(e.store.updateColumns(),e.store.scheduleLayout())},sort(t,l){const{prop:n,order:a,init:o}=l;if(n){const l=(0,s.R1)(t.columns).find(e=>e.property===n);l&&(l.order=a,e.store.updateSort(l,n,a),e.store.commit("changeSortCondition",{init:o}))}},changeSortCondition(t,l){const{sortingColumn:n,sortProp:a,sortOrder:o}=t,c=(0,s.R1)(n),r=(0,s.R1)(a),i=(0,s.R1)(o);u(i)&&(t.sortingColumn.value=null,t.sortProp.value=null);const d={filter:!0};e.store.execQuery(d),l&&(l.silent||l.init)||e.emit("sort-change",{column:c,prop:r,order:i}),e.store.updateTableScrollY()},filterChange(t,l){const{column:n,values:a,silent:o}=l,c=e.store.updateFilters(n,a);e.store.execQuery(),o||e.emit("filter-change",c),e.store.updateTableScrollY()},toggleAllSelection(){var t,l;null==(l=(t=e.store).toggleAllSelection)||l.call(t)},rowSelectedChanged(t,l){e.store.toggleRowSelection(l),e.store.updateAllSelected()},setHoverRow(e,t){e.hoverRow.value=t},setCurrentRow(t,l){e.store.updateCurrentRow(l)}},c=function(t,...l){const n=e.store.mutations;if(!n[t])throw new Error(`Action not found: ${t}`);n[t].apply(e,[e.store.states,...l])},r=function(){(0,n.dY)(()=>e.layout.updateScrollY.apply(e.layout))};return{ns:l,t:a,...t,mutations:o,commit:c,updateTableScrollY:r}}const tt={rowKey:"rowKey",defaultExpandAll:"defaultExpandAll",selectOnIndeterminate:"selectOnIndeterminate",indent:"indent",lazy:"lazy",data:"data",["treeProps.hasChildren"]:{key:"lazyColumnIdentifier",default:"hasChildren"},["treeProps.children"]:{key:"childrenColumnName",default:"children"},["treeProps.checkStrictly"]:{key:"checkStrictly",default:!1}};function lt(e,t){if(!e)throw new Error("Table is required.");const l=et();return l.toggleAllSelection=(0,c.A)(l._toggleAllSelection,10),Object.keys(tt).forEach(e=>{at(ot(t,e),e,l)}),nt(l,t),l}function nt(e,t){Object.keys(tt).forEach(l=>{(0,n.wB)(()=>ot(t,l),t=>{at(t,l,e)})})}function at(e,t,l){let n=e,o=tt[t];(0,a.Gv)(o)&&(n=n||o.default,o=o.key),l.states[o].value=n}function ot(e,t){if(t.includes(".")){const l=t.split(".");let n=e;return l.forEach(e=>{n=n[e]}),n}return e[t]}var ct=l(17);class rt{constructor(e){this.observers=[],this.table=null,this.store=null,this.columns=[],this.fit=!0,this.showHeader=!0,this.height=(0,s.KR)(null),this.scrollX=(0,s.KR)(!1),this.scrollY=(0,s.KR)(!1),this.bodyWidth=(0,s.KR)(null),this.fixedWidth=(0,s.KR)(null),this.rightFixedWidth=(0,s.KR)(null),this.gutterWidth=0;for(const t in e)(0,a.$3)(e,t)&&((0,s.i9)(this[t])?this[t].value=e[t]:this[t]=e[t]);if(!this.table)throw new Error("Table is required for Table Layout");if(!this.store)throw new Error("Store is required for Table Layout")}updateScrollY(){const e=this.height.value;if(u(e))return!1;const t=this.table.refs.scrollBarRef;if(this.table.vnode.el&&(null==t?void 0:t.wrapRef)){let e=!0;const l=this.scrollY.value;return e=t.wrapRef.scrollHeight>t.wrapRef.clientHeight,this.scrollY.value=e,l!==e}return!1}setHeight(e,t="height"){if(!ct.oc)return;const l=this.table.vnode.el;e=Ee(e),this.height.value=Number(e),l||!e&&0!==e?l&&(0,ge.Et)(e)?(l.style[t]=`${e}px`,this.updateElsHeight()):l&&(0,a.Kg)(e)&&(l.style[t]=e,this.updateElsHeight()):(0,n.dY)(()=>this.setHeight(e,t))}setMaxHeight(e){this.setHeight(e,"max-height")}getFlattenColumns(){const e=[],t=this.table.store.states.columns.value;return t.forEach(t=>{t.isColumnGroup?e.push.apply(e,t.columns):e.push(t)}),e}updateElsHeight(){this.updateScrollY(),this.notifyObservers("scrollable")}headerDisplayNone(e){if(!e)return!0;let t=e;while("DIV"!==t.tagName){if("none"===getComputedStyle(t).display)return!0;t=t.parentElement}return!1}updateColumnsWidth(){var e;if(!ct.oc)return;const t=this.fit,l=null==(e=this.table.vnode.el)?void 0:e.clientWidth;let n=0;const a=this.getFlattenColumns(),o=a.filter(e=>!(0,ge.Et)(e.width));if(a.forEach(e=>{(0,ge.Et)(e.width)&&e.realWidth&&(e.realWidth=null)}),o.length>0&&t){if(a.forEach(e=>{n+=Number(e.width||e.minWidth||80)}),n<=l){this.scrollX.value=!1;const e=l-n;if(1===o.length)o[0].realWidth=Number(o[0].minWidth||80)+e;else{const t=o.reduce((e,t)=>e+Number(t.minWidth||80),0),l=e/t;let n=0;o.forEach((e,t)=>{if(0===t)return;const a=Math.floor(Number(e.minWidth||80)*l);n+=a,e.realWidth=Number(e.minWidth||80)+a}),o[0].realWidth=Number(o[0].minWidth||80)+e-n}}else this.scrollX.value=!0,o.forEach(e=>{e.realWidth=Number(e.minWidth)});this.bodyWidth.value=Math.max(n,l),this.table.state.resizeState.value.width=this.bodyWidth.value}else a.forEach(e=>{e.width||e.minWidth?e.realWidth=Number(e.width||e.minWidth):e.realWidth=80,n+=e.realWidth}),this.scrollX.value=n>l,this.bodyWidth.value=n;const c=this.store.states.fixedColumns.value;if(c.length>0){let e=0;c.forEach(t=>{e+=Number(t.realWidth||t.width)}),this.fixedWidth.value=e}const r=this.store.states.rightFixedColumns.value;if(r.length>0){let e=0;r.forEach(t=>{e+=Number(t.realWidth||t.width)}),this.rightFixedWidth.value=e}this.notifyObservers("columns")}addObserver(e){this.observers.push(e)}removeObserver(e){const t=this.observers.indexOf(e);-1!==t&&this.observers.splice(t,1)}notifyObservers(e){const t=this.observers;t.forEach(t=>{var l,n;switch(e){case"columns":null==(l=t.state)||l.onColumnsChange(this);break;case"scrollable":null==(n=t.state)||n.onScrollableChange(this);break;default:throw new Error(`Table Layout don't have event ${e}.`)}})}}var st=l(850),it=l(813),ut=l(7477),dt=l(9077),ft=l(2251),pt=l(4225),mt=l(515);const vt=(0,n.pM)({name:"ElTableFilterPanel",components:{ElCheckbox:st.dI,ElCheckboxGroup:st.o5,ElScrollbar:r.kA,ElTooltip:ve.R7,ElIcon:it.tk,ArrowDown:ut.ArrowDown,ArrowUp:ut.ArrowUp},props:{placement:{type:String,default:"bottom-start"},store:{type:Object},column:{type:Object},upDataColumn:{type:Function},appendTo:ft.E.appendTo},setup(e){const t=(0,n.nI)(),{t:l}=(0,Qe.Ym)(),a=(0,Ye.DU)("table-filter"),o=null==t?void 0:t.parent;e.column&&!o.filterPanels.value[e.column.id]&&(o.filterPanels.value[e.column.id]=t);const c=(0,s.KR)(null),r=(0,s.KR)(null),i=(0,s.KR)(0),u=(0,n.EW)(()=>e.column&&e.column.filters),d=(0,n.EW)(()=>e.column&&e.column.filterClassName?`${a.b()} ${e.column.filterClassName}`:a.b()),f=(0,n.EW)({get:()=>{var t;return((null==(t=e.column)?void 0:t.filteredValue)||[])[0]},set:e=>{p.value&&((0,ge.Xj)(e)?p.value.splice(0,1):p.value.splice(0,1,e))}}),p=(0,n.EW)({get(){return e.column&&e.column.filteredValue||[]},set(t){var l;e.column&&(null==(l=e.upDataColumn)||l.call(e,"filteredValue",t))}}),m=(0,n.EW)(()=>!e.column||e.column.filterMultiple),v=e=>e.value===f.value,h=()=>{var e;null==(e=c.value)||e.onClose()},g=()=>{C(p.value),h()},b=()=>{p.value=[],C(p.value),h()},y=(e,t)=>{f.value=e,i.value=t,(0,ge.Xj)(e)?C([]):C(p.value),h()},C=t=>{var l,n;null==(l=e.store)||l.commit("filterChange",{column:e.column,values:t}),null==(n=e.store)||n.updateAllSelected()},w=()=>{var t,l;null==(t=r.value)||t.focus(),!m.value&&x(),e.column&&(null==(l=e.upDataColumn)||l.call(e,"filterOpened",!0))},L=()=>{var t;e.column&&(null==(t=e.upDataColumn)||t.call(e,"filterOpened",!1))},x=()=>{if((0,ge.Xj)(f))return void(i.value=0);const e=(u.value||[]).findIndex(e=>e.value===f.value);i.value=e>=0?e+1:0},M=e=>{var t,l;const n=(0,pt.CG)(e),o=(u.value?u.value.length:0)+1;let c=i.value,s=!0;switch(n){case mt.R.down:case mt.R.right:c=(c+1)%o;break;case mt.R.up:case mt.R.left:c=(c-1+o)%o;break;case mt.R.tab:h(),s=!1;break;case mt.R.enter:case mt.R.space:if(0===c)y(null,0);else{const e=(u.value||[])[c-1];e.value&&y(e.value,c)}break;default:s=!1;break}s&&e.preventDefault(),i.value=c,null==(l=null==(t=r.value)?void 0:t.querySelector(`.${a.e("list-item")}:nth-child(${c+1})`))||l.focus()};return{multiple:m,filterClassName:d,filteredValue:p,filterValue:f,filters:u,handleConfirm:g,handleReset:b,handleSelect:y,isPropAbsent:ge.Xj,isActive:v,t:l,ns:a,tooltipRef:c,rootRef:r,checkedIndex:i,handleShowTooltip:w,handleHideTooltip:L,handleKeydown:M}}});function ht(e,t,l,o,c,r){const s=(0,n.g2)("el-checkbox"),i=(0,n.g2)("el-checkbox-group"),u=(0,n.g2)("el-scrollbar"),d=(0,n.g2)("arrow-up"),f=(0,n.g2)("arrow-down"),p=(0,n.g2)("el-icon"),m=(0,n.g2)("el-tooltip");return(0,n.uX)(),(0,n.Wv)(m,{ref:"tooltipRef",offset:0,placement:e.placement,"show-arrow":!1,trigger:"click",role:"dialog",teleported:"",effect:"light",pure:"",loop:"","popper-class":e.filterClassName,persistent:"","append-to":e.appendTo,onShow:e.handleShowTooltip,onHide:e.handleHideTooltip},{content:(0,n.k6)(()=>[e.multiple?((0,n.uX)(),(0,n.CE)("div",{key:0,ref:"rootRef",tabindex:"-1",class:(0,a.C4)(e.ns.e("multiple"))},[(0,n.Lk)("div",{class:(0,a.C4)(e.ns.e("content"))},[(0,n.bF)(u,{"wrap-class":e.ns.e("wrap")},{default:(0,n.k6)(()=>[(0,n.bF)(i,{modelValue:e.filteredValue,"onUpdate:modelValue":t=>e.filteredValue=t,class:(0,a.C4)(e.ns.e("checkbox-group"))},{default:(0,n.k6)(()=>[((0,n.uX)(!0),(0,n.CE)(n.FK,null,(0,n.pI)(e.filters,e=>((0,n.uX)(),(0,n.Wv)(s,{key:e.value,value:e.value},{default:(0,n.k6)(()=>[(0,n.eW)((0,a.v_)(e.text),1)]),_:2},1032,["value"]))),128))]),_:1},8,["modelValue","onUpdate:modelValue","class"])]),_:1},8,["wrap-class"])],2),(0,n.Lk)("div",{class:(0,a.C4)(e.ns.e("bottom"))},[(0,n.Lk)("button",{class:(0,a.C4)(e.ns.is("disabled",0===e.filteredValue.length)),disabled:0===e.filteredValue.length,type:"button",onClick:e.handleConfirm},(0,a.v_)(e.t("el.table.confirmFilter")),11,["disabled","onClick"]),(0,n.Lk)("button",{type:"button",onClick:e.handleReset},(0,a.v_)(e.t("el.table.resetFilter")),9,["onClick"])],2)],2)):((0,n.uX)(),(0,n.CE)("ul",{key:1,ref:"rootRef",tabindex:"-1",role:"radiogroup",class:(0,a.C4)(e.ns.e("list")),onKeydown:e.handleKeydown},[(0,n.Lk)("li",{role:"radio",class:(0,a.C4)([e.ns.e("list-item"),e.ns.is("active",e.isPropAbsent(e.filterValue))]),tabindex:0===e.checkedIndex?0:-1,"aria-checked":e.isPropAbsent(e.filterValue),onClick:t=>e.handleSelect(null,0)},(0,a.v_)(e.t("el.table.clearFilter")),11,["tabindex","aria-checked","onClick"]),((0,n.uX)(!0),(0,n.CE)(n.FK,null,(0,n.pI)(e.filters,(t,l)=>((0,n.uX)(),(0,n.CE)("li",{key:t.value,role:"radio",class:(0,a.C4)([e.ns.e("list-item"),e.ns.is("active",e.isActive(t))]),tabindex:e.checkedIndex===l+1?0:-1,"aria-checked":e.isActive(t),onClick:n=>e.handleSelect(t.value,l+1)},(0,a.v_)(t.text),11,["tabindex","aria-checked","onClick"]))),128))],42,["onKeydown"]))]),default:(0,n.k6)(()=>{var t;return[(0,n.Lk)("button",{type:"button",class:(0,a.C4)(`${e.ns.namespace.value}-table__column-filter-trigger`),"aria-label":e.t("el.table.filterLabel",{column:(null==(t=e.column)?void 0:t.label)||""})},[(0,n.bF)(p,null,{default:(0,n.k6)(()=>[(0,n.RG)(e.$slots,"filter-icon",{},()=>{var t;return[(null==(t=e.column)?void 0:t.filterOpened)?((0,n.uX)(),(0,n.Wv)(d,{key:0})):((0,n.uX)(),(0,n.Wv)(f,{key:1}))]})]),_:3})],10,["aria-label"])]}),_:3},8,["placement","popper-class","append-to","onShow","onHide"])}var gt=(0,dt.A)(vt,[["render",ht],["__file","filter-panel.vue"]]);function bt(e){const t=(0,n.nI)();(0,n.KC)(()=>{l.value.addObserver(t)}),(0,n.sV)(()=>{a(l.value),o(l.value)}),(0,n.$u)(()=>{a(l.value),o(l.value)}),(0,n.hi)(()=>{l.value.removeObserver(t)});const l=(0,n.EW)(()=>{const t=e.layout;if(!t)throw new Error("Can not find table layout.");return t}),a=t=>{var l;const n=(null==(l=e.vnode.el)?void 0:l.querySelectorAll("colgroup > col"))||[];if(!n.length)return;const a=t.getFlattenColumns(),o={};a.forEach(e=>{o[e.id]=e});for(let e=0,c=n.length;e{var l,n;const a=(null==(l=e.vnode.el)?void 0:l.querySelectorAll("colgroup > col[name=gutter]"))||[];for(let e=0,c=a.length;e{e.stopPropagation()},c=(e,t)=>{!t.filters&&t.sortable?g(e,t,!1):t.filterable&&!t.sortable&&o(e),null==a||a.emit("header-click",t,e)},r=(e,t)=>{null==a||a.emit("header-contextmenu",t,e)},i=(0,s.KR)(null),d=(0,s.KR)(!1),f=(0,s.KR)(),p=(n,o)=>{var c,r;if(ct.oc&&!(o.children&&o.children.length>0)&&i.value&&e.border&&i.value.id===o.id){d.value=!0;const s=a;t("set-drag-visible",!0);const u=null==s?void 0:s.vnode.el,p=null==u?void 0:u.getBoundingClientRect().left,m=null==(r=null==(c=null==l?void 0:l.vnode)?void 0:c.el)?void 0:r.querySelector(`th.${o.id}`),v=m.getBoundingClientRect(),h=v.left-p+30;(0,Ct.iQ)(m,"noclick"),f.value={startMouseLeft:n.clientX,startLeft:v.right-p,startColumnLeft:v.left-p,tableLeft:p};const g=null==s?void 0:s.refs.resizeProxy;g.style.left=`${f.value.startLeft}px`,document.onselectstart=function(){return!1},document.ondragstart=function(){return!1};const b=e=>{const t=e.clientX-f.value.startMouseLeft,l=f.value.startLeft+t;g.style.left=`${Math.max(h,l)}px`},y=()=>{if(d.value){const{startColumnLeft:l,startLeft:a}=f.value,c=Number.parseInt(g.style.left,10),r=c-l;o.width=o.realWidth=r,null==s||s.emit("header-dragend",o.width,a-l,o,n),requestAnimationFrame(()=>{e.store.scheduleLayout(!1,!0)}),document.body.style.cursor="",d.value=!1,i.value=null,f.value=void 0,t("set-drag-visible",!1)}document.removeEventListener("mousemove",b),document.removeEventListener("mouseup",y),document.onselectstart=null,document.ondragstart=null,setTimeout(()=>{(0,Ct.vy)(m,"noclick")},0)};document.addEventListener("mousemove",b),document.addEventListener("mouseup",y)}},m=(t,l)=>{var n;if(!e.border||l.children&&l.children.length>0)return;const a=t.target,o=(0,ge.vq)(a)?a.closest("th"):null;if(!o)return;const c=(0,Ct.nB)(o,"is-sortable");if(c){const e=d.value?"col-resize":"";o.style.cursor=e;const t=o.querySelector(".caret-wrapper");t&&(t.style.cursor=e)}if(!l.resizable||d.value)return void(i.value=null);const r=o.getBoundingClientRect(),s=(null==(n=o.parentNode)?void 0:n.lastElementChild)===o,u=e.allowDragLastColumn||!s,f=r.width>12&&r.right-t.clientX<8&&u,p=f?"col-resize":"";document.body.style.cursor=p,i.value=f?l:null,c&&(o.style.cursor=p)},v=()=>{ct.oc&&!d.value&&(document.body.style.cursor="")},h=({order:e,sortOrders:t})=>{if(""===e)return t[0];const l=t.indexOf(e||null);return t[l>t.length-2?0:l+1]},g=(t,l,n)=>{var o;t.stopPropagation();const c=l.order===n?null:n||h(l),r=null==(o=t.target)?void 0:o.closest("th");if(r&&(0,Ct.nB)(r,"noclick"))return void(0,Ct.vy)(r,"noclick");if(!l.sortable)return;const s=t.currentTarget;if(["ascending","descending"].some(e=>(0,Ct.nB)(s,e)&&!l.sortOrders.includes(e)))return;const i=e.store.states;let d,f=i.sortProp.value;const p=i.sortingColumn.value;(p!==l||p===l&&u(p.order))&&(p&&(p.order=null),i.sortingColumn.value=l,f=l.property),d=l.order=c||null,i.sortProp.value=f,i.sortOrder.value=d,null==a||a.store.commit("changeSortCondition")};return{handleHeaderClick:c,handleHeaderContextMenu:r,handleMouseDown:p,handleMouseMove:m,handleMouseOut:v,handleSortClick:g,handleFilterClick:o}}function Lt(e){const t=(0,n.WQ)(yt),l=(0,Ye.DU)("table"),o=e=>{const l=null==t?void 0:t.props.headerRowStyle;return(0,a.Tn)(l)?l.call(null,{rowIndex:e}):l},c=e=>{const l=[],n=null==t?void 0:t.props.headerRowClassName;return(0,a.Kg)(n)?l.push(n):(0,a.Tn)(n)&&l.push(n.call(null,{rowIndex:e})),l.join(" ")},r=(l,n,o,c)=>{var r;let s=null!=(r=null==t?void 0:t.props.headerCellStyle)?r:{};(0,a.Tn)(s)&&(s=s.call(null,{rowIndex:l,columnIndex:n,row:o,column:c}));const i=Pe(n,c.fixed,e.store,o);return $e(i,"left"),$e(i,"right"),Object.assign({},s,i)},s=(n,o,c,r)=>{const s=Fe(l.b(),o,r.fixed,e.store,c),i=[r.id,r.order,r.headerAlign,r.className,r.labelClassName,...s];r.children||i.push("is-leaf"),r.sortable&&i.push("is-sortable");const u=null==t?void 0:t.props.headerCellClassName;return(0,a.Kg)(u)?i.push(u):(0,a.Tn)(u)&&i.push(u.call(null,{rowIndex:n,columnIndex:o,row:c,column:r})),i.push(l.e("cell")),i.filter(e=>Boolean(e)).join(" ")};return{getHeaderRowStyle:o,getHeaderRowClass:c,getHeaderCellStyle:r,getHeaderCellClass:s}}const xt=e=>{const t=[];return e.forEach(e=>{e.children?(t.push(e),t.push.apply(t,xt(e.children))):t.push(e)}),t},Mt=e=>{let t=1;const l=(e,n)=>{if(n&&(e.level=n.level+1,t{l(n,e),t+=n.colSpan}),e.colSpan=t}else e.colSpan=1};e.forEach(e=>{e.level=1,l(e,void 0)});const n=[];for(let o=0;o{e.children?(e.rowSpan=1,e.children.forEach(e=>e.isSubColumn=!0)):e.rowSpan=t-e.level+1,n[e.level-1].push(e)}),n};function zt(e){const t=(0,n.WQ)(yt),l=(0,n.EW)(()=>Mt(e.store.states.originColumns.value)),a=(0,n.EW)(()=>{const e=l.value.length>1;return e&&t&&(t.state.isGroup.value=!0),e}),o=e=>{e.stopPropagation(),null==t||t.store.commit("toggleAllSelection")};return{isGroup:a,toggleAllSelection:o,columnRows:l}}var Rt=(0,n.pM)({name:"ElTableHeader",components:{ElCheckbox:st.dI},props:{fixed:{type:String,default:""},store:{required:!0,type:Object},border:Boolean,defaultSort:{type:Object,default:()=>({prop:"",order:""})},appendFilterPanelTo:{type:String},allowDragLastColumn:{type:Boolean}},setup(e,{emit:t}){const l=(0,n.nI)(),a=(0,n.WQ)(yt),o=(0,Ye.DU)("table"),c=(0,s.KR)({}),{onColumnsChange:r,onScrollableChange:i}=bt(a),u="auto"===(null==a?void 0:a.props.tableLayout),d=(0,s.Kh)(new Map),f=(0,s.KR)();let p;const m=()=>{p=setTimeout(()=>{d.size>0&&(d.forEach((e,t)=>{const l=f.value.querySelector(`.${t.replace(/\s/g,".")}`);if(l){const t=l.getBoundingClientRect().width;e.width=t||e.width}}),d.clear())})};(0,n.wB)(d,m),(0,n.xo)(()=>{p&&(clearTimeout(p),p=void 0)}),(0,n.sV)(async()=>{await(0,n.dY)(),await(0,n.dY)();const{prop:t,order:l}=e.defaultSort;null==a||a.store.commit("sort",{prop:t,order:l,init:!0}),m()});const{handleHeaderClick:v,handleHeaderContextMenu:h,handleMouseDown:g,handleMouseMove:b,handleMouseOut:y,handleSortClick:C,handleFilterClick:w}=wt(e,t),{getHeaderRowStyle:L,getHeaderRowClass:x,getHeaderCellStyle:M,getHeaderCellClass:z}=Lt(e),{isGroup:R,toggleAllSelection:k,columnRows:S}=zt(e),{t:E}=(0,Qe.Ym)();return l.state={onColumnsChange:r,onScrollableChange:i},l.filterPanels=c,{ns:o,t:E,filterPanels:c,onColumnsChange:r,onScrollableChange:i,columnRows:S,getHeaderRowClass:x,getHeaderRowStyle:L,getHeaderCellClass:z,getHeaderCellStyle:M,handleHeaderClick:v,handleHeaderContextMenu:h,handleMouseDown:g,handleMouseMove:b,handleMouseOut:y,handleSortClick:C,handleFilterClick:w,isGroup:R,toggleAllSelection:k,saveIndexSelection:d,isTableLayoutAuto:u,theadRef:f,updateFixedColumnStyle:m}},render(){const{ns:e,t:t,isGroup:l,columnRows:a,getHeaderCellStyle:o,getHeaderCellClass:c,getHeaderRowClass:r,getHeaderRowStyle:s,handleHeaderClick:i,handleHeaderContextMenu:u,handleMouseDown:d,handleMouseMove:f,handleSortClick:p,handleMouseOut:m,store:v,$parent:h,saveIndexSelection:g,isTableLayoutAuto:b}=this;let y=1;return(0,n.h)("thead",{ref:"theadRef",class:e.is("group",l)},a.map((e,l)=>(0,n.h)("tr",{class:r(l),key:l,style:s(l)},e.map((a,r)=>{a.rowSpan>y&&(y=a.rowSpan);const s=c(l,r,e,a);return b&&a.fixed&&g.set(s,a),(0,n.h)("th",{class:s,colspan:a.colSpan,key:`${a.id}-thead`,rowspan:a.rowSpan,scope:a.colSpan>1?"colgroup":"col",style:o(l,r,e,a),onClick:e=>{var t;(null==(t=e.currentTarget)?void 0:t.classList.contains("noclick"))||i(e,a)},onContextmenu:e=>u(e,a),onMousedown:e=>d(e,a),onMousemove:e=>f(e,a),onMouseout:m},[(0,n.h)("div",{class:["cell",a.filteredValue&&a.filteredValue.length>0?"highlight":""]},[a.renderHeader?a.renderHeader({column:a,$index:r,store:v,_self:h}):a.label,a.sortable&&(0,n.h)("button",{type:"button",class:"caret-wrapper","aria-label":t("el.table.sortLabel",{column:a.label||""}),onClick:e=>p(e,a)},[(0,n.h)("i",{onClick:e=>p(e,a,"ascending"),class:"sort-caret ascending"}),(0,n.h)("i",{onClick:e=>p(e,a,"descending"),class:"sort-caret descending"})]),a.filterable&&(0,n.h)(gt,{store:v,placement:a.filterPlacement||"bottom-start",appendTo:null==h?void 0:h.appendFilterPanelTo,column:a,upDataColumn:(e,t)=>{a[e]=t}},{"filter-icon":()=>a.renderFilterIcon?a.renderFilterIcon({filterOpened:a.filterOpened}):null})])])}))))}});function kt(e,t,l=.03){return e-t>l}function St(e){const t=(0,n.WQ)(yt),l=(0,s.KR)(""),a=(0,s.KR)((0,n.h)("div")),o=(l,n,a)=>{var o,c,r;const s=t,i=ye(l);let u=null;const d=null==(o=null==s?void 0:s.vnode.el)?void 0:o.dataset.prefix;i&&(u=xe({columns:null!=(r=null==(c=e.store)?void 0:c.states.columns.value)?r:[]},i,d),u&&(null==s||s.emit(`cell-${a}`,n,u,i,l))),null==s||s.emit(`row-${a}`,n,u,l)},r=(e,t)=>{o(e,t,"dblclick")},i=(t,l)=>{var n;null==(n=e.store)||n.commit("setCurrentRow",l),o(t,l,"click")},u=(e,t)=>{o(e,t,"contextmenu")},d=(0,c.A)(t=>{var l;null==(l=e.store)||l.commit("setHoverRow",t)},30),f=(0,c.A)(()=>{var t;null==(t=e.store)||t.commit("setHoverRow",null)},30),p=e=>{const t=window.getComputedStyle(e,null),l=Number.parseInt(t.paddingLeft,10)||0,n=Number.parseInt(t.paddingRight,10)||0,a=Number.parseInt(t.paddingTop,10)||0,o=Number.parseInt(t.paddingBottom,10)||0;return{left:l,right:n,top:a,bottom:o}},m=(e,t,l)=>{var n;let a=null==(n=null==t?void 0:t.target)?void 0:n.parentNode;while(e>1){if(a=null==a?void 0:a.nextSibling,!a||"TR"!==a.nodeName)break;l(a,"hover-row hover-fixed-row"),e--}},v=(l,n,a)=>{var o,c,r,s,i,u,d,f,v;if(!t)return;const h=t,g=ye(l),b=null==(o=null==h?void 0:h.vnode.el)?void 0:o.dataset.prefix;let y=null;if(g){if(y=xe({columns:null!=(r=null==(c=e.store)?void 0:c.states.columns.value)?r:[]},g,b),!y)return;g.rowSpan>1&&m(g.rowSpan,l,Ct.iQ);const t=h.hoverState={cell:g,column:y,row:n};null==h||h.emit("cell-mouse-enter",t.row,t.column,t.cell,l)}if(!a)return void((null==(s=Oe)?void 0:s.trigger)===g&&(null==(i=Oe)||i()));const C=l.target.querySelector(".cell");if(!((0,Ct.nB)(C,`${b}-tooltip`)&&C.childNodes.length&&(null==(u=C.textContent)?void 0:u.trim())))return;const w=document.createRange();w.setStart(C,0),w.setEnd(C,C.childNodes.length);const{width:L,height:x}=w.getBoundingClientRect(),{width:M,height:z}=C.getBoundingClientRect(),{top:R,left:k,right:S,bottom:E}=p(C),A=k+S,N=R+E;kt(L+A,M)||kt(x+N,z)||kt(C.scrollWidth,M)?We(a,null!=(d=(null==g?void 0:g.innerText)||(null==g?void 0:g.textContent))?d:"",n,y,g,h):(null==(f=Oe)?void 0:f.trigger)===g&&(null==(v=Oe)||v())},h=e=>{const l=ye(e);if(!l)return;l.rowSpan>1&&m(l.rowSpan,e,Ct.vy);const n=null==t?void 0:t.hoverState;null==t||t.emit("cell-mouse-leave",null==n?void 0:n.row,null==n?void 0:n.column,null==n?void 0:n.cell,e)};return{handleDoubleClick:r,handleClick:i,handleContextMenu:u,handleMouseEnter:d,handleMouseLeave:f,handleCellMouseEnter:v,handleCellMouseLeave:h,tooltipContent:l,tooltipTrigger:a}}function Et(e){const t=(0,n.WQ)(yt),l=(0,Ye.DU)("table"),o=(e,l)=>{const n=null==t?void 0:t.props.rowStyle;return(0,a.Tn)(n)?n.call(null,{row:e,rowIndex:l}):n||null},c=(n,o,c)=>{var r;const s=[l.e("row")];(null==t?void 0:t.props.highlightCurrentRow)&&n===(null==(r=e.store)?void 0:r.states.currentRow.value)&&s.push("current-row"),e.stripe&&c%2===1&&s.push(l.em("row","striped"));const i=null==t?void 0:t.props.rowClassName;return(0,a.Kg)(i)?s.push(i):(0,a.Tn)(i)&&s.push(i.call(null,{row:n,rowIndex:o})),s},r=(l,n,o,c)=>{const r=null==t?void 0:t.props.cellStyle;let s=null!=r?r:{};(0,a.Tn)(r)&&(s=r.call(null,{rowIndex:l,columnIndex:n,row:o,column:c}));const i=Pe(n,null==e?void 0:e.fixed,e.store);return $e(i,"left"),$e(i,"right"),Object.assign({},s,i)},s=(n,o,c,r,s)=>{const i=Fe(l.b(),o,null==e?void 0:e.fixed,e.store,void 0,s),u=[r.id,r.align,r.className,...i],d=null==t?void 0:t.props.cellClassName;return(0,a.Kg)(d)?u.push(d):(0,a.Tn)(d)&&u.push(d.call(null,{rowIndex:n,columnIndex:o,row:c,column:r})),u.push(l.e("cell")),u.filter(e=>Boolean(e)).join(" ")},i=(e,l,n,o)=>{let c=1,r=1;const s=null==t?void 0:t.props.spanMethod;if((0,a.Tn)(s)){const t=s({row:e,column:l,rowIndex:n,columnIndex:o});(0,a.cy)(t)?(c=t[0],r=t[1]):(0,a.Gv)(t)&&(c=t.rowspan,r=t.colspan)}return{rowspan:c,colspan:r}},u=(e,t,l)=>{if(t<1)return e[l].realWidth;const n=e.map(({realWidth:e,width:t})=>e||t).slice(l,l+t);return Number(n.reduce((e,t)=>Number(e)+Number(t),-1))};return{getRowStyle:o,getRowClass:c,getCellStyle:r,getCellClass:s,getSpan:i,getColspanRealWidth:u}}const At=(0,n.pM)({name:"TableTdWrapper"}),Nt=(0,n.pM)({...At,props:{colspan:{type:Number,default:1},rowspan:{type:Number,default:1}},setup(e){return(t,l)=>((0,n.uX)(),(0,n.CE)("td",{colspan:e.colspan,rowspan:e.rowspan},[(0,n.RG)(t.$slots,"default")],8,["colspan","rowspan"]))}});var _t=(0,dt.A)(Nt,[["__file","td-wrapper.vue"]]);function Tt(e){const t=(0,n.WQ)(yt),l=(0,Ye.DU)("table"),{handleDoubleClick:a,handleClick:o,handleContextMenu:c,handleMouseEnter:r,handleMouseLeave:s,handleCellMouseEnter:i,handleCellMouseLeave:u,tooltipContent:d,tooltipTrigger:f}=St(e),{getRowStyle:p,getRowClass:m,getCellStyle:v,getCellClass:h,getSpan:g,getColspanRealWidth:b}=Et(e);let y=-1;const C=(0,n.EW)(()=>{var t;return null==(t=e.store)?void 0:t.states.columns.value.findIndex(({type:e})=>"default"===e)}),w=(e,l)=>{var n;const a=null==(n=null==t?void 0:t.props)?void 0:n.rowKey;return a?Me(e,a):l},L=(d,f,L,M=!1)=>{const{tooltipEffect:z,tooltipOptions:R,store:k}=e,{indent:S,columns:E}=k.states,A=[];let N=!0;L&&(A.push(l.em("row",`level-${L.level}`)),N=!!L.display),0===f&&(y=-1),e.stripe&&N&&y++,A.push(...m(d,f,y));const _=N?null:{display:"none"};return(0,n.h)("tr",{style:[_,p(d,f)],class:A,key:w(d,f),onDblclick:e=>a(e,d),onClick:e=>o(e,d),onContextmenu:e=>c(e,d),onMouseenter:()=>r(f),onMouseleave:s},E.value.map((l,a)=>{const{rowspan:o,colspan:c}=g(d,l,f,a);if(!o||!c)return null;const r=Object.assign({},l);r.realWidth=b(E.value,c,a);const s={store:k,_self:e.context||t,column:r,row:d,$index:f,cellIndex:a,expanded:M};a===C.value&&L&&(s.treeNode={indent:L.level&&L.level*S.value,level:L.level},(0,ge.Lm)(L.expanded)&&(s.treeNode.expanded=L.expanded,"loading"in L&&(s.treeNode.loading=L.loading),"noLazyChildren"in L&&(s.treeNode.noLazyChildren=L.noLazyChildren)));const p=`${w(d,f)},${a}`,m=r.columnKey||r.rawColumnKey||"",y=l.showOverflowTooltip&&me({effect:z},R,l.showOverflowTooltip);return(0,n.h)(_t,{style:v(f,a,d,l),class:h(f,a,d,l,c-1),key:`${m}${p}`,rowspan:o,colspan:c,onMouseenter:e=>i(e,d,y),onMouseleave:u},{default:()=>x(a,l,s)})}))},x=(e,t,l)=>t.renderCell(l),M=(a,o)=>{const c=e.store,{isRowExpanded:r,assertRowKey:s}=c,{treeData:i,lazyTreeNodeMap:u,childrenColumnName:d,rowKey:f}=c.states,p=c.states.columns.value,m=p.some(({type:e})=>"expand"===e);if(m){const e=r(a),s=L(a,o,void 0,e),i=null==t?void 0:t.renderExpanded;if(!i)return console.error("[Element Error]renderExpanded is required."),s;const u=[[s]];return(t.props.preserveExpandedContent||e)&&u[0].push((0,n.h)("tr",{key:`expanded-row__${s.key}`,style:{display:e?"":"none"}},[(0,n.h)("td",{colspan:p.length,class:`${l.e("cell")} ${l.e("expanded-cell")}`},[i({row:a,$index:o,store:c,expanded:e})])])),u}if(Object.keys(i.value).length){s();const e=Me(a,f.value);let t=i.value[e],l=null;t&&(l={expanded:t.expanded,level:t.level,display:!0,noLazyChildren:void 0,loading:void 0},(0,ge.Lm)(t.lazy)&&(l&&(0,ge.Lm)(t.loaded)&&t.loaded&&(l.noLazyChildren=!(t.children&&t.children.length)),l.loading=t.loading));const n=[L(a,o,null!=l?l:void 0)];if(t){let l=0;const c=(e,a)=>{e&&e.length&&a&&e.forEach(e=>{const r={display:a.display&&a.expanded,level:a.level+1,expanded:!1,noLazyChildren:!1,loading:!1},s=Me(e,f.value);if((0,ge.Xj)(s))throw new Error("For nested data item, row-key is required.");if(t={...i.value[s]},t&&(r.expanded=t.expanded,t.level=t.level||r.level,t.display=!(!t.expanded||!r.display),(0,ge.Lm)(t.lazy)&&((0,ge.Lm)(t.loaded)&&t.loaded&&(r.noLazyChildren=!(t.children&&t.children.length)),r.loading=t.loading)),l++,n.push(L(e,o+l,r)),t){const l=u.value[s]||e[d.value];c(l,t)}})};t.display=!0;const r=u.value[e]||a[d.value];c(r,t)}return n}return L(a,o,void 0)};return{wrappedRowRender:M,tooltipContent:d,tooltipTrigger:f}}const Ot={store:{required:!0,type:Object},stripe:Boolean,tooltipEffect:String,tooltipOptions:{type:Object},context:{default:()=>({}),type:Object},rowClassName:[String,Function],rowStyle:[Object,Function],fixed:{type:String,default:""},highlight:Boolean};var Wt=l(5431),Bt=(0,n.pM)({name:"ElTableBody",props:Ot,setup(e){var t;const l=(0,n.nI)(),a=(0,n.WQ)(yt),o=(0,Ye.DU)("table"),{wrappedRowRender:c,tooltipContent:r,tooltipTrigger:s}=Tt(e),{onColumnsChange:i,onScrollableChange:u}=bt(a),d=[];return(0,n.wB)(null==(t=e.store)?void 0:t.states.hoverRow,(t,n)=>{var a,c;const r=null==l?void 0:l.vnode.el,s=Array.from((null==r?void 0:r.children)||[]).filter(e=>null==e?void 0:e.classList.contains(`${o.e("row")}`));let i=t;const u=null==(a=s[i])?void 0:a.childNodes;if(null==u?void 0:u.length){let e=0;const l=Array.from(u).reduce((t,l,n)=>{var a,o;return(null==(a=u[n])?void 0:a.colSpan)>1&&(e=null==(o=u[n])?void 0:o.colSpan),"TD"!==l.nodeName&&0===e&&t.push(n),e>0&&e--,t},[]);l.forEach(e=>{var l;i=t;while(i>0){const t=null==(l=s[i-1])?void 0:l.childNodes;if(t[e]&&"TD"===t[e].nodeName&&t[e].rowSpan>1){(0,Ct.iQ)(t[e],"hover-cell"),d.push(t[e]);break}i--}})}else d.forEach(e=>(0,Ct.vy)(e,"hover-cell")),d.length=0;(null==(c=e.store)?void 0:c.states.isComplex.value)&&ct.oc&&(0,Wt.m)(()=>{const e=s[n],l=s[t];e&&!e.classList.contains("hover-fixed-row")&&(0,Ct.vy)(e,"hover-row"),l&&(0,Ct.iQ)(l,"hover-row")})}),(0,n.hi)(()=>{var e;null==(e=Oe)||e()}),{ns:o,onColumnsChange:i,onScrollableChange:u,wrappedRowRender:c,tooltipContent:r,tooltipTrigger:s}},render(){const{wrappedRowRender:e,store:t}=this,l=(null==t?void 0:t.states.data.value)||[];return(0,n.h)("tbody",{tabIndex:-1},[l.reduce((t,l)=>t.concat(e(l,t.length)),[])])}});function It(){const e=(0,n.WQ)(yt),t=null==e?void 0:e.store,l=(0,n.EW)(()=>{var e;return null!=(e=null==t?void 0:t.states.fixedLeafColumnsLength.value)?e:0}),a=(0,n.EW)(()=>{var e;return null!=(e=null==t?void 0:t.states.rightFixedColumns.value.length)?e:0}),o=(0,n.EW)(()=>{var e;return null!=(e=null==t?void 0:t.states.columns.value.length)?e:0}),c=(0,n.EW)(()=>{var e;return null!=(e=null==t?void 0:t.states.fixedColumns.value.length)?e:0}),r=(0,n.EW)(()=>{var e;return null!=(e=null==t?void 0:t.states.rightFixedColumns.value.length)?e:0});return{leftFixedLeafCount:l,rightFixedLeafCount:a,columnsCount:o,leftFixedCount:c,rightFixedCount:r,columns:(0,n.EW)(()=>{var e;return null!=(e=null==t?void 0:t.states.columns.value)?e:[]})}}function Dt(e){const{columns:t}=It(),l=(0,Ye.DU)("table"),n=(t,n)=>{const a=t[n],o=[l.e("cell"),a.id,a.align,a.labelClassName,...Fe(l.b(),n,a.fixed,e.store)];return a.className&&o.push(a.className),a.children||o.push(l.is("leaf")),o},a=(t,l)=>{const n=Pe(l,t.fixed,e.store);return $e(n,"left"),$e(n,"right"),n};return{getCellClasses:n,getCellStyles:a,columns:t}}var Ft=(0,n.pM)({name:"ElTableFooter",props:{fixed:{type:String,default:""},store:{required:!0,type:Object},summaryMethod:Function,sumText:String,border:Boolean,defaultSort:{type:Object,default:()=>({prop:"",order:""})}},setup(e){const t=(0,n.WQ)(yt),l=(0,Ye.DU)("table"),{getCellClasses:a,getCellStyles:o,columns:c}=Dt(e),{onScrollableChange:r,onColumnsChange:s}=bt(t);return{ns:l,onScrollableChange:r,onColumnsChange:s,getCellClasses:a,getCellStyles:o,columns:c}},render(){const{columns:e,getCellStyles:t,getCellClasses:l,summaryMethod:a,sumText:o}=this,c=this.store.states.data.value;let r=[];return a?r=a({columns:e,data:c}):e.forEach((e,t)=>{if(0===t)return void(r[t]=o);const l=c.map(t=>Number(t[e.property])),n=[];let a=!0;l.forEach(e=>{if(!Number.isNaN(+e)){a=!1;const t=`${e}`.split(".")[1];n.push(t?t.length:0)}});const s=Math.max.apply(null,n);r[t]=a?"":l.reduce((e,t)=>{const l=Number(t);return Number.isNaN(+l)?e:Number.parseFloat((e+t).toFixed(Math.min(s,20)))},0)}),(0,n.h)((0,n.h)("tfoot",[(0,n.h)("tr",{},[...e.map((a,o)=>(0,n.h)("td",{key:o,colspan:a.colSpan,rowspan:a.rowSpan,class:l(e,o),style:t(a,o)},[(0,n.h)("div",{class:["cell",a.labelClassName]},[r[o]])]))])]))}});function Vt(e){const t=t=>{e.commit("setCurrentRow",t)},l=()=>e.getSelectionRows(),n=(t,l,n=!0)=>{e.toggleRowSelection(t,l,!1,n),e.updateAllSelected()},a=()=>{e.clearSelection()},o=t=>{e.clearFilter(t)},c=()=>{e.commit("toggleAllSelection")},r=(t,l)=>{e.toggleRowExpansionAdapter(t,l)},s=()=>{e.clearSort()},i=(t,l)=>{e.commit("sort",{prop:t,order:l})},u=(t,l)=>{e.updateKeyChildren(t,l)};return{setCurrentRow:t,getSelectionRows:l,toggleRowSelection:n,clearSelection:a,clearFilter:o,toggleAllSelection:c,toggleRowExpansion:r,clearSort:s,sort:i,updateKeyChildren:u}}var Pt=l(7687),$t=l(2436);function Ht(e,t,l,a){const o=(0,s.KR)(!1),c=(0,s.KR)(null),r=(0,s.KR)(!1),i=e=>{r.value=e},u=(0,s.KR)({width:null,height:null,headerHeight:null}),d=(0,s.KR)(!1),f={display:"inline-block",verticalAlign:"middle"},p=(0,s.KR)(),m=(0,s.KR)(0),v=(0,s.KR)(0),h=(0,s.KR)(0),g=(0,s.KR)(0),b=(0,s.KR)(0);(0,n.wB)(()=>e.height,e=>{t.setHeight(null!=e?e:null)},{immediate:!0}),(0,n.wB)(()=>e.maxHeight,e=>{t.setMaxHeight(null!=e?e:null)},{immediate:!0}),(0,n.wB)(()=>[e.currentRowKey,l.states.rowKey],([e,t])=>{(0,s.R1)(t)&&(0,s.R1)(e)&&l.setCurrentRowKey(`${e}`)},{immediate:!0}),(0,n.wB)(()=>e.data,e=>{a.store.commit("setData",e)},{immediate:!0,deep:!0}),(0,n.nT)(()=>{e.expandRowKeys&&l.setExpandRowKeysAdapter(e.expandRowKeys)});const y=()=>{a.store.commit("setHoverRow",null),a.hoverState&&(a.hoverState=null)},C=(e,t)=>{const{pixelX:l,pixelY:n}=t;Math.abs(l)>=Math.abs(n)&&(a.refs.bodyWrapper.scrollLeft+=t.pixelX/5)},w=(0,n.EW)(()=>e.height||e.maxHeight||l.states.fixedColumns.value.length>0||l.states.rightFixedColumns.value.length>0),L=(0,n.EW)(()=>({width:t.bodyWidth.value?`${t.bodyWidth.value}px`:""})),x=()=>{w.value&&t.updateElsHeight(),t.updateColumnsWidth(),"undefined"!==typeof window&&requestAnimationFrame(k)};(0,n.sV)(async()=>{await(0,n.dY)(),l.updateColumns(),S(),requestAnimationFrame(x);const t=a.vnode.el,o=a.refs.headerWrapper;e.flexible&&t&&t.parentElement&&(t.parentElement.style.minWidth="0"),u.value={width:p.value=t.offsetWidth,height:t.offsetHeight,headerHeight:e.showHeader&&o?o.offsetHeight:null},l.states.columns.value.forEach(e=>{e.filteredValue&&e.filteredValue.length&&a.store.commit("filterChange",{column:e,values:e.filteredValue,silent:!0})}),a.$ready=!0});const M=(e,l)=>{if(!e)return;const n=Array.from(e.classList).filter(e=>!e.startsWith("is-scrolling-"));n.push(t.scrollX.value?l:"is-scrolling-none"),e.className=n.join(" ")},z=e=>{const{tableWrapper:t}=a.refs;M(t,e)},R=e=>{const{tableWrapper:t}=a.refs;return!(!t||!t.classList.contains(e))},k=function(){if(!a.refs.scrollBarRef)return;if(!t.scrollX.value){const e="is-scrolling-none";return void(R(e)||z(e))}const e=a.refs.scrollBarRef.wrapRef;if(!e)return;const{scrollLeft:l,offsetWidth:n,scrollWidth:o}=e,{headerWrapper:c,footerWrapper:r}=a.refs;c&&(c.scrollLeft=l),r&&(r.scrollLeft=l);const s=o-n-1;z(l>=s?"is-scrolling-right":0===l?"is-scrolling-left":"is-scrolling-middle")},S=()=>{a.refs.scrollBarRef&&(a.refs.scrollBarRef.wrapRef&&(0,Pt.MLh)(a.refs.scrollBarRef.wrapRef,"scroll",k,{passive:!0}),e.fit?(0,Pt.wYm)(a.vnode.el,E):(0,Pt.MLh)(window,"resize",E),(0,Pt.wYm)(a.refs.tableInnerWrapper,()=>{var e,t;E(),null==(t=null==(e=a.refs)?void 0:e.scrollBarRef)||t.update()}))},E=()=>{var t,l,n,o;const c=a.vnode.el;if(!a.$ready||!c)return;let r=!1;const{width:s,height:i,headerHeight:d}=u.value,f=p.value=c.offsetWidth;s!==f&&(r=!0);const y=c.offsetHeight;(e.height||w.value)&&i!==y&&(r=!0);const C="fixed"===e.tableLayout?a.refs.headerWrapper:null==(t=a.refs.tableHeaderRef)?void 0:t.$el;e.showHeader&&(null==C?void 0:C.offsetHeight)!==d&&(r=!0),m.value=(null==(l=a.refs.tableWrapper)?void 0:l.scrollHeight)||0,h.value=(null==C?void 0:C.scrollHeight)||0,g.value=(null==(n=a.refs.footerWrapper)?void 0:n.offsetHeight)||0,b.value=(null==(o=a.refs.appendWrapper)?void 0:o.offsetHeight)||0,v.value=m.value-h.value-g.value-b.value,r&&(u.value={width:f,height:y,headerHeight:e.showHeader&&(null==C?void 0:C.offsetHeight)||0},x())},A=(0,$t.NV)(),N=(0,n.EW)(()=>{const{bodyWidth:e,scrollY:l,gutterWidth:n}=t;return e.value?e.value-(l.value?n:0)+"px":""}),_=(0,n.EW)(()=>e.maxHeight?"fixed":e.tableLayout),T=(0,n.EW)(()=>{if(e.data&&e.data.length)return;let t="100%";e.height&&v.value&&(t=`${v.value}px`);const l=p.value;return{width:l?`${l}px`:"",height:t}}),O=(0,n.EW)(()=>e.height?{height:"100%"}:e.maxHeight?Number.isNaN(Number(e.maxHeight))?{maxHeight:`calc(${e.maxHeight} - ${h.value+g.value}px)`}:{maxHeight:+e.maxHeight-h.value-g.value+"px"}:{});return{isHidden:o,renderExpanded:c,setDragVisible:i,isGroup:d,handleMouseLeave:y,handleHeaderFooterMousewheel:C,tableSize:A,emptyBlockStyle:T,resizeProxyVisible:r,bodyWidth:N,resizeState:u,doLayout:x,tableBodyStyles:L,tableLayout:_,scrollbarViewStyle:f,scrollbarStyle:O}}function jt(e){const t=(0,s.KR)(),l=()=>{const l=e.vnode.el,n=l.querySelector(".hidden-columns"),a={childList:!0,subtree:!0},o=e.store.states.updateOrderFns;t.value=new MutationObserver(()=>{o.forEach(e=>e())}),t.value.observe(n,a)};(0,n.sV)(()=>{l()}),(0,n.hi)(()=>{var e;null==(e=t.value)||e.disconnect()})}var Kt=l(3845),Xt={data:{type:Array,default:()=>[]},size:Kt.mU,width:[String,Number],height:[String,Number],maxHeight:[String,Number],fit:{type:Boolean,default:!0},stripe:Boolean,border:Boolean,rowKey:[String,Function],showHeader:{type:Boolean,default:!0},showSummary:Boolean,sumText:String,summaryMethod:Function,rowClassName:[String,Function],rowStyle:[Object,Function],cellClassName:[String,Function],cellStyle:[Object,Function],headerRowClassName:[String,Function],headerRowStyle:[Object,Function],headerCellClassName:[String,Function],headerCellStyle:[Object,Function],highlightCurrentRow:Boolean,currentRowKey:[String,Number],emptyText:String,expandRowKeys:Array,defaultExpandAll:Boolean,defaultSort:Object,tooltipEffect:String,tooltipOptions:Object,spanMethod:Function,selectOnIndeterminate:{type:Boolean,default:!0},indent:{type:Number,default:16},treeProps:{type:Object,default:()=>({hasChildren:"hasChildren",children:"children",checkStrictly:!1})},lazy:Boolean,load:Function,style:{type:[String,Object,Array],default:()=>({})},className:{type:String,default:""},tableLayout:{type:String,default:"fixed"},scrollbarAlwaysOn:Boolean,flexible:Boolean,showOverflowTooltip:[Boolean,Object],tooltipFormatter:Function,appendFilterPanelTo:String,scrollbarTabindex:{type:[Number,String],default:void 0},allowDragLastColumn:{type:Boolean,default:!0},preserveExpandedContent:Boolean,nativeScrollbar:Boolean};l(1148);function Ut(e){const t="auto"===e.tableLayout;let l=e.columns||[];t&&l.every(({width:e})=>(0,ge.b0)(e))&&(l=[]);const a=l=>{const n={key:`${e.tableLayout}_${l.id}`,style:{},name:void 0};return t?n.style={width:`${l.width}px`}:n.name=l.id,n};return(0,n.h)("colgroup",{},l.map(e=>(0,n.h)("col",a(e))))}Ut.props=["columns","tableLayout"];const qt=()=>{const e=(0,s.KR)(),t=(t,l)=>{const n=e.value;n&&n.scrollTo(t,l)},l=(t,l)=>{const n=e.value;n&&(0,ge.Et)(l)&&["Top","Left"].includes(t)&&n[`setScroll${t}`](l)},n=e=>l("Top",e),a=e=>l("Left",e);return{scrollBarRef:e,scrollTo:t,setScrollTop:n,setScrollLeft:a}};var Gt,Yt,Qt,Zt,Jt,el,tl,ll,nl,al,ol,cl,rl,sl,il,ul=!1;function dl(){if(!ul){ul=!0;var e=navigator.userAgent,t=/(?:MSIE.(\d+\.\d+))|(?:(?:Firefox|GranParadiso|Iceweasel).(\d+\.\d+))|(?:Opera(?:.+Version.|.)(\d+\.\d+))|(?:AppleWebKit.(\d+(?:\.\d+)?))|(?:Trident\/\d+\.\d+.*rv:(\d+\.\d+))/.exec(e),l=/(Mac OS X)|(Windows)|(Linux)/.exec(e);if(cl=/\b(iPhone|iP[ao]d)/.exec(e),rl=/\b(iP[ao]d)/.exec(e),al=/Android/i.exec(e),sl=/FBAN\/\w+;/i.exec(e),il=/Mobile/i.exec(e),ol=!!/Win64/.exec(e),t){Gt=t[1]?parseFloat(t[1]):t[5]?parseFloat(t[5]):NaN,Gt&&document&&document.documentMode&&(Gt=document.documentMode);var n=/(?:Trident\/(\d+.\d+))/.exec(e);el=n?parseFloat(n[1])+4:Gt,Yt=t[2]?parseFloat(t[2]):NaN,Qt=t[3]?parseFloat(t[3]):NaN,Zt=t[4]?parseFloat(t[4]):NaN,Zt?(t=/(?:Chrome\/(\d+\.\d+))/.exec(e),Jt=t&&t[1]?parseFloat(t[1]):NaN):Jt=NaN}else Gt=Yt=Qt=Jt=Zt=NaN;if(l){if(l[1]){var a=/(?:Mac OS X (\d+(?:[._]\d+)?))/.exec(e);tl=!a||parseFloat(a[1].replace("_","."))}else tl=!1;ll=!!l[2],nl=!!l[3]}else tl=ll=nl=!1}}var fl,pl={ie:function(){return dl()||Gt},ieCompatibilityMode:function(){return dl()||el>Gt},ie64:function(){return pl.ie()&&ol},firefox:function(){return dl()||Yt},opera:function(){return dl()||Qt},webkit:function(){return dl()||Zt},safari:function(){return pl.webkit()},chrome:function(){return dl()||Jt},windows:function(){return dl()||ll},osx:function(){return dl()||tl},linux:function(){return dl()||nl},iphone:function(){return dl()||cl},mobile:function(){return dl()||cl||rl||al||il},nativeApp:function(){return dl()||sl},android:function(){return dl()||al},ipad:function(){return dl()||rl}},ml=pl,vl=!!(typeof window<"u"&&window.document&&window.document.createElement),hl={canUseDOM:vl,canUseWorkers:typeof Worker<"u",canUseEventListeners:vl&&!(!window.addEventListener&&!window.attachEvent),canUseViewport:vl&&!!window.screen,isInWorker:!vl},gl=hl;function bl(e,t){if(!gl.canUseDOM||t&&!("addEventListener"in document))return!1;var l="on"+e,n=l in document;if(!n){var a=document.createElement("div");a.setAttribute(l,"return;"),n="function"==typeof a[l]}return!n&&fl&&"wheel"===e&&(n=document.implementation.hasFeature("Events.wheel","3.0")),n}gl.canUseDOM&&(fl=document.implementation&&document.implementation.hasFeature&&!0!==document.implementation.hasFeature("",""));var yl=bl,Cl=10,wl=40,Ll=800;function xl(e){var t=0,l=0,n=0,a=0;return"detail"in e&&(l=e.detail),"wheelDelta"in e&&(l=-e.wheelDelta/120),"wheelDeltaY"in e&&(l=-e.wheelDeltaY/120),"wheelDeltaX"in e&&(t=-e.wheelDeltaX/120),"axis"in e&&e.axis===e.HORIZONTAL_AXIS&&(t=l,l=0),n=t*Cl,a=l*Cl,"deltaY"in e&&(a=e.deltaY),"deltaX"in e&&(n=e.deltaX),(n||a)&&e.deltaMode&&(1==e.deltaMode?(n*=wl,a*=wl):(n*=Ll,a*=Ll)),n&&!t&&(t=n<1?-1:1),a&&!l&&(l=a<1?-1:1),{spinX:t,spinY:l,pixelX:n,pixelY:a}}xl.getEventType=function(){return ml.firefox()?"DOMMouseScroll":yl("wheel")?"wheel":"mousewheel"};var Ml=xl; +let c;const r="undefined"!==typeof window&&window.trustedTypes;if(r)try{c=r.createPolicy("vue",{createHTML:e=>e})}catch(Ke){}const s=c?e=>c.createHTML(e):e=>e,i="http://www.w3.org/2000/svg",u="http://www.w3.org/1998/Math/MathML",d="undefined"!==typeof document?document:null,f=d&&d.createElement("template"),p={insert:(e,t,l)=>{t.insertBefore(e,l||null)},remove:e=>{const t=e.parentNode;t&&t.removeChild(e)},createElement:(e,t,l,n)=>{const a="svg"===t?d.createElementNS(i,e):"mathml"===t?d.createElementNS(u,e):l?d.createElement(e,{is:l}):d.createElement(e);return"select"===e&&n&&null!=n.multiple&&a.setAttribute("multiple",n.multiple),a},createText:e=>d.createTextNode(e),createComment:e=>d.createComment(e),setText:(e,t)=>{e.nodeValue=t},setElementText:(e,t)=>{e.textContent=t},parentNode:e=>e.parentNode,nextSibling:e=>e.nextSibling,querySelector:e=>d.querySelector(e),setScopeId(e,t){e.setAttribute(t,"")},insertStaticContent(e,t,l,n,a,o){const c=l?l.previousSibling:t.lastChild;if(a&&(a===o||a.nextSibling)){while(1)if(t.insertBefore(a.cloneNode(!0),l),a===o||!(a=a.nextSibling))break}else{f.innerHTML=s("svg"===n?`${e}`:"mathml"===n?`${e}`:e);const a=f.content;if("svg"===n||"mathml"===n){const e=a.firstChild;while(e.firstChild)a.appendChild(e.firstChild);a.removeChild(e)}t.insertBefore(a,l)}return[c?c.nextSibling:t.firstChild,l?l.previousSibling:t.lastChild]}},m="transition",v="animation",h=Symbol("_vtc"),g={name:String,type:String,css:{type:Boolean,default:!0},duration:[String,Number,Object],enterFromClass:String,enterActiveClass:String,enterToClass:String,appearFromClass:String,appearActiveClass:String,appearToClass:String,leaveFromClass:String,leaveActiveClass:String,leaveToClass:String},b=(0,a.X$)({},n.QP,g),y=e=>(e.displayName="Transition",e.props=b,e),C=y((e,{slots:t})=>(0,n.h)(n.pR,x(e),t)),w=(e,t=[])=>{(0,a.cy)(e)?e.forEach(e=>e(...t)):e&&e(...t)},L=e=>!!e&&((0,a.cy)(e)?e.some(e=>e.length>1):e.length>1);function x(e){const t={};for(const a in e)a in g||(t[a]=e[a]);if(!1===e.css)return t;const{name:l="v",type:n,duration:o,enterFromClass:c=`${l}-enter-from`,enterActiveClass:r=`${l}-enter-active`,enterToClass:s=`${l}-enter-to`,appearFromClass:i=c,appearActiveClass:u=r,appearToClass:d=s,leaveFromClass:f=`${l}-leave-from`,leaveActiveClass:p=`${l}-leave-active`,leaveToClass:m=`${l}-leave-to`}=e,v=M(o),h=v&&v[0],b=v&&v[1],{onBeforeEnter:y,onEnter:C,onEnterCancelled:x,onLeave:z,onLeaveCancelled:E,onBeforeAppear:N=y,onAppear:_=C,onAppearCancelled:T=x}=t,W=(e,t,l,n)=>{e._enterCancelled=n,k(e,t?d:s),k(e,t?u:r),l&&l()},B=(e,t)=>{e._isLeaving=!1,k(e,f),k(e,m),k(e,p),t&&t()},I=e=>(t,l)=>{const a=e?_:C,o=()=>W(t,e,l);w(a,[t,o]),S(()=>{k(t,e?i:c),R(t,e?d:s),L(a)||A(t,n,h,o)})};return(0,a.X$)(t,{onBeforeEnter(e){w(y,[e]),R(e,c),R(e,r)},onBeforeAppear(e){w(N,[e]),R(e,i),R(e,u)},onEnter:I(!1),onAppear:I(!0),onLeave(e,t){e._isLeaving=!0;const l=()=>B(e,t);R(e,f),e._enterCancelled?(R(e,p),O(e)):(O(e),R(e,p)),S(()=>{e._isLeaving&&(k(e,f),R(e,m),L(z)||A(e,n,b,l))}),w(z,[e,l])},onEnterCancelled(e){W(e,!1,void 0,!0),w(x,[e])},onAppearCancelled(e){W(e,!0,void 0,!0),w(T,[e])},onLeaveCancelled(e){B(e),w(E,[e])}})}function M(e){if(null==e)return null;if((0,a.Gv)(e))return[z(e.enter),z(e.leave)];{const t=z(e);return[t,t]}}function z(e){const t=(0,a.Ro)(e);return t}function R(e,t){t.split(/\s+/).forEach(t=>t&&e.classList.add(t)),(e[h]||(e[h]=new Set)).add(t)}function k(e,t){t.split(/\s+/).forEach(t=>t&&e.classList.remove(t));const l=e[h];l&&(l.delete(t),l.size||(e[h]=void 0))}function S(e){requestAnimationFrame(()=>{requestAnimationFrame(e)})}let E=0;function A(e,t,l,n){const a=e._endId=++E,o=()=>{a===e._endId&&n()};if(null!=l)return setTimeout(o,l);const{type:c,timeout:r,propCount:s}=N(e,t);if(!c)return n();const i=c+"end";let u=0;const d=()=>{e.removeEventListener(i,f),o()},f=t=>{t.target===e&&++u>=s&&d()};setTimeout(()=>{u(l[e]||"").split(", "),a=n(`${m}Delay`),o=n(`${m}Duration`),c=_(a,o),r=n(`${v}Delay`),s=n(`${v}Duration`),i=_(r,s);let u=null,d=0,f=0;t===m?c>0&&(u=m,d=c,f=o.length):t===v?i>0&&(u=v,d=i,f=s.length):(d=Math.max(c,i),u=d>0?c>i?m:v:null,f=u?u===m?o.length:s.length:0);const p=u===m&&/\b(?:transform|all)(?:,|$)/.test(n(`${m}Property`).toString());return{type:u,timeout:d,propCount:f,hasTransform:p}}function _(e,t){while(e.lengthT(t)+T(e[l])))}function T(e){return"auto"===e?0:1e3*Number(e.slice(0,-1).replace(",","."))}function O(e){const t=e?e.ownerDocument:document;return t.body.offsetHeight}function W(e,t,l){const n=e[h];n&&(t=(t?[t,...n]:[...n]).join(" ")),null==t?e.removeAttribute("class"):l?e.setAttribute("class",t):e.className=t}const B=Symbol("_vod"),I=Symbol("_vsh"),D={name:"show",beforeMount(e,{value:t},{transition:l}){e[B]="none"===e.style.display?"":e.style.display,l&&t?l.beforeEnter(e):F(e,t)},mounted(e,{value:t},{transition:l}){l&&t&&l.enter(e)},updated(e,{value:t,oldValue:l},{transition:n}){!t!==!l&&(n?t?(n.beforeEnter(e),F(e,!0),n.enter(e)):n.leave(e,()=>{F(e,!1)}):F(e,t))},beforeUnmount(e,{value:t}){F(e,t)}};function F(e,t){e.style.display=t?e[B]:"none",e[I]=!t}const V=Symbol("");const P=/(?:^|;)\s*display\s*:/;function $(e,t,l){const n=e.style,o=(0,a.Kg)(l);let c=!1;if(l&&!o){if(t)if((0,a.Kg)(t))for(const e of t.split(";")){const t=e.slice(0,e.indexOf(":")).trim();null==l[t]&&j(n,t,"")}else for(const e in t)null==l[e]&&j(n,e,"");for(const e in l)"display"===e&&(c=!0),j(n,e,l[e])}else if(o){if(t!==l){const e=n[V];e&&(l+=";"+e),n.cssText=l,c=P.test(l)}}else t&&e.removeAttribute("style");B in e&&(e[B]=c?n.display:"",e[I]&&(n.display="none"))}const H=/\s*!important$/;function j(e,t,l){if((0,a.cy)(l))l.forEach(l=>j(e,t,l));else if(null==l&&(l=""),t.startsWith("--"))e.setProperty(t,l);else{const n=U(e,t);H.test(l)?e.setProperty((0,a.Tg)(n),l.replace(H,""),"important"):e[n]=l}}const K=["Webkit","Moz","ms"],X={};function U(e,t){const l=X[t];if(l)return l;let n=(0,a.PT)(t);if("filter"!==n&&n in e)return X[t]=n;n=(0,a.ZH)(n);for(let a=0;ane||(ae.then(()=>ne=0),ne=Date.now());function ce(e,t){const l=e=>{if(e._vts){if(e._vts<=l.attached)return}else e._vts=Date.now();(0,n.qL)(re(e,l.value),t,5,[e])};return l.value=e,l.attached=oe(),l}function re(e,t){if((0,a.cy)(t)){const l=e.stopImmediatePropagation;return e.stopImmediatePropagation=()=>{l.call(e),e._stopped=!0},t.map(e=>t=>!t._stopped&&e&&e(t))}return t}const se=e=>111===e.charCodeAt(0)&&110===e.charCodeAt(1)&&e.charCodeAt(2)>96&&e.charCodeAt(2)<123,ie=(e,t,l,n,o,c)=>{const r="svg"===o;"class"===t?W(e,n,r):"style"===t?$(e,l,n):(0,a.Mp)(t)?(0,a.CP)(t)||ee(e,t,l,n,c):("."===t[0]?(t=t.slice(1),1):"^"===t[0]?(t=t.slice(1),0):ue(e,t,n,r))?(Y(e,t,n),e.tagName.includes("-")||"value"!==t&&"checked"!==t&&"selected"!==t||G(e,t,n,r,c,"value"!==t)):!e._isVueCE||!/[A-Z]/.test(t)&&(0,a.Kg)(n)?("true-value"===t?e._trueValue=n:"false-value"===t&&(e._falseValue=n),G(e,t,n,r)):Y(e,(0,a.PT)(t),n,c,t)};function ue(e,t,l,n){if(n)return"innerHTML"===t||"textContent"===t||!!(t in e&&se(t)&&(0,a.Tn)(l));if("spellcheck"===t||"draggable"===t||"translate"===t||"autocorrect"===t)return!1;if("sandbox"===t&&"IFRAME"===e.tagName)return!1;if("form"===t)return!1;if("list"===t&&"INPUT"===e.tagName)return!1;if("type"===t&&"TEXTAREA"===e.tagName)return!1;if("width"===t||"height"===t){const t=e.tagName;if("IMG"===t||"VIDEO"===t||"CANVAS"===t||"SOURCE"===t)return!1}return(!se(t)||!(0,a.Kg)(l))&&t in e}"undefined"!==typeof HTMLElement&&HTMLElement;const de=new WeakMap,fe=new WeakMap,pe=Symbol("_moveCb"),me=Symbol("_enterCb"),ve=e=>(delete e.props.mode,e),he=ve({name:"TransitionGroup",props:(0,a.X$)({},b,{tag:String,moveClass:String}),setup(e,{slots:t}){const l=(0,n.nI)(),a=(0,n.Gy)();let c,r;return(0,n.$u)(()=>{if(!c.length)return;const t=e.moveClass||`${e.name||"v"}-move`;if(!we(c[0].el,l.vnode.el,t))return void(c=[]);c.forEach(be),c.forEach(ye);const n=c.filter(Ce);O(l.vnode.el),n.forEach(e=>{const l=e.el,n=l.style;R(l,t),n.transform=n.webkitTransform=n.transitionDuration="";const a=l[pe]=e=>{e&&e.target!==l||e&&!e.propertyName.endsWith("transform")||(l.removeEventListener("transitionend",a),l[pe]=null,k(l,t))};l.addEventListener("transitionend",a)}),c=[]}),()=>{const s=(0,o.ux)(e),i=x(s);let u=s.tag||n.FK;if(c=[],r)for(let e=0;e{e.split(/\s+/).forEach(e=>e&&n.classList.remove(e))}),l.split(/\s+/).forEach(e=>e&&n.classList.add(e)),n.style.display="none";const o=1===t.nodeType?t:t.parentNode;o.appendChild(n);const{hasTransform:c}=N(n);return o.removeChild(n),c}const Le=e=>{const t=e.props["onUpdate:modelValue"]||!1;return(0,a.cy)(t)?e=>(0,a.DY)(t,e):t};function xe(e){e.target.composing=!0}function Me(e){const t=e.target;t.composing&&(t.composing=!1,t.dispatchEvent(new Event("input")))}const ze=Symbol("_assign");function Re(e,t,l){return t&&(e=e.trim()),l&&(e=(0,a.bB)(e)),e}const ke={created(e,{modifiers:{lazy:t,trim:l,number:n}},a){e[ze]=Le(a);const o=n||a.props&&"number"===a.props.type;Q(e,t?"change":"input",t=>{t.target.composing||e[ze](Re(e.value,l,o))}),(l||o)&&Q(e,"change",()=>{e.value=Re(e.value,l,o)}),t||(Q(e,"compositionstart",xe),Q(e,"compositionend",Me),Q(e,"change",Me))},mounted(e,{value:t}){e.value=null==t?"":t},beforeUpdate(e,{value:t,oldValue:l,modifiers:{lazy:n,trim:o,number:c}},r){if(e[ze]=Le(r),e.composing)return;const s=!c&&"number"!==e.type||/^0\d/.test(e.value)?e.value:(0,a.bB)(e.value),i=null==t?"":t;if(s!==i){if(document.activeElement===e&&"range"!==e.type){if(n&&t===l)return;if(o&&e.value.trim()===i)return}e.value=i}}},Se={deep:!0,created(e,t,l){e[ze]=Le(l),Q(e,"change",()=>{const t=e._modelValue,l=Ne(e),n=e.checked,o=e[ze];if((0,a.cy)(t)){const e=(0,a.u3)(t,l),c=-1!==e;if(n&&!c)o(t.concat(l));else if(!n&&c){const l=[...t];l.splice(e,1),o(l)}}else if((0,a.vM)(t)){const e=new Set(t);n?e.add(l):e.delete(l),o(e)}else o(_e(e,n))})},mounted:Ee,beforeUpdate(e,t,l){e[ze]=Le(l),Ee(e,t,l)}};function Ee(e,{value:t,oldValue:l},n){let o;if(e._modelValue=t,(0,a.cy)(t))o=(0,a.u3)(t,n.props.value)>-1;else if((0,a.vM)(t))o=t.has(n.props.value);else{if(t===l)return;o=(0,a.BX)(t,_e(e,!0))}e.checked!==o&&(e.checked=o)}const Ae={created(e,{value:t},l){e.checked=(0,a.BX)(t,l.props.value),e[ze]=Le(l),Q(e,"change",()=>{e[ze](Ne(e))})},beforeUpdate(e,{value:t,oldValue:l},n){e[ze]=Le(n),t!==l&&(e.checked=(0,a.BX)(t,n.props.value))}};function Ne(e){return"_value"in e?e._value:e.value}function _e(e,t){const l=t?"_trueValue":"_falseValue";return l in e?e[l]:t}const Te=["ctrl","shift","alt","meta"],Oe={stop:e=>e.stopPropagation(),prevent:e=>e.preventDefault(),self:e=>e.target!==e.currentTarget,ctrl:e=>!e.ctrlKey,shift:e=>!e.shiftKey,alt:e=>!e.altKey,meta:e=>!e.metaKey,left:e=>"button"in e&&0!==e.button,middle:e=>"button"in e&&1!==e.button,right:e=>"button"in e&&2!==e.button,exact:(e,t)=>Te.some(l=>e[`${l}Key`]&&!t.includes(l))},We=(e,t)=>{const l=e._withMods||(e._withMods={}),n=t.join(".");return l[n]||(l[n]=(l,...n)=>{for(let e=0;e{const l=e._withKeys||(e._withKeys={}),n=t.join(".");return l[n]||(l[n]=l=>{if(!("key"in l))return;const n=(0,a.Tg)(l.key);return t.some(e=>e===n||Be[e]===n)?e(l):void 0})},De=(0,a.X$)({patchProp:ie},p);let Fe;function Ve(){return Fe||(Fe=(0,n.K9)(De))}const Pe=(...e)=>{Ve().render(...e)},$e=(...e)=>{const t=Ve().createApp(...e);const{mount:l}=t;return t.mount=e=>{const n=je(e);if(!n)return;const o=t._component;(0,a.Tn)(o)||o.render||o.template||(o.template=n.innerHTML),1===n.nodeType&&(n.textContent="");const c=l(n,!1,He(n));return n instanceof Element&&(n.removeAttribute("v-cloak"),n.setAttribute("data-v-app","")),c},t};function He(e){return e instanceof SVGElement?"svg":"function"===typeof MathMLElement&&e instanceof MathMLElement?"mathml":void 0}function je(e){if((0,a.Kg)(e)){const t=document.querySelector(e);return t}return e}},5131:function(e,t,l){"use strict";l(8111),l(2489),l(7588),l(1701),l(8237),l(3110),l(8335);var n=function(e){return function(e){return!!e&&"object"==typeof e}(e)&&!function(e){var t=Object.prototype.toString.call(e);return"[object RegExp]"===t||"[object Date]"===t||function(e){return e.$$typeof===a}(e)}(e)},a="function"==typeof Symbol&&Symbol.for?Symbol.for("react.element"):60103;function o(e,t){return!1!==t.clone&&t.isMergeableObject(e)?i(Array.isArray(e)?[]:{},e,t):e}function c(e,t,l){return e.concat(t).map(function(e){return o(e,l)})}function r(e){return Object.keys(e).concat(function(e){return Object.getOwnPropertySymbols?Object.getOwnPropertySymbols(e).filter(function(t){return e.propertyIsEnumerable(t)}):[]}(e))}function s(e,t){try{return t in e}catch(e){return!1}}function i(e,t,l){(l=l||{}).arrayMerge=l.arrayMerge||c,l.isMergeableObject=l.isMergeableObject||n,l.cloneUnlessOtherwiseSpecified=o;var a=Array.isArray(t);return a===Array.isArray(e)?a?l.arrayMerge(e,t,l):function(e,t,l){var n={};return l.isMergeableObject(e)&&r(e).forEach(function(t){n[t]=o(e[t],l)}),r(t).forEach(function(a){(function(e,t){return s(e,t)&&!(Object.hasOwnProperty.call(e,t)&&Object.propertyIsEnumerable.call(e,t))})(e,a)||(n[a]=s(e,a)&&l.isMergeableObject(t[a])?function(e,t){if(!t.customMerge)return i;var l=t.customMerge(e);return"function"==typeof l?l:i}(a,l)(e[a],t[a],l):o(t[a],l))}),n}(e,t,l):o(t,l)}i.all=function(e,t){if(!Array.isArray(e))throw new Error("first argument should be an array");return e.reduce(function(e,l){return i(e,l,t)},{})};var u=i;function d(e){var t=(e=e||{}).storage||window&&window.localStorage,l=e.key||"vuex";function n(e,t){var l=t.getItem(e);try{return"string"==typeof l?JSON.parse(l):"object"==typeof l?l:void 0}catch(e){}}function a(){return!0}function o(e,t,l){return l.setItem(e,JSON.stringify(t))}function c(e,t){return Array.isArray(t)?t.reduce(function(t,l){return function(e,t,l){return!/^(__proto__|constructor|prototype)$/.test(t)&&((t=t.split?t.split("."):t.slice(0)).slice(0,-1).reduce(function(e,t){return e[t]=e[t]||{}},e)[t.pop()]=l),e}(t,l,(n=e,void 0===(n=((a=l).split?a.split("."):a).reduce(function(e,t){return e&&e[t]},n))?void 0:n));var n,a},{}):e}function r(e){return function(t){return e.subscribe(t)}}(e.assertStorage||function(){t.setItem("@@",1),t.removeItem("@@")})(t);var s,i=function(){return(e.getState||n)(l,t)};return e.fetchBeforeUse&&(s=i()),function(n){e.fetchBeforeUse||(s=i()),"object"==typeof s&&null!==s&&(n.replaceState(e.overwrite?s:u(n.state,s,{arrayMerge:e.arrayMerger||function(e,t){return t},clone:!1})),(e.rehydrated||function(){})(n)),(e.subscriber||r)(n)(function(n,r){(e.filter||a)(n)&&(e.setState||o)(l,(e.reducer||c)(r,e.paths),t)})}}t.A=d},5169:function(e,t,l){"use strict";var n=l(3238),a=TypeError;e.exports=function(e){if(n(e))throw new a("ArrayBuffer is detached");return e}},5170:function(e,t,l){"use strict";var n=l(6706),a=l(4402);e.exports=n(a.proto,"size","get")||function(e){return e.size}},5318:function(e,t,l){"use strict";l.d(t,{A:function(){return p}});l(4114);function n(e,t){var l=-1,n=Array(e);while(++l-1&&e%1==0&&e<=l}t.A=n},5376:function(e,t,l){"use strict";l.d(t,{GU:function(){return a},PZ:function(){return c},WM:function(){return r},_u:function(){return o}});var n=l(4232);const a=(e,t)=>{if(e.install=l=>{for(const n of[e,...Object.values(null!=t?t:{})])l.component(n.name,n)},t)for(const[l,n]of Object.entries(t))e[l]=n;return e},o=(e,t)=>(e.install=l=>{e._context=l._context,l.config.globalProperties[t]=e},e),c=(e,t)=>(e.install=l=>{l.directive(t,e)},e),r=e=>(e.install=n.tE,e)},5397:function(e,t,l){"use strict";var n=l(7055),a=l(7750);e.exports=function(e){return n(a(e))}},5407:function(e,t,l){"use strict";l.d(t,{z_:function(){return g}});var n=l(6768),a=l(4232),o=l(144),c=l(5130),r=l(7378);const s=(0,r.b_)({value:{type:[String,Number],default:""},max:{type:Number,default:99},isDot:Boolean,hidden:Boolean,type:{type:String,values:["primary","success","warning","info","danger"],default:"danger"},showZero:{type:Boolean,default:!0},color:String,badgeStyle:{type:(0,r.jq)([String,Object,Array])},offset:{type:(0,r.jq)(Array),default:[0,0]},badgeClass:{type:String}});var i=l(9077),u=l(3513),d=l(2235),f=l(3558);const p=(0,n.pM)({name:"ElBadge"}),m=(0,n.pM)({...p,props:s,setup(e,{expose:t}){const l=e,r=(0,u.DU)("badge"),s=(0,n.EW)(()=>l.isDot?"":(0,d.Et)(l.value)&&(0,d.Et)(l.max)&&l.max{var e;return[{backgroundColor:l.color,marginRight:(0,f._V)(-l.offset[0]),marginTop:(0,f._V)(l.offset[1])},null!=(e=l.badgeStyle)?e:{}]});return t({content:s}),(e,t)=>((0,n.uX)(),(0,n.CE)("div",{class:(0,a.C4)((0,o.R1)(r).b())},[(0,n.RG)(e.$slots,"default"),(0,n.bF)(c.eB,{name:`${(0,o.R1)(r).namespace.value}-zoom-in-center`,persisted:""},{default:(0,n.k6)(()=>[(0,n.bo)((0,n.Lk)("sup",{class:(0,a.C4)([(0,o.R1)(r).e("content"),(0,o.R1)(r).em("content",e.type),(0,o.R1)(r).is("fixed",!!e.$slots.default),(0,o.R1)(r).is("dot",e.isDot),(0,o.R1)(r).is("hide-zero",!e.showZero&&0===e.value),e.badgeClass]),style:(0,a.Tr)((0,o.R1)(i))},[(0,n.RG)(e.$slots,"content",{value:(0,o.R1)(s)},()=>[(0,n.eW)((0,a.v_)((0,o.R1)(s)),1)])],6),[[c.aG,!e.hidden&&((0,o.R1)(s)||e.isDot||e.$slots.content)]])]),_:3},8,["name"])],2))}});var v=(0,i.A)(m,[["__file","badge.vue"]]),h=l(5376);const g=(0,h.GU)(v)},5412:function(e,t,l){"use strict";l(5331),l(2099)},5420:function(e,t,l){"use strict";l.d(t,{M:function(){return i},m:function(){return s}});var n=l(144),a=l(17);function o(){let e;const t=(t,n)=>{l(),e=window.setTimeout(t,n)},l=()=>window.clearTimeout(e);return(0,a.Uo)(()=>l()),{registerTimeout:t,cancelTimeout:l}}var c=l(7378),r=l(2235);const s=(0,c.b_)({showAfter:{type:Number,default:0},hideAfter:{type:Number,default:200},autoClose:{type:Number,default:0}}),i=({showAfter:e,hideAfter:t,autoClose:l,open:a,close:c})=>{const{registerTimeout:s}=o(),{registerTimeout:i,cancelTimeout:u}=o(),d=(t,o=(0,n.R1)(e))=>{s(()=>{a(t);const e=(0,n.R1)(l);(0,r.Et)(e)&&e>0&&i(()=>{c(t)},e)},o)},f=(e,l=(0,n.R1)(t))=>{u(),s(()=>{c(e)},l)};return{onOpen:d,onClose:f}}},5431:function(e,t,l){"use strict";l.d(t,{V:function(){return o},m:function(){return a}});var n=l(17);const a=e=>n.oc?window.requestAnimationFrame(e):setTimeout(e,16),o=e=>n.oc?window.cancelAnimationFrame(e):clearTimeout(e)},5445:function(e,t,l){"use strict";l.d(t,{A:function(){return f}});var n=l(6768),a=l(144),o=l(5130),c=l(8114),r=l(3558);function s(e,t){let l;const s=(0,a.KR)(!1),i=(0,a.Kh)({...e,originalPosition:"",originalOverflow:"",visible:!1});function u(e){i.text=e}function d(){const e=i.parent,t=g.ns;if(!e.vLoadingAddClassList){let l=e.getAttribute("loading-number");l=Number.parseInt(l)-1,l?e.setAttribute("loading-number",l.toString()):((0,r.vy)(e,t.bm("parent","relative")),e.removeAttribute("loading-number")),(0,r.vy)(e,t.bm("parent","hidden"))}f(),h.unmount()}function f(){var e,t;null==(t=null==(e=g.$el)?void 0:e.parentNode)||t.removeChild(g.$el)}function p(){var t;e.beforeClose&&!e.beforeClose()||(s.value=!0,clearTimeout(l),l=setTimeout(m,400),i.visible=!1,null==(t=e.closed)||t.call(e))}function m(){if(!s.value)return;const e=i.parent;s.value=!1,e.vLoadingAddClassList=void 0,d()}const v=(0,n.pM)({name:"ElLoading",setup(e,{expose:t}){const{ns:l,zIndex:a}=(0,c.ht)("loading");return t({ns:l,zIndex:a}),()=>{const e=i.spinner||i.svg,t=(0,n.h)("svg",{class:"circular",viewBox:i.svgViewBox?i.svgViewBox:"0 0 50 50",...e?{innerHTML:e}:{}},[(0,n.h)("circle",{class:"path",cx:"25",cy:"25",r:"20",fill:"none"})]),a=i.text?(0,n.h)("p",{class:l.b("text")},[i.text]):void 0;return(0,n.h)(o.eB,{name:l.b("fade"),onAfterLeave:m},{default:(0,n.k6)(()=>[(0,n.bo)((0,n.bF)("div",{style:{backgroundColor:i.background||""},class:[l.b("mask"),i.customClass,l.is("fullscreen",i.fullscreen)]},[(0,n.h)("div",{class:l.b("spinner")},[t,a])]),[[o.aG,i.visible]])])})}}}),h=(0,o.Ef)(v);Object.assign(h._context,null!=t?t:{});const g=h.mount(document.createElement("div"));return{...(0,a.QW)(i),setText:u,removeElLoadingChild:f,close:p,handleAfterLeave:m,vm:g,get $el(){return g.$el}}}var i=l(17),u=l(4232);let d;const f=function(e={},t){if(!i.oc)return;const l=p(e);if(l.fullscreen&&d)return d;const a=s({...l,closed:()=>{var e;null==(e=l.closed)||e.call(l),l.fullscreen&&(d=void 0)}},null!=t?t:f._context);m(l,l.parent,a),v(l,l.parent,a),l.parent.vLoadingAddClassList=()=>v(l,l.parent,a);let o=l.parent.getAttribute("loading-number");return o=o?`${Number.parseInt(o)+1}`:"1",l.parent.setAttribute("loading-number",o),l.parent.appendChild(a.$el),(0,n.dY)(()=>a.visible.value=l.visible),l.fullscreen&&(d=a),a},p=e=>{var t,l,n,a;let o;return o=(0,u.Kg)(e.target)?null!=(t=document.querySelector(e.target))?t:document.body:e.target||document.body,{parent:o===document.body||e.body?document.body:o,background:e.background||"",svg:e.svg||"",svgViewBox:e.svgViewBox||"",spinner:e.spinner||!1,text:e.text||"",fullscreen:o===document.body&&(null==(l=e.fullscreen)||l),lock:null!=(n=e.lock)&&n,customClass:e.customClass||"",visible:null==(a=e.visible)||a,beforeClose:e.beforeClose,closed:e.closed,target:o}},m=async(e,t,l)=>{const{nextZIndex:a}=l.vm.zIndex||l.vm._.exposed.zIndex,o={};if(e.fullscreen)l.originalPosition.value=(0,r.gd)(document.body,"position"),l.originalOverflow.value=(0,r.gd)(document.body,"overflow"),o.zIndex=a();else if(e.parent===document.body){l.originalPosition.value=(0,r.gd)(document.body,"position"),await(0,n.dY)();for(const t of["top","left"]){const l="top"===t?"scrollTop":"scrollLeft";o[t]=e.target.getBoundingClientRect()[t]+document.body[l]+document.documentElement[l]-Number.parseInt((0,r.gd)(document.body,`margin-${t}`),10)+"px"}for(const t of["height","width"])o[t]=`${e.target.getBoundingClientRect()[t]}px`}else l.originalPosition.value=(0,r.gd)(t,"position");for(const[n,c]of Object.entries(o))l.$el.style[n]=c},v=(e,t,l)=>{const n=l.vm.ns||l.vm._.exposed.ns;["absolute","fixed","sticky"].includes(l.originalPosition.value)?(0,r.vy)(t,n.bm("parent","relative")):(0,r.iQ)(t,n.bm("parent","relative")),e.fullscreen&&e.lock?(0,r.iQ)(t,n.bm("parent","hidden")):(0,r.vy)(t,n.bm("parent","hidden"))};f._context=null},5454:function(e,t,l){"use strict";var n=l(4672),a=l(2132),o=l(6636);function c(e){return(0,n.A)(e,o.A,a.A)}t.A=c},5488:function(e,t,l){"use strict";l.d(t,{o:function(){return c}});var n=l(144),a=l(6768);const o=e=>/([\uAC00-\uD7AF\u3130-\u318F])+/gi.test(e);function c({afterComposition:e,emit:t}){const l=(0,n.KR)(!1),c=e=>{null==t||t("compositionstart",e),l.value=!0},r=e=>{var n;null==t||t("compositionupdate",e);const a=null==(n=e.target)?void 0:n.value,c=a[a.length-1]||"";l.value=!o(c)},s=n=>{null==t||t("compositionend",n),l.value&&(l.value=!1,(0,a.dY)(()=>e(n)))},i=e=>{"compositionend"===e.type?s(e):r(e)};return{isComposing:l,handleComposition:i,handleCompositionStart:c,handleCompositionUpdate:r,handleCompositionEnd:s}}},5513:function(e,t,l){"use strict";l.d(t,{Q:function(){return o},k:function(){return c}});var n=l(7378),a=l(464);const o=(0,n.b_)({center:Boolean,alignCenter:{type:Boolean,default:void 0},closeIcon:{type:a.Ze},draggable:{type:Boolean,default:void 0},overflow:{type:Boolean,default:void 0},fullscreen:Boolean,headerClass:String,bodyClass:String,footerClass:String,showClose:{type:Boolean,default:!0},title:{type:String,default:""},ariaLevel:{type:String,default:"2"}}),c={close:()=>!0}},5558:function(e,t,l){"use strict";l.d(t,{qi:function(){return S}});var n=l(6768),a=l(144),o=l(4232),c=l(5130),r=l(813),s=l(7477),i=l(3027),u=l(7378),d=l(464),f=l(8501),p=l(2056),m=l(2235);const v=(0,u.b_)({modelValue:{type:[Boolean,String,Number],default:!1},disabled:{type:Boolean,default:void 0},loading:Boolean,size:{type:String,validator:i.x},width:{type:[String,Number],default:""},inlinePrompt:Boolean,inactiveActionIcon:{type:d.Ze},activeActionIcon:{type:d.Ze},activeIcon:{type:d.Ze},inactiveIcon:{type:d.Ze},activeText:{type:String,default:""},inactiveText:{type:String,default:""},activeValue:{type:[Boolean,String,Number],default:!0},inactiveValue:{type:[Boolean,String,Number],default:!1},name:{type:String,default:""},validateEvent:{type:Boolean,default:!0},beforeChange:{type:(0,u.jq)(Function)},id:String,tabindex:{type:[String,Number]},...(0,f.l)(["ariaLabel"])}),h={[p.l4]:e=>(0,m.Lm)(e)||(0,o.Kg)(e)||(0,m.Et)(e),[p.YU]:e=>(0,m.Lm)(e)||(0,o.Kg)(e)||(0,m.Et)(e),[p.qs]:e=>(0,m.Lm)(e)||(0,o.Kg)(e)||(0,m.Et)(e)};var g=l(9077),b=l(4216),y=l(2436),C=l(3513),w=l(3558),L=l(6894);const x="ElSwitch",M=(0,n.pM)({name:x}),z=(0,n.pM)({...M,props:v,emits:h,setup(e,{expose:t,emit:l}){const i=e,{formItem:u}=(0,b.j)(),d=(0,y.NV)(),f=(0,C.DU)("switch"),{inputId:v}=(0,b.W)(i,{formItemContext:u}),h=(0,y.CB)((0,n.EW)(()=>{if(i.loading)return!0})),g=(0,a.KR)(!1!==i.modelValue),M=(0,a.IJ)(),z=(0,n.EW)(()=>[f.b(),f.m(d.value),f.is("disabled",h.value),f.is("checked",A.value)]),R=(0,n.EW)(()=>[f.e("label"),f.em("label","left"),f.is("active",!A.value)]),k=(0,n.EW)(()=>[f.e("label"),f.em("label","right"),f.is("active",A.value)]),S=(0,n.EW)(()=>({width:(0,w._V)(i.width)}));(0,n.wB)(()=>i.modelValue,()=>{g.value=!0});const E=(0,n.EW)(()=>!!g.value&&i.modelValue),A=(0,n.EW)(()=>E.value===i.activeValue);[i.activeValue,i.inactiveValue].includes(E.value)||(l(p.l4,i.inactiveValue),l(p.YU,i.inactiveValue),l(p.qs,i.inactiveValue)),(0,n.wB)(A,e=>{var t;M.value.checked=e,i.validateEvent&&(null==(t=null==u?void 0:u.validate)||t.call(u,"change").catch(e=>(0,L.U)(e)))});const N=()=>{const e=A.value?i.inactiveValue:i.activeValue;l(p.l4,e),l(p.YU,e),l(p.qs,e),(0,n.dY)(()=>{M.value.checked=A.value})},_=()=>{if(h.value)return;const{beforeChange:e}=i;if(!e)return void N();const t=e(),l=[(0,o.yL)(t),(0,m.Lm)(t)].includes(!0);l||(0,L.$)(x,"beforeChange must return type `Promise` or `boolean`"),(0,o.yL)(t)?t.then(e=>{e&&N()}).catch(e=>{(0,L.U)(x,`some error occurred: ${e}`)}):t&&N()},T=()=>{var e,t;null==(t=null==(e=M.value)?void 0:e.focus)||t.call(e)};return(0,n.sV)(()=>{M.value.checked=A.value}),t({focus:T,checked:A}),(e,t)=>((0,n.uX)(),(0,n.CE)("div",{class:(0,o.C4)((0,a.R1)(z)),onClick:(0,c.D$)(_,["prevent"])},[(0,n.Lk)("input",{id:(0,a.R1)(v),ref_key:"input",ref:M,class:(0,o.C4)((0,a.R1)(f).e("input")),type:"checkbox",role:"switch","aria-checked":(0,a.R1)(A),"aria-disabled":(0,a.R1)(h),"aria-label":e.ariaLabel,name:e.name,"true-value":e.activeValue,"false-value":e.inactiveValue,disabled:(0,a.R1)(h),tabindex:e.tabindex,onChange:N,onKeydown:(0,c.jR)(_,["enter"])},null,42,["id","aria-checked","aria-disabled","aria-label","name","true-value","false-value","disabled","tabindex","onKeydown"]),e.inlinePrompt||!e.inactiveIcon&&!e.inactiveText?(0,n.Q3)("v-if",!0):((0,n.uX)(),(0,n.CE)("span",{key:0,class:(0,o.C4)((0,a.R1)(R))},[e.inactiveIcon?((0,n.uX)(),(0,n.Wv)((0,a.R1)(r.tk),{key:0},{default:(0,n.k6)(()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)(e.inactiveIcon)))]),_:1})):(0,n.Q3)("v-if",!0),!e.inactiveIcon&&e.inactiveText?((0,n.uX)(),(0,n.CE)("span",{key:1,"aria-hidden":(0,a.R1)(A)},(0,o.v_)(e.inactiveText),9,["aria-hidden"])):(0,n.Q3)("v-if",!0)],2)),(0,n.Lk)("span",{class:(0,o.C4)((0,a.R1)(f).e("core")),style:(0,o.Tr)((0,a.R1)(S))},[e.inlinePrompt?((0,n.uX)(),(0,n.CE)("div",{key:0,class:(0,o.C4)((0,a.R1)(f).e("inner"))},[e.activeIcon||e.inactiveIcon?((0,n.uX)(),(0,n.Wv)((0,a.R1)(r.tk),{key:0,class:(0,o.C4)((0,a.R1)(f).is("icon"))},{default:(0,n.k6)(()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)((0,a.R1)(A)?e.activeIcon:e.inactiveIcon)))]),_:1},8,["class"])):e.activeText||e.inactiveText?((0,n.uX)(),(0,n.CE)("span",{key:1,class:(0,o.C4)((0,a.R1)(f).is("text")),"aria-hidden":!(0,a.R1)(A)},(0,o.v_)((0,a.R1)(A)?e.activeText:e.inactiveText),11,["aria-hidden"])):(0,n.Q3)("v-if",!0)],2)):(0,n.Q3)("v-if",!0),(0,n.Lk)("div",{class:(0,o.C4)((0,a.R1)(f).e("action"))},[e.loading?((0,n.uX)(),(0,n.Wv)((0,a.R1)(r.tk),{key:0,class:(0,o.C4)((0,a.R1)(f).is("loading"))},{default:(0,n.k6)(()=>[(0,n.bF)((0,a.R1)(s.Loading))]),_:1},8,["class"])):(0,a.R1)(A)?(0,n.RG)(e.$slots,"active-action",{key:1},()=>[e.activeActionIcon?((0,n.uX)(),(0,n.Wv)((0,a.R1)(r.tk),{key:0},{default:(0,n.k6)(()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)(e.activeActionIcon)))]),_:1})):(0,n.Q3)("v-if",!0)]):(0,a.R1)(A)?(0,n.Q3)("v-if",!0):(0,n.RG)(e.$slots,"inactive-action",{key:2},()=>[e.inactiveActionIcon?((0,n.uX)(),(0,n.Wv)((0,a.R1)(r.tk),{key:0},{default:(0,n.k6)(()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)(e.inactiveActionIcon)))]),_:1})):(0,n.Q3)("v-if",!0)])],2)],6),e.inlinePrompt||!e.activeIcon&&!e.activeText?(0,n.Q3)("v-if",!0):((0,n.uX)(),(0,n.CE)("span",{key:1,class:(0,o.C4)((0,a.R1)(k))},[e.activeIcon?((0,n.uX)(),(0,n.Wv)((0,a.R1)(r.tk),{key:0},{default:(0,n.k6)(()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)(e.activeIcon)))]),_:1})):(0,n.Q3)("v-if",!0),!e.activeIcon&&e.activeText?((0,n.uX)(),(0,n.CE)("span",{key:1,"aria-hidden":!(0,a.R1)(A)},(0,o.v_)(e.activeText),9,["aria-hidden"])):(0,n.Q3)("v-if",!0)],2))],10,["onClick"]))}});var R=(0,g.A)(z,[["__file","switch.vue"]]),k=l(5376);const S=(0,k.GU)(R)},5610:function(e,t,l){"use strict";var n=l(1291),a=Math.max,o=Math.min;e.exports=function(e,t){var l=n(e);return l<0?a(l+t,0):o(l,t)}},5623:function(e,t,l){"use strict";l(456)},5636:function(e,t,l){"use strict";var n=l(4576),a=l(9504),o=l(6706),c=l(7696),r=l(5169),s=l(7394),i=l(4483),u=l(1548),d=n.structuredClone,f=n.ArrayBuffer,p=n.DataView,m=Math.min,v=f.prototype,h=p.prototype,g=a(v.slice),b=o(v,"resizable","get"),y=o(v,"maxByteLength","get"),C=a(h.getInt8),w=a(h.setInt8);e.exports=(u||i)&&function(e,t,l){var n,a=s(e),o=void 0===t?a:c(t),v=!b||!b(e);if(r(e),u&&(e=d(e,{transfer:[e]}),a===o&&(l||v)))return e;if(a>=o&&(!l||v))n=g(e,0,o);else{var h=l&&!v&&y?{maxByteLength:y(e)}:void 0;n=new f(o,h);for(var L=new p(e),x=new p(n),M=m(o,a),z=0;z=52?l-1:l}}})},5810:function(e,t,l){"use strict";var n=l(34),a=l(1181).get;e.exports=function(e){if(!n(e))return!1;var t=a(e);return!!t&&"RawJSON"===t.type}},5854:function(e,t,l){"use strict";var n=l(2777),a=TypeError;e.exports=function(e){var t=n(e,"number");if("number"==typeof t)throw new a("Can't convert number to bigint");return BigInt(t)}},5856:function(e,t,l){"use strict";var n=l(7529),a=1,o=4;function c(e){return(0,n.A)(e,a|o)}t.A=c},5867:function(e,t,l){"use strict";function n(e,t,l){switch(l.length){case 0:return e.call(t);case 1:return e.call(t,l[0]);case 2:return e.call(t,l[0],l[1]);case 3:return e.call(t,l[0],l[1],l[2])}return e.apply(t,l)}l.d(t,{A:function(){return r}});var a=n,o=Math.max;function c(e,t,l){return t=o(void 0===t?e.length-1:t,0),function(){var n=arguments,c=-1,r=o(n.length-t,0),s=Array(r);while(++c[...new Set(e)],o=e=>(0,n.cy)(e)?e[0]:e,c=e=>e||0===e?(0,n.cy)(e)?e:[e]:[]},6018:function(e,t,l){"use strict";l.d(t,{P9:function(){return Ce},EL:function(){return we},AV:function(){return ye}});l(4114),l(8111),l(7588),l(1701),l(8237);var n=l(6768),a=l(144),o=l(4232),c=l(5130),r=l(8507),s=l(8559),i=l(2687),u=l(813),d=l(793),f=(l(3579),l(5951)),p=l(9615),m=l(9195),v=l(4344),h=l(7378);const g="ElOption",b=(0,h.b_)({value:{type:[String,Number,Boolean,Object],required:!0},label:{type:[String,Number]},created:Boolean,disabled:Boolean});var y=l(2261),C=l(6894);function w(e,t){const l=(0,n.WQ)(v.u);l||(0,C.$)(g,"usage: ");const c=(0,n.WQ)(v.P,{disabled:!1}),r=(0,n.EW)(()=>b((0,f.A)(l.props.modelValue),e.value)),s=(0,n.EW)(()=>{var e;if(l.props.multiple){const t=(0,f.A)(null!=(e=l.props.modelValue)?e:[]);return!r.value&&t.length>=l.props.multipleLimit&&l.props.multipleLimit>0}return!1}),i=(0,n.EW)(()=>{var t;return null!=(t=e.label)?t:(0,o.Gv)(e.value)?"":e.value}),u=(0,n.EW)(()=>e.value||e.label||""),d=(0,n.EW)(()=>e.disabled||t.groupDisabled||s.value),h=(0,n.nI)(),b=(t=[],n)=>{if((0,o.Gv)(e.value)){const e=l.props.valueKey;return t&&t.some(t=>(0,a.ux)((0,p.A)(t,e))===(0,p.A)(n,e))}return t&&t.includes(n)},w=()=>{d.value||(l.states.hoveringIndex=l.optionsArray.indexOf(h.proxy))},L=l=>{const n=new RegExp((0,y.qr)(l),"i");t.visible=n.test(String(i.value))||e.created};return(0,n.wB)(()=>i.value,()=>{e.created||l.props.remote||l.setSelected()}),(0,n.wB)(()=>e.value,(t,n)=>{const{remote:a,valueKey:c}=l.props,r=a?t!==n:!(0,m.A)(t,n);if(r&&(l.onOptionDestroy(n,h.proxy),l.onOptionCreate(h.proxy)),!e.created&&!a){if(c&&(0,o.Gv)(t)&&(0,o.Gv)(n)&&t[c]===n[c])return;l.setSelected()}}),(0,n.wB)(()=>c.disabled,()=>{t.groupDisabled=c.disabled},{immediate:!0}),{select:l,currentLabel:i,currentValue:u,itemSelected:r,isDisabled:d,hoverItem:w,updateOption:L}}var L=l(9077),x=l(3513),M=l(1305);const z=(0,n.pM)({name:g,componentName:g,props:b,setup(e){const t=(0,x.DU)("select"),l=(0,M.Bi)(),o=(0,n.EW)(()=>[t.be("dropdown","item"),t.is("disabled",(0,a.R1)(i)),t.is("selected",(0,a.R1)(s)),t.is("hovering",(0,a.R1)(m))]),c=(0,a.Kh)({index:-1,groupDisabled:!1,visible:!0,hover:!1}),{currentLabel:r,itemSelected:s,isDisabled:i,select:u,hoverItem:d,updateOption:f}=w(e,c),{visible:p,hover:m}=(0,a.QW)(c),v=(0,n.nI)().proxy;function h(){i.value||u.handleOptionSelect(v)}return u.onOptionCreate(v),(0,n.xo)(()=>{const e=v.value;(0,n.dY)(()=>{const{selected:t}=u.states,l=t.some(e=>e.value===v.value);u.states.cachedOptions.get(e)!==v||l||u.states.cachedOptions.delete(e)}),u.onOptionDestroy(e,v)}),{ns:t,id:l,containerKls:o,currentLabel:r,itemSelected:s,isDisabled:i,select:u,visible:p,hover:m,states:c,hoverItem:d,updateOption:f,selectOptionClick:h}}});function R(e,t){return(0,n.bo)(((0,n.uX)(),(0,n.CE)("li",{id:e.id,class:(0,o.C4)(e.containerKls),role:"option","aria-disabled":e.isDisabled||void 0,"aria-selected":e.itemSelected,onMousemove:e.hoverItem,onClick:(0,c.D$)(e.selectOptionClick,["stop"])},[(0,n.RG)(e.$slots,"default",{},()=>[(0,n.Lk)("span",null,(0,o.v_)(e.currentLabel),1)])],42,["id","aria-disabled","aria-selected","onMousemove","onClick"])),[[c.aG,e.visible]])}var k=(0,L.A)(z,[["render",R],["__file","option.vue"]]),S=l(7687),E=l(2934);const A=(0,n.pM)({name:"ElSelectDropdown",componentName:"ElSelectDropdown",setup(){const e=(0,n.WQ)(v.u),t=(0,x.DU)("select"),l=(0,n.EW)(()=>e.props.popperClass),o=(0,n.EW)(()=>e.props.multiple),c=(0,n.EW)(()=>e.props.fitInputWidth),r=(0,a.KR)("");function s(){var t;const l=null==(t=e.selectRef)?void 0:t.offsetWidth;r.value=l?l-E.f+"px":""}return(0,n.sV)(()=>{s(),(0,S.wYm)(e.selectRef,s)}),{ns:t,minWidth:r,popperClass:l,isMultiple:o,isFitInputWidth:c}}});function N(e,t,l,a,c,r){return(0,n.uX)(),(0,n.CE)("div",{class:(0,o.C4)([e.ns.b("dropdown"),e.ns.is("multiple",e.isMultiple),e.popperClass]),style:(0,o.Tr)({[e.isFitInputWidth?"width":"minWidth"]:e.minWidth})},[e.$slots.header?((0,n.uX)(),(0,n.CE)("div",{key:0,class:(0,o.C4)(e.ns.be("dropdown","header"))},[(0,n.RG)(e.$slots,"header")],2)):(0,n.Q3)("v-if",!0),(0,n.RG)(e.$slots,"default"),e.$slots.footer?((0,n.uX)(),(0,n.CE)("div",{key:1,class:(0,o.C4)(e.ns.be("dropdown","footer"))},[(0,n.RG)(e.$slots,"footer")],2)):(0,n.Q3)("v-if",!0)],6)}var _=(0,L.A)(A,[["render",N],["__file","select-dropdown.vue"]]),T=(l(1148),l(2489),l(116),l(2762)),O=l(6032),W=l(8096),B=l(17),I=l(6268),D=l(4216),F=l(9180),V=l(5488),P=l(2436),$=l(1939),H=l(464),j=l(2235),K=l(4225),X=l(515),U=l(2056),q=l(8587);const G=(e,t)=>{const{t:l}=(0,I.Ym)(),c=(0,M.Bi)(),r=(0,x.DU)("select"),s=(0,x.DU)("input"),i=(0,a.Kh)({inputValue:"",options:new Map,cachedOptions:new Map,optionValues:[],selected:[],selectionWidth:0,collapseItemWidth:0,selectedLabel:"",hoveringIndex:-1,previousQuery:null,inputHovering:!1,menuVisibleOnFocus:!1,isBeforeHide:!1}),u=(0,a.KR)(),d=(0,a.KR)(),v=(0,a.KR)(),h=(0,a.KR)(),g=(0,a.KR)(),b=(0,a.KR)(),y=(0,a.KR)(),w=(0,a.KR)(),L=(0,a.KR)(),z=(0,a.KR)(),R=(0,a.KR)(),k=(0,a.KR)(!1),A=(0,a.KR)(),N=(0,a.KR)(!1),{form:_,formItem:G}=(0,D.j)(),{inputId:Y}=(0,D.W)(e,{formItemContext:G}),{valueOnClear:Q,isEmptyValue:Z}=(0,F.fQ)(e),{isComposing:J,handleCompositionStart:ee,handleCompositionUpdate:te,handleCompositionEnd:le}=(0,V.o)({afterComposition:e=>De(e)}),ne=(0,P.CB)(),{wrapperRef:ae,isFocused:oe,handleBlur:ce}=(0,$.K)(g,{disabled:ne,afterFocus(){e.automaticDropdown&&!k.value&&(k.value=!0,i.menuVisibleOnFocus=!0)},beforeBlur(e){var t,l;return(null==(t=v.value)?void 0:t.isFocusInsideContent(e))||(null==(l=h.value)?void 0:l.isFocusInsideContent(e))},afterBlur(){var t;k.value=!1,i.menuVisibleOnFocus=!1,e.validateEvent&&(null==(t=null==G?void 0:G.validate)||t.call(G,"blur").catch(e=>(0,C.U)(e)))}}),re=(0,n.EW)(()=>(0,o.cy)(e.modelValue)?e.modelValue.length>0:!Z(e.modelValue)),se=(0,n.EW)(()=>{var e;return null!=(e=null==_?void 0:_.statusIcon)&&e}),ie=(0,n.EW)(()=>e.clearable&&!ne.value&&re.value&&(oe.value||i.inputHovering)),ue=(0,n.EW)(()=>e.remote&&e.filterable&&!e.remoteShowSuffix?"":e.suffixIcon),de=(0,n.EW)(()=>r.is("reverse",!(!ue.value||!k.value))),fe=(0,n.EW)(()=>(null==G?void 0:G.validateState)||""),pe=(0,n.EW)(()=>fe.value&&H.vK[fe.value]),me=(0,n.EW)(()=>e.remote?e.debounce:0),ve=(0,n.EW)(()=>e.remote&&!i.inputValue&&0===i.options.size),he=(0,n.EW)(()=>e.loading?e.loadingText||l("el.select.loading"):e.filterable&&i.inputValue&&i.options.size>0&&0===ge.value?e.noMatchText||l("el.select.noMatch"):0===i.options.size?e.noDataText||l("el.select.noData"):null),ge=(0,n.EW)(()=>be.value.filter(e=>e.visible).length),be=(0,n.EW)(()=>{const e=Array.from(i.options.values()),t=[];return i.optionValues.forEach(l=>{const n=e.findIndex(e=>e.value===l);n>-1&&t.push(e[n])}),t.length>=e.length?t:e}),ye=(0,n.EW)(()=>Array.from(i.cachedOptions.values())),Ce=(0,n.EW)(()=>{const t=be.value.filter(e=>!e.created).some(e=>e.currentLabel===i.inputValue);return e.filterable&&e.allowCreate&&""!==i.inputValue&&!t}),we=()=>{e.filterable&&(0,o.Tn)(e.filterMethod)||e.filterable&&e.remote&&(0,o.Tn)(e.remoteMethod)||be.value.forEach(e=>{var t;null==(t=e.updateOption)||t.call(e,i.inputValue)})},Le=(0,P.NV)(),xe=(0,n.EW)(()=>["small"].includes(Le.value)?"small":"default"),Me=(0,n.EW)({get(){return k.value&&(e.loading||!ve.value)&&(!N.value||!(0,j.Im)(i.previousQuery))},set(e){k.value=e}}),ze=(0,n.EW)(()=>{if(e.multiple&&!(0,j.b0)(e.modelValue))return 0===(0,f.A)(e.modelValue).length&&!i.inputValue;const t=(0,o.cy)(e.modelValue)?e.modelValue[0]:e.modelValue;return!e.filterable&&!(0,j.b0)(t)||!i.inputValue}),Re=(0,n.EW)(()=>{var t;const n=null!=(t=e.placeholder)?t:l("el.select.placeholder");return e.multiple||!re.value?n:i.selectedLabel}),ke=(0,n.EW)(()=>B.un?null:"mouseenter");(0,n.wB)(()=>e.modelValue,(t,l)=>{e.multiple&&e.filterable&&!e.reserveKeyword&&(i.inputValue="",Se("")),Ae(),!(0,m.A)(t,l)&&e.validateEvent&&(null==G||G.validate("change").catch(e=>(0,C.U)(e)))},{flush:"post",deep:!0}),(0,n.wB)(()=>k.value,e=>{e?Se(i.inputValue):(i.inputValue="",i.previousQuery=null,i.isBeforeHide=!0)}),(0,n.wB)(()=>i.options.entries(),()=>{B.oc&&(Ae(),e.defaultFirstOption&&(e.filterable||e.remote)&&ge.value&&Ee())},{flush:"post"}),(0,n.wB)([()=>i.hoveringIndex,be],([e])=>{(0,j.Et)(e)&&e>-1?A.value=be.value[e]||{}:A.value={},be.value.forEach(e=>{e.hover=A.value===e})}),(0,n.nT)(()=>{i.isBeforeHide||we()});const Se=t=>{i.previousQuery===t||J.value||(i.previousQuery=t,e.filterable&&(0,o.Tn)(e.filterMethod)?e.filterMethod(t):e.filterable&&e.remote&&(0,o.Tn)(e.remoteMethod)&&e.remoteMethod(t),e.defaultFirstOption&&(e.filterable||e.remote)&&ge.value?(0,n.dY)(Ee):(0,n.dY)(_e))},Ee=()=>{const e=be.value.filter(e=>e.visible&&!e.disabled&&!e.states.groupDisabled),t=e.find(e=>e.created),l=e[0],n=be.value.map(e=>e.value);i.hoveringIndex=Xe(n,t||l)},Ae=()=>{if(!e.multiple){const t=(0,o.cy)(e.modelValue)?e.modelValue[0]:e.modelValue,l=Ne(t);return i.selectedLabel=l.currentLabel,void(i.selected=[l])}i.selectedLabel="";const t=[];(0,j.b0)(e.modelValue)||(0,f.A)(e.modelValue).forEach(e=>{t.push(Ne(e))}),i.selected=t},Ne=t=>{let l;const n=(0,o.Qd)(t);for(let o=i.cachedOptions.size-1;o>=0;o--){const a=ye.value[o],c=n?(0,p.A)(a.value,e.valueKey)===(0,p.A)(t,e.valueKey):a.value===t;if(c){l={index:be.value.filter(e=>!e.created).indexOf(a),value:t,currentLabel:a.currentLabel,get isDisabled(){return a.isDisabled}};break}}if(l)return l;const a=n?t.label:null!=t?t:"",c={index:-1,value:t,currentLabel:a};return c},_e=()=>{const e=i.selected.length;if(e>0){const t=i.selected[e-1];i.hoveringIndex=be.value.findIndex(e=>ot(t)===ot(e))}else i.hoveringIndex=-1},Te=()=>{i.selectionWidth=Number.parseFloat(window.getComputedStyle(d.value).width)},Oe=()=>{i.collapseItemWidth=z.value.getBoundingClientRect().width},We=()=>{var e,t;null==(t=null==(e=v.value)?void 0:e.updatePopper)||t.call(e)},Be=()=>{var e,t;null==(t=null==(e=h.value)?void 0:e.updatePopper)||t.call(e)},Ie=()=>{i.inputValue.length>0&&!k.value&&(k.value=!0),Se(i.inputValue)},De=t=>{if(i.inputValue=t.target.value,!e.remote)return Ie();N.value=!0,Fe()},Fe=(0,B.xD)(()=>{Ie(),N.value=!1},me),Ve=l=>{(0,m.A)(e.modelValue,l)||t(U.YU,l)},Pe=e=>(0,T.A)(e,e=>{const t=i.cachedOptions.get(e);return!(null==t?void 0:t.disabled)&&!(null==t?void 0:t.states.groupDisabled)}),$e=l=>{const n=(0,K.CG)(l);if(e.multiple&&n!==X.R.delete&&l.target.value.length<=0){const l=(0,f.A)(e.modelValue).slice(),n=Pe(l);if(n<0)return;const a=l[n];l.splice(n,1),t(U.l4,l),Ve(l),t("remove-tag",a)}},He=(l,n)=>{const a=i.selected.indexOf(n);if(a>-1&&!ne.value){const l=(0,f.A)(e.modelValue).slice();l.splice(a,1),t(U.l4,l),Ve(l),t("remove-tag",n.value)}l.stopPropagation(),Ze()},je=l=>{l.stopPropagation();const n=e.multiple?[]:Q.value;if(e.multiple)for(const e of i.selected)e.isDisabled&&n.push(e.value);t(U.l4,n),Ve(n),i.hoveringIndex=-1,k.value=!1,t("clear"),Ze()},Ke=l=>{var a;if(e.multiple){const n=(0,f.A)(null!=(a=e.modelValue)?a:[]).slice(),o=Xe(n,l);o>-1?n.splice(o,1):(e.multipleLimit<=0||n.length{Ue(l)})},Xe=(t,l)=>(0,j.b0)(l)?-1:(0,o.Gv)(l.value)?t.findIndex(t=>(0,m.A)((0,p.A)(t,e.valueKey),ot(l))):t.indexOf(l.value),Ue=e=>{var t,l,n,a,c;const s=(0,o.cy)(e)?e[e.length-1]:e;let i=null;if(!(0,O.A)(null==s?void 0:s.value)){const e=be.value.filter(e=>e.value===s.value);e.length>0&&(i=e[0].$el)}if(v.value&&i){const e=null==(a=null==(n=null==(l=null==(t=v.value)?void 0:t.popperRef)?void 0:l.contentRef)?void 0:n.querySelector)?void 0:a.call(n,`.${r.be("dropdown","wrap")}`);e&&(0,q.Rt)(e,i)}null==(c=R.value)||c.handleScroll()},qe=e=>{i.options.set(e.value,e),i.cachedOptions.set(e.value,e)},Ge=(e,t)=>{i.options.get(e)===t&&i.options.delete(e)},Ye=(0,n.EW)(()=>{var e,t;return null==(t=null==(e=v.value)?void 0:e.popperRef)?void 0:t.contentRef}),Qe=()=>{i.isBeforeHide=!1,(0,n.dY)(()=>{var e;null==(e=R.value)||e.update(),Ue(i.selected)})},Ze=()=>{var e;null==(e=g.value)||e.focus()},Je=()=>{var e;if(k.value)return k.value=!1,void(0,n.dY)(()=>{var e;return null==(e=g.value)?void 0:e.blur()});null==(e=g.value)||e.blur()},et=e=>{je(e)},tt=e=>{if(k.value=!1,oe.value){const t=new FocusEvent("blur",e);(0,n.dY)(()=>ce(t))}},lt=()=>{i.inputValue.length>0?i.inputValue="":k.value=!1},nt=t=>{var l;ne.value||e.filterable&&k.value&&t&&!(null==(l=y.value)?void 0:l.contains(t.target))||(B.un&&(i.inputHovering=!0),i.menuVisibleOnFocus?i.menuVisibleOnFocus=!1:k.value=!k.value)},at=()=>{if(k.value){const e=be.value[i.hoveringIndex];e&&!e.isDisabled&&Ke(e)}else nt()},ot=t=>(0,o.Gv)(t.value)?(0,p.A)(t.value,e.valueKey):t.value,ct=(0,n.EW)(()=>be.value.filter(e=>e.visible).every(e=>e.isDisabled)),rt=(0,n.EW)(()=>e.multiple?e.collapseTags?i.selected.slice(0,e.maxCollapseTags):i.selected:[]),st=(0,n.EW)(()=>e.multiple&&e.collapseTags?i.selected.slice(e.maxCollapseTags):[]),it=e=>{if(k.value){if(0!==i.options.size&&0!==ge.value&&!J.value&&!ct.value){"next"===e?(i.hoveringIndex++,i.hoveringIndex===i.options.size&&(i.hoveringIndex=0)):"prev"===e&&(i.hoveringIndex--,i.hoveringIndex<0&&(i.hoveringIndex=i.options.size-1));const t=be.value[i.hoveringIndex];!t.isDisabled&&t.visible||it(e),(0,n.dY)(()=>Ue(A.value))}}else k.value=!0},ut=(e,t,l,n)=>{for(let a=t;a>=0&&a{var l;const a=i.options.size;if(0===a)return;const o=(0,W.A)(e,0,a-1),c=be.value,r="up"===t?-1:1,s=null!=(l=ut(c,o,r,a))?l:ut(c,o-r,-r,a);null!=s&&(i.hoveringIndex=s,(0,n.dY)(()=>Ue(A.value)))},ft=e=>{const t=(0,K.CG)(e);let l=!0;switch(t){case X.R.up:it("prev");break;case X.R.down:it("next");break;case X.R.enter:case X.R.numpadEnter:J.value||at();break;case X.R.esc:lt();break;case X.R.backspace:return l=!1,void $e(e);case X.R.home:if(!k.value)return;dt(0,"down");break;case X.R.end:if(!k.value)return;dt(i.options.size-1,"up");break;case X.R.pageUp:if(!k.value)return;dt(i.hoveringIndex-10,"up");break;case X.R.pageDown:if(!k.value)return;dt(i.hoveringIndex+10,"down");break;default:l=!1;break}l&&(e.preventDefault(),e.stopPropagation())},pt=()=>{if(!d.value)return 0;const e=window.getComputedStyle(d.value);return Number.parseFloat(e.gap||"6px")},mt=(0,n.EW)(()=>{const t=pt(),l=e.filterable?t+E.R:0,n=z.value&&1===e.maxCollapseTags?i.selectionWidth-i.collapseItemWidth-t-l:i.selectionWidth-l;return{maxWidth:`${n}px`}}),vt=(0,n.EW)(()=>({maxWidth:`${i.selectionWidth}px`})),ht=e=>{t("popup-scroll",e)};let gt;return(0,S.wYm)(d,Te),(0,S.wYm)(ae,We),(0,S.wYm)(L,Be),(0,S.wYm)(z,Oe),(0,n.wB)(()=>Me.value,e=>{e?gt=(0,S.wYm)(w,We).stop:(null==gt||gt(),gt=void 0),t("visible-change",e)}),(0,n.sV)(()=>{Ae()}),{inputId:Y,contentId:c,nsSelect:r,nsInput:s,states:i,isFocused:oe,expanded:k,optionsArray:be,hoverOption:A,selectSize:Le,filteredOptionsCount:ge,updateTooltip:We,updateTagTooltip:Be,debouncedOnInputChange:Fe,onInput:De,deletePrevTag:$e,deleteTag:He,deleteSelected:je,handleOptionSelect:Ke,scrollToOption:Ue,hasModelValue:re,shouldShowPlaceholder:ze,currentPlaceholder:Re,mouseEnterEventName:ke,needStatusIcon:se,showClearBtn:ie,iconComponent:ue,iconReverse:de,validateState:fe,validateIcon:pe,showNewOption:Ce,updateOptions:we,collapseTagSize:xe,setSelected:Ae,selectDisabled:ne,emptyText:he,handleCompositionStart:ee,handleCompositionUpdate:te,handleCompositionEnd:le,handleKeydown:ft,onOptionCreate:qe,onOptionDestroy:Ge,handleMenuEnter:Qe,focus:Ze,blur:Je,handleClearClick:et,handleClickOutside:tt,handleEsc:lt,toggleMenu:nt,selectOption:at,getValueKey:ot,navigateOptions:it,dropdownMenuVisible:Me,showTagList:rt,collapseTagList:st,popupScroll:ht,getOption:Ne,tagStyle:mt,collapseTagStyle:vt,popperRef:Ye,inputRef:g,tooltipRef:v,tagTooltipRef:h,prefixRef:b,suffixRef:y,selectRef:u,wrapperRef:ae,selectionRef:d,scrollbarRef:R,menuRef:w,tagMenuRef:L,collapseItemRef:z}};var Y=(0,n.pM)({name:"ElOptions",setup(e,{slots:t}){const l=(0,n.WQ)(v.u);let a=[];return()=>{var e,n;const c=null==(e=t.default)?void 0:e.call(t),r=[];function s(e){(0,o.cy)(e)&&e.forEach(e=>{var t,l,n,a;const c=null==(t=(null==e?void 0:e.type)||{})?void 0:t.name;"ElOptionGroup"===c?s((0,o.Kg)(e.children)||(0,o.cy)(e.children)||!(0,o.Tn)(null==(l=e.children)?void 0:l.default)?e.children:null==(n=e.children)?void 0:n.default()):"ElOption"===c?r.push(null==(a=e.props)?void 0:a.value):(0,o.cy)(e.children)&&s(e.children)})}return c.length&&s(null==(n=c[0])?void 0:n.children),(0,m.A)(r,a)||(a=r,l&&(l.states.optionValues=r)),c}}}),Q=l(6484),Z=l(7477),J=l(9825),ee=l(3845),te=l(2251),le=l(3829),ne=l(8501);const ae=(0,h.b_)({name:String,id:String,modelValue:{type:(0,h.jq)([Array,String,Number,Boolean,Object]),default:void 0},autocomplete:{type:String,default:"off"},automaticDropdown:Boolean,size:ee.mU,effect:{type:(0,h.jq)(String),default:"light"},disabled:{type:Boolean,default:void 0},clearable:Boolean,filterable:Boolean,allowCreate:Boolean,loading:Boolean,popperClass:{type:String,default:""},popperStyle:{type:(0,h.jq)([String,Object])},popperOptions:{type:(0,h.jq)(Object),default:()=>({})},remote:Boolean,debounce:{type:Number,default:300},loadingText:String,noMatchText:String,noDataText:String,remoteMethod:{type:(0,h.jq)(Function)},filterMethod:{type:(0,h.jq)(Function)},multiple:Boolean,multipleLimit:{type:Number,default:0},placeholder:{type:String},defaultFirstOption:Boolean,reserveKeyword:{type:Boolean,default:!0},valueKey:{type:String,default:"value"},collapseTags:Boolean,collapseTagsTooltip:Boolean,maxCollapseTags:{type:Number,default:1},teleported:te.E.teleported,persistent:{type:Boolean,default:!0},clearIcon:{type:H.Ze,default:Z.CircleClose},fitInputWidth:Boolean,suffixIcon:{type:H.Ze,default:Z.ArrowDown},tagType:{...le.z.type,default:"info"},tagEffect:{...le.z.effect,default:"light"},validateEvent:{type:Boolean,default:!0},remoteShowSuffix:Boolean,showArrow:{type:Boolean,default:!0},offset:{type:Number,default:12},placement:{type:(0,h.jq)(String),values:Q.DD,default:"bottom-start"},fallbackPlacements:{type:(0,h.jq)(Array),default:["bottom-start","top-start","right","left"]},tabindex:{type:[String,Number],default:0},appendTo:te.E.appendTo,options:{type:(0,h.jq)(Array)},props:{type:(0,h.jq)(Object),default:()=>d.G},...F.bs,...(0,ne.l)(["ariaLabel"])}),oe=(U.l4,U.YU,J.f.scroll,(0,n.pM)({name:"ElOptionGroup",componentName:"ElOptionGroup",props:{label:String,disabled:Boolean},setup(e){const t=(0,x.DU)("select"),l=(0,a.KR)(),c=(0,n.nI)(),r=(0,a.KR)([]);(0,n.Gt)(v.P,(0,a.Kh)({...(0,a.QW)(e)}));const s=(0,n.EW)(()=>r.value.some(e=>!0===e.visible)),i=e=>{var t;return"ElOption"===e.type.name&&!!(null==(t=e.component)?void 0:t.proxy)},u=e=>{const t=(0,f.A)(e),l=[];return t.forEach(e=>{var t;(0,n.vv)(e)&&(i(e)?l.push(e.component.proxy):(0,o.cy)(e.children)&&e.children.length?l.push(...u(e.children)):(null==(t=e.component)?void 0:t.subTree)&&l.push(...u(e.component.subTree)))}),l},d=()=>{r.value=u(c.subTree)};return(0,n.sV)(()=>{d()}),(0,S.P1n)(l,d,{attributes:!0,subtree:!0,childList:!0}),{groupRef:l,visible:s,ns:t}}}));function ce(e,t,l,a,r,s){return(0,n.bo)(((0,n.uX)(),(0,n.CE)("ul",{ref:"groupRef",class:(0,o.C4)(e.ns.be("group","wrap"))},[(0,n.Lk)("li",{class:(0,o.C4)(e.ns.be("group","title"))},(0,o.v_)(e.label),3),(0,n.Lk)("li",null,[(0,n.Lk)("ul",{class:(0,o.C4)(e.ns.b("group"))},[(0,n.RG)(e.$slots,"default")],2)])],2)),[[c.aG,e.visible]])}var re=(0,L.A)(oe,[["render",ce],["__file","option-group.vue"]]),se=l(2142),ie=l(3337),ue=l(6139);const de="ElSelect",fe=new WeakMap,pe=e=>(...t)=>{var l,n;const a=t[0];if(!a||a.includes('Slot "default" invoked outside of the render function')&&(null==(l=t[2])?void 0:l.includes("ElTreeSelect")))return;const o=null==(n=fe.get(e))?void 0:n.originalWarnHandler;o?o(...t):console.warn(...t)},me=e=>{let t=fe.get(e);return t||(t={originalWarnHandler:e.config.warnHandler,handler:pe(e),count:0},fe.set(e,t)),t},ve=(0,n.pM)({name:de,componentName:de,components:{ElSelectMenu:_,ElOption:k,ElOptions:Y,ElOptionGroup:re,ElTag:i.u,ElScrollbar:s.kA,ElTooltip:r.R7,ElIcon:u.tk},directives:{ClickOutside:se.A},props:ae,emits:[U.l4,U.YU,"remove-tag","clear","visible-change","focus","blur","popup-scroll"],setup(e,{emit:t,slots:l}){const c=(0,n.nI)(),r=me(c.appContext);r.count+=1,c.appContext.config.warnHandler=r.handler;const s=(0,n.EW)(()=>{const{modelValue:t,multiple:l}=e,n=l?[]:void 0;return(0,o.cy)(t)?l?t:n:l?n:t}),i=(0,a.Kh)({...(0,a.QW)(e),modelValue:s}),u=G(i,t),{calculatorRef:f,inputStyle:p}=(0,ie.v)(),{getLabel:m,getValue:h,getOptions:g,getDisabled:b}=(0,d.Y)(e),y=e=>({label:m(e),value:h(e),disabled:b(e)}),C=e=>e.reduce((e,t)=>(e.push(t),t.children&&t.children.length>0&&e.push(...C(t.children)),e),[]),w=e=>{const t=(0,ue.CW)(e||[]);t.forEach(e=>{var t;if((0,o.Gv)(e)&&("ElOption"===e.type.name||"ElTree"===e.type.name)){const l=e.type.name;if("ElTree"===l){const l=(null==(t=e.props)?void 0:t.data)||[],n=C(l);n.forEach(e=>{e.currentLabel=e.label||((0,o.Gv)(e.value)?"":e.value),u.onOptionCreate(e)})}else if("ElOption"===l){const t={...e.props};t.currentLabel=t.label||((0,o.Gv)(t.value)?"":t.value),u.onOptionCreate(t)}}})};(0,n.wB)(()=>{var e;return[null==(e=l.default)?void 0:e.call(l),s.value]},()=>{var t;e.persistent||u.expanded.value||(u.states.options.clear(),w(null==(t=l.default)?void 0:t.call(l)))},{immediate:!0}),(0,n.Gt)(v.u,(0,a.Kh)({props:i,states:u.states,selectRef:u.selectRef,optionsArray:u.optionsArray,setSelected:u.setSelected,handleOptionSelect:u.handleOptionSelect,onOptionCreate:u.onOptionCreate,onOptionDestroy:u.onOptionDestroy}));const L=(0,n.EW)(()=>e.multiple?u.states.selected.map(e=>e.currentLabel):u.states.selectedLabel);return(0,n.xo)(()=>{const e=fe.get(c.appContext);e&&(e.count-=1,e.count<=0&&(c.appContext.config.warnHandler=e.originalWarnHandler,fe.delete(c.appContext)))}),{...u,modelValue:s,selectedLabel:L,calculatorRef:f,inputStyle:p,getLabel:m,getValue:h,getOptions:g,getDisabled:b,getOptionProps:y}}});function he(e,t){const l=(0,n.g2)("el-tag"),a=(0,n.g2)("el-tooltip"),r=(0,n.g2)("el-icon"),s=(0,n.g2)("el-option"),i=(0,n.g2)("el-option-group"),u=(0,n.g2)("el-options"),d=(0,n.g2)("el-scrollbar"),f=(0,n.g2)("el-select-menu"),p=(0,n.gN)("click-outside");return(0,n.bo)(((0,n.uX)(),(0,n.CE)("div",{ref:"selectRef",class:(0,o.C4)([e.nsSelect.b(),e.nsSelect.m(e.selectSize)]),[(0,o.rU)(e.mouseEnterEventName)]:t=>e.states.inputHovering=!0,onMouseleave:t=>e.states.inputHovering=!1},[(0,n.bF)(a,{ref:"tooltipRef",visible:e.dropdownMenuVisible,placement:e.placement,teleported:e.teleported,"popper-class":[e.nsSelect.e("popper"),e.popperClass],"popper-style":e.popperStyle,"popper-options":e.popperOptions,"fallback-placements":e.fallbackPlacements,effect:e.effect,pure:"",trigger:"click",transition:`${e.nsSelect.namespace.value}-zoom-in-top`,"stop-popper-mouse-event":!1,"gpu-acceleration":!1,persistent:e.persistent,"append-to":e.appendTo,"show-arrow":e.showArrow,offset:e.offset,onBeforeShow:e.handleMenuEnter,onHide:t=>e.states.isBeforeHide=!1},{default:(0,n.k6)(()=>{var t;return[(0,n.Lk)("div",{ref:"wrapperRef",class:(0,o.C4)([e.nsSelect.e("wrapper"),e.nsSelect.is("focused",e.isFocused),e.nsSelect.is("hovering",e.states.inputHovering),e.nsSelect.is("filterable",e.filterable),e.nsSelect.is("disabled",e.selectDisabled)]),onClick:(0,c.D$)(e.toggleMenu,["prevent"])},[e.$slots.prefix?((0,n.uX)(),(0,n.CE)("div",{key:0,ref:"prefixRef",class:(0,o.C4)(e.nsSelect.e("prefix"))},[(0,n.RG)(e.$slots,"prefix")],2)):(0,n.Q3)("v-if",!0),(0,n.Lk)("div",{ref:"selectionRef",class:(0,o.C4)([e.nsSelect.e("selection"),e.nsSelect.is("near",e.multiple&&!e.$slots.prefix&&!!e.states.selected.length)])},[e.multiple?(0,n.RG)(e.$slots,"tag",{key:0,data:e.states.selected,deleteTag:e.deleteTag,selectDisabled:e.selectDisabled},()=>[((0,n.uX)(!0),(0,n.CE)(n.FK,null,(0,n.pI)(e.showTagList,t=>((0,n.uX)(),(0,n.CE)("div",{key:e.getValueKey(t),class:(0,o.C4)(e.nsSelect.e("selected-item"))},[(0,n.bF)(l,{closable:!e.selectDisabled&&!t.isDisabled,size:e.collapseTagSize,type:e.tagType,effect:e.tagEffect,"disable-transitions":"",style:(0,o.Tr)(e.tagStyle),onClose:l=>e.deleteTag(l,t)},{default:(0,n.k6)(()=>[(0,n.Lk)("span",{class:(0,o.C4)(e.nsSelect.e("tags-text"))},[(0,n.RG)(e.$slots,"label",{index:t.index,label:t.currentLabel,value:t.value},()=>[(0,n.eW)((0,o.v_)(t.currentLabel),1)])],2)]),_:2},1032,["closable","size","type","effect","style","onClose"])],2))),128)),e.collapseTags&&e.states.selected.length>e.maxCollapseTags?((0,n.uX)(),(0,n.Wv)(a,{key:0,ref:"tagTooltipRef",disabled:e.dropdownMenuVisible||!e.collapseTagsTooltip,"fallback-placements":["bottom","top","right","left"],effect:e.effect,placement:"bottom","popper-class":e.popperClass,"popper-style":e.popperStyle,teleported:e.teleported},{default:(0,n.k6)(()=>[(0,n.Lk)("div",{ref:"collapseItemRef",class:(0,o.C4)(e.nsSelect.e("selected-item"))},[(0,n.bF)(l,{closable:!1,size:e.collapseTagSize,type:e.tagType,effect:e.tagEffect,"disable-transitions":"",style:(0,o.Tr)(e.collapseTagStyle)},{default:(0,n.k6)(()=>[(0,n.Lk)("span",{class:(0,o.C4)(e.nsSelect.e("tags-text"))}," + "+(0,o.v_)(e.states.selected.length-e.maxCollapseTags),3)]),_:1},8,["size","type","effect","style"])],2)]),content:(0,n.k6)(()=>[(0,n.Lk)("div",{ref:"tagMenuRef",class:(0,o.C4)(e.nsSelect.e("selection"))},[((0,n.uX)(!0),(0,n.CE)(n.FK,null,(0,n.pI)(e.collapseTagList,t=>((0,n.uX)(),(0,n.CE)("div",{key:e.getValueKey(t),class:(0,o.C4)(e.nsSelect.e("selected-item"))},[(0,n.bF)(l,{class:"in-tooltip",closable:!e.selectDisabled&&!t.isDisabled,size:e.collapseTagSize,type:e.tagType,effect:e.tagEffect,"disable-transitions":"",onClose:l=>e.deleteTag(l,t)},{default:(0,n.k6)(()=>[(0,n.Lk)("span",{class:(0,o.C4)(e.nsSelect.e("tags-text"))},[(0,n.RG)(e.$slots,"label",{index:t.index,label:t.currentLabel,value:t.value},()=>[(0,n.eW)((0,o.v_)(t.currentLabel),1)])],2)]),_:2},1032,["closable","size","type","effect","onClose"])],2))),128))],2)]),_:3},8,["disabled","effect","popper-class","popper-style","teleported"])):(0,n.Q3)("v-if",!0)]):(0,n.Q3)("v-if",!0),(0,n.Lk)("div",{class:(0,o.C4)([e.nsSelect.e("selected-item"),e.nsSelect.e("input-wrapper"),e.nsSelect.is("hidden",!e.filterable||e.selectDisabled)])},[(0,n.bo)((0,n.Lk)("input",{id:e.inputId,ref:"inputRef","onUpdate:modelValue":t=>e.states.inputValue=t,type:"text",name:e.name,class:(0,o.C4)([e.nsSelect.e("input"),e.nsSelect.is(e.selectSize)]),disabled:e.selectDisabled,autocomplete:e.autocomplete,style:(0,o.Tr)(e.inputStyle),tabindex:e.tabindex,role:"combobox",readonly:!e.filterable,spellcheck:"false","aria-activedescendant":(null==(t=e.hoverOption)?void 0:t.id)||"","aria-controls":e.contentId,"aria-expanded":e.dropdownMenuVisible,"aria-label":e.ariaLabel,"aria-autocomplete":"none","aria-haspopup":"listbox",onKeydown:e.handleKeydown,onCompositionstart:e.handleCompositionStart,onCompositionupdate:e.handleCompositionUpdate,onCompositionend:e.handleCompositionEnd,onInput:e.onInput,onClick:(0,c.D$)(e.toggleMenu,["stop"])},null,46,["id","onUpdate:modelValue","name","disabled","autocomplete","tabindex","readonly","aria-activedescendant","aria-controls","aria-expanded","aria-label","onKeydown","onCompositionstart","onCompositionupdate","onCompositionend","onInput","onClick"]),[[c.Jo,e.states.inputValue]]),e.filterable?((0,n.uX)(),(0,n.CE)("span",{key:0,ref:"calculatorRef","aria-hidden":"true",class:(0,o.C4)(e.nsSelect.e("input-calculator")),textContent:(0,o.v_)(e.states.inputValue)},null,10,["textContent"])):(0,n.Q3)("v-if",!0)],2),e.shouldShowPlaceholder?((0,n.uX)(),(0,n.CE)("div",{key:1,class:(0,o.C4)([e.nsSelect.e("selected-item"),e.nsSelect.e("placeholder"),e.nsSelect.is("transparent",!e.hasModelValue||e.expanded&&!e.states.inputValue)])},[e.hasModelValue?(0,n.RG)(e.$slots,"label",{key:0,index:e.getOption(e.modelValue).index,label:e.currentPlaceholder,value:e.modelValue},()=>[(0,n.Lk)("span",null,(0,o.v_)(e.currentPlaceholder),1)]):((0,n.uX)(),(0,n.CE)("span",{key:1},(0,o.v_)(e.currentPlaceholder),1))],2)):(0,n.Q3)("v-if",!0)],2),(0,n.Lk)("div",{ref:"suffixRef",class:(0,o.C4)(e.nsSelect.e("suffix"))},[e.iconComponent&&!e.showClearBtn?((0,n.uX)(),(0,n.Wv)(r,{key:0,class:(0,o.C4)([e.nsSelect.e("caret"),e.nsSelect.e("icon"),e.iconReverse])},{default:(0,n.k6)(()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)(e.iconComponent)))]),_:1},8,["class"])):(0,n.Q3)("v-if",!0),e.showClearBtn&&e.clearIcon?((0,n.uX)(),(0,n.Wv)(r,{key:1,class:(0,o.C4)([e.nsSelect.e("caret"),e.nsSelect.e("icon"),e.nsSelect.e("clear")]),onClick:e.handleClearClick},{default:(0,n.k6)(()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)(e.clearIcon)))]),_:1},8,["class","onClick"])):(0,n.Q3)("v-if",!0),e.validateState&&e.validateIcon&&e.needStatusIcon?((0,n.uX)(),(0,n.Wv)(r,{key:2,class:(0,o.C4)([e.nsInput.e("icon"),e.nsInput.e("validateIcon"),e.nsInput.is("loading","validating"===e.validateState)])},{default:(0,n.k6)(()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)(e.validateIcon)))]),_:1},8,["class"])):(0,n.Q3)("v-if",!0)],2)],10,["onClick"])]}),content:(0,n.k6)(()=>[(0,n.bF)(f,{ref:"menuRef"},{default:(0,n.k6)(()=>[e.$slots.header?((0,n.uX)(),(0,n.CE)("div",{key:0,class:(0,o.C4)(e.nsSelect.be("dropdown","header")),onClick:(0,c.D$)(()=>{},["stop"])},[(0,n.RG)(e.$slots,"header")],10,["onClick"])):(0,n.Q3)("v-if",!0),(0,n.bo)((0,n.bF)(d,{id:e.contentId,ref:"scrollbarRef",tag:"ul","wrap-class":e.nsSelect.be("dropdown","wrap"),"view-class":e.nsSelect.be("dropdown","list"),class:(0,o.C4)([e.nsSelect.is("empty",0===e.filteredOptionsCount)]),role:"listbox","aria-label":e.ariaLabel,"aria-orientation":"vertical",onScroll:e.popupScroll},{default:(0,n.k6)(()=>[e.showNewOption?((0,n.uX)(),(0,n.Wv)(s,{key:0,value:e.states.inputValue,created:!0},null,8,["value"])):(0,n.Q3)("v-if",!0),(0,n.bF)(u,null,{default:(0,n.k6)(()=>[(0,n.RG)(e.$slots,"default",{},()=>[((0,n.uX)(!0),(0,n.CE)(n.FK,null,(0,n.pI)(e.options,(t,l)=>{var a;return(0,n.uX)(),(0,n.CE)(n.FK,{key:l},[(null==(a=e.getOptions(t))?void 0:a.length)?((0,n.uX)(),(0,n.Wv)(i,{key:0,label:e.getLabel(t),disabled:e.getDisabled(t)},{default:(0,n.k6)(()=>[((0,n.uX)(!0),(0,n.CE)(n.FK,null,(0,n.pI)(e.getOptions(t),t=>((0,n.uX)(),(0,n.Wv)(s,(0,n.v6)({key:e.getValue(t)},e.getOptionProps(t)),null,16))),128))]),_:2},1032,["label","disabled"])):((0,n.uX)(),(0,n.Wv)(s,(0,o._B)((0,n.v6)({key:1},e.getOptionProps(t))),null,16))],64)}),128))])]),_:3})]),_:3},8,["id","wrap-class","view-class","class","aria-label","onScroll"]),[[c.aG,e.states.options.size>0&&!e.loading]]),e.$slots.loading&&e.loading?((0,n.uX)(),(0,n.CE)("div",{key:1,class:(0,o.C4)(e.nsSelect.be("dropdown","loading"))},[(0,n.RG)(e.$slots,"loading")],2)):e.loading||0===e.filteredOptionsCount?((0,n.uX)(),(0,n.CE)("div",{key:2,class:(0,o.C4)(e.nsSelect.be("dropdown","empty"))},[(0,n.RG)(e.$slots,"empty",{},()=>[(0,n.Lk)("span",null,(0,o.v_)(e.emptyText),1)])],2)):(0,n.Q3)("v-if",!0),e.$slots.footer?((0,n.uX)(),(0,n.CE)("div",{key:3,class:(0,o.C4)(e.nsSelect.be("dropdown","footer")),onClick:(0,c.D$)(()=>{},["stop"])},[(0,n.RG)(e.$slots,"footer")],10,["onClick"])):(0,n.Q3)("v-if",!0)]),_:3},512)]),_:3},8,["visible","placement","teleported","popper-class","popper-style","popper-options","fallback-placements","effect","transition","persistent","append-to","show-arrow","offset","onBeforeShow","onHide"])],16,["onMouseleave"])),[[p,e.handleClickOutside,e.popperRef]])}var ge=(0,L.A)(ve,[["render",he],["__file","select.vue"]]),be=l(5376);const ye=(0,be.GU)(ge,{Option:k,OptionGroup:re}),Ce=(0,be.WM)(k),we=(0,be.WM)(re)},6032:function(e,t){"use strict";function l(e){return null==e}t.A=l},6054:function(e,t){"use strict";function l(){return[]}t.A=l},6062:function(e,t,l){"use strict";var n=l(7162),a=l(9578),o=(0,n.A)(a.A,"Map");t.A=o},6080:function(e,t,l){"use strict";var n=l(7476),a=l(9306),o=l(616),c=n(n.bind);e.exports=function(e,t){return a(e),void 0===t?e:o?c(e,t):function(){return e.apply(t,arguments)}}},6110:function(e,t,l){l(8111),l(1701),function(t,l){e.exports=l()}(0,function(){"use strict";var e={LTS:"h:mm:ss A",LT:"h:mm A",L:"MM/DD/YYYY",LL:"MMMM D, YYYY",LLL:"MMMM D, YYYY h:mm A",LLLL:"dddd, MMMM D, YYYY h:mm A"},t=/(\[[^[]*\])|([-_:/.,()\s]+)|(A|a|Q|YYYY|YY?|ww?|MM?M?M?|Do|DD?|hh?|HH?|mm?|ss?|S{1,3}|z|ZZ?)/g,l=/\d/,n=/\d\d/,a=/\d\d?/,o=/\d*[^-_:/,()\s\d]+/,c={},r=function(e){return(e=+e)+(e>68?1900:2e3)},s=function(e){return function(t){this[e]=+t}},i=[/[+-]\d\d:?(\d\d)?|Z/,function(e){(this.zone||(this.zone={})).offset=function(e){if(!e)return 0;if("Z"===e)return 0;var t=e.match(/([+-]|\d\d)/g),l=60*t[1]+(+t[2]||0);return 0===l?0:"+"===t[0]?-l:l}(e)}],u=function(e){var t=c[e];return t&&(t.indexOf?t:t.s.concat(t.f))},d=function(e,t){var l,n=c.meridiem;if(n){for(var a=1;a<=24;a+=1)if(e.indexOf(n(a,0,t))>-1){l=a>12;break}}else l=e===(t?"pm":"PM");return l},f={A:[o,function(e){this.afternoon=d(e,!1)}],a:[o,function(e){this.afternoon=d(e,!0)}],Q:[l,function(e){this.month=3*(e-1)+1}],S:[l,function(e){this.milliseconds=100*+e}],SS:[n,function(e){this.milliseconds=10*+e}],SSS:[/\d{3}/,function(e){this.milliseconds=+e}],s:[a,s("seconds")],ss:[a,s("seconds")],m:[a,s("minutes")],mm:[a,s("minutes")],H:[a,s("hours")],h:[a,s("hours")],HH:[a,s("hours")],hh:[a,s("hours")],D:[a,s("day")],DD:[n,s("day")],Do:[o,function(e){var t=c.ordinal,l=e.match(/\d+/);if(this.day=l[0],t)for(var n=1;n<=31;n+=1)t(n).replace(/\[|\]/g,"")===e&&(this.day=n)}],w:[a,s("week")],ww:[n,s("week")],M:[a,s("month")],MM:[n,s("month")],MMM:[o,function(e){var t=u("months"),l=(u("monthsShort")||t.map(function(e){return e.slice(0,3)})).indexOf(e)+1;if(l<1)throw new Error;this.month=l%12||l}],MMMM:[o,function(e){var t=u("months").indexOf(e)+1;if(t<1)throw new Error;this.month=t%12||t}],Y:[/[+-]?\d+/,s("year")],YY:[n,function(e){this.year=r(e)}],YYYY:[/\d{4}/,s("year")],Z:i,ZZ:i};function p(l){var n,a;n=l,a=c&&c.formats;for(var o=(l=n.replace(/(\[[^\]]+])|(LTS?|l{1,4}|L{1,4})/g,function(t,l,n){var o=n&&n.toUpperCase();return l||a[n]||e[n]||a[o].replace(/(\[[^\]]+])|(MMMM|MM|DD|dddd)/g,function(e,t,l){return t||l.slice(1)})})).match(t),r=o.length,s=0;s-1)return new Date(("X"===t?1e3:1)*e);var a=p(t)(e),o=a.year,c=a.month,r=a.day,s=a.hours,i=a.minutes,u=a.seconds,d=a.milliseconds,f=a.zone,m=a.week,v=new Date,h=r||(o||c?1:v.getDate()),g=o||v.getFullYear(),b=0;o&&!c||(b=c>0?c-1:v.getMonth());var y,C=s||0,w=i||0,L=u||0,x=d||0;return f?new Date(Date.UTC(g,b,h,C,w,L,x+60*f.offset*1e3)):l?new Date(Date.UTC(g,b,h,C,w,L,x)):(y=new Date(g,b,h,C,w,L,x),m&&(y=n(y).week(m).toDate()),y)}catch(e){return new Date("")}}(t,r,n,l),this.init(),d&&!0!==d&&(this.$L=this.locale(d).$L),u&&t!=this.format(r)&&(this.$d=new Date("")),c={}}else if(r instanceof Array)for(var f=r.length,m=1;m<=f;m+=1){o[1]=r[m-1];var v=l.apply(this,o);if(v.isValid()){this.$d=v.$d,this.$L=v.$L,this.init();break}m===f&&(this.$d=new Date(""))}else a.call(this,e)}}})},6119:function(e,t,l){"use strict";var n=l(5745),a=l(3392),o=n("keys");e.exports=function(e){return o[e]||(o[e]=a(e))}},6125:function(e,t,l){"use strict";l.d(t,{Ft:function(){return o},WB:function(){return a}});var n=l(7378);const a=["dialog","grid","group","listbox","menu","navigation","tooltip","tree"],o=(0,n.b_)({role:{type:String,values:a,default:"tooltip"}})},6139:function(e,t,l){"use strict";l.d(t,{CW:function(){return f},Yn:function(){return r},jO:function(){return u},oh:function(){return d},zv:function(){return s}});l(4114),l(8111),l(7588);var n=l(6768),a=l(4232),o=l(6894);const c="utils/vue/vnode";var r=(e=>(e[e["TEXT"]=1]="TEXT",e[e["CLASS"]=2]="CLASS",e[e["STYLE"]=4]="STYLE",e[e["PROPS"]=8]="PROPS",e[e["FULL_PROPS"]=16]="FULL_PROPS",e[e["HYDRATE_EVENTS"]=32]="HYDRATE_EVENTS",e[e["STABLE_FRAGMENT"]=64]="STABLE_FRAGMENT",e[e["KEYED_FRAGMENT"]=128]="KEYED_FRAGMENT",e[e["UNKEYED_FRAGMENT"]=256]="UNKEYED_FRAGMENT",e[e["NEED_PATCH"]=512]="NEED_PATCH",e[e["DYNAMIC_SLOTS"]=1024]="DYNAMIC_SLOTS",e[e["HOISTED"]=-1]="HOISTED",e[e["BAIL"]=-2]="BAIL",e))(r||{});function s(e){return(0,n.vv)(e)&&e.type===n.FK}function i(e){return(0,n.vv)(e)&&e.type===n.Mw}function u(e){return(0,n.vv)(e)&&!s(e)&&!i(e)}const d=e=>{if(!(0,n.vv)(e))return(0,o.U)(c,"[getNormalizedProps] must be a VNode"),{};const t=e.props||{},l=((0,n.vv)(e.type)?e.type.props:void 0)||{},r={};return Object.keys(l).forEach(e=>{(0,a.$3)(l[e],"default")&&(r[e]=l[e].default)}),Object.keys(t).forEach(e=>{r[(0,a.PT)(e)]=t[e]}),r},f=e=>{const t=(0,a.cy)(e)?e:[e],l=[];return t.forEach(e=>{var t;(0,a.cy)(e)?l.push(...f(e)):(0,n.vv)(e)&&(null==(t=e.component)?void 0:t.subTree)?l.push(e,...f(e.component.subTree)):(0,n.vv)(e)&&(0,a.cy)(e.children)?l.push(...f(e.children)):(0,n.vv)(e)&&2===e.shapeFlag?l.push(...f(e.type())):l.push(e)}),l}},6149:function(e,t,l){"use strict";l.d(t,{$:function(){return d},p:function(){return f}});var n=l(7477),a=l(3845),o=l(464),c=l(6769),r=l(8501),s=l(2056),i=l(7378),u=l(4232);const d=(0,i.b_)({id:{type:String,default:void 0},size:a.mU,disabled:{type:Boolean,default:void 0},modelValue:{type:(0,i.jq)([String,Number,Object]),default:""},modelModifiers:{type:(0,i.jq)(Object),default:()=>({})},maxlength:{type:[String,Number]},minlength:{type:[String,Number]},type:{type:(0,i.jq)(String),default:"text"},resize:{type:String,values:["none","both","horizontal","vertical"]},autosize:{type:(0,i.jq)([Boolean,Object]),default:!1},autocomplete:{type:(0,i.jq)(String),default:"off"},formatter:{type:Function},parser:{type:Function},placeholder:{type:String},form:{type:String},readonly:Boolean,clearable:Boolean,clearIcon:{type:o.Ze,default:n.CircleClose},showPassword:Boolean,showWordLimit:Boolean,wordLimitPosition:{type:String,values:["inside","outside"],default:"inside"},suffixIcon:{type:o.Ze},prefixIcon:{type:o.Ze},containerRole:{type:String,default:void 0},tabindex:{type:[String,Number],default:0},validateEvent:{type:Boolean,default:!0},inputStyle:{type:(0,i.jq)([Object,Array,String]),default:()=>(0,c.f)({})},autofocus:Boolean,rows:{type:Number,default:2},...(0,r.l)(["ariaLabel"]),inputmode:{type:(0,i.jq)(String),default:void 0},name:String}),f={[s.l4]:e=>(0,u.Kg)(e),input:e=>(0,u.Kg)(e),change:(e,t)=>(0,u.Kg)(e)&&(t instanceof Event||void 0===t),focus:e=>e instanceof FocusEvent,blur:e=>e instanceof FocusEvent,clear:()=>!0,mouseleave:e=>e instanceof MouseEvent,mouseenter:e=>e instanceof MouseEvent,keydown:e=>e instanceof Event,compositionstart:e=>e instanceof CompositionEvent,compositionupdate:e=>e instanceof CompositionEvent,compositionend:e=>e instanceof CompositionEvent}},6162:function(e,t,l){"use strict";l.d(t,{A:function(){return f}});var n=l(1591),a=l(2799),o="[object Arguments]";function c(e){return(0,a.A)(e)&&(0,n.A)(e)==o}var r=c,s=Object.prototype,i=s.hasOwnProperty,u=s.propertyIsEnumerable,d=r(function(){return arguments}())?r:function(e){return(0,a.A)(e)&&i.call(e,"callee")&&!u.call(e,"callee")},f=d},6166:function(e,t,l){"use strict";l.d(t,{A:function(){return m}});var n=l(5318),a=(l(4114),l(729)),o=l(9314),c=(0,o.A)(Object.keys,Object),r=c,s=Object.prototype,i=s.hasOwnProperty;function u(e){if(!(0,a.A)(e))return r(e);var t=[];for(var l in Object(e))i.call(e,l)&&"constructor"!=l&&t.push(l);return t}var d=u,f=l(1805);function p(e){return(0,f.A)(e)?(0,n.A)(e):d(e)}var m=p},6193:function(e,t,l){"use strict";var n=l(4215);e.exports="NODE"===n},6198:function(e,t,l){"use strict";var n=l(8014);e.exports=function(e){return n(e.length)}},6200:function(e,t,l){"use strict";l.d(t,{A:function(){return k}});l(6573),l(8100),l(7936);var n=l(7162),a=l(9578),o=(0,n.A)(a.A,"DataView"),c=o,r=l(6062),s=(0,n.A)(a.A,"Promise"),i=s,u=l(3452),d=(0,n.A)(a.A,"WeakMap"),f=d,p=l(1591),m=l(3534),v="[object Map]",h="[object Object]",g="[object Promise]",b="[object Set]",y="[object WeakMap]",C="[object DataView]",w=(0,m.A)(c),L=(0,m.A)(r.A),x=(0,m.A)(i),M=(0,m.A)(u.A),z=(0,m.A)(f),R=p.A;(c&&R(new c(new ArrayBuffer(1)))!=C||r.A&&R(new r.A)!=v||i&&R(i.resolve())!=g||u.A&&R(new u.A)!=b||f&&R(new f)!=y)&&(R=function(e){var t=(0,p.A)(e),l=t==h?e.constructor:void 0,n=l?(0,m.A)(l):"";if(n)switch(n){case w:return C;case L:return v;case x:return g;case M:return b;case z:return y}return t});var k=R},6268:function(e,t,l){"use strict";l.d(t,{vx:function(){return u},Ym:function(){return d}});var n=l(144),a=l(6768),o=l(9615),c={name:"en",el:{breadcrumb:{label:"Breadcrumb"},colorpicker:{confirm:"OK",clear:"Clear",defaultLabel:"color picker",description:"current color is {color}. press enter to select a new color.",alphaLabel:"pick alpha value",alphaDescription:"alpha {alpha}, current color is {color}",hueLabel:"pick hue value",hueDescription:"hue {hue}, current color is {color}",svLabel:"pick saturation and brightness value",svDescription:"saturation {saturation}, brightness {brightness}, current color is {color}",predefineDescription:"select {value} as the color"},datepicker:{now:"Now",today:"Today",cancel:"Cancel",clear:"Clear",confirm:"OK",dateTablePrompt:"Use the arrow keys and enter to select the day of the month",monthTablePrompt:"Use the arrow keys and enter to select the month",yearTablePrompt:"Use the arrow keys and enter to select the year",selectedDate:"Selected date",selectDate:"Select date",selectTime:"Select time",startDate:"Start Date",startTime:"Start Time",endDate:"End Date",endTime:"End Time",prevYear:"Previous Year",nextYear:"Next Year",prevMonth:"Previous Month",nextMonth:"Next Month",year:"",month1:"January",month2:"February",month3:"March",month4:"April",month5:"May",month6:"June",month7:"July",month8:"August",month9:"September",month10:"October",month11:"November",month12:"December",weeks:{sun:"Sun",mon:"Mon",tue:"Tue",wed:"Wed",thu:"Thu",fri:"Fri",sat:"Sat"},weeksFull:{sun:"Sunday",mon:"Monday",tue:"Tuesday",wed:"Wednesday",thu:"Thursday",fri:"Friday",sat:"Saturday"},months:{jan:"Jan",feb:"Feb",mar:"Mar",apr:"Apr",may:"May",jun:"Jun",jul:"Jul",aug:"Aug",sep:"Sep",oct:"Oct",nov:"Nov",dec:"Dec"}},inputNumber:{decrease:"decrease number",increase:"increase number"},select:{loading:"Loading",noMatch:"No matching data",noData:"No data",placeholder:"Select"},mention:{loading:"Loading"},dropdown:{toggleDropdown:"Toggle Dropdown"},cascader:{noMatch:"No matching data",loading:"Loading",placeholder:"Select",noData:"No data"},pagination:{goto:"Go to",pagesize:"/page",total:"Total {total}",pageClassifier:"",page:"Page",prev:"Go to previous page",next:"Go to next page",currentPage:"page {pager}",prevPages:"Previous {pager} pages",nextPages:"Next {pager} pages",deprecationWarning:"Deprecated usages detected, please refer to the el-pagination documentation for more details"},dialog:{close:"Close this dialog"},drawer:{close:"Close this dialog"},messagebox:{title:"Message",confirm:"OK",cancel:"Cancel",error:"Illegal input",close:"Close this dialog"},upload:{deleteTip:"press delete to remove",delete:"Delete",preview:"Preview",continue:"Continue"},slider:{defaultLabel:"slider between {min} and {max}",defaultRangeStartLabel:"pick start value",defaultRangeEndLabel:"pick end value"},table:{emptyText:"No Data",confirmFilter:"Confirm",resetFilter:"Reset",clearFilter:"All",sumText:"Sum",selectAllLabel:"Select all rows",selectRowLabel:"Select this row",expandRowLabel:"Expand this row",collapseRowLabel:"Collapse this row",sortLabel:"Sort by {column}",filterLabel:"Filter by {column}"},tag:{close:"Close this tag"},tour:{next:"Next",previous:"Previous",finish:"Finish",close:"Close this dialog"},tree:{emptyText:"No Data"},transfer:{noMatch:"No matching data",noData:"No data",titles:["List 1","List 2"],filterPlaceholder:"Enter keyword",noCheckedFormat:"{total} items",hasCheckedFormat:"{checked}/{total} checked"},image:{error:"FAILED"},pageHeader:{title:"Back"},popconfirm:{confirmButtonText:"Yes",cancelButtonText:"No"},carousel:{leftArrow:"Carousel arrow left",rightArrow:"Carousel arrow right",indicator:"Carousel switch to index {index}"}}};const r=e=>(t,l)=>s(t,l,(0,n.R1)(e)),s=(e,t,l)=>(0,o.A)(l,e,e).replace(/\{(\w+)\}/g,(e,l)=>{var n;return`${null!=(n=null==t?void 0:t[l])?n:`{${l}}`}`}),i=e=>{const t=(0,a.EW)(()=>(0,n.R1)(e).name),l=(0,n.i9)(e)?e:(0,n.KR)(e);return{lang:t,locale:l,t:r(e)}},u=Symbol("localeContextKey"),d=e=>{const t=e||(0,a.WQ)(u,(0,n.KR)());return i((0,a.EW)(()=>t.value||c))}},6269:function(e){"use strict";e.exports={}},6279:function(e,t,l){"use strict";var n=l(6840);e.exports=function(e,t,l){for(var a in t)n(e,a,t[a],l);return e}},6301:function(e,t,l){"use strict";l.d(t,{A:function(){return f}});var n=l(168),a=l(9578),o=function(){return a.A.Date.now()},c=o,r=l(754),s="Expected a function",i=Math.max,u=Math.min;function d(e,t,l){var a,o,d,f,p,m,v=0,h=!1,g=!1,b=!0;if("function"!=typeof e)throw new TypeError(s);function y(t){var l=a,n=o;return a=o=void 0,v=t,f=e.apply(n,l),f}function C(e){return v=e,p=setTimeout(x,t),h?y(e):f}function w(e){var l=e-m,n=e-v,a=t-l;return g?u(a,d-n):a}function L(e){var l=e-m,n=e-v;return void 0===m||l>=t||l<0||g&&n>=d}function x(){var e=c();if(L(e))return M(e);p=setTimeout(x,w(e))}function M(e){return p=void 0,b&&a?y(e):(a=o=void 0,f)}function z(){void 0!==p&&clearTimeout(p),v=0,a=m=o=p=void 0}function R(){return void 0===p?f:M(c())}function k(){var e=c(),l=L(e);if(a=arguments,o=this,m=e,l){if(void 0===p)return C(m);if(g)return clearTimeout(p),p=setTimeout(x,t),y(m)}return void 0===p&&(p=setTimeout(x,t)),f}return t=(0,r.A)(t)||0,(0,n.A)(l)&&(h=!!l.leading,g="maxWait"in l,d=g?i((0,r.A)(l.maxWait)||0,t):d,b="trailing"in l?!!l.trailing:b),k.cancel=z,k.flush=R,k}var f=d},6319:function(e,t,l){"use strict";var n=l(8551),a=l(9539);e.exports=function(e,t,l,o){try{return o?t(n(l)[0],l[1]):t(l)}catch(c){a(e,"throw",c)}}},6340:function(e,t,l){"use strict";l.d(t,{Hl:function(){return s},Lw:function(){return f},pW:function(){return d},rQ:function(){return u},tp:function(){return r},uG:function(){return c},xe:function(){return i}});l(8111),l(2489);const n='a[href],button:not([disabled]),button:not([hidden]),:not([tabindex="-1"]),input:not([disabled]),input:not([type="hidden"]),select:not([disabled]),textarea:not([disabled])',a=e=>"undefined"!==typeof Element&&e instanceof Element,o=e=>{const t=getComputedStyle(e);return"fixed"!==t.position&&null!==e.offsetParent},c=e=>Array.from(e.querySelectorAll(n)).filter(e=>r(e)&&o(e)),r=e=>{if(e.tabIndex>0||0===e.tabIndex&&null!==e.getAttribute("tabIndex"))return!0;if(e.tabIndex<0||e.hasAttribute("disabled")||"true"===e.getAttribute("aria-disabled"))return!1;switch(e.nodeName){case"A":return!!e.href&&"ignore"!==e.rel;case"INPUT":return!("hidden"===e.type||"file"===e.type);case"BUTTON":case"SELECT":case"TEXTAREA":return!0;default:return!1}},s=function(e,t,...l){let n;n=t.includes("mouse")||t.includes("click")?"MouseEvents":t.includes("key")?"KeyboardEvent":"HTMLEvents";const a=document.createEvent(n);return a.initEvent(t,...l),e.dispatchEvent(a),e},i=e=>!e.getAttribute("aria-owns"),u=(e,t,l)=>{const{parentNode:n}=e;if(!n)return null;const a=n.querySelectorAll(l),o=Array.prototype.indexOf.call(a,e);return a[o+t]||null},d=(e,t)=>{if(!e||!e.focus)return;let l=!1;!a(e)||r(e)||e.getAttribute("tabindex")||(e.setAttribute("tabindex","-1"),l=!0),e.focus(t),a(e)&&l&&e.removeAttribute("tabindex")},f=e=>{e&&(d(e),!i(e)&&e.click())}},6368:function(e,t,l){"use strict";var n=l(6518),a=l(4576),o=l(9225).clear;n({global:!0,bind:!0,enumerable:!0,forced:a.clearImmediate!==o},{clearImmediate:o})},6395:function(e){"use strict";e.exports=!1},6484:function(e,t,l){"use strict";l.d(t,{DD:function(){return h},n4:function(){return rt}});l(4114),l(8111),l(1148),l(2489),l(116),l(7588),l(1701),l(8237),l(3579),l(7642),l(8004),l(3853),l(5876),l(2475),l(5024),l(1698);var n="top",a="bottom",o="right",c="left",r="auto",s=[n,a,o,c],i="start",u="end",d="clippingParents",f="viewport",p="popper",m="reference",v=s.reduce(function(e,t){return e.concat([t+"-"+i,t+"-"+u])},[]),h=[].concat(s,[r]).reduce(function(e,t){return e.concat([t,t+"-"+i,t+"-"+u])},[]),g="beforeRead",b="read",y="afterRead",C="beforeMain",w="main",L="afterMain",x="beforeWrite",M="write",z="afterWrite",R=[g,b,y,C,w,L,x,M,z];function k(e){return e?(e.nodeName||"").toLowerCase():null}function S(e){if(null==e)return window;if("[object Window]"!==e.toString()){var t=e.ownerDocument;return t&&t.defaultView||window}return e}function E(e){var t=S(e).Element;return e instanceof t||e instanceof Element}function A(e){var t=S(e).HTMLElement;return e instanceof t||e instanceof HTMLElement}function N(e){if("undefined"==typeof ShadowRoot)return!1;var t=S(e).ShadowRoot;return e instanceof t||e instanceof ShadowRoot}function _(e){var t=e.state;Object.keys(t.elements).forEach(function(e){var l=t.styles[e]||{},n=t.attributes[e]||{},a=t.elements[e];!A(a)||!k(a)||(Object.assign(a.style,l),Object.keys(n).forEach(function(e){var t=n[e];!1===t?a.removeAttribute(e):a.setAttribute(e,!0===t?"":t)}))})}function T(e){var t=e.state,l={popper:{position:t.options.strategy,left:"0",top:"0",margin:"0"},arrow:{position:"absolute"},reference:{}};return Object.assign(t.elements.popper.style,l.popper),t.styles=l,t.elements.arrow&&Object.assign(t.elements.arrow.style,l.arrow),function(){Object.keys(t.elements).forEach(function(e){var n=t.elements[e],a=t.attributes[e]||{},o=Object.keys(t.styles.hasOwnProperty(e)?t.styles[e]:l[e]),c=o.reduce(function(e,t){return e[t]="",e},{});!A(n)||!k(n)||(Object.assign(n.style,c),Object.keys(a).forEach(function(e){n.removeAttribute(e)}))})}}var O={name:"applyStyles",enabled:!0,phase:"write",fn:_,effect:T,requires:["computeStyles"]};function W(e){return e.split("-")[0]}var B=Math.max,I=Math.min,D=Math.round;function F(e,t){void 0===t&&(t=!1);var l=e.getBoundingClientRect(),n=1,a=1;if(A(e)&&t){var o=e.offsetHeight,c=e.offsetWidth;c>0&&(n=D(l.width)/c||1),o>0&&(a=D(l.height)/o||1)}return{width:l.width/n,height:l.height/a,top:l.top/a,right:l.right/n,bottom:l.bottom/a,left:l.left/n,x:l.left/n,y:l.top/a}}function V(e){var t=F(e),l=e.offsetWidth,n=e.offsetHeight;return Math.abs(t.width-l)<=1&&(l=t.width),Math.abs(t.height-n)<=1&&(n=t.height),{x:e.offsetLeft,y:e.offsetTop,width:l,height:n}}function P(e,t){var l=t.getRootNode&&t.getRootNode();if(e.contains(t))return!0;if(l&&N(l)){var n=t;do{if(n&&e.isSameNode(n))return!0;n=n.parentNode||n.host}while(n)}return!1}function $(e){return S(e).getComputedStyle(e)}function H(e){return["table","td","th"].indexOf(k(e))>=0}function j(e){return((E(e)?e.ownerDocument:e.document)||window.document).documentElement}function K(e){return"html"===k(e)?e:e.assignedSlot||e.parentNode||(N(e)?e.host:null)||j(e)}function X(e){return A(e)&&"fixed"!==$(e).position?e.offsetParent:null}function U(e){var t=-1!==navigator.userAgent.toLowerCase().indexOf("firefox"),l=-1!==navigator.userAgent.indexOf("Trident");if(l&&A(e)){var n=$(e);if("fixed"===n.position)return null}var a=K(e);for(N(a)&&(a=a.host);A(a)&&["html","body"].indexOf(k(a))<0;){var o=$(a);if("none"!==o.transform||"none"!==o.perspective||"paint"===o.contain||-1!==["transform","perspective"].indexOf(o.willChange)||t&&"filter"===o.willChange||t&&o.filter&&"none"!==o.filter)return a;a=a.parentNode}return null}function q(e){for(var t=S(e),l=X(e);l&&H(l)&&"static"===$(l).position;)l=X(l);return l&&("html"===k(l)||"body"===k(l)&&"static"===$(l).position)?t:l||U(e)||t}function G(e){return["top","bottom"].indexOf(e)>=0?"x":"y"}function Y(e,t,l){return B(e,I(t,l))}function Q(e,t,l){var n=Y(e,t,l);return n>l?l:n}function Z(){return{top:0,right:0,bottom:0,left:0}}function J(e){return Object.assign({},Z(),e)}function ee(e,t){return t.reduce(function(t,l){return t[l]=e,t},{})}var te=function(e,t){return e="function"==typeof e?e(Object.assign({},t.rects,{placement:t.placement})):e,J("number"!=typeof e?e:ee(e,s))};function le(e){var t,l=e.state,r=e.name,s=e.options,i=l.elements.arrow,u=l.modifiersData.popperOffsets,d=W(l.placement),f=G(d),p=[c,o].indexOf(d)>=0,m=p?"height":"width";if(i&&u){var v=te(s.padding,l),h=V(i),g="y"===f?n:c,b="y"===f?a:o,y=l.rects.reference[m]+l.rects.reference[f]-u[f]-l.rects.popper[m],C=u[f]-l.rects.reference[f],w=q(i),L=w?"y"===f?w.clientHeight||0:w.clientWidth||0:0,x=y/2-C/2,M=v[g],z=L-h[m]-v[b],R=L/2-h[m]/2+x,k=Y(M,R,z),S=f;l.modifiersData[r]=(t={},t[S]=k,t.centerOffset=k-R,t)}}function ne(e){var t=e.state,l=e.options,n=l.element,a=void 0===n?"[data-popper-arrow]":n;null!=a&&("string"==typeof a&&(a=t.elements.popper.querySelector(a),!a)||!P(t.elements.popper,a)||(t.elements.arrow=a))}var ae={name:"arrow",enabled:!0,phase:"main",fn:le,effect:ne,requires:["popperOffsets"],requiresIfExists:["preventOverflow"]};function oe(e){return e.split("-")[1]}var ce={top:"auto",right:"auto",bottom:"auto",left:"auto"};function re(e){var t=e.x,l=e.y,n=window,a=n.devicePixelRatio||1;return{x:D(t*a)/a||0,y:D(l*a)/a||0}}function se(e){var t,l=e.popper,r=e.popperRect,s=e.placement,i=e.variation,d=e.offsets,f=e.position,p=e.gpuAcceleration,m=e.adaptive,v=e.roundOffsets,h=e.isFixed,g=d.x,b=void 0===g?0:g,y=d.y,C=void 0===y?0:y,w="function"==typeof v?v({x:b,y:C}):{x:b,y:C};b=w.x,C=w.y;var L=d.hasOwnProperty("x"),x=d.hasOwnProperty("y"),M=c,z=n,R=window;if(m){var k=q(l),E="clientHeight",A="clientWidth";if(k===S(l)&&(k=j(l),"static"!==$(k).position&&"absolute"===f&&(E="scrollHeight",A="scrollWidth")),s===n||(s===c||s===o)&&i===u){z=a;var N=h&&k===R&&R.visualViewport?R.visualViewport.height:k[E];C-=N-r.height,C*=p?1:-1}if(s===c||(s===n||s===a)&&i===u){M=o;var _=h&&k===R&&R.visualViewport?R.visualViewport.width:k[A];b-=_-r.width,b*=p?1:-1}}var T,O=Object.assign({position:f},m&&ce),W=!0===v?re({x:b,y:C}):{x:b,y:C};return b=W.x,C=W.y,p?Object.assign({},O,(T={},T[z]=x?"0":"",T[M]=L?"0":"",T.transform=(R.devicePixelRatio||1)<=1?"translate("+b+"px, "+C+"px)":"translate3d("+b+"px, "+C+"px, 0)",T)):Object.assign({},O,(t={},t[z]=x?C+"px":"",t[M]=L?b+"px":"",t.transform="",t))}function ie(e){var t=e.state,l=e.options,n=l.gpuAcceleration,a=void 0===n||n,o=l.adaptive,c=void 0===o||o,r=l.roundOffsets,s=void 0===r||r,i={placement:W(t.placement),variation:oe(t.placement),popper:t.elements.popper,popperRect:t.rects.popper,gpuAcceleration:a,isFixed:"fixed"===t.options.strategy};null!=t.modifiersData.popperOffsets&&(t.styles.popper=Object.assign({},t.styles.popper,se(Object.assign({},i,{offsets:t.modifiersData.popperOffsets,position:t.options.strategy,adaptive:c,roundOffsets:s})))),null!=t.modifiersData.arrow&&(t.styles.arrow=Object.assign({},t.styles.arrow,se(Object.assign({},i,{offsets:t.modifiersData.arrow,position:"absolute",adaptive:!1,roundOffsets:s})))),t.attributes.popper=Object.assign({},t.attributes.popper,{"data-popper-placement":t.placement})}var ue={name:"computeStyles",enabled:!0,phase:"beforeWrite",fn:ie,data:{}},de={passive:!0};function fe(e){var t=e.state,l=e.instance,n=e.options,a=n.scroll,o=void 0===a||a,c=n.resize,r=void 0===c||c,s=S(t.elements.popper),i=[].concat(t.scrollParents.reference,t.scrollParents.popper);return o&&i.forEach(function(e){e.addEventListener("scroll",l.update,de)}),r&&s.addEventListener("resize",l.update,de),function(){o&&i.forEach(function(e){e.removeEventListener("scroll",l.update,de)}),r&&s.removeEventListener("resize",l.update,de)}}var pe={name:"eventListeners",enabled:!0,phase:"write",fn:function(){},effect:fe,data:{}},me={left:"right",right:"left",bottom:"top",top:"bottom"};function ve(e){return e.replace(/left|right|bottom|top/g,function(e){return me[e]})}var he={start:"end",end:"start"};function ge(e){return e.replace(/start|end/g,function(e){return he[e]})}function be(e){var t=S(e),l=t.pageXOffset,n=t.pageYOffset;return{scrollLeft:l,scrollTop:n}}function ye(e){return F(j(e)).left+be(e).scrollLeft}function Ce(e){var t=S(e),l=j(e),n=t.visualViewport,a=l.clientWidth,o=l.clientHeight,c=0,r=0;return n&&(a=n.width,o=n.height,/^((?!chrome|android).)*safari/i.test(navigator.userAgent)||(c=n.offsetLeft,r=n.offsetTop)),{width:a,height:o,x:c+ye(e),y:r}}function we(e){var t,l=j(e),n=be(e),a=null==(t=e.ownerDocument)?void 0:t.body,o=B(l.scrollWidth,l.clientWidth,a?a.scrollWidth:0,a?a.clientWidth:0),c=B(l.scrollHeight,l.clientHeight,a?a.scrollHeight:0,a?a.clientHeight:0),r=-n.scrollLeft+ye(e),s=-n.scrollTop;return"rtl"===$(a||l).direction&&(r+=B(l.clientWidth,a?a.clientWidth:0)-o),{width:o,height:c,x:r,y:s}}function Le(e){var t=$(e),l=t.overflow,n=t.overflowX,a=t.overflowY;return/auto|scroll|overlay|hidden/.test(l+a+n)}function xe(e){return["html","body","#document"].indexOf(k(e))>=0?e.ownerDocument.body:A(e)&&Le(e)?e:xe(K(e))}function Me(e,t){var l;void 0===t&&(t=[]);var n=xe(e),a=n===(null==(l=e.ownerDocument)?void 0:l.body),o=S(n),c=a?[o].concat(o.visualViewport||[],Le(n)?n:[]):n,r=t.concat(c);return a?r:r.concat(Me(K(c)))}function ze(e){return Object.assign({},e,{left:e.x,top:e.y,right:e.x+e.width,bottom:e.y+e.height})}function Re(e){var t=F(e);return t.top=t.top+e.clientTop,t.left=t.left+e.clientLeft,t.bottom=t.top+e.clientHeight,t.right=t.left+e.clientWidth,t.width=e.clientWidth,t.height=e.clientHeight,t.x=t.left,t.y=t.top,t}function ke(e,t){return t===f?ze(Ce(e)):E(t)?Re(t):ze(we(j(e)))}function Se(e){var t=Me(K(e)),l=["absolute","fixed"].indexOf($(e).position)>=0,n=l&&A(e)?q(e):e;return E(n)?t.filter(function(e){return E(e)&&P(e,n)&&"body"!==k(e)}):[]}function Ee(e,t,l){var n="clippingParents"===t?Se(e):[].concat(t),a=[].concat(n,[l]),o=a[0],c=a.reduce(function(t,l){var n=ke(e,l);return t.top=B(n.top,t.top),t.right=I(n.right,t.right),t.bottom=I(n.bottom,t.bottom),t.left=B(n.left,t.left),t},ke(e,o));return c.width=c.right-c.left,c.height=c.bottom-c.top,c.x=c.left,c.y=c.top,c}function Ae(e){var t,l=e.reference,r=e.element,s=e.placement,d=s?W(s):null,f=s?oe(s):null,p=l.x+l.width/2-r.width/2,m=l.y+l.height/2-r.height/2;switch(d){case n:t={x:p,y:l.y-r.height};break;case a:t={x:p,y:l.y+l.height};break;case o:t={x:l.x+l.width,y:m};break;case c:t={x:l.x-r.width,y:m};break;default:t={x:l.x,y:l.y}}var v=d?G(d):null;if(null!=v){var h="y"===v?"height":"width";switch(f){case i:t[v]=t[v]-(l[h]/2-r[h]/2);break;case u:t[v]=t[v]+(l[h]/2-r[h]/2);break}}return t}function Ne(e,t){void 0===t&&(t={});var l=t,c=l.placement,r=void 0===c?e.placement:c,i=l.boundary,u=void 0===i?d:i,v=l.rootBoundary,h=void 0===v?f:v,g=l.elementContext,b=void 0===g?p:g,y=l.altBoundary,C=void 0!==y&&y,w=l.padding,L=void 0===w?0:w,x=J("number"!=typeof L?L:ee(L,s)),M=b===p?m:p,z=e.rects.popper,R=e.elements[C?M:b],k=Ee(E(R)?R:R.contextElement||j(e.elements.popper),u,h),S=F(e.elements.reference),A=Ae({reference:S,element:z,strategy:"absolute",placement:r}),N=ze(Object.assign({},z,A)),_=b===p?N:S,T={top:k.top-_.top+x.top,bottom:_.bottom-k.bottom+x.bottom,left:k.left-_.left+x.left,right:_.right-k.right+x.right},O=e.modifiersData.offset;if(b===p&&O){var W=O[r];Object.keys(T).forEach(function(e){var t=[o,a].indexOf(e)>=0?1:-1,l=[n,a].indexOf(e)>=0?"y":"x";T[e]+=W[l]*t})}return T}function _e(e,t){void 0===t&&(t={});var l=t,n=l.placement,a=l.boundary,o=l.rootBoundary,c=l.padding,r=l.flipVariations,i=l.allowedAutoPlacements,u=void 0===i?h:i,d=oe(n),f=d?r?v:v.filter(function(e){return oe(e)===d}):s,p=f.filter(function(e){return u.indexOf(e)>=0});0===p.length&&(p=f);var m=p.reduce(function(t,l){return t[l]=Ne(e,{placement:l,boundary:a,rootBoundary:o,padding:c})[W(l)],t},{});return Object.keys(m).sort(function(e,t){return m[e]-m[t]})}function Te(e){if(W(e)===r)return[];var t=ve(e);return[ge(e),t,ge(t)]}function Oe(e){var t=e.state,l=e.options,s=e.name;if(!t.modifiersData[s]._skip){for(var u=l.mainAxis,d=void 0===u||u,f=l.altAxis,p=void 0===f||f,m=l.fallbackPlacements,v=l.padding,h=l.boundary,g=l.rootBoundary,b=l.altBoundary,y=l.flipVariations,C=void 0===y||y,w=l.allowedAutoPlacements,L=t.options.placement,x=W(L),M=x===L,z=m||(M||!C?[ve(L)]:Te(L)),R=[L].concat(z).reduce(function(e,l){return e.concat(W(l)===r?_e(t,{placement:l,boundary:h,rootBoundary:g,padding:v,flipVariations:C,allowedAutoPlacements:w}):l)},[]),k=t.rects.reference,S=t.rects.popper,E=new Map,A=!0,N=R[0],_=0;_=0,D=I?"width":"height",F=Ne(t,{placement:T,boundary:h,rootBoundary:g,altBoundary:b,padding:v}),V=I?B?o:c:B?a:n;k[D]>S[D]&&(V=ve(V));var P=ve(V),$=[];if(d&&$.push(F[O]<=0),p&&$.push(F[V]<=0,F[P]<=0),$.every(function(e){return e})){N=T,A=!1;break}E.set(T,$)}if(A)for(var H=C?3:1,j=function(e){var t=R.find(function(t){var l=E.get(t);if(l)return l.slice(0,e).every(function(e){return e})});if(t)return N=t,"break"},K=H;K>0;K--){var X=j(K);if("break"===X)break}t.placement!==N&&(t.modifiersData[s]._skip=!0,t.placement=N,t.reset=!0)}}var We={name:"flip",enabled:!0,phase:"main",fn:Oe,requiresIfExists:["offset"],data:{_skip:!1}};function Be(e,t,l){return void 0===l&&(l={x:0,y:0}),{top:e.top-t.height-l.y,right:e.right-t.width+l.x,bottom:e.bottom-t.height+l.y,left:e.left-t.width-l.x}}function Ie(e){return[n,o,a,c].some(function(t){return e[t]>=0})}function De(e){var t=e.state,l=e.name,n=t.rects.reference,a=t.rects.popper,o=t.modifiersData.preventOverflow,c=Ne(t,{elementContext:"reference"}),r=Ne(t,{altBoundary:!0}),s=Be(c,n),i=Be(r,a,o),u=Ie(s),d=Ie(i);t.modifiersData[l]={referenceClippingOffsets:s,popperEscapeOffsets:i,isReferenceHidden:u,hasPopperEscaped:d},t.attributes.popper=Object.assign({},t.attributes.popper,{"data-popper-reference-hidden":u,"data-popper-escaped":d})}var Fe={name:"hide",enabled:!0,phase:"main",requiresIfExists:["preventOverflow"],fn:De};function Ve(e,t,l){var a=W(e),r=[c,n].indexOf(a)>=0?-1:1,s="function"==typeof l?l(Object.assign({},t,{placement:e})):l,i=s[0],u=s[1];return i=i||0,u=(u||0)*r,[c,o].indexOf(a)>=0?{x:u,y:i}:{x:i,y:u}}function Pe(e){var t=e.state,l=e.options,n=e.name,a=l.offset,o=void 0===a?[0,0]:a,c=h.reduce(function(e,l){return e[l]=Ve(l,t.rects,o),e},{}),r=c[t.placement],s=r.x,i=r.y;null!=t.modifiersData.popperOffsets&&(t.modifiersData.popperOffsets.x+=s,t.modifiersData.popperOffsets.y+=i),t.modifiersData[n]=c}var $e={name:"offset",enabled:!0,phase:"main",requires:["popperOffsets"],fn:Pe};function He(e){var t=e.state,l=e.name;t.modifiersData[l]=Ae({reference:t.rects.reference,element:t.rects.popper,strategy:"absolute",placement:t.placement})}var je={name:"popperOffsets",enabled:!0,phase:"read",fn:He,data:{}};function Ke(e){return"x"===e?"y":"x"}function Xe(e){var t=e.state,l=e.options,r=e.name,s=l.mainAxis,u=void 0===s||s,d=l.altAxis,f=void 0!==d&&d,p=l.boundary,m=l.rootBoundary,v=l.altBoundary,h=l.padding,g=l.tether,b=void 0===g||g,y=l.tetherOffset,C=void 0===y?0:y,w=Ne(t,{boundary:p,rootBoundary:m,padding:h,altBoundary:v}),L=W(t.placement),x=oe(t.placement),M=!x,z=G(L),R=Ke(z),k=t.modifiersData.popperOffsets,S=t.rects.reference,E=t.rects.popper,A="function"==typeof C?C(Object.assign({},t.rects,{placement:t.placement})):C,N="number"==typeof A?{mainAxis:A,altAxis:A}:Object.assign({mainAxis:0,altAxis:0},A),_=t.modifiersData.offset?t.modifiersData.offset[t.placement]:null,T={x:0,y:0};if(k){if(u){var O,D="y"===z?n:c,F="y"===z?a:o,P="y"===z?"height":"width",$=k[z],H=$+w[D],j=$-w[F],K=b?-E[P]/2:0,X=x===i?S[P]:E[P],U=x===i?-E[P]:-S[P],J=t.elements.arrow,ee=b&&J?V(J):{width:0,height:0},te=t.modifiersData["arrow#persistent"]?t.modifiersData["arrow#persistent"].padding:Z(),le=te[D],ne=te[F],ae=Y(0,S[P],ee[P]),ce=M?S[P]/2-K-ae-le-N.mainAxis:X-ae-le-N.mainAxis,re=M?-S[P]/2+K+ae+ne+N.mainAxis:U+ae+ne+N.mainAxis,se=t.elements.arrow&&q(t.elements.arrow),ie=se?"y"===z?se.clientTop||0:se.clientLeft||0:0,ue=null!=(O=null==_?void 0:_[z])?O:0,de=$+ce-ue-ie,fe=$+re-ue,pe=Y(b?I(H,de):H,$,b?B(j,fe):j);k[z]=pe,T[z]=pe-$}if(f){var me,ve="x"===z?n:c,he="x"===z?a:o,ge=k[R],be="y"===R?"height":"width",ye=ge+w[ve],Ce=ge-w[he],we=-1!==[n,c].indexOf(L),Le=null!=(me=null==_?void 0:_[R])?me:0,xe=we?ye:ge-S[be]-E[be]-Le+N.altAxis,Me=we?ge+S[be]+E[be]-Le-N.altAxis:Ce,ze=b&&we?Q(xe,ge,Me):Y(b?xe:ye,ge,b?Me:Ce);k[R]=ze,T[R]=ze-ge}t.modifiersData[r]=T}}var Ue={name:"preventOverflow",enabled:!0,phase:"main",fn:Xe,requiresIfExists:["offset"]};function qe(e){return{scrollLeft:e.scrollLeft,scrollTop:e.scrollTop}}function Ge(e){return e!==S(e)&&A(e)?qe(e):be(e)}function Ye(e){var t=e.getBoundingClientRect(),l=D(t.width)/e.offsetWidth||1,n=D(t.height)/e.offsetHeight||1;return 1!==l||1!==n}function Qe(e,t,l){void 0===l&&(l=!1);var n=A(t),a=A(t)&&Ye(t),o=j(t),c=F(e,a),r={scrollLeft:0,scrollTop:0},s={x:0,y:0};return(n||!n&&!l)&&(("body"!==k(t)||Le(o))&&(r=Ge(t)),A(t)?(s=F(t,!0),s.x+=t.clientLeft,s.y+=t.clientTop):o&&(s.x=ye(o))),{x:c.left+r.scrollLeft-s.x,y:c.top+r.scrollTop-s.y,width:c.width,height:c.height}}function Ze(e){var t=new Map,l=new Set,n=[];function a(e){l.add(e.name);var o=[].concat(e.requires||[],e.requiresIfExists||[]);o.forEach(function(e){if(!l.has(e)){var n=t.get(e);n&&a(n)}}),n.push(e)}return e.forEach(function(e){t.set(e.name,e)}),e.forEach(function(e){l.has(e.name)||a(e)}),n}function Je(e){var t=Ze(e);return R.reduce(function(e,l){return e.concat(t.filter(function(e){return e.phase===l}))},[])}function et(e){var t;return function(){return t||(t=new Promise(function(l){Promise.resolve().then(function(){t=void 0,l(e())})})),t}}function tt(e){var t=e.reduce(function(e,t){var l=e[t.name];return e[t.name]=l?Object.assign({},l,t,{options:Object.assign({},l.options,t.options),data:Object.assign({},l.data,t.data)}):t,e},{});return Object.keys(t).map(function(e){return t[e]})}var lt={placement:"bottom",modifiers:[],strategy:"absolute"};function nt(){for(var e=arguments.length,t=new Array(e),l=0;l1?arguments[1]:void 0,this,this.length);return{read:t.read,written:t.written}}})},6636:function(e,t,l){"use strict";l.d(t,{A:function(){return m}});var n=l(5318),a=(l(4114),l(168)),o=l(729);function c(e){var t=[];if(null!=e)for(var l in Object(e))t.push(l);return t}var r=c,s=Object.prototype,i=s.hasOwnProperty;function u(e){if(!(0,a.A)(e))return r(e);var t=(0,o.A)(e),l=[];for(var n in e)("constructor"!=n||!t&&i.call(e,n))&&l.push(n);return l}var d=u,f=l(1805);function p(e){return(0,f.A)(e)?(0,n.A)(e,!0):d(e)}var m=p},6690:function(e,t,l){"use strict";var n=l(1805),a=l(2799);function o(e){return(0,a.A)(e)&&(0,n.A)(e)}t.A=o},6697:function(e,t,l){"use strict";l.d(t,{Cg:function(){return g},KR:function(){return b},N9:function(){return C},OX:function(){return c},Tc:function(){return n},U4:function(){return w},UZ:function(){return i},Wc:function(){return r},Y5:function(){return f},YF:function(){return s},bx:function(){return p},k0:function(){return o},rX:function(){return h},sr:function(){return y},tT:function(){return m},v_:function(){return d},xG:function(){return a},zf:function(){return v},zj:function(){return u}});const n=50,a="itemRendered",o="scroll",c="forward",r="backward",s="auto",i="smart",u="start",d="center",f="end",p="horizontal",m="vertical",v="ltr",h="rtl",g="negative",b="positive-ascending",y="positive-descending",C={[p]:"left",[m]:"top"},w=20},6699:function(e,t,l){"use strict";var n=l(3724),a=l(4913),o=l(6980);e.exports=n?function(e,t,l){return a.f(e,t,o(1,l))}:function(e,t,l){return e[t]=l,e}},6706:function(e,t,l){"use strict";var n=l(9504),a=l(9306);e.exports=function(e,t,l){try{return n(a(Object.getOwnPropertyDescriptor(e,t)[l]))}catch(o){}}},6711:function(e,t,l){"use strict";l(5331)},6714:function(e,t,l){"use strict";l.d(t,{_q:function(){return f}});var n=l(6768),a=l(1968),o=l(6139),c=l(7378),r=l(3513);const s=(0,c.b_)({mask:{type:Boolean,default:!0},customMaskEvent:Boolean,overlayClass:{type:(0,c.jq)([String,Array,Object])},zIndex:{type:(0,c.jq)([String,Number])}}),i={click:e=>e instanceof MouseEvent},u="overlay";var d=(0,n.pM)({name:"ElOverlay",props:s,emits:i,setup(e,{slots:t,emit:l}){const c=(0,r.DU)(u),s=e=>{l("click",e)},{onClick:i,onMousedown:d,onMouseup:f}=(0,a.r)(e.customMaskEvent?void 0:s);return()=>e.mask?(0,n.bF)("div",{class:[c.b(),e.overlayClass],style:{zIndex:e.zIndex},onClick:i,onMousedown:d,onMouseup:f},[(0,n.RG)(t,"default")],o.Yn.STYLE|o.Yn.CLASS|o.Yn.PROPS,["onClick","onMouseup","onMousedown"]):(0,n.h)("div",{class:e.overlayClass,style:{zIndex:e.zIndex,position:"fixed",top:"0px",right:"0px",bottom:"0px",left:"0px"}},[(0,n.RG)(t,"default")])}});const f=d},6768:function(e,t,l){"use strict";l.d(t,{$u:function(){return Me},$y:function(){return We},CE:function(){return zl},Df:function(){return ae},E3:function(){return Wl},EW:function(){return pn},EY:function(){return vl},FK:function(){return ml},Fv:function(){return Il},Gt:function(){return gt},Gy:function(){return X},Ht:function(){return qe},Ic:function(){return xe},Im:function(){return P},K9:function(){return nl},KC:function(){return we},Lk:function(){return Nl},MZ:function(){return ne},Mw:function(){return hl},Ng:function(){return Ol},OA:function(){return Ge},OW:function(){return ee},Q3:function(){return Dl},QP:function(){return q},R8:function(){return hn},RG:function(){return Pe},Tb:function(){return He},WQ:function(){return bt},Wv:function(){return Rl},Y4:function(){return me},bF:function(){return _l},bo:function(){return E},dY:function(){return h},eW:function(){return Bl},eX:function(){return Ve},g2:function(){return Te},gN:function(){return Be},h:function(){return mn},hi:function(){return Re},k6:function(){return S},n:function(){return pe},nI:function(){return ql},nT:function(){return wt},pI:function(){return Fe},pM:function(){return oe},pR:function(){return Z},qL:function(){return c},rE:function(){return vn},sV:function(){return Le},uX:function(){return Cl},v6:function(){return $l},vv:function(){return kl},wB:function(){return Lt},xo:function(){return ze}});l(4114),l(8111),l(1148),l(2489),l(7588),l(1701),l(8237),l(3579),l(3110),l(7642),l(8004),l(3853),l(5876),l(2475),l(5024),l(1698);var n=l(144),a=l(4232);function o(e,t,l,n){try{return n?e(...n):e()}catch(a){r(a,t,l)}}function c(e,t,l,n){if((0,a.Tn)(e)){const c=o(e,t,l,n);return c&&(0,a.yL)(c)&&c.catch(e=>{r(e,t,l)}),c}if((0,a.cy)(e)){const a=[];for(let o=0;o>>1,a=i[n],o=x(a);o=x(l)?i.push(e):i.splice(g(t),0,e),e.flags|=1,y()}}function y(){v||(v=m.then(M))}function C(e){(0,a.cy)(e)?d.push(...e):f&&-1===e.id?f.splice(p+1,0,e):1&e.flags||(d.push(e),e.flags|=1),y()}function w(e,t,l=u+1){for(0;lx(e)-x(t));if(d.length=0,f)return void f.push(...e);for(f=e,p=0;pnull==e.id?2&e.flags?-1:1/0:e.id;function M(e){a.tE;try{for(u=0;u{n._d&&xl(-1);const a=k(t);let o;try{o=e(...l)}finally{k(a),n._d&&xl(1)}return o};return n._n=!0,n._c=!0,n._d=!0,n}function E(e,t){if(null===z)return e;const l=un(z),o=e.dirs||(e.dirs=[]);for(let c=0;ce.__isTeleport,T=e=>e&&(e.disabled||""===e.disabled),O=e=>e&&(e.defer||""===e.defer),W=e=>"undefined"!==typeof SVGElement&&e instanceof SVGElement,B=e=>"function"===typeof MathMLElement&&e instanceof MathMLElement,I=(e,t)=>{const l=e&&e.to;if((0,a.Kg)(l)){if(t){const e=t(l);return e}return null}return l},D={name:"Teleport",__isTeleport:!0,process(e,t,l,n,a,o,c,r,s,i){const{mc:u,pc:d,pbc:f,o:{insert:p,querySelector:m,createText:v,createComment:h}}=i,g=T(t.props);let{shapeFlag:b,children:y,dynamicChildren:C}=t;if(null==e){const e=t.el=v(""),i=t.anchor=v("");p(e,l,n),p(i,l,n);const d=(e,t)=>{16&b&&u(y,e,t,a,o,c,r,s)},f=()=>{const e=t.target=I(t.props,m),l=H(e,t,v,p);e&&("svg"!==c&&W(e)?c="svg":"mathml"!==c&&B(e)&&(c="mathml"),a&&a.isCE&&(a.ce._teleportTargets||(a.ce._teleportTargets=new Set)).add(e),g||(d(e,l),$(t,!1)))};g&&(d(l,i),$(t,!0)),O(t.props)?(t.el.__isMounted=!1,ll(()=>{f(),delete t.el.__isMounted},o)):f()}else{if(O(t.props)&&!1===e.el.__isMounted)return void ll(()=>{D.process(e,t,l,n,a,o,c,r,s,i)},o);t.el=e.el,t.targetStart=e.targetStart;const u=t.anchor=e.anchor,p=t.target=e.target,v=t.targetAnchor=e.targetAnchor,h=T(e.props),b=h?l:p,y=h?u:v;if("svg"===c||W(p)?c="svg":("mathml"===c||B(p))&&(c="mathml"),C?(f(e.dynamicChildren,C,b,a,o,c,r),sl(e,t,!0)):s||d(e,t,b,y,a,o,c,r,!1),g)h?t.props&&e.props&&t.props.to!==e.props.to&&(t.props.to=e.props.to):F(t,l,u,i,1);else if((t.props&&t.props.to)!==(e.props&&e.props.to)){const e=t.target=I(t.props,m);e&&F(t,e,null,i,0)}else h&&F(t,p,v,i,1);$(t,g)}},remove(e,t,l,{um:n,o:{remove:a}},o){const{shapeFlag:c,children:r,anchor:s,targetStart:i,targetAnchor:u,target:d,props:f}=e;if(d&&(a(i),a(u)),o&&a(s),16&c){const e=o||!T(f);for(let a=0;a{e.isMounted=!0}),ze(()=>{e.isUnmounting=!0}),e}const U=[Function,Array],q={mode:String,appear:Boolean,persisted:Boolean,onBeforeEnter:U,onEnter:U,onAfterEnter:U,onEnterCancelled:U,onBeforeLeave:U,onLeave:U,onAfterLeave:U,onLeaveCancelled:U,onBeforeAppear:U,onAppear:U,onAfterAppear:U,onAppearCancelled:U},G=e=>{const t=e.subTree;return t.component?G(t.component):t},Y={name:"BaseTransition",props:q,setup(e,{slots:t}){const l=ql(),a=X();return()=>{const o=t.default&&ae(t.default(),!0);if(!o||!o.length)return;const c=Q(o),r=(0,n.ux)(e),{mode:s}=r;if(a.isLeaving)return te(c);const i=le(c);if(!i)return te(c);let u=ee(i,r,a,l,e=>u=e);i.type!==hl&&ne(i,u);let d=l.subTree&&le(l.subTree);if(d&&d.type!==hl&&!Sl(d,i)&&G(l).type!==hl){let e=ee(d,r,a,l);if(ne(d,e),"out-in"===s&&i.type!==hl)return a.isLeaving=!0,e.afterLeave=()=>{a.isLeaving=!1,8&l.job.flags||l.update(),delete e.afterLeave,d=void 0},te(c);"in-out"===s&&i.type!==hl?e.delayLeave=(e,t,l)=>{const n=J(a,d);n[String(d.key)]=d,e[j]=()=>{t(),e[j]=void 0,delete u.delayedLeave,d=void 0},u.delayedLeave=()=>{l(),delete u.delayedLeave,d=void 0}}:d=void 0}else d&&(d=void 0);return c}}};function Q(e){let t=e[0];if(e.length>1){let l=!1;for(const n of e)if(n.type!==hl){0,t=n,l=!0;break}}return t}const Z=Y;function J(e,t){const{leavingVNodes:l}=e;let n=l.get(t.type);return n||(n=Object.create(null),l.set(t.type,n)),n}function ee(e,t,l,n,o){const{appear:r,mode:s,persisted:i=!1,onBeforeEnter:u,onEnter:d,onAfterEnter:f,onEnterCancelled:p,onBeforeLeave:m,onLeave:v,onAfterLeave:h,onLeaveCancelled:g,onBeforeAppear:b,onAppear:y,onAfterAppear:C,onAppearCancelled:w}=t,L=String(e.key),x=J(l,e),M=(e,t)=>{e&&c(e,n,9,t)},z=(e,t)=>{const l=t[1];M(e,t),(0,a.cy)(e)?e.every(e=>e.length<=1)&&l():e.length<=1&&l()},R={mode:s,persisted:i,beforeEnter(t){let n=u;if(!l.isMounted){if(!r)return;n=b||u}t[j]&&t[j](!0);const a=x[L];a&&Sl(e,a)&&a.el[j]&&a.el[j](),M(n,[t])},enter(e){let t=d,n=f,a=p;if(!l.isMounted){if(!r)return;t=y||d,n=C||f,a=w||p}let o=!1;const c=e[K]=t=>{o||(o=!0,M(t?a:n,[e]),R.delayedLeave&&R.delayedLeave(),e[K]=void 0)};t?z(t,[e,c]):c()},leave(t,n){const a=String(e.key);if(t[K]&&t[K](!0),l.isUnmounting)return n();M(m,[t]);let o=!1;const c=t[j]=l=>{o||(o=!0,n(),M(l?g:h,[t]),t[j]=void 0,x[a]===e&&delete x[a])};x[a]=e,v?z(v,[t,c]):c()},clone(e){const a=ee(e,t,l,n,o);return o&&o(a),a}};return R}function te(e){if(de(e))return e=Wl(e),e.children=null,e}function le(e){if(!de(e))return _(e.type)&&e.children?Q(e.children):e;if(e.component)return e.component.subTree;const{shapeFlag:t,children:l}=e;if(l){if(16&t)return l[0];if(32&t&&(0,a.Tn)(l.default))return l.default()}}function ne(e,t){6&e.shapeFlag&&e.component?(e.transition=t,ne(e.component.subTree,t)):128&e.shapeFlag?(e.ssContent.transition=t.clone(e.ssContent),e.ssFallback.transition=t.clone(e.ssFallback)):e.transition=t}function ae(e,t=!1,l){let n=[],a=0;for(let o=0;o1)for(let o=0;o(0,a.X$)({name:e.name},t,{setup:e}))():e}function ce(e){e.ids=[e.ids[0]+e.ids[2]+++"-",0,0]}const re=new WeakMap;function se(e,t,l,c,r=!1){if((0,a.cy)(e))return void e.forEach((e,n)=>se(e,t&&((0,a.cy)(t)?t[n]:t),l,c,r));if(ue(c)&&!r)return void(512&c.shapeFlag&&c.type.__asyncResolved&&c.component.subTree.component&&se(e,t,l,c.component.subTree));const s=4&c.shapeFlag?un(c.component):c.el,i=r?null:s,{i:u,r:d}=e;const f=t&&t.r,p=u.refs===a.MZ?u.refs={}:u.refs,m=u.setupState,v=(0,n.ux)(m),h=m===a.MZ?a.NO:e=>(0,a.$3)(v,e),g=e=>!0;if(null!=f&&f!==d)if(ie(t),(0,a.Kg)(f))p[f]=null,h(f)&&(m[f]=null);else if((0,n.i9)(f)){g(f)&&(f.value=null);const e=t;e.k&&(p[e.k]=null)}if((0,a.Tn)(d))o(d,u,12,[i,p]);else{const t=(0,a.Kg)(d),o=(0,n.i9)(d);if(t||o){const n=()=>{if(e.f){const l=t?h(d)?m[d]:p[d]:g(d)||!e.k?d.value:p[e.k];if(r)(0,a.cy)(l)&&(0,a.TF)(l,s);else if((0,a.cy)(l))l.includes(s)||l.push(s);else if(t)p[d]=[s],h(d)&&(m[d]=p[d]);else{const t=[s];g(d)&&(d.value=t),e.k&&(p[e.k]=t)}}else t?(p[d]=i,h(d)&&(m[d]=i)):o&&(g(d)&&(d.value=i),e.k&&(p[e.k]=i))};if(i){const t=()=>{n(),re.delete(e)};t.id=-1,re.set(e,t),ll(t,l)}else ie(e),n()}else 0}}function ie(e){const t=re.get(e);t&&(t.flags|=8,re.delete(e))}(0,a.We)().requestIdleCallback,(0,a.We)().cancelIdleCallback;const ue=e=>!!e.type.__asyncLoader;const de=e=>e.type.__isKeepAlive;RegExp,RegExp;function fe(e,t){return(0,a.cy)(e)?e.some(e=>fe(e,t)):(0,a.Kg)(e)?e.split(",").includes(t):!!(0,a.gd)(e)&&(e.lastIndex=0,e.test(t))}function pe(e,t){ve(e,"a",t)}function me(e,t){ve(e,"da",t)}function ve(e,t,l=Ul){const n=e.__wdc||(e.__wdc=()=>{let t=l;while(t){if(t.isDeactivated)return;t=t.parent}return e()});if(ye(t,n,l),l){let e=l.parent;while(e&&e.parent)de(e.parent.vnode)&&he(n,t,l,e),e=e.parent}}function he(e,t,l,n){const o=ye(t,e,n,!0);Re(()=>{(0,a.TF)(n[t],o)},l)}function ge(e){e.shapeFlag&=-257,e.shapeFlag&=-513}function be(e){return 128&e.shapeFlag?e.ssContent:e}function ye(e,t,l=Ul,a=!1){if(l){const o=l[e]||(l[e]=[]),r=t.__weh||(t.__weh=(...a)=>{(0,n.C4)();const o=Ql(l),r=c(t,l,e,a);return o(),(0,n.bl)(),r});return a?o.unshift(r):o.push(r),r}}const Ce=e=>(t,l=Ul)=>{ln&&"sp"!==e||ye(e,(...e)=>t(...e),l)},we=Ce("bm"),Le=Ce("m"),xe=Ce("bu"),Me=Ce("u"),ze=Ce("bum"),Re=Ce("um"),ke=Ce("sp"),Se=Ce("rtg"),Ee=Ce("rtc");function Ae(e,t=Ul){ye("ec",e,t)}const Ne="components",_e="directives";function Te(e,t){return Ie(Ne,e,!0,t)||e}const Oe=Symbol.for("v-ndc");function We(e){return(0,a.Kg)(e)?Ie(Ne,e,!1)||e:e||Oe}function Be(e){return Ie(_e,e)}function Ie(e,t,l=!0,n=!1){const o=z||Ul;if(o){const l=o.type;if(e===Ne){const e=dn(l,!1);if(e&&(e===t||e===(0,a.PT)(t)||e===(0,a.ZH)((0,a.PT)(t))))return l}const c=De(o[e]||l[e],t)||De(o.appContext[e],t);return!c&&n?l:c}}function De(e,t){return e&&(e[t]||e[(0,a.PT)(t)]||e[(0,a.ZH)((0,a.PT)(t))])}function Fe(e,t,l,o){let c;const r=l&&l[o],s=(0,a.cy)(e);if(s||(0,a.Kg)(e)){const l=s&&(0,n.g8)(e);let a=!1,o=!1;l&&(a=!(0,n.fE)(e),o=(0,n.Tm)(e),e=(0,n.qA)(e)),c=new Array(e.length);for(let s=0,i=e.length;st(e,l,void 0,r&&r[l]));else{const l=Object.keys(e);c=new Array(l.length);for(let n=0,a=l.length;n{const t=n.fn(...e);return t&&(t.key=n.key),t}:n.fn)}return e}function Pe(e,t,l={},n,o){if(z.ce||z.parent&&ue(z.parent)&&z.parent.ce){const e=Object.keys(l).length>0;return"default"!==t&&(l.name=t),Cl(),Rl(ml,null,[_l("slot",l,n&&n())],e?-2:64)}let c=e[t];c&&c._c&&(c._d=!1),Cl();const r=c&&$e(c(l)),s=l.key||r&&r.key,i=Rl(ml,{key:(s&&!(0,a.Bm)(s)?s:`_${t}`)+(!r&&n?"_fb":"")},r||(n?n():[]),r&&1===e._?64:-2);return!o&&i.scopeId&&(i.slotScopeIds=[i.scopeId+"-s"]),c&&c._c&&(c._d=!0),i}function $e(e){return e.some(e=>!kl(e)||e.type!==hl&&!(e.type===ml&&!$e(e.children)))?e:null}function He(e,t){const l={};for(const n in e)l[t&&/[A-Z]/.test(n)?`on:${n}`:(0,a.rU)(n)]=e[n];return l}const je=e=>e?Jl(e)?un(e):je(e.parent):null,Ke=(0,a.X$)(Object.create(null),{$:e=>e,$el:e=>e.vnode.el,$data:e=>e.data,$props:e=>e.props,$attrs:e=>e.attrs,$slots:e=>e.slots,$refs:e=>e.refs,$parent:e=>je(e.parent),$root:e=>je(e.root),$host:e=>e.ce,$emit:e=>e.emit,$options:e=>nt(e),$forceUpdate:e=>e.f||(e.f=()=>{b(e.update)}),$nextTick:e=>e.n||(e.n=h.bind(e.proxy)),$watch:e=>Mt.bind(e)}),Xe=(e,t)=>e!==a.MZ&&!e.__isScriptSetup&&(0,a.$3)(e,t),Ue={get({_:e},t){if("__v_skip"===t)return!0;const{ctx:l,setupState:o,data:c,props:r,accessCache:s,type:i,appContext:u}=e;if("$"!==t[0]){const e=s[t];if(void 0!==e)switch(e){case 1:return o[t];case 2:return c[t];case 4:return l[t];case 3:return r[t]}else{if(Xe(o,t))return s[t]=1,o[t];if(c!==a.MZ&&(0,a.$3)(c,t))return s[t]=2,c[t];if((0,a.$3)(r,t))return s[t]=3,r[t];if(l!==a.MZ&&(0,a.$3)(l,t))return s[t]=4,l[t];Ze&&(s[t]=0)}}const d=Ke[t];let f,p;return d?("$attrs"===t&&(0,n.u4)(e.attrs,"get",""),d(e)):(f=i.__cssModules)&&(f=f[t])?f:l!==a.MZ&&(0,a.$3)(l,t)?(s[t]=4,l[t]):(p=u.config.globalProperties,(0,a.$3)(p,t)?p[t]:void 0)},set({_:e},t,l){const{data:n,setupState:o,ctx:c}=e;return Xe(o,t)?(o[t]=l,!0):n!==a.MZ&&(0,a.$3)(n,t)?(n[t]=l,!0):!(0,a.$3)(e.props,t)&&(("$"!==t[0]||!(t.slice(1)in e))&&(c[t]=l,!0))},has({_:{data:e,setupState:t,accessCache:l,ctx:n,appContext:o,props:c,type:r}},s){let i;return!!(l[s]||e!==a.MZ&&"$"!==s[0]&&(0,a.$3)(e,s)||Xe(t,s)||(0,a.$3)(c,s)||(0,a.$3)(n,s)||(0,a.$3)(Ke,s)||(0,a.$3)(o.config.globalProperties,s)||(i=r.__cssModules)&&i[s])},defineProperty(e,t,l){return null!=l.get?e._.accessCache[t]=0:(0,a.$3)(l,"value")&&this.set(e,t,l.value,null),Reflect.defineProperty(e,t,l)}};function qe(){return Ye("useSlots").slots}function Ge(){return Ye("useAttrs").attrs}function Ye(e){const t=ql();return t.setupContext||(t.setupContext=sn(t))}function Qe(e){return(0,a.cy)(e)?e.reduce((e,t)=>(e[t]=null,e),{}):e}let Ze=!0;function Je(e){const t=nt(e),l=e.proxy,o=e.ctx;Ze=!1,t.beforeCreate&&tt(t.beforeCreate,e,"bc");const{data:c,computed:r,methods:s,watch:i,provide:u,inject:d,created:f,beforeMount:p,mounted:m,beforeUpdate:v,updated:h,activated:g,deactivated:b,beforeDestroy:y,beforeUnmount:C,destroyed:w,unmounted:L,render:x,renderTracked:M,renderTriggered:z,errorCaptured:R,serverPrefetch:k,expose:S,inheritAttrs:E,components:A,directives:N,filters:_}=t,T=null;if(d&&et(d,o,T),s)for(const n in s){const e=s[n];(0,a.Tn)(e)&&(o[n]=e.bind(l))}if(c){0;const t=c.call(l,l);0,(0,a.Gv)(t)&&(e.data=(0,n.Kh)(t))}if(Ze=!0,r)for(const n in r){const e=r[n],t=(0,a.Tn)(e)?e.bind(l,l):(0,a.Tn)(e.get)?e.get.bind(l,l):a.tE;0;const c=!(0,a.Tn)(e)&&(0,a.Tn)(e.set)?e.set.bind(l):a.tE,s=pn({get:t,set:c});Object.defineProperty(o,n,{enumerable:!0,configurable:!0,get:()=>s.value,set:e=>s.value=e})}if(i)for(const n in i)lt(i[n],o,l,n);if(u){const e=(0,a.Tn)(u)?u.call(l):u;Reflect.ownKeys(e).forEach(t=>{gt(t,e[t])})}function O(e,t){(0,a.cy)(t)?t.forEach(t=>e(t.bind(l))):t&&e(t.bind(l))}if(f&&tt(f,e,"c"),O(we,p),O(Le,m),O(xe,v),O(Me,h),O(pe,g),O(me,b),O(Ae,R),O(Ee,M),O(Se,z),O(ze,C),O(Re,L),O(ke,k),(0,a.cy)(S))if(S.length){const t=e.exposed||(e.exposed={});S.forEach(e=>{Object.defineProperty(t,e,{get:()=>l[e],set:t=>l[e]=t,enumerable:!0})})}else e.exposed||(e.exposed={});x&&e.render===a.tE&&(e.render=x),null!=E&&(e.inheritAttrs=E),A&&(e.components=A),N&&(e.directives=N),k&&ce(e)}function et(e,t,l=a.tE){(0,a.cy)(e)&&(e=st(e));for(const o in e){const l=e[o];let c;c=(0,a.Gv)(l)?"default"in l?bt(l.from||o,l.default,!0):bt(l.from||o):bt(l),(0,n.i9)(c)?Object.defineProperty(t,o,{enumerable:!0,configurable:!0,get:()=>c.value,set:e=>c.value=e}):t[o]=c}}function tt(e,t,l){c((0,a.cy)(e)?e.map(e=>e.bind(t.proxy)):e.bind(t.proxy),t,l)}function lt(e,t,l,n){let o=n.includes(".")?zt(l,n):()=>l[n];if((0,a.Kg)(e)){const l=t[e];(0,a.Tn)(l)&&Lt(o,l)}else if((0,a.Tn)(e))Lt(o,e.bind(l));else if((0,a.Gv)(e))if((0,a.cy)(e))e.forEach(e=>lt(e,t,l,n));else{const n=(0,a.Tn)(e.handler)?e.handler.bind(l):t[e.handler];(0,a.Tn)(n)&&Lt(o,n,e)}else 0}function nt(e){const t=e.type,{mixins:l,extends:n}=t,{mixins:o,optionsCache:c,config:{optionMergeStrategies:r}}=e.appContext,s=c.get(t);let i;return s?i=s:o.length||l||n?(i={},o.length&&o.forEach(e=>at(i,e,r,!0)),at(i,t,r)):i=t,(0,a.Gv)(t)&&c.set(t,i),i}function at(e,t,l,n=!1){const{mixins:a,extends:o}=t;o&&at(e,o,l,!0),a&&a.forEach(t=>at(e,t,l,!0));for(const c in t)if(n&&"expose"===c);else{const n=ot[c]||l&&l[c];e[c]=n?n(e[c],t[c]):t[c]}return e}const ot={data:ct,props:dt,emits:dt,methods:ut,computed:ut,beforeCreate:it,created:it,beforeMount:it,mounted:it,beforeUpdate:it,updated:it,beforeDestroy:it,beforeUnmount:it,destroyed:it,unmounted:it,activated:it,deactivated:it,errorCaptured:it,serverPrefetch:it,components:ut,directives:ut,watch:ft,provide:ct,inject:rt};function ct(e,t){return t?e?function(){return(0,a.X$)((0,a.Tn)(e)?e.call(this,this):e,(0,a.Tn)(t)?t.call(this,this):t)}:t:e}function rt(e,t){return ut(st(e),st(t))}function st(e){if((0,a.cy)(e)){const t={};for(let l=0;l1)return l&&(0,a.Tn)(t)?t.call(n&&n.proxy):t}else 0}const yt=Symbol.for("v-scx"),Ct=()=>{{const e=bt(yt);return e}};function wt(e,t){return xt(e,null,t)}function Lt(e,t,l){return xt(e,t,l)}function xt(e,t,l=a.MZ){const{immediate:o,deep:r,flush:s,once:i}=l;const u=(0,a.X$)({},l);const d=t&&o||!t&&"post"!==s;let f;if(ln)if("sync"===s){const e=Ct();f=e.__watcherHandles||(e.__watcherHandles=[])}else if(!d){const e=()=>{};return e.stop=a.tE,e.resume=a.tE,e.pause=a.tE,e}const p=Ul;u.call=(e,t,l)=>c(e,p,t,l);let m=!1;"post"===s?u.scheduler=e=>{ll(e,p&&p.suspense)}:"sync"!==s&&(m=!0,u.scheduler=(e,t)=>{t?e():b(e)}),u.augmentJob=e=>{t&&(e.flags|=4),m&&(e.flags|=2,p&&(e.id=p.uid,e.i=p))};const v=(0,n.wB)(e,t,u);return ln&&(f?f.push(v):d&&v()),v}function Mt(e,t,l){const n=this.proxy,o=(0,a.Kg)(e)?e.includes(".")?zt(n,e):()=>n[e]:e.bind(n,n);let c;(0,a.Tn)(t)?c=t:(c=t.handler,l=t);const r=Ql(this),s=xt(o,c.bind(n),l);return r(),s}function zt(e,t){const l=t.split(".");return()=>{let t=e;for(let e=0;e"modelValue"===t||"model-value"===t?e.modelModifiers:e[`${t}Modifiers`]||e[`${(0,a.PT)(t)}Modifiers`]||e[`${(0,a.Tg)(t)}Modifiers`];function kt(e,t,...l){if(e.isUnmounted)return;const n=e.vnode.props||a.MZ;let o=l;const r=t.startsWith("update:"),s=r&&Rt(n,t.slice(7));let i;s&&(s.trim&&(o=l.map(e=>(0,a.Kg)(e)?e.trim():e)),s.number&&(o=l.map(a.bB)));let u=n[i=(0,a.rU)(t)]||n[i=(0,a.rU)((0,a.PT)(t))];!u&&r&&(u=n[i=(0,a.rU)((0,a.Tg)(t))]),u&&c(u,e,6,o);const d=n[i+"Once"];if(d){if(e.emitted){if(e.emitted[i])return}else e.emitted={};e.emitted[i]=!0,c(d,e,6,o)}}const St=new WeakMap;function Et(e,t,l=!1){const n=l?St:t.emitsCache,o=n.get(e);if(void 0!==o)return o;const c=e.emits;let r={},s=!1;if(!(0,a.Tn)(e)){const n=e=>{const l=Et(e,t,!0);l&&(s=!0,(0,a.X$)(r,l))};!l&&t.mixins.length&&t.mixins.forEach(n),e.extends&&n(e.extends),e.mixins&&e.mixins.forEach(n)}return c||s?((0,a.cy)(c)?c.forEach(e=>r[e]=null):(0,a.X$)(r,c),(0,a.Gv)(e)&&n.set(e,r),r):((0,a.Gv)(e)&&n.set(e,null),null)}function At(e,t){return!(!e||!(0,a.Mp)(t))&&(t=t.slice(2).replace(/Once$/,""),(0,a.$3)(e,t[0].toLowerCase()+t.slice(1))||(0,a.$3)(e,(0,a.Tg)(t))||(0,a.$3)(e,t))}function Nt(e){const{type:t,vnode:l,proxy:n,withProxy:o,propsOptions:[c],slots:s,attrs:i,emit:u,render:d,renderCache:f,props:p,data:m,setupState:v,ctx:h,inheritAttrs:g}=e,b=k(e);let y,C;try{if(4&l.shapeFlag){const e=o||n,t=e;y=Fl(d.call(t,e,f,p,v,m,h)),C=i}else{const e=t;0,y=Fl(e.length>1?e(p,{attrs:i,slots:s,emit:u}):e(p,null)),C=t.props?i:_t(i)}}catch(L){bl.length=0,r(L,e,1),y=_l(hl)}let w=y;if(C&&!1!==g){const e=Object.keys(C),{shapeFlag:t}=w;e.length&&7&t&&(c&&e.some(a.CP)&&(C=Tt(C,c)),w=Wl(w,C,!1,!0))}return l.dirs&&(w=Wl(w,null,!1,!0),w.dirs=w.dirs?w.dirs.concat(l.dirs):l.dirs),l.transition&&ne(w,l.transition),y=w,k(b),y}const _t=e=>{let t;for(const l in e)("class"===l||"style"===l||(0,a.Mp)(l))&&((t||(t={}))[l]=e[l]);return t},Tt=(e,t)=>{const l={};for(const n in e)(0,a.CP)(n)&&n.slice(9)in t||(l[n]=e[n]);return l};function Ot(e,t,l){const{props:n,children:a,component:o}=e,{props:c,children:r,patchFlag:s}=t,i=o.emitsOptions;if(t.dirs||t.transition)return!0;if(!(l&&s>=0))return!(!a&&!r||r&&r.$stable)||n!==c&&(n?!c||Wt(n,c,i):!!c);if(1024&s)return!0;if(16&s)return n?Wt(n,c,i):!!c;if(8&s){const e=t.dynamicProps;for(let t=0;tObject.create(It),Ft=e=>Object.getPrototypeOf(e)===It;function Vt(e,t,l,a=!1){const o={},c=Dt();e.propsDefaults=Object.create(null),$t(e,t,o,c);for(const n in e.propsOptions[0])n in o||(o[n]=void 0);l?e.props=a?o:(0,n.Gc)(o):e.type.props?e.props=o:e.props=c,e.attrs=c}function Pt(e,t,l,o){const{props:c,attrs:r,vnode:{patchFlag:s}}=e,i=(0,n.ux)(c),[u]=e.propsOptions;let d=!1;if(!(o||s>0)||16&s){let n;$t(e,t,c,r)&&(d=!0);for(const o in i)t&&((0,a.$3)(t,o)||(n=(0,a.Tg)(o))!==o&&(0,a.$3)(t,n))||(u?!l||void 0===l[o]&&void 0===l[n]||(c[o]=Ht(u,i,o,void 0,e,!0)):delete c[o]);if(r!==i)for(const e in r)t&&(0,a.$3)(t,e)||(delete r[e],d=!0)}else if(8&s){const l=e.vnode.dynamicProps;for(let n=0;n{i=!0;const[l,n]=Kt(e,t,!0);(0,a.X$)(r,l),n&&s.push(...n)};!l&&t.mixins.length&&t.mixins.forEach(n),e.extends&&n(e.extends),e.mixins&&e.mixins.forEach(n)}if(!c&&!i)return(0,a.Gv)(e)&&n.set(e,a.Oj),a.Oj;if((0,a.cy)(c))for(let d=0;d"_"===e||"_ctx"===e||"$stable"===e,qt=e=>(0,a.cy)(e)?e.map(Fl):[Fl(e)],Gt=(e,t,l)=>{if(t._n)return t;const n=S((...e)=>qt(t(...e)),l);return n._c=!1,n},Yt=(e,t,l)=>{const n=e._ctx;for(const o in e){if(Ut(o))continue;const l=e[o];if((0,a.Tn)(l))t[o]=Gt(o,l,n);else if(null!=l){0;const e=qt(l);t[o]=()=>e}}},Qt=(e,t)=>{const l=qt(t);e.slots.default=()=>l},Zt=(e,t,l)=>{for(const n in t)!l&&Ut(n)||(e[n]=t[n])},Jt=(e,t,l)=>{const n=e.slots=Dt();if(32&e.vnode.shapeFlag){const e=t._;e?(Zt(n,t,l),l&&(0,a.yQ)(n,"_",e,!0)):Yt(t,n)}else t&&Qt(e,t)},el=(e,t,l)=>{const{vnode:n,slots:o}=e;let c=!0,r=a.MZ;if(32&n.shapeFlag){const e=t._;e?l&&1===e?c=!1:Zt(o,t,l):(c=!t.$stable,Yt(t,o)),r=t}else t&&(Qt(e,t),r={default:1});if(c)for(const a in o)Ut(a)||null!=r[a]||delete o[a]};function tl(){}const ll=pl;function nl(e){return al(e)}function al(e,t){tl();const l=(0,a.We)();l.__VUE__=!0;const{insert:o,remove:c,patchProp:r,createElement:s,createText:i,createComment:u,setText:d,setElementText:f,parentNode:p,nextSibling:m,setScopeId:v=a.tE,insertStaticContent:h}=e,g=(e,t,l,n=null,a=null,o=null,c=void 0,r=null,s=!!t.dynamicChildren)=>{if(e===t)return;e&&!Sl(e,t)&&(n=Q(e),X(e,a,o,!0),e=null),-2===t.patchFlag&&(s=!1,t.dynamicChildren=null);const{type:i,ref:u,shapeFlag:d}=t;switch(i){case vl:y(e,t,l,n);break;case hl:C(e,t,l,n);break;case gl:null==e&&x(t,l,n,c);break;case ml:W(e,t,l,n,a,o,c,r,s);break;default:1&d?R(e,t,l,n,a,o,c,r,s):6&d?B(e,t,l,n,a,o,c,r,s):(64&d||128&d)&&i.process(e,t,l,n,a,o,c,r,s,ee)}null!=u&&a?se(u,e&&e.ref,o,t||e,!t):null==u&&e&&null!=e.ref&&se(e.ref,null,o,e,!0)},y=(e,t,l,n)=>{if(null==e)o(t.el=i(t.children),l,n);else{const l=t.el=e.el;t.children!==e.children&&d(l,t.children)}},C=(e,t,l,n)=>{null==e?o(t.el=u(t.children||""),l,n):t.el=e.el},x=(e,t,l,n)=>{[e.el,e.anchor]=h(e.children,t,l,n,e.el,e.anchor)},M=({el:e,anchor:t},l,n)=>{let a;while(e&&e!==t)a=m(e),o(e,l,n),e=a;o(t,l,n)},z=({el:e,anchor:t})=>{let l;while(e&&e!==t)l=m(e),c(e),e=l;c(t)},R=(e,t,l,n,a,o,c,r,s)=>{if("svg"===t.type?c="svg":"math"===t.type&&(c="mathml"),null==e)k(t,l,n,a,o,c,r,s);else{const l=e.el&&e.el._isVueCE?e.el:null;try{l&&l._beginPatch(),_(e,t,a,o,c,r,s)}finally{l&&l._endPatch()}}},k=(e,t,l,n,c,i,u,d)=>{let p,m;const{props:v,shapeFlag:h,transition:g,dirs:b}=e;if(p=e.el=s(e.type,i,v&&v.is,v),8&h?f(p,e.children):16&h&&E(e.children,p,null,n,c,ol(e,i),u,d),b&&A(e,null,n,"created"),S(p,e,e.scopeId,u,n),v){for(const e in v)"value"===e||(0,a.SU)(e)||r(p,e,null,v[e],i,n);"value"in v&&r(p,"value",null,v.value,i),(m=v.onVnodeBeforeMount)&&Hl(m,n,e)}b&&A(e,null,n,"beforeMount");const y=rl(c,g);y&&g.beforeEnter(p),o(p,t,l),((m=v&&v.onVnodeMounted)||y||b)&&ll(()=>{m&&Hl(m,n,e),y&&g.enter(p),b&&A(e,null,n,"mounted")},c)},S=(e,t,l,n,a)=>{if(l&&v(e,l),n)for(let o=0;o{for(let i=s;i{const i=t.el=e.el;let{patchFlag:u,dynamicChildren:d,dirs:p}=t;u|=16&e.patchFlag;const m=e.props||a.MZ,v=t.props||a.MZ;let h;if(l&&cl(l,!1),(h=v.onVnodeBeforeUpdate)&&Hl(h,l,t,e),p&&A(t,e,l,"beforeUpdate"),l&&cl(l,!0),(m.innerHTML&&null==v.innerHTML||m.textContent&&null==v.textContent)&&f(i,""),d?T(e.dynamicChildren,d,i,l,n,ol(t,o),c):s||P(e,t,i,null,l,n,ol(t,o),c,!1),u>0){if(16&u)O(i,m,v,l,o);else if(2&u&&m.class!==v.class&&r(i,"class",null,v.class,o),4&u&&r(i,"style",m.style,v.style,o),8&u){const e=t.dynamicProps;for(let t=0;t{h&&Hl(h,l,t,e),p&&A(t,e,l,"updated")},n)},T=(e,t,l,n,a,o,c)=>{for(let r=0;r{if(t!==l){if(t!==a.MZ)for(const c in t)(0,a.SU)(c)||c in l||r(e,c,t[c],null,o,n);for(const c in l){if((0,a.SU)(c))continue;const s=l[c],i=t[c];s!==i&&"value"!==c&&r(e,c,i,s,o,n)}"value"in l&&r(e,"value",t.value,l.value,o)}},W=(e,t,l,n,a,c,r,s,u)=>{const d=t.el=e?e.el:i(""),f=t.anchor=e?e.anchor:i("");let{patchFlag:p,dynamicChildren:m,slotScopeIds:v}=t;v&&(s=s?s.concat(v):v),null==e?(o(d,l,n),o(f,l,n),E(t.children||[],l,f,a,c,r,s,u)):p>0&&64&p&&m&&e.dynamicChildren?(T(e.dynamicChildren,m,l,a,c,r,s),(null!=t.key||a&&t===a.subTree)&&sl(e,t,!0)):P(e,t,l,f,a,c,r,s,u)},B=(e,t,l,n,a,o,c,r,s)=>{t.slotScopeIds=r,null==e?512&t.shapeFlag?a.ctx.activate(t,l,n,c,s):I(t,l,n,a,o,c,s):D(e,t,s)},I=(e,t,l,n,a,o,c)=>{const r=e.component=Xl(e,n,a);if(de(e)&&(r.ctx.renderer=ee),nn(r,!1,c),r.asyncDep){if(a&&a.registerDep(r,F,c),!e.el){const n=r.subTree=_l(hl);C(null,n,t,l),e.placeholder=n.el}}else F(r,e,t,l,a,o,c)},D=(e,t,l)=>{const n=t.component=e.component;if(Ot(e,t,l)){if(n.asyncDep&&!n.asyncResolved)return void V(n,t,l);n.next=t,n.update()}else t.el=e.el,n.vnode=t},F=(e,t,l,o,c,r,s)=>{const i=()=>{if(e.isMounted){let{next:t,bu:l,u:n,parent:o,vnode:u}=e;{const l=ul(e);if(l)return t&&(t.el=u.el,V(e,t,s)),void l.asyncDep.then(()=>{e.isUnmounted||i()})}let d,f=t;0,cl(e,!1),t?(t.el=u.el,V(e,t,s)):t=u,l&&(0,a.DY)(l),(d=t.props&&t.props.onVnodeBeforeUpdate)&&Hl(d,o,t,u),cl(e,!0);const m=Nt(e);0;const v=e.subTree;e.subTree=m,g(v,m,p(v.el),Q(v),e,c,r),t.el=m.el,null===f&&Bt(e,m.el),n&&ll(n,c),(d=t.props&&t.props.onVnodeUpdated)&&ll(()=>Hl(d,o,t,u),c)}else{let n;const{el:s,props:i}=t,{bm:u,m:d,parent:f,root:p,type:m}=e,v=ue(t);if(cl(e,!1),u&&(0,a.DY)(u),!v&&(n=i&&i.onVnodeBeforeMount)&&Hl(n,f,t),cl(e,!0),s&&le){const t=()=>{e.subTree=Nt(e),le(s,e.subTree,e,c,null)};v&&m.__asyncHydrate?m.__asyncHydrate(s,e,t):t()}else{p.ce&&!1!==p.ce._def.shadowRoot&&p.ce._injectChildStyle(m);const n=e.subTree=Nt(e);0,g(null,n,l,o,e,c,r),t.el=n.el}if(d&&ll(d,c),!v&&(n=i&&i.onVnodeMounted)){const e=t;ll(()=>Hl(n,f,e),c)}(256&t.shapeFlag||f&&ue(f.vnode)&&256&f.vnode.shapeFlag)&&e.a&&ll(e.a,c),e.isMounted=!0,t=l=o=null}};e.scope.on();const u=e.effect=new n.X2(i);e.scope.off();const d=e.update=u.run.bind(u),f=e.job=u.runIfDirty.bind(u);f.i=e,f.id=e.uid,u.scheduler=()=>b(f),cl(e,!0),d()},V=(e,t,l)=>{t.component=e;const a=e.vnode.props;e.vnode=t,e.next=null,Pt(e,t.props,a,l),el(e,t.children,l),(0,n.C4)(),w(e),(0,n.bl)()},P=(e,t,l,n,a,o,c,r,s=!1)=>{const i=e&&e.children,u=e?e.shapeFlag:0,d=t.children,{patchFlag:p,shapeFlag:m}=t;if(p>0){if(128&p)return void H(i,d,l,n,a,o,c,r,s);if(256&p)return void $(i,d,l,n,a,o,c,r,s)}8&m?(16&u&&Y(i,a,o),d!==i&&f(l,d)):16&u?16&m?H(i,d,l,n,a,o,c,r,s):Y(i,a,o,!0):(8&u&&f(l,""),16&m&&E(d,l,n,a,o,c,r,s))},$=(e,t,l,n,o,c,r,s,i)=>{e=e||a.Oj,t=t||a.Oj;const u=e.length,d=t.length,f=Math.min(u,d);let p;for(p=0;pd?Y(e,o,c,!0,!1,f):E(t,l,n,o,c,r,s,i,f)},H=(e,t,l,n,o,c,r,s,i)=>{let u=0;const d=t.length;let f=e.length-1,p=d-1;while(u<=f&&u<=p){const n=e[u],a=t[u]=i?Vl(t[u]):Fl(t[u]);if(!Sl(n,a))break;g(n,a,l,null,o,c,r,s,i),u++}while(u<=f&&u<=p){const n=e[f],a=t[p]=i?Vl(t[p]):Fl(t[p]);if(!Sl(n,a))break;g(n,a,l,null,o,c,r,s,i),f--,p--}if(u>f){if(u<=p){const e=p+1,a=ep)while(u<=f)X(e[u],o,c,!0),u++;else{const m=u,v=u,h=new Map;for(u=v;u<=p;u++){const e=t[u]=i?Vl(t[u]):Fl(t[u]);null!=e.key&&h.set(e.key,u)}let b,y=0;const C=p-v+1;let w=!1,L=0;const x=new Array(C);for(u=0;u=C){X(n,o,c,!0);continue}let a;if(null!=n.key)a=h.get(n.key);else for(b=v;b<=p;b++)if(0===x[b-v]&&Sl(n,t[b])){a=b;break}void 0===a?X(n,o,c,!0):(x[a-v]=u+1,a>=L?L=a:w=!0,g(n,t[a],l,null,o,c,r,s,i),y++)}const M=w?il(x):a.Oj;for(b=M.length-1,u=C-1;u>=0;u--){const e=v+u,a=t[e],f=t[e+1],p=e+1{const{el:r,type:s,transition:i,children:u,shapeFlag:d}=e;if(6&d)return void K(e.component.subTree,t,l,n);if(128&d)return void e.suspense.move(t,l,n);if(64&d)return void s.move(e,t,l,ee);if(s===ml){o(r,t,l);for(let e=0;ei.enter(r),a);else{const{leave:n,delayLeave:a,afterLeave:s}=i,u=()=>{e.ctx.isUnmounted?c(r):o(r,t,l)},d=()=>{r._isLeaving&&r[j](!0),n(r,()=>{u(),s&&s()})};a?a(r,u,d):d()}else o(r,t,l)},X=(e,t,l,a=!1,o=!1)=>{const{type:c,props:r,ref:s,children:i,dynamicChildren:u,shapeFlag:d,patchFlag:f,dirs:p,cacheIndex:m}=e;if(-2===f&&(o=!1),null!=s&&((0,n.C4)(),se(s,null,l,e,!0),(0,n.bl)()),null!=m&&(t.renderCache[m]=void 0),256&d)return void t.ctx.deactivate(e);const v=1&d&&p,h=!ue(e);let g;if(h&&(g=r&&r.onVnodeBeforeUnmount)&&Hl(g,t,e),6&d)G(e.component,l,a);else{if(128&d)return void e.suspense.unmount(l,a);v&&A(e,null,t,"beforeUnmount"),64&d?e.type.remove(e,t,l,ee,a):u&&!u.hasOnce&&(c!==ml||f>0&&64&f)?Y(u,t,l,!1,!0):(c===ml&&384&f||!o&&16&d)&&Y(i,t,l),a&&U(e)}(h&&(g=r&&r.onVnodeUnmounted)||v)&&ll(()=>{g&&Hl(g,t,e),v&&A(e,null,t,"unmounted")},l)},U=e=>{const{type:t,el:l,anchor:n,transition:a}=e;if(t===ml)return void q(l,n);if(t===gl)return void z(e);const o=()=>{c(l),a&&!a.persisted&&a.afterLeave&&a.afterLeave()};if(1&e.shapeFlag&&a&&!a.persisted){const{leave:t,delayLeave:n}=a,c=()=>t(l,o);n?n(e.el,o,c):c()}else o()},q=(e,t)=>{let l;while(e!==t)l=m(e),c(e),e=l;c(t)},G=(e,t,l)=>{const{bum:n,scope:o,job:c,subTree:r,um:s,m:i,a:u}=e;dl(i),dl(u),n&&(0,a.DY)(n),o.stop(),c&&(c.flags|=8,X(r,e,t,l)),s&&ll(s,t),ll(()=>{e.isUnmounted=!0},t)},Y=(e,t,l,n=!1,a=!1,o=0)=>{for(let c=o;c{if(6&e.shapeFlag)return Q(e.component.subTree);if(128&e.shapeFlag)return e.suspense.next();const t=m(e.anchor||e.el),l=t&&t[N];return l?m(l):t};let Z=!1;const J=(e,t,l)=>{null==e?t._vnode&&X(t._vnode,null,null,!0):g(t._vnode||null,e,t,null,null,null,l),t._vnode=e,Z||(Z=!0,w(),L(),Z=!1)},ee={p:g,um:X,m:K,r:U,mt:I,mc:E,pc:P,pbc:T,n:Q,o:e};let te,le;return t&&([te,le]=t(ee)),{render:J,hydrate:te,createApp:vt(J,te)}}function ol({type:e,props:t},l){return"svg"===l&&"foreignObject"===e||"mathml"===l&&"annotation-xml"===e&&t&&t.encoding&&t.encoding.includes("html")?void 0:l}function cl({effect:e,job:t},l){l?(e.flags|=32,t.flags|=4):(e.flags&=-33,t.flags&=-5)}function rl(e,t){return(!e||e&&!e.pendingBranch)&&t&&!t.persisted}function sl(e,t,l=!1){const n=e.children,o=t.children;if((0,a.cy)(n)&&(0,a.cy)(o))for(let a=0;a>1,e[l[r]]0&&(t[n]=l[o-1]),l[o]=n)}}o=l.length,c=l[o-1];while(o-- >0)l[o]=c,c=t[c];return l}function ul(e){const t=e.subTree.component;if(t)return t.asyncDep&&!t.asyncResolved?t:ul(t)}function dl(e){if(e)for(let t=0;te.__isSuspense;function pl(e,t){t&&t.pendingBranch?(0,a.cy)(e)?t.effects.push(...e):t.effects.push(e):C(e)}const ml=Symbol.for("v-fgt"),vl=Symbol.for("v-txt"),hl=Symbol.for("v-cmt"),gl=Symbol.for("v-stc"),bl=[];let yl=null;function Cl(e=!1){bl.push(yl=e?null:[])}function wl(){bl.pop(),yl=bl[bl.length-1]||null}let Ll=1;function xl(e,t=!1){Ll+=e,e<0&&yl&&t&&(yl.hasOnce=!0)}function Ml(e){return e.dynamicChildren=Ll>0?yl||a.Oj:null,wl(),Ll>0&&yl&&yl.push(e),e}function zl(e,t,l,n,a,o){return Ml(Nl(e,t,l,n,a,o,!0))}function Rl(e,t,l,n,a){return Ml(_l(e,t,l,n,a,!0))}function kl(e){return!!e&&!0===e.__v_isVNode}function Sl(e,t){return e.type===t.type&&e.key===t.key}const El=({key:e})=>null!=e?e:null,Al=({ref:e,ref_key:t,ref_for:l})=>("number"===typeof e&&(e=""+e),null!=e?(0,a.Kg)(e)||(0,n.i9)(e)||(0,a.Tn)(e)?{i:z,r:e,k:t,f:!!l}:e:null);function Nl(e,t=null,l=null,n=0,o=null,c=(e===ml?0:1),r=!1,s=!1){const i={__v_isVNode:!0,__v_skip:!0,type:e,props:t,key:t&&El(t),ref:t&&Al(t),scopeId:R,slotScopeIds:null,children:l,component:null,suspense:null,ssContent:null,ssFallback:null,dirs:null,transition:null,el:null,anchor:null,target:null,targetStart:null,targetAnchor:null,staticCount:0,shapeFlag:c,patchFlag:n,dynamicProps:o,dynamicChildren:null,appContext:null,ctx:z};return s?(Pl(i,l),128&c&&e.normalize(i)):l&&(i.shapeFlag|=(0,a.Kg)(l)?8:16),Ll>0&&!r&&yl&&(i.patchFlag>0||6&c)&&32!==i.patchFlag&&yl.push(i),i}const _l=Tl;function Tl(e,t=null,l=null,o=0,c=null,r=!1){if(e&&e!==Oe||(e=hl),kl(e)){const n=Wl(e,t,!0);return l&&Pl(n,l),Ll>0&&!r&&yl&&(6&n.shapeFlag?yl[yl.indexOf(e)]=n:yl.push(n)),n.patchFlag=-2,n}if(fn(e)&&(e=e.__vccOpts),t){t=Ol(t);let{class:e,style:l}=t;e&&!(0,a.Kg)(e)&&(t.class=(0,a.C4)(e)),(0,a.Gv)(l)&&((0,n.ju)(l)&&!(0,a.cy)(l)&&(l=(0,a.X$)({},l)),t.style=(0,a.Tr)(l))}const s=(0,a.Kg)(e)?1:fl(e)?128:_(e)?64:(0,a.Gv)(e)?4:(0,a.Tn)(e)?2:0;return Nl(e,t,l,o,c,s,r,!0)}function Ol(e){return e?(0,n.ju)(e)||Ft(e)?(0,a.X$)({},e):e:null}function Wl(e,t,l=!1,n=!1){const{props:o,ref:c,patchFlag:r,children:s,transition:i}=e,u=t?$l(o||{},t):o,d={__v_isVNode:!0,__v_skip:!0,type:e.type,props:u,key:u&&El(u),ref:t&&t.ref?l&&c?(0,a.cy)(c)?c.concat(Al(t)):[c,Al(t)]:Al(t):c,scopeId:e.scopeId,slotScopeIds:e.slotScopeIds,children:s,target:e.target,targetStart:e.targetStart,targetAnchor:e.targetAnchor,staticCount:e.staticCount,shapeFlag:e.shapeFlag,patchFlag:t&&e.type!==ml?-1===r?16:16|r:r,dynamicProps:e.dynamicProps,dynamicChildren:e.dynamicChildren,appContext:e.appContext,dirs:e.dirs,transition:i,component:e.component,suspense:e.suspense,ssContent:e.ssContent&&Wl(e.ssContent),ssFallback:e.ssFallback&&Wl(e.ssFallback),placeholder:e.placeholder,el:e.el,anchor:e.anchor,ctx:e.ctx,ce:e.ce};return i&&n&&ne(d,i.clone(d)),d}function Bl(e=" ",t=0){return _l(vl,null,e,t)}function Il(e,t){const l=_l(gl,null,e);return l.staticCount=t,l}function Dl(e="",t=!1){return t?(Cl(),Rl(hl,null,e)):_l(hl,null,e)}function Fl(e){return null==e||"boolean"===typeof e?_l(hl):(0,a.cy)(e)?_l(ml,null,e.slice()):kl(e)?Vl(e):_l(vl,null,String(e))}function Vl(e){return null===e.el&&-1!==e.patchFlag||e.memo?e:Wl(e)}function Pl(e,t){let l=0;const{shapeFlag:n}=e;if(null==t)t=null;else if((0,a.cy)(t))l=16;else if("object"===typeof t){if(65&n){const l=t.default;return void(l&&(l._c&&(l._d=!1),Pl(e,l()),l._c&&(l._d=!0)))}{l=32;const n=t._;n||Ft(t)?3===n&&z&&(1===z.slots._?t._=1:(t._=2,e.patchFlag|=1024)):t._ctx=z}}else(0,a.Tn)(t)?(t={default:t,_ctx:z},l=32):(t=String(t),64&n?(l=16,t=[Bl(t)]):l=8);e.children=t,e.shapeFlag|=l}function $l(...e){const t={};for(let l=0;lUl||z;let Gl,Yl;{const e=(0,a.We)(),t=(t,l)=>{let n;return(n=e[t])||(n=e[t]=[]),n.push(l),e=>{n.length>1?n.forEach(t=>t(e)):n[0](e)}};Gl=t("__VUE_INSTANCE_SETTERS__",e=>Ul=e),Yl=t("__VUE_SSR_SETTERS__",e=>ln=e)}const Ql=e=>{const t=Ul;return Gl(e),e.scope.on(),()=>{e.scope.off(),Gl(t)}},Zl=()=>{Ul&&Ul.scope.off(),Gl(null)};function Jl(e){return 4&e.vnode.shapeFlag}let en,tn,ln=!1;function nn(e,t=!1,l=!1){t&&Yl(t);const{props:n,children:a}=e.vnode,o=Jl(e);Vt(e,n,o,t),Jt(e,a,l||t);const c=o?an(e,t):void 0;return t&&Yl(!1),c}function an(e,t){const l=e.type;e.accessCache=Object.create(null),e.proxy=new Proxy(e.ctx,Ue);const{setup:c}=l;if(c){(0,n.C4)();const l=e.setupContext=c.length>1?sn(e):null,s=Ql(e),i=o(c,e,0,[e.props,l]),u=(0,a.yL)(i);if((0,n.bl)(),s(),!u&&!e.sp||ue(e)||ce(e),u){if(i.then(Zl,Zl),t)return i.then(l=>{on(e,l,t)}).catch(t=>{r(t,e,0)});e.asyncDep=i}else on(e,i,t)}else cn(e,t)}function on(e,t,l){(0,a.Tn)(t)?e.type.__ssrInlineRender?e.ssrRender=t:e.render=t:(0,a.Gv)(t)&&(e.setupState=(0,n.Pr)(t)),cn(e,l)}function cn(e,t,l){const o=e.type;if(!e.render){if(!t&&en&&!o.render){const t=o.template||nt(e).template;if(t){0;const{isCustomElement:l,compilerOptions:n}=e.appContext.config,{delimiters:c,compilerOptions:r}=o,s=(0,a.X$)((0,a.X$)({isCustomElement:l,delimiters:c},n),r);o.render=en(t,s)}}e.render=o.render||a.tE,tn&&tn(e)}{const t=Ql(e);(0,n.C4)();try{Je(e)}finally{(0,n.bl)(),t()}}}const rn={get(e,t){return(0,n.u4)(e,"get",""),e[t]}};function sn(e){const t=t=>{e.exposed=t||{}};return{attrs:new Proxy(e.attrs,rn),slots:e.slots,emit:e.emit,expose:t}}function un(e){return e.exposed?e.exposeProxy||(e.exposeProxy=new Proxy((0,n.Pr)((0,n.IG)(e.exposed)),{get(t,l){return l in t?t[l]:l in Ke?Ke[l](e):void 0},has(e,t){return t in e||t in Ke}})):e.proxy}function dn(e,t=!0){return(0,a.Tn)(e)?e.displayName||e.name:e.name||t&&e.__name}function fn(e){return(0,a.Tn)(e)&&"__vccOpts"in e}const pn=(e,t)=>{const l=(0,n.EW)(e,t,ln);return l};function mn(e,t,l){try{xl(-1);const n=arguments.length;return 2===n?(0,a.Gv)(t)&&!(0,a.cy)(t)?kl(t)?_l(e,null,[t]):_l(e,t):_l(e,null,t):(n>3?l=Array.prototype.slice.call(arguments,2):3===n&&kl(l)&&(l=[l]),_l(e,t,l))}finally{xl(1)}}const vn="3.5.25",hn=a.tE},6769:function(e,t,l){"use strict";l.d(t,{f:function(){return n}});const n=e=>e},6801:function(e,t,l){"use strict";var n=l(3724),a=l(8686),o=l(4913),c=l(8551),r=l(5397),s=l(1072);t.f=n&&!a?Object.defineProperties:function(e,t){c(e);var l,n=r(t),a=s(t),i=a.length,u=0;while(i>u)o.f(e,l=a[u++],n[l]);return e}},6810:function(e,t,l){"use strict";l.d(t,{ll:function(){return V},Zh:function(){return $},MQ:function(){return P}});var n=l(6768),a=l(4232),o=l(144),c=l(5130),r=l(7378),s=l(3845),i=l(2056),u=l(2235);const d=(0,r.b_)({modelValue:{type:[String,Number,Boolean],default:void 0},size:s.mU,disabled:{type:Boolean,default:void 0},label:{type:[String,Number,Boolean],default:void 0},value:{type:[String,Number,Boolean],default:void 0},name:{type:String,default:void 0}}),f=(0,r.b_)({...d,border:Boolean}),p={[i.l4]:e=>(0,a.Kg)(e)||(0,u.Et)(e)||(0,u.Lm)(e),[i.YU]:e=>(0,a.Kg)(e)||(0,u.Et)(e)||(0,u.Lm)(e)},m=Symbol("radioGroupKey");var v=l(2436),h=l(261);const g=(e,t)=>{const l=(0,o.KR)(),a=(0,n.WQ)(m,void 0),c=(0,n.EW)(()=>!!a),r=(0,n.EW)(()=>(0,u.Xj)(e.value)?e.label:e.value),s=(0,n.EW)({get(){return c.value?a.modelValue:e.modelValue},set(n){c.value?a.changeEvent(n):t&&t(i.l4,n),l.value.checked=e.modelValue===r.value}}),d=(0,v.NV)((0,n.EW)(()=>null==a?void 0:a.size)),f=(0,v.CB)((0,n.EW)(()=>null==a?void 0:a.disabled)),p=(0,o.KR)(!1),g=(0,n.EW)(()=>f.value||c.value&&s.value!==r.value?-1:0);return(0,h.b)({from:"label act as value",replacement:"value",version:"3.0.0",scope:"el-radio",ref:"https://element-plus.org/en-US/component/radio.html"},(0,n.EW)(()=>c.value&&(0,u.Xj)(e.value))),{radioRef:l,isGroup:c,radioGroup:a,focus:p,size:d,disabled:f,tabIndex:g,modelValue:s,actualValue:r}};var b=l(9077),y=l(3513);const C=(0,n.pM)({name:"ElRadio"}),w=(0,n.pM)({...C,props:f,emits:p,setup(e,{emit:t}){const l=e,r=(0,y.DU)("radio"),{radioRef:s,radioGroup:u,focus:d,size:f,disabled:p,modelValue:m,actualValue:v}=g(l,t);function h(){(0,n.dY)(()=>t(i.YU,m.value))}return(e,t)=>{var l;return(0,n.uX)(),(0,n.CE)("label",{class:(0,a.C4)([(0,o.R1)(r).b(),(0,o.R1)(r).is("disabled",(0,o.R1)(p)),(0,o.R1)(r).is("focus",(0,o.R1)(d)),(0,o.R1)(r).is("bordered",e.border),(0,o.R1)(r).is("checked",(0,o.R1)(m)===(0,o.R1)(v)),(0,o.R1)(r).m((0,o.R1)(f))])},[(0,n.Lk)("span",{class:(0,a.C4)([(0,o.R1)(r).e("input"),(0,o.R1)(r).is("disabled",(0,o.R1)(p)),(0,o.R1)(r).is("checked",(0,o.R1)(m)===(0,o.R1)(v))])},[(0,n.bo)((0,n.Lk)("input",{ref_key:"radioRef",ref:s,"onUpdate:modelValue":e=>(0,o.i9)(m)?m.value=e:null,class:(0,a.C4)((0,o.R1)(r).e("original")),value:(0,o.R1)(v),name:e.name||(null==(l=(0,o.R1)(u))?void 0:l.name),disabled:(0,o.R1)(p),checked:(0,o.R1)(m)===(0,o.R1)(v),type:"radio",onFocus:e=>d.value=!0,onBlur:e=>d.value=!1,onChange:h,onClick:(0,c.D$)(()=>{},["stop"])},null,42,["onUpdate:modelValue","value","name","disabled","checked","onFocus","onBlur","onClick"]),[[c.XL,(0,o.R1)(m)]]),(0,n.Lk)("span",{class:(0,a.C4)((0,o.R1)(r).e("inner"))},null,2)],2),(0,n.Lk)("span",{class:(0,a.C4)((0,o.R1)(r).e("label")),onKeydown:(0,c.D$)(()=>{},["stop"])},[(0,n.RG)(e.$slots,"default",{},()=>[(0,n.eW)((0,a.v_)(e.label),1)])],42,["onKeydown"])],2)}}});var L=(0,b.A)(w,[["__file","radio.vue"]]);const x=(0,r.b_)({...d}),M=(0,n.pM)({name:"ElRadioButton"}),z=(0,n.pM)({...M,props:x,setup(e){const t=e,l=(0,y.DU)("radio"),{radioRef:r,focus:s,size:i,disabled:u,modelValue:d,radioGroup:f,actualValue:p}=g(t),m=(0,n.EW)(()=>({backgroundColor:(null==f?void 0:f.fill)||"",borderColor:(null==f?void 0:f.fill)||"",boxShadow:(null==f?void 0:f.fill)?`-1px 0 0 0 ${f.fill}`:"",color:(null==f?void 0:f.textColor)||""}));return(e,t)=>{var v;return(0,n.uX)(),(0,n.CE)("label",{class:(0,a.C4)([(0,o.R1)(l).b("button"),(0,o.R1)(l).is("active",(0,o.R1)(d)===(0,o.R1)(p)),(0,o.R1)(l).is("disabled",(0,o.R1)(u)),(0,o.R1)(l).is("focus",(0,o.R1)(s)),(0,o.R1)(l).bm("button",(0,o.R1)(i))])},[(0,n.bo)((0,n.Lk)("input",{ref_key:"radioRef",ref:r,"onUpdate:modelValue":e=>(0,o.i9)(d)?d.value=e:null,class:(0,a.C4)((0,o.R1)(l).be("button","original-radio")),value:(0,o.R1)(p),type:"radio",name:e.name||(null==(v=(0,o.R1)(f))?void 0:v.name),disabled:(0,o.R1)(u),onFocus:e=>s.value=!0,onBlur:e=>s.value=!1,onClick:(0,c.D$)(()=>{},["stop"])},null,42,["onUpdate:modelValue","value","name","disabled","onFocus","onBlur","onClick"]),[[c.XL,(0,o.R1)(d)]]),(0,n.Lk)("span",{class:(0,a.C4)((0,o.R1)(l).be("button","inner")),style:(0,a.Tr)((0,o.R1)(d)===(0,o.R1)(p)?(0,o.R1)(m):{}),onKeydown:(0,c.D$)(()=>{},["stop"])},[(0,n.RG)(e.$slots,"default",{},()=>[(0,n.eW)((0,a.v_)(e.label),1)])],46,["onKeydown"])],2)}}});var R=(0,b.A)(z,[["__file","radio-button.vue"]]),k=(l(8111),l(3579),l(8501));const S=(0,r.b_)({id:{type:String,default:void 0},size:s.mU,disabled:{type:Boolean,default:void 0},modelValue:{type:[String,Number,Boolean],default:void 0},fill:{type:String,default:""},textColor:{type:String,default:""},name:{type:String,default:void 0},validateEvent:{type:Boolean,default:!0},options:{type:(0,r.jq)(Array)},props:{type:(0,r.jq)(Object),default:()=>A},type:{type:String,values:["radio","button"],default:"radio"},...(0,k.l)(["ariaLabel"])}),E=p,A={label:"label",value:"value",disabled:"disabled"};var N=l(1074),_=l(9195),T=l(1305),O=l(4216),W=l(6894);const B=(0,n.pM)({name:"ElRadioGroup"}),I=(0,n.pM)({...B,props:S,emits:E,setup(e,{emit:t}){const l=e,c=(0,y.DU)("radio"),r=(0,T.Bi)(),s=(0,o.KR)(),{formItem:u}=(0,O.j)(),{inputId:d,isLabeledByFormItem:f}=(0,O.W)(l,{formItemContext:u}),p=e=>{t(i.l4,e),(0,n.dY)(()=>t(i.YU,e))};(0,n.sV)(()=>{const e=s.value.querySelectorAll("[type=radio]"),t=e[0];!Array.from(e).some(e=>e.checked)&&t&&(t.tabIndex=0)});const v=(0,n.EW)(()=>l.name||r.value),h=(0,n.EW)(()=>({...A,...l.props})),g=e=>{const{label:t,value:l,disabled:n}=h.value,a={label:e[t],value:e[l],disabled:e[n]};return{...(0,N.A)(e,[t,l,n]),...a}},b=(0,n.EW)(()=>"button"===l.type?R:L);return(0,n.Gt)(m,(0,o.Kh)({...(0,o.QW)(l),changeEvent:p,name:v})),(0,n.wB)(()=>l.modelValue,(e,t)=>{l.validateEvent&&!(0,_.A)(e,t)&&(null==u||u.validate("change").catch(e=>(0,W.U)(e)))}),(e,t)=>((0,n.uX)(),(0,n.CE)("div",{id:(0,o.R1)(d),ref_key:"radioGroupRef",ref:s,class:(0,a.C4)((0,o.R1)(c).b("group")),role:"radiogroup","aria-label":(0,o.R1)(f)?void 0:e.ariaLabel||"radio-group","aria-labelledby":(0,o.R1)(f)?(0,o.R1)(u).labelId:void 0},[(0,n.RG)(e.$slots,"default",{},()=>[((0,n.uX)(!0),(0,n.CE)(n.FK,null,(0,n.pI)(e.options,(e,t)=>((0,n.uX)(),(0,n.Wv)((0,n.$y)((0,o.R1)(b)),(0,n.v6)({key:t},g(e)),null,16))),128))])],10,["id","aria-label","aria-labelledby"]))}});var D=(0,b.A)(I,[["__file","radio-group.vue"]]),F=l(5376);const V=(0,F.GU)(L,{RadioButton:R,RadioGroup:D}),P=(0,F.WM)(D),$=(0,F.WM)(R)},6823:function(e){"use strict";var t=String;e.exports=function(e){try{return t(e)}catch(l){return"Object"}}},6834:function(e,t,l){"use strict";l.d(t,{A:function(){return I}});l(4114);var n=l(6768),a=l(144),o=l(6032),c=l(3291),r=l(6340);const s=(0,a.KR)(),i=(0,a.KR)(0),u=(0,a.KR)(0);let d=0;const f=e=>{const t=[],l=document.createTreeWalker(e,NodeFilter.SHOW_ELEMENT,{acceptNode:e=>{const t="INPUT"===e.tagName&&"hidden"===e.type;return e.disabled||e.hidden||t?NodeFilter.FILTER_SKIP:e.tabIndex>=0||e===document.activeElement?NodeFilter.FILTER_ACCEPT:NodeFilter.FILTER_SKIP}});while(l.nextNode())t.push(l.currentNode);return t},p=(e,t)=>{for(const l of e)if(!m(l,t))return l},m=(e,t)=>{if("hidden"===getComputedStyle(e).visibility)return!0;while(e){if(t&&e===t)return!1;if("none"===getComputedStyle(e).display)return!0;e=e.parentElement}return!1},v=e=>{const t=f(e),l=p(t,e),n=p(t.reverse(),e);return[l,n]},h=e=>e instanceof HTMLInputElement&&"select"in e,g=(e,t)=>{if(e){const l=document.activeElement;(0,r.pW)(e,{preventScroll:!0}),u.value=window.performance.now(),e!==l&&h(e)&&t&&e.select()}};function b(e,t){const l=[...e],n=e.indexOf(t);return-1!==n&&l.splice(n,1),l}const y=()=>{let e=[];const t=t=>{const l=e[0];l&&t!==l&&l.pause(),e=b(e,t),e.unshift(t)},l=t=>{var l,n;e=b(e,t),null==(n=null==(l=e[0])?void 0:l.resume)||n.call(l)};return{push:t,remove:l}},C=(e,t=!1)=>{const l=document.activeElement;for(const n of e)if(g(n,t),document.activeElement!==l)return},w=y(),L=()=>i.value>u.value,x=()=>{s.value="pointer",i.value=window.performance.now()},M=()=>{s.value="keyboard",i.value=window.performance.now()},z=()=>((0,n.sV)(()=>{0===d&&(document.addEventListener("mousedown",x),document.addEventListener("touchstart",x),document.addEventListener("keydown",M)),d++}),(0,n.xo)(()=>{d--,d<=0&&(document.removeEventListener("mousedown",x),document.removeEventListener("touchstart",x),document.removeEventListener("keydown",M))}),{focusReason:s,lastUserFocusTimestamp:i,lastAutomatedFocusTimestamp:u}),R=e=>new CustomEvent(c.d,{...c.oV,detail:e});var k=l(9077),S=(l(8111),l(2489),l(7588),l(17)),E=l(4225),A=l(515);let N=[];const _=e=>{const t=(0,E.CG)(e);t===A.R.esc&&N.forEach(t=>t(e))},T=e=>{(0,n.sV)(()=>{0===N.length&&document.addEventListener("keydown",_),S.oc&&N.push(e)}),(0,n.xo)(()=>{N=N.filter(t=>t!==e),0===N.length&&S.oc&&document.removeEventListener("keydown",_)})};var O=l(4232);const W=(0,n.pM)({name:"ElFocusTrap",inheritAttrs:!1,props:{loop:Boolean,trapped:Boolean,focusTrapEl:Object,focusStartEl:{type:[Object,String],default:"first"}},emits:[c.NP,c.fI,"focusin","focusout","focusout-prevented","release-requested"],setup(e,{emit:t}){const l=(0,a.KR)();let r,s;const{focusReason:i}=z();T(l=>{e.trapped&&!u.paused&&t("release-requested",l)});const u={paused:!1,pause(){this.paused=!0},resume(){this.paused=!1}},d=l=>{if(!e.loop&&!e.trapped)return;if(u.paused)return;const{altKey:n,ctrlKey:a,metaKey:o,currentTarget:c,shiftKey:r}=l,{loop:s}=e,d=(0,E.CG)(l),f=d===A.R.tab&&!n&&!a&&!o,p=document.activeElement;if(f&&p){const e=c,[n,a]=v(e),o=n&&a;if(o)if(r||p!==a){if(r&&[n,e].includes(p)){const e=R({focusReason:i.value});t("focusout-prevented",e),e.defaultPrevented||(l.preventDefault(),s&&g(a,!0))}}else{const e=R({focusReason:i.value});t("focusout-prevented",e),e.defaultPrevented||(l.preventDefault(),s&&g(n,!0))}else if(p===e){const e=R({focusReason:i.value});t("focusout-prevented",e),e.defaultPrevented||l.preventDefault()}}};(0,n.Gt)(c.r3,{focusTrapRef:l,onKeydown:d}),(0,n.wB)(()=>e.focusTrapEl,e=>{e&&(l.value=e)},{immediate:!0}),(0,n.wB)([l],([e],[t])=>{e&&(e.addEventListener("keydown",d),e.addEventListener("focusin",h),e.addEventListener("focusout",b)),t&&(t.removeEventListener("keydown",d),t.removeEventListener("focusin",h),t.removeEventListener("focusout",b))});const p=e=>{t(c.NP,e)},m=e=>t(c.fI,e),h=n=>{const o=(0,a.R1)(l);if(!o)return;const c=n.target,i=n.relatedTarget,d=c&&o.contains(c);if(!e.trapped){const e=i&&o.contains(i);e||(r=i)}d&&t("focusin",n),u.paused||e.trapped&&(d?s=c:g(s,!0))},b=n=>{const c=(0,a.R1)(l);if(!u.paused&&c)if(e.trapped){const l=n.relatedTarget;(0,o.A)(l)||c.contains(l)||setTimeout(()=>{if(!u.paused&&e.trapped){const e=R({focusReason:i.value});t("focusout-prevented",e),e.defaultPrevented||g(s,!0)}},0)}else{const e=n.target,l=e&&c.contains(e);l||t("focusout",n)}};async function y(){await(0,n.dY)();const t=(0,a.R1)(l);if(t){w.push(u);const l=t.contains(document.activeElement)?r:document.activeElement;r=l;const a=t.contains(l);if(!a){const a=new Event(c.Ll,c.MP);t.addEventListener(c.Ll,p),t.dispatchEvent(a),a.defaultPrevented||(0,n.dY)(()=>{let n=e.focusStartEl;(0,O.Kg)(n)||(g(n),document.activeElement!==n&&(n="first")),"first"===n&&C(f(t),!0),document.activeElement!==l&&"container"!==n||g(t)})}}}function x(){const e=(0,a.R1)(l);if(e){e.removeEventListener(c.Ll,p);const t=new CustomEvent(c.aw,{...c.MP,detail:{focusReason:i.value}});e.addEventListener(c.aw,m),e.dispatchEvent(t),t.defaultPrevented||"keyboard"!=i.value&&L()&&!e.contains(document.activeElement)||g(null!=r?r:document.body),e.removeEventListener(c.aw,m),w.remove(u),r=null,s=null}}return(0,n.sV)(()=>{e.trapped&&y(),(0,n.wB)(()=>e.trapped,e=>{e?y():x()})}),(0,n.xo)(()=>{e.trapped&&x(),l.value&&(l.value.removeEventListener("keydown",d),l.value.removeEventListener("focusin",h),l.value.removeEventListener("focusout",b),l.value=void 0),r=null,s=null}),{onKeydown:d}}});function B(e,t,l,a,o,c){return(0,n.RG)(e.$slots,"default",{handleKeydown:e.onKeydown})}var I=(0,k.A)(W,[["render",B],["__file","focus-trap.vue"]])},6837:function(e){"use strict";var t=TypeError,l=9007199254740991;e.exports=function(e){if(e>l)throw t("Maximum allowed index exceeded");return e}},6840:function(e,t,l){"use strict";var n=l(4901),a=l(4913),o=l(283),c=l(9433);e.exports=function(e,t,l,r){r||(r={});var s=r.enumerable,i=void 0!==r.name?r.name:t;if(n(l)&&o(l,i,r),r.global)s?e[t]=l:c(t,l);else{try{r.unsafe?e[t]&&(s=!0):delete e[t]}catch(u){}s?e[t]=l:a.f(e,t,{value:l,enumerable:!1,configurable:!r.nonConfigurable,writable:!r.nonWritable})}return e}},6841:function(e,t){"use strict";function l(e,t){return e===t||e!==e&&t!==t}t.A=l},6865:function(e,t,l){"use strict";function n(e,t){return null!=e&&t in Object(e)}l.d(t,{A:function(){return m}});var a=n,o=l(5014),c=l(6162),r=l(3506),s=l(2676),i=l(5351),u=l(3708);function d(e,t,l){t=(0,o.A)(t,e);var n=-1,a=t.length,d=!1;while(++n(0,d.f)([])},previewTeleported:Boolean,zIndex:{type:Number},initialIndex:{type:Number,default:0},infinite:{type:Boolean,default:!0},closeOnPressEscape:{type:Boolean,default:!0},zoomRate:{type:Number,default:1.2},scale:{type:Number,default:1},minScale:{type:Number,default:.2},maxScale:{type:Number,default:7},showProgress:Boolean,crossorigin:{type:(0,u.jq)(String)}}),m={load:e=>e instanceof Event,error:e=>e instanceof Event,switch:e=>(0,f.Et)(e),close:()=>!0,show:()=>!0};var v=l(9077),h=l(6268),g=l(3513),b=l(3716),y=l(8587);const C=(0,n.pM)({name:"ElImage",inheritAttrs:!1}),w=(0,n.pM)({...C,props:p,emits:m,setup(e,{expose:t,emit:l}){const u=e,{t:d}=(0,h.Ym)(),p=(0,g.DU)("image"),m=(0,n.OA)(),v=(0,n.EW)(()=>(0,s.A)(Object.entries(m).filter(([e])=>/^(data-|on[A-Z])/i.test(e)||["id","style"].includes(e)))),C=(0,b.O)({excludeListeners:!0,excludeKeys:(0,n.EW)(()=>Object.keys(v.value))}),w=(0,a.KR)(),L=(0,a.KR)(!1),x=(0,a.KR)(!0),M=(0,a.KR)(!1),z=(0,a.KR)(),R=(0,a.KR)(),k=c.oc&&"loading"in HTMLImageElement.prototype;let S;const E=(0,n.EW)(()=>[p.e("inner"),N.value&&p.e("preview"),x.value&&p.is("loading")]),A=(0,n.EW)(()=>{const{fit:e}=u;return c.oc&&e?{objectFit:e}:{}}),N=(0,n.EW)(()=>{const{previewSrcList:e}=u;return(0,o.cy)(e)&&e.length>0}),_=(0,n.EW)(()=>{const{previewSrcList:e,initialIndex:t}=u;let l=t;return t>e.length-1&&(l=0),l}),T=(0,n.EW)(()=>"eager"!==u.loading&&(!k&&"lazy"===u.loading||u.lazy)),O=()=>{c.oc&&(x.value=!0,L.value=!1,w.value=u.src)};function W(e){x.value=!1,L.value=!1,l("load",e)}function B(e){x.value=!1,L.value=!0,l("error",e)}function I(e){e&&(O(),V())}const D=(0,c.k3)(I,200,!0);async function F(){var e;if(!c.oc)return;await(0,n.dY)();const{scrollContainer:t}=u;if((0,f.vq)(t))R.value=t;else if((0,o.Kg)(t)&&""!==t)R.value=null!=(e=document.querySelector(t))?e:void 0;else if(z.value){const e=(0,y.Bo)(z.value);R.value=(0,f.l6)(e)?void 0:e}const{stop:l}=(0,r.BLq)(z,([e])=>{D(e.isIntersecting)},{root:R});S=l}function V(){c.oc&&D&&(null==S||S(),R.value=void 0,S=void 0)}function P(){N.value&&(M.value=!0,l("show"))}function $(){M.value=!1,l("close")}function H(e){l("switch",e)}return(0,n.wB)(()=>u.src,()=>{T.value?(x.value=!0,L.value=!1,V(),F()):O()}),(0,n.sV)(()=>{T.value?F():O()}),t({showPreview:P}),(e,t)=>((0,n.uX)(),(0,n.CE)("div",(0,n.v6)({ref_key:"container",ref:z},(0,a.R1)(v),{class:[(0,a.R1)(p).b(),e.$attrs.class]}),[L.value?(0,n.RG)(e.$slots,"error",{key:0},()=>[(0,n.Lk)("div",{class:(0,o.C4)((0,a.R1)(p).e("error"))},(0,o.v_)((0,a.R1)(d)("el.image.error")),3)]):((0,n.uX)(),(0,n.CE)(n.FK,{key:1},[void 0!==w.value?((0,n.uX)(),(0,n.CE)("img",(0,n.v6)({key:0},(0,a.R1)(C),{src:w.value,loading:e.loading,style:(0,a.R1)(A),class:(0,a.R1)(E),crossorigin:e.crossorigin,onClick:P,onLoad:W,onError:B}),null,16,["src","loading","crossorigin"])):(0,n.Q3)("v-if",!0),x.value?((0,n.uX)(),(0,n.CE)("div",{key:1,class:(0,o.C4)((0,a.R1)(p).e("wrapper"))},[(0,n.RG)(e.$slots,"placeholder",{},()=>[(0,n.Lk)("div",{class:(0,o.C4)((0,a.R1)(p).e("placeholder"))},null,2)])],2)):(0,n.Q3)("v-if",!0)],64)),(0,a.R1)(N)?((0,n.uX)(),(0,n.CE)(n.FK,{key:2},[M.value?((0,n.uX)(),(0,n.Wv)((0,a.R1)(i.Tg),{key:0,"z-index":e.zIndex,"initial-index":(0,a.R1)(_),infinite:e.infinite,"zoom-rate":e.zoomRate,"min-scale":e.minScale,"max-scale":e.maxScale,"show-progress":e.showProgress,"url-list":e.previewSrcList,scale:e.scale,crossorigin:e.crossorigin,"hide-on-click-modal":e.hideOnClickModal,teleported:e.previewTeleported,"close-on-press-escape":e.closeOnPressEscape,onClose:$,onSwitch:H},(0,n.eX)({toolbar:(0,n.k6)(t=>[(0,n.RG)(e.$slots,"toolbar",(0,o._B)((0,n.Ng)(t)))]),default:(0,n.k6)(()=>[e.$slots.viewer?((0,n.uX)(),(0,n.CE)("div",{key:0},[(0,n.RG)(e.$slots,"viewer")])):(0,n.Q3)("v-if",!0)]),_:2},[e.$slots.progress?{name:"progress",fn:(0,n.k6)(t=>[(0,n.RG)(e.$slots,"progress",(0,o._B)((0,n.Ng)(t)))])}:void 0,e.$slots["viewer-error"]?{name:"viewer-error",fn:(0,n.k6)(t=>[(0,n.RG)(e.$slots,"viewer-error",(0,o._B)((0,n.Ng)(t)))])}:void 0]),1032,["z-index","initial-index","infinite","zoom-rate","min-scale","max-scale","show-progress","url-list","scale","crossorigin","hide-on-click-modal","teleported","close-on-press-escape"])):(0,n.Q3)("v-if",!0)],64)):(0,n.Q3)("v-if",!0)],16))}});var L=(0,v.A)(w,[["__file","image.vue"]]),x=l(5376);const M=(0,x.GU)(L)},7017:function(e,t,l){"use strict";l.d(t,{Ap:function(){return o},Rd:function(){return n},rc:function(){return a}});const n=4,a={vertical:{offset:"offsetHeight",scroll:"scrollTop",scrollSize:"scrollHeight",size:"height",key:"vertical",axis:"Y",client:"clientY",direction:"top"},horizontal:{offset:"offsetWidth",scroll:"scrollLeft",scrollSize:"scrollWidth",size:"width",key:"horizontal",axis:"X",client:"clientX",direction:"left"}},o=({move:e,size:t,bar:l})=>({[l.size]:t,transform:`translate${l.axis}(${e}%)`})},7023:function(e,t,l){"use strict";l.d(t,{W:function(){return r}});l(4114),l(8111),l(2489),l(1701),l(3579);var n=l(6768),a=l(144),o=l(6139);const c=(e,t,l)=>{const a=(0,o.CW)(e.subTree).filter(e=>{var l;return(0,n.vv)(e)&&(null==(l=e.type)?void 0:l.name)===t&&!!e.component}),c=a.map(e=>e.component.uid);return c.map(e=>l[e]).filter(e=>!!e)},r=(e,t)=>{const l=(0,a.IJ)({}),o=(0,a.IJ)([]),r=new WeakMap,s=e=>{l.value[e.uid]=e,(0,a.mu)(l),(0,n.sV)(()=>{const t=e.getVnode().el,n=t.parentNode;if(!r.has(n)){r.set(n,[]);const e=n.insertBefore.bind(n);n.insertBefore=(t,o)=>{const c=r.get(n).some(e=>t===e||o===e);return c&&(0,a.mu)(l),e(t,o)}}r.get(n).push(t)})},i=e=>{delete l.value[e.uid],(0,a.mu)(l);const t=e.getVnode().el,n=t.parentNode,o=r.get(n),c=o.indexOf(t);o.splice(c,1)},u=()=>{o.value=c(e,t,l.value)},d=e=>e.render(),f=(0,n.pM)({setup(e,{slots:t}){return()=>(u(),t.default?(0,n.h)(d,{render:t.default}):null)}});return{children:o,addChild:s,removeChild:i,ChildrenSorter:f}}},7040:function(e,t,l){"use strict";var n=l(4495);e.exports=n&&!Symbol.sham&&"symbol"==typeof Symbol.iterator},7055:function(e,t,l){"use strict";var n=l(9504),a=l(9039),o=l(2195),c=Object,r=n("".split);e.exports=a(function(){return!c("z").propertyIsEnumerable(0)})?function(e){return"String"===o(e)?r(e,""):c(e)}:c},7063:function(e,t,l){"use strict";l.d(t,{A:function(){return r}});var n=l(6697),a=l(5431),o=l(2808);const c={[n.bx]:"deltaX",[n.tT]:"deltaY"},r=({atEndEdge:e,atStartEdge:t,layout:l},n)=>{let r,s=0;const i=l=>{const n=l<0&&t.value||l>0&&e.value;return n},u=e=>{(0,a.V)(r);const t=e[c[l.value]];i(s)&&i(s+t)||(s+=t,(0,o.gm)()||e.preventDefault(),r=(0,a.m)(()=>{n(s),s=0}))};return{hasReachedEdge:i,onWheel:u}}},7080:function(e,t,l){"use strict";var n=l(4402).has;e.exports=function(e){return n(e),e}},7083:function(e,t,l){"use strict";var n=l(1591),a=l(168),o="[object AsyncFunction]",c="[object Function]",r="[object GeneratorFunction]",s="[object Proxy]";function i(e){if(!(0,a.A)(e))return!1;var t=(0,n.A)(e);return t==c||t==r||t==o||t==s}t.A=i},7138:function(e,t,l){"use strict";l.d(t,{Up:function(){return Xl},o8:function(){return Ul}});var n=l(6768),a=l(4232),o=l(5130),c=l(6301),r=l(8559),s=(l(8111),l(7588),l(4114),l(116),l(1701),l(144));function i(e){return null===e}var u=i,d=(l(2489),l(3579),l(8237),l(2308)),f=l(5347),p=l(7582);function m(e){return function(t,l,n){var a=-1,o=Object(t),c=n(t),r=c.length;while(r--){var s=c[e?r:++a];if(!1===l(o[s],s,o))break}return t}}var v=m,h=v(),g=h,b=l(6166);function y(e,t){return e&&g(e,t,b.A)}var C=y,w=l(1805);function L(e,t){return function(l,n){if(null==l)return l;if(!(0,w.A)(l))return e(l,n);var a=l.length,o=t?a:-1,c=Object(l);while(t?o--:++o1?l[a-1]:void 0,c=a>2?l[2]:void 0;o=e.length>3&&"function"==typeof o?(a--,o):void 0,c&&ue(l[0],l[1],c)&&(o=a<3?void 0:o,a=1),t=Object(t);while(++n(0,a.Kg)(t)?(0,O.A)(l,t):t(l,n,e)):("$key"!==t&&(0,a.Gv)(l)&&"$value"in l&&(l=l.$value),[(0,a.Gv)(l)?t?(0,O.A)(l,t):null:l])},r=function(e,t){var l,a,o,c,r,s;if(n)return n(e.value,t.value);for(let n=0,i=null!=(a=null==(l=e.key)?void 0:l.length)?a:0;n(null==(s=t.key)?void 0:s[n]))return 1}return 0};return e.map((e,t)=>({value:e,index:t,key:c?c(e,t):null})).sort((e,t)=>{let n=r(e,t);return n||(n=e.index-t.index),n*+l}).map(e=>e.value)},we=function(e,t){let l=null;return e.columns.forEach(e=>{e.id===t&&(l=e)}),l},Le=function(e,t){let l=null;for(let n=0;n{if(!e)throw new Error("Row is required when get row identity");if((0,a.Kg)(t)){if(!t.includes("."))return`${e[t]}`;const l=t.split(".");let n=e;for(const e of l)n=n[e];return`${n}`}return(0,a.Tn)(t)?t.call(null,e):""},ze=function(e,t,l=!1,n="children"){const o=e||[],c={};return o.forEach((e,o)=>{if(c[Me(e,t)]={row:e,index:o},l){const l=e[n];(0,a.cy)(l)&&Object.assign(c,ze(l,t,!0,n))}}),c};function Re(e,t){const l={};let n;for(n in e)l[n]=e[n];for(n in t)if((0,a.$3)(t,n)){const e=t[n];(0,ge.b0)(e)||(l[n]=e)}return l}function ke(e){return""===e||(0,ge.b0)(e)||(e=Number.parseInt(e,10),Number.isNaN(e)&&(e="")),e}function Se(e){return""===e||(0,ge.b0)(e)||(e=ke(e),Number.isNaN(e)&&(e=80)),e}function Ee(e){return(0,ge.Et)(e)?e:(0,a.Kg)(e)?/^\d+(?:px)?$/.test(e)?Number.parseInt(e,10):e:null}function Ae(...e){return 0===e.length?e=>e:1===e.length?e[0]:e.reduce((e,t)=>(...l)=>e(t(...l)))}function Ne(e,t,l,n,o,c,r){let s=null!=c?c:0,i=!1;const u=()=>{if(!r)return e.indexOf(t);const l=Me(t,r);return e.findIndex(e=>Me(e,r)===l)},d=u(),f=-1!==d,p=null==o?void 0:o.call(null,t,s),m=l=>{"add"===l?e.push(t):e.splice(d,1),i=!0},v=e=>{let t=0;const l=(null==n?void 0:n.children)&&e[n.children];return l&&(0,a.cy)(l)&&(t+=l.length,l.forEach(e=>{t+=v(e)})),t};return o&&!p||((0,ge.Lm)(l)?l&&!f?m("add"):!l&&f&&m("remove"):m(f?"remove":"add")),!(null==n?void 0:n.checkStrictly)&&(null==n?void 0:n.children)&&(0,a.cy)(t[n.children])&&t[n.children].forEach(t=>{const a=Ne(e,t,null!=l?l:!f,n,o,s+1,r);s+=v(t)+1,a&&(i=a)}),i}function _e(e,t,l="children",n="hasChildren",o=!1){const c=e=>!((0,a.cy)(e)&&e.length);function r(e,a,s){t(e,a,s),a.forEach(e=>{if(e[n]&&o)return void t(e,null,s+1);const a=e[l];c(a)||r(e,a,s+1)})}e.forEach(e=>{if(e[n]&&o)return void t(e,null,0);const a=e[l];c(a)||r(e,a,0)})}const Te=(e,t,l,o)=>{const c={strategy:"fixed",...e.popperOptions},r=(0,a.Tn)(null==o?void 0:o.tooltipFormatter)?o.tooltipFormatter({row:l,column:o,cellValue:(0,be.GT)(l,o.property).value}):void 0;return(0,n.vv)(r)?{slotContent:r,content:null,...e,popperOptions:c}:{slotContent:null,content:null!=r?r:t,...e,popperOptions:c}};let Oe=null;function We(e,t,l,a,c,r){var s;const i=Te(e,t,l,a),u={...i,slotContent:void 0};if((null==Oe?void 0:Oe.trigger)===c){const e=null==(s=Oe.vm)?void 0:s.component;return me(null==e?void 0:e.props,u),void(e&&i.slotContent&&(e.slots.content=()=>[i.slotContent]))}null==Oe||Oe();const d=null==r?void 0:r.refs.tableWrapper,f=null==d?void 0:d.dataset.prefix,p=(0,n.bF)(ve.R7,{virtualTriggering:!0,virtualRef:c,appendTo:d,placement:"top",transition:"none",offset:0,hideAfter:0,...u},i.slotContent?{content:()=>i.slotContent}:void 0);p.appContext={...r.appContext,...r};const m=document.createElement("div");(0,o.XX)(p,m),p.component.exposed.onOpen();const v=null==d?void 0:d.querySelector(`.${f}-scrollbar__wrap`);Oe=()=>{var e,t;(null==(t=null==(e=p.component)?void 0:e.exposed)?void 0:t.onClose)&&p.component.exposed.onClose(),(0,o.XX)(null,m);const l=Oe;null==v||v.removeEventListener("scroll",l),l.trigger=void 0,l.vm=void 0,Oe=null},Oe.trigger=null!=c?c:void 0,Oe.vm=p,null==v||v.addEventListener("scroll",Oe)}function Be(e){return e.children?_(e.children,Be):[e]}function Ie(e,t){return e+t.colSpan}const De=(e,t,l,n)=>{let a=0,o=e;const c=l.states.columns.value;if(n){const t=Be(n[e]),l=c.slice(0,c.indexOf(t[0]));a=l.reduce(Ie,0),o=a+t.reduce(Ie,0)-1}else a=e;let r;switch(t){case"left":o=c.length-l.states.rightFixedLeafColumnsLength.value&&(r="right");break;default:o=c.length-l.states.rightFixedLeafColumnsLength.value&&(r="right")}return r?{direction:r,start:a,after:o}:{}},Fe=(e,t,l,n,a,o=0)=>{const c=[],{direction:r,start:s,after:i}=De(t,l,n,a);if(r){const t="left"===r;c.push(`${e}-fixed-column--${r}`),t&&i+o===n.states.fixedLeafColumnsLength.value-1?c.push("is-last-column"):t||s-o!==n.states.columns.value.length-n.states.rightFixedLeafColumnsLength.value||c.push("is-first-column")}return c};function Ve(e,t){return e+(u(t.realWidth)||Number.isNaN(t.realWidth)?Number(t.width):t.realWidth)}const Pe=(e,t,l,n)=>{const{direction:a,start:o=0,after:c=0}=De(e,t,l,n);if(!a)return;const r={},s="left"===a,i=l.states.columns.value;return s?r.left=i.slice(0,o).reduce(Ve,0):r.right=i.slice(c+1).reverse().reduce(Ve,0),r},$e=(e,t)=>{e&&(Number.isNaN(e[t])||(e[t]=`${e[t]}px`))};function He(e){return e.some(e=>!(0,n.vv)(e)||e.type!==n.Mw&&!(e.type===n.FK&&!He(e.children)))?e:null}function je(e){const t=(0,n.nI)(),l=(0,s.KR)(!1),a=(0,s.KR)([]),o=()=>{const t=e.data.value||[],n=e.rowKey.value;if(l.value)a.value=t.slice();else if(n){const e=ze(a.value,n);a.value=t.reduce((t,l)=>{const a=Me(l,n),o=e[a];return o&&t.push(l),t},[])}else a.value=[]},c=(l,n)=>{const o=Ne(a.value,l,n,void 0,void 0,void 0,e.rowKey.value);o&&t.emit("expand-change",l,a.value.slice())},r=l=>{t.store.assertRowKey();const n=e.data.value||[],o=e.rowKey.value,c=ze(n,o);a.value=l.reduce((e,t)=>{const l=c[t];return l&&e.push(l.row),e},[])},i=t=>{const l=e.rowKey.value;if(l){const e=ze(a.value,l);return!!e[Me(t,l)]}return a.value.includes(t)};return{updateExpandRows:o,toggleRowExpansion:c,setExpandRowKeys:r,isRowExpanded:i,states:{expandRows:a,defaultExpandAll:l}}}function Ke(e){const t=(0,n.nI)(),l=(0,s.KR)(null),a=(0,s.KR)(null),o=e=>{t.store.assertRowKey(),l.value=e,r(e)},c=()=>{l.value=null},r=l=>{var n;const{data:o,rowKey:c}=e;let r=null;c.value&&(r=null!=(n=((0,s.R1)(o)||[]).find(e=>Me(e,c.value)===l))?n:null),a.value=null!=r?r:null,t.emit("current-change",a.value,null)},i=e=>{const l=a.value;if(e&&e!==l)return a.value=e,void t.emit("current-change",a.value,l);!e&&l&&(a.value=null,t.emit("current-change",null,l))},d=()=>{const n=e.rowKey.value,o=e.data.value||[],s=a.value;if(s&&!o.includes(s)){if(n){const e=Me(s,n);r(e)}else a.value=null;u(a.value)&&t.emit("current-change",null,s)}else l.value&&(r(l.value),c())};return{setCurrentRowKey:o,restoreCurrentRowKey:c,setCurrentRowByKey:r,updateCurrentRow:i,updateCurrentRowData:d,states:{_currentRowKey:l,currentRow:a}}}function Xe(e){const t=(0,s.KR)([]),l=(0,s.KR)({}),o=(0,s.KR)(16),c=(0,s.KR)(!1),r=(0,s.KR)({}),i=(0,s.KR)("hasChildren"),u=(0,s.KR)("children"),d=(0,s.KR)(!1),f=(0,n.nI)(),p=(0,n.EW)(()=>{if(!e.rowKey.value)return{};const t=e.data.value||[];return v(t)}),m=(0,n.EW)(()=>{const t=e.rowKey.value,l=Object.keys(r.value),n={};return l.length?(l.forEach(e=>{if(r.value[e].length){const l={children:[]};r.value[e].forEach(e=>{const a=Me(e,t);l.children.push(a),e[i.value]&&!n[a]&&(n[a]={children:[]})}),n[e]=l}}),n):n}),v=t=>{const l=e.rowKey.value,n={};return _e(t,(e,t,o)=>{const r=Me(e,l);(0,a.cy)(t)?n[r]={children:t.map(e=>Me(e,l)),level:o}:c.value&&(n[r]={children:[],lazy:!0,level:o})},u.value,i.value,c.value),n},h=(e=!1,n)=>{var a,o;n||(n=null==(a=f.store)?void 0:a.states.defaultExpandAll.value);const r=p.value,i=m.value,u=Object.keys(r),d={};if(u.length){const a=(0,s.R1)(l),o=[],f=(l,a)=>{if(e)return t.value?n||t.value.includes(a):!(!n&&!(null==l?void 0:l.expanded));{const e=n||t.value&&t.value.includes(a);return!(!(null==l?void 0:l.expanded)&&!e)}};u.forEach(e=>{const t=a[e],l={...r[e]};if(l.expanded=f(t,e),l.lazy){const{loaded:n=!1,loading:a=!1}=t||{};l.loaded=!!n,l.loading=!!a,o.push(e)}d[e]=l});const p=Object.keys(i);c.value&&p.length&&o.length&&p.forEach(e=>{var t;const l=a[e],n=i[e].children;if(o.includes(e)){if(0!==(null==(t=d[e].children)?void 0:t.length))throw new Error("[ElTable]children must be an empty array.");d[e].children=n}else{const{loaded:t=!1,loading:a=!1}=l||{};d[e]={lazy:!0,loaded:!!t,loading:!!a,expanded:f(l,e),children:n,level:void 0}}})}l.value=d,null==(o=f.store)||o.updateTableScrollY()};(0,n.wB)(()=>t.value,()=>{h(!0)}),(0,n.wB)(()=>p.value,()=>{h()}),(0,n.wB)(()=>m.value,()=>{h()});const g=e=>{t.value=e,h()},b=e=>c.value&&e&&"loaded"in e&&!e.loaded,y=(t,n)=>{f.store.assertRowKey();const a=e.rowKey.value,o=Me(t,a),c=o&&l.value[o];if(o&&c&&"expanded"in c){const e=c.expanded;n=(0,ge.b0)(n)?!c.expanded:n,l.value[o].expanded=n,e!==n&&f.emit("expand-change",t,n),n&&b(c)&&w(t,o,c),f.store.updateTableScrollY()}},C=t=>{f.store.assertRowKey();const n=e.rowKey.value,a=Me(t,n),o=l.value[a];b(o)?w(t,a,o):y(t,void 0)},w=(e,t,n)=>{const{load:o}=f.props;o&&!l.value[t].loaded&&(l.value[t].loading=!0,o(e,n,n=>{if(!(0,a.cy)(n))throw new TypeError("[ElTable] data must be an array");l.value[t].loading=!1,l.value[t].loaded=!0,l.value[t].expanded=!0,n.length&&(r.value[t]=n),f.emit("expand-change",e,!0)}))},L=(e,t)=>{const{lazy:l,rowKey:n}=f.props;if(l){if(!n)throw new Error("[Table] rowKey is required in updateKeyChild");r.value[e]&&(r.value[e]=t)}};return{loadData:w,loadOrToggle:C,toggleTreeExpansion:y,updateTreeExpandKeys:g,updateTreeData:h,updateKeyChildren:L,normalize:v,states:{expandRowKeys:t,treeData:l,indent:o,lazy:c,lazyTreeNodeMap:r,lazyColumnIdentifier:i,childrenColumnName:u,checkStrictly:d}}}const Ue=(e,t)=>{const l=t.sortingColumn;return!l||(0,a.Kg)(l.sortable)?e:Ce(e,t.sortProp,t.sortOrder,l.sortMethod,l.sortBy)},qe=e=>{const t=[];return e.forEach(e=>{e.children&&e.children.length>0?t.push.apply(t,qe(e.children)):t.push(e)}),t};function Ge(){var e;const t=(0,n.nI)(),{size:l}=(0,s.QW)(null==(e=t.proxy)?void 0:e.$props),o=(0,s.KR)(null),c=(0,s.KR)([]),r=(0,s.KR)([]),i=(0,s.KR)(!1),u=(0,s.KR)([]),d=(0,s.KR)([]),f=(0,s.KR)([]),p=(0,s.KR)([]),m=(0,s.KR)([]),v=(0,s.KR)([]),h=(0,s.KR)([]),g=(0,s.KR)([]),b=[],y=(0,s.KR)(0),C=(0,s.KR)(0),w=(0,s.KR)(0),L=(0,s.KR)(!1),x=(0,s.KR)([]),M=(0,s.KR)(!1),z=(0,s.KR)(!1),R=(0,s.KR)(null),k=(0,s.KR)({}),S=(0,s.KR)(null),E=(0,s.KR)(null),A=(0,s.KR)(null),N=(0,s.KR)(null),_=(0,s.KR)(null),O=(0,n.EW)(()=>o.value?ze(x.value,o.value):void 0);(0,n.wB)(c,()=>{var e;if(t.state){D(!1);const l="auto"===t.props.tableLayout;l&&(null==(e=t.refs.tableHeaderRef)||e.updateFixedColumnStyle())}},{deep:!0});const W=()=>{if(!o.value)throw new Error("[ElTable] prop row-key is required")},B=e=>{var t;null==(t=e.children)||t.forEach(t=>{t.fixed=e.fixed,B(t)})},I=()=>{u.value.forEach(e=>{B(e)}),p.value=u.value.filter(e=>[!0,"left"].includes(e.fixed));const e=u.value.find(e=>"selection"===e.type);let t;if(e&&"right"!==e.fixed&&!p.value.includes(e)){const l=u.value.indexOf(e);0===l&&p.value.length&&(p.value.unshift(e),t=!0)}m.value=u.value.filter(e=>"right"===e.fixed);const l=u.value.filter(e=>(!t||"selection"!==e.type)&&!e.fixed);d.value=Array.from(p.value).concat(l).concat(m.value);const n=qe(l),a=qe(p.value),o=qe(m.value);y.value=n.length,C.value=a.length,w.value=o.length,f.value=Array.from(a).concat(n).concat(o),i.value=p.value.length>0||m.value.length>0},D=(e,l=!1)=>{e&&I(),l?t.state.doLayout():t.state.debouncedUpdateLayout()},F=e=>O.value?!!O.value[Me(e,o.value)]:x.value.includes(e),V=()=>{L.value=!1;const e=x.value;x.value=[],e.length&&t.emit("selection-change",[])},P=()=>{var e,l;let n;if(o.value){n=[];const r=null==(l=null==(e=null==t?void 0:t.store)?void 0:e.states)?void 0:l.childrenColumnName.value,s=ze(c.value,o.value,!0,r);for(const e in O.value)(0,a.$3)(O.value,e)&&!s[e]&&n.push(O.value[e].row)}else n=x.value.filter(e=>!c.value.includes(e));if(n.length){const e=x.value.filter(e=>!n.includes(e));x.value=e,t.emit("selection-change",e.slice())}},$=()=>(x.value||[]).slice(),H=(e,l,n=!0,a=!1)=>{var r,s,i,u;const d={children:null==(s=null==(r=null==t?void 0:t.store)?void 0:r.states)?void 0:s.childrenColumnName.value,checkStrictly:null==(u=null==(i=null==t?void 0:t.store)?void 0:i.states)?void 0:u.checkStrictly.value},f=Ne(x.value,e,l,d,a?void 0:R.value,c.value.indexOf(e),o.value);if(f){const l=(x.value||[]).slice();n&&t.emit("select",l,e),t.emit("selection-change",l)}},j=()=>{var e,l;const n=z.value?!L.value:!(L.value||x.value.length);L.value=n;let a=!1,o=0;const r=null==(l=null==(e=null==t?void 0:t.store)?void 0:e.states)?void 0:l.rowKey.value,{childrenColumnName:s}=t.store.states,i={children:s.value,checkStrictly:!1};c.value.forEach((e,t)=>{const l=t+o;Ne(x.value,e,n,i,R.value,l,r)&&(a=!0),o+=X(Me(e,r))}),a&&t.emit("selection-change",x.value?x.value.slice():[]),t.emit("select-all",(x.value||[]).slice())},K=()=>{var e;if(0===(null==(e=c.value)?void 0:e.length))return void(L.value=!1);const{childrenColumnName:l}=t.store.states;let n=0,a=0;const o=e=>{var t;for(const c of e){const e=R.value&&R.value.call(null,c,n);if(F(c))a++;else if(!R.value||e)return!1;if(n++,(null==(t=c[l.value])?void 0:t.length)&&!o(c[l.value]))return!1}return!0},r=o(c.value||[]);L.value=0!==a&&r},X=e=>{var l;if(!t||!t.store)return 0;const{treeData:n}=t.store.states;let a=0;const o=null==(l=n.value[e])?void 0:l.children;return o&&(a+=o.length,o.forEach(e=>{a+=X(e)})),a},U=(e,t)=>{const l={};return(0,T.A)(e).forEach(e=>{k.value[e.id]=t,l[e.columnKey||e.id]=t}),l},q=(e,t,l)=>{E.value&&E.value!==e&&(E.value.order=null),E.value=e,A.value=t,N.value=l},G=()=>{let e=(0,s.R1)(r);Object.keys(k.value).forEach(t=>{const l=k.value[t];if(!l||0===l.length)return;const n=we({columns:f.value},t);n&&n.filterMethod&&(e=e.filter(e=>l.some(t=>n.filterMethod.call(null,t,e,n))))}),S.value=e},Y=()=>{var e;c.value=Ue(null!=(e=S.value)?e:[],{sortingColumn:E.value,sortProp:A.value,sortOrder:N.value})},Q=(e=void 0)=>{(null==e?void 0:e.filter)||G(),Y()},Z=e=>{const{tableHeaderRef:l}=t.refs;if(!l)return;const n=Object.assign({},l.filterPanels),o=Object.keys(n);if(o.length)if((0,a.Kg)(e)&&(e=[e]),(0,a.cy)(e)){const l=e.map(e=>Le({columns:f.value},e));o.forEach(e=>{const t=l.find(t=>t.id===e);t&&(t.filteredValue=[])}),t.store.commit("filterChange",{column:l,values:[],silent:!0,multi:!0})}else o.forEach(e=>{const t=f.value.find(t=>t.id===e);t&&(t.filteredValue=[])}),k.value={},t.store.commit("filterChange",{column:{},values:[],silent:!0})},J=()=>{E.value&&(q(null,null,null),t.store.commit("changeSortCondition",{silent:!0}))},{setExpandRowKeys:ee,toggleRowExpansion:te,updateExpandRows:le,states:ne,isRowExpanded:ae}=je({data:c,rowKey:o}),{updateTreeExpandKeys:oe,toggleTreeExpansion:ce,updateTreeData:re,updateKeyChildren:se,loadOrToggle:ie,states:ue}=Xe({data:c,rowKey:o}),{updateCurrentRowData:de,updateCurrentRow:fe,setCurrentRowKey:pe,states:me}=Ke({data:c,rowKey:o}),ve=e=>{ee(e),oe(e)},he=(e,t)=>{const l=f.value.some(({type:e})=>"expand"===e);l?te(e,t):ce(e,t)};return{assertRowKey:W,updateColumns:I,scheduleLayout:D,isSelected:F,clearSelection:V,cleanSelection:P,getSelectionRows:$,toggleRowSelection:H,_toggleAllSelection:j,toggleAllSelection:null,updateAllSelected:K,updateFilters:U,updateCurrentRow:fe,updateSort:q,execFilter:G,execSort:Y,execQuery:Q,clearFilter:Z,clearSort:J,toggleRowExpansion:te,setExpandRowKeysAdapter:ve,setCurrentRowKey:pe,toggleRowExpansionAdapter:he,isRowExpanded:ae,updateExpandRows:le,updateCurrentRowData:de,loadOrToggle:ie,updateTreeData:re,updateKeyChildren:se,states:{tableSize:l,rowKey:o,data:c,_data:r,isComplex:i,_columns:u,originColumns:d,columns:f,fixedColumns:p,rightFixedColumns:m,leafColumns:v,fixedLeafColumns:h,rightFixedLeafColumns:g,updateOrderFns:b,leafColumnsLength:y,fixedLeafColumnsLength:C,rightFixedLeafColumnsLength:w,isAllSelected:L,selection:x,reserveSelection:M,selectOnIndeterminate:z,selectable:R,filters:k,filteredData:S,sortingColumn:E,sortProp:A,sortOrder:N,hoverRow:_,...ne,...ue,...me}}}var Ye=l(3513),Qe=l(6268);function Ze(e,t){return e.map(e=>{var l;return e.id===t.id?t:((null==(l=e.children)?void 0:l.length)&&(e.children=Ze(e.children,t)),e)})}function Je(e){e.forEach(e=>{var t,l;e.no=null==(t=e.getColumnIndex)?void 0:t.call(e),(null==(l=e.children)?void 0:l.length)&&Je(e.children)}),e.sort((e,t)=>e.no-t.no)}function et(){const e=(0,n.nI)(),t=Ge(),l=(0,Ye.DU)("table"),{t:a}=(0,Qe.Ym)(),o={setData(t,l){const n=(0,s.R1)(t._data)!==l;t.data.value=l,t._data.value=l,e.store.execQuery(),e.store.updateCurrentRowData(),e.store.updateExpandRows(),e.store.updateTreeData(e.store.states.defaultExpandAll.value),(0,s.R1)(t.reserveSelection)?e.store.assertRowKey():n?e.store.clearSelection():e.store.cleanSelection(),e.store.updateAllSelected(),e.$ready&&e.store.scheduleLayout()},insertColumn(t,l,n,a){var o;const c=(0,s.R1)(t._columns);let r=[];n?(n&&!n.children&&(n.children=[]),null==(o=n.children)||o.push(l),r=Ze(c,n)):(c.push(l),r=c),Je(r),t._columns.value=r,t.updateOrderFns.push(a),"selection"===l.type&&(t.selectable.value=l.selectable,t.reserveSelection.value=l.reserveSelection),e.$ready&&(e.store.updateColumns(),e.store.scheduleLayout())},updateColumnOrder(t,l){var n;const a=null==(n=l.getColumnIndex)?void 0:n.call(l);a!==l.no&&(Je(t._columns.value),e.$ready&&e.store.updateColumns())},removeColumn(t,l,a,o){var c;const r=(0,s.R1)(t._columns)||[];if(a)null==(c=a.children)||c.splice(a.children.findIndex(e=>e.id===l.id),1),(0,n.dY)(()=>{var e;0===(null==(e=a.children)?void 0:e.length)&&delete a.children}),t._columns.value=Ze(r,a);else{const e=r.indexOf(l);e>-1&&(r.splice(e,1),t._columns.value=r)}const i=t.updateOrderFns.indexOf(o);i>-1&&t.updateOrderFns.splice(i,1),e.$ready&&(e.store.updateColumns(),e.store.scheduleLayout())},sort(t,l){const{prop:n,order:a,init:o}=l;if(n){const l=(0,s.R1)(t.columns).find(e=>e.property===n);l&&(l.order=a,e.store.updateSort(l,n,a),e.store.commit("changeSortCondition",{init:o}))}},changeSortCondition(t,l){const{sortingColumn:n,sortProp:a,sortOrder:o}=t,c=(0,s.R1)(n),r=(0,s.R1)(a),i=(0,s.R1)(o);u(i)&&(t.sortingColumn.value=null,t.sortProp.value=null);const d={filter:!0};e.store.execQuery(d),l&&(l.silent||l.init)||e.emit("sort-change",{column:c,prop:r,order:i}),e.store.updateTableScrollY()},filterChange(t,l){const{column:n,values:a,silent:o}=l,c=e.store.updateFilters(n,a);e.store.execQuery(),o||e.emit("filter-change",c),e.store.updateTableScrollY()},toggleAllSelection(){var t,l;null==(l=(t=e.store).toggleAllSelection)||l.call(t)},rowSelectedChanged(t,l){e.store.toggleRowSelection(l),e.store.updateAllSelected()},setHoverRow(e,t){e.hoverRow.value=t},setCurrentRow(t,l){e.store.updateCurrentRow(l)}},c=function(t,...l){const n=e.store.mutations;if(!n[t])throw new Error(`Action not found: ${t}`);n[t].apply(e,[e.store.states,...l])},r=function(){(0,n.dY)(()=>e.layout.updateScrollY.apply(e.layout))};return{ns:l,t:a,...t,mutations:o,commit:c,updateTableScrollY:r}}const tt={rowKey:"rowKey",defaultExpandAll:"defaultExpandAll",selectOnIndeterminate:"selectOnIndeterminate",indent:"indent",lazy:"lazy",data:"data",["treeProps.hasChildren"]:{key:"lazyColumnIdentifier",default:"hasChildren"},["treeProps.children"]:{key:"childrenColumnName",default:"children"},["treeProps.checkStrictly"]:{key:"checkStrictly",default:!1}};function lt(e,t){if(!e)throw new Error("Table is required.");const l=et();return l.toggleAllSelection=(0,c.A)(l._toggleAllSelection,10),Object.keys(tt).forEach(e=>{at(ot(t,e),e,l)}),nt(l,t),l}function nt(e,t){Object.keys(tt).forEach(l=>{(0,n.wB)(()=>ot(t,l),t=>{at(t,l,e)})})}function at(e,t,l){let n=e,o=tt[t];(0,a.Gv)(o)&&(n=n||o.default,o=o.key),l.states[o].value=n}function ot(e,t){if(t.includes(".")){const l=t.split(".");let n=e;return l.forEach(e=>{n=n[e]}),n}return e[t]}var ct=l(17);class rt{constructor(e){this.observers=[],this.table=null,this.store=null,this.columns=[],this.fit=!0,this.showHeader=!0,this.height=(0,s.KR)(null),this.scrollX=(0,s.KR)(!1),this.scrollY=(0,s.KR)(!1),this.bodyWidth=(0,s.KR)(null),this.fixedWidth=(0,s.KR)(null),this.rightFixedWidth=(0,s.KR)(null),this.gutterWidth=0;for(const t in e)(0,a.$3)(e,t)&&((0,s.i9)(this[t])?this[t].value=e[t]:this[t]=e[t]);if(!this.table)throw new Error("Table is required for Table Layout");if(!this.store)throw new Error("Store is required for Table Layout")}updateScrollY(){const e=this.height.value;if(u(e))return!1;const t=this.table.refs.scrollBarRef;if(this.table.vnode.el&&(null==t?void 0:t.wrapRef)){let e=!0;const l=this.scrollY.value;return e=t.wrapRef.scrollHeight>t.wrapRef.clientHeight,this.scrollY.value=e,l!==e}return!1}setHeight(e,t="height"){if(!ct.oc)return;const l=this.table.vnode.el;e=Ee(e),this.height.value=Number(e),l||!e&&0!==e?l&&(0,ge.Et)(e)?(l.style[t]=`${e}px`,this.updateElsHeight()):l&&(0,a.Kg)(e)&&(l.style[t]=e,this.updateElsHeight()):(0,n.dY)(()=>this.setHeight(e,t))}setMaxHeight(e){this.setHeight(e,"max-height")}getFlattenColumns(){const e=[],t=this.table.store.states.columns.value;return t.forEach(t=>{t.isColumnGroup?e.push.apply(e,t.columns):e.push(t)}),e}updateElsHeight(){this.updateScrollY(),this.notifyObservers("scrollable")}headerDisplayNone(e){if(!e)return!0;let t=e;while("DIV"!==t.tagName){if("none"===getComputedStyle(t).display)return!0;t=t.parentElement}return!1}updateColumnsWidth(){var e;if(!ct.oc)return;const t=this.fit,l=null==(e=this.table.vnode.el)?void 0:e.clientWidth;let n=0;const a=this.getFlattenColumns(),o=a.filter(e=>!(0,ge.Et)(e.width));if(a.forEach(e=>{(0,ge.Et)(e.width)&&e.realWidth&&(e.realWidth=null)}),o.length>0&&t){if(a.forEach(e=>{n+=Number(e.width||e.minWidth||80)}),n<=l){this.scrollX.value=!1;const e=l-n;if(1===o.length)o[0].realWidth=Number(o[0].minWidth||80)+e;else{const t=o.reduce((e,t)=>e+Number(t.minWidth||80),0),l=e/t;let n=0;o.forEach((e,t)=>{if(0===t)return;const a=Math.floor(Number(e.minWidth||80)*l);n+=a,e.realWidth=Number(e.minWidth||80)+a}),o[0].realWidth=Number(o[0].minWidth||80)+e-n}}else this.scrollX.value=!0,o.forEach(e=>{e.realWidth=Number(e.minWidth)});this.bodyWidth.value=Math.max(n,l),this.table.state.resizeState.value.width=this.bodyWidth.value}else a.forEach(e=>{e.width||e.minWidth?e.realWidth=Number(e.width||e.minWidth):e.realWidth=80,n+=e.realWidth}),this.scrollX.value=n>l,this.bodyWidth.value=n;const c=this.store.states.fixedColumns.value;if(c.length>0){let e=0;c.forEach(t=>{e+=Number(t.realWidth||t.width)}),this.fixedWidth.value=e}const r=this.store.states.rightFixedColumns.value;if(r.length>0){let e=0;r.forEach(t=>{e+=Number(t.realWidth||t.width)}),this.rightFixedWidth.value=e}this.notifyObservers("columns")}addObserver(e){this.observers.push(e)}removeObserver(e){const t=this.observers.indexOf(e);-1!==t&&this.observers.splice(t,1)}notifyObservers(e){const t=this.observers;t.forEach(t=>{var l,n;switch(e){case"columns":null==(l=t.state)||l.onColumnsChange(this);break;case"scrollable":null==(n=t.state)||n.onScrollableChange(this);break;default:throw new Error(`Table Layout don't have event ${e}.`)}})}}var st=l(850),it=l(813),ut=l(7477),dt=l(9077),ft=l(2251),pt=l(4225),mt=l(515);const vt=(0,n.pM)({name:"ElTableFilterPanel",components:{ElCheckbox:st.dI,ElCheckboxGroup:st.o5,ElScrollbar:r.kA,ElTooltip:ve.R7,ElIcon:it.tk,ArrowDown:ut.ArrowDown,ArrowUp:ut.ArrowUp},props:{placement:{type:String,default:"bottom-start"},store:{type:Object},column:{type:Object},upDataColumn:{type:Function},appendTo:ft.E.appendTo},setup(e){const t=(0,n.nI)(),{t:l}=(0,Qe.Ym)(),a=(0,Ye.DU)("table-filter"),o=null==t?void 0:t.parent;e.column&&!o.filterPanels.value[e.column.id]&&(o.filterPanels.value[e.column.id]=t);const c=(0,s.KR)(null),r=(0,s.KR)(null),i=(0,s.KR)(0),u=(0,n.EW)(()=>e.column&&e.column.filters),d=(0,n.EW)(()=>e.column&&e.column.filterClassName?`${a.b()} ${e.column.filterClassName}`:a.b()),f=(0,n.EW)({get:()=>{var t;return((null==(t=e.column)?void 0:t.filteredValue)||[])[0]},set:e=>{p.value&&((0,ge.Xj)(e)?p.value.splice(0,1):p.value.splice(0,1,e))}}),p=(0,n.EW)({get(){return e.column&&e.column.filteredValue||[]},set(t){var l;e.column&&(null==(l=e.upDataColumn)||l.call(e,"filteredValue",t))}}),m=(0,n.EW)(()=>!e.column||e.column.filterMultiple),v=e=>e.value===f.value,h=()=>{var e;null==(e=c.value)||e.onClose()},g=()=>{C(p.value),h()},b=()=>{p.value=[],C(p.value),h()},y=(e,t)=>{f.value=e,i.value=t,(0,ge.Xj)(e)?C([]):C(p.value),h()},C=t=>{var l,n;null==(l=e.store)||l.commit("filterChange",{column:e.column,values:t}),null==(n=e.store)||n.updateAllSelected()},w=()=>{var t,l;null==(t=r.value)||t.focus(),!m.value&&x(),e.column&&(null==(l=e.upDataColumn)||l.call(e,"filterOpened",!0))},L=()=>{var t;e.column&&(null==(t=e.upDataColumn)||t.call(e,"filterOpened",!1))},x=()=>{if((0,ge.Xj)(f))return void(i.value=0);const e=(u.value||[]).findIndex(e=>e.value===f.value);i.value=e>=0?e+1:0},M=e=>{var t,l;const n=(0,pt.CG)(e),o=(u.value?u.value.length:0)+1;let c=i.value,s=!0;switch(n){case mt.R.down:case mt.R.right:c=(c+1)%o;break;case mt.R.up:case mt.R.left:c=(c-1+o)%o;break;case mt.R.tab:h(),s=!1;break;case mt.R.enter:case mt.R.space:if(0===c)y(null,0);else{const e=(u.value||[])[c-1];e.value&&y(e.value,c)}break;default:s=!1;break}s&&e.preventDefault(),i.value=c,null==(l=null==(t=r.value)?void 0:t.querySelector(`.${a.e("list-item")}:nth-child(${c+1})`))||l.focus()};return{multiple:m,filterClassName:d,filteredValue:p,filterValue:f,filters:u,handleConfirm:g,handleReset:b,handleSelect:y,isPropAbsent:ge.Xj,isActive:v,t:l,ns:a,tooltipRef:c,rootRef:r,checkedIndex:i,handleShowTooltip:w,handleHideTooltip:L,handleKeydown:M}}});function ht(e,t,l,o,c,r){const s=(0,n.g2)("el-checkbox"),i=(0,n.g2)("el-checkbox-group"),u=(0,n.g2)("el-scrollbar"),d=(0,n.g2)("arrow-up"),f=(0,n.g2)("arrow-down"),p=(0,n.g2)("el-icon"),m=(0,n.g2)("el-tooltip");return(0,n.uX)(),(0,n.Wv)(m,{ref:"tooltipRef",offset:0,placement:e.placement,"show-arrow":!1,trigger:"click",role:"dialog",teleported:"",effect:"light",pure:"",loop:"","popper-class":e.filterClassName,persistent:"","append-to":e.appendTo,onShow:e.handleShowTooltip,onHide:e.handleHideTooltip},{content:(0,n.k6)(()=>[e.multiple?((0,n.uX)(),(0,n.CE)("div",{key:0,ref:"rootRef",tabindex:"-1",class:(0,a.C4)(e.ns.e("multiple"))},[(0,n.Lk)("div",{class:(0,a.C4)(e.ns.e("content"))},[(0,n.bF)(u,{"wrap-class":e.ns.e("wrap")},{default:(0,n.k6)(()=>[(0,n.bF)(i,{modelValue:e.filteredValue,"onUpdate:modelValue":t=>e.filteredValue=t,class:(0,a.C4)(e.ns.e("checkbox-group"))},{default:(0,n.k6)(()=>[((0,n.uX)(!0),(0,n.CE)(n.FK,null,(0,n.pI)(e.filters,e=>((0,n.uX)(),(0,n.Wv)(s,{key:e.value,value:e.value},{default:(0,n.k6)(()=>[(0,n.eW)((0,a.v_)(e.text),1)]),_:2},1032,["value"]))),128))]),_:1},8,["modelValue","onUpdate:modelValue","class"])]),_:1},8,["wrap-class"])],2),(0,n.Lk)("div",{class:(0,a.C4)(e.ns.e("bottom"))},[(0,n.Lk)("button",{class:(0,a.C4)(e.ns.is("disabled",0===e.filteredValue.length)),disabled:0===e.filteredValue.length,type:"button",onClick:e.handleConfirm},(0,a.v_)(e.t("el.table.confirmFilter")),11,["disabled","onClick"]),(0,n.Lk)("button",{type:"button",onClick:e.handleReset},(0,a.v_)(e.t("el.table.resetFilter")),9,["onClick"])],2)],2)):((0,n.uX)(),(0,n.CE)("ul",{key:1,ref:"rootRef",tabindex:"-1",role:"radiogroup",class:(0,a.C4)(e.ns.e("list")),onKeydown:e.handleKeydown},[(0,n.Lk)("li",{role:"radio",class:(0,a.C4)([e.ns.e("list-item"),e.ns.is("active",e.isPropAbsent(e.filterValue))]),tabindex:0===e.checkedIndex?0:-1,"aria-checked":e.isPropAbsent(e.filterValue),onClick:t=>e.handleSelect(null,0)},(0,a.v_)(e.t("el.table.clearFilter")),11,["tabindex","aria-checked","onClick"]),((0,n.uX)(!0),(0,n.CE)(n.FK,null,(0,n.pI)(e.filters,(t,l)=>((0,n.uX)(),(0,n.CE)("li",{key:t.value,role:"radio",class:(0,a.C4)([e.ns.e("list-item"),e.ns.is("active",e.isActive(t))]),tabindex:e.checkedIndex===l+1?0:-1,"aria-checked":e.isActive(t),onClick:n=>e.handleSelect(t.value,l+1)},(0,a.v_)(t.text),11,["tabindex","aria-checked","onClick"]))),128))],42,["onKeydown"]))]),default:(0,n.k6)(()=>{var t;return[(0,n.Lk)("button",{type:"button",class:(0,a.C4)(`${e.ns.namespace.value}-table__column-filter-trigger`),"aria-label":e.t("el.table.filterLabel",{column:(null==(t=e.column)?void 0:t.label)||""})},[(0,n.bF)(p,null,{default:(0,n.k6)(()=>[(0,n.RG)(e.$slots,"filter-icon",{},()=>{var t;return[(null==(t=e.column)?void 0:t.filterOpened)?((0,n.uX)(),(0,n.Wv)(d,{key:0})):((0,n.uX)(),(0,n.Wv)(f,{key:1}))]})]),_:3})],10,["aria-label"])]}),_:3},8,["placement","popper-class","append-to","onShow","onHide"])}var gt=(0,dt.A)(vt,[["render",ht],["__file","filter-panel.vue"]]);function bt(e){const t=(0,n.nI)();(0,n.KC)(()=>{l.value.addObserver(t)}),(0,n.sV)(()=>{a(l.value),o(l.value)}),(0,n.$u)(()=>{a(l.value),o(l.value)}),(0,n.hi)(()=>{l.value.removeObserver(t)});const l=(0,n.EW)(()=>{const t=e.layout;if(!t)throw new Error("Can not find table layout.");return t}),a=t=>{var l;const n=(null==(l=e.vnode.el)?void 0:l.querySelectorAll("colgroup > col"))||[];if(!n.length)return;const a=t.getFlattenColumns(),o={};a.forEach(e=>{o[e.id]=e});for(let e=0,c=n.length;e{var l,n;const a=(null==(l=e.vnode.el)?void 0:l.querySelectorAll("colgroup > col[name=gutter]"))||[];for(let e=0,c=a.length;e{e.stopPropagation()},c=(e,t)=>{!t.filters&&t.sortable?g(e,t,!1):t.filterable&&!t.sortable&&o(e),null==a||a.emit("header-click",t,e)},r=(e,t)=>{null==a||a.emit("header-contextmenu",t,e)},i=(0,s.KR)(null),d=(0,s.KR)(!1),f=(0,s.KR)(),p=(n,o)=>{var c,r;if(ct.oc&&!(o.children&&o.children.length>0)&&i.value&&e.border&&i.value.id===o.id){d.value=!0;const s=a;t("set-drag-visible",!0);const u=null==s?void 0:s.vnode.el,p=null==u?void 0:u.getBoundingClientRect().left,m=null==(r=null==(c=null==l?void 0:l.vnode)?void 0:c.el)?void 0:r.querySelector(`th.${o.id}`),v=m.getBoundingClientRect(),h=v.left-p+30;(0,Ct.iQ)(m,"noclick"),f.value={startMouseLeft:n.clientX,startLeft:v.right-p,startColumnLeft:v.left-p,tableLeft:p};const g=null==s?void 0:s.refs.resizeProxy;g.style.left=`${f.value.startLeft}px`,document.onselectstart=function(){return!1},document.ondragstart=function(){return!1};const b=e=>{const t=e.clientX-f.value.startMouseLeft,l=f.value.startLeft+t;g.style.left=`${Math.max(h,l)}px`},y=()=>{if(d.value){const{startColumnLeft:l,startLeft:a}=f.value,c=Number.parseInt(g.style.left,10),r=c-l;o.width=o.realWidth=r,null==s||s.emit("header-dragend",o.width,a-l,o,n),requestAnimationFrame(()=>{e.store.scheduleLayout(!1,!0)}),document.body.style.cursor="",d.value=!1,i.value=null,f.value=void 0,t("set-drag-visible",!1)}document.removeEventListener("mousemove",b),document.removeEventListener("mouseup",y),document.onselectstart=null,document.ondragstart=null,setTimeout(()=>{(0,Ct.vy)(m,"noclick")},0)};document.addEventListener("mousemove",b),document.addEventListener("mouseup",y)}},m=(t,l)=>{var n;if(!e.border||l.children&&l.children.length>0)return;const a=t.target,o=(0,ge.vq)(a)?a.closest("th"):null;if(!o)return;const c=(0,Ct.nB)(o,"is-sortable");if(c){const e=d.value?"col-resize":"";o.style.cursor=e;const t=o.querySelector(".caret-wrapper");t&&(t.style.cursor=e)}if(!l.resizable||d.value)return void(i.value=null);const r=o.getBoundingClientRect(),s=(null==(n=o.parentNode)?void 0:n.lastElementChild)===o,u=e.allowDragLastColumn||!s,f=r.width>12&&r.right-t.clientX<8&&u,p=f?"col-resize":"";document.body.style.cursor=p,i.value=f?l:null,c&&(o.style.cursor=p)},v=()=>{ct.oc&&!d.value&&(document.body.style.cursor="")},h=({order:e,sortOrders:t})=>{if(""===e)return t[0];const l=t.indexOf(e||null);return t[l>t.length-2?0:l+1]},g=(t,l,n)=>{var o;t.stopPropagation();const c=l.order===n?null:n||h(l),r=null==(o=t.target)?void 0:o.closest("th");if(r&&(0,Ct.nB)(r,"noclick"))return void(0,Ct.vy)(r,"noclick");if(!l.sortable)return;const s=t.currentTarget;if(["ascending","descending"].some(e=>(0,Ct.nB)(s,e)&&!l.sortOrders.includes(e)))return;const i=e.store.states;let d,f=i.sortProp.value;const p=i.sortingColumn.value;(p!==l||p===l&&u(p.order))&&(p&&(p.order=null),i.sortingColumn.value=l,f=l.property),d=l.order=c||null,i.sortProp.value=f,i.sortOrder.value=d,null==a||a.store.commit("changeSortCondition")};return{handleHeaderClick:c,handleHeaderContextMenu:r,handleMouseDown:p,handleMouseMove:m,handleMouseOut:v,handleSortClick:g,handleFilterClick:o}}function Lt(e){const t=(0,n.WQ)(yt),l=(0,Ye.DU)("table"),o=e=>{const l=null==t?void 0:t.props.headerRowStyle;return(0,a.Tn)(l)?l.call(null,{rowIndex:e}):l},c=e=>{const l=[],n=null==t?void 0:t.props.headerRowClassName;return(0,a.Kg)(n)?l.push(n):(0,a.Tn)(n)&&l.push(n.call(null,{rowIndex:e})),l.join(" ")},r=(l,n,o,c)=>{var r;let s=null!=(r=null==t?void 0:t.props.headerCellStyle)?r:{};(0,a.Tn)(s)&&(s=s.call(null,{rowIndex:l,columnIndex:n,row:o,column:c}));const i=Pe(n,c.fixed,e.store,o);return $e(i,"left"),$e(i,"right"),Object.assign({},s,i)},s=(n,o,c,r)=>{const s=Fe(l.b(),o,r.fixed,e.store,c),i=[r.id,r.order,r.headerAlign,r.className,r.labelClassName,...s];r.children||i.push("is-leaf"),r.sortable&&i.push("is-sortable");const u=null==t?void 0:t.props.headerCellClassName;return(0,a.Kg)(u)?i.push(u):(0,a.Tn)(u)&&i.push(u.call(null,{rowIndex:n,columnIndex:o,row:c,column:r})),i.push(l.e("cell")),i.filter(e=>Boolean(e)).join(" ")};return{getHeaderRowStyle:o,getHeaderRowClass:c,getHeaderCellStyle:r,getHeaderCellClass:s}}const xt=e=>{const t=[];return e.forEach(e=>{e.children?(t.push(e),t.push.apply(t,xt(e.children))):t.push(e)}),t},Mt=e=>{let t=1;const l=(e,n)=>{if(n&&(e.level=n.level+1,t{l(n,e),t+=n.colSpan}),e.colSpan=t}else e.colSpan=1};e.forEach(e=>{e.level=1,l(e,void 0)});const n=[];for(let o=0;o{e.children?(e.rowSpan=1,e.children.forEach(e=>e.isSubColumn=!0)):e.rowSpan=t-e.level+1,n[e.level-1].push(e)}),n};function zt(e){const t=(0,n.WQ)(yt),l=(0,n.EW)(()=>Mt(e.store.states.originColumns.value)),a=(0,n.EW)(()=>{const e=l.value.length>1;return e&&t&&(t.state.isGroup.value=!0),e}),o=e=>{e.stopPropagation(),null==t||t.store.commit("toggleAllSelection")};return{isGroup:a,toggleAllSelection:o,columnRows:l}}var Rt=(0,n.pM)({name:"ElTableHeader",components:{ElCheckbox:st.dI},props:{fixed:{type:String,default:""},store:{required:!0,type:Object},border:Boolean,defaultSort:{type:Object,default:()=>({prop:"",order:""})},appendFilterPanelTo:{type:String},allowDragLastColumn:{type:Boolean}},setup(e,{emit:t}){const l=(0,n.nI)(),a=(0,n.WQ)(yt),o=(0,Ye.DU)("table"),c=(0,s.KR)({}),{onColumnsChange:r,onScrollableChange:i}=bt(a),u="auto"===(null==a?void 0:a.props.tableLayout),d=(0,s.Kh)(new Map),f=(0,s.KR)();let p;const m=()=>{p=setTimeout(()=>{d.size>0&&(d.forEach((e,t)=>{const l=f.value.querySelector(`.${t.replace(/\s/g,".")}`);if(l){const t=l.getBoundingClientRect().width;e.width=t||e.width}}),d.clear())})};(0,n.wB)(d,m),(0,n.xo)(()=>{p&&(clearTimeout(p),p=void 0)}),(0,n.sV)(async()=>{await(0,n.dY)(),await(0,n.dY)();const{prop:t,order:l}=e.defaultSort;null==a||a.store.commit("sort",{prop:t,order:l,init:!0}),m()});const{handleHeaderClick:v,handleHeaderContextMenu:h,handleMouseDown:g,handleMouseMove:b,handleMouseOut:y,handleSortClick:C,handleFilterClick:w}=wt(e,t),{getHeaderRowStyle:L,getHeaderRowClass:x,getHeaderCellStyle:M,getHeaderCellClass:z}=Lt(e),{isGroup:R,toggleAllSelection:k,columnRows:S}=zt(e),{t:E}=(0,Qe.Ym)();return l.state={onColumnsChange:r,onScrollableChange:i},l.filterPanels=c,{ns:o,t:E,filterPanels:c,onColumnsChange:r,onScrollableChange:i,columnRows:S,getHeaderRowClass:x,getHeaderRowStyle:L,getHeaderCellClass:z,getHeaderCellStyle:M,handleHeaderClick:v,handleHeaderContextMenu:h,handleMouseDown:g,handleMouseMove:b,handleMouseOut:y,handleSortClick:C,handleFilterClick:w,isGroup:R,toggleAllSelection:k,saveIndexSelection:d,isTableLayoutAuto:u,theadRef:f,updateFixedColumnStyle:m}},render(){const{ns:e,t:t,isGroup:l,columnRows:a,getHeaderCellStyle:o,getHeaderCellClass:c,getHeaderRowClass:r,getHeaderRowStyle:s,handleHeaderClick:i,handleHeaderContextMenu:u,handleMouseDown:d,handleMouseMove:f,handleSortClick:p,handleMouseOut:m,store:v,$parent:h,saveIndexSelection:g,isTableLayoutAuto:b}=this;let y=1;return(0,n.h)("thead",{ref:"theadRef",class:e.is("group",l)},a.map((e,l)=>(0,n.h)("tr",{class:r(l),key:l,style:s(l)},e.map((a,r)=>{a.rowSpan>y&&(y=a.rowSpan);const s=c(l,r,e,a);return b&&a.fixed&&g.set(s,a),(0,n.h)("th",{class:s,colspan:a.colSpan,key:`${a.id}-thead`,rowspan:a.rowSpan,scope:a.colSpan>1?"colgroup":"col",style:o(l,r,e,a),onClick:e=>{var t;(null==(t=e.currentTarget)?void 0:t.classList.contains("noclick"))||i(e,a)},onContextmenu:e=>u(e,a),onMousedown:e=>d(e,a),onMousemove:e=>f(e,a),onMouseout:m},[(0,n.h)("div",{class:["cell",a.filteredValue&&a.filteredValue.length>0?"highlight":""]},[a.renderHeader?a.renderHeader({column:a,$index:r,store:v,_self:h}):a.label,a.sortable&&(0,n.h)("button",{type:"button",class:"caret-wrapper","aria-label":t("el.table.sortLabel",{column:a.label||""}),onClick:e=>p(e,a)},[(0,n.h)("i",{onClick:e=>p(e,a,"ascending"),class:"sort-caret ascending"}),(0,n.h)("i",{onClick:e=>p(e,a,"descending"),class:"sort-caret descending"})]),a.filterable&&(0,n.h)(gt,{store:v,placement:a.filterPlacement||"bottom-start",appendTo:null==h?void 0:h.appendFilterPanelTo,column:a,upDataColumn:(e,t)=>{a[e]=t}},{"filter-icon":()=>a.renderFilterIcon?a.renderFilterIcon({filterOpened:a.filterOpened}):null})])])}))))}});function kt(e,t,l=.03){return e-t>l}function St(e){const t=(0,n.WQ)(yt),l=(0,s.KR)(""),a=(0,s.KR)((0,n.h)("div")),o=(l,n,a)=>{var o,c,r;const s=t,i=ye(l);let u=null;const d=null==(o=null==s?void 0:s.vnode.el)?void 0:o.dataset.prefix;i&&(u=xe({columns:null!=(r=null==(c=e.store)?void 0:c.states.columns.value)?r:[]},i,d),u&&(null==s||s.emit(`cell-${a}`,n,u,i,l))),null==s||s.emit(`row-${a}`,n,u,l)},r=(e,t)=>{o(e,t,"dblclick")},i=(t,l)=>{var n;null==(n=e.store)||n.commit("setCurrentRow",l),o(t,l,"click")},u=(e,t)=>{o(e,t,"contextmenu")},d=(0,c.A)(t=>{var l;null==(l=e.store)||l.commit("setHoverRow",t)},30),f=(0,c.A)(()=>{var t;null==(t=e.store)||t.commit("setHoverRow",null)},30),p=e=>{const t=window.getComputedStyle(e,null),l=Number.parseInt(t.paddingLeft,10)||0,n=Number.parseInt(t.paddingRight,10)||0,a=Number.parseInt(t.paddingTop,10)||0,o=Number.parseInt(t.paddingBottom,10)||0;return{left:l,right:n,top:a,bottom:o}},m=(e,t,l)=>{var n;let a=null==(n=null==t?void 0:t.target)?void 0:n.parentNode;while(e>1){if(a=null==a?void 0:a.nextSibling,!a||"TR"!==a.nodeName)break;l(a,"hover-row hover-fixed-row"),e--}},v=(l,n,a)=>{var o,c,r,s,i,u,d,f,v;if(!t)return;const h=t,g=ye(l),b=null==(o=null==h?void 0:h.vnode.el)?void 0:o.dataset.prefix;let y=null;if(g){if(y=xe({columns:null!=(r=null==(c=e.store)?void 0:c.states.columns.value)?r:[]},g,b),!y)return;g.rowSpan>1&&m(g.rowSpan,l,Ct.iQ);const t=h.hoverState={cell:g,column:y,row:n};null==h||h.emit("cell-mouse-enter",t.row,t.column,t.cell,l)}if(!a)return void((null==(s=Oe)?void 0:s.trigger)===g&&(null==(i=Oe)||i()));const C=l.target.querySelector(".cell");if(!((0,Ct.nB)(C,`${b}-tooltip`)&&C.childNodes.length&&(null==(u=C.textContent)?void 0:u.trim())))return;const w=document.createRange();w.setStart(C,0),w.setEnd(C,C.childNodes.length);const{width:L,height:x}=w.getBoundingClientRect(),{width:M,height:z}=C.getBoundingClientRect(),{top:R,left:k,right:S,bottom:E}=p(C),A=k+S,N=R+E;kt(L+A,M)||kt(x+N,z)||kt(C.scrollWidth,M)?We(a,null!=(d=(null==g?void 0:g.innerText)||(null==g?void 0:g.textContent))?d:"",n,y,g,h):(null==(f=Oe)?void 0:f.trigger)===g&&(null==(v=Oe)||v())},h=e=>{const l=ye(e);if(!l)return;l.rowSpan>1&&m(l.rowSpan,e,Ct.vy);const n=null==t?void 0:t.hoverState;null==t||t.emit("cell-mouse-leave",null==n?void 0:n.row,null==n?void 0:n.column,null==n?void 0:n.cell,e)};return{handleDoubleClick:r,handleClick:i,handleContextMenu:u,handleMouseEnter:d,handleMouseLeave:f,handleCellMouseEnter:v,handleCellMouseLeave:h,tooltipContent:l,tooltipTrigger:a}}function Et(e){const t=(0,n.WQ)(yt),l=(0,Ye.DU)("table"),o=(e,l)=>{const n=null==t?void 0:t.props.rowStyle;return(0,a.Tn)(n)?n.call(null,{row:e,rowIndex:l}):n||null},c=(n,o,c)=>{var r;const s=[l.e("row")];(null==t?void 0:t.props.highlightCurrentRow)&&n===(null==(r=e.store)?void 0:r.states.currentRow.value)&&s.push("current-row"),e.stripe&&c%2===1&&s.push(l.em("row","striped"));const i=null==t?void 0:t.props.rowClassName;return(0,a.Kg)(i)?s.push(i):(0,a.Tn)(i)&&s.push(i.call(null,{row:n,rowIndex:o})),s},r=(l,n,o,c)=>{const r=null==t?void 0:t.props.cellStyle;let s=null!=r?r:{};(0,a.Tn)(r)&&(s=r.call(null,{rowIndex:l,columnIndex:n,row:o,column:c}));const i=Pe(n,null==e?void 0:e.fixed,e.store);return $e(i,"left"),$e(i,"right"),Object.assign({},s,i)},s=(n,o,c,r,s)=>{const i=Fe(l.b(),o,null==e?void 0:e.fixed,e.store,void 0,s),u=[r.id,r.align,r.className,...i],d=null==t?void 0:t.props.cellClassName;return(0,a.Kg)(d)?u.push(d):(0,a.Tn)(d)&&u.push(d.call(null,{rowIndex:n,columnIndex:o,row:c,column:r})),u.push(l.e("cell")),u.filter(e=>Boolean(e)).join(" ")},i=(e,l,n,o)=>{let c=1,r=1;const s=null==t?void 0:t.props.spanMethod;if((0,a.Tn)(s)){const t=s({row:e,column:l,rowIndex:n,columnIndex:o});(0,a.cy)(t)?(c=t[0],r=t[1]):(0,a.Gv)(t)&&(c=t.rowspan,r=t.colspan)}return{rowspan:c,colspan:r}},u=(e,t,l)=>{if(t<1)return e[l].realWidth;const n=e.map(({realWidth:e,width:t})=>e||t).slice(l,l+t);return Number(n.reduce((e,t)=>Number(e)+Number(t),-1))};return{getRowStyle:o,getRowClass:c,getCellStyle:r,getCellClass:s,getSpan:i,getColspanRealWidth:u}}const At=(0,n.pM)({name:"TableTdWrapper"}),Nt=(0,n.pM)({...At,props:{colspan:{type:Number,default:1},rowspan:{type:Number,default:1}},setup(e){return(t,l)=>((0,n.uX)(),(0,n.CE)("td",{colspan:e.colspan,rowspan:e.rowspan},[(0,n.RG)(t.$slots,"default")],8,["colspan","rowspan"]))}});var _t=(0,dt.A)(Nt,[["__file","td-wrapper.vue"]]);function Tt(e){const t=(0,n.WQ)(yt),l=(0,Ye.DU)("table"),{handleDoubleClick:a,handleClick:o,handleContextMenu:c,handleMouseEnter:r,handleMouseLeave:s,handleCellMouseEnter:i,handleCellMouseLeave:u,tooltipContent:d,tooltipTrigger:f}=St(e),{getRowStyle:p,getRowClass:m,getCellStyle:v,getCellClass:h,getSpan:g,getColspanRealWidth:b}=Et(e);let y=-1;const C=(0,n.EW)(()=>{var t;return null==(t=e.store)?void 0:t.states.columns.value.findIndex(({type:e})=>"default"===e)}),w=(e,l)=>{var n;const a=null==(n=null==t?void 0:t.props)?void 0:n.rowKey;return a?Me(e,a):l},L=(d,f,L,M=!1)=>{const{tooltipEffect:z,tooltipOptions:R,store:k}=e,{indent:S,columns:E}=k.states,A=[];let N=!0;L&&(A.push(l.em("row",`level-${L.level}`)),N=!!L.display),0===f&&(y=-1),e.stripe&&N&&y++,A.push(...m(d,f,y));const _=N?null:{display:"none"};return(0,n.h)("tr",{style:[_,p(d,f)],class:A,key:w(d,f),onDblclick:e=>a(e,d),onClick:e=>o(e,d),onContextmenu:e=>c(e,d),onMouseenter:()=>r(f),onMouseleave:s},E.value.map((l,a)=>{const{rowspan:o,colspan:c}=g(d,l,f,a);if(!o||!c)return null;const r=Object.assign({},l);r.realWidth=b(E.value,c,a);const s={store:k,_self:e.context||t,column:r,row:d,$index:f,cellIndex:a,expanded:M};a===C.value&&L&&(s.treeNode={indent:L.level&&L.level*S.value,level:L.level},(0,ge.Lm)(L.expanded)&&(s.treeNode.expanded=L.expanded,"loading"in L&&(s.treeNode.loading=L.loading),"noLazyChildren"in L&&(s.treeNode.noLazyChildren=L.noLazyChildren)));const p=`${w(d,f)},${a}`,m=r.columnKey||r.rawColumnKey||"",y=l.showOverflowTooltip&&me({effect:z},R,l.showOverflowTooltip);return(0,n.h)(_t,{style:v(f,a,d,l),class:h(f,a,d,l,c-1),key:`${m}${p}`,rowspan:o,colspan:c,onMouseenter:e=>i(e,d,y),onMouseleave:u},{default:()=>x(a,l,s)})}))},x=(e,t,l)=>t.renderCell(l),M=(a,o)=>{const c=e.store,{isRowExpanded:r,assertRowKey:s}=c,{treeData:i,lazyTreeNodeMap:u,childrenColumnName:d,rowKey:f}=c.states,p=c.states.columns.value,m=p.some(({type:e})=>"expand"===e);if(m){const e=r(a),s=L(a,o,void 0,e),i=null==t?void 0:t.renderExpanded;if(!i)return console.error("[Element Error]renderExpanded is required."),s;const u=[[s]];return(t.props.preserveExpandedContent||e)&&u[0].push((0,n.h)("tr",{key:`expanded-row__${s.key}`,style:{display:e?"":"none"}},[(0,n.h)("td",{colspan:p.length,class:`${l.e("cell")} ${l.e("expanded-cell")}`},[i({row:a,$index:o,store:c,expanded:e})])])),u}if(Object.keys(i.value).length){s();const e=Me(a,f.value);let t=i.value[e],l=null;t&&(l={expanded:t.expanded,level:t.level,display:!0,noLazyChildren:void 0,loading:void 0},(0,ge.Lm)(t.lazy)&&(l&&(0,ge.Lm)(t.loaded)&&t.loaded&&(l.noLazyChildren=!(t.children&&t.children.length)),l.loading=t.loading));const n=[L(a,o,null!=l?l:void 0)];if(t){let l=0;const c=(e,a)=>{e&&e.length&&a&&e.forEach(e=>{const r={display:a.display&&a.expanded,level:a.level+1,expanded:!1,noLazyChildren:!1,loading:!1},s=Me(e,f.value);if((0,ge.Xj)(s))throw new Error("For nested data item, row-key is required.");if(t={...i.value[s]},t&&(r.expanded=t.expanded,t.level=t.level||r.level,t.display=!(!t.expanded||!r.display),(0,ge.Lm)(t.lazy)&&((0,ge.Lm)(t.loaded)&&t.loaded&&(r.noLazyChildren=!(t.children&&t.children.length)),r.loading=t.loading)),l++,n.push(L(e,o+l,r)),t){const l=u.value[s]||e[d.value];c(l,t)}})};t.display=!0;const r=u.value[e]||a[d.value];c(r,t)}return n}return L(a,o,void 0)};return{wrappedRowRender:M,tooltipContent:d,tooltipTrigger:f}}const Ot={store:{required:!0,type:Object},stripe:Boolean,tooltipEffect:String,tooltipOptions:{type:Object},context:{default:()=>({}),type:Object},rowClassName:[String,Function],rowStyle:[Object,Function],fixed:{type:String,default:""},highlight:Boolean};var Wt=l(5431),Bt=(0,n.pM)({name:"ElTableBody",props:Ot,setup(e){var t;const l=(0,n.nI)(),a=(0,n.WQ)(yt),o=(0,Ye.DU)("table"),{wrappedRowRender:c,tooltipContent:r,tooltipTrigger:s}=Tt(e),{onColumnsChange:i,onScrollableChange:u}=bt(a),d=[];return(0,n.wB)(null==(t=e.store)?void 0:t.states.hoverRow,(t,n)=>{var a,c;const r=null==l?void 0:l.vnode.el,s=Array.from((null==r?void 0:r.children)||[]).filter(e=>null==e?void 0:e.classList.contains(`${o.e("row")}`));let i=t;const u=null==(a=s[i])?void 0:a.childNodes;if(null==u?void 0:u.length){let e=0;const l=Array.from(u).reduce((t,l,n)=>{var a,o;return(null==(a=u[n])?void 0:a.colSpan)>1&&(e=null==(o=u[n])?void 0:o.colSpan),"TD"!==l.nodeName&&0===e&&t.push(n),e>0&&e--,t},[]);l.forEach(e=>{var l;i=t;while(i>0){const t=null==(l=s[i-1])?void 0:l.childNodes;if(t[e]&&"TD"===t[e].nodeName&&t[e].rowSpan>1){(0,Ct.iQ)(t[e],"hover-cell"),d.push(t[e]);break}i--}})}else d.forEach(e=>(0,Ct.vy)(e,"hover-cell")),d.length=0;(null==(c=e.store)?void 0:c.states.isComplex.value)&&ct.oc&&(0,Wt.m)(()=>{const e=s[n],l=s[t];e&&!e.classList.contains("hover-fixed-row")&&(0,Ct.vy)(e,"hover-row"),l&&(0,Ct.iQ)(l,"hover-row")})}),(0,n.hi)(()=>{var e;null==(e=Oe)||e()}),{ns:o,onColumnsChange:i,onScrollableChange:u,wrappedRowRender:c,tooltipContent:r,tooltipTrigger:s}},render(){const{wrappedRowRender:e,store:t}=this,l=(null==t?void 0:t.states.data.value)||[];return(0,n.h)("tbody",{tabIndex:-1},[l.reduce((t,l)=>t.concat(e(l,t.length)),[])])}});function It(){const e=(0,n.WQ)(yt),t=null==e?void 0:e.store,l=(0,n.EW)(()=>{var e;return null!=(e=null==t?void 0:t.states.fixedLeafColumnsLength.value)?e:0}),a=(0,n.EW)(()=>{var e;return null!=(e=null==t?void 0:t.states.rightFixedColumns.value.length)?e:0}),o=(0,n.EW)(()=>{var e;return null!=(e=null==t?void 0:t.states.columns.value.length)?e:0}),c=(0,n.EW)(()=>{var e;return null!=(e=null==t?void 0:t.states.fixedColumns.value.length)?e:0}),r=(0,n.EW)(()=>{var e;return null!=(e=null==t?void 0:t.states.rightFixedColumns.value.length)?e:0});return{leftFixedLeafCount:l,rightFixedLeafCount:a,columnsCount:o,leftFixedCount:c,rightFixedCount:r,columns:(0,n.EW)(()=>{var e;return null!=(e=null==t?void 0:t.states.columns.value)?e:[]})}}function Dt(e){const{columns:t}=It(),l=(0,Ye.DU)("table"),n=(t,n)=>{const a=t[n],o=[l.e("cell"),a.id,a.align,a.labelClassName,...Fe(l.b(),n,a.fixed,e.store)];return a.className&&o.push(a.className),a.children||o.push(l.is("leaf")),o},a=(t,l)=>{const n=Pe(l,t.fixed,e.store);return $e(n,"left"),$e(n,"right"),n};return{getCellClasses:n,getCellStyles:a,columns:t}}var Ft=(0,n.pM)({name:"ElTableFooter",props:{fixed:{type:String,default:""},store:{required:!0,type:Object},summaryMethod:Function,sumText:String,border:Boolean,defaultSort:{type:Object,default:()=>({prop:"",order:""})}},setup(e){const t=(0,n.WQ)(yt),l=(0,Ye.DU)("table"),{getCellClasses:a,getCellStyles:o,columns:c}=Dt(e),{onScrollableChange:r,onColumnsChange:s}=bt(t);return{ns:l,onScrollableChange:r,onColumnsChange:s,getCellClasses:a,getCellStyles:o,columns:c}},render(){const{columns:e,getCellStyles:t,getCellClasses:l,summaryMethod:a,sumText:o}=this,c=this.store.states.data.value;let r=[];return a?r=a({columns:e,data:c}):e.forEach((e,t)=>{if(0===t)return void(r[t]=o);const l=c.map(t=>Number(t[e.property])),n=[];let a=!0;l.forEach(e=>{if(!Number.isNaN(+e)){a=!1;const t=`${e}`.split(".")[1];n.push(t?t.length:0)}});const s=Math.max.apply(null,n);r[t]=a?"":l.reduce((e,t)=>{const l=Number(t);return Number.isNaN(+l)?e:Number.parseFloat((e+t).toFixed(Math.min(s,20)))},0)}),(0,n.h)((0,n.h)("tfoot",[(0,n.h)("tr",{},[...e.map((a,o)=>(0,n.h)("td",{key:o,colspan:a.colSpan,rowspan:a.rowSpan,class:l(e,o),style:t(a,o)},[(0,n.h)("div",{class:["cell",a.labelClassName]},[r[o]])]))])]))}});function Vt(e){const t=t=>{e.commit("setCurrentRow",t)},l=()=>e.getSelectionRows(),n=(t,l,n=!0)=>{e.toggleRowSelection(t,l,!1,n),e.updateAllSelected()},a=()=>{e.clearSelection()},o=t=>{e.clearFilter(t)},c=()=>{e.commit("toggleAllSelection")},r=(t,l)=>{e.toggleRowExpansionAdapter(t,l)},s=()=>{e.clearSort()},i=(t,l)=>{e.commit("sort",{prop:t,order:l})},u=(t,l)=>{e.updateKeyChildren(t,l)};return{setCurrentRow:t,getSelectionRows:l,toggleRowSelection:n,clearSelection:a,clearFilter:o,toggleAllSelection:c,toggleRowExpansion:r,clearSort:s,sort:i,updateKeyChildren:u}}var Pt=l(7687),$t=l(2436);function Ht(e,t,l,a){const o=(0,s.KR)(!1),c=(0,s.KR)(null),r=(0,s.KR)(!1),i=e=>{r.value=e},u=(0,s.KR)({width:null,height:null,headerHeight:null}),d=(0,s.KR)(!1),f={display:"inline-block",verticalAlign:"middle"},p=(0,s.KR)(),m=(0,s.KR)(0),v=(0,s.KR)(0),h=(0,s.KR)(0),g=(0,s.KR)(0),b=(0,s.KR)(0);(0,n.wB)(()=>e.height,e=>{t.setHeight(null!=e?e:null)},{immediate:!0}),(0,n.wB)(()=>e.maxHeight,e=>{t.setMaxHeight(null!=e?e:null)},{immediate:!0}),(0,n.wB)(()=>[e.currentRowKey,l.states.rowKey],([e,t])=>{(0,s.R1)(t)&&(0,s.R1)(e)&&l.setCurrentRowKey(`${e}`)},{immediate:!0}),(0,n.wB)(()=>e.data,e=>{a.store.commit("setData",e)},{immediate:!0,deep:!0}),(0,n.nT)(()=>{e.expandRowKeys&&l.setExpandRowKeysAdapter(e.expandRowKeys)});const y=()=>{a.store.commit("setHoverRow",null),a.hoverState&&(a.hoverState=null)},C=(e,t)=>{const{pixelX:l,pixelY:n}=t;Math.abs(l)>=Math.abs(n)&&(a.refs.bodyWrapper.scrollLeft+=t.pixelX/5)},w=(0,n.EW)(()=>e.height||e.maxHeight||l.states.fixedColumns.value.length>0||l.states.rightFixedColumns.value.length>0),L=(0,n.EW)(()=>({width:t.bodyWidth.value?`${t.bodyWidth.value}px`:""})),x=()=>{w.value&&t.updateElsHeight(),t.updateColumnsWidth(),"undefined"!==typeof window&&requestAnimationFrame(k)};(0,n.sV)(async()=>{await(0,n.dY)(),l.updateColumns(),S(),requestAnimationFrame(x);const t=a.vnode.el,o=a.refs.headerWrapper;e.flexible&&t&&t.parentElement&&(t.parentElement.style.minWidth="0"),u.value={width:p.value=t.offsetWidth,height:t.offsetHeight,headerHeight:e.showHeader&&o?o.offsetHeight:null},l.states.columns.value.forEach(e=>{e.filteredValue&&e.filteredValue.length&&a.store.commit("filterChange",{column:e,values:e.filteredValue,silent:!0})}),a.$ready=!0});const M=(e,l)=>{if(!e)return;const n=Array.from(e.classList).filter(e=>!e.startsWith("is-scrolling-"));n.push(t.scrollX.value?l:"is-scrolling-none"),e.className=n.join(" ")},z=e=>{const{tableWrapper:t}=a.refs;M(t,e)},R=e=>{const{tableWrapper:t}=a.refs;return!(!t||!t.classList.contains(e))},k=function(){if(!a.refs.scrollBarRef)return;if(!t.scrollX.value){const e="is-scrolling-none";return void(R(e)||z(e))}const e=a.refs.scrollBarRef.wrapRef;if(!e)return;const{scrollLeft:l,offsetWidth:n,scrollWidth:o}=e,{headerWrapper:c,footerWrapper:r}=a.refs;c&&(c.scrollLeft=l),r&&(r.scrollLeft=l);const s=o-n-1;z(l>=s?"is-scrolling-right":0===l?"is-scrolling-left":"is-scrolling-middle")},S=()=>{a.refs.scrollBarRef&&(a.refs.scrollBarRef.wrapRef&&(0,Pt.MLh)(a.refs.scrollBarRef.wrapRef,"scroll",k,{passive:!0}),e.fit?(0,Pt.wYm)(a.vnode.el,E):(0,Pt.MLh)(window,"resize",E),(0,Pt.wYm)(a.refs.tableInnerWrapper,()=>{var e,t;E(),null==(t=null==(e=a.refs)?void 0:e.scrollBarRef)||t.update()}))},E=()=>{var t,l,n,o;const c=a.vnode.el;if(!a.$ready||!c)return;let r=!1;const{width:s,height:i,headerHeight:d}=u.value,f=p.value=c.offsetWidth;s!==f&&(r=!0);const y=c.offsetHeight;(e.height||w.value)&&i!==y&&(r=!0);const C="fixed"===e.tableLayout?a.refs.headerWrapper:null==(t=a.refs.tableHeaderRef)?void 0:t.$el;e.showHeader&&(null==C?void 0:C.offsetHeight)!==d&&(r=!0),m.value=(null==(l=a.refs.tableWrapper)?void 0:l.scrollHeight)||0,h.value=(null==C?void 0:C.scrollHeight)||0,g.value=(null==(n=a.refs.footerWrapper)?void 0:n.offsetHeight)||0,b.value=(null==(o=a.refs.appendWrapper)?void 0:o.offsetHeight)||0,v.value=m.value-h.value-g.value-b.value,r&&(u.value={width:f,height:y,headerHeight:e.showHeader&&(null==C?void 0:C.offsetHeight)||0},x())},A=(0,$t.NV)(),N=(0,n.EW)(()=>{const{bodyWidth:e,scrollY:l,gutterWidth:n}=t;return e.value?e.value-(l.value?n:0)+"px":""}),_=(0,n.EW)(()=>e.maxHeight?"fixed":e.tableLayout),T=(0,n.EW)(()=>{if(e.data&&e.data.length)return;let t="100%";e.height&&v.value&&(t=`${v.value}px`);const l=p.value;return{width:l?`${l}px`:"",height:t}}),O=(0,n.EW)(()=>e.height?{height:"100%"}:e.maxHeight?Number.isNaN(Number(e.maxHeight))?{maxHeight:`calc(${e.maxHeight} - ${h.value+g.value}px)`}:{maxHeight:+e.maxHeight-h.value-g.value+"px"}:{});return{isHidden:o,renderExpanded:c,setDragVisible:i,isGroup:d,handleMouseLeave:y,handleHeaderFooterMousewheel:C,tableSize:A,emptyBlockStyle:T,resizeProxyVisible:r,bodyWidth:N,resizeState:u,doLayout:x,tableBodyStyles:L,tableLayout:_,scrollbarViewStyle:f,scrollbarStyle:O}}function jt(e){const t=(0,s.KR)(),l=()=>{const l=e.vnode.el,n=l.querySelector(".hidden-columns"),a={childList:!0,subtree:!0},o=e.store.states.updateOrderFns;t.value=new MutationObserver(()=>{o.forEach(e=>e())}),t.value.observe(n,a)};(0,n.sV)(()=>{l()}),(0,n.hi)(()=>{var e;null==(e=t.value)||e.disconnect()})}var Kt=l(3845),Xt={data:{type:Array,default:()=>[]},size:Kt.mU,width:[String,Number],height:[String,Number],maxHeight:[String,Number],fit:{type:Boolean,default:!0},stripe:Boolean,border:Boolean,rowKey:[String,Function],showHeader:{type:Boolean,default:!0},showSummary:Boolean,sumText:String,summaryMethod:Function,rowClassName:[String,Function],rowStyle:[Object,Function],cellClassName:[String,Function],cellStyle:[Object,Function],headerRowClassName:[String,Function],headerRowStyle:[Object,Function],headerCellClassName:[String,Function],headerCellStyle:[Object,Function],highlightCurrentRow:Boolean,currentRowKey:[String,Number],emptyText:String,expandRowKeys:Array,defaultExpandAll:Boolean,defaultSort:Object,tooltipEffect:String,tooltipOptions:Object,spanMethod:Function,selectOnIndeterminate:{type:Boolean,default:!0},indent:{type:Number,default:16},treeProps:{type:Object,default:()=>({hasChildren:"hasChildren",children:"children",checkStrictly:!1})},lazy:Boolean,load:Function,style:{type:[String,Object,Array],default:()=>({})},className:{type:String,default:""},tableLayout:{type:String,default:"fixed"},scrollbarAlwaysOn:Boolean,flexible:Boolean,showOverflowTooltip:[Boolean,Object],tooltipFormatter:Function,appendFilterPanelTo:String,scrollbarTabindex:{type:[Number,String],default:void 0},allowDragLastColumn:{type:Boolean,default:!0},preserveExpandedContent:Boolean,nativeScrollbar:Boolean};l(1148);function Ut(e){const t="auto"===e.tableLayout;let l=e.columns||[];t&&l.every(({width:e})=>(0,ge.b0)(e))&&(l=[]);const a=l=>{const n={key:`${e.tableLayout}_${l.id}`,style:{},name:void 0};return t?n.style={width:`${l.width}px`}:n.name=l.id,n};return(0,n.h)("colgroup",{},l.map(e=>(0,n.h)("col",a(e))))}Ut.props=["columns","tableLayout"];const qt=()=>{const e=(0,s.KR)(),t=(t,l)=>{const n=e.value;n&&n.scrollTo(t,l)},l=(t,l)=>{const n=e.value;n&&(0,ge.Et)(l)&&["Top","Left"].includes(t)&&n[`setScroll${t}`](l)},n=e=>l("Top",e),a=e=>l("Left",e);return{scrollBarRef:e,scrollTo:t,setScrollTop:n,setScrollLeft:a}};var Gt,Yt,Qt,Zt,Jt,el,tl,ll,nl,al,ol,cl,rl,sl,il,ul=!1;function dl(){if(!ul){ul=!0;var e=navigator.userAgent,t=/(?:MSIE.(\d+\.\d+))|(?:(?:Firefox|GranParadiso|Iceweasel).(\d+\.\d+))|(?:Opera(?:.+Version.|.)(\d+\.\d+))|(?:AppleWebKit.(\d+(?:\.\d+)?))|(?:Trident\/\d+\.\d+.*rv:(\d+\.\d+))/.exec(e),l=/(Mac OS X)|(Windows)|(Linux)/.exec(e);if(cl=/\b(iPhone|iP[ao]d)/.exec(e),rl=/\b(iP[ao]d)/.exec(e),al=/Android/i.exec(e),sl=/FBAN\/\w+;/i.exec(e),il=/Mobile/i.exec(e),ol=!!/Win64/.exec(e),t){Gt=t[1]?parseFloat(t[1]):t[5]?parseFloat(t[5]):NaN,Gt&&document&&document.documentMode&&(Gt=document.documentMode);var n=/(?:Trident\/(\d+.\d+))/.exec(e);el=n?parseFloat(n[1])+4:Gt,Yt=t[2]?parseFloat(t[2]):NaN,Qt=t[3]?parseFloat(t[3]):NaN,Zt=t[4]?parseFloat(t[4]):NaN,Zt?(t=/(?:Chrome\/(\d+\.\d+))/.exec(e),Jt=t&&t[1]?parseFloat(t[1]):NaN):Jt=NaN}else Gt=Yt=Qt=Jt=Zt=NaN;if(l){if(l[1]){var a=/(?:Mac OS X (\d+(?:[._]\d+)?))/.exec(e);tl=!a||parseFloat(a[1].replace("_","."))}else tl=!1;ll=!!l[2],nl=!!l[3]}else tl=ll=nl=!1}}var fl,pl={ie:function(){return dl()||Gt},ieCompatibilityMode:function(){return dl()||el>Gt},ie64:function(){return pl.ie()&&ol},firefox:function(){return dl()||Yt},opera:function(){return dl()||Qt},webkit:function(){return dl()||Zt},safari:function(){return pl.webkit()},chrome:function(){return dl()||Jt},windows:function(){return dl()||ll},osx:function(){return dl()||tl},linux:function(){return dl()||nl},iphone:function(){return dl()||cl},mobile:function(){return dl()||cl||rl||al||il},nativeApp:function(){return dl()||sl},android:function(){return dl()||al},ipad:function(){return dl()||rl}},ml=pl,vl=!!(typeof window<"u"&&window.document&&window.document.createElement),hl={canUseDOM:vl,canUseWorkers:typeof Worker<"u",canUseEventListeners:vl&&!(!window.addEventListener&&!window.attachEvent),canUseViewport:vl&&!!window.screen,isInWorker:!vl},gl=hl;function bl(e,t){if(!gl.canUseDOM||t&&!("addEventListener"in document))return!1;var l="on"+e,n=l in document;if(!n){var a=document.createElement("div");a.setAttribute(l,"return;"),n="function"==typeof a[l]}return!n&&fl&&"wheel"===e&&(n=document.implementation.hasFeature("Events.wheel","3.0")),n}gl.canUseDOM&&(fl=document.implementation&&document.implementation.hasFeature&&!0!==document.implementation.hasFeature("",""));var yl=bl,Cl=10,wl=40,Ll=800;function xl(e){var t=0,l=0,n=0,a=0;return"detail"in e&&(l=e.detail),"wheelDelta"in e&&(l=-e.wheelDelta/120),"wheelDeltaY"in e&&(l=-e.wheelDeltaY/120),"wheelDeltaX"in e&&(t=-e.wheelDeltaX/120),"axis"in e&&e.axis===e.HORIZONTAL_AXIS&&(t=l,l=0),n=t*Cl,a=l*Cl,"deltaY"in e&&(a=e.deltaY),"deltaX"in e&&(n=e.deltaX),(n||a)&&e.deltaMode&&(1==e.deltaMode?(n*=wl,a*=wl):(n*=Ll,a*=Ll)),n&&!t&&(t=n<1?-1:1),a&&!l&&(l=a<1?-1:1),{spinX:t,spinY:l,pixelX:n,pixelY:a}}xl.getEventType=function(){return ml.firefox()?"DOMMouseScroll":yl("wheel")?"wheel":"mousewheel"};var Ml=xl; /** * Checks if an event is supported in the current execution environment. * @@ -65,5 +65,5 @@ let Me=()=>location.protocol+"//"+location.host;function ze(e,t){const{pathname: * License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License) * Copyright 2024 Fonticons, Inc. */ -function n(e,t,l){return(t=r(t))in e?Object.defineProperty(e,t,{value:l,enumerable:!0,configurable:!0,writable:!0}):e[t]=l,e}function a(e,t){var l=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter(function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable})),l.push.apply(l,n)}return l}function o(e){for(var t=1;t{};let i={},u={},d=null,f={mark:s,measure:s};try{"undefined"!==typeof window&&(i=window),"undefined"!==typeof document&&(u=document),"undefined"!==typeof MutationObserver&&(d=MutationObserver),"undefined"!==typeof performance&&(f=performance)}catch(Tn){}const{userAgent:p=""}=i.navigator||{},m=i,v=u,h=d,g=f,b=(m.document,!!v.documentElement&&!!v.head&&"function"===typeof v.addEventListener&&"function"===typeof v.createElement),y=~p.indexOf("MSIE")||~p.indexOf("Trident/");var C=/fa(s|r|l|t|d|dr|dl|dt|b|k|kd|ss|sr|sl|st|sds|sdr|sdl|sdt)?[\-\ ]/,w=/Font ?Awesome ?([56 ]*)(Solid|Regular|Light|Thin|Duotone|Brands|Free|Pro|Sharp Duotone|Sharp|Kit)?.*/i,L={classic:{fa:"solid",fas:"solid","fa-solid":"solid",far:"regular","fa-regular":"regular",fal:"light","fa-light":"light",fat:"thin","fa-thin":"thin",fab:"brands","fa-brands":"brands"},duotone:{fa:"solid",fad:"solid","fa-solid":"solid","fa-duotone":"solid",fadr:"regular","fa-regular":"regular",fadl:"light","fa-light":"light",fadt:"thin","fa-thin":"thin"},sharp:{fa:"solid",fass:"solid","fa-solid":"solid",fasr:"regular","fa-regular":"regular",fasl:"light","fa-light":"light",fast:"thin","fa-thin":"thin"},"sharp-duotone":{fa:"solid",fasds:"solid","fa-solid":"solid",fasdr:"regular","fa-regular":"regular",fasdl:"light","fa-light":"light",fasdt:"thin","fa-thin":"thin"}},x={GROUP:"duotone-group",SWAP_OPACITY:"swap-opacity",PRIMARY:"primary",SECONDARY:"secondary"},M=["fa-classic","fa-duotone","fa-sharp","fa-sharp-duotone"],z="classic",R="duotone",k="sharp",S="sharp-duotone",E=[z,R,k,S],A={classic:{900:"fas",400:"far",normal:"far",300:"fal",100:"fat"},duotone:{900:"fad",400:"fadr",300:"fadl",100:"fadt"},sharp:{900:"fass",400:"fasr",300:"fasl",100:"fast"},"sharp-duotone":{900:"fasds",400:"fasdr",300:"fasdl",100:"fasdt"}},N={"Font Awesome 6 Free":{900:"fas",400:"far"},"Font Awesome 6 Pro":{900:"fas",400:"far",normal:"far",300:"fal",100:"fat"},"Font Awesome 6 Brands":{400:"fab",normal:"fab"},"Font Awesome 6 Duotone":{900:"fad",400:"fadr",normal:"fadr",300:"fadl",100:"fadt"},"Font Awesome 6 Sharp":{900:"fass",400:"fasr",normal:"fasr",300:"fasl",100:"fast"},"Font Awesome 6 Sharp Duotone":{900:"fasds",400:"fasdr",normal:"fasdr",300:"fasdl",100:"fasdt"}},_=new Map([["classic",{defaultShortPrefixId:"fas",defaultStyleId:"solid",styleIds:["solid","regular","light","thin","brands"],futureStyleIds:[],defaultFontWeight:900}],["sharp",{defaultShortPrefixId:"fass",defaultStyleId:"solid",styleIds:["solid","regular","light","thin"],futureStyleIds:[],defaultFontWeight:900}],["duotone",{defaultShortPrefixId:"fad",defaultStyleId:"solid",styleIds:["solid","regular","light","thin"],futureStyleIds:[],defaultFontWeight:900}],["sharp-duotone",{defaultShortPrefixId:"fasds",defaultStyleId:"solid",styleIds:["solid","regular","light","thin"],futureStyleIds:[],defaultFontWeight:900}]]),T={classic:{solid:"fas",regular:"far",light:"fal",thin:"fat",brands:"fab"},duotone:{solid:"fad",regular:"fadr",light:"fadl",thin:"fadt"},sharp:{solid:"fass",regular:"fasr",light:"fasl",thin:"fast"},"sharp-duotone":{solid:"fasds",regular:"fasdr",light:"fasdl",thin:"fasdt"}},O=["fak","fa-kit","fakd","fa-kit-duotone"],W={kit:{fak:"kit","fa-kit":"kit"},"kit-duotone":{fakd:"kit-duotone","fa-kit-duotone":"kit-duotone"}},B=["kit"],I={kit:{"fa-kit":"fak"},"kit-duotone":{"fa-kit-duotone":"fakd"}},D=["fak","fakd"],F={kit:{fak:"fa-kit"},"kit-duotone":{fakd:"fa-kit-duotone"}},V={kit:{kit:"fak"},"kit-duotone":{"kit-duotone":"fakd"}},P={GROUP:"duotone-group",SWAP_OPACITY:"swap-opacity",PRIMARY:"primary",SECONDARY:"secondary"},$=["fa-classic","fa-duotone","fa-sharp","fa-sharp-duotone"],H=["fak","fa-kit","fakd","fa-kit-duotone"],j={"Font Awesome Kit":{400:"fak",normal:"fak"},"Font Awesome Kit Duotone":{400:"fakd",normal:"fakd"}},K={classic:{"fa-brands":"fab","fa-duotone":"fad","fa-light":"fal","fa-regular":"far","fa-solid":"fas","fa-thin":"fat"},duotone:{"fa-regular":"fadr","fa-light":"fadl","fa-thin":"fadt"},sharp:{"fa-solid":"fass","fa-regular":"fasr","fa-light":"fasl","fa-thin":"fast"},"sharp-duotone":{"fa-solid":"fasds","fa-regular":"fasdr","fa-light":"fasdl","fa-thin":"fasdt"}},X={classic:["fas","far","fal","fat","fad"],duotone:["fadr","fadl","fadt"],sharp:["fass","fasr","fasl","fast"],"sharp-duotone":["fasds","fasdr","fasdl","fasdt"]},U={classic:{fab:"fa-brands",fad:"fa-duotone",fal:"fa-light",far:"fa-regular",fas:"fa-solid",fat:"fa-thin"},duotone:{fadr:"fa-regular",fadl:"fa-light",fadt:"fa-thin"},sharp:{fass:"fa-solid",fasr:"fa-regular",fasl:"fa-light",fast:"fa-thin"},"sharp-duotone":{fasds:"fa-solid",fasdr:"fa-regular",fasdl:"fa-light",fasdt:"fa-thin"}},q=["fa-solid","fa-regular","fa-light","fa-thin","fa-duotone","fa-brands"],G=["fa","fas","far","fal","fat","fad","fadr","fadl","fadt","fab","fass","fasr","fasl","fast","fasds","fasdr","fasdl","fasdt",...$,...q],Y=["solid","regular","light","thin","duotone","brands"],Q=[1,2,3,4,5,6,7,8,9,10],Z=Q.concat([11,12,13,14,15,16,17,18,19,20]),J=[...Object.keys(X),...Y,"2xs","xs","sm","lg","xl","2xl","beat","border","fade","beat-fade","bounce","flip-both","flip-horizontal","flip-vertical","flip","fw","inverse","layers-counter","layers-text","layers","li","pull-left","pull-right","pulse","rotate-180","rotate-270","rotate-90","rotate-by","shake","spin-pulse","spin-reverse","spin","stack-1x","stack-2x","stack","ul",P.GROUP,P.SWAP_OPACITY,P.PRIMARY,P.SECONDARY].concat(Q.map(e=>"".concat(e,"x"))).concat(Z.map(e=>"w-".concat(e))),ee={"Font Awesome 5 Free":{900:"fas",400:"far"},"Font Awesome 5 Pro":{900:"fas",400:"far",normal:"far",300:"fal"},"Font Awesome 5 Brands":{400:"fab",normal:"fab"},"Font Awesome 5 Duotone":{900:"fad"}};const te="___FONT_AWESOME___",le=16,ne="fa",ae="svg-inline--fa",oe="data-fa-i2svg",ce="data-fa-pseudo-element",re="data-fa-pseudo-element-pending",se="data-prefix",ie="data-icon",ue="fontawesome-i2svg",de="async",fe=["HTML","HEAD","STYLE","SCRIPT"],pe=(()=>{try{return!0}catch(e){return!1}})();function me(e){return new Proxy(e,{get(e,t){return t in e?e[t]:e[z]}})}const ve=o({},L);ve[z]=o(o(o(o({},{"fa-duotone":"duotone"}),L[z]),W["kit"]),W["kit-duotone"]);const he=me(ve),ge=o({},T);ge[z]=o(o(o(o({},{duotone:"fad"}),ge[z]),V["kit"]),V["kit-duotone"]);const be=me(ge),ye=o({},U);ye[z]=o(o({},ye[z]),F["kit"]);const Ce=me(ye),we=o({},K);we[z]=o(o({},we[z]),I["kit"]);me(we);const Le=C,xe="fa-layers-text",Me=w,ze=o({},A),Re=(me(ze),["class","data-prefix","data-icon","data-fa-transform","data-fa-mask"]),ke=x,Se=[...B,...J],Ee=m.FontAwesomeConfig||{};function Ae(e){var t=v.querySelector("script["+e+"]");if(t)return t.getAttribute(e)}function Ne(e){return""===e||"false"!==e&&("true"===e||e)}if(v&&"function"===typeof v.querySelector){const e=[["data-family-prefix","familyPrefix"],["data-css-prefix","cssPrefix"],["data-family-default","familyDefault"],["data-style-default","styleDefault"],["data-replacement-class","replacementClass"],["data-auto-replace-svg","autoReplaceSvg"],["data-auto-add-css","autoAddCss"],["data-auto-a11y","autoA11y"],["data-search-pseudo-elements","searchPseudoElements"],["data-observe-mutations","observeMutations"],["data-mutate-approach","mutateApproach"],["data-keep-original-source","keepOriginalSource"],["data-measure-performance","measurePerformance"],["data-show-missing-icons","showMissingIcons"]];e.forEach(e=>{let[t,l]=e;const n=Ne(Ae(t));void 0!==n&&null!==n&&(Ee[l]=n)})}const _e={styleDefault:"solid",familyDefault:z,cssPrefix:ne,replacementClass:ae,autoReplaceSvg:!0,autoAddCss:!0,autoA11y:!0,searchPseudoElements:!1,observeMutations:!0,mutateApproach:"async",keepOriginalSource:!0,measurePerformance:!1,showMissingIcons:!0};Ee.familyPrefix&&(Ee.cssPrefix=Ee.familyPrefix);const Te=o(o({},_e),Ee);Te.autoReplaceSvg||(Te.observeMutations=!1);const Oe={};Object.keys(_e).forEach(e=>{Object.defineProperty(Oe,e,{enumerable:!0,set:function(t){Te[e]=t,We.forEach(e=>e(Oe))},get:function(){return Te[e]}})}),Object.defineProperty(Oe,"familyPrefix",{enumerable:!0,set:function(e){Te.cssPrefix=e,We.forEach(e=>e(Oe))},get:function(){return Te.cssPrefix}}),m.FontAwesomeConfig=Oe;const We=[];function Be(e){return We.push(e),()=>{We.splice(We.indexOf(e),1)}}const Ie=le,De={size:16,x:0,y:0,rotate:0,flipX:!1,flipY:!1};function Fe(e){if(!e||!b)return;const t=v.createElement("style");t.setAttribute("type","text/css"),t.innerHTML=e;const l=v.head.childNodes;let n=null;for(let a=l.length-1;a>-1;a--){const e=l[a],t=(e.tagName||"").toUpperCase();["STYLE","LINK"].indexOf(t)>-1&&(n=e)}return v.head.insertBefore(t,n),e}const Ve="0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";function Pe(){let e=12,t="";while(e-- >0)t+=Ve[62*Math.random()|0];return t}function $e(e){const t=[];for(let l=(e||[]).length>>>0;l--;)t[l]=e[l];return t}function He(e){return e.classList?$e(e.classList):(e.getAttribute("class")||"").split(" ").filter(e=>e)}function je(e){return"".concat(e).replace(/&/g,"&").replace(/"/g,""").replace(/'/g,"'").replace(//g,">")}function Ke(e){return Object.keys(e||{}).reduce((t,l)=>t+"".concat(l,'="').concat(je(e[l]),'" '),"").trim()}function Xe(e){return Object.keys(e||{}).reduce((t,l)=>t+"".concat(l,": ").concat(e[l].trim(),";"),"")}function Ue(e){return e.size!==De.size||e.x!==De.x||e.y!==De.y||e.rotate!==De.rotate||e.flipX||e.flipY}function qe(e){let{transform:t,containerWidth:l,iconWidth:n}=e;const a={transform:"translate(".concat(l/2," 256)")},o="translate(".concat(32*t.x,", ").concat(32*t.y,") "),c="scale(".concat(t.size/16*(t.flipX?-1:1),", ").concat(t.size/16*(t.flipY?-1:1),") "),r="rotate(".concat(t.rotate," 0 0)"),s={transform:"".concat(o," ").concat(c," ").concat(r)},i={transform:"translate(".concat(n/2*-1," -256)")};return{outer:a,inner:s,path:i}}function Ge(e){let{transform:t,width:l=le,height:n=le,startCentered:a=!1}=e,o="";return o+=a&&y?"translate(".concat(t.x/Ie-l/2,"em, ").concat(t.y/Ie-n/2,"em) "):a?"translate(calc(-50% + ".concat(t.x/Ie,"em), calc(-50% + ").concat(t.y/Ie,"em)) "):"translate(".concat(t.x/Ie,"em, ").concat(t.y/Ie,"em) "),o+="scale(".concat(t.size/Ie*(t.flipX?-1:1),", ").concat(t.size/Ie*(t.flipY?-1:1),") "),o+="rotate(".concat(t.rotate,"deg) "),o}var Ye=':root, :host {\n --fa-font-solid: normal 900 1em/1 "Font Awesome 6 Free";\n --fa-font-regular: normal 400 1em/1 "Font Awesome 6 Free";\n --fa-font-light: normal 300 1em/1 "Font Awesome 6 Pro";\n --fa-font-thin: normal 100 1em/1 "Font Awesome 6 Pro";\n --fa-font-duotone: normal 900 1em/1 "Font Awesome 6 Duotone";\n --fa-font-duotone-regular: normal 400 1em/1 "Font Awesome 6 Duotone";\n --fa-font-duotone-light: normal 300 1em/1 "Font Awesome 6 Duotone";\n --fa-font-duotone-thin: normal 100 1em/1 "Font Awesome 6 Duotone";\n --fa-font-brands: normal 400 1em/1 "Font Awesome 6 Brands";\n --fa-font-sharp-solid: normal 900 1em/1 "Font Awesome 6 Sharp";\n --fa-font-sharp-regular: normal 400 1em/1 "Font Awesome 6 Sharp";\n --fa-font-sharp-light: normal 300 1em/1 "Font Awesome 6 Sharp";\n --fa-font-sharp-thin: normal 100 1em/1 "Font Awesome 6 Sharp";\n --fa-font-sharp-duotone-solid: normal 900 1em/1 "Font Awesome 6 Sharp Duotone";\n --fa-font-sharp-duotone-regular: normal 400 1em/1 "Font Awesome 6 Sharp Duotone";\n --fa-font-sharp-duotone-light: normal 300 1em/1 "Font Awesome 6 Sharp Duotone";\n --fa-font-sharp-duotone-thin: normal 100 1em/1 "Font Awesome 6 Sharp Duotone";\n}\n\nsvg:not(:root).svg-inline--fa, svg:not(:host).svg-inline--fa {\n overflow: visible;\n box-sizing: content-box;\n}\n\n.svg-inline--fa {\n display: var(--fa-display, inline-block);\n height: 1em;\n overflow: visible;\n vertical-align: -0.125em;\n}\n.svg-inline--fa.fa-2xs {\n vertical-align: 0.1em;\n}\n.svg-inline--fa.fa-xs {\n vertical-align: 0em;\n}\n.svg-inline--fa.fa-sm {\n vertical-align: -0.0714285705em;\n}\n.svg-inline--fa.fa-lg {\n vertical-align: -0.2em;\n}\n.svg-inline--fa.fa-xl {\n vertical-align: -0.25em;\n}\n.svg-inline--fa.fa-2xl {\n vertical-align: -0.3125em;\n}\n.svg-inline--fa.fa-pull-left {\n margin-right: var(--fa-pull-margin, 0.3em);\n width: auto;\n}\n.svg-inline--fa.fa-pull-right {\n margin-left: var(--fa-pull-margin, 0.3em);\n width: auto;\n}\n.svg-inline--fa.fa-li {\n width: var(--fa-li-width, 2em);\n top: 0.25em;\n}\n.svg-inline--fa.fa-fw {\n width: var(--fa-fw-width, 1.25em);\n}\n\n.fa-layers svg.svg-inline--fa {\n bottom: 0;\n left: 0;\n margin: auto;\n position: absolute;\n right: 0;\n top: 0;\n}\n\n.fa-layers-counter, .fa-layers-text {\n display: inline-block;\n position: absolute;\n text-align: center;\n}\n\n.fa-layers {\n display: inline-block;\n height: 1em;\n position: relative;\n text-align: center;\n vertical-align: -0.125em;\n width: 1em;\n}\n.fa-layers svg.svg-inline--fa {\n transform-origin: center center;\n}\n\n.fa-layers-text {\n left: 50%;\n top: 50%;\n transform: translate(-50%, -50%);\n transform-origin: center center;\n}\n\n.fa-layers-counter {\n background-color: var(--fa-counter-background-color, #ff253a);\n border-radius: var(--fa-counter-border-radius, 1em);\n box-sizing: border-box;\n color: var(--fa-inverse, #fff);\n line-height: var(--fa-counter-line-height, 1);\n max-width: var(--fa-counter-max-width, 5em);\n min-width: var(--fa-counter-min-width, 1.5em);\n overflow: hidden;\n padding: var(--fa-counter-padding, 0.25em 0.5em);\n right: var(--fa-right, 0);\n text-overflow: ellipsis;\n top: var(--fa-top, 0);\n transform: scale(var(--fa-counter-scale, 0.25));\n transform-origin: top right;\n}\n\n.fa-layers-bottom-right {\n bottom: var(--fa-bottom, 0);\n right: var(--fa-right, 0);\n top: auto;\n transform: scale(var(--fa-layers-scale, 0.25));\n transform-origin: bottom right;\n}\n\n.fa-layers-bottom-left {\n bottom: var(--fa-bottom, 0);\n left: var(--fa-left, 0);\n right: auto;\n top: auto;\n transform: scale(var(--fa-layers-scale, 0.25));\n transform-origin: bottom left;\n}\n\n.fa-layers-top-right {\n top: var(--fa-top, 0);\n right: var(--fa-right, 0);\n transform: scale(var(--fa-layers-scale, 0.25));\n transform-origin: top right;\n}\n\n.fa-layers-top-left {\n left: var(--fa-left, 0);\n right: auto;\n top: var(--fa-top, 0);\n transform: scale(var(--fa-layers-scale, 0.25));\n transform-origin: top left;\n}\n\n.fa-1x {\n font-size: 1em;\n}\n\n.fa-2x {\n font-size: 2em;\n}\n\n.fa-3x {\n font-size: 3em;\n}\n\n.fa-4x {\n font-size: 4em;\n}\n\n.fa-5x {\n font-size: 5em;\n}\n\n.fa-6x {\n font-size: 6em;\n}\n\n.fa-7x {\n font-size: 7em;\n}\n\n.fa-8x {\n font-size: 8em;\n}\n\n.fa-9x {\n font-size: 9em;\n}\n\n.fa-10x {\n font-size: 10em;\n}\n\n.fa-2xs {\n font-size: 0.625em;\n line-height: 0.1em;\n vertical-align: 0.225em;\n}\n\n.fa-xs {\n font-size: 0.75em;\n line-height: 0.0833333337em;\n vertical-align: 0.125em;\n}\n\n.fa-sm {\n font-size: 0.875em;\n line-height: 0.0714285718em;\n vertical-align: 0.0535714295em;\n}\n\n.fa-lg {\n font-size: 1.25em;\n line-height: 0.05em;\n vertical-align: -0.075em;\n}\n\n.fa-xl {\n font-size: 1.5em;\n line-height: 0.0416666682em;\n vertical-align: -0.125em;\n}\n\n.fa-2xl {\n font-size: 2em;\n line-height: 0.03125em;\n vertical-align: -0.1875em;\n}\n\n.fa-fw {\n text-align: center;\n width: 1.25em;\n}\n\n.fa-ul {\n list-style-type: none;\n margin-left: var(--fa-li-margin, 2.5em);\n padding-left: 0;\n}\n.fa-ul > li {\n position: relative;\n}\n\n.fa-li {\n left: calc(-1 * var(--fa-li-width, 2em));\n position: absolute;\n text-align: center;\n width: var(--fa-li-width, 2em);\n line-height: inherit;\n}\n\n.fa-border {\n border-color: var(--fa-border-color, #eee);\n border-radius: var(--fa-border-radius, 0.1em);\n border-style: var(--fa-border-style, solid);\n border-width: var(--fa-border-width, 0.08em);\n padding: var(--fa-border-padding, 0.2em 0.25em 0.15em);\n}\n\n.fa-pull-left {\n float: left;\n margin-right: var(--fa-pull-margin, 0.3em);\n}\n\n.fa-pull-right {\n float: right;\n margin-left: var(--fa-pull-margin, 0.3em);\n}\n\n.fa-beat {\n animation-name: fa-beat;\n animation-delay: var(--fa-animation-delay, 0s);\n animation-direction: var(--fa-animation-direction, normal);\n animation-duration: var(--fa-animation-duration, 1s);\n animation-iteration-count: var(--fa-animation-iteration-count, infinite);\n animation-timing-function: var(--fa-animation-timing, ease-in-out);\n}\n\n.fa-bounce {\n animation-name: fa-bounce;\n animation-delay: var(--fa-animation-delay, 0s);\n animation-direction: var(--fa-animation-direction, normal);\n animation-duration: var(--fa-animation-duration, 1s);\n animation-iteration-count: var(--fa-animation-iteration-count, infinite);\n animation-timing-function: var(--fa-animation-timing, cubic-bezier(0.28, 0.84, 0.42, 1));\n}\n\n.fa-fade {\n animation-name: fa-fade;\n animation-delay: var(--fa-animation-delay, 0s);\n animation-direction: var(--fa-animation-direction, normal);\n animation-duration: var(--fa-animation-duration, 1s);\n animation-iteration-count: var(--fa-animation-iteration-count, infinite);\n animation-timing-function: var(--fa-animation-timing, cubic-bezier(0.4, 0, 0.6, 1));\n}\n\n.fa-beat-fade {\n animation-name: fa-beat-fade;\n animation-delay: var(--fa-animation-delay, 0s);\n animation-direction: var(--fa-animation-direction, normal);\n animation-duration: var(--fa-animation-duration, 1s);\n animation-iteration-count: var(--fa-animation-iteration-count, infinite);\n animation-timing-function: var(--fa-animation-timing, cubic-bezier(0.4, 0, 0.6, 1));\n}\n\n.fa-flip {\n animation-name: fa-flip;\n animation-delay: var(--fa-animation-delay, 0s);\n animation-direction: var(--fa-animation-direction, normal);\n animation-duration: var(--fa-animation-duration, 1s);\n animation-iteration-count: var(--fa-animation-iteration-count, infinite);\n animation-timing-function: var(--fa-animation-timing, ease-in-out);\n}\n\n.fa-shake {\n animation-name: fa-shake;\n animation-delay: var(--fa-animation-delay, 0s);\n animation-direction: var(--fa-animation-direction, normal);\n animation-duration: var(--fa-animation-duration, 1s);\n animation-iteration-count: var(--fa-animation-iteration-count, infinite);\n animation-timing-function: var(--fa-animation-timing, linear);\n}\n\n.fa-spin {\n animation-name: fa-spin;\n animation-delay: var(--fa-animation-delay, 0s);\n animation-direction: var(--fa-animation-direction, normal);\n animation-duration: var(--fa-animation-duration, 2s);\n animation-iteration-count: var(--fa-animation-iteration-count, infinite);\n animation-timing-function: var(--fa-animation-timing, linear);\n}\n\n.fa-spin-reverse {\n --fa-animation-direction: reverse;\n}\n\n.fa-pulse,\n.fa-spin-pulse {\n animation-name: fa-spin;\n animation-direction: var(--fa-animation-direction, normal);\n animation-duration: var(--fa-animation-duration, 1s);\n animation-iteration-count: var(--fa-animation-iteration-count, infinite);\n animation-timing-function: var(--fa-animation-timing, steps(8));\n}\n\n@media (prefers-reduced-motion: reduce) {\n .fa-beat,\n.fa-bounce,\n.fa-fade,\n.fa-beat-fade,\n.fa-flip,\n.fa-pulse,\n.fa-shake,\n.fa-spin,\n.fa-spin-pulse {\n animation-delay: -1ms;\n animation-duration: 1ms;\n animation-iteration-count: 1;\n transition-delay: 0s;\n transition-duration: 0s;\n }\n}\n@keyframes fa-beat {\n 0%, 90% {\n transform: scale(1);\n }\n 45% {\n transform: scale(var(--fa-beat-scale, 1.25));\n }\n}\n@keyframes fa-bounce {\n 0% {\n transform: scale(1, 1) translateY(0);\n }\n 10% {\n transform: scale(var(--fa-bounce-start-scale-x, 1.1), var(--fa-bounce-start-scale-y, 0.9)) translateY(0);\n }\n 30% {\n transform: scale(var(--fa-bounce-jump-scale-x, 0.9), var(--fa-bounce-jump-scale-y, 1.1)) translateY(var(--fa-bounce-height, -0.5em));\n }\n 50% {\n transform: scale(var(--fa-bounce-land-scale-x, 1.05), var(--fa-bounce-land-scale-y, 0.95)) translateY(0);\n }\n 57% {\n transform: scale(1, 1) translateY(var(--fa-bounce-rebound, -0.125em));\n }\n 64% {\n transform: scale(1, 1) translateY(0);\n }\n 100% {\n transform: scale(1, 1) translateY(0);\n }\n}\n@keyframes fa-fade {\n 50% {\n opacity: var(--fa-fade-opacity, 0.4);\n }\n}\n@keyframes fa-beat-fade {\n 0%, 100% {\n opacity: var(--fa-beat-fade-opacity, 0.4);\n transform: scale(1);\n }\n 50% {\n opacity: 1;\n transform: scale(var(--fa-beat-fade-scale, 1.125));\n }\n}\n@keyframes fa-flip {\n 50% {\n transform: rotate3d(var(--fa-flip-x, 0), var(--fa-flip-y, 1), var(--fa-flip-z, 0), var(--fa-flip-angle, -180deg));\n }\n}\n@keyframes fa-shake {\n 0% {\n transform: rotate(-15deg);\n }\n 4% {\n transform: rotate(15deg);\n }\n 8%, 24% {\n transform: rotate(-18deg);\n }\n 12%, 28% {\n transform: rotate(18deg);\n }\n 16% {\n transform: rotate(-22deg);\n }\n 20% {\n transform: rotate(22deg);\n }\n 32% {\n transform: rotate(-12deg);\n }\n 36% {\n transform: rotate(12deg);\n }\n 40%, 100% {\n transform: rotate(0deg);\n }\n}\n@keyframes fa-spin {\n 0% {\n transform: rotate(0deg);\n }\n 100% {\n transform: rotate(360deg);\n }\n}\n.fa-rotate-90 {\n transform: rotate(90deg);\n}\n\n.fa-rotate-180 {\n transform: rotate(180deg);\n}\n\n.fa-rotate-270 {\n transform: rotate(270deg);\n}\n\n.fa-flip-horizontal {\n transform: scale(-1, 1);\n}\n\n.fa-flip-vertical {\n transform: scale(1, -1);\n}\n\n.fa-flip-both,\n.fa-flip-horizontal.fa-flip-vertical {\n transform: scale(-1, -1);\n}\n\n.fa-rotate-by {\n transform: rotate(var(--fa-rotate-angle, 0));\n}\n\n.fa-stack {\n display: inline-block;\n vertical-align: middle;\n height: 2em;\n position: relative;\n width: 2.5em;\n}\n\n.fa-stack-1x,\n.fa-stack-2x {\n bottom: 0;\n left: 0;\n margin: auto;\n position: absolute;\n right: 0;\n top: 0;\n z-index: var(--fa-stack-z-index, auto);\n}\n\n.svg-inline--fa.fa-stack-1x {\n height: 1em;\n width: 1.25em;\n}\n.svg-inline--fa.fa-stack-2x {\n height: 2em;\n width: 2.5em;\n}\n\n.fa-inverse {\n color: var(--fa-inverse, #fff);\n}\n\n.sr-only,\n.fa-sr-only {\n position: absolute;\n width: 1px;\n height: 1px;\n padding: 0;\n margin: -1px;\n overflow: hidden;\n clip: rect(0, 0, 0, 0);\n white-space: nowrap;\n border-width: 0;\n}\n\n.sr-only-focusable:not(:focus),\n.fa-sr-only-focusable:not(:focus) {\n position: absolute;\n width: 1px;\n height: 1px;\n padding: 0;\n margin: -1px;\n overflow: hidden;\n clip: rect(0, 0, 0, 0);\n white-space: nowrap;\n border-width: 0;\n}\n\n.svg-inline--fa .fa-primary {\n fill: var(--fa-primary-color, currentColor);\n opacity: var(--fa-primary-opacity, 1);\n}\n\n.svg-inline--fa .fa-secondary {\n fill: var(--fa-secondary-color, currentColor);\n opacity: var(--fa-secondary-opacity, 0.4);\n}\n\n.svg-inline--fa.fa-swap-opacity .fa-primary {\n opacity: var(--fa-secondary-opacity, 0.4);\n}\n\n.svg-inline--fa.fa-swap-opacity .fa-secondary {\n opacity: var(--fa-primary-opacity, 1);\n}\n\n.svg-inline--fa mask .fa-primary,\n.svg-inline--fa mask .fa-secondary {\n fill: black;\n}';function Qe(){const e=ne,t=ae,l=Oe.cssPrefix,n=Oe.replacementClass;let a=Ye;if(l!==e||n!==t){const o=new RegExp("\\.".concat(e,"\\-"),"g"),c=new RegExp("\\--".concat(e,"\\-"),"g"),r=new RegExp("\\.".concat(t),"g");a=a.replace(o,".".concat(l,"-")).replace(c,"--".concat(l,"-")).replace(r,".".concat(n))}return a}let Ze=!1;function Je(){Oe.autoAddCss&&!Ze&&(Fe(Qe()),Ze=!0)}var et={mixout(){return{dom:{css:Qe,insertCss:Je}}},hooks(){return{beforeDOMElementCreation(){Je()},beforeI2svg(){Je()}}}};const tt=m||{};tt[te]||(tt[te]={}),tt[te].styles||(tt[te].styles={}),tt[te].hooks||(tt[te].hooks={}),tt[te].shims||(tt[te].shims=[]);var lt=tt[te];const nt=[],at=function(){v.removeEventListener("DOMContentLoaded",at),ot=1,nt.map(e=>e())};let ot=!1;function ct(e){b&&(ot?setTimeout(e,0):nt.push(e))}function rt(e){const{tag:t,attributes:l={},children:n=[]}=e;return"string"===typeof e?je(e):"<".concat(t," ").concat(Ke(l),">").concat(n.map(rt).join(""),"")}function st(e,t,l){if(e&&e[t]&&e[t][l])return{prefix:t,iconName:l,icon:e[t][l]}}b&&(ot=(v.documentElement.doScroll?/^loaded|^c/:/^loaded|^i|^c/).test(v.readyState),ot||v.addEventListener("DOMContentLoaded",at));var it=function(e,t){return function(l,n,a,o){return e.call(t,l,n,a,o)}},ut=function(e,t,l,n){var a,o,c,r=Object.keys(e),s=r.length,i=void 0!==n?it(t,n):t;for(void 0===l?(a=1,c=e[r[0]]):(a=0,c=l);a=55296&&a<=56319&&l=55296&&a<=56319&&l>t+1&&(n=e.charCodeAt(t+1),n>=56320&&n<=57343)?1024*(a-55296)+n-56320+65536:a}function mt(e){return Object.keys(e).reduce((t,l)=>{const n=e[l],a=!!n.icon;return a?t[n.iconName]=n.icon:t[l]=n,t},{})}function vt(e,t){let l=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};const{skipHooks:n=!1}=l,a=mt(t);"function"!==typeof lt.hooks.addPack||n?lt.styles[e]=o(o({},lt.styles[e]||{}),a):lt.hooks.addPack(e,mt(t)),"fas"===e&&vt("fa",t)}const{styles:ht,shims:gt}=lt,bt=Object.keys(Ce),yt=bt.reduce((e,t)=>(e[t]=Object.keys(Ce[t]),e),{});let Ct=null,wt={},Lt={},xt={},Mt={},zt={};function Rt(e){return~Se.indexOf(e)}function kt(e,t){const l=t.split("-"),n=l[0],a=l.slice(1).join("-");return n!==e||""===a||Rt(a)?null:a}const St=()=>{const e=e=>ut(ht,(t,l,n)=>(t[n]=ut(l,e,{}),t),{});wt=e((e,t,l)=>{if(t[3]&&(e[t[3]]=l),t[2]){const n=t[2].filter(e=>"number"===typeof e);n.forEach(t=>{e[t.toString(16)]=l})}return e}),Lt=e((e,t,l)=>{if(e[l]=l,t[2]){const n=t[2].filter(e=>"string"===typeof e);n.forEach(t=>{e[t]=l})}return e}),zt=e((e,t,l)=>{const n=t[2];return e[l]=l,n.forEach(t=>{e[t]=l}),e});const t="far"in ht||Oe.autoFetchSvg,l=ut(gt,(e,l)=>{const n=l[0];let a=l[1];const o=l[2];return"far"!==a||t||(a="fas"),"string"===typeof n&&(e.names[n]={prefix:a,iconName:o}),"number"===typeof n&&(e.unicodes[n.toString(16)]={prefix:a,iconName:o}),e},{names:{},unicodes:{}});xt=l.names,Mt=l.unicodes,Ct=It(Oe.styleDefault,{family:Oe.familyDefault})};function Et(e,t){return(wt[e]||{})[t]}function At(e,t){return(Lt[e]||{})[t]}function Nt(e,t){return(zt[e]||{})[t]}function _t(e){return xt[e]||{prefix:null,iconName:null}}function Tt(e){const t=Mt[e],l=Et("fas",e);return t||(l?{prefix:"fas",iconName:l}:null)||{prefix:null,iconName:null}}function Ot(){return Ct}Be(e=>{Ct=It(e.styleDefault,{family:Oe.familyDefault})}),St();const Wt=()=>({prefix:null,iconName:null,rest:[]});function Bt(e){let t=z;const l=bt.reduce((e,t)=>(e[t]="".concat(Oe.cssPrefix,"-").concat(t),e),{});return E.forEach(n=>{(e.includes(l[n])||e.some(e=>yt[n].includes(e)))&&(t=n)}),t}function It(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};const{family:l=z}=t,n=he[l][e];if(l===R&&!e)return"fad";const a=be[l][e]||be[l][n],o=e in lt.styles?e:null,c=a||o||null;return c}function Dt(e){let t=[],l=null;return e.forEach(e=>{const n=kt(Oe.cssPrefix,e);n?l=n:e&&t.push(e)}),{iconName:l,rest:t}}function Ft(e){return e.sort().filter((e,t,l)=>l.indexOf(e)===t)}function Vt(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};const{skipLookups:l=!1}=t;let n=null;const a=G.concat(H),c=Ft(e.filter(e=>a.includes(e))),r=Ft(e.filter(e=>!G.includes(e))),s=c.filter(e=>(n=e,!M.includes(e))),[i=null]=s,u=Bt(c),d=o(o({},Dt(r)),{},{prefix:It(i,{family:u})});return o(o(o({},d),jt({values:e,family:u,styles:ht,config:Oe,canonical:d,givenPrefix:n})),Pt(l,n,d))}function Pt(e,t,l){let{prefix:n,iconName:a}=l;if(e||!n||!a)return{prefix:n,iconName:a};const o="fa"===t?_t(a):{},c=Nt(n,a);return a=o.iconName||c||a,n=o.prefix||n,"far"!==n||ht["far"]||!ht["fas"]||Oe.autoFetchSvg||(n="fas"),{prefix:n,iconName:a}}const $t=E.filter(e=>e!==z||e!==R),Ht=Object.keys(U).filter(e=>e!==z).map(e=>Object.keys(U[e])).flat();function jt(e){const{values:t,family:l,canonical:n,givenPrefix:a="",styles:o={},config:c={}}=e,r=l===R,s=t.includes("fa-duotone")||t.includes("fad"),i="duotone"===c.familyDefault,u="fad"===n.prefix||"fa-duotone"===n.prefix;if(!r&&(s||i||u)&&(n.prefix="fad"),(t.includes("fa-brands")||t.includes("fab"))&&(n.prefix="fab"),!n.prefix&&$t.includes(l)){const e=Object.keys(o).find(e=>Ht.includes(e));if(e||c.autoFetchSvg){const e=_.get(l).defaultShortPrefixId;n.prefix=e,n.iconName=Nt(n.prefix,n.iconName)||n.iconName}}return"fa"!==n.prefix&&"fa"!==a||(n.prefix=Ot()||"fas"),n}class Kt{constructor(){this.definitions={}}add(){for(var e=arguments.length,t=new Array(e),l=0;l{this.definitions[e]=o(o({},this.definitions[e]||{}),n[e]),vt(e,n[e]);const t=Ce[z][e];t&&vt(t,n[e]),St()})}reset(){this.definitions={}}_pullDefinitions(e,t){const l=t.prefix&&t.iconName&&t.icon?{0:t}:t;return Object.keys(l).map(t=>{const{prefix:n,iconName:a,icon:o}=l[t],c=o[2];e[n]||(e[n]={}),c.length>0&&c.forEach(t=>{"string"===typeof t&&(e[n][t]=o)}),e[n][a]=o}),e}}let Xt=[],Ut={};const qt={},Gt=Object.keys(qt);function Yt(e,t){let{mixoutsTo:l}=t;return Xt=e,Ut={},Object.keys(qt).forEach(e=>{-1===Gt.indexOf(e)&&delete qt[e]}),Xt.forEach(e=>{const t=e.mixout?e.mixout():{};if(Object.keys(t).forEach(e=>{"function"===typeof t[e]&&(l[e]=t[e]),"object"===typeof t[e]&&Object.keys(t[e]).forEach(n=>{l[e]||(l[e]={}),l[e][n]=t[e][n]})}),e.hooks){const t=e.hooks();Object.keys(t).forEach(e=>{Ut[e]||(Ut[e]=[]),Ut[e].push(t[e])})}e.provides&&e.provides(qt)}),l}function Qt(e,t){for(var l=arguments.length,n=new Array(l>2?l-2:0),a=2;a{t=e.apply(null,[t,...n])}),t}function Zt(e){for(var t=arguments.length,l=new Array(t>1?t-1:0),n=1;n{e.apply(null,l)})}function Jt(){const e=arguments[0],t=Array.prototype.slice.call(arguments,1);return qt[e]?qt[e].apply(null,t):void 0}function el(e){"fa"===e.prefix&&(e.prefix="fas");let{iconName:t}=e;const l=e.prefix||Ot();if(t)return t=Nt(l,t)||t,st(tl.definitions,l,t)||st(lt.styles,l,t)}const tl=new Kt,ll=()=>{Oe.autoReplaceSvg=!1,Oe.observeMutations=!1,Zt("noAuto")},nl={i2svg:function(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return b?(Zt("beforeI2svg",e),Jt("pseudoElements2svg",e),Jt("i2svg",e)):Promise.reject(new Error("Operation requires a DOM of some kind."))},watch:function(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};const{autoReplaceSvgRoot:t}=e;!1===Oe.autoReplaceSvg&&(Oe.autoReplaceSvg=!0),Oe.observeMutations=!0,ct(()=>{cl({autoReplaceSvgRoot:t}),Zt("watch",e)})}},al={icon:e=>{if(null===e)return null;if("object"===typeof e&&e.prefix&&e.iconName)return{prefix:e.prefix,iconName:Nt(e.prefix,e.iconName)||e.iconName};if(Array.isArray(e)&&2===e.length){const t=0===e[1].indexOf("fa-")?e[1].slice(3):e[1],l=It(e[0]);return{prefix:l,iconName:Nt(l,t)||t}}if("string"===typeof e&&(e.indexOf("".concat(Oe.cssPrefix,"-"))>-1||e.match(Le))){const t=Vt(e.split(" "),{skipLookups:!0});return{prefix:t.prefix||Ot(),iconName:Nt(t.prefix,t.iconName)||t.iconName}}if("string"===typeof e){const t=Ot();return{prefix:t,iconName:Nt(t,e)||e}}}},ol={noAuto:ll,config:Oe,dom:nl,parse:al,library:tl,findIconDefinition:el,toHtml:rt},cl=function(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};const{autoReplaceSvgRoot:t=v}=e;(Object.keys(lt.styles).length>0||Oe.autoFetchSvg)&&b&&Oe.autoReplaceSvg&&ol.dom.i2svg({node:t})};function rl(e,t){return Object.defineProperty(e,"abstract",{get:t}),Object.defineProperty(e,"html",{get:function(){return e.abstract.map(e=>rt(e))}}),Object.defineProperty(e,"node",{get:function(){if(!b)return;const t=v.createElement("div");return t.innerHTML=e.html,t.children}}),e}function sl(e){let{children:t,main:l,mask:n,attributes:a,styles:c,transform:r}=e;if(Ue(r)&&l.found&&!n.found){const{width:e,height:t}=l,n={x:e/t/2,y:.5};a["style"]=Xe(o(o({},c),{},{"transform-origin":"".concat(n.x+r.x/16,"em ").concat(n.y+r.y/16,"em")}))}return[{tag:"svg",attributes:a,children:t}]}function il(e){let{prefix:t,iconName:l,children:n,attributes:a,symbol:c}=e;const r=!0===c?"".concat(t,"-").concat(Oe.cssPrefix,"-").concat(l):c;return[{tag:"svg",attributes:{style:"display: none;"},children:[{tag:"symbol",attributes:o(o({},a),{},{id:r}),children:n}]}]}function ul(e){const{icons:{main:t,mask:l},prefix:n,iconName:a,transform:c,symbol:r,title:s,maskId:i,titleId:u,extra:d,watchable:f=!1}=e,{width:p,height:m}=l.found?l:t,v=D.includes(n),h=[Oe.replacementClass,a?"".concat(Oe.cssPrefix,"-").concat(a):""].filter(e=>-1===d.classes.indexOf(e)).filter(e=>""!==e||!!e).concat(d.classes).join(" ");let g={children:[],attributes:o(o({},d.attributes),{},{"data-prefix":n,"data-icon":a,class:h,role:d.attributes.role||"img",xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 ".concat(p," ").concat(m)})};const b=v&&!~d.classes.indexOf("fa-fw")?{width:"".concat(p/m*16*.0625,"em")}:{};f&&(g.attributes[oe]=""),s&&(g.children.push({tag:"title",attributes:{id:g.attributes["aria-labelledby"]||"title-".concat(u||Pe())},children:[s]}),delete g.attributes.title);const y=o(o({},g),{},{prefix:n,iconName:a,main:t,mask:l,maskId:i,transform:c,symbol:r,styles:o(o({},b),d.styles)}),{children:C,attributes:w}=l.found&&t.found?Jt("generateAbstractMask",y)||{children:[],attributes:{}}:Jt("generateAbstractIcon",y)||{children:[],attributes:{}};return y.children=C,y.attributes=w,r?il(y):sl(y)}function dl(e){const{content:t,width:l,height:n,transform:a,title:c,extra:r,watchable:s=!1}=e,i=o(o(o({},r.attributes),c?{title:c}:{}),{},{class:r.classes.join(" ")});s&&(i[oe]="");const u=o({},r.styles);Ue(a)&&(u["transform"]=Ge({transform:a,startCentered:!0,width:l,height:n}),u["-webkit-transform"]=u["transform"]);const d=Xe(u);d.length>0&&(i["style"]=d);const f=[];return f.push({tag:"span",attributes:i,children:[t]}),c&&f.push({tag:"span",attributes:{class:"sr-only"},children:[c]}),f}function fl(e){const{content:t,title:l,extra:n}=e,a=o(o(o({},n.attributes),l?{title:l}:{}),{},{class:n.classes.join(" ")}),c=Xe(n.styles);c.length>0&&(a["style"]=c);const r=[];return r.push({tag:"span",attributes:a,children:[t]}),l&&r.push({tag:"span",attributes:{class:"sr-only"},children:[l]}),r}const{styles:pl}=lt;function ml(e){const t=e[0],l=e[1],[n]=e.slice(4);let a=null;return a=Array.isArray(n)?{tag:"g",attributes:{class:"".concat(Oe.cssPrefix,"-").concat(ke.GROUP)},children:[{tag:"path",attributes:{class:"".concat(Oe.cssPrefix,"-").concat(ke.SECONDARY),fill:"currentColor",d:n[0]}},{tag:"path",attributes:{class:"".concat(Oe.cssPrefix,"-").concat(ke.PRIMARY),fill:"currentColor",d:n[1]}}]}:{tag:"path",attributes:{fill:"currentColor",d:n}},{found:!0,width:t,height:l,icon:a}}const vl={found:!1,width:512,height:512};function hl(e,t){pe||Oe.showMissingIcons||!e||console.error('Icon with name "'.concat(e,'" and prefix "').concat(t,'" is missing.'))}function gl(e,t){let l=t;return"fa"===t&&null!==Oe.styleDefault&&(t=Ot()),new Promise((n,a)=>{if("fa"===l){const l=_t(e)||{};e=l.iconName||e,t=l.prefix||t}if(e&&t&&pl[t]&&pl[t][e]){const l=pl[t][e];return n(ml(l))}hl(e,t),n(o(o({},vl),{},{icon:Oe.showMissingIcons&&e&&Jt("missingIconAbstract")||{}}))})}const bl=()=>{},yl=Oe.measurePerformance&&g&&g.mark&&g.measure?g:{mark:bl,measure:bl},Cl='FA "6.7.2"',wl=e=>(yl.mark("".concat(Cl," ").concat(e," begins")),()=>Ll(e)),Ll=e=>{yl.mark("".concat(Cl," ").concat(e," ends")),yl.measure("".concat(Cl," ").concat(e),"".concat(Cl," ").concat(e," begins"),"".concat(Cl," ").concat(e," ends"))};var xl={begin:wl,end:Ll};const Ml=()=>{};function zl(e){const t=e.getAttribute?e.getAttribute(oe):null;return"string"===typeof t}function Rl(e){const t=e.getAttribute?e.getAttribute(se):null,l=e.getAttribute?e.getAttribute(ie):null;return t&&l}function kl(e){return e&&e.classList&&e.classList.contains&&e.classList.contains(Oe.replacementClass)}function Sl(){if(!0===Oe.autoReplaceSvg)return Tl.replace;const e=Tl[Oe.autoReplaceSvg];return e||Tl.replace}function El(e){return v.createElementNS("http://www.w3.org/2000/svg",e)}function Al(e){return v.createElement(e)}function Nl(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};const{ceFn:l=("svg"===e.tag?El:Al)}=t;if("string"===typeof e)return v.createTextNode(e);const n=l(e.tag);Object.keys(e.attributes||[]).forEach(function(t){n.setAttribute(t,e.attributes[t])});const a=e.children||[];return a.forEach(function(e){n.appendChild(Nl(e,{ceFn:l}))}),n}function _l(e){let t=" ".concat(e.outerHTML," ");return t="".concat(t,"Font Awesome fontawesome.com "),t}const Tl={replace:function(e){const t=e[0];if(t.parentNode)if(e[1].forEach(e=>{t.parentNode.insertBefore(Nl(e),t)}),null===t.getAttribute(oe)&&Oe.keepOriginalSource){let e=v.createComment(_l(t));t.parentNode.replaceChild(e,t)}else t.remove()},nest:function(e){const t=e[0],l=e[1];if(~He(t).indexOf(Oe.replacementClass))return Tl.replace(e);const n=new RegExp("".concat(Oe.cssPrefix,"-.*"));if(delete l[0].attributes.id,l[0].attributes.class){const e=l[0].attributes.class.split(" ").reduce((e,t)=>(t===Oe.replacementClass||t.match(n)?e.toSvg.push(t):e.toNode.push(t),e),{toNode:[],toSvg:[]});l[0].attributes.class=e.toSvg.join(" "),0===e.toNode.length?t.removeAttribute("class"):t.setAttribute("class",e.toNode.join(" "))}const a=l.map(e=>rt(e)).join("\n");t.setAttribute(oe,""),t.innerHTML=a}};function Ol(e){e()}function Wl(e,t){const l="function"===typeof t?t:Ml;if(0===e.length)l();else{let t=Ol;Oe.mutateApproach===de&&(t=m.requestAnimationFrame||Ol),t(()=>{const t=Sl(),n=xl.begin("mutate");e.map(t),n(),l()})}}let Bl=!1;function Il(){Bl=!0}function Dl(){Bl=!1}let Fl=null;function Vl(e){if(!h)return;if(!Oe.observeMutations)return;const{treeCallback:t=Ml,nodeCallback:l=Ml,pseudoElementsCallback:n=Ml,observeMutationsRoot:a=v}=e;Fl=new h(e=>{if(Bl)return;const a=Ot();$e(e).forEach(e=>{if("childList"===e.type&&e.addedNodes.length>0&&!zl(e.addedNodes[0])&&(Oe.searchPseudoElements&&n(e.target),t(e.target)),"attributes"===e.type&&e.target.parentNode&&Oe.searchPseudoElements&&n(e.target.parentNode),"attributes"===e.type&&zl(e.target)&&~Re.indexOf(e.attributeName))if("class"===e.attributeName&&Rl(e.target)){const{prefix:t,iconName:l}=Vt(He(e.target));e.target.setAttribute(se,t||a),l&&e.target.setAttribute(ie,l)}else kl(e.target)&&l(e.target)})}),b&&Fl.observe(a,{childList:!0,attributes:!0,characterData:!0,subtree:!0})}function Pl(){Fl&&Fl.disconnect()}function $l(e){const t=e.getAttribute("style");let l=[];return t&&(l=t.split(";").reduce((e,t)=>{const l=t.split(":"),n=l[0],a=l.slice(1);return n&&a.length>0&&(e[n]=a.join(":").trim()),e},{})),l}function Hl(e){const t=e.getAttribute("data-prefix"),l=e.getAttribute("data-icon"),n=void 0!==e.innerText?e.innerText.trim():"";let a=Vt(He(e));return a.prefix||(a.prefix=Ot()),t&&l&&(a.prefix=t,a.iconName=l),a.iconName&&a.prefix||(a.prefix&&n.length>0&&(a.iconName=At(a.prefix,e.innerText)||Et(a.prefix,ft(e.innerText))),!a.iconName&&Oe.autoFetchSvg&&e.firstChild&&e.firstChild.nodeType===Node.TEXT_NODE&&(a.iconName=e.firstChild.data)),a}function jl(e){const t=$e(e.attributes).reduce((e,t)=>("class"!==e.name&&"style"!==e.name&&(e[t.name]=t.value),e),{}),l=e.getAttribute("title"),n=e.getAttribute("data-fa-title-id");return Oe.autoA11y&&(l?t["aria-labelledby"]="".concat(Oe.replacementClass,"-title-").concat(n||Pe()):(t["aria-hidden"]="true",t["focusable"]="false")),t}function Kl(){return{iconName:null,title:null,titleId:null,prefix:null,transform:De,symbol:!1,mask:{iconName:null,prefix:null,rest:[]},maskId:null,extra:{classes:[],styles:{},attributes:{}}}}function Xl(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{styleParser:!0};const{iconName:l,prefix:n,rest:a}=Hl(e),c=jl(e),r=Qt("parseNodeAttributes",{},e);let s=t.styleParser?$l(e):[];return o({iconName:l,title:e.getAttribute("title"),titleId:e.getAttribute("data-fa-title-id"),prefix:n,transform:De,mask:{iconName:null,prefix:null,rest:[]},maskId:null,symbol:!1,extra:{classes:a,styles:s,attributes:c}},r)}const{styles:Ul}=lt;function ql(e){const t="nest"===Oe.autoReplaceSvg?Xl(e,{styleParser:!1}):Xl(e);return~t.extra.classes.indexOf(xe)?Jt("generateLayersText",e,t):Jt("generateSvgReplacementMutation",e,t)}function Gl(){return[...O,...G]}function Yl(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:null;if(!b)return Promise.resolve();const l=v.documentElement.classList,n=e=>l.add("".concat(ue,"-").concat(e)),a=e=>l.remove("".concat(ue,"-").concat(e)),o=Oe.autoFetchSvg?Gl():M.concat(Object.keys(Ul));o.includes("fa")||o.push("fa");const c=[".".concat(xe,":not([").concat(oe,"])")].concat(o.map(e=>".".concat(e,":not([").concat(oe,"])"))).join(", ");if(0===c.length)return Promise.resolve();let r=[];try{r=$e(e.querySelectorAll(c))}catch(u){}if(!(r.length>0))return Promise.resolve();n("pending"),a("complete");const s=xl.begin("onTree"),i=r.reduce((e,t)=>{try{const l=ql(t);l&&e.push(l)}catch(u){pe||"MissingIcon"===u.name&&console.error(u)}return e},[]);return new Promise((e,l)=>{Promise.all(i).then(l=>{Wl(l,()=>{n("active"),n("complete"),a("pending"),"function"===typeof t&&t(),s(),e()})}).catch(e=>{s(),l(e)})})}function Ql(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:null;ql(e).then(e=>{e&&Wl([e],t)})}function Zl(e){return function(t){let l=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};const n=(t||{}).icon?t:el(t||{});let{mask:a}=l;return a&&(a=(a||{}).icon?a:el(a||{})),e(n,o(o({},l),{},{mask:a}))}}const Jl=function(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};const{transform:l=De,symbol:n=!1,mask:a=null,maskId:c=null,title:r=null,titleId:s=null,classes:i=[],attributes:u={},styles:d={}}=t;if(!e)return;const{prefix:f,iconName:p,icon:m}=e;return rl(o({type:"icon"},e),()=>(Zt("beforeDOMElementCreation",{iconDefinition:e,params:t}),Oe.autoA11y&&(r?u["aria-labelledby"]="".concat(Oe.replacementClass,"-title-").concat(s||Pe()):(u["aria-hidden"]="true",u["focusable"]="false")),ul({icons:{main:ml(m),mask:a?ml(a.icon):{found:!1,width:null,height:null,icon:{}}},prefix:f,iconName:p,transform:o(o({},De),l),symbol:n,title:r,maskId:c,titleId:s,extra:{attributes:u,styles:d,classes:i}})))};var en={mixout(){return{icon:Zl(Jl)}},hooks(){return{mutationObserverCallbacks(e){return e.treeCallback=Yl,e.nodeCallback=Ql,e}}},provides(e){e.i2svg=function(e){const{node:t=v,callback:l=()=>{}}=e;return Yl(t,l)},e.generateSvgReplacementMutation=function(e,t){const{iconName:l,title:n,titleId:a,prefix:o,transform:c,symbol:r,mask:s,maskId:i,extra:u}=t;return new Promise((t,d)=>{Promise.all([gl(l,o),s.iconName?gl(s.iconName,s.prefix):Promise.resolve({found:!1,width:512,height:512,icon:{}})]).then(s=>{let[d,f]=s;t([e,ul({icons:{main:d,mask:f},prefix:o,iconName:l,transform:c,symbol:r,maskId:i,title:n,titleId:a,extra:u,watchable:!0})])}).catch(d)})},e.generateAbstractIcon=function(e){let{children:t,attributes:l,main:n,transform:a,styles:o}=e;const c=Xe(o);let r;return c.length>0&&(l["style"]=c),Ue(a)&&(r=Jt("generateAbstractTransformGrouping",{main:n,transform:a,containerWidth:n.width,iconWidth:n.width})),t.push(r||n.icon),{children:t,attributes:l}}}},tn={mixout(){return{layer(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};const{classes:l=[]}=t;return rl({type:"layer"},()=>{Zt("beforeDOMElementCreation",{assembler:e,params:t});let n=[];return e(e=>{Array.isArray(e)?e.map(e=>{n=n.concat(e.abstract)}):n=n.concat(e.abstract)}),[{tag:"span",attributes:{class:["".concat(Oe.cssPrefix,"-layers"),...l].join(" ")},children:n}]})}}}},ln={mixout(){return{counter(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};const{title:l=null,classes:n=[],attributes:a={},styles:o={}}=t;return rl({type:"counter",content:e},()=>(Zt("beforeDOMElementCreation",{content:e,params:t}),fl({content:e.toString(),title:l,extra:{attributes:a,styles:o,classes:["".concat(Oe.cssPrefix,"-layers-counter"),...n]}})))}}}},nn={mixout(){return{text(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};const{transform:l=De,title:n=null,classes:a=[],attributes:c={},styles:r={}}=t;return rl({type:"text",content:e},()=>(Zt("beforeDOMElementCreation",{content:e,params:t}),dl({content:e,transform:o(o({},De),l),title:n,extra:{attributes:c,styles:r,classes:["".concat(Oe.cssPrefix,"-layers-text"),...a]}})))}}},provides(e){e.generateLayersText=function(e,t){const{title:l,transform:n,extra:a}=t;let o=null,c=null;if(y){const t=parseInt(getComputedStyle(e).fontSize,10),l=e.getBoundingClientRect();o=l.width/t,c=l.height/t}return Oe.autoA11y&&!l&&(a.attributes["aria-hidden"]="true"),Promise.resolve([e,dl({content:e.innerHTML,width:o,height:c,transform:n,title:l,extra:a,watchable:!0})])}}};const an=new RegExp('"',"ug"),on=[1105920,1112319],cn=o(o(o(o({},{FontAwesome:{normal:"fas",400:"fas"}}),N),ee),j),rn=Object.keys(cn).reduce((e,t)=>(e[t.toLowerCase()]=cn[t],e),{}),sn=Object.keys(rn).reduce((e,t)=>{const l=rn[t];return e[t]=l[900]||[...Object.entries(l)][0][1],e},{});function un(e){const t=e.replace(an,""),l=pt(t,0),n=l>=on[0]&&l<=on[1],a=2===t.length&&t[0]===t[1];return{value:ft(a?t[0]:t),isSecondary:n||a}}function dn(e,t){const l=e.replace(/^['"]|['"]$/g,"").toLowerCase(),n=parseInt(t),a=isNaN(n)?"normal":n;return(rn[l]||{})[a]||sn[l]}function fn(e,t){const l="".concat(re).concat(t.replace(":","-"));return new Promise((n,a)=>{if(null!==e.getAttribute(l))return n();const c=$e(e.children),r=c.filter(e=>e.getAttribute(ce)===t)[0],s=m.getComputedStyle(e,t),i=s.getPropertyValue("font-family"),u=i.match(Me),d=s.getPropertyValue("font-weight"),f=s.getPropertyValue("content");if(r&&!u)return e.removeChild(r),n();if(u&&"none"!==f&&""!==f){const c=s.getPropertyValue("content");let f=dn(i,d);const{value:p,isSecondary:m}=un(c),h=u[0].startsWith("FontAwesome");let g=Et(f,p),b=g;if(h){const e=Tt(p);e.iconName&&e.prefix&&(g=e.iconName,f=e.prefix)}if(!g||m||r&&r.getAttribute(se)===f&&r.getAttribute(ie)===b)n();else{e.setAttribute(l,b),r&&e.removeChild(r);const c=Kl(),{extra:s}=c;s.attributes[ce]=t,gl(g,f).then(a=>{const r=ul(o(o({},c),{},{icons:{main:a,mask:Wt()},prefix:f,iconName:b,extra:s,watchable:!0})),i=v.createElementNS("http://www.w3.org/2000/svg","svg");"::before"===t?e.insertBefore(i,e.firstChild):e.appendChild(i),i.outerHTML=r.map(e=>rt(e)).join("\n"),e.removeAttribute(l),n()}).catch(a)}}else n()})}function pn(e){return Promise.all([fn(e,"::before"),fn(e,"::after")])}function mn(e){return e.parentNode!==document.head&&!~fe.indexOf(e.tagName.toUpperCase())&&!e.getAttribute(ce)&&(!e.parentNode||"svg"!==e.parentNode.tagName)}function vn(e){if(b)return new Promise((t,l)=>{const n=$e(e.querySelectorAll("*")).filter(mn).map(pn),a=xl.begin("searchPseudoElements");Il(),Promise.all(n).then(()=>{a(),Dl(),t()}).catch(()=>{a(),Dl(),l()})})}var hn={hooks(){return{mutationObserverCallbacks(e){return e.pseudoElementsCallback=vn,e}}},provides(e){e.pseudoElements2svg=function(e){const{node:t=v}=e;Oe.searchPseudoElements&&vn(t)}}};let gn=!1;var bn={mixout(){return{dom:{unwatch(){Il(),gn=!0}}}},hooks(){return{bootstrap(){Vl(Qt("mutationObserverCallbacks",{}))},noAuto(){Pl()},watch(e){const{observeMutationsRoot:t}=e;gn?Dl():Vl(Qt("mutationObserverCallbacks",{observeMutationsRoot:t}))}}}};const yn=e=>{let t={size:16,x:0,y:0,flipX:!1,flipY:!1,rotate:0};return e.toLowerCase().split(" ").reduce((e,t)=>{const l=t.toLowerCase().split("-"),n=l[0];let a=l.slice(1).join("-");if(n&&"h"===a)return e.flipX=!0,e;if(n&&"v"===a)return e.flipY=!0,e;if(a=parseFloat(a),isNaN(a))return e;switch(n){case"grow":e.size=e.size+a;break;case"shrink":e.size=e.size-a;break;case"left":e.x=e.x-a;break;case"right":e.x=e.x+a;break;case"up":e.y=e.y-a;break;case"down":e.y=e.y+a;break;case"rotate":e.rotate=e.rotate+a;break}return e},t)};var Cn={mixout(){return{parse:{transform:e=>yn(e)}}},hooks(){return{parseNodeAttributes(e,t){const l=t.getAttribute("data-fa-transform");return l&&(e.transform=yn(l)),e}}},provides(e){e.generateAbstractTransformGrouping=function(e){let{main:t,transform:l,containerWidth:n,iconWidth:a}=e;const c={transform:"translate(".concat(n/2," 256)")},r="translate(".concat(32*l.x,", ").concat(32*l.y,") "),s="scale(".concat(l.size/16*(l.flipX?-1:1),", ").concat(l.size/16*(l.flipY?-1:1),") "),i="rotate(".concat(l.rotate," 0 0)"),u={transform:"".concat(r," ").concat(s," ").concat(i)},d={transform:"translate(".concat(a/2*-1," -256)")},f={outer:c,inner:u,path:d};return{tag:"g",attributes:o({},f.outer),children:[{tag:"g",attributes:o({},f.inner),children:[{tag:t.icon.tag,children:t.icon.children,attributes:o(o({},t.icon.attributes),f.path)}]}]}}}};const wn={x:0,y:0,width:"100%",height:"100%"};function Ln(e){let t=!(arguments.length>1&&void 0!==arguments[1])||arguments[1];return e.attributes&&(e.attributes.fill||t)&&(e.attributes.fill="black"),e}function xn(e){return"g"===e.tag?e.children:[e]}var Mn={hooks(){return{parseNodeAttributes(e,t){const l=t.getAttribute("data-fa-mask"),n=l?Vt(l.split(" ").map(e=>e.trim())):Wt();return n.prefix||(n.prefix=Ot()),e.mask=n,e.maskId=t.getAttribute("data-fa-mask-id"),e}}},provides(e){e.generateAbstractMask=function(e){let{children:t,attributes:l,main:n,mask:a,maskId:c,transform:r}=e;const{width:s,icon:i}=n,{width:u,icon:d}=a,f=qe({transform:r,containerWidth:u,iconWidth:s}),p={tag:"rect",attributes:o(o({},wn),{},{fill:"white"})},m=i.children?{children:i.children.map(Ln)}:{},v={tag:"g",attributes:o({},f.inner),children:[Ln(o({tag:i.tag,attributes:o(o({},i.attributes),f.path)},m))]},h={tag:"g",attributes:o({},f.outer),children:[v]},g="mask-".concat(c||Pe()),b="clip-".concat(c||Pe()),y={tag:"mask",attributes:o(o({},wn),{},{id:g,maskUnits:"userSpaceOnUse",maskContentUnits:"userSpaceOnUse"}),children:[p,h]},C={tag:"defs",children:[{tag:"clipPath",attributes:{id:b},children:xn(d)},y]};return t.push(C,{tag:"rect",attributes:o({fill:"currentColor","clip-path":"url(#".concat(b,")"),mask:"url(#".concat(g,")")},wn)}),{children:t,attributes:l}}}},zn={provides(e){let t=!1;m.matchMedia&&(t=m.matchMedia("(prefers-reduced-motion: reduce)").matches),e.missingIconAbstract=function(){const e=[],l={fill:"currentColor"},n={attributeType:"XML",repeatCount:"indefinite",dur:"2s"};e.push({tag:"path",attributes:o(o({},l),{},{d:"M156.5,447.7l-12.6,29.5c-18.7-9.5-35.9-21.2-51.5-34.9l22.7-22.7C127.6,430.5,141.5,440,156.5,447.7z M40.6,272H8.5 c1.4,21.2,5.4,41.7,11.7,61.1L50,321.2C45.1,305.5,41.8,289,40.6,272z M40.6,240c1.4-18.8,5.2-37,11.1-54.1l-29.5-12.6 C14.7,194.3,10,216.7,8.5,240H40.6z M64.3,156.5c7.8-14.9,17.2-28.8,28.1-41.5L69.7,92.3c-13.7,15.6-25.5,32.8-34.9,51.5 L64.3,156.5z M397,419.6c-13.9,12-29.4,22.3-46.1,30.4l11.9,29.8c20.7-9.9,39.8-22.6,56.9-37.6L397,419.6z M115,92.4 c13.9-12,29.4-22.3,46.1-30.4l-11.9-29.8c-20.7,9.9-39.8,22.6-56.8,37.6L115,92.4z M447.7,355.5c-7.8,14.9-17.2,28.8-28.1,41.5 l22.7,22.7c13.7-15.6,25.5-32.9,34.9-51.5L447.7,355.5z M471.4,272c-1.4,18.8-5.2,37-11.1,54.1l29.5,12.6 c7.5-21.1,12.2-43.5,13.6-66.8H471.4z M321.2,462c-15.7,5-32.2,8.2-49.2,9.4v32.1c21.2-1.4,41.7-5.4,61.1-11.7L321.2,462z M240,471.4c-18.8-1.4-37-5.2-54.1-11.1l-12.6,29.5c21.1,7.5,43.5,12.2,66.8,13.6V471.4z M462,190.8c5,15.7,8.2,32.2,9.4,49.2h32.1 c-1.4-21.2-5.4-41.7-11.7-61.1L462,190.8z M92.4,397c-12-13.9-22.3-29.4-30.4-46.1l-29.8,11.9c9.9,20.7,22.6,39.8,37.6,56.9 L92.4,397z M272,40.6c18.8,1.4,36.9,5.2,54.1,11.1l12.6-29.5C317.7,14.7,295.3,10,272,8.5V40.6z M190.8,50 c15.7-5,32.2-8.2,49.2-9.4V8.5c-21.2,1.4-41.7,5.4-61.1,11.7L190.8,50z M442.3,92.3L419.6,115c12,13.9,22.3,29.4,30.5,46.1 l29.8-11.9C470,128.5,457.3,109.4,442.3,92.3z M397,92.4l22.7-22.7c-15.6-13.7-32.8-25.5-51.5-34.9l-12.6,29.5 C370.4,72.1,384.4,81.5,397,92.4z"})});const a=o(o({},n),{},{attributeName:"opacity"}),c={tag:"circle",attributes:o(o({},l),{},{cx:"256",cy:"364",r:"28"}),children:[]};return t||c.children.push({tag:"animate",attributes:o(o({},n),{},{attributeName:"r",values:"28;14;28;28;14;28;"})},{tag:"animate",attributes:o(o({},a),{},{values:"1;0;1;1;0;1;"})}),e.push(c),e.push({tag:"path",attributes:o(o({},l),{},{opacity:"1",d:"M263.7,312h-16c-6.6,0-12-5.4-12-12c0-71,77.4-63.9,77.4-107.8c0-20-17.8-40.2-57.4-40.2c-29.1,0-44.3,9.6-59.2,28.7 c-3.9,5-11.1,6-16.2,2.4l-13.1-9.2c-5.6-3.9-6.9-11.8-2.6-17.2c21.2-27.2,46.4-44.7,91.2-44.7c52.3,0,97.4,29.8,97.4,80.2 c0,67.6-77.4,63.5-77.4,107.8C275.7,306.6,270.3,312,263.7,312z"}),children:t?[]:[{tag:"animate",attributes:o(o({},a),{},{values:"1;0;0;0;0;1;"})}]}),t||e.push({tag:"path",attributes:o(o({},l),{},{opacity:"0",d:"M232.5,134.5l7,168c0.3,6.4,5.6,11.5,12,11.5h9c6.4,0,11.7-5.1,12-11.5l7-168c0.3-6.8-5.2-12.5-12-12.5h-23 C237.7,122,232.2,127.7,232.5,134.5z"}),children:[{tag:"animate",attributes:o(o({},a),{},{values:"0;0;1;1;0;0;"})}]}),{tag:"g",attributes:{class:"missing"},children:e}}}},Rn={hooks(){return{parseNodeAttributes(e,t){const l=t.getAttribute("data-fa-symbol"),n=null!==l&&(""===l||l);return e["symbol"]=n,e}}}},kn=[et,en,tn,ln,nn,hn,bn,Cn,Mn,zn,Rn];Yt(kn,{mixoutsTo:ol});ol.noAuto;const Sn=ol.config,En=ol.library,An=(ol.dom,ol.parse),Nn=(ol.findIconDefinition,ol.toHtml,ol.icon),_n=(ol.layer,ol.text);ol.counter},8951:function(e,t,l){"use strict";l.d(t,{c:function(){return Le},i:function(){return ze},r:function(){return be}});l(8111),l(1701),l(4114),l(2489),l(116),l(7588),l(3110),l(7642),l(8004),l(3853),l(5876),l(2475),l(5024),l(1698),l(8237),l(8335);const n=new Set(["title","titleTemplate","script","style","noscript"]),a=new Set(["base","meta","link","style","script","noscript"]),o=new Set(["title","titleTemplate","templateParams","base","htmlAttrs","bodyAttrs","meta","link","style","script","noscript"]),c=new Set(["base","title","titleTemplate","bodyAttrs","htmlAttrs","templateParams"]),r=new Set(["tagPosition","tagPriority","tagDuplicateStrategy","children","innerHTML","textContent","processTemplateParams"]),s="undefined"!==typeof window;function i(e){return e}function u(e){let t=9;for(let l=0;l>>9)).toString(16).substring(1,8).toLowerCase()}function d(e){if(e._h)return e._h;if(e._d)return u(e._d);let t=`${e.tag}:${e.textContent||e.innerHTML||""}:`;for(const l in e.props)t+=`${l}:${String(e.props[l])},`;return u(t)}const f=e=>({keyValue:e,metaKey:"property"}),p=e=>({keyValue:e}),m=(f("article:expiration_time"),f("article:modified_time"),f("article:published_time"),f("book:release_date"),f("fb:app_id"),p("msapplication-Config"),p("msapplication-TileColor"),p("msapplication-TileImage"),f("og:audio:secure_url"),f("og:audio"),f("og:image:secure_url"),f("og:image"),f("og:site_name"),f("og:video:secure_url"),f("og:video"),f("profile:first_name"),f("profile:last_name"),f("profile:username"),new Set(["og","book","article","profile"]));function v(e){const t=e.replace(/([A-Z])/g,"-$1").toLowerCase(),l=t.indexOf("-"),n=t.substring(0,l);return"twitter"===n||m.has(n)?e.replace(/([A-Z])/g,":$1").toLowerCase():t}function h(e,t){return e instanceof Promise?e.then(t):t(e)}function g(e,t,l,a){const o=a||C("object"!==typeof t||"function"===typeof t||t instanceof Promise?{["script"===e||"noscript"===e||"style"===e?"innerHTML":"textContent"]:t}:{...t},"templateParams"===e||"titleTemplate"===e);if(o instanceof Promise)return o.then(n=>g(e,t,l,n));const c={tag:e,props:o};for(const s of r){const e=void 0!==c.props[s]?c.props[s]:l[s];void 0!==e&&(("innerHTML"!==s&&"textContent"!==s&&"children"!==s||n.has(c.tag))&&(c["children"===s?"innerHTML":s]=e),delete c.props[s])}return c.props.body&&(c.tagPosition="bodyClose",delete c.props.body),"script"===c.tag&&"object"===typeof c.innerHTML&&(c.innerHTML=JSON.stringify(c.innerHTML),c.props.type=c.props.type||"application/json"),Array.isArray(c.props.content)?c.props.content.map(e=>({...c,props:{...c.props,content:e}})):c}function b(e,t){const l="class"===e?" ":";";return t&&"object"===typeof t&&!Array.isArray(t)&&(t=Object.entries(t).filter(([,e])=>e).map(([t,l])=>"style"===e?`${t}:${l}`:t)),String(Array.isArray(t)?t.join(l):t)?.split(l).filter(e=>Boolean(e.trim())).join(l)}function y(e,t,l,n){for(let a=n;a(e[n]=o,y(e,t,l,a)));if(!t&&!r.has(n)){const t=String(e[n]),l=n.startsWith("data-");"true"===t||""===t?e[n]=!l||"true":e[n]||(l&&"false"===t?e[n]="false":delete e[n])}}else e[n]=b(n,e[n])}}function C(e,t=!1){const l=y(e,t,Object.keys(e),0);return l instanceof Promise?l.then(()=>e):e}const w=10;function L(e,t,l){for(let n=l;n(t[n]=l,L(e,t,n)));Array.isArray(l)?e.push(...l):e.push(l)}}function x(e){const t=[],l=e.resolvedInput;for(const a in l){if(!Object.prototype.hasOwnProperty.call(l,a))continue;const n=l[a];if(void 0!==n&&o.has(a))if(Array.isArray(n))for(const l of n)t.push(g(a,l,e));else t.push(g(a,n,e))}if(0===t.length)return[];const n=[];return h(L(n,t,0),()=>n.map((t,l)=>(t._e=e._i,e.mode&&(t._m=e.mode),t._p=(e._i<{if(e===N||!o.includes(e))return e;const l=_(t,e.slice(1),n);return void 0!==l?l:e}).trim(),c&&(e.endsWith(N)&&(e=e.slice(0,-N.length)),e.startsWith(N)&&(e=e.slice(N.length)),e=e.replace(T,l).trim()),e}function W(e,t){return null==e?t||null:"function"===typeof e?e(t):e}async function B(e,t={}){const l=t.document||e.resolvedOptions.document;if(!l||!e.dirty)return;const n={shouldRender:!0,tags:[]};return await e.hooks.callHook("dom:beforeRender",n),n.shouldRender?(e._domUpdatePromise||(e._domUpdatePromise=new Promise(async t=>{const n=(await e.resolveTags()).map(e=>({tag:e,id:a.has(e.tag)?d(e):e.tag,shouldRender:!0}));let o=e._dom;if(!o){o={elMap:{htmlAttrs:l.documentElement,bodyAttrs:l.body}};const e=new Set;for(const t of["body","head"]){const n=l[t]?.children;for(const t of n){const l=t.tagName.toLowerCase();if(!a.has(l))continue;const n={tag:l,props:await C(t.getAttributeNames().reduce((e,l)=>({...e,[l]:t.getAttribute(l)}),{})),innerHTML:t.innerHTML},c=A(n);let r=c,s=1;while(r&&e.has(r))r=`${c}:${s++}`;r&&(n._d=r,e.add(r)),o.elMap[t.getAttribute("data-hid")||d(n)]=t}}}function c(e,t,l){const n=`${e}:${t}`;o.sideEffects[n]=l,delete o.pendingSideEffects[n]}function r({id:e,$el:t,tag:n}){const a=n.tag.endsWith("Attrs");if(o.elMap[e]=t,a||(n.textContent&&n.textContent!==t.textContent&&(t.textContent=n.textContent),n.innerHTML&&n.innerHTML!==t.innerHTML&&(t.innerHTML=n.innerHTML),c(e,"el",()=>{o.elMap[e]?.remove(),delete o.elMap[e]})),n._eventHandlers)for(const o in n._eventHandlers)Object.prototype.hasOwnProperty.call(n._eventHandlers,o)&&""!==t.getAttribute(`data-${o}`)&&(("bodyAttrs"===n.tag?l.defaultView:t).addEventListener(o.substring(2),n._eventHandlers[o].bind(t)),t.setAttribute(`data-${o}`,""));for(const l in n.props){if(!Object.prototype.hasOwnProperty.call(n.props,l))continue;const o=n.props[l],r=`attr:${l}`;if("class"===l){if(!o)continue;for(const l of o.split(" "))a&&c(e,`${r}:${l}`,()=>t.classList.remove(l)),!t.classList.contains(l)&&t.classList.add(l)}else if("style"===l){if(!o)continue;for(const l of o.split(";")){const n=l.indexOf(":"),a=l.substring(0,n).trim(),o=l.substring(n+1).trim();c(e,`${r}:${a}`,()=>{t.style.removeProperty(a)}),t.style.setProperty(a,o)}}else t.getAttribute(l)!==o&&t.setAttribute(l,!0===o?"":String(o)),a&&c(e,r,()=>t.removeAttribute(l))}}o.pendingSideEffects={...o.sideEffects},o.sideEffects={};const s=[],i={bodyClose:void 0,bodyOpen:void 0,head:void 0};for(const e of n){const{tag:t,shouldRender:n,id:c}=e;n&&("title"!==t.tag?(e.$el=e.$el||o.elMap[c],e.$el?r(e):a.has(t.tag)&&s.push(e)):l.title=t.textContent)}for(const e of s){const t=e.tag.tagPosition||"head";e.$el=l.createElement(e.tag.tag),r(e),i[t]=i[t]||l.createDocumentFragment(),i[t].appendChild(e.$el)}for(const a of n)await e.hooks.callHook("dom:renderTag",a,l,c);i.head&&l.head.appendChild(i.head),i.bodyOpen&&l.body.insertBefore(i.bodyOpen,l.body.firstChild),i.bodyClose&&l.body.appendChild(i.bodyClose);for(const e in o.pendingSideEffects)o.pendingSideEffects[e]();e._dom=o,await e.hooks.callHook("dom:rendered",{renders:n}),t()}).finally(()=>{e._domUpdatePromise=void 0,e.dirty=!1})),e._domUpdatePromise):void 0}function I(e,t={}){const l=t.delayFn||(e=>setTimeout(e,10));return e._domDebouncedUpdatePromise=e._domDebouncedUpdatePromise||new Promise(n=>l(()=>B(e,t).then(()=>{delete e._domDebouncedUpdatePromise,n()})))}function D(e){return i(t=>{const l=t.resolvedOptions.document?.head.querySelector('script[id="unhead:payload"]')?.innerHTML||!1;return l&&t.push(JSON.parse(l)),{mode:"client",hooks:{"entries:updated":t=>{I(t,e)}}}})}function F(e,t={},l){for(const n in e){const a=e[n],o=l?`${l}:${n}`:n;"object"===typeof a&&null!==a?F(a,t,o):"function"===typeof a&&(t[o]=a)}return t}const V={run:e=>e()},P=()=>V,$="undefined"!==typeof console.createTask?console.createTask:P;function H(e,t){const l=t.shift(),n=$(l);return e.reduce((e,l)=>e.then(()=>n.run(()=>l(...t))),Promise.resolve())}function j(e,t){const l=t.shift(),n=$(l);return Promise.all(e.map(e=>n.run(()=>e(...t))))}function K(e,t){for(const l of[...e])l(t)}class X{constructor(){this._hooks={},this._before=void 0,this._after=void 0,this._deprecatedMessages=void 0,this._deprecatedHooks={},this.hook=this.hook.bind(this),this.callHook=this.callHook.bind(this),this.callHookWith=this.callHookWith.bind(this)}hook(e,t,l={}){if(!e||"function"!==typeof t)return()=>{};const n=e;let a;while(this._deprecatedHooks[e])a=this._deprecatedHooks[e],e=a.to;if(a&&!l.allowDeprecated){let e=a.message;e||(e=`${n} hook has been deprecated`+(a.to?`, please use ${a.to}`:"")),this._deprecatedMessages||(this._deprecatedMessages=new Set),this._deprecatedMessages.has(e)||(console.warn(e),this._deprecatedMessages.add(e))}if(!t.name)try{Object.defineProperty(t,"name",{get:()=>"_"+e.replace(/\W+/g,"_")+"_hook_cb",configurable:!0})}catch{}return this._hooks[e]=this._hooks[e]||[],this._hooks[e].push(t),()=>{t&&(this.removeHook(e,t),t=void 0)}}hookOnce(e,t){let l,n=(...e)=>("function"===typeof l&&l(),l=void 0,n=void 0,t(...e));return l=this.hook(e,n),l}removeHook(e,t){if(this._hooks[e]){const l=this._hooks[e].indexOf(t);-1!==l&&this._hooks[e].splice(l,1),0===this._hooks[e].length&&delete this._hooks[e]}}deprecateHook(e,t){this._deprecatedHooks[e]="string"===typeof t?{to:t}:t;const l=this._hooks[e]||[];delete this._hooks[e];for(const n of l)this.hook(e,n)}deprecateHooks(e){Object.assign(this._deprecatedHooks,e);for(const t in e)this.deprecateHook(t,e[t])}addHooks(e){const t=F(e),l=Object.keys(t).map(e=>this.hook(e,t[e]));return()=>{for(const e of l.splice(0,l.length))e()}}removeHooks(e){const t=F(e);for(const l in t)this.removeHook(l,t[l])}removeAllHooks(){for(const e in this._hooks)delete this._hooks[e]}callHook(e,...t){return t.unshift(e),this.callHookWith(H,e,...t)}callHookParallel(e,...t){return t.unshift(e),this.callHookWith(j,e,...t)}callHookWith(e,t,...l){const n=this._before||this._after?{name:t,args:l,context:{}}:void 0;this._before&&K(this._before,n);const a=e(t in this._hooks?[...this._hooks[t]]:[],l);return a instanceof Promise?a.finally(()=>{this._after&&n&&K(this._after,n)}):(this._after&&n&&K(this._after,n),a)}beforeEach(e){return this._before=this._before||[],this._before.push(e),()=>{if(void 0!==this._before){const t=this._before.indexOf(e);-1!==t&&this._before.splice(t,1)}}}afterEach(e){return this._after=this._after||[],this._after.push(e),()=>{if(void 0!==this._after){const t=this._after.indexOf(e);-1!==t&&this._after.splice(t,1)}}}}function U(){return new X}const q=new Set(["templateParams","htmlAttrs","bodyAttrs"]),G=i({hooks:{"tag:normalise":({tag:e})=>{e.props.hid&&(e.key=e.props.hid,delete e.props.hid),e.props.vmid&&(e.key=e.props.vmid,delete e.props.vmid),e.props.key&&(e.key=e.props.key,delete e.props.key);const t=A(e);!t||t.startsWith("meta:og:")||t.startsWith("meta:twitter:")||delete e.key;const l=t||!!e.key&&`${e.tag}:${e.key}`;l&&(e._d=l)},"tags:resolve":e=>{const t=Object.create(null);for(const n of e.tags){const e=(n.key?`${n.tag}:${n.key}`:n._d)||d(n),l=t[e];if(l){let a=n?.tagDuplicateStrategy;if(!a&&q.has(n.tag)&&(a="merge"),"merge"===a){const a=l.props;a.style&&n.props.style&&(";"!==a.style[a.style.length-1]&&(a.style+=";"),n.props.style=`${a.style} ${n.props.style}`),a.class&&n.props.class?n.props.class=`${a.class} ${n.props.class}`:a.class&&(n.props.class=a.class),t[e].props={...a,...n.props};continue}if(n._e===l._e){l._duped=l._duped||[],n._d=`${l._d}:${l._duped.length+1}`,l._duped.push(n);continue}if(k(n)>k(l))continue}const o=n.innerHTML||n.textContent||0!==Object.keys(n.props).length;o||!a.has(n.tag)?t[e]=n:delete t[e]}const l=[];for(const n in t){const e=t[n],a=e._duped;l.push(e),a&&(delete e._duped,l.push(...a))}e.tags=l,e.tags=e.tags.filter(e=>!("meta"===e.tag&&(e.props.name||e.props.property)&&!e.props.content))}}}),Y=new Set(["script","link","bodyAttrs"]),Q=i(e=>({hooks:{"tags:resolve":t=>{for(const l of t.tags){if(!Y.has(l.tag))continue;const t=l.props;for(const n in t){if("o"!==n[0]||"n"!==n[1])continue;if(!Object.prototype.hasOwnProperty.call(t,n))continue;const a=t[n];"function"===typeof a&&(e.ssr&&M.has(n)?t[n]=`this.dataset.${n}fired = true`:delete t[n],l._eventHandlers=l._eventHandlers||{},l._eventHandlers[n]=a)}e.ssr&&l._eventHandlers&&(l.props.src||l.props.href)&&(l.key=l.key||u(l.props.src||l.props.href))}},"dom:renderTag":({$el:e,tag:t})=>{const l=e?.dataset;if(l)for(const n in l){if(!n.endsWith("fired"))continue;const l=n.slice(0,-5);M.has(l)&&t._eventHandlers?.[l]?.call(e,new Event(l.substring(2)))}}}})),Z=new Set(["link","style","script","noscript"]),J=i({hooks:{"tag:normalise":({tag:e})=>{e.key&&Z.has(e.tag)&&(e.props["data-hid"]=e._h=u(e.key))}}}),ee=i({mode:"server",hooks:{"tags:beforeResolve":e=>{const t={};let l=!1;for(const n of e.tags)"server"!==n._m||"titleTemplate"!==n.tag&&"templateParams"!==n.tag&&"title"!==n.tag||(t[n.tag]="title"===n.tag||"titleTemplate"===n.tag?n.textContent:n.props,l=!0);l&&e.tags.push({tag:"script",innerHTML:JSON.stringify(t),props:{id:"unhead:payload",type:"application/json"}})}}}),te=i({hooks:{"tags:resolve":e=>{for(const t of e.tags)if("string"===typeof t.tagPriority)for(const{prefix:l,offset:n}of S){if(!t.tagPriority.startsWith(l))continue;const a=t.tagPriority.substring(l.length),o=e.tags.find(e=>e._d===a)?._p;if(void 0!==o){t._p=o+n;break}}e.tags.sort((e,t)=>{const l=k(e),n=k(t);return ln?1:e._p-t._p})}}}),le={meta:"content",link:"href",htmlAttrs:"lang"},ne=["innerHTML","textContent"],ae=i(e=>({hooks:{"tags:resolve":t=>{const{tags:l}=t;let n;for(let e=0;e"title"===e.tag)?.textContent||"",a,o);for(const e of l){if(!1===e.processTemplateParams)continue;const t=le[e.tag];if(t&&"string"===typeof e.props[t])e.props[t]=O(e.props[t],a,o);else if(e.processTemplateParams||"titleTemplate"===e.tag||"title"===e.tag)for(const l of ne)"string"===typeof e[l]&&(e[l]=O(e[l],a,o,"script"===e.tag&&e.props.type.endsWith("json")))}e._templateParams=a,e._separator=o},"tags:afterResolve":({tags:t})=>{let l;for(let e=0;e{const{tags:t}=e;let l,n;for(let a=0;a{for(const t of e.tags)"string"===typeof t.innerHTML&&(!t.innerHTML||"application/ld+json"!==t.props.type&&"application/json"!==t.props.type?t.innerHTML=t.innerHTML.replace(new RegExp(`{r.dirty=!0,t.callHook("entries:updated",r)};let a=0,o=[];const c=[],r={plugins:c,dirty:!1,resolvedOptions:e,hooks:t,headEntries(){return o},use(e){const n="function"===typeof e?e(r):e;n.key&&c.some(e=>e.key===n.key)||(c.push(n),ie(n.mode,l)&&t.addHooks(n.hooks||{}))},push(e,t){delete t?.head;const c={_i:a++,input:e,...t};return ie(c.mode,l)&&(o.push(c),n()),{dispose(){o=o.filter(e=>e._i!==c._i),n()},patch(e){for(const t of o)t._i===c._i&&(t.input=c.input=e);n()}}},async resolveTags(){const e={tags:[],entries:[...o]};await t.callHook("entries:resolve",e);for(const l of e.entries){const n=l.resolvedInput||l.input;if(l.resolvedInput=await(l.transform?l.transform(n):n),l.resolvedInput)for(const a of await x(l)){const n={tag:a,entry:l,resolvedOptions:r.resolvedOptions};await t.callHook("tag:normalise",n),e.tags.push(n.tag)}}return await t.callHook("tags:beforeResolve",e),await t.callHook("tags:resolve",e),await t.callHook("tags:afterResolve",e),e.tags},ssr:l};return[G,ee,Q,J,te,ae,oe,ce,...e?.plugins||[]].forEach(e=>r.use(e)),r.hooks.callHook("init",r),r}function de(){return re}const fe=Symbol("ScriptProxyTarget");function pe(){}pe[fe]=!0;var me=l(6768),ve=l(144);const he="3"===me.rE[0];function ge(e){return"function"===typeof e?e():(0,ve.R1)(e)}function be(e){if(e instanceof Promise||e instanceof Date||e instanceof RegExp)return e;const t=ge(e);if(!e||!t)return t;if(Array.isArray(t))return t.map(e=>be(e));if("object"===typeof t){const e={};for(const l in t)Object.prototype.hasOwnProperty.call(t,l)&&("titleTemplate"===l||"o"===l[0]&&"n"===l[1]?e[l]=(0,ve.R1)(t[l]):e[l]=be(t[l]));return e}return t}const ye=i({hooks:{"entries:resolve":e=>{for(const t of e.entries)t.resolvedInput=be(t.input)}}}),Ce="usehead";function we(e){const t={install(t){he&&(t.config.globalProperties.$unhead=e,t.config.globalProperties.$head=e,t.provide(Ce,e))}};return t.install}function Le(e={}){e.domDelayFn=e.domDelayFn||(e=>(0,me.dY)(()=>setTimeout(()=>e(),0)));const t=se(e);return t.use(ye),t.install=we(t),t}const xe="undefined"!==typeof globalThis?globalThis:"undefined"!==typeof window?window:"undefined"!==typeof l.g?l.g:"undefined"!==typeof self?self:{},Me="__unhead_injection_handler__";function ze(){if(Me in xe)return xe[Me]();const e=(0,me.WQ)(Ce);return e||de()}},8981:function(e,t,l){"use strict";var n=l(7750),a=Object;e.exports=function(e){return a(n(e))}},9039:function(e){"use strict";e.exports=function(e){try{return!!e()}catch(t){return!0}}},9077:function(e,t,l){"use strict";l.d(t,{A:function(){return n}});var n=(e,t)=>{const l=e.__vccOpts||e;for(const[n,a]of t)l[n]=a;return l}},9078:function(e,t,l){"use strict";var n=l(3939);function a(e){var t=new e.constructor(e.byteLength);return new n.A(t).set(new n.A(e)),t}t.A=a},9092:function(e,t,l){"use strict";var n=l(9314),a=(0,n.A)(Object.getPrototypeOf,Object);t.A=a},9112:function(e,t,l){"use strict";var n=l(6518),a=l(3724),o=l(4576),c=l(7751),r=l(9504),s=l(9565),i=l(4901),u=l(34),d=l(4376),f=l(9297),p=l(655),m=l(6198),v=l(4659),h=l(9039),g=l(8235),b=l(4495),y=o.JSON,C=o.Number,w=o.SyntaxError,L=y&&y.parse,x=c("Object","keys"),M=Object.getOwnPropertyDescriptor,z=r("".charAt),R=r("".slice),k=r(/./.exec),S=r([].push),E=/^\d$/,A=/^[1-9]$/,N=/^[\d-]$/,_=/^[\t\n\r ]$/,T=0,O=1,W=function(e,t){e=p(e);var l=new F(e,0,""),n=l.parse(),a=n.value,o=l.skip(_,n.end);if(o`element-loading-${(0,o.Tg)(e)}`,s=(e,t)=>{var l,s,i,d;const f=t.instance,p=e=>(0,o.Gv)(t.value)?t.value[e]:void 0,m=e=>{const t=(0,o.Kg)(e)&&(null==f?void 0:f[e])||e;return(0,n.KR)(t)},v=t=>m(p(t)||e.getAttribute(r(t))),h=null!=(l=p("fullscreen"))?l:t.modifiers.fullscreen,g={text:v("text"),svg:v("svg"),svgViewBox:v("svgViewBox"),spinner:v("spinner"),background:v("background"),customClass:v("customClass"),fullscreen:h,target:null!=(s=p("target"))?s:h?void 0:e,body:null!=(i=p("body"))?i:t.modifiers.body,lock:null!=(d=p("lock"))?d:t.modifiers.lock},b=(0,a.A)(g);b._context=u._context,e[c]={options:g,instance:b}},i=(e,t)=>{for(const l of Object.keys(e))(0,n.i9)(e[l])&&(e[l].value=t[l])},u={mounted(e,t){t.value&&s(e,t)},updated(e,t){const l=e[c];if(!t.value)return null==l||l.instance.close(),void(e[c]=null);l?i(l.options,(0,o.Gv)(t.value)?t.value:{text:e.getAttribute(r("text")),svg:e.getAttribute(r("svg")),svgViewBox:e.getAttribute(r("svgViewBox")),spinner:e.getAttribute(r("spinner")),background:e.getAttribute(r("background")),customClass:e.getAttribute(r("customClass"))}):s(e,t)},unmounted(e){var t;null==(t=e[c])||t.instance.close(),e[c]=null},_context:null}},9143:function(e,t,l){"use strict";var n=l(4576),a=l(9504),o=l(3972),c=l(3463),r=l(9297),s=l(2804),i=l(944),u=l(5169),d=s.c2i,f=s.c2iUrl,p=n.SyntaxError,m=n.TypeError,v=a("".charAt),h=function(e,t){for(var l=e.length;t>16&255,a>>8&255,255&a];if(2===n){if(l&&0!==o[1])throw new p("Extra bits");return[o[0]]}if(3===n){if(l&&0!==o[2])throw new p("Extra bits");return[o[0],o[1]]}return o},b=function(e,t,l){for(var n=t.length,a=0;a0){if("stop-before-partial"===s)break;if("loose"!==s)throw new p("Missing padding");if(1===x.length)throw new p("Malformed padding: exactly one additional character");w=b(C,g(x,a,!1),w)}L=y;break}var z=v(e,M);if(++M,"="===z){if(x.length<2)throw new p("Padding is too early");if(M=h(e,M),2===x.length){if(M===y){if("stop-before-partial"===s)break;throw new p("Malformed padding: only one =")}"="===v(e,M)&&(++M,M=h(e,M))}if(M(e=(0,r.Tn)(e)?e():e,(0,r.cy)(e)?e.every(e=>!e):!e)}}),m=(e,t)=>{const l=(0,n.nI)()?(0,n.WQ)(i,(0,a.KR)({})):(0,a.KR)({}),c=(0,n.EW)(()=>e.emptyValues||l.value.emptyValues||d),p=(0,n.EW)(()=>(0,r.Tn)(e.valueOnClear)?e.valueOnClear():void 0!==e.valueOnClear?e.valueOnClear:(0,r.Tn)(l.value.valueOnClear)?l.value.valueOnClear():void 0!==l.value.valueOnClear?l.value.valueOnClear:void 0!==t?t:f),m=e=>{let t=!0;return t=(0,r.cy)(e)?c.value.some(t=>(0,o.A)(e,t)):c.value.includes(e),t};return m(p.value)||(0,s.U)(u,"value-on-clear should be a value of empty-values"),{emptyValues:c,valueOnClear:p,isEmptyValue:m}}},9195:function(e,t,l){"use strict";var n=l(7179);function a(e,t){return(0,n.A)(e,t)}t.A=a},9225:function(e,t,l){"use strict";var n,a,o,c,r=l(4576),s=l(8745),i=l(6080),u=l(4901),d=l(9297),f=l(9039),p=l(397),m=l(7680),v=l(4055),h=l(2812),g=l(9544),b=l(6193),y=r.setImmediate,C=r.clearImmediate,w=r.process,L=r.Dispatch,x=r.Function,M=r.MessageChannel,z=r.String,R=0,k={},S="onreadystatechange";f(function(){n=r.location});var E=function(e){if(d(k,e)){var t=k[e];delete k[e],t()}},A=function(e){return function(){E(e)}},N=function(e){E(e.data)},_=function(e){r.postMessage(z(e),n.protocol+"//"+n.host)};y&&C||(y=function(e){h(arguments.length,1);var t=u(e)?e:x(e),l=m(arguments,1);return k[++R]=function(){s(t,void 0,l)},a(R),R},C=function(e){delete k[e]},b?a=function(e){w.nextTick(A(e))}:L&&L.now?a=function(e){L.now(A(e))}:M&&!g?(o=new M,c=o.port2,o.port1.onmessage=N,a=i(c.postMessage,c)):r.addEventListener&&u(r.postMessage)&&!r.importScripts&&n&&"file:"!==n.protocol&&!f(_)?(a=_,r.addEventListener("message",N,!1)):a=S in v("script")?function(e){p.appendChild(v("script"))[S]=function(){p.removeChild(this),E(e)}}:function(e){setTimeout(A(e),0)}),e.exports={set:y,clear:C}},9267:function(e,t,l){"use strict";l.d(t,{kZ:function(){return N}});var n=l(6768),a=l(144),o=l(5130),c=l(4232),r=l(6714),s=l(6834),i=l(8769),u=l(813),d=l(8724),f=l(5513),p=l(9077),m=l(3291),v=l(7833),h=l(464),g=l(4425),b=l(6268);const y=(0,n.pM)({name:"ElDialogContent"}),C=(0,n.pM)({...y,props:f.Q,emits:f.k,setup(e,{expose:t}){const l=e,{t:o}=(0,b.Ym)(),{Close:r}=h.H2,{dialogRef:s,headerRef:i,bodyId:f,ns:p,style:y}=(0,n.WQ)(d.Z),{focusTrapRef:C}=(0,n.WQ)(m.r3),w=(0,g.t)(C,s),L=(0,n.EW)(()=>!!l.draggable),x=(0,n.EW)(()=>!!l.overflow),{resetPosition:M,updatePosition:z,isDragging:R}=(0,v.P)(s,i,L,x),k=(0,n.EW)(()=>[p.b(),p.is("fullscreen",l.fullscreen),p.is("draggable",L.value),p.is("dragging",R.value),p.is("align-center",!!l.alignCenter),{[p.m("center")]:l.center}]);return t({resetPosition:M,updatePosition:z}),(e,t)=>((0,n.uX)(),(0,n.CE)("div",{ref:(0,a.R1)(w),class:(0,c.C4)((0,a.R1)(k)),style:(0,c.Tr)((0,a.R1)(y)),tabindex:"-1"},[(0,n.Lk)("header",{ref_key:"headerRef",ref:i,class:(0,c.C4)([(0,a.R1)(p).e("header"),e.headerClass,{"show-close":e.showClose}])},[(0,n.RG)(e.$slots,"header",{},()=>[(0,n.Lk)("span",{role:"heading","aria-level":e.ariaLevel,class:(0,c.C4)((0,a.R1)(p).e("title"))},(0,c.v_)(e.title),11,["aria-level"])]),e.showClose?((0,n.uX)(),(0,n.CE)("button",{key:0,"aria-label":(0,a.R1)(o)("el.dialog.close"),class:(0,c.C4)((0,a.R1)(p).e("headerbtn")),type:"button",onClick:t=>e.$emit("close")},[(0,n.bF)((0,a.R1)(u.tk),{class:(0,c.C4)((0,a.R1)(p).e("close"))},{default:(0,n.k6)(()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)(e.closeIcon||(0,a.R1)(r))))]),_:1},8,["class"])],10,["aria-label","onClick"])):(0,n.Q3)("v-if",!0)],2),(0,n.Lk)("div",{id:(0,a.R1)(f),class:(0,c.C4)([(0,a.R1)(p).e("body"),e.bodyClass])},[(0,n.RG)(e.$slots,"default")],10,["id"]),e.$slots.footer?((0,n.uX)(),(0,n.CE)("footer",{key:0,class:(0,c.C4)([(0,a.R1)(p).e("footer"),e.footerClass])},[(0,n.RG)(e.$slots,"footer")],2)):(0,n.Q3)("v-if",!0)],6))}});var w=(0,p.A)(C,[["__file","dialog-content.vue"]]),L=l(7201),x=l(3711),M=l(261),z=l(3513),R=l(1968);const k=(0,n.pM)({name:"ElDialog",inheritAttrs:!1}),S=(0,n.pM)({...k,props:L.z5,emits:L.Pg,setup(e,{expose:t}){const l=e,u=(0,n.Ht)();(0,M.b)({scope:"el-dialog",from:"the title slot",replacement:"the header slot",version:"3.0.0",ref:"https://element-plus.org/en-US/component/dialog.html#slots"},(0,n.EW)(()=>!!u.title));const f=(0,z.DU)("dialog"),p=(0,a.KR)(),m=(0,a.KR)(),v=(0,a.KR)(),{visible:h,titleId:g,bodyId:b,style:y,overlayDialogStyle:C,rendered:L,transitionConfig:k,zIndex:S,_draggable:E,_alignCenter:A,_overflow:N,handleClose:_,onModalClick:T,onOpenAutoFocus:O,onCloseAutoFocus:W,onCloseRequested:B,onFocusoutPrevented:I}=(0,x.s)(l,p);(0,n.Gt)(d.Z,{dialogRef:p,headerRef:m,bodyId:b,ns:f,rendered:L,style:y});const D=(0,R.r)(T),F=(0,n.EW)(()=>l.modalPenetrable&&!l.modal&&!l.fullscreen),V=()=>{var e;null==(e=v.value)||e.resetPosition()};return t({visible:h,dialogContentRef:v,resetPosition:V,handleClose:_}),(e,t)=>((0,n.uX)(),(0,n.Wv)((0,a.R1)(i.Nr),{to:e.appendTo,disabled:"body"===e.appendTo&&!e.appendToBody},{default:(0,n.k6)(()=>[(0,n.bF)(o.eB,(0,n.v6)((0,a.R1)(k),{persisted:""}),{default:(0,n.k6)(()=>{var t;return[(0,n.bo)((0,n.bF)((0,a.R1)(r._q),{"custom-mask-event":"",mask:e.modal,"overlay-class":[null!=(t=e.modalClass)?t:"",`${(0,a.R1)(f).namespace.value}-modal-dialog`,(0,a.R1)(f).is("penetrable",(0,a.R1)(F))],"z-index":(0,a.R1)(S)},{default:(0,n.k6)(()=>[(0,n.Lk)("div",{role:"dialog","aria-modal":"true","aria-label":e.title||void 0,"aria-labelledby":e.title?void 0:(0,a.R1)(g),"aria-describedby":(0,a.R1)(b),class:(0,c.C4)(`${(0,a.R1)(f).namespace.value}-overlay-dialog`),style:(0,c.Tr)((0,a.R1)(C)),onClick:(0,a.R1)(D).onClick,onMousedown:(0,a.R1)(D).onMousedown,onMouseup:(0,a.R1)(D).onMouseup},[(0,n.bF)((0,a.R1)(s.A),{loop:"",trapped:(0,a.R1)(h),"focus-start-el":"container",onFocusAfterTrapped:(0,a.R1)(O),onFocusAfterReleased:(0,a.R1)(W),onFocusoutPrevented:(0,a.R1)(I),onReleaseRequested:(0,a.R1)(B)},{default:(0,n.k6)(()=>[(0,a.R1)(L)?((0,n.uX)(),(0,n.Wv)(w,(0,n.v6)({key:0,ref_key:"dialogContentRef",ref:v},e.$attrs,{center:e.center,"align-center":(0,a.R1)(A),"close-icon":e.closeIcon,draggable:(0,a.R1)(E),overflow:(0,a.R1)(N),fullscreen:e.fullscreen,"header-class":e.headerClass,"body-class":e.bodyClass,"footer-class":e.footerClass,"show-close":e.showClose,title:e.title,"aria-level":e.headerAriaLevel,onClose:(0,a.R1)(_)}),(0,n.eX)({header:(0,n.k6)(()=>[e.$slots.title?(0,n.RG)(e.$slots,"title",{key:1}):(0,n.RG)(e.$slots,"header",{key:0,close:(0,a.R1)(_),titleId:(0,a.R1)(g),titleClass:(0,a.R1)(f).e("title")})]),default:(0,n.k6)(()=>[(0,n.RG)(e.$slots,"default")]),_:2},[e.$slots.footer?{name:"footer",fn:(0,n.k6)(()=>[(0,n.RG)(e.$slots,"footer")])}:void 0]),1040,["center","align-center","close-icon","draggable","overflow","fullscreen","header-class","body-class","footer-class","show-close","title","aria-level","onClose"])):(0,n.Q3)("v-if",!0)]),_:3},8,["trapped","onFocusAfterTrapped","onFocusAfterReleased","onFocusoutPrevented","onReleaseRequested"])],46,["aria-label","aria-labelledby","aria-describedby","onClick","onMousedown","onMouseup"])]),_:3},8,["mask","overlay-class","z-index"]),[[o.aG,(0,a.R1)(h)]])]}),_:3},16)]),_:3},8,["to","disabled"]))}});var E=(0,p.A)(S,[["__file","dialog.vue"]]),A=l(5376);const N=(0,A.GU)(E)},9286:function(e,t,l){"use strict";var n=l(4402),a=l(8469),o=n.Set,c=n.add;e.exports=function(e){var t=new o;return a(e,function(e){c(t,e)}),t}},9297:function(e,t,l){"use strict";var n=l(9504),a=l(8981),o=n({}.hasOwnProperty);e.exports=Object.hasOwn||function(e,t){return o(a(e),t)}},9306:function(e,t,l){"use strict";var n=l(4901),a=l(6823),o=TypeError;e.exports=function(e){if(n(e))return e;throw new o(a(e)+" is not a function")}},9309:function(e,t,l){"use strict";var n=l(6518),a=l(4576),o=l(9225).set,c=l(9472),r=a.setImmediate?c(o,!1):o;n({global:!0,bind:!0,enumerable:!0,forced:a.setImmediate!==r},{setImmediate:r})},9314:function(e,t){"use strict";function l(e,t){return function(l){return e(t(l))}}t.A=l},9429:function(e,t,l){"use strict";var n=l(4576),a=l(6193);e.exports=function(e){if(a){try{return n.process.getBuiltinModule(e)}catch(t){}try{return Function('return require("'+e+'")')()}catch(t){}}}},9433:function(e,t,l){"use strict";var n=l(4576),a=Object.defineProperty;e.exports=function(e,t){try{a(n,e,{value:t,configurable:!0,writable:!0})}catch(l){n[e]=t}return t}},9436:function(e,t,l){"use strict";l(5331)},9462:function(e,t,l){"use strict";var n=l(9565),a=l(2360),o=l(6699),c=l(6279),r=l(8227),s=l(1181),i=l(5966),u=l(7657).IteratorPrototype,d=l(2529),f=l(9539),p=l(1385),m=r("toStringTag"),v="IteratorHelper",h="WrapForValidIterator",g="normal",b="throw",y=s.set,C=function(e){var t=s.getterFor(e?h:v);return c(a(u),{next:function(){var l=t(this);if(e)return l.nextHandler();if(l.done)return d(void 0,!0);try{var n=l.nextHandler();return l.returnHandlerResult?n:d(n,l.done)}catch(a){throw l.done=!0,a}},return:function(){var l=t(this),a=l.iterator;if(l.done=!0,e){var o=i(a,"return");return o?n(o,a):d(void 0,!0)}if(l.inner)try{f(l.inner.iterator,g)}catch(c){return f(a,b,c)}if(l.openIters)try{p(l.openIters,g)}catch(c){return f(a,b,c)}return a&&f(a,g),d(void 0,!0)}})},w=C(!0),L=C(!1);o(L,m,"Iterator Helper"),e.exports=function(e,t,l){var n=function(n,a){a?(a.iterator=n.iterator,a.next=n.next):a=n,a.type=t?h:v,a.returnHandlerResult=!!l,a.nextHandler=e,a.counter=0,a.done=!1,y(this,a)};return n.prototype=t?w:L,n}},9472:function(e,t,l){"use strict";var n=l(4576),a=l(8745),o=l(4901),c=l(4215),r=l(2839),s=l(7680),i=l(2812),u=n.Function,d=/MSIE .\./.test(r)||"BUN"===c&&function(){var e=n.Bun.version.split(".");return e.length<3||"0"===e[0]&&(e[1]<3||"3"===e[1]&&"0"===e[2])}();e.exports=function(e,t){var l=t?2:1;return d?function(n,c){var r=i(arguments.length,1)>l,d=o(n)?n:u(n),f=r?s(arguments,l):[],p=r?function(){a(d,this,f)}:d;return t?e(p,c):e(p)}:e}},9486:function(e,t,l){"use strict";var n=l(6518),a=l(4576),o=l(9504),c=l(3972),r=l(4154),s=l(5169),i=l(2804),u=l(944),d=i.i2c,f=i.i2cUrl,p=o("".charAt),m=a.Uint8Array,v=!m||!m.prototype.toBase64||!function(){try{var e=new m;e.toBase64(null)}catch(t){return!0}}();m&&n({target:"Uint8Array",proto:!0,forced:v},{toBase64:function(){var e=r(this),t=arguments.length?c(arguments[0]):void 0,l="base64"===u(t)?d:f,n=!!t&&!!t.omitPadding;s(this.buffer);for(var a,o="",i=0,m=e.length,v=function(e){return p(l,a>>6*e&63)};i+20&&n[0]<4?1:+(n[0]+n[1])),!a&&c&&(n=c.match(/Edge\/(\d+)/),(!n||n[1]>=74)&&(n=c.match(/Chrome\/(\d+)/),n&&(a=+n[1]))),e.exports=a},9539:function(e,t,l){"use strict";var n=l(9565),a=l(8551),o=l(5966);e.exports=function(e,t,l){var c,r;a(e);try{if(c=o(e,"return"),!c){if("throw"===t)throw l;return l}c=n(c,e)}catch(s){r=!0,c=s}if("throw"===t)throw l;if(r)throw c;return a(c),l}},9544:function(e,t,l){"use strict";var n=l(2839);e.exports=/(?:ipad|iphone|ipod).*applewebkit/i.test(n)},9559:function(e,t,l){"use strict";l.d(t,{KR:function(){return w}});var n=l(6768),a=l(144),o=l(5130),c=l(4232),r=l(813),s=l(464),i=l(7378),u=l(4340);const d=["light","dark"],f=(0,i.b_)({title:{type:String,default:""},description:{type:String,default:""},type:{type:String,values:(0,u.YD)(s.rz),default:"info"},closable:{type:Boolean,default:!0},closeText:{type:String,default:""},showIcon:Boolean,center:Boolean,effect:{type:String,values:d,default:"light"},showAfter:Number,hideAfter:Number,autoClose:Number}),p={close:e=>e instanceof MouseEvent};var m=l(9077),v=l(3513),h=l(6894);const g=(0,n.pM)({name:"ElAlert"}),b=(0,n.pM)({...g,props:f,emits:p,setup(e,{emit:t}){const l=e,{Close:i}=s.Nk,u=(0,n.Ht)(),d=(0,v.DU)("alert"),f=(0,a.KR)(!0),p=(0,n.EW)(()=>s.rz[l.type]),m=(0,n.EW)(()=>!(!l.description&&!u.default)),g=e=>{f.value=!1,t("close",e)};return(l.showAfter||l.hideAfter||l.autoClose)&&(0,h.U)("el-alert","The `show-after`, `hide-after`, and `auto-close` attributes were removed after 2.11.8. Please use `v-if` and `v-show` to manually replace them, visit: https://github.com/element-plus/element-plus/pull/22560"),(e,t)=>((0,n.uX)(),(0,n.Wv)(o.eB,{name:(0,a.R1)(d).b("fade"),persisted:""},{default:(0,n.k6)(()=>[(0,n.bo)((0,n.Lk)("div",{class:(0,c.C4)([(0,a.R1)(d).b(),(0,a.R1)(d).m(e.type),(0,a.R1)(d).is("center",e.center),(0,a.R1)(d).is(e.effect)]),role:"alert"},[e.showIcon&&(e.$slots.icon||(0,a.R1)(p))?((0,n.uX)(),(0,n.Wv)((0,a.R1)(r.tk),{key:0,class:(0,c.C4)([(0,a.R1)(d).e("icon"),(0,a.R1)(d).is("big",(0,a.R1)(m))])},{default:(0,n.k6)(()=>[(0,n.RG)(e.$slots,"icon",{},()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)((0,a.R1)(p))))])]),_:3},8,["class"])):(0,n.Q3)("v-if",!0),(0,n.Lk)("div",{class:(0,c.C4)((0,a.R1)(d).e("content"))},[e.title||e.$slots.title?((0,n.uX)(),(0,n.CE)("span",{key:0,class:(0,c.C4)([(0,a.R1)(d).e("title"),{"with-description":(0,a.R1)(m)}])},[(0,n.RG)(e.$slots,"title",{},()=>[(0,n.eW)((0,c.v_)(e.title),1)])],2)):(0,n.Q3)("v-if",!0),(0,a.R1)(m)?((0,n.uX)(),(0,n.CE)("p",{key:1,class:(0,c.C4)((0,a.R1)(d).e("description"))},[(0,n.RG)(e.$slots,"default",{},()=>[(0,n.eW)((0,c.v_)(e.description),1)])],2)):(0,n.Q3)("v-if",!0),e.closable?((0,n.uX)(),(0,n.CE)(n.FK,{key:2},[e.closeText?((0,n.uX)(),(0,n.CE)("div",{key:0,class:(0,c.C4)([(0,a.R1)(d).e("close-btn"),(0,a.R1)(d).is("customed")]),onClick:g},(0,c.v_)(e.closeText),3)):((0,n.uX)(),(0,n.Wv)((0,a.R1)(r.tk),{key:1,class:(0,c.C4)((0,a.R1)(d).e("close-btn")),onClick:g},{default:(0,n.k6)(()=>[(0,n.bF)((0,a.R1)(i))]),_:1},8,["class"]))],64)):(0,n.Q3)("v-if",!0)],2)],2),[[o.aG,f.value]])]),_:3},8,["name"]))}});var y=(0,m.A)(b,[["__file","alert.vue"]]),C=l(5376);const w=(0,C.GU)(y)},9565:function(e,t,l){"use strict";var n=l(616),a=Function.prototype.call;e.exports=n?a.bind(a):function(){return a.apply(a,arguments)}},9577:function(e,t,l){"use strict";var n=l(9928),a=l(4644),o=l(1108),c=l(1291),r=l(5854),s=a.aTypedArray,i=a.getTypedArrayConstructor,u=a.exportTypedArrayMethod,d=function(){try{new Int8Array(1)["with"](2,{valueOf:function(){throw 8}})}catch(e){return 8===e}}(),f=d&&function(){try{new Int8Array(1)["with"](-.5,1)}catch(e){return!0}}();u("with",{with:function(e,t){var l=s(this),a=c(e),u=o(l)?r(t):+t;return n(l,i(l),a,u)}}["with"],!d||f)},9578:function(e,t,l){"use strict";var n=l(339),a="object"==typeof self&&self&&self.Object===Object&&self,o=n.A||a||Function("return this")();t.A=o},9606:function(e,t){"use strict";function l(e,t){var l=-1,n=e.length;t||(t=Array(n));while(++lu)if(i=r[u++],i!==i)return!0}else for(;s>u;u++)if((e||u in r)&&r[u]===l)return e||u||0;return!e&&-1}};e.exports={includes:c(!0),indexOf:c(!1)}},9623:function(e,t,l){"use strict";l.d(t,{WK:function(){return I}});var n=l(6768),a=l(144),o=l(4232),c=l(5130),r=l(7687),s=l(17),i=l(6032),u=l(813),d=l(7477),f=(l(8111),l(7588),l(2808)),p=l(2235);let m;const v={height:"0",visibility:"hidden",overflow:(0,f.gm)()?"":"hidden",position:"absolute","z-index":"-1000",top:"0",right:"0"},h=["letter-spacing","line-height","padding-top","padding-bottom","font-family","font-weight","font-size","text-rendering","text-transform","width","text-indent","padding-left","padding-right","border-width","box-sizing","word-break"],g=e=>{const t=Number.parseFloat(e);return Number.isNaN(t)?e:t};function b(e){const t=window.getComputedStyle(e),l=t.getPropertyValue("box-sizing"),n=Number.parseFloat(t.getPropertyValue("padding-bottom"))+Number.parseFloat(t.getPropertyValue("padding-top")),a=Number.parseFloat(t.getPropertyValue("border-bottom-width"))+Number.parseFloat(t.getPropertyValue("border-top-width")),o=h.map(e=>[e,t.getPropertyValue(e)]);return{contextStyle:o,paddingSize:n,borderSize:a,boxSizing:l}}function y(e,t=1,l){var n,a;m||(m=document.createElement("textarea"),(null!=(n=e.parentNode)?n:document.body).appendChild(m));const{paddingSize:o,borderSize:c,boxSizing:r,contextStyle:s}=b(e);s.forEach(([e,t])=>null==m?void 0:m.style.setProperty(e,t)),Object.entries(v).forEach(([e,t])=>null==m?void 0:m.style.setProperty(e,t,"important")),m.value=e.value||e.placeholder||"";let i=m.scrollHeight;const u={};"border-box"===r?i+=c:"content-box"===r&&(i-=o),m.value="";const d=m.scrollHeight-o;if((0,p.Et)(t)){let e=d*t;"border-box"===r&&(e=e+o+c),i=Math.max(e,i),u.minHeight=`${e}px`}if((0,p.Et)(l)){let e=d*l;"border-box"===r&&(e=e+o+c),i=Math.min(e,i)}return u.height=`${i}px`,null==(a=m.parentNode)||a.removeChild(m),m=void 0,u}var C=l(6149),w=l(9077),L=l(3716),x=l(4216),M=l(2436),z=l(1939),R=l(464),k=l(5488),S=l(2056);function E(e){let t;function l(){if(void 0==e.value)return;const{selectionStart:l,selectionEnd:n,value:a}=e.value;if(null==l||null==n)return;const o=a.slice(0,Math.max(0,l)),c=a.slice(Math.max(0,n));t={selectionStart:l,selectionEnd:n,value:a,beforeTxt:o,afterTxt:c}}function n(){if(void 0==e.value||void 0==t)return;const{value:l}=e.value,{beforeTxt:n,afterTxt:a,selectionStart:o}=t;if(void 0==n||void 0==a||void 0==o)return;let c=l.length;if(l.endsWith(a))c=l.length-a.length;else if(l.startsWith(n))c=n.length;else{const e=n[o-1],t=l.indexOf(e,o-1);-1!==t&&(c=t+1)}e.value.setSelectionRange(c,c)}return[l,n]}var A=l(3513),N=l(6894);const _="ElInput",T=(0,n.pM)({name:_,inheritAttrs:!1}),O=(0,n.pM)({...T,props:C.$,emits:C.p,setup(e,{expose:t,emit:l}){const f=e,p=(0,n.OA)(),m=(0,L.O)(),v=(0,n.Ht)(),h=(0,n.EW)(()=>["textarea"===f.type?I.b():B.b(),B.m(O.value),B.is("disabled",W.value),B.is("exceed",ce.value),{[B.b("group")]:v.prepend||v.append,[B.m("prefix")]:v.prefix||f.prefixIcon,[B.m("suffix")]:v.suffix||f.suffixIcon||f.clearable||f.showPassword,[B.bm("suffix","password-clear")]:le.value&&ne.value,[B.b("hidden")]:"hidden"===f.type},p.class]),b=(0,n.EW)(()=>[B.e("wrapper"),B.is("focus",X.value)]),{form:C,formItem:w}=(0,x.j)(),{inputId:T}=(0,x.W)(f,{formItemContext:w}),O=(0,M.NV)(),W=(0,M.CB)(),B=(0,A.DU)("input"),I=(0,A.DU)("textarea"),D=(0,a.IJ)(),F=(0,a.IJ)(),V=(0,a.KR)(!1),P=(0,a.KR)(!1),$=(0,a.KR)(),H=(0,a.IJ)(f.inputStyle),j=(0,n.EW)(()=>D.value||F.value),{wrapperRef:K,isFocused:X,handleFocus:U,handleBlur:q}=(0,z.K)(j,{disabled:W,afterBlur(){var e;f.validateEvent&&(null==(e=null==w?void 0:w.validate)||e.call(w,"blur").catch(e=>(0,N.U)(e)))}}),G=(0,n.EW)(()=>{var e;return null!=(e=null==C?void 0:C.statusIcon)&&e}),Y=(0,n.EW)(()=>(null==w?void 0:w.validateState)||""),Q=(0,n.EW)(()=>Y.value&&R.vK[Y.value]),Z=(0,n.EW)(()=>P.value?d.View:d.Hide),J=(0,n.EW)(()=>[p.style]),ee=(0,n.EW)(()=>[f.inputStyle,H.value,{resize:f.resize}]),te=(0,n.EW)(()=>(0,i.A)(f.modelValue)?"":String(f.modelValue)),le=(0,n.EW)(()=>f.clearable&&!W.value&&!f.readonly&&!!te.value&&(X.value||V.value)),ne=(0,n.EW)(()=>f.showPassword&&!W.value&&!!te.value),ae=(0,n.EW)(()=>f.showWordLimit&&!!f.maxlength&&("text"===f.type||"textarea"===f.type)&&!W.value&&!f.readonly&&!f.showPassword),oe=(0,n.EW)(()=>te.value.length),ce=(0,n.EW)(()=>!!ae.value&&oe.value>Number(f.maxlength)),re=(0,n.EW)(()=>!!v.suffix||!!f.suffixIcon||le.value||f.showPassword||ae.value||!!Y.value&&G.value),se=(0,n.EW)(()=>!!Object.keys(f.modelModifiers).length),[ie,ue]=E(D);(0,r.wYm)(F,e=>{if(pe(),!ae.value||"both"!==f.resize&&"horizontal"!==f.resize)return;const t=e[0],{width:l}=t.contentRect;$.value={right:`calc(100% - ${l+22-10}px)`}});const de=()=>{const{type:e,autosize:t}=f;if(s.oc&&"textarea"===e&&F.value)if(t){const e=(0,o.Gv)(t)?t.minRows:void 0,l=(0,o.Gv)(t)?t.maxRows:void 0,a=y(F.value,e,l);H.value={overflowY:"hidden",...a},(0,n.dY)(()=>{F.value.offsetHeight,H.value=a})}else H.value={minHeight:y(F.value).minHeight}},fe=e=>{let t=!1;return()=>{var l;if(t||!f.autosize)return;const n=null===(null==(l=F.value)?void 0:l.offsetParent);n||(setTimeout(e),t=!0)}},pe=fe(de),me=()=>{const e=j.value,t=f.formatter?f.formatter(te.value):te.value;e&&e.value!==t&&"file"!==f.type&&(e.value=t)},ve=e=>{const{trim:t,number:l}=f.modelModifiers;return t&&(e=e.trim()),l&&(e=`${g(e)}`),f.formatter&&f.parser&&(e=f.parser(e)),e},he=async e=>{if(be.value)return;const{lazy:t}=f.modelModifiers;let{value:a}=e.target;t?l(S.qs,a):(a=ve(a),String(a)!==te.value?(ie(),l(S.l4,a),l(S.qs,a),await(0,n.dY)(),(f.formatter&&f.parser||!se.value)&&me(),ue()):f.formatter&&me())},ge=async e=>{let{value:t}=e.target;t=ve(t),f.modelModifiers.lazy&&l(S.l4,t),l(S.YU,t,e),await(0,n.dY)(),me()},{isComposing:be,handleCompositionStart:ye,handleCompositionUpdate:Ce,handleCompositionEnd:we}=(0,k.o)({emit:l,afterComposition:he}),Le=()=>{P.value=!P.value},xe=()=>{var e;return null==(e=j.value)?void 0:e.focus()},Me=()=>{var e;return null==(e=j.value)?void 0:e.blur()},ze=e=>{V.value=!1,l("mouseleave",e)},Re=e=>{V.value=!0,l("mouseenter",e)},ke=e=>{l("keydown",e)},Se=()=>{var e;null==(e=j.value)||e.select()},Ee=()=>{l(S.l4,""),l(S.YU,""),l("clear"),l(S.qs,"")};return(0,n.wB)(()=>f.modelValue,()=>{var e;(0,n.dY)(()=>de()),f.validateEvent&&(null==(e=null==w?void 0:w.validate)||e.call(w,"change").catch(e=>(0,N.U)(e)))}),(0,n.wB)(te,e=>{if(!j.value)return;const{trim:t,number:l}=f.modelModifiers,n=j.value.value,a=!l&&"number"!==f.type||/^0\d/.test(n)?n:`${g(n)}`;a!==e&&(document.activeElement===j.value&&"range"!==j.value.type&&t&&a.trim()===e||me())}),(0,n.wB)(()=>f.type,async()=>{await(0,n.dY)(),me(),de()}),(0,n.sV)(()=>{!f.formatter&&f.parser&&(0,N.U)(_,"If you set the parser, you also need to set the formatter."),me(),(0,n.dY)(de)}),t({input:D,textarea:F,ref:j,textareaStyle:ee,autosize:(0,a.lW)(f,"autosize"),isComposing:be,focus:xe,blur:Me,select:Se,clear:Ee,resizeTextarea:de}),(e,t)=>((0,n.uX)(),(0,n.CE)("div",{class:(0,o.C4)([(0,a.R1)(h),{[(0,a.R1)(B).bm("group","append")]:e.$slots.append,[(0,a.R1)(B).bm("group","prepend")]:e.$slots.prepend}]),style:(0,o.Tr)((0,a.R1)(J)),onMouseenter:Re,onMouseleave:ze},[(0,n.Q3)(" input "),"textarea"!==e.type?((0,n.uX)(),(0,n.CE)(n.FK,{key:0},[(0,n.Q3)(" prepend slot "),e.$slots.prepend?((0,n.uX)(),(0,n.CE)("div",{key:0,class:(0,o.C4)((0,a.R1)(B).be("group","prepend"))},[(0,n.RG)(e.$slots,"prepend")],2)):(0,n.Q3)("v-if",!0),(0,n.Lk)("div",{ref_key:"wrapperRef",ref:K,class:(0,o.C4)((0,a.R1)(b))},[(0,n.Q3)(" prefix slot "),e.$slots.prefix||e.prefixIcon?((0,n.uX)(),(0,n.CE)("span",{key:0,class:(0,o.C4)((0,a.R1)(B).e("prefix"))},[(0,n.Lk)("span",{class:(0,o.C4)((0,a.R1)(B).e("prefix-inner"))},[(0,n.RG)(e.$slots,"prefix"),e.prefixIcon?((0,n.uX)(),(0,n.Wv)((0,a.R1)(u.tk),{key:0,class:(0,o.C4)((0,a.R1)(B).e("icon"))},{default:(0,n.k6)(()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)(e.prefixIcon)))]),_:1},8,["class"])):(0,n.Q3)("v-if",!0)],2)],2)):(0,n.Q3)("v-if",!0),(0,n.Lk)("input",(0,n.v6)({id:(0,a.R1)(T),ref_key:"input",ref:D,class:(0,a.R1)(B).e("inner")},(0,a.R1)(m),{name:e.name,minlength:e.minlength,maxlength:e.maxlength,type:e.showPassword?P.value?"text":"password":e.type,disabled:(0,a.R1)(W),readonly:e.readonly,autocomplete:e.autocomplete,tabindex:e.tabindex,"aria-label":e.ariaLabel,placeholder:e.placeholder,style:e.inputStyle,form:e.form,autofocus:e.autofocus,role:e.containerRole,inputmode:e.inputmode,onCompositionstart:(0,a.R1)(ye),onCompositionupdate:(0,a.R1)(Ce),onCompositionend:(0,a.R1)(we),onInput:he,onChange:ge,onKeydown:ke}),null,16,["id","name","minlength","maxlength","type","disabled","readonly","autocomplete","tabindex","aria-label","placeholder","form","autofocus","role","inputmode","onCompositionstart","onCompositionupdate","onCompositionend"]),(0,n.Q3)(" suffix slot "),(0,a.R1)(re)?((0,n.uX)(),(0,n.CE)("span",{key:1,class:(0,o.C4)((0,a.R1)(B).e("suffix"))},[(0,n.Lk)("span",{class:(0,o.C4)((0,a.R1)(B).e("suffix-inner"))},[(0,a.R1)(le)&&(0,a.R1)(ne)&&(0,a.R1)(ae)?(0,n.Q3)("v-if",!0):((0,n.uX)(),(0,n.CE)(n.FK,{key:0},[(0,n.RG)(e.$slots,"suffix"),e.suffixIcon?((0,n.uX)(),(0,n.Wv)((0,a.R1)(u.tk),{key:0,class:(0,o.C4)((0,a.R1)(B).e("icon"))},{default:(0,n.k6)(()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)(e.suffixIcon)))]),_:1},8,["class"])):(0,n.Q3)("v-if",!0)],64)),(0,a.R1)(le)?((0,n.uX)(),(0,n.Wv)((0,a.R1)(u.tk),{key:1,class:(0,o.C4)([(0,a.R1)(B).e("icon"),(0,a.R1)(B).e("clear")]),onMousedown:(0,c.D$)((0,a.R1)(o.tE),["prevent"]),onClick:Ee},{default:(0,n.k6)(()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)(e.clearIcon)))]),_:1},8,["class","onMousedown"])):(0,n.Q3)("v-if",!0),(0,a.R1)(ne)?((0,n.uX)(),(0,n.Wv)((0,a.R1)(u.tk),{key:2,class:(0,o.C4)([(0,a.R1)(B).e("icon"),(0,a.R1)(B).e("password")]),onClick:Le,onMousedown:(0,c.D$)((0,a.R1)(o.tE),["prevent"]),onMouseup:(0,c.D$)((0,a.R1)(o.tE),["prevent"])},{default:(0,n.k6)(()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)((0,a.R1)(Z))))]),_:1},8,["class","onMousedown","onMouseup"])):(0,n.Q3)("v-if",!0),(0,a.R1)(ae)?((0,n.uX)(),(0,n.CE)("span",{key:3,class:(0,o.C4)([(0,a.R1)(B).e("count"),(0,a.R1)(B).is("outside","outside"===e.wordLimitPosition)])},[(0,n.Lk)("span",{class:(0,o.C4)((0,a.R1)(B).e("count-inner"))},(0,o.v_)((0,a.R1)(oe))+" / "+(0,o.v_)(e.maxlength),3)],2)):(0,n.Q3)("v-if",!0),(0,a.R1)(Y)&&(0,a.R1)(Q)&&(0,a.R1)(G)?((0,n.uX)(),(0,n.Wv)((0,a.R1)(u.tk),{key:4,class:(0,o.C4)([(0,a.R1)(B).e("icon"),(0,a.R1)(B).e("validateIcon"),(0,a.R1)(B).is("loading","validating"===(0,a.R1)(Y))])},{default:(0,n.k6)(()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)((0,a.R1)(Q))))]),_:1},8,["class"])):(0,n.Q3)("v-if",!0)],2)],2)):(0,n.Q3)("v-if",!0)],2),(0,n.Q3)(" append slot "),e.$slots.append?((0,n.uX)(),(0,n.CE)("div",{key:1,class:(0,o.C4)((0,a.R1)(B).be("group","append"))},[(0,n.RG)(e.$slots,"append")],2)):(0,n.Q3)("v-if",!0)],64)):((0,n.uX)(),(0,n.CE)(n.FK,{key:1},[(0,n.Q3)(" textarea "),(0,n.Lk)("textarea",(0,n.v6)({id:(0,a.R1)(T),ref_key:"textarea",ref:F,class:[(0,a.R1)(I).e("inner"),(0,a.R1)(B).is("focus",(0,a.R1)(X))]},(0,a.R1)(m),{name:e.name,minlength:e.minlength,maxlength:e.maxlength,tabindex:e.tabindex,disabled:(0,a.R1)(W),readonly:e.readonly,autocomplete:e.autocomplete,style:(0,a.R1)(ee),"aria-label":e.ariaLabel,placeholder:e.placeholder,form:e.form,autofocus:e.autofocus,rows:e.rows,role:e.containerRole,onCompositionstart:(0,a.R1)(ye),onCompositionupdate:(0,a.R1)(Ce),onCompositionend:(0,a.R1)(we),onInput:he,onFocus:(0,a.R1)(U),onBlur:(0,a.R1)(q),onChange:ge,onKeydown:ke}),null,16,["id","name","minlength","maxlength","tabindex","disabled","readonly","autocomplete","aria-label","placeholder","form","autofocus","rows","role","onCompositionstart","onCompositionupdate","onCompositionend","onFocus","onBlur"]),(0,a.R1)(ae)?((0,n.uX)(),(0,n.CE)("span",{key:0,style:(0,o.Tr)($.value),class:(0,o.C4)([(0,a.R1)(B).e("count"),(0,a.R1)(B).is("outside","outside"===e.wordLimitPosition)])},(0,o.v_)((0,a.R1)(oe))+" / "+(0,o.v_)(e.maxlength),7)):(0,n.Q3)("v-if",!0)],64))],38))}});var W=(0,w.A)(O,[["__file","input.vue"]]),B=l(5376);const I=(0,B.GU)(W)},9631:function(e,t,l){"use strict";l(9486)},9646:function(e,t,l){"use strict";var n=l(339),a="object"==typeof exports&&exports&&!exports.nodeType&&exports,o=a&&"object"==typeof module&&module&&!module.nodeType&&module,c=o&&o.exports===a,r=c&&n.A.process,s=function(){try{var e=o&&o.require&&o.require("util").types;return e||r&&r.binding&&r.binding("util")}catch(t){}}();t.A=s},9648:function(e,t,l){"use strict";l(5331)},9655:function(e,t,l){"use strict";l.d(t,{ve:function(){return h}});l(8111),l(1701);var n=l(6768),a=l(4232),o=l(144),c=l(813),r=l(7477),s=l(7378);const i=(0,s.b_)({type:{type:String,default:"line",values:["line","circle","dashboard"]},percentage:{type:Number,default:0,validator:e=>e>=0&&e<=100},status:{type:String,default:"",values:["","success","exception","warning"]},indeterminate:Boolean,duration:{type:Number,default:3},strokeWidth:{type:Number,default:6},strokeLinecap:{type:(0,s.jq)(String),default:"round"},textInside:Boolean,width:{type:Number,default:126},showText:{type:Boolean,default:!0},color:{type:(0,s.jq)([String,Array,Function]),default:""},striped:Boolean,stripedFlow:Boolean,format:{type:(0,s.jq)(Function),default:e=>`${e}%`}});var u=l(9077),d=l(3513);const f=(0,n.pM)({name:"ElProgress"}),p=(0,n.pM)({...f,props:i,setup(e){const t=e,l={success:"#13ce66",exception:"#ff4949",warning:"#e6a23c",default:"#20a0ff"},s=(0,d.DU)("progress"),i=(0,n.EW)(()=>{const e={width:`${t.percentage}%`,animationDuration:`${t.duration}s`},l=M(t.percentage);return l.includes("gradient")?e.background=l:e.backgroundColor=l,e}),u=(0,n.EW)(()=>(t.strokeWidth/t.width*100).toFixed(1)),f=(0,n.EW)(()=>["circle","dashboard"].includes(t.type)?Number.parseInt(""+(50-Number.parseFloat(u.value)/2),10):0),p=(0,n.EW)(()=>{const e=f.value,l="dashboard"===t.type;return`\n M 50 50\n m 0 ${l?"":"-"}${e}\n a ${e} ${e} 0 1 1 0 ${l?"-":""}${2*e}\n a ${e} ${e} 0 1 1 0 ${l?"":"-"}${2*e}\n `}),m=(0,n.EW)(()=>2*Math.PI*f.value),v=(0,n.EW)(()=>"dashboard"===t.type?.75:1),h=(0,n.EW)(()=>{const e=-1*m.value*(1-v.value)/2;return`${e}px`}),g=(0,n.EW)(()=>({strokeDasharray:`${m.value*v.value}px, ${m.value}px`,strokeDashoffset:h.value})),b=(0,n.EW)(()=>({strokeDasharray:`${m.value*v.value*(t.percentage/100)}px, ${m.value}px`,strokeDashoffset:h.value,transition:"stroke-dasharray 0.6s ease 0s, stroke 0.6s ease, opacity ease 0.6s"})),y=(0,n.EW)(()=>{let e;return e=t.color?M(t.percentage):l[t.status]||l.default,e}),C=(0,n.EW)(()=>"warning"===t.status?r.WarningFilled:"line"===t.type?"success"===t.status?r.CircleCheck:r.CircleClose:"success"===t.status?r.Check:r.Close),w=(0,n.EW)(()=>"line"===t.type?12+.4*t.strokeWidth:.111111*t.width+2),L=(0,n.EW)(()=>t.format(t.percentage));function x(e){const t=100/e.length,l=e.map((e,l)=>(0,a.Kg)(e)?{color:e,percentage:(l+1)*t}:e);return l.sort((e,t)=>e.percentage-t.percentage)}const M=e=>{var l;const{color:n}=t;if((0,a.Tn)(n))return n(e);if((0,a.Kg)(n))return n;{const t=x(n);for(const l of t)if(l.percentage>e)return l.color;return null==(l=t[t.length-1])?void 0:l.color}};return(e,t)=>((0,n.uX)(),(0,n.CE)("div",{class:(0,a.C4)([(0,o.R1)(s).b(),(0,o.R1)(s).m(e.type),(0,o.R1)(s).is(e.status),{[(0,o.R1)(s).m("without-text")]:!e.showText,[(0,o.R1)(s).m("text-inside")]:e.textInside}]),role:"progressbar","aria-valuenow":e.percentage,"aria-valuemin":"0","aria-valuemax":"100"},["line"===e.type?((0,n.uX)(),(0,n.CE)("div",{key:0,class:(0,a.C4)((0,o.R1)(s).b("bar"))},[(0,n.Lk)("div",{class:(0,a.C4)((0,o.R1)(s).be("bar","outer")),style:(0,a.Tr)({height:`${e.strokeWidth}px`})},[(0,n.Lk)("div",{class:(0,a.C4)([(0,o.R1)(s).be("bar","inner"),{[(0,o.R1)(s).bem("bar","inner","indeterminate")]:e.indeterminate},{[(0,o.R1)(s).bem("bar","inner","striped")]:e.striped},{[(0,o.R1)(s).bem("bar","inner","striped-flow")]:e.stripedFlow}]),style:(0,a.Tr)((0,o.R1)(i))},[(e.showText||e.$slots.default)&&e.textInside?((0,n.uX)(),(0,n.CE)("div",{key:0,class:(0,a.C4)((0,o.R1)(s).be("bar","innerText"))},[(0,n.RG)(e.$slots,"default",{percentage:e.percentage},()=>[(0,n.Lk)("span",null,(0,a.v_)((0,o.R1)(L)),1)])],2)):(0,n.Q3)("v-if",!0)],6)],6)],2)):((0,n.uX)(),(0,n.CE)("div",{key:1,class:(0,a.C4)((0,o.R1)(s).b("circle")),style:(0,a.Tr)({height:`${e.width}px`,width:`${e.width}px`})},[((0,n.uX)(),(0,n.CE)("svg",{viewBox:"0 0 100 100"},[(0,n.Lk)("path",{class:(0,a.C4)((0,o.R1)(s).be("circle","track")),d:(0,o.R1)(p),stroke:`var(${(0,o.R1)(s).cssVarName("fill-color-light")}, #e5e9f2)`,"stroke-linecap":e.strokeLinecap,"stroke-width":(0,o.R1)(u),fill:"none",style:(0,a.Tr)((0,o.R1)(g))},null,14,["d","stroke","stroke-linecap","stroke-width"]),(0,n.Lk)("path",{class:(0,a.C4)((0,o.R1)(s).be("circle","path")),d:(0,o.R1)(p),stroke:(0,o.R1)(y),fill:"none",opacity:e.percentage?1:0,"stroke-linecap":e.strokeLinecap,"stroke-width":(0,o.R1)(u),style:(0,a.Tr)((0,o.R1)(b))},null,14,["d","stroke","opacity","stroke-linecap","stroke-width"])]))],6)),!e.showText&&!e.$slots.default||e.textInside?(0,n.Q3)("v-if",!0):((0,n.uX)(),(0,n.CE)("div",{key:2,class:(0,a.C4)((0,o.R1)(s).e("text")),style:(0,a.Tr)({fontSize:`${(0,o.R1)(w)}px`})},[(0,n.RG)(e.$slots,"default",{percentage:e.percentage},()=>[e.status?((0,n.uX)(),(0,n.Wv)((0,o.R1)(c.tk),{key:1},{default:(0,n.k6)(()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)((0,o.R1)(C))))]),_:1})):((0,n.uX)(),(0,n.CE)("span",{key:0},(0,a.v_)((0,o.R1)(L)),1))])],6))],10,["aria-valuenow"]))}});var m=(0,u.A)(p,[["__file","progress.vue"]]),v=l(5376);const h=(0,v.GU)(m)},9759:function(e,t){"use strict";function l(e,t){return e.has(t)}t.A=l},9797:function(e,t,l){"use strict";l(4226)},9825:function(e,t,l){"use strict";l.d(t,{b:function(){return c},f:function(){return r}});var n=l(7378),a=l(8501),o=l(2235);const c=(0,n.b_)({distance:{type:Number,default:0},height:{type:[String,Number],default:""},maxHeight:{type:[String,Number],default:""},native:Boolean,wrapStyle:{type:(0,n.jq)([String,Object,Array]),default:""},wrapClass:{type:[String,Array],default:""},viewClass:{type:[String,Array],default:""},viewStyle:{type:[String,Array,Object],default:""},noresize:Boolean,tag:{type:String,default:"div"},always:Boolean,minSize:{type:Number,default:20},tabindex:{type:[String,Number],default:void 0},id:String,role:String,...(0,a.l)(["ariaLabel","ariaOrientation"])}),r={"end-reached":e=>["left","right","top","bottom"].includes(e),scroll:({scrollTop:e,scrollLeft:t})=>[e,t].every(o.Et)}},9835:function(e){"use strict";e.exports=function(e){try{var t=new Set,l={size:0,has:function(){return!0},keys:function(){return Object.defineProperty({},"next",{get:function(){return t.clear(),t.add(4),function(){return{done:!0}}}})}},n=t[e](l);return 1===n.size&&4===n.values().next().value}catch(a){return!1}}},9848:function(e,t,l){"use strict";l(6368),l(9309)},9869:function(e,t,l){"use strict";l.d(t,{TS:function(){return E},MF:function(){return A}});l(4114),l(8111),l(2489),l(7588);var n=l(6768),a=l(4232),o=l(144),c=(l(1701),l(6032));const r=Symbol("elDescriptions");var s=l(6139),i=l(3558),u=l(3513),d=(0,n.pM)({name:"ElDescriptionsCell",props:{cell:{type:Object},tag:{type:String,default:"td"},type:{type:String}},setup(){const e=(0,n.WQ)(r,{});return{descriptions:e}},render(){var e,t,l,a;const o=(0,s.oh)(this.cell),r=((null==(e=this.cell)?void 0:e.dirs)||[]).map(e=>{const{dir:t,arg:l,modifiers:n,value:a}=e;return[t,a,l,n]}),{border:d,direction:f}=this.descriptions,p="vertical"===f,m=()=>{var e,t,l;return(null==(l=null==(t=null==(e=this.cell)?void 0:e.children)?void 0:t.label)?void 0:l.call(t))||o.label},v=()=>{var e,t,l;return null==(l=null==(t=null==(e=this.cell)?void 0:e.children)?void 0:t.default)?void 0:l.call(t)},h=o.span,g=o.rowspan,b=o.align?`is-${o.align}`:"",y=o.labelAlign?`is-${o.labelAlign}`:b,C=o.className,w=o.labelClassName,L="label"===this.type&&null!=(l=null!=(t=o.labelWidth)?t:this.descriptions.labelWidth)?l:o.width,x={width:(0,i._V)(L),minWidth:(0,i._V)(o.minWidth)},M=(0,u.DU)("descriptions");switch(this.type){case"label":return(0,n.bo)((0,n.h)(this.tag,{style:x,class:[M.e("cell"),M.e("label"),M.is("bordered-label",d),M.is("vertical-label",p),y,w],colSpan:p?h:1,rowspan:p?1:g},m()),r);case"content":return(0,n.bo)((0,n.h)(this.tag,{style:x,class:[M.e("cell"),M.e("content"),M.is("bordered-content",d),M.is("vertical-content",p),b,C],colSpan:p?h:2*h-1,rowspan:p?2*g-1:g},v()),r);default:{const e=m(),t={},l=(0,i._V)(null!=(a=o.labelWidth)?a:this.descriptions.labelWidth);return l&&(t.width=l,t.display="inline-block"),(0,n.bo)((0,n.h)("td",{style:x,class:[M.e("cell"),b],colSpan:h,rowspan:g},[(0,c.A)(e)?void 0:(0,n.h)("span",{style:t,class:[M.e("label"),w]},e),(0,n.h)("span",{class:[M.e("content"),C]},v())]),r)}}}}),f=l(7378);const p=(0,f.b_)({row:{type:(0,f.jq)(Array),default:()=>[]}});var m=l(9077);const v=(0,n.pM)({name:"ElDescriptionsRow"}),h=(0,n.pM)({...v,props:p,setup(e){const t=(0,n.WQ)(r,{});return(e,l)=>"vertical"===(0,o.R1)(t).direction?((0,n.uX)(),(0,n.CE)(n.FK,{key:0},[(0,n.Lk)("tr",null,[((0,n.uX)(!0),(0,n.CE)(n.FK,null,(0,n.pI)(e.row,(e,t)=>((0,n.uX)(),(0,n.Wv)((0,o.R1)(d),{key:`tr1-${t}`,cell:e,tag:"th",type:"label"},null,8,["cell"]))),128))]),(0,n.Lk)("tr",null,[((0,n.uX)(!0),(0,n.CE)(n.FK,null,(0,n.pI)(e.row,(e,t)=>((0,n.uX)(),(0,n.Wv)((0,o.R1)(d),{key:`tr2-${t}`,cell:e,tag:"td",type:"content"},null,8,["cell"]))),128))])],64)):((0,n.uX)(),(0,n.CE)("tr",{key:1},[((0,n.uX)(!0),(0,n.CE)(n.FK,null,(0,n.pI)(e.row,(e,l)=>((0,n.uX)(),(0,n.CE)(n.FK,{key:`tr3-${l}`},[(0,o.R1)(t).border?((0,n.uX)(),(0,n.CE)(n.FK,{key:0},[(0,n.bF)((0,o.R1)(d),{cell:e,tag:"td",type:"label"},null,8,["cell"]),(0,n.bF)((0,o.R1)(d),{cell:e,tag:"td",type:"content"},null,8,["cell"])],64)):((0,n.uX)(),(0,n.Wv)((0,o.R1)(d),{key:1,cell:e,tag:"td",type:"both"},null,8,["cell"]))],64))),128))]))}});var g=(0,m.A)(h,[["__file","descriptions-row.vue"]]),b=l(3845);const y=(0,f.b_)({border:Boolean,column:{type:Number,default:3},direction:{type:String,values:["horizontal","vertical"],default:"horizontal"},size:b.mU,title:{type:String,default:""},extra:{type:String,default:""},labelWidth:{type:[String,Number]}}),C="ElDescriptionsItem";var w=l(2436);const L=(0,n.pM)({name:"ElDescriptions"}),x=(0,n.pM)({...L,props:y,setup(e){const t=e,l=(0,u.DU)("descriptions"),c=(0,w.NV)(),i=(0,n.Ht)();(0,n.Gt)(r,t);const d=(0,n.EW)(()=>[l.b(),l.m(c.value)]),f=(e,t,l,n=!1)=>(e.props||(e.props={}),t>l&&(e.props.span=l),n&&(e.props.span=t),e),p=()=>{if(!i.default)return[];const e=(0,s.CW)(i.default()).filter(e=>{var t;return(null==(t=null==e?void 0:e.type)?void 0:t.name)===C}),l=[];let n=[],a=t.column,o=0;const c=[];return e.forEach((r,s)=>{var i,u,d;const p=(null==(i=r.props)?void 0:i.span)||1,m=(null==(u=r.props)?void 0:u.rowspan)||1,v=l.length;if(c[v]||(c[v]=0),m>1)for(let e=1;e0&&(a-=c[v],c[v]=0),sa?a:p),s===e.length-1){const e=t.column-o%t.column;return n.push(f(r,e,a,!0)),void l.push(n)}p((0,n.uX)(),(0,n.CE)("div",{class:(0,a.C4)((0,o.R1)(d))},[e.title||e.extra||e.$slots.title||e.$slots.extra?((0,n.uX)(),(0,n.CE)("div",{key:0,class:(0,a.C4)((0,o.R1)(l).e("header"))},[(0,n.Lk)("div",{class:(0,a.C4)((0,o.R1)(l).e("title"))},[(0,n.RG)(e.$slots,"title",{},()=>[(0,n.eW)((0,a.v_)(e.title),1)])],2),(0,n.Lk)("div",{class:(0,a.C4)((0,o.R1)(l).e("extra"))},[(0,n.RG)(e.$slots,"extra",{},()=>[(0,n.eW)((0,a.v_)(e.extra),1)])],2)],2)):(0,n.Q3)("v-if",!0),(0,n.Lk)("div",{class:(0,a.C4)((0,o.R1)(l).e("body"))},[(0,n.Lk)("table",{class:(0,a.C4)([(0,o.R1)(l).e("table"),(0,o.R1)(l).is("bordered",e.border)])},[(0,n.Lk)("tbody",null,[((0,n.uX)(!0),(0,n.CE)(n.FK,null,(0,n.pI)(p(),(e,t)=>((0,n.uX)(),(0,n.Wv)(g,{key:t,row:e},null,8,["row"]))),128))])],2)],2)],2))}});var M=(0,m.A)(x,[["__file","description.vue"]]);const z=["left","center","right"],R=(0,f.b_)({label:{type:String,default:""},span:{type:Number,default:1},rowspan:{type:Number,default:1},width:{type:[String,Number],default:""},minWidth:{type:[String,Number],default:""},labelWidth:{type:[String,Number]},align:{type:String,values:z,default:"left"},labelAlign:{type:String,values:z},className:{type:String,default:""},labelClassName:{type:String,default:""}}),k=(0,n.pM)({name:C,props:R});var S=l(5376);const E=(0,S.GU)(M,{DescriptionsItem:k}),A=(0,S.WM)(k)},9928:function(e,t,l){"use strict";var n=l(6198),a=l(1291),o=RangeError;e.exports=function(e,t,l,c){var r=n(e),s=a(l),i=s<0?r+s:s;if(i>=r||i<0)throw new o("Incorrect index");for(var u=new t(r),d=0;d{};let i={},u={},d=null,f={mark:s,measure:s};try{"undefined"!==typeof window&&(i=window),"undefined"!==typeof document&&(u=document),"undefined"!==typeof MutationObserver&&(d=MutationObserver),"undefined"!==typeof performance&&(f=performance)}catch(Tn){}const{userAgent:p=""}=i.navigator||{},m=i,v=u,h=d,g=f,b=(m.document,!!v.documentElement&&!!v.head&&"function"===typeof v.addEventListener&&"function"===typeof v.createElement),y=~p.indexOf("MSIE")||~p.indexOf("Trident/");var C=/fa(s|r|l|t|d|dr|dl|dt|b|k|kd|ss|sr|sl|st|sds|sdr|sdl|sdt)?[\-\ ]/,w=/Font ?Awesome ?([56 ]*)(Solid|Regular|Light|Thin|Duotone|Brands|Free|Pro|Sharp Duotone|Sharp|Kit)?.*/i,L={classic:{fa:"solid",fas:"solid","fa-solid":"solid",far:"regular","fa-regular":"regular",fal:"light","fa-light":"light",fat:"thin","fa-thin":"thin",fab:"brands","fa-brands":"brands"},duotone:{fa:"solid",fad:"solid","fa-solid":"solid","fa-duotone":"solid",fadr:"regular","fa-regular":"regular",fadl:"light","fa-light":"light",fadt:"thin","fa-thin":"thin"},sharp:{fa:"solid",fass:"solid","fa-solid":"solid",fasr:"regular","fa-regular":"regular",fasl:"light","fa-light":"light",fast:"thin","fa-thin":"thin"},"sharp-duotone":{fa:"solid",fasds:"solid","fa-solid":"solid",fasdr:"regular","fa-regular":"regular",fasdl:"light","fa-light":"light",fasdt:"thin","fa-thin":"thin"}},x={GROUP:"duotone-group",SWAP_OPACITY:"swap-opacity",PRIMARY:"primary",SECONDARY:"secondary"},M=["fa-classic","fa-duotone","fa-sharp","fa-sharp-duotone"],z="classic",R="duotone",k="sharp",S="sharp-duotone",E=[z,R,k,S],A={classic:{900:"fas",400:"far",normal:"far",300:"fal",100:"fat"},duotone:{900:"fad",400:"fadr",300:"fadl",100:"fadt"},sharp:{900:"fass",400:"fasr",300:"fasl",100:"fast"},"sharp-duotone":{900:"fasds",400:"fasdr",300:"fasdl",100:"fasdt"}},N={"Font Awesome 6 Free":{900:"fas",400:"far"},"Font Awesome 6 Pro":{900:"fas",400:"far",normal:"far",300:"fal",100:"fat"},"Font Awesome 6 Brands":{400:"fab",normal:"fab"},"Font Awesome 6 Duotone":{900:"fad",400:"fadr",normal:"fadr",300:"fadl",100:"fadt"},"Font Awesome 6 Sharp":{900:"fass",400:"fasr",normal:"fasr",300:"fasl",100:"fast"},"Font Awesome 6 Sharp Duotone":{900:"fasds",400:"fasdr",normal:"fasdr",300:"fasdl",100:"fasdt"}},_=new Map([["classic",{defaultShortPrefixId:"fas",defaultStyleId:"solid",styleIds:["solid","regular","light","thin","brands"],futureStyleIds:[],defaultFontWeight:900}],["sharp",{defaultShortPrefixId:"fass",defaultStyleId:"solid",styleIds:["solid","regular","light","thin"],futureStyleIds:[],defaultFontWeight:900}],["duotone",{defaultShortPrefixId:"fad",defaultStyleId:"solid",styleIds:["solid","regular","light","thin"],futureStyleIds:[],defaultFontWeight:900}],["sharp-duotone",{defaultShortPrefixId:"fasds",defaultStyleId:"solid",styleIds:["solid","regular","light","thin"],futureStyleIds:[],defaultFontWeight:900}]]),T={classic:{solid:"fas",regular:"far",light:"fal",thin:"fat",brands:"fab"},duotone:{solid:"fad",regular:"fadr",light:"fadl",thin:"fadt"},sharp:{solid:"fass",regular:"fasr",light:"fasl",thin:"fast"},"sharp-duotone":{solid:"fasds",regular:"fasdr",light:"fasdl",thin:"fasdt"}},O=["fak","fa-kit","fakd","fa-kit-duotone"],W={kit:{fak:"kit","fa-kit":"kit"},"kit-duotone":{fakd:"kit-duotone","fa-kit-duotone":"kit-duotone"}},B=["kit"],I={kit:{"fa-kit":"fak"},"kit-duotone":{"fa-kit-duotone":"fakd"}},D=["fak","fakd"],F={kit:{fak:"fa-kit"},"kit-duotone":{fakd:"fa-kit-duotone"}},V={kit:{kit:"fak"},"kit-duotone":{"kit-duotone":"fakd"}},P={GROUP:"duotone-group",SWAP_OPACITY:"swap-opacity",PRIMARY:"primary",SECONDARY:"secondary"},$=["fa-classic","fa-duotone","fa-sharp","fa-sharp-duotone"],H=["fak","fa-kit","fakd","fa-kit-duotone"],j={"Font Awesome Kit":{400:"fak",normal:"fak"},"Font Awesome Kit Duotone":{400:"fakd",normal:"fakd"}},K={classic:{"fa-brands":"fab","fa-duotone":"fad","fa-light":"fal","fa-regular":"far","fa-solid":"fas","fa-thin":"fat"},duotone:{"fa-regular":"fadr","fa-light":"fadl","fa-thin":"fadt"},sharp:{"fa-solid":"fass","fa-regular":"fasr","fa-light":"fasl","fa-thin":"fast"},"sharp-duotone":{"fa-solid":"fasds","fa-regular":"fasdr","fa-light":"fasdl","fa-thin":"fasdt"}},X={classic:["fas","far","fal","fat","fad"],duotone:["fadr","fadl","fadt"],sharp:["fass","fasr","fasl","fast"],"sharp-duotone":["fasds","fasdr","fasdl","fasdt"]},U={classic:{fab:"fa-brands",fad:"fa-duotone",fal:"fa-light",far:"fa-regular",fas:"fa-solid",fat:"fa-thin"},duotone:{fadr:"fa-regular",fadl:"fa-light",fadt:"fa-thin"},sharp:{fass:"fa-solid",fasr:"fa-regular",fasl:"fa-light",fast:"fa-thin"},"sharp-duotone":{fasds:"fa-solid",fasdr:"fa-regular",fasdl:"fa-light",fasdt:"fa-thin"}},q=["fa-solid","fa-regular","fa-light","fa-thin","fa-duotone","fa-brands"],G=["fa","fas","far","fal","fat","fad","fadr","fadl","fadt","fab","fass","fasr","fasl","fast","fasds","fasdr","fasdl","fasdt",...$,...q],Y=["solid","regular","light","thin","duotone","brands"],Q=[1,2,3,4,5,6,7,8,9,10],Z=Q.concat([11,12,13,14,15,16,17,18,19,20]),J=[...Object.keys(X),...Y,"2xs","xs","sm","lg","xl","2xl","beat","border","fade","beat-fade","bounce","flip-both","flip-horizontal","flip-vertical","flip","fw","inverse","layers-counter","layers-text","layers","li","pull-left","pull-right","pulse","rotate-180","rotate-270","rotate-90","rotate-by","shake","spin-pulse","spin-reverse","spin","stack-1x","stack-2x","stack","ul",P.GROUP,P.SWAP_OPACITY,P.PRIMARY,P.SECONDARY].concat(Q.map(e=>"".concat(e,"x"))).concat(Z.map(e=>"w-".concat(e))),ee={"Font Awesome 5 Free":{900:"fas",400:"far"},"Font Awesome 5 Pro":{900:"fas",400:"far",normal:"far",300:"fal"},"Font Awesome 5 Brands":{400:"fab",normal:"fab"},"Font Awesome 5 Duotone":{900:"fad"}};const te="___FONT_AWESOME___",le=16,ne="fa",ae="svg-inline--fa",oe="data-fa-i2svg",ce="data-fa-pseudo-element",re="data-fa-pseudo-element-pending",se="data-prefix",ie="data-icon",ue="fontawesome-i2svg",de="async",fe=["HTML","HEAD","STYLE","SCRIPT"],pe=(()=>{try{return!0}catch(e){return!1}})();function me(e){return new Proxy(e,{get(e,t){return t in e?e[t]:e[z]}})}const ve=o({},L);ve[z]=o(o(o(o({},{"fa-duotone":"duotone"}),L[z]),W["kit"]),W["kit-duotone"]);const he=me(ve),ge=o({},T);ge[z]=o(o(o(o({},{duotone:"fad"}),ge[z]),V["kit"]),V["kit-duotone"]);const be=me(ge),ye=o({},U);ye[z]=o(o({},ye[z]),F["kit"]);const Ce=me(ye),we=o({},K);we[z]=o(o({},we[z]),I["kit"]);me(we);const Le=C,xe="fa-layers-text",Me=w,ze=o({},A),Re=(me(ze),["class","data-prefix","data-icon","data-fa-transform","data-fa-mask"]),ke=x,Se=[...B,...J],Ee=m.FontAwesomeConfig||{};function Ae(e){var t=v.querySelector("script["+e+"]");if(t)return t.getAttribute(e)}function Ne(e){return""===e||"false"!==e&&("true"===e||e)}if(v&&"function"===typeof v.querySelector){const e=[["data-family-prefix","familyPrefix"],["data-css-prefix","cssPrefix"],["data-family-default","familyDefault"],["data-style-default","styleDefault"],["data-replacement-class","replacementClass"],["data-auto-replace-svg","autoReplaceSvg"],["data-auto-add-css","autoAddCss"],["data-auto-a11y","autoA11y"],["data-search-pseudo-elements","searchPseudoElements"],["data-observe-mutations","observeMutations"],["data-mutate-approach","mutateApproach"],["data-keep-original-source","keepOriginalSource"],["data-measure-performance","measurePerformance"],["data-show-missing-icons","showMissingIcons"]];e.forEach(e=>{let[t,l]=e;const n=Ne(Ae(t));void 0!==n&&null!==n&&(Ee[l]=n)})}const _e={styleDefault:"solid",familyDefault:z,cssPrefix:ne,replacementClass:ae,autoReplaceSvg:!0,autoAddCss:!0,autoA11y:!0,searchPseudoElements:!1,observeMutations:!0,mutateApproach:"async",keepOriginalSource:!0,measurePerformance:!1,showMissingIcons:!0};Ee.familyPrefix&&(Ee.cssPrefix=Ee.familyPrefix);const Te=o(o({},_e),Ee);Te.autoReplaceSvg||(Te.observeMutations=!1);const Oe={};Object.keys(_e).forEach(e=>{Object.defineProperty(Oe,e,{enumerable:!0,set:function(t){Te[e]=t,We.forEach(e=>e(Oe))},get:function(){return Te[e]}})}),Object.defineProperty(Oe,"familyPrefix",{enumerable:!0,set:function(e){Te.cssPrefix=e,We.forEach(e=>e(Oe))},get:function(){return Te.cssPrefix}}),m.FontAwesomeConfig=Oe;const We=[];function Be(e){return We.push(e),()=>{We.splice(We.indexOf(e),1)}}const Ie=le,De={size:16,x:0,y:0,rotate:0,flipX:!1,flipY:!1};function Fe(e){if(!e||!b)return;const t=v.createElement("style");t.setAttribute("type","text/css"),t.innerHTML=e;const l=v.head.childNodes;let n=null;for(let a=l.length-1;a>-1;a--){const e=l[a],t=(e.tagName||"").toUpperCase();["STYLE","LINK"].indexOf(t)>-1&&(n=e)}return v.head.insertBefore(t,n),e}const Ve="0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";function Pe(){let e=12,t="";while(e-- >0)t+=Ve[62*Math.random()|0];return t}function $e(e){const t=[];for(let l=(e||[]).length>>>0;l--;)t[l]=e[l];return t}function He(e){return e.classList?$e(e.classList):(e.getAttribute("class")||"").split(" ").filter(e=>e)}function je(e){return"".concat(e).replace(/&/g,"&").replace(/"/g,""").replace(/'/g,"'").replace(//g,">")}function Ke(e){return Object.keys(e||{}).reduce((t,l)=>t+"".concat(l,'="').concat(je(e[l]),'" '),"").trim()}function Xe(e){return Object.keys(e||{}).reduce((t,l)=>t+"".concat(l,": ").concat(e[l].trim(),";"),"")}function Ue(e){return e.size!==De.size||e.x!==De.x||e.y!==De.y||e.rotate!==De.rotate||e.flipX||e.flipY}function qe(e){let{transform:t,containerWidth:l,iconWidth:n}=e;const a={transform:"translate(".concat(l/2," 256)")},o="translate(".concat(32*t.x,", ").concat(32*t.y,") "),c="scale(".concat(t.size/16*(t.flipX?-1:1),", ").concat(t.size/16*(t.flipY?-1:1),") "),r="rotate(".concat(t.rotate," 0 0)"),s={transform:"".concat(o," ").concat(c," ").concat(r)},i={transform:"translate(".concat(n/2*-1," -256)")};return{outer:a,inner:s,path:i}}function Ge(e){let{transform:t,width:l=le,height:n=le,startCentered:a=!1}=e,o="";return o+=a&&y?"translate(".concat(t.x/Ie-l/2,"em, ").concat(t.y/Ie-n/2,"em) "):a?"translate(calc(-50% + ".concat(t.x/Ie,"em), calc(-50% + ").concat(t.y/Ie,"em)) "):"translate(".concat(t.x/Ie,"em, ").concat(t.y/Ie,"em) "),o+="scale(".concat(t.size/Ie*(t.flipX?-1:1),", ").concat(t.size/Ie*(t.flipY?-1:1),") "),o+="rotate(".concat(t.rotate,"deg) "),o}var Ye=':root, :host {\n --fa-font-solid: normal 900 1em/1 "Font Awesome 6 Free";\n --fa-font-regular: normal 400 1em/1 "Font Awesome 6 Free";\n --fa-font-light: normal 300 1em/1 "Font Awesome 6 Pro";\n --fa-font-thin: normal 100 1em/1 "Font Awesome 6 Pro";\n --fa-font-duotone: normal 900 1em/1 "Font Awesome 6 Duotone";\n --fa-font-duotone-regular: normal 400 1em/1 "Font Awesome 6 Duotone";\n --fa-font-duotone-light: normal 300 1em/1 "Font Awesome 6 Duotone";\n --fa-font-duotone-thin: normal 100 1em/1 "Font Awesome 6 Duotone";\n --fa-font-brands: normal 400 1em/1 "Font Awesome 6 Brands";\n --fa-font-sharp-solid: normal 900 1em/1 "Font Awesome 6 Sharp";\n --fa-font-sharp-regular: normal 400 1em/1 "Font Awesome 6 Sharp";\n --fa-font-sharp-light: normal 300 1em/1 "Font Awesome 6 Sharp";\n --fa-font-sharp-thin: normal 100 1em/1 "Font Awesome 6 Sharp";\n --fa-font-sharp-duotone-solid: normal 900 1em/1 "Font Awesome 6 Sharp Duotone";\n --fa-font-sharp-duotone-regular: normal 400 1em/1 "Font Awesome 6 Sharp Duotone";\n --fa-font-sharp-duotone-light: normal 300 1em/1 "Font Awesome 6 Sharp Duotone";\n --fa-font-sharp-duotone-thin: normal 100 1em/1 "Font Awesome 6 Sharp Duotone";\n}\n\nsvg:not(:root).svg-inline--fa, svg:not(:host).svg-inline--fa {\n overflow: visible;\n box-sizing: content-box;\n}\n\n.svg-inline--fa {\n display: var(--fa-display, inline-block);\n height: 1em;\n overflow: visible;\n vertical-align: -0.125em;\n}\n.svg-inline--fa.fa-2xs {\n vertical-align: 0.1em;\n}\n.svg-inline--fa.fa-xs {\n vertical-align: 0em;\n}\n.svg-inline--fa.fa-sm {\n vertical-align: -0.0714285705em;\n}\n.svg-inline--fa.fa-lg {\n vertical-align: -0.2em;\n}\n.svg-inline--fa.fa-xl {\n vertical-align: -0.25em;\n}\n.svg-inline--fa.fa-2xl {\n vertical-align: -0.3125em;\n}\n.svg-inline--fa.fa-pull-left {\n margin-right: var(--fa-pull-margin, 0.3em);\n width: auto;\n}\n.svg-inline--fa.fa-pull-right {\n margin-left: var(--fa-pull-margin, 0.3em);\n width: auto;\n}\n.svg-inline--fa.fa-li {\n width: var(--fa-li-width, 2em);\n top: 0.25em;\n}\n.svg-inline--fa.fa-fw {\n width: var(--fa-fw-width, 1.25em);\n}\n\n.fa-layers svg.svg-inline--fa {\n bottom: 0;\n left: 0;\n margin: auto;\n position: absolute;\n right: 0;\n top: 0;\n}\n\n.fa-layers-counter, .fa-layers-text {\n display: inline-block;\n position: absolute;\n text-align: center;\n}\n\n.fa-layers {\n display: inline-block;\n height: 1em;\n position: relative;\n text-align: center;\n vertical-align: -0.125em;\n width: 1em;\n}\n.fa-layers svg.svg-inline--fa {\n transform-origin: center center;\n}\n\n.fa-layers-text {\n left: 50%;\n top: 50%;\n transform: translate(-50%, -50%);\n transform-origin: center center;\n}\n\n.fa-layers-counter {\n background-color: var(--fa-counter-background-color, #ff253a);\n border-radius: var(--fa-counter-border-radius, 1em);\n box-sizing: border-box;\n color: var(--fa-inverse, #fff);\n line-height: var(--fa-counter-line-height, 1);\n max-width: var(--fa-counter-max-width, 5em);\n min-width: var(--fa-counter-min-width, 1.5em);\n overflow: hidden;\n padding: var(--fa-counter-padding, 0.25em 0.5em);\n right: var(--fa-right, 0);\n text-overflow: ellipsis;\n top: var(--fa-top, 0);\n transform: scale(var(--fa-counter-scale, 0.25));\n transform-origin: top right;\n}\n\n.fa-layers-bottom-right {\n bottom: var(--fa-bottom, 0);\n right: var(--fa-right, 0);\n top: auto;\n transform: scale(var(--fa-layers-scale, 0.25));\n transform-origin: bottom right;\n}\n\n.fa-layers-bottom-left {\n bottom: var(--fa-bottom, 0);\n left: var(--fa-left, 0);\n right: auto;\n top: auto;\n transform: scale(var(--fa-layers-scale, 0.25));\n transform-origin: bottom left;\n}\n\n.fa-layers-top-right {\n top: var(--fa-top, 0);\n right: var(--fa-right, 0);\n transform: scale(var(--fa-layers-scale, 0.25));\n transform-origin: top right;\n}\n\n.fa-layers-top-left {\n left: var(--fa-left, 0);\n right: auto;\n top: var(--fa-top, 0);\n transform: scale(var(--fa-layers-scale, 0.25));\n transform-origin: top left;\n}\n\n.fa-1x {\n font-size: 1em;\n}\n\n.fa-2x {\n font-size: 2em;\n}\n\n.fa-3x {\n font-size: 3em;\n}\n\n.fa-4x {\n font-size: 4em;\n}\n\n.fa-5x {\n font-size: 5em;\n}\n\n.fa-6x {\n font-size: 6em;\n}\n\n.fa-7x {\n font-size: 7em;\n}\n\n.fa-8x {\n font-size: 8em;\n}\n\n.fa-9x {\n font-size: 9em;\n}\n\n.fa-10x {\n font-size: 10em;\n}\n\n.fa-2xs {\n font-size: 0.625em;\n line-height: 0.1em;\n vertical-align: 0.225em;\n}\n\n.fa-xs {\n font-size: 0.75em;\n line-height: 0.0833333337em;\n vertical-align: 0.125em;\n}\n\n.fa-sm {\n font-size: 0.875em;\n line-height: 0.0714285718em;\n vertical-align: 0.0535714295em;\n}\n\n.fa-lg {\n font-size: 1.25em;\n line-height: 0.05em;\n vertical-align: -0.075em;\n}\n\n.fa-xl {\n font-size: 1.5em;\n line-height: 0.0416666682em;\n vertical-align: -0.125em;\n}\n\n.fa-2xl {\n font-size: 2em;\n line-height: 0.03125em;\n vertical-align: -0.1875em;\n}\n\n.fa-fw {\n text-align: center;\n width: 1.25em;\n}\n\n.fa-ul {\n list-style-type: none;\n margin-left: var(--fa-li-margin, 2.5em);\n padding-left: 0;\n}\n.fa-ul > li {\n position: relative;\n}\n\n.fa-li {\n left: calc(-1 * var(--fa-li-width, 2em));\n position: absolute;\n text-align: center;\n width: var(--fa-li-width, 2em);\n line-height: inherit;\n}\n\n.fa-border {\n border-color: var(--fa-border-color, #eee);\n border-radius: var(--fa-border-radius, 0.1em);\n border-style: var(--fa-border-style, solid);\n border-width: var(--fa-border-width, 0.08em);\n padding: var(--fa-border-padding, 0.2em 0.25em 0.15em);\n}\n\n.fa-pull-left {\n float: left;\n margin-right: var(--fa-pull-margin, 0.3em);\n}\n\n.fa-pull-right {\n float: right;\n margin-left: var(--fa-pull-margin, 0.3em);\n}\n\n.fa-beat {\n animation-name: fa-beat;\n animation-delay: var(--fa-animation-delay, 0s);\n animation-direction: var(--fa-animation-direction, normal);\n animation-duration: var(--fa-animation-duration, 1s);\n animation-iteration-count: var(--fa-animation-iteration-count, infinite);\n animation-timing-function: var(--fa-animation-timing, ease-in-out);\n}\n\n.fa-bounce {\n animation-name: fa-bounce;\n animation-delay: var(--fa-animation-delay, 0s);\n animation-direction: var(--fa-animation-direction, normal);\n animation-duration: var(--fa-animation-duration, 1s);\n animation-iteration-count: var(--fa-animation-iteration-count, infinite);\n animation-timing-function: var(--fa-animation-timing, cubic-bezier(0.28, 0.84, 0.42, 1));\n}\n\n.fa-fade {\n animation-name: fa-fade;\n animation-delay: var(--fa-animation-delay, 0s);\n animation-direction: var(--fa-animation-direction, normal);\n animation-duration: var(--fa-animation-duration, 1s);\n animation-iteration-count: var(--fa-animation-iteration-count, infinite);\n animation-timing-function: var(--fa-animation-timing, cubic-bezier(0.4, 0, 0.6, 1));\n}\n\n.fa-beat-fade {\n animation-name: fa-beat-fade;\n animation-delay: var(--fa-animation-delay, 0s);\n animation-direction: var(--fa-animation-direction, normal);\n animation-duration: var(--fa-animation-duration, 1s);\n animation-iteration-count: var(--fa-animation-iteration-count, infinite);\n animation-timing-function: var(--fa-animation-timing, cubic-bezier(0.4, 0, 0.6, 1));\n}\n\n.fa-flip {\n animation-name: fa-flip;\n animation-delay: var(--fa-animation-delay, 0s);\n animation-direction: var(--fa-animation-direction, normal);\n animation-duration: var(--fa-animation-duration, 1s);\n animation-iteration-count: var(--fa-animation-iteration-count, infinite);\n animation-timing-function: var(--fa-animation-timing, ease-in-out);\n}\n\n.fa-shake {\n animation-name: fa-shake;\n animation-delay: var(--fa-animation-delay, 0s);\n animation-direction: var(--fa-animation-direction, normal);\n animation-duration: var(--fa-animation-duration, 1s);\n animation-iteration-count: var(--fa-animation-iteration-count, infinite);\n animation-timing-function: var(--fa-animation-timing, linear);\n}\n\n.fa-spin {\n animation-name: fa-spin;\n animation-delay: var(--fa-animation-delay, 0s);\n animation-direction: var(--fa-animation-direction, normal);\n animation-duration: var(--fa-animation-duration, 2s);\n animation-iteration-count: var(--fa-animation-iteration-count, infinite);\n animation-timing-function: var(--fa-animation-timing, linear);\n}\n\n.fa-spin-reverse {\n --fa-animation-direction: reverse;\n}\n\n.fa-pulse,\n.fa-spin-pulse {\n animation-name: fa-spin;\n animation-direction: var(--fa-animation-direction, normal);\n animation-duration: var(--fa-animation-duration, 1s);\n animation-iteration-count: var(--fa-animation-iteration-count, infinite);\n animation-timing-function: var(--fa-animation-timing, steps(8));\n}\n\n@media (prefers-reduced-motion: reduce) {\n .fa-beat,\n.fa-bounce,\n.fa-fade,\n.fa-beat-fade,\n.fa-flip,\n.fa-pulse,\n.fa-shake,\n.fa-spin,\n.fa-spin-pulse {\n animation-delay: -1ms;\n animation-duration: 1ms;\n animation-iteration-count: 1;\n transition-delay: 0s;\n transition-duration: 0s;\n }\n}\n@keyframes fa-beat {\n 0%, 90% {\n transform: scale(1);\n }\n 45% {\n transform: scale(var(--fa-beat-scale, 1.25));\n }\n}\n@keyframes fa-bounce {\n 0% {\n transform: scale(1, 1) translateY(0);\n }\n 10% {\n transform: scale(var(--fa-bounce-start-scale-x, 1.1), var(--fa-bounce-start-scale-y, 0.9)) translateY(0);\n }\n 30% {\n transform: scale(var(--fa-bounce-jump-scale-x, 0.9), var(--fa-bounce-jump-scale-y, 1.1)) translateY(var(--fa-bounce-height, -0.5em));\n }\n 50% {\n transform: scale(var(--fa-bounce-land-scale-x, 1.05), var(--fa-bounce-land-scale-y, 0.95)) translateY(0);\n }\n 57% {\n transform: scale(1, 1) translateY(var(--fa-bounce-rebound, -0.125em));\n }\n 64% {\n transform: scale(1, 1) translateY(0);\n }\n 100% {\n transform: scale(1, 1) translateY(0);\n }\n}\n@keyframes fa-fade {\n 50% {\n opacity: var(--fa-fade-opacity, 0.4);\n }\n}\n@keyframes fa-beat-fade {\n 0%, 100% {\n opacity: var(--fa-beat-fade-opacity, 0.4);\n transform: scale(1);\n }\n 50% {\n opacity: 1;\n transform: scale(var(--fa-beat-fade-scale, 1.125));\n }\n}\n@keyframes fa-flip {\n 50% {\n transform: rotate3d(var(--fa-flip-x, 0), var(--fa-flip-y, 1), var(--fa-flip-z, 0), var(--fa-flip-angle, -180deg));\n }\n}\n@keyframes fa-shake {\n 0% {\n transform: rotate(-15deg);\n }\n 4% {\n transform: rotate(15deg);\n }\n 8%, 24% {\n transform: rotate(-18deg);\n }\n 12%, 28% {\n transform: rotate(18deg);\n }\n 16% {\n transform: rotate(-22deg);\n }\n 20% {\n transform: rotate(22deg);\n }\n 32% {\n transform: rotate(-12deg);\n }\n 36% {\n transform: rotate(12deg);\n }\n 40%, 100% {\n transform: rotate(0deg);\n }\n}\n@keyframes fa-spin {\n 0% {\n transform: rotate(0deg);\n }\n 100% {\n transform: rotate(360deg);\n }\n}\n.fa-rotate-90 {\n transform: rotate(90deg);\n}\n\n.fa-rotate-180 {\n transform: rotate(180deg);\n}\n\n.fa-rotate-270 {\n transform: rotate(270deg);\n}\n\n.fa-flip-horizontal {\n transform: scale(-1, 1);\n}\n\n.fa-flip-vertical {\n transform: scale(1, -1);\n}\n\n.fa-flip-both,\n.fa-flip-horizontal.fa-flip-vertical {\n transform: scale(-1, -1);\n}\n\n.fa-rotate-by {\n transform: rotate(var(--fa-rotate-angle, 0));\n}\n\n.fa-stack {\n display: inline-block;\n vertical-align: middle;\n height: 2em;\n position: relative;\n width: 2.5em;\n}\n\n.fa-stack-1x,\n.fa-stack-2x {\n bottom: 0;\n left: 0;\n margin: auto;\n position: absolute;\n right: 0;\n top: 0;\n z-index: var(--fa-stack-z-index, auto);\n}\n\n.svg-inline--fa.fa-stack-1x {\n height: 1em;\n width: 1.25em;\n}\n.svg-inline--fa.fa-stack-2x {\n height: 2em;\n width: 2.5em;\n}\n\n.fa-inverse {\n color: var(--fa-inverse, #fff);\n}\n\n.sr-only,\n.fa-sr-only {\n position: absolute;\n width: 1px;\n height: 1px;\n padding: 0;\n margin: -1px;\n overflow: hidden;\n clip: rect(0, 0, 0, 0);\n white-space: nowrap;\n border-width: 0;\n}\n\n.sr-only-focusable:not(:focus),\n.fa-sr-only-focusable:not(:focus) {\n position: absolute;\n width: 1px;\n height: 1px;\n padding: 0;\n margin: -1px;\n overflow: hidden;\n clip: rect(0, 0, 0, 0);\n white-space: nowrap;\n border-width: 0;\n}\n\n.svg-inline--fa .fa-primary {\n fill: var(--fa-primary-color, currentColor);\n opacity: var(--fa-primary-opacity, 1);\n}\n\n.svg-inline--fa .fa-secondary {\n fill: var(--fa-secondary-color, currentColor);\n opacity: var(--fa-secondary-opacity, 0.4);\n}\n\n.svg-inline--fa.fa-swap-opacity .fa-primary {\n opacity: var(--fa-secondary-opacity, 0.4);\n}\n\n.svg-inline--fa.fa-swap-opacity .fa-secondary {\n opacity: var(--fa-primary-opacity, 1);\n}\n\n.svg-inline--fa mask .fa-primary,\n.svg-inline--fa mask .fa-secondary {\n fill: black;\n}';function Qe(){const e=ne,t=ae,l=Oe.cssPrefix,n=Oe.replacementClass;let a=Ye;if(l!==e||n!==t){const o=new RegExp("\\.".concat(e,"\\-"),"g"),c=new RegExp("\\--".concat(e,"\\-"),"g"),r=new RegExp("\\.".concat(t),"g");a=a.replace(o,".".concat(l,"-")).replace(c,"--".concat(l,"-")).replace(r,".".concat(n))}return a}let Ze=!1;function Je(){Oe.autoAddCss&&!Ze&&(Fe(Qe()),Ze=!0)}var et={mixout(){return{dom:{css:Qe,insertCss:Je}}},hooks(){return{beforeDOMElementCreation(){Je()},beforeI2svg(){Je()}}}};const tt=m||{};tt[te]||(tt[te]={}),tt[te].styles||(tt[te].styles={}),tt[te].hooks||(tt[te].hooks={}),tt[te].shims||(tt[te].shims=[]);var lt=tt[te];const nt=[],at=function(){v.removeEventListener("DOMContentLoaded",at),ot=1,nt.map(e=>e())};let ot=!1;function ct(e){b&&(ot?setTimeout(e,0):nt.push(e))}function rt(e){const{tag:t,attributes:l={},children:n=[]}=e;return"string"===typeof e?je(e):"<".concat(t," ").concat(Ke(l),">").concat(n.map(rt).join(""),"")}function st(e,t,l){if(e&&e[t]&&e[t][l])return{prefix:t,iconName:l,icon:e[t][l]}}b&&(ot=(v.documentElement.doScroll?/^loaded|^c/:/^loaded|^i|^c/).test(v.readyState),ot||v.addEventListener("DOMContentLoaded",at));var it=function(e,t){return function(l,n,a,o){return e.call(t,l,n,a,o)}},ut=function(e,t,l,n){var a,o,c,r=Object.keys(e),s=r.length,i=void 0!==n?it(t,n):t;for(void 0===l?(a=1,c=e[r[0]]):(a=0,c=l);a=55296&&a<=56319&&l=55296&&a<=56319&&l>t+1&&(n=e.charCodeAt(t+1),n>=56320&&n<=57343)?1024*(a-55296)+n-56320+65536:a}function mt(e){return Object.keys(e).reduce((t,l)=>{const n=e[l],a=!!n.icon;return a?t[n.iconName]=n.icon:t[l]=n,t},{})}function vt(e,t){let l=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};const{skipHooks:n=!1}=l,a=mt(t);"function"!==typeof lt.hooks.addPack||n?lt.styles[e]=o(o({},lt.styles[e]||{}),a):lt.hooks.addPack(e,mt(t)),"fas"===e&&vt("fa",t)}const{styles:ht,shims:gt}=lt,bt=Object.keys(Ce),yt=bt.reduce((e,t)=>(e[t]=Object.keys(Ce[t]),e),{});let Ct=null,wt={},Lt={},xt={},Mt={},zt={};function Rt(e){return~Se.indexOf(e)}function kt(e,t){const l=t.split("-"),n=l[0],a=l.slice(1).join("-");return n!==e||""===a||Rt(a)?null:a}const St=()=>{const e=e=>ut(ht,(t,l,n)=>(t[n]=ut(l,e,{}),t),{});wt=e((e,t,l)=>{if(t[3]&&(e[t[3]]=l),t[2]){const n=t[2].filter(e=>"number"===typeof e);n.forEach(t=>{e[t.toString(16)]=l})}return e}),Lt=e((e,t,l)=>{if(e[l]=l,t[2]){const n=t[2].filter(e=>"string"===typeof e);n.forEach(t=>{e[t]=l})}return e}),zt=e((e,t,l)=>{const n=t[2];return e[l]=l,n.forEach(t=>{e[t]=l}),e});const t="far"in ht||Oe.autoFetchSvg,l=ut(gt,(e,l)=>{const n=l[0];let a=l[1];const o=l[2];return"far"!==a||t||(a="fas"),"string"===typeof n&&(e.names[n]={prefix:a,iconName:o}),"number"===typeof n&&(e.unicodes[n.toString(16)]={prefix:a,iconName:o}),e},{names:{},unicodes:{}});xt=l.names,Mt=l.unicodes,Ct=It(Oe.styleDefault,{family:Oe.familyDefault})};function Et(e,t){return(wt[e]||{})[t]}function At(e,t){return(Lt[e]||{})[t]}function Nt(e,t){return(zt[e]||{})[t]}function _t(e){return xt[e]||{prefix:null,iconName:null}}function Tt(e){const t=Mt[e],l=Et("fas",e);return t||(l?{prefix:"fas",iconName:l}:null)||{prefix:null,iconName:null}}function Ot(){return Ct}Be(e=>{Ct=It(e.styleDefault,{family:Oe.familyDefault})}),St();const Wt=()=>({prefix:null,iconName:null,rest:[]});function Bt(e){let t=z;const l=bt.reduce((e,t)=>(e[t]="".concat(Oe.cssPrefix,"-").concat(t),e),{});return E.forEach(n=>{(e.includes(l[n])||e.some(e=>yt[n].includes(e)))&&(t=n)}),t}function It(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};const{family:l=z}=t,n=he[l][e];if(l===R&&!e)return"fad";const a=be[l][e]||be[l][n],o=e in lt.styles?e:null,c=a||o||null;return c}function Dt(e){let t=[],l=null;return e.forEach(e=>{const n=kt(Oe.cssPrefix,e);n?l=n:e&&t.push(e)}),{iconName:l,rest:t}}function Ft(e){return e.sort().filter((e,t,l)=>l.indexOf(e)===t)}function Vt(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};const{skipLookups:l=!1}=t;let n=null;const a=G.concat(H),c=Ft(e.filter(e=>a.includes(e))),r=Ft(e.filter(e=>!G.includes(e))),s=c.filter(e=>(n=e,!M.includes(e))),[i=null]=s,u=Bt(c),d=o(o({},Dt(r)),{},{prefix:It(i,{family:u})});return o(o(o({},d),jt({values:e,family:u,styles:ht,config:Oe,canonical:d,givenPrefix:n})),Pt(l,n,d))}function Pt(e,t,l){let{prefix:n,iconName:a}=l;if(e||!n||!a)return{prefix:n,iconName:a};const o="fa"===t?_t(a):{},c=Nt(n,a);return a=o.iconName||c||a,n=o.prefix||n,"far"!==n||ht["far"]||!ht["fas"]||Oe.autoFetchSvg||(n="fas"),{prefix:n,iconName:a}}const $t=E.filter(e=>e!==z||e!==R),Ht=Object.keys(U).filter(e=>e!==z).map(e=>Object.keys(U[e])).flat();function jt(e){const{values:t,family:l,canonical:n,givenPrefix:a="",styles:o={},config:c={}}=e,r=l===R,s=t.includes("fa-duotone")||t.includes("fad"),i="duotone"===c.familyDefault,u="fad"===n.prefix||"fa-duotone"===n.prefix;if(!r&&(s||i||u)&&(n.prefix="fad"),(t.includes("fa-brands")||t.includes("fab"))&&(n.prefix="fab"),!n.prefix&&$t.includes(l)){const e=Object.keys(o).find(e=>Ht.includes(e));if(e||c.autoFetchSvg){const e=_.get(l).defaultShortPrefixId;n.prefix=e,n.iconName=Nt(n.prefix,n.iconName)||n.iconName}}return"fa"!==n.prefix&&"fa"!==a||(n.prefix=Ot()||"fas"),n}class Kt{constructor(){this.definitions={}}add(){for(var e=arguments.length,t=new Array(e),l=0;l{this.definitions[e]=o(o({},this.definitions[e]||{}),n[e]),vt(e,n[e]);const t=Ce[z][e];t&&vt(t,n[e]),St()})}reset(){this.definitions={}}_pullDefinitions(e,t){const l=t.prefix&&t.iconName&&t.icon?{0:t}:t;return Object.keys(l).map(t=>{const{prefix:n,iconName:a,icon:o}=l[t],c=o[2];e[n]||(e[n]={}),c.length>0&&c.forEach(t=>{"string"===typeof t&&(e[n][t]=o)}),e[n][a]=o}),e}}let Xt=[],Ut={};const qt={},Gt=Object.keys(qt);function Yt(e,t){let{mixoutsTo:l}=t;return Xt=e,Ut={},Object.keys(qt).forEach(e=>{-1===Gt.indexOf(e)&&delete qt[e]}),Xt.forEach(e=>{const t=e.mixout?e.mixout():{};if(Object.keys(t).forEach(e=>{"function"===typeof t[e]&&(l[e]=t[e]),"object"===typeof t[e]&&Object.keys(t[e]).forEach(n=>{l[e]||(l[e]={}),l[e][n]=t[e][n]})}),e.hooks){const t=e.hooks();Object.keys(t).forEach(e=>{Ut[e]||(Ut[e]=[]),Ut[e].push(t[e])})}e.provides&&e.provides(qt)}),l}function Qt(e,t){for(var l=arguments.length,n=new Array(l>2?l-2:0),a=2;a{t=e.apply(null,[t,...n])}),t}function Zt(e){for(var t=arguments.length,l=new Array(t>1?t-1:0),n=1;n{e.apply(null,l)})}function Jt(){const e=arguments[0],t=Array.prototype.slice.call(arguments,1);return qt[e]?qt[e].apply(null,t):void 0}function el(e){"fa"===e.prefix&&(e.prefix="fas");let{iconName:t}=e;const l=e.prefix||Ot();if(t)return t=Nt(l,t)||t,st(tl.definitions,l,t)||st(lt.styles,l,t)}const tl=new Kt,ll=()=>{Oe.autoReplaceSvg=!1,Oe.observeMutations=!1,Zt("noAuto")},nl={i2svg:function(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return b?(Zt("beforeI2svg",e),Jt("pseudoElements2svg",e),Jt("i2svg",e)):Promise.reject(new Error("Operation requires a DOM of some kind."))},watch:function(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};const{autoReplaceSvgRoot:t}=e;!1===Oe.autoReplaceSvg&&(Oe.autoReplaceSvg=!0),Oe.observeMutations=!0,ct(()=>{cl({autoReplaceSvgRoot:t}),Zt("watch",e)})}},al={icon:e=>{if(null===e)return null;if("object"===typeof e&&e.prefix&&e.iconName)return{prefix:e.prefix,iconName:Nt(e.prefix,e.iconName)||e.iconName};if(Array.isArray(e)&&2===e.length){const t=0===e[1].indexOf("fa-")?e[1].slice(3):e[1],l=It(e[0]);return{prefix:l,iconName:Nt(l,t)||t}}if("string"===typeof e&&(e.indexOf("".concat(Oe.cssPrefix,"-"))>-1||e.match(Le))){const t=Vt(e.split(" "),{skipLookups:!0});return{prefix:t.prefix||Ot(),iconName:Nt(t.prefix,t.iconName)||t.iconName}}if("string"===typeof e){const t=Ot();return{prefix:t,iconName:Nt(t,e)||e}}}},ol={noAuto:ll,config:Oe,dom:nl,parse:al,library:tl,findIconDefinition:el,toHtml:rt},cl=function(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};const{autoReplaceSvgRoot:t=v}=e;(Object.keys(lt.styles).length>0||Oe.autoFetchSvg)&&b&&Oe.autoReplaceSvg&&ol.dom.i2svg({node:t})};function rl(e,t){return Object.defineProperty(e,"abstract",{get:t}),Object.defineProperty(e,"html",{get:function(){return e.abstract.map(e=>rt(e))}}),Object.defineProperty(e,"node",{get:function(){if(!b)return;const t=v.createElement("div");return t.innerHTML=e.html,t.children}}),e}function sl(e){let{children:t,main:l,mask:n,attributes:a,styles:c,transform:r}=e;if(Ue(r)&&l.found&&!n.found){const{width:e,height:t}=l,n={x:e/t/2,y:.5};a["style"]=Xe(o(o({},c),{},{"transform-origin":"".concat(n.x+r.x/16,"em ").concat(n.y+r.y/16,"em")}))}return[{tag:"svg",attributes:a,children:t}]}function il(e){let{prefix:t,iconName:l,children:n,attributes:a,symbol:c}=e;const r=!0===c?"".concat(t,"-").concat(Oe.cssPrefix,"-").concat(l):c;return[{tag:"svg",attributes:{style:"display: none;"},children:[{tag:"symbol",attributes:o(o({},a),{},{id:r}),children:n}]}]}function ul(e){const{icons:{main:t,mask:l},prefix:n,iconName:a,transform:c,symbol:r,title:s,maskId:i,titleId:u,extra:d,watchable:f=!1}=e,{width:p,height:m}=l.found?l:t,v=D.includes(n),h=[Oe.replacementClass,a?"".concat(Oe.cssPrefix,"-").concat(a):""].filter(e=>-1===d.classes.indexOf(e)).filter(e=>""!==e||!!e).concat(d.classes).join(" ");let g={children:[],attributes:o(o({},d.attributes),{},{"data-prefix":n,"data-icon":a,class:h,role:d.attributes.role||"img",xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 ".concat(p," ").concat(m)})};const b=v&&!~d.classes.indexOf("fa-fw")?{width:"".concat(p/m*16*.0625,"em")}:{};f&&(g.attributes[oe]=""),s&&(g.children.push({tag:"title",attributes:{id:g.attributes["aria-labelledby"]||"title-".concat(u||Pe())},children:[s]}),delete g.attributes.title);const y=o(o({},g),{},{prefix:n,iconName:a,main:t,mask:l,maskId:i,transform:c,symbol:r,styles:o(o({},b),d.styles)}),{children:C,attributes:w}=l.found&&t.found?Jt("generateAbstractMask",y)||{children:[],attributes:{}}:Jt("generateAbstractIcon",y)||{children:[],attributes:{}};return y.children=C,y.attributes=w,r?il(y):sl(y)}function dl(e){const{content:t,width:l,height:n,transform:a,title:c,extra:r,watchable:s=!1}=e,i=o(o(o({},r.attributes),c?{title:c}:{}),{},{class:r.classes.join(" ")});s&&(i[oe]="");const u=o({},r.styles);Ue(a)&&(u["transform"]=Ge({transform:a,startCentered:!0,width:l,height:n}),u["-webkit-transform"]=u["transform"]);const d=Xe(u);d.length>0&&(i["style"]=d);const f=[];return f.push({tag:"span",attributes:i,children:[t]}),c&&f.push({tag:"span",attributes:{class:"sr-only"},children:[c]}),f}function fl(e){const{content:t,title:l,extra:n}=e,a=o(o(o({},n.attributes),l?{title:l}:{}),{},{class:n.classes.join(" ")}),c=Xe(n.styles);c.length>0&&(a["style"]=c);const r=[];return r.push({tag:"span",attributes:a,children:[t]}),l&&r.push({tag:"span",attributes:{class:"sr-only"},children:[l]}),r}const{styles:pl}=lt;function ml(e){const t=e[0],l=e[1],[n]=e.slice(4);let a=null;return a=Array.isArray(n)?{tag:"g",attributes:{class:"".concat(Oe.cssPrefix,"-").concat(ke.GROUP)},children:[{tag:"path",attributes:{class:"".concat(Oe.cssPrefix,"-").concat(ke.SECONDARY),fill:"currentColor",d:n[0]}},{tag:"path",attributes:{class:"".concat(Oe.cssPrefix,"-").concat(ke.PRIMARY),fill:"currentColor",d:n[1]}}]}:{tag:"path",attributes:{fill:"currentColor",d:n}},{found:!0,width:t,height:l,icon:a}}const vl={found:!1,width:512,height:512};function hl(e,t){pe||Oe.showMissingIcons||!e||console.error('Icon with name "'.concat(e,'" and prefix "').concat(t,'" is missing.'))}function gl(e,t){let l=t;return"fa"===t&&null!==Oe.styleDefault&&(t=Ot()),new Promise((n,a)=>{if("fa"===l){const l=_t(e)||{};e=l.iconName||e,t=l.prefix||t}if(e&&t&&pl[t]&&pl[t][e]){const l=pl[t][e];return n(ml(l))}hl(e,t),n(o(o({},vl),{},{icon:Oe.showMissingIcons&&e&&Jt("missingIconAbstract")||{}}))})}const bl=()=>{},yl=Oe.measurePerformance&&g&&g.mark&&g.measure?g:{mark:bl,measure:bl},Cl='FA "6.7.2"',wl=e=>(yl.mark("".concat(Cl," ").concat(e," begins")),()=>Ll(e)),Ll=e=>{yl.mark("".concat(Cl," ").concat(e," ends")),yl.measure("".concat(Cl," ").concat(e),"".concat(Cl," ").concat(e," begins"),"".concat(Cl," ").concat(e," ends"))};var xl={begin:wl,end:Ll};const Ml=()=>{};function zl(e){const t=e.getAttribute?e.getAttribute(oe):null;return"string"===typeof t}function Rl(e){const t=e.getAttribute?e.getAttribute(se):null,l=e.getAttribute?e.getAttribute(ie):null;return t&&l}function kl(e){return e&&e.classList&&e.classList.contains&&e.classList.contains(Oe.replacementClass)}function Sl(){if(!0===Oe.autoReplaceSvg)return Tl.replace;const e=Tl[Oe.autoReplaceSvg];return e||Tl.replace}function El(e){return v.createElementNS("http://www.w3.org/2000/svg",e)}function Al(e){return v.createElement(e)}function Nl(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};const{ceFn:l=("svg"===e.tag?El:Al)}=t;if("string"===typeof e)return v.createTextNode(e);const n=l(e.tag);Object.keys(e.attributes||[]).forEach(function(t){n.setAttribute(t,e.attributes[t])});const a=e.children||[];return a.forEach(function(e){n.appendChild(Nl(e,{ceFn:l}))}),n}function _l(e){let t=" ".concat(e.outerHTML," ");return t="".concat(t,"Font Awesome fontawesome.com "),t}const Tl={replace:function(e){const t=e[0];if(t.parentNode)if(e[1].forEach(e=>{t.parentNode.insertBefore(Nl(e),t)}),null===t.getAttribute(oe)&&Oe.keepOriginalSource){let e=v.createComment(_l(t));t.parentNode.replaceChild(e,t)}else t.remove()},nest:function(e){const t=e[0],l=e[1];if(~He(t).indexOf(Oe.replacementClass))return Tl.replace(e);const n=new RegExp("".concat(Oe.cssPrefix,"-.*"));if(delete l[0].attributes.id,l[0].attributes.class){const e=l[0].attributes.class.split(" ").reduce((e,t)=>(t===Oe.replacementClass||t.match(n)?e.toSvg.push(t):e.toNode.push(t),e),{toNode:[],toSvg:[]});l[0].attributes.class=e.toSvg.join(" "),0===e.toNode.length?t.removeAttribute("class"):t.setAttribute("class",e.toNode.join(" "))}const a=l.map(e=>rt(e)).join("\n");t.setAttribute(oe,""),t.innerHTML=a}};function Ol(e){e()}function Wl(e,t){const l="function"===typeof t?t:Ml;if(0===e.length)l();else{let t=Ol;Oe.mutateApproach===de&&(t=m.requestAnimationFrame||Ol),t(()=>{const t=Sl(),n=xl.begin("mutate");e.map(t),n(),l()})}}let Bl=!1;function Il(){Bl=!0}function Dl(){Bl=!1}let Fl=null;function Vl(e){if(!h)return;if(!Oe.observeMutations)return;const{treeCallback:t=Ml,nodeCallback:l=Ml,pseudoElementsCallback:n=Ml,observeMutationsRoot:a=v}=e;Fl=new h(e=>{if(Bl)return;const a=Ot();$e(e).forEach(e=>{if("childList"===e.type&&e.addedNodes.length>0&&!zl(e.addedNodes[0])&&(Oe.searchPseudoElements&&n(e.target),t(e.target)),"attributes"===e.type&&e.target.parentNode&&Oe.searchPseudoElements&&n(e.target.parentNode),"attributes"===e.type&&zl(e.target)&&~Re.indexOf(e.attributeName))if("class"===e.attributeName&&Rl(e.target)){const{prefix:t,iconName:l}=Vt(He(e.target));e.target.setAttribute(se,t||a),l&&e.target.setAttribute(ie,l)}else kl(e.target)&&l(e.target)})}),b&&Fl.observe(a,{childList:!0,attributes:!0,characterData:!0,subtree:!0})}function Pl(){Fl&&Fl.disconnect()}function $l(e){const t=e.getAttribute("style");let l=[];return t&&(l=t.split(";").reduce((e,t)=>{const l=t.split(":"),n=l[0],a=l.slice(1);return n&&a.length>0&&(e[n]=a.join(":").trim()),e},{})),l}function Hl(e){const t=e.getAttribute("data-prefix"),l=e.getAttribute("data-icon"),n=void 0!==e.innerText?e.innerText.trim():"";let a=Vt(He(e));return a.prefix||(a.prefix=Ot()),t&&l&&(a.prefix=t,a.iconName=l),a.iconName&&a.prefix||(a.prefix&&n.length>0&&(a.iconName=At(a.prefix,e.innerText)||Et(a.prefix,ft(e.innerText))),!a.iconName&&Oe.autoFetchSvg&&e.firstChild&&e.firstChild.nodeType===Node.TEXT_NODE&&(a.iconName=e.firstChild.data)),a}function jl(e){const t=$e(e.attributes).reduce((e,t)=>("class"!==e.name&&"style"!==e.name&&(e[t.name]=t.value),e),{}),l=e.getAttribute("title"),n=e.getAttribute("data-fa-title-id");return Oe.autoA11y&&(l?t["aria-labelledby"]="".concat(Oe.replacementClass,"-title-").concat(n||Pe()):(t["aria-hidden"]="true",t["focusable"]="false")),t}function Kl(){return{iconName:null,title:null,titleId:null,prefix:null,transform:De,symbol:!1,mask:{iconName:null,prefix:null,rest:[]},maskId:null,extra:{classes:[],styles:{},attributes:{}}}}function Xl(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{styleParser:!0};const{iconName:l,prefix:n,rest:a}=Hl(e),c=jl(e),r=Qt("parseNodeAttributes",{},e);let s=t.styleParser?$l(e):[];return o({iconName:l,title:e.getAttribute("title"),titleId:e.getAttribute("data-fa-title-id"),prefix:n,transform:De,mask:{iconName:null,prefix:null,rest:[]},maskId:null,symbol:!1,extra:{classes:a,styles:s,attributes:c}},r)}const{styles:Ul}=lt;function ql(e){const t="nest"===Oe.autoReplaceSvg?Xl(e,{styleParser:!1}):Xl(e);return~t.extra.classes.indexOf(xe)?Jt("generateLayersText",e,t):Jt("generateSvgReplacementMutation",e,t)}function Gl(){return[...O,...G]}function Yl(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:null;if(!b)return Promise.resolve();const l=v.documentElement.classList,n=e=>l.add("".concat(ue,"-").concat(e)),a=e=>l.remove("".concat(ue,"-").concat(e)),o=Oe.autoFetchSvg?Gl():M.concat(Object.keys(Ul));o.includes("fa")||o.push("fa");const c=[".".concat(xe,":not([").concat(oe,"])")].concat(o.map(e=>".".concat(e,":not([").concat(oe,"])"))).join(", ");if(0===c.length)return Promise.resolve();let r=[];try{r=$e(e.querySelectorAll(c))}catch(u){}if(!(r.length>0))return Promise.resolve();n("pending"),a("complete");const s=xl.begin("onTree"),i=r.reduce((e,t)=>{try{const l=ql(t);l&&e.push(l)}catch(u){pe||"MissingIcon"===u.name&&console.error(u)}return e},[]);return new Promise((e,l)=>{Promise.all(i).then(l=>{Wl(l,()=>{n("active"),n("complete"),a("pending"),"function"===typeof t&&t(),s(),e()})}).catch(e=>{s(),l(e)})})}function Ql(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:null;ql(e).then(e=>{e&&Wl([e],t)})}function Zl(e){return function(t){let l=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};const n=(t||{}).icon?t:el(t||{});let{mask:a}=l;return a&&(a=(a||{}).icon?a:el(a||{})),e(n,o(o({},l),{},{mask:a}))}}const Jl=function(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};const{transform:l=De,symbol:n=!1,mask:a=null,maskId:c=null,title:r=null,titleId:s=null,classes:i=[],attributes:u={},styles:d={}}=t;if(!e)return;const{prefix:f,iconName:p,icon:m}=e;return rl(o({type:"icon"},e),()=>(Zt("beforeDOMElementCreation",{iconDefinition:e,params:t}),Oe.autoA11y&&(r?u["aria-labelledby"]="".concat(Oe.replacementClass,"-title-").concat(s||Pe()):(u["aria-hidden"]="true",u["focusable"]="false")),ul({icons:{main:ml(m),mask:a?ml(a.icon):{found:!1,width:null,height:null,icon:{}}},prefix:f,iconName:p,transform:o(o({},De),l),symbol:n,title:r,maskId:c,titleId:s,extra:{attributes:u,styles:d,classes:i}})))};var en={mixout(){return{icon:Zl(Jl)}},hooks(){return{mutationObserverCallbacks(e){return e.treeCallback=Yl,e.nodeCallback=Ql,e}}},provides(e){e.i2svg=function(e){const{node:t=v,callback:l=()=>{}}=e;return Yl(t,l)},e.generateSvgReplacementMutation=function(e,t){const{iconName:l,title:n,titleId:a,prefix:o,transform:c,symbol:r,mask:s,maskId:i,extra:u}=t;return new Promise((t,d)=>{Promise.all([gl(l,o),s.iconName?gl(s.iconName,s.prefix):Promise.resolve({found:!1,width:512,height:512,icon:{}})]).then(s=>{let[d,f]=s;t([e,ul({icons:{main:d,mask:f},prefix:o,iconName:l,transform:c,symbol:r,maskId:i,title:n,titleId:a,extra:u,watchable:!0})])}).catch(d)})},e.generateAbstractIcon=function(e){let{children:t,attributes:l,main:n,transform:a,styles:o}=e;const c=Xe(o);let r;return c.length>0&&(l["style"]=c),Ue(a)&&(r=Jt("generateAbstractTransformGrouping",{main:n,transform:a,containerWidth:n.width,iconWidth:n.width})),t.push(r||n.icon),{children:t,attributes:l}}}},tn={mixout(){return{layer(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};const{classes:l=[]}=t;return rl({type:"layer"},()=>{Zt("beforeDOMElementCreation",{assembler:e,params:t});let n=[];return e(e=>{Array.isArray(e)?e.map(e=>{n=n.concat(e.abstract)}):n=n.concat(e.abstract)}),[{tag:"span",attributes:{class:["".concat(Oe.cssPrefix,"-layers"),...l].join(" ")},children:n}]})}}}},ln={mixout(){return{counter(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};const{title:l=null,classes:n=[],attributes:a={},styles:o={}}=t;return rl({type:"counter",content:e},()=>(Zt("beforeDOMElementCreation",{content:e,params:t}),fl({content:e.toString(),title:l,extra:{attributes:a,styles:o,classes:["".concat(Oe.cssPrefix,"-layers-counter"),...n]}})))}}}},nn={mixout(){return{text(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};const{transform:l=De,title:n=null,classes:a=[],attributes:c={},styles:r={}}=t;return rl({type:"text",content:e},()=>(Zt("beforeDOMElementCreation",{content:e,params:t}),dl({content:e,transform:o(o({},De),l),title:n,extra:{attributes:c,styles:r,classes:["".concat(Oe.cssPrefix,"-layers-text"),...a]}})))}}},provides(e){e.generateLayersText=function(e,t){const{title:l,transform:n,extra:a}=t;let o=null,c=null;if(y){const t=parseInt(getComputedStyle(e).fontSize,10),l=e.getBoundingClientRect();o=l.width/t,c=l.height/t}return Oe.autoA11y&&!l&&(a.attributes["aria-hidden"]="true"),Promise.resolve([e,dl({content:e.innerHTML,width:o,height:c,transform:n,title:l,extra:a,watchable:!0})])}}};const an=new RegExp('"',"ug"),on=[1105920,1112319],cn=o(o(o(o({},{FontAwesome:{normal:"fas",400:"fas"}}),N),ee),j),rn=Object.keys(cn).reduce((e,t)=>(e[t.toLowerCase()]=cn[t],e),{}),sn=Object.keys(rn).reduce((e,t)=>{const l=rn[t];return e[t]=l[900]||[...Object.entries(l)][0][1],e},{});function un(e){const t=e.replace(an,""),l=pt(t,0),n=l>=on[0]&&l<=on[1],a=2===t.length&&t[0]===t[1];return{value:ft(a?t[0]:t),isSecondary:n||a}}function dn(e,t){const l=e.replace(/^['"]|['"]$/g,"").toLowerCase(),n=parseInt(t),a=isNaN(n)?"normal":n;return(rn[l]||{})[a]||sn[l]}function fn(e,t){const l="".concat(re).concat(t.replace(":","-"));return new Promise((n,a)=>{if(null!==e.getAttribute(l))return n();const c=$e(e.children),r=c.filter(e=>e.getAttribute(ce)===t)[0],s=m.getComputedStyle(e,t),i=s.getPropertyValue("font-family"),u=i.match(Me),d=s.getPropertyValue("font-weight"),f=s.getPropertyValue("content");if(r&&!u)return e.removeChild(r),n();if(u&&"none"!==f&&""!==f){const c=s.getPropertyValue("content");let f=dn(i,d);const{value:p,isSecondary:m}=un(c),h=u[0].startsWith("FontAwesome");let g=Et(f,p),b=g;if(h){const e=Tt(p);e.iconName&&e.prefix&&(g=e.iconName,f=e.prefix)}if(!g||m||r&&r.getAttribute(se)===f&&r.getAttribute(ie)===b)n();else{e.setAttribute(l,b),r&&e.removeChild(r);const c=Kl(),{extra:s}=c;s.attributes[ce]=t,gl(g,f).then(a=>{const r=ul(o(o({},c),{},{icons:{main:a,mask:Wt()},prefix:f,iconName:b,extra:s,watchable:!0})),i=v.createElementNS("http://www.w3.org/2000/svg","svg");"::before"===t?e.insertBefore(i,e.firstChild):e.appendChild(i),i.outerHTML=r.map(e=>rt(e)).join("\n"),e.removeAttribute(l),n()}).catch(a)}}else n()})}function pn(e){return Promise.all([fn(e,"::before"),fn(e,"::after")])}function mn(e){return e.parentNode!==document.head&&!~fe.indexOf(e.tagName.toUpperCase())&&!e.getAttribute(ce)&&(!e.parentNode||"svg"!==e.parentNode.tagName)}function vn(e){if(b)return new Promise((t,l)=>{const n=$e(e.querySelectorAll("*")).filter(mn).map(pn),a=xl.begin("searchPseudoElements");Il(),Promise.all(n).then(()=>{a(),Dl(),t()}).catch(()=>{a(),Dl(),l()})})}var hn={hooks(){return{mutationObserverCallbacks(e){return e.pseudoElementsCallback=vn,e}}},provides(e){e.pseudoElements2svg=function(e){const{node:t=v}=e;Oe.searchPseudoElements&&vn(t)}}};let gn=!1;var bn={mixout(){return{dom:{unwatch(){Il(),gn=!0}}}},hooks(){return{bootstrap(){Vl(Qt("mutationObserverCallbacks",{}))},noAuto(){Pl()},watch(e){const{observeMutationsRoot:t}=e;gn?Dl():Vl(Qt("mutationObserverCallbacks",{observeMutationsRoot:t}))}}}};const yn=e=>{let t={size:16,x:0,y:0,flipX:!1,flipY:!1,rotate:0};return e.toLowerCase().split(" ").reduce((e,t)=>{const l=t.toLowerCase().split("-"),n=l[0];let a=l.slice(1).join("-");if(n&&"h"===a)return e.flipX=!0,e;if(n&&"v"===a)return e.flipY=!0,e;if(a=parseFloat(a),isNaN(a))return e;switch(n){case"grow":e.size=e.size+a;break;case"shrink":e.size=e.size-a;break;case"left":e.x=e.x-a;break;case"right":e.x=e.x+a;break;case"up":e.y=e.y-a;break;case"down":e.y=e.y+a;break;case"rotate":e.rotate=e.rotate+a;break}return e},t)};var Cn={mixout(){return{parse:{transform:e=>yn(e)}}},hooks(){return{parseNodeAttributes(e,t){const l=t.getAttribute("data-fa-transform");return l&&(e.transform=yn(l)),e}}},provides(e){e.generateAbstractTransformGrouping=function(e){let{main:t,transform:l,containerWidth:n,iconWidth:a}=e;const c={transform:"translate(".concat(n/2," 256)")},r="translate(".concat(32*l.x,", ").concat(32*l.y,") "),s="scale(".concat(l.size/16*(l.flipX?-1:1),", ").concat(l.size/16*(l.flipY?-1:1),") "),i="rotate(".concat(l.rotate," 0 0)"),u={transform:"".concat(r," ").concat(s," ").concat(i)},d={transform:"translate(".concat(a/2*-1," -256)")},f={outer:c,inner:u,path:d};return{tag:"g",attributes:o({},f.outer),children:[{tag:"g",attributes:o({},f.inner),children:[{tag:t.icon.tag,children:t.icon.children,attributes:o(o({},t.icon.attributes),f.path)}]}]}}}};const wn={x:0,y:0,width:"100%",height:"100%"};function Ln(e){let t=!(arguments.length>1&&void 0!==arguments[1])||arguments[1];return e.attributes&&(e.attributes.fill||t)&&(e.attributes.fill="black"),e}function xn(e){return"g"===e.tag?e.children:[e]}var Mn={hooks(){return{parseNodeAttributes(e,t){const l=t.getAttribute("data-fa-mask"),n=l?Vt(l.split(" ").map(e=>e.trim())):Wt();return n.prefix||(n.prefix=Ot()),e.mask=n,e.maskId=t.getAttribute("data-fa-mask-id"),e}}},provides(e){e.generateAbstractMask=function(e){let{children:t,attributes:l,main:n,mask:a,maskId:c,transform:r}=e;const{width:s,icon:i}=n,{width:u,icon:d}=a,f=qe({transform:r,containerWidth:u,iconWidth:s}),p={tag:"rect",attributes:o(o({},wn),{},{fill:"white"})},m=i.children?{children:i.children.map(Ln)}:{},v={tag:"g",attributes:o({},f.inner),children:[Ln(o({tag:i.tag,attributes:o(o({},i.attributes),f.path)},m))]},h={tag:"g",attributes:o({},f.outer),children:[v]},g="mask-".concat(c||Pe()),b="clip-".concat(c||Pe()),y={tag:"mask",attributes:o(o({},wn),{},{id:g,maskUnits:"userSpaceOnUse",maskContentUnits:"userSpaceOnUse"}),children:[p,h]},C={tag:"defs",children:[{tag:"clipPath",attributes:{id:b},children:xn(d)},y]};return t.push(C,{tag:"rect",attributes:o({fill:"currentColor","clip-path":"url(#".concat(b,")"),mask:"url(#".concat(g,")")},wn)}),{children:t,attributes:l}}}},zn={provides(e){let t=!1;m.matchMedia&&(t=m.matchMedia("(prefers-reduced-motion: reduce)").matches),e.missingIconAbstract=function(){const e=[],l={fill:"currentColor"},n={attributeType:"XML",repeatCount:"indefinite",dur:"2s"};e.push({tag:"path",attributes:o(o({},l),{},{d:"M156.5,447.7l-12.6,29.5c-18.7-9.5-35.9-21.2-51.5-34.9l22.7-22.7C127.6,430.5,141.5,440,156.5,447.7z M40.6,272H8.5 c1.4,21.2,5.4,41.7,11.7,61.1L50,321.2C45.1,305.5,41.8,289,40.6,272z M40.6,240c1.4-18.8,5.2-37,11.1-54.1l-29.5-12.6 C14.7,194.3,10,216.7,8.5,240H40.6z M64.3,156.5c7.8-14.9,17.2-28.8,28.1-41.5L69.7,92.3c-13.7,15.6-25.5,32.8-34.9,51.5 L64.3,156.5z M397,419.6c-13.9,12-29.4,22.3-46.1,30.4l11.9,29.8c20.7-9.9,39.8-22.6,56.9-37.6L397,419.6z M115,92.4 c13.9-12,29.4-22.3,46.1-30.4l-11.9-29.8c-20.7,9.9-39.8,22.6-56.8,37.6L115,92.4z M447.7,355.5c-7.8,14.9-17.2,28.8-28.1,41.5 l22.7,22.7c13.7-15.6,25.5-32.9,34.9-51.5L447.7,355.5z M471.4,272c-1.4,18.8-5.2,37-11.1,54.1l29.5,12.6 c7.5-21.1,12.2-43.5,13.6-66.8H471.4z M321.2,462c-15.7,5-32.2,8.2-49.2,9.4v32.1c21.2-1.4,41.7-5.4,61.1-11.7L321.2,462z M240,471.4c-18.8-1.4-37-5.2-54.1-11.1l-12.6,29.5c21.1,7.5,43.5,12.2,66.8,13.6V471.4z M462,190.8c5,15.7,8.2,32.2,9.4,49.2h32.1 c-1.4-21.2-5.4-41.7-11.7-61.1L462,190.8z M92.4,397c-12-13.9-22.3-29.4-30.4-46.1l-29.8,11.9c9.9,20.7,22.6,39.8,37.6,56.9 L92.4,397z M272,40.6c18.8,1.4,36.9,5.2,54.1,11.1l12.6-29.5C317.7,14.7,295.3,10,272,8.5V40.6z M190.8,50 c15.7-5,32.2-8.2,49.2-9.4V8.5c-21.2,1.4-41.7,5.4-61.1,11.7L190.8,50z M442.3,92.3L419.6,115c12,13.9,22.3,29.4,30.5,46.1 l29.8-11.9C470,128.5,457.3,109.4,442.3,92.3z M397,92.4l22.7-22.7c-15.6-13.7-32.8-25.5-51.5-34.9l-12.6,29.5 C370.4,72.1,384.4,81.5,397,92.4z"})});const a=o(o({},n),{},{attributeName:"opacity"}),c={tag:"circle",attributes:o(o({},l),{},{cx:"256",cy:"364",r:"28"}),children:[]};return t||c.children.push({tag:"animate",attributes:o(o({},n),{},{attributeName:"r",values:"28;14;28;28;14;28;"})},{tag:"animate",attributes:o(o({},a),{},{values:"1;0;1;1;0;1;"})}),e.push(c),e.push({tag:"path",attributes:o(o({},l),{},{opacity:"1",d:"M263.7,312h-16c-6.6,0-12-5.4-12-12c0-71,77.4-63.9,77.4-107.8c0-20-17.8-40.2-57.4-40.2c-29.1,0-44.3,9.6-59.2,28.7 c-3.9,5-11.1,6-16.2,2.4l-13.1-9.2c-5.6-3.9-6.9-11.8-2.6-17.2c21.2-27.2,46.4-44.7,91.2-44.7c52.3,0,97.4,29.8,97.4,80.2 c0,67.6-77.4,63.5-77.4,107.8C275.7,306.6,270.3,312,263.7,312z"}),children:t?[]:[{tag:"animate",attributes:o(o({},a),{},{values:"1;0;0;0;0;1;"})}]}),t||e.push({tag:"path",attributes:o(o({},l),{},{opacity:"0",d:"M232.5,134.5l7,168c0.3,6.4,5.6,11.5,12,11.5h9c6.4,0,11.7-5.1,12-11.5l7-168c0.3-6.8-5.2-12.5-12-12.5h-23 C237.7,122,232.2,127.7,232.5,134.5z"}),children:[{tag:"animate",attributes:o(o({},a),{},{values:"0;0;1;1;0;0;"})}]}),{tag:"g",attributes:{class:"missing"},children:e}}}},Rn={hooks(){return{parseNodeAttributes(e,t){const l=t.getAttribute("data-fa-symbol"),n=null!==l&&(""===l||l);return e["symbol"]=n,e}}}},kn=[et,en,tn,ln,nn,hn,bn,Cn,Mn,zn,Rn];Yt(kn,{mixoutsTo:ol});ol.noAuto;const Sn=ol.config,En=ol.library,An=(ol.dom,ol.parse),Nn=(ol.findIconDefinition,ol.toHtml,ol.icon),_n=(ol.layer,ol.text);ol.counter},8951:function(e,t,l){"use strict";l.d(t,{c:function(){return Le},i:function(){return ze},r:function(){return be}});l(8111),l(1701),l(4114),l(2489),l(116),l(7588),l(3110),l(7642),l(8004),l(3853),l(5876),l(2475),l(5024),l(1698),l(8237),l(8335);const n=new Set(["title","titleTemplate","script","style","noscript"]),a=new Set(["base","meta","link","style","script","noscript"]),o=new Set(["title","titleTemplate","templateParams","base","htmlAttrs","bodyAttrs","meta","link","style","script","noscript"]),c=new Set(["base","title","titleTemplate","bodyAttrs","htmlAttrs","templateParams"]),r=new Set(["tagPosition","tagPriority","tagDuplicateStrategy","children","innerHTML","textContent","processTemplateParams"]),s="undefined"!==typeof window;function i(e){return e}function u(e){let t=9;for(let l=0;l>>9)).toString(16).substring(1,8).toLowerCase()}function d(e){if(e._h)return e._h;if(e._d)return u(e._d);let t=`${e.tag}:${e.textContent||e.innerHTML||""}:`;for(const l in e.props)t+=`${l}:${String(e.props[l])},`;return u(t)}const f=e=>({keyValue:e,metaKey:"property"}),p=e=>({keyValue:e}),m=(f("article:expiration_time"),f("article:modified_time"),f("article:published_time"),f("book:release_date"),f("fb:app_id"),p("msapplication-Config"),p("msapplication-TileColor"),p("msapplication-TileImage"),f("og:audio:secure_url"),f("og:audio"),f("og:image:secure_url"),f("og:image"),f("og:site_name"),f("og:video:secure_url"),f("og:video"),f("profile:first_name"),f("profile:last_name"),f("profile:username"),new Set(["og","book","article","profile"]));function v(e){const t=e.replace(/([A-Z])/g,"-$1").toLowerCase(),l=t.indexOf("-"),n=t.substring(0,l);return"twitter"===n||m.has(n)?e.replace(/([A-Z])/g,":$1").toLowerCase():t}function h(e,t){return e instanceof Promise?e.then(t):t(e)}function g(e,t,l,a){const o=a||C("object"!==typeof t||"function"===typeof t||t instanceof Promise?{["script"===e||"noscript"===e||"style"===e?"innerHTML":"textContent"]:t}:{...t},"templateParams"===e||"titleTemplate"===e);if(o instanceof Promise)return o.then(n=>g(e,t,l,n));const c={tag:e,props:o};for(const s of r){const e=void 0!==c.props[s]?c.props[s]:l[s];void 0!==e&&(("innerHTML"!==s&&"textContent"!==s&&"children"!==s||n.has(c.tag))&&(c["children"===s?"innerHTML":s]=e),delete c.props[s])}return c.props.body&&(c.tagPosition="bodyClose",delete c.props.body),"script"===c.tag&&"object"===typeof c.innerHTML&&(c.innerHTML=JSON.stringify(c.innerHTML),c.props.type=c.props.type||"application/json"),Array.isArray(c.props.content)?c.props.content.map(e=>({...c,props:{...c.props,content:e}})):c}function b(e,t){const l="class"===e?" ":";";return t&&"object"===typeof t&&!Array.isArray(t)&&(t=Object.entries(t).filter(([,e])=>e).map(([t,l])=>"style"===e?`${t}:${l}`:t)),String(Array.isArray(t)?t.join(l):t)?.split(l).filter(e=>Boolean(e.trim())).join(l)}function y(e,t,l,n){for(let a=n;a(e[n]=o,y(e,t,l,a)));if(!t&&!r.has(n)){const t=String(e[n]),l=n.startsWith("data-");"true"===t||""===t?e[n]=!l||"true":e[n]||(l&&"false"===t?e[n]="false":delete e[n])}}else e[n]=b(n,e[n])}}function C(e,t=!1){const l=y(e,t,Object.keys(e),0);return l instanceof Promise?l.then(()=>e):e}const w=10;function L(e,t,l){for(let n=l;n(t[n]=l,L(e,t,n)));Array.isArray(l)?e.push(...l):e.push(l)}}function x(e){const t=[],l=e.resolvedInput;for(const a in l){if(!Object.prototype.hasOwnProperty.call(l,a))continue;const n=l[a];if(void 0!==n&&o.has(a))if(Array.isArray(n))for(const l of n)t.push(g(a,l,e));else t.push(g(a,n,e))}if(0===t.length)return[];const n=[];return h(L(n,t,0),()=>n.map((t,l)=>(t._e=e._i,e.mode&&(t._m=e.mode),t._p=(e._i<{if(e===N||!o.includes(e))return e;const l=_(t,e.slice(1),n);return void 0!==l?l:e}).trim(),c&&(e.endsWith(N)&&(e=e.slice(0,-N.length)),e.startsWith(N)&&(e=e.slice(N.length)),e=e.replace(T,l).trim()),e}function W(e,t){return null==e?t||null:"function"===typeof e?e(t):e}async function B(e,t={}){const l=t.document||e.resolvedOptions.document;if(!l||!e.dirty)return;const n={shouldRender:!0,tags:[]};return await e.hooks.callHook("dom:beforeRender",n),n.shouldRender?(e._domUpdatePromise||(e._domUpdatePromise=new Promise(async t=>{const n=(await e.resolveTags()).map(e=>({tag:e,id:a.has(e.tag)?d(e):e.tag,shouldRender:!0}));let o=e._dom;if(!o){o={elMap:{htmlAttrs:l.documentElement,bodyAttrs:l.body}};const e=new Set;for(const t of["body","head"]){const n=l[t]?.children;for(const t of n){const l=t.tagName.toLowerCase();if(!a.has(l))continue;const n={tag:l,props:await C(t.getAttributeNames().reduce((e,l)=>({...e,[l]:t.getAttribute(l)}),{})),innerHTML:t.innerHTML},c=A(n);let r=c,s=1;while(r&&e.has(r))r=`${c}:${s++}`;r&&(n._d=r,e.add(r)),o.elMap[t.getAttribute("data-hid")||d(n)]=t}}}function c(e,t,l){const n=`${e}:${t}`;o.sideEffects[n]=l,delete o.pendingSideEffects[n]}function r({id:e,$el:t,tag:n}){const a=n.tag.endsWith("Attrs");if(o.elMap[e]=t,a||(n.textContent&&n.textContent!==t.textContent&&(t.textContent=n.textContent),n.innerHTML&&n.innerHTML!==t.innerHTML&&(t.innerHTML=n.innerHTML),c(e,"el",()=>{o.elMap[e]?.remove(),delete o.elMap[e]})),n._eventHandlers)for(const o in n._eventHandlers)Object.prototype.hasOwnProperty.call(n._eventHandlers,o)&&""!==t.getAttribute(`data-${o}`)&&(("bodyAttrs"===n.tag?l.defaultView:t).addEventListener(o.substring(2),n._eventHandlers[o].bind(t)),t.setAttribute(`data-${o}`,""));for(const l in n.props){if(!Object.prototype.hasOwnProperty.call(n.props,l))continue;const o=n.props[l],r=`attr:${l}`;if("class"===l){if(!o)continue;for(const l of o.split(" "))a&&c(e,`${r}:${l}`,()=>t.classList.remove(l)),!t.classList.contains(l)&&t.classList.add(l)}else if("style"===l){if(!o)continue;for(const l of o.split(";")){const n=l.indexOf(":"),a=l.substring(0,n).trim(),o=l.substring(n+1).trim();c(e,`${r}:${a}`,()=>{t.style.removeProperty(a)}),t.style.setProperty(a,o)}}else t.getAttribute(l)!==o&&t.setAttribute(l,!0===o?"":String(o)),a&&c(e,r,()=>t.removeAttribute(l))}}o.pendingSideEffects={...o.sideEffects},o.sideEffects={};const s=[],i={bodyClose:void 0,bodyOpen:void 0,head:void 0};for(const e of n){const{tag:t,shouldRender:n,id:c}=e;n&&("title"!==t.tag?(e.$el=e.$el||o.elMap[c],e.$el?r(e):a.has(t.tag)&&s.push(e)):l.title=t.textContent)}for(const e of s){const t=e.tag.tagPosition||"head";e.$el=l.createElement(e.tag.tag),r(e),i[t]=i[t]||l.createDocumentFragment(),i[t].appendChild(e.$el)}for(const a of n)await e.hooks.callHook("dom:renderTag",a,l,c);i.head&&l.head.appendChild(i.head),i.bodyOpen&&l.body.insertBefore(i.bodyOpen,l.body.firstChild),i.bodyClose&&l.body.appendChild(i.bodyClose);for(const e in o.pendingSideEffects)o.pendingSideEffects[e]();e._dom=o,await e.hooks.callHook("dom:rendered",{renders:n}),t()}).finally(()=>{e._domUpdatePromise=void 0,e.dirty=!1})),e._domUpdatePromise):void 0}function I(e,t={}){const l=t.delayFn||(e=>setTimeout(e,10));return e._domDebouncedUpdatePromise=e._domDebouncedUpdatePromise||new Promise(n=>l(()=>B(e,t).then(()=>{delete e._domDebouncedUpdatePromise,n()})))}function D(e){return i(t=>{const l=t.resolvedOptions.document?.head.querySelector('script[id="unhead:payload"]')?.innerHTML||!1;return l&&t.push(JSON.parse(l)),{mode:"client",hooks:{"entries:updated":t=>{I(t,e)}}}})}function F(e,t={},l){for(const n in e){const a=e[n],o=l?`${l}:${n}`:n;"object"===typeof a&&null!==a?F(a,t,o):"function"===typeof a&&(t[o]=a)}return t}const V={run:e=>e()},P=()=>V,$="undefined"!==typeof console.createTask?console.createTask:P;function H(e,t){const l=t.shift(),n=$(l);return e.reduce((e,l)=>e.then(()=>n.run(()=>l(...t))),Promise.resolve())}function j(e,t){const l=t.shift(),n=$(l);return Promise.all(e.map(e=>n.run(()=>e(...t))))}function K(e,t){for(const l of[...e])l(t)}class X{constructor(){this._hooks={},this._before=void 0,this._after=void 0,this._deprecatedMessages=void 0,this._deprecatedHooks={},this.hook=this.hook.bind(this),this.callHook=this.callHook.bind(this),this.callHookWith=this.callHookWith.bind(this)}hook(e,t,l={}){if(!e||"function"!==typeof t)return()=>{};const n=e;let a;while(this._deprecatedHooks[e])a=this._deprecatedHooks[e],e=a.to;if(a&&!l.allowDeprecated){let e=a.message;e||(e=`${n} hook has been deprecated`+(a.to?`, please use ${a.to}`:"")),this._deprecatedMessages||(this._deprecatedMessages=new Set),this._deprecatedMessages.has(e)||(console.warn(e),this._deprecatedMessages.add(e))}if(!t.name)try{Object.defineProperty(t,"name",{get:()=>"_"+e.replace(/\W+/g,"_")+"_hook_cb",configurable:!0})}catch{}return this._hooks[e]=this._hooks[e]||[],this._hooks[e].push(t),()=>{t&&(this.removeHook(e,t),t=void 0)}}hookOnce(e,t){let l,n=(...e)=>("function"===typeof l&&l(),l=void 0,n=void 0,t(...e));return l=this.hook(e,n),l}removeHook(e,t){if(this._hooks[e]){const l=this._hooks[e].indexOf(t);-1!==l&&this._hooks[e].splice(l,1),0===this._hooks[e].length&&delete this._hooks[e]}}deprecateHook(e,t){this._deprecatedHooks[e]="string"===typeof t?{to:t}:t;const l=this._hooks[e]||[];delete this._hooks[e];for(const n of l)this.hook(e,n)}deprecateHooks(e){Object.assign(this._deprecatedHooks,e);for(const t in e)this.deprecateHook(t,e[t])}addHooks(e){const t=F(e),l=Object.keys(t).map(e=>this.hook(e,t[e]));return()=>{for(const e of l.splice(0,l.length))e()}}removeHooks(e){const t=F(e);for(const l in t)this.removeHook(l,t[l])}removeAllHooks(){for(const e in this._hooks)delete this._hooks[e]}callHook(e,...t){return t.unshift(e),this.callHookWith(H,e,...t)}callHookParallel(e,...t){return t.unshift(e),this.callHookWith(j,e,...t)}callHookWith(e,t,...l){const n=this._before||this._after?{name:t,args:l,context:{}}:void 0;this._before&&K(this._before,n);const a=e(t in this._hooks?[...this._hooks[t]]:[],l);return a instanceof Promise?a.finally(()=>{this._after&&n&&K(this._after,n)}):(this._after&&n&&K(this._after,n),a)}beforeEach(e){return this._before=this._before||[],this._before.push(e),()=>{if(void 0!==this._before){const t=this._before.indexOf(e);-1!==t&&this._before.splice(t,1)}}}afterEach(e){return this._after=this._after||[],this._after.push(e),()=>{if(void 0!==this._after){const t=this._after.indexOf(e);-1!==t&&this._after.splice(t,1)}}}}function U(){return new X}const q=new Set(["templateParams","htmlAttrs","bodyAttrs"]),G=i({hooks:{"tag:normalise":({tag:e})=>{e.props.hid&&(e.key=e.props.hid,delete e.props.hid),e.props.vmid&&(e.key=e.props.vmid,delete e.props.vmid),e.props.key&&(e.key=e.props.key,delete e.props.key);const t=A(e);!t||t.startsWith("meta:og:")||t.startsWith("meta:twitter:")||delete e.key;const l=t||!!e.key&&`${e.tag}:${e.key}`;l&&(e._d=l)},"tags:resolve":e=>{const t=Object.create(null);for(const n of e.tags){const e=(n.key?`${n.tag}:${n.key}`:n._d)||d(n),l=t[e];if(l){let a=n?.tagDuplicateStrategy;if(!a&&q.has(n.tag)&&(a="merge"),"merge"===a){const a=l.props;a.style&&n.props.style&&(";"!==a.style[a.style.length-1]&&(a.style+=";"),n.props.style=`${a.style} ${n.props.style}`),a.class&&n.props.class?n.props.class=`${a.class} ${n.props.class}`:a.class&&(n.props.class=a.class),t[e].props={...a,...n.props};continue}if(n._e===l._e){l._duped=l._duped||[],n._d=`${l._d}:${l._duped.length+1}`,l._duped.push(n);continue}if(k(n)>k(l))continue}const o=n.innerHTML||n.textContent||0!==Object.keys(n.props).length;o||!a.has(n.tag)?t[e]=n:delete t[e]}const l=[];for(const n in t){const e=t[n],a=e._duped;l.push(e),a&&(delete e._duped,l.push(...a))}e.tags=l,e.tags=e.tags.filter(e=>!("meta"===e.tag&&(e.props.name||e.props.property)&&!e.props.content))}}}),Y=new Set(["script","link","bodyAttrs"]),Q=i(e=>({hooks:{"tags:resolve":t=>{for(const l of t.tags){if(!Y.has(l.tag))continue;const t=l.props;for(const n in t){if("o"!==n[0]||"n"!==n[1])continue;if(!Object.prototype.hasOwnProperty.call(t,n))continue;const a=t[n];"function"===typeof a&&(e.ssr&&M.has(n)?t[n]=`this.dataset.${n}fired = true`:delete t[n],l._eventHandlers=l._eventHandlers||{},l._eventHandlers[n]=a)}e.ssr&&l._eventHandlers&&(l.props.src||l.props.href)&&(l.key=l.key||u(l.props.src||l.props.href))}},"dom:renderTag":({$el:e,tag:t})=>{const l=e?.dataset;if(l)for(const n in l){if(!n.endsWith("fired"))continue;const l=n.slice(0,-5);M.has(l)&&t._eventHandlers?.[l]?.call(e,new Event(l.substring(2)))}}}})),Z=new Set(["link","style","script","noscript"]),J=i({hooks:{"tag:normalise":({tag:e})=>{e.key&&Z.has(e.tag)&&(e.props["data-hid"]=e._h=u(e.key))}}}),ee=i({mode:"server",hooks:{"tags:beforeResolve":e=>{const t={};let l=!1;for(const n of e.tags)"server"!==n._m||"titleTemplate"!==n.tag&&"templateParams"!==n.tag&&"title"!==n.tag||(t[n.tag]="title"===n.tag||"titleTemplate"===n.tag?n.textContent:n.props,l=!0);l&&e.tags.push({tag:"script",innerHTML:JSON.stringify(t),props:{id:"unhead:payload",type:"application/json"}})}}}),te=i({hooks:{"tags:resolve":e=>{for(const t of e.tags)if("string"===typeof t.tagPriority)for(const{prefix:l,offset:n}of S){if(!t.tagPriority.startsWith(l))continue;const a=t.tagPriority.substring(l.length),o=e.tags.find(e=>e._d===a)?._p;if(void 0!==o){t._p=o+n;break}}e.tags.sort((e,t)=>{const l=k(e),n=k(t);return ln?1:e._p-t._p})}}}),le={meta:"content",link:"href",htmlAttrs:"lang"},ne=["innerHTML","textContent"],ae=i(e=>({hooks:{"tags:resolve":t=>{const{tags:l}=t;let n;for(let e=0;e"title"===e.tag)?.textContent||"",a,o);for(const e of l){if(!1===e.processTemplateParams)continue;const t=le[e.tag];if(t&&"string"===typeof e.props[t])e.props[t]=O(e.props[t],a,o);else if(e.processTemplateParams||"titleTemplate"===e.tag||"title"===e.tag)for(const l of ne)"string"===typeof e[l]&&(e[l]=O(e[l],a,o,"script"===e.tag&&e.props.type.endsWith("json")))}e._templateParams=a,e._separator=o},"tags:afterResolve":({tags:t})=>{let l;for(let e=0;e{const{tags:t}=e;let l,n;for(let a=0;a{for(const t of e.tags)"string"===typeof t.innerHTML&&(!t.innerHTML||"application/ld+json"!==t.props.type&&"application/json"!==t.props.type?t.innerHTML=t.innerHTML.replace(new RegExp(`{r.dirty=!0,t.callHook("entries:updated",r)};let a=0,o=[];const c=[],r={plugins:c,dirty:!1,resolvedOptions:e,hooks:t,headEntries(){return o},use(e){const n="function"===typeof e?e(r):e;n.key&&c.some(e=>e.key===n.key)||(c.push(n),ie(n.mode,l)&&t.addHooks(n.hooks||{}))},push(e,t){delete t?.head;const c={_i:a++,input:e,...t};return ie(c.mode,l)&&(o.push(c),n()),{dispose(){o=o.filter(e=>e._i!==c._i),n()},patch(e){for(const t of o)t._i===c._i&&(t.input=c.input=e);n()}}},async resolveTags(){const e={tags:[],entries:[...o]};await t.callHook("entries:resolve",e);for(const l of e.entries){const n=l.resolvedInput||l.input;if(l.resolvedInput=await(l.transform?l.transform(n):n),l.resolvedInput)for(const a of await x(l)){const n={tag:a,entry:l,resolvedOptions:r.resolvedOptions};await t.callHook("tag:normalise",n),e.tags.push(n.tag)}}return await t.callHook("tags:beforeResolve",e),await t.callHook("tags:resolve",e),await t.callHook("tags:afterResolve",e),e.tags},ssr:l};return[G,ee,Q,J,te,ae,oe,ce,...e?.plugins||[]].forEach(e=>r.use(e)),r.hooks.callHook("init",r),r}function de(){return re}const fe=Symbol("ScriptProxyTarget");function pe(){}pe[fe]=!0;var me=l(6768),ve=l(144);const he="3"===me.rE[0];function ge(e){return"function"===typeof e?e():(0,ve.R1)(e)}function be(e){if(e instanceof Promise||e instanceof Date||e instanceof RegExp)return e;const t=ge(e);if(!e||!t)return t;if(Array.isArray(t))return t.map(e=>be(e));if("object"===typeof t){const e={};for(const l in t)Object.prototype.hasOwnProperty.call(t,l)&&("titleTemplate"===l||"o"===l[0]&&"n"===l[1]?e[l]=(0,ve.R1)(t[l]):e[l]=be(t[l]));return e}return t}const ye=i({hooks:{"entries:resolve":e=>{for(const t of e.entries)t.resolvedInput=be(t.input)}}}),Ce="usehead";function we(e){const t={install(t){he&&(t.config.globalProperties.$unhead=e,t.config.globalProperties.$head=e,t.provide(Ce,e))}};return t.install}function Le(e={}){e.domDelayFn=e.domDelayFn||(e=>(0,me.dY)(()=>setTimeout(()=>e(),0)));const t=se(e);return t.use(ye),t.install=we(t),t}const xe="undefined"!==typeof globalThis?globalThis:"undefined"!==typeof window?window:"undefined"!==typeof l.g?l.g:"undefined"!==typeof self?self:{},Me="__unhead_injection_handler__";function ze(){if(Me in xe)return xe[Me]();const e=(0,me.WQ)(Ce);return e||de()}},8981:function(e,t,l){"use strict";var n=l(7750),a=Object;e.exports=function(e){return a(n(e))}},9039:function(e){"use strict";e.exports=function(e){try{return!!e()}catch(t){return!0}}},9077:function(e,t,l){"use strict";l.d(t,{A:function(){return n}});var n=(e,t)=>{const l=e.__vccOpts||e;for(const[n,a]of t)l[n]=a;return l}},9078:function(e,t,l){"use strict";var n=l(3939);function a(e){var t=new e.constructor(e.byteLength);return new n.A(t).set(new n.A(e)),t}t.A=a},9092:function(e,t,l){"use strict";var n=l(9314),a=(0,n.A)(Object.getPrototypeOf,Object);t.A=a},9112:function(e,t,l){"use strict";var n=l(6518),a=l(3724),o=l(4576),c=l(7751),r=l(9504),s=l(9565),i=l(4901),u=l(34),d=l(4376),f=l(9297),p=l(655),m=l(6198),v=l(4659),h=l(9039),g=l(8235),b=l(4495),y=o.JSON,C=o.Number,w=o.SyntaxError,L=y&&y.parse,x=c("Object","keys"),M=Object.getOwnPropertyDescriptor,z=r("".charAt),R=r("".slice),k=r(/./.exec),S=r([].push),E=/^\d$/,A=/^[1-9]$/,N=/^[\d-]$/,_=/^[\t\n\r ]$/,T=0,O=1,W=function(e,t){e=p(e);var l=new F(e,0,""),n=l.parse(),a=n.value,o=l.skip(_,n.end);if(o`element-loading-${(0,o.Tg)(e)}`,s=(e,t)=>{var l,s,i,d;const f=t.instance,p=e=>(0,o.Gv)(t.value)?t.value[e]:void 0,m=e=>{const t=(0,o.Kg)(e)&&(null==f?void 0:f[e])||e;return(0,n.KR)(t)},v=t=>m(p(t)||e.getAttribute(r(t))),h=null!=(l=p("fullscreen"))?l:t.modifiers.fullscreen,g={text:v("text"),svg:v("svg"),svgViewBox:v("svgViewBox"),spinner:v("spinner"),background:v("background"),customClass:v("customClass"),fullscreen:h,target:null!=(s=p("target"))?s:h?void 0:e,body:null!=(i=p("body"))?i:t.modifiers.body,lock:null!=(d=p("lock"))?d:t.modifiers.lock},b=(0,a.A)(g);b._context=u._context,e[c]={options:g,instance:b}},i=(e,t)=>{for(const l of Object.keys(e))(0,n.i9)(e[l])&&(e[l].value=t[l])},u={mounted(e,t){t.value&&s(e,t)},updated(e,t){const l=e[c];if(!t.value)return null==l||l.instance.close(),void(e[c]=null);l?i(l.options,(0,o.Gv)(t.value)?t.value:{text:e.getAttribute(r("text")),svg:e.getAttribute(r("svg")),svgViewBox:e.getAttribute(r("svgViewBox")),spinner:e.getAttribute(r("spinner")),background:e.getAttribute(r("background")),customClass:e.getAttribute(r("customClass"))}):s(e,t)},unmounted(e){var t;null==(t=e[c])||t.instance.close(),e[c]=null},_context:null}},9143:function(e,t,l){"use strict";var n=l(4576),a=l(9504),o=l(3972),c=l(3463),r=l(9297),s=l(2804),i=l(944),u=l(5169),d=s.c2i,f=s.c2iUrl,p=n.SyntaxError,m=n.TypeError,v=a("".charAt),h=function(e,t){for(var l=e.length;t>16&255,a>>8&255,255&a];if(2===n){if(l&&0!==o[1])throw new p("Extra bits");return[o[0]]}if(3===n){if(l&&0!==o[2])throw new p("Extra bits");return[o[0],o[1]]}return o},b=function(e,t,l){for(var n=t.length,a=0;a0){if("stop-before-partial"===s)break;if("loose"!==s)throw new p("Missing padding");if(1===x.length)throw new p("Malformed padding: exactly one additional character");w=b(C,g(x,a,!1),w)}L=y;break}var z=v(e,M);if(++M,"="===z){if(x.length<2)throw new p("Padding is too early");if(M=h(e,M),2===x.length){if(M===y){if("stop-before-partial"===s)break;throw new p("Malformed padding: only one =")}"="===v(e,M)&&(++M,M=h(e,M))}if(M(e=(0,r.Tn)(e)?e():e,(0,r.cy)(e)?e.every(e=>!e):!e)}}),m=(e,t)=>{const l=(0,n.nI)()?(0,n.WQ)(i,(0,a.KR)({})):(0,a.KR)({}),c=(0,n.EW)(()=>e.emptyValues||l.value.emptyValues||d),p=(0,n.EW)(()=>(0,r.Tn)(e.valueOnClear)?e.valueOnClear():void 0!==e.valueOnClear?e.valueOnClear:(0,r.Tn)(l.value.valueOnClear)?l.value.valueOnClear():void 0!==l.value.valueOnClear?l.value.valueOnClear:void 0!==t?t:f),m=e=>{let t=!0;return t=(0,r.cy)(e)?c.value.some(t=>(0,o.A)(e,t)):c.value.includes(e),t};return m(p.value)||(0,s.U)(u,"value-on-clear should be a value of empty-values"),{emptyValues:c,valueOnClear:p,isEmptyValue:m}}},9195:function(e,t,l){"use strict";var n=l(7179);function a(e,t){return(0,n.A)(e,t)}t.A=a},9225:function(e,t,l){"use strict";var n,a,o,c,r=l(4576),s=l(8745),i=l(6080),u=l(4901),d=l(9297),f=l(9039),p=l(397),m=l(7680),v=l(4055),h=l(2812),g=l(9544),b=l(6193),y=r.setImmediate,C=r.clearImmediate,w=r.process,L=r.Dispatch,x=r.Function,M=r.MessageChannel,z=r.String,R=0,k={},S="onreadystatechange";f(function(){n=r.location});var E=function(e){if(d(k,e)){var t=k[e];delete k[e],t()}},A=function(e){return function(){E(e)}},N=function(e){E(e.data)},_=function(e){r.postMessage(z(e),n.protocol+"//"+n.host)};y&&C||(y=function(e){h(arguments.length,1);var t=u(e)?e:x(e),l=m(arguments,1);return k[++R]=function(){s(t,void 0,l)},a(R),R},C=function(e){delete k[e]},b?a=function(e){w.nextTick(A(e))}:L&&L.now?a=function(e){L.now(A(e))}:M&&!g?(o=new M,c=o.port2,o.port1.onmessage=N,a=i(c.postMessage,c)):r.addEventListener&&u(r.postMessage)&&!r.importScripts&&n&&"file:"!==n.protocol&&!f(_)?(a=_,r.addEventListener("message",N,!1)):a=S in v("script")?function(e){p.appendChild(v("script"))[S]=function(){p.removeChild(this),E(e)}}:function(e){setTimeout(A(e),0)}),e.exports={set:y,clear:C}},9267:function(e,t,l){"use strict";l.d(t,{kZ:function(){return N}});var n=l(6768),a=l(144),o=l(5130),c=l(4232),r=l(6714),s=l(6834),i=l(8769),u=l(813),d=l(8724),f=l(5513),p=l(9077),m=l(3291),v=l(7833),h=l(464),g=l(4425),b=l(6268);const y=(0,n.pM)({name:"ElDialogContent"}),C=(0,n.pM)({...y,props:f.Q,emits:f.k,setup(e,{expose:t}){const l=e,{t:o}=(0,b.Ym)(),{Close:r}=h.H2,{dialogRef:s,headerRef:i,bodyId:f,ns:p,style:y}=(0,n.WQ)(d.Z),{focusTrapRef:C}=(0,n.WQ)(m.r3),w=(0,g.t)(C,s),L=(0,n.EW)(()=>!!l.draggable),x=(0,n.EW)(()=>!!l.overflow),{resetPosition:M,updatePosition:z,isDragging:R}=(0,v.P)(s,i,L,x),k=(0,n.EW)(()=>[p.b(),p.is("fullscreen",l.fullscreen),p.is("draggable",L.value),p.is("dragging",R.value),p.is("align-center",!!l.alignCenter),{[p.m("center")]:l.center}]);return t({resetPosition:M,updatePosition:z}),(e,t)=>((0,n.uX)(),(0,n.CE)("div",{ref:(0,a.R1)(w),class:(0,c.C4)((0,a.R1)(k)),style:(0,c.Tr)((0,a.R1)(y)),tabindex:"-1"},[(0,n.Lk)("header",{ref_key:"headerRef",ref:i,class:(0,c.C4)([(0,a.R1)(p).e("header"),e.headerClass,{"show-close":e.showClose}])},[(0,n.RG)(e.$slots,"header",{},()=>[(0,n.Lk)("span",{role:"heading","aria-level":e.ariaLevel,class:(0,c.C4)((0,a.R1)(p).e("title"))},(0,c.v_)(e.title),11,["aria-level"])]),e.showClose?((0,n.uX)(),(0,n.CE)("button",{key:0,"aria-label":(0,a.R1)(o)("el.dialog.close"),class:(0,c.C4)((0,a.R1)(p).e("headerbtn")),type:"button",onClick:t=>e.$emit("close")},[(0,n.bF)((0,a.R1)(u.tk),{class:(0,c.C4)((0,a.R1)(p).e("close"))},{default:(0,n.k6)(()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)(e.closeIcon||(0,a.R1)(r))))]),_:1},8,["class"])],10,["aria-label","onClick"])):(0,n.Q3)("v-if",!0)],2),(0,n.Lk)("div",{id:(0,a.R1)(f),class:(0,c.C4)([(0,a.R1)(p).e("body"),e.bodyClass])},[(0,n.RG)(e.$slots,"default")],10,["id"]),e.$slots.footer?((0,n.uX)(),(0,n.CE)("footer",{key:0,class:(0,c.C4)([(0,a.R1)(p).e("footer"),e.footerClass])},[(0,n.RG)(e.$slots,"footer")],2)):(0,n.Q3)("v-if",!0)],6))}});var w=(0,p.A)(C,[["__file","dialog-content.vue"]]),L=l(7201),x=l(3711),M=l(261),z=l(3513),R=l(1968);const k=(0,n.pM)({name:"ElDialog",inheritAttrs:!1}),S=(0,n.pM)({...k,props:L.z5,emits:L.Pg,setup(e,{expose:t}){const l=e,u=(0,n.Ht)();(0,M.b)({scope:"el-dialog",from:"the title slot",replacement:"the header slot",version:"3.0.0",ref:"https://element-plus.org/en-US/component/dialog.html#slots"},(0,n.EW)(()=>!!u.title));const f=(0,z.DU)("dialog"),p=(0,a.KR)(),m=(0,a.KR)(),v=(0,a.KR)(),{visible:h,titleId:g,bodyId:b,style:y,overlayDialogStyle:C,rendered:L,transitionConfig:k,zIndex:S,_draggable:E,_alignCenter:A,_overflow:N,handleClose:_,onModalClick:T,onOpenAutoFocus:O,onCloseAutoFocus:W,onCloseRequested:B,onFocusoutPrevented:I}=(0,x.s)(l,p);(0,n.Gt)(d.Z,{dialogRef:p,headerRef:m,bodyId:b,ns:f,rendered:L,style:y});const D=(0,R.r)(T),F=(0,n.EW)(()=>l.modalPenetrable&&!l.modal&&!l.fullscreen),V=()=>{var e;null==(e=v.value)||e.resetPosition()};return t({visible:h,dialogContentRef:v,resetPosition:V,handleClose:_}),(e,t)=>((0,n.uX)(),(0,n.Wv)((0,a.R1)(i.Nr),{to:e.appendTo,disabled:"body"===e.appendTo&&!e.appendToBody},{default:(0,n.k6)(()=>[(0,n.bF)(o.eB,(0,n.v6)((0,a.R1)(k),{persisted:""}),{default:(0,n.k6)(()=>{var t;return[(0,n.bo)((0,n.bF)((0,a.R1)(r._q),{"custom-mask-event":"",mask:e.modal,"overlay-class":[null!=(t=e.modalClass)?t:"",`${(0,a.R1)(f).namespace.value}-modal-dialog`,(0,a.R1)(f).is("penetrable",(0,a.R1)(F))],"z-index":(0,a.R1)(S)},{default:(0,n.k6)(()=>[(0,n.Lk)("div",{role:"dialog","aria-modal":"true","aria-label":e.title||void 0,"aria-labelledby":e.title?void 0:(0,a.R1)(g),"aria-describedby":(0,a.R1)(b),class:(0,c.C4)(`${(0,a.R1)(f).namespace.value}-overlay-dialog`),style:(0,c.Tr)((0,a.R1)(C)),onClick:(0,a.R1)(D).onClick,onMousedown:(0,a.R1)(D).onMousedown,onMouseup:(0,a.R1)(D).onMouseup},[(0,n.bF)((0,a.R1)(s.A),{loop:"",trapped:(0,a.R1)(h),"focus-start-el":"container",onFocusAfterTrapped:(0,a.R1)(O),onFocusAfterReleased:(0,a.R1)(W),onFocusoutPrevented:(0,a.R1)(I),onReleaseRequested:(0,a.R1)(B)},{default:(0,n.k6)(()=>[(0,a.R1)(L)?((0,n.uX)(),(0,n.Wv)(w,(0,n.v6)({key:0,ref_key:"dialogContentRef",ref:v},e.$attrs,{center:e.center,"align-center":(0,a.R1)(A),"close-icon":e.closeIcon,draggable:(0,a.R1)(E),overflow:(0,a.R1)(N),fullscreen:e.fullscreen,"header-class":e.headerClass,"body-class":e.bodyClass,"footer-class":e.footerClass,"show-close":e.showClose,title:e.title,"aria-level":e.headerAriaLevel,onClose:(0,a.R1)(_)}),(0,n.eX)({header:(0,n.k6)(()=>[e.$slots.title?(0,n.RG)(e.$slots,"title",{key:1}):(0,n.RG)(e.$slots,"header",{key:0,close:(0,a.R1)(_),titleId:(0,a.R1)(g),titleClass:(0,a.R1)(f).e("title")})]),default:(0,n.k6)(()=>[(0,n.RG)(e.$slots,"default")]),_:2},[e.$slots.footer?{name:"footer",fn:(0,n.k6)(()=>[(0,n.RG)(e.$slots,"footer")])}:void 0]),1040,["center","align-center","close-icon","draggable","overflow","fullscreen","header-class","body-class","footer-class","show-close","title","aria-level","onClose"])):(0,n.Q3)("v-if",!0)]),_:3},8,["trapped","onFocusAfterTrapped","onFocusAfterReleased","onFocusoutPrevented","onReleaseRequested"])],46,["aria-label","aria-labelledby","aria-describedby","onClick","onMousedown","onMouseup"])]),_:3},8,["mask","overlay-class","z-index"]),[[o.aG,(0,a.R1)(h)]])]}),_:3},16)]),_:3},8,["to","disabled"]))}});var E=(0,p.A)(S,[["__file","dialog.vue"]]),A=l(5376);const N=(0,A.GU)(E)},9286:function(e,t,l){"use strict";var n=l(4402),a=l(8469),o=n.Set,c=n.add;e.exports=function(e){var t=new o;return a(e,function(e){c(t,e)}),t}},9297:function(e,t,l){"use strict";var n=l(9504),a=l(8981),o=n({}.hasOwnProperty);e.exports=Object.hasOwn||function(e,t){return o(a(e),t)}},9306:function(e,t,l){"use strict";var n=l(4901),a=l(6823),o=TypeError;e.exports=function(e){if(n(e))return e;throw new o(a(e)+" is not a function")}},9309:function(e,t,l){"use strict";var n=l(6518),a=l(4576),o=l(9225).set,c=l(9472),r=a.setImmediate?c(o,!1):o;n({global:!0,bind:!0,enumerable:!0,forced:a.setImmediate!==r},{setImmediate:r})},9314:function(e,t){"use strict";function l(e,t){return function(l){return e(t(l))}}t.A=l},9429:function(e,t,l){"use strict";var n=l(4576),a=l(6193);e.exports=function(e){if(a){try{return n.process.getBuiltinModule(e)}catch(t){}try{return Function('return require("'+e+'")')()}catch(t){}}}},9433:function(e,t,l){"use strict";var n=l(4576),a=Object.defineProperty;e.exports=function(e,t){try{a(n,e,{value:t,configurable:!0,writable:!0})}catch(l){n[e]=t}return t}},9462:function(e,t,l){"use strict";var n=l(9565),a=l(2360),o=l(6699),c=l(6279),r=l(8227),s=l(1181),i=l(5966),u=l(7657).IteratorPrototype,d=l(2529),f=l(9539),p=l(1385),m=r("toStringTag"),v="IteratorHelper",h="WrapForValidIterator",g="normal",b="throw",y=s.set,C=function(e){var t=s.getterFor(e?h:v);return c(a(u),{next:function(){var l=t(this);if(e)return l.nextHandler();if(l.done)return d(void 0,!0);try{var n=l.nextHandler();return l.returnHandlerResult?n:d(n,l.done)}catch(a){throw l.done=!0,a}},return:function(){var l=t(this),a=l.iterator;if(l.done=!0,e){var o=i(a,"return");return o?n(o,a):d(void 0,!0)}if(l.inner)try{f(l.inner.iterator,g)}catch(c){return f(a,b,c)}if(l.openIters)try{p(l.openIters,g)}catch(c){return f(a,b,c)}return a&&f(a,g),d(void 0,!0)}})},w=C(!0),L=C(!1);o(L,m,"Iterator Helper"),e.exports=function(e,t,l){var n=function(n,a){a?(a.iterator=n.iterator,a.next=n.next):a=n,a.type=t?h:v,a.returnHandlerResult=!!l,a.nextHandler=e,a.counter=0,a.done=!1,y(this,a)};return n.prototype=t?w:L,n}},9472:function(e,t,l){"use strict";var n=l(4576),a=l(8745),o=l(4901),c=l(4215),r=l(2839),s=l(7680),i=l(2812),u=n.Function,d=/MSIE .\./.test(r)||"BUN"===c&&function(){var e=n.Bun.version.split(".");return e.length<3||"0"===e[0]&&(e[1]<3||"3"===e[1]&&"0"===e[2])}();e.exports=function(e,t){var l=t?2:1;return d?function(n,c){var r=i(arguments.length,1)>l,d=o(n)?n:u(n),f=r?s(arguments,l):[],p=r?function(){a(d,this,f)}:d;return t?e(p,c):e(p)}:e}},9486:function(e,t,l){"use strict";var n=l(6518),a=l(4576),o=l(9504),c=l(3972),r=l(4154),s=l(5169),i=l(2804),u=l(944),d=i.i2c,f=i.i2cUrl,p=o("".charAt),m=a.Uint8Array,v=!m||!m.prototype.toBase64||!function(){try{var e=new m;e.toBase64(null)}catch(t){return!0}}();m&&n({target:"Uint8Array",proto:!0,forced:v},{toBase64:function(){var e=r(this),t=arguments.length?c(arguments[0]):void 0,l="base64"===u(t)?d:f,n=!!t&&!!t.omitPadding;s(this.buffer);for(var a,o="",i=0,m=e.length,v=function(e){return p(l,a>>6*e&63)};i+20&&n[0]<4?1:+(n[0]+n[1])),!a&&c&&(n=c.match(/Edge\/(\d+)/),(!n||n[1]>=74)&&(n=c.match(/Chrome\/(\d+)/),n&&(a=+n[1]))),e.exports=a},9539:function(e,t,l){"use strict";var n=l(9565),a=l(8551),o=l(5966);e.exports=function(e,t,l){var c,r;a(e);try{if(c=o(e,"return"),!c){if("throw"===t)throw l;return l}c=n(c,e)}catch(s){r=!0,c=s}if("throw"===t)throw l;if(r)throw c;return a(c),l}},9544:function(e,t,l){"use strict";var n=l(2839);e.exports=/(?:ipad|iphone|ipod).*applewebkit/i.test(n)},9559:function(e,t,l){"use strict";l.d(t,{KR:function(){return w}});var n=l(6768),a=l(144),o=l(5130),c=l(4232),r=l(813),s=l(464),i=l(7378),u=l(4340);const d=["light","dark"],f=(0,i.b_)({title:{type:String,default:""},description:{type:String,default:""},type:{type:String,values:(0,u.YD)(s.rz),default:"info"},closable:{type:Boolean,default:!0},closeText:{type:String,default:""},showIcon:Boolean,center:Boolean,effect:{type:String,values:d,default:"light"},showAfter:Number,hideAfter:Number,autoClose:Number}),p={close:e=>e instanceof MouseEvent};var m=l(9077),v=l(3513),h=l(6894);const g=(0,n.pM)({name:"ElAlert"}),b=(0,n.pM)({...g,props:f,emits:p,setup(e,{emit:t}){const l=e,{Close:i}=s.Nk,u=(0,n.Ht)(),d=(0,v.DU)("alert"),f=(0,a.KR)(!0),p=(0,n.EW)(()=>s.rz[l.type]),m=(0,n.EW)(()=>!(!l.description&&!u.default)),g=e=>{f.value=!1,t("close",e)};return(l.showAfter||l.hideAfter||l.autoClose)&&(0,h.U)("el-alert","The `show-after`, `hide-after`, and `auto-close` attributes were removed after 2.11.8. Please use `v-if` and `v-show` to manually replace them, visit: https://github.com/element-plus/element-plus/pull/22560"),(e,t)=>((0,n.uX)(),(0,n.Wv)(o.eB,{name:(0,a.R1)(d).b("fade"),persisted:""},{default:(0,n.k6)(()=>[(0,n.bo)((0,n.Lk)("div",{class:(0,c.C4)([(0,a.R1)(d).b(),(0,a.R1)(d).m(e.type),(0,a.R1)(d).is("center",e.center),(0,a.R1)(d).is(e.effect)]),role:"alert"},[e.showIcon&&(e.$slots.icon||(0,a.R1)(p))?((0,n.uX)(),(0,n.Wv)((0,a.R1)(r.tk),{key:0,class:(0,c.C4)([(0,a.R1)(d).e("icon"),(0,a.R1)(d).is("big",(0,a.R1)(m))])},{default:(0,n.k6)(()=>[(0,n.RG)(e.$slots,"icon",{},()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)((0,a.R1)(p))))])]),_:3},8,["class"])):(0,n.Q3)("v-if",!0),(0,n.Lk)("div",{class:(0,c.C4)((0,a.R1)(d).e("content"))},[e.title||e.$slots.title?((0,n.uX)(),(0,n.CE)("span",{key:0,class:(0,c.C4)([(0,a.R1)(d).e("title"),{"with-description":(0,a.R1)(m)}])},[(0,n.RG)(e.$slots,"title",{},()=>[(0,n.eW)((0,c.v_)(e.title),1)])],2)):(0,n.Q3)("v-if",!0),(0,a.R1)(m)?((0,n.uX)(),(0,n.CE)("p",{key:1,class:(0,c.C4)((0,a.R1)(d).e("description"))},[(0,n.RG)(e.$slots,"default",{},()=>[(0,n.eW)((0,c.v_)(e.description),1)])],2)):(0,n.Q3)("v-if",!0),e.closable?((0,n.uX)(),(0,n.CE)(n.FK,{key:2},[e.closeText?((0,n.uX)(),(0,n.CE)("div",{key:0,class:(0,c.C4)([(0,a.R1)(d).e("close-btn"),(0,a.R1)(d).is("customed")]),onClick:g},(0,c.v_)(e.closeText),3)):((0,n.uX)(),(0,n.Wv)((0,a.R1)(r.tk),{key:1,class:(0,c.C4)((0,a.R1)(d).e("close-btn")),onClick:g},{default:(0,n.k6)(()=>[(0,n.bF)((0,a.R1)(i))]),_:1},8,["class"]))],64)):(0,n.Q3)("v-if",!0)],2)],2),[[o.aG,f.value]])]),_:3},8,["name"]))}});var y=(0,m.A)(b,[["__file","alert.vue"]]),C=l(5376);const w=(0,C.GU)(y)},9565:function(e,t,l){"use strict";var n=l(616),a=Function.prototype.call;e.exports=n?a.bind(a):function(){return a.apply(a,arguments)}},9577:function(e,t,l){"use strict";var n=l(9928),a=l(4644),o=l(1108),c=l(1291),r=l(5854),s=a.aTypedArray,i=a.getTypedArrayConstructor,u=a.exportTypedArrayMethod,d=function(){try{new Int8Array(1)["with"](2,{valueOf:function(){throw 8}})}catch(e){return 8===e}}(),f=d&&function(){try{new Int8Array(1)["with"](-.5,1)}catch(e){return!0}}();u("with",{with:function(e,t){var l=s(this),a=c(e),u=o(l)?r(t):+t;return n(l,i(l),a,u)}}["with"],!d||f)},9578:function(e,t,l){"use strict";var n=l(339),a="object"==typeof self&&self&&self.Object===Object&&self,o=n.A||a||Function("return this")();t.A=o},9606:function(e,t){"use strict";function l(e,t){var l=-1,n=e.length;t||(t=Array(n));while(++lu)if(i=r[u++],i!==i)return!0}else for(;s>u;u++)if((e||u in r)&&r[u]===l)return e||u||0;return!e&&-1}};e.exports={includes:c(!0),indexOf:c(!1)}},9623:function(e,t,l){"use strict";l.d(t,{WK:function(){return I}});var n=l(6768),a=l(144),o=l(4232),c=l(5130),r=l(7687),s=l(17),i=l(6032),u=l(813),d=l(7477),f=(l(8111),l(7588),l(2808)),p=l(2235);let m;const v={height:"0",visibility:"hidden",overflow:(0,f.gm)()?"":"hidden",position:"absolute","z-index":"-1000",top:"0",right:"0"},h=["letter-spacing","line-height","padding-top","padding-bottom","font-family","font-weight","font-size","text-rendering","text-transform","width","text-indent","padding-left","padding-right","border-width","box-sizing","word-break"],g=e=>{const t=Number.parseFloat(e);return Number.isNaN(t)?e:t};function b(e){const t=window.getComputedStyle(e),l=t.getPropertyValue("box-sizing"),n=Number.parseFloat(t.getPropertyValue("padding-bottom"))+Number.parseFloat(t.getPropertyValue("padding-top")),a=Number.parseFloat(t.getPropertyValue("border-bottom-width"))+Number.parseFloat(t.getPropertyValue("border-top-width")),o=h.map(e=>[e,t.getPropertyValue(e)]);return{contextStyle:o,paddingSize:n,borderSize:a,boxSizing:l}}function y(e,t=1,l){var n,a;m||(m=document.createElement("textarea"),(null!=(n=e.parentNode)?n:document.body).appendChild(m));const{paddingSize:o,borderSize:c,boxSizing:r,contextStyle:s}=b(e);s.forEach(([e,t])=>null==m?void 0:m.style.setProperty(e,t)),Object.entries(v).forEach(([e,t])=>null==m?void 0:m.style.setProperty(e,t,"important")),m.value=e.value||e.placeholder||"";let i=m.scrollHeight;const u={};"border-box"===r?i+=c:"content-box"===r&&(i-=o),m.value="";const d=m.scrollHeight-o;if((0,p.Et)(t)){let e=d*t;"border-box"===r&&(e=e+o+c),i=Math.max(e,i),u.minHeight=`${e}px`}if((0,p.Et)(l)){let e=d*l;"border-box"===r&&(e=e+o+c),i=Math.min(e,i)}return u.height=`${i}px`,null==(a=m.parentNode)||a.removeChild(m),m=void 0,u}var C=l(6149),w=l(9077),L=l(3716),x=l(4216),M=l(2436),z=l(1939),R=l(464),k=l(5488),S=l(2056);function E(e){let t;function l(){if(void 0==e.value)return;const{selectionStart:l,selectionEnd:n,value:a}=e.value;if(null==l||null==n)return;const o=a.slice(0,Math.max(0,l)),c=a.slice(Math.max(0,n));t={selectionStart:l,selectionEnd:n,value:a,beforeTxt:o,afterTxt:c}}function n(){if(void 0==e.value||void 0==t)return;const{value:l}=e.value,{beforeTxt:n,afterTxt:a,selectionStart:o}=t;if(void 0==n||void 0==a||void 0==o)return;let c=l.length;if(l.endsWith(a))c=l.length-a.length;else if(l.startsWith(n))c=n.length;else{const e=n[o-1],t=l.indexOf(e,o-1);-1!==t&&(c=t+1)}e.value.setSelectionRange(c,c)}return[l,n]}var A=l(3513),N=l(6894);const _="ElInput",T=(0,n.pM)({name:_,inheritAttrs:!1}),O=(0,n.pM)({...T,props:C.$,emits:C.p,setup(e,{expose:t,emit:l}){const f=e,p=(0,n.OA)(),m=(0,L.O)(),v=(0,n.Ht)(),h=(0,n.EW)(()=>["textarea"===f.type?I.b():B.b(),B.m(O.value),B.is("disabled",W.value),B.is("exceed",ce.value),{[B.b("group")]:v.prepend||v.append,[B.m("prefix")]:v.prefix||f.prefixIcon,[B.m("suffix")]:v.suffix||f.suffixIcon||f.clearable||f.showPassword,[B.bm("suffix","password-clear")]:le.value&&ne.value,[B.b("hidden")]:"hidden"===f.type},p.class]),b=(0,n.EW)(()=>[B.e("wrapper"),B.is("focus",X.value)]),{form:C,formItem:w}=(0,x.j)(),{inputId:T}=(0,x.W)(f,{formItemContext:w}),O=(0,M.NV)(),W=(0,M.CB)(),B=(0,A.DU)("input"),I=(0,A.DU)("textarea"),D=(0,a.IJ)(),F=(0,a.IJ)(),V=(0,a.KR)(!1),P=(0,a.KR)(!1),$=(0,a.KR)(),H=(0,a.IJ)(f.inputStyle),j=(0,n.EW)(()=>D.value||F.value),{wrapperRef:K,isFocused:X,handleFocus:U,handleBlur:q}=(0,z.K)(j,{disabled:W,afterBlur(){var e;f.validateEvent&&(null==(e=null==w?void 0:w.validate)||e.call(w,"blur").catch(e=>(0,N.U)(e)))}}),G=(0,n.EW)(()=>{var e;return null!=(e=null==C?void 0:C.statusIcon)&&e}),Y=(0,n.EW)(()=>(null==w?void 0:w.validateState)||""),Q=(0,n.EW)(()=>Y.value&&R.vK[Y.value]),Z=(0,n.EW)(()=>P.value?d.View:d.Hide),J=(0,n.EW)(()=>[p.style]),ee=(0,n.EW)(()=>[f.inputStyle,H.value,{resize:f.resize}]),te=(0,n.EW)(()=>(0,i.A)(f.modelValue)?"":String(f.modelValue)),le=(0,n.EW)(()=>f.clearable&&!W.value&&!f.readonly&&!!te.value&&(X.value||V.value)),ne=(0,n.EW)(()=>f.showPassword&&!W.value&&!!te.value),ae=(0,n.EW)(()=>f.showWordLimit&&!!f.maxlength&&("text"===f.type||"textarea"===f.type)&&!W.value&&!f.readonly&&!f.showPassword),oe=(0,n.EW)(()=>te.value.length),ce=(0,n.EW)(()=>!!ae.value&&oe.value>Number(f.maxlength)),re=(0,n.EW)(()=>!!v.suffix||!!f.suffixIcon||le.value||f.showPassword||ae.value||!!Y.value&&G.value),se=(0,n.EW)(()=>!!Object.keys(f.modelModifiers).length),[ie,ue]=E(D);(0,r.wYm)(F,e=>{if(pe(),!ae.value||"both"!==f.resize&&"horizontal"!==f.resize)return;const t=e[0],{width:l}=t.contentRect;$.value={right:`calc(100% - ${l+22-10}px)`}});const de=()=>{const{type:e,autosize:t}=f;if(s.oc&&"textarea"===e&&F.value)if(t){const e=(0,o.Gv)(t)?t.minRows:void 0,l=(0,o.Gv)(t)?t.maxRows:void 0,a=y(F.value,e,l);H.value={overflowY:"hidden",...a},(0,n.dY)(()=>{F.value.offsetHeight,H.value=a})}else H.value={minHeight:y(F.value).minHeight}},fe=e=>{let t=!1;return()=>{var l;if(t||!f.autosize)return;const n=null===(null==(l=F.value)?void 0:l.offsetParent);n||(setTimeout(e),t=!0)}},pe=fe(de),me=()=>{const e=j.value,t=f.formatter?f.formatter(te.value):te.value;e&&e.value!==t&&"file"!==f.type&&(e.value=t)},ve=e=>{const{trim:t,number:l}=f.modelModifiers;return t&&(e=e.trim()),l&&(e=`${g(e)}`),f.formatter&&f.parser&&(e=f.parser(e)),e},he=async e=>{if(be.value)return;const{lazy:t}=f.modelModifiers;let{value:a}=e.target;t?l(S.qs,a):(a=ve(a),String(a)!==te.value?(ie(),l(S.l4,a),l(S.qs,a),await(0,n.dY)(),(f.formatter&&f.parser||!se.value)&&me(),ue()):f.formatter&&me())},ge=async e=>{let{value:t}=e.target;t=ve(t),f.modelModifiers.lazy&&l(S.l4,t),l(S.YU,t,e),await(0,n.dY)(),me()},{isComposing:be,handleCompositionStart:ye,handleCompositionUpdate:Ce,handleCompositionEnd:we}=(0,k.o)({emit:l,afterComposition:he}),Le=()=>{P.value=!P.value},xe=()=>{var e;return null==(e=j.value)?void 0:e.focus()},Me=()=>{var e;return null==(e=j.value)?void 0:e.blur()},ze=e=>{V.value=!1,l("mouseleave",e)},Re=e=>{V.value=!0,l("mouseenter",e)},ke=e=>{l("keydown",e)},Se=()=>{var e;null==(e=j.value)||e.select()},Ee=()=>{l(S.l4,""),l(S.YU,""),l("clear"),l(S.qs,"")};return(0,n.wB)(()=>f.modelValue,()=>{var e;(0,n.dY)(()=>de()),f.validateEvent&&(null==(e=null==w?void 0:w.validate)||e.call(w,"change").catch(e=>(0,N.U)(e)))}),(0,n.wB)(te,e=>{if(!j.value)return;const{trim:t,number:l}=f.modelModifiers,n=j.value.value,a=!l&&"number"!==f.type||/^0\d/.test(n)?n:`${g(n)}`;a!==e&&(document.activeElement===j.value&&"range"!==j.value.type&&t&&a.trim()===e||me())}),(0,n.wB)(()=>f.type,async()=>{await(0,n.dY)(),me(),de()}),(0,n.sV)(()=>{!f.formatter&&f.parser&&(0,N.U)(_,"If you set the parser, you also need to set the formatter."),me(),(0,n.dY)(de)}),t({input:D,textarea:F,ref:j,textareaStyle:ee,autosize:(0,a.lW)(f,"autosize"),isComposing:be,focus:xe,blur:Me,select:Se,clear:Ee,resizeTextarea:de}),(e,t)=>((0,n.uX)(),(0,n.CE)("div",{class:(0,o.C4)([(0,a.R1)(h),{[(0,a.R1)(B).bm("group","append")]:e.$slots.append,[(0,a.R1)(B).bm("group","prepend")]:e.$slots.prepend}]),style:(0,o.Tr)((0,a.R1)(J)),onMouseenter:Re,onMouseleave:ze},[(0,n.Q3)(" input "),"textarea"!==e.type?((0,n.uX)(),(0,n.CE)(n.FK,{key:0},[(0,n.Q3)(" prepend slot "),e.$slots.prepend?((0,n.uX)(),(0,n.CE)("div",{key:0,class:(0,o.C4)((0,a.R1)(B).be("group","prepend"))},[(0,n.RG)(e.$slots,"prepend")],2)):(0,n.Q3)("v-if",!0),(0,n.Lk)("div",{ref_key:"wrapperRef",ref:K,class:(0,o.C4)((0,a.R1)(b))},[(0,n.Q3)(" prefix slot "),e.$slots.prefix||e.prefixIcon?((0,n.uX)(),(0,n.CE)("span",{key:0,class:(0,o.C4)((0,a.R1)(B).e("prefix"))},[(0,n.Lk)("span",{class:(0,o.C4)((0,a.R1)(B).e("prefix-inner"))},[(0,n.RG)(e.$slots,"prefix"),e.prefixIcon?((0,n.uX)(),(0,n.Wv)((0,a.R1)(u.tk),{key:0,class:(0,o.C4)((0,a.R1)(B).e("icon"))},{default:(0,n.k6)(()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)(e.prefixIcon)))]),_:1},8,["class"])):(0,n.Q3)("v-if",!0)],2)],2)):(0,n.Q3)("v-if",!0),(0,n.Lk)("input",(0,n.v6)({id:(0,a.R1)(T),ref_key:"input",ref:D,class:(0,a.R1)(B).e("inner")},(0,a.R1)(m),{name:e.name,minlength:e.minlength,maxlength:e.maxlength,type:e.showPassword?P.value?"text":"password":e.type,disabled:(0,a.R1)(W),readonly:e.readonly,autocomplete:e.autocomplete,tabindex:e.tabindex,"aria-label":e.ariaLabel,placeholder:e.placeholder,style:e.inputStyle,form:e.form,autofocus:e.autofocus,role:e.containerRole,inputmode:e.inputmode,onCompositionstart:(0,a.R1)(ye),onCompositionupdate:(0,a.R1)(Ce),onCompositionend:(0,a.R1)(we),onInput:he,onChange:ge,onKeydown:ke}),null,16,["id","name","minlength","maxlength","type","disabled","readonly","autocomplete","tabindex","aria-label","placeholder","form","autofocus","role","inputmode","onCompositionstart","onCompositionupdate","onCompositionend"]),(0,n.Q3)(" suffix slot "),(0,a.R1)(re)?((0,n.uX)(),(0,n.CE)("span",{key:1,class:(0,o.C4)((0,a.R1)(B).e("suffix"))},[(0,n.Lk)("span",{class:(0,o.C4)((0,a.R1)(B).e("suffix-inner"))},[(0,a.R1)(le)&&(0,a.R1)(ne)&&(0,a.R1)(ae)?(0,n.Q3)("v-if",!0):((0,n.uX)(),(0,n.CE)(n.FK,{key:0},[(0,n.RG)(e.$slots,"suffix"),e.suffixIcon?((0,n.uX)(),(0,n.Wv)((0,a.R1)(u.tk),{key:0,class:(0,o.C4)((0,a.R1)(B).e("icon"))},{default:(0,n.k6)(()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)(e.suffixIcon)))]),_:1},8,["class"])):(0,n.Q3)("v-if",!0)],64)),(0,a.R1)(le)?((0,n.uX)(),(0,n.Wv)((0,a.R1)(u.tk),{key:1,class:(0,o.C4)([(0,a.R1)(B).e("icon"),(0,a.R1)(B).e("clear")]),onMousedown:(0,c.D$)((0,a.R1)(o.tE),["prevent"]),onClick:Ee},{default:(0,n.k6)(()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)(e.clearIcon)))]),_:1},8,["class","onMousedown"])):(0,n.Q3)("v-if",!0),(0,a.R1)(ne)?((0,n.uX)(),(0,n.Wv)((0,a.R1)(u.tk),{key:2,class:(0,o.C4)([(0,a.R1)(B).e("icon"),(0,a.R1)(B).e("password")]),onClick:Le,onMousedown:(0,c.D$)((0,a.R1)(o.tE),["prevent"]),onMouseup:(0,c.D$)((0,a.R1)(o.tE),["prevent"])},{default:(0,n.k6)(()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)((0,a.R1)(Z))))]),_:1},8,["class","onMousedown","onMouseup"])):(0,n.Q3)("v-if",!0),(0,a.R1)(ae)?((0,n.uX)(),(0,n.CE)("span",{key:3,class:(0,o.C4)([(0,a.R1)(B).e("count"),(0,a.R1)(B).is("outside","outside"===e.wordLimitPosition)])},[(0,n.Lk)("span",{class:(0,o.C4)((0,a.R1)(B).e("count-inner"))},(0,o.v_)((0,a.R1)(oe))+" / "+(0,o.v_)(e.maxlength),3)],2)):(0,n.Q3)("v-if",!0),(0,a.R1)(Y)&&(0,a.R1)(Q)&&(0,a.R1)(G)?((0,n.uX)(),(0,n.Wv)((0,a.R1)(u.tk),{key:4,class:(0,o.C4)([(0,a.R1)(B).e("icon"),(0,a.R1)(B).e("validateIcon"),(0,a.R1)(B).is("loading","validating"===(0,a.R1)(Y))])},{default:(0,n.k6)(()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)((0,a.R1)(Q))))]),_:1},8,["class"])):(0,n.Q3)("v-if",!0)],2)],2)):(0,n.Q3)("v-if",!0)],2),(0,n.Q3)(" append slot "),e.$slots.append?((0,n.uX)(),(0,n.CE)("div",{key:1,class:(0,o.C4)((0,a.R1)(B).be("group","append"))},[(0,n.RG)(e.$slots,"append")],2)):(0,n.Q3)("v-if",!0)],64)):((0,n.uX)(),(0,n.CE)(n.FK,{key:1},[(0,n.Q3)(" textarea "),(0,n.Lk)("textarea",(0,n.v6)({id:(0,a.R1)(T),ref_key:"textarea",ref:F,class:[(0,a.R1)(I).e("inner"),(0,a.R1)(B).is("focus",(0,a.R1)(X))]},(0,a.R1)(m),{name:e.name,minlength:e.minlength,maxlength:e.maxlength,tabindex:e.tabindex,disabled:(0,a.R1)(W),readonly:e.readonly,autocomplete:e.autocomplete,style:(0,a.R1)(ee),"aria-label":e.ariaLabel,placeholder:e.placeholder,form:e.form,autofocus:e.autofocus,rows:e.rows,role:e.containerRole,onCompositionstart:(0,a.R1)(ye),onCompositionupdate:(0,a.R1)(Ce),onCompositionend:(0,a.R1)(we),onInput:he,onFocus:(0,a.R1)(U),onBlur:(0,a.R1)(q),onChange:ge,onKeydown:ke}),null,16,["id","name","minlength","maxlength","tabindex","disabled","readonly","autocomplete","aria-label","placeholder","form","autofocus","rows","role","onCompositionstart","onCompositionupdate","onCompositionend","onFocus","onBlur"]),(0,a.R1)(ae)?((0,n.uX)(),(0,n.CE)("span",{key:0,style:(0,o.Tr)($.value),class:(0,o.C4)([(0,a.R1)(B).e("count"),(0,a.R1)(B).is("outside","outside"===e.wordLimitPosition)])},(0,o.v_)((0,a.R1)(oe))+" / "+(0,o.v_)(e.maxlength),7)):(0,n.Q3)("v-if",!0)],64))],38))}});var W=(0,w.A)(O,[["__file","input.vue"]]),B=l(5376);const I=(0,B.GU)(W)},9631:function(e,t,l){"use strict";l(9486)},9646:function(e,t,l){"use strict";var n=l(339),a="object"==typeof exports&&exports&&!exports.nodeType&&exports,o=a&&"object"==typeof module&&module&&!module.nodeType&&module,c=o&&o.exports===a,r=c&&n.A.process,s=function(){try{var e=o&&o.require&&o.require("util").types;return e||r&&r.binding&&r.binding("util")}catch(t){}}();t.A=s},9648:function(e,t,l){"use strict";l(5331)},9655:function(e,t,l){"use strict";l.d(t,{ve:function(){return h}});l(8111),l(1701);var n=l(6768),a=l(4232),o=l(144),c=l(813),r=l(7477),s=l(7378);const i=(0,s.b_)({type:{type:String,default:"line",values:["line","circle","dashboard"]},percentage:{type:Number,default:0,validator:e=>e>=0&&e<=100},status:{type:String,default:"",values:["","success","exception","warning"]},indeterminate:Boolean,duration:{type:Number,default:3},strokeWidth:{type:Number,default:6},strokeLinecap:{type:(0,s.jq)(String),default:"round"},textInside:Boolean,width:{type:Number,default:126},showText:{type:Boolean,default:!0},color:{type:(0,s.jq)([String,Array,Function]),default:""},striped:Boolean,stripedFlow:Boolean,format:{type:(0,s.jq)(Function),default:e=>`${e}%`}});var u=l(9077),d=l(3513);const f=(0,n.pM)({name:"ElProgress"}),p=(0,n.pM)({...f,props:i,setup(e){const t=e,l={success:"#13ce66",exception:"#ff4949",warning:"#e6a23c",default:"#20a0ff"},s=(0,d.DU)("progress"),i=(0,n.EW)(()=>{const e={width:`${t.percentage}%`,animationDuration:`${t.duration}s`},l=M(t.percentage);return l.includes("gradient")?e.background=l:e.backgroundColor=l,e}),u=(0,n.EW)(()=>(t.strokeWidth/t.width*100).toFixed(1)),f=(0,n.EW)(()=>["circle","dashboard"].includes(t.type)?Number.parseInt(""+(50-Number.parseFloat(u.value)/2),10):0),p=(0,n.EW)(()=>{const e=f.value,l="dashboard"===t.type;return`\n M 50 50\n m 0 ${l?"":"-"}${e}\n a ${e} ${e} 0 1 1 0 ${l?"-":""}${2*e}\n a ${e} ${e} 0 1 1 0 ${l?"":"-"}${2*e}\n `}),m=(0,n.EW)(()=>2*Math.PI*f.value),v=(0,n.EW)(()=>"dashboard"===t.type?.75:1),h=(0,n.EW)(()=>{const e=-1*m.value*(1-v.value)/2;return`${e}px`}),g=(0,n.EW)(()=>({strokeDasharray:`${m.value*v.value}px, ${m.value}px`,strokeDashoffset:h.value})),b=(0,n.EW)(()=>({strokeDasharray:`${m.value*v.value*(t.percentage/100)}px, ${m.value}px`,strokeDashoffset:h.value,transition:"stroke-dasharray 0.6s ease 0s, stroke 0.6s ease, opacity ease 0.6s"})),y=(0,n.EW)(()=>{let e;return e=t.color?M(t.percentage):l[t.status]||l.default,e}),C=(0,n.EW)(()=>"warning"===t.status?r.WarningFilled:"line"===t.type?"success"===t.status?r.CircleCheck:r.CircleClose:"success"===t.status?r.Check:r.Close),w=(0,n.EW)(()=>"line"===t.type?12+.4*t.strokeWidth:.111111*t.width+2),L=(0,n.EW)(()=>t.format(t.percentage));function x(e){const t=100/e.length,l=e.map((e,l)=>(0,a.Kg)(e)?{color:e,percentage:(l+1)*t}:e);return l.sort((e,t)=>e.percentage-t.percentage)}const M=e=>{var l;const{color:n}=t;if((0,a.Tn)(n))return n(e);if((0,a.Kg)(n))return n;{const t=x(n);for(const l of t)if(l.percentage>e)return l.color;return null==(l=t[t.length-1])?void 0:l.color}};return(e,t)=>((0,n.uX)(),(0,n.CE)("div",{class:(0,a.C4)([(0,o.R1)(s).b(),(0,o.R1)(s).m(e.type),(0,o.R1)(s).is(e.status),{[(0,o.R1)(s).m("without-text")]:!e.showText,[(0,o.R1)(s).m("text-inside")]:e.textInside}]),role:"progressbar","aria-valuenow":e.percentage,"aria-valuemin":"0","aria-valuemax":"100"},["line"===e.type?((0,n.uX)(),(0,n.CE)("div",{key:0,class:(0,a.C4)((0,o.R1)(s).b("bar"))},[(0,n.Lk)("div",{class:(0,a.C4)((0,o.R1)(s).be("bar","outer")),style:(0,a.Tr)({height:`${e.strokeWidth}px`})},[(0,n.Lk)("div",{class:(0,a.C4)([(0,o.R1)(s).be("bar","inner"),{[(0,o.R1)(s).bem("bar","inner","indeterminate")]:e.indeterminate},{[(0,o.R1)(s).bem("bar","inner","striped")]:e.striped},{[(0,o.R1)(s).bem("bar","inner","striped-flow")]:e.stripedFlow}]),style:(0,a.Tr)((0,o.R1)(i))},[(e.showText||e.$slots.default)&&e.textInside?((0,n.uX)(),(0,n.CE)("div",{key:0,class:(0,a.C4)((0,o.R1)(s).be("bar","innerText"))},[(0,n.RG)(e.$slots,"default",{percentage:e.percentage},()=>[(0,n.Lk)("span",null,(0,a.v_)((0,o.R1)(L)),1)])],2)):(0,n.Q3)("v-if",!0)],6)],6)],2)):((0,n.uX)(),(0,n.CE)("div",{key:1,class:(0,a.C4)((0,o.R1)(s).b("circle")),style:(0,a.Tr)({height:`${e.width}px`,width:`${e.width}px`})},[((0,n.uX)(),(0,n.CE)("svg",{viewBox:"0 0 100 100"},[(0,n.Lk)("path",{class:(0,a.C4)((0,o.R1)(s).be("circle","track")),d:(0,o.R1)(p),stroke:`var(${(0,o.R1)(s).cssVarName("fill-color-light")}, #e5e9f2)`,"stroke-linecap":e.strokeLinecap,"stroke-width":(0,o.R1)(u),fill:"none",style:(0,a.Tr)((0,o.R1)(g))},null,14,["d","stroke","stroke-linecap","stroke-width"]),(0,n.Lk)("path",{class:(0,a.C4)((0,o.R1)(s).be("circle","path")),d:(0,o.R1)(p),stroke:(0,o.R1)(y),fill:"none",opacity:e.percentage?1:0,"stroke-linecap":e.strokeLinecap,"stroke-width":(0,o.R1)(u),style:(0,a.Tr)((0,o.R1)(b))},null,14,["d","stroke","opacity","stroke-linecap","stroke-width"])]))],6)),!e.showText&&!e.$slots.default||e.textInside?(0,n.Q3)("v-if",!0):((0,n.uX)(),(0,n.CE)("div",{key:2,class:(0,a.C4)((0,o.R1)(s).e("text")),style:(0,a.Tr)({fontSize:`${(0,o.R1)(w)}px`})},[(0,n.RG)(e.$slots,"default",{percentage:e.percentage},()=>[e.status?((0,n.uX)(),(0,n.Wv)((0,o.R1)(c.tk),{key:1},{default:(0,n.k6)(()=>[((0,n.uX)(),(0,n.Wv)((0,n.$y)((0,o.R1)(C))))]),_:1})):((0,n.uX)(),(0,n.CE)("span",{key:0},(0,a.v_)((0,o.R1)(L)),1))])],6))],10,["aria-valuenow"]))}});var m=(0,u.A)(p,[["__file","progress.vue"]]),v=l(5376);const h=(0,v.GU)(m)},9759:function(e,t){"use strict";function l(e,t){return e.has(t)}t.A=l},9797:function(e,t,l){"use strict";l(4226)},9825:function(e,t,l){"use strict";l.d(t,{b:function(){return c},f:function(){return r}});var n=l(7378),a=l(8501),o=l(2235);const c=(0,n.b_)({distance:{type:Number,default:0},height:{type:[String,Number],default:""},maxHeight:{type:[String,Number],default:""},native:Boolean,wrapStyle:{type:(0,n.jq)([String,Object,Array]),default:""},wrapClass:{type:[String,Array],default:""},viewClass:{type:[String,Array],default:""},viewStyle:{type:[String,Array,Object],default:""},noresize:Boolean,tag:{type:String,default:"div"},always:Boolean,minSize:{type:Number,default:20},tabindex:{type:[String,Number],default:void 0},id:String,role:String,...(0,a.l)(["ariaLabel","ariaOrientation"])}),r={"end-reached":e=>["left","right","top","bottom"].includes(e),scroll:({scrollTop:e,scrollLeft:t})=>[e,t].every(o.Et)}},9835:function(e){"use strict";e.exports=function(e){try{var t=new Set,l={size:0,has:function(){return!0},keys:function(){return Object.defineProperty({},"next",{get:function(){return t.clear(),t.add(4),function(){return{done:!0}}}})}},n=t[e](l);return 1===n.size&&4===n.values().next().value}catch(a){return!1}}},9848:function(e,t,l){"use strict";l(6368),l(9309)},9869:function(e,t,l){"use strict";l.d(t,{TS:function(){return E},MF:function(){return A}});l(4114),l(8111),l(2489),l(7588);var n=l(6768),a=l(4232),o=l(144),c=(l(1701),l(6032));const r=Symbol("elDescriptions");var s=l(6139),i=l(3558),u=l(3513),d=(0,n.pM)({name:"ElDescriptionsCell",props:{cell:{type:Object},tag:{type:String,default:"td"},type:{type:String}},setup(){const e=(0,n.WQ)(r,{});return{descriptions:e}},render(){var e,t,l,a;const o=(0,s.oh)(this.cell),r=((null==(e=this.cell)?void 0:e.dirs)||[]).map(e=>{const{dir:t,arg:l,modifiers:n,value:a}=e;return[t,a,l,n]}),{border:d,direction:f}=this.descriptions,p="vertical"===f,m=()=>{var e,t,l;return(null==(l=null==(t=null==(e=this.cell)?void 0:e.children)?void 0:t.label)?void 0:l.call(t))||o.label},v=()=>{var e,t,l;return null==(l=null==(t=null==(e=this.cell)?void 0:e.children)?void 0:t.default)?void 0:l.call(t)},h=o.span,g=o.rowspan,b=o.align?`is-${o.align}`:"",y=o.labelAlign?`is-${o.labelAlign}`:b,C=o.className,w=o.labelClassName,L="label"===this.type&&null!=(l=null!=(t=o.labelWidth)?t:this.descriptions.labelWidth)?l:o.width,x={width:(0,i._V)(L),minWidth:(0,i._V)(o.minWidth)},M=(0,u.DU)("descriptions");switch(this.type){case"label":return(0,n.bo)((0,n.h)(this.tag,{style:x,class:[M.e("cell"),M.e("label"),M.is("bordered-label",d),M.is("vertical-label",p),y,w],colSpan:p?h:1,rowspan:p?1:g},m()),r);case"content":return(0,n.bo)((0,n.h)(this.tag,{style:x,class:[M.e("cell"),M.e("content"),M.is("bordered-content",d),M.is("vertical-content",p),b,C],colSpan:p?h:2*h-1,rowspan:p?2*g-1:g},v()),r);default:{const e=m(),t={},l=(0,i._V)(null!=(a=o.labelWidth)?a:this.descriptions.labelWidth);return l&&(t.width=l,t.display="inline-block"),(0,n.bo)((0,n.h)("td",{style:x,class:[M.e("cell"),b],colSpan:h,rowspan:g},[(0,c.A)(e)?void 0:(0,n.h)("span",{style:t,class:[M.e("label"),w]},e),(0,n.h)("span",{class:[M.e("content"),C]},v())]),r)}}}}),f=l(7378);const p=(0,f.b_)({row:{type:(0,f.jq)(Array),default:()=>[]}});var m=l(9077);const v=(0,n.pM)({name:"ElDescriptionsRow"}),h=(0,n.pM)({...v,props:p,setup(e){const t=(0,n.WQ)(r,{});return(e,l)=>"vertical"===(0,o.R1)(t).direction?((0,n.uX)(),(0,n.CE)(n.FK,{key:0},[(0,n.Lk)("tr",null,[((0,n.uX)(!0),(0,n.CE)(n.FK,null,(0,n.pI)(e.row,(e,t)=>((0,n.uX)(),(0,n.Wv)((0,o.R1)(d),{key:`tr1-${t}`,cell:e,tag:"th",type:"label"},null,8,["cell"]))),128))]),(0,n.Lk)("tr",null,[((0,n.uX)(!0),(0,n.CE)(n.FK,null,(0,n.pI)(e.row,(e,t)=>((0,n.uX)(),(0,n.Wv)((0,o.R1)(d),{key:`tr2-${t}`,cell:e,tag:"td",type:"content"},null,8,["cell"]))),128))])],64)):((0,n.uX)(),(0,n.CE)("tr",{key:1},[((0,n.uX)(!0),(0,n.CE)(n.FK,null,(0,n.pI)(e.row,(e,l)=>((0,n.uX)(),(0,n.CE)(n.FK,{key:`tr3-${l}`},[(0,o.R1)(t).border?((0,n.uX)(),(0,n.CE)(n.FK,{key:0},[(0,n.bF)((0,o.R1)(d),{cell:e,tag:"td",type:"label"},null,8,["cell"]),(0,n.bF)((0,o.R1)(d),{cell:e,tag:"td",type:"content"},null,8,["cell"])],64)):((0,n.uX)(),(0,n.Wv)((0,o.R1)(d),{key:1,cell:e,tag:"td",type:"both"},null,8,["cell"]))],64))),128))]))}});var g=(0,m.A)(h,[["__file","descriptions-row.vue"]]),b=l(3845);const y=(0,f.b_)({border:Boolean,column:{type:Number,default:3},direction:{type:String,values:["horizontal","vertical"],default:"horizontal"},size:b.mU,title:{type:String,default:""},extra:{type:String,default:""},labelWidth:{type:[String,Number]}}),C="ElDescriptionsItem";var w=l(2436);const L=(0,n.pM)({name:"ElDescriptions"}),x=(0,n.pM)({...L,props:y,setup(e){const t=e,l=(0,u.DU)("descriptions"),c=(0,w.NV)(),i=(0,n.Ht)();(0,n.Gt)(r,t);const d=(0,n.EW)(()=>[l.b(),l.m(c.value)]),f=(e,t,l,n=!1)=>(e.props||(e.props={}),t>l&&(e.props.span=l),n&&(e.props.span=t),e),p=()=>{if(!i.default)return[];const e=(0,s.CW)(i.default()).filter(e=>{var t;return(null==(t=null==e?void 0:e.type)?void 0:t.name)===C}),l=[];let n=[],a=t.column,o=0;const c=[];return e.forEach((r,s)=>{var i,u,d;const p=(null==(i=r.props)?void 0:i.span)||1,m=(null==(u=r.props)?void 0:u.rowspan)||1,v=l.length;if(c[v]||(c[v]=0),m>1)for(let e=1;e0&&(a-=c[v],c[v]=0),sa?a:p),s===e.length-1){const e=t.column-o%t.column;return n.push(f(r,e,a,!0)),void l.push(n)}p((0,n.uX)(),(0,n.CE)("div",{class:(0,a.C4)((0,o.R1)(d))},[e.title||e.extra||e.$slots.title||e.$slots.extra?((0,n.uX)(),(0,n.CE)("div",{key:0,class:(0,a.C4)((0,o.R1)(l).e("header"))},[(0,n.Lk)("div",{class:(0,a.C4)((0,o.R1)(l).e("title"))},[(0,n.RG)(e.$slots,"title",{},()=>[(0,n.eW)((0,a.v_)(e.title),1)])],2),(0,n.Lk)("div",{class:(0,a.C4)((0,o.R1)(l).e("extra"))},[(0,n.RG)(e.$slots,"extra",{},()=>[(0,n.eW)((0,a.v_)(e.extra),1)])],2)],2)):(0,n.Q3)("v-if",!0),(0,n.Lk)("div",{class:(0,a.C4)((0,o.R1)(l).e("body"))},[(0,n.Lk)("table",{class:(0,a.C4)([(0,o.R1)(l).e("table"),(0,o.R1)(l).is("bordered",e.border)])},[(0,n.Lk)("tbody",null,[((0,n.uX)(!0),(0,n.CE)(n.FK,null,(0,n.pI)(p(),(e,t)=>((0,n.uX)(),(0,n.Wv)(g,{key:t,row:e},null,8,["row"]))),128))])],2)],2)],2))}});var M=(0,m.A)(x,[["__file","description.vue"]]);const z=["left","center","right"],R=(0,f.b_)({label:{type:String,default:""},span:{type:Number,default:1},rowspan:{type:Number,default:1},width:{type:[String,Number],default:""},minWidth:{type:[String,Number],default:""},labelWidth:{type:[String,Number]},align:{type:String,values:z,default:"left"},labelAlign:{type:String,values:z},className:{type:String,default:""},labelClassName:{type:String,default:""}}),k=(0,n.pM)({name:C,props:R});var S=l(5376);const E=(0,S.GU)(M,{DescriptionsItem:k}),A=(0,S.WM)(k)},9928:function(e,t,l){"use strict";var n=l(6198),a=l(1291),o=RangeError;e.exports=function(e,t,l,c){var r=n(e),s=a(l),i=s<0?r+s:s;if(i>=r||i<0)throw new o("Incorrect index");for(var u=new t(r),d=0;d key in obj ? __defProp$9(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$9 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$b.call(b, prop))\n __defNormalProp$9(a, prop, b[prop]);\n if (__getOwnPropSymbols$b)\n for (var prop of __getOwnPropSymbols$b(b)) {\n if (__propIsEnum$b.call(b, prop))\n __defNormalProp$9(a, prop, b[prop]);\n }\n return a;\n};\nvar __spreadProps$6 = (a, b) => __defProps$6(a, __getOwnPropDescs$6(b));\nfunction computedEager(fn, options) {\n var _a;\n const result = shallowRef();\n watchEffect(() => {\n result.value = fn();\n }, __spreadProps$6(__spreadValues$9({}, options), {\n flush: (_a = options == null ? void 0 : options.flush) != null ? _a : \"sync\"\n }));\n return readonly(result);\n}\n\nvar _a;\nconst isClient = typeof window !== \"undefined\";\nconst isDef = (val) => typeof val !== \"undefined\";\nconst assert = (condition, ...infos) => {\n if (!condition)\n console.warn(...infos);\n};\nconst toString = Object.prototype.toString;\nconst isBoolean = (val) => typeof val === \"boolean\";\nconst isFunction = (val) => typeof val === \"function\";\nconst isNumber = (val) => typeof val === \"number\";\nconst isString = (val) => typeof val === \"string\";\nconst isObject = (val) => toString.call(val) === \"[object Object]\";\nconst isWindow = (val) => typeof window !== \"undefined\" && toString.call(val) === \"[object Window]\";\nconst now = () => Date.now();\nconst timestamp = () => +Date.now();\nconst clamp = (n, min, max) => Math.min(max, Math.max(min, n));\nconst noop = () => {\n};\nconst rand = (min, max) => {\n min = Math.ceil(min);\n max = Math.floor(max);\n return Math.floor(Math.random() * (max - min + 1)) + min;\n};\nconst isIOS = isClient && ((_a = window == null ? void 0 : window.navigator) == null ? void 0 : _a.userAgent) && /iP(ad|hone|od)/.test(window.navigator.userAgent);\nconst hasOwn = (val, key) => Object.prototype.hasOwnProperty.call(val, key);\n\nfunction resolveUnref(r) {\n return typeof r === \"function\" ? r() : unref(r);\n}\n\nfunction createFilterWrapper(filter, fn) {\n function wrapper(...args) {\n return new Promise((resolve, reject) => {\n Promise.resolve(filter(() => fn.apply(this, args), { fn, thisArg: this, args })).then(resolve).catch(reject);\n });\n }\n return wrapper;\n}\nconst bypassFilter = (invoke) => {\n return invoke();\n};\nfunction debounceFilter(ms, options = {}) {\n let timer;\n let maxTimer;\n let lastRejector = noop;\n const _clearTimeout = (timer2) => {\n clearTimeout(timer2);\n lastRejector();\n lastRejector = noop;\n };\n const filter = (invoke) => {\n const duration = resolveUnref(ms);\n const maxDuration = resolveUnref(options.maxWait);\n if (timer)\n _clearTimeout(timer);\n if (duration <= 0 || maxDuration !== void 0 && maxDuration <= 0) {\n if (maxTimer) {\n _clearTimeout(maxTimer);\n maxTimer = null;\n }\n return Promise.resolve(invoke());\n }\n return new Promise((resolve, reject) => {\n lastRejector = options.rejectOnCancel ? reject : resolve;\n if (maxDuration && !maxTimer) {\n maxTimer = setTimeout(() => {\n if (timer)\n _clearTimeout(timer);\n maxTimer = null;\n resolve(invoke());\n }, maxDuration);\n }\n timer = setTimeout(() => {\n if (maxTimer)\n _clearTimeout(maxTimer);\n maxTimer = null;\n resolve(invoke());\n }, duration);\n });\n };\n return filter;\n}\nfunction throttleFilter(ms, trailing = true, leading = true, rejectOnCancel = false) {\n let lastExec = 0;\n let timer;\n let isLeading = true;\n let lastRejector = noop;\n let lastValue;\n const clear = () => {\n if (timer) {\n clearTimeout(timer);\n timer = void 0;\n lastRejector();\n lastRejector = noop;\n }\n };\n const filter = (_invoke) => {\n const duration = resolveUnref(ms);\n const elapsed = Date.now() - lastExec;\n const invoke = () => {\n return lastValue = _invoke();\n };\n clear();\n if (duration <= 0) {\n lastExec = Date.now();\n return invoke();\n }\n if (elapsed > duration && (leading || !isLeading)) {\n lastExec = Date.now();\n invoke();\n } else if (trailing) {\n lastValue = new Promise((resolve, reject) => {\n lastRejector = rejectOnCancel ? reject : resolve;\n timer = setTimeout(() => {\n lastExec = Date.now();\n isLeading = true;\n resolve(invoke());\n clear();\n }, Math.max(0, duration - elapsed));\n });\n }\n if (!leading && !timer)\n timer = setTimeout(() => isLeading = true, duration);\n isLeading = false;\n return lastValue;\n };\n return filter;\n}\nfunction pausableFilter(extendFilter = bypassFilter) {\n const isActive = ref(true);\n function pause() {\n isActive.value = false;\n }\n function resume() {\n isActive.value = true;\n }\n const eventFilter = (...args) => {\n if (isActive.value)\n extendFilter(...args);\n };\n return { isActive: readonly(isActive), pause, resume, eventFilter };\n}\n\nfunction __onlyVue3(name = \"this function\") {\n if (isVue3)\n return;\n throw new Error(`[VueUse] ${name} is only works on Vue 3.`);\n}\nfunction __onlyVue27Plus(name = \"this function\") {\n if (isVue3 || version.startsWith(\"2.7.\"))\n return;\n throw new Error(`[VueUse] ${name} is only works on Vue 2.7 or above.`);\n}\nconst directiveHooks = {\n mounted: isVue3 ? \"mounted\" : \"inserted\",\n updated: isVue3 ? \"updated\" : \"componentUpdated\",\n unmounted: isVue3 ? \"unmounted\" : \"unbind\"\n};\n\nfunction promiseTimeout(ms, throwOnTimeout = false, reason = \"Timeout\") {\n return new Promise((resolve, reject) => {\n if (throwOnTimeout)\n setTimeout(() => reject(reason), ms);\n else\n setTimeout(resolve, ms);\n });\n}\nfunction identity(arg) {\n return arg;\n}\nfunction createSingletonPromise(fn) {\n let _promise;\n function wrapper() {\n if (!_promise)\n _promise = fn();\n return _promise;\n }\n wrapper.reset = async () => {\n const _prev = _promise;\n _promise = void 0;\n if (_prev)\n await _prev;\n };\n return wrapper;\n}\nfunction invoke(fn) {\n return fn();\n}\nfunction containsProp(obj, ...props) {\n return props.some((k) => k in obj);\n}\nfunction increaseWithUnit(target, delta) {\n var _a;\n if (typeof target === \"number\")\n return target + delta;\n const value = ((_a = target.match(/^-?[0-9]+\\.?[0-9]*/)) == null ? void 0 : _a[0]) || \"\";\n const unit = target.slice(value.length);\n const result = parseFloat(value) + delta;\n if (Number.isNaN(result))\n return target;\n return result + unit;\n}\nfunction objectPick(obj, keys, omitUndefined = false) {\n return keys.reduce((n, k) => {\n if (k in obj) {\n if (!omitUndefined || obj[k] !== void 0)\n n[k] = obj[k];\n }\n return n;\n }, {});\n}\n\nfunction computedWithControl(source, fn) {\n let v = void 0;\n let track;\n let trigger;\n const dirty = ref(true);\n const update = () => {\n dirty.value = true;\n trigger();\n };\n watch(source, update, { flush: \"sync\" });\n const get = isFunction(fn) ? fn : fn.get;\n const set = isFunction(fn) ? void 0 : fn.set;\n const result = customRef((_track, _trigger) => {\n track = _track;\n trigger = _trigger;\n return {\n get() {\n if (dirty.value) {\n v = get();\n dirty.value = false;\n }\n track();\n return v;\n },\n set(v2) {\n set == null ? void 0 : set(v2);\n }\n };\n });\n if (Object.isExtensible(result))\n result.trigger = update;\n return result;\n}\n\nfunction tryOnScopeDispose(fn) {\n if (getCurrentScope()) {\n onScopeDispose(fn);\n return true;\n }\n return false;\n}\n\nfunction createEventHook() {\n const fns = [];\n const off = (fn) => {\n const index = fns.indexOf(fn);\n if (index !== -1)\n fns.splice(index, 1);\n };\n const on = (fn) => {\n fns.push(fn);\n const offFn = () => off(fn);\n tryOnScopeDispose(offFn);\n return {\n off: offFn\n };\n };\n const trigger = (param) => {\n fns.forEach((fn) => fn(param));\n };\n return {\n on,\n off,\n trigger\n };\n}\n\nfunction createGlobalState(stateFactory) {\n let initialized = false;\n let state;\n const scope = effectScope(true);\n return () => {\n if (!initialized) {\n state = scope.run(stateFactory);\n initialized = true;\n }\n return state;\n };\n}\n\nfunction createInjectionState(composable) {\n const key = Symbol(\"InjectionState\");\n const useProvidingState = (...args) => {\n const state = composable(...args);\n provide(key, state);\n return state;\n };\n const useInjectedState = () => inject(key);\n return [useProvidingState, useInjectedState];\n}\n\nfunction createSharedComposable(composable) {\n let subscribers = 0;\n let state;\n let scope;\n const dispose = () => {\n subscribers -= 1;\n if (scope && subscribers <= 0) {\n scope.stop();\n state = void 0;\n scope = void 0;\n }\n };\n return (...args) => {\n subscribers += 1;\n if (!state) {\n scope = effectScope(true);\n state = scope.run(() => composable(...args));\n }\n tryOnScopeDispose(dispose);\n return state;\n };\n}\n\nfunction extendRef(ref, extend, { enumerable = false, unwrap = true } = {}) {\n __onlyVue27Plus();\n for (const [key, value] of Object.entries(extend)) {\n if (key === \"value\")\n continue;\n if (isRef(value) && unwrap) {\n Object.defineProperty(ref, key, {\n get() {\n return value.value;\n },\n set(v) {\n value.value = v;\n },\n enumerable\n });\n } else {\n Object.defineProperty(ref, key, { value, enumerable });\n }\n }\n return ref;\n}\n\nfunction get(obj, key) {\n if (key == null)\n return unref(obj);\n return unref(obj)[key];\n}\n\nfunction isDefined(v) {\n return unref(v) != null;\n}\n\nvar __defProp$8 = Object.defineProperty;\nvar __getOwnPropSymbols$a = Object.getOwnPropertySymbols;\nvar __hasOwnProp$a = Object.prototype.hasOwnProperty;\nvar __propIsEnum$a = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$8 = (obj, key, value) => key in obj ? __defProp$8(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$8 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$a.call(b, prop))\n __defNormalProp$8(a, prop, b[prop]);\n if (__getOwnPropSymbols$a)\n for (var prop of __getOwnPropSymbols$a(b)) {\n if (__propIsEnum$a.call(b, prop))\n __defNormalProp$8(a, prop, b[prop]);\n }\n return a;\n};\nfunction makeDestructurable(obj, arr) {\n if (typeof Symbol !== \"undefined\") {\n const clone = __spreadValues$8({}, obj);\n Object.defineProperty(clone, Symbol.iterator, {\n enumerable: false,\n value() {\n let index = 0;\n return {\n next: () => ({\n value: arr[index++],\n done: index > arr.length\n })\n };\n }\n });\n return clone;\n } else {\n return Object.assign([...arr], obj);\n }\n}\n\nfunction reactify(fn, options) {\n const unrefFn = (options == null ? void 0 : options.computedGetter) === false ? unref : resolveUnref;\n return function(...args) {\n return computed(() => fn.apply(this, args.map((i) => unrefFn(i))));\n };\n}\n\nfunction reactifyObject(obj, optionsOrKeys = {}) {\n let keys = [];\n let options;\n if (Array.isArray(optionsOrKeys)) {\n keys = optionsOrKeys;\n } else {\n options = optionsOrKeys;\n const { includeOwnProperties = true } = optionsOrKeys;\n keys.push(...Object.keys(obj));\n if (includeOwnProperties)\n keys.push(...Object.getOwnPropertyNames(obj));\n }\n return Object.fromEntries(keys.map((key) => {\n const value = obj[key];\n return [\n key,\n typeof value === \"function\" ? reactify(value.bind(obj), options) : value\n ];\n }));\n}\n\nfunction toReactive(objectRef) {\n if (!isRef(objectRef))\n return reactive(objectRef);\n const proxy = new Proxy({}, {\n get(_, p, receiver) {\n return unref(Reflect.get(objectRef.value, p, receiver));\n },\n set(_, p, value) {\n if (isRef(objectRef.value[p]) && !isRef(value))\n objectRef.value[p].value = value;\n else\n objectRef.value[p] = value;\n return true;\n },\n deleteProperty(_, p) {\n return Reflect.deleteProperty(objectRef.value, p);\n },\n has(_, p) {\n return Reflect.has(objectRef.value, p);\n },\n ownKeys() {\n return Object.keys(objectRef.value);\n },\n getOwnPropertyDescriptor() {\n return {\n enumerable: true,\n configurable: true\n };\n }\n });\n return reactive(proxy);\n}\n\nfunction reactiveComputed(fn) {\n return toReactive(computed(fn));\n}\n\nfunction reactiveOmit(obj, ...keys) {\n const flatKeys = keys.flat();\n return reactiveComputed(() => Object.fromEntries(Object.entries(toRefs$1(obj)).filter((e) => !flatKeys.includes(e[0]))));\n}\n\nfunction reactivePick(obj, ...keys) {\n const flatKeys = keys.flat();\n return reactive(Object.fromEntries(flatKeys.map((k) => [k, toRef(obj, k)])));\n}\n\nfunction refAutoReset(defaultValue, afterMs = 1e4) {\n return customRef((track, trigger) => {\n let value = defaultValue;\n let timer;\n const resetAfter = () => setTimeout(() => {\n value = defaultValue;\n trigger();\n }, resolveUnref(afterMs));\n tryOnScopeDispose(() => {\n clearTimeout(timer);\n });\n return {\n get() {\n track();\n return value;\n },\n set(newValue) {\n value = newValue;\n trigger();\n clearTimeout(timer);\n timer = resetAfter();\n }\n };\n });\n}\n\nfunction useDebounceFn(fn, ms = 200, options = {}) {\n return createFilterWrapper(debounceFilter(ms, options), fn);\n}\n\nfunction refDebounced(value, ms = 200, options = {}) {\n const debounced = ref(value.value);\n const updater = useDebounceFn(() => {\n debounced.value = value.value;\n }, ms, options);\n watch(value, () => updater());\n return debounced;\n}\n\nfunction refDefault(source, defaultValue) {\n return computed({\n get() {\n var _a;\n return (_a = source.value) != null ? _a : defaultValue;\n },\n set(value) {\n source.value = value;\n }\n });\n}\n\nfunction useThrottleFn(fn, ms = 200, trailing = false, leading = true, rejectOnCancel = false) {\n return createFilterWrapper(throttleFilter(ms, trailing, leading, rejectOnCancel), fn);\n}\n\nfunction refThrottled(value, delay = 200, trailing = true, leading = true) {\n if (delay <= 0)\n return value;\n const throttled = ref(value.value);\n const updater = useThrottleFn(() => {\n throttled.value = value.value;\n }, delay, trailing, leading);\n watch(value, () => updater());\n return throttled;\n}\n\nfunction refWithControl(initial, options = {}) {\n let source = initial;\n let track;\n let trigger;\n const ref = customRef((_track, _trigger) => {\n track = _track;\n trigger = _trigger;\n return {\n get() {\n return get();\n },\n set(v) {\n set(v);\n }\n };\n });\n function get(tracking = true) {\n if (tracking)\n track();\n return source;\n }\n function set(value, triggering = true) {\n var _a, _b;\n if (value === source)\n return;\n const old = source;\n if (((_a = options.onBeforeChange) == null ? void 0 : _a.call(options, value, old)) === false)\n return;\n source = value;\n (_b = options.onChanged) == null ? void 0 : _b.call(options, value, old);\n if (triggering)\n trigger();\n }\n const untrackedGet = () => get(false);\n const silentSet = (v) => set(v, false);\n const peek = () => get(false);\n const lay = (v) => set(v, false);\n return extendRef(ref, {\n get,\n set,\n untrackedGet,\n silentSet,\n peek,\n lay\n }, { enumerable: true });\n}\nconst controlledRef = refWithControl;\n\nfunction resolveRef(r) {\n return typeof r === \"function\" ? computed(r) : ref(r);\n}\n\nfunction set(...args) {\n if (args.length === 2) {\n const [ref, value] = args;\n ref.value = value;\n }\n if (args.length === 3) {\n if (isVue2) {\n set$1(...args);\n } else {\n const [target, key, value] = args;\n target[key] = value;\n }\n }\n}\n\nfunction syncRef(left, right, options = {}) {\n var _a, _b;\n const {\n flush = \"sync\",\n deep = false,\n immediate = true,\n direction = \"both\",\n transform = {}\n } = options;\n let watchLeft;\n let watchRight;\n const transformLTR = (_a = transform.ltr) != null ? _a : (v) => v;\n const transformRTL = (_b = transform.rtl) != null ? _b : (v) => v;\n if (direction === \"both\" || direction === \"ltr\") {\n watchLeft = watch(left, (newValue) => right.value = transformLTR(newValue), { flush, deep, immediate });\n }\n if (direction === \"both\" || direction === \"rtl\") {\n watchRight = watch(right, (newValue) => left.value = transformRTL(newValue), { flush, deep, immediate });\n }\n return () => {\n watchLeft == null ? void 0 : watchLeft();\n watchRight == null ? void 0 : watchRight();\n };\n}\n\nfunction syncRefs(source, targets, options = {}) {\n const {\n flush = \"sync\",\n deep = false,\n immediate = true\n } = options;\n if (!Array.isArray(targets))\n targets = [targets];\n return watch(source, (newValue) => targets.forEach((target) => target.value = newValue), { flush, deep, immediate });\n}\n\nvar __defProp$7 = Object.defineProperty;\nvar __defProps$5 = Object.defineProperties;\nvar __getOwnPropDescs$5 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$9 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$9 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$9 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$7 = (obj, key, value) => key in obj ? __defProp$7(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$7 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$9.call(b, prop))\n __defNormalProp$7(a, prop, b[prop]);\n if (__getOwnPropSymbols$9)\n for (var prop of __getOwnPropSymbols$9(b)) {\n if (__propIsEnum$9.call(b, prop))\n __defNormalProp$7(a, prop, b[prop]);\n }\n return a;\n};\nvar __spreadProps$5 = (a, b) => __defProps$5(a, __getOwnPropDescs$5(b));\nfunction toRefs(objectRef) {\n if (!isRef(objectRef))\n return toRefs$1(objectRef);\n const result = Array.isArray(objectRef.value) ? new Array(objectRef.value.length) : {};\n for (const key in objectRef.value) {\n result[key] = customRef(() => ({\n get() {\n return objectRef.value[key];\n },\n set(v) {\n if (Array.isArray(objectRef.value)) {\n const copy = [...objectRef.value];\n copy[key] = v;\n objectRef.value = copy;\n } else {\n const newObject = __spreadProps$5(__spreadValues$7({}, objectRef.value), { [key]: v });\n Object.setPrototypeOf(newObject, objectRef.value);\n objectRef.value = newObject;\n }\n }\n }));\n }\n return result;\n}\n\nfunction tryOnBeforeMount(fn, sync = true) {\n if (getCurrentInstance())\n onBeforeMount(fn);\n else if (sync)\n fn();\n else\n nextTick(fn);\n}\n\nfunction tryOnBeforeUnmount(fn) {\n if (getCurrentInstance())\n onBeforeUnmount(fn);\n}\n\nfunction tryOnMounted(fn, sync = true) {\n if (getCurrentInstance())\n onMounted(fn);\n else if (sync)\n fn();\n else\n nextTick(fn);\n}\n\nfunction tryOnUnmounted(fn) {\n if (getCurrentInstance())\n onUnmounted(fn);\n}\n\nfunction createUntil(r, isNot = false) {\n function toMatch(condition, { flush = \"sync\", deep = false, timeout, throwOnTimeout } = {}) {\n let stop = null;\n const watcher = new Promise((resolve) => {\n stop = watch(r, (v) => {\n if (condition(v) !== isNot) {\n stop == null ? void 0 : stop();\n resolve(v);\n }\n }, {\n flush,\n deep,\n immediate: true\n });\n });\n const promises = [watcher];\n if (timeout != null) {\n promises.push(promiseTimeout(timeout, throwOnTimeout).then(() => resolveUnref(r)).finally(() => stop == null ? void 0 : stop()));\n }\n return Promise.race(promises);\n }\n function toBe(value, options) {\n if (!isRef(value))\n return toMatch((v) => v === value, options);\n const { flush = \"sync\", deep = false, timeout, throwOnTimeout } = options != null ? options : {};\n let stop = null;\n const watcher = new Promise((resolve) => {\n stop = watch([r, value], ([v1, v2]) => {\n if (isNot !== (v1 === v2)) {\n stop == null ? void 0 : stop();\n resolve(v1);\n }\n }, {\n flush,\n deep,\n immediate: true\n });\n });\n const promises = [watcher];\n if (timeout != null) {\n promises.push(promiseTimeout(timeout, throwOnTimeout).then(() => resolveUnref(r)).finally(() => {\n stop == null ? void 0 : stop();\n return resolveUnref(r);\n }));\n }\n return Promise.race(promises);\n }\n function toBeTruthy(options) {\n return toMatch((v) => Boolean(v), options);\n }\n function toBeNull(options) {\n return toBe(null, options);\n }\n function toBeUndefined(options) {\n return toBe(void 0, options);\n }\n function toBeNaN(options) {\n return toMatch(Number.isNaN, options);\n }\n function toContains(value, options) {\n return toMatch((v) => {\n const array = Array.from(v);\n return array.includes(value) || array.includes(resolveUnref(value));\n }, options);\n }\n function changed(options) {\n return changedTimes(1, options);\n }\n function changedTimes(n = 1, options) {\n let count = -1;\n return toMatch(() => {\n count += 1;\n return count >= n;\n }, options);\n }\n if (Array.isArray(resolveUnref(r))) {\n const instance = {\n toMatch,\n toContains,\n changed,\n changedTimes,\n get not() {\n return createUntil(r, !isNot);\n }\n };\n return instance;\n } else {\n const instance = {\n toMatch,\n toBe,\n toBeTruthy,\n toBeNull,\n toBeNaN,\n toBeUndefined,\n changed,\n changedTimes,\n get not() {\n return createUntil(r, !isNot);\n }\n };\n return instance;\n }\n}\nfunction until(r) {\n return createUntil(r);\n}\n\nfunction useArrayEvery(list, fn) {\n return computed(() => resolveUnref(list).every((element, index, array) => fn(resolveUnref(element), index, array)));\n}\n\nfunction useArrayFilter(list, fn) {\n return computed(() => resolveUnref(list).map((i) => resolveUnref(i)).filter(fn));\n}\n\nfunction useArrayFind(list, fn) {\n return computed(() => resolveUnref(resolveUnref(list).find((element, index, array) => fn(resolveUnref(element), index, array))));\n}\n\nfunction useArrayFindIndex(list, fn) {\n return computed(() => resolveUnref(list).findIndex((element, index, array) => fn(resolveUnref(element), index, array)));\n}\n\nfunction findLast(arr, cb) {\n let index = arr.length;\n while (index-- > 0) {\n if (cb(arr[index], index, arr))\n return arr[index];\n }\n return void 0;\n}\nfunction useArrayFindLast(list, fn) {\n return computed(() => resolveUnref(!Array.prototype.findLast ? findLast(resolveUnref(list), (element, index, array) => fn(resolveUnref(element), index, array)) : resolveUnref(list).findLast((element, index, array) => fn(resolveUnref(element), index, array))));\n}\n\nfunction useArrayJoin(list, separator) {\n return computed(() => resolveUnref(list).map((i) => resolveUnref(i)).join(resolveUnref(separator)));\n}\n\nfunction useArrayMap(list, fn) {\n return computed(() => resolveUnref(list).map((i) => resolveUnref(i)).map(fn));\n}\n\nfunction useArrayReduce(list, reducer, ...args) {\n const reduceCallback = (sum, value, index) => reducer(resolveUnref(sum), resolveUnref(value), index);\n return computed(() => {\n const resolved = resolveUnref(list);\n return args.length ? resolved.reduce(reduceCallback, resolveUnref(args[0])) : resolved.reduce(reduceCallback);\n });\n}\n\nfunction useArraySome(list, fn) {\n return computed(() => resolveUnref(list).some((element, index, array) => fn(resolveUnref(element), index, array)));\n}\n\nfunction useArrayUnique(list) {\n return computed(() => [...new Set(resolveUnref(list).map((element) => resolveUnref(element)))]);\n}\n\nfunction useCounter(initialValue = 0, options = {}) {\n const count = ref(initialValue);\n const {\n max = Infinity,\n min = -Infinity\n } = options;\n const inc = (delta = 1) => count.value = Math.min(max, count.value + delta);\n const dec = (delta = 1) => count.value = Math.max(min, count.value - delta);\n const get = () => count.value;\n const set = (val) => count.value = Math.max(min, Math.min(max, val));\n const reset = (val = initialValue) => {\n initialValue = val;\n return set(val);\n };\n return { count, inc, dec, get, set, reset };\n}\n\nconst REGEX_PARSE = /^(\\d{4})[-/]?(\\d{1,2})?[-/]?(\\d{0,2})[Tt\\s]*(\\d{1,2})?:?(\\d{1,2})?:?(\\d{1,2})?[.:]?(\\d+)?$/;\nconst REGEX_FORMAT = /\\[([^\\]]+)]|Y{1,4}|M{1,4}|D{1,2}|d{1,4}|H{1,2}|h{1,2}|a{1,2}|A{1,2}|m{1,2}|s{1,2}|Z{1,2}|SSS/g;\nconst defaultMeridiem = (hours, minutes, isLowercase, hasPeriod) => {\n let m = hours < 12 ? \"AM\" : \"PM\";\n if (hasPeriod)\n m = m.split(\"\").reduce((acc, curr) => acc += `${curr}.`, \"\");\n return isLowercase ? m.toLowerCase() : m;\n};\nconst formatDate = (date, formatStr, options = {}) => {\n var _a;\n const years = date.getFullYear();\n const month = date.getMonth();\n const days = date.getDate();\n const hours = date.getHours();\n const minutes = date.getMinutes();\n const seconds = date.getSeconds();\n const milliseconds = date.getMilliseconds();\n const day = date.getDay();\n const meridiem = (_a = options.customMeridiem) != null ? _a : defaultMeridiem;\n const matches = {\n YY: () => String(years).slice(-2),\n YYYY: () => years,\n M: () => month + 1,\n MM: () => `${month + 1}`.padStart(2, \"0\"),\n MMM: () => date.toLocaleDateString(options.locales, { month: \"short\" }),\n MMMM: () => date.toLocaleDateString(options.locales, { month: \"long\" }),\n D: () => String(days),\n DD: () => `${days}`.padStart(2, \"0\"),\n H: () => String(hours),\n HH: () => `${hours}`.padStart(2, \"0\"),\n h: () => `${hours % 12 || 12}`.padStart(1, \"0\"),\n hh: () => `${hours % 12 || 12}`.padStart(2, \"0\"),\n m: () => String(minutes),\n mm: () => `${minutes}`.padStart(2, \"0\"),\n s: () => String(seconds),\n ss: () => `${seconds}`.padStart(2, \"0\"),\n SSS: () => `${milliseconds}`.padStart(3, \"0\"),\n d: () => day,\n dd: () => date.toLocaleDateString(options.locales, { weekday: \"narrow\" }),\n ddd: () => date.toLocaleDateString(options.locales, { weekday: \"short\" }),\n dddd: () => date.toLocaleDateString(options.locales, { weekday: \"long\" }),\n A: () => meridiem(hours, minutes),\n AA: () => meridiem(hours, minutes, false, true),\n a: () => meridiem(hours, minutes, true),\n aa: () => meridiem(hours, minutes, true, true)\n };\n return formatStr.replace(REGEX_FORMAT, (match, $1) => $1 || matches[match]());\n};\nconst normalizeDate = (date) => {\n if (date === null)\n return new Date(NaN);\n if (date === void 0)\n return new Date();\n if (date instanceof Date)\n return new Date(date);\n if (typeof date === \"string\" && !/Z$/i.test(date)) {\n const d = date.match(REGEX_PARSE);\n if (d) {\n const m = d[2] - 1 || 0;\n const ms = (d[7] || \"0\").substring(0, 3);\n return new Date(d[1], m, d[3] || 1, d[4] || 0, d[5] || 0, d[6] || 0, ms);\n }\n }\n return new Date(date);\n};\nfunction useDateFormat(date, formatStr = \"HH:mm:ss\", options = {}) {\n return computed(() => formatDate(normalizeDate(resolveUnref(date)), resolveUnref(formatStr), options));\n}\n\nfunction useIntervalFn(cb, interval = 1e3, options = {}) {\n const {\n immediate = true,\n immediateCallback = false\n } = options;\n let timer = null;\n const isActive = ref(false);\n function clean() {\n if (timer) {\n clearInterval(timer);\n timer = null;\n }\n }\n function pause() {\n isActive.value = false;\n clean();\n }\n function resume() {\n const intervalValue = resolveUnref(interval);\n if (intervalValue <= 0)\n return;\n isActive.value = true;\n if (immediateCallback)\n cb();\n clean();\n timer = setInterval(cb, intervalValue);\n }\n if (immediate && isClient)\n resume();\n if (isRef(interval) || isFunction(interval)) {\n const stopWatch = watch(interval, () => {\n if (isActive.value && isClient)\n resume();\n });\n tryOnScopeDispose(stopWatch);\n }\n tryOnScopeDispose(pause);\n return {\n isActive,\n pause,\n resume\n };\n}\n\nvar __defProp$6 = Object.defineProperty;\nvar __getOwnPropSymbols$8 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$8 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$8 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$6 = (obj, key, value) => key in obj ? __defProp$6(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$6 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$8.call(b, prop))\n __defNormalProp$6(a, prop, b[prop]);\n if (__getOwnPropSymbols$8)\n for (var prop of __getOwnPropSymbols$8(b)) {\n if (__propIsEnum$8.call(b, prop))\n __defNormalProp$6(a, prop, b[prop]);\n }\n return a;\n};\nfunction useInterval(interval = 1e3, options = {}) {\n const {\n controls: exposeControls = false,\n immediate = true,\n callback\n } = options;\n const counter = ref(0);\n const update = () => counter.value += 1;\n const reset = () => {\n counter.value = 0;\n };\n const controls = useIntervalFn(callback ? () => {\n update();\n callback(counter.value);\n } : update, interval, { immediate });\n if (exposeControls) {\n return __spreadValues$6({\n counter,\n reset\n }, controls);\n } else {\n return counter;\n }\n}\n\nfunction useLastChanged(source, options = {}) {\n var _a;\n const ms = ref((_a = options.initialValue) != null ? _a : null);\n watch(source, () => ms.value = timestamp(), options);\n return ms;\n}\n\nfunction useTimeoutFn(cb, interval, options = {}) {\n const {\n immediate = true\n } = options;\n const isPending = ref(false);\n let timer = null;\n function clear() {\n if (timer) {\n clearTimeout(timer);\n timer = null;\n }\n }\n function stop() {\n isPending.value = false;\n clear();\n }\n function start(...args) {\n clear();\n isPending.value = true;\n timer = setTimeout(() => {\n isPending.value = false;\n timer = null;\n cb(...args);\n }, resolveUnref(interval));\n }\n if (immediate) {\n isPending.value = true;\n if (isClient)\n start();\n }\n tryOnScopeDispose(stop);\n return {\n isPending: readonly(isPending),\n start,\n stop\n };\n}\n\nvar __defProp$5 = Object.defineProperty;\nvar __getOwnPropSymbols$7 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$7 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$7 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$5 = (obj, key, value) => key in obj ? __defProp$5(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$5 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$7.call(b, prop))\n __defNormalProp$5(a, prop, b[prop]);\n if (__getOwnPropSymbols$7)\n for (var prop of __getOwnPropSymbols$7(b)) {\n if (__propIsEnum$7.call(b, prop))\n __defNormalProp$5(a, prop, b[prop]);\n }\n return a;\n};\nfunction useTimeout(interval = 1e3, options = {}) {\n const {\n controls: exposeControls = false,\n callback\n } = options;\n const controls = useTimeoutFn(callback != null ? callback : noop, interval, options);\n const ready = computed(() => !controls.isPending.value);\n if (exposeControls) {\n return __spreadValues$5({\n ready\n }, controls);\n } else {\n return ready;\n }\n}\n\nfunction useToNumber(value, options = {}) {\n const {\n method = \"parseFloat\",\n radix,\n nanToZero\n } = options;\n return computed(() => {\n let resolved = resolveUnref(value);\n if (typeof resolved === \"string\")\n resolved = Number[method](resolved, radix);\n if (nanToZero && isNaN(resolved))\n resolved = 0;\n return resolved;\n });\n}\n\nfunction useToString(value) {\n return computed(() => `${resolveUnref(value)}`);\n}\n\nfunction useToggle(initialValue = false, options = {}) {\n const {\n truthyValue = true,\n falsyValue = false\n } = options;\n const valueIsRef = isRef(initialValue);\n const _value = ref(initialValue);\n function toggle(value) {\n if (arguments.length) {\n _value.value = value;\n return _value.value;\n } else {\n const truthy = resolveUnref(truthyValue);\n _value.value = _value.value === truthy ? resolveUnref(falsyValue) : truthy;\n return _value.value;\n }\n }\n if (valueIsRef)\n return toggle;\n else\n return [_value, toggle];\n}\n\nfunction watchArray(source, cb, options) {\n let oldList = (options == null ? void 0 : options.immediate) ? [] : [\n ...source instanceof Function ? source() : Array.isArray(source) ? source : unref(source)\n ];\n return watch(source, (newList, _, onCleanup) => {\n const oldListRemains = new Array(oldList.length);\n const added = [];\n for (const obj of newList) {\n let found = false;\n for (let i = 0; i < oldList.length; i++) {\n if (!oldListRemains[i] && obj === oldList[i]) {\n oldListRemains[i] = true;\n found = true;\n break;\n }\n }\n if (!found)\n added.push(obj);\n }\n const removed = oldList.filter((_2, i) => !oldListRemains[i]);\n cb(newList, oldList, added, removed, onCleanup);\n oldList = [...newList];\n }, options);\n}\n\nvar __getOwnPropSymbols$6 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$6 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$6 = Object.prototype.propertyIsEnumerable;\nvar __objRest$5 = (source, exclude) => {\n var target = {};\n for (var prop in source)\n if (__hasOwnProp$6.call(source, prop) && exclude.indexOf(prop) < 0)\n target[prop] = source[prop];\n if (source != null && __getOwnPropSymbols$6)\n for (var prop of __getOwnPropSymbols$6(source)) {\n if (exclude.indexOf(prop) < 0 && __propIsEnum$6.call(source, prop))\n target[prop] = source[prop];\n }\n return target;\n};\nfunction watchWithFilter(source, cb, options = {}) {\n const _a = options, {\n eventFilter = bypassFilter\n } = _a, watchOptions = __objRest$5(_a, [\n \"eventFilter\"\n ]);\n return watch(source, createFilterWrapper(eventFilter, cb), watchOptions);\n}\n\nvar __getOwnPropSymbols$5 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$5 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$5 = Object.prototype.propertyIsEnumerable;\nvar __objRest$4 = (source, exclude) => {\n var target = {};\n for (var prop in source)\n if (__hasOwnProp$5.call(source, prop) && exclude.indexOf(prop) < 0)\n target[prop] = source[prop];\n if (source != null && __getOwnPropSymbols$5)\n for (var prop of __getOwnPropSymbols$5(source)) {\n if (exclude.indexOf(prop) < 0 && __propIsEnum$5.call(source, prop))\n target[prop] = source[prop];\n }\n return target;\n};\nfunction watchAtMost(source, cb, options) {\n const _a = options, {\n count\n } = _a, watchOptions = __objRest$4(_a, [\n \"count\"\n ]);\n const current = ref(0);\n const stop = watchWithFilter(source, (...args) => {\n current.value += 1;\n if (current.value >= resolveUnref(count))\n nextTick(() => stop());\n cb(...args);\n }, watchOptions);\n return { count: current, stop };\n}\n\nvar __defProp$4 = Object.defineProperty;\nvar __defProps$4 = Object.defineProperties;\nvar __getOwnPropDescs$4 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$4 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$4 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$4 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$4 = (obj, key, value) => key in obj ? __defProp$4(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$4 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$4.call(b, prop))\n __defNormalProp$4(a, prop, b[prop]);\n if (__getOwnPropSymbols$4)\n for (var prop of __getOwnPropSymbols$4(b)) {\n if (__propIsEnum$4.call(b, prop))\n __defNormalProp$4(a, prop, b[prop]);\n }\n return a;\n};\nvar __spreadProps$4 = (a, b) => __defProps$4(a, __getOwnPropDescs$4(b));\nvar __objRest$3 = (source, exclude) => {\n var target = {};\n for (var prop in source)\n if (__hasOwnProp$4.call(source, prop) && exclude.indexOf(prop) < 0)\n target[prop] = source[prop];\n if (source != null && __getOwnPropSymbols$4)\n for (var prop of __getOwnPropSymbols$4(source)) {\n if (exclude.indexOf(prop) < 0 && __propIsEnum$4.call(source, prop))\n target[prop] = source[prop];\n }\n return target;\n};\nfunction watchDebounced(source, cb, options = {}) {\n const _a = options, {\n debounce = 0,\n maxWait = void 0\n } = _a, watchOptions = __objRest$3(_a, [\n \"debounce\",\n \"maxWait\"\n ]);\n return watchWithFilter(source, cb, __spreadProps$4(__spreadValues$4({}, watchOptions), {\n eventFilter: debounceFilter(debounce, { maxWait })\n }));\n}\n\nvar __defProp$3 = Object.defineProperty;\nvar __defProps$3 = Object.defineProperties;\nvar __getOwnPropDescs$3 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$3 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$3 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$3 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$3 = (obj, key, value) => key in obj ? __defProp$3(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$3 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$3.call(b, prop))\n __defNormalProp$3(a, prop, b[prop]);\n if (__getOwnPropSymbols$3)\n for (var prop of __getOwnPropSymbols$3(b)) {\n if (__propIsEnum$3.call(b, prop))\n __defNormalProp$3(a, prop, b[prop]);\n }\n return a;\n};\nvar __spreadProps$3 = (a, b) => __defProps$3(a, __getOwnPropDescs$3(b));\nvar __objRest$2 = (source, exclude) => {\n var target = {};\n for (var prop in source)\n if (__hasOwnProp$3.call(source, prop) && exclude.indexOf(prop) < 0)\n target[prop] = source[prop];\n if (source != null && __getOwnPropSymbols$3)\n for (var prop of __getOwnPropSymbols$3(source)) {\n if (exclude.indexOf(prop) < 0 && __propIsEnum$3.call(source, prop))\n target[prop] = source[prop];\n }\n return target;\n};\nfunction watchIgnorable(source, cb, options = {}) {\n const _a = options, {\n eventFilter = bypassFilter\n } = _a, watchOptions = __objRest$2(_a, [\n \"eventFilter\"\n ]);\n const filteredCb = createFilterWrapper(eventFilter, cb);\n let ignoreUpdates;\n let ignorePrevAsyncUpdates;\n let stop;\n if (watchOptions.flush === \"sync\") {\n const ignore = ref(false);\n ignorePrevAsyncUpdates = () => {\n };\n ignoreUpdates = (updater) => {\n ignore.value = true;\n updater();\n ignore.value = false;\n };\n stop = watch(source, (...args) => {\n if (!ignore.value)\n filteredCb(...args);\n }, watchOptions);\n } else {\n const disposables = [];\n const ignoreCounter = ref(0);\n const syncCounter = ref(0);\n ignorePrevAsyncUpdates = () => {\n ignoreCounter.value = syncCounter.value;\n };\n disposables.push(watch(source, () => {\n syncCounter.value++;\n }, __spreadProps$3(__spreadValues$3({}, watchOptions), { flush: \"sync\" })));\n ignoreUpdates = (updater) => {\n const syncCounterPrev = syncCounter.value;\n updater();\n ignoreCounter.value += syncCounter.value - syncCounterPrev;\n };\n disposables.push(watch(source, (...args) => {\n const ignore = ignoreCounter.value > 0 && ignoreCounter.value === syncCounter.value;\n ignoreCounter.value = 0;\n syncCounter.value = 0;\n if (ignore)\n return;\n filteredCb(...args);\n }, watchOptions));\n stop = () => {\n disposables.forEach((fn) => fn());\n };\n }\n return { stop, ignoreUpdates, ignorePrevAsyncUpdates };\n}\n\nfunction watchOnce(source, cb, options) {\n const stop = watch(source, (...args) => {\n nextTick(() => stop());\n return cb(...args);\n }, options);\n}\n\nvar __defProp$2 = Object.defineProperty;\nvar __defProps$2 = Object.defineProperties;\nvar __getOwnPropDescs$2 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$2 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$2 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$2 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$2 = (obj, key, value) => key in obj ? __defProp$2(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$2 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$2.call(b, prop))\n __defNormalProp$2(a, prop, b[prop]);\n if (__getOwnPropSymbols$2)\n for (var prop of __getOwnPropSymbols$2(b)) {\n if (__propIsEnum$2.call(b, prop))\n __defNormalProp$2(a, prop, b[prop]);\n }\n return a;\n};\nvar __spreadProps$2 = (a, b) => __defProps$2(a, __getOwnPropDescs$2(b));\nvar __objRest$1 = (source, exclude) => {\n var target = {};\n for (var prop in source)\n if (__hasOwnProp$2.call(source, prop) && exclude.indexOf(prop) < 0)\n target[prop] = source[prop];\n if (source != null && __getOwnPropSymbols$2)\n for (var prop of __getOwnPropSymbols$2(source)) {\n if (exclude.indexOf(prop) < 0 && __propIsEnum$2.call(source, prop))\n target[prop] = source[prop];\n }\n return target;\n};\nfunction watchPausable(source, cb, options = {}) {\n const _a = options, {\n eventFilter: filter\n } = _a, watchOptions = __objRest$1(_a, [\n \"eventFilter\"\n ]);\n const { eventFilter, pause, resume, isActive } = pausableFilter(filter);\n const stop = watchWithFilter(source, cb, __spreadProps$2(__spreadValues$2({}, watchOptions), {\n eventFilter\n }));\n return { stop, pause, resume, isActive };\n}\n\nvar __defProp$1 = Object.defineProperty;\nvar __defProps$1 = Object.defineProperties;\nvar __getOwnPropDescs$1 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$1 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$1 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$1 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$1 = (obj, key, value) => key in obj ? __defProp$1(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$1 = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp$1.call(b, prop))\n __defNormalProp$1(a, prop, b[prop]);\n if (__getOwnPropSymbols$1)\n for (var prop of __getOwnPropSymbols$1(b)) {\n if (__propIsEnum$1.call(b, prop))\n __defNormalProp$1(a, prop, b[prop]);\n }\n return a;\n};\nvar __spreadProps$1 = (a, b) => __defProps$1(a, __getOwnPropDescs$1(b));\nvar __objRest = (source, exclude) => {\n var target = {};\n for (var prop in source)\n if (__hasOwnProp$1.call(source, prop) && exclude.indexOf(prop) < 0)\n target[prop] = source[prop];\n if (source != null && __getOwnPropSymbols$1)\n for (var prop of __getOwnPropSymbols$1(source)) {\n if (exclude.indexOf(prop) < 0 && __propIsEnum$1.call(source, prop))\n target[prop] = source[prop];\n }\n return target;\n};\nfunction watchThrottled(source, cb, options = {}) {\n const _a = options, {\n throttle = 0,\n trailing = true,\n leading = true\n } = _a, watchOptions = __objRest(_a, [\n \"throttle\",\n \"trailing\",\n \"leading\"\n ]);\n return watchWithFilter(source, cb, __spreadProps$1(__spreadValues$1({}, watchOptions), {\n eventFilter: throttleFilter(throttle, trailing, leading)\n }));\n}\n\nvar __defProp = Object.defineProperty;\nvar __defProps = Object.defineProperties;\nvar __getOwnPropDescs = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols = Object.getOwnPropertySymbols;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __propIsEnum = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues = (a, b) => {\n for (var prop in b || (b = {}))\n if (__hasOwnProp.call(b, prop))\n __defNormalProp(a, prop, b[prop]);\n if (__getOwnPropSymbols)\n for (var prop of __getOwnPropSymbols(b)) {\n if (__propIsEnum.call(b, prop))\n __defNormalProp(a, prop, b[prop]);\n }\n return a;\n};\nvar __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));\nfunction watchTriggerable(source, cb, options = {}) {\n let cleanupFn;\n function onEffect() {\n if (!cleanupFn)\n return;\n const fn = cleanupFn;\n cleanupFn = void 0;\n fn();\n }\n function onCleanup(callback) {\n cleanupFn = callback;\n }\n const _cb = (value, oldValue) => {\n onEffect();\n return cb(value, oldValue, onCleanup);\n };\n const res = watchIgnorable(source, _cb, options);\n const { ignoreUpdates } = res;\n const trigger = () => {\n let res2;\n ignoreUpdates(() => {\n res2 = _cb(getWatchSources(source), getOldValue(source));\n });\n return res2;\n };\n return __spreadProps(__spreadValues({}, res), {\n trigger\n });\n}\nfunction getWatchSources(sources) {\n if (isReactive(sources))\n return sources;\n if (Array.isArray(sources))\n return sources.map((item) => getOneWatchSource(item));\n return getOneWatchSource(sources);\n}\nfunction getOneWatchSource(source) {\n return typeof source === \"function\" ? source() : unref(source);\n}\nfunction getOldValue(source) {\n return Array.isArray(source) ? source.map(() => void 0) : void 0;\n}\n\nfunction whenever(source, cb, options) {\n return watch(source, (v, ov, onInvalidate) => {\n if (v)\n cb(v, ov, onInvalidate);\n }, options);\n}\n\nexport { __onlyVue27Plus, __onlyVue3, assert, refAutoReset as autoResetRef, bypassFilter, clamp, computedEager, computedWithControl, containsProp, computedWithControl as controlledComputed, controlledRef, createEventHook, createFilterWrapper, createGlobalState, createInjectionState, reactify as createReactiveFn, createSharedComposable, createSingletonPromise, debounceFilter, refDebounced as debouncedRef, watchDebounced as debouncedWatch, directiveHooks, computedEager as eagerComputed, extendRef, formatDate, get, hasOwn, identity, watchIgnorable as ignorableWatch, increaseWithUnit, invoke, isBoolean, isClient, isDef, isDefined, isFunction, isIOS, isNumber, isObject, isString, isWindow, makeDestructurable, noop, normalizeDate, now, objectPick, pausableFilter, watchPausable as pausableWatch, promiseTimeout, rand, reactify, reactifyObject, reactiveComputed, reactiveOmit, reactivePick, refAutoReset, refDebounced, refDefault, refThrottled, refWithControl, resolveRef, resolveUnref, set, syncRef, syncRefs, throttleFilter, refThrottled as throttledRef, watchThrottled as throttledWatch, timestamp, toReactive, toRefs, tryOnBeforeMount, tryOnBeforeUnmount, tryOnMounted, tryOnScopeDispose, tryOnUnmounted, until, useArrayEvery, useArrayFilter, useArrayFind, useArrayFindIndex, useArrayFindLast, useArrayJoin, useArrayMap, useArrayReduce, useArraySome, useArrayUnique, useCounter, useDateFormat, refDebounced as useDebounce, useDebounceFn, useInterval, useIntervalFn, useLastChanged, refThrottled as useThrottle, useThrottleFn, useTimeout, useTimeoutFn, useToNumber, useToString, useToggle, watchArray, watchAtMost, watchDebounced, watchIgnorable, watchOnce, watchPausable, watchThrottled, watchTriggerable, watchWithFilter, whenever };\n","'use strict';\nvar isCallable = require('../internals/is-callable');\n\nmodule.exports = function (it) {\n return typeof it == 'object' ? it !== null : isCallable(it);\n};\n","import identity from './identity.js';\nimport overRest from './_overRest.js';\nimport setToString from './_setToString.js';\n\n/**\n * The base implementation of `_.rest` which doesn't validate or coerce arguments.\n *\n * @private\n * @param {Function} func The function to apply a rest parameter to.\n * @param {number} [start=func.length-1] The start position of the rest parameter.\n * @returns {Function} Returns the new function.\n */\nfunction baseRest(func, start) {\n return setToString(overRest(func, start, identity), func + '');\n}\n\nexport default baseRest;\n","import type { InjectionKey } from 'vue'\nimport type { ButtonProps } from './button'\n\nexport interface ButtonGroupContext {\n size?: ButtonProps['size']\n type?: ButtonProps['type']\n}\n\nexport const buttonGroupContextKey: InjectionKey = Symbol(\n 'buttonGroupContextKey'\n)\n","import { Text, computed, inject, ref, useSlots } from 'vue'\nimport {\n useFormDisabled,\n useFormItem,\n useFormSize,\n} from '@element-plus/components/form'\nimport { useGlobalConfig } from '@element-plus/components/config-provider'\nimport { useDeprecated } from '@element-plus/hooks'\nimport { buttonGroupContextKey } from './constants'\n\nimport type { SetupContext } from 'vue'\nimport type { ButtonEmits, ButtonProps } from './button'\n\nexport const useButton = (\n props: ButtonProps,\n emit: SetupContext['emit']\n) => {\n useDeprecated(\n {\n from: 'type.text',\n replacement: 'link',\n version: '3.0.0',\n scope: 'props',\n ref: 'https://element-plus.org/en-US/component/button.html#button-attributes',\n },\n computed(() => props.type === 'text')\n )\n\n const buttonGroupContext = inject(buttonGroupContextKey, undefined)\n const globalConfig = useGlobalConfig('button')\n const { form } = useFormItem()\n const _size = useFormSize(computed(() => buttonGroupContext?.size))\n const _disabled = useFormDisabled()\n const _ref = ref()\n const slots = useSlots()\n\n const _type = computed(\n () =>\n props.type || buttonGroupContext?.type || globalConfig.value?.type || ''\n )\n const autoInsertSpace = computed(\n () => props.autoInsertSpace ?? globalConfig.value?.autoInsertSpace ?? false\n )\n const _plain = computed(\n () => props.plain ?? globalConfig.value?.plain ?? false\n )\n const _round = computed(\n () => props.round ?? globalConfig.value?.round ?? false\n )\n const _text = computed(() => props.text ?? globalConfig.value?.text ?? false)\n\n const _props = computed(() => {\n if (props.tag === 'button') {\n return {\n ariaDisabled: _disabled.value || props.loading,\n disabled: _disabled.value || props.loading,\n autofocus: props.autofocus,\n type: props.nativeType,\n }\n }\n return {}\n })\n\n // add space between two characters in Chinese\n const shouldAddSpace = computed(() => {\n const defaultSlot = slots.default?.()\n if (autoInsertSpace.value && defaultSlot?.length === 1) {\n const slot = defaultSlot[0]\n if (slot?.type === Text) {\n const text = slot.children as string\n return /^\\p{Unified_Ideograph}{2}$/u.test(text.trim())\n }\n }\n return false\n })\n\n const handleClick = (evt: MouseEvent) => {\n if (_disabled.value || props.loading) {\n evt.stopPropagation()\n return\n }\n if (props.nativeType === 'reset') {\n form?.resetFields()\n }\n emit('click', evt)\n }\n\n return {\n _disabled,\n _size,\n _type,\n _ref,\n _props,\n _plain,\n _round,\n _text,\n shouldAddSpace,\n handleClick,\n }\n}\n","import { computed } from 'vue'\nimport { TinyColor } from '@ctrl/tinycolor'\nimport { useNamespace } from '@element-plus/hooks'\nimport { useFormDisabled } from '@element-plus/components/form'\n\nimport type { ButtonProps } from './button'\n\nexport function darken(color: TinyColor, amount = 20) {\n return color.mix('#141414', amount).toString()\n}\n\nexport function useButtonCustomStyle(props: ButtonProps) {\n const _disabled = useFormDisabled()\n const ns = useNamespace('button')\n\n // calculate hover & active color by custom color\n // only work when custom color\n return computed(() => {\n let styles: Record = {}\n\n let buttonColor = props.color\n\n if (buttonColor) {\n const match = (buttonColor as string).match(/var\\((.*?)\\)/)\n if (match) {\n buttonColor = window\n .getComputedStyle(window.document.documentElement)\n .getPropertyValue(match[1])\n }\n const color = new TinyColor(buttonColor)\n const activeBgColor = props.dark\n ? color.tint(20).toString()\n : darken(color, 20)\n\n if (props.plain) {\n styles = ns.cssVarBlock({\n 'bg-color': props.dark\n ? darken(color, 90)\n : color.tint(90).toString(),\n 'text-color': buttonColor,\n 'border-color': props.dark\n ? darken(color, 50)\n : color.tint(50).toString(),\n 'hover-text-color': `var(${ns.cssVarName('color-white')})`,\n 'hover-bg-color': buttonColor,\n 'hover-border-color': buttonColor,\n 'active-bg-color': activeBgColor,\n 'active-text-color': `var(${ns.cssVarName('color-white')})`,\n 'active-border-color': activeBgColor,\n })\n\n if (_disabled.value) {\n styles[ns.cssVarBlockName('disabled-bg-color')] = props.dark\n ? darken(color, 90)\n : color.tint(90).toString()\n styles[ns.cssVarBlockName('disabled-text-color')] = props.dark\n ? darken(color, 50)\n : color.tint(50).toString()\n styles[ns.cssVarBlockName('disabled-border-color')] = props.dark\n ? darken(color, 80)\n : color.tint(80).toString()\n }\n } else {\n const hoverBgColor = props.dark\n ? darken(color, 30)\n : color.tint(30).toString()\n const textColor = color.isDark()\n ? `var(${ns.cssVarName('color-white')})`\n : `var(${ns.cssVarName('color-black')})`\n styles = ns.cssVarBlock({\n 'bg-color': buttonColor,\n 'text-color': textColor,\n 'border-color': buttonColor,\n 'hover-bg-color': hoverBgColor,\n 'hover-text-color': textColor,\n 'hover-border-color': hoverBgColor,\n 'active-bg-color': activeBgColor,\n 'active-border-color': activeBgColor,\n })\n\n if (_disabled.value) {\n const disabledButtonColor = props.dark\n ? darken(color, 50)\n : color.tint(50).toString()\n styles[ns.cssVarBlockName('disabled-bg-color')] = disabledButtonColor\n styles[ns.cssVarBlockName('disabled-text-color')] = props.dark\n ? 'rgba(255, 255, 255, 0.5)'\n : `var(${ns.cssVarName('color-white')})`\n styles[ns.cssVarBlockName('disabled-border-color')] =\n disabledButtonColor\n }\n }\n }\n\n return styles\n })\n}\n","\n\n\n","import { definePropType } from '@element-plus/utils'\nimport { buttonProps } from './button'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\n\nexport const buttonGroupProps = {\n /**\n * @description control the size of buttons in this button-group\n */\n size: buttonProps.size,\n /**\n * @description control the type of buttons in this button-group\n */\n type: buttonProps.type,\n /**\n * @description display direction\n */\n direction: {\n type: definePropType<'horizontal' | 'vertical'>(String),\n values: ['horizontal', 'vertical'],\n default: 'horizontal',\n },\n} as const\nexport type ButtonGroupProps = ExtractPropTypes\nexport type ButtonGroupPropsPublic = __ExtractPublicPropTypes<\n typeof buttonGroupProps\n>\n","\n\n\n","import { withInstall, withNoopInstall } from '@element-plus/utils'\nimport Button from './src/button.vue'\nimport ButtonGroup from './src/button-group.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElButton: SFCWithInstall & {\n ButtonGroup: typeof ButtonGroup\n} = withInstall(Button, {\n ButtonGroup,\n})\nexport const ElButtonGroup: SFCWithInstall =\n withNoopInstall(ButtonGroup)\nexport default ElButton\n\nexport * from './src/button'\nexport * from './src/constants'\nexport type { ButtonInstance, ButtonGroupInstance } from './src/instance'\n","'use strict';\nvar call = require('../internals/function-call');\nvar aCallable = require('../internals/a-callable');\nvar anObject = require('../internals/an-object');\nvar tryToString = require('../internals/try-to-string');\nvar getIteratorMethod = require('../internals/get-iterator-method');\n\nvar $TypeError = TypeError;\n\nmodule.exports = function (argument, usingIterator) {\n var iteratorMethod = arguments.length < 2 ? getIteratorMethod(argument) : usingIterator;\n if (aCallable(iteratorMethod)) return anObject(call(iteratorMethod, argument));\n throw new $TypeError(tryToString(argument) + ' is not iterable');\n};\n","import { buildProps } from '@element-plus/utils'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type Arrow from './arrow.vue'\n\nexport const popperArrowProps = buildProps({\n arrowOffset: {\n type: Number,\n default: 5,\n },\n} as const)\nexport type PopperArrowProps = ExtractPropTypes\nexport type PopperArrowPropsPublic = __ExtractPublicPropTypes<\n typeof popperArrowProps\n>\n\nexport type PopperArrowInstance = InstanceType & unknown\n\n/** @deprecated use `popperArrowProps` instead, and it will be deprecated in the next major version */\nexport const usePopperArrowProps = popperArrowProps\n\n/** @deprecated use `PopperArrowProps` instead, and it will be deprecated in the next major version */\nexport type UsePopperArrowProps = PopperArrowProps\n\n/** @deprecated use `PopperArrowInstance` instead, and it will be deprecated in the next major version */\nexport type ElPopperArrowInstance = PopperArrowInstance\n","'use strict';\nvar $ = require('../internals/export');\nvar call = require('../internals/function-call');\nvar iterate = require('../internals/iterate');\nvar aCallable = require('../internals/a-callable');\nvar anObject = require('../internals/an-object');\nvar getIteratorDirect = require('../internals/get-iterator-direct');\nvar iteratorClose = require('../internals/iterator-close');\nvar iteratorHelperWithoutClosingOnEarlyError = require('../internals/iterator-helper-without-closing-on-early-error');\n\nvar findWithoutClosingOnEarlyError = iteratorHelperWithoutClosingOnEarlyError('find', TypeError);\n\n// `Iterator.prototype.find` method\n// https://tc39.es/ecma262/#sec-iterator.prototype.find\n$({ target: 'Iterator', proto: true, real: true, forced: findWithoutClosingOnEarlyError }, {\n find: function find(predicate) {\n anObject(this);\n try {\n aCallable(predicate);\n } catch (error) {\n iteratorClose(this, 'throw', error);\n }\n\n if (findWithoutClosingOnEarlyError) return call(findWithoutClosingOnEarlyError, this, predicate);\n\n var record = getIteratorDirect(this);\n var counter = 0;\n return iterate(record, function (value, stop) {\n if (predicate(value, counter++)) return stop(value);\n }, { IS_RECORD: true, INTERRUPTED: true }).result;\n }\n});\n","/**\n* @vue/reactivity v3.5.25\n* (c) 2018-present Yuxi (Evan) You and Vue contributors\n* @license MIT\n**/\nimport { extend, hasChanged, isArray, isIntegerKey, isSymbol, isMap, hasOwn, makeMap, isObject, capitalize, toRawType, def, isFunction, EMPTY_OBJ, isSet, isPlainObject, remove, NOOP } from '@vue/shared';\n\nfunction warn(msg, ...args) {\n console.warn(`[Vue warn] ${msg}`, ...args);\n}\n\nlet activeEffectScope;\nclass EffectScope {\n constructor(detached = false) {\n this.detached = detached;\n /**\n * @internal\n */\n this._active = true;\n /**\n * @internal track `on` calls, allow `on` call multiple times\n */\n this._on = 0;\n /**\n * @internal\n */\n this.effects = [];\n /**\n * @internal\n */\n this.cleanups = [];\n this._isPaused = false;\n this.parent = activeEffectScope;\n if (!detached && activeEffectScope) {\n this.index = (activeEffectScope.scopes || (activeEffectScope.scopes = [])).push(\n this\n ) - 1;\n }\n }\n get active() {\n return this._active;\n }\n pause() {\n if (this._active) {\n this._isPaused = true;\n let i, l;\n if (this.scopes) {\n for (i = 0, l = this.scopes.length; i < l; i++) {\n this.scopes[i].pause();\n }\n }\n for (i = 0, l = this.effects.length; i < l; i++) {\n this.effects[i].pause();\n }\n }\n }\n /**\n * Resumes the effect scope, including all child scopes and effects.\n */\n resume() {\n if (this._active) {\n if (this._isPaused) {\n this._isPaused = false;\n let i, l;\n if (this.scopes) {\n for (i = 0, l = this.scopes.length; i < l; i++) {\n this.scopes[i].resume();\n }\n }\n for (i = 0, l = this.effects.length; i < l; i++) {\n this.effects[i].resume();\n }\n }\n }\n }\n run(fn) {\n if (this._active) {\n const currentEffectScope = activeEffectScope;\n try {\n activeEffectScope = this;\n return fn();\n } finally {\n activeEffectScope = currentEffectScope;\n }\n } else if (!!(process.env.NODE_ENV !== \"production\")) {\n warn(`cannot run an inactive effect scope.`);\n }\n }\n /**\n * This should only be called on non-detached scopes\n * @internal\n */\n on() {\n if (++this._on === 1) {\n this.prevScope = activeEffectScope;\n activeEffectScope = this;\n }\n }\n /**\n * This should only be called on non-detached scopes\n * @internal\n */\n off() {\n if (this._on > 0 && --this._on === 0) {\n activeEffectScope = this.prevScope;\n this.prevScope = void 0;\n }\n }\n stop(fromParent) {\n if (this._active) {\n this._active = false;\n let i, l;\n for (i = 0, l = this.effects.length; i < l; i++) {\n this.effects[i].stop();\n }\n this.effects.length = 0;\n for (i = 0, l = this.cleanups.length; i < l; i++) {\n this.cleanups[i]();\n }\n this.cleanups.length = 0;\n if (this.scopes) {\n for (i = 0, l = this.scopes.length; i < l; i++) {\n this.scopes[i].stop(true);\n }\n this.scopes.length = 0;\n }\n if (!this.detached && this.parent && !fromParent) {\n const last = this.parent.scopes.pop();\n if (last && last !== this) {\n this.parent.scopes[this.index] = last;\n last.index = this.index;\n }\n }\n this.parent = void 0;\n }\n }\n}\nfunction effectScope(detached) {\n return new EffectScope(detached);\n}\nfunction getCurrentScope() {\n return activeEffectScope;\n}\nfunction onScopeDispose(fn, failSilently = false) {\n if (activeEffectScope) {\n activeEffectScope.cleanups.push(fn);\n } else if (!!(process.env.NODE_ENV !== \"production\") && !failSilently) {\n warn(\n `onScopeDispose() is called when there is no active effect scope to be associated with.`\n );\n }\n}\n\nlet activeSub;\nconst EffectFlags = {\n \"ACTIVE\": 1,\n \"1\": \"ACTIVE\",\n \"RUNNING\": 2,\n \"2\": \"RUNNING\",\n \"TRACKING\": 4,\n \"4\": \"TRACKING\",\n \"NOTIFIED\": 8,\n \"8\": \"NOTIFIED\",\n \"DIRTY\": 16,\n \"16\": \"DIRTY\",\n \"ALLOW_RECURSE\": 32,\n \"32\": \"ALLOW_RECURSE\",\n \"PAUSED\": 64,\n \"64\": \"PAUSED\",\n \"EVALUATED\": 128,\n \"128\": \"EVALUATED\"\n};\nconst pausedQueueEffects = /* @__PURE__ */ new WeakSet();\nclass ReactiveEffect {\n constructor(fn) {\n this.fn = fn;\n /**\n * @internal\n */\n this.deps = void 0;\n /**\n * @internal\n */\n this.depsTail = void 0;\n /**\n * @internal\n */\n this.flags = 1 | 4;\n /**\n * @internal\n */\n this.next = void 0;\n /**\n * @internal\n */\n this.cleanup = void 0;\n this.scheduler = void 0;\n if (activeEffectScope && activeEffectScope.active) {\n activeEffectScope.effects.push(this);\n }\n }\n pause() {\n this.flags |= 64;\n }\n resume() {\n if (this.flags & 64) {\n this.flags &= -65;\n if (pausedQueueEffects.has(this)) {\n pausedQueueEffects.delete(this);\n this.trigger();\n }\n }\n }\n /**\n * @internal\n */\n notify() {\n if (this.flags & 2 && !(this.flags & 32)) {\n return;\n }\n if (!(this.flags & 8)) {\n batch(this);\n }\n }\n run() {\n if (!(this.flags & 1)) {\n return this.fn();\n }\n this.flags |= 2;\n cleanupEffect(this);\n prepareDeps(this);\n const prevEffect = activeSub;\n const prevShouldTrack = shouldTrack;\n activeSub = this;\n shouldTrack = true;\n try {\n return this.fn();\n } finally {\n if (!!(process.env.NODE_ENV !== \"production\") && activeSub !== this) {\n warn(\n \"Active effect was not restored correctly - this is likely a Vue internal bug.\"\n );\n }\n cleanupDeps(this);\n activeSub = prevEffect;\n shouldTrack = prevShouldTrack;\n this.flags &= -3;\n }\n }\n stop() {\n if (this.flags & 1) {\n for (let link = this.deps; link; link = link.nextDep) {\n removeSub(link);\n }\n this.deps = this.depsTail = void 0;\n cleanupEffect(this);\n this.onStop && this.onStop();\n this.flags &= -2;\n }\n }\n trigger() {\n if (this.flags & 64) {\n pausedQueueEffects.add(this);\n } else if (this.scheduler) {\n this.scheduler();\n } else {\n this.runIfDirty();\n }\n }\n /**\n * @internal\n */\n runIfDirty() {\n if (isDirty(this)) {\n this.run();\n }\n }\n get dirty() {\n return isDirty(this);\n }\n}\nlet batchDepth = 0;\nlet batchedSub;\nlet batchedComputed;\nfunction batch(sub, isComputed = false) {\n sub.flags |= 8;\n if (isComputed) {\n sub.next = batchedComputed;\n batchedComputed = sub;\n return;\n }\n sub.next = batchedSub;\n batchedSub = sub;\n}\nfunction startBatch() {\n batchDepth++;\n}\nfunction endBatch() {\n if (--batchDepth > 0) {\n return;\n }\n if (batchedComputed) {\n let e = batchedComputed;\n batchedComputed = void 0;\n while (e) {\n const next = e.next;\n e.next = void 0;\n e.flags &= -9;\n e = next;\n }\n }\n let error;\n while (batchedSub) {\n let e = batchedSub;\n batchedSub = void 0;\n while (e) {\n const next = e.next;\n e.next = void 0;\n e.flags &= -9;\n if (e.flags & 1) {\n try {\n ;\n e.trigger();\n } catch (err) {\n if (!error) error = err;\n }\n }\n e = next;\n }\n }\n if (error) throw error;\n}\nfunction prepareDeps(sub) {\n for (let link = sub.deps; link; link = link.nextDep) {\n link.version = -1;\n link.prevActiveLink = link.dep.activeLink;\n link.dep.activeLink = link;\n }\n}\nfunction cleanupDeps(sub) {\n let head;\n let tail = sub.depsTail;\n let link = tail;\n while (link) {\n const prev = link.prevDep;\n if (link.version === -1) {\n if (link === tail) tail = prev;\n removeSub(link);\n removeDep(link);\n } else {\n head = link;\n }\n link.dep.activeLink = link.prevActiveLink;\n link.prevActiveLink = void 0;\n link = prev;\n }\n sub.deps = head;\n sub.depsTail = tail;\n}\nfunction isDirty(sub) {\n for (let link = sub.deps; link; link = link.nextDep) {\n if (link.dep.version !== link.version || link.dep.computed && (refreshComputed(link.dep.computed) || link.dep.version !== link.version)) {\n return true;\n }\n }\n if (sub._dirty) {\n return true;\n }\n return false;\n}\nfunction refreshComputed(computed) {\n if (computed.flags & 4 && !(computed.flags & 16)) {\n return;\n }\n computed.flags &= -17;\n if (computed.globalVersion === globalVersion) {\n return;\n }\n computed.globalVersion = globalVersion;\n if (!computed.isSSR && computed.flags & 128 && (!computed.deps && !computed._dirty || !isDirty(computed))) {\n return;\n }\n computed.flags |= 2;\n const dep = computed.dep;\n const prevSub = activeSub;\n const prevShouldTrack = shouldTrack;\n activeSub = computed;\n shouldTrack = true;\n try {\n prepareDeps(computed);\n const value = computed.fn(computed._value);\n if (dep.version === 0 || hasChanged(value, computed._value)) {\n computed.flags |= 128;\n computed._value = value;\n dep.version++;\n }\n } catch (err) {\n dep.version++;\n throw err;\n } finally {\n activeSub = prevSub;\n shouldTrack = prevShouldTrack;\n cleanupDeps(computed);\n computed.flags &= -3;\n }\n}\nfunction removeSub(link, soft = false) {\n const { dep, prevSub, nextSub } = link;\n if (prevSub) {\n prevSub.nextSub = nextSub;\n link.prevSub = void 0;\n }\n if (nextSub) {\n nextSub.prevSub = prevSub;\n link.nextSub = void 0;\n }\n if (!!(process.env.NODE_ENV !== \"production\") && dep.subsHead === link) {\n dep.subsHead = nextSub;\n }\n if (dep.subs === link) {\n dep.subs = prevSub;\n if (!prevSub && dep.computed) {\n dep.computed.flags &= -5;\n for (let l = dep.computed.deps; l; l = l.nextDep) {\n removeSub(l, true);\n }\n }\n }\n if (!soft && !--dep.sc && dep.map) {\n dep.map.delete(dep.key);\n }\n}\nfunction removeDep(link) {\n const { prevDep, nextDep } = link;\n if (prevDep) {\n prevDep.nextDep = nextDep;\n link.prevDep = void 0;\n }\n if (nextDep) {\n nextDep.prevDep = prevDep;\n link.nextDep = void 0;\n }\n}\nfunction effect(fn, options) {\n if (fn.effect instanceof ReactiveEffect) {\n fn = fn.effect.fn;\n }\n const e = new ReactiveEffect(fn);\n if (options) {\n extend(e, options);\n }\n try {\n e.run();\n } catch (err) {\n e.stop();\n throw err;\n }\n const runner = e.run.bind(e);\n runner.effect = e;\n return runner;\n}\nfunction stop(runner) {\n runner.effect.stop();\n}\nlet shouldTrack = true;\nconst trackStack = [];\nfunction pauseTracking() {\n trackStack.push(shouldTrack);\n shouldTrack = false;\n}\nfunction enableTracking() {\n trackStack.push(shouldTrack);\n shouldTrack = true;\n}\nfunction resetTracking() {\n const last = trackStack.pop();\n shouldTrack = last === void 0 ? true : last;\n}\nfunction onEffectCleanup(fn, failSilently = false) {\n if (activeSub instanceof ReactiveEffect) {\n activeSub.cleanup = fn;\n } else if (!!(process.env.NODE_ENV !== \"production\") && !failSilently) {\n warn(\n `onEffectCleanup() was called when there was no active effect to associate with.`\n );\n }\n}\nfunction cleanupEffect(e) {\n const { cleanup } = e;\n e.cleanup = void 0;\n if (cleanup) {\n const prevSub = activeSub;\n activeSub = void 0;\n try {\n cleanup();\n } finally {\n activeSub = prevSub;\n }\n }\n}\n\nlet globalVersion = 0;\nclass Link {\n constructor(sub, dep) {\n this.sub = sub;\n this.dep = dep;\n this.version = dep.version;\n this.nextDep = this.prevDep = this.nextSub = this.prevSub = this.prevActiveLink = void 0;\n }\n}\nclass Dep {\n // TODO isolatedDeclarations \"__v_skip\"\n constructor(computed) {\n this.computed = computed;\n this.version = 0;\n /**\n * Link between this dep and the current active effect\n */\n this.activeLink = void 0;\n /**\n * Doubly linked list representing the subscribing effects (tail)\n */\n this.subs = void 0;\n /**\n * For object property deps cleanup\n */\n this.map = void 0;\n this.key = void 0;\n /**\n * Subscriber counter\n */\n this.sc = 0;\n /**\n * @internal\n */\n this.__v_skip = true;\n if (!!(process.env.NODE_ENV !== \"production\")) {\n this.subsHead = void 0;\n }\n }\n track(debugInfo) {\n if (!activeSub || !shouldTrack || activeSub === this.computed) {\n return;\n }\n let link = this.activeLink;\n if (link === void 0 || link.sub !== activeSub) {\n link = this.activeLink = new Link(activeSub, this);\n if (!activeSub.deps) {\n activeSub.deps = activeSub.depsTail = link;\n } else {\n link.prevDep = activeSub.depsTail;\n activeSub.depsTail.nextDep = link;\n activeSub.depsTail = link;\n }\n addSub(link);\n } else if (link.version === -1) {\n link.version = this.version;\n if (link.nextDep) {\n const next = link.nextDep;\n next.prevDep = link.prevDep;\n if (link.prevDep) {\n link.prevDep.nextDep = next;\n }\n link.prevDep = activeSub.depsTail;\n link.nextDep = void 0;\n activeSub.depsTail.nextDep = link;\n activeSub.depsTail = link;\n if (activeSub.deps === link) {\n activeSub.deps = next;\n }\n }\n }\n if (!!(process.env.NODE_ENV !== \"production\") && activeSub.onTrack) {\n activeSub.onTrack(\n extend(\n {\n effect: activeSub\n },\n debugInfo\n )\n );\n }\n return link;\n }\n trigger(debugInfo) {\n this.version++;\n globalVersion++;\n this.notify(debugInfo);\n }\n notify(debugInfo) {\n startBatch();\n try {\n if (!!(process.env.NODE_ENV !== \"production\")) {\n for (let head = this.subsHead; head; head = head.nextSub) {\n if (head.sub.onTrigger && !(head.sub.flags & 8)) {\n head.sub.onTrigger(\n extend(\n {\n effect: head.sub\n },\n debugInfo\n )\n );\n }\n }\n }\n for (let link = this.subs; link; link = link.prevSub) {\n if (link.sub.notify()) {\n ;\n link.sub.dep.notify();\n }\n }\n } finally {\n endBatch();\n }\n }\n}\nfunction addSub(link) {\n link.dep.sc++;\n if (link.sub.flags & 4) {\n const computed = link.dep.computed;\n if (computed && !link.dep.subs) {\n computed.flags |= 4 | 16;\n for (let l = computed.deps; l; l = l.nextDep) {\n addSub(l);\n }\n }\n const currentTail = link.dep.subs;\n if (currentTail !== link) {\n link.prevSub = currentTail;\n if (currentTail) currentTail.nextSub = link;\n }\n if (!!(process.env.NODE_ENV !== \"production\") && link.dep.subsHead === void 0) {\n link.dep.subsHead = link;\n }\n link.dep.subs = link;\n }\n}\nconst targetMap = /* @__PURE__ */ new WeakMap();\nconst ITERATE_KEY = Symbol(\n !!(process.env.NODE_ENV !== \"production\") ? \"Object iterate\" : \"\"\n);\nconst MAP_KEY_ITERATE_KEY = Symbol(\n !!(process.env.NODE_ENV !== \"production\") ? \"Map keys iterate\" : \"\"\n);\nconst ARRAY_ITERATE_KEY = Symbol(\n !!(process.env.NODE_ENV !== \"production\") ? \"Array iterate\" : \"\"\n);\nfunction track(target, type, key) {\n if (shouldTrack && activeSub) {\n let depsMap = targetMap.get(target);\n if (!depsMap) {\n targetMap.set(target, depsMap = /* @__PURE__ */ new Map());\n }\n let dep = depsMap.get(key);\n if (!dep) {\n depsMap.set(key, dep = new Dep());\n dep.map = depsMap;\n dep.key = key;\n }\n if (!!(process.env.NODE_ENV !== \"production\")) {\n dep.track({\n target,\n type,\n key\n });\n } else {\n dep.track();\n }\n }\n}\nfunction trigger(target, type, key, newValue, oldValue, oldTarget) {\n const depsMap = targetMap.get(target);\n if (!depsMap) {\n globalVersion++;\n return;\n }\n const run = (dep) => {\n if (dep) {\n if (!!(process.env.NODE_ENV !== \"production\")) {\n dep.trigger({\n target,\n type,\n key,\n newValue,\n oldValue,\n oldTarget\n });\n } else {\n dep.trigger();\n }\n }\n };\n startBatch();\n if (type === \"clear\") {\n depsMap.forEach(run);\n } else {\n const targetIsArray = isArray(target);\n const isArrayIndex = targetIsArray && isIntegerKey(key);\n if (targetIsArray && key === \"length\") {\n const newLength = Number(newValue);\n depsMap.forEach((dep, key2) => {\n if (key2 === \"length\" || key2 === ARRAY_ITERATE_KEY || !isSymbol(key2) && key2 >= newLength) {\n run(dep);\n }\n });\n } else {\n if (key !== void 0 || depsMap.has(void 0)) {\n run(depsMap.get(key));\n }\n if (isArrayIndex) {\n run(depsMap.get(ARRAY_ITERATE_KEY));\n }\n switch (type) {\n case \"add\":\n if (!targetIsArray) {\n run(depsMap.get(ITERATE_KEY));\n if (isMap(target)) {\n run(depsMap.get(MAP_KEY_ITERATE_KEY));\n }\n } else if (isArrayIndex) {\n run(depsMap.get(\"length\"));\n }\n break;\n case \"delete\":\n if (!targetIsArray) {\n run(depsMap.get(ITERATE_KEY));\n if (isMap(target)) {\n run(depsMap.get(MAP_KEY_ITERATE_KEY));\n }\n }\n break;\n case \"set\":\n if (isMap(target)) {\n run(depsMap.get(ITERATE_KEY));\n }\n break;\n }\n }\n }\n endBatch();\n}\nfunction getDepFromReactive(object, key) {\n const depMap = targetMap.get(object);\n return depMap && depMap.get(key);\n}\n\nfunction reactiveReadArray(array) {\n const raw = toRaw(array);\n if (raw === array) return raw;\n track(raw, \"iterate\", ARRAY_ITERATE_KEY);\n return isShallow(array) ? raw : raw.map(toReactive);\n}\nfunction shallowReadArray(arr) {\n track(arr = toRaw(arr), \"iterate\", ARRAY_ITERATE_KEY);\n return arr;\n}\nfunction toWrapped(target, item) {\n if (isReadonly(target)) {\n return isReactive(target) ? toReadonly(toReactive(item)) : toReadonly(item);\n }\n return toReactive(item);\n}\nconst arrayInstrumentations = {\n __proto__: null,\n [Symbol.iterator]() {\n return iterator(this, Symbol.iterator, (item) => toWrapped(this, item));\n },\n concat(...args) {\n return reactiveReadArray(this).concat(\n ...args.map((x) => isArray(x) ? reactiveReadArray(x) : x)\n );\n },\n entries() {\n return iterator(this, \"entries\", (value) => {\n value[1] = toWrapped(this, value[1]);\n return value;\n });\n },\n every(fn, thisArg) {\n return apply(this, \"every\", fn, thisArg, void 0, arguments);\n },\n filter(fn, thisArg) {\n return apply(\n this,\n \"filter\",\n fn,\n thisArg,\n (v) => v.map((item) => toWrapped(this, item)),\n arguments\n );\n },\n find(fn, thisArg) {\n return apply(\n this,\n \"find\",\n fn,\n thisArg,\n (item) => toWrapped(this, item),\n arguments\n );\n },\n findIndex(fn, thisArg) {\n return apply(this, \"findIndex\", fn, thisArg, void 0, arguments);\n },\n findLast(fn, thisArg) {\n return apply(\n this,\n \"findLast\",\n fn,\n thisArg,\n (item) => toWrapped(this, item),\n arguments\n );\n },\n findLastIndex(fn, thisArg) {\n return apply(this, \"findLastIndex\", fn, thisArg, void 0, arguments);\n },\n // flat, flatMap could benefit from ARRAY_ITERATE but are not straight-forward to implement\n forEach(fn, thisArg) {\n return apply(this, \"forEach\", fn, thisArg, void 0, arguments);\n },\n includes(...args) {\n return searchProxy(this, \"includes\", args);\n },\n indexOf(...args) {\n return searchProxy(this, \"indexOf\", args);\n },\n join(separator) {\n return reactiveReadArray(this).join(separator);\n },\n // keys() iterator only reads `length`, no optimization required\n lastIndexOf(...args) {\n return searchProxy(this, \"lastIndexOf\", args);\n },\n map(fn, thisArg) {\n return apply(this, \"map\", fn, thisArg, void 0, arguments);\n },\n pop() {\n return noTracking(this, \"pop\");\n },\n push(...args) {\n return noTracking(this, \"push\", args);\n },\n reduce(fn, ...args) {\n return reduce(this, \"reduce\", fn, args);\n },\n reduceRight(fn, ...args) {\n return reduce(this, \"reduceRight\", fn, args);\n },\n shift() {\n return noTracking(this, \"shift\");\n },\n // slice could use ARRAY_ITERATE but also seems to beg for range tracking\n some(fn, thisArg) {\n return apply(this, \"some\", fn, thisArg, void 0, arguments);\n },\n splice(...args) {\n return noTracking(this, \"splice\", args);\n },\n toReversed() {\n return reactiveReadArray(this).toReversed();\n },\n toSorted(comparer) {\n return reactiveReadArray(this).toSorted(comparer);\n },\n toSpliced(...args) {\n return reactiveReadArray(this).toSpliced(...args);\n },\n unshift(...args) {\n return noTracking(this, \"unshift\", args);\n },\n values() {\n return iterator(this, \"values\", (item) => toWrapped(this, item));\n }\n};\nfunction iterator(self, method, wrapValue) {\n const arr = shallowReadArray(self);\n const iter = arr[method]();\n if (arr !== self && !isShallow(self)) {\n iter._next = iter.next;\n iter.next = () => {\n const result = iter._next();\n if (!result.done) {\n result.value = wrapValue(result.value);\n }\n return result;\n };\n }\n return iter;\n}\nconst arrayProto = Array.prototype;\nfunction apply(self, method, fn, thisArg, wrappedRetFn, args) {\n const arr = shallowReadArray(self);\n const needsWrap = arr !== self && !isShallow(self);\n const methodFn = arr[method];\n if (methodFn !== arrayProto[method]) {\n const result2 = methodFn.apply(self, args);\n return needsWrap ? toReactive(result2) : result2;\n }\n let wrappedFn = fn;\n if (arr !== self) {\n if (needsWrap) {\n wrappedFn = function(item, index) {\n return fn.call(this, toWrapped(self, item), index, self);\n };\n } else if (fn.length > 2) {\n wrappedFn = function(item, index) {\n return fn.call(this, item, index, self);\n };\n }\n }\n const result = methodFn.call(arr, wrappedFn, thisArg);\n return needsWrap && wrappedRetFn ? wrappedRetFn(result) : result;\n}\nfunction reduce(self, method, fn, args) {\n const arr = shallowReadArray(self);\n let wrappedFn = fn;\n if (arr !== self) {\n if (!isShallow(self)) {\n wrappedFn = function(acc, item, index) {\n return fn.call(this, acc, toWrapped(self, item), index, self);\n };\n } else if (fn.length > 3) {\n wrappedFn = function(acc, item, index) {\n return fn.call(this, acc, item, index, self);\n };\n }\n }\n return arr[method](wrappedFn, ...args);\n}\nfunction searchProxy(self, method, args) {\n const arr = toRaw(self);\n track(arr, \"iterate\", ARRAY_ITERATE_KEY);\n const res = arr[method](...args);\n if ((res === -1 || res === false) && isProxy(args[0])) {\n args[0] = toRaw(args[0]);\n return arr[method](...args);\n }\n return res;\n}\nfunction noTracking(self, method, args = []) {\n pauseTracking();\n startBatch();\n const res = toRaw(self)[method].apply(self, args);\n endBatch();\n resetTracking();\n return res;\n}\n\nconst isNonTrackableKeys = /* @__PURE__ */ makeMap(`__proto__,__v_isRef,__isVue`);\nconst builtInSymbols = new Set(\n /* @__PURE__ */ Object.getOwnPropertyNames(Symbol).filter((key) => key !== \"arguments\" && key !== \"caller\").map((key) => Symbol[key]).filter(isSymbol)\n);\nfunction hasOwnProperty(key) {\n if (!isSymbol(key)) key = String(key);\n const obj = toRaw(this);\n track(obj, \"has\", key);\n return obj.hasOwnProperty(key);\n}\nclass BaseReactiveHandler {\n constructor(_isReadonly = false, _isShallow = false) {\n this._isReadonly = _isReadonly;\n this._isShallow = _isShallow;\n }\n get(target, key, receiver) {\n if (key === \"__v_skip\") return target[\"__v_skip\"];\n const isReadonly2 = this._isReadonly, isShallow2 = this._isShallow;\n if (key === \"__v_isReactive\") {\n return !isReadonly2;\n } else if (key === \"__v_isReadonly\") {\n return isReadonly2;\n } else if (key === \"__v_isShallow\") {\n return isShallow2;\n } else if (key === \"__v_raw\") {\n if (receiver === (isReadonly2 ? isShallow2 ? shallowReadonlyMap : readonlyMap : isShallow2 ? shallowReactiveMap : reactiveMap).get(target) || // receiver is not the reactive proxy, but has the same prototype\n // this means the receiver is a user proxy of the reactive proxy\n Object.getPrototypeOf(target) === Object.getPrototypeOf(receiver)) {\n return target;\n }\n return;\n }\n const targetIsArray = isArray(target);\n if (!isReadonly2) {\n let fn;\n if (targetIsArray && (fn = arrayInstrumentations[key])) {\n return fn;\n }\n if (key === \"hasOwnProperty\") {\n return hasOwnProperty;\n }\n }\n const res = Reflect.get(\n target,\n key,\n // if this is a proxy wrapping a ref, return methods using the raw ref\n // as receiver so that we don't have to call `toRaw` on the ref in all\n // its class methods\n isRef(target) ? target : receiver\n );\n if (isSymbol(key) ? builtInSymbols.has(key) : isNonTrackableKeys(key)) {\n return res;\n }\n if (!isReadonly2) {\n track(target, \"get\", key);\n }\n if (isShallow2) {\n return res;\n }\n if (isRef(res)) {\n const value = targetIsArray && isIntegerKey(key) ? res : res.value;\n return isReadonly2 && isObject(value) ? readonly(value) : value;\n }\n if (isObject(res)) {\n return isReadonly2 ? readonly(res) : reactive(res);\n }\n return res;\n }\n}\nclass MutableReactiveHandler extends BaseReactiveHandler {\n constructor(isShallow2 = false) {\n super(false, isShallow2);\n }\n set(target, key, value, receiver) {\n let oldValue = target[key];\n const isArrayWithIntegerKey = isArray(target) && isIntegerKey(key);\n if (!this._isShallow) {\n const isOldValueReadonly = isReadonly(oldValue);\n if (!isShallow(value) && !isReadonly(value)) {\n oldValue = toRaw(oldValue);\n value = toRaw(value);\n }\n if (!isArrayWithIntegerKey && isRef(oldValue) && !isRef(value)) {\n if (isOldValueReadonly) {\n if (!!(process.env.NODE_ENV !== \"production\")) {\n warn(\n `Set operation on key \"${String(key)}\" failed: target is readonly.`,\n target[key]\n );\n }\n return true;\n } else {\n oldValue.value = value;\n return true;\n }\n }\n }\n const hadKey = isArrayWithIntegerKey ? Number(key) < target.length : hasOwn(target, key);\n const result = Reflect.set(\n target,\n key,\n value,\n isRef(target) ? target : receiver\n );\n if (target === toRaw(receiver)) {\n if (!hadKey) {\n trigger(target, \"add\", key, value);\n } else if (hasChanged(value, oldValue)) {\n trigger(target, \"set\", key, value, oldValue);\n }\n }\n return result;\n }\n deleteProperty(target, key) {\n const hadKey = hasOwn(target, key);\n const oldValue = target[key];\n const result = Reflect.deleteProperty(target, key);\n if (result && hadKey) {\n trigger(target, \"delete\", key, void 0, oldValue);\n }\n return result;\n }\n has(target, key) {\n const result = Reflect.has(target, key);\n if (!isSymbol(key) || !builtInSymbols.has(key)) {\n track(target, \"has\", key);\n }\n return result;\n }\n ownKeys(target) {\n track(\n target,\n \"iterate\",\n isArray(target) ? \"length\" : ITERATE_KEY\n );\n return Reflect.ownKeys(target);\n }\n}\nclass ReadonlyReactiveHandler extends BaseReactiveHandler {\n constructor(isShallow2 = false) {\n super(true, isShallow2);\n }\n set(target, key) {\n if (!!(process.env.NODE_ENV !== \"production\")) {\n warn(\n `Set operation on key \"${String(key)}\" failed: target is readonly.`,\n target\n );\n }\n return true;\n }\n deleteProperty(target, key) {\n if (!!(process.env.NODE_ENV !== \"production\")) {\n warn(\n `Delete operation on key \"${String(key)}\" failed: target is readonly.`,\n target\n );\n }\n return true;\n }\n}\nconst mutableHandlers = /* @__PURE__ */ new MutableReactiveHandler();\nconst readonlyHandlers = /* @__PURE__ */ new ReadonlyReactiveHandler();\nconst shallowReactiveHandlers = /* @__PURE__ */ new MutableReactiveHandler(true);\nconst shallowReadonlyHandlers = /* @__PURE__ */ new ReadonlyReactiveHandler(true);\n\nconst toShallow = (value) => value;\nconst getProto = (v) => Reflect.getPrototypeOf(v);\nfunction createIterableMethod(method, isReadonly2, isShallow2) {\n return function(...args) {\n const target = this[\"__v_raw\"];\n const rawTarget = toRaw(target);\n const targetIsMap = isMap(rawTarget);\n const isPair = method === \"entries\" || method === Symbol.iterator && targetIsMap;\n const isKeyOnly = method === \"keys\" && targetIsMap;\n const innerIterator = target[method](...args);\n const wrap = isShallow2 ? toShallow : isReadonly2 ? toReadonly : toReactive;\n !isReadonly2 && track(\n rawTarget,\n \"iterate\",\n isKeyOnly ? MAP_KEY_ITERATE_KEY : ITERATE_KEY\n );\n return {\n // iterator protocol\n next() {\n const { value, done } = innerIterator.next();\n return done ? { value, done } : {\n value: isPair ? [wrap(value[0]), wrap(value[1])] : wrap(value),\n done\n };\n },\n // iterable protocol\n [Symbol.iterator]() {\n return this;\n }\n };\n };\n}\nfunction createReadonlyMethod(type) {\n return function(...args) {\n if (!!(process.env.NODE_ENV !== \"production\")) {\n const key = args[0] ? `on key \"${args[0]}\" ` : ``;\n warn(\n `${capitalize(type)} operation ${key}failed: target is readonly.`,\n toRaw(this)\n );\n }\n return type === \"delete\" ? false : type === \"clear\" ? void 0 : this;\n };\n}\nfunction createInstrumentations(readonly, shallow) {\n const instrumentations = {\n get(key) {\n const target = this[\"__v_raw\"];\n const rawTarget = toRaw(target);\n const rawKey = toRaw(key);\n if (!readonly) {\n if (hasChanged(key, rawKey)) {\n track(rawTarget, \"get\", key);\n }\n track(rawTarget, \"get\", rawKey);\n }\n const { has } = getProto(rawTarget);\n const wrap = shallow ? toShallow : readonly ? toReadonly : toReactive;\n if (has.call(rawTarget, key)) {\n return wrap(target.get(key));\n } else if (has.call(rawTarget, rawKey)) {\n return wrap(target.get(rawKey));\n } else if (target !== rawTarget) {\n target.get(key);\n }\n },\n get size() {\n const target = this[\"__v_raw\"];\n !readonly && track(toRaw(target), \"iterate\", ITERATE_KEY);\n return target.size;\n },\n has(key) {\n const target = this[\"__v_raw\"];\n const rawTarget = toRaw(target);\n const rawKey = toRaw(key);\n if (!readonly) {\n if (hasChanged(key, rawKey)) {\n track(rawTarget, \"has\", key);\n }\n track(rawTarget, \"has\", rawKey);\n }\n return key === rawKey ? target.has(key) : target.has(key) || target.has(rawKey);\n },\n forEach(callback, thisArg) {\n const observed = this;\n const target = observed[\"__v_raw\"];\n const rawTarget = toRaw(target);\n const wrap = shallow ? toShallow : readonly ? toReadonly : toReactive;\n !readonly && track(rawTarget, \"iterate\", ITERATE_KEY);\n return target.forEach((value, key) => {\n return callback.call(thisArg, wrap(value), wrap(key), observed);\n });\n }\n };\n extend(\n instrumentations,\n readonly ? {\n add: createReadonlyMethod(\"add\"),\n set: createReadonlyMethod(\"set\"),\n delete: createReadonlyMethod(\"delete\"),\n clear: createReadonlyMethod(\"clear\")\n } : {\n add(value) {\n if (!shallow && !isShallow(value) && !isReadonly(value)) {\n value = toRaw(value);\n }\n const target = toRaw(this);\n const proto = getProto(target);\n const hadKey = proto.has.call(target, value);\n if (!hadKey) {\n target.add(value);\n trigger(target, \"add\", value, value);\n }\n return this;\n },\n set(key, value) {\n if (!shallow && !isShallow(value) && !isReadonly(value)) {\n value = toRaw(value);\n }\n const target = toRaw(this);\n const { has, get } = getProto(target);\n let hadKey = has.call(target, key);\n if (!hadKey) {\n key = toRaw(key);\n hadKey = has.call(target, key);\n } else if (!!(process.env.NODE_ENV !== \"production\")) {\n checkIdentityKeys(target, has, key);\n }\n const oldValue = get.call(target, key);\n target.set(key, value);\n if (!hadKey) {\n trigger(target, \"add\", key, value);\n } else if (hasChanged(value, oldValue)) {\n trigger(target, \"set\", key, value, oldValue);\n }\n return this;\n },\n delete(key) {\n const target = toRaw(this);\n const { has, get } = getProto(target);\n let hadKey = has.call(target, key);\n if (!hadKey) {\n key = toRaw(key);\n hadKey = has.call(target, key);\n } else if (!!(process.env.NODE_ENV !== \"production\")) {\n checkIdentityKeys(target, has, key);\n }\n const oldValue = get ? get.call(target, key) : void 0;\n const result = target.delete(key);\n if (hadKey) {\n trigger(target, \"delete\", key, void 0, oldValue);\n }\n return result;\n },\n clear() {\n const target = toRaw(this);\n const hadItems = target.size !== 0;\n const oldTarget = !!(process.env.NODE_ENV !== \"production\") ? isMap(target) ? new Map(target) : new Set(target) : void 0;\n const result = target.clear();\n if (hadItems) {\n trigger(\n target,\n \"clear\",\n void 0,\n void 0,\n oldTarget\n );\n }\n return result;\n }\n }\n );\n const iteratorMethods = [\n \"keys\",\n \"values\",\n \"entries\",\n Symbol.iterator\n ];\n iteratorMethods.forEach((method) => {\n instrumentations[method] = createIterableMethod(method, readonly, shallow);\n });\n return instrumentations;\n}\nfunction createInstrumentationGetter(isReadonly2, shallow) {\n const instrumentations = createInstrumentations(isReadonly2, shallow);\n return (target, key, receiver) => {\n if (key === \"__v_isReactive\") {\n return !isReadonly2;\n } else if (key === \"__v_isReadonly\") {\n return isReadonly2;\n } else if (key === \"__v_raw\") {\n return target;\n }\n return Reflect.get(\n hasOwn(instrumentations, key) && key in target ? instrumentations : target,\n key,\n receiver\n );\n };\n}\nconst mutableCollectionHandlers = {\n get: /* @__PURE__ */ createInstrumentationGetter(false, false)\n};\nconst shallowCollectionHandlers = {\n get: /* @__PURE__ */ createInstrumentationGetter(false, true)\n};\nconst readonlyCollectionHandlers = {\n get: /* @__PURE__ */ createInstrumentationGetter(true, false)\n};\nconst shallowReadonlyCollectionHandlers = {\n get: /* @__PURE__ */ createInstrumentationGetter(true, true)\n};\nfunction checkIdentityKeys(target, has, key) {\n const rawKey = toRaw(key);\n if (rawKey !== key && has.call(target, rawKey)) {\n const type = toRawType(target);\n warn(\n `Reactive ${type} contains both the raw and reactive versions of the same object${type === `Map` ? ` as keys` : ``}, which can lead to inconsistencies. Avoid differentiating between the raw and reactive versions of an object and only use the reactive version if possible.`\n );\n }\n}\n\nconst reactiveMap = /* @__PURE__ */ new WeakMap();\nconst shallowReactiveMap = /* @__PURE__ */ new WeakMap();\nconst readonlyMap = /* @__PURE__ */ new WeakMap();\nconst shallowReadonlyMap = /* @__PURE__ */ new WeakMap();\nfunction targetTypeMap(rawType) {\n switch (rawType) {\n case \"Object\":\n case \"Array\":\n return 1 /* COMMON */;\n case \"Map\":\n case \"Set\":\n case \"WeakMap\":\n case \"WeakSet\":\n return 2 /* COLLECTION */;\n default:\n return 0 /* INVALID */;\n }\n}\nfunction getTargetType(value) {\n return value[\"__v_skip\"] || !Object.isExtensible(value) ? 0 /* INVALID */ : targetTypeMap(toRawType(value));\n}\nfunction reactive(target) {\n if (isReadonly(target)) {\n return target;\n }\n return createReactiveObject(\n target,\n false,\n mutableHandlers,\n mutableCollectionHandlers,\n reactiveMap\n );\n}\nfunction shallowReactive(target) {\n return createReactiveObject(\n target,\n false,\n shallowReactiveHandlers,\n shallowCollectionHandlers,\n shallowReactiveMap\n );\n}\nfunction readonly(target) {\n return createReactiveObject(\n target,\n true,\n readonlyHandlers,\n readonlyCollectionHandlers,\n readonlyMap\n );\n}\nfunction shallowReadonly(target) {\n return createReactiveObject(\n target,\n true,\n shallowReadonlyHandlers,\n shallowReadonlyCollectionHandlers,\n shallowReadonlyMap\n );\n}\nfunction createReactiveObject(target, isReadonly2, baseHandlers, collectionHandlers, proxyMap) {\n if (!isObject(target)) {\n if (!!(process.env.NODE_ENV !== \"production\")) {\n warn(\n `value cannot be made ${isReadonly2 ? \"readonly\" : \"reactive\"}: ${String(\n target\n )}`\n );\n }\n return target;\n }\n if (target[\"__v_raw\"] && !(isReadonly2 && target[\"__v_isReactive\"])) {\n return target;\n }\n const targetType = getTargetType(target);\n if (targetType === 0 /* INVALID */) {\n return target;\n }\n const existingProxy = proxyMap.get(target);\n if (existingProxy) {\n return existingProxy;\n }\n const proxy = new Proxy(\n target,\n targetType === 2 /* COLLECTION */ ? collectionHandlers : baseHandlers\n );\n proxyMap.set(target, proxy);\n return proxy;\n}\nfunction isReactive(value) {\n if (isReadonly(value)) {\n return isReactive(value[\"__v_raw\"]);\n }\n return !!(value && value[\"__v_isReactive\"]);\n}\nfunction isReadonly(value) {\n return !!(value && value[\"__v_isReadonly\"]);\n}\nfunction isShallow(value) {\n return !!(value && value[\"__v_isShallow\"]);\n}\nfunction isProxy(value) {\n return value ? !!value[\"__v_raw\"] : false;\n}\nfunction toRaw(observed) {\n const raw = observed && observed[\"__v_raw\"];\n return raw ? toRaw(raw) : observed;\n}\nfunction markRaw(value) {\n if (!hasOwn(value, \"__v_skip\") && Object.isExtensible(value)) {\n def(value, \"__v_skip\", true);\n }\n return value;\n}\nconst toReactive = (value) => isObject(value) ? reactive(value) : value;\nconst toReadonly = (value) => isObject(value) ? readonly(value) : value;\n\nfunction isRef(r) {\n return r ? r[\"__v_isRef\"] === true : false;\n}\nfunction ref(value) {\n return createRef(value, false);\n}\nfunction shallowRef(value) {\n return createRef(value, true);\n}\nfunction createRef(rawValue, shallow) {\n if (isRef(rawValue)) {\n return rawValue;\n }\n return new RefImpl(rawValue, shallow);\n}\nclass RefImpl {\n constructor(value, isShallow2) {\n this.dep = new Dep();\n this[\"__v_isRef\"] = true;\n this[\"__v_isShallow\"] = false;\n this._rawValue = isShallow2 ? value : toRaw(value);\n this._value = isShallow2 ? value : toReactive(value);\n this[\"__v_isShallow\"] = isShallow2;\n }\n get value() {\n if (!!(process.env.NODE_ENV !== \"production\")) {\n this.dep.track({\n target: this,\n type: \"get\",\n key: \"value\"\n });\n } else {\n this.dep.track();\n }\n return this._value;\n }\n set value(newValue) {\n const oldValue = this._rawValue;\n const useDirectValue = this[\"__v_isShallow\"] || isShallow(newValue) || isReadonly(newValue);\n newValue = useDirectValue ? newValue : toRaw(newValue);\n if (hasChanged(newValue, oldValue)) {\n this._rawValue = newValue;\n this._value = useDirectValue ? newValue : toReactive(newValue);\n if (!!(process.env.NODE_ENV !== \"production\")) {\n this.dep.trigger({\n target: this,\n type: \"set\",\n key: \"value\",\n newValue,\n oldValue\n });\n } else {\n this.dep.trigger();\n }\n }\n }\n}\nfunction triggerRef(ref2) {\n if (ref2.dep) {\n if (!!(process.env.NODE_ENV !== \"production\")) {\n ref2.dep.trigger({\n target: ref2,\n type: \"set\",\n key: \"value\",\n newValue: ref2._value\n });\n } else {\n ref2.dep.trigger();\n }\n }\n}\nfunction unref(ref2) {\n return isRef(ref2) ? ref2.value : ref2;\n}\nfunction toValue(source) {\n return isFunction(source) ? source() : unref(source);\n}\nconst shallowUnwrapHandlers = {\n get: (target, key, receiver) => key === \"__v_raw\" ? target : unref(Reflect.get(target, key, receiver)),\n set: (target, key, value, receiver) => {\n const oldValue = target[key];\n if (isRef(oldValue) && !isRef(value)) {\n oldValue.value = value;\n return true;\n } else {\n return Reflect.set(target, key, value, receiver);\n }\n }\n};\nfunction proxyRefs(objectWithRefs) {\n return isReactive(objectWithRefs) ? objectWithRefs : new Proxy(objectWithRefs, shallowUnwrapHandlers);\n}\nclass CustomRefImpl {\n constructor(factory) {\n this[\"__v_isRef\"] = true;\n this._value = void 0;\n const dep = this.dep = new Dep();\n const { get, set } = factory(dep.track.bind(dep), dep.trigger.bind(dep));\n this._get = get;\n this._set = set;\n }\n get value() {\n return this._value = this._get();\n }\n set value(newVal) {\n this._set(newVal);\n }\n}\nfunction customRef(factory) {\n return new CustomRefImpl(factory);\n}\nfunction toRefs(object) {\n if (!!(process.env.NODE_ENV !== \"production\") && !isProxy(object)) {\n warn(`toRefs() expects a reactive object but received a plain one.`);\n }\n const ret = isArray(object) ? new Array(object.length) : {};\n for (const key in object) {\n ret[key] = propertyToRef(object, key);\n }\n return ret;\n}\nclass ObjectRefImpl {\n constructor(_object, _key, _defaultValue) {\n this._object = _object;\n this._key = _key;\n this._defaultValue = _defaultValue;\n this[\"__v_isRef\"] = true;\n this._value = void 0;\n this._raw = toRaw(_object);\n let shallow = true;\n let obj = _object;\n if (!isArray(_object) || !isIntegerKey(String(_key))) {\n do {\n shallow = !isProxy(obj) || isShallow(obj);\n } while (shallow && (obj = obj[\"__v_raw\"]));\n }\n this._shallow = shallow;\n }\n get value() {\n let val = this._object[this._key];\n if (this._shallow) {\n val = unref(val);\n }\n return this._value = val === void 0 ? this._defaultValue : val;\n }\n set value(newVal) {\n if (this._shallow && isRef(this._raw[this._key])) {\n const nestedRef = this._object[this._key];\n if (isRef(nestedRef)) {\n nestedRef.value = newVal;\n return;\n }\n }\n this._object[this._key] = newVal;\n }\n get dep() {\n return getDepFromReactive(this._raw, this._key);\n }\n}\nclass GetterRefImpl {\n constructor(_getter) {\n this._getter = _getter;\n this[\"__v_isRef\"] = true;\n this[\"__v_isReadonly\"] = true;\n this._value = void 0;\n }\n get value() {\n return this._value = this._getter();\n }\n}\nfunction toRef(source, key, defaultValue) {\n if (isRef(source)) {\n return source;\n } else if (isFunction(source)) {\n return new GetterRefImpl(source);\n } else if (isObject(source) && arguments.length > 1) {\n return propertyToRef(source, key, defaultValue);\n } else {\n return ref(source);\n }\n}\nfunction propertyToRef(source, key, defaultValue) {\n return new ObjectRefImpl(source, key, defaultValue);\n}\n\nclass ComputedRefImpl {\n constructor(fn, setter, isSSR) {\n this.fn = fn;\n this.setter = setter;\n /**\n * @internal\n */\n this._value = void 0;\n /**\n * @internal\n */\n this.dep = new Dep(this);\n /**\n * @internal\n */\n this.__v_isRef = true;\n // TODO isolatedDeclarations \"__v_isReadonly\"\n // A computed is also a subscriber that tracks other deps\n /**\n * @internal\n */\n this.deps = void 0;\n /**\n * @internal\n */\n this.depsTail = void 0;\n /**\n * @internal\n */\n this.flags = 16;\n /**\n * @internal\n */\n this.globalVersion = globalVersion - 1;\n /**\n * @internal\n */\n this.next = void 0;\n // for backwards compat\n this.effect = this;\n this[\"__v_isReadonly\"] = !setter;\n this.isSSR = isSSR;\n }\n /**\n * @internal\n */\n notify() {\n this.flags |= 16;\n if (!(this.flags & 8) && // avoid infinite self recursion\n activeSub !== this) {\n batch(this, true);\n return true;\n } else if (!!(process.env.NODE_ENV !== \"production\")) ;\n }\n get value() {\n const link = !!(process.env.NODE_ENV !== \"production\") ? this.dep.track({\n target: this,\n type: \"get\",\n key: \"value\"\n }) : this.dep.track();\n refreshComputed(this);\n if (link) {\n link.version = this.dep.version;\n }\n return this._value;\n }\n set value(newValue) {\n if (this.setter) {\n this.setter(newValue);\n } else if (!!(process.env.NODE_ENV !== \"production\")) {\n warn(\"Write operation failed: computed value is readonly\");\n }\n }\n}\nfunction computed(getterOrOptions, debugOptions, isSSR = false) {\n let getter;\n let setter;\n if (isFunction(getterOrOptions)) {\n getter = getterOrOptions;\n } else {\n getter = getterOrOptions.get;\n setter = getterOrOptions.set;\n }\n const cRef = new ComputedRefImpl(getter, setter, isSSR);\n if (!!(process.env.NODE_ENV !== \"production\") && debugOptions && !isSSR) {\n cRef.onTrack = debugOptions.onTrack;\n cRef.onTrigger = debugOptions.onTrigger;\n }\n return cRef;\n}\n\nconst TrackOpTypes = {\n \"GET\": \"get\",\n \"HAS\": \"has\",\n \"ITERATE\": \"iterate\"\n};\nconst TriggerOpTypes = {\n \"SET\": \"set\",\n \"ADD\": \"add\",\n \"DELETE\": \"delete\",\n \"CLEAR\": \"clear\"\n};\nconst ReactiveFlags = {\n \"SKIP\": \"__v_skip\",\n \"IS_REACTIVE\": \"__v_isReactive\",\n \"IS_READONLY\": \"__v_isReadonly\",\n \"IS_SHALLOW\": \"__v_isShallow\",\n \"RAW\": \"__v_raw\",\n \"IS_REF\": \"__v_isRef\"\n};\n\nconst WatchErrorCodes = {\n \"WATCH_GETTER\": 2,\n \"2\": \"WATCH_GETTER\",\n \"WATCH_CALLBACK\": 3,\n \"3\": \"WATCH_CALLBACK\",\n \"WATCH_CLEANUP\": 4,\n \"4\": \"WATCH_CLEANUP\"\n};\nconst INITIAL_WATCHER_VALUE = {};\nconst cleanupMap = /* @__PURE__ */ new WeakMap();\nlet activeWatcher = void 0;\nfunction getCurrentWatcher() {\n return activeWatcher;\n}\nfunction onWatcherCleanup(cleanupFn, failSilently = false, owner = activeWatcher) {\n if (owner) {\n let cleanups = cleanupMap.get(owner);\n if (!cleanups) cleanupMap.set(owner, cleanups = []);\n cleanups.push(cleanupFn);\n } else if (!!(process.env.NODE_ENV !== \"production\") && !failSilently) {\n warn(\n `onWatcherCleanup() was called when there was no active watcher to associate with.`\n );\n }\n}\nfunction watch(source, cb, options = EMPTY_OBJ) {\n const { immediate, deep, once, scheduler, augmentJob, call } = options;\n const warnInvalidSource = (s) => {\n (options.onWarn || warn)(\n `Invalid watch source: `,\n s,\n `A watch source can only be a getter/effect function, a ref, a reactive object, or an array of these types.`\n );\n };\n const reactiveGetter = (source2) => {\n if (deep) return source2;\n if (isShallow(source2) || deep === false || deep === 0)\n return traverse(source2, 1);\n return traverse(source2);\n };\n let effect;\n let getter;\n let cleanup;\n let boundCleanup;\n let forceTrigger = false;\n let isMultiSource = false;\n if (isRef(source)) {\n getter = () => source.value;\n forceTrigger = isShallow(source);\n } else if (isReactive(source)) {\n getter = () => reactiveGetter(source);\n forceTrigger = true;\n } else if (isArray(source)) {\n isMultiSource = true;\n forceTrigger = source.some((s) => isReactive(s) || isShallow(s));\n getter = () => source.map((s) => {\n if (isRef(s)) {\n return s.value;\n } else if (isReactive(s)) {\n return reactiveGetter(s);\n } else if (isFunction(s)) {\n return call ? call(s, 2) : s();\n } else {\n !!(process.env.NODE_ENV !== \"production\") && warnInvalidSource(s);\n }\n });\n } else if (isFunction(source)) {\n if (cb) {\n getter = call ? () => call(source, 2) : source;\n } else {\n getter = () => {\n if (cleanup) {\n pauseTracking();\n try {\n cleanup();\n } finally {\n resetTracking();\n }\n }\n const currentEffect = activeWatcher;\n activeWatcher = effect;\n try {\n return call ? call(source, 3, [boundCleanup]) : source(boundCleanup);\n } finally {\n activeWatcher = currentEffect;\n }\n };\n }\n } else {\n getter = NOOP;\n !!(process.env.NODE_ENV !== \"production\") && warnInvalidSource(source);\n }\n if (cb && deep) {\n const baseGetter = getter;\n const depth = deep === true ? Infinity : deep;\n getter = () => traverse(baseGetter(), depth);\n }\n const scope = getCurrentScope();\n const watchHandle = () => {\n effect.stop();\n if (scope && scope.active) {\n remove(scope.effects, effect);\n }\n };\n if (once && cb) {\n const _cb = cb;\n cb = (...args) => {\n _cb(...args);\n watchHandle();\n };\n }\n let oldValue = isMultiSource ? new Array(source.length).fill(INITIAL_WATCHER_VALUE) : INITIAL_WATCHER_VALUE;\n const job = (immediateFirstRun) => {\n if (!(effect.flags & 1) || !effect.dirty && !immediateFirstRun) {\n return;\n }\n if (cb) {\n const newValue = effect.run();\n if (deep || forceTrigger || (isMultiSource ? newValue.some((v, i) => hasChanged(v, oldValue[i])) : hasChanged(newValue, oldValue))) {\n if (cleanup) {\n cleanup();\n }\n const currentWatcher = activeWatcher;\n activeWatcher = effect;\n try {\n const args = [\n newValue,\n // pass undefined as the old value when it's changed for the first time\n oldValue === INITIAL_WATCHER_VALUE ? void 0 : isMultiSource && oldValue[0] === INITIAL_WATCHER_VALUE ? [] : oldValue,\n boundCleanup\n ];\n oldValue = newValue;\n call ? call(cb, 3, args) : (\n // @ts-expect-error\n cb(...args)\n );\n } finally {\n activeWatcher = currentWatcher;\n }\n }\n } else {\n effect.run();\n }\n };\n if (augmentJob) {\n augmentJob(job);\n }\n effect = new ReactiveEffect(getter);\n effect.scheduler = scheduler ? () => scheduler(job, false) : job;\n boundCleanup = (fn) => onWatcherCleanup(fn, false, effect);\n cleanup = effect.onStop = () => {\n const cleanups = cleanupMap.get(effect);\n if (cleanups) {\n if (call) {\n call(cleanups, 4);\n } else {\n for (const cleanup2 of cleanups) cleanup2();\n }\n cleanupMap.delete(effect);\n }\n };\n if (!!(process.env.NODE_ENV !== \"production\")) {\n effect.onTrack = options.onTrack;\n effect.onTrigger = options.onTrigger;\n }\n if (cb) {\n if (immediate) {\n job(true);\n } else {\n oldValue = effect.run();\n }\n } else if (scheduler) {\n scheduler(job.bind(null, true), true);\n } else {\n effect.run();\n }\n watchHandle.pause = effect.pause.bind(effect);\n watchHandle.resume = effect.resume.bind(effect);\n watchHandle.stop = watchHandle;\n return watchHandle;\n}\nfunction traverse(value, depth = Infinity, seen) {\n if (depth <= 0 || !isObject(value) || value[\"__v_skip\"]) {\n return value;\n }\n seen = seen || /* @__PURE__ */ new Map();\n if ((seen.get(value) || 0) >= depth) {\n return value;\n }\n seen.set(value, depth);\n depth--;\n if (isRef(value)) {\n traverse(value.value, depth, seen);\n } else if (isArray(value)) {\n for (let i = 0; i < value.length; i++) {\n traverse(value[i], depth, seen);\n }\n } else if (isSet(value) || isMap(value)) {\n value.forEach((v) => {\n traverse(v, depth, seen);\n });\n } else if (isPlainObject(value)) {\n for (const key in value) {\n traverse(value[key], depth, seen);\n }\n for (const key of Object.getOwnPropertySymbols(value)) {\n if (Object.prototype.propertyIsEnumerable.call(value, key)) {\n traverse(value[key], depth, seen);\n }\n }\n }\n return value;\n}\n\nexport { ARRAY_ITERATE_KEY, EffectFlags, EffectScope, ITERATE_KEY, MAP_KEY_ITERATE_KEY, ReactiveEffect, ReactiveFlags, TrackOpTypes, TriggerOpTypes, WatchErrorCodes, computed, customRef, effect, effectScope, enableTracking, getCurrentScope, getCurrentWatcher, isProxy, isReactive, isReadonly, isRef, isShallow, markRaw, onEffectCleanup, onScopeDispose, onWatcherCleanup, pauseTracking, proxyRefs, reactive, reactiveReadArray, readonly, ref, resetTracking, shallowReactive, shallowReadArray, shallowReadonly, shallowRef, stop, toRaw, toReactive, toReadonly, toRef, toRefs, toValue, track, traverse, trigger, triggerRef, unref, watch };\n","/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n var type = typeof value;\n return value != null && (type == 'object' || type == 'function');\n}\n\nexport default isObject;\n","import assignValue from './_assignValue.js';\nimport castPath from './_castPath.js';\nimport isIndex from './_isIndex.js';\nimport isObject from './isObject.js';\nimport toKey from './_toKey.js';\n\n/**\n * The base implementation of `_.set`.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to set.\n * @param {*} value The value to set.\n * @param {Function} [customizer] The function to customize path creation.\n * @returns {Object} Returns `object`.\n */\nfunction baseSet(object, path, value, customizer) {\n if (!isObject(object)) {\n return object;\n }\n path = castPath(path, object);\n\n var index = -1,\n length = path.length,\n lastIndex = length - 1,\n nested = object;\n\n while (nested != null && ++index < length) {\n var key = toKey(path[index]),\n newValue = value;\n\n if (key === '__proto__' || key === 'constructor' || key === 'prototype') {\n return object;\n }\n\n if (index != lastIndex) {\n var objValue = nested[key];\n newValue = customizer ? customizer(objValue, key, nested) : undefined;\n if (newValue === undefined) {\n newValue = isObject(objValue)\n ? objValue\n : (isIndex(path[index + 1]) ? [] : {});\n }\n }\n assignValue(nested, key, newValue);\n nested = nested[key];\n }\n return object;\n}\n\nexport default baseSet;\n","import { unref, watch } from 'vue'\nimport { debugWarn } from '@element-plus/utils'\n\nimport type { MaybeRef } from '@vueuse/core'\n\ntype DeprecationParam = {\n from: string\n replacement: string\n scope: string\n version: string\n ref: string\n type?: 'API' | 'Attribute' | 'Event' | 'Slot'\n}\n\nexport const useDeprecated = (\n { from, replacement, scope, version, ref, type = 'API' }: DeprecationParam,\n condition: MaybeRef\n) => {\n watch(\n () => unref(condition),\n (val) => {\n if (val) {\n debugWarn(\n scope,\n `[${type}] ${from} is about to be deprecated in version ${version}, please use ${replacement} instead.\nFor more detail, please visit: ${ref}\n`\n )\n }\n },\n {\n immediate: true,\n }\n )\n}\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar fails = require('../internals/fails');\nvar isCallable = require('../internals/is-callable');\nvar hasOwn = require('../internals/has-own-property');\nvar DESCRIPTORS = require('../internals/descriptors');\nvar CONFIGURABLE_FUNCTION_NAME = require('../internals/function-name').CONFIGURABLE;\nvar inspectSource = require('../internals/inspect-source');\nvar InternalStateModule = require('../internals/internal-state');\n\nvar enforceInternalState = InternalStateModule.enforce;\nvar getInternalState = InternalStateModule.get;\nvar $String = String;\n// eslint-disable-next-line es/no-object-defineproperty -- safe\nvar defineProperty = Object.defineProperty;\nvar stringSlice = uncurryThis(''.slice);\nvar replace = uncurryThis(''.replace);\nvar join = uncurryThis([].join);\n\nvar CONFIGURABLE_LENGTH = DESCRIPTORS && !fails(function () {\n return defineProperty(function () { /* empty */ }, 'length', { value: 8 }).length !== 8;\n});\n\nvar TEMPLATE = String(String).split('String');\n\nvar makeBuiltIn = module.exports = function (value, name, options) {\n if (stringSlice($String(name), 0, 7) === 'Symbol(') {\n name = '[' + replace($String(name), /^Symbol\\(([^)]*)\\).*$/, '$1') + ']';\n }\n if (options && options.getter) name = 'get ' + name;\n if (options && options.setter) name = 'set ' + name;\n if (!hasOwn(value, 'name') || (CONFIGURABLE_FUNCTION_NAME && value.name !== name)) {\n if (DESCRIPTORS) defineProperty(value, 'name', { value: name, configurable: true });\n else value.name = name;\n }\n if (CONFIGURABLE_LENGTH && options && hasOwn(options, 'arity') && value.length !== options.arity) {\n defineProperty(value, 'length', { value: options.arity });\n }\n try {\n if (options && hasOwn(options, 'constructor') && options.constructor) {\n if (DESCRIPTORS) defineProperty(value, 'prototype', { writable: false });\n // in V8 ~ Chrome 53, prototypes of some methods, like `Array.prototype.values`, are non-writable\n } else if (value.prototype) value.prototype = undefined;\n } catch (error) { /* empty */ }\n var state = enforceInternalState(value);\n if (!hasOwn(state, 'source')) {\n state.source = join(TEMPLATE, typeof name == 'string' ? name : '');\n } return value;\n};\n\n// add fake Function#toString for correct work wrapped methods / constructors with methods like LoDash isNative\n// eslint-disable-next-line no-extend-native -- required\nFunction.prototype.toString = makeBuiltIn(function toString() {\n return isCallable(this) && getInternalState(this).source || inspectSource(this);\n}, 'toString');\n","import { h, defineComponent, computed, watch } from 'vue';\nimport { parse, icon, config, text } from '@fortawesome/fontawesome-svg-core';\n\nfunction _arrayLikeToArray(r, a) {\n (null == a || a > r.length) && (a = r.length);\n for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e];\n return n;\n}\nfunction _arrayWithoutHoles(r) {\n if (Array.isArray(r)) return _arrayLikeToArray(r);\n}\nfunction _defineProperty(e, r, t) {\n return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, {\n value: t,\n enumerable: !0,\n configurable: !0,\n writable: !0\n }) : e[r] = t, e;\n}\nfunction _iterableToArray(r) {\n if (\"undefined\" != typeof Symbol && null != r[Symbol.iterator] || null != r[\"@@iterator\"]) return Array.from(r);\n}\nfunction _nonIterableSpread() {\n throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\nfunction ownKeys(e, r) {\n var t = Object.keys(e);\n if (Object.getOwnPropertySymbols) {\n var o = Object.getOwnPropertySymbols(e);\n r && (o = o.filter(function (r) {\n return Object.getOwnPropertyDescriptor(e, r).enumerable;\n })), t.push.apply(t, o);\n }\n return t;\n}\nfunction _objectSpread2(e) {\n for (var r = 1; r < arguments.length; r++) {\n var t = null != arguments[r] ? arguments[r] : {};\n r % 2 ? ownKeys(Object(t), !0).forEach(function (r) {\n _defineProperty(e, r, t[r]);\n }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) {\n Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r));\n });\n }\n return e;\n}\nfunction _objectWithoutProperties(e, t) {\n if (null == e) return {};\n var o,\n r,\n i = _objectWithoutPropertiesLoose(e, t);\n if (Object.getOwnPropertySymbols) {\n var n = Object.getOwnPropertySymbols(e);\n for (r = 0; r < n.length; r++) o = n[r], -1 === t.indexOf(o) && {}.propertyIsEnumerable.call(e, o) && (i[o] = e[o]);\n }\n return i;\n}\nfunction _objectWithoutPropertiesLoose(r, e) {\n if (null == r) return {};\n var t = {};\n for (var n in r) if ({}.hasOwnProperty.call(r, n)) {\n if (-1 !== e.indexOf(n)) continue;\n t[n] = r[n];\n }\n return t;\n}\nfunction _toConsumableArray(r) {\n return _arrayWithoutHoles(r) || _iterableToArray(r) || _unsupportedIterableToArray(r) || _nonIterableSpread();\n}\nfunction _toPrimitive(t, r) {\n if (\"object\" != typeof t || !t) return t;\n var e = t[Symbol.toPrimitive];\n if (void 0 !== e) {\n var i = e.call(t, r || \"default\");\n if (\"object\" != typeof i) return i;\n throw new TypeError(\"@@toPrimitive must return a primitive value.\");\n }\n return (\"string\" === r ? String : Number)(t);\n}\nfunction _toPropertyKey(t) {\n var i = _toPrimitive(t, \"string\");\n return \"symbol\" == typeof i ? i : i + \"\";\n}\nfunction _typeof(o) {\n \"@babel/helpers - typeof\";\n\n return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (o) {\n return typeof o;\n } : function (o) {\n return o && \"function\" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? \"symbol\" : typeof o;\n }, _typeof(o);\n}\nfunction _unsupportedIterableToArray(r, a) {\n if (r) {\n if (\"string\" == typeof r) return _arrayLikeToArray(r, a);\n var t = {}.toString.call(r).slice(8, -1);\n return \"Object\" === t && r.constructor && (t = r.constructor.name), \"Map\" === t || \"Set\" === t ? Array.from(r) : \"Arguments\" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0;\n }\n}\n\nfunction objectWithKey(key, value) {\n return Array.isArray(value) && value.length > 0 || !Array.isArray(value) && value ? _defineProperty({}, key, value) : {};\n}\nfunction classList(props) {\n var _classes;\n var classes = (_classes = {\n 'fa-spin': props.spin,\n 'fa-pulse': props.pulse,\n // the fixedWidth property has been deprecated as of version 7.0.0\n 'fa-fw': props.fixedWidth,\n 'fa-border': props.border,\n 'fa-li': props.listItem,\n 'fa-inverse': props.inverse,\n 'fa-flip': props.flip === true,\n 'fa-flip-horizontal': props.flip === 'horizontal' || props.flip === 'both',\n 'fa-flip-vertical': props.flip === 'vertical' || props.flip === 'both'\n }, _defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty(_classes, \"fa-\".concat(props.size), props.size !== null), \"fa-rotate-\".concat(props.rotation), props.rotation !== null), 'fa-rotate-by', props.rotateBy), \"fa-pull-\".concat(props.pull), props.pull !== null), 'fa-swap-opacity', props.swapOpacity), 'fa-bounce', props.bounce), 'fa-shake', props.shake), 'fa-beat', props.beat), 'fa-fade', props.fade), 'fa-beat-fade', props.beatFade), _defineProperty(_defineProperty(_defineProperty(_defineProperty(_classes, 'fa-flash', props.flash), 'fa-spin-pulse', props.spinPulse), 'fa-spin-reverse', props.spinReverse), 'fa-width-auto', props.widthAuto));\n return Object.keys(classes).map(function (key) {\n return classes[key] ? key : null;\n }).filter(function (key) {\n return key;\n });\n}\n\nvar commonjsGlobal = typeof globalThis !== 'undefined' ? globalThis : typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self : {};\n\nvar humps$1 = {exports: {}};\n\n(function (module) {\n(function(global) {\n\n\t var _processKeys = function(convert, obj, options) {\n\t if(!_isObject(obj) || _isDate(obj) || _isRegExp(obj) || _isBoolean(obj) || _isFunction(obj)) {\n\t return obj;\n\t }\n\n\t var output,\n\t i = 0,\n\t l = 0;\n\n\t if(_isArray(obj)) {\n\t output = [];\n\t for(l=obj.length; i} classes The class list to convert.\n * @returns {Object}\n */\nfunction classToObject(classes) {\n return classes.split(/\\s+/).reduce(function (output, className) {\n output[className] = true;\n return output;\n }, {});\n}\n\n/**\n * Converts a FontAwesome abstract element of an icon into a Vue VNode.\n * @param {AbstractElement | String} abstractElement The element to convert.\n * @param {Object} props The user-defined props.\n * @param {Object} attrs The user-defined native HTML attributes.\n * @returns {VNode}\n */\nfunction convert(abstractElement) {\n var props = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n var attrs = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n // If the abstract element is a string, we'll just return a string render function\n if (typeof abstractElement === 'string') {\n return abstractElement;\n }\n\n // Converting abstract element children into Vue VNodes\n var children = (abstractElement.children || []).map(function (child) {\n return convert(child);\n });\n\n // Converting abstract element attributes into valid Vue format\n var mixins = Object.keys(abstractElement.attributes || {}).reduce(function (mixins, key) {\n var value = abstractElement.attributes[key];\n switch (key) {\n case 'class':\n mixins.class = classToObject(value);\n break;\n case 'style':\n mixins.style = styleToObject(value);\n break;\n default:\n mixins.attrs[key] = value;\n }\n return mixins;\n }, {\n attrs: {},\n class: {},\n style: {}\n });\n\n // Now, we'll return the VNode\n attrs.class;\n var _attrs$style = attrs.style,\n aStyle = _attrs$style === void 0 ? {} : _attrs$style,\n otherAttrs = _objectWithoutProperties(attrs, _excluded);\n return h(abstractElement.tag, _objectSpread2(_objectSpread2(_objectSpread2({}, props), {}, {\n class: mixins.class,\n style: _objectSpread2(_objectSpread2({}, mixins.style), aStyle)\n }, mixins.attrs), otherAttrs), children);\n}\n\nvar PRODUCTION = false;\ntry {\n PRODUCTION = process.env.NODE_ENV === 'production';\n} catch (e) {}\nfunction log () {\n if (!PRODUCTION && console && typeof console.error === 'function') {\n var _console;\n (_console = console).error.apply(_console, arguments);\n }\n}\n\nfunction normalizeIconArgs(icon) {\n if (icon && _typeof(icon) === 'object' && icon.prefix && icon.iconName && icon.icon) {\n return icon;\n }\n if (parse.icon) {\n return parse.icon(icon);\n }\n if (icon === null) {\n return null;\n }\n if (_typeof(icon) === 'object' && icon.prefix && icon.iconName) {\n return icon;\n }\n if (Array.isArray(icon) && icon.length === 2) {\n return {\n prefix: icon[0],\n iconName: icon[1]\n };\n }\n if (typeof icon === 'string') {\n return {\n prefix: 'fas',\n iconName: icon\n };\n }\n}\nvar FontAwesomeIcon = defineComponent({\n name: 'FontAwesomeIcon',\n props: {\n border: {\n type: Boolean,\n default: false\n },\n // the fixedWidth property has been deprecated as of version 7\n fixedWidth: {\n type: Boolean,\n default: false\n },\n flip: {\n type: [Boolean, String],\n default: false,\n validator: function validator(value) {\n return [true, false, 'horizontal', 'vertical', 'both'].indexOf(value) > -1;\n }\n },\n icon: {\n type: [Object, Array, String],\n required: true\n },\n mask: {\n type: [Object, Array, String],\n default: null\n },\n maskId: {\n type: String,\n default: null\n },\n listItem: {\n type: Boolean,\n default: false\n },\n pull: {\n type: String,\n default: null,\n validator: function validator(value) {\n return ['right', 'left'].indexOf(value) > -1;\n }\n },\n pulse: {\n type: Boolean,\n default: false\n },\n rotation: {\n type: [String, Number],\n default: null,\n validator: function validator(value) {\n return [90, 180, 270].indexOf(Number.parseInt(value, 10)) > -1;\n }\n },\n // the rotateBy property is only supported in version 7.0.0 and later\n rotateBy: {\n type: Boolean,\n default: false\n },\n swapOpacity: {\n type: Boolean,\n default: false\n },\n size: {\n type: String,\n default: null,\n validator: function validator(value) {\n return ['2xs', 'xs', 'sm', 'lg', 'xl', '2xl', '1x', '2x', '3x', '4x', '5x', '6x', '7x', '8x', '9x', '10x'].indexOf(value) > -1;\n }\n },\n spin: {\n type: Boolean,\n default: false\n },\n transform: {\n type: [String, Object],\n default: null\n },\n symbol: {\n type: [Boolean, String],\n default: false\n },\n title: {\n type: String,\n default: null\n },\n titleId: {\n type: String,\n default: null\n },\n inverse: {\n type: Boolean,\n default: false\n },\n bounce: {\n type: Boolean,\n default: false\n },\n shake: {\n type: Boolean,\n default: false\n },\n beat: {\n type: Boolean,\n default: false\n },\n fade: {\n type: Boolean,\n default: false\n },\n beatFade: {\n type: Boolean,\n default: false\n },\n flash: {\n type: Boolean,\n default: false\n },\n spinPulse: {\n type: Boolean,\n default: false\n },\n spinReverse: {\n type: Boolean,\n default: false\n },\n // the widthAuto property is only supported in version 7.0.0 and later\n widthAuto: {\n type: Boolean,\n default: false\n }\n },\n setup: function setup(props, _ref) {\n var attrs = _ref.attrs;\n var icon$1 = computed(function () {\n return normalizeIconArgs(props.icon);\n });\n var classes = computed(function () {\n return objectWithKey('classes', classList(props));\n });\n var transform = computed(function () {\n return objectWithKey('transform', typeof props.transform === 'string' ? parse.transform(props.transform) : props.transform);\n });\n var mask = computed(function () {\n return objectWithKey('mask', normalizeIconArgs(props.mask));\n });\n var renderedIcon = computed(function () {\n var iconProps = _objectSpread2(_objectSpread2(_objectSpread2(_objectSpread2({}, classes.value), transform.value), mask.value), {}, {\n symbol: props.symbol,\n maskId: props.maskId\n });\n\n // the title attribute will only apply to versions prior to version 7.0.0\n iconProps.title = props.title;\n iconProps.titleId = props.titleId;\n return icon(icon$1.value, iconProps);\n });\n watch(renderedIcon, function (value) {\n if (!value) {\n return log('Could not find one or more icon(s)', icon$1.value, mask.value);\n }\n }, {\n immediate: true\n });\n var vnode = computed(function () {\n return renderedIcon.value ? convert(renderedIcon.value.abstract[0], {}, attrs) : null;\n });\n return function () {\n return vnode.value;\n };\n }\n});\n\nvar FontAwesomeLayers = defineComponent({\n name: 'FontAwesomeLayers',\n props: {\n fixedWidth: {\n type: Boolean,\n default: false\n }\n },\n setup: function setup(props, _ref) {\n var slots = _ref.slots;\n var familyPrefix = config.familyPrefix;\n var className = computed(function () {\n return [\"\".concat(familyPrefix, \"-layers\")].concat(_toConsumableArray(props.fixedWidth ? [\"\".concat(familyPrefix, \"-fw\")] : []));\n });\n return function () {\n return h('div', {\n class: className.value\n }, slots.default ? slots.default() : []);\n };\n }\n});\n\nvar FontAwesomeLayersText = defineComponent({\n name: 'FontAwesomeLayersText',\n props: {\n value: {\n type: [String, Number],\n default: ''\n },\n transform: {\n type: [String, Object],\n default: null\n },\n counter: {\n type: Boolean,\n default: false\n },\n position: {\n type: String,\n default: null,\n validator: function validator(value) {\n return ['bottom-left', 'bottom-right', 'top-left', 'top-right'].indexOf(value) > -1;\n }\n }\n },\n setup: function setup(props, _ref) {\n var attrs = _ref.attrs;\n var familyPrefix = config.familyPrefix;\n var classes = computed(function () {\n return objectWithKey('classes', [].concat(_toConsumableArray(props.counter ? [\"\".concat(familyPrefix, \"-layers-counter\")] : []), _toConsumableArray(props.position ? [\"\".concat(familyPrefix, \"-layers-\").concat(props.position)] : [])));\n });\n var transform = computed(function () {\n return objectWithKey('transform', typeof props.transform === 'string' ? parse.transform(props.transform) : props.transform);\n });\n var abstractElement = computed(function () {\n var _text = text(props.value.toString(), _objectSpread2(_objectSpread2({}, transform.value), classes.value)),\n abstract = _text.abstract;\n if (props.counter) {\n abstract[0].attributes.class = abstract[0].attributes.class.replace('fa-layers-text', '');\n }\n return abstract[0];\n });\n var vnode = computed(function () {\n return convert(abstractElement.value, {}, attrs);\n });\n return function () {\n return vnode.value;\n };\n }\n});\n\nexport { FontAwesomeIcon, FontAwesomeLayers, FontAwesomeLayersText };\n","/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\nexport default freeGlobal;\n","'use strict';\nvar DESCRIPTORS = require('../internals/descriptors');\nvar hasOwn = require('../internals/has-own-property');\n\nvar FunctionPrototype = Function.prototype;\n// eslint-disable-next-line es/no-object-getownpropertydescriptor -- safe\nvar getDescriptor = DESCRIPTORS && Object.getOwnPropertyDescriptor;\n\nvar EXISTS = hasOwn(FunctionPrototype, 'name');\n// additional protection from minified / mangled / dropped function names\nvar PROPER = EXISTS && (function something() { /* empty */ }).name === 'something';\nvar CONFIGURABLE = EXISTS && (!DESCRIPTORS || (DESCRIPTORS && getDescriptor(FunctionPrototype, 'name').configurable));\n\nmodule.exports = {\n EXISTS: EXISTS,\n PROPER: PROPER,\n CONFIGURABLE: CONFIGURABLE\n};\n","'use strict';\nvar getBuiltIn = require('../internals/get-built-in');\n\nmodule.exports = getBuiltIn('document', 'documentElement');\n","'use strict';\nmodule.exports = {};\n","'use strict';\nvar $ = require('../internals/export');\nvar globalThis = require('../internals/global-this');\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar anUint8Array = require('../internals/an-uint8-array');\nvar notDetached = require('../internals/array-buffer-not-detached');\n\nvar numberToString = uncurryThis(1.1.toString);\n\nvar Uint8Array = globalThis.Uint8Array;\n\nvar INCORRECT_BEHAVIOR_OR_DOESNT_EXISTS = !Uint8Array || !Uint8Array.prototype.toHex || !(function () {\n try {\n var target = new Uint8Array([255, 255, 255, 255, 255, 255, 255, 255]);\n return target.toHex() === 'ffffffffffffffff';\n } catch (error) {\n return false;\n }\n})();\n\n// `Uint8Array.prototype.toHex` method\n// https://github.com/tc39/proposal-arraybuffer-base64\nif (Uint8Array) $({ target: 'Uint8Array', proto: true, forced: INCORRECT_BEHAVIOR_OR_DOESNT_EXISTS }, {\n toHex: function toHex() {\n anUint8Array(this);\n notDetached(this.buffer);\n var result = '';\n for (var i = 0, length = this.length; i < length; i++) {\n var hex = numberToString(this[i], 16);\n result += hex.length === 1 ? '0' + hex : hex;\n }\n return result;\n }\n});\n","import {\n CircleCheck,\n CircleClose,\n CircleCloseFilled,\n Close,\n InfoFilled,\n Loading,\n SuccessFilled,\n WarningFilled,\n} from '@element-plus/icons-vue'\nimport { definePropType } from './props'\n\nimport type { Component } from 'vue'\n\nexport const iconPropType = definePropType([\n String,\n Object,\n Function,\n])\n\nexport const CloseComponents = {\n Close,\n}\n\nexport const TypeComponents = {\n Close,\n SuccessFilled,\n InfoFilled,\n WarningFilled,\n CircleCloseFilled,\n}\n\nexport const TypeComponentsMap = {\n primary: InfoFilled,\n success: SuccessFilled,\n warning: WarningFilled,\n error: CircleCloseFilled,\n info: InfoFilled,\n}\n\nexport const ValidateComponentsMap = {\n validating: Loading,\n success: CircleCheck,\n error: CircleClose,\n}\n","'use strict';\nvar call = require('../internals/function-call');\n\nmodule.exports = function (record, fn, ITERATOR_INSTEAD_OF_RECORD) {\n var iterator = ITERATOR_INSTEAD_OF_RECORD ? record : record.iterator;\n var next = record.next;\n var step, result;\n while (!(step = call(next, iterator)).done) {\n result = fn(step.value);\n if (result !== undefined) return result;\n }\n};\n","export const EVENT_CODE = {\n tab: 'Tab',\n enter: 'Enter',\n space: 'Space',\n left: 'ArrowLeft', // 37\n up: 'ArrowUp', // 38\n right: 'ArrowRight', // 39\n down: 'ArrowDown', // 40\n esc: 'Escape',\n delete: 'Delete',\n backspace: 'Backspace',\n numpadEnter: 'NumpadEnter',\n pageUp: 'PageUp',\n pageDown: 'PageDown',\n home: 'Home',\n end: 'End',\n}\n","'use strict';\nvar $ = require('../internals/export');\nvar call = require('../internals/function-call');\nvar aCallable = require('../internals/a-callable');\nvar anObject = require('../internals/an-object');\nvar getIteratorDirect = require('../internals/get-iterator-direct');\nvar getIteratorFlattenable = require('../internals/get-iterator-flattenable');\nvar createIteratorProxy = require('../internals/iterator-create-proxy');\nvar iteratorClose = require('../internals/iterator-close');\nvar IS_PURE = require('../internals/is-pure');\nvar iteratorHelperThrowsOnInvalidIterator = require('../internals/iterator-helper-throws-on-invalid-iterator');\nvar iteratorHelperWithoutClosingOnEarlyError = require('../internals/iterator-helper-without-closing-on-early-error');\n\nvar FLAT_MAP_WITHOUT_THROWING_ON_INVALID_ITERATOR = !IS_PURE\n && !iteratorHelperThrowsOnInvalidIterator('flatMap', function () { /* empty */ });\nvar flatMapWithoutClosingOnEarlyError = !IS_PURE && !FLAT_MAP_WITHOUT_THROWING_ON_INVALID_ITERATOR\n && iteratorHelperWithoutClosingOnEarlyError('flatMap', TypeError);\n\nvar FORCED = IS_PURE || FLAT_MAP_WITHOUT_THROWING_ON_INVALID_ITERATOR || flatMapWithoutClosingOnEarlyError;\n\nvar IteratorProxy = createIteratorProxy(function () {\n var iterator = this.iterator;\n var mapper = this.mapper;\n var result, inner;\n\n while (true) {\n if (inner = this.inner) try {\n result = anObject(call(inner.next, inner.iterator));\n if (!result.done) return result.value;\n this.inner = null;\n } catch (error) { iteratorClose(iterator, 'throw', error); }\n\n result = anObject(call(this.next, iterator));\n\n if (this.done = !!result.done) return;\n\n try {\n this.inner = getIteratorFlattenable(mapper(result.value, this.counter++), false);\n } catch (error) { iteratorClose(iterator, 'throw', error); }\n }\n});\n\n// `Iterator.prototype.flatMap` method\n// https://tc39.es/ecma262/#sec-iterator.prototype.flatmap\n$({ target: 'Iterator', proto: true, real: true, forced: FORCED }, {\n flatMap: function flatMap(mapper) {\n anObject(this);\n try {\n aCallable(mapper);\n } catch (error) {\n iteratorClose(this, 'throw', error);\n }\n\n if (flatMapWithoutClosingOnEarlyError) return call(flatMapWithoutClosingOnEarlyError, this, mapper);\n\n return new IteratorProxy(getIteratorDirect(this), {\n mapper: mapper,\n inner: null\n });\n }\n});\n","'use strict';\nvar fails = require('../internals/fails');\n\nmodule.exports = !fails(function () {\n // eslint-disable-next-line es/no-function-prototype-bind -- safe\n var test = (function () { /* empty */ }).bind();\n // eslint-disable-next-line no-prototype-builtins -- safe\n return typeof test != 'function' || test.hasOwnProperty('prototype');\n});\n","'use strict';\nvar classof = require('../internals/classof');\n\nvar $String = String;\n\nmodule.exports = function (argument) {\n if (classof(argument) === 'Symbol') throw new TypeError('Cannot convert a Symbol value to a string');\n return $String(argument);\n};\n","'use strict';\nvar isPrototypeOf = require('../internals/object-is-prototype-of');\n\nvar $TypeError = TypeError;\n\nmodule.exports = function (it, Prototype) {\n if (isPrototypeOf(Prototype, it)) return it;\n throw new $TypeError('Incorrect invocation');\n};\n","import { buildProps, definePropType } from '@element-plus/utils'\n\nimport type {\n ExtractPropTypes,\n InjectionKey,\n StyleValue,\n __ExtractPublicPropTypes,\n} from 'vue'\n\nexport const cardProps = buildProps({\n /**\n * @description title of the card. Also accepts a DOM passed by `slot#header`\n */\n header: {\n type: String,\n default: '',\n },\n /**\n * @description content of footer. Also accepts a DOM passed by `slot#footer`\n */\n footer: {\n type: String,\n default: '',\n },\n /**\n * @description CSS style of card body\n */\n bodyStyle: {\n type: definePropType([String, Object, Array]),\n default: '',\n },\n /**\n * @description custom class name of card footer\n */\n headerClass: String,\n /**\n * @description custom class name of card body\n */\n bodyClass: String,\n /**\n * @description custom class name of card footer\n */\n footerClass: String,\n /**\n * @description when to show card shadows\n */\n shadow: {\n type: String,\n values: ['always', 'hover', 'never'],\n default: undefined,\n },\n} as const)\nexport type CardProps = ExtractPropTypes\nexport type CardPropsPublic = __ExtractPublicPropTypes\nexport interface CardConfigContext {\n shadow?: string\n}\n\nexport const cardContextKey: InjectionKey =\n Symbol('cardContextKey')\n","\n\n\n","import { withInstall } from '@element-plus/utils'\nimport Card from './src/card.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElCard: SFCWithInstall = withInstall(Card)\nexport default ElCard\n\nexport * from './src/card'\nexport type { CardInstance } from './src/instance'\n","'use strict';\n// Should throw an error on invalid iterator\n// https://issues.chromium.org/issues/336839115\nmodule.exports = function (methodName, argument) {\n // eslint-disable-next-line es/no-iterator -- required for testing\n var method = typeof Iterator == 'function' && Iterator.prototype[methodName];\n if (method) try {\n method.call({ next: null }, argument).next();\n } catch (error) {\n return true;\n }\n};\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Checks if `value` is likely a prototype object.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.\n */\nfunction isPrototype(value) {\n var Ctor = value && value.constructor,\n proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;\n\n return value === proto;\n}\n\nexport default isPrototype;\n","'use strict';\nvar ceil = Math.ceil;\nvar floor = Math.floor;\n\n// `Math.trunc` method\n// https://tc39.es/ecma262/#sec-math.trunc\n// eslint-disable-next-line es/no-math-trunc -- safe\nmodule.exports = Math.trunc || function trunc(x) {\n var n = +x;\n return (n > 0 ? floor : ceil)(n);\n};\n","/** Used to match a single whitespace character. */\nvar reWhitespace = /\\s/;\n\n/**\n * Used by `_.trim` and `_.trimEnd` to get the index of the last non-whitespace\n * character of `string`.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {number} Returns the index of the last non-whitespace character.\n */\nfunction trimmedEndIndex(string) {\n var index = string.length;\n\n while (index-- && reWhitespace.test(string.charAt(index))) {}\n return index;\n}\n\nexport default trimmedEndIndex;\n","import trimmedEndIndex from './_trimmedEndIndex.js';\n\n/** Used to match leading whitespace. */\nvar reTrimStart = /^\\s+/;\n\n/**\n * The base implementation of `_.trim`.\n *\n * @private\n * @param {string} string The string to trim.\n * @returns {string} Returns the trimmed string.\n */\nfunction baseTrim(string) {\n return string\n ? string.slice(0, trimmedEndIndex(string) + 1).replace(reTrimStart, '')\n : string;\n}\n\nexport default baseTrim;\n","import baseTrim from './_baseTrim.js';\nimport isObject from './isObject.js';\nimport isSymbol from './isSymbol.js';\n\n/** Used as references for various `Number` constants. */\nvar NAN = 0 / 0;\n\n/** Used to detect bad signed hexadecimal string values. */\nvar reIsBadHex = /^[-+]0x[0-9a-f]+$/i;\n\n/** Used to detect binary string values. */\nvar reIsBinary = /^0b[01]+$/i;\n\n/** Used to detect octal string values. */\nvar reIsOctal = /^0o[0-7]+$/i;\n\n/** Built-in method references without a dependency on `root`. */\nvar freeParseInt = parseInt;\n\n/**\n * Converts `value` to a number.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to process.\n * @returns {number} Returns the number.\n * @example\n *\n * _.toNumber(3.2);\n * // => 3.2\n *\n * _.toNumber(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toNumber(Infinity);\n * // => Infinity\n *\n * _.toNumber('3.2');\n * // => 3.2\n */\nfunction toNumber(value) {\n if (typeof value == 'number') {\n return value;\n }\n if (isSymbol(value)) {\n return NAN;\n }\n if (isObject(value)) {\n var other = typeof value.valueOf == 'function' ? value.valueOf() : value;\n value = isObject(other) ? (other + '') : other;\n }\n if (typeof value != 'string') {\n return value === 0 ? value : +value;\n }\n value = baseTrim(value);\n var isBinary = reIsBinary.test(value);\n return (isBinary || reIsOctal.test(value))\n ? freeParseInt(value.slice(2), isBinary ? 2 : 8)\n : (reIsBadHex.test(value) ? NAN : +value);\n}\n\nexport default toNumber;\n","'use strict';\nvar getBuiltIn = require('../internals/get-built-in');\nvar isCallable = require('../internals/is-callable');\nvar isPrototypeOf = require('../internals/object-is-prototype-of');\nvar USE_SYMBOL_AS_UID = require('../internals/use-symbol-as-uid');\n\nvar $Object = Object;\n\nmodule.exports = USE_SYMBOL_AS_UID ? function (it) {\n return typeof it == 'symbol';\n} : function (it) {\n var $Symbol = getBuiltIn('Symbol');\n return isCallable($Symbol) && isPrototypeOf($Symbol.prototype, $Object(it));\n};\n","import type { CSSProperties, ComputedRef, InjectionKey, Ref } from 'vue'\nimport type { Instance } from '@popperjs/core'\n\nexport type Measurable = {\n getBoundingClientRect: () => DOMRect\n}\n\n/**\n * triggerRef indicates the element that triggers popper\n * contentRef indicates the element of popper content\n * referenceRef indicates the element that popper content relative with\n */\nexport type ElPopperInjectionContext = {\n triggerRef: Ref\n contentRef: Ref\n popperInstanceRef: Ref\n referenceRef: Ref\n role: ComputedRef\n}\n\nexport type ElPopperContentInjectionContext = {\n arrowRef: Ref\n arrowStyle: ComputedRef\n}\n\nexport const POPPER_INJECTION_KEY: InjectionKey =\n Symbol('popper')\n\nexport const POPPER_CONTENT_INJECTION_KEY: InjectionKey =\n Symbol('popperContent')\n","import { ref, watch } from 'vue'\nimport { get, isEqual } from 'lodash-unified'\n\nimport type { SelectV2Props } from './token'\nimport type { Option } from './select.types'\n\nexport interface Props {\n label?: string\n value?: string\n disabled?: string\n options?: string\n}\n\nexport const defaultProps: Required = {\n label: 'label',\n value: 'value',\n disabled: 'disabled',\n options: 'options',\n}\n\nexport function useProps(props: Pick) {\n const aliasProps = ref({ ...defaultProps, ...props.props })\n let cache = { ...props.props }\n\n watch(\n () => props.props,\n (val) => {\n // The props is an object, and its properties may be modified without changing the reference. In this case, the watch values before and after are equal. Here, we compare using the cached previous value.\n if (!isEqual(val, cache)) {\n aliasProps.value = { ...defaultProps, ...val }\n cache = { ...val }\n }\n },\n { deep: true }\n )\n\n const getLabel = (option: Option) => get(option, aliasProps.value.label)\n const getValue = (option: Option) => get(option, aliasProps.value.value)\n const getDisabled = (option: Option) => get(option, aliasProps.value.disabled)\n const getOptions = (option: Option) => get(option, aliasProps.value.options)\n\n return {\n aliasProps,\n getLabel,\n getValue,\n getDisabled,\n getOptions,\n }\n}\n","import { buildProps, definePropType } from '@element-plus/utils'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type Icon from './icon.vue'\n\nexport const iconProps = buildProps({\n /**\n * @description SVG icon size, size x size\n */\n size: {\n type: definePropType([Number, String]),\n },\n /**\n * @description SVG tag's fill attribute\n */\n color: {\n type: String,\n },\n} as const)\nexport type IconProps = ExtractPropTypes\nexport type IconPropsPublic = __ExtractPublicPropTypes\nexport type IconInstance = InstanceType & unknown\n","\n\n\n","import { withInstall } from '@element-plus/utils'\nimport Icon from './src/icon.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElIcon: SFCWithInstall = withInstall(Icon)\nexport default ElIcon\n\nexport * from './src/icon'\n","import { buildProps, definePropType } from '@element-plus/utils'\nimport { popperTriggerProps } from '@element-plus/components/popper'\nimport { EVENT_CODE } from '@element-plus/constants'\n\nimport type { Arrayable } from '@element-plus/utils'\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\n\nexport type TooltipTriggerType = 'hover' | 'focus' | 'click' | 'contextmenu'\n\nexport const useTooltipTriggerProps = buildProps({\n ...popperTriggerProps,\n /**\n * @description whether Tooltip is disabled\n */\n disabled: Boolean,\n /**\n * @description How should the tooltip be triggered (to show), not valid in controlled mode\n */\n trigger: {\n type: definePropType>([String, Array]),\n default: 'hover',\n },\n /**\n * @description When you click the mouse to focus on the trigger element, you can define a set of keyboard codes to control the display of tooltip through the keyboard, not valid in controlled mode\n */\n triggerKeys: {\n type: definePropType(Array),\n default: () => [EVENT_CODE.enter, EVENT_CODE.numpadEnter, EVENT_CODE.space],\n },\n /**\n * @description when triggering tooltips through hover, whether to focus the trigger element, which improves accessibility\n */\n focusOnTarget: Boolean,\n} as const)\n\nexport type ElTooltipTriggerProps = ExtractPropTypes<\n typeof useTooltipTriggerProps\n>\n\nexport type ElTooltipTriggerPropsPublic = __ExtractPublicPropTypes<\n typeof useTooltipTriggerProps\n>\n","import { UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport { useAriaProps, useSizeProp } from '@element-plus/hooks'\nimport { isBoolean, isNumber, isString } from '@element-plus/utils'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type Checkbox from './checkbox.vue'\n\nexport type CheckboxValueType = string | number | boolean\n\nexport const checkboxProps = {\n /**\n * @description binding value\n */\n modelValue: {\n type: [Number, String, Boolean],\n default: undefined,\n },\n /**\n * @description label of the Checkbox when used inside a `checkbox-group`\n */\n label: {\n type: [String, Boolean, Number, Object],\n default: undefined,\n },\n /**\n * @description value of the Checkbox when used inside a `checkbox-group`\n */\n value: {\n type: [String, Boolean, Number, Object],\n default: undefined,\n },\n /**\n * @description Set indeterminate state, only responsible for style control\n */\n indeterminate: Boolean,\n /**\n * @description whether the Checkbox is disabled\n */\n disabled: {\n type: Boolean,\n default: undefined,\n },\n /**\n * @description if the Checkbox is checked\n */\n checked: Boolean,\n /**\n * @description native 'name' attribute\n */\n name: {\n type: String,\n default: undefined,\n },\n /**\n * @description value of the Checkbox if it's checked\n */\n trueValue: {\n type: [String, Number],\n default: undefined,\n },\n /**\n * @description value of the Checkbox if it's not checked\n */\n falseValue: {\n type: [String, Number],\n default: undefined,\n },\n /**\n * @deprecated use `trueValue` instead\n * @description value of the Checkbox if it's checked\n */\n trueLabel: {\n type: [String, Number],\n default: undefined,\n },\n /**\n * @deprecated use `falseValue` instead\n * @description value of the Checkbox if it's not checked\n */\n falseLabel: {\n type: [String, Number],\n default: undefined,\n },\n /**\n * @description input id\n */\n id: {\n type: String,\n default: undefined,\n },\n /**\n * @description whether to add a border around Checkbox\n */\n border: Boolean,\n /**\n * @description size of the Checkbox\n */\n size: useSizeProp,\n /**\n * @description input tabindex\n */\n tabindex: [String, Number],\n /**\n * @description whether to trigger form validation\n */\n validateEvent: {\n type: Boolean,\n default: true,\n },\n ariaLabel: String,\n ...useAriaProps(['ariaControls']),\n}\n\nexport const checkboxEmits = {\n [UPDATE_MODEL_EVENT]: (val: CheckboxValueType) =>\n isString(val) || isNumber(val) || isBoolean(val),\n change: (val: CheckboxValueType) =>\n isString(val) || isNumber(val) || isBoolean(val),\n}\n\nexport type CheckboxProps = ExtractPropTypes\nexport type CheckboxPropsPublic = __ExtractPublicPropTypes\nexport type CheckboxEmits = typeof checkboxEmits\nexport type CheckboxInstance = InstanceType & unknown\n","import type {\n ComputedRef,\n InjectionKey,\n ToRefs,\n WritableComputedRef,\n} from 'vue'\nimport type { CheckboxGroupProps } from './checkbox-group'\n\ntype CheckboxGroupContext = {\n modelValue?: WritableComputedRef\n changeEvent?: (...args: any) => any\n disabled?: ComputedRef\n} & ToRefs<\n Pick<\n CheckboxGroupProps,\n 'size' | 'min' | 'max' | 'validateEvent' | 'fill' | 'textColor'\n >\n>\n\nexport const checkboxGroupContextKey: InjectionKey =\n Symbol('checkboxGroupContextKey')\n","import { computed, inject } from 'vue'\nimport { formContextKey, useFormDisabled } from '@element-plus/components/form'\nimport { isUndefined } from '@element-plus/utils'\nimport { checkboxGroupContextKey } from '../constants'\n\nimport type { CheckboxModel, CheckboxStatus } from '../composables'\n\nexport const useCheckboxDisabled = ({\n model,\n isChecked,\n}: Pick & Pick) => {\n const checkboxGroup = inject(checkboxGroupContextKey, undefined)\n const formContext = inject(formContextKey, undefined)\n\n const isLimitDisabled = computed(() => {\n const max = checkboxGroup?.max?.value\n const min = checkboxGroup?.min?.value\n return (\n (!isUndefined(max) && model.value.length >= max && !isChecked.value) ||\n (!isUndefined(min) && model.value.length <= min && isChecked.value)\n )\n })\n\n const isDisabled = useFormDisabled(\n computed(() => {\n // Directly use the checkbox\n if (checkboxGroup === undefined) {\n return formContext?.disabled ?? isLimitDisabled.value\n } else {\n return checkboxGroup.disabled?.value || isLimitDisabled.value\n }\n })\n )\n\n return {\n isDisabled,\n isLimitDisabled,\n }\n}\n\nexport type CheckboxDisabled = ReturnType\n","import { computed, getCurrentInstance, inject, nextTick, watch } from 'vue'\nimport { useFormItem } from '@element-plus/components/form'\nimport { debugWarn } from '@element-plus/utils'\nimport { CHANGE_EVENT } from '@element-plus/constants'\nimport { checkboxGroupContextKey } from '../constants'\n\nimport type { useFormItemInputId } from '@element-plus/components/form'\nimport type { CheckboxProps } from '../checkbox'\nimport type {\n CheckboxDisabled,\n CheckboxModel,\n CheckboxStatus,\n} from '../composables'\n\nexport const useCheckboxEvent = (\n props: CheckboxProps,\n {\n model,\n isLimitExceeded,\n hasOwnLabel,\n isDisabled,\n isLabeledByFormItem,\n }: Pick &\n Pick &\n Pick &\n Pick, 'isLabeledByFormItem'>\n) => {\n const checkboxGroup = inject(checkboxGroupContextKey, undefined)\n const { formItem } = useFormItem()\n const { emit } = getCurrentInstance()!\n\n function getLabeledValue(value: string | number | boolean) {\n return [true, props.trueValue, props.trueLabel].includes(value)\n ? (props.trueValue ?? props.trueLabel ?? true)\n : (props.falseValue ?? props.falseLabel ?? false)\n }\n\n function emitChangeEvent(\n checked: string | number | boolean,\n e: InputEvent | MouseEvent\n ) {\n emit(CHANGE_EVENT, getLabeledValue(checked), e)\n }\n\n function handleChange(e: Event) {\n if (isLimitExceeded.value) return\n\n const target = e.target as HTMLInputElement\n emit(CHANGE_EVENT, getLabeledValue(target.checked), e)\n }\n\n async function onClickRoot(e: MouseEvent) {\n if (isLimitExceeded.value) return\n\n if (!hasOwnLabel.value && !isDisabled.value && isLabeledByFormItem.value) {\n // fix: https://github.com/element-plus/element-plus/issues/9981\n const eventTargets: EventTarget[] = e.composedPath()\n const hasLabel = eventTargets.some(\n (item) => (item as HTMLElement).tagName === 'LABEL'\n )\n if (!hasLabel) {\n model.value = getLabeledValue(\n [false, props.falseValue, props.falseLabel].includes(model.value)\n )\n await nextTick()\n emitChangeEvent(model.value, e)\n }\n }\n }\n\n const validateEvent = computed(\n () => checkboxGroup?.validateEvent || props.validateEvent\n )\n\n watch(\n () => props.modelValue,\n () => {\n if (validateEvent.value) {\n formItem?.validate('change').catch((err) => debugWarn(err))\n }\n }\n )\n\n return {\n handleChange,\n onClickRoot,\n }\n}\n","import { computed, getCurrentInstance, inject, ref } from 'vue'\nimport { isArray, isUndefined } from '@element-plus/utils'\nimport { UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport { checkboxGroupContextKey } from '../constants'\n\nimport type { CheckboxProps } from '../checkbox'\n\nexport const useCheckboxModel = (props: CheckboxProps) => {\n const selfModel = ref(false)\n const { emit } = getCurrentInstance()!\n const checkboxGroup = inject(checkboxGroupContextKey, undefined)\n const isGroup = computed(() => isUndefined(checkboxGroup) === false)\n const isLimitExceeded = ref(false)\n const model = computed({\n get() {\n return isGroup.value\n ? checkboxGroup?.modelValue?.value\n : (props.modelValue ?? selfModel.value)\n },\n\n set(val: unknown) {\n if (isGroup.value && isArray(val)) {\n isLimitExceeded.value =\n checkboxGroup?.max?.value !== undefined &&\n val.length > checkboxGroup?.max.value &&\n val.length > model.value.length\n isLimitExceeded.value === false && checkboxGroup?.changeEvent?.(val)\n } else {\n emit(UPDATE_MODEL_EVENT, val)\n selfModel.value = val\n }\n },\n })\n\n return {\n model,\n isGroup,\n isLimitExceeded,\n }\n}\n\nexport type CheckboxModel = ReturnType\n","import { computed, inject, ref, toRaw } from 'vue'\nimport { isEqual } from 'lodash-unified'\nimport { useFormSize } from '@element-plus/components/form'\nimport { isArray, isBoolean, isObject, isPropAbsent } from '@element-plus/utils'\nimport { checkboxGroupContextKey } from '../constants'\n\nimport type { ComponentInternalInstance } from 'vue'\nimport type { CheckboxProps } from '../checkbox'\nimport type { CheckboxModel } from '../composables'\n\nexport const useCheckboxStatus = (\n props: CheckboxProps,\n slots: ComponentInternalInstance['slots'],\n { model }: Pick\n) => {\n const checkboxGroup = inject(checkboxGroupContextKey, undefined)\n const isFocused = ref(false)\n const actualValue = computed(() => {\n // In version 2.x, if there's no props.value, props.label will act as props.value\n // In version 3.x, remove this computed value, use props.value instead.\n if (!isPropAbsent(props.value)) {\n return props.value\n }\n return props.label\n })\n const isChecked = computed(() => {\n const value = model.value\n if (isBoolean(value)) {\n return value\n } else if (isArray(value)) {\n if (isObject(actualValue.value)) {\n return value.map(toRaw).some((o) => isEqual(o, actualValue.value))\n } else {\n return value.map(toRaw).includes(actualValue.value)\n }\n } else if (value !== null && value !== undefined) {\n return value === props.trueValue || value === props.trueLabel\n } else {\n return !!value\n }\n })\n\n const checkboxButtonSize = useFormSize(\n computed(() => checkboxGroup?.size?.value),\n {\n prop: true,\n }\n )\n const checkboxSize = useFormSize(computed(() => checkboxGroup?.size?.value))\n\n const hasOwnLabel = computed(() => {\n return !!slots.default || !isPropAbsent(actualValue.value)\n })\n\n return {\n checkboxButtonSize,\n isChecked,\n isFocused,\n checkboxSize,\n hasOwnLabel,\n actualValue,\n }\n}\n\nexport type CheckboxStatus = ReturnType\n","import { computed } from 'vue'\nimport { useFormItem, useFormItemInputId } from '@element-plus/components/form'\nimport { isArray, isPropAbsent } from '@element-plus/utils'\nimport { useDeprecated } from '@element-plus/hooks'\nimport { useCheckboxDisabled } from './use-checkbox-disabled'\nimport { useCheckboxEvent } from './use-checkbox-event'\nimport { useCheckboxModel } from './use-checkbox-model'\nimport { useCheckboxStatus } from './use-checkbox-status'\n\nimport type { ComponentInternalInstance } from 'vue'\nimport type { CheckboxProps } from '../checkbox'\n\nexport const useCheckbox = (\n props: CheckboxProps,\n slots: ComponentInternalInstance['slots']\n) => {\n const { formItem: elFormItem } = useFormItem()\n const { model, isGroup, isLimitExceeded } = useCheckboxModel(props)\n const {\n isFocused,\n isChecked,\n checkboxButtonSize,\n checkboxSize,\n hasOwnLabel,\n actualValue,\n } = useCheckboxStatus(props, slots, { model })\n const { isDisabled } = useCheckboxDisabled({ model, isChecked })\n const { inputId, isLabeledByFormItem } = useFormItemInputId(props, {\n formItemContext: elFormItem,\n disableIdGeneration: hasOwnLabel,\n disableIdManagement: isGroup,\n })\n const { handleChange, onClickRoot } = useCheckboxEvent(props, {\n model,\n isLimitExceeded,\n hasOwnLabel,\n isDisabled,\n isLabeledByFormItem,\n })\n\n const setStoreValue = () => {\n function addToStore() {\n if (isArray(model.value) && !model.value.includes(actualValue.value)) {\n model.value.push(actualValue.value)\n } else {\n model.value = props.trueValue ?? props.trueLabel ?? true\n }\n }\n props.checked && addToStore()\n }\n\n setStoreValue()\n\n useDeprecated(\n {\n from: 'label act as value',\n replacement: 'value',\n version: '3.0.0',\n scope: 'el-checkbox',\n ref: 'https://element-plus.org/en-US/component/checkbox.html',\n },\n computed(() => isGroup.value && isPropAbsent(props.value))\n )\n\n useDeprecated(\n {\n from: 'true-label',\n replacement: 'true-value',\n version: '3.0.0',\n scope: 'el-checkbox',\n ref: 'https://element-plus.org/en-US/component/checkbox.html',\n },\n computed(() => !!props.trueLabel)\n )\n\n useDeprecated(\n {\n from: 'false-label',\n replacement: 'false-value',\n version: '3.0.0',\n scope: 'el-checkbox',\n ref: 'https://element-plus.org/en-US/component/checkbox.html',\n },\n computed(() => !!props.falseLabel)\n )\n\n return {\n inputId,\n isLabeledByFormItem,\n isChecked,\n isDisabled,\n isFocused,\n checkboxButtonSize,\n checkboxSize,\n hasOwnLabel,\n model,\n actualValue,\n handleChange,\n onClickRoot,\n }\n}\n","\n\n\n","\n\n\n","import { UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport { useAriaProps, useSizeProp } from '@element-plus/hooks'\nimport { buildProps, definePropType, isArray } from '@element-plus/utils'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type checkboxGroup from './checkbox-group.vue'\nimport type { CheckboxPropsPublic, CheckboxValueType } from './checkbox'\n\nexport type CheckboxGroupValueType = Exclude[]\n\nexport const checkboxGroupProps = buildProps({\n /**\n * @description binding value\n */\n modelValue: {\n type: definePropType(Array),\n default: () => [],\n },\n /**\n * @description whether the nesting checkboxes are disabled\n */\n disabled: {\n type: Boolean,\n default: undefined,\n },\n /**\n * @description minimum number of checkbox checked\n */\n min: Number,\n /**\n * @description maximum number of checkbox checked\n */\n max: Number,\n /**\n * @description size of checkbox\n */\n size: useSizeProp,\n /**\n * @description border and background color when button is active\n */\n fill: String,\n /**\n * @description font color when button is active\n */\n textColor: String,\n /**\n * @description element tag of the checkbox group\n */\n tag: {\n type: String,\n default: 'div',\n },\n /**\n * @description whether to trigger form validation\n */\n validateEvent: {\n type: Boolean,\n default: true,\n },\n options: {\n type: definePropType(Array),\n },\n props: {\n type: definePropType(Object),\n default: () => checkboxDefaultProps,\n },\n type: {\n type: String,\n values: ['checkbox', 'button'] as const,\n default: 'checkbox',\n },\n ...useAriaProps(['ariaLabel']),\n} as const)\n\nexport const checkboxGroupEmits = {\n [UPDATE_MODEL_EVENT]: (val: CheckboxGroupValueType) => isArray(val),\n change: (val: CheckboxValueType[]) => isArray(val),\n}\n\nexport type CheckboxGroupProps = ExtractPropTypes\nexport type CheckboxGroupPropsPublic = __ExtractPublicPropTypes<\n typeof checkboxGroupProps\n>\nexport type CheckboxGroupEmits = typeof checkboxGroupEmits\nexport type CheckboxGroupInstance = InstanceType & unknown\n\nexport type CheckboxOption = CheckboxPropsPublic & Record\n\ntype CheckboxOptionProps = {\n value?: string\n label?: string\n disabled?: string\n}\nexport const checkboxDefaultProps: Required = {\n label: 'label',\n value: 'value',\n disabled: 'disabled',\n}\n","\n\n\n","import { withInstall, withNoopInstall } from '@element-plus/utils'\nimport Checkbox from './src/checkbox.vue'\nimport CheckboxButton from './src/checkbox-button.vue'\nimport CheckboxGroup from './src/checkbox-group.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElCheckbox: SFCWithInstall & {\n CheckboxButton: typeof CheckboxButton\n CheckboxGroup: typeof CheckboxGroup\n} = withInstall(Checkbox, {\n CheckboxButton,\n CheckboxGroup,\n})\nexport default ElCheckbox\n\nexport const ElCheckboxButton: SFCWithInstall =\n withNoopInstall(CheckboxButton)\nexport const ElCheckboxGroup: SFCWithInstall =\n withNoopInstall(CheckboxGroup)\n\nexport * from './src/checkbox-group'\nexport * from './src/checkbox'\nexport * from './src/constants'\n","'use strict';\nvar classof = require('../internals/classof');\nvar getMethod = require('../internals/get-method');\nvar isNullOrUndefined = require('../internals/is-null-or-undefined');\nvar Iterators = require('../internals/iterators');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar ITERATOR = wellKnownSymbol('iterator');\n\nmodule.exports = function (it) {\n if (!isNullOrUndefined(it)) return getMethod(it, ITERATOR)\n || getMethod(it, '@@iterator')\n || Iterators[classof(it)];\n};\n","'use strict';\nvar $TypeError = TypeError;\n\nmodule.exports = function (options) {\n var alphabet = options && options.alphabet;\n if (alphabet === undefined || alphabet === 'base64' || alphabet === 'base64url') return alphabet || 'base64';\n throw new $TypeError('Incorrect `alphabet` option');\n};\n","import { provide } from 'vue'\n\nimport type { InjectionKey, ObjectDirective, Ref } from 'vue'\n\ntype ForwardRefSetter = (el: T) => void\n\nexport type ForwardRefInjectionContext = {\n setForwardRef: ForwardRefSetter\n}\n\nexport const FORWARD_REF_INJECTION_KEY: InjectionKey =\n Symbol('elForwardRef')\n\nexport const useForwardRef = (forwardRef: Ref) => {\n const setForwardRef = (el: T) => {\n forwardRef.value = el\n }\n\n provide(FORWARD_REF_INJECTION_KEY, {\n setForwardRef,\n })\n}\n\nexport const useForwardRefDirective = (\n setForwardRef: ForwardRefSetter\n): ObjectDirective => {\n return {\n mounted(el) {\n setForwardRef(el)\n },\n updated(el) {\n setForwardRef(el)\n },\n unmounted() {\n setForwardRef(null)\n },\n }\n}\n","import baseAssignValue from './_baseAssignValue.js';\nimport eq from './eq.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Assigns `value` to `key` of `object` if the existing value is not equivalent\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\nfunction assignValue(object, key, value) {\n var objValue = object[key];\n if (!(hasOwnProperty.call(object, key) && eq(objValue, value)) ||\n (value === undefined && !(key in object))) {\n baseAssignValue(object, key, value);\n }\n}\n\nexport default assignValue;\n","'use strict';\nvar internalObjectKeys = require('../internals/object-keys-internal');\nvar enumBugKeys = require('../internals/enum-bug-keys');\n\n// `Object.keys` method\n// https://tc39.es/ecma262/#sec-object.keys\n// eslint-disable-next-line es/no-object-keys -- safe\nmodule.exports = Object.keys || function keys(O) {\n return internalObjectKeys(O, enumBugKeys);\n};\n","/**\n * Gets the last element of `array`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to query.\n * @returns {*} Returns the last element of `array`.\n * @example\n *\n * _.last([1, 2, 3]);\n * // => 3\n */\nfunction last(array) {\n var length = array == null ? 0 : array.length;\n return length ? array[length - 1] : undefined;\n}\n\nexport default last;\n","/**\n * The base implementation of `_.slice` without an iteratee call guard.\n *\n * @private\n * @param {Array} array The array to slice.\n * @param {number} [start=0] The start position.\n * @param {number} [end=array.length] The end position.\n * @returns {Array} Returns the slice of `array`.\n */\nfunction baseSlice(array, start, end) {\n var index = -1,\n length = array.length;\n\n if (start < 0) {\n start = -start > length ? 0 : (length + start);\n }\n end = end > length ? length : end;\n if (end < 0) {\n end += length;\n }\n length = start > end ? 0 : ((end - start) >>> 0);\n start >>>= 0;\n\n var result = Array(length);\n while (++index < length) {\n result[index] = array[index + start];\n }\n return result;\n}\n\nexport default baseSlice;\n","import baseGet from './_baseGet.js';\nimport baseSlice from './_baseSlice.js';\n\n/**\n * Gets the parent value at `path` of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array} path The path to get the parent value of.\n * @returns {*} Returns the parent value.\n */\nfunction parent(object, path) {\n return path.length < 2 ? object : baseGet(object, baseSlice(path, 0, -1));\n}\n\nexport default parent;\n","import castPath from './_castPath.js';\nimport last from './last.js';\nimport parent from './_parent.js';\nimport toKey from './_toKey.js';\n\n/**\n * The base implementation of `_.unset`.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {Array|string} path The property path to unset.\n * @returns {boolean} Returns `true` if the property is deleted, else `false`.\n */\nfunction baseUnset(object, path) {\n path = castPath(path, object);\n object = parent(object, path);\n return object == null || delete object[toKey(last(path))];\n}\n\nexport default baseUnset;\n","import isPlainObject from './isPlainObject.js';\n\n/**\n * Used by `_.omit` to customize its `_.cloneDeep` use to only clone plain\n * objects.\n *\n * @private\n * @param {*} value The value to inspect.\n * @param {string} key The key of the property to inspect.\n * @returns {*} Returns the uncloned value or `undefined` to defer cloning to `_.cloneDeep`.\n */\nfunction customOmitClone(value) {\n return isPlainObject(value) ? undefined : value;\n}\n\nexport default customOmitClone;\n","import arrayMap from './_arrayMap.js';\nimport baseClone from './_baseClone.js';\nimport baseUnset from './_baseUnset.js';\nimport castPath from './_castPath.js';\nimport copyObject from './_copyObject.js';\nimport customOmitClone from './_customOmitClone.js';\nimport flatRest from './_flatRest.js';\nimport getAllKeysIn from './_getAllKeysIn.js';\n\n/** Used to compose bitmasks for cloning. */\nvar CLONE_DEEP_FLAG = 1,\n CLONE_FLAT_FLAG = 2,\n CLONE_SYMBOLS_FLAG = 4;\n\n/**\n * The opposite of `_.pick`; this method creates an object composed of the\n * own and inherited enumerable property paths of `object` that are not omitted.\n *\n * **Note:** This method is considerably slower than `_.pick`.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The source object.\n * @param {...(string|string[])} [paths] The property paths to omit.\n * @returns {Object} Returns the new object.\n * @example\n *\n * var object = { 'a': 1, 'b': '2', 'c': 3 };\n *\n * _.omit(object, ['a', 'c']);\n * // => { 'b': '2' }\n */\nvar omit = flatRest(function(object, paths) {\n var result = {};\n if (object == null) {\n return result;\n }\n var isDeep = false;\n paths = arrayMap(paths, function(path) {\n path = castPath(path, object);\n isDeep || (isDeep = path.length > 1);\n return path;\n });\n copyObject(object, getAllKeysIn(object), result);\n if (isDeep) {\n result = baseClone(result, CLONE_DEEP_FLAG | CLONE_FLAT_FLAG | CLONE_SYMBOLS_FLAG, customOmitClone);\n }\n var length = paths.length;\n while (length--) {\n baseUnset(result, paths[length]);\n }\n return result;\n});\n\nexport default omit;\n","import type { InjectionKey } from 'vue'\nimport type { BreadcrumbProps } from './breadcrumb'\n\nexport const breadcrumbKey: InjectionKey =\n Symbol('breadcrumbKey')\n","import { buildProps, iconPropType } from '@element-plus/utils'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\n\nexport const breadcrumbProps = buildProps({\n /**\n * @description separator character\n */\n separator: {\n type: String,\n default: '/',\n },\n /**\n * @description icon component of icon separator\n */\n separatorIcon: {\n type: iconPropType,\n },\n} as const)\nexport type BreadcrumbProps = ExtractPropTypes\nexport type BreadcrumbPropsPublic = __ExtractPublicPropTypes<\n typeof breadcrumbProps\n>\n","\n\n\n","import { buildProps, definePropType } from '@element-plus/utils'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type { RouteLocationRaw } from 'vue-router'\n\nexport const breadcrumbItemProps = buildProps({\n /**\n * @description target route of the link, same as `to` of `vue-router`\n */\n to: {\n type: definePropType([String, Object]),\n default: '',\n },\n /**\n * @description if `true`, the navigation will not leave a history record\n */\n replace: Boolean,\n} as const)\nexport type BreadcrumbItemProps = ExtractPropTypes\nexport type BreadcrumbItemPropsPublic = __ExtractPublicPropTypes<\n typeof breadcrumbItemProps\n>\n","\n\n\n","import { withInstall, withNoopInstall } from '@element-plus/utils'\nimport Breadcrumb from './src/breadcrumb.vue'\nimport BreadcrumbItem from './src/breadcrumb-item.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElBreadcrumb: SFCWithInstall & {\n BreadcrumbItem: typeof BreadcrumbItem\n} = withInstall(Breadcrumb, {\n BreadcrumbItem,\n})\nexport const ElBreadcrumbItem: SFCWithInstall =\n withNoopInstall(BreadcrumbItem)\nexport default ElBreadcrumb\n\nexport * from './src/breadcrumb'\nexport * from './src/breadcrumb-item'\nexport * from './src/constants'\nexport type {\n BreadcrumbInstance,\n BreadcrumbItemInstance,\n} from './src/instances'\n","'use strict';\nvar classof = require('../internals/classof');\n\nmodule.exports = function (it) {\n var klass = classof(it);\n return klass === 'BigInt64Array' || klass === 'BigUint64Array';\n};\n","/**\n * This method returns `false`.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {boolean} Returns `false`.\n * @example\n *\n * _.times(2, _.stubFalse);\n * // => [false, false]\n */\nfunction stubFalse() {\n return false;\n}\n\nexport default stubFalse;\n","import root from './_root.js';\nimport stubFalse from './stubFalse.js';\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined;\n\n/**\n * Checks if `value` is a buffer.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a buffer, else `false`.\n * @example\n *\n * _.isBuffer(new Buffer(2));\n * // => true\n *\n * _.isBuffer(new Uint8Array(2));\n * // => false\n */\nvar isBuffer = nativeIsBuffer || stubFalse;\n\nexport default isBuffer;\n","'use strict';\nvar isPossiblePrototype = require('../internals/is-possible-prototype');\n\nvar $String = String;\nvar $TypeError = TypeError;\n\nmodule.exports = function (argument) {\n if (isPossiblePrototype(argument)) return argument;\n throw new $TypeError(\"Can't set \" + $String(argument) + ' as a prototype');\n};\n","'use strict';\nvar $ = require('../internals/export');\nvar call = require('../internals/function-call');\nvar iterate = require('../internals/iterate');\nvar aCallable = require('../internals/a-callable');\nvar anObject = require('../internals/an-object');\nvar getIteratorDirect = require('../internals/get-iterator-direct');\nvar iteratorClose = require('../internals/iterator-close');\nvar iteratorHelperWithoutClosingOnEarlyError = require('../internals/iterator-helper-without-closing-on-early-error');\n\nvar everyWithoutClosingOnEarlyError = iteratorHelperWithoutClosingOnEarlyError('every', TypeError);\n\n// `Iterator.prototype.every` method\n// https://tc39.es/ecma262/#sec-iterator.prototype.every\n$({ target: 'Iterator', proto: true, real: true, forced: everyWithoutClosingOnEarlyError }, {\n every: function every(predicate) {\n anObject(this);\n try {\n aCallable(predicate);\n } catch (error) {\n iteratorClose(this, 'throw', error);\n }\n\n if (everyWithoutClosingOnEarlyError) return call(everyWithoutClosingOnEarlyError, this, predicate);\n\n var record = getIteratorDirect(this);\n var counter = 0;\n return !iterate(record, function (value, stop) {\n if (!predicate(value, counter++)) return stop();\n }, { IS_RECORD: true, INTERRUPTED: true }).stopped;\n }\n});\n","/**\n * The inverse of `_.toPairs`; this method returns an object composed\n * from key-value `pairs`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} pairs The key-value pairs.\n * @returns {Object} Returns the new object.\n * @example\n *\n * _.fromPairs([['a', 1], ['b', 2]]);\n * // => { 'a': 1, 'b': 2 }\n */\nfunction fromPairs(pairs) {\n var index = -1,\n length = pairs == null ? 0 : pairs.length,\n result = {};\n\n while (++index < length) {\n var pair = pairs[index];\n result[pair[0]] = pair[1];\n }\n return result;\n}\n\nexport default fromPairs;\n","/**\n * The base implementation of `_.findIndex` and `_.findLastIndex` without\n * support for iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {Function} predicate The function invoked per iteration.\n * @param {number} fromIndex The index to search from.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction baseFindIndex(array, predicate, fromIndex, fromRight) {\n var length = array.length,\n index = fromIndex + (fromRight ? 1 : -1);\n\n while ((fromRight ? index-- : ++index < length)) {\n if (predicate(array[index], index, array)) {\n return index;\n }\n }\n return -1;\n}\n\nexport default baseFindIndex;\n","'use strict';\nvar NATIVE_WEAK_MAP = require('../internals/weak-map-basic-detection');\nvar globalThis = require('../internals/global-this');\nvar isObject = require('../internals/is-object');\nvar createNonEnumerableProperty = require('../internals/create-non-enumerable-property');\nvar hasOwn = require('../internals/has-own-property');\nvar shared = require('../internals/shared-store');\nvar sharedKey = require('../internals/shared-key');\nvar hiddenKeys = require('../internals/hidden-keys');\n\nvar OBJECT_ALREADY_INITIALIZED = 'Object already initialized';\nvar TypeError = globalThis.TypeError;\nvar WeakMap = globalThis.WeakMap;\nvar set, get, has;\n\nvar enforce = function (it) {\n return has(it) ? get(it) : set(it, {});\n};\n\nvar getterFor = function (TYPE) {\n return function (it) {\n var state;\n if (!isObject(it) || (state = get(it)).type !== TYPE) {\n throw new TypeError('Incompatible receiver, ' + TYPE + ' required');\n } return state;\n };\n};\n\nif (NATIVE_WEAK_MAP || shared.state) {\n var store = shared.state || (shared.state = new WeakMap());\n /* eslint-disable no-self-assign -- prototype methods protection */\n store.get = store.get;\n store.has = store.has;\n store.set = store.set;\n /* eslint-enable no-self-assign -- prototype methods protection */\n set = function (it, metadata) {\n if (store.has(it)) throw new TypeError(OBJECT_ALREADY_INITIALIZED);\n metadata.facade = it;\n store.set(it, metadata);\n return metadata;\n };\n get = function (it) {\n return store.get(it) || {};\n };\n has = function (it) {\n return store.has(it);\n };\n} else {\n var STATE = sharedKey('state');\n hiddenKeys[STATE] = true;\n set = function (it, metadata) {\n if (hasOwn(it, STATE)) throw new TypeError(OBJECT_ALREADY_INITIALIZED);\n metadata.facade = it;\n createNonEnumerableProperty(it, STATE, metadata);\n return metadata;\n };\n get = function (it) {\n return hasOwn(it, STATE) ? it[STATE] : {};\n };\n has = function (it) {\n return hasOwn(it, STATE);\n };\n}\n\nmodule.exports = {\n set: set,\n get: get,\n has: has,\n enforce: enforce,\n getterFor: getterFor\n};\n","import isArray from './isArray.js';\nimport isSymbol from './isSymbol.js';\n\n/** Used to match property names within property paths. */\nvar reIsDeepProp = /\\.|\\[(?:[^[\\]]*|([\"'])(?:(?!\\1)[^\\\\]|\\\\.)*?\\1)\\]/,\n reIsPlainProp = /^\\w*$/;\n\n/**\n * Checks if `value` is a property name and not a property path.\n *\n * @private\n * @param {*} value The value to check.\n * @param {Object} [object] The object to query keys on.\n * @returns {boolean} Returns `true` if `value` is a property name, else `false`.\n */\nfunction isKey(value, object) {\n if (isArray(value)) {\n return false;\n }\n var type = typeof value;\n if (type == 'number' || type == 'symbol' || type == 'boolean' ||\n value == null || isSymbol(value)) {\n return true;\n }\n return reIsPlainProp.test(value) || !reIsDeepProp.test(value) ||\n (object != null && value in Object(object));\n}\n\nexport default isKey;\n","export const componentSizes = ['', 'default', 'small', 'large'] as const\n\nexport type ComponentSize = (typeof componentSizes)[number]\n\nexport const componentSizeMap = {\n large: 40,\n default: 32,\n small: 24,\n} as const\n","import {\n buildProps,\n definePropType,\n iconPropType,\n isClient,\n mutable,\n} from '@element-plus/utils'\n\nimport type {\n AppContext,\n ExtractPropTypes,\n VNode,\n __ExtractPublicPropTypes,\n} from 'vue'\nimport type { Mutable } from '@element-plus/utils'\nimport type MessageConstructor from './message.vue'\n\nexport const messageTypes = [\n 'primary',\n 'success',\n 'info',\n 'warning',\n 'error',\n] as const\n\nexport const messagePlacement = [\n 'top',\n 'top-left',\n 'top-right',\n 'bottom',\n 'bottom-left',\n 'bottom-right',\n] as const\n\nexport const MESSAGE_DEFAULT_PLACEMENT = 'top'\n\nexport type MessageType = (typeof messageTypes)[number]\nexport type MessagePlacement = (typeof messagePlacement)[number]\n/** @deprecated please use `MessageType` instead */\nexport type messageType = MessageType // will be removed in 3.0.0.\n\nexport interface MessageConfigContext {\n max?: number\n grouping?: boolean\n duration?: number\n offset?: number\n showClose?: boolean\n plain?: boolean\n placement?: string\n}\n\nexport const messageDefaults = mutable({\n customClass: '',\n dangerouslyUseHTMLString: false,\n duration: 3000,\n icon: undefined,\n id: '',\n message: '',\n onClose: undefined,\n showClose: false,\n type: 'info',\n plain: false,\n offset: 16,\n placement: undefined,\n zIndex: 0,\n grouping: false,\n repeatNum: 1,\n appendTo: isClient ? document.body : (undefined as never),\n} as const)\n\nexport const messageProps = buildProps({\n /**\n * @description custom class name for Message\n */\n customClass: {\n type: String,\n default: messageDefaults.customClass,\n },\n /**\n * @description whether `message` is treated as HTML string\n */\n dangerouslyUseHTMLString: {\n type: Boolean,\n default: messageDefaults.dangerouslyUseHTMLString,\n },\n /**\n * @description display duration, millisecond. If set to 0, it will not turn off automatically\n */\n duration: {\n type: Number,\n default: messageDefaults.duration,\n },\n /**\n * @description custom icon component, overrides `type`\n */\n icon: {\n type: iconPropType,\n default: messageDefaults.icon,\n },\n /**\n * @description message dom id\n */\n id: {\n type: String,\n default: messageDefaults.id,\n },\n /**\n * @description message text\n */\n message: {\n type: definePropType VNode)>([\n String,\n Object,\n Function,\n ]),\n default: messageDefaults.message,\n },\n /**\n * @description callback function when closed with the message instance as the parameter\n */\n onClose: {\n type: definePropType<() => void>(Function),\n default: messageDefaults.onClose,\n },\n /**\n * @description whether to show a close button\n */\n showClose: {\n type: Boolean,\n default: messageDefaults.showClose,\n },\n /**\n * @description message type\n */\n type: {\n type: String,\n values: messageTypes,\n default: messageDefaults.type,\n },\n /**\n * @description whether message is plain\n */\n plain: {\n type: Boolean,\n default: messageDefaults.plain,\n },\n /**\n * @description set the distance to the top of viewport\n */\n offset: {\n type: Number,\n default: messageDefaults.offset,\n },\n /**\n * @description message placement position\n */\n placement: {\n type: String,\n values: messagePlacement,\n default: messageDefaults.placement,\n },\n /**\n * @description input box size\n */\n zIndex: {\n type: Number,\n default: messageDefaults.zIndex,\n },\n /**\n * @description merge messages with the same content, type of VNode message is not supported\n */\n grouping: {\n type: Boolean,\n default: messageDefaults.grouping,\n },\n /**\n * @description The number of repetitions, similar to badge, is used as the initial number when used with `grouping`\n */\n repeatNum: {\n type: Number,\n default: messageDefaults.repeatNum,\n },\n} as const)\nexport type MessageProps = ExtractPropTypes\nexport type MessagePropsPublic = __ExtractPublicPropTypes\n\nexport const messageEmits = {\n destroy: () => true,\n}\nexport type MessageEmits = typeof messageEmits\n\nexport type MessageInstance = InstanceType & unknown\n\nexport type MessageOptions = Partial<\n Mutable<\n Omit & {\n appendTo?: HTMLElement | string\n }\n >\n>\nexport type MessageParams = MessageOptions | MessageOptions['message']\nexport type MessageParamsNormalized = Omit & {\n /**\n * @description set the root element for the message, default to `document.body`\n */\n appendTo: HTMLElement\n}\nexport type MessageOptionsWithType = Omit\nexport type MessageParamsWithType =\n | MessageOptionsWithType\n | MessageOptions['message']\n\nexport interface MessageHandler {\n /**\n * @description close the Message\n */\n close: () => void\n}\n\nexport type MessageFn = {\n (options?: MessageParams, appContext?: null | AppContext): MessageHandler\n closeAll(type?: MessageType): void\n closeAllByPlacement(position: MessagePlacement): void\n}\nexport type MessageTypedFn = (\n options?: MessageParamsWithType,\n appContext?: null | AppContext\n) => MessageHandler\n\nexport type Message = MessageFn & {\n primary: MessageTypedFn\n success: MessageTypedFn\n warning: MessageTypedFn\n info: MessageTypedFn\n error: MessageTypedFn\n}\n","import { shallowReactive } from 'vue'\n\nimport type { ComponentInternalInstance, VNode } from 'vue'\nimport type { Mutable } from '@element-plus/utils'\nimport type { MessageHandler, MessagePlacement, MessageProps } from './message'\n\nexport type MessageContext = {\n id: string\n vnode: VNode\n handler: MessageHandler\n vm: ComponentInternalInstance\n props: Mutable\n}\n\nexport const placementInstances = shallowReactive(\n {} as Record\n)\n\nexport const getOrCreatePlacementInstances = (placement: MessagePlacement) => {\n if (!placementInstances[placement]) {\n placementInstances[placement] = shallowReactive([])\n }\n return placementInstances[placement]\n}\n\nexport const getInstance = (id: string, placement: MessagePlacement) => {\n const instances = placementInstances[placement] || []\n const idx = instances.findIndex((instance) => instance.id === id)\n const current = instances[idx]\n let prev: MessageContext | undefined\n if (idx > 0) {\n prev = instances[idx - 1]\n }\n return { current, prev }\n}\n\nexport const getLastOffset = (\n id: string,\n placement: MessagePlacement\n): number => {\n const { prev } = getInstance(id, placement)\n if (!prev) return 0\n return prev.vm.exposed!.bottom.value\n}\n\nexport const getOffsetOrSpace = (\n id: string,\n offset: number,\n placement: MessagePlacement\n) => {\n const instances = placementInstances[placement] || []\n const idx = instances.findIndex((instance) => instance.id === id)\n return idx > 0 ? 16 : offset\n}\n","\n\n\n","import { createVNode, isVNode, render } from 'vue'\nimport {\n debugWarn,\n hasOwn,\n isBoolean,\n isClient,\n isElement,\n isFunction,\n isNumber,\n isString,\n} from '@element-plus/utils'\nimport { messageConfig } from '@element-plus/components/config-provider'\nimport MessageConstructor from './message.vue'\nimport {\n MESSAGE_DEFAULT_PLACEMENT,\n messageDefaults,\n messagePlacement,\n messageTypes,\n} from './message'\nimport { getOrCreatePlacementInstances, placementInstances } from './instance'\n\nimport type { MessageContext } from './instance'\nimport type { AppContext } from 'vue'\nimport type {\n Message,\n MessageFn,\n MessageHandler,\n MessageOptions,\n MessageParams,\n MessageParamsNormalized,\n MessagePlacement,\n MessageType,\n} from './message'\n\nlet seed = 1\n\n// TODO: Since Notify.ts is basically the same like this file. So we could do some encapsulation against them to reduce code duplication.\n\nconst normalizeAppendTo = (normalized: MessageOptions) => {\n const appendTo = normalized.appendTo\n if (!appendTo) {\n normalized.appendTo = document.body\n } else if (isString(normalized.appendTo)) {\n let appendTo = document.querySelector(normalized.appendTo)\n\n // should fallback to default value with a warning\n if (!isElement(appendTo)) {\n debugWarn(\n 'ElMessage',\n 'the appendTo option is not an HTMLElement. Falling back to document.body.'\n )\n appendTo = document.body\n }\n normalized.appendTo = appendTo\n }\n}\n\nconst normalizePlacement = (normalized: MessageOptions) => {\n // if placement is not passed and global has config, use global config\n if (\n !normalized.placement &&\n isString(messageConfig.placement) &&\n messageConfig.placement\n ) {\n normalized.placement = messageConfig.placement as\n | MessagePlacement\n | undefined\n }\n // if placement is not passed and global has no config, use default config\n if (!normalized.placement) {\n normalized.placement = MESSAGE_DEFAULT_PLACEMENT\n }\n // if placement is not valid, use default config\n if (!messagePlacement.includes(normalized.placement!)) {\n debugWarn(\n 'ElMessage',\n `Invalid placement: ${normalized.placement}. Falling back to '${MESSAGE_DEFAULT_PLACEMENT}'.`\n )\n normalized.placement = MESSAGE_DEFAULT_PLACEMENT\n }\n}\n\nconst normalizeOptions = (params?: MessageParams) => {\n const options: MessageOptions =\n !params || isString(params) || isVNode(params) || isFunction(params)\n ? { message: params }\n : params\n\n const normalized: MessageOptions = {\n ...messageDefaults,\n ...options,\n }\n\n normalizeAppendTo(normalized)\n normalizePlacement(normalized)\n\n // When grouping is configured globally,\n // if grouping is manually set when calling message individually and it is not equal to the default value,\n // the global configuration cannot override the current setting. default => false\n if (isBoolean(messageConfig.grouping) && !normalized.grouping) {\n normalized.grouping = messageConfig.grouping\n }\n if (isNumber(messageConfig.duration) && normalized.duration === 3000) {\n normalized.duration = messageConfig.duration\n }\n if (isNumber(messageConfig.offset) && normalized.offset === 16) {\n normalized.offset = messageConfig.offset\n }\n if (isBoolean(messageConfig.showClose) && !normalized.showClose) {\n normalized.showClose = messageConfig.showClose\n }\n if (isBoolean(messageConfig.plain) && !normalized.plain) {\n normalized.plain = messageConfig.plain\n }\n\n return normalized as MessageParamsNormalized\n}\n\nconst closeMessage = (instance: MessageContext) => {\n const placement = instance.props.placement || MESSAGE_DEFAULT_PLACEMENT\n const instances = placementInstances[placement]\n\n const idx = instances.indexOf(instance)\n if (idx === -1) return\n instances.splice(idx, 1)\n const { handler } = instance\n handler.close()\n}\n\nconst createMessage = (\n { appendTo, ...options }: MessageParamsNormalized,\n context?: AppContext | null\n): MessageContext => {\n const id = `message_${seed++}`\n const userOnClose = options.onClose\n\n const container = document.createElement('div')\n\n const props = {\n ...options,\n // now the zIndex will be used inside the message.vue component instead of here.\n // zIndex: nextIndex() + options.zIndex\n id,\n onClose: () => {\n userOnClose?.()\n closeMessage(instance)\n },\n\n // clean message element preventing mem leak\n onDestroy: () => {\n // since the element is destroy, then the VNode should be collected by GC as well\n // we do not want cause any mem leak because we have returned vm as a reference to users\n // so that we manually set it to false.\n render(null, container)\n },\n }\n const vnode = createVNode(\n MessageConstructor,\n props,\n isFunction(props.message) || isVNode(props.message)\n ? {\n default: isFunction(props.message)\n ? props.message\n : () => props.message,\n }\n : null\n )\n vnode.appContext = context || message._context\n\n render(vnode, container)\n // instances will remove this item when close function gets called. So we do not need to worry about it.\n appendTo.appendChild(container.firstElementChild!)\n\n const vm = vnode.component!\n\n const handler: MessageHandler = {\n // instead of calling the onClose function directly, setting this value so that we can have the full lifecycle\n // for out component, so that all closing steps will not be skipped.\n close: () => {\n vm.exposed!.close()\n },\n }\n\n const instance: MessageContext = {\n id,\n vnode,\n vm,\n handler,\n props: (vnode.component as any).props,\n }\n\n return instance\n}\n\nconst message: MessageFn &\n Partial & { _context: AppContext | null } = (\n options = {},\n context\n) => {\n if (!isClient) return { close: () => undefined }\n\n const normalized = normalizeOptions(options)\n const instances = getOrCreatePlacementInstances(\n normalized.placement || MESSAGE_DEFAULT_PLACEMENT\n )\n\n if (normalized.grouping && instances.length) {\n const instance = instances.find(\n ({ vnode: vm }) => vm.props?.message === normalized.message\n )\n if (instance) {\n instance.props.repeatNum += 1\n instance.props.type = normalized.type\n return instance.handler\n }\n }\n\n if (isNumber(messageConfig.max) && instances.length >= messageConfig.max) {\n return { close: () => undefined }\n }\n\n const instance = createMessage(normalized, context)\n\n instances.push(instance)\n return instance.handler\n}\n\nmessageTypes.forEach((type) => {\n message[type] = (options = {}, appContext) => {\n const normalized = normalizeOptions(options)\n return message({ ...normalized, type }, appContext)\n }\n})\n\nexport function closeAll(type?: MessageType): void {\n for (const placement in placementInstances) {\n if (hasOwn(placementInstances, placement)) {\n // Create a copy of instances to avoid modification during iteration\n const instances: MessageContext[] = [...placementInstances[placement]]\n for (const instance of instances) {\n if (!type || type === instance.props.type) {\n instance.handler.close()\n }\n }\n }\n }\n}\n\nexport function closeAllByPlacement(placement: MessagePlacement) {\n if (!placementInstances[placement]) return\n // Create a copy of instances to avoid modification during iteration\n const instances = [...placementInstances[placement]]\n instances.forEach((instance) => instance.handler.close())\n}\n\nmessage.closeAll = closeAll\nmessage.closeAllByPlacement = closeAllByPlacement\nmessage._context = null\n\nexport default message as Message\n","import { withInstallFunction } from '@element-plus/utils'\nimport Message from './src/method'\n\nexport const ElMessage = withInstallFunction(Message, '$message')\nexport default ElMessage\n\nexport * from './src/message'\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\n// runtime helper for setting properties on components\n// in a tree-shakable way\nexports.default = (sfc, props) => {\n const target = sfc.__vccOpts || sfc;\n for (const [key, val] of props) {\n target[key] = val;\n }\n return target;\n};\n","import isObject from './isObject.js';\n\n/** Built-in value references. */\nvar objectCreate = Object.create;\n\n/**\n * The base implementation of `_.create` without support for assigning\n * properties to the created object.\n *\n * @private\n * @param {Object} proto The object to inherit from.\n * @returns {Object} Returns the new object.\n */\nvar baseCreate = (function() {\n function object() {}\n return function(proto) {\n if (!isObject(proto)) {\n return {};\n }\n if (objectCreate) {\n return objectCreate(proto);\n }\n object.prototype = proto;\n var result = new object;\n object.prototype = undefined;\n return result;\n };\n}());\n\nexport default baseCreate;\n","import baseCreate from './_baseCreate.js';\nimport getPrototype from './_getPrototype.js';\nimport isPrototype from './_isPrototype.js';\n\n/**\n * Initializes an object clone.\n *\n * @private\n * @param {Object} object The object to clone.\n * @returns {Object} Returns the initialized clone.\n */\nfunction initCloneObject(object) {\n return (typeof object.constructor == 'function' && !isPrototype(object))\n ? baseCreate(getPrototype(object))\n : {};\n}\n\nexport default initCloneObject;\n","'use strict';\nvar trunc = require('../internals/math-trunc');\n\n// `ToIntegerOrInfinity` abstract operation\n// https://tc39.es/ecma262/#sec-tointegerorinfinity\nmodule.exports = function (argument) {\n var number = +argument;\n // eslint-disable-next-line no-self-compare -- NaN check\n return number !== number || number === 0 ? 0 : trunc(number);\n};\n","import { getCurrentInstance, inject, unref } from 'vue'\nimport { computedEager } from '@vueuse/core'\nimport { debugWarn, isClient } from '@element-plus/utils'\nimport { useGetDerivedNamespace } from '../use-namespace'\n\nimport type { MaybeRef } from '@vueuse/core'\nimport type { InjectionKey, Ref } from 'vue'\n\nexport type ElIdInjectionContext = {\n prefix: number\n current: number\n}\n\nconst defaultIdInjection = {\n prefix: Math.floor(Math.random() * 10000),\n current: 0,\n}\n\nexport const ID_INJECTION_KEY: InjectionKey =\n Symbol('elIdInjection')\n\nexport const useIdInjection = (): ElIdInjectionContext => {\n return getCurrentInstance()\n ? inject(ID_INJECTION_KEY, defaultIdInjection)\n : defaultIdInjection\n}\n\nexport const useId = (deterministicId?: MaybeRef): Ref => {\n const idInjection = useIdInjection()\n if (!isClient && idInjection === defaultIdInjection) {\n debugWarn(\n 'IdInjection',\n `Looks like you are using server rendering, you must provide a id provider to ensure the hydration process to be succeed\nusage: app.provide(ID_INJECTION_KEY, {\n prefix: number,\n current: number,\n})`\n )\n }\n\n const namespace = useGetDerivedNamespace()\n\n // NOTE: Here we use `computedEager` to calculate the id value immediately, avoiding inconsistent id generation due to the lazy feature of `computed` when server rendering.\n const idRef = computedEager(\n () =>\n unref(deterministicId) ||\n `${namespace.value}-id-${idInjection.prefix}-${idInjection.current++}`\n )\n\n return idRef\n}\n","'use strict';\nvar iteratorClose = require('../internals/iterator-close');\n\nmodule.exports = function (iters, kind, value) {\n for (var i = iters.length - 1; i >= 0; i--) {\n if (iters[i] === undefined) continue;\n try {\n value = iteratorClose(iters[i].iterator, kind, value);\n } catch (error) {\n kind = 'throw';\n value = error;\n }\n }\n if (kind === 'throw') throw value;\n return value;\n};\n","import { isNil } from 'lodash-unified'\nimport { useAriaProps, useSizeProp } from '@element-plus/hooks'\nimport { buildProps, definePropType, isNumber } from '@element-plus/utils'\nimport {\n CHANGE_EVENT,\n INPUT_EVENT,\n UPDATE_MODEL_EVENT,\n} from '@element-plus/constants'\n\nimport type {\n ExtractPropTypes,\n HTMLAttributes,\n __ExtractPublicPropTypes,\n} from 'vue'\nimport type InputNumber from './input-number.vue'\n\nexport const inputNumberProps = buildProps({\n /**\n * @description same as `id` in native input\n */\n id: {\n type: String,\n default: undefined,\n },\n /**\n * @description incremental step\n */\n step: {\n type: Number,\n default: 1,\n },\n /**\n * @description whether input value can only be multiple of step\n */\n stepStrictly: Boolean,\n /**\n * @description the maximum allowed value\n */\n max: {\n type: Number,\n default: Number.MAX_SAFE_INTEGER,\n },\n /**\n * @description the minimum allowed value\n */\n min: {\n type: Number,\n default: Number.MIN_SAFE_INTEGER,\n },\n /**\n * @description binding value\n */\n modelValue: {\n type: [Number, null],\n },\n /**\n * @description same as `readonly` in native input\n */\n readonly: Boolean,\n /**\n * @description whether the component is disabled\n */\n disabled: {\n type: Boolean,\n default: undefined,\n },\n /**\n * @description size of the component\n */\n size: useSizeProp,\n /**\n * @description whether to enable the control buttons\n */\n controls: {\n type: Boolean,\n default: true,\n },\n /**\n * @description position of the control buttons\n */\n controlsPosition: {\n type: String,\n default: '',\n values: ['', 'right'],\n },\n /**\n * @description value should be set when input box is cleared\n */\n valueOnClear: {\n type: [String, Number, null],\n validator: (val: 'min' | 'max' | number | null) =>\n val === null || isNumber(val) || ['min', 'max'].includes(val),\n default: null,\n },\n /**\n * @description same as `name` in native input\n */\n name: String,\n /**\n * @description same as `placeholder` in native input\n */\n placeholder: String,\n /**\n * @description precision of input value\n */\n precision: {\n type: Number,\n validator: (val: number) =>\n val >= 0 && val === Number.parseInt(`${val}`, 10),\n },\n /**\n * @description whether to trigger form validation\n */\n validateEvent: {\n type: Boolean,\n default: true,\n },\n ...useAriaProps(['ariaLabel']),\n /**\n * @description native input mode for virtual keyboards\n */\n inputmode: {\n type: definePropType(String),\n default: undefined,\n },\n /**\n * @description alignment for the inner input text\n */\n align: {\n type: definePropType<'left' | 'right' | 'center'>(String),\n default: 'center',\n },\n /**\n * @description whether to disable scientific notation input (e.g. 'e', 'E')\n */\n disabledScientific: Boolean,\n} as const)\nexport type InputNumberProps = ExtractPropTypes\nexport type InputNumberPropsPublic = __ExtractPublicPropTypes<\n typeof inputNumberProps\n>\n\nexport const inputNumberEmits = {\n [CHANGE_EVENT]: (cur: number | undefined, prev: number | undefined) =>\n prev !== cur,\n blur: (e: FocusEvent) => e instanceof FocusEvent,\n focus: (e: FocusEvent) => e instanceof FocusEvent,\n [INPUT_EVENT]: (val: number | null | undefined) =>\n isNumber(val) || isNil(val),\n [UPDATE_MODEL_EVENT]: (val: number | undefined) =>\n isNumber(val) || isNil(val),\n}\nexport type InputNumberEmits = typeof inputNumberEmits\n\nexport type InputNumberInstance = InstanceType & unknown\n","\n\n\n","import { withInstall } from '@element-plus/utils'\nimport InputNumber from './src/input-number.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElInputNumber: SFCWithInstall =\n withInstall(InputNumber)\n\nexport default ElInputNumber\nexport * from './src/input-number'\n","/**\n * Take input from [0, n] and return it as [0, 1]\n * @hidden\n */\nexport function bound01(n, max) {\n if (isOnePointZero(n)) {\n n = '100%';\n }\n var isPercent = isPercentage(n);\n n = max === 360 ? n : Math.min(max, Math.max(0, parseFloat(n)));\n // Automatically convert percentage into number\n if (isPercent) {\n n = parseInt(String(n * max), 10) / 100;\n }\n // Handle floating point rounding errors\n if (Math.abs(n - max) < 0.000001) {\n return 1;\n }\n // Convert into [0, 1] range if it isn't already\n if (max === 360) {\n // If n is a hue given in degrees,\n // wrap around out-of-range values into [0, 360] range\n // then convert into [0, 1].\n n = (n < 0 ? (n % max) + max : n % max) / parseFloat(String(max));\n }\n else {\n // If n not a hue given in degrees\n // Convert into [0, 1] range if it isn't already.\n n = (n % max) / parseFloat(String(max));\n }\n return n;\n}\n/**\n * Force a number between 0 and 1\n * @hidden\n */\nexport function clamp01(val) {\n return Math.min(1, Math.max(0, val));\n}\n/**\n * Need to handle 1.0 as 100%, since once it is a number, there is no difference between it and 1\n * \n * @hidden\n */\nexport function isOnePointZero(n) {\n return typeof n === 'string' && n.indexOf('.') !== -1 && parseFloat(n) === 1;\n}\n/**\n * Check to see if string passed in is a percentage\n * @hidden\n */\nexport function isPercentage(n) {\n return typeof n === 'string' && n.indexOf('%') !== -1;\n}\n/**\n * Return a valid alpha value [0,1] with all invalid values being set to 1\n * @hidden\n */\nexport function boundAlpha(a) {\n a = parseFloat(a);\n if (isNaN(a) || a < 0 || a > 1) {\n a = 1;\n }\n return a;\n}\n/**\n * Replace a decimal with it's percentage value\n * @hidden\n */\nexport function convertToPercentage(n) {\n if (n <= 1) {\n return \"\".concat(Number(n) * 100, \"%\");\n }\n return n;\n}\n/**\n * Force a hex value to have 2 characters\n * @hidden\n */\nexport function pad2(c) {\n return c.length === 1 ? '0' + c : String(c);\n}\n","import { bound01, pad2 } from './util.js';\n// `rgbToHsl`, `rgbToHsv`, `hslToRgb`, `hsvToRgb` modified from:\n// \n/**\n * Handle bounds / percentage checking to conform to CSS color spec\n * \n * *Assumes:* r, g, b in [0, 255] or [0, 1]\n * *Returns:* { r, g, b } in [0, 255]\n */\nexport function rgbToRgb(r, g, b) {\n return {\n r: bound01(r, 255) * 255,\n g: bound01(g, 255) * 255,\n b: bound01(b, 255) * 255,\n };\n}\n/**\n * Converts an RGB color value to HSL.\n * *Assumes:* r, g, and b are contained in [0, 255] or [0, 1]\n * *Returns:* { h, s, l } in [0,1]\n */\nexport function rgbToHsl(r, g, b) {\n r = bound01(r, 255);\n g = bound01(g, 255);\n b = bound01(b, 255);\n var max = Math.max(r, g, b);\n var min = Math.min(r, g, b);\n var h = 0;\n var s = 0;\n var l = (max + min) / 2;\n if (max === min) {\n s = 0;\n h = 0; // achromatic\n }\n else {\n var d = max - min;\n s = l > 0.5 ? d / (2 - max - min) : d / (max + min);\n switch (max) {\n case r:\n h = (g - b) / d + (g < b ? 6 : 0);\n break;\n case g:\n h = (b - r) / d + 2;\n break;\n case b:\n h = (r - g) / d + 4;\n break;\n default:\n break;\n }\n h /= 6;\n }\n return { h: h, s: s, l: l };\n}\nfunction hue2rgb(p, q, t) {\n if (t < 0) {\n t += 1;\n }\n if (t > 1) {\n t -= 1;\n }\n if (t < 1 / 6) {\n return p + (q - p) * (6 * t);\n }\n if (t < 1 / 2) {\n return q;\n }\n if (t < 2 / 3) {\n return p + (q - p) * (2 / 3 - t) * 6;\n }\n return p;\n}\n/**\n * Converts an HSL color value to RGB.\n *\n * *Assumes:* h is contained in [0, 1] or [0, 360] and s and l are contained [0, 1] or [0, 100]\n * *Returns:* { r, g, b } in the set [0, 255]\n */\nexport function hslToRgb(h, s, l) {\n var r;\n var g;\n var b;\n h = bound01(h, 360);\n s = bound01(s, 100);\n l = bound01(l, 100);\n if (s === 0) {\n // achromatic\n g = l;\n b = l;\n r = l;\n }\n else {\n var q = l < 0.5 ? l * (1 + s) : l + s - l * s;\n var p = 2 * l - q;\n r = hue2rgb(p, q, h + 1 / 3);\n g = hue2rgb(p, q, h);\n b = hue2rgb(p, q, h - 1 / 3);\n }\n return { r: r * 255, g: g * 255, b: b * 255 };\n}\n/**\n * Converts an RGB color value to HSV\n *\n * *Assumes:* r, g, and b are contained in the set [0, 255] or [0, 1]\n * *Returns:* { h, s, v } in [0,1]\n */\nexport function rgbToHsv(r, g, b) {\n r = bound01(r, 255);\n g = bound01(g, 255);\n b = bound01(b, 255);\n var max = Math.max(r, g, b);\n var min = Math.min(r, g, b);\n var h = 0;\n var v = max;\n var d = max - min;\n var s = max === 0 ? 0 : d / max;\n if (max === min) {\n h = 0; // achromatic\n }\n else {\n switch (max) {\n case r:\n h = (g - b) / d + (g < b ? 6 : 0);\n break;\n case g:\n h = (b - r) / d + 2;\n break;\n case b:\n h = (r - g) / d + 4;\n break;\n default:\n break;\n }\n h /= 6;\n }\n return { h: h, s: s, v: v };\n}\n/**\n * Converts an HSV color value to RGB.\n *\n * *Assumes:* h is contained in [0, 1] or [0, 360] and s and v are contained in [0, 1] or [0, 100]\n * *Returns:* { r, g, b } in the set [0, 255]\n */\nexport function hsvToRgb(h, s, v) {\n h = bound01(h, 360) * 6;\n s = bound01(s, 100);\n v = bound01(v, 100);\n var i = Math.floor(h);\n var f = h - i;\n var p = v * (1 - s);\n var q = v * (1 - f * s);\n var t = v * (1 - (1 - f) * s);\n var mod = i % 6;\n var r = [v, q, p, p, t, v][mod];\n var g = [t, v, v, q, p, p][mod];\n var b = [p, p, t, v, v, q][mod];\n return { r: r * 255, g: g * 255, b: b * 255 };\n}\n/**\n * Converts an RGB color to hex\n *\n * Assumes r, g, and b are contained in the set [0, 255]\n * Returns a 3 or 6 character hex\n */\nexport function rgbToHex(r, g, b, allow3Char) {\n var hex = [\n pad2(Math.round(r).toString(16)),\n pad2(Math.round(g).toString(16)),\n pad2(Math.round(b).toString(16)),\n ];\n // Return a 3 character hex if possible\n if (allow3Char &&\n hex[0].startsWith(hex[0].charAt(1)) &&\n hex[1].startsWith(hex[1].charAt(1)) &&\n hex[2].startsWith(hex[2].charAt(1))) {\n return hex[0].charAt(0) + hex[1].charAt(0) + hex[2].charAt(0);\n }\n return hex.join('');\n}\n/**\n * Converts an RGBA color plus alpha transparency to hex\n *\n * Assumes r, g, b are contained in the set [0, 255] and\n * a in [0, 1]. Returns a 4 or 8 character rgba hex\n */\n// eslint-disable-next-line max-params\nexport function rgbaToHex(r, g, b, a, allow4Char) {\n var hex = [\n pad2(Math.round(r).toString(16)),\n pad2(Math.round(g).toString(16)),\n pad2(Math.round(b).toString(16)),\n pad2(convertDecimalToHex(a)),\n ];\n // Return a 4 character hex if possible\n if (allow4Char &&\n hex[0].startsWith(hex[0].charAt(1)) &&\n hex[1].startsWith(hex[1].charAt(1)) &&\n hex[2].startsWith(hex[2].charAt(1)) &&\n hex[3].startsWith(hex[3].charAt(1))) {\n return hex[0].charAt(0) + hex[1].charAt(0) + hex[2].charAt(0) + hex[3].charAt(0);\n }\n return hex.join('');\n}\n/**\n * Converts an RGBA color to an ARGB Hex8 string\n * Rarely used, but required for \"toFilter()\"\n */\nexport function rgbaToArgbHex(r, g, b, a) {\n var hex = [\n pad2(convertDecimalToHex(a)),\n pad2(Math.round(r).toString(16)),\n pad2(Math.round(g).toString(16)),\n pad2(Math.round(b).toString(16)),\n ];\n return hex.join('');\n}\n/** Converts a decimal to a hex value */\nexport function convertDecimalToHex(d) {\n return Math.round(parseFloat(d) * 255).toString(16);\n}\n/** Converts a hex value to a decimal */\nexport function convertHexToDecimal(h) {\n return parseIntFromHex(h) / 255;\n}\n/** Parse a base-16 hex value into a base-10 integer */\nexport function parseIntFromHex(val) {\n return parseInt(val, 16);\n}\nexport function numberInputToObject(color) {\n return {\n r: color >> 16,\n g: (color & 0xff00) >> 8,\n b: color & 0xff,\n };\n}\n","// https://github.com/bahamas10/css-color-names/blob/master/css-color-names.json\n/**\n * @hidden\n */\nexport var names = {\n aliceblue: '#f0f8ff',\n antiquewhite: '#faebd7',\n aqua: '#00ffff',\n aquamarine: '#7fffd4',\n azure: '#f0ffff',\n beige: '#f5f5dc',\n bisque: '#ffe4c4',\n black: '#000000',\n blanchedalmond: '#ffebcd',\n blue: '#0000ff',\n blueviolet: '#8a2be2',\n brown: '#a52a2a',\n burlywood: '#deb887',\n cadetblue: '#5f9ea0',\n chartreuse: '#7fff00',\n chocolate: '#d2691e',\n coral: '#ff7f50',\n cornflowerblue: '#6495ed',\n cornsilk: '#fff8dc',\n crimson: '#dc143c',\n cyan: '#00ffff',\n darkblue: '#00008b',\n darkcyan: '#008b8b',\n darkgoldenrod: '#b8860b',\n darkgray: '#a9a9a9',\n darkgreen: '#006400',\n darkgrey: '#a9a9a9',\n darkkhaki: '#bdb76b',\n darkmagenta: '#8b008b',\n darkolivegreen: '#556b2f',\n darkorange: '#ff8c00',\n darkorchid: '#9932cc',\n darkred: '#8b0000',\n darksalmon: '#e9967a',\n darkseagreen: '#8fbc8f',\n darkslateblue: '#483d8b',\n darkslategray: '#2f4f4f',\n darkslategrey: '#2f4f4f',\n darkturquoise: '#00ced1',\n darkviolet: '#9400d3',\n deeppink: '#ff1493',\n deepskyblue: '#00bfff',\n dimgray: '#696969',\n dimgrey: '#696969',\n dodgerblue: '#1e90ff',\n firebrick: '#b22222',\n floralwhite: '#fffaf0',\n forestgreen: '#228b22',\n fuchsia: '#ff00ff',\n gainsboro: '#dcdcdc',\n ghostwhite: '#f8f8ff',\n goldenrod: '#daa520',\n gold: '#ffd700',\n gray: '#808080',\n green: '#008000',\n greenyellow: '#adff2f',\n grey: '#808080',\n honeydew: '#f0fff0',\n hotpink: '#ff69b4',\n indianred: '#cd5c5c',\n indigo: '#4b0082',\n ivory: '#fffff0',\n khaki: '#f0e68c',\n lavenderblush: '#fff0f5',\n lavender: '#e6e6fa',\n lawngreen: '#7cfc00',\n lemonchiffon: '#fffacd',\n lightblue: '#add8e6',\n lightcoral: '#f08080',\n lightcyan: '#e0ffff',\n lightgoldenrodyellow: '#fafad2',\n lightgray: '#d3d3d3',\n lightgreen: '#90ee90',\n lightgrey: '#d3d3d3',\n lightpink: '#ffb6c1',\n lightsalmon: '#ffa07a',\n lightseagreen: '#20b2aa',\n lightskyblue: '#87cefa',\n lightslategray: '#778899',\n lightslategrey: '#778899',\n lightsteelblue: '#b0c4de',\n lightyellow: '#ffffe0',\n lime: '#00ff00',\n limegreen: '#32cd32',\n linen: '#faf0e6',\n magenta: '#ff00ff',\n maroon: '#800000',\n mediumaquamarine: '#66cdaa',\n mediumblue: '#0000cd',\n mediumorchid: '#ba55d3',\n mediumpurple: '#9370db',\n mediumseagreen: '#3cb371',\n mediumslateblue: '#7b68ee',\n mediumspringgreen: '#00fa9a',\n mediumturquoise: '#48d1cc',\n mediumvioletred: '#c71585',\n midnightblue: '#191970',\n mintcream: '#f5fffa',\n mistyrose: '#ffe4e1',\n moccasin: '#ffe4b5',\n navajowhite: '#ffdead',\n navy: '#000080',\n oldlace: '#fdf5e6',\n olive: '#808000',\n olivedrab: '#6b8e23',\n orange: '#ffa500',\n orangered: '#ff4500',\n orchid: '#da70d6',\n palegoldenrod: '#eee8aa',\n palegreen: '#98fb98',\n paleturquoise: '#afeeee',\n palevioletred: '#db7093',\n papayawhip: '#ffefd5',\n peachpuff: '#ffdab9',\n peru: '#cd853f',\n pink: '#ffc0cb',\n plum: '#dda0dd',\n powderblue: '#b0e0e6',\n purple: '#800080',\n rebeccapurple: '#663399',\n red: '#ff0000',\n rosybrown: '#bc8f8f',\n royalblue: '#4169e1',\n saddlebrown: '#8b4513',\n salmon: '#fa8072',\n sandybrown: '#f4a460',\n seagreen: '#2e8b57',\n seashell: '#fff5ee',\n sienna: '#a0522d',\n silver: '#c0c0c0',\n skyblue: '#87ceeb',\n slateblue: '#6a5acd',\n slategray: '#708090',\n slategrey: '#708090',\n snow: '#fffafa',\n springgreen: '#00ff7f',\n steelblue: '#4682b4',\n tan: '#d2b48c',\n teal: '#008080',\n thistle: '#d8bfd8',\n tomato: '#ff6347',\n turquoise: '#40e0d0',\n violet: '#ee82ee',\n wheat: '#f5deb3',\n white: '#ffffff',\n whitesmoke: '#f5f5f5',\n yellow: '#ffff00',\n yellowgreen: '#9acd32',\n};\n","/* eslint-disable @typescript-eslint/no-redundant-type-constituents */\nimport { convertHexToDecimal, hslToRgb, hsvToRgb, parseIntFromHex, rgbToRgb, } from './conversion.js';\nimport { names } from './css-color-names.js';\nimport { boundAlpha, convertToPercentage } from './util.js';\n/**\n * Given a string or object, convert that input to RGB\n *\n * Possible string inputs:\n * ```\n * \"red\"\n * \"#f00\" or \"f00\"\n * \"#ff0000\" or \"ff0000\"\n * \"#ff000000\" or \"ff000000\"\n * \"rgb 255 0 0\" or \"rgb (255, 0, 0)\"\n * \"rgb 1.0 0 0\" or \"rgb (1, 0, 0)\"\n * \"rgba (255, 0, 0, 1)\" or \"rgba 255, 0, 0, 1\"\n * \"rgba (1.0, 0, 0, 1)\" or \"rgba 1.0, 0, 0, 1\"\n * \"hsl(0, 100%, 50%)\" or \"hsl 0 100% 50%\"\n * \"hsla(0, 100%, 50%, 1)\" or \"hsla 0 100% 50%, 1\"\n * \"hsv(0, 100%, 100%)\" or \"hsv 0 100% 100%\"\n * ```\n */\nexport function inputToRGB(color) {\n var rgb = { r: 0, g: 0, b: 0 };\n var a = 1;\n var s = null;\n var v = null;\n var l = null;\n var ok = false;\n var format = false;\n if (typeof color === 'string') {\n color = stringInputToObject(color);\n }\n if (typeof color === 'object') {\n if (isValidCSSUnit(color.r) && isValidCSSUnit(color.g) && isValidCSSUnit(color.b)) {\n rgb = rgbToRgb(color.r, color.g, color.b);\n ok = true;\n format = String(color.r).substr(-1) === '%' ? 'prgb' : 'rgb';\n }\n else if (isValidCSSUnit(color.h) && isValidCSSUnit(color.s) && isValidCSSUnit(color.v)) {\n s = convertToPercentage(color.s);\n v = convertToPercentage(color.v);\n rgb = hsvToRgb(color.h, s, v);\n ok = true;\n format = 'hsv';\n }\n else if (isValidCSSUnit(color.h) && isValidCSSUnit(color.s) && isValidCSSUnit(color.l)) {\n s = convertToPercentage(color.s);\n l = convertToPercentage(color.l);\n rgb = hslToRgb(color.h, s, l);\n ok = true;\n format = 'hsl';\n }\n if (Object.prototype.hasOwnProperty.call(color, 'a')) {\n a = color.a;\n }\n }\n a = boundAlpha(a);\n return {\n ok: ok,\n format: color.format || format,\n r: Math.min(255, Math.max(rgb.r, 0)),\n g: Math.min(255, Math.max(rgb.g, 0)),\n b: Math.min(255, Math.max(rgb.b, 0)),\n a: a,\n };\n}\n// \nvar CSS_INTEGER = '[-\\\\+]?\\\\d+%?';\n// \nvar CSS_NUMBER = '[-\\\\+]?\\\\d*\\\\.\\\\d+%?';\n// Allow positive/negative integer/number. Don't capture the either/or, just the entire outcome.\nvar CSS_UNIT = \"(?:\".concat(CSS_NUMBER, \")|(?:\").concat(CSS_INTEGER, \")\");\n// Actual matching.\n// Parentheses and commas are optional, but not required.\n// Whitespace can take the place of commas or opening paren\nvar PERMISSIVE_MATCH3 = \"[\\\\s|\\\\(]+(\".concat(CSS_UNIT, \")[,|\\\\s]+(\").concat(CSS_UNIT, \")[,|\\\\s]+(\").concat(CSS_UNIT, \")\\\\s*\\\\)?\");\nvar PERMISSIVE_MATCH4 = \"[\\\\s|\\\\(]+(\".concat(CSS_UNIT, \")[,|\\\\s]+(\").concat(CSS_UNIT, \")[,|\\\\s]+(\").concat(CSS_UNIT, \")[,|\\\\s]+(\").concat(CSS_UNIT, \")\\\\s*\\\\)?\");\nvar matchers = {\n CSS_UNIT: new RegExp(CSS_UNIT),\n rgb: new RegExp('rgb' + PERMISSIVE_MATCH3),\n rgba: new RegExp('rgba' + PERMISSIVE_MATCH4),\n hsl: new RegExp('hsl' + PERMISSIVE_MATCH3),\n hsla: new RegExp('hsla' + PERMISSIVE_MATCH4),\n hsv: new RegExp('hsv' + PERMISSIVE_MATCH3),\n hsva: new RegExp('hsva' + PERMISSIVE_MATCH4),\n hex3: /^#?([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,\n hex6: /^#?([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/,\n hex4: /^#?([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,\n hex8: /^#?([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/,\n};\n/**\n * Permissive string parsing. Take in a number of formats, and output an object\n * based on detected format. Returns `{ r, g, b }` or `{ h, s, l }` or `{ h, s, v}`\n */\nexport function stringInputToObject(color) {\n color = color.trim().toLowerCase();\n if (color.length === 0) {\n return false;\n }\n var named = false;\n if (names[color]) {\n color = names[color];\n named = true;\n }\n else if (color === 'transparent') {\n return { r: 0, g: 0, b: 0, a: 0, format: 'name' };\n }\n // Try to match string input using regular expressions.\n // Keep most of the number bounding out of this function - don't worry about [0,1] or [0,100] or [0,360]\n // Just return an object and let the conversion functions handle that.\n // This way the result will be the same whether the tinycolor is initialized with string or object.\n var match = matchers.rgb.exec(color);\n if (match) {\n return { r: match[1], g: match[2], b: match[3] };\n }\n match = matchers.rgba.exec(color);\n if (match) {\n return { r: match[1], g: match[2], b: match[3], a: match[4] };\n }\n match = matchers.hsl.exec(color);\n if (match) {\n return { h: match[1], s: match[2], l: match[3] };\n }\n match = matchers.hsla.exec(color);\n if (match) {\n return { h: match[1], s: match[2], l: match[3], a: match[4] };\n }\n match = matchers.hsv.exec(color);\n if (match) {\n return { h: match[1], s: match[2], v: match[3] };\n }\n match = matchers.hsva.exec(color);\n if (match) {\n return { h: match[1], s: match[2], v: match[3], a: match[4] };\n }\n match = matchers.hex8.exec(color);\n if (match) {\n return {\n r: parseIntFromHex(match[1]),\n g: parseIntFromHex(match[2]),\n b: parseIntFromHex(match[3]),\n a: convertHexToDecimal(match[4]),\n format: named ? 'name' : 'hex8',\n };\n }\n match = matchers.hex6.exec(color);\n if (match) {\n return {\n r: parseIntFromHex(match[1]),\n g: parseIntFromHex(match[2]),\n b: parseIntFromHex(match[3]),\n format: named ? 'name' : 'hex',\n };\n }\n match = matchers.hex4.exec(color);\n if (match) {\n return {\n r: parseIntFromHex(match[1] + match[1]),\n g: parseIntFromHex(match[2] + match[2]),\n b: parseIntFromHex(match[3] + match[3]),\n a: convertHexToDecimal(match[4] + match[4]),\n format: named ? 'name' : 'hex8',\n };\n }\n match = matchers.hex3.exec(color);\n if (match) {\n return {\n r: parseIntFromHex(match[1] + match[1]),\n g: parseIntFromHex(match[2] + match[2]),\n b: parseIntFromHex(match[3] + match[3]),\n format: named ? 'name' : 'hex',\n };\n }\n return false;\n}\n/**\n * Check to see if it looks like a CSS unit\n * (see `matchers` above for definition).\n */\nexport function isValidCSSUnit(color) {\n return Boolean(matchers.CSS_UNIT.exec(String(color)));\n}\n","import { numberInputToObject, rgbaToHex, rgbToHex, rgbToHsl, rgbToHsv } from './conversion.js';\nimport { names } from './css-color-names.js';\nimport { inputToRGB } from './format-input';\nimport { bound01, boundAlpha, clamp01 } from './util.js';\nvar TinyColor = /** @class */ (function () {\n function TinyColor(color, opts) {\n if (color === void 0) { color = ''; }\n if (opts === void 0) { opts = {}; }\n var _a;\n // If input is already a tinycolor, return itself\n if (color instanceof TinyColor) {\n // eslint-disable-next-line no-constructor-return\n return color;\n }\n if (typeof color === 'number') {\n color = numberInputToObject(color);\n }\n this.originalInput = color;\n var rgb = inputToRGB(color);\n this.originalInput = color;\n this.r = rgb.r;\n this.g = rgb.g;\n this.b = rgb.b;\n this.a = rgb.a;\n this.roundA = Math.round(100 * this.a) / 100;\n this.format = (_a = opts.format) !== null && _a !== void 0 ? _a : rgb.format;\n this.gradientType = opts.gradientType;\n // Don't let the range of [0,255] come back in [0,1].\n // Potentially lose a little bit of precision here, but will fix issues where\n // .5 gets interpreted as half of the total, instead of half of 1\n // If it was supposed to be 128, this was already taken care of by `inputToRgb`\n if (this.r < 1) {\n this.r = Math.round(this.r);\n }\n if (this.g < 1) {\n this.g = Math.round(this.g);\n }\n if (this.b < 1) {\n this.b = Math.round(this.b);\n }\n this.isValid = rgb.ok;\n }\n TinyColor.prototype.isDark = function () {\n return this.getBrightness() < 128;\n };\n TinyColor.prototype.isLight = function () {\n return !this.isDark();\n };\n /**\n * Returns the perceived brightness of the color, from 0-255.\n */\n TinyColor.prototype.getBrightness = function () {\n // http://www.w3.org/TR/AERT#color-contrast\n var rgb = this.toRgb();\n return (rgb.r * 299 + rgb.g * 587 + rgb.b * 114) / 1000;\n };\n /**\n * Returns the perceived luminance of a color, from 0-1.\n */\n TinyColor.prototype.getLuminance = function () {\n // http://www.w3.org/TR/2008/REC-WCAG20-20081211/#relativeluminancedef\n var rgb = this.toRgb();\n var R;\n var G;\n var B;\n var RsRGB = rgb.r / 255;\n var GsRGB = rgb.g / 255;\n var BsRGB = rgb.b / 255;\n if (RsRGB <= 0.03928) {\n R = RsRGB / 12.92;\n }\n else {\n // eslint-disable-next-line prefer-exponentiation-operator\n R = Math.pow((RsRGB + 0.055) / 1.055, 2.4);\n }\n if (GsRGB <= 0.03928) {\n G = GsRGB / 12.92;\n }\n else {\n // eslint-disable-next-line prefer-exponentiation-operator\n G = Math.pow((GsRGB + 0.055) / 1.055, 2.4);\n }\n if (BsRGB <= 0.03928) {\n B = BsRGB / 12.92;\n }\n else {\n // eslint-disable-next-line prefer-exponentiation-operator\n B = Math.pow((BsRGB + 0.055) / 1.055, 2.4);\n }\n return 0.2126 * R + 0.7152 * G + 0.0722 * B;\n };\n /**\n * Returns the alpha value of a color, from 0-1.\n */\n TinyColor.prototype.getAlpha = function () {\n return this.a;\n };\n /**\n * Sets the alpha value on the current color.\n *\n * @param alpha - The new alpha value. The accepted range is 0-1.\n */\n TinyColor.prototype.setAlpha = function (alpha) {\n this.a = boundAlpha(alpha);\n this.roundA = Math.round(100 * this.a) / 100;\n return this;\n };\n /**\n * Returns whether the color is monochrome.\n */\n TinyColor.prototype.isMonochrome = function () {\n var s = this.toHsl().s;\n return s === 0;\n };\n /**\n * Returns the object as a HSVA object.\n */\n TinyColor.prototype.toHsv = function () {\n var hsv = rgbToHsv(this.r, this.g, this.b);\n return { h: hsv.h * 360, s: hsv.s, v: hsv.v, a: this.a };\n };\n /**\n * Returns the hsva values interpolated into a string with the following format:\n * \"hsva(xxx, xxx, xxx, xx)\".\n */\n TinyColor.prototype.toHsvString = function () {\n var hsv = rgbToHsv(this.r, this.g, this.b);\n var h = Math.round(hsv.h * 360);\n var s = Math.round(hsv.s * 100);\n var v = Math.round(hsv.v * 100);\n return this.a === 1 ? \"hsv(\".concat(h, \", \").concat(s, \"%, \").concat(v, \"%)\") : \"hsva(\".concat(h, \", \").concat(s, \"%, \").concat(v, \"%, \").concat(this.roundA, \")\");\n };\n /**\n * Returns the object as a HSLA object.\n */\n TinyColor.prototype.toHsl = function () {\n var hsl = rgbToHsl(this.r, this.g, this.b);\n return { h: hsl.h * 360, s: hsl.s, l: hsl.l, a: this.a };\n };\n /**\n * Returns the hsla values interpolated into a string with the following format:\n * \"hsla(xxx, xxx, xxx, xx)\".\n */\n TinyColor.prototype.toHslString = function () {\n var hsl = rgbToHsl(this.r, this.g, this.b);\n var h = Math.round(hsl.h * 360);\n var s = Math.round(hsl.s * 100);\n var l = Math.round(hsl.l * 100);\n return this.a === 1 ? \"hsl(\".concat(h, \", \").concat(s, \"%, \").concat(l, \"%)\") : \"hsla(\".concat(h, \", \").concat(s, \"%, \").concat(l, \"%, \").concat(this.roundA, \")\");\n };\n /**\n * Returns the hex value of the color.\n * @param allow3Char will shorten hex value to 3 char if possible\n */\n TinyColor.prototype.toHex = function (allow3Char) {\n if (allow3Char === void 0) { allow3Char = false; }\n return rgbToHex(this.r, this.g, this.b, allow3Char);\n };\n /**\n * Returns the hex value of the color -with a # prefixed.\n * @param allow3Char will shorten hex value to 3 char if possible\n */\n TinyColor.prototype.toHexString = function (allow3Char) {\n if (allow3Char === void 0) { allow3Char = false; }\n return '#' + this.toHex(allow3Char);\n };\n /**\n * Returns the hex 8 value of the color.\n * @param allow4Char will shorten hex value to 4 char if possible\n */\n TinyColor.prototype.toHex8 = function (allow4Char) {\n if (allow4Char === void 0) { allow4Char = false; }\n return rgbaToHex(this.r, this.g, this.b, this.a, allow4Char);\n };\n /**\n * Returns the hex 8 value of the color -with a # prefixed.\n * @param allow4Char will shorten hex value to 4 char if possible\n */\n TinyColor.prototype.toHex8String = function (allow4Char) {\n if (allow4Char === void 0) { allow4Char = false; }\n return '#' + this.toHex8(allow4Char);\n };\n /**\n * Returns the shorter hex value of the color depends on its alpha -with a # prefixed.\n * @param allowShortChar will shorten hex value to 3 or 4 char if possible\n */\n TinyColor.prototype.toHexShortString = function (allowShortChar) {\n if (allowShortChar === void 0) { allowShortChar = false; }\n return this.a === 1 ? this.toHexString(allowShortChar) : this.toHex8String(allowShortChar);\n };\n /**\n * Returns the object as a RGBA object.\n */\n TinyColor.prototype.toRgb = function () {\n return {\n r: Math.round(this.r),\n g: Math.round(this.g),\n b: Math.round(this.b),\n a: this.a,\n };\n };\n /**\n * Returns the RGBA values interpolated into a string with the following format:\n * \"RGBA(xxx, xxx, xxx, xx)\".\n */\n TinyColor.prototype.toRgbString = function () {\n var r = Math.round(this.r);\n var g = Math.round(this.g);\n var b = Math.round(this.b);\n return this.a === 1 ? \"rgb(\".concat(r, \", \").concat(g, \", \").concat(b, \")\") : \"rgba(\".concat(r, \", \").concat(g, \", \").concat(b, \", \").concat(this.roundA, \")\");\n };\n /**\n * Returns the object as a RGBA object.\n */\n TinyColor.prototype.toPercentageRgb = function () {\n var fmt = function (x) { return \"\".concat(Math.round(bound01(x, 255) * 100), \"%\"); };\n return {\n r: fmt(this.r),\n g: fmt(this.g),\n b: fmt(this.b),\n a: this.a,\n };\n };\n /**\n * Returns the RGBA relative values interpolated into a string\n */\n TinyColor.prototype.toPercentageRgbString = function () {\n var rnd = function (x) { return Math.round(bound01(x, 255) * 100); };\n return this.a === 1\n ? \"rgb(\".concat(rnd(this.r), \"%, \").concat(rnd(this.g), \"%, \").concat(rnd(this.b), \"%)\")\n : \"rgba(\".concat(rnd(this.r), \"%, \").concat(rnd(this.g), \"%, \").concat(rnd(this.b), \"%, \").concat(this.roundA, \")\");\n };\n /**\n * The 'real' name of the color -if there is one.\n */\n TinyColor.prototype.toName = function () {\n if (this.a === 0) {\n return 'transparent';\n }\n if (this.a < 1) {\n return false;\n }\n var hex = '#' + rgbToHex(this.r, this.g, this.b, false);\n for (var _i = 0, _a = Object.entries(names); _i < _a.length; _i++) {\n var _b = _a[_i], key = _b[0], value = _b[1];\n if (hex === value) {\n return key;\n }\n }\n return false;\n };\n TinyColor.prototype.toString = function (format) {\n var formatSet = Boolean(format);\n format = format !== null && format !== void 0 ? format : this.format;\n var formattedString = false;\n var hasAlpha = this.a < 1 && this.a >= 0;\n var needsAlphaFormat = !formatSet && hasAlpha && (format.startsWith('hex') || format === 'name');\n if (needsAlphaFormat) {\n // Special case for \"transparent\", all other non-alpha formats\n // will return rgba when there is transparency.\n if (format === 'name' && this.a === 0) {\n return this.toName();\n }\n return this.toRgbString();\n }\n if (format === 'rgb') {\n formattedString = this.toRgbString();\n }\n if (format === 'prgb') {\n formattedString = this.toPercentageRgbString();\n }\n if (format === 'hex' || format === 'hex6') {\n formattedString = this.toHexString();\n }\n if (format === 'hex3') {\n formattedString = this.toHexString(true);\n }\n if (format === 'hex4') {\n formattedString = this.toHex8String(true);\n }\n if (format === 'hex8') {\n formattedString = this.toHex8String();\n }\n if (format === 'name') {\n formattedString = this.toName();\n }\n if (format === 'hsl') {\n formattedString = this.toHslString();\n }\n if (format === 'hsv') {\n formattedString = this.toHsvString();\n }\n return formattedString || this.toHexString();\n };\n TinyColor.prototype.toNumber = function () {\n return (Math.round(this.r) << 16) + (Math.round(this.g) << 8) + Math.round(this.b);\n };\n TinyColor.prototype.clone = function () {\n return new TinyColor(this.toString());\n };\n /**\n * Lighten the color a given amount. Providing 100 will always return white.\n * @param amount - valid between 1-100\n */\n TinyColor.prototype.lighten = function (amount) {\n if (amount === void 0) { amount = 10; }\n var hsl = this.toHsl();\n hsl.l += amount / 100;\n hsl.l = clamp01(hsl.l);\n return new TinyColor(hsl);\n };\n /**\n * Brighten the color a given amount, from 0 to 100.\n * @param amount - valid between 1-100\n */\n TinyColor.prototype.brighten = function (amount) {\n if (amount === void 0) { amount = 10; }\n var rgb = this.toRgb();\n rgb.r = Math.max(0, Math.min(255, rgb.r - Math.round(255 * -(amount / 100))));\n rgb.g = Math.max(0, Math.min(255, rgb.g - Math.round(255 * -(amount / 100))));\n rgb.b = Math.max(0, Math.min(255, rgb.b - Math.round(255 * -(amount / 100))));\n return new TinyColor(rgb);\n };\n /**\n * Darken the color a given amount, from 0 to 100.\n * Providing 100 will always return black.\n * @param amount - valid between 1-100\n */\n TinyColor.prototype.darken = function (amount) {\n if (amount === void 0) { amount = 10; }\n var hsl = this.toHsl();\n hsl.l -= amount / 100;\n hsl.l = clamp01(hsl.l);\n return new TinyColor(hsl);\n };\n /**\n * Mix the color with pure white, from 0 to 100.\n * Providing 0 will do nothing, providing 100 will always return white.\n * @param amount - valid between 1-100\n */\n TinyColor.prototype.tint = function (amount) {\n if (amount === void 0) { amount = 10; }\n return this.mix('white', amount);\n };\n /**\n * Mix the color with pure black, from 0 to 100.\n * Providing 0 will do nothing, providing 100 will always return black.\n * @param amount - valid between 1-100\n */\n TinyColor.prototype.shade = function (amount) {\n if (amount === void 0) { amount = 10; }\n return this.mix('black', amount);\n };\n /**\n * Desaturate the color a given amount, from 0 to 100.\n * Providing 100 will is the same as calling greyscale\n * @param amount - valid between 1-100\n */\n TinyColor.prototype.desaturate = function (amount) {\n if (amount === void 0) { amount = 10; }\n var hsl = this.toHsl();\n hsl.s -= amount / 100;\n hsl.s = clamp01(hsl.s);\n return new TinyColor(hsl);\n };\n /**\n * Saturate the color a given amount, from 0 to 100.\n * @param amount - valid between 1-100\n */\n TinyColor.prototype.saturate = function (amount) {\n if (amount === void 0) { amount = 10; }\n var hsl = this.toHsl();\n hsl.s += amount / 100;\n hsl.s = clamp01(hsl.s);\n return new TinyColor(hsl);\n };\n /**\n * Completely desaturates a color into greyscale.\n * Same as calling `desaturate(100)`\n */\n TinyColor.prototype.greyscale = function () {\n return this.desaturate(100);\n };\n /**\n * Spin takes a positive or negative amount within [-360, 360] indicating the change of hue.\n * Values outside of this range will be wrapped into this range.\n */\n TinyColor.prototype.spin = function (amount) {\n var hsl = this.toHsl();\n var hue = (hsl.h + amount) % 360;\n hsl.h = hue < 0 ? 360 + hue : hue;\n return new TinyColor(hsl);\n };\n /**\n * Mix the current color a given amount with another color, from 0 to 100.\n * 0 means no mixing (return current color).\n */\n TinyColor.prototype.mix = function (color, amount) {\n if (amount === void 0) { amount = 50; }\n var rgb1 = this.toRgb();\n var rgb2 = new TinyColor(color).toRgb();\n var p = amount / 100;\n var rgba = {\n r: (rgb2.r - rgb1.r) * p + rgb1.r,\n g: (rgb2.g - rgb1.g) * p + rgb1.g,\n b: (rgb2.b - rgb1.b) * p + rgb1.b,\n a: (rgb2.a - rgb1.a) * p + rgb1.a,\n };\n return new TinyColor(rgba);\n };\n TinyColor.prototype.analogous = function (results, slices) {\n if (results === void 0) { results = 6; }\n if (slices === void 0) { slices = 30; }\n var hsl = this.toHsl();\n var part = 360 / slices;\n var ret = [this];\n for (hsl.h = (hsl.h - ((part * results) >> 1) + 720) % 360; --results;) {\n hsl.h = (hsl.h + part) % 360;\n ret.push(new TinyColor(hsl));\n }\n return ret;\n };\n /**\n * taken from https://github.com/infusion/jQuery-xcolor/blob/master/jquery.xcolor.js\n */\n TinyColor.prototype.complement = function () {\n var hsl = this.toHsl();\n hsl.h = (hsl.h + 180) % 360;\n return new TinyColor(hsl);\n };\n TinyColor.prototype.monochromatic = function (results) {\n if (results === void 0) { results = 6; }\n var hsv = this.toHsv();\n var h = hsv.h;\n var s = hsv.s;\n var v = hsv.v;\n var res = [];\n var modification = 1 / results;\n while (results--) {\n res.push(new TinyColor({ h: h, s: s, v: v }));\n v = (v + modification) % 1;\n }\n return res;\n };\n TinyColor.prototype.splitcomplement = function () {\n var hsl = this.toHsl();\n var h = hsl.h;\n return [\n this,\n new TinyColor({ h: (h + 72) % 360, s: hsl.s, l: hsl.l }),\n new TinyColor({ h: (h + 216) % 360, s: hsl.s, l: hsl.l }),\n ];\n };\n /**\n * Compute how the color would appear on a background\n */\n TinyColor.prototype.onBackground = function (background) {\n var fg = this.toRgb();\n var bg = new TinyColor(background).toRgb();\n var alpha = fg.a + bg.a * (1 - fg.a);\n return new TinyColor({\n r: (fg.r * fg.a + bg.r * bg.a * (1 - fg.a)) / alpha,\n g: (fg.g * fg.a + bg.g * bg.a * (1 - fg.a)) / alpha,\n b: (fg.b * fg.a + bg.b * bg.a * (1 - fg.a)) / alpha,\n a: alpha,\n });\n };\n /**\n * Alias for `polyad(3)`\n */\n TinyColor.prototype.triad = function () {\n return this.polyad(3);\n };\n /**\n * Alias for `polyad(4)`\n */\n TinyColor.prototype.tetrad = function () {\n return this.polyad(4);\n };\n /**\n * Get polyad colors, like (for 1, 2, 3, 4, 5, 6, 7, 8, etc...)\n * monad, dyad, triad, tetrad, pentad, hexad, heptad, octad, etc...\n */\n TinyColor.prototype.polyad = function (n) {\n var hsl = this.toHsl();\n var h = hsl.h;\n var result = [this];\n var increment = 360 / n;\n for (var i = 1; i < n; i++) {\n result.push(new TinyColor({ h: (h + i * increment) % 360, s: hsl.s, l: hsl.l }));\n }\n return result;\n };\n /**\n * compare color vs current color\n */\n TinyColor.prototype.equals = function (color) {\n return this.toRgbString() === new TinyColor(color).toRgbString();\n };\n return TinyColor;\n}());\nexport { TinyColor };\n// kept for backwards compatability with v1\nexport function tinycolor(color, opts) {\n if (color === void 0) { color = ''; }\n if (opts === void 0) { opts = {}; }\n return new TinyColor(color, opts);\n}\n","'use strict';\nvar globalThis = require('../internals/global-this');\nvar fails = require('../internals/fails');\nvar V8 = require('../internals/environment-v8-version');\nvar ENVIRONMENT = require('../internals/environment');\n\nvar structuredClone = globalThis.structuredClone;\n\nmodule.exports = !!structuredClone && !fails(function () {\n // prevent V8 ArrayBufferDetaching protector cell invalidation and performance degradation\n // https://github.com/zloirock/core-js/issues/679\n if ((ENVIRONMENT === 'DENO' && V8 > 92) || (ENVIRONMENT === 'NODE' && V8 > 94) || (ENVIRONMENT === 'BROWSER' && V8 > 97)) return false;\n var buffer = new ArrayBuffer(8);\n var clone = structuredClone(buffer, { transfer: [buffer] });\n return buffer.byteLength !== 0 || clone.byteLength !== 8;\n});\n","'use strict';\n// TODO: Remove from `core-js@4`\nrequire('../modules/es.uint8-array.set-from-base64');\n","!function(t,e){\"object\"==typeof exports&&\"undefined\"!=typeof module?module.exports=e():\"function\"==typeof define&&define.amd?define(e):(t=\"undefined\"!=typeof globalThis?globalThis:t||self).dayjs=e()}(this,(function(){\"use strict\";var t=1e3,e=6e4,n=36e5,r=\"millisecond\",i=\"second\",s=\"minute\",u=\"hour\",a=\"day\",o=\"week\",c=\"month\",f=\"quarter\",h=\"year\",d=\"date\",l=\"Invalid Date\",$=/^(\\d{4})[-/]?(\\d{1,2})?[-/]?(\\d{0,2})[Tt\\s]*(\\d{1,2})?:?(\\d{1,2})?:?(\\d{1,2})?[.:]?(\\d+)?$/,y=/\\[([^\\]]+)]|Y{1,4}|M{1,4}|D{1,2}|d{1,4}|H{1,2}|h{1,2}|a|A|m{1,2}|s{1,2}|Z{1,2}|SSS/g,M={name:\"en\",weekdays:\"Sunday_Monday_Tuesday_Wednesday_Thursday_Friday_Saturday\".split(\"_\"),months:\"January_February_March_April_May_June_July_August_September_October_November_December\".split(\"_\"),ordinal:function(t){var e=[\"th\",\"st\",\"nd\",\"rd\"],n=t%100;return\"[\"+t+(e[(n-20)%10]||e[n]||e[0])+\"]\"}},m=function(t,e,n){var r=String(t);return!r||r.length>=e?t:\"\"+Array(e+1-r.length).join(n)+t},v={s:m,z:function(t){var e=-t.utcOffset(),n=Math.abs(e),r=Math.floor(n/60),i=n%60;return(e<=0?\"+\":\"-\")+m(r,2,\"0\")+\":\"+m(i,2,\"0\")},m:function t(e,n){if(e.date()1)return t(u[0])}else{var a=e.name;D[a]=e,i=a}return!r&&i&&(g=i),i||!r&&g},O=function(t,e){if(S(t))return t.clone();var n=\"object\"==typeof e?e:{};return n.date=t,n.args=arguments,new _(n)},b=v;b.l=w,b.i=S,b.w=function(t,e){return O(t,{locale:e.$L,utc:e.$u,x:e.$x,$offset:e.$offset})};var _=function(){function M(t){this.$L=w(t.locale,null,!0),this.parse(t),this.$x=this.$x||t.x||{},this[p]=!0}var m=M.prototype;return m.parse=function(t){this.$d=function(t){var e=t.date,n=t.utc;if(null===e)return new Date(NaN);if(b.u(e))return new Date;if(e instanceof Date)return new Date(e);if(\"string\"==typeof e&&!/Z$/i.test(e)){var r=e.match($);if(r){var i=r[2]-1||0,s=(r[7]||\"0\").substring(0,3);return n?new Date(Date.UTC(r[1],i,r[3]||1,r[4]||0,r[5]||0,r[6]||0,s)):new Date(r[1],i,r[3]||1,r[4]||0,r[5]||0,r[6]||0,s)}}return new Date(e)}(t),this.init()},m.init=function(){var t=this.$d;this.$y=t.getFullYear(),this.$M=t.getMonth(),this.$D=t.getDate(),this.$W=t.getDay(),this.$H=t.getHours(),this.$m=t.getMinutes(),this.$s=t.getSeconds(),this.$ms=t.getMilliseconds()},m.$utils=function(){return b},m.isValid=function(){return!(this.$d.toString()===l)},m.isSame=function(t,e){var n=O(t);return this.startOf(e)<=n&&n<=this.endOf(e)},m.isAfter=function(t,e){return O(t) Loading,\n },\n /**\n * @description determine whether it's a plain button\n */\n plain: {\n type: Boolean,\n default: undefined,\n },\n /**\n * @description determine whether it's a text button\n */\n text: {\n type: Boolean,\n default: undefined,\n },\n /**\n * @description determine whether it's a link button\n */\n link: Boolean,\n /**\n * @description determine whether the text button background color is always on\n */\n bg: Boolean,\n /**\n * @description native button autofocus\n */\n autofocus: Boolean,\n /**\n * @description determine whether it's a round button\n */\n round: {\n type: Boolean,\n default: undefined,\n },\n /**\n * @description determine whether it's a circle button\n */\n circle: Boolean,\n /**\n * @description custom button color, automatically calculate `hover` and `active` color\n */\n color: String,\n /**\n * @description dark mode, which automatically converts `color` to dark mode colors\n */\n dark: Boolean,\n /**\n * @description automatically insert a space between two chinese characters\n */\n autoInsertSpace: {\n type: Boolean,\n default: undefined,\n },\n /**\n * @description custom element tag\n */\n tag: {\n type: definePropType([String, Object]),\n default: 'button',\n },\n} as const)\nexport const buttonEmits = {\n click: (evt: MouseEvent) => evt instanceof MouseEvent,\n}\n\nexport type ButtonProps = ExtractPropTypes\nexport type ButtonPropsPublic = __ExtractPublicPropTypes\nexport type ButtonEmits = typeof buttonEmits\n\nexport type ButtonType = ButtonProps['type']\nexport type ButtonNativeType = ButtonProps['nativeType']\n\nexport interface ButtonConfigContext {\n type?: string\n plain?: boolean\n text?: boolean\n round?: boolean\n autoInsertSpace?: boolean\n}\n","import { buildProps, definePropType } from '@element-plus/utils'\nimport { useEmptyValuesProps, useSizeProp } from '@element-plus/hooks'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type { Language } from '@element-plus/locale'\nimport type { ButtonConfigContext } from '@element-plus/components/button'\nimport type { CardConfigContext } from '@element-plus/components/card'\nimport type { DialogConfigContext } from '@element-plus/components/dialog'\nimport type { MessageConfigContext } from '@element-plus/components/message'\nimport type { LinkConfigContext } from '@element-plus/components/link'\n\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\nexport type ExperimentalFeatures = {\n // TO BE Defined\n}\n\nexport const configProviderProps = buildProps({\n /**\n * @description Controlling if the users want a11y features\n */\n a11y: {\n type: Boolean,\n default: true,\n },\n /**\n * @description Locale Object\n */\n locale: {\n type: definePropType(Object),\n },\n /**\n * @description global component size\n */\n size: useSizeProp,\n /**\n * @description button related configuration, [see the following table](https://element-plus.org/en-US/component/config-provider.html#button-attribute)\n */\n button: {\n type: definePropType(Object),\n },\n /**\n * @description card related configuration, [see the following table](https://element-plus.org/en-US/component/config-provider.html#card-attribute)\n */\n card: {\n type: definePropType(Object),\n },\n /**\n * @description dialog related configuration, [see the following table](https://element-plus.org/en-US/component/config-provider.html#dialog-attribute)\n */\n dialog: {\n type: definePropType(Object),\n },\n /**\n * @description link related configuration, [see the following table](https://element-plus.org/en-US/component/config-provider.html#link-attribute)\n */\n link: {\n type: definePropType(Object),\n },\n /**\n * @description features at experimental stage to be added, all features are default to be set to false, [see the following table](https://element-plus.org/en-US/component/config-provider.html#experimental-features) | ^[object]\n */\n experimentalFeatures: {\n type: definePropType(Object),\n },\n /**\n * @description Controls if we should handle keyboard navigation\n */\n keyboardNavigation: {\n type: Boolean,\n default: true,\n },\n /**\n * @description message related configuration, [see the following table](https://element-plus.org/en-US/component/config-provider.html#message-attribute)\n */\n message: {\n type: definePropType(Object),\n },\n /**\n * @description global Initial zIndex\n */\n zIndex: Number,\n /**\n * @description global component className prefix (cooperated with [$namespace](https://github.com/element-plus/element-plus/blob/dev/packages/theme-chalk/src/mixins/config.scss#L1)) | ^[string]\n */\n namespace: {\n type: String,\n default: 'el',\n },\n ...useEmptyValuesProps,\n} as const)\nexport type ConfigProviderProps = ExtractPropTypes\nexport type ConfigProviderPropsPublic = __ExtractPublicPropTypes<\n typeof configProviderProps\n>\n","import { defineComponent, renderSlot, watch } from 'vue'\nimport { provideGlobalConfig } from './hooks/use-global-config'\nimport { configProviderProps } from './config-provider-props'\n\nimport type { MessageConfigContext } from '@element-plus/components/message'\n\nexport const messageConfig: MessageConfigContext = {\n placement: 'top',\n}\n\nconst ConfigProvider = defineComponent({\n name: 'ElConfigProvider',\n props: configProviderProps,\n\n setup(props, { slots }) {\n const config = provideGlobalConfig(props)\n watch(\n () => props.message,\n (val) => {\n Object.assign(messageConfig, config?.value?.message ?? {}, val ?? {})\n },\n { immediate: true, deep: true }\n )\n return () => renderSlot(slots, 'default', { config: config?.value })\n },\n})\nexport type ConfigProviderInstance = InstanceType &\n unknown\n\nexport default ConfigProvider\n","import Symbol from './_Symbol.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the raw `toStringTag`.\n */\nfunction getRawTag(value) {\n var isOwn = hasOwnProperty.call(value, symToStringTag),\n tag = value[symToStringTag];\n\n try {\n value[symToStringTag] = undefined;\n var unmasked = true;\n } catch (e) {}\n\n var result = nativeObjectToString.call(value);\n if (unmasked) {\n if (isOwn) {\n value[symToStringTag] = tag;\n } else {\n delete value[symToStringTag];\n }\n }\n return result;\n}\n\nexport default getRawTag;\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/**\n * Converts `value` to a string using `Object.prototype.toString`.\n *\n * @private\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n */\nfunction objectToString(value) {\n return nativeObjectToString.call(value);\n}\n\nexport default objectToString;\n","import Symbol from './_Symbol.js';\nimport getRawTag from './_getRawTag.js';\nimport objectToString from './_objectToString.js';\n\n/** `Object#toString` result references. */\nvar nullTag = '[object Null]',\n undefinedTag = '[object Undefined]';\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * The base implementation of `getTag` without fallbacks for buggy environments.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nfunction baseGetTag(value) {\n if (value == null) {\n return value === undefined ? undefinedTag : nullTag;\n }\n return (symToStringTag && symToStringTag in Object(value))\n ? getRawTag(value)\n : objectToString(value);\n}\n\nexport default baseGetTag;\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\n\nmodule.exports = uncurryThis({}.isPrototypeOf);\n","'use strict';\nvar $ = require('../internals/export');\nvar union = require('../internals/set-union');\nvar setMethodGetKeysBeforeCloning = require('../internals/set-method-get-keys-before-cloning-detection');\nvar setMethodAcceptSetLike = require('../internals/set-method-accept-set-like');\n\nvar FORCED = !setMethodAcceptSetLike('union') || !setMethodGetKeysBeforeCloning('union');\n\n// `Set.prototype.union` method\n// https://tc39.es/ecma262/#sec-set.prototype.union\n$({ target: 'Set', proto: true, real: true, forced: FORCED }, {\n union: union\n});\n","'use strict';\nvar $ = require('../internals/export');\nvar call = require('../internals/function-call');\nvar aCallable = require('../internals/a-callable');\nvar anObject = require('../internals/an-object');\nvar getIteratorDirect = require('../internals/get-iterator-direct');\nvar createIteratorProxy = require('../internals/iterator-create-proxy');\nvar callWithSafeIterationClosing = require('../internals/call-with-safe-iteration-closing');\nvar iteratorClose = require('../internals/iterator-close');\nvar iteratorHelperThrowsOnInvalidIterator = require('../internals/iterator-helper-throws-on-invalid-iterator');\nvar iteratorHelperWithoutClosingOnEarlyError = require('../internals/iterator-helper-without-closing-on-early-error');\nvar IS_PURE = require('../internals/is-pure');\n\nvar MAP_WITHOUT_THROWING_ON_INVALID_ITERATOR = !IS_PURE && !iteratorHelperThrowsOnInvalidIterator('map', function () { /* empty */ });\nvar mapWithoutClosingOnEarlyError = !IS_PURE && !MAP_WITHOUT_THROWING_ON_INVALID_ITERATOR\n && iteratorHelperWithoutClosingOnEarlyError('map', TypeError);\n\nvar FORCED = IS_PURE || MAP_WITHOUT_THROWING_ON_INVALID_ITERATOR || mapWithoutClosingOnEarlyError;\n\nvar IteratorProxy = createIteratorProxy(function () {\n var iterator = this.iterator;\n var result = anObject(call(this.next, iterator));\n var done = this.done = !!result.done;\n if (!done) return callWithSafeIterationClosing(iterator, this.mapper, [result.value, this.counter++], true);\n});\n\n// `Iterator.prototype.map` method\n// https://tc39.es/ecma262/#sec-iterator.prototype.map\n$({ target: 'Iterator', proto: true, real: true, forced: FORCED }, {\n map: function map(mapper) {\n anObject(this);\n try {\n aCallable(mapper);\n } catch (error) {\n iteratorClose(this, 'throw', error);\n }\n\n if (mapWithoutClosingOnEarlyError) return call(mapWithoutClosingOnEarlyError, this, mapper);\n\n return new IteratorProxy(getIteratorDirect(this), {\n mapper: mapper\n });\n }\n});\n","'use strict';\n// `GetIteratorDirect(obj)` abstract operation\n// https://tc39.es/ecma262/#sec-getiteratordirect\nmodule.exports = function (obj) {\n return {\n iterator: obj,\n next: obj.next,\n done: false\n };\n};\n","/**\n * A specialized version of `_.filter` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n */\nfunction arrayFilter(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length,\n resIndex = 0,\n result = [];\n\n while (++index < length) {\n var value = array[index];\n if (predicate(value, index, array)) {\n result[resIndex++] = value;\n }\n }\n return result;\n}\n\nexport default arrayFilter;\n","import arrayFilter from './_arrayFilter.js';\nimport stubArray from './stubArray.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Built-in value references. */\nvar propertyIsEnumerable = objectProto.propertyIsEnumerable;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeGetSymbols = Object.getOwnPropertySymbols;\n\n/**\n * Creates an array of the own enumerable symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of symbols.\n */\nvar getSymbols = !nativeGetSymbols ? stubArray : function(object) {\n if (object == null) {\n return [];\n }\n object = Object(object);\n return arrayFilter(nativeGetSymbols(object), function(symbol) {\n return propertyIsEnumerable.call(object, symbol);\n });\n};\n\nexport default getSymbols;\n","import isFunction from './isFunction.js';\nimport isLength from './isLength.js';\n\n/**\n * Checks if `value` is array-like. A value is considered array-like if it's\n * not a function and has a `value.length` that's an integer greater than or\n * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is array-like, else `false`.\n * @example\n *\n * _.isArrayLike([1, 2, 3]);\n * // => true\n *\n * _.isArrayLike(document.body.children);\n * // => true\n *\n * _.isArrayLike('abc');\n * // => true\n *\n * _.isArrayLike(_.noop);\n * // => false\n */\nfunction isArrayLike(value) {\n return value != null && isLength(value.length) && !isFunction(value);\n}\n\nexport default isArrayLike;\n","'use strict';\nvar $ = require('../internals/export');\nvar anObject = require('../internals/an-object');\nvar iterate = require('../internals/iterate');\nvar getIteratorDirect = require('../internals/get-iterator-direct');\n\nvar push = [].push;\n\n// `Iterator.prototype.toArray` method\n// https://tc39.es/ecma262/#sec-iterator.prototype.toarray\n$({ target: 'Iterator', proto: true, real: true }, {\n toArray: function toArray() {\n var result = [];\n iterate(getIteratorDirect(anObject(this)), push, { that: result, IS_RECORD: true });\n return result;\n }\n});\n","/**\n * Appends the elements of `values` to `array`.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {Array} values The values to append.\n * @returns {Array} Returns `array`.\n */\nfunction arrayPush(array, values) {\n var index = -1,\n length = values.length,\n offset = array.length;\n\n while (++index < length) {\n array[offset + index] = values[index];\n }\n return array;\n}\n\nexport default arrayPush;\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar hasOwn = require('../internals/has-own-property');\nvar toIndexedObject = require('../internals/to-indexed-object');\nvar indexOf = require('../internals/array-includes').indexOf;\nvar hiddenKeys = require('../internals/hidden-keys');\n\nvar push = uncurryThis([].push);\n\nmodule.exports = function (object, names) {\n var O = toIndexedObject(object);\n var i = 0;\n var result = [];\n var key;\n for (key in O) !hasOwn(hiddenKeys, key) && hasOwn(O, key) && push(result, key);\n // Don't enum bug & hidden keys\n while (names.length > i) if (hasOwn(O, key = names[i++])) {\n ~indexOf(result, key) || push(result, key);\n }\n return result;\n};\n","import {\n getCurrentInstance,\n onMounted,\n ref,\n shallowRef,\n unref,\n watch,\n} from 'vue'\nimport { useEventListener } from '@vueuse/core'\nimport { isElement, isFocusable, isFunction } from '@element-plus/utils'\n\nimport type { ShallowRef } from 'vue'\nimport type { MaybeRef } from '@vueuse/core'\n\ninterface UseFocusControllerOptions {\n disabled?: MaybeRef\n /**\n * return true to cancel focus\n * @param event FocusEvent\n */\n beforeFocus?: (event: FocusEvent) => boolean | undefined\n afterFocus?: () => void\n /**\n * return true to cancel blur\n * @param event FocusEvent\n */\n beforeBlur?: (event: FocusEvent) => boolean | undefined\n afterBlur?: () => void\n}\n\nexport function useFocusController void }>(\n target: ShallowRef,\n {\n disabled,\n beforeFocus,\n afterFocus,\n beforeBlur,\n afterBlur,\n }: UseFocusControllerOptions = {}\n) {\n const instance = getCurrentInstance()!\n const { emit } = instance\n const wrapperRef = shallowRef()\n const isFocused = ref(false)\n\n const handleFocus = (event: FocusEvent) => {\n const cancelFocus = isFunction(beforeFocus) ? beforeFocus(event) : false\n if (unref(disabled) || isFocused.value || cancelFocus) return\n\n isFocused.value = true\n emit('focus', event)\n afterFocus?.()\n }\n\n const handleBlur = (event: FocusEvent) => {\n const cancelBlur = isFunction(beforeBlur) ? beforeBlur(event) : false\n if (\n unref(disabled) ||\n (event.relatedTarget &&\n wrapperRef.value?.contains(event.relatedTarget as Node)) ||\n cancelBlur\n )\n return\n\n isFocused.value = false\n emit('blur', event)\n afterBlur?.()\n }\n\n const handleClick = (event: Event) => {\n if (\n unref(disabled) ||\n isFocusable(event.target as HTMLElement) ||\n (wrapperRef.value?.contains(document.activeElement) &&\n wrapperRef.value !== document.activeElement)\n )\n return\n\n target.value?.focus()\n }\n\n watch([wrapperRef, () => unref(disabled)], ([el, disabled]) => {\n if (!el) return\n if (disabled) {\n el.removeAttribute('tabindex')\n } else {\n el.setAttribute('tabindex', '-1')\n }\n })\n\n useEventListener(wrapperRef, 'focus', handleFocus, true)\n useEventListener(wrapperRef, 'blur', handleBlur, true)\n useEventListener(wrapperRef, 'click', handleClick, true)\n\n // only for test\n if (typeof process !== 'undefined' && process.env.NODE_ENV === 'test') {\n onMounted(() => {\n const targetEl = isElement(target.value)\n ? target.value\n : document.querySelector('input,textarea')\n\n if (targetEl) {\n useEventListener(targetEl, 'focus', handleFocus, true)\n useEventListener(targetEl, 'blur', handleBlur, true)\n }\n })\n }\n\n return {\n isFocused,\n /** Avoid using wrapperRef and handleFocus/handleBlur together */\n wrapperRef,\n handleFocus,\n handleBlur,\n }\n}\n","import { NOOP } from '@element-plus/utils'\n\nexport const useSameTarget = (handleClick?: (e: MouseEvent) => void) => {\n if (!handleClick) {\n return { onClick: NOOP, onMousedown: NOOP, onMouseup: NOOP }\n }\n\n let mousedownTarget = false\n let mouseupTarget = false\n // refer to this https://javascript.info/mouse-events-basics\n // events fired in the order: mousedown -> mouseup -> click\n // we need to set the mousedown handle to false after click fired.\n const onClick = (e: MouseEvent) => {\n // if and only if\n if (mousedownTarget && mouseupTarget) {\n handleClick(e)\n }\n mousedownTarget = mouseupTarget = false\n }\n\n const onMousedown = (e: MouseEvent) => {\n // marking current mousedown target.\n mousedownTarget = e.target === e.currentTarget\n }\n const onMouseup = (e: MouseEvent) => {\n // marking current mouseup target.\n mouseupTarget = e.target === e.currentTarget\n }\n\n return { onClick, onMousedown, onMouseup }\n}\n","import baseGet from './_baseGet.js';\nimport baseSet from './_baseSet.js';\nimport castPath from './_castPath.js';\n\n/**\n * The base implementation of `_.pickBy` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The source object.\n * @param {string[]} paths The property paths to pick.\n * @param {Function} predicate The function invoked per property.\n * @returns {Object} Returns the new object.\n */\nfunction basePickBy(object, paths, predicate) {\n var index = -1,\n length = paths.length,\n result = {};\n\n while (++index < length) {\n var path = paths[index],\n value = baseGet(object, path);\n\n if (predicate(value, path)) {\n baseSet(result, castPath(path, object), value);\n }\n }\n return result;\n}\n\nexport default basePickBy;\n","import basePickBy from './_basePickBy.js';\nimport hasIn from './hasIn.js';\n\n/**\n * The base implementation of `_.pick` without support for individual\n * property identifiers.\n *\n * @private\n * @param {Object} object The source object.\n * @param {string[]} paths The property paths to pick.\n * @returns {Object} Returns the new object.\n */\nfunction basePick(object, paths) {\n return basePickBy(object, paths, function(value, path) {\n return hasIn(object, path);\n });\n}\n\nexport default basePick;\n","import basePick from './_basePick.js';\nimport flatRest from './_flatRest.js';\n\n/**\n * Creates an object composed of the picked `object` properties.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The source object.\n * @param {...(string|string[])} [paths] The property paths to pick.\n * @returns {Object} Returns the new object.\n * @example\n *\n * var object = { 'a': 1, 'b': '2', 'c': 3 };\n *\n * _.pick(object, ['a', 'c']);\n * // => { 'a': 1, 'c': 3 }\n */\nvar pick = flatRest(function(object, paths) {\n return object == null ? {} : basePick(object, paths);\n});\n\nexport default pick;\n","import { componentSizes } from '@element-plus/constants'\nimport {\n buildProps,\n definePropType,\n isArray,\n isBoolean,\n isString,\n} from '@element-plus/utils'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type { FormItemProp } from './form-item'\nimport type { FormRules } from './types'\n\nexport const formMetaProps = buildProps({\n /**\n * @description Control the size of components in this form.\n */\n size: {\n type: String,\n values: componentSizes,\n },\n /**\n * @description Whether to disable all components in this form. If set to `true`, it will override the `disabled` prop of the inner component.\n */\n disabled: Boolean,\n} as const)\n\nexport const formProps = buildProps({\n ...formMetaProps,\n /**\n * @description Data of form component.\n */\n model: Object,\n /**\n * @description Validation rules of form.\n */\n rules: {\n type: definePropType(Object),\n },\n /**\n * @description Position of label. If set to `'left'` or `'right'`, `label-width` prop is also required.\n */\n labelPosition: {\n type: String,\n values: ['left', 'right', 'top'],\n default: 'right',\n },\n /**\n * @description Position of asterisk.\n */\n requireAsteriskPosition: {\n type: String,\n values: ['left', 'right'],\n default: 'left',\n },\n /**\n * @description Width of label, e.g. `'50px'`. All its direct child form items will inherit this value. `auto` is supported.\n */\n labelWidth: {\n type: [String, Number],\n default: '',\n },\n /**\n * @description Suffix of the label.\n */\n labelSuffix: {\n type: String,\n default: '',\n },\n /**\n * @description Whether the form is inline.\n */\n inline: Boolean,\n /**\n * @description Whether to display the error message inline with the form item.\n */\n inlineMessage: Boolean,\n /**\n * @description Whether to display an icon indicating the validation result.\n */\n statusIcon: Boolean,\n /**\n * @description Whether to show the error message.\n */\n showMessage: {\n type: Boolean,\n default: true,\n },\n /**\n * @description Whether to trigger validation when the `rules` prop is changed.\n */\n validateOnRuleChange: {\n type: Boolean,\n default: true,\n },\n /**\n * @description Whether to hide required fields should have a red asterisk (star) beside their labels.\n */\n hideRequiredAsterisk: Boolean,\n /**\n * @description When validation fails, scroll to the first error form entry.\n */\n scrollToError: Boolean,\n /**\n * @description When validation fails, it scrolls to the first error item based on the scrollIntoView option.\n */\n scrollIntoViewOptions: {\n type: definePropType([Object, Boolean]),\n default: true,\n },\n} as const)\nexport type FormProps = ExtractPropTypes\nexport type FormPropsPublic = __ExtractPublicPropTypes\n\nexport type FormMetaProps = ExtractPropTypes\nexport type FormMetaPropsPublic = __ExtractPublicPropTypes\n\nexport const formEmits = {\n validate: (prop: FormItemProp, isValid: boolean, message: string) =>\n (isArray(prop) || isString(prop)) &&\n isBoolean(isValid) &&\n isString(message),\n}\nexport type FormEmits = typeof formEmits\n","import { computed, ref } from 'vue'\nimport { debugWarn, ensureArray, isArray } from '@element-plus/utils'\n\nimport type { Arrayable } from '@element-plus/utils'\nimport type { FormItemContext } from './types'\nimport type { FormItemProp } from './form-item'\n\nconst SCOPE = 'ElForm'\n\nexport function useFormLabelWidth() {\n const potentialLabelWidthArr = ref([])\n\n const autoLabelWidth = computed(() => {\n if (!potentialLabelWidthArr.value.length) return '0'\n const max = Math.max(...potentialLabelWidthArr.value)\n return max ? `${max}px` : ''\n })\n\n function getLabelWidthIndex(width: number) {\n const index = potentialLabelWidthArr.value.indexOf(width)\n if (index === -1 && autoLabelWidth.value === '0') {\n debugWarn(SCOPE, `unexpected width ${width}`)\n }\n return index\n }\n\n function registerLabelWidth(val: number, oldVal: number) {\n if (val && oldVal) {\n const index = getLabelWidthIndex(oldVal)\n potentialLabelWidthArr.value.splice(index, 1, val)\n } else if (val) {\n potentialLabelWidthArr.value.push(val)\n }\n }\n\n function deregisterLabelWidth(val: number) {\n const index = getLabelWidthIndex(val)\n if (index > -1) {\n potentialLabelWidthArr.value.splice(index, 1)\n }\n }\n\n return {\n autoLabelWidth,\n registerLabelWidth,\n deregisterLabelWidth,\n }\n}\n\nexport const filterFields = (\n fields: FormItemContext[],\n props: Arrayable\n) => {\n const normalized = ensureArray(props).map((prop) =>\n isArray(prop) ? prop.join('.') : prop\n )\n return normalized.length > 0\n ? fields.filter(\n (field) => field.propString && normalized.includes(field.propString)\n )\n : fields\n}\n","\n\n\n","/* eslint no-console:0 */\n\nimport {\n ValidateError,\n ValidateOption,\n RuleValuePackage,\n InternalRuleItem,\n SyncErrorType,\n RuleType,\n Value,\n Values,\n} from './interface';\n\nconst formatRegExp = /%[sdj%]/g;\n\ndeclare var ASYNC_VALIDATOR_NO_WARNING;\n\nexport let warning: (type: string, errors: SyncErrorType[]) => void = () => {};\n\n// don't print warning message when in production env or node runtime\nif (\n typeof process !== 'undefined' &&\n process.env &&\n process.env.NODE_ENV !== 'production' &&\n typeof window !== 'undefined' &&\n typeof document !== 'undefined'\n) {\n warning = (type, errors) => {\n if (\n typeof console !== 'undefined' &&\n console.warn &&\n typeof ASYNC_VALIDATOR_NO_WARNING === 'undefined'\n ) {\n if (errors.every(e => typeof e === 'string')) {\n console.warn(type, errors);\n }\n }\n };\n}\n\nexport function convertFieldsError(\n errors: ValidateError[],\n): Record {\n if (!errors || !errors.length) return null;\n const fields = {};\n errors.forEach(error => {\n const field = error.field;\n fields[field] = fields[field] || [];\n fields[field].push(error);\n });\n return fields;\n}\n\nexport function format(\n template: ((...args: any[]) => string) | string,\n ...args: any[]\n): string {\n let i = 0;\n const len = args.length;\n if (typeof template === 'function') {\n return template.apply(null, args);\n }\n if (typeof template === 'string') {\n let str = template.replace(formatRegExp, x => {\n if (x === '%%') {\n return '%';\n }\n if (i >= len) {\n return x;\n }\n switch (x) {\n case '%s':\n return String(args[i++]);\n case '%d':\n return (Number(args[i++]) as unknown) as string;\n case '%j':\n try {\n return JSON.stringify(args[i++]);\n } catch (_) {\n return '[Circular]';\n }\n break;\n default:\n return x;\n }\n });\n return str;\n }\n return template;\n}\n\nfunction isNativeStringType(type: string) {\n return (\n type === 'string' ||\n type === 'url' ||\n type === 'hex' ||\n type === 'email' ||\n type === 'date' ||\n type === 'pattern'\n );\n}\n\nexport function isEmptyValue(value: Value, type?: string) {\n if (value === undefined || value === null) {\n return true;\n }\n if (type === 'array' && Array.isArray(value) && !value.length) {\n return true;\n }\n if (isNativeStringType(type) && typeof value === 'string' && !value) {\n return true;\n }\n return false;\n}\n\nexport function isEmptyObject(obj: object) {\n return Object.keys(obj).length === 0;\n}\n\nfunction asyncParallelArray(\n arr: RuleValuePackage[],\n func: ValidateFunc,\n callback: (errors: ValidateError[]) => void,\n) {\n const results: ValidateError[] = [];\n let total = 0;\n const arrLength = arr.length;\n\n function count(errors: ValidateError[]) {\n results.push(...(errors || []));\n total++;\n if (total === arrLength) {\n callback(results);\n }\n }\n\n arr.forEach(a => {\n func(a, count);\n });\n}\n\nfunction asyncSerialArray(\n arr: RuleValuePackage[],\n func: ValidateFunc,\n callback: (errors: ValidateError[]) => void,\n) {\n let index = 0;\n const arrLength = arr.length;\n\n function next(errors: ValidateError[]) {\n if (errors && errors.length) {\n callback(errors);\n return;\n }\n const original = index;\n index = index + 1;\n if (original < arrLength) {\n func(arr[original], next);\n } else {\n callback([]);\n }\n }\n\n next([]);\n}\n\nfunction flattenObjArr(objArr: Record) {\n const ret: RuleValuePackage[] = [];\n Object.keys(objArr).forEach(k => {\n ret.push(...(objArr[k] || []));\n });\n return ret;\n}\n\nexport class AsyncValidationError extends Error {\n errors: ValidateError[];\n fields: Record;\n\n constructor(\n errors: ValidateError[],\n fields: Record,\n ) {\n super('Async Validation Error');\n this.errors = errors;\n this.fields = fields;\n }\n}\n\ntype ValidateFunc = (\n data: RuleValuePackage,\n doIt: (errors: ValidateError[]) => void,\n) => void;\n\nexport function asyncMap(\n objArr: Record,\n option: ValidateOption,\n func: ValidateFunc,\n callback: (errors: ValidateError[]) => void,\n source: Values,\n): Promise {\n if (option.first) {\n const pending = new Promise((resolve, reject) => {\n const next = (errors: ValidateError[]) => {\n callback(errors);\n return errors.length\n ? reject(new AsyncValidationError(errors, convertFieldsError(errors)))\n : resolve(source);\n };\n const flattenArr = flattenObjArr(objArr);\n asyncSerialArray(flattenArr, func, next);\n });\n pending.catch(e => e);\n return pending;\n }\n const firstFields =\n option.firstFields === true\n ? Object.keys(objArr)\n : option.firstFields || [];\n\n const objArrKeys = Object.keys(objArr);\n const objArrLength = objArrKeys.length;\n let total = 0;\n const results: ValidateError[] = [];\n const pending = new Promise((resolve, reject) => {\n const next = (errors: ValidateError[]) => {\n results.push.apply(results, errors);\n total++;\n if (total === objArrLength) {\n callback(results);\n return results.length\n ? reject(\n new AsyncValidationError(results, convertFieldsError(results)),\n )\n : resolve(source);\n }\n };\n if (!objArrKeys.length) {\n callback(results);\n resolve(source);\n }\n objArrKeys.forEach(key => {\n const arr = objArr[key];\n if (firstFields.indexOf(key) !== -1) {\n asyncSerialArray(arr, func, next);\n } else {\n asyncParallelArray(arr, func, next);\n }\n });\n });\n pending.catch(e => e);\n return pending;\n}\n\nfunction isErrorObj(\n obj: ValidateError | string | (() => string),\n): obj is ValidateError {\n return !!(obj && (obj as ValidateError).message !== undefined);\n}\n\nfunction getValue(value: Values, path: string[]) {\n let v = value;\n for (let i = 0; i < path.length; i++) {\n if (v == undefined) {\n return v;\n }\n v = v[path[i]];\n }\n return v;\n}\n\nexport function complementError(rule: InternalRuleItem, source: Values) {\n return (oe: ValidateError | (() => string) | string): ValidateError => {\n let fieldValue;\n if (rule.fullFields) {\n fieldValue = getValue(source, rule.fullFields);\n } else {\n fieldValue = source[(oe as any).field || rule.fullField];\n }\n if (isErrorObj(oe)) {\n oe.field = oe.field || rule.fullField;\n oe.fieldValue = fieldValue;\n return oe;\n }\n return {\n message: typeof oe === 'function' ? oe() : oe,\n fieldValue,\n field: ((oe as unknown) as ValidateError).field || rule.fullField,\n };\n };\n}\n\nexport function deepMerge(target: T, source: Partial): T {\n if (source) {\n for (const s in source) {\n if (source.hasOwnProperty(s)) {\n const value = source[s];\n if (typeof value === 'object' && typeof target[s] === 'object') {\n target[s] = {\n ...target[s],\n ...value,\n };\n } else {\n target[s] = value;\n }\n }\n }\n }\n return target;\n}\n","import { ExecuteRule } from '../interface';\nimport { format, isEmptyValue } from '../util';\n\nconst required: ExecuteRule = (rule, value, source, errors, options, type) => {\n if (\n rule.required &&\n (!source.hasOwnProperty(rule.field) ||\n isEmptyValue(value, type || rule.type))\n ) {\n errors.push(format(options.messages.required, rule.fullField));\n }\n};\n\nexport default required;\n","// https://github.com/kevva/url-regex/blob/master/index.js\nlet urlReg: RegExp;\n\nexport default () => {\n if (urlReg) {\n return urlReg;\n }\n\n const word = '[a-fA-F\\\\d:]';\n const b = options =>\n options && options.includeBoundaries\n ? `(?:(?<=\\\\s|^)(?=${word})|(?<=${word})(?=\\\\s|$))`\n : '';\n\n const v4 =\n '(?:25[0-5]|2[0-4]\\\\d|1\\\\d\\\\d|[1-9]\\\\d|\\\\d)(?:\\\\.(?:25[0-5]|2[0-4]\\\\d|1\\\\d\\\\d|[1-9]\\\\d|\\\\d)){3}';\n\n const v6seg = '[a-fA-F\\\\d]{1,4}';\n const v6 = `\n(?:\n(?:${v6seg}:){7}(?:${v6seg}|:)| // 1:2:3:4:5:6:7:: 1:2:3:4:5:6:7:8\n(?:${v6seg}:){6}(?:${v4}|:${v6seg}|:)| // 1:2:3:4:5:6:: 1:2:3:4:5:6::8 1:2:3:4:5:6::8 1:2:3:4:5:6::1.2.3.4\n(?:${v6seg}:){5}(?::${v4}|(?::${v6seg}){1,2}|:)| // 1:2:3:4:5:: 1:2:3:4:5::7:8 1:2:3:4:5::8 1:2:3:4:5::7:1.2.3.4\n(?:${v6seg}:){4}(?:(?::${v6seg}){0,1}:${v4}|(?::${v6seg}){1,3}|:)| // 1:2:3:4:: 1:2:3:4::6:7:8 1:2:3:4::8 1:2:3:4::6:7:1.2.3.4\n(?:${v6seg}:){3}(?:(?::${v6seg}){0,2}:${v4}|(?::${v6seg}){1,4}|:)| // 1:2:3:: 1:2:3::5:6:7:8 1:2:3::8 1:2:3::5:6:7:1.2.3.4\n(?:${v6seg}:){2}(?:(?::${v6seg}){0,3}:${v4}|(?::${v6seg}){1,5}|:)| // 1:2:: 1:2::4:5:6:7:8 1:2::8 1:2::4:5:6:7:1.2.3.4\n(?:${v6seg}:){1}(?:(?::${v6seg}){0,4}:${v4}|(?::${v6seg}){1,6}|:)| // 1:: 1::3:4:5:6:7:8 1::8 1::3:4:5:6:7:1.2.3.4\n(?::(?:(?::${v6seg}){0,5}:${v4}|(?::${v6seg}){1,7}|:)) // ::2:3:4:5:6:7:8 ::2:3:4:5:6:7:8 ::8 ::1.2.3.4\n)(?:%[0-9a-zA-Z]{1,})? // %eth0 %1\n`\n .replace(/\\s*\\/\\/.*$/gm, '')\n .replace(/\\n/g, '')\n .trim();\n\n // Pre-compile only the exact regexes because adding a global flag make regexes stateful\n const v46Exact = new RegExp(`(?:^${v4}$)|(?:^${v6}$)`);\n const v4exact = new RegExp(`^${v4}$`);\n const v6exact = new RegExp(`^${v6}$`);\n\n const ip = options =>\n options && options.exact\n ? v46Exact\n : new RegExp(\n `(?:${b(options)}${v4}${b(options)})|(?:${b(options)}${v6}${b(\n options,\n )})`,\n 'g',\n );\n\n ip.v4 = (options?) =>\n options && options.exact\n ? v4exact\n : new RegExp(`${b(options)}${v4}${b(options)}`, 'g');\n ip.v6 = (options?) =>\n options && options.exact\n ? v6exact\n : new RegExp(`${b(options)}${v6}${b(options)}`, 'g');\n\n const protocol = `(?:(?:[a-z]+:)?//)`;\n const auth = '(?:\\\\S+(?::\\\\S*)?@)?';\n const ipv4 = ip.v4().source;\n const ipv6 = ip.v6().source;\n const host = '(?:(?:[a-z\\\\u00a1-\\\\uffff0-9][-_]*)*[a-z\\\\u00a1-\\\\uffff0-9]+)';\n const domain =\n '(?:\\\\.(?:[a-z\\\\u00a1-\\\\uffff0-9]-*)*[a-z\\\\u00a1-\\\\uffff0-9]+)*';\n const tld = `(?:\\\\.(?:[a-z\\\\u00a1-\\\\uffff]{2,}))`;\n const port = '(?::\\\\d{2,5})?';\n const path = '(?:[/?#][^\\\\s\"]*)?';\n const regex = `(?:${protocol}|www\\\\.)${auth}(?:localhost|${ipv4}|${ipv6}|${host}${domain}${tld})${port}${path}`;\n urlReg = new RegExp(`(?:^${regex}$)`, 'i');\n return urlReg;\n};\n","import { ExecuteRule } from '../interface';\nimport { format } from '../util';\n\n/**\n * Rule for validating whitespace.\n *\n * @param rule The validation rule.\n * @param value The value of the field on the source object.\n * @param source The source object being validated.\n * @param errors An array of errors that this rule may add\n * validation errors to.\n * @param options The validation options.\n * @param options.messages The validation messages.\n */\nconst whitespace: ExecuteRule = (rule, value, source, errors, options) => {\n if (/^\\s+$/.test(value) || value === '') {\n errors.push(format(options.messages.whitespace, rule.fullField));\n }\n};\n\nexport default whitespace;\n","import { ExecuteRule, Value } from '../interface';\nimport { format } from '../util';\nimport required from './required';\nimport getUrlRegex from './url';\n/* eslint max-len:0 */\n\nconst pattern = {\n // http://emailregex.com/\n email: /^(([^<>()\\[\\]\\\\.,;:\\s@\"]+(\\.[^<>()\\[\\]\\\\.,;:\\s@\"]+)*)|(\".+\"))@((\\[[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}])|(([a-zA-Z\\-0-9\\u00A0-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFEF]+\\.)+[a-zA-Z\\u00A0-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFEF]{2,}))$/,\n // url: new RegExp(\n // '^(?!mailto:)(?:(?:http|https|ftp)://|//)(?:\\\\S+(?::\\\\S*)?@)?(?:(?:(?:[1-9]\\\\d?|1\\\\d\\\\d|2[01]\\\\d|22[0-3])(?:\\\\.(?:1?\\\\d{1,2}|2[0-4]\\\\d|25[0-5])){2}(?:\\\\.(?:[0-9]\\\\d?|1\\\\d\\\\d|2[0-4]\\\\d|25[0-4]))|(?:(?:[a-z\\\\u00a1-\\\\uffff0-9]+-*)*[a-z\\\\u00a1-\\\\uffff0-9]+)(?:\\\\.(?:[a-z\\\\u00a1-\\\\uffff0-9]+-*)*[a-z\\\\u00a1-\\\\uffff0-9]+)*(?:\\\\.(?:[a-z\\\\u00a1-\\\\uffff]{2,})))|localhost)(?::\\\\d{2,5})?(?:(/|\\\\?|#)[^\\\\s]*)?$',\n // 'i',\n // ),\n hex: /^#?([a-f0-9]{6}|[a-f0-9]{3})$/i,\n};\n\nconst types = {\n integer(value: Value) {\n return types.number(value) && parseInt(value, 10) === value;\n },\n float(value: Value) {\n return types.number(value) && !types.integer(value);\n },\n array(value: Value) {\n return Array.isArray(value);\n },\n regexp(value: Value) {\n if (value instanceof RegExp) {\n return true;\n }\n try {\n return !!new RegExp(value);\n } catch (e) {\n return false;\n }\n },\n date(value: Value) {\n return (\n typeof value.getTime === 'function' &&\n typeof value.getMonth === 'function' &&\n typeof value.getYear === 'function' &&\n !isNaN(value.getTime())\n );\n },\n number(value: Value) {\n if (isNaN(value)) {\n return false;\n }\n return typeof value === 'number';\n },\n object(value: Value) {\n return typeof value === 'object' && !types.array(value);\n },\n method(value: Value) {\n return typeof value === 'function';\n },\n email(value: Value) {\n return (\n typeof value === 'string' &&\n value.length <= 320 &&\n !!value.match(pattern.email)\n );\n },\n url(value: Value) {\n return (\n typeof value === 'string' &&\n value.length <= 2048 &&\n !!value.match(getUrlRegex())\n );\n },\n hex(value: Value) {\n return typeof value === 'string' && !!value.match(pattern.hex);\n },\n};\n\nconst type: ExecuteRule = (rule, value, source, errors, options) => {\n if (rule.required && value === undefined) {\n required(rule, value, source, errors, options);\n return;\n }\n const custom = [\n 'integer',\n 'float',\n 'array',\n 'regexp',\n 'object',\n 'method',\n 'email',\n 'number',\n 'date',\n 'url',\n 'hex',\n ];\n const ruleType = rule.type;\n if (custom.indexOf(ruleType) > -1) {\n if (!types[ruleType](value)) {\n errors.push(\n format(options.messages.types[ruleType], rule.fullField, rule.type),\n );\n }\n // straight typeof check\n } else if (ruleType && typeof value !== rule.type) {\n errors.push(\n format(options.messages.types[ruleType], rule.fullField, rule.type),\n );\n }\n};\n\nexport default type;\n","import { ExecuteRule } from '../interface';\nimport { format } from '../util';\n\nconst range: ExecuteRule = (rule, value, source, errors, options) => {\n const len = typeof rule.len === 'number';\n const min = typeof rule.min === 'number';\n const max = typeof rule.max === 'number';\n // 正则匹配码点范围从U+010000一直到U+10FFFF的文字(补充平面Supplementary Plane)\n const spRegexp = /[\\uD800-\\uDBFF][\\uDC00-\\uDFFF]/g;\n let val = value;\n let key = null;\n const num = typeof value === 'number';\n const str = typeof value === 'string';\n const arr = Array.isArray(value);\n if (num) {\n key = 'number';\n } else if (str) {\n key = 'string';\n } else if (arr) {\n key = 'array';\n }\n // if the value is not of a supported type for range validation\n // the validation rule rule should use the\n // type property to also test for a particular type\n if (!key) {\n return false;\n }\n if (arr) {\n val = value.length;\n }\n if (str) {\n // 处理码点大于U+010000的文字length属性不准确的bug,如\"𠮷𠮷𠮷\".lenght !== 3\n val = value.replace(spRegexp, '_').length;\n }\n if (len) {\n if (val !== rule.len) {\n errors.push(format(options.messages[key].len, rule.fullField, rule.len));\n }\n } else if (min && !max && val < rule.min) {\n errors.push(format(options.messages[key].min, rule.fullField, rule.min));\n } else if (max && !min && val > rule.max) {\n errors.push(format(options.messages[key].max, rule.fullField, rule.max));\n } else if (min && max && (val < rule.min || val > rule.max)) {\n errors.push(\n format(options.messages[key].range, rule.fullField, rule.min, rule.max),\n );\n }\n};\n\nexport default range;\n","import { ExecuteRule } from '../interface';\nimport { format } from '../util';\n\nconst ENUM = 'enum' as const;\n\nconst enumerable: ExecuteRule = (rule, value, source, errors, options) => {\n rule[ENUM] = Array.isArray(rule[ENUM]) ? rule[ENUM] : [];\n if (rule[ENUM].indexOf(value) === -1) {\n errors.push(\n format(options.messages[ENUM], rule.fullField, rule[ENUM].join(', ')),\n );\n }\n};\n\nexport default enumerable;\n","import { ExecuteRule } from '../interface';\nimport { format } from '../util';\n\nconst pattern: ExecuteRule = (rule, value, source, errors, options) => {\n if (rule.pattern) {\n if (rule.pattern instanceof RegExp) {\n // if a RegExp instance is passed, reset `lastIndex` in case its `global`\n // flag is accidentally set to `true`, which in a validation scenario\n // is not necessary and the result might be misleading\n rule.pattern.lastIndex = 0;\n if (!rule.pattern.test(value)) {\n errors.push(\n format(\n options.messages.pattern.mismatch,\n rule.fullField,\n value,\n rule.pattern,\n ),\n );\n }\n } else if (typeof rule.pattern === 'string') {\n const _pattern = new RegExp(rule.pattern);\n if (!_pattern.test(value)) {\n errors.push(\n format(\n options.messages.pattern.mismatch,\n rule.fullField,\n value,\n rule.pattern,\n ),\n );\n }\n }\n }\n};\n\nexport default pattern;\n","import required from './required';\nimport whitespace from './whitespace';\nimport type from './type';\nimport range from './range';\nimport enumRule from './enum';\nimport pattern from './pattern';\n\nexport default {\n required,\n whitespace,\n type,\n range,\n enum: enumRule,\n pattern,\n};\n","import { ExecuteValidator } from '../interface';\nimport rules from '../rule';\nimport { isEmptyValue } from '../util';\n\nconst string: ExecuteValidator = (rule, value, callback, source, options) => {\n const errors: string[] = [];\n const validate =\n rule.required || (!rule.required && source.hasOwnProperty(rule.field));\n if (validate) {\n if (isEmptyValue(value, 'string') && !rule.required) {\n return callback();\n }\n rules.required(rule, value, source, errors, options, 'string');\n if (!isEmptyValue(value, 'string')) {\n rules.type(rule, value, source, errors, options);\n rules.range(rule, value, source, errors, options);\n rules.pattern(rule, value, source, errors, options);\n if (rule.whitespace === true) {\n rules.whitespace(rule, value, source, errors, options);\n }\n }\n }\n callback(errors);\n};\n\nexport default string;\n","import { ExecuteValidator } from '../interface';\nimport rules from '../rule';\nimport { isEmptyValue } from '../util';\n\nconst method: ExecuteValidator = (rule, value, callback, source, options) => {\n const errors: string[] = [];\n const validate =\n rule.required || (!rule.required && source.hasOwnProperty(rule.field));\n if (validate) {\n if (isEmptyValue(value) && !rule.required) {\n return callback();\n }\n rules.required(rule, value, source, errors, options);\n if (value !== undefined) {\n rules.type(rule, value, source, errors, options);\n }\n }\n callback(errors);\n};\n\nexport default method;\n","import { ExecuteValidator } from '../interface';\nimport rules from '../rule';\nimport { isEmptyValue } from '../util';\n\nconst number: ExecuteValidator = (rule, value, callback, source, options) => {\n const errors: string[] = [];\n const validate =\n rule.required || (!rule.required && source.hasOwnProperty(rule.field));\n if (validate) {\n if (value === '') {\n value = undefined;\n }\n if (isEmptyValue(value) && !rule.required) {\n return callback();\n }\n rules.required(rule, value, source, errors, options);\n if (value !== undefined) {\n rules.type(rule, value, source, errors, options);\n rules.range(rule, value, source, errors, options);\n }\n }\n callback(errors);\n};\n\nexport default number;\n","import { isEmptyValue } from '../util';\nimport rules from '../rule';\nimport { ExecuteValidator } from '../interface';\n\nconst boolean: ExecuteValidator = (rule, value, callback, source, options) => {\n const errors: string[] = [];\n const validate =\n rule.required || (!rule.required && source.hasOwnProperty(rule.field));\n if (validate) {\n if (isEmptyValue(value) && !rule.required) {\n return callback();\n }\n rules.required(rule, value, source, errors, options);\n if (value !== undefined) {\n rules.type(rule, value, source, errors, options);\n }\n }\n callback(errors);\n};\n\nexport default boolean;\n","import { ExecuteValidator } from '../interface';\nimport rules from '../rule';\nimport { isEmptyValue } from '../util';\n\nconst regexp: ExecuteValidator = (rule, value, callback, source, options) => {\n const errors: string[] = [];\n const validate =\n rule.required || (!rule.required && source.hasOwnProperty(rule.field));\n if (validate) {\n if (isEmptyValue(value) && !rule.required) {\n return callback();\n }\n rules.required(rule, value, source, errors, options);\n if (!isEmptyValue(value)) {\n rules.type(rule, value, source, errors, options);\n }\n }\n callback(errors);\n};\n\nexport default regexp;\n","import { ExecuteValidator } from '../interface';\nimport rules from '../rule';\nimport { isEmptyValue } from '../util';\n\nconst integer: ExecuteValidator = (rule, value, callback, source, options) => {\n const errors: string[] = [];\n const validate =\n rule.required || (!rule.required && source.hasOwnProperty(rule.field));\n if (validate) {\n if (isEmptyValue(value) && !rule.required) {\n return callback();\n }\n rules.required(rule, value, source, errors, options);\n if (value !== undefined) {\n rules.type(rule, value, source, errors, options);\n rules.range(rule, value, source, errors, options);\n }\n }\n callback(errors);\n};\n\nexport default integer;\n","import { ExecuteValidator } from '../interface';\nimport rules from '../rule';\nimport { isEmptyValue } from '../util';\n\nconst floatFn: ExecuteValidator = (rule, value, callback, source, options) => {\n const errors: string[] = [];\n const validate =\n rule.required || (!rule.required && source.hasOwnProperty(rule.field));\n if (validate) {\n if (isEmptyValue(value) && !rule.required) {\n return callback();\n }\n rules.required(rule, value, source, errors, options);\n if (value !== undefined) {\n rules.type(rule, value, source, errors, options);\n rules.range(rule, value, source, errors, options);\n }\n }\n callback(errors);\n};\n\nexport default floatFn;\n","import { ExecuteValidator } from '../interface';\nimport rules from '../rule/index';\n\nconst array: ExecuteValidator = (rule, value, callback, source, options) => {\n const errors: string[] = [];\n const validate =\n rule.required || (!rule.required && source.hasOwnProperty(rule.field));\n if (validate) {\n if ((value === undefined || value === null) && !rule.required) {\n return callback();\n }\n rules.required(rule, value, source, errors, options, 'array');\n if (value !== undefined && value !== null) {\n rules.type(rule, value, source, errors, options);\n rules.range(rule, value, source, errors, options);\n }\n }\n callback(errors);\n};\n\nexport default array;\n","import { ExecuteValidator } from '../interface';\nimport rules from '../rule';\nimport { isEmptyValue } from '../util';\n\nconst object: ExecuteValidator = (rule, value, callback, source, options) => {\n const errors: string[] = [];\n const validate =\n rule.required || (!rule.required && source.hasOwnProperty(rule.field));\n if (validate) {\n if (isEmptyValue(value) && !rule.required) {\n return callback();\n }\n rules.required(rule, value, source, errors, options);\n if (value !== undefined) {\n rules.type(rule, value, source, errors, options);\n }\n }\n callback(errors);\n};\n\nexport default object;\n","import { ExecuteValidator } from '../interface';\nimport rules from '../rule';\nimport { isEmptyValue } from '../util';\n\nconst ENUM = 'enum' as const;\n\nconst enumerable: ExecuteValidator = (\n rule,\n value,\n callback,\n source,\n options,\n) => {\n const errors: string[] = [];\n const validate =\n rule.required || (!rule.required && source.hasOwnProperty(rule.field));\n if (validate) {\n if (isEmptyValue(value) && !rule.required) {\n return callback();\n }\n rules.required(rule, value, source, errors, options);\n if (value !== undefined) {\n rules[ENUM](rule, value, source, errors, options);\n }\n }\n callback(errors);\n};\n\nexport default enumerable;\n","import { ExecuteValidator } from '../interface';\nimport rules from '../rule';\nimport { isEmptyValue } from '../util';\n\nconst pattern: ExecuteValidator = (rule, value, callback, source, options) => {\n const errors: string[] = [];\n const validate =\n rule.required || (!rule.required && source.hasOwnProperty(rule.field));\n if (validate) {\n if (isEmptyValue(value, 'string') && !rule.required) {\n return callback();\n }\n rules.required(rule, value, source, errors, options);\n if (!isEmptyValue(value, 'string')) {\n rules.pattern(rule, value, source, errors, options);\n }\n }\n callback(errors);\n};\n\nexport default pattern;\n","import { ExecuteValidator } from '../interface';\nimport rules from '../rule';\nimport { isEmptyValue } from '../util';\n\nconst date: ExecuteValidator = (rule, value, callback, source, options) => {\n // console.log('integer rule called %j', rule);\n const errors: string[] = [];\n const validate =\n rule.required || (!rule.required && source.hasOwnProperty(rule.field));\n // console.log('validate on %s value', value);\n if (validate) {\n if (isEmptyValue(value, 'date') && !rule.required) {\n return callback();\n }\n rules.required(rule, value, source, errors, options);\n if (!isEmptyValue(value, 'date')) {\n let dateObject;\n\n if (value instanceof Date) {\n dateObject = value;\n } else {\n dateObject = new Date(value);\n }\n\n rules.type(rule, dateObject, source, errors, options);\n if (dateObject) {\n rules.range(rule, dateObject.getTime(), source, errors, options);\n }\n }\n }\n callback(errors);\n};\n\nexport default date;\n","import { ExecuteValidator } from '../interface';\nimport rules from '../rule';\n\nconst required: ExecuteValidator = (rule, value, callback, source, options) => {\n const errors: string[] = [];\n const type = Array.isArray(value) ? 'array' : typeof value;\n rules.required(rule, value, source, errors, options, type);\n callback(errors);\n};\n\nexport default required;\n","import { ExecuteValidator } from '../interface';\nimport rules from '../rule';\nimport { isEmptyValue } from '../util';\n\nconst type: ExecuteValidator = (rule, value, callback, source, options) => {\n const ruleType = rule.type;\n const errors: string[] = [];\n const validate =\n rule.required || (!rule.required && source.hasOwnProperty(rule.field));\n if (validate) {\n if (isEmptyValue(value, ruleType) && !rule.required) {\n return callback();\n }\n rules.required(rule, value, source, errors, options, ruleType);\n if (!isEmptyValue(value, ruleType)) {\n rules.type(rule, value, source, errors, options);\n }\n }\n callback(errors);\n};\n\nexport default type;\n","import { ExecuteValidator } from '../interface';\nimport rules from '../rule';\nimport { isEmptyValue } from '../util';\n\nconst any: ExecuteValidator = (rule, value, callback, source, options) => {\n const errors: string[] = [];\n const validate =\n rule.required || (!rule.required && source.hasOwnProperty(rule.field));\n if (validate) {\n if (isEmptyValue(value) && !rule.required) {\n return callback();\n }\n rules.required(rule, value, source, errors, options);\n }\n callback(errors);\n};\n\nexport default any;\n","import string from './string';\nimport method from './method';\nimport number from './number';\nimport boolean from './boolean';\nimport regexp from './regexp';\nimport integer from './integer';\nimport float from './float';\nimport array from './array';\nimport object from './object';\nimport enumValidator from './enum';\nimport pattern from './pattern';\nimport date from './date';\nimport required from './required';\nimport type from './type';\nimport any from './any';\n\nexport default {\n string,\n method,\n number,\n boolean,\n regexp,\n integer,\n float,\n array,\n object,\n enum: enumValidator,\n pattern,\n date,\n url: type,\n hex: type,\n email: type,\n required,\n any,\n};\n","import { InternalValidateMessages } from './interface';\n\nexport function newMessages(): InternalValidateMessages {\n return {\n default: 'Validation error on field %s',\n required: '%s is required',\n enum: '%s must be one of %s',\n whitespace: '%s cannot be empty',\n date: {\n format: '%s date %s is invalid for format %s',\n parse: '%s date could not be parsed, %s is invalid ',\n invalid: '%s date %s is invalid',\n },\n types: {\n string: '%s is not a %s',\n method: '%s is not a %s (function)',\n array: '%s is not an %s',\n object: '%s is not an %s',\n number: '%s is not a %s',\n date: '%s is not a %s',\n boolean: '%s is not a %s',\n integer: '%s is not an %s',\n float: '%s is not a %s',\n regexp: '%s is not a valid %s',\n email: '%s is not a valid %s',\n url: '%s is not a valid %s',\n hex: '%s is not a valid %s',\n },\n string: {\n len: '%s must be exactly %s characters',\n min: '%s must be at least %s characters',\n max: '%s cannot be longer than %s characters',\n range: '%s must be between %s and %s characters',\n },\n number: {\n len: '%s must equal %s',\n min: '%s cannot be less than %s',\n max: '%s cannot be greater than %s',\n range: '%s must be between %s and %s',\n },\n array: {\n len: '%s must be exactly %s in length',\n min: '%s cannot be less than %s in length',\n max: '%s cannot be greater than %s in length',\n range: '%s must be between %s and %s in length',\n },\n pattern: {\n mismatch: '%s value %s does not match pattern %s',\n },\n clone() {\n const cloned = JSON.parse(JSON.stringify(this));\n cloned.clone = this.clone;\n return cloned;\n },\n };\n}\n\nexport const messages = newMessages();\n","import {\n format,\n complementError,\n asyncMap,\n warning,\n deepMerge,\n convertFieldsError,\n} from './util';\nimport validators from './validator/index';\nimport { messages as defaultMessages, newMessages } from './messages';\nimport {\n InternalRuleItem,\n InternalValidateMessages,\n Rule,\n RuleItem,\n Rules,\n ValidateCallback,\n ValidateMessages,\n ValidateOption,\n Values,\n RuleValuePackage,\n ValidateError,\n ValidateFieldsError,\n SyncErrorType,\n ValidateResult,\n} from './interface';\n\nexport * from './interface';\n\n/**\n * Encapsulates a validation schema.\n *\n * @param descriptor An object declaring validation rules\n * for this schema.\n */\nclass Schema {\n // ========================= Static =========================\n static register = function register(type: string, validator) {\n if (typeof validator !== 'function') {\n throw new Error(\n 'Cannot register a validator by type, validator is not a function',\n );\n }\n validators[type] = validator;\n };\n\n static warning = warning;\n\n static messages = defaultMessages;\n\n static validators = validators;\n\n // ======================== Instance ========================\n rules: Record = null;\n _messages: InternalValidateMessages = defaultMessages;\n\n constructor(descriptor: Rules) {\n this.define(descriptor);\n }\n\n define(rules: Rules) {\n if (!rules) {\n throw new Error('Cannot configure a schema with no rules');\n }\n if (typeof rules !== 'object' || Array.isArray(rules)) {\n throw new Error('Rules must be an object');\n }\n this.rules = {};\n\n Object.keys(rules).forEach(name => {\n const item: Rule = rules[name];\n this.rules[name] = Array.isArray(item) ? item : [item];\n });\n }\n\n messages(messages?: ValidateMessages) {\n if (messages) {\n this._messages = deepMerge(newMessages(), messages);\n }\n return this._messages;\n }\n\n validate(\n source: Values,\n option?: ValidateOption,\n callback?: ValidateCallback,\n ): Promise;\n validate(source: Values, callback: ValidateCallback): Promise;\n validate(source: Values): Promise;\n\n validate(source_: Values, o: any = {}, oc: any = () => {}): Promise {\n let source: Values = source_;\n let options: ValidateOption = o;\n let callback: ValidateCallback = oc;\n if (typeof options === 'function') {\n callback = options;\n options = {};\n }\n if (!this.rules || Object.keys(this.rules).length === 0) {\n if (callback) {\n callback(null, source);\n }\n return Promise.resolve(source);\n }\n\n function complete(results: (ValidateError | ValidateError[])[]) {\n let errors: ValidateError[] = [];\n let fields: ValidateFieldsError = {};\n\n function add(e: ValidateError | ValidateError[]) {\n if (Array.isArray(e)) {\n errors = errors.concat(...e);\n } else {\n errors.push(e);\n }\n }\n\n for (let i = 0; i < results.length; i++) {\n add(results[i]);\n }\n if (!errors.length) {\n callback(null, source);\n } else {\n fields = convertFieldsError(errors);\n (callback as (\n errors: ValidateError[],\n fields: ValidateFieldsError,\n ) => void)(errors, fields);\n }\n }\n\n if (options.messages) {\n let messages = this.messages();\n if (messages === defaultMessages) {\n messages = newMessages();\n }\n deepMerge(messages, options.messages);\n options.messages = messages;\n } else {\n options.messages = this.messages();\n }\n\n const series: Record = {};\n const keys = options.keys || Object.keys(this.rules);\n keys.forEach(z => {\n const arr = this.rules[z];\n let value = source[z];\n arr.forEach(r => {\n let rule: InternalRuleItem = r;\n if (typeof rule.transform === 'function') {\n if (source === source_) {\n source = { ...source };\n }\n value = source[z] = rule.transform(value);\n }\n if (typeof rule === 'function') {\n rule = {\n validator: rule,\n };\n } else {\n rule = { ...rule };\n }\n\n // Fill validator. Skip if nothing need to validate\n rule.validator = this.getValidationMethod(rule);\n if (!rule.validator) {\n return;\n }\n\n rule.field = z;\n rule.fullField = rule.fullField || z;\n rule.type = this.getType(rule);\n series[z] = series[z] || [];\n series[z].push({\n rule,\n value,\n source,\n field: z,\n });\n });\n });\n const errorFields = {};\n return asyncMap(\n series,\n options,\n (data, doIt) => {\n const rule = data.rule;\n let deep =\n (rule.type === 'object' || rule.type === 'array') &&\n (typeof rule.fields === 'object' ||\n typeof rule.defaultField === 'object');\n deep = deep && (rule.required || (!rule.required && data.value));\n rule.field = data.field;\n\n function addFullField(key: string, schema: RuleItem) {\n return {\n ...schema,\n fullField: `${rule.fullField}.${key}`,\n fullFields: rule.fullFields ? [...rule.fullFields, key] : [key],\n };\n }\n\n function cb(e: SyncErrorType | SyncErrorType[] = []) {\n let errorList = Array.isArray(e) ? e : [e];\n if (!options.suppressWarning && errorList.length) {\n Schema.warning('async-validator:', errorList);\n }\n if (errorList.length && rule.message !== undefined) {\n errorList = [].concat(rule.message);\n }\n\n // Fill error info\n let filledErrors = errorList.map(complementError(rule, source));\n\n if (options.first && filledErrors.length) {\n errorFields[rule.field] = 1;\n return doIt(filledErrors);\n }\n if (!deep) {\n doIt(filledErrors);\n } else {\n // if rule is required but the target object\n // does not exist fail at the rule level and don't\n // go deeper\n if (rule.required && !data.value) {\n if (rule.message !== undefined) {\n filledErrors = []\n .concat(rule.message)\n .map(complementError(rule, source));\n } else if (options.error) {\n filledErrors = [\n options.error(\n rule,\n format(options.messages.required, rule.field),\n ),\n ];\n }\n return doIt(filledErrors);\n }\n\n let fieldsSchema: Record = {};\n if (rule.defaultField) {\n Object.keys(data.value).map(key => {\n fieldsSchema[key] = rule.defaultField;\n });\n }\n fieldsSchema = {\n ...fieldsSchema,\n ...data.rule.fields,\n };\n\n const paredFieldsSchema: Record = {};\n\n Object.keys(fieldsSchema).forEach(field => {\n const fieldSchema = fieldsSchema[field];\n const fieldSchemaList = Array.isArray(fieldSchema)\n ? fieldSchema\n : [fieldSchema];\n paredFieldsSchema[field] = fieldSchemaList.map(\n addFullField.bind(null, field),\n );\n });\n const schema = new Schema(paredFieldsSchema);\n schema.messages(options.messages);\n if (data.rule.options) {\n data.rule.options.messages = options.messages;\n data.rule.options.error = options.error;\n }\n schema.validate(data.value, data.rule.options || options, errs => {\n const finalErrors = [];\n if (filledErrors && filledErrors.length) {\n finalErrors.push(...filledErrors);\n }\n if (errs && errs.length) {\n finalErrors.push(...errs);\n }\n doIt(finalErrors.length ? finalErrors : null);\n });\n }\n }\n\n let res: ValidateResult;\n if (rule.asyncValidator) {\n res = rule.asyncValidator(rule, data.value, cb, data.source, options);\n } else if (rule.validator) {\n try {\n res = rule.validator(rule, data.value, cb, data.source, options);\n } catch (error) {\n console.error?.(error);\n // rethrow to report error\n if (!options.suppressValidatorError) {\n setTimeout(() => {\n throw error;\n }, 0);\n }\n cb(error.message);\n }\n if (res === true) {\n cb();\n } else if (res === false) {\n cb(\n typeof rule.message === 'function'\n ? rule.message(rule.fullField || rule.field)\n : rule.message || `${rule.fullField || rule.field} fails`,\n );\n } else if (res instanceof Array) {\n cb(res);\n } else if (res instanceof Error) {\n cb(res.message);\n }\n }\n if (res && (res as Promise).then) {\n (res as Promise).then(\n () => cb(),\n e => cb(e),\n );\n }\n },\n results => {\n complete(results);\n },\n source,\n );\n }\n\n getType(rule: InternalRuleItem) {\n if (rule.type === undefined && rule.pattern instanceof RegExp) {\n rule.type = 'pattern';\n }\n if (\n typeof rule.validator !== 'function' &&\n rule.type &&\n !validators.hasOwnProperty(rule.type)\n ) {\n throw new Error(format('Unknown rule type %s', rule.type));\n }\n return rule.type || 'string';\n }\n\n getValidationMethod(rule: InternalRuleItem) {\n if (typeof rule.validator === 'function') {\n return rule.validator;\n }\n const keys = Object.keys(rule);\n const messageIndex = keys.indexOf('message');\n if (messageIndex !== -1) {\n keys.splice(messageIndex, 1);\n }\n if (keys.length === 1 && keys[0] === 'required') {\n return validators.required;\n }\n return validators[this.getType(rule)] || undefined;\n }\n}\n\nexport default Schema;\n","import baseClone from './_baseClone.js';\n\n/** Used to compose bitmasks for cloning. */\nvar CLONE_SYMBOLS_FLAG = 4;\n\n/**\n * Creates a shallow clone of `value`.\n *\n * **Note:** This method is loosely based on the\n * [structured clone algorithm](https://mdn.io/Structured_clone_algorithm)\n * and supports cloning arrays, array buffers, booleans, date objects, maps,\n * numbers, `Object` objects, regexes, sets, strings, symbols, and typed\n * arrays. The own enumerable properties of `arguments` objects are cloned\n * as plain objects. An empty object is returned for uncloneable values such\n * as error objects, functions, DOM nodes, and WeakMaps.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to clone.\n * @returns {*} Returns the cloned value.\n * @see _.cloneDeep\n * @example\n *\n * var objects = [{ 'a': 1 }, { 'b': 2 }];\n *\n * var shallow = _.clone(objects);\n * console.log(shallow[0] === objects[0]);\n * // => true\n */\nfunction clone(value) {\n return baseClone(value, CLONE_SYMBOLS_FLAG);\n}\n\nexport default clone;\n","import { componentSizes } from '@element-plus/constants'\nimport { buildProps, definePropType } from '@element-plus/utils'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type { Arrayable } from '@element-plus/utils'\nimport type { FormItemRule } from './types'\n\nexport const formItemValidateStates = [\n '',\n 'error',\n 'validating',\n 'success',\n] as const\nexport type FormItemValidateState = (typeof formItemValidateStates)[number]\n\nexport type FormItemProp = Arrayable\n\nexport const formItemProps = buildProps({\n /**\n * @description Label text.\n */\n label: String,\n /**\n * @description Width of label, e.g. `'50px'`. `'auto'` is supported.\n */\n labelWidth: {\n type: [String, Number],\n },\n /**\n * @description Position of label. If set to `'left'` or `'right'`, `label-width` prop is also required. The default is extend from `form label-position`.\n */\n labelPosition: {\n type: String,\n values: ['left', 'right', 'top', ''],\n default: '',\n },\n /**\n * @description A key of `model`. It could be an array of property paths (e.g `['a', 'b', '0']`). In the use of `validate` and `resetFields` method, the attribute is required.\n */\n prop: {\n type: definePropType([String, Array]),\n },\n /**\n * @description Whether the field is required or not, will be determined by validation rules if omitted.\n */\n required: {\n type: Boolean,\n default: undefined,\n },\n /**\n * @description Validation rules of form, see the [following table](#formitemrule), more advanced usage at [async-validator](https://github.com/yiminghe/async-validator).\n */\n rules: {\n type: definePropType>([Object, Array]),\n },\n /**\n * @description Field error message, set its value and the field will validate error and show this message immediately.\n */\n error: String,\n /**\n * @description Validation state of formItem.\n */\n validateStatus: {\n type: String,\n values: formItemValidateStates,\n },\n /**\n * @description Same as for in native label.\n */\n for: String,\n /**\n * @description Inline style validate message.\n */\n inlineMessage: {\n type: Boolean,\n default: undefined,\n },\n /**\n * @description Whether to show the error message.\n */\n showMessage: {\n type: Boolean,\n default: true,\n },\n /**\n * @description Control the size of components in this form-item.\n */\n size: {\n type: String,\n values: componentSizes,\n },\n} as const)\nexport type FormItemProps = ExtractPropTypes\nexport type FormItemPropsPublic = __ExtractPublicPropTypes\n","import {\n Fragment,\n computed,\n defineComponent,\n inject,\n nextTick,\n onBeforeUnmount,\n onMounted,\n onUpdated,\n ref,\n watch,\n} from 'vue'\nimport { useResizeObserver } from '@vueuse/core'\nimport { throwError } from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport { formContextKey, formItemContextKey } from './constants'\n\nimport type { CSSProperties } from 'vue'\n\nconst COMPONENT_NAME = 'ElLabelWrap'\nexport default defineComponent({\n name: COMPONENT_NAME,\n props: {\n isAutoWidth: Boolean,\n updateAll: Boolean,\n },\n\n setup(props, { slots }) {\n const formContext = inject(formContextKey, undefined)\n const formItemContext = inject(formItemContextKey)\n if (!formItemContext)\n throwError(\n COMPONENT_NAME,\n 'usage: '\n )\n\n const ns = useNamespace('form')\n\n const el = ref()\n const computedWidth = ref(0)\n\n const getLabelWidth = () => {\n if (el.value?.firstElementChild) {\n const width = window.getComputedStyle(el.value.firstElementChild).width\n return Math.ceil(Number.parseFloat(width))\n } else {\n return 0\n }\n }\n\n const updateLabelWidth = (action: 'update' | 'remove' = 'update') => {\n nextTick(() => {\n if (slots.default && props.isAutoWidth) {\n if (action === 'update') {\n computedWidth.value = getLabelWidth()\n } else if (action === 'remove') {\n formContext?.deregisterLabelWidth(computedWidth.value)\n }\n }\n })\n }\n const updateLabelWidthFn = () => updateLabelWidth('update')\n\n onMounted(() => {\n updateLabelWidthFn()\n })\n onBeforeUnmount(() => {\n updateLabelWidth('remove')\n })\n onUpdated(() => updateLabelWidthFn())\n\n watch(computedWidth, (val, oldVal) => {\n if (props.updateAll) {\n formContext?.registerLabelWidth(val, oldVal)\n }\n })\n\n useResizeObserver(\n computed(\n () => (el.value?.firstElementChild ?? null) as HTMLElement | null\n ),\n updateLabelWidthFn\n )\n\n return () => {\n if (!slots) return null\n\n const { isAutoWidth } = props\n if (isAutoWidth) {\n const autoLabelWidth = formContext?.autoLabelWidth\n const hasLabel = formItemContext?.hasLabel\n const style: CSSProperties = {}\n if (hasLabel && autoLabelWidth && autoLabelWidth !== 'auto') {\n const marginWidth = Math.max(\n 0,\n Number.parseInt(autoLabelWidth, 10) - computedWidth.value\n )\n const labelPosition =\n formItemContext.labelPosition || formContext.labelPosition\n\n const marginPosition =\n labelPosition === 'left' ? 'marginRight' : 'marginLeft'\n\n if (marginWidth) {\n style[marginPosition] = `${marginWidth}px`\n }\n }\n return (\n
\n {slots.default?.()}\n
\n )\n } else {\n return {slots.default?.()}\n }\n }\n },\n})\n","\n\n\n","import { withInstall, withNoopInstall } from '@element-plus/utils'\nimport Form from './src/form.vue'\nimport FormItem from './src/form-item.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElForm: SFCWithInstall & {\n FormItem: typeof FormItem\n} = withInstall(Form, {\n FormItem,\n})\nexport default ElForm\nexport const ElFormItem: SFCWithInstall =\n withNoopInstall(FormItem)\n\nexport * from './src/form'\nexport * from './src/form-item'\nexport * from './src/types'\nexport * from './src/constants'\nexport * from './src/hooks'\n\nexport type FormInstance = InstanceType & unknown\nexport type FormItemInstance = InstanceType & unknown\n","export const UPDATE_MODEL_EVENT = 'update:modelValue'\nexport const CHANGE_EVENT = 'change'\nexport const INPUT_EVENT = 'input'\n","\n\n\n","\n\n\n","import { inject, onBeforeUnmount, onMounted, provide, ref, unref } from 'vue'\nimport Collection from './collection.vue'\nimport CollectionItem from './collection-item.vue'\n\nimport type { InjectionKey, SetupContext } from 'vue'\nimport type {\n ElCollectionInjectionContext,\n ElCollectionItemInjectionContext,\n} from './tokens'\n\nexport const COLLECTION_ITEM_SIGN = `data-el-collection-item`\n\n// Make sure the first letter of name is capitalized\nexport const createCollectionWithScope = (name: string) => {\n const COLLECTION_NAME = `El${name}Collection`\n const COLLECTION_ITEM_NAME = `${COLLECTION_NAME}Item`\n const COLLECTION_INJECTION_KEY: InjectionKey =\n Symbol(COLLECTION_NAME)\n const COLLECTION_ITEM_INJECTION_KEY: InjectionKey =\n Symbol(COLLECTION_ITEM_NAME)\n\n const ElCollection = {\n ...Collection,\n name: COLLECTION_NAME,\n setup() {\n const collectionRef = ref()\n const itemMap: ElCollectionInjectionContext['itemMap'] = new Map()\n const getItems = () => {\n const collectionEl = unref(collectionRef)\n\n if (!collectionEl) return []\n const orderedNodes = Array.from(\n collectionEl.querySelectorAll(`[${COLLECTION_ITEM_SIGN}]`)\n )\n\n const items = [...itemMap.values()]\n\n return items.sort(\n (a, b) => orderedNodes.indexOf(a.ref!) - orderedNodes.indexOf(b.ref!)\n )\n }\n\n provide(COLLECTION_INJECTION_KEY, {\n itemMap,\n getItems,\n collectionRef,\n })\n },\n }\n\n const ElCollectionItem = {\n ...CollectionItem,\n name: COLLECTION_ITEM_NAME,\n setup(_: unknown, { attrs }: SetupContext) {\n const collectionItemRef = ref()\n const collectionInjection = inject(COLLECTION_INJECTION_KEY, undefined)!\n\n provide(COLLECTION_ITEM_INJECTION_KEY, {\n collectionItemRef,\n })\n\n onMounted(() => {\n const collectionItemEl = unref(collectionItemRef)\n if (collectionItemEl) {\n collectionInjection.itemMap.set(collectionItemEl, {\n ref: collectionItemEl,\n ...attrs,\n })\n }\n })\n\n onBeforeUnmount(() => {\n const collectionItemEl = unref(collectionItemRef)!\n collectionInjection.itemMap.delete(collectionItemEl)\n })\n },\n }\n\n return {\n COLLECTION_INJECTION_KEY,\n COLLECTION_ITEM_INJECTION_KEY,\n ElCollection,\n ElCollectionItem,\n }\n}\n","import { buildProps, definePropType } from '@element-plus/utils'\nimport { createCollectionWithScope } from '@element-plus/components/collection'\n\nimport type {\n ExtractPropTypes,\n HTMLAttributes,\n StyleValue,\n __ExtractPublicPropTypes,\n} from 'vue'\n\nexport const rovingFocusGroupProps = buildProps({\n style: { type: definePropType([String, Array, Object]) },\n currentTabId: {\n type: definePropType(String),\n },\n defaultCurrentTabId: String,\n loop: Boolean,\n dir: {\n type: String, // left for direction support\n values: ['ltr', 'rtl'],\n default: 'ltr',\n },\n orientation: {\n // left for orientation support\n type: definePropType(String),\n },\n\n onBlur: Function,\n onFocus: Function,\n onMousedown: Function,\n})\n\nexport type ElRovingFocusGroupProps = ExtractPropTypes<\n typeof rovingFocusGroupProps\n>\n\nexport type ElRovingFocusGroupPropsPublic = __ExtractPublicPropTypes<\n typeof rovingFocusGroupProps\n>\n\nconst {\n ElCollection,\n ElCollectionItem,\n COLLECTION_INJECTION_KEY,\n COLLECTION_ITEM_INJECTION_KEY,\n} = createCollectionWithScope('RovingFocusGroup')\n\nexport {\n ElCollection,\n ElCollectionItem,\n COLLECTION_INJECTION_KEY as ROVING_FOCUS_COLLECTION_INJECTION_KEY,\n COLLECTION_ITEM_INJECTION_KEY as ROVING_FOCUS_ITEM_COLLECTION_INJECTION_KEY,\n}\n","import type { InjectionKey, Ref, StyleValue } from 'vue'\nimport type { ElRovingFocusGroupProps } from './roving-focus-group'\n\ntype EventHandler = (e: T) => void\n\nexport type RovingGroupInjectionContext = {\n currentTabbedId: Ref\n dir: Ref\n loop: Ref\n orientation: Ref\n tabIndex: Ref\n rovingFocusGroupRef: Ref\n rovingFocusGroupRootStyle: Ref\n onBlur: EventHandler\n onFocus: EventHandler\n onMousedown: EventHandler\n onItemFocus: (id: string) => void\n onItemShiftTab: () => void\n onKeydown: EventHandler\n}\n\nexport type RovingFocusGroupItemInjectionContext = {\n rovingFocusGroupItemRef: Ref\n tabIndex: Ref\n handleMousedown: EventHandler\n handleFocus: EventHandler\n handleKeydown: EventHandler\n}\n\nexport const ROVING_FOCUS_GROUP_INJECTION_KEY: InjectionKey =\n Symbol('elRovingFocusGroup')\n\nexport const ROVING_FOCUS_GROUP_ITEM_INJECTION_KEY: InjectionKey =\n Symbol('elRovingFocusGroupItem')\n","import { EVENT_CODE } from '@element-plus/constants'\nimport { getEventCode } from '@element-plus/utils'\n\nimport type { HTMLAttributes } from 'vue'\n\ntype Orientation = HTMLAttributes['aria-orientation']\ntype Direction = 'ltr' | 'rtl'\ntype FocusIntent = 'first' | 'last' | 'prev' | 'next'\n\nconst MAP_KEY_TO_FOCUS_INTENT: Record = {\n ArrowLeft: 'prev',\n ArrowUp: 'prev',\n ArrowRight: 'next',\n ArrowDown: 'next',\n PageUp: 'first',\n Home: 'first',\n PageDown: 'last',\n End: 'last',\n}\n\nconst getDirectionAwareKey = (key: string, dir?: Direction) => {\n if (dir !== 'rtl') return key\n\n switch (key) {\n case EVENT_CODE.right:\n return EVENT_CODE.left\n case EVENT_CODE.left:\n return EVENT_CODE.right\n default:\n return key\n }\n}\n\nexport const getFocusIntent = (\n event: KeyboardEvent,\n orientation?: Orientation,\n dir?: Direction\n) => {\n const code = getEventCode(event)\n const key = getDirectionAwareKey(code, dir)\n if (\n orientation === 'vertical' &&\n [EVENT_CODE.left, EVENT_CODE.right].includes(key)\n )\n return undefined\n if (\n orientation === 'horizontal' &&\n [EVENT_CODE.up, EVENT_CODE.down].includes(key)\n )\n return undefined\n return MAP_KEY_TO_FOCUS_INTENT[key]\n}\n\nexport const reorderArray = (array: T[], atIdx: number) => {\n return array.map((_, idx) => array[(idx + atIdx) % array.length])\n}\n\nexport const focusFirst = (elements: HTMLElement[]) => {\n const { activeElement: prevActive } = document\n\n for (const element of elements) {\n if (element === prevActive) return\n element.focus()\n if (prevActive !== document.activeElement) return\n }\n}\n","\n\n\n","\n\n\n","import type { PopperProps } from '@element-plus/components/popper'\nimport type { ComputedRef, InjectionKey, Ref } from 'vue'\n\nexport type ElDropdownInjectionContext = {\n contentRef: Ref\n role: ComputedRef\n triggerId: ComputedRef\n isUsingKeyboard: Ref\n onItemLeave: (e: PointerEvent) => void\n onItemEnter: (e: PointerEvent) => void\n handleClose: () => void\n}\n\nexport const DROPDOWN_INJECTION_KEY: InjectionKey =\n Symbol('elDropdown')\n\nexport const DROPDOWN_INSTANCE_INJECTION_KEY = 'elDropdown'\n","\n\n\n","\n\n\n","\n\n\n","import { computed, inject } from 'vue'\nimport { DROPDOWN_INSTANCE_INJECTION_KEY } from './tokens'\n\nimport type { IElDropdownInstance } from './dropdown'\n\nexport const useDropdown = () => {\n const elDropdown = inject(\n DROPDOWN_INSTANCE_INJECTION_KEY,\n {}\n )\n const _elDropdownSize = computed(() => elDropdown?.dropdownSize)\n\n return {\n elDropdown,\n _elDropdownSize,\n }\n}\n","\n\n\n","\n\n\n","import { withInstall, withNoopInstall } from '@element-plus/utils'\nimport Dropdown from './src/dropdown.vue'\nimport DropdownItem from './src/dropdown-item.vue'\nimport DropdownMenu from './src/dropdown-menu.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElDropdown: SFCWithInstall & {\n DropdownItem: typeof DropdownItem\n DropdownMenu: typeof DropdownMenu\n} = withInstall(Dropdown, {\n DropdownItem,\n DropdownMenu,\n})\nexport default ElDropdown\nexport const ElDropdownItem: SFCWithInstall =\n withNoopInstall(DropdownItem)\nexport const ElDropdownMenu: SFCWithInstall =\n withNoopInstall(DropdownMenu)\nexport * from './src/dropdown'\nexport * from './src/instance'\nexport * from './src/tokens'\n","'use strict';\nvar makeBuiltIn = require('../internals/make-built-in');\nvar defineProperty = require('../internals/object-define-property');\n\nmodule.exports = function (target, name, descriptor) {\n if (descriptor.get) makeBuiltIn(descriptor.get, name, { getter: true });\n if (descriptor.set) makeBuiltIn(descriptor.set, name, { setter: true });\n return defineProperty.f(target, name, descriptor);\n};\n","import arrayPush from './_arrayPush.js';\nimport getPrototype from './_getPrototype.js';\nimport getSymbols from './_getSymbols.js';\nimport stubArray from './stubArray.js';\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeGetSymbols = Object.getOwnPropertySymbols;\n\n/**\n * Creates an array of the own and inherited enumerable symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of symbols.\n */\nvar getSymbolsIn = !nativeGetSymbols ? stubArray : function(object) {\n var result = [];\n while (object) {\n arrayPush(result, getSymbols(object));\n object = getPrototype(object);\n }\n return result;\n};\n\nexport default getSymbolsIn;\n","'use strict';\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar TO_STRING_TAG = wellKnownSymbol('toStringTag');\nvar test = {};\n// eslint-disable-next-line unicorn/no-immediate-mutation -- ES3 syntax limitation\ntest[TO_STRING_TAG] = 'z';\n\nmodule.exports = String(test) === '[object z]';\n","import { isArray, isClient, isElement } from '@element-plus/utils'\n\nimport type {\n ComponentPublicInstance,\n DirectiveBinding,\n ObjectDirective,\n} from 'vue'\n\ntype DocumentHandler = (mouseup: T, mousedown: T) => void\ntype FlushList = Map<\n HTMLElement,\n {\n documentHandler: DocumentHandler\n bindingFn: (...args: unknown[]) => unknown\n }[]\n>\n\nconst nodeList: FlushList = new Map()\n\nif (isClient) {\n let startClick: MouseEvent | undefined\n document.addEventListener('mousedown', (e: MouseEvent) => (startClick = e))\n document.addEventListener('mouseup', (e: MouseEvent) => {\n if (startClick) {\n for (const handlers of nodeList.values()) {\n for (const { documentHandler } of handlers) {\n documentHandler(e as MouseEvent, startClick)\n }\n }\n startClick = undefined\n }\n })\n}\n\nfunction createDocumentHandler(\n el: HTMLElement,\n binding: DirectiveBinding\n): DocumentHandler {\n let excludes: HTMLElement[] = []\n if (isArray(binding.arg)) {\n excludes = binding.arg\n } else if (isElement(binding.arg)) {\n // due to current implementation on binding type is wrong the type casting is necessary here\n excludes.push(binding.arg as unknown as HTMLElement)\n }\n return function (mouseup, mousedown) {\n const popperRef = (\n binding.instance as ComponentPublicInstance<{\n popperRef: HTMLElement\n }>\n ).popperRef\n const mouseUpTarget = mouseup.target as Node\n const mouseDownTarget = mousedown?.target as Node\n const isBound = !binding || !binding.instance\n const isTargetExists = !mouseUpTarget || !mouseDownTarget\n const isContainedByEl =\n el.contains(mouseUpTarget) || el.contains(mouseDownTarget)\n const isSelf = el === mouseUpTarget\n\n const isTargetExcluded =\n (excludes.length &&\n excludes.some((item) => item?.contains(mouseUpTarget))) ||\n (excludes.length && excludes.includes(mouseDownTarget as HTMLElement))\n const isContainedByPopper =\n popperRef &&\n (popperRef.contains(mouseUpTarget) || popperRef.contains(mouseDownTarget))\n if (\n isBound ||\n isTargetExists ||\n isContainedByEl ||\n isSelf ||\n isTargetExcluded ||\n isContainedByPopper\n ) {\n return\n }\n binding.value(mouseup, mousedown)\n }\n}\n\nconst ClickOutside: ObjectDirective = {\n beforeMount(el: HTMLElement, binding: DirectiveBinding) {\n // there could be multiple handlers on the element\n if (!nodeList.has(el)) {\n nodeList.set(el, [])\n }\n\n nodeList.get(el)!.push({\n documentHandler: createDocumentHandler(el, binding),\n bindingFn: binding.value,\n })\n },\n updated(el: HTMLElement, binding: DirectiveBinding) {\n if (!nodeList.has(el)) {\n nodeList.set(el, [])\n }\n\n const handlers = nodeList.get(el)!\n const oldHandlerIndex = handlers.findIndex(\n (item) => item.bindingFn === binding.oldValue\n )\n const newHandler = {\n documentHandler: createDocumentHandler(el, binding),\n bindingFn: binding.value,\n }\n\n if (oldHandlerIndex >= 0) {\n // replace the old handler to the new handler\n handlers.splice(oldHandlerIndex, 1, newHandler)\n } else {\n handlers.push(newHandler)\n }\n },\n unmounted(el: HTMLElement) {\n // remove all listeners when a component unmounted\n nodeList.delete(el)\n },\n}\n\nexport default ClickOutside\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\n\nvar toString = uncurryThis({}.toString);\nvar stringSlice = uncurryThis(''.slice);\n\nmodule.exports = function (it) {\n return stringSlice(toString(it), 8, -1);\n};\n","'use strict';\nvar fails = require('../internals/fails');\n\nmodule.exports = !fails(function () {\n function F() { /* empty */ }\n F.prototype.constructor = null;\n // eslint-disable-next-line es/no-object-getprototypeof -- required for testing\n return Object.getPrototypeOf(new F()) !== F.prototype;\n});\n","import { isArray, isObject, isString } from '@vue/shared'\nimport { isNil } from 'lodash-unified'\n\nexport {\n isArray,\n isFunction,\n isObject,\n isString,\n isDate,\n isPromise,\n isSymbol,\n isPlainObject,\n} from '@vue/shared'\n\nexport const isUndefined = (val: any): val is undefined => val === undefined\nexport const isBoolean = (val: any): val is boolean => typeof val === 'boolean'\nexport const isNumber = (val: any): val is number => typeof val === 'number'\n\nexport const isEmpty = (val: unknown) =>\n (!val && val !== 0) ||\n (isArray(val) && val.length === 0) ||\n (isObject(val) && !Object.keys(val).length)\n\nexport const isElement = (e: unknown): e is Element => {\n if (typeof Element === 'undefined') return false\n return e instanceof Element\n}\n\nexport const isPropAbsent = (prop: unknown): prop is null | undefined =>\n isNil(prop)\n\nexport const isStringNumber = (val: string): boolean => {\n if (!isString(val)) {\n return false\n }\n return !Number.isNaN(Number(val))\n}\n\nexport const isWindow = (val: unknown): val is Window => val === window\n","import { buildProps, definePropType } from '@element-plus/utils'\nimport { popperContentProps } from '@element-plus/components/popper'\nimport { useAriaProps, useDelayedToggleProps } from '@element-plus/hooks'\nimport { teleportProps } from '@element-plus/components/teleport'\n\nimport type TooltipContent from './content.vue'\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\n\nexport const useTooltipContentProps = buildProps({\n ...useDelayedToggleProps,\n ...popperContentProps,\n /**\n * @description which element the tooltip CONTENT appends to\n */\n appendTo: {\n type: teleportProps.to.type,\n },\n /**\n * @description display content, can be overridden by `slot#content`\n */\n content: {\n type: String,\n default: '',\n },\n /**\n * @description whether `content` is treated as HTML string\n */\n rawContent: Boolean,\n /**\n * @description when tooltip inactive and `persistent` is `false` , popconfirm will be destroyed\n */\n persistent: Boolean,\n // because model toggle prop is generated dynamically\n // so the typing cannot be evaluated by typescript as type:\n // [name]: { type: Boolean, default: null }\n // so we need to declare that again for type checking.\n /**\n * @description visibility of Tooltip\n */\n visible: {\n type: definePropType(Boolean),\n default: null,\n },\n /**\n * @description animation name\n */\n transition: String,\n /**\n * @description whether tooltip content is teleported, if `true` it will be teleported to where `append-to` sets\n */\n teleported: {\n type: Boolean,\n default: true,\n },\n /**\n * @description whether Tooltip is disabled\n */\n disabled: Boolean,\n ...useAriaProps(['ariaLabel']),\n} as const)\n\nexport type ElTooltipContentProps = ExtractPropTypes<\n typeof useTooltipContentProps\n>\nexport type ElTooltipContentPropsPublic = __ExtractPublicPropTypes<\n typeof useTooltipContentProps\n>\n\nexport type TooltipContentInstance = InstanceType &\n unknown\n","import { camelize, hyphenate, capitalize as toCapitalize } from '@vue/shared'\n\nexport { camelize, hyphenate }\nexport const kebabCase = hyphenate\n\n/**\n * fork from {@link https://github.com/sindresorhus/escape-string-regexp}\n */\nexport const escapeStringRegexp = (string = '') =>\n string.replace(/[|\\\\{}()[\\]^$+*?.]/g, '\\\\$&').replace(/-/g, '\\\\x2d')\n\n// NOTE: improve capitalize types. Restore previous code after the [PR](https://github.com/vuejs/core/pull/6212) merge\nexport const capitalize = (str: T) =>\n toCapitalize(str) as Capitalize\n","'use strict';\nvar globalThis = require('../internals/global-this');\nvar uncurryThis = require('../internals/function-uncurry-this');\n\nvar Uint8Array = globalThis.Uint8Array;\nvar SyntaxError = globalThis.SyntaxError;\nvar parseInt = globalThis.parseInt;\nvar min = Math.min;\nvar NOT_HEX = /[^\\da-f]/i;\nvar exec = uncurryThis(NOT_HEX.exec);\nvar stringSlice = uncurryThis(''.slice);\n\nmodule.exports = function (string, into) {\n var stringLength = string.length;\n if (stringLength % 2 !== 0) throw new SyntaxError('String should be an even number of characters');\n var maxLength = into ? min(into.length, stringLength / 2) : stringLength / 2;\n var bytes = into || new Uint8Array(maxLength);\n var read = 0;\n var written = 0;\n while (written < maxLength) {\n var hexits = stringSlice(string, read, read += 2);\n if (exec(NOT_HEX, hexits)) throw new SyntaxError('String should only contain hex characters');\n bytes[written++] = parseInt(hexits, 16);\n }\n return { bytes: bytes, read: read };\n};\n","import Symbol from './_Symbol.js';\nimport isArguments from './isArguments.js';\nimport isArray from './isArray.js';\n\n/** Built-in value references. */\nvar spreadableSymbol = Symbol ? Symbol.isConcatSpreadable : undefined;\n\n/**\n * Checks if `value` is a flattenable `arguments` object or array.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is flattenable, else `false`.\n */\nfunction isFlattenable(value) {\n return isArray(value) || isArguments(value) ||\n !!(spreadableSymbol && value && value[spreadableSymbol]);\n}\n\nexport default isFlattenable;\n","import arrayPush from './_arrayPush.js';\nimport isFlattenable from './_isFlattenable.js';\n\n/**\n * The base implementation of `_.flatten` with support for restricting flattening.\n *\n * @private\n * @param {Array} array The array to flatten.\n * @param {number} depth The maximum recursion depth.\n * @param {boolean} [predicate=isFlattenable] The function invoked per iteration.\n * @param {boolean} [isStrict] Restrict to values that pass `predicate` checks.\n * @param {Array} [result=[]] The initial result value.\n * @returns {Array} Returns the new flattened array.\n */\nfunction baseFlatten(array, depth, predicate, isStrict, result) {\n var index = -1,\n length = array.length;\n\n predicate || (predicate = isFlattenable);\n result || (result = []);\n\n while (++index < length) {\n var value = array[index];\n if (depth > 0 && predicate(value)) {\n if (depth > 1) {\n // Recursively flatten arrays (susceptible to call stack limits).\n baseFlatten(value, depth - 1, predicate, isStrict, result);\n } else {\n arrayPush(result, value);\n }\n } else if (!isStrict) {\n result[result.length] = value;\n }\n }\n return result;\n}\n\nexport default baseFlatten;\n","!function(n,e){\"object\"==typeof exports&&\"undefined\"!=typeof module?module.exports=e():\"function\"==typeof define&&define.amd?define(e):(n=\"undefined\"!=typeof globalThis?globalThis:n||self).dayjs_plugin_localeData=e()}(this,(function(){\"use strict\";return function(n,e,t){var r=e.prototype,o=function(n){return n&&(n.indexOf?n:n.s)},u=function(n,e,t,r,u){var i=n.name?n:n.$locale(),a=o(i[e]),s=o(i[t]),f=a||s.map((function(n){return n.slice(0,r)}));if(!u)return f;var d=i.weekStart;return f.map((function(n,e){return f[(e+(d||0))%7]}))},i=function(){return t.Ls[t.locale()]},a=function(n,e){return n.formats[e]||function(n){return n.replace(/(\\[[^\\]]+])|(MMMM|MM|DD|dddd)/g,(function(n,e,t){return e||t.slice(1)}))}(n.formats[e.toUpperCase()])},s=function(){var n=this;return{months:function(e){return e?e.format(\"MMMM\"):u(n,\"months\")},monthsShort:function(e){return e?e.format(\"MMM\"):u(n,\"monthsShort\",\"months\",3)},firstDayOfWeek:function(){return n.$locale().weekStart||0},weekdays:function(e){return e?e.format(\"dddd\"):u(n,\"weekdays\")},weekdaysMin:function(e){return e?e.format(\"dd\"):u(n,\"weekdaysMin\",\"weekdays\",2)},weekdaysShort:function(e){return e?e.format(\"ddd\"):u(n,\"weekdaysShort\",\"weekdays\",3)},longDateFormat:function(e){return a(n.$locale(),e)},meridiem:this.$locale().meridiem,ordinal:this.$locale().ordinal}};r.localeData=function(){return s.bind(this)()},t.localeData=function(){var n=i();return{firstDayOfWeek:function(){return n.weekStart||0},weekdays:function(){return t.weekdays()},weekdaysShort:function(){return t.weekdaysShort()},weekdaysMin:function(){return t.weekdaysMin()},months:function(){return t.months()},monthsShort:function(){return t.monthsShort()},longDateFormat:function(e){return a(n,e)},meridiem:n.meridiem,ordinal:n.ordinal}},t.months=function(){return u(i(),\"months\")},t.monthsShort=function(){return u(i(),\"monthsShort\",\"months\",3)},t.weekdays=function(n){return u(i(),\"weekdays\",null,null,n)},t.weekdaysShort=function(n){return u(i(),\"weekdaysShort\",\"weekdays\",3,n)},t.weekdaysMin=function(n){return u(i(),\"weekdaysMin\",\"weekdays\",2,n)}}}));","/*!\n * Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com\n * License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License)\n * Copyright 2024 Fonticons, Inc.\n */\nconst prefix = \"fas\";\nconst fa0 = {\n prefix: 'fas',\n iconName: '0',\n icon: [320, 512, [], \"30\", \"M0 192C0 103.6 71.6 32 160 32s160 71.6 160 160l0 128c0 88.4-71.6 160-160 160S0 408.4 0 320L0 192zM160 96c-53 0-96 43-96 96l0 128c0 53 43 96 96 96s96-43 96-96l0-128c0-53-43-96-96-96z\"]\n};\nconst fa1 = {\n prefix: 'fas',\n iconName: '1',\n icon: [256, 512, [], \"31\", \"M160 64c0-11.8-6.5-22.6-16.9-28.2s-23-5-32.8 1.6l-96 64C-.5 111.2-4.4 131 5.4 145.8s29.7 18.7 44.4 8.9L96 123.8 96 416l-64 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l96 0 96 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-64 0 0-352z\"]\n};\nconst fa2 = {\n prefix: 'fas',\n iconName: '2',\n icon: [320, 512, [], \"32\", \"M142.9 96c-21.5 0-42.2 8.5-57.4 23.8L54.6 150.6c-12.5 12.5-32.8 12.5-45.3 0s-12.5-32.8 0-45.3L40.2 74.5C67.5 47.3 104.4 32 142.9 32C223 32 288 97 288 177.1c0 38.5-15.3 75.4-42.5 102.6L109.3 416 288 416c17.7 0 32 14.3 32 32s-14.3 32-32 32L32 480c-12.9 0-24.6-7.8-29.6-19.8s-2.2-25.7 6.9-34.9L200.2 234.5c15.2-15.2 23.8-35.9 23.8-57.4c0-44.8-36.3-81.1-81.1-81.1z\"]\n};\nconst fa3 = {\n prefix: 'fas',\n iconName: '3',\n icon: [320, 512, [], \"33\", \"M0 64C0 46.3 14.3 32 32 32l240 0c13.2 0 25 8.1 29.8 20.4s1.5 26.3-8.2 35.2L162.3 208l21.7 0c75.1 0 136 60.9 136 136s-60.9 136-136 136l-78.6 0C63 480 24.2 456 5.3 418.1l-1.9-3.8c-7.9-15.8-1.5-35 14.3-42.9s35-1.5 42.9 14.3l1.9 3.8c8.1 16.3 24.8 26.5 42.9 26.5l78.6 0c39.8 0 72-32.2 72-72s-32.2-72-72-72L80 272c-13.2 0-25-8.1-29.8-20.4s-1.5-26.3 8.2-35.2L189.7 96 32 96C14.3 96 0 81.7 0 64z\"]\n};\nconst fa4 = {\n prefix: 'fas',\n iconName: '4',\n icon: [384, 512, [], \"34\", \"M189 77.6c7.5-16 .7-35.1-15.3-42.6s-35.1-.7-42.6 15.3L3 322.4c-4.7 9.9-3.9 21.5 1.9 30.8S21 368 32 368l224 0 0 80c0 17.7 14.3 32 32 32s32-14.3 32-32l0-80 32 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-32 0 0-144c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 144L82.4 304 189 77.6z\"]\n};\nconst fa5 = {\n prefix: 'fas',\n iconName: '5',\n icon: [320, 512, [], \"35\", \"M32.5 58.3C35.3 43.1 48.5 32 64 32l192 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L90.7 96 70.3 208 184 208c75.1 0 136 60.9 136 136s-60.9 136-136 136l-83.5 0c-39.4 0-75.4-22.3-93-57.5l-4.1-8.2c-7.9-15.8-1.5-35 14.3-42.9s35-1.5 42.9 14.3l4.1 8.2c6.8 13.6 20.6 22.1 35.8 22.1l83.5 0c39.8 0 72-32.2 72-72s-32.2-72-72-72L32 272c-9.5 0-18.5-4.2-24.6-11.5s-8.6-16.9-6.9-26.2l32-176z\"]\n};\nconst fa6 = {\n prefix: 'fas',\n iconName: '6',\n icon: [320, 512, [], \"36\", \"M232.4 84.7c11.4-13.5 9.7-33.7-3.8-45.1s-33.7-9.7-45.1 3.8L38.6 214.7C14.7 242.9 1.1 278.4 .1 315.2c0 1.4-.1 2.9-.1 4.3l0 .5c0 88.4 71.6 160 160 160s160-71.6 160-160c0-85.5-67.1-155.4-151.5-159.8l63.9-75.6zM256 320A96 96 0 1 1 64 320a96 96 0 1 1 192 0z\"]\n};\nconst fa7 = {\n prefix: 'fas',\n iconName: '7',\n icon: [320, 512, [], \"37\", \"M0 64C0 46.3 14.3 32 32 32l256 0c11.5 0 22 6.1 27.7 16.1s5.7 22.2-.1 32.1l-224 384c-8.9 15.3-28.5 20.4-43.8 11.5s-20.4-28.5-11.5-43.8L232.3 96 32 96C14.3 96 0 81.7 0 64z\"]\n};\nconst fa8 = {\n prefix: 'fas',\n iconName: '8',\n icon: [320, 512, [], \"38\", \"M304 160c0-70.7-57.3-128-128-128l-32 0C73.3 32 16 89.3 16 160c0 34.6 13.7 66 36 89C20.5 272.3 0 309.8 0 352c0 70.7 57.3 128 128 128l64 0c70.7 0 128-57.3 128-128c0-42.2-20.5-79.7-52-103c22.3-23 36-54.4 36-89zM176.1 288l15.9 0c35.3 0 64 28.7 64 64s-28.7 64-64 64l-64 0c-35.3 0-64-28.7-64-64s28.7-64 64-64l15.9 0c0 0 .1 0 .1 0l32 0c0 0 .1 0 .1 0zm0-64c0 0 0 0 0 0l-32 0c0 0 0 0 0 0c-35.3 0-64-28.7-64-64c0-35.3 28.7-64 64-64l32 0c35.3 0 64 28.7 64 64c0 35.3-28.6 64-64 64z\"]\n};\nconst fa9 = {\n prefix: 'fas',\n iconName: '9',\n icon: [320, 512, [], \"39\", \"M64 192a96 96 0 1 0 192 0A96 96 0 1 0 64 192zm87.5 159.8C67.1 347.4 0 277.5 0 192C0 103.6 71.6 32 160 32s160 71.6 160 160c0 2.6-.1 5.3-.2 7.9c-1.7 35.7-15.2 70-38.4 97.4l-145 171.4c-11.4 13.5-31.6 15.2-45.1 3.8s-15.2-31.6-3.8-45.1l63.9-75.6z\"]\n};\nconst faFillDrip = {\n prefix: 'fas',\n iconName: 'fill-drip',\n icon: [576, 512, [], \"f576\", \"M41.4 9.4C53.9-3.1 74.1-3.1 86.6 9.4L168 90.7l53.1-53.1c28.1-28.1 73.7-28.1 101.8 0L474.3 189.1c28.1 28.1 28.1 73.7 0 101.8L283.9 481.4c-37.5 37.5-98.3 37.5-135.8 0L30.6 363.9c-37.5-37.5-37.5-98.3 0-135.8L122.7 136 41.4 54.6c-12.5-12.5-12.5-32.8 0-45.3zm176 221.3L168 181.3 75.9 273.4c-4.2 4.2-7 9.3-8.4 14.6l319.2 0 42.3-42.3c3.1-3.1 3.1-8.2 0-11.3L277.7 82.9c-3.1-3.1-8.2-3.1-11.3 0L213.3 136l49.4 49.4c12.5 12.5 12.5 32.8 0 45.3s-32.8 12.5-45.3 0zM512 512c-35.3 0-64-28.7-64-64c0-25.2 32.6-79.6 51.2-108.7c6-9.4 19.5-9.4 25.5 0C543.4 368.4 576 422.8 576 448c0 35.3-28.7 64-64 64z\"]\n};\nconst faArrowsToCircle = {\n prefix: 'fas',\n iconName: 'arrows-to-circle',\n icon: [640, 512, [], \"e4bd\", \"M9.4 9.4C21.9-3.1 42.1-3.1 54.6 9.4L160 114.7 160 96c0-17.7 14.3-32 32-32s32 14.3 32 32l0 96c0 4.3-.9 8.5-2.4 12.2c-1.6 3.7-3.8 7.3-6.9 10.3l-.1 .1c-3.1 3-6.6 5.3-10.3 6.9c-3.8 1.6-7.9 2.4-12.2 2.4l-96 0c-17.7 0-32-14.3-32-32s14.3-32 32-32l18.7 0L9.4 54.6C-3.1 42.1-3.1 21.9 9.4 9.4zM256 256a64 64 0 1 1 128 0 64 64 0 1 1 -128 0zM114.7 352L96 352c-17.7 0-32-14.3-32-32s14.3-32 32-32l96 0s0 0 0 0l.1 0c8.8 0 16.7 3.6 22.5 9.3l.1 .1c3 3.1 5.3 6.6 6.9 10.3c1.6 3.8 2.4 7.9 2.4 12.2l0 96c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-18.7L54.6 502.6c-12.5 12.5-32.8 12.5-45.3 0s-12.5-32.8 0-45.3L114.7 352zM416 96c0-17.7 14.3-32 32-32s32 14.3 32 32l0 18.7L585.4 9.4c12.5-12.5 32.8-12.5 45.3 0s12.5 32.8 0 45.3L525.3 160l18.7 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-96 0c-8.8 0-16.8-3.6-22.6-9.3l-.1-.1c-3-3.1-5.3-6.6-6.9-10.3s-2.4-7.8-2.4-12.2l0-.1s0 0 0 0l0-96zM525.3 352L630.6 457.4c12.5 12.5 12.5 32.8 0 45.3s-32.8 12.5-45.3 0L480 397.3l0 18.7c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-96s0 0 0 0l0-.1c0-4.3 .9-8.4 2.4-12.2c1.6-3.8 3.9-7.3 6.9-10.4c5.8-5.8 13.7-9.3 22.5-9.4l.1 0s0 0 0 0l96 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-18.7 0z\"]\n};\nconst faCircleChevronRight = {\n prefix: 'fas',\n iconName: 'circle-chevron-right',\n icon: [512, 512, [\"chevron-circle-right\"], \"f138\", \"M0 256a256 256 0 1 0 512 0A256 256 0 1 0 0 256zM241 377c-9.4 9.4-24.6 9.4-33.9 0s-9.4-24.6 0-33.9l87-87-87-87c-9.4-9.4-9.4-24.6 0-33.9s24.6-9.4 33.9 0L345 239c9.4 9.4 9.4 24.6 0 33.9L241 377z\"]\n};\nconst faChevronCircleRight = faCircleChevronRight;\nconst faAt = {\n prefix: 'fas',\n iconName: 'at',\n icon: [512, 512, [61946], \"40\", \"M256 64C150 64 64 150 64 256s86 192 192 192c17.7 0 32 14.3 32 32s-14.3 32-32 32C114.6 512 0 397.4 0 256S114.6 0 256 0S512 114.6 512 256l0 32c0 53-43 96-96 96c-29.3 0-55.6-13.2-73.2-33.9C320 371.1 289.5 384 256 384c-70.7 0-128-57.3-128-128s57.3-128 128-128c27.9 0 53.7 8.9 74.7 24.1c5.7-5 13.1-8.1 21.3-8.1c17.7 0 32 14.3 32 32l0 80 0 32c0 17.7 14.3 32 32 32s32-14.3 32-32l0-32c0-106-86-192-192-192zm64 192a64 64 0 1 0 -128 0 64 64 0 1 0 128 0z\"]\n};\nconst faTrashCan = {\n prefix: 'fas',\n iconName: 'trash-can',\n icon: [448, 512, [61460, \"trash-alt\"], \"f2ed\", \"M135.2 17.7C140.6 6.8 151.7 0 163.8 0L284.2 0c12.1 0 23.2 6.8 28.6 17.7L320 32l96 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L32 96C14.3 96 0 81.7 0 64S14.3 32 32 32l96 0 7.2-14.3zM32 128l384 0 0 320c0 35.3-28.7 64-64 64L96 512c-35.3 0-64-28.7-64-64l0-320zm96 64c-8.8 0-16 7.2-16 16l0 224c0 8.8 7.2 16 16 16s16-7.2 16-16l0-224c0-8.8-7.2-16-16-16zm96 0c-8.8 0-16 7.2-16 16l0 224c0 8.8 7.2 16 16 16s16-7.2 16-16l0-224c0-8.8-7.2-16-16-16zm96 0c-8.8 0-16 7.2-16 16l0 224c0 8.8 7.2 16 16 16s16-7.2 16-16l0-224c0-8.8-7.2-16-16-16z\"]\n};\nconst faTrashAlt = faTrashCan;\nconst faTextHeight = {\n prefix: 'fas',\n iconName: 'text-height',\n icon: [576, 512, [], \"f034\", \"M64 128l0-32 64 0 0 320-32 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l128 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-32 0 0-320 64 0 0 32c0 17.7 14.3 32 32 32s32-14.3 32-32l0-48c0-26.5-21.5-48-48-48L160 32 48 32C21.5 32 0 53.5 0 80l0 48c0 17.7 14.3 32 32 32s32-14.3 32-32zM502.6 41.4c-12.5-12.5-32.8-12.5-45.3 0l-64 64c-9.2 9.2-11.9 22.9-6.9 34.9s16.6 19.8 29.6 19.8l32 0 0 192-32 0c-12.9 0-24.6 7.8-29.6 19.8s-2.2 25.7 6.9 34.9l64 64c12.5 12.5 32.8 12.5 45.3 0l64-64c9.2-9.2 11.9-22.9 6.9-34.9s-16.6-19.8-29.6-19.8l-32 0 0-192 32 0c12.9 0 24.6-7.8 29.6-19.8s2.2-25.7-6.9-34.9l-64-64z\"]\n};\nconst faUserXmark = {\n prefix: 'fas',\n iconName: 'user-xmark',\n icon: [640, 512, [\"user-times\"], \"f235\", \"M96 128a128 128 0 1 1 256 0A128 128 0 1 1 96 128zM0 482.3C0 383.8 79.8 304 178.3 304l91.4 0C368.2 304 448 383.8 448 482.3c0 16.4-13.3 29.7-29.7 29.7L29.7 512C13.3 512 0 498.7 0 482.3zM471 143c9.4-9.4 24.6-9.4 33.9 0l47 47 47-47c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9l-47 47 47 47c9.4 9.4 9.4 24.6 0 33.9s-24.6 9.4-33.9 0l-47-47-47 47c-9.4 9.4-24.6 9.4-33.9 0s-9.4-24.6 0-33.9l47-47-47-47c-9.4-9.4-9.4-24.6 0-33.9z\"]\n};\nconst faUserTimes = faUserXmark;\nconst faStethoscope = {\n prefix: 'fas',\n iconName: 'stethoscope',\n icon: [576, 512, [129658], \"f0f1\", \"M142.4 21.9c5.6 16.8-3.5 34.9-20.2 40.5L96 71.1 96 192c0 53 43 96 96 96s96-43 96-96l0-120.9-26.1-8.7c-16.8-5.6-25.8-23.7-20.2-40.5s23.7-25.8 40.5-20.2l26.1 8.7C334.4 19.1 352 43.5 352 71.1L352 192c0 77.2-54.6 141.6-127.3 156.7C231 404.6 278.4 448 336 448c61.9 0 112-50.1 112-112l0-70.7c-28.3-12.3-48-40.5-48-73.3c0-44.2 35.8-80 80-80s80 35.8 80 80c0 32.8-19.7 61-48 73.3l0 70.7c0 97.2-78.8 176-176 176c-92.9 0-168.9-71.9-175.5-163.1C87.2 334.2 32 269.6 32 192L32 71.1c0-27.5 17.6-52 43.8-60.7l26.1-8.7c16.8-5.6 34.9 3.5 40.5 20.2zM480 224a32 32 0 1 0 0-64 32 32 0 1 0 0 64z\"]\n};\nconst faMessage = {\n prefix: 'fas',\n iconName: 'message',\n icon: [512, 512, [\"comment-alt\"], \"f27a\", \"M64 0C28.7 0 0 28.7 0 64L0 352c0 35.3 28.7 64 64 64l96 0 0 80c0 6.1 3.4 11.6 8.8 14.3s11.9 2.1 16.8-1.5L309.3 416 448 416c35.3 0 64-28.7 64-64l0-288c0-35.3-28.7-64-64-64L64 0z\"]\n};\nconst faCommentAlt = faMessage;\nconst faInfo = {\n prefix: 'fas',\n iconName: 'info',\n icon: [192, 512, [], \"f129\", \"M48 80a48 48 0 1 1 96 0A48 48 0 1 1 48 80zM0 224c0-17.7 14.3-32 32-32l64 0c17.7 0 32 14.3 32 32l0 224 32 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L32 512c-17.7 0-32-14.3-32-32s14.3-32 32-32l32 0 0-192-32 0c-17.7 0-32-14.3-32-32z\"]\n};\nconst faDownLeftAndUpRightToCenter = {\n prefix: 'fas',\n iconName: 'down-left-and-up-right-to-center',\n icon: [512, 512, [\"compress-alt\"], \"f422\", \"M439 7c9.4-9.4 24.6-9.4 33.9 0l32 32c9.4 9.4 9.4 24.6 0 33.9l-87 87 39 39c6.9 6.9 8.9 17.2 5.2 26.2s-12.5 14.8-22.2 14.8l-144 0c-13.3 0-24-10.7-24-24l0-144c0-9.7 5.8-18.5 14.8-22.2s19.3-1.7 26.2 5.2l39 39L439 7zM72 272l144 0c13.3 0 24 10.7 24 24l0 144c0 9.7-5.8 18.5-14.8 22.2s-19.3 1.7-26.2-5.2l-39-39L73 505c-9.4 9.4-24.6 9.4-33.9 0L7 473c-9.4-9.4-9.4-24.6 0-33.9l87-87L55 313c-6.9-6.9-8.9-17.2-5.2-26.2s12.5-14.8 22.2-14.8z\"]\n};\nconst faCompressAlt = faDownLeftAndUpRightToCenter;\nconst faExplosion = {\n prefix: 'fas',\n iconName: 'explosion',\n icon: [576, 512, [], \"e4e9\", \"M499.6 11.3c6.7-10.7 20.5-14.5 31.7-8.5s15.8 19.5 10.6 31L404.8 338.6c2.2 2.3 4.3 4.7 6.3 7.1l97.2-54.7c10.5-5.9 23.6-3.1 30.9 6.4s6.3 23-2.2 31.5l-87 87-71.4 0c-13.2-37.3-48.7-64-90.5-64s-77.4 26.7-90.5 64l-79.6 0L42.3 363.7c-9.7-6.7-13.1-19.6-7.9-30.3s17.4-15.9 28.7-12.4l97.2 30.4c3-3.9 6.1-7.7 9.4-11.3L107.4 236.3c-6.1-10.1-3.9-23.1 5.1-30.7s22.2-7.5 31.1 .1L246 293.6c1.5-.4 3-.8 4.5-1.1l13.6-142.7c1.2-12.3 11.5-21.7 23.9-21.7s22.7 9.4 23.9 21.7l13.5 141.9L499.6 11.3zM64 448s0 0 0 0l448 0s0 0 0 0l32 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L32 512c-17.7 0-32-14.3-32-32s14.3-32 32-32l32 0zM288 0c13.3 0 24 10.7 24 24l0 48c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-48c0-13.3 10.7-24 24-24z\"]\n};\nconst faFileLines = {\n prefix: 'fas',\n iconName: 'file-lines',\n icon: [384, 512, [128441, 128462, 61686, \"file-alt\", \"file-text\"], \"f15c\", \"M64 0C28.7 0 0 28.7 0 64L0 448c0 35.3 28.7 64 64 64l256 0c35.3 0 64-28.7 64-64l0-288-128 0c-17.7 0-32-14.3-32-32L224 0 64 0zM256 0l0 128 128 0L256 0zM112 256l160 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-160 0c-8.8 0-16-7.2-16-16s7.2-16 16-16zm0 64l160 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-160 0c-8.8 0-16-7.2-16-16s7.2-16 16-16zm0 64l160 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-160 0c-8.8 0-16-7.2-16-16s7.2-16 16-16z\"]\n};\nconst faFileAlt = faFileLines;\nconst faFileText = faFileLines;\nconst faWaveSquare = {\n prefix: 'fas',\n iconName: 'wave-square',\n icon: [640, 512, [], \"f83e\", \"M128 64c0-17.7 14.3-32 32-32l160 0c17.7 0 32 14.3 32 32l0 352 96 0 0-160c0-17.7 14.3-32 32-32l128 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-96 0 0 160c0 17.7-14.3 32-32 32l-160 0c-17.7 0-32-14.3-32-32l0-352-96 0 0 160c0 17.7-14.3 32-32 32L32 288c-17.7 0-32-14.3-32-32s14.3-32 32-32l96 0 0-160z\"]\n};\nconst faRing = {\n prefix: 'fas',\n iconName: 'ring',\n icon: [512, 512, [], \"f70b\", \"M64 208c0 7.8 4.4 18.7 17.1 30.3C126.5 214.1 188.9 200 256 200s129.5 14.1 174.9 38.3C443.6 226.7 448 215.8 448 208c0-12.3-10.8-32-47.9-50.6C364.9 139.8 314 128 256 128s-108.9 11.8-144.1 29.4C74.8 176 64 195.7 64 208zm192 40c-47 0-89.3 7.6-122.9 19.7C166.3 280.2 208.8 288 256 288s89.7-7.8 122.9-20.3C345.3 255.6 303 248 256 248zM0 208c0-49.6 39.4-85.8 83.3-107.8C129.1 77.3 190.3 64 256 64s126.9 13.3 172.7 36.2c43.9 22 83.3 58.2 83.3 107.8l0 96c0 49.6-39.4 85.8-83.3 107.8C382.9 434.7 321.7 448 256 448s-126.9-13.3-172.7-36.2C39.4 389.8 0 353.6 0 304l0-96z\"]\n};\nconst faBuildingUn = {\n prefix: 'fas',\n iconName: 'building-un',\n icon: [384, 512, [], \"e4d9\", \"M48 0C21.5 0 0 21.5 0 48L0 464c0 26.5 21.5 48 48 48l96 0 0-80c0-26.5 21.5-48 48-48s48 21.5 48 48l0 80 96 0c26.5 0 48-21.5 48-48l0-416c0-26.5-21.5-48-48-48L48 0zM64 240c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32zm112-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16zm80 16c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32zM237.3 71.1l34.7 52L272 80c0-8.8 7.2-16 16-16s16 7.2 16 16l0 96c0 7.1-4.6 13.3-11.4 15.3s-14-.6-17.9-6.4l-34.7-52 0 43.2c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-96c0-7.1 4.6-13.3 11.4-15.3s14 .6 17.9 6.4zM112 80l0 64c0 8.8 7.2 16 16 16s16-7.2 16-16l0-64c0-8.8 7.2-16 16-16s16 7.2 16 16l0 64c0 26.5-21.5 48-48 48s-48-21.5-48-48l0-64c0-8.8 7.2-16 16-16s16 7.2 16 16z\"]\n};\nconst faDiceThree = {\n prefix: 'fas',\n iconName: 'dice-three',\n icon: [448, 512, [9858], \"f527\", \"M64 32C28.7 32 0 60.7 0 96L0 416c0 35.3 28.7 64 64 64l320 0c35.3 0 64-28.7 64-64l0-320c0-35.3-28.7-64-64-64L64 32zm64 96a32 32 0 1 1 0 64 32 32 0 1 1 0-64zm64 128a32 32 0 1 1 64 0 32 32 0 1 1 -64 0zm128 64a32 32 0 1 1 0 64 32 32 0 1 1 0-64z\"]\n};\nconst faCalendarDays = {\n prefix: 'fas',\n iconName: 'calendar-days',\n icon: [448, 512, [\"calendar-alt\"], \"f073\", \"M128 0c17.7 0 32 14.3 32 32l0 32 128 0 0-32c0-17.7 14.3-32 32-32s32 14.3 32 32l0 32 48 0c26.5 0 48 21.5 48 48l0 48L0 160l0-48C0 85.5 21.5 64 48 64l48 0 0-32c0-17.7 14.3-32 32-32zM0 192l448 0 0 272c0 26.5-21.5 48-48 48L48 512c-26.5 0-48-21.5-48-48L0 192zm64 80l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0c-8.8 0-16 7.2-16 16zm128 0l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0c-8.8 0-16 7.2-16 16zm144-16c-8.8 0-16 7.2-16 16l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0zM64 400l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0c-8.8 0-16 7.2-16 16zm144-16c-8.8 0-16 7.2-16 16l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0zm112 16l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0c-8.8 0-16 7.2-16 16z\"]\n};\nconst faCalendarAlt = faCalendarDays;\nconst faAnchorCircleCheck = {\n prefix: 'fas',\n iconName: 'anchor-circle-check',\n icon: [640, 512, [], \"e4aa\", \"M320 96a32 32 0 1 1 -64 0 32 32 0 1 1 64 0zm21.1 80C367 158.8 384 129.4 384 96c0-53-43-96-96-96s-96 43-96 96c0 33.4 17 62.8 42.9 80L224 176c-17.7 0-32 14.3-32 32s14.3 32 32 32l32 0 0 208-48 0c-53 0-96-43-96-96l0-6.1 7 7c9.4 9.4 24.6 9.4 33.9 0s9.4-24.6 0-33.9L97 263c-9.4-9.4-24.6-9.4-33.9 0L7 319c-9.4 9.4-9.4 24.6 0 33.9s24.6 9.4 33.9 0l7-7 0 6.1c0 88.4 71.6 160 160 160l80 0 80 0c8.2 0 16.3-.6 24.2-1.8c-22.2-16.2-40.4-37.5-53-62.2L320 448l0-80 0-128 32 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-10.9 0zM640 368a144 144 0 1 0 -288 0 144 144 0 1 0 288 0zm-76.7-43.3c6.2 6.2 6.2 16.4 0 22.6l-72 72c-6.2 6.2-16.4 6.2-22.6 0l-40-40c-6.2-6.2-6.2-16.4 0-22.6s16.4-6.2 22.6 0L480 385.4l60.7-60.7c6.2-6.2 16.4-6.2 22.6 0z\"]\n};\nconst faBuildingCircleArrowRight = {\n prefix: 'fas',\n iconName: 'building-circle-arrow-right',\n icon: [640, 512, [], \"e4d1\", \"M0 48C0 21.5 21.5 0 48 0L336 0c26.5 0 48 21.5 48 48l0 184.2c-39.1 32.3-64 81.1-64 135.8c0 49.5 20.4 94.2 53.3 126.2C364.5 505.1 351.1 512 336 512l-96 0 0-80c0-26.5-21.5-48-48-48s-48 21.5-48 48l0 80-96 0c-26.5 0-48-21.5-48-48L0 48zM80 224c-8.8 0-16 7.2-16 16l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0zm80 16l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0c-8.8 0-16 7.2-16 16zm112-16c-8.8 0-16 7.2-16 16l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0zM64 112l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16L80 96c-8.8 0-16 7.2-16 16zM176 96c-8.8 0-16 7.2-16 16l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0zm80 16l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0c-8.8 0-16 7.2-16 16zm96 256a144 144 0 1 1 288 0 144 144 0 1 1 -288 0zm140.7-67.3c-6.2 6.2-6.2 16.4 0 22.6L521.4 352 432 352c-8.8 0-16 7.2-16 16s7.2 16 16 16l89.4 0-28.7 28.7c-6.2 6.2-6.2 16.4 0 22.6s16.4 6.2 22.6 0l56-56c6.2-6.2 6.2-16.4 0-22.6l-56-56c-6.2-6.2-16.4-6.2-22.6 0z\"]\n};\nconst faVolleyball = {\n prefix: 'fas',\n iconName: 'volleyball',\n icon: [512, 512, [127952, \"volleyball-ball\"], \"f45f\", \"M511.8 267.4c-26.1 8.7-53.4 13.8-81 15.1c9.2-105.3-31.5-204.2-103.2-272.4C434.1 41.1 512 139.5 512 256c0 3.8-.1 7.6-.2 11.4zm-3.9 34.7c-5.8 32-17.6 62-34.2 88.7c-97.5 48.5-217.7 42.6-311.9-24.5c23.7-36.2 55.4-67.7 94.5-91.8c79.9 43.2 170.1 50.8 251.6 27.6zm-236-55.5c-2.5-90.9-41.1-172.7-101.9-231.7C196.8 5.2 225.8 0 256 0c2.7 0 5.3 0 7.9 .1c90.8 60.2 145.7 167.2 134.7 282.3c-43.1-2.4-86.4-14.1-126.8-35.9zM138 28.8c20.6 18.3 38.7 39.4 53.7 62.6C95.9 136.1 30.6 220.8 7.3 316.9C2.5 297.4 0 277 0 256C0 157.2 56 71.5 138 28.8zm69.6 90.5c19.5 38.6 31 81.9 32.3 127.7C162.5 294.6 110.9 368.9 90.2 451C66 430.4 45.6 405.4 30.4 377.2c6.7-108.7 71.9-209.9 177.1-257.9zM256 512c-50.7 0-98-14.7-137.8-40.2c5.6-27 14.8-53.1 27.4-77.7C232.2 454.6 338.1 468.8 433 441c-46 44-108.3 71-177 71z\"]\n};\nconst faVolleyballBall = faVolleyball;\nconst faArrowsUpToLine = {\n prefix: 'fas',\n iconName: 'arrows-up-to-line',\n icon: [576, 512, [], \"e4c2\", \"M32 96l512 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L32 32C14.3 32 0 46.3 0 64S14.3 96 32 96zM9.4 233.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0L96 237.3 96 448c0 17.7 14.3 32 32 32s32-14.3 32-32l0-210.7 41.4 41.4c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3l-96-96c-12.5-12.5-32.8-12.5-45.3 0l-96 96zm320 45.3c12.5 12.5 32.8 12.5 45.3 0L416 237.3 416 448c0 17.7 14.3 32 32 32s32-14.3 32-32l0-210.7 41.4 41.4c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3l-96-96c-12.5-12.5-32.8-12.5-45.3 0l-96 96c-12.5 12.5-12.5 32.8 0 45.3z\"]\n};\nconst faSortDown = {\n prefix: 'fas',\n iconName: 'sort-down',\n icon: [320, 512, [\"sort-desc\"], \"f0dd\", \"M182.6 470.6c-12.5 12.5-32.8 12.5-45.3 0l-128-128c-9.2-9.2-11.9-22.9-6.9-34.9s16.6-19.8 29.6-19.8l256 0c12.9 0 24.6 7.8 29.6 19.8s2.2 25.7-6.9 34.9l-128 128z\"]\n};\nconst faSortDesc = faSortDown;\nconst faCircleMinus = {\n prefix: 'fas',\n iconName: 'circle-minus',\n icon: [512, 512, [\"minus-circle\"], \"f056\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM184 232l144 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-144 0c-13.3 0-24-10.7-24-24s10.7-24 24-24z\"]\n};\nconst faMinusCircle = faCircleMinus;\nconst faDoorOpen = {\n prefix: 'fas',\n iconName: 'door-open',\n icon: [576, 512, [], \"f52b\", \"M320 32c0-9.9-4.5-19.2-12.3-25.2S289.8-1.4 280.2 1l-179.9 45C79 51.3 64 70.5 64 92.5L64 448l-32 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l64 0 192 0 32 0 0-32 0-448zM256 256c0 17.7-10.7 32-24 32s-24-14.3-24-32s10.7-32 24-32s24 14.3 24 32zm96-128l96 0 0 352c0 17.7 14.3 32 32 32l64 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-32 0 0-320c0-35.3-28.7-64-64-64l-96 0 0 64z\"]\n};\nconst faRightFromBracket = {\n prefix: 'fas',\n iconName: 'right-from-bracket',\n icon: [512, 512, [\"sign-out-alt\"], \"f2f5\", \"M377.9 105.9L500.7 228.7c7.2 7.2 11.3 17.1 11.3 27.3s-4.1 20.1-11.3 27.3L377.9 406.1c-6.4 6.4-15 9.9-24 9.9c-18.7 0-33.9-15.2-33.9-33.9l0-62.1-128 0c-17.7 0-32-14.3-32-32l0-64c0-17.7 14.3-32 32-32l128 0 0-62.1c0-18.7 15.2-33.9 33.9-33.9c9 0 17.6 3.6 24 9.9zM160 96L96 96c-17.7 0-32 14.3-32 32l0 256c0 17.7 14.3 32 32 32l64 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-64 0c-53 0-96-43-96-96L0 128C0 75 43 32 96 32l64 0c17.7 0 32 14.3 32 32s-14.3 32-32 32z\"]\n};\nconst faSignOutAlt = faRightFromBracket;\nconst faAtom = {\n prefix: 'fas',\n iconName: 'atom',\n icon: [512, 512, [9883], \"f5d2\", \"M256 398.8c-11.8 5.1-23.4 9.7-34.9 13.5c16.7 33.8 31 35.7 34.9 35.7s18.1-1.9 34.9-35.7c-11.4-3.9-23.1-8.4-34.9-13.5zM446 256c33 45.2 44.3 90.9 23.6 128c-20.2 36.3-62.5 49.3-115.2 43.2c-22 52.1-55.6 84.8-98.4 84.8s-76.4-32.7-98.4-84.8c-52.7 6.1-95-6.8-115.2-43.2C21.7 346.9 33 301.2 66 256c-33-45.2-44.3-90.9-23.6-128c20.2-36.3 62.5-49.3 115.2-43.2C179.6 32.7 213.2 0 256 0s76.4 32.7 98.4 84.8c52.7-6.1 95 6.8 115.2 43.2c20.7 37.1 9.4 82.8-23.6 128zm-65.8 67.4c-1.7 14.2-3.9 28-6.7 41.2c31.8 1.4 38.6-8.7 40.2-11.7c2.3-4.2 7-17.9-11.9-48.1c-6.8 6.3-14 12.5-21.6 18.6zm-6.7-175.9c2.8 13.1 5 26.9 6.7 41.2c7.6 6.1 14.8 12.3 21.6 18.6c18.9-30.2 14.2-44 11.9-48.1c-1.6-2.9-8.4-13-40.2-11.7zM290.9 99.7C274.1 65.9 259.9 64 256 64s-18.1 1.9-34.9 35.7c11.4 3.9 23.1 8.4 34.9 13.5c11.8-5.1 23.4-9.7 34.9-13.5zm-159 88.9c1.7-14.3 3.9-28 6.7-41.2c-31.8-1.4-38.6 8.7-40.2 11.7c-2.3 4.2-7 17.9 11.9 48.1c6.8-6.3 14-12.5 21.6-18.6zM110.2 304.8C91.4 335 96 348.7 98.3 352.9c1.6 2.9 8.4 13 40.2 11.7c-2.8-13.1-5-26.9-6.7-41.2c-7.6-6.1-14.8-12.3-21.6-18.6zM336 256a80 80 0 1 0 -160 0 80 80 0 1 0 160 0zm-80-32a32 32 0 1 1 0 64 32 32 0 1 1 0-64z\"]\n};\nconst faSoap = {\n prefix: 'fas',\n iconName: 'soap',\n icon: [512, 512, [129532], \"e06e\", \"M208 96a48 48 0 1 0 0-96 48 48 0 1 0 0 96zM320 256a64 64 0 1 0 0-128 64 64 0 1 0 0 128zM416 32a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zm0 160c0 27.6-11.7 52.5-30.4 70.1C422.1 275.7 448 310.8 448 352c0 53-43 96-96 96l-192 0c-53 0-96-43-96-96s43-96 96-96l88.4 0c-15.2-17-24.4-39.4-24.4-64L96 192c-53 0-96 43-96 96L0 416c0 53 43 96 96 96l320 0c53 0 96-43 96-96l0-128c0-53-43-96-96-96zM160 288c-35.3 0-64 28.7-64 64s28.7 64 64 64l192 0c35.3 0 64-28.7 64-64s-28.7-64-64-64l-32 0-160 0z\"]\n};\nconst faIcons = {\n prefix: 'fas',\n iconName: 'icons',\n icon: [512, 512, [\"heart-music-camera-bolt\"], \"f86d\", \"M500.3 7.3C507.7 13.3 512 22.4 512 32l0 144c0 26.5-28.7 48-64 48s-64-21.5-64-48s28.7-48 64-48l0-57L352 90.2 352 208c0 26.5-28.7 48-64 48s-64-21.5-64-48s28.7-48 64-48l0-96c0-15.3 10.8-28.4 25.7-31.4l160-32c9.4-1.9 19.1 .6 26.6 6.6zM74.7 304l11.8-17.8c5.9-8.9 15.9-14.2 26.6-14.2l61.7 0c10.7 0 20.7 5.3 26.6 14.2L213.3 304l26.7 0c26.5 0 48 21.5 48 48l0 112c0 26.5-21.5 48-48 48L48 512c-26.5 0-48-21.5-48-48L0 352c0-26.5 21.5-48 48-48l26.7 0zM192 408a48 48 0 1 0 -96 0 48 48 0 1 0 96 0zM478.7 278.3L440.3 368l55.7 0c6.7 0 12.6 4.1 15 10.4s.6 13.3-4.4 17.7l-128 112c-5.6 4.9-13.9 5.3-19.9 .9s-8.2-12.4-5.3-19.2L391.7 400 336 400c-6.7 0-12.6-4.1-15-10.4s-.6-13.3 4.4-17.7l128-112c5.6-4.9 13.9-5.3 19.9-.9s8.2 12.4 5.3 19.2zm-339-59.2c-6.5 6.5-17 6.5-23 0L19.9 119.2c-28-29-26.5-76.9 5-103.9c27-23.5 68.4-19 93.4 6.5l10 10.5 9.5-10.5c25-25.5 65.9-30 93.9-6.5c31 27 32.5 74.9 4.5 103.9l-96.4 99.9z\"]\n};\nconst faHeartMusicCameraBolt = faIcons;\nconst faMicrophoneLinesSlash = {\n prefix: 'fas',\n iconName: 'microphone-lines-slash',\n icon: [640, 512, [\"microphone-alt-slash\"], \"f539\", \"M38.8 5.1C28.4-3.1 13.3-1.2 5.1 9.2S-1.2 34.7 9.2 42.9l592 464c10.4 8.2 25.5 6.3 33.7-4.1s6.3-25.5-4.1-33.7L472.1 344.7c15.2-26 23.9-56.3 23.9-88.7l0-40c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 24 0 16c0 21.2-5.1 41.1-14.2 58.7L416 300.8l0-44.8-57.1 0-34.5-27c2.9-3.1 7-5 11.6-5l80 0 0-32-80 0c-8.8 0-16-7.2-16-16s7.2-16 16-16l80 0 0-32-80 0c-8.8 0-16-7.2-16-16s7.2-16 16-16l80 0c0-53-43-96-96-96s-96 43-96 96l0 54.3L38.8 5.1zm362.5 407l-43.1-33.9C346.1 382 333.3 384 320 384c-70.7 0-128-57.3-128-128l0-8.7L144.7 210c-.5 1.9-.7 3.9-.7 6l0 40c0 89.1 66.2 162.7 152 174.4l0 33.6-48 0c-13.3 0-24 10.7-24 24s10.7 24 24 24l72 0 72 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-48 0 0-33.6c20.4-2.8 39.7-9.1 57.3-18.2z\"]\n};\nconst faMicrophoneAltSlash = faMicrophoneLinesSlash;\nconst faBridgeCircleCheck = {\n prefix: 'fas',\n iconName: 'bridge-circle-check',\n icon: [640, 512, [], \"e4c9\", \"M64 32C46.3 32 32 46.3 32 64s14.3 32 32 32l40 0 0 64-72 0 0 128c53 0 96 43 96 96l0 64c0 17.7 14.3 32 32 32l32 0c17.7 0 32-14.3 32-32l0-64c0-53 43-96 96-96c6.3 0 12.4 .6 18.3 1.7C367.1 231.8 426.9 192 496 192c42.5 0 81.6 15.1 112 40.2l0-72.2-72 0 0-64 40 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L64 32zM488 96l0 64-80 0 0-64 80 0zM360 96l0 64-80 0 0-64 80 0zM232 96l0 64-80 0 0-64 80 0zM640 368a144 144 0 1 0 -288 0 144 144 0 1 0 288 0zm-76.7-43.3c6.2 6.2 6.2 16.4 0 22.6l-72 72c-6.2 6.2-16.4 6.2-22.6 0l-40-40c-6.2-6.2-6.2-16.4 0-22.6s16.4-6.2 22.6 0L480 385.4l60.7-60.7c6.2-6.2 16.4-6.2 22.6 0z\"]\n};\nconst faPumpMedical = {\n prefix: 'fas',\n iconName: 'pump-medical',\n icon: [448, 512, [], \"e06a\", \"M128 32l0 96 128 0 0-32 60.1 0c4.2 0 8.3 1.7 11.3 4.7l33.9 33.9c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3L372.7 55.4c-15-15-35.4-23.4-56.6-23.4L256 32c0-17.7-14.3-32-32-32L160 0c-17.7 0-32 14.3-32 32zM117.4 160c-33.3 0-61 25.5-63.8 58.7L35 442.7C31.9 480 61.3 512 98.8 512l186.4 0c37.4 0 66.9-32 63.8-69.3l-18.7-224c-2.8-33.2-30.5-58.7-63.8-58.7l-149.1 0zM216 280l0 32 32 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-32 0 0 32c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-32-32 0c-13.3 0-24-10.7-24-24s10.7-24 24-24l32 0 0-32c0-13.3 10.7-24 24-24s24 10.7 24 24z\"]\n};\nconst faFingerprint = {\n prefix: 'fas',\n iconName: 'fingerprint',\n icon: [512, 512, [], \"f577\", \"M48 256C48 141.1 141.1 48 256 48c63.1 0 119.6 28.1 157.8 72.5c8.6 10.1 23.8 11.2 33.8 2.6s11.2-23.8 2.6-33.8C403.3 34.6 333.7 0 256 0C114.6 0 0 114.6 0 256l0 40c0 13.3 10.7 24 24 24s24-10.7 24-24l0-40zm458.5-52.9c-2.7-13-15.5-21.3-28.4-18.5s-21.3 15.5-18.5 28.4c2.9 13.9 4.5 28.3 4.5 43.1l0 40c0 13.3 10.7 24 24 24s24-10.7 24-24l0-40c0-18.1-1.9-35.8-5.5-52.9zM256 80c-19 0-37.4 3-54.5 8.6c-15.2 5-18.7 23.7-8.3 35.9c7.1 8.3 18.8 10.8 29.4 7.9c10.6-2.9 21.8-4.4 33.4-4.4c70.7 0 128 57.3 128 128l0 24.9c0 25.2-1.5 50.3-4.4 75.3c-1.7 14.6 9.4 27.8 24.2 27.8c11.8 0 21.9-8.6 23.3-20.3c3.3-27.4 5-55 5-82.7l0-24.9c0-97.2-78.8-176-176-176zM150.7 148.7c-9.1-10.6-25.3-11.4-33.9-.4C93.7 178 80 215.4 80 256l0 24.9c0 24.2-2.6 48.4-7.8 71.9C68.8 368.4 80.1 384 96.1 384c10.5 0 19.9-7 22.2-17.3c6.4-28.1 9.7-56.8 9.7-85.8l0-24.9c0-27.2 8.5-52.4 22.9-73.1c7.2-10.4 8-24.6-.2-34.2zM256 160c-53 0-96 43-96 96l0 24.9c0 35.9-4.6 71.5-13.8 106.1c-3.8 14.3 6.7 29 21.5 29c9.5 0 17.9-6.2 20.4-15.4c10.5-39 15.9-79.2 15.9-119.7l0-24.9c0-28.7 23.3-52 52-52s52 23.3 52 52l0 24.9c0 36.3-3.5 72.4-10.4 107.9c-2.7 13.9 7.7 27.2 21.8 27.2c10.2 0 19-7 21-17c7.7-38.8 11.6-78.3 11.6-118.1l0-24.9c0-53-43-96-96-96zm24 96c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 24.9c0 59.9-11 119.3-32.5 175.2l-5.9 15.3c-4.8 12.4 1.4 26.3 13.8 31s26.3-1.4 31-13.8l5.9-15.3C267.9 411.9 280 346.7 280 280.9l0-24.9z\"]\n};\nconst faHandPointRight = {\n prefix: 'fas',\n iconName: 'hand-point-right',\n icon: [512, 512, [], \"f0a4\", \"M480 96c17.7 0 32 14.3 32 32s-14.3 32-32 32l-208 0 0-64 208 0zM320 288c17.7 0 32 14.3 32 32s-14.3 32-32 32l-64 0c-17.7 0-32-14.3-32-32s14.3-32 32-32l64 0zm64-64c0 17.7-14.3 32-32 32l-48 0c-17.7 0-32-14.3-32-32s14.3-32 32-32l48 0c17.7 0 32 14.3 32 32zM288 384c17.7 0 32 14.3 32 32s-14.3 32-32 32l-64 0c-17.7 0-32-14.3-32-32s14.3-32 32-32l64 0zm-88-96l.6 0c-5.4 9.4-8.6 20.3-8.6 32c0 13.2 4 25.4 10.8 35.6C177.9 364.3 160 388.1 160 416c0 11.7 3.1 22.6 8.6 32l-8.6 0C71.6 448 0 376.4 0 288l0-61.7c0-42.4 16.9-83.1 46.9-113.1l11.6-11.6C82.5 77.5 115.1 64 149 64l27 0c35.3 0 64 28.7 64 64l0 88c0 22.1-17.9 40-40 40s-40-17.9-40-40l0-56c0-8.8-7.2-16-16-16s-16 7.2-16 16l0 56c0 39.8 32.2 72 72 72z\"]\n};\nconst faMagnifyingGlassLocation = {\n prefix: 'fas',\n iconName: 'magnifying-glass-location',\n icon: [512, 512, [\"search-location\"], \"f689\", \"M416 208c0 45.9-14.9 88.3-40 122.7L502.6 457.4c12.5 12.5 12.5 32.8 0 45.3s-32.8 12.5-45.3 0L330.7 376c-34.4 25.2-76.8 40-122.7 40C93.1 416 0 322.9 0 208S93.1 0 208 0S416 93.1 416 208zM288 176c0-44.2-35.8-80-80-80s-80 35.8-80 80c0 48.8 46.5 111.6 68.6 138.6c6 7.3 16.8 7.3 22.7 0c22.1-27 68.6-89.8 68.6-138.6zm-112 0a32 32 0 1 1 64 0 32 32 0 1 1 -64 0z\"]\n};\nconst faSearchLocation = faMagnifyingGlassLocation;\nconst faForwardStep = {\n prefix: 'fas',\n iconName: 'forward-step',\n icon: [320, 512, [\"step-forward\"], \"f051\", \"M52.5 440.6c-9.5 7.9-22.8 9.7-34.1 4.4S0 428.4 0 416L0 96C0 83.6 7.2 72.3 18.4 67s24.5-3.6 34.1 4.4l192 160L256 241l0-145c0-17.7 14.3-32 32-32s32 14.3 32 32l0 320c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-145-11.5 9.6-192 160z\"]\n};\nconst faStepForward = faForwardStep;\nconst faFaceSmileBeam = {\n prefix: 'fas',\n iconName: 'face-smile-beam',\n icon: [512, 512, [128522, \"smile-beam\"], \"f5b8\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM164.1 325.5C182 346.2 212.6 368 256 368s74-21.8 91.9-42.5c5.8-6.7 15.9-7.4 22.6-1.6s7.4 15.9 1.6 22.6C349.8 372.1 311.1 400 256 400s-93.8-27.9-116.1-53.5c-5.8-6.7-5.1-16.8 1.6-22.6s16.8-5.1 22.6 1.6zm53.5-96.7s0 0 0 0c0 0 0 0 0 0l-.2-.2c-.2-.2-.4-.5-.7-.9c-.6-.8-1.6-2-2.8-3.4c-2.5-2.8-6-6.6-10.2-10.3c-8.8-7.8-18.8-14-27.7-14s-18.9 6.2-27.7 14c-4.2 3.7-7.7 7.5-10.2 10.3c-1.2 1.4-2.2 2.6-2.8 3.4c-.3 .4-.6 .7-.7 .9l-.2 .2c0 0 0 0 0 0c0 0 0 0 0 0s0 0 0 0c-2.1 2.8-5.7 3.9-8.9 2.8s-5.5-4.1-5.5-7.6c0-17.9 6.7-35.6 16.6-48.8c9.8-13 23.9-23.2 39.4-23.2s29.6 10.2 39.4 23.2c9.9 13.2 16.6 30.9 16.6 48.8c0 3.4-2.2 6.5-5.5 7.6s-6.9 0-8.9-2.8c0 0 0 0 0 0s0 0 0 0zm160 0c0 0 0 0 0 0l-.2-.2c-.2-.2-.4-.5-.7-.9c-.6-.8-1.6-2-2.8-3.4c-2.5-2.8-6-6.6-10.2-10.3c-8.8-7.8-18.8-14-27.7-14s-18.9 6.2-27.7 14c-4.2 3.7-7.7 7.5-10.2 10.3c-1.2 1.4-2.2 2.6-2.8 3.4c-.3 .4-.6 .7-.7 .9l-.2 .2c0 0 0 0 0 0c0 0 0 0 0 0s0 0 0 0c-2.1 2.8-5.7 3.9-8.9 2.8s-5.5-4.1-5.5-7.6c0-17.9 6.7-35.6 16.6-48.8c9.8-13 23.9-23.2 39.4-23.2s29.6 10.2 39.4 23.2c9.9 13.2 16.6 30.9 16.6 48.8c0 3.4-2.2 6.5-5.5 7.6s-6.9 0-8.9-2.8c0 0 0 0 0 0s0 0 0 0s0 0 0 0z\"]\n};\nconst faSmileBeam = faFaceSmileBeam;\nconst faFlagCheckered = {\n prefix: 'fas',\n iconName: 'flag-checkered',\n icon: [448, 512, [127937], \"f11e\", \"M32 0C49.7 0 64 14.3 64 32l0 16 69-17.2c38.1-9.5 78.3-5.1 113.5 12.5c46.3 23.2 100.8 23.2 147.1 0l9.6-4.8C423.8 28.1 448 43.1 448 66.1l0 279.7c0 13.3-8.3 25.3-20.8 30l-34.7 13c-46.2 17.3-97.6 14.6-141.7-7.4c-37.9-19-81.3-23.7-122.5-13.4L64 384l0 96c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-80 0-66L0 64 0 32C0 14.3 14.3 0 32 0zM64 187.1l64-13.9 0 65.5L64 252.6 64 318l48.8-12.2c5.1-1.3 10.1-2.4 15.2-3.3l0-63.9 38.9-8.4c8.3-1.8 16.7-2.5 25.1-2.1l0-64c13.6 .4 27.2 2.6 40.4 6.4l23.6 6.9 0 66.7-41.7-12.3c-7.3-2.1-14.8-3.4-22.3-3.8l0 71.4c21.8 1.9 43.3 6.7 64 14.4l0-69.8 22.7 6.7c13.5 4 27.3 6.4 41.3 7.4l0-64.2c-7.8-.8-15.6-2.3-23.2-4.5l-40.8-12 0-62c-13-3.8-25.8-8.8-38.2-15c-8.2-4.1-16.9-7-25.8-8.8l0 72.4c-13-.4-26 .8-38.7 3.6L128 173.2 128 98 64 114l0 73.1zM320 335.7c16.8 1.5 33.9-.7 50-6.8l14-5.2 0-71.7-7.9 1.8c-18.4 4.3-37.3 5.7-56.1 4.5l0 77.4zm64-149.4l0-70.8c-20.9 6.1-42.4 9.1-64 9.1l0 69.4c13.9 1.4 28 .5 41.7-2.6l22.3-5.2z\"]\n};\nconst faFootball = {\n prefix: 'fas',\n iconName: 'football',\n icon: [512, 512, [127944, \"football-ball\"], \"f44e\", \"M247.5 25.4c-13.5 3.3-26.4 7.2-38.6 11.7C142.9 61.6 96.7 103.6 66 153.6C47.8 183.4 35.1 215.9 26.9 249L264.5 486.6c13.5-3.3 26.4-7.2 38.6-11.7c66-24.5 112.2-66.5 142.9-116.5c18.3-29.8 30.9-62.3 39.1-95.3L247.5 25.4zM495.2 205.3c6.1-56.8 1.4-112.2-7.7-156.4c-2.7-12.9-13-22.9-26.1-25.1c-58.2-9.7-109.9-12-155.6-7.9L495.2 205.3zM206.1 496L16.8 306.7c-6.1 56.8-1.4 112.2 7.7 156.4c2.7 12.9 13 22.9 26.1 25.1c58.2 9.7 109.9 12 155.6 7.9zm54.6-331.3c6.2-6.2 16.4-6.2 22.6 0l64 64c6.2 6.2 6.2 16.4 0 22.6s-16.4 6.2-22.6 0l-64-64c-6.2-6.2-6.2-16.4 0-22.6zm-48 48c6.2-6.2 16.4-6.2 22.6 0l64 64c6.2 6.2 6.2 16.4 0 22.6s-16.4 6.2-22.6 0l-64-64c-6.2-6.2-6.2-16.4 0-22.6zm-48 48c6.2-6.2 16.4-6.2 22.6 0l64 64c6.2 6.2 6.2 16.4 0 22.6s-16.4 6.2-22.6 0l-64-64c-6.2-6.2-6.2-16.4 0-22.6z\"]\n};\nconst faFootballBall = faFootball;\nconst faSchoolCircleExclamation = {\n prefix: 'fas',\n iconName: 'school-circle-exclamation',\n icon: [640, 512, [], \"e56c\", \"M337.8 5.4C327-1.8 313-1.8 302.2 5.4L166.3 96 48 96C21.5 96 0 117.5 0 144L0 464c0 26.5 21.5 48 48 48l272 0s0 0 0 0l-64 0 0-96c0-35.3 28.7-64 64-64l.3 0 .5 0c3.4-37.7 18.7-72.1 42.2-99.1C350.2 260 335.6 264 320 264c-48.6 0-88-39.4-88-88s39.4-88 88-88s88 39.4 88 88c0 18.3-5.6 35.3-15.1 49.4c29-21 64.6-33.4 103.1-33.4c59.5 0 112.1 29.6 144 74.8L640 144c0-26.5-21.5-48-48-48L473.7 96 337.8 5.4zM96 192l32 0c8.8 0 16 7.2 16 16l0 64c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-64c0-8.8 7.2-16 16-16zm0 128l32 0c8.8 0 16 7.2 16 16l0 64c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-64c0-8.8 7.2-16 16-16zM320 128c-8.8 0-16 7.2-16 16l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16s-7.2-16-16-16l-16 0 0-16c0-8.8-7.2-16-16-16zM496 512a144 144 0 1 0 0-288 144 144 0 1 0 0 288zm0-96a24 24 0 1 1 0 48 24 24 0 1 1 0-48zm0-144c8.8 0 16 7.2 16 16l0 80c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-80c0-8.8 7.2-16 16-16z\"]\n};\nconst faCrop = {\n prefix: 'fas',\n iconName: 'crop',\n icon: [512, 512, [], \"f125\", \"M448 109.3l54.6-54.6c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0L402.7 64 160 64l0 64 178.7 0L128 338.7 128 32c0-17.7-14.3-32-32-32S64 14.3 64 32l0 32L32 64C14.3 64 0 78.3 0 96s14.3 32 32 32l32 0 0 256c0 35.3 28.7 64 64 64l224 0 0-64-178.7 0L384 173.3 384 480c0 17.7 14.3 32 32 32s32-14.3 32-32l0-32 32 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-32 0 0-274.7z\"]\n};\nconst faAnglesDown = {\n prefix: 'fas',\n iconName: 'angles-down',\n icon: [448, 512, [\"angle-double-down\"], \"f103\", \"M246.6 470.6c-12.5 12.5-32.8 12.5-45.3 0l-160-160c-12.5-12.5-12.5-32.8 0-45.3s32.8-12.5 45.3 0L224 402.7 361.4 265.4c12.5-12.5 32.8-12.5 45.3 0s12.5 32.8 0 45.3l-160 160zm160-352l-160 160c-12.5 12.5-32.8 12.5-45.3 0l-160-160c-12.5-12.5-12.5-32.8 0-45.3s32.8-12.5 45.3 0L224 210.7 361.4 73.4c12.5-12.5 32.8-12.5 45.3 0s12.5 32.8 0 45.3z\"]\n};\nconst faAngleDoubleDown = faAnglesDown;\nconst faUsersRectangle = {\n prefix: 'fas',\n iconName: 'users-rectangle',\n icon: [640, 512, [], \"e594\", \"M96 0C43 0 0 43 0 96L0 416c0 53 43 96 96 96l448 0c53 0 96-43 96-96l0-320c0-53-43-96-96-96L96 0zM64 96c0-17.7 14.3-32 32-32l448 0c17.7 0 32 14.3 32 32l0 320c0 17.7-14.3 32-32 32L96 448c-17.7 0-32-14.3-32-32L64 96zm159.8 80a48 48 0 1 0 -96 0 48 48 0 1 0 96 0zM96 309.3c0 14.7 11.9 26.7 26.7 26.7l56.1 0c8-34.1 32.8-61.7 65.2-73.6c-7.5-4.1-16.2-6.4-25.3-6.4l-69.3 0C119.9 256 96 279.9 96 309.3zM461.2 336l56.1 0c14.7 0 26.7-11.9 26.7-26.7c0-29.5-23.9-53.3-53.3-53.3l-69.3 0c-9.2 0-17.8 2.3-25.3 6.4c32.4 11.9 57.2 39.5 65.2 73.6zM372 289c-3.9-.7-7.9-1-12-1l-80 0c-4.1 0-8.1 .3-12 1c-26 4.4-47.3 22.7-55.9 47c-2.7 7.5-4.1 15.6-4.1 24c0 13.3 10.7 24 24 24l176 0c13.3 0 24-10.7 24-24c0-8.4-1.4-16.5-4.1-24c-8.6-24.3-29.9-42.6-55.9-47zM512 176a48 48 0 1 0 -96 0 48 48 0 1 0 96 0zM320 256a64 64 0 1 0 0-128 64 64 0 1 0 0 128z\"]\n};\nconst faPeopleRoof = {\n prefix: 'fas',\n iconName: 'people-roof',\n icon: [640, 512, [], \"e537\", \"M335.5 4l288 160c15.4 8.6 21 28.1 12.4 43.5s-28.1 21-43.5 12.4L320 68.6 47.5 220c-15.4 8.6-34.9 3-43.5-12.4s-3-34.9 12.4-43.5L304.5 4c9.7-5.4 21.4-5.4 31.1 0zM320 160a40 40 0 1 1 0 80 40 40 0 1 1 0-80zM144 256a40 40 0 1 1 0 80 40 40 0 1 1 0-80zm312 40a40 40 0 1 1 80 0 40 40 0 1 1 -80 0zM226.9 491.4L200 441.5l0 38.5c0 17.7-14.3 32-32 32l-48 0c-17.7 0-32-14.3-32-32l0-38.5L61.1 491.4c-6.3 11.7-20.8 16-32.5 9.8s-16-20.8-9.8-32.5l37.9-70.3c15.3-28.5 45.1-46.3 77.5-46.3l19.5 0c16.3 0 31.9 4.5 45.4 12.6l33.6-62.3c15.3-28.5 45.1-46.3 77.5-46.3l19.5 0c32.4 0 62.1 17.8 77.5 46.3l33.6 62.3c13.5-8.1 29.1-12.6 45.4-12.6l19.5 0c32.4 0 62.1 17.8 77.5 46.3l37.9 70.3c6.3 11.7 1.9 26.2-9.8 32.5s-26.2 1.9-32.5-9.8L552 441.5l0 38.5c0 17.7-14.3 32-32 32l-48 0c-17.7 0-32-14.3-32-32l0-38.5-26.9 49.9c-6.3 11.7-20.8 16-32.5 9.8s-16-20.8-9.8-32.5l36.3-67.5c-1.7-1.7-3.2-3.6-4.3-5.8L376 345.5l0 54.5c0 17.7-14.3 32-32 32l-48 0c-17.7 0-32-14.3-32-32l0-54.5-26.9 49.9c-1.2 2.2-2.6 4.1-4.3 5.8l36.3 67.5c6.3 11.7 1.9 26.2-9.8 32.5s-26.2 1.9-32.5-9.8z\"]\n};\nconst faPeopleLine = {\n prefix: 'fas',\n iconName: 'people-line',\n icon: [640, 512, [], \"e534\", \"M360 72a40 40 0 1 0 -80 0 40 40 0 1 0 80 0zM144 208a40 40 0 1 0 0-80 40 40 0 1 0 0 80zM32 416c-17.7 0-32 14.3-32 32s14.3 32 32 32l576 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L32 416zM496 208a40 40 0 1 0 0-80 40 40 0 1 0 0 80zM200 313.5l26.9 49.9c6.3 11.7 20.8 16 32.5 9.8s16-20.8 9.8-32.5l-36.3-67.5c1.7-1.7 3.2-3.6 4.3-5.8L264 217.5l0 54.5c0 17.7 14.3 32 32 32l48 0c17.7 0 32-14.3 32-32l0-54.5 26.9 49.9c1.2 2.2 2.6 4.1 4.3 5.8l-36.3 67.5c-6.3 11.7-1.9 26.2 9.8 32.5s26.2 1.9 32.5-9.8L440 313.5l0 38.5c0 17.7 14.3 32 32 32l48 0c17.7 0 32-14.3 32-32l0-38.5 26.9 49.9c6.3 11.7 20.8 16 32.5 9.8s16-20.8 9.8-32.5l-37.9-70.3c-15.3-28.5-45.1-46.3-77.5-46.3l-19.5 0c-16.3 0-31.9 4.5-45.4 12.6l-33.6-62.3c-15.3-28.5-45.1-46.3-77.5-46.3l-19.5 0c-32.4 0-62.1 17.8-77.5 46.3l-33.6 62.3c-13.5-8.1-29.1-12.6-45.4-12.6l-19.5 0c-32.4 0-62.1 17.8-77.5 46.3L18.9 340.6c-6.3 11.7-1.9 26.2 9.8 32.5s26.2 1.9 32.5-9.8L88 313.5 88 352c0 17.7 14.3 32 32 32l48 0c17.7 0 32-14.3 32-32l0-38.5z\"]\n};\nconst faBeerMugEmpty = {\n prefix: 'fas',\n iconName: 'beer-mug-empty',\n icon: [512, 512, [\"beer\"], \"f0fc\", \"M32 64c0-17.7 14.3-32 32-32l288 0c17.7 0 32 14.3 32 32l0 32 51.2 0c42.4 0 76.8 34.4 76.8 76.8l0 102.1c0 30.4-17.9 57.9-45.6 70.2L384 381.7l0 34.3c0 35.3-28.7 64-64 64L96 480c-35.3 0-64-28.7-64-64L32 64zM384 311.6l56.4-25.1c4.6-2.1 7.6-6.6 7.6-11.7l0-102.1c0-7.1-5.7-12.8-12.8-12.8L384 160l0 151.6zM160 144c0-8.8-7.2-16-16-16s-16 7.2-16 16l0 224c0 8.8 7.2 16 16 16s16-7.2 16-16l0-224zm64 0c0-8.8-7.2-16-16-16s-16 7.2-16 16l0 224c0 8.8 7.2 16 16 16s16-7.2 16-16l0-224zm64 0c0-8.8-7.2-16-16-16s-16 7.2-16 16l0 224c0 8.8 7.2 16 16 16s16-7.2 16-16l0-224z\"]\n};\nconst faBeer = faBeerMugEmpty;\nconst faDiagramPredecessor = {\n prefix: 'fas',\n iconName: 'diagram-predecessor',\n icon: [512, 512, [], \"e477\", \"M448 416l0-64L64 352l0 64 384 0zm0 64L64 480c-35.3 0-64-28.7-64-64l0-64c0-35.3 28.7-64 64-64l384 0c35.3 0 64 28.7 64 64l0 64c0 35.3-28.7 64-64 64zM288 160c0 35.3-28.7 64-64 64L64 224c-35.3 0-64-28.7-64-64L0 96C0 60.7 28.7 32 64 32l144 0 16 0 144 0c44.2 0 80 35.8 80 80l0 16 38.1 0c21.4 0 32.1 25.9 17 41L433 239c-9.4 9.4-24.6 9.4-33.9 0L329 169c-15.1-15.1-4.4-41 17-41l38.1 0 0-16c0-8.8-7.2-16-16-16l-80 0 0 64z\"]\n};\nconst faArrowUpLong = {\n prefix: 'fas',\n iconName: 'arrow-up-long',\n icon: [384, 512, [\"long-arrow-up\"], \"f176\", \"M214.6 9.4c-12.5-12.5-32.8-12.5-45.3 0l-128 128c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0L160 109.3 160 480c0 17.7 14.3 32 32 32s32-14.3 32-32l0-370.7 73.4 73.4c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3l-128-128z\"]\n};\nconst faLongArrowUp = faArrowUpLong;\nconst faFireFlameSimple = {\n prefix: 'fas',\n iconName: 'fire-flame-simple',\n icon: [384, 512, [\"burn\"], \"f46a\", \"M372.5 256.5l-.7-1.9C337.8 160.8 282 76.5 209.1 8.5l-3.3-3C202.1 2 197.1 0 192 0s-10.1 2-13.8 5.5l-3.3 3C102 76.5 46.2 160.8 12.2 254.6l-.7 1.9C3.9 277.3 0 299.4 0 321.6C0 426.7 86.8 512 192 512s192-85.3 192-190.4c0-22.2-3.9-44.2-11.5-65.1zm-90.8 49.5c4.1 9.3 6.2 19.4 6.2 29.5c0 53-43 96.5-96 96.5s-96-43.5-96-96.5c0-10.1 2.1-20.3 6.2-29.5l1.9-4.3c15.8-35.4 37.9-67.7 65.3-95.1l8.9-8.9c3.6-3.6 8.5-5.6 13.6-5.6s10 2 13.6 5.6l8.9 8.9c27.4 27.4 49.6 59.7 65.3 95.1l1.9 4.3z\"]\n};\nconst faBurn = faFireFlameSimple;\nconst faPerson = {\n prefix: 'fas',\n iconName: 'person',\n icon: [320, 512, [129485, \"male\"], \"f183\", \"M112 48a48 48 0 1 1 96 0 48 48 0 1 1 -96 0zm40 304l0 128c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-223.1L59.4 304.5c-9.1 15.1-28.8 20-43.9 10.9s-20-28.8-10.9-43.9l58.3-97c17.4-28.9 48.6-46.6 82.3-46.6l29.7 0c33.7 0 64.9 17.7 82.3 46.6l58.3 97c9.1 15.1 4.2 34.8-10.9 43.9s-34.8 4.2-43.9-10.9L232 256.9 232 480c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-128-16 0z\"]\n};\nconst faMale = faPerson;\nconst faLaptop = {\n prefix: 'fas',\n iconName: 'laptop',\n icon: [640, 512, [128187], \"f109\", \"M128 32C92.7 32 64 60.7 64 96l0 256 64 0 0-256 384 0 0 256 64 0 0-256c0-35.3-28.7-64-64-64L128 32zM19.2 384C8.6 384 0 392.6 0 403.2C0 445.6 34.4 480 76.8 480l486.4 0c42.4 0 76.8-34.4 76.8-76.8c0-10.6-8.6-19.2-19.2-19.2L19.2 384z\"]\n};\nconst faFileCsv = {\n prefix: 'fas',\n iconName: 'file-csv',\n icon: [512, 512, [], \"f6dd\", \"M0 64C0 28.7 28.7 0 64 0L224 0l0 128c0 17.7 14.3 32 32 32l128 0 0 144-208 0c-35.3 0-64 28.7-64 64l0 144-48 0c-35.3 0-64-28.7-64-64L0 64zm384 64l-128 0L256 0 384 128zM200 352l16 0c22.1 0 40 17.9 40 40l0 8c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-8c0-4.4-3.6-8-8-8l-16 0c-4.4 0-8 3.6-8 8l0 80c0 4.4 3.6 8 8 8l16 0c4.4 0 8-3.6 8-8l0-8c0-8.8 7.2-16 16-16s16 7.2 16 16l0 8c0 22.1-17.9 40-40 40l-16 0c-22.1 0-40-17.9-40-40l0-80c0-22.1 17.9-40 40-40zm133.1 0l34.9 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-34.9 0c-7.2 0-13.1 5.9-13.1 13.1c0 5.2 3 9.9 7.8 12l37.4 16.6c16.3 7.2 26.8 23.4 26.8 41.2c0 24.9-20.2 45.1-45.1 45.1L304 512c-8.8 0-16-7.2-16-16s7.2-16 16-16l42.9 0c7.2 0 13.1-5.9 13.1-13.1c0-5.2-3-9.9-7.8-12l-37.4-16.6c-16.3-7.2-26.8-23.4-26.8-41.2c0-24.9 20.2-45.1 45.1-45.1zm98.9 0c8.8 0 16 7.2 16 16l0 31.6c0 23 5.5 45.6 16 66c10.5-20.3 16-42.9 16-66l0-31.6c0-8.8 7.2-16 16-16s16 7.2 16 16l0 31.6c0 34.7-10.3 68.7-29.6 97.6l-5.1 7.7c-3 4.5-8 7.1-13.3 7.1s-10.3-2.7-13.3-7.1l-5.1-7.7c-19.3-28.9-29.6-62.9-29.6-97.6l0-31.6c0-8.8 7.2-16 16-16z\"]\n};\nconst faMenorah = {\n prefix: 'fas',\n iconName: 'menorah',\n icon: [640, 512, [], \"f676\", \"M20.8 7.4C22.8 2.9 27.1 0 32 0s9.2 2.9 11.2 7.4L61.3 49.7c1.8 4.1 2.7 8.6 2.7 13.1L64 64c0 17.7-14.3 32-32 32S0 81.7 0 64l0-1.2c0-4.5 .9-8.9 2.7-13.1L20.8 7.4zm96 0C118.8 2.9 123.1 0 128 0s9.2 2.9 11.2 7.4l18.2 42.4c1.8 4.1 2.7 8.6 2.7 13.1l0 1.2c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-1.2c0-4.5 .9-8.9 2.7-13.1L116.8 7.4zm77.8 42.4L212.8 7.4C214.8 2.9 219.1 0 224 0s9.2 2.9 11.2 7.4l18.2 42.4c1.8 4.1 2.7 8.6 2.7 13.1l0 1.2c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-1.2c0-4.5 .9-8.9 2.7-13.1zM308.8 7.4C310.8 2.9 315.1 0 320 0s9.2 2.9 11.2 7.4l18.2 42.4c1.8 4.1 2.7 8.6 2.7 13.1l0 1.2c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-1.2c0-4.5 .9-8.9 2.7-13.1L308.8 7.4zm77.8 42.4L404.8 7.4C406.8 2.9 411.1 0 416 0s9.2 2.9 11.2 7.4l18.2 42.4c1.8 4.1 2.7 8.6 2.7 13.1l0 1.2c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-1.2c0-4.5 .9-8.9 2.7-13.1zM500.8 7.4C502.8 2.9 507.1 0 512 0s9.2 2.9 11.2 7.4l18.2 42.4c1.8 4.1 2.7 8.6 2.7 13.1l0 1.2c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-1.2c0-4.5 .9-8.9 2.7-13.1L500.8 7.4zm77.8 42.4L596.8 7.4C598.8 2.9 603.1 0 608 0s9.2 2.9 11.2 7.4l18.2 42.4c1.8 4.1 2.7 8.6 2.7 13.1l0 1.2c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-1.2c0-4.5 .9-8.9 2.7-13.1zM32 128c17.7 0 32 14.3 32 32l0 128c0 17.7 14.3 32 32 32l192 0 0-160c0-17.7 14.3-32 32-32s32 14.3 32 32l0 160 192 0c17.7 0 32-14.3 32-32l0-128c0-17.7 14.3-32 32-32s32 14.3 32 32l0 128c0 53-43 96-96 96l-192 0 0 64 128 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-160 0-160 0c-17.7 0-32-14.3-32-32s14.3-32 32-32l128 0 0-64L96 384c-53 0-96-43-96-96L0 160c0-17.7 14.3-32 32-32zm96 0c17.7 0 32 14.3 32 32l0 96 0 32-64 0 0-32 0-96c0-17.7 14.3-32 32-32zm96 0c17.7 0 32 14.3 32 32l0 96 0 32-64 0 0-32 0-96c0-17.7 14.3-32 32-32zm192 0c17.7 0 32 14.3 32 32l0 96 0 32-64 0 0-32 0-96c0-17.7 14.3-32 32-32zm96 0c17.7 0 32 14.3 32 32l0 96 0 32-64 0 0-32 0-96c0-17.7 14.3-32 32-32z\"]\n};\nconst faTruckPlane = {\n prefix: 'fas',\n iconName: 'truck-plane',\n icon: [640, 512, [], \"e58f\", \"M200 0c-30.6 0-56 54.7-56 86.1l0 106.5L7.8 274.3C2.9 277.2 0 282.4 0 288l0 64c0 5.1 2.4 9.8 6.4 12.8s9.3 3.9 14.1 2.5l123.4-37 0 81.2-50 40c-3.8 3-6 7.6-6 12.5l0 32c0 5.1 2.5 10 6.6 13s9.5 3.8 14.4 2.2L200 480.9 290.4 511c-1.6-4.7-2.4-9.8-2.4-15l0-32.6c-18.2-10.5-30.7-29.7-31.9-51.8l-.1-.1 0-3.5 0-82.5L256 184l0-1.1s0 0 0 0l0-96.9C256 54.7 231.5 0 200 0zm88 176l0 224c0 20.9 13.4 38.7 32 45.3l0 42.7c0 13.3 10.7 24 24 24l16 0c13.3 0 24-10.7 24-24l0-40 160 0 0 40c0 13.3 10.7 24 24 24l16 0c13.3 0 24-10.7 24-24l0-42.7c18.6-6.6 32-24.4 32-45.3l0-224c0-26.5-21.5-48-48-48l-256 0c-26.5 0-48 21.5-48 48zm79.8 78.7c3.3-8.7 11.2-14.7 20.5-14.7l151.4 0c9.2 0 17.2 6 20.5 14.7L576 304l-224 0 15.8-49.3zM568 352a24 24 0 1 1 0 48 24 24 0 1 1 0-48zM336 376a24 24 0 1 1 48 0 24 24 0 1 1 -48 0z\"]\n};\nconst faRecordVinyl = {\n prefix: 'fas',\n iconName: 'record-vinyl',\n icon: [512, 512, [], \"f8d9\", \"M0 256a256 256 0 1 1 512 0A256 256 0 1 1 0 256zm256-96a96 96 0 1 1 0 192 96 96 0 1 1 0-192zm0 224a128 128 0 1 0 0-256 128 128 0 1 0 0 256zm0-96a32 32 0 1 0 0-64 32 32 0 1 0 0 64z\"]\n};\nconst faFaceGrinStars = {\n prefix: 'fas',\n iconName: 'face-grin-stars',\n icon: [512, 512, [129321, \"grin-stars\"], \"f587\", \"M0 256a256 256 0 1 1 512 0A256 256 0 1 1 0 256zm407.4 75.5c5-11.8-7-22.5-19.3-18.7c-39.7 12.2-84.5 19-131.8 19s-92.1-6.8-131.8-19c-12.3-3.8-24.3 6.9-19.3 18.7c25 59.1 83.2 100.5 151.1 100.5s126.2-41.4 151.1-100.5zM160 120c-3.1 0-5.9 1.8-7.2 4.6l-16.6 34.7-38.1 5c-3.1 .4-5.6 2.5-6.6 5.5s-.1 6.2 2.1 8.3l27.9 26.5-7 37.8c-.6 3 .7 6.1 3.2 7.9s5.8 2 8.5 .6L160 232.5l33.8 18.3c2.7 1.5 6 1.3 8.5-.6s3.7-4.9 3.2-7.9l-7-37.8L226.4 178c2.2-2.1 3.1-5.3 2.1-8.3s-3.5-5.1-6.6-5.5l-38.1-5-16.6-34.7c-1.3-2.8-4.1-4.6-7.2-4.6zm192 0c-3.1 0-5.9 1.8-7.2 4.6l-16.6 34.7-38.1 5c-3.1 .4-5.6 2.5-6.6 5.5s-.1 6.2 2.1 8.3l27.9 26.5-7 37.8c-.6 3 .7 6.1 3.2 7.9s5.8 2 8.5 .6L352 232.5l33.8 18.3c2.7 1.5 6 1.3 8.5-.6s3.7-4.9 3.2-7.9l-7-37.8L418.4 178c2.2-2.1 3.1-5.3 2.1-8.3s-3.5-5.1-6.6-5.5l-38.1-5-16.6-34.7c-1.3-2.8-4.1-4.6-7.2-4.6z\"]\n};\nconst faGrinStars = faFaceGrinStars;\nconst faBong = {\n prefix: 'fas',\n iconName: 'bong',\n icon: [448, 512, [], \"f55c\", \"M160 208.5c0 29.1-15.6 53.9-37.2 67.8c-17.2 11.1-31.5 26.1-41.7 43.7l221.8 0c-10.2-17.6-24.5-32.6-41.7-43.7c-21.6-13.9-37.2-38.7-37.2-67.8L224 64l-64 0 0 144.5zM288 64l0 144.5c0 5.7 3.1 10.9 7.9 14c11.2 7.2 21.5 15.5 30.9 24.8L366.1 208l-7-7c-9.4-9.4-9.4-24.6 0-33.9s24.6-9.4 33.9 0l24 24 24 24c9.4 9.4 9.4 24.6 0 33.9s-24.6 9.4-33.9 0l-7-7-43.3 43.3C374 314.1 384 347.9 384 384c0 39.4-11.9 76.1-32.2 106.5c-9.6 14.4-26.5 21.5-43.8 21.5L76.1 512c-17.3 0-34.2-7.1-43.8-21.5C11.9 460.1 0 423.4 0 384c0-67.8 35.1-127.3 88.1-161.5c4.8-3.1 7.9-8.3 7.9-14L96 64C78.3 64 64 49.7 64 32S78.3 0 96 0l16 0L272 0l16 0c17.7 0 32 14.3 32 32s-14.3 32-32 32z\"]\n};\nconst faSpaghettiMonsterFlying = {\n prefix: 'fas',\n iconName: 'spaghetti-monster-flying',\n icon: [640, 512, [\"pastafarianism\"], \"f67b\", \"M208 64a16 16 0 1 0 -32 0 16 16 0 1 0 32 0zm48 0c0 16.2-6 31.1-16 42.3l15.6 31.2c18.7-6 39.9-9.5 64.4-9.5s45.8 3.5 64.4 9.5L400 106.3C390 95.1 384 80.2 384 64c0-35.3 28.7-64 64-64s64 28.7 64 64s-28.7 64-64 64c-1.7 0-3.4-.1-5.1-.2L427.8 158c21.1 13.6 37.7 30.2 51.4 46.4c7.1 8.3 13.5 16.6 19.3 24l1.4 1.8c6.3 8.1 11.6 14.8 16.7 20.4C527.3 262.3 532.7 264 536 264c2.5 0 4.3-.6 7.1-3.3c3.7-3.5 7.1-8.8 12.5-17.4l.6-.9c4.6-7.4 11-17.6 19.4-25.7c9.7-9.3 22.9-16.7 40.4-16.7c13.3 0 24 10.7 24 24s-10.7 24-24 24c-2.5 0-4.3 .6-7.1 3.3c-3.7 3.5-7.1 8.8-12.5 17.4l-.6 .9c-4.6 7.4-11 17.6-19.4 25.7c-9.7 9.3-22.9 16.7-40.4 16.7c-18.5 0-32.9-8.5-44.3-18.6c-3.1 4-6.6 8.3-10.5 12.7c1.4 4.3 2.8 8.5 4 12.5c.9 3 1.8 5.8 2.6 8.6c3 9.8 5.5 18.2 8.6 25.9c3.9 9.8 7.4 15.4 10.8 18.5c2.6 2.4 5.9 4.3 12.8 4.3c8.7 0 16.9-4.2 33.7-13.2c15-8 35.7-18.8 62.3-18.8c13.3 0 24 10.7 24 24s-10.7 24-24 24c-13.4 0-24.7 5.2-39.7 13.2c-1 .6-2.1 1.1-3.2 1.7C559.9 414 541.4 424 520 424c-18.4 0-33.6-6.1-45.5-17.2c-11.1-10.3-17.9-23.7-22.7-36c-3.6-9-6.7-19.1-9.5-28.5c-16.4 12.3-36.1 23.6-58.9 31.3c3.6 10.8 8.4 23.5 14.4 36.2c7.5 15.9 16.2 30.4 25.8 40.5C433 460.5 441.2 464 448 464c13.3 0 24 10.7 24 24s-10.7 24-24 24c-25.2 0-45-13.5-59.5-28.8c-14.5-15.4-25.7-34.9-34.2-53c-8-17-14.1-33.8-18.3-46.9c-5.2 .4-10.6 .6-16 .6s-10.8-.2-16-.6c-4.2 13-10.3 29.9-18.3 46.9c-8.5 18.1-19.8 37.6-34.2 53C237 498.5 217.2 512 192 512c-13.3 0-24-10.7-24-24s10.7-24 24-24c6.8 0 15-3.5 24.5-13.7c9.5-10.1 18.3-24.6 25.8-40.5c5.9-12.6 10.7-25.4 14.4-36.2c-22.8-7.7-42.5-19-58.9-31.3c-2.9 9.4-6 19.5-9.5 28.5c-4.8 12.2-11.6 25.6-22.7 36C153.6 417.9 138.4 424 120 424c-21.4 0-39.9-10-53.1-17.1c0 0 0 0 0 0c-1.1-.6-2.2-1.2-3.2-1.7c-15-8-26.3-13.2-39.7-13.2c-13.3 0-24-10.7-24-24s10.7-24 24-24c26.6 0 47.3 10.8 62.3 18.8c16.8 9 25 13.2 33.7 13.2c6.8 0 10.2-1.9 12.8-4.3c3.4-3.2 7-8.8 10.8-18.5c3-7.7 5.6-16.1 8.6-25.9c.8-2.7 1.7-5.6 2.6-8.6c1.2-4 2.6-8.2 4-12.5c-3.9-4.5-7.4-8.8-10.5-12.7C136.9 303.5 122.5 312 104 312c-17.5 0-30.7-7.4-40.4-16.7c-8.4-8.1-14.8-18.3-19.4-25.7l-.6-.9c-5.4-8.6-8.8-13.9-12.5-17.4c-2.8-2.7-4.6-3.3-7.1-3.3c-13.3 0-24-10.7-24-24s10.7-24 24-24c17.5 0 30.7 7.4 40.4 16.7c8.4 8.1 14.8 18.3 19.4 25.7l.6 .9c5.4 8.6 8.8 13.9 12.5 17.4c2.8 2.7 4.6 3.3 7.1 3.3c3.3 0 8.7-1.7 19.4-13.4c5.1-5.6 10.4-12.3 16.7-20.4l1.4-1.8c5.8-7.4 12.2-15.7 19.3-24c13.8-16.2 30.3-32.8 51.4-46.4l-15.1-30.2c-1.7 .1-3.4 .2-5.1 .2c-35.3 0-64-28.7-64-64s28.7-64 64-64s64 28.7 64 64zm208 0a16 16 0 1 0 -32 0 16 16 0 1 0 32 0z\"]\n};\nconst faPastafarianism = faSpaghettiMonsterFlying;\nconst faArrowDownUpAcrossLine = {\n prefix: 'fas',\n iconName: 'arrow-down-up-across-line',\n icon: [576, 512, [], \"e4af\", \"M137.4 502.6c12.5 12.5 32.8 12.5 45.3 0l96-96c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0L192 402.7 192 288l352 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-96 0 0-114.7 41.4 41.4c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3l-96-96c-12.5-12.5-32.8-12.5-45.3 0l-96 96c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0L384 109.3 384 224l-192 0-64 0-96 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l96 0 0 114.7L86.6 361.4c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3l96 96zM128 192l64 0 0-128c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 128zM448 320l-64 0 0 128c0 17.7 14.3 32 32 32s32-14.3 32-32l0-128z\"]\n};\nconst faSpoon = {\n prefix: 'fas',\n iconName: 'spoon',\n icon: [512, 512, [129348, 61873, \"utensil-spoon\"], \"f2e5\", \"M245.8 220.9c-14.5-17.6-21.8-39.2-21.8-60.8C224 80 320 0 416 0c53 0 96 43 96 96c0 96-80 192-160.2 192c-21.6 0-43.2-7.3-60.8-21.8L54.6 502.6c-12.5 12.5-32.8 12.5-45.3 0s-12.5-32.8 0-45.3L245.8 220.9z\"]\n};\nconst faUtensilSpoon = faSpoon;\nconst faJarWheat = {\n prefix: 'fas',\n iconName: 'jar-wheat',\n icon: [320, 512, [], \"e517\", \"M32 32C32 14.3 46.3 0 64 0L256 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L64 64C46.3 64 32 49.7 32 32zM0 160c0-35.3 28.7-64 64-64l192 0c35.3 0 64 28.7 64 64l0 288c0 35.3-28.7 64-64 64L64 512c-35.3 0-64-28.7-64-64L0 160zm112 0l-42.2 0c-3.2 0-5.8 2.6-5.8 5.8C64 198 90 224 122.2 224l21.8 0 32 0 21.8 0c32.1 0 58.2-26 58.2-58.2c0-3.2-2.6-5.8-5.8-5.8L208 160c-19.1 0-36.3 8.4-48 21.7c-11.7-13.3-28.9-21.7-48-21.7zm48 117.7c-11.7-13.3-28.9-21.7-48-21.7l-42.2 0c-3.2 0-5.8 2.6-5.8 5.8C64 294 90 320 122.2 320l21.8 0 32 0 21.8 0c32.1 0 58.2-26 58.2-58.2c0-3.2-2.6-5.8-5.8-5.8L208 256c-19.1 0-36.3 8.4-48 21.7zM112 352l-42.2 0c-3.2 0-5.8 2.6-5.8 5.8C64 390 90 416 122.2 416l21.8 0 0 32c0 8.8 7.2 16 16 16s16-7.2 16-16l0-32 21.8 0c32.1 0 58.2-26 58.2-58.2c0-3.2-2.6-5.8-5.8-5.8L208 352c-19.1 0-36.3 8.4-48 21.7c-11.7-13.3-28.9-21.7-48-21.7z\"]\n};\nconst faEnvelopesBulk = {\n prefix: 'fas',\n iconName: 'envelopes-bulk',\n icon: [640, 512, [\"mail-bulk\"], \"f674\", \"M128 0C110.3 0 96 14.3 96 32l0 192 96 0 0-32c0-35.3 28.7-64 64-64l224 0 0-96c0-17.7-14.3-32-32-32L128 0zM256 160c-17.7 0-32 14.3-32 32l0 32 96 0c35.3 0 64 28.7 64 64l0 128 192 0c17.7 0 32-14.3 32-32l0-192c0-17.7-14.3-32-32-32l-320 0zm240 64l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16zM64 256c-17.7 0-32 14.3-32 32l0 13L187.1 415.9c1.4 1 3.1 1.6 4.9 1.6s3.5-.6 4.9-1.6L352 301l0-13c0-17.7-14.3-32-32-32L64 256zm288 84.8L216 441.6c-6.9 5.1-15.3 7.9-24 7.9s-17-2.8-24-7.9L32 340.8 32 480c0 17.7 14.3 32 32 32l256 0c17.7 0 32-14.3 32-32l0-139.2z\"]\n};\nconst faMailBulk = faEnvelopesBulk;\nconst faFileCircleExclamation = {\n prefix: 'fas',\n iconName: 'file-circle-exclamation',\n icon: [576, 512, [], \"e4eb\", \"M0 64C0 28.7 28.7 0 64 0L224 0l0 128c0 17.7 14.3 32 32 32l128 0 0 38.6C310.1 219.5 256 287.4 256 368c0 59.1 29.1 111.3 73.7 143.3c-3.2 .5-6.4 .7-9.7 .7L64 512c-35.3 0-64-28.7-64-64L0 64zm384 64l-128 0L256 0 384 128zm48 96a144 144 0 1 1 0 288 144 144 0 1 1 0-288zm0 240a24 24 0 1 0 0-48 24 24 0 1 0 0 48zm0-192c-8.8 0-16 7.2-16 16l0 80c0 8.8 7.2 16 16 16s16-7.2 16-16l0-80c0-8.8-7.2-16-16-16z\"]\n};\nconst faCircleH = {\n prefix: 'fas',\n iconName: 'circle-h',\n icon: [512, 512, [9405, \"hospital-symbol\"], \"f47e\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM368 152l0 104 0 104c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-80-128 0 0 80c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-208c0-13.3 10.7-24 24-24s24 10.7 24 24l0 80 128 0 0-80c0-13.3 10.7-24 24-24s24 10.7 24 24z\"]\n};\nconst faHospitalSymbol = faCircleH;\nconst faPager = {\n prefix: 'fas',\n iconName: 'pager',\n icon: [512, 512, [128223], \"f815\", \"M0 128C0 92.7 28.7 64 64 64l384 0c35.3 0 64 28.7 64 64l0 256c0 35.3-28.7 64-64 64L64 448c-35.3 0-64-28.7-64-64L0 128zm64 32l0 64c0 17.7 14.3 32 32 32l320 0c17.7 0 32-14.3 32-32l0-64c0-17.7-14.3-32-32-32L96 128c-17.7 0-32 14.3-32 32zM80 320c-13.3 0-24 10.7-24 24s10.7 24 24 24l56 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-56 0zm136 0c-13.3 0-24 10.7-24 24s10.7 24 24 24l48 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-48 0z\"]\n};\nconst faAddressBook = {\n prefix: 'fas',\n iconName: 'address-book',\n icon: [512, 512, [62138, \"contact-book\"], \"f2b9\", \"M96 0C60.7 0 32 28.7 32 64l0 384c0 35.3 28.7 64 64 64l288 0c35.3 0 64-28.7 64-64l0-384c0-35.3-28.7-64-64-64L96 0zM208 288l64 0c44.2 0 80 35.8 80 80c0 8.8-7.2 16-16 16l-192 0c-8.8 0-16-7.2-16-16c0-44.2 35.8-80 80-80zm-32-96a64 64 0 1 1 128 0 64 64 0 1 1 -128 0zM512 80c0-8.8-7.2-16-16-16s-16 7.2-16 16l0 64c0 8.8 7.2 16 16 16s16-7.2 16-16l0-64zM496 192c-8.8 0-16 7.2-16 16l0 64c0 8.8 7.2 16 16 16s16-7.2 16-16l0-64c0-8.8-7.2-16-16-16zm16 144c0-8.8-7.2-16-16-16s-16 7.2-16 16l0 64c0 8.8 7.2 16 16 16s16-7.2 16-16l0-64z\"]\n};\nconst faContactBook = faAddressBook;\nconst faStrikethrough = {\n prefix: 'fas',\n iconName: 'strikethrough',\n icon: [512, 512, [], \"f0cc\", \"M161.3 144c3.2-17.2 14-30.1 33.7-38.6c21.1-9 51.8-12.3 88.6-6.5c11.9 1.9 48.8 9.1 60.1 12c17.1 4.5 34.6-5.6 39.2-22.7s-5.6-34.6-22.7-39.2c-14.3-3.8-53.6-11.4-66.6-13.4c-44.7-7-88.3-4.2-123.7 10.9c-36.5 15.6-64.4 44.8-71.8 87.3c-.1 .6-.2 1.1-.2 1.7c-2.8 23.9 .5 45.6 10.1 64.6c4.5 9 10.2 16.9 16.7 23.9L32 224c-17.7 0-32 14.3-32 32s14.3 32 32 32l448 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-209.9 0-.4-.1-1.1-.3c-36-10.8-65.2-19.6-85.2-33.1c-9.3-6.3-15-12.6-18.2-19.1c-3.1-6.1-5.2-14.6-3.8-27.4zM348.9 337.2c2.7 6.5 4.4 15.8 1.9 30.1c-3 17.6-13.8 30.8-33.9 39.4c-21.1 9-51.7 12.3-88.5 6.5c-18-2.9-49.1-13.5-74.4-22.1c-5.6-1.9-11-3.7-15.9-5.4c-16.8-5.6-34.9 3.5-40.5 20.3s3.5 34.9 20.3 40.5c3.6 1.2 7.9 2.7 12.7 4.3c0 0 0 0 0 0s0 0 0 0c24.9 8.5 63.6 21.7 87.6 25.6c0 0 0 0 0 0l.2 0c44.7 7 88.3 4.2 123.7-10.9c36.5-15.6 64.4-44.8 71.8-87.3c3.6-21 2.7-40.4-3.1-58.1l-75.7 0c7 5.6 11.4 11.2 13.9 17.2z\"]\n};\nconst faK = {\n prefix: 'fas',\n iconName: 'k',\n icon: [320, 512, [107], \"4b\", \"M311 86.3c12.3-12.7 12-32.9-.7-45.2s-32.9-12-45.2 .7l-155.2 160L64 249 64 64c0-17.7-14.3-32-32-32S0 46.3 0 64L0 328 0 448c0 17.7 14.3 32 32 32s32-14.3 32-32l0-107 64.7-66.7 133 192c10.1 14.5 30 18.1 44.5 8.1s18.1-30 8.1-44.5L174.1 227.4 311 86.3z\"]\n};\nconst faLandmarkFlag = {\n prefix: 'fas',\n iconName: 'landmark-flag',\n icon: [512, 512, [], \"e51c\", \"M272 0l80 0c8.8 0 16 7.2 16 16l0 64c0 8.8-7.2 16-16 16l-80 0 0 32 192 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L48 192c-17.7 0-32-14.3-32-32s14.3-32 32-32l192 0 0-112c0-8.8 7.2-16 16-16l16 0zM64 224l64 0 0 192 40 0 0-192 64 0 0 192 48 0 0-192 64 0 0 192 40 0 0-192 64 0 0 196.3c.6 .3 1.2 .7 1.8 1.1l48 32c11.7 7.8 17 22.4 12.9 35.9S494.1 512 480 512L32 512c-14.1 0-26.5-9.2-30.6-22.7s1.1-28.1 12.9-35.9l48-32c.6-.4 1.2-.7 1.8-1.1L64 224z\"]\n};\nconst faPencil = {\n prefix: 'fas',\n iconName: 'pencil',\n icon: [512, 512, [9999, 61504, \"pencil-alt\"], \"f303\", \"M410.3 231l11.3-11.3-33.9-33.9-62.1-62.1L291.7 89.8l-11.3 11.3-22.6 22.6L58.6 322.9c-10.4 10.4-18 23.3-22.2 37.4L1 480.7c-2.5 8.4-.2 17.5 6.1 23.7s15.3 8.5 23.7 6.1l120.3-35.4c14.1-4.2 27-11.8 37.4-22.2L387.7 253.7 410.3 231zM160 399.4l-9.1 22.7c-4 3.1-8.5 5.4-13.3 6.9L59.4 452l23-78.1c1.4-4.9 3.8-9.4 6.9-13.3l22.7-9.1 0 32c0 8.8 7.2 16 16 16l32 0zM362.7 18.7L348.3 33.2 325.7 55.8 314.3 67.1l33.9 33.9 62.1 62.1 33.9 33.9 11.3-11.3 22.6-22.6 14.5-14.5c25-25 25-65.5 0-90.5L453.3 18.7c-25-25-65.5-25-90.5 0zm-47.4 168l-144 144c-6.2 6.2-16.4 6.2-22.6 0s-6.2-16.4 0-22.6l144-144c6.2-6.2 16.4-6.2 22.6 0s6.2 16.4 0 22.6z\"]\n};\nconst faPencilAlt = faPencil;\nconst faBackward = {\n prefix: 'fas',\n iconName: 'backward',\n icon: [512, 512, [9194], \"f04a\", \"M459.5 440.6c9.5 7.9 22.8 9.7 34.1 4.4s18.4-16.6 18.4-29l0-320c0-12.4-7.2-23.7-18.4-29s-24.5-3.6-34.1 4.4L288 214.3l0 41.7 0 41.7L459.5 440.6zM256 352l0-96 0-128 0-32c0-12.4-7.2-23.7-18.4-29s-24.5-3.6-34.1 4.4l-192 160C4.2 237.5 0 246.5 0 256s4.2 18.5 11.5 24.6l192 160c9.5 7.9 22.8 9.7 34.1 4.4s18.4-16.6 18.4-29l0-64z\"]\n};\nconst faCaretRight = {\n prefix: 'fas',\n iconName: 'caret-right',\n icon: [256, 512, [], \"f0da\", \"M246.6 278.6c12.5-12.5 12.5-32.8 0-45.3l-128-128c-9.2-9.2-22.9-11.9-34.9-6.9s-19.8 16.6-19.8 29.6l0 256c0 12.9 7.8 24.6 19.8 29.6s25.7 2.2 34.9-6.9l128-128z\"]\n};\nconst faComments = {\n prefix: 'fas',\n iconName: 'comments',\n icon: [640, 512, [128490, 61670], \"f086\", \"M208 352c114.9 0 208-78.8 208-176S322.9 0 208 0S0 78.8 0 176c0 38.6 14.7 74.3 39.6 103.4c-3.5 9.4-8.7 17.7-14.2 24.7c-4.8 6.2-9.7 11-13.3 14.3c-1.8 1.6-3.3 2.9-4.3 3.7c-.5 .4-.9 .7-1.1 .8l-.2 .2s0 0 0 0s0 0 0 0C1 327.2-1.4 334.4 .8 340.9S9.1 352 16 352c21.8 0 43.8-5.6 62.1-12.5c9.2-3.5 17.8-7.4 25.2-11.4C134.1 343.3 169.8 352 208 352zM448 176c0 112.3-99.1 196.9-216.5 207C255.8 457.4 336.4 512 432 512c38.2 0 73.9-8.7 104.7-23.9c7.5 4 16 7.9 25.2 11.4c18.3 6.9 40.3 12.5 62.1 12.5c6.9 0 13.1-4.5 15.2-11.1c2.1-6.6-.2-13.8-5.8-17.9c0 0 0 0 0 0s0 0 0 0l-.2-.2c-.2-.2-.6-.4-1.1-.8c-1-.8-2.5-2-4.3-3.7c-3.6-3.3-8.5-8.1-13.3-14.3c-5.5-7-10.7-15.4-14.2-24.7c24.9-29 39.6-64.7 39.6-103.4c0-92.8-84.9-168.9-192.6-175.5c.4 5.1 .6 10.3 .6 15.5z\"]\n};\nconst faPaste = {\n prefix: 'fas',\n iconName: 'paste',\n icon: [512, 512, [\"file-clipboard\"], \"f0ea\", \"M160 0c-23.7 0-44.4 12.9-55.4 32L48 32C21.5 32 0 53.5 0 80L0 400c0 26.5 21.5 48 48 48l144 0 0-272c0-44.2 35.8-80 80-80l48 0 0-16c0-26.5-21.5-48-48-48l-56.6 0C204.4 12.9 183.7 0 160 0zM272 128c-26.5 0-48 21.5-48 48l0 272 0 16c0 26.5 21.5 48 48 48l192 0c26.5 0 48-21.5 48-48l0-220.1c0-12.7-5.1-24.9-14.1-33.9l-67.9-67.9c-9-9-21.2-14.1-33.9-14.1L320 128l-48 0zM160 40a24 24 0 1 1 0 48 24 24 0 1 1 0-48z\"]\n};\nconst faFileClipboard = faPaste;\nconst faCodePullRequest = {\n prefix: 'fas',\n iconName: 'code-pull-request',\n icon: [512, 512, [], \"e13c\", \"M305.8 2.1C314.4 5.9 320 14.5 320 24l0 40 16 0c70.7 0 128 57.3 128 128l0 166.7c28.3 12.3 48 40.5 48 73.3c0 44.2-35.8 80-80 80s-80-35.8-80-80c0-32.8 19.7-61 48-73.3L400 192c0-35.3-28.7-64-64-64l-16 0 0 40c0 9.5-5.6 18.1-14.2 21.9s-18.8 2.3-25.8-4.1l-80-72c-5.1-4.6-7.9-11-7.9-17.8s2.9-13.3 7.9-17.8l80-72c7-6.3 17.2-7.9 25.8-4.1zM104 80A24 24 0 1 0 56 80a24 24 0 1 0 48 0zm8 73.3l0 205.3c28.3 12.3 48 40.5 48 73.3c0 44.2-35.8 80-80 80s-80-35.8-80-80c0-32.8 19.7-61 48-73.3l0-205.3C19.7 141 0 112.8 0 80C0 35.8 35.8 0 80 0s80 35.8 80 80c0 32.8-19.7 61-48 73.3zM104 432a24 24 0 1 0 -48 0 24 24 0 1 0 48 0zm328 24a24 24 0 1 0 0-48 24 24 0 1 0 0 48z\"]\n};\nconst faClipboardList = {\n prefix: 'fas',\n iconName: 'clipboard-list',\n icon: [384, 512, [], \"f46d\", \"M192 0c-41.8 0-77.4 26.7-90.5 64L64 64C28.7 64 0 92.7 0 128L0 448c0 35.3 28.7 64 64 64l256 0c35.3 0 64-28.7 64-64l0-320c0-35.3-28.7-64-64-64l-37.5 0C269.4 26.7 233.8 0 192 0zm0 64a32 32 0 1 1 0 64 32 32 0 1 1 0-64zM72 272a24 24 0 1 1 48 0 24 24 0 1 1 -48 0zm104-16l128 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-128 0c-8.8 0-16-7.2-16-16s7.2-16 16-16zM72 368a24 24 0 1 1 48 0 24 24 0 1 1 -48 0zm88 0c0-8.8 7.2-16 16-16l128 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-128 0c-8.8 0-16-7.2-16-16z\"]\n};\nconst faTruckRampBox = {\n prefix: 'fas',\n iconName: 'truck-ramp-box',\n icon: [640, 512, [\"truck-loading\"], \"f4de\", \"M640 0l0 400c0 61.9-50.1 112-112 112c-61 0-110.5-48.7-112-109.3L48.4 502.9c-17.1 4.6-34.6-5.4-39.3-22.5s5.4-34.6 22.5-39.3L352 353.8 352 64c0-35.3 28.7-64 64-64L640 0zM576 400a48 48 0 1 0 -96 0 48 48 0 1 0 96 0zM23.1 207.7c-4.6-17.1 5.6-34.6 22.6-39.2l46.4-12.4 20.7 77.3c2.3 8.5 11.1 13.6 19.6 11.3l30.9-8.3c8.5-2.3 13.6-11.1 11.3-19.6l-20.7-77.3 46.4-12.4c17.1-4.6 34.6 5.6 39.2 22.6l41.4 154.5c4.6 17.1-5.6 34.6-22.6 39.2L103.7 384.9c-17.1 4.6-34.6-5.6-39.2-22.6L23.1 207.7z\"]\n};\nconst faTruckLoading = faTruckRampBox;\nconst faUserCheck = {\n prefix: 'fas',\n iconName: 'user-check',\n icon: [640, 512, [], \"f4fc\", \"M96 128a128 128 0 1 1 256 0A128 128 0 1 1 96 128zM0 482.3C0 383.8 79.8 304 178.3 304l91.4 0C368.2 304 448 383.8 448 482.3c0 16.4-13.3 29.7-29.7 29.7L29.7 512C13.3 512 0 498.7 0 482.3zM625 177L497 305c-9.4 9.4-24.6 9.4-33.9 0l-64-64c-9.4-9.4-9.4-24.6 0-33.9s24.6-9.4 33.9 0l47 47L591 143c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9z\"]\n};\nconst faVialVirus = {\n prefix: 'fas',\n iconName: 'vial-virus',\n icon: [512, 512, [], \"e597\", \"M32 32C14.3 32 0 46.3 0 64S14.3 96 32 96l0 288c0 53 43 96 96 96c28.6 0 54.2-12.5 71.8-32.3c.1-14.2 5.6-28.3 16.4-39.1c.2-.2 .1-.6-.2-.6c-30.9 0-56-25.1-56-56s25.1-56 56-56c.3 0 .4-.4 .2-.6c-21.9-21.9-21.9-57.3 0-79.2c2.4-2.4 5-4.6 7.8-6.5L224 96c17.7 0 32-14.3 32-32s-14.3-32-32-32l-64 0L96 32 32 32zM96 192l0-96 64 0 0 96-64 0zM216 376c28.8 0 43.2 34.8 22.9 55.2c-9.4 9.4-9.4 24.6 0 33.9s24.6 9.4 33.9 0c20.4-20.4 55.2-5.9 55.2 22.9c0 13.3 10.7 24 24 24s24-10.7 24-24c0-28.8 34.8-43.2 55.2-22.9c9.4 9.4 24.6 9.4 33.9 0s9.4-24.6 0-33.9C444.8 410.8 459.2 376 488 376c13.3 0 24-10.7 24-24s-10.7-24-24-24c-28.8 0-43.2-34.8-22.9-55.2c9.4-9.4 9.4-24.6 0-33.9s-24.6-9.4-33.9 0C410.8 259.2 376 244.8 376 216c0-13.3-10.7-24-24-24s-24 10.7-24 24c0 28.8-34.8 43.2-55.2 22.9c-9.4-9.4-24.6-9.4-33.9 0s-9.4 24.6 0 33.9c20.4 20.4 5.9 55.2-22.9 55.2c-13.3 0-24 10.7-24 24s10.7 24 24 24zm104-88a32 32 0 1 1 0 64 32 32 0 1 1 0-64zm40 96a24 24 0 1 1 48 0 24 24 0 1 1 -48 0z\"]\n};\nconst faSheetPlastic = {\n prefix: 'fas',\n iconName: 'sheet-plastic',\n icon: [384, 512, [], \"e571\", \"M0 448c0 35.3 28.7 64 64 64l160 0 0-128c0-17.7 14.3-32 32-32l128 0 0-288c0-35.3-28.7-64-64-64L64 0C28.7 0 0 28.7 0 64L0 448zM171.3 75.3l-96 96c-6.2 6.2-16.4 6.2-22.6 0s-6.2-16.4 0-22.6l96-96c6.2-6.2 16.4-6.2 22.6 0s6.2 16.4 0 22.6zm96 32l-160 160c-6.2 6.2-16.4 6.2-22.6 0s-6.2-16.4 0-22.6l160-160c6.2-6.2 16.4-6.2 22.6 0s6.2 16.4 0 22.6zM384 384l-128 0 0 128L384 384z\"]\n};\nconst faBlog = {\n prefix: 'fas',\n iconName: 'blog',\n icon: [512, 512, [], \"f781\", \"M192 32c0 17.7 14.3 32 32 32c123.7 0 224 100.3 224 224c0 17.7 14.3 32 32 32s32-14.3 32-32C512 128.9 383.1 0 224 0c-17.7 0-32 14.3-32 32zm0 96c0 17.7 14.3 32 32 32c70.7 0 128 57.3 128 128c0 17.7 14.3 32 32 32s32-14.3 32-32c0-106-86-192-192-192c-17.7 0-32 14.3-32 32zM96 144c0-26.5-21.5-48-48-48S0 117.5 0 144L0 368c0 79.5 64.5 144 144 144s144-64.5 144-144s-64.5-144-144-144l-16 0 0 96 16 0c26.5 0 48 21.5 48 48s-21.5 48-48 48s-48-21.5-48-48l0-224z\"]\n};\nconst faUserNinja = {\n prefix: 'fas',\n iconName: 'user-ninja',\n icon: [448, 512, [129399], \"f504\", \"M224 256c-57.2 0-105.6-37.5-122-89.3c-1.1 1.3-2.2 2.6-3.5 3.8c-15.8 15.8-38.8 20.7-53.6 22.1c-8.1 .8-14.6-5.7-13.8-13.8c1.4-14.7 6.3-37.8 22.1-53.6c5.8-5.8 12.6-10.1 19.6-13.4c-7-3.2-13.8-7.6-19.6-13.4C37.4 82.7 32.6 59.7 31.1 44.9c-.8-8.1 5.7-14.6 13.8-13.8c14.7 1.4 37.8 6.3 53.6 22.1c4.8 4.8 8.7 10.4 11.7 16.1C131.4 28.2 174.4 0 224 0c70.7 0 128 57.3 128 128s-57.3 128-128 128zM0 482.3C0 399.5 56.4 330 132.8 309.9c6-1.6 12.2 .9 15.9 5.8l62.5 83.3c6.4 8.5 19.2 8.5 25.6 0l62.5-83.3c3.7-4.9 9.9-7.4 15.9-5.8C391.6 330 448 399.5 448 482.3c0 16.4-13.3 29.7-29.7 29.7L29.7 512C13.3 512 0 498.7 0 482.3zM160 96c-8.8 0-16 7.2-16 16s7.2 16 16 16l128 0c8.8 0 16-7.2 16-16s-7.2-16-16-16L160 96z\"]\n};\nconst faPersonArrowUpFromLine = {\n prefix: 'fas',\n iconName: 'person-arrow-up-from-line',\n icon: [640, 512, [], \"e539\", \"M192 96a48 48 0 1 0 0-96 48 48 0 1 0 0 96zm-8 352l0-96 16 0 0 96-16 0zm-64 0l-88 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l120 0 80 0 376 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-344 0 0-191.1 28.6 47.5c9.1 15.1 28.8 20 43.9 10.9s20-28.8 10.9-43.9l-58.3-97c-17.4-28.9-48.6-46.6-82.3-46.6l-29.7 0c-33.7 0-64.9 17.7-82.3 46.6l-58.3 97c-9.1 15.1-4.2 34.8 10.9 43.9s34.8 4.2 43.9-10.9L120 256.9 120 448zM598.6 121.4l-80-80c-12.5-12.5-32.8-12.5-45.3 0l-80 80c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0L464 141.3 464 384c0 17.7 14.3 32 32 32s32-14.3 32-32l0-242.7 25.4 25.4c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3z\"]\n};\nconst faScrollTorah = {\n prefix: 'fas',\n iconName: 'scroll-torah',\n icon: [640, 512, [\"torah\"], \"f6a0\", \"M96 480L96 32C96 14.3 74.5 0 48 0S0 14.3 0 32L0 480c0 17.7 21.5 32 48 32s48-14.3 48-32zM512 32L128 32l0 448 384 0 0-448zM592 0c-26.5 0-48 14.3-48 32l0 448c0 17.7 21.5 32 48 32s48-14.3 48-32l0-448c0-17.7-21.5-32-48-32zM196 313.7c0-3.2 .9-6.4 2.5-9.2L226.7 256l-28.3-48.5c-1.6-2.8-2.5-6-2.5-9.2c0-10.1 8.2-18.3 18.3-18.3l56.7 0 31.4-53.9c3.6-6.3 10.3-10.1 17.6-10.1s13.9 3.8 17.6 10.1L369 180l56.7 0c10.1 0 18.3 8.2 18.3 18.3c0 3.2-.9 6.4-2.5 9.2L413.3 256l28.3 48.5c1.6 2.8 2.5 6 2.5 9.2c0 10.1-8.2 18.3-18.3 18.3L369 332l-31.4 53.9c-3.6 6.3-10.3 10.1-17.6 10.1s-13.9-3.8-17.6-10.1L271 332l-56.7 0c-10.1 0-18.3-8.2-18.3-18.3zm124 54.7L341.2 332l-42.4 0L320 368.4zM254.5 256l30.3 52 70.4 0 30.3-52-30.3-52-70.4 0-30.3 52zm144.9 23.8L383 308l32.8 0-16.4-28.2zM415.8 204L383 204l16.4 28.2L415.8 204zM320 143.6L298.8 180l42.4 0L320 143.6zM224.2 204l16.4 28.2L257 204l-32.8 0zM257 308l-16.4-28.2L224.2 308l32.8 0z\"]\n};\nconst faTorah = faScrollTorah;\nconst faBroomBall = {\n prefix: 'fas',\n iconName: 'broom-ball',\n icon: [576, 512, [\"quidditch\", \"quidditch-broom-ball\"], \"f458\", \"M566.6 9.4c12.5 12.5 12.5 32.8 0 45.3l-192 192 34.7 34.7c4.2 4.2 6.6 10 6.6 16c0 12.5-10.1 22.6-22.6 22.6l-29.1 0L256 211.7l0-29.1c0-12.5 10.1-22.6 22.6-22.6c6 0 11.8 2.4 16 6.6l34.7 34.7 192-192c12.5-12.5 32.8-12.5 45.3 0zm-344 225.5L341.1 353.4c3.7 42.7-11.7 85.2-42.3 115.8C271.4 496.6 234.2 512 195.5 512L22.1 512C9.9 512 0 502.1 0 489.9c0-6.3 2.7-12.3 7.3-16.5L133.7 359.7c4.2-3.7-.4-10.4-5.4-7.9L77.2 377.4c-6.1 3-13.2-1.4-13.2-8.2c0-31.5 12.5-61.7 34.8-84l8-8c30.6-30.6 73.1-45.9 115.8-42.3zM464 352a80 80 0 1 1 0 160 80 80 0 1 1 0-160z\"]\n};\nconst faQuidditch = faBroomBall;\nconst faQuidditchBroomBall = faBroomBall;\nconst faToggleOff = {\n prefix: 'fas',\n iconName: 'toggle-off',\n icon: [576, 512, [], \"f204\", \"M384 128c70.7 0 128 57.3 128 128s-57.3 128-128 128l-192 0c-70.7 0-128-57.3-128-128s57.3-128 128-128l192 0zM576 256c0-106-86-192-192-192L192 64C86 64 0 150 0 256S86 448 192 448l192 0c106 0 192-86 192-192zM192 352a96 96 0 1 0 0-192 96 96 0 1 0 0 192z\"]\n};\nconst faBoxArchive = {\n prefix: 'fas',\n iconName: 'box-archive',\n icon: [512, 512, [\"archive\"], \"f187\", \"M32 32l448 0c17.7 0 32 14.3 32 32l0 32c0 17.7-14.3 32-32 32L32 128C14.3 128 0 113.7 0 96L0 64C0 46.3 14.3 32 32 32zm0 128l448 0 0 256c0 35.3-28.7 64-64 64L96 480c-35.3 0-64-28.7-64-64l0-256zm128 80c0 8.8 7.2 16 16 16l160 0c8.8 0 16-7.2 16-16s-7.2-16-16-16l-160 0c-8.8 0-16 7.2-16 16z\"]\n};\nconst faArchive = faBoxArchive;\nconst faPersonDrowning = {\n prefix: 'fas',\n iconName: 'person-drowning',\n icon: [576, 512, [], \"e545\", \"M192 64c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 32.2c0 54.1 23.5 104 62.2 138.3l-21 146.7c7.8 2.1 15.5 3.3 22.8 3.3c21.1 0 42-8.5 59.2-20.3c22.1-15.5 51.6-15.5 73.7 0c12.4 8.5 26.1 14.8 39.7 18l17.7-97.6c10.7-1.2 21.3-3.1 31.9-5.5l105-23.9c17.2-3.9 28-21.1 24.1-38.3s-21.1-28-38.3-24.1L400 216.6c-41 9.3-83.7 7.5-123.7-5.2c-50.2-16-84.3-62.6-84.3-115.3L192 64zM320 192a64 64 0 1 0 0-128 64 64 0 1 0 0 128zM306.5 389.9c-11.1-7.9-25.9-7.9-37 0C247 405.4 219.5 416 192 416c-26.9 0-55.3-10.8-77.4-26.1c0 0 0 0 0 0c-11.9-8.5-28.1-7.8-39.2 1.7c-14.4 11.9-32.5 21-50.6 25.2c-17.2 4-27.9 21.2-23.9 38.4s21.2 27.9 38.4 23.9c24.5-5.7 44.9-16.5 58.2-25C126.5 469.7 159 480 192 480c31.9 0 60.6-9.9 80.4-18.9c5.8-2.7 11.1-5.3 15.6-7.7c4.5 2.4 9.7 5.1 15.6 7.7c19.8 9 48.5 18.9 80.4 18.9c33 0 65.5-10.3 94.5-25.8c13.4 8.4 33.7 19.3 58.2 25c17.2 4 34.4-6.7 38.4-23.9s-6.7-34.4-23.9-38.4c-18.1-4.2-36.2-13.3-50.6-25.2c-11.1-9.4-27.3-10.1-39.2-1.7c0 0 0 0 0 0C439.4 405.2 410.9 416 384 416c-27.5 0-55-10.6-77.5-26.1z\"]\n};\nconst faArrowDown91 = {\n prefix: 'fas',\n iconName: 'arrow-down-9-1',\n icon: [576, 512, [\"sort-numeric-desc\", \"sort-numeric-down-alt\"], \"f886\", \"M160 480c9 0 17.5-3.8 23.6-10.4l88-96c11.9-13 11.1-33.3-2-45.2s-33.3-11.1-45.2 2L192 365.7 192 64c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 301.7L95.6 330.4c-11.9-13-32.2-13.9-45.2-2s-13.9 32.2-2 45.2l88 96C142.5 476.2 151 480 160 480zM450.7 294c-8.3-6-19.1-7.7-28.8-4.4l-48 16c-16.8 5.6-25.8 23.7-20.2 40.5s23.7 25.8 40.5 20.2l5.9-2 0 51.6-16 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l48 0 48 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-16 0 0-96c0-10.3-4.9-19.9-13.3-26zM418.3 91a32 32 0 1 1 27.4 57.9A32 32 0 1 1 418.3 91zM405.1 203.8l-6.8 9.2c-10.5 14.2-7.5 34.2 6.7 44.8s34.2 7.5 44.8-6.7l48.8-65.8c14-18.9 21.5-41.7 21.5-65.2c0-48.6-39.4-88-88-88s-88 39.4-88 88c0 39.2 25.6 72.4 61.1 83.8z\"]\n};\nconst faSortNumericDesc = faArrowDown91;\nconst faSortNumericDownAlt = faArrowDown91;\nconst faFaceGrinTongueSquint = {\n prefix: 'fas',\n iconName: 'face-grin-tongue-squint',\n icon: [512, 512, [128541, \"grin-tongue-squint\"], \"f58a\", \"M0 256C0 368.9 73.1 464.7 174.5 498.8C165.3 484 160 466.6 160 448l0-47.3c-24-17.5-43.1-41.4-54.8-69.2c-5-11.8 7-22.5 19.3-18.7c39.7 12.2 84.5 19 131.8 19s92.1-6.8 131.8-19c12.3-3.8 24.3 6.9 19.3 18.7c-11.8 28-31.1 52-55.4 69.6l0 46.9c0 18.6-5.3 36-14.5 50.8C438.9 464.7 512 368.9 512 256C512 114.6 397.4 0 256 0S0 114.6 0 256zM116 141.1c0-9 9.6-14.7 17.5-10.5l89.9 47.9c10.7 5.7 10.7 21.1 0 26.8l-89.9 47.9c-7.9 4.2-17.5-1.5-17.5-10.5c0-2.8 1-5.5 2.8-7.6l36-43.2-36-43.2c-1.8-2.1-2.8-4.8-2.8-7.6zm262.5-10.5c7.9-4.2 17.5 1.5 17.5 10.5c0 2.8-1 5.5-2.8 7.6l-36 43.2 36 43.2c1.8 2.1 2.8 4.8 2.8 7.6c0 9-9.6 14.7-17.5 10.5l-89.9-47.9c-10.7-5.7-10.7-21.1 0-26.8l89.9-47.9zM320 448l0-45.4c0-14.7-11.9-26.6-26.6-26.6l-2 0c-11.3 0-21.1 7.9-23.6 18.9c-2.8 12.6-20.8 12.6-23.6 0c-2.5-11.1-12.3-18.9-23.6-18.9l-2 0c-14.7 0-26.6 11.9-26.6 26.6l0 45.4c0 35.3 28.7 64 64 64s64-28.7 64-64z\"]\n};\nconst faGrinTongueSquint = faFaceGrinTongueSquint;\nconst faSprayCan = {\n prefix: 'fas',\n iconName: 'spray-can',\n icon: [512, 512, [], \"f5bd\", \"M128 0l64 0c17.7 0 32 14.3 32 32l0 96L96 128l0-96c0-17.7 14.3-32 32-32zM0 256c0-53 43-96 96-96l128 0c53 0 96 43 96 96l0 208c0 26.5-21.5 48-48 48L48 512c-26.5 0-48-21.5-48-48L0 256zm240 80A80 80 0 1 0 80 336a80 80 0 1 0 160 0zM256 64a32 32 0 1 1 64 0 32 32 0 1 1 -64 0zM384 32a32 32 0 1 1 0 64 32 32 0 1 1 0-64zm64 32a32 32 0 1 1 64 0 32 32 0 1 1 -64 0zm32 64a32 32 0 1 1 0 64 32 32 0 1 1 0-64zM448 256a32 32 0 1 1 64 0 32 32 0 1 1 -64 0zM384 128a32 32 0 1 1 0 64 32 32 0 1 1 0-64z\"]\n};\nconst faTruckMonster = {\n prefix: 'fas',\n iconName: 'truck-monster',\n icon: [640, 512, [], \"f63b\", \"M288 64l0 64 128 0L368 64l-80 0zM419.2 25.6L496 128l80 0c17.7 0 32 14.3 32 32l0 64c17.7 0 32 14.3 32 32s-14.3 32-32 32c-29.2-38.9-75.7-64-128-64s-98.8 25.1-128 64l-64 0c-29.2-38.9-75.7-64-128-64s-98.8 25.1-128 64c-17.7 0-32-14.3-32-32s14.3-32 32-32l0-64c0-17.7 14.3-32 32-32l160 0 0-80c0-26.5 21.5-48 48-48l96 0c20.1 0 39.1 9.5 51.2 25.6zM152 256l16 0c12.1 0 22.1 8.9 23.8 20.6c7.6 2.2 14.9 5.3 21.7 9c9.4-7 22.8-6.3 31.3 2.3l11.3 11.3c8.6 8.6 9.3 21.9 2.3 31.3c3.7 6.8 6.8 14.1 9 21.7c11.6 1.7 20.6 11.7 20.6 23.8l0 16c0 12.1-8.9 22.1-20.6 23.8c-2.2 7.6-5.3 14.9-9 21.7c7 9.4 6.3 22.8-2.3 31.3l-11.3 11.3c-8.6 8.6-21.9 9.3-31.3 2.2c-6.8 3.7-14.1 6.8-21.7 9C190.1 503.1 180.1 512 168 512l-16 0c-12.1 0-22.1-8.9-23.8-20.6c-7.6-2.2-14.9-5.3-21.7-9c-9.4 7.1-22.8 6.3-31.3-2.2L63.8 468.9c-8.6-8.6-9.3-21.9-2.3-31.3c-3.7-6.9-6.8-14.1-9-21.8C40.9 414.1 32 404.1 32 392l0-16c0-12.1 8.9-22.1 20.6-23.8c2.2-7.6 5.3-14.9 9-21.8c-7-9.4-6.3-22.8 2.3-31.3l11.3-11.3c8.6-8.6 21.9-9.3 31.3-2.3c6.8-3.7 14.1-6.8 21.7-9c1.7-11.6 11.7-20.6 23.8-20.6zm8 176a48 48 0 1 0 0-96 48 48 0 1 0 0 96zM448.2 276.6c1.7-11.6 11.7-20.6 23.8-20.6l16 0c12.1 0 22.1 8.9 23.8 20.6c7.6 2.2 14.9 5.3 21.8 9c9.4-7 22.8-6.3 31.3 2.3l11.3 11.3c8.6 8.6 9.3 21.9 2.2 31.3c3.7 6.8 6.8 14.1 9 21.7c11.6 1.7 20.6 11.7 20.6 23.8l0 16c0 12.1-8.9 22.1-20.6 23.8c-2.2 7.6-5.3 14.9-9 21.7c7 9.4 6.3 22.8-2.2 31.3l-11.3 11.3c-8.6 8.6-21.9 9.3-31.3 2.2c-6.9 3.7-14.1 6.8-21.8 9C510.1 503.1 500.1 512 488 512l-16 0c-12.1 0-22.1-8.9-23.8-20.6c-7.6-2.2-14.9-5.3-21.7-9c-9.4 7.1-22.8 6.3-31.3-2.2l-11.3-11.3c-8.6-8.6-9.3-21.9-2.2-31.3c-3.7-6.9-6.8-14.1-9-21.8C360.9 414.1 352 404.1 352 392l0-16c0-12.1 8.9-22.1 20.6-23.8c2.2-7.6 5.3-14.9 9-21.8c-7-9.4-6.3-22.8 2.2-31.3l11.3-11.3c8.6-8.6 21.9-9.3 31.3-2.3c6.8-3.7 14.1-6.8 21.7-9zM528 384a48 48 0 1 0 -96 0 48 48 0 1 0 96 0z\"]\n};\nconst faW = {\n prefix: 'fas',\n iconName: 'w',\n icon: [576, 512, [119], \"57\", \"M20.8 34c16.5-6.2 35 2.2 41.2 18.7l110.2 294L257.3 55c4-13.7 16.5-23 30.7-23s26.7 9.4 30.7 23l85.1 291.7L514 52.8c6.2-16.5 24.6-24.9 41.2-18.7s24.9 24.7 18.7 41.2l-144 384c-4.8 12.9-17.4 21.3-31.2 20.7s-25.7-9.8-29.5-23L288 178.3 206.7 457c-3.9 13.2-15.8 22.5-29.5 23s-26.3-7.8-31.2-20.7L2 75.2C-4.2 58.7 4.2 40.2 20.8 34z\"]\n};\nconst faEarthAfrica = {\n prefix: 'fas',\n iconName: 'earth-africa',\n icon: [512, 512, [127757, \"globe-africa\"], \"f57c\", \"M177.8 63.2l10 17.4c2.8 4.8 4.2 10.3 4.2 15.9l0 41.4c0 3.9 1.6 7.7 4.3 10.4c6.2 6.2 16.5 5.7 22-1.2l13.6-17c4.7-5.9 12.9-7.7 19.6-4.3l15.2 7.6c3.4 1.7 7.2 2.6 11 2.6c6.5 0 12.8-2.6 17.4-7.2l3.9-3.9c2.9-2.9 7.3-3.6 11-1.8l29.2 14.6c7.8 3.9 12.6 11.8 12.6 20.5c0 10.5-7.1 19.6-17.3 22.2l-35.4 8.8c-7.4 1.8-15.1 1.5-22.4-.9l-32-10.7c-3.3-1.1-6.7-1.7-10.2-1.7c-7 0-13.8 2.3-19.4 6.5L176 212c-10.1 7.6-16 19.4-16 32l0 28c0 26.5 21.5 48 48 48l32 0c8.8 0 16 7.2 16 16l0 48c0 17.7 14.3 32 32 32c10.1 0 19.6-4.7 25.6-12.8l25.6-34.1c8.3-11.1 12.8-24.6 12.8-38.4l0-12.1c0-3.9 2.6-7.3 6.4-8.2l5.3-1.3c11.9-3 20.3-13.7 20.3-26c0-7.1-2.8-13.9-7.8-18.9l-33.5-33.5c-3.7-3.7-3.7-9.7 0-13.4c5.7-5.7 14.1-7.7 21.8-5.1l14.1 4.7c12.3 4.1 25.7-1.5 31.5-13c3.5-7 11.2-10.8 18.9-9.2l27.4 5.5C432 112.4 351.5 48 256 48c-27.7 0-54 5.4-78.2 15.2zM0 256a256 256 0 1 1 512 0A256 256 0 1 1 0 256z\"]\n};\nconst faGlobeAfrica = faEarthAfrica;\nconst faRainbow = {\n prefix: 'fas',\n iconName: 'rainbow',\n icon: [640, 512, [127752], \"f75b\", \"M320 96C178.6 96 64 210.6 64 352l0 96c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-96C0 175.3 143.3 32 320 32s320 143.3 320 320l0 96c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-96C576 210.6 461.4 96 320 96zm0 192c-35.3 0-64 28.7-64 64l0 96c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-96c0-70.7 57.3-128 128-128s128 57.3 128 128l0 96c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-96c0-35.3-28.7-64-64-64zM160 352l0 96c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-96c0-123.7 100.3-224 224-224s224 100.3 224 224l0 96c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-96c0-88.4-71.6-160-160-160s-160 71.6-160 160z\"]\n};\nconst faCircleNotch = {\n prefix: 'fas',\n iconName: 'circle-notch',\n icon: [512, 512, [], \"f1ce\", \"M222.7 32.1c5 16.9-4.6 34.8-21.5 39.8C121.8 95.6 64 169.1 64 256c0 106 86 192 192 192s192-86 192-192c0-86.9-57.8-160.4-137.1-184.1c-16.9-5-26.6-22.9-21.5-39.8s22.9-26.6 39.8-21.5C434.9 42.1 512 140 512 256c0 141.4-114.6 256-256 256S0 397.4 0 256C0 140 77.1 42.1 182.9 10.6c16.9-5 34.8 4.6 39.8 21.5z\"]\n};\nconst faTabletScreenButton = {\n prefix: 'fas',\n iconName: 'tablet-screen-button',\n icon: [448, 512, [\"tablet-alt\"], \"f3fa\", \"M0 64C0 28.7 28.7 0 64 0L384 0c35.3 0 64 28.7 64 64l0 384c0 35.3-28.7 64-64 64L64 512c-35.3 0-64-28.7-64-64L0 64zM256 448a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zM384 64L64 64l0 320 320 0 0-320z\"]\n};\nconst faTabletAlt = faTabletScreenButton;\nconst faPaw = {\n prefix: 'fas',\n iconName: 'paw',\n icon: [512, 512, [], \"f1b0\", \"M226.5 92.9c14.3 42.9-.3 86.2-32.6 96.8s-70.1-15.6-84.4-58.5s.3-86.2 32.6-96.8s70.1 15.6 84.4 58.5zM100.4 198.6c18.9 32.4 14.3 70.1-10.2 84.1s-59.7-.9-78.5-33.3S-2.7 179.3 21.8 165.3s59.7 .9 78.5 33.3zM69.2 401.2C121.6 259.9 214.7 224 256 224s134.4 35.9 186.8 177.2c3.6 9.7 5.2 20.1 5.2 30.5l0 1.6c0 25.8-20.9 46.7-46.7 46.7c-11.5 0-22.9-1.4-34-4.2l-88-22c-15.3-3.8-31.3-3.8-46.6 0l-88 22c-11.1 2.8-22.5 4.2-34 4.2C84.9 480 64 459.1 64 433.3l0-1.6c0-10.4 1.6-20.8 5.2-30.5zM421.8 282.7c-24.5-14-29.1-51.7-10.2-84.1s54-47.3 78.5-33.3s29.1 51.7 10.2 84.1s-54 47.3-78.5 33.3zM310.1 189.7c-32.3-10.6-46.9-53.9-32.6-96.8s52.1-69.1 84.4-58.5s46.9 53.9 32.6 96.8s-52.1 69.1-84.4 58.5z\"]\n};\nconst faCloud = {\n prefix: 'fas',\n iconName: 'cloud',\n icon: [640, 512, [9729], \"f0c2\", \"M0 336c0 79.5 64.5 144 144 144l368 0c70.7 0 128-57.3 128-128c0-61.9-44-113.6-102.4-125.4c4.1-10.7 6.4-22.4 6.4-34.6c0-53-43-96-96-96c-19.7 0-38.1 6-53.3 16.2C367 64.2 315.3 32 256 32C167.6 32 96 103.6 96 192c0 2.7 .1 5.4 .2 8.1C40.2 219.8 0 273.2 0 336z\"]\n};\nconst faTrowelBricks = {\n prefix: 'fas',\n iconName: 'trowel-bricks',\n icon: [512, 512, [], \"e58a\", \"M240.8 4.8C250.3 10.6 256 20.9 256 32l0 72 89 0c3.6-13.8 16.1-24 31-24l88 0c26.5 0 48 21.5 48 48s-21.5 48-48 48l-88 0c-14.9 0-27.4-10.2-31-24l-89 0 0 72c0 11.1-5.7 21.4-15.2 27.2s-21.2 6.4-31.1 1.4l-192-96C6.8 151.2 0 140.1 0 128s6.8-23.2 17.7-28.6l192-96c9.9-5 21.7-4.4 31.1 1.4zM288 256c0-17.7 14.3-32 32-32l160 0c17.7 0 32 14.3 32 32l0 64c0 17.7-14.3 32-32 32l-160 0c-17.7 0-32-14.3-32-32l0-64zM32 384l96 0c17.7 0 32 14.3 32 32l0 64c0 17.7-14.3 32-32 32l-96 0c-17.7 0-32-14.3-32-32l0-64c0-17.7 14.3-32 32-32zm192 0l256 0c17.7 0 32 14.3 32 32l0 64c0 17.7-14.3 32-32 32l-256 0c-17.7 0-32-14.3-32-32l0-64c0-17.7 14.3-32 32-32z\"]\n};\nconst faFaceFlushed = {\n prefix: 'fas',\n iconName: 'face-flushed',\n icon: [512, 512, [128563, \"flushed\"], \"f579\", \"M0 256a256 256 0 1 1 512 0A256 256 0 1 1 0 256zM176 384c0 8.8 7.2 16 16 16l128 0c8.8 0 16-7.2 16-16s-7.2-16-16-16l-128 0c-8.8 0-16 7.2-16 16zm-16-88a72 72 0 1 0 0-144 72 72 0 1 0 0 144zm264-72a72 72 0 1 0 -144 0 72 72 0 1 0 144 0zm-288 0a24 24 0 1 1 48 0 24 24 0 1 1 -48 0zm192 0a24 24 0 1 1 48 0 24 24 0 1 1 -48 0z\"]\n};\nconst faFlushed = faFaceFlushed;\nconst faHospitalUser = {\n prefix: 'fas',\n iconName: 'hospital-user',\n icon: [576, 512, [], \"f80d\", \"M48 0C21.5 0 0 21.5 0 48L0 256l144 0c8.8 0 16 7.2 16 16s-7.2 16-16 16L0 288l0 64 144 0c8.8 0 16 7.2 16 16s-7.2 16-16 16L0 384l0 80c0 26.5 21.5 48 48 48l217.9 0c-6.3-10.2-9.9-22.2-9.9-35.1c0-46.9 25.8-87.8 64-109.2l0-95.9L320 48c0-26.5-21.5-48-48-48L48 0zM152 64l16 0c8.8 0 16 7.2 16 16l0 24 24 0c8.8 0 16 7.2 16 16l0 16c0 8.8-7.2 16-16 16l-24 0 0 24c0 8.8-7.2 16-16 16l-16 0c-8.8 0-16-7.2-16-16l0-24-24 0c-8.8 0-16-7.2-16-16l0-16c0-8.8 7.2-16 16-16l24 0 0-24c0-8.8 7.2-16 16-16zM512 272a80 80 0 1 0 -160 0 80 80 0 1 0 160 0zM288 477.1c0 19.3 15.6 34.9 34.9 34.9l218.2 0c19.3 0 34.9-15.6 34.9-34.9c0-51.4-41.7-93.1-93.1-93.1l-101.8 0c-51.4 0-93.1 41.7-93.1 93.1z\"]\n};\nconst faTentArrowLeftRight = {\n prefix: 'fas',\n iconName: 'tent-arrow-left-right',\n icon: [576, 512, [], \"e57f\", \"M488.1 6.2c-9.9-8.9-25-8.1-33.9 1.8s-8.1 25 1.8 33.9L489.5 72 86.5 72l33.5-30.2c9.9-8.9 10.7-24 1.8-33.9S97.8-2.7 87.9 6.2l-80 72C2.9 82.7 0 89.2 0 96s2.9 13.3 7.9 17.8l80 72c9.9 8.9 25 8.1 33.9-1.8s8.1-25-1.8-33.9L86.5 120l402.9 0-33.5 30.2c-9.9 8.9-10.7 24-1.8 33.9s24 10.7 33.9 1.8l80-72c5.1-4.6 7.9-11 7.9-17.8s-2.9-13.3-7.9-17.8l-80-72zM307.4 166.5c-11.5-8.7-27.3-8.7-38.8 0l-168 128c-6.6 5-11 12.5-12.3 20.7l-24 160c-1.4 9.2 1.3 18.6 7.4 25.6S86.7 512 96 512l144 0 16 0c17.7 0 32-14.3 32-32l0-118.1c0-5.5 4.4-9.9 9.9-9.9c3.7 0 7.2 2.1 8.8 5.5l68.4 136.8c5.4 10.8 16.5 17.7 28.6 17.7l60.2 0 16 0c9.3 0 18.2-4.1 24.2-11.1s8.8-16.4 7.4-25.6l-24-160c-1.2-8.2-5.6-15.7-12.3-20.7l-168-128z\"]\n};\nconst faGavel = {\n prefix: 'fas',\n iconName: 'gavel',\n icon: [512, 512, [\"legal\"], \"f0e3\", \"M318.6 9.4c-12.5-12.5-32.8-12.5-45.3 0l-120 120c-12.5 12.5-12.5 32.8 0 45.3l16 16c12.5 12.5 32.8 12.5 45.3 0l4-4L325.4 293.4l-4 4c-12.5 12.5-12.5 32.8 0 45.3l16 16c12.5 12.5 32.8 12.5 45.3 0l120-120c12.5-12.5 12.5-32.8 0-45.3l-16-16c-12.5-12.5-32.8-12.5-45.3 0l-4 4L330.6 74.6l4-4c12.5-12.5 12.5-32.8 0-45.3l-16-16zm-152 288c-12.5-12.5-32.8-12.5-45.3 0l-112 112c-12.5 12.5-12.5 32.8 0 45.3l48 48c12.5 12.5 32.8 12.5 45.3 0l112-112c12.5-12.5 12.5-32.8 0-45.3l-1.4-1.4L272 285.3 226.7 240 168 298.7l-1.4-1.4z\"]\n};\nconst faLegal = faGavel;\nconst faBinoculars = {\n prefix: 'fas',\n iconName: 'binoculars',\n icon: [512, 512, [], \"f1e5\", \"M128 32l32 0c17.7 0 32 14.3 32 32l0 32L96 96l0-32c0-17.7 14.3-32 32-32zm64 96l0 320c0 17.7-14.3 32-32 32L32 480c-17.7 0-32-14.3-32-32l0-59.1c0-34.6 9.4-68.6 27.2-98.3C40.9 267.8 49.7 242.4 53 216L60.5 156c2-16 15.6-28 31.8-28l99.8 0zm227.8 0c16.1 0 29.8 12 31.8 28L459 216c3.3 26.4 12.1 51.8 25.8 74.6c17.8 29.7 27.2 63.7 27.2 98.3l0 59.1c0 17.7-14.3 32-32 32l-128 0c-17.7 0-32-14.3-32-32l0-320 99.8 0zM320 64c0-17.7 14.3-32 32-32l32 0c17.7 0 32 14.3 32 32l0 32-96 0 0-32zm-32 64l0 160-64 0 0-160 64 0z\"]\n};\nconst faMicrophoneSlash = {\n prefix: 'fas',\n iconName: 'microphone-slash',\n icon: [640, 512, [], \"f131\", \"M38.8 5.1C28.4-3.1 13.3-1.2 5.1 9.2S-1.2 34.7 9.2 42.9l592 464c10.4 8.2 25.5 6.3 33.7-4.1s6.3-25.5-4.1-33.7L472.1 344.7c15.2-26 23.9-56.3 23.9-88.7l0-40c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 40c0 21.2-5.1 41.1-14.2 58.7L416 300.8 416 96c0-53-43-96-96-96s-96 43-96 96l0 54.3L38.8 5.1zM344 430.4c20.4-2.8 39.7-9.1 57.3-18.2l-43.1-33.9C346.1 382 333.3 384 320 384c-70.7 0-128-57.3-128-128l0-8.7L144.7 210c-.5 1.9-.7 3.9-.7 6l0 40c0 89.1 66.2 162.7 152 174.4l0 33.6-48 0c-13.3 0-24 10.7-24 24s10.7 24 24 24l72 0 72 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-48 0 0-33.6z\"]\n};\nconst faBoxTissue = {\n prefix: 'fas',\n iconName: 'box-tissue',\n icon: [512, 512, [], \"e05b\", \"M92.5 0L208 0c40 0 52 24 64 48s24 48 64 48l85.2 0C436 96 448 108 448 122.8c0 3.4-.7 6.8-1.9 10L409.6 224 384 288l-256 0-16-64L64.9 35.4c-.6-2.3-.9-4.6-.9-6.9C64 12.8 76.8 0 92.5 0zM79 224l16 64-15 0c-8.8 0-16 7.2-16 16s7.2 16 16 16l48 0 256 0 48 0c8.8 0 16-7.2 16-16s-7.2-16-16-16l-13.5 0 25.6-64 19.9 0c26.5 0 48 21.5 48 48l0 112L0 384 0 272c0-26.5 21.5-48 48-48l31 0zM0 416l512 0 0 48c0 26.5-21.5 48-48 48L48 512c-26.5 0-48-21.5-48-48l0-48z\"]\n};\nconst faMotorcycle = {\n prefix: 'fas',\n iconName: 'motorcycle',\n icon: [640, 512, [127949], \"f21c\", \"M280 32c-13.3 0-24 10.7-24 24s10.7 24 24 24l57.7 0 16.4 30.3L256 192l-45.3-45.3c-12-12-28.3-18.7-45.3-18.7L64 128c-17.7 0-32 14.3-32 32l0 32 96 0c88.4 0 160 71.6 160 160c0 11-1.1 21.7-3.2 32l70.4 0c-2.1-10.3-3.2-21-3.2-32c0-52.2 25-98.6 63.7-127.8l15.4 28.6C402.4 276.3 384 312 384 352c0 70.7 57.3 128 128 128s128-57.3 128-128s-57.3-128-128-128c-13.5 0-26.5 2.1-38.7 6L418.2 128l61.8 0c17.7 0 32-14.3 32-32l0-32c0-17.7-14.3-32-32-32l-20.4 0c-7.5 0-14.7 2.6-20.5 7.4L391.7 78.9l-14-26c-7-12.9-20.5-21-35.2-21L280 32zM462.7 311.2l28.2 52.2c6.3 11.7 20.9 16 32.5 9.7s16-20.9 9.7-32.5l-28.2-52.2c2.3-.3 4.7-.4 7.1-.4c35.3 0 64 28.7 64 64s-28.7 64-64 64s-64-28.7-64-64c0-15.5 5.5-29.7 14.7-40.8zM187.3 376c-9.5 23.5-32.5 40-59.3 40c-35.3 0-64-28.7-64-64s28.7-64 64-64c26.9 0 49.9 16.5 59.3 40l66.4 0C242.5 268.8 190.5 224 128 224C57.3 224 0 281.3 0 352s57.3 128 128 128c62.5 0 114.5-44.8 125.8-104l-66.4 0zM128 384a32 32 0 1 0 0-64 32 32 0 1 0 0 64z\"]\n};\nconst faBellConcierge = {\n prefix: 'fas',\n iconName: 'bell-concierge',\n icon: [512, 512, [128718, \"concierge-bell\"], \"f562\", \"M216 64c-13.3 0-24 10.7-24 24s10.7 24 24 24l16 0 0 33.3C119.6 157.2 32 252.4 32 368l448 0c0-115.6-87.6-210.8-200-222.7l0-33.3 16 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-40 0-40 0zM24 400c-13.3 0-24 10.7-24 24s10.7 24 24 24l464 0c13.3 0 24-10.7 24-24s-10.7-24-24-24L24 400z\"]\n};\nconst faConciergeBell = faBellConcierge;\nconst faPenRuler = {\n prefix: 'fas',\n iconName: 'pen-ruler',\n icon: [512, 512, [\"pencil-ruler\"], \"f5ae\", \"M469.3 19.3l23.4 23.4c25 25 25 65.5 0 90.5l-56.4 56.4L322.3 75.7l56.4-56.4c25-25 65.5-25 90.5 0zM44.9 353.2L299.7 98.3 413.7 212.3 158.8 467.1c-6.7 6.7-15.1 11.6-24.2 14.2l-104 29.7c-8.4 2.4-17.4 .1-23.6-6.1s-8.5-15.2-6.1-23.6l29.7-104c2.6-9.2 7.5-17.5 14.2-24.2zM249.4 103.4L103.4 249.4 16 161.9c-18.7-18.7-18.7-49.1 0-67.9L94.1 16c18.7-18.7 49.1-18.7 67.9 0l19.8 19.8c-.3 .3-.7 .6-1 .9l-64 64c-6.2 6.2-6.2 16.4 0 22.6s16.4 6.2 22.6 0l64-64c.3-.3 .6-.7 .9-1l45.1 45.1zM408.6 262.6l45.1 45.1c-.3 .3-.7 .6-1 .9l-64 64c-6.2 6.2-6.2 16.4 0 22.6s16.4 6.2 22.6 0l64-64c.3-.3 .6-.7 .9-1L496 350.1c18.7 18.7 18.7 49.1 0 67.9L417.9 496c-18.7 18.7-49.1 18.7-67.9 0l-87.4-87.4L408.6 262.6z\"]\n};\nconst faPencilRuler = faPenRuler;\nconst faPeopleArrows = {\n prefix: 'fas',\n iconName: 'people-arrows',\n icon: [640, 512, [\"people-arrows-left-right\"], \"e068\", \"M64 64a64 64 0 1 1 128 0A64 64 0 1 1 64 64zM25.9 233.4C29.3 191.9 64 160 105.6 160l44.8 0c27 0 51 13.4 65.5 34.1c-2.7 1.9-5.2 4-7.5 6.3l-64 64c-21.9 21.9-21.9 57.3 0 79.2L192 391.2l0 72.8c0 26.5-21.5 48-48 48l-32 0c-26.5 0-48-21.5-48-48l0-115.7c-26.5-9.5-44.7-35.8-42.2-65.6l4.1-49.3zM448 64a64 64 0 1 1 128 0A64 64 0 1 1 448 64zM431.6 200.4c-2.3-2.3-4.9-4.4-7.5-6.3c14.5-20.7 38.6-34.1 65.5-34.1l44.8 0c41.6 0 76.3 31.9 79.7 73.4l4.1 49.3c2.5 29.8-15.7 56.1-42.2 65.6L576 464c0 26.5-21.5 48-48 48l-32 0c-26.5 0-48-21.5-48-48l0-72.8 47.6-47.6c21.9-21.9 21.9-57.3 0-79.2l-64-64zM272 240l0 32 96 0 0-32c0-9.7 5.8-18.5 14.8-22.2s19.3-1.7 26.2 5.2l64 64c9.4 9.4 9.4 24.6 0 33.9l-64 64c-6.9 6.9-17.2 8.9-26.2 5.2s-14.8-12.5-14.8-22.2l0-32-96 0 0 32c0 9.7-5.8 18.5-14.8 22.2s-19.3 1.7-26.2-5.2l-64-64c-9.4-9.4-9.4-24.6 0-33.9l64-64c6.9-6.9 17.2-8.9 26.2-5.2s14.8 12.5 14.8 22.2z\"]\n};\nconst faPeopleArrowsLeftRight = faPeopleArrows;\nconst faMarsAndVenusBurst = {\n prefix: 'fas',\n iconName: 'mars-and-venus-burst',\n icon: [640, 512, [], \"e523\", \"M504 0c-9.7 0-18.5 5.8-22.2 14.8s-1.7 19.3 5.2 26.2l39 39-22.2 22.2C475.9 78.4 439.6 64 400 64c-88.4 0-160 71.6-160 160c0 80.2 59.1 146.7 136.1 158.2c0 .6-.1 1.2-.1 1.8l0 .4 0 .4 0 .4 0 .4 0 .4 0 .4 0 .4 0 .4 0 .4 0 .4 0 .4 0 .4 0 .4 0 .4 0 .4 0 .4 0 .4 0 .4 0 .4 0 .4 0 .4 0 .4 0 .4 0 .4 0 .4 0 .4 0 .4 0 .4 0 .4 0 .4 0 .3 0 .4 0 .3 0 .3 0 .3 0 .3 0 .3 0 .3 0 .3 0 .3 0 .3 0 .3 0 .3 0 .3 0 .3 0 .3 0 .3 0 .3 0 .3 0 .3 0 .3 0 .3 0 .3 0 .3 0 .3 0 .3 0 .3 0 .3 0 .3 0 .3 0 .3 0 .3 0 .3 0 .3 0 .3 0 .3 0 .3 0 .3 0 .3-24 0c-13.3 0-24 10.7-24 24s10.7 24 24 24l24 0 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .2 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1 0 .1c0 0 0 .1 0 .1s0 .1 0 .1l0 .1c0 0 0 .1 0 .1s0 .1 0 .1s0 .1 0 .1s0 .1 0 .1s0 .1 0 .1s0 .1 0 .1s0 .1 0 .1s0 .1 0 .1s0 .1 0 .1s0 .1 0 .1s0 .1 0 .1s0 .1 0 .1s0 .1 0 .1s0 .1 0 .1s0 .1 0 .1s0 .1 0 .1s0 .1 0 .1s0 .1 0 .1s0 .1 0 .1s0 .1 0 .1s0 .1 0 .1s0 0 0 .1s0 0 0 .1s0 0 0 .1s0 0 0 .1s0 0 0 .1s0 0 0 .1s0 0 0 .1s0 0 0 .1s0 0 0 .1s0 0 0 .1s0 0 0 .1s0 0 0 .1s0 0 0 .1s0 0 0 .1s0 0 0 .1s0 0 0 .1s0 0 0 .1s0 0 0 .1s0 0 0 .1s0 0 0 .1s0 0 0 .1s0 0 0 .1s0 0 0 .1s0 0 0 .1s0 0 0 .1s0 0 0 .1s0 0 0 .1s0 0 0 .1s0 0 0 .1s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0l24 0-24 0c0 13.3 10.7 24 24 24s24-10.7 24-24l-24 0 24 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0-.1s0 0 0-.1s0 0 0-.1s0 0 0-.1s0 0 0-.1s0 0 0-.1s0 0 0-.1s0 0 0-.1s0 0 0-.1s0 0 0-.1s0 0 0-.1s0 0 0-.1s0 0 0-.1s0 0 0-.1s0 0 0-.1s0 0 0-.1s0 0 0-.1s0 0 0-.1s0 0 0-.1s0 0 0-.1s0 0 0-.1s0 0 0-.1s0 0 0-.1s0 0 0-.1s0 0 0-.1s0 0 0-.1s0 0 0-.1s0 0 0-.1s0 0 0-.1s0-.1 0-.1s0-.1 0-.1s0-.1 0-.1s0-.1 0-.1s0-.1 0-.1s0-.1 0-.1s0-.1 0-.1s0-.1 0-.1s0-.1 0-.1s0-.1 0-.1s0-.1 0-.1s0-.1 0-.1s0-.1 0-.1s0-.1 0-.1s0-.1 0-.1s0-.1 0-.1s0-.1 0-.1s0-.1 0-.1s0-.1 0-.1s0-.1 0-.1s0-.1 0-.1l0-.1c0 0 0-.1 0-.1s0-.1 0-.1l0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.1 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 0-.2 24 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-24 0 0-.3 0-.3 0-.3 0-.3 0-.3 0-.3 0-.3 0-.3 0-.3 0-.3 0-.3 0-.3 0-.3 0-.3 0-.3 0-.3 0-.3 0-.3 0-.3 0-.3 0-.3 0-.3 0-.3 0-.3 0-.3 0-.3 0-.3 0-.3 0-.3 0-.3 0-.3 0-.3 0-.3 0-.3 0-.3 0-.3 0-.3 0-.4 0-.3 0-.4 0-.4 0-.4 0-.4 0-.4 0-.4 0-.4 0-.4 0-.4 0-.4 0-.4 0-.4 0-.4 0-.4 0-.4 0-.4 0-.4 0-.4 0-.4 0-.4 0-.4 0-.4 0-.4 0-.4 0-.4 0-.4 0-.4 0-.4 0-.4 0-.4c0-.6 0-1.2-.1-1.8c77-11.6 136.1-78 136.1-158.2c0-31.4-9-60.7-24.7-85.4L560 113.9l39 39c6.9 6.9 17.2 8.9 26.2 5.2s14.8-12.5 14.8-22.2l0-112c0-13.3-10.7-24-24-24L504 0zM400 128a96 96 0 1 1 0 192 96 96 0 1 1 0-192zM190.9 18.1C188.4 12 182.6 8 176 8s-12.4 4-14.9 10.1l-29.4 74L55.6 68.9c-6.3-1.9-13.1 .2-17.2 5.3s-4.6 12.2-1.4 17.9l39.5 69.1L10.9 206.4c-5.4 3.7-8 10.3-6.5 16.7s6.7 11.2 13.1 12.2l78.7 12.2L90.6 327c-.5 6.5 3.1 12.7 9 15.5s12.9 1.8 17.8-2.6L176 286.1l58.6 53.9c4.1 3.8 9.9 5.1 15.2 3.6C223.6 310.8 208 269.2 208 224c0-60.8 28.3-115 72.4-150.2L220.3 92.1l-29.4-74z\"]\n};\nconst faSquareCaretRight = {\n prefix: 'fas',\n iconName: 'square-caret-right',\n icon: [448, 512, [\"caret-square-right\"], \"f152\", \"M448 96c0-35.3-28.7-64-64-64L64 32C28.7 32 0 60.7 0 96L0 416c0 35.3 28.7 64 64 64l320 0c35.3 0 64-28.7 64-64l0-320zM320 256c0 6.7-2.8 13-7.7 17.6l-112 104c-7 6.5-17.2 8.2-25.9 4.4s-14.4-12.5-14.4-22l0-208c0-9.5 5.7-18.2 14.4-22s18.9-2.1 25.9 4.4l112 104c4.9 4.5 7.7 10.9 7.7 17.6z\"]\n};\nconst faCaretSquareRight = faSquareCaretRight;\nconst faScissors = {\n prefix: 'fas',\n iconName: 'scissors',\n icon: [512, 512, [9984, 9986, 9988, \"cut\"], \"f0c4\", \"M256 192l-39.5-39.5c4.9-12.6 7.5-26.2 7.5-40.5C224 50.1 173.9 0 112 0S0 50.1 0 112s50.1 112 112 112c14.3 0 27.9-2.7 40.5-7.5L192 256l-39.5 39.5c-12.6-4.9-26.2-7.5-40.5-7.5C50.1 288 0 338.1 0 400s50.1 112 112 112s112-50.1 112-112c0-14.3-2.7-27.9-7.5-40.5L499.2 76.8c7.1-7.1 7.1-18.5 0-25.6c-28.3-28.3-74.1-28.3-102.4 0L256 192zm22.6 150.6L396.8 460.8c28.3 28.3 74.1 28.3 102.4 0c7.1-7.1 7.1-18.5 0-25.6L342.6 278.6l-64 64zM64 112a48 48 0 1 1 96 0 48 48 0 1 1 -96 0zm48 240a48 48 0 1 1 0 96 48 48 0 1 1 0-96z\"]\n};\nconst faCut = faScissors;\nconst faSunPlantWilt = {\n prefix: 'fas',\n iconName: 'sun-plant-wilt',\n icon: [640, 512, [], \"e57a\", \"M160 0c-6.3 0-12 3.7-14.6 9.5L120.6 64.9 63.9 43.2c-5.9-2.3-12.6-.8-17 3.6s-5.9 11.1-3.6 17l21.7 56.7L9.5 145.4C3.7 148 0 153.7 0 160s3.7 12 9.5 14.6l55.4 24.8L43.2 256.1c-2.3 5.9-.8 12.6 3.6 17s11.1 5.9 17 3.6l56.7-21.7 24.8 55.4c2.6 5.8 8.3 9.5 14.6 9.5s12-3.7 14.6-9.5l24.8-55.4 56.7 21.7c5.9 2.3 12.6 .8 17-3.6s5.9-11.1 3.6-17l-21.7-56.7 55.4-24.8c5.8-2.6 9.5-8.3 9.5-14.6s-3.7-12-9.5-14.6l-55.4-24.8 21.7-56.7c2.3-5.9 .8-12.6-3.6-17s-11.1-5.9-17-3.6L199.4 64.9 174.6 9.5C172 3.7 166.3 0 160 0zm0 96a64 64 0 1 1 0 128 64 64 0 1 1 0-128zm32 64a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zm312 16c0-17.7 14.3-32 32-32s32 14.3 32 32l0 53.4c-14.8 7.7-24 23.1-24 44.6c0 16.8 16 44 37.4 67.2c5.8 6.2 15.5 6.2 21.2 0C624 318 640 290.7 640 274c0-21.5-9.2-37-24-44.6l0-53.4c0-44.2-35.8-80-80-80s-80 35.8-80 80l0 22.7c-9.8-4.3-20.6-6.7-32-6.7c-44.2 0-80 35.8-80 80l0 21.4c-14.8 7.7-24 23.1-24 44.6c0 16.8 16 44 37.4 67.2c5.8 6.2 15.5 6.2 21.2 0C400 382 416 354.7 416 338c0-21.5-9.2-37-24-44.6l0-21.4c0-17.7 14.3-32 32-32s32 14.3 32 32l0 8 0 168L32 448c-17.7 0-32 14.3-32 32s14.3 32 32 32l576 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-104 0 0-168 0-8 0-96z\"]\n};\nconst faToiletsPortable = {\n prefix: 'fas',\n iconName: 'toilets-portable',\n icon: [576, 512, [], \"e584\", \"M32 0L224 0c17.7 0 32 14.3 32 32l0 32L0 64 0 32C0 14.3 14.3 0 32 0zM0 96l24 0 208 0 24 0 0 24 0 368c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-8L48 480l0 8c0 13.3-10.7 24-24 24s-24-10.7-24-24L0 120 0 96zM192 224c-8.8 0-16 7.2-16 16l0 64c0 8.8 7.2 16 16 16s16-7.2 16-16l0-64c0-8.8-7.2-16-16-16zM352 0L544 0c17.7 0 32 14.3 32 32l0 32L320 64l0-32c0-17.7 14.3-32 32-32zM320 96l24 0 208 0 24 0 0 24 0 368c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-8-160 0 0 8c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-368 0-24zM512 224c-8.8 0-16 7.2-16 16l0 64c0 8.8 7.2 16 16 16s16-7.2 16-16l0-64c0-8.8-7.2-16-16-16z\"]\n};\nconst faHockeyPuck = {\n prefix: 'fas',\n iconName: 'hockey-puck',\n icon: [512, 512, [], \"f453\", \"M256 256C114.6 256 0 213 0 160s114.6-96 256-96s256 43 256 96s-114.6 96-256 96zm192.3 1.8c24.7-9.3 46.9-21 63.7-35.6L512 352c0 53-114.6 96-256 96S0 405 0 352L0 222.3c16.8 14.6 39 26.3 63.7 35.6C114.5 276.9 182.5 288 256 288s141.5-11.1 192.3-30.2z\"]\n};\nconst faTable = {\n prefix: 'fas',\n iconName: 'table',\n icon: [512, 512, [], \"f0ce\", \"M64 256l0-96 160 0 0 96L64 256zm0 64l160 0 0 96L64 416l0-96zm224 96l0-96 160 0 0 96-160 0zM448 256l-160 0 0-96 160 0 0 96zM64 32C28.7 32 0 60.7 0 96L0 416c0 35.3 28.7 64 64 64l384 0c35.3 0 64-28.7 64-64l0-320c0-35.3-28.7-64-64-64L64 32z\"]\n};\nconst faMagnifyingGlassArrowRight = {\n prefix: 'fas',\n iconName: 'magnifying-glass-arrow-right',\n icon: [512, 512, [], \"e521\", \"M416 208c0 45.9-14.9 88.3-40 122.7L502.6 457.4c12.5 12.5 12.5 32.8 0 45.3s-32.8 12.5-45.3 0L330.7 376c-34.4 25.2-76.8 40-122.7 40C93.1 416 0 322.9 0 208S93.1 0 208 0S416 93.1 416 208zM241 119c-9.4-9.4-24.6-9.4-33.9 0s-9.4 24.6 0 33.9l31 31L120 184c-13.3 0-24 10.7-24 24s10.7 24 24 24l118.1 0-31 31c-9.4 9.4-9.4 24.6 0 33.9s24.6 9.4 33.9 0l72-72c9.4-9.4 9.4-24.6 0-33.9l-72-72z\"]\n};\nconst faTachographDigital = {\n prefix: 'fas',\n iconName: 'tachograph-digital',\n icon: [640, 512, [\"digital-tachograph\"], \"f566\", \"M64 64C28.7 64 0 92.7 0 128L0 384c0 35.3 28.7 64 64 64l512 0c35.3 0 64-28.7 64-64l0-256c0-35.3-28.7-64-64-64L64 64zm32 64l224 0c17.7 0 32 14.3 32 32l0 64c0 17.7-14.3 32-32 32L96 256c-17.7 0-32-14.3-32-32l0-64c0-17.7 14.3-32 32-32zM64 368c0-8.8 7.2-16 16-16l256 0c8.8 0 16 7.2 16 16s-7.2 16-16 16L80 384c-8.8 0-16-7.2-16-16zm320 0c0-8.8 7.2-16 16-16l160 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-160 0c-8.8 0-16-7.2-16-16zM80 288a16 16 0 1 1 0 32 16 16 0 1 1 0-32zm48 16a16 16 0 1 1 32 0 16 16 0 1 1 -32 0zm80-16a16 16 0 1 1 0 32 16 16 0 1 1 0-32zm48 16a16 16 0 1 1 32 0 16 16 0 1 1 -32 0zm80-16a16 16 0 1 1 0 32 16 16 0 1 1 0-32z\"]\n};\nconst faDigitalTachograph = faTachographDigital;\nconst faUsersSlash = {\n prefix: 'fas',\n iconName: 'users-slash',\n icon: [640, 512, [], \"e073\", \"M38.8 5.1C28.4-3.1 13.3-1.2 5.1 9.2S-1.2 34.7 9.2 42.9l592 464c10.4 8.2 25.5 6.3 33.7-4.1s6.3-25.5-4.1-33.7L440.6 320l178.1 0c11.8 0 21.3-9.6 21.3-21.3C640 239.8 592.2 192 533.3 192l-42.7 0c-15.9 0-31 3.5-44.6 9.7c1.3 7.2 1.9 14.7 1.9 22.3c0 30.2-10.5 58-28 79.9l-25.2-19.7C408.1 267.7 416 246.8 416 224c0-53-43-96-96-96c-31.1 0-58.7 14.8-76.3 37.7l-40.6-31.8c13-14.2 20.9-33.1 20.9-53.9c0-44.2-35.8-80-80-80C116.3 0 91.9 14.1 77.5 35.5L38.8 5.1zM106.7 192C47.8 192 0 239.8 0 298.7C0 310.4 9.6 320 21.3 320l213.3 0c.2 0 .4 0 .7 0c-20.6-18.2-35.2-42.8-40.8-70.8L121.8 192l-15.2 0zM261.3 352C187.7 352 128 411.7 128 485.3c0 14.7 11.9 26.7 26.7 26.7l330.7 0c10.5 0 19.5-6 23.9-14.8L324.9 352l-63.6 0zM512 160A80 80 0 1 0 512 0a80 80 0 1 0 0 160z\"]\n};\nconst faClover = {\n prefix: 'fas',\n iconName: 'clover',\n icon: [448, 512, [], \"e139\", \"M216.6 49.9C205.1 38.5 189.5 32 173.3 32C139.4 32 112 59.4 112 93.3l0 4.9c0 12 3.3 23.7 9.4 34l18.8 31.3c1.1 1.8 1.2 3.1 1 4.2c-.2 1.2-.8 2.5-2 3.6s-2.4 1.8-3.6 2c-1 .2-2.4 .1-4.2-1l-31.3-18.8c-10.3-6.2-22-9.4-34-9.4l-4.9 0C27.4 144 0 171.4 0 205.3c0 16.2 6.5 31.8 17.9 43.3l1.2 1.2c3.4 3.4 3.4 9 0 12.4l-1.2 1.2C6.5 274.9 0 290.5 0 306.7C0 340.6 27.4 368 61.3 368l4.9 0c12 0 23.7-3.3 34-9.4l31.3-18.8c1.8-1.1 3.1-1.2 4.2-1c1.2 .2 2.5 .8 3.6 2s1.8 2.4 2 3.6c.2 1 .1 2.4-1 4.2l-18.8 31.3c-6.2 10.3-9.4 22-9.4 34l0 4.9c0 33.8 27.4 61.3 61.3 61.3c16.2 0 31.8-6.5 43.3-17.9l1.2-1.2c3.4-3.4 9-3.4 12.4 0l1.2 1.2c11.5 11.5 27.1 17.9 43.3 17.9c33.8 0 61.3-27.4 61.3-61.3l0-4.9c0-12-3.3-23.7-9.4-34l-18.8-31.3c-1.1-1.8-1.2-3.1-1-4.2c.2-1.2 .8-2.5 2-3.6s2.4-1.8 3.6-2c1-.2 2.4-.1 4.2 1l31.3 18.8c10.3 6.2 22 9.4 34 9.4l4.9 0c33.8 0 61.3-27.4 61.3-61.3c0-16.2-6.5-31.8-17.9-43.3l-1.2-1.2c-3.4-3.4-3.4-9 0-12.4l1.2-1.2c11.5-11.5 17.9-27.1 17.9-43.3c0-33.8-27.4-61.3-61.3-61.3l-4.9 0c-12 0-23.7 3.3-34 9.4l-31.3 18.8c-1.8 1.1-3.1 1.2-4.2 1c-1.2-.2-2.5-.8-3.6-2s-1.8-2.4-2-3.6c-.2-1-.1-2.4 1-4.2l18.8-31.3c6.2-10.3 9.4-22 9.4-34l0-4.9C336 59.4 308.6 32 274.7 32c-16.2 0-31.8 6.5-43.3 17.9l-1.2 1.2c-3.4 3.4-9 3.4-12.4 0l-1.2-1.2z\"]\n};\nconst faReply = {\n prefix: 'fas',\n iconName: 'reply',\n icon: [512, 512, [61714, \"mail-reply\"], \"f3e5\", \"M205 34.8c11.5 5.1 19 16.6 19 29.2l0 64 112 0c97.2 0 176 78.8 176 176c0 113.3-81.5 163.9-100.2 174.1c-2.5 1.4-5.3 1.9-8.1 1.9c-10.9 0-19.7-8.9-19.7-19.7c0-7.5 4.3-14.4 9.8-19.5c9.4-8.8 22.2-26.4 22.2-56.7c0-53-43-96-96-96l-96 0 0 64c0 12.6-7.4 24.1-19 29.2s-25 3-34.4-5.4l-160-144C3.9 225.7 0 217.1 0 208s3.9-17.7 10.6-23.8l160-144c9.4-8.5 22.9-10.6 34.4-5.4z\"]\n};\nconst faMailReply = faReply;\nconst faStarAndCrescent = {\n prefix: 'fas',\n iconName: 'star-and-crescent',\n icon: [512, 512, [9770], \"f699\", \"M0 256C0 114.6 114.6 0 256 0c33 0 64.6 6.3 93.6 17.7c7.4 2.9 11.5 10.7 9.8 18.4s-8.8 13-16.7 12.4c-4.8-.3-9.7-.5-14.6-.5c-114.9 0-208 93.1-208 208s93.1 208 208 208c4.9 0 9.8-.2 14.6-.5c7.9-.5 15 4.7 16.7 12.4s-2.4 15.5-9.8 18.4C320.6 505.7 289 512 256 512C114.6 512 0 397.4 0 256zM375.4 137.4c3.5-7.1 13.7-7.1 17.2 0l31.5 63.8c1.4 2.8 4.1 4.8 7.2 5.3l70.4 10.2c7.9 1.1 11 10.8 5.3 16.4l-50.9 49.6c-2.3 2.2-3.3 5.4-2.8 8.5l12 70.1c1.3 7.8-6.9 13.8-13.9 10.1l-63-33.1c-2.8-1.5-6.1-1.5-8.9 0l-63 33.1c-7 3.7-15.3-2.3-13.9-10.1l12-70.1c.5-3.1-.5-6.3-2.8-8.5L261 233.1c-5.7-5.6-2.6-15.2 5.3-16.4l70.4-10.2c3.1-.5 5.8-2.4 7.2-5.3l31.5-63.8z\"]\n};\nconst faHouseFire = {\n prefix: 'fas',\n iconName: 'house-fire',\n icon: [640, 512, [], \"e50c\", \"M288 350.1l0 1.9-32 0c-17.7 0-32 14.3-32 32l0 64 0 24c0 22.1-17.9 40-40 40l-24 0-31.9 0c-1.5 0-3-.1-4.5-.2c-1.2 .1-2.4 .2-3.6 .2l-16 0c-22.1 0-40-17.9-40-40l0-112c0-.9 0-1.9 .1-2.8l0-69.7-32 0c-18 0-32-14-32-32.1c0-9 3-17 10-24L266.4 8c7-7 15-8 22-8s15 2 21 7L447.3 128.1c-12.3-1-25 3-34.8 11.7c-35.4 31.6-65.6 67.7-87.3 102.8C304.3 276.5 288 314.9 288 350.1zM480 512c-88.4 0-160-71.6-160-160c0-76.7 62.5-144.7 107.2-179.4c5-3.9 10.9-5.8 16.8-5.8c7.9-.1 16 3.1 22 9.2l46 46 11.3-11.3c11.7-11.7 30.6-12.7 42.3-1C624.5 268 640 320.2 640 352c0 88.4-71.6 160-160 160zm64-111.8c0-36.5-37-73-54.8-88.4c-5.4-4.7-13.1-4.7-18.5 0C453 327.1 416 363.6 416 400.2c0 35.3 28.7 64 64 64s64-28.7 64-64z\"]\n};\nconst faSquareMinus = {\n prefix: 'fas',\n iconName: 'square-minus',\n icon: [448, 512, [61767, \"minus-square\"], \"f146\", \"M64 32C28.7 32 0 60.7 0 96L0 416c0 35.3 28.7 64 64 64l320 0c35.3 0 64-28.7 64-64l0-320c0-35.3-28.7-64-64-64L64 32zm88 200l144 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-144 0c-13.3 0-24-10.7-24-24s10.7-24 24-24z\"]\n};\nconst faMinusSquare = faSquareMinus;\nconst faHelicopter = {\n prefix: 'fas',\n iconName: 'helicopter',\n icon: [640, 512, [128641], \"f533\", \"M128 32c0-17.7 14.3-32 32-32L544 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L384 64l0 64 32 0c88.4 0 160 71.6 160 160l0 64c0 17.7-14.3 32-32 32l-160 0-64 0c-20.1 0-39.1-9.5-51.2-25.6l-71.4-95.2c-3.5-4.7-8.3-8.3-13.7-10.5L47.2 198.1c-9.5-3.8-16.7-12-19.2-22L5 83.9C2.4 73.8 10.1 64 20.5 64L48 64c10.1 0 19.6 4.7 25.6 12.8L112 128l208 0 0-64L160 64c-17.7 0-32-14.3-32-32zM384 320l128 0 0-32c0-53-43-96-96-96l-32 0 0 128zM630.6 425.4c12.5 12.5 12.5 32.8 0 45.3l-3.9 3.9c-24 24-56.6 37.5-90.5 37.5L256 512c-17.7 0-32-14.3-32-32s14.3-32 32-32l280.2 0c17 0 33.3-6.7 45.3-18.7l3.9-3.9c12.5-12.5 32.8-12.5 45.3 0z\"]\n};\nconst faCompass = {\n prefix: 'fas',\n iconName: 'compass',\n icon: [512, 512, [129517], \"f14e\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zm50.7-186.9L162.4 380.6c-19.4 7.5-38.5-11.6-31-31l55.5-144.3c3.3-8.5 9.9-15.1 18.4-18.4l144.3-55.5c19.4-7.5 38.5 11.6 31 31L325.1 306.7c-3.2 8.5-9.9 15.1-18.4 18.4zM288 256a32 32 0 1 0 -64 0 32 32 0 1 0 64 0z\"]\n};\nconst faSquareCaretDown = {\n prefix: 'fas',\n iconName: 'square-caret-down',\n icon: [448, 512, [\"caret-square-down\"], \"f150\", \"M384 480c35.3 0 64-28.7 64-64l0-320c0-35.3-28.7-64-64-64L64 32C28.7 32 0 60.7 0 96L0 416c0 35.3 28.7 64 64 64l320 0zM224 352c-6.7 0-13-2.8-17.6-7.7l-104-112c-6.5-7-8.2-17.2-4.4-25.9s12.5-14.4 22-14.4l208 0c9.5 0 18.2 5.7 22 14.4s2.1 18.9-4.4 25.9l-104 112c-4.5 4.9-10.9 7.7-17.6 7.7z\"]\n};\nconst faCaretSquareDown = faSquareCaretDown;\nconst faFileCircleQuestion = {\n prefix: 'fas',\n iconName: 'file-circle-question',\n icon: [576, 512, [], \"e4ef\", \"M0 64C0 28.7 28.7 0 64 0L224 0l0 128c0 17.7 14.3 32 32 32l128 0 0 38.6C310.1 219.5 256 287.4 256 368c0 59.1 29.1 111.3 73.7 143.3c-3.2 .5-6.4 .7-9.7 .7L64 512c-35.3 0-64-28.7-64-64L0 64zm384 64l-128 0L256 0 384 128zm48 96a144 144 0 1 1 0 288 144 144 0 1 1 0-288zm0 240a24 24 0 1 0 0-48 24 24 0 1 0 0 48zM368 321.6l0 6.4c0 8.8 7.2 16 16 16s16-7.2 16-16l0-6.4c0-5.3 4.3-9.6 9.6-9.6l40.5 0c7.7 0 13.9 6.2 13.9 13.9c0 5.2-2.9 9.9-7.4 12.3l-32 16.8c-5.3 2.8-8.6 8.2-8.6 14.2l0 14.8c0 8.8 7.2 16 16 16s16-7.2 16-16l0-5.1 23.5-12.3c15.1-7.9 24.5-23.6 24.5-40.6c0-25.4-20.6-45.9-45.9-45.9l-40.5 0c-23 0-41.6 18.6-41.6 41.6z\"]\n};\nconst faLaptopCode = {\n prefix: 'fas',\n iconName: 'laptop-code',\n icon: [640, 512, [], \"f5fc\", \"M64 96c0-35.3 28.7-64 64-64l384 0c35.3 0 64 28.7 64 64l0 256-64 0 0-256L128 96l0 256-64 0L64 96zM0 403.2C0 392.6 8.6 384 19.2 384l601.6 0c10.6 0 19.2 8.6 19.2 19.2c0 42.4-34.4 76.8-76.8 76.8L76.8 480C34.4 480 0 445.6 0 403.2zM281 209l-31 31 31 31c9.4 9.4 9.4 24.6 0 33.9s-24.6 9.4-33.9 0l-48-48c-9.4-9.4-9.4-24.6 0-33.9l48-48c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9zM393 175l48 48c9.4 9.4 9.4 24.6 0 33.9l-48 48c-9.4 9.4-24.6 9.4-33.9 0s-9.4-24.6 0-33.9l31-31-31-31c-9.4-9.4-9.4-24.6 0-33.9s24.6-9.4 33.9 0z\"]\n};\nconst faSwatchbook = {\n prefix: 'fas',\n iconName: 'swatchbook',\n icon: [512, 512, [], \"f5c3\", \"M0 32C0 14.3 14.3 0 32 0L160 0c17.7 0 32 14.3 32 32l0 384c0 53-43 96-96 96s-96-43-96-96L0 32zM223.6 425.9c.3-3.3 .4-6.6 .4-9.9l0-262 75.4-75.4c12.5-12.5 32.8-12.5 45.3 0l90.5 90.5c12.5 12.5 12.5 32.8 0 45.3L223.6 425.9zM182.8 512l192-192L480 320c17.7 0 32 14.3 32 32l0 128c0 17.7-14.3 32-32 32l-297.2 0zM128 64L64 64l0 64 64 0 0-64zM64 192l0 64 64 0 0-64-64 0zM96 440a24 24 0 1 0 0-48 24 24 0 1 0 0 48z\"]\n};\nconst faPrescriptionBottle = {\n prefix: 'fas',\n iconName: 'prescription-bottle',\n icon: [384, 512, [], \"f485\", \"M0 32C0 14.3 14.3 0 32 0L352 0c17.7 0 32 14.3 32 32l0 32c0 17.7-14.3 32-32 32L32 96C14.3 96 0 81.7 0 64L0 32zm32 96l320 0 0 320c0 35.3-28.7 64-64 64L96 512c-35.3 0-64-28.7-64-64l0-32 112 0c8.8 0 16-7.2 16-16s-7.2-16-16-16L32 384l0-64 112 0c8.8 0 16-7.2 16-16s-7.2-16-16-16L32 288l0-64 112 0c8.8 0 16-7.2 16-16s-7.2-16-16-16L32 192l0-64z\"]\n};\nconst faBars = {\n prefix: 'fas',\n iconName: 'bars',\n icon: [448, 512, [\"navicon\"], \"f0c9\", \"M0 96C0 78.3 14.3 64 32 64l384 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L32 128C14.3 128 0 113.7 0 96zM0 256c0-17.7 14.3-32 32-32l384 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L32 288c-17.7 0-32-14.3-32-32zM448 416c0 17.7-14.3 32-32 32L32 448c-17.7 0-32-14.3-32-32s14.3-32 32-32l384 0c17.7 0 32 14.3 32 32z\"]\n};\nconst faNavicon = faBars;\nconst faPeopleGroup = {\n prefix: 'fas',\n iconName: 'people-group',\n icon: [640, 512, [], \"e533\", \"M72 88a56 56 0 1 1 112 0A56 56 0 1 1 72 88zM64 245.7C54 256.9 48 271.8 48 288s6 31.1 16 42.3l0-84.7zm144.4-49.3C178.7 222.7 160 261.2 160 304c0 34.3 12 65.8 32 90.5l0 21.5c0 17.7-14.3 32-32 32l-64 0c-17.7 0-32-14.3-32-32l0-26.8C26.2 371.2 0 332.7 0 288c0-61.9 50.1-112 112-112l32 0c24 0 46.2 7.5 64.4 20.3zM448 416l0-21.5c20-24.7 32-56.2 32-90.5c0-42.8-18.7-81.3-48.4-107.7C449.8 183.5 472 176 496 176l32 0c61.9 0 112 50.1 112 112c0 44.7-26.2 83.2-64 101.2l0 26.8c0 17.7-14.3 32-32 32l-64 0c-17.7 0-32-14.3-32-32zm8-328a56 56 0 1 1 112 0A56 56 0 1 1 456 88zM576 245.7l0 84.7c10-11.3 16-26.1 16-42.3s-6-31.1-16-42.3zM320 32a64 64 0 1 1 0 128 64 64 0 1 1 0-128zM240 304c0 16.2 6 31 16 42.3l0-84.7c-10 11.3-16 26.1-16 42.3zm144-42.3l0 84.7c10-11.3 16-26.1 16-42.3s-6-31.1-16-42.3zM448 304c0 44.7-26.2 83.2-64 101.2l0 42.8c0 17.7-14.3 32-32 32l-64 0c-17.7 0-32-14.3-32-32l0-42.8c-37.8-18-64-56.5-64-101.2c0-61.9 50.1-112 112-112l32 0c61.9 0 112 50.1 112 112z\"]\n};\nconst faHourglassEnd = {\n prefix: 'fas',\n iconName: 'hourglass-end',\n icon: [384, 512, [8987, \"hourglass-3\"], \"f253\", \"M32 0C14.3 0 0 14.3 0 32S14.3 64 32 64l0 11c0 42.4 16.9 83.1 46.9 113.1L146.7 256 78.9 323.9C48.9 353.9 32 394.6 32 437l0 11c-17.7 0-32 14.3-32 32s14.3 32 32 32l32 0 256 0 32 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l0-11c0-42.4-16.9-83.1-46.9-113.1L237.3 256l67.9-67.9c30-30 46.9-70.7 46.9-113.1l0-11c17.7 0 32-14.3 32-32s-14.3-32-32-32L320 0 64 0 32 0zM96 75l0-11 192 0 0 11c0 25.5-10.1 49.9-28.1 67.9L192 210.7l-67.9-67.9C106.1 124.9 96 100.4 96 75z\"]\n};\nconst faHourglass3 = faHourglassEnd;\nconst faHeartCrack = {\n prefix: 'fas',\n iconName: 'heart-crack',\n icon: [512, 512, [128148, \"heart-broken\"], \"f7a9\", \"M119.4 44.1c23.3-3.9 46.8-1.9 68.6 5.3l49.8 77.5-75.4 75.4c-1.5 1.5-2.4 3.6-2.3 5.8s1 4.2 2.6 5.7l112 104c2.9 2.7 7.4 2.9 10.5 .3s3.8-7 1.7-10.4l-60.4-98.1 90.7-75.6c2.6-2.1 3.5-5.7 2.4-8.8L296.8 61.8c28.5-16.7 62.4-23.2 95.7-17.6C461.5 55.6 512 115.2 512 185.1l0 5.8c0 41.5-17.2 81.2-47.6 109.5L283.7 469.1c-7.5 7-17.4 10.9-27.7 10.9s-20.2-3.9-27.7-10.9L47.6 300.4C17.2 272.1 0 232.4 0 190.9l0-5.8c0-69.9 50.5-129.5 119.4-141z\"]\n};\nconst faHeartBroken = faHeartCrack;\nconst faSquareUpRight = {\n prefix: 'fas',\n iconName: 'square-up-right',\n icon: [448, 512, [8599, \"external-link-square-alt\"], \"f360\", \"M384 32c35.3 0 64 28.7 64 64l0 320c0 35.3-28.7 64-64 64L64 480c-35.3 0-64-28.7-64-64L0 96C0 60.7 28.7 32 64 32l320 0zM160 160c-6.5 0-12.3 3.9-14.8 9.9s-1.1 12.9 3.5 17.4l40 40-71 71C114 302 112 306.9 112 312s2 10 5.7 13.7l36.7 36.7c3.6 3.6 8.5 5.7 13.7 5.7s10-2 13.7-5.7l71-71 40 40c4.6 4.6 11.5 5.9 17.4 3.5s9.9-8.3 9.9-14.8l0-144c0-8.8-7.2-16-16-16l-144 0z\"]\n};\nconst faExternalLinkSquareAlt = faSquareUpRight;\nconst faFaceKissBeam = {\n prefix: 'fas',\n iconName: 'face-kiss-beam',\n icon: [512, 512, [128537, \"kiss-beam\"], \"f597\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zm48.7-198.3c4.3 5.1 7.3 11.4 7.3 18.3s-3.1 13.2-7.3 18.3c-4.3 5.2-10.1 9.7-16.7 13.4c-2.7 1.5-5.7 3-8.7 4.3c3.1 1.3 6 2.7 8.7 4.3c6.6 3.7 12.5 8.2 16.7 13.4c4.3 5.1 7.3 11.4 7.3 18.3s-3.1 13.2-7.3 18.3c-4.3 5.2-10.1 9.7-16.7 13.4C274.7 443.1 257.4 448 240 448c-3.6 0-6.8-2.5-7.7-6s.6-7.2 3.8-9c0 0 0 0 0 0s0 0 0 0s0 0 0 0c0 0 0 0 0 0l.2-.1c.2-.1 .5-.3 .9-.5c.8-.5 2-1.2 3.4-2.1c2.8-1.9 6.5-4.5 10.2-7.6c3.7-3.1 7.2-6.6 9.6-10.1c2.5-3.5 3.5-6.4 3.5-8.6s-1-5-3.5-8.6c-2.5-3.5-5.9-6.9-9.6-10.1c-3.7-3.1-7.4-5.7-10.2-7.6c-1.4-.9-2.6-1.6-3.4-2.1c-.4-.2-.7-.4-.9-.5l-.2-.1c0 0 0 0 0 0c0 0 0 0 0 0s0 0 0 0c-2.5-1.4-4.1-4.1-4.1-7s1.6-5.6 4.1-7c0 0 0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0c0 0 0 0 0 0l.2-.1 .3-.2 .6-.4c.8-.5 2-1.2 3.4-2.1c2.8-1.9 6.5-4.5 10.2-7.6c3.7-3.1 7.2-6.6 9.6-10.1c2.5-3.5 3.5-6.4 3.5-8.6s-1-5-3.5-8.6c-2.5-3.5-5.9-6.9-9.6-10.1c-3.7-3.1-7.4-5.7-10.2-7.6c-1.4-.9-2.6-1.6-3.4-2.1l-.4-.3-.5-.3-.2-.1c0 0 0 0 0 0c0 0 0 0 0 0s0 0 0 0c-3.2-1.8-4.7-5.5-3.8-9s4.1-6 7.7-6c17.4 0 34.7 4.9 47.9 12.3c6.6 3.7 12.5 8.2 16.7 13.4zm-87.1-84.9s0 0 0 0c0 0 0 0 0 0l-.2-.2c-.2-.2-.4-.5-.7-.9c-.6-.8-1.6-2-2.8-3.4c-2.5-2.8-6-6.6-10.2-10.3c-8.8-7.8-18.8-14-27.7-14s-18.9 6.2-27.7 14c-4.2 3.7-7.7 7.5-10.2 10.3c-1.2 1.4-2.2 2.6-2.8 3.4c-.3 .4-.6 .7-.7 .9l-.2 .2c0 0 0 0 0 0c0 0 0 0 0 0s0 0 0 0c-2.1 2.8-5.7 3.9-8.9 2.8s-5.5-4.1-5.5-7.6c0-17.9 6.7-35.6 16.6-48.8c9.8-13 23.9-23.2 39.4-23.2s29.6 10.2 39.4 23.2c9.9 13.2 16.6 30.9 16.6 48.8c0 3.4-2.2 6.5-5.5 7.6s-6.9 0-8.9-2.8c0 0 0 0 0 0s0 0 0 0zm160 0c0 0 0 0 0 0l-.2-.2c-.2-.2-.4-.5-.7-.9c-.6-.8-1.6-2-2.8-3.4c-2.5-2.8-6-6.6-10.2-10.3c-8.8-7.8-18.8-14-27.7-14s-18.9 6.2-27.7 14c-4.2 3.7-7.7 7.5-10.2 10.3c-1.2 1.4-2.2 2.6-2.8 3.4c-.3 .4-.6 .7-.7 .9l-.2 .2c0 0 0 0 0 0c0 0 0 0 0 0s0 0 0 0c-2.1 2.8-5.7 3.9-8.9 2.8s-5.5-4.1-5.5-7.6c0-17.9 6.7-35.6 16.6-48.8c9.8-13 23.9-23.2 39.4-23.2s29.6 10.2 39.4 23.2c9.9 13.2 16.6 30.9 16.6 48.8c0 3.4-2.2 6.5-5.5 7.6s-6.9 0-8.9-2.8c0 0 0 0 0 0s0 0 0 0s0 0 0 0z\"]\n};\nconst faKissBeam = faFaceKissBeam;\nconst faFilm = {\n prefix: 'fas',\n iconName: 'film',\n icon: [512, 512, [127902], \"f008\", \"M0 96C0 60.7 28.7 32 64 32l384 0c35.3 0 64 28.7 64 64l0 320c0 35.3-28.7 64-64 64L64 480c-35.3 0-64-28.7-64-64L0 96zM48 368l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0c-8.8 0-16 7.2-16 16zm368-16c-8.8 0-16 7.2-16 16l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0zM48 240l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0c-8.8 0-16 7.2-16 16zm368-16c-8.8 0-16 7.2-16 16l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0zM48 112l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16L64 96c-8.8 0-16 7.2-16 16zM416 96c-8.8 0-16 7.2-16 16l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0zM160 128l0 64c0 17.7 14.3 32 32 32l128 0c17.7 0 32-14.3 32-32l0-64c0-17.7-14.3-32-32-32L192 96c-17.7 0-32 14.3-32 32zm32 160c-17.7 0-32 14.3-32 32l0 64c0 17.7 14.3 32 32 32l128 0c17.7 0 32-14.3 32-32l0-64c0-17.7-14.3-32-32-32l-128 0z\"]\n};\nconst faRulerHorizontal = {\n prefix: 'fas',\n iconName: 'ruler-horizontal',\n icon: [640, 512, [], \"f547\", \"M0 336c0 26.5 21.5 48 48 48l544 0c26.5 0 48-21.5 48-48l0-160c0-26.5-21.5-48-48-48l-64 0 0 80c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-80-64 0 0 80c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-80-64 0 0 80c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-80-64 0 0 80c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-80-64 0 0 80c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-80-64 0c-26.5 0-48 21.5-48 48L0 336z\"]\n};\nconst faPeopleRobbery = {\n prefix: 'fas',\n iconName: 'people-robbery',\n icon: [576, 512, [], \"e536\", \"M488.2 59.1C478.1 99.6 441.7 128 400 128s-78.1-28.4-88.2-68.9L303 24.2C298.8 7.1 281.4-3.3 264.2 1S236.7 22.6 241 39.8l8.7 34.9c11 44 40.2 79.6 78.3 99.6L328 480c0 17.7 14.3 32 32 32s32-14.3 32-32l0-128 16 0 0 128c0 17.7 14.3 32 32 32s32-14.3 32-32l0-305.7c38.1-20 67.3-55.6 78.3-99.6L559 39.8c4.3-17.1-6.1-34.5-23.3-38.8S501.2 7.1 497 24.2l-8.7 34.9zM400 96a48 48 0 1 0 0-96 48 48 0 1 0 0 96zM80 96A48 48 0 1 0 80 0a48 48 0 1 0 0 96zm-8 32c-35.3 0-64 28.7-64 64l0 96 0 .6L8 480c0 17.7 14.3 32 32 32s32-14.3 32-32l0-128 16 0 0 128c0 17.7 14.3 32 32 32s32-14.3 32-32l0-227.3 13 20.5c5.9 9.2 16.1 14.9 27 14.9l48 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-30.4 0-37.4-58.9C157.6 142 132.1 128 104.7 128L72 128z\"]\n};\nconst faLightbulb = {\n prefix: 'fas',\n iconName: 'lightbulb',\n icon: [384, 512, [128161], \"f0eb\", \"M272 384c9.6-31.9 29.5-59.1 49.2-86.2c0 0 0 0 0 0c5.2-7.1 10.4-14.2 15.4-21.4c19.8-28.5 31.4-63 31.4-100.3C368 78.8 289.2 0 192 0S16 78.8 16 176c0 37.3 11.6 71.9 31.4 100.3c5 7.2 10.2 14.3 15.4 21.4c0 0 0 0 0 0c19.8 27.1 39.7 54.4 49.2 86.2l160 0zM192 512c44.2 0 80-35.8 80-80l0-16-160 0 0 16c0 44.2 35.8 80 80 80zM112 176c0 8.8-7.2 16-16 16s-16-7.2-16-16c0-61.9 50.1-112 112-112c8.8 0 16 7.2 16 16s-7.2 16-16 16c-44.2 0-80 35.8-80 80z\"]\n};\nconst faCaretLeft = {\n prefix: 'fas',\n iconName: 'caret-left',\n icon: [256, 512, [], \"f0d9\", \"M9.4 278.6c-12.5-12.5-12.5-32.8 0-45.3l128-128c9.2-9.2 22.9-11.9 34.9-6.9s19.8 16.6 19.8 29.6l0 256c0 12.9-7.8 24.6-19.8 29.6s-25.7 2.2-34.9-6.9l-128-128z\"]\n};\nconst faCircleExclamation = {\n prefix: 'fas',\n iconName: 'circle-exclamation',\n icon: [512, 512, [\"exclamation-circle\"], \"f06a\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zm0-384c13.3 0 24 10.7 24 24l0 112c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-112c0-13.3 10.7-24 24-24zM224 352a32 32 0 1 1 64 0 32 32 0 1 1 -64 0z\"]\n};\nconst faExclamationCircle = faCircleExclamation;\nconst faSchoolCircleXmark = {\n prefix: 'fas',\n iconName: 'school-circle-xmark',\n icon: [640, 512, [], \"e56d\", \"M337.8 5.4C327-1.8 313-1.8 302.2 5.4L166.3 96 48 96C21.5 96 0 117.5 0 144L0 464c0 26.5 21.5 48 48 48l272 0s0 0 0 0l-64 0 0-96c0-35.3 28.7-64 64-64l.3 0 .5 0c3.4-37.7 18.7-72.1 42.2-99.1C350.2 260 335.6 264 320 264c-48.6 0-88-39.4-88-88s39.4-88 88-88s88 39.4 88 88c0 18.3-5.6 35.3-15.1 49.4c29-21 64.6-33.4 103.1-33.4c59.5 0 112.1 29.6 144 74.8L640 144c0-26.5-21.5-48-48-48L473.7 96 337.8 5.4zM96 192l32 0c8.8 0 16 7.2 16 16l0 64c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-64c0-8.8 7.2-16 16-16zm0 128l32 0c8.8 0 16 7.2 16 16l0 64c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-64c0-8.8 7.2-16 16-16zM320 128c-8.8 0-16 7.2-16 16l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16s-7.2-16-16-16l-16 0 0-16c0-8.8-7.2-16-16-16zM496 512a144 144 0 1 0 0-288 144 144 0 1 0 0 288zm22.6-144l36.7 36.7c6.2 6.2 6.2 16.4 0 22.6s-16.4 6.2-22.6 0L496 390.6l-36.7 36.7c-6.2 6.2-16.4 6.2-22.6 0s-6.2-16.4 0-22.6L473.4 368l-36.7-36.7c-6.2-6.2-6.2-16.4 0-22.6s16.4-6.2 22.6 0L496 345.4l36.7-36.7c6.2-6.2 16.4-6.2 22.6 0s6.2 16.4 0 22.6L518.6 368z\"]\n};\nconst faArrowRightFromBracket = {\n prefix: 'fas',\n iconName: 'arrow-right-from-bracket',\n icon: [512, 512, [\"sign-out\"], \"f08b\", \"M502.6 278.6c12.5-12.5 12.5-32.8 0-45.3l-128-128c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3L402.7 224 192 224c-17.7 0-32 14.3-32 32s14.3 32 32 32l210.7 0-73.4 73.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0l128-128zM160 96c17.7 0 32-14.3 32-32s-14.3-32-32-32L96 32C43 32 0 75 0 128L0 384c0 53 43 96 96 96l64 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-64 0c-17.7 0-32-14.3-32-32l0-256c0-17.7 14.3-32 32-32l64 0z\"]\n};\nconst faSignOut = faArrowRightFromBracket;\nconst faCircleChevronDown = {\n prefix: 'fas',\n iconName: 'circle-chevron-down',\n icon: [512, 512, [\"chevron-circle-down\"], \"f13a\", \"M256 0a256 256 0 1 0 0 512A256 256 0 1 0 256 0zM135 241c-9.4-9.4-9.4-24.6 0-33.9s24.6-9.4 33.9 0l87 87 87-87c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L273 345c-9.4 9.4-24.6 9.4-33.9 0L135 241z\"]\n};\nconst faChevronCircleDown = faCircleChevronDown;\nconst faUnlockKeyhole = {\n prefix: 'fas',\n iconName: 'unlock-keyhole',\n icon: [448, 512, [\"unlock-alt\"], \"f13e\", \"M224 64c-44.2 0-80 35.8-80 80l0 48 240 0c35.3 0 64 28.7 64 64l0 192c0 35.3-28.7 64-64 64L64 512c-35.3 0-64-28.7-64-64L0 256c0-35.3 28.7-64 64-64l16 0 0-48C80 64.5 144.5 0 224 0c57.5 0 107 33.7 130.1 82.3c7.6 16 .8 35.1-15.2 42.6s-35.1 .8-42.6-15.2C283.4 82.6 255.9 64 224 64zm32 320c17.7 0 32-14.3 32-32s-14.3-32-32-32l-64 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l64 0z\"]\n};\nconst faUnlockAlt = faUnlockKeyhole;\nconst faCloudShowersHeavy = {\n prefix: 'fas',\n iconName: 'cloud-showers-heavy',\n icon: [512, 512, [], \"f740\", \"M96 320c-53 0-96-43-96-96c0-42.5 27.6-78.6 65.9-91.2C64.7 126.1 64 119.1 64 112C64 50.1 114.1 0 176 0c43.1 0 80.5 24.3 99.2 60c14.7-17.1 36.5-28 60.8-28c44.2 0 80 35.8 80 80c0 5.5-.6 10.8-1.6 16c.5 0 1.1 0 1.6 0c53 0 96 43 96 96s-43 96-96 96L96 320zM81.5 353.9c12.2 5.2 17.8 19.3 12.6 31.5l-48 112c-5.2 12.2-19.3 17.8-31.5 12.6S-3.3 490.7 1.9 478.5l48-112c5.2-12.2 19.3-17.8 31.5-12.6zm120 0c12.2 5.2 17.8 19.3 12.6 31.5l-48 112c-5.2 12.2-19.3 17.8-31.5 12.6s-17.8-19.3-12.6-31.5l48-112c5.2-12.2 19.3-17.8 31.5-12.6zm244.6 31.5l-48 112c-5.2 12.2-19.3 17.8-31.5 12.6s-17.8-19.3-12.6-31.5l48-112c5.2-12.2 19.3-17.8 31.5-12.6s17.8 19.3 12.6 31.5zM313.5 353.9c12.2 5.2 17.8 19.3 12.6 31.5l-48 112c-5.2 12.2-19.3 17.8-31.5 12.6s-17.8-19.3-12.6-31.5l48-112c5.2-12.2 19.3-17.8 31.5-12.6z\"]\n};\nconst faHeadphonesSimple = {\n prefix: 'fas',\n iconName: 'headphones-simple',\n icon: [512, 512, [\"headphones-alt\"], \"f58f\", \"M256 80C141.1 80 48 173.1 48 288l0 104c0 13.3-10.7 24-24 24s-24-10.7-24-24L0 288C0 146.6 114.6 32 256 32s256 114.6 256 256l0 104c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-104c0-114.9-93.1-208-208-208zM80 352c0-35.3 28.7-64 64-64l16 0c17.7 0 32 14.3 32 32l0 128c0 17.7-14.3 32-32 32l-16 0c-35.3 0-64-28.7-64-64l0-64zm288-64c35.3 0 64 28.7 64 64l0 64c0 35.3-28.7 64-64 64l-16 0c-17.7 0-32-14.3-32-32l0-128c0-17.7 14.3-32 32-32l16 0z\"]\n};\nconst faHeadphonesAlt = faHeadphonesSimple;\nconst faSitemap = {\n prefix: 'fas',\n iconName: 'sitemap',\n icon: [576, 512, [], \"f0e8\", \"M208 80c0-26.5 21.5-48 48-48l64 0c26.5 0 48 21.5 48 48l0 64c0 26.5-21.5 48-48 48l-8 0 0 40 152 0c30.9 0 56 25.1 56 56l0 32 8 0c26.5 0 48 21.5 48 48l0 64c0 26.5-21.5 48-48 48l-64 0c-26.5 0-48-21.5-48-48l0-64c0-26.5 21.5-48 48-48l8 0 0-32c0-4.4-3.6-8-8-8l-152 0 0 40 8 0c26.5 0 48 21.5 48 48l0 64c0 26.5-21.5 48-48 48l-64 0c-26.5 0-48-21.5-48-48l0-64c0-26.5 21.5-48 48-48l8 0 0-40-152 0c-4.4 0-8 3.6-8 8l0 32 8 0c26.5 0 48 21.5 48 48l0 64c0 26.5-21.5 48-48 48l-64 0c-26.5 0-48-21.5-48-48l0-64c0-26.5 21.5-48 48-48l8 0 0-32c0-30.9 25.1-56 56-56l152 0 0-40-8 0c-26.5 0-48-21.5-48-48l0-64z\"]\n};\nconst faCircleDollarToSlot = {\n prefix: 'fas',\n iconName: 'circle-dollar-to-slot',\n icon: [512, 512, [\"donate\"], \"f4b9\", \"M326.7 403.7c-22.1 8-45.9 12.3-70.7 12.3s-48.7-4.4-70.7-12.3l-.8-.3c-30-11-56.8-28.7-78.6-51.4C70 314.6 48 263.9 48 208C48 93.1 141.1 0 256 0S464 93.1 464 208c0 55.9-22 106.6-57.9 144c-1 1-2 2.1-3 3.1c-21.4 21.4-47.4 38.1-76.3 48.6zM256 91.9c-11.1 0-20.1 9-20.1 20.1l0 6c-5.6 1.2-10.9 2.9-15.9 5.1c-15 6.8-27.9 19.4-31.1 37.7c-1.8 10.2-.8 20 3.4 29c4.2 8.8 10.7 15 17.3 19.5c11.6 7.9 26.9 12.5 38.6 16l2.2 .7c13.9 4.2 23.4 7.4 29.3 11.7c2.5 1.8 3.4 3.2 3.7 4c.3 .8 .9 2.6 .2 6.7c-.6 3.5-2.5 6.4-8 8.8c-6.1 2.6-16 3.9-28.8 1.9c-6-1-16.7-4.6-26.2-7.9c0 0 0 0 0 0s0 0 0 0s0 0 0 0c-2.2-.7-4.3-1.5-6.4-2.1c-10.5-3.5-21.8 2.2-25.3 12.7s2.2 21.8 12.7 25.3c1.2 .4 2.7 .9 4.4 1.5c7.9 2.7 20.3 6.9 29.8 9.1l0 6.4c0 11.1 9 20.1 20.1 20.1s20.1-9 20.1-20.1l0-5.5c5.3-1 10.5-2.5 15.4-4.6c15.7-6.7 28.4-19.7 31.6-38.7c1.8-10.4 1-20.3-3-29.4c-3.9-9-10.2-15.6-16.9-20.5c-12.2-8.8-28.3-13.7-40.4-17.4l-.8-.2c-14.2-4.3-23.8-7.3-29.9-11.4c-2.6-1.8-3.4-3-3.6-3.5c-.2-.3-.7-1.6-.1-5c.3-1.9 1.9-5.2 8.2-8.1c6.4-2.9 16.4-4.5 28.6-2.6c4.3 .7 17.9 3.3 21.7 4.3c10.7 2.8 21.6-3.5 24.5-14.2s-3.5-21.6-14.2-24.5c-4.4-1.2-14.4-3.2-21-4.4l0-6.3c0-11.1-9-20.1-20.1-20.1zM48 352l16 0c19.5 25.9 44 47.7 72.2 64L64 416l0 32 192 0 192 0 0-32-72.2 0c28.2-16.3 52.8-38.1 72.2-64l16 0c26.5 0 48 21.5 48 48l0 64c0 26.5-21.5 48-48 48L48 512c-26.5 0-48-21.5-48-48l0-64c0-26.5 21.5-48 48-48z\"]\n};\nconst faDonate = faCircleDollarToSlot;\nconst faMemory = {\n prefix: 'fas',\n iconName: 'memory',\n icon: [576, 512, [], \"f538\", \"M64 64C28.7 64 0 92.7 0 128l0 7.4c0 6.8 4.4 12.6 10.1 16.3C23.3 160.3 32 175.1 32 192s-8.7 31.7-21.9 40.3C4.4 236 0 241.8 0 248.6L0 320l576 0 0-71.4c0-6.8-4.4-12.6-10.1-16.3C552.7 223.7 544 208.9 544 192s8.7-31.7 21.9-40.3c5.7-3.7 10.1-9.5 10.1-16.3l0-7.4c0-35.3-28.7-64-64-64L64 64zM576 352L0 352l0 64c0 17.7 14.3 32 32 32l48 0 0-32c0-8.8 7.2-16 16-16s16 7.2 16 16l0 32 96 0 0-32c0-8.8 7.2-16 16-16s16 7.2 16 16l0 32 96 0 0-32c0-8.8 7.2-16 16-16s16 7.2 16 16l0 32 96 0 0-32c0-8.8 7.2-16 16-16s16 7.2 16 16l0 32 48 0c17.7 0 32-14.3 32-32l0-64zM192 160l0 64c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-64c0-17.7 14.3-32 32-32s32 14.3 32 32zm128 0l0 64c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-64c0-17.7 14.3-32 32-32s32 14.3 32 32zm128 0l0 64c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-64c0-17.7 14.3-32 32-32s32 14.3 32 32z\"]\n};\nconst faRoadSpikes = {\n prefix: 'fas',\n iconName: 'road-spikes',\n icon: [640, 512, [], \"e568\", \"M64 116.8c0-15.8 20.5-22 29.3-8.9L192 256l0-139.2c0-15.8 20.5-22 29.3-8.9L320 256l0-139.2c0-15.8 20.5-22 29.3-8.9L448 256l0-139.2c0-15.8 20.5-22 29.3-8.9L606.8 302.2c14.2 21.3-1.1 49.7-26.6 49.7L512 352l-64 0-64 0-64 0-64 0-64 0L64 352l0-235.2zM32 384l576 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L32 448c-17.7 0-32-14.3-32-32s14.3-32 32-32z\"]\n};\nconst faFireBurner = {\n prefix: 'fas',\n iconName: 'fire-burner',\n icon: [640, 512, [], \"e4f1\", \"M345.7 48.3L358 34.5c5.4-6.1 13.3-8.8 20.9-8.9c7.2 0 14.3 2.6 19.9 7.8c19.7 18.3 39.8 43.2 55 70.6C469 131.2 480 162.2 480 192.2C480 280.8 408.7 352 320 352c-89.6 0-160-71.3-160-159.8c0-37.3 16-73.4 36.8-104.5c20.9-31.3 47.5-59 70.9-80.2C273.4 2.3 280.7-.2 288 0c14.1 .3 23.8 11.4 32.7 21.6c0 0 0 0 0 0c2 2.3 4 4.6 6 6.7l19 19.9zM384 240.2c0-36.5-37-73-54.8-88.4c-5.4-4.7-13.1-4.7-18.5 0C293 167.1 256 203.6 256 240.2c0 35.3 28.7 64 64 64s64-28.7 64-64zM32 288c0-17.7 14.3-32 32-32l32 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l0 64 448 0 0-64c-17.7 0-32-14.3-32-32s14.3-32 32-32l32 0c17.7 0 32 14.3 32 32l0 96c17.7 0 32 14.3 32 32l0 64c0 17.7-14.3 32-32 32L32 512c-17.7 0-32-14.3-32-32l0-64c0-17.7 14.3-32 32-32l0-96zM320 480a32 32 0 1 0 0-64 32 32 0 1 0 0 64zm160-32a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zM192 480a32 32 0 1 0 0-64 32 32 0 1 0 0 64z\"]\n};\nconst faFlag = {\n prefix: 'fas',\n iconName: 'flag',\n icon: [448, 512, [127988, 61725], \"f024\", \"M64 32C64 14.3 49.7 0 32 0S0 14.3 0 32L0 64 0 368 0 480c0 17.7 14.3 32 32 32s32-14.3 32-32l0-128 64.3-16.1c41.1-10.3 84.6-5.5 122.5 13.4c44.2 22.1 95.5 24.8 141.7 7.4l34.7-13c12.5-4.7 20.8-16.6 20.8-30l0-247.7c0-23-24.2-38-44.8-27.7l-9.6 4.8c-46.3 23.2-100.8 23.2-147.1 0c-35.1-17.6-75.4-22-113.5-12.5L64 48l0-16z\"]\n};\nconst faHanukiah = {\n prefix: 'fas',\n iconName: 'hanukiah',\n icon: [640, 512, [128334], \"f6e6\", \"M314.2 3.3C309.1 12.1 296 36.6 296 56c0 13.3 10.7 24 24 24s24-10.7 24-24c0-19.4-13.1-43.9-18.2-52.7C324.6 1.2 322.4 0 320 0s-4.6 1.2-5.8 3.3zm-288 48C21.1 60.1 8 84.6 8 104c0 13.3 10.7 24 24 24s24-10.7 24-24c0-19.4-13.1-43.9-18.2-52.7C36.6 49.2 34.4 48 32 48s-4.6 1.2-5.8 3.3zM88 104c0 13.3 10.7 24 24 24s24-10.7 24-24c0-19.4-13.1-43.9-18.2-52.7c-1.2-2.1-3.4-3.3-5.8-3.3s-4.6 1.2-5.8 3.3C101.1 60.1 88 84.6 88 104zm82.2-52.7C165.1 60.1 152 84.6 152 104c0 13.3 10.7 24 24 24s24-10.7 24-24c0-19.4-13.1-43.9-18.2-52.7c-1.2-2.1-3.4-3.3-5.8-3.3s-4.6 1.2-5.8 3.3zM216 104c0 13.3 10.7 24 24 24s24-10.7 24-24c0-19.4-13.1-43.9-18.2-52.7c-1.2-2.1-3.4-3.3-5.8-3.3s-4.6 1.2-5.8 3.3C229.1 60.1 216 84.6 216 104zM394.2 51.3C389.1 60.1 376 84.6 376 104c0 13.3 10.7 24 24 24s24-10.7 24-24c0-19.4-13.1-43.9-18.2-52.7c-1.2-2.1-3.4-3.3-5.8-3.3s-4.6 1.2-5.8 3.3zM440 104c0 13.3 10.7 24 24 24s24-10.7 24-24c0-19.4-13.1-43.9-18.2-52.7c-1.2-2.1-3.4-3.3-5.8-3.3s-4.6 1.2-5.8 3.3C453.1 60.1 440 84.6 440 104zm82.2-52.7C517.1 60.1 504 84.6 504 104c0 13.3 10.7 24 24 24s24-10.7 24-24c0-19.4-13.1-43.9-18.2-52.7c-1.2-2.1-3.4-3.3-5.8-3.3s-4.6 1.2-5.8 3.3zM584 104c0 13.3 10.7 24 24 24s24-10.7 24-24c0-19.4-13.1-43.9-18.2-52.7c-1.2-2.1-3.4-3.3-5.8-3.3s-4.6 1.2-5.8 3.3C597.1 60.1 584 84.6 584 104zM112 160c-8.8 0-16 7.2-16 16l0 96 0 16 32 0 0-16 0-96c0-8.8-7.2-16-16-16zm64 0c-8.8 0-16 7.2-16 16l0 96 0 16 32 0 0-16 0-96c0-8.8-7.2-16-16-16zm64 0c-8.8 0-16 7.2-16 16l0 96 0 16 32 0 0-16 0-96c0-8.8-7.2-16-16-16zm160 0c-8.8 0-16 7.2-16 16l0 96 0 16 32 0 0-16 0-96c0-8.8-7.2-16-16-16zm64 0c-8.8 0-16 7.2-16 16l0 96 0 16 32 0 0-16 0-96c0-8.8-7.2-16-16-16zm64 0c-8.8 0-16 7.2-16 16l0 96 0 16 32 0 0-16 0-96c0-8.8-7.2-16-16-16zM352 144c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 176L96 320c-17.7 0-32-14.3-32-32l0-96c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 96c0 53 43 96 96 96l192 0 0 64-128 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l160 0 160 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-128 0 0-64 192 0c53 0 96-43 96-96l0-96c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 96c0 17.7-14.3 32-32 32l-192 0 0-176z\"]\n};\nconst faFeather = {\n prefix: 'fas',\n iconName: 'feather',\n icon: [512, 512, [129718], \"f52d\", \"M278.5 215.6L23 471c-9.4 9.4-9.4 24.6 0 33.9s24.6 9.4 33.9 0l57-57 68 0c49.7 0 97.9-14.4 139-41c11.1-7.2 5.5-23-7.8-23c-5.1 0-9.2-4.1-9.2-9.2c0-4.1 2.7-7.6 6.5-8.8l81-24.3c2.5-.8 4.8-2.1 6.7-4l22.4-22.4c10.1-10.1 2.9-27.3-11.3-27.3l-32.2 0c-5.1 0-9.2-4.1-9.2-9.2c0-4.1 2.7-7.6 6.5-8.8l112-33.6c4-1.2 7.4-3.9 9.3-7.7C506.4 207.6 512 184.1 512 160c0-41-16.3-80.3-45.3-109.3l-5.5-5.5C432.3 16.3 393 0 352 0s-80.3 16.3-109.3 45.3L139 149C91 197 64 262.1 64 330l0 55.3L253.6 195.8c6.2-6.2 16.4-6.2 22.6 0c5.4 5.4 6.1 13.6 2.2 19.8z\"]\n};\nconst faVolumeLow = {\n prefix: 'fas',\n iconName: 'volume-low',\n icon: [448, 512, [128264, \"volume-down\"], \"f027\", \"M301.1 34.8C312.6 40 320 51.4 320 64l0 384c0 12.6-7.4 24-18.9 29.2s-25 3.1-34.4-5.3L131.8 352 64 352c-35.3 0-64-28.7-64-64l0-64c0-35.3 28.7-64 64-64l67.8 0L266.7 40.1c9.4-8.4 22.9-10.4 34.4-5.3zM412.6 181.5C434.1 199.1 448 225.9 448 256s-13.9 56.9-35.4 74.5c-10.3 8.4-25.4 6.8-33.8-3.5s-6.8-25.4 3.5-33.8C393.1 284.4 400 271 400 256s-6.9-28.4-17.7-37.3c-10.3-8.4-11.8-23.5-3.5-33.8s23.5-11.8 33.8-3.5z\"]\n};\nconst faVolumeDown = faVolumeLow;\nconst faCommentSlash = {\n prefix: 'fas',\n iconName: 'comment-slash',\n icon: [640, 512, [], \"f4b3\", \"M38.8 5.1C28.4-3.1 13.3-1.2 5.1 9.2S-1.2 34.7 9.2 42.9l592 464c10.4 8.2 25.5 6.3 33.7-4.1s6.3-25.5-4.1-33.7L512.9 376.7C552.2 340.2 576 292.3 576 240C576 125.1 461.4 32 320 32c-67.7 0-129.3 21.4-175.1 56.3L38.8 5.1zm385.2 425L82.9 161.3C70.7 185.6 64 212.2 64 240c0 45.1 17.7 86.8 47.7 120.9c-1.9 24.5-11.4 46.3-21.4 62.9c-5.5 9.2-11.1 16.6-15.2 21.6c-2.1 2.5-3.7 4.4-4.9 5.7c-.6 .6-1 1.1-1.3 1.4l-.3 .3c0 0 0 0 0 0c0 0 0 0 0 0s0 0 0 0s0 0 0 0c-4.6 4.6-5.9 11.4-3.4 17.4c2.5 6 8.3 9.9 14.8 9.9c28.7 0 57.6-8.9 81.6-19.3c22.9-10 42.4-21.9 54.3-30.6c31.8 11.5 67 17.9 104.1 17.9c37 0 72.3-6.4 104.1-17.9z\"]\n};\nconst faCloudSunRain = {\n prefix: 'fas',\n iconName: 'cloud-sun-rain',\n icon: [640, 512, [127782], \"f743\", \"M294.2 1.2c5.1 2.1 8.7 6.7 9.6 12.1l10.4 62.4c-23.3 10.8-42.9 28.4-56 50.3c-14.6-9-31.8-14.1-50.2-14.1c-53 0-96 43-96 96c0 35.5 19.3 66.6 48 83.2c.8 31.8 13.2 60.7 33.1 82.7l-56 39.2c-4.5 3.2-10.3 3.8-15.4 1.6s-8.7-6.7-9.6-12.1L98.1 317.9 13.4 303.8c-5.4-.9-10-4.5-12.1-9.6s-1.5-10.9 1.6-15.4L52.5 208 2.9 137.2c-3.2-4.5-3.8-10.3-1.6-15.4s6.7-8.7 12.1-9.6L98.1 98.1l14.1-84.7c.9-5.4 4.5-10 9.6-12.1s10.9-1.5 15.4 1.6L208 52.5 278.8 2.9c4.5-3.2 10.3-3.8 15.4-1.6zM208 144c13.8 0 26.7 4.4 37.1 11.9c-1.2 4.1-2.2 8.3-3 12.6c-37.9 14.6-67.2 46.6-77.8 86.4C151.8 243.1 144 226.5 144 208c0-35.3 28.7-64 64-64zm69.4 276c11 7.4 14 22.3 6.7 33.3l-32 48c-7.4 11-22.3 14-33.3 6.7s-14-22.3-6.7-33.3l32-48c7.4-11 22.3-14 33.3-6.7zm96 0c11 7.4 14 22.3 6.7 33.3l-32 48c-7.4 11-22.3 14-33.3 6.7s-14-22.3-6.7-33.3l32-48c7.4-11 22.3-14 33.3-6.7zm96 0c11 7.4 14 22.3 6.7 33.3l-32 48c-7.4 11-22.3 14-33.3 6.7s-14-22.3-6.7-33.3l32-48c7.4-11 22.3-14 33.3-6.7zm96 0c11 7.4 14 22.3 6.7 33.3l-32 48c-7.4 11-22.3 14-33.3 6.7s-14-22.3-6.7-33.3l32-48c7.4-11 22.3-14 33.3-6.7zm74.5-116.1c0 44.2-35.8 80-80 80l-271.9 0c-53 0-96-43-96-96c0-47.6 34.6-87 80-94.6l0-1.3c0-53 43-96 96-96c34.9 0 65.4 18.6 82.2 46.4c13-9.1 28.8-14.4 45.8-14.4c44.2 0 80 35.8 80 80c0 5.9-.6 11.7-1.9 17.2c37.4 6.7 65.8 39.4 65.8 78.7z\"]\n};\nconst faCompress = {\n prefix: 'fas',\n iconName: 'compress',\n icon: [448, 512, [], \"f066\", \"M160 64c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 64-64 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l96 0c17.7 0 32-14.3 32-32l0-96zM32 320c-17.7 0-32 14.3-32 32s14.3 32 32 32l64 0 0 64c0 17.7 14.3 32 32 32s32-14.3 32-32l0-96c0-17.7-14.3-32-32-32l-96 0zM352 64c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 96c0 17.7 14.3 32 32 32l96 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-64 0 0-64zM320 320c-17.7 0-32 14.3-32 32l0 96c0 17.7 14.3 32 32 32s32-14.3 32-32l0-64 64 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-96 0z\"]\n};\nconst faWheatAwn = {\n prefix: 'fas',\n iconName: 'wheat-awn',\n icon: [512, 512, [\"wheat-alt\"], \"e2cd\", \"M505 41c9.4-9.4 9.4-24.6 0-33.9s-24.6-9.4-33.9 0L383 95c-9.4 9.4-9.4 24.6 0 33.9s24.6 9.4 33.9 0l88-88zM305.5 27.3c-6.2-6.2-16.4-6.2-22.6 0L271.5 38.6c-37.5 37.5-37.5 98.3 0 135.8l10.4 10.4-30.5 30.5c-3.4-27.3-15.5-53.8-36.5-74.8l-11.3-11.3c-6.2-6.2-16.4-6.2-22.6 0l-11.3 11.3c-37.5 37.5-37.5 98.3 0 135.8l10.4 10.4-30.5 30.5c-3.4-27.3-15.5-53.8-36.5-74.8L101.8 231c-6.2-6.2-16.4-6.2-22.6 0L67.9 242.3c-37.5 37.5-37.5 98.3 0 135.8l10.4 10.4L9.4 457.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0l68.9-68.9 12.2 12.2c37.5 37.5 98.3 37.5 135.8 0l11.3-11.3c6.2-6.2 6.2-16.4 0-22.6l-11.3-11.3c-21.8-21.8-49.6-34.1-78.1-36.9l31.9-31.9 12.2 12.2c37.5 37.5 98.3 37.5 135.8 0l11.3-11.3c6.2-6.2 6.2-16.4 0-22.6l-11.3-11.3c-21.8-21.8-49.6-34.1-78.1-36.9l31.9-31.9 12.2 12.2c37.5 37.5 98.3 37.5 135.8 0L486.5 231c6.2-6.2 6.2-16.4 0-22.6L475.2 197c-5.2-5.2-10.6-9.8-16.4-13.9L505 137c9.4-9.4 9.4-24.6 0-33.9s-24.6-9.4-33.9 0l-59.4 59.4c-20.6-4.4-42-3.7-62.3 2.1c6.1-21.3 6.6-43.8 1.4-65.3L409 41c9.4-9.4 9.4-24.6 0-33.9s-24.6-9.4-33.9 0L329.1 52.9c-3.7-5-7.8-9.8-12.4-14.3L305.5 27.3z\"]\n};\nconst faWheatAlt = faWheatAwn;\nconst faAnkh = {\n prefix: 'fas',\n iconName: 'ankh',\n icon: [320, 512, [9765], \"f644\", \"M96 128c0-35.3 28.7-64 64-64s64 28.7 64 64c0 41.6-20.7 76.6-46.6 104.1c-5.9 6.2-11.8 11.8-17.4 16.7c-5.6-4.9-11.5-10.5-17.4-16.7C116.7 204.6 96 169.6 96 128zM160 0C89.3 0 32 57.3 32 128c0 52.4 21.5 95.5 46.8 128L32 256c-17.7 0-32 14.3-32 32s14.3 32 32 32l96 0 0 160c0 17.7 14.3 32 32 32s32-14.3 32-32l0-160 96 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-46.8 0c25.4-32.5 46.8-75.6 46.8-128C288 57.3 230.7 0 160 0z\"]\n};\nconst faHandsHoldingChild = {\n prefix: 'fas',\n iconName: 'hands-holding-child',\n icon: [640, 512, [], \"e4fa\", \"M320 0a40 40 0 1 1 0 80 40 40 0 1 1 0-80zm44.7 164.3L375.8 253c1.6 13.2-7.7 25.1-20.8 26.8s-25.1-7.7-26.8-20.8l-4.4-35-7.6 0-4.4 35c-1.6 13.2-13.6 22.5-26.8 20.8s-22.5-13.6-20.8-26.8l11.1-88.8L255.5 181c-10.1 8.6-25.3 7.3-33.8-2.8s-7.3-25.3 2.8-33.8l27.9-23.6C271.3 104.8 295.3 96 320 96s48.7 8.8 67.6 24.7l27.9 23.6c10.1 8.6 11.4 23.7 2.8 33.8s-23.7 11.4-33.8 2.8l-19.8-16.7zM40 64c22.1 0 40 17.9 40 40l0 40 0 80 0 40.2c0 17 6.7 33.3 18.7 45.3l51.1 51.1c8.3 8.3 21.3 9.6 31 3.1c12.9-8.6 14.7-26.9 3.7-37.8l-15.2-15.2-32-32c-12.5-12.5-12.5-32.8 0-45.3s32.8-12.5 45.3 0l32 32 15.2 15.2c0 0 0 0 0 0l25.3 25.3c21 21 32.8 49.5 32.8 79.2l0 78.9c0 26.5-21.5 48-48 48l-66.7 0c-17 0-33.3-6.7-45.3-18.7L28.1 393.4C10.1 375.4 0 351 0 325.5L0 224l0-64 0-56C0 81.9 17.9 64 40 64zm560 0c22.1 0 40 17.9 40 40l0 56 0 64 0 101.5c0 25.5-10.1 49.9-28.1 67.9L512 493.3c-12 12-28.3 18.7-45.3 18.7L400 512c-26.5 0-48-21.5-48-48l0-78.9c0-29.7 11.8-58.2 32.8-79.2l25.3-25.3c0 0 0 0 0 0l15.2-15.2 32-32c12.5-12.5 32.8-12.5 45.3 0s12.5 32.8 0 45.3l-32 32-15.2 15.2c-11 11-9.2 29.2 3.7 37.8c9.7 6.5 22.7 5.2 31-3.1l51.1-51.1c12-12 18.7-28.3 18.7-45.3l0-40.2 0-80 0-40c0-22.1 17.9-40 40-40z\"]\n};\nconst faAsterisk = {\n prefix: 'fas',\n iconName: 'asterisk',\n icon: [384, 512, [10033, 61545], \"2a\", \"M192 32c17.7 0 32 14.3 32 32l0 135.5 111.5-66.9c15.2-9.1 34.8-4.2 43.9 11s4.2 34.8-11 43.9L254.2 256l114.3 68.6c15.2 9.1 20.1 28.7 11 43.9s-28.7 20.1-43.9 11L224 312.5 224 448c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-135.5L48.5 379.4c-15.2 9.1-34.8 4.2-43.9-11s-4.2-34.8 11-43.9L129.8 256 15.5 187.4c-15.2-9.1-20.1-28.7-11-43.9s28.7-20.1 43.9-11L160 199.5 160 64c0-17.7 14.3-32 32-32z\"]\n};\nconst faSquareCheck = {\n prefix: 'fas',\n iconName: 'square-check',\n icon: [448, 512, [9745, 9989, 61510, \"check-square\"], \"f14a\", \"M64 32C28.7 32 0 60.7 0 96L0 416c0 35.3 28.7 64 64 64l320 0c35.3 0 64-28.7 64-64l0-320c0-35.3-28.7-64-64-64L64 32zM337 209L209 337c-9.4 9.4-24.6 9.4-33.9 0l-64-64c-9.4-9.4-9.4-24.6 0-33.9s24.6-9.4 33.9 0l47 47L303 175c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9z\"]\n};\nconst faCheckSquare = faSquareCheck;\nconst faPesetaSign = {\n prefix: 'fas',\n iconName: 'peseta-sign',\n icon: [384, 512, [], \"e221\", \"M64 32C46.3 32 32 46.3 32 64l0 96c-17.7 0-32 14.3-32 32s14.3 32 32 32l0 96 0 128c0 17.7 14.3 32 32 32s32-14.3 32-32l0-96 96 0c77.4 0 142-55 156.8-128l3.2 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-3.2 0C334 87 269.4 32 192 32L64 32zM282.5 160L96 160l0-64 96 0c41.8 0 77.4 26.7 90.5 64zM96 224l186.5 0c-13.2 37.3-48.7 64-90.5 64l-96 0 0-64z\"]\n};\nconst faHeading = {\n prefix: 'fas',\n iconName: 'heading',\n icon: [448, 512, [\"header\"], \"f1dc\", \"M0 64C0 46.3 14.3 32 32 32l48 0 48 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-16 0 0 112 224 0 0-112-16 0c-17.7 0-32-14.3-32-32s14.3-32 32-32l48 0 48 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-16 0 0 144 0 176 16 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-48 0-48 0c-17.7 0-32-14.3-32-32s14.3-32 32-32l16 0 0-144-224 0 0 144 16 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-48 0-48 0c-17.7 0-32-14.3-32-32s14.3-32 32-32l16 0 0-176L48 96 32 96C14.3 96 0 81.7 0 64z\"]\n};\nconst faHeader = faHeading;\nconst faGhost = {\n prefix: 'fas',\n iconName: 'ghost',\n icon: [384, 512, [128123], \"f6e2\", \"M40.1 467.1l-11.2 9c-3.2 2.5-7.1 3.9-11.1 3.9C8 480 0 472 0 462.2L0 192C0 86 86 0 192 0S384 86 384 192l0 270.2c0 9.8-8 17.8-17.8 17.8c-4 0-7.9-1.4-11.1-3.9l-11.2-9c-13.4-10.7-32.8-9-44.1 3.9L269.3 506c-3.3 3.8-8.2 6-13.3 6s-9.9-2.2-13.3-6l-26.6-30.5c-12.7-14.6-35.4-14.6-48.2 0L141.3 506c-3.3 3.8-8.2 6-13.3 6s-9.9-2.2-13.3-6L84.2 471c-11.3-12.9-30.7-14.6-44.1-3.9zM160 192a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zm96 32a32 32 0 1 0 0-64 32 32 0 1 0 0 64z\"]\n};\nconst faList = {\n prefix: 'fas',\n iconName: 'list',\n icon: [512, 512, [\"list-squares\"], \"f03a\", \"M40 48C26.7 48 16 58.7 16 72l0 48c0 13.3 10.7 24 24 24l48 0c13.3 0 24-10.7 24-24l0-48c0-13.3-10.7-24-24-24L40 48zM192 64c-17.7 0-32 14.3-32 32s14.3 32 32 32l288 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L192 64zm0 160c-17.7 0-32 14.3-32 32s14.3 32 32 32l288 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-288 0zm0 160c-17.7 0-32 14.3-32 32s14.3 32 32 32l288 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-288 0zM16 232l0 48c0 13.3 10.7 24 24 24l48 0c13.3 0 24-10.7 24-24l0-48c0-13.3-10.7-24-24-24l-48 0c-13.3 0-24 10.7-24 24zM40 368c-13.3 0-24 10.7-24 24l0 48c0 13.3 10.7 24 24 24l48 0c13.3 0 24-10.7 24-24l0-48c0-13.3-10.7-24-24-24l-48 0z\"]\n};\nconst faListSquares = faList;\nconst faSquarePhoneFlip = {\n prefix: 'fas',\n iconName: 'square-phone-flip',\n icon: [448, 512, [\"phone-square-alt\"], \"f87b\", \"M384 32c35.3 0 64 28.7 64 64l0 320c0 35.3-28.7 64-64 64L64 480c-35.3 0-64-28.7-64-64L0 96C0 60.7 28.7 32 64 32l320 0zm-90.7 96.7c-9.7-2.6-19.9 2.3-23.7 11.6l-20 48c-3.4 8.2-1 17.6 5.8 23.2L280 231.7c-16.6 35.2-45.1 63.7-80.3 80.3l-20.2-24.7c-5.6-6.8-15-9.2-23.2-5.8l-48 20c-9.3 3.9-14.2 14-11.6 23.7l12 44C111.1 378 119 384 128 384c123.7 0 224-100.3 224-224c0-9-6-16.9-14.7-19.3l-44-12z\"]\n};\nconst faPhoneSquareAlt = faSquarePhoneFlip;\nconst faCartPlus = {\n prefix: 'fas',\n iconName: 'cart-plus',\n icon: [576, 512, [], \"f217\", \"M0 24C0 10.7 10.7 0 24 0L69.5 0c22 0 41.5 12.8 50.6 32l411 0c26.3 0 45.5 25 38.6 50.4l-41 152.3c-8.5 31.4-37 53.3-69.5 53.3l-288.5 0 5.4 28.5c2.2 11.3 12.1 19.5 23.6 19.5L488 336c13.3 0 24 10.7 24 24s-10.7 24-24 24l-288.3 0c-34.6 0-64.3-24.6-70.7-58.5L77.4 54.5c-.7-3.8-4-6.5-7.9-6.5L24 48C10.7 48 0 37.3 0 24zM128 464a48 48 0 1 1 96 0 48 48 0 1 1 -96 0zm336-48a48 48 0 1 1 0 96 48 48 0 1 1 0-96zM252 160c0 11 9 20 20 20l44 0 0 44c0 11 9 20 20 20s20-9 20-20l0-44 44 0c11 0 20-9 20-20s-9-20-20-20l-44 0 0-44c0-11-9-20-20-20s-20 9-20 20l0 44-44 0c-11 0-20 9-20 20z\"]\n};\nconst faGamepad = {\n prefix: 'fas',\n iconName: 'gamepad',\n icon: [640, 512, [], \"f11b\", \"M192 64C86 64 0 150 0 256S86 448 192 448l256 0c106 0 192-86 192-192s-86-192-192-192L192 64zM496 168a40 40 0 1 1 0 80 40 40 0 1 1 0-80zM392 304a40 40 0 1 1 80 0 40 40 0 1 1 -80 0zM168 200c0-13.3 10.7-24 24-24s24 10.7 24 24l0 32 32 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-32 0 0 32c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-32-32 0c-13.3 0-24-10.7-24-24s10.7-24 24-24l32 0 0-32z\"]\n};\nconst faCircleDot = {\n prefix: 'fas',\n iconName: 'circle-dot',\n icon: [512, 512, [128280, \"dot-circle\"], \"f192\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zm0-352a96 96 0 1 1 0 192 96 96 0 1 1 0-192z\"]\n};\nconst faDotCircle = faCircleDot;\nconst faFaceDizzy = {\n prefix: 'fas',\n iconName: 'face-dizzy',\n icon: [512, 512, [\"dizzy\"], \"f567\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zm0-224a64 64 0 1 1 0 128 64 64 0 1 1 0-128zM100.7 132.7c6.2-6.2 16.4-6.2 22.6 0L160 169.4l36.7-36.7c6.2-6.2 16.4-6.2 22.6 0s6.2 16.4 0 22.6L182.6 192l36.7 36.7c6.2 6.2 6.2 16.4 0 22.6s-16.4 6.2-22.6 0L160 214.6l-36.7 36.7c-6.2 6.2-16.4 6.2-22.6 0s-6.2-16.4 0-22.6L137.4 192l-36.7-36.7c-6.2-6.2-6.2-16.4 0-22.6zm192 0c6.2-6.2 16.4-6.2 22.6 0L352 169.4l36.7-36.7c6.2-6.2 16.4-6.2 22.6 0s6.2 16.4 0 22.6L374.6 192l36.7 36.7c6.2 6.2 6.2 16.4 0 22.6s-16.4 6.2-22.6 0L352 214.6l-36.7 36.7c-6.2 6.2-16.4 6.2-22.6 0s-6.2-16.4 0-22.6L329.4 192l-36.7-36.7c-6.2-6.2-6.2-16.4 0-22.6z\"]\n};\nconst faDizzy = faFaceDizzy;\nconst faEgg = {\n prefix: 'fas',\n iconName: 'egg',\n icon: [384, 512, [129370], \"f7fb\", \"M192 496C86 496 0 394 0 288C0 176 64 16 192 16s192 160 192 272c0 106-86 208-192 208zM154.8 134c6.5-6 7-16.1 1-22.6s-16.1-7-22.6-1c-23.9 21.8-41.1 52.7-52.3 84.2C69.7 226.1 64 259.7 64 288c0 8.8 7.2 16 16 16s16-7.2 16-16c0-24.5 5-54.4 15.1-82.8c10.1-28.5 25-54.1 43.7-71.2z\"]\n};\nconst faHouseMedicalCircleXmark = {\n prefix: 'fas',\n iconName: 'house-medical-circle-xmark',\n icon: [640, 512, [], \"e513\", \"M320 368c0 59.5 29.5 112.1 74.8 144l-266.7 0c-35.3 0-64-28.7-64-64l0-160.4-32 0c-18 0-32-14-32-32.1c0-9 3-17 10-24L266.4 8c7-7 15-8 22-8s15 2 21 7L522.1 193.9c-8.5-1.3-17.3-1.9-26.1-1.9c-54.7 0-103.5 24.9-135.8 64L320 256l0-48c0-8.8-7.2-16-16-16l-32 0c-8.8 0-16 7.2-16 16l0 48-48 0c-8.8 0-16 7.2-16 16l0 32c0 8.8 7.2 16 16 16l48 0 0 48c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16zM496 224a144 144 0 1 1 0 288 144 144 0 1 1 0-288zm22.6 144l36.7-36.7c6.2-6.2 6.2-16.4 0-22.6s-16.4-6.2-22.6 0L496 345.4l-36.7-36.7c-6.2-6.2-16.4-6.2-22.6 0s-6.2 16.4 0 22.6L473.4 368l-36.7 36.7c-6.2 6.2-6.2 16.4 0 22.6s16.4 6.2 22.6 0L496 390.6l36.7 36.7c6.2 6.2 16.4 6.2 22.6 0s6.2-16.4 0-22.6L518.6 368z\"]\n};\nconst faCampground = {\n prefix: 'fas',\n iconName: 'campground',\n icon: [576, 512, [9978], \"f6bb\", \"M377 52c11-13.8 8.8-33.9-5-45s-33.9-8.8-45 5L288 60.8 249 12c-11-13.8-31.2-16-45-5s-16 31.2-5 45l48 60L12.3 405.4C4.3 415.4 0 427.7 0 440.4L0 464c0 26.5 21.5 48 48 48l240 0 240 0c26.5 0 48-21.5 48-48l0-23.6c0-12.7-4.3-25.1-12.3-35L329 112l48-60zM288 448l-119.5 0L288 291.7 407.5 448 288 448z\"]\n};\nconst faFolderPlus = {\n prefix: 'fas',\n iconName: 'folder-plus',\n icon: [512, 512, [], \"f65e\", \"M512 416c0 35.3-28.7 64-64 64L64 480c-35.3 0-64-28.7-64-64L0 96C0 60.7 28.7 32 64 32l128 0c20.1 0 39.1 9.5 51.2 25.6l19.2 25.6c6 8.1 15.5 12.8 25.6 12.8l160 0c35.3 0 64 28.7 64 64l0 256zM232 376c0 13.3 10.7 24 24 24s24-10.7 24-24l0-64 64 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-64 0 0-64c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 64-64 0c-13.3 0-24 10.7-24 24s10.7 24 24 24l64 0 0 64z\"]\n};\nconst faFutbol = {\n prefix: 'fas',\n iconName: 'futbol',\n icon: [512, 512, [9917, \"futbol-ball\", \"soccer-ball\"], \"f1e3\", \"M417.3 360.1l-71.6-4.8c-5.2-.3-10.3 1.1-14.5 4.2s-7.2 7.4-8.4 12.5l-17.6 69.6C289.5 445.8 273 448 256 448s-33.5-2.2-49.2-6.4L189.2 372c-1.3-5-4.3-9.4-8.4-12.5s-9.3-4.5-14.5-4.2l-71.6 4.8c-17.6-27.2-28.5-59.2-30.4-93.6L125 228.3c4.4-2.8 7.6-7 9.2-11.9s1.4-10.2-.5-15l-26.7-66.6C128 109.2 155.3 89 186.7 76.9l55.2 46c4 3.3 9 5.1 14.1 5.1s10.2-1.8 14.1-5.1l55.2-46c31.3 12.1 58.7 32.3 79.6 57.9l-26.7 66.6c-1.9 4.8-2.1 10.1-.5 15s4.9 9.1 9.2 11.9l60.7 38.2c-1.9 34.4-12.8 66.4-30.4 93.6zM256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zm14.1-325.7c-8.4-6.1-19.8-6.1-28.2 0L194 221c-8.4 6.1-11.9 16.9-8.7 26.8l18.3 56.3c3.2 9.9 12.4 16.6 22.8 16.6l59.2 0c10.4 0 19.6-6.7 22.8-16.6l18.3-56.3c3.2-9.9-.3-20.7-8.7-26.8l-47.9-34.8z\"]\n};\nconst faFutbolBall = faFutbol;\nconst faSoccerBall = faFutbol;\nconst faPaintbrush = {\n prefix: 'fas',\n iconName: 'paintbrush',\n icon: [576, 512, [128396, \"paint-brush\"], \"f1fc\", \"M339.3 367.1c27.3-3.9 51.9-19.4 67.2-42.9L568.2 74.1c12.6-19.5 9.4-45.3-7.6-61.2S517.7-4.4 499.1 9.6L262.4 187.2c-24 18-38.2 46.1-38.4 76.1L339.3 367.1zm-19.6 25.4l-116-104.4C143.9 290.3 96 339.6 96 400c0 3.9 .2 7.8 .6 11.6C98.4 429.1 86.4 448 68.8 448L64 448c-17.7 0-32 14.3-32 32s14.3 32 32 32l144 0c61.9 0 112-50.1 112-112c0-2.5-.1-5-.2-7.5z\"]\n};\nconst faPaintBrush = faPaintbrush;\nconst faLock = {\n prefix: 'fas',\n iconName: 'lock',\n icon: [448, 512, [128274], \"f023\", \"M144 144l0 48 160 0 0-48c0-44.2-35.8-80-80-80s-80 35.8-80 80zM80 192l0-48C80 64.5 144.5 0 224 0s144 64.5 144 144l0 48 16 0c35.3 0 64 28.7 64 64l0 192c0 35.3-28.7 64-64 64L64 512c-35.3 0-64-28.7-64-64L0 256c0-35.3 28.7-64 64-64l16 0z\"]\n};\nconst faGasPump = {\n prefix: 'fas',\n iconName: 'gas-pump',\n icon: [512, 512, [9981], \"f52f\", \"M32 64C32 28.7 60.7 0 96 0L256 0c35.3 0 64 28.7 64 64l0 192 8 0c48.6 0 88 39.4 88 88l0 32c0 13.3 10.7 24 24 24s24-10.7 24-24l0-154c-27.6-7.1-48-32.2-48-62l0-64L384 64c-8.8-8.8-8.8-23.2 0-32s23.2-8.8 32 0l77.3 77.3c12 12 18.7 28.3 18.7 45.3l0 13.5 0 24 0 32 0 152c0 39.8-32.2 72-72 72s-72-32.2-72-72l0-32c0-22.1-17.9-40-40-40l-8 0 0 144c17.7 0 32 14.3 32 32s-14.3 32-32 32L32 512c-17.7 0-32-14.3-32-32s14.3-32 32-32L32 64zM96 80l0 96c0 8.8 7.2 16 16 16l128 0c8.8 0 16-7.2 16-16l0-96c0-8.8-7.2-16-16-16L112 64c-8.8 0-16 7.2-16 16z\"]\n};\nconst faHotTubPerson = {\n prefix: 'fas',\n iconName: 'hot-tub-person',\n icon: [512, 512, [\"hot-tub\"], \"f593\", \"M272 24c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 5.2c0 34 14.4 66.4 39.7 89.2l16.4 14.8c15.2 13.7 23.8 33.1 23.8 53.5l0 13.2c0 13.3 10.7 24 24 24s24-10.7 24-24l0-13.2c0-34-14.4-66.4-39.7-89.2L295.8 82.8C280.7 69.1 272 49.7 272 29.2l0-5.2zM0 320l0 16L0 448c0 35.3 28.7 64 64 64l384 0c35.3 0 64-28.7 64-64l0-128c0-35.3-28.7-64-64-64l-170.7 0c-13.8 0-27.3-4.5-38.4-12.8l-85.3-64C137 166.7 116.8 160 96 160c-53 0-96 43-96 96l0 64zm128 16l0 96c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-96c0-8.8 7.2-16 16-16s16 7.2 16 16zm80-16c8.8 0 16 7.2 16 16l0 96c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-96c0-8.8 7.2-16 16-16zm112 16l0 96c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-96c0-8.8 7.2-16 16-16s16 7.2 16 16zm80-16c8.8 0 16 7.2 16 16l0 96c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-96c0-8.8 7.2-16 16-16zM360 0c-13.3 0-24 10.7-24 24l0 5.2c0 34 14.4 66.4 39.7 89.2l16.4 14.8c15.2 13.7 23.8 33.1 23.8 53.5l0 13.2c0 13.3 10.7 24 24 24s24-10.7 24-24l0-13.2c0-34-14.4-66.4-39.7-89.2L407.8 82.8C392.7 69.1 384 49.7 384 29.2l0-5.2c0-13.3-10.7-24-24-24zM64 128A64 64 0 1 0 64 0a64 64 0 1 0 0 128z\"]\n};\nconst faHotTub = faHotTubPerson;\nconst faMapLocation = {\n prefix: 'fas',\n iconName: 'map-location',\n icon: [576, 512, [\"map-marked\"], \"f59f\", \"M302.8 312C334.9 271.9 408 174.6 408 120C408 53.7 354.3 0 288 0S168 53.7 168 120c0 54.6 73.1 151.9 105.2 192c7.7 9.6 22 9.6 29.6 0zM416 503l144.9-58c9.1-3.6 15.1-12.5 15.1-22.3L576 152c0-17-17.1-28.6-32.9-22.3l-116 46.4c-.5 1.2-1 2.5-1.5 3.7c-2.9 6.8-6.1 13.7-9.6 20.6L416 503zM15.1 187.3C6 191 0 199.8 0 209.6L0 480.4c0 17 17.1 28.6 32.9 22.3L160 451.8l0-251.4c-3.5-6.9-6.7-13.8-9.6-20.6c-5.6-13.2-10.4-27.4-12.8-41.5l-122.6 49zM384 255c-20.5 31.3-42.3 59.6-56.2 77c-20.5 25.6-59.1 25.6-79.6 0c-13.9-17.4-35.7-45.7-56.2-77l0 194.4 192 54.9L384 255z\"]\n};\nconst faMapMarked = faMapLocation;\nconst faHouseFloodWater = {\n prefix: 'fas',\n iconName: 'house-flood-water',\n icon: [576, 512, [], \"e50e\", \"M306.8 6.1C295.6-2 280.4-2 269.2 6.1l-176 128c-11.2 8.2-15.9 22.6-11.6 35.8S98.1 192 112 192l16 0 0 73c1.7 1 3.3 2 4.9 3.1c18 12.4 40.1 20.3 59.2 20.3c21.1 0 42-8.5 59.2-20.3c22.1-15.5 51.6-15.5 73.7 0c18.4 12.7 39.6 20.3 59.2 20.3c19 0 41.2-7.9 59.2-20.3c1.5-1 3-2 4.5-2.9l-.3-73.2 16.6 0c13.9 0 26.1-8.9 30.4-22.1s-.4-27.6-11.6-35.8l-176-128zM269.5 309.9C247 325.4 219.5 336 192 336c-26.9 0-55.3-10.8-77.4-26.1c0 0 0 0 0 0c-11.9-8.5-28.1-7.8-39.2 1.7c-14.4 11.9-32.5 21-50.6 25.2c-17.2 4-27.9 21.2-23.9 38.4s21.2 27.9 38.4 23.9c24.5-5.7 44.9-16.5 58.2-25C126.5 389.7 159 400 192 400c31.9 0 60.6-9.9 80.4-18.9c5.8-2.7 11.1-5.3 15.6-7.7c4.5 2.4 9.7 5.1 15.6 7.7c19.8 9 48.5 18.9 80.4 18.9c33 0 65.5-10.3 94.5-25.8c13.4 8.4 33.7 19.3 58.2 25c17.2 4 34.4-6.7 38.4-23.9s-6.7-34.4-23.9-38.4c-18.1-4.2-36.2-13.3-50.6-25.2c-11.1-9.5-27.3-10.1-39.2-1.7c0 0 0 0 0 0C439.4 325.2 410.9 336 384 336c-27.5 0-55-10.6-77.5-26.1c-11.1-7.9-25.9-7.9-37 0zM384 448c-27.5 0-55-10.6-77.5-26.1c-11.1-7.9-25.9-7.9-37 0C247 437.4 219.5 448 192 448c-26.9 0-55.3-10.8-77.4-26.1c0 0 0 0 0 0c-11.9-8.5-28.1-7.8-39.2 1.7c-14.4 11.9-32.5 21-50.6 25.2c-17.2 4-27.9 21.2-23.9 38.4s21.2 27.9 38.4 23.9c24.5-5.7 44.9-16.5 58.2-25C126.5 501.7 159 512 192 512c31.9 0 60.6-9.9 80.4-18.9c5.8-2.7 11.1-5.3 15.6-7.7c4.5 2.4 9.7 5.1 15.6 7.7c19.8 9 48.5 18.9 80.4 18.9c33 0 65.5-10.3 94.5-25.8c13.4 8.4 33.7 19.3 58.2 25c17.2 4 34.4-6.7 38.4-23.9s-6.7-34.4-23.9-38.4c-18.1-4.2-36.2-13.3-50.6-25.2c-11.1-9.4-27.3-10.1-39.2-1.7c0 0 0 0 0 0C439.4 437.2 410.9 448 384 448z\"]\n};\nconst faTree = {\n prefix: 'fas',\n iconName: 'tree',\n icon: [448, 512, [127794], \"f1bb\", \"M210.6 5.9L62 169.4c-3.9 4.2-6 9.8-6 15.5C56 197.7 66.3 208 79.1 208l24.9 0L30.6 281.4c-4.2 4.2-6.6 10-6.6 16C24 309.9 34.1 320 46.6 320L80 320 5.4 409.5C1.9 413.7 0 419 0 424.5c0 13 10.5 23.5 23.5 23.5L192 448l0 32c0 17.7 14.3 32 32 32s32-14.3 32-32l0-32 168.5 0c13 0 23.5-10.5 23.5-23.5c0-5.5-1.9-10.8-5.4-15L368 320l33.4 0c12.5 0 22.6-10.1 22.6-22.6c0-6-2.4-11.8-6.6-16L344 208l24.9 0c12.7 0 23.1-10.3 23.1-23.1c0-5.7-2.1-11.3-6-15.5L237.4 5.9C234 2.1 229.1 0 224 0s-10 2.1-13.4 5.9z\"]\n};\nconst faBridgeLock = {\n prefix: 'fas',\n iconName: 'bridge-lock',\n icon: [640, 512, [], \"e4cc\", \"M32 64c0-17.7 14.3-32 32-32l512 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-40 0 0 64-8 0c-61.9 0-112 50.1-112 112l0 24.6c-9.9 5.8-18.2 14.1-23.8 24.1c-17.6-20-43.4-32.7-72.2-32.7c-53 0-96 43-96 96l0 64c0 17.7-14.3 32-32 32l-32 0c-17.7 0-32-14.3-32-32l0-64c0-53-43-96-96-96l0-128 72 0 0-64L64 96C46.3 96 32 81.7 32 64zM408 96l0 64 80 0 0-64-80 0zm-48 64l0-64-80 0 0 64 80 0zM152 96l0 64 80 0 0-64-80 0zM528 240c-17.7 0-32 14.3-32 32l0 48 64 0 0-48c0-17.7-14.3-32-32-32zm-80 32c0-44.2 35.8-80 80-80s80 35.8 80 80l0 48c17.7 0 32 14.3 32 32l0 128c0 17.7-14.3 32-32 32l-160 0c-17.7 0-32-14.3-32-32l0-128c0-17.7 14.3-32 32-32l0-48z\"]\n};\nconst faSackDollar = {\n prefix: 'fas',\n iconName: 'sack-dollar',\n icon: [512, 512, [128176], \"f81d\", \"M320 96L192 96 144.6 24.9C137.5 14.2 145.1 0 157.9 0L354.1 0c12.8 0 20.4 14.2 13.3 24.9L320 96zM192 128l128 0c3.8 2.5 8.1 5.3 13 8.4C389.7 172.7 512 250.9 512 416c0 53-43 96-96 96L96 512c-53 0-96-43-96-96C0 250.9 122.3 172.7 179 136.4c0 0 0 0 0 0s0 0 0 0c4.8-3.1 9.2-5.9 13-8.4zm84 88c0-11-9-20-20-20s-20 9-20 20l0 14c-7.6 1.7-15.2 4.4-22.2 8.5c-13.9 8.3-25.9 22.8-25.8 43.9c.1 20.3 12 33.1 24.7 40.7c11 6.6 24.7 10.8 35.6 14l1.7 .5c12.6 3.8 21.8 6.8 28 10.7c5.1 3.2 5.8 5.4 5.9 8.2c.1 5-1.8 8-5.9 10.5c-5 3.1-12.9 5-21.4 4.7c-11.1-.4-21.5-3.9-35.1-8.5c-2.3-.8-4.7-1.6-7.2-2.4c-10.5-3.5-21.8 2.2-25.3 12.6s2.2 21.8 12.6 25.3c1.9 .6 4 1.3 6.1 2.1c0 0 0 0 0 0s0 0 0 0c8.3 2.9 17.9 6.2 28.2 8.4l0 14.6c0 11 9 20 20 20s20-9 20-20l0-13.8c8-1.7 16-4.5 23.2-9c14.3-8.9 25.1-24.1 24.8-45c-.3-20.3-11.7-33.4-24.6-41.6c-11.5-7.2-25.9-11.6-37.1-15c0 0 0 0 0 0l-.7-.2c-12.8-3.9-21.9-6.7-28.3-10.5c-5.2-3.1-5.3-4.9-5.3-6.7c0-3.7 1.4-6.5 6.2-9.3c5.4-3.2 13.6-5.1 21.5-5c9.6 .1 20.2 2.2 31.2 5.2c10.7 2.8 21.6-3.5 24.5-14.2s-3.5-21.6-14.2-24.5c-6.5-1.7-13.7-3.4-21.1-4.7l0-13.9z\"]\n};\nconst faPenToSquare = {\n prefix: 'fas',\n iconName: 'pen-to-square',\n icon: [512, 512, [\"edit\"], \"f044\", \"M471.6 21.7c-21.9-21.9-57.3-21.9-79.2 0L362.3 51.7l97.9 97.9 30.1-30.1c21.9-21.9 21.9-57.3 0-79.2L471.6 21.7zm-299.2 220c-6.1 6.1-10.8 13.6-13.5 21.9l-29.6 88.8c-2.9 8.6-.6 18.1 5.8 24.6s15.9 8.7 24.6 5.8l88.8-29.6c8.2-2.7 15.7-7.4 21.9-13.5L437.7 172.3 339.7 74.3 172.4 241.7zM96 64C43 64 0 107 0 160L0 416c0 53 43 96 96 96l256 0c53 0 96-43 96-96l0-96c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 96c0 17.7-14.3 32-32 32L96 448c-17.7 0-32-14.3-32-32l0-256c0-17.7 14.3-32 32-32l96 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L96 64z\"]\n};\nconst faEdit = faPenToSquare;\nconst faCarSide = {\n prefix: 'fas',\n iconName: 'car-side',\n icon: [640, 512, [128663], \"f5e4\", \"M171.3 96L224 96l0 96-112.7 0 30.4-75.9C146.5 104 158.2 96 171.3 96zM272 192l0-96 81.2 0c9.7 0 18.9 4.4 25 12l67.2 84L272 192zm256.2 1L428.2 68c-18.2-22.8-45.8-36-75-36L171.3 32c-39.3 0-74.6 23.9-89.1 60.3L40.6 196.4C16.8 205.8 0 228.9 0 256L0 368c0 17.7 14.3 32 32 32l33.3 0c7.6 45.4 47.1 80 94.7 80s87.1-34.6 94.7-80l130.7 0c7.6 45.4 47.1 80 94.7 80s87.1-34.6 94.7-80l33.3 0c17.7 0 32-14.3 32-32l0-48c0-65.2-48.8-119-111.8-127zM434.7 368a48 48 0 1 1 90.5 32 48 48 0 1 1 -90.5-32zM160 336a48 48 0 1 1 0 96 48 48 0 1 1 0-96z\"]\n};\nconst faShareNodes = {\n prefix: 'fas',\n iconName: 'share-nodes',\n icon: [448, 512, [\"share-alt\"], \"f1e0\", \"M352 224c53 0 96-43 96-96s-43-96-96-96s-96 43-96 96c0 4 .2 8 .7 11.9l-94.1 47C145.4 170.2 121.9 160 96 160c-53 0-96 43-96 96s43 96 96 96c25.9 0 49.4-10.2 66.6-26.9l94.1 47c-.5 3.9-.7 7.8-.7 11.9c0 53 43 96 96 96s96-43 96-96s-43-96-96-96c-25.9 0-49.4 10.2-66.6 26.9l-94.1-47c.5-3.9 .7-7.8 .7-11.9s-.2-8-.7-11.9l94.1-47C302.6 213.8 326.1 224 352 224z\"]\n};\nconst faShareAlt = faShareNodes;\nconst faHeartCircleMinus = {\n prefix: 'fas',\n iconName: 'heart-circle-minus',\n icon: [576, 512, [], \"e4ff\", \"M47.6 300.4L228.3 469.1c7.5 7 17.4 10.9 27.7 10.9s20.2-3.9 27.7-10.9l2.6-2.4C267.2 438.6 256 404.6 256 368c0-97.2 78.8-176 176-176c28.3 0 55 6.7 78.7 18.5c.9-6.5 1.3-13 1.3-19.6l0-5.8c0-69.9-50.5-129.5-119.4-141C347 36.5 300.6 51.4 268 84L256 96 244 84c-32.6-32.6-79-47.5-124.6-39.9C50.5 55.6 0 115.2 0 185.1l0 5.8c0 41.5 17.2 81.2 47.6 109.5zM576 368a144 144 0 1 0 -288 0 144 144 0 1 0 288 0zm-64 0c0 8.8-7.2 16-16 16l-128 0c-8.8 0-16-7.2-16-16s7.2-16 16-16l128 0c8.8 0 16 7.2 16 16z\"]\n};\nconst faHourglassHalf = {\n prefix: 'fas',\n iconName: 'hourglass-half',\n icon: [384, 512, [\"hourglass-2\"], \"f252\", \"M32 0C14.3 0 0 14.3 0 32S14.3 64 32 64l0 11c0 42.4 16.9 83.1 46.9 113.1L146.7 256 78.9 323.9C48.9 353.9 32 394.6 32 437l0 11c-17.7 0-32 14.3-32 32s14.3 32 32 32l32 0 256 0 32 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l0-11c0-42.4-16.9-83.1-46.9-113.1L237.3 256l67.9-67.9c30-30 46.9-70.7 46.9-113.1l0-11c17.7 0 32-14.3 32-32s-14.3-32-32-32L320 0 64 0 32 0zM96 75l0-11 192 0 0 11c0 19-5.6 37.4-16 53L112 128c-10.3-15.6-16-34-16-53zm16 309c3.5-5.3 7.6-10.3 12.1-14.9L192 301.3l67.9 67.9c4.6 4.6 8.6 9.6 12.1 14.9L112 384z\"]\n};\nconst faHourglass2 = faHourglassHalf;\nconst faMicroscope = {\n prefix: 'fas',\n iconName: 'microscope',\n icon: [512, 512, [128300], \"f610\", \"M160 32c0-17.7 14.3-32 32-32l32 0c17.7 0 32 14.3 32 32c17.7 0 32 14.3 32 32l0 224c0 17.7-14.3 32-32 32c0 17.7-14.3 32-32 32l-32 0c-17.7 0-32-14.3-32-32c-17.7 0-32-14.3-32-32l0-224c0-17.7 14.3-32 32-32zM32 448l288 0c70.7 0 128-57.3 128-128s-57.3-128-128-128l0-64c106 0 192 86 192 192c0 49.2-18.5 94-48.9 128l16.9 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-160 0L32 512c-17.7 0-32-14.3-32-32s14.3-32 32-32zm80-64l192 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-192 0c-8.8 0-16-7.2-16-16s7.2-16 16-16z\"]\n};\nconst faSink = {\n prefix: 'fas',\n iconName: 'sink',\n icon: [512, 512, [], \"e06d\", \"M288 96c0-17.7 14.3-32 32-32s32 14.3 32 32s14.3 32 32 32s32-14.3 32-32c0-53-43-96-96-96s-96 43-96 96l0 192-64 0 0-24c0-30.9-25.1-56-56-56l-48 0c-13.3 0-24 10.7-24 24s10.7 24 24 24l48 0c4.4 0 8 3.6 8 8l0 24-80 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l224 0 224 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-80 0 0-24c0-4.4 3.6-8 8-8l56 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-56 0c-30.9 0-56 25.1-56 56l0 24-64 0 0-192zM480 416l0-32L32 384l0 32c0 53 43 96 96 96l256 0c53 0 96-43 96-96z\"]\n};\nconst faBagShopping = {\n prefix: 'fas',\n iconName: 'bag-shopping',\n icon: [448, 512, [\"shopping-bag\"], \"f290\", \"M160 112c0-35.3 28.7-64 64-64s64 28.7 64 64l0 48-128 0 0-48zm-48 48l-64 0c-26.5 0-48 21.5-48 48L0 416c0 53 43 96 96 96l256 0c53 0 96-43 96-96l0-208c0-26.5-21.5-48-48-48l-64 0 0-48C336 50.1 285.9 0 224 0S112 50.1 112 112l0 48zm24 48a24 24 0 1 1 0 48 24 24 0 1 1 0-48zm152 24a24 24 0 1 1 48 0 24 24 0 1 1 -48 0z\"]\n};\nconst faShoppingBag = faBagShopping;\nconst faArrowDownZA = {\n prefix: 'fas',\n iconName: 'arrow-down-z-a',\n icon: [576, 512, [\"sort-alpha-desc\", \"sort-alpha-down-alt\"], \"f881\", \"M183.6 469.6C177.5 476.2 169 480 160 480s-17.5-3.8-23.6-10.4l-88-96c-11.9-13-11.1-33.3 2-45.2s33.3-11.1 45.2 2L128 365.7 128 64c0-17.7 14.3-32 32-32s32 14.3 32 32l0 301.7 32.4-35.4c11.9-13 32.2-13.9 45.2-2s13.9 32.2 2 45.2l-88 96zM320 64c0-17.7 14.3-32 32-32l128 0c12.9 0 24.6 7.8 29.6 19.8s2.2 25.7-6.9 34.9L429.3 160l50.7 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-128 0c-12.9 0-24.6-7.8-29.6-19.8s-2.2-25.7 6.9-34.9L402.7 96 352 96c-17.7 0-32-14.3-32-32zm96 192c12.1 0 23.2 6.8 28.6 17.7l64 128 16 32c7.9 15.8 1.5 35-14.3 42.9s-35 1.5-42.9-14.3L460.2 448l-88.4 0-7.2 14.3c-7.9 15.8-27.1 22.2-42.9 14.3s-22.2-27.1-14.3-42.9l16-32 64-128c5.4-10.8 16.5-17.7 28.6-17.7zM395.8 400l40.4 0L416 359.6 395.8 400z\"]\n};\nconst faSortAlphaDesc = faArrowDownZA;\nconst faSortAlphaDownAlt = faArrowDownZA;\nconst faMitten = {\n prefix: 'fas',\n iconName: 'mitten',\n icon: [448, 512, [], \"f7b5\", \"M352 384L64 384 5.4 178.9C1.8 166.4 0 153.4 0 140.3C0 62.8 62.8 0 140.3 0l3.4 0c66 0 123.5 44.9 139.5 108.9l31.4 125.8 17.6-20.1C344.8 200.2 362.9 192 382 192l2.8 0c34.9 0 63.3 28.3 63.3 63.3c0 15.9-6 31.2-16.8 42.9L352 384zM32 448c0-17.7 14.3-32 32-32l288 0c17.7 0 32 14.3 32 32l0 32c0 17.7-14.3 32-32 32L64 512c-17.7 0-32-14.3-32-32l0-32z\"]\n};\nconst faPersonRays = {\n prefix: 'fas',\n iconName: 'person-rays',\n icon: [512, 512, [], \"e54d\", \"M208 48a48 48 0 1 1 96 0 48 48 0 1 1 -96 0zm40 304l0 128c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-223.1-28.6 47.5c-9.1 15.1-28.8 20-43.9 10.9s-20-28.8-10.9-43.9l58.3-97c17.4-28.9 48.6-46.6 82.3-46.6l29.7 0c33.7 0 64.9 17.7 82.3 46.6l58.3 97c9.1 15.1 4.2 34.8-10.9 43.9s-34.8 4.2-43.9-10.9L328 256.9 328 480c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-128-16 0zM7 7C16.4-2.3 31.6-2.3 41 7l80 80c9.4 9.4 9.4 24.6 0 33.9s-24.6 9.4-33.9 0L7 41C-2.3 31.6-2.3 16.4 7 7zM471 7c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9l-80 80c-9.4 9.4-24.6 9.4-33.9 0s-9.4-24.6 0-33.9L471 7zM7 505c-9.4-9.4-9.4-24.6 0-33.9l80-80c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L41 505c-9.4 9.4-24.6 9.4-33.9 0zm464 0l-80-80c-9.4-9.4-9.4-24.6 0-33.9s24.6-9.4 33.9 0l80 80c9.4 9.4 9.4 24.6 0 33.9s-24.6 9.4-33.9 0z\"]\n};\nconst faUsers = {\n prefix: 'fas',\n iconName: 'users',\n icon: [640, 512, [], \"f0c0\", \"M144 0a80 80 0 1 1 0 160A80 80 0 1 1 144 0zM512 0a80 80 0 1 1 0 160A80 80 0 1 1 512 0zM0 298.7C0 239.8 47.8 192 106.7 192l42.7 0c15.9 0 31 3.5 44.6 9.7c-1.3 7.2-1.9 14.7-1.9 22.3c0 38.2 16.8 72.5 43.3 96c-.2 0-.4 0-.7 0L21.3 320C9.6 320 0 310.4 0 298.7zM405.3 320c-.2 0-.4 0-.7 0c26.6-23.5 43.3-57.8 43.3-96c0-7.6-.7-15-1.9-22.3c13.6-6.3 28.7-9.7 44.6-9.7l42.7 0C592.2 192 640 239.8 640 298.7c0 11.8-9.6 21.3-21.3 21.3l-213.3 0zM224 224a96 96 0 1 1 192 0 96 96 0 1 1 -192 0zM128 485.3C128 411.7 187.7 352 261.3 352l117.3 0C452.3 352 512 411.7 512 485.3c0 14.7-11.9 26.7-26.7 26.7l-330.7 0c-14.7 0-26.7-11.9-26.7-26.7z\"]\n};\nconst faEyeSlash = {\n prefix: 'fas',\n iconName: 'eye-slash',\n icon: [640, 512, [], \"f070\", \"M38.8 5.1C28.4-3.1 13.3-1.2 5.1 9.2S-1.2 34.7 9.2 42.9l592 464c10.4 8.2 25.5 6.3 33.7-4.1s6.3-25.5-4.1-33.7L525.6 386.7c39.6-40.6 66.4-86.1 79.9-118.4c3.3-7.9 3.3-16.7 0-24.6c-14.9-35.7-46.2-87.7-93-131.1C465.5 68.8 400.8 32 320 32c-68.2 0-125 26.3-169.3 60.8L38.8 5.1zM223.1 149.5C248.6 126.2 282.7 112 320 112c79.5 0 144 64.5 144 144c0 24.9-6.3 48.3-17.4 68.7L408 294.5c8.4-19.3 10.6-41.4 4.8-63.3c-11.1-41.5-47.8-69.4-88.6-71.1c-5.8-.2-9.2 6.1-7.4 11.7c2.1 6.4 3.3 13.2 3.3 20.3c0 10.2-2.4 19.8-6.6 28.3l-90.3-70.8zM373 389.9c-16.4 6.5-34.3 10.1-53 10.1c-79.5 0-144-64.5-144-144c0-6.9 .5-13.6 1.4-20.2L83.1 161.5C60.3 191.2 44 220.8 34.5 243.7c-3.3 7.9-3.3 16.7 0 24.6c14.9 35.7 46.2 87.7 93 131.1C174.5 443.2 239.2 480 320 480c47.8 0 89.9-12.9 126.2-32.5L373 389.9z\"]\n};\nconst faFlaskVial = {\n prefix: 'fas',\n iconName: 'flask-vial',\n icon: [640, 512, [], \"e4f3\", \"M175 389.4c-9.8 16-15 34.3-15 53.1c-10 3.5-20.8 5.5-32 5.5c-53 0-96-43-96-96L32 64C14.3 64 0 49.7 0 32S14.3 0 32 0L96 0l64 0 64 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l0 245.9-49 79.6zM96 64l0 96 64 0 0-96L96 64zM352 0L480 0l32 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l0 150.9L629.7 406.2c6.7 10.9 10.3 23.5 10.3 36.4c0 38.3-31.1 69.4-69.4 69.4l-309.2 0c-38.3 0-69.4-31.1-69.4-69.4c0-12.8 3.6-25.4 10.3-36.4L320 214.9 320 64c-17.7 0-32-14.3-32-32s14.3-32 32-32l32 0zm32 64l0 160c0 5.9-1.6 11.7-4.7 16.8L330.5 320l171 0-48.8-79.2c-3.1-5-4.7-10.8-4.7-16.8l0-160-64 0z\"]\n};\nconst faHand = {\n prefix: 'fas',\n iconName: 'hand',\n icon: [512, 512, [129306, 9995, \"hand-paper\"], \"f256\", \"M288 32c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 208c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-176c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 272c0 1.5 0 3.1 .1 4.6L67.6 283c-16-15.2-41.3-14.6-56.6 1.4s-14.6 41.3 1.4 56.6L124.8 448c43.1 41.1 100.4 64 160 64l19.2 0c97.2 0 176-78.8 176-176l0-208c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 112c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-176c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 176c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-208z\"]\n};\nconst faHandPaper = faHand;\nconst faOm = {\n prefix: 'fas',\n iconName: 'om',\n icon: [512, 512, [128329], \"f679\", \"M379.3 4.7c-6.2-6.2-16.4-6.2-22.6 0l-16 16c-6.2 6.2-6.2 16.4 0 22.6l16 16c6.2 6.2 16.4 6.2 22.6 0l16-16c6.2-6.2 6.2-16.4 0-22.6l-16-16zM281 66.7c-2.2-1.5-4.9-2.5-7.7-2.7c-.6 0-1.3-.1-1.9 0c-3.9 .2-7.4 1.7-10.1 4.2c-.9 .8-1.6 1.7-2.3 2.6c-1.7 2.4-2.7 5.3-2.9 8.5c0 .7 0 1.4 0 2.1c.2 2.2 .9 4.3 1.9 6.2l.3 .6c.3 .6 .8 1.4 1.4 2.4c1.2 2 2.9 4.8 5.1 8.2c4.4 6.7 11.1 15.5 20 24.4C302.4 141.1 330.3 160 368 160c31.2 0 56.6-10.4 73.9-20.2c8.7-5 15.6-9.9 20.4-13.8c2.4-1.9 4.3-3.6 5.7-4.9c.7-.6 1.3-1.2 1.7-1.6l.6-.5 .1-.1 .1-.1s0 0 0 0s0 0 0 0c5.9-5.8 9.5-13.9 9.5-22.8c0-17.7-14.3-32-32-32c-8.7 0-16.7 3.5-22.4 9.2c-.1 .1-.2 .2-.5 .4c-.5 .5-1.5 1.3-2.8 2.4c-2.7 2.2-6.8 5.2-12.1 8.2C399.4 90.4 384.8 96 368 96c-20.8 0-42.4-7-59.5-14.6c-8.4-3.7-15.4-7.5-20.3-10.3c-2.4-1.4-4.3-2.5-5.6-3.3c-.6-.4-1.1-.7-1.4-.9l-.3-.2zM115.2 169.6c8-6 17.9-9.6 28.8-9.6c26.5 0 48 21.5 48 48s-21.5 48-48 48l-34.2 0c-7.6 0-13.8 6.2-13.8 13.8c0 1.5 .2 2.9 .7 4.4l8 24c4.4 13.1 16.6 21.9 30.4 21.9l8.9 0 16 0c35.3 0 64 28.7 64 64s-28.7 64-64 64c-50.8 0-82.7-21.5-102.2-42.8c-9.9-10.8-16.6-21.6-20.9-29.7c-2.1-4-3.6-7.3-4.5-9.6c-.5-1.1-.8-2-1-2.5l-.2-.5c-.3-.9-.7-1.8-1.1-2.6c-1.2-2.2-2.8-4-4.7-5.4c-1.9-1.4-4.1-2.3-6.5-2.8c-1.4-.3-2.9-.3-4.4-.2c-2.5 .2-4.8 1-6.8 2.3c-1.1 .7-2.2 1.5-3.1 2.5c-2.4 2.5-4.1 5.8-4.5 9.5c-.1 .6-.1 1.1-.1 1.7c0 0 0 0 0 0c0 .8 .1 1.7 .2 2.5l0 .1c0 .3 .1 .8 .2 1.3c.2 1.1 .4 2.7 .8 4.6c.8 3.9 2 9.4 3.9 15.9c3.8 13 10.3 30.4 21.3 48C48.7 476.2 89.4 512 160 512c70.7 0 128-57.3 128-128c0-23.3-6.2-45.2-17.1-64l22.6 0c25.5 0 49.9-10.1 67.9-28.1l26.5-26.5c6-6 14.1-9.4 22.6-9.4l5.5 0c17.7 0 32 14.3 32 32l0 96c0 17.7-14.3 32-32 32c-25.7 0-41.4-12.5-51.2-25.6c-5-6.7-8.4-13.4-10.5-18.6c-1.1-2.5-1.8-4.6-2.2-6c-.2-.7-.4-1.2-.5-1.5l-.1-.2c-.3-1.3-.8-2.6-1.5-3.8c-1.1-2-2.6-3.8-4.4-5.1c-2.7-2-6-3.2-9.6-3.2l-.2 0c-8 .1-14.6 6.1-15.6 13.9c0 0 0 0 0 0c0 .3-.1 .6-.2 1.1c-.1 .9-.3 2.1-.4 3.6c-.3 3-.6 7.3-.6 12.4c0 10.1 1.1 23.9 5.8 38.1c4.8 14.3 13.4 29.3 28.6 40.7C368.7 473.3 389.3 480 416 480c53 0 96-43 96-96l0-96c0-53-43-96-96-96l-5.5 0c-25.5 0-49.9 10.1-67.9 28.1l-26.5 26.5c-6 6-14.1 9.4-22.6 9.4l-48.3 0c6.9-14.5 10.8-30.8 10.8-48c0-61.9-50.1-112-112-112c-25.2 0-48.5 8.3-67.2 22.4c-14.1 10.6-17 30.7-6.4 44.8s30.7 17 44.8 6.4z\"]\n};\nconst faWorm = {\n prefix: 'fas',\n iconName: 'worm',\n icon: [512, 512, [], \"e599\", \"M256 96c0-53 43-96 96-96l38.4 0C439.9 0 480 40.1 480 89.6l0 86.4 0 16 0 184c0 75.1-60.9 136-136 136s-136-60.9-136-136l0-80c0-22.1-17.9-40-40-40s-40 17.9-40 40l0 168c0 26.5-21.5 48-48 48s-48-21.5-48-48l0-168c0-75.1 60.9-136 136-136s136 60.9 136 136l0 80c0 22.1 17.9 40 40 40s40-17.9 40-40l0-184-32 0c-53 0-96-43-96-96zm144-8a24 24 0 1 0 -48 0 24 24 0 1 0 48 0z\"]\n};\nconst faHouseCircleXmark = {\n prefix: 'fas',\n iconName: 'house-circle-xmark',\n icon: [640, 512, [], \"e50b\", \"M320.7 352c8.1-89.7 83.5-160 175.3-160c8.9 0 17.6 .7 26.1 1.9L309.5 7c-6-5-14-7-21-7s-15 1-22 8L10 231.5c-7 7-10 15-10 24c0 18 14 32.1 32 32.1l32 0 0 69.7c-.1 .9-.1 1.8-.1 2.8l0 112c0 22.1 17.9 40 40 40l16 0c1.2 0 2.4-.1 3.6-.2c1.5 .1 3 .2 4.5 .2l31.9 0 24 0c22.1 0 40-17.9 40-40l0-24 0-64c0-17.7 14.3-32 32-32l64 0 .7 0zM496 512a144 144 0 1 0 0-288 144 144 0 1 0 0 288zm59.3-180.7L518.6 368l36.7 36.7c6.2 6.2 6.2 16.4 0 22.6s-16.4 6.2-22.6 0L496 390.6l-36.7 36.7c-6.2 6.2-16.4 6.2-22.6 0s-6.2-16.4 0-22.6L473.4 368l-36.7-36.7c-6.2-6.2-6.2-16.4 0-22.6s16.4-6.2 22.6 0L496 345.4l36.7-36.7c6.2-6.2 16.4-6.2 22.6 0s6.2 16.4 0 22.6z\"]\n};\nconst faPlug = {\n prefix: 'fas',\n iconName: 'plug',\n icon: [384, 512, [128268], \"f1e6\", \"M96 0C78.3 0 64 14.3 64 32l0 96 64 0 0-96c0-17.7-14.3-32-32-32zM288 0c-17.7 0-32 14.3-32 32l0 96 64 0 0-96c0-17.7-14.3-32-32-32zM32 160c-17.7 0-32 14.3-32 32s14.3 32 32 32l0 32c0 77.4 55 142 128 156.8l0 67.2c0 17.7 14.3 32 32 32s32-14.3 32-32l0-67.2C297 398 352 333.4 352 256l0-32c17.7 0 32-14.3 32-32s-14.3-32-32-32L32 160z\"]\n};\nconst faChevronUp = {\n prefix: 'fas',\n iconName: 'chevron-up',\n icon: [512, 512, [], \"f077\", \"M233.4 105.4c12.5-12.5 32.8-12.5 45.3 0l192 192c12.5 12.5 12.5 32.8 0 45.3s-32.8 12.5-45.3 0L256 173.3 86.6 342.6c-12.5 12.5-32.8 12.5-45.3 0s-12.5-32.8 0-45.3l192-192z\"]\n};\nconst faHandSpock = {\n prefix: 'fas',\n iconName: 'hand-spock',\n icon: [576, 512, [128406], \"f259\", \"M246.9 23.7C242.3 6.6 224.8-3.5 207.7 1.1s-27.2 22.1-22.6 39.2L238 237.8c2.5 9.2-4.5 18.2-14 18.2c-6.4 0-12-4.2-13.9-10.3L166.6 102.7c-5.1-16.9-23-26.4-39.9-21.3s-26.4 23-21.3 39.9l62.8 206.4c2.4 7.9-7.2 13.8-13.2 8.1L99.6 283c-16-15.2-41.3-14.6-56.6 1.4s-14.6 41.3 1.4 56.6L156.8 448c43.1 41.1 100.4 64 160 64l10.9 0 8.2 0c.1 0 .1-.1 .1-.1s.1-.1 .1-.1c58.3-3.5 108.6-43.2 125.3-99.7l81.2-275c5-16.9-4.7-34.7-21.6-39.8s-34.7 4.7-39.8 21.6L443.5 247.1c-1.6 5.3-6.4 8.9-12 8.9c-7.9 0-13.8-7.3-12.2-15.1l36-170.3c3.7-17.3-7.4-34.3-24.7-37.9s-34.3 7.4-37.9 24.7L355.1 235.1c-2.6 12.2-13.3 20.9-25.8 20.9c-11.9 0-22.4-8-25.4-19.5l-57-212.8z\"]\n};\nconst faStopwatch = {\n prefix: 'fas',\n iconName: 'stopwatch',\n icon: [448, 512, [9201], \"f2f2\", \"M176 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l16 0 0 34.4C92.3 113.8 16 200 16 304c0 114.9 93.1 208 208 208s208-93.1 208-208c0-41.8-12.3-80.7-33.5-113.2l24.1-24.1c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0L355.7 143c-28.1-23-62.2-38.8-99.7-44.6L256 64l16 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L224 0 176 0zm72 192l0 128c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-128c0-13.3 10.7-24 24-24s24 10.7 24 24z\"]\n};\nconst faFaceKiss = {\n prefix: 'fas',\n iconName: 'face-kiss',\n icon: [512, 512, [128535, \"kiss\"], \"f596\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zm48.7-198.3c4.3 5.1 7.3 11.4 7.3 18.3s-3.1 13.2-7.3 18.3c-4.3 5.2-10.1 9.7-16.7 13.4c-2.7 1.5-5.7 3-8.7 4.3c3.1 1.3 6 2.7 8.7 4.3c6.6 3.7 12.5 8.2 16.7 13.4c4.3 5.1 7.3 11.4 7.3 18.3s-3.1 13.2-7.3 18.3c-4.3 5.2-10.1 9.7-16.7 13.4C274.7 443.1 257.4 448 240 448c-3.6 0-6.8-2.5-7.7-6s.6-7.2 3.8-9c0 0 0 0 0 0s0 0 0 0s0 0 0 0c0 0 0 0 0 0l.2-.1c.2-.1 .5-.3 .9-.5c.8-.5 2-1.2 3.4-2.1c2.8-1.9 6.5-4.5 10.2-7.6c3.7-3.1 7.2-6.6 9.6-10.1c2.5-3.5 3.5-6.4 3.5-8.6s-1-5-3.5-8.6c-2.5-3.5-5.9-6.9-9.6-10.1c-3.7-3.1-7.4-5.7-10.2-7.6c-1.4-.9-2.6-1.6-3.4-2.1c-.4-.2-.7-.4-.9-.5l-.2-.1c0 0 0 0 0 0c0 0 0 0 0 0s0 0 0 0c-2.5-1.4-4.1-4.1-4.1-7s1.6-5.6 4.1-7c0 0 0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0c0 0 0 0 0 0l.2-.1 .3-.2 .6-.4c.8-.5 2-1.2 3.4-2.1c2.8-1.9 6.5-4.5 10.2-7.6c3.7-3.1 7.2-6.6 9.6-10.1c2.5-3.5 3.5-6.4 3.5-8.6s-1-5-3.5-8.6c-2.5-3.5-5.9-6.9-9.6-10.1c-3.7-3.1-7.4-5.7-10.2-7.6c-1.4-.9-2.6-1.6-3.4-2.1l-.4-.3-.5-.3-.2-.1c0 0 0 0 0 0c0 0 0 0 0 0s0 0 0 0c-3.2-1.8-4.7-5.5-3.8-9s4.1-6 7.7-6c17.4 0 34.7 4.9 47.9 12.3c6.6 3.7 12.5 8.2 16.7 13.4zM144.4 208a32 32 0 1 1 64 0 32 32 0 1 1 -64 0zm192-32a32 32 0 1 1 0 64 32 32 0 1 1 0-64z\"]\n};\nconst faKiss = faFaceKiss;\nconst faBridgeCircleXmark = {\n prefix: 'fas',\n iconName: 'bridge-circle-xmark',\n icon: [640, 512, [], \"e4cb\", \"M64 32C46.3 32 32 46.3 32 64s14.3 32 32 32l40 0 0 64-72 0 0 128c53 0 96 43 96 96l0 64c0 17.7 14.3 32 32 32l32 0c17.7 0 32-14.3 32-32l0-64c0-53 43-96 96-96c6.3 0 12.4 .6 18.3 1.7C367.1 231.8 426.9 192 496 192c42.5 0 81.6 15.1 112 40.2l0-72.2-72 0 0-64 40 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L64 32zM488 96l0 64-80 0 0-64 80 0zM360 96l0 64-80 0 0-64 80 0zM232 96l0 64-80 0 0-64 80 0zM496 512a144 144 0 1 0 0-288 144 144 0 1 0 0 288zm59.3-180.7L518.6 368l36.7 36.7c6.2 6.2 6.2 16.4 0 22.6s-16.4 6.2-22.6 0L496 390.6l-36.7 36.7c-6.2 6.2-16.4 6.2-22.6 0s-6.2-16.4 0-22.6L473.4 368l-36.7-36.7c-6.2-6.2-6.2-16.4 0-22.6s16.4-6.2 22.6 0L496 345.4l36.7-36.7c6.2-6.2 16.4-6.2 22.6 0s6.2 16.4 0 22.6z\"]\n};\nconst faFaceGrinTongue = {\n prefix: 'fas',\n iconName: 'face-grin-tongue',\n icon: [512, 512, [128539, \"grin-tongue\"], \"f589\", \"M0 256C0 368.9 73.1 464.7 174.5 498.8C165.3 484 160 466.6 160 448l0-47.3c-24-17.5-43.1-41.4-54.8-69.2c-5-11.8 7-22.5 19.3-18.7c39.7 12.2 84.5 19 131.8 19s92.1-6.8 131.8-19c12.3-3.8 24.3 6.9 19.3 18.7c-11.8 28-31.1 52-55.4 69.6l0 46.9c0 18.6-5.3 36-14.5 50.8C438.9 464.7 512 368.9 512 256C512 114.6 397.4 0 256 0S0 114.6 0 256zm176.4-80a32 32 0 1 1 0 64 32 32 0 1 1 0-64zm128 32a32 32 0 1 1 64 0 32 32 0 1 1 -64 0zM320 448l0-45.4c0-14.7-11.9-26.6-26.6-26.6l-2 0c-11.3 0-21.1 7.9-23.6 18.9c-2.8 12.6-20.8 12.6-23.6 0c-2.5-11.1-12.3-18.9-23.6-18.9l-2 0c-14.7 0-26.6 11.9-26.6 26.6l0 45.4c0 35.3 28.7 64 64 64s64-28.7 64-64z\"]\n};\nconst faGrinTongue = faFaceGrinTongue;\nconst faChessBishop = {\n prefix: 'fas',\n iconName: 'chess-bishop',\n icon: [320, 512, [9821], \"f43a\", \"M128 0C110.3 0 96 14.3 96 32c0 16.1 11.9 29.4 27.4 31.7C78.4 106.8 8 190 8 288c0 47.4 30.8 72.3 56 84.7L64 400l192 0 0-27.3c25.2-12.5 56-37.4 56-84.7c0-37.3-10.2-72.4-25.3-104.1l-99.4 99.4c-6.2 6.2-16.4 6.2-22.6 0s-6.2-16.4 0-22.6L270.8 154.6c-23.2-38.1-51.8-69.5-74.2-90.9C212.1 61.4 224 48.1 224 32c0-17.7-14.3-32-32-32L128 0zM48 432L6.6 473.4c-4.2 4.2-6.6 10-6.6 16C0 501.9 10.1 512 22.6 512l274.7 0c12.5 0 22.6-10.1 22.6-22.6c0-6-2.4-11.8-6.6-16L272 432 48 432z\"]\n};\nconst faFaceGrinWink = {\n prefix: 'fas',\n iconName: 'face-grin-wink',\n icon: [512, 512, [\"grin-wink\"], \"f58c\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM388.1 312.8c12.3-3.8 24.3 6.9 19.3 18.7C382.4 390.6 324.2 432 256.3 432s-126.2-41.4-151.1-100.5c-5-11.8 7-22.5 19.3-18.7c39.7 12.2 84.5 19 131.8 19s92.1-6.8 131.8-19zm-16.9-79.2c-17.6-23.5-52.8-23.5-70.4 0c-5.3 7.1-15.3 8.5-22.4 3.2s-8.5-15.3-3.2-22.4c30.4-40.5 91.2-40.5 121.6 0c5.3 7.1 3.9 17.1-3.2 22.4s-17.1 3.9-22.4-3.2zM176.4 176a32 32 0 1 1 0 64 32 32 0 1 1 0-64z\"]\n};\nconst faGrinWink = faFaceGrinWink;\nconst faEarDeaf = {\n prefix: 'fas',\n iconName: 'ear-deaf',\n icon: [512, 512, [\"deaf\", \"deafness\", \"hard-of-hearing\"], \"f2a4\", \"M502.6 54.6l-40 40c-12.5 12.5-32.8 12.5-45.3 0s-12.5-32.8 0-45.3l40-40c12.5-12.5 32.8-12.5 45.3 0s12.5 32.8 0 45.3zm-320 320l-128 128c-12.5 12.5-32.8 12.5-45.3 0s-12.5-32.8 0-45.3l128-128c12.5-12.5 32.8-12.5 45.3 0s12.5 32.8 0 45.3zM240 128c-57.6 0-105.1 43.6-111.3 99.5c-1.9 17.6-17.8 30.2-35.3 28.3s-30.2-17.8-28.3-35.3C74.8 132.5 149.4 64 240 64c97.2 0 176 78.8 176 176c0 46-17.7 87.9-46.6 119.3c-12 13-17.4 24.8-17.4 34.7l0 6.1c0 61.9-50.1 112-112 112c-17.7 0-32-14.3-32-32s14.3-32 32-32c26.5 0 48-21.5 48-48l0-6.1c0-32.9 17.4-59.6 34.4-78c18.4-20 29.6-46.6 29.6-75.9c0-61.9-50.1-112-112-112zm0 80c-17.7 0-32 14.3-32 32c0 13.3-10.7 24-24 24s-24-10.7-24-24c0-44.2 35.8-80 80-80s80 35.8 80 80c0 13.3-10.7 24-24 24s-24-10.7-24-24c0-17.7-14.3-32-32-32z\"]\n};\nconst faDeaf = faEarDeaf;\nconst faDeafness = faEarDeaf;\nconst faHardOfHearing = faEarDeaf;\nconst faRoadCircleCheck = {\n prefix: 'fas',\n iconName: 'road-circle-check',\n icon: [640, 512, [], \"e564\", \"M213.2 32L288 32l0 64c0 17.7 14.3 32 32 32s32-14.3 32-32l0-64 74.8 0c27.1 0 51.3 17.1 60.3 42.6l42.7 120.6c-10.9-2.1-22.2-3.2-33.8-3.2c-59.5 0-112.1 29.6-144 74.8l0-42.8c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 64c0 17.7 14.3 32 32 32c2.3 0 4.6-.3 6.8-.7c-4.5 15.5-6.8 31.8-6.8 48.7c0 5.4 .2 10.7 .7 16l-.7 0c-17.7 0-32 14.3-32 32l0 64L86.6 480C56.5 480 32 455.5 32 425.4c0-6.2 1.1-12.4 3.1-18.2L152.9 74.6C162 49.1 186.1 32 213.2 32zM352 368a144 144 0 1 1 288 0 144 144 0 1 1 -288 0zm211.3-43.3c-6.2-6.2-16.4-6.2-22.6 0L480 385.4l-28.7-28.7c-6.2-6.2-16.4-6.2-22.6 0s-6.2 16.4 0 22.6l40 40c6.2 6.2 16.4 6.2 22.6 0l72-72c6.2-6.2 6.2-16.4 0-22.6z\"]\n};\nconst faDiceFive = {\n prefix: 'fas',\n iconName: 'dice-five',\n icon: [448, 512, [9860], \"f523\", \"M64 32C28.7 32 0 60.7 0 96L0 416c0 35.3 28.7 64 64 64l320 0c35.3 0 64-28.7 64-64l0-320c0-35.3-28.7-64-64-64L64 32zm64 96a32 32 0 1 1 0 64 32 32 0 1 1 0-64zM96 352a32 32 0 1 1 64 0 32 32 0 1 1 -64 0zM224 224a32 32 0 1 1 0 64 32 32 0 1 1 0-64zm64-64a32 32 0 1 1 64 0 32 32 0 1 1 -64 0zm32 160a32 32 0 1 1 0 64 32 32 0 1 1 0-64z\"]\n};\nconst faSquareRss = {\n prefix: 'fas',\n iconName: 'square-rss',\n icon: [448, 512, [\"rss-square\"], \"f143\", \"M64 32C28.7 32 0 60.7 0 96L0 416c0 35.3 28.7 64 64 64l320 0c35.3 0 64-28.7 64-64l0-320c0-35.3-28.7-64-64-64L64 32zM96 136c0-13.3 10.7-24 24-24c137 0 248 111 248 248c0 13.3-10.7 24-24 24s-24-10.7-24-24c0-110.5-89.5-200-200-200c-13.3 0-24-10.7-24-24zm0 96c0-13.3 10.7-24 24-24c83.9 0 152 68.1 152 152c0 13.3-10.7 24-24 24s-24-10.7-24-24c0-57.4-46.6-104-104-104c-13.3 0-24-10.7-24-24zm0 120a32 32 0 1 1 64 0 32 32 0 1 1 -64 0z\"]\n};\nconst faRssSquare = faSquareRss;\nconst faLandMineOn = {\n prefix: 'fas',\n iconName: 'land-mine-on',\n icon: [640, 512, [], \"e51b\", \"M344 24l0 144c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-144c0-13.3 10.7-24 24-24s24 10.7 24 24zM192 320c0-17.7 14.3-32 32-32l192 0c17.7 0 32 14.3 32 32l0 32-256 0 0-32zm-77.3 90.5c8.1-16.3 24.8-26.5 42.9-26.5l324.7 0c18.2 0 34.8 10.3 42.9 26.5l27.6 55.2C563.5 487 548 512 524.2 512l-408.4 0c-23.8 0-39.3-25-28.6-46.3l27.6-55.2zM36.3 138.3c7.5-10.9 22.5-13.6 33.4-6.1l104 72c10.9 7.5 13.6 22.5 6.1 33.4s-22.5 13.6-33.4 6.1l-104-72c-10.9-7.5-13.6-22.5-6.1-33.4zm534.1-6.1c10.9-7.5 25.8-4.8 33.4 6.1s4.8 25.8-6.1 33.4l-104 72c-10.9 7.5-25.8 4.8-33.4-6.1s-4.8-25.8 6.1-33.4l104-72z\"]\n};\nconst faICursor = {\n prefix: 'fas',\n iconName: 'i-cursor',\n icon: [256, 512, [], \"f246\", \"M.1 29.3C-1.4 47 11.7 62.4 29.3 63.9l8 .7C70.5 67.3 96 95 96 128.3L96 224l-32 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l32 0 0 95.7c0 33.3-25.5 61-58.7 63.8l-8 .7C11.7 449.6-1.4 465 .1 482.7s16.9 30.7 34.5 29.2l8-.7c34.1-2.8 64.2-18.9 85.4-42.9c21.2 24 51.2 40 85.4 42.9l8 .7c17.6 1.5 33.1-11.6 34.5-29.2s-11.6-33.1-29.2-34.5l-8-.7C185.5 444.7 160 417 160 383.7l0-95.7 32 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-32 0 0-95.7c0-33.3 25.5-61 58.7-63.8l8-.7c17.6-1.5 30.7-16.9 29.2-34.5S239-1.4 221.3 .1l-8 .7C179.2 3.6 149.2 19.7 128 43.7c-21.2-24-51.2-40-85.4-42.9l-8-.7C17-1.4 1.6 11.7 .1 29.3z\"]\n};\nconst faStamp = {\n prefix: 'fas',\n iconName: 'stamp',\n icon: [512, 512, [], \"f5bf\", \"M312 201.8c0-17.4 9.2-33.2 19.9-47C344.5 138.5 352 118.1 352 96c0-53-43-96-96-96s-96 43-96 96c0 22.1 7.5 42.5 20.1 58.8c10.7 13.8 19.9 29.6 19.9 47c0 29.9-24.3 54.2-54.2 54.2L112 256C50.1 256 0 306.1 0 368c0 20.9 13.4 38.7 32 45.3L32 464c0 26.5 21.5 48 48 48l352 0c26.5 0 48-21.5 48-48l0-50.7c18.6-6.6 32-24.4 32-45.3c0-61.9-50.1-112-112-112l-33.8 0c-29.9 0-54.2-24.3-54.2-54.2zM416 416l0 32L96 448l0-32 320 0z\"]\n};\nconst faStairs = {\n prefix: 'fas',\n iconName: 'stairs',\n icon: [576, 512, [], \"e289\", \"M384 64c0-17.7 14.3-32 32-32l128 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-96 0 0 96c0 17.7-14.3 32-32 32l-96 0 0 96c0 17.7-14.3 32-32 32l-96 0 0 96c0 17.7-14.3 32-32 32L32 480c-17.7 0-32-14.3-32-32s14.3-32 32-32l96 0 0-96c0-17.7 14.3-32 32-32l96 0 0-96c0-17.7 14.3-32 32-32l96 0 0-96z\"]\n};\nconst faI = {\n prefix: 'fas',\n iconName: 'i',\n icon: [320, 512, [105], \"49\", \"M32 32C14.3 32 0 46.3 0 64S14.3 96 32 96l96 0 0 320-96 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l256 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-96 0 0-320 96 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L160 32 32 32z\"]\n};\nconst faHryvniaSign = {\n prefix: 'fas',\n iconName: 'hryvnia-sign',\n icon: [384, 512, [8372, \"hryvnia\"], \"f6f2\", \"M121.9 116.2C138.3 103.1 158.7 96 179.6 96L223 96c27.1 0 49 21.9 49 49c0 11.5-4 22.4-11.1 31L32 176c-17.7 0-32 14.3-32 32s14.3 32 32 32l123.5 0-50.6 28.9c-1.7 1-3.4 2-5.1 3.1L32 272c-17.7 0-32 14.3-32 32s14.3 32 32 32l20.3 0c-2.8 9.9-4.3 20.4-4.3 31c0 62.4 50.6 113 113 113l43.4 0c35.5 0 70-12.1 97.7-34.3L308 441c13.8-11 16-31.2 5-45s-31.2-16-45-5l-5.9 4.7c-16.4 13.1-36.7 20.2-57.7 20.2L161 416c-27.1 0-49-21.9-49-49c0-11.5 4-22.4 11.1-31L352 336c17.7 0 32-14.3 32-32s-14.3-32-32-32l-123.5 0 50.6-28.9c1.7-1 3.4-2 5.1-3.1l67.8 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-20.3 0c2.8-10 4.3-20.4 4.3-31c0-62.4-50.6-113-113-113l-43.4 0c-35.5 0-70 12.1-97.7 34.3L76 71c-13.8 11-16 31.2-5 45s31.2 16 45 5l5.9-4.7z\"]\n};\nconst faHryvnia = faHryvniaSign;\nconst faPills = {\n prefix: 'fas',\n iconName: 'pills',\n icon: [576, 512, [], \"f484\", \"M112 96c-26.5 0-48 21.5-48 48l0 112 96 0 0-112c0-26.5-21.5-48-48-48zM0 144C0 82.1 50.1 32 112 32s112 50.1 112 112l0 224c0 61.9-50.1 112-112 112S0 429.9 0 368L0 144zM554.9 399.4c-7.1 12.3-23.7 13.1-33.8 3.1L333.5 214.9c-10-10-9.3-26.7 3.1-33.8C360 167.7 387.1 160 416 160c88.4 0 160 71.6 160 160c0 28.9-7.7 56-21.1 79.4zm-59.5 59.5C472 472.3 444.9 480 416 480c-88.4 0-160-71.6-160-160c0-28.9 7.7-56 21.1-79.4c7.1-12.3 23.7-13.1 33.8-3.1L498.5 425.1c10 10 9.3 26.7-3.1 33.8z\"]\n};\nconst faFaceGrinWide = {\n prefix: 'fas',\n iconName: 'face-grin-wide',\n icon: [512, 512, [128515, \"grin-alt\"], \"f581\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM388.1 312.8c12.3-3.8 24.3 6.9 19.3 18.7C382.4 390.6 324.2 432 256.3 432s-126.2-41.4-151.1-100.5c-5-11.8 7-22.5 19.3-18.7c39.7 12.2 84.5 19 131.8 19s92.1-6.8 131.8-19zM208 192c0 35.3-14.3 64-32 64s-32-28.7-32-64s14.3-64 32-64s32 28.7 32 64zm128 64c-17.7 0-32-28.7-32-64s14.3-64 32-64s32 28.7 32 64s-14.3 64-32 64z\"]\n};\nconst faGrinAlt = faFaceGrinWide;\nconst faTooth = {\n prefix: 'fas',\n iconName: 'tooth',\n icon: [448, 512, [129463], \"f5c9\", \"M186.1 52.1C169.3 39.1 148.7 32 127.5 32C74.7 32 32 74.7 32 127.5l0 6.2c0 15.8 3.7 31.3 10.7 45.5l23.5 47.1c4.5 8.9 7.6 18.4 9.4 28.2l36.7 205.8c2 11.2 11.6 19.4 22.9 19.8s21.4-7.4 24-18.4l28.9-121.3C192.2 323.7 207 312 224 312s31.8 11.7 35.8 28.3l28.9 121.3c2.6 11.1 12.7 18.8 24 18.4s20.9-8.6 22.9-19.8l36.7-205.8c1.8-9.8 4.9-19.3 9.4-28.2l23.5-47.1c7.1-14.1 10.7-29.7 10.7-45.5l0-2.1c0-55-44.6-99.6-99.6-99.6c-24.1 0-47.4 8.8-65.6 24.6l-3.2 2.8 19.5 15.2c7 5.4 8.2 15.5 2.8 22.5s-15.5 8.2-22.5 2.8l-24.4-19-37-28.8z\"]\n};\nconst faV = {\n prefix: 'fas',\n iconName: 'v',\n icon: [384, 512, [118], \"56\", \"M19.7 34.5c16.3-6.8 35 .9 41.8 17.2L192 364.8 322.5 51.7c6.8-16.3 25.5-24 41.8-17.2s24 25.5 17.2 41.8l-160 384c-5 11.9-16.6 19.7-29.5 19.7s-24.6-7.8-29.5-19.7L2.5 76.3c-6.8-16.3 .9-35 17.2-41.8z\"]\n};\nconst faBangladeshiTakaSign = {\n prefix: 'fas',\n iconName: 'bangladeshi-taka-sign',\n icon: [384, 512, [], \"e2e6\", \"M36 32.3C18.4 30.1 2.4 42.5 .2 60S10.5 93.6 28 95.8l7.9 1c16 2 28 15.6 28 31.8L64 160l-32 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l32 0 0 160c0 53 43 96 96 96l32 0c106 0 192-86 192-192l0-32c0-53-43-96-96-96l-16 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l16 0c17.7 0 32 14.3 32 32l0 32c0 70.7-57.3 128-128 128l-32 0c-17.7 0-32-14.3-32-32l0-160 32 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-32 0 0-31.5c0-48.4-36.1-89.3-84.1-95.3l-7.9-1z\"]\n};\nconst faBicycle = {\n prefix: 'fas',\n iconName: 'bicycle',\n icon: [640, 512, [128690], \"f206\", \"M312 32c-13.3 0-24 10.7-24 24s10.7 24 24 24l25.7 0 34.6 64-149.4 0-27.4-38C191 99.7 183.7 96 176 96l-56 0c-13.3 0-24 10.7-24 24s10.7 24 24 24l43.7 0 22.1 30.7-26.6 53.1c-10-2.5-20.5-3.8-31.2-3.8C57.3 224 0 281.3 0 352s57.3 128 128 128c65.3 0 119.1-48.9 127-112l49 0c8.5 0 16.3-4.5 20.7-11.8l84.8-143.5 21.7 40.1C402.4 276.3 384 312 384 352c0 70.7 57.3 128 128 128s128-57.3 128-128s-57.3-128-128-128c-13.5 0-26.5 2.1-38.7 6L375.4 48.8C369.8 38.4 359 32 347.2 32L312 32zM458.6 303.7l32.3 59.7c6.3 11.7 20.9 16 32.5 9.7s16-20.9 9.7-32.5l-32.3-59.7c3.6-.6 7.4-.9 11.2-.9c39.8 0 72 32.2 72 72s-32.2 72-72 72s-72-32.2-72-72c0-18.6 7-35.5 18.6-48.3zM133.2 368l65 0c-7.3 32.1-36 56-70.2 56c-39.8 0-72-32.2-72-72s32.2-72 72-72c1.7 0 3.4 .1 5.1 .2l-24.2 48.5c-9 18.1 4.1 39.4 24.3 39.4zm33.7-48l50.7-101.3 72.9 101.2-.1 .1-123.5 0zm90.6-128l108.5 0L317 274.8 257.4 192z\"]\n};\nconst faStaffSnake = {\n prefix: 'fas',\n iconName: 'staff-snake',\n icon: [384, 512, [\"rod-asclepius\", \"rod-snake\", \"staff-aesculapius\"], \"e579\", \"M222.6 43.2l-.1 4.8L288 48c53 0 96 43 96 96s-43 96-96 96l-40 0 0-80 40 0c8.8 0 16-7.2 16-16s-7.2-16-16-16l-40 0-28 0-4.5 144 40.5 0c53 0 96 43 96 96s-43 96-96 96l-16 0 0-80 16 0c8.8 0 16-7.2 16-16s-7.2-16-16-16l-43 0-3.1 99.5L208.5 495l0 1c-.3 8.9-7.6 16-16.5 16s-16.2-7.1-16.5-16l0-1-1-31L136 464c-22.1 0-40-17.9-40-40s17.9-40 40-40l36 0-1-32-19 0c-53 0-96-43-96-96c0-47.6 34.6-87.1 80-94.7l0 94.7c0 8.8 7.2 16 16 16l16.5 0L164 128l-28 0-13.4 0c-9 18.9-28.3 32-50.6 32l-16 0c-30.9 0-56-25.1-56-56S25.1 48 56 48l8 0 8 0 89.5 0-.1-4.8L161 32c0-.7 0-1.3 0-1.9c.5-16.6 14.1-30 31-30s30.5 13.4 31 30c0 .6 0 1.3 0 1.9l-.4 11.2zM64 112a16 16 0 1 0 0-32 16 16 0 1 0 0 32z\"]\n};\nconst faRodAsclepius = faStaffSnake;\nconst faRodSnake = faStaffSnake;\nconst faStaffAesculapius = faStaffSnake;\nconst faHeadSideCoughSlash = {\n prefix: 'fas',\n iconName: 'head-side-cough-slash',\n icon: [640, 512, [], \"e062\", \"M448 325.8l44 34.5c8.1 1.4 14.8 6.8 18 14.1L552.9 408c10.6 .4 19.5 7.6 22.2 17.4l39.1 30.6c.6 0 1.2-.1 1.8-.1c11.1 0 20.4 7.5 23.2 17.8l-3.9 0c6.2 8.5 6.4 20.4-.4 29c-8.2 10.4-23.3 12.3-33.7 4.1L9.2 42.9C-1.2 34.7-3.1 19.6 5.1 9.2S28.4-3.1 38.8 5.1L89.6 44.9C127 16.7 173.5 0 224 0l24 0c95.2 0 181.2 69.3 197.3 160.2c2.3 13 6.8 25.7 15.1 36l42 52.6c6.2 7.8 9.6 17.4 9.6 27.4c0 24.2-19.6 43.8-43.8 43.8L448 320s0 0 0 0l0 5.8zM0 224.2c0-38.7 9.8-75.1 27.1-106.9L341.8 365.3l-2.5 .3c-11 1.4-19.2 10.7-19.2 21.8c0 11.6 9 21.2 20.6 21.9l62 3.9 43 33.9C439.3 466.2 421.2 480 400 480l-80 0 0 8c0 13.3-10.7 24-24 24l-40 0s0 0 0 0L96 512c-17.7 0-32-14.3-32-32l0-72.7c0-16.7-6.9-32.5-17.1-45.8C16.6 322.4 0 274.1 0 224.2zM616 360a24 24 0 1 1 0 48 24 24 0 1 1 0-48zm-64-48a24 24 0 1 1 0 48 24 24 0 1 1 0-48zm40-24a24 24 0 1 1 48 0 24 24 0 1 1 -48 0z\"]\n};\nconst faTruckMedical = {\n prefix: 'fas',\n iconName: 'truck-medical',\n icon: [640, 512, [128657, \"ambulance\"], \"f0f9\", \"M0 48C0 21.5 21.5 0 48 0L368 0c26.5 0 48 21.5 48 48l0 48 50.7 0c17 0 33.3 6.7 45.3 18.7L589.3 192c12 12 18.7 28.3 18.7 45.3l0 18.7 0 32 0 64c17.7 0 32 14.3 32 32s-14.3 32-32 32l-32 0c0 53-43 96-96 96s-96-43-96-96l-128 0c0 53-43 96-96 96s-96-43-96-96l-16 0c-26.5 0-48-21.5-48-48L0 48zM416 256l128 0 0-18.7L466.7 160 416 160l0 96zM160 464a48 48 0 1 0 0-96 48 48 0 1 0 0 96zm368-48a48 48 0 1 0 -96 0 48 48 0 1 0 96 0zM176 80l0 48-48 0c-8.8 0-16 7.2-16 16l0 32c0 8.8 7.2 16 16 16l48 0 0 48c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-48 48 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-48 0 0-48c0-8.8-7.2-16-16-16l-32 0c-8.8 0-16 7.2-16 16z\"]\n};\nconst faAmbulance = faTruckMedical;\nconst faWheatAwnCircleExclamation = {\n prefix: 'fas',\n iconName: 'wheat-awn-circle-exclamation',\n icon: [640, 512, [], \"e598\", \"M505 41c9.4-9.4 9.4-24.6 0-33.9s-24.6-9.4-33.9 0L383 95c-9.4 9.4-9.4 24.6 0 33.9s24.6 9.4 33.9 0l88-88zM305.5 27.3c-6.2-6.2-16.4-6.2-22.6 0L271.5 38.6c-37.5 37.5-37.5 98.3 0 135.8l10.4 10.4-30.5 30.5c-3.4-27.3-15.5-53.8-36.5-74.8l-11.3-11.3c-6.2-6.2-16.4-6.2-22.6 0l-11.3 11.3c-37.5 37.5-37.5 98.3 0 135.8l10.4 10.4-30.5 30.5c-3.4-27.3-15.5-53.8-36.5-74.8L101.8 231c-6.2-6.2-16.4-6.2-22.6 0L67.9 242.3c-37.5 37.5-37.5 98.3 0 135.8l10.4 10.4L9.4 457.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0l68.9-68.9 12.2 12.2c37.5 37.5 98.3 37.5 135.8 0l11.3-11.3c6.2-6.2 6.2-16.4 0-22.6l-11.3-11.3c-21.8-21.8-49.6-34.1-78.1-36.9l31.9-31.9 12.2 12.2c22.5 22.5 53.3 31.5 82.4 27c0-1 0-2.1 0-3.1c0-33.1 9.1-64.1 25-90.6c-15.5-8.7-32.5-13.8-49.8-15.5l31.9-31.9 12.2 12.2c6 6 12.6 11.1 19.7 15.2c27.5-34 67.3-57.5 112.6-63.8c-4.1-3.8-8.4-7.3-12.9-10.5L505 137c9.4-9.4 9.4-24.6 0-33.9s-24.6-9.4-33.9 0l-59.4 59.4c-20.6-4.4-42-3.7-62.3 2.1c6.1-21.3 6.6-43.8 1.4-65.3L409 41c9.4-9.4 9.4-24.6 0-33.9s-24.6-9.4-33.9 0L329.1 52.9c-3.7-5-7.8-9.8-12.4-14.3L305.5 27.3zM496 512a144 144 0 1 0 0-288 144 144 0 1 0 0 288zm0-96a24 24 0 1 1 0 48 24 24 0 1 1 0-48zm0-144c8.8 0 16 7.2 16 16l0 80c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-80c0-8.8 7.2-16 16-16z\"]\n};\nconst faSnowman = {\n prefix: 'fas',\n iconName: 'snowman',\n icon: [512, 512, [9731, 9924], \"f7d0\", \"M341.1 140.6c-2 3.9-1.6 8.6 1.2 12c7 8.5 12.9 18.1 17.2 28.4L408 160.2l0-40.2c0-13.3 10.7-24 24-24s24 10.7 24 24l0 19.6 22.5-9.7c12.2-5.2 26.3 .4 31.5 12.6s-.4 26.3-12.6 31.5l-56 24-73.6 31.5c-.5 9.5-2.1 18.6-4.8 27.3c-1.2 3.8-.1 8 2.8 10.8C396.7 296.9 416 338.2 416 384c0 44.7-18.3 85-47.8 114.1c-9.9 9.7-23.7 13.9-37.5 13.9l-149.3 0c-13.9 0-27.7-4.2-37.5-13.9C114.3 469 96 428.7 96 384c0-45.8 19.3-87.1 50.1-116.3c2.9-2.8 4-6.9 2.8-10.8c-2.7-8.7-4.3-17.9-4.8-27.3L70.5 198.1l-56-24C2.4 168.8-3.3 154.7 1.9 142.5s19.3-17.8 31.5-12.6L56 139.6 56 120c0-13.3 10.7-24 24-24s24 10.7 24 24l0 40.2L152.6 181c4.3-10.3 10.1-19.9 17.2-28.4c2.8-3.4 3.3-8.1 1.2-12C164 127.2 160 112.1 160 96c0-53 43-96 96-96s96 43 96 96c0 16.1-4 31.2-10.9 44.6zM224 96a16 16 0 1 0 0-32 16 16 0 1 0 0 32zm48 128a16 16 0 1 0 -32 0 16 16 0 1 0 32 0zm-16 80a16 16 0 1 0 0-32 16 16 0 1 0 0 32zm16 48a16 16 0 1 0 -32 0 16 16 0 1 0 32 0zM288 96a16 16 0 1 0 0-32 16 16 0 1 0 0 32zm-48 24l0 3.2c0 3.2 .8 6.3 2.3 9l9 16.9c.9 1.7 2.7 2.8 4.7 2.8s3.8-1.1 4.7-2.8l9-16.9c1.5-2.8 2.3-5.9 2.3-9l0-3.2c0-8.8-7.2-16-16-16s-16 7.2-16 16z\"]\n};\nconst faMortarPestle = {\n prefix: 'fas',\n iconName: 'mortar-pestle',\n icon: [512, 512, [], \"f5a7\", \"M504.3 11.1C493.3-1.6 474.5-3.7 461 6.2L252.3 160l144.9 0L502.6 54.6c11.8-11.8 12.6-30.8 1.6-43.5zM32 192c-17.7 0-32 14.3-32 32s14.3 32 32 32c0 82.5 43.4 147.7 123.9 176.2c-11.1 13.9-19.4 30.3-23.9 48.1C127.6 497.4 142.3 512 160 512l192 0c17.7 0 32.4-14.6 28.1-31.7c-4.5-17.8-12.8-34.1-23.9-48.1C436.6 403.7 480 338.5 480 256c17.7 0 32-14.3 32-32s-14.3-32-32-32L32 192z\"]\n};\nconst faRoadBarrier = {\n prefix: 'fas',\n iconName: 'road-barrier',\n icon: [640, 512, [], \"e562\", \"M32 32C14.3 32 0 46.3 0 64L0 448c0 17.7 14.3 32 32 32s32-14.3 32-32l0-181.7L149.2 96 64 96l0-32c0-17.7-14.3-32-32-32zM405.2 96l-74.3 0-5.4 10.7L234.8 288l74.3 0 5.4-10.7L405.2 96zM362.8 288l74.3 0 5.4-10.7L533.2 96l-74.3 0-5.4 10.7L362.8 288zM202.8 96l-5.4 10.7L106.8 288l74.3 0 5.4-10.7L277.2 96l-74.3 0zm288 192l85.2 0 0 160c0 17.7 14.3 32 32 32s32-14.3 32-32l0-384c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 53.7L490.8 288z\"]\n};\nconst faSchool = {\n prefix: 'fas',\n iconName: 'school',\n icon: [640, 512, [127979], \"f549\", \"M337.8 5.4C327-1.8 313-1.8 302.2 5.4L166.3 96 48 96C21.5 96 0 117.5 0 144L0 464c0 26.5 21.5 48 48 48l208 0 0-96c0-35.3 28.7-64 64-64s64 28.7 64 64l0 96 208 0c26.5 0 48-21.5 48-48l0-320c0-26.5-21.5-48-48-48L473.7 96 337.8 5.4zM96 192l32 0c8.8 0 16 7.2 16 16l0 64c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-64c0-8.8 7.2-16 16-16zm400 16c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 64c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-64zM96 320l32 0c8.8 0 16 7.2 16 16l0 64c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-64c0-8.8 7.2-16 16-16zm400 16c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 64c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-64zM232 176a88 88 0 1 1 176 0 88 88 0 1 1 -176 0zm88-48c-8.8 0-16 7.2-16 16l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16s-7.2-16-16-16l-16 0 0-16c0-8.8-7.2-16-16-16z\"]\n};\nconst faIgloo = {\n prefix: 'fas',\n iconName: 'igloo',\n icon: [576, 512, [], \"f7ae\", \"M320 33.8L320 160 48.5 160C100.2 82.8 188.1 32 288 32c10.8 0 21.5 .6 32 1.8zM352 160l0-120.9C424.9 55.7 487.2 99.8 527.5 160L352 160zM29.9 192L96 192l0 128L0 320c0-46 10.8-89.4 29.9-128zM192 320l-64 0 0-128 320 0 0 128-64 0 0 32 192 0 0 80c0 26.5-21.5 48-48 48l-176 0 0-128c0-35.3-28.7-64-64-64s-64 28.7-64 64l0 128L48 480c-26.5 0-48-21.5-48-48l0-80 192 0 0-32zm288 0l0-128 66.1 0c19.2 38.6 29.9 82 29.9 128l-96 0z\"]\n};\nconst faJoint = {\n prefix: 'fas',\n iconName: 'joint',\n icon: [640, 512, [], \"f595\", \"M448 32c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 11c0 55.2 21.9 108.1 60.9 147.1l21 21c9 9 14.1 21.2 14.1 33.9l0 11c0 17.7 14.3 32 32 32s32-14.3 32-32l0-11c0-29.7-11.8-58.2-32.8-79.2l-21-21C463.2 117.8 448 81.2 448 43l0-11zM576 256c0 17.7 14.3 32 32 32s32-14.3 32-32l0-11c0-55.2-21.9-108.1-60.9-147.1l-21-21c-9-9-14.1-21.2-14.1-33.9l0-11c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 11c0 29.7 11.8 58.2 32.8 79.2l21 21c27 27 42.2 63.6 42.2 101.8l0 11zM229.8 360c-4.7-2.3-10-2.7-15.2-2c-37.8 5.6-75.2 14.3-106.9 22.8C81.3 388 58.3 395.1 42 400.4c-8.2 2.7-14.7 4.9-19.2 6.5c-2.3 .8-4 1.4-5.2 1.8l-1.3 .5C6.8 412.5 0 421.4 0 432s6.8 19.5 16.3 22.7l1.3 .5c1.2 .4 3 1.1 5.2 1.8c4.5 1.6 11 3.8 19.2 6.5c16.3 5.4 39.2 12.5 65.7 19.6C160.3 497.3 228.8 512 288 512l67.3 0c4.1 0 6.3-5.1 3.6-8.3L256.5 380.8c-7.4-8.9-16.5-15.9-26.7-20.8zM445 512l19 0 51.3 0c4.1 0 6.3-5.1 3.6-8.3L416.5 380.8C401.3 362.5 378.8 352 355 352l-19 0-48 0c-1.1 0-2.3 0-3.4 0c-4.1 0-6.2 5.1-3.5 8.3L383.5 483.2C398.7 501.5 421.2 512 445 512zm-3.9-151.7L543.5 483.2c14.6 17.5 35.9 27.9 58.6 28.7c21.1-1.1 37.9-18.6 37.9-39.9l0-80c0-22.1-17.9-40-40-40l-155.3 0c-4.1 0-6.3 5.1-3.6 8.3z\"]\n};\nconst faAngleRight = {\n prefix: 'fas',\n iconName: 'angle-right',\n icon: [320, 512, [8250], \"f105\", \"M278.6 233.4c12.5 12.5 12.5 32.8 0 45.3l-160 160c-12.5 12.5-32.8 12.5-45.3 0s-12.5-32.8 0-45.3L210.7 256 73.4 118.6c-12.5-12.5-12.5-32.8 0-45.3s32.8-12.5 45.3 0l160 160z\"]\n};\nconst faHorse = {\n prefix: 'fas',\n iconName: 'horse',\n icon: [576, 512, [128014], \"f6f0\", \"M448 238.1l0-78.1 16 0 9.8 19.6c12.5 25.1 42.2 36.4 68.3 26c20.5-8.2 33.9-28 33.9-50.1L576 80c0-19.1-8.4-36.3-21.7-48l5.7 0c8.8 0 16-7.2 16-16s-7.2-16-16-16L480 0 448 0C377.3 0 320 57.3 320 128l-96 0-20.8 0-54.4 0c-30.7 0-57.6 16.3-72.5 40.8C33.2 174.5 0 211.4 0 256l0 56c0 13.3 10.7 24 24 24s24-10.7 24-24l0-56c0-13.4 6.6-25.2 16.7-32.5c1.6 13 6.3 25.4 13.6 36.4l28.2 42.4c8.3 12.4 6.4 28.7-1.2 41.6c-16.5 28-20.6 62.2-10 93.9l17.5 52.4c4.4 13.1 16.6 21.9 30.4 21.9l33.7 0c21.8 0 37.3-21.4 30.4-42.1l-20.8-62.5c-2.1-6.4-.5-13.4 4.3-18.2l12.7-12.7c13.2-13.2 20.6-31.1 20.6-49.7c0-2.3-.1-4.6-.3-6.9l84 24c4.1 1.2 8.2 2.1 12.3 2.8L320 480c0 17.7 14.3 32 32 32l32 0c17.7 0 32-14.3 32-32l0-164.3c19.2-19.2 31.5-45.7 32-75.7c0 0 0 0 0 0l0-1.9zM496 64a16 16 0 1 1 0 32 16 16 0 1 1 0-32z\"]\n};\nconst faQ = {\n prefix: 'fas',\n iconName: 'q',\n icon: [448, 512, [113], \"51\", \"M64 256c0 88.4 71.6 160 160 160c28.9 0 56-7.7 79.4-21.1l-72-86.4c-11.3-13.6-9.5-33.8 4.1-45.1s33.8-9.5 45.1 4.1l70.9 85.1C371.9 325.8 384 292.3 384 256c0-88.4-71.6-160-160-160S64 167.6 64 256zM344.9 444.6C310 467 268.5 480 224 480C100.3 480 0 379.7 0 256S100.3 32 224 32s224 100.3 224 224c0 56.1-20.6 107.4-54.7 146.7l47.3 56.8c11.3 13.6 9.5 33.8-4.1 45.1s-33.8 9.5-45.1-4.1l-46.6-55.9z\"]\n};\nconst faG = {\n prefix: 'fas',\n iconName: 'g',\n icon: [448, 512, [103], \"47\", \"M224 96C135.6 96 64 167.6 64 256s71.6 160 160 160c77.4 0 142-55 156.8-128L256 288c-17.7 0-32-14.3-32-32s14.3-32 32-32l144 0c25.8 0 49.6 21.4 47.2 50.6C437.8 389.6 341.4 480 224 480C100.3 480 0 379.7 0 256S100.3 32 224 32c57.4 0 109.7 21.6 149.3 57c13.2 11.8 14.3 32 2.5 45.2s-32 14.3-45.2 2.5C302.3 111.4 265 96 224 96z\"]\n};\nconst faNotesMedical = {\n prefix: 'fas',\n iconName: 'notes-medical',\n icon: [512, 512, [], \"f481\", \"M96 352L96 96c0-35.3 28.7-64 64-64l256 0c35.3 0 64 28.7 64 64l0 197.5c0 17-6.7 33.3-18.7 45.3l-58.5 58.5c-12 12-28.3 18.7-45.3 18.7L160 416c-35.3 0-64-28.7-64-64zM272 128c-8.8 0-16 7.2-16 16l0 48-48 0c-8.8 0-16 7.2-16 16l0 32c0 8.8 7.2 16 16 16l48 0 0 48c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-48 48 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-48 0 0-48c0-8.8-7.2-16-16-16l-32 0zm24 336c13.3 0 24 10.7 24 24s-10.7 24-24 24l-160 0C60.9 512 0 451.1 0 376L0 152c0-13.3 10.7-24 24-24s24 10.7 24 24l0 224c0 48.6 39.4 88 88 88l160 0z\"]\n};\nconst faTemperatureHalf = {\n prefix: 'fas',\n iconName: 'temperature-half',\n icon: [320, 512, [127777, \"temperature-2\", \"thermometer-2\", \"thermometer-half\"], \"f2c9\", \"M160 64c-26.5 0-48 21.5-48 48l0 164.5c0 17.3-7.1 31.9-15.3 42.5C86.2 332.6 80 349.5 80 368c0 44.2 35.8 80 80 80s80-35.8 80-80c0-18.5-6.2-35.4-16.7-48.9c-8.2-10.6-15.3-25.2-15.3-42.5L208 112c0-26.5-21.5-48-48-48zM48 112C48 50.2 98.1 0 160 0s112 50.1 112 112l0 164.4c0 .1 .1 .3 .2 .6c.2 .6 .8 1.6 1.7 2.8c18.9 24.4 30.1 55 30.1 88.1c0 79.5-64.5 144-144 144S16 447.5 16 368c0-33.2 11.2-63.8 30.1-88.1c.9-1.2 1.5-2.2 1.7-2.8c.1-.3 .2-.5 .2-.6L48 112zM208 368c0 26.5-21.5 48-48 48s-48-21.5-48-48c0-20.9 13.4-38.7 32-45.3L144 208c0-8.8 7.2-16 16-16s16 7.2 16 16l0 114.7c18.6 6.6 32 24.4 32 45.3z\"]\n};\nconst faTemperature2 = faTemperatureHalf;\nconst faThermometer2 = faTemperatureHalf;\nconst faThermometerHalf = faTemperatureHalf;\nconst faDongSign = {\n prefix: 'fas',\n iconName: 'dong-sign',\n icon: [384, 512, [], \"e169\", \"M288 32c-17.7 0-32 14.3-32 32l-32 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l32 0 0 49.1c-18.8-10.9-40.7-17.1-64-17.1c-70.7 0-128 57.3-128 128s57.3 128 128 128c24.5 0 47.4-6.9 66.8-18.8c5 11.1 16.2 18.8 29.2 18.8c17.7 0 32-14.3 32-32l0-96 0-160c17.7 0 32-14.3 32-32s-14.3-32-32-32c0-17.7-14.3-32-32-32zM128 288a64 64 0 1 1 128 0 64 64 0 1 1 -128 0zM32 448c-17.7 0-32 14.3-32 32s14.3 32 32 32l320 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L32 448z\"]\n};\nconst faCapsules = {\n prefix: 'fas',\n iconName: 'capsules',\n icon: [576, 512, [], \"f46b\", \"M64 144c0-26.5 21.5-48 48-48s48 21.5 48 48l0 112-96 0 0-112zM0 144L0 368c0 61.9 50.1 112 112 112s112-50.1 112-112l0-178.4c1.8 19.1 8.2 38 19.8 54.8L372.3 431.7c35.5 51.7 105.3 64.3 156 28.1s63-107.5 27.5-159.2L427.3 113.3C391.8 61.5 321.9 49 271.3 85.2c-28 20-44.3 50.8-47.3 83l0-24.2c0-61.9-50.1-112-112-112S0 82.1 0 144zm296.6 64.2c-16-23.3-10-55.3 11.9-71c21.2-15.1 50.5-10.3 66 12.2l67 97.6L361.6 303l-65-94.8zM491 407.7c-.8 .6-1.6 1.1-2.4 1.6l4-2.8c-.5 .4-1 .8-1.6 1.2z\"]\n};\nconst faPooStorm = {\n prefix: 'fas',\n iconName: 'poo-storm',\n icon: [448, 512, [\"poo-bolt\"], \"f75a\", \"M236.9 .2c-5.5-.7-11 1.4-14.5 5.7s-4.6 10.1-2.8 15.3c2.8 8.2 4.3 16.9 4.3 26.1c0 21.7-8.5 37.2-21.9 47.6c-13.8 10.8-34 17-57.8 17L128 112c-35.3 0-64 28.7-64 64c0 12.2 3.4 23.5 9.3 33.2C31.7 216.2 0 252.4 0 296c0 40.9 28 75.4 65.8 85.2c-5.3-18.5 1-38.5 16.2-50.7l160-128c17.6-14.1 42.6-14 60.2 .2s22.8 38.6 12.8 58.8L285.7 320l18.3 0c20.4 0 38.5 12.9 45.3 32.1c3.7 10.6 3.5 21.8 0 31.9l10.7 0c48.6 0 88-39.4 88-88c0-43.6-31.7-79.8-73.3-86.8c5.9-9.7 9.3-21.1 9.3-33.2c0-35.3-28.7-64-64-64l-1.4 0c.9-5.4 1.4-10.9 1.4-16.6c0-48.7-36.1-88.9-83.1-95.2zm45.1 227.4c-5.8-4.7-14.2-4.7-20.1-.1l-160 128c-5.3 4.2-7.4 11.4-5.1 17.8s8.3 10.7 15.1 10.7l70.1 0L129.7 488.8c-3.4 6.7-1.6 14.9 4.3 19.6s14.2 4.7 20.1 .1l160-128c5.3-4.2 7.4-11.4 5.1-17.8s-8.3-10.7-15.1-10.7l-70.1 0 52.4-104.8c3.4-6.7 1.6-14.9-4.3-19.6z\"]\n};\nconst faPooBolt = faPooStorm;\nconst faFaceFrownOpen = {\n prefix: 'fas',\n iconName: 'face-frown-open',\n icon: [512, 512, [128550, \"frown-open\"], \"f57a\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM176.4 176a32 32 0 1 1 0 64 32 32 0 1 1 0-64zm128 32a32 32 0 1 1 64 0 32 32 0 1 1 -64 0zm-122 174.5c-12.4 5.2-26.5-4.1-21.1-16.4c16-36.6 52.4-62.1 94.8-62.1s78.8 25.6 94.8 62.1c5.4 12.3-8.7 21.6-21.1 16.4c-22.4-9.5-47.4-14.8-73.7-14.8s-51.3 5.3-73.7 14.8z\"]\n};\nconst faFrownOpen = faFaceFrownOpen;\nconst faHandPointUp = {\n prefix: 'fas',\n iconName: 'hand-point-up',\n icon: [384, 512, [9757], \"f0a6\", \"M32 32C32 14.3 46.3 0 64 0S96 14.3 96 32l0 208-64 0L32 32zM224 192c0-17.7 14.3-32 32-32s32 14.3 32 32l0 64c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-64zm-64-64c17.7 0 32 14.3 32 32l0 48c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-48c0-17.7 14.3-32 32-32zm160 96c0-17.7 14.3-32 32-32s32 14.3 32 32l0 64c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-64zm-96 88l0-.6c9.4 5.4 20.3 8.6 32 8.6c13.2 0 25.4-4 35.6-10.8c8.7 24.9 32.5 42.8 60.4 42.8c11.7 0 22.6-3.1 32-8.6l0 8.6c0 88.4-71.6 160-160 160l-61.7 0c-42.4 0-83.1-16.9-113.1-46.9L37.5 453.5C13.5 429.5 0 396.9 0 363l0-27c0-35.3 28.7-64 64-64l88 0c22.1 0 40 17.9 40 40s-17.9 40-40 40l-56 0c-8.8 0-16 7.2-16 16s7.2 16 16 16l56 0c39.8 0 72-32.2 72-72z\"]\n};\nconst faMoneyBill = {\n prefix: 'fas',\n iconName: 'money-bill',\n icon: [576, 512, [], \"f0d6\", \"M64 64C28.7 64 0 92.7 0 128L0 384c0 35.3 28.7 64 64 64l448 0c35.3 0 64-28.7 64-64l0-256c0-35.3-28.7-64-64-64L64 64zm64 320l-64 0 0-64c35.3 0 64 28.7 64 64zM64 192l0-64 64 0c0 35.3-28.7 64-64 64zM448 384c0-35.3 28.7-64 64-64l0 64-64 0zm64-192c-35.3 0-64-28.7-64-64l64 0 0 64zM288 160a96 96 0 1 1 0 192 96 96 0 1 1 0-192z\"]\n};\nconst faBookmark = {\n prefix: 'fas',\n iconName: 'bookmark',\n icon: [384, 512, [128278, 61591], \"f02e\", \"M0 48V487.7C0 501.1 10.9 512 24.3 512c5 0 9.9-1.5 14-4.4L192 400 345.7 507.6c4.1 2.9 9 4.4 14 4.4c13.4 0 24.3-10.9 24.3-24.3V48c0-26.5-21.5-48-48-48H48C21.5 0 0 21.5 0 48z\"]\n};\nconst faAlignJustify = {\n prefix: 'fas',\n iconName: 'align-justify',\n icon: [448, 512, [], \"f039\", \"M448 64c0-17.7-14.3-32-32-32L32 32C14.3 32 0 46.3 0 64S14.3 96 32 96l384 0c17.7 0 32-14.3 32-32zm0 256c0-17.7-14.3-32-32-32L32 288c-17.7 0-32 14.3-32 32s14.3 32 32 32l384 0c17.7 0 32-14.3 32-32zM0 192c0 17.7 14.3 32 32 32l384 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L32 160c-17.7 0-32 14.3-32 32zM448 448c0-17.7-14.3-32-32-32L32 416c-17.7 0-32 14.3-32 32s14.3 32 32 32l384 0c17.7 0 32-14.3 32-32z\"]\n};\nconst faUmbrellaBeach = {\n prefix: 'fas',\n iconName: 'umbrella-beach',\n icon: [576, 512, [127958], \"f5ca\", \"M346.3 271.8l-60.1-21.9L214 448 32 448c-17.7 0-32 14.3-32 32s14.3 32 32 32l512 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-261.9 0 64.1-176.2zm121.1-.2l-3.3 9.1 67.7 24.6c18.1 6.6 38-4.2 39.6-23.4c6.5-78.5-23.9-155.5-80.8-208.5c2 8 3.2 16.3 3.4 24.8l.2 6c1.8 57-7.3 113.8-26.8 167.4zM462 99.1c-1.1-34.4-22.5-64.8-54.4-77.4c-.9-.4-1.9-.7-2.8-1.1c-33-11.7-69.8-2.4-93.1 23.8l-4 4.5C272.4 88.3 245 134.2 226.8 184l-3.3 9.1L434 269.7l3.3-9.1c18.1-49.8 26.6-102.5 24.9-155.5l-.2-6zM107.2 112.9c-11.1 15.7-2.8 36.8 15.3 43.4l71 25.8 3.3-9.1c19.5-53.6 49.1-103 87.1-145.5l4-4.5c6.2-6.9 13.1-13 20.5-18.2c-79.6 2.5-154.7 42.2-201.2 108z\"]\n};\nconst faHelmetUn = {\n prefix: 'fas',\n iconName: 'helmet-un',\n icon: [512, 512, [], \"e503\", \"M479.5 224C471.2 98.9 367.2 0 240 0C107.5 0 0 107.5 0 240l0 56.3C0 344.8 39.2 384 87.7 384L200 384l14.9 0L343.5 505.4c4.5 4.2 10.4 6.6 16.5 6.6l96 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-86.5 0-1.5-1.5L368 288l80 0 32 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-.5 0zM320 417.2l-78-73.7L274.4 288l45.6 0 0 129.2zM285.3 103.1l34.7 52 0-43.2c0-8.8 7.2-16 16-16s16 7.2 16 16l0 96c0 7.1-4.6 13.3-11.4 15.3s-14-.6-17.9-6.4l-34.7-52 0 43.2c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-96c0-7.1 4.6-13.3 11.4-15.3s14 .6 17.9 6.4zM160 112l0 64c0 8.8 7.2 16 16 16s16-7.2 16-16l0-64c0-8.8 7.2-16 16-16s16 7.2 16 16l0 64c0 26.5-21.5 48-48 48s-48-21.5-48-48l0-64c0-8.8 7.2-16 16-16s16 7.2 16 16z\"]\n};\nconst faBullseye = {\n prefix: 'fas',\n iconName: 'bullseye',\n icon: [512, 512, [], \"f140\", \"M448 256A192 192 0 1 0 64 256a192 192 0 1 0 384 0zM0 256a256 256 0 1 1 512 0A256 256 0 1 1 0 256zm256 80a80 80 0 1 0 0-160 80 80 0 1 0 0 160zm0-224a144 144 0 1 1 0 288 144 144 0 1 1 0-288zM224 256a32 32 0 1 1 64 0 32 32 0 1 1 -64 0z\"]\n};\nconst faBacon = {\n prefix: 'fas',\n iconName: 'bacon',\n icon: [576, 512, [129363], \"f7e5\", \"M439.2 1.2c11.2-3.2 23.2-.1 31.4 8.1L518 56.7l-26.5 7.9c-58 16.6-98.1 39.6-129.6 67.4c-31.2 27.5-53.2 59.1-75.1 90.9l-2.3 3.3C241.6 288.7 195 356.6 72.8 417.7L37.9 435.2 9.4 406.6c-7.3-7.3-10.6-17.6-9-27.8s8.1-18.9 17.3-23.5C136.1 296.2 180.9 231 223.3 169.3l2.3-3.4c21.8-31.8 44.9-64.9 77.7-93.9c33.4-29.5 75.8-53.6 135.9-70.8zM61.8 459l25.4-12.7c129.5-64.7 179.9-138.1 223.8-202l2.2-3.3c22.1-32.1 42.1-60.5 69.9-85.1c27.5-24.3 63.4-45.2 117.3-60.6c0 0 0 0 0 0l.2-.1 43.1-12.9 23 23c8 8 11.2 19.7 8.3 30.7s-11.3 19.6-22.2 22.7c-51.9 14.8-85.6 34.7-111.1 57.2c-26.1 23-45.1 49.9-67.3 82.1l-2.2 3.2C327.8 365.9 275.5 442 142.3 508.6c-12.3 6.2-27.2 3.7-36.9-6L61.8 459z\"]\n};\nconst faHandPointDown = {\n prefix: 'fas',\n iconName: 'hand-point-down',\n icon: [384, 512, [], \"f0a7\", \"M32 480c0 17.7 14.3 32 32 32s32-14.3 32-32l0-208-64 0 0 208zM224 320c0 17.7 14.3 32 32 32s32-14.3 32-32l0-64c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 64zm-64 64c17.7 0 32-14.3 32-32l0-48c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 48c0 17.7 14.3 32 32 32zm160-96c0 17.7 14.3 32 32 32s32-14.3 32-32l0-64c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 64zm-96-88l0 .6c9.4-5.4 20.3-8.6 32-8.6c13.2 0 25.4 4 35.6 10.8c8.7-24.9 32.5-42.8 60.4-42.8c11.7 0 22.6 3.1 32 8.6l0-8.6C384 71.6 312.4 0 224 0L162.3 0C119.8 0 79.1 16.9 49.1 46.9L37.5 58.5C13.5 82.5 0 115.1 0 149l0 27c0 35.3 28.7 64 64 64l88 0c22.1 0 40-17.9 40-40s-17.9-40-40-40l-56 0c-8.8 0-16-7.2-16-16s7.2-16 16-16l56 0c39.8 0 72 32.2 72 72z\"]\n};\nconst faArrowUpFromBracket = {\n prefix: 'fas',\n iconName: 'arrow-up-from-bracket',\n icon: [448, 512, [], \"e09a\", \"M246.6 9.4c-12.5-12.5-32.8-12.5-45.3 0l-128 128c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0L192 109.3 192 320c0 17.7 14.3 32 32 32s32-14.3 32-32l0-210.7 73.4 73.4c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3l-128-128zM64 352c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 64c0 53 43 96 96 96l256 0c53 0 96-43 96-96l0-64c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 64c0 17.7-14.3 32-32 32L96 448c-17.7 0-32-14.3-32-32l0-64z\"]\n};\nconst faFolder = {\n prefix: 'fas',\n iconName: 'folder',\n icon: [512, 512, [128193, 128447, 61716, \"folder-blank\"], \"f07b\", \"M64 480H448c35.3 0 64-28.7 64-64V160c0-35.3-28.7-64-64-64H288c-10.1 0-19.6-4.7-25.6-12.8L243.2 57.6C231.1 41.5 212.1 32 192 32H64C28.7 32 0 60.7 0 96V416c0 35.3 28.7 64 64 64z\"]\n};\nconst faFolderBlank = faFolder;\nconst faFileWaveform = {\n prefix: 'fas',\n iconName: 'file-waveform',\n icon: [448, 512, [\"file-medical-alt\"], \"f478\", \"M96 0C60.7 0 32 28.7 32 64l0 224 112 0c6.1 0 11.6 3.4 14.3 8.8L176 332.2l49.7-99.4c2.7-5.4 8.3-8.8 14.3-8.8s11.6 3.4 14.3 8.8L281.9 288l70.1 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-80 0c-6.1 0-11.6-3.4-14.3-8.8L240 275.8l-49.7 99.4c-2.7 5.4-8.3 8.8-14.3 8.8s-11.6-3.4-14.3-8.8L134.1 320 32 320l0 128c0 35.3 28.7 64 64 64l256 0c35.3 0 64-28.7 64-64l0-288-128 0c-17.7 0-32-14.3-32-32L256 0 96 0zM288 0l0 128 128 0L288 0z\"]\n};\nconst faFileMedicalAlt = faFileWaveform;\nconst faRadiation = {\n prefix: 'fas',\n iconName: 'radiation',\n icon: [512, 512, [], \"f7b9\", \"M216 186.7c-23.9 13.8-40 39.7-40 69.3L32 256C14.3 256-.2 241.6 2 224.1C10.7 154 47.8 92.7 101.3 52c14.1-10.7 33.8-5.3 42.7 10l72 124.7zM256 336c14.6 0 28.2-3.9 40-10.7l72 124.8c8.8 15.3 3.7 35.1-12.6 41.9c-30.6 12.9-64.2 20-99.4 20s-68.9-7.1-99.4-20c-16.3-6.9-21.4-26.6-12.6-41.9l72-124.8c11.8 6.8 25.4 10.7 40 10.7zm224-80l-144 0c0-29.6-16.1-55.5-40-69.3L368 62c8.8-15.3 28.6-20.7 42.7-10c53.6 40.7 90.6 102 99.4 172.1c2.2 17.5-12.4 31.9-30 31.9zM256 208a48 48 0 1 1 0 96 48 48 0 1 1 0-96z\"]\n};\nconst faChartSimple = {\n prefix: 'fas',\n iconName: 'chart-simple',\n icon: [448, 512, [], \"e473\", \"M160 80c0-26.5 21.5-48 48-48l32 0c26.5 0 48 21.5 48 48l0 352c0 26.5-21.5 48-48 48l-32 0c-26.5 0-48-21.5-48-48l0-352zM0 272c0-26.5 21.5-48 48-48l32 0c26.5 0 48 21.5 48 48l0 160c0 26.5-21.5 48-48 48l-32 0c-26.5 0-48-21.5-48-48L0 272zM368 96l32 0c26.5 0 48 21.5 48 48l0 288c0 26.5-21.5 48-48 48l-32 0c-26.5 0-48-21.5-48-48l0-288c0-26.5 21.5-48 48-48z\"]\n};\nconst faMarsStroke = {\n prefix: 'fas',\n iconName: 'mars-stroke',\n icon: [512, 512, [9894], \"f229\", \"M376 0c-9.7 0-18.5 5.8-22.2 14.8s-1.7 19.3 5.2 26.2l33.4 33.4L370.3 96.4 345 71c-9.4-9.4-24.6-9.4-33.9 0s-9.4 24.6 0 33.9l25.4 25.4L307.8 159c-28.4-19.5-62.7-31-99.8-31c-97.2 0-176 78.8-176 176s78.8 176 176 176s176-78.8 176-176c0-37-11.4-71.4-31-99.8l28.6-28.6L407 201c9.4 9.4 24.6 9.4 33.9 0s9.4-24.6 0-33.9l-25.4-25.4 22.1-22.1L471 153c6.9 6.9 17.2 8.9 26.2 5.2s14.8-12.5 14.8-22.2l0-112c0-13.3-10.7-24-24-24L376 0zm88 48s0 0 0 0s0 0 0 0s0 0 0 0zM96 304a112 112 0 1 1 224 0A112 112 0 1 1 96 304z\"]\n};\nconst faVial = {\n prefix: 'fas',\n iconName: 'vial',\n icon: [512, 512, [129514], \"f492\", \"M342.6 9.4c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3l9.4 9.4L28.1 342.6C10.1 360.6 0 385 0 410.5L0 416c0 53 43 96 96 96l5.5 0c25.5 0 49.9-10.1 67.9-28.1L448 205.3l9.4 9.4c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3l-32-32-96-96-32-32zM205.3 256L352 109.3 402.7 160l-96 96-101.5 0z\"]\n};\nconst faGauge = {\n prefix: 'fas',\n iconName: 'gauge',\n icon: [512, 512, [\"dashboard\", \"gauge-med\", \"tachometer-alt-average\"], \"f624\", \"M0 256a256 256 0 1 1 512 0A256 256 0 1 1 0 256zm320 96c0-26.9-16.5-49.9-40-59.3L280 88c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 204.7c-23.5 9.5-40 32.5-40 59.3c0 35.3 28.7 64 64 64s64-28.7 64-64zM144 176a32 32 0 1 0 0-64 32 32 0 1 0 0 64zm-16 80a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zm288 32a32 32 0 1 0 0-64 32 32 0 1 0 0 64zM400 144a32 32 0 1 0 -64 0 32 32 0 1 0 64 0z\"]\n};\nconst faDashboard = faGauge;\nconst faGaugeMed = faGauge;\nconst faTachometerAltAverage = faGauge;\nconst faWandMagicSparkles = {\n prefix: 'fas',\n iconName: 'wand-magic-sparkles',\n icon: [576, 512, [\"magic-wand-sparkles\"], \"e2ca\", \"M234.7 42.7L197 56.8c-3 1.1-5 4-5 7.2s2 6.1 5 7.2l37.7 14.1L248.8 123c1.1 3 4 5 7.2 5s6.1-2 7.2-5l14.1-37.7L315 71.2c3-1.1 5-4 5-7.2s-2-6.1-5-7.2L277.3 42.7 263.2 5c-1.1-3-4-5-7.2-5s-6.1 2-7.2 5L234.7 42.7zM46.1 395.4c-18.7 18.7-18.7 49.1 0 67.9l34.6 34.6c18.7 18.7 49.1 18.7 67.9 0L529.9 116.5c18.7-18.7 18.7-49.1 0-67.9L495.3 14.1c-18.7-18.7-49.1-18.7-67.9 0L46.1 395.4zM484.6 82.6l-105 105-23.3-23.3 105-105 23.3 23.3zM7.5 117.2C3 118.9 0 123.2 0 128s3 9.1 7.5 10.8L64 160l21.2 56.5c1.7 4.5 6 7.5 10.8 7.5s9.1-3 10.8-7.5L128 160l56.5-21.2c4.5-1.7 7.5-6 7.5-10.8s-3-9.1-7.5-10.8L128 96 106.8 39.5C105.1 35 100.8 32 96 32s-9.1 3-10.8 7.5L64 96 7.5 117.2zm352 256c-4.5 1.7-7.5 6-7.5 10.8s3 9.1 7.5 10.8L416 416l21.2 56.5c1.7 4.5 6 7.5 10.8 7.5s9.1-3 10.8-7.5L480 416l56.5-21.2c4.5-1.7 7.5-6 7.5-10.8s-3-9.1-7.5-10.8L480 352l-21.2-56.5c-1.7-4.5-6-7.5-10.8-7.5s-9.1 3-10.8 7.5L416 352l-56.5 21.2z\"]\n};\nconst faMagicWandSparkles = faWandMagicSparkles;\nconst faE = {\n prefix: 'fas',\n iconName: 'e',\n icon: [320, 512, [101], \"45\", \"M64 32C28.7 32 0 60.7 0 96L0 256 0 416c0 35.3 28.7 64 64 64l224 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L64 416l0-128 160 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L64 224 64 96l224 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L64 32z\"]\n};\nconst faPenClip = {\n prefix: 'fas',\n iconName: 'pen-clip',\n icon: [512, 512, [\"pen-alt\"], \"f305\", \"M453.3 19.3l39.4 39.4c25 25 25 65.5 0 90.5l-52.1 52.1s0 0 0 0l-1-1s0 0 0 0l-16-16-96-96-17-17 52.1-52.1c25-25 65.5-25 90.5 0zM241 114.9c-9.4-9.4-24.6-9.4-33.9 0L105 217c-9.4 9.4-24.6 9.4-33.9 0s-9.4-24.6 0-33.9L173.1 81c28.1-28.1 73.7-28.1 101.8 0L288 94.1l17 17 96 96 16 16 1 1-17 17L229.5 412.5c-48 48-109.2 80.8-175.8 94.1l-25 5c-7.9 1.6-16-.9-21.7-6.6s-8.1-13.8-6.6-21.7l5-25c13.3-66.6 46.1-127.8 94.1-175.8L254.1 128 241 114.9z\"]\n};\nconst faPenAlt = faPenClip;\nconst faBridgeCircleExclamation = {\n prefix: 'fas',\n iconName: 'bridge-circle-exclamation',\n icon: [640, 512, [], \"e4ca\", \"M64 32C46.3 32 32 46.3 32 64s14.3 32 32 32l40 0 0 64-72 0 0 128c53 0 96 43 96 96l0 64c0 17.7 14.3 32 32 32l32 0c17.7 0 32-14.3 32-32l0-64c0-53 43-96 96-96c6.3 0 12.4 .6 18.3 1.7C367.1 231.8 426.9 192 496 192c42.5 0 81.6 15.1 112 40.2l0-72.2-72 0 0-64 40 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L64 32zM488 96l0 64-80 0 0-64 80 0zM360 96l0 64-80 0 0-64 80 0zM232 96l0 64-80 0 0-64 80 0zM496 512a144 144 0 1 0 0-288 144 144 0 1 0 0 288zm0-96a24 24 0 1 1 0 48 24 24 0 1 1 0-48zm0-144c8.8 0 16 7.2 16 16l0 80c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-80c0-8.8 7.2-16 16-16z\"]\n};\nconst faUser = {\n prefix: 'fas',\n iconName: 'user',\n icon: [448, 512, [128100, 62144], \"f007\", \"M224 256A128 128 0 1 0 224 0a128 128 0 1 0 0 256zm-45.7 48C79.8 304 0 383.8 0 482.3C0 498.7 13.3 512 29.7 512l388.6 0c16.4 0 29.7-13.3 29.7-29.7C448 383.8 368.2 304 269.7 304l-91.4 0z\"]\n};\nconst faSchoolCircleCheck = {\n prefix: 'fas',\n iconName: 'school-circle-check',\n icon: [640, 512, [], \"e56b\", \"M337.8 5.4C327-1.8 313-1.8 302.2 5.4L166.3 96 48 96C21.5 96 0 117.5 0 144L0 464c0 26.5 21.5 48 48 48l272 0s0 0 0 0l-64 0 0-96c0-35.3 28.7-64 64-64l.3 0 .5 0c3.4-37.7 18.7-72.1 42.2-99.1C350.2 260 335.6 264 320 264c-48.6 0-88-39.4-88-88s39.4-88 88-88s88 39.4 88 88c0 18.3-5.6 35.3-15.1 49.4c29-21 64.6-33.4 103.1-33.4c59.5 0 112.1 29.6 144 74.8L640 144c0-26.5-21.5-48-48-48L473.7 96 337.8 5.4zM96 192l32 0c8.8 0 16 7.2 16 16l0 64c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-64c0-8.8 7.2-16 16-16zm0 128l32 0c8.8 0 16 7.2 16 16l0 64c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-64c0-8.8 7.2-16 16-16zM320 128c-8.8 0-16 7.2-16 16l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16s-7.2-16-16-16l-16 0 0-16c0-8.8-7.2-16-16-16zM640 368a144 144 0 1 0 -288 0 144 144 0 1 0 288 0zm-99.3-43.3c6.2-6.2 16.4-6.2 22.6 0s6.2 16.4 0 22.6l-72 72c-6.2 6.2-16.4 6.2-22.6 0l-40-40c-6.2-6.2-6.2-16.4 0-22.6s16.4-6.2 22.6 0L480 385.4l60.7-60.7z\"]\n};\nconst faDumpster = {\n prefix: 'fas',\n iconName: 'dumpster',\n icon: [576, 512, [], \"f793\", \"M49.7 32c-10.5 0-19.8 6.9-22.9 16.9L.9 133c-.6 2-.9 4.1-.9 6.1C0 150.7 9.3 160 20.9 160l94 0L140.5 32 49.7 32zM272 160l0-128-98.9 0L147.5 160 272 160zm32 0l124.5 0L402.9 32 304 32l0 128zm157.1 0l94 0c11.5 0 20.9-9.3 20.9-20.9c0-2.1-.3-4.1-.9-6.1L549.2 48.9C546.1 38.9 536.8 32 526.3 32l-90.8 0 25.6 128zM32 192l4 32-4 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l12 0L64 448c0 17.7 14.3 32 32 32s32-14.3 32-32l320 0c0 17.7 14.3 32 32 32s32-14.3 32-32l20-160 12 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-4 0 4-32L32 192z\"]\n};\nconst faVanShuttle = {\n prefix: 'fas',\n iconName: 'van-shuttle',\n icon: [640, 512, [128656, \"shuttle-van\"], \"f5b6\", \"M64 104l0 88 96 0 0-96L72 96c-4.4 0-8 3.6-8 8zm482 88L465.1 96 384 96l0 96 162 0zm-226 0l0-96-96 0 0 96 96 0zM592 384l-16 0c0 53-43 96-96 96s-96-43-96-96l-128 0c0 53-43 96-96 96s-96-43-96-96l-16 0c-26.5 0-48-21.5-48-48L0 104C0 64.2 32.2 32 72 32l120 0 160 0 113.1 0c18.9 0 36.8 8.3 49 22.8L625 186.5c9.7 11.5 15 26.1 15 41.2L640 336c0 26.5-21.5 48-48 48zm-64 0a48 48 0 1 0 -96 0 48 48 0 1 0 96 0zM160 432a48 48 0 1 0 0-96 48 48 0 1 0 0 96z\"]\n};\nconst faShuttleVan = faVanShuttle;\nconst faBuildingUser = {\n prefix: 'fas',\n iconName: 'building-user',\n icon: [640, 512, [], \"e4da\", \"M48 0C21.5 0 0 21.5 0 48L0 464c0 26.5 21.5 48 48 48l96 0 0-80c0-26.5 21.5-48 48-48s48 21.5 48 48l0 80 89.9 0c-6.3-10.2-9.9-22.2-9.9-35.1c0-46.9 25.8-87.8 64-109.2l0-95.9L384 48c0-26.5-21.5-48-48-48L48 0zM64 240c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32zm112-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16zm80 16c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32zM80 96l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16zm80 16c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32zM272 96l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16zM576 272a80 80 0 1 0 -160 0 80 80 0 1 0 160 0zM352 477.1c0 19.3 15.6 34.9 34.9 34.9l218.2 0c19.3 0 34.9-15.6 34.9-34.9c0-51.4-41.7-93.1-93.1-93.1l-101.8 0c-51.4 0-93.1 41.7-93.1 93.1z\"]\n};\nconst faSquareCaretLeft = {\n prefix: 'fas',\n iconName: 'square-caret-left',\n icon: [448, 512, [\"caret-square-left\"], \"f191\", \"M0 416c0 35.3 28.7 64 64 64l320 0c35.3 0 64-28.7 64-64l0-320c0-35.3-28.7-64-64-64L64 32C28.7 32 0 60.7 0 96L0 416zM128 256c0-6.7 2.8-13 7.7-17.6l112-104c7-6.5 17.2-8.2 25.9-4.4s14.4 12.5 14.4 22l0 208c0 9.5-5.7 18.2-14.4 22s-18.9 2.1-25.9-4.4l-112-104c-4.9-4.5-7.7-10.9-7.7-17.6z\"]\n};\nconst faCaretSquareLeft = faSquareCaretLeft;\nconst faHighlighter = {\n prefix: 'fas',\n iconName: 'highlighter',\n icon: [576, 512, [], \"f591\", \"M315 315l158.4-215L444.1 70.6 229 229 315 315zm-187 5s0 0 0 0l0-71.7c0-15.3 7.2-29.6 19.5-38.6L420.6 8.4C428 2.9 437 0 446.2 0c11.4 0 22.4 4.5 30.5 12.6l54.8 54.8c8.1 8.1 12.6 19 12.6 30.5c0 9.2-2.9 18.2-8.4 25.6L334.4 396.5c-9 12.3-23.4 19.5-38.6 19.5L224 416l-25.4 25.4c-12.5 12.5-32.8 12.5-45.3 0l-50.7-50.7c-12.5-12.5-12.5-32.8 0-45.3L128 320zM7 466.3l63-63 70.6 70.6-31 31c-4.5 4.5-10.6 7-17 7L24 512c-13.3 0-24-10.7-24-24l0-4.7c0-6.4 2.5-12.5 7-17z\"]\n};\nconst faKey = {\n prefix: 'fas',\n iconName: 'key',\n icon: [512, 512, [128273], \"f084\", \"M336 352c97.2 0 176-78.8 176-176S433.2 0 336 0S160 78.8 160 176c0 18.7 2.9 36.8 8.3 53.7L7 391c-4.5 4.5-7 10.6-7 17l0 80c0 13.3 10.7 24 24 24l80 0c13.3 0 24-10.7 24-24l0-40 40 0c13.3 0 24-10.7 24-24l0-40 40 0c6.4 0 12.5-2.5 17-7l33.3-33.3c16.9 5.4 35 8.3 53.7 8.3zM376 96a40 40 0 1 1 0 80 40 40 0 1 1 0-80z\"]\n};\nconst faBullhorn = {\n prefix: 'fas',\n iconName: 'bullhorn',\n icon: [512, 512, [128226, 128363], \"f0a1\", \"M480 32c0-12.9-7.8-24.6-19.8-29.6s-25.7-2.2-34.9 6.9L381.7 53c-48 48-113.1 75-181 75l-8.7 0-32 0-96 0c-35.3 0-64 28.7-64 64l0 96c0 35.3 28.7 64 64 64l0 128c0 17.7 14.3 32 32 32l64 0c17.7 0 32-14.3 32-32l0-128 8.7 0c67.9 0 133 27 181 75l43.6 43.6c9.2 9.2 22.9 11.9 34.9 6.9s19.8-16.6 19.8-29.6l0-147.6c18.6-8.8 32-32.5 32-60.4s-13.4-51.6-32-60.4L480 32zm-64 76.7L416 240l0 131.3C357.2 317.8 280.5 288 200.7 288l-8.7 0 0-96 8.7 0c79.8 0 156.5-29.8 215.3-83.3z\"]\n};\nconst faGlobe = {\n prefix: 'fas',\n iconName: 'globe',\n icon: [512, 512, [127760], \"f0ac\", \"M352 256c0 22.2-1.2 43.6-3.3 64l-185.3 0c-2.2-20.4-3.3-41.8-3.3-64s1.2-43.6 3.3-64l185.3 0c2.2 20.4 3.3 41.8 3.3 64zm28.8-64l123.1 0c5.3 20.5 8.1 41.9 8.1 64s-2.8 43.5-8.1 64l-123.1 0c2.1-20.6 3.2-42 3.2-64s-1.1-43.4-3.2-64zm112.6-32l-116.7 0c-10-63.9-29.8-117.4-55.3-151.6c78.3 20.7 142 77.5 171.9 151.6zm-149.1 0l-176.6 0c6.1-36.4 15.5-68.6 27-94.7c10.5-23.6 22.2-40.7 33.5-51.5C239.4 3.2 248.7 0 256 0s16.6 3.2 27.8 13.8c11.3 10.8 23 27.9 33.5 51.5c11.6 26 20.9 58.2 27 94.7zm-209 0L18.6 160C48.6 85.9 112.2 29.1 190.6 8.4C165.1 42.6 145.3 96.1 135.3 160zM8.1 192l123.1 0c-2.1 20.6-3.2 42-3.2 64s1.1 43.4 3.2 64L8.1 320C2.8 299.5 0 278.1 0 256s2.8-43.5 8.1-64zM194.7 446.6c-11.6-26-20.9-58.2-27-94.6l176.6 0c-6.1 36.4-15.5 68.6-27 94.6c-10.5 23.6-22.2 40.7-33.5 51.5C272.6 508.8 263.3 512 256 512s-16.6-3.2-27.8-13.8c-11.3-10.8-23-27.9-33.5-51.5zM135.3 352c10 63.9 29.8 117.4 55.3 151.6C112.2 482.9 48.6 426.1 18.6 352l116.7 0zm358.1 0c-30 74.1-93.6 130.9-171.9 151.6c25.5-34.2 45.2-87.7 55.3-151.6l116.7 0z\"]\n};\nconst faSynagogue = {\n prefix: 'fas',\n iconName: 'synagogue',\n icon: [640, 512, [128333], \"f69b\", \"M309.8 3.7c5.9-4.9 14.6-4.9 20.5 0l121 100.8C469.5 119.7 480 142.2 480 166l0 114.1L480 512l-16 0-112 0 0-96c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 96-112 0-16 0 0-231.9L160 166c0-23.7 10.5-46.3 28.8-61.5L309.8 3.7zM512 512l0-267.5 28.1-31.2c3-3.4 7.4-5.3 11.9-5.3s8.9 1.9 11.9 5.3l63.8 70.9c7.9 8.8 12.3 20.3 12.3 32.1L640 448c0 35.3-28.7 64-64 64l-64 0zM128 244.5L128 512l-64 0c-35.3 0-64-28.7-64-64L0 316.3c0-11.9 4.4-23.3 12.3-32.1l63.8-70.9c3-3.4 7.4-5.3 11.9-5.3s8.9 1.9 11.9 5.3L128 244.5zM327 124.3c-3.1-5.4-10.9-5.4-13.9 0l-15.9 28.1-32.3-.3c-6.2-.1-10.1 6.7-7 12.1L274.3 192l-16.4 27.8c-3.2 5.4 .7 12.1 7 12.1l32.3-.3L313 259.7c3.1 5.4 10.9 5.4 13.9 0l15.9-28.1 32.3 .3c6.2 .1 10.1-6.7 7-12.1L365.7 192l16.4-27.8c3.2-5.4-.7-12.1-7-12.1l-32.3 .3L327 124.3z\"]\n};\nconst faPersonHalfDress = {\n prefix: 'fas',\n iconName: 'person-half-dress',\n icon: [320, 512, [], \"e548\", \"M160 0a48 48 0 1 1 0 96 48 48 0 1 1 0-96zm8 352l0-224 6.9 0c33.7 0 64.9 17.7 82.3 46.6l58.3 97c9.1 15.1 4.2 34.8-10.9 43.9s-34.8 4.2-43.9-10.9L232 256.9 232 480c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-128s0 0 0 0zM58.2 182.3c19.9-33.1 55.3-53.5 93.8-54.3l0 256s0 0 0 0l0 96c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-96-17.8 0c-10.9 0-18.6-10.7-15.2-21.1L93.3 248.1 59.4 304.5c-9.1 15.1-28.8 20-43.9 10.9s-20-28.8-10.9-43.9l53.6-89.2z\"]\n};\nconst faRoadBridge = {\n prefix: 'fas',\n iconName: 'road-bridge',\n icon: [640, 512, [], \"e563\", \"M352 0L608 0c17.7 0 32 14.3 32 32l0 448c0 17.7-14.3 32-32 32l-256 0c-17.7 0-32-14.3-32-32l0-448c0-17.7 14.3-32 32-32zM480 200c-13.3 0-24 10.7-24 24l0 64c0 13.3 10.7 24 24 24s24-10.7 24-24l0-64c0-13.3-10.7-24-24-24zm24 184c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 64c0 13.3 10.7 24 24 24s24-10.7 24-24l0-64zM480 40c-13.3 0-24 10.7-24 24l0 64c0 13.3 10.7 24 24 24s24-10.7 24-24l0-64c0-13.3-10.7-24-24-24zM32 96l256 0 0 64-40 0 0 64 40 0 0 96c-53 0-96 43-96 96l0 64c0 17.7-14.3 32-32 32l-32 0c-17.7 0-32-14.3-32-32l0-64c0-53-43-96-96-96l0-96 72 0 0-64-40 0c-17.7 0-32-14.3-32-32s14.3-32 32-32zm168 64l-80 0 0 64 80 0 0-64z\"]\n};\nconst faLocationArrow = {\n prefix: 'fas',\n iconName: 'location-arrow',\n icon: [448, 512, [], \"f124\", \"M429.6 92.1c4.9-11.9 2.1-25.6-7-34.7s-22.8-11.9-34.7-7l-352 144c-14.2 5.8-22.2 20.8-19.3 35.8s16.1 25.8 31.4 25.8l176 0 0 176c0 15.3 10.8 28.4 25.8 31.4s30-5.1 35.8-19.3l144-352z\"]\n};\nconst faC = {\n prefix: 'fas',\n iconName: 'c',\n icon: [384, 512, [99], \"43\", \"M329.1 142.9c-62.5-62.5-155.8-62.5-218.3 0s-62.5 163.8 0 226.3s155.8 62.5 218.3 0c12.5-12.5 32.8-12.5 45.3 0s12.5 32.8 0 45.3c-87.5 87.5-221.3 87.5-308.8 0s-87.5-229.3 0-316.8s221.3-87.5 308.8 0c12.5 12.5 12.5 32.8 0 45.3s-32.8 12.5-45.3 0z\"]\n};\nconst faTabletButton = {\n prefix: 'fas',\n iconName: 'tablet-button',\n icon: [448, 512, [], \"f10a\", \"M64 0C28.7 0 0 28.7 0 64L0 448c0 35.3 28.7 64 64 64l320 0c35.3 0 64-28.7 64-64l0-384c0-35.3-28.7-64-64-64L64 0zM224 400a32 32 0 1 1 0 64 32 32 0 1 1 0-64z\"]\n};\nconst faBuildingLock = {\n prefix: 'fas',\n iconName: 'building-lock',\n icon: [576, 512, [], \"e4d6\", \"M48 0C21.5 0 0 21.5 0 48L0 464c0 26.5 21.5 48 48 48l96 0 0-80c0-26.5 21.5-48 48-48s48 21.5 48 48l0 80 88.6 0c-5.4-9.4-8.6-20.3-8.6-32l0-128c0-23.7 12.9-44.4 32-55.4l0-24.6c0-30.5 12.2-58.2 32-78.4L384 48c0-26.5-21.5-48-48-48L48 0zM64 240c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32zm112-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16zm80 16c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32zM80 96l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16zm80 16c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32zM272 96l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16zM464 240c17.7 0 32 14.3 32 32l0 48-64 0 0-48c0-17.7 14.3-32 32-32zm-80 32l0 48c-17.7 0-32 14.3-32 32l0 128c0 17.7 14.3 32 32 32l160 0c17.7 0 32-14.3 32-32l0-128c0-17.7-14.3-32-32-32l0-48c0-44.2-35.8-80-80-80s-80 35.8-80 80z\"]\n};\nconst faPizzaSlice = {\n prefix: 'fas',\n iconName: 'pizza-slice',\n icon: [512, 512, [], \"f818\", \"M169.7 .9c-22.8-1.6-41.9 14-47.5 34.7L110.4 80c.5 0 1.1 0 1.6 0c176.7 0 320 143.3 320 320c0 .5 0 1.1 0 1.6l44.4-11.8c20.8-5.5 36.3-24.7 34.7-47.5C498.5 159.5 352.5 13.5 169.7 .9zM399.8 410.2c.1-3.4 .2-6.8 .2-10.2c0-159.1-128.9-288-288-288c-3.4 0-6.8 .1-10.2 .2L.5 491.9c-1.5 5.5 .1 11.4 4.1 15.4s9.9 5.6 15.4 4.1L399.8 410.2zM176 208a32 32 0 1 1 0 64 32 32 0 1 1 0-64zm64 128a32 32 0 1 1 64 0 32 32 0 1 1 -64 0zM96 384a32 32 0 1 1 64 0 32 32 0 1 1 -64 0z\"]\n};\nconst faMoneyBillWave = {\n prefix: 'fas',\n iconName: 'money-bill-wave',\n icon: [576, 512, [], \"f53a\", \"M0 112.5L0 422.3c0 18 10.1 35 27 41.3c87 32.5 174 10.3 261-11.9c79.8-20.3 159.6-40.7 239.3-18.9c23 6.3 48.7-9.5 48.7-33.4l0-309.9c0-18-10.1-35-27-41.3C462 15.9 375 38.1 288 60.3C208.2 80.6 128.4 100.9 48.7 79.1C25.6 72.8 0 88.6 0 112.5zM288 352c-44.2 0-80-43-80-96s35.8-96 80-96s80 43 80 96s-35.8 96-80 96zM64 352c35.3 0 64 28.7 64 64l-64 0 0-64zm64-208c0 35.3-28.7 64-64 64l0-64 64 0zM512 304l0 64-64 0c0-35.3 28.7-64 64-64zM448 96l64 0 0 64c-35.3 0-64-28.7-64-64z\"]\n};\nconst faChartArea = {\n prefix: 'fas',\n iconName: 'chart-area',\n icon: [512, 512, [\"area-chart\"], \"f1fe\", \"M64 64c0-17.7-14.3-32-32-32S0 46.3 0 64L0 400c0 44.2 35.8 80 80 80l400 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L80 416c-8.8 0-16-7.2-16-16L64 64zm96 288l288 0c17.7 0 32-14.3 32-32l0-68.2c0-7.6-2.7-15-7.7-20.8l-65.8-76.8c-12.1-14.2-33.7-15-46.9-1.8l-21 21c-10 10-26.4 9.2-35.4-1.6l-39.2-47c-12.6-15.1-35.7-15.4-48.7-.6L135.9 215c-5.1 5.8-7.9 13.3-7.9 21.1l0 84c0 17.7 14.3 32 32 32z\"]\n};\nconst faAreaChart = faChartArea;\nconst faHouseFlag = {\n prefix: 'fas',\n iconName: 'house-flag',\n icon: [640, 512, [], \"e50d\", \"M480 0c-17.7 0-32 14.3-32 32l0 160 0 320 64 0 0-320 112 0c8.8 0 16-7.2 16-16l0-128c0-8.8-7.2-16-16-16L512 32c0-17.7-14.3-32-32-32zM416 159L276.8 39.7c-12-10.3-29.7-10.3-41.7 0l-224 192C1 240.4-2.7 254.5 2 267.1S18.6 288 32 288l32 0 0 192c0 17.7 14.3 32 32 32l64 0c17.7 0 32-14.3 32-32l0-96c0-17.7 14.3-32 32-32l64 0c17.7 0 32 14.3 32 32l0 96c0 17.7 14.3 32 32 32l64.7 0 .2 0-1 0 0-353z\"]\n};\nconst faPersonCircleMinus = {\n prefix: 'fas',\n iconName: 'person-circle-minus',\n icon: [576, 512, [], \"e540\", \"M112 48a48 48 0 1 1 96 0 48 48 0 1 1 -96 0zm40 304l0 128c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-223.1L59.4 304.5c-9.1 15.1-28.8 20-43.9 10.9s-20-28.8-10.9-43.9l58.3-97c17.4-28.9 48.6-46.6 82.3-46.6l29.7 0c33.7 0 64.9 17.7 82.3 46.6l44.9 74.7c-16.1 17.6-28.6 38.5-36.6 61.5c-1.9-1.8-3.5-3.9-4.9-6.3L232 256.9 232 480c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-128-16 0zm136 16a144 144 0 1 1 288 0 144 144 0 1 1 -288 0zm224 0c0-8.8-7.2-16-16-16l-128 0c-8.8 0-16 7.2-16 16s7.2 16 16 16l128 0c8.8 0 16-7.2 16-16z\"]\n};\nconst faBan = {\n prefix: 'fas',\n iconName: 'ban',\n icon: [512, 512, [128683, \"cancel\"], \"f05e\", \"M367.2 412.5L99.5 144.8C77.1 176.1 64 214.5 64 256c0 106 86 192 192 192c41.5 0 79.9-13.1 111.2-35.5zm45.3-45.3C434.9 335.9 448 297.5 448 256c0-106-86-192-192-192c-41.5 0-79.9 13.1-111.2 35.5L412.5 367.2zM0 256a256 256 0 1 1 512 0A256 256 0 1 1 0 256z\"]\n};\nconst faCancel = faBan;\nconst faCameraRotate = {\n prefix: 'fas',\n iconName: 'camera-rotate',\n icon: [640, 512, [], \"e0d8\", \"M213.1 64.8L202.7 96 128 96c-35.3 0-64 28.7-64 64l0 256c0 35.3 28.7 64 64 64l384 0c35.3 0 64-28.7 64-64l0-256c0-35.3-28.7-64-64-64l-74.7 0L426.9 64.8C420.4 45.2 402.1 32 381.4 32L258.6 32c-20.7 0-39 13.2-45.5 32.8zM448 256c0 8.8-7.2 16-16 16l-76.7 0c-6.2 0-11.3-5.1-11.3-11.3c0-3 1.2-5.9 3.3-8L371 229c-13.6-13.4-31.9-21-51-21c-19.2 0-37.7 7.6-51.3 21.3L249 249c-9.4 9.4-24.6 9.4-33.9 0s-9.4-24.6 0-33.9l19.7-19.7C257.4 172.7 288 160 320 160c31.8 0 62.4 12.6 85 35l23.7-23.7c2.1-2.1 5-3.3 8-3.3c6.2 0 11.3 5.1 11.3 11.3l0 76.7zM192 320c0-8.8 7.2-16 16-16l76.7 0c6.2 0 11.3 5.1 11.3 11.3c0 3-1.2 5.9-3.3 8L269 347c13.6 13.4 31.9 21 51 21c19.2 0 37.7-7.6 51.3-21.3L391 327c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9l-19.7 19.7C382.6 403.3 352 416 320 416c-31.8 0-62.4-12.6-85-35l-23.7 23.7c-2.1 2.1-5 3.3-8 3.3c-6.2 0-11.3-5.1-11.3-11.3l0-76.7z\"]\n};\nconst faSprayCanSparkles = {\n prefix: 'fas',\n iconName: 'spray-can-sparkles',\n icon: [512, 512, [\"air-freshener\"], \"f5d0\", \"M96 32l0 96 128 0 0-96c0-17.7-14.3-32-32-32L128 0C110.3 0 96 14.3 96 32zm0 128c-53 0-96 43-96 96L0 464c0 26.5 21.5 48 48 48l224 0c26.5 0 48-21.5 48-48l0-208c0-53-43-96-96-96L96 160zm64 96a80 80 0 1 1 0 160 80 80 0 1 1 0-160zM384 48c0-1.4-1-3-2.2-3.6L352 32 339.6 2.2C339 1 337.4 0 336 0s-3 1-3.6 2.2L320 32 290.2 44.4C289 45 288 46.6 288 48c0 1.4 1 3 2.2 3.6L320 64l12.4 29.8C333 95 334.6 96 336 96s3-1 3.6-2.2L352 64l29.8-12.4C383 51 384 49.4 384 48zm76.4 45.8C461 95 462.6 96 464 96s3-1 3.6-2.2L480 64l29.8-12.4C511 51 512 49.4 512 48c0-1.4-1-3-2.2-3.6L480 32 467.6 2.2C467 1 465.4 0 464 0s-3 1-3.6 2.2L448 32 418.2 44.4C417 45 416 46.6 416 48c0 1.4 1 3 2.2 3.6L448 64l12.4 29.8zm7.2 100.4c-.6-1.2-2.2-2.2-3.6-2.2s-3 1-3.6 2.2L448 224l-29.8 12.4c-1.2 .6-2.2 2.2-2.2 3.6c0 1.4 1 3 2.2 3.6L448 256l12.4 29.8c.6 1.2 2.2 2.2 3.6 2.2s3-1 3.6-2.2L480 256l29.8-12.4c1.2-.6 2.2-2.2 2.2-3.6c0-1.4-1-3-2.2-3.6L480 224l-12.4-29.8zM448 144c0-1.4-1-3-2.2-3.6L416 128 403.6 98.2C403 97 401.4 96 400 96s-3 1-3.6 2.2L384 128l-29.8 12.4c-1.2 .6-2.2 2.2-2.2 3.6c0 1.4 1 3 2.2 3.6L384 160l12.4 29.8c.6 1.2 2.2 2.2 3.6 2.2s3-1 3.6-2.2L416 160l29.8-12.4c1.2-.6 2.2-2.2 2.2-3.6z\"]\n};\nconst faAirFreshener = faSprayCanSparkles;\nconst faStar = {\n prefix: 'fas',\n iconName: 'star',\n icon: [576, 512, [11088, 61446], \"f005\", \"M316.9 18C311.6 7 300.4 0 288.1 0s-23.4 7-28.8 18L195 150.3 51.4 171.5c-12 1.8-22 10.2-25.7 21.7s-.7 24.2 7.9 32.7L137.8 329 113.2 474.7c-2 12 3 24.2 12.9 31.3s23 8 33.8 2.3l128.3-68.5 128.3 68.5c10.8 5.7 23.9 4.9 33.8-2.3s14.9-19.3 12.9-31.3L438.5 329 542.7 225.9c8.6-8.5 11.7-21.2 7.9-32.7s-13.7-19.9-25.7-21.7L381.2 150.3 316.9 18z\"]\n};\nconst faRepeat = {\n prefix: 'fas',\n iconName: 'repeat',\n icon: [512, 512, [128257], \"f363\", \"M0 224c0 17.7 14.3 32 32 32s32-14.3 32-32c0-53 43-96 96-96l160 0 0 32c0 12.9 7.8 24.6 19.8 29.6s25.7 2.2 34.9-6.9l64-64c12.5-12.5 12.5-32.8 0-45.3l-64-64c-9.2-9.2-22.9-11.9-34.9-6.9S320 19.1 320 32l0 32L160 64C71.6 64 0 135.6 0 224zm512 64c0-17.7-14.3-32-32-32s-32 14.3-32 32c0 53-43 96-96 96l-160 0 0-32c0-12.9-7.8-24.6-19.8-29.6s-25.7-2.2-34.9 6.9l-64 64c-12.5 12.5-12.5 32.8 0 45.3l64 64c9.2 9.2 22.9 11.9 34.9 6.9s19.8-16.6 19.8-29.6l0-32 160 0c88.4 0 160-71.6 160-160z\"]\n};\nconst faCross = {\n prefix: 'fas',\n iconName: 'cross',\n icon: [384, 512, [128327, 10013], \"f654\", \"M176 0c-26.5 0-48 21.5-48 48l0 80-80 0c-26.5 0-48 21.5-48 48l0 32c0 26.5 21.5 48 48 48l80 0 0 208c0 26.5 21.5 48 48 48l32 0c26.5 0 48-21.5 48-48l0-208 80 0c26.5 0 48-21.5 48-48l0-32c0-26.5-21.5-48-48-48l-80 0 0-80c0-26.5-21.5-48-48-48L176 0z\"]\n};\nconst faBox = {\n prefix: 'fas',\n iconName: 'box',\n icon: [448, 512, [128230], \"f466\", \"M50.7 58.5L0 160l208 0 0-128L93.7 32C75.5 32 58.9 42.3 50.7 58.5zM240 160l208 0L397.3 58.5C389.1 42.3 372.5 32 354.3 32L240 32l0 128zm208 32L0 192 0 416c0 35.3 28.7 64 64 64l320 0c35.3 0 64-28.7 64-64l0-224z\"]\n};\nconst faVenusMars = {\n prefix: 'fas',\n iconName: 'venus-mars',\n icon: [640, 512, [9892], \"f228\", \"M176 288a112 112 0 1 0 0-224 112 112 0 1 0 0 224zM352 176c0 86.3-62.1 158.1-144 173.1l0 34.9 32 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-32 0 0 32c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-32-32 0c-17.7 0-32-14.3-32-32s14.3-32 32-32l32 0 0-34.9C62.1 334.1 0 262.3 0 176C0 78.8 78.8 0 176 0s176 78.8 176 176zM271.9 360.6c19.3-10.1 36.9-23.1 52.1-38.4c20 18.5 46.7 29.8 76.1 29.8c61.9 0 112-50.1 112-112s-50.1-112-112-112c-7.2 0-14.3 .7-21.1 2c-4.9-21.5-13-41.7-24-60.2C369.3 66 384.4 64 400 64c37 0 71.4 11.4 99.8 31l20.6-20.6L487 41c-6.9-6.9-8.9-17.2-5.2-26.2S494.3 0 504 0L616 0c13.3 0 24 10.7 24 24l0 112c0 9.7-5.8 18.5-14.8 22.2s-19.3 1.7-26.2-5.2l-33.4-33.4L545 140.2c19.5 28.4 31 62.7 31 99.8c0 97.2-78.8 176-176 176c-50.5 0-96-21.3-128.1-55.4z\"]\n};\nconst faArrowPointer = {\n prefix: 'fas',\n iconName: 'arrow-pointer',\n icon: [320, 512, [\"mouse-pointer\"], \"f245\", \"M0 55.2L0 426c0 12.2 9.9 22 22 22c6.3 0 12.4-2.7 16.6-7.5L121.2 346l58.1 116.3c7.9 15.8 27.1 22.2 42.9 14.3s22.2-27.1 14.3-42.9L179.8 320l118.1 0c12.2 0 22.1-9.9 22.1-22.1c0-6.3-2.7-12.3-7.4-16.5L38.6 37.9C34.3 34.1 28.9 32 23.2 32C10.4 32 0 42.4 0 55.2z\"]\n};\nconst faMousePointer = faArrowPointer;\nconst faMaximize = {\n prefix: 'fas',\n iconName: 'maximize',\n icon: [512, 512, [\"expand-arrows-alt\"], \"f31e\", \"M200 32L56 32C42.7 32 32 42.7 32 56l0 144c0 9.7 5.8 18.5 14.8 22.2s19.3 1.7 26.2-5.2l40-40 79 79-79 79L73 295c-6.9-6.9-17.2-8.9-26.2-5.2S32 302.3 32 312l0 144c0 13.3 10.7 24 24 24l144 0c9.7 0 18.5-5.8 22.2-14.8s1.7-19.3-5.2-26.2l-40-40 79-79 79 79-40 40c-6.9 6.9-8.9 17.2-5.2 26.2s12.5 14.8 22.2 14.8l144 0c13.3 0 24-10.7 24-24l0-144c0-9.7-5.8-18.5-14.8-22.2s-19.3-1.7-26.2 5.2l-40 40-79-79 79-79 40 40c6.9 6.9 17.2 8.9 26.2 5.2s14.8-12.5 14.8-22.2l0-144c0-13.3-10.7-24-24-24L312 32c-9.7 0-18.5 5.8-22.2 14.8s-1.7 19.3 5.2 26.2l40 40-79 79-79-79 40-40c6.9-6.9 8.9-17.2 5.2-26.2S209.7 32 200 32z\"]\n};\nconst faExpandArrowsAlt = faMaximize;\nconst faChargingStation = {\n prefix: 'fas',\n iconName: 'charging-station',\n icon: [576, 512, [], \"f5e7\", \"M96 0C60.7 0 32 28.7 32 64l0 384c-17.7 0-32 14.3-32 32s14.3 32 32 32l288 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l0-144 16 0c22.1 0 40 17.9 40 40l0 32c0 39.8 32.2 72 72 72s72-32.2 72-72l0-123.7c32.5-10.2 56-40.5 56-76.3l0-32c0-8.8-7.2-16-16-16l-16 0 0-48c0-8.8-7.2-16-16-16s-16 7.2-16 16l0 48-32 0 0-48c0-8.8-7.2-16-16-16s-16 7.2-16 16l0 48-16 0c-8.8 0-16 7.2-16 16l0 32c0 35.8 23.5 66.1 56 76.3L472 376c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-32c0-48.6-39.4-88-88-88l-16 0 0-192c0-35.3-28.7-64-64-64L96 0zM216.9 82.7c6 4 8.5 11.5 6.3 18.3l-25 74.9 57.8 0c6.7 0 12.7 4.2 15 10.4s.5 13.3-4.6 17.7l-112 96c-5.5 4.7-13.4 5.1-19.3 1.1s-8.5-11.5-6.3-18.3l25-74.9L96 208c-6.7 0-12.7-4.2-15-10.4s-.5-13.3 4.6-17.7l112-96c5.5-4.7 13.4-5.1 19.3-1.1z\"]\n};\nconst faShapes = {\n prefix: 'fas',\n iconName: 'shapes',\n icon: [512, 512, [\"triangle-circle-square\"], \"f61f\", \"M315.4 15.5C309.7 5.9 299.2 0 288 0s-21.7 5.9-27.4 15.5l-96 160c-5.9 9.9-6.1 22.2-.4 32.2s16.3 16.2 27.8 16.2l192 0c11.5 0 22.2-6.2 27.8-16.2s5.5-22.3-.4-32.2l-96-160zM288 312l0 144c0 22.1 17.9 40 40 40l144 0c22.1 0 40-17.9 40-40l0-144c0-22.1-17.9-40-40-40l-144 0c-22.1 0-40 17.9-40 40zM128 512a128 128 0 1 0 0-256 128 128 0 1 0 0 256z\"]\n};\nconst faTriangleCircleSquare = faShapes;\nconst faShuffle = {\n prefix: 'fas',\n iconName: 'shuffle',\n icon: [512, 512, [128256, \"random\"], \"f074\", \"M403.8 34.4c12-5 25.7-2.2 34.9 6.9l64 64c6 6 9.4 14.1 9.4 22.6s-3.4 16.6-9.4 22.6l-64 64c-9.2 9.2-22.9 11.9-34.9 6.9s-19.8-16.6-19.8-29.6l0-32-32 0c-10.1 0-19.6 4.7-25.6 12.8L284 229.3 244 176l31.2-41.6C293.3 110.2 321.8 96 352 96l32 0 0-32c0-12.9 7.8-24.6 19.8-29.6zM164 282.7L204 336l-31.2 41.6C154.7 401.8 126.2 416 96 416l-64 0c-17.7 0-32-14.3-32-32s14.3-32 32-32l64 0c10.1 0 19.6-4.7 25.6-12.8L164 282.7zm274.6 188c-9.2 9.2-22.9 11.9-34.9 6.9s-19.8-16.6-19.8-29.6l0-32-32 0c-30.2 0-58.7-14.2-76.8-38.4L121.6 172.8c-6-8.1-15.5-12.8-25.6-12.8l-64 0c-17.7 0-32-14.3-32-32s14.3-32 32-32l64 0c30.2 0 58.7 14.2 76.8 38.4L326.4 339.2c6 8.1 15.5 12.8 25.6 12.8l32 0 0-32c0-12.9 7.8-24.6 19.8-29.6s25.7-2.2 34.9 6.9l64 64c6 6 9.4 14.1 9.4 22.6s-3.4 16.6-9.4 22.6l-64 64z\"]\n};\nconst faRandom = faShuffle;\nconst faPersonRunning = {\n prefix: 'fas',\n iconName: 'person-running',\n icon: [448, 512, [127939, \"running\"], \"f70c\", \"M320 48a48 48 0 1 0 -96 0 48 48 0 1 0 96 0zM125.7 175.5c9.9-9.9 23.4-15.5 37.5-15.5c1.9 0 3.8 .1 5.6 .3L137.6 254c-9.3 28 1.7 58.8 26.8 74.5l86.2 53.9-25.4 88.8c-4.9 17 5 34.7 22 39.6s34.7-5 39.6-22l28.7-100.4c5.9-20.6-2.6-42.6-20.7-53.9L238 299l30.9-82.4 5.1 12.3C289 264.7 323.9 288 362.7 288l21.3 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-21.3 0c-12.9 0-24.6-7.8-29.5-19.7l-6.3-15c-14.6-35.1-44.1-61.9-80.5-73.1l-48.7-15c-11.1-3.4-22.7-5.2-34.4-5.2c-31 0-60.8 12.3-82.7 34.3L57.4 153.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0l23.1-23.1zM91.2 352L32 352c-17.7 0-32 14.3-32 32s14.3 32 32 32l69.6 0c19 0 36.2-11.2 43.9-28.5L157 361.6l-9.5-6c-17.5-10.9-30.5-26.8-37.9-44.9L91.2 352z\"]\n};\nconst faRunning = faPersonRunning;\nconst faMobileRetro = {\n prefix: 'fas',\n iconName: 'mobile-retro',\n icon: [320, 512, [], \"e527\", \"M0 64C0 28.7 28.7 0 64 0L256 0c35.3 0 64 28.7 64 64l0 384c0 35.3-28.7 64-64 64L64 512c-35.3 0-64-28.7-64-64L0 64zm64 96l0 64c0 17.7 14.3 32 32 32l128 0c17.7 0 32-14.3 32-32l0-64c0-17.7-14.3-32-32-32L96 128c-17.7 0-32 14.3-32 32zM80 352a24 24 0 1 0 0-48 24 24 0 1 0 0 48zm24 56a24 24 0 1 0 -48 0 24 24 0 1 0 48 0zm56-56a24 24 0 1 0 0-48 24 24 0 1 0 0 48zm24 56a24 24 0 1 0 -48 0 24 24 0 1 0 48 0zm56-56a24 24 0 1 0 0-48 24 24 0 1 0 0 48zm24 56a24 24 0 1 0 -48 0 24 24 0 1 0 48 0zM128 48c-8.8 0-16 7.2-16 16s7.2 16 16 16l64 0c8.8 0 16-7.2 16-16s-7.2-16-16-16l-64 0z\"]\n};\nconst faGripLinesVertical = {\n prefix: 'fas',\n iconName: 'grip-lines-vertical',\n icon: [192, 512, [], \"f7a5\", \"M64 64c0-17.7-14.3-32-32-32S0 46.3 0 64L0 448c0 17.7 14.3 32 32 32s32-14.3 32-32L64 64zm128 0c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 384c0 17.7 14.3 32 32 32s32-14.3 32-32l0-384z\"]\n};\nconst faSpider = {\n prefix: 'fas',\n iconName: 'spider',\n icon: [512, 512, [128375], \"f717\", \"M158.4 32.6c4.8-12.4-1.4-26.3-13.8-31s-26.3 1.4-31 13.8L81.1 100c-7.9 20.7-3 44.1 12.7 59.7l57.4 57.4L70.8 190.3c-2.4-.8-4.3-2.7-5.1-5.1L46.8 128.4C42.6 115.8 29 109 16.4 113.2S-3 131 1.2 143.6l18.9 56.8c5.6 16.7 18.7 29.8 35.4 35.4L116.1 256 55.6 276.2c-16.7 5.6-29.8 18.7-35.4 35.4L1.2 368.4C-3 381 3.8 394.6 16.4 398.8s26.2-2.6 30.4-15.2l18.9-56.8c.8-2.4 2.7-4.3 5.1-5.1l80.4-26.8L93.7 352.3C78.1 368 73.1 391.4 81.1 412l32.5 84.6c4.8 12.4 18.6 18.5 31 13.8s18.5-18.6 13.8-31l-32.5-84.6c-1.1-3-.4-6.3 1.8-8.5L160 353.9c1 52.1 43.6 94.1 96 94.1s95-41.9 96-94.1l32.3 32.3c2.2 2.2 2.9 5.6 1.8 8.5l-32.5 84.6c-4.8 12.4 1.4 26.3 13.8 31s26.3-1.4 31-13.8L430.9 412c7.9-20.7 3-44.1-12.7-59.7l-57.4-57.4 80.4 26.8c2.4 .8 4.3 2.7 5.1 5.1l18.9 56.8c4.2 12.6 17.8 19.4 30.4 15.2s19.4-17.8 15.2-30.4l-18.9-56.8c-5.6-16.7-18.7-29.8-35.4-35.4L395.9 256l60.5-20.2c16.7-5.6 29.8-18.7 35.4-35.4l18.9-56.8c4.2-12.6-2.6-26.2-15.2-30.4s-26.2 2.6-30.4 15.2l-18.9 56.8c-.8 2.4-2.7 4.3-5.1 5.1l-80.4 26.8 57.4-57.4c15.6-15.6 20.6-39 12.7-59.7L398.4 15.4C393.6 3 379.8-3.2 367.4 1.6s-18.5 18.6-13.8 31l32.5 84.6c1.1 3 .4 6.3-1.8 8.5L336 174.1l0-14.1c0-31.8-18.6-59.3-45.5-72.2c-9.1-4.4-18.5 3.3-18.5 13.4l0 10.8c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-10.8c0-10.1-9.4-17.7-18.5-13.4C194.6 100.7 176 128.2 176 160l0 14.1-48.3-48.3c-2.2-2.2-2.9-5.6-1.8-8.5l32.5-84.6z\"]\n};\nconst faHandsBound = {\n prefix: 'fas',\n iconName: 'hands-bound',\n icon: [640, 512, [], \"e4f9\", \"M96 32C96 14.3 81.7 0 64 0S32 14.3 32 32l0 64 0 59.1 0 .7L32 192l0 21.9c0 14.2 5.1 27.9 14.3 38.7L131.6 352l-3.6 0c-13.3 0-24 10.7-24 24s10.7 24 24 24l32 0 128 0 64 0 128 0 32 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-3.6 0 85.3-99.5c9.2-10.8 14.3-24.5 14.3-38.7l0-21.9 0-36.2 0-.7L608 96l0-64c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 64 0 48.8-69.3 92.4c-5.7 7.6-16.1 9.6-24.2 4.8c-9.7-5.7-12.1-18.7-5.1-27.5L473 180c10.8-13.5 8.9-33.3-4.4-44.5s-33-9.8-44.5 3.2l-46.7 52.5C361 209.7 352 233.4 352 258.1l0 61.9 0 32-64 0 0-32 0-61.9c0-24.6-9-48.4-25.4-66.8l-46.7-52.5c-11.5-13-31.3-14.4-44.5-3.2s-15.2 30.9-4.4 44.5l27.6 34.5c7 8.8 4.7 21.8-5.1 27.5c-8.1 4.8-18.6 2.7-24.2-4.8L96 144.8 96 96l0-64zm64 448l0 32 128 0 0-32 64 0 0 32 128 0 0-32 32 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-32 0-128 0-64 0-128 0-32 0c-13.3 0-24 10.7-24 24s10.7 24 24 24l32 0z\"]\n};\nconst faFileInvoiceDollar = {\n prefix: 'fas',\n iconName: 'file-invoice-dollar',\n icon: [384, 512, [], \"f571\", \"M64 0C28.7 0 0 28.7 0 64L0 448c0 35.3 28.7 64 64 64l256 0c35.3 0 64-28.7 64-64l0-288-128 0c-17.7 0-32-14.3-32-32L224 0 64 0zM256 0l0 128 128 0L256 0zM64 80c0-8.8 7.2-16 16-16l64 0c8.8 0 16 7.2 16 16s-7.2 16-16 16L80 96c-8.8 0-16-7.2-16-16zm0 64c0-8.8 7.2-16 16-16l64 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-64 0c-8.8 0-16-7.2-16-16zm128 72c8.8 0 16 7.2 16 16l0 17.3c8.5 1.2 16.7 3.1 24.1 5.1c8.5 2.3 13.6 11 11.3 19.6s-11 13.6-19.6 11.3c-11.1-3-22-5.2-32.1-5.3c-8.4-.1-17.4 1.8-23.6 5.5c-5.7 3.4-8.1 7.3-8.1 12.8c0 3.7 1.3 6.5 7.3 10.1c6.9 4.1 16.6 7.1 29.2 10.9l.5 .1s0 0 0 0s0 0 0 0c11.3 3.4 25.3 7.6 36.3 14.6c12.1 7.6 22.4 19.7 22.7 38.2c.3 19.3-9.6 33.3-22.9 41.6c-7.7 4.8-16.4 7.6-25.1 9.1l0 17.1c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-17.8c-11.2-2.1-21.7-5.7-30.9-8.9c0 0 0 0 0 0c-2.1-.7-4.2-1.4-6.2-2.1c-8.4-2.8-12.9-11.9-10.1-20.2s11.9-12.9 20.2-10.1c2.5 .8 4.8 1.6 7.1 2.4c0 0 0 0 0 0s0 0 0 0s0 0 0 0c13.6 4.6 24.6 8.4 36.3 8.7c9.1 .3 17.9-1.7 23.7-5.3c5.1-3.2 7.9-7.3 7.8-14c-.1-4.6-1.8-7.8-7.7-11.6c-6.8-4.3-16.5-7.4-29-11.2l-1.6-.5s0 0 0 0c-11-3.3-24.3-7.3-34.8-13.7c-12-7.2-22.6-18.9-22.7-37.3c-.1-19.4 10.8-32.8 23.8-40.5c7.5-4.4 15.8-7.2 24.1-8.7l0-17.3c0-8.8 7.2-16 16-16z\"]\n};\nconst faPlaneCircleExclamation = {\n prefix: 'fas',\n iconName: 'plane-circle-exclamation',\n icon: [640, 512, [], \"e556\", \"M256 0c-35 0-64 59.5-64 93.7l0 84.6L8.1 283.4c-5 2.8-8.1 8.2-8.1 13.9l0 65.5c0 10.6 10.2 18.3 20.4 15.4l171.6-49 0 70.9-57.6 43.2c-4 3-6.4 7.8-6.4 12.8l0 42c0 7.8 6.3 14 14 14c1.3 0 2.6-.2 3.9-.5L256 480l110.1 31.5c1.3 .4 2.6 .5 3.9 .5c6 0 11.1-3.7 13.1-9C344.5 470.7 320 422.2 320 368c0-60.6 30.6-114 77.1-145.6L320 178.3l0-84.6C320 59.5 292 0 256 0zM496 512a144 144 0 1 0 0-288 144 144 0 1 0 0 288zm0-96a24 24 0 1 1 0 48 24 24 0 1 1 0-48zm0-144c8.8 0 16 7.2 16 16l0 80c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-80c0-8.8 7.2-16 16-16z\"]\n};\nconst faXRay = {\n prefix: 'fas',\n iconName: 'x-ray',\n icon: [512, 512, [], \"f497\", \"M0 64C0 46.3 14.3 32 32 32l448 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l0 320c17.7 0 32 14.3 32 32s-14.3 32-32 32L32 480c-17.7 0-32-14.3-32-32s14.3-32 32-32L32 96C14.3 96 0 81.7 0 64zM256 96c-8.8 0-16 7.2-16 16l0 32-80 0c-8.8 0-16 7.2-16 16s7.2 16 16 16l80 0 0 48-112 0c-8.8 0-16 7.2-16 16s7.2 16 16 16l112 0 0 70.6L189.1 307c-5.2-2-10.6-3-16.2-3l-2.1 0c-23.6 0-42.8 19.2-42.8 42.8c0 9.6 3.2 18.9 9.1 26.4l18.2 23.2c9.7 12.4 24.6 19.6 40.3 19.6l120.8 0c15.7 0 30.6-7.2 40.3-19.6l18.2-23.2c5.9-7.5 9.1-16.8 9.1-26.4c0-23.6-19.2-42.8-42.8-42.8l-2.2 0c-5.5 0-11 1-16.2 3L272 326.6l0-70.6 112 0c8.8 0 16-7.2 16-16s-7.2-16-16-16l-112 0 0-48 80 0c8.8 0 16-7.2 16-16s-7.2-16-16-16l-80 0 0-32c0-8.8-7.2-16-16-16zM208 352a16 16 0 1 1 0 32 16 16 0 1 1 0-32zm80 16a16 16 0 1 1 32 0 16 16 0 1 1 -32 0z\"]\n};\nconst faSpellCheck = {\n prefix: 'fas',\n iconName: 'spell-check',\n icon: [576, 512, [], \"f891\", \"M112 0C99.1 0 87.4 7.8 82.5 19.7l-66.7 160-13.3 32c-6.8 16.3 .9 35 17.2 41.8s35-.9 41.8-17.2L66.7 224l90.7 0 5.1 12.3c6.8 16.3 25.5 24 41.8 17.2s24-25.5 17.2-41.8l-13.3-32-66.7-160C136.6 7.8 124.9 0 112 0zm18.7 160l-37.3 0L112 115.2 130.7 160zM256 32l0 96 0 96c0 17.7 14.3 32 32 32l80 0c44.2 0 80-35.8 80-80c0-23.1-9.8-43.8-25.4-58.4c6-11.2 9.4-24 9.4-37.6c0-44.2-35.8-80-80-80L288 0c-17.7 0-32 14.3-32 32zm96 64l-32 0 0-32 32 0c8.8 0 16 7.2 16 16s-7.2 16-16 16zm-32 64l32 0 16 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-48 0 0-32zM566.6 310.6c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0L352 434.7l-73.4-73.4c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3l96 96c12.5 12.5 32.8 12.5 45.3 0l192-192z\"]\n};\nconst faSlash = {\n prefix: 'fas',\n iconName: 'slash',\n icon: [640, 512, [], \"f715\", \"M5.1 9.2C13.3-1.2 28.4-3.1 38.8 5.1l592 464c10.4 8.2 12.3 23.3 4.1 33.7s-23.3 12.3-33.7 4.1L9.2 42.9C-1.2 34.7-3.1 19.6 5.1 9.2z\"]\n};\nconst faComputerMouse = {\n prefix: 'fas',\n iconName: 'computer-mouse',\n icon: [384, 512, [128433, \"mouse\"], \"f8cc\", \"M0 192l176 0L176 0 160 0C71.6 0 0 71.6 0 160l0 32zm0 32L0 352c0 88.4 71.6 160 160 160l64 0c88.4 0 160-71.6 160-160l0-128-192 0L0 224zm384-32l0-32C384 71.6 312.4 0 224 0L208 0l0 192 176 0z\"]\n};\nconst faMouse = faComputerMouse;\nconst faArrowRightToBracket = {\n prefix: 'fas',\n iconName: 'arrow-right-to-bracket',\n icon: [512, 512, [\"sign-in\"], \"f090\", \"M352 96l64 0c17.7 0 32 14.3 32 32l0 256c0 17.7-14.3 32-32 32l-64 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l64 0c53 0 96-43 96-96l0-256c0-53-43-96-96-96l-64 0c-17.7 0-32 14.3-32 32s14.3 32 32 32zm-9.4 182.6c12.5-12.5 12.5-32.8 0-45.3l-128-128c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3L242.7 224 32 224c-17.7 0-32 14.3-32 32s14.3 32 32 32l210.7 0-73.4 73.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0l128-128z\"]\n};\nconst faSignIn = faArrowRightToBracket;\nconst faShopSlash = {\n prefix: 'fas',\n iconName: 'shop-slash',\n icon: [640, 512, [\"store-alt-slash\"], \"e070\", \"M38.8 5.1C28.4-3.1 13.3-1.2 5.1 9.2S-1.2 34.7 9.2 42.9l592 464c10.4 8.2 25.5 6.3 33.7-4.1s6.3-25.5-4.1-33.7l-54.8-43L576 224l-64 0 0 152L384 275.7l0-51.7-64 0 0 1.5L277.2 192l325.9 0c20.3 0 36.8-16.5 36.8-36.8c0-7.3-2.2-14.4-6.2-20.4L558.2 21.4C549.3 8 534.4 0 518.3 0L121.7 0c-16 0-31 8-39.9 21.4L74.1 32.8 38.8 5.1zM36.8 192l85 0L21 112.5 6.2 134.7c-4 6.1-6.2 13.2-6.2 20.4C0 175.5 16.5 192 36.8 192zM320 384l-192 0 0-160-64 0 0 160 0 80c0 26.5 21.5 48 48 48l224 0c26.5 0 48-21.5 48-48l0-65.5-64-50.4 0 35.9z\"]\n};\nconst faStoreAltSlash = faShopSlash;\nconst faServer = {\n prefix: 'fas',\n iconName: 'server',\n icon: [512, 512, [], \"f233\", \"M64 32C28.7 32 0 60.7 0 96l0 64c0 35.3 28.7 64 64 64l384 0c35.3 0 64-28.7 64-64l0-64c0-35.3-28.7-64-64-64L64 32zm280 72a24 24 0 1 1 0 48 24 24 0 1 1 0-48zm48 24a24 24 0 1 1 48 0 24 24 0 1 1 -48 0zM64 288c-35.3 0-64 28.7-64 64l0 64c0 35.3 28.7 64 64 64l384 0c35.3 0 64-28.7 64-64l0-64c0-35.3-28.7-64-64-64L64 288zm280 72a24 24 0 1 1 0 48 24 24 0 1 1 0-48zm56 24a24 24 0 1 1 48 0 24 24 0 1 1 -48 0z\"]\n};\nconst faVirusCovidSlash = {\n prefix: 'fas',\n iconName: 'virus-covid-slash',\n icon: [640, 512, [], \"e4a9\", \"M38.8 5.1C28.4-3.1 13.3-1.2 5.1 9.2S-1.2 34.7 9.2 42.9l592 464c10.4 8.2 25.5 6.3 33.7-4.1s6.3-25.5-4.1-33.7L472.1 344.7c11.4-19.5 19.1-41.4 22.3-64.7l33.6 0 0 16c0 13.3 10.7 24 24 24s24-10.7 24-24l0-80c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 16-33.6 0c-4.2-30.7-16.3-58.8-34.1-82.3L484 125.9l11.3 11.3c9.4 9.4 24.6 9.4 33.9 0s9.4-24.6 0-33.9L472.7 46.7c-9.4-9.4-24.6-9.4-33.9 0s-9.4 24.6 0 33.9L450.1 92l-23.8 23.8C402.8 97.9 374.7 85.8 344 81.6L344 48l16 0c13.3 0 24-10.7 24-24s-10.7-24-24-24L280 0c-13.3 0-24 10.7-24 24s10.7 24 24 24l16 0 0 33.6c-30.7 4.2-58.8 16.3-82.3 34.1L189.9 92l11.3-11.3c9.4-9.4 9.4-24.6 0-33.9s-24.6-9.4-33.9 0L134.1 79.8 38.8 5.1zM149.2 213.5c-1.5 6-2.7 12.2-3.5 18.5L112 232l0-16c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 80c0 13.3 10.7 24 24 24s24-10.7 24-24l0-16 33.6 0c4.2 30.7 16.3 58.8 34.1 82.3L156 386.1l-11.3-11.3c-9.4-9.4-24.6-9.4-33.9 0s-9.4 24.6 0 33.9l56.6 56.6c9.4 9.4 24.6 9.4 33.9 0s9.4-24.6 0-33.9L189.9 420l23.8-23.8c23.5 17.9 51.7 29.9 82.3 34.1l0 33.6-16 0c-13.3 0-24 10.7-24 24s10.7 24 24 24l80 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-16 0 0-33.6c20.4-2.8 39.7-9.1 57.3-18.2L149.2 213.5z\"]\n};\nconst faShopLock = {\n prefix: 'fas',\n iconName: 'shop-lock',\n icon: [640, 512, [], \"e4a5\", \"M36.8 192l412.8 0c20.2-19.8 47.9-32 78.4-32c30.5 0 58.1 12.2 78.3 31.9c18.9-1.6 33.7-17.4 33.7-36.7c0-7.3-2.2-14.4-6.2-20.4L558.2 21.4C549.3 8 534.4 0 518.3 0L121.7 0c-16 0-31 8-39.9 21.4L6.2 134.7c-4 6.1-6.2 13.2-6.2 20.4C0 175.5 16.5 192 36.8 192zM384 224l-64 0 0 160-192 0 0-160-64 0 0 160 0 80c0 26.5 21.5 48 48 48l224 0c26.5 0 48-21.5 48-48l0-80 0-32 0-128zm144 16c17.7 0 32 14.3 32 32l0 48-64 0 0-48c0-17.7 14.3-32 32-32zm-80 32l0 48c-17.7 0-32 14.3-32 32l0 128c0 17.7 14.3 32 32 32l160 0c17.7 0 32-14.3 32-32l0-128c0-17.7-14.3-32-32-32l0-48c0-44.2-35.8-80-80-80s-80 35.8-80 80z\"]\n};\nconst faHourglassStart = {\n prefix: 'fas',\n iconName: 'hourglass-start',\n icon: [384, 512, [\"hourglass-1\"], \"f251\", \"M32 0C14.3 0 0 14.3 0 32S14.3 64 32 64l0 11c0 42.4 16.9 83.1 46.9 113.1L146.7 256 78.9 323.9C48.9 353.9 32 394.6 32 437l0 11c-17.7 0-32 14.3-32 32s14.3 32 32 32l32 0 256 0 32 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l0-11c0-42.4-16.9-83.1-46.9-113.1L237.3 256l67.9-67.9c30-30 46.9-70.7 46.9-113.1l0-11c17.7 0 32-14.3 32-32s-14.3-32-32-32L320 0 64 0 32 0zM288 437l0 11L96 448l0-11c0-25.5 10.1-49.9 28.1-67.9L192 301.3l67.9 67.9c18 18 28.1 42.4 28.1 67.9z\"]\n};\nconst faHourglass1 = faHourglassStart;\nconst faBlenderPhone = {\n prefix: 'fas',\n iconName: 'blender-phone',\n icon: [576, 512, [], \"f6b6\", \"M224 352L196.8 52.3C194.2 24.2 216.3 0 244.6 0L534.1 0c21.1 0 36.4 20.1 30.9 40.4L558.5 64 400 64c-8.8 0-16 7.2-16 16s7.2 16 16 16l149.8 0-17.5 64L400 160c-8.8 0-16 7.2-16 16s7.2 16 16 16l123.6 0-17.5 64L400 256c-8.8 0-16 7.2-16 16s7.2 16 16 16l97.5 0L480 352l-256 0zm-16 32l288 0c26.5 0 48 21.5 48 48l0 32c0 26.5-21.5 48-48 48l-288 0c-26.5 0-48-21.5-48-48l0-32c0-26.5 21.5-48 48-48zm144 96a32 32 0 1 0 0-64 32 32 0 1 0 0 64zM147.5 30.7c10.8 6.7 15.3 21 10.6 33.4l-22 57.8c-4.2 10.9-14.5 17.6-25.3 16.4l-33.3-3.6c-13.6 42.2-13.6 88.4 0 130.7l33.3-3.6c10.9-1.2 21.2 5.5 25.3 16.4l22 57.8c4.7 12.4 .2 26.7-10.6 33.4l-44 27.2c-9.7 6-21.9 4.2-29.8-4.3C-24.6 286-24.6 114 73.7 7.8C81.6-.7 93.8-2.5 103.5 3.5l44 27.2z\"]\n};\nconst faBuildingWheat = {\n prefix: 'fas',\n iconName: 'building-wheat',\n icon: [640, 512, [], \"e4db\", \"M0 48C0 21.5 21.5 0 48 0L336 0c26.5 0 48 21.5 48 48l0 416c0 26.5-21.5 48-48 48l-96 0 0-80c0-26.5-21.5-48-48-48s-48 21.5-48 48l0 80-96 0c-26.5 0-48-21.5-48-48L0 48zM80 224c-8.8 0-16 7.2-16 16l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0zm80 16l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0c-8.8 0-16 7.2-16 16zm112-16c-8.8 0-16 7.2-16 16l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0zM64 112l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16L80 96c-8.8 0-16 7.2-16 16zM176 96c-8.8 0-16 7.2-16 16l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0zm80 16l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0c-8.8 0-16 7.2-16 16zm384 80l0 16c0 44.2-35.8 80-80 80l-16 0 0-16c0-44.2 35.8-80 80-80l16 0zm0 128c0 44.2-35.8 80-80 80l-16 0 0-16c0-44.2 35.8-80 80-80l16 0 0 16zm0 112c0 44.2-35.8 80-80 80l-16 0 0-16c0-44.2 35.8-80 80-80l16 0 0 16zM512 496l0 16-16 0c-44.2 0-80-35.8-80-80l0-16 16 0c44.2 0 80 35.8 80 80zm0-96l-16 0c-44.2 0-80-35.8-80-80l0-16 16 0c44.2 0 80 35.8 80 80l0 16zm0-128l0 16-16 0c-44.2 0-80-35.8-80-80l0-16 16 0c44.2 0 80 35.8 80 80zM528 32c13.3 0 24 10.7 24 24l0 104c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-104c0-13.3 10.7-24 24-24zm96 64l0 32c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-32c0-13.3 10.7-24 24-24s24 10.7 24 24zM456 72c13.3 0 24 10.7 24 24l0 32c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-32c0-13.3 10.7-24 24-24z\"]\n};\nconst faPersonBreastfeeding = {\n prefix: 'fas',\n iconName: 'person-breastfeeding',\n icon: [448, 512, [], \"e53a\", \"M224 0a80 80 0 1 1 0 160A80 80 0 1 1 224 0zM436.8 382.8L373.5 462c-16.6 20.7-46.8 24.1-67.5 7.5c-17.6-14.1-22.7-38.1-13.5-57.7l-.8-.1c-38.9-5.6-74.3-25.1-99.7-54.8l0-36.8c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 48c0 .8 0 1.6 .1 2.4l101.4 50.7c23.7 11.9 33.3 40.7 21.5 64.4s-40.7 33.3-64.4 21.5L27.2 427.3c-1.1-.5-2.2-1.1-3.3-1.7c-4.9-2.8-9.2-6.4-12.6-10.6c-4.6-5.4-7.8-11.7-9.6-18.4c-3.3-12-1.9-25.2 4.8-36.6c.6-1.1 1.3-2.2 2-3.2L75.6 256.1c26.7-40.1 71.7-64.1 119.8-64.1l75.2 0c46.5 0 90.1 22.5 117.2 60.3l50.7 70.9c2.2 3 4 6.1 5.5 9.4c2.9 6.7 4.3 13.8 4 20.8c-.3 10.6-4.2 21-11.2 29.4zM320 332a44 44 0 1 0 -88 0 44 44 0 1 0 88 0z\"]\n};\nconst faRightToBracket = {\n prefix: 'fas',\n iconName: 'right-to-bracket',\n icon: [512, 512, [\"sign-in-alt\"], \"f2f6\", \"M217.9 105.9L340.7 228.7c7.2 7.2 11.3 17.1 11.3 27.3s-4.1 20.1-11.3 27.3L217.9 406.1c-6.4 6.4-15 9.9-24 9.9c-18.7 0-33.9-15.2-33.9-33.9l0-62.1L32 320c-17.7 0-32-14.3-32-32l0-64c0-17.7 14.3-32 32-32l128 0 0-62.1c0-18.7 15.2-33.9 33.9-33.9c9 0 17.6 3.6 24 9.9zM352 416l64 0c17.7 0 32-14.3 32-32l0-256c0-17.7-14.3-32-32-32l-64 0c-17.7 0-32-14.3-32-32s14.3-32 32-32l64 0c53 0 96 43 96 96l0 256c0 53-43 96-96 96l-64 0c-17.7 0-32-14.3-32-32s14.3-32 32-32z\"]\n};\nconst faSignInAlt = faRightToBracket;\nconst faVenus = {\n prefix: 'fas',\n iconName: 'venus',\n icon: [384, 512, [9792], \"f221\", \"M80 176a112 112 0 1 1 224 0A112 112 0 1 1 80 176zM224 349.1c81.9-15 144-86.8 144-173.1C368 78.8 289.2 0 192 0S16 78.8 16 176c0 86.3 62.1 158.1 144 173.1l0 34.9-32 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l32 0 0 32c0 17.7 14.3 32 32 32s32-14.3 32-32l0-32 32 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-32 0 0-34.9z\"]\n};\nconst faPassport = {\n prefix: 'fas',\n iconName: 'passport',\n icon: [448, 512, [], \"f5ab\", \"M0 64C0 28.7 28.7 0 64 0L384 0c35.3 0 64 28.7 64 64l0 384c0 35.3-28.7 64-64 64L64 512c-35.3 0-64-28.7-64-64L0 64zM183 278.8c-27.9-13.2-48.4-39.4-53.7-70.8l39.1 0c1.6 30.4 7.7 53.8 14.6 70.8zm41.3 9.2l-.3 0-.3 0c-2.4-3.5-5.7-8.9-9.1-16.5c-6-13.6-12.4-34.3-14.2-63.5l47.1 0c-1.8 29.2-8.1 49.9-14.2 63.5c-3.4 7.6-6.7 13-9.1 16.5zm40.7-9.2c6.8-17.1 12.9-40.4 14.6-70.8l39.1 0c-5.3 31.4-25.8 57.6-53.7 70.8zM279.6 176c-1.6-30.4-7.7-53.8-14.6-70.8c27.9 13.2 48.4 39.4 53.7 70.8l-39.1 0zM223.7 96l.3 0 .3 0c2.4 3.5 5.7 8.9 9.1 16.5c6 13.6 12.4 34.3 14.2 63.5l-47.1 0c1.8-29.2 8.1-49.9 14.2-63.5c3.4-7.6 6.7-13 9.1-16.5zM183 105.2c-6.8 17.1-12.9 40.4-14.6 70.8l-39.1 0c5.3-31.4 25.8-57.6 53.7-70.8zM352 192A128 128 0 1 0 96 192a128 128 0 1 0 256 0zM112 384c-8.8 0-16 7.2-16 16s7.2 16 16 16l224 0c8.8 0 16-7.2 16-16s-7.2-16-16-16l-224 0z\"]\n};\nconst faThumbtackSlash = {\n prefix: 'fas',\n iconName: 'thumbtack-slash',\n icon: [640, 512, [\"thumb-tack-slash\"], \"e68f\", \"M38.8 5.1C28.4-3.1 13.3-1.2 5.1 9.2S-1.2 34.7 9.2 42.9l592 464c10.4 8.2 25.5 6.3 33.7-4.1s6.3-25.5-4.1-33.7L481.4 352c9.8-.4 18.9-5.3 24.6-13.3c6-8.3 7.7-19.1 4.4-28.8l-1-3c-13.8-41.5-42.8-74.8-79.5-94.7L418.5 64 448 64c17.7 0 32-14.3 32-32s-14.3-32-32-32L192 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l29.5 0-6.1 79.5L38.8 5.1zM324.9 352L177.1 235.6c-20.9 18.9-37.2 43.3-46.5 71.3l-1 3c-3.3 9.8-1.6 20.5 4.4 28.8s15.7 13.3 26 13.3l164.9 0zM288 384l0 96c0 17.7 14.3 32 32 32s32-14.3 32-32l0-96-64 0z\"]\n};\nconst faThumbTackSlash = faThumbtackSlash;\nconst faHeartPulse = {\n prefix: 'fas',\n iconName: 'heart-pulse',\n icon: [512, 512, [\"heartbeat\"], \"f21e\", \"M228.3 469.1L47.6 300.4c-4.2-3.9-8.2-8.1-11.9-12.4l87 0c22.6 0 43-13.6 51.7-34.5l10.5-25.2 49.3 109.5c3.8 8.5 12.1 14 21.4 14.1s17.8-5 22-13.3L320 253.7l1.7 3.4c9.5 19 28.9 31 50.1 31l104.5 0c-3.7 4.3-7.7 8.5-11.9 12.4L283.7 469.1c-7.5 7-17.4 10.9-27.7 10.9s-20.2-3.9-27.7-10.9zM503.7 240l-132 0c-3 0-5.8-1.7-7.2-4.4l-23.2-46.3c-4.1-8.1-12.4-13.3-21.5-13.3s-17.4 5.1-21.5 13.3l-41.4 82.8L205.9 158.2c-3.9-8.7-12.7-14.3-22.2-14.1s-18.1 5.9-21.8 14.8l-31.8 76.3c-1.2 3-4.2 4.9-7.4 4.9L16 240c-2.6 0-5 .4-7.3 1.1C3 225.2 0 208.2 0 190.9l0-5.8c0-69.9 50.5-129.5 119.4-141C165 36.5 211.4 51.4 244 84l12 12 12-12c32.6-32.6 79-47.5 124.6-39.9C461.5 55.6 512 115.2 512 185.1l0 5.8c0 16.9-2.8 33.5-8.3 49.1z\"]\n};\nconst faHeartbeat = faHeartPulse;\nconst faPeopleCarryBox = {\n prefix: 'fas',\n iconName: 'people-carry-box',\n icon: [640, 512, [\"people-carry\"], \"f4ce\", \"M80 48a48 48 0 1 1 96 0A48 48 0 1 1 80 48zm64 193.7l0 65.1 51 51c7.1 7.1 11.8 16.2 13.4 26.1l15.2 90.9c2.9 17.4-8.9 33.9-26.3 36.8s-33.9-8.9-36.8-26.3l-14.3-85.9L66.8 320C54.8 308 48 291.7 48 274.7l0-88.1c0-32.4 26.2-58.6 58.6-58.6c24.1 0 46.5 12 59.9 32l47.4 71.1 10.1 5 0-76.2c0-17.7 14.3-32 32-32l128 0c17.7 0 32 14.3 32 32l0 76.2 10.1-5L473.5 160c13.3-20 35.8-32 59.9-32c32.4 0 58.6 26.2 58.6 58.6l0 88.1c0 17-6.7 33.3-18.7 45.3l-79.4 79.4-14.3 85.9c-2.9 17.4-19.4 29.2-36.8 26.3s-29.2-19.4-26.3-36.8l15.2-90.9c1.6-9.9 6.3-19 13.4-26.1l51-51 0-65.1-19 28.5c-4.6 7-11 12.6-18.5 16.3l-59.6 29.8c-2.4 1.3-4.9 2.2-7.6 2.8c-2.6 .6-5.3 .9-7.9 .8l-126.7 0c-2.5 .1-5-.2-7.5-.7c-2.9-.6-5.6-1.6-8.1-3l-59.5-29.8c-7.5-3.7-13.8-9.4-18.5-16.3l-19-28.5zM2.3 468.1L50.1 348.6l49.2 49.2-37.6 94c-6.6 16.4-25.2 24.4-41.6 17.8S-4.3 484.5 2.3 468.1zM512 0a48 48 0 1 1 0 96 48 48 0 1 1 0-96zm77.9 348.6l47.8 119.5c6.6 16.4-1.4 35-17.8 41.6s-35-1.4-41.6-17.8l-37.6-94 49.2-49.2z\"]\n};\nconst faPeopleCarry = faPeopleCarryBox;\nconst faTemperatureHigh = {\n prefix: 'fas',\n iconName: 'temperature-high',\n icon: [512, 512, [], \"f769\", \"M416 64a32 32 0 1 1 0 64 32 32 0 1 1 0-64zm0 128A96 96 0 1 0 416 0a96 96 0 1 0 0 192zM96 112c0-26.5 21.5-48 48-48s48 21.5 48 48l0 164.5c0 17.3 7.1 31.9 15.3 42.5C217.8 332.6 224 349.5 224 368c0 44.2-35.8 80-80 80s-80-35.8-80-80c0-18.5 6.2-35.4 16.7-48.9C88.9 308.4 96 293.8 96 276.5L96 112zM144 0C82.1 0 32 50.2 32 112l0 164.4c0 .1-.1 .3-.2 .6c-.2 .6-.8 1.6-1.7 2.8C11.2 304.2 0 334.8 0 368c0 79.5 64.5 144 144 144s144-64.5 144-144c0-33.2-11.2-63.8-30.1-88.1c-.9-1.2-1.5-2.2-1.7-2.8c-.1-.3-.2-.5-.2-.6L256 112C256 50.2 205.9 0 144 0zm0 416c26.5 0 48-21.5 48-48c0-20.9-13.4-38.7-32-45.3L160 112c0-8.8-7.2-16-16-16s-16 7.2-16 16l0 210.7c-18.6 6.6-32 24.4-32 45.3c0 26.5 21.5 48 48 48z\"]\n};\nconst faMicrochip = {\n prefix: 'fas',\n iconName: 'microchip',\n icon: [512, 512, [], \"f2db\", \"M176 24c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 40c-35.3 0-64 28.7-64 64l-40 0c-13.3 0-24 10.7-24 24s10.7 24 24 24l40 0 0 56-40 0c-13.3 0-24 10.7-24 24s10.7 24 24 24l40 0 0 56-40 0c-13.3 0-24 10.7-24 24s10.7 24 24 24l40 0c0 35.3 28.7 64 64 64l0 40c0 13.3 10.7 24 24 24s24-10.7 24-24l0-40 56 0 0 40c0 13.3 10.7 24 24 24s24-10.7 24-24l0-40 56 0 0 40c0 13.3 10.7 24 24 24s24-10.7 24-24l0-40c35.3 0 64-28.7 64-64l40 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-40 0 0-56 40 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-40 0 0-56 40 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-40 0c0-35.3-28.7-64-64-64l0-40c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 40-56 0 0-40c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 40-56 0 0-40zM160 128l192 0c17.7 0 32 14.3 32 32l0 192c0 17.7-14.3 32-32 32l-192 0c-17.7 0-32-14.3-32-32l0-192c0-17.7 14.3-32 32-32zm192 32l-192 0 0 192 192 0 0-192z\"]\n};\nconst faCrown = {\n prefix: 'fas',\n iconName: 'crown',\n icon: [576, 512, [128081], \"f521\", \"M309 106c11.4-7 19-19.7 19-34c0-22.1-17.9-40-40-40s-40 17.9-40 40c0 14.4 7.6 27 19 34L209.7 220.6c-9.1 18.2-32.7 23.4-48.6 10.7L72 160c5-6.7 8-15 8-24c0-22.1-17.9-40-40-40S0 113.9 0 136s17.9 40 40 40c.2 0 .5 0 .7 0L86.4 427.4c5.5 30.4 32 52.6 63 52.6l277.2 0c30.9 0 57.4-22.1 63-52.6L535.3 176c.2 0 .5 0 .7 0c22.1 0 40-17.9 40-40s-17.9-40-40-40s-40 17.9-40 40c0 9 3 17.3 8 24l-89.1 71.3c-15.9 12.7-39.5 7.5-48.6-10.7L309 106z\"]\n};\nconst faWeightHanging = {\n prefix: 'fas',\n iconName: 'weight-hanging',\n icon: [512, 512, [], \"f5cd\", \"M224 96a32 32 0 1 1 64 0 32 32 0 1 1 -64 0zm122.5 32c3.5-10 5.5-20.8 5.5-32c0-53-43-96-96-96s-96 43-96 96c0 11.2 1.9 22 5.5 32L120 128c-22 0-41.2 15-46.6 36.4l-72 288c-3.6 14.3-.4 29.5 8.7 41.2S33.2 512 48 512l416 0c14.8 0 28.7-6.8 37.8-18.5s12.3-26.8 8.7-41.2l-72-288C433.2 143 414 128 392 128l-45.5 0z\"]\n};\nconst faXmarksLines = {\n prefix: 'fas',\n iconName: 'xmarks-lines',\n icon: [640, 512, [], \"e59a\", \"M32 32C14.3 32 0 46.3 0 64S14.3 96 32 96l576 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L32 32zm0 384c-17.7 0-32 14.3-32 32s14.3 32 32 32l576 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L32 416zM7 167c-9.4 9.4-9.4 24.6 0 33.9l55 55L7 311c-9.4 9.4-9.4 24.6 0 33.9s24.6 9.4 33.9 0l55-55 55 55c9.4 9.4 24.6 9.4 33.9 0s9.4-24.6 0-33.9l-55-55 55-55c9.4-9.4 9.4-24.6 0-33.9s-24.6-9.4-33.9 0l-55 55L41 167c-9.4-9.4-24.6-9.4-33.9 0zM265 167c-9.4-9.4-24.6-9.4-33.9 0s-9.4 24.6 0 33.9l55 55-55 55c-9.4 9.4-9.4 24.6 0 33.9s24.6 9.4 33.9 0l55-55 55 55c9.4 9.4 24.6 9.4 33.9 0s9.4-24.6 0-33.9l-55-55 55-55c9.4-9.4 9.4-24.6 0-33.9s-24.6-9.4-33.9 0l-55 55-55-55zM455 167c-9.4 9.4-9.4 24.6 0 33.9l55 55-55 55c-9.4 9.4-9.4 24.6 0 33.9s24.6 9.4 33.9 0l55-55 55 55c9.4 9.4 24.6 9.4 33.9 0s9.4-24.6 0-33.9l-55-55 55-55c9.4-9.4 9.4-24.6 0-33.9s-24.6-9.4-33.9 0l-55 55-55-55c-9.4-9.4-24.6-9.4-33.9 0z\"]\n};\nconst faFilePrescription = {\n prefix: 'fas',\n iconName: 'file-prescription',\n icon: [384, 512, [], \"f572\", \"M64 0C28.7 0 0 28.7 0 64L0 448c0 35.3 28.7 64 64 64l256 0c35.3 0 64-28.7 64-64l0-288-128 0c-17.7 0-32-14.3-32-32L224 0 64 0zM256 0l0 128 128 0L256 0zM104 196l72 0c33.1 0 60 26.9 60 60c0 25.5-15.9 47.2-38.3 55.9l43 40.3 33.8-31c8.1-7.5 20.8-6.9 28.3 1.2s6.9 20.8-1.2 28.3L270 379.7l31.7 29.7c8.1 7.6 8.5 20.2 .9 28.3s-20.2 8.5-28.3 .9l-33.9-31.8-34.9 32c-8.1 7.5-20.8 6.9-28.3-1.2s-6.9-20.8 1.2-28.3l32.6-29.9-64.8-60.8c-.9-.8-1.6-1.7-2.3-2.6l-20 0 0 44c0 11-9 20-20 20s-20-9-20-20l0-64 0-80c0-11 9-20 20-20zm72 80c11 0 20-9 20-20s-9-20-20-20l-52 0 0 40 52 0z\"]\n};\nconst faWeightScale = {\n prefix: 'fas',\n iconName: 'weight-scale',\n icon: [512, 512, [\"weight\"], \"f496\", \"M128 176a128 128 0 1 1 256 0 128 128 0 1 1 -256 0zM391.8 64C359.5 24.9 310.7 0 256 0S152.5 24.9 120.2 64L64 64C28.7 64 0 92.7 0 128L0 448c0 35.3 28.7 64 64 64l384 0c35.3 0 64-28.7 64-64l0-320c0-35.3-28.7-64-64-64l-56.2 0zM296 224c0-10.6-4.1-20.2-10.9-27.4l33.6-78.3c3.5-8.1-.3-17.5-8.4-21s-17.5 .3-21 8.4L255.7 184c-22 .1-39.7 18-39.7 40c0 22.1 17.9 40 40 40s40-17.9 40-40z\"]\n};\nconst faWeight = faWeightScale;\nconst faUserGroup = {\n prefix: 'fas',\n iconName: 'user-group',\n icon: [640, 512, [128101, \"user-friends\"], \"f500\", \"M96 128a128 128 0 1 1 256 0A128 128 0 1 1 96 128zM0 482.3C0 383.8 79.8 304 178.3 304l91.4 0C368.2 304 448 383.8 448 482.3c0 16.4-13.3 29.7-29.7 29.7L29.7 512C13.3 512 0 498.7 0 482.3zM609.3 512l-137.8 0c5.4-9.4 8.6-20.3 8.6-32l0-8c0-60.7-27.1-115.2-69.8-151.8c2.4-.1 4.7-.2 7.1-.2l61.4 0C567.8 320 640 392.2 640 481.3c0 17-13.8 30.7-30.7 30.7zM432 256c-31 0-59-12.6-79.3-32.9C372.4 196.5 384 163.6 384 128c0-26.8-6.6-52.1-18.3-74.3C384.3 40.1 407.2 32 432 32c61.9 0 112 50.1 112 112s-50.1 112-112 112z\"]\n};\nconst faUserFriends = faUserGroup;\nconst faArrowUpAZ = {\n prefix: 'fas',\n iconName: 'arrow-up-a-z',\n icon: [576, 512, [\"sort-alpha-up\"], \"f15e\", \"M183.6 42.4C177.5 35.8 169 32 160 32s-17.5 3.8-23.6 10.4l-88 96c-11.9 13-11.1 33.3 2 45.2s33.3 11.1 45.2-2L128 146.3 128 448c0 17.7 14.3 32 32 32s32-14.3 32-32l0-301.7 32.4 35.4c11.9 13 32.2 13.9 45.2 2s13.9-32.2 2-45.2l-88-96zM320 320c0 17.7 14.3 32 32 32l50.7 0-73.4 73.4c-9.2 9.2-11.9 22.9-6.9 34.9s16.6 19.8 29.6 19.8l128 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-50.7 0 73.4-73.4c9.2-9.2 11.9-22.9 6.9-34.9s-16.6-19.8-29.6-19.8l-128 0c-17.7 0-32 14.3-32 32zM416 32c-12.1 0-23.2 6.8-28.6 17.7l-64 128-16 32c-7.9 15.8-1.5 35 14.3 42.9s35 1.5 42.9-14.3l7.2-14.3 88.4 0 7.2 14.3c7.9 15.8 27.1 22.2 42.9 14.3s22.2-27.1 14.3-42.9l-16-32-64-128C439.2 38.8 428.1 32 416 32zM395.8 176L416 135.6 436.2 176l-40.4 0z\"]\n};\nconst faSortAlphaUp = faArrowUpAZ;\nconst faChessKnight = {\n prefix: 'fas',\n iconName: 'chess-knight',\n icon: [448, 512, [9822], \"f441\", \"M96 48L82.7 61.3C70.7 73.3 64 89.5 64 106.5l0 132.4c0 10.7 5.3 20.7 14.2 26.6l10.6 7c14.3 9.6 32.7 10.7 48.1 3l3.2-1.6c2.6-1.3 5-2.8 7.3-4.5l49.4-37c6.6-5 15.7-5 22.3 0c10.2 7.7 9.9 23.1-.7 30.3L90.4 350C73.9 361.3 64 380 64 400l320 0 28.9-159c2.1-11.3 3.1-22.8 3.1-34.3l0-14.7C416 86 330 0 224 0L83.8 0C72.9 0 64 8.9 64 19.8c0 7.5 4.2 14.3 10.9 17.7L96 48zm24 68a20 20 0 1 1 40 0 20 20 0 1 1 -40 0zM22.6 473.4c-4.2 4.2-6.6 10-6.6 16C16 501.9 26.1 512 38.6 512l370.7 0c12.5 0 22.6-10.1 22.6-22.6c0-6-2.4-11.8-6.6-16L384 432 64 432 22.6 473.4z\"]\n};\nconst faFaceLaughSquint = {\n prefix: 'fas',\n iconName: 'face-laugh-squint',\n icon: [512, 512, [\"laugh-squint\"], \"f59b\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM96.8 314.1c-3.8-13.7 7.4-26.1 21.6-26.1l275.2 0c14.2 0 25.5 12.4 21.6 26.1C396.2 382 332.1 432 256 432s-140.2-50-159.2-117.9zm36.7-199.4l89.9 47.9c10.7 5.7 10.7 21.1 0 26.8l-89.9 47.9c-7.9 4.2-17.5-1.5-17.5-10.5c0-2.8 1-5.5 2.8-7.6l36-43.2-36-43.2c-1.8-2.1-2.8-4.8-2.8-7.6c0-9 9.6-14.7 17.5-10.5zM396 125.1c0 2.8-1 5.5-2.8 7.6l-36 43.2 36 43.2c1.8 2.1 2.8 4.8 2.8 7.6c0 9-9.6 14.7-17.5 10.5l-89.9-47.9c-10.7-5.7-10.7-21.1 0-26.8l89.9-47.9c7.9-4.2 17.5 1.5 17.5 10.5z\"]\n};\nconst faLaughSquint = faFaceLaughSquint;\nconst faWheelchair = {\n prefix: 'fas',\n iconName: 'wheelchair',\n icon: [512, 512, [], \"f193\", \"M192 96a48 48 0 1 0 0-96 48 48 0 1 0 0 96zM120.5 247.2c12.4-4.7 18.7-18.5 14-30.9s-18.5-18.7-30.9-14C43.1 225.1 0 283.5 0 352c0 88.4 71.6 160 160 160c61.2 0 114.3-34.3 141.2-84.7c6.2-11.7 1.8-26.2-9.9-32.5s-26.2-1.8-32.5 9.9C240 440 202.8 464 160 464C98.1 464 48 413.9 48 352c0-47.9 30.1-88.8 72.5-104.8zM259.8 176l-1.9-9.7c-4.5-22.3-24-38.3-46.8-38.3c-30.1 0-52.7 27.5-46.8 57l23.1 115.5c6 29.9 32.2 51.4 62.8 51.4l5.1 0c.4 0 .8 0 1.3 0l94.1 0c6.7 0 12.6 4.1 15 10.4L402 459.2c6 16.1 23.8 24.6 40.1 19.1l48-16c16.8-5.6 25.8-23.7 20.2-40.5s-23.7-25.8-40.5-20.2l-18.7 6.2-25.5-68c-11.7-31.2-41.6-51.9-74.9-51.9l-68.5 0-9.6-48 63.4 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-76.2 0z\"]\n};\nconst faCircleArrowUp = {\n prefix: 'fas',\n iconName: 'circle-arrow-up',\n icon: [512, 512, [\"arrow-circle-up\"], \"f0aa\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM385 215c9.4 9.4 9.4 24.6 0 33.9s-24.6 9.4-33.9 0l-71-71L280 392c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-214.1-71 71c-9.4 9.4-24.6 9.4-33.9 0s-9.4-24.6 0-33.9L239 103c9.4-9.4 24.6-9.4 33.9 0L385 215z\"]\n};\nconst faArrowCircleUp = faCircleArrowUp;\nconst faToggleOn = {\n prefix: 'fas',\n iconName: 'toggle-on',\n icon: [576, 512, [], \"f205\", \"M192 64C86 64 0 150 0 256S86 448 192 448l192 0c106 0 192-86 192-192s-86-192-192-192L192 64zm192 96a96 96 0 1 1 0 192 96 96 0 1 1 0-192z\"]\n};\nconst faPersonWalking = {\n prefix: 'fas',\n iconName: 'person-walking',\n icon: [320, 512, [128694, \"walking\"], \"f554\", \"M160 48a48 48 0 1 1 96 0 48 48 0 1 1 -96 0zM126.5 199.3c-1 .4-1.9 .8-2.9 1.2l-8 3.5c-16.4 7.3-29 21.2-34.7 38.2l-2.6 7.8c-5.6 16.8-23.7 25.8-40.5 20.2s-25.8-23.7-20.2-40.5l2.6-7.8c11.4-34.1 36.6-61.9 69.4-76.5l8-3.5c20.8-9.2 43.3-14 66.1-14c44.6 0 84.8 26.8 101.9 67.9L281 232.7l21.4 10.7c15.8 7.9 22.2 27.1 14.3 42.9s-27.1 22.2-42.9 14.3L247 287.3c-10.3-5.2-18.4-13.8-22.8-24.5l-9.6-23-19.3 65.5 49.5 54c5.4 5.9 9.2 13 11.2 20.8l23 92.1c4.3 17.1-6.1 34.5-23.3 38.8s-34.5-6.1-38.8-23.3l-22-88.1-70.7-77.1c-14.8-16.1-20.3-38.6-14.7-59.7l16.9-63.5zM68.7 398l25-62.4c2.1 3 4.5 5.8 7 8.6l40.7 44.4-14.5 36.2c-2.4 6-6 11.5-10.6 16.1L54.6 502.6c-12.5 12.5-32.8 12.5-45.3 0s-12.5-32.8 0-45.3L68.7 398z\"]\n};\nconst faWalking = faPersonWalking;\nconst faL = {\n prefix: 'fas',\n iconName: 'l',\n icon: [320, 512, [108], \"4c\", \"M64 32c17.7 0 32 14.3 32 32l0 352 192 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L64 480c-17.7 0-32-14.3-32-32L32 64c0-17.7 14.3-32 32-32z\"]\n};\nconst faFire = {\n prefix: 'fas',\n iconName: 'fire',\n icon: [448, 512, [128293], \"f06d\", \"M159.3 5.4c7.8-7.3 19.9-7.2 27.7 .1c27.6 25.9 53.5 53.8 77.7 84c11-14.4 23.5-30.1 37-42.9c7.9-7.4 20.1-7.4 28 .1c34.6 33 63.9 76.6 84.5 118c20.3 40.8 33.8 82.5 33.8 111.9C448 404.2 348.2 512 224 512C98.4 512 0 404.1 0 276.5c0-38.4 17.8-85.3 45.4-131.7C73.3 97.7 112.7 48.6 159.3 5.4zM225.7 416c25.3 0 47.7-7 68.8-21c42.1-29.4 53.4-88.2 28.1-134.4c-4.5-9-16-9.6-22.5-2l-25.2 29.3c-6.6 7.6-18.5 7.4-24.7-.5c-16.5-21-46-58.5-62.8-79.8c-6.3-8-18.3-8.1-24.7-.1c-33.8 42.5-50.8 69.3-50.8 99.4C112 375.4 162.6 416 225.7 416z\"]\n};\nconst faBedPulse = {\n prefix: 'fas',\n iconName: 'bed-pulse',\n icon: [640, 512, [\"procedures\"], \"f487\", \"M483.2 9.6L524 64l92 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-104 0c-7.6 0-14.7-3.6-19.2-9.6L468.7 70.3l-47 99.9c-3.7 7.8-11.3 13.1-19.9 13.7s-16.9-3.4-21.7-10.6L339.2 112 216 112c-13.3 0-24-10.7-24-24s10.7-24 24-24l136 0c8 0 15.5 4 20 10.7l24.4 36.6 45.9-97.5C445.9 6.2 453.2 1 461.6 .1s16.6 2.7 21.6 9.5zM320 160l12.7 0 20.7 31.1c11.2 16.8 30.6 26.3 50.7 24.8s37.9-13.7 46.5-32L461.9 160l82.1 0c53 0 96 43 96 96l0 224c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-32-224 0-32 0L64 448l0 32c0 17.7-14.3 32-32 32s-32-14.3-32-32L0 96C0 78.3 14.3 64 32 64s32 14.3 32 32l0 256 224 0 0-160c0-17.7 14.3-32 32-32zm-144 0a80 80 0 1 1 0 160 80 80 0 1 1 0-160z\"]\n};\nconst faProcedures = faBedPulse;\nconst faShuttleSpace = {\n prefix: 'fas',\n iconName: 'shuttle-space',\n icon: [640, 512, [\"space-shuttle\"], \"f197\", \"M130 480c40.6 0 80.4-11 115.2-31.9L352 384l-224 0 0 96 2 0zM352 128L245.2 63.9C210.4 43 170.6 32 130 32l-2 0 0 96 224 0zM96 128l0-96L80 32C53.5 32 32 53.5 32 80l0 48 8 0c-22.1 0-40 17.9-40 40l0 16L0 328l0 16c0 22.1 17.9 40 40 40l-8 0 0 48c0 26.5 21.5 48 48 48l16 0 0-96 8 0c26.2 0 49.4-12.6 64-32l288 0c69.3 0 135-22.7 179.2-81.6c6.4-8.5 6.4-20.3 0-28.8C591 182.7 525.3 160 456 160l-288 0c-14.6-19.4-37.8-32-64-32l-8 0zM512 243.6l0 24.9c0 19.6-15.9 35.6-35.6 35.6c-2.5 0-4.4-2-4.4-4.4l0-87.1c0-2.5 2-4.4 4.4-4.4c19.6 0 35.6 15.9 35.6 35.6z\"]\n};\nconst faSpaceShuttle = faShuttleSpace;\nconst faFaceLaugh = {\n prefix: 'fas',\n iconName: 'face-laugh',\n icon: [512, 512, [\"laugh\"], \"f599\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM96.8 314.1c-3.8-13.7 7.4-26.1 21.6-26.1l275.2 0c14.2 0 25.5 12.4 21.6 26.1C396.2 382 332.1 432 256 432s-140.2-50-159.2-117.9zM144.4 192a32 32 0 1 1 64 0 32 32 0 1 1 -64 0zm192-32a32 32 0 1 1 0 64 32 32 0 1 1 0-64z\"]\n};\nconst faLaugh = faFaceLaugh;\nconst faFolderOpen = {\n prefix: 'fas',\n iconName: 'folder-open',\n icon: [576, 512, [128194, 128449, 61717], \"f07c\", \"M88.7 223.8L0 375.8 0 96C0 60.7 28.7 32 64 32l117.5 0c17 0 33.3 6.7 45.3 18.7l26.5 26.5c12 12 28.3 18.7 45.3 18.7L416 96c35.3 0 64 28.7 64 64l0 32-336 0c-22.8 0-43.8 12.1-55.3 31.8zm27.6 16.1C122.1 230 132.6 224 144 224l400 0c11.5 0 22 6.1 27.7 16.1s5.7 22.2-.1 32.1l-112 192C453.9 474 443.4 480 432 480L32 480c-11.5 0-22-6.1-27.7-16.1s-5.7-22.2 .1-32.1l112-192z\"]\n};\nconst faHeartCirclePlus = {\n prefix: 'fas',\n iconName: 'heart-circle-plus',\n icon: [576, 512, [], \"e500\", \"M47.6 300.4L228.3 469.1c7.5 7 17.4 10.9 27.7 10.9s20.2-3.9 27.7-10.9l2.6-2.4C267.2 438.6 256 404.6 256 368c0-97.2 78.8-176 176-176c28.3 0 55 6.7 78.7 18.5c.9-6.5 1.3-13 1.3-19.6l0-5.8c0-69.9-50.5-129.5-119.4-141C347 36.5 300.6 51.4 268 84L256 96 244 84c-32.6-32.6-79-47.5-124.6-39.9C50.5 55.6 0 115.2 0 185.1l0 5.8c0 41.5 17.2 81.2 47.6 109.5zM432 512a144 144 0 1 0 0-288 144 144 0 1 0 0 288zm16-208l0 48 48 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-48 0 0 48c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-48-48 0c-8.8 0-16-7.2-16-16s7.2-16 16-16l48 0 0-48c0-8.8 7.2-16 16-16s16 7.2 16 16z\"]\n};\nconst faCodeFork = {\n prefix: 'fas',\n iconName: 'code-fork',\n icon: [448, 512, [], \"e13b\", \"M80 104a24 24 0 1 0 0-48 24 24 0 1 0 0 48zm80-24c0 32.8-19.7 61-48 73.3l0 38.7c0 17.7 14.3 32 32 32l160 0c17.7 0 32-14.3 32-32l0-38.7C307.7 141 288 112.8 288 80c0-44.2 35.8-80 80-80s80 35.8 80 80c0 32.8-19.7 61-48 73.3l0 38.7c0 53-43 96-96 96l-48 0 0 70.7c28.3 12.3 48 40.5 48 73.3c0 44.2-35.8 80-80 80s-80-35.8-80-80c0-32.8 19.7-61 48-73.3l0-70.7-48 0c-53 0-96-43-96-96l0-38.7C19.7 141 0 112.8 0 80C0 35.8 35.8 0 80 0s80 35.8 80 80zm208 24a24 24 0 1 0 0-48 24 24 0 1 0 0 48zM248 432a24 24 0 1 0 -48 0 24 24 0 1 0 48 0z\"]\n};\nconst faCity = {\n prefix: 'fas',\n iconName: 'city',\n icon: [640, 512, [127961], \"f64f\", \"M480 48c0-26.5-21.5-48-48-48L336 0c-26.5 0-48 21.5-48 48l0 48-64 0 0-72c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 72-64 0 0-72c0-13.3-10.7-24-24-24S64 10.7 64 24l0 72L48 96C21.5 96 0 117.5 0 144l0 96L0 464c0 26.5 21.5 48 48 48l256 0 32 0 96 0 160 0c26.5 0 48-21.5 48-48l0-224c0-26.5-21.5-48-48-48l-112 0 0-144zm96 320l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16zM240 416l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16zM128 400c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32zM560 256c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16l32 0zM256 176l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16zM112 160c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16l32 0zM256 304c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32zM112 320l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16zm304-48l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16zM400 64c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16l32 0zm16 112l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16z\"]\n};\nconst faMicrophoneLines = {\n prefix: 'fas',\n iconName: 'microphone-lines',\n icon: [384, 512, [127897, \"microphone-alt\"], \"f3c9\", \"M96 96l0 160c0 53 43 96 96 96s96-43 96-96l-80 0c-8.8 0-16-7.2-16-16s7.2-16 16-16l80 0 0-32-80 0c-8.8 0-16-7.2-16-16s7.2-16 16-16l80 0 0-32-80 0c-8.8 0-16-7.2-16-16s7.2-16 16-16l80 0c0-53-43-96-96-96S96 43 96 96zM320 240l0 16c0 70.7-57.3 128-128 128s-128-57.3-128-128l0-40c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 40c0 89.1 66.2 162.7 152 174.4l0 33.6-48 0c-13.3 0-24 10.7-24 24s10.7 24 24 24l72 0 72 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-48 0 0-33.6c85.8-11.7 152-85.3 152-174.4l0-40c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 24z\"]\n};\nconst faMicrophoneAlt = faMicrophoneLines;\nconst faPepperHot = {\n prefix: 'fas',\n iconName: 'pepper-hot',\n icon: [512, 512, [127798], \"f816\", \"M428.3 3c11.6-6.4 26.2-2.3 32.6 9.3l4.8 8.7c19.3 34.7 19.8 75.7 3.4 110C495.8 159.6 512 197.9 512 240c0 18.5-3.1 36.3-8.9 52.8c-6.1 17.3-28.5 16.3-36.8-.1l-11.7-23.4c-4.1-8.1-12.4-13.3-21.5-13.3L360 256c-13.3 0-24-10.7-24-24l0-80c0-13.3-10.7-24-24-24l-17.1 0c-21.3 0-30-23.9-10.8-32.9C304.7 85.4 327.7 80 352 80c28.3 0 54.8 7.3 77.8 20.2c5.5-18.2 3.7-38.4-6-55.8L419 35.7c-6.4-11.6-2.3-26.2 9.3-32.6zM171.2 345.5L264 160l40 0 0 80c0 26.5 21.5 48 48 48l76.2 0 23.9 47.8C372.3 443.9 244.3 512 103.2 512l-58.8 0C19.9 512 0 492.1 0 467.6c0-20.8 14.5-38.8 34.8-43.3l49.8-11.1c37.6-8.4 69.5-33.2 86.7-67.7z\"]\n};\nconst faUnlock = {\n prefix: 'fas',\n iconName: 'unlock',\n icon: [448, 512, [128275], \"f09c\", \"M144 144c0-44.2 35.8-80 80-80c31.9 0 59.4 18.6 72.3 45.7c7.6 16 26.7 22.8 42.6 15.2s22.8-26.7 15.2-42.6C331 33.7 281.5 0 224 0C144.5 0 80 64.5 80 144l0 48-16 0c-35.3 0-64 28.7-64 64L0 448c0 35.3 28.7 64 64 64l320 0c35.3 0 64-28.7 64-64l0-192c0-35.3-28.7-64-64-64l-240 0 0-48z\"]\n};\nconst faColonSign = {\n prefix: 'fas',\n iconName: 'colon-sign',\n icon: [384, 512, [], \"e140\", \"M255 39.8c4.3-17.1-6.1-34.5-23.3-38.8S197.2 7.1 193 24.2L181.9 68.6C96.1 87.8 32 164.4 32 256c0 58.1 25.8 110.2 66.7 145.4L81 472.2c-4.3 17.1 6.1 34.5 23.3 38.8s34.5-6.1 38.8-23.3l13-52.1c9 3.4 18.4 6.2 28 8.2L177 472.2c-4.3 17.1 6.1 34.5 23.3 38.8s34.5-6.1 38.8-23.3l10.4-41.4c33.4-4.4 64.1-17.4 89.8-36.7c14.1-10.6 17-30.7 6.4-44.8s-30.7-17-44.8-6.4c-10.2 7.7-21.7 13.9-34 18.3L321 160c9.4-.3 18.5-4.7 24.6-12.8c10.6-14.1 7.8-34.2-6.4-44.8c-1.1-.8-2.2-1.6-3.3-2.4L351 39.8c4.3-17.1-6.1-34.5-23.3-38.8S293.2 7.1 289 24.2L277.2 71.5c-9.3-2.7-18.8-4.6-28.6-5.9L255 39.8zM163.2 143.3L117.3 326.8C103.9 306.5 96 282.2 96 256c0-48.7 27.2-91 67.2-112.7zm8.6 229.5l61.1-244.6c9.9 .7 19.5 2.5 28.7 5.3l-62 248.1c-9.7-1.9-19-4.8-27.8-8.8z\"]\n};\nconst faHeadset = {\n prefix: 'fas',\n iconName: 'headset',\n icon: [512, 512, [], \"f590\", \"M256 48C141.1 48 48 141.1 48 256l0 40c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-40C0 114.6 114.6 0 256 0S512 114.6 512 256l0 144.1c0 48.6-39.4 88-88.1 88L313.6 488c-8.3 14.3-23.8 24-41.6 24l-32 0c-26.5 0-48-21.5-48-48s21.5-48 48-48l32 0c17.8 0 33.3 9.7 41.6 24l110.4 .1c22.1 0 40-17.9 40-40L464 256c0-114.9-93.1-208-208-208zM144 208l16 0c17.7 0 32 14.3 32 32l0 112c0 17.7-14.3 32-32 32l-16 0c-35.3 0-64-28.7-64-64l0-48c0-35.3 28.7-64 64-64zm224 0c35.3 0 64 28.7 64 64l0 48c0 35.3-28.7 64-64 64l-16 0c-17.7 0-32-14.3-32-32l0-112c0-17.7 14.3-32 32-32l16 0z\"]\n};\nconst faStoreSlash = {\n prefix: 'fas',\n iconName: 'store-slash',\n icon: [640, 512, [], \"e071\", \"M38.8 5.1C28.4-3.1 13.3-1.2 5.1 9.2S-1.2 34.7 9.2 42.9l592 464c10.4 8.2 25.5 6.3 33.7-4.1s6.3-25.5-4.1-33.7l-86.8-68 0-17.1 0-131.4c-4 1-8 1.8-12.3 2.3c0 0 0 0-.1 0c-5.3 .7-10.7 1.1-16.2 1.1c-12.4 0-24.3-1.9-35.4-5.3l0 100.3L301.2 210.7c7-4.4 13.3-9.7 18.8-15.7c15.9 17.6 39.1 29 65.2 29c26.2 0 49.3-11.4 65.2-29c16 17.6 39.1 29 65.2 29c4.1 0 8.1-.3 12.1-.8c55.5-7.4 81.8-72.5 52.1-119.4L522.3 13.1C517.2 5 508.1 0 498.4 0L141.6 0c-9.7 0-18.8 5-23.9 13.1l-22.7 36L38.8 5.1zm73.4 218.1c4 .5 8.1 .8 12.1 .8c11 0 21.4-2 31-5.6L48.9 134.5c-6.1 40.6 19.5 82.8 63.3 88.7zM160 384l0-133.4c-11.2 3.5-23.2 5.4-35.6 5.4c-5.5 0-11-.4-16.3-1.1l-.1 0c-4.1-.6-8.1-1.3-12-2.3L96 384l0 64c0 35.3 28.7 64 64 64l320 0c12.9 0 24.8-3.8 34.9-10.3L365.5 384 160 384z\"]\n};\nconst faRoadCircleXmark = {\n prefix: 'fas',\n iconName: 'road-circle-xmark',\n icon: [640, 512, [], \"e566\", \"M213.2 32L288 32l0 64c0 17.7 14.3 32 32 32s32-14.3 32-32l0-64 74.8 0c27.1 0 51.3 17.1 60.3 42.6l42.7 120.6c-10.9-2.1-22.2-3.2-33.8-3.2c-59.5 0-112.1 29.6-144 74.8l0-42.8c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 64c0 17.7 14.3 32 32 32c2.3 0 4.6-.3 6.8-.7c-4.5 15.5-6.8 31.8-6.8 48.7c0 5.4 .2 10.7 .7 16l-.7 0c-17.7 0-32 14.3-32 32l0 64L86.6 480C56.5 480 32 455.5 32 425.4c0-6.2 1.1-12.4 3.1-18.2L152.9 74.6C162 49.1 186.1 32 213.2 32zM496 224a144 144 0 1 1 0 288 144 144 0 1 1 0-288zm22.6 144l36.7-36.7c6.2-6.2 6.2-16.4 0-22.6s-16.4-6.2-22.6 0L496 345.4l-36.7-36.7c-6.2-6.2-16.4-6.2-22.6 0s-6.2 16.4 0 22.6L473.4 368l-36.7 36.7c-6.2 6.2-6.2 16.4 0 22.6s16.4 6.2 22.6 0L496 390.6l36.7 36.7c6.2 6.2 16.4 6.2 22.6 0s6.2-16.4 0-22.6L518.6 368z\"]\n};\nconst faUserMinus = {\n prefix: 'fas',\n iconName: 'user-minus',\n icon: [640, 512, [], \"f503\", \"M96 128a128 128 0 1 1 256 0A128 128 0 1 1 96 128zM0 482.3C0 383.8 79.8 304 178.3 304l91.4 0C368.2 304 448 383.8 448 482.3c0 16.4-13.3 29.7-29.7 29.7L29.7 512C13.3 512 0 498.7 0 482.3zM472 200l144 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-144 0c-13.3 0-24-10.7-24-24s10.7-24 24-24z\"]\n};\nconst faMarsStrokeUp = {\n prefix: 'fas',\n iconName: 'mars-stroke-up',\n icon: [320, 512, [9896, \"mars-stroke-v\"], \"f22a\", \"M148.7 4.7c6.2-6.2 16.4-6.2 22.6 0l64 64c4.6 4.6 5.9 11.5 3.5 17.4s-8.3 9.9-14.8 9.9l-40 0 0 24 32 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-32 0 0 24c0 .6 0 1.2-.1 1.8c77 11.6 136.1 78 136.1 158.2c0 88.4-71.6 160-160 160S0 440.4 0 352c0-80.2 59.1-146.7 136.1-158.2c0-.6-.1-1.2-.1-1.8l0-24-32 0c-13.3 0-24-10.7-24-24s10.7-24 24-24l32 0 0-24L96 96c-6.5 0-12.3-3.9-14.8-9.9s-1.1-12.9 3.5-17.4l64-64zM256 352A96 96 0 1 0 64 352a96 96 0 1 0 192 0z\"]\n};\nconst faMarsStrokeV = faMarsStrokeUp;\nconst faChampagneGlasses = {\n prefix: 'fas',\n iconName: 'champagne-glasses',\n icon: [640, 512, [129346, \"glass-cheers\"], \"f79f\", \"M155.6 17.3C163 3 179.9-3.6 195 1.9L320 47.5l125-45.6c15.1-5.5 32 1.1 39.4 15.4l78.8 152.9c28.8 55.8 10.3 122.3-38.5 156.6L556.1 413l41-15c16.6-6 35 2.5 41 19.1s-2.5 35-19.1 41l-71.1 25.9L476.8 510c-16.6 6.1-35-2.5-41-19.1s2.5-35 19.1-41l41-15-31.3-86.2c-59.4 5.2-116.2-34-130-95.2L320 188.8l-14.6 64.7c-13.8 61.3-70.6 100.4-130 95.2l-31.3 86.2 41 15c16.6 6 25.2 24.4 19.1 41s-24.4 25.2-41 19.1L92.2 484.1 21.1 458.2c-16.6-6.1-25.2-24.4-19.1-41s24.4-25.2 41-19.1l41 15 31.3-86.2C66.5 292.5 48.1 226 76.9 170.2L155.6 17.3zm44 54.4l-27.2 52.8L261.6 157l13.1-57.9L199.6 71.7zm240.9 0L365.4 99.1 378.5 157l89.2-32.5L440.5 71.7z\"]\n};\nconst faGlassCheers = faChampagneGlasses;\nconst faClipboard = {\n prefix: 'fas',\n iconName: 'clipboard',\n icon: [384, 512, [128203], \"f328\", \"M192 0c-41.8 0-77.4 26.7-90.5 64L64 64C28.7 64 0 92.7 0 128L0 448c0 35.3 28.7 64 64 64l256 0c35.3 0 64-28.7 64-64l0-320c0-35.3-28.7-64-64-64l-37.5 0C269.4 26.7 233.8 0 192 0zm0 64a32 32 0 1 1 0 64 32 32 0 1 1 0-64zM112 192l160 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-160 0c-8.8 0-16-7.2-16-16s7.2-16 16-16z\"]\n};\nconst faHouseCircleExclamation = {\n prefix: 'fas',\n iconName: 'house-circle-exclamation',\n icon: [640, 512, [], \"e50a\", \"M320.7 352c8.1-89.7 83.5-160 175.3-160c8.9 0 17.6 .7 26.1 1.9L309.5 7c-6-5-14-7-21-7s-15 1-22 8L10 231.5c-7 7-10 15-10 24c0 18 14 32.1 32 32.1l32 0 0 69.7c-.1 .9-.1 1.8-.1 2.8l0 112c0 22.1 17.9 40 40 40l16 0c1.2 0 2.4-.1 3.6-.2c1.5 .1 3 .2 4.5 .2l31.9 0 24 0c22.1 0 40-17.9 40-40l0-24 0-64c0-17.7 14.3-32 32-32l64 0 .7 0zM496 512a144 144 0 1 0 0-288 144 144 0 1 0 0 288zm0-96a24 24 0 1 1 0 48 24 24 0 1 1 0-48zm0-144c8.8 0 16 7.2 16 16l0 80c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-80c0-8.8 7.2-16 16-16z\"]\n};\nconst faFileArrowUp = {\n prefix: 'fas',\n iconName: 'file-arrow-up',\n icon: [384, 512, [\"file-upload\"], \"f574\", \"M64 0C28.7 0 0 28.7 0 64L0 448c0 35.3 28.7 64 64 64l256 0c35.3 0 64-28.7 64-64l0-288-128 0c-17.7 0-32-14.3-32-32L224 0 64 0zM256 0l0 128 128 0L256 0zM216 408c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-102.1-31 31c-9.4 9.4-24.6 9.4-33.9 0s-9.4-24.6 0-33.9l72-72c9.4-9.4 24.6-9.4 33.9 0l72 72c9.4 9.4 9.4 24.6 0 33.9s-24.6 9.4-33.9 0l-31-31L216 408z\"]\n};\nconst faFileUpload = faFileArrowUp;\nconst faWifi = {\n prefix: 'fas',\n iconName: 'wifi',\n icon: [640, 512, [\"wifi-3\", \"wifi-strong\"], \"f1eb\", \"M54.2 202.9C123.2 136.7 216.8 96 320 96s196.8 40.7 265.8 106.9c12.8 12.2 33 11.8 45.2-.9s11.8-33-.9-45.2C549.7 79.5 440.4 32 320 32S90.3 79.5 9.8 156.7C-2.9 169-3.3 189.2 8.9 202s32.5 13.2 45.2 .9zM320 256c56.8 0 108.6 21.1 148.2 56c13.3 11.7 33.5 10.4 45.2-2.8s10.4-33.5-2.8-45.2C459.8 219.2 393 192 320 192s-139.8 27.2-190.5 72c-13.3 11.7-14.5 31.9-2.8 45.2s31.9 14.5 45.2 2.8c39.5-34.9 91.3-56 148.2-56zm64 160a64 64 0 1 0 -128 0 64 64 0 1 0 128 0z\"]\n};\nconst faWifi3 = faWifi;\nconst faWifiStrong = faWifi;\nconst faBath = {\n prefix: 'fas',\n iconName: 'bath',\n icon: [512, 512, [128705, \"bathtub\"], \"f2cd\", \"M96 77.3c0-7.3 5.9-13.3 13.3-13.3c3.5 0 6.9 1.4 9.4 3.9l14.9 14.9C130 91.8 128 101.7 128 112c0 19.9 7.2 38 19.2 52c-5.3 9.2-4 21.1 3.8 29c9.4 9.4 24.6 9.4 33.9 0L289 89c9.4-9.4 9.4-24.6 0-33.9c-7.9-7.9-19.8-9.1-29-3.8C246 39.2 227.9 32 208 32c-10.3 0-20.2 2-29.2 5.5L163.9 22.6C149.4 8.1 129.7 0 109.3 0C66.6 0 32 34.6 32 77.3L32 256c-17.7 0-32 14.3-32 32s14.3 32 32 32l448 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L96 256 96 77.3zM32 352l0 16c0 28.4 12.4 54 32 71.6L64 480c0 17.7 14.3 32 32 32s32-14.3 32-32l0-16 256 0 0 16c0 17.7 14.3 32 32 32s32-14.3 32-32l0-40.4c19.6-17.6 32-43.1 32-71.6l0-16L32 352z\"]\n};\nconst faBathtub = faBath;\nconst faUnderline = {\n prefix: 'fas',\n iconName: 'underline',\n icon: [448, 512, [], \"f0cd\", \"M16 64c0-17.7 14.3-32 32-32l96 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-16 0 0 128c0 53 43 96 96 96s96-43 96-96l0-128-16 0c-17.7 0-32-14.3-32-32s14.3-32 32-32l96 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-16 0 0 128c0 88.4-71.6 160-160 160s-160-71.6-160-160L64 96 48 96C30.3 96 16 81.7 16 64zM0 448c0-17.7 14.3-32 32-32l384 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L32 480c-17.7 0-32-14.3-32-32z\"]\n};\nconst faUserPen = {\n prefix: 'fas',\n iconName: 'user-pen',\n icon: [640, 512, [\"user-edit\"], \"f4ff\", \"M224 256A128 128 0 1 0 224 0a128 128 0 1 0 0 256zm-45.7 48C79.8 304 0 383.8 0 482.3C0 498.7 13.3 512 29.7 512l293.1 0c-3.1-8.8-3.7-18.4-1.4-27.8l15-60.1c2.8-11.3 8.6-21.5 16.8-29.7l40.3-40.3c-32.1-31-75.7-50.1-123.9-50.1l-91.4 0zm435.5-68.3c-15.6-15.6-40.9-15.6-56.6 0l-29.4 29.4 71 71 29.4-29.4c15.6-15.6 15.6-40.9 0-56.6l-14.4-14.4zM375.9 417c-4.1 4.1-7 9.2-8.4 14.9l-15 60.1c-1.4 5.5 .2 11.2 4.2 15.2s9.7 5.6 15.2 4.2l60.1-15c5.6-1.4 10.8-4.3 14.9-8.4L576.1 358.7l-71-71L375.9 417z\"]\n};\nconst faUserEdit = faUserPen;\nconst faSignature = {\n prefix: 'fas',\n iconName: 'signature',\n icon: [640, 512, [], \"f5b7\", \"M192 128c0-17.7 14.3-32 32-32s32 14.3 32 32l0 7.8c0 27.7-2.4 55.3-7.1 82.5l-84.4 25.3c-40.6 12.2-68.4 49.6-68.4 92l0 71.9c0 40 32.5 72.5 72.5 72.5c26 0 50-13.9 62.9-36.5l13.9-24.3c26.8-47 46.5-97.7 58.4-150.5l94.4-28.3-12.5 37.5c-3.3 9.8-1.6 20.5 4.4 28.8s15.7 13.3 26 13.3l128 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-83.6 0 18-53.9c3.8-11.3 .9-23.8-7.4-32.4s-20.7-11.8-32.2-8.4L316.4 198.1c2.4-20.7 3.6-41.4 3.6-62.3l0-7.8c0-53-43-96-96-96s-96 43-96 96l0 32c0 17.7 14.3 32 32 32s32-14.3 32-32l0-32zm-9.2 177l49-14.7c-10.4 33.8-24.5 66.4-42.1 97.2l-13.9 24.3c-1.5 2.6-4.3 4.3-7.4 4.3c-4.7 0-8.5-3.8-8.5-8.5l0-71.9c0-14.1 9.3-26.6 22.8-30.7zM24 368c-13.3 0-24 10.7-24 24s10.7 24 24 24l40.3 0c-.2-2.8-.3-5.6-.3-8.5L64 368l-40 0zm592 48c13.3 0 24-10.7 24-24s-10.7-24-24-24l-310.1 0c-6.7 16.3-14.2 32.3-22.3 48L616 416z\"]\n};\nconst faStroopwafel = {\n prefix: 'fas',\n iconName: 'stroopwafel',\n icon: [512, 512, [], \"f551\", \"M0 256a256 256 0 1 1 512 0A256 256 0 1 1 0 256zM312.6 63.7c-6.2-6.2-16.4-6.2-22.6 0L256 97.6 222.1 63.7c-6.2-6.2-16.4-6.2-22.6 0s-6.2 16.4 0 22.6l33.9 33.9-45.3 45.3-56.6-56.6c-6.2-6.2-16.4-6.2-22.6 0s-6.2 16.4 0 22.6l56.6 56.6-45.3 45.3L86.3 199.4c-6.2-6.2-16.4-6.2-22.6 0s-6.2 16.4 0 22.6L97.6 256 63.7 289.9c-6.2 6.2-6.2 16.4 0 22.6s16.4 6.2 22.6 0l33.9-33.9 45.3 45.3-56.6 56.6c-6.2 6.2-6.2 16.4 0 22.6s16.4 6.2 22.6 0l56.6-56.6 45.3 45.3-33.9 33.9c-6.2 6.2-6.2 16.4 0 22.6s16.4 6.2 22.6 0L256 414.4l33.9 33.9c6.2 6.2 16.4 6.2 22.6 0s6.2-16.4 0-22.6l-33.9-33.9 45.3-45.3 56.6 56.6c6.2 6.2 16.4 6.2 22.6 0s6.2-16.4 0-22.6l-56.6-56.6 45.3-45.3 33.9 33.9c6.2 6.2 16.4 6.2 22.6 0s6.2-16.4 0-22.6L414.4 256l33.9-33.9c6.2-6.2 6.2-16.4 0-22.6s-16.4-6.2-22.6 0l-33.9 33.9-45.3-45.3 56.6-56.6c6.2-6.2 6.2-16.4 0-22.6s-16.4-6.2-22.6 0l-56.6 56.6-45.3-45.3 33.9-33.9c6.2-6.2 6.2-16.4 0-22.6zM142.9 256l45.3-45.3L233.4 256l-45.3 45.3L142.9 256zm67.9 67.9L256 278.6l45.3 45.3L256 369.1l-45.3-45.3zM278.6 256l45.3-45.3L369.1 256l-45.3 45.3L278.6 256zm22.6-67.9L256 233.4l-45.3-45.3L256 142.9l45.3 45.3z\"]\n};\nconst faBold = {\n prefix: 'fas',\n iconName: 'bold',\n icon: [384, 512, [], \"f032\", \"M0 64C0 46.3 14.3 32 32 32l48 0 16 0 128 0c70.7 0 128 57.3 128 128c0 31.3-11.3 60.1-30 82.3c37.1 22.4 62 63.1 62 109.7c0 70.7-57.3 128-128 128L96 480l-16 0-48 0c-17.7 0-32-14.3-32-32s14.3-32 32-32l16 0 0-160L48 96 32 96C14.3 96 0 81.7 0 64zM224 224c35.3 0 64-28.7 64-64s-28.7-64-64-64L112 96l0 128 112 0zM112 288l0 128 144 0c35.3 0 64-28.7 64-64s-28.7-64-64-64l-32 0-112 0z\"]\n};\nconst faAnchorLock = {\n prefix: 'fas',\n iconName: 'anchor-lock',\n icon: [640, 512, [], \"e4ad\", \"M320 96a32 32 0 1 1 -64 0 32 32 0 1 1 64 0zm21.1 80C367 158.8 384 129.4 384 96c0-53-43-96-96-96s-96 43-96 96c0 33.4 17 62.8 42.9 80L224 176c-17.7 0-32 14.3-32 32s14.3 32 32 32l32 0 0 208-48 0c-53 0-96-43-96-96l0-6.1 7 7c9.4 9.4 24.6 9.4 33.9 0s9.4-24.6 0-33.9L97 263c-9.4-9.4-24.6-9.4-33.9 0L7 319c-9.4 9.4-9.4 24.6 0 33.9s24.6 9.4 33.9 0l7-7 0 6.1c0 88.4 71.6 160 160 160l80 0 80 0c8 0 15.9-.6 23.6-1.7c-4.8-9-7.6-19.3-7.6-30.3l0-33.3c-5.2 .9-10.5 1.3-16 1.3l-48 0 0-208 32 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-10.9 0zM528 240c17.7 0 32 14.3 32 32l0 48-64 0 0-48c0-17.7 14.3-32 32-32zm-80 32l0 48c-17.7 0-32 14.3-32 32l0 128c0 17.7 14.3 32 32 32l160 0c17.7 0 32-14.3 32-32l0-128c0-17.7-14.3-32-32-32l0-48c0-44.2-35.8-80-80-80s-80 35.8-80 80z\"]\n};\nconst faBuildingNgo = {\n prefix: 'fas',\n iconName: 'building-ngo',\n icon: [384, 512, [], \"e4d7\", \"M48 0C21.5 0 0 21.5 0 48L0 464c0 26.5 21.5 48 48 48l96 0 0-80c0-26.5 21.5-48 48-48s48 21.5 48 48l0 80 96 0c26.5 0 48-21.5 48-48l0-416c0-26.5-21.5-48-48-48L48 0zM64 240c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32zm112-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16zm80 16c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32zM168 64l48 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-32 0 0 64 16 0 0-16c0-8.8 7.2-16 16-16s16 7.2 16 16l0 24c0 13.3-10.7 24-24 24l-32 0c-13.3 0-24-10.7-24-24l0-88c0-8.8 7.2-16 16-16zM304 96c-8.8 0-16 7.2-16 16l0 32c0 8.8 7.2 16 16 16s16-7.2 16-16l0-32c0-8.8-7.2-16-16-16zm-48 16c0-26.5 21.5-48 48-48s48 21.5 48 48l0 32c0 26.5-21.5 48-48 48s-48-21.5-48-48l0-32zM61.3 71.1l34.7 52L96 80c0-8.8 7.2-16 16-16s16 7.2 16 16l0 96c0 7.1-4.6 13.3-11.4 15.3s-14-.6-17.9-6.4L64 132.8 64 176c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-96c0-7.1 4.6-13.3 11.4-15.3s14 .6 17.9 6.4z\"]\n};\nconst faManatSign = {\n prefix: 'fas',\n iconName: 'manat-sign',\n icon: [384, 512, [], \"e1d5\", \"M192 32c-17.7 0-32 14.3-32 32l0 34.7C69.2 113.9 0 192.9 0 288L0 448c0 17.7 14.3 32 32 32s32-14.3 32-32l0-160c0-59.6 40.8-109.8 96-124l0 284c0 17.7 14.3 32 32 32s32-14.3 32-32l0-284c55.2 14.2 96 64.3 96 124l0 160c0 17.7 14.3 32 32 32s32-14.3 32-32l0-160c0-95.1-69.2-174.1-160-189.3L224 64c0-17.7-14.3-32-32-32z\"]\n};\nconst faNotEqual = {\n prefix: 'fas',\n iconName: 'not-equal',\n icon: [448, 512, [], \"f53e\", \"M369.8 37.4c14.7 9.8 18.7 29.7 8.9 44.4L337.1 144l62.9 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-105.5 0-64 96L400 304c17.7 0 32 14.3 32 32s-14.3 32-32 32l-212.2 0-65.2 97.7c-9.8 14.7-29.7 18.7-44.4 8.9s-18.7-29.7-8.9-44.4L110.9 368 48 368c-17.7 0-32-14.3-32-32s14.3-32 32-32l105.5 0 64-96L48 208c-17.7 0-32-14.3-32-32s14.3-32 32-32l212.2 0 65.2-97.7c9.8-14.7 29.7-18.7 44.4-8.9z\"]\n};\nconst faBorderTopLeft = {\n prefix: 'fas',\n iconName: 'border-top-left',\n icon: [448, 512, [\"border-style\"], \"f853\", \"M0 448c0 17.7 14.3 32 32 32s32-14.3 32-32l0-336c0-8.8 7.2-16 16-16l336 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L80 32C35.8 32 0 67.8 0 112L0 448zm160 0a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zm192 0a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zm-96 0a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zm192 0a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zM416 288a32 32 0 1 0 0-64 32 32 0 1 0 0 64zm0 32a32 32 0 1 0 0 64 32 32 0 1 0 0-64zm0-128a32 32 0 1 0 0-64 32 32 0 1 0 0 64z\"]\n};\nconst faBorderStyle = faBorderTopLeft;\nconst faMapLocationDot = {\n prefix: 'fas',\n iconName: 'map-location-dot',\n icon: [576, 512, [\"map-marked-alt\"], \"f5a0\", \"M408 120c0 54.6-73.1 151.9-105.2 192c-7.7 9.6-22 9.6-29.6 0C241.1 271.9 168 174.6 168 120C168 53.7 221.7 0 288 0s120 53.7 120 120zm8 80.4c3.5-6.9 6.7-13.8 9.6-20.6c.5-1.2 1-2.5 1.5-3.7l116-46.4C558.9 123.4 576 135 576 152l0 270.8c0 9.8-6 18.6-15.1 22.3L416 503l0-302.6zM137.6 138.3c2.4 14.1 7.2 28.3 12.8 41.5c2.9 6.8 6.1 13.7 9.6 20.6l0 251.4L32.9 502.7C17.1 509 0 497.4 0 480.4L0 209.6c0-9.8 6-18.6 15.1-22.3l122.6-49zM327.8 332c13.9-17.4 35.7-45.7 56.2-77l0 249.3L192 449.4 192 255c20.5 31.3 42.3 59.6 56.2 77c20.5 25.6 59.1 25.6 79.6 0zM288 152a40 40 0 1 0 0-80 40 40 0 1 0 0 80z\"]\n};\nconst faMapMarkedAlt = faMapLocationDot;\nconst faJedi = {\n prefix: 'fas',\n iconName: 'jedi',\n icon: [576, 512, [], \"f669\", \"M246 315.7l-21.2-31.9c-2.1-3.2-1.7-7.4 1-10.1s6.9-3.1 10.1-1l29.5 19.7c2.1 1.4 4.9 0 5-2.6L279.7 8c.1-4.5 3.8-8 8.3-8s8.1 3.5 8.3 8l9.4 281.9c.1 2.5 2.9 3.9 5 2.6l29.5-19.7c3.2-2.1 7.4-1.7 10.1 1s3.1 6.9 1 10.1L330 315.7c-1.3 1.9-.2 4.5 2 4.9l37.6 7.5c3.7 .7 6.4 4 6.4 7.8s-2.7 7.1-6.4 7.8L332 351.4c-2.2 .4-3.3 3-2 4.9l21.2 31.9c2.1 3.2 1.7 7.4-1 10.1s-6.9 3.1-10.1 1l-26.3-17.6c-2.2-1.4-5.1 .2-5 2.8l2.1 61.5C370.6 435.2 416 382.9 416 320c0-37-15.7-70.4-40.8-93.7c-7-6.5-6.5-18.6 1-24.4C410.1 175.5 432 134.3 432 88c0-16.8-2.9-33-8.2-48c-4.6-13 10.2-30 21.4-22c53.5 38 92.7 94.8 107.8 160.7c.5 2.1-.2 4.3-1.7 5.9l-28.4 28.4c-4 4-1.2 10.9 4.5 10.9l26 0c3.4 0 6.2 2.6 6.3 6c.1 3.3 .2 6.6 .2 10c0 17.5-1.7 34.7-4.8 51.3c-.2 1.2-.9 2.4-1.7 3.3l-46.5 46.5c-4 4-1.2 10.9 4.5 10.9l14.6 0c4.6 0 7.7 4.8 5.7 9C487.2 450.5 394.8 512 288 512S88.8 450.5 44.3 361c-2.1-4.2 1-9 5.7-9l14.6 0c5.7 0 8.6-6.9 4.5-10.9L22.6 294.6c-.9-.9-1.5-2-1.7-3.3C17.7 274.7 16 257.5 16 240c0-3.3 .1-6.7 .2-10c.1-3.4 2.9-6 6.3-6l26 0c5.7 0 8.6-6.9 4.5-10.9L24.6 184.6c-1.5-1.5-2.2-3.8-1.7-5.9C38.1 112.8 77.3 56 130.8 18c11.3-8 26 8.9 21.4 22c-5.3 15-8.2 31.2-8.2 48c0 46.3 21.9 87.5 55.8 113.9c7.5 5.8 8 17.9 1 24.4C175.7 249.6 160 283 160 320c0 62.9 45.4 115.2 105.1 126l2.1-61.5c.1-2.6-2.8-4.2-5-2.8l-26.3 17.6c-3.2 2.1-7.4 1.7-10.1-1s-3.1-6.9-1-10.1L246 356.3c1.3-1.9 .2-4.5-2-4.9l-37.6-7.5c-3.7-.7-6.4-4-6.4-7.8s2.7-7.1 6.4-7.8l37.6-7.5c2.2-.4 3.3-3 2-4.9z\"]\n};\nconst faSquarePollVertical = {\n prefix: 'fas',\n iconName: 'square-poll-vertical',\n icon: [448, 512, [\"poll\"], \"f681\", \"M64 32C28.7 32 0 60.7 0 96L0 416c0 35.3 28.7 64 64 64l320 0c35.3 0 64-28.7 64-64l0-320c0-35.3-28.7-64-64-64L64 32zm64 192c17.7 0 32 14.3 32 32l0 96c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-96c0-17.7 14.3-32 32-32zm64-64c0-17.7 14.3-32 32-32s32 14.3 32 32l0 192c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-192zM320 288c17.7 0 32 14.3 32 32l0 32c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-32c0-17.7 14.3-32 32-32z\"]\n};\nconst faPoll = faSquarePollVertical;\nconst faMugHot = {\n prefix: 'fas',\n iconName: 'mug-hot',\n icon: [512, 512, [9749], \"f7b6\", \"M88 0C74.7 0 64 10.7 64 24c0 38.9 23.4 59.4 39.1 73.1l1.1 1C120.5 112.3 128 119.9 128 136c0 13.3 10.7 24 24 24s24-10.7 24-24c0-38.9-23.4-59.4-39.1-73.1l-1.1-1C119.5 47.7 112 40.1 112 24c0-13.3-10.7-24-24-24zM32 192c-17.7 0-32 14.3-32 32L0 416c0 53 43 96 96 96l192 0c53 0 96-43 96-96l16 0c61.9 0 112-50.1 112-112s-50.1-112-112-112l-48 0L32 192zm352 64l16 0c26.5 0 48 21.5 48 48s-21.5 48-48 48l-16 0 0-96zM224 24c0-13.3-10.7-24-24-24s-24 10.7-24 24c0 38.9 23.4 59.4 39.1 73.1l1.1 1C232.5 112.3 240 119.9 240 136c0 13.3 10.7 24 24 24s24-10.7 24-24c0-38.9-23.4-59.4-39.1-73.1l-1.1-1C231.5 47.7 224 40.1 224 24z\"]\n};\nconst faCarBattery = {\n prefix: 'fas',\n iconName: 'car-battery',\n icon: [512, 512, [\"battery-car\"], \"f5df\", \"M80 96c0-17.7 14.3-32 32-32l64 0c17.7 0 32 14.3 32 32l96 0c0-17.7 14.3-32 32-32l64 0c17.7 0 32 14.3 32 32l16 0c35.3 0 64 28.7 64 64l0 224c0 35.3-28.7 64-64 64L64 448c-35.3 0-64-28.7-64-64L0 160c0-35.3 28.7-64 64-64l16 0zm304 96c0-8.8-7.2-16-16-16s-16 7.2-16 16l0 32-32 0c-8.8 0-16 7.2-16 16s7.2 16 16 16l32 0 0 32c0 8.8 7.2 16 16 16s16-7.2 16-16l0-32 32 0c8.8 0 16-7.2 16-16s-7.2-16-16-16l-32 0 0-32zM80 240c0 8.8 7.2 16 16 16l96 0c8.8 0 16-7.2 16-16s-7.2-16-16-16l-96 0c-8.8 0-16 7.2-16 16z\"]\n};\nconst faBatteryCar = faCarBattery;\nconst faGift = {\n prefix: 'fas',\n iconName: 'gift',\n icon: [512, 512, [127873], \"f06b\", \"M190.5 68.8L225.3 128l-1.3 0-72 0c-22.1 0-40-17.9-40-40s17.9-40 40-40l2.2 0c14.9 0 28.8 7.9 36.3 20.8zM64 88c0 14.4 3.5 28 9.6 40L32 128c-17.7 0-32 14.3-32 32l0 64c0 17.7 14.3 32 32 32l448 0c17.7 0 32-14.3 32-32l0-64c0-17.7-14.3-32-32-32l-41.6 0c6.1-12 9.6-25.6 9.6-40c0-48.6-39.4-88-88-88l-2.2 0c-31.9 0-61.5 16.9-77.7 44.4L256 85.5l-24.1-41C215.7 16.9 186.1 0 154.2 0L152 0C103.4 0 64 39.4 64 88zm336 0c0 22.1-17.9 40-40 40l-72 0-1.3 0 34.8-59.2C329.1 55.9 342.9 48 357.8 48l2.2 0c22.1 0 40 17.9 40 40zM32 288l0 176c0 26.5 21.5 48 48 48l144 0 0-224L32 288zM288 512l144 0c26.5 0 48-21.5 48-48l0-176-192 0 0 224z\"]\n};\nconst faDiceTwo = {\n prefix: 'fas',\n iconName: 'dice-two',\n icon: [448, 512, [9857], \"f528\", \"M0 96C0 60.7 28.7 32 64 32l320 0c35.3 0 64 28.7 64 64l0 320c0 35.3-28.7 64-64 64L64 480c-35.3 0-64-28.7-64-64L0 96zM352 352a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zM128 192a32 32 0 1 0 0-64 32 32 0 1 0 0 64z\"]\n};\nconst faChessQueen = {\n prefix: 'fas',\n iconName: 'chess-queen',\n icon: [512, 512, [9819], \"f445\", \"M256 0a56 56 0 1 1 0 112A56 56 0 1 1 256 0zM134.1 143.8c3.3-13 15-23.8 30.2-23.8c12.3 0 22.6 7.2 27.7 17c12 23.2 36.2 39 64 39s52-15.8 64-39c5.1-9.8 15.4-17 27.7-17c15.3 0 27 10.8 30.2 23.8c7 27.8 32.2 48.3 62.1 48.3c10.8 0 21-2.7 29.8-7.4c8.4-4.4 18.9-4.5 27.6 .9c13 8 17.1 25 9.2 38L399.7 400 384 400l-40.4 0-175.1 0L128 400l-15.7 0L5.4 223.6c-7.9-13-3.8-30 9.2-38c8.7-5.3 19.2-5.3 27.6-.9c8.9 4.7 19 7.4 29.8 7.4c29.9 0 55.1-20.5 62.1-48.3zM256 224s0 0 0 0s0 0 0 0s0 0 0 0zM112 432l288 0 41.4 41.4c4.2 4.2 6.6 10 6.6 16c0 12.5-10.1 22.6-22.6 22.6L86.6 512C74.1 512 64 501.9 64 489.4c0-6 2.4-11.8 6.6-16L112 432z\"]\n};\nconst faGlasses = {\n prefix: 'fas',\n iconName: 'glasses',\n icon: [576, 512, [], \"f530\", \"M118.6 80c-11.5 0-21.4 7.9-24 19.1L57 260.3c20.5-6.2 48.3-12.3 78.7-12.3c32.3 0 61.8 6.9 82.8 13.5c10.6 3.3 19.3 6.7 25.4 9.2c3.1 1.3 5.5 2.4 7.3 3.2c.9 .4 1.6 .7 2.1 1l.6 .3 .2 .1c0 0 .1 0 .1 0c0 0 0 0 0 0s0 0 0 0L247.9 288s0 0 0 0l6.3-12.7c5.8 2.9 10.4 7.3 13.5 12.7l40.6 0c3.1-5.3 7.7-9.8 13.5-12.7l6.3 12.7s0 0 0 0c-6.3-12.7-6.3-12.7-6.3-12.7s0 0 0 0s0 0 0 0c0 0 .1 0 .1 0l.2-.1 .6-.3c.5-.2 1.2-.6 2.1-1c1.8-.8 4.2-1.9 7.3-3.2c6.1-2.6 14.8-5.9 25.4-9.2c21-6.6 50.4-13.5 82.8-13.5c30.4 0 58.2 6.1 78.7 12.3L481.4 99.1c-2.6-11.2-12.6-19.1-24-19.1c-3.1 0-6.2 .6-9.2 1.8L416.9 94.3c-12.3 4.9-26.3-1.1-31.2-13.4s1.1-26.3 13.4-31.2l31.3-12.5c8.6-3.4 17.7-5.2 27-5.2c33.8 0 63.1 23.3 70.8 56.2l43.9 188c1.7 7.3 2.9 14.7 3.5 22.1c.3 1.9 .5 3.8 .5 5.7l0 6.7 0 41.3 0 16c0 61.9-50.1 112-112 112l-44.3 0c-59.4 0-108.5-46.4-111.8-105.8L306.6 352l-37.2 0-1.2 22.2C264.9 433.6 215.8 480 156.3 480L112 480C50.1 480 0 429.9 0 368l0-16 0-41.3L0 304c0-1.9 .2-3.8 .5-5.7c.6-7.4 1.8-14.8 3.5-22.1l43.9-188C55.5 55.3 84.8 32 118.6 32c9.2 0 18.4 1.8 27 5.2l31.3 12.5c12.3 4.9 18.3 18.9 13.4 31.2s-18.9 18.3-31.2 13.4L127.8 81.8c-2.9-1.2-6-1.8-9.2-1.8zM64 325.4L64 368c0 26.5 21.5 48 48 48l44.3 0c25.5 0 46.5-19.9 47.9-45.3l2.5-45.6c-2.3-.8-4.9-1.7-7.5-2.5c-17.2-5.4-39.9-10.5-63.6-10.5c-23.7 0-46.2 5.1-63.2 10.5c-3.1 1-5.9 1.9-8.5 2.9zM512 368l0-42.6c-2.6-.9-5.5-1.9-8.5-2.9c-17-5.4-39.5-10.5-63.2-10.5c-23.7 0-46.4 5.1-63.6 10.5c-2.7 .8-5.2 1.7-7.5 2.5l2.5 45.6c1.4 25.4 22.5 45.3 47.9 45.3l44.3 0c26.5 0 48-21.5 48-48z\"]\n};\nconst faChessBoard = {\n prefix: 'fas',\n iconName: 'chess-board',\n icon: [448, 512, [], \"f43c\", \"M64 32C28.7 32 0 60.7 0 96L0 416c0 35.3 28.7 64 64 64l320 0c35.3 0 64-28.7 64-64l0-320c0-35.3-28.7-64-64-64L64 32zm64 64l0 64 64 0 0-64 64 0 0 64 64 0 0-64 64 0 0 64-64 0 0 64 64 0 0 64-64 0 0 64 64 0 0 64-64 0 0-64-64 0 0 64-64 0 0-64-64 0 0 64-64 0 0-64 64 0 0-64-64 0 0-64 64 0 0-64-64 0 0-64 64 0zm64 128l64 0 0-64-64 0 0 64zm0 64l0-64-64 0 0 64 64 0zm64 0l-64 0 0 64 64 0 0-64zm0 0l64 0 0-64-64 0 0 64z\"]\n};\nconst faBuildingCircleCheck = {\n prefix: 'fas',\n iconName: 'building-circle-check',\n icon: [640, 512, [], \"e4d2\", \"M48 0C21.5 0 0 21.5 0 48L0 464c0 26.5 21.5 48 48 48l96 0 0-80c0-26.5 21.5-48 48-48s48 21.5 48 48l0 80 96 0c15.1 0 28.5-6.9 37.3-17.8C340.4 462.2 320 417.5 320 368c0-54.7 24.9-103.5 64-135.8L384 48c0-26.5-21.5-48-48-48L48 0zM64 240c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32zm112-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16zm80 16c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32zM80 96l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16zm80 16c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32zM272 96l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16zM640 368a144 144 0 1 0 -288 0 144 144 0 1 0 288 0zm-76.7-43.3c6.2 6.2 6.2 16.4 0 22.6l-72 72c-6.2 6.2-16.4 6.2-22.6 0l-40-40c-6.2-6.2-6.2-16.4 0-22.6s16.4-6.2 22.6 0L480 385.4l60.7-60.7c6.2-6.2 16.4-6.2 22.6 0z\"]\n};\nconst faPersonChalkboard = {\n prefix: 'fas',\n iconName: 'person-chalkboard',\n icon: [640, 512, [], \"e53d\", \"M192 96a48 48 0 1 0 0-96 48 48 0 1 0 0 96zm-8 384l0-128 16 0 0 128c0 17.7 14.3 32 32 32s32-14.3 32-32l0-288 56 0 64 0 16 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-16 0 0-64 192 0 0 192-192 0 0-32-64 0 0 48c0 26.5 21.5 48 48 48l224 0c26.5 0 48-21.5 48-48l0-224c0-26.5-21.5-48-48-48L368 0c-26.5 0-48 21.5-48 48l0 80-76.9 0-65.9 0c-33.7 0-64.9 17.7-82.3 46.6l-58.3 97c-9.1 15.1-4.2 34.8 10.9 43.9s34.8 4.2 43.9-10.9L120 256.9 120 480c0 17.7 14.3 32 32 32s32-14.3 32-32z\"]\n};\nconst faMarsStrokeRight = {\n prefix: 'fas',\n iconName: 'mars-stroke-right',\n icon: [640, 512, [9897, \"mars-stroke-h\"], \"f22b\", \"M208 368a112 112 0 1 0 0-224 112 112 0 1 0 0 224zm174.4-88C370.7 365.8 297.1 432 208 432c-97.2 0-176-78.8-176-176s78.8-176 176-176c89.1 0 162.7 66.2 174.4 152l33.6 0 0-56c0-13.3 10.7-24 24-24s24 10.7 24 24l0 56 32 0 0-56c0-9.7 5.8-18.5 14.8-22.2s19.3-1.7 26.2 5.2l80 80c9.4 9.4 9.4 24.6 0 33.9l-80 80c-6.9 6.9-17.2 8.9-26.2 5.2s-14.8-12.5-14.8-22.2l0-56-32 0 0 56c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-56-33.6 0z\"]\n};\nconst faMarsStrokeH = faMarsStrokeRight;\nconst faHandBackFist = {\n prefix: 'fas',\n iconName: 'hand-back-fist',\n icon: [448, 512, [\"hand-rock\"], \"f255\", \"M144 0C117.5 0 96 21.5 96 48l0 48 0 28.5L96 176c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-26.7-9 7.5C40.4 169 32 187 32 206L32 244c0 38 16.9 74 46.1 98.3L128 384l0 96c0 17.7 14.3 32 32 32l160 0c17.7 0 32-14.3 32-32l0-105.3c46.9-19 80-65 80-118.7l0-80 0-16 0-16c0-26.5-21.5-48-48-48c-12.4 0-23.6 4.7-32.1 12.3C350 83.5 329.3 64 304 64c-12.4 0-23.6 4.7-32.1 12.3C270 51.5 249.3 32 224 32c-12.4 0-23.6 4.7-32.1 12.3C190 19.5 169.3 0 144 0z\"]\n};\nconst faHandRock = faHandBackFist;\nconst faSquareCaretUp = {\n prefix: 'fas',\n iconName: 'square-caret-up',\n icon: [448, 512, [\"caret-square-up\"], \"f151\", \"M64 32C28.7 32 0 60.7 0 96L0 416c0 35.3 28.7 64 64 64l320 0c35.3 0 64-28.7 64-64l0-320c0-35.3-28.7-64-64-64L64 32zM224 160c6.7 0 13 2.8 17.6 7.7l104 112c6.5 7 8.2 17.2 4.4 25.9s-12.5 14.4-22 14.4l-208 0c-9.5 0-18.2-5.7-22-14.4s-2.1-18.9 4.4-25.9l104-112c4.5-4.9 10.9-7.7 17.6-7.7z\"]\n};\nconst faCaretSquareUp = faSquareCaretUp;\nconst faCloudShowersWater = {\n prefix: 'fas',\n iconName: 'cloud-showers-water',\n icon: [576, 512, [], \"e4e4\", \"M224 0c38.6 0 71.9 22.8 87.2 55.7C325.7 41.1 345.8 32 368 32c38.7 0 71 27.5 78.4 64l1.6 0c35.3 0 64 28.7 64 64s-28.7 64-64 64l-320 0c-35.3 0-64-28.7-64-64s28.7-64 64-64c0-53 43-96 96-96zM140.6 292.3l-48 80c-6.8 11.4-21.6 15-32.9 8.2s-15.1-21.6-8.2-32.9l48-80c6.8-11.4 21.6-15.1 32.9-8.2s15.1 21.6 8.2 32.9zm327.8-32.9c11.4 6.8 15 21.6 8.2 32.9l-48 80c-6.8 11.4-21.6 15-32.9 8.2s-15-21.6-8.2-32.9l48-80c6.8-11.4 21.6-15.1 32.9-8.2zM252.6 292.3l-48 80c-6.8 11.4-21.6 15-32.9 8.2s-15.1-21.6-8.2-32.9l48-80c6.8-11.4 21.6-15.1 32.9-8.2s15.1 21.6 8.2 32.9zm103.8-32.9c11.4 6.8 15 21.6 8.2 32.9l-48 80c-6.8 11.4-21.6 15-32.9 8.2s-15.1-21.6-8.2-32.9l48-80c6.8-11.4 21.6-15.1 32.9-8.2zM306.5 421.9C329 437.4 356.5 448 384 448c26.9 0 55.4-10.8 77.4-26.1c0 0 0 0 0 0c11.9-8.5 28.1-7.8 39.2 1.7c14.4 11.9 32.5 21 50.6 25.2c17.2 4 27.9 21.2 23.9 38.4s-21.2 27.9-38.4 23.9c-24.5-5.7-44.9-16.5-58.2-25C449.5 501.7 417 512 384 512c-31.9 0-60.6-9.9-80.4-18.9c-5.8-2.7-11.1-5.3-15.6-7.7c-4.5 2.4-9.7 5.1-15.6 7.7c-19.8 9-48.5 18.9-80.4 18.9c-33 0-65.5-10.3-94.5-25.8c-13.4 8.4-33.7 19.3-58.2 25c-17.2 4-34.4-6.7-38.4-23.9s6.7-34.4 23.9-38.4c18.1-4.2 36.2-13.3 50.6-25.2c11.1-9.4 27.3-10.1 39.2-1.7c0 0 0 0 0 0C136.7 437.2 165.1 448 192 448c27.5 0 55-10.6 77.5-26.1c11.1-7.9 25.9-7.9 37 0z\"]\n};\nconst faChartBar = {\n prefix: 'fas',\n iconName: 'chart-bar',\n icon: [512, 512, [\"bar-chart\"], \"f080\", \"M32 32c17.7 0 32 14.3 32 32l0 336c0 8.8 7.2 16 16 16l400 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L80 480c-44.2 0-80-35.8-80-80L0 64C0 46.3 14.3 32 32 32zm96 96c0-17.7 14.3-32 32-32l192 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-192 0c-17.7 0-32-14.3-32-32zm32 64l128 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-128 0c-17.7 0-32-14.3-32-32s14.3-32 32-32zm0 96l256 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-256 0c-17.7 0-32-14.3-32-32s14.3-32 32-32z\"]\n};\nconst faBarChart = faChartBar;\nconst faHandsBubbles = {\n prefix: 'fas',\n iconName: 'hands-bubbles',\n icon: [576, 512, [\"hands-wash\"], \"e05e\", \"M416 64a32 32 0 1 0 0-64 32 32 0 1 0 0 64zm96 128a32 32 0 1 0 0-64 32 32 0 1 0 0 64zM160 464a48 48 0 1 0 -96 0 48 48 0 1 0 96 0zM32 160l.1 72.6c.1 52.2 24 101 64 133.1c-.1-1.9-.1-3.8-.1-5.7l0-8c0-71.8 37-138.6 97.9-176.7l60.2-37.6c8.6-5.4 17.9-8.4 27.3-9.4l45.9-79.5c6.6-11.5 2.7-26.2-8.8-32.8s-26.2-2.7-32.8 8.8l-78 135.1c-3.3 5.7-10.7 7.7-16.4 4.4s-7.7-10.7-4.4-16.4l62-107.4c6.6-11.5 2.7-26.2-8.8-32.8S214 5 207.4 16.5l-68 117.8s0 0 0 0s0 0 0 0l-43.3 75L96 160c0-17.7-14.4-32-32-32s-32 14.4-32 32zM332.1 88.5L307.5 131c13.9 4.5 26.4 13.7 34.7 27c.9 1.5 1.8 2.9 2.5 4.4l28.9-50c6.6-11.5 2.7-26.2-8.8-32.8s-26.2-2.7-32.8 8.8zm46.4 63.7l-26.8 46.4c-.6 6-2.1 11.8-4.3 17.4l4.7 0 13.3 0s0 0 0 0l31.8 0 23-39.8c6.6-11.5 2.7-26.2-8.8-32.8s-26.2-2.7-32.8 8.8zM315.1 175c-9.4-15-29.1-19.5-44.1-10.2l-60.2 37.6C159.3 234.7 128 291.2 128 352l0 8c0 8.9 .8 17.6 2.2 26.1c35.4 8.2 61.8 40 61.8 77.9c0 6.3-.7 12.5-2.1 18.4C215.1 501 246.3 512 280 512l176 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-92 0c-6.6 0-12-5.4-12-12s5.4-12 12-12l124 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-124 0c-6.6 0-12-5.4-12-12s5.4-12 12-12l156 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-156 0c-6.6 0-12-5.4-12-12s5.4-12 12-12l124 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-136 0s0 0 0 0s0 0 0 0l-93.2 0L305 219.1c15-9.4 19.5-29.1 10.2-44.1z\"]\n};\nconst faHandsWash = faHandsBubbles;\nconst faLessThanEqual = {\n prefix: 'fas',\n iconName: 'less-than-equal',\n icon: [448, 512, [], \"f537\", \"M395.9 93.7c16.4-6.6 24.4-25.2 17.8-41.6s-25.2-24.4-41.6-17.8l-320 128C40 167.1 32 178.9 32 192s8 24.9 20.1 29.7l320 128c16.4 6.6 35-1.4 41.6-17.8s-1.4-35-17.8-41.6L150.2 192 395.9 93.7zM32 416c-17.7 0-32 14.3-32 32s14.3 32 32 32l384 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L32 416z\"]\n};\nconst faTrain = {\n prefix: 'fas',\n iconName: 'train',\n icon: [448, 512, [128646], \"f238\", \"M96 0C43 0 0 43 0 96L0 352c0 48 35.2 87.7 81.1 94.9l-46 46C28.1 499.9 33.1 512 43 512l39.7 0c8.5 0 16.6-3.4 22.6-9.4L160 448l128 0 54.6 54.6c6 6 14.1 9.4 22.6 9.4l39.7 0c10 0 15-12.1 7.9-19.1l-46-46c46-7.1 81.1-46.9 81.1-94.9l0-256c0-53-43-96-96-96L96 0zM64 96c0-17.7 14.3-32 32-32l256 0c17.7 0 32 14.3 32 32l0 96c0 17.7-14.3 32-32 32L96 224c-17.7 0-32-14.3-32-32l0-96zM224 288a48 48 0 1 1 0 96 48 48 0 1 1 0-96z\"]\n};\nconst faEyeLowVision = {\n prefix: 'fas',\n iconName: 'eye-low-vision',\n icon: [640, 512, [\"low-vision\"], \"f2a8\", \"M38.8 5.1C28.4-3.1 13.3-1.2 5.1 9.2S-1.2 34.7 9.2 42.9l592 464c10.4 8.2 25.5 6.3 33.7-4.1s6.3-25.5-4.1-33.7L525.6 386.7c39.6-40.6 66.4-86.1 79.9-118.4c3.3-7.9 3.3-16.7 0-24.6c-14.9-35.7-46.2-87.7-93-131.1C465.5 68.8 400.8 32 320 32c-68.2 0-125 26.3-169.3 60.8L38.8 5.1zM223 149.5c48.6-44.3 123-50.8 179.3-11.7c60.8 42.4 78.9 123.2 44.2 186.9L408 294.5c8.4-19.3 10.6-41.4 4.8-63.3c-11.1-41.5-47.8-69.4-88.6-71.1c-5.8-.2-9.2 6.1-7.4 11.7c2.1 6.4 3.3 13.2 3.3 20.3c0 10.2-2.4 19.8-6.6 28.3L223 149.5zm223.1 298L83.1 161.5c-11 14.4-20.5 28.7-28.4 42.2l339 265.7c18.7-5.5 36.2-13 52.6-21.8zM34.5 268.3c14.9 35.7 46.2 87.7 93 131.1C174.5 443.2 239.2 480 320 480c3.1 0 6.1-.1 9.2-.2L33.1 247.8c-1.8 6.8-1.3 14 1.4 20.5z\"]\n};\nconst faLowVision = faEyeLowVision;\nconst faCrow = {\n prefix: 'fas',\n iconName: 'crow',\n icon: [640, 512, [], \"f520\", \"M456 0c-48.6 0-88 39.4-88 88l0 29.2L12.5 390.6c-14 10.8-16.6 30.9-5.9 44.9s30.9 16.6 44.9 5.9L126.1 384l133.1 0 46.6 113.1c5 12.3 19.1 18.1 31.3 13.1s18.1-19.1 13.1-31.3L311.1 384l40.9 0c1.1 0 2.1 0 3.2 0l46.6 113.2c5 12.3 19.1 18.1 31.3 13.1s18.1-19.1 13.1-31.3l-42-102C484.9 354.1 544 280 544 192l0-64 0-8 80.5-20.1c8.6-2.1 13.8-10.8 11.6-19.4C629 52 603.4 32 574 32l-50.1 0C507.7 12.5 483.3 0 456 0zm0 64a24 24 0 1 1 0 48 24 24 0 1 1 0-48z\"]\n};\nconst faSailboat = {\n prefix: 'fas',\n iconName: 'sailboat',\n icon: [576, 512, [], \"e445\", \"M256 16c0-7 4.5-13.2 11.2-15.3s13.9 .4 17.9 6.1l224 320c3.4 4.9 3.8 11.3 1.1 16.6s-8.2 8.6-14.2 8.6l-224 0c-8.8 0-16-7.2-16-16l0-320zM212.1 96.5c7 1.9 11.9 8.2 11.9 15.5l0 224c0 8.8-7.2 16-16 16L80 352c-5.7 0-11-3-13.8-8s-2.9-11-.1-16l128-224c3.6-6.3 11-9.4 18-7.5zM5.7 404.3C2.8 394.1 10.5 384 21.1 384l533.8 0c10.6 0 18.3 10.1 15.4 20.3l-4 14.3C550.7 473.9 500.4 512 443 512L133 512C75.6 512 25.3 473.9 9.7 418.7l-4-14.3z\"]\n};\nconst faWindowRestore = {\n prefix: 'fas',\n iconName: 'window-restore',\n icon: [512, 512, [], \"f2d2\", \"M432 64L208 64c-8.8 0-16 7.2-16 16l0 16-64 0 0-16c0-44.2 35.8-80 80-80L432 0c44.2 0 80 35.8 80 80l0 224c0 44.2-35.8 80-80 80l-16 0 0-64 16 0c8.8 0 16-7.2 16-16l0-224c0-8.8-7.2-16-16-16zM0 192c0-35.3 28.7-64 64-64l256 0c35.3 0 64 28.7 64 64l0 256c0 35.3-28.7 64-64 64L64 512c-35.3 0-64-28.7-64-64L0 192zm64 32c0 17.7 14.3 32 32 32l192 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L96 192c-17.7 0-32 14.3-32 32z\"]\n};\nconst faSquarePlus = {\n prefix: 'fas',\n iconName: 'square-plus',\n icon: [448, 512, [61846, \"plus-square\"], \"f0fe\", \"M64 32C28.7 32 0 60.7 0 96L0 416c0 35.3 28.7 64 64 64l320 0c35.3 0 64-28.7 64-64l0-320c0-35.3-28.7-64-64-64L64 32zM200 344l0-64-64 0c-13.3 0-24-10.7-24-24s10.7-24 24-24l64 0 0-64c0-13.3 10.7-24 24-24s24 10.7 24 24l0 64 64 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-64 0 0 64c0 13.3-10.7 24-24 24s-24-10.7-24-24z\"]\n};\nconst faPlusSquare = faSquarePlus;\nconst faToriiGate = {\n prefix: 'fas',\n iconName: 'torii-gate',\n icon: [512, 512, [9961], \"f6a1\", \"M0 80c0 26.5 21.5 48 48 48l16 0 0 64 64 0 0-64 96 0 0 64 64 0 0-64 96 0 0 64 64 0 0-64 16 0c26.5 0 48-21.5 48-48l0-66.6C512 6 506 0 498.6 0c-1.7 0-3.4 .3-5 1l-49 19.6C425.7 28.1 405.5 32 385.2 32L126.8 32c-20.4 0-40.5-3.9-59.4-11.4L18.4 1c-1.6-.6-3.3-1-5-1C6 0 0 6 0 13.4L0 80zM64 288l0 192c0 17.7 14.3 32 32 32s32-14.3 32-32l0-192 256 0 0 192c0 17.7 14.3 32 32 32s32-14.3 32-32l0-192 32 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L32 224c-17.7 0-32 14.3-32 32s14.3 32 32 32l32 0z\"]\n};\nconst faFrog = {\n prefix: 'fas',\n iconName: 'frog',\n icon: [576, 512, [], \"f52e\", \"M368 32c41.7 0 75.9 31.8 79.7 72.5l85.6 26.3c25.4 7.8 42.8 31.3 42.8 57.9c0 21.8-11.7 41.9-30.7 52.7L400.8 323.5 493.3 416l50.7 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-64 0c-8.5 0-16.6-3.4-22.6-9.4L346.9 360.2c11.7-36 3.2-77.1-25.4-105.7c-40.6-40.6-106.3-40.6-146.9-.1L101 324.4c-6.4 6.1-6.7 16.2-.6 22.6s16.2 6.6 22.6 .6l73.8-70.2 .1-.1 .1-.1c3.5-3.5 7.3-6.6 11.3-9.2c27.9-18.5 65.9-15.4 90.5 9.2c24.7 24.7 27.7 62.9 9 90.9c-2.6 3.8-5.6 7.5-9 10.9L261.8 416l90.2 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L64 480c-35.3 0-64-28.7-64-64C0 249.6 127 112.9 289.3 97.5C296.2 60.2 328.8 32 368 32zm0 104a24 24 0 1 0 0-48 24 24 0 1 0 0 48z\"]\n};\nconst faBucket = {\n prefix: 'fas',\n iconName: 'bucket',\n icon: [448, 512, [], \"e4cf\", \"M96 152l0 8-48 0 0-8C48 68.1 116.1 0 200 0l48 0c83.9 0 152 68.1 152 152l0 8-48 0 0-8c0-57.4-46.6-104-104-104l-48 0C142.6 48 96 94.6 96 152zM0 224c0-17.7 14.3-32 32-32l384 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-5.1 0L388.5 469c-2.6 24.4-23.2 43-47.7 43l-233.6 0c-24.6 0-45.2-18.5-47.7-43L37.1 256 32 256c-17.7 0-32-14.3-32-32z\"]\n};\nconst faImage = {\n prefix: 'fas',\n iconName: 'image',\n icon: [512, 512, [], \"f03e\", \"M0 96C0 60.7 28.7 32 64 32l384 0c35.3 0 64 28.7 64 64l0 320c0 35.3-28.7 64-64 64L64 480c-35.3 0-64-28.7-64-64L0 96zM323.8 202.5c-4.5-6.6-11.9-10.5-19.8-10.5s-15.4 3.9-19.8 10.5l-87 127.6L170.7 297c-4.6-5.7-11.5-9-18.7-9s-14.2 3.3-18.7 9l-64 80c-5.8 7.2-6.9 17.1-2.9 25.4s12.4 13.6 21.6 13.6l96 0 32 0 208 0c8.9 0 17.1-4.9 21.2-12.8s3.6-17.4-1.4-24.7l-120-176zM112 192a48 48 0 1 0 0-96 48 48 0 1 0 0 96z\"]\n};\nconst faMicrophone = {\n prefix: 'fas',\n iconName: 'microphone',\n icon: [384, 512, [], \"f130\", \"M192 0C139 0 96 43 96 96l0 160c0 53 43 96 96 96s96-43 96-96l0-160c0-53-43-96-96-96zM64 216c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 40c0 89.1 66.2 162.7 152 174.4l0 33.6-48 0c-13.3 0-24 10.7-24 24s10.7 24 24 24l72 0 72 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-48 0 0-33.6c85.8-11.7 152-85.3 152-174.4l0-40c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 40c0 70.7-57.3 128-128 128s-128-57.3-128-128l0-40z\"]\n};\nconst faCow = {\n prefix: 'fas',\n iconName: 'cow',\n icon: [640, 512, [128004], \"f6c8\", \"M96 224l0 32 0 160c0 17.7 14.3 32 32 32l32 0c17.7 0 32-14.3 32-32l0-88.2c9.9 6.6 20.6 12 32 16.1l0 24.2c0 8.8 7.2 16 16 16s16-7.2 16-16l0-16.9c5.3 .6 10.6 .9 16 .9s10.7-.3 16-.9l0 16.9c0 8.8 7.2 16 16 16s16-7.2 16-16l0-24.2c11.4-4 22.1-9.4 32-16.1l0 88.2c0 17.7 14.3 32 32 32l32 0c17.7 0 32-14.3 32-32l0-160 32 32 0 49.5c0 9.5 2.8 18.7 8.1 26.6L530 427c8.8 13.1 23.5 21 39.3 21c22.5 0 41.9-15.9 46.3-38l20.3-101.6c2.6-13-.3-26.5-8-37.3l-3.9-5.5 0-81.6c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 14.4-52.9-74.1C496 86.5 452.4 64 405.9 64L272 64l-16 0-64 0-48 0C77.7 64 24 117.7 24 184l0 54C9.4 249.8 0 267.8 0 288l0 17.6c0 8 6.4 14.4 14.4 14.4C46.2 320 72 294.2 72 262.4l0-6.4 0-32 0-40c0-24.3 12.1-45.8 30.5-58.9C98.3 135.9 96 147.7 96 160l0 64zM560 336a16 16 0 1 1 32 0 16 16 0 1 1 -32 0zM166.6 166.6c-4.2-4.2-6.6-10-6.6-16c0-12.5 10.1-22.6 22.6-22.6l178.7 0c12.5 0 22.6 10.1 22.6 22.6c0 6-2.4 11.8-6.6 16l-23.4 23.4C332.2 211.8 302.7 224 272 224s-60.2-12.2-81.9-33.9l-23.4-23.4z\"]\n};\nconst faCaretUp = {\n prefix: 'fas',\n iconName: 'caret-up',\n icon: [320, 512, [], \"f0d8\", \"M182.6 137.4c-12.5-12.5-32.8-12.5-45.3 0l-128 128c-9.2 9.2-11.9 22.9-6.9 34.9s16.6 19.8 29.6 19.8l256 0c12.9 0 24.6-7.8 29.6-19.8s2.2-25.7-6.9-34.9l-128-128z\"]\n};\nconst faScrewdriver = {\n prefix: 'fas',\n iconName: 'screwdriver',\n icon: [512, 512, [129691], \"f54a\", \"M465 7c-8.5-8.5-22-9.4-31.6-2.1l-104 80c-5.9 4.5-9.4 11.6-9.4 19l0 54.1-85.6 85.6c6.7 4.2 13 9.3 18.8 15.1s10.9 12.2 15.1 18.8L353.9 192l54.1 0c7.5 0 14.5-3.5 19-9.4l80-104c7.4-9.6 6.5-23.1-2.1-31.6L465 7zM121.4 281.4l-112 112c-12.5 12.5-12.5 32.8 0 45.3l64 64c12.5 12.5 32.8 12.5 45.3 0l112-112c30.2-30.2 30.2-79.1 0-109.3s-79.1-30.2-109.3 0z\"]\n};\nconst faFolderClosed = {\n prefix: 'fas',\n iconName: 'folder-closed',\n icon: [512, 512, [], \"e185\", \"M448 480L64 480c-35.3 0-64-28.7-64-64L0 192l512 0 0 224c0 35.3-28.7 64-64 64zm64-320L0 160 0 96C0 60.7 28.7 32 64 32l128 0c20.1 0 39.1 9.5 51.2 25.6l19.2 25.6c6 8.1 15.5 12.8 25.6 12.8l160 0c35.3 0 64 28.7 64 64z\"]\n};\nconst faHouseTsunami = {\n prefix: 'fas',\n iconName: 'house-tsunami',\n icon: [576, 512, [], \"e515\", \"M80.8 136.5C104.9 93.8 152.6 64 209 64c16.9 0 33.1 2.7 48.2 7.7c16.8 5.5 34.9-3.6 40.4-20.4s-3.6-34.9-20.4-40.4C255.8 3.8 232.8 0 209 0C95.2 0 0 88 0 200c0 91.6 53.5 172.1 142.2 194.1c13.4 3.8 27.5 5.9 42.2 5.9c.7 0 1.4 0 2.1-.1c1.8 0 3.7 .1 5.5 .1c0 0 0 0 0 0c31.9 0 60.6-9.9 80.4-18.9c5.8-2.7 11.1-5.3 15.6-7.7c4.5 2.4 9.7 5.1 15.6 7.7c19.8 9 48.5 18.9 80.4 18.9c33 0 65.5-10.3 94.5-25.8c13.4 8.4 33.7 19.3 58.2 25c17.2 4 34.4-6.7 38.4-23.9s-6.7-34.4-23.9-38.4c-18.1-4.2-36.2-13.3-50.6-25.2c-11.1-9.5-27.3-10.1-39.2-1.7c0 0 0 0 0 0C439.4 325.2 410.9 336 384 336c-27.5 0-55-10.6-77.5-26.1c-11.1-7.9-25.9-7.9-37 0c-22.4 15.5-49.9 26.1-77.4 26.1c0 0-.1 0-.1 0c-12.4 0-24-1.5-34.9-4.3C121.6 320.2 96 287 96 248c0-48.5 39.5-88 88.4-88c13.5 0 26.1 3 37.5 8.3c16 7.5 35.1 .6 42.5-15.5s.6-35.1-15.5-42.5C229.3 101.1 207.4 96 184.4 96c-40 0-76.4 15.4-103.6 40.5zm252-18.1c-8.1 6-12.8 15.5-12.8 25.6l0 121c1.6 1 3.3 2 4.8 3.1c18.4 12.7 39.6 20.3 59.2 20.3c19 0 41.2-7.9 59.2-20.3c23.8-16.7 55.8-15.3 78.1 3.4c10.6 8.8 24.2 15.6 37.3 18.6c5.8 1.4 11.2 3.4 16.2 6.2c.7-2.7 1.1-5.5 1.1-8.4l-.4-144c0-10-4.7-19.4-12.7-25.5l-95.5-72c-11.4-8.6-27.1-8.6-38.5 0l-96 72zM384 448c-27.5 0-55-10.6-77.5-26.1c-11.1-7.9-25.9-7.9-37 0C247 437.4 219.5 448 192 448c-26.9 0-55.3-10.8-77.4-26.1c0 0 0 0 0 0c-11.9-8.5-28.1-7.8-39.2 1.7c-14.4 11.9-32.5 21-50.6 25.2c-17.2 4-27.9 21.2-23.9 38.4s21.2 27.9 38.4 23.9c24.5-5.7 44.9-16.5 58.2-25C126.5 501.7 159 512 192 512c31.9 0 60.6-9.9 80.4-18.9c5.8-2.7 11.1-5.3 15.6-7.7c4.5 2.4 9.7 5.1 15.6 7.7c19.8 9 48.5 18.9 80.4 18.9c33 0 65.5-10.3 94.5-25.8c13.4 8.4 33.7 19.3 58.2 25c17.2 4 34.4-6.7 38.4-23.9s-6.7-34.4-23.9-38.4c-18.1-4.2-36.2-13.3-50.6-25.2c-11.1-9.4-27.3-10.1-39.2-1.7c0 0 0 0 0 0C439.4 437.2 410.9 448 384 448z\"]\n};\nconst faSquareNfi = {\n prefix: 'fas',\n iconName: 'square-nfi',\n icon: [448, 512, [], \"e576\", \"M0 96C0 60.7 28.7 32 64 32l320 0c35.3 0 64 28.7 64 64l0 320c0 35.3-28.7 64-64 64L64 480c-35.3 0-64-28.7-64-64L0 96zm75.7 64.6C68.8 162.5 64 168.8 64 176l0 160c0 8.8 7.2 16 16 16s16-7.2 16-16l0-102.2 66.3 110.5c3.7 6.2 11.1 9.1 18 7.2s11.7-8.2 11.7-15.4l0-160c0-8.8-7.2-16-16-16s-16 7.2-16 16l0 102.2L93.7 167.8c-3.7-6.2-11.1-9.1-18-7.2zM224 176l0 64 0 96c0 8.8 7.2 16 16 16s16-7.2 16-16l0-80 48 0c8.8 0 16-7.2 16-16s-7.2-16-16-16l-48 0 0-32 48 0c8.8 0 16-7.2 16-16s-7.2-16-16-16l-64 0c-8.8 0-16 7.2-16 16zm160 0c0-8.8-7.2-16-16-16s-16 7.2-16 16l0 160c0 8.8 7.2 16 16 16s16-7.2 16-16l0-160z\"]\n};\nconst faArrowUpFromGroundWater = {\n prefix: 'fas',\n iconName: 'arrow-up-from-ground-water',\n icon: [576, 512, [], \"e4b5\", \"M288 352c17.7 0 32-14.3 32-32l0-210.7 25.4 25.4c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3l-80-80c-12.5-12.5-32.8-12.5-45.3 0l-80 80c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0L256 109.3 256 320c0 17.7 14.3 32 32 32zm-18.5 69.9C247 437.4 219.5 448 192 448c-26.9 0-55.3-10.8-77.4-26.1c0 0 0 0 0 0c-11.9-8.5-28.1-7.8-39.2 1.7c-14.4 11.9-32.5 21-50.6 25.2c-17.2 4-27.9 21.2-23.9 38.4s21.2 27.9 38.4 23.9c24.5-5.7 44.9-16.5 58.2-25C126.5 501.7 159 512 192 512c31.9 0 60.6-9.9 80.4-18.9c5.8-2.7 11.1-5.3 15.6-7.7c4.5 2.4 9.7 5.1 15.6 7.7c19.8 9 48.5 18.9 80.4 18.9c33 0 65.5-10.3 94.5-25.8c13.4 8.4 33.7 19.3 58.2 25c17.2 4 34.4-6.7 38.4-23.9s-6.7-34.4-23.9-38.4c-18.1-4.2-36.2-13.3-50.6-25.2c-11.1-9.4-27.3-10.1-39.2-1.7c0 0 0 0 0 0C439.4 437.2 410.9 448 384 448c-27.5 0-55-10.6-77.5-26.1c-11.1-7.9-25.9-7.9-37 0zM192 192L48 192c-26.5 0-48 21.5-48 48L0 425c5.3-3.1 11.2-5.4 17.5-6.9c13.1-3.1 26.7-9.8 37.3-18.6c22.2-18.7 54.3-20.1 78.1-3.4c18 12.4 40.1 20.3 59.1 20.3L192 192zm384 48c0-26.5-21.5-48-48-48l-144 0 0 224.5s0 0 0 0c19 0 41.2-7.9 59.2-20.3c23.8-16.7 55.8-15.4 78.1 3.4c10.6 8.8 24.2 15.6 37.3 18.6c6.3 1.5 12.1 3.8 17.5 6.9l0-185z\"]\n};\nconst faMartiniGlass = {\n prefix: 'fas',\n iconName: 'martini-glass',\n icon: [512, 512, [127864, \"glass-martini-alt\"], \"f57b\", \"M32 0C19.1 0 7.4 7.8 2.4 19.8s-2.2 25.7 6.9 34.9L224 269.3 224 448l-64 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l96 0 96 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-64 0 0-178.7L502.6 54.6c9.2-9.2 11.9-22.9 6.9-34.9S492.9 0 480 0L32 0zM173.3 128l-64-64 293.5 0-64 64-165.5 0z\"]\n};\nconst faGlassMartiniAlt = faMartiniGlass;\nconst faSquareBinary = {\n prefix: 'fas',\n iconName: 'square-binary',\n icon: [448, 512, [], \"e69b\", \"M0 96C0 60.7 28.7 32 64 32l320 0c35.3 0 64 28.7 64 64l0 320c0 35.3-28.7 64-64 64L64 480c-35.3 0-64-28.7-64-64L0 96zm144 4c-24.3 0-44 19.7-44 44l0 48c0 24.3 19.7 44 44 44l32 0c24.3 0 44-19.7 44-44l0-48c0-24.3-19.7-44-44-44l-32 0zm-4 44c0-2.2 1.8-4 4-4l32 0c2.2 0 4 1.8 4 4l0 48c0 2.2-1.8 4-4 4l-32 0c-2.2 0-4-1.8-4-4l0-48zm140-44c-11 0-20 9-20 20c0 9.7 6.9 17.7 16 19.6l0 76.4c0 11 9 20 20 20s20-9 20-20l0-96c0-11-9-20-20-20l-16 0zM132 296c0 9.7 6.9 17.7 16 19.6l0 76.4c0 11 9 20 20 20s20-9 20-20l0-96c0-11-9-20-20-20l-16 0c-11 0-20 9-20 20zm96 24l0 48c0 24.3 19.7 44 44 44l32 0c24.3 0 44-19.7 44-44l0-48c0-24.3-19.7-44-44-44l-32 0c-24.3 0-44 19.7-44 44zm44-4l32 0c2.2 0 4 1.8 4 4l0 48c0 2.2-1.8 4-4 4l-32 0c-2.2 0-4-1.8-4-4l0-48c0-2.2 1.8-4 4-4z\"]\n};\nconst faRotateLeft = {\n prefix: 'fas',\n iconName: 'rotate-left',\n icon: [512, 512, [\"rotate-back\", \"rotate-backward\", \"undo-alt\"], \"f2ea\", \"M48.5 224L40 224c-13.3 0-24-10.7-24-24L16 72c0-9.7 5.8-18.5 14.8-22.2s19.3-1.7 26.2 5.2L98.6 96.6c87.6-86.5 228.7-86.2 315.8 1c87.5 87.5 87.5 229.3 0 316.8s-229.3 87.5-316.8 0c-12.5-12.5-12.5-32.8 0-45.3s32.8-12.5 45.3 0c62.5 62.5 163.8 62.5 226.3 0s62.5-163.8 0-226.3c-62.2-62.2-162.7-62.5-225.3-1L185 183c6.9 6.9 8.9 17.2 5.2 26.2s-12.5 14.8-22.2 14.8L48.5 224z\"]\n};\nconst faRotateBack = faRotateLeft;\nconst faRotateBackward = faRotateLeft;\nconst faUndoAlt = faRotateLeft;\nconst faTableColumns = {\n prefix: 'fas',\n iconName: 'table-columns',\n icon: [512, 512, [\"columns\"], \"f0db\", \"M0 96C0 60.7 28.7 32 64 32l384 0c35.3 0 64 28.7 64 64l0 320c0 35.3-28.7 64-64 64L64 480c-35.3 0-64-28.7-64-64L0 96zm64 64l0 256 160 0 0-256L64 160zm384 0l-160 0 0 256 160 0 0-256z\"]\n};\nconst faColumns = faTableColumns;\nconst faLemon = {\n prefix: 'fas',\n iconName: 'lemon',\n icon: [448, 512, [127819], \"f094\", \"M448 96c0-35.3-28.7-64-64-64c-6.6 0-13 1-19 2.9c-22.5 7-48.1 14.9-71 9c-75.2-19.1-156.4 11-213.7 68.3S-7.2 250.8 11.9 326c5.8 22.9-2 48.4-9 71C1 403 0 409.4 0 416c0 35.3 28.7 64 64 64c6.6 0 13-1 19.1-2.9c22.5-7 48.1-14.9 71-9c75.2 19.1 156.4-11 213.7-68.3s87.5-138.5 68.3-213.7c-5.8-22.9 2-48.4 9-71c1.9-6 2.9-12.4 2.9-19.1zM212.5 127.4c-54.6 16-101.1 62.5-117.1 117.1C92.9 253 84 257.8 75.5 255.4S62.2 244 64.6 235.5c19.1-65.1 73.7-119.8 138.9-138.9c8.5-2.5 17.4 2.4 19.9 10.9s-2.4 17.4-10.9 19.9z\"]\n};\nconst faHeadSideMask = {\n prefix: 'fas',\n iconName: 'head-side-mask',\n icon: [576, 512, [], \"e063\", \"M32 224.2c0-22.2 3.2-43.6 9.2-63.9L262.2 321c-4 9.5-6.2 20-6.2 31l0 160-128 0c-17.7 0-32-14.3-32-32l0-72.7c0-16.7-6.9-32.5-17.1-45.8C48.6 322.4 32 274.1 32 224.2zm248.3 70.4L53 129.3C88.7 53 166.2 0 256 0l24 0c95.2 0 181.2 69.3 197.3 160.2c2.3 13 6.8 25.7 15.1 36l42 52.6c5.4 6.7 8.6 14.8 9.4 23.2L336 272c-21.7 0-41.3 8.6-55.7 22.6zM336 304l198 0s0 0 0 0l10 0-19.7 64L368 368c-8.8 0-16 7.2-16 16s7.2 16 16 16l146.5 0-9.8 32L368 432c-8.8 0-16 7.2-16 16s7.2 16 16 16l126.8 0-.9 2.8c-8.3 26.9-33.1 45.2-61.2 45.2L288 512l0-160c0-14 6-26.7 15.6-35.4c0 0 0 0 0 0c8.5-7.8 19.9-12.6 32.4-12.6zm48-80a32 32 0 1 0 0-64 32 32 0 1 0 0 64z\"]\n};\nconst faHandshake = {\n prefix: 'fas',\n iconName: 'handshake',\n icon: [640, 512, [], \"f2b5\", \"M323.4 85.2l-96.8 78.4c-16.1 13-19.2 36.4-7 53.1c12.9 17.8 38 21.3 55.3 7.8l99.3-77.2c7-5.4 17-4.2 22.5 2.8s4.2 17-2.8 22.5l-20.9 16.2L512 316.8 512 128l-.7 0-3.9-2.5L434.8 79c-15.3-9.8-33.2-15-51.4-15c-21.8 0-43 7.5-60 21.2zm22.8 124.4l-51.7 40.2C263 274.4 217.3 268 193.7 235.6c-22.2-30.5-16.6-73.1 12.7-96.8l83.2-67.3c-11.6-4.9-24.1-7.4-36.8-7.4C234 64 215.7 69.6 200 80l-72 48 0 224 28.2 0 91.4 83.4c19.6 17.9 49.9 16.5 67.8-3.1c5.5-6.1 9.2-13.2 11.1-20.6l17 15.6c19.5 17.9 49.9 16.6 67.8-2.9c4.5-4.9 7.8-10.6 9.9-16.5c19.4 13 45.8 10.3 62.1-7.5c17.9-19.5 16.6-49.9-2.9-67.8l-134.2-123zM16 128c-8.8 0-16 7.2-16 16L0 352c0 17.7 14.3 32 32 32l32 0c17.7 0 32-14.3 32-32l0-224-80 0zM48 320a16 16 0 1 1 0 32 16 16 0 1 1 0-32zM544 128l0 224c0 17.7 14.3 32 32 32l32 0c17.7 0 32-14.3 32-32l0-208c0-8.8-7.2-16-16-16l-80 0zm32 208a16 16 0 1 1 32 0 16 16 0 1 1 -32 0z\"]\n};\nconst faGem = {\n prefix: 'fas',\n iconName: 'gem',\n icon: [512, 512, [128142], \"f3a5\", \"M116.7 33.8c4.5-6.1 11.7-9.8 19.3-9.8l240 0c7.6 0 14.8 3.6 19.3 9.8l112 152c6.8 9.2 6.1 21.9-1.5 30.4l-232 256c-4.5 5-11 7.9-17.8 7.9s-13.2-2.9-17.8-7.9l-232-256c-7.7-8.5-8.3-21.2-1.5-30.4l112-152zm38.5 39.8c-3.3 2.5-4.2 7-2.1 10.5l57.4 95.6L63.3 192c-4.1 .3-7.3 3.8-7.3 8s3.2 7.6 7.3 8l192 16c.4 0 .9 0 1.3 0l192-16c4.1-.3 7.3-3.8 7.3-8s-3.2-7.6-7.3-8L301.5 179.8l57.4-95.6c2.1-3.5 1.2-8.1-2.1-10.5s-7.9-2-10.7 1L256 172.2 165.9 74.6c-2.8-3-7.4-3.4-10.7-1z\"]\n};\nconst faDolly = {\n prefix: 'fas',\n iconName: 'dolly',\n icon: [576, 512, [\"dolly-box\"], \"f472\", \"M0 32C0 14.3 14.3 0 32 0l72.9 0c27.5 0 52 17.6 60.7 43.8L257.7 320c30.1 .5 56.8 14.9 74 37l202.1-67.4c16.8-5.6 34.9 3.5 40.5 20.2s-3.5 34.9-20.2 40.5L352 417.7c-.9 52.2-43.5 94.3-96 94.3c-53 0-96-43-96-96c0-30.8 14.5-58.2 37-75.8L104.9 64 32 64C14.3 64 0 49.7 0 32zM244.8 134.5c-5.5-16.8 3.7-34.9 20.5-40.3L311 79.4l19.8 60.9 60.9-19.8L371.8 59.6l45.7-14.8c16.8-5.5 34.9 3.7 40.3 20.5l49.4 152.2c5.5 16.8-3.7 34.9-20.5 40.3L334.5 307.2c-16.8 5.5-34.9-3.7-40.3-20.5L244.8 134.5z\"]\n};\nconst faDollyBox = faDolly;\nconst faSmoking = {\n prefix: 'fas',\n iconName: 'smoking',\n icon: [640, 512, [128684], \"f48d\", \"M448 32l0 11c0 38.2 15.2 74.8 42.2 101.8l21 21c21 21 32.8 49.5 32.8 79.2l0 11c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-11c0-12.7-5.1-24.9-14.1-33.9l-21-21C405.9 151.1 384 98.1 384 43l0-11c0-17.7 14.3-32 32-32s32 14.3 32 32zM576 256l0-11c0-38.2-15.2-74.8-42.2-101.8l-21-21c-21-21-32.8-49.5-32.8-79.2l0-11c0-17.7 14.3-32 32-32s32 14.3 32 32l0 11c0 12.7 5.1 24.9 14.1 33.9l21 21c39 39 60.9 91.9 60.9 147.1l0 11c0 17.7-14.3 32-32 32s-32-14.3-32-32zM0 416c0-35.3 28.7-64 64-64l352 0c17.7 0 32 14.3 32 32l0 96c0 17.7-14.3 32-32 32L64 512c-35.3 0-64-28.7-64-64l0-32zm224 0l0 32 160 0 0-32-160 0zm288-64c17.7 0 32 14.3 32 32l0 96c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-96c0-17.7 14.3-32 32-32zm96 0c17.7 0 32 14.3 32 32l0 96c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-96c0-17.7 14.3-32 32-32z\"]\n};\nconst faMinimize = {\n prefix: 'fas',\n iconName: 'minimize',\n icon: [512, 512, [\"compress-arrows-alt\"], \"f78c\", \"M456 224l-144 0c-13.3 0-24-10.7-24-24l0-144c0-9.7 5.8-18.5 14.8-22.2s19.3-1.7 26.2 5.2l40 40L442.3 5.7C446 2 450.9 0 456 0s10 2 13.7 5.7l36.7 36.7C510 46 512 50.9 512 56s-2 10-5.7 13.7L433 143l40 40c6.9 6.9 8.9 17.2 5.2 26.2s-12.5 14.8-22.2 14.8zm0 64c9.7 0 18.5 5.8 22.2 14.8s1.7 19.3-5.2 26.2l-40 40 73.4 73.4c3.6 3.6 5.7 8.5 5.7 13.7s-2 10-5.7 13.7l-36.7 36.7C466 510 461.1 512 456 512s-10-2-13.7-5.7L369 433l-40 40c-6.9 6.9-17.2 8.9-26.2 5.2s-14.8-12.5-14.8-22.2l0-144c0-13.3 10.7-24 24-24l144 0zm-256 0c13.3 0 24 10.7 24 24l0 144c0 9.7-5.8 18.5-14.8 22.2s-19.3 1.7-26.2-5.2l-40-40L69.7 506.3C66 510 61.1 512 56 512s-10-2-13.7-5.7L5.7 469.7C2 466 0 461.1 0 456s2-10 5.7-13.7L79 369 39 329c-6.9-6.9-8.9-17.2-5.2-26.2s12.5-14.8 22.2-14.8l144 0zM56 224c-9.7 0-18.5-5.8-22.2-14.8s-1.7-19.3 5.2-26.2l40-40L5.7 69.7C2 66 0 61.1 0 56s2-10 5.7-13.7L42.3 5.7C46 2 50.9 0 56 0s10 2 13.7 5.7L143 79l40-40c6.9-6.9 17.2-8.9 26.2-5.2s14.8 12.5 14.8 22.2l0 144c0 13.3-10.7 24-24 24L56 224z\"]\n};\nconst faCompressArrowsAlt = faMinimize;\nconst faMonument = {\n prefix: 'fas',\n iconName: 'monument',\n icon: [384, 512, [], \"f5a6\", \"M180.7 4.7c6.2-6.2 16.4-6.2 22.6 0l80 80c2.5 2.5 4.1 5.8 4.6 9.3l40.2 322L55.9 416 96.1 94c.4-3.5 2-6.8 4.6-9.3l80-80zM152 272c-13.3 0-24 10.7-24 24s10.7 24 24 24l80 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-80 0zM32 448l320 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L32 512c-17.7 0-32-14.3-32-32s14.3-32 32-32z\"]\n};\nconst faSnowplow = {\n prefix: 'fas',\n iconName: 'snowplow',\n icon: [640, 512, [], \"f7d2\", \"M298.9 64l68.6 160L256 224l-64-64 0-96 106.9 0zM445.1 242.7l-87.4-204C347.6 15.3 324.5 0 298.9 0L176 0c-26.5 0-48 21.5-48 48l0 112-32 0c-17.7 0-32 14.3-32 32l0 106.8C26.2 316.8 0 355.3 0 400c0 61.9 50.1 112 112 112l256 0c61.9 0 112-50.1 112-112c0-17.2-3.9-33.5-10.8-48l42.8 0 0 50.7c0 17 6.7 33.3 18.7 45.3l54.6 54.6c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3L576 402.7l0-82.7 0-84.8L633 164c11-13.8 8.8-33.9-5-45s-33.9-8.8-45 5l-57 71.2c-9.1 11.3-14 25.4-14 40l0 52.8-64 0 0-31.3c.1-2.4-.2-4.8-.6-7.1s-1.2-4.7-2.2-6.8zM368 352c26.5 0 48 21.5 48 48s-21.5 48-48 48l-256 0c-26.5 0-48-21.5-48-48s21.5-48 48-48l256 0zM144 400a24 24 0 1 0 -48 0 24 24 0 1 0 48 0zm216 24a24 24 0 1 0 0-48 24 24 0 1 0 0 48zm-56-24a24 24 0 1 0 -48 0 24 24 0 1 0 48 0zM200 424a24 24 0 1 0 0-48 24 24 0 1 0 0 48z\"]\n};\nconst faAnglesRight = {\n prefix: 'fas',\n iconName: 'angles-right',\n icon: [512, 512, [187, \"angle-double-right\"], \"f101\", \"M470.6 278.6c12.5-12.5 12.5-32.8 0-45.3l-160-160c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3L402.7 256 265.4 393.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0l160-160zm-352 160l160-160c12.5-12.5 12.5-32.8 0-45.3l-160-160c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3L210.7 256 73.4 393.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0z\"]\n};\nconst faAngleDoubleRight = faAnglesRight;\nconst faCannabis = {\n prefix: 'fas',\n iconName: 'cannabis',\n icon: [512, 512, [], \"f55f\", \"M256 0c5.3 0 10.3 2.7 13.3 7.1c15.8 23.5 36.7 63.7 49.2 109c7.2 26.4 11.8 55.2 10.4 84c11.5-8.8 23.7-16.7 35.8-23.6c41-23.3 84.4-36.9 112.2-42.5c5.2-1 10.7 .6 14.4 4.4s5.4 9.2 4.4 14.5c-5.6 27.7-19.3 70.9-42.7 111.7c-9.1 15.9-19.9 31.7-32.4 46.3c27.8 6.6 52.4 17.3 67.2 25.5c5.1 2.8 8.2 8.2 8.2 14s-3.2 11.2-8.2 14c-15.2 8.4-40.9 19.5-69.8 26.1c-20.2 4.6-42.9 7.2-65.2 4.6l8.3 33.1c1.5 6.1-.6 12.4-5.5 16.4s-11.6 4.6-17.2 1.9L280 417.2l0 70.8c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-70.8-58.5 29.1c-5.6 2.8-12.3 2.1-17.2-1.9s-7-10.3-5.5-16.4l8.3-33.1c-22.2 2.6-45 0-65.2-4.6c-28.9-6.6-54.6-17.6-69.8-26.1c-5.1-2.8-8.2-8.2-8.2-14s3.2-11.2 8.2-14c14.8-8.2 39.4-18.8 67.2-25.5C78.9 296.3 68.1 280.5 59 264.6c-23.4-40.8-37.1-84-42.7-111.7c-1.1-5.2 .6-10.7 4.4-14.5s9.2-5.4 14.4-4.4c27.9 5.5 71.2 19.2 112.2 42.5c12.1 6.9 24.3 14.7 35.8 23.6c-1.4-28.7 3.1-57.6 10.4-84c12.5-45.3 33.4-85.5 49.2-109c3-4.4 8-7.1 13.3-7.1z\"]\n};\nconst faCirclePlay = {\n prefix: 'fas',\n iconName: 'circle-play',\n icon: [512, 512, [61469, \"play-circle\"], \"f144\", \"M0 256a256 256 0 1 1 512 0A256 256 0 1 1 0 256zM188.3 147.1c-7.6 4.2-12.3 12.3-12.3 20.9l0 176c0 8.7 4.7 16.7 12.3 20.9s16.8 4.1 24.3-.5l144-88c7.1-4.4 11.5-12.1 11.5-20.5s-4.4-16.1-11.5-20.5l-144-88c-7.4-4.5-16.7-4.7-24.3-.5z\"]\n};\nconst faPlayCircle = faCirclePlay;\nconst faTablets = {\n prefix: 'fas',\n iconName: 'tablets',\n icon: [640, 512, [], \"f490\", \"M614.3 247c-5.2 7.9-16.2 8.5-22.9 1.8L391.2 48.6c-6.7-6.7-6.2-17.8 1.8-22.9C418.1 9.4 447.9 0 480 0c88.4 0 160 71.6 160 160c0 32.1-9.4 61.9-25.7 87zM567 294.3c-25 16.3-54.9 25.7-87 25.7c-88.4 0-160-71.6-160-160c0-32.1 9.4-61.9 25.7-87c5.2-7.9 16.2-8.5 22.9-1.8L568.8 271.4c6.7 6.7 6.2 17.8-1.8 22.9zM301.5 368c9.5 0 16.9 8.2 15 17.5C301.1 457.8 236.9 512 160 512S18.9 457.8 3.5 385.5c-2-9.3 5.5-17.5 15-17.5l283.1 0zm0-32L18.5 336c-9.5 0-16.9-8.2-15-17.5C18.9 246.2 83.1 192 160 192s141.1 54.2 156.5 126.5c2 9.3-5.5 17.5-15 17.5z\"]\n};\nconst faEthernet = {\n prefix: 'fas',\n iconName: 'ethernet',\n icon: [512, 512, [], \"f796\", \"M0 224L0 416c0 17.7 14.3 32 32 32l64 0 0-112c0-8.8 7.2-16 16-16s16 7.2 16 16l0 112 64 0 0-112c0-8.8 7.2-16 16-16s16 7.2 16 16l0 112 64 0 0-112c0-8.8 7.2-16 16-16s16 7.2 16 16l0 112 64 0 0-112c0-8.8 7.2-16 16-16s16 7.2 16 16l0 112 64 0c17.7 0 32-14.3 32-32l0-192c0-17.7-14.3-32-32-32l-32 0 0-32c0-17.7-14.3-32-32-32l-32 0 0-32c0-17.7-14.3-32-32-32L160 64c-17.7 0-32 14.3-32 32l0 32-32 0c-17.7 0-32 14.3-32 32l0 32-32 0c-17.7 0-32 14.3-32 32z\"]\n};\nconst faEuroSign = {\n prefix: 'fas',\n iconName: 'euro-sign',\n icon: [320, 512, [8364, \"eur\", \"euro\"], \"f153\", \"M48.1 240c-.1 2.7-.1 5.3-.1 8l0 16c0 2.7 0 5.3 .1 8L32 272c-17.7 0-32 14.3-32 32s14.3 32 32 32l28.3 0C89.9 419.9 170 480 264 480l24 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-24 0c-57.9 0-108.2-32.4-133.9-80L256 336c17.7 0 32-14.3 32-32s-14.3-32-32-32l-143.8 0c-.1-2.6-.2-5.3-.2-8l0-16c0-2.7 .1-5.4 .2-8L256 240c17.7 0 32-14.3 32-32s-14.3-32-32-32l-125.9 0c25.7-47.6 76-80 133.9-80l24 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-24 0C170 32 89.9 92.1 60.3 176L32 176c-17.7 0-32 14.3-32 32s14.3 32 32 32l16.1 0z\"]\n};\nconst faEur = faEuroSign;\nconst faEuro = faEuroSign;\nconst faChair = {\n prefix: 'fas',\n iconName: 'chair',\n icon: [448, 512, [129681], \"f6c0\", \"M248 48l0 208 48 0 0-197.3c23.9 13.8 40 39.7 40 69.3l0 128 48 0 0-128C384 57.3 326.7 0 256 0L192 0C121.3 0 64 57.3 64 128l0 128 48 0 0-128c0-29.6 16.1-55.5 40-69.3L152 256l48 0 0-208 48 0zM48 288c-12.1 0-23.2 6.8-28.6 17.7l-16 32c-5 9.9-4.4 21.7 1.4 31.1S20.9 384 32 384l0 96c0 17.7 14.3 32 32 32s32-14.3 32-32l0-96 256 0 0 96c0 17.7 14.3 32 32 32s32-14.3 32-32l0-96c11.1 0 21.4-5.7 27.2-15.2s6.4-21.2 1.4-31.1l-16-32C423.2 294.8 412.1 288 400 288L48 288z\"]\n};\nconst faCircleCheck = {\n prefix: 'fas',\n iconName: 'circle-check',\n icon: [512, 512, [61533, \"check-circle\"], \"f058\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM369 209L241 337c-9.4 9.4-24.6 9.4-33.9 0l-64-64c-9.4-9.4-9.4-24.6 0-33.9s24.6-9.4 33.9 0l47 47L335 175c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9z\"]\n};\nconst faCheckCircle = faCircleCheck;\nconst faCircleStop = {\n prefix: 'fas',\n iconName: 'circle-stop',\n icon: [512, 512, [62094, \"stop-circle\"], \"f28d\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM192 160l128 0c17.7 0 32 14.3 32 32l0 128c0 17.7-14.3 32-32 32l-128 0c-17.7 0-32-14.3-32-32l0-128c0-17.7 14.3-32 32-32z\"]\n};\nconst faStopCircle = faCircleStop;\nconst faCompassDrafting = {\n prefix: 'fas',\n iconName: 'compass-drafting',\n icon: [512, 512, [\"drafting-compass\"], \"f568\", \"M352 96c0 14.3-3.1 27.9-8.8 40.2L396 227.4c-23.7 25.3-54.2 44.1-88.5 53.6L256 192c0 0 0 0 0 0s0 0 0 0l-68 117.5c21.5 6.8 44.3 10.5 68.1 10.5c70.7 0 133.8-32.7 174.9-84c11.1-13.8 31.2-16 45-5s16 31.2 5 45C428.1 341.8 347 384 256 384c-35.4 0-69.4-6.4-100.7-18.1L98.7 463.7C94 471.8 87 478.4 78.6 482.6L23.2 510.3c-5 2.5-10.9 2.2-15.6-.7S0 501.5 0 496l0-55.4c0-8.4 2.2-16.7 6.5-24.1l60-103.7C53.7 301.6 41.8 289.3 31.2 276c-11.1-13.8-8.8-33.9 5-45s33.9-8.8 45 5c5.7 7.1 11.8 13.8 18.2 20.1l69.4-119.9c-5.6-12.2-8.8-25.8-8.8-40.2c0-53 43-96 96-96s96 43 96 96zm21 297.9c32.6-12.8 62.5-30.8 88.9-52.9l43.7 75.5c4.2 7.3 6.5 15.6 6.5 24.1l0 55.4c0 5.5-2.9 10.7-7.6 13.6s-10.6 3.2-15.6 .7l-55.4-27.7c-8.4-4.2-15.4-10.8-20.1-18.9L373 393.9zM256 128a32 32 0 1 0 0-64 32 32 0 1 0 0 64z\"]\n};\nconst faDraftingCompass = faCompassDrafting;\nconst faPlateWheat = {\n prefix: 'fas',\n iconName: 'plate-wheat',\n icon: [512, 512, [], \"e55a\", \"M176 32c44.2 0 80 35.8 80 80l0 16c0 8.8-7.2 16-16 16c-44.2 0-80-35.8-80-80l0-16c0-8.8 7.2-16 16-16zM56 64l48 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-48 0c-13.3 0-24-10.7-24-24s10.7-24 24-24zM24 136l112 0c13.3 0 24 10.7 24 24s-10.7 24-24 24L24 184c-13.3 0-24-10.7-24-24s10.7-24 24-24zm8 96c0-13.3 10.7-24 24-24l48 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-48 0c-13.3 0-24-10.7-24-24zM272 48c0-8.8 7.2-16 16-16c44.2 0 80 35.8 80 80l0 16c0 8.8-7.2 16-16 16c-44.2 0-80-35.8-80-80l0-16zM400 32c44.2 0 80 35.8 80 80l0 16c0 8.8-7.2 16-16 16c-44.2 0-80-35.8-80-80l0-16c0-8.8 7.2-16 16-16zm80 160l0 16c0 44.2-35.8 80-80 80c-8.8 0-16-7.2-16-16l0-16c0-44.2 35.8-80 80-80c8.8 0 16 7.2 16 16zM352 176c8.8 0 16 7.2 16 16l0 16c0 44.2-35.8 80-80 80c-8.8 0-16-7.2-16-16l0-16c0-44.2 35.8-80 80-80zm-96 16l0 16c0 44.2-35.8 80-80 80c-8.8 0-16-7.2-16-16l0-16c0-44.2 35.8-80 80-80c8.8 0 16 7.2 16 16zM3.5 347.6C1.6 332.9 13 320 27.8 320l456.4 0c14.8 0 26.2 12.9 24.4 27.6C502.3 397.8 464.2 437 416 446l0 2c0 17.7-14.3 32-32 32l-256 0c-17.7 0-32-14.3-32-32l0-2c-48.2-9-86.3-48.2-92.5-98.4z\"]\n};\nconst faIcicles = {\n prefix: 'fas',\n iconName: 'icicles',\n icon: [512, 512, [], \"f7ad\", \"M75.8 304.8L1 35.7c-.7-2.5-1-5-1-7.5C0 12.6 12.6 0 28.2 0H482.4C498.8 0 512 13.2 512 29.6c0 1.6-.1 3.3-.4 4.9L434.6 496.1c-1.5 9.2-9.5 15.9-18.8 15.9c-9.2 0-17.1-6.6-18.7-15.6L336 160 307.2 303.9c-1.9 9.3-10.1 16.1-19.6 16.1c-9.2 0-17.2-6.2-19.4-15.1L240 192 210.6 368.2c-1.5 9.1-9.4 15.8-18.6 15.8s-17.1-6.7-18.6-15.8L144 192 115.9 304.3c-2.3 9.2-10.6 15.7-20.1 15.7c-9.3 0-17.5-6.2-20-15.2z\"]\n};\nconst faPersonShelter = {\n prefix: 'fas',\n iconName: 'person-shelter',\n icon: [512, 512, [], \"e54f\", \"M271.9 4.2c-9.8-5.6-21.9-5.6-31.8 0l-224 128C6.2 137.9 0 148.5 0 160L0 480c0 17.7 14.3 32 32 32s32-14.3 32-32l0-301.4L256 68.9 448 178.6 448 480c0 17.7 14.3 32 32 32s32-14.3 32-32l0-320c0-11.5-6.2-22.1-16.1-27.8l-224-128zM256 208a40 40 0 1 0 0-80 40 40 0 1 0 0 80zm-8 280l0-88 16 0 0 88c0 13.3 10.7 24 24 24s24-10.7 24-24l0-174.5 26.9 49.9c6.3 11.7 20.8 16 32.5 9.8s16-20.8 9.8-32.5l-37.9-70.3c-15.3-28.5-45.1-46.3-77.5-46.3l-19.5 0c-32.4 0-62.1 17.8-77.5 46.3l-37.9 70.3c-6.3 11.7-1.9 26.2 9.8 32.5s26.2 1.9 32.5-9.8L200 313.5 200 488c0 13.3 10.7 24 24 24s24-10.7 24-24z\"]\n};\nconst faNeuter = {\n prefix: 'fas',\n iconName: 'neuter',\n icon: [384, 512, [9906], \"f22c\", \"M80 176a112 112 0 1 1 224 0A112 112 0 1 1 80 176zM224 349.1c81.9-15 144-86.8 144-173.1C368 78.8 289.2 0 192 0S16 78.8 16 176c0 86.3 62.1 158.1 144 173.1L160 480c0 17.7 14.3 32 32 32s32-14.3 32-32l0-130.9z\"]\n};\nconst faIdBadge = {\n prefix: 'fas',\n iconName: 'id-badge',\n icon: [384, 512, [], \"f2c1\", \"M64 0C28.7 0 0 28.7 0 64L0 448c0 35.3 28.7 64 64 64l256 0c35.3 0 64-28.7 64-64l0-384c0-35.3-28.7-64-64-64L64 0zm96 320l64 0c44.2 0 80 35.8 80 80c0 8.8-7.2 16-16 16L96 416c-8.8 0-16-7.2-16-16c0-44.2 35.8-80 80-80zm-32-96a64 64 0 1 1 128 0 64 64 0 1 1 -128 0zM144 64l96 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-96 0c-8.8 0-16-7.2-16-16s7.2-16 16-16z\"]\n};\nconst faMarker = {\n prefix: 'fas',\n iconName: 'marker',\n icon: [512, 512, [], \"f5a1\", \"M481 31C445.1-4.8 386.9-4.8 351 31l-15 15L322.9 33C294.8 4.9 249.2 4.9 221.1 33L135 119c-9.4 9.4-9.4 24.6 0 33.9s24.6 9.4 33.9 0L255 66.9c9.4-9.4 24.6-9.4 33.9 0L302.1 80 186.3 195.7 316.3 325.7 481 161c35.9-35.9 35.9-94.1 0-129.9zM293.7 348.3L163.7 218.3 99.5 282.5c-48 48-80.8 109.2-94.1 175.8l-5 25c-1.6 7.9 .9 16 6.6 21.7s13.8 8.1 21.7 6.6l25-5c66.6-13.3 127.8-46.1 175.8-94.1l64.2-64.2z\"]\n};\nconst faFaceLaughBeam = {\n prefix: 'fas',\n iconName: 'face-laugh-beam',\n icon: [512, 512, [128513, \"laugh-beam\"], \"f59a\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM96.8 314.1c-3.8-13.7 7.4-26.1 21.6-26.1l275.2 0c14.2 0 25.5 12.4 21.6 26.1C396.2 382 332.1 432 256 432s-140.2-50-159.2-117.9zM217.6 212.8s0 0 0 0c0 0 0 0 0 0l-.2-.2c-.2-.2-.4-.5-.7-.9c-.6-.8-1.6-2-2.8-3.4c-2.5-2.8-6-6.6-10.2-10.3c-8.8-7.8-18.8-14-27.7-14s-18.9 6.2-27.7 14c-4.2 3.7-7.7 7.5-10.2 10.3c-1.2 1.4-2.2 2.6-2.8 3.4c-.3 .4-.6 .7-.7 .9l-.2 .2c0 0 0 0 0 0c0 0 0 0 0 0s0 0 0 0c-2.1 2.8-5.7 3.9-8.9 2.8s-5.5-4.1-5.5-7.6c0-17.9 6.7-35.6 16.6-48.8c9.8-13 23.9-23.2 39.4-23.2s29.6 10.2 39.4 23.2c9.9 13.2 16.6 30.9 16.6 48.8c0 3.4-2.2 6.5-5.5 7.6s-6.9 0-8.9-2.8c0 0 0 0 0 0s0 0 0 0zm160 0c0 0 0 0 0 0l-.2-.2c-.2-.2-.4-.5-.7-.9c-.6-.8-1.6-2-2.8-3.4c-2.5-2.8-6-6.6-10.2-10.3c-8.8-7.8-18.8-14-27.7-14s-18.9 6.2-27.7 14c-4.2 3.7-7.7 7.5-10.2 10.3c-1.2 1.4-2.2 2.6-2.8 3.4c-.3 .4-.6 .7-.7 .9l-.2 .2c0 0 0 0 0 0c0 0 0 0 0 0s0 0 0 0c-2.1 2.8-5.7 3.9-8.9 2.8s-5.5-4.1-5.5-7.6c0-17.9 6.7-35.6 16.6-48.8c9.8-13 23.9-23.2 39.4-23.2s29.6 10.2 39.4 23.2c9.9 13.2 16.6 30.9 16.6 48.8c0 3.4-2.2 6.5-5.5 7.6s-6.9 0-8.9-2.8c0 0 0 0 0 0s0 0 0 0s0 0 0 0z\"]\n};\nconst faLaughBeam = faFaceLaughBeam;\nconst faHelicopterSymbol = {\n prefix: 'fas',\n iconName: 'helicopter-symbol',\n icon: [512, 512, [], \"e502\", \"M445.3 224l64.7 0C495.6 108.2 403.8 16.4 288 2l0 64.7C368.4 80.1 431.9 143.6 445.3 224zM510 288l-64.7 0C431.9 368.4 368.4 431.9 288 445.3l0 64.7c115.8-14.4 207.6-106.2 222-222zM2 288C16.4 403.8 108.2 495.6 224 510l0-64.7C143.6 431.9 80.1 368.4 66.7 288L2 288zm0-64l64.7 0C80.1 143.6 143.6 80.1 224 66.7L224 2C108.2 16.4 16.4 108.2 2 224zm206-64c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 192c0 17.7 14.3 32 32 32s32-14.3 32-32l0-64 96 0 0 64c0 17.7 14.3 32 32 32s32-14.3 32-32l0-192c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 64-96 0 0-64z\"]\n};\nconst faUniversalAccess = {\n prefix: 'fas',\n iconName: 'universal-access',\n icon: [512, 512, [], \"f29a\", \"M0 256a256 256 0 1 1 512 0A256 256 0 1 1 0 256zm161.5-86.1c-12.2-5.2-26.3 .4-31.5 12.6s.4 26.3 12.6 31.5l11.9 5.1c17.3 7.4 35.2 12.9 53.6 16.3l0 50.1c0 4.3-.7 8.6-2.1 12.6l-28.7 86.1c-4.2 12.6 2.6 26.2 15.2 30.4s26.2-2.6 30.4-15.2l24.4-73.2c1.3-3.8 4.8-6.4 8.8-6.4s7.6 2.6 8.8 6.4l24.4 73.2c4.2 12.6 17.8 19.4 30.4 15.2s19.4-17.8 15.2-30.4l-28.7-86.1c-1.4-4.1-2.1-8.3-2.1-12.6l0-50.1c18.4-3.5 36.3-8.9 53.6-16.3l11.9-5.1c12.2-5.2 17.8-19.3 12.6-31.5s-19.3-17.8-31.5-12.6L338.7 175c-26.1 11.2-54.2 17-82.7 17s-56.5-5.8-82.7-17l-11.9-5.1zM256 160a40 40 0 1 0 0-80 40 40 0 1 0 0 80z\"]\n};\nconst faCircleChevronUp = {\n prefix: 'fas',\n iconName: 'circle-chevron-up',\n icon: [512, 512, [\"chevron-circle-up\"], \"f139\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM377 271c9.4 9.4 9.4 24.6 0 33.9s-24.6 9.4-33.9 0l-87-87-87 87c-9.4 9.4-24.6 9.4-33.9 0s-9.4-24.6 0-33.9L239 167c9.4-9.4 24.6-9.4 33.9 0L377 271z\"]\n};\nconst faChevronCircleUp = faCircleChevronUp;\nconst faLariSign = {\n prefix: 'fas',\n iconName: 'lari-sign',\n icon: [384, 512, [], \"e1c8\", \"M144 32c17.7 0 32 14.3 32 32l0 32.7c5.3-.4 10.6-.7 16-.7s10.7 .2 16 .7L208 64c0-17.7 14.3-32 32-32s32 14.3 32 32l0 49.4c54.9 25.2 95.8 75.5 108.2 136.2c3.5 17.3-7.7 34.2-25 37.7s-34.2-7.7-37.7-25c-6.1-29.9-22.5-55.9-45.4-74.3l0 67.9c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-95c-5.2-.7-10.6-1-16-1s-10.8 .3-16 1l0 95c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-67.9C82.7 211.5 64 247.6 64 288c0 70.7 57.3 128 128 128l160 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-160 0L32 480c-17.7 0-32-14.3-32-32s14.3-32 32-32l16.9 0C18.5 382 0 337.2 0 288c0-77.5 45.9-144.3 112-174.6L112 64c0-17.7 14.3-32 32-32z\"]\n};\nconst faVolcano = {\n prefix: 'fas',\n iconName: 'volcano',\n icon: [512, 512, [127755], \"f770\", \"M160 144c-35.3 0-64-28.7-64-64s28.7-64 64-64c15.7 0 30 5.6 41.2 15C212.4 12.4 232.7 0 256 0s43.6 12.4 54.8 31C322 21.6 336.3 16 352 16c35.3 0 64 28.7 64 64s-28.7 64-64 64c-14.7 0-28.3-5-39.1-13.3l-32 48C275.3 187 266 192 256 192s-19.3-5-24.9-13.3l-32-48C188.3 139 174.7 144 160 144zM144 352l48.4-24.2c10.2-5.1 21.6-7.8 33-7.8c19.6 0 38.4 7.8 52.2 21.6l32.5 32.5c6.3 6.3 14.9 9.9 23.8 9.9c11.3 0 21.8-5.6 28-15l9.7-14.6-58.9-66.3c-9.1-10.2-22.2-16.1-35.9-16.1l-41.8 0c-13.7 0-26.8 5.9-35.9 16.1l-59.9 67.4L144 352zm19.4-95.8c18.2-20.5 44.3-32.2 71.8-32.2l41.8 0c27.4 0 53.5 11.7 71.8 32.2l150.2 169c8.5 9.5 13.2 21.9 13.2 34.7c0 28.8-23.4 52.2-52.2 52.2L52.2 512C23.4 512 0 488.6 0 459.8c0-12.8 4.7-25.1 13.2-34.7l150.2-169z\"]\n};\nconst faPersonWalkingDashedLineArrowRight = {\n prefix: 'fas',\n iconName: 'person-walking-dashed-line-arrow-right',\n icon: [640, 512, [], \"e553\", \"M208 96a48 48 0 1 0 0-96 48 48 0 1 0 0 96zM123.7 200.5c1-.4 1.9-.8 2.9-1.2l-16.9 63.5c-5.6 21.1-.1 43.6 14.7 59.7l70.7 77.1 22 88.1c4.3 17.1 21.7 27.6 38.8 23.3s27.6-21.7 23.3-38.8l-23-92.1c-1.9-7.8-5.8-14.9-11.2-20.8l-49.5-54 19.3-65.5 9.6 23c4.4 10.6 12.5 19.3 22.8 24.5l26.7 13.3c15.8 7.9 35 1.5 42.9-14.3s1.5-35-14.3-42.9L281 232.7l-15.3-36.8C248.5 154.8 208.3 128 163.7 128c-22.8 0-45.3 4.8-66.1 14l-8 3.5c-32.9 14.6-58.1 42.4-69.4 76.5l-2.6 7.8c-5.6 16.8 3.5 34.9 20.2 40.5s34.9-3.5 40.5-20.2l2.6-7.8c5.7-17.1 18.3-30.9 34.7-38.2l8-3.5zm-30 135.1L68.7 398 9.4 457.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0L116.3 441c4.6-4.6 8.2-10.1 10.6-16.1l14.5-36.2-40.7-44.4c-2.5-2.7-4.8-5.6-7-8.6zM550.6 153.4c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3L530.7 224 384 224c-17.7 0-32 14.3-32 32s14.3 32 32 32l146.7 0-25.4 25.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0l80-80c12.5-12.5 12.5-32.8 0-45.3l-80-80zM392 0c-13.3 0-24 10.7-24 24l0 48c0 13.3 10.7 24 24 24s24-10.7 24-24l0-48c0-13.3-10.7-24-24-24zm24 152c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 16c0 13.3 10.7 24 24 24s24-10.7 24-24l0-16zM392 320c-13.3 0-24 10.7-24 24l0 16c0 13.3 10.7 24 24 24s24-10.7 24-24l0-16c0-13.3-10.7-24-24-24zm24 120c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 48c0 13.3 10.7 24 24 24s24-10.7 24-24l0-48z\"]\n};\nconst faSterlingSign = {\n prefix: 'fas',\n iconName: 'sterling-sign',\n icon: [320, 512, [163, \"gbp\", \"pound-sign\"], \"f154\", \"M112 160.4c0-35.5 28.8-64.4 64.4-64.4c6.9 0 13.8 1.1 20.4 3.3l81.2 27.1c16.8 5.6 34.9-3.5 40.5-20.2s-3.5-34.9-20.2-40.5L217 38.6c-13.1-4.4-26.8-6.6-40.6-6.6C105.5 32 48 89.5 48 160.4L48 224l-16 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l16 0 0 44.5c0 17.4-4.7 34.5-13.7 49.4L4.6 431.5c-5.9 9.9-6.1 22.2-.4 32.2S20.5 480 32 480l256 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L88.5 416l.7-1.1C104.1 390 112 361.5 112 332.5l0-44.5 112 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-112 0 0-63.6z\"]\n};\nconst faGbp = faSterlingSign;\nconst faPoundSign = faSterlingSign;\nconst faViruses = {\n prefix: 'fas',\n iconName: 'viruses',\n icon: [640, 512, [], \"e076\", \"M192 0c13.3 0 24 10.7 24 24l0 13.5c0 35.6 43.1 53.5 68.3 28.3l9.5-9.5c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9l-9.5 9.5C293 124.9 310.9 168 346.5 168l13.5 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-13.5 0c-35.6 0-53.5 43.1-28.3 68.3l9.5 9.5c9.4 9.4 9.4 24.6 0 33.9s-24.6 9.4-33.9 0l-9.5-9.5C259.1 293 216 310.9 216 346.5l0 13.5c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-13.5c0-35.6-43.1-53.5-68.3-28.3l-9.5 9.5c-9.4 9.4-24.6 9.4-33.9 0s-9.4-24.6 0-33.9l9.5-9.5C91 259.1 73.1 216 37.5 216L24 216c-13.3 0-24-10.7-24-24s10.7-24 24-24l13.5 0c35.6 0 53.5-43.1 28.3-68.3l-9.5-9.5c-9.4-9.4-9.4-24.6 0-33.9s24.6-9.4 33.9 0l9.5 9.5C124.9 91 168 73.1 168 37.5L168 24c0-13.3 10.7-24 24-24zm48 224a16 16 0 1 0 0-32 16 16 0 1 0 0 32zm-48-64a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zm320 80c0 33 39.9 49.5 63.2 26.2c6.2-6.2 16.4-6.2 22.6 0s6.2 16.4 0 22.6C574.5 312.1 591 352 624 352c8.8 0 16 7.2 16 16s-7.2 16-16 16c-33 0-49.5 39.9-26.2 63.2c6.2 6.2 6.2 16.4 0 22.6s-16.4 6.2-22.6 0C551.9 446.5 512 463 512 496c0 8.8-7.2 16-16 16s-16-7.2-16-16c0-33-39.9-49.5-63.2-26.2c-6.2 6.2-16.4 6.2-22.6 0s-6.2-16.4 0-22.6C417.5 423.9 401 384 368 384c-8.8 0-16-7.2-16-16s7.2-16 16-16c33 0 49.5-39.9 26.2-63.2c-6.2-6.2-6.2-16.4 0-22.6s16.4-6.2 22.6 0C440.1 289.5 480 273 480 240c0-8.8 7.2-16 16-16s16 7.2 16 16zm0 112a32 32 0 1 0 -64 0 32 32 0 1 0 64 0z\"]\n};\nconst faSquarePersonConfined = {\n prefix: 'fas',\n iconName: 'square-person-confined',\n icon: [448, 512, [], \"e577\", \"M64 32C28.7 32 0 60.7 0 96L0 416c0 35.3 28.7 64 64 64l320 0c35.3 0 64-28.7 64-64l0-320c0-35.3-28.7-64-64-64L64 32zm96 112a48 48 0 1 1 96 0 48 48 0 1 1 -96 0zm80 104c0-30.9 25.1-56 56-56s56 25.1 56 56l0 102.1c0 36.4-29.5 65.9-65.9 65.9c-17.5 0-34.3-6.9-46.6-19.3L184.8 342l-28.1 56.3c-7.9 15.8-27.1 22.2-42.9 14.3s-22.2-27.1-14.3-42.9l48-96c4.6-9.2 13.3-15.6 23.5-17.3s20.5 1.7 27.8 9L240 306.7l0-58.7z\"]\n};\nconst faUserTie = {\n prefix: 'fas',\n iconName: 'user-tie',\n icon: [448, 512, [], \"f508\", \"M96 128a128 128 0 1 0 256 0A128 128 0 1 0 96 128zm94.5 200.2l18.6 31L175.8 483.1l-36-146.9c-2-8.1-9.8-13.4-17.9-11.3C51.9 342.4 0 405.8 0 481.3c0 17 13.8 30.7 30.7 30.7l131.7 0c0 0 0 0 .1 0l5.5 0 112 0 5.5 0c0 0 0 0 .1 0l131.7 0c17 0 30.7-13.8 30.7-30.7c0-75.5-51.9-138.9-121.9-156.4c-8.1-2-15.9 3.3-17.9 11.3l-36 146.9L238.9 359.2l18.6-31c6.4-10.7-1.3-24.2-13.7-24.2L224 304l-19.7 0c-12.4 0-20.1 13.6-13.7 24.2z\"]\n};\nconst faArrowDownLong = {\n prefix: 'fas',\n iconName: 'arrow-down-long',\n icon: [384, 512, [\"long-arrow-down\"], \"f175\", \"M169.4 502.6c12.5 12.5 32.8 12.5 45.3 0l128-128c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0L224 402.7 224 32c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 370.7L86.6 329.4c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3l128 128z\"]\n};\nconst faLongArrowDown = faArrowDownLong;\nconst faTentArrowDownToLine = {\n prefix: 'fas',\n iconName: 'tent-arrow-down-to-line',\n icon: [640, 512, [], \"e57e\", \"M241.8 111.9c8.9 9.9 8.1 25-1.8 33.9l-80 72c-9.1 8.2-23 8.2-32.1 0l-80-72c-9.9-8.9-10.7-24-1.8-33.9s24-10.7 33.9-1.8l39.9 36L120 24c0-13.3 10.7-24 24-24s24 10.7 24 24l0 122.1 39.9-36c9.9-8.9 25-8.1 33.9 1.8zm122.8 22.6c11.5-8.7 27.3-8.7 38.8 0l168 128c6.6 5 11 12.5 12.3 20.7l24 160 .7 4.7c17.5 .2 31.6 14.4 31.6 32c0 17.7-14.3 32-32 32L32 512c-17.7 0-32-14.3-32-32s14.3-32 32-32l127.6 0 .7-4.7 24-160c1.2-8.2 5.6-15.7 12.3-20.7l168-128zM384 448l80 0L402.7 325.5c-1.7-3.4-5.1-5.5-8.8-5.5c-5.5 0-9.9 4.4-9.9 9.9L384 448z\"]\n};\nconst faCertificate = {\n prefix: 'fas',\n iconName: 'certificate',\n icon: [512, 512, [], \"f0a3\", \"M211 7.3C205 1 196-1.4 187.6 .8s-14.9 8.9-17.1 17.3L154.7 80.6l-62-17.5c-8.4-2.4-17.4 0-23.5 6.1s-8.5 15.1-6.1 23.5l17.5 62L18.1 170.6c-8.4 2.1-15 8.7-17.3 17.1S1 205 7.3 211l46.2 45L7.3 301C1 307-1.4 316 .8 324.4s8.9 14.9 17.3 17.1l62.5 15.8-17.5 62c-2.4 8.4 0 17.4 6.1 23.5s15.1 8.5 23.5 6.1l62-17.5 15.8 62.5c2.1 8.4 8.7 15 17.1 17.3s17.3-.2 23.4-6.4l45-46.2 45 46.2c6.1 6.2 15 8.7 23.4 6.4s14.9-8.9 17.1-17.3l15.8-62.5 62 17.5c8.4 2.4 17.4 0 23.5-6.1s8.5-15.1 6.1-23.5l-17.5-62 62.5-15.8c8.4-2.1 15-8.7 17.3-17.1s-.2-17.4-6.4-23.4l-46.2-45 46.2-45c6.2-6.1 8.7-15 6.4-23.4s-8.9-14.9-17.3-17.1l-62.5-15.8 17.5-62c2.4-8.4 0-17.4-6.1-23.5s-15.1-8.5-23.5-6.1l-62 17.5L341.4 18.1c-2.1-8.4-8.7-15-17.1-17.3S307 1 301 7.3L256 53.5 211 7.3z\"]\n};\nconst faReplyAll = {\n prefix: 'fas',\n iconName: 'reply-all',\n icon: [576, 512, [\"mail-reply-all\"], \"f122\", \"M209.4 39.5c-9.1-9.6-24.3-10-33.9-.9L33.8 173.2c-19.9 18.9-19.9 50.7 0 69.6L175.5 377.4c9.6 9.1 24.8 8.7 33.9-.9s8.7-24.8-.9-33.9L66.8 208 208.5 73.4c9.6-9.1 10-24.3 .9-33.9zM352 64c0-12.6-7.4-24.1-19-29.2s-25-3-34.4 5.4l-160 144c-6.7 6.1-10.6 14.7-10.6 23.8s3.9 17.7 10.6 23.8l160 144c9.4 8.5 22.9 10.6 34.4 5.4s19-16.6 19-29.2l0-64 32 0c53 0 96 43 96 96c0 30.4-12.8 47.9-22.2 56.7c-5.5 5.1-9.8 12-9.8 19.5c0 10.9 8.8 19.7 19.7 19.7c2.8 0 5.6-.6 8.1-1.9C494.5 467.9 576 417.3 576 304c0-97.2-78.8-176-176-176l-48 0 0-64z\"]\n};\nconst faMailReplyAll = faReplyAll;\nconst faSuitcase = {\n prefix: 'fas',\n iconName: 'suitcase',\n icon: [512, 512, [129523], \"f0f2\", \"M176 56l0 40 160 0 0-40c0-4.4-3.6-8-8-8L184 48c-4.4 0-8 3.6-8 8zM128 96l0-40c0-30.9 25.1-56 56-56L328 0c30.9 0 56 25.1 56 56l0 40 0 32 0 352-256 0 0-352 0-32zM64 96l32 0 0 384-32 0c-35.3 0-64-28.7-64-64L0 160c0-35.3 28.7-64 64-64zM448 480l-32 0 0-384 32 0c35.3 0 64 28.7 64 64l0 256c0 35.3-28.7 64-64 64z\"]\n};\nconst faPersonSkating = {\n prefix: 'fas',\n iconName: 'person-skating',\n icon: [448, 512, [\"skating\"], \"f7c5\", \"M352 48a48 48 0 1 1 96 0 48 48 0 1 1 -96 0zM128 128c0-17.7 14.3-32 32-32l159.4 0c43.6 0 64.6 53.4 32.8 83.1l-74.4 69.4 60.2 60.2c9 9 14.1 21.2 14.1 33.9l0 73.4c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-66.7-77.9-77.8c-26.6-26.6-24.6-70.3 4.3-94.4l20.4-17L160 160c-17.7 0-32-14.3-32-32zM81.4 353.4l86.9-86.9c4.6 10 11 19.3 19.3 27.5l21.8 21.8-82.7 82.7c-12.5 12.5-32.8 12.5-45.3 0s-12.5-32.8 0-45.3zm322.5 95.1c8.6 2.1 13.8 10.8 11.6 19.4l-.4 1.7c-6.2 24.9-28.6 42.4-54.3 42.4L272 512c-8.8 0-16-7.2-16-16s7.2-16 16-16l88.8 0c11 0 20.6-7.5 23.3-18.2l.4-1.7c2.1-8.6 10.8-13.8 19.4-11.6zM135.2 478.3l-6.2 3.1c-21.6 10.8-47.6 6.6-64.6-10.5L4.7 411.3c-6.2-6.2-6.2-16.4 0-22.6s16.4-6.2 22.6 0l59.6 59.6c7.3 7.3 18.5 9.1 27.7 4.5l6.2-3.1c7.9-4 17.5-.7 21.5 7.2s.7 17.5-7.2 21.5z\"]\n};\nconst faSkating = faPersonSkating;\nconst faFilterCircleDollar = {\n prefix: 'fas',\n iconName: 'filter-circle-dollar',\n icon: [576, 512, [\"funnel-dollar\"], \"f662\", \"M3.9 22.9C10.5 8.9 24.5 0 40 0L472 0c15.5 0 29.5 8.9 36.1 22.9s4.6 30.5-5.2 42.5L396.4 195.6C316.2 212.1 256 283 256 368c0 27.4 6.3 53.4 17.5 76.5c-1.6-.8-3.2-1.8-4.7-2.9l-64-48c-8.1-6-12.8-15.5-12.8-25.6l0-79.1L9 65.3C-.7 53.4-2.8 36.8 3.9 22.9zM288 368a144 144 0 1 1 288 0 144 144 0 1 1 -288 0zm120.8-32.6c.6-.9 1.8-2.1 4.2-3.4c5.1-2.7 12.5-4.1 18.7-4c8.2 .1 17.1 1.8 26.4 4.1c8.6 2.1 17.3-3.1 19.4-11.7s-3.1-17.3-11.7-19.4c-5.6-1.4-11.6-2.7-17.9-3.7l0-9.4c0-8.8-7.2-16-16-16s-16 7.2-16 16l0 9.5c-6.1 1.2-12.3 3.2-18 6.3c-11.8 6.3-23 18.4-21.8 37.2c1 16 11.7 25.3 21.6 30.7c8.8 4.7 19.7 7.8 28.6 10.3l1.8 .5c10.3 2.9 17.9 5.2 23.2 8.3c4.5 2.7 4.7 4.2 4.7 5.6c.1 2.4-.5 3.7-1 4.5c-.6 1-1.8 2.2-4 3.3c-4.7 2.5-11.8 3.8-18.5 3.6c-9.5-.3-18.5-3.1-29.9-6.8c-1.9-.6-3.8-1.2-5.8-1.8c-8.4-2.6-17.4 2.1-20 10.5s2.1 17.4 10.5 20c1.6 .5 3.3 1 5 1.6c0 0 0 0 0 0s0 0 0 0c7 2.3 15.1 4.8 23.7 6.6l0 11.4c0 8.8 7.2 16 16 16s16-7.2 16-16l0-10.8c6.2-1.1 12.5-3.1 18.3-6.2c12.1-6.5 22.3-18.7 21.7-36.9c-.5-16.2-10.3-26.3-20.5-32.3c-9.4-5.6-21.2-8.9-30.5-11.5l-.2 0c-10.4-2.9-18.3-5.2-23.9-8.2c-4.8-2.6-4.8-4-4.8-4.5c0 0 0 0 0-.1c-.1-1.9 .3-2.9 .8-3.6z\"]\n};\nconst faFunnelDollar = faFilterCircleDollar;\nconst faCameraRetro = {\n prefix: 'fas',\n iconName: 'camera-retro',\n icon: [512, 512, [128247], \"f083\", \"M220.6 121.2L271.1 96 448 96l0 96-114.8 0c-21.9-15.1-48.5-24-77.2-24s-55.2 8.9-77.2 24L64 192l0-64 128 0c9.9 0 19.7-2.3 28.6-6.8zM0 128L0 416c0 35.3 28.7 64 64 64l384 0c35.3 0 64-28.7 64-64l0-320c0-35.3-28.7-64-64-64L271.1 32c-9.9 0-19.7 2.3-28.6 6.8L192 64l-32 0 0-16c0-8.8-7.2-16-16-16L80 32c-8.8 0-16 7.2-16 16l0 16C28.7 64 0 92.7 0 128zM168 304a88 88 0 1 1 176 0 88 88 0 1 1 -176 0z\"]\n};\nconst faCircleArrowDown = {\n prefix: 'fas',\n iconName: 'circle-arrow-down',\n icon: [512, 512, [\"arrow-circle-down\"], \"f0ab\", \"M256 0a256 256 0 1 0 0 512A256 256 0 1 0 256 0zM127 297c-9.4-9.4-9.4-24.6 0-33.9s24.6-9.4 33.9 0l71 71L232 120c0-13.3 10.7-24 24-24s24 10.7 24 24l0 214.1 71-71c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L273 409c-9.4 9.4-24.6 9.4-33.9 0L127 297z\"]\n};\nconst faArrowCircleDown = faCircleArrowDown;\nconst faFileImport = {\n prefix: 'fas',\n iconName: 'file-import',\n icon: [512, 512, [\"arrow-right-to-file\"], \"f56f\", \"M128 64c0-35.3 28.7-64 64-64L352 0l0 128c0 17.7 14.3 32 32 32l128 0 0 288c0 35.3-28.7 64-64 64l-256 0c-35.3 0-64-28.7-64-64l0-112 174.1 0-39 39c-9.4 9.4-9.4 24.6 0 33.9s24.6 9.4 33.9 0l80-80c9.4-9.4 9.4-24.6 0-33.9l-80-80c-9.4-9.4-24.6-9.4-33.9 0s-9.4 24.6 0 33.9l39 39L128 288l0-224zm0 224l0 48L24 336c-13.3 0-24-10.7-24-24s10.7-24 24-24l104 0zM512 128l-128 0L384 0 512 128z\"]\n};\nconst faArrowRightToFile = faFileImport;\nconst faSquareArrowUpRight = {\n prefix: 'fas',\n iconName: 'square-arrow-up-right',\n icon: [448, 512, [\"external-link-square\"], \"f14c\", \"M384 32c35.3 0 64 28.7 64 64l0 320c0 35.3-28.7 64-64 64L64 480c-35.3 0-64-28.7-64-64L0 96C0 60.7 28.7 32 64 32l320 0zM160 144c-13.3 0-24 10.7-24 24s10.7 24 24 24l94.1 0L119 327c-9.4 9.4-9.4 24.6 0 33.9s24.6 9.4 33.9 0l135-135L288 328c0 13.3 10.7 24 24 24s24-10.7 24-24l0-160c0-13.3-10.7-24-24-24l-152 0z\"]\n};\nconst faExternalLinkSquare = faSquareArrowUpRight;\nconst faBoxOpen = {\n prefix: 'fas',\n iconName: 'box-open',\n icon: [640, 512, [], \"f49e\", \"M58.9 42.1c3-6.1 9.6-9.6 16.3-8.7L320 64 564.8 33.4c6.7-.8 13.3 2.7 16.3 8.7l41.7 83.4c9 17.9-.6 39.6-19.8 45.1L439.6 217.3c-13.9 4-28.8-1.9-36.2-14.3L320 64 236.6 203c-7.4 12.4-22.3 18.3-36.2 14.3L37.1 170.6c-19.3-5.5-28.8-27.2-19.8-45.1L58.9 42.1zM321.1 128l54.9 91.4c14.9 24.8 44.6 36.6 72.5 28.6L576 211.6l0 167c0 22-15 41.2-36.4 46.6l-204.1 51c-10.2 2.6-20.9 2.6-31 0l-204.1-51C79 419.7 64 400.5 64 378.5l0-167L191.6 248c27.8 8 57.6-3.8 72.5-28.6L318.9 128l2.2 0z\"]\n};\nconst faScroll = {\n prefix: 'fas',\n iconName: 'scroll',\n icon: [576, 512, [128220], \"f70e\", \"M0 80l0 48c0 17.7 14.3 32 32 32l16 0 48 0 0-80c0-26.5-21.5-48-48-48S0 53.5 0 80zM112 32c10 13.4 16 30 16 48l0 304c0 35.3 28.7 64 64 64s64-28.7 64-64l0-5.3c0-32.4 26.3-58.7 58.7-58.7L480 320l0-192c0-53-43-96-96-96L112 32zM464 480c61.9 0 112-50.1 112-112c0-8.8-7.2-16-16-16l-245.3 0c-14.7 0-26.7 11.9-26.7 26.7l0 5.3c0 53-43 96-96 96l176 0 96 0z\"]\n};\nconst faSpa = {\n prefix: 'fas',\n iconName: 'spa',\n icon: [576, 512, [], \"f5bb\", \"M183.1 235.3c33.7 20.7 62.9 48.1 85.8 80.5c7 9.9 13.4 20.3 19.1 31c5.7-10.8 12.1-21.1 19.1-31c22.9-32.4 52.1-59.8 85.8-80.5C437.6 207.8 490.1 192 546 192l9.9 0c11.1 0 20.1 9 20.1 20.1C576 360.1 456.1 480 308.1 480L288 480l-20.1 0C119.9 480 0 360.1 0 212.1C0 201 9 192 20.1 192l9.9 0c55.9 0 108.4 15.8 153.1 43.3zM301.5 37.6c15.7 16.9 61.1 71.8 84.4 164.6c-38 21.6-71.4 50.8-97.9 85.6c-26.5-34.8-59.9-63.9-97.9-85.6c23.2-92.8 68.6-147.7 84.4-164.6C278 33.9 282.9 32 288 32s10 1.9 13.5 5.6z\"]\n};\nconst faLocationPinLock = {\n prefix: 'fas',\n iconName: 'location-pin-lock',\n icon: [512, 512, [], \"e51f\", \"M215.7 499.2c11-13.8 25.1-31.7 40.3-52.3l0-94.8c0-23.7 12.9-44.4 32-55.4l0-24.6c0-55.6 40.5-101.7 93.6-110.5C367 70 287.7 0 192 0C86 0 0 86 0 192c0 87.4 117 243 168.3 307.2c12.3 15.3 35.1 15.3 47.4 0zM192 128a64 64 0 1 1 0 128 64 64 0 1 1 0-128zM400 240c17.7 0 32 14.3 32 32l0 48-64 0 0-48c0-17.7 14.3-32 32-32zm-80 32l0 48c-17.7 0-32 14.3-32 32l0 128c0 17.7 14.3 32 32 32l160 0c17.7 0 32-14.3 32-32l0-128c0-17.7-14.3-32-32-32l0-48c0-44.2-35.8-80-80-80s-80 35.8-80 80z\"]\n};\nconst faPause = {\n prefix: 'fas',\n iconName: 'pause',\n icon: [320, 512, [9208], \"f04c\", \"M48 64C21.5 64 0 85.5 0 112L0 400c0 26.5 21.5 48 48 48l32 0c26.5 0 48-21.5 48-48l0-288c0-26.5-21.5-48-48-48L48 64zm192 0c-26.5 0-48 21.5-48 48l0 288c0 26.5 21.5 48 48 48l32 0c26.5 0 48-21.5 48-48l0-288c0-26.5-21.5-48-48-48l-32 0z\"]\n};\nconst faHillAvalanche = {\n prefix: 'fas',\n iconName: 'hill-avalanche',\n icon: [576, 512, [], \"e507\", \"M439.7 401.9c34.2 23.1 81.1 19.5 111.4-10.8c34.4-34.4 34.4-90.1 0-124.4c-27.8-27.8-69.5-33.1-102.6-16c-11.8 6.1-16.4 20.6-10.3 32.3s20.6 16.4 32.3 10.3c15.1-7.8 34-5.3 46.6 7.3c15.6 15.6 15.6 40.9 0 56.6s-40.9 15.6-56.6 0l-81.7-81.7C401.2 261.3 416 236.4 416 208c0-33.9-21.1-62.9-50.9-74.5c1.9-6.8 2.9-14 2.9-21.5c0-44.2-35.8-80-80-80c-27.3 0-51.5 13.7-65.9 34.6C216.3 46.6 197.9 32 176 32c-26.5 0-48 21.5-48 48c0 4 .5 7.9 1.4 11.6L439.7 401.9zM480 64a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zm0 128a32 32 0 1 0 0-64 32 32 0 1 0 0 64zM68.3 87C43.1 61.8 0 79.7 0 115.3L0 432c0 44.2 35.8 80 80 80l316.7 0c35.6 0 53.5-43.1 28.3-68.3L68.3 87z\"]\n};\nconst faTemperatureEmpty = {\n prefix: 'fas',\n iconName: 'temperature-empty',\n icon: [320, 512, [\"temperature-0\", \"thermometer-0\", \"thermometer-empty\"], \"f2cb\", \"M112 112c0-26.5 21.5-48 48-48s48 21.5 48 48l0 164.5c0 17.3 7.1 31.9 15.3 42.5C233.8 332.6 240 349.5 240 368c0 44.2-35.8 80-80 80s-80-35.8-80-80c0-18.5 6.2-35.4 16.7-48.9c8.2-10.6 15.3-25.2 15.3-42.5L112 112zM160 0C98.1 0 48 50.2 48 112l0 164.4c0 .1-.1 .3-.2 .6c-.2 .6-.8 1.6-1.7 2.8C27.2 304.2 16 334.8 16 368c0 79.5 64.5 144 144 144s144-64.5 144-144c0-33.2-11.2-63.8-30.1-88.1c-.9-1.2-1.5-2.2-1.7-2.8c-.1-.3-.2-.5-.2-.6L272 112C272 50.2 221.9 0 160 0zm0 416a48 48 0 1 0 0-96 48 48 0 1 0 0 96z\"]\n};\nconst faTemperature0 = faTemperatureEmpty;\nconst faThermometer0 = faTemperatureEmpty;\nconst faThermometerEmpty = faTemperatureEmpty;\nconst faBomb = {\n prefix: 'fas',\n iconName: 'bomb',\n icon: [512, 512, [128163], \"f1e2\", \"M459.1 52.4L442.6 6.5C440.7 2.6 436.5 0 432.1 0s-8.5 2.6-10.4 6.5L405.2 52.4l-46 16.8c-4.3 1.6-7.3 5.9-7.2 10.4c0 4.5 3 8.7 7.2 10.2l45.7 16.8 16.8 45.8c1.5 4.4 5.8 7.5 10.4 7.5s8.9-3.1 10.4-7.5l16.5-45.8 45.7-16.8c4.2-1.5 7.2-5.7 7.2-10.2c0-4.6-3-8.9-7.2-10.4L459.1 52.4zm-132.4 53c-12.5-12.5-32.8-12.5-45.3 0l-2.9 2.9C256.5 100.3 232.7 96 208 96C93.1 96 0 189.1 0 304S93.1 512 208 512s208-93.1 208-208c0-24.7-4.3-48.5-12.2-70.5l2.9-2.9c12.5-12.5 12.5-32.8 0-45.3l-80-80zM200 192c-57.4 0-104 46.6-104 104l0 8c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-8c0-75.1 60.9-136 136-136l8 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-8 0z\"]\n};\nconst faRegistered = {\n prefix: 'fas',\n iconName: 'registered',\n icon: [512, 512, [174], \"f25d\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM160 152c0-13.3 10.7-24 24-24l88 0c44.2 0 80 35.8 80 80c0 28-14.4 52.7-36.3 67l34.1 75.1c5.5 12.1 .1 26.3-11.9 31.8s-26.3 .1-31.8-11.9L268.9 288 208 288l0 72c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-96 0-112zm48 88l64 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-64 0 0 64z\"]\n};\nconst faAddressCard = {\n prefix: 'fas',\n iconName: 'address-card',\n icon: [576, 512, [62140, \"contact-card\", \"vcard\"], \"f2bb\", \"M64 32C28.7 32 0 60.7 0 96L0 416c0 35.3 28.7 64 64 64l448 0c35.3 0 64-28.7 64-64l0-320c0-35.3-28.7-64-64-64L64 32zm80 256l64 0c44.2 0 80 35.8 80 80c0 8.8-7.2 16-16 16L80 384c-8.8 0-16-7.2-16-16c0-44.2 35.8-80 80-80zm-32-96a64 64 0 1 1 128 0 64 64 0 1 1 -128 0zm256-32l128 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-128 0c-8.8 0-16-7.2-16-16s7.2-16 16-16zm0 64l128 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-128 0c-8.8 0-16-7.2-16-16s7.2-16 16-16zm0 64l128 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-128 0c-8.8 0-16-7.2-16-16s7.2-16 16-16z\"]\n};\nconst faContactCard = faAddressCard;\nconst faVcard = faAddressCard;\nconst faScaleUnbalancedFlip = {\n prefix: 'fas',\n iconName: 'scale-unbalanced-flip',\n icon: [640, 512, [\"balance-scale-right\"], \"f516\", \"M117.9 62.4c-16.8-5.6-25.8-23.7-20.2-40.5s23.7-25.8 40.5-20.2l113 37.7C265 15.8 290.7 0 320 0c44.2 0 80 35.8 80 80c0 3-.2 5.9-.5 8.8l122.6 40.9c16.8 5.6 25.8 23.7 20.2 40.5s-23.7 25.8-40.5 20.2L366.4 145.2c-4.5 3.2-9.3 5.9-14.4 8.2L352 480c0 17.7-14.3 32-32 32l-192 0c-17.7 0-32-14.3-32-32s14.3-32 32-32l160 0 0-294.7c-21-9.2-37.2-27-44.2-49l-125.9-42zM200.4 288L128 163.8 55.6 288l144.9 0zM128 384C65.1 384 12.8 350 2 305.1c-2.6-11 1-22.3 6.7-32.1l95.2-163.2c5-8.6 14.2-13.8 24.1-13.8s19.1 5.3 24.1 13.8l95.2 163.2c5.7 9.8 9.3 21.1 6.7 32.1C243.2 350 190.9 384 128 384zm382.8-92.2L438.4 416l144.9 0L510.8 291.8zm126 141.3C626 478 573.7 512 510.8 512s-115.2-34-126-78.9c-2.6-11 1-22.3 6.7-32.1l95.2-163.2c5-8.6 14.2-13.8 24.1-13.8s19.1 5.3 24.1 13.8l95.2 163.2c5.7 9.8 9.3 21.1 6.7 32.1z\"]\n};\nconst faBalanceScaleRight = faScaleUnbalancedFlip;\nconst faSubscript = {\n prefix: 'fas',\n iconName: 'subscript',\n icon: [512, 512, [], \"f12c\", \"M32 64C14.3 64 0 78.3 0 96s14.3 32 32 32l15.3 0 89.6 128L47.3 384 32 384c-17.7 0-32 14.3-32 32s14.3 32 32 32l32 0c10.4 0 20.2-5.1 26.2-13.6L176 311.8l85.8 122.6c6 8.6 15.8 13.6 26.2 13.6l32 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-15.3 0L215.1 256l89.6-128 15.3 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-32 0c-10.4 0-20.2 5.1-26.2 13.6L176 200.2 90.2 77.6C84.2 69.1 74.4 64 64 64L32 64zM480 320c0-11.1-5.7-21.4-15.2-27.2s-21.2-6.4-31.1-1.4l-32 16c-15.8 7.9-22.2 27.1-14.3 42.9C393 361.5 404.3 368 416 368l0 80c-17.7 0-32 14.3-32 32s14.3 32 32 32l32 0 32 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l0-128z\"]\n};\nconst faDiamondTurnRight = {\n prefix: 'fas',\n iconName: 'diamond-turn-right',\n icon: [512, 512, [\"directions\"], \"f5eb\", \"M227.7 11.7c15.6-15.6 40.9-15.6 56.6 0l216 216c15.6 15.6 15.6 40.9 0 56.6l-216 216c-15.6 15.6-40.9 15.6-56.6 0l-216-216c-15.6-15.6-15.6-40.9 0-56.6l216-216zm87.6 137c-4.6-4.6-11.5-5.9-17.4-3.5s-9.9 8.3-9.9 14.8l0 56-64 0c-35.3 0-64 28.7-64 64l0 48c0 13.3 10.7 24 24 24s24-10.7 24-24l0-48c0-8.8 7.2-16 16-16l64 0 0 56c0 6.5 3.9 12.3 9.9 14.8s12.9 1.1 17.4-3.5l80-80c6.2-6.2 6.2-16.4 0-22.6l-80-80z\"]\n};\nconst faDirections = faDiamondTurnRight;\nconst faBurst = {\n prefix: 'fas',\n iconName: 'burst',\n icon: [512, 512, [], \"e4dc\", \"M37.6 4.2C28-2.3 15.2-1.1 7 7s-9.4 21-2.8 30.5l112 163.3L16.6 233.2C6.7 236.4 0 245.6 0 256s6.7 19.6 16.6 22.8l103.1 33.4L66.8 412.8c-4.9 9.3-3.2 20.7 4.3 28.1s18.8 9.2 28.1 4.3l100.6-52.9 33.4 103.1c3.2 9.9 12.4 16.6 22.8 16.6s19.6-6.7 22.8-16.6l33.4-103.1 100.6 52.9c9.3 4.9 20.7 3.2 28.1-4.3s9.2-18.8 4.3-28.1L392.3 312.2l103.1-33.4c9.9-3.2 16.6-12.4 16.6-22.8s-6.7-19.6-16.6-22.8L388.9 198.7l25.7-70.4c3.2-8.8 1-18.6-5.6-25.2s-16.4-8.8-25.2-5.6l-70.4 25.7L278.8 16.6C275.6 6.7 266.4 0 256 0s-19.6 6.7-22.8 16.6l-32.3 99.6L37.6 4.2z\"]\n};\nconst faHouseLaptop = {\n prefix: 'fas',\n iconName: 'house-laptop',\n icon: [640, 512, [\"laptop-house\"], \"e066\", \"M218.3 8.5c12.3-11.3 31.2-11.3 43.4 0l208 192c6.7 6.2 10.3 14.8 10.3 23.5l-144 0c-19.1 0-36.3 8.4-48 21.7l0-37.7c0-8.8-7.2-16-16-16l-64 0c-8.8 0-16 7.2-16 16l0 64c0 8.8 7.2 16 16 16l64 0 0 128-160 0c-26.5 0-48-21.5-48-48l0-112-32 0c-13.2 0-25-8.1-29.8-20.3s-1.6-26.2 8.1-35.2l208-192zM352 304l0 144 192 0 0-144-192 0zm-48-16c0-17.7 14.3-32 32-32l224 0c17.7 0 32 14.3 32 32l0 160 32 0c8.8 0 16 7.2 16 16c0 26.5-21.5 48-48 48l-48 0-192 0-48 0c-26.5 0-48-21.5-48-48c0-8.8 7.2-16 16-16l32 0 0-160z\"]\n};\nconst faLaptopHouse = faHouseLaptop;\nconst faFaceTired = {\n prefix: 'fas',\n iconName: 'face-tired',\n icon: [512, 512, [128555, \"tired\"], \"f5c8\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM164.7 328.7c22-22 53.9-40.7 91.3-40.7s69.3 18.7 91.3 40.7c11.1 11.1 20.1 23.4 26.4 35.4c6.2 11.7 10.3 24.4 10.3 35.9c0 5.2-2.6 10.2-6.9 13.2s-9.8 3.7-14.7 1.8l-20.5-7.7c-26.9-10.1-55.5-15.3-84.3-15.3l-3.2 0c-28.8 0-57.3 5.2-84.3 15.3L149.6 415c-4.9 1.8-10.4 1.2-14.7-1.8s-6.9-7.9-6.9-13.2c0-11.6 4.2-24.2 10.3-35.9c6.3-12 15.3-24.3 26.4-35.4zm-31.2-182l89.9 47.9c10.7 5.7 10.7 21.1 0 26.8l-89.9 47.9c-7.9 4.2-17.5-1.5-17.5-10.5c0-2.8 1-5.5 2.8-7.6l36-43.2-36-43.2c-1.8-2.1-2.8-4.8-2.8-7.6c0-9 9.6-14.7 17.5-10.5zM396 157.1c0 2.8-1 5.5-2.8 7.6l-36 43.2 36 43.2c1.8 2.1 2.8 4.8 2.8 7.6c0 9-9.6 14.7-17.5 10.5l-89.9-47.9c-10.7-5.7-10.7-21.1 0-26.8l89.9-47.9c7.9-4.2 17.5 1.5 17.5 10.5z\"]\n};\nconst faTired = faFaceTired;\nconst faMoneyBills = {\n prefix: 'fas',\n iconName: 'money-bills',\n icon: [640, 512, [], \"e1f3\", \"M96 96l0 224c0 35.3 28.7 64 64 64l416 0c35.3 0 64-28.7 64-64l0-224c0-35.3-28.7-64-64-64L160 32c-35.3 0-64 28.7-64 64zm64 160c35.3 0 64 28.7 64 64l-64 0 0-64zM224 96c0 35.3-28.7 64-64 64l0-64 64 0zM576 256l0 64-64 0c0-35.3 28.7-64 64-64zM512 96l64 0 0 64c-35.3 0-64-28.7-64-64zM288 208a80 80 0 1 1 160 0 80 80 0 1 1 -160 0zM48 120c0-13.3-10.7-24-24-24S0 106.7 0 120L0 360c0 66.3 53.7 120 120 120l400 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-400 0c-39.8 0-72-32.2-72-72l0-240z\"]\n};\nconst faSmog = {\n prefix: 'fas',\n iconName: 'smog',\n icon: [640, 512, [], \"f75f\", \"M32 144c0 79.5 64.5 144 144 144l123.3 0c22.6 19.9 52.2 32 84.7 32s62.1-12.1 84.7-32l27.3 0c61.9 0 112-50.1 112-112s-50.1-112-112-112c-10.7 0-21 1.5-30.8 4.3C443.8 27.7 401.1 0 352 0c-32.6 0-62.4 12.2-85.1 32.3C242.1 12.1 210.5 0 176 0C96.5 0 32 64.5 32 144zM616 368l-336 0c-13.3 0-24 10.7-24 24s10.7 24 24 24l336 0c13.3 0 24-10.7 24-24s-10.7-24-24-24zm-64 96l-112 0c-13.3 0-24 10.7-24 24s10.7 24 24 24l112 0c13.3 0 24-10.7 24-24s-10.7-24-24-24zm-192 0L24 464c-13.3 0-24 10.7-24 24s10.7 24 24 24l336 0c13.3 0 24-10.7 24-24s-10.7-24-24-24zM224 392c0-13.3-10.7-24-24-24L96 368c-13.3 0-24 10.7-24 24s10.7 24 24 24l104 0c13.3 0 24-10.7 24-24z\"]\n};\nconst faCrutch = {\n prefix: 'fas',\n iconName: 'crutch',\n icon: [512, 512, [], \"f7f7\", \"M297.4 9.4c-12.5 12.5-12.5 32.8 0 45.3l160 160c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3l-160-160c-12.5-12.5-32.8-12.5-45.3 0zm-96 144l-34.8 34.8c-12.9 12.9-21.9 29.2-25.8 47.1L116.8 342.9c-1.3 5.9-4.3 11.4-8.6 15.7L9.4 457.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0l98.8-98.8c4.3-4.3 9.7-7.3 15.7-8.6l107.6-23.9c17.8-4 34.1-12.9 47.1-25.8l34.7-34.7c0 0 .1-.1 .1-.1s.1-.1 .1-.1l74.6-74.6-45.3-45.3L336 242.7 269.3 176l52.1-52.1L276.1 78.6l-74.7 74.7zM224 221.3L290.7 288l-12.2 12.2c-4.3 4.3-9.7 7.3-15.7 8.6l-76.7 17 17-76.7c1.3-5.9 4.3-11.4 8.6-15.7L224 221.3z\"]\n};\nconst faFontAwesome = {\n prefix: 'fas',\n iconName: 'font-awesome',\n icon: [512, 512, [62501, 62694, \"font-awesome-flag\", \"font-awesome-logo-full\"], \"f2b4\", \"M91.7 96C106.3 86.8 116 70.5 116 52C116 23.3 92.7 0 64 0S12 23.3 12 52c0 16.7 7.8 31.5 20 41l0 3 0 352 0 64 64 0 0-64 373.6 0c14.6 0 26.4-11.8 26.4-26.4c0-3.7-.8-7.3-2.3-10.7L432 272l61.7-138.9c1.5-3.4 2.3-7 2.3-10.7c0-14.6-11.8-26.4-26.4-26.4L91.7 96z\"]\n};\nconst faFontAwesomeFlag = faFontAwesome;\nconst faFontAwesomeLogoFull = faFontAwesome;\nconst faCloudArrowUp = {\n prefix: 'fas',\n iconName: 'cloud-arrow-up',\n icon: [640, 512, [62338, \"cloud-upload\", \"cloud-upload-alt\"], \"f0ee\", \"M144 480C64.5 480 0 415.5 0 336c0-62.8 40.2-116.2 96.2-135.9c-.1-2.7-.2-5.4-.2-8.1c0-88.4 71.6-160 160-160c59.3 0 111 32.2 138.7 80.2C409.9 102 428.3 96 448 96c53 0 96 43 96 96c0 12.2-2.3 23.8-6.4 34.6C596 238.4 640 290.1 640 352c0 70.7-57.3 128-128 128l-368 0zm79-217c-9.4 9.4-9.4 24.6 0 33.9s24.6 9.4 33.9 0l39-39L296 392c0 13.3 10.7 24 24 24s24-10.7 24-24l0-134.1 39 39c9.4 9.4 24.6 9.4 33.9 0s9.4-24.6 0-33.9l-80-80c-9.4-9.4-24.6-9.4-33.9 0l-80 80z\"]\n};\nconst faCloudUpload = faCloudArrowUp;\nconst faCloudUploadAlt = faCloudArrowUp;\nconst faPalette = {\n prefix: 'fas',\n iconName: 'palette',\n icon: [512, 512, [127912], \"f53f\", \"M512 256c0 .9 0 1.8 0 2.7c-.4 36.5-33.6 61.3-70.1 61.3L344 320c-26.5 0-48 21.5-48 48c0 3.4 .4 6.7 1 9.9c2.1 10.2 6.5 20 10.8 29.9c6.1 13.8 12.1 27.5 12.1 42c0 31.8-21.6 60.7-53.4 62c-3.5 .1-7 .2-10.6 .2C114.6 512 0 397.4 0 256S114.6 0 256 0S512 114.6 512 256zM128 288a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zm0-96a32 32 0 1 0 0-64 32 32 0 1 0 0 64zM288 96a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zm96 96a32 32 0 1 0 0-64 32 32 0 1 0 0 64z\"]\n};\nconst faArrowsTurnRight = {\n prefix: 'fas',\n iconName: 'arrows-turn-right',\n icon: [448, 512, [], \"e4c0\", \"M297.4 9.4c12.5-12.5 32.8-12.5 45.3 0l96 96c12.5 12.5 12.5 32.8 0 45.3l-96 96c-12.5 12.5-32.8 12.5-45.3 0s-12.5-32.8 0-45.3L338.7 160 128 160c-35.3 0-64 28.7-64 64l0 32c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-32C0 153.3 57.3 96 128 96l210.7 0L297.4 54.6c-12.5-12.5-12.5-32.8 0-45.3zm-96 256c12.5-12.5 32.8-12.5 45.3 0l96 96c12.5 12.5 12.5 32.8 0 45.3l-96 96c-12.5 12.5-32.8 12.5-45.3 0s-12.5-32.8 0-45.3L242.7 416 96 416c-17.7 0-32 14.3-32 32l0 32c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-32c0-53 43-96 96-96l146.7 0-41.4-41.4c-12.5-12.5-12.5-32.8 0-45.3z\"]\n};\nconst faVest = {\n prefix: 'fas',\n iconName: 'vest',\n icon: [448, 512, [], \"e085\", \"M207.1 237.4L151.2 69.7C168.6 79.7 192.6 88 224 88s55.4-8.3 72.8-18.3L226.5 280.6c-1.6 4.9-2.5 10-2.5 15.2L224 464c0 26.5 21.5 48 48 48l128 0c26.5 0 48-21.5 48-48l0-193.5c0-9.5-2.8-18.7-8.1-26.6l-47.9-71.8c-5.3-7.9-8.1-17.1-8.1-26.6l0-17.5 0-73.7 0-6.3c0-26.5-21.5-48-48-48l-4.5 0c-.2 0-.4 0-.6 0c-.4 0-.8 0-1.2 0C311 0 295.7 9.7 285.7 18.8C276.4 27.2 257.2 40 224 40s-52.4-12.8-61.7-21.2C152.3 9.7 137 0 118.3 0c-.4 0-.8 0-1.2 0c-.2 0-.4 0-.6 0L112 0C85.5 0 64 21.5 64 48l0 6.3L64 128l0 17.5c0 9.5-2.8 18.7-8.1 26.6L8.1 243.9C2.8 251.8 0 261.1 0 270.5L0 464c0 26.5 21.5 48 48 48l128 0c9.9 0 19-3 26.7-8.1C195.9 492.2 192 478.5 192 464l0-168.2c0-8.6 1.4-17.1 4.1-25.3l11-33.1zM347.3 356.7l48 48c6.2 6.2 6.2 16.4 0 22.6s-16.4 6.2-22.6 0l-48-48c-6.2-6.2-6.2-16.4 0-22.6s16.4-6.2 22.6 0zm-294.6 48l48-48c6.2-6.2 16.4-6.2 22.6 0s6.2 16.4 0 22.6l-48 48c-6.2 6.2-16.4 6.2-22.6 0s-6.2-16.4 0-22.6z\"]\n};\nconst faFerry = {\n prefix: 'fas',\n iconName: 'ferry',\n icon: [576, 512, [], \"e4ea\", \"M224 0L352 0c17.7 0 32 14.3 32 32l75.1 0c20.6 0 31.6 24.3 18.1 39.8L456 96 120 96 98.8 71.8C85.3 56.3 96.3 32 116.9 32L192 32c0-17.7 14.3-32 32-32zM96 128l384 0c17.7 0 32 14.3 32 32l0 123.5c0 13.3-4.2 26.3-11.9 37.2l-51.4 71.9c-1.9 1.1-3.7 2.2-5.5 3.5c-15.5 10.7-34 18-51 19.9l-16.5 0c-17.1-1.8-35-9-50.8-19.9c-22.1-15.5-51.6-15.5-73.7 0c-14.8 10.2-32.5 18-50.6 19.9l-16.6 0c-17-1.8-35.6-9.2-51-19.9c-1.8-1.3-3.7-2.4-5.6-3.5L75.9 320.7C68.2 309.8 64 296.8 64 283.5L64 160c0-17.7 14.3-32 32-32zm32 64l0 96 320 0 0-96-320 0zM306.5 421.9C329 437.4 356.5 448 384 448c26.9 0 55.3-10.8 77.4-26.1c0 0 0 0 0 0c11.9-8.5 28.1-7.8 39.2 1.7c14.4 11.9 32.5 21 50.6 25.2c17.2 4 27.9 21.2 23.9 38.4s-21.2 27.9-38.4 23.9c-24.5-5.7-44.9-16.5-58.2-25C449.5 501.7 417 512 384 512c-31.9 0-60.6-9.9-80.4-18.9c-5.8-2.7-11.1-5.3-15.6-7.7c-4.5 2.4-9.7 5.1-15.6 7.7c-19.8 9-48.5 18.9-80.4 18.9c-33 0-65.5-10.3-94.5-25.8c-13.4 8.4-33.7 19.3-58.2 25c-17.2 4-34.4-6.7-38.4-23.9s6.7-34.4 23.9-38.4c18.1-4.2 36.2-13.3 50.6-25.2c11.1-9.4 27.3-10.1 39.2-1.7c0 0 0 0 0 0C136.7 437.2 165.1 448 192 448c27.5 0 55-10.6 77.5-26.1c11.1-7.9 25.9-7.9 37 0z\"]\n};\nconst faArrowsDownToPeople = {\n prefix: 'fas',\n iconName: 'arrows-down-to-people',\n icon: [640, 512, [], \"e4b9\", \"M144 0c-13.3 0-24 10.7-24 24l0 118.1L97 119c-9.4-9.4-24.6-9.4-33.9 0s-9.4 24.6 0 33.9l64 64c9.4 9.4 24.6 9.4 33.9 0l64-64c9.4-9.4 9.4-24.6 0-33.9s-24.6-9.4-33.9 0l-23 23L168 24c0-13.3-10.7-24-24-24zM360 200a40 40 0 1 0 -80 0 40 40 0 1 0 80 0zM184 296a40 40 0 1 0 -80 0 40 40 0 1 0 80 0zm312 40a40 40 0 1 0 0-80 40 40 0 1 0 0 80zM200 441.5l26.9 49.9c6.3 11.7 20.8 16 32.5 9.8s16-20.8 9.8-32.5l-36.3-67.5c1.7-1.7 3.2-3.6 4.3-5.8L264 345.5l0 54.5c0 17.7 14.3 32 32 32l48 0c17.7 0 32-14.3 32-32l0-54.5 26.9 49.9c1.2 2.2 2.6 4.1 4.3 5.8l-36.3 67.5c-6.3 11.7-1.9 26.2 9.8 32.5s26.2 1.9 32.5-9.8L440 441.5l0 38.5c0 17.7 14.3 32 32 32l48 0c17.7 0 32-14.3 32-32l0-38.5 26.9 49.9c6.3 11.7 20.8 16 32.5 9.8s16-20.8 9.8-32.5l-37.9-70.3c-15.3-28.5-45.1-46.3-77.5-46.3l-19.5 0c-16.3 0-31.9 4.5-45.4 12.6l-33.6-62.3c-15.3-28.5-45.1-46.3-77.5-46.3l-19.5 0c-32.4 0-62.1 17.8-77.5 46.3l-33.6 62.3c-13.5-8.1-29.1-12.6-45.4-12.6l-19.5 0c-32.4 0-62.1 17.8-77.5 46.3L18.9 468.6c-6.3 11.7-1.9 26.2 9.8 32.5s26.2 1.9 32.5-9.8L88 441.5 88 480c0 17.7 14.3 32 32 32l48 0c17.7 0 32-14.3 32-32l0-38.5zM415 153l64 64c9.4 9.4 24.6 9.4 33.9 0l64-64c9.4-9.4 9.4-24.6 0-33.9s-24.6-9.4-33.9 0l-23 23L520 24c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 118.1-23-23c-9.4-9.4-24.6-9.4-33.9 0s-9.4 24.6 0 33.9z\"]\n};\nconst faSeedling = {\n prefix: 'fas',\n iconName: 'seedling',\n icon: [512, 512, [127793, \"sprout\"], \"f4d8\", \"M512 32c0 113.6-84.6 207.5-194.2 222c-7.1-53.4-30.6-101.6-65.3-139.3C290.8 46.3 364 0 448 0l32 0c17.7 0 32 14.3 32 32zM0 96C0 78.3 14.3 64 32 64l32 0c123.7 0 224 100.3 224 224l0 32 0 160c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-160C100.3 320 0 219.7 0 96z\"]\n};\nconst faSprout = faSeedling;\nconst faLeftRight = {\n prefix: 'fas',\n iconName: 'left-right',\n icon: [512, 512, [8596, \"arrows-alt-h\"], \"f337\", \"M504.3 273.6c4.9-4.5 7.7-10.9 7.7-17.6s-2.8-13-7.7-17.6l-112-104c-7-6.5-17.2-8.2-25.9-4.4s-14.4 12.5-14.4 22l0 56-192 0 0-56c0-9.5-5.7-18.2-14.4-22s-18.9-2.1-25.9 4.4l-112 104C2.8 243 0 249.3 0 256s2.8 13 7.7 17.6l112 104c7 6.5 17.2 8.2 25.9 4.4s14.4-12.5 14.4-22l0-56 192 0 0 56c0 9.5 5.7 18.2 14.4 22s18.9 2.1 25.9-4.4l112-104z\"]\n};\nconst faArrowsAltH = faLeftRight;\nconst faBoxesPacking = {\n prefix: 'fas',\n iconName: 'boxes-packing',\n icon: [640, 512, [], \"e4c7\", \"M256 48c0-26.5 21.5-48 48-48L592 0c26.5 0 48 21.5 48 48l0 416c0 26.5-21.5 48-48 48l-210.7 0c1.8-5 2.7-10.4 2.7-16l0-242.7c18.6-6.6 32-24.4 32-45.3l0-32c0-26.5-21.5-48-48-48l-112 0 0-80zM571.3 347.3c6.2-6.2 6.2-16.4 0-22.6l-64-64c-6.2-6.2-16.4-6.2-22.6 0l-64 64c-6.2 6.2-6.2 16.4 0 22.6s16.4 6.2 22.6 0L480 310.6 480 432c0 8.8 7.2 16 16 16s16-7.2 16-16l0-121.4 36.7 36.7c6.2 6.2 16.4 6.2 22.6 0zM0 176c0-8.8 7.2-16 16-16l352 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16L16 224c-8.8 0-16-7.2-16-16l0-32zm352 80l0 224c0 17.7-14.3 32-32 32L64 512c-17.7 0-32-14.3-32-32l0-224 320 0zM144 320c-8.8 0-16 7.2-16 16s7.2 16 16 16l96 0c8.8 0 16-7.2 16-16s-7.2-16-16-16l-96 0z\"]\n};\nconst faCircleArrowLeft = {\n prefix: 'fas',\n iconName: 'circle-arrow-left',\n icon: [512, 512, [\"arrow-circle-left\"], \"f0a8\", \"M512 256A256 256 0 1 0 0 256a256 256 0 1 0 512 0zM215 127c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9l-71 71L392 232c13.3 0 24 10.7 24 24s-10.7 24-24 24l-214.1 0 71 71c9.4 9.4 9.4 24.6 0 33.9s-24.6 9.4-33.9 0L103 273c-9.4-9.4-9.4-24.6 0-33.9L215 127z\"]\n};\nconst faArrowCircleLeft = faCircleArrowLeft;\nconst faGroupArrowsRotate = {\n prefix: 'fas',\n iconName: 'group-arrows-rotate',\n icon: [512, 512, [], \"e4f6\", \"M201.1 71.9c16.9-5 26.6-22.9 21.5-39.8s-22.9-26.6-39.8-21.5c-21.5 6.4-41.8 15.5-60.6 27C114.3 34 105.4 32 96 32C60.7 32 32 60.7 32 96c0 9.4 2 18.3 5.6 26.3c-11.5 18.7-20.6 39-27 60.6c-5 16.9 4.6 34.8 21.5 39.8s34.8-4.6 39.8-21.5c4.3-14.6 10.4-28.5 17.9-41.4c2 .2 4.1 .3 6.1 .3c35.3 0 64-28.7 64-64c0-2.1-.1-4.1-.3-6.1c12.9-7.5 26.8-13.6 41.4-17.9zm128-61.3c-16.9-5-34.8 4.6-39.8 21.5s4.6 34.8 21.5 39.8c14.6 4.3 28.5 10.4 41.4 17.9c-.2 2-.3 4.1-.3 6.1c0 35.3 28.7 64 64 64c2.1 0 4.1-.1 6.2-.3c7.5 12.9 13.6 26.8 17.9 41.4c5 16.9 22.9 26.6 39.8 21.5s26.6-22.9 21.5-39.8c-6.4-21.5-15.5-41.8-27-60.6c3.6-8 5.6-16.9 5.6-26.3c0-35.3-28.7-64-64-64c-9.4 0-18.3 2-26.3 5.6c-18.7-11.5-39-20.6-60.6-27zM71.9 310.9c-5-16.9-22.9-26.6-39.8-21.5s-26.6 22.9-21.5 39.8c6.4 21.5 15.5 41.8 27 60.6C34 397.7 32 406.6 32 416c0 35.3 28.7 64 64 64c9.4 0 18.3-2 26.3-5.6c18.7 11.5 39 20.6 60.6 27c16.9 5 34.8-4.6 39.8-21.5s-4.6-34.8-21.5-39.8c-14.6-4.3-28.5-10.4-41.4-17.9c.2-2 .3-4.1 .3-6.2c0-35.3-28.7-64-64-64c-2.1 0-4.1 .1-6.2 .3c-7.5-12.9-13.6-26.8-17.9-41.4zm429.4 18.3c5-16.9-4.6-34.8-21.5-39.8s-34.8 4.6-39.8 21.5c-4.3 14.6-10.4 28.5-17.9 41.4c-2-.2-4.1-.3-6.2-.3c-35.3 0-64 28.7-64 64c0 2.1 .1 4.1 .3 6.2c-12.9 7.5-26.8 13.6-41.4 17.9c-16.9 5-26.6 22.9-21.5 39.8s22.9 26.6 39.8 21.5c21.5-6.4 41.8-15.5 60.6-27c8 3.6 16.9 5.6 26.3 5.6c35.3 0 64-28.7 64-64c0-9.4-2-18.3-5.6-26.3c11.5-18.7 20.6-39 27-60.6zM192.8 256.8c0-15.6 5.6-29.9 14.9-41.1L223 231c6.6 6.6 17.8 1.9 17.8-7.4l0-60.5c0-5.7-4.7-10.4-10.4-10.4l-60.5 0c-9.3 0-13.9 11.2-7.4 17.8l11.2 11.2c-17.9 19.8-28.9 46.2-28.9 75.1c0 43.6 24.9 81.3 61.1 99.8c11.8 6 26.3 1.4 32.3-10.4s1.4-26.3-10.4-32.3c-20.8-10.6-34.9-32.2-34.9-57zm93.1-58.6c20.8 10.6 34.9 32.2 34.9 57c0 15.6-5.6 29.9-14.9 41.1L290.6 281c-6.6-6.6-17.8-1.9-17.8 7.4l0 60.5c0 5.7 4.7 10.4 10.4 10.4l60.5 0c9.3 0 13.9-11.2 7.4-17.8l-11.2-11.2c17.9-19.8 28.9-46.2 28.9-75.1c0-43.6-24.9-81.3-61.1-99.8c-11.8-6-26.3-1.4-32.3 10.4s-1.4 26.3 10.4 32.3z\"]\n};\nconst faBowlFood = {\n prefix: 'fas',\n iconName: 'bowl-food',\n icon: [512, 512, [], \"e4c6\", \"M0 192c0-35.3 28.7-64 64-64c.5 0 1.1 0 1.6 0C73 91.5 105.3 64 144 64c15 0 29 4.1 40.9 11.2C198.2 49.6 225.1 32 256 32s57.8 17.6 71.1 43.2C339 68.1 353 64 368 64c38.7 0 71 27.5 78.4 64c.5 0 1.1 0 1.6 0c35.3 0 64 28.7 64 64c0 11.7-3.1 22.6-8.6 32L8.6 224C3.1 214.6 0 203.7 0 192zm0 91.4C0 268.3 12.3 256 27.4 256l457.1 0c15.1 0 27.4 12.3 27.4 27.4c0 70.5-44.4 130.7-106.7 154.1L403.5 452c-2 16-15.6 28-31.8 28l-231.5 0c-16.1 0-29.8-12-31.8-28l-1.8-14.4C44.4 414.1 0 353.9 0 283.4z\"]\n};\nconst faCandyCane = {\n prefix: 'fas',\n iconName: 'candy-cane',\n icon: [512, 512, [], \"f786\", \"M348.8 131.5c3.7-2.3 7.9-3.5 12.2-3.5c12.7 0 23 10.3 23 23l0 5.6c0 9.9-5.1 19.1-13.5 24.3L30.1 393.7C.1 412.5-9 451.9 9.7 481.9s58.2 39.1 88.2 20.4L438.4 289.5c45.8-28.6 73.6-78.8 73.6-132.8l0-5.6C512 67.6 444.4 0 361 0c-28.3 0-56 8-80.1 23L254.1 39.7c-30 18.7-39.1 58.2-20.4 88.2s58.2 39.1 88.2 20.4l26.8-16.8zM298.4 49.8c9.2-5.7 19.1-10.1 29.4-13.1L348 97.5c-5.7 1.4-11.2 3.7-16.3 6.8l-12.6 7.9L298.4 49.8zm88.5 52.7l46.2-46.2c8.5 6.5 16.1 14.1 22.6 22.6l-46.2 46.2c-5.1-9.6-13-17.5-22.6-22.6zm28.9 59.3l61.6 20.5c-2.2 10.5-5.8 20.7-10.5 30.2l-62-20.7c6.2-8.8 10.1-19.1 11-30.1zm-86.1 82.5l60.4 37.7-30.2 18.9-60.4-37.7 30.2-18.9zm-107.2 67l60.4 37.7-30.2 18.9-60.4-37.7 30.2-18.9zM119.3 375.7l60.4 37.7-30.2 18.9L89.1 394.6l30.2-18.9z\"]\n};\nconst faArrowDownWideShort = {\n prefix: 'fas',\n iconName: 'arrow-down-wide-short',\n icon: [576, 512, [\"sort-amount-asc\", \"sort-amount-down\"], \"f160\", \"M151.6 469.6C145.5 476.2 137 480 128 480s-17.5-3.8-23.6-10.4l-88-96c-11.9-13-11.1-33.3 2-45.2s33.3-11.1 45.2 2L96 365.7 96 64c0-17.7 14.3-32 32-32s32 14.3 32 32l0 301.7 32.4-35.4c11.9-13 32.2-13.9 45.2-2s13.9 32.2 2 45.2l-88 96zM320 480c-17.7 0-32-14.3-32-32s14.3-32 32-32l32 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-32 0zm0-128c-17.7 0-32-14.3-32-32s14.3-32 32-32l96 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-96 0zm0-128c-17.7 0-32-14.3-32-32s14.3-32 32-32l160 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-160 0zm0-128c-17.7 0-32-14.3-32-32s14.3-32 32-32l224 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L320 96z\"]\n};\nconst faSortAmountAsc = faArrowDownWideShort;\nconst faSortAmountDown = faArrowDownWideShort;\nconst faCloudBolt = {\n prefix: 'fas',\n iconName: 'cloud-bolt',\n icon: [512, 512, [127785, \"thunderstorm\"], \"f76c\", \"M0 224c0 53 43 96 96 96l47.2 0L290 202.5c17.6-14.1 42.6-14 60.2 .2s22.8 38.6 12.8 58.8L333.7 320l18.3 0 64 0c53 0 96-43 96-96s-43-96-96-96c-.5 0-1.1 0-1.6 0c1.1-5.2 1.6-10.5 1.6-16c0-44.2-35.8-80-80-80c-24.3 0-46.1 10.9-60.8 28C256.5 24.3 219.1 0 176 0C114.1 0 64 50.1 64 112c0 7.1 .7 14.1 1.9 20.8C27.6 145.4 0 181.5 0 224zm330.1 3.6c-5.8-4.7-14.2-4.7-20.1-.1l-160 128c-5.3 4.2-7.4 11.4-5.1 17.8s8.3 10.7 15.1 10.7l70.1 0L177.7 488.8c-3.4 6.7-1.6 14.9 4.3 19.6s14.2 4.7 20.1 .1l160-128c5.3-4.2 7.4-11.4 5.1-17.8s-8.3-10.7-15.1-10.7l-70.1 0 52.4-104.8c3.4-6.7 1.6-14.9-4.2-19.6z\"]\n};\nconst faThunderstorm = faCloudBolt;\nconst faTextSlash = {\n prefix: 'fas',\n iconName: 'text-slash',\n icon: [640, 512, [\"remove-format\"], \"f87d\", \"M38.8 5.1C28.4-3.1 13.3-1.2 5.1 9.2S-1.2 34.7 9.2 42.9l592 464c10.4 8.2 25.5 6.3 33.7-4.1s6.3-25.5-4.1-33.7L355.7 253.5 400.2 96 503 96 497 120.2c-4.3 17.1 6.1 34.5 23.3 38.8s34.5-6.1 38.8-23.3l11-44.1C577.6 61.3 554.7 32 523.5 32L376.1 32l-.3 0L204.5 32c-22 0-41.2 15-46.6 36.4l-6.3 25.2L38.8 5.1zm168 131.7c.1-.3 .2-.7 .3-1L217 96l116.7 0L301.3 210.8l-94.5-74.1zM243.3 416L192 416c-17.7 0-32 14.3-32 32s14.3 32 32 32l160 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-42.2 0 17.6-62.1L272.9 311 243.3 416z\"]\n};\nconst faRemoveFormat = faTextSlash;\nconst faFaceSmileWink = {\n prefix: 'fas',\n iconName: 'face-smile-wink',\n icon: [512, 512, [128521, \"smile-wink\"], \"f4da\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM164.1 325.5C182 346.2 212.6 368 256 368s74-21.8 91.9-42.5c5.8-6.7 15.9-7.4 22.6-1.6s7.4 15.9 1.6 22.6C349.8 372.1 311.1 400 256 400s-93.8-27.9-116.1-53.5c-5.8-6.7-5.1-16.8 1.6-22.6s16.8-5.1 22.6 1.6zM144.4 208a32 32 0 1 1 64 0 32 32 0 1 1 -64 0zm156.4 25.6c-5.3 7.1-15.3 8.5-22.4 3.2s-8.5-15.3-3.2-22.4c30.4-40.5 91.2-40.5 121.6 0c5.3 7.1 3.9 17.1-3.2 22.4s-17.1 3.9-22.4-3.2c-17.6-23.5-52.8-23.5-70.4 0z\"]\n};\nconst faSmileWink = faFaceSmileWink;\nconst faFileWord = {\n prefix: 'fas',\n iconName: 'file-word',\n icon: [384, 512, [], \"f1c2\", \"M64 0C28.7 0 0 28.7 0 64L0 448c0 35.3 28.7 64 64 64l256 0c35.3 0 64-28.7 64-64l0-288-128 0c-17.7 0-32-14.3-32-32L224 0 64 0zM256 0l0 128 128 0L256 0zM111 257.1l26.8 89.2 31.6-90.3c3.4-9.6 12.5-16.1 22.7-16.1s19.3 6.4 22.7 16.1l31.6 90.3L273 257.1c3.8-12.7 17.2-19.9 29.9-16.1s19.9 17.2 16.1 29.9l-48 160c-3 10-12 16.9-22.4 17.1s-19.8-6.2-23.2-16.1L192 336.6l-33.3 95.3c-3.4 9.8-12.8 16.3-23.2 16.1s-19.5-7.1-22.4-17.1l-48-160c-3.8-12.7 3.4-26.1 16.1-29.9s26.1 3.4 29.9 16.1z\"]\n};\nconst faFilePowerpoint = {\n prefix: 'fas',\n iconName: 'file-powerpoint',\n icon: [384, 512, [], \"f1c4\", \"M64 0C28.7 0 0 28.7 0 64L0 448c0 35.3 28.7 64 64 64l256 0c35.3 0 64-28.7 64-64l0-288-128 0c-17.7 0-32-14.3-32-32L224 0 64 0zM256 0l0 128 128 0L256 0zM136 240l68 0c42 0 76 34 76 76s-34 76-76 76l-44 0 0 32c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-56 0-104c0-13.3 10.7-24 24-24zm68 104c15.5 0 28-12.5 28-28s-12.5-28-28-28l-44 0 0 56 44 0z\"]\n};\nconst faArrowsLeftRight = {\n prefix: 'fas',\n iconName: 'arrows-left-right',\n icon: [512, 512, [\"arrows-h\"], \"f07e\", \"M406.6 374.6l96-96c12.5-12.5 12.5-32.8 0-45.3l-96-96c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3L402.7 224l-293.5 0 41.4-41.4c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0l-96 96c-12.5 12.5-12.5 32.8 0 45.3l96 96c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3L109.3 288l293.5 0-41.4 41.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0z\"]\n};\nconst faArrowsH = faArrowsLeftRight;\nconst faHouseLock = {\n prefix: 'fas',\n iconName: 'house-lock',\n icon: [640, 512, [], \"e510\", \"M384 480c0 11.7 3.1 22.6 8.6 32l-.6 0c-22.1 0-40-17.9-40-40l0-24 0-64c0-17.7-14.3-32-32-32l-64 0c-17.7 0-32 14.3-32 32l0 64 0 24c0 22.1-17.9 40-40 40l-24 0-31.9 0c-1.5 0-3-.1-4.5-.2c-1.2 .1-2.4 .2-3.6 .2l-16 0c-22.1 0-40-17.9-40-40l0-112c0-.9 0-1.9 .1-2.8l0-69.7-32 0c-18 0-32-14-32-32.1c0-9 3-17 10-24L266.4 8c7-7 15-8 22-8s15 2 21 7L490.7 166.3C447.2 181.7 416 223.2 416 272l0 24.6c-19.1 11.1-32 31.7-32 55.4l0 128zM528 240c-17.7 0-32 14.3-32 32l0 48 64 0 0-48c0-17.7-14.3-32-32-32zm-80 32c0-44.2 35.8-80 80-80s80 35.8 80 80l0 48c17.7 0 32 14.3 32 32l0 128c0 17.7-14.3 32-32 32l-160 0c-17.7 0-32-14.3-32-32l0-128c0-17.7 14.3-32 32-32l0-48z\"]\n};\nconst faCloudArrowDown = {\n prefix: 'fas',\n iconName: 'cloud-arrow-down',\n icon: [640, 512, [62337, \"cloud-download\", \"cloud-download-alt\"], \"f0ed\", \"M144 480C64.5 480 0 415.5 0 336c0-62.8 40.2-116.2 96.2-135.9c-.1-2.7-.2-5.4-.2-8.1c0-88.4 71.6-160 160-160c59.3 0 111 32.2 138.7 80.2C409.9 102 428.3 96 448 96c53 0 96 43 96 96c0 12.2-2.3 23.8-6.4 34.6C596 238.4 640 290.1 640 352c0 70.7-57.3 128-128 128l-368 0zm79-167l80 80c9.4 9.4 24.6 9.4 33.9 0l80-80c9.4-9.4 9.4-24.6 0-33.9s-24.6-9.4-33.9 0l-39 39L344 184c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 134.1-39-39c-9.4-9.4-24.6-9.4-33.9 0s-9.4 24.6 0 33.9z\"]\n};\nconst faCloudDownload = faCloudArrowDown;\nconst faCloudDownloadAlt = faCloudArrowDown;\nconst faChildren = {\n prefix: 'fas',\n iconName: 'children',\n icon: [640, 512, [], \"e4e1\", \"M160 0a64 64 0 1 1 0 128A64 64 0 1 1 160 0zM88 480l0-80-17.8 0c-10.9 0-18.6-10.7-15.2-21.1l31.1-93.4L57.5 323.3c-10.7 14.1-30.8 16.8-44.8 6.2s-16.8-30.7-6.2-44.8L65.4 207c22.4-29.6 57.5-47 94.6-47s72.2 17.4 94.6 47l58.9 77.7c10.7 14.1 7.9 34.2-6.2 44.8s-34.2 7.9-44.8-6.2l-28.6-37.8L265 378.9c3.5 10.4-4.3 21.1-15.2 21.1L232 400l0 80c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-80-16 0 0 80c0 17.7-14.3 32-32 32s-32-14.3-32-32zM480 0a64 64 0 1 1 0 128A64 64 0 1 1 480 0zm-8 384l0 96c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-179.5L395.1 321c-9.4 15-29.2 19.4-44.1 10s-19.4-29.2-10-44.1l51.7-82.1c17.6-27.9 48.3-44.9 81.2-44.9l12.3 0c33 0 63.7 16.9 81.2 44.9L619.1 287c9.4 15 4.9 34.7-10 44.1s-34.7 4.9-44.1-10L552 300.5 552 480c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-96-16 0z\"]\n};\nconst faChalkboard = {\n prefix: 'fas',\n iconName: 'chalkboard',\n icon: [576, 512, [\"blackboard\"], \"f51b\", \"M96 32C60.7 32 32 60.7 32 96l0 288 64 0L96 96l384 0 0 288 64 0 0-288c0-35.3-28.7-64-64-64L96 32zM224 384l0 32L32 416c-17.7 0-32 14.3-32 32s14.3 32 32 32l512 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-128 0 0-32c0-17.7-14.3-32-32-32l-128 0c-17.7 0-32 14.3-32 32z\"]\n};\nconst faBlackboard = faChalkboard;\nconst faUserLargeSlash = {\n prefix: 'fas',\n iconName: 'user-large-slash',\n icon: [640, 512, [\"user-alt-slash\"], \"f4fa\", \"M38.8 5.1C28.4-3.1 13.3-1.2 5.1 9.2S-1.2 34.7 9.2 42.9l592 464c10.4 8.2 25.5 6.3 33.7-4.1s6.3-25.5-4.1-33.7L381.9 274c48.5-23.2 82.1-72.7 82.1-130C464 64.5 399.5 0 320 0C250.4 0 192.4 49.3 178.9 114.9L38.8 5.1zM545.5 512L528 512 284.3 320l-59 0C136.2 320 64 392.2 64 481.3c0 17 13.8 30.7 30.7 30.7l450.6 0 .3 0z\"]\n};\nconst faUserAltSlash = faUserLargeSlash;\nconst faEnvelopeOpen = {\n prefix: 'fas',\n iconName: 'envelope-open',\n icon: [512, 512, [62135], \"f2b6\", \"M64 208.1L256 65.9 448 208.1l0 47.4L289.5 373c-9.7 7.2-21.4 11-33.5 11s-23.8-3.9-33.5-11L64 255.5l0-47.4zM256 0c-12.1 0-23.8 3.9-33.5 11L25.9 156.7C9.6 168.8 0 187.8 0 208.1L0 448c0 35.3 28.7 64 64 64l384 0c35.3 0 64-28.7 64-64l0-239.9c0-20.3-9.6-39.4-25.9-51.4L289.5 11C279.8 3.9 268.1 0 256 0z\"]\n};\nconst faHandshakeSimpleSlash = {\n prefix: 'fas',\n iconName: 'handshake-simple-slash',\n icon: [640, 512, [\"handshake-alt-slash\"], \"e05f\", \"M38.8 5.1C28.4-3.1 13.3-1.2 5.1 9.2S-1.2 34.7 9.2 42.9l592 464c10.4 8.2 25.5 6.3 33.7-4.1s6.3-25.5-4.1-33.7l-135-105.8c-1.1-11.4-6.3-22.3-15.3-30.7l-134.2-123-23.4 18.2-26-20.3 77.2-60.1c7-5.4 17-4.2 22.5 2.8s4.2 17-2.8 22.5l-20.9 16.2L550.2 352l41.8 0c26.5 0 48-21.5 48-48l0-128c0-26.5-21.5-48-48-48l-76 0-4 0-.7 0-3.9-2.5L434.8 79c-15.3-9.8-33.2-15-51.4-15c-21.8 0-43 7.5-60 21.2l-89.7 72.6-25.8-20.3 81.8-66.2c-11.6-4.9-24.1-7.4-36.8-7.4C234 64 215.7 69.6 200 80l-35.5 23.7L38.8 5.1zM0 176L0 304c0 26.5 21.5 48 48 48l108.2 0 91.4 83.4c19.6 17.9 49.9 16.5 67.8-3.1c5.5-6.1 9.2-13.2 11.1-20.6l17 15.6c19.5 17.9 49.9 16.6 67.8-2.9c.8-.8 1.5-1.7 2.2-2.6L41.2 128.5C17.9 131.8 0 151.8 0 176z\"]\n};\nconst faHandshakeAltSlash = faHandshakeSimpleSlash;\nconst faMattressPillow = {\n prefix: 'fas',\n iconName: 'mattress-pillow',\n icon: [640, 512, [], \"e525\", \"M256 64L64 64C28.7 64 0 92.7 0 128L0 384c0 35.3 28.7 64 64 64l192 0 0-384zm32 384l288 0c35.3 0 64-28.7 64-64l0-256c0-35.3-28.7-64-64-64L288 64l0 384zM64 160c0-17.7 14.3-32 32-32l64 0c17.7 0 32 14.3 32 32l0 192c0 17.7-14.3 32-32 32l-64 0c-17.7 0-32-14.3-32-32l0-192z\"]\n};\nconst faGuaraniSign = {\n prefix: 'fas',\n iconName: 'guarani-sign',\n icon: [384, 512, [], \"e19a\", \"M192 0c-17.7 0-32 14.3-32 32l0 34.7C69.2 81.9 0 160.9 0 256s69.2 174.1 160 189.3l0 34.7c0 17.7 14.3 32 32 32s32-14.3 32-32l0-34.7c90.8-15.2 160-94.2 160-189.3c0-17.7-14.3-32-32-32l-128 0 0-92c22.1 5.7 41.8 17.1 57.6 32.6c12.6 12.4 32.9 12.2 45.3-.4s12.2-32.9-.5-45.3C299 92 263.5 73.3 224 66.7L224 32c0-17.7-14.3-32-32-32zM160 132L160 380c-55.2-14.2-96-64.3-96-124s40.8-109.8 96-124zM224 380l0-92 92 0c-11.6 45-47 80.4-92 92z\"]\n};\nconst faArrowsRotate = {\n prefix: 'fas',\n iconName: 'arrows-rotate',\n icon: [512, 512, [128472, \"refresh\", \"sync\"], \"f021\", \"M105.1 202.6c7.7-21.8 20.2-42.3 37.8-59.8c62.5-62.5 163.8-62.5 226.3 0L386.3 160 352 160c-17.7 0-32 14.3-32 32s14.3 32 32 32l111.5 0c0 0 0 0 0 0l.4 0c17.7 0 32-14.3 32-32l0-112c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 35.2L414.4 97.6c-87.5-87.5-229.3-87.5-316.8 0C73.2 122 55.6 150.7 44.8 181.4c-5.9 16.7 2.9 34.9 19.5 40.8s34.9-2.9 40.8-19.5zM39 289.3c-5 1.5-9.8 4.2-13.7 8.2c-4 4-6.7 8.8-8.1 14c-.3 1.2-.6 2.5-.8 3.8c-.3 1.7-.4 3.4-.4 5.1L16 432c0 17.7 14.3 32 32 32s32-14.3 32-32l0-35.1 17.6 17.5c0 0 0 0 0 0c87.5 87.4 229.3 87.4 316.7 0c24.4-24.4 42.1-53.1 52.9-83.8c5.9-16.7-2.9-34.9-19.5-40.8s-34.9 2.9-40.8 19.5c-7.7 21.8-20.2 42.3-37.8 59.8c-62.5 62.5-163.8 62.5-226.3 0l-.1-.1L125.6 352l34.4 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L48.4 288c-1.6 0-3.2 .1-4.8 .3s-3.1 .5-4.6 1z\"]\n};\nconst faRefresh = faArrowsRotate;\nconst faSync = faArrowsRotate;\nconst faFireExtinguisher = {\n prefix: 'fas',\n iconName: 'fire-extinguisher',\n icon: [512, 512, [129519], \"f134\", \"M500.3 7.3C507.7 13.3 512 22.4 512 32l0 96c0 9.6-4.3 18.7-11.7 24.7s-17.2 8.5-26.6 6.6l-160-32C301.5 124.9 292 115.7 289 104l-65 0 0 34.8c37.8 18 64 56.5 64 101.2l0 144L64 384l0-144c0-44.7 26.2-83.2 64-101.2l0-28.8c-36.2 11.1-66 36.9-82.3 70.5c-5.8 11.9-20.2 16.9-32.1 11.1S-3.3 171.4 2.5 159.5C26.7 109.8 72.7 72.6 128 60.4L128 32c0-17.7 14.3-32 32-32l32 0c17.7 0 32 14.3 32 32l0 24 65 0c3-11.7 12.5-20.9 24.7-23.4l160-32c9.4-1.9 19.1 .6 26.6 6.6zM288 416l0 32c0 35.3-28.7 64-64 64l-96 0c-35.3 0-64-28.7-64-64l0-32 224 0zM176 96a16 16 0 1 0 0-32 16 16 0 1 0 0 32z\"]\n};\nconst faCruzeiroSign = {\n prefix: 'fas',\n iconName: 'cruzeiro-sign',\n icon: [448, 512, [], \"e152\", \"M96 256c0-88.4 71.6-160 160-160c41 0 78.3 15.4 106.7 40.7c13.2 11.8 33.4 10.7 45.2-2.5s10.7-33.4-2.5-45.2c-39.6-35.5-92-57-149.3-57C132.3 32 32 132.3 32 256s100.3 224 224 224c57.4 0 109.7-21.6 149.3-57c13.2-11.8 14.3-32 2.5-45.2s-32-14.3-45.2-2.5C334.3 400.6 297 416 256 416l0-96 0-8.7c0-12.8 10.4-23.3 23.3-23.3c4.6 0 9.1 1.4 12.9 3.9l10.1 6.7c14.7 9.8 34.6 5.8 44.4-8.9s5.8-34.6-8.9-44.4l-10.1-6.7c-14.3-9.6-31.2-14.7-48.4-14.7c-12.4 0-24.2 2.6-34.9 7.3c-5.5-4.5-12.6-7.3-20.3-7.3c-17.7 0-32 14.3-32 32l0 55.3 0 8.7 0 82.7C135.5 378 96 321.6 96 256z\"]\n};\nconst faGreaterThanEqual = {\n prefix: 'fas',\n iconName: 'greater-than-equal',\n icon: [448, 512, [], \"f532\", \"M52.1 93.7C35.7 87.1 27.7 68.5 34.3 52.1s25.2-24.4 41.6-17.8l320 128C408 167.1 416 178.9 416 192s-8 24.9-20.1 29.7l-320 128c-16.4 6.6-35-1.4-41.6-17.8s1.4-35 17.8-41.6L297.8 192 52.1 93.7zM416 416c17.7 0 32 14.3 32 32s-14.3 32-32 32L32 480c-17.7 0-32-14.3-32-32s14.3-32 32-32l384 0z\"]\n};\nconst faShieldHalved = {\n prefix: 'fas',\n iconName: 'shield-halved',\n icon: [512, 512, [\"shield-alt\"], \"f3ed\", \"M256 0c4.6 0 9.2 1 13.4 2.9L457.7 82.8c22 9.3 38.4 31 38.3 57.2c-.5 99.2-41.3 280.7-213.6 363.2c-16.7 8-36.1 8-52.8 0C57.3 420.7 16.5 239.2 16 140c-.1-26.2 16.3-47.9 38.3-57.2L242.7 2.9C246.8 1 251.4 0 256 0zm0 66.8l0 378.1C394 378 431.1 230.1 432 141.4L256 66.8s0 0 0 0z\"]\n};\nconst faShieldAlt = faShieldHalved;\nconst faBookAtlas = {\n prefix: 'fas',\n iconName: 'book-atlas',\n icon: [448, 512, [\"atlas\"], \"f558\", \"M0 96C0 43 43 0 96 0L384 0l32 0c17.7 0 32 14.3 32 32l0 320c0 17.7-14.3 32-32 32l0 64c17.7 0 32 14.3 32 32s-14.3 32-32 32l-32 0L96 512c-53 0-96-43-96-96L0 96zM64 416c0 17.7 14.3 32 32 32l256 0 0-64L96 384c-17.7 0-32 14.3-32 32zM247.4 283.8c-3.7 3.7-6.2 4.2-7.4 4.2s-3.7-.5-7.4-4.2c-3.8-3.7-8-10-11.8-18.9c-6.2-14.5-10.8-34.3-12.2-56.9l63 0c-1.5 22.6-6 42.4-12.2 56.9c-3.8 8.9-8 15.2-11.8 18.9zm42.7-9.9c7.3-18.3 12-41.1 13.4-65.9l31.1 0c-4.7 27.9-21.4 51.7-44.5 65.9zm0-163.8c23.2 14.2 39.9 38 44.5 65.9l-31.1 0c-1.4-24.7-6.1-47.5-13.4-65.9zM368 192a128 128 0 1 0 -256 0 128 128 0 1 0 256 0zM145.3 208l31.1 0c1.4 24.7 6.1 47.5 13.4 65.9c-23.2-14.2-39.9-38-44.5-65.9zm31.1-32l-31.1 0c4.7-27.9 21.4-51.7 44.5-65.9c-7.3 18.3-12 41.1-13.4 65.9zm56.1-75.8c3.7-3.7 6.2-4.2 7.4-4.2s3.7 .5 7.4 4.2c3.8 3.7 8 10 11.8 18.9c6.2 14.5 10.8 34.3 12.2 56.9l-63 0c1.5-22.6 6-42.4 12.2-56.9c3.8-8.9 8-15.2 11.8-18.9z\"]\n};\nconst faAtlas = faBookAtlas;\nconst faVirus = {\n prefix: 'fas',\n iconName: 'virus',\n icon: [512, 512, [], \"e074\", \"M288 32c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 11.5c0 49.9-60.3 74.9-95.6 39.6L120.2 75C107.7 62.5 87.5 62.5 75 75s-12.5 32.8 0 45.3l8.2 8.2C118.4 163.7 93.4 224 43.5 224L32 224c-17.7 0-32 14.3-32 32s14.3 32 32 32l11.5 0c49.9 0 74.9 60.3 39.6 95.6L75 391.8c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0l8.2-8.2c35.3-35.3 95.6-10.3 95.6 39.6l0 11.5c0 17.7 14.3 32 32 32s32-14.3 32-32l0-11.5c0-49.9 60.3-74.9 95.6-39.6l8.2 8.2c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3l-8.2-8.2c-35.3-35.3-10.3-95.6 39.6-95.6l11.5 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-11.5 0c-49.9 0-74.9-60.3-39.6-95.6l8.2-8.2c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0l-8.2 8.2C348.3 118.4 288 93.4 288 43.5L288 32zM176 224a48 48 0 1 1 96 0 48 48 0 1 1 -96 0zm128 56a24 24 0 1 1 0 48 24 24 0 1 1 0-48z\"]\n};\nconst faEnvelopeCircleCheck = {\n prefix: 'fas',\n iconName: 'envelope-circle-check',\n icon: [640, 512, [], \"e4e8\", \"M48 64C21.5 64 0 85.5 0 112c0 15.1 7.1 29.3 19.2 38.4L236.8 313.6c11.4 8.5 27 8.5 38.4 0l57.4-43c23.9-59.8 79.7-103.3 146.3-109.8l13.9-10.4c12.1-9.1 19.2-23.3 19.2-38.4c0-26.5-21.5-48-48-48L48 64zM294.4 339.2c-22.8 17.1-54 17.1-76.8 0L0 176 0 384c0 35.3 28.7 64 64 64l296.2 0C335.1 417.6 320 378.5 320 336c0-5.6 .3-11.1 .8-16.6l-26.4 19.8zM640 336a144 144 0 1 0 -288 0 144 144 0 1 0 288 0zm-76.7-43.3c6.2 6.2 6.2 16.4 0 22.6l-72 72c-6.2 6.2-16.4 6.2-22.6 0l-40-40c-6.2-6.2-6.2-16.4 0-22.6s16.4-6.2 22.6 0L480 353.4l60.7-60.7c6.2-6.2 16.4-6.2 22.6 0z\"]\n};\nconst faLayerGroup = {\n prefix: 'fas',\n iconName: 'layer-group',\n icon: [576, 512, [], \"f5fd\", \"M264.5 5.2c14.9-6.9 32.1-6.9 47 0l218.6 101c8.5 3.9 13.9 12.4 13.9 21.8s-5.4 17.9-13.9 21.8l-218.6 101c-14.9 6.9-32.1 6.9-47 0L45.9 149.8C37.4 145.8 32 137.3 32 128s5.4-17.9 13.9-21.8L264.5 5.2zM476.9 209.6l53.2 24.6c8.5 3.9 13.9 12.4 13.9 21.8s-5.4 17.9-13.9 21.8l-218.6 101c-14.9 6.9-32.1 6.9-47 0L45.9 277.8C37.4 273.8 32 265.3 32 256s5.4-17.9 13.9-21.8l53.2-24.6 152 70.2c23.4 10.8 50.4 10.8 73.8 0l152-70.2zm-152 198.2l152-70.2 53.2 24.6c8.5 3.9 13.9 12.4 13.9 21.8s-5.4 17.9-13.9 21.8l-218.6 101c-14.9 6.9-32.1 6.9-47 0L45.9 405.8C37.4 401.8 32 393.3 32 384s5.4-17.9 13.9-21.8l53.2-24.6 152 70.2c23.4 10.8 50.4 10.8 73.8 0z\"]\n};\nconst faArrowsToDot = {\n prefix: 'fas',\n iconName: 'arrows-to-dot',\n icon: [512, 512, [], \"e4be\", \"M256 0c17.7 0 32 14.3 32 32l0 32 32 0c12.9 0 24.6 7.8 29.6 19.8s2.2 25.7-6.9 34.9l-64 64c-12.5 12.5-32.8 12.5-45.3 0l-64-64c-9.2-9.2-11.9-22.9-6.9-34.9s16.6-19.8 29.6-19.8l32 0 0-32c0-17.7 14.3-32 32-32zM169.4 393.4l64-64c12.5-12.5 32.8-12.5 45.3 0l64 64c9.2 9.2 11.9 22.9 6.9 34.9s-16.6 19.8-29.6 19.8l-32 0 0 32c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-32-32 0c-12.9 0-24.6-7.8-29.6-19.8s-2.2-25.7 6.9-34.9zM32 224l32 0 0-32c0-12.9 7.8-24.6 19.8-29.6s25.7-2.2 34.9 6.9l64 64c12.5 12.5 12.5 32.8 0 45.3l-64 64c-9.2 9.2-22.9 11.9-34.9 6.9s-19.8-16.6-19.8-29.6l0-32-32 0c-17.7 0-32-14.3-32-32s14.3-32 32-32zm297.4 54.6c-12.5-12.5-12.5-32.8 0-45.3l64-64c9.2-9.2 22.9-11.9 34.9-6.9s19.8 16.6 19.8 29.6l0 32 32 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-32 0 0 32c0 12.9-7.8 24.6-19.8 29.6s-25.7 2.2-34.9-6.9l-64-64zM256 224a32 32 0 1 1 0 64 32 32 0 1 1 0-64z\"]\n};\nconst faArchway = {\n prefix: 'fas',\n iconName: 'archway',\n icon: [512, 512, [], \"f557\", \"M32 32C14.3 32 0 46.3 0 64S14.3 96 32 96l448 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L32 32zm0 384c-17.7 0-32 14.3-32 32s14.3 32 32 32l64 0 64 0 0-128c0-53 43-96 96-96s96 43 96 96l0 128 64 0 64 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l0-288L32 128l0 288z\"]\n};\nconst faHeartCircleCheck = {\n prefix: 'fas',\n iconName: 'heart-circle-check',\n icon: [576, 512, [], \"e4fd\", \"M47.6 300.4L228.3 469.1c7.5 7 17.4 10.9 27.7 10.9s20.2-3.9 27.7-10.9l2.6-2.4C267.2 438.6 256 404.6 256 368c0-97.2 78.8-176 176-176c28.3 0 55 6.7 78.7 18.5c.9-6.5 1.3-13 1.3-19.6l0-5.8c0-69.9-50.5-129.5-119.4-141C347 36.5 300.6 51.4 268 84L256 96 244 84c-32.6-32.6-79-47.5-124.6-39.9C50.5 55.6 0 115.2 0 185.1l0 5.8c0 41.5 17.2 81.2 47.6 109.5zM576 368a144 144 0 1 0 -288 0 144 144 0 1 0 288 0zm-76.7-43.3c6.2 6.2 6.2 16.4 0 22.6l-72 72c-6.2 6.2-16.4 6.2-22.6 0l-40-40c-6.2-6.2-6.2-16.4 0-22.6s16.4-6.2 22.6 0L416 385.4l60.7-60.7c6.2-6.2 16.4-6.2 22.6 0z\"]\n};\nconst faHouseChimneyCrack = {\n prefix: 'fas',\n iconName: 'house-chimney-crack',\n icon: [576, 512, [\"house-damage\"], \"f6f1\", \"M575.8 255.5c0 18-15 32.1-32 32.1l-32 0 .7 160.2c.2 35.5-28.5 64.3-64 64.3l-122.1 0L288 448l80.8-67.3c7.8-6.5 7.6-18.6-.4-24.9L250.6 263.2c-14.6-11.5-33.8 7-22.8 22L288 368l-85.5 71.2c-6.1 5-7.5 13.8-3.5 20.5L230.4 512l-102.3 0c-35.3 0-64-28.7-64-64l0-160.4-32 0c-18 0-32-14-32-32.1c0-9 3-17 10-24L266.4 8c7-7 15-8 22-8s15 2 21 7L416 100.7 416 64c0-17.7 14.3-32 32-32l32 0c17.7 0 32 14.3 32 32l0 121 52.8 46.4c8 7 12 15 11 24z\"]\n};\nconst faHouseDamage = faHouseChimneyCrack;\nconst faFileZipper = {\n prefix: 'fas',\n iconName: 'file-zipper',\n icon: [384, 512, [\"file-archive\"], \"f1c6\", \"M64 0C28.7 0 0 28.7 0 64L0 448c0 35.3 28.7 64 64 64l256 0c35.3 0 64-28.7 64-64l0-288-128 0c-17.7 0-32-14.3-32-32L224 0 64 0zM256 0l0 128 128 0L256 0zM96 48c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16zm0 64c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16zm0 64c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16zm-6.3 71.8c3.7-14 16.4-23.8 30.9-23.8l14.8 0c14.5 0 27.2 9.7 30.9 23.8l23.5 88.2c1.4 5.4 2.1 10.9 2.1 16.4c0 35.2-28.8 63.7-64 63.7s-64-28.5-64-63.7c0-5.5 .7-11.1 2.1-16.4l23.5-88.2zM112 336c-8.8 0-16 7.2-16 16s7.2 16 16 16l32 0c8.8 0 16-7.2 16-16s-7.2-16-16-16l-32 0z\"]\n};\nconst faFileArchive = faFileZipper;\nconst faSquare = {\n prefix: 'fas',\n iconName: 'square',\n icon: [448, 512, [9632, 9723, 9724, 61590], \"f0c8\", \"M0 96C0 60.7 28.7 32 64 32H384c35.3 0 64 28.7 64 64V416c0 35.3-28.7 64-64 64H64c-35.3 0-64-28.7-64-64V96z\"]\n};\nconst faMartiniGlassEmpty = {\n prefix: 'fas',\n iconName: 'martini-glass-empty',\n icon: [512, 512, [\"glass-martini\"], \"f000\", \"M32 0C19.1 0 7.4 7.8 2.4 19.8s-2.2 25.7 6.9 34.9L224 269.3 224 448l-64 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l96 0 96 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-64 0 0-178.7L502.6 54.6c9.2-9.2 11.9-22.9 6.9-34.9S492.9 0 480 0L32 0zM256 210.7L109.3 64l293.5 0L256 210.7z\"]\n};\nconst faGlassMartini = faMartiniGlassEmpty;\nconst faCouch = {\n prefix: 'fas',\n iconName: 'couch',\n icon: [640, 512, [], \"f4b8\", \"M64 160C64 89.3 121.3 32 192 32l256 0c70.7 0 128 57.3 128 128l0 33.6c-36.5 7.4-64 39.7-64 78.4l0 48-384 0 0-48c0-38.7-27.5-71-64-78.4L64 160zM544 272c0-20.9 13.4-38.7 32-45.3c5-1.8 10.4-2.7 16-2.7c26.5 0 48 21.5 48 48l0 176c0 17.7-14.3 32-32 32l-32 0c-17.7 0-32-14.3-32-32L96 448c0 17.7-14.3 32-32 32l-32 0c-17.7 0-32-14.3-32-32L0 272c0-26.5 21.5-48 48-48c5.6 0 11 1 16 2.7c18.6 6.6 32 24.4 32 45.3l0 48 0 32 32 0 384 0 32 0 0-32 0-48z\"]\n};\nconst faCediSign = {\n prefix: 'fas',\n iconName: 'cedi-sign',\n icon: [384, 512, [], \"e0df\", \"M256 32c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 34.7C101.2 81.9 32 160.9 32 256s69.2 174.1 160 189.3l0 34.7c0 17.7 14.3 32 32 32s32-14.3 32-32l0-34.7c30.9-5.2 59.2-17.7 83.2-35.8c14.1-10.6 17-30.7 6.4-44.8s-30.7-17-44.8-6.4c-13.2 9.9-28.3 17.3-44.8 21.6L256 132c16.4 4.2 31.6 11.6 44.8 21.6c14.1 10.6 34.2 7.8 44.8-6.4s7.8-34.2-6.4-44.8c-24-18-52.4-30.6-83.2-35.8L256 32zM192 132L192 380c-55.2-14.2-96-64.3-96-124s40.8-109.8 96-124z\"]\n};\nconst faItalic = {\n prefix: 'fas',\n iconName: 'italic',\n icon: [384, 512, [], \"f033\", \"M128 64c0-17.7 14.3-32 32-32l192 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-58.7 0L160 416l64 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L32 480c-17.7 0-32-14.3-32-32s14.3-32 32-32l58.7 0L224 96l-64 0c-17.7 0-32-14.3-32-32z\"]\n};\nconst faTableCellsColumnLock = {\n prefix: 'fas',\n iconName: 'table-cells-column-lock',\n icon: [640, 512, [], \"e678\", \"M0 96C0 60.7 28.7 32 64 32l384 0c35.3 0 64 28.7 64 64l0 65.1c-37.8 5.4-69.4 29.6-85.2 62.9L360 224l0 64 56 0 0 8.6c-19.1 11.1-32 31.7-32 55.4l-24 0 0 64 24 0 0 64L64 480c-35.3 0-64-28.7-64-64L0 96zm208 0l0 64 88 0 0-64-88 0zm240 0l-88 0 0 64 88 0 0-64zM208 224l0 64 88 0 0-64-88 0zm0 128l0 64 88 0 0-64-88 0zM528 240c-17.7 0-32 14.3-32 32l0 48 64 0 0-48c0-17.7-14.3-32-32-32zm-80 32c0-44.2 35.8-80 80-80s80 35.8 80 80l0 48c17.7 0 32 14.3 32 32l0 128c0 17.7-14.3 32-32 32l-160 0c-17.7 0-32-14.3-32-32l0-128c0-17.7 14.3-32 32-32l0-48z\"]\n};\nconst faChurch = {\n prefix: 'fas',\n iconName: 'church',\n icon: [640, 512, [9962], \"f51d\", \"M344 24c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 24-32 0c-13.3 0-24 10.7-24 24s10.7 24 24 24l32 0 0 46.4L183.3 210c-14.5 8.7-23.3 24.3-23.3 41.2L160 512l96 0 0-96c0-35.3 28.7-64 64-64s64 28.7 64 64l0 96 96 0 0-260.8c0-16.9-8.8-32.5-23.3-41.2L344 142.4 344 96l32 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-32 0 0-24zM24.9 330.3C9.5 338.8 0 354.9 0 372.4L0 464c0 26.5 21.5 48 48 48l80 0 0-238.4L24.9 330.3zM592 512c26.5 0 48-21.5 48-48l0-91.6c0-17.5-9.5-33.6-24.9-42.1L512 273.6 512 512l80 0z\"]\n};\nconst faCommentsDollar = {\n prefix: 'fas',\n iconName: 'comments-dollar',\n icon: [640, 512, [], \"f653\", \"M416 176c0 97.2-93.1 176-208 176c-38.2 0-73.9-8.7-104.7-23.9c-7.5 4-16 7.9-25.2 11.4C59.8 346.4 37.8 352 16 352c-6.9 0-13.1-4.5-15.2-11.1s.2-13.8 5.8-17.9c0 0 0 0 0 0s0 0 0 0l.2-.2c.2-.2 .6-.4 1.1-.8c1-.8 2.5-2 4.3-3.7c3.6-3.3 8.5-8.1 13.3-14.3c5.5-7 10.7-15.4 14.2-24.7C14.7 250.3 0 214.6 0 176C0 78.8 93.1 0 208 0S416 78.8 416 176zM231.5 383C348.9 372.9 448 288.3 448 176c0-5.2-.2-10.4-.6-15.5C555.1 167.1 640 243.2 640 336c0 38.6-14.7 74.3-39.6 103.4c3.5 9.4 8.7 17.7 14.2 24.7c4.8 6.2 9.7 11 13.3 14.3c1.8 1.6 3.3 2.9 4.3 3.7c.5 .4 .9 .7 1.1 .8l.2 .2s0 0 0 0s0 0 0 0c5.6 4.1 7.9 11.3 5.8 17.9c-2.1 6.6-8.3 11.1-15.2 11.1c-21.8 0-43.8-5.6-62.1-12.5c-9.2-3.5-17.8-7.4-25.2-11.4C505.9 503.3 470.2 512 432 512c-95.6 0-176.2-54.6-200.5-129zM228 72c0-11-9-20-20-20s-20 9-20 20l0 14c-7.6 1.7-15.2 4.4-22.2 8.5c-13.9 8.3-25.9 22.8-25.8 43.9c.1 20.3 12 33.1 24.7 40.7c11 6.6 24.7 10.8 35.6 14l1.7 .5c12.6 3.8 21.8 6.8 28 10.7c5.1 3.2 5.8 5.4 5.9 8.2c.1 5-1.8 8-5.9 10.5c-5 3.1-12.9 5-21.4 4.7c-11.1-.4-21.5-3.9-35.1-8.5c-2.3-.8-4.7-1.6-7.2-2.4c-10.5-3.5-21.8 2.2-25.3 12.6s2.2 21.8 12.6 25.3c1.9 .6 4 1.3 6.1 2.1c0 0 0 0 0 0s0 0 0 0c8.3 2.9 17.9 6.2 28.2 8.4l0 14.6c0 11 9 20 20 20s20-9 20-20l0-13.8c8-1.7 16-4.5 23.2-9c14.3-8.9 25.1-24.1 24.8-45c-.3-20.3-11.7-33.4-24.6-41.6c-11.5-7.2-25.9-11.6-37.1-15l-.7-.2c-12.8-3.9-21.9-6.7-28.3-10.5c-5.2-3.1-5.3-4.9-5.3-6.7c0-3.7 1.4-6.5 6.2-9.3c5.4-3.2 13.6-5.1 21.5-5c9.6 .1 20.2 2.2 31.2 5.2c10.7 2.8 21.6-3.5 24.5-14.2s-3.5-21.6-14.2-24.5c-6.5-1.7-13.7-3.4-21.1-4.7L228 72z\"]\n};\nconst faDemocrat = {\n prefix: 'fas',\n iconName: 'democrat',\n icon: [640, 512, [], \"f747\", \"M64 32c0-8.9 3.8-20.9 6.2-27.3C71.2 1.8 74 0 77 0c1.9 0 3.8 .7 5.2 2.1L128 45.7 173.8 2.1C175.2 .7 177.1 0 179 0c3 0 5.8 1.8 6.8 4.7c2.4 6.5 6.2 18.4 6.2 27.3c0 26.5-21.9 42-29.5 46.6l76.2 72.6c6 5.7 13.9 8.8 22.1 8.8L480 160l32 0c40.3 0 78.2 19 102.4 51.2l19.2 25.6c10.6 14.1 7.7 34.2-6.4 44.8s-34.2 7.7-44.8-6.4l-19.2-25.6c-5.3-7-11.8-12.8-19.2-17l0 87.4-352 0-40.4-94.3c-3.9-9.2-15.3-12.6-23.6-7l-42.1 28c-9.1 6.1-19.7 9.3-30.7 9.3l-2 0C23.9 256 0 232.1 0 202.7c0-12.1 4.1-23.8 11.7-33.3L87.6 74.6C78.1 67.4 64 53.2 64 32zM448 352l96 0 0 64 0 64c0 17.7-14.3 32-32 32l-32 0c-17.7 0-32-14.3-32-32l0-64-160 0 0 64c0 17.7-14.3 32-32 32l-32 0c-17.7 0-32-14.3-32-32l0-64 0-64 96 0 160 0zM260.9 210.9c-.9-1.8-2.8-2.9-4.8-2.9s-3.9 1.1-4.8 2.9l-10.5 20.5-23.5 3.3c-2 .3-3.7 1.6-4.3 3.5s-.1 3.9 1.3 5.3l17 16-4 22.6c-.3 1.9 .5 3.9 2.1 5s3.8 1.3 5.6 .4l21-10.7 21 10.7c1.8 .9 4 .8 5.6-.4s2.5-3.1 2.1-5l-4-22.6 17-16c1.5-1.4 2-3.4 1.3-5.3s-2.3-3.2-4.3-3.5l-23.5-3.3-10.5-20.5zM368.1 208c-2 0-3.9 1.1-4.8 2.9l-10.5 20.5-23.5 3.3c-2 .3-3.7 1.6-4.3 3.5s-.1 3.9 1.3 5.3l17 16-4 22.6c-.3 1.9 .5 3.9 2.1 5s3.8 1.3 5.6 .4l21-10.7 21 10.7c1.8 .9 4 .8 5.6-.4s2.5-3.1 2.1-5l-4-22.6 17-16c1.5-1.4 2-3.4 1.4-5.3s-2.3-3.2-4.3-3.5l-23.5-3.3-10.5-20.5c-.9-1.8-2.8-2.9-4.8-2.9zm116.8 2.9c-.9-1.8-2.8-2.9-4.8-2.9s-3.9 1.1-4.8 2.9l-10.5 20.5-23.5 3.3c-2 .3-3.7 1.6-4.3 3.5s-.1 3.9 1.3 5.3l17 16-4 22.6c-.3 1.9 .5 3.9 2.1 5s3.8 1.3 5.6 .4l21-10.7 21 10.7c1.8 .9 4 .8 5.6-.4s2.5-3.1 2.1-5l-4-22.6 17-16c1.5-1.4 2-3.4 1.4-5.3s-2.3-3.2-4.3-3.5l-23.5-3.3-10.5-20.5z\"]\n};\nconst faZ = {\n prefix: 'fas',\n iconName: 'z',\n icon: [384, 512, [122], \"5a\", \"M0 64C0 46.3 14.3 32 32 32l320 0c12.4 0 23.7 7.2 29 18.4s3.6 24.5-4.4 34.1L100.3 416 352 416c17.7 0 32 14.3 32 32s-14.3 32-32 32L32 480c-12.4 0-23.7-7.2-29-18.4s-3.6-24.5 4.4-34.1L283.7 96 32 96C14.3 96 0 81.7 0 64z\"]\n};\nconst faPersonSkiing = {\n prefix: 'fas',\n iconName: 'person-skiing',\n icon: [512, 512, [9975, \"skiing\"], \"f7c9\", \"M380.7 48a48 48 0 1 1 96 0 48 48 0 1 1 -96 0zM2.7 268.9c6.1-11.8 20.6-16.3 32.4-10.2L232.7 361.3l46.2-69.2-75.1-75.1c-14.6-14.6-20.4-33.9-18.4-52.1l108.8 52 39.3 39.3c16.2 16.2 18.7 41.5 6 60.6L289.8 391l128.7 66.8c13.6 7.1 29.8 7.2 43.6 .3l15.2-7.6c11.9-5.9 26.3-1.1 32.2 10.7s1.1 26.3-10.7 32.2l-15.2 7.6c-27.5 13.7-59.9 13.5-87.2-.7L12.9 301.3C1.2 295.2-3.4 280.7 2.7 268.9zM118.9 65.6L137 74.2l8.7-17.4c4-7.9 13.6-11.1 21.5-7.2s11.1 13.6 7.2 21.5l-8.5 16.9 54.7 26.2c1.5-.7 3.1-1.4 4.7-2.1l83.4-33.4c34.2-13.7 72.8 4.2 84.5 39.2l17.1 51.2 52.1 26.1c15.8 7.9 22.2 27.1 14.3 42.9s-27.1 22.2-42.9 14.3l-58.1-29c-11.4-5.7-20-15.7-24.1-27.8l-5.8-17.3-27.3 12.1-6.8 3-6.7-3.2L151.5 116.7l-9.2 18.4c-4 7.9-13.6 11.1-21.5 7.2s-11.1-13.6-7.2-21.5l9-18-17.6-8.4c-8-3.8-11.3-13.4-7.5-21.3s13.4-11.3 21.3-7.5z\"]\n};\nconst faSkiing = faPersonSkiing;\nconst faRoadLock = {\n prefix: 'fas',\n iconName: 'road-lock',\n icon: [640, 512, [], \"e567\", \"M288 32l-74.8 0c-27.1 0-51.3 17.1-60.3 42.6L35.1 407.2c-2.1 5.9-3.1 12-3.1 18.2C32 455.5 56.5 480 86.6 480L288 480l0-64c0-17.7 14.3-32 32-32s32 14.3 32 32l0 64 32 0 0-128c0-23.7 12.9-44.4 32-55.4l0-24.6c0-58.3 44.6-106.2 101.5-111.5L487.1 74.6C478 49.1 453.9 32 426.8 32L352 32l0 64c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-64zm64 192l0 64c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-64c0-17.7 14.3-32 32-32s32 14.3 32 32zm176 16c17.7 0 32 14.3 32 32l0 48-64 0 0-48c0-17.7 14.3-32 32-32zm-80 32l0 48c-17.7 0-32 14.3-32 32l0 128c0 17.7 14.3 32 32 32l160 0c17.7 0 32-14.3 32-32l0-128c0-17.7-14.3-32-32-32l0-48c0-44.2-35.8-80-80-80s-80 35.8-80 80z\"]\n};\nconst faA = {\n prefix: 'fas',\n iconName: 'a',\n icon: [384, 512, [97], \"41\", \"M221.5 51.7C216.6 39.8 204.9 32 192 32s-24.6 7.8-29.5 19.7l-120 288-40 96c-6.8 16.3 .9 35 17.2 41.8s35-.9 41.8-17.2L93.3 384l197.3 0 31.8 76.3c6.8 16.3 25.5 24 41.8 17.2s24-25.5 17.2-41.8l-40-96-120-288zM264 320l-144 0 72-172.8L264 320z\"]\n};\nconst faTemperatureArrowDown = {\n prefix: 'fas',\n iconName: 'temperature-arrow-down',\n icon: [576, 512, [\"temperature-down\"], \"e03f\", \"M128 112c0-26.5 21.5-48 48-48s48 21.5 48 48l0 164.5c0 17.3 7.1 31.9 15.3 42.5C249.8 332.6 256 349.5 256 368c0 44.2-35.8 80-80 80s-80-35.8-80-80c0-18.5 6.2-35.4 16.7-48.9c8.2-10.6 15.3-25.2 15.3-42.5L128 112zM176 0C114.1 0 64 50.1 64 112l0 164.4c0 .1-.1 .3-.2 .6c-.2 .6-.8 1.6-1.7 2.8C43.2 304.2 32 334.8 32 368c0 79.5 64.5 144 144 144s144-64.5 144-144c0-33.2-11.2-63.8-30.1-88.1c-.9-1.2-1.5-2.2-1.7-2.8c-.1-.3-.2-.5-.2-.6L288 112C288 50.1 237.9 0 176 0zm0 416c26.5 0 48-21.5 48-48c0-20.9-13.4-38.7-32-45.3l0-50.7c0-8.8-7.2-16-16-16s-16 7.2-16 16l0 50.7c-18.6 6.6-32 24.4-32 45.3c0 26.5 21.5 48 48 48zm336-64l-32 0 0-288c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 288-32 0c-12.9 0-24.6 7.8-29.6 19.8s-2.2 25.7 6.9 34.9l64 64c6 6 14.1 9.4 22.6 9.4s16.6-3.4 22.6-9.4l64-64c9.2-9.2 11.9-22.9 6.9-34.9s-16.6-19.8-29.6-19.8z\"]\n};\nconst faTemperatureDown = faTemperatureArrowDown;\nconst faFeatherPointed = {\n prefix: 'fas',\n iconName: 'feather-pointed',\n icon: [512, 512, [\"feather-alt\"], \"f56b\", \"M278.5 215.6L23 471c-9.4 9.4-9.4 24.6 0 33.9s24.6 9.4 33.9 0l74.8-74.8c7.4 4.6 15.3 8.2 23.8 10.5C200.3 452.8 270 454.5 338 409.4c12.2-8.1 5.8-25.4-8.8-25.4l-16.1 0c-5.1 0-9.2-4.1-9.2-9.2c0-4.1 2.7-7.6 6.5-8.8l97.7-29.3c3.4-1 6.4-3.1 8.4-6.1c4.4-6.4 8.6-12.9 12.6-19.6c6.2-10.3-1.5-23-13.5-23l-38.6 0c-5.1 0-9.2-4.1-9.2-9.2c0-4.1 2.7-7.6 6.5-8.8l80.9-24.3c4.6-1.4 8.4-4.8 10.2-9.3C494.5 163 507.8 86.1 511.9 36.8c.8-9.9-3-19.6-10-26.6s-16.7-10.8-26.6-10C391.5 7 228.5 40.5 137.4 131.6C57.3 211.7 56.7 302.3 71.3 356.4c2.1 7.9 12 9.6 17.8 3.8L253.6 195.8c6.2-6.2 16.4-6.2 22.6 0c5.4 5.4 6.1 13.6 2.2 19.8z\"]\n};\nconst faFeatherAlt = faFeatherPointed;\nconst faP = {\n prefix: 'fas',\n iconName: 'p',\n icon: [320, 512, [112], \"50\", \"M0 96C0 60.7 28.7 32 64 32l96 0c88.4 0 160 71.6 160 160s-71.6 160-160 160l-96 0 0 96c0 17.7-14.3 32-32 32s-32-14.3-32-32L0 320 0 96zM64 288l96 0c53 0 96-43 96-96s-43-96-96-96L64 96l0 192z\"]\n};\nconst faSnowflake = {\n prefix: 'fas',\n iconName: 'snowflake',\n icon: [448, 512, [10052, 10054], \"f2dc\", \"M224 0c17.7 0 32 14.3 32 32l0 30.1 15-15c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9l-49 49 0 70.3 61.4-35.8 17.7-66.1c3.4-12.8 16.6-20.4 29.4-17s20.4 16.6 17 29.4l-5.2 19.3 23.6-13.8c15.3-8.9 34.9-3.7 43.8 11.5s3.8 34.9-11.5 43.8l-25.3 14.8 21.7 5.8c12.8 3.4 20.4 16.6 17 29.4s-16.6 20.4-29.4 17l-67.7-18.1L287.5 256l60.9 35.5 67.7-18.1c12.8-3.4 26 4.2 29.4 17s-4.2 26-17 29.4l-21.7 5.8 25.3 14.8c15.3 8.9 20.4 28.5 11.5 43.8s-28.5 20.4-43.8 11.5l-23.6-13.8 5.2 19.3c3.4 12.8-4.2 26-17 29.4s-26-4.2-29.4-17l-17.7-66.1L256 311.7l0 70.3 49 49c9.4 9.4 9.4 24.6 0 33.9s-24.6 9.4-33.9 0l-15-15 0 30.1c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-30.1-15 15c-9.4 9.4-24.6 9.4-33.9 0s-9.4-24.6 0-33.9l49-49 0-70.3-61.4 35.8-17.7 66.1c-3.4 12.8-16.6 20.4-29.4 17s-20.4-16.6-17-29.4l5.2-19.3L48.1 395.6c-15.3 8.9-34.9 3.7-43.8-11.5s-3.7-34.9 11.5-43.8l25.3-14.8-21.7-5.8c-12.8-3.4-20.4-16.6-17-29.4s16.6-20.4 29.4-17l67.7 18.1L160.5 256 99.6 220.5 31.9 238.6c-12.8 3.4-26-4.2-29.4-17s4.2-26 17-29.4l21.7-5.8L15.9 171.6C.6 162.7-4.5 143.1 4.4 127.9s28.5-20.4 43.8-11.5l23.6 13.8-5.2-19.3c-3.4-12.8 4.2-26 17-29.4s26 4.2 29.4 17l17.7 66.1L192 200.3l0-70.3L143 81c-9.4-9.4-9.4-24.6 0-33.9s24.6-9.4 33.9 0l15 15L192 32c0-17.7 14.3-32 32-32z\"]\n};\nconst faNewspaper = {\n prefix: 'fas',\n iconName: 'newspaper',\n icon: [512, 512, [128240], \"f1ea\", \"M96 96c0-35.3 28.7-64 64-64l288 0c35.3 0 64 28.7 64 64l0 320c0 35.3-28.7 64-64 64L80 480c-44.2 0-80-35.8-80-80L0 128c0-17.7 14.3-32 32-32s32 14.3 32 32l0 272c0 8.8 7.2 16 16 16s16-7.2 16-16L96 96zm64 24l0 80c0 13.3 10.7 24 24 24l112 0c13.3 0 24-10.7 24-24l0-80c0-13.3-10.7-24-24-24L184 96c-13.3 0-24 10.7-24 24zm208-8c0 8.8 7.2 16 16 16l48 0c8.8 0 16-7.2 16-16s-7.2-16-16-16l-48 0c-8.8 0-16 7.2-16 16zm0 96c0 8.8 7.2 16 16 16l48 0c8.8 0 16-7.2 16-16s-7.2-16-16-16l-48 0c-8.8 0-16 7.2-16 16zM160 304c0 8.8 7.2 16 16 16l256 0c8.8 0 16-7.2 16-16s-7.2-16-16-16l-256 0c-8.8 0-16 7.2-16 16zm0 96c0 8.8 7.2 16 16 16l256 0c8.8 0 16-7.2 16-16s-7.2-16-16-16l-256 0c-8.8 0-16 7.2-16 16z\"]\n};\nconst faRectangleAd = {\n prefix: 'fas',\n iconName: 'rectangle-ad',\n icon: [576, 512, [\"ad\"], \"f641\", \"M64 32C28.7 32 0 60.7 0 96L0 416c0 35.3 28.7 64 64 64l448 0c35.3 0 64-28.7 64-64l0-320c0-35.3-28.7-64-64-64L64 32zM229.5 173.3l72 144c5.9 11.9 1.1 26.3-10.7 32.2s-26.3 1.1-32.2-10.7L253.2 328l-90.3 0-5.4 10.7c-5.9 11.9-20.3 16.7-32.2 10.7s-16.7-20.3-10.7-32.2l72-144c4.1-8.1 12.4-13.3 21.5-13.3s17.4 5.1 21.5 13.3zM208 237.7L186.8 280l42.3 0L208 237.7zM392 256a24 24 0 1 0 0 48 24 24 0 1 0 0-48zm24-43.9l0-28.1c0-13.3 10.7-24 24-24s24 10.7 24 24l0 96 0 48c0 13.3-10.7 24-24 24c-6.6 0-12.6-2.7-17-7c-9.4 4.5-19.9 7-31 7c-39.8 0-72-32.2-72-72s32.2-72 72-72c8.4 0 16.5 1.4 24 4.1z\"]\n};\nconst faAd = faRectangleAd;\nconst faCircleArrowRight = {\n prefix: 'fas',\n iconName: 'circle-arrow-right',\n icon: [512, 512, [\"arrow-circle-right\"], \"f0a9\", \"M0 256a256 256 0 1 0 512 0A256 256 0 1 0 0 256zM297 385c-9.4 9.4-24.6 9.4-33.9 0s-9.4-24.6 0-33.9l71-71L120 280c-13.3 0-24-10.7-24-24s10.7-24 24-24l214.1 0-71-71c-9.4-9.4-9.4-24.6 0-33.9s24.6-9.4 33.9 0L409 239c9.4 9.4 9.4 24.6 0 33.9L297 385z\"]\n};\nconst faArrowCircleRight = faCircleArrowRight;\nconst faFilterCircleXmark = {\n prefix: 'fas',\n iconName: 'filter-circle-xmark',\n icon: [576, 512, [], \"e17b\", \"M3.9 22.9C10.5 8.9 24.5 0 40 0L472 0c15.5 0 29.5 8.9 36.1 22.9s4.6 30.5-5.2 42.5L396.4 195.6C316.2 212.1 256 283 256 368c0 27.4 6.3 53.4 17.5 76.5c-1.6-.8-3.2-1.8-4.7-2.9l-64-48c-8.1-6-12.8-15.5-12.8-25.6l0-79.1L9 65.3C-.7 53.4-2.8 36.8 3.9 22.9zM432 224a144 144 0 1 1 0 288 144 144 0 1 1 0-288zm59.3 107.3c6.2-6.2 6.2-16.4 0-22.6s-16.4-6.2-22.6 0L432 345.4l-36.7-36.7c-6.2-6.2-16.4-6.2-22.6 0s-6.2 16.4 0 22.6L409.4 368l-36.7 36.7c-6.2 6.2-6.2 16.4 0 22.6s16.4 6.2 22.6 0L432 390.6l36.7 36.7c6.2 6.2 16.4 6.2 22.6 0s6.2-16.4 0-22.6L454.6 368l36.7-36.7z\"]\n};\nconst faLocust = {\n prefix: 'fas',\n iconName: 'locust',\n icon: [576, 512, [], \"e520\", \"M312 32c-13.3 0-24 10.7-24 24s10.7 24 24 24l16 0c98.7 0 180.6 71.4 197 165.4c-9-3.5-18.8-5.4-29-5.4l-64.2 0-41.8-97.5c-3.4-7.9-10.8-13.4-19.3-14.4s-17 2.7-22.1 9.6l-40.9 55.5-21.7-50.7c-3.3-7.8-10.5-13.2-18.9-14.3s-16.7 2.3-22 8.9l-240 304c-8.2 10.4-6.4 25.5 4 33.7s25.5 6.4 33.7-4l79.4-100.5 43 16.4-40.5 55c-7.9 10.7-5.6 25.7 5.1 33.6s25.7 5.6 33.6-5.1L215.1 400l74.5 0-29.3 42.3c-7.5 10.9-4.8 25.8 6.1 33.4s25.8 4.8 33.4-6.1L348 400l80.4 0 38.8 67.9c6.6 11.5 21.2 15.5 32.7 8.9s15.5-21.2 8.9-32.7L483.6 400l12.4 0c44.1 0 79.8-35.7 80-79.7c0-.1 0-.2 0-.3l0-40C576 143 465 32 328 32l-16 0zm50.5 168l17.1 40L333 240l29.5-40zm-87.7 38.1l-1.4 1.9-48.2 0 32.7-41.5 16.9 39.5zM88.8 240C57.4 240 32 265.4 32 296.8c0 15.5 6.3 30 16.9 40.4L126.7 240l-37.9 0zM496 288a16 16 0 1 1 0 32 16 16 0 1 1 0-32z\"]\n};\nconst faSort = {\n prefix: 'fas',\n iconName: 'sort',\n icon: [320, 512, [\"unsorted\"], \"f0dc\", \"M137.4 41.4c12.5-12.5 32.8-12.5 45.3 0l128 128c9.2 9.2 11.9 22.9 6.9 34.9s-16.6 19.8-29.6 19.8L32 224c-12.9 0-24.6-7.8-29.6-19.8s-2.2-25.7 6.9-34.9l128-128zm0 429.3l-128-128c-9.2-9.2-11.9-22.9-6.9-34.9s16.6-19.8 29.6-19.8l256 0c12.9 0 24.6 7.8 29.6 19.8s2.2 25.7-6.9 34.9l-128 128c-12.5 12.5-32.8 12.5-45.3 0z\"]\n};\nconst faUnsorted = faSort;\nconst faListOl = {\n prefix: 'fas',\n iconName: 'list-ol',\n icon: [512, 512, [\"list-1-2\", \"list-numeric\"], \"f0cb\", \"M24 56c0-13.3 10.7-24 24-24l32 0c13.3 0 24 10.7 24 24l0 120 16 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-80 0c-13.3 0-24-10.7-24-24s10.7-24 24-24l16 0 0-96-8 0C34.7 80 24 69.3 24 56zM86.7 341.2c-6.5-7.4-18.3-6.9-24 1.2L51.5 357.9c-7.7 10.8-22.7 13.3-33.5 5.6s-13.3-22.7-5.6-33.5l11.1-15.6c23.7-33.2 72.3-35.6 99.2-4.9c21.3 24.4 20.8 60.9-1.1 84.7L86.8 432l33.2 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-88 0c-9.5 0-18.2-5.6-22-14.4s-2.1-18.9 4.3-25.9l72-78c5.3-5.8 5.4-14.6 .3-20.5zM224 64l256 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-256 0c-17.7 0-32-14.3-32-32s14.3-32 32-32zm0 160l256 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-256 0c-17.7 0-32-14.3-32-32s14.3-32 32-32zm0 160l256 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-256 0c-17.7 0-32-14.3-32-32s14.3-32 32-32z\"]\n};\nconst faList12 = faListOl;\nconst faListNumeric = faListOl;\nconst faPersonDressBurst = {\n prefix: 'fas',\n iconName: 'person-dress-burst',\n icon: [640, 512, [], \"e544\", \"M528 48a48 48 0 1 0 -96 0 48 48 0 1 0 96 0zM390.2 384l17.8 0 0 96c0 17.7 14.3 32 32 32s32-14.3 32-32l0-96 16 0 0 96c0 17.7 14.3 32 32 32s32-14.3 32-32l0-96 17.8 0c10.9 0 18.6-10.7 15.2-21.1L546.7 248.1l33.9 56.3c9.1 15.1 28.8 20 43.9 10.9s20-28.8 10.9-43.9l-53.6-89.2c-20.2-33.7-56.7-54.3-96-54.3l-11.6 0c-39.3 0-75.7 20.6-96 54.3l-53.6 89.2c-9.1 15.1-4.2 34.8 10.9 43.9s34.8 4.2 43.9-10.9l33.9-56.3L375 362.9c-3.5 10.4 4.3 21.1 15.2 21.1zM190.9 18.1C188.4 12 182.6 8 176 8s-12.4 4-14.9 10.1l-29.4 74L55.6 68.9c-6.3-1.9-13.1 .2-17.2 5.3s-4.6 12.2-1.4 17.9l39.5 69.1L10.9 206.4c-5.4 3.7-8 10.3-6.5 16.7s6.7 11.2 13.1 12.2l78.7 12.2L90.6 327c-.5 6.5 3.1 12.7 9 15.5s12.9 1.8 17.8-2.6L176 286.1l58.6 53.9c4.8 4.4 11.9 5.5 17.8 2.6s9.5-9 9-15.5l-5.6-79.4 50.5-7.8 24.4-40.5-55.2-38L315 92.2c3.3-5.7 2.7-12.8-1.4-17.9s-10.9-7.2-17.2-5.3L220.3 92.1l-29.4-74z\"]\n};\nconst faMoneyCheckDollar = {\n prefix: 'fas',\n iconName: 'money-check-dollar',\n icon: [576, 512, [\"money-check-alt\"], \"f53d\", \"M64 64C28.7 64 0 92.7 0 128L0 384c0 35.3 28.7 64 64 64l448 0c35.3 0 64-28.7 64-64l0-256c0-35.3-28.7-64-64-64L64 64zM272 192l224 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-224 0c-8.8 0-16-7.2-16-16s7.2-16 16-16zM256 304c0-8.8 7.2-16 16-16l224 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-224 0c-8.8 0-16-7.2-16-16zM164 152l0 13.9c7.5 1.2 14.6 2.9 21.1 4.7c10.7 2.8 17 13.8 14.2 24.5s-13.8 17-24.5 14.2c-11-2.9-21.6-5-31.2-5.2c-7.9-.1-16 1.8-21.5 5c-4.8 2.8-6.2 5.6-6.2 9.3c0 1.8 .1 3.5 5.3 6.7c6.3 3.8 15.5 6.7 28.3 10.5l.7 .2c11.2 3.4 25.6 7.7 37.1 15c12.9 8.1 24.3 21.3 24.6 41.6c.3 20.9-10.5 36.1-24.8 45c-7.2 4.5-15.2 7.3-23.2 9l0 13.8c0 11-9 20-20 20s-20-9-20-20l0-14.6c-10.3-2.2-20-5.5-28.2-8.4c0 0 0 0 0 0s0 0 0 0c-2.1-.7-4.1-1.4-6.1-2.1c-10.5-3.5-16.1-14.8-12.6-25.3s14.8-16.1 25.3-12.6c2.5 .8 4.9 1.7 7.2 2.4c13.6 4.6 24 8.1 35.1 8.5c8.6 .3 16.5-1.6 21.4-4.7c4.1-2.5 6-5.5 5.9-10.5c0-2.9-.8-5-5.9-8.2c-6.3-4-15.4-6.9-28-10.7l-1.7-.5c-10.9-3.3-24.6-7.4-35.6-14c-12.7-7.7-24.6-20.5-24.7-40.7c-.1-21.1 11.8-35.7 25.8-43.9c6.9-4.1 14.5-6.8 22.2-8.5l0-14c0-11 9-20 20-20s20 9 20 20z\"]\n};\nconst faMoneyCheckAlt = faMoneyCheckDollar;\nconst faVectorSquare = {\n prefix: 'fas',\n iconName: 'vector-square',\n icon: [448, 512, [], \"f5cb\", \"M368 80l32 0 0 32-32 0 0-32zM352 32c-17.7 0-32 14.3-32 32L128 64c0-17.7-14.3-32-32-32L32 32C14.3 32 0 46.3 0 64l0 64c0 17.7 14.3 32 32 32l0 192c-17.7 0-32 14.3-32 32l0 64c0 17.7 14.3 32 32 32l64 0c17.7 0 32-14.3 32-32l192 0c0 17.7 14.3 32 32 32l64 0c17.7 0 32-14.3 32-32l0-64c0-17.7-14.3-32-32-32l0-192c17.7 0 32-14.3 32-32l0-64c0-17.7-14.3-32-32-32l-64 0zM96 160c17.7 0 32-14.3 32-32l192 0c0 17.7 14.3 32 32 32l0 192c-17.7 0-32 14.3-32 32l-192 0c0-17.7-14.3-32-32-32l0-192zM48 400l32 0 0 32-32 0 0-32zm320 32l0-32 32 0 0 32-32 0zM48 112l0-32 32 0 0 32-32 0z\"]\n};\nconst faBreadSlice = {\n prefix: 'fas',\n iconName: 'bread-slice',\n icon: [512, 512, [], \"f7ec\", \"M256 32C192 32 0 64 0 192c0 35.3 28.7 64 64 64V432c0 26.5 21.5 48 48 48H400c26.5 0 48-21.5 48-48V256c35.3 0 64-28.7 64-64C512 64 320 32 256 32z\"]\n};\nconst faLanguage = {\n prefix: 'fas',\n iconName: 'language',\n icon: [640, 512, [], \"f1ab\", \"M0 128C0 92.7 28.7 64 64 64l192 0 48 0 16 0 256 0c35.3 0 64 28.7 64 64l0 256c0 35.3-28.7 64-64 64l-256 0-16 0-48 0L64 448c-35.3 0-64-28.7-64-64L0 128zm320 0l0 256 256 0 0-256-256 0zM178.3 175.9c-3.2-7.2-10.4-11.9-18.3-11.9s-15.1 4.7-18.3 11.9l-64 144c-4.5 10.1 .1 21.9 10.2 26.4s21.9-.1 26.4-10.2l8.9-20.1 73.6 0 8.9 20.1c4.5 10.1 16.3 14.6 26.4 10.2s14.6-16.3 10.2-26.4l-64-144zM160 233.2L179 276l-38 0 19-42.8zM448 164c11 0 20 9 20 20l0 4 44 0 16 0c11 0 20 9 20 20s-9 20-20 20l-2 0-1.6 4.5c-8.9 24.4-22.4 46.6-39.6 65.4c.9 .6 1.8 1.1 2.7 1.6l18.9 11.3c9.5 5.7 12.5 18 6.9 27.4s-18 12.5-27.4 6.9l-18.9-11.3c-4.5-2.7-8.8-5.5-13.1-8.5c-10.6 7.5-21.9 14-34 19.4l-3.6 1.6c-10.1 4.5-21.9-.1-26.4-10.2s.1-21.9 10.2-26.4l3.6-1.6c6.4-2.9 12.6-6.1 18.5-9.8l-12.2-12.2c-7.8-7.8-7.8-20.5 0-28.3s20.5-7.8 28.3 0l14.6 14.6 .5 .5c12.4-13.1 22.5-28.3 29.8-45L448 228l-72 0c-11 0-20-9-20-20s9-20 20-20l52 0 0-4c0-11 9-20 20-20z\"]\n};\nconst faFaceKissWinkHeart = {\n prefix: 'fas',\n iconName: 'face-kiss-wink-heart',\n icon: [512, 512, [128536, \"kiss-wink-heart\"], \"f598\", \"M498 339.7c9.1-26.2 14-54.4 14-83.7C512 114.6 397.4 0 256 0S0 114.6 0 256S114.6 512 256 512c35.4 0 69.1-7.2 99.7-20.2c-4.8-5.5-8.5-12.2-10.4-19.7l-22.9-89.3c-10-39 11.8-80.9 51.8-92.1c37.2-10.4 73.8 10.1 87.5 44c12.7-1.6 25.1 .4 36.2 5zM296 332c0 6.9-3.1 13.2-7.3 18.3c-4.3 5.2-10.1 9.7-16.7 13.4c-2.7 1.5-5.7 3-8.7 4.3c3.1 1.3 6 2.7 8.7 4.3c6.6 3.7 12.5 8.2 16.7 13.4c4.3 5.1 7.3 11.4 7.3 18.3s-3.1 13.2-7.3 18.3c-4.3 5.2-10.1 9.7-16.7 13.4C258.7 443.1 241.4 448 224 448c-3.6 0-6.8-2.5-7.7-6s.6-7.2 3.8-9c0 0 0 0 0 0s0 0 0 0s0 0 0 0c0 0 0 0 0 0l.2-.1c.2-.1 .5-.3 .9-.5c.8-.5 2-1.2 3.4-2.1c2.8-1.9 6.5-4.5 10.2-7.6c3.7-3.1 7.2-6.6 9.6-10.1c2.5-3.5 3.5-6.4 3.5-8.6s-1-5-3.5-8.6c-2.5-3.5-5.9-6.9-9.6-10.1c-3.7-3.1-7.4-5.7-10.2-7.6c-1.4-.9-2.6-1.6-3.4-2.1l-.6-.4-.3-.2-.2-.1c0 0 0 0 0 0c0 0 0 0 0 0s0 0 0 0c-2.5-1.4-4.1-4.1-4.1-7s1.6-5.6 4.1-7c0 0 0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0c0 0 0 0 0 0l.2-.1c.2-.1 .5-.3 .9-.5c.8-.5 2-1.2 3.4-2.1c2.8-1.9 6.5-4.5 10.2-7.6c3.7-3.1 7.2-6.6 9.6-10.1c2.5-3.5 3.5-6.4 3.5-8.6s-1-5-3.5-8.6c-2.5-3.5-5.9-6.9-9.6-10.1c-3.7-3.1-7.4-5.7-10.2-7.6c-1.4-.9-2.6-1.6-3.4-2.1c-.4-.2-.7-.4-.9-.5l-.2-.1c0 0 0 0 0 0c0 0 0 0 0 0s0 0 0 0c-3.2-1.8-4.7-5.5-3.8-9s4.1-6 7.7-6c17.4 0 34.7 4.9 47.9 12.3c6.6 3.7 12.5 8.2 16.7 13.4c4.3 5.1 7.3 11.4 7.3 18.3zM176.4 176a32 32 0 1 1 0 64 32 32 0 1 1 0-64zm194.8 57.6c-17.6-23.5-52.8-23.5-70.4 0c-5.3 7.1-15.3 8.5-22.4 3.2s-8.5-15.3-3.2-22.4c30.4-40.5 91.2-40.5 121.6 0c5.3 7.1 3.9 17.1-3.2 22.4s-17.1 3.9-22.4-3.2zM434 352.3c-6-23.2-28.8-37-51.1-30.8s-35.4 30.1-29.5 53.4l22.9 89.3c2.2 8.7 11.2 13.9 19.8 11.4l84.9-23.8c22.2-6.2 35.4-30.1 29.5-53.4s-28.8-37-51.1-30.8l-20.2 5.6-5.4-21z\"]\n};\nconst faKissWinkHeart = faFaceKissWinkHeart;\nconst faFilter = {\n prefix: 'fas',\n iconName: 'filter',\n icon: [512, 512, [], \"f0b0\", \"M3.9 54.9C10.5 40.9 24.5 32 40 32l432 0c15.5 0 29.5 8.9 36.1 22.9s4.6 30.5-5.2 42.5L320 320.9 320 448c0 12.1-6.8 23.2-17.7 28.6s-23.8 4.3-33.5-3l-64-48c-8.1-6-12.8-15.5-12.8-25.6l0-79.1L9 97.3C-.7 85.4-2.8 68.8 3.9 54.9z\"]\n};\nconst faQuestion = {\n prefix: 'fas',\n iconName: 'question',\n icon: [320, 512, [10067, 10068, 61736], \"3f\", \"M80 160c0-35.3 28.7-64 64-64l32 0c35.3 0 64 28.7 64 64l0 3.6c0 21.8-11.1 42.1-29.4 53.8l-42.2 27.1c-25.2 16.2-40.4 44.1-40.4 74l0 1.4c0 17.7 14.3 32 32 32s32-14.3 32-32l0-1.4c0-8.2 4.2-15.8 11-20.2l42.2-27.1c36.6-23.6 58.8-64.1 58.8-107.7l0-3.6c0-70.7-57.3-128-128-128l-32 0C73.3 32 16 89.3 16 160c0 17.7 14.3 32 32 32s32-14.3 32-32zm80 320a40 40 0 1 0 0-80 40 40 0 1 0 0 80z\"]\n};\nconst faFileSignature = {\n prefix: 'fas',\n iconName: 'file-signature',\n icon: [576, 512, [], \"f573\", \"M64 0C28.7 0 0 28.7 0 64L0 448c0 35.3 28.7 64 64 64l256 0c35.3 0 64-28.7 64-64l0-19.3c-2.7 1.1-5.4 2-8.2 2.7l-60.1 15c-3 .7-6 1.2-9 1.4c-.9 .1-1.8 .2-2.7 .2l-64 0c-6.1 0-11.6-3.4-14.3-8.8l-8.8-17.7c-1.7-3.4-5.1-5.5-8.8-5.5s-7.2 2.1-8.8 5.5l-8.8 17.7c-2.9 5.9-9.2 9.4-15.7 8.8s-12.1-5.1-13.9-11.3L144 381l-9.8 32.8c-6.1 20.3-24.8 34.2-46 34.2L80 448c-8.8 0-16-7.2-16-16s7.2-16 16-16l8.2 0c7.1 0 13.3-4.6 15.3-11.4l14.9-49.5c3.4-11.3 13.8-19.1 25.6-19.1s22.2 7.8 25.6 19.1l11.6 38.6c7.4-6.2 16.8-9.7 26.8-9.7c15.9 0 30.4 9 37.5 23.2l4.4 8.8 8.9 0c-3.1-8.8-3.7-18.4-1.4-27.8l15-60.1c2.8-11.3 8.6-21.5 16.8-29.7L384 203.6l0-43.6-128 0c-17.7 0-32-14.3-32-32L224 0 64 0zM256 0l0 128 128 0L256 0zM549.8 139.7c-15.6-15.6-40.9-15.6-56.6 0l-29.4 29.4 71 71 29.4-29.4c15.6-15.6 15.6-40.9 0-56.6l-14.4-14.4zM311.9 321c-4.1 4.1-7 9.2-8.4 14.9l-15 60.1c-1.4 5.5 .2 11.2 4.2 15.2s9.7 5.6 15.2 4.2l60.1-15c5.6-1.4 10.8-4.3 14.9-8.4L512.1 262.7l-71-71L311.9 321z\"]\n};\nconst faUpDownLeftRight = {\n prefix: 'fas',\n iconName: 'up-down-left-right',\n icon: [512, 512, [\"arrows-alt\"], \"f0b2\", \"M278.6 9.4c-12.5-12.5-32.8-12.5-45.3 0l-64 64c-9.2 9.2-11.9 22.9-6.9 34.9s16.6 19.8 29.6 19.8l32 0 0 96-96 0 0-32c0-12.9-7.8-24.6-19.8-29.6s-25.7-2.2-34.9 6.9l-64 64c-12.5 12.5-12.5 32.8 0 45.3l64 64c9.2 9.2 22.9 11.9 34.9 6.9s19.8-16.6 19.8-29.6l0-32 96 0 0 96-32 0c-12.9 0-24.6 7.8-29.6 19.8s-2.2 25.7 6.9 34.9l64 64c12.5 12.5 32.8 12.5 45.3 0l64-64c9.2-9.2 11.9-22.9 6.9-34.9s-16.6-19.8-29.6-19.8l-32 0 0-96 96 0 0 32c0 12.9 7.8 24.6 19.8 29.6s25.7 2.2 34.9-6.9l64-64c12.5-12.5 12.5-32.8 0-45.3l-64-64c-9.2-9.2-22.9-11.9-34.9-6.9s-19.8 16.6-19.8 29.6l0 32-96 0 0-96 32 0c12.9 0 24.6-7.8 29.6-19.8s2.2-25.7-6.9-34.9l-64-64z\"]\n};\nconst faArrowsAlt = faUpDownLeftRight;\nconst faHouseChimneyUser = {\n prefix: 'fas',\n iconName: 'house-chimney-user',\n icon: [576, 512, [], \"e065\", \"M543.8 287.6c17 0 32-14 32-32.1c1-9-3-17-11-24L512 185l0-121c0-17.7-14.3-32-32-32l-32 0c-17.7 0-32 14.3-32 32l0 36.7L309.5 7c-6-5-14-7-21-7s-15 1-22 8L10 231.5c-7 7-10 15-10 24c0 18 14 32.1 32 32.1l32 0 0 160.4c0 35.3 28.7 64 64 64l320.4 0c35.5 0 64.2-28.8 64-64.3l-.7-160.2 32 0zM288 160a64 64 0 1 1 0 128 64 64 0 1 1 0-128zM176 400c0-44.2 35.8-80 80-80l64 0c44.2 0 80 35.8 80 80c0 8.8-7.2 16-16 16l-192 0c-8.8 0-16-7.2-16-16z\"]\n};\nconst faHandHoldingHeart = {\n prefix: 'fas',\n iconName: 'hand-holding-heart',\n icon: [576, 512, [], \"f4be\", \"M163.9 136.9c-29.4-29.8-29.4-78.2 0-108s77-29.8 106.4 0l17.7 18 17.7-18c29.4-29.8 77-29.8 106.4 0s29.4 78.2 0 108L310.5 240.1c-6.2 6.3-14.3 9.4-22.5 9.4s-16.3-3.1-22.5-9.4L163.9 136.9zM568.2 336.3c13.1 17.8 9.3 42.8-8.5 55.9L433.1 485.5c-23.4 17.2-51.6 26.5-80.7 26.5L192 512 32 512c-17.7 0-32-14.3-32-32l0-64c0-17.7 14.3-32 32-32l36.8 0 44.9-36c22.7-18.2 50.9-28 80-28l78.3 0 16 0 64 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-64 0-16 0c-8.8 0-16 7.2-16 16s7.2 16 16 16l120.6 0 119.7-88.2c17.8-13.1 42.8-9.3 55.9 8.5zM193.6 384c0 0 0 0 0 0l-.9 0c.3 0 .6 0 .9 0z\"]\n};\nconst faPuzzlePiece = {\n prefix: 'fas',\n iconName: 'puzzle-piece',\n icon: [512, 512, [129513], \"f12e\", \"M192 104.8c0-9.2-5.8-17.3-13.2-22.8C167.2 73.3 160 61.3 160 48c0-26.5 28.7-48 64-48s64 21.5 64 48c0 13.3-7.2 25.3-18.8 34c-7.4 5.5-13.2 13.6-13.2 22.8c0 12.8 10.4 23.2 23.2 23.2l56.8 0c26.5 0 48 21.5 48 48l0 56.8c0 12.8 10.4 23.2 23.2 23.2c9.2 0 17.3-5.8 22.8-13.2c8.7-11.6 20.7-18.8 34-18.8c26.5 0 48 28.7 48 64s-21.5 64-48 64c-13.3 0-25.3-7.2-34-18.8c-5.5-7.4-13.6-13.2-22.8-13.2c-12.8 0-23.2 10.4-23.2 23.2L384 464c0 26.5-21.5 48-48 48l-56.8 0c-12.8 0-23.2-10.4-23.2-23.2c0-9.2 5.8-17.3 13.2-22.8c11.6-8.7 18.8-20.7 18.8-34c0-26.5-28.7-48-64-48s-64 21.5-64 48c0 13.3 7.2 25.3 18.8 34c7.4 5.5 13.2 13.6 13.2 22.8c0 12.8-10.4 23.2-23.2 23.2L48 512c-26.5 0-48-21.5-48-48L0 343.2C0 330.4 10.4 320 23.2 320c9.2 0 17.3 5.8 22.8 13.2C54.7 344.8 66.7 352 80 352c26.5 0 48-28.7 48-64s-21.5-64-48-64c-13.3 0-25.3 7.2-34 18.8C40.5 250.2 32.4 256 23.2 256C10.4 256 0 245.6 0 232.8L0 176c0-26.5 21.5-48 48-48l120.8 0c12.8 0 23.2-10.4 23.2-23.2z\"]\n};\nconst faMoneyCheck = {\n prefix: 'fas',\n iconName: 'money-check',\n icon: [576, 512, [], \"f53c\", \"M64 64C28.7 64 0 92.7 0 128L0 384c0 35.3 28.7 64 64 64l448 0c35.3 0 64-28.7 64-64l0-256c0-35.3-28.7-64-64-64L64 64zm48 160l160 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-160 0c-8.8 0-16-7.2-16-16s7.2-16 16-16zM96 336c0-8.8 7.2-16 16-16l352 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-352 0c-8.8 0-16-7.2-16-16zM376 160l80 0c13.3 0 24 10.7 24 24l0 48c0 13.3-10.7 24-24 24l-80 0c-13.3 0-24-10.7-24-24l0-48c0-13.3 10.7-24 24-24z\"]\n};\nconst faStarHalfStroke = {\n prefix: 'fas',\n iconName: 'star-half-stroke',\n icon: [576, 512, [\"star-half-alt\"], \"f5c0\", \"M288 376.4l.1-.1 26.4 14.1 85.2 45.5-16.5-97.6-4.8-28.7 20.7-20.5 70.1-69.3-96.1-14.2-29.3-4.3-12.9-26.6L288.1 86.9l-.1 .3 0 289.2zm175.1 98.3c2 12-3 24.2-12.9 31.3s-23 8-33.8 2.3L288.1 439.8 159.8 508.3C149 514 135.9 513.1 126 506s-14.9-19.3-12.9-31.3L137.8 329 33.6 225.9c-8.6-8.5-11.7-21.2-7.9-32.7s13.7-19.9 25.7-21.7L195 150.3 259.4 18c5.4-11 16.5-18 28.8-18s23.4 7 28.8 18l64.3 132.3 143.6 21.2c12 1.8 22 10.2 25.7 21.7s.7 24.2-7.9 32.7L438.5 329l24.6 145.7z\"]\n};\nconst faStarHalfAlt = faStarHalfStroke;\nconst faCode = {\n prefix: 'fas',\n iconName: 'code',\n icon: [640, 512, [], \"f121\", \"M392.8 1.2c-17-4.9-34.7 5-39.6 22l-128 448c-4.9 17 5 34.7 22 39.6s34.7-5 39.6-22l128-448c4.9-17-5-34.7-22-39.6zm80.6 120.1c-12.5 12.5-12.5 32.8 0 45.3L562.7 256l-89.4 89.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0l112-112c12.5-12.5 12.5-32.8 0-45.3l-112-112c-12.5-12.5-32.8-12.5-45.3 0zm-306.7 0c-12.5-12.5-32.8-12.5-45.3 0l-112 112c-12.5 12.5-12.5 32.8 0 45.3l112 112c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3L77.3 256l89.4-89.4c12.5-12.5 12.5-32.8 0-45.3z\"]\n};\nconst faWhiskeyGlass = {\n prefix: 'fas',\n iconName: 'whiskey-glass',\n icon: [512, 512, [129347, \"glass-whiskey\"], \"f7a0\", \"M32 32c-9.3 0-18.1 4-24.2 11.1S-1 59.4 .3 68.6l50 342.9c5.7 39.3 39.4 68.5 79.2 68.5l253 0c39.7 0 73.4-29.1 79.2-68.5l50-342.9c1.3-9.2-1.4-18.5-7.5-25.5S489.3 32 480 32L32 32zM87.7 224L69 96l374 0L424.3 224 87.7 224z\"]\n};\nconst faGlassWhiskey = faWhiskeyGlass;\nconst faBuildingCircleExclamation = {\n prefix: 'fas',\n iconName: 'building-circle-exclamation',\n icon: [640, 512, [], \"e4d3\", \"M48 0C21.5 0 0 21.5 0 48L0 464c0 26.5 21.5 48 48 48l96 0 0-80c0-26.5 21.5-48 48-48s48 21.5 48 48l0 80 96 0c15.1 0 28.5-6.9 37.3-17.8C340.4 462.2 320 417.5 320 368c0-54.7 24.9-103.5 64-135.8L384 48c0-26.5-21.5-48-48-48L48 0zM64 240c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32zm112-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16zm80 16c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32zM80 96l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16zm80 16c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32zM272 96l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16zM496 512a144 144 0 1 0 0-288 144 144 0 1 0 0 288zm0-96a24 24 0 1 1 0 48 24 24 0 1 1 0-48zm0-144c8.8 0 16 7.2 16 16l0 80c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-80c0-8.8 7.2-16 16-16z\"]\n};\nconst faMagnifyingGlassChart = {\n prefix: 'fas',\n iconName: 'magnifying-glass-chart',\n icon: [512, 512, [], \"e522\", \"M416 208c0 45.9-14.9 88.3-40 122.7L502.6 457.4c12.5 12.5 12.5 32.8 0 45.3s-32.8 12.5-45.3 0L330.7 376c-34.4 25.2-76.8 40-122.7 40C93.1 416 0 322.9 0 208S93.1 0 208 0S416 93.1 416 208zm-312 8l0 64c0 13.3 10.7 24 24 24s24-10.7 24-24l0-64c0-13.3-10.7-24-24-24s-24 10.7-24 24zm80-96l0 160c0 13.3 10.7 24 24 24s24-10.7 24-24l0-160c0-13.3-10.7-24-24-24s-24 10.7-24 24zm80 64l0 96c0 13.3 10.7 24 24 24s24-10.7 24-24l0-96c0-13.3-10.7-24-24-24s-24 10.7-24 24z\"]\n};\nconst faArrowUpRightFromSquare = {\n prefix: 'fas',\n iconName: 'arrow-up-right-from-square',\n icon: [512, 512, [\"external-link\"], \"f08e\", \"M320 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l82.7 0L201.4 265.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0L448 109.3l0 82.7c0 17.7 14.3 32 32 32s32-14.3 32-32l0-160c0-17.7-14.3-32-32-32L320 0zM80 32C35.8 32 0 67.8 0 112L0 432c0 44.2 35.8 80 80 80l320 0c44.2 0 80-35.8 80-80l0-112c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 112c0 8.8-7.2 16-16 16L80 448c-8.8 0-16-7.2-16-16l0-320c0-8.8 7.2-16 16-16l112 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L80 32z\"]\n};\nconst faExternalLink = faArrowUpRightFromSquare;\nconst faCubesStacked = {\n prefix: 'fas',\n iconName: 'cubes-stacked',\n icon: [448, 512, [], \"e4e6\", \"M192 64l0 64c0 17.7 14.3 32 32 32l64 0c17.7 0 32-14.3 32-32l0-64c0-17.7-14.3-32-32-32l-64 0c-17.7 0-32 14.3-32 32zM82.7 207c-15.3 8.8-20.5 28.4-11.7 43.7l32 55.4c8.8 15.3 28.4 20.5 43.7 11.7l55.4-32c15.3-8.8 20.5-28.4 11.7-43.7l-32-55.4c-8.8-15.3-28.4-20.5-43.7-11.7L82.7 207zM288 192c-17.7 0-32 14.3-32 32l0 64c0 17.7 14.3 32 32 32l64 0c17.7 0 32-14.3 32-32l0-64c0-17.7-14.3-32-32-32l-64 0zm64 160c-17.7 0-32 14.3-32 32l0 64c0 17.7 14.3 32 32 32l64 0c17.7 0 32-14.3 32-32l0-64c0-17.7-14.3-32-32-32l-64 0zM160 384l0 64c0 17.7 14.3 32 32 32l64 0c17.7 0 32-14.3 32-32l0-64c0-17.7-14.3-32-32-32l-64 0c-17.7 0-32 14.3-32 32zM32 352c-17.7 0-32 14.3-32 32l0 64c0 17.7 14.3 32 32 32l64 0c17.7 0 32-14.3 32-32l0-64c0-17.7-14.3-32-32-32l-64 0z\"]\n};\nconst faWonSign = {\n prefix: 'fas',\n iconName: 'won-sign',\n icon: [512, 512, [8361, \"krw\", \"won\"], \"f159\", \"M62.4 53.9C56.8 37.1 38.6 28.1 21.9 33.6S-3.9 57.4 1.6 74.1L51.6 224 32 224c-17.7 0-32 14.3-32 32s14.3 32 32 32l40.9 0 56.7 170.1c4.5 13.5 17.4 22.4 31.6 21.9s26.4-10.4 29.8-24.2L233 288l46 0L321 455.8c3.4 13.8 15.6 23.7 29.8 24.2s27.1-8.4 31.6-21.9L439.1 288l40.9 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-19.6 0 50-149.9c5.6-16.8-3.5-34.9-20.2-40.5s-34.9 3.5-40.5 20.2L392.9 224l-64 0L287 56.2C283.5 42 270.7 32 256 32s-27.5 10-31 24.2L183 224l-64 0L62.4 53.9zm78 234.1l26.6 0-11.4 45.6L140.4 288zM249 224l7-28.1 7 28.1-14 0zm96 64l26.6 0-15.2 45.6L345 288z\"]\n};\nconst faKrw = faWonSign;\nconst faWon = faWonSign;\nconst faVirusCovid = {\n prefix: 'fas',\n iconName: 'virus-covid',\n icon: [512, 512, [], \"e4a8\", \"M192 24c0-13.3 10.7-24 24-24l80 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-16 0 0 33.6c30.7 4.2 58.8 16.3 82.3 34.1L386.1 92 374.8 80.6c-9.4-9.4-9.4-24.6 0-33.9s24.6-9.4 33.9 0l56.6 56.6c9.4 9.4 9.4 24.6 0 33.9s-24.6 9.4-33.9 0L420 125.9l-23.8 23.8c17.9 23.5 29.9 51.7 34.1 82.3l33.6 0 0-16c0-13.3 10.7-24 24-24s24 10.7 24 24l0 80c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-16-33.6 0c-4.2 30.7-16.3 58.8-34.1 82.3L420 386.1l11.3-11.3c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9l-56.6 56.6c-9.4 9.4-24.6 9.4-33.9 0s-9.4-24.6 0-33.9L386.1 420l-23.8-23.8c-23.5 17.9-51.7 29.9-82.3 34.1l0 33.6 16 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-80 0c-13.3 0-24-10.7-24-24s10.7-24 24-24l16 0 0-33.6c-30.7-4.2-58.8-16.3-82.3-34.1L125.9 420l11.3 11.3c9.4 9.4 9.4 24.6 0 33.9s-24.6 9.4-33.9 0L46.7 408.7c-9.4-9.4-9.4-24.6 0-33.9s24.6-9.4 33.9 0L92 386.1l23.8-23.8C97.9 338.8 85.8 310.7 81.6 280L48 280l0 16c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-80c0-13.3 10.7-24 24-24s24 10.7 24 24l0 16 33.6 0c4.2-30.7 16.3-58.8 34.1-82.3L92 125.9 80.6 137.2c-9.4 9.4-24.6 9.4-33.9 0s-9.4-24.6 0-33.9l56.6-56.6c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L125.9 92l23.8 23.8c23.5-17.9 51.7-29.9 82.3-34.1L232 48l-16 0c-13.3 0-24-10.7-24-24zm48 200a48 48 0 1 0 -96 0 48 48 0 1 0 96 0zm64 104a24 24 0 1 0 0-48 24 24 0 1 0 0 48z\"]\n};\nconst faAustralSign = {\n prefix: 'fas',\n iconName: 'austral-sign',\n icon: [448, 512, [], \"e0a9\", \"M253.5 51.7C248.6 39.8 236.9 32 224 32s-24.6 7.8-29.5 19.7L122.7 224 32 224c-17.7 0-32 14.3-32 32s14.3 32 32 32l64 0L82.7 320 32 320c-17.7 0-32 14.3-32 32s14.3 32 32 32l24 0L34.5 435.7c-6.8 16.3 .9 35 17.2 41.8s35-.9 41.8-17.2L125.3 384l197.3 0 31.8 76.3c6.8 16.3 25.5 24 41.8 17.2s24-25.5 17.2-41.8L392 384l24 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-50.7 0L352 288l64 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-90.7 0L253.5 51.7zM256 224l-64 0 32-76.8L256 224zm-90.7 64l117.3 0L296 320l-144 0 13.3-32z\"]\n};\nconst faF = {\n prefix: 'fas',\n iconName: 'f',\n icon: [320, 512, [102], \"46\", \"M64 32C28.7 32 0 60.7 0 96L0 256 0 448c0 17.7 14.3 32 32 32s32-14.3 32-32l0-160 160 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L64 224 64 96l224 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L64 32z\"]\n};\nconst faLeaf = {\n prefix: 'fas',\n iconName: 'leaf',\n icon: [512, 512, [], \"f06c\", \"M272 96c-78.6 0-145.1 51.5-167.7 122.5c33.6-17 71.5-26.5 111.7-26.5l88 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-16 0-72 0s0 0 0 0c-16.6 0-32.7 1.9-48.3 5.4c-25.9 5.9-49.9 16.4-71.4 30.7c0 0 0 0 0 0C38.3 298.8 0 364.9 0 440l0 16c0 13.3 10.7 24 24 24s24-10.7 24-24l0-16c0-48.7 20.7-92.5 53.8-123.2C121.6 392.3 190.3 448 272 448l1 0c132.1-.7 239-130.9 239-291.4c0-42.6-7.5-83.1-21.1-119.6c-2.6-6.9-12.7-6.6-16.2-.1C455.9 72.1 418.7 96 376 96L272 96z\"]\n};\nconst faRoad = {\n prefix: 'fas',\n iconName: 'road',\n icon: [576, 512, [128739], \"f018\", \"M256 32l-74.8 0c-27.1 0-51.3 17.1-60.3 42.6L3.1 407.2C1.1 413 0 419.2 0 425.4C0 455.5 24.5 480 54.6 480L256 480l0-64c0-17.7 14.3-32 32-32s32 14.3 32 32l0 64 201.4 0c30.2 0 54.6-24.5 54.6-54.6c0-6.2-1.1-12.4-3.1-18.2L455.1 74.6C446 49.1 421.9 32 394.8 32L320 32l0 64c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-64zm64 192l0 64c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-64c0-17.7 14.3-32 32-32s32 14.3 32 32z\"]\n};\nconst faTaxi = {\n prefix: 'fas',\n iconName: 'taxi',\n icon: [512, 512, [128662, \"cab\"], \"f1ba\", \"M192 0c-17.7 0-32 14.3-32 32l0 32 0 .2c-38.6 2.2-72.3 27.3-85.2 64.1L39.6 228.8C16.4 238.4 0 261.3 0 288L0 432l0 48c0 17.7 14.3 32 32 32l32 0c17.7 0 32-14.3 32-32l0-48 320 0 0 48c0 17.7 14.3 32 32 32l32 0c17.7 0 32-14.3 32-32l0-48 0-144c0-26.7-16.4-49.6-39.6-59.2L437.2 128.3c-12.9-36.8-46.6-62-85.2-64.1l0-.2 0-32c0-17.7-14.3-32-32-32L192 0zM165.4 128l181.2 0c13.6 0 25.7 8.6 30.2 21.4L402.9 224l-293.8 0 26.1-74.6c4.5-12.8 16.6-21.4 30.2-21.4zM96 288a32 32 0 1 1 0 64 32 32 0 1 1 0-64zm288 32a32 32 0 1 1 64 0 32 32 0 1 1 -64 0z\"]\n};\nconst faCab = faTaxi;\nconst faPersonCirclePlus = {\n prefix: 'fas',\n iconName: 'person-circle-plus',\n icon: [576, 512, [], \"e541\", \"M112 48a48 48 0 1 1 96 0 48 48 0 1 1 -96 0zm40 304l0 128c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-223.1L59.4 304.5c-9.1 15.1-28.8 20-43.9 10.9s-20-28.8-10.9-43.9l58.3-97c17.4-28.9 48.6-46.6 82.3-46.6l29.7 0c33.7 0 64.9 17.7 82.3 46.6l44.9 74.7c-16.1 17.6-28.6 38.5-36.6 61.5c-1.9-1.8-3.5-3.9-4.9-6.3L232 256.9 232 480c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-128-16 0zM432 224a144 144 0 1 1 0 288 144 144 0 1 1 0-288zm16 80c0-8.8-7.2-16-16-16s-16 7.2-16 16l0 48-48 0c-8.8 0-16 7.2-16 16s7.2 16 16 16l48 0 0 48c0 8.8 7.2 16 16 16s16-7.2 16-16l0-48 48 0c8.8 0 16-7.2 16-16s-7.2-16-16-16l-48 0 0-48z\"]\n};\nconst faChartPie = {\n prefix: 'fas',\n iconName: 'chart-pie',\n icon: [576, 512, [\"pie-chart\"], \"f200\", \"M304 240l0-223.4c0-9 7-16.6 16-16.6C443.7 0 544 100.3 544 224c0 9-7.6 16-16.6 16L304 240zM32 272C32 150.7 122.1 50.3 239 34.3c9.2-1.3 17 6.1 17 15.4L256 288 412.5 444.5c6.7 6.7 6.2 17.7-1.5 23.1C371.8 495.6 323.8 512 272 512C139.5 512 32 404.6 32 272zm526.4 16c9.3 0 16.6 7.8 15.4 17c-7.7 55.9-34.6 105.6-73.9 142.3c-6 5.6-15.4 5.2-21.2-.7L320 288l238.4 0z\"]\n};\nconst faPieChart = faChartPie;\nconst faBoltLightning = {\n prefix: 'fas',\n iconName: 'bolt-lightning',\n icon: [384, 512, [], \"e0b7\", \"M0 256L28.5 28c2-16 15.6-28 31.8-28H228.9c15 0 27.1 12.1 27.1 27.1c0 3.2-.6 6.5-1.7 9.5L208 160H347.3c20.2 0 36.7 16.4 36.7 36.7c0 7.4-2.2 14.6-6.4 20.7l-192.2 281c-5.9 8.6-15.6 13.7-25.9 13.7h-2.9c-15.7 0-28.5-12.8-28.5-28.5c0-2.3 .3-4.6 .9-6.9L176 288H32c-17.7 0-32-14.3-32-32z\"]\n};\nconst faSackXmark = {\n prefix: 'fas',\n iconName: 'sack-xmark',\n icon: [512, 512, [], \"e56a\", \"M192 96l128 0 47.4-71.1C374.5 14.2 366.9 0 354.1 0L157.9 0c-12.8 0-20.4 14.2-13.3 24.9L192 96zm128 32l-128 0c-3.8 2.5-8.1 5.3-13 8.4c0 0 0 0 0 0s0 0 0 0C122.3 172.7 0 250.9 0 416c0 53 43 96 96 96l320 0c53 0 96-43 96-96c0-165.1-122.3-243.3-179-279.6c-4.8-3.1-9.2-5.9-13-8.4zM289.9 336l47 47c9.4 9.4 9.4 24.6 0 33.9s-24.6 9.4-33.9 0l-47-47-47 47c-9.4 9.4-24.6 9.4-33.9 0s-9.4-24.6 0-33.9l47-47-47-47c-9.4-9.4-9.4-24.6 0-33.9s24.6-9.4 33.9 0l47 47 47-47c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9l-47 47z\"]\n};\nconst faFileExcel = {\n prefix: 'fas',\n iconName: 'file-excel',\n icon: [384, 512, [], \"f1c3\", \"M64 0C28.7 0 0 28.7 0 64L0 448c0 35.3 28.7 64 64 64l256 0c35.3 0 64-28.7 64-64l0-288-128 0c-17.7 0-32-14.3-32-32L224 0 64 0zM256 0l0 128 128 0L256 0zM155.7 250.2L192 302.1l36.3-51.9c7.6-10.9 22.6-13.5 33.4-5.9s13.5 22.6 5.9 33.4L221.3 344l46.4 66.2c7.6 10.9 5 25.8-5.9 33.4s-25.8 5-33.4-5.9L192 385.8l-36.3 51.9c-7.6 10.9-22.6 13.5-33.4 5.9s-13.5-22.6-5.9-33.4L162.7 344l-46.4-66.2c-7.6-10.9-5-25.8 5.9-33.4s25.8-5 33.4 5.9z\"]\n};\nconst faFileContract = {\n prefix: 'fas',\n iconName: 'file-contract',\n icon: [384, 512, [], \"f56c\", \"M64 0C28.7 0 0 28.7 0 64L0 448c0 35.3 28.7 64 64 64l256 0c35.3 0 64-28.7 64-64l0-288-128 0c-17.7 0-32-14.3-32-32L224 0 64 0zM256 0l0 128 128 0L256 0zM80 64l64 0c8.8 0 16 7.2 16 16s-7.2 16-16 16L80 96c-8.8 0-16-7.2-16-16s7.2-16 16-16zm0 64l64 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-64 0c-8.8 0-16-7.2-16-16s7.2-16 16-16zm54.2 253.8c-6.1 20.3-24.8 34.2-46 34.2L80 416c-8.8 0-16-7.2-16-16s7.2-16 16-16l8.2 0c7.1 0 13.3-4.6 15.3-11.4l14.9-49.5c3.4-11.3 13.8-19.1 25.6-19.1s22.2 7.7 25.6 19.1l11.6 38.6c7.4-6.2 16.8-9.7 26.8-9.7c15.9 0 30.4 9 37.5 23.2l4.4 8.8 54.1 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-64 0c-6.1 0-11.6-3.4-14.3-8.8l-8.8-17.7c-1.7-3.4-5.1-5.5-8.8-5.5s-7.2 2.1-8.8 5.5l-8.8 17.7c-2.9 5.9-9.2 9.4-15.7 8.8s-12.1-5.1-13.9-11.3L144 349l-9.8 32.8z\"]\n};\nconst faFishFins = {\n prefix: 'fas',\n iconName: 'fish-fins',\n icon: [576, 512, [], \"e4f2\", \"M275.2 38.4c-10.6-8-25-8.5-36.3-1.5S222 57.3 224.6 70.3l9.7 48.6c-19.4 9-36.9 19.9-52.4 31.5c-15.3 11.5-29 23.9-40.7 36.3L48.1 132.4c-12.5-7.3-28.4-5.3-38.6 4.9S-3 163.3 4.2 175.9L50 256 4.2 336.1c-7.2 12.6-5 28.4 5.3 38.6s26.1 12.2 38.6 4.9l93.1-54.3c11.8 12.3 25.4 24.8 40.7 36.3c15.5 11.6 33 22.5 52.4 31.5l-9.7 48.6c-2.6 13 3.1 26.3 14.3 33.3s25.6 6.5 36.3-1.5l77.6-58.2c54.9-4 101.5-27 137.2-53.8c39.2-29.4 67.2-64.7 81.6-89.5c5.8-9.9 5.8-22.2 0-32.1c-14.4-24.8-42.5-60.1-81.6-89.5c-35.8-26.8-82.3-49.8-137.2-53.8L275.2 38.4zM384 256a32 32 0 1 1 64 0 32 32 0 1 1 -64 0z\"]\n};\nconst faBuildingFlag = {\n prefix: 'fas',\n iconName: 'building-flag',\n icon: [640, 512, [], \"e4d5\", \"M48 0C21.5 0 0 21.5 0 48L0 464c0 26.5 21.5 48 48 48l96 0 0-80c0-26.5 21.5-48 48-48s48 21.5 48 48l0 80 96 0c26.5 0 48-21.5 48-48l0-416c0-26.5-21.5-48-48-48L48 0zM64 240c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32zm112-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16zm80 16c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32zM80 96l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16zm80 16c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32zM272 96l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16zM448 0c-17.7 0-32 14.3-32 32l0 480 64 0 0-320 144 0c8.8 0 16-7.2 16-16l0-128c0-8.8-7.2-16-16-16L480 32c0-17.7-14.3-32-32-32z\"]\n};\nconst faFaceGrinBeam = {\n prefix: 'fas',\n iconName: 'face-grin-beam',\n icon: [512, 512, [128516, \"grin-beam\"], \"f582\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM388.1 312.8c12.3-3.8 24.3 6.9 19.3 18.7C382.4 390.6 324.2 432 256.3 432s-126.2-41.4-151.1-100.5c-5-11.8 7-22.5 19.3-18.7c39.7 12.2 84.5 19 131.8 19s92.1-6.8 131.8-19zm-170.5-84s0 0 0 0c0 0 0 0 0 0l-.2-.2c-.2-.2-.4-.5-.7-.9c-.6-.8-1.6-2-2.8-3.4c-2.5-2.8-6-6.6-10.2-10.3c-8.8-7.8-18.8-14-27.7-14s-18.9 6.2-27.7 14c-4.2 3.7-7.7 7.5-10.2 10.3c-1.2 1.4-2.2 2.6-2.8 3.4c-.3 .4-.6 .7-.7 .9l-.2 .2c0 0 0 0 0 0c0 0 0 0 0 0s0 0 0 0c-2.1 2.8-5.7 3.9-8.9 2.8s-5.5-4.1-5.5-7.6c0-17.9 6.7-35.6 16.6-48.8c9.8-13 23.9-23.2 39.4-23.2s29.6 10.2 39.4 23.2c9.9 13.2 16.6 30.9 16.6 48.8c0 3.4-2.2 6.5-5.5 7.6s-6.9 0-8.9-2.8c0 0 0 0 0 0s0 0 0 0zm160 0c0 0 0 0 0 0l-.2-.2c-.2-.2-.4-.5-.7-.9c-.6-.8-1.6-2-2.8-3.4c-2.5-2.8-6-6.6-10.2-10.3c-8.8-7.8-18.8-14-27.7-14s-18.9 6.2-27.7 14c-4.2 3.7-7.7 7.5-10.2 10.3c-1.2 1.4-2.2 2.6-2.8 3.4c-.3 .4-.6 .7-.7 .9l-.2 .2c0 0 0 0 0 0c0 0 0 0 0 0s0 0 0 0c-2.1 2.8-5.7 3.9-8.9 2.8s-5.5-4.1-5.5-7.6c0-17.9 6.7-35.6 16.6-48.8c9.8-13 23.9-23.2 39.4-23.2s29.6 10.2 39.4 23.2c9.9 13.2 16.6 30.9 16.6 48.8c0 3.4-2.2 6.5-5.5 7.6s-6.9 0-8.9-2.8c0 0 0 0 0 0s0 0 0 0s0 0 0 0z\"]\n};\nconst faGrinBeam = faFaceGrinBeam;\nconst faObjectUngroup = {\n prefix: 'fas',\n iconName: 'object-ungroup',\n icon: [640, 512, [], \"f248\", \"M32 119.4C12.9 108.4 0 87.7 0 64C0 28.7 28.7 0 64 0c23.7 0 44.4 12.9 55.4 32l209.1 0C339.6 12.9 360.3 0 384 0c35.3 0 64 28.7 64 64c0 23.7-12.9 44.4-32 55.4l0 113.1c19.1 11.1 32 31.7 32 55.4c0 35.3-28.7 64-64 64c-23.7 0-44.4-12.9-55.4-32l-209.1 0c-11.1 19.1-31.7 32-55.4 32c-35.3 0-64-28.7-64-64c0-23.7 12.9-44.4 32-55.4l0-113.1zM119.4 96c-5.6 9.7-13.7 17.8-23.4 23.4l0 113.1c9.7 5.6 17.8 13.7 23.4 23.4l209.1 0c5.6-9.7 13.7-17.8 23.4-23.4l0-113.1c-9.7-5.6-17.8-13.7-23.4-23.4L119.4 96zm192 384c-11.1 19.1-31.7 32-55.4 32c-35.3 0-64-28.7-64-64c0-23.7 12.9-44.4 32-55.4l0-40.6 64 0 0 40.6c9.7 5.6 17.8 13.7 23.4 23.4l209.1 0c5.6-9.7 13.7-17.8 23.4-23.4l0-113.1c-9.7-5.6-17.8-13.7-23.4-23.4l-46 0c-5.4-15.4-14.6-28.9-26.5-39.6l0-24.4 72.6 0c11.1-19.1 31.7-32 55.4-32c35.3 0 64 28.7 64 64c0 23.7-12.9 44.4-32 55.4l0 113.1c19.1 11.1 32 31.7 32 55.4c0 35.3-28.7 64-64 64c-23.7 0-44.4-12.9-55.4-32l-209.1 0z\"]\n};\nconst faPoop = {\n prefix: 'fas',\n iconName: 'poop',\n icon: [512, 512, [], \"f619\", \"M254.4 6.6c3.5-4.3 9-6.5 14.5-5.7C315.8 7.2 352 47.4 352 96c0 11.2-1.9 22-5.5 32l5.5 0c35.3 0 64 28.7 64 64c0 19.1-8.4 36.3-21.7 48l13.7 0c39.8 0 72 32.2 72 72c0 23.2-11 43.8-28 57c34.1 5.7 60 35.3 60 71c0 39.8-32.2 72-72 72L72 512c-39.8 0-72-32.2-72-72c0-35.7 25.9-65.3 60-71c-17-13.2-28-33.8-28-57c0-39.8 32.2-72 72-72l13.7 0C104.4 228.3 96 211.1 96 192c0-35.3 28.7-64 64-64l16.2 0c44.1-.1 79.8-35.9 79.8-80c0-9.2-1.5-17.9-4.3-26.1c-1.8-5.2-.8-11.1 2.8-15.4z\"]\n};\nconst faLocationPin = {\n prefix: 'fas',\n iconName: 'location-pin',\n icon: [384, 512, [\"map-marker\"], \"f041\", \"M384 192c0 87.4-117 243-168.3 307.2c-12.3 15.3-35.1 15.3-47.4 0C117 435 0 279.4 0 192C0 86 86 0 192 0S384 86 384 192z\"]\n};\nconst faMapMarker = faLocationPin;\nconst faKaaba = {\n prefix: 'fas',\n iconName: 'kaaba',\n icon: [576, 512, [128331], \"f66b\", \"M60 120l228 71.2L516 120 288 48.8 60 120zM278.5 1.5c6.2-1.9 12.9-1.9 19.1 0l256 80C566.9 85.6 576 98 576 112l0 16s0 0 0 0l0 21.2L292.8 237.7c-3.1 1-6.4 1-9.5 0L0 149.2 0 128l0-16C0 98 9.1 85.6 22.5 81.5l256-80zm23.9 266.8L576 182.8l0 46.5-52.8 16.5c-8.4 2.6-13.1 11.6-10.5 20s11.6 13.1 20 10.5L576 262.8 576 400c0 14-9.1 26.4-22.5 30.5l-256 80c-6.2 1.9-12.9 1.9-19.1 0l-256-80C9.1 426.4 0 414 0 400L0 262.8l43.2 13.5c8.4 2.6 17.4-2.1 20-10.5s-2.1-17.4-10.5-20L0 229.2l0-46.5 273.7 85.5c9.3 2.9 19.3 2.9 28.6 0zm-185.5-2.6c-8.4-2.6-17.4 2.1-20 10.5s2.1 17.4 10.5 20l64 20c8.4 2.6 17.4-2.1 20-10.5s-2.1-17.4-10.5-20l-64-20zm352 30.5c8.4-2.6 13.1-11.6 10.5-20s-11.6-13.1-20-10.5l-64 20c-8.4 2.6-13.1 11.6-10.5 20s11.6 13.1 20 10.5l64-20zm-224 9.5c-8.4-2.6-17.4 2.1-20 10.5s2.1 17.4 10.5 20l38.5 12c9.3 2.9 19.3 2.9 28.6 0l38.5-12c8.4-2.6 13.1-11.6 10.5-20s-11.6-13.1-20-10.5l-38.5 12c-3.1 1-6.4 1-9.5 0l-38.5-12z\"]\n};\nconst faToiletPaper = {\n prefix: 'fas',\n iconName: 'toilet-paper',\n icon: [640, 512, [129531], \"f71e\", \"M444.2 0C397.2 49.6 384 126.5 384 192c0 158.8-27.3 247-42.7 283.9c-10 24-33.2 36.1-55.4 36.1L48 512c-11.5 0-22.2-6.2-27.8-16.2s-5.6-22.3 .4-32.2c9.8-17.7 15.4-38.2 20.5-57.7C52.3 362.8 64 293.5 64 192C64 86 107 0 160 0L444.2 0zM512 384c-53 0-96-86-96-192S459 0 512 0s96 86 96 192s-43 192-96 192zm0-128c17.7 0 32-28.7 32-64s-14.3-64-32-64s-32 28.7-32 64s14.3 64 32 64zM144 208a16 16 0 1 0 -32 0 16 16 0 1 0 32 0zm64 0a16 16 0 1 0 -32 0 16 16 0 1 0 32 0zm48 16a16 16 0 1 0 0-32 16 16 0 1 0 0 32zm80-16a16 16 0 1 0 -32 0 16 16 0 1 0 32 0z\"]\n};\nconst faHelmetSafety = {\n prefix: 'fas',\n iconName: 'helmet-safety',\n icon: [576, 512, [\"hard-hat\", \"hat-hard\"], \"f807\", \"M256 32c-17.7 0-32 14.3-32 32l0 2.3 0 99.6c0 5.6-4.5 10.1-10.1 10.1c-3.6 0-7-1.9-8.8-5.1L157.1 87C83 123.5 32 199.8 32 288l0 64 512 0 0-66.4c-.9-87.2-51.7-162.4-125.1-198.6l-48 83.9c-1.8 3.2-5.2 5.1-8.8 5.1c-5.6 0-10.1-4.5-10.1-10.1l0-99.6 0-2.3c0-17.7-14.3-32-32-32l-64 0zM16.6 384C7.4 384 0 391.4 0 400.6c0 4.7 2 9.2 5.8 11.9C27.5 428.4 111.8 480 288 480s260.5-51.6 282.2-67.5c3.8-2.8 5.8-7.2 5.8-11.9c0-9.2-7.4-16.6-16.6-16.6L16.6 384z\"]\n};\nconst faHardHat = faHelmetSafety;\nconst faHatHard = faHelmetSafety;\nconst faEject = {\n prefix: 'fas',\n iconName: 'eject',\n icon: [448, 512, [9167], \"f052\", \"M224 32c13.5 0 26.3 5.6 35.4 15.6l176 192c12.9 14 16.2 34.3 8.6 51.8S419 320 400 320L48 320c-19 0-36.3-11.2-43.9-28.7s-4.3-37.7 8.6-51.8l176-192C197.7 37.6 210.5 32 224 32zM0 432c0-26.5 21.5-48 48-48l352 0c26.5 0 48 21.5 48 48s-21.5 48-48 48L48 480c-26.5 0-48-21.5-48-48z\"]\n};\nconst faCircleRight = {\n prefix: 'fas',\n iconName: 'circle-right',\n icon: [512, 512, [61838, \"arrow-alt-circle-right\"], \"f35a\", \"M0 256a256 256 0 1 0 512 0A256 256 0 1 0 0 256zm395.3 11.3l-112 112c-4.6 4.6-11.5 5.9-17.4 3.5s-9.9-8.3-9.9-14.8l0-64-96 0c-17.7 0-32-14.3-32-32l0-32c0-17.7 14.3-32 32-32l96 0 0-64c0-6.5 3.9-12.3 9.9-14.8s12.9-1.1 17.4 3.5l112 112c6.2 6.2 6.2 16.4 0 22.6z\"]\n};\nconst faArrowAltCircleRight = faCircleRight;\nconst faPlaneCircleCheck = {\n prefix: 'fas',\n iconName: 'plane-circle-check',\n icon: [640, 512, [], \"e555\", \"M256 0c-35 0-64 59.5-64 93.7l0 84.6L8.1 283.4c-5 2.8-8.1 8.2-8.1 13.9l0 65.5c0 10.6 10.2 18.3 20.4 15.4l171.6-49 0 70.9-57.6 43.2c-4 3-6.4 7.8-6.4 12.8l0 42c0 7.8 6.3 14 14 14c1.3 0 2.6-.2 3.9-.5L256 480l110.1 31.5c1.3 .4 2.6 .5 3.9 .5c6 0 11.1-3.7 13.1-9C344.5 470.7 320 422.2 320 368c0-60.6 30.6-114 77.1-145.6L320 178.3l0-84.6C320 59.5 292 0 256 0zM640 368a144 144 0 1 0 -288 0 144 144 0 1 0 288 0zm-76.7-43.3c6.2 6.2 6.2 16.4 0 22.6l-72 72c-6.2 6.2-16.4 6.2-22.6 0l-40-40c-6.2-6.2-6.2-16.4 0-22.6s16.4-6.2 22.6 0L480 385.4l60.7-60.7c6.2-6.2 16.4-6.2 22.6 0z\"]\n};\nconst faFaceRollingEyes = {\n prefix: 'fas',\n iconName: 'face-rolling-eyes',\n icon: [512, 512, [128580, \"meh-rolling-eyes\"], \"f5a5\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM192 368l128 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-128 0c-8.8 0-16-7.2-16-16s7.2-16 16-16zm32-144c0 35.3-28.7 64-64 64s-64-28.7-64-64c0-26 15.5-48.4 37.8-58.4c-3.7 5.2-5.8 11.6-5.8 18.4c0 17.7 14.3 32 32 32s32-14.3 32-32c0-6.9-2.2-13.2-5.8-18.4C208.5 175.6 224 198 224 224zm128 64c-35.3 0-64-28.7-64-64c0-26 15.5-48.4 37.8-58.4c-3.7 5.2-5.8 11.6-5.8 18.4c0 17.7 14.3 32 32 32s32-14.3 32-32c0-6.9-2.2-13.2-5.8-18.4C400.5 175.6 416 198 416 224c0 35.3-28.7 64-64 64z\"]\n};\nconst faMehRollingEyes = faFaceRollingEyes;\nconst faObjectGroup = {\n prefix: 'fas',\n iconName: 'object-group',\n icon: [576, 512, [], \"f247\", \"M32 119.4C12.9 108.4 0 87.7 0 64C0 28.7 28.7 0 64 0c23.7 0 44.4 12.9 55.4 32l337.1 0C467.6 12.9 488.3 0 512 0c35.3 0 64 28.7 64 64c0 23.7-12.9 44.4-32 55.4l0 273.1c19.1 11.1 32 31.7 32 55.4c0 35.3-28.7 64-64 64c-23.7 0-44.4-12.9-55.4-32l-337.1 0c-11.1 19.1-31.7 32-55.4 32c-35.3 0-64-28.7-64-64c0-23.7 12.9-44.4 32-55.4l0-273.1zM456.6 96L119.4 96c-5.6 9.7-13.7 17.8-23.4 23.4l0 273.1c9.7 5.6 17.8 13.7 23.4 23.4l337.1 0c5.6-9.7 13.7-17.8 23.4-23.4l0-273.1c-9.7-5.6-17.8-13.7-23.4-23.4zM128 160c0-17.7 14.3-32 32-32l128 0c17.7 0 32 14.3 32 32l0 96c0 17.7-14.3 32-32 32l-128 0c-17.7 0-32-14.3-32-32l0-96zM256 320l32 0c35.3 0 64-28.7 64-64l0-32 64 0c17.7 0 32 14.3 32 32l0 96c0 17.7-14.3 32-32 32l-128 0c-17.7 0-32-14.3-32-32l0-32z\"]\n};\nconst faChartLine = {\n prefix: 'fas',\n iconName: 'chart-line',\n icon: [512, 512, [\"line-chart\"], \"f201\", \"M64 64c0-17.7-14.3-32-32-32S0 46.3 0 64L0 400c0 44.2 35.8 80 80 80l400 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L80 416c-8.8 0-16-7.2-16-16L64 64zm406.6 86.6c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0L320 210.7l-57.4-57.4c-12.5-12.5-32.8-12.5-45.3 0l-112 112c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0L240 221.3l57.4 57.4c12.5 12.5 32.8 12.5 45.3 0l128-128z\"]\n};\nconst faLineChart = faChartLine;\nconst faMaskVentilator = {\n prefix: 'fas',\n iconName: 'mask-ventilator',\n icon: [640, 512, [], \"e524\", \"M159.1 176C139.4 219.2 128 264.7 128 300.8c0 15.9 2.2 31.4 6.3 46l-31.8-7.9C70.5 330.9 48 302.1 48 269l0-85c0-4.4 3.6-8 8-8l103.1 0zm26-48L56 128c-30.9 0-56 25.1-56 56l0 85c0 55.1 37.5 103.1 90.9 116.4l71.3 17.8c22.7 30.5 55.4 54.1 93.8 66.6l0-76.6c-19.7-16.4-32-40.3-32-66.9c0-49.5 43-134.4 96-134.4c52.5 0 96 84.9 96 134.4c0 26.7-12.4 50.4-32 66.8l0 76.6c38-12.6 70.6-36 93.5-66.4l71.6-17.9C602.5 372.1 640 324.1 640 269l0-85c0-30.9-25.1-56-56-56l-129.5 0C419.7 73.8 372.1 32 320 32c-52.6 0-100.2 41.8-134.9 96zm295.6 48L584 176c4.4 0 8 3.6 8 8l0 85c0 33-22.5 61.8-54.5 69.9l-31.8 8c4.2-14.7 6.4-30.1 6.4-46.1c0-36.1-11.6-81.6-31.3-124.8zM288 320l0 192 64 0 0-192c0-17.7-14.3-32-32-32s-32 14.3-32 32z\"]\n};\nconst faArrowRight = {\n prefix: 'fas',\n iconName: 'arrow-right',\n icon: [448, 512, [8594], \"f061\", \"M438.6 278.6c12.5-12.5 12.5-32.8 0-45.3l-160-160c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3L338.8 224 32 224c-17.7 0-32 14.3-32 32s14.3 32 32 32l306.7 0L233.4 393.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0l160-160z\"]\n};\nconst faSignsPost = {\n prefix: 'fas',\n iconName: 'signs-post',\n icon: [512, 512, [\"map-signs\"], \"f277\", \"M224 32L64 32C46.3 32 32 46.3 32 64l0 64c0 17.7 14.3 32 32 32l377.4 0c4.2 0 8.3-1.7 11.3-4.7l48-48c6.2-6.2 6.2-16.4 0-22.6l-48-48c-3-3-7.1-4.7-11.3-4.7L288 32c0-17.7-14.3-32-32-32s-32 14.3-32 32zM480 256c0-17.7-14.3-32-32-32l-160 0 0-32-64 0 0 32L70.6 224c-4.2 0-8.3 1.7-11.3 4.7l-48 48c-6.2 6.2-6.2 16.4 0 22.6l48 48c3 3 7.1 4.7 11.3 4.7L448 352c17.7 0 32-14.3 32-32l0-64zM288 480l0-96-64 0 0 96c0 17.7 14.3 32 32 32s32-14.3 32-32z\"]\n};\nconst faMapSigns = faSignsPost;\nconst faCashRegister = {\n prefix: 'fas',\n iconName: 'cash-register',\n icon: [512, 512, [], \"f788\", \"M64 0C46.3 0 32 14.3 32 32l0 64c0 17.7 14.3 32 32 32l80 0 0 32-57 0c-31.6 0-58.5 23.1-63.3 54.4L1.1 364.1C.4 368.8 0 373.6 0 378.4L0 448c0 35.3 28.7 64 64 64l384 0c35.3 0 64-28.7 64-64l0-69.6c0-4.8-.4-9.6-1.1-14.4L488.2 214.4C483.5 183.1 456.6 160 425 160l-217 0 0-32 80 0c17.7 0 32-14.3 32-32l0-64c0-17.7-14.3-32-32-32L64 0zM96 48l160 0c8.8 0 16 7.2 16 16s-7.2 16-16 16L96 80c-8.8 0-16-7.2-16-16s7.2-16 16-16zM64 432c0-8.8 7.2-16 16-16l352 0c8.8 0 16 7.2 16 16s-7.2 16-16 16L80 448c-8.8 0-16-7.2-16-16zm48-168a24 24 0 1 1 0-48 24 24 0 1 1 0 48zm120-24a24 24 0 1 1 -48 0 24 24 0 1 1 48 0zM160 344a24 24 0 1 1 0-48 24 24 0 1 1 0 48zM328 240a24 24 0 1 1 -48 0 24 24 0 1 1 48 0zM256 344a24 24 0 1 1 0-48 24 24 0 1 1 0 48zM424 240a24 24 0 1 1 -48 0 24 24 0 1 1 48 0zM352 344a24 24 0 1 1 0-48 24 24 0 1 1 0 48z\"]\n};\nconst faPersonCircleQuestion = {\n prefix: 'fas',\n iconName: 'person-circle-question',\n icon: [576, 512, [], \"e542\", \"M112 48a48 48 0 1 1 96 0 48 48 0 1 1 -96 0zm40 304l0 128c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-223.1L59.4 304.5c-9.1 15.1-28.8 20-43.9 10.9s-20-28.8-10.9-43.9l58.3-97c17.4-28.9 48.6-46.6 82.3-46.6l29.7 0c33.7 0 64.9 17.7 82.3 46.6l44.9 74.7c-16.1 17.6-28.6 38.5-36.6 61.5c-1.9-1.8-3.5-3.9-4.9-6.3L232 256.9 232 480c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-128-16 0zM432 224a144 144 0 1 1 0 288 144 144 0 1 1 0-288zm0 240a24 24 0 1 0 0-48 24 24 0 1 0 0 48zM368 321.6l0 6.4c0 8.8 7.2 16 16 16s16-7.2 16-16l0-6.4c0-5.3 4.3-9.6 9.6-9.6l40.5 0c7.7 0 13.9 6.2 13.9 13.9c0 5.2-2.9 9.9-7.4 12.3l-32 16.8c-5.3 2.8-8.6 8.2-8.6 14.2l0 14.8c0 8.8 7.2 16 16 16s16-7.2 16-16l0-5.1 23.5-12.3c15.1-7.9 24.5-23.6 24.5-40.6c0-25.4-20.6-45.9-45.9-45.9l-40.5 0c-23 0-41.6 18.6-41.6 41.6z\"]\n};\nconst faH = {\n prefix: 'fas',\n iconName: 'h',\n icon: [384, 512, [104], \"48\", \"M320 256l0 192c0 17.7 14.3 32 32 32s32-14.3 32-32l0-224 0-160c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 128L64 192 64 64c0-17.7-14.3-32-32-32S0 46.3 0 64L0 448c0 17.7 14.3 32 32 32s32-14.3 32-32l0-192 256 0z\"]\n};\nconst faTarp = {\n prefix: 'fas',\n iconName: 'tarp',\n icon: [576, 512, [], \"e57b\", \"M576 128c0-35.3-28.7-64-64-64L64 64C28.7 64 0 92.7 0 128L0 384c0 35.3 28.7 64 64 64l352 0 0-128c0-17.7 14.3-32 32-32l128 0 0-160zM448 448L576 320l-128 0 0 128zM96 128a32 32 0 1 1 0 64 32 32 0 1 1 0-64z\"]\n};\nconst faScrewdriverWrench = {\n prefix: 'fas',\n iconName: 'screwdriver-wrench',\n icon: [512, 512, [\"tools\"], \"f7d9\", \"M78.6 5C69.1-2.4 55.6-1.5 47 7L7 47c-8.5 8.5-9.4 22-2.1 31.6l80 104c4.5 5.9 11.6 9.4 19 9.4l54.1 0 109 109c-14.7 29-10 65.4 14.3 89.6l112 112c12.5 12.5 32.8 12.5 45.3 0l64-64c12.5-12.5 12.5-32.8 0-45.3l-112-112c-24.2-24.2-60.6-29-89.6-14.3l-109-109 0-54.1c0-7.5-3.5-14.5-9.4-19L78.6 5zM19.9 396.1C7.2 408.8 0 426.1 0 444.1C0 481.6 30.4 512 67.9 512c18 0 35.3-7.2 48-19.9L233.7 374.3c-7.8-20.9-9-43.6-3.6-65.1l-61.7-61.7L19.9 396.1zM512 144c0-10.5-1.1-20.7-3.2-30.5c-2.4-11.2-16.1-14.1-24.2-6l-63.9 63.9c-3 3-7.1 4.7-11.3 4.7L352 176c-8.8 0-16-7.2-16-16l0-57.4c0-4.2 1.7-8.3 4.7-11.3l63.9-63.9c8.1-8.1 5.2-21.8-6-24.2C388.7 1.1 378.5 0 368 0C288.5 0 224 64.5 224 144l0 .8 85.3 85.3c36-9.1 75.8 .5 104 28.7L429 274.5c49-23 83-72.8 83-130.5zM56 432a24 24 0 1 1 48 0 24 24 0 1 1 -48 0z\"]\n};\nconst faTools = faScrewdriverWrench;\nconst faArrowsToEye = {\n prefix: 'fas',\n iconName: 'arrows-to-eye',\n icon: [640, 512, [], \"e4bf\", \"M15 15C24.4 5.7 39.6 5.7 49 15l63 63L112 40c0-13.3 10.7-24 24-24s24 10.7 24 24l0 96c0 13.3-10.7 24-24 24l-96 0c-13.3 0-24-10.7-24-24s10.7-24 24-24l38.1 0L15 49C5.7 39.6 5.7 24.4 15 15zM133.5 243.9C158.6 193.6 222.7 112 320 112s161.4 81.6 186.5 131.9c3.8 7.6 3.8 16.5 0 24.2C481.4 318.4 417.3 400 320 400s-161.4-81.6-186.5-131.9c-3.8-7.6-3.8-16.5 0-24.2zM320 320a64 64 0 1 0 0-128 64 64 0 1 0 0 128zM591 15c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9l-63 63 38.1 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-96 0c-13.3 0-24-10.7-24-24l0-96c0-13.3 10.7-24 24-24s24 10.7 24 24l0 38.1 63-63zM15 497c-9.4-9.4-9.4-24.6 0-33.9l63-63L40 400c-13.3 0-24-10.7-24-24s10.7-24 24-24l96 0c13.3 0 24 10.7 24 24l0 96c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-38.1L49 497c-9.4 9.4-24.6 9.4-33.9 0zm576 0l-63-63 0 38.1c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-96c0-13.3 10.7-24 24-24l96 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-38.1 0 63 63c9.4 9.4 9.4 24.6 0 33.9s-24.6 9.4-33.9 0z\"]\n};\nconst faPlugCircleBolt = {\n prefix: 'fas',\n iconName: 'plug-circle-bolt',\n icon: [576, 512, [], \"e55b\", \"M96 0C78.3 0 64 14.3 64 32l0 96 64 0 0-96c0-17.7-14.3-32-32-32zM288 0c-17.7 0-32 14.3-32 32l0 96 64 0 0-96c0-17.7-14.3-32-32-32zM32 160c-17.7 0-32 14.3-32 32s14.3 32 32 32l0 32c0 77.4 55 142 128 156.8l0 67.2c0 17.7 14.3 32 32 32s32-14.3 32-32l0-67.2c12.3-2.5 24.1-6.4 35.1-11.5c-2.1-10.8-3.1-21.9-3.1-33.3c0-80.3 53.8-148 127.3-169.2c.5-2.2 .7-4.5 .7-6.8c0-17.7-14.3-32-32-32L32 160zM432 512a144 144 0 1 0 0-288 144 144 0 1 0 0 288zm47.9-225c4.3 3.7 5.4 9.9 2.6 14.9L452.4 356l35.6 0c5.2 0 9.8 3.3 11.4 8.2s-.1 10.3-4.2 13.4l-96 72c-4.5 3.4-10.8 3.2-15.1-.6s-5.4-9.9-2.6-14.9L411.6 380 376 380c-5.2 0-9.8-3.3-11.4-8.2s.1-10.3 4.2-13.4l96-72c4.5-3.4 10.8-3.2 15.1 .6z\"]\n};\nconst faHeart = {\n prefix: 'fas',\n iconName: 'heart',\n icon: [512, 512, [128153, 128154, 128155, 128156, 128420, 129293, 129294, 129505, 9829, 10084, 61578], \"f004\", \"M47.6 300.4L228.3 469.1c7.5 7 17.4 10.9 27.7 10.9s20.2-3.9 27.7-10.9L464.4 300.4c30.4-28.3 47.6-68 47.6-109.5v-5.8c0-69.9-50.5-129.5-119.4-141C347 36.5 300.6 51.4 268 84L256 96 244 84c-32.6-32.6-79-47.5-124.6-39.9C50.5 55.6 0 115.2 0 185.1v5.8c0 41.5 17.2 81.2 47.6 109.5z\"]\n};\nconst faMarsAndVenus = {\n prefix: 'fas',\n iconName: 'mars-and-venus',\n icon: [512, 512, [9893], \"f224\", \"M337.8 14.8C341.5 5.8 350.3 0 360 0L472 0c13.3 0 24 10.7 24 24l0 112c0 9.7-5.8 18.5-14.8 22.2s-19.3 1.7-26.2-5.2l-39-39-24.7 24.7C407 163.3 416 192.6 416 224c0 80.2-59 146.6-136 158.2l0 25.8 24 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-24 0 0 32c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-32-24 0c-13.3 0-24-10.7-24-24s10.7-24 24-24l24 0 0-25.8C155 370.6 96 304.2 96 224c0-88.4 71.6-160 160-160c39.6 0 75.9 14.4 103.8 38.2L382.1 80 343 41c-6.9-6.9-8.9-17.2-5.2-26.2zM448 48s0 0 0 0s0 0 0 0s0 0 0 0zM352 224a96 96 0 1 0 -192 0 96 96 0 1 0 192 0z\"]\n};\nconst faHouseUser = {\n prefix: 'fas',\n iconName: 'house-user',\n icon: [576, 512, [\"home-user\"], \"e1b0\", \"M575.8 255.5c0 18-15 32.1-32 32.1l-32 0 .7 160.2c.2 35.5-28.5 64.3-64 64.3l-320.4 0c-35.3 0-64-28.7-64-64l0-160.4-32 0c-18 0-32-14-32-32.1c0-9 3-17 10-24L266.4 8c7-7 15-8 22-8s15 2 21 7L564.8 231.5c8 7 12 15 11 24zM352 224a64 64 0 1 0 -128 0 64 64 0 1 0 128 0zm-96 96c-44.2 0-80 35.8-80 80c0 8.8 7.2 16 16 16l192 0c8.8 0 16-7.2 16-16c0-44.2-35.8-80-80-80l-64 0z\"]\n};\nconst faHomeUser = faHouseUser;\nconst faDumpsterFire = {\n prefix: 'fas',\n iconName: 'dumpster-fire',\n icon: [640, 512, [], \"f794\", \"M49.7 32l90.8 0L114.9 160l-94 0C9.3 160 0 150.7 0 139.1c0-2.1 .3-4.1 .9-6.1L26.8 48.9C29.9 38.9 39.2 32 49.7 32zM272 160l-124.5 0L173.1 32 272 32l0 128zm32 0l0-128 98.9 0 14.4 72.1c-1.7 1.1-3.3 2.4-4.8 3.8c-18.4 16.4-35.4 34-50.5 52.1l-58 0zm209.9-23.7c-1.7 1.6-3.4 3.2-5 4.8C498 129.6 486.7 118.6 475 108c-7.6-6.9-17-10.8-26.6-11.8L435.5 32l90.8 0c10.5 0 19.8 6.9 22.9 16.9L575.1 133c.2 .7 .4 1.4 .5 2.1c-17.8-15-44.3-14.6-61.7 1.2zM325.2 210.7C304.3 244.5 288 282.9 288 318.1c0 49.3 18.6 95.2 49.6 129.9L128 448c0 17.7-14.3 32-32 32s-32-14.3-32-32L44 288l-12 0c-17.7 0-32-14.3-32-32s14.3-32 32-32l4 0-4-32 305.5 0c-4.4 6.2-8.5 12.5-12.3 18.7zm180.6-34.5L518 162.5c5.4-6.1 13.3-8.8 20.9-8.9c7.2 0 14.3 2.6 19.9 7.8c19.7 18.3 39.8 43.2 55 70.6C629 259.2 640 290.2 640 320.2C640 408.8 568.7 480 480 480c-89.6 0-160-71.3-160-159.8c0-37.3 16-73.4 36.8-104.5c20.9-31.3 47.5-59 70.9-80.2c5.7-5.2 13.1-7.7 20.3-7.5c14.1 .3 23.8 11.4 32.7 21.6c0 0 0 0 0 0c2 2.3 4 4.6 6 6.7l19 19.9zM544 368.2c0-36.5-37-73-54.8-88.4c-5.4-4.7-13.1-4.7-18.5 0C453 295.1 416 331.6 416 368.2c0 35.3 28.7 64 64 64s64-28.7 64-64z\"]\n};\nconst faHouseCrack = {\n prefix: 'fas',\n iconName: 'house-crack',\n icon: [576, 512, [], \"e3b1\", \"M543.8 287.6c17 0 32-14 32-32.1c1-9-3-17-11-24L309.5 7c-6-5-14-7-21-7s-15 1-22 8L10 231.5c-7 7-10 15-10 24c0 18 14 32.1 32 32.1l32 0 0 160.4c0 35.3 28.7 64 64 64l102.3 0-31.3-52.2c-4.1-6.8-2.6-15.5 3.5-20.5L288 368l-60.2-82.8c-10.9-15 8.2-33.5 22.8-22l117.9 92.6c8 6.3 8.2 18.4 .4 24.9L288 448l38.4 64 122.1 0c35.5 0 64.2-28.8 64-64.3l-.7-160.2 32 0z\"]\n};\nconst faMartiniGlassCitrus = {\n prefix: 'fas',\n iconName: 'martini-glass-citrus',\n icon: [576, 512, [\"cocktail\"], \"f561\", \"M432 240c53 0 96-43 96-96s-43-96-96-96c-35.5 0-66.6 19.3-83.2 48l-52.6 0C316 40.1 369.3 0 432 0c79.5 0 144 64.5 144 144s-64.5 144-144 144c-27.7 0-53.5-7.8-75.5-21.3l35.4-35.4c12.2 5.6 25.8 8.7 40.1 8.7zM1.8 142.8C5.5 133.8 14.3 128 24 128l368 0c9.7 0 18.5 5.8 22.2 14.8s1.7 19.3-5.2 26.2l-177 177L232 464l64 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-88 0-88 0c-13.3 0-24-10.7-24-24s10.7-24 24-24l64 0 0-118.1L7 169c-6.9-6.9-8.9-17.2-5.2-26.2z\"]\n};\nconst faCocktail = faMartiniGlassCitrus;\nconst faFaceSurprise = {\n prefix: 'fas',\n iconName: 'face-surprise',\n icon: [512, 512, [128558, \"surprise\"], \"f5c2\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM176.4 176a32 32 0 1 1 0 64 32 32 0 1 1 0-64zm128 32a32 32 0 1 1 64 0 32 32 0 1 1 -64 0zM256 288a64 64 0 1 1 0 128 64 64 0 1 1 0-128z\"]\n};\nconst faSurprise = faFaceSurprise;\nconst faBottleWater = {\n prefix: 'fas',\n iconName: 'bottle-water',\n icon: [320, 512, [], \"e4c5\", \"M120 0l80 0c13.3 0 24 10.7 24 24l0 40L96 64l0-40c0-13.3 10.7-24 24-24zM32 167.5c0-19.5 10-37.6 26.6-47.9l15.8-9.9C88.7 100.7 105.2 96 122.1 96l75.8 0c16.9 0 33.4 4.7 47.7 13.7l15.8 9.9C278 129.9 288 148 288 167.5c0 17-7.5 32.3-19.4 42.6C280.6 221.7 288 238 288 256c0 19.1-8.4 36.3-21.7 48c13.3 11.7 21.7 28.9 21.7 48s-8.4 36.3-21.7 48c13.3 11.7 21.7 28.9 21.7 48c0 35.3-28.7 64-64 64L96 512c-35.3 0-64-28.7-64-64c0-19.1 8.4-36.3 21.7-48C40.4 388.3 32 371.1 32 352s8.4-36.3 21.7-48C40.4 292.3 32 275.1 32 256c0-18 7.4-34.3 19.4-45.9C39.5 199.7 32 184.5 32 167.5zM96 240c0 8.8 7.2 16 16 16l96 0c8.8 0 16-7.2 16-16s-7.2-16-16-16l-96 0c-8.8 0-16 7.2-16 16zm16 112c-8.8 0-16 7.2-16 16s7.2 16 16 16l96 0c8.8 0 16-7.2 16-16s-7.2-16-16-16l-96 0z\"]\n};\nconst faCirclePause = {\n prefix: 'fas',\n iconName: 'circle-pause',\n icon: [512, 512, [62092, \"pause-circle\"], \"f28b\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM224 192l0 128c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-128c0-17.7 14.3-32 32-32s32 14.3 32 32zm128 0l0 128c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-128c0-17.7 14.3-32 32-32s32 14.3 32 32z\"]\n};\nconst faPauseCircle = faCirclePause;\nconst faToiletPaperSlash = {\n prefix: 'fas',\n iconName: 'toilet-paper-slash',\n icon: [640, 512, [], \"e072\", \"M38.8 5.1C28.4-3.1 13.3-1.2 5.1 9.2S-1.2 34.7 9.2 42.9l592 464c10.4 8.2 25.5 6.3 33.7-4.1s6.3-25.5-4.1-33.7l-109.7-86C569.9 374 608 291.9 608 192C608 86 565 0 512 0s-96 86-96 192c0 49.1 9.2 93.9 24.4 127.9l-59-46.2c1.6-24.8 2.6-52 2.6-81.6c0-65.5 13.2-142.4 60.2-192L160 0c-24.8 0-47.4 18.8-64.4 49.6L38.8 5.1zM367.3 385.4L66.5 148.4C64.9 162.4 64 177 64 192c0 101.5-11.7 170.8-23 213.9c-5.1 19.4-10.7 39.9-20.5 57.7c-5.9 9.9-6.1 22.1-.4 32.2S36.5 512 48 512l237.9 0c22.3 0 45.4-12.1 55.4-36.1c7.4-17.7 17.5-47.2 26-90.6zM544 192c0 35.3-14.3 64-32 64s-32-28.7-32-64s14.3-64 32-64s32 28.7 32 64z\"]\n};\nconst faAppleWhole = {\n prefix: 'fas',\n iconName: 'apple-whole',\n icon: [448, 512, [127822, 127823, \"apple-alt\"], \"f5d1\", \"M224 112c-8.8 0-16-7.2-16-16l0-16c0-44.2 35.8-80 80-80l16 0c8.8 0 16 7.2 16 16l0 16c0 44.2-35.8 80-80 80l-16 0zM0 288c0-76.3 35.7-160 112-160c27.3 0 59.7 10.3 82.7 19.3c18.8 7.3 39.9 7.3 58.7 0c22.9-8.9 55.4-19.3 82.7-19.3c76.3 0 112 83.7 112 160c0 128-80 224-160 224c-16.5 0-38.1-6.6-51.5-11.3c-8.1-2.8-16.9-2.8-25 0c-13.4 4.7-35 11.3-51.5 11.3C80 512 0 416 0 288z\"]\n};\nconst faAppleAlt = faAppleWhole;\nconst faKitchenSet = {\n prefix: 'fas',\n iconName: 'kitchen-set',\n icon: [576, 512, [], \"e51a\", \"M240 144A96 96 0 1 0 48 144a96 96 0 1 0 192 0zm44.4 32C269.9 240.1 212.5 288 144 288C64.5 288 0 223.5 0 144S64.5 0 144 0c68.5 0 125.9 47.9 140.4 112l71.8 0c8.8-9.8 21.6-16 35.8-16l104 0c26.5 0 48 21.5 48 48s-21.5 48-48 48l-104 0c-14.2 0-27-6.2-35.8-16l-71.8 0zM144 80a64 64 0 1 1 0 128 64 64 0 1 1 0-128zM400 240c13.3 0 24 10.7 24 24l0 8 96 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-240 0c-13.3 0-24-10.7-24-24s10.7-24 24-24l96 0 0-8c0-13.3 10.7-24 24-24zM288 464l0-112 224 0 0 112c0 26.5-21.5 48-48 48l-128 0c-26.5 0-48-21.5-48-48zM48 320l80 0 16 0 32 0c26.5 0 48 21.5 48 48s-21.5 48-48 48l-16 0c0 17.7-14.3 32-32 32l-64 0c-17.7 0-32-14.3-32-32l0-80c0-8.8 7.2-16 16-16zm128 64c8.8 0 16-7.2 16-16s-7.2-16-16-16l-16 0 0 32 16 0zM24 464l176 0c13.3 0 24 10.7 24 24s-10.7 24-24 24L24 512c-13.3 0-24-10.7-24-24s10.7-24 24-24z\"]\n};\nconst faR = {\n prefix: 'fas',\n iconName: 'r',\n icon: [320, 512, [114], \"52\", \"M64 32C28.7 32 0 60.7 0 96L0 288 0 448c0 17.7 14.3 32 32 32s32-14.3 32-32l0-128 95.3 0L261.8 466.4c10.1 14.5 30.1 18 44.6 7.9s18-30.1 7.9-44.6L230.1 309.5C282.8 288.1 320 236.4 320 176c0-79.5-64.5-144-144-144L64 32zM176 256L64 256 64 96l112 0c44.2 0 80 35.8 80 80s-35.8 80-80 80z\"]\n};\nconst faTemperatureQuarter = {\n prefix: 'fas',\n iconName: 'temperature-quarter',\n icon: [320, 512, [\"temperature-1\", \"thermometer-1\", \"thermometer-quarter\"], \"f2ca\", \"M160 64c-26.5 0-48 21.5-48 48l0 164.5c0 17.3-7.1 31.9-15.3 42.5C86.2 332.6 80 349.5 80 368c0 44.2 35.8 80 80 80s80-35.8 80-80c0-18.5-6.2-35.4-16.7-48.9c-8.2-10.6-15.3-25.2-15.3-42.5L208 112c0-26.5-21.5-48-48-48zM48 112C48 50.2 98.1 0 160 0s112 50.1 112 112l0 164.4c0 .1 .1 .3 .2 .6c.2 .6 .8 1.6 1.7 2.8c18.9 24.4 30.1 55 30.1 88.1c0 79.5-64.5 144-144 144S16 447.5 16 368c0-33.2 11.2-63.8 30.1-88.1c.9-1.2 1.5-2.2 1.7-2.8c.1-.3 .2-.5 .2-.6L48 112zM208 368c0 26.5-21.5 48-48 48s-48-21.5-48-48c0-20.9 13.4-38.7 32-45.3l0-50.7c0-8.8 7.2-16 16-16s16 7.2 16 16l0 50.7c18.6 6.6 32 24.4 32 45.3z\"]\n};\nconst faTemperature1 = faTemperatureQuarter;\nconst faThermometer1 = faTemperatureQuarter;\nconst faThermometerQuarter = faTemperatureQuarter;\nconst faCube = {\n prefix: 'fas',\n iconName: 'cube',\n icon: [512, 512, [], \"f1b2\", \"M234.5 5.7c13.9-5 29.1-5 43.1 0l192 68.6C495 83.4 512 107.5 512 134.6l0 242.9c0 27-17 51.2-42.5 60.3l-192 68.6c-13.9 5-29.1 5-43.1 0l-192-68.6C17 428.6 0 404.5 0 377.4L0 134.6c0-27 17-51.2 42.5-60.3l192-68.6zM256 66L82.3 128 256 190l173.7-62L256 66zm32 368.6l160-57.1 0-188L288 246.6l0 188z\"]\n};\nconst faBitcoinSign = {\n prefix: 'fas',\n iconName: 'bitcoin-sign',\n icon: [320, 512, [], \"e0b4\", \"M48 32C48 14.3 62.3 0 80 0s32 14.3 32 32l0 32 32 0 0-32c0-17.7 14.3-32 32-32s32 14.3 32 32l0 32c0 1.5-.1 3.1-.3 4.5C254.1 82.2 288 125.1 288 176c0 24.2-7.7 46.6-20.7 64.9c31.7 19.8 52.7 55 52.7 95.1c0 61.9-50.1 112-112 112l0 32c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-32-32 0 0 32c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-32-6.3 0C18.7 448 0 429.3 0 406.3L0 288l0-22.3L0 224 0 101.6C0 80.8 16.8 64 37.6 64L48 64l0-32zM64 224l112 0c26.5 0 48-21.5 48-48s-21.5-48-48-48L64 128l0 96zm112 64L64 288l0 96 144 0c26.5 0 48-21.5 48-48s-21.5-48-48-48l-32 0z\"]\n};\nconst faShieldDog = {\n prefix: 'fas',\n iconName: 'shield-dog',\n icon: [512, 512, [], \"e573\", \"M269.4 2.9C265.2 1 260.7 0 256 0s-9.2 1-13.4 2.9L54.3 82.8c-22 9.3-38.4 31-38.3 57.2c.5 99.2 41.3 280.7 213.6 363.2c16.7 8 36.1 8 52.8 0C454.7 420.7 495.5 239.2 496 140c.1-26.2-16.3-47.9-38.3-57.2L269.4 2.9zM160.9 286.2c4.8 1.2 9.9 1.8 15.1 1.8c35.3 0 64-28.7 64-64l0-64 44.2 0c12.1 0 23.2 6.8 28.6 17.7L320 192l64 0c8.8 0 16 7.2 16 16l0 32c0 44.2-35.8 80-80 80l-48 0 0 50.7c0 7.3-5.9 13.3-13.3 13.3c-1.8 0-3.6-.4-5.2-1.1l-98.7-42.3c-6.6-2.8-10.8-9.3-10.8-16.4c0-2.8 .6-5.5 1.9-8l15-30zM160 160l40 0 8 0 0 32 0 32c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-48c0-8.8 7.2-16 16-16zm128 48a16 16 0 1 0 -32 0 16 16 0 1 0 32 0z\"]\n};\nconst faSolarPanel = {\n prefix: 'fas',\n iconName: 'solar-panel',\n icon: [640, 512, [], \"f5ba\", \"M122.2 0C91.7 0 65.5 21.5 59.5 51.4L8.3 307.4C.4 347 30.6 384 71 384l217 0 0 64-64 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l192 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-64 0 0-64 217 0c40.4 0 70.7-36.9 62.8-76.6l-51.2-256C574.5 21.5 548.3 0 517.8 0L122.2 0zM260.9 64l118.2 0 10.4 104-139 0L260.9 64zM202.3 168l-100.8 0L122.2 64l90.4 0L202.3 168zM91.8 216l105.6 0L187.1 320 71 320 91.8 216zm153.9 0l148.6 0 10.4 104-169.4 0 10.4-104zm196.8 0l105.6 0L569 320l-116 0L442.5 216zm96-48l-100.8 0L427.3 64l90.4 0 31.4-6.3L517.8 64l20.8 104z\"]\n};\nconst faLockOpen = {\n prefix: 'fas',\n iconName: 'lock-open',\n icon: [576, 512, [], \"f3c1\", \"M352 144c0-44.2 35.8-80 80-80s80 35.8 80 80l0 48c0 17.7 14.3 32 32 32s32-14.3 32-32l0-48C576 64.5 511.5 0 432 0S288 64.5 288 144l0 48L64 192c-35.3 0-64 28.7-64 64L0 448c0 35.3 28.7 64 64 64l320 0c35.3 0 64-28.7 64-64l0-192c0-35.3-28.7-64-64-64l-32 0 0-48z\"]\n};\nconst faElevator = {\n prefix: 'fas',\n iconName: 'elevator',\n icon: [512, 512, [], \"e16d\", \"M132.7 4.7l-64 64c-4.6 4.6-5.9 11.5-3.5 17.4s8.3 9.9 14.8 9.9l128 0c6.5 0 12.3-3.9 14.8-9.9s1.1-12.9-3.5-17.4l-64-64c-6.2-6.2-16.4-6.2-22.6 0zM64 128c-35.3 0-64 28.7-64 64L0 448c0 35.3 28.7 64 64 64l384 0c35.3 0 64-28.7 64-64l0-256c0-35.3-28.7-64-64-64L64 128zm96 96a48 48 0 1 1 0 96 48 48 0 1 1 0-96zM80 400c0-26.5 21.5-48 48-48l64 0c26.5 0 48 21.5 48 48l0 16c0 17.7-14.3 32-32 32l-96 0c-17.7 0-32-14.3-32-32l0-16zm192 0c0-26.5 21.5-48 48-48l64 0c26.5 0 48 21.5 48 48l0 16c0 17.7-14.3 32-32 32l-96 0c-17.7 0-32-14.3-32-32l0-16zm32-128a48 48 0 1 1 96 0 48 48 0 1 1 -96 0zM356.7 91.3c6.2 6.2 16.4 6.2 22.6 0l64-64c4.6-4.6 5.9-11.5 3.5-17.4S438.5 0 432 0L304 0c-6.5 0-12.3 3.9-14.8 9.9s-1.1 12.9 3.5 17.4l64 64z\"]\n};\nconst faMoneyBillTransfer = {\n prefix: 'fas',\n iconName: 'money-bill-transfer',\n icon: [640, 512, [], \"e528\", \"M535 41c-9.4-9.4-9.4-24.6 0-33.9s24.6-9.4 33.9 0l64 64c4.5 4.5 7 10.6 7 17s-2.5 12.5-7 17l-64 64c-9.4 9.4-24.6 9.4-33.9 0s-9.4-24.6 0-33.9l23-23L384 112c-13.3 0-24-10.7-24-24s10.7-24 24-24l174.1 0L535 41zM105 377l-23 23L256 400c13.3 0 24 10.7 24 24s-10.7 24-24 24L81.9 448l23 23c9.4 9.4 9.4 24.6 0 33.9s-24.6 9.4-33.9 0L7 441c-4.5-4.5-7-10.6-7-17s2.5-12.5 7-17l64-64c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9zM96 64l241.9 0c-3.7 7.2-5.9 15.3-5.9 24c0 28.7 23.3 52 52 52l117.4 0c-4 17 .6 35.5 13.8 48.8c20.3 20.3 53.2 20.3 73.5 0L608 169.5 608 384c0 35.3-28.7 64-64 64l-241.9 0c3.7-7.2 5.9-15.3 5.9-24c0-28.7-23.3-52-52-52l-117.4 0c4-17-.6-35.5-13.8-48.8c-20.3-20.3-53.2-20.3-73.5 0L32 342.5 32 128c0-35.3 28.7-64 64-64zm64 64l-64 0 0 64c35.3 0 64-28.7 64-64zM544 320c-35.3 0-64 28.7-64 64l64 0 0-64zM320 352a96 96 0 1 0 0-192 96 96 0 1 0 0 192z\"]\n};\nconst faMoneyBillTrendUp = {\n prefix: 'fas',\n iconName: 'money-bill-trend-up',\n icon: [512, 512, [], \"e529\", \"M470.7 9.4c3 3.1 5.3 6.6 6.9 10.3s2.4 7.8 2.4 12.2c0 0 0 .1 0 .1c0 0 0 0 0 0l0 96c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-18.7L310.6 214.6c-11.8 11.8-30.8 12.6-43.5 1.7L176 138.1 84.8 216.3c-13.4 11.5-33.6 9.9-45.1-3.5s-9.9-33.6 3.5-45.1l112-96c12-10.3 29.7-10.3 41.7 0l89.5 76.7L370.7 64 352 64c-17.7 0-32-14.3-32-32s14.3-32 32-32l96 0s0 0 0 0c8.8 0 16.8 3.6 22.6 9.3l.1 .1zM0 304c0-26.5 21.5-48 48-48l416 0c26.5 0 48 21.5 48 48l0 160c0 26.5-21.5 48-48 48L48 512c-26.5 0-48-21.5-48-48L0 304zM48 416l0 48 48 0c0-26.5-21.5-48-48-48zM96 304l-48 0 0 48c26.5 0 48-21.5 48-48zM464 416c-26.5 0-48 21.5-48 48l48 0 0-48zM416 304c0 26.5 21.5 48 48 48l0-48-48 0zm-96 80a64 64 0 1 0 -128 0 64 64 0 1 0 128 0z\"]\n};\nconst faHouseFloodWaterCircleArrowRight = {\n prefix: 'fas',\n iconName: 'house-flood-water-circle-arrow-right',\n icon: [640, 512, [], \"e50f\", \"M288 144A144 144 0 1 0 0 144a144 144 0 1 0 288 0zM140.7 76.7c6.2-6.2 16.4-6.2 22.6 0l56 56c6.2 6.2 6.2 16.4 0 22.6l-56 56c-6.2 6.2-16.4 6.2-22.6 0s-6.2-16.4 0-22.6L169.4 160 80 160c-8.8 0-16-7.2-16-16s7.2-16 16-16l89.4 0L140.7 99.3c-6.2-6.2-6.2-16.4 0-22.6zM320 144c0 57.3-27.4 108.2-69.8 140.3c11.8-3.6 23-9.4 33-16.2c22.1-15.5 51.6-15.5 73.7 0c18.4 12.7 39.6 20.3 59.2 20.3c19 0 41.2-7.9 59.2-20.3c23.8-16.7 55.8-15.4 78.1 3.4c2.1 1.7 4.2 3.3 6.5 4.9l-.3-84.4 16.6 0c13.9 0 26.1-8.9 30.4-22.1s-.4-27.6-11.6-35.8l-176-128C407.6-2 392.4-2 381.2 6.1L301 64.4c12.1 23.9 19 50.9 19 79.6zm18.5 165.9c-11.1-7.9-25.9-7.9-37 0C279 325.4 251.5 336 224 336c-26.9 0-55.3-10.8-77.4-26.1c0 0 0 0 0 0c-11.9-8.5-28.1-7.8-39.2 1.7c-14.4 11.9-32.5 21-50.6 25.2c-17.2 4-27.9 21.2-23.9 38.4s21.2 27.9 38.4 23.9c24.5-5.7 44.9-16.5 58.2-25C158.5 389.7 191 400 224 400c31.9 0 60.6-9.9 80.4-18.9c5.8-2.7 11.1-5.3 15.6-7.7c4.5 2.4 9.7 5.1 15.6 7.7c19.8 9 48.6 18.9 80.4 18.9c33 0 65.5-10.3 94.5-25.8c13.4 8.4 33.7 19.3 58.2 25c17.2 4 34.4-6.7 38.4-23.9s-6.7-34.4-23.9-38.4c-18.1-4.2-36.2-13.3-50.6-25.2c-11.1-9.5-27.3-10.1-39.2-1.7c0 0 0 0 0 0C471.4 325.2 442.9 336 416 336c-27.5 0-55-10.6-77.5-26.1zm0 112c-11.1-7.9-25.9-7.9-37 0C279 437.4 251.5 448 224 448c-26.9 0-55.3-10.8-77.4-26.1c0 0 0 0 0 0c-11.9-8.5-28.1-7.8-39.2 1.7c-14.4 11.9-32.5 21-50.6 25.2c-17.2 4-27.9 21.2-23.9 38.4s21.2 27.9 38.4 23.9c24.5-5.7 44.9-16.5 58.2-25C158.5 501.7 191 512 224 512c31.9 0 60.6-9.9 80.4-18.9c5.8-2.7 11.1-5.3 15.6-7.7c4.5 2.4 9.7 5.1 15.6 7.7c19.8 9 48.6 18.9 80.4 18.9c33 0 65.5-10.3 94.5-25.8c13.4 8.4 33.7 19.3 58.2 25c17.2 4 34.4-6.7 38.4-23.9s-6.7-34.4-23.9-38.4c-18.1-4.2-36.2-13.3-50.6-25.2c-11.1-9.4-27.3-10.1-39.2-1.7c0 0 0 0 0 0C471.4 437.2 442.9 448 416 448c-27.5 0-55-10.6-77.5-26.1z\"]\n};\nconst faSquarePollHorizontal = {\n prefix: 'fas',\n iconName: 'square-poll-horizontal',\n icon: [448, 512, [\"poll-h\"], \"f682\", \"M448 96c0-35.3-28.7-64-64-64L64 32C28.7 32 0 60.7 0 96L0 416c0 35.3 28.7 64 64 64l320 0c35.3 0 64-28.7 64-64l0-320zM256 160c0 17.7-14.3 32-32 32l-96 0c-17.7 0-32-14.3-32-32s14.3-32 32-32l96 0c17.7 0 32 14.3 32 32zm64 64c17.7 0 32 14.3 32 32s-14.3 32-32 32l-192 0c-17.7 0-32-14.3-32-32s14.3-32 32-32l192 0zM192 352c0 17.7-14.3 32-32 32l-32 0c-17.7 0-32-14.3-32-32s14.3-32 32-32l32 0c17.7 0 32 14.3 32 32z\"]\n};\nconst faPollH = faSquarePollHorizontal;\nconst faCircle = {\n prefix: 'fas',\n iconName: 'circle',\n icon: [512, 512, [128308, 128309, 128992, 128993, 128994, 128995, 128996, 9679, 9898, 9899, 11044, 61708, 61915], \"f111\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512z\"]\n};\nconst faBackwardFast = {\n prefix: 'fas',\n iconName: 'backward-fast',\n icon: [512, 512, [9198, \"fast-backward\"], \"f049\", \"M493.6 445c-11.2 5.3-24.5 3.6-34.1-4.4L288 297.7 288 416c0 12.4-7.2 23.7-18.4 29s-24.5 3.6-34.1-4.4L64 297.7 64 416c0 17.7-14.3 32-32 32s-32-14.3-32-32L0 96C0 78.3 14.3 64 32 64s32 14.3 32 32l0 118.3L235.5 71.4c9.5-7.9 22.8-9.7 34.1-4.4S288 83.6 288 96l0 118.3L459.5 71.4c9.5-7.9 22.8-9.7 34.1-4.4S512 83.6 512 96l0 320c0 12.4-7.2 23.7-18.4 29z\"]\n};\nconst faFastBackward = faBackwardFast;\nconst faRecycle = {\n prefix: 'fas',\n iconName: 'recycle',\n icon: [512, 512, [9842, 9850, 9851], \"f1b8\", \"M174.7 45.1C192.2 17 223 0 256 0s63.8 17 81.3 45.1l38.6 61.7 27-15.6c8.4-4.9 18.9-4.2 26.6 1.7s11.1 15.9 8.6 25.3l-23.4 87.4c-3.4 12.8-16.6 20.4-29.4 17l-87.4-23.4c-9.4-2.5-16.3-10.4-17.6-20s3.4-19.1 11.8-23.9l28.4-16.4L283 79c-5.8-9.3-16-15-27-15s-21.2 5.7-27 15l-17.5 28c-9.2 14.8-28.6 19.5-43.6 10.5c-15.3-9.2-20.2-29.2-10.7-44.4l17.5-28zM429.5 251.9c15-9 34.4-4.3 43.6 10.5l24.4 39.1c9.4 15.1 14.4 32.4 14.6 50.2c.3 53.1-42.7 96.4-95.8 96.4L320 448l0 32c0 9.7-5.8 18.5-14.8 22.2s-19.3 1.7-26.2-5.2l-64-64c-9.4-9.4-9.4-24.6 0-33.9l64-64c6.9-6.9 17.2-8.9 26.2-5.2s14.8 12.5 14.8 22.2l0 32 96.2 0c17.6 0 31.9-14.4 31.8-32c0-5.9-1.7-11.7-4.8-16.7l-24.4-39.1c-9.5-15.2-4.7-35.2 10.7-44.4zm-364.6-31L36 204.2c-8.4-4.9-13.1-14.3-11.8-23.9s8.2-17.5 17.6-20l87.4-23.4c12.8-3.4 26 4.2 29.4 17L182 241.2c2.5 9.4-.9 19.3-8.6 25.3s-18.2 6.6-26.6 1.7l-26.5-15.3L68.8 335.3c-3.1 5-4.8 10.8-4.8 16.7c-.1 17.6 14.2 32 31.8 32l32.2 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-32.2 0C42.7 448-.3 404.8 0 351.6c.1-17.8 5.1-35.1 14.6-50.2l50.3-80.5z\"]\n};\nconst faUserAstronaut = {\n prefix: 'fas',\n iconName: 'user-astronaut',\n icon: [448, 512, [], \"f4fb\", \"M370.7 96.1C346.1 39.5 289.7 0 224 0S101.9 39.5 77.3 96.1C60.9 97.5 48 111.2 48 128l0 64c0 16.8 12.9 30.5 29.3 31.9C101.9 280.5 158.3 320 224 320s122.1-39.5 146.7-96.1c16.4-1.4 29.3-15.1 29.3-31.9l0-64c0-16.8-12.9-30.5-29.3-31.9zM336 144l0 16c0 53-43 96-96 96l-32 0c-53 0-96-43-96-96l0-16c0-26.5 21.5-48 48-48l128 0c26.5 0 48 21.5 48 48zM189.3 162.7l-6-21.2c-.9-3.3-3.9-5.5-7.3-5.5s-6.4 2.2-7.3 5.5l-6 21.2-21.2 6c-3.3 .9-5.5 3.9-5.5 7.3s2.2 6.4 5.5 7.3l21.2 6 6 21.2c.9 3.3 3.9 5.5 7.3 5.5s6.4-2.2 7.3-5.5l6-21.2 21.2-6c3.3-.9 5.5-3.9 5.5-7.3s-2.2-6.4-5.5-7.3l-21.2-6zM112.7 316.5C46.7 342.6 0 407 0 482.3C0 498.7 13.3 512 29.7 512l98.3 0 0-64c0-17.7 14.3-32 32-32l128 0c17.7 0 32 14.3 32 32l0 64 98.3 0c16.4 0 29.7-13.3 29.7-29.7c0-75.3-46.7-139.7-112.7-165.8C303.9 338.8 265.5 352 224 352s-79.9-13.2-111.3-35.5zM176 448c-8.8 0-16 7.2-16 16l0 48 32 0 0-48c0-8.8-7.2-16-16-16zm96 32a16 16 0 1 0 0-32 16 16 0 1 0 0 32z\"]\n};\nconst faPlaneSlash = {\n prefix: 'fas',\n iconName: 'plane-slash',\n icon: [640, 512, [], \"e069\", \"M514.3 192c34.2 0 93.7 29 93.7 64c0 36-59.5 64-93.7 64l-73.8 0L630.8 469.1c10.4 8.2 12.3 23.3 4.1 33.7s-23.3 12.3-33.7 4.1L9.2 42.9C-1.2 34.7-3.1 19.6 5.1 9.2S28.4-3.1 38.8 5.1L238.1 161.3 197.8 20.4C194.9 10.2 202.6 0 213.2 0l56.2 0c11.5 0 22.1 6.2 27.8 16.1L397.7 192l116.6 0zM41.5 128.7l321 252.9L297.2 495.9c-5.7 10-16.3 16.1-27.8 16.1l-56.2 0c-10.6 0-18.3-10.2-15.4-20.4l49-171.6L144 320l-43.2 57.6c-3 4-7.8 6.4-12.8 6.4l-42 0c-7.8 0-14-6.3-14-14c0-1.3 .2-2.6 .5-3.9L64 256 32.5 145.9c-.4-1.3-.5-2.6-.5-3.9c0-6.2 4-11.4 9.5-13.3z\"]\n};\nconst faTrademark = {\n prefix: 'fas',\n iconName: 'trademark',\n icon: [640, 512, [8482], \"f25c\", \"M345.6 108.8c-8.3-11-22.7-15.5-35.7-11.2S288 114.2 288 128l0 256c0 17.7 14.3 32 32 32s32-14.3 32-32l0-160 86.4 115.2c6 8.1 15.5 12.8 25.6 12.8s19.6-4.7 25.6-12.8L576 224l0 160c0 17.7 14.3 32 32 32s32-14.3 32-32l0-256c0-13.8-8.8-26-21.9-30.4s-27.5 .1-35.7 11.2L464 266.7 345.6 108.8zM0 128c0 17.7 14.3 32 32 32l64 0 0 224c0 17.7 14.3 32 32 32s32-14.3 32-32l0-224 64 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L32 96C14.3 96 0 110.3 0 128z\"]\n};\nconst faBasketball = {\n prefix: 'fas',\n iconName: 'basketball',\n icon: [512, 512, [127936, \"basketball-ball\"], \"f434\", \"M86.6 64l85.2 85.2C194.5 121.7 208 86.4 208 48c0-14.7-2-28.9-5.7-42.4C158.6 15 119 35.5 86.6 64zM64 86.6C35.5 119 15 158.6 5.6 202.3C19.1 206 33.3 208 48 208c38.4 0 73.7-13.5 101.3-36.1L64 86.6zM256 0c-7.3 0-14.6 .3-21.8 .9C238 16 240 31.8 240 48c0 47.3-17.1 90.5-45.4 124L256 233.4 425.4 64C380.2 24.2 320.9 0 256 0zM48 240c-16.2 0-32-2-47.1-5.8C.3 241.4 0 248.7 0 256c0 64.9 24.2 124.2 64 169.4L233.4 256 172 194.6C138.5 222.9 95.3 240 48 240zm463.1 37.8c.6-7.2 .9-14.5 .9-21.8c0-64.9-24.2-124.2-64-169.4L278.6 256 340 317.4c33.4-28.3 76.7-45.4 124-45.4c16.2 0 32 2 47.1 5.8zm-4.7 31.9C492.9 306 478.7 304 464 304c-38.4 0-73.7 13.5-101.3 36.1L448 425.4c28.5-32.3 49.1-71.9 58.4-115.7zM340.1 362.7C317.5 390.3 304 425.6 304 464c0 14.7 2 28.9 5.7 42.4C353.4 497 393 476.5 425.4 448l-85.2-85.2zM317.4 340L256 278.6 86.6 448c45.1 39.8 104.4 64 169.4 64c7.3 0 14.6-.3 21.8-.9C274 496 272 480.2 272 464c0-47.3 17.1-90.5 45.4-124z\"]\n};\nconst faBasketballBall = faBasketball;\nconst faSatelliteDish = {\n prefix: 'fas',\n iconName: 'satellite-dish',\n icon: [512, 512, [128225], \"f7c0\", \"M192 32c0-17.7 14.3-32 32-32C383.1 0 512 128.9 512 288c0 17.7-14.3 32-32 32s-32-14.3-32-32C448 164.3 347.7 64 224 64c-17.7 0-32-14.3-32-32zM60.6 220.6L164.7 324.7l28.4-28.4c-.7-2.6-1.1-5.4-1.1-8.3c0-17.7 14.3-32 32-32s32 14.3 32 32s-14.3 32-32 32c-2.9 0-5.6-.4-8.3-1.1l-28.4 28.4L291.4 451.4c14.5 14.5 11.8 38.8-7.3 46.3C260.5 506.9 234.9 512 208 512C93.1 512 0 418.9 0 304c0-26.9 5.1-52.5 14.4-76.1c7.5-19 31.8-21.8 46.3-7.3zM224 96c106 0 192 86 192 192c0 17.7-14.3 32-32 32s-32-14.3-32-32c0-70.7-57.3-128-128-128c-17.7 0-32-14.3-32-32s14.3-32 32-32z\"]\n};\nconst faCircleUp = {\n prefix: 'fas',\n iconName: 'circle-up',\n icon: [512, 512, [61467, \"arrow-alt-circle-up\"], \"f35b\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zm11.3-395.3l112 112c4.6 4.6 5.9 11.5 3.5 17.4s-8.3 9.9-14.8 9.9l-64 0 0 96c0 17.7-14.3 32-32 32l-32 0c-17.7 0-32-14.3-32-32l0-96-64 0c-6.5 0-12.3-3.9-14.8-9.9s-1.1-12.9 3.5-17.4l112-112c6.2-6.2 16.4-6.2 22.6 0z\"]\n};\nconst faArrowAltCircleUp = faCircleUp;\nconst faMobileScreenButton = {\n prefix: 'fas',\n iconName: 'mobile-screen-button',\n icon: [384, 512, [\"mobile-alt\"], \"f3cd\", \"M16 64C16 28.7 44.7 0 80 0L304 0c35.3 0 64 28.7 64 64l0 384c0 35.3-28.7 64-64 64L80 512c-35.3 0-64-28.7-64-64L16 64zM224 448a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zM304 64L80 64l0 320 224 0 0-320z\"]\n};\nconst faMobileAlt = faMobileScreenButton;\nconst faVolumeHigh = {\n prefix: 'fas',\n iconName: 'volume-high',\n icon: [640, 512, [128266, \"volume-up\"], \"f028\", \"M533.6 32.5C598.5 85.2 640 165.8 640 256s-41.5 170.7-106.4 223.5c-10.3 8.4-25.4 6.8-33.8-3.5s-6.8-25.4 3.5-33.8C557.5 398.2 592 331.2 592 256s-34.5-142.2-88.7-186.3c-10.3-8.4-11.8-23.5-3.5-33.8s23.5-11.8 33.8-3.5zM473.1 107c43.2 35.2 70.9 88.9 70.9 149s-27.7 113.8-70.9 149c-10.3 8.4-25.4 6.8-33.8-3.5s-6.8-25.4 3.5-33.8C475.3 341.3 496 301.1 496 256s-20.7-85.3-53.2-111.8c-10.3-8.4-11.8-23.5-3.5-33.8s23.5-11.8 33.8-3.5zm-60.5 74.5C434.1 199.1 448 225.9 448 256s-13.9 56.9-35.4 74.5c-10.3 8.4-25.4 6.8-33.8-3.5s-6.8-25.4 3.5-33.8C393.1 284.4 400 271 400 256s-6.9-28.4-17.7-37.3c-10.3-8.4-11.8-23.5-3.5-33.8s23.5-11.8 33.8-3.5zM301.1 34.8C312.6 40 320 51.4 320 64l0 384c0 12.6-7.4 24-18.9 29.2s-25 3.1-34.4-5.3L131.8 352 64 352c-35.3 0-64-28.7-64-64l0-64c0-35.3 28.7-64 64-64l67.8 0L266.7 40.1c9.4-8.4 22.9-10.4 34.4-5.3z\"]\n};\nconst faVolumeUp = faVolumeHigh;\nconst faUsersRays = {\n prefix: 'fas',\n iconName: 'users-rays',\n icon: [640, 512, [], \"e593\", \"M41 7C31.6-2.3 16.4-2.3 7 7S-2.3 31.6 7 41l72 72c9.4 9.4 24.6 9.4 33.9 0s9.4-24.6 0-33.9L41 7zM599 7L527 79c-9.4 9.4-9.4 24.6 0 33.9s24.6 9.4 33.9 0l72-72c9.4-9.4 9.4-24.6 0-33.9s-24.6-9.4-33.9 0zM7 505c9.4 9.4 24.6 9.4 33.9 0l72-72c9.4-9.4 9.4-24.6 0-33.9s-24.6-9.4-33.9 0L7 471c-9.4 9.4-9.4 24.6 0 33.9zm592 0c9.4 9.4 24.6 9.4 33.9 0s9.4-24.6 0-33.9l-72-72c-9.4-9.4-24.6-9.4-33.9 0s-9.4 24.6 0 33.9l72 72zM320 256a64 64 0 1 0 0-128 64 64 0 1 0 0 128zM212.1 336c-2.7 7.5-4.1 15.6-4.1 24c0 13.3 10.7 24 24 24l176 0c13.3 0 24-10.7 24-24c0-8.4-1.4-16.5-4.1-24c-.5-1.4-1-2.7-1.6-4c-9.4-22.3-29.8-38.9-54.3-43c-3.9-.7-7.9-1-12-1l-80 0c-4.1 0-8.1 .3-12 1c-.8 .1-1.7 .3-2.5 .5c-24.9 5.1-45.1 23-53.4 46.5zM175.8 224a48 48 0 1 0 0-96 48 48 0 1 0 0 96zm-26.5 32C119.9 256 96 279.9 96 309.3c0 14.7 11.9 26.7 26.7 26.7l56.1 0c8-34.1 32.8-61.7 65.2-73.6c-7.5-4.1-16.2-6.4-25.3-6.4l-69.3 0zm368 80c14.7 0 26.7-11.9 26.7-26.7c0-29.5-23.9-53.3-53.3-53.3l-69.3 0c-9.2 0-17.8 2.3-25.3 6.4c32.4 11.9 57.2 39.5 65.2 73.6l56.1 0zM464 224a48 48 0 1 0 0-96 48 48 0 1 0 0 96z\"]\n};\nconst faWallet = {\n prefix: 'fas',\n iconName: 'wallet',\n icon: [512, 512, [], \"f555\", \"M64 32C28.7 32 0 60.7 0 96L0 416c0 35.3 28.7 64 64 64l384 0c35.3 0 64-28.7 64-64l0-224c0-35.3-28.7-64-64-64L80 128c-8.8 0-16-7.2-16-16s7.2-16 16-16l368 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L64 32zM416 272a32 32 0 1 1 0 64 32 32 0 1 1 0-64z\"]\n};\nconst faClipboardCheck = {\n prefix: 'fas',\n iconName: 'clipboard-check',\n icon: [384, 512, [], \"f46c\", \"M192 0c-41.8 0-77.4 26.7-90.5 64L64 64C28.7 64 0 92.7 0 128L0 448c0 35.3 28.7 64 64 64l256 0c35.3 0 64-28.7 64-64l0-320c0-35.3-28.7-64-64-64l-37.5 0C269.4 26.7 233.8 0 192 0zm0 64a32 32 0 1 1 0 64 32 32 0 1 1 0-64zM305 273L177 401c-9.4 9.4-24.6 9.4-33.9 0L79 337c-9.4-9.4-9.4-24.6 0-33.9s24.6-9.4 33.9 0l47 47L271 239c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9z\"]\n};\nconst faFileAudio = {\n prefix: 'fas',\n iconName: 'file-audio',\n icon: [384, 512, [], \"f1c7\", \"M64 0C28.7 0 0 28.7 0 64L0 448c0 35.3 28.7 64 64 64l256 0c35.3 0 64-28.7 64-64l0-288-128 0c-17.7 0-32-14.3-32-32L224 0 64 0zM256 0l0 128 128 0L256 0zm2 226.3c37.1 22.4 62 63.1 62 109.7s-24.9 87.3-62 109.7c-7.6 4.6-17.4 2.1-22-5.4s-2.1-17.4 5.4-22C269.4 401.5 288 370.9 288 336s-18.6-65.5-46.5-82.3c-7.6-4.6-10-14.4-5.4-22s14.4-10 22-5.4zm-91.9 30.9c6 2.5 9.9 8.3 9.9 14.8l0 128c0 6.5-3.9 12.3-9.9 14.8s-12.9 1.1-17.4-3.5L113.4 376 80 376c-8.8 0-16-7.2-16-16l0-48c0-8.8 7.2-16 16-16l33.4 0 35.3-35.3c4.6-4.6 11.5-5.9 17.4-3.5zm51 34.9c6.6-5.9 16.7-5.3 22.6 1.3C249.8 304.6 256 319.6 256 336s-6.2 31.4-16.3 42.7c-5.9 6.6-16 7.1-22.6 1.3s-7.1-16-1.3-22.6c5.1-5.7 8.1-13.1 8.1-21.3s-3.1-15.7-8.1-21.3c-5.9-6.6-5.3-16.7 1.3-22.6z\"]\n};\nconst faBurger = {\n prefix: 'fas',\n iconName: 'burger',\n icon: [512, 512, [\"hamburger\"], \"f805\", \"M61.1 224C45 224 32 211 32 194.9c0-1.9 .2-3.7 .6-5.6C37.9 168.3 78.8 32 256 32s218.1 136.3 223.4 157.3c.5 1.9 .6 3.7 .6 5.6c0 16.1-13 29.1-29.1 29.1L61.1 224zM144 128a16 16 0 1 0 -32 0 16 16 0 1 0 32 0zm240 16a16 16 0 1 0 0-32 16 16 0 1 0 0 32zM272 96a16 16 0 1 0 -32 0 16 16 0 1 0 32 0zM16 304c0-26.5 21.5-48 48-48l384 0c26.5 0 48 21.5 48 48s-21.5 48-48 48L64 352c-26.5 0-48-21.5-48-48zm16 96c0-8.8 7.2-16 16-16l416 0c8.8 0 16 7.2 16 16l0 16c0 35.3-28.7 64-64 64L96 480c-35.3 0-64-28.7-64-64l0-16z\"]\n};\nconst faHamburger = faBurger;\nconst faWrench = {\n prefix: 'fas',\n iconName: 'wrench',\n icon: [512, 512, [128295], \"f0ad\", \"M352 320c88.4 0 160-71.6 160-160c0-15.3-2.2-30.1-6.2-44.2c-3.1-10.8-16.4-13.2-24.3-5.3l-76.8 76.8c-3 3-7.1 4.7-11.3 4.7L336 192c-8.8 0-16-7.2-16-16l0-57.4c0-4.2 1.7-8.3 4.7-11.3l76.8-76.8c7.9-7.9 5.4-21.2-5.3-24.3C382.1 2.2 367.3 0 352 0C263.6 0 192 71.6 192 160c0 19.1 3.4 37.5 9.5 54.5L19.9 396.1C7.2 408.8 0 426.1 0 444.1C0 481.6 30.4 512 67.9 512c18 0 35.3-7.2 48-19.9L297.5 310.5c17 6.2 35.4 9.5 54.5 9.5zM80 408a24 24 0 1 1 0 48 24 24 0 1 1 0-48z\"]\n};\nconst faBugs = {\n prefix: 'fas',\n iconName: 'bugs',\n icon: [576, 512, [], \"e4d0\", \"M164.5 107.4l33.4-73.5c5.5-12.1 .1-26.3-11.9-31.8s-26.3-.1-31.8 11.9L128 71.7 101.9 14.1C96.4 2 82.1-3.3 70.1 2.1S52.7 21.9 58.1 33.9l33.4 73.5c-10.2 7.1-18.2 17-22.9 28.6l-17 0-4.1-20.7c-2.6-13-15.2-21.4-28.2-18.8S-2.1 111.7 .5 124.7l8 40C10.7 175.9 20.6 184 32 184l32 0 0 23.3-37.8 9.5c-9.5 2.4-16.6 10.2-17.9 19.9l-8 56c-1.9 13.1 7.2 25.3 20.4 27.2s25.3-7.2 27.2-20.4l5.7-40 18.4-4.6C82.7 274.6 103.8 288 128 288s45.3-13.4 56.1-33.2l18.4 4.6 5.7 40c1.9 13.1 14 22.2 27.2 20.4s22.2-14 20.4-27.2l-8-56c-1.4-9.7-8.5-17.5-17.9-19.9L192 207.3l0-23.3 32 0c11.4 0 21.3-8.1 23.5-19.3l8-40c2.6-13-5.8-25.6-18.8-28.2s-25.6 5.8-28.2 18.8L204.3 136l-17 0c-4.7-11.6-12.7-21.5-22.9-28.6zM496 286.5l65.6-47c10.8-7.7 13.3-22.7 5.6-33.5s-22.7-13.3-33.5-5.6l-51.4 36.8 6.1-62.9c1.3-13.2-8.4-24.9-21.6-26.2s-24.9 8.4-26.2 21.6L432.8 250c-12.3 1-24.2 5.6-34.1 13.3L384 254.8l6.8-20c4.2-12.6-2.5-26.2-15-30.4s-26.2 2.5-30.4 15l-13.1 38.6c-3.7 10.8 .8 22.8 10.7 28.5l27.7 16L359 322.7 321.5 312c-9.4-2.7-19.5 .6-25.5 8.3l-34.9 44.5c-8.2 10.4-6.4 25.5 4.1 33.7s25.5 6.4 33.7-4.1l25-31.8 18.2 5.2c-.5 22.6 11 44.7 32 56.8s45.9 11 65.2-.7l13.6 13.2-15.1 37.5c-4.9 12.3 1 26.3 13.3 31.2s26.3-1 31.2-13.3L503.5 440c3.6-9.1 1.4-19.4-5.6-26.2l-28-27.1 11.6-20.1 27.7 16c9.9 5.7 22.5 3.7 30-4.9L566.2 347c8.7-10 7.8-25.1-2.2-33.9s-25.1-7.8-33.9 2.2l-13.9 15.9-14.7-8.5c1.7-12.4-.2-25-5.5-36.2z\"]\n};\nconst faRupeeSign = {\n prefix: 'fas',\n iconName: 'rupee-sign',\n icon: [448, 512, [8360, \"rupee\"], \"f156\", \"M0 64C0 46.3 14.3 32 32 32l80 0c79.5 0 144 64.5 144 144c0 58.8-35.2 109.3-85.7 131.7l51.4 128.4c6.6 16.4-1.4 35-17.8 41.6s-35-1.4-41.6-17.8L106.3 320 64 320l0 128c0 17.7-14.3 32-32 32s-32-14.3-32-32L0 288 0 64zM64 256l48 0c44.2 0 80-35.8 80-80s-35.8-80-80-80L64 96l0 160zm256.5 16.4c-.9 6 0 8.7 .4 9.8c.4 1.1 1.4 2.6 4.2 4.9c7.2 5.7 18.7 10 37.9 16.8l1.3 .5c16 5.6 38.7 13.6 55.7 28.1c9.5 8.1 17.9 18.6 23.1 32.3c5.1 13.7 6.1 28.5 3.8 44c-4.2 28.1-20.5 49.3-43.8 60.9c-22.1 11-48.1 12.5-73.2 8l-.2 0s0 0 0 0c-9.3-1.8-20.5-5.7-29.3-9c-6-2.3-12.6-4.9-17.7-6.9c0 0 0 0 0 0c-2.5-1-4.6-1.8-6.3-2.5c-16.5-6.4-24.6-25-18.2-41.4s24.9-24.6 41.4-18.2c2.6 1 5.2 2 7.9 3.1c0 0 0 0 0 0c4.8 1.9 9.8 3.9 15.4 6c8.8 3.3 15.3 5.4 18.7 6c15.7 2.8 26.7 .8 32.9-2.3c5-2.5 8-6 9.1-13c1-6.9 .2-10.5-.5-12.3c-.6-1.7-1.8-3.6-4.5-5.9c-6.9-5.8-18.2-10.4-36.9-17l-3-1.1c-15.5-5.4-37-13-53.3-25.9c-9.5-7.5-18.3-17.6-23.7-31c-5.5-13.4-6.6-28-4.4-43.2c8.4-57.1 67-78 116.9-68.9c6.9 1.3 27.3 5.8 35.4 8.4c16.9 5.2 26.3 23.2 21.1 40.1s-23.2 26.3-40.1 21.1c-4.7-1.4-22.3-5.5-27.9-6.5c-14.6-2.7-25.8-.4-32.6 3.2c-6.3 3.3-8.9 7.6-9.5 12z\"]\n};\nconst faRupee = faRupeeSign;\nconst faFileImage = {\n prefix: 'fas',\n iconName: 'file-image',\n icon: [384, 512, [128443], \"f1c5\", \"M64 0C28.7 0 0 28.7 0 64L0 448c0 35.3 28.7 64 64 64l256 0c35.3 0 64-28.7 64-64l0-288-128 0c-17.7 0-32-14.3-32-32L224 0 64 0zM256 0l0 128 128 0L256 0zM64 256a32 32 0 1 1 64 0 32 32 0 1 1 -64 0zm152 32c5.3 0 10.2 2.6 13.2 6.9l88 128c3.4 4.9 3.7 11.3 1 16.5s-8.2 8.6-14.2 8.6l-88 0-40 0-48 0-48 0c-5.8 0-11.1-3.1-13.9-8.1s-2.8-11.2 .2-16.1l48-80c2.9-4.8 8.1-7.8 13.7-7.8s10.8 2.9 13.7 7.8l12.8 21.4 48.3-70.2c3-4.3 7.9-6.9 13.2-6.9z\"]\n};\nconst faCircleQuestion = {\n prefix: 'fas',\n iconName: 'circle-question',\n icon: [512, 512, [62108, \"question-circle\"], \"f059\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM169.8 165.3c7.9-22.3 29.1-37.3 52.8-37.3l58.3 0c34.9 0 63.1 28.3 63.1 63.1c0 22.6-12.1 43.5-31.7 54.8L280 264.4c-.2 13-10.9 23.6-24 23.6c-13.3 0-24-10.7-24-24l0-13.5c0-8.6 4.6-16.5 12.1-20.8l44.3-25.4c4.7-2.7 7.6-7.7 7.6-13.1c0-8.4-6.8-15.1-15.1-15.1l-58.3 0c-3.4 0-6.4 2.1-7.5 5.3l-.4 1.2c-4.4 12.5-18.2 19-30.6 14.6s-19-18.2-14.6-30.6l.4-1.2zM224 352a32 32 0 1 1 64 0 32 32 0 1 1 -64 0z\"]\n};\nconst faQuestionCircle = faCircleQuestion;\nconst faPlaneDeparture = {\n prefix: 'fas',\n iconName: 'plane-departure',\n icon: [640, 512, [128747], \"f5b0\", \"M381 114.9L186.1 41.8c-16.7-6.2-35.2-5.3-51.1 2.7L89.1 67.4C78 73 77.2 88.5 87.6 95.2l146.9 94.5L136 240 77.8 214.1c-8.7-3.9-18.8-3.7-27.3 .6L18.3 230.8c-9.3 4.7-11.8 16.8-5 24.7l73.1 85.3c6.1 7.1 15 11.2 24.3 11.2l137.7 0c5 0 9.9-1.2 14.3-3.4L535.6 212.2c46.5-23.3 82.5-63.3 100.8-112C645.9 75 627.2 48 600.2 48l-57.4 0c-20.2 0-40.2 4.8-58.2 14L381 114.9zM0 480c0 17.7 14.3 32 32 32l576 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L32 448c-17.7 0-32 14.3-32 32z\"]\n};\nconst faHandshakeSlash = {\n prefix: 'fas',\n iconName: 'handshake-slash',\n icon: [640, 512, [], \"e060\", \"M38.8 5.1C28.4-3.1 13.3-1.2 5.1 9.2S-1.2 34.7 9.2 42.9l592 464c10.4 8.2 25.5 6.3 33.7-4.1s6.3-25.5-4.1-33.7l-135-105.8c-1.1-11.4-6.3-22.3-15.3-30.7l-134.2-123-23.4 18.2-26-20.3 77.2-60.1c7-5.4 17-4.2 22.5 2.8s4.2 17-2.8 22.5l-20.9 16.2L512 316.8 512 128l-.7 0-3.9-2.5L434.8 79c-15.3-9.8-33.2-15-51.4-15c-21.8 0-43 7.5-60 21.2l-89.7 72.6-25.8-20.3 81.8-66.2c-11.6-4.9-24.1-7.4-36.8-7.4C234 64 215.7 69.6 200 80l-35.5 23.7L38.8 5.1zM96 171.6L40.6 128 0 128 0 352c0 17.7 14.3 32 32 32l32 0c17.7 0 32-14.3 32-32l0-180.4zM413.6 421.9L128 196.9 128 352l28.2 0 91.4 83.4c19.6 17.9 49.9 16.5 67.8-3.1c5.5-6.1 9.2-13.2 11.1-20.6l17 15.6c19.5 17.9 49.9 16.6 67.8-2.9c.8-.8 1.5-1.7 2.2-2.6zM48 320a16 16 0 1 1 0 32 16 16 0 1 1 0-32zM544 128l0 224c0 17.7 14.3 32 32 32l32 0c17.7 0 32-14.3 32-32l0-224-96 0zm32 208a16 16 0 1 1 32 0 16 16 0 1 1 -32 0z\"]\n};\nconst faBookBookmark = {\n prefix: 'fas',\n iconName: 'book-bookmark',\n icon: [448, 512, [], \"e0bb\", \"M0 96C0 43 43 0 96 0l96 0 0 190.7c0 13.4 15.5 20.9 26 12.5L272 160l54 43.2c10.5 8.4 26 .9 26-12.5L352 0l32 0 32 0c17.7 0 32 14.3 32 32l0 320c0 17.7-14.3 32-32 32l0 64c17.7 0 32 14.3 32 32s-14.3 32-32 32l-32 0L96 512c-53 0-96-43-96-96L0 96zM64 416c0 17.7 14.3 32 32 32l256 0 0-64L96 384c-17.7 0-32 14.3-32 32z\"]\n};\nconst faCodeBranch = {\n prefix: 'fas',\n iconName: 'code-branch',\n icon: [448, 512, [], \"f126\", \"M80 104a24 24 0 1 0 0-48 24 24 0 1 0 0 48zm80-24c0 32.8-19.7 61-48 73.3l0 87.8c18.8-10.9 40.7-17.1 64-17.1l96 0c35.3 0 64-28.7 64-64l0-6.7C307.7 141 288 112.8 288 80c0-44.2 35.8-80 80-80s80 35.8 80 80c0 32.8-19.7 61-48 73.3l0 6.7c0 70.7-57.3 128-128 128l-96 0c-35.3 0-64 28.7-64 64l0 6.7c28.3 12.3 48 40.5 48 73.3c0 44.2-35.8 80-80 80s-80-35.8-80-80c0-32.8 19.7-61 48-73.3l0-6.7 0-198.7C19.7 141 0 112.8 0 80C0 35.8 35.8 0 80 0s80 35.8 80 80zm232 0a24 24 0 1 0 -48 0 24 24 0 1 0 48 0zM80 456a24 24 0 1 0 0-48 24 24 0 1 0 0 48z\"]\n};\nconst faHatCowboy = {\n prefix: 'fas',\n iconName: 'hat-cowboy',\n icon: [640, 512, [], \"f8c0\", \"M320 64c14.4 0 22.3-7 30.8-14.4C360.4 41.1 370.7 32 392 32c49.3 0 84.4 152.2 97.9 221.9C447.8 272.1 390.9 288 320 288s-127.8-15.9-169.9-34.1C163.6 184.2 198.7 32 248 32c21.3 0 31.6 9.1 41.2 17.6C297.7 57 305.6 64 320 64zM111.1 270.7c47.2 24.5 117.5 49.3 209 49.3s161.8-24.8 208.9-49.3c24.8-12.9 49.8-28.3 70.1-47.7c7.9-7.9 20.2-9.2 29.6-3.3c9.5 5.9 13.5 17.9 9.9 28.5c-13.5 37.7-38.4 72.3-66.1 100.6C523.7 398.9 443.6 448 320 448s-203.6-49.1-252.5-99.2C39.8 320.4 14.9 285.8 1.4 248.1c-3.6-10.6 .4-22.6 9.9-28.5c9.5-5.9 21.7-4.5 29.6 3.3c20.4 19.4 45.3 34.8 70.1 47.7z\"]\n};\nconst faBridge = {\n prefix: 'fas',\n iconName: 'bridge',\n icon: [576, 512, [], \"e4c8\", \"M32 32C14.3 32 0 46.3 0 64S14.3 96 32 96l40 0 0 64L0 160 0 288c53 0 96 43 96 96l0 64c0 17.7 14.3 32 32 32l32 0c17.7 0 32-14.3 32-32l0-64c0-53 43-96 96-96s96 43 96 96l0 64c0 17.7 14.3 32 32 32l32 0c17.7 0 32-14.3 32-32l0-64c0-53 43-96 96-96l0-128-72 0 0-64 40 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L32 32zM456 96l0 64-80 0 0-64 80 0zM328 96l0 64-80 0 0-64 80 0zM200 96l0 64-80 0 0-64 80 0z\"]\n};\nconst faPhoneFlip = {\n prefix: 'fas',\n iconName: 'phone-flip',\n icon: [512, 512, [128381, \"phone-alt\"], \"f879\", \"M347.1 24.6c7.7-18.6 28-28.5 47.4-23.2l88 24C499.9 30.2 512 46 512 64c0 247.4-200.6 448-448 448c-18 0-33.8-12.1-38.6-29.5l-24-88c-5.3-19.4 4.6-39.7 23.2-47.4l96-40c16.3-6.8 35.2-2.1 46.3 11.6L207.3 368c70.4-33.3 127.4-90.3 160.7-160.7L318.7 167c-13.7-11.2-18.4-30-11.6-46.3l40-96z\"]\n};\nconst faPhoneAlt = faPhoneFlip;\nconst faTruckFront = {\n prefix: 'fas',\n iconName: 'truck-front',\n icon: [512, 512, [], \"e2b7\", \"M0 80C0 35.8 35.8 0 80 0L432 0c44.2 0 80 35.8 80 80l0 288c0 26.2-12.6 49.4-32 64l0 48c0 17.7-14.3 32-32 32l-32 0c-17.7 0-32-14.3-32-32l0-32-256 0 0 32c0 17.7-14.3 32-32 32l-32 0c-17.7 0-32-14.3-32-32l0-48C12.6 417.4 0 394.2 0 368L0 80zm129.9 72.2L112 224l288 0-17.9-71.8C378.5 138 365.7 128 351 128l-190 0c-14.7 0-27.5 10-31 24.2zM128 320a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zm288 32a32 32 0 1 0 0-64 32 32 0 1 0 0 64z\"]\n};\nconst faCat = {\n prefix: 'fas',\n iconName: 'cat',\n icon: [576, 512, [128008], \"f6be\", \"M320 192l17.1 0c22.1 38.3 63.5 64 110.9 64c11 0 21.8-1.4 32-4l0 4 0 32 0 192c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-140.8L280 448l56 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-144 0c-53 0-96-43-96-96l0-223.5c0-16.1-12-29.8-28-31.8l-7.9-1c-17.5-2.2-30-18.2-27.8-35.7s18.2-30 35.7-27.8l7.9 1c48 6 84.1 46.8 84.1 95.3l0 85.3c34.4-51.7 93.2-85.8 160-85.8zm160 26.5s0 0 0 0c-10 3.5-20.8 5.5-32 5.5c-28.4 0-54-12.4-71.6-32c0 0 0 0 0 0c-3.7-4.1-7-8.5-9.9-13.2C357.3 164 352 146.6 352 128c0 0 0 0 0 0l0-96 0-20 0-1.3C352 4.8 356.7 .1 362.6 0l.2 0c3.3 0 6.4 1.6 8.4 4.2c0 0 0 0 0 .1L384 21.3l27.2 36.3L416 64l64 0 4.8-6.4L512 21.3 524.8 4.3c0 0 0 0 0-.1c2-2.6 5.1-4.2 8.4-4.2l.2 0C539.3 .1 544 4.8 544 10.7l0 1.3 0 20 0 96c0 17.3-4.6 33.6-12.6 47.6c-11.3 19.8-29.6 35.2-51.4 42.9zM432 128a16 16 0 1 0 -32 0 16 16 0 1 0 32 0zm48 16a16 16 0 1 0 0-32 16 16 0 1 0 0 32z\"]\n};\nconst faAnchorCircleExclamation = {\n prefix: 'fas',\n iconName: 'anchor-circle-exclamation',\n icon: [640, 512, [], \"e4ab\", \"M320 96a32 32 0 1 1 -64 0 32 32 0 1 1 64 0zm21.1 80C367 158.8 384 129.4 384 96c0-53-43-96-96-96s-96 43-96 96c0 33.4 17 62.8 42.9 80L224 176c-17.7 0-32 14.3-32 32s14.3 32 32 32l32 0 0 208-48 0c-53 0-96-43-96-96l0-6.1 7 7c9.4 9.4 24.6 9.4 33.9 0s9.4-24.6 0-33.9L97 263c-9.4-9.4-24.6-9.4-33.9 0L7 319c-9.4 9.4-9.4 24.6 0 33.9s24.6 9.4 33.9 0l7-7 0 6.1c0 88.4 71.6 160 160 160l80 0 80 0c8.2 0 16.3-.6 24.2-1.8c-22.2-16.2-40.4-37.5-53-62.2L320 448l0-80 0-128 32 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-10.9 0zM496 512a144 144 0 1 0 0-288 144 144 0 1 0 0 288zm0-96a24 24 0 1 1 0 48 24 24 0 1 1 0-48zm0-144c8.8 0 16 7.2 16 16l0 80c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-80c0-8.8 7.2-16 16-16z\"]\n};\nconst faTruckField = {\n prefix: 'fas',\n iconName: 'truck-field',\n icon: [640, 512, [], \"e58d\", \"M32 96c0-35.3 28.7-64 64-64l224 0c23.7 0 44.4 12.9 55.4 32l51.8 0c25.3 0 48.2 14.9 58.5 38l52.8 118.8c.5 1.1 .9 2.1 1.3 3.2l4.2 0c35.3 0 64 28.7 64 64l0 32c17.7 0 32 14.3 32 32s-14.3 32-32 32l-32 0c0 53-43 96-96 96s-96-43-96-96l-128 0c0 53-43 96-96 96s-96-43-96-96l-32 0c-17.7 0-32-14.3-32-32s14.3-32 32-32l0-32c-17.7 0-32-14.3-32-32l0-96c0-17.7 14.3-32 32-32l0-32zM384 224l85.9 0-42.7-96L384 128l0 96zM160 432a48 48 0 1 0 0-96 48 48 0 1 0 0 96zm368-48a48 48 0 1 0 -96 0 48 48 0 1 0 96 0z\"]\n};\nconst faRoute = {\n prefix: 'fas',\n iconName: 'route',\n icon: [512, 512, [], \"f4d7\", \"M512 96c0 50.2-59.1 125.1-84.6 155c-3.8 4.4-9.4 6.1-14.5 5L320 256c-17.7 0-32 14.3-32 32s14.3 32 32 32l96 0c53 0 96 43 96 96s-43 96-96 96l-276.4 0c8.7-9.9 19.3-22.6 30-36.8c6.3-8.4 12.8-17.6 19-27.2L416 448c17.7 0 32-14.3 32-32s-14.3-32-32-32l-96 0c-53 0-96-43-96-96s43-96 96-96l39.8 0c-21-31.5-39.8-67.7-39.8-96c0-53 43-96 96-96s96 43 96 96zM117.1 489.1c-3.8 4.3-7.2 8.1-10.1 11.3l-1.8 2-.2-.2c-6 4.6-14.6 4-20-1.8C59.8 473 0 402.5 0 352c0-53 43-96 96-96s96 43 96 96c0 30-21.1 67-43.5 97.9c-10.7 14.7-21.7 28-30.8 38.5l-.6 .7zM128 352a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zM416 128a32 32 0 1 0 0-64 32 32 0 1 0 0 64z\"]\n};\nconst faClipboardQuestion = {\n prefix: 'fas',\n iconName: 'clipboard-question',\n icon: [384, 512, [], \"e4e3\", \"M192 0c-41.8 0-77.4 26.7-90.5 64L64 64C28.7 64 0 92.7 0 128L0 448c0 35.3 28.7 64 64 64l256 0c35.3 0 64-28.7 64-64l0-320c0-35.3-28.7-64-64-64l-37.5 0C269.4 26.7 233.8 0 192 0zm0 64a32 32 0 1 1 0 64 32 32 0 1 1 0-64zM105.8 229.3c7.9-22.3 29.1-37.3 52.8-37.3l58.3 0c34.9 0 63.1 28.3 63.1 63.1c0 22.6-12.1 43.5-31.7 54.8L216 328.4c-.2 13-10.9 23.6-24 23.6c-13.3 0-24-10.7-24-24l0-13.5c0-8.6 4.6-16.5 12.1-20.8l44.3-25.4c4.7-2.7 7.6-7.7 7.6-13.1c0-8.4-6.8-15.1-15.1-15.1l-58.3 0c-3.4 0-6.4 2.1-7.5 5.3l-.4 1.2c-4.4 12.5-18.2 19-30.6 14.6s-19-18.2-14.6-30.6l.4-1.2zM160 416a32 32 0 1 1 64 0 32 32 0 1 1 -64 0z\"]\n};\nconst faPanorama = {\n prefix: 'fas',\n iconName: 'panorama',\n icon: [640, 512, [], \"e209\", \"M45.6 32C20.4 32 0 52.4 0 77.6L0 434.4C0 459.6 20.4 480 45.6 480c5.1 0 10-.8 14.7-2.4C74.6 472.8 177.6 440 320 440s245.4 32.8 259.6 37.6c4.7 1.6 9.7 2.4 14.7 2.4c25.2 0 45.6-20.4 45.6-45.6l0-356.7C640 52.4 619.6 32 594.4 32c-5 0-10 .8-14.7 2.4C565.4 39.2 462.4 72 320 72S74.6 39.2 60.4 34.4C55.6 32.8 50.7 32 45.6 32zM96 160a32 32 0 1 1 64 0 32 32 0 1 1 -64 0zm272 0c7.9 0 15.4 3.9 19.8 10.5L512.3 353c5.4 8 5.6 18.4 .4 26.5s-14.7 12.3-24.2 10.7C442.7 382.4 385.2 376 320 376c-65.6 0-123.4 6.5-169.3 14.4c-9.8 1.7-19.7-2.9-24.7-11.5s-4.3-19.4 1.9-27.2L197.3 265c4.6-5.7 11.4-9 18.7-9s14.2 3.3 18.7 9l26.4 33.1 87-127.6c4.5-6.6 11.9-10.5 19.8-10.5z\"]\n};\nconst faCommentMedical = {\n prefix: 'fas',\n iconName: 'comment-medical',\n icon: [512, 512, [], \"f7f5\", \"M256 448c141.4 0 256-93.1 256-208S397.4 32 256 32S0 125.1 0 240c0 45.1 17.7 86.8 47.7 120.9c-1.9 24.5-11.4 46.3-21.4 62.9c-5.5 9.2-11.1 16.6-15.2 21.6c-2.1 2.5-3.7 4.4-4.9 5.7c-.6 .6-1 1.1-1.3 1.4l-.3 .3c0 0 0 0 0 0c0 0 0 0 0 0s0 0 0 0s0 0 0 0c-4.6 4.6-5.9 11.4-3.4 17.4c2.5 6 8.3 9.9 14.8 9.9c28.7 0 57.6-8.9 81.6-19.3c22.9-10 42.4-21.9 54.3-30.6c31.8 11.5 67 17.9 104.1 17.9zM224 160c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 48 48 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-48 0 0 48c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-48-48 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16l48 0 0-48z\"]\n};\nconst faTeethOpen = {\n prefix: 'fas',\n iconName: 'teeth-open',\n icon: [576, 512, [], \"f62f\", \"M96 32C43 32 0 75 0 128l0 64c0 35.3 28.7 64 64 64l448 0c35.3 0 64-28.7 64-64l0-64c0-53-43-96-96-96L96 32zM224 96c26.5 0 48 21.5 48 48l0 56c0 13.3-10.7 24-24 24l-48 0c-13.3 0-24-10.7-24-24l0-56c0-26.5 21.5-48 48-48zm80 48c0-26.5 21.5-48 48-48s48 21.5 48 48l0 56c0 13.3-10.7 24-24 24l-48 0c-13.3 0-24-10.7-24-24l0-56zM96 128c26.5 0 48 21.5 48 48l0 24c0 13.3-10.7 24-24 24l-48 0c-13.3 0-24-10.7-24-24l0-24c0-26.5 21.5-48 48-48zm336 48c0-26.5 21.5-48 48-48s48 21.5 48 48l0 24c0 13.3-10.7 24-24 24l-48 0c-13.3 0-24-10.7-24-24l0-24zM96 480l384 0c53 0 96-43 96-96l0-32c0-35.3-28.7-64-64-64L64 288c-35.3 0-64 28.7-64 64l0 32c0 53 43 96 96 96zm0-64c-26.5 0-48-21.5-48-48l0-24c0-13.3 10.7-24 24-24l48 0c13.3 0 24 10.7 24 24l0 24c0 26.5-21.5 48-48 48zm80-48l0-24c0-13.3 10.7-24 24-24l48 0c13.3 0 24 10.7 24 24l0 24c0 26.5-21.5 48-48 48s-48-21.5-48-48zm176 48c-26.5 0-48-21.5-48-48l0-24c0-13.3 10.7-24 24-24l48 0c13.3 0 24 10.7 24 24l0 24c0 26.5-21.5 48-48 48zm80-48l0-24c0-13.3 10.7-24 24-24l48 0c13.3 0 24 10.7 24 24l0 24c0 26.5-21.5 48-48 48s-48-21.5-48-48z\"]\n};\nconst faFileCircleMinus = {\n prefix: 'fas',\n iconName: 'file-circle-minus',\n icon: [576, 512, [], \"e4ed\", \"M0 64C0 28.7 28.7 0 64 0L224 0l0 128c0 17.7 14.3 32 32 32l128 0 0 38.6C310.1 219.5 256 287.4 256 368c0 59.1 29.1 111.3 73.7 143.3c-3.2 .5-6.4 .7-9.7 .7L64 512c-35.3 0-64-28.7-64-64L0 64zm384 64l-128 0L256 0 384 128zM288 368a144 144 0 1 1 288 0 144 144 0 1 1 -288 0zm224 0c0-8.8-7.2-16-16-16l-128 0c-8.8 0-16 7.2-16 16s7.2 16 16 16l128 0c8.8 0 16-7.2 16-16z\"]\n};\nconst faTags = {\n prefix: 'fas',\n iconName: 'tags',\n icon: [512, 512, [], \"f02c\", \"M345 39.1L472.8 168.4c52.4 53 52.4 138.2 0 191.2L360.8 472.9c-9.3 9.4-24.5 9.5-33.9 .2s-9.5-24.5-.2-33.9L438.6 325.9c33.9-34.3 33.9-89.4 0-123.7L310.9 72.9c-9.3-9.4-9.2-24.6 .2-33.9s24.6-9.2 33.9 .2zM0 229.5L0 80C0 53.5 21.5 32 48 32l149.5 0c17 0 33.3 6.7 45.3 18.7l168 168c25 25 25 65.5 0 90.5L277.3 442.7c-25 25-65.5 25-90.5 0l-168-168C6.7 262.7 0 246.5 0 229.5zM144 144a32 32 0 1 0 -64 0 32 32 0 1 0 64 0z\"]\n};\nconst faWineGlass = {\n prefix: 'fas',\n iconName: 'wine-glass',\n icon: [320, 512, [127863], \"f4e3\", \"M32.1 29.3C33.5 12.8 47.4 0 64 0L256 0c16.6 0 30.5 12.8 31.9 29.3l14 168.4c6 72-42.5 135.2-109.9 150.6l0 99.6 48 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-80 0-80 0c-17.7 0-32-14.3-32-32s14.3-32 32-32l48 0 0-99.6C60.6 333 12.1 269.8 18.1 197.8l14-168.4zm56 98.7l143.8 0-5.3-64L93.4 64l-5.3 64z\"]\n};\nconst faForwardFast = {\n prefix: 'fas',\n iconName: 'forward-fast',\n icon: [512, 512, [9197, \"fast-forward\"], \"f050\", \"M18.4 445c11.2 5.3 24.5 3.6 34.1-4.4L224 297.7 224 416c0 12.4 7.2 23.7 18.4 29s24.5 3.6 34.1-4.4L448 297.7 448 416c0 17.7 14.3 32 32 32s32-14.3 32-32l0-320c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 118.3L276.5 71.4c-9.5-7.9-22.8-9.7-34.1-4.4S224 83.6 224 96l0 118.3L52.5 71.4c-9.5-7.9-22.8-9.7-34.1-4.4S0 83.6 0 96L0 416c0 12.4 7.2 23.7 18.4 29z\"]\n};\nconst faFastForward = faForwardFast;\nconst faFaceMehBlank = {\n prefix: 'fas',\n iconName: 'face-meh-blank',\n icon: [512, 512, [128566, \"meh-blank\"], \"f5a4\", \"M0 256a256 256 0 1 1 512 0A256 256 0 1 1 0 256zm208.4-48a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zm128 32a32 32 0 1 0 0-64 32 32 0 1 0 0 64z\"]\n};\nconst faMehBlank = faFaceMehBlank;\nconst faSquareParking = {\n prefix: 'fas',\n iconName: 'square-parking',\n icon: [448, 512, [127359, \"parking\"], \"f540\", \"M64 32C28.7 32 0 60.7 0 96L0 416c0 35.3 28.7 64 64 64l320 0c35.3 0 64-28.7 64-64l0-320c0-35.3-28.7-64-64-64L64 32zM192 256l48 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-48 0 0 64zm48 64l-48 0 0 32c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-64 0-120c0-22.1 17.9-40 40-40l72 0c53 0 96 43 96 96s-43 96-96 96z\"]\n};\nconst faParking = faSquareParking;\nconst faHouseSignal = {\n prefix: 'fas',\n iconName: 'house-signal',\n icon: [576, 512, [], \"e012\", \"M357.7 8.5c-12.3-11.3-31.2-11.3-43.4 0l-208 192c-9.4 8.6-12.7 22-8.5 34c87.1 25.3 155.6 94.2 180.3 181.6L464 416c26.5 0 48-21.5 48-48l0-112 32 0c13.2 0 25-8.1 29.8-20.3s1.6-26.2-8.1-35.2l-208-192zM288 208c0-8.8 7.2-16 16-16l64 0c8.8 0 16 7.2 16 16l0 64c0 8.8-7.2 16-16 16l-64 0c-8.8 0-16-7.2-16-16l0-64zM24 256c-13.3 0-24 10.7-24 24s10.7 24 24 24c101.6 0 184 82.4 184 184c0 13.3 10.7 24 24 24s24-10.7 24-24c0-128.1-103.9-232-232-232zm8 256a32 32 0 1 0 0-64 32 32 0 1 0 0 64zM0 376c0 13.3 10.7 24 24 24c48.6 0 88 39.4 88 88c0 13.3 10.7 24 24 24s24-10.7 24-24c0-75.1-60.9-136-136-136c-13.3 0-24 10.7-24 24z\"]\n};\nconst faBarsProgress = {\n prefix: 'fas',\n iconName: 'bars-progress',\n icon: [512, 512, [\"tasks-alt\"], \"f828\", \"M448 160l-128 0 0-32 128 0 0 32zM48 64C21.5 64 0 85.5 0 112l0 64c0 26.5 21.5 48 48 48l416 0c26.5 0 48-21.5 48-48l0-64c0-26.5-21.5-48-48-48L48 64zM448 352l0 32-256 0 0-32 256 0zM48 288c-26.5 0-48 21.5-48 48l0 64c0 26.5 21.5 48 48 48l416 0c26.5 0 48-21.5 48-48l0-64c0-26.5-21.5-48-48-48L48 288z\"]\n};\nconst faTasksAlt = faBarsProgress;\nconst faFaucetDrip = {\n prefix: 'fas',\n iconName: 'faucet-drip',\n icon: [512, 512, [128688], \"e006\", \"M224 0c17.7 0 32 14.3 32 32l0 12 96-12c17.7 0 32 14.3 32 32s-14.3 32-32 32L256 84l-31-3.9-1-.1-1 .1L192 84 96 96C78.3 96 64 81.7 64 64s14.3-32 32-32l96 12 0-12c0-17.7 14.3-32 32-32zM0 224c0-17.7 14.3-32 32-32l96 0 22.6-22.6c6-6 14.1-9.4 22.6-9.4l18.7 0 0-43.8 32-4 32 4 0 43.8 18.7 0c8.5 0 16.6 3.4 22.6 9.4L320 192l32 0c88.4 0 160 71.6 160 160c0 17.7-14.3 32-32 32l-64 0c-17.7 0-32-14.3-32-32s-14.3-32-32-32l-36.1 0c-20.2 29-53.9 48-91.9 48s-71.7-19-91.9-48L32 320c-17.7 0-32-14.3-32-32l0-64zM436.8 423.4c1.9-4.5 6.3-7.4 11.2-7.4s9.2 2.9 11.2 7.4l18.2 42.4c1.8 4.1 2.7 8.6 2.7 13.1l0 1.2c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-1.2c0-4.5 .9-8.9 2.7-13.1l18.2-42.4z\"]\n};\nconst faCartFlatbed = {\n prefix: 'fas',\n iconName: 'cart-flatbed',\n icon: [640, 512, [\"dolly-flatbed\"], \"f474\", \"M32 0C14.3 0 0 14.3 0 32S14.3 64 32 64l16 0c8.8 0 16 7.2 16 16l0 288c0 44.2 35.8 80 80 80l18.7 0c-1.8 5-2.7 10.4-2.7 16c0 26.5 21.5 48 48 48s48-21.5 48-48c0-5.6-1-11-2.7-16l197.5 0c-1.8 5-2.7 10.4-2.7 16c0 26.5 21.5 48 48 48s48-21.5 48-48c0-5.6-1-11-2.7-16l66.7 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-464 0c-8.8 0-16-7.2-16-16l0-288C128 35.8 92.2 0 48 0L32 0zM192 80l0 192c0 26.5 21.5 48 48 48l320 0c26.5 0 48-21.5 48-48l0-192c0-26.5-21.5-48-48-48l-96 0 0 144c0 5.9-3.2 11.3-8.5 14.1s-11.5 2.5-16.4-.8L400 163.2l-39.1 26.1c-4.9 3.3-11.2 3.6-16.4 .8s-8.5-8.2-8.5-14.1l0-144-96 0c-26.5 0-48 21.5-48 48z\"]\n};\nconst faDollyFlatbed = faCartFlatbed;\nconst faBanSmoking = {\n prefix: 'fas',\n iconName: 'ban-smoking',\n icon: [512, 512, [128685, \"smoking-ban\"], \"f54d\", \"M99.5 144.8L178.7 224l96 96 92.5 92.5C335.9 434.9 297.5 448 256 448C150 448 64 362 64 256c0-41.5 13.1-79.9 35.5-111.2zM333.3 288l-32-32 82.7 0 0 32-50.7 0zm32 32l34.7 0c8.8 0 16-7.2 16-16l0-64c0-8.8-7.2-16-16-16l-130.7 0L144.8 99.5C176.1 77.1 214.5 64 256 64c106 0 192 86 192 192c0 41.5-13.1 79.9-35.5 111.2L365.3 320zM256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM272 96c-8.8 0-16 7.2-16 16c0 26.5 21.5 48 48 48l32 0c8.8 0 16 7.2 16 16s7.2 16 16 16s16-7.2 16-16c0-26.5-21.5-48-48-48l-32 0c-8.8 0-16-7.2-16-16s-7.2-16-16-16zM229.5 320l-96-96L112 224c-8.8 0-16 7.2-16 16l0 64c0 8.8 7.2 16 16 16l117.5 0z\"]\n};\nconst faSmokingBan = faBanSmoking;\nconst faTerminal = {\n prefix: 'fas',\n iconName: 'terminal',\n icon: [576, 512, [], \"f120\", \"M9.4 86.6C-3.1 74.1-3.1 53.9 9.4 41.4s32.8-12.5 45.3 0l192 192c12.5 12.5 12.5 32.8 0 45.3l-192 192c-12.5 12.5-32.8 12.5-45.3 0s-12.5-32.8 0-45.3L178.7 256 9.4 86.6zM256 416l288 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-288 0c-17.7 0-32-14.3-32-32s14.3-32 32-32z\"]\n};\nconst faMobileButton = {\n prefix: 'fas',\n iconName: 'mobile-button',\n icon: [384, 512, [], \"f10b\", \"M80 0C44.7 0 16 28.7 16 64l0 384c0 35.3 28.7 64 64 64l224 0c35.3 0 64-28.7 64-64l0-384c0-35.3-28.7-64-64-64L80 0zM192 400a32 32 0 1 1 0 64 32 32 0 1 1 0-64z\"]\n};\nconst faHouseMedicalFlag = {\n prefix: 'fas',\n iconName: 'house-medical-flag',\n icon: [640, 512, [], \"e514\", \"M480 0c17.7 0 32 14.3 32 32l112 0c8.8 0 16 7.2 16 16l0 128c0 8.8-7.2 16-16 16l-112 0 0 320-64 0 0-320 0-160c0-17.7 14.3-32 32-32zM276.8 39.7L416 159l0 353 1 0-.2 0L96 512c-17.7 0-32-14.3-32-32l0-192-32 0c-13.4 0-25.4-8.3-30-20.9s-1-26.7 9.2-35.4l224-192c12-10.3 29.7-10.3 41.7 0zM224 208l0 48-48 0c-8.8 0-16 7.2-16 16l0 32c0 8.8 7.2 16 16 16l48 0 0 48c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-48 48 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-48 0 0-48c0-8.8-7.2-16-16-16l-32 0c-8.8 0-16 7.2-16 16z\"]\n};\nconst faBasketShopping = {\n prefix: 'fas',\n iconName: 'basket-shopping',\n icon: [576, 512, [\"shopping-basket\"], \"f291\", \"M253.3 35.1c6.1-11.8 1.5-26.3-10.2-32.4s-26.3-1.5-32.4 10.2L117.6 192 32 192c-17.7 0-32 14.3-32 32s14.3 32 32 32L83.9 463.5C91 492 116.6 512 146 512L430 512c29.4 0 55-20 62.1-48.5L544 256c17.7 0 32-14.3 32-32s-14.3-32-32-32l-85.6 0L365.3 12.9C359.2 1.2 344.7-3.4 332.9 2.7s-16.3 20.6-10.2 32.4L404.3 192l-232.6 0L253.3 35.1zM192 304l0 96c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-96c0-8.8 7.2-16 16-16s16 7.2 16 16zm96-16c8.8 0 16 7.2 16 16l0 96c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-96c0-8.8 7.2-16 16-16zm128 16l0 96c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-96c0-8.8 7.2-16 16-16s16 7.2 16 16z\"]\n};\nconst faShoppingBasket = faBasketShopping;\nconst faTape = {\n prefix: 'fas',\n iconName: 'tape',\n icon: [576, 512, [], \"f4db\", \"M380.8 416c41.5-40.7 67.2-97.3 67.2-160C448 132.3 347.7 32 224 32S0 132.3 0 256S100.3 480 224 480l320 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-163.2 0zM224 160a96 96 0 1 1 0 192 96 96 0 1 1 0-192zm64 96a64 64 0 1 0 -128 0 64 64 0 1 0 128 0z\"]\n};\nconst faBusSimple = {\n prefix: 'fas',\n iconName: 'bus-simple',\n icon: [448, 512, [\"bus-alt\"], \"f55e\", \"M224 0C348.8 0 448 35.2 448 80l0 16 0 320c0 17.7-14.3 32-32 32l0 32c0 17.7-14.3 32-32 32l-32 0c-17.7 0-32-14.3-32-32l0-32-192 0 0 32c0 17.7-14.3 32-32 32l-32 0c-17.7 0-32-14.3-32-32l0-32c-17.7 0-32-14.3-32-32L0 96 0 80C0 35.2 99.2 0 224 0zM64 128l0 128c0 17.7 14.3 32 32 32l256 0c17.7 0 32-14.3 32-32l0-128c0-17.7-14.3-32-32-32L96 96c-17.7 0-32 14.3-32 32zM80 400a32 32 0 1 0 0-64 32 32 0 1 0 0 64zm288 0a32 32 0 1 0 0-64 32 32 0 1 0 0 64z\"]\n};\nconst faBusAlt = faBusSimple;\nconst faEye = {\n prefix: 'fas',\n iconName: 'eye',\n icon: [576, 512, [128065], \"f06e\", \"M288 32c-80.8 0-145.5 36.8-192.6 80.6C48.6 156 17.3 208 2.5 243.7c-3.3 7.9-3.3 16.7 0 24.6C17.3 304 48.6 356 95.4 399.4C142.5 443.2 207.2 480 288 480s145.5-36.8 192.6-80.6c46.8-43.5 78.1-95.4 93-131.1c3.3-7.9 3.3-16.7 0-24.6c-14.9-35.7-46.2-87.7-93-131.1C433.5 68.8 368.8 32 288 32zM144 256a144 144 0 1 1 288 0 144 144 0 1 1 -288 0zm144-64c0 35.3-28.7 64-64 64c-7.1 0-13.9-1.2-20.3-3.3c-5.5-1.8-11.9 1.6-11.7 7.4c.3 6.9 1.3 13.8 3.2 20.7c13.7 51.2 66.4 81.6 117.6 67.9s81.6-66.4 67.9-117.6c-11.1-41.5-47.8-69.4-88.6-71.1c-5.8-.2-9.2 6.1-7.4 11.7c2.1 6.4 3.3 13.2 3.3 20.3z\"]\n};\nconst faFaceSadCry = {\n prefix: 'fas',\n iconName: 'face-sad-cry',\n icon: [512, 512, [128557, \"sad-cry\"], \"f5b3\", \"M352 493.4c-29.6 12-62.1 18.6-96 18.6s-66.4-6.6-96-18.6L160 288c0-8.8-7.2-16-16-16s-16 7.2-16 16l0 189.8C51.5 433.5 0 350.8 0 256C0 114.6 114.6 0 256 0S512 114.6 512 256c0 94.8-51.5 177.5-128 221.8L384 288c0-8.8-7.2-16-16-16s-16 7.2-16 16l0 205.4zM195.2 233.6c5.3 7.1 15.3 8.5 22.4 3.2s8.5-15.3 3.2-22.4c-30.4-40.5-91.2-40.5-121.6 0c-5.3 7.1-3.9 17.1 3.2 22.4s17.1 3.9 22.4-3.2c17.6-23.5 52.8-23.5 70.4 0zm121.6 0c17.6-23.5 52.8-23.5 70.4 0c5.3 7.1 15.3 8.5 22.4 3.2s8.5-15.3 3.2-22.4c-30.4-40.5-91.2-40.5-121.6 0c-5.3 7.1-3.9 17.1 3.2 22.4s17.1 3.9 22.4-3.2zM208 336l0 32c0 26.5 21.5 48 48 48s48-21.5 48-48l0-32c0-26.5-21.5-48-48-48s-48 21.5-48 48z\"]\n};\nconst faSadCry = faFaceSadCry;\nconst faAudioDescription = {\n prefix: 'fas',\n iconName: 'audio-description',\n icon: [576, 512, [], \"f29e\", \"M64 32C28.7 32 0 60.7 0 96L0 416c0 35.3 28.7 64 64 64l448 0c35.3 0 64-28.7 64-64l0-320c0-35.3-28.7-64-64-64L64 32zM213.5 173.3l72 144c5.9 11.9 1.1 26.3-10.7 32.2s-26.3 1.1-32.2-10.7l-9.4-18.9-82.2 0-9.4 18.9c-5.9 11.9-20.3 16.7-32.2 10.7s-16.7-20.3-10.7-32.2l72-144c4.1-8.1 12.4-13.3 21.5-13.3s17.4 5.1 21.5 13.3zm-.4 106.6L192 237.7l-21.1 42.2 42.2 0zM304 184c0-13.3 10.7-24 24-24l56 0c53 0 96 43 96 96s-43 96-96 96l-56 0c-13.3 0-24-10.7-24-24l0-144zm48 24l0 96 32 0c26.5 0 48-21.5 48-48s-21.5-48-48-48l-32 0z\"]\n};\nconst faPersonMilitaryToPerson = {\n prefix: 'fas',\n iconName: 'person-military-to-person',\n icon: [512, 512, [], \"e54c\", \"M71 12.5c-8.6 1-15 8.2-15 16.8c0 9.3 7.5 16.8 16.7 16.9l111.4 0c8.8-.1 15.9-7.2 15.9-16L200 16c0-9.5-8.3-17-17.8-15.9L71 12.5zM189.5 78.1l-122.9 0C64.9 83.8 64 89.8 64 96c0 35.3 28.7 64 64 64s64-28.7 64-64c0-6.2-.9-12.2-2.5-17.9zM32 256l0 32c0 17.7 14.3 32 32 32l128 0c1.8 0 3.5-.1 5.2-.4L53 208.6C40.1 220.3 32 237.2 32 256zm190.2 42.5c1.1-3.3 1.8-6.8 1.8-10.5l0-32c0-35.3-28.7-64-64-64l-64 0c-3.7 0-7.4 .3-10.9 .9L222.2 298.5zM384 160a64 64 0 1 0 0-128 64 64 0 1 0 0 128zm-32 32c-35.3 0-64 28.7-64 64l0 32c0 17.7 14.3 32 32 32l128 0c17.7 0 32-14.3 32-32l0-32c0-35.3-28.7-64-64-64l-64 0zM215.8 450.1c5.2-4.6 8.2-11.1 8.2-18.1s-3-13.5-8.2-18.1l-64-56c-7.1-6.2-17.1-7.7-25.7-3.8S112 366.6 112 376l0 32-88 0c-13.3 0-24 10.7-24 24s10.7 24 24 24l88 0 0 32c0 9.4 5.5 18 14.1 21.9s18.6 2.4 25.7-3.8l64-56zM288 431.9c0 6.9 2.9 13.5 8.1 18.1l64 56.4c7.1 6.2 17.1 7.8 25.7 3.9s14.1-12.4 14.1-21.9l0-32.4 88 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-88 0 0-32c0-9.4-5.5-18-14.1-21.9s-18.6-2.4-25.7 3.8l-64 56c-5.2 4.5-8.2 11.1-8.2 18z\"]\n};\nconst faFileShield = {\n prefix: 'fas',\n iconName: 'file-shield',\n icon: [576, 512, [], \"e4f0\", \"M0 64C0 28.7 28.7 0 64 0L224 0l0 128c0 17.7 14.3 32 32 32l128 0 0 47-92.8 37.1c-21.3 8.5-35.2 29.1-35.2 52c0 56.6 18.9 148 94.2 208.3c-9 4.8-19.3 7.6-30.2 7.6L64 512c-35.3 0-64-28.7-64-64L0 64zm384 64l-128 0L256 0 384 128zm39.1 97.7c5.7-2.3 12.1-2.3 17.8 0l120 48C570 277.4 576 286.2 576 296c0 63.3-25.9 168.8-134.8 214.2c-5.9 2.5-12.6 2.5-18.5 0C313.9 464.8 288 359.3 288 296c0-9.8 6-18.6 15.1-22.3l120-48zM527.4 312L432 273.8l0 187.8c68.2-33 91.5-99 95.4-149.7z\"]\n};\nconst faUserSlash = {\n prefix: 'fas',\n iconName: 'user-slash',\n icon: [640, 512, [], \"f506\", \"M38.8 5.1C28.4-3.1 13.3-1.2 5.1 9.2S-1.2 34.7 9.2 42.9l592 464c10.4 8.2 25.5 6.3 33.7-4.1s6.3-25.5-4.1-33.7L353.3 251.6C407.9 237 448 187.2 448 128C448 57.3 390.7 0 320 0C250.2 0 193.5 55.8 192 125.2L38.8 5.1zM264.3 304.3C170.5 309.4 96 387.2 96 482.3c0 16.4 13.3 29.7 29.7 29.7l388.6 0c3.9 0 7.6-.7 11-2.1l-261-205.6z\"]\n};\nconst faPen = {\n prefix: 'fas',\n iconName: 'pen',\n icon: [512, 512, [128394], \"f304\", \"M362.7 19.3L314.3 67.7 444.3 197.7l48.4-48.4c25-25 25-65.5 0-90.5L453.3 19.3c-25-25-65.5-25-90.5 0zm-71 71L58.6 323.5c-10.4 10.4-18 23.3-22.2 37.4L1 481.2C-1.5 489.7 .8 498.8 7 505s15.3 8.5 23.7 6.1l120.3-35.4c14.1-4.2 27-11.8 37.4-22.2L421.7 220.3 291.7 90.3z\"]\n};\nconst faTowerObservation = {\n prefix: 'fas',\n iconName: 'tower-observation',\n icon: [512, 512, [], \"e586\", \"M241.7 3.4c9-4.5 19.6-4.5 28.6 0l160 80c15.8 7.9 22.2 27.1 14.3 42.9C439 137.5 427.7 144 416 144l0 80c0 17.7-14.3 32-32 32l-4.9 0 32 192 68.9 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-95.5 0c-.4 0-.8 0-1.1 0l-254.8 0c-.4 0-.8 0-1.1 0L32 512c-17.7 0-32-14.3-32-32s14.3-32 32-32l68.9 0 32-192-4.9 0c-17.7 0-32-14.3-32-32l0-80c-11.7 0-23-6.5-28.6-17.7c-7.9-15.8-1.5-35 14.3-42.9l160-80zM314.5 448L256 399.2 197.5 448l117 0zM197.8 256l-4.7 28.3L256 336.8l62.9-52.5L314.2 256l-116.5 0zm-13.9 83.2l-11.2 67L218.5 368l-34.6-28.8zM293.5 368l45.8 38.1-11.2-67L293.5 368zM176 128c-8.8 0-16 7.2-16 16s7.2 16 16 16l160 0c8.8 0 16-7.2 16-16s-7.2-16-16-16l-160 0z\"]\n};\nconst faFileCode = {\n prefix: 'fas',\n iconName: 'file-code',\n icon: [384, 512, [], \"f1c9\", \"M64 0C28.7 0 0 28.7 0 64L0 448c0 35.3 28.7 64 64 64l256 0c35.3 0 64-28.7 64-64l0-288-128 0c-17.7 0-32-14.3-32-32L224 0 64 0zM256 0l0 128 128 0L256 0zM153 289l-31 31 31 31c9.4 9.4 9.4 24.6 0 33.9s-24.6 9.4-33.9 0L71 337c-9.4-9.4-9.4-24.6 0-33.9l48-48c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9zM265 255l48 48c9.4 9.4 9.4 24.6 0 33.9l-48 48c-9.4 9.4-24.6 9.4-33.9 0s-9.4-24.6 0-33.9l31-31-31-31c-9.4-9.4-9.4-24.6 0-33.9s24.6-9.4 33.9 0z\"]\n};\nconst faSignal = {\n prefix: 'fas',\n iconName: 'signal',\n icon: [640, 512, [128246, \"signal-5\", \"signal-perfect\"], \"f012\", \"M576 0c17.7 0 32 14.3 32 32l0 448c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-448c0-17.7 14.3-32 32-32zM448 96c17.7 0 32 14.3 32 32l0 352c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-352c0-17.7 14.3-32 32-32zM352 224l0 256c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-256c0-17.7 14.3-32 32-32s32 14.3 32 32zM192 288c17.7 0 32 14.3 32 32l0 160c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-160c0-17.7 14.3-32 32-32zM96 416l0 64c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-64c0-17.7 14.3-32 32-32s32 14.3 32 32z\"]\n};\nconst faSignal5 = faSignal;\nconst faSignalPerfect = faSignal;\nconst faBus = {\n prefix: 'fas',\n iconName: 'bus',\n icon: [576, 512, [128653], \"f207\", \"M288 0C422.4 0 512 35.2 512 80l0 16 0 32c17.7 0 32 14.3 32 32l0 64c0 17.7-14.3 32-32 32l0 160c0 17.7-14.3 32-32 32l0 32c0 17.7-14.3 32-32 32l-32 0c-17.7 0-32-14.3-32-32l0-32-192 0 0 32c0 17.7-14.3 32-32 32l-32 0c-17.7 0-32-14.3-32-32l0-32c-17.7 0-32-14.3-32-32l0-160c-17.7 0-32-14.3-32-32l0-64c0-17.7 14.3-32 32-32c0 0 0 0 0 0l0-32s0 0 0 0l0-16C64 35.2 153.6 0 288 0zM128 160l0 96c0 17.7 14.3 32 32 32l112 0 0-160-112 0c-17.7 0-32 14.3-32 32zM304 288l112 0c17.7 0 32-14.3 32-32l0-96c0-17.7-14.3-32-32-32l-112 0 0 160zM144 400a32 32 0 1 0 0-64 32 32 0 1 0 0 64zm288 0a32 32 0 1 0 0-64 32 32 0 1 0 0 64zM384 80c0-8.8-7.2-16-16-16L208 64c-8.8 0-16 7.2-16 16s7.2 16 16 16l160 0c8.8 0 16-7.2 16-16z\"]\n};\nconst faHeartCircleXmark = {\n prefix: 'fas',\n iconName: 'heart-circle-xmark',\n icon: [576, 512, [], \"e501\", \"M47.6 300.4L228.3 469.1c7.5 7 17.4 10.9 27.7 10.9s20.2-3.9 27.7-10.9l2.6-2.4C267.2 438.6 256 404.6 256 368c0-97.2 78.8-176 176-176c28.3 0 55 6.7 78.7 18.5c.9-6.5 1.3-13 1.3-19.6l0-5.8c0-69.9-50.5-129.5-119.4-141C347 36.5 300.6 51.4 268 84L256 96 244 84c-32.6-32.6-79-47.5-124.6-39.9C50.5 55.6 0 115.2 0 185.1l0 5.8c0 41.5 17.2 81.2 47.6 109.5zM432 512a144 144 0 1 0 0-288 144 144 0 1 0 0 288zm59.3-180.7L454.6 368l36.7 36.7c6.2 6.2 6.2 16.4 0 22.6s-16.4 6.2-22.6 0L432 390.6l-36.7 36.7c-6.2 6.2-16.4 6.2-22.6 0s-6.2-16.4 0-22.6L409.4 368l-36.7-36.7c-6.2-6.2-6.2-16.4 0-22.6s16.4-6.2 22.6 0L432 345.4l36.7-36.7c6.2-6.2 16.4-6.2 22.6 0s6.2 16.4 0 22.6z\"]\n};\nconst faHouseChimney = {\n prefix: 'fas',\n iconName: 'house-chimney',\n icon: [576, 512, [63499, \"home-lg\"], \"e3af\", \"M543.8 287.6c17 0 32-14 32-32.1c1-9-3-17-11-24L512 185l0-121c0-17.7-14.3-32-32-32l-32 0c-17.7 0-32 14.3-32 32l0 36.7L309.5 7c-6-5-14-7-21-7s-15 1-22 8L10 231.5c-7 7-10 15-10 24c0 18 14 32.1 32 32.1l32 0 0 69.7c-.1 .9-.1 1.8-.1 2.8l0 112c0 22.1 17.9 40 40 40l16 0c1.2 0 2.4-.1 3.6-.2c1.5 .1 3 .2 4.5 .2l31.9 0 24 0c22.1 0 40-17.9 40-40l0-24 0-64c0-17.7 14.3-32 32-32l64 0c17.7 0 32 14.3 32 32l0 64 0 24c0 22.1 17.9 40 40 40l24 0 32.5 0c1.4 0 2.8 0 4.2-.1c1.1 .1 2.2 .1 3.3 .1l16 0c22.1 0 40-17.9 40-40l0-16.2c.3-2.6 .5-5.3 .5-8.1l-.7-160.2 32 0z\"]\n};\nconst faHomeLg = faHouseChimney;\nconst faWindowMaximize = {\n prefix: 'fas',\n iconName: 'window-maximize',\n icon: [512, 512, [128470], \"f2d0\", \"M64 32C28.7 32 0 60.7 0 96L0 416c0 35.3 28.7 64 64 64l384 0c35.3 0 64-28.7 64-64l0-320c0-35.3-28.7-64-64-64L64 32zM96 96l320 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L96 160c-17.7 0-32-14.3-32-32s14.3-32 32-32z\"]\n};\nconst faFaceFrown = {\n prefix: 'fas',\n iconName: 'face-frown',\n icon: [512, 512, [9785, \"frown\"], \"f119\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM159.3 388.7c-2.6 8.4-11.6 13.2-20 10.5s-13.2-11.6-10.5-20C145.2 326.1 196.3 288 256 288s110.8 38.1 127.3 91.3c2.6 8.4-2.1 17.4-10.5 20s-17.4-2.1-20-10.5C340.5 349.4 302.1 320 256 320s-84.5 29.4-96.7 68.7zM144.4 208a32 32 0 1 1 64 0 32 32 0 1 1 -64 0zm192-32a32 32 0 1 1 0 64 32 32 0 1 1 0-64z\"]\n};\nconst faFrown = faFaceFrown;\nconst faPrescription = {\n prefix: 'fas',\n iconName: 'prescription',\n icon: [448, 512, [], \"f5b1\", \"M32 0C14.3 0 0 14.3 0 32L0 192l0 96c0 17.7 14.3 32 32 32s32-14.3 32-32l0-64 50.7 0 128 128L137.4 457.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0L288 397.3 393.4 502.6c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3L333.3 352 438.6 246.6c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0L288 306.7l-85.8-85.8C251.4 209.1 288 164.8 288 112C288 50.1 237.9 0 176 0L32 0zM176 160L64 160l0-96 112 0c26.5 0 48 21.5 48 48s-21.5 48-48 48z\"]\n};\nconst faShop = {\n prefix: 'fas',\n iconName: 'shop',\n icon: [640, 512, [\"store-alt\"], \"f54f\", \"M36.8 192l566.3 0c20.3 0 36.8-16.5 36.8-36.8c0-7.3-2.2-14.4-6.2-20.4L558.2 21.4C549.3 8 534.4 0 518.3 0L121.7 0c-16 0-31 8-39.9 21.4L6.2 134.7c-4 6.1-6.2 13.2-6.2 20.4C0 175.5 16.5 192 36.8 192zM64 224l0 160 0 80c0 26.5 21.5 48 48 48l224 0c26.5 0 48-21.5 48-48l0-80 0-160-64 0 0 160-192 0 0-160-64 0zm448 0l0 256c0 17.7 14.3 32 32 32s32-14.3 32-32l0-256-64 0z\"]\n};\nconst faStoreAlt = faShop;\nconst faFloppyDisk = {\n prefix: 'fas',\n iconName: 'floppy-disk',\n icon: [448, 512, [128190, 128426, \"save\"], \"f0c7\", \"M64 32C28.7 32 0 60.7 0 96L0 416c0 35.3 28.7 64 64 64l320 0c35.3 0 64-28.7 64-64l0-242.7c0-17-6.7-33.3-18.7-45.3L352 50.7C340 38.7 323.7 32 306.7 32L64 32zm0 96c0-17.7 14.3-32 32-32l192 0c17.7 0 32 14.3 32 32l0 64c0 17.7-14.3 32-32 32L96 224c-17.7 0-32-14.3-32-32l0-64zM224 288a64 64 0 1 1 0 128 64 64 0 1 1 0-128z\"]\n};\nconst faSave = faFloppyDisk;\nconst faVihara = {\n prefix: 'fas',\n iconName: 'vihara',\n icon: [640, 512, [], \"f6a7\", \"M281 22L305.8 4.7c1.3-.9 2.7-1.8 4.1-2.4C313.1 .7 316.6 0 320 0s6.9 .7 10.1 2.2c1.4 .7 2.8 1.5 4.1 2.4L359 22C393 45.8 430.8 63.5 470.8 74.4l23 6.3c1.8 .5 3.6 1.1 5.2 2c3.2 1.7 5.9 4 8.1 6.8c3.8 4.9 5.6 11.3 4.7 17.8c-.4 2.8-1.2 5.4-2.5 7.8c-1.7 3.2-4 5.9-6.8 8.1c-4.3 3.2-9.6 5.1-15.1 4.9l-7.5 0 0 56.1 6.4 5.1 5.2 4.1c21.1 16.7 45 29.6 70.5 38.1l28.9 9.6c1.6 .5 3.2 1.2 4.6 2c3.1 1.7 5.8 4.1 7.8 6.9s3.5 6.1 4.1 9.6c.5 2.7 .6 5.5 .1 8.3s-1.4 5.4-2.7 7.8c-1.7 3.1-4.1 5.8-6.9 7.8s-6.1 3.5-9.6 4.1c-1.6 .3-3.3 .4-5 .4L544 288l0 65.9c20.5 22.8 47.4 39.2 77.4 46.7C632 403 640 412.6 640 424c0 13.3-10.7 24-24 24l-40 0 0 32c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-32-160 0 0 32c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-32-160 0 0 32c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-32-40 0c-13.3 0-24-10.7-24-24c0-11.4 8-21 18.6-23.4c30-7.6 56.9-23.9 77.4-46.7L96 288l-39.4 0c-1.7 0-3.4-.1-5-.4c-3.5-.7-6.8-2.1-9.6-4.1s-5.2-4.7-7-7.8c-1.3-2.4-2.3-5-2.7-7.8s-.4-5.6 .1-8.3c.7-3.5 2.1-6.8 4.1-9.6s4.7-5.2 7.8-6.9c1.4-.8 3-1.5 4.6-2l28.9-9.6c25.5-8.5 49.4-21.4 70.5-38.1l5.2-4.1 6.4-5.1 0-8.1 0-48-7.5 0c-5.5 .1-10.8-1.7-15.1-4.9c-2.8-2.1-5.1-4.8-6.8-8.1c-1.2-2.4-2.1-5-2.5-7.8c-.9-6.5 .9-12.8 4.7-17.8c2.1-2.8 4.8-5.1 8.1-6.8c1.6-.8 3.4-1.5 5.2-2l23-6.3C209.2 63.5 247 45.8 281 22zM416 128l-96 0-96 0 0 64 72 0 48 0 72 0 0-64zM160 288l0 64 136 0 24 0 24 0 136 0 0-64-136 0-24 0s0 0 0 0l-24 0-136 0z\"]\n};\nconst faScaleUnbalanced = {\n prefix: 'fas',\n iconName: 'scale-unbalanced',\n icon: [640, 512, [\"balance-scale-left\"], \"f515\", \"M522.1 62.4c16.8-5.6 25.8-23.7 20.2-40.5S518.6-3.9 501.9 1.6l-113 37.7C375 15.8 349.3 0 320 0c-44.2 0-80 35.8-80 80c0 3 .2 5.9 .5 8.8L117.9 129.6c-16.8 5.6-25.8 23.7-20.2 40.5s23.7 25.8 40.5 20.2l135.5-45.2c4.5 3.2 9.3 5.9 14.4 8.2L288 480c0 17.7 14.3 32 32 32l192 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-160 0 0-294.7c21-9.2 37.2-27 44.2-49l125.9-42zM439.6 288L512 163.8 584.4 288l-144.9 0zM512 384c62.9 0 115.2-34 126-78.9c2.6-11-1-22.3-6.7-32.1L536.1 109.8c-5-8.6-14.2-13.8-24.1-13.8s-19.1 5.3-24.1 13.8L392.7 273.1c-5.7 9.8-9.3 21.1-6.7 32.1C396.8 350 449.1 384 512 384zM129.2 291.8L201.6 416 56.7 416l72.4-124.2zM3.2 433.1C14 478 66.3 512 129.2 512s115.2-34 126-78.9c2.6-11-1-22.3-6.7-32.1L153.2 237.8c-5-8.6-14.2-13.8-24.1-13.8s-19.1 5.3-24.1 13.8L9.9 401.1c-5.7 9.8-9.3 21.1-6.7 32.1z\"]\n};\nconst faBalanceScaleLeft = faScaleUnbalanced;\nconst faSortUp = {\n prefix: 'fas',\n iconName: 'sort-up',\n icon: [320, 512, [\"sort-asc\"], \"f0de\", \"M182.6 41.4c-12.5-12.5-32.8-12.5-45.3 0l-128 128c-9.2 9.2-11.9 22.9-6.9 34.9s16.6 19.8 29.6 19.8l256 0c12.9 0 24.6-7.8 29.6-19.8s2.2-25.7-6.9-34.9l-128-128z\"]\n};\nconst faSortAsc = faSortUp;\nconst faCommentDots = {\n prefix: 'fas',\n iconName: 'comment-dots',\n icon: [512, 512, [128172, 62075, \"commenting\"], \"f4ad\", \"M256 448c141.4 0 256-93.1 256-208S397.4 32 256 32S0 125.1 0 240c0 45.1 17.7 86.8 47.7 120.9c-1.9 24.5-11.4 46.3-21.4 62.9c-5.5 9.2-11.1 16.6-15.2 21.6c-2.1 2.5-3.7 4.4-4.9 5.7c-.6 .6-1 1.1-1.3 1.4l-.3 .3c0 0 0 0 0 0c0 0 0 0 0 0s0 0 0 0s0 0 0 0c-4.6 4.6-5.9 11.4-3.4 17.4c2.5 6 8.3 9.9 14.8 9.9c28.7 0 57.6-8.9 81.6-19.3c22.9-10 42.4-21.9 54.3-30.6c31.8 11.5 67 17.9 104.1 17.9zM128 208a32 32 0 1 1 0 64 32 32 0 1 1 0-64zm128 0a32 32 0 1 1 0 64 32 32 0 1 1 0-64zm96 32a32 32 0 1 1 64 0 32 32 0 1 1 -64 0z\"]\n};\nconst faCommenting = faCommentDots;\nconst faPlantWilt = {\n prefix: 'fas',\n iconName: 'plant-wilt',\n icon: [512, 512, [], \"e5aa\", \"M288 120c0-30.9 25.1-56 56-56s56 25.1 56 56l0 13c-29.3 10-48 34.5-48 70.1c0 27.9 25.3 74.8 66 111.6c3.8 3.5 8.9 5.3 14 5.3s10.2-1.8 14-5.3c40.7-36.8 66-83.7 66-111.6c0-35.6-18.7-60.2-48-70.1l0-13C464 53.7 410.3 0 344 0S224 53.7 224 120l0 21.8C207.3 133 188.2 128 168 128c-66.3 0-120 53.7-120 120l0 13c-29.3 10-48 34.5-48 70.1C0 359 25.3 405.9 66 442.7c3.8 3.5 8.9 5.3 14 5.3s10.2-1.8 14-5.3c40.7-36.8 66-83.7 66-111.6c0-35.6-18.7-60.2-48-70.1l0-13c0-30.9 25.1-56 56-56s56 25.1 56 56l0 32 0 200c0 17.7 14.3 32 32 32s32-14.3 32-32l0-200 0-32 0-128z\"]\n};\nconst faDiamond = {\n prefix: 'fas',\n iconName: 'diamond',\n icon: [512, 512, [9830], \"f219\", \"M284.3 11.7c-15.6-15.6-40.9-15.6-56.6 0l-216 216c-15.6 15.6-15.6 40.9 0 56.6l216 216c15.6 15.6 40.9 15.6 56.6 0l216-216c15.6-15.6 15.6-40.9 0-56.6l-216-216z\"]\n};\nconst faFaceGrinSquint = {\n prefix: 'fas',\n iconName: 'face-grin-squint',\n icon: [512, 512, [128518, \"grin-squint\"], \"f585\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM388.1 312.8c12.3-3.8 24.3 6.9 19.3 18.7C382.4 390.6 324.2 432 256.3 432s-126.2-41.4-151.1-100.5c-5-11.8 7-22.5 19.3-18.7c39.7 12.2 84.5 19 131.8 19s92.1-6.8 131.8-19zM133.5 146.7l89.9 47.9c10.7 5.7 10.7 21.1 0 26.8l-89.9 47.9c-7.9 4.2-17.5-1.5-17.5-10.5c0-2.8 1-5.5 2.8-7.6l36-43.2-36-43.2c-1.8-2.1-2.8-4.8-2.8-7.6c0-9 9.6-14.7 17.5-10.5zM396 157.1c0 2.8-1 5.5-2.8 7.6l-36 43.2 36 43.2c1.8 2.1 2.8 4.8 2.8 7.6c0 9-9.6 14.7-17.5 10.5l-89.9-47.9c-10.7-5.7-10.7-21.1 0-26.8l89.9-47.9c7.9-4.2 17.5 1.5 17.5 10.5z\"]\n};\nconst faGrinSquint = faFaceGrinSquint;\nconst faHandHoldingDollar = {\n prefix: 'fas',\n iconName: 'hand-holding-dollar',\n icon: [576, 512, [\"hand-holding-usd\"], \"f4c0\", \"M312 24l0 10.5c6.4 1.2 12.6 2.7 18.2 4.2c12.8 3.4 20.4 16.6 17 29.4s-16.6 20.4-29.4 17c-10.9-2.9-21.1-4.9-30.2-5c-7.3-.1-14.7 1.7-19.4 4.4c-2.1 1.3-3.1 2.4-3.5 3c-.3 .5-.7 1.2-.7 2.8c0 .3 0 .5 0 .6c.2 .2 .9 1.2 3.3 2.6c5.8 3.5 14.4 6.2 27.4 10.1l.9 .3s0 0 0 0c11.1 3.3 25.9 7.8 37.9 15.3c13.7 8.6 26.1 22.9 26.4 44.9c.3 22.5-11.4 38.9-26.7 48.5c-6.7 4.1-13.9 7-21.3 8.8l0 10.6c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-11.4c-9.5-2.3-18.2-5.3-25.6-7.8c-2.1-.7-4.1-1.4-6-2c-12.6-4.2-19.4-17.8-15.2-30.4s17.8-19.4 30.4-15.2c2.6 .9 5 1.7 7.3 2.5c13.6 4.6 23.4 7.9 33.9 8.3c8 .3 15.1-1.6 19.2-4.1c1.9-1.2 2.8-2.2 3.2-2.9c.4-.6 .9-1.8 .8-4.1l0-.2c0-1 0-2.1-4-4.6c-5.7-3.6-14.3-6.4-27.1-10.3l-1.9-.6c-10.8-3.2-25-7.5-36.4-14.4c-13.5-8.1-26.5-22-26.6-44.1c-.1-22.9 12.9-38.6 27.7-47.4c6.4-3.8 13.3-6.4 20.2-8.2L264 24c0-13.3 10.7-24 24-24s24 10.7 24 24zM568.2 336.3c13.1 17.8 9.3 42.8-8.5 55.9L433.1 485.5c-23.4 17.2-51.6 26.5-80.7 26.5L192 512 32 512c-17.7 0-32-14.3-32-32l0-64c0-17.7 14.3-32 32-32l36.8 0 44.9-36c22.7-18.2 50.9-28 80-28l78.3 0 16 0 64 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-64 0-16 0c-8.8 0-16 7.2-16 16s7.2 16 16 16l120.6 0 119.7-88.2c17.8-13.1 42.8-9.3 55.9 8.5zM193.6 384c0 0 0 0 0 0l-.9 0c.3 0 .6 0 .9 0z\"]\n};\nconst faHandHoldingUsd = faHandHoldingDollar;\nconst faChartDiagram = {\n prefix: 'fas',\n iconName: 'chart-diagram',\n icon: [512, 512, [], \"e695\", \"M80 32C53.5 32 32 53.5 32 80s21.5 48 48 48l152 0 0 40-48 48-56 0c-48.6 0-88 39.4-88 88l0 48-8 0c-17.7 0-32 14.3-32 32l0 64c0 17.7 14.3 32 32 32l64 0c17.7 0 32-14.3 32-32l0-64c0-17.7-14.3-32-32-32l-8 0 0-48c0-22.1 17.9-40 40-40l56 0 48 48 0 40-8 0c-17.7 0-32 14.3-32 32l0 64c0 17.7 14.3 32 32 32l64 0c17.7 0 32-14.3 32-32l0-64c0-17.7-14.3-32-32-32l-8 0 0-40 48-48 56 0c22.1 0 40 17.9 40 40l0 48-8 0c-17.7 0-32 14.3-32 32l0 64c0 17.7 14.3 32 32 32l64 0c17.7 0 32-14.3 32-32l0-64c0-17.7-14.3-32-32-32l-8 0 0-48c0-48.6-39.4-88-88-88l-56 0-48-48 0-40 152 0c26.5 0 48-21.5 48-48s-21.5-48-48-48L80 32z\"]\n};\nconst faBacterium = {\n prefix: 'fas',\n iconName: 'bacterium',\n icon: [512, 512, [], \"e05a\", \"M423.1 30.6c3.6-12.7-3.7-26-16.5-29.7s-26 3.7-29.7 16.5l-4.2 14.7c-9.8-.4-19.9 .5-29.9 2.8c-12.1 2.8-23.7 5.9-34.9 9.4l-5.9-13.7c-5.2-12.2-19.3-17.8-31.5-12.6s-17.8 19.3-12.6 31.5l4.9 11.3c-22 9.4-42 20.1-60.2 31.8L196 82.7c-7.4-11-22.3-14-33.3-6.7s-14 22.3-6.7 33.3l7.8 11.6c-18 15-33.7 30.8-47.3 47.1L103 157.3c-10.4-8.3-25.5-6.6-33.7 3.7s-6.6 25.5 3.7 33.7l15 12c-2.1 3.2-4.1 6.5-6 9.7c-9.4 15.7-17 31-23.2 45.3l-9.9-3.9c-12.3-4.9-26.3 1.1-31.2 13.4s1.1 26.3 13.4 31.2l11.6 4.6c-.3 1.1-.6 2.1-.9 3.1c-3.5 12.5-5.7 23.2-7.1 31.3c-.7 4.1-1.2 7.5-1.6 10.3c-.2 1.4-.3 2.6-.4 3.6l-.1 1.4-.1 .6 0 .3 0 .1c0 0 0 .1 39.2 3.7c0 0 0 0 0 0l-39.2-3.6c-.5 5-.6 10-.4 14.9l-14.7 4.2C4.7 380.6-2.7 393.8 .9 406.6s16.9 20.1 29.7 16.5l13.8-3.9c10.6 20.7 27.6 37.8 48.5 48.5l-3.9 13.7c-3.6 12.7 3.7 26 16.5 29.7s26-3.7 29.7-16.5l4.2-14.7c23.8 1 46.3-5.5 65.1-17.6L215 473c9.4 9.4 24.6 9.4 33.9 0s9.4-24.6 0-33.9l-10.6-10.6c9.1-14.1 15.1-30.5 17-48.3l.1-.8c.3-1.7 1-5.1 2.3-9.8l.2-.8 12.6 5.4c12.2 5.2 26.3-.4 31.5-12.6s-.4-26.3-12.6-31.5l-11.3-4.8c9.9-14.9 24.9-31.6 48.6-46l2.1 7.5c3.6 12.7 16.9 20.1 29.7 16.5s20.1-16.9 16.5-29.7L371 259.2c6.9-2.2 14.3-4.3 22.2-6.1c12.9-3 24.7-8 35.2-14.8L439 249c9.4 9.4 24.6 9.4 33.9 0s9.4-24.6 0-33.9l-10.6-10.6c12.2-19 18.6-41.6 17.6-65.1l14.7-4.2c12.7-3.6 20.1-16.9 16.5-29.7s-16.9-20.1-29.7-16.5l-13.7 3.9c-10.8-21.2-28-38-48.5-48.5l3.9-13.8zM92.1 363.3s0 0 0 0L144 368l-51.9-4.7zM112 320a48 48 0 1 1 96 0 48 48 0 1 1 -96 0zM240 184a24 24 0 1 1 0 48 24 24 0 1 1 0-48z\"]\n};\nconst faHandPointer = {\n prefix: 'fas',\n iconName: 'hand-pointer',\n icon: [448, 512, [], \"f25a\", \"M128 40c0-22.1 17.9-40 40-40s40 17.9 40 40l0 148.2c8.5-7.6 19.7-12.2 32-12.2c20.6 0 38.2 13 45 31.2c8.8-9.3 21.2-15.2 35-15.2c25.3 0 46 19.5 47.9 44.3c8.5-7.7 19.8-12.3 32.1-12.3c26.5 0 48 21.5 48 48l0 48 0 16 0 48c0 70.7-57.3 128-128 128l-16 0-64 0-.1 0-5.2 0c-5 0-9.9-.3-14.7-1c-55.3-5.6-106.2-34-140-79L8 336c-13.3-17.7-9.7-42.7 8-56s42.7-9.7 56 8l56 74.7L128 40zM240 304c0-8.8-7.2-16-16-16s-16 7.2-16 16l0 96c0 8.8 7.2 16 16 16s16-7.2 16-16l0-96zm48-16c-8.8 0-16 7.2-16 16l0 96c0 8.8 7.2 16 16 16s16-7.2 16-16l0-96c0-8.8-7.2-16-16-16zm80 16c0-8.8-7.2-16-16-16s-16 7.2-16 16l0 96c0 8.8 7.2 16 16 16s16-7.2 16-16l0-96z\"]\n};\nconst faDrumSteelpan = {\n prefix: 'fas',\n iconName: 'drum-steelpan',\n icon: [576, 512, [], \"f56a\", \"M288 32c159.1 0 288 48 288 128l0 192c0 80-128.9 128-288 128S0 432 0 352L0 160C0 80 128.9 32 288 32zM528 160c0-9.9-8-29.9-55-49.8c-18.6-7.9-40.9-14.4-66-19.4l-27.8 43.6c-7.3 11.5-11.2 24.8-11.2 38.4c0 17.5 6.4 34.4 18.1 47.5l9.8 11c29.8-5.2 55.9-12.5 77.2-21.5c47.1-19.9 55-39.9 55-49.8zM349.2 237.3c-8-26.2-32.4-45.3-61.2-45.3s-53.3 19.1-61.2 45.3c19.4 1.7 39.9 2.7 61.2 2.7s41.8-.9 61.2-2.7zM169 90.8c-25.2 5-47.4 11.6-66 19.4C56 130.1 48 150.1 48 160s8 29.9 55 49.8c21.3 9 47.4 16.3 77.2 21.5l9.8-11c11.6-13.1 18.1-30 18.1-47.5c0-13.6-3.9-26.9-11.2-38.4L169 90.8zm56.3-8C224.5 87 224 91.5 224 96c0 35.3 28.7 64 64 64s64-28.7 64-64c0-4.5-.5-9-1.4-13.2C330.8 81 309.8 80 288 80s-42.8 1-62.6 2.8z\"]\n};\nconst faHandScissors = {\n prefix: 'fas',\n iconName: 'hand-scissors',\n icon: [512, 512, [], \"f257\", \"M40 208c-22.1 0-40 17.9-40 40s17.9 40 40 40l180.2 0c-7.6 8.5-12.2 19.7-12.2 32c0 25.3 19.5 46 44.3 47.9c-7.7 8.5-12.3 19.8-12.3 32.1c0 26.5 21.5 48 48 48l32 0 64 0c70.7 0 128-57.3 128-128l0-113.1c0-40.2-16-78.8-44.4-107.3C444.8 76.8 413.9 64 381.7 64L336 64c-21.3 0-39.3 13.9-45.6 33.1l74.5 23.7c8.4 2.7 13.1 11.7 10.4 20.1s-11.7 13.1-20.1 10.4L288 129.9c0 0 0 .1 0 .1L84 65.8C62.9 59.2 40.5 70.9 33.8 92s5.1 43.5 26.2 50.2L269.5 208 40 208z\"]\n};\nconst faHandsPraying = {\n prefix: 'fas',\n iconName: 'hands-praying',\n icon: [640, 512, [\"praying-hands\"], \"f684\", \"M351.2 4.8c3.2-2 6.6-3.3 10-4.1c4.7-1 9.6-.9 14.1 .1c7.7 1.8 14.8 6.5 19.4 13.6L514.6 194.2c8.8 13.1 13.4 28.6 13.4 44.4l0 73.5c0 6.9 4.4 13 10.9 15.2l79.2 26.4C631.2 358 640 370.2 640 384l0 96c0 9.9-4.6 19.3-12.5 25.4s-18.1 8.1-27.7 5.5L431 465.9c-56-14.9-95-65.7-95-123.7L336 224c0-17.7 14.3-32 32-32s32 14.3 32 32l0 80c0 8.8 7.2 16 16 16s16-7.2 16-16l0-84.9c0-7-1.8-13.8-5.3-19.8L340.3 48.1c-1.7-3-2.9-6.1-3.6-9.3c-1-4.7-1-9.6 .1-14.1c1.9-8 6.8-15.2 14.3-19.9zm-62.4 0c7.5 4.6 12.4 11.9 14.3 19.9c1.1 4.6 1.2 9.4 .1 14.1c-.7 3.2-1.9 6.3-3.6 9.3L213.3 199.3c-3.5 6-5.3 12.9-5.3 19.8l0 84.9c0 8.8 7.2 16 16 16s16-7.2 16-16l0-80c0-17.7 14.3-32 32-32s32 14.3 32 32l0 118.2c0 58-39 108.7-95 123.7l-168.7 45c-9.6 2.6-19.9 .5-27.7-5.5S0 490 0 480l0-96c0-13.8 8.8-26 21.9-30.4l79.2-26.4c6.5-2.2 10.9-8.3 10.9-15.2l0-73.5c0-15.8 4.7-31.2 13.4-44.4L245.2 14.5c4.6-7.1 11.7-11.8 19.4-13.6c4.6-1.1 9.4-1.2 14.1-.1c3.5 .8 6.9 2.1 10 4.1z\"]\n};\nconst faPrayingHands = faHandsPraying;\nconst faArrowRotateRight = {\n prefix: 'fas',\n iconName: 'arrow-rotate-right',\n icon: [512, 512, [8635, \"arrow-right-rotate\", \"arrow-rotate-forward\", \"redo\"], \"f01e\", \"M386.3 160L336 160c-17.7 0-32 14.3-32 32s14.3 32 32 32l128 0c17.7 0 32-14.3 32-32l0-128c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 51.2L414.4 97.6c-87.5-87.5-229.3-87.5-316.8 0s-87.5 229.3 0 316.8s229.3 87.5 316.8 0c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0c-62.5 62.5-163.8 62.5-226.3 0s-62.5-163.8 0-226.3s163.8-62.5 226.3 0L386.3 160z\"]\n};\nconst faArrowRightRotate = faArrowRotateRight;\nconst faArrowRotateForward = faArrowRotateRight;\nconst faRedo = faArrowRotateRight;\nconst faWebAwesome = {\n prefix: 'fas',\n iconName: 'web-awesome',\n icon: [640, 512, [], \"e682\", \"M372.2 52c0 20.9-12.4 39-30.2 47.2L448 192l104.4-20.9c-5.3-7.7-8.4-17.1-8.4-27.1c0-26.5 21.5-48 48-48s48 21.5 48 48c0 26-20.6 47.1-46.4 48L481 442.3c-10.3 23-33.2 37.7-58.4 37.7l-205.2 0c-25.2 0-48-14.8-58.4-37.7L46.4 192C20.6 191.1 0 170 0 144c0-26.5 21.5-48 48-48s48 21.5 48 48c0 10.1-3.1 19.4-8.4 27.1L192 192 298.1 99.1c-17.7-8.3-30-26.3-30-47.1c0-28.7 23.3-52 52-52s52 23.3 52 52z\"]\n};\nconst faBiohazard = {\n prefix: 'fas',\n iconName: 'biohazard',\n icon: [576, 512, [9763], \"f780\", \"M173.2 0c-1.8 0-3.5 .7-4.8 2C138.5 32.3 120 74 120 120c0 26.2 6 50.9 16.6 73c-22 2.4-43.8 9.1-64.2 20.5C37.9 232.8 13.3 262.4 .4 296c-.7 1.7-.5 3.7 .5 5.2c2.2 3.7 7.4 4.3 10.6 1.3C64.2 254.3 158 245.1 205 324s-8.1 153.1-77.6 173.2c-4.2 1.2-6.3 5.9-4.1 9.6c1 1.6 2.6 2.7 4.5 3c36.5 5.9 75.2 .1 109.7-19.2c20.4-11.4 37.4-26.5 50.5-43.8c13.1 17.3 30.1 32.4 50.5 43.8c34.5 19.3 73.3 25.2 109.7 19.2c1.9-.3 3.5-1.4 4.5-3c2.2-3.7 .1-8.4-4.1-9.6C379.1 477.1 324 403 371 324s140.7-69.8 193.5-21.4c3.2 2.9 8.4 2.3 10.6-1.3c1-1.6 1.1-3.5 .5-5.2c-12.9-33.6-37.5-63.2-72.1-82.5c-20.4-11.4-42.2-18.1-64.2-20.5C450 170.9 456 146.2 456 120c0-46-18.5-87.7-48.4-118c-1.3-1.3-3-2-4.8-2c-5 0-8.4 5.2-6.7 9.9C421.7 80.5 385.6 176 288 176S154.3 80.5 179.9 9.9c1.7-4.7-1.6-9.9-6.7-9.9zM240 272a48 48 0 1 1 96 0 48 48 0 1 1 -96 0zM181.7 417.6c6.3-11.8 9.8-25.1 8.6-39.8c-19.5-18-34-41.4-41.2-67.8c-12.5-8.1-26.2-11.8-40-12.4c-9-.4-18.1 .6-27.1 2.7c7.8 57.1 38.7 106.8 82.9 139.4c6.8-6.7 12.6-14.1 16.8-22.1zM288 64c-28.8 0-56.3 5.9-81.2 16.5c2 8.3 5 16.2 9 23.5c6.8 12.4 16.7 23.1 30.1 30.3c13.3-4.1 27.5-6.3 42.2-6.3s28.8 2.2 42.2 6.3c13.4-7.2 23.3-17.9 30.1-30.3c4-7.3 7-15.2 9-23.5C344.3 69.9 316.8 64 288 64zM426.9 310c-7.2 26.4-21.7 49.7-41.2 67.8c-1.2 14.7 2.2 28.1 8.6 39.8c4.3 8 10 15.4 16.8 22.1c44.3-32.6 75.2-82.3 82.9-139.4c-9-2.2-18.1-3.1-27.1-2.7c-13.8 .6-27.5 4.4-40 12.4z\"]\n};\nconst faLocationCrosshairs = {\n prefix: 'fas',\n iconName: 'location-crosshairs',\n icon: [512, 512, [\"location\"], \"f601\", \"M256 0c17.7 0 32 14.3 32 32l0 34.7C368.4 80.1 431.9 143.6 445.3 224l34.7 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-34.7 0C431.9 368.4 368.4 431.9 288 445.3l0 34.7c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-34.7C143.6 431.9 80.1 368.4 66.7 288L32 288c-17.7 0-32-14.3-32-32s14.3-32 32-32l34.7 0C80.1 143.6 143.6 80.1 224 66.7L224 32c0-17.7 14.3-32 32-32zM128 256a128 128 0 1 0 256 0 128 128 0 1 0 -256 0zm128-80a80 80 0 1 1 0 160 80 80 0 1 1 0-160z\"]\n};\nconst faLocation = faLocationCrosshairs;\nconst faMarsDouble = {\n prefix: 'fas',\n iconName: 'mars-double',\n icon: [640, 512, [9891], \"f227\", \"M312 32c-9.7 0-18.5 5.8-22.2 14.8s-1.7 19.3 5.2 26.2l33.4 33.4L275.8 159c-28.4-19.5-62.7-31-99.8-31C78.8 128 0 206.8 0 304s78.8 176 176 176s176-78.8 176-176c0-37-11.4-71.4-31-99.8l52.6-52.6L407 185c6.9 6.9 17.2 8.9 26.2 5.2s14.8-12.5 14.8-22.2l0-112c0-13.3-10.7-24-24-24L312 32zm88 48s0 0 0 0s0 0 0 0s0 0 0 0zM64 304a112 112 0 1 1 224 0A112 112 0 1 1 64 304zM368 480c97.2 0 176-78.8 176-176c0-37-11.4-71.4-31-99.8l52.6-52.6L599 185c6.9 6.9 17.2 8.9 26.2 5.2s14.8-12.5 14.8-22.2l0-112c0-13.3-10.7-24-24-24L504 32c-9.7 0-18.5 5.8-22.2 14.8c-1.2 2.9-1.8 6-1.8 9l0 .2 0 .2c0 6.2 2.5 12.2 7 16.8l33.4 33.4L480 146.7l0 21.3c0 22.6-13.6 43.1-34.6 51.7c-.8 .3-1.7 .7-2.5 1C465.7 241.2 480 270.9 480 304c0 61.9-50.1 112-112 112c-5.4 0-10.8-.4-16-1.1c-12.9 20.4-29.1 38.3-48.1 53.1c19.8 7.8 41.4 12 64 12z\"]\n};\nconst faChildDress = {\n prefix: 'fas',\n iconName: 'child-dress',\n icon: [320, 512, [], \"e59c\", \"M224 64A64 64 0 1 0 96 64a64 64 0 1 0 128 0zM88 400l0 80c0 17.7 14.3 32 32 32s32-14.3 32-32l0-80 16 0 0 80c0 17.7 14.3 32 32 32s32-14.3 32-32l0-80 17.8 0c10.9 0 18.6-10.7 15.2-21.1l-31.1-93.4 28.6 37.8c10.7 14.1 30.8 16.8 44.8 6.2s16.8-30.7 6.2-44.8L254.6 207c-22.4-29.6-57.5-47-94.6-47s-72.2 17.4-94.6 47L6.5 284.7c-10.7 14.1-7.9 34.2 6.2 44.8s34.2 7.9 44.8-6.2l28.7-37.8L55 378.9C51.6 389.3 59.3 400 70.2 400L88 400z\"]\n};\nconst faUsersBetweenLines = {\n prefix: 'fas',\n iconName: 'users-between-lines',\n icon: [640, 512, [], \"e591\", \"M0 24C0 10.7 10.7 0 24 0L616 0c13.3 0 24 10.7 24 24s-10.7 24-24 24L24 48C10.7 48 0 37.3 0 24zM0 488c0-13.3 10.7-24 24-24l592 0c13.3 0 24 10.7 24 24s-10.7 24-24 24L24 512c-13.3 0-24-10.7-24-24zM83.2 160a64 64 0 1 1 128 0 64 64 0 1 1 -128 0zM32 320c0-35.3 28.7-64 64-64l96 0c12.2 0 23.7 3.4 33.4 9.4c-37.2 15.1-65.6 47.2-75.8 86.6L64 352c-17.7 0-32-14.3-32-32zm461.6 32c-10.3-40.1-39.6-72.6-77.7-87.4c9.4-5.5 20.4-8.6 32.1-8.6l96 0c35.3 0 64 28.7 64 64c0 17.7-14.3 32-32 32l-82.4 0zM391.2 290.4c32.1 7.4 58.1 30.9 68.9 61.6c3.5 10 5.5 20.8 5.5 32c0 17.7-14.3 32-32 32l-224 0c-17.7 0-32-14.3-32-32c0-11.2 1.9-22 5.5-32c10.5-29.7 35.3-52.8 66.1-60.9c7.8-2.1 16-3.1 24.5-3.1l96 0c7.4 0 14.7 .8 21.6 2.4zm44-130.4a64 64 0 1 1 128 0 64 64 0 1 1 -128 0zM321.6 96a80 80 0 1 1 0 160 80 80 0 1 1 0-160z\"]\n};\nconst faLungsVirus = {\n prefix: 'fas',\n iconName: 'lungs-virus',\n icon: [640, 512, [], \"e067\", \"M320 0c17.7 0 32 14.3 32 32l0 124.2c-8.5-7.6-19.7-12.2-32-12.2s-23.5 4.6-32 12.2L288 32c0-17.7 14.3-32 32-32zM444.5 195.5c-16.4-16.4-41.8-18.5-60.5-6.1l0-24.1C384 127 415 96 453.3 96c21.7 0 42.8 10.2 55.8 28.8c15.4 22.1 44.3 65.4 71 116.9c26.5 50.9 52.4 112.5 59.6 170.3c.2 1.3 .2 2.6 .2 4l0 7c0 49.1-39.8 89-89 89c-7.3 0-14.5-.9-21.6-2.7l-72.7-18.2c-20.9-5.2-38.7-17.1-51.5-32.9c14 1.5 28.5-3 39.2-13.8l-22.6-22.6 22.6 22.6c18.7-18.7 18.7-49.1 0-67.9c-1.1-1.1-1.4-2-1.5-2.5c-.1-.8-.1-1.8 .4-2.9s1.2-1.9 1.8-2.3c.5-.3 1.3-.8 2.9-.8c26.5 0 48-21.5 48-48s-21.5-48-48-48c-1.6 0-2.4-.4-2.9-.8c-.6-.4-1.3-1.2-1.8-2.3s-.5-2.2-.4-2.9c.1-.6 .4-1.4 1.5-2.5c18.7-18.7 18.7-49.1 0-67.9zM421.8 421.8c-6.2 6.2-16.4 6.2-22.6 0C375.9 398.5 336 415 336 448c0 8.8-7.2 16-16 16s-16-7.2-16-16c0-33-39.9-49.5-63.2-26.2c-6.2 6.2-16.4 6.2-22.6 0s-6.2-16.4 0-22.6C241.5 375.9 225 336 192 336c-8.8 0-16-7.2-16-16s7.2-16 16-16c33 0 49.5-39.9 26.2-63.2c-6.2-6.2-6.2-16.4 0-22.6s16.4-6.2 22.6 0C264.1 241.5 304 225 304 192c0-8.8 7.2-16 16-16s16 7.2 16 16c0 33 39.9 49.5 63.2 26.2c6.2-6.2 16.4-6.2 22.6 0s6.2 16.4 0 22.6C398.5 264.1 415 304 448 304c8.8 0 16 7.2 16 16s-7.2 16-16 16c-33 0-49.5 39.9-26.2 63.2c6.2 6.2 6.2 16.4 0 22.6zM183.3 491.2l-72.7 18.2c-7.1 1.8-14.3 2.7-21.6 2.7c-49.1 0-89-39.8-89-89l0-7c0-1.3 .1-2.7 .2-4c7.2-57.9 33.1-119.4 59.6-170.3c26.8-51.5 55.6-94.8 71-116.9c13-18.6 34-28.8 55.8-28.8C225 96 256 127 256 165.3l0 24.1c-18.6-12.4-44-10.3-60.5 6.1c-18.7 18.7-18.7 49.1 0 67.9c1.1 1.1 1.4 2 1.5 2.5c.1 .8 .1 1.8-.4 2.9s-1.2 1.9-1.8 2.3c-.5 .3-1.3 .8-2.9 .8c-26.5 0-48 21.5-48 48s21.5 48 48 48c1.6 0 2.4 .4 2.9 .8c.6 .4 1.3 1.2 1.8 2.3s.5 2.2 .4 2.9c-.1 .6-.4 1.4-1.5 2.5c-18.7 18.7-18.7 49.1 0 67.9c10.7 10.7 25.3 15.3 39.2 13.8c-12.8 15.9-30.6 27.7-51.5 32.9zM296 320a24 24 0 1 0 0-48 24 24 0 1 0 0 48zm72 32a16 16 0 1 0 -32 0 16 16 0 1 0 32 0z\"]\n};\nconst faFaceGrinTears = {\n prefix: 'fas',\n iconName: 'face-grin-tears',\n icon: [640, 512, [128514, \"grin-tears\"], \"f588\", \"M548.6 371.4C506.4 454.8 419.9 512 320 512s-186.4-57.2-228.6-140.6c4.5-2.9 8.7-6.3 12.7-10.3c8.1-8.1 13.2-18.6 16.5-26.6c3.6-8.8 6.5-18.4 8.8-27.5c4.6-18.2 7.7-37 9.3-48.2c3.9-26.5-18.8-49.2-45.2-45.4c-6.8 .9-16.2 2.4-26.6 4.4C85.3 94.5 191.6 0 320 0S554.7 94.5 573.2 217.7c-10.3-2-19.8-3.5-26.6-4.4c-26.5-3.9-49.2 18.8-45.2 45.4c1.6 11.3 4.6 30 9.3 48.2c2.3 9.1 5.2 18.8 8.8 27.5c3.3 8.1 8.4 18.5 16.5 26.6c3.9 3.9 8.2 7.4 12.7 10.3zM107 254.1c-3.1 21.5-11.4 70.2-25.5 84.4c-.9 1-1.9 1.8-2.9 2.7C60 356.7 32 355.5 14.3 337.7c-18.7-18.7-19.1-48.8-.7-67.2c8.6-8.6 30.1-15.1 50.5-19.6c13-2.8 25.5-4.8 33.9-6c5.4-.8 9.9 3.7 9 9zm454.5 87.1c-.8-.6-1.5-1.3-2.3-2c-.2-.2-.5-.4-.7-.7c-14.1-14.1-22.5-62.9-25.5-84.4c-.8-5.4 3.7-9.9 9-9c1 .1 2.2 .3 3.3 .5c8.2 1.2 19.2 3 30.6 5.5c20.4 4.4 41.9 10.9 50.5 19.6c18.4 18.4 18 48.5-.7 67.2c-17.7 17.7-45.7 19-64.2 3.4zm-90.1-9.7c5-11.8-7-22.5-19.3-18.7c-39.7 12.2-84.5 19-131.8 19s-92.1-6.8-131.8-19c-12.3-3.8-24.3 6.9-19.3 18.7c25 59.1 83.2 100.5 151.1 100.5s126.2-41.4 151.1-100.5zM281.6 228.8s0 0 0 0s0 0 0 0s0 0 0 0c2.1 2.8 5.7 3.9 8.9 2.8s5.5-4.1 5.5-7.6c0-17.9-6.7-35.6-16.6-48.8c-9.8-13-23.9-23.2-39.4-23.2s-29.6 10.2-39.4 23.2C190.7 188.4 184 206.1 184 224c0 3.4 2.2 6.5 5.5 7.6s6.9 0 8.9-2.8c0 0 0 0 0 0s0 0 0 0c0 0 0 0 0 0l.2-.2c.2-.2 .4-.5 .7-.9c.6-.8 1.6-2 2.8-3.4c2.5-2.8 6-6.6 10.2-10.3c8.8-7.8 18.8-14 27.7-14s18.9 6.2 27.7 14c4.2 3.7 7.7 7.5 10.2 10.3c1.2 1.4 2.2 2.6 2.8 3.4c.3 .4 .6 .7 .7 .9l.2 .2c0 0 0 0 0 0zm160 0s0 0 0 0s0 0 0 0c2.1 2.8 5.7 3.9 8.9 2.8s5.5-4.1 5.5-7.6c0-17.9-6.7-35.6-16.6-48.8c-9.8-13-23.9-23.2-39.4-23.2s-29.6 10.2-39.4 23.2C350.7 188.4 344 206.1 344 224c0 3.4 2.2 6.5 5.5 7.6s6.9 0 8.9-2.8c0 0 0 0 0 0s0 0 0 0c0 0 0 0 0 0l.2-.2c.2-.2 .4-.5 .7-.9c.6-.8 1.6-2 2.8-3.4c2.5-2.8 6-6.6 10.2-10.3c8.8-7.8 18.8-14 27.7-14s18.9 6.2 27.7 14c4.2 3.7 7.7 7.5 10.2 10.3c1.2 1.4 2.2 2.6 2.8 3.4c.3 .4 .6 .7 .7 .9l.2 .2c0 0 0 0 0 0c0 0 0 0 0 0z\"]\n};\nconst faGrinTears = faFaceGrinTears;\nconst faPhone = {\n prefix: 'fas',\n iconName: 'phone',\n icon: [512, 512, [128222, 128379], \"f095\", \"M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z\"]\n};\nconst faCalendarXmark = {\n prefix: 'fas',\n iconName: 'calendar-xmark',\n icon: [448, 512, [\"calendar-times\"], \"f273\", \"M128 0c17.7 0 32 14.3 32 32l0 32 128 0 0-32c0-17.7 14.3-32 32-32s32 14.3 32 32l0 32 48 0c26.5 0 48 21.5 48 48l0 48L0 160l0-48C0 85.5 21.5 64 48 64l48 0 0-32c0-17.7 14.3-32 32-32zM0 192l448 0 0 272c0 26.5-21.5 48-48 48L48 512c-26.5 0-48-21.5-48-48L0 192zM305 305c9.4-9.4 9.4-24.6 0-33.9s-24.6-9.4-33.9 0l-47 47-47-47c-9.4-9.4-24.6-9.4-33.9 0s-9.4 24.6 0 33.9l47 47-47 47c-9.4 9.4-9.4 24.6 0 33.9s24.6 9.4 33.9 0l47-47 47 47c9.4 9.4 24.6 9.4 33.9 0s9.4-24.6 0-33.9l-47-47 47-47z\"]\n};\nconst faCalendarTimes = faCalendarXmark;\nconst faChildReaching = {\n prefix: 'fas',\n iconName: 'child-reaching',\n icon: [384, 512, [], \"e59d\", \"M256 64A64 64 0 1 0 128 64a64 64 0 1 0 128 0zM152.9 169.3c-23.7-8.4-44.5-24.3-58.8-45.8L74.6 94.2C64.8 79.5 45 75.6 30.2 85.4s-18.7 29.7-8.9 44.4L40.9 159c18.1 27.1 42.8 48.4 71.1 62.4L112 480c0 17.7 14.3 32 32 32s32-14.3 32-32l0-96 32 0 0 96c0 17.7 14.3 32 32 32s32-14.3 32-32l0-258.4c29.1-14.2 54.4-36.2 72.7-64.2l18.2-27.9c9.6-14.8 5.4-34.6-9.4-44.3s-34.6-5.5-44.3 9.4L291 122.4c-21.8 33.4-58.9 53.6-98.8 53.6c-12.6 0-24.9-2-36.6-5.8c-.9-.3-1.8-.7-2.7-.9z\"]\n};\nconst faHeadSideVirus = {\n prefix: 'fas',\n iconName: 'head-side-virus',\n icon: [512, 512, [], \"e064\", \"M0 224.2C0 100.6 100.2 0 224 0l24 0c95.2 0 181.2 69.3 197.3 160.2c2.3 13 6.8 25.7 15.1 36l42 52.6c6.2 7.8 9.6 17.4 9.6 27.4c0 24.2-19.6 43.8-43.8 43.8L448 320l0 64c0 35.3-28.7 64-64 64l-64 0 0 32c0 17.7-14.3 32-32 32L96 512c-17.7 0-32-14.3-32-32l0-72.7c0-16.7-6.9-32.5-17.1-45.8C16.6 322.4 0 274.1 0 224.2zM224 64c-8.8 0-16 7.2-16 16c0 33-39.9 49.5-63.2 26.2c-6.2-6.2-16.4-6.2-22.6 0s-6.2 16.4 0 22.6C145.5 152.1 129 192 96 192c-8.8 0-16 7.2-16 16s7.2 16 16 16c33 0 49.5 39.9 26.2 63.2c-6.2 6.2-6.2 16.4 0 22.6s16.4 6.2 22.6 0C168.1 286.5 208 303 208 336c0 8.8 7.2 16 16 16s16-7.2 16-16c0-33 39.9-49.5 63.2-26.2c6.2 6.2 16.4 6.2 22.6 0s6.2-16.4 0-22.6C302.5 263.9 319 224 352 224c8.8 0 16-7.2 16-16s-7.2-16-16-16c-33 0-49.5-39.9-26.2-63.2c6.2-6.2 6.2-16.4 0-22.6s-16.4-6.2-22.6 0C279.9 129.5 240 113 240 80c0-8.8-7.2-16-16-16zm-24 96a24 24 0 1 1 0 48 24 24 0 1 1 0-48zm40 80a16 16 0 1 1 32 0 16 16 0 1 1 -32 0z\"]\n};\nconst faUserGear = {\n prefix: 'fas',\n iconName: 'user-gear',\n icon: [640, 512, [\"user-cog\"], \"f4fe\", \"M224 0a128 128 0 1 1 0 256A128 128 0 1 1 224 0zM178.3 304l91.4 0c11.8 0 23.4 1.2 34.5 3.3c-2.1 18.5 7.4 35.6 21.8 44.8c-16.6 10.6-26.7 31.6-20 53.3c4 12.9 9.4 25.5 16.4 37.6s15.2 23.1 24.4 33c15.7 16.9 39.6 18.4 57.2 8.7l0 .9c0 9.2 2.7 18.5 7.9 26.3L29.7 512C13.3 512 0 498.7 0 482.3C0 383.8 79.8 304 178.3 304zM436 218.2c0-7 4.5-13.3 11.3-14.8c10.5-2.4 21.5-3.7 32.7-3.7s22.2 1.3 32.7 3.7c6.8 1.5 11.3 7.8 11.3 14.8l0 30.6c7.9 3.4 15.4 7.7 22.3 12.8l24.9-14.3c6.1-3.5 13.7-2.7 18.5 2.4c7.6 8.1 14.3 17.2 20.1 27.2s10.3 20.4 13.5 31c2.1 6.7-1.1 13.7-7.2 17.2l-25 14.4c.4 4 .7 8.1 .7 12.3s-.2 8.2-.7 12.3l25 14.4c6.1 3.5 9.2 10.5 7.2 17.2c-3.3 10.6-7.8 21-13.5 31s-12.5 19.1-20.1 27.2c-4.8 5.1-12.5 5.9-18.5 2.4l-24.9-14.3c-6.9 5.1-14.3 9.4-22.3 12.8l0 30.6c0 7-4.5 13.3-11.3 14.8c-10.5 2.4-21.5 3.7-32.7 3.7s-22.2-1.3-32.7-3.7c-6.8-1.5-11.3-7.8-11.3-14.8l0-30.5c-8-3.4-15.6-7.7-22.5-12.9l-24.7 14.3c-6.1 3.5-13.7 2.7-18.5-2.4c-7.6-8.1-14.3-17.2-20.1-27.2s-10.3-20.4-13.5-31c-2.1-6.7 1.1-13.7 7.2-17.2l24.8-14.3c-.4-4.1-.7-8.2-.7-12.4s.2-8.3 .7-12.4L343.8 325c-6.1-3.5-9.2-10.5-7.2-17.2c3.3-10.6 7.7-21 13.5-31s12.5-19.1 20.1-27.2c4.8-5.1 12.4-5.9 18.5-2.4l24.8 14.3c6.9-5.1 14.5-9.4 22.5-12.9l0-30.5zm92.1 133.5a48.1 48.1 0 1 0 -96.1 0 48.1 48.1 0 1 0 96.1 0z\"]\n};\nconst faUserCog = faUserGear;\nconst faArrowUp19 = {\n prefix: 'fas',\n iconName: 'arrow-up-1-9',\n icon: [576, 512, [\"sort-numeric-up\"], \"f163\", \"M450.7 38c8.3 6 13.3 15.7 13.3 26l0 96 16 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-48 0-48 0c-17.7 0-32-14.3-32-32s14.3-32 32-32l16 0 0-51.6-5.9 2c-16.8 5.6-34.9-3.5-40.5-20.2s3.5-34.9 20.2-40.5l48-16c9.8-3.3 20.5-1.6 28.8 4.4zM160 32c9 0 17.5 3.8 23.6 10.4l88 96c11.9 13 11.1 33.3-2 45.2s-33.3 11.1-45.2-2L192 146.3 192 448c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-301.7L95.6 181.6c-11.9 13-32.2 13.9-45.2 2s-13.9-32.2-2-45.2l88-96C142.5 35.8 151 32 160 32zM445.7 364.9A32 32 0 1 0 418.3 307a32 32 0 1 0 27.4 57.9zm-40.7 54.9C369.6 408.4 344 375.2 344 336c0-48.6 39.4-88 88-88s88 39.4 88 88c0 23.5-7.5 46.3-21.5 65.2L449.7 467c-10.5 14.2-30.6 17.2-44.8 6.7s-17.2-30.6-6.7-44.8l6.8-9.2z\"]\n};\nconst faSortNumericUp = faArrowUp19;\nconst faDoorClosed = {\n prefix: 'fas',\n iconName: 'door-closed',\n icon: [576, 512, [128682], \"f52a\", \"M96 64c0-35.3 28.7-64 64-64L416 0c35.3 0 64 28.7 64 64l0 384 64 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-112 0-288 0L32 512c-17.7 0-32-14.3-32-32s14.3-32 32-32l64 0L96 64zM384 288a32 32 0 1 0 0-64 32 32 0 1 0 0 64z\"]\n};\nconst faShieldVirus = {\n prefix: 'fas',\n iconName: 'shield-virus',\n icon: [512, 512, [], \"e06c\", \"M269.4 2.9C265.2 1 260.7 0 256 0s-9.2 1-13.4 2.9L54.3 82.8c-22 9.3-38.4 31-38.3 57.2c.5 99.2 41.3 280.7 213.6 363.2c16.7 8 36.1 8 52.8 0C454.7 420.7 495.5 239.2 496 140c.1-26.2-16.3-47.9-38.3-57.2L269.4 2.9zM256 112c8.8 0 16 7.2 16 16c0 33 39.9 49.5 63.2 26.2c6.2-6.2 16.4-6.2 22.6 0s6.2 16.4 0 22.6C334.5 200.1 351 240 384 240c8.8 0 16 7.2 16 16s-7.2 16-16 16c-33 0-49.5 39.9-26.2 63.2c6.2 6.2 6.2 16.4 0 22.6s-16.4 6.2-22.6 0C311.9 334.5 272 351 272 384c0 8.8-7.2 16-16 16s-16-7.2-16-16c0-33-39.9-49.5-63.2-26.2c-6.2 6.2-16.4 6.2-22.6 0s-6.2-16.4 0-22.6C177.5 311.9 161 272 128 272c-8.8 0-16-7.2-16-16s7.2-16 16-16c33 0 49.5-39.9 26.2-63.2c-6.2-6.2-6.2-16.4 0-22.6s16.4-6.2 22.6 0C200.1 177.5 240 161 240 128c0-8.8 7.2-16 16-16zM232 256a24 24 0 1 0 0-48 24 24 0 1 0 0 48zm72 32a16 16 0 1 0 -32 0 16 16 0 1 0 32 0z\"]\n};\nconst faDiceSix = {\n prefix: 'fas',\n iconName: 'dice-six',\n icon: [448, 512, [9861], \"f526\", \"M0 96C0 60.7 28.7 32 64 32l320 0c35.3 0 64 28.7 64 64l0 320c0 35.3-28.7 64-64 64L64 480c-35.3 0-64-28.7-64-64L0 96zm160 64a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zM128 288a32 32 0 1 0 0-64 32 32 0 1 0 0 64zm32 64a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zM320 192a32 32 0 1 0 0-64 32 32 0 1 0 0 64zm32 64a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zM320 384a32 32 0 1 0 0-64 32 32 0 1 0 0 64z\"]\n};\nconst faMosquitoNet = {\n prefix: 'fas',\n iconName: 'mosquito-net',\n icon: [640, 512, [], \"e52c\", \"M168.8 462.3c-7.9-4-11.1-13.6-7.2-21.5L192 380.2l0-44.2c0-4.2 1.7-8.3 4.7-11.3L256 265.4l0-23.1L139.2 344C87.8 395.3 0 358.9 0 286.3c0-41.1 30.6-75.8 71.4-80.9l159.9-23.9-49.6-41.3c-5.1-4.2-7-11.1-4.9-17.4l13.9-41.7-29-58.1c-4-7.9-.7-17.5 7.2-21.5s17.5-.7 21.5 7.2l32 64c1.9 3.8 2.2 8.2 .9 12.2l-12.5 37.6L256 160.5l0-22.6c0-14.9 10.1-27.3 23.8-31l0-43.3c0-4.5 3.7-8.2 8.2-8.2s8.2 3.7 8.2 8.2l0 43.3c13.7 3.6 23.8 16.1 23.8 31l0 22.6 45.4-37.8L352.8 85.1c-1.3-4-1-8.4 .9-12.2l32-64c4-7.9 13.6-11.1 21.5-7.2s11.1 13.6 7.2 21.5l-29 58.1 13.9 41.7c2.1 6.2 .1 13.1-4.9 17.4l-49.6 41.3 159.9 23.9c22.5 2.8 41.8 14.6 54.7 31.4c-2.7 2.6-5.2 5.4-7.3 8.6c-8.6-12.9-23.3-21.5-40-21.5s-31.4 8.5-40 21.5c-8.6-12.9-23.3-21.5-40-21.5c-21.7 0-40 14.3-45.9 34.1c-10.7 3.2-19.8 10.1-25.9 19.2l-40.2-35 0 23.1 32.4 32.4c-.3 2-.4 4.1-.4 6.2c0 16.7 8.5 31.4 21.5 40c-4 2.6-7.5 5.9-10.6 9.5L320 310.6l0 50c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-50-32 32 0 41.4c0 2.5-.6 4.9-1.7 7.2l-32 64c-4 7.9-13.6 11.1-21.5 7.2zM512 256c8.8 0 16 7.2 16 16l0 16 48 0 0-16c0-8.8 7.2-16 16-16s16 7.2 16 16l0 16 16 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-16 0 0 48 16 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-16 0 0 48 16 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-16 0 0 16c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-16-48 0 0 16c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-16-48 0 0 16c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-16-16 0c-8.8 0-16-7.2-16-16s7.2-16 16-16l16 0 0-48-16 0c-8.8 0-16-7.2-16-16s7.2-16 16-16l16 0 0-48-16 0c-8.8 0-16-7.2-16-16s7.2-16 16-16l16 0 0-16c0-8.8 7.2-16 16-16s16 7.2 16 16l0 16 48 0 0-16c0-8.8 7.2-16 16-16zm16 112l48 0 0-48-48 0 0 48zm0 80l48 0 0-48-48 0 0 48zM448 320l0 48 48 0 0-48-48 0zm0 80l0 48 48 0 0-48-48 0z\"]\n};\nconst faFileFragment = {\n prefix: 'fas',\n iconName: 'file-fragment',\n icon: [384, 512, [], \"e697\", \"M0 64C0 28.7 28.7 0 64 0L224 0l0 128c0 17.7 14.3 32 32 32l128 0 0 288c0 35.3-28.7 64-64 64l-128 0 0-128c0-35.3-28.7-64-64-64L0 320 0 64zm384 64l-128 0L256 0 384 128zM32 352l96 0c17.7 0 32 14.3 32 32l0 96c0 17.7-14.3 32-32 32l-96 0c-17.7 0-32-14.3-32-32l0-96c0-17.7 14.3-32 32-32z\"]\n};\nconst faBridgeWater = {\n prefix: 'fas',\n iconName: 'bridge-water',\n icon: [576, 512, [], \"e4ce\", \"M0 96C0 78.3 14.3 64 32 64l512 0c17.7 0 32 14.3 32 32l0 35.6c0 15.7-12.7 28.4-28.4 28.4c-37.3 0-67.6 30.2-67.6 67.6l0 124.9c-12.9 0-25.8 3.9-36.8 11.7c-18 12.4-40.1 20.3-59.2 20.3c0 0 0 0 0 0l0-.5 0-128c0-53-43-96-96-96s-96 43-96 96l0 128 0 .5c-19 0-41.2-7.9-59.1-20.3c-11.1-7.8-24-11.7-36.9-11.7l0-124.9C96 190.2 65.8 160 28.4 160C12.7 160 0 147.3 0 131.6L0 96zM306.5 389.9C329 405.4 356.5 416 384 416c26.9 0 55.4-10.8 77.4-26.1c0 0 0 0 0 0c11.9-8.5 28.1-7.8 39.2 1.7c14.4 11.9 32.5 21 50.6 25.2c17.2 4 27.9 21.2 23.9 38.4s-21.2 27.9-38.4 23.9c-24.5-5.7-44.9-16.5-58.2-25C449.5 469.7 417 480 384 480c-31.9 0-60.6-9.9-80.4-18.9c-5.8-2.7-11.1-5.3-15.6-7.7c-4.5 2.4-9.7 5.1-15.6 7.7c-19.8 9-48.5 18.9-80.4 18.9c-33 0-65.5-10.3-94.5-25.8c-13.4 8.4-33.7 19.3-58.2 25c-17.2 4-34.4-6.7-38.4-23.9s6.7-34.4 23.9-38.4c18.1-4.2 36.2-13.3 50.6-25.2c11.1-9.4 27.3-10.1 39.2-1.7c0 0 0 0 0 0C136.7 405.2 165.1 416 192 416c27.5 0 55-10.6 77.5-26.1c11.1-7.9 25.9-7.9 37 0z\"]\n};\nconst faPersonBooth = {\n prefix: 'fas',\n iconName: 'person-booth',\n icon: [576, 512, [], \"f756\", \"M256 32c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 160 64 0 0-160zm320 0c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 448c0 17.7 14.3 32 32 32s32-14.3 32-32l0-448zM224 512c17.7 0 32-14.3 32-32l0-160-64 0 0 160c0 17.7 14.3 32 32 32zM320 0c-9.3 0-18.1 4-24.2 11s-8.8 16.3-7.5 25.5l31.2 218.6L288.6 409.7c-3.5 17.3 7.8 34.2 25.1 37.7s34.2-7.8 37.7-25.1l.7-3.6c1.3 16.4 15.1 29.4 31.9 29.4c17.7 0 32-14.3 32-32c0 17.7 14.3 32 32 32s32-14.3 32-32l0-384c0-17.7-14.3-32-32-32L320 0zM112 80A48 48 0 1 0 16 80a48 48 0 1 0 96 0zm0 261.3l0-72.1 4.7 4.7c9 9 21.2 14.1 33.9 14.1l73.4 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-66.7 0-41.6-41.6c-14.3-14.3-33.8-22.4-54-22.4C27.6 160 0 187.6 0 221.6l0 55.7 0 .9L0 480c0 17.7 14.3 32 32 32s32-14.3 32-32l0-96 32 42.7L96 480c0 17.7 14.3 32 32 32s32-14.3 32-32l0-58.7c0-10.4-3.4-20.5-9.6-28.8L112 341.3z\"]\n};\nconst faTextWidth = {\n prefix: 'fas',\n iconName: 'text-width',\n icon: [448, 512, [], \"f035\", \"M64 128l0-32 128 0 0 128-16 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l96 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-16 0 0-128 128 0 0 32c0 17.7 14.3 32 32 32s32-14.3 32-32l0-48c0-26.5-21.5-48-48-48L224 32 48 32C21.5 32 0 53.5 0 80l0 48c0 17.7 14.3 32 32 32s32-14.3 32-32zM9.4 361.4c-12.5 12.5-12.5 32.8 0 45.3l64 64c9.2 9.2 22.9 11.9 34.9 6.9s19.8-16.6 19.8-29.6l0-32 192 0 0 32c0 12.9 7.8 24.6 19.8 29.6s25.7 2.2 34.9-6.9l64-64c12.5-12.5 12.5-32.8 0-45.3l-64-64c-9.2-9.2-22.9-11.9-34.9-6.9s-19.8 16.6-19.8 29.6l0 32-192 0 0-32c0-12.9-7.8-24.6-19.8-29.6s-25.7-2.2-34.9 6.9l-64 64z\"]\n};\nconst faHatWizard = {\n prefix: 'fas',\n iconName: 'hat-wizard',\n icon: [512, 512, [], \"f6e8\", \"M64 416L168.6 180.7c15.3-34.4 40.3-63.5 72-83.7l146.9-94c3-1.9 6.5-2.9 10-2.9C407.7 0 416 8.3 416 18.6l0 1.6c0 2.6-.5 5.1-1.4 7.5L354.8 176.9c-1.9 4.7-2.8 9.7-2.8 14.7c0 5.5 1.2 11 3.4 16.1L448 416l-207.1 0 11.8-35.4 40.4-13.5c6.5-2.2 10.9-8.3 10.9-15.2s-4.4-13-10.9-15.2l-40.4-13.5-13.5-40.4C237 276.4 230.9 272 224 272s-13 4.4-15.2 10.9l-13.5 40.4-40.4 13.5C148.4 339 144 345.1 144 352s4.4 13 10.9 15.2l40.4 13.5L207.1 416 64 416zM279.6 141.5c-1.1-3.3-4.1-5.5-7.6-5.5s-6.5 2.2-7.6 5.5l-6.7 20.2-20.2 6.7c-3.3 1.1-5.5 4.1-5.5 7.6s2.2 6.5 5.5 7.6l20.2 6.7 6.7 20.2c1.1 3.3 4.1 5.5 7.6 5.5s6.5-2.2 7.6-5.5l6.7-20.2 20.2-6.7c3.3-1.1 5.5-4.1 5.5-7.6s-2.2-6.5-5.5-7.6l-20.2-6.7-6.7-20.2zM32 448l448 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L32 512c-17.7 0-32-14.3-32-32s14.3-32 32-32z\"]\n};\nconst faPenFancy = {\n prefix: 'fas',\n iconName: 'pen-fancy',\n icon: [512, 512, [128395, 10002], \"f5ac\", \"M373.5 27.1C388.5 9.9 410.2 0 433 0c43.6 0 79 35.4 79 79c0 22.8-9.9 44.6-27.1 59.6L277.7 319l-10.3-10.3-64-64L193 234.3 373.5 27.1zM170.3 256.9l10.4 10.4 64 64 10.4 10.4-19.2 83.4c-3.9 17.1-16.9 30.7-33.8 35.4L24.3 510.3l95.4-95.4c2.6 .7 5.4 1.1 8.3 1.1c17.7 0 32-14.3 32-32s-14.3-32-32-32s-32 14.3-32 32c0 2.9 .4 5.6 1.1 8.3L1.7 487.6 51.5 310c4.7-16.9 18.3-29.9 35.4-33.8l83.4-19.2z\"]\n};\nconst faPersonDigging = {\n prefix: 'fas',\n iconName: 'person-digging',\n icon: [576, 512, [\"digging\"], \"f85e\", \"M208 64a48 48 0 1 1 96 0 48 48 0 1 1 -96 0zM9.8 214.8c5.1-12.2 19.1-18 31.4-12.9L60.7 210l22.9-38.1C99.9 144.6 129.3 128 161 128c51.4 0 97 32.9 113.3 81.7l34.6 103.7 79.3 33.1 34.2-45.6c6.4-8.5 16.6-13.3 27.2-12.8s20.3 6.4 25.8 15.5l96 160c5.9 9.9 6.1 22.2 .4 32.2s-16.3 16.2-27.8 16.2l-256 0c-11.1 0-21.4-5.7-27.2-15.2s-6.4-21.2-1.4-31.1l16-32c5.4-10.8 16.5-17.7 28.6-17.7l32 0 22.5-30L22.8 246.2c-12.2-5.1-18-19.1-12.9-31.4zm82.8 91.8l112 48c11.8 5 19.4 16.6 19.4 29.4l0 96c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-74.9-60.6-26-37 111c-5.6 16.8-23.7 25.8-40.5 20.2S-3.9 486.6 1.6 469.9l48-144 11-33 32 13.7z\"]\n};\nconst faDigging = faPersonDigging;\nconst faTrash = {\n prefix: 'fas',\n iconName: 'trash',\n icon: [448, 512, [], \"f1f8\", \"M135.2 17.7L128 32 32 32C14.3 32 0 46.3 0 64S14.3 96 32 96l384 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-96 0-7.2-14.3C307.4 6.8 296.3 0 284.2 0L163.8 0c-12.1 0-23.2 6.8-28.6 17.7zM416 128L32 128 53.2 467c1.6 25.3 22.6 45 47.9 45l245.8 0c25.3 0 46.3-19.7 47.9-45L416 128z\"]\n};\nconst faGaugeSimple = {\n prefix: 'fas',\n iconName: 'gauge-simple',\n icon: [512, 512, [\"gauge-simple-med\", \"tachometer-average\"], \"f629\", \"M0 256a256 256 0 1 1 512 0A256 256 0 1 1 0 256zm320 96c0-26.9-16.5-49.9-40-59.3L280 88c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 204.7c-23.5 9.5-40 32.5-40 59.3c0 35.3 28.7 64 64 64s64-28.7 64-64z\"]\n};\nconst faGaugeSimpleMed = faGaugeSimple;\nconst faTachometerAverage = faGaugeSimple;\nconst faBookMedical = {\n prefix: 'fas',\n iconName: 'book-medical',\n icon: [448, 512, [], \"f7e6\", \"M0 96C0 43 43 0 96 0L384 0l32 0c17.7 0 32 14.3 32 32l0 320c0 17.7-14.3 32-32 32l0 64c17.7 0 32 14.3 32 32s-14.3 32-32 32l-32 0L96 512c-53 0-96-43-96-96L0 96zM64 416c0 17.7 14.3 32 32 32l256 0 0-64L96 384c-17.7 0-32 14.3-32 32zM208 112l0 48-48 0c-8.8 0-16 7.2-16 16l0 32c0 8.8 7.2 16 16 16l48 0 0 48c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-48 48 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-48 0 0-48c0-8.8-7.2-16-16-16l-32 0c-8.8 0-16 7.2-16 16z\"]\n};\nconst faPoo = {\n prefix: 'fas',\n iconName: 'poo',\n icon: [512, 512, [128169], \"f2fe\", \"M268.9 .9c-5.5-.7-11 1.4-14.5 5.7s-4.6 10.1-2.8 15.4c2.8 8.2 4.3 16.9 4.3 26.1c0 44.1-35.7 79.9-79.8 80L160 128c-35.3 0-64 28.7-64 64c0 19.1 8.4 36.3 21.7 48L104 240c-39.8 0-72 32.2-72 72c0 23.2 11 43.8 28 57c-34.1 5.7-60 35.3-60 71c0 39.8 32.2 72 72 72l368 0c39.8 0 72-32.2 72-72c0-35.7-25.9-65.3-60-71c17-13.2 28-33.8 28-57c0-39.8-32.2-72-72-72l-13.7 0c13.3-11.7 21.7-28.9 21.7-48c0-35.3-28.7-64-64-64l-5.5 0c3.5-10 5.5-20.8 5.5-32c0-48.6-36.2-88.8-83.1-95.1zM192 256a32 32 0 1 1 0 64 32 32 0 1 1 0-64zm96 32a32 32 0 1 1 64 0 32 32 0 1 1 -64 0zm64 108.3c0 2.4-.7 4.8-2.2 6.7c-8.2 10.5-39.5 45-93.8 45s-85.6-34.6-93.8-45c-1.5-1.9-2.2-4.3-2.2-6.7c0-6.8 5.5-12.3 12.3-12.3l167.4 0c6.8 0 12.3 5.5 12.3 12.3z\"]\n};\nconst faQuoteRight = {\n prefix: 'fas',\n iconName: 'quote-right',\n icon: [448, 512, [8221, \"quote-right-alt\"], \"f10e\", \"M448 296c0 66.3-53.7 120-120 120l-8 0c-17.7 0-32-14.3-32-32s14.3-32 32-32l8 0c30.9 0 56-25.1 56-56l0-8-64 0c-35.3 0-64-28.7-64-64l0-64c0-35.3 28.7-64 64-64l64 0c35.3 0 64 28.7 64 64l0 32 0 32 0 72zm-256 0c0 66.3-53.7 120-120 120l-8 0c-17.7 0-32-14.3-32-32s14.3-32 32-32l8 0c30.9 0 56-25.1 56-56l0-8-64 0c-35.3 0-64-28.7-64-64l0-64c0-35.3 28.7-64 64-64l64 0c35.3 0 64 28.7 64 64l0 32 0 32 0 72z\"]\n};\nconst faQuoteRightAlt = faQuoteRight;\nconst faShirt = {\n prefix: 'fas',\n iconName: 'shirt',\n icon: [640, 512, [128085, \"t-shirt\", \"tshirt\"], \"f553\", \"M211.8 0c7.8 0 14.3 5.7 16.7 13.2C240.8 51.9 277.1 80 320 80s79.2-28.1 91.5-66.8C413.9 5.7 420.4 0 428.2 0l12.6 0c22.5 0 44.2 7.9 61.5 22.3L628.5 127.4c6.6 5.5 10.7 13.5 11.4 22.1s-2.1 17.1-7.8 23.6l-56 64c-11.4 13.1-31.2 14.6-44.6 3.5L480 197.7 480 448c0 35.3-28.7 64-64 64l-192 0c-35.3 0-64-28.7-64-64l0-250.3-51.5 42.9c-13.3 11.1-33.1 9.6-44.6-3.5l-56-64c-5.7-6.5-8.5-15-7.8-23.6s4.8-16.6 11.4-22.1L137.7 22.3C155 7.9 176.7 0 199.2 0l12.6 0z\"]\n};\nconst faTShirt = faShirt;\nconst faTshirt = faShirt;\nconst faCubes = {\n prefix: 'fas',\n iconName: 'cubes',\n icon: [576, 512, [], \"f1b3\", \"M290.8 48.6l78.4 29.7L288 109.5 206.8 78.3l78.4-29.7c1.8-.7 3.8-.7 5.7 0zM136 92.5l0 112.2c-1.3 .4-2.6 .8-3.9 1.3l-96 36.4C14.4 250.6 0 271.5 0 294.7L0 413.9c0 22.2 13.1 42.3 33.5 51.3l96 42.2c14.4 6.3 30.7 6.3 45.1 0L288 457.5l113.5 49.9c14.4 6.3 30.7 6.3 45.1 0l96-42.2c20.3-8.9 33.5-29.1 33.5-51.3l0-119.1c0-23.3-14.4-44.1-36.1-52.4l-96-36.4c-1.3-.5-2.6-.9-3.9-1.3l0-112.2c0-23.3-14.4-44.1-36.1-52.4l-96-36.4c-12.8-4.8-26.9-4.8-39.7 0l-96 36.4C150.4 48.4 136 69.3 136 92.5zM392 210.6l-82.4 31.2 0-89.2L392 121l0 89.6zM154.8 250.9l78.4 29.7L152 311.7 70.8 280.6l78.4-29.7c1.8-.7 3.8-.7 5.7 0zm18.8 204.4l0-100.5L256 323.2l0 95.9-82.4 36.2zM421.2 250.9c1.8-.7 3.8-.7 5.7 0l78.4 29.7L424 311.7l-81.2-31.1 78.4-29.7zM523.2 421.2l-77.6 34.1 0-100.5L528 323.2l0 90.7c0 3.2-1.9 6-4.8 7.3z\"]\n};\nconst faDivide = {\n prefix: 'fas',\n iconName: 'divide',\n icon: [448, 512, [10135, 247], \"f529\", \"M272 96a48 48 0 1 0 -96 0 48 48 0 1 0 96 0zm0 320a48 48 0 1 0 -96 0 48 48 0 1 0 96 0zM400 288c17.7 0 32-14.3 32-32s-14.3-32-32-32L48 224c-17.7 0-32 14.3-32 32s14.3 32 32 32l352 0z\"]\n};\nconst faTengeSign = {\n prefix: 'fas',\n iconName: 'tenge-sign',\n icon: [384, 512, [8376, \"tenge\"], \"f7d7\", \"M0 64C0 46.3 14.3 32 32 32l320 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L32 96C14.3 96 0 81.7 0 64zM0 192c0-17.7 14.3-32 32-32l160 0 160 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-128 0 0 224c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-224L32 224c-17.7 0-32-14.3-32-32z\"]\n};\nconst faTenge = faTengeSign;\nconst faHeadphones = {\n prefix: 'fas',\n iconName: 'headphones',\n icon: [512, 512, [127911], \"f025\", \"M256 80C149.9 80 62.4 159.4 49.6 262c9.4-3.8 19.6-6 30.4-6c26.5 0 48 21.5 48 48l0 128c0 26.5-21.5 48-48 48c-44.2 0-80-35.8-80-80l0-16 0-48 0-48C0 146.6 114.6 32 256 32s256 114.6 256 256l0 48 0 48 0 16c0 44.2-35.8 80-80 80c-26.5 0-48-21.5-48-48l0-128c0-26.5 21.5-48 48-48c10.8 0 21 2.1 30.4 6C449.6 159.4 362.1 80 256 80z\"]\n};\nconst faHandsHolding = {\n prefix: 'fas',\n iconName: 'hands-holding',\n icon: [640, 512, [], \"f4c2\", \"M80 104c0-22.1-17.9-40-40-40S0 81.9 0 104l0 56 0 64L0 325.5c0 25.5 10.1 49.9 28.1 67.9L128 493.3c12 12 28.3 18.7 45.3 18.7l66.7 0c26.5 0 48-21.5 48-48l0-78.9c0-29.7-11.8-58.2-32.8-79.2l-25.3-25.3c0 0 0 0 0 0l-15.2-15.2-32-32c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3l32 32 15.2 15.2c11 11 9.2 29.2-3.7 37.8c-9.7 6.5-22.7 5.2-31-3.1L98.7 309.5c-12-12-18.7-28.3-18.7-45.3L80 224l0-80 0-40zm480 0l0 40 0 80 0 40.2c0 17-6.7 33.3-18.7 45.3l-51.1 51.1c-8.3 8.3-21.3 9.6-31 3.1c-12.9-8.6-14.7-26.9-3.7-37.8l15.2-15.2 32-32c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0l-32 32-15.2 15.2c0 0 0 0 0 0l-25.3 25.3c-21 21-32.8 49.5-32.8 79.2l0 78.9c0 26.5 21.5 48 48 48l66.7 0c17 0 33.3-6.7 45.3-18.7l99.9-99.9c18-18 28.1-42.4 28.1-67.9L640 224l0-64 0-56c0-22.1-17.9-40-40-40s-40 17.9-40 40z\"]\n};\nconst faHandsClapping = {\n prefix: 'fas',\n iconName: 'hands-clapping',\n icon: [512, 512, [], \"e1a8\", \"M336 16l0 64c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-64c0-8.8 7.2-16 16-16s16 7.2 16 16zm-98.7 7.1l32 48c4.9 7.4 2.9 17.3-4.4 22.2s-17.3 2.9-22.2-4.4l-32-48c-4.9-7.4-2.9-17.3 4.4-22.2s17.3-2.9 22.2 4.4zM135 119c9.4-9.4 24.6-9.4 33.9 0L292.7 242.7c10.1 10.1 27.3 2.9 27.3-11.3l0-39.4c0-17.7 14.3-32 32-32s32 14.3 32 32l0 153.6c0 57.1-30 110-78.9 139.4c-64 38.4-145.8 28.3-198.5-24.4L7 361c-9.4-9.4-9.4-24.6 0-33.9s24.6-9.4 33.9 0l53 53c6.1 6.1 16 6.1 22.1 0s6.1-16 0-22.1L23 265c-9.4-9.4-9.4-24.6 0-33.9s24.6-9.4 33.9 0l93 93c6.1 6.1 16 6.1 22.1 0s6.1-16 0-22.1L55 185c-9.4-9.4-9.4-24.6 0-33.9s24.6-9.4 33.9 0l117 117c6.1 6.1 16 6.1 22.1 0s6.1-16 0-22.1l-93-93c-9.4-9.4-9.4-24.6 0-33.9zM433.1 484.9c-24.2 14.5-50.9 22.1-77.7 23.1c48.1-39.6 76.6-99 76.6-162.4l0-98.1c8.2-.1 16-6.4 16-16l0-39.4c0-17.7 14.3-32 32-32s32 14.3 32 32l0 153.6c0 57.1-30 110-78.9 139.4zM424.9 18.7c7.4 4.9 9.3 14.8 4.4 22.2l-32 48c-4.9 7.4-14.8 9.3-22.2 4.4s-9.3-14.8-4.4-22.2l32-48c4.9-7.4 14.8-9.3 22.2-4.4z\"]\n};\nconst faRepublican = {\n prefix: 'fas',\n iconName: 'republican',\n icon: [640, 512, [], \"f75e\", \"M0 192C0 103.6 71.6 32 160 32l224 0c88.4 0 160 71.6 160 160l0 64L0 256l0-64zm415.9-64c-2.4 0-4.7 1.3-5.7 3.4l-12.6 24.6-28.2 4c-2.4 .3-4.4 2-5.2 4.2s-.1 4.7 1.6 6.3l20.4 19.2-4.8 27.1c-.4 2.3 .6 4.7 2.5 6s4.6 1.6 6.7 .5l25.2-12.8 25.2 12.8c2.2 1.1 4.8 .9 6.7-.5s3-3.7 2.5-6l-4.8-27.1L466 170.5c1.7-1.6 2.4-4.1 1.6-6.3s-2.8-3.9-5.2-4.2l-28.2-4-12.6-24.6c-1.1-2.1-3.3-3.4-5.7-3.4zm-138.3 3.4c-1.1-2.1-3.3-3.4-5.7-3.4s-4.7 1.3-5.7 3.4l-12.6 24.6-28.2 4c-2.4 .3-4.4 2-5.2 4.2s-.1 4.7 1.6 6.3l20.4 19.2-4.8 27.1c-.4 2.3 .6 4.7 2.5 6s4.6 1.6 6.7 .5l25.2-12.8 25.2 12.8c2.2 1.1 4.8 .9 6.7-.5s3-3.7 2.5-6l-4.8-27.1L322 170.5c1.7-1.6 2.4-4.1 1.6-6.3s-2.8-3.9-5.2-4.2l-28.2-4-12.6-24.6zM127.9 128c-2.4 0-4.7 1.3-5.7 3.4l-12.6 24.6-28.2 4c-2.4 .3-4.4 2-5.2 4.2s-.1 4.7 1.6 6.3l20.4 19.2-4.8 27.1c-.4 2.3 .6 4.7 2.5 6s4.6 1.6 6.7 .5l25.2-12.8 25.2 12.8c2.2 1.1 4.8 .9 6.7-.5s3-3.7 2.5-6l-4.8-27.1L178 170.5c1.7-1.6 2.4-4.1 1.6-6.3s-2.8-3.9-5.2-4.2l-28.2-4-12.6-24.6c-1.1-2.1-3.3-3.4-5.7-3.4zm.1 160l192 0 96 0 32 0 64 0 32 0 0 32 0 80c0 8.8 7.2 16 16 16s16-7.2 16-16l0-48c0-17.7 14.3-32 32-32s32 14.3 32 32l0 48c0 44.2-35.8 80-80 80s-80-35.8-80-80l0-48-32 0 0 32 0 64c0 17.7-14.3 32-32 32l-64 0c-17.7 0-32-14.3-32-32l0-64-192 0 0 64c0 17.7-14.3 32-32 32l-64 0c-17.7 0-32-14.3-32-32l0-64 0-96 128 0z\"]\n};\nconst faArrowLeft = {\n prefix: 'fas',\n iconName: 'arrow-left',\n icon: [448, 512, [8592], \"f060\", \"M9.4 233.4c-12.5 12.5-12.5 32.8 0 45.3l160 160c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3L109.2 288 416 288c17.7 0 32-14.3 32-32s-14.3-32-32-32l-306.7 0L214.6 118.6c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0l-160 160z\"]\n};\nconst faPersonCircleXmark = {\n prefix: 'fas',\n iconName: 'person-circle-xmark',\n icon: [576, 512, [], \"e543\", \"M112 48a48 48 0 1 1 96 0 48 48 0 1 1 -96 0zm40 304l0 128c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-223.1L59.4 304.5c-9.1 15.1-28.8 20-43.9 10.9s-20-28.8-10.9-43.9l58.3-97c17.4-28.9 48.6-46.6 82.3-46.6l29.7 0c33.7 0 64.9 17.7 82.3 46.6l44.9 74.7c-16.1 17.6-28.6 38.5-36.6 61.5c-1.9-1.8-3.5-3.9-4.9-6.3L232 256.9 232 480c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-128-16 0zM432 224a144 144 0 1 1 0 288 144 144 0 1 1 0-288zm59.3 107.3c6.2-6.2 6.2-16.4 0-22.6s-16.4-6.2-22.6 0L432 345.4l-36.7-36.7c-6.2-6.2-16.4-6.2-22.6 0s-6.2 16.4 0 22.6L409.4 368l-36.7 36.7c-6.2 6.2-6.2 16.4 0 22.6s16.4 6.2 22.6 0L432 390.6l36.7 36.7c6.2 6.2 16.4 6.2 22.6 0s6.2-16.4 0-22.6L454.6 368l36.7-36.7z\"]\n};\nconst faRuler = {\n prefix: 'fas',\n iconName: 'ruler',\n icon: [512, 512, [128207], \"f545\", \"M177.9 494.1c-18.7 18.7-49.1 18.7-67.9 0L17.9 401.9c-18.7-18.7-18.7-49.1 0-67.9l50.7-50.7 48 48c6.2 6.2 16.4 6.2 22.6 0s6.2-16.4 0-22.6l-48-48 41.4-41.4 48 48c6.2 6.2 16.4 6.2 22.6 0s6.2-16.4 0-22.6l-48-48 41.4-41.4 48 48c6.2 6.2 16.4 6.2 22.6 0s6.2-16.4 0-22.6l-48-48 41.4-41.4 48 48c6.2 6.2 16.4 6.2 22.6 0s6.2-16.4 0-22.6l-48-48 50.7-50.7c18.7-18.7 49.1-18.7 67.9 0l92.1 92.1c18.7 18.7 18.7 49.1 0 67.9L177.9 494.1z\"]\n};\nconst faAlignLeft = {\n prefix: 'fas',\n iconName: 'align-left',\n icon: [448, 512, [], \"f036\", \"M288 64c0 17.7-14.3 32-32 32L32 96C14.3 96 0 81.7 0 64S14.3 32 32 32l224 0c17.7 0 32 14.3 32 32zm0 256c0 17.7-14.3 32-32 32L32 352c-17.7 0-32-14.3-32-32s14.3-32 32-32l224 0c17.7 0 32 14.3 32 32zM0 192c0-17.7 14.3-32 32-32l384 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L32 224c-17.7 0-32-14.3-32-32zM448 448c0 17.7-14.3 32-32 32L32 480c-17.7 0-32-14.3-32-32s14.3-32 32-32l384 0c17.7 0 32 14.3 32 32z\"]\n};\nconst faDiceD6 = {\n prefix: 'fas',\n iconName: 'dice-d6',\n icon: [448, 512, [], \"f6d1\", \"M201 10.3c14.3-7.8 31.6-7.8 46 0L422.3 106c5.1 2.8 8.3 8.2 8.3 14s-3.2 11.2-8.3 14L231.7 238c-4.8 2.6-10.5 2.6-15.3 0L25.7 134c-5.1-2.8-8.3-8.2-8.3-14s3.2-11.2 8.3-14L201 10.3zM23.7 170l176 96c5.1 2.8 8.3 8.2 8.3 14l0 216c0 5.6-3 10.9-7.8 13.8s-10.9 3-15.8 .3L25 423.1C9.6 414.7 0 398.6 0 381L0 184c0-5.6 3-10.9 7.8-13.8s10.9-3 15.8-.3zm400.7 0c5-2.7 11-2.6 15.8 .3s7.8 8.1 7.8 13.8l0 197c0 17.6-9.6 33.7-25 42.1L263.7 510c-5 2.7-11 2.6-15.8-.3s-7.8-8.1-7.8-13.8l0-216c0-5.9 3.2-11.2 8.3-14l176-96z\"]\n};\nconst faRestroom = {\n prefix: 'fas',\n iconName: 'restroom',\n icon: [640, 512, [], \"f7bd\", \"M80 48a48 48 0 1 1 96 0A48 48 0 1 1 80 48zm40 304l0 128c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-154.8c-8.1 9.2-21.1 13.2-33.5 9.4c-16.9-5.3-26.3-23.2-21-40.1l30.9-99.1C44.9 155.3 82 128 124 128l8 0c42 0 79.1 27.3 91.6 67.4l30.9 99.1c5.3 16.9-4.1 34.8-21 40.1c-12.4 3.9-25.4-.2-33.5-9.4L200 480c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-128-16 0zM320 0c13.3 0 24 10.7 24 24l0 464c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-464c0-13.3 10.7-24 24-24zM464 48a48 48 0 1 1 96 0 48 48 0 1 1 -96 0zM440 480l0-96-17.8 0c-10.9 0-18.6-10.7-15.2-21.1l9-26.9c-3.2 0-6.4-.5-9.5-1.5c-16.9-5.3-26.3-23.2-21-40.1l29.7-95.2C428.4 156.9 467.6 128 512 128s83.6 28.9 96.8 71.2l29.7 95.2c5.3 16.9-4.1 34.8-21 40.1c-3.2 1-6.4 1.5-9.5 1.5l9 26.9c3.5 10.4-4.3 21.1-15.2 21.1L584 384l0 96c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-96-16 0 0 96c0 17.7-14.3 32-32 32s-32-14.3-32-32z\"]\n};\nconst faJ = {\n prefix: 'fas',\n iconName: 'j',\n icon: [320, 512, [106], \"4a\", \"M288 32c17.7 0 32 14.3 32 32l0 256c0 88.4-71.6 160-160 160S0 408.4 0 320l0-32c0-17.7 14.3-32 32-32s32 14.3 32 32l0 32c0 53 43 96 96 96s96-43 96-96l0-256c0-17.7 14.3-32 32-32z\"]\n};\nconst faUsersViewfinder = {\n prefix: 'fas',\n iconName: 'users-viewfinder',\n icon: [640, 512, [], \"e595\", \"M48 48l88 0c13.3 0 24-10.7 24-24s-10.7-24-24-24L32 0C14.3 0 0 14.3 0 32L0 136c0 13.3 10.7 24 24 24s24-10.7 24-24l0-88zM175.8 224a48 48 0 1 0 0-96 48 48 0 1 0 0 96zm-26.5 32C119.9 256 96 279.9 96 309.3c0 14.7 11.9 26.7 26.7 26.7l56.1 0c8-34.1 32.8-61.7 65.2-73.6c-7.5-4.1-16.2-6.4-25.3-6.4l-69.3 0zm368 80c14.7 0 26.7-11.9 26.7-26.7c0-29.5-23.9-53.3-53.3-53.3l-69.3 0c-9.2 0-17.8 2.3-25.3 6.4c32.4 11.9 57.2 39.5 65.2 73.6l56.1 0zm-89.4 0c-8.6-24.3-29.9-42.6-55.9-47c-3.9-.7-7.9-1-12-1l-80 0c-4.1 0-8.1 .3-12 1c-26 4.4-47.3 22.7-55.9 47c-2.7 7.5-4.1 15.6-4.1 24c0 13.3 10.7 24 24 24l176 0c13.3 0 24-10.7 24-24c0-8.4-1.4-16.5-4.1-24zM464 224a48 48 0 1 0 0-96 48 48 0 1 0 0 96zm-80-32a64 64 0 1 0 -128 0 64 64 0 1 0 128 0zM504 48l88 0 0 88c0 13.3 10.7 24 24 24s24-10.7 24-24l0-104c0-17.7-14.3-32-32-32L504 0c-13.3 0-24 10.7-24 24s10.7 24 24 24zM48 464l0-88c0-13.3-10.7-24-24-24s-24 10.7-24 24L0 480c0 17.7 14.3 32 32 32l104 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-88 0zm456 0c-13.3 0-24 10.7-24 24s10.7 24 24 24l104 0c17.7 0 32-14.3 32-32l0-104c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 88-88 0z\"]\n};\nconst faFileVideo = {\n prefix: 'fas',\n iconName: 'file-video',\n icon: [384, 512, [], \"f1c8\", \"M64 0C28.7 0 0 28.7 0 64L0 448c0 35.3 28.7 64 64 64l256 0c35.3 0 64-28.7 64-64l0-288-128 0c-17.7 0-32-14.3-32-32L224 0 64 0zM256 0l0 128 128 0L256 0zM64 288c0-17.7 14.3-32 32-32l96 0c17.7 0 32 14.3 32 32l0 96c0 17.7-14.3 32-32 32l-96 0c-17.7 0-32-14.3-32-32l0-96zM300.9 397.9L256 368l0-64 44.9-29.9c2-1.3 4.4-2.1 6.8-2.1c6.8 0 12.3 5.5 12.3 12.3l0 103.4c0 6.8-5.5 12.3-12.3 12.3c-2.4 0-4.8-.7-6.8-2.1z\"]\n};\nconst faUpRightFromSquare = {\n prefix: 'fas',\n iconName: 'up-right-from-square',\n icon: [512, 512, [\"external-link-alt\"], \"f35d\", \"M352 0c-12.9 0-24.6 7.8-29.6 19.8s-2.2 25.7 6.9 34.9L370.7 96 201.4 265.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0L416 141.3l41.4 41.4c9.2 9.2 22.9 11.9 34.9 6.9s19.8-16.6 19.8-29.6l0-128c0-17.7-14.3-32-32-32L352 0zM80 32C35.8 32 0 67.8 0 112L0 432c0 44.2 35.8 80 80 80l320 0c44.2 0 80-35.8 80-80l0-112c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 112c0 8.8-7.2 16-16 16L80 448c-8.8 0-16-7.2-16-16l0-320c0-8.8 7.2-16 16-16l112 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L80 32z\"]\n};\nconst faExternalLinkAlt = faUpRightFromSquare;\nconst faTableCells = {\n prefix: 'fas',\n iconName: 'table-cells',\n icon: [512, 512, [\"th\"], \"f00a\", \"M64 32C28.7 32 0 60.7 0 96L0 416c0 35.3 28.7 64 64 64l384 0c35.3 0 64-28.7 64-64l0-320c0-35.3-28.7-64-64-64L64 32zm88 64l0 64-88 0 0-64 88 0zm56 0l88 0 0 64-88 0 0-64zm240 0l0 64-88 0 0-64 88 0zM64 224l88 0 0 64-88 0 0-64zm232 0l0 64-88 0 0-64 88 0zm64 0l88 0 0 64-88 0 0-64zM152 352l0 64-88 0 0-64 88 0zm56 0l88 0 0 64-88 0 0-64zm240 0l0 64-88 0 0-64 88 0z\"]\n};\nconst faTh = faTableCells;\nconst faFilePdf = {\n prefix: 'fas',\n iconName: 'file-pdf',\n icon: [512, 512, [], \"f1c1\", \"M0 64C0 28.7 28.7 0 64 0L224 0l0 128c0 17.7 14.3 32 32 32l128 0 0 144-208 0c-35.3 0-64 28.7-64 64l0 144-48 0c-35.3 0-64-28.7-64-64L0 64zm384 64l-128 0L256 0 384 128zM176 352l32 0c30.9 0 56 25.1 56 56s-25.1 56-56 56l-16 0 0 32c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-48 0-80c0-8.8 7.2-16 16-16zm32 80c13.3 0 24-10.7 24-24s-10.7-24-24-24l-16 0 0 48 16 0zm96-80l32 0c26.5 0 48 21.5 48 48l0 64c0 26.5-21.5 48-48 48l-32 0c-8.8 0-16-7.2-16-16l0-128c0-8.8 7.2-16 16-16zm32 128c8.8 0 16-7.2 16-16l0-64c0-8.8-7.2-16-16-16l-16 0 0 96 16 0zm80-112c0-8.8 7.2-16 16-16l48 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-32 0 0 32 32 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-32 0 0 48c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-64 0-64z\"]\n};\nconst faBookBible = {\n prefix: 'fas',\n iconName: 'book-bible',\n icon: [448, 512, [\"bible\"], \"f647\", \"M96 0C43 0 0 43 0 96L0 416c0 53 43 96 96 96l288 0 32 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l0-64c17.7 0 32-14.3 32-32l0-320c0-17.7-14.3-32-32-32L384 0 96 0zm0 384l256 0 0 64L96 448c-17.7 0-32-14.3-32-32s14.3-32 32-32zM208 80c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 48 48 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-48 0 0 112c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-112-48 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16l48 0 0-48z\"]\n};\nconst faBible = faBookBible;\nconst faO = {\n prefix: 'fas',\n iconName: 'o',\n icon: [448, 512, [111], \"4f\", \"M224 96a160 160 0 1 0 0 320 160 160 0 1 0 0-320zM448 256A224 224 0 1 1 0 256a224 224 0 1 1 448 0z\"]\n};\nconst faSuitcaseMedical = {\n prefix: 'fas',\n iconName: 'suitcase-medical',\n icon: [512, 512, [\"medkit\"], \"f0fa\", \"M184 48l144 0c4.4 0 8 3.6 8 8l0 40L176 96l0-40c0-4.4 3.6-8 8-8zm-56 8l0 40 0 32 0 352 256 0 0-352 0-32 0-40c0-30.9-25.1-56-56-56L184 0c-30.9 0-56 25.1-56 56zM96 96L64 96C28.7 96 0 124.7 0 160L0 416c0 35.3 28.7 64 64 64l32 0L96 96zM416 480l32 0c35.3 0 64-28.7 64-64l0-256c0-35.3-28.7-64-64-64l-32 0 0 384zM224 208c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 48 48 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-48 0 0 48c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-48-48 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16l48 0 0-48z\"]\n};\nconst faMedkit = faSuitcaseMedical;\nconst faUserSecret = {\n prefix: 'fas',\n iconName: 'user-secret',\n icon: [448, 512, [128373], \"f21b\", \"M224 16c-6.7 0-10.8-2.8-15.5-6.1C201.9 5.4 194 0 176 0c-30.5 0-52 43.7-66 89.4C62.7 98.1 32 112.2 32 128c0 14.3 25 27.1 64.6 35.9c-.4 4-.6 8-.6 12.1c0 17 3.3 33.2 9.3 48l-59.9 0C38 224 32 230 32 237.4c0 1.7 .3 3.4 1 5l38.8 96.9C28.2 371.8 0 423.8 0 482.3C0 498.7 13.3 512 29.7 512l388.6 0c16.4 0 29.7-13.3 29.7-29.7c0-58.5-28.2-110.4-71.7-143L415 242.4c.6-1.6 1-3.3 1-5c0-7.4-6-13.4-13.4-13.4l-59.9 0c6-14.8 9.3-31 9.3-48c0-4.1-.2-8.1-.6-12.1C391 155.1 416 142.3 416 128c0-15.8-30.7-29.9-78-38.6C324 43.7 302.5 0 272 0c-18 0-25.9 5.4-32.5 9.9c-4.8 3.3-8.8 6.1-15.5 6.1zm56 208l-12.4 0c-16.5 0-31.1-10.6-36.3-26.2c-2.3-7-12.2-7-14.5 0c-5.2 15.6-19.9 26.2-36.3 26.2L168 224c-22.1 0-40-17.9-40-40l0-14.4c28.2 4.1 61 6.4 96 6.4s67.8-2.3 96-6.4l0 14.4c0 22.1-17.9 40-40 40zm-88 96l16 32L176 480 128 288l64 32zm128-32L272 480 240 352l16-32 64-32z\"]\n};\nconst faOtter = {\n prefix: 'fas',\n iconName: 'otter',\n icon: [640, 512, [129446], \"f700\", \"M181.5 197.1l12.9 6.4c5.9 3 12.4 4.5 19.1 4.5c23.5 0 42.6-19.1 42.6-42.6l0-21.4c0-35.3-28.7-64-64-64l-64 0c-35.3 0-64 28.7-64 64l0 21.4c0 23.5 19.1 42.6 42.6 42.6c6.6 0 13.1-1.5 19.1-4.5l12.9-6.4 8.4-4.2L135.1 185c-4.5-3-7.1-8-7.1-13.3l0-3.7c0-13.3 10.7-24 24-24l16 0c13.3 0 24 10.7 24 24l0 3.7c0 5.3-2.7 10.3-7.1 13.3l-11.8 7.9 8.4 4.2zm-8.6 49.4L160 240l-12.9 6.4c-12.6 6.3-26.5 9.6-40.5 9.6c-3.6 0-7.1-.2-10.6-.6l0 .6c0 35.3 28.7 64 64 64l64 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l160 0 0-48 0-16c0-23.7 12.9-44.4 32-55.4c9.4-5.4 20.3-8.6 32-8.6l0-16c0-26.5 21.5-48 48-48c8.8 0 16 7.2 16 16l0 32 0 16 0 48c0 8.8 7.2 16 16 16s16-7.2 16-16l0-99.7c0-48.2-30.8-91-76.6-106.3l-8.5-2.8c-8-2.7-12.6-11.1-10.4-19.3s10.3-13.2 18.6-11.6l19.9 4C576 86.1 640 164.2 640 254.9l0 1.1s0 0 0 0c0 123.7-100.3 224-224 224l-1.1 0L256 480l-.6 0C132 480 32 380 32 256.6l0-.6 0-39.2c-10.1-14.6-16-32.3-16-51.4L16 144l0-1.4C6.7 139.3 0 130.5 0 120c0-13.3 10.7-24 24-24l2.8 0C44.8 58.2 83.3 32 128 32l64 0c44.7 0 83.2 26.2 101.2 64l2.8 0c13.3 0 24 10.7 24 24c0 10.5-6.7 19.3-16 22.6l0 1.4 0 21.4c0 1.4 0 2.8-.1 4.3c12-6.2 25.7-9.6 40.1-9.6l8 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-8 0c-13.3 0-24 10.7-24 24l0 8 56.4 0c-15.2 17-24.4 39.4-24.4 64l-32 0c-42.3 0-78.2-27.4-91-65.3c-5.1 .9-10.3 1.3-15.6 1.3c-14.1 0-27.9-3.3-40.5-9.6zM96 128a16 16 0 1 1 0 32 16 16 0 1 1 0-32zm112 16a16 16 0 1 1 32 0 16 16 0 1 1 -32 0z\"]\n};\nconst faPersonDress = {\n prefix: 'fas',\n iconName: 'person-dress',\n icon: [320, 512, [\"female\"], \"f182\", \"M160 0a48 48 0 1 1 0 96 48 48 0 1 1 0-96zM88 384l-17.8 0c-10.9 0-18.6-10.7-15.2-21.1L93.3 248.1 59.4 304.5c-9.1 15.1-28.8 20-43.9 10.9s-20-28.8-10.9-43.9l53.6-89.2c20.3-33.7 56.7-54.3 96-54.3l11.6 0c39.3 0 75.7 20.6 96 54.3l53.6 89.2c9.1 15.1 4.2 34.8-10.9 43.9s-34.8 4.2-43.9-10.9l-33.9-56.3L265 362.9c3.5 10.4-4.3 21.1-15.2 21.1L232 384l0 96c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-96-16 0 0 96c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-96z\"]\n};\nconst faFemale = faPersonDress;\nconst faCommentDollar = {\n prefix: 'fas',\n iconName: 'comment-dollar',\n icon: [512, 512, [], \"f651\", \"M256 448c141.4 0 256-93.1 256-208S397.4 32 256 32S0 125.1 0 240c0 45.1 17.7 86.8 47.7 120.9c-1.9 24.5-11.4 46.3-21.4 62.9c-5.5 9.2-11.1 16.6-15.2 21.6c-2.1 2.5-3.7 4.4-4.9 5.7c-.6 .6-1 1.1-1.3 1.4l-.3 .3c0 0 0 0 0 0c0 0 0 0 0 0s0 0 0 0s0 0 0 0c-4.6 4.6-5.9 11.4-3.4 17.4c2.5 6 8.3 9.9 14.8 9.9c28.7 0 57.6-8.9 81.6-19.3c22.9-10 42.4-21.9 54.3-30.6c31.8 11.5 67 17.9 104.1 17.9zm20-312l0 13.9c7.5 1.2 14.6 2.9 21.1 4.7c10.7 2.8 17 13.8 14.2 24.5s-13.8 17-24.5 14.2c-11-2.9-21.6-5-31.2-5.2c-7.9-.1-16 1.8-21.5 5c-4.8 2.8-6.2 5.6-6.2 9.3c0 1.8 .1 3.5 5.3 6.7c6.3 3.8 15.5 6.7 28.3 10.5l.7 .2c11.2 3.4 25.6 7.7 37.1 15c12.9 8.1 24.3 21.3 24.6 41.6c.3 20.9-10.5 36.1-24.8 45c-7.2 4.5-15.2 7.3-23.2 9l0 13.8c0 11-9 20-20 20s-20-9-20-20l0-14.6c-10.3-2.2-20-5.5-28.2-8.4c0 0 0 0 0 0s0 0 0 0c-2.1-.7-4.1-1.4-6.1-2.1c-10.5-3.5-16.1-14.8-12.6-25.3s14.8-16.1 25.3-12.6c2.5 .8 4.9 1.7 7.2 2.4c0 0 0 0 0 0c13.6 4.6 24 8.1 35.1 8.5c8.6 .3 16.5-1.6 21.4-4.7c4.1-2.5 6-5.5 5.9-10.5c0-2.9-.8-5-5.9-8.2c-6.3-4-15.4-6.9-28-10.7l-1.7-.5c-10.9-3.3-24.6-7.4-35.6-14c-12.7-7.7-24.6-20.5-24.7-40.7c-.1-21.1 11.8-35.7 25.8-43.9c6.9-4.1 14.5-6.8 22.2-8.5l0-14c0-11 9-20 20-20s20 9 20 20z\"]\n};\nconst faBusinessTime = {\n prefix: 'fas',\n iconName: 'business-time',\n icon: [640, 512, [\"briefcase-clock\"], \"f64a\", \"M184 48l144 0c4.4 0 8 3.6 8 8l0 40L176 96l0-40c0-4.4 3.6-8 8-8zm-56 8l0 40L64 96C28.7 96 0 124.7 0 160l0 96 192 0 160 0 8.2 0c32.3-39.1 81.1-64 135.8-64c5.4 0 10.7 .2 16 .7l0-32.7c0-35.3-28.7-64-64-64l-64 0 0-40c0-30.9-25.1-56-56-56L184 0c-30.9 0-56 25.1-56 56zM320 352l-96 0c-17.7 0-32-14.3-32-32l0-32L0 288 0 416c0 35.3 28.7 64 64 64l296.2 0C335.1 449.6 320 410.5 320 368c0-5.4 .2-10.7 .7-16l-.7 0zm320 16a144 144 0 1 0 -288 0 144 144 0 1 0 288 0zM496 288c8.8 0 16 7.2 16 16l0 48 32 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-48 0c-8.8 0-16-7.2-16-16l0-64c0-8.8 7.2-16 16-16z\"]\n};\nconst faBriefcaseClock = faBusinessTime;\nconst faTableCellsLarge = {\n prefix: 'fas',\n iconName: 'table-cells-large',\n icon: [512, 512, [\"th-large\"], \"f009\", \"M448 96l0 128-160 0 0-128 160 0zm0 192l0 128-160 0 0-128 160 0zM224 224L64 224 64 96l160 0 0 128zM64 288l160 0 0 128L64 416l0-128zM64 32C28.7 32 0 60.7 0 96L0 416c0 35.3 28.7 64 64 64l384 0c35.3 0 64-28.7 64-64l0-320c0-35.3-28.7-64-64-64L64 32z\"]\n};\nconst faThLarge = faTableCellsLarge;\nconst faBookTanakh = {\n prefix: 'fas',\n iconName: 'book-tanakh',\n icon: [448, 512, [\"tanakh\"], \"f827\", \"M352 0c53 0 96 43 96 96l0 320c0 53-43 96-96 96L64 512l-32 0c-17.7 0-32-14.3-32-32s14.3-32 32-32l0-64c-17.7 0-32-14.3-32-32L0 32C0 14.3 14.3 0 32 0L64 0 352 0zm0 384L96 384l0 64 256 0c17.7 0 32-14.3 32-32s-14.3-32-32-32zM138.7 208l13.9 24-27.7 0 13.9-24zm-13.9-24L97.1 232c-6.2 10.7 1.5 24 13.9 24l55.4 0 27.7 48c6.2 10.7 21.6 10.7 27.7 0l27.7-48 55.4 0c12.3 0 20-13.3 13.9-24l-27.7-48 27.7-48c6.2-10.7-1.5-24-13.9-24l-55.4 0L221.9 64c-6.2-10.7-21.6-10.7-27.7 0l-27.7 48L111 112c-12.3 0-20 13.3-13.9 24l27.7 48zm27.7 0l27.7-48 55.4 0 27.7 48-27.7 48-55.4 0-27.7-48zm0-48l-13.9 24-13.9-24 27.7 0zm41.6-24L208 88l13.9 24-27.7 0zm69.3 24l27.7 0-13.9 24-13.9-24zm13.9 72l13.9 24-27.7 0 13.9-24zm-55.4 48L208 280l-13.9-24 27.7 0z\"]\n};\nconst faTanakh = faBookTanakh;\nconst faPhoneVolume = {\n prefix: 'fas',\n iconName: 'phone-volume',\n icon: [512, 512, [\"volume-control-phone\"], \"f2a0\", \"M280 0C408.1 0 512 103.9 512 232c0 13.3-10.7 24-24 24s-24-10.7-24-24c0-101.6-82.4-184-184-184c-13.3 0-24-10.7-24-24s10.7-24 24-24zm8 192a32 32 0 1 1 0 64 32 32 0 1 1 0-64zm-32-72c0-13.3 10.7-24 24-24c75.1 0 136 60.9 136 136c0 13.3-10.7 24-24 24s-24-10.7-24-24c0-48.6-39.4-88-88-88c-13.3 0-24-10.7-24-24zM117.5 1.4c19.4-5.3 39.7 4.6 47.4 23.2l40 96c6.8 16.3 2.1 35.2-11.6 46.3L144 207.3c33.3 70.4 90.3 127.4 160.7 160.7L345 318.7c11.2-13.7 30-18.4 46.3-11.6l96 40c18.6 7.7 28.5 28 23.2 47.4l-24 88C481.8 499.9 466 512 448 512C200.6 512 0 311.4 0 64C0 46 12.1 30.2 29.5 25.4l88-24z\"]\n};\nconst faVolumeControlPhone = faPhoneVolume;\nconst faHatCowboySide = {\n prefix: 'fas',\n iconName: 'hat-cowboy-side',\n icon: [640, 512, [], \"f8c1\", \"M152.7 135.9l-10.4 57.2c6.8-.7 13.6-1.1 20.5-1.1l10.7 0c39.4 0 77.8 12.1 110.1 34.7L562.4 421.8l35.1 24.6c24.4-6 42.5-28.1 42.5-54.4c0-75.8-94.7-126.6-134.6-144.7L474 83.9C468.2 53.8 441.8 32 411.1 32l-2.7 0c-5.6 0-11.1 .7-16.5 2.2L199.2 85.5c-23.9 6.4-42 26-46.5 50.4zM0 384c0 35.3 28.7 64 64 64l480 0L265.3 252.9c-26.9-18.8-58.9-28.9-91.8-28.9l-10.7 0c-60.6 0-116 34.2-143.1 88.4L13.5 325C4.6 342.7 0 362.3 0 382.2L0 384z\"]\n};\nconst faClipboardUser = {\n prefix: 'fas',\n iconName: 'clipboard-user',\n icon: [384, 512, [], \"f7f3\", \"M192 0c-41.8 0-77.4 26.7-90.5 64L64 64C28.7 64 0 92.7 0 128L0 448c0 35.3 28.7 64 64 64l256 0c35.3 0 64-28.7 64-64l0-320c0-35.3-28.7-64-64-64l-37.5 0C269.4 26.7 233.8 0 192 0zm0 64a32 32 0 1 1 0 64 32 32 0 1 1 0-64zM128 256a64 64 0 1 1 128 0 64 64 0 1 1 -128 0zM80 432c0-44.2 35.8-80 80-80l64 0c44.2 0 80 35.8 80 80c0 8.8-7.2 16-16 16L96 448c-8.8 0-16-7.2-16-16z\"]\n};\nconst faChild = {\n prefix: 'fas',\n iconName: 'child',\n icon: [320, 512, [], \"f1ae\", \"M96 64a64 64 0 1 1 128 0A64 64 0 1 1 96 64zm48 320l0 96c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-192.2L59.1 321c-9.4 15-29.2 19.4-44.1 10S-4.5 301.9 4.9 287l39.9-63.3C69.7 184 113.2 160 160 160s90.3 24 115.2 63.6L315.1 287c9.4 15 4.9 34.7-10 44.1s-34.7 4.9-44.1-10L240 287.8 240 480c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-96-32 0z\"]\n};\nconst faLiraSign = {\n prefix: 'fas',\n iconName: 'lira-sign',\n icon: [320, 512, [8356], \"f195\", \"M112 160.4c0-35.5 28.8-64.4 64.4-64.4c6.9 0 13.8 1.1 20.4 3.3l81.2 27.1c16.8 5.6 34.9-3.5 40.5-20.2s-3.5-34.9-20.2-40.5L217 38.6c-13.1-4.4-26.8-6.6-40.6-6.6C105.5 32 48 89.5 48 160.4L48 192l-16 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l16 0 0 32-16 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l14 0c-2.2 10.5-6.1 20.6-11.7 29.9L4.6 431.5c-5.9 9.9-6.1 22.2-.4 32.2S20.5 480 32 480l256 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L88.5 416l.7-1.1c11.6-19.3 18.9-40.7 21.6-62.9L224 352c17.7 0 32-14.3 32-32s-14.3-32-32-32l-112 0 0-32 112 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-112 0 0-31.6z\"]\n};\nconst faSatellite = {\n prefix: 'fas',\n iconName: 'satellite',\n icon: [512, 512, [128752], \"f7bf\", \"M233 7c-9.4-9.4-24.6-9.4-33.9 0l-96 96c-9.4 9.4-9.4 24.6 0 33.9l89.4 89.4-15.5 15.5C152.3 230.4 124.9 224 96 224c-31.7 0-61.5 7.7-87.8 21.2c-9 4.7-10.3 16.7-3.1 23.8L112.7 376.7 96.3 393.1c-2.6-.7-5.4-1.1-8.3-1.1c-17.7 0-32 14.3-32 32s14.3 32 32 32s32-14.3 32-32c0-2.9-.4-5.6-1.1-8.3l16.4-16.4L242.9 506.9c7.2 7.2 19.2 5.9 23.8-3.1C280.3 477.5 288 447.7 288 416c0-28.9-6.4-56.3-17.8-80.9l15.5-15.5L375 409c9.4 9.4 24.6 9.4 33.9 0l96-96c9.4-9.4 9.4-24.6 0-33.9l-89.4-89.4 55-55c12.5-12.5 12.5-32.8 0-45.3l-48-48c-12.5-12.5-32.8-12.5-45.3 0l-55 55L233 7zm159 351l-72.4-72.4 62.1-62.1L454.1 296 392 358.1zM226.3 192.4L153.9 120 216 57.9l72.4 72.4-62.1 62.1z\"]\n};\nconst faPlaneLock = {\n prefix: 'fas',\n iconName: 'plane-lock',\n icon: [640, 512, [], \"e558\", \"M192 93.7C192 59.5 221 0 256 0c36 0 64 59.5 64 93.7l0 84.6 101.8 58.2C418 247.6 416 259.6 416 272l0 24.6c-17.9 10.4-30.3 29.1-31.8 50.9L320 329.1l0 70.9 57.6 43.2c4 3 6.4 7.8 6.4 12.8l0 24 0 18c0 7.8-6.3 14-14 14c-1.3 0-2.6-.2-3.9-.5L256 480 145.9 511.5c-1.3 .4-2.6 .5-3.9 .5c-7.8 0-14-6.3-14-14l0-42c0-5 2.4-9.8 6.4-12.8L192 400l0-70.9-171.6 49C10.2 381.1 0 373.4 0 362.8l0-65.5c0-5.7 3.1-11 8.1-13.9L192 178.3l0-84.6zM528 240c-17.7 0-32 14.3-32 32l0 48 64 0 0-48c0-17.7-14.3-32-32-32zm-80 32c0-44.2 35.8-80 80-80s80 35.8 80 80l0 48c17.7 0 32 14.3 32 32l0 128c0 17.7-14.3 32-32 32l-160 0c-17.7 0-32-14.3-32-32l0-128c0-17.7 14.3-32 32-32l0-48z\"]\n};\nconst faTag = {\n prefix: 'fas',\n iconName: 'tag',\n icon: [448, 512, [127991], \"f02b\", \"M0 80L0 229.5c0 17 6.7 33.3 18.7 45.3l176 176c25 25 65.5 25 90.5 0L418.7 317.3c25-25 25-65.5 0-90.5l-176-176c-12-12-28.3-18.7-45.3-18.7L48 32C21.5 32 0 53.5 0 80zm112 32a32 32 0 1 1 0 64 32 32 0 1 1 0-64z\"]\n};\nconst faComment = {\n prefix: 'fas',\n iconName: 'comment',\n icon: [512, 512, [128489, 61669], \"f075\", \"M512 240c0 114.9-114.6 208-256 208c-37.1 0-72.3-6.4-104.1-17.9c-11.9 8.7-31.3 20.6-54.3 30.6C73.6 471.1 44.7 480 16 480c-6.5 0-12.3-3.9-14.8-9.9c-2.5-6-1.1-12.8 3.4-17.4c0 0 0 0 0 0s0 0 0 0s0 0 0 0c0 0 0 0 0 0l.3-.3c.3-.3 .7-.7 1.3-1.4c1.1-1.2 2.8-3.1 4.9-5.7c4.1-5 9.6-12.4 15.2-21.6c10-16.6 19.5-38.4 21.4-62.9C17.7 326.8 0 285.1 0 240C0 125.1 114.6 32 256 32s256 93.1 256 208z\"]\n};\nconst faCakeCandles = {\n prefix: 'fas',\n iconName: 'cake-candles',\n icon: [448, 512, [127874, \"birthday-cake\", \"cake\"], \"f1fd\", \"M86.4 5.5L61.8 47.6C58 54.1 56 61.6 56 69.2L56 72c0 22.1 17.9 40 40 40s40-17.9 40-40l0-2.8c0-7.6-2-15-5.8-21.6L105.6 5.5C103.6 2.1 100 0 96 0s-7.6 2.1-9.6 5.5zm128 0L189.8 47.6c-3.8 6.5-5.8 14-5.8 21.6l0 2.8c0 22.1 17.9 40 40 40s40-17.9 40-40l0-2.8c0-7.6-2-15-5.8-21.6L233.6 5.5C231.6 2.1 228 0 224 0s-7.6 2.1-9.6 5.5zM317.8 47.6c-3.8 6.5-5.8 14-5.8 21.6l0 2.8c0 22.1 17.9 40 40 40s40-17.9 40-40l0-2.8c0-7.6-2-15-5.8-21.6L361.6 5.5C359.6 2.1 356 0 352 0s-7.6 2.1-9.6 5.5L317.8 47.6zM128 176c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 48c-35.3 0-64 28.7-64 64l0 71c8.3 5.2 18.1 9 28.8 9c13.5 0 27.2-6.1 38.4-13.4c5.4-3.5 9.9-7.1 13-9.7c1.5-1.3 2.7-2.4 3.5-3.1c.4-.4 .7-.6 .8-.8l.1-.1s0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0c3.1-3.2 7.4-4.9 11.9-4.8s8.6 2.1 11.6 5.4c0 0 0 0 0 0s0 0 0 0l.1 .1c.1 .1 .4 .4 .7 .7c.7 .7 1.7 1.7 3.1 3c2.8 2.6 6.8 6.1 11.8 9.5c10.2 7.1 23 13.1 36.3 13.1s26.1-6 36.3-13.1c5-3.5 9-6.9 11.8-9.5c1.4-1.3 2.4-2.3 3.1-3c.3-.3 .6-.6 .7-.7l.1-.1c3-3.5 7.4-5.4 12-5.4s9 2 12 5.4l.1 .1c.1 .1 .4 .4 .7 .7c.7 .7 1.7 1.7 3.1 3c2.8 2.6 6.8 6.1 11.8 9.5c10.2 7.1 23 13.1 36.3 13.1s26.1-6 36.3-13.1c5-3.5 9-6.9 11.8-9.5c1.4-1.3 2.4-2.3 3.1-3c.3-.3 .6-.6 .7-.7l.1-.1c2.9-3.4 7.1-5.3 11.6-5.4s8.7 1.6 11.9 4.8c0 0 0 0 0 0s0 0 0 0s0 0 0 0l.1 .1c.2 .2 .4 .4 .8 .8c.8 .7 1.9 1.8 3.5 3.1c3.1 2.6 7.5 6.2 13 9.7c11.2 7.3 24.9 13.4 38.4 13.4c10.7 0 20.5-3.9 28.8-9l0-71c0-35.3-28.7-64-64-64l0-48c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 48-64 0 0-48c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 48-64 0 0-48zM448 394.6c-8.5 3.3-18.2 5.4-28.8 5.4c-22.5 0-42.4-9.9-55.8-18.6c-4.1-2.7-7.8-5.4-10.9-7.8c-2.8 2.4-6.1 5-9.8 7.5C329.8 390 310.6 400 288 400s-41.8-10-54.6-18.9c-3.5-2.4-6.7-4.9-9.4-7.2c-2.7 2.3-5.9 4.7-9.4 7.2C201.8 390 182.6 400 160 400s-41.8-10-54.6-18.9c-3.7-2.6-7-5.2-9.8-7.5c-3.1 2.4-6.8 5.1-10.9 7.8C71.2 390.1 51.3 400 28.8 400c-10.6 0-20.3-2.2-28.8-5.4L0 480c0 17.7 14.3 32 32 32l384 0c17.7 0 32-14.3 32-32l0-85.4z\"]\n};\nconst faBirthdayCake = faCakeCandles;\nconst faCake = faCakeCandles;\nconst faEnvelope = {\n prefix: 'fas',\n iconName: 'envelope',\n icon: [512, 512, [128386, 9993, 61443], \"f0e0\", \"M48 64C21.5 64 0 85.5 0 112c0 15.1 7.1 29.3 19.2 38.4L236.8 313.6c11.4 8.5 27 8.5 38.4 0L492.8 150.4c12.1-9.1 19.2-23.3 19.2-38.4c0-26.5-21.5-48-48-48L48 64zM0 176L0 384c0 35.3 28.7 64 64 64l384 0c35.3 0 64-28.7 64-64l0-208L294.4 339.2c-22.8 17.1-54 17.1-76.8 0L0 176z\"]\n};\nconst faAnglesUp = {\n prefix: 'fas',\n iconName: 'angles-up',\n icon: [448, 512, [\"angle-double-up\"], \"f102\", \"M246.6 41.4c-12.5-12.5-32.8-12.5-45.3 0l-160 160c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0L224 109.3 361.4 246.6c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3l-160-160zm160 352l-160-160c-12.5-12.5-32.8-12.5-45.3 0l-160 160c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0L224 301.3 361.4 438.6c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3z\"]\n};\nconst faAngleDoubleUp = faAnglesUp;\nconst faPaperclip = {\n prefix: 'fas',\n iconName: 'paperclip',\n icon: [448, 512, [128206], \"f0c6\", \"M364.2 83.8c-24.4-24.4-64-24.4-88.4 0l-184 184c-42.1 42.1-42.1 110.3 0 152.4s110.3 42.1 152.4 0l152-152c10.9-10.9 28.7-10.9 39.6 0s10.9 28.7 0 39.6l-152 152c-64 64-167.6 64-231.6 0s-64-167.6 0-231.6l184-184c46.3-46.3 121.3-46.3 167.6 0s46.3 121.3 0 167.6l-176 176c-28.6 28.6-75 28.6-103.6 0s-28.6-75 0-103.6l144-144c10.9-10.9 28.7-10.9 39.6 0s10.9 28.7 0 39.6l-144 144c-6.7 6.7-6.7 17.7 0 24.4s17.7 6.7 24.4 0l176-176c24.4-24.4 24.4-64 0-88.4z\"]\n};\nconst faArrowRightToCity = {\n prefix: 'fas',\n iconName: 'arrow-right-to-city',\n icon: [640, 512, [], \"e4b3\", \"M288 48c0-26.5 21.5-48 48-48l96 0c26.5 0 48 21.5 48 48l0 144 40 0 0-72c0-13.3 10.7-24 24-24s24 10.7 24 24l0 72 24 0c26.5 0 48 21.5 48 48l0 224c0 26.5-21.5 48-48 48l-160 0-96 0c-26.5 0-48-21.5-48-48l0-416zm64 32l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0c-8.8 0-16 7.2-16 16zm16 80c-8.8 0-16 7.2-16 16l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0zM352 272l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0c-8.8 0-16 7.2-16 16zm176-16c-8.8 0-16 7.2-16 16l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0zM512 368l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0c-8.8 0-16 7.2-16 16zM166.6 153.4l80 80c12.5 12.5 12.5 32.8 0 45.3l-80 80c-12.5 12.5-32.8 12.5-45.3 0s-12.5-32.8 0-45.3L146.7 288 32 288c-17.7 0-32-14.3-32-32s14.3-32 32-32l114.7 0-25.4-25.4c-12.5-12.5-12.5-32.8 0-45.3s32.8-12.5 45.3 0z\"]\n};\nconst faRibbon = {\n prefix: 'fas',\n iconName: 'ribbon',\n icon: [448, 512, [127895], \"f4d6\", \"M333.2 322.8s0 0 0 0l-133.9-146s0 0 0 0L146 118.6c7.8-5.1 37-22.6 78-22.6s70.2 17.4 78 22.6L245.7 180l85.6 93.4 27.4-29.8c16.3-17.7 25.3-40.9 25.3-65l0-29.5c0-19-5.6-37.5-16.1-53.3L327.8 35.6C312.9 13.4 287.9 0 261.2 0l-76 0c-25.8 0-50.1 12.5-65.1 33.5L81.9 87C70.3 103.2 64 122.8 64 142.8L64 164c0 23.2 8.4 45.6 23.6 63.1l56 64.2s0 0 0 0l83.3 95.6s0 0 0 0l91.8 105.3c10 11.5 26.8 14.3 40 6.8l54.5-31.1c17.8-10.2 21.6-34.3 7.7-49.4l-87.7-95.7zM205.2 410.6l-83.3-95.6L27.1 418.5c-13.9 15.1-10.1 39.2 7.7 49.4l55.1 31.5c13 7.4 29.3 4.9 39.4-6.1l75.9-82.6z\"]\n};\nconst faLungs = {\n prefix: 'fas',\n iconName: 'lungs',\n icon: [640, 512, [129729], \"f604\", \"M320 0c17.7 0 32 14.3 32 32l0 132.1c0 16.4 8.4 31.7 22.2 40.5l9.8 6.2 0-45.5C384 127 415 96 453.3 96c21.7 0 42.8 10.2 55.8 28.8c15.4 22.1 44.3 65.4 71 116.9c26.5 50.9 52.4 112.5 59.6 170.3c.2 1.3 .2 2.6 .2 4l0 7c0 49.1-39.8 89-89 89c-7.3 0-14.5-.9-21.6-2.7l-72.7-18.2C414 480.5 384 442.1 384 398l0-73 90.5 57.6c7.5 4.7 17.3 2.5 22.1-4.9s2.5-17.3-4.9-22.1L384 287.1l0-.4-44.1-28.1c-7.3-4.6-13.9-10.1-19.9-16.1c-5.9 6-12.6 11.5-19.9 16.1L256 286.7 161.2 347l-13.5 8.6c0 0 0 0-.1 0c-7.4 4.8-9.6 14.6-4.8 22.1c4.7 7.5 14.6 9.7 22.1 4.9l91.1-58 0 73.4c0 44.1-30 82.5-72.7 93.1l-72.7 18.2c-7.1 1.8-14.3 2.7-21.6 2.7c-49.1 0-89-39.8-89-89l0-7c0-1.3 .1-2.7 .2-4c7.2-57.9 33.1-119.4 59.6-170.3c26.8-51.5 55.6-94.8 71-116.9c13-18.6 34-28.8 55.8-28.8C225 96 256 127 256 165.3l0 45.5 9.8-6.2c13.8-8.8 22.2-24.1 22.2-40.5L288 32c0-17.7 14.3-32 32-32z\"]\n};\nconst faArrowUp91 = {\n prefix: 'fas',\n iconName: 'arrow-up-9-1',\n icon: [576, 512, [\"sort-numeric-up-alt\"], \"f887\", \"M160 32c9 0 17.5 3.8 23.6 10.4l88 96c11.9 13 11.1 33.3-2 45.2s-33.3 11.1-45.2-2L192 146.3 192 448c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-301.7L95.6 181.6c-11.9 13-32.2 13.9-45.2 2s-13.9-32.2-2-45.2l88-96C142.5 35.8 151 32 160 32zM450.7 294c8.3 6 13.3 15.7 13.3 26l0 96 16 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-48 0-48 0c-17.7 0-32-14.3-32-32s14.3-32 32-32l16 0 0-51.6-5.9 2c-16.8 5.6-34.9-3.5-40.5-20.2s3.5-34.9 20.2-40.5l48-16c9.8-3.3 20.5-1.6 28.8 4.4zm-5-145.1A32 32 0 1 0 418.3 91a32 32 0 1 0 27.4 57.9zm-40.7 54.9C369.6 192.4 344 159.2 344 120c0-48.6 39.4-88 88-88s88 39.4 88 88c0 23.5-7.5 46.3-21.5 65.2L449.7 251c-10.5 14.2-30.6 17.2-44.8 6.7s-17.2-30.6-6.7-44.8l6.8-9.2z\"]\n};\nconst faSortNumericUpAlt = faArrowUp91;\nconst faLitecoinSign = {\n prefix: 'fas',\n iconName: 'litecoin-sign',\n icon: [384, 512, [], \"e1d3\", \"M128 64c0-17.7-14.3-32-32-32S64 46.3 64 64l0 149.6L23.2 225.2c-17 4.9-26.8 22.6-22 39.6s22.6 26.8 39.6 22L64 280.1 64 448c0 17.7 14.3 32 32 32l256 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-224 0 0-154.1 136.8-39.1c17-4.9 26.8-22.6 22-39.6s-22.6-26.8-39.6-22L128 195.3 128 64z\"]\n};\nconst faBorderNone = {\n prefix: 'fas',\n iconName: 'border-none',\n icon: [448, 512, [], \"f850\", \"M32 480a32 32 0 1 1 0-64 32 32 0 1 1 0 64zm96-64a32 32 0 1 1 0 64 32 32 0 1 1 0-64zm0-384a32 32 0 1 1 0 64 32 32 0 1 1 0-64zm0 256a32 32 0 1 1 0-64 32 32 0 1 1 0 64zM320 416a32 32 0 1 1 0 64 32 32 0 1 1 0-64zm0-320a32 32 0 1 1 0-64 32 32 0 1 1 0 64zm0 128a32 32 0 1 1 0 64 32 32 0 1 1 0-64zM224 480a32 32 0 1 1 0-64 32 32 0 1 1 0 64zm0-448a32 32 0 1 1 0 64 32 32 0 1 1 0-64zm0 256a32 32 0 1 1 0-64 32 32 0 1 1 0 64zM416 416a32 32 0 1 1 0 64 32 32 0 1 1 0-64zm0-384a32 32 0 1 1 0 64 32 32 0 1 1 0-64zM32 96a32 32 0 1 1 0-64 32 32 0 1 1 0 64zM416 224a32 32 0 1 1 0 64 32 32 0 1 1 0-64zM32 288a32 32 0 1 1 0-64 32 32 0 1 1 0 64zm192 32a32 32 0 1 1 0 64 32 32 0 1 1 0-64zm192 64a32 32 0 1 1 0-64 32 32 0 1 1 0 64zM32 320a32 32 0 1 1 0 64 32 32 0 1 1 0-64zM416 192a32 32 0 1 1 0-64 32 32 0 1 1 0 64zM32 128a32 32 0 1 1 0 64 32 32 0 1 1 0-64zm192 64a32 32 0 1 1 0-64 32 32 0 1 1 0 64z\"]\n};\nconst faCircleNodes = {\n prefix: 'fas',\n iconName: 'circle-nodes',\n icon: [512, 512, [], \"e4e2\", \"M418.4 157.9c35.3-8.3 61.6-40 61.6-77.9c0-44.2-35.8-80-80-80c-43.4 0-78.7 34.5-80 77.5L136.2 151.1C121.7 136.8 101.9 128 80 128c-44.2 0-80 35.8-80 80s35.8 80 80 80c12.2 0 23.8-2.7 34.1-7.6L259.7 407.8c-2.4 7.6-3.7 15.8-3.7 24.2c0 44.2 35.8 80 80 80s80-35.8 80-80c0-27.7-14-52.1-35.4-66.4l37.8-207.7zM156.3 232.2c2.2-6.9 3.5-14.2 3.7-21.7l183.8-73.5c3.6 3.5 7.4 6.7 11.6 9.5L317.6 354.1c-5.5 1.3-10.8 3.1-15.8 5.5L156.3 232.2z\"]\n};\nconst faParachuteBox = {\n prefix: 'fas',\n iconName: 'parachute-box',\n icon: [512, 512, [], \"f4cd\", \"M383.5 192c.3-5.3 .5-10.6 .5-16c0-51-15.9-96-40.2-127.6C319.5 16.9 288.2 0 256 0s-63.5 16.9-87.8 48.4C143.9 80 128 125 128 176c0 5.4 .2 10.7 .5 16L240 192l0 128-32 0c-7 0-13.7 1.5-19.7 4.2L68.2 192l28.3 0c-.3-5.3-.5-10.6-.5-16c0-64 22.2-121.2 57.1-159.3C62 49.3 18.6 122.6 4.2 173.6C1.5 183.1 9 192 18.9 192l6 0L165.2 346.3c-3.3 6.5-5.2 13.9-5.2 21.7l0 96c0 26.5 21.5 48 48 48l96 0c26.5 0 48-21.5 48-48l0-96c0-7.8-1.9-15.2-5.2-21.7L487.1 192l6 0c9.9 0 17.4-8.9 14.7-18.4C493.4 122.6 450 49.3 358.9 16.7C393.8 54.8 416 112.1 416 176c0 5.4-.2 10.7-.5 16l28.3 0L323.7 324.2c-6-2.7-12.7-4.2-19.7-4.2l-32 0 0-128 111.5 0z\"]\n};\nconst faIndent = {\n prefix: 'fas',\n iconName: 'indent',\n icon: [448, 512, [], \"f03c\", \"M0 64C0 46.3 14.3 32 32 32l384 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L32 96C14.3 96 0 81.7 0 64zM192 192c0-17.7 14.3-32 32-32l192 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-192 0c-17.7 0-32-14.3-32-32zm32 96l192 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-192 0c-17.7 0-32-14.3-32-32s14.3-32 32-32zM0 448c0-17.7 14.3-32 32-32l384 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L32 480c-17.7 0-32-14.3-32-32zM127.8 268.6L25.8 347.9C15.3 356.1 0 348.6 0 335.3L0 176.7c0-13.3 15.3-20.8 25.8-12.6l101.9 79.3c8.2 6.4 8.2 18.9 0 25.3z\"]\n};\nconst faTruckFieldUn = {\n prefix: 'fas',\n iconName: 'truck-field-un',\n icon: [640, 512, [], \"e58e\", \"M96 32C60.7 32 32 60.7 32 96l0 32c-17.7 0-32 14.3-32 32l0 96c0 17.7 14.3 32 32 32l0 32c-17.7 0-32 14.3-32 32s14.3 32 32 32l32 0c0 53 43 96 96 96s96-43 96-96l128 0c0 53 43 96 96 96s96-43 96-96l32 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l0-32c0-35.3-28.7-64-64-64l-4.2 0c-.4-1.1-.9-2.1-1.3-3.2L485.7 102c-10.3-23.1-33.2-38-58.5-38l-51.8 0C364.4 44.9 343.7 32 320 32L96 32zm288 96l43.2 0 42.7 96L384 224l0-96zM112 384a48 48 0 1 1 96 0 48 48 0 1 1 -96 0zm368-48a48 48 0 1 1 0 96 48 48 0 1 1 0-96zM253.3 135.1l34.7 52 0-43.2c0-8.8 7.2-16 16-16s16 7.2 16 16l0 96c0 7.1-4.6 13.3-11.4 15.3s-14-.6-17.9-6.4l-34.7-52 0 43.2c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-96c0-7.1 4.6-13.3 11.4-15.3s14 .6 17.9 6.4zM128 144l0 64c0 8.8 7.2 16 16 16s16-7.2 16-16l0-64c0-8.8 7.2-16 16-16s16 7.2 16 16l0 64c0 26.5-21.5 48-48 48s-48-21.5-48-48l0-64c0-8.8 7.2-16 16-16s16 7.2 16 16z\"]\n};\nconst faHourglass = {\n prefix: 'fas',\n iconName: 'hourglass',\n icon: [384, 512, [9203, 62032, \"hourglass-empty\"], \"f254\", \"M0 32C0 14.3 14.3 0 32 0L64 0 320 0l32 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l0 11c0 42.4-16.9 83.1-46.9 113.1L237.3 256l67.9 67.9c30 30 46.9 70.7 46.9 113.1l0 11c17.7 0 32 14.3 32 32s-14.3 32-32 32l-32 0L64 512l-32 0c-17.7 0-32-14.3-32-32s14.3-32 32-32l0-11c0-42.4 16.9-83.1 46.9-113.1L146.7 256 78.9 188.1C48.9 158.1 32 117.4 32 75l0-11C14.3 64 0 49.7 0 32zM96 64l0 11c0 25.5 10.1 49.9 28.1 67.9L192 210.7l67.9-67.9c18-18 28.1-42.4 28.1-67.9l0-11L96 64zm0 384l192 0 0-11c0-25.5-10.1-49.9-28.1-67.9L192 301.3l-67.9 67.9c-18 18-28.1 42.4-28.1 67.9l0 11z\"]\n};\nconst faHourglassEmpty = faHourglass;\nconst faMountain = {\n prefix: 'fas',\n iconName: 'mountain',\n icon: [512, 512, [127956], \"f6fc\", \"M256 32c12.5 0 24.1 6.4 30.8 17L503.4 394.4c5.6 8.9 8.6 19.2 8.6 29.7c0 30.9-25 55.9-55.9 55.9L55.9 480C25 480 0 455 0 424.1c0-10.5 3-20.8 8.6-29.7L225.2 49c6.6-10.6 18.3-17 30.8-17zm65 192L256 120.4 176.9 246.5l18.3 24.4c6.4 8.5 19.2 8.5 25.6 0l25.6-34.1c6-8.1 15.5-12.8 25.6-12.8l49 0z\"]\n};\nconst faUserDoctor = {\n prefix: 'fas',\n iconName: 'user-doctor',\n icon: [448, 512, [\"user-md\"], \"f0f0\", \"M224 256A128 128 0 1 0 224 0a128 128 0 1 0 0 256zm-96 55.2C54 332.9 0 401.3 0 482.3C0 498.7 13.3 512 29.7 512l388.6 0c16.4 0 29.7-13.3 29.7-29.7c0-81-54-149.4-128-171.1l0 50.8c27.6 7.1 48 32.2 48 62l0 40c0 8.8-7.2 16-16 16l-16 0c-8.8 0-16-7.2-16-16s7.2-16 16-16l0-24c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 24c8.8 0 16 7.2 16 16s-7.2 16-16 16l-16 0c-8.8 0-16-7.2-16-16l0-40c0-29.8 20.4-54.9 48-62l0-57.1c-6-.6-12.1-.9-18.3-.9l-91.4 0c-6.2 0-12.3 .3-18.3 .9l0 65.4c23.1 6.9 40 28.3 40 53.7c0 30.9-25.1 56-56 56s-56-25.1-56-56c0-25.4 16.9-46.8 40-53.7l0-59.1zM144 448a24 24 0 1 0 0-48 24 24 0 1 0 0 48z\"]\n};\nconst faUserMd = faUserDoctor;\nconst faCircleInfo = {\n prefix: 'fas',\n iconName: 'circle-info',\n icon: [512, 512, [\"info-circle\"], \"f05a\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM216 336l24 0 0-64-24 0c-13.3 0-24-10.7-24-24s10.7-24 24-24l48 0c13.3 0 24 10.7 24 24l0 88 8 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-80 0c-13.3 0-24-10.7-24-24s10.7-24 24-24zm40-208a32 32 0 1 1 0 64 32 32 0 1 1 0-64z\"]\n};\nconst faInfoCircle = faCircleInfo;\nconst faCloudMeatball = {\n prefix: 'fas',\n iconName: 'cloud-meatball',\n icon: [512, 512, [], \"f73b\", \"M0 224c0 53 43 96 96 96l44.7 0c9.5-23.5 32.5-40 59.3-40c2 0 3.9 .1 5.8 .3C217.6 265.5 235.7 256 256 256s38.4 9.5 50.2 24.3c1.9-.2 3.9-.3 5.8-.3c26.9 0 49.9 16.5 59.3 40l44.7 0c53 0 96-43 96-96s-43-96-96-96c-.5 0-1.1 0-1.6 0c1.1-5.2 1.6-10.5 1.6-16c0-44.2-35.8-80-80-80c-24.3 0-46.1 10.9-60.8 28C256.5 24.3 219.1 0 176 0C114.1 0 64 50.1 64 112c0 7.1 .7 14.1 1.9 20.8C27.6 145.4 0 181.5 0 224zm288 96c0-17.7-14.3-32-32-32s-32 14.3-32 32c0 1 .1 2.1 .1 3.1c-.7-.8-1.4-1.6-2.1-2.3c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3c.7 .7 1.5 1.4 2.3 2.1c-1-.1-2.1-.1-3.1-.1c-17.7 0-32 14.3-32 32s14.3 32 32 32c1 0 2.1-.1 3.1-.1c-.8 .7-1.6 1.3-2.3 2.1c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0c.7-.7 1.4-1.5 2.1-2.3c-.1 1-.1 2.1-.1 3.1c0 17.7 14.3 32 32 32s32-14.3 32-32c0-1-.1-2.1-.1-3.1c.7 .8 1.3 1.6 2.1 2.3c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3c-.7-.7-1.5-1.4-2.3-2.1c1 .1 2.1 .1 3.1 .1c17.7 0 32-14.3 32-32s-14.3-32-32-32c-1 0-2.1 .1-3.1 .1c.8-.7 1.6-1.3 2.3-2.1c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0c-.7 .7-1.4 1.5-2.1 2.3c.1-1 .1-2.1 .1-3.1zM48 448a48 48 0 1 0 0-96 48 48 0 1 0 0 96zm416 0a48 48 0 1 0 0-96 48 48 0 1 0 0 96z\"]\n};\nconst faCamera = {\n prefix: 'fas',\n iconName: 'camera',\n icon: [512, 512, [62258, \"camera-alt\"], \"f030\", \"M149.1 64.8L138.7 96 64 96C28.7 96 0 124.7 0 160L0 416c0 35.3 28.7 64 64 64l384 0c35.3 0 64-28.7 64-64l0-256c0-35.3-28.7-64-64-64l-74.7 0L362.9 64.8C356.4 45.2 338.1 32 317.4 32L194.6 32c-20.7 0-39 13.2-45.5 32.8zM256 192a96 96 0 1 1 0 192 96 96 0 1 1 0-192z\"]\n};\nconst faCameraAlt = faCamera;\nconst faSquareVirus = {\n prefix: 'fas',\n iconName: 'square-virus',\n icon: [448, 512, [], \"e578\", \"M64 32C28.7 32 0 60.7 0 96L0 416c0 35.3 28.7 64 64 64l320 0c35.3 0 64-28.7 64-64l0-320c0-35.3-28.7-64-64-64L64 32zM223.8 93.7c13.3 0 24 10.7 24 24c0 29.3 35.4 43.9 56.1 23.2c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9c-20.7 20.7-6 56.1 23.2 56.1c13.3 0 24 10.7 24 24s-10.7 24-24 24c-29.3 0-43.9 35.4-23.2 56.1c9.4 9.4 9.4 24.6 0 33.9s-24.6 9.4-33.9 0c-20.7-20.7-56.1-6-56.1 23.2c0 13.3-10.7 24-24 24s-24-10.7-24-24c0-29.3-35.4-43.9-56.1-23.2c-9.4 9.4-24.6 9.4-33.9 0s-9.4-24.6 0-33.9c20.7-20.7 6-56.1-23.2-56.1c-13.3 0-24-10.7-24-24s10.7-24 24-24c29.3 0 43.9-35.4 23.2-56.1c-9.4-9.4-9.4-24.6 0-33.9s24.6-9.4 33.9 0c20.7 20.7 56.1 6 56.1-23.2c0-13.3 10.7-24 24-24zM192 256a32 32 0 1 0 0-64 32 32 0 1 0 0 64zm88 32a24 24 0 1 0 -48 0 24 24 0 1 0 48 0z\"]\n};\nconst faMeteor = {\n prefix: 'fas',\n iconName: 'meteor',\n icon: [512, 512, [9732], \"f753\", \"M493.7 .9L299.4 75.6l2.3-29.3c1-12.8-12.8-21.5-24-15.1L101.3 133.4C38.6 169.7 0 236.6 0 309C0 421.1 90.9 512 203 512c72.4 0 139.4-38.6 175.7-101.3L480.8 234.3c6.5-11.1-2.2-25-15.1-24l-29.3 2.3L511.1 18.3c.6-1.5 .9-3.2 .9-4.8C512 6 506 0 498.5 0c-1.7 0-3.3 .3-4.8 .9zM192 192a128 128 0 1 1 0 256 128 128 0 1 1 0-256zm0 96a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zm16 96a16 16 0 1 0 0-32 16 16 0 1 0 0 32z\"]\n};\nconst faCarOn = {\n prefix: 'fas',\n iconName: 'car-on',\n icon: [512, 512, [], \"e4dd\", \"M280 24c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 80c0 13.3 10.7 24 24 24s24-10.7 24-24l0-80zM185.8 224l140.3 0c6.8 0 12.8 4.3 15.1 10.6L360.3 288l-208.6 0 19.1-53.4c2.3-6.4 8.3-10.6 15.1-10.6zm-75.3-10.9L82.2 292.4C62.1 300.9 48 320.8 48 344l0 40 0 64 0 32c0 17.7 14.3 32 32 32l16 0c17.7 0 32-14.3 32-32l0-32 256 0 0 32c0 17.7 14.3 32 32 32l16 0c17.7 0 32-14.3 32-32l0-32 0-64 0-40c0-23.2-14.1-43.1-34.2-51.6l-28.3-79.3C390.1 181.3 360 160 326.2 160l-140.3 0c-33.8 0-64 21.3-75.3 53.1zM128 344a24 24 0 1 1 0 48 24 24 0 1 1 0-48zm232 24a24 24 0 1 1 48 0 24 24 0 1 1 -48 0zM39 39c-9.4 9.4-9.4 24.6 0 33.9l48 48c9.4 9.4 24.6 9.4 33.9 0s9.4-24.6 0-33.9L73 39c-9.4-9.4-24.6-9.4-33.9 0zm400 0L391 87c-9.4 9.4-9.4 24.6 0 33.9s24.6 9.4 33.9 0l48-48c9.4-9.4 9.4-24.6 0-33.9s-24.6-9.4-33.9 0z\"]\n};\nconst faSleigh = {\n prefix: 'fas',\n iconName: 'sleigh',\n icon: [640, 512, [], \"f7cc\", \"M32 32C14.3 32 0 46.3 0 64S14.3 96 32 96l0 160c0 53 43 96 96 96l0 32 64 0 0-32 192 0 0 32 64 0 0-32c53 0 96-43 96-96l0-96c17.7 0 32-14.3 32-32s-14.3-32-32-32l-32 0-32 0c-17.7 0-32 14.3-32 32l0 41.3c0 30.2-24.5 54.7-54.7 54.7c-75.5 0-145.6-38.9-185.6-102.9l-4.3-6.9C174.2 67.6 125 37.6 70.7 32.7c-2.2-.5-4.4-.7-6.7-.7l-9 0L32 32zM640 384c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 8c0 13.3-10.7 24-24 24L64 416c-17.7 0-32 14.3-32 32s14.3 32 32 32l488 0c48.6 0 88-39.4 88-88l0-8z\"]\n};\nconst faArrowDown19 = {\n prefix: 'fas',\n iconName: 'arrow-down-1-9',\n icon: [576, 512, [\"sort-numeric-asc\", \"sort-numeric-down\"], \"f162\", \"M450.7 38c-8.3-6-19.1-7.7-28.8-4.4l-48 16c-16.8 5.6-25.8 23.7-20.2 40.5s23.7 25.8 40.5 20.2l5.9-2 0 51.6-16 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l48 0 48 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-16 0 0-96c0-10.3-4.9-19.9-13.3-26zM160 480c9 0 17.5-3.8 23.6-10.4l88-96c11.9-13 11.1-33.3-2-45.2s-33.3-11.1-45.2 2L192 365.7 192 64c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 301.7L95.6 330.4c-11.9-13-32.2-13.9-45.2-2s-13.9 32.2-2 45.2l88 96C142.5 476.2 151 480 160 480zM418.3 307a32 32 0 1 1 27.4 57.9A32 32 0 1 1 418.3 307zM405.1 419.8l-6.8 9.2c-10.5 14.2-7.5 34.2 6.7 44.8s34.2 7.5 44.8-6.7l48.8-65.8c14-18.9 21.5-41.7 21.5-65.2c0-48.6-39.4-88-88-88s-88 39.4-88 88c0 39.2 25.6 72.4 61.1 83.8z\"]\n};\nconst faSortNumericAsc = faArrowDown19;\nconst faSortNumericDown = faArrowDown19;\nconst faHandHoldingDroplet = {\n prefix: 'fas',\n iconName: 'hand-holding-droplet',\n icon: [576, 512, [\"hand-holding-water\"], \"f4c1\", \"M275.5 6.6C278.3 2.5 283 0 288 0s9.7 2.5 12.5 6.6L366.8 103C378 119.3 384 138.6 384 158.3l0 1.7c0 53-43 96-96 96s-96-43-96-96l0-1.7c0-19.8 6-39 17.2-55.3L275.5 6.6zM568.2 336.3c13.1 17.8 9.3 42.8-8.5 55.9L433.1 485.5c-23.4 17.2-51.6 26.5-80.7 26.5L192 512 32 512c-17.7 0-32-14.3-32-32l0-64c0-17.7 14.3-32 32-32l36.8 0 44.9-36c22.7-18.2 50.9-28 80-28l78.3 0 16 0 64 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-64 0-16 0c-8.8 0-16 7.2-16 16s7.2 16 16 16l120.6 0 119.7-88.2c17.8-13.1 42.8-9.3 55.9 8.5zM193.6 384c0 0 0 0 0 0l-.9 0c.3 0 .6 0 .9 0z\"]\n};\nconst faHandHoldingWater = faHandHoldingDroplet;\nconst faWater = {\n prefix: 'fas',\n iconName: 'water',\n icon: [576, 512, [], \"f773\", \"M269.5 69.9c11.1-7.9 25.9-7.9 37 0C329 85.4 356.5 96 384 96c26.9 0 55.4-10.8 77.4-26.1c0 0 0 0 0 0c11.9-8.5 28.1-7.8 39.2 1.7c14.4 11.9 32.5 21 50.6 25.2c17.2 4 27.9 21.2 23.9 38.4s-21.2 27.9-38.4 23.9c-24.5-5.7-44.9-16.5-58.2-25C449.5 149.7 417 160 384 160c-31.9 0-60.6-9.9-80.4-18.9c-5.8-2.7-11.1-5.3-15.6-7.7c-4.5 2.4-9.7 5.1-15.6 7.7c-19.8 9-48.5 18.9-80.4 18.9c-33 0-65.5-10.3-94.5-25.8c-13.4 8.4-33.7 19.3-58.2 25c-17.2 4-34.4-6.7-38.4-23.9s6.7-34.4 23.9-38.4C42.8 92.6 61 83.5 75.3 71.6c11.1-9.5 27.3-10.1 39.2-1.7c0 0 0 0 0 0C136.7 85.2 165.1 96 192 96c27.5 0 55-10.6 77.5-26.1zm37 288C329 373.4 356.5 384 384 384c26.9 0 55.4-10.8 77.4-26.1c0 0 0 0 0 0c11.9-8.5 28.1-7.8 39.2 1.7c14.4 11.9 32.5 21 50.6 25.2c17.2 4 27.9 21.2 23.9 38.4s-21.2 27.9-38.4 23.9c-24.5-5.7-44.9-16.5-58.2-25C449.5 437.7 417 448 384 448c-31.9 0-60.6-9.9-80.4-18.9c-5.8-2.7-11.1-5.3-15.6-7.7c-4.5 2.4-9.7 5.1-15.6 7.7c-19.8 9-48.5 18.9-80.4 18.9c-33 0-65.5-10.3-94.5-25.8c-13.4 8.4-33.7 19.3-58.2 25c-17.2 4-34.4-6.7-38.4-23.9s6.7-34.4 23.9-38.4c18.1-4.2 36.2-13.3 50.6-25.2c11.1-9.4 27.3-10.1 39.2-1.7c0 0 0 0 0 0C136.7 373.2 165.1 384 192 384c27.5 0 55-10.6 77.5-26.1c11.1-7.9 25.9-7.9 37 0zm0-144C329 229.4 356.5 240 384 240c26.9 0 55.4-10.8 77.4-26.1c0 0 0 0 0 0c11.9-8.5 28.1-7.8 39.2 1.7c14.4 11.9 32.5 21 50.6 25.2c17.2 4 27.9 21.2 23.9 38.4s-21.2 27.9-38.4 23.9c-24.5-5.7-44.9-16.5-58.2-25C449.5 293.7 417 304 384 304c-31.9 0-60.6-9.9-80.4-18.9c-5.8-2.7-11.1-5.3-15.6-7.7c-4.5 2.4-9.7 5.1-15.6 7.7c-19.8 9-48.5 18.9-80.4 18.9c-33 0-65.5-10.3-94.5-25.8c-13.4 8.4-33.7 19.3-58.2 25c-17.2 4-34.4-6.7-38.4-23.9s6.7-34.4 23.9-38.4c18.1-4.2 36.2-13.3 50.6-25.2c11.1-9.5 27.3-10.1 39.2-1.7c0 0 0 0 0 0C136.7 229.2 165.1 240 192 240c27.5 0 55-10.6 77.5-26.1c11.1-7.9 25.9-7.9 37 0z\"]\n};\nconst faCalendarCheck = {\n prefix: 'fas',\n iconName: 'calendar-check',\n icon: [448, 512, [], \"f274\", \"M128 0c17.7 0 32 14.3 32 32l0 32 128 0 0-32c0-17.7 14.3-32 32-32s32 14.3 32 32l0 32 48 0c26.5 0 48 21.5 48 48l0 48L0 160l0-48C0 85.5 21.5 64 48 64l48 0 0-32c0-17.7 14.3-32 32-32zM0 192l448 0 0 272c0 26.5-21.5 48-48 48L48 512c-26.5 0-48-21.5-48-48L0 192zM329 305c9.4-9.4 9.4-24.6 0-33.9s-24.6-9.4-33.9 0l-95 95-47-47c-9.4-9.4-24.6-9.4-33.9 0s-9.4 24.6 0 33.9l64 64c9.4 9.4 24.6 9.4 33.9 0L329 305z\"]\n};\nconst faBraille = {\n prefix: 'fas',\n iconName: 'braille',\n icon: [640, 512, [], \"f2a1\", \"M0 96a64 64 0 1 1 128 0A64 64 0 1 1 0 96zM224 272a16 16 0 1 0 0-32 16 16 0 1 0 0 32zm0-80a64 64 0 1 1 0 128 64 64 0 1 1 0-128zM80 416a16 16 0 1 0 -32 0 16 16 0 1 0 32 0zM0 416a64 64 0 1 1 128 0A64 64 0 1 1 0 416zm240 0a16 16 0 1 0 -32 0 16 16 0 1 0 32 0zm-80 0a64 64 0 1 1 128 0 64 64 0 1 1 -128 0zM64 192a64 64 0 1 1 0 128 64 64 0 1 1 0-128zM224 32a64 64 0 1 1 0 128 64 64 0 1 1 0-128zM352 96a64 64 0 1 1 128 0A64 64 0 1 1 352 96zm240 0a16 16 0 1 0 -32 0 16 16 0 1 0 32 0zm-80 0a64 64 0 1 1 128 0A64 64 0 1 1 512 96zm64 176a16 16 0 1 0 0-32 16 16 0 1 0 0 32zm0-80a64 64 0 1 1 0 128 64 64 0 1 1 0-128zm16 224a16 16 0 1 0 -32 0 16 16 0 1 0 32 0zm-80 0a64 64 0 1 1 128 0 64 64 0 1 1 -128 0zM416 272a16 16 0 1 0 0-32 16 16 0 1 0 0 32zm0-80a64 64 0 1 1 0 128 64 64 0 1 1 0-128zm16 224a16 16 0 1 0 -32 0 16 16 0 1 0 32 0zm-80 0a64 64 0 1 1 128 0 64 64 0 1 1 -128 0z\"]\n};\nconst faPrescriptionBottleMedical = {\n prefix: 'fas',\n iconName: 'prescription-bottle-medical',\n icon: [384, 512, [\"prescription-bottle-alt\"], \"f486\", \"M0 32C0 14.3 14.3 0 32 0L352 0c17.7 0 32 14.3 32 32l0 32c0 17.7-14.3 32-32 32L32 96C14.3 96 0 81.7 0 64L0 32zm32 96l320 0 0 320c0 35.3-28.7 64-64 64L96 512c-35.3 0-64-28.7-64-64l0-320zM160 240l0 48-48 0c-8.8 0-16 7.2-16 16l0 32c0 8.8 7.2 16 16 16l48 0 0 48c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-48 48 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-48 0 0-48c0-8.8-7.2-16-16-16l-32 0c-8.8 0-16 7.2-16 16z\"]\n};\nconst faPrescriptionBottleAlt = faPrescriptionBottleMedical;\nconst faLandmark = {\n prefix: 'fas',\n iconName: 'landmark',\n icon: [512, 512, [127963], \"f66f\", \"M240.1 4.2c9.8-5.6 21.9-5.6 31.8 0l171.8 98.1L448 104l0 .9 47.9 27.4c12.6 7.2 18.8 22 15.1 36s-16.4 23.8-30.9 23.8L32 192c-14.5 0-27.2-9.8-30.9-23.8s2.5-28.8 15.1-36L64 104.9l0-.9 4.4-1.6L240.1 4.2zM64 224l64 0 0 192 40 0 0-192 64 0 0 192 48 0 0-192 64 0 0 192 40 0 0-192 64 0 0 196.3c.6 .3 1.2 .7 1.8 1.1l48 32c11.7 7.8 17 22.4 12.9 35.9S494.1 512 480 512L32 512c-14.1 0-26.5-9.2-30.6-22.7s1.1-28.1 12.9-35.9l48-32c.6-.4 1.2-.7 1.8-1.1L64 224z\"]\n};\nconst faTruck = {\n prefix: 'fas',\n iconName: 'truck',\n icon: [640, 512, [128666, 9951], \"f0d1\", \"M48 0C21.5 0 0 21.5 0 48L0 368c0 26.5 21.5 48 48 48l16 0c0 53 43 96 96 96s96-43 96-96l128 0c0 53 43 96 96 96s96-43 96-96l32 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l0-64 0-32 0-18.7c0-17-6.7-33.3-18.7-45.3L512 114.7c-12-12-28.3-18.7-45.3-18.7L416 96l0-48c0-26.5-21.5-48-48-48L48 0zM416 160l50.7 0L544 237.3l0 18.7-128 0 0-96zM112 416a48 48 0 1 1 96 0 48 48 0 1 1 -96 0zm368-48a48 48 0 1 1 0 96 48 48 0 1 1 0-96z\"]\n};\nconst faCrosshairs = {\n prefix: 'fas',\n iconName: 'crosshairs',\n icon: [512, 512, [], \"f05b\", \"M256 0c17.7 0 32 14.3 32 32l0 10.4c93.7 13.9 167.7 88 181.6 181.6l10.4 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-10.4 0c-13.9 93.7-88 167.7-181.6 181.6l0 10.4c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-10.4C130.3 455.7 56.3 381.7 42.4 288L32 288c-17.7 0-32-14.3-32-32s14.3-32 32-32l10.4 0C56.3 130.3 130.3 56.3 224 42.4L224 32c0-17.7 14.3-32 32-32zM107.4 288c12.5 58.3 58.4 104.1 116.6 116.6l0-20.6c0-17.7 14.3-32 32-32s32 14.3 32 32l0 20.6c58.3-12.5 104.1-58.4 116.6-116.6L384 288c-17.7 0-32-14.3-32-32s14.3-32 32-32l20.6 0C392.1 165.7 346.3 119.9 288 107.4l0 20.6c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-20.6C165.7 119.9 119.9 165.7 107.4 224l20.6 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-20.6 0zM256 224a32 32 0 1 1 0 64 32 32 0 1 1 0-64z\"]\n};\nconst faPersonCane = {\n prefix: 'fas',\n iconName: 'person-cane',\n icon: [448, 512, [], \"e53c\", \"M272 48a48 48 0 1 0 -96 0 48 48 0 1 0 96 0zm-8 187.3l47.4 57.1c11.3 13.6 31.5 15.5 45.1 4.2s15.5-31.5 4.2-45.1l-73.7-88.9c-18.2-22-45.3-34.7-73.9-34.7l-35.9 0c-33.7 0-64.9 17.7-82.3 46.6l-58.3 97c-9.1 15.1-4.2 34.8 10.9 43.9s34.8 4.2 43.9-10.9L120 256.9 120 480c0 17.7 14.3 32 32 32s32-14.3 32-32l0-128 16 0 0 128c0 17.7 14.3 32 32 32s32-14.3 32-32l0-244.7zM352 376c0-4.4 3.6-8 8-8s8 3.6 8 8l0 112c0 13.3 10.7 24 24 24s24-10.7 24-24l0-112c0-30.9-25.1-56-56-56s-56 25.1-56 56l0 8c0 13.3 10.7 24 24 24s24-10.7 24-24l0-8z\"]\n};\nconst faTent = {\n prefix: 'fas',\n iconName: 'tent',\n icon: [576, 512, [], \"e57d\", \"M269.4 6C280.5-2 295.5-2 306.6 6l224 160c7.4 5.3 12.2 13.5 13.2 22.5l32 288c1 9-1.9 18.1-8 24.9s-14.7 10.7-23.8 10.7l-80 0-28.2 0c-12.1 0-23.2-6.8-28.6-17.7L306.7 293.5c-1.7-3.4-5.1-5.5-8.8-5.5c-5.5 0-9.9 4.4-9.9 9.9L288 480c0 17.7-14.3 32-32 32l-16 0L32 512c-9.1 0-17.8-3.9-23.8-10.7s-9-15.8-8-24.9l32-288c1-9 5.8-17.2 13.2-22.5L269.4 6z\"]\n};\nconst faVestPatches = {\n prefix: 'fas',\n iconName: 'vest-patches',\n icon: [448, 512, [], \"e086\", \"M151.2 69.7l55.9 167.7-11 33.1c-2.7 8.2-4.1 16.7-4.1 25.3L192 464c0 14.5 3.9 28.2 10.7 39.9C195 509 185.9 512 176 512L48 512c-26.5 0-48-21.5-48-48L0 270.5c0-9.5 2.8-18.7 8.1-26.6l47.9-71.8c5.3-7.9 8.1-17.1 8.1-26.6L64 128l0-73.7L64 48C64 21.5 85.5 0 112 0l4.5 0c.2 0 .4 0 .6 0c.4 0 .8 0 1.2 0c18.8 0 34.1 9.7 44.1 18.8C171.6 27.2 190.8 40 224 40s52.4-12.8 61.7-21.2C295.7 9.7 311 0 329.7 0c.4 0 .8 0 1.2 0c.2 0 .4 0 .6 0L336 0c26.5 0 48 21.5 48 48l0 6.3 0 73.7 0 17.5c0 9.5 2.8 18.7 8.1 26.6l47.9 71.8c5.3 7.9 8.1 17.1 8.1 26.6L448 464c0 26.5-21.5 48-48 48l-128 0c-26.5 0-48-21.5-48-48l0-168.2c0-5.2 .8-10.3 2.5-15.2L296.8 69.7C279.4 79.7 255.4 88 224 88s-55.4-8.3-72.8-18.3zM96 456a40 40 0 1 0 0-80 40 40 0 1 0 0 80zM63.5 255.5c-4.7 4.7-4.7 12.3 0 17L79 288 63.5 303.5c-4.7 4.7-4.7 12.3 0 17s12.3 4.7 17 0L96 305l15.5 15.5c4.7 4.7 12.3 4.7 17 0s4.7-12.3 0-17L113 288l15.5-15.5c4.7-4.7 4.7-12.3 0-17s-12.3-4.7-17 0L96 271 80.5 255.5c-4.7-4.7-12.3-4.7-17 0zM304 280l0 8 0 32c0 8.8 7.2 16 16 16l32 0 8 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-8 0 0-8c0-13.3-10.7-24-24-24s-24 10.7-24 24z\"]\n};\nconst faCheckDouble = {\n prefix: 'fas',\n iconName: 'check-double',\n icon: [448, 512, [], \"f560\", \"M342.6 86.6c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0L160 178.7l-57.4-57.4c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3l80 80c12.5 12.5 32.8 12.5 45.3 0l160-160zm96 128c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0L160 402.7 54.6 297.4c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3l128 128c12.5 12.5 32.8 12.5 45.3 0l256-256z\"]\n};\nconst faArrowDownAZ = {\n prefix: 'fas',\n iconName: 'arrow-down-a-z',\n icon: [576, 512, [\"sort-alpha-asc\", \"sort-alpha-down\"], \"f15d\", \"M183.6 469.6C177.5 476.2 169 480 160 480s-17.5-3.8-23.6-10.4l-88-96c-11.9-13-11.1-33.3 2-45.2s33.3-11.1 45.2 2L128 365.7 128 64c0-17.7 14.3-32 32-32s32 14.3 32 32l0 301.7 32.4-35.4c11.9-13 32.2-13.9 45.2-2s13.9 32.2 2 45.2l-88 96zM320 320c0-17.7 14.3-32 32-32l128 0c12.9 0 24.6 7.8 29.6 19.8s2.2 25.7-6.9 34.9L429.3 416l50.7 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-128 0c-12.9 0-24.6-7.8-29.6-19.8s-2.2-25.7 6.9-34.9L402.7 352 352 352c-17.7 0-32-14.3-32-32zM416 32c12.1 0 23.2 6.8 28.6 17.7l64 128 16 32c7.9 15.8 1.5 35-14.3 42.9s-35 1.5-42.9-14.3L460.2 224l-88.4 0-7.2 14.3c-7.9 15.8-27.1 22.2-42.9 14.3s-22.2-27.1-14.3-42.9l16-32 64-128C392.8 38.8 403.9 32 416 32zM395.8 176l40.4 0L416 135.6 395.8 176z\"]\n};\nconst faSortAlphaAsc = faArrowDownAZ;\nconst faSortAlphaDown = faArrowDownAZ;\nconst faMoneyBillWheat = {\n prefix: 'fas',\n iconName: 'money-bill-wheat',\n icon: [512, 512, [], \"e52a\", \"M176 0c44.2 0 80 35.8 80 80c0 8.8-7.2 16-16 16c-44.2 0-80-35.8-80-80c0-8.8 7.2-16 16-16zM56 16l48 0c13.3 0 24 10.7 24 24s-10.7 24-24 24L56 64C42.7 64 32 53.3 32 40s10.7-24 24-24zM24 88l112 0c13.3 0 24 10.7 24 24s-10.7 24-24 24L24 136c-13.3 0-24-10.7-24-24S10.7 88 24 88zm8 96c0-13.3 10.7-24 24-24l48 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-48 0c-13.3 0-24-10.7-24-24zM272 16c0-8.8 7.2-16 16-16c44.2 0 80 35.8 80 80c0 8.8-7.2 16-16 16c-44.2 0-80-35.8-80-80zM400 0c44.2 0 80 35.8 80 80c0 8.8-7.2 16-16 16c-44.2 0-80-35.8-80-80c0-8.8 7.2-16 16-16zm80 144c0 44.2-35.8 80-80 80c-8.8 0-16-7.2-16-16c0-44.2 35.8-80 80-80c8.8 0 16 7.2 16 16zM352 128c8.8 0 16 7.2 16 16c0 44.2-35.8 80-80 80c-8.8 0-16-7.2-16-16c0-44.2 35.8-80 80-80zm-96 16c0 44.2-35.8 80-80 80c-8.8 0-16-7.2-16-16c0-44.2 35.8-80 80-80c8.8 0 16 7.2 16 16zM0 304c0-26.5 21.5-48 48-48l416 0c26.5 0 48 21.5 48 48l0 160c0 26.5-21.5 48-48 48L48 512c-26.5 0-48-21.5-48-48L0 304zM48 416l0 48 48 0c0-26.5-21.5-48-48-48zM96 304l-48 0 0 48c26.5 0 48-21.5 48-48zM464 416c-26.5 0-48 21.5-48 48l48 0 0-48zM416 304c0 26.5 21.5 48 48 48l0-48-48 0zm-96 80a64 64 0 1 0 -128 0 64 64 0 1 0 128 0z\"]\n};\nconst faCookie = {\n prefix: 'fas',\n iconName: 'cookie',\n icon: [512, 512, [127850], \"f563\", \"M247.2 17c-22.1-3.1-44.6 .9-64.4 11.4l-74 39.5C89.1 78.4 73.2 94.9 63.4 115L26.7 190.6c-9.8 20.1-13 42.9-9.1 64.9l14.5 82.8c3.9 22.1 14.6 42.3 30.7 57.9l60.3 58.4c16.1 15.6 36.6 25.6 58.7 28.7l83 11.7c22.1 3.1 44.6-.9 64.4-11.4l74-39.5c19.7-10.5 35.6-27 45.4-47.2l36.7-75.5c9.8-20.1 13-42.9 9.1-64.9l-14.6-82.8c-3.9-22.1-14.6-42.3-30.7-57.9L388.9 57.5c-16.1-15.6-36.6-25.6-58.7-28.7L247.2 17zM208 144a32 32 0 1 1 0 64 32 32 0 1 1 0-64zM144 336a32 32 0 1 1 64 0 32 32 0 1 1 -64 0zm224-64a32 32 0 1 1 0 64 32 32 0 1 1 0-64z\"]\n};\nconst faArrowRotateLeft = {\n prefix: 'fas',\n iconName: 'arrow-rotate-left',\n icon: [512, 512, [8634, \"arrow-left-rotate\", \"arrow-rotate-back\", \"arrow-rotate-backward\", \"undo\"], \"f0e2\", \"M125.7 160l50.3 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L48 224c-17.7 0-32-14.3-32-32L16 64c0-17.7 14.3-32 32-32s32 14.3 32 32l0 51.2L97.6 97.6c87.5-87.5 229.3-87.5 316.8 0s87.5 229.3 0 316.8s-229.3 87.5-316.8 0c-12.5-12.5-12.5-32.8 0-45.3s32.8-12.5 45.3 0c62.5 62.5 163.8 62.5 226.3 0s62.5-163.8 0-226.3s-163.8-62.5-226.3 0L125.7 160z\"]\n};\nconst faArrowLeftRotate = faArrowRotateLeft;\nconst faArrowRotateBack = faArrowRotateLeft;\nconst faArrowRotateBackward = faArrowRotateLeft;\nconst faUndo = faArrowRotateLeft;\nconst faHardDrive = {\n prefix: 'fas',\n iconName: 'hard-drive',\n icon: [512, 512, [128436, \"hdd\"], \"f0a0\", \"M0 96C0 60.7 28.7 32 64 32l384 0c35.3 0 64 28.7 64 64l0 184.4c-17-15.2-39.4-24.4-64-24.4L64 256c-24.6 0-47 9.2-64 24.4L0 96zM64 288l384 0c35.3 0 64 28.7 64 64l0 64c0 35.3-28.7 64-64 64L64 480c-35.3 0-64-28.7-64-64l0-64c0-35.3 28.7-64 64-64zM320 416a32 32 0 1 0 0-64 32 32 0 1 0 0 64zm128-32a32 32 0 1 0 -64 0 32 32 0 1 0 64 0z\"]\n};\nconst faHdd = faHardDrive;\nconst faFaceGrinSquintTears = {\n prefix: 'fas',\n iconName: 'face-grin-squint-tears',\n icon: [512, 512, [129315, \"grin-squint-tears\"], \"f586\", \"M426.8 14.2C446-5 477.5-4.6 497.1 14.9s20 51 .7 70.3c-6.8 6.8-21.4 12.4-37.4 16.7c-16.3 4.4-34.1 7.5-46.3 9.3c-1.6 .2-3.1 .5-4.6 .6c-4.9 .8-9.1-2.8-9.5-7.4c-.1-.7 0-1.4 .1-2.1c1.6-11.2 4.6-29.6 9-47c.3-1.3 .7-2.6 1-3.9c4.3-15.9 9.8-30.5 16.7-37.4zm-44.7 19c-1.5 4.8-2.9 9.6-4.1 14.3c-4.8 18.9-8 38.5-9.7 50.3c-4 26.8 18.9 49.7 45.7 45.8c11.9-1.6 31.5-4.8 50.4-9.7c4.7-1.2 9.5-2.5 14.3-4.1C534.2 227.5 520.2 353.8 437 437c-83.2 83.2-209.5 97.2-307.2 41.8c1.5-4.8 2.8-9.6 4-14.3c4.8-18.9 8-38.5 9.7-50.3c4-26.8-18.9-49.7-45.7-45.8c-11.9 1.6-31.5 4.8-50.4 9.7c-4.7 1.2-9.5 2.5-14.3 4.1C-22.2 284.5-8.2 158.2 75 75C158.2-8.3 284.5-22.2 382.2 33.2zM51.5 410.1c18.5-5 38.8-8.3 50.9-10c.4-.1 .7-.1 1-.1c5.1-.2 9.2 4.3 8.4 9.6c-1.7 12.1-5 32.4-10 50.9C97.6 476.4 92 491 85.2 497.8C66 517 34.5 516.6 14.9 497.1s-20-51-.7-70.3c6.8-6.8 21.4-12.4 37.4-16.7zM416.9 209c-4.7-11.9-20.8-11-26.8 .3c-19 35.5-45 70.8-77.5 103.3S244.8 371.1 209.3 390c-11.3 6-12.2 22.1-.3 26.8c57.6 22.9 125.8 11 172.3-35.5s58.4-114.8 35.5-172.3zM87.1 285.1c2 2 4.6 3.2 7.3 3.4l56.1 5.1 5.1 56.1c.3 2.8 1.5 5.4 3.4 7.3c6.3 6.3 17.2 3.6 19.8-4.9l29.7-97.4c3.5-11.6-7.3-22.5-19-19L92 265.3c-8.6 2.6-11.3 13.4-4.9 19.8zM265.3 92l-29.7 97.4c-3.5 11.6 7.3 22.5 19 19l97.4-29.7c8.6-2.6 11.3-13.4 4.9-19.8c-2-2-4.6-3.2-7.3-3.4l-56.1-5.1-5.1-56.1c-.3-2.8-1.5-5.4-3.4-7.3c-6.3-6.3-17.2-3.6-19.8 4.9z\"]\n};\nconst faGrinSquintTears = faFaceGrinSquintTears;\nconst faDumbbell = {\n prefix: 'fas',\n iconName: 'dumbbell',\n icon: [640, 512, [], \"f44b\", \"M96 64c0-17.7 14.3-32 32-32l32 0c17.7 0 32 14.3 32 32l0 160 0 64 0 160c0 17.7-14.3 32-32 32l-32 0c-17.7 0-32-14.3-32-32l0-64-32 0c-17.7 0-32-14.3-32-32l0-64c-17.7 0-32-14.3-32-32s14.3-32 32-32l0-64c0-17.7 14.3-32 32-32l32 0 0-64zm448 0l0 64 32 0c17.7 0 32 14.3 32 32l0 64c17.7 0 32 14.3 32 32s-14.3 32-32 32l0 64c0 17.7-14.3 32-32 32l-32 0 0 64c0 17.7-14.3 32-32 32l-32 0c-17.7 0-32-14.3-32-32l0-160 0-64 0-160c0-17.7 14.3-32 32-32l32 0c17.7 0 32 14.3 32 32zM416 224l0 64-192 0 0-64 192 0z\"]\n};\nconst faRectangleList = {\n prefix: 'fas',\n iconName: 'rectangle-list',\n icon: [576, 512, [\"list-alt\"], \"f022\", \"M0 96C0 60.7 28.7 32 64 32l448 0c35.3 0 64 28.7 64 64l0 320c0 35.3-28.7 64-64 64L64 480c-35.3 0-64-28.7-64-64L0 96zM128 288a32 32 0 1 0 0-64 32 32 0 1 0 0 64zm32-128a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zM128 384a32 32 0 1 0 0-64 32 32 0 1 0 0 64zm96-248c-13.3 0-24 10.7-24 24s10.7 24 24 24l224 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-224 0zm0 96c-13.3 0-24 10.7-24 24s10.7 24 24 24l224 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-224 0zm0 96c-13.3 0-24 10.7-24 24s10.7 24 24 24l224 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-224 0z\"]\n};\nconst faListAlt = faRectangleList;\nconst faTarpDroplet = {\n prefix: 'fas',\n iconName: 'tarp-droplet',\n icon: [576, 512, [], \"e57c\", \"M288 160c-35.3 0-64-26.9-64-60c0-24 33.7-70.1 52.2-93.5c6.1-7.7 17.5-7.7 23.6 0C318.3 29.9 352 76 352 100c0 33.1-28.7 60-64 60zM64 128l133.5 0c13.2 37.3 48.7 64 90.5 64s77.4-26.7 90.5-64L512 128c35.3 0 64 28.7 64 64l0 160-128 0c-17.7 0-32 14.3-32 32l0 128L64 512c-35.3 0-64-28.7-64-64L0 192c0-35.3 28.7-64 64-64zM448 512l0-128 128 0L448 512zM96 256a32 32 0 1 0 0-64 32 32 0 1 0 0 64z\"]\n};\nconst faHouseMedicalCircleCheck = {\n prefix: 'fas',\n iconName: 'house-medical-circle-check',\n icon: [640, 512, [], \"e511\", \"M320 368c0 59.5 29.5 112.1 74.8 144l-266.7 0c-35.3 0-64-28.7-64-64l0-160.4-32 0c-18 0-32-14-32-32.1c0-9 3-17 10-24L266.4 8c7-7 15-8 22-8s15 2 21 7L522.1 193.9c-8.5-1.3-17.3-1.9-26.1-1.9c-54.7 0-103.5 24.9-135.8 64L320 256l0-48c0-8.8-7.2-16-16-16l-32 0c-8.8 0-16 7.2-16 16l0 48-48 0c-8.8 0-16 7.2-16 16l0 32c0 8.8 7.2 16 16 16l48 0 0 48c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16zm32 0a144 144 0 1 1 288 0 144 144 0 1 1 -288 0zm211.3-43.3c-6.2-6.2-16.4-6.2-22.6 0L480 385.4l-28.7-28.7c-6.2-6.2-16.4-6.2-22.6 0s-6.2 16.4 0 22.6l40 40c6.2 6.2 16.4 6.2 22.6 0l72-72c6.2-6.2 6.2-16.4 0-22.6z\"]\n};\nconst faPersonSkiingNordic = {\n prefix: 'fas',\n iconName: 'person-skiing-nordic',\n icon: [576, 512, [\"skiing-nordic\"], \"f7ca\", \"M336 96a48 48 0 1 0 0-96 48 48 0 1 0 0 96zM227.2 160c1.9 0 3.8 .1 5.6 .3L201.6 254c-9.3 28 1.7 58.8 26.8 74.5l86.2 53.9L291.3 464l-88.5 0 41.1-88.1-32.4-20.3c-7.8-4.9-14.7-10.7-20.6-17.3L132.2 464l-32.4 0 54.2-257.6c4.6-1.5 9-4.1 12.7-7.8l23.1-23.1c9.9-9.9 23.4-15.5 37.5-15.5zM121.4 198.6c.4 .4 .8 .8 1.3 1.2L67 464l-43 0c-13.3 0-24 10.7-24 24s10.7 24 24 24l135.3 0c.5 0 .9 0 1.4 0l158.6 0c.5 0 1 0 1.4 0L504 512c39.8 0 72-32.2 72-72l0-8c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 8c0 13.3-10.7 24-24 24l-69.4 0 27.6-179.3c10.5-5.2 17.8-16.1 17.8-28.7c0-17.7-14.3-32-32-32l-21.3 0c-12.9 0-24.6-7.8-29.5-19.7l-6.3-15c-14.6-35.1-44.1-61.9-80.5-73.1l-48.7-15c-11.1-3.4-22.7-5.2-34.4-5.2c-31 0-60.8 12.3-82.7 34.3l-23.1 23.1c-12.5 12.5-12.5 32.8 0 45.3zm308 89.4L402.3 464l-44.4 0 21.6-75.6c5.9-20.6-2.6-42.6-20.7-53.9L302 299l30.9-82.4 5.1 12.3C353 264.7 387.9 288 426.7 288l2.7 0z\"]\n};\nconst faSkiingNordic = faPersonSkiingNordic;\nconst faCalendarPlus = {\n prefix: 'fas',\n iconName: 'calendar-plus',\n icon: [448, 512, [], \"f271\", \"M96 32l0 32L48 64C21.5 64 0 85.5 0 112l0 48 448 0 0-48c0-26.5-21.5-48-48-48l-48 0 0-32c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 32L160 64l0-32c0-17.7-14.3-32-32-32S96 14.3 96 32zM448 192L0 192 0 464c0 26.5 21.5 48 48 48l352 0c26.5 0 48-21.5 48-48l0-272zM224 248c13.3 0 24 10.7 24 24l0 56 56 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-56 0 0 56c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-56-56 0c-13.3 0-24-10.7-24-24s10.7-24 24-24l56 0 0-56c0-13.3 10.7-24 24-24z\"]\n};\nconst faPlaneArrival = {\n prefix: 'fas',\n iconName: 'plane-arrival',\n icon: [640, 512, [128748], \"f5af\", \"M.3 166.9L0 68C0 57.7 9.5 50.1 19.5 52.3l35.6 7.9c10.6 2.3 19.2 9.9 23 20L96 128l127.3 37.6L181.8 20.4C178.9 10.2 186.6 0 197.2 0l40.1 0c11.6 0 22.2 6.2 27.9 16.3l109 193.8 107.2 31.7c15.9 4.7 30.8 12.5 43.7 22.8l34.4 27.6c24 19.2 18.1 57.3-10.7 68.2c-41.2 15.6-86.2 18.1-128.8 7L121.7 289.8c-11.1-2.9-21.2-8.7-29.3-16.9L9.5 189.4c-5.9-6-9.3-14.1-9.3-22.5zM32 448l576 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L32 512c-17.7 0-32-14.3-32-32s14.3-32 32-32zm96-80a32 32 0 1 1 64 0 32 32 0 1 1 -64 0zm128-16a32 32 0 1 1 0 64 32 32 0 1 1 0-64z\"]\n};\nconst faCircleLeft = {\n prefix: 'fas',\n iconName: 'circle-left',\n icon: [512, 512, [61840, \"arrow-alt-circle-left\"], \"f359\", \"M512 256A256 256 0 1 0 0 256a256 256 0 1 0 512 0zM116.7 244.7l112-112c4.6-4.6 11.5-5.9 17.4-3.5s9.9 8.3 9.9 14.8l0 64 96 0c17.7 0 32 14.3 32 32l0 32c0 17.7-14.3 32-32 32l-96 0 0 64c0 6.5-3.9 12.3-9.9 14.8s-12.9 1.1-17.4-3.5l-112-112c-6.2-6.2-6.2-16.4 0-22.6z\"]\n};\nconst faArrowAltCircleLeft = faCircleLeft;\nconst faTrainSubway = {\n prefix: 'fas',\n iconName: 'train-subway',\n icon: [448, 512, [\"subway\"], \"f239\", \"M96 0C43 0 0 43 0 96L0 352c0 48 35.2 87.7 81.1 94.9l-46 46C28.1 499.9 33.1 512 43 512l39.7 0c8.5 0 16.6-3.4 22.6-9.4L160 448l128 0 54.6 54.6c6 6 14.1 9.4 22.6 9.4l39.7 0c10 0 15-12.1 7.9-19.1l-46-46c46-7.1 81.1-46.9 81.1-94.9l0-256c0-53-43-96-96-96L96 0zM64 128c0-17.7 14.3-32 32-32l80 0c17.7 0 32 14.3 32 32l0 96c0 17.7-14.3 32-32 32l-80 0c-17.7 0-32-14.3-32-32l0-96zM272 96l80 0c17.7 0 32 14.3 32 32l0 96c0 17.7-14.3 32-32 32l-80 0c-17.7 0-32-14.3-32-32l0-96c0-17.7 14.3-32 32-32zM64 352a32 32 0 1 1 64 0 32 32 0 1 1 -64 0zm288-32a32 32 0 1 1 0 64 32 32 0 1 1 0-64z\"]\n};\nconst faSubway = faTrainSubway;\nconst faChartGantt = {\n prefix: 'fas',\n iconName: 'chart-gantt',\n icon: [512, 512, [], \"e0e4\", \"M32 32c17.7 0 32 14.3 32 32l0 336c0 8.8 7.2 16 16 16l400 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L80 480c-44.2 0-80-35.8-80-80L0 64C0 46.3 14.3 32 32 32zm96 96c0-17.7 14.3-32 32-32l96 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-96 0c-17.7 0-32-14.3-32-32zm96 64l128 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-128 0c-17.7 0-32-14.3-32-32s14.3-32 32-32zm160 96l64 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-64 0c-17.7 0-32-14.3-32-32s14.3-32 32-32z\"]\n};\nconst faIndianRupeeSign = {\n prefix: 'fas',\n iconName: 'indian-rupee-sign',\n icon: [320, 512, [\"indian-rupee\", \"inr\"], \"e1bc\", \"M0 64C0 46.3 14.3 32 32 32l64 0 16 0 176 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-56.2 0c9.6 14.4 16.7 30.6 20.7 48l35.6 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-35.6 0c-13.2 58.3-61.9 103.2-122.2 110.9L274.6 422c14.4 10.3 17.7 30.3 7.4 44.6s-30.3 17.7-44.6 7.4L13.4 314C2.1 306-2.7 291.5 1.5 278.2S18.1 256 32 256l80 0c32.8 0 61-19.7 73.3-48L32 208c-17.7 0-32-14.3-32-32s14.3-32 32-32l153.3 0C173 115.7 144.8 96 112 96L96 96 32 96C14.3 96 0 81.7 0 64z\"]\n};\nconst faIndianRupee = faIndianRupeeSign;\nconst faInr = faIndianRupeeSign;\nconst faCropSimple = {\n prefix: 'fas',\n iconName: 'crop-simple',\n icon: [512, 512, [\"crop-alt\"], \"f565\", \"M128 32c0-17.7-14.3-32-32-32S64 14.3 64 32l0 32L32 64C14.3 64 0 78.3 0 96s14.3 32 32 32l32 0 0 256c0 35.3 28.7 64 64 64l224 0 0-64-224 0 0-352zM384 480c0 17.7 14.3 32 32 32s32-14.3 32-32l0-32 32 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-32 0 0-256c0-35.3-28.7-64-64-64L160 64l0 64 224 0 0 352z\"]\n};\nconst faCropAlt = faCropSimple;\nconst faMoneyBill1 = {\n prefix: 'fas',\n iconName: 'money-bill-1',\n icon: [576, 512, [\"money-bill-alt\"], \"f3d1\", \"M64 64C28.7 64 0 92.7 0 128L0 384c0 35.3 28.7 64 64 64l448 0c35.3 0 64-28.7 64-64l0-256c0-35.3-28.7-64-64-64L64 64zm64 320l-64 0 0-64c35.3 0 64 28.7 64 64zM64 192l0-64 64 0c0 35.3-28.7 64-64 64zM448 384c0-35.3 28.7-64 64-64l0 64-64 0zm64-192c-35.3 0-64-28.7-64-64l64 0 0 64zM176 256a112 112 0 1 1 224 0 112 112 0 1 1 -224 0zm76-48c0 9.7 6.9 17.7 16 19.6l0 48.4-4 0c-11 0-20 9-20 20s9 20 20 20l24 0 24 0c11 0 20-9 20-20s-9-20-20-20l-4 0 0-68c0-11-9-20-20-20l-16 0c-11 0-20 9-20 20z\"]\n};\nconst faMoneyBillAlt = faMoneyBill1;\nconst faLeftLong = {\n prefix: 'fas',\n iconName: 'left-long',\n icon: [512, 512, [\"long-arrow-alt-left\"], \"f30a\", \"M177.5 414c-8.8 3.8-19 2-26-4.6l-144-136C2.7 268.9 0 262.6 0 256s2.7-12.9 7.5-17.4l144-136c7-6.6 17.2-8.4 26-4.6s14.5 12.5 14.5 22l0 72 288 0c17.7 0 32 14.3 32 32l0 64c0 17.7-14.3 32-32 32l-288 0 0 72c0 9.6-5.7 18.2-14.5 22z\"]\n};\nconst faLongArrowAltLeft = faLeftLong;\nconst faDna = {\n prefix: 'fas',\n iconName: 'dna',\n icon: [448, 512, [129516], \"f471\", \"M416 0c17.7 0 32 14.3 32 32c0 59.8-30.3 107.5-69.4 146.6c-28 28-62.5 53.5-97.3 77.4l-2.5 1.7c-11.9 8.1-23.8 16.1-35.5 23.9c0 0 0 0 0 0s0 0 0 0s0 0 0 0l-1.6 1c-6 4-11.9 7.9-17.8 11.9c-20.9 14-40.8 27.7-59.3 41.5l118.5 0c-9.8-7.4-20.1-14.7-30.7-22.1l7-4.7 3-2c15.1-10.1 30.9-20.6 46.7-31.6c25 18.1 48.9 37.3 69.4 57.7C417.7 372.5 448 420.2 448 480c0 17.7-14.3 32-32 32s-32-14.3-32-32L64 480c0 17.7-14.3 32-32 32s-32-14.3-32-32c0-59.8 30.3-107.5 69.4-146.6c28-28 62.5-53.5 97.3-77.4c-34.8-23.9-69.3-49.3-97.3-77.4C30.3 139.5 0 91.8 0 32C0 14.3 14.3 0 32 0S64 14.3 64 32l320 0c0-17.7 14.3-32 32-32zM338.6 384l-229.2 0c-10.1 10.6-18.6 21.3-25.5 32l280.2 0c-6.8-10.7-15.3-21.4-25.5-32zM109.4 128l229.2 0c10.1-10.7 18.6-21.3 25.5-32L83.9 96c6.8 10.7 15.3 21.3 25.5 32zm55.4 48c18.4 13.8 38.4 27.5 59.3 41.5c20.9-14 40.8-27.7 59.3-41.5l-118.5 0z\"]\n};\nconst faVirusSlash = {\n prefix: 'fas',\n iconName: 'virus-slash',\n icon: [640, 512, [], \"e075\", \"M38.8 5.1C28.4-3.1 13.3-1.2 5.1 9.2S-1.2 34.7 9.2 42.9l592 464c10.4 8.2 25.5 6.3 33.7-4.1s6.3-25.5-4.1-33.7l-154.3-121c-2-30.1 20.8-60.1 56-60.1l11.5 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-11.5 0c-49.9 0-74.9-60.3-39.6-95.6l8.2-8.2c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0l-8.2 8.2C412.3 118.4 352 93.4 352 43.5L352 32c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 11.5c0 49.9-60.3 74.9-95.6 39.6L184.2 75c-12.5-12.5-32.8-12.5-45.3 0c-1.6 1.6-3.1 3.4-4.3 5.3L38.8 5.1zm225.8 177c6.9-3.9 14.9-6.1 23.4-6.1c26.5 0 48 21.5 48 48c0 4.4-.6 8.7-1.7 12.7l-69.7-54.6zM402 412.7L144.7 210c-9.5 8.5-22.2 14-37.2 14L96 224c-17.7 0-32 14.3-32 32s14.3 32 32 32l11.5 0c49.9 0 74.9 60.3 39.6 95.6l-8.2 8.2c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0l8.2-8.2c35.3-35.3 95.6-10.3 95.6 39.6l0 11.5c0 17.7 14.3 32 32 32s32-14.3 32-32l0-11.5c0-31.2 23.6-52.7 50-55.7z\"]\n};\nconst faMinus = {\n prefix: 'fas',\n iconName: 'minus',\n icon: [448, 512, [8211, 8722, 10134, \"subtract\"], \"f068\", \"M432 256c0 17.7-14.3 32-32 32L48 288c-17.7 0-32-14.3-32-32s14.3-32 32-32l352 0c17.7 0 32 14.3 32 32z\"]\n};\nconst faSubtract = faMinus;\nconst faChess = {\n prefix: 'fas',\n iconName: 'chess',\n icon: [512, 512, [], \"f439\", \"M144 16c0-8.8-7.2-16-16-16s-16 7.2-16 16l0 16L96 32c-8.8 0-16 7.2-16 16s7.2 16 16 16l16 0 0 32L60.2 96C49.1 96 40 105.1 40 116.2c0 2.5 .5 4.9 1.3 7.3L73.8 208 72 208c-13.3 0-24 10.7-24 24s10.7 24 24 24l4 0L60 384l136 0L180 256l4 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-1.8 0 32.5-84.5c.9-2.3 1.3-4.8 1.3-7.3c0-11.2-9.1-20.2-20.2-20.2L144 96l0-32 16 0c8.8 0 16-7.2 16-16s-7.2-16-16-16l-16 0 0-16zM48 416L4.8 473.6C1.7 477.8 0 482.8 0 488c0 13.3 10.7 24 24 24l208 0c13.3 0 24-10.7 24-24c0-5.2-1.7-10.2-4.8-14.4L208 416 48 416zm288 0l-43.2 57.6c-3.1 4.2-4.8 9.2-4.8 14.4c0 13.3 10.7 24 24 24l176 0c13.3 0 24-10.7 24-24c0-5.2-1.7-10.2-4.8-14.4L464 416l-128 0zM304 208l0 51.9c0 7.8 2.8 15.3 8 21.1L339.2 312 337 384l125.5 0-3.3-72 28.3-30.8c5.4-5.9 8.5-13.6 8.5-21.7l0-51.5c0-8.8-7.2-16-16-16l-16 0c-8.8 0-16 7.2-16 16l0 16-24 0 0-16c0-8.8-7.2-16-16-16l-16 0c-8.8 0-16 7.2-16 16l0 16-24 0 0-16c0-8.8-7.2-16-16-16l-16 0c-8.8 0-16 7.2-16 16zm80 96c0-8.8 7.2-16 16-16s16 7.2 16 16l0 32-32 0 0-32z\"]\n};\nconst faArrowLeftLong = {\n prefix: 'fas',\n iconName: 'arrow-left-long',\n icon: [512, 512, [\"long-arrow-left\"], \"f177\", \"M9.4 233.4c-12.5 12.5-12.5 32.8 0 45.3l128 128c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3L109.3 288 480 288c17.7 0 32-14.3 32-32s-14.3-32-32-32l-370.7 0 73.4-73.4c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0l-128 128z\"]\n};\nconst faLongArrowLeft = faArrowLeftLong;\nconst faPlugCircleCheck = {\n prefix: 'fas',\n iconName: 'plug-circle-check',\n icon: [576, 512, [], \"e55c\", \"M96 0C78.3 0 64 14.3 64 32l0 96 64 0 0-96c0-17.7-14.3-32-32-32zM288 0c-17.7 0-32 14.3-32 32l0 96 64 0 0-96c0-17.7-14.3-32-32-32zM32 160c-17.7 0-32 14.3-32 32s14.3 32 32 32l0 32c0 77.4 55 142 128 156.8l0 67.2c0 17.7 14.3 32 32 32s32-14.3 32-32l0-67.2c12.3-2.5 24.1-6.4 35.1-11.5c-2.1-10.8-3.1-21.9-3.1-33.3c0-80.3 53.8-148 127.3-169.2c.5-2.2 .7-4.5 .7-6.8c0-17.7-14.3-32-32-32L32 160zM576 368a144 144 0 1 0 -288 0 144 144 0 1 0 288 0zm-76.7-43.3c6.2 6.2 6.2 16.4 0 22.6l-72 72c-6.2 6.2-16.4 6.2-22.6 0l-40-40c-6.2-6.2-6.2-16.4 0-22.6s16.4-6.2 22.6 0L416 385.4l60.7-60.7c6.2-6.2 16.4-6.2 22.6 0z\"]\n};\nconst faStreetView = {\n prefix: 'fas',\n iconName: 'street-view',\n icon: [512, 512, [], \"f21d\", \"M320 64A64 64 0 1 0 192 64a64 64 0 1 0 128 0zm-96 96c-35.3 0-64 28.7-64 64l0 48c0 17.7 14.3 32 32 32l1.8 0 11.1 99.5c1.8 16.2 15.5 28.5 31.8 28.5l38.7 0c16.3 0 30-12.3 31.8-28.5L318.2 304l1.8 0c17.7 0 32-14.3 32-32l0-48c0-35.3-28.7-64-64-64l-64 0zM132.3 394.2c13-2.4 21.7-14.9 19.3-27.9s-14.9-21.7-27.9-19.3c-32.4 5.9-60.9 14.2-82 24.8c-10.5 5.3-20.3 11.7-27.8 19.6C6.4 399.5 0 410.5 0 424c0 21.4 15.5 36.1 29.1 45c14.7 9.6 34.3 17.3 56.4 23.4C130.2 504.7 190.4 512 256 512s125.8-7.3 170.4-19.6c22.1-6.1 41.8-13.8 56.4-23.4c13.7-8.9 29.1-23.6 29.1-45c0-13.5-6.4-24.5-14-32.6c-7.5-7.9-17.3-14.3-27.8-19.6c-21-10.6-49.5-18.9-82-24.8c-13-2.4-25.5 6.3-27.9 19.3s6.3 25.5 19.3 27.9c30.2 5.5 53.7 12.8 69 20.5c3.2 1.6 5.8 3.1 7.9 4.5c3.6 2.4 3.6 7.2 0 9.6c-8.8 5.7-23.1 11.8-43 17.3C374.3 457 318.5 464 256 464s-118.3-7-157.7-17.9c-19.9-5.5-34.2-11.6-43-17.3c-3.6-2.4-3.6-7.2 0-9.6c2.1-1.4 4.8-2.9 7.9-4.5c15.3-7.7 38.8-14.9 69-20.5z\"]\n};\nconst faFrancSign = {\n prefix: 'fas',\n iconName: 'franc-sign',\n icon: [320, 512, [], \"e18f\", \"M80 32C62.3 32 48 46.3 48 64l0 160 0 96-16 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l16 0 0 64c0 17.7 14.3 32 32 32s32-14.3 32-32l0-64 80 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-80 0 0-64 144 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-144 0 0-96 176 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L80 32z\"]\n};\nconst faVolumeOff = {\n prefix: 'fas',\n iconName: 'volume-off',\n icon: [320, 512, [], \"f026\", \"M320 64c0-12.6-7.4-24-18.9-29.2s-25-3.1-34.4 5.3L131.8 160 64 160c-35.3 0-64 28.7-64 64l0 64c0 35.3 28.7 64 64 64l67.8 0L266.7 471.9c9.4 8.4 22.9 10.4 34.4 5.3S320 460.6 320 448l0-384z\"]\n};\nconst faHandsAslInterpreting = {\n prefix: 'fas',\n iconName: 'hands-asl-interpreting',\n icon: [640, 512, [\"american-sign-language-interpreting\", \"asl-interpreting\", \"hands-american-sign-language-interpreting\"], \"f2a3\", \"M156.6 46.3c7.9-15.8 1.5-35-14.3-42.9s-35-1.5-42.9 14.3L13.5 189.4C4.6 207.2 0 226.8 0 246.7L0 256c0 70.7 57.3 128 128 128l72 0 8 0 0-.3c35.2-2.7 65.4-22.8 82.1-51.7c8.8-15.3 3.6-34.9-11.7-43.7s-34.9-3.6-43.7 11.7c-7 12-19.9 20-34.7 20c-22.1 0-40-17.9-40-40s17.9-40 40-40c14.8 0 27.7 8 34.7 20c8.8 15.3 28.4 20.5 43.7 11.7s20.5-28.4 11.7-43.7c-12.8-22.1-33.6-39.1-58.4-47.1l80.8-22c17-4.6 27.1-22.2 22.5-39.3s-22.2-27.1-39.3-22.5L194.9 124.6l81.6-68c13.6-11.3 15.4-31.5 4.1-45.1S249.1-3.9 235.5 7.4L133.6 92.3l23-46zM483.4 465.7c-7.9 15.8-1.5 35 14.3 42.9s35 1.5 42.9-14.3l85.9-171.7c8.9-17.8 13.5-37.4 13.5-57.2l0-9.3c0-70.7-57.3-128-128-128l-72 0-8 0 0 .3c-35.2 2.7-65.4 22.8-82.1 51.7c-8.9 15.3-3.6 34.9 11.7 43.7s34.9 3.6 43.7-11.7c7-12 19.9-20 34.7-20c22.1 0 40 17.9 40 40s-17.9 40-40 40c-14.8 0-27.7-8-34.7-20c-8.9-15.3-28.4-20.5-43.7-11.7s-20.5 28.4-11.7 43.7c12.8 22.1 33.6 39.1 58.4 47.1l-80.8 22c-17.1 4.7-27.1 22.2-22.5 39.3s22.2 27.1 39.3 22.5l100.7-27.5-81.6 68c-13.6 11.3-15.4 31.5-4.1 45.1s31.5 15.4 45.1 4.1l101.9-84.9-23 46z\"]\n};\nconst faAmericanSignLanguageInterpreting = faHandsAslInterpreting;\nconst faAslInterpreting = faHandsAslInterpreting;\nconst faHandsAmericanSignLanguageInterpreting = faHandsAslInterpreting;\nconst faGear = {\n prefix: 'fas',\n iconName: 'gear',\n icon: [512, 512, [9881, \"cog\"], \"f013\", \"M495.9 166.6c3.2 8.7 .5 18.4-6.4 24.6l-43.3 39.4c1.1 8.3 1.7 16.8 1.7 25.4s-.6 17.1-1.7 25.4l43.3 39.4c6.9 6.2 9.6 15.9 6.4 24.6c-4.4 11.9-9.7 23.3-15.8 34.3l-4.7 8.1c-6.6 11-14 21.4-22.1 31.2c-5.9 7.2-15.7 9.6-24.5 6.8l-55.7-17.7c-13.4 10.3-28.2 18.9-44 25.4l-12.5 57.1c-2 9.1-9 16.3-18.2 17.8c-13.8 2.3-28 3.5-42.5 3.5s-28.7-1.2-42.5-3.5c-9.2-1.5-16.2-8.7-18.2-17.8l-12.5-57.1c-15.8-6.5-30.6-15.1-44-25.4L83.1 425.9c-8.8 2.8-18.6 .3-24.5-6.8c-8.1-9.8-15.5-20.2-22.1-31.2l-4.7-8.1c-6.1-11-11.4-22.4-15.8-34.3c-3.2-8.7-.5-18.4 6.4-24.6l43.3-39.4C64.6 273.1 64 264.6 64 256s.6-17.1 1.7-25.4L22.4 191.2c-6.9-6.2-9.6-15.9-6.4-24.6c4.4-11.9 9.7-23.3 15.8-34.3l4.7-8.1c6.6-11 14-21.4 22.1-31.2c5.9-7.2 15.7-9.6 24.5-6.8l55.7 17.7c13.4-10.3 28.2-18.9 44-25.4l12.5-57.1c2-9.1 9-16.3 18.2-17.8C227.3 1.2 241.5 0 256 0s28.7 1.2 42.5 3.5c9.2 1.5 16.2 8.7 18.2 17.8l12.5 57.1c15.8 6.5 30.6 15.1 44 25.4l55.7-17.7c8.8-2.8 18.6-.3 24.5 6.8c8.1 9.8 15.5 20.2 22.1 31.2l4.7 8.1c6.1 11 11.4 22.4 15.8 34.3zM256 336a80 80 0 1 0 0-160 80 80 0 1 0 0 160z\"]\n};\nconst faCog = faGear;\nconst faDropletSlash = {\n prefix: 'fas',\n iconName: 'droplet-slash',\n icon: [640, 512, [\"tint-slash\"], \"f5c7\", \"M320 512c53.2 0 101.4-21.6 136.1-56.6l-298.3-235C140 257.1 128 292.3 128 320c0 106 86 192 192 192zM505.2 370.7c4.4-16.2 6.8-33.1 6.8-50.7c0-91.2-130.2-262.3-166.6-308.3C339.4 4.2 330.5 0 320.9 0l-1.8 0c-9.6 0-18.5 4.2-24.5 11.7C277.8 33 240.7 81.3 205.8 136L38.8 5.1C28.4-3.1 13.3-1.2 5.1 9.2S-1.2 34.7 9.2 42.9l592 464c10.4 8.2 25.5 6.3 33.7-4.1s6.3-25.5-4.1-33.7L505.2 370.7zM224 336c0 44.2 35.8 80 80 80c8.8 0 16 7.2 16 16s-7.2 16-16 16c-61.9 0-112-50.1-112-112c0-8.8 7.2-16 16-16s16 7.2 16 16z\"]\n};\nconst faTintSlash = faDropletSlash;\nconst faMosque = {\n prefix: 'fas',\n iconName: 'mosque',\n icon: [640, 512, [128332], \"f678\", \"M400 0c5 0 9.8 2.4 12.8 6.4c34.7 46.3 78.1 74.9 133.5 111.5c0 0 0 0 0 0s0 0 0 0c5.2 3.4 10.5 7 16 10.6c28.9 19.2 45.7 51.7 45.7 86.1c0 28.6-11.3 54.5-29.8 73.4l-356.4 0c-18.4-19-29.8-44.9-29.8-73.4c0-34.4 16.7-66.9 45.7-86.1c5.4-3.6 10.8-7.1 16-10.6c0 0 0 0 0 0s0 0 0 0C309.1 81.3 352.5 52.7 387.2 6.4c3-4 7.8-6.4 12.8-6.4zM288 512l0-72c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 72-48 0c-17.7 0-32-14.3-32-32l0-128c0-17.7 14.3-32 32-32l416 0c17.7 0 32 14.3 32 32l0 128c0 17.7-14.3 32-32 32l-48 0 0-72c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 72-64 0 0-58c0-19-8.4-37-23-49.2L400 384l-25 20.8C360.4 417 352 435 352 454l0 58-64 0zM70.4 5.2c5.7-4.3 13.5-4.3 19.2 0l16 12C139.8 42.9 160 83.2 160 126l0 2L0 128l0-2C0 83.2 20.2 42.9 54.4 17.2l16-12zM0 160l160 0 0 136.6c-19.1 11.1-32 31.7-32 55.4l0 128c0 9.6 2.1 18.6 5.8 26.8c-6.6 3.4-14 5.2-21.8 5.2l-64 0c-26.5 0-48-21.5-48-48L0 176l0-16z\"]\n};\nconst faMosquito = {\n prefix: 'fas',\n iconName: 'mosquito',\n icon: [640, 512, [], \"e52b\", \"M463.7 505.9c9.8-8.9 10.7-24.3 2.1-34.3l-42.1-49 0-54.7c0-5.5-1.8-10.8-5.1-15.1L352 266.3l0-.3L485.4 387.8C542.4 447.6 640 405.2 640 320.6c0-47.9-34-88.3-79.4-94.2l-153-23.9 40.8-40.9c7.8-7.8 9.4-20.1 3.9-29.8L428.5 90.1l38.2-50.9c8-10.6 6.1-25.9-4.3-34.1s-25.2-6.3-33.2 4.4l-48 63.9c-5.9 7.9-6.6 18.6-1.7 27.2L402.2 140 352 190.3l0-38.2c0-14.9-10.2-27.4-24-31l0-57.2c0-4.4-3.6-8-8-8s-8 3.6-8 8l0 57.2c-13.8 3.6-24 16.1-24 31l0 38.1L237.8 140l22.6-39.5c4.9-8.6 4.2-19.3-1.7-27.2l-48-63.9c-8-10.6-22.8-12.6-33.2-4.4s-12.2 23.5-4.3 34.1l38.2 50.9-23.9 41.7c-5.5 9.7-3.9 22 3.9 29.8l40.8 40.9-153 23.9C34 232.3 0 272.7 0 320.6c0 84.6 97.6 127 154.6 67.1L288 266l0 .3-66.5 86.4c-3.3 4.3-5.1 9.6-5.1 15.1l0 54.7-42.1 49c-8.6 10.1-7.7 25.5 2.1 34.3s24.7 7.9 33.4-2.1l48-55.9c3.8-4.4 5.9-10.2 5.9-16.1l0-55.4L288 344.7l0 63.1c0 17.7 14.3 32 32 32s32-14.3 32-32l0-63.1 24.3 31.6 0 55.4c0 5.9 2.1 11.7 5.9 16.1l48 55.9c8.6 10.1 23.6 11 33.4 2.1z\"]\n};\nconst faStarOfDavid = {\n prefix: 'fas',\n iconName: 'star-of-david',\n icon: [512, 512, [10017], \"f69a\", \"M404.2 309.5L383.1 344l42.3 0-21.1-34.5zM371.4 256l-54-88-122.8 0-54 88 54 88 122.8 0 54-88zm65.7 0l53.4 87c3.6 5.9 5.5 12.7 5.5 19.6c0 20.7-16.8 37.4-37.4 37.4l-109.8 0-56.2 91.5C284.8 504.3 270.9 512 256 512s-28.8-7.7-36.6-20.5L163.3 400 53.4 400C32.8 400 16 383.2 16 362.6c0-6.9 1.9-13.7 5.5-19.6l53.4-87L21.5 169c-3.6-5.9-5.5-12.7-5.5-19.6C16 128.8 32.8 112 53.4 112l109.8 0 56.2-91.5C227.2 7.7 241.1 0 256 0s28.8 7.7 36.6 20.5L348.7 112l109.8 0c20.7 0 37.4 16.8 37.4 37.4c0 6.9-1.9 13.7-5.5 19.6l-53.4 87zm-54-88l21.1 34.5L425.4 168l-42.3 0zM283 112L256 68l-27 44 54 0zM128.9 168l-42.3 0 21.1 34.5L128.9 168zM107.8 309.5L86.6 344l42.3 0-21.1-34.5zM229 400l27 44 27-44-54 0z\"]\n};\nconst faPersonMilitaryRifle = {\n prefix: 'fas',\n iconName: 'person-military-rifle',\n icon: [512, 512, [], \"e54b\", \"M160 39c0-13 10-23.8 22.9-24.9L334.7 1.4C344 .7 352 8 352 17.4L352 48c0 8.8-7.2 16-16 16L185 64c-13.8 0-25-11.2-25-25zm17.6 57l156.8 0c1 5.2 1.6 10.5 1.6 16c0 44.2-35.8 80-80 80s-80-35.8-80-80c0-5.5 .6-10.8 1.6-16zm228 364.3L352 369.7 352 480c0 1.3-.1 2.5-.2 3.8L177.5 234.9c16.6-7.1 34.6-10.9 53.3-10.9l50.4 0c15.9 0 31.3 2.8 45.8 7.9L421.9 67.7c-7.7-4.4-10.3-14.2-5.9-21.9s14.2-10.3 21.9-5.9l13.9 8 13.9 8c7.7 4.4 10.3 14.2 5.9 21.9L416 173.9l1.6 .9c15.3 8.8 20.6 28.4 11.7 43.7L392.6 282c2 2.8 3.9 5.8 5.7 8.8l76.1 128.8c11.2 19 4.9 43.5-14.1 54.8s-43.5 4.9-54.8-14.1zM320 512l-128 0c-17.7 0-32-14.3-32-32l0-110.3-53.6 90.6c-11.2 19-35.8 25.3-54.8 14.1s-25.3-35.8-14.1-54.8l76.1-128.8c9.4-15.8 21.7-29.3 36-40L331.1 510c-3.5 1.3-7.2 2-11.1 2zM296 320a24 24 0 1 0 0-48 24 24 0 1 0 0 48z\"]\n};\nconst faCartShopping = {\n prefix: 'fas',\n iconName: 'cart-shopping',\n icon: [576, 512, [128722, \"shopping-cart\"], \"f07a\", \"M0 24C0 10.7 10.7 0 24 0L69.5 0c22 0 41.5 12.8 50.6 32l411 0c26.3 0 45.5 25 38.6 50.4l-41 152.3c-8.5 31.4-37 53.3-69.5 53.3l-288.5 0 5.4 28.5c2.2 11.3 12.1 19.5 23.6 19.5L488 336c13.3 0 24 10.7 24 24s-10.7 24-24 24l-288.3 0c-34.6 0-64.3-24.6-70.7-58.5L77.4 54.5c-.7-3.8-4-6.5-7.9-6.5L24 48C10.7 48 0 37.3 0 24zM128 464a48 48 0 1 1 96 0 48 48 0 1 1 -96 0zm336-48a48 48 0 1 1 0 96 48 48 0 1 1 0-96z\"]\n};\nconst faShoppingCart = faCartShopping;\nconst faVials = {\n prefix: 'fas',\n iconName: 'vials',\n icon: [512, 512, [], \"f493\", \"M0 64C0 46.3 14.3 32 32 32l56 0 48 0 56 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l0 304c0 44.2-35.8 80-80 80s-80-35.8-80-80L32 96C14.3 96 0 81.7 0 64zM136 96L88 96l0 160 48 0 0-160zM288 64c0-17.7 14.3-32 32-32l56 0 48 0 56 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l0 304c0 44.2-35.8 80-80 80s-80-35.8-80-80l0-304c-17.7 0-32-14.3-32-32zM424 96l-48 0 0 160 48 0 0-160z\"]\n};\nconst faPlugCirclePlus = {\n prefix: 'fas',\n iconName: 'plug-circle-plus',\n icon: [576, 512, [], \"e55f\", \"M96 0C78.3 0 64 14.3 64 32l0 96 64 0 0-96c0-17.7-14.3-32-32-32zM288 0c-17.7 0-32 14.3-32 32l0 96 64 0 0-96c0-17.7-14.3-32-32-32zM32 160c-17.7 0-32 14.3-32 32s14.3 32 32 32l0 32c0 77.4 55 142 128 156.8l0 67.2c0 17.7 14.3 32 32 32s32-14.3 32-32l0-67.2c12.3-2.5 24.1-6.4 35.1-11.5c-2.1-10.8-3.1-21.9-3.1-33.3c0-80.3 53.8-148 127.3-169.2c.5-2.2 .7-4.5 .7-6.8c0-17.7-14.3-32-32-32L32 160zM432 512a144 144 0 1 0 0-288 144 144 0 1 0 0 288zm16-208l0 48 48 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-48 0 0 48c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-48-48 0c-8.8 0-16-7.2-16-16s7.2-16 16-16l48 0 0-48c0-8.8 7.2-16 16-16s16 7.2 16 16z\"]\n};\nconst faPlaceOfWorship = {\n prefix: 'fas',\n iconName: 'place-of-worship',\n icon: [640, 512, [], \"f67f\", \"M224 109.3l0 108.3L183.3 242c-14.5 8.7-23.3 24.3-23.3 41.2L160 512l96 0 0-96c0-35.3 28.7-64 64-64s64 28.7 64 64l0 96 96 0 0-228.8c0-16.9-8.8-32.5-23.3-41.2L416 217.6l0-108.3c0-8.5-3.4-16.6-9.4-22.6L331.3 11.3c-6.2-6.2-16.4-6.2-22.6 0L233.4 86.6c-6 6-9.4 14.1-9.4 22.6zM24.9 330.3C9.5 338.8 0 354.9 0 372.4L0 464c0 26.5 21.5 48 48 48l80 0 0-238.4L24.9 330.3zM592 512c26.5 0 48-21.5 48-48l0-91.6c0-17.5-9.5-33.6-24.9-42.1L512 273.6 512 512l80 0z\"]\n};\nconst faGripVertical = {\n prefix: 'fas',\n iconName: 'grip-vertical',\n icon: [320, 512, [], \"f58e\", \"M40 352l48 0c22.1 0 40 17.9 40 40l0 48c0 22.1-17.9 40-40 40l-48 0c-22.1 0-40-17.9-40-40l0-48c0-22.1 17.9-40 40-40zm192 0l48 0c22.1 0 40 17.9 40 40l0 48c0 22.1-17.9 40-40 40l-48 0c-22.1 0-40-17.9-40-40l0-48c0-22.1 17.9-40 40-40zM40 320c-22.1 0-40-17.9-40-40l0-48c0-22.1 17.9-40 40-40l48 0c22.1 0 40 17.9 40 40l0 48c0 22.1-17.9 40-40 40l-48 0zM232 192l48 0c22.1 0 40 17.9 40 40l0 48c0 22.1-17.9 40-40 40l-48 0c-22.1 0-40-17.9-40-40l0-48c0-22.1 17.9-40 40-40zM40 160c-22.1 0-40-17.9-40-40L0 72C0 49.9 17.9 32 40 32l48 0c22.1 0 40 17.9 40 40l0 48c0 22.1-17.9 40-40 40l-48 0zM232 32l48 0c22.1 0 40 17.9 40 40l0 48c0 22.1-17.9 40-40 40l-48 0c-22.1 0-40-17.9-40-40l0-48c0-22.1 17.9-40 40-40z\"]\n};\nconst faHexagonNodes = {\n prefix: 'fas',\n iconName: 'hexagon-nodes',\n icon: [448, 512, [], \"e699\", \"M248 106.6c18.9-9 32-28.3 32-50.6c0-30.9-25.1-56-56-56s-56 25.1-56 56c0 22.3 13.1 41.6 32 50.6l0 98.8c-2.8 1.3-5.5 2.9-8 4.7l-80.1-45.8c1.6-20.8-8.6-41.6-27.9-52.8C57.2 96 23 105.2 7.5 132S1.2 193 28 208.5c1.3 .8 2.6 1.5 4 2.1l0 90.8c-1.3 .6-2.7 1.3-4 2.1C1.2 319-8 353.2 7.5 380S57.2 416 84 400.5c19.3-11.1 29.4-32 27.8-52.8l50.5-28.9c-11.5-11.2-19.9-25.6-23.8-41.7L88 306.1c-2.6-1.8-5.2-3.3-8-4.7l0-90.8c2.8-1.3 5.5-2.9 8-4.7l80.1 45.8c-.1 1.4-.2 2.8-.2 4.3c0 22.3 13.1 41.6 32 50.6l0 98.8c-18.9 9-32 28.3-32 50.6c0 30.9 25.1 56 56 56s56-25.1 56-56c0-22.3-13.1-41.6-32-50.6l0-98.8c2.8-1.3 5.5-2.9 8-4.7l80.1 45.8c-1.6 20.8 8.6 41.6 27.8 52.8c26.8 15.5 61 6.3 76.5-20.5s6.3-61-20.5-76.5c-1.3-.8-2.7-1.5-4-2.1l0-90.8c1.4-.6 2.7-1.3 4-2.1c26.8-15.5 36-49.7 20.5-76.5S390.8 96 364 111.5c-19.3 11.1-29.4 32-27.8 52.8l-50.6 28.9c11.5 11.2 19.9 25.6 23.8 41.7L360 205.9c2.6 1.8 5.2 3.3 8 4.7l0 90.8c-2.8 1.3-5.5 2.9-8 4.6l-80.1-45.8c.1-1.4 .2-2.8 .2-4.3c0-22.3-13.1-41.6-32-50.6l0-98.8z\"]\n};\nconst faArrowTurnUp = {\n prefix: 'fas',\n iconName: 'arrow-turn-up',\n icon: [384, 512, [\"level-up\"], \"f148\", \"M32 448c-17.7 0-32 14.3-32 32s14.3 32 32 32l96 0c53 0 96-43 96-96l0-306.7 73.4 73.4c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3l-128-128c-12.5-12.5-32.8-12.5-45.3 0l-128 128c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0L160 109.3 160 416c0 17.7-14.3 32-32 32l-96 0z\"]\n};\nconst faLevelUp = faArrowTurnUp;\nconst faU = {\n prefix: 'fas',\n iconName: 'u',\n icon: [384, 512, [117], \"55\", \"M32 32c17.7 0 32 14.3 32 32l0 224c0 70.7 57.3 128 128 128s128-57.3 128-128l0-224c0-17.7 14.3-32 32-32s32 14.3 32 32l0 224c0 106-86 192-192 192S0 394 0 288L0 64C0 46.3 14.3 32 32 32z\"]\n};\nconst faSquareRootVariable = {\n prefix: 'fas',\n iconName: 'square-root-variable',\n icon: [576, 512, [\"square-root-alt\"], \"f698\", \"M282.6 78.1c8-27.3 33-46.1 61.4-46.1l200 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L344 96 238.7 457c-3.6 12.3-14.1 21.2-26.8 22.8s-25.1-4.6-31.5-15.6L77.6 288 32 288c-17.7 0-32-14.3-32-32s14.3-32 32-32l45.6 0c22.8 0 43.8 12.1 55.3 31.8l65.2 111.8L282.6 78.1zM393.4 233.4c12.5-12.5 32.8-12.5 45.3 0L480 274.7l41.4-41.4c12.5-12.5 32.8-12.5 45.3 0s12.5 32.8 0 45.3L525.3 320l41.4 41.4c12.5 12.5 12.5 32.8 0 45.3s-32.8 12.5-45.3 0L480 365.3l-41.4 41.4c-12.5 12.5-32.8 12.5-45.3 0s-12.5-32.8 0-45.3L434.7 320l-41.4-41.4c-12.5-12.5-12.5-32.8 0-45.3z\"]\n};\nconst faSquareRootAlt = faSquareRootVariable;\nconst faClock = {\n prefix: 'fas',\n iconName: 'clock',\n icon: [512, 512, [128339, \"clock-four\"], \"f017\", \"M256 0a256 256 0 1 1 0 512A256 256 0 1 1 256 0zM232 120l0 136c0 8 4 15.5 10.7 20l96 64c11 7.4 25.9 4.4 33.3-6.7s4.4-25.9-6.7-33.3L280 243.2 280 120c0-13.3-10.7-24-24-24s-24 10.7-24 24z\"]\n};\nconst faClockFour = faClock;\nconst faBackwardStep = {\n prefix: 'fas',\n iconName: 'backward-step',\n icon: [320, 512, [\"step-backward\"], \"f048\", \"M267.5 440.6c9.5 7.9 22.8 9.7 34.1 4.4s18.4-16.6 18.4-29l0-320c0-12.4-7.2-23.7-18.4-29s-24.5-3.6-34.1 4.4l-192 160L64 241 64 96c0-17.7-14.3-32-32-32S0 78.3 0 96L0 416c0 17.7 14.3 32 32 32s32-14.3 32-32l0-145 11.5 9.6 192 160z\"]\n};\nconst faStepBackward = faBackwardStep;\nconst faPallet = {\n prefix: 'fas',\n iconName: 'pallet',\n icon: [640, 512, [], \"f482\", \"M32 320c-17.7 0-32 14.3-32 32s14.3 32 32 32l32 0 0 64-32 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l64 0 224 0 224 0 64 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-32 0 0-64 32 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-64 0-224 0L96 320l-64 0zm96 64l160 0 0 64-160 0 0-64zm224 0l160 0 0 64-160 0 0-64z\"]\n};\nconst faFaucet = {\n prefix: 'fas',\n iconName: 'faucet',\n icon: [512, 512, [], \"e005\", \"M192 96l0 12L96 96c-17.7 0-32 14.3-32 32s14.3 32 32 32l96-12 31-3.9 1-.1 1 .1 31 3.9 96 12c17.7 0 32-14.3 32-32s-14.3-32-32-32l-96 12 0-12c0-17.7-14.3-32-32-32s-32 14.3-32 32zM32 256c-17.7 0-32 14.3-32 32l0 64c0 17.7 14.3 32 32 32l100.1 0c20.2 29 53.9 48 91.9 48s71.7-19 91.9-48l36.1 0c17.7 0 32 14.3 32 32s14.3 32 32 32l64 0c17.7 0 32-14.3 32-32c0-88.4-71.6-160-160-160l-32 0-22.6-22.6c-6-6-14.1-9.4-22.6-9.4L256 224l0-43.8-32-4-32 4 0 43.8-18.7 0c-8.5 0-16.6 3.4-22.6 9.4L128 256l-96 0z\"]\n};\nconst faBaseballBatBall = {\n prefix: 'fas',\n iconName: 'baseball-bat-ball',\n icon: [512, 512, [], \"f432\", \"M424 0c-12.4 0-24.2 4.9-33 13.7L233.5 171.2c-10.5 10.5-19.8 22.1-27.7 34.6L132.7 321.6c-7.3 11.5-15.8 22.2-25.5 31.9L69.9 390.7l51.3 51.3 37.3-37.3c9.6-9.6 20.3-18.2 31.9-25.5l115.8-73.1c12.5-7.9 24.1-17.2 34.6-27.7L498.3 121c8.7-8.7 13.7-20.6 13.7-33s-4.9-24.2-13.7-33L457 13.7C448.2 4.9 436.4 0 424 0zm88 432a80 80 0 1 0 -160 0 80 80 0 1 0 160 0zM15 399c-9.4 9.4-9.4 24.6 0 33.9l64 64c9.4 9.4 24.6 9.4 33.9 0s9.4-24.6 0-33.9L49 399c-9.4-9.4-24.6-9.4-33.9 0z\"]\n};\nconst faS = {\n prefix: 'fas',\n iconName: 's',\n icon: [320, 512, [115], \"53\", \"M99.1 105.4C79 114 68.2 127.2 65.2 144.8c-2.4 14.1-.7 23.2 2 29.4c2.8 6.3 7.9 12.4 16.7 18.6c19.2 13.4 48.3 22.1 84.9 32.5c1 .3 1.9 .6 2.9 .8c32.7 9.3 72 20.6 100.9 40.7c15.7 10.9 29.9 25.5 38.6 45.1c8.8 19.8 10.8 42 6.6 66.3c-7.3 42.5-35.3 71.7-71.8 87.3c-35.4 15.2-79.1 17.9-123.7 10.9l-.2 0s0 0 0 0c-24-3.9-62.7-17.1-87.6-25.6c-4.8-1.7-9.2-3.1-12.8-4.3C5.1 440.8-3.9 422.7 1.6 405.9s23.7-25.8 40.5-20.3c4.9 1.6 10.2 3.4 15.9 5.4c25.4 8.6 56.4 19.2 74.4 22.1c36.8 5.7 67.5 2.5 88.5-6.5c20.1-8.6 30.8-21.8 33.9-39.4c2.4-14.1 .7-23.2-2-29.4c-2.8-6.3-7.9-12.4-16.7-18.6c-19.2-13.4-48.3-22.1-84.9-32.5c-1-.3-1.9-.6-2.9-.8c-32.7-9.3-72-20.6-100.9-40.7c-15.7-10.9-29.9-25.5-38.6-45.1c-8.8-19.8-10.8-42-6.6-66.3l31.5 5.5L2.1 133.9C9.4 91.4 37.4 62.2 73.9 46.6c35.4-15.2 79.1-17.9 123.7-10.9c13 2 52.4 9.6 66.6 13.4c17.1 4.5 27.2 22.1 22.7 39.2s-22.1 27.2-39.2 22.7c-11.2-3-48.1-10.2-60.1-12l4.9-31.5-4.9 31.5c-36.9-5.8-67.5-2.5-88.6 6.5z\"]\n};\nconst faTimeline = {\n prefix: 'fas',\n iconName: 'timeline',\n icon: [640, 512, [], \"e29c\", \"M128 72a24 24 0 1 1 0 48 24 24 0 1 1 0-48zm32 97.3c28.3-12.3 48-40.5 48-73.3c0-44.2-35.8-80-80-80S48 51.8 48 96c0 32.8 19.7 61 48 73.3L96 224l-64 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l256 0 0 54.7c-28.3 12.3-48 40.5-48 73.3c0 44.2 35.8 80 80 80s80-35.8 80-80c0-32.8-19.7-61-48-73.3l0-54.7 256 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-64 0 0-54.7c28.3-12.3 48-40.5 48-73.3c0-44.2-35.8-80-80-80s-80 35.8-80 80c0 32.8 19.7 61 48 73.3l0 54.7-320 0 0-54.7zM488 96a24 24 0 1 1 48 0 24 24 0 1 1 -48 0zM320 392a24 24 0 1 1 0 48 24 24 0 1 1 0-48z\"]\n};\nconst faKeyboard = {\n prefix: 'fas',\n iconName: 'keyboard',\n icon: [576, 512, [9000], \"f11c\", \"M64 64C28.7 64 0 92.7 0 128L0 384c0 35.3 28.7 64 64 64l448 0c35.3 0 64-28.7 64-64l0-256c0-35.3-28.7-64-64-64L64 64zm16 64l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16zM64 240c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32zm16 80l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16zm80-176c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32zm16 80l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16zM160 336c0-8.8 7.2-16 16-16l224 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-224 0c-8.8 0-16-7.2-16-16l0-32zM272 128l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16zM256 240c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32zM368 128l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16zM352 240c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32zM464 128l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16zM448 240c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32zm16 80l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16z\"]\n};\nconst faCaretDown = {\n prefix: 'fas',\n iconName: 'caret-down',\n icon: [320, 512, [], \"f0d7\", \"M137.4 374.6c12.5 12.5 32.8 12.5 45.3 0l128-128c9.2-9.2 11.9-22.9 6.9-34.9s-16.6-19.8-29.6-19.8L32 192c-12.9 0-24.6 7.8-29.6 19.8s-2.2 25.7 6.9 34.9l128 128z\"]\n};\nconst faHouseChimneyMedical = {\n prefix: 'fas',\n iconName: 'house-chimney-medical',\n icon: [576, 512, [\"clinic-medical\"], \"f7f2\", \"M575.8 255.5c0 18-15 32.1-32 32.1l-32 0 .7 160.2c.2 35.5-28.5 64.3-64 64.3l-320.4 0c-35.3 0-64-28.7-64-64l0-160.4-32 0c-18 0-32-14-32-32.1c0-9 3-17 10-24L266.4 8c7-7 15-8 22-8s15 2 21 7L416 100.7 416 64c0-17.7 14.3-32 32-32l32 0c17.7 0 32 14.3 32 32l0 121 52.8 46.4c8 7 12 15 11 24zM272 192c-8.8 0-16 7.2-16 16l0 48-48 0c-8.8 0-16 7.2-16 16l0 32c0 8.8 7.2 16 16 16l48 0 0 48c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-48 48 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-48 0 0-48c0-8.8-7.2-16-16-16l-32 0z\"]\n};\nconst faClinicMedical = faHouseChimneyMedical;\nconst faTemperatureThreeQuarters = {\n prefix: 'fas',\n iconName: 'temperature-three-quarters',\n icon: [320, 512, [\"temperature-3\", \"thermometer-3\", \"thermometer-three-quarters\"], \"f2c8\", \"M160 64c-26.5 0-48 21.5-48 48l0 164.5c0 17.3-7.1 31.9-15.3 42.5C86.2 332.6 80 349.5 80 368c0 44.2 35.8 80 80 80s80-35.8 80-80c0-18.5-6.2-35.4-16.7-48.9c-8.2-10.6-15.3-25.2-15.3-42.5L208 112c0-26.5-21.5-48-48-48zM48 112C48 50.2 98.1 0 160 0s112 50.1 112 112l0 164.4c0 .1 .1 .3 .2 .6c.2 .6 .8 1.6 1.7 2.8c18.9 24.4 30.1 55 30.1 88.1c0 79.5-64.5 144-144 144S16 447.5 16 368c0-33.2 11.2-63.8 30.1-88.1c.9-1.2 1.5-2.2 1.7-2.8c.1-.3 .2-.5 .2-.6L48 112zM208 368c0 26.5-21.5 48-48 48s-48-21.5-48-48c0-20.9 13.4-38.7 32-45.3L144 144c0-8.8 7.2-16 16-16s16 7.2 16 16l0 178.7c18.6 6.6 32 24.4 32 45.3z\"]\n};\nconst faTemperature3 = faTemperatureThreeQuarters;\nconst faThermometer3 = faTemperatureThreeQuarters;\nconst faThermometerThreeQuarters = faTemperatureThreeQuarters;\nconst faMobileScreen = {\n prefix: 'fas',\n iconName: 'mobile-screen',\n icon: [384, 512, [\"mobile-android-alt\"], \"f3cf\", \"M16 64C16 28.7 44.7 0 80 0L304 0c35.3 0 64 28.7 64 64l0 384c0 35.3-28.7 64-64 64L80 512c-35.3 0-64-28.7-64-64L16 64zM144 448c0 8.8 7.2 16 16 16l64 0c8.8 0 16-7.2 16-16s-7.2-16-16-16l-64 0c-8.8 0-16 7.2-16 16zM304 64L80 64l0 320 224 0 0-320z\"]\n};\nconst faMobileAndroidAlt = faMobileScreen;\nconst faPlaneUp = {\n prefix: 'fas',\n iconName: 'plane-up',\n icon: [512, 512, [], \"e22d\", \"M192 93.7C192 59.5 221 0 256 0c36 0 64 59.5 64 93.7l0 66.3L497.8 278.5c8.9 5.9 14.2 15.9 14.2 26.6l0 56.7c0 10.9-10.7 18.6-21.1 15.2L320 320l0 80 57.6 43.2c4 3 6.4 7.8 6.4 12.8l0 42c0 7.8-6.3 14-14 14c-1.3 0-2.6-.2-3.9-.5L256 480 145.9 511.5c-1.3 .4-2.6 .5-3.9 .5c-7.8 0-14-6.3-14-14l0-42c0-5 2.4-9.8 6.4-12.8L192 400l0-80L21.1 377C10.7 380.4 0 372.7 0 361.8l0-56.7c0-10.7 5.3-20.7 14.2-26.6L192 160l0-66.3z\"]\n};\nconst faPiggyBank = {\n prefix: 'fas',\n iconName: 'piggy-bank',\n icon: [576, 512, [], \"f4d3\", \"M400 96l0 .7c-5.3-.4-10.6-.7-16-.7L256 96c-16.5 0-32.5 2.1-47.8 6c-.1-2-.2-4-.2-6c0-53 43-96 96-96s96 43 96 96zm-16 32c3.5 0 7 .1 10.4 .3c4.2 .3 8.4 .7 12.6 1.3C424.6 109.1 450.8 96 480 96l11.5 0c10.4 0 18 9.8 15.5 19.9l-13.8 55.2c15.8 14.8 28.7 32.8 37.5 52.9l13.3 0c17.7 0 32 14.3 32 32l0 96c0 17.7-14.3 32-32 32l-32 0c-9.1 12.1-19.9 22.9-32 32l0 64c0 17.7-14.3 32-32 32l-32 0c-17.7 0-32-14.3-32-32l0-32-128 0 0 32c0 17.7-14.3 32-32 32l-32 0c-17.7 0-32-14.3-32-32l0-64c-34.9-26.2-58.7-66.3-63.2-112L68 304c-37.6 0-68-30.4-68-68s30.4-68 68-68l4 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-4 0c-11 0-20 9-20 20s9 20 20 20l31.2 0c12.1-59.8 57.7-107.5 116.3-122.8c12.9-3.4 26.5-5.2 40.5-5.2l128 0zm64 136a24 24 0 1 0 -48 0 24 24 0 1 0 48 0z\"]\n};\nconst faBatteryHalf = {\n prefix: 'fas',\n iconName: 'battery-half',\n icon: [576, 512, [\"battery-3\"], \"f242\", \"M464 160c8.8 0 16 7.2 16 16l0 160c0 8.8-7.2 16-16 16L80 352c-8.8 0-16-7.2-16-16l0-160c0-8.8 7.2-16 16-16l384 0zM80 96C35.8 96 0 131.8 0 176L0 336c0 44.2 35.8 80 80 80l384 0c44.2 0 80-35.8 80-80l0-16c17.7 0 32-14.3 32-32l0-64c0-17.7-14.3-32-32-32l0-16c0-44.2-35.8-80-80-80L80 96zm208 96L96 192l0 128 192 0 0-128z\"]\n};\nconst faBattery3 = faBatteryHalf;\nconst faMountainCity = {\n prefix: 'fas',\n iconName: 'mountain-city',\n icon: [640, 512, [], \"e52e\", \"M336 0c-26.5 0-48 21.5-48 48l0 92.1 71.4 118.4c2.5-1.6 5.4-2.5 8.6-2.5l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-3.5 0 73.8 122.4c12.4 20.6 12.9 46.3 1.2 67.3c-.4 .8-.9 1.6-1.4 2.3L592 512c26.5 0 48-21.5 48-48l0-224c0-26.5-21.5-48-48-48l-24 0 0-72c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 72-40 0 0-144c0-26.5-21.5-48-48-48L336 0zm32 64l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16zM352 176c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32zm160 96c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32zm16 80l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16zM224 188.9L283.8 288 223 288l-48 64-24.6-41.2L224 188.9zm29.4-44.2C247.1 134.3 236 128 224 128s-23.1 6.3-29.4 16.7L5.1 458.9c-6.5 10.8-6.7 24.3-.7 35.3S22 512 34.5 512l379.1 0c12.5 0 24-6.8 30.1-17.8s5.8-24.5-.7-35.3L253.4 144.7z\"]\n};\nconst faCoins = {\n prefix: 'fas',\n iconName: 'coins',\n icon: [512, 512, [], \"f51e\", \"M512 80c0 18-14.3 34.6-38.4 48c-29.1 16.1-72.5 27.5-122.3 30.9c-3.7-1.8-7.4-3.5-11.3-5C300.6 137.4 248.2 128 192 128c-8.3 0-16.4 .2-24.5 .6l-1.1-.6C142.3 114.6 128 98 128 80c0-44.2 86-80 192-80S512 35.8 512 80zM160.7 161.1c10.2-.7 20.7-1.1 31.3-1.1c62.2 0 117.4 12.3 152.5 31.4C369.3 204.9 384 221.7 384 240c0 4-.7 7.9-2.1 11.7c-4.6 13.2-17 25.3-35 35.5c0 0 0 0 0 0c-.1 .1-.3 .1-.4 .2c0 0 0 0 0 0s0 0 0 0c-.3 .2-.6 .3-.9 .5c-35 19.4-90.8 32-153.6 32c-59.6 0-112.9-11.3-148.2-29.1c-1.9-.9-3.7-1.9-5.5-2.9C14.3 274.6 0 258 0 240c0-34.8 53.4-64.5 128-75.4c10.5-1.5 21.4-2.7 32.7-3.5zM416 240c0-21.9-10.6-39.9-24.1-53.4c28.3-4.4 54.2-11.4 76.2-20.5c16.3-6.8 31.5-15.2 43.9-25.5l0 35.4c0 19.3-16.5 37.1-43.8 50.9c-14.6 7.4-32.4 13.7-52.4 18.5c.1-1.8 .2-3.5 .2-5.3zm-32 96c0 18-14.3 34.6-38.4 48c-1.8 1-3.6 1.9-5.5 2.9C304.9 404.7 251.6 416 192 416c-62.8 0-118.6-12.6-153.6-32C14.3 370.6 0 354 0 336l0-35.4c12.5 10.3 27.6 18.7 43.9 25.5C83.4 342.6 135.8 352 192 352s108.6-9.4 148.1-25.9c7.8-3.2 15.3-6.9 22.4-10.9c6.1-3.4 11.8-7.2 17.2-11.2c1.5-1.1 2.9-2.3 4.3-3.4l0 3.4 0 5.7 0 26.3zm32 0l0-32 0-25.9c19-4.2 36.5-9.5 52.1-16c16.3-6.8 31.5-15.2 43.9-25.5l0 35.4c0 10.5-5 21-14.9 30.9c-16.3 16.3-45 29.7-81.3 38.4c.1-1.7 .2-3.5 .2-5.3zM192 448c56.2 0 108.6-9.4 148.1-25.9c16.3-6.8 31.5-15.2 43.9-25.5l0 35.4c0 44.2-86 80-192 80S0 476.2 0 432l0-35.4c12.5 10.3 27.6 18.7 43.9 25.5C83.4 438.6 135.8 448 192 448z\"]\n};\nconst faKhanda = {\n prefix: 'fas',\n iconName: 'khanda',\n icon: [512, 512, [9772], \"f66d\", \"M245.8 3.7c5.9-4.9 14.6-4.9 20.5 0l48 40c5.9 4.9 7.5 13.2 3.8 19.9c0 0 0 0 0 0s0 0 0 0s0 0 0 0s0 0 0 0l-.1 .1-.3 .6c-.3 .5-.7 1.3-1.2 2.3c-1 2-2.6 5-4.4 8.6c-.5 .9-.9 1.9-1.4 2.9C344.9 97.4 368 134 368 176s-23.1 78.6-57.3 97.8c.5 1 1 2 1.4 2.9c1.8 3.7 3.3 6.6 4.4 8.6c.5 1 .9 1.8 1.2 2.3l.3 .6 .1 .1s0 0 0 0s0 0 0 0c3.6 6.7 2 15-3.8 19.9L272 343.5l0 19.8 35.6-24.5 41.1-28.2c42.8-29.4 68.4-78 68.4-130c0-31.1-9.2-61.6-26.5-87.5l-2.8-4.2c-4-6-3.5-14 1.3-19.5s12.7-7 19.2-3.7L401.1 80c7.2-14.3 7.2-14.3 7.2-14.3s0 0 0 0s0 0 0 0l.1 0 .3 .2 1 .5c.8 .4 2 1.1 3.5 1.9c2.9 1.7 7 4.1 11.8 7.3c9.6 6.4 22.5 16.1 35.4 29c25.7 25.7 52.7 65.6 52.7 119.3c0 53.1-26.4 100.5-51.2 133.6c-12.6 16.7-25.1 30.3-34.5 39.7c-4.7 4.7-8.7 8.4-11.5 10.9c-1.4 1.3-2.5 2.2-3.3 2.9l-.9 .8-.3 .2-.1 .1c0 0 0 0 0 0s0 0 0 0L401.1 400l10.2 12.3c-5.1 4.3-12.4 4.9-18.2 1.6l-75.6-43-32.7 22.5 45.5 31.3c1.8-.4 3.7-.7 5.7-.7c13.3 0 24 10.7 24 24s-10.7 24-24 24c-12.2 0-22.3-9.1-23.8-21L272 423.4l0 28.9c9.6 5.5 16 15.9 16 27.7c0 17.7-14.3 32-32 32s-32-14.3-32-32c0-11.8 6.4-22.2 16-27.7l0-28.1-40.3 27.7C197.8 463.3 187.9 472 176 472c-13.3 0-24-10.7-24-24s10.7-24 24-24c2.2 0 4.4 .3 6.5 .9l45.8-31.5-32.7-22.5-75.6 43c-5.8 3.3-13 2.7-18.2-1.6L112 400c-10.2 12.3-10.2 12.3-10.3 12.3s0 0 0 0s0 0 0 0l-.1-.1-.3-.2-.9-.8c-.8-.7-1.9-1.7-3.3-2.9c-2.8-2.5-6.7-6.2-11.5-10.9c-9.4-9.4-21.9-23-34.5-39.7C26.4 324.5 0 277.1 0 224c0-53.7 26.9-93.6 52.7-119.3c12.9-12.9 25.8-22.6 35.4-29C93 72.5 97 70 99.9 68.4c1.5-.8 2.6-1.5 3.5-1.9l1-.5 .3-.2 .1 0c0 0 0 0 0 0s0 0 0 0L112 80l-7.2-14.3c6.5-3.2 14.3-1.7 19.2 3.7s5.3 13.4 1.3 19.5l-2.8 4.2C105.2 119 96 149.5 96 180.6c0 51.9 25.6 100.6 68.4 130l41.1 28.2L240 362.6l0-19.1-42.2-35.2c-5.9-4.9-7.5-13.2-3.8-19.9c0 0 0 0 0 0s0 0 0 0s0 0 0 0l.1-.1 .3-.6c.3-.5 .7-1.3 1.2-2.3c1-2 2.6-5 4.4-8.6c.5-.9 .9-1.9 1.4-2.9C167.1 254.6 144 218 144 176s23.1-78.6 57.3-97.8c-.5-1-1-2-1.4-2.9c-1.8-3.7-3.3-6.6-4.4-8.6c-.5-1-.9-1.8-1.2-2.3l-.3-.6-.1-.1s0 0 0 0s0 0 0 0s0 0 0 0c-3.6-6.7-2-15 3.8-19.9l48-40zM220.2 122.9c-17 11.5-28.2 31-28.2 53.1s11.2 41.6 28.2 53.1C227 210.2 232 190.9 232 176s-5-34.2-11.8-53.1zm71.5 106.2c17-11.5 28.2-31 28.2-53.1s-11.2-41.6-28.2-53.1C285 141.8 280 161.1 280 176s5 34.2 11.8 53.1z\"]\n};\nconst faSliders = {\n prefix: 'fas',\n iconName: 'sliders',\n icon: [512, 512, [\"sliders-h\"], \"f1de\", \"M0 416c0 17.7 14.3 32 32 32l54.7 0c12.3 28.3 40.5 48 73.3 48s61-19.7 73.3-48L480 448c17.7 0 32-14.3 32-32s-14.3-32-32-32l-246.7 0c-12.3-28.3-40.5-48-73.3-48s-61 19.7-73.3 48L32 384c-17.7 0-32 14.3-32 32zm128 0a32 32 0 1 1 64 0 32 32 0 1 1 -64 0zM320 256a32 32 0 1 1 64 0 32 32 0 1 1 -64 0zm32-80c-32.8 0-61 19.7-73.3 48L32 224c-17.7 0-32 14.3-32 32s14.3 32 32 32l246.7 0c12.3 28.3 40.5 48 73.3 48s61-19.7 73.3-48l54.7 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-54.7 0c-12.3-28.3-40.5-48-73.3-48zM192 128a32 32 0 1 1 0-64 32 32 0 1 1 0 64zm73.3-64C253 35.7 224.8 16 192 16s-61 19.7-73.3 48L32 64C14.3 64 0 78.3 0 96s14.3 32 32 32l86.7 0c12.3 28.3 40.5 48 73.3 48s61-19.7 73.3-48L480 128c17.7 0 32-14.3 32-32s-14.3-32-32-32L265.3 64z\"]\n};\nconst faSlidersH = faSliders;\nconst faFolderTree = {\n prefix: 'fas',\n iconName: 'folder-tree',\n icon: [576, 512, [], \"f802\", \"M64 32C64 14.3 49.7 0 32 0S0 14.3 0 32l0 96L0 384c0 35.3 28.7 64 64 64l192 0 0-64L64 384l0-224 192 0 0-64L64 96l0-64zM288 192c0 17.7 14.3 32 32 32l224 0c17.7 0 32-14.3 32-32l0-128c0-17.7-14.3-32-32-32l-98.7 0c-8.5 0-16.6-3.4-22.6-9.4L409.4 9.4c-6-6-14.1-9.4-22.6-9.4L320 0c-17.7 0-32 14.3-32 32l0 160zm0 288c0 17.7 14.3 32 32 32l224 0c17.7 0 32-14.3 32-32l0-128c0-17.7-14.3-32-32-32l-98.7 0c-8.5 0-16.6-3.4-22.6-9.4l-13.3-13.3c-6-6-14.1-9.4-22.6-9.4L320 288c-17.7 0-32 14.3-32 32l0 160z\"]\n};\nconst faNetworkWired = {\n prefix: 'fas',\n iconName: 'network-wired',\n icon: [640, 512, [], \"f6ff\", \"M256 64l128 0 0 64-128 0 0-64zM240 0c-26.5 0-48 21.5-48 48l0 96c0 26.5 21.5 48 48 48l48 0 0 32L32 224c-17.7 0-32 14.3-32 32s14.3 32 32 32l96 0 0 32-48 0c-26.5 0-48 21.5-48 48l0 96c0 26.5 21.5 48 48 48l160 0c26.5 0 48-21.5 48-48l0-96c0-26.5-21.5-48-48-48l-48 0 0-32 256 0 0 32-48 0c-26.5 0-48 21.5-48 48l0 96c0 26.5 21.5 48 48 48l160 0c26.5 0 48-21.5 48-48l0-96c0-26.5-21.5-48-48-48l-48 0 0-32 96 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-256 0 0-32 48 0c26.5 0 48-21.5 48-48l0-96c0-26.5-21.5-48-48-48L240 0zM96 448l0-64 128 0 0 64L96 448zm320-64l128 0 0 64-128 0 0-64z\"]\n};\nconst faMapPin = {\n prefix: 'fas',\n iconName: 'map-pin',\n icon: [320, 512, [128205], \"f276\", \"M16 144a144 144 0 1 1 288 0A144 144 0 1 1 16 144zM160 80c8.8 0 16-7.2 16-16s-7.2-16-16-16c-53 0-96 43-96 96c0 8.8 7.2 16 16 16s16-7.2 16-16c0-35.3 28.7-64 64-64zM128 480l0-162.9c10.4 1.9 21.1 2.9 32 2.9s21.6-1 32-2.9L192 480c0 17.7-14.3 32-32 32s-32-14.3-32-32z\"]\n};\nconst faHamsa = {\n prefix: 'fas',\n iconName: 'hamsa',\n icon: [512, 512, [], \"f665\", \"M34.6 288L80 288c8.8 0 16-7.2 16-16L96 72c0-22.1 17.9-40 40-40s40 17.9 40 40l0 132c0 11 9 20 20 20s20-9 20-20l0-164c0-22.1 17.9-40 40-40s40 17.9 40 40l0 164c0 11 9 20 20 20s20-9 20-20l0-132c0-22.1 17.9-40 40-40s40 17.9 40 40l0 200c0 8.8 7.2 16 16 16l45.4 0c19.1 0 34.6 15.5 34.6 34.6c0 8.6-3.2 16.9-9 23.3L416.6 441c-41.1 45.2-99.4 71-160.6 71s-119.4-25.8-160.6-71L9 345.9c-5.8-6.4-9-14.7-9-23.3C0 303.5 15.5 288 34.6 288zM256 288c-38.4 0-76.8 35.8-90.6 50.2c-3.6 3.7-5.4 8.7-5.4 13.8s1.8 10.1 5.4 13.8C179.2 380.2 217.6 416 256 416s76.8-35.8 90.6-50.2c3.6-3.7 5.4-8.7 5.4-13.8s-1.8-10.1-5.4-13.8C332.8 323.8 294.4 288 256 288zm0 32a32 32 0 1 1 0 64 32 32 0 1 1 0-64z\"]\n};\nconst faCentSign = {\n prefix: 'fas',\n iconName: 'cent-sign',\n icon: [384, 512, [], \"e3f5\", \"M224 0c17.7 0 32 14.3 32 32l0 34.7c30.9 5.2 59.2 17.7 83.2 35.8c14.1 10.6 17 30.7 6.4 44.8s-30.7 17-44.8 6.4C279.4 137.5 252.9 128 224 128c-70.7 0-128 57.3-128 128s57.3 128 128 128c28.9 0 55.4-9.5 76.8-25.6c14.1-10.6 34.2-7.8 44.8 6.4s7.8 34.2-6.4 44.8c-24 18-52.4 30.6-83.2 35.8l0 34.7c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-34.7C101.2 430.1 32 351.1 32 256s69.2-174.1 160-189.3L192 32c0-17.7 14.3-32 32-32z\"]\n};\nconst faFlask = {\n prefix: 'fas',\n iconName: 'flask',\n icon: [448, 512, [], \"f0c3\", \"M288 0L160 0 128 0C110.3 0 96 14.3 96 32s14.3 32 32 32l0 132.8c0 11.8-3.3 23.5-9.5 33.5L10.3 406.2C3.6 417.2 0 429.7 0 442.6C0 480.9 31.1 512 69.4 512l309.2 0c38.3 0 69.4-31.1 69.4-69.4c0-12.8-3.6-25.4-10.3-36.4L329.5 230.4c-6.2-10.1-9.5-21.7-9.5-33.5L320 64c17.7 0 32-14.3 32-32s-14.3-32-32-32L288 0zM192 196.8L192 64l64 0 0 132.8c0 23.7 6.6 46.9 19 67.1L309.5 320l-171 0L173 263.9c12.4-20.2 19-43.4 19-67.1z\"]\n};\nconst faPersonPregnant = {\n prefix: 'fas',\n iconName: 'person-pregnant',\n icon: [384, 512, [], \"e31e\", \"M192 0a48 48 0 1 1 0 96 48 48 0 1 1 0-96zM120 383c-13.8-3.6-24-16.1-24-31l0-55.1-4.6 7.6c-9.1 15.1-28.8 20-43.9 10.9s-20-28.8-10.9-43.9l58.3-97c15-24.9 40.3-41.5 68.7-45.6c4.1-.6 8.2-1 12.5-1l1.1 0 12.5 0 2.4 0c1.4 0 2.8 .1 4.1 .3c35.7 2.9 65.4 29.3 72.1 65l6.1 32.5c44.3 8.6 77.7 47.5 77.7 94.3l0 32c0 17.7-14.3 32-32 32l-16 0-40 0 0 96c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-96-8 0-8 0 0 96c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-97z\"]\n};\nconst faWandSparkles = {\n prefix: 'fas',\n iconName: 'wand-sparkles',\n icon: [512, 512, [], \"f72b\", \"M464 6.1c9.5-8.5 24-8.1 33 .9l8 8c9 9 9.4 23.5 .9 33l-85.8 95.9c-2.6 2.9-4.1 6.7-4.1 10.7l0 21.4c0 8.8-7.2 16-16 16l-15.8 0c-4.6 0-8.9 1.9-11.9 5.3L100.7 500.9C94.3 508 85.3 512 75.8 512c-8.8 0-17.3-3.5-23.5-9.8L9.7 459.7C3.5 453.4 0 445 0 436.2c0-9.5 4-18.5 11.1-24.8l111.6-99.8c3.4-3 5.3-7.4 5.3-11.9l0-27.6c0-8.8 7.2-16 16-16l34.6 0c3.9 0 7.7-1.5 10.7-4.1L464 6.1zM432 288c3.6 0 6.7 2.4 7.7 5.8l14.8 51.7 51.7 14.8c3.4 1 5.8 4.1 5.8 7.7s-2.4 6.7-5.8 7.7l-51.7 14.8-14.8 51.7c-1 3.4-4.1 5.8-7.7 5.8s-6.7-2.4-7.7-5.8l-14.8-51.7-51.7-14.8c-3.4-1-5.8-4.1-5.8-7.7s2.4-6.7 5.8-7.7l51.7-14.8 14.8-51.7c1-3.4 4.1-5.8 7.7-5.8zM87.7 69.8l14.8 51.7 51.7 14.8c3.4 1 5.8 4.1 5.8 7.7s-2.4 6.7-5.8 7.7l-51.7 14.8L87.7 218.2c-1 3.4-4.1 5.8-7.7 5.8s-6.7-2.4-7.7-5.8L57.5 166.5 5.8 151.7c-3.4-1-5.8-4.1-5.8-7.7s2.4-6.7 5.8-7.7l51.7-14.8L72.3 69.8c1-3.4 4.1-5.8 7.7-5.8s6.7 2.4 7.7 5.8zM208 0c3.7 0 6.9 2.5 7.8 6.1l6.8 27.3 27.3 6.8c3.6 .9 6.1 4.1 6.1 7.8s-2.5 6.9-6.1 7.8l-27.3 6.8-6.8 27.3c-.9 3.6-4.1 6.1-7.8 6.1s-6.9-2.5-7.8-6.1l-6.8-27.3-27.3-6.8c-3.6-.9-6.1-4.1-6.1-7.8s2.5-6.9 6.1-7.8l27.3-6.8 6.8-27.3c.9-3.6 4.1-6.1 7.8-6.1z\"]\n};\nconst faEllipsisVertical = {\n prefix: 'fas',\n iconName: 'ellipsis-vertical',\n icon: [128, 512, [\"ellipsis-v\"], \"f142\", \"M64 360a56 56 0 1 0 0 112 56 56 0 1 0 0-112zm0-160a56 56 0 1 0 0 112 56 56 0 1 0 0-112zM120 96A56 56 0 1 0 8 96a56 56 0 1 0 112 0z\"]\n};\nconst faEllipsisV = faEllipsisVertical;\nconst faTicket = {\n prefix: 'fas',\n iconName: 'ticket',\n icon: [576, 512, [127903], \"f145\", \"M64 64C28.7 64 0 92.7 0 128l0 64c0 8.8 7.4 15.7 15.7 18.6C34.5 217.1 48 235 48 256s-13.5 38.9-32.3 45.4C7.4 304.3 0 311.2 0 320l0 64c0 35.3 28.7 64 64 64l448 0c35.3 0 64-28.7 64-64l0-64c0-8.8-7.4-15.7-15.7-18.6C541.5 294.9 528 277 528 256s13.5-38.9 32.3-45.4c8.3-2.9 15.7-9.8 15.7-18.6l0-64c0-35.3-28.7-64-64-64L64 64zm64 112l0 160c0 8.8 7.2 16 16 16l288 0c8.8 0 16-7.2 16-16l0-160c0-8.8-7.2-16-16-16l-288 0c-8.8 0-16 7.2-16 16zM96 160c0-17.7 14.3-32 32-32l320 0c17.7 0 32 14.3 32 32l0 192c0 17.7-14.3 32-32 32l-320 0c-17.7 0-32-14.3-32-32l0-192z\"]\n};\nconst faPowerOff = {\n prefix: 'fas',\n iconName: 'power-off',\n icon: [512, 512, [9211], \"f011\", \"M288 32c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 224c0 17.7 14.3 32 32 32s32-14.3 32-32l0-224zM143.5 120.6c13.6-11.3 15.4-31.5 4.1-45.1s-31.5-15.4-45.1-4.1C49.7 115.4 16 181.8 16 256c0 132.5 107.5 240 240 240s240-107.5 240-240c0-74.2-33.8-140.6-86.6-184.6c-13.6-11.3-33.8-9.4-45.1 4.1s-9.4 33.8 4.1 45.1c38.9 32.3 63.5 81 63.5 135.4c0 97.2-78.8 176-176 176s-176-78.8-176-176c0-54.4 24.7-103.1 63.5-135.4z\"]\n};\nconst faRightLong = {\n prefix: 'fas',\n iconName: 'right-long',\n icon: [512, 512, [\"long-arrow-alt-right\"], \"f30b\", \"M334.5 414c8.8 3.8 19 2 26-4.6l144-136c4.8-4.5 7.5-10.8 7.5-17.4s-2.7-12.9-7.5-17.4l-144-136c-7-6.6-17.2-8.4-26-4.6s-14.5 12.5-14.5 22l0 72L32 192c-17.7 0-32 14.3-32 32l0 64c0 17.7 14.3 32 32 32l288 0 0 72c0 9.6 5.7 18.2 14.5 22z\"]\n};\nconst faLongArrowAltRight = faRightLong;\nconst faFlagUsa = {\n prefix: 'fas',\n iconName: 'flag-usa',\n icon: [448, 512, [], \"f74d\", \"M32 0C49.7 0 64 14.3 64 32l0 16 69-17.2c38.1-9.5 78.3-5.1 113.5 12.5c46.3 23.2 100.8 23.2 147.1 0l9.6-4.8C423.8 28.1 448 43.1 448 66.1l0 36.1-44.7 16.2c-42.8 15.6-90 13.9-131.6-4.6l-16.1-7.2c-20.3-9-41.8-14.7-63.6-16.9l0 32.2c17.4 2.1 34.4 6.7 50.6 13.9l16.1 7.2c49.2 21.9 105 23.8 155.6 5.4L448 136.3l0 62-44.7 16.2c-42.8 15.6-90 13.9-131.6-4.6l-16.1-7.2c-40.2-17.9-85-22.5-128.1-13.3L64 203.1l0 32.7 70.2-15.1c36.4-7.8 74.3-3.9 108.4 11.3l16.1 7.2c49.2 21.9 105 23.8 155.6 5.4L448 232.3l0 62-44.7 16.2c-42.8 15.6-90 13.9-131.6-4.6l-16.1-7.2c-40.2-17.9-85-22.5-128.1-13.3L64 299.1l0 32.7 70.2-15.1c36.4-7.8 74.3-3.9 108.4 11.3l16.1 7.2c49.2 21.9 105 23.8 155.6 5.4L448 328.3l0 33.5c0 13.3-8.3 25.3-20.8 30l-34.7 13c-46.2 17.3-97.6 14.6-141.7-7.4c-37.9-19-81.3-23.7-122.5-13.4L64 400l0 80c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-64 0-70.5 0-32.7 0-63.3 0-32.7 0-63.3 0-32.7L0 64 0 32C0 14.3 14.3 0 32 0zm80 96A16 16 0 1 0 80 96a16 16 0 1 0 32 0zm32 0a16 16 0 1 0 0-32 16 16 0 1 0 0 32zm-32 48a16 16 0 1 0 -32 0 16 16 0 1 0 32 0zm32 0a16 16 0 1 0 0-32 16 16 0 1 0 0 32z\"]\n};\nconst faLaptopFile = {\n prefix: 'fas',\n iconName: 'laptop-file',\n icon: [640, 512, [], \"e51d\", \"M128 0C92.7 0 64 28.7 64 64l0 224-44.8 0C8.6 288 0 296.6 0 307.2C0 349.6 34.4 384 76.8 384L320 384l0-96-192 0 0-224 320 0 0 32 64 0 0-32c0-35.3-28.7-64-64-64L128 0zM512 128l-112 0c-26.5 0-48 21.5-48 48l0 288c0 26.5 21.5 48 48 48l192 0c26.5 0 48-21.5 48-48l0-208-96 0c-17.7 0-32-14.3-32-32l0-96zm32 0l0 96 96 0-96-96z\"]\n};\nconst faTty = {\n prefix: 'fas',\n iconName: 'tty',\n icon: [512, 512, [\"teletype\"], \"f1e4\", \"M38.3 241.3L15.1 200.6c-9.2-16.2-8.4-36.5 4.5-50C61.4 106.8 144.7 48 256 48s194.6 58.8 236.4 102.6c12.9 13.5 13.7 33.8 4.5 50l-23.1 40.7c-7.5 13.2-23.3 19.3-37.8 14.6l-81.1-26.6c-13.1-4.3-22-16.6-22-30.4l0-54.8c-49.6-18.1-104-18.1-153.6 0l0 54.8c0 13.8-8.9 26.1-22 30.4L76.1 255.8c-14.5 4.7-30.3-1.4-37.8-14.6zM32 336c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32zm0 96c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32zM144 320l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16zm80 16c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32zm112-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16zm80 16c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32zm16 80l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16zM128 432c0-8.8 7.2-16 16-16l224 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-224 0c-8.8 0-16-7.2-16-16l0-32z\"]\n};\nconst faTeletype = faTty;\nconst faDiagramNext = {\n prefix: 'fas',\n iconName: 'diagram-next',\n icon: [512, 512, [], \"e476\", \"M512 160c0 35.3-28.7 64-64 64l-168 0 0 64 46.1 0c21.4 0 32.1 25.9 17 41L273 399c-9.4 9.4-24.6 9.4-33.9 0L169 329c-15.1-15.1-4.4-41 17-41l46.1 0 0-64L64 224c-35.3 0-64-28.7-64-64L0 96C0 60.7 28.7 32 64 32l384 0c35.3 0 64 28.7 64 64l0 64zM448 416l0-64-82.7 0 .4-.4c18.4-18.4 20.4-43.7 11-63.6l71.3 0c35.3 0 64 28.7 64 64l0 64c0 35.3-28.7 64-64 64L64 480c-35.3 0-64-28.7-64-64l0-64c0-35.3 28.7-64 64-64l71.3 0c-9.4 19.9-7.4 45.2 11 63.6l.4 .4L64 352l0 64 146.7 0 5.7 5.7c21.9 21.9 57.3 21.9 79.2 0l5.7-5.7L448 416z\"]\n};\nconst faPersonRifle = {\n prefix: 'fas',\n iconName: 'person-rifle',\n icon: [576, 512, [], \"e54e\", \"M265.2 192c25.4 0 49.8 7.1 70.8 19.9L336 512l-192 0 0-174.3L90.4 428.3c-11.2 19-35.8 25.3-54.8 14.1s-25.3-35.8-14.1-54.8L97.7 258.8c24.5-41.4 69-66.8 117.1-66.8l50.4 0zM160 80a80 80 0 1 1 160 0A80 80 0 1 1 160 80zM448 0c8.8 0 16 7.2 16 16l0 116.3c9.6 5.5 16 15.9 16 27.7l0 109.3 16-5.3 0-56c0-8.8 7.2-16 16-16l16 0c8.8 0 16 7.2 16 16l0 84.5c0 6.9-4.4 13-10.9 15.2L480 325.3l0 26.7 48 0c8.8 0 16 7.2 16 16l0 16c0 8.8-7.2 16-16 16l-44 0 23 92.1c2.5 10.1-5.1 19.9-15.5 19.9L432 512c-8.8 0-16-7.2-16-16l0-96-16 0c-17.7 0-32-14.3-32-32l0-144c0-17.7 14.3-32 32-32l0-32c0-11.8 6.4-22.2 16-27.7L416 32c-8.8 0-16-7.2-16-16s7.2-16 16-16l16 0 16 0z\"]\n};\nconst faHouseMedicalCircleExclamation = {\n prefix: 'fas',\n iconName: 'house-medical-circle-exclamation',\n icon: [640, 512, [], \"e512\", \"M320 368c0 59.5 29.5 112.1 74.8 144l-266.7 0c-35.3 0-64-28.7-64-64l0-160.4-32 0c-18 0-32-14-32-32.1c0-9 3-17 10-24L266.4 8c7-7 15-8 22-8s15 2 21 7L522.1 193.9c-8.5-1.3-17.3-1.9-26.1-1.9c-54.7 0-103.5 24.9-135.8 64L320 256l0-48c0-8.8-7.2-16-16-16l-32 0c-8.8 0-16 7.2-16 16l0 48-48 0c-8.8 0-16 7.2-16 16l0 32c0 8.8 7.2 16 16 16l48 0 0 48c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16zM496 224a144 144 0 1 1 0 288 144 144 0 1 1 0-288zm0 240a24 24 0 1 0 0-48 24 24 0 1 0 0 48zm0-192c-8.8 0-16 7.2-16 16l0 80c0 8.8 7.2 16 16 16s16-7.2 16-16l0-80c0-8.8-7.2-16-16-16z\"]\n};\nconst faClosedCaptioning = {\n prefix: 'fas',\n iconName: 'closed-captioning',\n icon: [576, 512, [], \"f20a\", \"M0 96C0 60.7 28.7 32 64 32l448 0c35.3 0 64 28.7 64 64l0 320c0 35.3-28.7 64-64 64L64 480c-35.3 0-64-28.7-64-64L0 96zM200 208c14.2 0 27 6.1 35.8 16c8.8 9.9 24 10.7 33.9 1.9s10.7-24 1.9-33.9c-17.5-19.6-43.1-32-71.5-32c-53 0-96 43-96 96s43 96 96 96c28.4 0 54-12.4 71.5-32c8.8-9.9 8-25-1.9-33.9s-25-8-33.9 1.9c-8.8 9.9-21.6 16-35.8 16c-26.5 0-48-21.5-48-48s21.5-48 48-48zm144 48c0-26.5 21.5-48 48-48c14.2 0 27 6.1 35.8 16c8.8 9.9 24 10.7 33.9 1.9s10.7-24 1.9-33.9c-17.5-19.6-43.1-32-71.5-32c-53 0-96 43-96 96s43 96 96 96c28.4 0 54-12.4 71.5-32c8.8-9.9 8-25-1.9-33.9s-25-8-33.9 1.9c-8.8 9.9-21.6 16-35.8 16c-26.5 0-48-21.5-48-48z\"]\n};\nconst faPersonHiking = {\n prefix: 'fas',\n iconName: 'person-hiking',\n icon: [384, 512, [\"hiking\"], \"f6ec\", \"M192 48a48 48 0 1 1 96 0 48 48 0 1 1 -96 0zm51.3 182.7L224.2 307l49.7 49.7c9 9 14.1 21.2 14.1 33.9l0 89.4c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-82.7-73.9-73.9c-15.8-15.8-22.2-38.6-16.9-60.3l20.4-84c8.3-34.1 42.7-54.9 76.7-46.4c19 4.8 35.6 16.4 46.4 32.7L305.1 208l30.9 0 0-24c0-13.3 10.7-24 24-24s24 10.7 24 24l0 55.8c0 .1 0 .2 0 .2s0 .2 0 .2L384 488c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-216-39.4 0c-16 0-31-8-39.9-21.4l-13.3-20zM81.1 471.9L117.3 334c3 4.2 6.4 8.2 10.1 11.9l41.9 41.9L142.9 488.1c-4.5 17.1-22 27.3-39.1 22.8s-27.3-22-22.8-39.1zm55.5-346L101.4 266.5c-3 12.1-14.9 19.9-27.2 17.9l-47.9-8c-14-2.3-22.9-16.3-19.2-30L31.9 155c9.5-34.8 41.1-59 77.2-59l4.2 0c15.6 0 27.1 14.7 23.3 29.8z\"]\n};\nconst faHiking = faPersonHiking;\nconst faVenusDouble = {\n prefix: 'fas',\n iconName: 'venus-double',\n icon: [640, 512, [9890], \"f226\", \"M192 288a112 112 0 1 0 0-224 112 112 0 1 0 0 224zM368 176c0 86.3-62.1 158.1-144 173.1l0 34.9 32 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-32 0 0 32c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-32-32 0c-17.7 0-32-14.3-32-32s14.3-32 32-32l32 0 0-34.9C78.1 334.1 16 262.3 16 176C16 78.8 94.8 0 192 0s176 78.8 176 176zM344 318c14.6-15.6 26.8-33.4 36-53c18.8 14.4 42.4 23 68 23c61.9 0 112-50.1 112-112s-50.1-112-112-112c-25.6 0-49.1 8.6-68 23c-9.3-19.5-21.5-37.4-36-53C373.1 12.6 409.1 0 448 0c97.2 0 176 78.8 176 176c0 86.3-62.1 158.1-144 173.1l0 34.9 32 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-32 0 0 32c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-32-32 0c-17.7 0-32-14.3-32-32s14.3-32 32-32l32 0 0-34.9c-26.6-4.9-51.1-15.7-72-31.1z\"]\n};\nconst faImages = {\n prefix: 'fas',\n iconName: 'images',\n icon: [576, 512, [], \"f302\", \"M160 32c-35.3 0-64 28.7-64 64l0 224c0 35.3 28.7 64 64 64l352 0c35.3 0 64-28.7 64-64l0-224c0-35.3-28.7-64-64-64L160 32zM396 138.7l96 144c4.9 7.4 5.4 16.8 1.2 24.6S480.9 320 472 320l-144 0-48 0-80 0c-9.2 0-17.6-5.3-21.6-13.6s-2.9-18.2 2.9-25.4l64-80c4.6-5.7 11.4-9 18.7-9s14.2 3.3 18.7 9l17.3 21.6 56-84C360.5 132 368 128 376 128s15.5 4 20 10.7zM192 128a32 32 0 1 1 64 0 32 32 0 1 1 -64 0zM48 120c0-13.3-10.7-24-24-24S0 106.7 0 120L0 344c0 75.1 60.9 136 136 136l320 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-320 0c-48.6 0-88-39.4-88-88l0-224z\"]\n};\nconst faCalculator = {\n prefix: 'fas',\n iconName: 'calculator',\n icon: [384, 512, [128425], \"f1ec\", \"M64 0C28.7 0 0 28.7 0 64L0 448c0 35.3 28.7 64 64 64l256 0c35.3 0 64-28.7 64-64l0-384c0-35.3-28.7-64-64-64L64 0zM96 64l192 0c17.7 0 32 14.3 32 32l0 32c0 17.7-14.3 32-32 32L96 160c-17.7 0-32-14.3-32-32l0-32c0-17.7 14.3-32 32-32zm32 160a32 32 0 1 1 -64 0 32 32 0 1 1 64 0zM96 352a32 32 0 1 1 0-64 32 32 0 1 1 0 64zM64 416c0-17.7 14.3-32 32-32l96 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-96 0c-17.7 0-32-14.3-32-32zM192 256a32 32 0 1 1 0-64 32 32 0 1 1 0 64zm32 64a32 32 0 1 1 -64 0 32 32 0 1 1 64 0zm64-64a32 32 0 1 1 0-64 32 32 0 1 1 0 64zm32 64a32 32 0 1 1 -64 0 32 32 0 1 1 64 0zM288 448a32 32 0 1 1 0-64 32 32 0 1 1 0 64z\"]\n};\nconst faPeoplePulling = {\n prefix: 'fas',\n iconName: 'people-pulling',\n icon: [576, 512, [], \"e535\", \"M80 96A48 48 0 1 0 80 0a48 48 0 1 0 0 96zM64 128c-35.3 0-64 28.7-64 64L0 320c0 17.7 14.3 32 32 32c9.8 0 18.5-4.4 24.4-11.2L80.4 485.3c2.9 17.4 19.4 29.2 36.8 26.3s29.2-19.4 26.3-36.8L123.1 352l15.7 0 30 134.9c3.8 17.3 20.9 28.1 38.2 24.3s28.1-20.9 24.3-38.2l-57.3-258 116.3 53.8c.5 .3 1.1 .5 1.6 .7c8.6 3.6 18 3.1 25.9-.7c3.4-1.6 6.6-3.9 9.3-6.7c3.1-3.2 5.5-7 7.1-11.4c.1-.3 .2-.7 .3-1l2.5-7.5c5.7-17.1 18.3-30.9 34.7-38.2l8-3.5c1-.4 1.9-.8 2.9-1.2l-16.9 63.5c-5.6 21.1-.1 43.6 14.7 59.7l70.7 77.1 22 88.1c4.3 17.1 21.7 27.6 38.8 23.3s27.6-21.7 23.3-38.8l-23-92.1c-1.9-7.8-5.8-14.9-11.2-20.8l-49.5-54 19.3-65.5 9.6 23c4.4 10.6 12.5 19.3 22.8 24.5l26.7 13.3c15.8 7.9 35 1.5 42.9-14.3s1.5-35-14.3-42.9L537 232.7l-15.3-36.8C504.5 154.8 464.3 128 419.7 128c-22.8 0-45.3 4.8-66.1 14l-8 3.5c-24.4 10.9-44.6 29-58.1 51.6L157.3 136.9C144.7 131 130.9 128 117 128l-53 0zM464 96a48 48 0 1 0 0-96 48 48 0 1 0 0 96zM349.7 335.6l-25 62.4-59.4 59.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0L372.3 441c4.6-4.6 8.2-10.1 10.6-16.1l14.5-36.2-40.7-44.4c-2.5-2.7-4.8-5.6-7-8.6z\"]\n};\nconst faN = {\n prefix: 'fas',\n iconName: 'n',\n icon: [384, 512, [110], \"4e\", \"M21.1 33.9c12.7-4.6 26.9-.7 35.5 9.6L320 359.6 320 64c0-17.7 14.3-32 32-32s32 14.3 32 32l0 384c0 13.5-8.4 25.5-21.1 30.1s-26.9 .7-35.5-9.6L64 152.4 64 448c0 17.7-14.3 32-32 32s-32-14.3-32-32L0 64C0 50.5 8.4 38.5 21.1 33.9z\"]\n};\nconst faCableCar = {\n prefix: 'fas',\n iconName: 'cable-car',\n icon: [512, 512, [128673, 57551, \"tram\"], \"f7da\", \"M288 0a32 32 0 1 1 0 64 32 32 0 1 1 0-64zM160 56a32 32 0 1 1 64 0 32 32 0 1 1 -64 0zM32 288c0-35.3 28.7-64 64-64l136 0 0-66.5-203.1 42c-13 2.7-25.7-5.7-28.4-18.6s5.7-25.7 18.6-28.4l232-48 232-48c13-2.7 25.7 5.7 28.4 18.6s-5.7 25.7-18.6 28.4L280 147.5l0 76.5 136 0c35.3 0 64 28.7 64 64l0 160c0 35.3-28.7 64-64 64L96 512c-35.3 0-64-28.7-64-64l0-160zm64 0c-8.8 0-16 7.2-16 16l0 64c0 8.8 7.2 16 16 16l64 0c8.8 0 16-7.2 16-16l0-64c0-8.8-7.2-16-16-16l-64 0zm112 16l0 64c0 8.8 7.2 16 16 16l64 0c8.8 0 16-7.2 16-16l0-64c0-8.8-7.2-16-16-16l-64 0c-8.8 0-16 7.2-16 16zm144-16c-8.8 0-16 7.2-16 16l0 64c0 8.8 7.2 16 16 16l64 0c8.8 0 16-7.2 16-16l0-64c0-8.8-7.2-16-16-16l-64 0z\"]\n};\nconst faTram = faCableCar;\nconst faCloudRain = {\n prefix: 'fas',\n iconName: 'cloud-rain',\n icon: [512, 512, [127783, 9926], \"f73d\", \"M96 320c-53 0-96-43-96-96c0-42.5 27.6-78.6 65.9-91.2C64.7 126.1 64 119.1 64 112C64 50.1 114.1 0 176 0c43.1 0 80.5 24.3 99.2 60c14.7-17.1 36.5-28 60.8-28c44.2 0 80 35.8 80 80c0 5.5-.6 10.8-1.6 16c.5 0 1.1 0 1.6 0c53 0 96 43 96 96s-43 96-96 96L96 320zm-6.8 52c1.3-2.5 3.9-4 6.8-4s5.4 1.5 6.8 4l35.1 64.6c4.1 7.5 6.2 15.8 6.2 24.3l0 3c0 26.5-21.5 48-48 48s-48-21.5-48-48l0-3c0-8.5 2.1-16.9 6.2-24.3L89.2 372zm160 0c1.3-2.5 3.9-4 6.8-4s5.4 1.5 6.8 4l35.1 64.6c4.1 7.5 6.2 15.8 6.2 24.3l0 3c0 26.5-21.5 48-48 48s-48-21.5-48-48l0-3c0-8.5 2.1-16.9 6.2-24.3L249.2 372zm124.9 64.6L409.2 372c1.3-2.5 3.9-4 6.8-4s5.4 1.5 6.8 4l35.1 64.6c4.1 7.5 6.2 15.8 6.2 24.3l0 3c0 26.5-21.5 48-48 48s-48-21.5-48-48l0-3c0-8.5 2.1-16.9 6.2-24.3z\"]\n};\nconst faBuildingCircleXmark = {\n prefix: 'fas',\n iconName: 'building-circle-xmark',\n icon: [640, 512, [], \"e4d4\", \"M48 0C21.5 0 0 21.5 0 48L0 464c0 26.5 21.5 48 48 48l96 0 0-80c0-26.5 21.5-48 48-48s48 21.5 48 48l0 80 96 0c15.1 0 28.5-6.9 37.3-17.8C340.4 462.2 320 417.5 320 368c0-54.7 24.9-103.5 64-135.8L384 48c0-26.5-21.5-48-48-48L48 0zM64 240c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32zm112-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16zm80 16c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32zM80 96l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16zm80 16c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32zM272 96l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16zM496 512a144 144 0 1 0 0-288 144 144 0 1 0 0 288zm59.3-180.7L518.6 368l36.7 36.7c6.2 6.2 6.2 16.4 0 22.6s-16.4 6.2-22.6 0L496 390.6l-36.7 36.7c-6.2 6.2-16.4 6.2-22.6 0s-6.2-16.4 0-22.6L473.4 368l-36.7-36.7c-6.2-6.2-6.2-16.4 0-22.6s16.4-6.2 22.6 0L496 345.4l36.7-36.7c6.2-6.2 16.4-6.2 22.6 0s6.2 16.4 0 22.6z\"]\n};\nconst faShip = {\n prefix: 'fas',\n iconName: 'ship',\n icon: [576, 512, [128674], \"f21a\", \"M192 32c0-17.7 14.3-32 32-32L352 0c17.7 0 32 14.3 32 32l0 32 48 0c26.5 0 48 21.5 48 48l0 128 44.4 14.8c23.1 7.7 29.5 37.5 11.5 53.9l-101 92.6c-16.2 9.4-34.7 15.1-50.9 15.1c-19.6 0-40.8-7.7-59.2-20.3c-22.1-15.5-51.6-15.5-73.7 0c-17.1 11.8-38 20.3-59.2 20.3c-16.2 0-34.7-5.7-50.9-15.1l-101-92.6c-18-16.5-11.6-46.2 11.5-53.9L96 240l0-128c0-26.5 21.5-48 48-48l48 0 0-32zM160 218.7l107.8-35.9c13.1-4.4 27.3-4.4 40.5 0L416 218.7l0-90.7-256 0 0 90.7zM306.5 421.9C329 437.4 356.5 448 384 448c26.9 0 55.4-10.8 77.4-26.1c0 0 0 0 0 0c11.9-8.5 28.1-7.8 39.2 1.7c14.4 11.9 32.5 21 50.6 25.2c17.2 4 27.9 21.2 23.9 38.4s-21.2 27.9-38.4 23.9c-24.5-5.7-44.9-16.5-58.2-25C449.5 501.7 417 512 384 512c-31.9 0-60.6-9.9-80.4-18.9c-5.8-2.7-11.1-5.3-15.6-7.7c-4.5 2.4-9.7 5.1-15.6 7.7c-19.8 9-48.5 18.9-80.4 18.9c-33 0-65.5-10.3-94.5-25.8c-13.4 8.4-33.7 19.3-58.2 25c-17.2 4-34.4-6.7-38.4-23.9s6.7-34.4 23.9-38.4c18.1-4.2 36.2-13.3 50.6-25.2c11.1-9.4 27.3-10.1 39.2-1.7c0 0 0 0 0 0C136.7 437.2 165.1 448 192 448c27.5 0 55-10.6 77.5-26.1c11.1-7.9 25.9-7.9 37 0z\"]\n};\nconst faArrowsDownToLine = {\n prefix: 'fas',\n iconName: 'arrows-down-to-line',\n icon: [576, 512, [], \"e4b8\", \"M544 416L32 416c-17.7 0-32 14.3-32 32s14.3 32 32 32l512 0c17.7 0 32-14.3 32-32s-14.3-32-32-32zm22.6-137.4c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0L480 274.7 480 64c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 210.7-41.4-41.4c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3l96 96c12.5 12.5 32.8 12.5 45.3 0l96-96zm-320-45.3c-12.5-12.5-32.8-12.5-45.3 0L160 274.7 160 64c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 210.7L54.6 233.4c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3l96 96c12.5 12.5 32.8 12.5 45.3 0l96-96c12.5-12.5 12.5-32.8 0-45.3z\"]\n};\nconst faDownload = {\n prefix: 'fas',\n iconName: 'download',\n icon: [512, 512, [], \"f019\", \"M288 32c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 242.7-73.4-73.4c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3l128 128c12.5 12.5 32.8 12.5 45.3 0l128-128c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0L288 274.7 288 32zM64 352c-35.3 0-64 28.7-64 64l0 32c0 35.3 28.7 64 64 64l384 0c35.3 0 64-28.7 64-64l0-32c0-35.3-28.7-64-64-64l-101.5 0-45.3 45.3c-25 25-65.5 25-90.5 0L165.5 352 64 352zm368 56a24 24 0 1 1 0 48 24 24 0 1 1 0-48z\"]\n};\nconst faFaceGrin = {\n prefix: 'fas',\n iconName: 'face-grin',\n icon: [512, 512, [128512, \"grin\"], \"f580\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM388.1 312.8c12.3-3.8 24.3 6.9 19.3 18.7C382.4 390.6 324.2 432 256.3 432s-126.2-41.4-151.1-100.5c-5-11.8 7-22.5 19.3-18.7c39.7 12.2 84.5 19 131.8 19s92.1-6.8 131.8-19zM144.4 208a32 32 0 1 1 64 0 32 32 0 1 1 -64 0zm192-32a32 32 0 1 1 0 64 32 32 0 1 1 0-64z\"]\n};\nconst faGrin = faFaceGrin;\nconst faDeleteLeft = {\n prefix: 'fas',\n iconName: 'delete-left',\n icon: [576, 512, [9003, \"backspace\"], \"f55a\", \"M576 128c0-35.3-28.7-64-64-64L205.3 64c-17 0-33.3 6.7-45.3 18.7L9.4 233.4c-6 6-9.4 14.1-9.4 22.6s3.4 16.6 9.4 22.6L160 429.3c12 12 28.3 18.7 45.3 18.7L512 448c35.3 0 64-28.7 64-64l0-256zM271 175c9.4-9.4 24.6-9.4 33.9 0l47 47 47-47c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9l-47 47 47 47c9.4 9.4 9.4 24.6 0 33.9s-24.6 9.4-33.9 0l-47-47-47 47c-9.4 9.4-24.6 9.4-33.9 0s-9.4-24.6 0-33.9l47-47-47-47c-9.4-9.4-9.4-24.6 0-33.9z\"]\n};\nconst faBackspace = faDeleteLeft;\nconst faEyeDropper = {\n prefix: 'fas',\n iconName: 'eye-dropper',\n icon: [512, 512, [\"eye-dropper-empty\", \"eyedropper\"], \"f1fb\", \"M341.6 29.2L240.1 130.8l-9.4-9.4c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3l160 160c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3l-9.4-9.4L482.8 170.4c39-39 39-102.2 0-141.1s-102.2-39-141.1 0zM55.4 323.3c-15 15-23.4 35.4-23.4 56.6l0 42.4L5.4 462.2c-8.5 12.7-6.8 29.6 4 40.4s27.7 12.5 40.4 4L89.7 480l42.4 0c21.2 0 41.6-8.4 56.6-23.4L309.4 335.9l-45.3-45.3L143.4 411.3c-3 3-7.1 4.7-11.3 4.7L96 416l0-36.1c0-4.2 1.7-8.3 4.7-11.3L221.4 247.9l-45.3-45.3L55.4 323.3z\"]\n};\nconst faEyeDropperEmpty = faEyeDropper;\nconst faEyedropper = faEyeDropper;\nconst faFileCircleCheck = {\n prefix: 'fas',\n iconName: 'file-circle-check',\n icon: [576, 512, [], \"e5a0\", \"M0 64C0 28.7 28.7 0 64 0L224 0l0 128c0 17.7 14.3 32 32 32l128 0 0 38.6C310.1 219.5 256 287.4 256 368c0 59.1 29.1 111.3 73.7 143.3c-3.2 .5-6.4 .7-9.7 .7L64 512c-35.3 0-64-28.7-64-64L0 64zm384 64l-128 0L256 0 384 128zM288 368a144 144 0 1 1 288 0 144 144 0 1 1 -288 0zm211.3-43.3c-6.2-6.2-16.4-6.2-22.6 0L416 385.4l-28.7-28.7c-6.2-6.2-16.4-6.2-22.6 0s-6.2 16.4 0 22.6l40 40c6.2 6.2 16.4 6.2 22.6 0l72-72c6.2-6.2 6.2-16.4 0-22.6z\"]\n};\nconst faForward = {\n prefix: 'fas',\n iconName: 'forward',\n icon: [512, 512, [9193], \"f04e\", \"M52.5 440.6c-9.5 7.9-22.8 9.7-34.1 4.4S0 428.4 0 416L0 96C0 83.6 7.2 72.3 18.4 67s24.5-3.6 34.1 4.4L224 214.3l0 41.7 0 41.7L52.5 440.6zM256 352l0-96 0-128 0-32c0-12.4 7.2-23.7 18.4-29s24.5-3.6 34.1 4.4l192 160c7.3 6.1 11.5 15.1 11.5 24.6s-4.2 18.5-11.5 24.6l-192 160c-9.5 7.9-22.8 9.7-34.1 4.4s-18.4-16.6-18.4-29l0-64z\"]\n};\nconst faMobile = {\n prefix: 'fas',\n iconName: 'mobile',\n icon: [384, 512, [128241, \"mobile-android\", \"mobile-phone\"], \"f3ce\", \"M80 0C44.7 0 16 28.7 16 64l0 384c0 35.3 28.7 64 64 64l224 0c35.3 0 64-28.7 64-64l0-384c0-35.3-28.7-64-64-64L80 0zm80 432l64 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-64 0c-8.8 0-16-7.2-16-16s7.2-16 16-16z\"]\n};\nconst faMobileAndroid = faMobile;\nconst faMobilePhone = faMobile;\nconst faFaceMeh = {\n prefix: 'fas',\n iconName: 'face-meh',\n icon: [512, 512, [128528, \"meh\"], \"f11a\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM176.4 176a32 32 0 1 1 0 64 32 32 0 1 1 0-64zm128 32a32 32 0 1 1 64 0 32 32 0 1 1 -64 0zM160 336l192 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-192 0c-8.8 0-16-7.2-16-16s7.2-16 16-16z\"]\n};\nconst faMeh = faFaceMeh;\nconst faAlignCenter = {\n prefix: 'fas',\n iconName: 'align-center',\n icon: [448, 512, [], \"f037\", \"M352 64c0-17.7-14.3-32-32-32L128 32c-17.7 0-32 14.3-32 32s14.3 32 32 32l192 0c17.7 0 32-14.3 32-32zm96 128c0-17.7-14.3-32-32-32L32 160c-17.7 0-32 14.3-32 32s14.3 32 32 32l384 0c17.7 0 32-14.3 32-32zM0 448c0 17.7 14.3 32 32 32l384 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L32 416c-17.7 0-32 14.3-32 32zM352 320c0-17.7-14.3-32-32-32l-192 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l192 0c17.7 0 32-14.3 32-32z\"]\n};\nconst faBookSkull = {\n prefix: 'fas',\n iconName: 'book-skull',\n icon: [448, 512, [\"book-dead\"], \"f6b7\", \"M0 96C0 43 43 0 96 0L384 0l32 0c17.7 0 32 14.3 32 32l0 320c0 17.7-14.3 32-32 32l0 64c17.7 0 32 14.3 32 32s-14.3 32-32 32l-32 0L96 512c-53 0-96-43-96-96L0 96zM64 416c0 17.7 14.3 32 32 32l256 0 0-64L96 384c-17.7 0-32 14.3-32 32zM320 112c0-35.3-35.8-64-80-64s-80 28.7-80 64c0 20.9 12.6 39.5 32 51.2l0 12.8c0 8.8 7.2 16 16 16l64 0c8.8 0 16-7.2 16-16l0-12.8c19.4-11.7 32-30.3 32-51.2zM208 96a16 16 0 1 1 0 32 16 16 0 1 1 0-32zm48 16a16 16 0 1 1 32 0 16 16 0 1 1 -32 0zM134.3 209.3c-8.1-3.5-17.5 .3-21 8.4s.3 17.5 8.4 21L199.4 272l-77.7 33.3c-8.1 3.5-11.9 12.9-8.4 21s12.9 11.9 21 8.4L240 289.4l105.7 45.3c8.1 3.5 17.5-.3 21-8.4s-.3-17.5-8.4-21L280.6 272l77.7-33.3c8.1-3.5 11.9-12.9 8.4-21s-12.9-11.9-21-8.4L240 254.6 134.3 209.3z\"]\n};\nconst faBookDead = faBookSkull;\nconst faIdCard = {\n prefix: 'fas',\n iconName: 'id-card',\n icon: [576, 512, [62147, \"drivers-license\"], \"f2c2\", \"M0 96l576 0c0-35.3-28.7-64-64-64L64 32C28.7 32 0 60.7 0 96zm0 32L0 416c0 35.3 28.7 64 64 64l448 0c35.3 0 64-28.7 64-64l0-288L0 128zM64 405.3c0-29.5 23.9-53.3 53.3-53.3l117.3 0c29.5 0 53.3 23.9 53.3 53.3c0 5.9-4.8 10.7-10.7 10.7L74.7 416c-5.9 0-10.7-4.8-10.7-10.7zM176 192a64 64 0 1 1 0 128 64 64 0 1 1 0-128zm176 16c0-8.8 7.2-16 16-16l128 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-128 0c-8.8 0-16-7.2-16-16zm0 64c0-8.8 7.2-16 16-16l128 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-128 0c-8.8 0-16-7.2-16-16zm0 64c0-8.8 7.2-16 16-16l128 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-128 0c-8.8 0-16-7.2-16-16z\"]\n};\nconst faDriversLicense = faIdCard;\nconst faOutdent = {\n prefix: 'fas',\n iconName: 'outdent',\n icon: [448, 512, [\"dedent\"], \"f03b\", \"M0 64C0 46.3 14.3 32 32 32l384 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L32 96C14.3 96 0 81.7 0 64zM192 192c0-17.7 14.3-32 32-32l192 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-192 0c-17.7 0-32-14.3-32-32zm32 96l192 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-192 0c-17.7 0-32-14.3-32-32s14.3-32 32-32zM0 448c0-17.7 14.3-32 32-32l384 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L32 480c-17.7 0-32-14.3-32-32zM.2 268.6c-8.2-6.4-8.2-18.9 0-25.3l101.9-79.3c10.5-8.2 25.8-.7 25.8 12.6l0 158.6c0 13.3-15.3 20.8-25.8 12.6L.2 268.6z\"]\n};\nconst faDedent = faOutdent;\nconst faHeartCircleExclamation = {\n prefix: 'fas',\n iconName: 'heart-circle-exclamation',\n icon: [576, 512, [], \"e4fe\", \"M47.6 300.4L228.3 469.1c7.5 7 17.4 10.9 27.7 10.9s20.2-3.9 27.7-10.9l2.6-2.4C267.2 438.6 256 404.6 256 368c0-97.2 78.8-176 176-176c28.3 0 55 6.7 78.7 18.5c.9-6.5 1.3-13 1.3-19.6l0-5.8c0-69.9-50.5-129.5-119.4-141C347 36.5 300.6 51.4 268 84L256 96 244 84c-32.6-32.6-79-47.5-124.6-39.9C50.5 55.6 0 115.2 0 185.1l0 5.8c0 41.5 17.2 81.2 47.6 109.5zM432 512a144 144 0 1 0 0-288 144 144 0 1 0 0 288zm0-96a24 24 0 1 1 0 48 24 24 0 1 1 0-48zm0-144c8.8 0 16 7.2 16 16l0 80c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-80c0-8.8 7.2-16 16-16z\"]\n};\nconst faHouse = {\n prefix: 'fas',\n iconName: 'house',\n icon: [576, 512, [127968, 63498, 63500, \"home\", \"home-alt\", \"home-lg-alt\"], \"f015\", \"M575.8 255.5c0 18-15 32.1-32 32.1l-32 0 .7 160.2c0 2.7-.2 5.4-.5 8.1l0 16.2c0 22.1-17.9 40-40 40l-16 0c-1.1 0-2.2 0-3.3-.1c-1.4 .1-2.8 .1-4.2 .1L416 512l-24 0c-22.1 0-40-17.9-40-40l0-24 0-64c0-17.7-14.3-32-32-32l-64 0c-17.7 0-32 14.3-32 32l0 64 0 24c0 22.1-17.9 40-40 40l-24 0-31.9 0c-1.5 0-3-.1-4.5-.2c-1.2 .1-2.4 .2-3.6 .2l-16 0c-22.1 0-40-17.9-40-40l0-112c0-.9 0-1.9 .1-2.8l0-69.7-32 0c-18 0-32-14-32-32.1c0-9 3-17 10-24L266.4 8c7-7 15-8 22-8s15 2 21 7L564.8 231.5c8 7 12 15 11 24z\"]\n};\nconst faHome = faHouse;\nconst faHomeAlt = faHouse;\nconst faHomeLgAlt = faHouse;\nconst faCalendarWeek = {\n prefix: 'fas',\n iconName: 'calendar-week',\n icon: [448, 512, [], \"f784\", \"M128 0c17.7 0 32 14.3 32 32l0 32 128 0 0-32c0-17.7 14.3-32 32-32s32 14.3 32 32l0 32 48 0c26.5 0 48 21.5 48 48l0 48L0 160l0-48C0 85.5 21.5 64 48 64l48 0 0-32c0-17.7 14.3-32 32-32zM0 192l448 0 0 272c0 26.5-21.5 48-48 48L48 512c-26.5 0-48-21.5-48-48L0 192zm80 64c-8.8 0-16 7.2-16 16l0 64c0 8.8 7.2 16 16 16l288 0c8.8 0 16-7.2 16-16l0-64c0-8.8-7.2-16-16-16L80 256z\"]\n};\nconst faLaptopMedical = {\n prefix: 'fas',\n iconName: 'laptop-medical',\n icon: [640, 512, [], \"f812\", \"M64 96c0-35.3 28.7-64 64-64l384 0c35.3 0 64 28.7 64 64l0 256-64 0 0-256L128 96l0 256-64 0L64 96zM0 403.2C0 392.6 8.6 384 19.2 384l601.6 0c10.6 0 19.2 8.6 19.2 19.2c0 42.4-34.4 76.8-76.8 76.8L76.8 480C34.4 480 0 445.6 0 403.2zM288 160c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 48 48 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-48 0 0 48c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-48-48 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16l48 0 0-48z\"]\n};\nconst faB = {\n prefix: 'fas',\n iconName: 'b',\n icon: [320, 512, [98], \"42\", \"M64 32C28.7 32 0 60.7 0 96L0 256 0 416c0 35.3 28.7 64 64 64l128 0c70.7 0 128-57.3 128-128c0-46.5-24.8-87.3-62-109.7c18.7-22.3 30-51 30-82.3c0-70.7-57.3-128-128-128L64 32zm96 192l-96 0L64 96l96 0c35.3 0 64 28.7 64 64s-28.7 64-64 64zM64 288l96 0 32 0c35.3 0 64 28.7 64 64s-28.7 64-64 64L64 416l0-128z\"]\n};\nconst faFileMedical = {\n prefix: 'fas',\n iconName: 'file-medical',\n icon: [384, 512, [], \"f477\", \"M64 0C28.7 0 0 28.7 0 64L0 448c0 35.3 28.7 64 64 64l256 0c35.3 0 64-28.7 64-64l0-288-128 0c-17.7 0-32-14.3-32-32L224 0 64 0zM256 0l0 128 128 0L256 0zM160 240c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 48 48 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-48 0 0 48c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-48-48 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16l48 0 0-48z\"]\n};\nconst faDiceOne = {\n prefix: 'fas',\n iconName: 'dice-one',\n icon: [448, 512, [9856], \"f525\", \"M64 32C28.7 32 0 60.7 0 96L0 416c0 35.3 28.7 64 64 64l320 0c35.3 0 64-28.7 64-64l0-320c0-35.3-28.7-64-64-64L64 32zM224 224a32 32 0 1 1 0 64 32 32 0 1 1 0-64z\"]\n};\nconst faKiwiBird = {\n prefix: 'fas',\n iconName: 'kiwi-bird',\n icon: [576, 512, [], \"f535\", \"M291.2 388.4c31.2-18.8 64.7-36.4 101.1-36.4l55.7 0c4.6 0 9.1-.2 13.6-.7l85.3 121.9c4 5.7 11.3 8.2 17.9 6.1s11.2-8.3 11.2-15.3l0-240c0-70.7-57.3-128-128-128l-55.7 0c-36.4 0-69.9-17.6-101.1-36.4C262.3 42.1 228.3 32 192 32C86 32 0 118 0 224c0 71.1 38.6 133.1 96 166.3L96 456c0 13.3 10.7 24 24 24s24-10.7 24-24l0-46c15.3 3.9 31.4 6 48 6c5.4 0 10.7-.2 16-.7l0 40.7c0 13.3 10.7 24 24 24s24-10.7 24-24l0-50.9c12.4-4.4 24.2-10 35.2-16.7zM448 200a24 24 0 1 1 0 48 24 24 0 1 1 0-48z\"]\n};\nconst faArrowRightArrowLeft = {\n prefix: 'fas',\n iconName: 'arrow-right-arrow-left',\n icon: [448, 512, [8644, \"exchange\"], \"f0ec\", \"M438.6 150.6c12.5-12.5 12.5-32.8 0-45.3l-96-96c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3L338.7 96 32 96C14.3 96 0 110.3 0 128s14.3 32 32 32l306.7 0-41.4 41.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0l96-96zm-333.3 352c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3L109.3 416 416 416c17.7 0 32-14.3 32-32s-14.3-32-32-32l-306.7 0 41.4-41.4c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0l-96 96c-12.5 12.5-12.5 32.8 0 45.3l96 96z\"]\n};\nconst faExchange = faArrowRightArrowLeft;\nconst faRotateRight = {\n prefix: 'fas',\n iconName: 'rotate-right',\n icon: [512, 512, [\"redo-alt\", \"rotate-forward\"], \"f2f9\", \"M463.5 224l8.5 0c13.3 0 24-10.7 24-24l0-128c0-9.7-5.8-18.5-14.8-22.2s-19.3-1.7-26.2 5.2L413.4 96.6c-87.6-86.5-228.7-86.2-315.8 1c-87.5 87.5-87.5 229.3 0 316.8s229.3 87.5 316.8 0c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0c-62.5 62.5-163.8 62.5-226.3 0s-62.5-163.8 0-226.3c62.2-62.2 162.7-62.5 225.3-1L327 183c-6.9 6.9-8.9 17.2-5.2 26.2s12.5 14.8 22.2 14.8l119.5 0z\"]\n};\nconst faRedoAlt = faRotateRight;\nconst faRotateForward = faRotateRight;\nconst faUtensils = {\n prefix: 'fas',\n iconName: 'utensils',\n icon: [448, 512, [127860, 61685, \"cutlery\"], \"f2e7\", \"M416 0C400 0 288 32 288 176l0 112c0 35.3 28.7 64 64 64l32 0 0 128c0 17.7 14.3 32 32 32s32-14.3 32-32l0-128 0-112 0-208c0-17.7-14.3-32-32-32zM64 16C64 7.8 57.9 1 49.7 .1S34.2 4.6 32.4 12.5L2.1 148.8C.7 155.1 0 161.5 0 167.9c0 45.9 35.1 83.6 80 87.7L80 480c0 17.7 14.3 32 32 32s32-14.3 32-32l0-224.4c44.9-4.1 80-41.8 80-87.7c0-6.4-.7-12.8-2.1-19.1L191.6 12.5c-1.8-8-9.3-13.3-17.4-12.4S160 7.8 160 16l0 134.2c0 5.4-4.4 9.8-9.8 9.8c-5.1 0-9.3-3.9-9.8-9L127.9 14.6C127.2 6.3 120.3 0 112 0s-15.2 6.3-15.9 14.6L83.7 151c-.5 5.1-4.7 9-9.8 9c-5.4 0-9.8-4.4-9.8-9.8L64 16zm48.3 152l-.3 0-.3 0 .3-.7 .3 .7z\"]\n};\nconst faCutlery = faUtensils;\nconst faArrowUpWideShort = {\n prefix: 'fas',\n iconName: 'arrow-up-wide-short',\n icon: [576, 512, [\"sort-amount-up\"], \"f161\", \"M151.6 42.4C145.5 35.8 137 32 128 32s-17.5 3.8-23.6 10.4l-88 96c-11.9 13-11.1 33.3 2 45.2s33.3 11.1 45.2-2L96 146.3 96 448c0 17.7 14.3 32 32 32s32-14.3 32-32l0-301.7 32.4 35.4c11.9 13 32.2 13.9 45.2 2s13.9-32.2 2-45.2l-88-96zM320 480l32 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-32 0c-17.7 0-32 14.3-32 32s14.3 32 32 32zm0-128l96 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-96 0c-17.7 0-32 14.3-32 32s14.3 32 32 32zm0-128l160 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-160 0c-17.7 0-32 14.3-32 32s14.3 32 32 32zm0-128l224 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L320 32c-17.7 0-32 14.3-32 32s14.3 32 32 32z\"]\n};\nconst faSortAmountUp = faArrowUpWideShort;\nconst faMillSign = {\n prefix: 'fas',\n iconName: 'mill-sign',\n icon: [384, 512, [], \"e1ed\", \"M302.1 42.8c5.9-16.6-2.7-35-19.4-40.9s-35 2.7-40.9 19.4L208 116.1c-5.7 4-11.1 8.5-16 13.5C171.7 108.9 143.3 96 112 96c-19.5 0-37.8 5-53.7 13.7C52.5 101.4 42.9 96 32 96C14.3 96 0 110.3 0 128l0 80L0 416c0 17.7 14.3 32 32 32s32-14.3 32-32l0-208c0-26.5 21.5-48 48-48s48 21.5 48 48l0 42.5L81.9 469.2c-5.9 16.6 2.7 35 19.4 40.9s35-2.7 40.9-19.4l21.4-60C168.9 441 179.6 448 192 448c17.7 0 32-14.3 32-32l0-154.5 35.7-100c3.9-1 8.1-1.6 12.3-1.6c26.5 0 48 21.5 48 48l0 208c0 17.7 14.3 32 32 32s32-14.3 32-32l0-208c0-58.2-44.3-106-101.1-111.5l19.2-53.8z\"]\n};\nconst faBowlRice = {\n prefix: 'fas',\n iconName: 'bowl-rice',\n icon: [512, 512, [], \"e2eb\", \"M176 56c0-13.3 10.7-24 24-24l16 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-16 0c-13.3 0-24-10.7-24-24zm24 48l16 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-16 0c-13.3 0-24-10.7-24-24s10.7-24 24-24zM56 176l16 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-16 0c-13.3 0-24-10.7-24-24s10.7-24 24-24zM0 283.4C0 268.3 12.3 256 27.4 256l457.1 0c15.1 0 27.4 12.3 27.4 27.4c0 70.5-44.4 130.7-106.7 154.1L403.5 452c-2 16-15.6 28-31.8 28l-231.5 0c-16.1 0-29.8-12-31.8-28l-1.8-14.4C44.4 414.1 0 353.9 0 283.4zM224 200c0-13.3 10.7-24 24-24l16 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-16 0c-13.3 0-24-10.7-24-24zm-96 0c0-13.3 10.7-24 24-24l16 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-16 0c-13.3 0-24-10.7-24-24zm-24-96l16 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-16 0c-13.3 0-24-10.7-24-24s10.7-24 24-24zm216 96c0-13.3 10.7-24 24-24l16 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-16 0c-13.3 0-24-10.7-24-24zm-24-96l16 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-16 0c-13.3 0-24-10.7-24-24s10.7-24 24-24zm120 96c0-13.3 10.7-24 24-24l16 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-16 0c-13.3 0-24-10.7-24-24zm-24-96l16 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-16 0c-13.3 0-24-10.7-24-24s10.7-24 24-24zM296 32l16 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-16 0c-13.3 0-24-10.7-24-24s10.7-24 24-24z\"]\n};\nconst faSkull = {\n prefix: 'fas',\n iconName: 'skull',\n icon: [512, 512, [128128], \"f54c\", \"M416 398.9c58.5-41.1 96-104.1 96-174.9C512 100.3 397.4 0 256 0S0 100.3 0 224c0 70.7 37.5 133.8 96 174.9c0 .4 0 .7 0 1.1l0 64c0 26.5 21.5 48 48 48l48 0 0-48c0-8.8 7.2-16 16-16s16 7.2 16 16l0 48 64 0 0-48c0-8.8 7.2-16 16-16s16 7.2 16 16l0 48 48 0c26.5 0 48-21.5 48-48l0-64c0-.4 0-.7 0-1.1zM96 256a64 64 0 1 1 128 0A64 64 0 1 1 96 256zm256-64a64 64 0 1 1 0 128 64 64 0 1 1 0-128z\"]\n};\nconst faTowerBroadcast = {\n prefix: 'fas',\n iconName: 'tower-broadcast',\n icon: [576, 512, [\"broadcast-tower\"], \"f519\", \"M80.3 44C69.8 69.9 64 98.2 64 128s5.8 58.1 16.3 84c6.6 16.4-1.3 35-17.7 41.7s-35-1.3-41.7-17.7C7.4 202.6 0 166.1 0 128S7.4 53.4 20.9 20C27.6 3.6 46.2-4.3 62.6 2.3S86.9 27.6 80.3 44zM555.1 20C568.6 53.4 576 89.9 576 128s-7.4 74.6-20.9 108c-6.6 16.4-25.3 24.3-41.7 17.7S489.1 228.4 495.7 212c10.5-25.9 16.3-54.2 16.3-84s-5.8-58.1-16.3-84C489.1 27.6 497 9 513.4 2.3s35 1.3 41.7 17.7zM352 128c0 23.7-12.9 44.4-32 55.4L320 480c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-296.6c-19.1-11.1-32-31.7-32-55.4c0-35.3 28.7-64 64-64s64 28.7 64 64zM170.6 76.8C163.8 92.4 160 109.7 160 128s3.8 35.6 10.6 51.2c7.1 16.2-.3 35.1-16.5 42.1s-35.1-.3-42.1-16.5c-10.3-23.6-16-49.6-16-76.8s5.7-53.2 16-76.8c7.1-16.2 25.9-23.6 42.1-16.5s23.6 25.9 16.5 42.1zM464 51.2c10.3 23.6 16 49.6 16 76.8s-5.7 53.2-16 76.8c-7.1 16.2-25.9 23.6-42.1 16.5s-23.6-25.9-16.5-42.1c6.8-15.6 10.6-32.9 10.6-51.2s-3.8-35.6-10.6-51.2c-7.1-16.2 .3-35.1 16.5-42.1s35.1 .3 42.1 16.5z\"]\n};\nconst faBroadcastTower = faTowerBroadcast;\nconst faTruckPickup = {\n prefix: 'fas',\n iconName: 'truck-pickup',\n icon: [640, 512, [128763], \"f63c\", \"M368.6 96l76.8 96L288 192l0-96 80.6 0zM224 80l0 112L64 192c-17.7 0-32 14.3-32 32l0 64c-17.7 0-32 14.3-32 32s14.3 32 32 32l33.1 0c-.7 5.2-1.1 10.6-1.1 16c0 61.9 50.1 112 112 112s112-50.1 112-112c0-5.4-.4-10.8-1.1-16l66.3 0c-.7 5.2-1.1 10.6-1.1 16c0 61.9 50.1 112 112 112s112-50.1 112-112c0-5.4-.4-10.8-1.1-16l33.1 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l0-64c0-17.7-14.3-32-32-32l-48.6 0L418.6 56c-12.1-15.2-30.5-24-50-24L272 32c-26.5 0-48 21.5-48 48zm0 288a48 48 0 1 1 -96 0 48 48 0 1 1 96 0zm288 0a48 48 0 1 1 -96 0 48 48 0 1 1 96 0z\"]\n};\nconst faUpLong = {\n prefix: 'fas',\n iconName: 'up-long',\n icon: [320, 512, [\"long-arrow-alt-up\"], \"f30c\", \"M318 177.5c3.8-8.8 2-19-4.6-26l-136-144C172.9 2.7 166.6 0 160 0s-12.9 2.7-17.4 7.5l-136 144c-6.6 7-8.4 17.2-4.6 26S14.4 192 24 192l72 0 0 288c0 17.7 14.3 32 32 32l64 0c17.7 0 32-14.3 32-32l0-288 72 0c9.6 0 18.2-5.7 22-14.5z\"]\n};\nconst faLongArrowAltUp = faUpLong;\nconst faStop = {\n prefix: 'fas',\n iconName: 'stop',\n icon: [384, 512, [9209], \"f04d\", \"M0 128C0 92.7 28.7 64 64 64H320c35.3 0 64 28.7 64 64V384c0 35.3-28.7 64-64 64H64c-35.3 0-64-28.7-64-64V128z\"]\n};\nconst faCodeMerge = {\n prefix: 'fas',\n iconName: 'code-merge',\n icon: [448, 512, [], \"f387\", \"M80 56a24 24 0 1 1 0 48 24 24 0 1 1 0-48zm32.4 97.2c28-12.4 47.6-40.5 47.6-73.2c0-44.2-35.8-80-80-80S0 35.8 0 80c0 32.8 19.7 61 48 73.3l0 205.3C19.7 371 0 399.2 0 432c0 44.2 35.8 80 80 80s80-35.8 80-80c0-32.8-19.7-61-48-73.3l0-86.6c26.7 20.1 60 32 96 32l86.7 0c12.3 28.3 40.5 48 73.3 48c44.2 0 80-35.8 80-80s-35.8-80-80-80c-32.8 0-61 19.7-73.3 48L208 240c-49.9 0-91-38.1-95.6-86.8zM80 408a24 24 0 1 1 0 48 24 24 0 1 1 0-48zM344 272a24 24 0 1 1 48 0 24 24 0 1 1 -48 0z\"]\n};\nconst faUpload = {\n prefix: 'fas',\n iconName: 'upload',\n icon: [512, 512, [], \"f093\", \"M288 109.3L288 352c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-242.7-73.4 73.4c-12.5 12.5-32.8 12.5-45.3 0s-12.5-32.8 0-45.3l128-128c12.5-12.5 32.8-12.5 45.3 0l128 128c12.5 12.5 12.5 32.8 0 45.3s-32.8 12.5-45.3 0L288 109.3zM64 352l128 0c0 35.3 28.7 64 64 64s64-28.7 64-64l128 0c35.3 0 64 28.7 64 64l0 32c0 35.3-28.7 64-64 64L64 512c-35.3 0-64-28.7-64-64l0-32c0-35.3 28.7-64 64-64zM432 456a24 24 0 1 0 0-48 24 24 0 1 0 0 48z\"]\n};\nconst faHurricane = {\n prefix: 'fas',\n iconName: 'hurricane',\n icon: [384, 512, [], \"f751\", \"M0 208C0 104.4 75.7 18.5 174.9 2.6C184 1.2 192 8.6 192 17.9l0 63.3c0 8.4 6.5 15.3 14.7 16.5C307 112.5 384 199 384 303.4c0 103.6-75.7 189.5-174.9 205.4c-9.2 1.5-17.1-5.9-17.1-15.2l0-63.3c0-8.4-6.5-15.3-14.7-16.5C77 398.9 0 312.4 0 208zm288 48A96 96 0 1 0 96 256a96 96 0 1 0 192 0zm-96-32a32 32 0 1 1 0 64 32 32 0 1 1 0-64z\"]\n};\nconst faMound = {\n prefix: 'fas',\n iconName: 'mound',\n icon: [576, 512, [], \"e52d\", \"M144.1 179.2C173.8 127.7 228.6 96 288 96s114.2 31.7 143.9 83.2L540.4 368c12.3 21.3-3.1 48-27.7 48H63.3c-24.6 0-40-26.6-27.7-48L144.1 179.2z\"]\n};\nconst faToiletPortable = {\n prefix: 'fas',\n iconName: 'toilet-portable',\n icon: [320, 512, [], \"e583\", \"M0 32L0 64l320 0 0-32c0-17.7-14.3-32-32-32L32 0C14.3 0 0 14.3 0 32zM24 96L0 96l0 24L0 488c0 13.3 10.7 24 24 24s24-10.7 24-24l0-8 224 0 0 8c0 13.3 10.7 24 24 24s24-10.7 24-24l0-368 0-24-24 0L24 96zM256 240l0 64c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-64c0-8.8 7.2-16 16-16s16 7.2 16 16z\"]\n};\nconst faCompactDisc = {\n prefix: 'fas',\n iconName: 'compact-disc',\n icon: [512, 512, [128191, 128192, 128440], \"f51f\", \"M0 256a256 256 0 1 1 512 0A256 256 0 1 1 0 256zm256 32a32 32 0 1 1 0-64 32 32 0 1 1 0 64zm-96-32a96 96 0 1 0 192 0 96 96 0 1 0 -192 0zM96 240c0-35 17.5-71.1 45.2-98.8S205 96 240 96c8.8 0 16-7.2 16-16s-7.2-16-16-16c-45.4 0-89.2 22.3-121.5 54.5S64 194.6 64 240c0 8.8 7.2 16 16 16s16-7.2 16-16z\"]\n};\nconst faFileArrowDown = {\n prefix: 'fas',\n iconName: 'file-arrow-down',\n icon: [384, 512, [\"file-download\"], \"f56d\", \"M64 0C28.7 0 0 28.7 0 64L0 448c0 35.3 28.7 64 64 64l256 0c35.3 0 64-28.7 64-64l0-288-128 0c-17.7 0-32-14.3-32-32L224 0 64 0zM256 0l0 128 128 0L256 0zM216 232l0 102.1 31-31c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9l-72 72c-9.4 9.4-24.6 9.4-33.9 0l-72-72c-9.4-9.4-9.4-24.6 0-33.9s24.6-9.4 33.9 0l31 31L168 232c0-13.3 10.7-24 24-24s24 10.7 24 24z\"]\n};\nconst faFileDownload = faFileArrowDown;\nconst faCaravan = {\n prefix: 'fas',\n iconName: 'caravan',\n icon: [640, 512, [], \"f8ff\", \"M0 112C0 67.8 35.8 32 80 32l336 0c88.4 0 160 71.6 160 160l0 160 32 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-32 0-288 0c0 53-43 96-96 96s-96-43-96-96l-16 0c-44.2 0-80-35.8-80-80L0 112zM320 352l128 0 0-96-32 0c-8.8 0-16-7.2-16-16s7.2-16 16-16l32 0 0-64c0-17.7-14.3-32-32-32l-64 0c-17.7 0-32 14.3-32 32l0 192zM96 128c-17.7 0-32 14.3-32 32l0 64c0 17.7 14.3 32 32 32l128 0c17.7 0 32-14.3 32-32l0-64c0-17.7-14.3-32-32-32L96 128zm96 336a48 48 0 1 0 0-96 48 48 0 1 0 0 96z\"]\n};\nconst faShieldCat = {\n prefix: 'fas',\n iconName: 'shield-cat',\n icon: [512, 512, [], \"e572\", \"M269.4 2.9C265.2 1 260.7 0 256 0s-9.2 1-13.4 2.9L54.3 82.8c-22 9.3-38.4 31-38.3 57.2c.5 99.2 41.3 280.7 213.6 363.2c16.7 8 36.1 8 52.8 0C454.7 420.7 495.5 239.2 496 140c.1-26.2-16.3-47.9-38.3-57.2L269.4 2.9zM160 154.4c0-5.8 4.7-10.4 10.4-10.4l.2 0c3.4 0 6.5 1.6 8.5 4.3l40 53.3c3 4 7.8 6.4 12.8 6.4l48 0c5 0 9.8-2.4 12.8-6.4l40-53.3c2-2.7 5.2-4.3 8.5-4.3l.2 0c5.8 0 10.4 4.7 10.4 10.4L352 272c0 53-43 96-96 96s-96-43-96-96l0-117.6zM216 288a16 16 0 1 0 0-32 16 16 0 1 0 0 32zm96-16a16 16 0 1 0 -32 0 16 16 0 1 0 32 0z\"]\n};\nconst faBolt = {\n prefix: 'fas',\n iconName: 'bolt',\n icon: [448, 512, [9889, \"zap\"], \"f0e7\", \"M349.4 44.6c5.9-13.7 1.5-29.7-10.6-38.5s-28.6-8-39.9 1.8l-256 224c-10 8.8-13.6 22.9-8.9 35.3S50.7 288 64 288l111.5 0L98.6 467.4c-5.9 13.7-1.5 29.7 10.6 38.5s28.6 8 39.9-1.8l256-224c10-8.8 13.6-22.9 8.9-35.3s-16.6-20.7-30-20.7l-111.5 0L349.4 44.6z\"]\n};\nconst faZap = faBolt;\nconst faGlassWater = {\n prefix: 'fas',\n iconName: 'glass-water',\n icon: [384, 512, [], \"e4f4\", \"M32 0C23.1 0 14.6 3.7 8.6 10.2S-.6 25.4 .1 34.3L28.9 437.7c3 41.9 37.8 74.3 79.8 74.3l166.6 0c42 0 76.8-32.4 79.8-74.3L383.9 34.3c.6-8.9-2.4-17.6-8.5-24.1S360.9 0 352 0L32 0zM73 156.5L66.4 64l251.3 0L311 156.5l-24.2 12.1c-19.4 9.7-42.2 9.7-61.6 0c-20.9-10.4-45.5-10.4-66.4 0c-19.4 9.7-42.2 9.7-61.6 0L73 156.5z\"]\n};\nconst faOilWell = {\n prefix: 'fas',\n iconName: 'oil-well',\n icon: [576, 512, [], \"e532\", \"M528.3 61.3c-11.4-42.7-55.3-68-98-56.6L414.9 8.8C397.8 13.4 387.7 31 392.3 48l24.5 91.4L308.5 167.5l-6.3-18.1C297.7 136.6 285.6 128 272 128s-25.7 8.6-30.2 21.4l-13.6 39L96 222.6 96 184c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 264-16 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l512 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-137.3 0L340 257.5l-62.2 16.1L305.3 352l-66.6 0L265 277l-74.6 19.3L137.3 448 96 448l0-159.2 337.4-87.5 25.2 94c4.6 17.1 22.1 27.2 39.2 22.6l15.5-4.1c42.7-11.4 68-55.3 56.6-98L528.3 61.3zM205.1 448l11.2-32 111.4 0 11.2 32-133.8 0z\"]\n};\nconst faVault = {\n prefix: 'fas',\n iconName: 'vault',\n icon: [576, 512, [], \"e2c5\", \"M64 0C28.7 0 0 28.7 0 64L0 416c0 35.3 28.7 64 64 64l16 0 16 32 64 0 16-32 224 0 16 32 64 0 16-32 16 0c35.3 0 64-28.7 64-64l0-352c0-35.3-28.7-64-64-64L64 0zM224 320a80 80 0 1 0 0-160 80 80 0 1 0 0 160zm0-240a160 160 0 1 1 0 320 160 160 0 1 1 0-320zM480 221.3L480 336c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-114.7c-18.6-6.6-32-24.4-32-45.3c0-26.5 21.5-48 48-48s48 21.5 48 48c0 20.9-13.4 38.7-32 45.3z\"]\n};\nconst faMars = {\n prefix: 'fas',\n iconName: 'mars',\n icon: [448, 512, [9794], \"f222\", \"M289.8 46.8c3.7-9 12.5-14.8 22.2-14.8l112 0c13.3 0 24 10.7 24 24l0 112c0 9.7-5.8 18.5-14.8 22.2s-19.3 1.7-26.2-5.2l-33.4-33.4L321 204.2c19.5 28.4 31 62.7 31 99.8c0 97.2-78.8 176-176 176S0 401.2 0 304s78.8-176 176-176c37 0 71.4 11.4 99.8 31l52.6-52.6L295 73c-6.9-6.9-8.9-17.2-5.2-26.2zM400 80s0 0 0 0s0 0 0 0s0 0 0 0zM176 416a112 112 0 1 0 0-224 112 112 0 1 0 0 224z\"]\n};\nconst faToilet = {\n prefix: 'fas',\n iconName: 'toilet',\n icon: [448, 512, [128701], \"f7d8\", \"M24 0C10.7 0 0 10.7 0 24S10.7 48 24 48l8 0 0 148.9c-1.9 1.4-3.8 2.9-5.6 4.4C10.9 214.5 0 232.9 0 256c0 46.9 14.3 84.1 37 112.5c14.2 17.7 31.1 31.3 48.5 41.8L65.6 469.9c-3.3 9.8-1.6 20.5 4.4 28.8s15.7 13.3 26 13.3l256 0c10.3 0 19.9-4.9 26-13.3s7.7-19.1 4.4-28.8l-19.8-59.5c17.4-10.5 34.3-24.1 48.5-41.8c22.7-28.4 37-65.5 37-112.5c0-23.1-10.9-41.5-26.4-54.6c-1.8-1.5-3.7-3-5.6-4.4L416 48l8 0c13.3 0 24-10.7 24-24s-10.7-24-24-24L24 0zM384 256.3c0 1-.3 2.6-3.8 5.6c-4.8 4.1-14 9-29.3 13.4C320.5 284 276.1 288 224 288s-96.5-4-126.9-12.8c-15.3-4.4-24.5-9.3-29.3-13.4c-3.5-3-3.8-4.6-3.8-5.6l0-.3c0 0 0-.1 0-.1c0-1 0-2.5 3.8-5.8c4.8-4.1 14-9 29.3-13.4C127.5 228 171.9 224 224 224s96.5 4 126.9 12.8c15.3 4.4 24.5 9.3 29.3 13.4c3.8 3.2 3.8 4.8 3.8 5.8c0 0 0 .1 0 .1l0 .3zM328.2 384l-.2 .5 0-.5 .2 0zM112 64l32 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16s7.2-16 16-16z\"]\n};\nconst faPlaneCircleXmark = {\n prefix: 'fas',\n iconName: 'plane-circle-xmark',\n icon: [640, 512, [], \"e557\", \"M256 0c-35 0-64 59.5-64 93.7l0 84.6L8.1 283.4c-5 2.8-8.1 8.2-8.1 13.9l0 65.5c0 10.6 10.2 18.3 20.4 15.4l171.6-49 0 70.9-57.6 43.2c-4 3-6.4 7.8-6.4 12.8l0 42c0 7.8 6.3 14 14 14c1.3 0 2.6-.2 3.9-.5L256 480l110.1 31.5c1.3 .4 2.6 .5 3.9 .5c6 0 11.1-3.7 13.1-9C344.5 470.7 320 422.2 320 368c0-60.6 30.6-114 77.1-145.6L320 178.3l0-84.6C320 59.5 292 0 256 0zM496 512a144 144 0 1 0 0-288 144 144 0 1 0 0 288zm59.3-180.7L518.6 368l36.7 36.7c6.2 6.2 6.2 16.4 0 22.6s-16.4 6.2-22.6 0L496 390.6l-36.7 36.7c-6.2 6.2-16.4 6.2-22.6 0s-6.2-16.4 0-22.6L473.4 368l-36.7-36.7c-6.2-6.2-6.2-16.4 0-22.6s16.4-6.2 22.6 0L496 345.4l36.7-36.7c6.2-6.2 16.4-6.2 22.6 0s6.2 16.4 0 22.6z\"]\n};\nconst faYenSign = {\n prefix: 'fas',\n iconName: 'yen-sign',\n icon: [320, 512, [165, \"cny\", \"jpy\", \"rmb\", \"yen\"], \"f157\", \"M58.6 46.3C48.8 31.5 29 27.6 14.2 37.4S-4.4 67 5.4 81.8L100.2 224 48 224c-17.7 0-32 14.3-32 32s14.3 32 32 32l80 0 0 32-80 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l80 0 0 64c0 17.7 14.3 32 32 32s32-14.3 32-32l0-64 80 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-80 0 0-32 80 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-52.2 0L314.6 81.8c9.8-14.7 5.8-34.6-8.9-44.4s-34.6-5.8-44.4 8.9L160 198.3 58.6 46.3z\"]\n};\nconst faCny = faYenSign;\nconst faJpy = faYenSign;\nconst faRmb = faYenSign;\nconst faYen = faYenSign;\nconst faRubleSign = {\n prefix: 'fas',\n iconName: 'ruble-sign',\n icon: [384, 512, [8381, \"rouble\", \"rub\", \"ruble\"], \"f158\", \"M96 32C78.3 32 64 46.3 64 64l0 192-32 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l32 0 0 32-32 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l32 0 0 32c0 17.7 14.3 32 32 32s32-14.3 32-32l0-32 160 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-160 0 0-32 112 0c79.5 0 144-64.5 144-144s-64.5-144-144-144L96 32zM240 256l-112 0 0-160 112 0c44.2 0 80 35.8 80 80s-35.8 80-80 80z\"]\n};\nconst faRouble = faRubleSign;\nconst faRub = faRubleSign;\nconst faRuble = faRubleSign;\nconst faSun = {\n prefix: 'fas',\n iconName: 'sun',\n icon: [512, 512, [9728], \"f185\", \"M361.5 1.2c5 2.1 8.6 6.6 9.6 11.9L391 121l107.9 19.8c5.3 1 9.8 4.6 11.9 9.6s1.5 10.7-1.6 15.2L446.9 256l62.3 90.3c3.1 4.5 3.7 10.2 1.6 15.2s-6.6 8.6-11.9 9.6L391 391 371.1 498.9c-1 5.3-4.6 9.8-9.6 11.9s-10.7 1.5-15.2-1.6L256 446.9l-90.3 62.3c-4.5 3.1-10.2 3.7-15.2 1.6s-8.6-6.6-9.6-11.9L121 391 13.1 371.1c-5.3-1-9.8-4.6-11.9-9.6s-1.5-10.7 1.6-15.2L65.1 256 2.8 165.7c-3.1-4.5-3.7-10.2-1.6-15.2s6.6-8.6 11.9-9.6L121 121 140.9 13.1c1-5.3 4.6-9.8 9.6-11.9s10.7-1.5 15.2 1.6L256 65.1 346.3 2.8c4.5-3.1 10.2-3.7 15.2-1.6zM160 256a96 96 0 1 1 192 0 96 96 0 1 1 -192 0zm224 0a128 128 0 1 0 -256 0 128 128 0 1 0 256 0z\"]\n};\nconst faGuitar = {\n prefix: 'fas',\n iconName: 'guitar',\n icon: [512, 512, [], \"f7a6\", \"M465 7c-9.4-9.4-24.6-9.4-33.9 0L383 55c-2.4 2.4-4.3 5.3-5.5 8.5l-15.4 41-77.5 77.6c-45.1-29.4-99.3-30.2-131 1.6c-11 11-18 24.6-21.4 39.6c-3.7 16.6-19.1 30.7-36.1 31.6c-25.6 1.3-49.3 10.7-67.3 28.6C-16 328.4-7.6 409.4 47.5 464.5s136.1 63.5 180.9 18.7c17.9-17.9 27.4-41.7 28.6-67.3c.9-17 15-32.3 31.6-36.1c15-3.4 28.6-10.5 39.6-21.4c31.8-31.8 31-85.9 1.6-131l77.6-77.6 41-15.4c3.2-1.2 6.1-3.1 8.5-5.5l48-48c9.4-9.4 9.4-24.6 0-33.9L465 7zM208 256a48 48 0 1 1 0 96 48 48 0 1 1 0-96z\"]\n};\nconst faFaceLaughWink = {\n prefix: 'fas',\n iconName: 'face-laugh-wink',\n icon: [512, 512, [\"laugh-wink\"], \"f59c\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM96.8 314.1c-3.8-13.7 7.4-26.1 21.6-26.1l275.2 0c14.2 0 25.5 12.4 21.6 26.1C396.2 382 332.1 432 256 432s-140.2-50-159.2-117.9zM144.4 192a32 32 0 1 1 64 0 32 32 0 1 1 -64 0zm156.4 25.6c-5.3 7.1-15.3 8.5-22.4 3.2s-8.5-15.3-3.2-22.4c30.4-40.5 91.2-40.5 121.6 0c5.3 7.1 3.9 17.1-3.2 22.4s-17.1 3.9-22.4-3.2c-17.6-23.5-52.8-23.5-70.4 0z\"]\n};\nconst faLaughWink = faFaceLaughWink;\nconst faHorseHead = {\n prefix: 'fas',\n iconName: 'horse-head',\n icon: [640, 512, [], \"f7ab\", \"M64 464l0-147.1c0-108.4 68.3-205.1 170.5-241.3L404.2 15.5C425.6 7.9 448 23.8 448 46.4c0 11-5.5 21.2-14.6 27.3L400 96c48.1 0 91.2 29.8 108.1 74.9l48.6 129.5c11.8 31.4 4.1 66.8-19.6 90.5c-16 16-37.8 25.1-60.5 25.1l-3.4 0c-26.1 0-50.9-11.6-67.6-31.7l-32.3-38.7c-11.7 4.1-24.2 6.4-37.3 6.4c0 0 0 0-.1 0c0 0 0 0 0 0c-6.3 0-12.5-.5-18.6-1.5c-3.6-.6-7.2-1.4-10.7-2.3c0 0 0 0 0 0c-28.9-7.8-53.1-26.8-67.8-52.2c-4.4-7.6-14.2-10.3-21.9-5.8s-10.3 14.2-5.8 21.9c24 41.5 68.3 70 119.3 71.9l47.2 70.8c4 6.1 6.2 13.2 6.2 20.4c0 20.3-16.5 36.8-36.8 36.8L112 512c-26.5 0-48-21.5-48-48zM392 224a24 24 0 1 0 0-48 24 24 0 1 0 0 48z\"]\n};\nconst faBoreHole = {\n prefix: 'fas',\n iconName: 'bore-hole',\n icon: [512, 512, [], \"e4c3\", \"M256 0c-17.7 0-32 14.3-32 32l0 264.6c-19.1 11.1-32 31.7-32 55.4c0 35.3 28.7 64 64 64s64-28.7 64-64c0-23.7-12.9-44.4-32-55.4L288 32c0-17.7-14.3-32-32-32zM48 128c-26.5 0-48 21.5-48 48L0 464c0 26.5 21.5 48 48 48l416 0c26.5 0 48-21.5 48-48l0-288c0-26.5-21.5-48-48-48l-80 0c-17.7 0-32 14.3-32 32l0 192c0 53-43 96-96 96s-96-43-96-96l0-192c0-17.7-14.3-32-32-32l-80 0z\"]\n};\nconst faIndustry = {\n prefix: 'fas',\n iconName: 'industry',\n icon: [576, 512, [], \"f275\", \"M64 32C46.3 32 32 46.3 32 64l0 240 0 48 0 80c0 26.5 21.5 48 48 48l416 0c26.5 0 48-21.5 48-48l0-128 0-151.8c0-18.2-19.4-29.7-35.4-21.1L352 215.4l0-63.2c0-18.2-19.4-29.7-35.4-21.1L160 215.4 160 64c0-17.7-14.3-32-32-32L64 32z\"]\n};\nconst faCircleDown = {\n prefix: 'fas',\n iconName: 'circle-down',\n icon: [512, 512, [61466, \"arrow-alt-circle-down\"], \"f358\", \"M256 0a256 256 0 1 0 0 512A256 256 0 1 0 256 0zM244.7 395.3l-112-112c-4.6-4.6-5.9-11.5-3.5-17.4s8.3-9.9 14.8-9.9l64 0 0-96c0-17.7 14.3-32 32-32l32 0c17.7 0 32 14.3 32 32l0 96 64 0c6.5 0 12.3 3.9 14.8 9.9s1.1 12.9-3.5 17.4l-112 112c-6.2 6.2-16.4 6.2-22.6 0z\"]\n};\nconst faArrowAltCircleDown = faCircleDown;\nconst faArrowsTurnToDots = {\n prefix: 'fas',\n iconName: 'arrows-turn-to-dots',\n icon: [512, 512, [], \"e4c1\", \"M249.4 25.4c12.5-12.5 32.8-12.5 45.3 0s12.5 32.8 0 45.3L269.3 96 416 96c53 0 96 43 96 96l0 32c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-32c0-17.7-14.3-32-32-32l-146.7 0 25.4 25.4c12.5 12.5 12.5 32.8 0 45.3s-32.8 12.5-45.3 0l-80-80c-12.5-12.5-12.5-32.8 0-45.3l80-80zm13.3 256l80 80c12.5 12.5 12.5 32.8 0 45.3l-80 80c-12.5 12.5-32.8 12.5-45.3 0s-12.5-32.8 0-45.3L242.7 416 96 416c-17.7 0-32 14.3-32 32l0 32c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-32c0-53 43-96 96-96l146.7 0-25.4-25.4c-12.5-12.5-12.5-32.8 0-45.3s32.8-12.5 45.3 0zM384 384a64 64 0 1 1 128 0 64 64 0 1 1 -128 0zM64 192A64 64 0 1 1 64 64a64 64 0 1 1 0 128z\"]\n};\nconst faFlorinSign = {\n prefix: 'fas',\n iconName: 'florin-sign',\n icon: [384, 512, [], \"e184\", \"M314.7 32c-38.8 0-73.7 23.3-88.6 59.1L170.7 224 64 224c-17.7 0-32 14.3-32 32s14.3 32 32 32l80 0L98.9 396.3c-5 11.9-16.6 19.7-29.5 19.7L32 416c-17.7 0-32 14.3-32 32s14.3 32 32 32l37.3 0c38.8 0 73.7-23.3 88.6-59.1L213.3 288 320 288c17.7 0 32-14.3 32-32s-14.3-32-32-32l-80 0 45.1-108.3c5-11.9 16.6-19.7 29.5-19.7L352 96c17.7 0 32-14.3 32-32s-14.3-32-32-32l-37.3 0z\"]\n};\nconst faArrowDownShortWide = {\n prefix: 'fas',\n iconName: 'arrow-down-short-wide',\n icon: [576, 512, [\"sort-amount-desc\", \"sort-amount-down-alt\"], \"f884\", \"M151.6 469.6C145.5 476.2 137 480 128 480s-17.5-3.8-23.6-10.4l-88-96c-11.9-13-11.1-33.3 2-45.2s33.3-11.1 45.2 2L96 365.7 96 64c0-17.7 14.3-32 32-32s32 14.3 32 32l0 301.7 32.4-35.4c11.9-13 32.2-13.9 45.2-2s13.9 32.2 2 45.2l-88 96zM320 32l32 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-32 0c-17.7 0-32-14.3-32-32s14.3-32 32-32zm0 128l96 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-96 0c-17.7 0-32-14.3-32-32s14.3-32 32-32zm0 128l160 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-160 0c-17.7 0-32-14.3-32-32s14.3-32 32-32zm0 128l224 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-224 0c-17.7 0-32-14.3-32-32s14.3-32 32-32z\"]\n};\nconst faSortAmountDesc = faArrowDownShortWide;\nconst faSortAmountDownAlt = faArrowDownShortWide;\nconst faLessThan = {\n prefix: 'fas',\n iconName: 'less-than',\n icon: [384, 512, [62774], \"3c\", \"M380.6 81.7c7.9 15.8 1.5 35-14.3 42.9L103.6 256 366.3 387.4c15.8 7.9 22.2 27.1 14.3 42.9s-27.1 22.2-42.9 14.3l-320-160C6.8 279.2 0 268.1 0 256s6.8-23.2 17.7-28.6l320-160c15.8-7.9 35-1.5 42.9 14.3z\"]\n};\nconst faAngleDown = {\n prefix: 'fas',\n iconName: 'angle-down',\n icon: [448, 512, [8964], \"f107\", \"M201.4 374.6c12.5 12.5 32.8 12.5 45.3 0l160-160c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0L224 306.7 86.6 169.4c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3l160 160z\"]\n};\nconst faCarTunnel = {\n prefix: 'fas',\n iconName: 'car-tunnel',\n icon: [512, 512, [], \"e4de\", \"M256 0C114.6 0 0 114.6 0 256L0 448c0 35.3 28.7 64 64 64l42.8 0c-6.6-5.9-10.8-14.4-10.8-24l0-112c0-20.8 11.3-38.9 28.1-48.6l21-64.7c7.5-23.1 29-38.7 53.3-38.7l115.2 0c24.3 0 45.8 15.6 53.3 38.7l21 64.7c16.8 9.7 28.2 27.8 28.2 48.6l0 112c0 9.6-4.2 18.1-10.8 24l42.8 0c35.3 0 64-28.7 64-64l0-192C512 114.6 397.4 0 256 0zM362.8 512c-6.6-5.9-10.8-14.4-10.8-24l0-40-192 0 0 40c0 9.6-4.2 18.1-10.8 24l213.7 0zM190.8 277.5L177 320l158 0-13.8-42.5c-1.1-3.3-4.1-5.5-7.6-5.5l-115.2 0c-3.5 0-6.5 2.2-7.6 5.5zM168 408a24 24 0 1 0 0-48 24 24 0 1 0 0 48zm200-24a24 24 0 1 0 -48 0 24 24 0 1 0 48 0z\"]\n};\nconst faHeadSideCough = {\n prefix: 'fas',\n iconName: 'head-side-cough',\n icon: [640, 512, [], \"e061\", \"M0 224.2C0 100.6 100.2 0 224 0l24 0c95.2 0 181.2 69.3 197.3 160.2c2.3 13 6.8 25.7 15.1 36l42 52.6c6.2 7.8 9.6 17.4 9.6 27.4c0 24.2-19.6 43.8-43.8 43.8L448 320s0 0 0 0l0 32L339.2 365.6c-11 1.4-19.2 10.7-19.2 21.8c0 11.6 9 21.2 20.6 21.9L448 416l0 16c0 26.5-21.5 48-48 48l-80 0 0 8c0 13.3-10.7 24-24 24l-40 0s0 0 0 0L96 512c-17.7 0-32-14.3-32-32l0-72.7c0-16.7-6.9-32.5-17.1-45.8C16.6 322.4 0 274.1 0 224.2zm352-.2a32 32 0 1 0 0-64 32 32 0 1 0 0 64zM464 384a24 24 0 1 1 48 0 24 24 0 1 1 -48 0zm152-24a24 24 0 1 1 0 48 24 24 0 1 1 0-48zM592 480a24 24 0 1 1 48 0 24 24 0 1 1 -48 0zM552 312a24 24 0 1 1 0 48 24 24 0 1 1 0-48zm40-24a24 24 0 1 1 48 0 24 24 0 1 1 -48 0zM552 408a24 24 0 1 1 0 48 24 24 0 1 1 0-48z\"]\n};\nconst faGripLines = {\n prefix: 'fas',\n iconName: 'grip-lines',\n icon: [448, 512, [], \"f7a4\", \"M32 288c-17.7 0-32 14.3-32 32s14.3 32 32 32l384 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L32 288zm0-128c-17.7 0-32 14.3-32 32s14.3 32 32 32l384 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L32 160z\"]\n};\nconst faThumbsDown = {\n prefix: 'fas',\n iconName: 'thumbs-down',\n icon: [512, 512, [128078, 61576], \"f165\", \"M313.4 479.1c26-5.2 42.9-30.5 37.7-56.5l-2.3-11.4c-5.3-26.7-15.1-52.1-28.8-75.2l144 0c26.5 0 48-21.5 48-48c0-18.5-10.5-34.6-25.9-42.6C497 236.6 504 223.1 504 208c0-23.4-16.8-42.9-38.9-47.1c4.4-7.3 6.9-15.8 6.9-24.9c0-21.3-13.9-39.4-33.1-45.6c.7-3.3 1.1-6.8 1.1-10.4c0-26.5-21.5-48-48-48l-97.5 0c-19 0-37.5 5.6-53.3 16.1L202.7 73.8C176 91.6 160 121.6 160 153.7l0 38.3 0 48 0 24.9c0 29.2 13.3 56.7 36 75l7.4 5.9c26.5 21.2 44.6 51 51.2 84.2l2.3 11.4c5.2 26 30.5 42.9 56.5 37.7zM32 384l64 0c17.7 0 32-14.3 32-32l0-224c0-17.7-14.3-32-32-32L32 96C14.3 96 0 110.3 0 128L0 352c0 17.7 14.3 32 32 32z\"]\n};\nconst faUserLock = {\n prefix: 'fas',\n iconName: 'user-lock',\n icon: [640, 512, [], \"f502\", \"M224 256A128 128 0 1 0 224 0a128 128 0 1 0 0 256zm-45.7 48C79.8 304 0 383.8 0 482.3C0 498.7 13.3 512 29.7 512l362.8 0c-5.4-9.4-8.6-20.3-8.6-32l0-128c0-2.1 .1-4.2 .3-6.3c-31-26-71-41.7-114.6-41.7l-91.4 0zM528 240c17.7 0 32 14.3 32 32l0 48-64 0 0-48c0-17.7 14.3-32 32-32zm-80 32l0 48c-17.7 0-32 14.3-32 32l0 128c0 17.7 14.3 32 32 32l160 0c17.7 0 32-14.3 32-32l0-128c0-17.7-14.3-32-32-32l0-48c0-44.2-35.8-80-80-80s-80 35.8-80 80z\"]\n};\nconst faArrowRightLong = {\n prefix: 'fas',\n iconName: 'arrow-right-long',\n icon: [512, 512, [\"long-arrow-right\"], \"f178\", \"M502.6 278.6c12.5-12.5 12.5-32.8 0-45.3l-128-128c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3L402.7 224 32 224c-17.7 0-32 14.3-32 32s14.3 32 32 32l370.7 0-73.4 73.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0l128-128z\"]\n};\nconst faLongArrowRight = faArrowRightLong;\nconst faAnchorCircleXmark = {\n prefix: 'fas',\n iconName: 'anchor-circle-xmark',\n icon: [640, 512, [], \"e4ac\", \"M320 96a32 32 0 1 1 -64 0 32 32 0 1 1 64 0zm21.1 80C367 158.8 384 129.4 384 96c0-53-43-96-96-96s-96 43-96 96c0 33.4 17 62.8 42.9 80L224 176c-17.7 0-32 14.3-32 32s14.3 32 32 32l32 0 0 208-48 0c-53 0-96-43-96-96l0-6.1 7 7c9.4 9.4 24.6 9.4 33.9 0s9.4-24.6 0-33.9L97 263c-9.4-9.4-24.6-9.4-33.9 0L7 319c-9.4 9.4-9.4 24.6 0 33.9s24.6 9.4 33.9 0l7-7 0 6.1c0 88.4 71.6 160 160 160l80 0 80 0c8.2 0 16.3-.6 24.2-1.8c-22.2-16.2-40.4-37.5-53-62.2L320 448l0-80 0-128 32 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-10.9 0zM496 512a144 144 0 1 0 0-288 144 144 0 1 0 0 288zm59.3-180.7L518.6 368l36.7 36.7c6.2 6.2 6.2 16.4 0 22.6s-16.4 6.2-22.6 0L496 390.6l-36.7 36.7c-6.2 6.2-16.4 6.2-22.6 0s-6.2-16.4 0-22.6L473.4 368l-36.7-36.7c-6.2-6.2-6.2-16.4 0-22.6s16.4-6.2 22.6 0L496 345.4l36.7-36.7c6.2-6.2 16.4-6.2 22.6 0s6.2 16.4 0 22.6z\"]\n};\nconst faEllipsis = {\n prefix: 'fas',\n iconName: 'ellipsis',\n icon: [448, 512, [\"ellipsis-h\"], \"f141\", \"M8 256a56 56 0 1 1 112 0A56 56 0 1 1 8 256zm160 0a56 56 0 1 1 112 0 56 56 0 1 1 -112 0zm216-56a56 56 0 1 1 0 112 56 56 0 1 1 0-112z\"]\n};\nconst faEllipsisH = faEllipsis;\nconst faChessPawn = {\n prefix: 'fas',\n iconName: 'chess-pawn',\n icon: [320, 512, [9823], \"f443\", \"M215.5 224c29.2-18.4 48.5-50.9 48.5-88c0-57.4-46.6-104-104-104S56 78.6 56 136c0 37.1 19.4 69.6 48.5 88L96 224c-17.7 0-32 14.3-32 32c0 16.5 12.5 30 28.5 31.8L80 400l160 0L227.5 287.8c16-1.8 28.5-15.3 28.5-31.8c0-17.7-14.3-32-32-32l-8.5 0zM22.6 473.4c-4.2 4.2-6.6 10-6.6 16C16 501.9 26.1 512 38.6 512l242.7 0c12.5 0 22.6-10.1 22.6-22.6c0-6-2.4-11.8-6.6-16L256 432 64 432 22.6 473.4z\"]\n};\nconst faKitMedical = {\n prefix: 'fas',\n iconName: 'kit-medical',\n icon: [576, 512, [\"first-aid\"], \"f479\", \"M64 32C28.7 32 0 60.7 0 96L0 416c0 35.3 28.7 64 64 64l32 0L96 32 64 32zm64 0l0 448 320 0 0-448L128 32zM512 480c35.3 0 64-28.7 64-64l0-320c0-35.3-28.7-64-64-64l-32 0 0 448 32 0zM256 176c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 48 48 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-48 0 0 48c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-48-48 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16l48 0 0-48z\"]\n};\nconst faFirstAid = faKitMedical;\nconst faPersonThroughWindow = {\n prefix: 'fas',\n iconName: 'person-through-window',\n icon: [640, 512, [], \"e5a9\", \"M64 64l224 0 0 9.8c0 39-23.7 74-59.9 88.4C167.6 186.5 128 245 128 310.2l0 73.8s0 0 0 0l-64 0L64 64zm288 0l224 0 0 320-67.7 0-3.7-4.5-75.2-90.2c-9.1-10.9-22.6-17.3-36.9-17.3l-71.1 0-41-63.1c-.3-.5-.6-1-1-1.4c44.7-29 72.5-79 72.5-133.6l0-9.8zm73 320l-45.8 0 42.7 64L592 448c26.5 0 48-21.5 48-48l0-352c0-26.5-21.5-48-48-48L48 0C21.5 0 0 21.5 0 48L0 400c0 26.5 21.5 48 48 48l260.2 0 33.2 49.8c9.8 14.7 29.7 18.7 44.4 8.9s18.7-29.7 8.9-44.4L310.5 336l74.6 0 40 48zm-159.5 0L192 384s0 0 0 0l0-73.8c0-10.2 1.6-20.1 4.7-29.5L265.5 384zM192 128a48 48 0 1 0 -96 0 48 48 0 1 0 96 0z\"]\n};\nconst faToolbox = {\n prefix: 'fas',\n iconName: 'toolbox',\n icon: [512, 512, [129520], \"f552\", \"M176 88l0 40 160 0 0-40c0-4.4-3.6-8-8-8L184 80c-4.4 0-8 3.6-8 8zm-48 40l0-40c0-30.9 25.1-56 56-56l144 0c30.9 0 56 25.1 56 56l0 40 28.1 0c12.7 0 24.9 5.1 33.9 14.1l51.9 51.9c9 9 14.1 21.2 14.1 33.9l0 92.1-128 0 0-32c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 32-128 0 0-32c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 32L0 320l0-92.1c0-12.7 5.1-24.9 14.1-33.9l51.9-51.9c9-9 21.2-14.1 33.9-14.1l28.1 0zM0 416l0-64 128 0c0 17.7 14.3 32 32 32s32-14.3 32-32l128 0c0 17.7 14.3 32 32 32s32-14.3 32-32l128 0 0 64c0 35.3-28.7 64-64 64L64 480c-35.3 0-64-28.7-64-64z\"]\n};\nconst faHandsHoldingCircle = {\n prefix: 'fas',\n iconName: 'hands-holding-circle',\n icon: [640, 512, [], \"e4fb\", \"M320 0a128 128 0 1 1 0 256A128 128 0 1 1 320 0zM40 64c22.1 0 40 17.9 40 40l0 40 0 80 0 40.2c0 17 6.7 33.3 18.7 45.3l51.1 51.1c8.3 8.3 21.3 9.6 31 3.1c12.9-8.6 14.7-26.9 3.7-37.8l-15.2-15.2-32-32c-12.5-12.5-12.5-32.8 0-45.3s32.8-12.5 45.3 0l32 32 15.2 15.2c0 0 0 0 0 0l25.3 25.3c21 21 32.8 49.5 32.8 79.2l0 78.9c0 26.5-21.5 48-48 48l-66.7 0c-17 0-33.3-6.7-45.3-18.7L28.1 393.4C10.1 375.4 0 351 0 325.5L0 224l0-64 0-56C0 81.9 17.9 64 40 64zm560 0c22.1 0 40 17.9 40 40l0 56 0 64 0 101.5c0 25.5-10.1 49.9-28.1 67.9L512 493.3c-12 12-28.3 18.7-45.3 18.7L400 512c-26.5 0-48-21.5-48-48l0-78.9c0-29.7 11.8-58.2 32.8-79.2l25.3-25.3c0 0 0 0 0 0l15.2-15.2 32-32c12.5-12.5 32.8-12.5 45.3 0s12.5 32.8 0 45.3l-32 32-15.2 15.2c-11 11-9.2 29.2 3.7 37.8c9.7 6.5 22.7 5.2 31-3.1l51.1-51.1c12-12 18.7-28.3 18.7-45.3l0-40.2 0-80 0-40c0-22.1 17.9-40 40-40z\"]\n};\nconst faBug = {\n prefix: 'fas',\n iconName: 'bug',\n icon: [512, 512, [], \"f188\", \"M256 0c53 0 96 43 96 96l0 3.6c0 15.7-12.7 28.4-28.4 28.4l-135.1 0c-15.7 0-28.4-12.7-28.4-28.4l0-3.6c0-53 43-96 96-96zM41.4 105.4c12.5-12.5 32.8-12.5 45.3 0l64 64c.7 .7 1.3 1.4 1.9 2.1c14.2-7.3 30.4-11.4 47.5-11.4l112 0c17.1 0 33.2 4.1 47.5 11.4c.6-.7 1.2-1.4 1.9-2.1l64-64c12.5-12.5 32.8-12.5 45.3 0s12.5 32.8 0 45.3l-64 64c-.7 .7-1.4 1.3-2.1 1.9c6.2 12 10.1 25.3 11.1 39.5l64.3 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-64 0c0 24.6-5.5 47.8-15.4 68.6c2.2 1.3 4.2 2.9 6 4.8l64 64c12.5 12.5 12.5 32.8 0 45.3s-32.8 12.5-45.3 0l-63.1-63.1c-24.5 21.8-55.8 36.2-90.3 39.6L272 240c0-8.8-7.2-16-16-16s-16 7.2-16 16l0 239.2c-34.5-3.4-65.8-17.8-90.3-39.6L86.6 502.6c-12.5 12.5-32.8 12.5-45.3 0s-12.5-32.8 0-45.3l64-64c1.9-1.9 3.9-3.4 6-4.8C101.5 367.8 96 344.6 96 320l-64 0c-17.7 0-32-14.3-32-32s14.3-32 32-32l64.3 0c1.1-14.1 5-27.5 11.1-39.5c-.7-.6-1.4-1.2-2.1-1.9l-64-64c-12.5-12.5-12.5-32.8 0-45.3z\"]\n};\nconst faCreditCard = {\n prefix: 'fas',\n iconName: 'credit-card',\n icon: [576, 512, [128179, 62083, \"credit-card-alt\"], \"f09d\", \"M64 32C28.7 32 0 60.7 0 96l0 32 576 0 0-32c0-35.3-28.7-64-64-64L64 32zM576 224L0 224 0 416c0 35.3 28.7 64 64 64l448 0c35.3 0 64-28.7 64-64l0-192zM112 352l64 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-64 0c-8.8 0-16-7.2-16-16s7.2-16 16-16zm112 16c0-8.8 7.2-16 16-16l128 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-128 0c-8.8 0-16-7.2-16-16z\"]\n};\nconst faCreditCardAlt = faCreditCard;\nconst faCar = {\n prefix: 'fas',\n iconName: 'car',\n icon: [512, 512, [128664, \"automobile\"], \"f1b9\", \"M135.2 117.4L109.1 192l293.8 0-26.1-74.6C372.3 104.6 360.2 96 346.6 96L165.4 96c-13.6 0-25.7 8.6-30.2 21.4zM39.6 196.8L74.8 96.3C88.3 57.8 124.6 32 165.4 32l181.2 0c40.8 0 77.1 25.8 90.6 64.3l35.2 100.5c23.2 9.6 39.6 32.5 39.6 59.2l0 144 0 48c0 17.7-14.3 32-32 32l-32 0c-17.7 0-32-14.3-32-32l0-48L96 400l0 48c0 17.7-14.3 32-32 32l-32 0c-17.7 0-32-14.3-32-32l0-48L0 256c0-26.7 16.4-49.6 39.6-59.2zM128 288a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zm288 32a32 32 0 1 0 0-64 32 32 0 1 0 0 64z\"]\n};\nconst faAutomobile = faCar;\nconst faHandHoldingHand = {\n prefix: 'fas',\n iconName: 'hand-holding-hand',\n icon: [576, 512, [], \"e4f7\", \"M7.8 207.7c-13.1-17.8-9.3-42.8 8.5-55.9L142.9 58.5C166.2 41.3 194.5 32 223.5 32L384 32l160 0c17.7 0 32 14.3 32 32l0 64c0 17.7-14.3 32-32 32l-36.8 0-44.9 36c-22.7 18.2-50.9 28-80 28L304 224l-16 0-64 0c-17.7 0-32-14.3-32-32s14.3-32 32-32l64 0 16 0c8.8 0 16-7.2 16-16s-7.2-16-16-16l-120.6 0L63.7 216.2c-17.8 13.1-42.8 9.3-55.9-8.5zM382.4 160c0 0 0 0 0 0l.9 0c-.3 0-.6 0-.9 0zM568.2 304.3c13.1 17.8 9.3 42.8-8.5 55.9L433.1 453.5c-23.4 17.2-51.6 26.5-80.7 26.5L192 480 32 480c-17.7 0-32-14.3-32-32l0-64c0-17.7 14.3-32 32-32l36.8 0 44.9-36c22.7-18.2 50.9-28 80-28l78.3 0 16 0 64 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-64 0-16 0c-8.8 0-16 7.2-16 16s7.2 16 16 16l120.6 0 119.7-88.2c17.8-13.1 42.8-9.3 55.9 8.5zM193.6 352c0 0 0 0 0 0l-.9 0c.3 0 .6 0 .9 0z\"]\n};\nconst faBookOpenReader = {\n prefix: 'fas',\n iconName: 'book-open-reader',\n icon: [512, 512, [\"book-reader\"], \"f5da\", \"M160 96a96 96 0 1 1 192 0A96 96 0 1 1 160 96zm80 152l0 264-48.4-24.2c-20.9-10.4-43.5-17-66.8-19.3l-96-9.6C12.5 457.2 0 443.5 0 427L0 224c0-17.7 14.3-32 32-32l30.3 0c63.6 0 125.6 19.6 177.7 56zm32 264l0-264c52.1-36.4 114.1-56 177.7-56l30.3 0c17.7 0 32 14.3 32 32l0 203c0 16.4-12.5 30.2-28.8 31.8l-96 9.6c-23.2 2.3-45.9 8.9-66.8 19.3L272 512z\"]\n};\nconst faBookReader = faBookOpenReader;\nconst faMountainSun = {\n prefix: 'fas',\n iconName: 'mountain-sun',\n icon: [640, 512, [], \"e52f\", \"M560 160A80 80 0 1 0 560 0a80 80 0 1 0 0 160zM55.9 512l325.2 0 75 0 122.8 0c33.8 0 61.1-27.4 61.1-61.1c0-11.2-3.1-22.2-8.9-31.8l-132-216.3C495 196.1 487.8 192 480 192s-15 4.1-19.1 10.7l-48.2 79L286.8 81c-6.6-10.6-18.3-17-30.8-17s-24.1 6.4-30.8 17L8.6 426.4C3 435.3 0 445.6 0 456.1C0 487 25 512 55.9 512z\"]\n};\nconst faArrowsLeftRightToLine = {\n prefix: 'fas',\n iconName: 'arrows-left-right-to-line',\n icon: [640, 512, [], \"e4ba\", \"M32 64c17.7 0 32 14.3 32 32l0 320c0 17.7-14.3 32-32 32s-32-14.3-32-32L0 96C0 78.3 14.3 64 32 64zm214.6 73.4c12.5 12.5 12.5 32.8 0 45.3L205.3 224l229.5 0-41.4-41.4c-12.5-12.5-12.5-32.8 0-45.3s32.8-12.5 45.3 0l96 96c12.5 12.5 12.5 32.8 0 45.3l-96 96c-12.5 12.5-32.8 12.5-45.3 0s-12.5-32.8 0-45.3L434.7 288l-229.5 0 41.4 41.4c12.5 12.5 12.5 32.8 0 45.3s-32.8 12.5-45.3 0l-96-96c-12.5-12.5-12.5-32.8 0-45.3l96-96c12.5-12.5 32.8-12.5 45.3 0zM640 96l0 320c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-320c0-17.7 14.3-32 32-32s32 14.3 32 32z\"]\n};\nconst faDiceD20 = {\n prefix: 'fas',\n iconName: 'dice-d20',\n icon: [512, 512, [], \"f6cf\", \"M48.7 125.8l53.2 31.9c7.8 4.7 17.8 2 22.2-5.9L201.6 12.1c3-5.4-.9-12.1-7.1-12.1c-1.6 0-3.2 .5-4.6 1.4L47.9 98.8c-9.6 6.6-9.2 20.9 .8 26.9zM16 171.7l0 123.5c0 8 10.4 11 14.7 4.4l60-92c5-7.6 2.6-17.8-5.2-22.5L40.2 158C29.6 151.6 16 159.3 16 171.7zM310.4 12.1l77.6 139.6c4.4 7.9 14.5 10.6 22.2 5.9l53.2-31.9c10-6 10.4-20.3 .8-26.9L322.1 1.4c-1.4-.9-3-1.4-4.6-1.4c-6.2 0-10.1 6.7-7.1 12.1zM496 171.7c0-12.4-13.6-20.1-24.2-13.7l-45.3 27.2c-7.8 4.7-10.1 14.9-5.2 22.5l60 92c4.3 6.7 14.7 3.6 14.7-4.4l0-123.5zm-49.3 246L286.1 436.6c-8.1 .9-14.1 7.8-14.1 15.9l0 52.8c0 3.7 3 6.8 6.8 6.8c.8 0 1.6-.1 2.4-.4l172.7-64c6.1-2.2 10.1-8 10.1-14.5c0-9.3-8.1-16.5-17.3-15.4zM233.2 512c3.7 0 6.8-3 6.8-6.8l0-52.6c0-8.1-6.1-14.9-14.1-15.9l-160.6-19c-9.2-1.1-17.3 6.1-17.3 15.4c0 6.5 4 12.3 10.1 14.5l172.7 64c.8 .3 1.6 .4 2.4 .4zM41.7 382.9l170.9 20.2c7.8 .9 13.4-7.5 9.5-14.3l-85.7-150c-5.9-10.4-20.7-10.8-27.3-.8L30.2 358.2c-6.5 9.9-.3 23.3 11.5 24.7zm439.6-24.8L402.9 238.1c-6.5-10-21.4-9.6-27.3 .8L290.2 388.5c-3.9 6.8 1.6 15.2 9.5 14.3l170.1-20c11.8-1.4 18-14.7 11.5-24.6zm-216.9 11l78.4-137.2c6.1-10.7-1.6-23.9-13.9-23.9l-145.7 0c-12.3 0-20 13.3-13.9 23.9l78.4 137.2c3.7 6.4 13 6.4 16.7 0zM174.4 176l163.2 0c12.2 0 19.9-13.1 14-23.8l-80-144c-2.8-5.1-8.2-8.2-14-8.2l-3.2 0c-5.8 0-11.2 3.2-14 8.2l-80 144c-5.9 10.7 1.8 23.8 14 23.8z\"]\n};\nconst faTruckDroplet = {\n prefix: 'fas',\n iconName: 'truck-droplet',\n icon: [640, 512, [], \"e58c\", \"M0 48C0 21.5 21.5 0 48 0L368 0c26.5 0 48 21.5 48 48l0 48 50.7 0c17 0 33.3 6.7 45.3 18.7L589.3 192c12 12 18.7 28.3 18.7 45.3l0 18.7 0 32 0 64c17.7 0 32 14.3 32 32s-14.3 32-32 32l-32 0c0 53-43 96-96 96s-96-43-96-96l-128 0c0 53-43 96-96 96s-96-43-96-96l-16 0c-26.5 0-48-21.5-48-48L0 48zM416 256l128 0 0-18.7L466.7 160 416 160l0 96zM160 464a48 48 0 1 0 0-96 48 48 0 1 0 0 96zm368-48a48 48 0 1 0 -96 0 48 48 0 1 0 96 0zM208 272c39.8 0 72-29.6 72-66c0-27-39.4-82.9-59.9-110.3c-6.1-8.2-18.1-8.2-24.2 0C175.4 123 136 179 136 206c0 36.5 32.2 66 72 66z\"]\n};\nconst faFileCircleXmark = {\n prefix: 'fas',\n iconName: 'file-circle-xmark',\n icon: [576, 512, [], \"e5a1\", \"M0 64C0 28.7 28.7 0 64 0L224 0l0 128c0 17.7 14.3 32 32 32l128 0 0 38.6C310.1 219.5 256 287.4 256 368c0 59.1 29.1 111.3 73.7 143.3c-3.2 .5-6.4 .7-9.7 .7L64 512c-35.3 0-64-28.7-64-64L0 64zm384 64l-128 0L256 0 384 128zm48 96a144 144 0 1 1 0 288 144 144 0 1 1 0-288zm59.3 107.3c6.2-6.2 6.2-16.4 0-22.6s-16.4-6.2-22.6 0L432 345.4l-36.7-36.7c-6.2-6.2-16.4-6.2-22.6 0s-6.2 16.4 0 22.6L409.4 368l-36.7 36.7c-6.2 6.2-6.2 16.4 0 22.6s16.4 6.2 22.6 0L432 390.6l36.7 36.7c6.2 6.2 16.4 6.2 22.6 0s6.2-16.4 0-22.6L454.6 368l36.7-36.7z\"]\n};\nconst faTemperatureArrowUp = {\n prefix: 'fas',\n iconName: 'temperature-arrow-up',\n icon: [576, 512, [\"temperature-up\"], \"e040\", \"M128 112c0-26.5 21.5-48 48-48s48 21.5 48 48l0 164.5c0 17.3 7.1 31.9 15.3 42.5C249.8 332.6 256 349.5 256 368c0 44.2-35.8 80-80 80s-80-35.8-80-80c0-18.5 6.2-35.4 16.7-48.9c8.2-10.6 15.3-25.2 15.3-42.5L128 112zM176 0C114.1 0 64 50.1 64 112l0 164.4c0 .1-.1 .3-.2 .6c-.2 .6-.8 1.6-1.7 2.8C43.2 304.2 32 334.8 32 368c0 79.5 64.5 144 144 144s144-64.5 144-144c0-33.2-11.2-63.8-30.1-88.1c-.9-1.2-1.5-2.2-1.7-2.8c-.1-.3-.2-.5-.2-.6L288 112C288 50.1 237.9 0 176 0zm0 416c26.5 0 48-21.5 48-48c0-20.9-13.4-38.7-32-45.3L192 112c0-8.8-7.2-16-16-16s-16 7.2-16 16l0 210.7c-18.6 6.6-32 24.4-32 45.3c0 26.5 21.5 48 48 48zM480 160l32 0c12.9 0 24.6-7.8 29.6-19.8s2.2-25.7-6.9-34.9l-64-64c-12.5-12.5-32.8-12.5-45.3 0l-64 64c-9.2 9.2-11.9 22.9-6.9 34.9s16.6 19.8 29.6 19.8l32 0 0 288c0 17.7 14.3 32 32 32s32-14.3 32-32l0-288z\"]\n};\nconst faTemperatureUp = faTemperatureArrowUp;\nconst faMedal = {\n prefix: 'fas',\n iconName: 'medal',\n icon: [512, 512, [127941], \"f5a2\", \"M4.1 38.2C1.4 34.2 0 29.4 0 24.6C0 11 11 0 24.6 0L133.9 0c11.2 0 21.7 5.9 27.4 15.5l68.5 114.1c-48.2 6.1-91.3 28.6-123.4 61.9L4.1 38.2zm503.7 0L405.6 191.5c-32.1-33.3-75.2-55.8-123.4-61.9L350.7 15.5C356.5 5.9 366.9 0 378.1 0L487.4 0C501 0 512 11 512 24.6c0 4.8-1.4 9.6-4.1 13.6zM80 336a176 176 0 1 1 352 0A176 176 0 1 1 80 336zm184.4-94.9c-3.4-7-13.3-7-16.8 0l-22.4 45.4c-1.4 2.8-4 4.7-7 5.1L168 298.9c-7.7 1.1-10.7 10.5-5.2 16l36.3 35.4c2.2 2.2 3.2 5.2 2.7 8.3l-8.6 49.9c-1.3 7.6 6.7 13.5 13.6 9.9l44.8-23.6c2.7-1.4 6-1.4 8.7 0l44.8 23.6c6.9 3.6 14.9-2.2 13.6-9.9l-8.6-49.9c-.5-3 .5-6.1 2.7-8.3l36.3-35.4c5.6-5.4 2.5-14.8-5.2-16l-50.1-7.3c-3-.4-5.7-2.4-7-5.1l-22.4-45.4z\"]\n};\nconst faBed = {\n prefix: 'fas',\n iconName: 'bed',\n icon: [640, 512, [128716], \"f236\", \"M32 32c17.7 0 32 14.3 32 32l0 256 224 0 0-160c0-17.7 14.3-32 32-32l224 0c53 0 96 43 96 96l0 224c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-32-224 0-32 0L64 416l0 32c0 17.7-14.3 32-32 32s-32-14.3-32-32L0 64C0 46.3 14.3 32 32 32zm144 96a80 80 0 1 1 0 160 80 80 0 1 1 0-160z\"]\n};\nconst faSquareH = {\n prefix: 'fas',\n iconName: 'square-h',\n icon: [448, 512, [\"h-square\"], \"f0fd\", \"M64 32C28.7 32 0 60.7 0 96L0 416c0 35.3 28.7 64 64 64l320 0c35.3 0 64-28.7 64-64l0-320c0-35.3-28.7-64-64-64L64 32zM336 152l0 104 0 104c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-80-128 0 0 80c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-208c0-13.3 10.7-24 24-24s24 10.7 24 24l0 80 128 0 0-80c0-13.3 10.7-24 24-24s24 10.7 24 24z\"]\n};\nconst faHSquare = faSquareH;\nconst faPodcast = {\n prefix: 'fas',\n iconName: 'podcast',\n icon: [448, 512, [], \"f2ce\", \"M319.4 372c48.5-31.3 80.6-85.9 80.6-148c0-97.2-78.8-176-176-176S48 126.8 48 224c0 62.1 32.1 116.6 80.6 148c1.2 17.3 4 38 7.2 57.1l.2 1C56 395.8 0 316.5 0 224C0 100.3 100.3 0 224 0S448 100.3 448 224c0 92.5-56 171.9-136 206.1l.2-1.1c3.1-19.2 6-39.8 7.2-57zm-2.3-38.1c-1.6-5.7-3.9-11.1-7-16.2c-5.8-9.7-13.5-17-21.9-22.4c19.5-17.6 31.8-43 31.8-71.3c0-53-43-96-96-96s-96 43-96 96c0 28.3 12.3 53.8 31.8 71.3c-8.4 5.4-16.1 12.7-21.9 22.4c-3.1 5.1-5.4 10.5-7 16.2C99.8 307.5 80 268 80 224c0-79.5 64.5-144 144-144s144 64.5 144 144c0 44-19.8 83.5-50.9 109.9zM224 312c32.9 0 64 8.6 64 43.8c0 33-12.9 104.1-20.6 132.9c-5.1 19-24.5 23.4-43.4 23.4s-38.2-4.4-43.4-23.4c-7.8-28.5-20.6-99.7-20.6-132.8c0-35.1 31.1-43.8 64-43.8zm0-144a56 56 0 1 1 0 112 56 56 0 1 1 0-112z\"]\n};\nconst faTemperatureFull = {\n prefix: 'fas',\n iconName: 'temperature-full',\n icon: [320, 512, [\"temperature-4\", \"thermometer-4\", \"thermometer-full\"], \"f2c7\", \"M160 64c-26.5 0-48 21.5-48 48l0 164.5c0 17.3-7.1 31.9-15.3 42.5C86.2 332.6 80 349.5 80 368c0 44.2 35.8 80 80 80s80-35.8 80-80c0-18.5-6.2-35.4-16.7-48.9c-8.2-10.6-15.3-25.2-15.3-42.5L208 112c0-26.5-21.5-48-48-48zM48 112C48 50.2 98.1 0 160 0s112 50.1 112 112l0 164.4c0 .1 .1 .3 .2 .6c.2 .6 .8 1.6 1.7 2.8c18.9 24.4 30.1 55 30.1 88.1c0 79.5-64.5 144-144 144S16 447.5 16 368c0-33.2 11.2-63.8 30.1-88.1c.9-1.2 1.5-2.2 1.7-2.8c.1-.3 .2-.5 .2-.6L48 112zM208 368c0 26.5-21.5 48-48 48s-48-21.5-48-48c0-20.9 13.4-38.7 32-45.3L144 112c0-8.8 7.2-16 16-16s16 7.2 16 16l0 210.7c18.6 6.6 32 24.4 32 45.3z\"]\n};\nconst faTemperature4 = faTemperatureFull;\nconst faThermometer4 = faTemperatureFull;\nconst faThermometerFull = faTemperatureFull;\nconst faBell = {\n prefix: 'fas',\n iconName: 'bell',\n icon: [448, 512, [128276, 61602], \"f0f3\", \"M224 0c-17.7 0-32 14.3-32 32l0 19.2C119 66 64 130.6 64 208l0 18.8c0 47-17.3 92.4-48.5 127.6l-7.4 8.3c-8.4 9.4-10.4 22.9-5.3 34.4S19.4 416 32 416l384 0c12.6 0 24-7.4 29.2-18.9s3.1-25-5.3-34.4l-7.4-8.3C401.3 319.2 384 273.9 384 226.8l0-18.8c0-77.4-55-142-128-156.8L256 32c0-17.7-14.3-32-32-32zm45.3 493.3c12-12 18.7-28.3 18.7-45.3l-64 0-64 0c0 17 6.7 33.3 18.7 45.3s28.3 18.7 45.3 18.7s33.3-6.7 45.3-18.7z\"]\n};\nconst faSuperscript = {\n prefix: 'fas',\n iconName: 'superscript',\n icon: [512, 512, [], \"f12b\", \"M480 32c0-11.1-5.7-21.4-15.2-27.2s-21.2-6.4-31.1-1.4l-32 16c-15.8 7.9-22.2 27.1-14.3 42.9C393 73.5 404.3 80 416 80l0 80c-17.7 0-32 14.3-32 32s14.3 32 32 32l32 0 32 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l0-128zM32 64C14.3 64 0 78.3 0 96s14.3 32 32 32l15.3 0 89.6 128L47.3 384 32 384c-17.7 0-32 14.3-32 32s14.3 32 32 32l32 0c10.4 0 20.2-5.1 26.2-13.6L176 311.8l85.8 122.6c6 8.6 15.8 13.6 26.2 13.6l32 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-15.3 0L215.1 256l89.6-128 15.3 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-32 0c-10.4 0-20.2 5.1-26.2 13.6L176 200.2 90.2 77.6C84.2 69.1 74.4 64 64 64L32 64z\"]\n};\nconst faPlugCircleXmark = {\n prefix: 'fas',\n iconName: 'plug-circle-xmark',\n icon: [576, 512, [], \"e560\", \"M96 0C78.3 0 64 14.3 64 32l0 96 64 0 0-96c0-17.7-14.3-32-32-32zM288 0c-17.7 0-32 14.3-32 32l0 96 64 0 0-96c0-17.7-14.3-32-32-32zM32 160c-17.7 0-32 14.3-32 32s14.3 32 32 32l0 32c0 77.4 55 142 128 156.8l0 67.2c0 17.7 14.3 32 32 32s32-14.3 32-32l0-67.2c12.3-2.5 24.1-6.4 35.1-11.5c-2.1-10.8-3.1-21.9-3.1-33.3c0-80.3 53.8-148 127.3-169.2c.5-2.2 .7-4.5 .7-6.8c0-17.7-14.3-32-32-32L32 160zM432 512a144 144 0 1 0 0-288 144 144 0 1 0 0 288zm59.3-180.7L454.6 368l36.7 36.7c6.2 6.2 6.2 16.4 0 22.6s-16.4 6.2-22.6 0L432 390.6l-36.7 36.7c-6.2 6.2-16.4 6.2-22.6 0s-6.2-16.4 0-22.6L409.4 368l-36.7-36.7c-6.2-6.2-6.2-16.4 0-22.6s16.4-6.2 22.6 0L432 345.4l36.7-36.7c6.2-6.2 16.4-6.2 22.6 0s6.2 16.4 0 22.6z\"]\n};\nconst faStarOfLife = {\n prefix: 'fas',\n iconName: 'star-of-life',\n icon: [512, 512, [], \"f621\", \"M208 32c0-17.7 14.3-32 32-32l32 0c17.7 0 32 14.3 32 32l0 140.9 122-70.4c15.3-8.8 34.9-3.6 43.7 11.7l16 27.7c8.8 15.3 3.6 34.9-11.7 43.7L352 256l122 70.4c15.3 8.8 20.6 28.4 11.7 43.7l-16 27.7c-8.8 15.3-28.4 20.6-43.7 11.7L304 339.1 304 480c0 17.7-14.3 32-32 32l-32 0c-17.7 0-32-14.3-32-32l0-140.9L86 409.6c-15.3 8.8-34.9 3.6-43.7-11.7l-16-27.7c-8.8-15.3-3.6-34.9 11.7-43.7L160 256 38 185.6c-15.3-8.8-20.5-28.4-11.7-43.7l16-27.7C51.1 98.8 70.7 93.6 86 102.4l122 70.4L208 32z\"]\n};\nconst faPhoneSlash = {\n prefix: 'fas',\n iconName: 'phone-slash',\n icon: [640, 512, [], \"f3dd\", \"M228.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C76.1 30.2 64 46 64 64c0 107.4 37.8 206 100.8 283.1L9.2 469.1c-10.4 8.2-12.3 23.3-4.1 33.7s23.3 12.3 33.7 4.1l592-464c10.4-8.2 12.3-23.3 4.1-33.7s-23.3-12.3-33.7-4.1L253 278c-17.8-21.5-32.9-45.2-45-70.7L257.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96zm96.8 319l-91.3 72C310.7 476 407.1 512 512 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L368.7 368c-15-7.1-29.3-15.2-43-24.3z\"]\n};\nconst faPaintRoller = {\n prefix: 'fas',\n iconName: 'paint-roller',\n icon: [512, 512, [], \"f5aa\", \"M0 64C0 28.7 28.7 0 64 0L352 0c35.3 0 64 28.7 64 64l0 64c0 35.3-28.7 64-64 64L64 192c-35.3 0-64-28.7-64-64L0 64zM160 352c0-17.7 14.3-32 32-32l0-16c0-44.2 35.8-80 80-80l144 0c17.7 0 32-14.3 32-32l0-32 0-90.5c37.3 13.2 64 48.7 64 90.5l0 32c0 53-43 96-96 96l-144 0c-8.8 0-16 7.2-16 16l0 16c17.7 0 32 14.3 32 32l0 128c0 17.7-14.3 32-32 32l-64 0c-17.7 0-32-14.3-32-32l0-128z\"]\n};\nconst faHandshakeAngle = {\n prefix: 'fas',\n iconName: 'handshake-angle',\n icon: [640, 512, [\"hands-helping\"], \"f4c4\", \"M544 248l0 3.3 69.7-69.7c21.9-21.9 21.9-57.3 0-79.2L535.6 24.4c-21.9-21.9-57.3-21.9-79.2 0L416.3 64.5c-2.7-.3-5.5-.5-8.3-.5L296 64c-37.1 0-67.6 28-71.6 64l-.4 0 0 120c0 22.1 17.9 40 40 40s40-17.9 40-40l0-72c0 0 0-.1 0-.1l0-15.9 16 0 136 0c0 0 0 0 .1 0l7.9 0c44.2 0 80 35.8 80 80l0 8zM336 192l0 56c0 39.8-32.2 72-72 72s-72-32.2-72-72l0-118.6c-35.9 6.2-65.8 32.3-76 68.2L99.5 255.2 26.3 328.4c-21.9 21.9-21.9 57.3 0 79.2l78.1 78.1c21.9 21.9 57.3 21.9 79.2 0l37.7-37.7c.9 0 1.8 .1 2.7 .1l160 0c26.5 0 48-21.5 48-48c0-5.6-1-11-2.7-16l2.7 0c26.5 0 48-21.5 48-48c0-12.8-5-24.4-13.2-33c25.7-5 45.1-27.6 45.2-54.8l0-.4c-.1-30.8-25.1-55.8-56-55.8c0 0 0 0 0 0l-120 0z\"]\n};\nconst faHandsHelping = faHandshakeAngle;\nconst faLocationDot = {\n prefix: 'fas',\n iconName: 'location-dot',\n icon: [384, 512, [\"map-marker-alt\"], \"f3c5\", \"M215.7 499.2C267 435 384 279.4 384 192C384 86 298 0 192 0S0 86 0 192c0 87.4 117 243 168.3 307.2c12.3 15.3 35.1 15.3 47.4 0zM192 128a64 64 0 1 1 0 128 64 64 0 1 1 0-128z\"]\n};\nconst faMapMarkerAlt = faLocationDot;\nconst faFile = {\n prefix: 'fas',\n iconName: 'file',\n icon: [384, 512, [128196, 128459, 61462], \"f15b\", \"M0 64C0 28.7 28.7 0 64 0L224 0l0 128c0 17.7 14.3 32 32 32l128 0 0 288c0 35.3-28.7 64-64 64L64 512c-35.3 0-64-28.7-64-64L0 64zm384 64l-128 0L256 0 384 128z\"]\n};\nconst faGreaterThan = {\n prefix: 'fas',\n iconName: 'greater-than',\n icon: [384, 512, [62769], \"3e\", \"M3.4 81.7c-7.9 15.8-1.5 35 14.3 42.9L280.5 256 17.7 387.4C1.9 395.3-4.5 414.5 3.4 430.3s27.1 22.2 42.9 14.3l320-160c10.8-5.4 17.7-16.5 17.7-28.6s-6.8-23.2-17.7-28.6l-320-160c-15.8-7.9-35-1.5-42.9 14.3z\"]\n};\nconst faPersonSwimming = {\n prefix: 'fas',\n iconName: 'person-swimming',\n icon: [576, 512, [127946, \"swimmer\"], \"f5c4\", \"M309.5 178.4L447.9 297.1c-1.6 .9-3.2 2-4.8 3c-18 12.4-40.1 20.3-59.2 20.3c-19.6 0-40.8-7.7-59.2-20.3c-22.1-15.5-51.6-15.5-73.7 0c-17.1 11.8-38 20.3-59.2 20.3c-10.1 0-21.1-2.2-31.9-6.2C163.1 193.2 262.2 96 384 96l64 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-64 0c-26.9 0-52.3 6.6-74.5 18.4zM160 160A64 64 0 1 1 32 160a64 64 0 1 1 128 0zM306.5 325.9C329 341.4 356.5 352 384 352c26.9 0 55.4-10.8 77.4-26.1c0 0 0 0 0 0c11.9-8.5 28.1-7.8 39.2 1.7c14.4 11.9 32.5 21 50.6 25.2c17.2 4 27.9 21.2 23.9 38.4s-21.2 27.9-38.4 23.9c-24.5-5.7-44.9-16.5-58.2-25C449.5 405.7 417 416 384 416c-31.9 0-60.6-9.9-80.4-18.9c-5.8-2.7-11.1-5.3-15.6-7.7c-4.5 2.4-9.7 5.1-15.6 7.7c-19.8 9-48.5 18.9-80.4 18.9c-33 0-65.5-10.3-94.5-25.8c-13.4 8.4-33.7 19.3-58.2 25c-17.2 4-34.4-6.7-38.4-23.9s6.7-34.4 23.9-38.4c18.1-4.2 36.2-13.3 50.6-25.2c11.1-9.4 27.3-10.1 39.2-1.7c0 0 0 0 0 0C136.7 341.2 165.1 352 192 352c27.5 0 55-10.6 77.5-26.1c11.1-7.9 25.9-7.9 37 0z\"]\n};\nconst faSwimmer = faPersonSwimming;\nconst faArrowDown = {\n prefix: 'fas',\n iconName: 'arrow-down',\n icon: [384, 512, [8595], \"f063\", \"M169.4 470.6c12.5 12.5 32.8 12.5 45.3 0l160-160c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0L224 370.8 224 64c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 306.7L54.6 265.4c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3l160 160z\"]\n};\nconst faDroplet = {\n prefix: 'fas',\n iconName: 'droplet',\n icon: [384, 512, [128167, \"tint\"], \"f043\", \"M192 512C86 512 0 426 0 320C0 228.8 130.2 57.7 166.6 11.7C172.6 4.2 181.5 0 191.1 0l1.8 0c9.6 0 18.5 4.2 24.5 11.7C253.8 57.7 384 228.8 384 320c0 106-86 192-192 192zM96 336c0-8.8-7.2-16-16-16s-16 7.2-16 16c0 61.9 50.1 112 112 112c8.8 0 16-7.2 16-16s-7.2-16-16-16c-44.2 0-80-35.8-80-80z\"]\n};\nconst faTint = faDroplet;\nconst faEraser = {\n prefix: 'fas',\n iconName: 'eraser',\n icon: [576, 512, [], \"f12d\", \"M290.7 57.4L57.4 290.7c-25 25-25 65.5 0 90.5l80 80c12 12 28.3 18.7 45.3 18.7L288 480l9.4 0L512 480c17.7 0 32-14.3 32-32s-14.3-32-32-32l-124.1 0L518.6 285.3c25-25 25-65.5 0-90.5L381.3 57.4c-25-25-65.5-25-90.5 0zM297.4 416l-9.4 0-105.4 0-80-80L227.3 211.3 364.7 348.7 297.4 416z\"]\n};\nconst faEarthAmericas = {\n prefix: 'fas',\n iconName: 'earth-americas',\n icon: [512, 512, [127758, \"earth\", \"earth-america\", \"globe-americas\"], \"f57d\", \"M57.7 193l9.4 16.4c8.3 14.5 21.9 25.2 38 29.8L163 255.7c17.2 4.9 29 20.6 29 38.5l0 39.9c0 11 6.2 21 16 25.9s16 14.9 16 25.9l0 39c0 15.6 14.9 26.9 29.9 22.6c16.1-4.6 28.6-17.5 32.7-33.8l2.8-11.2c4.2-16.9 15.2-31.4 30.3-40l8.1-4.6c15-8.5 24.2-24.5 24.2-41.7l0-8.3c0-12.7-5.1-24.9-14.1-33.9l-3.9-3.9c-9-9-21.2-14.1-33.9-14.1L257 256c-11.1 0-22.1-2.9-31.8-8.4l-34.5-19.7c-4.3-2.5-7.6-6.5-9.2-11.2c-3.2-9.6 1.1-20 10.2-24.5l5.9-3c6.6-3.3 14.3-3.9 21.3-1.5l23.2 7.7c8.2 2.7 17.2-.4 21.9-7.5c4.7-7 4.2-16.3-1.2-22.8l-13.6-16.3c-10-12-9.9-29.5 .3-41.3l15.7-18.3c8.8-10.3 10.2-25 3.5-36.7l-2.4-4.2c-3.5-.2-6.9-.3-10.4-.3C163.1 48 84.4 108.9 57.7 193zM464 256c0-36.8-9.6-71.4-26.4-101.5L412 164.8c-15.7 6.3-23.8 23.8-18.5 39.8l16.9 50.7c3.5 10.4 12 18.3 22.6 20.9l29.1 7.3c1.2-9 1.8-18.2 1.8-27.5zM0 256a256 256 0 1 1 512 0A256 256 0 1 1 0 256z\"]\n};\nconst faEarth = faEarthAmericas;\nconst faEarthAmerica = faEarthAmericas;\nconst faGlobeAmericas = faEarthAmericas;\nconst faPersonBurst = {\n prefix: 'fas',\n iconName: 'person-burst',\n icon: [640, 512, [], \"e53b\", \"M480 96a48 48 0 1 0 0-96 48 48 0 1 0 0 96zm-8 384l0-128 16 0 0 128c0 17.7 14.3 32 32 32s32-14.3 32-32l0-223.1 28.6 47.5c9.1 15.1 28.8 20 43.9 10.9s20-28.8 10.9-43.9l-58.3-97c-17.4-28.9-48.6-46.6-82.3-46.6l-29.7 0c-33.7 0-64.9 17.7-82.3 46.6l-58.3 97c-9.1 15.1-4.2 34.8 10.9 43.9s34.8 4.2 43.9-10.9L408 256.9 408 480c0 17.7 14.3 32 32 32s32-14.3 32-32zM190.9 18.1C188.4 12 182.6 8 176 8s-12.4 4-14.9 10.1l-29.4 74L55.6 68.9c-6.3-1.9-13.1 .2-17.2 5.3s-4.6 12.2-1.4 17.9l39.5 69.1L10.9 206.4c-5.4 3.7-8 10.3-6.5 16.7s6.7 11.2 13.1 12.2l78.7 12.2L90.6 327c-.5 6.5 3.1 12.7 9 15.5s12.9 1.8 17.8-2.6L176 286.1l58.6 53.9c4.8 4.4 11.9 5.5 17.8 2.6s9.5-9 9-15.5l-5.6-79.4 50.5-7.8 24.3-40.5-55.2-38L315 92.2c3.3-5.7 2.7-12.8-1.4-17.9s-10.9-7.2-17.2-5.3L220.3 92.1l-29.4-74z\"]\n};\nconst faDove = {\n prefix: 'fas',\n iconName: 'dove',\n icon: [512, 512, [128330], \"f4ba\", \"M160.8 96.5c14 17 31 30.9 49.5 42.2c25.9 15.8 53.7 25.9 77.7 31.6l0-31.5C265.8 108.5 250 71.5 248.6 28c-.4-11.3-7.5-21.5-18.4-24.4c-7.6-2-15.8-.2-21 5.8c-13.3 15.4-32.7 44.6-48.4 87.2zM320 144l0 30.6s0 0 0 0l0 1.3s0 0 0 0l0 32.1c-60.8-5.1-185-43.8-219.3-157.2C97.4 40 87.9 32 76.6 32c-7.9 0-15.3 3.9-18.8 11C46.8 65.9 32 112.1 32 176c0 116.9 80.1 180.5 118.4 202.8L11.8 416.6C6.7 418 2.6 421.8 .9 426.8s-.8 10.6 2.3 14.8C21.7 466.2 77.3 512 160 512c3.6 0 7.2-1.2 10-3.5L245.6 448l74.4 0c88.4 0 160-71.6 160-160l0-160 29.9-44.9c1.3-2 2.1-4.4 2.1-6.8c0-6.8-5.5-12.3-12.3-12.3L400 64c-44.2 0-80 35.8-80 80zm80-16a16 16 0 1 1 0 32 16 16 0 1 1 0-32z\"]\n};\nconst faBatteryEmpty = {\n prefix: 'fas',\n iconName: 'battery-empty',\n icon: [576, 512, [\"battery-0\"], \"f244\", \"M80 160c-8.8 0-16 7.2-16 16l0 160c0 8.8 7.2 16 16 16l384 0c8.8 0 16-7.2 16-16l0-160c0-8.8-7.2-16-16-16L80 160zM0 176c0-44.2 35.8-80 80-80l384 0c44.2 0 80 35.8 80 80l0 16c17.7 0 32 14.3 32 32l0 64c0 17.7-14.3 32-32 32l0 16c0 44.2-35.8 80-80 80L80 416c-44.2 0-80-35.8-80-80L0 176z\"]\n};\nconst faBattery0 = faBatteryEmpty;\nconst faSocks = {\n prefix: 'fas',\n iconName: 'socks',\n icon: [512, 512, [129510], \"f696\", \"M175.2 476.6c-9.7-18-15.2-38.7-15.2-60.6c0-40.3 19-78.2 51.2-102.4l64-48c8.1-6 12.8-15.5 12.8-25.6l0-144L128 96l0 144c0 20.1-9.5 39.1-25.6 51.2l-64 48C14.2 357.3 0 385.8 0 416c0 53 43 96 96 96c20.8 0 41-6.7 57.6-19.2l21.6-16.2zM128 64l160 0 0-16c0-14.5 3.9-28.2 10.7-39.9C291 3 281.9 0 272 0L176 0c-26.5 0-48 21.5-48 48l0 16zM320 96l0 144c0 20.1-9.5 39.1-25.6 51.2l-64 48C206.2 357.3 192 385.8 192 416c0 53 43 96 96 96c20.8 0 41-6.7 57.6-19.2l115.2-86.4C493 382.2 512 344.3 512 304l0-208L320 96zM512 64l0-16c0-26.5-21.5-48-48-48L368 0c-26.5 0-48 21.5-48 48l0 16 192 0z\"]\n};\nconst faInbox = {\n prefix: 'fas',\n iconName: 'inbox',\n icon: [512, 512, [], \"f01c\", \"M121 32C91.6 32 66 52 58.9 80.5L1.9 308.4C.6 313.5 0 318.7 0 323.9L0 416c0 35.3 28.7 64 64 64l384 0c35.3 0 64-28.7 64-64l0-92.1c0-5.2-.6-10.4-1.9-15.5l-57-227.9C446 52 420.4 32 391 32L121 32zm0 64l270 0 48 192-51.2 0c-12.1 0-23.2 6.8-28.6 17.7l-14.3 28.6c-5.4 10.8-16.5 17.7-28.6 17.7l-120.4 0c-12.1 0-23.2-6.8-28.6-17.7l-14.3-28.6c-5.4-10.8-16.5-17.7-28.6-17.7L73 288 121 96z\"]\n};\nconst faSection = {\n prefix: 'fas',\n iconName: 'section',\n icon: [256, 512, [], \"e447\", \"M64.9 96C67.1 84.4 73.7 76.2 86 70.6c13.8-6.2 34.8-8.9 61.2-4.5c8.8 1.4 36.1 7.1 44.1 9.3c17 4.8 34.7-5.1 39.5-22.2s-5.1-34.7-22.2-39.5c-11.1-3.1-41-9.2-50.9-10.8C123-2.7 88.3-.6 59.7 12.3C29.9 25.8 7.5 50.9 1.6 86.5c-.1 .5-.2 1.1-.2 1.6c-2.2 19.7 .3 37.9 8.1 54.1c7.7 16.1 19.4 28 32 36.9c.6 .5 1.3 .9 2 1.4C22.3 194.2 6.5 215.1 1.7 243c-.1 .6-.2 1.1-.2 1.7c-2.3 19.3 .4 37.1 8.4 53c7.9 15.6 19.8 27 32.3 35.5c22.4 15.2 51.9 24 75.4 31c0 0 0 0 0 0l3.7 1.1c27.2 8.2 46.9 14.6 59.4 23.8c5.5 4 8.2 7.6 9.5 10.9c1.3 3.2 2.6 8.6 .9 18.1c-1.7 10.1-7.7 18-20.7 23.5c-14 6-35.4 8.5-62 4.4c-12.8-2.1-35.1-9.7-54.1-16.2c0 0 0 0 0 0c-4.3-1.5-8.5-2.9-12.3-4.2C25.3 420 7.2 429.1 1.6 445.8s3.5 34.9 20.3 40.5c2.6 .8 5.7 1.9 9.2 3.1c18.6 6.3 48.5 16.6 67.3 19.6c0 0 0 0 0 0l.2 0c34.5 5.4 68.8 3.4 97.2-8.7c29.4-12.6 52.5-36.5 58.5-71.5c3.3-19.3 1.9-37.4-5-53.9c-6.3-15-16.4-26.4-27.6-35.2c16.5-13.9 28.5-33.2 32.6-58.2c3.2-19.8 1.9-38.3-4.8-55.1c-6.7-16.8-17.8-29.4-30.2-39c-22.8-17.6-53.6-27.4-77.7-35l-1.4-.5c-27.4-8.7-47.8-15.3-61.5-25c-6.1-4.4-9.5-8.5-11.4-12.4c-1.8-3.7-3.2-9.3-2.3-18.5zm76.7 208.5l-.6-.2-1.4-.4c-27.4-8.2-47.9-14.5-61.7-23.8c-6.2-4.2-9.3-7.9-11-11.3c-1.5-3-2.9-7.7-2.1-15.7c1.9-9.7 7.9-17.3 20.5-22.7c14-6 35.4-8.5 62.1-4.3l16.4 2.6c6.3 2.9 11.7 6 16.2 9.5c5.5 4.2 8.4 8.2 10 12.2c1.6 4 2.8 10.4 1.1 20.9c-2.4 14.7-12.8 26.4-37.1 31l-12.4 2.3z\"]\n};\nconst faGaugeHigh = {\n prefix: 'fas',\n iconName: 'gauge-high',\n icon: [512, 512, [62461, \"tachometer-alt\", \"tachometer-alt-fast\"], \"f625\", \"M0 256a256 256 0 1 1 512 0A256 256 0 1 1 0 256zM288 96a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zM256 416c35.3 0 64-28.7 64-64c0-17.4-6.9-33.1-18.1-44.6L366 161.7c5.3-12.1-.2-26.3-12.3-31.6s-26.3 .2-31.6 12.3L257.9 288c-.6 0-1.3 0-1.9 0c-35.3 0-64 28.7-64 64s28.7 64 64 64zM176 144a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zM96 288a32 32 0 1 0 0-64 32 32 0 1 0 0 64zm352-32a32 32 0 1 0 -64 0 32 32 0 1 0 64 0z\"]\n};\nconst faTachometerAlt = faGaugeHigh;\nconst faTachometerAltFast = faGaugeHigh;\nconst faEnvelopeOpenText = {\n prefix: 'fas',\n iconName: 'envelope-open-text',\n icon: [512, 512, [], \"f658\", \"M215.4 96L144 96l-36.2 0L96 96l0 8.8L96 144l0 40.4 0 89L.2 202.5c1.6-18.1 10.9-34.9 25.7-45.8L48 140.3 48 96c0-26.5 21.5-48 48-48l76.6 0 49.9-36.9C232.2 3.9 243.9 0 256 0s23.8 3.9 33.5 11L339.4 48 416 48c26.5 0 48 21.5 48 48l0 44.3 22.1 16.4c14.8 10.9 24.1 27.7 25.7 45.8L416 273.4l0-89 0-40.4 0-39.2 0-8.8-11.8 0L368 96l-71.4 0-81.3 0zM0 448L0 242.1 217.6 403.3c11.1 8.2 24.6 12.7 38.4 12.7s27.3-4.4 38.4-12.7L512 242.1 512 448s0 0 0 0c0 35.3-28.7 64-64 64L64 512c-35.3 0-64-28.7-64-64c0 0 0 0 0 0zM176 160l160 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-160 0c-8.8 0-16-7.2-16-16s7.2-16 16-16zm0 64l160 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-160 0c-8.8 0-16-7.2-16-16s7.2-16 16-16z\"]\n};\nconst faHospital = {\n prefix: 'fas',\n iconName: 'hospital',\n icon: [640, 512, [127973, 62589, \"hospital-alt\", \"hospital-wide\"], \"f0f8\", \"M192 48c0-26.5 21.5-48 48-48L400 0c26.5 0 48 21.5 48 48l0 464-80 0 0-80c0-26.5-21.5-48-48-48s-48 21.5-48 48l0 80-80 0 0-464zM48 96l112 0 0 416L48 512c-26.5 0-48-21.5-48-48L0 320l80 0c8.8 0 16-7.2 16-16s-7.2-16-16-16L0 288l0-64 80 0c8.8 0 16-7.2 16-16s-7.2-16-16-16L0 192l0-48c0-26.5 21.5-48 48-48zm544 0c26.5 0 48 21.5 48 48l0 48-80 0c-8.8 0-16 7.2-16 16s7.2 16 16 16l80 0 0 64-80 0c-8.8 0-16 7.2-16 16s7.2 16 16 16l80 0 0 144c0 26.5-21.5 48-48 48l-112 0 0-416 112 0zM312 64c-8.8 0-16 7.2-16 16l0 24-24 0c-8.8 0-16 7.2-16 16l0 16c0 8.8 7.2 16 16 16l24 0 0 24c0 8.8 7.2 16 16 16l16 0c8.8 0 16-7.2 16-16l0-24 24 0c8.8 0 16-7.2 16-16l0-16c0-8.8-7.2-16-16-16l-24 0 0-24c0-8.8-7.2-16-16-16l-16 0z\"]\n};\nconst faHospitalAlt = faHospital;\nconst faHospitalWide = faHospital;\nconst faWineBottle = {\n prefix: 'fas',\n iconName: 'wine-bottle',\n icon: [512, 512, [], \"f72f\", \"M393.4 9.4c12.5-12.5 32.8-12.5 45.3 0l64 64c12.5 12.5 12.5 32.8 0 45.3c-11.8 11.8-30.7 12.5-43.2 1.9l-9.5 9.5-48.8 48.8c-9.2 9.2-11.5 22.9-8.6 35.6c9.4 40.9-1.9 85.6-33.8 117.5L197.3 493.3c-25 25-65.5 25-90.5 0l-88-88c-25-25-25-65.5 0-90.5L180.2 153.3c31.9-31.9 76.6-43.1 117.5-33.8c12.6 2.9 26.4 .5 35.5-8.6l48.8-48.8 9.5-9.5c-10.6-12.6-10-31.4 1.9-43.2zM99.3 347.3l65.4 65.4c6.2 6.2 16.4 6.2 22.6 0l97.4-97.4c6.2-6.2 6.2-16.4 0-22.6l-65.4-65.4c-6.2-6.2-16.4-6.2-22.6 0L99.3 324.7c-6.2 6.2-6.2 16.4 0 22.6z\"]\n};\nconst faChessRook = {\n prefix: 'fas',\n iconName: 'chess-rook',\n icon: [448, 512, [9820], \"f447\", \"M32 192L32 48c0-8.8 7.2-16 16-16l64 0c8.8 0 16 7.2 16 16l0 40c0 4.4 3.6 8 8 8l32 0c4.4 0 8-3.6 8-8l0-40c0-8.8 7.2-16 16-16l64 0c8.8 0 16 7.2 16 16l0 40c0 4.4 3.6 8 8 8l32 0c4.4 0 8-3.6 8-8l0-40c0-8.8 7.2-16 16-16l64 0c8.8 0 16 7.2 16 16l0 144c0 10.1-4.7 19.6-12.8 25.6L352 256l16 144L80 400 96 256 44.8 217.6C36.7 211.6 32 202.1 32 192zm176 96l32 0c8.8 0 16-7.2 16-16l0-48c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 48c0 8.8 7.2 16 16 16zM22.6 473.4L64 432l320 0 41.4 41.4c4.2 4.2 6.6 10 6.6 16c0 12.5-10.1 22.6-22.6 22.6L38.6 512C26.1 512 16 501.9 16 489.4c0-6 2.4-11.8 6.6-16z\"]\n};\nconst faBarsStaggered = {\n prefix: 'fas',\n iconName: 'bars-staggered',\n icon: [512, 512, [\"reorder\", \"stream\"], \"f550\", \"M0 96C0 78.3 14.3 64 32 64l384 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L32 128C14.3 128 0 113.7 0 96zM64 256c0-17.7 14.3-32 32-32l384 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L96 288c-17.7 0-32-14.3-32-32zM448 416c0 17.7-14.3 32-32 32L32 448c-17.7 0-32-14.3-32-32s14.3-32 32-32l384 0c17.7 0 32 14.3 32 32z\"]\n};\nconst faReorder = faBarsStaggered;\nconst faStream = faBarsStaggered;\nconst faDharmachakra = {\n prefix: 'fas',\n iconName: 'dharmachakra',\n icon: [512, 512, [9784], \"f655\", \"M337.8 205.7l48.6-42.5c13.8 19.3 23.4 41.9 27.4 66.2l-64.4 4.3c-2.4-10.1-6.4-19.5-11.6-28zm140.1 19.5c-5.3-38.8-20.6-74.5-43.2-104.3l.8-.7C449 108.4 449.7 87.6 437 75s-33.4-12-45.2 1.5l-.7 .8c-29.8-22.6-65.5-37.9-104.3-43.2l.1-1.1c1.2-17.9-13-33-30.9-33s-32.1 15.2-30.9 33l.1 1.1c-38.8 5.3-74.5 20.6-104.3 43.2l-.7-.8C108.4 63 87.6 62.3 75 75s-12 33.4 1.5 45.2l.8 .7c-22.6 29.8-37.9 65.5-43.2 104.3l-1.1-.1c-17.9-1.2-33 13-33 30.9s15.2 32.1 33 30.9l1.1-.1c5.3 38.8 20.6 74.5 43.2 104.3l-.8 .7C63 403.6 62.3 424.4 75 437s33.4 12 45.2-1.5l.7-.8c29.8 22.6 65.5 37.9 104.3 43.2l-.1 1.1c-1.2 17.9 13 33 30.9 33s32.1-15.2 30.9-33l-.1-1.1c38.8-5.3 74.5-20.6 104.3-43.2l.7 .8c11.8 13.5 32.5 14.2 45.2 1.5s12-33.4-1.5-45.2l-.8-.7c22.6-29.8 37.9-65.5 43.2-104.3l1.1 .1c17.9 1.2 33-13 33-30.9s-15.2-32.1-33-30.9l-1.1 .1zM163.2 125.6c19.3-13.8 41.9-23.4 66.2-27.5l4.3 64.4c-10 2.4-19.5 6.4-28 11.6l-42.5-48.6zm-65 103.8c4.1-24.4 13.7-46.9 27.5-66.2l48.6 42.5c-5.3 8.5-9.2 18-11.6 28l-64.4-4.3zm27.5 119.4c-13.8-19.3-23.4-41.9-27.5-66.2l64.4-4.3c2.4 10 6.4 19.5 11.6 28l-48.6 42.5zm103.8 65c-24.4-4.1-46.9-13.7-66.2-27.4l42.5-48.6c8.5 5.3 18 9.2 28 11.6l-4.3 64.4zm119.4-27.4c-19.3 13.8-41.9 23.4-66.2 27.4l-4.3-64.4c10-2.4 19.5-6.4 28-11.6l42.5 48.6zm65-103.8c-4.1 24.4-13.7 46.9-27.4 66.2l-48.6-42.5c5.3-8.5 9.2-18 11.6-28l64.4 4.3zm-65-156.9l-42.5 48.6c-8.5-5.3-18-9.2-28-11.6l4.3-64.4c24.4 4.1 46.9 13.7 66.2 27.5zM256 224a32 32 0 1 1 0 64 32 32 0 1 1 0-64z\"]\n};\nconst faHotdog = {\n prefix: 'fas',\n iconName: 'hotdog',\n icon: [512, 512, [127789], \"f80f\", \"M488.6 23.4c31.2 31.2 31.2 81.9 0 113.1l-352 352c-31.2 31.2-81.9 31.2-113.1 0s-31.2-81.9 0-113.1l352-352c31.2-31.2 81.9-31.2 113.1 0zM443.3 92.7c-6.2-6.2-16.4-6.2-22.6 0c-12.5 12.5-23.8 15.1-37.5 17.6l-2.5 .4c-13.8 2.5-31.6 5.6-48 22c-16.7 16.7-20.9 36-24.1 50.9c0 0 0 0 0 0s0 0 0 0l-.2 1c-3.4 15.6-6 26.4-15.7 36.1s-20.5 12.3-36.1 15.7l-1 .2c-14.9 3.2-34.2 7.4-50.9 24.1s-20.9 36-24.1 50.9l-.2 1c-3.4 15.6-6 26.4-15.7 36.1c-9.2 9.2-18 10.8-32.7 13.4c0 0 0 0 0 0l-.9 .2c-15.6 2.8-34.9 6.9-54.4 26.4c-6.2 6.2-6.2 16.4 0 22.6s16.4 6.2 22.6 0c12.5-12.5 23.8-15.1 37.5-17.6l2.5-.4c13.8-2.5 31.6-5.6 48-22c16.7-16.7 20.9-36 24.1-50.9l.2-1c3.4-15.6 6-26.4 15.7-36.1s20.5-12.3 36.1-15.7l1-.2c14.9-3.2 34.2-7.4 50.9-24.1s20.9-36 24.1-50.9l.2-1c3.4-15.6 6-26.4 15.7-36.1c9.2-9.2 18-10.8 32.7-13.4l.9-.2c15.6-2.8 34.9-6.9 54.4-26.4c6.2-6.2 6.2-16.4 0-22.6zM191.2 479.2l288-288L495 207c10.9 10.9 17 25.6 17 41s-6.1 30.1-17 41L289 495c-10.9 10.9-25.6 17-41 17s-30.1-6.1-41-17l-15.8-15.8zM17 305C6.1 294.1 0 279.4 0 264s6.1-30.1 17-41L223 17C233.9 6.1 248.6 0 264 0s30.1 6.1 41 17l15.8 15.8-288 288L17 305z\"]\n};\nconst faPersonWalkingWithCane = {\n prefix: 'fas',\n iconName: 'person-walking-with-cane',\n icon: [512, 512, [\"blind\"], \"f29d\", \"M176 96a48 48 0 1 0 0-96 48 48 0 1 0 0 96zm-8.4 32c-36.4 0-69.6 20.5-85.9 53.1L35.4 273.7c-7.9 15.8-1.5 35 14.3 42.9s35 1.5 42.9-14.3L128 231.6l0 43.2c0 17 6.7 33.3 18.7 45.3L224 397.3l0 82.7c0 17.7 14.3 32 32 32s32-14.3 32-32l0-89.4c0-12.7-5.1-24.9-14.1-33.9L224 306.7l0-93.4 70.4 93.9c10.6 14.1 30.7 17 44.8 6.4s17-30.7 6.4-44.8L268.8 166.4C250.7 142.2 222.2 128 192 128l-24.4 0zM128.3 346.8L97 472.2c-4.3 17.1 6.1 34.5 23.3 38.8s34.5-6.1 38.8-23.3l22-88.2-52.8-52.8zM450.8 505.1c5 7.3 15 9.1 22.3 4s9.1-15 4-22.3L358.9 316.1c-2.8 3.8-6.1 7.3-10.1 10.3c-5 3.8-10.5 6.4-16.2 7.9L450.8 505.1z\"]\n};\nconst faBlind = faPersonWalkingWithCane;\nconst faDrum = {\n prefix: 'fas',\n iconName: 'drum',\n icon: [512, 512, [129345], \"f569\", \"M501.2 76.1c11.1-7.3 14.2-22.1 6.9-33.2s-22.1-14.2-33.2-6.9L370.2 104.5C335.8 98.7 297 96 256 96C114.6 96 0 128 0 208L0 368c0 31.3 27.4 58.8 72 78.7L72 344c0-13.3 10.7-24 24-24s24 10.7 24 24l0 119.4c33 8.9 71.1 14.5 112 16.1L232 376c0-13.3 10.7-24 24-24s24 10.7 24 24l0 103.5c40.9-1.6 79-7.2 112-16.1L392 344c0-13.3 10.7-24 24-24s24 10.7 24 24l0 102.7c44.6-19.9 72-47.4 72-78.7l0-160c0-41.1-30.2-69.5-78.8-87.4l67.9-44.5zM307.4 145.6l-64.6 42.3c-11.1 7.3-14.2 22.1-6.9 33.2s22.1 14.2 33.2 6.9l111.1-72.8c14.7 3.2 27.9 7 39.4 11.5C458.4 181.8 464 197.4 464 208c0 .8-2.7 17.2-46 35.9C379.1 260.7 322 272 256 272s-123.1-11.3-162-28.1C50.7 225.2 48 208.8 48 208c0-10.6 5.6-26.2 44.4-41.3C130.6 151.9 187.8 144 256 144c18 0 35.1 .5 51.4 1.6z\"]\n};\nconst faIceCream = {\n prefix: 'fas',\n iconName: 'ice-cream',\n icon: [448, 512, [127848], \"f810\", \"M367.1 160c.6-5.3 .9-10.6 .9-16C368 64.5 303.5 0 224 0S80 64.5 80 144c0 5.4 .3 10.7 .9 16l-.9 0c-26.5 0-48 21.5-48 48s21.5 48 48 48l53.5 0 181 0 53.5 0c26.5 0 48-21.5 48-48s-21.5-48-48-48l-.9 0zM96 288L200.8 497.7c4.4 8.8 13.3 14.3 23.2 14.3s18.8-5.5 23.2-14.3L352 288 96 288z\"]\n};\nconst faHeartCircleBolt = {\n prefix: 'fas',\n iconName: 'heart-circle-bolt',\n icon: [576, 512, [], \"e4fc\", \"M47.6 300.4L228.3 469.1c7.5 7 17.4 10.9 27.7 10.9s20.2-3.9 27.7-10.9l2.6-2.4C267.2 438.6 256 404.6 256 368c0-97.2 78.8-176 176-176c28.3 0 55 6.7 78.7 18.5c.9-6.5 1.3-13 1.3-19.6l0-5.8c0-69.9-50.5-129.5-119.4-141C347 36.5 300.6 51.4 268 84L256 96 244 84c-32.6-32.6-79-47.5-124.6-39.9C50.5 55.6 0 115.2 0 185.1l0 5.8c0 41.5 17.2 81.2 47.6 109.5zM432 512a144 144 0 1 0 0-288 144 144 0 1 0 0 288zm47.9-225c4.3 3.7 5.4 9.9 2.6 14.9L452.4 356l35.6 0c5.2 0 9.8 3.3 11.4 8.2s-.1 10.3-4.2 13.4l-96 72c-4.5 3.4-10.8 3.2-15.1-.6s-5.4-9.9-2.6-14.9L411.6 380 376 380c-5.2 0-9.8-3.3-11.4-8.2s.1-10.3 4.2-13.4l96-72c4.5-3.4 10.8-3.2 15.1 .6z\"]\n};\nconst faFax = {\n prefix: 'fas',\n iconName: 'fax',\n icon: [512, 512, [128224, 128439], \"f1ac\", \"M128 64l0 96 64 0 0-96 194.7 0L416 93.3l0 66.7 64 0 0-66.7c0-17-6.7-33.3-18.7-45.3L432 18.7C420 6.7 403.7 0 386.7 0L192 0c-35.3 0-64 28.7-64 64zM0 160L0 480c0 17.7 14.3 32 32 32l32 0c17.7 0 32-14.3 32-32l0-320c0-17.7-14.3-32-32-32l-32 0c-17.7 0-32 14.3-32 32zm480 32l-352 0 0 288c0 17.7 14.3 32 32 32l320 0c17.7 0 32-14.3 32-32l0-256c0-17.7-14.3-32-32-32zM256 256a32 32 0 1 1 0 64 32 32 0 1 1 0-64zm96 32a32 32 0 1 1 64 0 32 32 0 1 1 -64 0zm32 96a32 32 0 1 1 0 64 32 32 0 1 1 0-64zM224 416a32 32 0 1 1 64 0 32 32 0 1 1 -64 0z\"]\n};\nconst faParagraph = {\n prefix: 'fas',\n iconName: 'paragraph',\n icon: [448, 512, [182], \"f1dd\", \"M192 32l64 0 160 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-32 0 0 352c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-352-32 0 0 352c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-96-32 0c-88.4 0-160-71.6-160-160s71.6-160 160-160z\"]\n};\nconst faCheckToSlot = {\n prefix: 'fas',\n iconName: 'check-to-slot',\n icon: [576, 512, [\"vote-yea\"], \"f772\", \"M96 80c0-26.5 21.5-48 48-48l288 0c26.5 0 48 21.5 48 48l0 304L96 384 96 80zm313 47c-9.4-9.4-24.6-9.4-33.9 0l-111 111-47-47c-9.4-9.4-24.6-9.4-33.9 0s-9.4 24.6 0 33.9l64 64c9.4 9.4 24.6 9.4 33.9 0L409 161c9.4-9.4 9.4-24.6 0-33.9zM0 336c0-26.5 21.5-48 48-48l16 0 0 128 448 0 0-128 16 0c26.5 0 48 21.5 48 48l0 96c0 26.5-21.5 48-48 48L48 480c-26.5 0-48-21.5-48-48l0-96z\"]\n};\nconst faVoteYea = faCheckToSlot;\nconst faStarHalf = {\n prefix: 'fas',\n iconName: 'star-half',\n icon: [576, 512, [61731], \"f089\", \"M288 0c-12.2 .1-23.3 7-28.6 18L195 150.3 51.4 171.5c-12 1.8-22 10.2-25.7 21.7s-.7 24.2 7.9 32.7L137.8 329 113.2 474.7c-2 12 3 24.2 12.9 31.3s23 8 33.8 2.3L288 439.8 288 0zM429.9 512c1.1 .1 2.1 .1 3.2 0l-3.2 0z\"]\n};\nconst faBoxesStacked = {\n prefix: 'fas',\n iconName: 'boxes-stacked',\n icon: [576, 512, [62625, \"boxes\", \"boxes-alt\"], \"f468\", \"M248 0L208 0c-26.5 0-48 21.5-48 48l0 112c0 35.3 28.7 64 64 64l128 0c35.3 0 64-28.7 64-64l0-112c0-26.5-21.5-48-48-48L328 0l0 80c0 8.8-7.2 16-16 16l-48 0c-8.8 0-16-7.2-16-16l0-80zM64 256c-35.3 0-64 28.7-64 64L0 448c0 35.3 28.7 64 64 64l160 0c35.3 0 64-28.7 64-64l0-128c0-35.3-28.7-64-64-64l-40 0 0 80c0 8.8-7.2 16-16 16l-48 0c-8.8 0-16-7.2-16-16l0-80-40 0zM352 512l160 0c35.3 0 64-28.7 64-64l0-128c0-35.3-28.7-64-64-64l-40 0 0 80c0 8.8-7.2 16-16 16l-48 0c-8.8 0-16-7.2-16-16l0-80-40 0c-15 0-28.8 5.1-39.7 13.8c4.9 10.4 7.7 22 7.7 34.2l0 160c0 12.2-2.8 23.8-7.7 34.2C323.2 506.9 337 512 352 512z\"]\n};\nconst faBoxes = faBoxesStacked;\nconst faBoxesAlt = faBoxesStacked;\nconst faLink = {\n prefix: 'fas',\n iconName: 'link',\n icon: [640, 512, [128279, \"chain\"], \"f0c1\", \"M579.8 267.7c56.5-56.5 56.5-148 0-204.5c-50-50-128.8-56.5-186.3-15.4l-1.6 1.1c-14.4 10.3-17.7 30.3-7.4 44.6s30.3 17.7 44.6 7.4l1.6-1.1c32.1-22.9 76-19.3 103.8 8.6c31.5 31.5 31.5 82.5 0 114L422.3 334.8c-31.5 31.5-82.5 31.5-114 0c-27.9-27.9-31.5-71.8-8.6-103.8l1.1-1.6c10.3-14.4 6.9-34.4-7.4-44.6s-34.4-6.9-44.6 7.4l-1.1 1.6C206.5 251.2 213 330 263 380c56.5 56.5 148 56.5 204.5 0L579.8 267.7zM60.2 244.3c-56.5 56.5-56.5 148 0 204.5c50 50 128.8 56.5 186.3 15.4l1.6-1.1c14.4-10.3 17.7-30.3 7.4-44.6s-30.3-17.7-44.6-7.4l-1.6 1.1c-32.1 22.9-76 19.3-103.8-8.6C74 372 74 321 105.5 289.5L217.7 177.2c31.5-31.5 82.5-31.5 114 0c27.9 27.9 31.5 71.8 8.6 103.9l-1.1 1.6c-10.3 14.4-6.9 34.4 7.4 44.6s34.4 6.9 44.6-7.4l1.1-1.6C433.5 260.8 427 182 377 132c-56.5-56.5-148-56.5-204.5 0L60.2 244.3z\"]\n};\nconst faChain = faLink;\nconst faEarListen = {\n prefix: 'fas',\n iconName: 'ear-listen',\n icon: [512, 512, [\"assistive-listening-systems\"], \"f2a2\", \"M398.3 3.4c-15.8-7.9-35-1.5-42.9 14.3c-7.9 15.8-1.5 34.9 14.2 42.9l.4 .2c.4 .2 1.1 .6 2.1 1.2c2 1.2 5 3 8.7 5.6c7.5 5.2 17.6 13.2 27.7 24.2C428.5 113.4 448 146 448 192c0 17.7 14.3 32 32 32s32-14.3 32-32c0-66-28.5-113.4-56.5-143.7C441.6 33.2 427.7 22.2 417.3 15c-5.3-3.7-9.7-6.4-13-8.3c-1.6-1-3-1.7-4-2.2c-.5-.3-.9-.5-1.2-.7l-.4-.2-.2-.1c0 0 0 0-.1 0c0 0 0 0 0 0L384 32 398.3 3.4zM128.7 227.5c6.2-56 53.7-99.5 111.3-99.5c61.9 0 112 50.1 112 112c0 29.3-11.2 55.9-29.6 75.9c-17 18.4-34.4 45.1-34.4 78l0 6.1c0 26.5-21.5 48-48 48c-17.7 0-32 14.3-32 32s14.3 32 32 32c61.9 0 112-50.1 112-112l0-6.1c0-9.8 5.4-21.7 17.4-34.7C398.3 327.9 416 286 416 240c0-97.2-78.8-176-176-176C149.4 64 74.8 132.5 65.1 220.5c-1.9 17.6 10.7 33.4 28.3 35.3s33.4-10.7 35.3-28.3zM32 512a32 32 0 1 0 0-64 32 32 0 1 0 0 64zM192 352a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zM41.4 361.4c-12.5 12.5-12.5 32.8 0 45.3l64 64c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3l-64-64c-12.5-12.5-32.8-12.5-45.3 0zM208 240c0-17.7 14.3-32 32-32s32 14.3 32 32c0 13.3 10.7 24 24 24s24-10.7 24-24c0-44.2-35.8-80-80-80s-80 35.8-80 80c0 13.3 10.7 24 24 24s24-10.7 24-24z\"]\n};\nconst faAssistiveListeningSystems = faEarListen;\nconst faTreeCity = {\n prefix: 'fas',\n iconName: 'tree-city',\n icon: [640, 512, [], \"e587\", \"M288 48c0-26.5 21.5-48 48-48l96 0c26.5 0 48 21.5 48 48l0 144 40 0 0-72c0-13.3 10.7-24 24-24s24 10.7 24 24l0 72 24 0c26.5 0 48 21.5 48 48l0 224c0 26.5-21.5 48-48 48l-160 0-96 0c-26.5 0-48-21.5-48-48l0-416zm64 32l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0c-8.8 0-16 7.2-16 16zm16 80c-8.8 0-16 7.2-16 16l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0zM352 272l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0c-8.8 0-16 7.2-16 16zm176-16c-8.8 0-16 7.2-16 16l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0zM512 368l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0c-8.8 0-16 7.2-16 16zM224 160c0 6-1 11-2 16c20 14 34 38 34 64c0 45-36 80-80 80l-16 0 0 160c0 18-15 32-32 32c-18 0-32-14-32-32l0-160-16 0c-45 0-80-35-80-80c0-26 13-50 33-64c-1-5-1-10-1-16c0-53 42-96 96-96c53 0 96 43 96 96z\"]\n};\nconst faPlay = {\n prefix: 'fas',\n iconName: 'play',\n icon: [384, 512, [9654], \"f04b\", \"M73 39c-14.8-9.1-33.4-9.4-48.5-.9S0 62.6 0 80L0 432c0 17.4 9.4 33.4 24.5 41.9s33.7 8.1 48.5-.9L361 297c14.3-8.7 23-24.2 23-41s-8.7-32.2-23-41L73 39z\"]\n};\nconst faFont = {\n prefix: 'fas',\n iconName: 'font',\n icon: [448, 512, [], \"f031\", \"M254 52.8C249.3 40.3 237.3 32 224 32s-25.3 8.3-30 20.8L57.8 416 32 416c-17.7 0-32 14.3-32 32s14.3 32 32 32l96 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-1.8 0 18-48 159.6 0 18 48-1.8 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l96 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-25.8 0L254 52.8zM279.8 304l-111.6 0L224 155.1 279.8 304z\"]\n};\nconst faTableCellsRowLock = {\n prefix: 'fas',\n iconName: 'table-cells-row-lock',\n icon: [640, 512, [], \"e67a\", \"M0 96C0 60.7 28.7 32 64 32l384 0c35.3 0 64 28.7 64 64l0 65.1c-37.8 5.4-69.4 29.6-85.2 62.9L360 224l0 64 56 0 0 8.6c-19.1 11.1-32 31.7-32 55.4l-24 0 0 64 24 0 0 64L64 480c-35.3 0-64-28.7-64-64L0 96zM64 224l0 64 88 0 0-64-88 0zm232 0l-88 0 0 64 88 0 0-64zM152 352l-88 0 0 64 88 0 0-64zm56 0l0 64 88 0 0-64-88 0zM528 240c-17.7 0-32 14.3-32 32l0 48 64 0 0-48c0-17.7-14.3-32-32-32zm-80 32c0-44.2 35.8-80 80-80s80 35.8 80 80l0 48c17.7 0 32 14.3 32 32l0 128c0 17.7-14.3 32-32 32l-160 0c-17.7 0-32-14.3-32-32l0-128c0-17.7 14.3-32 32-32l0-48z\"]\n};\nconst faRupiahSign = {\n prefix: 'fas',\n iconName: 'rupiah-sign',\n icon: [512, 512, [], \"e23d\", \"M0 64C0 46.3 14.3 32 32 32l80 0c79.5 0 144 64.5 144 144c0 58.8-35.2 109.3-85.7 131.7l51.4 128.4c6.6 16.4-1.4 35-17.8 41.6s-35-1.4-41.6-17.8L106.3 320 64 320l0 128c0 17.7-14.3 32-32 32s-32-14.3-32-32L0 288 0 64zM64 256l48 0c44.2 0 80-35.8 80-80s-35.8-80-80-80L64 96l0 160zm256-96l80 0c61.9 0 112 50.1 112 112s-50.1 112-112 112l-48 0 0 96c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-128 0-160c0-17.7 14.3-32 32-32zm80 160c26.5 0 48-21.5 48-48s-21.5-48-48-48l-48 0 0 96 48 0z\"]\n};\nconst faMagnifyingGlass = {\n prefix: 'fas',\n iconName: 'magnifying-glass',\n icon: [512, 512, [128269, \"search\"], \"f002\", \"M416 208c0 45.9-14.9 88.3-40 122.7L502.6 457.4c12.5 12.5 12.5 32.8 0 45.3s-32.8 12.5-45.3 0L330.7 376c-34.4 25.2-76.8 40-122.7 40C93.1 416 0 322.9 0 208S93.1 0 208 0S416 93.1 416 208zM208 352a144 144 0 1 0 0-288 144 144 0 1 0 0 288z\"]\n};\nconst faSearch = faMagnifyingGlass;\nconst faTableTennisPaddleBall = {\n prefix: 'fas',\n iconName: 'table-tennis-paddle-ball',\n icon: [512, 512, [127955, \"ping-pong-paddle-ball\", \"table-tennis\"], \"f45d\", \"M416 288c-50.1 0-93.6 28.8-114.6 70.8L68.9 126.3l.6-.6 60.1-60.1c87.5-87.5 229.3-87.5 316.8 0c67.1 67.1 82.7 166.3 46.8 248.3C471.8 297.6 445 288 416 288zM49.3 151.9L290.1 392.7c-1.4 7.5-2.1 15.3-2.1 23.3c0 23.2 6.2 44.9 16.9 63.7c-3 .2-6.1 .3-9.2 .3l-2.7 0c-33.9 0-66.5-13.5-90.5-37.5l-9.8-9.8c-13.1-13.1-34.6-12.4-46.8 1.7L88.2 501c-5.8 6.7-14.2 10.7-23 11s-17.5-3.1-23.8-9.4l-32-32C3.1 464.3-.3 455.7 0 446.9s4.3-17.2 11-23l66.6-57.7c14-12.2 14.8-33.7 1.7-46.8l-9.8-9.8C45.5 285.5 32 252.9 32 219l0-2.7c0-22.8 6.1-44.9 17.3-64.3zM416 320a96 96 0 1 1 0 192 96 96 0 1 1 0-192z\"]\n};\nconst faPingPongPaddleBall = faTableTennisPaddleBall;\nconst faTableTennis = faTableTennisPaddleBall;\nconst faPersonDotsFromLine = {\n prefix: 'fas',\n iconName: 'person-dots-from-line',\n icon: [576, 512, [\"diagnoses\"], \"f470\", \"M288 176A88 88 0 1 0 288 0a88 88 0 1 0 0 176zM78.7 372.9c15-12.5 50-34.4 97.3-50.1L176 432l224 0 0-109.3c47.3 15.8 82.3 37.7 97.3 50.1c20.4 17 50.6 14.2 67.6-6.1s14.2-50.6-6.1-67.6c-12-10-30.1-22.5-53.2-35C497.2 278.4 481.7 288 464 288c-26.5 0-48-21.5-48-48c0-4.3 .6-8.4 1.6-12.4C379.1 215.9 335.3 208 288 208c-60.2 0-114.9 12.9-160 29.9c0 .7 0 1.4 0 2.1c0 26.5-21.5 48-48 48c-11.8 0-22.7-4.3-31-11.4c-13.1 8.1-23.7 15.9-31.7 22.5c-20.4 17-23.1 47.2-6.1 67.6s47.2 23.1 67.6 6.1zM24 464c-13.3 0-24 10.7-24 24s10.7 24 24 24l528 0c13.3 0 24-10.7 24-24s-10.7-24-24-24L24 464zM224 280a24 24 0 1 1 48 0 24 24 0 1 1 -48 0zm104 56a24 24 0 1 1 0 48 24 24 0 1 1 0-48zM96 240a16 16 0 1 0 -32 0 16 16 0 1 0 32 0zm368 16a16 16 0 1 0 0-32 16 16 0 1 0 0 32z\"]\n};\nconst faDiagnoses = faPersonDotsFromLine;\nconst faTrashCanArrowUp = {\n prefix: 'fas',\n iconName: 'trash-can-arrow-up',\n icon: [448, 512, [\"trash-restore-alt\"], \"f82a\", \"M163.8 0L284.2 0c12.1 0 23.2 6.8 28.6 17.7L320 32l96 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L32 96C14.3 96 0 81.7 0 64S14.3 32 32 32l96 0 7.2-14.3C140.6 6.8 151.7 0 163.8 0zM32 128l384 0 0 320c0 35.3-28.7 64-64 64L96 512c-35.3 0-64-28.7-64-64l0-320zm192 64c-6.4 0-12.5 2.5-17 7l-80 80c-9.4 9.4-9.4 24.6 0 33.9s24.6 9.4 33.9 0l39-39L200 408c0 13.3 10.7 24 24 24s24-10.7 24-24l0-134.1 39 39c9.4 9.4 24.6 9.4 33.9 0s9.4-24.6 0-33.9l-80-80c-4.5-4.5-10.6-7-17-7z\"]\n};\nconst faTrashRestoreAlt = faTrashCanArrowUp;\nconst faNairaSign = {\n prefix: 'fas',\n iconName: 'naira-sign',\n icon: [448, 512, [], \"e1f6\", \"M122.6 46.3c-7.8-11.7-22.4-17-35.9-12.9S64 49.9 64 64l0 192-32 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l32 0 0 128c0 17.7 14.3 32 32 32s32-14.3 32-32l0-128 100.2 0 97.2 145.8c7.8 11.7 22.4 17 35.9 12.9s22.7-16.5 22.7-30.6l0-128 32 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-32 0 0-192c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 192-57.5 0L122.6 46.3zM305.1 320l14.9 0 0 22.3L305.1 320zM185.5 256L128 256l0-86.3L185.5 256z\"]\n};\nconst faCartArrowDown = {\n prefix: 'fas',\n iconName: 'cart-arrow-down',\n icon: [576, 512, [], \"f218\", \"M24 0C10.7 0 0 10.7 0 24S10.7 48 24 48l45.5 0c3.8 0 7.1 2.7 7.9 6.5l51.6 271c6.5 34 36.2 58.5 70.7 58.5L488 384c13.3 0 24-10.7 24-24s-10.7-24-24-24l-288.3 0c-11.5 0-21.4-8.2-23.6-19.5L170.7 288l288.5 0c32.6 0 61.1-21.8 69.5-53.3l41-152.3C576.6 57 557.4 32 531.1 32L360 32l0 102.1 23-23c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9l-64 64c-9.4 9.4-24.6 9.4-33.9 0l-64-64c-9.4-9.4-9.4-24.6 0-33.9s24.6-9.4 33.9 0l23 23L312 32 120.1 32C111 12.8 91.6 0 69.5 0L24 0zM176 512a48 48 0 1 0 0-96 48 48 0 1 0 0 96zm336-48a48 48 0 1 0 -96 0 48 48 0 1 0 96 0z\"]\n};\nconst faWalkieTalkie = {\n prefix: 'fas',\n iconName: 'walkie-talkie',\n icon: [384, 512, [], \"f8ef\", \"M112 24c0-13.3-10.7-24-24-24S64 10.7 64 24l0 72L48 96C21.5 96 0 117.5 0 144L0 300.1c0 12.7 5.1 24.9 14.1 33.9l3.9 3.9c9 9 14.1 21.2 14.1 33.9L32 464c0 26.5 21.5 48 48 48l224 0c26.5 0 48-21.5 48-48l0-92.1c0-12.7 5.1-24.9 14.1-33.9l3.9-3.9c9-9 14.1-21.2 14.1-33.9L384 144c0-26.5-21.5-48-48-48l-16 0c0-17.7-14.3-32-32-32s-32 14.3-32 32l-32 0c0-17.7-14.3-32-32-32s-32 14.3-32 32l-48 0 0-72zm0 136l160 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-160 0c-8.8 0-16-7.2-16-16s7.2-16 16-16zm0 64l160 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-160 0c-8.8 0-16-7.2-16-16s7.2-16 16-16zm0 64l160 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-160 0c-8.8 0-16-7.2-16-16s7.2-16 16-16z\"]\n};\nconst faFilePen = {\n prefix: 'fas',\n iconName: 'file-pen',\n icon: [576, 512, [128221, \"file-edit\"], \"f31c\", \"M0 64C0 28.7 28.7 0 64 0L224 0l0 128c0 17.7 14.3 32 32 32l128 0 0 125.7-86.8 86.8c-10.3 10.3-17.5 23.1-21 37.2l-18.7 74.9c-2.3 9.2-1.8 18.8 1.3 27.5L64 512c-35.3 0-64-28.7-64-64L0 64zm384 64l-128 0L256 0 384 128zM549.8 235.7l14.4 14.4c15.6 15.6 15.6 40.9 0 56.6l-29.4 29.4-71-71 29.4-29.4c15.6-15.6 40.9-15.6 56.6 0zM311.9 417L441.1 287.8l71 71L382.9 487.9c-4.1 4.1-9.2 7-14.9 8.4l-60.1 15c-5.5 1.4-11.2-.2-15.2-4.2s-5.6-9.7-4.2-15.2l15-60.1c1.4-5.6 4.3-10.8 8.4-14.9z\"]\n};\nconst faFileEdit = faFilePen;\nconst faReceipt = {\n prefix: 'fas',\n iconName: 'receipt',\n icon: [384, 512, [129534], \"f543\", \"M14 2.2C22.5-1.7 32.5-.3 39.6 5.8L80 40.4 120.4 5.8c9-7.7 22.3-7.7 31.2 0L192 40.4 232.4 5.8c9-7.7 22.3-7.7 31.2 0L304 40.4 344.4 5.8c7.1-6.1 17.1-7.5 25.6-3.6s14 12.4 14 21.8l0 464c0 9.4-5.5 17.9-14 21.8s-18.5 2.5-25.6-3.6L304 471.6l-40.4 34.6c-9 7.7-22.3 7.7-31.2 0L192 471.6l-40.4 34.6c-9 7.7-22.3 7.7-31.2 0L80 471.6 39.6 506.2c-7.1 6.1-17.1 7.5-25.6 3.6S0 497.4 0 488L0 24C0 14.6 5.5 6.1 14 2.2zM96 144c-8.8 0-16 7.2-16 16s7.2 16 16 16l192 0c8.8 0 16-7.2 16-16s-7.2-16-16-16L96 144zM80 352c0 8.8 7.2 16 16 16l192 0c8.8 0 16-7.2 16-16s-7.2-16-16-16L96 336c-8.8 0-16 7.2-16 16zM96 240c-8.8 0-16 7.2-16 16s7.2 16 16 16l192 0c8.8 0 16-7.2 16-16s-7.2-16-16-16L96 240z\"]\n};\nconst faSquarePen = {\n prefix: 'fas',\n iconName: 'square-pen',\n icon: [448, 512, [\"pen-square\", \"pencil-square\"], \"f14b\", \"M64 32C28.7 32 0 60.7 0 96L0 416c0 35.3 28.7 64 64 64l320 0c35.3 0 64-28.7 64-64l0-320c0-35.3-28.7-64-64-64L64 32zM325.8 139.7l14.4 14.4c15.6 15.6 15.6 40.9 0 56.6l-21.4 21.4-71-71 21.4-21.4c15.6-15.6 40.9-15.6 56.6 0zM119.9 289L225.1 183.8l71 71L190.9 359.9c-4.1 4.1-9.2 7-14.9 8.4l-60.1 15c-5.5 1.4-11.2-.2-15.2-4.2s-5.6-9.7-4.2-15.2l15-60.1c1.4-5.6 4.3-10.8 8.4-14.9z\"]\n};\nconst faPenSquare = faSquarePen;\nconst faPencilSquare = faSquarePen;\nconst faSuitcaseRolling = {\n prefix: 'fas',\n iconName: 'suitcase-rolling',\n icon: [384, 512, [], \"f5c1\", \"M144 56c0-4.4 3.6-8 8-8l80 0c4.4 0 8 3.6 8 8l0 72-96 0 0-72zm176 72l-32 0 0-72c0-30.9-25.1-56-56-56L152 0C121.1 0 96 25.1 96 56l0 72-32 0c-35.3 0-64 28.7-64 64L0 416c0 35.3 28.7 64 64 64c0 17.7 14.3 32 32 32s32-14.3 32-32l128 0c0 17.7 14.3 32 32 32s32-14.3 32-32c35.3 0 64-28.7 64-64l0-224c0-35.3-28.7-64-64-64zM112 224l160 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-160 0c-8.8 0-16-7.2-16-16s7.2-16 16-16zm0 128l160 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-160 0c-8.8 0-16-7.2-16-16s7.2-16 16-16z\"]\n};\nconst faPersonCircleExclamation = {\n prefix: 'fas',\n iconName: 'person-circle-exclamation',\n icon: [576, 512, [], \"e53f\", \"M112 48a48 48 0 1 1 96 0 48 48 0 1 1 -96 0zm40 304l0 128c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-223.1L59.4 304.5c-9.1 15.1-28.8 20-43.9 10.9s-20-28.8-10.9-43.9l58.3-97c17.4-28.9 48.6-46.6 82.3-46.6l29.7 0c33.7 0 64.9 17.7 82.3 46.6l44.9 74.7c-16.1 17.6-28.6 38.5-36.6 61.5c-1.9-1.8-3.5-3.9-4.9-6.3L232 256.9 232 480c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-128-16 0zM432 224a144 144 0 1 1 0 288 144 144 0 1 1 0-288zm0 240a24 24 0 1 0 0-48 24 24 0 1 0 0 48zm0-192c-8.8 0-16 7.2-16 16l0 80c0 8.8 7.2 16 16 16s16-7.2 16-16l0-80c0-8.8-7.2-16-16-16z\"]\n};\nconst faChevronDown = {\n prefix: 'fas',\n iconName: 'chevron-down',\n icon: [512, 512, [], \"f078\", \"M233.4 406.6c12.5 12.5 32.8 12.5 45.3 0l192-192c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0L256 338.7 86.6 169.4c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3l192 192z\"]\n};\nconst faBatteryFull = {\n prefix: 'fas',\n iconName: 'battery-full',\n icon: [576, 512, [128267, \"battery\", \"battery-5\"], \"f240\", \"M464 160c8.8 0 16 7.2 16 16l0 160c0 8.8-7.2 16-16 16L80 352c-8.8 0-16-7.2-16-16l0-160c0-8.8 7.2-16 16-16l384 0zM80 96C35.8 96 0 131.8 0 176L0 336c0 44.2 35.8 80 80 80l384 0c44.2 0 80-35.8 80-80l0-16c17.7 0 32-14.3 32-32l0-64c0-17.7-14.3-32-32-32l0-16c0-44.2-35.8-80-80-80L80 96zm368 96L96 192l0 128 352 0 0-128z\"]\n};\nconst faBattery = faBatteryFull;\nconst faBattery5 = faBatteryFull;\nconst faSkullCrossbones = {\n prefix: 'fas',\n iconName: 'skull-crossbones',\n icon: [448, 512, [128369, 9760], \"f714\", \"M368 128c0 44.4-25.4 83.5-64 106.4l0 21.6c0 17.7-14.3 32-32 32l-96 0c-17.7 0-32-14.3-32-32l0-21.6c-38.6-23-64-62.1-64-106.4C80 57.3 144.5 0 224 0s144 57.3 144 128zM168 176a32 32 0 1 0 0-64 32 32 0 1 0 0 64zm144-32a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zM3.4 273.7c7.9-15.8 27.1-22.2 42.9-14.3L224 348.2l177.7-88.8c15.8-7.9 35-1.5 42.9 14.3s1.5 35-14.3 42.9L295.6 384l134.8 67.4c15.8 7.9 22.2 27.1 14.3 42.9s-27.1 22.2-42.9 14.3L224 419.8 46.3 508.6c-15.8 7.9-35 1.5-42.9-14.3s-1.5-35 14.3-42.9L152.4 384 17.7 316.6C1.9 308.7-4.5 289.5 3.4 273.7z\"]\n};\nconst faCodeCompare = {\n prefix: 'fas',\n iconName: 'code-compare',\n icon: [512, 512, [], \"e13a\", \"M320 488c0 9.5-5.6 18.1-14.2 21.9s-18.8 2.3-25.8-4.1l-80-72c-5.1-4.6-7.9-11-7.9-17.8s2.9-13.3 7.9-17.8l80-72c7-6.3 17.2-7.9 25.8-4.1s14.2 12.4 14.2 21.9l0 40 16 0c35.3 0 64-28.7 64-64l0-166.7C371.7 141 352 112.8 352 80c0-44.2 35.8-80 80-80s80 35.8 80 80c0 32.8-19.7 61-48 73.3L464 320c0 70.7-57.3 128-128 128l-16 0 0 40zM456 80a24 24 0 1 0 -48 0 24 24 0 1 0 48 0zM192 24c0-9.5 5.6-18.1 14.2-21.9s18.8-2.3 25.8 4.1l80 72c5.1 4.6 7.9 11 7.9 17.8s-2.9 13.3-7.9 17.8l-80 72c-7 6.3-17.2 7.9-25.8 4.1s-14.2-12.4-14.2-21.9l0-40-16 0c-35.3 0-64 28.7-64 64l0 166.7c28.3 12.3 48 40.5 48 73.3c0 44.2-35.8 80-80 80s-80-35.8-80-80c0-32.8 19.7-61 48-73.3L48 192c0-70.7 57.3-128 128-128l16 0 0-40zM56 432a24 24 0 1 0 48 0 24 24 0 1 0 -48 0z\"]\n};\nconst faListUl = {\n prefix: 'fas',\n iconName: 'list-ul',\n icon: [512, 512, [\"list-dots\"], \"f0ca\", \"M64 144a48 48 0 1 0 0-96 48 48 0 1 0 0 96zM192 64c-17.7 0-32 14.3-32 32s14.3 32 32 32l288 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L192 64zm0 160c-17.7 0-32 14.3-32 32s14.3 32 32 32l288 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-288 0zm0 160c-17.7 0-32 14.3-32 32s14.3 32 32 32l288 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-288 0zM64 464a48 48 0 1 0 0-96 48 48 0 1 0 0 96zm48-208a48 48 0 1 0 -96 0 48 48 0 1 0 96 0z\"]\n};\nconst faListDots = faListUl;\nconst faSchoolLock = {\n prefix: 'fas',\n iconName: 'school-lock',\n icon: [640, 512, [], \"e56f\", \"M302.2 5.4c10.7-7.2 24.8-7.2 35.5 0L473.7 96 592 96c26.5 0 48 21.5 48 48l0 128c0-61.9-50.1-112-112-112s-112 50.1-112 112l0 24.6c-19.1 11.1-32 31.7-32 55.4l-63.7 0-.3 0c-35.3 0-64 28.7-64 64l0 96 64 0s0 0 0 0L48 512c-26.5 0-48-21.5-48-48L0 144c0-26.5 21.5-48 48-48l118.3 0L302.2 5.4zM80 208l0 64c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-64c0-8.8-7.2-16-16-16l-32 0c-8.8 0-16 7.2-16 16zm0 128l0 64c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-64c0-8.8-7.2-16-16-16l-32 0c-8.8 0-16 7.2-16 16zm240-72a88 88 0 1 0 0-176 88 88 0 1 0 0 176zm16-120l0 16 16 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16s16 7.2 16 16zm192 96c-17.7 0-32 14.3-32 32l0 48 64 0 0-48c0-17.7-14.3-32-32-32zm-80 32c0-44.2 35.8-80 80-80s80 35.8 80 80l0 48c17.7 0 32 14.3 32 32l0 128c0 17.7-14.3 32-32 32l-160 0c-17.7 0-32-14.3-32-32l0-128c0-17.7 14.3-32 32-32l0-48z\"]\n};\nconst faTowerCell = {\n prefix: 'fas',\n iconName: 'tower-cell',\n icon: [576, 512, [], \"e585\", \"M62.6 2.3C46.2-4.3 27.6 3.6 20.9 20C7.4 53.4 0 89.9 0 128s7.4 74.6 20.9 108c6.6 16.4 25.3 24.3 41.7 17.7S86.9 228.4 80.3 212C69.8 186.1 64 157.8 64 128s5.8-58.1 16.3-84C86.9 27.6 79 9 62.6 2.3zm450.8 0C497 9 489.1 27.6 495.7 44C506.2 69.9 512 98.2 512 128s-5.8 58.1-16.3 84c-6.6 16.4 1.3 35 17.7 41.7s35-1.3 41.7-17.7c13.5-33.4 20.9-69.9 20.9-108s-7.4-74.6-20.9-108C548.4 3.6 529.8-4.3 513.4 2.3zM340.1 165.2c7.5-10.5 11.9-23.3 11.9-37.2c0-35.3-28.7-64-64-64s-64 28.7-64 64c0 13.9 4.4 26.7 11.9 37.2L98.9 466.8c-7.3 16.1-.2 35.1 15.9 42.4s35.1 .2 42.4-15.9L177.7 448l220.6 0 20.6 45.2c7.3 16.1 26.3 23.2 42.4 15.9s23.2-26.3 15.9-42.4L340.1 165.2zM369.2 384l-162.4 0 14.5-32 133.3 0 14.5 32zM288 205.3L325.6 288l-75.2 0L288 205.3zM163.3 73.6c5.3-12.1-.2-26.3-12.4-31.6s-26.3 .2-31.6 12.4C109.5 77 104 101.9 104 128s5.5 51 15.3 73.6c5.3 12.1 19.5 17.7 31.6 12.4s17.7-19.5 12.4-31.6C156 165.8 152 147.4 152 128s4-37.8 11.3-54.4zM456.7 54.4c-5.3-12.1-19.5-17.7-31.6-12.4s-17.7 19.5-12.4 31.6C420 90.2 424 108.6 424 128s-4 37.8-11.3 54.4c-5.3 12.1 .2 26.3 12.4 31.6s26.3-.2 31.6-12.4C466.5 179 472 154.1 472 128s-5.5-51-15.3-73.6z\"]\n};\nconst faDownLong = {\n prefix: 'fas',\n iconName: 'down-long',\n icon: [320, 512, [\"long-arrow-alt-down\"], \"f309\", \"M2 334.5c-3.8 8.8-2 19 4.6 26l136 144c4.5 4.8 10.8 7.5 17.4 7.5s12.9-2.7 17.4-7.5l136-144c6.6-7 8.4-17.2 4.6-26s-12.5-14.5-22-14.5l-72 0 0-288c0-17.7-14.3-32-32-32L128 0C110.3 0 96 14.3 96 32l0 288-72 0c-9.6 0-18.2 5.7-22 14.5z\"]\n};\nconst faLongArrowAltDown = faDownLong;\nconst faRankingStar = {\n prefix: 'fas',\n iconName: 'ranking-star',\n icon: [640, 512, [], \"e561\", \"M353.8 54.1L330.2 6.3c-3.9-8.3-16.1-8.6-20.4 0L286.2 54.1l-52.3 7.5c-9.3 1.4-13.3 12.9-6.4 19.8l38 37-9 52.1c-1.4 9.3 8.2 16.5 16.8 12.2l46.9-24.8 46.6 24.4c8.6 4.3 18.3-2.9 16.8-12.2l-9-52.1 38-36.6c6.8-6.8 2.9-18.3-6.4-19.8l-52.3-7.5zM256 256c-17.7 0-32 14.3-32 32l0 192c0 17.7 14.3 32 32 32l128 0c17.7 0 32-14.3 32-32l0-192c0-17.7-14.3-32-32-32l-128 0zM32 320c-17.7 0-32 14.3-32 32L0 480c0 17.7 14.3 32 32 32l128 0c17.7 0 32-14.3 32-32l0-128c0-17.7-14.3-32-32-32L32 320zm416 96l0 64c0 17.7 14.3 32 32 32l128 0c17.7 0 32-14.3 32-32l0-64c0-17.7-14.3-32-32-32l-128 0c-17.7 0-32 14.3-32 32z\"]\n};\nconst faChessKing = {\n prefix: 'fas',\n iconName: 'chess-king',\n icon: [448, 512, [9818], \"f43f\", \"M224 0c17.7 0 32 14.3 32 32l0 16 16 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-16 0 0 48 152 0c22.1 0 40 17.9 40 40c0 5.3-1 10.5-3.1 15.4L368 400 80 400 3.1 215.4C1 210.5 0 205.3 0 200c0-22.1 17.9-40 40-40l152 0 0-48-16 0c-17.7 0-32-14.3-32-32s14.3-32 32-32l16 0 0-16c0-17.7 14.3-32 32-32zM38.6 473.4L80 432l288 0 41.4 41.4c4.2 4.2 6.6 10 6.6 16c0 12.5-10.1 22.6-22.6 22.6L54.6 512C42.1 512 32 501.9 32 489.4c0-6 2.4-11.8 6.6-16z\"]\n};\nconst faPersonHarassing = {\n prefix: 'fas',\n iconName: 'person-harassing',\n icon: [576, 512, [], \"e549\", \"M192 96a48 48 0 1 0 0-96 48 48 0 1 0 0 96zM59.4 304.5L88 256.9 88 480c0 17.7 14.3 32 32 32s32-14.3 32-32l0-128 16 0 0 128c0 17.7 14.3 32 32 32s32-14.3 32-32l0-244.7 47.4 57.1c11.3 13.6 31.5 15.5 45.1 4.2s15.5-31.5 4.2-45.1l-73.7-88.9c-18.2-22-45.3-34.7-73.9-34.7l-35.9 0c-33.7 0-64.9 17.7-82.3 46.6l-58.3 97c-9.1 15.1-4.2 34.8 10.9 43.9s34.8 4.2 43.9-10.9zM480 240a48 48 0 1 0 -96 0 48 48 0 1 0 96 0zM464 344l0 58.7-41.4-41.4c-7.3-7.3-17.6-10.6-27.8-9s-18.9 8.1-23.5 17.3l-48 96c-7.9 15.8-1.5 35 14.3 42.9s35 1.5 42.9-14.3L408.8 438l54.7 54.7c12.4 12.4 29.1 19.3 46.6 19.3c36.4 0 65.9-29.5 65.9-65.9L576 344c0-30.9-25.1-56-56-56s-56 25.1-56 56zM288 48c0 8.8 7.2 16 16 16l56 0c8.8 0 16-7.2 16-16s-7.2-16-16-16l-56 0c-8.8 0-16 7.2-16 16zm-.8 49.7c-7.9-4-17.5-.7-21.5 7.2s-.7 17.5 7.2 21.5l48 24c7.9 4 17.5 .7 21.5-7.2s.7-17.5-7.2-21.5l-48-24z\"]\n};\nconst faBrazilianRealSign = {\n prefix: 'fas',\n iconName: 'brazilian-real-sign',\n icon: [512, 512, [], \"e46c\", \"M400 0c17.7 0 32 14.3 32 32l0 18.2c12.5 2.3 24.7 6.4 36.2 12.1l10.1 5.1c15.8 7.9 22.2 27.1 14.3 42.9s-27.1 22.2-42.9 14.3l-10.2-5.1c-9.9-5-20.9-7.5-32-7.5l-1.7 0c-29.8 0-53.9 24.1-53.9 53.9c0 22 13.4 41.8 33.9 50l52 20.8c44.7 17.9 74.1 61.2 74.1 109.4l0 3.4c0 51.2-33.6 94.6-80 109.2l0 21.3c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-19.4c-15-3.5-29.4-9.7-42.3-18.3l-23.4-15.6c-14.7-9.8-18.7-29.7-8.9-44.4s29.7-18.7 44.4-8.9L361.2 389c10.8 7.2 23.4 11 36.3 11c27.9 0 50.5-22.6 50.5-50.5l0-3.4c0-22-13.4-41.8-33.9-50l-52-20.8C317.3 257.4 288 214.1 288 165.9C288 114 321.5 70 368 54.2L368 32c0-17.7 14.3-32 32-32zM0 64C0 46.3 14.3 32 32 32l80 0c79.5 0 144 64.5 144 144c0 58.8-35.2 109.3-85.7 131.7l51.4 128.4c6.6 16.4-1.4 35-17.8 41.6s-35-1.4-41.6-17.8L106.3 320 64 320l0 128c0 17.7-14.3 32-32 32s-32-14.3-32-32L0 288 0 64zM64 256l48 0c44.2 0 80-35.8 80-80s-35.8-80-80-80L64 96l0 160z\"]\n};\nconst faLandmarkDome = {\n prefix: 'fas',\n iconName: 'landmark-dome',\n icon: [512, 512, [\"landmark-alt\"], \"f752\", \"M248 0l16 0c13.3 0 24 10.7 24 24l0 10.7C368.4 48.1 431.9 111.6 445.3 192l2.7 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L64 256c-17.7 0-32-14.3-32-32s14.3-32 32-32l2.7 0C80.1 111.6 143.6 48.1 224 34.7L224 24c0-13.3 10.7-24 24-24zM64 288l64 0 0 128 40 0 0-128 64 0 0 128 48 0 0-128 64 0 0 128 40 0 0-128 64 0 0 132.3c.6 .3 1.2 .7 1.8 1.1l48 32c11.7 7.8 17 22.4 12.9 35.9S494.1 512 480 512L32 512c-14.1 0-26.5-9.2-30.6-22.7s1.1-28.1 12.9-35.9l48-32c.6-.4 1.2-.7 1.8-1.1L64 288z\"]\n};\nconst faLandmarkAlt = faLandmarkDome;\nconst faArrowUp = {\n prefix: 'fas',\n iconName: 'arrow-up',\n icon: [384, 512, [8593], \"f062\", \"M214.6 41.4c-12.5-12.5-32.8-12.5-45.3 0l-160 160c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0L160 141.2 160 448c0 17.7 14.3 32 32 32s32-14.3 32-32l0-306.7L329.4 246.6c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3l-160-160z\"]\n};\nconst faTv = {\n prefix: 'fas',\n iconName: 'tv',\n icon: [640, 512, [63717, \"television\", \"tv-alt\"], \"f26c\", \"M64 64l0 288 512 0 0-288L64 64zM0 64C0 28.7 28.7 0 64 0L576 0c35.3 0 64 28.7 64 64l0 288c0 35.3-28.7 64-64 64L64 416c-35.3 0-64-28.7-64-64L0 64zM128 448l384 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-384 0c-17.7 0-32-14.3-32-32s14.3-32 32-32z\"]\n};\nconst faTelevision = faTv;\nconst faTvAlt = faTv;\nconst faShrimp = {\n prefix: 'fas',\n iconName: 'shrimp',\n icon: [512, 512, [129424], \"e448\", \"M64 32C28.7 32 0 60.7 0 96s28.7 64 64 64l1 0c3.7 88.9 77 160 167 160l56 0 0-192-24 0L88.8 128 64 128c-17.7 0-32-14.3-32-32s14.3-32 32-32l400 0c8.8 0 16-7.2 16-16s-7.2-16-16-16L64 32zM224 456c0 13.3 10.7 24 24 24l72 0 0-72.2-64.1-22.4c-12.5-4.4-26.2 2.2-30.6 14.7s2.2 26.2 14.7 30.6l4.5 1.6C233 433.9 224 443.9 224 456zm128 23.3c36.4-3.3 69.5-17.6 96.1-39.6l-86.5-34.6c-3 1.8-6.2 3.2-9.6 4.3l0 69.9zM472.6 415c24.6-30.3 39.4-68.9 39.4-111c0-12.3-1.3-24.3-3.7-35.9L382.8 355.1c.8 3.4 1.2 7 1.2 10.6c0 4.6-.7 9-1.9 13.1L472.6 415zM336 128l-16 0 0 192 18.3 0c9.9 0 19.1 3.2 26.6 8.5l133.5-92.4C471.8 172.6 409.1 128 336 128zM168 192a24 24 0 1 1 48 0 24 24 0 1 1 -48 0z\"]\n};\nconst faListCheck = {\n prefix: 'fas',\n iconName: 'list-check',\n icon: [512, 512, [\"tasks\"], \"f0ae\", \"M152.1 38.2c9.9 8.9 10.7 24 1.8 33.9l-72 80c-4.4 4.9-10.6 7.8-17.2 7.9s-12.9-2.4-17.6-7L7 113C-2.3 103.6-2.3 88.4 7 79s24.6-9.4 33.9 0l22.1 22.1 55.1-61.2c8.9-9.9 24-10.7 33.9-1.8zm0 160c9.9 8.9 10.7 24 1.8 33.9l-72 80c-4.4 4.9-10.6 7.8-17.2 7.9s-12.9-2.4-17.6-7L7 273c-9.4-9.4-9.4-24.6 0-33.9s24.6-9.4 33.9 0l22.1 22.1 55.1-61.2c8.9-9.9 24-10.7 33.9-1.8zM224 96c0-17.7 14.3-32 32-32l224 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-224 0c-17.7 0-32-14.3-32-32zm0 160c0-17.7 14.3-32 32-32l224 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-224 0c-17.7 0-32-14.3-32-32zM160 416c0-17.7 14.3-32 32-32l288 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-288 0c-17.7 0-32-14.3-32-32zM48 368a48 48 0 1 1 0 96 48 48 0 1 1 0-96z\"]\n};\nconst faTasks = faListCheck;\nconst faJugDetergent = {\n prefix: 'fas',\n iconName: 'jug-detergent',\n icon: [384, 512, [], \"e519\", \"M96 24c0-13.3 10.7-24 24-24l80 0c13.3 0 24 10.7 24 24l0 24 8 0c13.3 0 24 10.7 24 24s-10.7 24-24 24L88 96C74.7 96 64 85.3 64 72s10.7-24 24-24l8 0 0-24zM0 256c0-70.7 57.3-128 128-128l128 0c70.7 0 128 57.3 128 128l0 192c0 35.3-28.7 64-64 64L64 512c-35.3 0-64-28.7-64-64L0 256zm256 0l0 96c0 17.7 14.3 32 32 32s32-14.3 32-32l0-96c0-17.7-14.3-32-32-32s-32 14.3-32 32z\"]\n};\nconst faCircleUser = {\n prefix: 'fas',\n iconName: 'circle-user',\n icon: [512, 512, [62142, \"user-circle\"], \"f2bd\", \"M399 384.2C376.9 345.8 335.4 320 288 320l-64 0c-47.4 0-88.9 25.8-111 64.2c35.2 39.2 86.2 63.8 143 63.8s107.8-24.7 143-63.8zM0 256a256 256 0 1 1 512 0A256 256 0 1 1 0 256zm256 16a72 72 0 1 0 0-144 72 72 0 1 0 0 144z\"]\n};\nconst faUserCircle = faCircleUser;\nconst faUserShield = {\n prefix: 'fas',\n iconName: 'user-shield',\n icon: [640, 512, [], \"f505\", \"M224 256A128 128 0 1 0 224 0a128 128 0 1 0 0 256zm-45.7 48C79.8 304 0 383.8 0 482.3C0 498.7 13.3 512 29.7 512l388.6 0c1.8 0 3.5-.2 5.3-.5c-76.3-55.1-99.8-141-103.1-200.2c-16.1-4.8-33.1-7.3-50.7-7.3l-91.4 0zm308.8-78.3l-120 48C358 277.4 352 286.2 352 296c0 63.3 25.9 168.8 134.8 214.2c5.9 2.5 12.6 2.5 18.5 0C614.1 464.8 640 359.3 640 296c0-9.8-6-18.6-15.1-22.3l-120-48c-5.7-2.3-12.1-2.3-17.8 0zM591.4 312c-3.9 50.7-27.2 116.7-95.4 149.7l0-187.8L591.4 312z\"]\n};\nconst faWind = {\n prefix: 'fas',\n iconName: 'wind',\n icon: [512, 512, [], \"f72e\", \"M288 32c0 17.7 14.3 32 32 32l32 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L32 128c-17.7 0-32 14.3-32 32s14.3 32 32 32l320 0c53 0 96-43 96-96s-43-96-96-96L320 0c-17.7 0-32 14.3-32 32zm64 352c0 17.7 14.3 32 32 32l32 0c53 0 96-43 96-96s-43-96-96-96L32 224c-17.7 0-32 14.3-32 32s14.3 32 32 32l384 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-32 0c-17.7 0-32 14.3-32 32zM128 512l32 0c53 0 96-43 96-96s-43-96-96-96L32 320c-17.7 0-32 14.3-32 32s14.3 32 32 32l128 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-32 0c-17.7 0-32 14.3-32 32s14.3 32 32 32z\"]\n};\nconst faCarBurst = {\n prefix: 'fas',\n iconName: 'car-burst',\n icon: [640, 512, [\"car-crash\"], \"f5e1\", \"M176 8c-6.6 0-12.4 4-14.9 10.1l-29.4 74L55.6 68.9c-6.3-1.9-13.1 .2-17.2 5.3s-4.6 12.2-1.4 17.9l39.5 69.1L10.9 206.4c-5.4 3.7-8 10.3-6.5 16.7s6.7 11.2 13.1 12.2l78.7 12.2L90.6 327c-.5 6.5 3.1 12.7 9 15.5s12.9 1.8 17.8-2.6l35.3-32.5 9.5-35.4 10.4-38.6c8-29.9 30.5-52.1 57.9-60.9l41-59.2c11.3-16.3 26.4-28.9 43.5-37.2c-.4-.6-.8-1.2-1.3-1.8c-4.1-5.1-10.9-7.2-17.2-5.3L220.3 92.1l-29.4-74C188.4 12 182.6 8 176 8zM367.7 161.5l135.6 36.3c6.5 1.8 11.3 7.4 11.8 14.2l4.6 56.5-201.5-54 32.2-46.6c3.8-5.6 10.8-8.1 17.3-6.4zm-69.9-30l-47.9 69.3c-21.6 3-40.3 18.6-46.3 41l-10.4 38.6-16.6 61.8-8.3 30.9c-4.6 17.1 5.6 34.6 22.6 39.2l15.5 4.1c17.1 4.6 34.6-5.6 39.2-22.6l8.3-30.9 247.3 66.3-8.3 30.9c-4.6 17.1 5.6 34.6 22.6 39.2l15.5 4.1c17.1 4.6 34.6-5.6 39.2-22.6l8.3-30.9L595 388l10.4-38.6c6-22.4-2.5-45.2-19.6-58.7l-6.8-84c-2.7-33.7-26.4-62-59-70.8L384.2 99.7c-32.7-8.8-67.3 4-86.5 31.8zm-17 131a24 24 0 1 1 -12.4 46.4 24 24 0 1 1 12.4-46.4zm217.9 83.2A24 24 0 1 1 545 358.1a24 24 0 1 1 -46.4-12.4z\"]\n};\nconst faCarCrash = faCarBurst;\nconst faY = {\n prefix: 'fas',\n iconName: 'y',\n icon: [384, 512, [121], \"59\", \"M58 45.4C47.8 31 27.8 27.7 13.4 38S-4.3 68.2 6 82.6L160 298.3 160 448c0 17.7 14.3 32 32 32s32-14.3 32-32l0-149.7L378 82.6c10.3-14.4 6.9-34.4-7.4-44.6S336.2 31 326 45.4L192 232.9 58 45.4z\"]\n};\nconst faPersonSnowboarding = {\n prefix: 'fas',\n iconName: 'person-snowboarding',\n icon: [512, 512, [127938, \"snowboarding\"], \"f7ce\", \"M209.7 3.4c15.8-7.9 35-1.5 42.9 14.3l25 50 42.4 8.5c19.5 3.9 37.8 12.3 53.5 24.5l126.1 98.1c14 10.9 16.5 31 5.6 44.9s-31 16.5-44.9 5.6l-72.1-56.1-71.5 31.8 33.1 27.6c23.2 19.3 33.5 50 26.7 79.4l-17.4 75.2c-2.2 9.4-8.2 16.8-16.1 21l86.5 33.1c4.6 1.8 9.4 2.6 14.3 2.6l28.2 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-28.2 0c-10.8 0-21.4-2-31.5-5.8L60.1 371.3c-11.5-4.4-22-11.2-30.8-20L7 329c-9.4-9.4-9.4-24.6 0-33.9s24.6-9.4 33.9 0l22.4 22.4c4 4 8.7 7.1 14 9.1l22.4 8.6c-.8-1.6-1.5-3.2-2.1-4.9c-5.6-16.8 3.5-34.9 20.2-40.5L192 264.9l0-53.2c0-24.2 13.7-46.4 35.4-57.2l45.2-22.6-7.5-1.5c-19.4-3.9-35.9-16.5-44.7-34.1l-25-50c-7.9-15.8-1.5-35 14.3-42.9zM139 350.1l159 60.9c-2.1-5.6-2.6-11.9-1.1-18.2l17.4-75.2c1.4-5.9-.7-12-5.3-15.9l-52.8-44 0 18.8c0 20.7-13.2 39-32.8 45.5L139 350.1zM432 0a48 48 0 1 1 0 96 48 48 0 1 1 0-96z\"]\n};\nconst faSnowboarding = faPersonSnowboarding;\nconst faTruckFast = {\n prefix: 'fas',\n iconName: 'truck-fast',\n icon: [640, 512, [\"shipping-fast\"], \"f48b\", \"M112 0C85.5 0 64 21.5 64 48l0 48L16 96c-8.8 0-16 7.2-16 16s7.2 16 16 16l48 0 208 0c8.8 0 16 7.2 16 16s-7.2 16-16 16L64 160l-16 0c-8.8 0-16 7.2-16 16s7.2 16 16 16l16 0 176 0c8.8 0 16 7.2 16 16s-7.2 16-16 16L64 224l-48 0c-8.8 0-16 7.2-16 16s7.2 16 16 16l48 0 144 0c8.8 0 16 7.2 16 16s-7.2 16-16 16L64 288l0 128c0 53 43 96 96 96s96-43 96-96l128 0c0 53 43 96 96 96s96-43 96-96l32 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l0-64 0-32 0-18.7c0-17-6.7-33.3-18.7-45.3L512 114.7c-12-12-28.3-18.7-45.3-18.7L416 96l0-48c0-26.5-21.5-48-48-48L112 0zM544 237.3l0 18.7-128 0 0-96 50.7 0L544 237.3zM160 368a48 48 0 1 1 0 96 48 48 0 1 1 0-96zm272 48a48 48 0 1 1 96 0 48 48 0 1 1 -96 0z\"]\n};\nconst faShippingFast = faTruckFast;\nconst faFish = {\n prefix: 'fas',\n iconName: 'fish',\n icon: [576, 512, [128031], \"f578\", \"M180.5 141.5C219.7 108.5 272.6 80 336 80s116.3 28.5 155.5 61.5c39.1 33 66.9 72.4 81 99.8c4.7 9.2 4.7 20.1 0 29.3c-14.1 27.4-41.9 66.8-81 99.8C452.3 403.5 399.4 432 336 432s-116.3-28.5-155.5-61.5c-16.2-13.7-30.5-28.5-42.7-43.1L48.1 379.6c-12.5 7.3-28.4 5.3-38.7-4.9S-3 348.7 4.2 336.1L50 256 4.2 175.9c-7.2-12.6-5-28.4 5.3-38.6s26.1-12.2 38.7-4.9l89.7 52.3c12.2-14.6 26.5-29.4 42.7-43.1zM448 256a32 32 0 1 0 -64 0 32 32 0 1 0 64 0z\"]\n};\nconst faUserGraduate = {\n prefix: 'fas',\n iconName: 'user-graduate',\n icon: [448, 512, [], \"f501\", \"M219.3 .5c3.1-.6 6.3-.6 9.4 0l200 40C439.9 42.7 448 52.6 448 64s-8.1 21.3-19.3 23.5L352 102.9l0 57.1c0 70.7-57.3 128-128 128s-128-57.3-128-128l0-57.1L48 93.3l0 65.1 15.7 78.4c.9 4.7-.3 9.6-3.3 13.3s-7.6 5.9-12.4 5.9l-32 0c-4.8 0-9.3-2.1-12.4-5.9s-4.3-8.6-3.3-13.3L16 158.4l0-71.8C6.5 83.3 0 74.3 0 64C0 52.6 8.1 42.7 19.3 40.5l200-40zM111.9 327.7c10.5-3.4 21.8 .4 29.4 8.5l71 75.5c6.3 6.7 17 6.7 23.3 0l71-75.5c7.6-8.1 18.9-11.9 29.4-8.5C401 348.6 448 409.4 448 481.3c0 17-13.8 30.7-30.7 30.7L30.7 512C13.8 512 0 498.2 0 481.3c0-71.9 47-132.7 111.9-153.6z\"]\n};\nconst faCircleHalfStroke = {\n prefix: 'fas',\n iconName: 'circle-half-stroke',\n icon: [512, 512, [9680, \"adjust\"], \"f042\", \"M448 256c0-106-86-192-192-192l0 384c106 0 192-86 192-192zM0 256a256 256 0 1 1 512 0A256 256 0 1 1 0 256z\"]\n};\nconst faAdjust = faCircleHalfStroke;\nconst faClapperboard = {\n prefix: 'fas',\n iconName: 'clapperboard',\n icon: [512, 512, [], \"e131\", \"M448 32l-86.1 0-1 1-127 127 92.1 0 1-1L453.8 32.3c-1.9-.2-3.8-.3-5.8-.3zm64 128l0-64c0-15.1-5.3-29.1-14-40l-104 104L512 160zM294.1 32l-92.1 0-1 1L73.9 160l92.1 0 1-1 127-127zM64 32C28.7 32 0 60.7 0 96l0 64 6.1 0 1-1 127-127L64 32zM512 192L0 192 0 416c0 35.3 28.7 64 64 64l384 0c35.3 0 64-28.7 64-64l0-224z\"]\n};\nconst faCircleRadiation = {\n prefix: 'fas',\n iconName: 'circle-radiation',\n icon: [512, 512, [9762, \"radiation-alt\"], \"f7ba\", \"M256 64a192 192 0 1 1 0 384 192 192 0 1 1 0-384zm0 448A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM200 256c0-20.7 11.3-38.8 28-48.5l-36-62.3c-8.8-15.3-28.7-20.8-42-9c-25.6 22.6-43.9 53.3-50.9 88.1C95.7 241.5 110.3 256 128 256l72 0zm28 48.5l-36 62.4c-8.8 15.3-3.6 35.2 13.1 40.8c16 5.4 33.1 8.3 50.9 8.3s34.9-2.9 50.9-8.3c16.7-5.6 21.9-25.5 13.1-40.8l-36-62.4c-8.2 4.8-17.8 7.5-28 7.5s-19.8-2.7-28-7.5zM312 256l72 0c17.7 0 32.3-14.5 28.8-31.8c-7-34.8-25.3-65.5-50.9-88.1c-13.2-11.7-33.1-6.3-42 9l-36 62.3c16.7 9.7 28 27.8 28 48.5zm-56 32a32 32 0 1 0 0-64 32 32 0 1 0 0 64z\"]\n};\nconst faRadiationAlt = faCircleRadiation;\nconst faBaseball = {\n prefix: 'fas',\n iconName: 'baseball',\n icon: [512, 512, [129358, 9918, \"baseball-ball\"], \"f433\", \"M62.7 223.4c-4.8 .4-9.7 .6-14.7 .6c-15.6 0-30.8-2-45.2-5.9C19.2 107.1 107.1 19.2 218.1 2.8C222 17.2 224 32.4 224 48c0 4.9-.2 9.8-.6 14.7c-.7 8.8 5.8 16.5 14.6 17.3s16.5-5.8 17.3-14.6c.5-5.7 .7-11.5 .7-17.3c0-16.5-1.9-32.6-5.6-47.9c1.8 0 3.7-.1 5.6-.1C397.4 0 512 114.6 512 256c0 1.9 0 3.7-.1 5.6c-15.4-3.6-31.4-5.6-47.9-5.6c-5.8 0-11.6 .2-17.3 .7c-8.8 .7-15.4 8.5-14.6 17.3s8.5 15.4 17.3 14.6c4.8-.4 9.7-.6 14.7-.6c15.6 0 30.8 2 45.2 5.9C492.8 404.9 404.9 492.8 293.9 509.2C290 494.8 288 479.6 288 464c0-4.9 .2-9.8 .6-14.7c.7-8.8-5.8-16.5-14.6-17.3s-16.5 5.8-17.3 14.6c-.5 5.7-.7 11.5-.7 17.3c0 16.5 1.9 32.6 5.6 47.9c-1.8 0-3.7 .1-5.6 .1C114.6 512 0 397.4 0 256c0-1.9 0-3.7 .1-5.6C15.4 254.1 31.5 256 48 256c5.8 0 11.6-.2 17.3-.7c8.8-.7 15.4-8.5 14.6-17.3s-8.5-15.4-17.3-14.6zM121.3 208c-8 3.7-11.6 13.2-7.9 21.2s13.2 11.6 21.2 7.9c45.2-20.8 81.7-57.2 102.5-102.5c3.7-8 .2-17.5-7.9-21.2s-17.5-.2-21.2 7.9c-17.6 38.3-48.5 69.2-86.7 86.7zm277.2 74.7c-3.7-8-13.2-11.6-21.2-7.9c-45.2 20.8-81.7 57.2-102.5 102.5c-3.7 8-.2 17.5 7.9 21.2s17.5 .2 21.2-7.9c17.6-38.3 48.5-69.2 86.7-86.7c8-3.7 11.6-13.2 7.9-21.2z\"]\n};\nconst faBaseballBall = faBaseball;\nconst faJetFighterUp = {\n prefix: 'fas',\n iconName: 'jet-fighter-up',\n icon: [512, 512, [], \"e518\", \"M270.7 9.7C268.2 3.8 262.4 0 256 0s-12.2 3.8-14.7 9.7L197.2 112.6c-3.4 8-5.2 16.5-5.2 25.2l0 77-144 84L48 280c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 56 0 32 0 24c0 13.3 10.7 24 24 24s24-10.7 24-24l0-8 144 0 0 32.7L133.5 468c-3.5 3-5.5 7.4-5.5 12l0 16c0 8.8 7.2 16 16 16l96 0 0-64c0-8.8 7.2-16 16-16s16 7.2 16 16l0 64 96 0c8.8 0 16-7.2 16-16l0-16c0-4.6-2-9-5.5-12L320 416.7l0-32.7 144 0 0 8c0 13.3 10.7 24 24 24s24-10.7 24-24l0-24 0-32 0-56c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 18.8-144-84 0-77c0-8.7-1.8-17.2-5.2-25.2L270.7 9.7z\"]\n};\nconst faDiagramProject = {\n prefix: 'fas',\n iconName: 'diagram-project',\n icon: [576, 512, [\"project-diagram\"], \"f542\", \"M0 80C0 53.5 21.5 32 48 32l96 0c26.5 0 48 21.5 48 48l0 16 192 0 0-16c0-26.5 21.5-48 48-48l96 0c26.5 0 48 21.5 48 48l0 96c0 26.5-21.5 48-48 48l-96 0c-26.5 0-48-21.5-48-48l0-16-192 0 0 16c0 1.7-.1 3.4-.3 5L272 288l96 0c26.5 0 48 21.5 48 48l0 96c0 26.5-21.5 48-48 48l-96 0c-26.5 0-48-21.5-48-48l0-96c0-1.7 .1-3.4 .3-5L144 224l-96 0c-26.5 0-48-21.5-48-48L0 80z\"]\n};\nconst faProjectDiagram = faDiagramProject;\nconst faCopy = {\n prefix: 'fas',\n iconName: 'copy',\n icon: [448, 512, [], \"f0c5\", \"M208 0L332.1 0c12.7 0 24.9 5.1 33.9 14.1l67.9 67.9c9 9 14.1 21.2 14.1 33.9L448 336c0 26.5-21.5 48-48 48l-192 0c-26.5 0-48-21.5-48-48l0-288c0-26.5 21.5-48 48-48zM48 128l80 0 0 64-64 0 0 256 192 0 0-32 64 0 0 48c0 26.5-21.5 48-48 48L48 512c-26.5 0-48-21.5-48-48L0 176c0-26.5 21.5-48 48-48z\"]\n};\nconst faVolumeXmark = {\n prefix: 'fas',\n iconName: 'volume-xmark',\n icon: [576, 512, [\"volume-mute\", \"volume-times\"], \"f6a9\", \"M301.1 34.8C312.6 40 320 51.4 320 64l0 384c0 12.6-7.4 24-18.9 29.2s-25 3.1-34.4-5.3L131.8 352 64 352c-35.3 0-64-28.7-64-64l0-64c0-35.3 28.7-64 64-64l67.8 0L266.7 40.1c9.4-8.4 22.9-10.4 34.4-5.3zM425 167l55 55 55-55c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9l-55 55 55 55c9.4 9.4 9.4 24.6 0 33.9s-24.6 9.4-33.9 0l-55-55-55 55c-9.4 9.4-24.6 9.4-33.9 0s-9.4-24.6 0-33.9l55-55-55-55c-9.4-9.4-9.4-24.6 0-33.9s24.6-9.4 33.9 0z\"]\n};\nconst faVolumeMute = faVolumeXmark;\nconst faVolumeTimes = faVolumeXmark;\nconst faHandSparkles = {\n prefix: 'fas',\n iconName: 'hand-sparkles',\n icon: [640, 512, [], \"e05d\", \"M320 0c17.7 0 32 14.3 32 32l0 208c0 8.8 7.2 16 16 16s16-7.2 16-16l0-176c0-17.7 14.3-32 32-32s32 14.3 32 32l0 176c0 8.8 7.2 16 16 16s16-7.2 16-16l0-112c0-17.7 14.3-32 32-32s32 14.3 32 32l0 195.1c-11.9 4.8-21.3 14.9-25 27.8l-8.9 31.2L478.9 391C460.6 396.3 448 413 448 432c0 18.9 12.5 35.6 30.6 40.9C448.4 497.4 409.9 512 368 512l-19.2 0c-59.6 0-116.9-22.9-160-64L76.4 341c-16-15.2-16.6-40.6-1.4-56.6s40.6-16.6 56.6-1.4l60.5 57.6c0-1.5-.1-3.1-.1-4.6l0-272c0-17.7 14.3-32 32-32s32 14.3 32 32l0 176c0 8.8 7.2 16 16 16s16-7.2 16-16l0-208c0-17.7 14.3-32 32-32zm-7.3 326.6c-1.1-3.9-4.7-6.6-8.7-6.6s-7.6 2.7-8.7 6.6L288 352l-25.4 7.3c-3.9 1.1-6.6 4.7-6.6 8.7s2.7 7.6 6.6 8.7L288 384l7.3 25.4c1.1 3.9 4.7 6.6 8.7 6.6s7.6-2.7 8.7-6.6L320 384l25.4-7.3c3.9-1.1 6.6-4.7 6.6-8.7s-2.7-7.6-6.6-8.7L320 352l-7.3-25.4zM104 120l48.3 13.8c4.6 1.3 7.7 5.5 7.7 10.2s-3.1 8.9-7.7 10.2L104 168 90.2 216.3c-1.3 4.6-5.5 7.7-10.2 7.7s-8.9-3.1-10.2-7.7L56 168 7.7 154.2C3.1 152.9 0 148.7 0 144s3.1-8.9 7.7-10.2L56 120 69.8 71.7C71.1 67.1 75.3 64 80 64s8.9 3.1 10.2 7.7L104 120zM584 408l48.3 13.8c4.6 1.3 7.7 5.5 7.7 10.2s-3.1 8.9-7.7 10.2L584 456l-13.8 48.3c-1.3 4.6-5.5 7.7-10.2 7.7s-8.9-3.1-10.2-7.7L536 456l-48.3-13.8c-4.6-1.3-7.7-5.5-7.7-10.2s3.1-8.9 7.7-10.2L536 408l13.8-48.3c1.3-4.6 5.5-7.7 10.2-7.7s8.9 3.1 10.2 7.7L584 408z\"]\n};\nconst faGrip = {\n prefix: 'fas',\n iconName: 'grip',\n icon: [448, 512, [\"grip-horizontal\"], \"f58d\", \"M128 136c0-22.1-17.9-40-40-40L40 96C17.9 96 0 113.9 0 136l0 48c0 22.1 17.9 40 40 40l48 0c22.1 0 40-17.9 40-40l0-48zm0 192c0-22.1-17.9-40-40-40l-48 0c-22.1 0-40 17.9-40 40l0 48c0 22.1 17.9 40 40 40l48 0c22.1 0 40-17.9 40-40l0-48zm32-192l0 48c0 22.1 17.9 40 40 40l48 0c22.1 0 40-17.9 40-40l0-48c0-22.1-17.9-40-40-40l-48 0c-22.1 0-40 17.9-40 40zM288 328c0-22.1-17.9-40-40-40l-48 0c-22.1 0-40 17.9-40 40l0 48c0 22.1 17.9 40 40 40l48 0c22.1 0 40-17.9 40-40l0-48zm32-192l0 48c0 22.1 17.9 40 40 40l48 0c22.1 0 40-17.9 40-40l0-48c0-22.1-17.9-40-40-40l-48 0c-22.1 0-40 17.9-40 40zM448 328c0-22.1-17.9-40-40-40l-48 0c-22.1 0-40 17.9-40 40l0 48c0 22.1 17.9 40 40 40l48 0c22.1 0 40-17.9 40-40l0-48z\"]\n};\nconst faGripHorizontal = faGrip;\nconst faShareFromSquare = {\n prefix: 'fas',\n iconName: 'share-from-square',\n icon: [576, 512, [61509, \"share-square\"], \"f14d\", \"M352 224l-46.5 0c-45 0-81.5 36.5-81.5 81.5c0 22.3 10.3 34.3 19.2 40.5c6.8 4.7 12.8 12 12.8 20.3c0 9.8-8 17.8-17.8 17.8l-2.5 0c-2.4 0-4.8-.4-7.1-1.4C210.8 374.8 128 333.4 128 240c0-79.5 64.5-144 144-144l80 0 0-61.3C352 15.5 367.5 0 386.7 0c8.6 0 16.8 3.2 23.2 8.9L548.1 133.3c7.6 6.8 11.9 16.5 11.9 26.7s-4.3 19.9-11.9 26.7l-139 125.1c-5.9 5.3-13.5 8.2-21.4 8.2l-3.7 0c-17.7 0-32-14.3-32-32l0-64zM80 96c-8.8 0-16 7.2-16 16l0 320c0 8.8 7.2 16 16 16l320 0c8.8 0 16-7.2 16-16l0-48c0-17.7 14.3-32 32-32s32 14.3 32 32l0 48c0 44.2-35.8 80-80 80L80 512c-44.2 0-80-35.8-80-80L0 112C0 67.8 35.8 32 80 32l48 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L80 96z\"]\n};\nconst faShareSquare = faShareFromSquare;\nconst faChildCombatant = {\n prefix: 'fas',\n iconName: 'child-combatant',\n icon: [576, 512, [\"child-rifle\"], \"e4e0\", \"M176 128A64 64 0 1 0 176 0a64 64 0 1 0 0 128zm-8 352l0-128 16 0 0 128c0 17.7 14.3 32 32 32s32-14.3 32-32l0-179.5L260.9 321c9.4 15 29.2 19.4 44.1 10s19.4-29.2 10-44.1l-51.7-82.1c-17.6-27.9-48.3-44.9-81.2-44.9l-12.3 0c-33 0-63.7 16.9-81.2 44.9L36.9 287c-9.4 15-4.9 34.7 10 44.1s34.7 4.9 44.1-10L104 300.5 104 480c0 17.7 14.3 32 32 32s32-14.3 32-32zM448 0L432 0 416 0c-8.8 0-16 7.2-16 16s7.2 16 16 16l0 100.3c-9.6 5.5-16 15.9-16 27.7l0 32c-17.7 0-32 14.3-32 32l0 144c0 17.7 14.3 32 32 32l16 0 0 96c0 8.8 7.2 16 16 16l59.5 0c10.4 0 18-9.8 15.5-19.9L484 400l44 0c8.8 0 16-7.2 16-16l0-16c0-8.8-7.2-16-16-16l-48 0 0-26.7 53.1-17.7c6.5-2.2 10.9-8.3 10.9-15.2l0-84.5c0-8.8-7.2-16-16-16l-16 0c-8.8 0-16 7.2-16 16l0 56-16 5.3L480 160c0-11.8-6.4-22.2-16-27.7L464 16c0-8.8-7.2-16-16-16z\"]\n};\nconst faChildRifle = faChildCombatant;\nconst faGun = {\n prefix: 'fas',\n iconName: 'gun',\n icon: [576, 512, [], \"e19b\", \"M528 56c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 8L32 64C14.3 64 0 78.3 0 96L0 208c0 17.7 14.3 32 32 32l10 0c20.8 0 36.1 19.6 31 39.8L33 440.2c-2.4 9.6-.2 19.7 5.8 27.5S54.1 480 64 480l96 0c14.7 0 27.5-10 31-24.2L217 352l104.5 0c23.7 0 44.8-14.9 52.7-37.2L400.9 240l31.1 0c8.5 0 16.6-3.4 22.6-9.4L477.3 208l66.7 0c17.7 0 32-14.3 32-32l0-80c0-17.7-14.3-32-32-32l-16 0 0-8zM321.4 304L229 304l16-64 105 0-21 58.7c-1.1 3.2-4.2 5.3-7.5 5.3zM80 128l384 0c8.8 0 16 7.2 16 16s-7.2 16-16 16L80 160c-8.8 0-16-7.2-16-16s7.2-16 16-16z\"]\n};\nconst faSquarePhone = {\n prefix: 'fas',\n iconName: 'square-phone',\n icon: [448, 512, [\"phone-square\"], \"f098\", \"M64 32C28.7 32 0 60.7 0 96L0 416c0 35.3 28.7 64 64 64l320 0c35.3 0 64-28.7 64-64l0-320c0-35.3-28.7-64-64-64L64 32zm90.7 96.7c9.7-2.6 19.9 2.3 23.7 11.6l20 48c3.4 8.2 1 17.6-5.8 23.2L168 231.7c16.6 35.2 45.1 63.7 80.3 80.3l20.2-24.7c5.6-6.8 15-9.2 23.2-5.8l48 20c9.3 3.9 14.2 14 11.6 23.7l-12 44C336.9 378 329 384 320 384C196.3 384 96 283.7 96 160c0-9 6-16.9 14.7-19.3l44-12z\"]\n};\nconst faPhoneSquare = faSquarePhone;\nconst faPlus = {\n prefix: 'fas',\n iconName: 'plus',\n icon: [448, 512, [10133, 61543, \"add\"], \"2b\", \"M256 80c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 144L48 224c-17.7 0-32 14.3-32 32s14.3 32 32 32l144 0 0 144c0 17.7 14.3 32 32 32s32-14.3 32-32l0-144 144 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-144 0 0-144z\"]\n};\nconst faAdd = faPlus;\nconst faExpand = {\n prefix: 'fas',\n iconName: 'expand',\n icon: [448, 512, [], \"f065\", \"M32 32C14.3 32 0 46.3 0 64l0 96c0 17.7 14.3 32 32 32s32-14.3 32-32l0-64 64 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L32 32zM64 352c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 96c0 17.7 14.3 32 32 32l96 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-64 0 0-64zM320 32c-17.7 0-32 14.3-32 32s14.3 32 32 32l64 0 0 64c0 17.7 14.3 32 32 32s32-14.3 32-32l0-96c0-17.7-14.3-32-32-32l-96 0zM448 352c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 64-64 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l96 0c17.7 0 32-14.3 32-32l0-96z\"]\n};\nconst faComputer = {\n prefix: 'fas',\n iconName: 'computer',\n icon: [640, 512, [], \"e4e5\", \"M384 96l0 224L64 320 64 96l320 0zM64 32C28.7 32 0 60.7 0 96L0 320c0 35.3 28.7 64 64 64l117.3 0-10.7 32L96 416c-17.7 0-32 14.3-32 32s14.3 32 32 32l256 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-74.7 0-10.7-32L384 384c35.3 0 64-28.7 64-64l0-224c0-35.3-28.7-64-64-64L64 32zm464 0c-26.5 0-48 21.5-48 48l0 352c0 26.5 21.5 48 48 48l64 0c26.5 0 48-21.5 48-48l0-352c0-26.5-21.5-48-48-48l-64 0zm16 64l32 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16s7.2-16 16-16zm-16 80c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16zm32 160a32 32 0 1 1 0 64 32 32 0 1 1 0-64z\"]\n};\nconst faXmark = {\n prefix: 'fas',\n iconName: 'xmark',\n icon: [384, 512, [128473, 10005, 10006, 10060, 215, \"close\", \"multiply\", \"remove\", \"times\"], \"f00d\", \"M342.6 150.6c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0L192 210.7 86.6 105.4c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3L146.7 256 41.4 361.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0L192 301.3 297.4 406.6c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3L237.3 256 342.6 150.6z\"]\n};\nconst faClose = faXmark;\nconst faMultiply = faXmark;\nconst faRemove = faXmark;\nconst faTimes = faXmark;\nconst faArrowsUpDownLeftRight = {\n prefix: 'fas',\n iconName: 'arrows-up-down-left-right',\n icon: [512, 512, [\"arrows\"], \"f047\", \"M278.6 9.4c-12.5-12.5-32.8-12.5-45.3 0l-64 64c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0l9.4-9.4L224 224l-114.7 0 9.4-9.4c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0l-64 64c-12.5 12.5-12.5 32.8 0 45.3l64 64c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3l-9.4-9.4L224 288l0 114.7-9.4-9.4c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3l64 64c12.5 12.5 32.8 12.5 45.3 0l64-64c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0l-9.4 9.4L288 288l114.7 0-9.4 9.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0l64-64c12.5-12.5 12.5-32.8 0-45.3l-64-64c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3l9.4 9.4L288 224l0-114.7 9.4 9.4c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3l-64-64z\"]\n};\nconst faArrows = faArrowsUpDownLeftRight;\nconst faChalkboardUser = {\n prefix: 'fas',\n iconName: 'chalkboard-user',\n icon: [640, 512, [\"chalkboard-teacher\"], \"f51c\", \"M160 64c0-35.3 28.7-64 64-64L576 0c35.3 0 64 28.7 64 64l0 288c0 35.3-28.7 64-64 64l-239.2 0c-11.8-25.5-29.9-47.5-52.4-64l99.6 0 0-32c0-17.7 14.3-32 32-32l64 0c17.7 0 32 14.3 32 32l0 32 64 0 0-288L224 64l0 49.1C205.2 102.2 183.3 96 160 96l0-32zm0 64a96 96 0 1 1 0 192 96 96 0 1 1 0-192zM133.3 352l53.3 0C260.3 352 320 411.7 320 485.3c0 14.7-11.9 26.7-26.7 26.7L26.7 512C11.9 512 0 500.1 0 485.3C0 411.7 59.7 352 133.3 352z\"]\n};\nconst faChalkboardTeacher = faChalkboardUser;\nconst faPesoSign = {\n prefix: 'fas',\n iconName: 'peso-sign',\n icon: [384, 512, [], \"e222\", \"M64 32C46.3 32 32 46.3 32 64l0 64c-17.7 0-32 14.3-32 32s14.3 32 32 32l0 32c-17.7 0-32 14.3-32 32s14.3 32 32 32l0 64 0 96c0 17.7 14.3 32 32 32s32-14.3 32-32l0-64 80 0c68.4 0 127.7-39 156.8-96l19.2 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-.7 0c.5-5.3 .7-10.6 .7-16s-.2-10.7-.7-16l.7 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-19.2 0C303.7 71 244.4 32 176 32L64 32zm190.4 96L96 128l0-32 80 0c30.5 0 58.2 12.2 78.4 32zM96 192l190.9 0c.7 5.2 1.1 10.6 1.1 16s-.4 10.8-1.1 16L96 224l0-32zm158.4 96c-20.2 19.8-47.9 32-78.4 32l-80 0 0-32 158.4 0z\"]\n};\nconst faBuildingShield = {\n prefix: 'fas',\n iconName: 'building-shield',\n icon: [576, 512, [], \"e4d8\", \"M0 48C0 21.5 21.5 0 48 0L336 0c26.5 0 48 21.5 48 48l0 159-42.4 17L304 224l-32 0c-8.8 0-16 7.2-16 16l0 32 0 24.2 0 7.8c0 .9 .1 1.7 .2 2.6c2.3 58.1 24.1 144.8 98.7 201.5c-5.8 2.5-12.2 3.9-18.9 3.9l-96 0 0-80c0-26.5-21.5-48-48-48s-48 21.5-48 48l0 80-96 0c-26.5 0-48-21.5-48-48L0 48zM80 224c-8.8 0-16 7.2-16 16l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0zm80 16l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0c-8.8 0-16 7.2-16 16zM64 112l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16L80 96c-8.8 0-16 7.2-16 16zM176 96c-8.8 0-16 7.2-16 16l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0zm80 16l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0c-8.8 0-16 7.2-16 16zM423.1 225.7c5.7-2.3 12.1-2.3 17.8 0l120 48C570 277.4 576 286.2 576 296c0 63.3-25.9 168.8-134.8 214.2c-5.9 2.5-12.6 2.5-18.5 0C313.9 464.8 288 359.3 288 296c0-9.8 6-18.6 15.1-22.3l120-48zM527.4 312L432 273.8l0 187.8c68.2-33 91.5-99 95.4-149.7z\"]\n};\nconst faBaby = {\n prefix: 'fas',\n iconName: 'baby',\n icon: [448, 512, [], \"f77c\", \"M152 88a72 72 0 1 1 144 0A72 72 0 1 1 152 88zM39.7 144.5c13-17.9 38-21.8 55.9-8.8L131.8 162c26.8 19.5 59.1 30 92.2 30s65.4-10.5 92.2-30l36.2-26.4c17.9-13 42.9-9 55.9 8.8s9 42.9-8.8 55.9l-36.2 26.4c-13.6 9.9-28.1 18.2-43.3 25l0 36.3-192 0 0-36.3c-15.2-6.7-29.7-15.1-43.3-25L48.5 200.3c-17.9-13-21.8-38-8.8-55.9zm89.8 184.8l60.6 53-26 37.2 24.3 24.3c15.6 15.6 15.6 40.9 0 56.6s-40.9 15.6-56.6 0l-48-48C70 438.6 68.1 417 79.2 401.1l50.2-71.8zm128.5 53l60.6-53 50.2 71.8c11.1 15.9 9.2 37.5-4.5 51.2l-48 48c-15.6 15.6-40.9 15.6-56.6 0s-15.6-40.9 0-56.6L284 419.4l-26-37.2z\"]\n};\nconst faUsersLine = {\n prefix: 'fas',\n iconName: 'users-line',\n icon: [640, 512, [], \"e592\", \"M211.2 96a64 64 0 1 0 -128 0 64 64 0 1 0 128 0zM32 256c0 17.7 14.3 32 32 32l85.6 0c10.1-39.4 38.6-71.5 75.8-86.6c-9.7-6-21.2-9.4-33.4-9.4l-96 0c-35.3 0-64 28.7-64 64zm461.6 32l82.4 0c17.7 0 32-14.3 32-32c0-35.3-28.7-64-64-64l-96 0c-11.7 0-22.7 3.1-32.1 8.6c38.1 14.8 67.4 47.3 77.7 87.4zM391.2 226.4c-6.9-1.6-14.2-2.4-21.6-2.4l-96 0c-8.5 0-16.7 1.1-24.5 3.1c-30.8 8.1-55.6 31.1-66.1 60.9c-3.5 10-5.5 20.8-5.5 32c0 17.7 14.3 32 32 32l224 0c17.7 0 32-14.3 32-32c0-11.2-1.9-22-5.5-32c-10.8-30.7-36.8-54.2-68.9-61.6zM563.2 96a64 64 0 1 0 -128 0 64 64 0 1 0 128 0zM321.6 192a80 80 0 1 0 0-160 80 80 0 1 0 0 160zM32 416c-17.7 0-32 14.3-32 32s14.3 32 32 32l576 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L32 416z\"]\n};\nconst faQuoteLeft = {\n prefix: 'fas',\n iconName: 'quote-left',\n icon: [448, 512, [8220, \"quote-left-alt\"], \"f10d\", \"M0 216C0 149.7 53.7 96 120 96l8 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-8 0c-30.9 0-56 25.1-56 56l0 8 64 0c35.3 0 64 28.7 64 64l0 64c0 35.3-28.7 64-64 64l-64 0c-35.3 0-64-28.7-64-64l0-32 0-32 0-72zm256 0c0-66.3 53.7-120 120-120l8 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-8 0c-30.9 0-56 25.1-56 56l0 8 64 0c35.3 0 64 28.7 64 64l0 64c0 35.3-28.7 64-64 64l-64 0c-35.3 0-64-28.7-64-64l0-32 0-32 0-72z\"]\n};\nconst faQuoteLeftAlt = faQuoteLeft;\nconst faTractor = {\n prefix: 'fas',\n iconName: 'tractor',\n icon: [640, 512, [128668], \"f722\", \"M96 64c0-35.3 28.7-64 64-64L266.3 0c26.2 0 49.7 15.9 59.4 40.2L373.7 160 480 160l0-33.8c0-24.8 5.8-49.3 16.9-71.6l2.5-5c7.9-15.8 27.1-22.2 42.9-14.3s22.2 27.1 14.3 42.9l-2.5 5c-6.7 13.3-10.1 28-10.1 42.9l0 33.8 56 0c22.1 0 40 17.9 40 40l0 45.4c0 16.5-8.5 31.9-22.6 40.7l-43.3 27.1c-14.2-5.9-29.8-9.2-46.1-9.2c-39.3 0-74.1 18.9-96 48l-80 0c0 17.7-14.3 32-32 32l-8.2 0c-1.7 4.8-3.7 9.5-5.8 14.1l5.8 5.8c12.5 12.5 12.5 32.8 0 45.3l-22.6 22.6c-12.5 12.5-32.8 12.5-45.3 0l-5.8-5.8c-4.6 2.2-9.3 4.1-14.1 5.8l0 8.2c0 17.7-14.3 32-32 32l-32 0c-17.7 0-32-14.3-32-32l0-8.2c-4.8-1.7-9.5-3.7-14.1-5.8l-5.8 5.8c-12.5 12.5-32.8 12.5-45.3 0L40.2 449.1c-12.5-12.5-12.5-32.8 0-45.3l5.8-5.8c-2.2-4.6-4.1-9.3-5.8-14.1L32 384c-17.7 0-32-14.3-32-32l0-32c0-17.7 14.3-32 32-32l8.2 0c1.7-4.8 3.7-9.5 5.8-14.1l-5.8-5.8c-12.5-12.5-12.5-32.8 0-45.3l22.6-22.6c9-9 21.9-11.5 33.1-7.6l0-.6 0-32 0-96zm170.3 0L160 64l0 96 32 0 112.7 0L266.3 64zM176 256a80 80 0 1 0 0 160 80 80 0 1 0 0-160zM528 448a24 24 0 1 0 0-48 24 24 0 1 0 0 48zm0 64c-48.6 0-88-39.4-88-88c0-29.8 14.8-56.1 37.4-72c14.3-10.1 31.8-16 50.6-16c2.7 0 5.3 .1 7.9 .3c44.9 4 80.1 41.7 80.1 87.7c0 48.6-39.4 88-88 88z\"]\n};\nconst faTrashArrowUp = {\n prefix: 'fas',\n iconName: 'trash-arrow-up',\n icon: [448, 512, [\"trash-restore\"], \"f829\", \"M163.8 0L284.2 0c12.1 0 23.2 6.8 28.6 17.7L320 32l96 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L32 96C14.3 96 0 81.7 0 64S14.3 32 32 32l96 0 7.2-14.3C140.6 6.8 151.7 0 163.8 0zM32 128l384 0L394.8 467c-1.6 25.3-22.6 45-47.9 45l-245.8 0c-25.3 0-46.3-19.7-47.9-45L32 128zm192 64c-6.4 0-12.5 2.5-17 7l-80 80c-9.4 9.4-9.4 24.6 0 33.9s24.6 9.4 33.9 0l39-39L200 408c0 13.3 10.7 24 24 24s24-10.7 24-24l0-134.1 39 39c9.4 9.4 24.6 9.4 33.9 0s9.4-24.6 0-33.9l-80-80c-4.5-4.5-10.6-7-17-7z\"]\n};\nconst faTrashRestore = faTrashArrowUp;\nconst faArrowDownUpLock = {\n prefix: 'fas',\n iconName: 'arrow-down-up-lock',\n icon: [640, 512, [], \"e4b0\", \"M150.6 502.6l96-96c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0L160 402.7 160 288l256 0 0-16c0-17.2 3.9-33.5 10.8-48L352 224l0-114.7 41.4 41.4c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3l-96-96c-6-6-14.1-9.4-22.6-9.4s-16.6 3.4-22.6 9.4l-96 96c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0L288 109.3 288 224l-128 0-64 0-64 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l64 0 0 114.7L54.6 361.4c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3l96 96c12.5 12.5 32.8 12.5 45.3 0zM160 192l0-128c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 128 64 0zM288 320l0 128c0 17.7 14.3 32 32 32s32-14.3 32-32l0-128-64 0zm240-80c17.7 0 32 14.3 32 32l0 48-64 0 0-48c0-17.7 14.3-32 32-32zm-80 32l0 48c-17.7 0-32 14.3-32 32l0 128c0 17.7 14.3 32 32 32l160 0c17.7 0 32-14.3 32-32l0-128c0-17.7-14.3-32-32-32l0-48c0-44.2-35.8-80-80-80s-80 35.8-80 80z\"]\n};\nconst faLinesLeaning = {\n prefix: 'fas',\n iconName: 'lines-leaning',\n icon: [384, 512, [], \"e51e\", \"M190.4 74.1c5.6-16.8-3.5-34.9-20.2-40.5s-34.9 3.5-40.5 20.2l-128 384c-5.6 16.8 3.5 34.9 20.2 40.5s34.9-3.5 40.5-20.2l128-384zm70.9-41.7c-17.4-2.9-33.9 8.9-36.8 26.3l-64 384c-2.9 17.4 8.9 33.9 26.3 36.8s33.9-8.9 36.8-26.3l64-384c2.9-17.4-8.9-33.9-26.3-36.8zM352 32c-17.7 0-32 14.3-32 32l0 384c0 17.7 14.3 32 32 32s32-14.3 32-32l0-384c0-17.7-14.3-32-32-32z\"]\n};\nconst faRulerCombined = {\n prefix: 'fas',\n iconName: 'ruler-combined',\n icon: [512, 512, [], \"f546\", \"M.2 468.9C2.7 493.1 23.1 512 48 512l96 0 320 0c26.5 0 48-21.5 48-48l0-96c0-26.5-21.5-48-48-48l-48 0 0 80c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-80-64 0 0 80c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-80-64 0 0 80c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-80-80 0c-8.8 0-16-7.2-16-16s7.2-16 16-16l80 0 0-64-80 0c-8.8 0-16-7.2-16-16s7.2-16 16-16l80 0 0-64-80 0c-8.8 0-16-7.2-16-16s7.2-16 16-16l80 0 0-48c0-26.5-21.5-48-48-48L48 0C21.5 0 0 21.5 0 48L0 368l0 96c0 1.7 .1 3.3 .2 4.9z\"]\n};\nconst faCopyright = {\n prefix: 'fas',\n iconName: 'copyright',\n icon: [512, 512, [169], \"f1f9\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM199.4 312.6c31.2 31.2 81.9 31.2 113.1 0c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9c-50 50-131 50-181 0s-50-131 0-181s131-50 181 0c9.4 9.4 9.4 24.6 0 33.9s-24.6 9.4-33.9 0c-31.2-31.2-81.9-31.2-113.1 0s-31.2 81.9 0 113.1z\"]\n};\nconst faEquals = {\n prefix: 'fas',\n iconName: 'equals',\n icon: [448, 512, [62764], \"3d\", \"M48 128c-17.7 0-32 14.3-32 32s14.3 32 32 32l352 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L48 128zm0 192c-17.7 0-32 14.3-32 32s14.3 32 32 32l352 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L48 320z\"]\n};\nconst faBlender = {\n prefix: 'fas',\n iconName: 'blender',\n icon: [512, 512, [], \"f517\", \"M0 64C0 28.7 28.7 0 64 0l64 0 32 0L470.1 0c21.1 0 36.4 20.1 30.9 40.4L494.5 64 336 64c-8.8 0-16 7.2-16 16s7.2 16 16 16l149.8 0-17.5 64L336 160c-8.8 0-16 7.2-16 16s7.2 16 16 16l123.6 0-17.5 64L336 256c-8.8 0-16 7.2-16 16s7.2 16 16 16l97.5 0L416 352l-256 0-8.7-96L64 256c-35.3 0-64-28.7-64-64L0 64zM145.5 192L133.8 64 64 64l0 128 81.5 0zM144 384l288 0c26.5 0 48 21.5 48 48l0 32c0 26.5-21.5 48-48 48l-288 0c-26.5 0-48-21.5-48-48l0-32c0-26.5 21.5-48 48-48zm144 96a32 32 0 1 0 0-64 32 32 0 1 0 0 64z\"]\n};\nconst faTeeth = {\n prefix: 'fas',\n iconName: 'teeth',\n icon: [576, 512, [], \"f62e\", \"M0 128C0 75 43 32 96 32l384 0c53 0 96 43 96 96l0 256c0 53-43 96-96 96L96 480c-53 0-96-43-96-96L0 128zm176 48l0 56c0 13.3 10.7 24 24 24l48 0c13.3 0 24-10.7 24-24l0-56c0-26.5-21.5-48-48-48s-48 21.5-48 48zm176-48c-26.5 0-48 21.5-48 48l0 56c0 13.3 10.7 24 24 24l48 0c13.3 0 24-10.7 24-24l0-56c0-26.5-21.5-48-48-48zM48 208l0 24c0 13.3 10.7 24 24 24l48 0c13.3 0 24-10.7 24-24l0-24c0-26.5-21.5-48-48-48s-48 21.5-48 48zM96 384c26.5 0 48-21.5 48-48l0-24c0-13.3-10.7-24-24-24l-48 0c-13.3 0-24 10.7-24 24l0 24c0 26.5 21.5 48 48 48zm80-48c0 26.5 21.5 48 48 48s48-21.5 48-48l0-24c0-13.3-10.7-24-24-24l-48 0c-13.3 0-24 10.7-24 24l0 24zm176 48c26.5 0 48-21.5 48-48l0-24c0-13.3-10.7-24-24-24l-48 0c-13.3 0-24 10.7-24 24l0 24c0 26.5 21.5 48 48 48zm80-176l0 24c0 13.3 10.7 24 24 24l48 0c13.3 0 24-10.7 24-24l0-24c0-26.5-21.5-48-48-48s-48 21.5-48 48zm48 176c26.5 0 48-21.5 48-48l0-24c0-13.3-10.7-24-24-24l-48 0c-13.3 0-24 10.7-24 24l0 24c0 26.5 21.5 48 48 48z\"]\n};\nconst faShekelSign = {\n prefix: 'fas',\n iconName: 'shekel-sign',\n icon: [448, 512, [8362, \"ils\", \"shekel\", \"sheqel\", \"sheqel-sign\"], \"f20b\", \"M32 32C14.3 32 0 46.3 0 64L0 448c0 17.7 14.3 32 32 32s32-14.3 32-32L64 96l128 0c35.3 0 64 28.7 64 64l0 160c0 17.7 14.3 32 32 32s32-14.3 32-32l0-160c0-70.7-57.3-128-128-128L32 32zM320 480c70.7 0 128-57.3 128-128l0-288c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 288c0 35.3-28.7 64-64 64l-128 0 0-224c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 256c0 17.7 14.3 32 32 32l160 0z\"]\n};\nconst faIls = faShekelSign;\nconst faShekel = faShekelSign;\nconst faSheqel = faShekelSign;\nconst faSheqelSign = faShekelSign;\nconst faMap = {\n prefix: 'fas',\n iconName: 'map',\n icon: [576, 512, [128506, 62072], \"f279\", \"M384 476.1L192 421.2l0-385.3L384 90.8l0 385.3zm32-1.2l0-386.5L543.1 37.5c15.8-6.3 32.9 5.3 32.9 22.3l0 334.8c0 9.8-6 18.6-15.1 22.3L416 474.8zM15.1 95.1L160 37.2l0 386.5L32.9 474.5C17.1 480.8 0 469.2 0 452.2L0 117.4c0-9.8 6-18.6 15.1-22.3z\"]\n};\nconst faRocket = {\n prefix: 'fas',\n iconName: 'rocket',\n icon: [512, 512, [], \"f135\", \"M156.6 384.9L125.7 354c-8.5-8.5-11.5-20.8-7.7-32.2c3-8.9 7-20.5 11.8-33.8L24 288c-8.6 0-16.6-4.6-20.9-12.1s-4.2-16.7 .2-24.1l52.5-88.5c13-21.9 36.5-35.3 61.9-35.3l82.3 0c2.4-4 4.8-7.7 7.2-11.3C289.1-4.1 411.1-8.1 483.9 5.3c11.6 2.1 20.6 11.2 22.8 22.8c13.4 72.9 9.3 194.8-111.4 276.7c-3.5 2.4-7.3 4.8-11.3 7.2l0 82.3c0 25.4-13.4 49-35.3 61.9l-88.5 52.5c-7.4 4.4-16.6 4.5-24.1 .2s-12.1-12.2-12.1-20.9l0-107.2c-14.1 4.9-26.4 8.9-35.7 11.9c-11.2 3.6-23.4 .5-31.8-7.8zM384 168a40 40 0 1 0 0-80 40 40 0 1 0 0 80z\"]\n};\nconst faPhotoFilm = {\n prefix: 'fas',\n iconName: 'photo-film',\n icon: [640, 512, [\"photo-video\"], \"f87c\", \"M256 0L576 0c35.3 0 64 28.7 64 64l0 224c0 35.3-28.7 64-64 64l-320 0c-35.3 0-64-28.7-64-64l0-224c0-35.3 28.7-64 64-64zM476 106.7C471.5 100 464 96 456 96s-15.5 4-20 10.7l-56 84L362.7 169c-4.6-5.7-11.5-9-18.7-9s-14.2 3.3-18.7 9l-64 80c-5.8 7.2-6.9 17.1-2.9 25.4s12.4 13.6 21.6 13.6l80 0 48 0 144 0c8.9 0 17-4.9 21.2-12.7s3.7-17.3-1.2-24.6l-96-144zM336 96a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zM64 128l96 0 0 256 0 32c0 17.7 14.3 32 32 32l128 0c17.7 0 32-14.3 32-32l0-32 160 0 0 64c0 35.3-28.7 64-64 64L64 512c-35.3 0-64-28.7-64-64L0 192c0-35.3 28.7-64 64-64zm8 64c-8.8 0-16 7.2-16 16l0 16c0 8.8 7.2 16 16 16l16 0c8.8 0 16-7.2 16-16l0-16c0-8.8-7.2-16-16-16l-16 0zm0 104c-8.8 0-16 7.2-16 16l0 16c0 8.8 7.2 16 16 16l16 0c8.8 0 16-7.2 16-16l0-16c0-8.8-7.2-16-16-16l-16 0zm0 104c-8.8 0-16 7.2-16 16l0 16c0 8.8 7.2 16 16 16l16 0c8.8 0 16-7.2 16-16l0-16c0-8.8-7.2-16-16-16l-16 0zm336 16l0 16c0 8.8 7.2 16 16 16l16 0c8.8 0 16-7.2 16-16l0-16c0-8.8-7.2-16-16-16l-16 0c-8.8 0-16 7.2-16 16z\"]\n};\nconst faPhotoVideo = faPhotoFilm;\nconst faFolderMinus = {\n prefix: 'fas',\n iconName: 'folder-minus',\n icon: [512, 512, [], \"f65d\", \"M448 480L64 480c-35.3 0-64-28.7-64-64L0 96C0 60.7 28.7 32 64 32l128 0c20.1 0 39.1 9.5 51.2 25.6l19.2 25.6c6 8.1 15.5 12.8 25.6 12.8l160 0c35.3 0 64 28.7 64 64l0 256c0 35.3-28.7 64-64 64zM184 272c-13.3 0-24 10.7-24 24s10.7 24 24 24l144 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-144 0z\"]\n};\nconst faHexagonNodesBolt = {\n prefix: 'fas',\n iconName: 'hexagon-nodes-bolt',\n icon: [576, 512, [], \"e69a\", \"M248 106.6c18.9-9 32-28.3 32-50.6c0-30.9-25.1-56-56-56s-56 25.1-56 56c0 22.3 13.1 41.6 32 50.6l0 98.8c-2.8 1.3-5.5 2.9-8 4.7l-80.1-45.8c1.6-20.8-8.6-41.6-27.9-52.8C57.2 96 23 105.2 7.5 132S1.2 193 28 208.5c1.3 .8 2.6 1.5 4 2.1l0 90.8c-1.3 .6-2.7 1.3-4 2.1C1.2 319-8 353.2 7.5 380S57.2 416 84 400.5c19.3-11.1 29.4-32 27.8-52.8l50.5-28.9c-11.5-11.2-19.9-25.6-23.8-41.7L88 306.1c-2.6-1.8-5.2-3.3-8-4.7l0-90.8c2.8-1.3 5.5-2.9 8-4.7l80.1 45.8c-.1 1.4-.2 2.8-.2 4.3c0 22.3 13.1 41.6 32 50.6l0 98.8c-18.9 9-32 28.3-32 50.6c0 30.9 25.1 56 56 56c30.7 0 55.6-24.7 56-55.2c-7.5-12.9-13.5-26.8-17.6-41.5c-4.2-4-9.1-7.3-14.4-9.9l0-98.8c2.8-1.3 5.5-2.9 8-4.7l10.5 6c5.5-15.3 13.1-29.5 22.4-42.5l-9.1-5.2c.1-1.4 .2-2.8 .2-4.3c0-22.3-13.1-41.6-32-50.6l0-98.8zM440.5 132C425 105.2 390.8 96 364 111.5c-19.3 11.1-29.4 32-27.8 52.8l-50.6 28.9c11.5 11.2 19.9 25.6 23.8 41.7L360 205.9c.4 .3 .8 .6 1.3 .9c21.7-9.5 45.6-14.8 70.8-14.8c2 0 4 0 5.9 .1c12.1-17.3 13.8-40.6 2.6-60.1zM432 512a144 144 0 1 0 0-288 144 144 0 1 0 0 288zm47.9-225c4.3 3.7 5.4 9.9 2.6 14.9L452.4 356l35.6 0c5.2 0 9.8 3.3 11.4 8.2s-.1 10.3-4.2 13.4l-96 72c-4.5 3.4-10.8 3.2-15.1-.6s-5.4-9.9-2.6-14.9L411.6 380 376 380c-5.2 0-9.8-3.3-11.4-8.2s.1-10.3 4.2-13.4l96-72c4.5-3.4 10.8-3.2 15.1 .6z\"]\n};\nconst faStore = {\n prefix: 'fas',\n iconName: 'store',\n icon: [576, 512, [], \"f54e\", \"M547.6 103.8L490.3 13.1C485.2 5 476.1 0 466.4 0L109.6 0C99.9 0 90.8 5 85.7 13.1L28.3 103.8c-29.6 46.8-3.4 111.9 51.9 119.4c4 .5 8.1 .8 12.1 .8c26.1 0 49.3-11.4 65.2-29c15.9 17.6 39.1 29 65.2 29c26.1 0 49.3-11.4 65.2-29c15.9 17.6 39.1 29 65.2 29c26.2 0 49.3-11.4 65.2-29c16 17.6 39.1 29 65.2 29c4.1 0 8.1-.3 12.1-.8c55.5-7.4 81.8-72.5 52.1-119.4zM499.7 254.9c0 0 0 0-.1 0c-5.3 .7-10.7 1.1-16.2 1.1c-12.4 0-24.3-1.9-35.4-5.3L448 384l-320 0 0-133.4c-11.2 3.5-23.2 5.4-35.6 5.4c-5.5 0-11-.4-16.3-1.1l-.1 0c-4.1-.6-8.1-1.3-12-2.3L64 384l0 64c0 35.3 28.7 64 64 64l320 0c35.3 0 64-28.7 64-64l0-64 0-131.4c-4 1-8 1.8-12.3 2.3z\"]\n};\nconst faArrowTrendUp = {\n prefix: 'fas',\n iconName: 'arrow-trend-up',\n icon: [576, 512, [], \"e098\", \"M384 160c-17.7 0-32-14.3-32-32s14.3-32 32-32l160 0c17.7 0 32 14.3 32 32l0 160c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-82.7L342.6 374.6c-12.5 12.5-32.8 12.5-45.3 0L192 269.3 54.6 406.6c-12.5 12.5-32.8 12.5-45.3 0s-12.5-32.8 0-45.3l160-160c12.5-12.5 32.8-12.5 45.3 0L320 306.7 466.7 160 384 160z\"]\n};\nconst faPlugCircleMinus = {\n prefix: 'fas',\n iconName: 'plug-circle-minus',\n icon: [576, 512, [], \"e55e\", \"M96 0C78.3 0 64 14.3 64 32l0 96 64 0 0-96c0-17.7-14.3-32-32-32zM288 0c-17.7 0-32 14.3-32 32l0 96 64 0 0-96c0-17.7-14.3-32-32-32zM32 160c-17.7 0-32 14.3-32 32s14.3 32 32 32l0 32c0 77.4 55 142 128 156.8l0 67.2c0 17.7 14.3 32 32 32s32-14.3 32-32l0-67.2c12.3-2.5 24.1-6.4 35.1-11.5c-2.1-10.8-3.1-21.9-3.1-33.3c0-80.3 53.8-148 127.3-169.2c.5-2.2 .7-4.5 .7-6.8c0-17.7-14.3-32-32-32L32 160zM576 368a144 144 0 1 0 -288 0 144 144 0 1 0 288 0zm-64 0c0 8.8-7.2 16-16 16l-128 0c-8.8 0-16-7.2-16-16s7.2-16 16-16l128 0c8.8 0 16 7.2 16 16z\"]\n};\nconst faSignHanging = {\n prefix: 'fas',\n iconName: 'sign-hanging',\n icon: [512, 512, [\"sign\"], \"f4d9\", \"M96 0c17.7 0 32 14.3 32 32l0 32 352 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-352 0 0 352c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-352-32 0C14.3 128 0 113.7 0 96S14.3 64 32 64l32 0 0-32C64 14.3 78.3 0 96 0zm96 160l256 0c17.7 0 32 14.3 32 32l0 160c0 17.7-14.3 32-32 32l-256 0c-17.7 0-32-14.3-32-32l0-160c0-17.7 14.3-32 32-32z\"]\n};\nconst faSign = faSignHanging;\nconst faBezierCurve = {\n prefix: 'fas',\n iconName: 'bezier-curve',\n icon: [640, 512, [], \"f55b\", \"M296 136l0-48 48 0 0 48-48 0zM288 32c-26.5 0-48 21.5-48 48l0 4L121.6 84C111.2 62.7 89.3 48 64 48C28.7 48 0 76.7 0 112s28.7 64 64 64c25.3 0 47.2-14.7 57.6-36l66.9 0c-58.9 39.6-98.9 105-104 180L80 320c-26.5 0-48 21.5-48 48l0 64c0 26.5 21.5 48 48 48l64 0c26.5 0 48-21.5 48-48l0-64c0-26.5-21.5-48-48-48l-3.3 0c5.9-67 48.5-123.4 107.5-149.1c8.6 12.7 23.2 21.1 39.8 21.1l64 0c16.6 0 31.1-8.4 39.8-21.1c59 25.7 101.6 82.1 107.5 149.1l-3.3 0c-26.5 0-48 21.5-48 48l0 64c0 26.5 21.5 48 48 48l64 0c26.5 0 48-21.5 48-48l0-64c0-26.5-21.5-48-48-48l-4.5 0c-5-75-45.1-140.4-104-180l66.9 0c10.4 21.3 32.3 36 57.6 36c35.3 0 64-28.7 64-64s-28.7-64-64-64c-25.3 0-47.2 14.7-57.6 36L400 84l0-4c0-26.5-21.5-48-48-48l-64 0zM88 376l48 0 0 48-48 0 0-48zm416 48l0-48 48 0 0 48-48 0z\"]\n};\nconst faBellSlash = {\n prefix: 'fas',\n iconName: 'bell-slash',\n icon: [640, 512, [128277, 61943], \"f1f6\", \"M38.8 5.1C28.4-3.1 13.3-1.2 5.1 9.2S-1.2 34.7 9.2 42.9l592 464c10.4 8.2 25.5 6.3 33.7-4.1s6.3-25.5-4.1-33.7l-90.2-70.7c.2-.4 .4-.9 .6-1.3c5.2-11.5 3.1-25-5.3-34.4l-7.4-8.3C497.3 319.2 480 273.9 480 226.8l0-18.8c0-77.4-55-142-128-156.8L352 32c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 19.2c-42.6 8.6-79 34.2-102 69.3L38.8 5.1zM406.2 416L160 222.1l0 4.8c0 47-17.3 92.4-48.5 127.6l-7.4 8.3c-8.4 9.4-10.4 22.9-5.3 34.4S115.4 416 128 416l278.2 0zm-40.9 77.3c12-12 18.7-28.3 18.7-45.3l-64 0-64 0c0 17 6.7 33.3 18.7 45.3s28.3 18.7 45.3 18.7s33.3-6.7 45.3-18.7z\"]\n};\nconst faTablet = {\n prefix: 'fas',\n iconName: 'tablet',\n icon: [448, 512, [\"tablet-android\"], \"f3fb\", \"M64 0C28.7 0 0 28.7 0 64L0 448c0 35.3 28.7 64 64 64l320 0c35.3 0 64-28.7 64-64l0-384c0-35.3-28.7-64-64-64L64 0zM176 432l96 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-96 0c-8.8 0-16-7.2-16-16s7.2-16 16-16z\"]\n};\nconst faTabletAndroid = faTablet;\nconst faSchoolFlag = {\n prefix: 'fas',\n iconName: 'school-flag',\n icon: [576, 512, [], \"e56e\", \"M288 0L400 0c8.8 0 16 7.2 16 16l0 64c0 8.8-7.2 16-16 16l-79.3 0 89.6 64L512 160c35.3 0 64 28.7 64 64l0 224c0 35.3-28.7 64-64 64l-176 0 0-112c0-26.5-21.5-48-48-48s-48 21.5-48 48l0 112L64 512c-35.3 0-64-28.7-64-64L0 224c0-35.3 28.7-64 64-64l101.7 0L256 95.5 256 32c0-17.7 14.3-32 32-32zm48 240a48 48 0 1 0 -96 0 48 48 0 1 0 96 0zM80 224c-8.8 0-16 7.2-16 16l0 64c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-64c0-8.8-7.2-16-16-16l-32 0zm368 16l0 64c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-64c0-8.8-7.2-16-16-16l-32 0c-8.8 0-16 7.2-16 16zM80 352c-8.8 0-16 7.2-16 16l0 64c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-64c0-8.8-7.2-16-16-16l-32 0zm384 0c-8.8 0-16 7.2-16 16l0 64c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-64c0-8.8-7.2-16-16-16l-32 0z\"]\n};\nconst faFill = {\n prefix: 'fas',\n iconName: 'fill',\n icon: [512, 512, [], \"f575\", \"M86.6 9.4C74.1-3.1 53.9-3.1 41.4 9.4s-12.5 32.8 0 45.3L122.7 136 30.6 228.1c-37.5 37.5-37.5 98.3 0 135.8L148.1 481.4c37.5 37.5 98.3 37.5 135.8 0L474.3 290.9c28.1-28.1 28.1-73.7 0-101.8L322.9 37.7c-28.1-28.1-73.7-28.1-101.8 0L168 90.7 86.6 9.4zM168 181.3l49.4 49.4c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3L213.3 136l53.1-53.1c3.1-3.1 8.2-3.1 11.3 0L429.1 234.3c3.1 3.1 3.1 8.2 0 11.3L386.7 288 67.5 288c1.4-5.4 4.2-10.4 8.4-14.6L168 181.3z\"]\n};\nconst faAngleUp = {\n prefix: 'fas',\n iconName: 'angle-up',\n icon: [448, 512, [8963], \"f106\", \"M201.4 137.4c12.5-12.5 32.8-12.5 45.3 0l160 160c12.5 12.5 12.5 32.8 0 45.3s-32.8 12.5-45.3 0L224 205.3 86.6 342.6c-12.5 12.5-32.8 12.5-45.3 0s-12.5-32.8 0-45.3l160-160z\"]\n};\nconst faDrumstickBite = {\n prefix: 'fas',\n iconName: 'drumstick-bite',\n icon: [512, 512, [], \"f6d7\", \"M160 265.2c0 8.5-3.4 16.6-9.4 22.6l-26.8 26.8c-12.3 12.3-32.5 11.4-49.4 7.2C69.8 320.6 65 320 60 320c-33.1 0-60 26.9-60 60s26.9 60 60 60c6.3 0 12 5.7 12 12c0 33.1 26.9 60 60 60s60-26.9 60-60c0-5-.6-9.8-1.8-14.5c-4.2-16.9-5.2-37.1 7.2-49.4l26.8-26.8c6-6 14.1-9.4 22.6-9.4l89.2 0c6.3 0 12.4-.3 18.5-1c11.9-1.2 16.4-15.5 10.8-26c-8.5-15.8-13.3-33.8-13.3-53c0-61.9 50.1-112 112-112c8 0 15.7 .8 23.2 2.4c11.7 2.5 24.1-5.9 22-17.6C494.5 62.5 422.5 0 336 0C238.8 0 160 78.8 160 176l0 89.2z\"]\n};\nconst faHollyBerry = {\n prefix: 'fas',\n iconName: 'holly-berry',\n icon: [512, 512, [], \"f7aa\", \"M256 96a48 48 0 1 0 0-96 48 48 0 1 0 0 96zm-80 96a48 48 0 1 0 0-96 48 48 0 1 0 0 96zM276.8 383.8c1 .1 2.1 .2 3.2 .2c39.8 0 72 32.2 72 72l0 22.7c0 16.4 16 27.9 31.6 22.8l12.8-4.3c18-6 37.3-6.5 55.6-1.5l19.4 5.3c17.9 4.9 34.4-11.6 29.5-29.5L495.6 452c-5-18.3-4.4-37.6 1.5-55.6l4.3-12.8c5.2-15.5-6.4-31.6-22.8-31.6c-34.6 0-62.7-28.1-62.7-62.7l0-32c0-16.4-16-27.9-31.6-22.8l-12.8 4.3c-18 6-37.3 6.5-55.6 1.5l-29.6-8.1c-2.9-.8-5.9-1-8.7-.7c4.2 9.7 5.8 20.8 3.7 32.3L275 298.7c-1.5 8.4-1.4 17 .5 25.3l5.3 23.9c2.8 12.7 1.1 25.2-4 35.9zM127.6 234.5c-15.5-5.2-31.6 6.4-31.6 22.8l0 32C96 323.9 67.9 352 33.3 352c-16.4 0-27.9 16-22.8 31.6l4.3 12.8c6 18 6.5 37.3 1.5 55.6l-5.3 19.4C6.2 489.4 22.6 505.8 40.5 501L60 495.6c18.3-5 37.6-4.5 55.6 1.5l12.8 4.3c15.5 5.2 31.6-6.4 31.6-22.8l0-32c0-34.6 28.1-62.7 62.7-62.7c16.4 0 27.9-16 22.8-31.6l-4.3-12.8c-6-18-6.5-37.3-1.5-55.6l5.3-19.4c4.9-17.9-11.6-34.4-29.5-29.5L196 240.4c-18.3 5-37.6 4.4-55.6-1.5l-12.8-4.3zM384 144a48 48 0 1 0 -96 0 48 48 0 1 0 96 0z\"]\n};\nconst faChevronLeft = {\n prefix: 'fas',\n iconName: 'chevron-left',\n icon: [320, 512, [9001], \"f053\", \"M9.4 233.4c-12.5 12.5-12.5 32.8 0 45.3l192 192c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3L77.3 256 246.6 86.6c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0l-192 192z\"]\n};\nconst faBacteria = {\n prefix: 'fas',\n iconName: 'bacteria',\n icon: [640, 512, [], \"e059\", \"M304.9 .7c-9.6-2.7-19.5 2.8-22.3 12.4l-4.3 15.2c-8.3-.6-16.8 0-25.2 1.9c-7.3 1.7-14.3 3.5-21.1 5.5l-5.5-12.7c-3.9-9.1-14.5-13.4-23.6-9.5s-13.4 14.5-9.5 23.6l4.4 10.4c-16.6 6.7-31.7 14.4-45.4 22.8L147 62c-5.5-8.3-16.7-10.5-25-5s-10.5 16.7-5 25l6 9c-13.7 11-25.5 22.8-35.8 34.9l-10-8c-7.8-6.2-19.1-5-25.3 2.8s-5 19.1 2.8 25.3L65.9 155c-1.8 2.8-3.5 5.7-5.1 8.5c-6.6 11.4-11.8 22.6-16 33l-8-3.2c-9.2-3.7-19.7 .8-23.4 10s.8 19.7 10 23.4l10.4 4.2c-.2 .8-.4 1.5-.5 2.3c-2.2 9.3-3.4 17.3-4.1 23.4c-.4 3.1-.6 5.7-.8 7.8c-.1 1.1-.1 2-.2 2.8l-.1 1.1 0 .5 0 .2 0 .1c0 0 0 .1 29.1 1c0 0 0 0-.1 0L28 269.3c-.1 3.1 0 6.1 .2 9.1l-15.2 4.3C3.5 285.4-2 295.4 .7 304.9s12.7 15.1 22.3 12.4l15.6-4.5c7.6 13.6 18.9 25 32.6 32.6L66.7 361c-2.7 9.6 2.8 19.5 12.4 22.3s19.5-2.8 22.3-12.4l4.3-15.2c1.2 .1 2.4 .2 3.6 .2c15.6 .5 30.3-3.3 43-10.2l9 9c7 7 18.4 7 25.5 0s7-18.4 0-25.5l-7.2-7.2c9.3-12.6 15.2-27.8 16.3-44.5l7.1 3c9.1 3.9 19.7-.3 23.6-9.5s-.3-19.7-9.5-23.6l-8.6-3.7c6.4-9.9 17.3-22.4 36.9-33.3l1.3 4.4c2.7 9.6 12.7 15.1 22.3 12.4s15.1-12.7 12.4-22.3l-2.3-8.1c3.8-1.1 7.7-2.1 11.9-3.1c11.6-2.7 22.1-7.7 31.1-14.4l7.2 7.2c7 7 18.4 7 25.5 0s7-18.4 0-25.5l-9-9c7.6-13.9 11.3-30.1 10.1-46.6l15.2-4.3c9.6-2.7 15.1-12.7 12.4-22.3S370.6 64 361 66.7l-15.6 4.5c-7.7-13.9-19.1-25.1-32.6-32.6l4.5-15.6c2.7-9.6-2.8-19.5-12.4-22.3zM112 272l-48-1.5c0 0 0 0 0 0c11.7 .4 27.3 .9 48 1.6zm16-80a32 32 0 1 1 0 64 32 32 0 1 1 0-64zm64-48a16 16 0 1 1 32 0 16 16 0 1 1 -32 0zM322.7 489c-2.7 9.6 2.8 19.5 12.4 22.3s19.5-2.8 22.2-12.4l4.3-15.2c8.3 .6 16.8 0 25.2-1.9c7.3-1.7 14.3-3.5 21.1-5.5l5.5 12.7c3.9 9.1 14.5 13.4 23.6 9.5s13.4-14.5 9.5-23.6l-4.4-10.4c16.6-6.7 31.7-14.4 45.4-22.8L493 450c5.5 8.3 16.7 10.5 25 5s10.5-16.7 5-25l-6-9c13.7-11 25.5-22.8 35.8-34.9l10 8c7.8 6.2 19.1 5 25.3-2.8s5-19.1-2.8-25.3L574.1 357c1.8-2.8 3.5-5.7 5.1-8.5c6.6-11.4 11.8-22.6 16-33l8 3.2c9.2 3.7 19.7-.8 23.4-10s-.8-19.7-10-23.4l-10.4-4.2c.2-.8 .4-1.5 .5-2.3c2.2-9.3 3.4-17.3 4.1-23.4c.4-3.1 .6-5.7 .8-7.8c.1-1.1 .1-2 .2-2.8l.1-1.1 0-.5 0-.2 0-.1c0 0 0-.1-29.1-1c0 0 0 0 .1 0l29.1 .9c.1-3.1 0-6.1-.2-9.1l15.2-4.3c9.6-2.7 15.1-12.7 12.4-22.3s-12.7-15.1-22.3-12.4l-15.6 4.5c-7.6-13.6-18.9-25-32.6-32.6l4.5-15.6c2.7-9.6-2.8-19.5-12.4-22.3s-19.5 2.8-22.3 12.4l-4.3 15.2c-1.2-.1-2.4-.2-3.6-.2c-15.6-.5-30.3 3.3-43 10.2l-9-9c-7-7-18.4-7-25.5 0s-7 18.4 0 25.5l7.2 7.2c-9.3 12.6-15.2 27.8-16.3 44.5l-7.1-3c-9.1-3.9-19.7 .3-23.6 9.5s.3 19.7 9.5 23.6l8.6 3.7c-6.4 9.9-17.3 22.4-36.9 33.3l-1.3-4.4c-2.7-9.6-12.7-15.1-22.3-12.4s-15.1 12.7-12.4 22.3l2.3 8.1c-3.8 1.1-7.7 2.1-11.9 3.1c-11.6 2.7-22.1 7.7-31.1 14.4l-7.2-7.2c-7-7-18.4-7-25.5 0s-7 18.4 0 25.5l9 9c-7.6 13.9-11.3 30.1-10.1 46.6l-15.2 4.3c-9.6 2.7-15.1 12.7-12.4 22.2s12.7 15.1 22.3 12.4l15.6-4.5c7.7 13.9 19.1 25.1 32.6 32.6L322.7 489zM576 241.5c0 0 0 0 0 0c-11.7-.4-27.3-.9-48-1.6l48 1.5zM448 384a32 32 0 1 1 -64 0 32 32 0 1 1 64 0z\"]\n};\nconst faHandLizard = {\n prefix: 'fas',\n iconName: 'hand-lizard',\n icon: [512, 512, [], \"f258\", \"M0 112C0 85.5 21.5 64 48 64l112 0 80 0 46.5 0c36.8 0 71.2 18 92.1 48.2l113.5 164c13 18.7 19.9 41 19.9 63.8l0 12 0 16 0 48c0 17.7-14.3 32-32 32l-96 0c-17.7 0-32-14.3-32-32l0-13.8L273.9 352 240 352l-80 0-48 0c-26.5 0-48-21.5-48-48s21.5-48 48-48l48 0 80 0c26.5 0 48-21.5 48-48s-21.5-48-48-48l-80 0L48 160c-26.5 0-48-21.5-48-48z\"]\n};\nconst faNotdef = {\n prefix: 'fas',\n iconName: 'notdef',\n icon: [384, 512, [], \"e1fe\", \"M64 390.3L153.5 256 64 121.7l0 268.6zM102.5 448l179.1 0L192 313.7 102.5 448zm128-192L320 390.3l0-268.6L230.5 256zM281.5 64L102.5 64 192 198.3 281.5 64zM0 48C0 21.5 21.5 0 48 0L336 0c26.5 0 48 21.5 48 48l0 416c0 26.5-21.5 48-48 48L48 512c-26.5 0-48-21.5-48-48L0 48z\"]\n};\nconst faDisease = {\n prefix: 'fas',\n iconName: 'disease',\n icon: [512, 512, [], \"f7fa\", \"M236.4 61.4L227 75.5c-21.3 32-59.4 48.5-97.3 42.1l-59.6-9.9C33.4 101.6 0 129.9 .1 167.1c0 15.9 6.4 31.2 17.6 42.5l29.2 29.2c11 11 17.2 25.9 17.2 41.5c0 15.8-6.4 30.9-17.7 42L33.3 335.1C22.2 345.9 16 360.7 16 376.2c0 36.8 34.1 64.2 70.1 56.2l62.3-13.8c7.7-1.7 15.7-2.6 23.6-2.6l10 0c27.2 0 53.7 9.3 75 26.3L287.8 467c10.5 8.4 23.6 13 37 13c32.7 0 59.3-26.5 59.3-59.3l0-25.2c0-34.9 21.4-66.2 53.9-78.8l36.9-14.3c22.4-8.7 37.2-30.3 37.2-54.3c0-28.1-20.1-52.3-47.8-57.3l-28-5.1c-36.5-6.7-65.4-34.5-73.6-70.7l-7.1-31.5C348.9 53.4 322.1 32 291.3 32c-22 0-42.6 11-54.9 29.4zM160 192a32 32 0 1 1 0 64 32 32 0 1 1 0-64zm128 16a16 16 0 1 1 32 0 16 16 0 1 1 -32 0zm0 80a32 32 0 1 1 0 64 32 32 0 1 1 0-64z\"]\n};\nconst faBriefcaseMedical = {\n prefix: 'fas',\n iconName: 'briefcase-medical',\n icon: [512, 512, [], \"f469\", \"M184 48l144 0c4.4 0 8 3.6 8 8l0 40L176 96l0-40c0-4.4 3.6-8 8-8zm-56 8l0 40L64 96C28.7 96 0 124.7 0 160L0 416c0 35.3 28.7 64 64 64l384 0c35.3 0 64-28.7 64-64l0-256c0-35.3-28.7-64-64-64l-64 0 0-40c0-30.9-25.1-56-56-56L184 0c-30.9 0-56 25.1-56 56zm96 152c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 48 48 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-48 0 0 48c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-48-48 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16l48 0 0-48z\"]\n};\nconst faGenderless = {\n prefix: 'fas',\n iconName: 'genderless',\n icon: [384, 512, [], \"f22d\", \"M192 144a112 112 0 1 1 0 224 112 112 0 1 1 0-224zm0 288a176 176 0 1 0 0-352 176 176 0 1 0 0 352z\"]\n};\nconst faChevronRight = {\n prefix: 'fas',\n iconName: 'chevron-right',\n icon: [320, 512, [9002], \"f054\", \"M310.6 233.4c12.5 12.5 12.5 32.8 0 45.3l-192 192c-12.5 12.5-32.8 12.5-45.3 0s-12.5-32.8 0-45.3L242.7 256 73.4 86.6c-12.5-12.5-12.5-32.8 0-45.3s32.8-12.5 45.3 0l192 192z\"]\n};\nconst faRetweet = {\n prefix: 'fas',\n iconName: 'retweet',\n icon: [576, 512, [], \"f079\", \"M272 416c17.7 0 32-14.3 32-32s-14.3-32-32-32l-112 0c-17.7 0-32-14.3-32-32l0-128 32 0c12.9 0 24.6-7.8 29.6-19.8s2.2-25.7-6.9-34.9l-64-64c-12.5-12.5-32.8-12.5-45.3 0l-64 64c-9.2 9.2-11.9 22.9-6.9 34.9s16.6 19.8 29.6 19.8l32 0 0 128c0 53 43 96 96 96l112 0zM304 96c-17.7 0-32 14.3-32 32s14.3 32 32 32l112 0c17.7 0 32 14.3 32 32l0 128-32 0c-12.9 0-24.6 7.8-29.6 19.8s-2.2 25.7 6.9 34.9l64 64c12.5 12.5 32.8 12.5 45.3 0l64-64c9.2-9.2 11.9-22.9 6.9-34.9s-16.6-19.8-29.6-19.8l-32 0 0-128c0-53-43-96-96-96L304 96z\"]\n};\nconst faCarRear = {\n prefix: 'fas',\n iconName: 'car-rear',\n icon: [512, 512, [\"car-alt\"], \"f5de\", \"M165.4 96l181.2 0c13.6 0 25.7 8.6 30.2 21.4L402.9 192l-293.8 0 26.1-74.6c4.5-12.8 16.6-21.4 30.2-21.4zm-90.6 .3L39.6 196.8C16.4 206.4 0 229.3 0 256l0 80c0 23.7 12.9 44.4 32 55.4L32 448c0 17.7 14.3 32 32 32l32 0c17.7 0 32-14.3 32-32l0-48 256 0 0 48c0 17.7 14.3 32 32 32l32 0c17.7 0 32-14.3 32-32l0-56.6c19.1-11.1 32-31.7 32-55.4l0-80c0-26.7-16.4-49.6-39.6-59.2L437.2 96.3C423.7 57.8 387.4 32 346.6 32L165.4 32c-40.8 0-77.1 25.8-90.6 64.3zM208 272l96 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-96 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16zM48 280c0-13.3 10.7-24 24-24l32 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-32 0c-13.3 0-24-10.7-24-24zm360-24l32 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-32 0c-13.3 0-24-10.7-24-24s10.7-24 24-24z\"]\n};\nconst faCarAlt = faCarRear;\nconst faPumpSoap = {\n prefix: 'fas',\n iconName: 'pump-soap',\n icon: [448, 512, [], \"e06b\", \"M128 32l0 96 128 0 0-32 60.1 0c4.2 0 8.3 1.7 11.3 4.7l33.9 33.9c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3L372.7 55.4c-15-15-35.4-23.4-56.6-23.4L256 32c0-17.7-14.3-32-32-32L160 0c-17.7 0-32 14.3-32 32zM117.4 160c-33.3 0-61 25.5-63.8 58.7L35 442.7C31.9 480 61.3 512 98.8 512l186.4 0c37.4 0 66.9-32 63.8-69.3l-18.7-224c-2.8-33.2-30.5-58.7-63.8-58.7l-149.1 0zM256 360c0 35.3-28.7 56-64 56s-64-20.7-64-56c0-32.5 37-80.9 50.9-97.9c3.2-3.9 8.1-6.1 13.1-6.1s9.9 2.2 13.1 6.1C219 279.1 256 327.5 256 360z\"]\n};\nconst faVideoSlash = {\n prefix: 'fas',\n iconName: 'video-slash',\n icon: [640, 512, [], \"f4e2\", \"M38.8 5.1C28.4-3.1 13.3-1.2 5.1 9.2S-1.2 34.7 9.2 42.9l592 464c10.4 8.2 25.5 6.3 33.7-4.1s6.3-25.5-4.1-33.7l-86.4-67.7 13.8 9.2c9.8 6.5 22.4 7.2 32.9 1.6s16.9-16.4 16.9-28.2l0-256c0-11.8-6.5-22.6-16.9-28.2s-23-5-32.9 1.6l-96 64L448 174.9l0 17.1 0 128 0 5.8-32-25.1L416 128c0-35.3-28.7-64-64-64L113.9 64 38.8 5.1zM407 416.7L32.3 121.5c-.2 2.1-.3 4.3-.3 6.5l0 256c0 35.3 28.7 64 64 64l256 0c23.4 0 43.9-12.6 55-31.3z\"]\n};\nconst faBatteryQuarter = {\n prefix: 'fas',\n iconName: 'battery-quarter',\n icon: [576, 512, [\"battery-2\"], \"f243\", \"M464 160c8.8 0 16 7.2 16 16l0 160c0 8.8-7.2 16-16 16L80 352c-8.8 0-16-7.2-16-16l0-160c0-8.8 7.2-16 16-16l384 0zM80 96C35.8 96 0 131.8 0 176L0 336c0 44.2 35.8 80 80 80l384 0c44.2 0 80-35.8 80-80l0-16c17.7 0 32-14.3 32-32l0-64c0-17.7-14.3-32-32-32l0-16c0-44.2-35.8-80-80-80L80 96zm112 96l-96 0 0 128 96 0 0-128z\"]\n};\nconst faBattery2 = faBatteryQuarter;\nconst faRadio = {\n prefix: 'fas',\n iconName: 'radio',\n icon: [512, 512, [128251], \"f8d7\", \"M494.8 47c12.7-3.7 20-17.1 16.3-29.8S494-2.8 481.2 1L51.7 126.9c-9.4 2.7-17.9 7.3-25.1 13.2C10.5 151.7 0 170.6 0 192l0 4L0 304 0 448c0 35.3 28.7 64 64 64l384 0c35.3 0 64-28.7 64-64l0-256c0-35.3-28.7-64-64-64l-229.5 0L494.8 47zM368 240a80 80 0 1 1 0 160 80 80 0 1 1 0-160zM80 256c0-8.8 7.2-16 16-16l96 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-96 0c-8.8 0-16-7.2-16-16zM64 320c0-8.8 7.2-16 16-16l128 0c8.8 0 16 7.2 16 16s-7.2 16-16 16L80 336c-8.8 0-16-7.2-16-16zm16 64c0-8.8 7.2-16 16-16l96 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-96 0c-8.8 0-16-7.2-16-16z\"]\n};\nconst faBabyCarriage = {\n prefix: 'fas',\n iconName: 'baby-carriage',\n icon: [512, 512, [\"carriage-baby\"], \"f77d\", \"M256 192L.1 192C2.7 117.9 41.3 52.9 99 14.1c13.3-8.9 30.8-4.3 39.9 8.8L256 192zm128-32c0-35.3 28.7-64 64-64l32 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-32 0 0 64c0 25.2-5.8 50.2-17 73.5s-27.8 44.5-48.6 62.3s-45.5 32-72.7 41.6S253.4 416 224 416s-58.5-5-85.7-14.6s-51.9-23.8-72.7-41.6s-37.3-39-48.6-62.3S0 249.2 0 224l224 0 160 0 0-64zM80 416a48 48 0 1 1 0 96 48 48 0 1 1 0-96zm240 48a48 48 0 1 1 96 0 48 48 0 1 1 -96 0z\"]\n};\nconst faCarriageBaby = faBabyCarriage;\nconst faTrafficLight = {\n prefix: 'fas',\n iconName: 'traffic-light',\n icon: [320, 512, [128678], \"f637\", \"M64 0C28.7 0 0 28.7 0 64L0 352c0 88.4 71.6 160 160 160s160-71.6 160-160l0-288c0-35.3-28.7-64-64-64L64 0zm96 416a48 48 0 1 1 0-96 48 48 0 1 1 0 96zm48-176a48 48 0 1 1 -96 0 48 48 0 1 1 96 0zm-48-80a48 48 0 1 1 0-96 48 48 0 1 1 0 96z\"]\n};\nconst faThermometer = {\n prefix: 'fas',\n iconName: 'thermometer',\n icon: [512, 512, [], \"f491\", \"M96 382.1l0-88.8c0-14.9 5.9-29.1 16.4-39.6l27.3-27.3 57 57c6.2 6.2 16.4 6.2 22.6 0s6.2-16.4 0-22.6l-57-57 41.4-41.4 57 57c6.2 6.2 16.4 6.2 22.6 0s6.2-16.4 0-22.6l-57-57 41.4-41.4 57 57c6.2 6.2 16.4 6.2 22.6 0s6.2-16.4 0-22.6l-57-57 45.5-45.5C355.2 10.9 381.4 0 408.8 0C465.8 0 512 46.2 512 103.2c0 27.4-10.9 53.6-30.2 73L258.3 399.6c-10.5 10.5-24.7 16.4-39.6 16.4l-88.8 0L41 505c-9.4 9.4-24.6 9.4-33.9 0s-9.4-24.6 0-33.9l89-89z\"]\n};\nconst faVrCardboard = {\n prefix: 'fas',\n iconName: 'vr-cardboard',\n icon: [640, 512, [], \"f729\", \"M576 64L64 64C28.7 64 0 92.7 0 128L0 384c0 35.3 28.7 64 64 64l120.4 0c24.2 0 46.4-13.7 57.2-35.4l32-64c8.8-17.5 26.7-28.6 46.3-28.6s37.5 11.1 46.3 28.6l32 64c10.8 21.7 33 35.4 57.2 35.4L576 448c35.3 0 64-28.7 64-64l0-256c0-35.3-28.7-64-64-64zM96 240a64 64 0 1 1 128 0A64 64 0 1 1 96 240zm384-64a64 64 0 1 1 0 128 64 64 0 1 1 0-128z\"]\n};\nconst faHandMiddleFinger = {\n prefix: 'fas',\n iconName: 'hand-middle-finger',\n icon: [448, 512, [128405], \"f806\", \"M232 0c-22.1 0-40 17.9-40 40l0 164.2c-8.5-7.6-19.7-12.2-32-12.2c-26.5 0-48 21.5-48 48l0 7 0 73c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-55.7c-2 1.4-3.9 3-5.8 4.5L55 284.8C40.4 297 32 315 32 334L32 372c0 38 16.9 74 46.1 98.3l5.4 4.5c28.8 24 65 37.1 102.4 37.1L304 512c70.7 0 128-57.3 128-128l0-64 0-32c0-26.5-21.5-48-48-48c-12.4 0-23.6 4.7-32.1 12.3C350 227.5 329.3 208 304 208c-12.3 0-23.5 4.6-32 12.2L272 40c0-22.1-17.9-40-40-40z\"]\n};\nconst faPercent = {\n prefix: 'fas',\n iconName: 'percent',\n icon: [384, 512, [62101, 62785, \"percentage\"], \"25\", \"M374.6 118.6c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0l-320 320c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0l320-320zM128 128A64 64 0 1 0 0 128a64 64 0 1 0 128 0zM384 384a64 64 0 1 0 -128 0 64 64 0 1 0 128 0z\"]\n};\nconst faPercentage = faPercent;\nconst faTruckMoving = {\n prefix: 'fas',\n iconName: 'truck-moving',\n icon: [640, 512, [], \"f4df\", \"M64 32C28.7 32 0 60.7 0 96L0 304l0 80 0 16c0 44.2 35.8 80 80 80c26.2 0 49.4-12.6 64-32c14.6 19.4 37.8 32 64 32c44.2 0 80-35.8 80-80c0-5.5-.6-10.8-1.6-16L416 384l33.6 0c-1 5.2-1.6 10.5-1.6 16c0 44.2 35.8 80 80 80s80-35.8 80-80c0-5.5-.6-10.8-1.6-16l1.6 0c17.7 0 32-14.3 32-32l0-64 0-16 0-10.3c0-9.2-3.2-18.2-9-25.3l-58.8-71.8c-10.6-13-26.5-20.5-43.3-20.5L480 144l0-48c0-35.3-28.7-64-64-64L64 32zM585 256l-105 0 0-64 48.8 0c2.4 0 4.7 1.1 6.2 2.9L585 256zM528 368a32 32 0 1 1 0 64 32 32 0 1 1 0-64zM176 400a32 32 0 1 1 64 0 32 32 0 1 1 -64 0zM80 368a32 32 0 1 1 0 64 32 32 0 1 1 0-64z\"]\n};\nconst faGlassWaterDroplet = {\n prefix: 'fas',\n iconName: 'glass-water-droplet',\n icon: [384, 512, [], \"e4f5\", \"M32 0C23.1 0 14.6 3.7 8.6 10.2S-.6 25.4 .1 34.3L28.9 437.7c3 41.9 37.8 74.3 79.8 74.3l166.6 0c42 0 76.8-32.4 79.8-74.3L383.9 34.3c.6-8.9-2.4-17.6-8.5-24.1S360.9 0 352 0L32 0zM83 297.5L66.4 64l251.3 0L301 297.5 288 304c-20.1 10.1-43.9 10.1-64 0s-43.9-10.1-64 0s-43.9 10.1-64 0l-13-6.5zM256 196c0-24-33.7-70.1-52.2-93.5c-6.1-7.7-17.5-7.7-23.6 0C161.7 125.9 128 172 128 196c0 33.1 28.7 60 64 60s64-26.9 64-60z\"]\n};\nconst faDisplay = {\n prefix: 'fas',\n iconName: 'display',\n icon: [576, 512, [], \"e163\", \"M64 0C28.7 0 0 28.7 0 64L0 352c0 35.3 28.7 64 64 64l176 0-10.7 32L160 448c-17.7 0-32 14.3-32 32s14.3 32 32 32l256 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-69.3 0L336 416l176 0c35.3 0 64-28.7 64-64l0-288c0-35.3-28.7-64-64-64L64 0zM512 64l0 288L64 352 64 64l448 0z\"]\n};\nconst faFaceSmile = {\n prefix: 'fas',\n iconName: 'face-smile',\n icon: [512, 512, [128578, \"smile\"], \"f118\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM164.1 325.5C182 346.2 212.6 368 256 368s74-21.8 91.9-42.5c5.8-6.7 15.9-7.4 22.6-1.6s7.4 15.9 1.6 22.6C349.8 372.1 311.1 400 256 400s-93.8-27.9-116.1-53.5c-5.8-6.7-5.1-16.8 1.6-22.6s16.8-5.1 22.6 1.6zM144.4 208a32 32 0 1 1 64 0 32 32 0 1 1 -64 0zm192-32a32 32 0 1 1 0 64 32 32 0 1 1 0-64z\"]\n};\nconst faSmile = faFaceSmile;\nconst faThumbtack = {\n prefix: 'fas',\n iconName: 'thumbtack',\n icon: [384, 512, [128204, 128392, \"thumb-tack\"], \"f08d\", \"M32 32C32 14.3 46.3 0 64 0L320 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-29.5 0 11.4 148.2c36.7 19.9 65.7 53.2 79.5 94.7l1 3c3.3 9.8 1.6 20.5-4.4 28.8s-15.7 13.3-26 13.3L32 352c-10.3 0-19.9-4.9-26-13.3s-7.7-19.1-4.4-28.8l1-3c13.8-41.5 42.8-74.8 79.5-94.7L93.5 64 64 64C46.3 64 32 49.7 32 32zM160 384l64 0 0 96c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-96z\"]\n};\nconst faThumbTack = faThumbtack;\nconst faTrophy = {\n prefix: 'fas',\n iconName: 'trophy',\n icon: [576, 512, [127942], \"f091\", \"M400 0L176 0c-26.5 0-48.1 21.8-47.1 48.2c.2 5.3 .4 10.6 .7 15.8L24 64C10.7 64 0 74.7 0 88c0 92.6 33.5 157 78.5 200.7c44.3 43.1 98.3 64.8 138.1 75.8c23.4 6.5 39.4 26 39.4 45.6c0 20.9-17 37.9-37.9 37.9L192 448c-17.7 0-32 14.3-32 32s14.3 32 32 32l192 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-26.1 0C337 448 320 431 320 410.1c0-19.6 15.9-39.2 39.4-45.6c39.9-11 93.9-32.7 138.2-75.8C542.5 245 576 180.6 576 88c0-13.3-10.7-24-24-24L446.4 64c.3-5.2 .5-10.4 .7-15.8C448.1 21.8 426.5 0 400 0zM48.9 112l84.4 0c9.1 90.1 29.2 150.3 51.9 190.6c-24.9-11-50.8-26.5-73.2-48.3c-32-31.1-58-76-63-142.3zM464.1 254.3c-22.4 21.8-48.3 37.3-73.2 48.3c22.7-40.3 42.8-100.5 51.9-190.6l84.4 0c-5.1 66.3-31.1 111.2-63 142.3z\"]\n};\nconst faPersonPraying = {\n prefix: 'fas',\n iconName: 'person-praying',\n icon: [448, 512, [128720, \"pray\"], \"f683\", \"M352 64A64 64 0 1 0 224 64a64 64 0 1 0 128 0zM232.7 264l22.9 31.5c6.5 8.9 16.3 14.7 27.2 16.1s21.9-1.7 30.4-8.7l88-72c17.1-14 19.6-39.2 5.6-56.3s-39.2-19.6-56.3-5.6l-55.2 45.2-26.2-36C253.6 156.7 228.6 144 202 144c-30.9 0-59.2 17.1-73.6 44.4L79.8 280.9c-20.2 38.5-9.4 85.9 25.6 111.8L158.6 432 72 432c-22.1 0-40 17.9-40 40s17.9 40 40 40l208 0c17.3 0 32.6-11.1 38-27.5s-.3-34.4-14.2-44.7L187.7 354l45-90z\"]\n};\nconst faPray = faPersonPraying;\nconst faHammer = {\n prefix: 'fas',\n iconName: 'hammer',\n icon: [576, 512, [128296], \"f6e3\", \"M413.5 237.5c-28.2 4.8-58.2-3.6-80-25.4l-38.1-38.1C280.4 159 272 138.8 272 117.6l0-12.1L192.3 62c-5.3-2.9-8.6-8.6-8.3-14.7s3.9-11.5 9.5-14l47.2-21C259.1 4.2 279 0 299.2 0l18.1 0c36.7 0 72 14 98.7 39.1l44.6 42c24.2 22.8 33.2 55.7 26.6 86L503 183l8-8c9.4-9.4 24.6-9.4 33.9 0l24 24c9.4 9.4 9.4 24.6 0 33.9l-88 88c-9.4 9.4-24.6 9.4-33.9 0l-24-24c-9.4-9.4-9.4-24.6 0-33.9l8-8-17.5-17.5zM27.4 377.1L260.9 182.6c3.5 4.9 7.5 9.6 11.8 14l38.1 38.1c6 6 12.4 11.2 19.2 15.7L134.9 484.6c-14.5 17.4-36 27.4-58.6 27.4C34.1 512 0 477.8 0 435.7c0-22.6 10.1-44.1 27.4-58.6z\"]\n};\nconst faHandPeace = {\n prefix: 'fas',\n iconName: 'hand-peace',\n icon: [512, 512, [9996], \"f25b\", \"M224 0c17.7 0 32 14.3 32 32l0 208-64 0 0-208c0-17.7 14.3-32 32-32zm96 160c17.7 0 32 14.3 32 32l0 64c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-64c0-17.7 14.3-32 32-32zm64 64c0-17.7 14.3-32 32-32s32 14.3 32 32l0 64c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-64zM93.3 51.2L175.9 240l-69.9 0L34.7 76.8C27.6 60.6 35 41.8 51.2 34.7s35.1 .3 42.1 16.5zm27 221.3l-.2-.5 69.9 0 26.1 0c22.1 0 40 17.9 40 40s-17.9 40-40 40l-56 0c-8.8 0-16 7.2-16 16s7.2 16 16 16l56 0c39.8 0 72-32.2 72-72l0-.6c9.4 5.4 20.3 8.6 32 8.6c13.2 0 25.4-4 35.6-10.8c8.7 24.9 32.5 42.8 60.4 42.8c11.7 0 22.6-3.1 32-8.6l0 8.6c0 88.4-71.6 160-160 160l-61.7 0c-42.4 0-83.1-16.9-113.1-46.9l-11.6-11.6C77.5 429.5 64 396.9 64 363l0-27c0-32.7 24.6-59.7 56.3-63.5z\"]\n};\nconst faRotate = {\n prefix: 'fas',\n iconName: 'rotate',\n icon: [512, 512, [128260, \"sync-alt\"], \"f2f1\", \"M142.9 142.9c-17.5 17.5-30.1 38-37.8 59.8c-5.9 16.7-24.2 25.4-40.8 19.5s-25.4-24.2-19.5-40.8C55.6 150.7 73.2 122 97.6 97.6c87.2-87.2 228.3-87.5 315.8-1L455 55c6.9-6.9 17.2-8.9 26.2-5.2s14.8 12.5 14.8 22.2l0 128c0 13.3-10.7 24-24 24l-8.4 0c0 0 0 0 0 0L344 224c-9.7 0-18.5-5.8-22.2-14.8s-1.7-19.3 5.2-26.2l41.1-41.1c-62.6-61.5-163.1-61.2-225.3 1zM16 312c0-13.3 10.7-24 24-24l7.6 0 .7 0L168 288c9.7 0 18.5 5.8 22.2 14.8s1.7 19.3-5.2 26.2l-41.1 41.1c62.6 61.5 163.1 61.2 225.3-1c17.5-17.5 30.1-38 37.8-59.8c5.9-16.7 24.2-25.4 40.8-19.5s25.4 24.2 19.5 40.8c-10.8 30.6-28.4 59.3-52.9 83.8c-87.2 87.2-228.3 87.5-315.8 1L57 457c-6.9 6.9-17.2 8.9-26.2 5.2S16 449.7 16 440l0-119.6 0-.7 0-7.6z\"]\n};\nconst faSyncAlt = faRotate;\nconst faSpinner = {\n prefix: 'fas',\n iconName: 'spinner',\n icon: [512, 512, [], \"f110\", \"M304 48a48 48 0 1 0 -96 0 48 48 0 1 0 96 0zm0 416a48 48 0 1 0 -96 0 48 48 0 1 0 96 0zM48 304a48 48 0 1 0 0-96 48 48 0 1 0 0 96zm464-48a48 48 0 1 0 -96 0 48 48 0 1 0 96 0zM142.9 437A48 48 0 1 0 75 369.1 48 48 0 1 0 142.9 437zm0-294.2A48 48 0 1 0 75 75a48 48 0 1 0 67.9 67.9zM369.1 437A48 48 0 1 0 437 369.1 48 48 0 1 0 369.1 437z\"]\n};\nconst faRobot = {\n prefix: 'fas',\n iconName: 'robot',\n icon: [640, 512, [129302], \"f544\", \"M320 0c17.7 0 32 14.3 32 32l0 64 120 0c39.8 0 72 32.2 72 72l0 272c0 39.8-32.2 72-72 72l-304 0c-39.8 0-72-32.2-72-72l0-272c0-39.8 32.2-72 72-72l120 0 0-64c0-17.7 14.3-32 32-32zM208 384c-8.8 0-16 7.2-16 16s7.2 16 16 16l32 0c8.8 0 16-7.2 16-16s-7.2-16-16-16l-32 0zm96 0c-8.8 0-16 7.2-16 16s7.2 16 16 16l32 0c8.8 0 16-7.2 16-16s-7.2-16-16-16l-32 0zm96 0c-8.8 0-16 7.2-16 16s7.2 16 16 16l32 0c8.8 0 16-7.2 16-16s-7.2-16-16-16l-32 0zM264 256a40 40 0 1 0 -80 0 40 40 0 1 0 80 0zm152 40a40 40 0 1 0 0-80 40 40 0 1 0 0 80zM48 224l16 0 0 192-16 0c-26.5 0-48-21.5-48-48l0-96c0-26.5 21.5-48 48-48zm544 0c26.5 0 48 21.5 48 48l0 96c0 26.5-21.5 48-48 48l-16 0 0-192 16 0z\"]\n};\nconst faPeace = {\n prefix: 'fas',\n iconName: 'peace',\n icon: [512, 512, [9774], \"f67c\", \"M224 445.3l0-121.8-94.3 77.1c26.1 22.8 58.5 38.7 94.3 44.7zM89.2 351.1L224 240.8l0-174.2C133.2 81.9 64 160.9 64 256c0 34.6 9.2 67.1 25.2 95.1zm293.1 49.5L288 323.5l0 121.8c35.7-6 68.1-21.9 94.3-44.7zm40.6-49.5c16-28 25.2-60.5 25.2-95.1c0-95.1-69.2-174.1-160-189.3l0 174.2L422.8 351.1zM0 256a256 256 0 1 1 512 0A256 256 0 1 1 0 256z\"]\n};\nconst faGears = {\n prefix: 'fas',\n iconName: 'gears',\n icon: [640, 512, [\"cogs\"], \"f085\", \"M308.5 135.3c7.1-6.3 9.9-16.2 6.2-25c-2.3-5.3-4.8-10.5-7.6-15.5L304 89.4c-3-5-6.3-9.9-9.8-14.6c-5.7-7.6-15.7-10.1-24.7-7.1l-28.2 9.3c-10.7-8.8-23-16-36.2-20.9L199 27.1c-1.9-9.3-9.1-16.7-18.5-17.8C173.9 8.4 167.2 8 160.4 8l-.7 0c-6.8 0-13.5 .4-20.1 1.2c-9.4 1.1-16.6 8.6-18.5 17.8L115 56.1c-13.3 5-25.5 12.1-36.2 20.9L50.5 67.8c-9-3-19-.5-24.7 7.1c-3.5 4.7-6.8 9.6-9.9 14.6l-3 5.3c-2.8 5-5.3 10.2-7.6 15.6c-3.7 8.7-.9 18.6 6.2 25l22.2 19.8C32.6 161.9 32 168.9 32 176s.6 14.1 1.7 20.9L11.5 216.7c-7.1 6.3-9.9 16.2-6.2 25c2.3 5.3 4.8 10.5 7.6 15.6l3 5.2c3 5.1 6.3 9.9 9.9 14.6c5.7 7.6 15.7 10.1 24.7 7.1l28.2-9.3c10.7 8.8 23 16 36.2 20.9l6.1 29.1c1.9 9.3 9.1 16.7 18.5 17.8c6.7 .8 13.5 1.2 20.4 1.2s13.7-.4 20.4-1.2c9.4-1.1 16.6-8.6 18.5-17.8l6.1-29.1c13.3-5 25.5-12.1 36.2-20.9l28.2 9.3c9 3 19 .5 24.7-7.1c3.5-4.7 6.8-9.5 9.8-14.6l3.1-5.4c2.8-5 5.3-10.2 7.6-15.5c3.7-8.7 .9-18.6-6.2-25l-22.2-19.8c1.1-6.8 1.7-13.8 1.7-20.9s-.6-14.1-1.7-20.9l22.2-19.8zM112 176a48 48 0 1 1 96 0 48 48 0 1 1 -96 0zM504.7 500.5c6.3 7.1 16.2 9.9 25 6.2c5.3-2.3 10.5-4.8 15.5-7.6l5.4-3.1c5-3 9.9-6.3 14.6-9.8c7.6-5.7 10.1-15.7 7.1-24.7l-9.3-28.2c8.8-10.7 16-23 20.9-36.2l29.1-6.1c9.3-1.9 16.7-9.1 17.8-18.5c.8-6.7 1.2-13.5 1.2-20.4s-.4-13.7-1.2-20.4c-1.1-9.4-8.6-16.6-17.8-18.5L583.9 307c-5-13.3-12.1-25.5-20.9-36.2l9.3-28.2c3-9 .5-19-7.1-24.7c-4.7-3.5-9.6-6.8-14.6-9.9l-5.3-3c-5-2.8-10.2-5.3-15.6-7.6c-8.7-3.7-18.6-.9-25 6.2l-19.8 22.2c-6.8-1.1-13.8-1.7-20.9-1.7s-14.1 .6-20.9 1.7l-19.8-22.2c-6.3-7.1-16.2-9.9-25-6.2c-5.3 2.3-10.5 4.8-15.6 7.6l-5.2 3c-5.1 3-9.9 6.3-14.6 9.9c-7.6 5.7-10.1 15.7-7.1 24.7l9.3 28.2c-8.8 10.7-16 23-20.9 36.2L315.1 313c-9.3 1.9-16.7 9.1-17.8 18.5c-.8 6.7-1.2 13.5-1.2 20.4s.4 13.7 1.2 20.4c1.1 9.4 8.6 16.6 17.8 18.5l29.1 6.1c5 13.3 12.1 25.5 20.9 36.2l-9.3 28.2c-3 9-.5 19 7.1 24.7c4.7 3.5 9.5 6.8 14.6 9.8l5.4 3.1c5 2.8 10.2 5.3 15.5 7.6c8.7 3.7 18.6 .9 25-6.2l19.8-22.2c6.8 1.1 13.8 1.7 20.9 1.7s14.1-.6 20.9-1.7l19.8 22.2zM464 304a48 48 0 1 1 0 96 48 48 0 1 1 0-96z\"]\n};\nconst faCogs = faGears;\nconst faWarehouse = {\n prefix: 'fas',\n iconName: 'warehouse',\n icon: [640, 512, [], \"f494\", \"M0 488L0 171.3c0-26.2 15.9-49.7 40.2-59.4L308.1 4.8c7.6-3.1 16.1-3.1 23.8 0L599.8 111.9c24.3 9.7 40.2 33.3 40.2 59.4L640 488c0 13.3-10.7 24-24 24l-48 0c-13.3 0-24-10.7-24-24l0-264c0-17.7-14.3-32-32-32l-384 0c-17.7 0-32 14.3-32 32l0 264c0 13.3-10.7 24-24 24l-48 0c-13.3 0-24-10.7-24-24zm488 24l-336 0c-13.3 0-24-10.7-24-24l0-56 384 0 0 56c0 13.3-10.7 24-24 24zM128 400l0-64 384 0 0 64-384 0zm0-96l0-80 384 0 0 80-384 0z\"]\n};\nconst faArrowUpRightDots = {\n prefix: 'fas',\n iconName: 'arrow-up-right-dots',\n icon: [576, 512, [], \"e4b7\", \"M160 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l50.7 0L9.4 265.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0L256 109.3l0 50.7c0 17.7 14.3 32 32 32s32-14.3 32-32l0-128c0-17.7-14.3-32-32-32L160 0zM576 80a48 48 0 1 0 -96 0 48 48 0 1 0 96 0zM448 208a48 48 0 1 0 -96 0 48 48 0 1 0 96 0zM400 384a48 48 0 1 0 0-96 48 48 0 1 0 0 96zm48 80a48 48 0 1 0 -96 0 48 48 0 1 0 96 0zm128 0a48 48 0 1 0 -96 0 48 48 0 1 0 96 0zM272 384a48 48 0 1 0 0-96 48 48 0 1 0 0 96zm48 80a48 48 0 1 0 -96 0 48 48 0 1 0 96 0zM144 512a48 48 0 1 0 0-96 48 48 0 1 0 0 96zM576 336a48 48 0 1 0 -96 0 48 48 0 1 0 96 0zm-48-80a48 48 0 1 0 0-96 48 48 0 1 0 0 96z\"]\n};\nconst faSplotch = {\n prefix: 'fas',\n iconName: 'splotch',\n icon: [512, 512, [], \"f5bc\", \"M208.5 62.3l28.1-36.9C248.8 9.4 267.8 0 288 0c28.5 0 53.6 18.7 61.8 46l17.8 59.4c10.3 34.4 36.1 62 69.8 74.6l39.8 14.9c20.9 7.9 34.8 27.9 34.8 50.2c0 16.9-7.9 32.8-21.5 42.9l-67.3 50.5c-24.3 18.2-37.2 47.9-33.8 78.1l2.5 22.7c4.3 38.7-26 72.6-65 72.6c-14.8 0-29.3-5.1-40.8-14.3l-55.4-44.3c-4.5-3.6-9.3-6.7-14.5-9.2c-15.8-7.9-33.7-10.4-51-7.3L82.4 451.9C47.8 458.2 16 431.6 16 396.5c0-13.2 4.7-26 13.1-36.2l11.2-13.4c14.6-17.4 22.6-39.4 22.6-62.1c0-18.8-5.5-37.2-15.8-53L8.8 173.5C3.1 164.7 0 154.4 0 143.9c0-33.4 30.1-58.8 63-53.2l51.3 8.7c35.9 6.1 72.2-8.2 94.2-37.1z\"]\n};\nconst faFaceGrinHearts = {\n prefix: 'fas',\n iconName: 'face-grin-hearts',\n icon: [512, 512, [128525, \"grin-hearts\"], \"f584\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM388.1 312.8c12.3-3.8 24.3 6.9 19.3 18.7C382.4 390.6 324.2 432 256.3 432s-126.2-41.4-151.1-100.5c-5-11.8 7-22.5 19.3-18.7c39.7 12.2 84.5 19 131.8 19s92.1-6.8 131.8-19zM199.3 129.1c17.8 4.8 28.4 23.1 23.6 40.8l-17.4 65c-2.3 8.5-11.1 13.6-19.6 11.3l-65.1-17.4c-17.8-4.8-28.4-23.1-23.6-40.8s23.1-28.4 40.8-23.6l16.1 4.3 4.3-16.1c4.8-17.8 23.1-28.4 40.8-23.6zm154.3 23.6l4.3 16.1 16.1-4.3c17.8-4.8 36.1 5.8 40.8 23.6s-5.8 36.1-23.6 40.8l-65.1 17.4c-8.5 2.3-17.3-2.8-19.6-11.3l-17.4-65c-4.8-17.8 5.8-36.1 23.6-40.8s36.1 5.8 40.9 23.6z\"]\n};\nconst faGrinHearts = faFaceGrinHearts;\nconst faDiceFour = {\n prefix: 'fas',\n iconName: 'dice-four',\n icon: [448, 512, [9859], \"f524\", \"M0 96C0 60.7 28.7 32 64 32l320 0c35.3 0 64 28.7 64 64l0 320c0 35.3-28.7 64-64 64L64 480c-35.3 0-64-28.7-64-64L0 96zm160 64a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zM128 384a32 32 0 1 0 0-64 32 32 0 1 0 0 64zM352 160a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zM320 384a32 32 0 1 0 0-64 32 32 0 1 0 0 64z\"]\n};\nconst faSimCard = {\n prefix: 'fas',\n iconName: 'sim-card',\n icon: [384, 512, [], \"f7c4\", \"M64 0L242.7 0c17 0 33.3 6.7 45.3 18.7L365.3 96c12 12 18.7 28.3 18.7 45.3L384 448c0 35.3-28.7 64-64 64L64 512c-35.3 0-64-28.7-64-64L0 64C0 28.7 28.7 0 64 0zM96 192c-17.7 0-32 14.3-32 32l0 32 64 0 0-64-32 0zM64 352l80 0 96 0 80 0 0-64-80 0-96 0-80 0 0 64zM320 224c0-17.7-14.3-32-32-32l-32 0 0 64 64 0 0-32zM160 192l0 64 64 0 0-64-64 0zM288 448c17.7 0 32-14.3 32-32l0-32-64 0 0 64 32 0zM160 384l0 64 64 0 0-64-64 0zM64 416c0 17.7 14.3 32 32 32l32 0 0-64-64 0 0 32z\"]\n};\nconst faTransgender = {\n prefix: 'fas',\n iconName: 'transgender',\n icon: [512, 512, [9895, \"transgender-alt\"], \"f225\", \"M112 0c6.5 0 12.3 3.9 14.8 9.9s1.1 12.9-3.5 17.4l-31 31L112 78.1l7-7c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9l-7 7 15.2 15.2C187.7 107.6 220.5 96 256 96s68.3 11.6 94.9 31.2l68.8-68.8-31-31c-4.6-4.6-5.9-11.5-3.5-17.4s8.3-9.9 14.8-9.9l96 0c8.8 0 16 7.2 16 16l0 96c0 6.5-3.9 12.3-9.9 14.8s-12.9 1.1-17.4-3.5l-31-31-68.8 68.8C404.4 187.7 416 220.5 416 256c0 80.2-59 146.6-136 158.2l0 17.8 16 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-16 0 0 8c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-8-16 0c-13.3 0-24-10.7-24-24s10.7-24 24-24l16 0 0-17.8C155 402.6 96 336.2 96 256c0-35.5 11.6-68.3 31.2-94.9L112 145.9l-7 7c-9.4 9.4-24.6 9.4-33.9 0s-9.4-24.6 0-33.9l7-7L58.3 92.3l-31 31c-4.6 4.6-11.5 5.9-17.4 3.5S0 118.5 0 112L0 16C0 7.2 7.2 0 16 0l96 0zM352 256a96 96 0 1 0 -192 0 96 96 0 1 0 192 0z\"]\n};\nconst faTransgenderAlt = faTransgender;\nconst faMercury = {\n prefix: 'fas',\n iconName: 'mercury',\n icon: [384, 512, [9791], \"f223\", \"M72.1 7C85.8-4 106-1.8 117 12c17.6 22 44.7 36 75 36s57.3-14 75-36c11.1-13.8 31.2-16 45-5s16 31.2 5 45c-7.8 9.7-16.6 18.4-26.4 26.1C337.3 109.7 368 163.3 368 224c0 89.1-66.2 162.7-152 174.4l0 25.6 32 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-32 0 0 16c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-16-32 0c-13.3 0-24-10.7-24-24s10.7-24 24-24l32 0 0-25.6C82.2 386.7 16 313.1 16 224c0-60.7 30.7-114.3 77.5-145.9C83.7 70.5 74.9 61.7 67.1 52c-11.1-13.8-8.8-33.9 5-45zM80 224a112 112 0 1 0 224 0A112 112 0 1 0 80 224z\"]\n};\nconst faArrowTurnDown = {\n prefix: 'fas',\n iconName: 'arrow-turn-down',\n icon: [384, 512, [\"level-down\"], \"f149\", \"M32 64C14.3 64 0 49.7 0 32S14.3 0 32 0l96 0c53 0 96 43 96 96l0 306.7 73.4-73.4c12.5-12.5 32.8-12.5 45.3 0s12.5 32.8 0 45.3l-128 128c-12.5 12.5-32.8 12.5-45.3 0l-128-128c-12.5-12.5-12.5-32.8 0-45.3s32.8-12.5 45.3 0L160 402.7 160 96c0-17.7-14.3-32-32-32L32 64z\"]\n};\nconst faLevelDown = faArrowTurnDown;\nconst faPersonFallingBurst = {\n prefix: 'fas',\n iconName: 'person-falling-burst',\n icon: [640, 512, [], \"e547\", \"M256 32c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 9.8c0 39-23.7 74-59.9 88.4C71.6 154.5 32 213 32 278.2L32 352c0 17.7 14.3 32 32 32s32-14.3 32-32l0-73.8c0-10 1.6-19.8 4.5-29L261.1 497.4c9.6 14.8 29.4 19.1 44.3 9.5s19.1-29.4 9.5-44.3L222.6 320l1.4 0 80 0 38.4 51.2c10.6 14.1 30.7 17 44.8 6.4s17-30.7 6.4-44.8l-43.2-57.6C341.3 263.1 327.1 256 312 256l-71.5 0-56.8-80.2-.2-.3c44.7-29 72.5-79 72.5-133.6l0-9.8zM96 80A48 48 0 1 0 0 80a48 48 0 1 0 96 0zM464 286.1l58.6 53.9c4.8 4.4 11.9 5.5 17.8 2.6s9.5-9 9-15.5l-5.6-79.4 78.7-12.2c6.5-1 11.7-5.9 13.1-12.2s-1.1-13-6.5-16.7l-65.6-45.1L603 92.2c3.3-5.7 2.7-12.8-1.4-17.9s-10.9-7.2-17.2-5.3L508.3 92.1l-29.4-74C476.4 12 470.6 8 464 8s-12.4 4-14.9 10.1l-29.4 74L343.6 68.9c-6.3-1.9-13.1 .2-17.2 5.3s-4.6 12.2-1.4 17.9l39.5 69.1-65.6 45.1c-5.4 3.7-8 10.3-6.5 16.7c.1 .3 .1 .6 .2 .8l19.4 0c20.1 0 39.2 7.5 53.8 20.8l18.4 2.9L383 265.3l36.2 48.3c2.1 2.8 3.9 5.7 5.5 8.6L464 286.1z\"]\n};\nconst faAward = {\n prefix: 'fas',\n iconName: 'award',\n icon: [384, 512, [], \"f559\", \"M173.8 5.5c11-7.3 25.4-7.3 36.4 0L228 17.2c6 3.9 13 5.8 20.1 5.4l21.3-1.3c13.2-.8 25.6 6.4 31.5 18.2l9.6 19.1c3.2 6.4 8.4 11.5 14.7 14.7L344.5 83c11.8 5.9 19 18.3 18.2 31.5l-1.3 21.3c-.4 7.1 1.5 14.2 5.4 20.1l11.8 17.8c7.3 11 7.3 25.4 0 36.4L366.8 228c-3.9 6-5.8 13-5.4 20.1l1.3 21.3c.8 13.2-6.4 25.6-18.2 31.5l-19.1 9.6c-6.4 3.2-11.5 8.4-14.7 14.7L301 344.5c-5.9 11.8-18.3 19-31.5 18.2l-21.3-1.3c-7.1-.4-14.2 1.5-20.1 5.4l-17.8 11.8c-11 7.3-25.4 7.3-36.4 0L156 366.8c-6-3.9-13-5.8-20.1-5.4l-21.3 1.3c-13.2 .8-25.6-6.4-31.5-18.2l-9.6-19.1c-3.2-6.4-8.4-11.5-14.7-14.7L39.5 301c-11.8-5.9-19-18.3-18.2-31.5l1.3-21.3c.4-7.1-1.5-14.2-5.4-20.1L5.5 210.2c-7.3-11-7.3-25.4 0-36.4L17.2 156c3.9-6 5.8-13 5.4-20.1l-1.3-21.3c-.8-13.2 6.4-25.6 18.2-31.5l19.1-9.6C65 70.2 70.2 65 73.4 58.6L83 39.5c5.9-11.8 18.3-19 31.5-18.2l21.3 1.3c7.1 .4 14.2-1.5 20.1-5.4L173.8 5.5zM272 192a80 80 0 1 0 -160 0 80 80 0 1 0 160 0zM1.3 441.8L44.4 339.3c.2 .1 .3 .2 .4 .4l9.6 19.1c11.7 23.2 36 37.3 62 35.8l21.3-1.3c.2 0 .5 0 .7 .2l17.8 11.8c5.1 3.3 10.5 5.9 16.1 7.7l-37.6 89.3c-2.3 5.5-7.4 9.2-13.3 9.7s-11.6-2.2-14.8-7.2L74.4 455.5l-56.1 8.3c-5.7 .8-11.4-1.5-15-6s-4.3-10.7-2.1-16zm248 60.4L211.7 413c5.6-1.8 11-4.3 16.1-7.7l17.8-11.8c.2-.1 .4-.2 .7-.2l21.3 1.3c26 1.5 50.3-12.6 62-35.8l9.6-19.1c.1-.2 .2-.3 .4-.4l43.2 102.5c2.2 5.3 1.4 11.4-2.1 16s-9.3 6.9-15 6l-56.1-8.3-32.2 49.2c-3.2 5-8.9 7.7-14.8 7.2s-11-4.3-13.3-9.7z\"]\n};\nconst faTicketSimple = {\n prefix: 'fas',\n iconName: 'ticket-simple',\n icon: [576, 512, [\"ticket-alt\"], \"f3ff\", \"M0 128C0 92.7 28.7 64 64 64l448 0c35.3 0 64 28.7 64 64l0 64c0 8.8-7.4 15.7-15.7 18.6C541.5 217.1 528 235 528 256s13.5 38.9 32.3 45.4c8.3 2.9 15.7 9.8 15.7 18.6l0 64c0 35.3-28.7 64-64 64L64 448c-35.3 0-64-28.7-64-64l0-64c0-8.8 7.4-15.7 15.7-18.6C34.5 294.9 48 277 48 256s-13.5-38.9-32.3-45.4C7.4 207.7 0 200.8 0 192l0-64z\"]\n};\nconst faTicketAlt = faTicketSimple;\nconst faBuilding = {\n prefix: 'fas',\n iconName: 'building',\n icon: [384, 512, [127970, 61687], \"f1ad\", \"M48 0C21.5 0 0 21.5 0 48L0 464c0 26.5 21.5 48 48 48l96 0 0-80c0-26.5 21.5-48 48-48s48 21.5 48 48l0 80 96 0c26.5 0 48-21.5 48-48l0-416c0-26.5-21.5-48-48-48L48 0zM64 240c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32zm112-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16zm80 16c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32zM80 96l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16zm80 16c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32zM272 96l32 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16z\"]\n};\nconst faAnglesLeft = {\n prefix: 'fas',\n iconName: 'angles-left',\n icon: [512, 512, [171, \"angle-double-left\"], \"f100\", \"M41.4 233.4c-12.5 12.5-12.5 32.8 0 45.3l160 160c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3L109.3 256 246.6 118.6c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0l-160 160zm352-160l-160 160c-12.5 12.5-12.5 32.8 0 45.3l160 160c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3L301.3 256 438.6 118.6c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0z\"]\n};\nconst faAngleDoubleLeft = faAnglesLeft;\nconst faQrcode = {\n prefix: 'fas',\n iconName: 'qrcode',\n icon: [448, 512, [], \"f029\", \"M0 80C0 53.5 21.5 32 48 32l96 0c26.5 0 48 21.5 48 48l0 96c0 26.5-21.5 48-48 48l-96 0c-26.5 0-48-21.5-48-48L0 80zM64 96l0 64 64 0 0-64L64 96zM0 336c0-26.5 21.5-48 48-48l96 0c26.5 0 48 21.5 48 48l0 96c0 26.5-21.5 48-48 48l-96 0c-26.5 0-48-21.5-48-48l0-96zm64 16l0 64 64 0 0-64-64 0zM304 32l96 0c26.5 0 48 21.5 48 48l0 96c0 26.5-21.5 48-48 48l-96 0c-26.5 0-48-21.5-48-48l0-96c0-26.5 21.5-48 48-48zm80 64l-64 0 0 64 64 0 0-64zM256 304c0-8.8 7.2-16 16-16l64 0c8.8 0 16 7.2 16 16s7.2 16 16 16l32 0c8.8 0 16-7.2 16-16s7.2-16 16-16s16 7.2 16 16l0 96c0 8.8-7.2 16-16 16l-64 0c-8.8 0-16-7.2-16-16s-7.2-16-16-16s-16 7.2-16 16l0 64c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-160zM368 480a16 16 0 1 1 0-32 16 16 0 1 1 0 32zm64 0a16 16 0 1 1 0-32 16 16 0 1 1 0 32z\"]\n};\nconst faClockRotateLeft = {\n prefix: 'fas',\n iconName: 'clock-rotate-left',\n icon: [512, 512, [\"history\"], \"f1da\", \"M75 75L41 41C25.9 25.9 0 36.6 0 57.9L0 168c0 13.3 10.7 24 24 24l110.1 0c21.4 0 32.1-25.9 17-41l-30.8-30.8C155 85.5 203 64 256 64c106 0 192 86 192 192s-86 192-192 192c-40.8 0-78.6-12.7-109.7-34.4c-14.5-10.1-34.4-6.6-44.6 7.9s-6.6 34.4 7.9 44.6C151.2 495 201.7 512 256 512c141.4 0 256-114.6 256-256S397.4 0 256 0C185.3 0 121.3 28.7 75 75zm181 53c-13.3 0-24 10.7-24 24l0 104c0 6.4 2.5 12.5 7 17l72 72c9.4 9.4 24.6 9.4 33.9 0s9.4-24.6 0-33.9l-65-65 0-94.1c0-13.3-10.7-24-24-24z\"]\n};\nconst faHistory = faClockRotateLeft;\nconst faFaceGrinBeamSweat = {\n prefix: 'fas',\n iconName: 'face-grin-beam-sweat',\n icon: [512, 512, [128517, \"grin-beam-sweat\"], \"f583\", \"M476.8 126.3c-4.1 1.1-8.4 1.7-12.8 1.7c-26.5 0-48-21-48-47c0-5 1.8-11.3 4.6-18.1c.3-.7 .6-1.4 .9-2.1c9-20.2 26.5-44.9 36-57.5c3.2-4.4 9.6-4.4 12.8 0C483.4 20.6 512 61 512 81c0 21.7-14.9 39.8-35.2 45.3zM256 0c51.4 0 99.3 15.2 139.4 41.2c-1.5 3.1-3 6.2-4.3 9.3c-3.4 8-7.1 19-7.1 30.5c0 44.3 36.6 79 80 79c9.6 0 18.8-1.7 27.4-4.8c13.3 30.9 20.6 65 20.6 100.8c0 141.4-114.6 256-256 256S0 397.4 0 256S114.6 0 256 0zM383.8 317.8C345.3 329.4 301.9 336 256 336s-89.3-6.6-127.8-18.2c-12.3-3.7-24.3 7-19.2 18.7c24.5 56.9 81.1 96.7 147 96.7s122.5-39.8 147-96.7c5.1-11.8-6.9-22.4-19.2-18.7zm-166.2-89s0 0 0 0s0 0 0 0c2.1 2.8 5.7 3.9 8.9 2.8s5.5-4.1 5.5-7.6c0-17.9-6.7-35.6-16.6-48.8c-9.8-13-23.9-23.2-39.4-23.2s-29.6 10.2-39.4 23.2C126.7 188.4 120 206.1 120 224c0 3.4 2.2 6.5 5.5 7.6s6.9 0 8.9-2.8c0 0 0 0 0 0s0 0 0 0c0 0 0 0 0 0l.2-.2c.2-.2 .4-.5 .7-.9c.6-.8 1.6-2 2.8-3.4c2.5-2.8 6-6.6 10.2-10.3c8.8-7.8 18.8-14 27.7-14s18.9 6.2 27.7 14c4.2 3.7 7.7 7.5 10.2 10.3c1.2 1.4 2.2 2.6 2.8 3.4c.3 .4 .6 .7 .7 .9l.2 .2c0 0 0 0 0 0c0 0 0 0 0 0zm160 0s0 0 0 0s0 0 0 0s0 0 0 0c2.1 2.8 5.7 3.9 8.9 2.8s5.5-4.1 5.5-7.6c0-17.9-6.7-35.6-16.6-48.8c-9.8-13-23.9-23.2-39.4-23.2s-29.6 10.2-39.4 23.2C286.7 188.4 280 206.1 280 224c0 3.4 2.2 6.5 5.5 7.6s6.9 0 8.9-2.8c0 0 0 0 0 0s0 0 0 0c0 0 0 0 0 0l.2-.2c.2-.2 .4-.5 .7-.9c.6-.8 1.6-2 2.8-3.4c2.5-2.8 6-6.6 10.2-10.3c8.8-7.8 18.8-14 27.7-14s18.9 6.2 27.7 14c4.2 3.7 7.7 7.5 10.2 10.3c1.2 1.4 2.2 2.6 2.8 3.4c.3 .4 .6 .7 .7 .9l.2 .2c0 0 0 0 0 0z\"]\n};\nconst faGrinBeamSweat = faFaceGrinBeamSweat;\nconst faFileExport = {\n prefix: 'fas',\n iconName: 'file-export',\n icon: [576, 512, [\"arrow-right-from-file\"], \"f56e\", \"M0 64C0 28.7 28.7 0 64 0L224 0l0 128c0 17.7 14.3 32 32 32l128 0 0 128-168 0c-13.3 0-24 10.7-24 24s10.7 24 24 24l168 0 0 112c0 35.3-28.7 64-64 64L64 512c-35.3 0-64-28.7-64-64L0 64zM384 336l0-48 110.1 0-39-39c-9.4-9.4-9.4-24.6 0-33.9s24.6-9.4 33.9 0l80 80c9.4 9.4 9.4 24.6 0 33.9l-80 80c-9.4 9.4-24.6 9.4-33.9 0s-9.4-24.6 0-33.9l39-39L384 336zm0-208l-128 0L256 0 384 128z\"]\n};\nconst faArrowRightFromFile = faFileExport;\nconst faShield = {\n prefix: 'fas',\n iconName: 'shield',\n icon: [512, 512, [128737, \"shield-blank\"], \"f132\", \"M256 0c4.6 0 9.2 1 13.4 2.9L457.7 82.8c22 9.3 38.4 31 38.3 57.2c-.5 99.2-41.3 280.7-213.6 363.2c-16.7 8-36.1 8-52.8 0C57.3 420.7 16.5 239.2 16 140c-.1-26.2 16.3-47.9 38.3-57.2L242.7 2.9C246.8 1 251.4 0 256 0z\"]\n};\nconst faShieldBlank = faShield;\nconst faArrowUpShortWide = {\n prefix: 'fas',\n iconName: 'arrow-up-short-wide',\n icon: [576, 512, [\"sort-amount-up-alt\"], \"f885\", \"M151.6 42.4C145.5 35.8 137 32 128 32s-17.5 3.8-23.6 10.4l-88 96c-11.9 13-11.1 33.3 2 45.2s33.3 11.1 45.2-2L96 146.3 96 448c0 17.7 14.3 32 32 32s32-14.3 32-32l0-301.7 32.4 35.4c11.9 13 32.2 13.9 45.2 2s13.9-32.2 2-45.2l-88-96zM320 32c-17.7 0-32 14.3-32 32s14.3 32 32 32l32 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-32 0zm0 128c-17.7 0-32 14.3-32 32s14.3 32 32 32l96 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-96 0zm0 128c-17.7 0-32 14.3-32 32s14.3 32 32 32l160 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-160 0zm0 128c-17.7 0-32 14.3-32 32s14.3 32 32 32l224 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-224 0z\"]\n};\nconst faSortAmountUpAlt = faArrowUpShortWide;\nconst faCommentNodes = {\n prefix: 'fas',\n iconName: 'comment-nodes',\n icon: [640, 512, [], \"e696\", \"M256 448c10.8 0 21.5-.5 32-1.6c.3-15.8 4.4-31.7 12.9-46.4c16-27.7 43.7-44.4 73.2-47.5l16.7-29.2c-4.3-11-6.7-22.9-6.7-35.4c0-53 43-96 96-96c9.1 0 17.8 1.3 26.2 3.6C481.1 102.1 378.6 32 256 32C114.6 32 0 125.1 0 240c0 45.1 17.7 86.8 47.7 120.9c-1.9 24.5-11.4 46.3-21.4 62.9c-5.5 9.2-11.1 16.6-15.2 21.6c-2.1 2.5-3.7 4.4-4.9 5.7c-.2 .3-.4 .5-.6 .7c-.3 .3-.5 .5-.6 .7l-.3 .3c0 0 0 0 0 0c0 0 0 0 0 0s0 0 0 0s0 0 0 0c-4.6 4.6-5.9 11.4-3.4 17.4c2.5 6 8.3 9.9 14.8 9.9c28.7 0 57.6-8.9 81.6-19.3c22.9-10 42.4-21.9 54.3-30.6c31.8 11.5 67 17.9 104.1 17.9zm72.6-32c-17.7 30.6-7.2 69.7 23.4 87.4s69.7 7.2 87.4-23.4c1.5-2.6 2.8-5.3 3.9-8l73.3 0c1.1 2.7 2.4 5.4 3.9 8c17.7 30.6 56.8 41.1 87.4 23.4s41.1-56.8 23.4-87.4c-13.4-23.2-39.1-34.8-64-31.4l-17.6-30.7c-11 11.7-25 20.6-40.6 25.6l16.5 28.9c-3.8 4.8-6.8 10-9 15.6l-73.4 0c-2.2-5.6-5.3-10.8-9-15.6l33-57.7c4.1 .8 8.4 1.3 12.8 1.3c35.3 0 64-28.7 64-64s-28.7-64-64-64s-64 28.7-64 64c0 13.4 4.1 25.8 11.2 36.1l-34.6 60.5c-25-3.4-50.6 8.3-64 31.4z\"]\n};\nconst faHouseMedical = {\n prefix: 'fas',\n iconName: 'house-medical',\n icon: [576, 512, [], \"e3b2\", \"M543.8 287.6c17 0 32-14 32-32.1c1-9-3-17-11-24L309.5 7c-6-5-14-7-21-7s-15 1-22 8L10 231.5c-7 7-10 15-10 24c0 18 14 32.1 32 32.1l32 0 0 160.4c0 35.3 28.7 64 64 64l320.4 0c35.5 0 64.2-28.8 64-64.3l-.7-160.2 32 0zM256 208c0-8.8 7.2-16 16-16l32 0c8.8 0 16 7.2 16 16l0 48 48 0c8.8 0 16 7.2 16 16l0 32c0 8.8-7.2 16-16 16l-48 0 0 48c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-48-48 0c-8.8 0-16-7.2-16-16l0-32c0-8.8 7.2-16 16-16l48 0 0-48z\"]\n};\nconst faGolfBallTee = {\n prefix: 'fas',\n iconName: 'golf-ball-tee',\n icon: [384, 512, [\"golf-ball\"], \"f450\", \"M384 192c0 66.8-34.1 125.6-85.8 160L85.8 352C34.1 317.6 0 258.8 0 192C0 86 86 0 192 0S384 86 384 192zM242.1 256.6c0 18.5-15 33.5-33.5 33.5c-4.9 0-9.1 5.1-5.4 8.4c5.9 5.2 13.7 8.4 22.1 8.4c18.5 0 33.5-15 33.5-33.5c0-8.5-3.2-16.2-8.4-22.1c-3.3-3.7-8.4 .5-8.4 5.4zm-52.3-49.3c-4.9 0-9.1 5.1-5.4 8.4c5.9 5.2 13.7 8.4 22.1 8.4c18.5 0 33.5-15 33.5-33.5c0-8.5-3.2-16.2-8.4-22.1c-3.3-3.7-8.4 .5-8.4 5.4c0 18.5-15 33.5-33.5 33.5zm113.5-17.5c0 18.5-15 33.5-33.5 33.5c-4.9 0-9.1 5.1-5.4 8.4c5.9 5.2 13.7 8.4 22.1 8.4c18.5 0 33.5-15 33.5-33.5c0-8.5-3.2-16.2-8.4-22.1c-3.3-3.7-8.4 .5-8.4 5.4zM96 416c0-17.7 14.3-32 32-32l64 0 64 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-16 0c-8.8 0-16 7.2-16 16l0 16c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-16c0-8.8-7.2-16-16-16l-16 0c-17.7 0-32-14.3-32-32z\"]\n};\nconst faGolfBall = faGolfBallTee;\nconst faCircleChevronLeft = {\n prefix: 'fas',\n iconName: 'circle-chevron-left',\n icon: [512, 512, [\"chevron-circle-left\"], \"f137\", \"M512 256A256 256 0 1 0 0 256a256 256 0 1 0 512 0zM271 135c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9l-87 87 87 87c9.4 9.4 9.4 24.6 0 33.9s-24.6 9.4-33.9 0L167 273c-9.4-9.4-9.4-24.6 0-33.9L271 135z\"]\n};\nconst faChevronCircleLeft = faCircleChevronLeft;\nconst faHouseChimneyWindow = {\n prefix: 'fas',\n iconName: 'house-chimney-window',\n icon: [576, 512, [], \"e00d\", \"M575.8 255.5c0 18-15 32.1-32 32.1l-32 0 .7 160.2c.2 35.5-28.5 64.3-64 64.3l-320.4 0c-35.3 0-64-28.7-64-64l0-160.4-32 0c-18 0-32-14-32-32.1c0-9 3-17 10-24L266.4 8c7-7 15-8 22-8s15 2 21 7L416 100.7 416 64c0-17.7 14.3-32 32-32l32 0c17.7 0 32 14.3 32 32l0 121 52.8 46.4c8 7 12 15 11 24zM248 192c-13.3 0-24 10.7-24 24l0 80c0 13.3 10.7 24 24 24l80 0c13.3 0 24-10.7 24-24l0-80c0-13.3-10.7-24-24-24l-80 0z\"]\n};\nconst faPenNib = {\n prefix: 'fas',\n iconName: 'pen-nib',\n icon: [512, 512, [10001], \"f5ad\", \"M368.4 18.3L312.7 74.1 437.9 199.3l55.7-55.7c21.9-21.9 21.9-57.3 0-79.2L447.6 18.3c-21.9-21.9-57.3-21.9-79.2 0zM288 94.6l-9.2 2.8L134.7 140.6c-19.9 6-35.7 21.2-42.3 41L3.8 445.8c-3.8 11.3-1 23.9 7.3 32.4L164.7 324.7c-3-6.3-4.7-13.3-4.7-20.7c0-26.5 21.5-48 48-48s48 21.5 48 48s-21.5 48-48 48c-7.4 0-14.4-1.7-20.7-4.7L33.7 500.9c8.6 8.3 21.1 11.2 32.4 7.3l264.3-88.6c19.7-6.6 35-22.4 41-42.3l43.2-144.1 2.7-9.2L288 94.6z\"]\n};\nconst faTentArrowTurnLeft = {\n prefix: 'fas',\n iconName: 'tent-arrow-turn-left',\n icon: [576, 512, [], \"e580\", \"M120.1 41.8c9.9-8.9 10.7-24 1.8-33.9S97.8-2.7 87.9 6.2l-80 72C2.9 82.7 0 89.2 0 96s2.9 13.3 7.9 17.8l80 72c9.9 8.9 25 8.1 33.9-1.8s8.1-25-1.8-33.9L86.5 120 456 120c39.8 0 72 32.2 72 72l0 40c0 13.3 10.7 24 24 24s24-10.7 24-24l0-40c0-66.3-53.7-120-120-120L86.5 72l33.5-30.2zM307.4 166.5c-11.5-8.7-27.3-8.7-38.8 0l-168 128c-6.6 5-11 12.5-12.3 20.7l-24 160c-1.4 9.2 1.3 18.6 7.4 25.6S86.7 512 96 512l144 0 16 0c17.7 0 32-14.3 32-32l0-118.1c0-5.5 4.4-9.9 9.9-9.9c3.7 0 7.2 2.1 8.8 5.5l68.4 136.8c5.4 10.8 16.5 17.7 28.6 17.7l60.2 0 16 0c9.3 0 18.2-4.1 24.2-11.1s8.8-16.4 7.4-25.6l-24-160c-1.2-8.2-5.6-15.7-12.3-20.7l-168-128z\"]\n};\nconst faTents = {\n prefix: 'fas',\n iconName: 'tents',\n icon: [640, 512, [], \"e582\", \"M396.6 6.5L235.8 129.1c9.6 1.8 18.9 5.8 27 12l168 128c13.2 10.1 22 24.9 24.5 41.4l6.2 41.5L608 352c9.3 0 18.2-4.1 24.2-11.1s8.8-16.4 7.4-25.6l-24-160c-1.2-8.2-5.6-15.7-12.3-20.7l-168-128c-11.5-8.7-27.3-8.7-38.8 0zm-153.2 160c-11.5-8.7-27.3-8.7-38.8 0l-168 128c-6.6 5-11 12.5-12.3 20.7l-24 160c-1.4 9.2 1.3 18.6 7.4 25.6S22.7 512 32 512l144 0 16 0c17.7 0 32-14.3 32-32l0-118.1c0-5.5 4.4-9.9 9.9-9.9c3.7 0 7.2 2.1 8.8 5.5l68.4 136.8c5.4 10.8 16.5 17.7 28.6 17.7l60.2 0 16 0c9.3 0 18.2-4.1 24.2-11.1s8.8-16.4 7.4-25.6l-24-160c-1.2-8.2-5.6-15.7-12.3-20.7l-168-128z\"]\n};\nconst faWandMagic = {\n prefix: 'fas',\n iconName: 'wand-magic',\n icon: [512, 512, [\"magic\"], \"f0d0\", \"M14.1 463.3c-18.7-18.7-18.7-49.1 0-67.9L395.4 14.1c18.7-18.7 49.1-18.7 67.9 0l34.6 34.6c18.7 18.7 18.7 49.1 0 67.9L116.5 497.9c-18.7 18.7-49.1 18.7-67.9 0L14.1 463.3zM347.6 187.6l105-105L429.4 59.3l-105 105 23.3 23.3z\"]\n};\nconst faMagic = faWandMagic;\nconst faDog = {\n prefix: 'fas',\n iconName: 'dog',\n icon: [576, 512, [128021], \"f6d3\", \"M309.6 158.5L332.7 19.8C334.6 8.4 344.5 0 356.1 0c7.5 0 14.5 3.5 19 9.5L392 32l52.1 0c12.7 0 24.9 5.1 33.9 14.1L496 64l56 0c13.3 0 24 10.7 24 24l0 24c0 44.2-35.8 80-80 80l-32 0-16 0-21.3 0-5.1 30.5-112-64zM416 256.1L416 480c0 17.7-14.3 32-32 32l-32 0c-17.7 0-32-14.3-32-32l0-115.2c-24 12.3-51.2 19.2-80 19.2s-56-6.9-80-19.2L160 480c0 17.7-14.3 32-32 32l-32 0c-17.7 0-32-14.3-32-32l0-230.2c-28.8-10.9-51.4-35.3-59.2-66.5L1 167.8c-4.3-17.1 6.1-34.5 23.3-38.8s34.5 6.1 38.8 23.3l3.9 15.5C70.5 182 83.3 192 98 192l30 0 16 0 159.8 0L416 256.1zM464 80a16 16 0 1 0 -32 0 16 16 0 1 0 32 0z\"]\n};\nconst faCarrot = {\n prefix: 'fas',\n iconName: 'carrot',\n icon: [512, 512, [129365], \"f787\", \"M346.7 6C337.6 17 320 42.3 320 72c0 40 15.3 55.3 40 80s40 40 80 40c29.7 0 55-17.6 66-26.7c4-3.3 6-8.2 6-13.3s-2-10-6-13.2c-11.4-9.1-38.3-26.8-74-26.8c-32 0-40 8-40 8s8-8 8-40c0-35.7-17.7-62.6-26.8-74C370 2 365.1 0 360 0s-10 2-13.3 6zM244.6 136c-40 0-77.1 18.1-101.7 48.2l60.5 60.5c6.2 6.2 6.2 16.4 0 22.6s-16.4 6.2-22.6 0l-55.3-55.3 0 .1L2.2 477.9C-2 487-.1 497.8 7 505s17.9 9 27.1 4.8l134.7-62.4-52.1-52.1c-6.2-6.2-6.2-16.4 0-22.6s16.4-6.2 22.6 0L199.7 433l100.2-46.4c46.4-21.5 76.2-68 76.2-119.2C376 194.8 317.2 136 244.6 136z\"]\n};\nconst faMoon = {\n prefix: 'fas',\n iconName: 'moon',\n icon: [384, 512, [127769, 9214], \"f186\", \"M223.5 32C100 32 0 132.3 0 256S100 480 223.5 480c60.6 0 115.5-24.2 155.8-63.4c5-4.9 6.3-12.5 3.1-18.7s-10.1-9.7-17-8.5c-9.8 1.7-19.8 2.6-30.1 2.6c-96.9 0-175.5-78.8-175.5-176c0-65.8 36-123.1 89.3-153.3c6.1-3.5 9.2-10.5 7.7-17.3s-7.3-11.9-14.3-12.5c-6.3-.5-12.6-.8-19-.8z\"]\n};\nconst faWineGlassEmpty = {\n prefix: 'fas',\n iconName: 'wine-glass-empty',\n icon: [320, 512, [\"wine-glass-alt\"], \"f5ce\", \"M64 0C47.4 0 33.5 12.8 32.1 29.3l-14 168.4c-6 72 42.5 135.2 109.9 150.6l0 99.6-48 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l80 0 80 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-48 0 0-99.6c67.4-15.4 115.9-78.6 109.9-150.6l-14-168.4C286.5 12.8 272.6 0 256 0L64 0zM81.9 203.1L93.4 64l133.1 0 11.6 139.1C242 248.8 205.9 288 160 288s-82-39.2-78.1-84.9z\"]\n};\nconst faWineGlassAlt = faWineGlassEmpty;\nconst faCheese = {\n prefix: 'fas',\n iconName: 'cheese',\n icon: [512, 512, [], \"f7ef\", \"M512 240.2l0 15.8L0 256c0-20 10-38.7 26.6-49.8L274.9 40.7c8.6-5.7 18.6-8.7 28.9-8.7C418.8 32 512 125.2 512 240.2zm0 47.8l0 128c0 35.3-28.7 64-64 64L64 480c-35.3 0-64-28.7-64-64L0 288l512 0z\"]\n};\nconst faYinYang = {\n prefix: 'fas',\n iconName: 'yin-yang',\n icon: [512, 512, [9775], \"f6ad\", \"M256 64c53 0 96 43 96 96s-43 96-96 96s-96 43-96 96s43 96 96 96C150 448 64 362 64 256S150 64 256 64zm0 448A256 256 0 1 0 256 0a256 256 0 1 0 0 512zm32-352a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zM224 352a32 32 0 1 1 64 0 32 32 0 1 1 -64 0z\"]\n};\nconst faMusic = {\n prefix: 'fas',\n iconName: 'music',\n icon: [512, 512, [127925], \"f001\", \"M499.1 6.3c8.1 6 12.9 15.6 12.9 25.7l0 72 0 264c0 44.2-43 80-96 80s-96-35.8-96-80s43-80 96-80c11.2 0 22 1.6 32 4.6L448 147 192 223.8 192 432c0 44.2-43 80-96 80s-96-35.8-96-80s43-80 96-80c11.2 0 22 1.6 32 4.6L128 200l0-72c0-14.1 9.3-26.6 22.8-30.7l320-96c9.7-2.9 20.2-1.1 28.3 5z\"]\n};\nconst faCodeCommit = {\n prefix: 'fas',\n iconName: 'code-commit',\n icon: [640, 512, [], \"f386\", \"M320 336a80 80 0 1 0 0-160 80 80 0 1 0 0 160zm156.8-48C462 361 397.4 416 320 416s-142-55-156.8-128L32 288c-17.7 0-32-14.3-32-32s14.3-32 32-32l131.2 0C178 151 242.6 96 320 96s142 55 156.8 128L608 224c17.7 0 32 14.3 32 32s-14.3 32-32 32l-131.2 0z\"]\n};\nconst faTemperatureLow = {\n prefix: 'fas',\n iconName: 'temperature-low',\n icon: [512, 512, [], \"f76b\", \"M448 96a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zM320 96a96 96 0 1 1 192 0A96 96 0 1 1 320 96zM144 64c-26.5 0-48 21.5-48 48l0 164.5c0 17.3-7.1 31.9-15.3 42.5C70.2 332.6 64 349.5 64 368c0 44.2 35.8 80 80 80s80-35.8 80-80c0-18.5-6.2-35.4-16.7-48.9c-8.2-10.6-15.3-25.2-15.3-42.5L192 112c0-26.5-21.5-48-48-48zM32 112C32 50.2 82.1 0 144 0s112 50.1 112 112l0 164.4c0 .1 .1 .3 .2 .6c.2 .6 .8 1.6 1.7 2.8c18.9 24.4 30.1 55 30.1 88.1c0 79.5-64.5 144-144 144S0 447.5 0 368c0-33.2 11.2-63.8 30.1-88.1c.9-1.2 1.5-2.2 1.7-2.8c.1-.3 .2-.5 .2-.6L32 112zM192 368c0 26.5-21.5 48-48 48s-48-21.5-48-48c0-20.9 13.4-38.7 32-45.3l0-50.7c0-8.8 7.2-16 16-16s16 7.2 16 16l0 50.7c18.6 6.6 32 24.4 32 45.3z\"]\n};\nconst faPersonBiking = {\n prefix: 'fas',\n iconName: 'person-biking',\n icon: [640, 512, [128692, \"biking\"], \"f84a\", \"M400 96a48 48 0 1 0 0-96 48 48 0 1 0 0 96zm27.2 64l-61.8-48.8c-17.3-13.6-41.7-13.8-59.1-.3l-83.1 64.2c-30.7 23.8-28.5 70.8 4.3 91.6L288 305.1 288 416c0 17.7 14.3 32 32 32s32-14.3 32-32l0-128c0-10.7-5.3-20.7-14.2-26.6L295 232.9l60.3-48.5L396 217c5.7 4.5 12.7 7 20 7l64 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-52.8 0zM56 384a72 72 0 1 1 144 0A72 72 0 1 1 56 384zm200 0A128 128 0 1 0 0 384a128 128 0 1 0 256 0zm184 0a72 72 0 1 1 144 0 72 72 0 1 1 -144 0zm200 0a128 128 0 1 0 -256 0 128 128 0 1 0 256 0z\"]\n};\nconst faBiking = faPersonBiking;\nconst faBroom = {\n prefix: 'fas',\n iconName: 'broom',\n icon: [576, 512, [129529], \"f51a\", \"M566.6 54.6c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0l-192 192-34.7-34.7c-4.2-4.2-10-6.6-16-6.6c-12.5 0-22.6 10.1-22.6 22.6l0 29.1L364.3 320l29.1 0c12.5 0 22.6-10.1 22.6-22.6c0-6-2.4-11.8-6.6-16l-34.7-34.7 192-192zM341.1 353.4L222.6 234.9c-42.7-3.7-85.2 11.7-115.8 42.3l-8 8C76.5 307.5 64 337.7 64 369.2c0 6.8 7.1 11.2 13.2 8.2l51.1-25.5c5-2.5 9.5 4.1 5.4 7.9L7.3 473.4C2.7 477.6 0 483.6 0 489.9C0 502.1 9.9 512 22.1 512l173.3 0c38.8 0 75.9-15.4 103.4-42.8c30.6-30.6 45.9-73.1 42.3-115.8z\"]\n};\nconst faShieldHeart = {\n prefix: 'fas',\n iconName: 'shield-heart',\n icon: [512, 512, [], \"e574\", \"M269.4 2.9C265.2 1 260.7 0 256 0s-9.2 1-13.4 2.9L54.3 82.8c-22 9.3-38.4 31-38.3 57.2c.5 99.2 41.3 280.7 213.6 363.2c16.7 8 36.1 8 52.8 0C454.7 420.7 495.5 239.2 496 140c.1-26.2-16.3-47.9-38.3-57.2L269.4 2.9zM144 221.3c0-33.8 27.4-61.3 61.3-61.3c16.2 0 31.8 6.5 43.3 17.9l7.4 7.4 7.4-7.4c11.5-11.5 27.1-17.9 43.3-17.9c33.8 0 61.3 27.4 61.3 61.3c0 16.2-6.5 31.8-17.9 43.3l-82.7 82.7c-6.2 6.2-16.4 6.2-22.6 0l-82.7-82.7c-11.5-11.5-17.9-27.1-17.9-43.3z\"]\n};\nconst faGopuram = {\n prefix: 'fas',\n iconName: 'gopuram',\n icon: [512, 512, [], \"f664\", \"M120 0c13.3 0 24 10.7 24 24l0 8 40 0 0-8c0-13.3 10.7-24 24-24s24 10.7 24 24l0 8 48 0 0-8c0-13.3 10.7-24 24-24s24 10.7 24 24l0 8 40 0 0-8c0-13.3 10.7-24 24-24s24 10.7 24 24l0 8 0 32 0 64c17.7 0 32 14.3 32 32l0 64c17.7 0 32 14.3 32 32l0 96c17.7 0 32 14.3 32 32l0 96c0 17.7-14.3 32-32 32l-64 0 0-160-32 0 0-128-32 0 0-96-32 0 0 96 32 0 0 128 32 0 0 160-80 0 0-48c0-26.5-21.5-48-48-48s-48 21.5-48 48l0 48-80 0 0-160 32 0 0-128 32 0 0-96-32 0 0 96-32 0 0 128-32 0 0 160-64 0c-17.7 0-32-14.3-32-32l0-96c0-17.7 14.3-32 32-32l0-96c0-17.7 14.3-32 32-32l0-64c0-17.7 14.3-32 32-32l0-64 0-32 0-8c0-13.3 10.7-24 24-24zM256 272c-17.7 0-32 14.3-32 32l0 48 64 0 0-48c0-17.7-14.3-32-32-32zm-32-80l0 32 64 0 0-32c0-17.7-14.3-32-32-32s-32 14.3-32 32z\"]\n};\nconst faEarthOceania = {\n prefix: 'fas',\n iconName: 'earth-oceania',\n icon: [512, 512, [\"globe-oceania\"], \"e47b\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM208.6 357.3l-39-13.5c-6.5-2.2-13.6-2.3-20.1-.3l-15.3 4.9c-18.5 5.9-38.5-2.4-47.5-19.5l-3.3-6.2c-10.6-20.1-2.3-45 18.2-54.7l35.3-16.8c2.3-1.1 4.4-2.8 5.9-4.8l5.3-7c7.2-9.6 18.6-15.3 30.6-15.3s23.4 5.7 30.6 15.3l4.6 6.1c2 2.6 4.9 4.5 8.1 5.1c7.8 1.6 15.7-1.5 20.4-7.9l10.4-14.2c2-2.8 5.3-4.4 8.7-4.4c4.4 0 8.4 2.7 10 6.8l10.1 25.9c2.8 7.2 6.7 14 11.5 20.2L311 299.8c5.8 7.4 9 16.6 9 26s-3.2 18.6-9 26L299 367.2c-8.3 10.6-21 16.8-34.4 16.8c-8.4 0-16.6-2.4-23.7-7l-25.4-16.4c-2.2-1.4-4.5-2.5-6.9-3.4zm65.2-214.8L296 164.7c10.1 10.1 2.9 27.3-11.3 27.3l-29.9 0c-5.6 0-11.1-1.2-16.2-3.4l-42.8-19c-14.3-6.3-11.9-27.3 3.4-30.3l38.5-7.7c13.1-2.6 26.7 1.5 36.1 10.9zM248 432c0-8.8 7.2-16 16-16l16 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-16 0c-8.8 0-16-7.2-16-16zM431.2 298.9l8 24c2.8 8.4-1.7 17.4-10.1 20.2s-17.4-1.7-20.2-10.1l-8-24c-2.8-8.4 1.7-17.4 10.1-20.2s17.4 1.7 20.2 10.1zm-19.9 80.4l-32 32c-6.2 6.2-16.4 6.2-22.6 0s-6.2-16.4 0-22.6l32-32c6.2-6.2 16.4-6.2 22.6 0s6.2 16.4 0 22.6z\"]\n};\nconst faGlobeOceania = faEarthOceania;\nconst faSquareXmark = {\n prefix: 'fas',\n iconName: 'square-xmark',\n icon: [448, 512, [10062, \"times-square\", \"xmark-square\"], \"f2d3\", \"M64 32C28.7 32 0 60.7 0 96L0 416c0 35.3 28.7 64 64 64l320 0c35.3 0 64-28.7 64-64l0-320c0-35.3-28.7-64-64-64L64 32zm79 143c9.4-9.4 24.6-9.4 33.9 0l47 47 47-47c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9l-47 47 47 47c9.4 9.4 9.4 24.6 0 33.9s-24.6 9.4-33.9 0l-47-47-47 47c-9.4 9.4-24.6 9.4-33.9 0s-9.4-24.6 0-33.9l47-47-47-47c-9.4-9.4-9.4-24.6 0-33.9z\"]\n};\nconst faTimesSquare = faSquareXmark;\nconst faXmarkSquare = faSquareXmark;\nconst faHashtag = {\n prefix: 'fas',\n iconName: 'hashtag',\n icon: [448, 512, [62098], \"23\", \"M181.3 32.4c17.4 2.9 29.2 19.4 26.3 36.8L197.8 128l95.1 0 11.5-69.3c2.9-17.4 19.4-29.2 36.8-26.3s29.2 19.4 26.3 36.8L357.8 128l58.2 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-68.9 0L325.8 320l58.2 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-68.9 0-11.5 69.3c-2.9 17.4-19.4 29.2-36.8 26.3s-29.2-19.4-26.3-36.8l9.8-58.7-95.1 0-11.5 69.3c-2.9 17.4-19.4 29.2-36.8 26.3s-29.2-19.4-26.3-36.8L90.2 384 32 384c-17.7 0-32-14.3-32-32s14.3-32 32-32l68.9 0 21.3-128L64 192c-17.7 0-32-14.3-32-32s14.3-32 32-32l68.9 0 11.5-69.3c2.9-17.4 19.4-29.2 36.8-26.3zM187.1 192L165.8 320l95.1 0 21.3-128-95.1 0z\"]\n};\nconst faUpRightAndDownLeftFromCenter = {\n prefix: 'fas',\n iconName: 'up-right-and-down-left-from-center',\n icon: [512, 512, [\"expand-alt\"], \"f424\", \"M344 0L488 0c13.3 0 24 10.7 24 24l0 144c0 9.7-5.8 18.5-14.8 22.2s-19.3 1.7-26.2-5.2l-39-39-87 87c-9.4 9.4-24.6 9.4-33.9 0l-32-32c-9.4-9.4-9.4-24.6 0-33.9l87-87L327 41c-6.9-6.9-8.9-17.2-5.2-26.2S334.3 0 344 0zM168 512L24 512c-13.3 0-24-10.7-24-24L0 344c0-9.7 5.8-18.5 14.8-22.2s19.3-1.7 26.2 5.2l39 39 87-87c9.4-9.4 24.6-9.4 33.9 0l32 32c9.4 9.4 9.4 24.6 0 33.9l-87 87 39 39c6.9 6.9 8.9 17.2 5.2 26.2s-12.5 14.8-22.2 14.8z\"]\n};\nconst faExpandAlt = faUpRightAndDownLeftFromCenter;\nconst faOilCan = {\n prefix: 'fas',\n iconName: 'oil-can',\n icon: [640, 512, [], \"f613\", \"M320 128c17.7 0 32-14.3 32-32s-14.3-32-32-32L192 64c-17.7 0-32 14.3-32 32s14.3 32 32 32l32 0 0 32-80 0-48 0-48 0c-26.5 0-48 21.5-48 48l0 64.8c0 19 11.2 36.2 28.5 43.9l67.5 30L96 368c0 26.5 21.5 48 48 48l259.1 0c18.4 0 35.8-7.9 48-21.7L633.5 187.7c12.3-13.9-.3-35.4-18.4-31.5L448 192l-50.5-25.2c-8.9-4.4-18.7-6.8-28.6-6.8L288 160l0-32 32 0zM96 208l0 86.1L48 272.8 48 208l48 0z\"]\n};\nconst faT = {\n prefix: 'fas',\n iconName: 't',\n icon: [384, 512, [116], \"54\", \"M32 32C14.3 32 0 46.3 0 64S14.3 96 32 96l128 0 0 352c0 17.7 14.3 32 32 32s32-14.3 32-32l0-352 128 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L192 32 32 32z\"]\n};\nconst faHippo = {\n prefix: 'fas',\n iconName: 'hippo',\n icon: [640, 512, [129435], \"f6ed\", \"M407 47c9.4-9.4 24.6-9.4 33.9 0l17.2 17.2c1.9-.1 3.9-.2 5.8-.2l32 0c11.2 0 21.9 2.3 31.6 6.5L543 55c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9L564 101.9c7.6 12.2 12 26.7 12 42.1c0 10.2 7.4 18.8 16.7 23c27.9 12.5 47.3 40.5 47.3 73c0 26.2-12.6 49.4-32 64l0 32c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-16-64 0 0 16c0 8.8-7.2 16-16 16l-32 0c-8.8 0-16-7.2-16-16l0-17.6c-11.8-2.4-22.7-7.4-32-14.4c-1.5-1.1-2.9-2.3-4.3-3.5c-17-14.7-27.7-36.4-27.7-60.5c0-8.8-7.2-16-16-16s-16 7.2-16 16c0 44.7 26.2 83.2 64 101.2l0 10.8c0 17.7 14.3 32 32 32l32 0 0 64c0 17.7-14.3 32-32 32l-64 0c-17.7 0-32-14.3-32-32l0-76c-19.8 7.7-41.4 12-64 12s-44.2-4.3-64-12l0 76c0 17.7-14.3 32-32 32l-64 0c-17.7 0-32-14.3-32-32l0-118.9L45.9 369.7c-5.4 12.1-19.6 17.6-31.7 12.2S-3.3 362.4 2.1 350.3L24 300.9c5.3-11.9 8-24.7 8-37.7C32 155.7 117.2 68 223.8 64.1l.2-.1 7.2 0L256 64l32 0c41.7 0 83.4 12.1 117.2 25.7c1.7-1.8 3.5-3.6 5.3-5.2L407 81c-9.4-9.4-9.4-24.6 0-33.9zm73 185a24 24 0 1 0 -48 0 24 24 0 1 0 48 0zm88 24a24 24 0 1 0 0-48 24 24 0 1 0 0 48zM480 144a16 16 0 1 0 -32 0 16 16 0 1 0 32 0zm48 16a16 16 0 1 0 0-32 16 16 0 1 0 0 32z\"]\n};\nconst faChartColumn = {\n prefix: 'fas',\n iconName: 'chart-column',\n icon: [512, 512, [], \"e0e3\", \"M32 32c17.7 0 32 14.3 32 32l0 336c0 8.8 7.2 16 16 16l400 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L80 480c-44.2 0-80-35.8-80-80L0 64C0 46.3 14.3 32 32 32zM160 224c17.7 0 32 14.3 32 32l0 64c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-64c0-17.7 14.3-32 32-32zm128-64l0 160c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-160c0-17.7 14.3-32 32-32s32 14.3 32 32zm64 32c17.7 0 32 14.3 32 32l0 96c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-96c0-17.7 14.3-32 32-32zM480 96l0 224c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-224c0-17.7 14.3-32 32-32s32 14.3 32 32z\"]\n};\nconst faInfinity = {\n prefix: 'fas',\n iconName: 'infinity',\n icon: [640, 512, [8734, 9854], \"f534\", \"M0 241.1C0 161 65 96 145.1 96c38.5 0 75.4 15.3 102.6 42.5L320 210.7l72.2-72.2C419.5 111.3 456.4 96 494.9 96C575 96 640 161 640 241.1l0 29.7C640 351 575 416 494.9 416c-38.5 0-75.4-15.3-102.6-42.5L320 301.3l-72.2 72.2C220.5 400.7 183.6 416 145.1 416C65 416 0 351 0 270.9l0-29.7zM274.7 256l-72.2-72.2c-15.2-15.2-35.9-23.8-57.4-23.8C100.3 160 64 196.3 64 241.1l0 29.7c0 44.8 36.3 81.1 81.1 81.1c21.5 0 42.2-8.5 57.4-23.8L274.7 256zm90.5 0l72.2 72.2c15.2 15.2 35.9 23.8 57.4 23.8c44.8 0 81.1-36.3 81.1-81.1l0-29.7c0-44.8-36.3-81.1-81.1-81.1c-21.5 0-42.2 8.5-57.4 23.8L365.3 256z\"]\n};\nconst faVialCircleCheck = {\n prefix: 'fas',\n iconName: 'vial-circle-check',\n icon: [512, 512, [], \"e596\", \"M0 64C0 46.3 14.3 32 32 32l64 0 64 0 64 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l0 170.8c-20.2 28.6-32 63.5-32 101.2c0 25.2 5.3 49.1 14.8 70.8C189.5 463.7 160.6 480 128 480c-53 0-96-43-96-96L32 96C14.3 96 0 81.7 0 64zM96 96l0 96 64 0 0-96L96 96zM224 368a144 144 0 1 1 288 0 144 144 0 1 1 -288 0zm211.3-43.3c-6.2-6.2-16.4-6.2-22.6 0L352 385.4l-28.7-28.7c-6.2-6.2-16.4-6.2-22.6 0s-6.2 16.4 0 22.6l40 40c6.2 6.2 16.4 6.2 22.6 0l72-72c6.2-6.2 6.2-16.4 0-22.6z\"]\n};\nconst faPersonArrowDownToLine = {\n prefix: 'fas',\n iconName: 'person-arrow-down-to-line',\n icon: [640, 512, [], \"e538\", \"M192 96a48 48 0 1 0 0-96 48 48 0 1 0 0 96zm-8 352l0-96 16 0 0 96-16 0zm-64 0l-88 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l120 0 80 0 376 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-344 0 0-191.1 28.6 47.5c9.1 15.1 28.8 20 43.9 10.9s20-28.8 10.9-43.9l-58.3-97c-17.4-28.9-48.6-46.6-82.3-46.6l-29.7 0c-33.7 0-64.9 17.7-82.3 46.6l-58.3 97c-9.1 15.1-4.2 34.8 10.9 43.9s34.8 4.2 43.9-10.9L120 256.9 120 448zM464 64l0 242.7-25.4-25.4c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3l80 80c12.5 12.5 32.8 12.5 45.3 0l80-80c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0L528 306.7 528 64c0-17.7-14.3-32-32-32s-32 14.3-32 32z\"]\n};\nconst faVoicemail = {\n prefix: 'fas',\n iconName: 'voicemail',\n icon: [640, 512, [], \"f897\", \"M144 320a80 80 0 1 1 0-160 80 80 0 1 1 0 160zm119.8 0c15.3-22.9 24.2-50.4 24.2-80c0-79.5-64.5-144-144-144S0 160.5 0 240s64.5 144 144 144l352 0c79.5 0 144-64.5 144-144s-64.5-144-144-144s-144 64.5-144 144c0 29.6 8.9 57.1 24.2 80l-112.5 0zM496 160a80 80 0 1 1 0 160 80 80 0 1 1 0-160z\"]\n};\nconst faFan = {\n prefix: 'fas',\n iconName: 'fan',\n icon: [512, 512, [], \"f863\", \"M258.6 0c-1.7 0-3.4 .1-5.1 .5C168 17 115.6 102.3 130.5 189.3c2.9 17 8.4 32.9 15.9 47.4L32 224l-2.6 0C13.2 224 0 237.2 0 253.4c0 1.7 .1 3.4 .5 5.1C17 344 102.3 396.4 189.3 381.5c17-2.9 32.9-8.4 47.4-15.9L224 480l0 2.6c0 16.2 13.2 29.4 29.4 29.4c1.7 0 3.4-.1 5.1-.5C344 495 396.4 409.7 381.5 322.7c-2.9-17-8.4-32.9-15.9-47.4L480 288l2.6 0c16.2 0 29.4-13.2 29.4-29.4c0-1.7-.1-3.4-.5-5.1C495 168 409.7 115.6 322.7 130.5c-17 2.9-32.9 8.4-47.4 15.9L288 32l0-2.6C288 13.2 274.8 0 258.6 0zM256 224a32 32 0 1 1 0 64 32 32 0 1 1 0-64z\"]\n};\nconst faPersonWalkingLuggage = {\n prefix: 'fas',\n iconName: 'person-walking-luggage',\n icon: [576, 512, [], \"e554\", \"M432 96a48 48 0 1 0 0-96 48 48 0 1 0 0 96zM347.7 200.5c1-.4 1.9-.8 2.9-1.2l-16.9 63.5c-5.6 21.1-.1 43.6 14.7 59.7l70.7 77.1 22 88.1c4.3 17.1 21.7 27.6 38.8 23.3s27.6-21.7 23.3-38.8l-23-92.1c-1.9-7.8-5.8-14.9-11.2-20.8l-49.5-54 19.3-65.5 9.6 23c4.4 10.6 12.5 19.3 22.8 24.5l26.7 13.3c15.8 7.9 35 1.5 42.9-14.3s1.5-35-14.3-42.9L505 232.7l-15.3-36.8C472.5 154.8 432.3 128 387.7 128c-22.8 0-45.3 4.8-66.1 14l-8 3.5c-32.9 14.6-58.1 42.4-69.4 76.5l-2.6 7.8c-5.6 16.8 3.5 34.9 20.2 40.5s34.9-3.5 40.5-20.2l2.6-7.8c5.7-17.1 18.3-30.9 34.7-38.2l8-3.5zm-30 135.1l-25 62.4-59.4 59.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0L340.3 441c4.6-4.6 8.2-10.1 10.6-16.1l14.5-36.2-40.7-44.4c-2.5-2.7-4.8-5.6-7-8.6zM256 274.1c-7.7-4.4-17.4-1.8-21.9 5.9l-32 55.4L147.7 304c-15.3-8.8-34.9-3.6-43.7 11.7L40 426.6c-8.8 15.3-3.6 34.9 11.7 43.7l55.4 32c15.3 8.8 34.9 3.6 43.7-11.7l64-110.9c1.5-2.6 2.6-5.2 3.3-8L261.9 296c4.4-7.7 1.8-17.4-5.9-21.9z\"]\n};\nconst faUpDown = {\n prefix: 'fas',\n iconName: 'up-down',\n icon: [256, 512, [8597, 11021, \"arrows-alt-v\"], \"f338\", \"M145.6 7.7C141 2.8 134.7 0 128 0s-13 2.8-17.6 7.7l-104 112c-6.5 7-8.2 17.2-4.4 25.9S14.5 160 24 160l56 0 0 192-56 0c-9.5 0-18.2 5.7-22 14.4s-2.1 18.9 4.4 25.9l104 112c4.5 4.9 10.9 7.7 17.6 7.7s13-2.8 17.6-7.7l104-112c6.5-7 8.2-17.2 4.4-25.9s-12.5-14.4-22-14.4l-56 0 0-192 56 0c9.5 0 18.2-5.7 22-14.4s2.1-18.9-4.4-25.9l-104-112z\"]\n};\nconst faArrowsAltV = faUpDown;\nconst faCloudMoonRain = {\n prefix: 'fas',\n iconName: 'cloud-moon-rain',\n icon: [576, 512, [], \"f73c\", \"M481.2 0C417 0 363.5 46.5 353.7 107.6c35.4 17.6 60.2 53.3 62.1 95.1c23.2 11 42 29.7 53.1 52.7c4 .4 8.1 .6 12.3 .6c34.9 0 66.7-13.8 89.9-36.1c5.1-4.9 6.4-12.5 3.2-18.7s-10.1-9.7-17-8.6c-4.9 .8-10 1.3-15.2 1.3c-49 0-88.4-39.3-88.4-87.4c0-32.6 18-61.1 44.9-76.1c6.1-3.4 9.3-10.5 7.8-17.4s-7.3-12-14.3-12.6c-3.6-.3-7.3-.5-10.9-.5zM367.9 383.9c44.2 0 80-35.8 80-80c0-39.3-28.4-72.1-65.8-78.7c1.2-5.6 1.9-11.3 1.9-17.2c0-44.2-35.8-80-80-80c-17 0-32.8 5.3-45.8 14.4C241.3 114.6 210.8 96 176 96c-53 0-96 43-96 96l0 1.3c-45.4 7.6-80 47.1-80 94.6c0 53 43 96 96 96l271.9 0zM85.4 420.1c-11-7.4-25.9-4.4-33.3 6.7l-32 48c-7.4 11-4.4 25.9 6.7 33.3s25.9 4.4 33.3-6.7l32-48c7.4-11 4.4-25.9-6.7-33.3zm96 0c-11-7.4-25.9-4.4-33.3 6.7l-32 48c-7.4 11-4.4 25.9 6.7 33.3s25.9 4.4 33.3-6.7l32-48c7.4-11 4.4-25.9-6.7-33.3zm96 0c-11-7.4-25.9-4.4-33.3 6.7l-32 48c-7.4 11-4.4 25.9 6.7 33.3s25.9 4.4 33.3-6.7l32-48c7.4-11 4.4-25.9-6.7-33.3zm96 0c-11-7.4-25.9-4.4-33.3 6.7l-32 48c-7.4 11-4.4 25.9 6.7 33.3s25.9 4.4 33.3-6.7l32-48c7.4-11 4.4-25.9-6.7-33.3z\"]\n};\nconst faCalendar = {\n prefix: 'fas',\n iconName: 'calendar',\n icon: [448, 512, [128197, 128198], \"f133\", \"M96 32l0 32L48 64C21.5 64 0 85.5 0 112l0 48 448 0 0-48c0-26.5-21.5-48-48-48l-48 0 0-32c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 32L160 64l0-32c0-17.7-14.3-32-32-32S96 14.3 96 32zM448 192L0 192 0 464c0 26.5 21.5 48 48 48l352 0c26.5 0 48-21.5 48-48l0-272z\"]\n};\nconst faTrailer = {\n prefix: 'fas',\n iconName: 'trailer',\n icon: [640, 512, [], \"e041\", \"M48 32C21.5 32 0 53.5 0 80L0 336c0 26.5 21.5 48 48 48l17.1 0c7.8-54.3 54.4-96 110.9-96s103.1 41.7 110.9 96L488 384l8 0 112 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-64 0 0-240c0-26.5-21.5-48-48-48L48 32zM80 96c8.8 0 16 7.2 16 16l0 131.2c-11.4 5.9-22.2 12.9-32 21L64 112c0-8.8 7.2-16 16-16zm96 128c-5.4 0-10.7 .2-16 .7L160 112c0-8.8 7.2-16 16-16s16 7.2 16 16l0 112.7c-5.3-.5-10.6-.7-16-.7zm80 19.2L256 112c0-8.8 7.2-16 16-16s16 7.2 16 16l0 152.2c-9.8-8.1-20.6-15.2-32-21zM368 96c8.8 0 16 7.2 16 16l0 192c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-192c0-8.8 7.2-16 16-16zm112 16l0 192c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-192c0-8.8 7.2-16 16-16s16 7.2 16 16zM176 480a80 80 0 1 0 0-160 80 80 0 1 0 0 160zm0-112a32 32 0 1 1 0 64 32 32 0 1 1 0-64z\"]\n};\nconst faBahai = {\n prefix: 'fas',\n iconName: 'bahai',\n icon: [576, 512, [\"haykal\"], \"f666\", \"M288 0c14.5 0 27.2 9.7 30.9 23.8l23.9 89.6 75.9-53.3c11.9-8.3 27.8-7.6 39 1.7s14.6 24.9 8.4 38.1l-39.3 84 92.4 8c14.4 1.2 26.2 12 28.8 26.3s-4.9 28.5-18 34.6l-84.1 39.1 65.7 65.5c10.3 10.2 12.4 26.1 5.1 38.7s-22 18.7-36 14.9L391 386.8l8.2 92.4c1.3 14.4-7.3 27.9-20.9 32.9s-28.9 .1-37.2-11.7l-53.1-76-53.1 76c-8.3 11.9-23.6 16.7-37.2 11.7s-22.2-18.5-20.9-32.9l8.2-92.4L95.4 410.9c-14 3.8-28.8-2.3-36-14.9s-5.2-28.4 5.1-38.7l65.7-65.5L46 252.7c-13.1-6.1-20.5-20.3-18-34.6s14.3-25.1 28.8-26.3l92.4-8-39.3-84c-6.1-13.1-2.7-28.8 8.4-38.1s27.1-10 39-1.7l75.9 53.3 23.9-89.6C260.8 9.7 273.5 0 288 0zm0 156.2l-4.8 18c-2.7 10.1-10.2 18.2-20 21.8s-20.8 2.1-29.3-3.9l-15.2-10.7 7.9 16.8c4.4 9.5 4 20.5-1.3 29.6s-14.5 15-25 15.9l-18.5 1.6 16.8 7.8c9.5 4.4 16.2 13.2 18 23.5s-1.5 20.8-8.9 28.2l-13.2 13.1 17.9-4.8c10.1-2.7 20.9-.3 28.9 6.4s12.2 16.9 11.3 27.3l-1.6 18.5 10.6-15.2c6-8.6 15.8-13.7 26.2-13.7s20.2 5.1 26.2 13.7l10.6 15.2-1.6-18.5c-.9-10.4 3.3-20.6 11.3-27.3s18.8-9.1 28.9-6.4l17.9 4.8-13.2-13.1c-7.4-7.4-10.7-17.9-8.9-28.2s8.5-19.1 18-23.5l16.8-7.8-18.5-1.6c-10.4-.9-19.7-6.8-25-15.9s-5.7-20.1-1.3-29.6l7.9-16.8-15.2 10.7c-8.6 6-19.5 7.5-29.3 3.9s-17.3-11.7-20-21.8l-4.8-18z\"]\n};\nconst faHaykal = faBahai;\nconst faSdCard = {\n prefix: 'fas',\n iconName: 'sd-card',\n icon: [384, 512, [], \"f7c2\", \"M320 0L141.3 0C124.3 0 108 6.7 96 18.7L18.7 96C6.7 108 0 124.3 0 141.3L0 448c0 35.3 28.7 64 64 64l256 0c35.3 0 64-28.7 64-64l0-384c0-35.3-28.7-64-64-64zM160 88l0 48c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-48c0-13.3 10.7-24 24-24s24 10.7 24 24zm80 0l0 48c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-48c0-13.3 10.7-24 24-24s24 10.7 24 24zm80 0l0 48c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-48c0-13.3 10.7-24 24-24s24 10.7 24 24z\"]\n};\nconst faDragon = {\n prefix: 'fas',\n iconName: 'dragon',\n icon: [640, 512, [128009], \"f6d5\", \"M352 124.5l-51.9-13c-6.5-1.6-11.3-7.1-12-13.8s2.8-13.1 8.7-16.1l40.8-20.4L294.4 28.8c-5.5-4.1-7.8-11.3-5.6-17.9S297.1 0 304 0L416 0l32 0 16 0c30.2 0 58.7 14.2 76.8 38.4l57.6 76.8c6.2 8.3 9.6 18.4 9.6 28.8c0 26.5-21.5 48-48 48l-21.5 0c-17 0-33.3-6.7-45.3-18.7L480 160l-32 0 0 21.5c0 24.8 12.8 47.9 33.8 61.1l106.6 66.6c32.1 20.1 51.6 55.2 51.6 93.1C640 462.9 590.9 512 530.2 512L496 512l-64 0L32.3 512c-3.3 0-6.6-.4-9.6-1.4C13.5 507.8 6 501 2.4 492.1C1 488.7 .2 485.2 0 481.4c-.2-3.7 .3-7.3 1.3-10.7c2.8-9.2 9.6-16.7 18.6-20.4c3-1.2 6.2-2 9.5-2.2L433.3 412c8.3-.7 14.7-7.7 14.7-16.1c0-4.3-1.7-8.4-4.7-11.4l-44.4-44.4c-30-30-46.9-70.7-46.9-113.1l0-45.5 0-57zM512 72.3c0-.1 0-.2 0-.3s0-.2 0-.3l0 .6zm-1.3 7.4L464.3 68.1c-.2 1.3-.3 2.6-.3 3.9c0 13.3 10.7 24 24 24c10.6 0 19.5-6.8 22.7-16.3zM130.9 116.5c16.3-14.5 40.4-16.2 58.5-4.1l130.6 87 0 27.5c0 32.8 8.4 64.8 24 93l-232 0c-6.7 0-12.7-4.2-15-10.4s-.5-13.3 4.6-17.7L171 232.3 18.4 255.8c-7 1.1-13.9-2.6-16.9-9s-1.5-14.1 3.8-18.8L130.9 116.5z\"]\n};\nconst faShoePrints = {\n prefix: 'fas',\n iconName: 'shoe-prints',\n icon: [640, 512, [], \"f54b\", \"M416 0C352.3 0 256 32 256 32l0 128c48 0 76 16 104 32s56 32 104 32c56.4 0 176-16 176-96S512 0 416 0zM128 96c0 35.3 28.7 64 64 64l32 0 0-128-32 0c-35.3 0-64 28.7-64 64zM288 512c96 0 224-48 224-128s-119.6-96-176-96c-48 0-76 16-104 32s-56 32-104 32l0 128s96.3 32 160 32zM0 416c0 35.3 28.7 64 64 64l32 0 0-128-32 0c-35.3 0-64 28.7-64 64z\"]\n};\nconst faCirclePlus = {\n prefix: 'fas',\n iconName: 'circle-plus',\n icon: [512, 512, [\"plus-circle\"], \"f055\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM232 344l0-64-64 0c-13.3 0-24-10.7-24-24s10.7-24 24-24l64 0 0-64c0-13.3 10.7-24 24-24s24 10.7 24 24l0 64 64 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-64 0 0 64c0 13.3-10.7 24-24 24s-24-10.7-24-24z\"]\n};\nconst faPlusCircle = faCirclePlus;\nconst faFaceGrinTongueWink = {\n prefix: 'fas',\n iconName: 'face-grin-tongue-wink',\n icon: [512, 512, [128540, \"grin-tongue-wink\"], \"f58b\", \"M174.5 498.8C73.1 464.7 0 368.9 0 256C0 114.6 114.6 0 256 0S512 114.6 512 256c0 112.9-73.1 208.7-174.5 242.8C346.7 484 352 466.6 352 448l0-46.9c24.3-17.5 43.6-41.6 55.4-69.6c5-11.8-7-22.5-19.3-18.7c-39.7 12.2-84.5 19-131.8 19s-92.1-6.8-131.8-19c-12.3-3.8-24.3 6.9-19.3 18.7c11.7 27.8 30.8 51.7 54.8 69.2l0 47.3c0 18.6 5.3 36 14.5 50.8zm20.7-265.2c5.3 7.1 15.3 8.5 22.4 3.2s8.5-15.3 3.2-22.4c-30.4-40.5-91.2-40.5-121.6 0c-5.3 7.1-3.9 17.1 3.2 22.4s17.1 3.9 22.4-3.2c17.6-23.5 52.8-23.5 70.4 0zM336 272a64 64 0 1 0 0-128 64 64 0 1 0 0 128zM320 402.6l0 45.4c0 35.3-28.7 64-64 64s-64-28.7-64-64l0-45.4c0-14.7 11.9-26.6 26.6-26.6l2 0c11.3 0 21.1 7.9 23.6 18.9c2.8 12.6 20.8 12.6 23.6 0c2.5-11.1 12.3-18.9 23.6-18.9l2 0c14.7 0 26.6 11.9 26.6 26.6zM336 184a24 24 0 1 1 0 48 24 24 0 1 1 0-48z\"]\n};\nconst faGrinTongueWink = faFaceGrinTongueWink;\nconst faHandHolding = {\n prefix: 'fas',\n iconName: 'hand-holding',\n icon: [576, 512, [], \"f4bd\", \"M559.7 392.2c17.8-13.1 21.6-38.1 8.5-55.9s-38.1-21.6-55.9-8.5L392.6 416 272 416c-8.8 0-16-7.2-16-16s7.2-16 16-16l16 0 64 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-64 0-16 0-78.3 0c-29.1 0-57.3 9.9-80 28L68.8 384 32 384c-17.7 0-32 14.3-32 32l0 64c0 17.7 14.3 32 32 32l160 0 160.5 0c29 0 57.3-9.3 80.7-26.5l126.6-93.3zm-367-8.2c.3 0 .6 0 .9 0c0 0 0 0 0 0c-.3 0-.6 0-.9 0z\"]\n};\nconst faPlugCircleExclamation = {\n prefix: 'fas',\n iconName: 'plug-circle-exclamation',\n icon: [576, 512, [], \"e55d\", \"M96 0C78.3 0 64 14.3 64 32l0 96 64 0 0-96c0-17.7-14.3-32-32-32zM288 0c-17.7 0-32 14.3-32 32l0 96 64 0 0-96c0-17.7-14.3-32-32-32zM32 160c-17.7 0-32 14.3-32 32s14.3 32 32 32l0 32c0 77.4 55 142 128 156.8l0 67.2c0 17.7 14.3 32 32 32s32-14.3 32-32l0-67.2c12.3-2.5 24.1-6.4 35.1-11.5c-2.1-10.8-3.1-21.9-3.1-33.3c0-80.3 53.8-148 127.3-169.2c.5-2.2 .7-4.5 .7-6.8c0-17.7-14.3-32-32-32L32 160zM432 512a144 144 0 1 0 0-288 144 144 0 1 0 0 288zm0-96a24 24 0 1 1 0 48 24 24 0 1 1 0-48zm0-144c8.8 0 16 7.2 16 16l0 80c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-80c0-8.8 7.2-16 16-16z\"]\n};\nconst faLinkSlash = {\n prefix: 'fas',\n iconName: 'link-slash',\n icon: [640, 512, [\"chain-broken\", \"chain-slash\", \"unlink\"], \"f127\", \"M38.8 5.1C28.4-3.1 13.3-1.2 5.1 9.2S-1.2 34.7 9.2 42.9l592 464c10.4 8.2 25.5 6.3 33.7-4.1s6.3-25.5-4.1-33.7L489.3 358.2l90.5-90.5c56.5-56.5 56.5-148 0-204.5c-50-50-128.8-56.5-186.3-15.4l-1.6 1.1c-14.4 10.3-17.7 30.3-7.4 44.6s30.3 17.7 44.6 7.4l1.6-1.1c32.1-22.9 76-19.3 103.8 8.6c31.5 31.5 31.5 82.5 0 114l-96 96-31.9-25C430.9 239.6 420.1 175.1 377 132c-52.2-52.3-134.5-56.2-191.3-11.7L38.8 5.1zM239 162c30.1-14.9 67.7-9.9 92.8 15.3c20 20 27.5 48.3 21.7 74.5L239 162zM406.6 416.4L220.9 270c-2.1 39.8 12.2 80.1 42.2 110c38.9 38.9 94.4 51 143.6 36.3zm-290-228.5L60.2 244.3c-56.5 56.5-56.5 148 0 204.5c50 50 128.8 56.5 186.3 15.4l1.6-1.1c14.4-10.3 17.7-30.3 7.4-44.6s-30.3-17.7-44.6-7.4l-1.6 1.1c-32.1 22.9-76 19.3-103.8-8.6C74 372 74 321 105.5 289.5l61.8-61.8-50.6-39.9z\"]\n};\nconst faChainBroken = faLinkSlash;\nconst faChainSlash = faLinkSlash;\nconst faUnlink = faLinkSlash;\nconst faClone = {\n prefix: 'fas',\n iconName: 'clone',\n icon: [512, 512, [], \"f24d\", \"M288 448L64 448l0-224 64 0 0-64-64 0c-35.3 0-64 28.7-64 64L0 448c0 35.3 28.7 64 64 64l224 0c35.3 0 64-28.7 64-64l0-64-64 0 0 64zm-64-96l224 0c35.3 0 64-28.7 64-64l0-224c0-35.3-28.7-64-64-64L224 0c-35.3 0-64 28.7-64 64l0 224c0 35.3 28.7 64 64 64z\"]\n};\nconst faPersonWalkingArrowLoopLeft = {\n prefix: 'fas',\n iconName: 'person-walking-arrow-loop-left',\n icon: [640, 512, [], \"e551\", \"M208 96a48 48 0 1 0 0-96 48 48 0 1 0 0 96zM123.7 200.5c1-.4 1.9-.8 2.9-1.2l-16.9 63.5c-5.6 21.1-.1 43.6 14.7 59.7l70.7 77.1 22 88.1c4.3 17.1 21.7 27.6 38.8 23.3s27.6-21.7 23.3-38.8l-23-92.1c-1.9-7.8-5.8-14.9-11.2-20.8l-49.5-54 19.3-65.5 9.6 23c4.4 10.6 12.5 19.3 22.8 24.5l26.7 13.3c15.8 7.9 35 1.5 42.9-14.3s1.5-35-14.3-42.9L281 232.7l-15.3-36.8C248.5 154.8 208.3 128 163.7 128c-22.8 0-45.3 4.8-66.1 14l-8 3.5c-32.9 14.6-58.1 42.4-69.4 76.5l-2.6 7.8c-5.6 16.8 3.5 34.9 20.2 40.5s34.9-3.5 40.5-20.2l2.6-7.8c5.7-17.1 18.3-30.9 34.7-38.2l8-3.5zm-30 135.1L68.7 398 9.4 457.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0L116.3 441c4.6-4.6 8.2-10.1 10.6-16.1l14.5-36.2-40.7-44.4c-2.5-2.7-4.8-5.6-7-8.6zm347.7 119c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3L461.3 384l18.7 0c88.4 0 160-71.6 160-160s-71.6-160-160-160L352 64c-17.7 0-32 14.3-32 32s14.3 32 32 32l128 0c53 0 96 43 96 96s-43 96-96 96l-18.7 0 25.4-25.4c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0l-80 80c-12.5 12.5-12.5 32.8 0 45.3l80 80z\"]\n};\nconst faArrowUpZA = {\n prefix: 'fas',\n iconName: 'arrow-up-z-a',\n icon: [576, 512, [\"sort-alpha-up-alt\"], \"f882\", \"M183.6 42.4C177.5 35.8 169 32 160 32s-17.5 3.8-23.6 10.4l-88 96c-11.9 13-11.1 33.3 2 45.2s33.3 11.1 45.2-2L128 146.3 128 448c0 17.7 14.3 32 32 32s32-14.3 32-32l0-301.7 32.4 35.4c11.9 13 32.2 13.9 45.2 2s13.9-32.2 2-45.2l-88-96zM320 64c0 17.7 14.3 32 32 32l50.7 0-73.4 73.4c-9.2 9.2-11.9 22.9-6.9 34.9s16.6 19.8 29.6 19.8l128 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-50.7 0 73.4-73.4c9.2-9.2 11.9-22.9 6.9-34.9s-16.6-19.8-29.6-19.8L352 32c-17.7 0-32 14.3-32 32zm96 192c-12.1 0-23.2 6.8-28.6 17.7l-64 128-16 32c-7.9 15.8-1.5 35 14.3 42.9s35 1.5 42.9-14.3l7.2-14.3 88.4 0 7.2 14.3c7.9 15.8 27.1 22.2 42.9 14.3s22.2-27.1 14.3-42.9l-16-32-64-128C439.2 262.8 428.1 256 416 256zM395.8 400L416 359.6 436.2 400l-40.4 0z\"]\n};\nconst faSortAlphaUpAlt = faArrowUpZA;\nconst faFireFlameCurved = {\n prefix: 'fas',\n iconName: 'fire-flame-curved',\n icon: [384, 512, [\"fire-alt\"], \"f7e4\", \"M153.6 29.9l16-21.3C173.6 3.2 180 0 186.7 0C198.4 0 208 9.6 208 21.3V43.5c0 13.1 5.4 25.7 14.9 34.7L307.6 159C356.4 205.6 384 270.2 384 337.7C384 434 306 512 209.7 512H192C86 512 0 426 0 320v-3.8c0-48.8 19.4-95.6 53.9-130.1l3.5-3.5c4.2-4.2 10-6.6 16-6.6C85.9 176 96 186.1 96 198.6V288c0 35.3 28.7 64 64 64s64-28.7 64-64v-3.9c0-18-7.2-35.3-19.9-48l-38.6-38.6c-24-24-37.5-56.7-37.5-90.7c0-27.7 9-54.8 25.6-76.9z\"]\n};\nconst faFireAlt = faFireFlameCurved;\nconst faTornado = {\n prefix: 'fas',\n iconName: 'tornado',\n icon: [448, 512, [127786], \"f76f\", \"M0 32L0 45.6C0 62.7 1.7 79.6 5 96l352.8 0c3.2-6.9 7.5-13.3 13-18.8l38.6-38.6c4.2-4.2 6.6-10 6.6-16C416 10.1 405.9 0 393.4 0L32 0C14.3 0 0 14.3 0 32zm352.2 96L13.6 128c12.2 35.9 32.3 68.7 58.8 96L412 224l-47.2-62.9c-7.3-9.7-11.6-21.2-12.6-33.1zm-226 138.2l116.4 68.5c8.2 4.8 15.8 10.7 22.5 17.3L445 352c2-9.8 3-19.9 3-30.1c0-23-5.3-45.5-15.3-65.9l-322.5 0c5.2 3.6 10.5 7 16 10.2zM288 384c10.3 21.4 13.8 45.5 9.9 69l-5.9 35.7c-2 12.2 7.4 23.4 19.8 23.4c5.3 0 10.4-2.1 14.2-5.9l78.2-78.2c12.8-12.8 23.1-27.7 30.4-43.9L288 384z\"]\n};\nconst faFileCirclePlus = {\n prefix: 'fas',\n iconName: 'file-circle-plus',\n icon: [576, 512, [58606], \"e494\", \"M0 64C0 28.7 28.7 0 64 0L224 0l0 128c0 17.7 14.3 32 32 32l128 0 0 38.6C310.1 219.5 256 287.4 256 368c0 59.1 29.1 111.3 73.7 143.3c-3.2 .5-6.4 .7-9.7 .7L64 512c-35.3 0-64-28.7-64-64L0 64zm384 64l-128 0L256 0 384 128zm48 96a144 144 0 1 1 0 288 144 144 0 1 1 0-288zm16 80c0-8.8-7.2-16-16-16s-16 7.2-16 16l0 48-48 0c-8.8 0-16 7.2-16 16s7.2 16 16 16l48 0 0 48c0 8.8 7.2 16 16 16s16-7.2 16-16l0-48 48 0c8.8 0 16-7.2 16-16s-7.2-16-16-16l-48 0 0-48z\"]\n};\nconst faBookQuran = {\n prefix: 'fas',\n iconName: 'book-quran',\n icon: [448, 512, [\"quran\"], \"f687\", \"M352 0c53 0 96 43 96 96l0 320c0 53-43 96-96 96L64 512l-32 0c-17.7 0-32-14.3-32-32s14.3-32 32-32l0-64c-17.7 0-32-14.3-32-32L0 32C0 14.3 14.3 0 32 0L64 0 352 0zm0 384L96 384l0 64 256 0c17.7 0 32-14.3 32-32s-14.3-32-32-32zM274.1 150.2l-8.9 21.4-23.1 1.9c-5.7 .5-8 7.5-3.7 11.2L256 199.8l-5.4 22.6c-1.3 5.5 4.7 9.9 9.6 6.9L280 217.2l19.8 12.1c4.9 3 10.9-1.4 9.6-6.9L304 199.8l17.6-15.1c4.3-3.7 2-10.8-3.7-11.2l-23.1-1.9-8.9-21.4c-2.2-5.3-9.6-5.3-11.8 0zM96 192c0 70.7 57.3 128 128 128c25.6 0 49.5-7.5 69.5-20.5c3.2-2.1 4.5-6.2 3.1-9.7s-5.2-5.6-9-4.8c-6.1 1.2-12.5 1.9-19 1.9c-52.4 0-94.9-42.5-94.9-94.9s42.5-94.9 94.9-94.9c6.5 0 12.8 .7 19 1.9c3.8 .8 7.5-1.3 9-4.8s.2-7.6-3.1-9.7C273.5 71.5 249.6 64 224 64C153.3 64 96 121.3 96 192z\"]\n};\nconst faQuran = faBookQuran;\nconst faAnchor = {\n prefix: 'fas',\n iconName: 'anchor',\n icon: [576, 512, [9875], \"f13d\", \"M320 96a32 32 0 1 1 -64 0 32 32 0 1 1 64 0zm21.1 80C367 158.8 384 129.4 384 96c0-53-43-96-96-96s-96 43-96 96c0 33.4 17 62.8 42.9 80L224 176c-17.7 0-32 14.3-32 32s14.3 32 32 32l32 0 0 208-48 0c-53 0-96-43-96-96l0-6.1 7 7c9.4 9.4 24.6 9.4 33.9 0s9.4-24.6 0-33.9L97 263c-9.4-9.4-24.6-9.4-33.9 0L7 319c-9.4 9.4-9.4 24.6 0 33.9s24.6 9.4 33.9 0l7-7 0 6.1c0 88.4 71.6 160 160 160l80 0 80 0c88.4 0 160-71.6 160-160l0-6.1 7 7c9.4 9.4 24.6 9.4 33.9 0s9.4-24.6 0-33.9l-56-56c-9.4-9.4-24.6-9.4-33.9 0l-56 56c-9.4 9.4-9.4 24.6 0 33.9s24.6 9.4 33.9 0l7-7 0 6.1c0 53-43 96-96 96l-48 0 0-208 32 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-10.9 0z\"]\n};\nconst faBorderAll = {\n prefix: 'fas',\n iconName: 'border-all',\n icon: [448, 512, [], \"f84c\", \"M384 96l0 128-128 0 0-128 128 0zm0 192l0 128-128 0 0-128 128 0zM192 224L64 224 64 96l128 0 0 128zM64 288l128 0 0 128L64 416l0-128zM64 32C28.7 32 0 60.7 0 96L0 416c0 35.3 28.7 64 64 64l320 0c35.3 0 64-28.7 64-64l0-320c0-35.3-28.7-64-64-64L64 32z\"]\n};\nconst faFaceAngry = {\n prefix: 'fas',\n iconName: 'face-angry',\n icon: [512, 512, [128544, \"angry\"], \"f556\", \"M0 256a256 256 0 1 1 512 0A256 256 0 1 1 0 256zM338.7 395.9c6.6-5.9 7.1-16 1.2-22.6C323.8 355.4 295.7 336 256 336s-67.8 19.4-83.9 37.3c-5.9 6.6-5.4 16.7 1.2 22.6s16.7 5.4 22.6-1.2c11.7-13 31.6-26.7 60.1-26.7s48.4 13.7 60.1 26.7c5.9 6.6 16 7.1 22.6 1.2zM176.4 272c17.7 0 32-14.3 32-32c0-1.5-.1-3-.3-4.4l10.9 3.6c8.4 2.8 17.4-1.7 20.2-10.1s-1.7-17.4-10.1-20.2l-96-32c-8.4-2.8-17.4 1.7-20.2 10.1s1.7 17.4 10.1 20.2l30.7 10.2c-5.8 5.8-9.3 13.8-9.3 22.6c0 17.7 14.3 32 32 32zm192-32c0-8.9-3.6-17-9.5-22.8l30.2-10.1c8.4-2.8 12.9-11.9 10.1-20.2s-11.9-12.9-20.2-10.1l-96 32c-8.4 2.8-12.9 11.9-10.1 20.2s11.9 12.9 20.2 10.1l11.7-3.9c-.2 1.5-.3 3.1-.3 4.7c0 17.7 14.3 32 32 32s32-14.3 32-32z\"]\n};\nconst faAngry = faFaceAngry;\nconst faCookieBite = {\n prefix: 'fas',\n iconName: 'cookie-bite',\n icon: [512, 512, [], \"f564\", \"M257.5 27.6c-.8-5.4-4.9-9.8-10.3-10.6c-22.1-3.1-44.6 .9-64.4 11.4l-74 39.5C89.1 78.4 73.2 94.9 63.4 115L26.7 190.6c-9.8 20.1-13 42.9-9.1 64.9l14.5 82.8c3.9 22.1 14.6 42.3 30.7 57.9l60.3 58.4c16.1 15.6 36.6 25.6 58.7 28.7l83 11.7c22.1 3.1 44.6-.9 64.4-11.4l74-39.5c19.7-10.5 35.6-27 45.4-47.2l36.7-75.5c9.8-20.1 13-42.9 9.1-64.9c-.9-5.3-5.3-9.3-10.6-10.1c-51.5-8.2-92.8-47.1-104.5-97.4c-1.8-7.6-8-13.4-15.7-14.6c-54.6-8.7-97.7-52-106.2-106.8zM208 144a32 32 0 1 1 0 64 32 32 0 1 1 0-64zM144 336a32 32 0 1 1 64 0 32 32 0 1 1 -64 0zm224-64a32 32 0 1 1 0 64 32 32 0 1 1 0-64z\"]\n};\nconst faArrowTrendDown = {\n prefix: 'fas',\n iconName: 'arrow-trend-down',\n icon: [576, 512, [], \"e097\", \"M384 352c-17.7 0-32 14.3-32 32s14.3 32 32 32l160 0c17.7 0 32-14.3 32-32l0-160c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 82.7L342.6 137.4c-12.5-12.5-32.8-12.5-45.3 0L192 242.7 54.6 105.4c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3l160 160c12.5 12.5 32.8 12.5 45.3 0L320 205.3 466.7 352 384 352z\"]\n};\nconst faRss = {\n prefix: 'fas',\n iconName: 'rss',\n icon: [448, 512, [\"feed\"], \"f09e\", \"M0 64C0 46.3 14.3 32 32 32c229.8 0 416 186.2 416 416c0 17.7-14.3 32-32 32s-32-14.3-32-32C384 253.6 226.4 96 32 96C14.3 96 0 81.7 0 64zM0 416a64 64 0 1 1 128 0A64 64 0 1 1 0 416zM32 160c159.1 0 288 128.9 288 288c0 17.7-14.3 32-32 32s-32-14.3-32-32c0-123.7-100.3-224-224-224c-17.7 0-32-14.3-32-32s14.3-32 32-32z\"]\n};\nconst faFeed = faRss;\nconst faDrawPolygon = {\n prefix: 'fas',\n iconName: 'draw-polygon',\n icon: [448, 512, [], \"f5ee\", \"M96 151.4l0 209.1c9.7 5.6 17.8 13.7 23.4 23.4l209.1 0c0-.1 .1-.2 .1-.3l-4.5-7.9-32-56s0 0 0 0c-1.4 .1-2.8 .1-4.2 .1c-35.3 0-64-28.7-64-64s28.7-64 64-64c1.4 0 2.8 0 4.2 .1c0 0 0 0 0 0l32-56 4.5-7.9-.1-.3-209.1 0c-5.6 9.7-13.7 17.8-23.4 23.4zM384.3 352c35.2 .2 63.7 28.7 63.7 64c0 35.3-28.7 64-64 64c-23.7 0-44.4-12.9-55.4-32l-209.1 0c-11.1 19.1-31.7 32-55.4 32c-35.3 0-64-28.7-64-64c0-23.7 12.9-44.4 32-55.4l0-209.1C12.9 140.4 0 119.7 0 96C0 60.7 28.7 32 64 32c23.7 0 44.4 12.9 55.4 32l209.1 0c11.1-19.1 31.7-32 55.4-32c35.3 0 64 28.7 64 64c0 35.3-28.5 63.8-63.7 64l-4.5 7.9-32 56-2.3 4c4.2 8.5 6.5 18 6.5 28.1s-2.3 19.6-6.5 28.1l2.3 4 32 56 4.5 7.9z\"]\n};\nconst faScaleBalanced = {\n prefix: 'fas',\n iconName: 'scale-balanced',\n icon: [640, 512, [9878, \"balance-scale\"], \"f24e\", \"M384 32l128 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L398.4 96c-5.2 25.8-22.9 47.1-46.4 57.3L352 448l160 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-192 0-192 0c-17.7 0-32-14.3-32-32s14.3-32 32-32l160 0 0-294.7c-23.5-10.3-41.2-31.6-46.4-57.3L128 96c-17.7 0-32-14.3-32-32s14.3-32 32-32l128 0c14.6-19.4 37.8-32 64-32s49.4 12.6 64 32zm55.6 288l144.9 0L512 195.8 439.6 320zM512 416c-62.9 0-115.2-34-126-78.9c-2.6-11 1-22.3 6.7-32.1l95.2-163.2c5-8.6 14.2-13.8 24.1-13.8s19.1 5.3 24.1 13.8l95.2 163.2c5.7 9.8 9.3 21.1 6.7 32.1C627.2 382 574.9 416 512 416zM126.8 195.8L54.4 320l144.9 0L126.8 195.8zM.9 337.1c-2.6-11 1-22.3 6.7-32.1l95.2-163.2c5-8.6 14.2-13.8 24.1-13.8s19.1 5.3 24.1 13.8l95.2 163.2c5.7 9.8 9.3 21.1 6.7 32.1C242 382 189.7 416 126.8 416S11.7 382 .9 337.1z\"]\n};\nconst faBalanceScale = faScaleBalanced;\nconst faGaugeSimpleHigh = {\n prefix: 'fas',\n iconName: 'gauge-simple-high',\n icon: [512, 512, [61668, \"tachometer\", \"tachometer-fast\"], \"f62a\", \"M0 256a256 256 0 1 1 512 0A256 256 0 1 1 0 256zm320 96c0-15.9-5.8-30.4-15.3-41.6l76.6-147.4c6.1-11.8 1.5-26.3-10.2-32.4s-26.2-1.5-32.4 10.2L262.1 288.3c-2-.2-4-.3-6.1-.3c-35.3 0-64 28.7-64 64s28.7 64 64 64s64-28.7 64-64z\"]\n};\nconst faTachometer = faGaugeSimpleHigh;\nconst faTachometerFast = faGaugeSimpleHigh;\nconst faShower = {\n prefix: 'fas',\n iconName: 'shower',\n icon: [512, 512, [128703], \"f2cc\", \"M64 131.9C64 112.1 80.1 96 99.9 96c9.5 0 18.6 3.8 25.4 10.5l16.2 16.2c-21 38.9-17.4 87.5 10.9 123L151 247c-9.4 9.4-9.4 24.6 0 33.9s24.6 9.4 33.9 0L345 121c9.4-9.4 9.4-24.6 0-33.9s-24.6-9.4-33.9 0l-1.3 1.3c-35.5-28.3-84.2-31.9-123-10.9L170.5 61.3C151.8 42.5 126.4 32 99.9 32C44.7 32 0 76.7 0 131.9L0 448c0 17.7 14.3 32 32 32s32-14.3 32-32l0-316.1zM256 352a32 32 0 1 0 0-64 32 32 0 1 0 0 64zm64 64a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zm0-128a32 32 0 1 0 0-64 32 32 0 1 0 0 64zm64 64a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zm0-128a32 32 0 1 0 0-64 32 32 0 1 0 0 64zm64 64a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zm32-32a32 32 0 1 0 0-64 32 32 0 1 0 0 64z\"]\n};\nconst faDesktop = {\n prefix: 'fas',\n iconName: 'desktop',\n icon: [576, 512, [128421, 61704, \"desktop-alt\"], \"f390\", \"M64 0C28.7 0 0 28.7 0 64L0 352c0 35.3 28.7 64 64 64l176 0-10.7 32L160 448c-17.7 0-32 14.3-32 32s14.3 32 32 32l256 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-69.3 0L336 416l176 0c35.3 0 64-28.7 64-64l0-288c0-35.3-28.7-64-64-64L64 0zM512 64l0 224L64 288 64 64l448 0z\"]\n};\nconst faDesktopAlt = faDesktop;\nconst faM = {\n prefix: 'fas',\n iconName: 'm',\n icon: [448, 512, [109], \"4d\", \"M22.7 33.4c13.5-4.1 28.1 1.1 35.9 12.9L224 294.3 389.4 46.3c7.8-11.7 22.4-17 35.9-12.9S448 49.9 448 64l0 384c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-278.3L250.6 369.8c-5.9 8.9-15.9 14.2-26.6 14.2s-20.7-5.3-26.6-14.2L64 169.7 64 448c0 17.7-14.3 32-32 32s-32-14.3-32-32L0 64C0 49.9 9.2 37.5 22.7 33.4z\"]\n};\nconst faTableList = {\n prefix: 'fas',\n iconName: 'table-list',\n icon: [512, 512, [\"th-list\"], \"f00b\", \"M0 96C0 60.7 28.7 32 64 32l384 0c35.3 0 64 28.7 64 64l0 320c0 35.3-28.7 64-64 64L64 480c-35.3 0-64-28.7-64-64L0 96zm64 0l0 64 64 0 0-64L64 96zm384 0L192 96l0 64 256 0 0-64zM64 224l0 64 64 0 0-64-64 0zm384 0l-256 0 0 64 256 0 0-64zM64 352l0 64 64 0 0-64-64 0zm384 0l-256 0 0 64 256 0 0-64z\"]\n};\nconst faThList = faTableList;\nconst faCommentSms = {\n prefix: 'fas',\n iconName: 'comment-sms',\n icon: [512, 512, [\"sms\"], \"f7cd\", \"M256 448c141.4 0 256-93.1 256-208S397.4 32 256 32S0 125.1 0 240c0 45.1 17.7 86.8 47.7 120.9c-1.9 24.5-11.4 46.3-21.4 62.9c-5.5 9.2-11.1 16.6-15.2 21.6c-2.1 2.5-3.7 4.4-4.9 5.7c-.6 .6-1 1.1-1.3 1.4l-.3 .3c0 0 0 0 0 0c0 0 0 0 0 0s0 0 0 0s0 0 0 0c-4.6 4.6-5.9 11.4-3.4 17.4c2.5 6 8.3 9.9 14.8 9.9c28.7 0 57.6-8.9 81.6-19.3c22.9-10 42.4-21.9 54.3-30.6c31.8 11.5 67 17.9 104.1 17.9zM96 212.8c0-20.3 16.5-36.8 36.8-36.8l19.2 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-19.2 0c-2.7 0-4.8 2.2-4.8 4.8c0 1.6 .8 3.1 2.2 4l29.4 19.6c10.3 6.8 16.4 18.3 16.4 30.7c0 20.3-16.5 36.8-36.8 36.8L112 304c-8.8 0-16-7.2-16-16s7.2-16 16-16l27.2 0c2.7 0 4.8-2.2 4.8-4.8c0-1.6-.8-3.1-2.2-4l-29.4-19.6C102.2 236.7 96 225.2 96 212.8zM372.8 176l19.2 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-19.2 0c-2.7 0-4.8 2.2-4.8 4.8c0 1.6 .8 3.1 2.2 4l29.4 19.6c10.2 6.8 16.4 18.3 16.4 30.7c0 20.3-16.5 36.8-36.8 36.8L352 304c-8.8 0-16-7.2-16-16s7.2-16 16-16l27.2 0c2.7 0 4.8-2.2 4.8-4.8c0-1.6-.8-3.1-2.2-4l-29.4-19.6c-10.2-6.8-16.4-18.3-16.4-30.7c0-20.3 16.5-36.8 36.8-36.8zm-152 6.4L256 229.3l35.2-46.9c4.1-5.5 11.3-7.8 17.9-5.6s10.9 8.3 10.9 15.2l0 96c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-48-19.2 25.6c-3 4-7.8 6.4-12.8 6.4s-9.8-2.4-12.8-6.4L224 240l0 48c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-96c0-6.9 4.4-13 10.9-15.2s13.7 .1 17.9 5.6z\"]\n};\nconst faSms = faCommentSms;\nconst faBook = {\n prefix: 'fas',\n iconName: 'book',\n icon: [448, 512, [128212], \"f02d\", \"M96 0C43 0 0 43 0 96L0 416c0 53 43 96 96 96l288 0 32 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l0-64c17.7 0 32-14.3 32-32l0-320c0-17.7-14.3-32-32-32L384 0 96 0zm0 384l256 0 0 64L96 448c-17.7 0-32-14.3-32-32s14.3-32 32-32zm32-240c0-8.8 7.2-16 16-16l192 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-192 0c-8.8 0-16-7.2-16-16zm16 48l192 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-192 0c-8.8 0-16-7.2-16-16s7.2-16 16-16z\"]\n};\nconst faUserPlus = {\n prefix: 'fas',\n iconName: 'user-plus',\n icon: [640, 512, [], \"f234\", \"M96 128a128 128 0 1 1 256 0A128 128 0 1 1 96 128zM0 482.3C0 383.8 79.8 304 178.3 304l91.4 0C368.2 304 448 383.8 448 482.3c0 16.4-13.3 29.7-29.7 29.7L29.7 512C13.3 512 0 498.7 0 482.3zM504 312l0-64-64 0c-13.3 0-24-10.7-24-24s10.7-24 24-24l64 0 0-64c0-13.3 10.7-24 24-24s24 10.7 24 24l0 64 64 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-64 0 0 64c0 13.3-10.7 24-24 24s-24-10.7-24-24z\"]\n};\nconst faCheck = {\n prefix: 'fas',\n iconName: 'check',\n icon: [448, 512, [10003, 10004], \"f00c\", \"M438.6 105.4c12.5 12.5 12.5 32.8 0 45.3l-256 256c-12.5 12.5-32.8 12.5-45.3 0l-128-128c-12.5-12.5-12.5-32.8 0-45.3s32.8-12.5 45.3 0L160 338.7 393.4 105.4c12.5-12.5 32.8-12.5 45.3 0z\"]\n};\nconst faBatteryThreeQuarters = {\n prefix: 'fas',\n iconName: 'battery-three-quarters',\n icon: [576, 512, [\"battery-4\"], \"f241\", \"M464 160c8.8 0 16 7.2 16 16l0 160c0 8.8-7.2 16-16 16L80 352c-8.8 0-16-7.2-16-16l0-160c0-8.8 7.2-16 16-16l384 0zM80 96C35.8 96 0 131.8 0 176L0 336c0 44.2 35.8 80 80 80l384 0c44.2 0 80-35.8 80-80l0-16c17.7 0 32-14.3 32-32l0-64c0-17.7-14.3-32-32-32l0-16c0-44.2-35.8-80-80-80L80 96zm272 96L96 192l0 128 256 0 0-128z\"]\n};\nconst faBattery4 = faBatteryThreeQuarters;\nconst faHouseCircleCheck = {\n prefix: 'fas',\n iconName: 'house-circle-check',\n icon: [640, 512, [], \"e509\", \"M320.7 352c8.1-89.7 83.5-160 175.3-160c8.9 0 17.6 .7 26.1 1.9L309.5 7c-6-5-14-7-21-7s-15 1-22 8L10 231.5c-7 7-10 15-10 24c0 18 14 32.1 32 32.1l32 0 0 69.7c-.1 .9-.1 1.8-.1 2.8l0 112c0 22.1 17.9 40 40 40l16 0c1.2 0 2.4-.1 3.6-.2c1.5 .1 3 .2 4.5 .2l31.9 0 24 0c22.1 0 40-17.9 40-40l0-24 0-64c0-17.7 14.3-32 32-32l64 0 .7 0zM640 368a144 144 0 1 0 -288 0 144 144 0 1 0 288 0zm-76.7-43.3c6.2 6.2 6.2 16.4 0 22.6l-72 72c-6.2 6.2-16.4 6.2-22.6 0l-40-40c-6.2-6.2-6.2-16.4 0-22.6s16.4-6.2 22.6 0L480 385.4l60.7-60.7c6.2-6.2 16.4-6.2 22.6 0z\"]\n};\nconst faAngleLeft = {\n prefix: 'fas',\n iconName: 'angle-left',\n icon: [320, 512, [8249], \"f104\", \"M41.4 233.4c-12.5 12.5-12.5 32.8 0 45.3l160 160c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3L109.3 256 246.6 118.6c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0l-160 160z\"]\n};\nconst faDiagramSuccessor = {\n prefix: 'fas',\n iconName: 'diagram-successor',\n icon: [512, 512, [], \"e47a\", \"M512 416l0-64c0-35.3-28.7-64-64-64L64 288c-35.3 0-64 28.7-64 64l0 64c0 35.3 28.7 64 64 64l384 0c35.3 0 64-28.7 64-64zM64 160l0-64 144 0 16 0 0 64L64 160zm224 0l0-64 80 0c8.8 0 16 7.2 16 16l0 16-38.1 0c-21.4 0-32.1 25.9-17 41L399 239c9.4 9.4 24.6 9.4 33.9 0L503 169c15.1-15.1 4.4-41-17-41L448 128l0-16c0-44.2-35.8-80-80-80L224 32l-16 0L64 32C28.7 32 0 60.7 0 96l0 64c0 35.3 28.7 64 64 64l160 0c35.3 0 64-28.7 64-64z\"]\n};\nconst faTruckArrowRight = {\n prefix: 'fas',\n iconName: 'truck-arrow-right',\n icon: [640, 512, [], \"e58b\", \"M0 48C0 21.5 21.5 0 48 0L368 0c26.5 0 48 21.5 48 48l0 48 50.7 0c17 0 33.3 6.7 45.3 18.7L589.3 192c12 12 18.7 28.3 18.7 45.3l0 18.7 0 32 0 64c17.7 0 32 14.3 32 32s-14.3 32-32 32l-32 0c0 53-43 96-96 96s-96-43-96-96l-128 0c0 53-43 96-96 96s-96-43-96-96l-16 0c-26.5 0-48-21.5-48-48L0 48zM416 256l128 0 0-18.7L466.7 160 416 160l0 96zM160 464a48 48 0 1 0 0-96 48 48 0 1 0 0 96zm368-48a48 48 0 1 0 -96 0 48 48 0 1 0 96 0zM257 95c-9.4-9.4-24.6-9.4-33.9 0s-9.4 24.6 0 33.9l39 39L96 168c-13.3 0-24 10.7-24 24s10.7 24 24 24l166.1 0-39 39c-9.4 9.4-9.4 24.6 0 33.9s24.6 9.4 33.9 0l80-80c9.4-9.4 9.4-24.6 0-33.9L257 95z\"]\n};\nconst faArrowsSplitUpAndLeft = {\n prefix: 'fas',\n iconName: 'arrows-split-up-and-left',\n icon: [512, 512, [], \"e4bc\", \"M246.6 150.6c-12.5 12.5-32.8 12.5-45.3 0s-12.5-32.8 0-45.3l96-96c12.5-12.5 32.8-12.5 45.3 0l96 96c12.5 12.5 12.5 32.8 0 45.3s-32.8 12.5-45.3 0L352 109.3 352 384c0 35.3 28.7 64 64 64l64 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-64 0c-70.7 0-128-57.3-128-128c0-35.3-28.7-64-64-64l-114.7 0 41.4 41.4c12.5 12.5 12.5 32.8 0 45.3s-32.8 12.5-45.3 0l-96-96c-12.5-12.5-12.5-32.8 0-45.3l96-96c12.5-12.5 32.8-12.5 45.3 0s12.5 32.8 0 45.3L109.3 256 224 256c23.3 0 45.2 6.2 64 17.1l0-163.9-41.4 41.4z\"]\n};\nconst faHandFist = {\n prefix: 'fas',\n iconName: 'hand-fist',\n icon: [448, 512, [9994, \"fist-raised\"], \"f6de\", \"M192 0c17.7 0 32 14.3 32 32l0 112-64 0 0-112c0-17.7 14.3-32 32-32zM64 64c0-17.7 14.3-32 32-32s32 14.3 32 32l0 80-64 0 0-80zm192 0c0-17.7 14.3-32 32-32s32 14.3 32 32l0 96c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-96zm96 64c0-17.7 14.3-32 32-32s32 14.3 32 32l0 64c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-64zm-96 88l0-.6c9.4 5.4 20.3 8.6 32 8.6c13.2 0 25.4-4 35.6-10.8c8.7 24.9 32.5 42.8 60.4 42.8c11.7 0 22.6-3.1 32-8.6l0 8.6c0 52.3-25.1 98.8-64 128l0 96c0 17.7-14.3 32-32 32l-160 0c-17.7 0-32-14.3-32-32l0-78.4c-17.3-7.9-33.2-18.8-46.9-32.5L69.5 357.5C45.5 333.5 32 300.9 32 267l0-27c0-35.3 28.7-64 64-64l88 0c22.1 0 40 17.9 40 40s-17.9 40-40 40l-56 0c-8.8 0-16 7.2-16 16s7.2 16 16 16l56 0c39.8 0 72-32.2 72-72z\"]\n};\nconst faFistRaised = faHandFist;\nconst faCloudMoon = {\n prefix: 'fas',\n iconName: 'cloud-moon',\n icon: [640, 512, [], \"f6c3\", \"M495.8 0c5.5 0 10.9 .2 16.3 .7c7 .6 12.8 5.7 14.3 12.5s-1.6 13.9-7.7 17.3c-44.4 25.2-74.4 73-74.4 127.8c0 81 65.5 146.6 146.2 146.6c8.6 0 17-.7 25.1-2.1c6.9-1.2 13.8 2.2 17 8.5s1.9 13.8-3.1 18.7c-34.5 33.6-81.7 54.4-133.6 54.4c-9.3 0-18.4-.7-27.4-1.9c-11.2-22.6-29.8-40.9-52.6-51.7c-2.7-58.5-50.3-105.3-109.2-106.7c-1.7-10.4-2.6-21-2.6-31.8C304 86.1 389.8 0 495.8 0zM447.9 431.9c0 44.2-35.8 80-80 80L96 511.9c-53 0-96-43-96-96c0-47.6 34.6-87 80-94.6l0-1.3c0-53 43-96 96-96c34.9 0 65.4 18.6 82.2 46.4c13-9.1 28.8-14.4 45.8-14.4c44.2 0 80 35.8 80 80c0 5.9-.6 11.7-1.9 17.2c37.4 6.7 65.8 39.4 65.8 78.7z\"]\n};\nconst faBriefcase = {\n prefix: 'fas',\n iconName: 'briefcase',\n icon: [512, 512, [128188], \"f0b1\", \"M184 48l144 0c4.4 0 8 3.6 8 8l0 40L176 96l0-40c0-4.4 3.6-8 8-8zm-56 8l0 40L64 96C28.7 96 0 124.7 0 160l0 96 192 0 128 0 192 0 0-96c0-35.3-28.7-64-64-64l-64 0 0-40c0-30.9-25.1-56-56-56L184 0c-30.9 0-56 25.1-56 56zM512 288l-192 0 0 32c0 17.7-14.3 32-32 32l-64 0c-17.7 0-32-14.3-32-32l0-32L0 288 0 416c0 35.3 28.7 64 64 64l384 0c35.3 0 64-28.7 64-64l0-128z\"]\n};\nconst faPersonFalling = {\n prefix: 'fas',\n iconName: 'person-falling',\n icon: [512, 512, [], \"e546\", \"M288 0c17.7 0 32 14.3 32 32l0 9.8c0 54.6-27.9 104.6-72.5 133.6l.2 .3L304.5 256l87.5 0c15.1 0 29.3 7.1 38.4 19.2l43.2 57.6c10.6 14.1 7.7 34.2-6.4 44.8s-34.2 7.7-44.8-6.4L384 320l-96 0-1.4 0 92.3 142.6c9.6 14.8 5.4 34.6-9.5 44.3s-34.6 5.4-44.3-9.5L164.5 249.2c-2.9 9.2-4.5 19-4.5 29l0 73.8c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-73.8c0-65.1 39.6-123.7 100.1-147.9C232.3 115.8 256 80.8 256 41.8l0-9.8c0-17.7 14.3-32 32-32zM112 32a48 48 0 1 1 0 96 48 48 0 1 1 0-96z\"]\n};\nconst faImagePortrait = {\n prefix: 'fas',\n iconName: 'image-portrait',\n icon: [384, 512, [\"portrait\"], \"f3e0\", \"M384 64c0-35.3-28.7-64-64-64L64 0C28.7 0 0 28.7 0 64L0 448c0 35.3 28.7 64 64 64l256 0c35.3 0 64-28.7 64-64l0-384zM128 192a64 64 0 1 1 128 0 64 64 0 1 1 -128 0zM80 356.6c0-37.9 30.7-68.6 68.6-68.6l86.9 0c37.9 0 68.6 30.7 68.6 68.6c0 15.1-12.3 27.4-27.4 27.4l-169.1 0C92.3 384 80 371.7 80 356.6z\"]\n};\nconst faPortrait = faImagePortrait;\nconst faUserTag = {\n prefix: 'fas',\n iconName: 'user-tag',\n icon: [640, 512, [], \"f507\", \"M224 256A128 128 0 1 0 224 0a128 128 0 1 0 0 256zm-45.7 48C79.8 304 0 383.8 0 482.3C0 498.7 13.3 512 29.7 512l388.6 0c10 0 18.8-4.9 24.2-12.5l-99.2-99.2c-14.9-14.9-23.3-35.1-23.3-56.1l0-33c-15.9-4.7-32.8-7.2-50.3-7.2l-91.4 0zM384 224c-17.7 0-32 14.3-32 32l0 82.7c0 17 6.7 33.3 18.7 45.3L478.1 491.3c18.7 18.7 49.1 18.7 67.9 0l73.4-73.4c18.7-18.7 18.7-49.1 0-67.9L512 242.7c-12-12-28.3-18.7-45.3-18.7L384 224zm24 80a24 24 0 1 1 48 0 24 24 0 1 1 -48 0z\"]\n};\nconst faRug = {\n prefix: 'fas',\n iconName: 'rug',\n icon: [640, 512, [], \"e569\", \"M24 64l32 0 24 0 0 24 0 88 0 80 0 80 0 88 0 24-24 0-32 0c-13.3 0-24-10.7-24-24s10.7-24 24-24l8 0 0-40-8 0c-13.3 0-24-10.7-24-24s10.7-24 24-24l8 0 0-32-8 0c-13.3 0-24-10.7-24-24s10.7-24 24-24l8 0 0-32-8 0c-13.3 0-24-10.7-24-24s10.7-24 24-24l8 0 0-40-8 0C10.7 112 0 101.3 0 88S10.7 64 24 64zm88 0l416 0 0 384-416 0 0-384zM640 88c0 13.3-10.7 24-24 24l-8 0 0 40 8 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-8 0 0 32 8 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-8 0 0 32 8 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-8 0 0 40 8 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-32 0-24 0 0-24 0-88 0-80 0-80 0-88 0-24 24 0 32 0c13.3 0 24 10.7 24 24z\"]\n};\nconst faEarthEurope = {\n prefix: 'fas',\n iconName: 'earth-europe',\n icon: [512, 512, [\"globe-europe\"], \"f7a2\", \"M266.3 48.3L232.5 73.6c-5.4 4-8.5 10.4-8.5 17.1l0 9.1c0 6.8 5.5 12.3 12.3 12.3c2.4 0 4.8-.7 6.8-2.1l41.8-27.9c2-1.3 4.4-2.1 6.8-2.1l1 0c6.2 0 11.3 5.1 11.3 11.3c0 3-1.2 5.9-3.3 8l-19.9 19.9c-5.8 5.8-12.9 10.2-20.7 12.8l-26.5 8.8c-5.8 1.9-9.6 7.3-9.6 13.4c0 3.7-1.5 7.3-4.1 10l-17.9 17.9c-6.4 6.4-9.9 15-9.9 24l0 4.3c0 16.4 13.6 29.7 29.9 29.7c11 0 21.2-6.2 26.1-16l4-8.1c2.4-4.8 7.4-7.9 12.8-7.9c4.5 0 8.7 2.1 11.4 5.7l16.3 21.7c2.1 2.9 5.5 4.5 9.1 4.5c8.4 0 13.9-8.9 10.1-16.4l-1.1-2.3c-3.5-7 0-15.5 7.5-18l21.2-7.1c7.6-2.5 12.7-9.6 12.7-17.6c0-10.3 8.3-18.6 18.6-18.6l29.4 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-20.7 0c-7.2 0-14.2 2.9-19.3 8l-4.7 4.7c-2.1 2.1-3.3 5-3.3 8c0 6.2 5.1 11.3 11.3 11.3l11.3 0c6 0 11.8 2.4 16 6.6l6.5 6.5c1.8 1.8 2.8 4.3 2.8 6.8s-1 5-2.8 6.8l-7.5 7.5C386 262 384 266.9 384 272s2 10 5.7 13.7L408 304c10.2 10.2 24.1 16 38.6 16l7.3 0c6.5-20.2 10-41.7 10-64c0-111.4-87.6-202.4-197.7-207.7zm172 307.9c-3.7-2.6-8.2-4.1-13-4.1c-6 0-11.8-2.4-16-6.6L396 332c-7.7-7.7-18-12-28.9-12c-9.7 0-19.2-3.5-26.6-9.8L314 287.4c-11.6-9.9-26.4-15.4-41.7-15.4l-20.9 0c-12.6 0-25 3.7-35.5 10.7L188.5 301c-17.8 11.9-28.5 31.9-28.5 53.3l0 3.2c0 17 6.7 33.3 18.7 45.3l16 16c8.5 8.5 20 13.3 32 13.3l21.3 0c13.3 0 24 10.7 24 24c0 2.5 .4 5 1.1 7.3c71.3-5.8 132.5-47.6 165.2-107.2zM0 256a256 256 0 1 1 512 0A256 256 0 1 1 0 256zM187.3 100.7c-6.2-6.2-16.4-6.2-22.6 0l-32 32c-6.2 6.2-6.2 16.4 0 22.6s16.4 6.2 22.6 0l32-32c6.2-6.2 6.2-16.4 0-22.6z\"]\n};\nconst faGlobeEurope = faEarthEurope;\nconst faCartFlatbedSuitcase = {\n prefix: 'fas',\n iconName: 'cart-flatbed-suitcase',\n icon: [640, 512, [\"luggage-cart\"], \"f59d\", \"M0 32C0 14.3 14.3 0 32 0L48 0c44.2 0 80 35.8 80 80l0 288c0 8.8 7.2 16 16 16l464 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l-66.7 0c1.8 5 2.7 10.4 2.7 16c0 26.5-21.5 48-48 48s-48-21.5-48-48c0-5.6 1-11 2.7-16l-197.5 0c1.8 5 2.7 10.4 2.7 16c0 26.5-21.5 48-48 48s-48-21.5-48-48c0-5.6 1-11 2.7-16L144 448c-44.2 0-80-35.8-80-80L64 80c0-8.8-7.2-16-16-16L32 64C14.3 64 0 49.7 0 32zM432 96l0-40c0-4.4-3.6-8-8-8l-80 0c-4.4 0-8 3.6-8 8l0 40 96 0zM288 96l0-40c0-30.9 25.1-56 56-56l80 0c30.9 0 56 25.1 56 56l0 40 0 224-192 0 0-224zM512 320l0-224 16 0c26.5 0 48 21.5 48 48l0 128c0 26.5-21.5 48-48 48l-16 0zM240 96l16 0 0 224-16 0c-26.5 0-48-21.5-48-48l0-128c0-26.5 21.5-48 48-48z\"]\n};\nconst faLuggageCart = faCartFlatbedSuitcase;\nconst faRectangleXmark = {\n prefix: 'fas',\n iconName: 'rectangle-xmark',\n icon: [512, 512, [62164, \"rectangle-times\", \"times-rectangle\", \"window-close\"], \"f410\", \"M64 32C28.7 32 0 60.7 0 96L0 416c0 35.3 28.7 64 64 64l384 0c35.3 0 64-28.7 64-64l0-320c0-35.3-28.7-64-64-64L64 32zM175 175c9.4-9.4 24.6-9.4 33.9 0l47 47 47-47c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9l-47 47 47 47c9.4 9.4 9.4 24.6 0 33.9s-24.6 9.4-33.9 0l-47-47-47 47c-9.4 9.4-24.6 9.4-33.9 0s-9.4-24.6 0-33.9l47-47-47-47c-9.4-9.4-9.4-24.6 0-33.9z\"]\n};\nconst faRectangleTimes = faRectangleXmark;\nconst faTimesRectangle = faRectangleXmark;\nconst faWindowClose = faRectangleXmark;\nconst faBahtSign = {\n prefix: 'fas',\n iconName: 'baht-sign',\n icon: [320, 512, [], \"e0ac\", \"M144 0c-17.7 0-32 14.3-32 32l0 32L37.6 64C16.8 64 0 80.8 0 101.6L0 224l0 41.7L0 288 0 406.3c0 23 18.7 41.7 41.7 41.7l70.3 0 0 32c0 17.7 14.3 32 32 32s32-14.3 32-32l0-32 32 0c61.9 0 112-50.1 112-112c0-40.1-21.1-75.3-52.7-95.1C280.3 222.6 288 200.2 288 176c0-61.9-50.1-112-112-112l0-32c0-17.7-14.3-32-32-32zM112 128l0 96-48 0 0-96 48 0zm64 96l0-96c26.5 0 48 21.5 48 48s-21.5 48-48 48zm-64 64l0 96-48 0 0-96 48 0zm64 96l0-96 32 0c26.5 0 48 21.5 48 48s-21.5 48-48 48l-32 0z\"]\n};\nconst faBookOpen = {\n prefix: 'fas',\n iconName: 'book-open',\n icon: [576, 512, [128214, 128366], \"f518\", \"M249.6 471.5c10.8 3.8 22.4-4.1 22.4-15.5l0-377.4c0-4.2-1.6-8.4-5-11C247.4 52 202.4 32 144 32C93.5 32 46.3 45.3 18.1 56.1C6.8 60.5 0 71.7 0 83.8L0 454.1c0 11.9 12.8 20.2 24.1 16.5C55.6 460.1 105.5 448 144 448c33.9 0 79 14 105.6 23.5zm76.8 0C353 462 398.1 448 432 448c38.5 0 88.4 12.1 119.9 22.6c11.3 3.8 24.1-4.6 24.1-16.5l0-370.3c0-12.1-6.8-23.3-18.1-27.6C529.7 45.3 482.5 32 432 32c-58.4 0-103.4 20-123 35.6c-3.3 2.6-5 6.8-5 11L304 456c0 11.4 11.7 19.3 22.4 15.5z\"]\n};\nconst faBookJournalWhills = {\n prefix: 'fas',\n iconName: 'book-journal-whills',\n icon: [448, 512, [\"journal-whills\"], \"f66a\", \"M0 96C0 43 43 0 96 0L384 0l32 0c17.7 0 32 14.3 32 32l0 320c0 17.7-14.3 32-32 32l0 64c17.7 0 32 14.3 32 32s-14.3 32-32 32l-32 0L96 512c-53 0-96-43-96-96L0 96zM64 416c0 17.7 14.3 32 32 32l256 0 0-64L96 384c-17.7 0-32 14.3-32 32zm90.4-234.4l-21.2-21.2c-3 10.1-5.1 20.6-5.1 31.6c0 .2 0 .5 .1 .8s.1 .5 .1 .8L165.2 226c2.5 2.1 3.4 5.8 2.3 8.9c-1.3 3-4.1 5.1-7.5 5.1c-1.9-.1-3.8-.8-5.2-2l-23.6-20.6C142.8 267 186.9 304 240 304s97.3-37 108.9-86.6L325.3 238c-1.4 1.2-3.3 2-5.3 2c-2.2-.1-4.4-1.1-6-2.8c-1.2-1.5-1.9-3.4-2-5.2c.1-2.2 1.1-4.4 2.8-6l37.1-32.5c0-.3 0-.5 .1-.8s.1-.5 .1-.8c0-11-2.1-21.5-5.1-31.6l-21.2 21.2c-3.1 3.1-8.1 3.1-11.3 0s-3.1-8.1 0-11.2l26.4-26.5c-8.2-17-20.5-31.7-35.9-42.6c-2.7-1.9-6.2 1.4-5 4.5c8.5 22.4 3.6 48-13 65.6c-3.2 3.4-3.6 8.9-.9 12.7c9.8 14 12.7 31.9 7.5 48.5c-5.9 19.4-22 34.1-41.9 38.3l-1.4-34.3 12.6 8.6c.6 .4 1.5 .6 2.3 .6c1.5 0 2.7-.8 3.5-2s.6-2.8-.1-4L260 225.4l18-3.6c1.8-.4 3.1-2.1 3.1-4s-1.4-3.5-3.1-3.9l-18-3.7 8.5-14.3c.8-1.2 .9-2.9 .1-4.1s-2-2-3.5-2l-.1 0c-.7 .1-1.5 .3-2.1 .7l-14.1 9.6L244 87.9c-.1-2.2-1.9-3.9-4-3.9s-3.9 1.6-4 3.9l-4.6 110.8-12-8.1c-1.5-1.1-3.6-.9-5 .4s-1.6 3.4-.8 5l8.6 14.3-18 3.7c-1.8 .4-3.1 2-3.1 3.9s1.4 3.6 3.1 4l18 3.8-8.6 14.2c-.2 .6-.5 1.4-.5 2c0 1.1 .5 2.1 1.2 3c.8 .6 1.8 1 2.8 1c.7 0 1.6-.2 2.2-.6l10.4-7.1-1.4 32.8c-19.9-4.1-36-18.9-41.9-38.3c-5.1-16.6-2.2-34.4 7.6-48.5c2.7-3.9 2.3-9.3-.9-12.7c-16.6-17.5-21.6-43.1-13.1-65.5c1.2-3.1-2.3-6.4-5-4.5c-15.3 10.9-27.6 25.6-35.8 42.6l26.4 26.5c3.1 3.1 3.1 8.1 0 11.2s-8.1 3.1-11.2 0z\"]\n};\nconst faJournalWhills = faBookJournalWhills;\nconst faHandcuffs = {\n prefix: 'fas',\n iconName: 'handcuffs',\n icon: [640, 512, [], \"e4f8\", \"M240 32a32 32 0 1 1 64 0 32 32 0 1 1 -64 0zM192 48a32 32 0 1 1 0 64 32 32 0 1 1 0-64zm-32 80c17.7 0 32 14.3 32 32l8 0c13.3 0 24 10.7 24 24l0 16c0 1.7-.2 3.4-.5 5.1C280.3 229.6 320 286.2 320 352c0 88.4-71.6 160-160 160S0 440.4 0 352c0-65.8 39.7-122.4 96.5-146.9c-.4-1.6-.5-3.3-.5-5.1l0-16c0-13.3 10.7-24 24-24l8 0c0-17.7 14.3-32 32-32zm0 320a96 96 0 1 0 0-192 96 96 0 1 0 0 192zm192-96c0-25.9-5.1-50.5-14.4-73.1c16.9-32.9 44.8-59.1 78.9-73.9c-.4-1.6-.5-3.3-.5-5.1l0-16c0-13.3 10.7-24 24-24l8 0c0-17.7 14.3-32 32-32s32 14.3 32 32l8 0c13.3 0 24 10.7 24 24l0 16c0 1.7-.2 3.4-.5 5.1C600.3 229.6 640 286.2 640 352c0 88.4-71.6 160-160 160c-62 0-115.8-35.3-142.4-86.9c9.3-22.5 14.4-47.2 14.4-73.1zm224 0a96 96 0 1 0 -192 0 96 96 0 1 0 192 0zM368 0a32 32 0 1 1 0 64 32 32 0 1 1 0-64zm80 48a32 32 0 1 1 0 64 32 32 0 1 1 0-64z\"]\n};\nconst faTriangleExclamation = {\n prefix: 'fas',\n iconName: 'triangle-exclamation',\n icon: [512, 512, [9888, \"exclamation-triangle\", \"warning\"], \"f071\", \"M256 32c14.2 0 27.3 7.5 34.5 19.8l216 368c7.3 12.4 7.3 27.7 .2 40.1S486.3 480 472 480L40 480c-14.3 0-27.6-7.7-34.7-20.1s-7-27.8 .2-40.1l216-368C228.7 39.5 241.8 32 256 32zm0 128c-13.3 0-24 10.7-24 24l0 112c0 13.3 10.7 24 24 24s24-10.7 24-24l0-112c0-13.3-10.7-24-24-24zm32 224a32 32 0 1 0 -64 0 32 32 0 1 0 64 0z\"]\n};\nconst faExclamationTriangle = faTriangleExclamation;\nconst faWarning = faTriangleExclamation;\nconst faDatabase = {\n prefix: 'fas',\n iconName: 'database',\n icon: [448, 512, [], \"f1c0\", \"M448 80l0 48c0 44.2-100.3 80-224 80S0 172.2 0 128L0 80C0 35.8 100.3 0 224 0S448 35.8 448 80zM393.2 214.7c20.8-7.4 39.9-16.9 54.8-28.6L448 288c0 44.2-100.3 80-224 80S0 332.2 0 288L0 186.1c14.9 11.8 34 21.2 54.8 28.6C99.7 230.7 159.5 240 224 240s124.3-9.3 169.2-25.3zM0 346.1c14.9 11.8 34 21.2 54.8 28.6C99.7 390.7 159.5 400 224 400s124.3-9.3 169.2-25.3c20.8-7.4 39.9-16.9 54.8-28.6l0 85.9c0 44.2-100.3 80-224 80S0 476.2 0 432l0-85.9z\"]\n};\nconst faShare = {\n prefix: 'fas',\n iconName: 'share',\n icon: [512, 512, [\"mail-forward\"], \"f064\", \"M307 34.8c-11.5 5.1-19 16.6-19 29.2l0 64-112 0C78.8 128 0 206.8 0 304C0 417.3 81.5 467.9 100.2 478.1c2.5 1.4 5.3 1.9 8.1 1.9c10.9 0 19.7-8.9 19.7-19.7c0-7.5-4.3-14.4-9.8-19.5C108.8 431.9 96 414.4 96 384c0-53 43-96 96-96l96 0 0 64c0 12.6 7.4 24.1 19 29.2s25 3 34.4-5.4l160-144c6.7-6.1 10.6-14.7 10.6-23.8s-3.8-17.7-10.6-23.8l-160-144c-9.4-8.5-22.9-10.6-34.4-5.4z\"]\n};\nconst faMailForward = faShare;\nconst faBottleDroplet = {\n prefix: 'fas',\n iconName: 'bottle-droplet',\n icon: [320, 512, [], \"e4c4\", \"M96 0C82.7 0 72 10.7 72 24s10.7 24 24 24c4.4 0 8 3.6 8 8l0 64.9c0 12.2-7.2 23.1-17.2 30.1C53.7 174.1 32 212.5 32 256l0 192c0 35.3 28.7 64 64 64l128 0c35.3 0 64-28.7 64-64l0-192c0-43.5-21.7-81.9-54.8-105c-10-7-17.2-17.9-17.2-30.1L216 56c0-4.4 3.6-8 8-8c13.3 0 24-10.7 24-24s-10.7-24-24-24l-8 0s0 0 0 0s0 0 0 0L104 0s0 0 0 0s0 0 0 0L96 0zm64 382c-26.5 0-48-20.1-48-45c0-16.8 22.1-48.1 36.3-66.4c6-7.8 17.5-7.8 23.5 0C185.9 288.9 208 320.2 208 337c0 24.9-21.5 45-48 45z\"]\n};\nconst faMaskFace = {\n prefix: 'fas',\n iconName: 'mask-face',\n icon: [640, 512, [], \"e1d7\", \"M320 64c-27.2 0-53.8 8-76.4 23.1l-37.1 24.8c-15.8 10.5-34.3 16.1-53.3 16.1l-9.2 0-16 0-72 0c-30.9 0-56 25.1-56 56l0 85c0 55.1 37.5 103.1 90.9 116.4l108 27C233.8 435 275.4 448 320 448s86.2-13 121.1-35.5l108-27C602.5 372.1 640 324.1 640 269l0-85c0-30.9-25.1-56-56-56l-72 0-16 0-9.2 0c-19 0-37.5-5.6-53.3-16.1L396.4 87.1C373.8 72 347.2 64 320 64zM132.3 346.3l-29.8-7.4C70.5 330.9 48 302.1 48 269l0-85c0-4.4 3.6-8 8-8l40 0 0 48c0 45.1 13.4 87.2 36.3 122.3zm405.1-7.4l-29.8 7.4c23-35.2 36.3-77.2 36.3-122.3l0-48 40 0c4.4 0 8 3.6 8 8l0 85c0 33-22.5 61.8-54.5 69.9zM192 208c0-8.8 7.2-16 16-16l224 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-224 0c-8.8 0-16-7.2-16-16zm16 48l224 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-224 0c-8.8 0-16-7.2-16-16s7.2-16 16-16zm16 80c0-8.8 7.2-16 16-16l160 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-160 0c-8.8 0-16-7.2-16-16z\"]\n};\nconst faHillRockslide = {\n prefix: 'fas',\n iconName: 'hill-rockslide',\n icon: [576, 512, [], \"e508\", \"M252.4 103.8l27 48c2.8 5 8.2 8.2 13.9 8.2l53.3 0c5.8 0 11.1-3.1 13.9-8.2l27-48c2.7-4.9 2.7-10.8 0-15.7l-27-48c-2.8-5-8.2-8.2-13.9-8.2l-53.3 0c-5.8 0-11.1 3.1-13.9 8.2l-27 48c-2.7 4.9-2.7 10.8 0 15.7zM68.3 87C43.1 61.8 0 79.7 0 115.3L0 432c0 44.2 35.8 80 80 80l316.7 0c35.6 0 53.5-43.1 28.3-68.3L68.3 87zM504.2 403.6c4.9 2.7 10.8 2.7 15.7 0l48-27c5-2.8 8.2-8.2 8.2-13.9l0-53.3c0-5.8-3.1-11.1-8.2-13.9l-48-27c-4.9-2.7-10.8-2.7-15.7 0l-48 27c-5 2.8-8.2 8.2-8.2 13.9l0 53.3c0 5.8 3.1 11.1 8.2 13.9l48 27zM192 64a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zM384 288a32 32 0 1 0 0-64 32 32 0 1 0 0 64z\"]\n};\nconst faRightLeft = {\n prefix: 'fas',\n iconName: 'right-left',\n icon: [512, 512, [\"exchange-alt\"], \"f362\", \"M32 96l320 0 0-64c0-12.9 7.8-24.6 19.8-29.6s25.7-2.2 34.9 6.9l96 96c6 6 9.4 14.1 9.4 22.6s-3.4 16.6-9.4 22.6l-96 96c-9.2 9.2-22.9 11.9-34.9 6.9s-19.8-16.6-19.8-29.6l0-64L32 160c-17.7 0-32-14.3-32-32s14.3-32 32-32zM480 352c17.7 0 32 14.3 32 32s-14.3 32-32 32l-320 0 0 64c0 12.9-7.8 24.6-19.8 29.6s-25.7 2.2-34.9-6.9l-96-96c-6-6-9.4-14.1-9.4-22.6s3.4-16.6 9.4-22.6l96-96c9.2-9.2 22.9-11.9 34.9-6.9s19.8 16.6 19.8 29.6l0 64 320 0z\"]\n};\nconst faExchangeAlt = faRightLeft;\nconst faPaperPlane = {\n prefix: 'fas',\n iconName: 'paper-plane',\n icon: [512, 512, [61913], \"f1d8\", \"M498.1 5.6c10.1 7 15.4 19.1 13.5 31.2l-64 416c-1.5 9.7-7.4 18.2-16 23s-18.9 5.4-28 1.6L284 427.7l-68.5 74.1c-8.9 9.7-22.9 12.9-35.2 8.1S160 493.2 160 480l0-83.6c0-4 1.5-7.8 4.2-10.8L331.8 202.8c5.8-6.3 5.6-16-.4-22s-15.7-6.4-22-.7L106 360.8 17.7 316.6C7.1 311.3 .3 300.7 0 288.9s5.9-22.8 16.1-28.7l448-256c10.7-6.1 23.9-5.5 34 1.4z\"]\n};\nconst faRoadCircleExclamation = {\n prefix: 'fas',\n iconName: 'road-circle-exclamation',\n icon: [640, 512, [], \"e565\", \"M213.2 32L288 32l0 64c0 17.7 14.3 32 32 32s32-14.3 32-32l0-64 74.8 0c27.1 0 51.3 17.1 60.3 42.6l42.7 120.6c-10.9-2.1-22.2-3.2-33.8-3.2c-59.5 0-112.1 29.6-144 74.8l0-42.8c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 64c0 17.7 14.3 32 32 32c2.3 0 4.6-.3 6.8-.7c-4.5 15.5-6.8 31.8-6.8 48.7c0 5.4 .2 10.7 .7 16l-.7 0c-17.7 0-32 14.3-32 32l0 64L86.6 480C56.5 480 32 455.5 32 425.4c0-6.2 1.1-12.4 3.1-18.2L152.9 74.6C162 49.1 186.1 32 213.2 32zM496 224a144 144 0 1 1 0 288 144 144 0 1 1 0-288zm0 240a24 24 0 1 0 0-48 24 24 0 1 0 0 48zm0-192c-8.8 0-16 7.2-16 16l0 80c0 8.8 7.2 16 16 16s16-7.2 16-16l0-80c0-8.8-7.2-16-16-16z\"]\n};\nconst faDungeon = {\n prefix: 'fas',\n iconName: 'dungeon',\n icon: [512, 512, [], \"f6d9\", \"M336.6 156.5c1.3 1.1 2.7 2.2 3.9 3.3c9.3 8.2 23 10.5 33.4 3.6l67.6-45.1c11.4-7.6 14.2-23.2 5.1-33.4C430 66.6 410.9 50.6 389.7 37.6c-11.9-7.3-26.9-1.4-32.1 11.6l-30.5 76.2c-4.5 11.1 .2 23.6 9.5 31.2zM328 36.8c5.1-12.8-1.6-27.4-15-30.5C294.7 2.2 275.6 0 256 0s-38.7 2.2-57 6.4C185.5 9.4 178.8 24 184 36.8l30.3 75.8c4.5 11.3 16.8 17.2 29 16c4.2-.4 8.4-.6 12.7-.6s8.6 .2 12.7 .6c12.1 1.2 24.4-4.7 29-16L328 36.8zM65.5 85c-9.1 10.2-6.3 25.8 5.1 33.4l67.6 45.1c10.3 6.9 24.1 4.6 33.4-3.6c1.3-1.1 2.6-2.3 4-3.3c9.3-7.5 13.9-20.1 9.5-31.2L154.4 49.2c-5.2-12.9-20.3-18.8-32.1-11.6C101.1 50.6 82 66.6 65.5 85zm314 137.1c.9 3.3 1.7 6.6 2.3 10c2.5 13 13 23.9 26.2 23.9l80 0c13.3 0 24.1-10.8 22.9-24c-2.5-27.2-9.3-53.2-19.7-77.3c-5.5-12.9-21.4-16.6-33.1-8.9l-68.6 45.7c-9.8 6.5-13.2 19.2-10 30.5zM53.9 145.8c-11.6-7.8-27.6-4-33.1 8.9C10.4 178.8 3.6 204.8 1.1 232c-1.2 13.2 9.6 24 22.9 24l80 0c13.3 0 23.8-10.8 26.2-23.9c.6-3.4 1.4-6.7 2.3-10c3.1-11.4-.2-24-10-30.5L53.9 145.8zM104 288l-80 0c-13.3 0-24 10.7-24 24l0 48c0 13.3 10.7 24 24 24l80 0c13.3 0 24-10.7 24-24l0-48c0-13.3-10.7-24-24-24zm304 0c-13.3 0-24 10.7-24 24l0 48c0 13.3 10.7 24 24 24l80 0c13.3 0 24-10.7 24-24l0-48c0-13.3-10.7-24-24-24l-80 0zM24 416c-13.3 0-24 10.7-24 24l0 48c0 13.3 10.7 24 24 24l80 0c13.3 0 24-10.7 24-24l0-48c0-13.3-10.7-24-24-24l-80 0zm384 0c-13.3 0-24 10.7-24 24l0 48c0 13.3 10.7 24 24 24l80 0c13.3 0 24-10.7 24-24l0-48c0-13.3-10.7-24-24-24l-80 0zM272 192c0-8.8-7.2-16-16-16s-16 7.2-16 16l0 272c0 8.8 7.2 16 16 16s16-7.2 16-16l0-272zm-64 32c0-8.8-7.2-16-16-16s-16 7.2-16 16l0 240c0 8.8 7.2 16 16 16s16-7.2 16-16l0-240zm128 0c0-8.8-7.2-16-16-16s-16 7.2-16 16l0 240c0 8.8 7.2 16 16 16s16-7.2 16-16l0-240z\"]\n};\nconst faAlignRight = {\n prefix: 'fas',\n iconName: 'align-right',\n icon: [448, 512, [], \"f038\", \"M448 64c0 17.7-14.3 32-32 32L192 96c-17.7 0-32-14.3-32-32s14.3-32 32-32l224 0c17.7 0 32 14.3 32 32zm0 256c0 17.7-14.3 32-32 32l-224 0c-17.7 0-32-14.3-32-32s14.3-32 32-32l224 0c17.7 0 32 14.3 32 32zM0 192c0-17.7 14.3-32 32-32l384 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L32 224c-17.7 0-32-14.3-32-32zM448 448c0 17.7-14.3 32-32 32L32 480c-17.7 0-32-14.3-32-32s14.3-32 32-32l384 0c17.7 0 32 14.3 32 32z\"]\n};\nconst faMoneyBill1Wave = {\n prefix: 'fas',\n iconName: 'money-bill-1-wave',\n icon: [576, 512, [\"money-bill-wave-alt\"], \"f53b\", \"M0 112.5L0 422.3c0 18 10.1 35 27 41.3c87 32.5 174 10.3 261-11.9c79.8-20.3 159.6-40.7 239.3-18.9c23 6.3 48.7-9.5 48.7-33.4l0-309.9c0-18-10.1-35-27-41.3C462 15.9 375 38.1 288 60.3C208.2 80.6 128.4 100.9 48.7 79.1C25.6 72.8 0 88.6 0 112.5zM128 416l-64 0 0-64c35.3 0 64 28.7 64 64zM64 224l0-64 64 0c0 35.3-28.7 64-64 64zM448 352c0-35.3 28.7-64 64-64l0 64-64 0zm64-192c-35.3 0-64-28.7-64-64l64 0 0 64zM384 256c0 61.9-43 112-96 112s-96-50.1-96-112s43-112 96-112s96 50.1 96 112zM252 208c0 9.7 6.9 17.7 16 19.6l0 48.4-4 0c-11 0-20 9-20 20s9 20 20 20l24 0 24 0c11 0 20-9 20-20s-9-20-20-20l-4 0 0-68c0-11-9-20-20-20l-16 0c-11 0-20 9-20 20z\"]\n};\nconst faMoneyBillWaveAlt = faMoneyBill1Wave;\nconst faLifeRing = {\n prefix: 'fas',\n iconName: 'life-ring',\n icon: [512, 512, [], \"f1cd\", \"M367.2 412.5C335.9 434.9 297.5 448 256 448s-79.9-13.1-111.2-35.5l58-58c15.8 8.6 34 13.5 53.3 13.5s37.4-4.9 53.3-13.5l58 58zm90.7 .8c33.8-43.4 54-98 54-157.3s-20.2-113.9-54-157.3c9-12.5 7.9-30.1-3.4-41.3S425.8 45 413.3 54C369.9 20.2 315.3 0 256 0S142.1 20.2 98.7 54c-12.5-9-30.1-7.9-41.3 3.4S45 86.2 54 98.7C20.2 142.1 0 196.7 0 256s20.2 113.9 54 157.3c-9 12.5-7.9 30.1 3.4 41.3S86.2 467 98.7 458c43.4 33.8 98 54 157.3 54s113.9-20.2 157.3-54c12.5 9 30.1 7.9 41.3-3.4s12.4-28.8 3.4-41.3zm-45.5-46.1l-58-58c8.6-15.8 13.5-34 13.5-53.3s-4.9-37.4-13.5-53.3l58-58C434.9 176.1 448 214.5 448 256s-13.1 79.9-35.5 111.2zM367.2 99.5l-58 58c-15.8-8.6-34-13.5-53.3-13.5s-37.4 4.9-53.3 13.5l-58-58C176.1 77.1 214.5 64 256 64s79.9 13.1 111.2 35.5zM157.5 309.3l-58 58C77.1 335.9 64 297.5 64 256s13.1-79.9 35.5-111.2l58 58c-8.6 15.8-13.5 34-13.5 53.3s4.9 37.4 13.5 53.3zM208 256a48 48 0 1 1 96 0 48 48 0 1 1 -96 0z\"]\n};\nconst faHands = {\n prefix: 'fas',\n iconName: 'hands',\n icon: [576, 512, [\"sign-language\", \"signing\"], \"f2a7\", \"M544 160l-.1 72.6c-.1 52.2-24 101-64 133.1c.1-1.9 .1-3.8 .1-5.7l0-8c0-71.8-37-138.6-97.9-176.7l-60.2-37.6c-8.6-5.4-17.9-8.4-27.3-9.4L248.7 48.8c-6.6-11.5-2.7-26.2 8.8-32.8s26.2-2.7 32.8 8.8l78 135.1c3.3 5.7 10.7 7.7 16.4 4.4s7.7-10.7 4.4-16.4l-62-107.4c-6.6-11.5-2.7-26.2 8.8-32.8S362 5 368.6 16.5l68 117.8s0 0 0 0s0 0 0 0l43.3 75L480 160c0-17.7 14.4-32 32-32s32 14.4 32 32zM243.9 88.5L268.5 131c-13.9 4.5-26.4 13.7-34.7 27c-.9 1.4-1.7 2.9-2.5 4.4l-28.9-50c-6.6-11.5-2.7-26.2 8.8-32.8s26.2-2.7 32.8 8.8zm-46.4 63.7l26.8 46.4c.6 6 2.1 11.8 4.3 17.4l-4.7 0-13.3 0s0 0 0 0L179 216l-23-39.8c-6.6-11.5-2.7-26.2 8.8-32.8s26.2-2.7 32.8 8.8zM260.9 175c9.4-15 29.1-19.5 44.1-10.2l60.2 37.6C416.7 234.7 448 291.2 448 352l0 8c0 83.9-68.1 152-152 152l-176 0c-13.3 0-24-10.7-24-24s10.7-24 24-24l92 0c6.6 0 12-5.4 12-12s-5.4-12-12-12L88 440c-13.3 0-24-10.7-24-24s10.7-24 24-24l124 0c6.6 0 12-5.4 12-12s-5.4-12-12-12L56 368c-13.3 0-24-10.7-24-24s10.7-24 24-24l156 0c6.6 0 12-5.4 12-12s-5.4-12-12-12L88 296c-13.3 0-24-10.7-24-24s10.7-24 24-24l136 0s0 0 0 0s0 0 0 0l93.2 0L271 219.1c-15-9.4-19.5-29.1-10.2-44.1z\"]\n};\nconst faSignLanguage = faHands;\nconst faSigning = faHands;\nconst faCalendarDay = {\n prefix: 'fas',\n iconName: 'calendar-day',\n icon: [448, 512, [], \"f783\", \"M128 0c17.7 0 32 14.3 32 32l0 32 128 0 0-32c0-17.7 14.3-32 32-32s32 14.3 32 32l0 32 48 0c26.5 0 48 21.5 48 48l0 48L0 160l0-48C0 85.5 21.5 64 48 64l48 0 0-32c0-17.7 14.3-32 32-32zM0 192l448 0 0 272c0 26.5-21.5 48-48 48L48 512c-26.5 0-48-21.5-48-48L0 192zm80 64c-8.8 0-16 7.2-16 16l0 96c0 8.8 7.2 16 16 16l96 0c8.8 0 16-7.2 16-16l0-96c0-8.8-7.2-16-16-16l-96 0z\"]\n};\nconst faWaterLadder = {\n prefix: 'fas',\n iconName: 'water-ladder',\n icon: [576, 512, [\"ladder-water\", \"swimming-pool\"], \"f5c5\", \"M128 127.7C128 74.9 170.9 32 223.7 32c48.3 0 89 36 95 83.9l1 8.2c2.2 17.5-10.2 33.5-27.8 35.7s-33.5-10.2-35.7-27.8l-1-8.2c-2-15.9-15.5-27.8-31.5-27.8c-17.5 0-31.7 14.2-31.7 31.7l0 96.3 192 0 0-96.3C384 74.9 426.9 32 479.7 32c48.3 0 89 36 95 83.9l1 8.2c2.2 17.5-10.2 33.5-27.8 35.7s-33.5-10.2-35.7-27.8l-1-8.2c-2-15.9-15.5-27.8-31.5-27.8c-17.5 0-31.7 14.2-31.7 31.7L448 361c-1.6 1-3.3 2-4.8 3.1c-18 12.4-40.1 20.3-59.2 20.3c0 0 0 0 0 0l0-96.5-192 0 0 96.5c-19 0-41.2-7.9-59.1-20.3c-1.6-1.1-3.2-2.2-4.9-3.1l0-233.3zM306.5 389.9C329 405.4 356.5 416 384 416c26.9 0 55.4-10.8 77.4-26.1c0 0 0 0 0 0c11.9-8.5 28.1-7.8 39.2 1.7c14.4 11.9 32.5 21 50.6 25.2c17.2 4 27.9 21.2 23.9 38.4s-21.2 27.9-38.4 23.9c-24.5-5.7-44.9-16.5-58.2-25C449.5 469.7 417 480 384 480c-31.9 0-60.6-9.9-80.4-18.9c-5.8-2.7-11.1-5.3-15.6-7.7c-4.5 2.4-9.7 5.1-15.6 7.7c-19.8 9-48.5 18.9-80.4 18.9c-33 0-65.5-10.3-94.5-25.8c-13.4 8.4-33.7 19.3-58.2 25c-17.2 4-34.4-6.7-38.4-23.9s6.7-34.4 23.9-38.4c18.1-4.2 36.2-13.3 50.6-25.2c11.1-9.4 27.3-10.1 39.2-1.7c0 0 0 0 0 0C136.7 405.2 165.1 416 192 416c27.5 0 55-10.6 77.5-26.1c11.1-7.9 25.9-7.9 37 0z\"]\n};\nconst faLadderWater = faWaterLadder;\nconst faSwimmingPool = faWaterLadder;\nconst faArrowsUpDown = {\n prefix: 'fas',\n iconName: 'arrows-up-down',\n icon: [320, 512, [\"arrows-v\"], \"f07d\", \"M182.6 9.4c-12.5-12.5-32.8-12.5-45.3 0l-96 96c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0L128 109.3l0 293.5L86.6 361.4c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3l96 96c12.5 12.5 32.8 12.5 45.3 0l96-96c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0L192 402.7l0-293.5 41.4 41.4c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3l-96-96z\"]\n};\nconst faArrowsV = faArrowsUpDown;\nconst faFaceGrimace = {\n prefix: 'fas',\n iconName: 'face-grimace',\n icon: [512, 512, [128556, \"grimace\"], \"f57f\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zm96-112l-8 0 0-40 55.3 0c-3.8 22.7-23.6 40-47.3 40zm47.3-56L344 344l0-40 8 0c23.8 0 43.5 17.3 47.3 40zM328 344l-64 0 0-40 64 0 0 40zm0 56l-64 0 0-40 64 0 0 40zm-80-96l0 40-64 0 0-40 64 0zm0 56l0 40-64 0 0-40 64 0zm-80-16l-55.3 0c3.8-22.7 23.6-40 47.3-40l8 0 0 40zm0 56l-8 0c-23.8 0-43.5-17.3-47.3-40l55.3 0 0 40zM144.4 208a32 32 0 1 1 64 0 32 32 0 1 1 -64 0zm192-32a32 32 0 1 1 0 64 32 32 0 1 1 0-64z\"]\n};\nconst faGrimace = faFaceGrimace;\nconst faWheelchairMove = {\n prefix: 'fas',\n iconName: 'wheelchair-move',\n icon: [448, 512, [\"wheelchair-alt\"], \"e2ce\", \"M320 48a48 48 0 1 1 96 0 48 48 0 1 1 -96 0zM204.5 121.3c-5.4-2.5-11.7-1.9-16.4 1.7l-40.9 30.7c-14.1 10.6-34.2 7.7-44.8-6.4s-7.7-34.2 6.4-44.8l40.9-30.7c23.7-17.8 55.3-21 82.1-8.4l90.4 42.5c29.1 13.7 36.8 51.6 15.2 75.5L299.1 224l97.4 0c30.3 0 53 27.7 47.1 57.4L415.4 422.3c-3.5 17.3-20.3 28.6-37.7 25.1s-28.6-20.3-25.1-37.7L377 288l-70.3 0c8.6 19.6 13.3 41.2 13.3 64c0 88.4-71.6 160-160 160S0 440.4 0 352s71.6-160 160-160c11.1 0 22 1.1 32.4 3.3l54.2-54.2-42.1-19.8zM160 448a96 96 0 1 0 0-192 96 96 0 1 0 0 192z\"]\n};\nconst faWheelchairAlt = faWheelchairMove;\nconst faTurnDown = {\n prefix: 'fas',\n iconName: 'turn-down',\n icon: [384, 512, [10549, \"level-down-alt\"], \"f3be\", \"M350 334.5c3.8 8.8 2 19-4.6 26l-136 144c-4.5 4.8-10.8 7.5-17.4 7.5s-12.9-2.7-17.4-7.5l-136-144c-6.6-7-8.4-17.2-4.6-26s12.5-14.5 22-14.5l88 0 0-192c0-17.7-14.3-32-32-32L32 96C14.3 96 0 81.7 0 64L0 32C0 14.3 14.3 0 32 0l80 0c70.7 0 128 57.3 128 128l0 192 88 0c9.6 0 18.2 5.7 22 14.5z\"]\n};\nconst faLevelDownAlt = faTurnDown;\nconst faPersonWalkingArrowRight = {\n prefix: 'fas',\n iconName: 'person-walking-arrow-right',\n icon: [640, 512, [], \"e552\", \"M208 96a48 48 0 1 0 0-96 48 48 0 1 0 0 96zM123.7 200.5c1-.4 1.9-.8 2.9-1.2l-16.9 63.5c-5.6 21.1-.1 43.6 14.7 59.7l70.7 77.1 22 88.1c4.3 17.1 21.7 27.6 38.8 23.3s27.6-21.7 23.3-38.8l-23-92.1c-1.9-7.8-5.8-14.9-11.2-20.8l-49.5-54 19.3-65.5 9.6 23c4.4 10.6 12.5 19.3 22.8 24.5l26.7 13.3c15.8 7.9 35 1.5 42.9-14.3s1.5-35-14.3-42.9L281 232.7l-15.3-36.8C248.5 154.8 208.3 128 163.7 128c-22.8 0-45.3 4.8-66.1 14l-8 3.5c-32.9 14.6-58.1 42.4-69.4 76.5l-2.6 7.8c-5.6 16.8 3.5 34.9 20.2 40.5s34.9-3.5 40.5-20.2l2.6-7.8c5.7-17.1 18.3-30.9 34.7-38.2l8-3.5zm-30 135.1L68.7 398 9.4 457.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0L116.3 441c4.6-4.6 8.2-10.1 10.6-16.1l14.5-36.2-40.7-44.4c-2.5-2.7-4.8-5.6-7-8.6zM550.6 153.4c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3L530.7 224 384 224c-17.7 0-32 14.3-32 32s14.3 32 32 32l146.7 0-25.4 25.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0l80-80c12.5-12.5 12.5-32.8 0-45.3l-80-80z\"]\n};\nconst faSquareEnvelope = {\n prefix: 'fas',\n iconName: 'square-envelope',\n icon: [448, 512, [\"envelope-square\"], \"f199\", \"M64 32C28.7 32 0 60.7 0 96L0 416c0 35.3 28.7 64 64 64l320 0c35.3 0 64-28.7 64-64l0-320c0-35.3-28.7-64-64-64L64 32zM218 271.7L64.2 172.4C66 156.4 79.5 144 96 144l256 0c16.5 0 30 12.4 31.8 28.4L230 271.7c-1.8 1.2-3.9 1.8-6 1.8s-4.2-.6-6-1.8zm29.4 26.9L384 210.4 384 336c0 17.7-14.3 32-32 32L96 368c-17.7 0-32-14.3-32-32l0-125.6 136.6 88.2c7 4.5 15.1 6.9 23.4 6.9s16.4-2.4 23.4-6.9z\"]\n};\nconst faEnvelopeSquare = faSquareEnvelope;\nconst faDice = {\n prefix: 'fas',\n iconName: 'dice',\n icon: [640, 512, [127922], \"f522\", \"M274.9 34.3c-28.1-28.1-73.7-28.1-101.8 0L34.3 173.1c-28.1 28.1-28.1 73.7 0 101.8L173.1 413.7c28.1 28.1 73.7 28.1 101.8 0L413.7 274.9c28.1-28.1 28.1-73.7 0-101.8L274.9 34.3zM200 224a24 24 0 1 1 48 0 24 24 0 1 1 -48 0zM96 200a24 24 0 1 1 0 48 24 24 0 1 1 0-48zM224 376a24 24 0 1 1 0-48 24 24 0 1 1 0 48zM352 200a24 24 0 1 1 0 48 24 24 0 1 1 0-48zM224 120a24 24 0 1 1 0-48 24 24 0 1 1 0 48zm96 328c0 35.3 28.7 64 64 64l192 0c35.3 0 64-28.7 64-64l0-192c0-35.3-28.7-64-64-64l-114.3 0c11.6 36 3.1 77-25.4 105.5L320 413.8l0 34.2zM480 328a24 24 0 1 1 0 48 24 24 0 1 1 0-48z\"]\n};\nconst faBowlingBall = {\n prefix: 'fas',\n iconName: 'bowling-ball',\n icon: [512, 512, [], \"f436\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM240 80a32 32 0 1 1 0 64 32 32 0 1 1 0-64zM208 208a32 32 0 1 1 64 0 32 32 0 1 1 -64 0zm-64-64a32 32 0 1 1 0 64 32 32 0 1 1 0-64z\"]\n};\nconst faBrain = {\n prefix: 'fas',\n iconName: 'brain',\n icon: [512, 512, [129504], \"f5dc\", \"M184 0c30.9 0 56 25.1 56 56l0 400c0 30.9-25.1 56-56 56c-28.9 0-52.7-21.9-55.7-50.1c-5.2 1.4-10.7 2.1-16.3 2.1c-35.3 0-64-28.7-64-64c0-7.4 1.3-14.6 3.6-21.2C21.4 367.4 0 338.2 0 304c0-31.9 18.7-59.5 45.8-72.3C37.1 220.8 32 207 32 192c0-30.7 21.6-56.3 50.4-62.6C80.8 123.9 80 118 80 112c0-29.9 20.6-55.1 48.3-62.1C131.3 21.9 155.1 0 184 0zM328 0c28.9 0 52.6 21.9 55.7 49.9c27.8 7 48.3 32.1 48.3 62.1c0 6-.8 11.9-2.4 17.4c28.8 6.2 50.4 31.9 50.4 62.6c0 15-5.1 28.8-13.8 39.7C493.3 244.5 512 272.1 512 304c0 34.2-21.4 63.4-51.6 74.8c2.3 6.6 3.6 13.8 3.6 21.2c0 35.3-28.7 64-64 64c-5.6 0-11.1-.7-16.3-2.1c-3 28.2-26.8 50.1-55.7 50.1c-30.9 0-56-25.1-56-56l0-400c0-30.9 25.1-56 56-56z\"]\n};\nconst faBandage = {\n prefix: 'fas',\n iconName: 'bandage',\n icon: [640, 512, [129657, \"band-aid\"], \"f462\", \"M480 416l96 0c35.3 0 64-28.7 64-64l0-192c0-35.3-28.7-64-64-64l-96 0 0 320zM448 96L192 96l0 320 256 0 0-320zM64 96C28.7 96 0 124.7 0 160L0 352c0 35.3 28.7 64 64 64l96 0 0-320L64 96zM248 208a24 24 0 1 1 48 0 24 24 0 1 1 -48 0zm120-24a24 24 0 1 1 0 48 24 24 0 1 1 0-48zM248 304a24 24 0 1 1 48 0 24 24 0 1 1 -48 0zm120-24a24 24 0 1 1 0 48 24 24 0 1 1 0-48z\"]\n};\nconst faBandAid = faBandage;\nconst faCalendarMinus = {\n prefix: 'fas',\n iconName: 'calendar-minus',\n icon: [448, 512, [], \"f272\", \"M128 0c17.7 0 32 14.3 32 32l0 32 128 0 0-32c0-17.7 14.3-32 32-32s32 14.3 32 32l0 32 48 0c26.5 0 48 21.5 48 48l0 48L0 160l0-48C0 85.5 21.5 64 48 64l48 0 0-32c0-17.7 14.3-32 32-32zM0 192l448 0 0 272c0 26.5-21.5 48-48 48L48 512c-26.5 0-48-21.5-48-48L0 192zM312 376c13.3 0 24-10.7 24-24s-10.7-24-24-24l-176 0c-13.3 0-24 10.7-24 24s10.7 24 24 24l176 0z\"]\n};\nconst faCircleXmark = {\n prefix: 'fas',\n iconName: 'circle-xmark',\n icon: [512, 512, [61532, \"times-circle\", \"xmark-circle\"], \"f057\", \"M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM175 175c9.4-9.4 24.6-9.4 33.9 0l47 47 47-47c9.4-9.4 24.6-9.4 33.9 0s9.4 24.6 0 33.9l-47 47 47 47c9.4 9.4 9.4 24.6 0 33.9s-24.6 9.4-33.9 0l-47-47-47 47c-9.4 9.4-24.6 9.4-33.9 0s-9.4-24.6 0-33.9l47-47-47-47c-9.4-9.4-9.4-24.6 0-33.9z\"]\n};\nconst faTimesCircle = faCircleXmark;\nconst faXmarkCircle = faCircleXmark;\nconst faGifts = {\n prefix: 'fas',\n iconName: 'gifts',\n icon: [640, 512, [], \"f79c\", \"M200.6 32C205 19.5 198.5 5.8 186 1.4S159.8 3.5 155.4 16L144.7 46.2l-9.9-29.8C130.6 3.8 117-3 104.4 1.2S85 19 89.2 31.6l8.3 25-27.4-20c-10.7-7.8-25.7-5.4-33.5 5.3s-5.4 25.7 5.3 33.5L70.2 96 48 96C21.5 96 0 117.5 0 144L0 464c0 26.5 21.5 48 48 48l152.6 0c-5.4-9.4-8.6-20.3-8.6-32l0-224c0-29.9 20.5-55 48.2-62c1.8-31 17.1-58.2 40.1-76.1C271.7 104.7 256.9 96 240 96l-22.2 0 28.3-20.6c10.7-7.8 13.1-22.8 5.3-33.5s-22.8-13.1-33.5-5.3L192.5 55.1 200.6 32zM363.5 185.5L393.1 224 344 224c-13.3 0-24-10.7-24-24c0-13.1 10.8-24 24.2-24c7.6 0 14.7 3.5 19.3 9.5zM272 200c0 8.4 1.4 16.5 4.1 24l-4.1 0c-26.5 0-48 21.5-48 48l0 80 192 0 0-96 32 0 0 96 192 0 0-80c0-26.5-21.5-48-48-48l-4.1 0c2.7-7.5 4.1-15.6 4.1-24c0-39.9-32.5-72-72.2-72c-22.4 0-43.6 10.4-57.3 28.2L432 195.8l-30.5-39.6c-13.7-17.8-35-28.2-57.3-28.2c-39.7 0-72.2 32.1-72.2 72zM224 464c0 26.5 21.5 48 48 48l144 0 0-128-192 0 0 80zm224 48l144 0c26.5 0 48-21.5 48-48l0-80-192 0 0 128zm96-312c0 13.3-10.7 24-24 24l-49.1 0 29.6-38.5c4.6-5.9 11.7-9.5 19.3-9.5c13.4 0 24.2 10.9 24.2 24z\"]\n};\nconst faHotel = {\n prefix: 'fas',\n iconName: 'hotel',\n icon: [512, 512, [127976], \"f594\", \"M0 32C0 14.3 14.3 0 32 0L480 0c17.7 0 32 14.3 32 32s-14.3 32-32 32l0 384c17.7 0 32 14.3 32 32s-14.3 32-32 32l-176 0 0-48c0-26.5-21.5-48-48-48s-48 21.5-48 48l0 48L32 512c-17.7 0-32-14.3-32-32s14.3-32 32-32L32 64C14.3 64 0 49.7 0 32zm96 80l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0c-8.8 0-16 7.2-16 16zM240 96c-8.8 0-16 7.2-16 16l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0zm112 16l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0c-8.8 0-16 7.2-16 16zM112 192c-8.8 0-16 7.2-16 16l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0zm112 16l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0c-8.8 0-16 7.2-16 16zm144-16c-8.8 0-16 7.2-16 16l0 32c0 8.8 7.2 16 16 16l32 0c8.8 0 16-7.2 16-16l0-32c0-8.8-7.2-16-16-16l-32 0zM328 384c13.3 0 24.3-10.9 21-23.8c-10.6-41.5-48.2-72.2-93-72.2s-82.5 30.7-93 72.2c-3.3 12.8 7.8 23.8 21 23.8l144 0z\"]\n};\nconst faEarthAsia = {\n prefix: 'fas',\n iconName: 'earth-asia',\n icon: [512, 512, [127759, \"globe-asia\"], \"f57e\", \"M51.7 295.1l31.7 6.3c7.9 1.6 16-.9 21.7-6.6l15.4-15.4c11.6-11.6 31.1-8.4 38.4 6.2l9.3 18.5c4.8 9.6 14.6 15.7 25.4 15.7c15.2 0 26.1-14.6 21.7-29.2l-6-19.9c-4.6-15.4 6.9-30.9 23-30.9l2.3 0c13.4 0 25.9-6.7 33.3-17.8l10.7-16.1c5.6-8.5 5.3-19.6-.8-27.7l-16.1-21.5c-10.3-13.7-3.3-33.5 13.4-37.7l17-4.3c7.5-1.9 13.6-7.2 16.5-14.4l16.4-40.9C303.4 52.1 280.2 48 256 48C141.1 48 48 141.1 48 256c0 13.4 1.3 26.5 3.7 39.1zm407.7 4.6c-3-.3-6-.1-9 .8l-15.8 4.4c-6.7 1.9-13.8-.9-17.5-6.7l-2-3.1c-6-9.4-16.4-15.1-27.6-15.1s-21.6 5.7-27.6 15.1l-6.1 9.5c-1.4 2.2-3.4 4.1-5.7 5.3L312 330.1c-18.1 10.1-25.5 32.4-17 51.3l5.5 12.4c8.6 19.2 30.7 28.5 50.5 21.1l2.6-1c10-3.7 21.3-2.2 29.9 4.1l1.5 1.1c37.2-29.5 64.1-71.4 74.4-119.5zM0 256a256 256 0 1 1 512 0A256 256 0 1 1 0 256zm144.5 92.1c-2.1 8.6 3.1 17.3 11.6 19.4l32 8c8.6 2.1 17.3-3.1 19.4-11.6s-3.1-17.3-11.6-19.4l-32-8c-8.6-2.1-17.3 3.1-19.4 11.6zm92-20c-2.1 8.6 3.1 17.3 11.6 19.4s17.3-3.1 19.4-11.6l8-32c2.1-8.6-3.1-17.3-11.6-19.4s-17.3 3.1-19.4 11.6l-8 32zM343.2 113.7c-7.9-4-17.5-.7-21.5 7.2l-16 32c-4 7.9-.7 17.5 7.2 21.5s17.5 .7 21.5-7.2l16-32c4-7.9 .7-17.5-7.2-21.5z\"]\n};\nconst faGlobeAsia = faEarthAsia;\nconst faIdCardClip = {\n prefix: 'fas',\n iconName: 'id-card-clip',\n icon: [576, 512, [\"id-card-alt\"], \"f47f\", \"M256 0l64 0c17.7 0 32 14.3 32 32l0 64c0 17.7-14.3 32-32 32l-64 0c-17.7 0-32-14.3-32-32l0-64c0-17.7 14.3-32 32-32zM64 64l128 0 0 48c0 26.5 21.5 48 48 48l96 0c26.5 0 48-21.5 48-48l0-48 128 0c35.3 0 64 28.7 64 64l0 320c0 35.3-28.7 64-64 64L64 512c-35.3 0-64-28.7-64-64L0 128C0 92.7 28.7 64 64 64zM176 437.3c0 5.9 4.8 10.7 10.7 10.7l202.7 0c5.9 0 10.7-4.8 10.7-10.7c0-29.5-23.9-53.3-53.3-53.3l-117.3 0c-29.5 0-53.3 23.9-53.3 53.3zM288 352a64 64 0 1 0 0-128 64 64 0 1 0 0 128z\"]\n};\nconst faIdCardAlt = faIdCardClip;\nconst faMagnifyingGlassPlus = {\n prefix: 'fas',\n iconName: 'magnifying-glass-plus',\n icon: [512, 512, [\"search-plus\"], \"f00e\", \"M416 208c0 45.9-14.9 88.3-40 122.7L502.6 457.4c12.5 12.5 12.5 32.8 0 45.3s-32.8 12.5-45.3 0L330.7 376c-34.4 25.2-76.8 40-122.7 40C93.1 416 0 322.9 0 208S93.1 0 208 0S416 93.1 416 208zM184 296c0 13.3 10.7 24 24 24s24-10.7 24-24l0-64 64 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-64 0 0-64c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 64-64 0c-13.3 0-24 10.7-24 24s10.7 24 24 24l64 0 0 64z\"]\n};\nconst faSearchPlus = faMagnifyingGlassPlus;\nconst faThumbsUp = {\n prefix: 'fas',\n iconName: 'thumbs-up',\n icon: [512, 512, [128077, 61575], \"f164\", \"M313.4 32.9c26 5.2 42.9 30.5 37.7 56.5l-2.3 11.4c-5.3 26.7-15.1 52.1-28.8 75.2l144 0c26.5 0 48 21.5 48 48c0 18.5-10.5 34.6-25.9 42.6C497 275.4 504 288.9 504 304c0 23.4-16.8 42.9-38.9 47.1c4.4 7.3 6.9 15.8 6.9 24.9c0 21.3-13.9 39.4-33.1 45.6c.7 3.3 1.1 6.8 1.1 10.4c0 26.5-21.5 48-48 48l-97.5 0c-19 0-37.5-5.6-53.3-16.1l-38.5-25.7C176 420.4 160 390.4 160 358.3l0-38.3 0-48 0-24.9c0-29.2 13.3-56.7 36-75l7.4-5.9c26.5-21.2 44.6-51 51.2-84.2l2.3-11.4c5.2-26 30.5-42.9 56.5-37.7zM32 192l64 0c17.7 0 32 14.3 32 32l0 224c0 17.7-14.3 32-32 32l-64 0c-17.7 0-32-14.3-32-32L0 224c0-17.7 14.3-32 32-32z\"]\n};\nconst faUserClock = {\n prefix: 'fas',\n iconName: 'user-clock',\n icon: [640, 512, [], \"f4fd\", \"M224 0a128 128 0 1 1 0 256A128 128 0 1 1 224 0zM178.3 304l91.4 0c20.6 0 40.4 3.5 58.8 9.9C323 331 320 349.1 320 368c0 59.5 29.5 112.1 74.8 144L29.7 512C13.3 512 0 498.7 0 482.3C0 383.8 79.8 304 178.3 304zM352 368a144 144 0 1 1 288 0 144 144 0 1 1 -288 0zm144-80c-8.8 0-16 7.2-16 16l0 64c0 8.8 7.2 16 16 16l48 0c8.8 0 16-7.2 16-16s-7.2-16-16-16l-32 0 0-48c0-8.8-7.2-16-16-16z\"]\n};\nconst faHandDots = {\n prefix: 'fas',\n iconName: 'hand-dots',\n icon: [512, 512, [\"allergies\"], \"f461\", \"M288 32c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 208c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-176c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 272c0 1.5 0 3.1 .1 4.6L67.6 283c-16-15.2-41.3-14.6-56.6 1.4s-14.6 41.3 1.4 56.6L124.8 448c43.1 41.1 100.4 64 160 64l19.2 0c97.2 0 176-78.8 176-176l0-208c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 112c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-176c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 176c0 8.8-7.2 16-16 16s-16-7.2-16-16l0-208zM240 336a16 16 0 1 1 32 0 16 16 0 1 1 -32 0zm80 16a16 16 0 1 1 0 32 16 16 0 1 1 0-32zm48-16a16 16 0 1 1 32 0 16 16 0 1 1 -32 0zm-16 80a16 16 0 1 1 0 32 16 16 0 1 1 0-32zM240 432a16 16 0 1 1 32 0 16 16 0 1 1 -32 0zm-48-48a16 16 0 1 1 0 32 16 16 0 1 1 0-32z\"]\n};\nconst faAllergies = faHandDots;\nconst faFileInvoice = {\n prefix: 'fas',\n iconName: 'file-invoice',\n icon: [384, 512, [], \"f570\", \"M64 0C28.7 0 0 28.7 0 64L0 448c0 35.3 28.7 64 64 64l256 0c35.3 0 64-28.7 64-64l0-288-128 0c-17.7 0-32-14.3-32-32L224 0 64 0zM256 0l0 128 128 0L256 0zM80 64l64 0c8.8 0 16 7.2 16 16s-7.2 16-16 16L80 96c-8.8 0-16-7.2-16-16s7.2-16 16-16zm0 64l64 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-64 0c-8.8 0-16-7.2-16-16s7.2-16 16-16zm16 96l192 0c17.7 0 32 14.3 32 32l0 64c0 17.7-14.3 32-32 32L96 352c-17.7 0-32-14.3-32-32l0-64c0-17.7 14.3-32 32-32zm0 32l0 64 192 0 0-64L96 256zM240 416l64 0c8.8 0 16 7.2 16 16s-7.2 16-16 16l-64 0c-8.8 0-16-7.2-16-16s7.2-16 16-16z\"]\n};\nconst faWindowMinimize = {\n prefix: 'fas',\n iconName: 'window-minimize',\n icon: [512, 512, [128469], \"f2d1\", \"M32 416c-17.7 0-32 14.3-32 32s14.3 32 32 32l448 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L32 416z\"]\n};\nconst faMugSaucer = {\n prefix: 'fas',\n iconName: 'mug-saucer',\n icon: [640, 512, [\"coffee\"], \"f0f4\", \"M96 64c0-17.7 14.3-32 32-32l320 0 64 0c70.7 0 128 57.3 128 128s-57.3 128-128 128l-32 0c0 53-43 96-96 96l-192 0c-53 0-96-43-96-96L96 64zM480 224l32 0c35.3 0 64-28.7 64-64s-28.7-64-64-64l-32 0 0 128zM32 416l512 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L32 480c-17.7 0-32-14.3-32-32s14.3-32 32-32z\"]\n};\nconst faCoffee = faMugSaucer;\nconst faBrush = {\n prefix: 'fas',\n iconName: 'brush',\n icon: [384, 512, [], \"f55d\", \"M162.4 6c-1.5-3.6-5-6-8.9-6l-19 0c-3.9 0-7.5 2.4-8.9 6L104.9 57.7c-3.2 8-14.6 8-17.8 0L66.4 6c-1.5-3.6-5-6-8.9-6L48 0C21.5 0 0 21.5 0 48L0 224l0 22.4L0 256l9.6 0 364.8 0 9.6 0 0-9.6 0-22.4 0-176c0-26.5-21.5-48-48-48L230.5 0c-3.9 0-7.5 2.4-8.9 6L200.9 57.7c-3.2 8-14.6 8-17.8 0L162.4 6zM0 288l0 32c0 35.3 28.7 64 64 64l64 0 0 64c0 35.3 28.7 64 64 64s64-28.7 64-64l0-64 64 0c35.3 0 64-28.7 64-64l0-32L0 288zM192 432a16 16 0 1 1 0 32 16 16 0 1 1 0-32z\"]\n};\nconst faFileHalfDashed = {\n prefix: 'fas',\n iconName: 'file-half-dashed',\n icon: [384, 512, [], \"e698\", \"M64 0C28.7 0 0 28.7 0 64L0 320l384 0 0-160-128 0c-17.7 0-32-14.3-32-32L224 0 64 0zM256 0l0 128 128 0L256 0zM0 416l64 0 0-64L0 352l0 64zm288 32l-80 0 0 64 80 0 0-64zm-112 0l-80 0 0 64 80 0 0-64zM64 448L0 448c0 35.3 28.7 64 64 64l0-64zm256 0l0 64c35.3 0 64-28.7 64-64l-64 0zm64-32l0-64-64 0 0 64 64 0z\"]\n};\nconst faMask = {\n prefix: 'fas',\n iconName: 'mask',\n icon: [576, 512, [], \"f6fa\", \"M288 64C64 64 0 160 0 272S80 448 176 448l8.4 0c24.2 0 46.4-13.7 57.2-35.4l23.2-46.3c4.4-8.8 13.3-14.3 23.2-14.3s18.8 5.5 23.2 14.3l23.2 46.3c10.8 21.7 33 35.4 57.2 35.4l8.4 0c96 0 176-64 176-176s-64-208-288-208zM96 256a64 64 0 1 1 128 0A64 64 0 1 1 96 256zm320-64a64 64 0 1 1 0 128 64 64 0 1 1 0-128z\"]\n};\nconst faMagnifyingGlassMinus = {\n prefix: 'fas',\n iconName: 'magnifying-glass-minus',\n icon: [512, 512, [\"search-minus\"], \"f010\", \"M416 208c0 45.9-14.9 88.3-40 122.7L502.6 457.4c12.5 12.5 12.5 32.8 0 45.3s-32.8 12.5-45.3 0L330.7 376c-34.4 25.2-76.8 40-122.7 40C93.1 416 0 322.9 0 208S93.1 0 208 0S416 93.1 416 208zM136 184c-13.3 0-24 10.7-24 24s10.7 24 24 24l144 0c13.3 0 24-10.7 24-24s-10.7-24-24-24l-144 0z\"]\n};\nconst faSearchMinus = faMagnifyingGlassMinus;\nconst faRulerVertical = {\n prefix: 'fas',\n iconName: 'ruler-vertical',\n icon: [256, 512, [], \"f548\", \"M0 48C0 21.5 21.5 0 48 0L208 0c26.5 0 48 21.5 48 48l0 48-80 0c-8.8 0-16 7.2-16 16s7.2 16 16 16l80 0 0 64-80 0c-8.8 0-16 7.2-16 16s7.2 16 16 16l80 0 0 64-80 0c-8.8 0-16 7.2-16 16s7.2 16 16 16l80 0 0 64-80 0c-8.8 0-16 7.2-16 16s7.2 16 16 16l80 0 0 48c0 26.5-21.5 48-48 48L48 512c-26.5 0-48-21.5-48-48L0 48z\"]\n};\nconst faUserLarge = {\n prefix: 'fas',\n iconName: 'user-large',\n icon: [512, 512, [\"user-alt\"], \"f406\", \"M256 288A144 144 0 1 0 256 0a144 144 0 1 0 0 288zm-94.7 32C72.2 320 0 392.2 0 481.3c0 17 13.8 30.7 30.7 30.7l450.6 0c17 0 30.7-13.8 30.7-30.7C512 392.2 439.8 320 350.7 320l-189.4 0z\"]\n};\nconst faUserAlt = faUserLarge;\nconst faTrainTram = {\n prefix: 'fas',\n iconName: 'train-tram',\n icon: [448, 512, [128650], \"e5b4\", \"M86.8 48c-12.2 0-23.6 5.5-31.2 15L42.7 79C34.5 89.3 19.4 91 9 82.7S-3 59.4 5.3 49L18 33C34.7 12.2 60 0 86.8 0L361.2 0c26.7 0 52 12.2 68.7 33l12.8 16c8.3 10.4 6.6 25.5-3.8 33.7s-25.5 6.6-33.7-3.7L392.5 63c-7.6-9.5-19.1-15-31.2-15L248 48l0 48 40 0c53 0 96 43 96 96l0 160c0 30.6-14.3 57.8-36.6 75.4l65.5 65.5c7.1 7.1 2.1 19.1-7.9 19.1l-39.7 0c-8.5 0-16.6-3.4-22.6-9.4L288 448l-128 0-54.6 54.6c-6 6-14.1 9.4-22.6 9.4L43 512c-10 0-15-12.1-7.9-19.1l65.5-65.5C78.3 409.8 64 382.6 64 352l0-160c0-53 43-96 96-96l40 0 0-48L86.8 48zM160 160c-17.7 0-32 14.3-32 32l0 32c0 17.7 14.3 32 32 32l128 0c17.7 0 32-14.3 32-32l0-32c0-17.7-14.3-32-32-32l-128 0zm32 192a32 32 0 1 0 -64 0 32 32 0 1 0 64 0zm96 32a32 32 0 1 0 0-64 32 32 0 1 0 0 64z\"]\n};\nconst faUserNurse = {\n prefix: 'fas',\n iconName: 'user-nurse',\n icon: [448, 512, [], \"f82f\", \"M96 128l0-57.8c0-13.3 8.3-25.3 20.8-30l96-36c7.2-2.7 15.2-2.7 22.5 0l96 36c12.5 4.7 20.8 16.6 20.8 30l0 57.8-.3 0c.2 2.6 .3 5.3 .3 8l0 40c0 70.7-57.3 128-128 128s-128-57.3-128-128l0-40c0-2.7 .1-5.4 .3-8l-.3 0zm48 48c0 44.2 35.8 80 80 80s80-35.8 80-80l0-16-160 0 0 16zM111.9 327.7c10.5-3.4 21.8 .4 29.4 8.5l71 75.5c6.3 6.7 17 6.7 23.3 0l71-75.5c7.6-8.1 18.9-11.9 29.4-8.5C401 348.6 448 409.4 448 481.3c0 17-13.8 30.7-30.7 30.7L30.7 512C13.8 512 0 498.2 0 481.3c0-71.9 47-132.7 111.9-153.6zM208 48l0 16-16 0c-4.4 0-8 3.6-8 8l0 16c0 4.4 3.6 8 8 8l16 0 0 16c0 4.4 3.6 8 8 8l16 0c4.4 0 8-3.6 8-8l0-16 16 0c4.4 0 8-3.6 8-8l0-16c0-4.4-3.6-8-8-8l-16 0 0-16c0-4.4-3.6-8-8-8l-16 0c-4.4 0-8 3.6-8 8z\"]\n};\nconst faSyringe = {\n prefix: 'fas',\n iconName: 'syringe',\n icon: [512, 512, [128137], \"f48e\", \"M441 7l32 32 32 32c9.4 9.4 9.4 24.6 0 33.9s-24.6 9.4-33.9 0l-15-15L417.9 128l55 55c9.4 9.4 9.4 24.6 0 33.9s-24.6 9.4-33.9 0l-72-72L295 73c-9.4-9.4-9.4-24.6 0-33.9s24.6-9.4 33.9 0l55 55L422.1 56 407 41c-9.4-9.4-9.4-24.6 0-33.9s24.6-9.4 33.9 0zM210.3 155.7l61.1-61.1c.3 .3 .6 .7 1 1l16 16 56 56 56 56 16 16c.3 .3 .6 .6 1 1l-191 191c-10.5 10.5-24.7 16.4-39.6 16.4l-88.8 0L41 505c-9.4 9.4-24.6 9.4-33.9 0s-9.4-24.6 0-33.9l57-57 0-88.8c0-14.9 5.9-29.1 16.4-39.6l43.3-43.3 57 57c6.2 6.2 16.4 6.2 22.6 0s6.2-16.4 0-22.6l-57-57 41.4-41.4 57 57c6.2 6.2 16.4 6.2 22.6 0s6.2-16.4 0-22.6l-57-57z\"]\n};\nconst faCloudSun = {\n prefix: 'fas',\n iconName: 'cloud-sun',\n icon: [640, 512, [9925], \"f6c4\", \"M294.2 1.2c5.1 2.1 8.7 6.7 9.6 12.1l14.1 84.7 84.7 14.1c5.4 .9 10 4.5 12.1 9.6s1.5 10.9-1.6 15.4l-38.5 55c-2.2-.1-4.4-.2-6.7-.2c-23.3 0-45.1 6.2-64 17.1l0-1.1c0-53-43-96-96-96s-96 43-96 96s43 96 96 96c8.1 0 15.9-1 23.4-2.9c-36.6 18.1-63.3 53.1-69.8 94.9l-24.4 17c-4.5 3.2-10.3 3.8-15.4 1.6s-8.7-6.7-9.6-12.1L98.1 317.9 13.4 303.8c-5.4-.9-10-4.5-12.1-9.6s-1.5-10.9 1.6-15.4L52.5 208 2.9 137.2c-3.2-4.5-3.8-10.3-1.6-15.4s6.7-8.7 12.1-9.6L98.1 98.1l14.1-84.7c.9-5.4 4.5-10 9.6-12.1s10.9-1.5 15.4 1.6L208 52.5 278.8 2.9c4.5-3.2 10.3-3.8 15.4-1.6zM144 208a64 64 0 1 1 128 0 64 64 0 1 1 -128 0zM639.9 431.9c0 44.2-35.8 80-80 80l-271.9 0c-53 0-96-43-96-96c0-47.6 34.6-87 80-94.6l0-1.3c0-53 43-96 96-96c34.9 0 65.4 18.6 82.2 46.4c13-9.1 28.8-14.4 45.8-14.4c44.2 0 80 35.8 80 80c0 5.9-.6 11.7-1.9 17.2c37.4 6.7 65.8 39.4 65.8 78.7z\"]\n};\nconst faStopwatch20 = {\n prefix: 'fas',\n iconName: 'stopwatch-20',\n icon: [448, 512, [], \"e06f\", \"M176 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l16 0 0 34.4C92.3 113.8 16 200 16 304c0 114.9 93.1 208 208 208s208-93.1 208-208c0-41.8-12.3-80.7-33.5-113.2l24.1-24.1c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0L355.7 143c-28.1-23-62.2-38.8-99.7-44.6L256 64l16 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L176 0zM288 204c28.7 0 52 23.3 52 52l0 96c0 28.7-23.3 52-52 52s-52-23.3-52-52l0-96c0-28.7 23.3-52 52-52zm-12 52l0 96c0 6.6 5.4 12 12 12s12-5.4 12-12l0-96c0-6.6-5.4-12-12-12s-12 5.4-12 12zM159.5 244c-5.4 0-10.2 3.5-11.9 8.6l-.6 1.7c-3.5 10.5-14.8 16.1-25.3 12.6s-16.1-14.8-12.6-25.3l.6-1.7c7.2-21.5 27.2-35.9 49.8-35.9c29 0 52.5 23.5 52.5 52.5l0 2.2c0 13.4-4.9 26.4-13.8 36.4l-39 43.9c-6.2 7-10 15.7-10.9 24.9l43.8 0c11 0 20 9 20 20s-9 20-20 20l-64 0c-11 0-20-9-20-20l0-15.7c0-20.6 7.5-40.4 21.2-55.8l39-43.9c2.4-2.7 3.7-6.2 3.7-9.8l0-2.2c0-6.9-5.6-12.5-12.5-12.5z\"]\n};\nconst faSquareFull = {\n prefix: 'fas',\n iconName: 'square-full',\n icon: [512, 512, [128997, 128998, 128999, 129000, 129001, 129002, 129003, 11035, 11036], \"f45c\", \"M0 0H512V512H0V0z\"]\n};\nconst faMagnet = {\n prefix: 'fas',\n iconName: 'magnet',\n icon: [448, 512, [129522], \"f076\", \"M0 160l0 96C0 379.7 100.3 480 224 480s224-100.3 224-224l0-96-128 0 0 96c0 53-43 96-96 96s-96-43-96-96l0-96L0 160zm0-32l128 0 0-64c0-17.7-14.3-32-32-32L32 32C14.3 32 0 46.3 0 64l0 64zm320 0l128 0 0-64c0-17.7-14.3-32-32-32l-64 0c-17.7 0-32 14.3-32 32l0 64z\"]\n};\nconst faJar = {\n prefix: 'fas',\n iconName: 'jar',\n icon: [320, 512, [], \"e516\", \"M32 32C32 14.3 46.3 0 64 0L256 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L64 64C46.3 64 32 49.7 32 32zM0 160c0-35.3 28.7-64 64-64l192 0c35.3 0 64 28.7 64 64l0 288c0 35.3-28.7 64-64 64L64 512c-35.3 0-64-28.7-64-64L0 160zm96 64c-17.7 0-32 14.3-32 32l0 96c0 17.7 14.3 32 32 32l128 0c17.7 0 32-14.3 32-32l0-96c0-17.7-14.3-32-32-32L96 224z\"]\n};\nconst faNoteSticky = {\n prefix: 'fas',\n iconName: 'note-sticky',\n icon: [448, 512, [62026, \"sticky-note\"], \"f249\", \"M64 32C28.7 32 0 60.7 0 96L0 416c0 35.3 28.7 64 64 64l224 0 0-112c0-26.5 21.5-48 48-48l112 0 0-224c0-35.3-28.7-64-64-64L64 32zM448 352l-45.3 0L336 352c-8.8 0-16 7.2-16 16l0 66.7 0 45.3 32-32 64-64 32-32z\"]\n};\nconst faStickyNote = faNoteSticky;\nconst faBugSlash = {\n prefix: 'fas',\n iconName: 'bug-slash',\n icon: [640, 512, [], \"e490\", \"M38.8 5.1C28.4-3.1 13.3-1.2 5.1 9.2S-1.2 34.7 9.2 42.9l592 464c10.4 8.2 25.5 6.3 33.7-4.1s6.3-25.5-4.1-33.7L477.4 348.9c1.7-9.4 2.6-19 2.6-28.9l64 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-64.3 0c-1.1-14.1-5-27.5-11.1-39.5c.7-.6 1.4-1.2 2.1-1.9l64-64c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0l-64 64c-.7 .7-1.3 1.4-1.9 2.1C409.2 164.1 393.1 160 376 160l-112 0c-8.3 0-16.3 1-24 2.8L38.8 5.1zM320 0c-53 0-96 43-96 96l0 3.6c0 15.7 12.7 28.4 28.4 28.4l135.1 0c15.7 0 28.4-12.7 28.4-28.4l0-3.6c0-53-43-96-96-96zM160.3 256L96 256c-17.7 0-32 14.3-32 32s14.3 32 32 32l64 0c0 24.6 5.5 47.8 15.4 68.6c-2.2 1.3-4.2 2.9-6 4.8l-64 64c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0l63.1-63.1c24.5 21.8 55.8 36.2 90.3 39.6l0-143.7L166.7 227.3c-3.4 9-5.6 18.7-6.4 28.7zM336 479.2c36.6-3.6 69.7-19.6 94.8-43.8L336 360.7l0 118.5z\"]\n};\nconst faArrowUpFromWaterPump = {\n prefix: 'fas',\n iconName: 'arrow-up-from-water-pump',\n icon: [576, 512, [], \"e4b6\", \"M112 0C85.5 0 64 21.5 64 48l0 208-16 0c-26.5 0-48 21.5-48 48l0 96c0 8 2 15.6 5.4 22.2c3.8-1.7 7.8-3.1 12-4.1c13.1-3.1 26.7-9.8 37.3-18.6c22.2-18.7 54.3-20.1 78.1-3.4c18 12.4 40.1 20.3 59.2 20.3c21.1 0 42-8.5 59.2-20.3c22.1-15.5 51.6-15.5 73.7 0c18.4 12.7 39.6 20.3 59.2 20.3c19 0 41.2-7.9 59.2-20.3c23.8-16.7 55.8-15.3 78.1 3.4c10.6 8.8 24.2 15.6 37.3 18.6c4.2 1 8.2 2.4 12 4.1C574 415.6 576 408 576 400l0-96c0-26.5-21.5-48-48-48l-48 0 0-146.7 25.4 25.4c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3l-80-80c-12.5-12.5-32.8-12.5-45.3 0l-80 80c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0L416 109.3 416 256l-128 0 0-208c0-26.5-21.5-48-48-48L112 0zM306.5 421.9c-11.1-7.9-25.9-7.9-37 0C247 437.4 219.5 448 192 448c-26.9 0-55.3-10.8-77.4-26.1c0 0 0 0 0 0c-11.9-8.5-28.1-7.8-39.2 1.7c-14.4 11.9-32.5 21-50.6 25.2c-17.2 4-27.9 21.2-23.9 38.4s21.2 27.9 38.4 23.9c24.5-5.7 44.9-16.5 58.2-25C126.5 501.7 159 512 192 512c31.9 0 60.6-9.9 80.4-18.9c5.8-2.7 11.1-5.3 15.6-7.7c4.5 2.4 9.7 5.1 15.6 7.7c19.8 9 48.5 18.9 80.4 18.9c33 0 65.5-10.3 94.5-25.8c13.4 8.4 33.7 19.3 58.2 25c17.2 4 34.4-6.7 38.4-23.9s-6.7-34.4-23.9-38.4c-18.1-4.2-36.2-13.3-50.6-25.2c-11.1-9.4-27.3-10.1-39.2-1.7c0 0 0 0 0 0C439.4 437.2 410.9 448 384 448c-27.5 0-55-10.6-77.5-26.1z\"]\n};\nconst faBone = {\n prefix: 'fas',\n iconName: 'bone',\n icon: [576, 512, [129460], \"f5d7\", \"M153.7 144.8c6.9 16.3 20.6 31.2 38.3 31.2l192 0c17.7 0 31.4-14.9 38.3-31.2C434.4 116.1 462.9 96 496 96c44.2 0 80 35.8 80 80c0 30.4-17 56.9-42 70.4c-3.6 1.9-6 5.5-6 9.6s2.4 7.7 6 9.6c25 13.5 42 40 42 70.4c0 44.2-35.8 80-80 80c-33.1 0-61.6-20.1-73.7-48.8C415.4 350.9 401.7 336 384 336l-192 0c-17.7 0-31.4 14.9-38.3 31.2C141.6 395.9 113.1 416 80 416c-44.2 0-80-35.8-80-80c0-30.4 17-56.9 42-70.4c3.6-1.9 6-5.5 6-9.6s-2.4-7.7-6-9.6C17 232.9 0 206.4 0 176c0-44.2 35.8-80 80-80c33.1 0 61.6 20.1 73.7 48.8z\"]\n};\nconst faTableCellsRowUnlock = {\n prefix: 'fas',\n iconName: 'table-cells-row-unlock',\n icon: [640, 512, [], \"e691\", \"M0 96C0 60.7 28.7 32 64 32l384 0c35.3 0 64 28.7 64 64l0 65.1c-37.8 5.4-69.4 29.6-85.2 62.9L360 224l0 64 56 0 0 8.6c-19.1 11.1-32 31.7-32 55.4l-24 0 0 64 24 0 0 64L64 480c-35.3 0-64-28.7-64-64L0 96zM64 224l0 64 88 0 0-64-88 0zm232 0l-88 0 0 64 88 0 0-64zM152 352l-88 0 0 64 88 0 0-64zm56 0l0 64 88 0 0-64-88 0zm288-80l0 48 32 0 32 0 48 0c17.7 0 32 14.3 32 32l0 128c0 17.7-14.3 32-32 32l-160 0c-17.7 0-32-14.3-32-32l0-128c0-17.7 14.3-32 32-32l0-48c0-44.2 35.8-80 80-80s80 35.8 80 80l-48 0c0-17.7-14.3-32-32-32s-32 14.3-32 32z\"]\n};\nconst faUserInjured = {\n prefix: 'fas',\n iconName: 'user-injured',\n icon: [448, 512, [], \"f728\", \"M240 80l102.7 0c-7.9-19.5-20.4-36.5-36.2-49.9L240 80zm37.7-68.2C261.3 4.2 243.2 0 224 0c-53.7 0-99.7 33.1-118.7 80l81.4 0 91-68.2zM224 256c70.7 0 128-57.3 128-128c0-5.4-.3-10.8-1-16L97 112c-.7 5.2-1 10.6-1 16c0 70.7 57.3 128 128 128zM124 312.4c-9.7 3.1-19.1 7-28 11.7L96 512l147.7 0L181.5 408.2 124 312.4zm33-7.2L204.3 384l67.7 0c44.2 0 80 35.8 80 80c0 18-6 34.6-16 48l82.3 0c16.4 0 29.7-13.3 29.7-29.7C448 383.8 368.2 304 269.7 304l-91.4 0c-7.2 0-14.3 .4-21.3 1.3zM0 482.3C0 498.7 13.3 512 29.7 512L64 512l0-166.6C24.9 378.1 0 427.3 0 482.3zM320 464c0-26.5-21.5-48-48-48l-48.5 0 57.1 95.2C303 507.2 320 487.6 320 464z\"]\n};\nconst faFaceSadTear = {\n prefix: 'fas',\n iconName: 'face-sad-tear',\n icon: [512, 512, [128546, \"sad-tear\"], \"f5b4\", \"M0 256a256 256 0 1 0 512 0A256 256 0 1 0 0 256zm240 80c0-8.8 7.2-16 16-16c45 0 85.6 20.5 115.7 53.1c6 6.5 5.6 16.6-.9 22.6s-16.6 5.6-22.6-.9c-25-27.1-57.4-42.9-92.3-42.9c-8.8 0-16-7.2-16-16zm-80 80c-26.5 0-48-21-48-47c0-20 28.6-60.4 41.6-77.7c3.2-4.4 9.6-4.4 12.8 0C179.6 308.6 208 349 208 369c0 26-21.5 47-48 47zM367.6 208a32 32 0 1 1 -64 0 32 32 0 1 1 64 0zm-192-32a32 32 0 1 1 0 64 32 32 0 1 1 0-64z\"]\n};\nconst faSadTear = faFaceSadTear;\nconst faPlane = {\n prefix: 'fas',\n iconName: 'plane',\n icon: [576, 512, [], \"f072\", \"M482.3 192c34.2 0 93.7 29 93.7 64c0 36-59.5 64-93.7 64l-116.6 0L265.2 495.9c-5.7 10-16.3 16.1-27.8 16.1l-56.2 0c-10.6 0-18.3-10.2-15.4-20.4l49-171.6L112 320 68.8 377.6c-3 4-7.8 6.4-12.8 6.4l-42 0c-7.8 0-14-6.3-14-14c0-1.3 .2-2.6 .5-3.9L32 256 .5 145.9c-.4-1.3-.5-2.6-.5-3.9c0-7.8 6.3-14 14-14l42 0c5 0 9.8 2.4 12.8 6.4L112 192l102.9 0-49-171.6C162.9 10.2 170.6 0 181.2 0l56.2 0c11.5 0 22.1 6.2 27.8 16.1L365.7 192l116.6 0z\"]\n};\nconst faTentArrowsDown = {\n prefix: 'fas',\n iconName: 'tent-arrows-down',\n icon: [576, 512, [], \"e581\", \"M209.8 111.9c-8.9-9.9-24-10.7-33.9-1.8l-39.9 36L136 24c0-13.3-10.7-24-24-24S88 10.7 88 24l0 122.1-39.9-36c-9.9-8.9-25-8.1-33.9 1.8s-8.1 25 1.8 33.9l80 72c9.1 8.2 23 8.2 32.1 0l80-72c9.9-8.9 10.7-24 1.8-33.9zm352 0c-8.9-9.9-24-10.7-33.9-1.8l-39.9 36L488 24c0-13.3-10.7-24-24-24s-24 10.7-24 24l0 122.1-39.9-36c-9.9-8.9-25-8.1-33.9 1.8s-8.1 25 1.8 33.9l80 72c9.1 8.2 23 8.2 32.1 0l80-72c9.9-8.9 10.7-24 1.8-33.9zM307.4 166.5c-11.5-8.7-27.3-8.7-38.8 0l-168 128c-6.6 5-11 12.5-12.3 20.7l-24 160c-1.4 9.2 1.3 18.6 7.4 25.6S86.7 512 96 512l144 0 16 0c17.7 0 32-14.3 32-32l0-118.1c0-5.5 4.4-9.9 9.9-9.9c3.7 0 7.2 2.1 8.8 5.5l68.4 136.8c5.4 10.8 16.5 17.7 28.6 17.7l60.2 0 16 0c9.3 0 18.2-4.1 24.2-11.1s8.8-16.4 7.4-25.6l-24-160c-1.2-8.2-5.6-15.7-12.3-20.7l-168-128z\"]\n};\nconst faExclamation = {\n prefix: 'fas',\n iconName: 'exclamation',\n icon: [128, 512, [10069, 10071, 61738], \"21\", \"M96 64c0-17.7-14.3-32-32-32S32 46.3 32 64l0 256c0 17.7 14.3 32 32 32s32-14.3 32-32L96 64zM64 480a40 40 0 1 0 0-80 40 40 0 1 0 0 80z\"]\n};\nconst faArrowsSpin = {\n prefix: 'fas',\n iconName: 'arrows-spin',\n icon: [512, 512, [], \"e4bb\", \"M256 96c38.4 0 73.7 13.5 101.3 36.1l-32.6 32.6c-4.6 4.6-5.9 11.5-3.5 17.4s8.3 9.9 14.8 9.9l112 0c8.8 0 16-7.2 16-16l0-112c0-6.5-3.9-12.3-9.9-14.8s-12.9-1.1-17.4 3.5l-34 34C363.4 52.6 312.1 32 256 32c-10.9 0-21.5 .8-32 2.3l0 64.9c10.3-2.1 21-3.2 32-3.2zM132.1 154.7l32.6 32.6c4.6 4.6 11.5 5.9 17.4 3.5s9.9-8.3 9.9-14.8l0-112c0-8.8-7.2-16-16-16L64 48c-6.5 0-12.3 3.9-14.8 9.9s-1.1 12.9 3.5 17.4l34 34C52.6 148.6 32 199.9 32 256c0 10.9 .8 21.5 2.3 32l64.9 0c-2.1-10.3-3.2-21-3.2-32c0-38.4 13.5-73.7 36.1-101.3zM477.7 224l-64.9 0c2.1 10.3 3.2 21 3.2 32c0 38.4-13.5 73.7-36.1 101.3l-32.6-32.6c-4.6-4.6-11.5-5.9-17.4-3.5s-9.9 8.3-9.9 14.8l0 112c0 8.8 7.2 16 16 16l112 0c6.5 0 12.3-3.9 14.8-9.9s1.1-12.9-3.5-17.4l-34-34C459.4 363.4 480 312.1 480 256c0-10.9-.8-21.5-2.3-32zM256 416c-38.4 0-73.7-13.5-101.3-36.1l32.6-32.6c4.6-4.6 5.9-11.5 3.5-17.4s-8.3-9.9-14.8-9.9L64 320c-8.8 0-16 7.2-16 16l0 112c0 6.5 3.9 12.3 9.9 14.8s12.9 1.1 17.4-3.5l34-34C148.6 459.4 199.9 480 256 480c10.9 0 21.5-.8 32-2.3l0-64.9c-10.3 2.1-21 3.2-32 3.2z\"]\n};\nconst faPrint = {\n prefix: 'fas',\n iconName: 'print',\n icon: [512, 512, [128424, 128438, 9113], \"f02f\", \"M128 0C92.7 0 64 28.7 64 64l0 96 64 0 0-96 226.7 0L384 93.3l0 66.7 64 0 0-66.7c0-17-6.7-33.3-18.7-45.3L400 18.7C388 6.7 371.7 0 354.7 0L128 0zM384 352l0 32 0 64-256 0 0-64 0-16 0-16 256 0zm64 32l32 0c17.7 0 32-14.3 32-32l0-96c0-35.3-28.7-64-64-64L64 192c-35.3 0-64 28.7-64 64l0 96c0 17.7 14.3 32 32 32l32 0 0 64c0 35.3 28.7 64 64 64l256 0c35.3 0 64-28.7 64-64l0-64zM432 248a24 24 0 1 1 0 48 24 24 0 1 1 0-48z\"]\n};\nconst faTurkishLiraSign = {\n prefix: 'fas',\n iconName: 'turkish-lira-sign',\n icon: [384, 512, [\"try\", \"turkish-lira\"], \"e2bb\", \"M96 32c17.7 0 32 14.3 32 32l0 35.3L247.2 65.2c17-4.9 34.7 5 39.6 22s-5 34.7-22 39.6L128 165.9l0 29.4 119.2-34.1c17-4.9 34.7 5 39.6 22s-5 34.7-22 39.6L128 261.9 128 416l63.8 0c68.2 0 124.4-53.5 127.8-121.6l.4-8c.9-17.7 15.9-31.2 33.6-30.4s31.2 15.9 30.4 33.6l-.4 8C378.5 399.8 294.1 480 191.8 480L96 480c-17.7 0-32-14.3-32-32l0-167.9-23.2 6.6c-17 4.9-34.7-5-39.6-22s5-34.7 22-39.6L64 213.6l0-29.4-23.2 6.6c-17 4.9-34.7-5-39.6-22s5-34.7 22-39.6L64 117.6 64 64c0-17.7 14.3-32 32-32z\"]\n};\nconst faTry = faTurkishLiraSign;\nconst faTurkishLira = faTurkishLiraSign;\nconst faDollarSign = {\n prefix: 'fas',\n iconName: 'dollar-sign',\n icon: [320, 512, [128178, 61781, \"dollar\", \"usd\"], \"24\", \"M160 0c17.7 0 32 14.3 32 32l0 35.7c1.6 .2 3.1 .4 4.7 .7c.4 .1 .7 .1 1.1 .2l48 8.8c17.4 3.2 28.9 19.9 25.7 37.2s-19.9 28.9-37.2 25.7l-47.5-8.7c-31.3-4.6-58.9-1.5-78.3 6.2s-27.2 18.3-29 28.1c-2 10.7-.5 16.7 1.2 20.4c1.8 3.9 5.5 8.3 12.8 13.2c16.3 10.7 41.3 17.7 73.7 26.3l2.9 .8c28.6 7.6 63.6 16.8 89.6 33.8c14.2 9.3 27.6 21.9 35.9 39.5c8.5 17.9 10.3 37.9 6.4 59.2c-6.9 38-33.1 63.4-65.6 76.7c-13.7 5.6-28.6 9.2-44.4 11l0 33.4c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-34.9c-.4-.1-.9-.1-1.3-.2l-.2 0s0 0 0 0c-24.4-3.8-64.5-14.3-91.5-26.3c-16.1-7.2-23.4-26.1-16.2-42.2s26.1-23.4 42.2-16.2c20.9 9.3 55.3 18.5 75.2 21.6c31.9 4.7 58.2 2 76-5.3c16.9-6.9 24.6-16.9 26.8-28.9c1.9-10.6 .4-16.7-1.3-20.4c-1.9-4-5.6-8.4-13-13.3c-16.4-10.7-41.5-17.7-74-26.3l-2.8-.7s0 0 0 0C119.4 279.3 84.4 270 58.4 253c-14.2-9.3-27.5-22-35.8-39.6c-8.4-17.9-10.1-37.9-6.1-59.2C23.7 116 52.3 91.2 84.8 78.3c13.3-5.3 27.9-8.9 43.2-11L128 32c0-17.7 14.3-32 32-32z\"]\n};\nconst faDollar = faDollarSign;\nconst faUsd = faDollarSign;\nconst faX = {\n prefix: 'fas',\n iconName: 'x',\n icon: [384, 512, [120], \"58\", \"M376.6 84.5c11.3-13.6 9.5-33.8-4.1-45.1s-33.8-9.5-45.1 4.1L192 206 56.6 43.5C45.3 29.9 25.1 28.1 11.5 39.4S-3.9 70.9 7.4 84.5L150.3 256 7.4 427.5c-11.3 13.6-9.5 33.8 4.1 45.1s33.8 9.5 45.1-4.1L192 306 327.4 468.5c11.3 13.6 31.5 15.4 45.1 4.1s15.4-31.5 4.1-45.1L233.7 256 376.6 84.5z\"]\n};\nconst faMagnifyingGlassDollar = {\n prefix: 'fas',\n iconName: 'magnifying-glass-dollar',\n icon: [512, 512, [\"search-dollar\"], \"f688\", \"M416 208c0 45.9-14.9 88.3-40 122.7L502.6 457.4c12.5 12.5 12.5 32.8 0 45.3s-32.8 12.5-45.3 0L330.7 376c-34.4 25.2-76.8 40-122.7 40C93.1 416 0 322.9 0 208S93.1 0 208 0S416 93.1 416 208zM228 104c0-11-9-20-20-20s-20 9-20 20l0 14c-7.6 1.7-15.2 4.4-22.2 8.5c-13.9 8.3-25.9 22.8-25.8 43.9c.1 20.3 12 33.1 24.7 40.7c11 6.6 24.7 10.8 35.6 14l1.7 .5c12.6 3.8 21.8 6.8 28 10.7c5.1 3.2 5.8 5.4 5.9 8.2c.1 5-1.8 8-5.9 10.5c-5 3.1-12.9 5-21.4 4.7c-11.1-.4-21.5-3.9-35.1-8.5c-2.3-.8-4.7-1.6-7.2-2.4c-10.5-3.5-21.8 2.2-25.3 12.6s2.2 21.8 12.6 25.3c1.9 .6 4 1.3 6.1 2.1c0 0 0 0 0 0s0 0 0 0c8.3 2.9 17.9 6.2 28.2 8.4l0 14.6c0 11 9 20 20 20s20-9 20-20l0-13.8c8-1.7 16-4.5 23.2-9c14.3-8.9 25.1-24.1 24.8-45c-.3-20.3-11.7-33.4-24.6-41.6c-11.5-7.2-25.9-11.6-37.1-15l-.7-.2c-12.8-3.9-21.9-6.7-28.3-10.5c-5.2-3.1-5.3-4.9-5.3-6.7c0-3.7 1.4-6.5 6.2-9.3c5.4-3.2 13.6-5.1 21.5-5c9.6 .1 20.2 2.2 31.2 5.2c10.7 2.8 21.6-3.5 24.5-14.2s-3.5-21.6-14.2-24.5c-6.5-1.7-13.7-3.4-21.1-4.7l0-13.9z\"]\n};\nconst faSearchDollar = faMagnifyingGlassDollar;\nconst faUsersGear = {\n prefix: 'fas',\n iconName: 'users-gear',\n icon: [640, 512, [\"users-cog\"], \"f509\", \"M144 160A80 80 0 1 0 144 0a80 80 0 1 0 0 160zm368 0A80 80 0 1 0 512 0a80 80 0 1 0 0 160zM0 298.7C0 310.4 9.6 320 21.3 320l213.3 0c.2 0 .4 0 .7 0c-26.6-23.5-43.3-57.8-43.3-96c0-7.6 .7-15 1.9-22.3c-13.6-6.3-28.7-9.7-44.6-9.7l-42.7 0C47.8 192 0 239.8 0 298.7zM320 320c24 0 45.9-8.8 62.7-23.3c2.5-3.7 5.2-7.3 8-10.7c2.7-3.3 5.7-6.1 9-8.3C410 262.3 416 243.9 416 224c0-53-43-96-96-96s-96 43-96 96s43 96 96 96zm65.4 60.2c-10.3-5.9-18.1-16.2-20.8-28.2l-103.2 0C187.7 352 128 411.7 128 485.3c0 14.7 11.9 26.7 26.7 26.7l300.6 0c-2.1-5.2-3.2-10.9-3.2-16.4l0-3c-1.3-.7-2.7-1.5-4-2.3l-2.6 1.5c-16.8 9.7-40.5 8-54.7-9.7c-4.5-5.6-8.6-11.5-12.4-17.6l-.1-.2-.1-.2-2.4-4.1-.1-.2-.1-.2c-3.4-6.2-6.4-12.6-9-19.3c-8.2-21.2 2.2-42.6 19-52.3l2.7-1.5c0-.8 0-1.5 0-2.3s0-1.5 0-2.3l-2.7-1.5zM533.3 192l-42.7 0c-15.9 0-31 3.5-44.6 9.7c1.3 7.2 1.9 14.7 1.9 22.3c0 17.4-3.5 33.9-9.7 49c2.5 .9 4.9 2 7.1 3.3l2.6 1.5c1.3-.8 2.6-1.6 4-2.3l0-3c0-19.4 13.3-39.1 35.8-42.6c7.9-1.2 16-1.9 24.2-1.9s16.3 .6 24.2 1.9c22.5 3.5 35.8 23.2 35.8 42.6l0 3c1.3 .7 2.7 1.5 4 2.3l2.6-1.5c16.8-9.7 40.5-8 54.7 9.7c2.3 2.8 4.5 5.8 6.6 8.7c-2.1-57.1-49-102.7-106.6-102.7zm91.3 163.9c6.3-3.6 9.5-11.1 6.8-18c-2.1-5.5-4.6-10.8-7.4-15.9l-2.3-4c-3.1-5.1-6.5-9.9-10.2-14.5c-4.6-5.7-12.7-6.7-19-3l-2.9 1.7c-9.2 5.3-20.4 4-29.6-1.3s-16.1-14.5-16.1-25.1l0-3.4c0-7.3-4.9-13.8-12.1-14.9c-6.5-1-13.1-1.5-19.9-1.5s-13.4 .5-19.9 1.5c-7.2 1.1-12.1 7.6-12.1 14.9l0 3.4c0 10.6-6.9 19.8-16.1 25.1s-20.4 6.6-29.6 1.3l-2.9-1.7c-6.3-3.6-14.4-2.6-19 3c-3.7 4.6-7.1 9.5-10.2 14.6l-2.3 3.9c-2.8 5.1-5.3 10.4-7.4 15.9c-2.6 6.8 .5 14.3 6.8 17.9l2.9 1.7c9.2 5.3 13.7 15.8 13.7 26.4s-4.5 21.1-13.7 26.4l-3 1.7c-6.3 3.6-9.5 11.1-6.8 17.9c2.1 5.5 4.6 10.7 7.4 15.8l2.4 4.1c3 5.1 6.4 9.9 10.1 14.5c4.6 5.7 12.7 6.7 19 3l2.9-1.7c9.2-5.3 20.4-4 29.6 1.3s16.1 14.5 16.1 25.1l0 3.4c0 7.3 4.9 13.8 12.1 14.9c6.5 1 13.1 1.5 19.9 1.5s13.4-.5 19.9-1.5c7.2-1.1 12.1-7.6 12.1-14.9l0-3.4c0-10.6 6.9-19.8 16.1-25.1s20.4-6.6 29.6-1.3l2.9 1.7c6.3 3.6 14.4 2.6 19-3c3.7-4.6 7.1-9.4 10.1-14.5l2.4-4.2c2.8-5.1 5.3-10.3 7.4-15.8c2.6-6.8-.5-14.3-6.8-17.9l-3-1.7c-9.2-5.3-13.7-15.8-13.7-26.4s4.5-21.1 13.7-26.4l3-1.7zM472 384a40 40 0 1 1 80 0 40 40 0 1 1 -80 0z\"]\n};\nconst faUsersCog = faUsersGear;\nconst faPersonMilitaryPointing = {\n prefix: 'fas',\n iconName: 'person-military-pointing',\n icon: [576, 512, [], \"e54a\", \"M246.9 14.1C234 15.2 224 26 224 39c0 13.8 11.2 25 25 25l151 0c8.8 0 16-7.2 16-16l0-30.6C416 8 408 .7 398.7 1.4L246.9 14.1zM240 112c0 44.2 35.8 80 80 80s80-35.8 80-80c0-5.5-.6-10.8-1.6-16L241.6 96c-1 5.2-1.6 10.5-1.6 16zM72 224c-22.1 0-40 17.9-40 40s17.9 40 40 40l152 0 0 89.4L386.8 230.5c-13.3-4.3-27.3-6.5-41.6-6.5L240 224 72 224zm345.7 20.9L246.6 416 416 416l0-46.3 53.6 90.6c11.2 19 35.8 25.3 54.8 14.1s25.3-35.8 14.1-54.8L462.3 290.8c-11.2-18.9-26.6-34.5-44.6-45.9zM224 448l0 32c0 17.7 14.3 32 32 32l128 0c17.7 0 32-14.3 32-32l0-32-192 0z\"]\n};\nconst faBuildingColumns = {\n prefix: 'fas',\n iconName: 'building-columns',\n icon: [512, 512, [\"bank\", \"institution\", \"museum\", \"university\"], \"f19c\", \"M243.4 2.6l-224 96c-14 6-21.8 21-18.7 35.8S16.8 160 32 160l0 8c0 13.3 10.7 24 24 24l400 0c13.3 0 24-10.7 24-24l0-8c15.2 0 28.3-10.7 31.3-25.6s-4.8-29.9-18.7-35.8l-224-96c-8-3.4-17.2-3.4-25.2 0zM128 224l-64 0 0 196.3c-.6 .3-1.2 .7-1.8 1.1l-48 32c-11.7 7.8-17 22.4-12.9 35.9S17.9 512 32 512l448 0c14.1 0 26.5-9.2 30.6-22.7s-1.1-28.1-12.9-35.9l-48-32c-.6-.4-1.2-.7-1.8-1.1L448 224l-64 0 0 192-40 0 0-192-64 0 0 192-48 0 0-192-64 0 0 192-40 0 0-192zM256 64a32 32 0 1 1 0 64 32 32 0 1 1 0-64z\"]\n};\nconst faBank = faBuildingColumns;\nconst faInstitution = faBuildingColumns;\nconst faMuseum = faBuildingColumns;\nconst faUniversity = faBuildingColumns;\nconst faUmbrella = {\n prefix: 'fas',\n iconName: 'umbrella',\n icon: [576, 512, [], \"f0e9\", \"M288 0c17.7 0 32 14.3 32 32l0 17.7C451.8 63.4 557.7 161 573.9 285.9c2 15.6-17.3 24.4-27.8 12.7C532.1 283 504.8 272 480 272c-38.7 0-71 27.5-78.4 64.1c-1.7 8.7-8.7 15.9-17.6 15.9s-15.8-7.2-17.6-15.9C359 299.5 326.7 272 288 272s-71 27.5-78.4 64.1c-1.7 8.7-8.7 15.9-17.6 15.9s-15.8-7.2-17.6-15.9C167 299.5 134.7 272 96 272c-24.8 0-52.1 11-66.1 26.7C19.4 310.4 .1 301.5 2.1 285.9C18.3 161 124.2 63.4 256 49.7L256 32c0-17.7 14.3-32 32-32zm0 304c12.3 0 23.5 4.6 32 12.2l0 114.3c0 45-36.5 81.4-81.4 81.4c-30.8 0-59-17.4-72.8-45l-2.3-4.7c-7.9-15.8-1.5-35 14.3-42.9s35-1.5 42.9 14.3l2.3 4.7c3 5.9 9 9.6 15.6 9.6c9.6 0 17.4-7.8 17.4-17.4l0-114.3c8.5-7.6 19.7-12.2 32-12.2z\"]\n};\nconst faTrowel = {\n prefix: 'fas',\n iconName: 'trowel',\n icon: [512, 512, [], \"e589\", \"M343.9 213.4L245.3 312l65.4 65.4c7.9 7.9 11.1 19.4 8.4 30.3s-10.8 19.6-21.5 22.9l-256 80c-11.4 3.5-23.8 .5-32.2-7.9S-2.1 481.8 1.5 470.5l80-256c3.3-10.7 12-18.9 22.9-21.5s22.4 .5 30.3 8.4L200 266.7l98.6-98.6c-14.3-14.6-14.2-38 .3-52.5l95.4-95.4c26.9-26.9 70.5-26.9 97.5 0s26.9 70.5 0 97.5l-95.4 95.4c-14.5 14.5-37.9 14.6-52.5 .3z\"]\n};\nconst faD = {\n prefix: 'fas',\n iconName: 'd',\n icon: [384, 512, [100], \"44\", \"M0 96C0 60.7 28.7 32 64 32l96 0c123.7 0 224 100.3 224 224s-100.3 224-224 224l-96 0c-35.3 0-64-28.7-64-64L0 96zm160 0L64 96l0 320 96 0c88.4 0 160-71.6 160-160s-71.6-160-160-160z\"]\n};\nconst faStapler = {\n prefix: 'fas',\n iconName: 'stapler',\n icon: [640, 512, [], \"e5af\", \"M640 299.3l0 4.7 0 128c0 26.5-21.5 48-48 48l-80 0-64 0L64 480c-17.7 0-32-14.3-32-32s14.3-32 32-32l384 0 0-48L96 368c-17.7 0-32-14.3-32-32l0-116.6L33.8 214C14.2 210.5 0 193.5 0 173.7c0-8.9 2.9-17.5 8.2-24.6l35.6-47.5C76.7 57.8 128.2 32 182.9 32c27 0 53.6 6.3 77.8 18.4L586.9 213.5C619.5 229.7 640 263 640 299.3zM448 304l0-16L128 230.9l0 73.1 320 0z\"]\n};\nconst faMasksTheater = {\n prefix: 'fas',\n iconName: 'masks-theater',\n icon: [640, 512, [127917, \"theater-masks\"], \"f630\", \"M74.6 373.2c41.7 36.1 108 82.5 166.1 73.7c6.1-.9 12.1-2.5 18-4.5c-9.2-12.3-17.3-24.4-24.2-35.4c-21.9-35-28.8-75.2-25.9-113.6c-20.6 4.1-39.2 13-54.7 25.4c-6.5 5.2-16.3 1.3-14.8-7c6.4-33.5 33-60.9 68.2-66.3c2.6-.4 5.3-.7 7.9-.8l19.4-131.3c2-13.8 8-32.7 25-45.9C278.2 53.2 310.5 37 363.2 32.2c-.8-.7-1.6-1.4-2.4-2.1C340.6 14.5 288.4-11.5 175.7 5.6S20.5 63 5.7 83.9C0 91.9-.8 102 .6 111.8L24.8 276.1c5.5 37.3 21.5 72.6 49.8 97.2zm87.7-219.6c4.4-3.1 10.8-2 11.8 3.3c.1 .5 .2 1.1 .3 1.6c3.2 21.8-11.6 42-33.1 45.3s-41.5-11.8-44.7-33.5c-.1-.5-.1-1.1-.2-1.6c-.6-5.4 5.2-8.4 10.3-6.7c9 3 18.8 3.9 28.7 2.4s19.1-5.3 26.8-10.8zM261.6 390c29.4 46.9 79.5 110.9 137.6 119.7s124.5-37.5 166.1-73.7c28.3-24.5 44.3-59.8 49.8-97.2l24.2-164.3c1.4-9.8 .6-19.9-5.1-27.9c-14.8-20.9-57.3-61.2-170-78.3S299.4 77.2 279.2 92.8c-7.8 6-11.5 15.4-12.9 25.2L242.1 282.3c-5.5 37.3-.4 75.8 19.6 107.7zM404.5 235.3c-7.7-5.5-16.8-9.3-26.8-10.8s-19.8-.6-28.7 2.4c-5.1 1.7-10.9-1.3-10.3-6.7c.1-.5 .1-1.1 .2-1.6c3.2-21.8 23.2-36.8 44.7-33.5s36.3 23.5 33.1 45.3c-.1 .5-.2 1.1-.3 1.6c-1 5.3-7.4 6.4-11.8 3.3zm136.2 15.5c-1 5.3-7.4 6.4-11.8 3.3c-7.7-5.5-16.8-9.3-26.8-10.8s-19.8-.6-28.7 2.4c-5.1 1.7-10.9-1.3-10.3-6.7c.1-.5 .1-1.1 .2-1.6c3.2-21.8 23.2-36.8 44.7-33.5s36.3 23.5 33.1 45.3c-.1 .5-.2 1.1-.3 1.6zM530 350.2c-19.6 44.7-66.8 72.5-116.8 64.9s-87.1-48.2-93-96.7c-1-8.3 8.9-12.1 15.2-6.7c23.9 20.8 53.6 35.3 87 40.3s66.1 .1 94.9-12.8c7.6-3.4 16 3.2 12.6 10.9z\"]\n};\nconst faTheaterMasks = faMasksTheater;\nconst faKipSign = {\n prefix: 'fas',\n iconName: 'kip-sign',\n icon: [384, 512, [], \"e1c4\", \"M340.8 88.3c13.4-11.5 15-31.7 3.5-45.1s-31.7-15-45.1-3.5L128 186.4 128 64c0-17.7-14.3-32-32-32S64 46.3 64 64l0 160-32 0c-17.7 0-32 14.3-32 32s14.3 32 32 32l32 0 0 160c0 17.7 14.3 32 32 32s32-14.3 32-32l0-122.4L299.2 472.3c13.4 11.5 33.6 9.9 45.1-3.5s9.9-33.6-3.5-45.1L182.5 288 352 288c17.7 0 32-14.3 32-32s-14.3-32-32-32l-169.5 0L340.8 88.3z\"]\n};\nconst faHandPointLeft = {\n prefix: 'fas',\n iconName: 'hand-point-left',\n icon: [512, 512, [], \"f0a5\", \"M32 96C14.3 96 0 110.3 0 128s14.3 32 32 32l208 0 0-64L32 96zM192 288c-17.7 0-32 14.3-32 32s14.3 32 32 32l64 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-64 0zm-64-64c0 17.7 14.3 32 32 32l48 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-48 0c-17.7 0-32 14.3-32 32zm96 160c-17.7 0-32 14.3-32 32s14.3 32 32 32l64 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-64 0zm88-96l-.6 0c5.4 9.4 8.6 20.3 8.6 32c0 13.2-4 25.4-10.8 35.6c24.9 8.7 42.8 32.5 42.8 60.4c0 11.7-3.1 22.6-8.6 32l8.6 0c88.4 0 160-71.6 160-160l0-61.7c0-42.4-16.9-83.1-46.9-113.1l-11.6-11.6C429.5 77.5 396.9 64 363 64l-27 0c-35.3 0-64 28.7-64 64l0 88c0 22.1 17.9 40 40 40s40-17.9 40-40l0-56c0-8.8 7.2-16 16-16s16 7.2 16 16l0 56c0 39.8-32.2 72-72 72z\"]\n};\nconst faHandshakeSimple = {\n prefix: 'fas',\n iconName: 'handshake-simple',\n icon: [640, 512, [129309, \"handshake-alt\"], \"f4c6\", \"M323.4 85.2l-96.8 78.4c-16.1 13-19.2 36.4-7 53.1c12.9 17.8 38 21.3 55.3 7.8l99.3-77.2c7-5.4 17-4.2 22.5 2.8s4.2 17-2.8 22.5l-20.9 16.2L550.2 352l41.8 0c26.5 0 48-21.5 48-48l0-128c0-26.5-21.5-48-48-48l-76 0-4 0-.7 0-3.9-2.5L434.8 79c-15.3-9.8-33.2-15-51.4-15c-21.8 0-43 7.5-60 21.2zm22.8 124.4l-51.7 40.2C263 274.4 217.3 268 193.7 235.6c-22.2-30.5-16.6-73.1 12.7-96.8l83.2-67.3c-11.6-4.9-24.1-7.4-36.8-7.4C234 64 215.7 69.6 200 80l-72 48-80 0c-26.5 0-48 21.5-48 48L0 304c0 26.5 21.5 48 48 48l108.2 0 91.4 83.4c19.6 17.9 49.9 16.5 67.8-3.1c5.5-6.1 9.2-13.2 11.1-20.6l17 15.6c19.5 17.9 49.9 16.6 67.8-2.9c4.5-4.9 7.8-10.6 9.9-16.5c19.4 13 45.8 10.3 62.1-7.5c17.9-19.5 16.6-49.9-2.9-67.8l-134.2-123z\"]\n};\nconst faHandshakeAlt = faHandshakeSimple;\nconst faJetFighter = {\n prefix: 'fas',\n iconName: 'jet-fighter',\n icon: [640, 512, [\"fighter-jet\"], \"f0fb\", \"M160 24c0-13.3 10.7-24 24-24L296 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-16 0L384 192l116.4 0c7.7 0 15.3 1.4 22.5 4.1L625 234.4c9 3.4 15 12 15 21.6s-6 18.2-15 21.6L522.9 315.9c-7.2 2.7-14.8 4.1-22.5 4.1L384 320 280 464l16 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-112 0c-13.3 0-24-10.7-24-24s10.7-24 24-24l8 0 0-144-32 0-54.6 54.6c-6 6-14.1 9.4-22.6 9.4L64 384c-17.7 0-32-14.3-32-32l0-64c-17.7 0-32-14.3-32-32s14.3-32 32-32l0-64c0-17.7 14.3-32 32-32l18.7 0c8.5 0 16.6 3.4 22.6 9.4L160 192l32 0 0-144-8 0c-13.3 0-24-10.7-24-24zM80 240c-8.8 0-16 7.2-16 16s7.2 16 16 16l64 0c8.8 0 16-7.2 16-16s-7.2-16-16-16l-64 0z\"]\n};\nconst faFighterJet = faJetFighter;\nconst faSquareShareNodes = {\n prefix: 'fas',\n iconName: 'square-share-nodes',\n icon: [448, 512, [\"share-alt-square\"], \"f1e1\", \"M64 32C28.7 32 0 60.7 0 96L0 416c0 35.3 28.7 64 64 64l320 0c35.3 0 64-28.7 64-64l0-320c0-35.3-28.7-64-64-64L64 32zM384 160c0 35.3-28.7 64-64 64c-15.4 0-29.5-5.4-40.6-14.5L194.1 256l85.3 46.5c11-9.1 25.2-14.5 40.6-14.5c35.3 0 64 28.7 64 64s-28.7 64-64 64s-64-28.7-64-64c0-2.5 .1-4.9 .4-7.3L174.5 300c-11.7 12.3-28.2 20-46.5 20c-35.3 0-64-28.7-64-64s28.7-64 64-64c18.3 0 34.8 7.7 46.5 20l81.9-44.7c-.3-2.4-.4-4.9-.4-7.3c0-35.3 28.7-64 64-64s64 28.7 64 64z\"]\n};\nconst faShareAltSquare = faSquareShareNodes;\nconst faBarcode = {\n prefix: 'fas',\n iconName: 'barcode',\n icon: [512, 512, [], \"f02a\", \"M24 32C10.7 32 0 42.7 0 56L0 456c0 13.3 10.7 24 24 24l16 0c13.3 0 24-10.7 24-24L64 56c0-13.3-10.7-24-24-24L24 32zm88 0c-8.8 0-16 7.2-16 16l0 416c0 8.8 7.2 16 16 16s16-7.2 16-16l0-416c0-8.8-7.2-16-16-16zm72 0c-13.3 0-24 10.7-24 24l0 400c0 13.3 10.7 24 24 24l16 0c13.3 0 24-10.7 24-24l0-400c0-13.3-10.7-24-24-24l-16 0zm96 0c-13.3 0-24 10.7-24 24l0 400c0 13.3 10.7 24 24 24l16 0c13.3 0 24-10.7 24-24l0-400c0-13.3-10.7-24-24-24l-16 0zM448 56l0 400c0 13.3 10.7 24 24 24l16 0c13.3 0 24-10.7 24-24l0-400c0-13.3-10.7-24-24-24l-16 0c-13.3 0-24 10.7-24 24zm-64-8l0 416c0 8.8 7.2 16 16 16s16-7.2 16-16l0-416c0-8.8-7.2-16-16-16s-16 7.2-16 16z\"]\n};\nconst faPlusMinus = {\n prefix: 'fas',\n iconName: 'plus-minus',\n icon: [384, 512, [], \"e43c\", \"M224 32c0-17.7-14.3-32-32-32s-32 14.3-32 32l0 112L48 144c-17.7 0-32 14.3-32 32s14.3 32 32 32l112 0 0 112c0 17.7 14.3 32 32 32s32-14.3 32-32l0-112 112 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-112 0 0-112zM0 480c0 17.7 14.3 32 32 32l320 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L32 448c-17.7 0-32 14.3-32 32z\"]\n};\nconst faVideo = {\n prefix: 'fas',\n iconName: 'video',\n icon: [576, 512, [\"video-camera\"], \"f03d\", \"M0 128C0 92.7 28.7 64 64 64l256 0c35.3 0 64 28.7 64 64l0 256c0 35.3-28.7 64-64 64L64 448c-35.3 0-64-28.7-64-64L0 128zM559.1 99.8c10.4 5.6 16.9 16.4 16.9 28.2l0 256c0 11.8-6.5 22.6-16.9 28.2s-23 5-32.9-1.6l-96-64L416 337.1l0-17.1 0-128 0-17.1 14.2-9.5 96-64c9.8-6.5 22.4-7.2 32.9-1.6z\"]\n};\nconst faVideoCamera = faVideo;\nconst faGraduationCap = {\n prefix: 'fas',\n iconName: 'graduation-cap',\n icon: [640, 512, [127891, \"mortar-board\"], \"f19d\", \"M320 32c-8.1 0-16.1 1.4-23.7 4.1L15.8 137.4C6.3 140.9 0 149.9 0 160s6.3 19.1 15.8 22.6l57.9 20.9C57.3 229.3 48 259.8 48 291.9l0 28.1c0 28.4-10.8 57.7-22.3 80.8c-6.5 13-13.9 25.8-22.5 37.6C0 442.7-.9 448.3 .9 453.4s6 8.9 11.2 10.2l64 16c4.2 1.1 8.7 .3 12.4-2s6.3-6.1 7.1-10.4c8.6-42.8 4.3-81.2-2.1-108.7C90.3 344.3 86 329.8 80 316.5l0-24.6c0-30.2 10.2-58.7 27.9-81.5c12.9-15.5 29.6-28 49.2-35.7l157-61.7c8.2-3.2 17.5 .8 20.7 9s-.8 17.5-9 20.7l-157 61.7c-12.4 4.9-23.3 12.4-32.2 21.6l159.6 57.6c7.6 2.7 15.6 4.1 23.7 4.1s16.1-1.4 23.7-4.1L624.2 182.6c9.5-3.4 15.8-12.5 15.8-22.6s-6.3-19.1-15.8-22.6L343.7 36.1C336.1 33.4 328.1 32 320 32zM128 408c0 35.3 86 72 192 72s192-36.7 192-72L496.7 262.6 354.5 314c-11.1 4-22.8 6-34.5 6s-23.5-2-34.5-6L143.3 262.6 128 408z\"]\n};\nconst faMortarBoard = faGraduationCap;\nconst faHandHoldingMedical = {\n prefix: 'fas',\n iconName: 'hand-holding-medical',\n icon: [576, 512, [], \"e05c\", \"M224 24l0 56-56 0c-13.3 0-24 10.7-24 24l0 48c0 13.3 10.7 24 24 24l56 0 0 56c0 13.3 10.7 24 24 24l48 0c13.3 0 24-10.7 24-24l0-56 56 0c13.3 0 24-10.7 24-24l0-48c0-13.3-10.7-24-24-24l-56 0 0-56c0-13.3-10.7-24-24-24L248 0c-13.3 0-24 10.7-24 24zM559.7 392.2c17.8-13.1 21.6-38.1 8.5-55.9s-38.1-21.6-55.9-8.5L392.6 416 272 416c-8.8 0-16-7.2-16-16s7.2-16 16-16l16 0 64 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-64 0-16 0-78.3 0c-29.1 0-57.3 9.9-80 28L68.8 384 32 384c-17.7 0-32 14.3-32 32l0 64c0 17.7 14.3 32 32 32l160 0 160.5 0c29 0 57.3-9.3 80.7-26.5l126.6-93.3zm-367-8.2l.9 0c0 0 0 0 0 0c-.3 0-.6 0-.9 0z\"]\n};\nconst faPersonCircleCheck = {\n prefix: 'fas',\n iconName: 'person-circle-check',\n icon: [576, 512, [], \"e53e\", \"M112 48a48 48 0 1 1 96 0 48 48 0 1 1 -96 0zm40 304l0 128c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-223.1L59.4 304.5c-9.1 15.1-28.8 20-43.9 10.9s-20-28.8-10.9-43.9l58.3-97c17.4-28.9 48.6-46.6 82.3-46.6l29.7 0c33.7 0 64.9 17.7 82.3 46.6l44.9 74.7c-16.1 17.6-28.6 38.5-36.6 61.5c-1.9-1.8-3.5-3.9-4.9-6.3L232 256.9 232 480c0 17.7-14.3 32-32 32s-32-14.3-32-32l0-128-16 0zm136 16a144 144 0 1 1 288 0 144 144 0 1 1 -288 0zm211.3-43.3c-6.2-6.2-16.4-6.2-22.6 0L416 385.4l-28.7-28.7c-6.2-6.2-16.4-6.2-22.6 0s-6.2 16.4 0 22.6l40 40c6.2 6.2 16.4 6.2 22.6 0l72-72c6.2-6.2 6.2-16.4 0-22.6z\"]\n};\nconst faTurnUp = {\n prefix: 'fas',\n iconName: 'turn-up',\n icon: [384, 512, [10548, \"level-up-alt\"], \"f3bf\", \"M350 177.5c3.8-8.8 2-19-4.6-26l-136-144C204.9 2.7 198.6 0 192 0s-12.9 2.7-17.4 7.5l-136 144c-6.6 7-8.4 17.2-4.6 26s12.5 14.5 22 14.5l88 0 0 192c0 17.7-14.3 32-32 32l-80 0c-17.7 0-32 14.3-32 32l0 32c0 17.7 14.3 32 32 32l80 0c70.7 0 128-57.3 128-128l0-192 88 0c9.6 0 18.2-5.7 22-14.5z\"]\n};\nconst faLevelUpAlt = faTurnUp;\nvar icons = {\n fa0,\n fa1,\n fa2,\n fa3,\n fa4,\n fa5,\n fa6,\n fa7,\n fa8,\n fa9,\n faFillDrip,\n faArrowsToCircle,\n faCircleChevronRight,\n faChevronCircleRight,\n faAt,\n faTrashCan,\n faTrashAlt,\n faTextHeight,\n faUserXmark,\n faUserTimes,\n faStethoscope,\n faMessage,\n faCommentAlt,\n faInfo,\n faDownLeftAndUpRightToCenter,\n faCompressAlt,\n faExplosion,\n faFileLines,\n faFileAlt,\n faFileText,\n faWaveSquare,\n faRing,\n faBuildingUn,\n faDiceThree,\n faCalendarDays,\n faCalendarAlt,\n faAnchorCircleCheck,\n faBuildingCircleArrowRight,\n faVolleyball,\n faVolleyballBall,\n faArrowsUpToLine,\n faSortDown,\n faSortDesc,\n faCircleMinus,\n faMinusCircle,\n faDoorOpen,\n faRightFromBracket,\n faSignOutAlt,\n faAtom,\n faSoap,\n faIcons,\n faHeartMusicCameraBolt,\n faMicrophoneLinesSlash,\n faMicrophoneAltSlash,\n faBridgeCircleCheck,\n faPumpMedical,\n faFingerprint,\n faHandPointRight,\n faMagnifyingGlassLocation,\n faSearchLocation,\n faForwardStep,\n faStepForward,\n faFaceSmileBeam,\n faSmileBeam,\n faFlagCheckered,\n faFootball,\n faFootballBall,\n faSchoolCircleExclamation,\n faCrop,\n faAnglesDown,\n faAngleDoubleDown,\n faUsersRectangle,\n faPeopleRoof,\n faPeopleLine,\n faBeerMugEmpty,\n faBeer,\n faDiagramPredecessor,\n faArrowUpLong,\n faLongArrowUp,\n faFireFlameSimple,\n faBurn,\n faPerson,\n faMale,\n faLaptop,\n faFileCsv,\n faMenorah,\n faTruckPlane,\n faRecordVinyl,\n faFaceGrinStars,\n faGrinStars,\n faBong,\n faSpaghettiMonsterFlying,\n faPastafarianism,\n faArrowDownUpAcrossLine,\n faSpoon,\n faUtensilSpoon,\n faJarWheat,\n faEnvelopesBulk,\n faMailBulk,\n faFileCircleExclamation,\n faCircleH,\n faHospitalSymbol,\n faPager,\n faAddressBook,\n faContactBook,\n faStrikethrough,\n faK,\n faLandmarkFlag,\n faPencil,\n faPencilAlt,\n faBackward,\n faCaretRight,\n faComments,\n faPaste,\n faFileClipboard,\n faCodePullRequest,\n faClipboardList,\n faTruckRampBox,\n faTruckLoading,\n faUserCheck,\n faVialVirus,\n faSheetPlastic,\n faBlog,\n faUserNinja,\n faPersonArrowUpFromLine,\n faScrollTorah,\n faTorah,\n faBroomBall,\n faQuidditch,\n faQuidditchBroomBall,\n faToggleOff,\n faBoxArchive,\n faArchive,\n faPersonDrowning,\n faArrowDown91,\n faSortNumericDesc,\n faSortNumericDownAlt,\n faFaceGrinTongueSquint,\n faGrinTongueSquint,\n faSprayCan,\n faTruckMonster,\n faW,\n faEarthAfrica,\n faGlobeAfrica,\n faRainbow,\n faCircleNotch,\n faTabletScreenButton,\n faTabletAlt,\n faPaw,\n faCloud,\n faTrowelBricks,\n faFaceFlushed,\n faFlushed,\n faHospitalUser,\n faTentArrowLeftRight,\n faGavel,\n faLegal,\n faBinoculars,\n faMicrophoneSlash,\n faBoxTissue,\n faMotorcycle,\n faBellConcierge,\n faConciergeBell,\n faPenRuler,\n faPencilRuler,\n faPeopleArrows,\n faPeopleArrowsLeftRight,\n faMarsAndVenusBurst,\n faSquareCaretRight,\n faCaretSquareRight,\n faScissors,\n faCut,\n faSunPlantWilt,\n faToiletsPortable,\n faHockeyPuck,\n faTable,\n faMagnifyingGlassArrowRight,\n faTachographDigital,\n faDigitalTachograph,\n faUsersSlash,\n faClover,\n faReply,\n faMailReply,\n faStarAndCrescent,\n faHouseFire,\n faSquareMinus,\n faMinusSquare,\n faHelicopter,\n faCompass,\n faSquareCaretDown,\n faCaretSquareDown,\n faFileCircleQuestion,\n faLaptopCode,\n faSwatchbook,\n faPrescriptionBottle,\n faBars,\n faNavicon,\n faPeopleGroup,\n faHourglassEnd,\n faHourglass3,\n faHeartCrack,\n faHeartBroken,\n faSquareUpRight,\n faExternalLinkSquareAlt,\n faFaceKissBeam,\n faKissBeam,\n faFilm,\n faRulerHorizontal,\n faPeopleRobbery,\n faLightbulb,\n faCaretLeft,\n faCircleExclamation,\n faExclamationCircle,\n faSchoolCircleXmark,\n faArrowRightFromBracket,\n faSignOut,\n faCircleChevronDown,\n faChevronCircleDown,\n faUnlockKeyhole,\n faUnlockAlt,\n faCloudShowersHeavy,\n faHeadphonesSimple,\n faHeadphonesAlt,\n faSitemap,\n faCircleDollarToSlot,\n faDonate,\n faMemory,\n faRoadSpikes,\n faFireBurner,\n faFlag,\n faHanukiah,\n faFeather,\n faVolumeLow,\n faVolumeDown,\n faCommentSlash,\n faCloudSunRain,\n faCompress,\n faWheatAwn,\n faWheatAlt,\n faAnkh,\n faHandsHoldingChild,\n faAsterisk,\n faSquareCheck,\n faCheckSquare,\n faPesetaSign,\n faHeading,\n faHeader,\n faGhost,\n faList,\n faListSquares,\n faSquarePhoneFlip,\n faPhoneSquareAlt,\n faCartPlus,\n faGamepad,\n faCircleDot,\n faDotCircle,\n faFaceDizzy,\n faDizzy,\n faEgg,\n faHouseMedicalCircleXmark,\n faCampground,\n faFolderPlus,\n faFutbol,\n faFutbolBall,\n faSoccerBall,\n faPaintbrush,\n faPaintBrush,\n faLock,\n faGasPump,\n faHotTubPerson,\n faHotTub,\n faMapLocation,\n faMapMarked,\n faHouseFloodWater,\n faTree,\n faBridgeLock,\n faSackDollar,\n faPenToSquare,\n faEdit,\n faCarSide,\n faShareNodes,\n faShareAlt,\n faHeartCircleMinus,\n faHourglassHalf,\n faHourglass2,\n faMicroscope,\n faSink,\n faBagShopping,\n faShoppingBag,\n faArrowDownZA,\n faSortAlphaDesc,\n faSortAlphaDownAlt,\n faMitten,\n faPersonRays,\n faUsers,\n faEyeSlash,\n faFlaskVial,\n faHand,\n faHandPaper,\n faOm,\n faWorm,\n faHouseCircleXmark,\n faPlug,\n faChevronUp,\n faHandSpock,\n faStopwatch,\n faFaceKiss,\n faKiss,\n faBridgeCircleXmark,\n faFaceGrinTongue,\n faGrinTongue,\n faChessBishop,\n faFaceGrinWink,\n faGrinWink,\n faEarDeaf,\n faDeaf,\n faDeafness,\n faHardOfHearing,\n faRoadCircleCheck,\n faDiceFive,\n faSquareRss,\n faRssSquare,\n faLandMineOn,\n faICursor,\n faStamp,\n faStairs,\n faI,\n faHryvniaSign,\n faHryvnia,\n faPills,\n faFaceGrinWide,\n faGrinAlt,\n faTooth,\n faV,\n faBangladeshiTakaSign,\n faBicycle,\n faStaffSnake,\n faRodAsclepius,\n faRodSnake,\n faStaffAesculapius,\n faHeadSideCoughSlash,\n faTruckMedical,\n faAmbulance,\n faWheatAwnCircleExclamation,\n faSnowman,\n faMortarPestle,\n faRoadBarrier,\n faSchool,\n faIgloo,\n faJoint,\n faAngleRight,\n faHorse,\n faQ,\n faG,\n faNotesMedical,\n faTemperatureHalf,\n faTemperature2,\n faThermometer2,\n faThermometerHalf,\n faDongSign,\n faCapsules,\n faPooStorm,\n faPooBolt,\n faFaceFrownOpen,\n faFrownOpen,\n faHandPointUp,\n faMoneyBill,\n faBookmark,\n faAlignJustify,\n faUmbrellaBeach,\n faHelmetUn,\n faBullseye,\n faBacon,\n faHandPointDown,\n faArrowUpFromBracket,\n faFolder,\n faFolderBlank,\n faFileWaveform,\n faFileMedicalAlt,\n faRadiation,\n faChartSimple,\n faMarsStroke,\n faVial,\n faGauge,\n faDashboard,\n faGaugeMed,\n faTachometerAltAverage,\n faWandMagicSparkles,\n faMagicWandSparkles,\n faE,\n faPenClip,\n faPenAlt,\n faBridgeCircleExclamation,\n faUser,\n faSchoolCircleCheck,\n faDumpster,\n faVanShuttle,\n faShuttleVan,\n faBuildingUser,\n faSquareCaretLeft,\n faCaretSquareLeft,\n faHighlighter,\n faKey,\n faBullhorn,\n faGlobe,\n faSynagogue,\n faPersonHalfDress,\n faRoadBridge,\n faLocationArrow,\n faC,\n faTabletButton,\n faBuildingLock,\n faPizzaSlice,\n faMoneyBillWave,\n faChartArea,\n faAreaChart,\n faHouseFlag,\n faPersonCircleMinus,\n faBan,\n faCancel,\n faCameraRotate,\n faSprayCanSparkles,\n faAirFreshener,\n faStar,\n faRepeat,\n faCross,\n faBox,\n faVenusMars,\n faArrowPointer,\n faMousePointer,\n faMaximize,\n faExpandArrowsAlt,\n faChargingStation,\n faShapes,\n faTriangleCircleSquare,\n faShuffle,\n faRandom,\n faPersonRunning,\n faRunning,\n faMobileRetro,\n faGripLinesVertical,\n faSpider,\n faHandsBound,\n faFileInvoiceDollar,\n faPlaneCircleExclamation,\n faXRay,\n faSpellCheck,\n faSlash,\n faComputerMouse,\n faMouse,\n faArrowRightToBracket,\n faSignIn,\n faShopSlash,\n faStoreAltSlash,\n faServer,\n faVirusCovidSlash,\n faShopLock,\n faHourglassStart,\n faHourglass1,\n faBlenderPhone,\n faBuildingWheat,\n faPersonBreastfeeding,\n faRightToBracket,\n faSignInAlt,\n faVenus,\n faPassport,\n faThumbtackSlash,\n faThumbTackSlash,\n faHeartPulse,\n faHeartbeat,\n faPeopleCarryBox,\n faPeopleCarry,\n faTemperatureHigh,\n faMicrochip,\n faCrown,\n faWeightHanging,\n faXmarksLines,\n faFilePrescription,\n faWeightScale,\n faWeight,\n faUserGroup,\n faUserFriends,\n faArrowUpAZ,\n faSortAlphaUp,\n faChessKnight,\n faFaceLaughSquint,\n faLaughSquint,\n faWheelchair,\n faCircleArrowUp,\n faArrowCircleUp,\n faToggleOn,\n faPersonWalking,\n faWalking,\n faL,\n faFire,\n faBedPulse,\n faProcedures,\n faShuttleSpace,\n faSpaceShuttle,\n faFaceLaugh,\n faLaugh,\n faFolderOpen,\n faHeartCirclePlus,\n faCodeFork,\n faCity,\n faMicrophoneLines,\n faMicrophoneAlt,\n faPepperHot,\n faUnlock,\n faColonSign,\n faHeadset,\n faStoreSlash,\n faRoadCircleXmark,\n faUserMinus,\n faMarsStrokeUp,\n faMarsStrokeV,\n faChampagneGlasses,\n faGlassCheers,\n faClipboard,\n faHouseCircleExclamation,\n faFileArrowUp,\n faFileUpload,\n faWifi,\n faWifi3,\n faWifiStrong,\n faBath,\n faBathtub,\n faUnderline,\n faUserPen,\n faUserEdit,\n faSignature,\n faStroopwafel,\n faBold,\n faAnchorLock,\n faBuildingNgo,\n faManatSign,\n faNotEqual,\n faBorderTopLeft,\n faBorderStyle,\n faMapLocationDot,\n faMapMarkedAlt,\n faJedi,\n faSquarePollVertical,\n faPoll,\n faMugHot,\n faCarBattery,\n faBatteryCar,\n faGift,\n faDiceTwo,\n faChessQueen,\n faGlasses,\n faChessBoard,\n faBuildingCircleCheck,\n faPersonChalkboard,\n faMarsStrokeRight,\n faMarsStrokeH,\n faHandBackFist,\n faHandRock,\n faSquareCaretUp,\n faCaretSquareUp,\n faCloudShowersWater,\n faChartBar,\n faBarChart,\n faHandsBubbles,\n faHandsWash,\n faLessThanEqual,\n faTrain,\n faEyeLowVision,\n faLowVision,\n faCrow,\n faSailboat,\n faWindowRestore,\n faSquarePlus,\n faPlusSquare,\n faToriiGate,\n faFrog,\n faBucket,\n faImage,\n faMicrophone,\n faCow,\n faCaretUp,\n faScrewdriver,\n faFolderClosed,\n faHouseTsunami,\n faSquareNfi,\n faArrowUpFromGroundWater,\n faMartiniGlass,\n faGlassMartiniAlt,\n faSquareBinary,\n faRotateLeft,\n faRotateBack,\n faRotateBackward,\n faUndoAlt,\n faTableColumns,\n faColumns,\n faLemon,\n faHeadSideMask,\n faHandshake,\n faGem,\n faDolly,\n faDollyBox,\n faSmoking,\n faMinimize,\n faCompressArrowsAlt,\n faMonument,\n faSnowplow,\n faAnglesRight,\n faAngleDoubleRight,\n faCannabis,\n faCirclePlay,\n faPlayCircle,\n faTablets,\n faEthernet,\n faEuroSign,\n faEur,\n faEuro,\n faChair,\n faCircleCheck,\n faCheckCircle,\n faCircleStop,\n faStopCircle,\n faCompassDrafting,\n faDraftingCompass,\n faPlateWheat,\n faIcicles,\n faPersonShelter,\n faNeuter,\n faIdBadge,\n faMarker,\n faFaceLaughBeam,\n faLaughBeam,\n faHelicopterSymbol,\n faUniversalAccess,\n faCircleChevronUp,\n faChevronCircleUp,\n faLariSign,\n faVolcano,\n faPersonWalkingDashedLineArrowRight,\n faSterlingSign,\n faGbp,\n faPoundSign,\n faViruses,\n faSquarePersonConfined,\n faUserTie,\n faArrowDownLong,\n faLongArrowDown,\n faTentArrowDownToLine,\n faCertificate,\n faReplyAll,\n faMailReplyAll,\n faSuitcase,\n faPersonSkating,\n faSkating,\n faFilterCircleDollar,\n faFunnelDollar,\n faCameraRetro,\n faCircleArrowDown,\n faArrowCircleDown,\n faFileImport,\n faArrowRightToFile,\n faSquareArrowUpRight,\n faExternalLinkSquare,\n faBoxOpen,\n faScroll,\n faSpa,\n faLocationPinLock,\n faPause,\n faHillAvalanche,\n faTemperatureEmpty,\n faTemperature0,\n faThermometer0,\n faThermometerEmpty,\n faBomb,\n faRegistered,\n faAddressCard,\n faContactCard,\n faVcard,\n faScaleUnbalancedFlip,\n faBalanceScaleRight,\n faSubscript,\n faDiamondTurnRight,\n faDirections,\n faBurst,\n faHouseLaptop,\n faLaptopHouse,\n faFaceTired,\n faTired,\n faMoneyBills,\n faSmog,\n faCrutch,\n faFontAwesome,\n faFontAwesomeFlag,\n faFontAwesomeLogoFull,\n faCloudArrowUp,\n faCloudUpload,\n faCloudUploadAlt,\n faPalette,\n faArrowsTurnRight,\n faVest,\n faFerry,\n faArrowsDownToPeople,\n faSeedling,\n faSprout,\n faLeftRight,\n faArrowsAltH,\n faBoxesPacking,\n faCircleArrowLeft,\n faArrowCircleLeft,\n faGroupArrowsRotate,\n faBowlFood,\n faCandyCane,\n faArrowDownWideShort,\n faSortAmountAsc,\n faSortAmountDown,\n faCloudBolt,\n faThunderstorm,\n faTextSlash,\n faRemoveFormat,\n faFaceSmileWink,\n faSmileWink,\n faFileWord,\n faFilePowerpoint,\n faArrowsLeftRight,\n faArrowsH,\n faHouseLock,\n faCloudArrowDown,\n faCloudDownload,\n faCloudDownloadAlt,\n faChildren,\n faChalkboard,\n faBlackboard,\n faUserLargeSlash,\n faUserAltSlash,\n faEnvelopeOpen,\n faHandshakeSimpleSlash,\n faHandshakeAltSlash,\n faMattressPillow,\n faGuaraniSign,\n faArrowsRotate,\n faRefresh,\n faSync,\n faFireExtinguisher,\n faCruzeiroSign,\n faGreaterThanEqual,\n faShieldHalved,\n faShieldAlt,\n faBookAtlas,\n faAtlas,\n faVirus,\n faEnvelopeCircleCheck,\n faLayerGroup,\n faArrowsToDot,\n faArchway,\n faHeartCircleCheck,\n faHouseChimneyCrack,\n faHouseDamage,\n faFileZipper,\n faFileArchive,\n faSquare,\n faMartiniGlassEmpty,\n faGlassMartini,\n faCouch,\n faCediSign,\n faItalic,\n faTableCellsColumnLock,\n faChurch,\n faCommentsDollar,\n faDemocrat,\n faZ,\n faPersonSkiing,\n faSkiing,\n faRoadLock,\n faA,\n faTemperatureArrowDown,\n faTemperatureDown,\n faFeatherPointed,\n faFeatherAlt,\n faP,\n faSnowflake,\n faNewspaper,\n faRectangleAd,\n faAd,\n faCircleArrowRight,\n faArrowCircleRight,\n faFilterCircleXmark,\n faLocust,\n faSort,\n faUnsorted,\n faListOl,\n faList12,\n faListNumeric,\n faPersonDressBurst,\n faMoneyCheckDollar,\n faMoneyCheckAlt,\n faVectorSquare,\n faBreadSlice,\n faLanguage,\n faFaceKissWinkHeart,\n faKissWinkHeart,\n faFilter,\n faQuestion,\n faFileSignature,\n faUpDownLeftRight,\n faArrowsAlt,\n faHouseChimneyUser,\n faHandHoldingHeart,\n faPuzzlePiece,\n faMoneyCheck,\n faStarHalfStroke,\n faStarHalfAlt,\n faCode,\n faWhiskeyGlass,\n faGlassWhiskey,\n faBuildingCircleExclamation,\n faMagnifyingGlassChart,\n faArrowUpRightFromSquare,\n faExternalLink,\n faCubesStacked,\n faWonSign,\n faKrw,\n faWon,\n faVirusCovid,\n faAustralSign,\n faF,\n faLeaf,\n faRoad,\n faTaxi,\n faCab,\n faPersonCirclePlus,\n faChartPie,\n faPieChart,\n faBoltLightning,\n faSackXmark,\n faFileExcel,\n faFileContract,\n faFishFins,\n faBuildingFlag,\n faFaceGrinBeam,\n faGrinBeam,\n faObjectUngroup,\n faPoop,\n faLocationPin,\n faMapMarker,\n faKaaba,\n faToiletPaper,\n faHelmetSafety,\n faHardHat,\n faHatHard,\n faEject,\n faCircleRight,\n faArrowAltCircleRight,\n faPlaneCircleCheck,\n faFaceRollingEyes,\n faMehRollingEyes,\n faObjectGroup,\n faChartLine,\n faLineChart,\n faMaskVentilator,\n faArrowRight,\n faSignsPost,\n faMapSigns,\n faCashRegister,\n faPersonCircleQuestion,\n faH,\n faTarp,\n faScrewdriverWrench,\n faTools,\n faArrowsToEye,\n faPlugCircleBolt,\n faHeart,\n faMarsAndVenus,\n faHouseUser,\n faHomeUser,\n faDumpsterFire,\n faHouseCrack,\n faMartiniGlassCitrus,\n faCocktail,\n faFaceSurprise,\n faSurprise,\n faBottleWater,\n faCirclePause,\n faPauseCircle,\n faToiletPaperSlash,\n faAppleWhole,\n faAppleAlt,\n faKitchenSet,\n faR,\n faTemperatureQuarter,\n faTemperature1,\n faThermometer1,\n faThermometerQuarter,\n faCube,\n faBitcoinSign,\n faShieldDog,\n faSolarPanel,\n faLockOpen,\n faElevator,\n faMoneyBillTransfer,\n faMoneyBillTrendUp,\n faHouseFloodWaterCircleArrowRight,\n faSquarePollHorizontal,\n faPollH,\n faCircle,\n faBackwardFast,\n faFastBackward,\n faRecycle,\n faUserAstronaut,\n faPlaneSlash,\n faTrademark,\n faBasketball,\n faBasketballBall,\n faSatelliteDish,\n faCircleUp,\n faArrowAltCircleUp,\n faMobileScreenButton,\n faMobileAlt,\n faVolumeHigh,\n faVolumeUp,\n faUsersRays,\n faWallet,\n faClipboardCheck,\n faFileAudio,\n faBurger,\n faHamburger,\n faWrench,\n faBugs,\n faRupeeSign,\n faRupee,\n faFileImage,\n faCircleQuestion,\n faQuestionCircle,\n faPlaneDeparture,\n faHandshakeSlash,\n faBookBookmark,\n faCodeBranch,\n faHatCowboy,\n faBridge,\n faPhoneFlip,\n faPhoneAlt,\n faTruckFront,\n faCat,\n faAnchorCircleExclamation,\n faTruckField,\n faRoute,\n faClipboardQuestion,\n faPanorama,\n faCommentMedical,\n faTeethOpen,\n faFileCircleMinus,\n faTags,\n faWineGlass,\n faForwardFast,\n faFastForward,\n faFaceMehBlank,\n faMehBlank,\n faSquareParking,\n faParking,\n faHouseSignal,\n faBarsProgress,\n faTasksAlt,\n faFaucetDrip,\n faCartFlatbed,\n faDollyFlatbed,\n faBanSmoking,\n faSmokingBan,\n faTerminal,\n faMobileButton,\n faHouseMedicalFlag,\n faBasketShopping,\n faShoppingBasket,\n faTape,\n faBusSimple,\n faBusAlt,\n faEye,\n faFaceSadCry,\n faSadCry,\n faAudioDescription,\n faPersonMilitaryToPerson,\n faFileShield,\n faUserSlash,\n faPen,\n faTowerObservation,\n faFileCode,\n faSignal,\n faSignal5,\n faSignalPerfect,\n faBus,\n faHeartCircleXmark,\n faHouseChimney,\n faHomeLg,\n faWindowMaximize,\n faFaceFrown,\n faFrown,\n faPrescription,\n faShop,\n faStoreAlt,\n faFloppyDisk,\n faSave,\n faVihara,\n faScaleUnbalanced,\n faBalanceScaleLeft,\n faSortUp,\n faSortAsc,\n faCommentDots,\n faCommenting,\n faPlantWilt,\n faDiamond,\n faFaceGrinSquint,\n faGrinSquint,\n faHandHoldingDollar,\n faHandHoldingUsd,\n faChartDiagram,\n faBacterium,\n faHandPointer,\n faDrumSteelpan,\n faHandScissors,\n faHandsPraying,\n faPrayingHands,\n faArrowRotateRight,\n faArrowRightRotate,\n faArrowRotateForward,\n faRedo,\n faWebAwesome,\n faBiohazard,\n faLocationCrosshairs,\n faLocation,\n faMarsDouble,\n faChildDress,\n faUsersBetweenLines,\n faLungsVirus,\n faFaceGrinTears,\n faGrinTears,\n faPhone,\n faCalendarXmark,\n faCalendarTimes,\n faChildReaching,\n faHeadSideVirus,\n faUserGear,\n faUserCog,\n faArrowUp19,\n faSortNumericUp,\n faDoorClosed,\n faShieldVirus,\n faDiceSix,\n faMosquitoNet,\n faFileFragment,\n faBridgeWater,\n faPersonBooth,\n faTextWidth,\n faHatWizard,\n faPenFancy,\n faPersonDigging,\n faDigging,\n faTrash,\n faGaugeSimple,\n faGaugeSimpleMed,\n faTachometerAverage,\n faBookMedical,\n faPoo,\n faQuoteRight,\n faQuoteRightAlt,\n faShirt,\n faTShirt,\n faTshirt,\n faCubes,\n faDivide,\n faTengeSign,\n faTenge,\n faHeadphones,\n faHandsHolding,\n faHandsClapping,\n faRepublican,\n faArrowLeft,\n faPersonCircleXmark,\n faRuler,\n faAlignLeft,\n faDiceD6,\n faRestroom,\n faJ,\n faUsersViewfinder,\n faFileVideo,\n faUpRightFromSquare,\n faExternalLinkAlt,\n faTableCells,\n faTh,\n faFilePdf,\n faBookBible,\n faBible,\n faO,\n faSuitcaseMedical,\n faMedkit,\n faUserSecret,\n faOtter,\n faPersonDress,\n faFemale,\n faCommentDollar,\n faBusinessTime,\n faBriefcaseClock,\n faTableCellsLarge,\n faThLarge,\n faBookTanakh,\n faTanakh,\n faPhoneVolume,\n faVolumeControlPhone,\n faHatCowboySide,\n faClipboardUser,\n faChild,\n faLiraSign,\n faSatellite,\n faPlaneLock,\n faTag,\n faComment,\n faCakeCandles,\n faBirthdayCake,\n faCake,\n faEnvelope,\n faAnglesUp,\n faAngleDoubleUp,\n faPaperclip,\n faArrowRightToCity,\n faRibbon,\n faLungs,\n faArrowUp91,\n faSortNumericUpAlt,\n faLitecoinSign,\n faBorderNone,\n faCircleNodes,\n faParachuteBox,\n faIndent,\n faTruckFieldUn,\n faHourglass,\n faHourglassEmpty,\n faMountain,\n faUserDoctor,\n faUserMd,\n faCircleInfo,\n faInfoCircle,\n faCloudMeatball,\n faCamera,\n faCameraAlt,\n faSquareVirus,\n faMeteor,\n faCarOn,\n faSleigh,\n faArrowDown19,\n faSortNumericAsc,\n faSortNumericDown,\n faHandHoldingDroplet,\n faHandHoldingWater,\n faWater,\n faCalendarCheck,\n faBraille,\n faPrescriptionBottleMedical,\n faPrescriptionBottleAlt,\n faLandmark,\n faTruck,\n faCrosshairs,\n faPersonCane,\n faTent,\n faVestPatches,\n faCheckDouble,\n faArrowDownAZ,\n faSortAlphaAsc,\n faSortAlphaDown,\n faMoneyBillWheat,\n faCookie,\n faArrowRotateLeft,\n faArrowLeftRotate,\n faArrowRotateBack,\n faArrowRotateBackward,\n faUndo,\n faHardDrive,\n faHdd,\n faFaceGrinSquintTears,\n faGrinSquintTears,\n faDumbbell,\n faRectangleList,\n faListAlt,\n faTarpDroplet,\n faHouseMedicalCircleCheck,\n faPersonSkiingNordic,\n faSkiingNordic,\n faCalendarPlus,\n faPlaneArrival,\n faCircleLeft,\n faArrowAltCircleLeft,\n faTrainSubway,\n faSubway,\n faChartGantt,\n faIndianRupeeSign,\n faIndianRupee,\n faInr,\n faCropSimple,\n faCropAlt,\n faMoneyBill1,\n faMoneyBillAlt,\n faLeftLong,\n faLongArrowAltLeft,\n faDna,\n faVirusSlash,\n faMinus,\n faSubtract,\n faChess,\n faArrowLeftLong,\n faLongArrowLeft,\n faPlugCircleCheck,\n faStreetView,\n faFrancSign,\n faVolumeOff,\n faHandsAslInterpreting,\n faAmericanSignLanguageInterpreting,\n faAslInterpreting,\n faHandsAmericanSignLanguageInterpreting,\n faGear,\n faCog,\n faDropletSlash,\n faTintSlash,\n faMosque,\n faMosquito,\n faStarOfDavid,\n faPersonMilitaryRifle,\n faCartShopping,\n faShoppingCart,\n faVials,\n faPlugCirclePlus,\n faPlaceOfWorship,\n faGripVertical,\n faHexagonNodes,\n faArrowTurnUp,\n faLevelUp,\n faU,\n faSquareRootVariable,\n faSquareRootAlt,\n faClock,\n faClockFour,\n faBackwardStep,\n faStepBackward,\n faPallet,\n faFaucet,\n faBaseballBatBall,\n faS,\n faTimeline,\n faKeyboard,\n faCaretDown,\n faHouseChimneyMedical,\n faClinicMedical,\n faTemperatureThreeQuarters,\n faTemperature3,\n faThermometer3,\n faThermometerThreeQuarters,\n faMobileScreen,\n faMobileAndroidAlt,\n faPlaneUp,\n faPiggyBank,\n faBatteryHalf,\n faBattery3,\n faMountainCity,\n faCoins,\n faKhanda,\n faSliders,\n faSlidersH,\n faFolderTree,\n faNetworkWired,\n faMapPin,\n faHamsa,\n faCentSign,\n faFlask,\n faPersonPregnant,\n faWandSparkles,\n faEllipsisVertical,\n faEllipsisV,\n faTicket,\n faPowerOff,\n faRightLong,\n faLongArrowAltRight,\n faFlagUsa,\n faLaptopFile,\n faTty,\n faTeletype,\n faDiagramNext,\n faPersonRifle,\n faHouseMedicalCircleExclamation,\n faClosedCaptioning,\n faPersonHiking,\n faHiking,\n faVenusDouble,\n faImages,\n faCalculator,\n faPeoplePulling,\n faN,\n faCableCar,\n faTram,\n faCloudRain,\n faBuildingCircleXmark,\n faShip,\n faArrowsDownToLine,\n faDownload,\n faFaceGrin,\n faGrin,\n faDeleteLeft,\n faBackspace,\n faEyeDropper,\n faEyeDropperEmpty,\n faEyedropper,\n faFileCircleCheck,\n faForward,\n faMobile,\n faMobileAndroid,\n faMobilePhone,\n faFaceMeh,\n faMeh,\n faAlignCenter,\n faBookSkull,\n faBookDead,\n faIdCard,\n faDriversLicense,\n faOutdent,\n faDedent,\n faHeartCircleExclamation,\n faHouse,\n faHome,\n faHomeAlt,\n faHomeLgAlt,\n faCalendarWeek,\n faLaptopMedical,\n faB,\n faFileMedical,\n faDiceOne,\n faKiwiBird,\n faArrowRightArrowLeft,\n faExchange,\n faRotateRight,\n faRedoAlt,\n faRotateForward,\n faUtensils,\n faCutlery,\n faArrowUpWideShort,\n faSortAmountUp,\n faMillSign,\n faBowlRice,\n faSkull,\n faTowerBroadcast,\n faBroadcastTower,\n faTruckPickup,\n faUpLong,\n faLongArrowAltUp,\n faStop,\n faCodeMerge,\n faUpload,\n faHurricane,\n faMound,\n faToiletPortable,\n faCompactDisc,\n faFileArrowDown,\n faFileDownload,\n faCaravan,\n faShieldCat,\n faBolt,\n faZap,\n faGlassWater,\n faOilWell,\n faVault,\n faMars,\n faToilet,\n faPlaneCircleXmark,\n faYenSign,\n faCny,\n faJpy,\n faRmb,\n faYen,\n faRubleSign,\n faRouble,\n faRub,\n faRuble,\n faSun,\n faGuitar,\n faFaceLaughWink,\n faLaughWink,\n faHorseHead,\n faBoreHole,\n faIndustry,\n faCircleDown,\n faArrowAltCircleDown,\n faArrowsTurnToDots,\n faFlorinSign,\n faArrowDownShortWide,\n faSortAmountDesc,\n faSortAmountDownAlt,\n faLessThan,\n faAngleDown,\n faCarTunnel,\n faHeadSideCough,\n faGripLines,\n faThumbsDown,\n faUserLock,\n faArrowRightLong,\n faLongArrowRight,\n faAnchorCircleXmark,\n faEllipsis,\n faEllipsisH,\n faChessPawn,\n faKitMedical,\n faFirstAid,\n faPersonThroughWindow,\n faToolbox,\n faHandsHoldingCircle,\n faBug,\n faCreditCard,\n faCreditCardAlt,\n faCar,\n faAutomobile,\n faHandHoldingHand,\n faBookOpenReader,\n faBookReader,\n faMountainSun,\n faArrowsLeftRightToLine,\n faDiceD20,\n faTruckDroplet,\n faFileCircleXmark,\n faTemperatureArrowUp,\n faTemperatureUp,\n faMedal,\n faBed,\n faSquareH,\n faHSquare,\n faPodcast,\n faTemperatureFull,\n faTemperature4,\n faThermometer4,\n faThermometerFull,\n faBell,\n faSuperscript,\n faPlugCircleXmark,\n faStarOfLife,\n faPhoneSlash,\n faPaintRoller,\n faHandshakeAngle,\n faHandsHelping,\n faLocationDot,\n faMapMarkerAlt,\n faFile,\n faGreaterThan,\n faPersonSwimming,\n faSwimmer,\n faArrowDown,\n faDroplet,\n faTint,\n faEraser,\n faEarthAmericas,\n faEarth,\n faEarthAmerica,\n faGlobeAmericas,\n faPersonBurst,\n faDove,\n faBatteryEmpty,\n faBattery0,\n faSocks,\n faInbox,\n faSection,\n faGaugeHigh,\n faTachometerAlt,\n faTachometerAltFast,\n faEnvelopeOpenText,\n faHospital,\n faHospitalAlt,\n faHospitalWide,\n faWineBottle,\n faChessRook,\n faBarsStaggered,\n faReorder,\n faStream,\n faDharmachakra,\n faHotdog,\n faPersonWalkingWithCane,\n faBlind,\n faDrum,\n faIceCream,\n faHeartCircleBolt,\n faFax,\n faParagraph,\n faCheckToSlot,\n faVoteYea,\n faStarHalf,\n faBoxesStacked,\n faBoxes,\n faBoxesAlt,\n faLink,\n faChain,\n faEarListen,\n faAssistiveListeningSystems,\n faTreeCity,\n faPlay,\n faFont,\n faTableCellsRowLock,\n faRupiahSign,\n faMagnifyingGlass,\n faSearch,\n faTableTennisPaddleBall,\n faPingPongPaddleBall,\n faTableTennis,\n faPersonDotsFromLine,\n faDiagnoses,\n faTrashCanArrowUp,\n faTrashRestoreAlt,\n faNairaSign,\n faCartArrowDown,\n faWalkieTalkie,\n faFilePen,\n faFileEdit,\n faReceipt,\n faSquarePen,\n faPenSquare,\n faPencilSquare,\n faSuitcaseRolling,\n faPersonCircleExclamation,\n faChevronDown,\n faBatteryFull,\n faBattery,\n faBattery5,\n faSkullCrossbones,\n faCodeCompare,\n faListUl,\n faListDots,\n faSchoolLock,\n faTowerCell,\n faDownLong,\n faLongArrowAltDown,\n faRankingStar,\n faChessKing,\n faPersonHarassing,\n faBrazilianRealSign,\n faLandmarkDome,\n faLandmarkAlt,\n faArrowUp,\n faTv,\n faTelevision,\n faTvAlt,\n faShrimp,\n faListCheck,\n faTasks,\n faJugDetergent,\n faCircleUser,\n faUserCircle,\n faUserShield,\n faWind,\n faCarBurst,\n faCarCrash,\n faY,\n faPersonSnowboarding,\n faSnowboarding,\n faTruckFast,\n faShippingFast,\n faFish,\n faUserGraduate,\n faCircleHalfStroke,\n faAdjust,\n faClapperboard,\n faCircleRadiation,\n faRadiationAlt,\n faBaseball,\n faBaseballBall,\n faJetFighterUp,\n faDiagramProject,\n faProjectDiagram,\n faCopy,\n faVolumeXmark,\n faVolumeMute,\n faVolumeTimes,\n faHandSparkles,\n faGrip,\n faGripHorizontal,\n faShareFromSquare,\n faShareSquare,\n faChildCombatant,\n faChildRifle,\n faGun,\n faSquarePhone,\n faPhoneSquare,\n faPlus,\n faAdd,\n faExpand,\n faComputer,\n faXmark,\n faClose,\n faMultiply,\n faRemove,\n faTimes,\n faArrowsUpDownLeftRight,\n faArrows,\n faChalkboardUser,\n faChalkboardTeacher,\n faPesoSign,\n faBuildingShield,\n faBaby,\n faUsersLine,\n faQuoteLeft,\n faQuoteLeftAlt,\n faTractor,\n faTrashArrowUp,\n faTrashRestore,\n faArrowDownUpLock,\n faLinesLeaning,\n faRulerCombined,\n faCopyright,\n faEquals,\n faBlender,\n faTeeth,\n faShekelSign,\n faIls,\n faShekel,\n faSheqel,\n faSheqelSign,\n faMap,\n faRocket,\n faPhotoFilm,\n faPhotoVideo,\n faFolderMinus,\n faHexagonNodesBolt,\n faStore,\n faArrowTrendUp,\n faPlugCircleMinus,\n faSignHanging,\n faSign,\n faBezierCurve,\n faBellSlash,\n faTablet,\n faTabletAndroid,\n faSchoolFlag,\n faFill,\n faAngleUp,\n faDrumstickBite,\n faHollyBerry,\n faChevronLeft,\n faBacteria,\n faHandLizard,\n faNotdef,\n faDisease,\n faBriefcaseMedical,\n faGenderless,\n faChevronRight,\n faRetweet,\n faCarRear,\n faCarAlt,\n faPumpSoap,\n faVideoSlash,\n faBatteryQuarter,\n faBattery2,\n faRadio,\n faBabyCarriage,\n faCarriageBaby,\n faTrafficLight,\n faThermometer,\n faVrCardboard,\n faHandMiddleFinger,\n faPercent,\n faPercentage,\n faTruckMoving,\n faGlassWaterDroplet,\n faDisplay,\n faFaceSmile,\n faSmile,\n faThumbtack,\n faThumbTack,\n faTrophy,\n faPersonPraying,\n faPray,\n faHammer,\n faHandPeace,\n faRotate,\n faSyncAlt,\n faSpinner,\n faRobot,\n faPeace,\n faGears,\n faCogs,\n faWarehouse,\n faArrowUpRightDots,\n faSplotch,\n faFaceGrinHearts,\n faGrinHearts,\n faDiceFour,\n faSimCard,\n faTransgender,\n faTransgenderAlt,\n faMercury,\n faArrowTurnDown,\n faLevelDown,\n faPersonFallingBurst,\n faAward,\n faTicketSimple,\n faTicketAlt,\n faBuilding,\n faAnglesLeft,\n faAngleDoubleLeft,\n faQrcode,\n faClockRotateLeft,\n faHistory,\n faFaceGrinBeamSweat,\n faGrinBeamSweat,\n faFileExport,\n faArrowRightFromFile,\n faShield,\n faShieldBlank,\n faArrowUpShortWide,\n faSortAmountUpAlt,\n faCommentNodes,\n faHouseMedical,\n faGolfBallTee,\n faGolfBall,\n faCircleChevronLeft,\n faChevronCircleLeft,\n faHouseChimneyWindow,\n faPenNib,\n faTentArrowTurnLeft,\n faTents,\n faWandMagic,\n faMagic,\n faDog,\n faCarrot,\n faMoon,\n faWineGlassEmpty,\n faWineGlassAlt,\n faCheese,\n faYinYang,\n faMusic,\n faCodeCommit,\n faTemperatureLow,\n faPersonBiking,\n faBiking,\n faBroom,\n faShieldHeart,\n faGopuram,\n faEarthOceania,\n faGlobeOceania,\n faSquareXmark,\n faTimesSquare,\n faXmarkSquare,\n faHashtag,\n faUpRightAndDownLeftFromCenter,\n faExpandAlt,\n faOilCan,\n faT,\n faHippo,\n faChartColumn,\n faInfinity,\n faVialCircleCheck,\n faPersonArrowDownToLine,\n faVoicemail,\n faFan,\n faPersonWalkingLuggage,\n faUpDown,\n faArrowsAltV,\n faCloudMoonRain,\n faCalendar,\n faTrailer,\n faBahai,\n faHaykal,\n faSdCard,\n faDragon,\n faShoePrints,\n faCirclePlus,\n faPlusCircle,\n faFaceGrinTongueWink,\n faGrinTongueWink,\n faHandHolding,\n faPlugCircleExclamation,\n faLinkSlash,\n faChainBroken,\n faChainSlash,\n faUnlink,\n faClone,\n faPersonWalkingArrowLoopLeft,\n faArrowUpZA,\n faSortAlphaUpAlt,\n faFireFlameCurved,\n faFireAlt,\n faTornado,\n faFileCirclePlus,\n faBookQuran,\n faQuran,\n faAnchor,\n faBorderAll,\n faFaceAngry,\n faAngry,\n faCookieBite,\n faArrowTrendDown,\n faRss,\n faFeed,\n faDrawPolygon,\n faScaleBalanced,\n faBalanceScale,\n faGaugeSimpleHigh,\n faTachometer,\n faTachometerFast,\n faShower,\n faDesktop,\n faDesktopAlt,\n faM,\n faTableList,\n faThList,\n faCommentSms,\n faSms,\n faBook,\n faUserPlus,\n faCheck,\n faBatteryThreeQuarters,\n faBattery4,\n faHouseCircleCheck,\n faAngleLeft,\n faDiagramSuccessor,\n faTruckArrowRight,\n faArrowsSplitUpAndLeft,\n faHandFist,\n faFistRaised,\n faCloudMoon,\n faBriefcase,\n faPersonFalling,\n faImagePortrait,\n faPortrait,\n faUserTag,\n faRug,\n faEarthEurope,\n faGlobeEurope,\n faCartFlatbedSuitcase,\n faLuggageCart,\n faRectangleXmark,\n faRectangleTimes,\n faTimesRectangle,\n faWindowClose,\n faBahtSign,\n faBookOpen,\n faBookJournalWhills,\n faJournalWhills,\n faHandcuffs,\n faTriangleExclamation,\n faExclamationTriangle,\n faWarning,\n faDatabase,\n faShare,\n faMailForward,\n faBottleDroplet,\n faMaskFace,\n faHillRockslide,\n faRightLeft,\n faExchangeAlt,\n faPaperPlane,\n faRoadCircleExclamation,\n faDungeon,\n faAlignRight,\n faMoneyBill1Wave,\n faMoneyBillWaveAlt,\n faLifeRing,\n faHands,\n faSignLanguage,\n faSigning,\n faCalendarDay,\n faWaterLadder,\n faLadderWater,\n faSwimmingPool,\n faArrowsUpDown,\n faArrowsV,\n faFaceGrimace,\n faGrimace,\n faWheelchairMove,\n faWheelchairAlt,\n faTurnDown,\n faLevelDownAlt,\n faPersonWalkingArrowRight,\n faSquareEnvelope,\n faEnvelopeSquare,\n faDice,\n faBowlingBall,\n faBrain,\n faBandage,\n faBandAid,\n faCalendarMinus,\n faCircleXmark,\n faTimesCircle,\n faXmarkCircle,\n faGifts,\n faHotel,\n faEarthAsia,\n faGlobeAsia,\n faIdCardClip,\n faIdCardAlt,\n faMagnifyingGlassPlus,\n faSearchPlus,\n faThumbsUp,\n faUserClock,\n faHandDots,\n faAllergies,\n faFileInvoice,\n faWindowMinimize,\n faMugSaucer,\n faCoffee,\n faBrush,\n faFileHalfDashed,\n faMask,\n faMagnifyingGlassMinus,\n faSearchMinus,\n faRulerVertical,\n faUserLarge,\n faUserAlt,\n faTrainTram,\n faUserNurse,\n faSyringe,\n faCloudSun,\n faStopwatch20,\n faSquareFull,\n faMagnet,\n faJar,\n faNoteSticky,\n faStickyNote,\n faBugSlash,\n faArrowUpFromWaterPump,\n faBone,\n faTableCellsRowUnlock,\n faUserInjured,\n faFaceSadTear,\n faSadTear,\n faPlane,\n faTentArrowsDown,\n faExclamation,\n faArrowsSpin,\n faPrint,\n faTurkishLiraSign,\n faTry,\n faTurkishLira,\n faDollarSign,\n faDollar,\n faUsd,\n faX,\n faMagnifyingGlassDollar,\n faSearchDollar,\n faUsersGear,\n faUsersCog,\n faPersonMilitaryPointing,\n faBuildingColumns,\n faBank,\n faInstitution,\n faMuseum,\n faUniversity,\n faUmbrella,\n faTrowel,\n faD,\n faStapler,\n faMasksTheater,\n faTheaterMasks,\n faKipSign,\n faHandPointLeft,\n faHandshakeSimple,\n faHandshakeAlt,\n faJetFighter,\n faFighterJet,\n faSquareShareNodes,\n faShareAltSquare,\n faBarcode,\n faPlusMinus,\n faVideo,\n faVideoCamera,\n faGraduationCap,\n faMortarBoard,\n faHandHoldingMedical,\n faPersonCircleCheck,\n faTurnUp,\n faLevelUpAlt\n};\n\nexport { icons as fas, prefix, fa0, fa1, fa2, fa3, fa4, fa5, fa6, fa7, fa8, fa9, faFillDrip, faArrowsToCircle, faCircleChevronRight, faChevronCircleRight, faAt, faTrashCan, faTrashAlt, faTextHeight, faUserXmark, faUserTimes, faStethoscope, faMessage, faCommentAlt, faInfo, faDownLeftAndUpRightToCenter, faCompressAlt, faExplosion, faFileLines, faFileAlt, faFileText, faWaveSquare, faRing, faBuildingUn, faDiceThree, faCalendarDays, faCalendarAlt, faAnchorCircleCheck, faBuildingCircleArrowRight, faVolleyball, faVolleyballBall, faArrowsUpToLine, faSortDown, faSortDesc, faCircleMinus, faMinusCircle, faDoorOpen, faRightFromBracket, faSignOutAlt, faAtom, faSoap, faIcons, faHeartMusicCameraBolt, faMicrophoneLinesSlash, faMicrophoneAltSlash, faBridgeCircleCheck, faPumpMedical, faFingerprint, faHandPointRight, faMagnifyingGlassLocation, faSearchLocation, faForwardStep, faStepForward, faFaceSmileBeam, faSmileBeam, faFlagCheckered, faFootball, faFootballBall, faSchoolCircleExclamation, faCrop, faAnglesDown, faAngleDoubleDown, faUsersRectangle, faPeopleRoof, faPeopleLine, faBeerMugEmpty, faBeer, faDiagramPredecessor, faArrowUpLong, faLongArrowUp, faFireFlameSimple, faBurn, faPerson, faMale, faLaptop, faFileCsv, faMenorah, faTruckPlane, faRecordVinyl, faFaceGrinStars, faGrinStars, faBong, faSpaghettiMonsterFlying, faPastafarianism, faArrowDownUpAcrossLine, faSpoon, faUtensilSpoon, faJarWheat, faEnvelopesBulk, faMailBulk, faFileCircleExclamation, faCircleH, faHospitalSymbol, faPager, faAddressBook, faContactBook, faStrikethrough, faK, faLandmarkFlag, faPencil, faPencilAlt, faBackward, faCaretRight, faComments, faPaste, faFileClipboard, faCodePullRequest, faClipboardList, faTruckRampBox, faTruckLoading, faUserCheck, faVialVirus, faSheetPlastic, faBlog, faUserNinja, faPersonArrowUpFromLine, faScrollTorah, faTorah, faBroomBall, faQuidditch, faQuidditchBroomBall, faToggleOff, faBoxArchive, faArchive, faPersonDrowning, faArrowDown91, faSortNumericDesc, faSortNumericDownAlt, faFaceGrinTongueSquint, faGrinTongueSquint, faSprayCan, faTruckMonster, faW, faEarthAfrica, faGlobeAfrica, faRainbow, faCircleNotch, faTabletScreenButton, faTabletAlt, faPaw, faCloud, faTrowelBricks, faFaceFlushed, faFlushed, faHospitalUser, faTentArrowLeftRight, faGavel, faLegal, faBinoculars, faMicrophoneSlash, faBoxTissue, faMotorcycle, faBellConcierge, faConciergeBell, faPenRuler, faPencilRuler, faPeopleArrows, faPeopleArrowsLeftRight, faMarsAndVenusBurst, faSquareCaretRight, faCaretSquareRight, faScissors, faCut, faSunPlantWilt, faToiletsPortable, faHockeyPuck, faTable, faMagnifyingGlassArrowRight, faTachographDigital, faDigitalTachograph, faUsersSlash, faClover, faReply, faMailReply, faStarAndCrescent, faHouseFire, faSquareMinus, faMinusSquare, faHelicopter, faCompass, faSquareCaretDown, faCaretSquareDown, faFileCircleQuestion, faLaptopCode, faSwatchbook, faPrescriptionBottle, faBars, faNavicon, faPeopleGroup, faHourglassEnd, faHourglass3, faHeartCrack, faHeartBroken, faSquareUpRight, faExternalLinkSquareAlt, faFaceKissBeam, faKissBeam, faFilm, faRulerHorizontal, faPeopleRobbery, faLightbulb, faCaretLeft, faCircleExclamation, faExclamationCircle, faSchoolCircleXmark, faArrowRightFromBracket, faSignOut, faCircleChevronDown, faChevronCircleDown, faUnlockKeyhole, faUnlockAlt, faCloudShowersHeavy, faHeadphonesSimple, faHeadphonesAlt, faSitemap, faCircleDollarToSlot, faDonate, faMemory, faRoadSpikes, faFireBurner, faFlag, faHanukiah, faFeather, faVolumeLow, faVolumeDown, faCommentSlash, faCloudSunRain, faCompress, faWheatAwn, faWheatAlt, faAnkh, faHandsHoldingChild, faAsterisk, faSquareCheck, faCheckSquare, faPesetaSign, faHeading, faHeader, faGhost, faList, faListSquares, faSquarePhoneFlip, faPhoneSquareAlt, faCartPlus, faGamepad, faCircleDot, faDotCircle, faFaceDizzy, faDizzy, faEgg, faHouseMedicalCircleXmark, faCampground, faFolderPlus, faFutbol, faFutbolBall, faSoccerBall, faPaintbrush, faPaintBrush, faLock, faGasPump, faHotTubPerson, faHotTub, faMapLocation, faMapMarked, faHouseFloodWater, faTree, faBridgeLock, faSackDollar, faPenToSquare, faEdit, faCarSide, faShareNodes, faShareAlt, faHeartCircleMinus, faHourglassHalf, faHourglass2, faMicroscope, faSink, faBagShopping, faShoppingBag, faArrowDownZA, faSortAlphaDesc, faSortAlphaDownAlt, faMitten, faPersonRays, faUsers, faEyeSlash, faFlaskVial, faHand, faHandPaper, faOm, faWorm, faHouseCircleXmark, faPlug, faChevronUp, faHandSpock, faStopwatch, faFaceKiss, faKiss, faBridgeCircleXmark, faFaceGrinTongue, faGrinTongue, faChessBishop, faFaceGrinWink, faGrinWink, faEarDeaf, faDeaf, faDeafness, faHardOfHearing, faRoadCircleCheck, faDiceFive, faSquareRss, faRssSquare, faLandMineOn, faICursor, faStamp, faStairs, faI, faHryvniaSign, faHryvnia, faPills, faFaceGrinWide, faGrinAlt, faTooth, faV, faBangladeshiTakaSign, faBicycle, faStaffSnake, faRodAsclepius, faRodSnake, faStaffAesculapius, faHeadSideCoughSlash, faTruckMedical, faAmbulance, faWheatAwnCircleExclamation, faSnowman, faMortarPestle, faRoadBarrier, faSchool, faIgloo, faJoint, faAngleRight, faHorse, faQ, faG, faNotesMedical, faTemperatureHalf, faTemperature2, faThermometer2, faThermometerHalf, faDongSign, faCapsules, faPooStorm, faPooBolt, faFaceFrownOpen, faFrownOpen, faHandPointUp, faMoneyBill, faBookmark, faAlignJustify, faUmbrellaBeach, faHelmetUn, faBullseye, faBacon, faHandPointDown, faArrowUpFromBracket, faFolder, faFolderBlank, faFileWaveform, faFileMedicalAlt, faRadiation, faChartSimple, faMarsStroke, faVial, faGauge, faDashboard, faGaugeMed, faTachometerAltAverage, faWandMagicSparkles, faMagicWandSparkles, faE, faPenClip, faPenAlt, faBridgeCircleExclamation, faUser, faSchoolCircleCheck, faDumpster, faVanShuttle, faShuttleVan, faBuildingUser, faSquareCaretLeft, faCaretSquareLeft, faHighlighter, faKey, faBullhorn, faGlobe, faSynagogue, faPersonHalfDress, faRoadBridge, faLocationArrow, faC, faTabletButton, faBuildingLock, faPizzaSlice, faMoneyBillWave, faChartArea, faAreaChart, faHouseFlag, faPersonCircleMinus, faBan, faCancel, faCameraRotate, faSprayCanSparkles, faAirFreshener, faStar, faRepeat, faCross, faBox, faVenusMars, faArrowPointer, faMousePointer, faMaximize, faExpandArrowsAlt, faChargingStation, faShapes, faTriangleCircleSquare, faShuffle, faRandom, faPersonRunning, faRunning, faMobileRetro, faGripLinesVertical, faSpider, faHandsBound, faFileInvoiceDollar, faPlaneCircleExclamation, faXRay, faSpellCheck, faSlash, faComputerMouse, faMouse, faArrowRightToBracket, faSignIn, faShopSlash, faStoreAltSlash, faServer, faVirusCovidSlash, faShopLock, faHourglassStart, faHourglass1, faBlenderPhone, faBuildingWheat, faPersonBreastfeeding, faRightToBracket, faSignInAlt, faVenus, faPassport, faThumbtackSlash, faThumbTackSlash, faHeartPulse, faHeartbeat, faPeopleCarryBox, faPeopleCarry, faTemperatureHigh, faMicrochip, faCrown, faWeightHanging, faXmarksLines, faFilePrescription, faWeightScale, faWeight, faUserGroup, faUserFriends, faArrowUpAZ, faSortAlphaUp, faChessKnight, faFaceLaughSquint, faLaughSquint, faWheelchair, faCircleArrowUp, faArrowCircleUp, faToggleOn, faPersonWalking, faWalking, faL, faFire, faBedPulse, faProcedures, faShuttleSpace, faSpaceShuttle, faFaceLaugh, faLaugh, faFolderOpen, faHeartCirclePlus, faCodeFork, faCity, faMicrophoneLines, faMicrophoneAlt, faPepperHot, faUnlock, faColonSign, faHeadset, faStoreSlash, faRoadCircleXmark, faUserMinus, faMarsStrokeUp, faMarsStrokeV, faChampagneGlasses, faGlassCheers, faClipboard, faHouseCircleExclamation, faFileArrowUp, faFileUpload, faWifi, faWifi3, faWifiStrong, faBath, faBathtub, faUnderline, faUserPen, faUserEdit, faSignature, faStroopwafel, faBold, faAnchorLock, faBuildingNgo, faManatSign, faNotEqual, faBorderTopLeft, faBorderStyle, faMapLocationDot, faMapMarkedAlt, faJedi, faSquarePollVertical, faPoll, faMugHot, faCarBattery, faBatteryCar, faGift, faDiceTwo, faChessQueen, faGlasses, faChessBoard, faBuildingCircleCheck, faPersonChalkboard, faMarsStrokeRight, faMarsStrokeH, faHandBackFist, faHandRock, faSquareCaretUp, faCaretSquareUp, faCloudShowersWater, faChartBar, faBarChart, faHandsBubbles, faHandsWash, faLessThanEqual, faTrain, faEyeLowVision, faLowVision, faCrow, faSailboat, faWindowRestore, faSquarePlus, faPlusSquare, faToriiGate, faFrog, faBucket, faImage, faMicrophone, faCow, faCaretUp, faScrewdriver, faFolderClosed, faHouseTsunami, faSquareNfi, faArrowUpFromGroundWater, faMartiniGlass, faGlassMartiniAlt, faSquareBinary, faRotateLeft, faRotateBack, faRotateBackward, faUndoAlt, faTableColumns, faColumns, faLemon, faHeadSideMask, faHandshake, faGem, faDolly, faDollyBox, faSmoking, faMinimize, faCompressArrowsAlt, faMonument, faSnowplow, faAnglesRight, faAngleDoubleRight, faCannabis, faCirclePlay, faPlayCircle, faTablets, faEthernet, faEuroSign, faEur, faEuro, faChair, faCircleCheck, faCheckCircle, faCircleStop, faStopCircle, faCompassDrafting, faDraftingCompass, faPlateWheat, faIcicles, faPersonShelter, faNeuter, faIdBadge, faMarker, faFaceLaughBeam, faLaughBeam, faHelicopterSymbol, faUniversalAccess, faCircleChevronUp, faChevronCircleUp, faLariSign, faVolcano, faPersonWalkingDashedLineArrowRight, faSterlingSign, faGbp, faPoundSign, faViruses, faSquarePersonConfined, faUserTie, faArrowDownLong, faLongArrowDown, faTentArrowDownToLine, faCertificate, faReplyAll, faMailReplyAll, faSuitcase, faPersonSkating, faSkating, faFilterCircleDollar, faFunnelDollar, faCameraRetro, faCircleArrowDown, faArrowCircleDown, faFileImport, faArrowRightToFile, faSquareArrowUpRight, faExternalLinkSquare, faBoxOpen, faScroll, faSpa, faLocationPinLock, faPause, faHillAvalanche, faTemperatureEmpty, faTemperature0, faThermometer0, faThermometerEmpty, faBomb, faRegistered, faAddressCard, faContactCard, faVcard, faScaleUnbalancedFlip, faBalanceScaleRight, faSubscript, faDiamondTurnRight, faDirections, faBurst, faHouseLaptop, faLaptopHouse, faFaceTired, faTired, faMoneyBills, faSmog, faCrutch, faFontAwesome, faFontAwesomeFlag, faFontAwesomeLogoFull, faCloudArrowUp, faCloudUpload, faCloudUploadAlt, faPalette, faArrowsTurnRight, faVest, faFerry, faArrowsDownToPeople, faSeedling, faSprout, faLeftRight, faArrowsAltH, faBoxesPacking, faCircleArrowLeft, faArrowCircleLeft, faGroupArrowsRotate, faBowlFood, faCandyCane, faArrowDownWideShort, faSortAmountAsc, faSortAmountDown, faCloudBolt, faThunderstorm, faTextSlash, faRemoveFormat, faFaceSmileWink, faSmileWink, faFileWord, faFilePowerpoint, faArrowsLeftRight, faArrowsH, faHouseLock, faCloudArrowDown, faCloudDownload, faCloudDownloadAlt, faChildren, faChalkboard, faBlackboard, faUserLargeSlash, faUserAltSlash, faEnvelopeOpen, faHandshakeSimpleSlash, faHandshakeAltSlash, faMattressPillow, faGuaraniSign, faArrowsRotate, faRefresh, faSync, faFireExtinguisher, faCruzeiroSign, faGreaterThanEqual, faShieldHalved, faShieldAlt, faBookAtlas, faAtlas, faVirus, faEnvelopeCircleCheck, faLayerGroup, faArrowsToDot, faArchway, faHeartCircleCheck, faHouseChimneyCrack, faHouseDamage, faFileZipper, faFileArchive, faSquare, faMartiniGlassEmpty, faGlassMartini, faCouch, faCediSign, faItalic, faTableCellsColumnLock, faChurch, faCommentsDollar, faDemocrat, faZ, faPersonSkiing, faSkiing, faRoadLock, faA, faTemperatureArrowDown, faTemperatureDown, faFeatherPointed, faFeatherAlt, faP, faSnowflake, faNewspaper, faRectangleAd, faAd, faCircleArrowRight, faArrowCircleRight, faFilterCircleXmark, faLocust, faSort, faUnsorted, faListOl, faList12, faListNumeric, faPersonDressBurst, faMoneyCheckDollar, faMoneyCheckAlt, faVectorSquare, faBreadSlice, faLanguage, faFaceKissWinkHeart, faKissWinkHeart, faFilter, faQuestion, faFileSignature, faUpDownLeftRight, faArrowsAlt, faHouseChimneyUser, faHandHoldingHeart, faPuzzlePiece, faMoneyCheck, faStarHalfStroke, faStarHalfAlt, faCode, faWhiskeyGlass, faGlassWhiskey, faBuildingCircleExclamation, faMagnifyingGlassChart, faArrowUpRightFromSquare, faExternalLink, faCubesStacked, faWonSign, faKrw, faWon, faVirusCovid, faAustralSign, faF, faLeaf, faRoad, faTaxi, faCab, faPersonCirclePlus, faChartPie, faPieChart, faBoltLightning, faSackXmark, faFileExcel, faFileContract, faFishFins, faBuildingFlag, faFaceGrinBeam, faGrinBeam, faObjectUngroup, faPoop, faLocationPin, faMapMarker, faKaaba, faToiletPaper, faHelmetSafety, faHardHat, faHatHard, faEject, faCircleRight, faArrowAltCircleRight, faPlaneCircleCheck, faFaceRollingEyes, faMehRollingEyes, faObjectGroup, faChartLine, faLineChart, faMaskVentilator, faArrowRight, faSignsPost, faMapSigns, faCashRegister, faPersonCircleQuestion, faH, faTarp, faScrewdriverWrench, faTools, faArrowsToEye, faPlugCircleBolt, faHeart, faMarsAndVenus, faHouseUser, faHomeUser, faDumpsterFire, faHouseCrack, faMartiniGlassCitrus, faCocktail, faFaceSurprise, faSurprise, faBottleWater, faCirclePause, faPauseCircle, faToiletPaperSlash, faAppleWhole, faAppleAlt, faKitchenSet, faR, faTemperatureQuarter, faTemperature1, faThermometer1, faThermometerQuarter, faCube, faBitcoinSign, faShieldDog, faSolarPanel, faLockOpen, faElevator, faMoneyBillTransfer, faMoneyBillTrendUp, faHouseFloodWaterCircleArrowRight, faSquarePollHorizontal, faPollH, faCircle, faBackwardFast, faFastBackward, faRecycle, faUserAstronaut, faPlaneSlash, faTrademark, faBasketball, faBasketballBall, faSatelliteDish, faCircleUp, faArrowAltCircleUp, faMobileScreenButton, faMobileAlt, faVolumeHigh, faVolumeUp, faUsersRays, faWallet, faClipboardCheck, faFileAudio, faBurger, faHamburger, faWrench, faBugs, faRupeeSign, faRupee, faFileImage, faCircleQuestion, faQuestionCircle, faPlaneDeparture, faHandshakeSlash, faBookBookmark, faCodeBranch, faHatCowboy, faBridge, faPhoneFlip, faPhoneAlt, faTruckFront, faCat, faAnchorCircleExclamation, faTruckField, faRoute, faClipboardQuestion, faPanorama, faCommentMedical, faTeethOpen, faFileCircleMinus, faTags, faWineGlass, faForwardFast, faFastForward, faFaceMehBlank, faMehBlank, faSquareParking, faParking, faHouseSignal, faBarsProgress, faTasksAlt, faFaucetDrip, faCartFlatbed, faDollyFlatbed, faBanSmoking, faSmokingBan, faTerminal, faMobileButton, faHouseMedicalFlag, faBasketShopping, faShoppingBasket, faTape, faBusSimple, faBusAlt, faEye, faFaceSadCry, faSadCry, faAudioDescription, faPersonMilitaryToPerson, faFileShield, faUserSlash, faPen, faTowerObservation, faFileCode, faSignal, faSignal5, faSignalPerfect, faBus, faHeartCircleXmark, faHouseChimney, faHomeLg, faWindowMaximize, faFaceFrown, faFrown, faPrescription, faShop, faStoreAlt, faFloppyDisk, faSave, faVihara, faScaleUnbalanced, faBalanceScaleLeft, faSortUp, faSortAsc, faCommentDots, faCommenting, faPlantWilt, faDiamond, faFaceGrinSquint, faGrinSquint, faHandHoldingDollar, faHandHoldingUsd, faChartDiagram, faBacterium, faHandPointer, faDrumSteelpan, faHandScissors, faHandsPraying, faPrayingHands, faArrowRotateRight, faArrowRightRotate, faArrowRotateForward, faRedo, faWebAwesome, faBiohazard, faLocationCrosshairs, faLocation, faMarsDouble, faChildDress, faUsersBetweenLines, faLungsVirus, faFaceGrinTears, faGrinTears, faPhone, faCalendarXmark, faCalendarTimes, faChildReaching, faHeadSideVirus, faUserGear, faUserCog, faArrowUp19, faSortNumericUp, faDoorClosed, faShieldVirus, faDiceSix, faMosquitoNet, faFileFragment, faBridgeWater, faPersonBooth, faTextWidth, faHatWizard, faPenFancy, faPersonDigging, faDigging, faTrash, faGaugeSimple, faGaugeSimpleMed, faTachometerAverage, faBookMedical, faPoo, faQuoteRight, faQuoteRightAlt, faShirt, faTShirt, faTshirt, faCubes, faDivide, faTengeSign, faTenge, faHeadphones, faHandsHolding, faHandsClapping, faRepublican, faArrowLeft, faPersonCircleXmark, faRuler, faAlignLeft, faDiceD6, faRestroom, faJ, faUsersViewfinder, faFileVideo, faUpRightFromSquare, faExternalLinkAlt, faTableCells, faTh, faFilePdf, faBookBible, faBible, faO, faSuitcaseMedical, faMedkit, faUserSecret, faOtter, faPersonDress, faFemale, faCommentDollar, faBusinessTime, faBriefcaseClock, faTableCellsLarge, faThLarge, faBookTanakh, faTanakh, faPhoneVolume, faVolumeControlPhone, faHatCowboySide, faClipboardUser, faChild, faLiraSign, faSatellite, faPlaneLock, faTag, faComment, faCakeCandles, faBirthdayCake, faCake, faEnvelope, faAnglesUp, faAngleDoubleUp, faPaperclip, faArrowRightToCity, faRibbon, faLungs, faArrowUp91, faSortNumericUpAlt, faLitecoinSign, faBorderNone, faCircleNodes, faParachuteBox, faIndent, faTruckFieldUn, faHourglass, faHourglassEmpty, faMountain, faUserDoctor, faUserMd, faCircleInfo, faInfoCircle, faCloudMeatball, faCamera, faCameraAlt, faSquareVirus, faMeteor, faCarOn, faSleigh, faArrowDown19, faSortNumericAsc, faSortNumericDown, faHandHoldingDroplet, faHandHoldingWater, faWater, faCalendarCheck, faBraille, faPrescriptionBottleMedical, faPrescriptionBottleAlt, faLandmark, faTruck, faCrosshairs, faPersonCane, faTent, faVestPatches, faCheckDouble, faArrowDownAZ, faSortAlphaAsc, faSortAlphaDown, faMoneyBillWheat, faCookie, faArrowRotateLeft, faArrowLeftRotate, faArrowRotateBack, faArrowRotateBackward, faUndo, faHardDrive, faHdd, faFaceGrinSquintTears, faGrinSquintTears, faDumbbell, faRectangleList, faListAlt, faTarpDroplet, faHouseMedicalCircleCheck, faPersonSkiingNordic, faSkiingNordic, faCalendarPlus, faPlaneArrival, faCircleLeft, faArrowAltCircleLeft, faTrainSubway, faSubway, faChartGantt, faIndianRupeeSign, faIndianRupee, faInr, faCropSimple, faCropAlt, faMoneyBill1, faMoneyBillAlt, faLeftLong, faLongArrowAltLeft, faDna, faVirusSlash, faMinus, faSubtract, faChess, faArrowLeftLong, faLongArrowLeft, faPlugCircleCheck, faStreetView, faFrancSign, faVolumeOff, faHandsAslInterpreting, faAmericanSignLanguageInterpreting, faAslInterpreting, faHandsAmericanSignLanguageInterpreting, faGear, faCog, faDropletSlash, faTintSlash, faMosque, faMosquito, faStarOfDavid, faPersonMilitaryRifle, faCartShopping, faShoppingCart, faVials, faPlugCirclePlus, faPlaceOfWorship, faGripVertical, faHexagonNodes, faArrowTurnUp, faLevelUp, faU, faSquareRootVariable, faSquareRootAlt, faClock, faClockFour, faBackwardStep, faStepBackward, faPallet, faFaucet, faBaseballBatBall, faS, faTimeline, faKeyboard, faCaretDown, faHouseChimneyMedical, faClinicMedical, faTemperatureThreeQuarters, faTemperature3, faThermometer3, faThermometerThreeQuarters, faMobileScreen, faMobileAndroidAlt, faPlaneUp, faPiggyBank, faBatteryHalf, faBattery3, faMountainCity, faCoins, faKhanda, faSliders, faSlidersH, faFolderTree, faNetworkWired, faMapPin, faHamsa, faCentSign, faFlask, faPersonPregnant, faWandSparkles, faEllipsisVertical, faEllipsisV, faTicket, faPowerOff, faRightLong, faLongArrowAltRight, faFlagUsa, faLaptopFile, faTty, faTeletype, faDiagramNext, faPersonRifle, faHouseMedicalCircleExclamation, faClosedCaptioning, faPersonHiking, faHiking, faVenusDouble, faImages, faCalculator, faPeoplePulling, faN, faCableCar, faTram, faCloudRain, faBuildingCircleXmark, faShip, faArrowsDownToLine, faDownload, faFaceGrin, faGrin, faDeleteLeft, faBackspace, faEyeDropper, faEyeDropperEmpty, faEyedropper, faFileCircleCheck, faForward, faMobile, faMobileAndroid, faMobilePhone, faFaceMeh, faMeh, faAlignCenter, faBookSkull, faBookDead, faIdCard, faDriversLicense, faOutdent, faDedent, faHeartCircleExclamation, faHouse, faHome, faHomeAlt, faHomeLgAlt, faCalendarWeek, faLaptopMedical, faB, faFileMedical, faDiceOne, faKiwiBird, faArrowRightArrowLeft, faExchange, faRotateRight, faRedoAlt, faRotateForward, faUtensils, faCutlery, faArrowUpWideShort, faSortAmountUp, faMillSign, faBowlRice, faSkull, faTowerBroadcast, faBroadcastTower, faTruckPickup, faUpLong, faLongArrowAltUp, faStop, faCodeMerge, faUpload, faHurricane, faMound, faToiletPortable, faCompactDisc, faFileArrowDown, faFileDownload, faCaravan, faShieldCat, faBolt, faZap, faGlassWater, faOilWell, faVault, faMars, faToilet, faPlaneCircleXmark, faYenSign, faCny, faJpy, faRmb, faYen, faRubleSign, faRouble, faRub, faRuble, faSun, faGuitar, faFaceLaughWink, faLaughWink, faHorseHead, faBoreHole, faIndustry, faCircleDown, faArrowAltCircleDown, faArrowsTurnToDots, faFlorinSign, faArrowDownShortWide, faSortAmountDesc, faSortAmountDownAlt, faLessThan, faAngleDown, faCarTunnel, faHeadSideCough, faGripLines, faThumbsDown, faUserLock, faArrowRightLong, faLongArrowRight, faAnchorCircleXmark, faEllipsis, faEllipsisH, faChessPawn, faKitMedical, faFirstAid, faPersonThroughWindow, faToolbox, faHandsHoldingCircle, faBug, faCreditCard, faCreditCardAlt, faCar, faAutomobile, faHandHoldingHand, faBookOpenReader, faBookReader, faMountainSun, faArrowsLeftRightToLine, faDiceD20, faTruckDroplet, faFileCircleXmark, faTemperatureArrowUp, faTemperatureUp, faMedal, faBed, faSquareH, faHSquare, faPodcast, faTemperatureFull, faTemperature4, faThermometer4, faThermometerFull, faBell, faSuperscript, faPlugCircleXmark, faStarOfLife, faPhoneSlash, faPaintRoller, faHandshakeAngle, faHandsHelping, faLocationDot, faMapMarkerAlt, faFile, faGreaterThan, faPersonSwimming, faSwimmer, faArrowDown, faDroplet, faTint, faEraser, faEarthAmericas, faEarth, faEarthAmerica, faGlobeAmericas, faPersonBurst, faDove, faBatteryEmpty, faBattery0, faSocks, faInbox, faSection, faGaugeHigh, faTachometerAlt, faTachometerAltFast, faEnvelopeOpenText, faHospital, faHospitalAlt, faHospitalWide, faWineBottle, faChessRook, faBarsStaggered, faReorder, faStream, faDharmachakra, faHotdog, faPersonWalkingWithCane, faBlind, faDrum, faIceCream, faHeartCircleBolt, faFax, faParagraph, faCheckToSlot, faVoteYea, faStarHalf, faBoxesStacked, faBoxes, faBoxesAlt, faLink, faChain, faEarListen, faAssistiveListeningSystems, faTreeCity, faPlay, faFont, faTableCellsRowLock, faRupiahSign, faMagnifyingGlass, faSearch, faTableTennisPaddleBall, faPingPongPaddleBall, faTableTennis, faPersonDotsFromLine, faDiagnoses, faTrashCanArrowUp, faTrashRestoreAlt, faNairaSign, faCartArrowDown, faWalkieTalkie, faFilePen, faFileEdit, faReceipt, faSquarePen, faPenSquare, faPencilSquare, faSuitcaseRolling, faPersonCircleExclamation, faChevronDown, faBatteryFull, faBattery, faBattery5, faSkullCrossbones, faCodeCompare, faListUl, faListDots, faSchoolLock, faTowerCell, faDownLong, faLongArrowAltDown, faRankingStar, faChessKing, faPersonHarassing, faBrazilianRealSign, faLandmarkDome, faLandmarkAlt, faArrowUp, faTv, faTelevision, faTvAlt, faShrimp, faListCheck, faTasks, faJugDetergent, faCircleUser, faUserCircle, faUserShield, faWind, faCarBurst, faCarCrash, faY, faPersonSnowboarding, faSnowboarding, faTruckFast, faShippingFast, faFish, faUserGraduate, faCircleHalfStroke, faAdjust, faClapperboard, faCircleRadiation, faRadiationAlt, faBaseball, faBaseballBall, faJetFighterUp, faDiagramProject, faProjectDiagram, faCopy, faVolumeXmark, faVolumeMute, faVolumeTimes, faHandSparkles, faGrip, faGripHorizontal, faShareFromSquare, faShareSquare, faChildCombatant, faChildRifle, faGun, faSquarePhone, faPhoneSquare, faPlus, faAdd, faExpand, faComputer, faXmark, faClose, faMultiply, faRemove, faTimes, faArrowsUpDownLeftRight, faArrows, faChalkboardUser, faChalkboardTeacher, faPesoSign, faBuildingShield, faBaby, faUsersLine, faQuoteLeft, faQuoteLeftAlt, faTractor, faTrashArrowUp, faTrashRestore, faArrowDownUpLock, faLinesLeaning, faRulerCombined, faCopyright, faEquals, faBlender, faTeeth, faShekelSign, faIls, faShekel, faSheqel, faSheqelSign, faMap, faRocket, faPhotoFilm, faPhotoVideo, faFolderMinus, faHexagonNodesBolt, faStore, faArrowTrendUp, faPlugCircleMinus, faSignHanging, faSign, faBezierCurve, faBellSlash, faTablet, faTabletAndroid, faSchoolFlag, faFill, faAngleUp, faDrumstickBite, faHollyBerry, faChevronLeft, faBacteria, faHandLizard, faNotdef, faDisease, faBriefcaseMedical, faGenderless, faChevronRight, faRetweet, faCarRear, faCarAlt, faPumpSoap, faVideoSlash, faBatteryQuarter, faBattery2, faRadio, faBabyCarriage, faCarriageBaby, faTrafficLight, faThermometer, faVrCardboard, faHandMiddleFinger, faPercent, faPercentage, faTruckMoving, faGlassWaterDroplet, faDisplay, faFaceSmile, faSmile, faThumbtack, faThumbTack, faTrophy, faPersonPraying, faPray, faHammer, faHandPeace, faRotate, faSyncAlt, faSpinner, faRobot, faPeace, faGears, faCogs, faWarehouse, faArrowUpRightDots, faSplotch, faFaceGrinHearts, faGrinHearts, faDiceFour, faSimCard, faTransgender, faTransgenderAlt, faMercury, faArrowTurnDown, faLevelDown, faPersonFallingBurst, faAward, faTicketSimple, faTicketAlt, faBuilding, faAnglesLeft, faAngleDoubleLeft, faQrcode, faClockRotateLeft, faHistory, faFaceGrinBeamSweat, faGrinBeamSweat, faFileExport, faArrowRightFromFile, faShield, faShieldBlank, faArrowUpShortWide, faSortAmountUpAlt, faCommentNodes, faHouseMedical, faGolfBallTee, faGolfBall, faCircleChevronLeft, faChevronCircleLeft, faHouseChimneyWindow, faPenNib, faTentArrowTurnLeft, faTents, faWandMagic, faMagic, faDog, faCarrot, faMoon, faWineGlassEmpty, faWineGlassAlt, faCheese, faYinYang, faMusic, faCodeCommit, faTemperatureLow, faPersonBiking, faBiking, faBroom, faShieldHeart, faGopuram, faEarthOceania, faGlobeOceania, faSquareXmark, faTimesSquare, faXmarkSquare, faHashtag, faUpRightAndDownLeftFromCenter, faExpandAlt, faOilCan, faT, faHippo, faChartColumn, faInfinity, faVialCircleCheck, faPersonArrowDownToLine, faVoicemail, faFan, faPersonWalkingLuggage, faUpDown, faArrowsAltV, faCloudMoonRain, faCalendar, faTrailer, faBahai, faHaykal, faSdCard, faDragon, faShoePrints, faCirclePlus, faPlusCircle, faFaceGrinTongueWink, faGrinTongueWink, faHandHolding, faPlugCircleExclamation, faLinkSlash, faChainBroken, faChainSlash, faUnlink, faClone, faPersonWalkingArrowLoopLeft, faArrowUpZA, faSortAlphaUpAlt, faFireFlameCurved, faFireAlt, faTornado, faFileCirclePlus, faBookQuran, faQuran, faAnchor, faBorderAll, faFaceAngry, faAngry, faCookieBite, faArrowTrendDown, faRss, faFeed, faDrawPolygon, faScaleBalanced, faBalanceScale, faGaugeSimpleHigh, faTachometer, faTachometerFast, faShower, faDesktop, faDesktopAlt, faM, faTableList, faThList, faCommentSms, faSms, faBook, faUserPlus, faCheck, faBatteryThreeQuarters, faBattery4, faHouseCircleCheck, faAngleLeft, faDiagramSuccessor, faTruckArrowRight, faArrowsSplitUpAndLeft, faHandFist, faFistRaised, faCloudMoon, faBriefcase, faPersonFalling, faImagePortrait, faPortrait, faUserTag, faRug, faEarthEurope, faGlobeEurope, faCartFlatbedSuitcase, faLuggageCart, faRectangleXmark, faRectangleTimes, faTimesRectangle, faWindowClose, faBahtSign, faBookOpen, faBookJournalWhills, faJournalWhills, faHandcuffs, faTriangleExclamation, faExclamationTriangle, faWarning, faDatabase, faShare, faMailForward, faBottleDroplet, faMaskFace, faHillRockslide, faRightLeft, faExchangeAlt, faPaperPlane, faRoadCircleExclamation, faDungeon, faAlignRight, faMoneyBill1Wave, faMoneyBillWaveAlt, faLifeRing, faHands, faSignLanguage, faSigning, faCalendarDay, faWaterLadder, faLadderWater, faSwimmingPool, faArrowsUpDown, faArrowsV, faFaceGrimace, faGrimace, faWheelchairMove, faWheelchairAlt, faTurnDown, faLevelDownAlt, faPersonWalkingArrowRight, faSquareEnvelope, faEnvelopeSquare, faDice, faBowlingBall, faBrain, faBandage, faBandAid, faCalendarMinus, faCircleXmark, faTimesCircle, faXmarkCircle, faGifts, faHotel, faEarthAsia, faGlobeAsia, faIdCardClip, faIdCardAlt, faMagnifyingGlassPlus, faSearchPlus, faThumbsUp, faUserClock, faHandDots, faAllergies, faFileInvoice, faWindowMinimize, faMugSaucer, faCoffee, faBrush, faFileHalfDashed, faMask, faMagnifyingGlassMinus, faSearchMinus, faRulerVertical, faUserLarge, faUserAlt, faTrainTram, faUserNurse, faSyringe, faCloudSun, faStopwatch20, faSquareFull, faMagnet, faJar, faNoteSticky, faStickyNote, faBugSlash, faArrowUpFromWaterPump, faBone, faTableCellsRowUnlock, faUserInjured, faFaceSadTear, faSadTear, faPlane, faTentArrowsDown, faExclamation, faArrowsSpin, faPrint, faTurkishLiraSign, faTry, faTurkishLira, faDollarSign, faDollar, faUsd, faX, faMagnifyingGlassDollar, faSearchDollar, faUsersGear, faUsersCog, faPersonMilitaryPointing, faBuildingColumns, faBank, faInstitution, faMuseum, faUniversity, faUmbrella, faTrowel, faD, faStapler, faMasksTheater, faTheaterMasks, faKipSign, faHandPointLeft, faHandshakeSimple, faHandshakeAlt, faJetFighter, faFighterJet, faSquareShareNodes, faShareAltSquare, faBarcode, faPlusMinus, faVideo, faVideoCamera, faGraduationCap, faMortarBoard, faHandHoldingMedical, faPersonCircleCheck, faTurnUp, faLevelUpAlt };\n","'use strict';\n/* global ActiveXObject -- old IE, WSH */\nvar anObject = require('../internals/an-object');\nvar definePropertiesModule = require('../internals/object-define-properties');\nvar enumBugKeys = require('../internals/enum-bug-keys');\nvar hiddenKeys = require('../internals/hidden-keys');\nvar html = require('../internals/html');\nvar documentCreateElement = require('../internals/document-create-element');\nvar sharedKey = require('../internals/shared-key');\n\nvar GT = '>';\nvar LT = '<';\nvar PROTOTYPE = 'prototype';\nvar SCRIPT = 'script';\nvar IE_PROTO = sharedKey('IE_PROTO');\n\nvar EmptyConstructor = function () { /* empty */ };\n\nvar scriptTag = function (content) {\n return LT + SCRIPT + GT + content + LT + '/' + SCRIPT + GT;\n};\n\n// Create object with fake `null` prototype: use ActiveX Object with cleared prototype\nvar NullProtoObjectViaActiveX = function (activeXDocument) {\n activeXDocument.write(scriptTag(''));\n activeXDocument.close();\n var temp = activeXDocument.parentWindow.Object;\n // eslint-disable-next-line no-useless-assignment -- avoid memory leak\n activeXDocument = null;\n return temp;\n};\n\n// Create object with fake `null` prototype: use iframe Object with cleared prototype\nvar NullProtoObjectViaIFrame = function () {\n // Thrash, waste and sodomy: IE GC bug\n var iframe = documentCreateElement('iframe');\n var JS = 'java' + SCRIPT + ':';\n var iframeDocument;\n iframe.style.display = 'none';\n html.appendChild(iframe);\n // https://github.com/zloirock/core-js/issues/475\n iframe.src = String(JS);\n iframeDocument = iframe.contentWindow.document;\n iframeDocument.open();\n iframeDocument.write(scriptTag('document.F=Object'));\n iframeDocument.close();\n return iframeDocument.F;\n};\n\n// Check for document.domain and active x support\n// No need to use active x approach when document.domain is not set\n// see https://github.com/es-shims/es5-shim/issues/150\n// variation of https://github.com/kitcambridge/es5-shim/commit/4f738ac066346\n// avoid IE GC bug\nvar activeXDocument;\nvar NullProtoObject = function () {\n try {\n activeXDocument = new ActiveXObject('htmlfile');\n } catch (error) { /* ignore */ }\n NullProtoObject = typeof document != 'undefined'\n ? document.domain && activeXDocument\n ? NullProtoObjectViaActiveX(activeXDocument) // old IE\n : NullProtoObjectViaIFrame()\n : NullProtoObjectViaActiveX(activeXDocument); // WSH\n var length = enumBugKeys.length;\n while (length--) delete NullProtoObject[PROTOTYPE][enumBugKeys[length]];\n return NullProtoObject();\n};\n\nhiddenKeys[IE_PROTO] = true;\n\n// `Object.create` method\n// https://tc39.es/ecma262/#sec-object.create\n// eslint-disable-next-line es/no-object-create -- safe\nmodule.exports = Object.create || function create(O, Properties) {\n var result;\n if (O !== null) {\n EmptyConstructor[PROTOTYPE] = anObject(O);\n result = new EmptyConstructor();\n EmptyConstructor[PROTOTYPE] = null;\n // add \"__proto__\" for Object.getPrototypeOf polyfill\n result[IE_PROTO] = O;\n } else result = NullProtoObject();\n return Properties === undefined ? result : definePropertiesModule.f(result, Properties);\n};\n","import { computed, getCurrentInstance, inject, ref, unref } from 'vue'\nimport { debugWarn, isClient, isNumber } from '@element-plus/utils'\n\nimport type { InjectionKey, Ref } from 'vue'\n\nexport interface ElZIndexInjectionContext {\n current: number\n}\n\nconst initial: ElZIndexInjectionContext = {\n current: 0,\n}\n\nconst zIndex = ref(0)\n\nexport const defaultInitialZIndex = 2000\n\n// For SSR\nexport const ZINDEX_INJECTION_KEY: InjectionKey =\n Symbol('elZIndexContextKey')\n\nexport const zIndexContextKey: InjectionKey> =\n Symbol('zIndexContextKey')\n\nexport const useZIndex = (zIndexOverrides?: Ref) => {\n const increasingInjection = getCurrentInstance()\n ? inject(ZINDEX_INJECTION_KEY, initial)\n : initial\n\n const zIndexInjection =\n zIndexOverrides ||\n (getCurrentInstance() ? inject(zIndexContextKey, undefined) : undefined)\n\n const initialZIndex = computed(() => {\n const zIndexFromInjection = unref(zIndexInjection)\n return isNumber(zIndexFromInjection)\n ? zIndexFromInjection\n : defaultInitialZIndex\n })\n\n const currentZIndex = computed(() => initialZIndex.value + zIndex.value)\n\n const nextZIndex = () => {\n increasingInjection.current++\n zIndex.value = increasingInjection.current\n return currentZIndex.value\n }\n\n if (!isClient && !inject(ZINDEX_INJECTION_KEY)) {\n debugWarn(\n 'ZIndexInjection',\n `Looks like you are using server rendering, you must provide a z-index provider to ensure the hydration process to be succeed\nusage: app.provide(ZINDEX_INJECTION_KEY, { current: 0 })`\n )\n }\n\n return {\n initialZIndex,\n currentZIndex,\n nextZIndex,\n }\n}\n\nexport type UseZIndexReturn = ReturnType\n","import { computed, getCurrentInstance } from 'vue'\n\nimport type { ComputedRef } from 'vue'\n\nexport const useProp = (name: string): ComputedRef => {\n const vm = getCurrentInstance()\n return computed(() => (vm?.proxy?.$props as any)?.[name])\n}\n","import { computed, inject, ref, unref } from 'vue'\nimport { useGlobalSize } from '@element-plus/hooks/use-size'\nimport { useProp } from '@element-plus/hooks/use-prop'\nimport { formContextKey, formItemContextKey } from '../constants'\n\nimport type { ComponentSize } from '@element-plus/constants'\nimport type { MaybeRef } from '@vueuse/core'\n\nexport const useFormSize = (\n fallback?: MaybeRef,\n ignore: Partial> = {}\n) => {\n const emptyRef = ref(undefined)\n\n const size = ignore.prop ? emptyRef : useProp('size')\n const globalConfig = ignore.global ? emptyRef : useGlobalSize()\n const form = ignore.form\n ? { size: undefined }\n : inject(formContextKey, undefined)\n const formItem = ignore.formItem\n ? { size: undefined }\n : inject(formItemContextKey, undefined)\n\n return computed(\n (): ComponentSize =>\n size.value ||\n unref(fallback) ||\n formItem?.size ||\n form?.size ||\n globalConfig.value ||\n ''\n )\n}\n\nexport const useFormDisabled = (fallback?: MaybeRef) => {\n const disabled = useProp('disabled')\n const form = inject(formContextKey, undefined)\n\n return computed(() => {\n return disabled.value ?? unref(fallback) ?? form?.disabled ?? false\n })\n}\n\n// These exports are used for preventing breaking changes\nexport const useSize = useFormSize\nexport const useDisabled = useFormDisabled\n","'use strict';\nvar $ = require('../internals/export');\nvar isSupersetOf = require('../internals/set-is-superset-of');\nvar setMethodAcceptSetLike = require('../internals/set-method-accept-set-like');\n\nvar INCORRECT = !setMethodAcceptSetLike('isSupersetOf', function (result) {\n return !result;\n});\n\n// `Set.prototype.isSupersetOf` method\n// https://tc39.es/ecma262/#sec-set.prototype.issupersetof\n$({ target: 'Set', proto: true, real: true, forced: INCORRECT }, {\n isSupersetOf: isSupersetOf\n});\n","'use strict';\nvar $ = require('../internals/export');\nvar call = require('../internals/function-call');\nvar aCallable = require('../internals/a-callable');\nvar anObject = require('../internals/an-object');\nvar getIteratorDirect = require('../internals/get-iterator-direct');\nvar createIteratorProxy = require('../internals/iterator-create-proxy');\nvar callWithSafeIterationClosing = require('../internals/call-with-safe-iteration-closing');\nvar IS_PURE = require('../internals/is-pure');\nvar iteratorClose = require('../internals/iterator-close');\nvar iteratorHelperThrowsOnInvalidIterator = require('../internals/iterator-helper-throws-on-invalid-iterator');\nvar iteratorHelperWithoutClosingOnEarlyError = require('../internals/iterator-helper-without-closing-on-early-error');\n\nvar FILTER_WITHOUT_THROWING_ON_INVALID_ITERATOR = !IS_PURE && !iteratorHelperThrowsOnInvalidIterator('filter', function () { /* empty */ });\nvar filterWithoutClosingOnEarlyError = !IS_PURE && !FILTER_WITHOUT_THROWING_ON_INVALID_ITERATOR\n && iteratorHelperWithoutClosingOnEarlyError('filter', TypeError);\n\nvar FORCED = IS_PURE || FILTER_WITHOUT_THROWING_ON_INVALID_ITERATOR || filterWithoutClosingOnEarlyError;\n\nvar IteratorProxy = createIteratorProxy(function () {\n var iterator = this.iterator;\n var predicate = this.predicate;\n var next = this.next;\n var result, done, value;\n while (true) {\n result = anObject(call(next, iterator));\n done = this.done = !!result.done;\n if (done) return;\n value = result.value;\n if (callWithSafeIterationClosing(iterator, predicate, [value, this.counter++], true)) return value;\n }\n});\n\n// `Iterator.prototype.filter` method\n// https://tc39.es/ecma262/#sec-iterator.prototype.filter\n$({ target: 'Iterator', proto: true, real: true, forced: FORCED }, {\n filter: function filter(predicate) {\n anObject(this);\n try {\n aCallable(predicate);\n } catch (error) {\n iteratorClose(this, 'throw', error);\n }\n\n if (filterWithoutClosingOnEarlyError) return call(filterWithoutClosingOnEarlyError, this, predicate);\n\n return new IteratorProxy(getIteratorDirect(this), {\n predicate: predicate\n });\n }\n});\n","'use strict';\n// `CreateIterResultObject` abstract operation\n// https://tc39.es/ecma262/#sec-createiterresultobject\nmodule.exports = function (value, done) {\n return { value: value, done: done };\n};\n","'use strict';\nvar toString = require('../internals/to-string');\n\nmodule.exports = function (argument, $default) {\n return argument === undefined ? arguments.length < 2 ? '' : $default : toString(argument);\n};\n","import castPath from './_castPath.js';\nimport toKey from './_toKey.js';\n\n/**\n * The base implementation of `_.get` without support for default values.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the property to get.\n * @returns {*} Returns the resolved value.\n */\nfunction baseGet(object, path) {\n path = castPath(path, object);\n\n var index = 0,\n length = path.length;\n\n while (object != null && index < length) {\n object = object[toKey(path[index++])];\n }\n return (index && index == length) ? object : undefined;\n}\n\nexport default baseGet;\n","'use strict';\nvar bind = require('../internals/function-bind-context');\nvar call = require('../internals/function-call');\nvar anObject = require('../internals/an-object');\nvar tryToString = require('../internals/try-to-string');\nvar isArrayIteratorMethod = require('../internals/is-array-iterator-method');\nvar lengthOfArrayLike = require('../internals/length-of-array-like');\nvar isPrototypeOf = require('../internals/object-is-prototype-of');\nvar getIterator = require('../internals/get-iterator');\nvar getIteratorMethod = require('../internals/get-iterator-method');\nvar iteratorClose = require('../internals/iterator-close');\n\nvar $TypeError = TypeError;\n\nvar Result = function (stopped, result) {\n this.stopped = stopped;\n this.result = result;\n};\n\nvar ResultPrototype = Result.prototype;\n\nmodule.exports = function (iterable, unboundFunction, options) {\n var that = options && options.that;\n var AS_ENTRIES = !!(options && options.AS_ENTRIES);\n var IS_RECORD = !!(options && options.IS_RECORD);\n var IS_ITERATOR = !!(options && options.IS_ITERATOR);\n var INTERRUPTED = !!(options && options.INTERRUPTED);\n var fn = bind(unboundFunction, that);\n var iterator, iterFn, index, length, result, next, step;\n\n var stop = function (condition) {\n if (iterator) iteratorClose(iterator, 'normal');\n return new Result(true, condition);\n };\n\n var callFn = function (value) {\n if (AS_ENTRIES) {\n anObject(value);\n return INTERRUPTED ? fn(value[0], value[1], stop) : fn(value[0], value[1]);\n } return INTERRUPTED ? fn(value, stop) : fn(value);\n };\n\n if (IS_RECORD) {\n iterator = iterable.iterator;\n } else if (IS_ITERATOR) {\n iterator = iterable;\n } else {\n iterFn = getIteratorMethod(iterable);\n if (!iterFn) throw new $TypeError(tryToString(iterable) + ' is not iterable');\n // optimisation for array iterators\n if (isArrayIteratorMethod(iterFn)) {\n for (index = 0, length = lengthOfArrayLike(iterable); length > index; index++) {\n result = callFn(iterable[index]);\n if (result && isPrototypeOf(ResultPrototype, result)) return result;\n } return new Result(false);\n }\n iterator = getIterator(iterable, iterFn);\n }\n\n next = IS_RECORD ? iterable.next : iterator.next;\n while (!(step = call(next, iterator)).done) {\n try {\n result = callFn(step.value);\n } catch (error) {\n iteratorClose(iterator, 'throw', error);\n }\n if (typeof result == 'object' && result && isPrototypeOf(ResultPrototype, result)) return result;\n } return new Result(false);\n};\n","import { computed, isRef, onScopeDispose, watch } from 'vue'\nimport {\n addClass,\n getScrollBarWidth,\n getStyle,\n hasClass,\n removeClass,\n throwError,\n} from '@element-plus/utils'\nimport { useNamespace } from '../use-namespace'\n\nimport type { Ref } from 'vue'\nimport type { UseNamespaceReturn } from '../use-namespace'\n\nexport type UseLockScreenOptions = {\n ns?: UseNamespaceReturn\n // shouldLock?: MaybeRef\n}\n\n/**\n * Hook that monitoring the ref value to lock or unlock the screen.\n * When the trigger became true, it assumes modal is now opened and vice versa.\n * @param trigger {Ref}\n */\nexport const useLockscreen = (\n trigger: Ref,\n options: UseLockScreenOptions = {}\n) => {\n if (!isRef(trigger)) {\n throwError(\n '[useLockscreen]',\n 'You need to pass a ref param to this function'\n )\n }\n\n const ns = options.ns || useNamespace('popup')\n\n const hiddenCls = computed(() => ns.bm('parent', 'hidden'))\n\n let scrollBarWidth = 0\n let withoutHiddenClass = false\n let bodyWidth = '0'\n\n const cleanup = () => {\n setTimeout(() => {\n // When the test case is running, the context environment simulated by jsdom may have been destroyed,\n // and the document does not exist at this time.\n if (typeof document === 'undefined') return\n if (withoutHiddenClass && document) {\n document.body.style.width = bodyWidth\n removeClass(document.body, hiddenCls.value)\n }\n }, 200)\n }\n watch(trigger, (val) => {\n if (!val) {\n cleanup()\n return\n }\n\n withoutHiddenClass = !hasClass(document.body, hiddenCls.value)\n if (withoutHiddenClass) {\n bodyWidth = document.body.style.width\n addClass(document.body, hiddenCls.value)\n }\n scrollBarWidth = getScrollBarWidth(ns.namespace.value)\n const bodyHasOverflow =\n document.documentElement.clientHeight < document.body.scrollHeight\n const bodyOverflowY = getStyle(document.body, 'overflowY')\n if (\n scrollBarWidth > 0 &&\n (bodyHasOverflow || bodyOverflowY === 'scroll') &&\n withoutHiddenClass\n ) {\n document.body.style.width = `calc(100% - ${scrollBarWidth}px)`\n }\n })\n onScopeDispose(() => cleanup())\n}\n","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/** Used to detect unsigned integer values. */\nvar reIsUint = /^(?:0|[1-9]\\d*)$/;\n\n/**\n * Checks if `value` is a valid array-like index.\n *\n * @private\n * @param {*} value The value to check.\n * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.\n * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.\n */\nfunction isIndex(value, length) {\n var type = typeof value;\n length = length == null ? MAX_SAFE_INTEGER : length;\n\n return !!length &&\n (type == 'number' ||\n (type != 'symbol' && reIsUint.test(value))) &&\n (value > -1 && value % 1 == 0 && value < length);\n}\n\nexport default isIndex;\n","\n\n\n","import { withInstall } from '@element-plus/utils'\nimport Tag from './src/tag.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElTag: SFCWithInstall = withInstall(Tag)\nexport default ElTag\n\nexport * from './src/tag'\n","import ListCache from './_ListCache.js';\n\n/**\n * Removes all key-value entries from the stack.\n *\n * @private\n * @name clear\n * @memberOf Stack\n */\nfunction stackClear() {\n this.__data__ = new ListCache;\n this.size = 0;\n}\n\nexport default stackClear;\n","/**\n * Removes `key` and its value from the stack.\n *\n * @private\n * @name delete\n * @memberOf Stack\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction stackDelete(key) {\n var data = this.__data__,\n result = data['delete'](key);\n\n this.size = data.size;\n return result;\n}\n\nexport default stackDelete;\n","/**\n * Gets the stack value for `key`.\n *\n * @private\n * @name get\n * @memberOf Stack\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction stackGet(key) {\n return this.__data__.get(key);\n}\n\nexport default stackGet;\n","/**\n * Checks if a stack value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Stack\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction stackHas(key) {\n return this.__data__.has(key);\n}\n\nexport default stackHas;\n","import ListCache from './_ListCache.js';\nimport Map from './_Map.js';\nimport MapCache from './_MapCache.js';\n\n/** Used as the size to enable large array optimizations. */\nvar LARGE_ARRAY_SIZE = 200;\n\n/**\n * Sets the stack `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Stack\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the stack cache instance.\n */\nfunction stackSet(key, value) {\n var data = this.__data__;\n if (data instanceof ListCache) {\n var pairs = data.__data__;\n if (!Map || (pairs.length < LARGE_ARRAY_SIZE - 1)) {\n pairs.push([key, value]);\n this.size = ++data.size;\n return this;\n }\n data = this.__data__ = new MapCache(pairs);\n }\n data.set(key, value);\n this.size = data.size;\n return this;\n}\n\nexport default stackSet;\n","import ListCache from './_ListCache.js';\nimport stackClear from './_stackClear.js';\nimport stackDelete from './_stackDelete.js';\nimport stackGet from './_stackGet.js';\nimport stackHas from './_stackHas.js';\nimport stackSet from './_stackSet.js';\n\n/**\n * Creates a stack cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Stack(entries) {\n var data = this.__data__ = new ListCache(entries);\n this.size = data.size;\n}\n\n// Add methods to `Stack`.\nStack.prototype.clear = stackClear;\nStack.prototype['delete'] = stackDelete;\nStack.prototype.get = stackGet;\nStack.prototype.has = stackHas;\nStack.prototype.set = stackSet;\n\nexport default Stack;\n","import toNumber from './toNumber.js';\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0,\n MAX_INTEGER = 1.7976931348623157e+308;\n\n/**\n * Converts `value` to a finite number.\n *\n * @static\n * @memberOf _\n * @since 4.12.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted number.\n * @example\n *\n * _.toFinite(3.2);\n * // => 3.2\n *\n * _.toFinite(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toFinite(Infinity);\n * // => 1.7976931348623157e+308\n *\n * _.toFinite('3.2');\n * // => 3.2\n */\nfunction toFinite(value) {\n if (!value) {\n return value === 0 ? value : 0;\n }\n value = toNumber(value);\n if (value === INFINITY || value === -INFINITY) {\n var sign = (value < 0 ? -1 : 1);\n return sign * MAX_INTEGER;\n }\n return value === value ? value : 0;\n}\n\nexport default toFinite;\n","import toFinite from './toFinite.js';\n\n/**\n * Converts `value` to an integer.\n *\n * **Note:** This method is loosely based on\n * [`ToInteger`](http://www.ecma-international.org/ecma-262/7.0/#sec-tointeger).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted integer.\n * @example\n *\n * _.toInteger(3.2);\n * // => 3\n *\n * _.toInteger(Number.MIN_VALUE);\n * // => 0\n *\n * _.toInteger(Infinity);\n * // => 1.7976931348623157e+308\n *\n * _.toInteger('3.2');\n * // => 3\n */\nfunction toInteger(value) {\n var result = toFinite(value),\n remainder = result % 1;\n\n return result === result ? (remainder ? result - remainder : result) : 0;\n}\n\nexport default toInteger;\n","import baseFindIndex from './_baseFindIndex.js';\nimport baseIteratee from './_baseIteratee.js';\nimport toInteger from './toInteger.js';\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max,\n nativeMin = Math.min;\n\n/**\n * This method is like `_.findIndex` except that it iterates over elements\n * of `collection` from right to left.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @param {number} [fromIndex=array.length-1] The index to search from.\n * @returns {number} Returns the index of the found element, else `-1`.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'active': true },\n * { 'user': 'fred', 'active': false },\n * { 'user': 'pebbles', 'active': false }\n * ];\n *\n * _.findLastIndex(users, function(o) { return o.user == 'pebbles'; });\n * // => 2\n *\n * // The `_.matches` iteratee shorthand.\n * _.findLastIndex(users, { 'user': 'barney', 'active': true });\n * // => 0\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.findLastIndex(users, ['active', false]);\n * // => 2\n *\n * // The `_.property` iteratee shorthand.\n * _.findLastIndex(users, 'active');\n * // => 0\n */\nfunction findLastIndex(array, predicate, fromIndex) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return -1;\n }\n var index = length - 1;\n if (fromIndex !== undefined) {\n index = toInteger(fromIndex);\n index = fromIndex < 0\n ? nativeMax(length + index, 0)\n : nativeMin(index, length - 1);\n }\n return baseFindIndex(array, baseIteratee(predicate, 3), index, true);\n}\n\nexport default findLastIndex;\n","'use strict';\nvar call = require('../internals/function-call');\nvar isObject = require('../internals/is-object');\nvar isSymbol = require('../internals/is-symbol');\nvar getMethod = require('../internals/get-method');\nvar ordinaryToPrimitive = require('../internals/ordinary-to-primitive');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar $TypeError = TypeError;\nvar TO_PRIMITIVE = wellKnownSymbol('toPrimitive');\n\n// `ToPrimitive` abstract operation\n// https://tc39.es/ecma262/#sec-toprimitive\nmodule.exports = function (input, pref) {\n if (!isObject(input) || isSymbol(input)) return input;\n var exoticToPrim = getMethod(input, TO_PRIMITIVE);\n var result;\n if (exoticToPrim) {\n if (pref === undefined) pref = 'default';\n result = call(exoticToPrim, input, pref);\n if (!isObject(result) || isSymbol(result)) return result;\n throw new $TypeError(\"Can't convert object to primitive value\");\n }\n if (pref === undefined) pref = 'number';\n return ordinaryToPrimitive(input, pref);\n};\n","'use strict';\nvar hasOwn = require('../internals/has-own-property');\nvar isCallable = require('../internals/is-callable');\nvar toObject = require('../internals/to-object');\nvar sharedKey = require('../internals/shared-key');\nvar CORRECT_PROTOTYPE_GETTER = require('../internals/correct-prototype-getter');\n\nvar IE_PROTO = sharedKey('IE_PROTO');\nvar $Object = Object;\nvar ObjectPrototype = $Object.prototype;\n\n// `Object.getPrototypeOf` method\n// https://tc39.es/ecma262/#sec-object.getprototypeof\n// eslint-disable-next-line es/no-object-getprototypeof -- safe\nmodule.exports = CORRECT_PROTOTYPE_GETTER ? $Object.getPrototypeOf : function (O) {\n var object = toObject(O);\n if (hasOwn(object, IE_PROTO)) return object[IE_PROTO];\n var constructor = object.constructor;\n if (isCallable(constructor) && object instanceof constructor) {\n return constructor.prototype;\n } return object instanceof $Object ? ObjectPrototype : null;\n};\n","'use strict';\nvar fails = require('../internals/fails');\nvar isCallable = require('../internals/is-callable');\n\nvar replacement = /#|\\.prototype\\./;\n\nvar isForced = function (feature, detection) {\n var value = data[normalize(feature)];\n return value === POLYFILL ? true\n : value === NATIVE ? false\n : isCallable(detection) ? fails(detection)\n : !!detection;\n};\n\nvar normalize = isForced.normalize = function (string) {\n return String(string).replace(replacement, '.').toLowerCase();\n};\n\nvar data = isForced.data = {};\nvar NATIVE = isForced.NATIVE = 'N';\nvar POLYFILL = isForced.POLYFILL = 'P';\n\nmodule.exports = isForced;\n","/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n return value != null && typeof value == 'object';\n}\n\nexport default isObjectLike;\n","'use strict';\nvar commonAlphabet = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';\nvar base64Alphabet = commonAlphabet + '+/';\nvar base64UrlAlphabet = commonAlphabet + '-_';\n\nvar inverse = function (characters) {\n // TODO: use `Object.create(null)` in `core-js@4`\n var result = {};\n var index = 0;\n for (; index < 64; index++) result[characters.charAt(index)] = index;\n return result;\n};\n\nmodule.exports = {\n i2c: base64Alphabet,\n c2i: inverse(base64Alphabet),\n i2cUrl: base64UrlAlphabet,\n c2iUrl: inverse(base64UrlAlphabet)\n};\n","import { isClient, isIOS } from '@vueuse/core'\n\nexport const isFirefox = (): boolean =>\n isClient && /firefox/i.test(window.navigator.userAgent)\n\nexport const isAndroid = (): boolean =>\n isClient && /android/i.test(window.navigator.userAgent)\n\nexport { isClient, isIOS }\n","'use strict';\nvar $TypeError = TypeError;\n\nmodule.exports = function (passed, required) {\n if (passed < required) throw new $TypeError('Not enough arguments');\n return passed;\n};\n","'use strict';\nvar globalThis = require('../internals/global-this');\n\nvar navigator = globalThis.navigator;\nvar userAgent = navigator && navigator.userAgent;\n\nmodule.exports = userAgent ? String(userAgent) : '';\n","!function(e,i){\"object\"==typeof exports&&\"undefined\"!=typeof module?module.exports=i():\"function\"==typeof define&&define.amd?define(i):(e=\"undefined\"!=typeof globalThis?globalThis:e||self).dayjs_plugin_isSameOrBefore=i()}(this,(function(){\"use strict\";return function(e,i){i.prototype.isSameOrBefore=function(e,i){return this.isSame(e,i)||this.isBefore(e,i)}}}));","import { nextTick } from 'vue'\nimport { getEventCode, obtainAllFocusableElements } from '@element-plus/utils'\nimport { EVENT_CODE } from '@element-plus/constants'\n\nimport type { ObjectDirective } from 'vue'\n\nexport const FOCUSABLE_CHILDREN = '_trap-focus-children'\nexport const TRAP_FOCUS_HANDLER = '_trap-focus-handler'\n\nexport interface TrapFocusElement extends HTMLElement {\n [FOCUSABLE_CHILDREN]: HTMLElement[]\n [TRAP_FOCUS_HANDLER]: (e: KeyboardEvent) => void\n}\n\nconst FOCUS_STACK: TrapFocusElement[] = []\n\nconst FOCUS_HANDLER = (e: KeyboardEvent) => {\n // Getting the top layer.\n if (FOCUS_STACK.length === 0) return\n const code = getEventCode(e)\n const focusableElement =\n FOCUS_STACK[FOCUS_STACK.length - 1][FOCUSABLE_CHILDREN]\n if (focusableElement.length > 0 && code === EVENT_CODE.tab) {\n if (focusableElement.length === 1) {\n e.preventDefault()\n if (document.activeElement !== focusableElement[0]) {\n focusableElement[0].focus()\n }\n return\n }\n const goingBackward = e.shiftKey\n const isFirst = e.target === focusableElement[0]\n const isLast = e.target === focusableElement[focusableElement.length - 1]\n if (isFirst && goingBackward) {\n e.preventDefault()\n focusableElement[focusableElement.length - 1].focus()\n }\n if (isLast && !goingBackward) {\n e.preventDefault()\n focusableElement[0].focus()\n }\n\n // the is critical since jsdom did not implement user actions, you can only mock it\n // DELETE ME: when testing env switches to puppeteer\n if (typeof process !== 'undefined' && process.env.NODE_ENV === 'test') {\n const index = focusableElement.indexOf(e.target as HTMLElement)\n if (index !== -1) {\n focusableElement[goingBackward ? index - 1 : index + 1]?.focus()\n }\n }\n }\n}\n\nconst TrapFocus: ObjectDirective = {\n beforeMount(el: TrapFocusElement) {\n el[FOCUSABLE_CHILDREN] = obtainAllFocusableElements(el)\n FOCUS_STACK.push(el)\n if (FOCUS_STACK.length <= 1) {\n document.addEventListener('keydown', FOCUS_HANDLER)\n }\n },\n updated(el: TrapFocusElement) {\n nextTick(() => {\n el[FOCUSABLE_CHILDREN] = obtainAllFocusableElements(el)\n })\n },\n unmounted() {\n FOCUS_STACK.shift()\n if (FOCUS_STACK.length === 0) {\n document.removeEventListener('keydown', FOCUS_HANDLER)\n }\n },\n}\n\nexport default TrapFocus\n","\n\n\n","import { createVNode, isVNode, markRaw, render } from 'vue'\nimport {\n debugWarn,\n hasOwn,\n isClient,\n isElement,\n isFunction,\n isObject,\n isString,\n isUndefined,\n} from '@element-plus/utils'\nimport MessageBoxConstructor from './index.vue'\n\nimport type { AppContext, ComponentPublicInstance, VNode } from 'vue'\nimport type {\n Action,\n Callback,\n ElMessageBoxOptions,\n ElMessageBoxShortcutMethod,\n IElMessageBox,\n MessageBoxData,\n MessageBoxState,\n} from './message-box.type'\n\n// component default merge props & data\n\nconst messageInstance = new Map<\n ComponentPublicInstance<{ doClose: () => void }>, // marking doClose as function\n {\n options: any\n callback: Callback | undefined\n resolve: (res: any) => void\n reject: (reason?: any) => void\n }\n>()\n\nconst getAppendToElement = (props: any): HTMLElement => {\n let appendTo: HTMLElement | null = document.body\n if (props.appendTo) {\n if (isString(props.appendTo)) {\n appendTo = document.querySelector(props.appendTo)\n }\n if (isElement(props.appendTo)) {\n appendTo = props.appendTo\n }\n\n // should fallback to default value with a warning\n if (!isElement(appendTo)) {\n debugWarn(\n 'ElMessageBox',\n 'the appendTo option is not an HTMLElement. Falling back to document.body.'\n )\n appendTo = document.body\n }\n }\n return appendTo\n}\n\nconst initInstance = (\n props: any,\n container: HTMLElement,\n appContext: AppContext | null = null\n) => {\n const vnode = createVNode(\n MessageBoxConstructor,\n props,\n isFunction(props.message) || isVNode(props.message)\n ? {\n default: isFunction(props.message)\n ? props.message\n : () => props.message,\n }\n : null\n )\n vnode.appContext = appContext\n render(vnode, container)\n getAppendToElement(props).appendChild(container.firstElementChild!)\n return vnode.component\n}\n\nconst genContainer = () => {\n return document.createElement('div')\n}\n\nconst showMessage = (options: any, appContext?: AppContext | null) => {\n const container = genContainer()\n // Adding destruct method.\n // when transition leaves emitting `vanish` evt. so that we can do the clean job.\n options.onVanish = () => {\n // not sure if this causes mem leak, need proof to verify that.\n // maybe calling out like 1000 msg-box then close them all.\n render(null, container)\n messageInstance.delete(vm) // Remove vm to avoid mem leak.\n // here we were suppose to call document.body.removeChild(container.firstElementChild)\n // but render(null, container) did that job for us. so that we do not call that directly\n }\n\n options.onAction = (action: Action) => {\n const currentMsg = messageInstance.get(vm)!\n let resolve: Action | { value: string; action: Action }\n if (options.showInput) {\n resolve = { value: vm.inputValue, action }\n } else {\n resolve = action\n }\n if (options.callback) {\n options.callback(resolve, instance.proxy)\n } else {\n if (action === 'cancel' || action === 'close') {\n if (options.distinguishCancelAndClose && action !== 'cancel') {\n currentMsg.reject('close')\n } else {\n currentMsg.reject('cancel')\n }\n } else {\n currentMsg.resolve(resolve)\n }\n }\n }\n\n const instance = initInstance(options, container, appContext)!\n\n // This is how we use message box programmatically.\n // Maybe consider releasing a template version?\n // get component instance like v2.\n const vm = instance.proxy as ComponentPublicInstance<\n {\n visible: boolean\n doClose: () => void\n } & MessageBoxState\n >\n\n for (const prop in options) {\n if (hasOwn(options, prop) && !hasOwn(vm.$props, prop)) {\n if (prop === 'closeIcon' && isObject(options[prop])) {\n vm[prop as keyof ComponentPublicInstance] = markRaw(options[prop])\n } else {\n vm[prop as keyof ComponentPublicInstance] = options[prop]\n }\n }\n }\n\n // change visibility after everything is settled\n vm.visible = true\n return vm\n}\n\nasync function MessageBox(\n options: ElMessageBoxOptions,\n appContext?: AppContext | null\n): Promise\nfunction MessageBox(\n options: ElMessageBoxOptions | string | VNode,\n appContext: AppContext | null = null\n): Promise<{ value: string; action: Action } | Action> {\n if (!isClient) return Promise.reject()\n let callback: Callback | undefined\n if (isString(options) || isVNode(options)) {\n options = {\n message: options,\n }\n } else {\n callback = options.callback\n }\n\n return new Promise((resolve, reject) => {\n const vm = showMessage(\n options,\n appContext ?? (MessageBox as IElMessageBox)._context\n )\n // collect this vm in order to handle upcoming events.\n messageInstance.set(vm, {\n options,\n callback,\n resolve,\n reject,\n })\n })\n}\n\nconst MESSAGE_BOX_VARIANTS = ['alert', 'confirm', 'prompt'] as const\nconst MESSAGE_BOX_DEFAULT_OPTS: Record<\n (typeof MESSAGE_BOX_VARIANTS)[number],\n Partial\n> = {\n alert: { closeOnPressEscape: false, closeOnClickModal: false },\n confirm: { showCancelButton: true },\n prompt: { showCancelButton: true, showInput: true },\n}\n\nMESSAGE_BOX_VARIANTS.forEach((boxType) => {\n ;(MessageBox as IElMessageBox)[boxType] = messageBoxFactory(\n boxType\n ) as ElMessageBoxShortcutMethod\n})\n\nfunction messageBoxFactory(boxType: (typeof MESSAGE_BOX_VARIANTS)[number]) {\n return (\n message: string | VNode,\n title: string | ElMessageBoxOptions,\n options?: ElMessageBoxOptions,\n appContext?: AppContext | null\n ) => {\n let titleOrOpts = ''\n if (isObject(title)) {\n options = title as ElMessageBoxOptions\n titleOrOpts = ''\n } else if (isUndefined(title)) {\n titleOrOpts = ''\n } else {\n titleOrOpts = title as string\n }\n\n return MessageBox(\n Object.assign(\n {\n title: titleOrOpts,\n message,\n type: '',\n ...MESSAGE_BOX_DEFAULT_OPTS[boxType],\n },\n options,\n {\n boxType,\n }\n ),\n appContext\n )\n }\n}\n\nMessageBox.close = () => {\n // instance.setupInstall.doClose()\n // instance.setupInstall.state.visible = false\n\n messageInstance.forEach((_, vm) => {\n vm.doClose()\n })\n\n messageInstance.clear()\n}\n;(MessageBox as IElMessageBox)._context = null\n\nexport default MessageBox as IElMessageBox\n","import MessageBox from './src/messageBox'\n\nimport type { App } from 'vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nconst _MessageBox = MessageBox as SFCWithInstall\n\n_MessageBox.install = (app: App) => {\n _MessageBox._context = app._context\n app.config.globalProperties.$msgbox = _MessageBox\n app.config.globalProperties.$messageBox = _MessageBox\n app.config.globalProperties.$alert = _MessageBox.alert\n app.config.globalProperties.$confirm = _MessageBox.confirm\n app.config.globalProperties.$prompt = _MessageBox.prompt\n}\n\nexport default _MessageBox\nexport const ElMessageBox = _MessageBox\n\nexport * from './src/message-box.type'\n","export const MINIMUM_INPUT_WIDTH = 11\nexport const BORDER_HORIZONTAL_WIDTH = 2\n","'use strict';\n/* eslint-disable no-proto -- safe */\nvar uncurryThisAccessor = require('../internals/function-uncurry-this-accessor');\nvar isObject = require('../internals/is-object');\nvar requireObjectCoercible = require('../internals/require-object-coercible');\nvar aPossiblePrototype = require('../internals/a-possible-prototype');\n\n// `Object.setPrototypeOf` method\n// https://tc39.es/ecma262/#sec-object.setprototypeof\n// Works with __proto__ only. Old v8 can't work with null proto objects.\n// eslint-disable-next-line es/no-object-setprototypeof -- safe\nmodule.exports = Object.setPrototypeOf || ('__proto__' in {} ? function () {\n var CORRECT_SETTER = false;\n var test = {};\n var setter;\n try {\n setter = uncurryThisAccessor(Object.prototype, '__proto__', 'set');\n setter(test, []);\n CORRECT_SETTER = test instanceof Array;\n } catch (error) { /* empty */ }\n return function setPrototypeOf(O, proto) {\n requireObjectCoercible(O);\n aPossiblePrototype(proto);\n if (!isObject(O)) return O;\n if (CORRECT_SETTER) setter(O, proto);\n else O.__proto__ = proto;\n return O;\n };\n}() : undefined);\n","import root from './_root.js';\n\n/** Built-in value references. */\nvar Symbol = root.Symbol;\n\nexport default Symbol;\n","import { componentSizes, datePickTypes } from '@element-plus/constants'\n\nimport type { ComponentSize, DatePickType } from '@element-plus/constants'\n\nexport const isValidComponentSize = (val: string): val is ComponentSize | '' =>\n ['', ...componentSizes].includes(val)\n\nexport const isValidDatePickType = (val: string): val is DatePickType =>\n ([...datePickTypes] as string[]).includes(val)\n","'use strict';\nvar $ = require('../internals/export');\nvar getBuiltIn = require('../internals/get-built-in');\nvar apply = require('../internals/function-apply');\nvar call = require('../internals/function-call');\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar fails = require('../internals/fails');\nvar isArray = require('../internals/is-array');\nvar isCallable = require('../internals/is-callable');\nvar isRawJSON = require('../internals/is-raw-json');\nvar isSymbol = require('../internals/is-symbol');\nvar classof = require('../internals/classof-raw');\nvar toString = require('../internals/to-string');\nvar arraySlice = require('../internals/array-slice');\nvar parseJSONString = require('../internals/parse-json-string');\nvar uid = require('../internals/uid');\nvar NATIVE_SYMBOL = require('../internals/symbol-constructor-detection');\nvar NATIVE_RAW_JSON = require('../internals/native-raw-json');\n\nvar $String = String;\nvar $stringify = getBuiltIn('JSON', 'stringify');\nvar exec = uncurryThis(/./.exec);\nvar charAt = uncurryThis(''.charAt);\nvar charCodeAt = uncurryThis(''.charCodeAt);\nvar replace = uncurryThis(''.replace);\nvar slice = uncurryThis(''.slice);\nvar push = uncurryThis([].push);\nvar numberToString = uncurryThis(1.1.toString);\n\nvar surrogates = /[\\uD800-\\uDFFF]/g;\nvar lowSurrogates = /^[\\uD800-\\uDBFF]$/;\nvar hiSurrogates = /^[\\uDC00-\\uDFFF]$/;\n\nvar MARK = uid();\nvar MARK_LENGTH = MARK.length;\n\nvar WRONG_SYMBOLS_CONVERSION = !NATIVE_SYMBOL || fails(function () {\n var symbol = getBuiltIn('Symbol')('stringify detection');\n // MS Edge converts symbol values to JSON as {}\n return $stringify([symbol]) !== '[null]'\n // WebKit converts symbol values to JSON as null\n || $stringify({ a: symbol }) !== '{}'\n // V8 throws on boxed symbols\n || $stringify(Object(symbol)) !== '{}';\n});\n\n// https://github.com/tc39/proposal-well-formed-stringify\nvar ILL_FORMED_UNICODE = fails(function () {\n return $stringify('\\uDF06\\uD834') !== '\"\\\\udf06\\\\ud834\"'\n || $stringify('\\uDEAD') !== '\"\\\\udead\"';\n});\n\nvar stringifyWithProperSymbolsConversion = WRONG_SYMBOLS_CONVERSION ? function (it, replacer) {\n var args = arraySlice(arguments);\n var $replacer = getReplacerFunction(replacer);\n if (!isCallable($replacer) && (it === undefined || isSymbol(it))) return; // IE8 returns string on undefined\n args[1] = function (key, value) {\n // some old implementations (like WebKit) could pass numbers as keys\n if (isCallable($replacer)) value = call($replacer, this, $String(key), value);\n if (!isSymbol(value)) return value;\n };\n return apply($stringify, null, args);\n} : $stringify;\n\nvar fixIllFormedJSON = function (match, offset, string) {\n var prev = charAt(string, offset - 1);\n var next = charAt(string, offset + 1);\n if ((exec(lowSurrogates, match) && !exec(hiSurrogates, next)) || (exec(hiSurrogates, match) && !exec(lowSurrogates, prev))) {\n return '\\\\u' + numberToString(charCodeAt(match, 0), 16);\n } return match;\n};\n\nvar getReplacerFunction = function (replacer) {\n if (isCallable(replacer)) return replacer;\n if (!isArray(replacer)) return;\n var rawLength = replacer.length;\n var keys = [];\n for (var i = 0; i < rawLength; i++) {\n var element = replacer[i];\n if (typeof element == 'string') push(keys, element);\n else if (typeof element == 'number' || classof(element) === 'Number' || classof(element) === 'String') push(keys, toString(element));\n }\n var keysLength = keys.length;\n var root = true;\n return function (key, value) {\n if (root) {\n root = false;\n return value;\n }\n if (isArray(this)) return value;\n for (var j = 0; j < keysLength; j++) if (keys[j] === key) return value;\n };\n};\n\n// `JSON.stringify` method\n// https://tc39.es/ecma262/#sec-json.stringify\n// https://github.com/tc39/proposal-json-parse-with-source\nif ($stringify) $({ target: 'JSON', stat: true, arity: 3, forced: WRONG_SYMBOLS_CONVERSION || ILL_FORMED_UNICODE || !NATIVE_RAW_JSON }, {\n stringify: function stringify(text, replacer, space) {\n var replacerFunction = getReplacerFunction(replacer);\n var rawStrings = [];\n\n var json = stringifyWithProperSymbolsConversion(text, function (key, value) {\n // some old implementations (like WebKit) could pass numbers as keys\n var v = isCallable(replacerFunction) ? call(replacerFunction, this, $String(key), value) : value;\n return !NATIVE_RAW_JSON && isRawJSON(v) ? MARK + (push(rawStrings, v.rawJSON) - 1) : v;\n }, space);\n\n if (typeof json != 'string') return json;\n\n if (ILL_FORMED_UNICODE) json = replace(json, surrogates, fixIllFormedJSON);\n\n if (NATIVE_RAW_JSON) return json;\n\n var result = '';\n var length = json.length;\n\n for (var i = 0; i < length; i++) {\n var chr = charAt(json, i);\n if (chr === '\"') {\n var end = parseJSONString(json, ++i).end - 1;\n var string = slice(json, i, end);\n result += slice(string, 0, MARK_LENGTH) === MARK\n ? rawStrings[slice(string, MARK_LENGTH)]\n : '\"' + string + '\"';\n i = end;\n } else result += chr;\n }\n\n return result;\n }\n});\n","import {\n Comment,\n Fragment,\n Text,\n cloneVNode,\n defineComponent,\n inject,\n withDirectives,\n} from 'vue'\nimport { NOOP, debugWarn, isObject } from '@element-plus/utils'\nimport {\n FORWARD_REF_INJECTION_KEY,\n useForwardRefDirective,\n useNamespace,\n} from '@element-plus/hooks'\n\nimport type { Ref, VNode } from 'vue'\n\nconst NAME = 'ElOnlyChild'\n\nexport const OnlyChild = defineComponent({\n name: NAME,\n setup(_, { slots, attrs }) {\n const forwardRefInjection = inject(FORWARD_REF_INJECTION_KEY)\n const forwardRefDirective = useForwardRefDirective(\n forwardRefInjection?.setForwardRef ?? NOOP\n )\n return () => {\n const defaultSlot = slots.default?.(attrs)\n if (!defaultSlot) return null\n const [firstLegitNode, length] = findFirstLegitChild(defaultSlot)\n\n if (!firstLegitNode) {\n debugWarn(NAME, 'no valid child node found')\n return null\n }\n if (length > 1) {\n debugWarn(NAME, 'requires exact only one valid child.')\n }\n\n return withDirectives(cloneVNode(firstLegitNode!, attrs), [\n [forwardRefDirective],\n ])\n }\n },\n})\n\nfunction findFirstLegitChild(\n node: VNode[] | undefined\n): [VNode | null, number] {\n if (!node) return [null, 0]\n const children = node as VNode[]\n const len = children.filter((c) => c.type !== Comment).length\n\n for (const child of children) {\n /**\n * when user uses h(Fragment, [text]) to render plain string,\n * this switch case just cannot handle, when the value is primitives\n * we should just return the wrapped string\n */\n if (isObject(child)) {\n switch (child.type) {\n case Comment:\n continue\n case Text:\n case 'svg':\n return [wrapTextContent(child), len]\n case Fragment:\n return findFirstLegitChild(child.children as VNode[])\n default:\n return [child, len]\n }\n }\n return [wrapTextContent(child), len]\n }\n return [null, 0]\n}\n\nfunction wrapTextContent(s: string | VNode) {\n const ns = useNamespace('only-child')\n return {s}\n}\n\nexport type OnlyChildExpose = {\n forwardRef: Ref\n}\n","'use strict';\nvar isCallable = require('../internals/is-callable');\nvar isObject = require('../internals/is-object');\nvar setPrototypeOf = require('../internals/object-set-prototype-of');\n\n// makes subclassing work correct for wrapped built-ins\nmodule.exports = function ($this, dummy, Wrapper) {\n var NewTarget, NewTargetPrototype;\n if (\n // it can work only with native `setPrototypeOf`\n setPrototypeOf &&\n // we haven't completely correct pre-ES6 way for getting `new.target`, so use this\n isCallable(NewTarget = dummy.constructor) &&\n NewTarget !== Wrapper &&\n isObject(NewTargetPrototype = NewTarget.prototype) &&\n NewTargetPrototype !== Wrapper.prototype\n ) setPrototypeOf($this, NewTargetPrototype);\n return $this;\n};\n","import { buildProps, definePropType, iconPropType } from '@element-plus/utils'\nimport { EVENT_CODE } from '@element-plus/constants'\nimport {\n useTooltipContentProps,\n useTooltipTriggerProps,\n} from '@element-plus/components/tooltip'\nimport { roleTypes } from '@element-plus/components/popper'\n\nimport type { TooltipTriggerType } from '@element-plus/components/tooltip'\nimport type { Placement } from '@element-plus/components/popper'\nimport type { Options } from '@popperjs/core'\nimport type { ButtonProps, ButtonType } from '@element-plus/components/button'\nimport type { ComponentInternalInstance, ComputedRef } from 'vue'\nimport type { Arrayable, Nullable } from '@element-plus/utils'\n\nexport interface IElDropdownInstance {\n instance?: ComponentInternalInstance\n dropdownSize?: ComputedRef\n handleClick?: () => void\n commandHandler?: (...arg: any[]) => void\n show?: () => void\n hide?: () => void\n trigger?: ComputedRef\n hideOnClick?: ComputedRef\n triggerElm?: ComputedRef>\n}\n\nexport const dropdownProps = buildProps({\n /**\n * @description how to trigger\n */\n trigger: {\n ...useTooltipTriggerProps.trigger,\n type: definePropType>>([\n String,\n Array,\n ]),\n },\n triggerKeys: {\n type: definePropType(Array),\n default: () => [\n EVENT_CODE.enter,\n EVENT_CODE.numpadEnter,\n EVENT_CODE.space,\n EVENT_CODE.down,\n ],\n },\n /**\n * @description Indicates whether virtual triggering is enabled\n */\n virtualTriggering: useTooltipTriggerProps.virtualTriggering,\n /**\n * @description Indicates the reference element to which the dropdown is attached\n */\n virtualRef: useTooltipTriggerProps.virtualRef,\n /**\n * @description Tooltip theme, built-in theme: `dark` / `light`\n */\n effect: {\n ...useTooltipContentProps.effect,\n default: 'light',\n },\n /**\n * @description menu button type, refer to `Button` Component, only works when `split-button` is true\n */\n type: {\n type: definePropType(String),\n },\n /**\n * @description placement of pop menu\n */\n placement: {\n type: definePropType(String),\n default: 'bottom',\n },\n /**\n * @description [popper.js](https://popper.js.org/docs/v2/) parameters\n */\n popperOptions: {\n type: definePropType>(Object),\n default: () => ({}),\n },\n id: String,\n /**\n * @description menu size, also works on the split button\n */\n size: {\n type: String,\n default: '',\n },\n /**\n * @description whether a button group is displayed\n */\n splitButton: Boolean,\n /**\n * @description whether to hide menu after clicking menu-item\n */\n hideOnClick: {\n type: Boolean,\n default: true,\n },\n loop: {\n type: Boolean,\n default: true,\n },\n /**\n * @description whether the tooltip content has an arrow\n */\n showArrow: {\n type: Boolean,\n default: true,\n },\n /**\n * @description delay time before show a dropdown (only works when trigger is `hover`)\n */\n showTimeout: {\n type: Number,\n default: 150,\n },\n /**\n * @description delay time before hide a dropdown (only works when trigger is `hover`)\n */\n hideTimeout: {\n type: Number,\n default: 150,\n },\n /**\n * @description [tabindex](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/tabindex) of Dropdown\n */\n tabindex: {\n type: definePropType([Number, String]),\n default: 0,\n },\n /**\n * @description the max height of menu\n */\n maxHeight: {\n type: definePropType([Number, String]),\n default: '',\n },\n /**\n * @description custom class name for Dropdown's dropdown\n */\n popperClass: useTooltipContentProps.popperClass,\n /**\n * @description custom style for Dropdown's dropdown\n */\n popperStyle: useTooltipContentProps.popperStyle,\n /**\n * @description whether to disable\n */\n disabled: Boolean,\n /**\n * @description the ARIA role attribute for the dropdown menu. Depending on the use case, you may want to change this to 'navigation'\n */\n role: {\n type: String,\n values: roleTypes,\n default: 'menu',\n },\n buttonProps: {\n type: definePropType>(Object),\n },\n /**\n * @description whether the dropdown popup is teleported to the body\n */\n teleported: useTooltipContentProps.teleported,\n /**\n * @description when dropdown inactive and `persistent` is `false` , dropdown menu will be destroyed\n */\n persistent: {\n type: Boolean,\n default: true,\n },\n} as const)\n\nexport const dropdownItemProps = buildProps({\n /**\n * @description a command to be dispatched to Dropdown's `command` callback\n */\n command: {\n type: [Object, String, Number],\n default: () => ({}),\n },\n /**\n * @description whether the item is disabled\n */\n disabled: Boolean,\n /**\n * @description whether a divider is displayed\n */\n divided: Boolean,\n textValue: String,\n /**\n * @description custom icon\n */\n icon: {\n type: iconPropType,\n },\n} as const)\n\nexport const dropdownMenuProps = buildProps({\n onKeydown: { type: definePropType<(e: KeyboardEvent) => void>(Function) },\n})\n\nexport const FIRST_KEYS = [\n EVENT_CODE.down,\n EVENT_CODE.pageDown,\n EVENT_CODE.home,\n]\n\nexport const LAST_KEYS = [EVENT_CODE.up, EVENT_CODE.pageUp, EVENT_CODE.end]\n\nexport const FIRST_LAST_KEYS = [...FIRST_KEYS, ...LAST_KEYS]\n","'use strict';\nvar globalThis = require('../internals/global-this');\nvar NATIVE_ARRAY_BUFFER = require('../internals/array-buffer-basic-detection');\nvar arrayBufferByteLength = require('../internals/array-buffer-byte-length');\n\nvar DataView = globalThis.DataView;\n\nmodule.exports = function (O) {\n if (!NATIVE_ARRAY_BUFFER || arrayBufferByteLength(O) !== 0) return false;\n try {\n // eslint-disable-next-line no-new -- thrower\n new DataView(O);\n return false;\n } catch (error) {\n return true;\n }\n};\n","import type { InjectionKey, Ref } from 'vue'\n\nexport const FOCUS_AFTER_TRAPPED = 'focus-trap.focus-after-trapped'\nexport const FOCUS_AFTER_RELEASED = 'focus-trap.focus-after-released'\nexport const FOCUSOUT_PREVENTED = 'focus-trap.focusout-prevented'\nexport const FOCUS_AFTER_TRAPPED_OPTS: EventInit = {\n cancelable: true,\n bubbles: false,\n}\nexport const FOCUSOUT_PREVENTED_OPTS: EventInit = {\n cancelable: true,\n bubbles: false,\n}\n\nexport const ON_TRAP_FOCUS_EVT = 'focusAfterTrapped'\nexport const ON_RELEASE_FOCUS_EVT = 'focusAfterReleased'\n\nexport type FocusTrapInjectionContext = {\n focusTrapRef: Ref\n onKeydown: (e: KeyboardEvent) => void\n}\n\nexport const FOCUS_TRAP_INJECTION_KEY: InjectionKey =\n Symbol('elFocusTrap')\n","import { computed, ref, shallowRef } from 'vue'\nimport { useResizeObserver } from '@vueuse/core'\nimport { MINIMUM_INPUT_WIDTH } from '@element-plus/constants'\n\nexport function useCalcInputWidth() {\n const calculatorRef = shallowRef()\n const calculatorWidth = ref(0)\n\n const inputStyle = computed(() => ({\n minWidth: `${Math.max(calculatorWidth.value, MINIMUM_INPUT_WIDTH)}px`,\n }))\n\n const resetCalculatorWidth = () => {\n calculatorWidth.value =\n calculatorRef.value?.getBoundingClientRect().width ?? 0\n }\n\n useResizeObserver(calculatorRef, resetCalculatorWidth)\n\n return {\n calculatorRef,\n calculatorWidth,\n inputStyle,\n }\n}\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\n\nvar id = 0;\nvar postfix = Math.random();\nvar toString = uncurryThis(1.1.toString);\n\nmodule.exports = function (key) {\n return 'Symbol(' + (key === undefined ? '' : key) + ')_' + toString(++id + postfix, 36);\n};\n","'use strict';\nvar aSet = require('../internals/a-set');\nvar SetHelpers = require('../internals/set-helpers');\nvar clone = require('../internals/set-clone');\nvar size = require('../internals/set-size');\nvar getSetRecord = require('../internals/get-set-record');\nvar iterateSet = require('../internals/set-iterate');\nvar iterateSimple = require('../internals/iterate-simple');\n\nvar has = SetHelpers.has;\nvar remove = SetHelpers.remove;\n\n// `Set.prototype.difference` method\n// https://tc39.es/ecma262/#sec-set.prototype.difference\nmodule.exports = function difference(other) {\n var O = aSet(this);\n var otherRec = getSetRecord(other);\n var result = clone(O);\n if (size(O) <= otherRec.size) iterateSet(O, function (e) {\n if (otherRec.includes(e)) remove(result, e);\n });\n else iterateSimple(otherRec.getIterator(), function (e) {\n if (has(result, e)) remove(result, e);\n });\n return result;\n};\n","import getNative from './_getNative.js';\nimport root from './_root.js';\n\n/* Built-in method references that are verified to be native. */\nvar Set = getNative(root, 'Set');\n\nexport default Set;\n","'use strict';\nvar $TypeError = TypeError;\n\nmodule.exports = function (argument) {\n if (typeof argument == 'string') return argument;\n throw new $TypeError('Argument is not a string');\n};\n","/**\n * Checks if `value` is classified as an `Array` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array, else `false`.\n * @example\n *\n * _.isArray([1, 2, 3]);\n * // => true\n *\n * _.isArray(document.body.children);\n * // => false\n *\n * _.isArray('abc');\n * // => false\n *\n * _.isArray(_.noop);\n * // => false\n */\nvar isArray = Array.isArray;\n\nexport default isArray;\n","import { computed, getCurrentInstance, inject, ref, unref } from 'vue'\n\nimport type { InjectionKey, Ref } from 'vue'\n\nexport const defaultNamespace = 'el'\nconst statePrefix = 'is-'\n\nconst _bem = (\n namespace: string,\n block: string,\n blockSuffix: string,\n element: string,\n modifier: string\n) => {\n let cls = `${namespace}-${block}`\n if (blockSuffix) {\n cls += `-${blockSuffix}`\n }\n if (element) {\n cls += `__${element}`\n }\n if (modifier) {\n cls += `--${modifier}`\n }\n return cls\n}\n\nexport const namespaceContextKey: InjectionKey> =\n Symbol('namespaceContextKey')\n\nexport const useGetDerivedNamespace = (\n namespaceOverrides?: Ref\n) => {\n const derivedNamespace =\n namespaceOverrides ||\n (getCurrentInstance()\n ? inject(namespaceContextKey, ref(defaultNamespace))\n : ref(defaultNamespace))\n const namespace = computed(() => {\n return unref(derivedNamespace) || defaultNamespace\n })\n return namespace\n}\n\nexport const useNamespace = (\n block: string,\n namespaceOverrides?: Ref\n) => {\n const namespace = useGetDerivedNamespace(namespaceOverrides)\n const b = (blockSuffix = '') =>\n _bem(namespace.value, block, blockSuffix, '', '')\n const e = (element?: string) =>\n element ? _bem(namespace.value, block, '', element, '') : ''\n const m = (modifier?: string) =>\n modifier ? _bem(namespace.value, block, '', '', modifier) : ''\n const be = (blockSuffix?: string, element?: string) =>\n blockSuffix && element\n ? _bem(namespace.value, block, blockSuffix, element, '')\n : ''\n const em = (element?: string, modifier?: string) =>\n element && modifier\n ? _bem(namespace.value, block, '', element, modifier)\n : ''\n const bm = (blockSuffix?: string, modifier?: string) =>\n blockSuffix && modifier\n ? _bem(namespace.value, block, blockSuffix, '', modifier)\n : ''\n const bem = (blockSuffix?: string, element?: string, modifier?: string) =>\n blockSuffix && element && modifier\n ? _bem(namespace.value, block, blockSuffix, element, modifier)\n : ''\n const is: {\n (name: string, state: boolean | undefined): string\n (name: string): string\n } = (name: string, ...args: [boolean | undefined] | []) => {\n const state = args.length >= 1 ? args[0]! : true\n return name && state ? `${statePrefix}${name}` : ''\n }\n\n // for css var\n // --el-xxx: value;\n const cssVar = (object: Record) => {\n const styles: Record = {}\n for (const key in object) {\n if (object[key]) {\n styles[`--${namespace.value}-${key}`] = object[key]\n }\n }\n return styles\n }\n // with block\n const cssVarBlock = (object: Record) => {\n const styles: Record = {}\n for (const key in object) {\n if (object[key]) {\n styles[`--${namespace.value}-${block}-${key}`] = object[key]\n }\n }\n return styles\n }\n\n const cssVarName = (name: string) => `--${namespace.value}-${name}`\n const cssVarBlockName = (name: string) =>\n `--${namespace.value}-${block}-${name}`\n\n return {\n namespace,\n b,\n e,\n m,\n be,\n em,\n bm,\n bem,\n is,\n // css\n cssVar,\n cssVarName,\n cssVarBlock,\n cssVarBlockName,\n }\n}\n\nexport type UseNamespaceReturn = ReturnType\n","import cloneArrayBuffer from './_cloneArrayBuffer.js';\n\n/**\n * Creates a clone of `typedArray`.\n *\n * @private\n * @param {Object} typedArray The typed array to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the cloned typed array.\n */\nfunction cloneTypedArray(typedArray, isDeep) {\n var buffer = isDeep ? cloneArrayBuffer(typedArray.buffer) : typedArray.buffer;\n return new typedArray.constructor(buffer, typedArray.byteOffset, typedArray.length);\n}\n\nexport default cloneTypedArray;\n","/** Used for built-in method references. */\nvar funcProto = Function.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/**\n * Converts `func` to its source code.\n *\n * @private\n * @param {Function} func The function to convert.\n * @returns {string} Returns the source code.\n */\nfunction toSource(func) {\n if (func != null) {\n try {\n return funcToString.call(func);\n } catch (e) {}\n try {\n return (func + '');\n } catch (e) {}\n }\n return '';\n}\n\nexport default toSource;\n","import { isNumber, isObject, isString, isStringNumber } from '../types'\nimport { isClient } from '../browser'\nimport { camelize } from '../strings'\nimport { entriesOf, keysOf } from '../objects'\nimport { debugWarn } from '../error'\n\nimport type { CSSProperties } from 'vue'\n\nconst SCOPE = 'utils/dom/style'\n\nexport const classNameToArray = (cls = '') =>\n cls.split(' ').filter((item) => !!item.trim())\n\nexport const hasClass = (el: Element, cls: string): boolean => {\n if (!el || !cls) return false\n if (cls.includes(' ')) throw new Error('className should not contain space.')\n return el.classList.contains(cls)\n}\n\nexport const addClass = (el: Element, cls: string) => {\n if (!el || !cls.trim()) return\n el.classList.add(...classNameToArray(cls))\n}\n\nexport const removeClass = (el: Element, cls: string) => {\n if (!el || !cls.trim()) return\n el.classList.remove(...classNameToArray(cls))\n}\n\nexport const getStyle = (\n element: HTMLElement,\n styleName: keyof CSSProperties\n): string => {\n if (!isClient || !element || !styleName) return ''\n\n let key = camelize(styleName)\n if (key === 'float') key = 'cssFloat'\n try {\n const style = (element.style as any)[key]\n if (style) return style\n const computed: any = document.defaultView?.getComputedStyle(element, '')\n return computed ? computed[key] : ''\n } catch {\n return (element.style as any)[key]\n }\n}\n\nexport const setStyle = (\n element: HTMLElement,\n styleName: CSSProperties | keyof CSSProperties,\n value?: string | number\n) => {\n if (!element || !styleName) return\n\n if (isObject(styleName)) {\n entriesOf(styleName).forEach(([prop, value]) =>\n setStyle(element, prop, value)\n )\n } else {\n const key: any = camelize(styleName)\n element.style[key] = value as any\n }\n}\n\nexport const removeStyle = (\n element: HTMLElement,\n style: CSSProperties | keyof CSSProperties\n) => {\n if (!element || !style) return\n\n if (isObject(style)) {\n keysOf(style).forEach((prop) => removeStyle(element, prop))\n } else {\n setStyle(element, style, '')\n }\n}\n\nexport function addUnit(value?: string | number, defaultUnit = 'px') {\n if (!value && value !== 0) return ''\n if (isNumber(value) || isStringNumber(value)) {\n return `${value}${defaultUnit}`\n } else if (isString(value)) {\n return value\n }\n debugWarn(SCOPE, 'binding value must be a string or number')\n}\n","!function(e,t){\"object\"==typeof exports&&\"undefined\"!=typeof module?module.exports=t():\"function\"==typeof define&&define.amd?define(t):(e=\"undefined\"!=typeof globalThis?globalThis:e||self).dayjs_plugin_dayOfYear=t()}(this,(function(){\"use strict\";return function(e,t,n){t.prototype.dayOfYear=function(e){var t=Math.round((n(this).startOf(\"day\")-n(this).startOf(\"year\"))/864e5)+1;return null==e?t:this.add(e-t,\"day\")}}}));","'use strict';\nvar $ = require('../internals/export');\nvar call = require('../internals/function-call');\nvar iterate = require('../internals/iterate');\nvar aCallable = require('../internals/a-callable');\nvar anObject = require('../internals/an-object');\nvar getIteratorDirect = require('../internals/get-iterator-direct');\nvar iteratorClose = require('../internals/iterator-close');\nvar iteratorHelperWithoutClosingOnEarlyError = require('../internals/iterator-helper-without-closing-on-early-error');\n\nvar someWithoutClosingOnEarlyError = iteratorHelperWithoutClosingOnEarlyError('some', TypeError);\n\n// `Iterator.prototype.some` method\n// https://tc39.es/ecma262/#sec-iterator.prototype.some\n$({ target: 'Iterator', proto: true, real: true, forced: someWithoutClosingOnEarlyError }, {\n some: function some(predicate) {\n anObject(this);\n try {\n aCallable(predicate);\n } catch (error) {\n iteratorClose(this, 'throw', error);\n }\n\n if (someWithoutClosingOnEarlyError) return call(someWithoutClosingOnEarlyError, this, predicate);\n\n var record = getIteratorDirect(this);\n var counter = 0;\n return iterate(record, function (value, stop) {\n if (predicate(value, counter++)) return stop();\n }, { IS_RECORD: true, INTERRUPTED: true }).stopped;\n }\n});\n","'use strict';\nvar aSet = require('../internals/a-set');\nvar SetHelpers = require('../internals/set-helpers');\nvar clone = require('../internals/set-clone');\nvar getSetRecord = require('../internals/get-set-record');\nvar iterateSimple = require('../internals/iterate-simple');\n\nvar add = SetHelpers.add;\nvar has = SetHelpers.has;\nvar remove = SetHelpers.remove;\n\n// `Set.prototype.symmetricDifference` method\n// https://tc39.es/ecma262/#sec-set.prototype.symmetricdifference\nmodule.exports = function symmetricDifference(other) {\n var O = aSet(this);\n var keysIter = getSetRecord(other).getIterator();\n var result = clone(O);\n iterateSimple(keysIter, function (e) {\n if (has(O, e)) remove(result, e);\n else add(result, e);\n });\n return result;\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar isCallable = require('../internals/is-callable');\nvar store = require('../internals/shared-store');\n\nvar functionToString = uncurryThis(Function.toString);\n\n// this helper broken in `core-js@3.4.1-3.4.4`, so we can't use `shared` helper\nif (!isCallable(store.inspectSource)) {\n store.inspectSource = function (it) {\n return functionToString(it);\n };\n}\n\nmodule.exports = store.inspectSource;\n","import isSymbol from './isSymbol.js';\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0;\n\n/**\n * Converts `value` to a string key if it's not a string or symbol.\n *\n * @private\n * @param {*} value The value to inspect.\n * @returns {string|symbol} Returns the key.\n */\nfunction toKey(value) {\n if (typeof value == 'string' || isSymbol(value)) {\n return value;\n }\n var result = (value + '');\n return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\n}\n\nexport default toKey;\n","import {\n computed,\n getCurrentInstance,\n nextTick,\n onMounted,\n ref,\n watch,\n} from 'vue'\nimport { useTimeoutFn } from '@vueuse/core'\nimport {\n defaultNamespace,\n useId,\n useLockscreen,\n useZIndex,\n} from '@element-plus/hooks'\nimport { UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport {\n addUnit,\n debugWarn,\n isArray,\n isClient,\n isFunction,\n isObject,\n} from '@element-plus/utils'\nimport { useGlobalConfig } from '@element-plus/components/config-provider'\nimport { DEFAULT_DIALOG_TRANSITION } from './constants'\n\nimport type { CSSProperties, Ref, SetupContext, TransitionProps } from 'vue'\nimport type { Arrayable } from '@element-plus/utils'\nimport type { DialogEmits, DialogProps } from './dialog'\n\nconst COMPONENT_NAME = 'ElDialog'\n\nexport const useDialog = (\n props: DialogProps,\n targetRef: Ref\n) => {\n const instance = getCurrentInstance()!\n const emit = instance.emit as SetupContext['emit']\n const { nextZIndex } = useZIndex()\n\n let lastPosition = ''\n const titleId = useId()\n const bodyId = useId()\n const visible = ref(false)\n const closed = ref(false)\n const rendered = ref(false) // when destroyOnClose is true, we initialize it as false vise versa\n const zIndex = ref(props.zIndex ?? nextZIndex())\n\n let openTimer: (() => void) | undefined = undefined\n let closeTimer: (() => void) | undefined = undefined\n\n const config = useGlobalConfig()\n\n const namespace = computed(() => config.value?.namespace ?? defaultNamespace)\n const globalConfig = computed(() => config.value?.dialog)\n\n const style = computed(() => {\n const style: CSSProperties = {}\n const varPrefix = `--${namespace.value}-dialog` as const\n if (!props.fullscreen) {\n if (props.top) {\n style[`${varPrefix}-margin-top`] = props.top\n }\n const width = addUnit(props.width)\n if (width) {\n style[`${varPrefix}-width`] = width\n }\n }\n return style\n })\n\n const _draggable = computed(\n () =>\n (props.draggable ?? globalConfig.value?.draggable ?? false) &&\n !props.fullscreen\n )\n\n const _alignCenter = computed(\n () => props.alignCenter ?? globalConfig.value?.alignCenter ?? false\n )\n\n const _overflow = computed(\n () => props.overflow ?? globalConfig.value?.overflow ?? false\n )\n\n const overlayDialogStyle = computed(() => {\n if (_alignCenter.value) {\n return { display: 'flex' }\n }\n return {}\n })\n\n const transitionConfig = computed(() => {\n const transition =\n props.transition ??\n globalConfig.value?.transition ??\n DEFAULT_DIALOG_TRANSITION\n const baseConfig = {\n name: transition,\n onAfterEnter: afterEnter,\n onBeforeLeave: beforeLeave,\n onAfterLeave: afterLeave,\n }\n if (isObject(transition)) {\n const config = { ...transition } as TransitionProps\n const _mergeHook = (\n userHook: Arrayable<(el: Element) => void> | undefined,\n defaultHook: () => void\n ) => {\n return (el: Element) => {\n if (isArray(userHook)) {\n userHook.forEach((fn) => {\n if (isFunction(fn)) fn(el)\n })\n } else if (isFunction(userHook)) {\n userHook(el)\n }\n defaultHook()\n }\n }\n config.onAfterEnter = _mergeHook(config.onAfterEnter, afterEnter)\n config.onBeforeLeave = _mergeHook(config.onBeforeLeave, beforeLeave)\n config.onAfterLeave = _mergeHook(config.onAfterLeave, afterLeave)\n if (!config.name) {\n config.name = DEFAULT_DIALOG_TRANSITION\n debugWarn(\n COMPONENT_NAME,\n `transition.name is missing when using object syntax, fallback to '${DEFAULT_DIALOG_TRANSITION}'`\n )\n }\n return config\n }\n\n return baseConfig\n })\n\n function afterEnter() {\n emit('opened')\n }\n\n function afterLeave() {\n emit('closed')\n emit(UPDATE_MODEL_EVENT, false)\n if (props.destroyOnClose) {\n rendered.value = false\n }\n }\n\n function beforeLeave() {\n emit('close')\n }\n\n function open() {\n closeTimer?.()\n openTimer?.()\n\n if (props.openDelay && props.openDelay > 0) {\n ;({ stop: openTimer } = useTimeoutFn(() => doOpen(), props.openDelay))\n } else {\n doOpen()\n }\n }\n\n function close() {\n openTimer?.()\n closeTimer?.()\n\n if (props.closeDelay && props.closeDelay > 0) {\n ;({ stop: closeTimer } = useTimeoutFn(() => doClose(), props.closeDelay))\n } else {\n doClose()\n }\n }\n\n function handleClose() {\n function hide(shouldCancel?: boolean) {\n if (shouldCancel) return\n closed.value = true\n visible.value = false\n }\n\n if (props.beforeClose) {\n props.beforeClose(hide)\n } else {\n close()\n }\n }\n\n function onModalClick() {\n if (props.closeOnClickModal) {\n handleClose()\n }\n }\n\n function doOpen() {\n if (!isClient) return\n visible.value = true\n }\n\n function doClose() {\n visible.value = false\n }\n\n function onOpenAutoFocus() {\n emit('openAutoFocus')\n }\n\n function onCloseAutoFocus() {\n emit('closeAutoFocus')\n }\n\n function onFocusoutPrevented(event: CustomEvent) {\n if (event.detail?.focusReason === 'pointer') {\n event.preventDefault()\n }\n }\n\n if (props.lockScroll) {\n useLockscreen(visible)\n }\n\n function onCloseRequested() {\n if (props.closeOnPressEscape) {\n handleClose()\n }\n }\n\n watch(\n () => props.zIndex,\n () => {\n zIndex.value = props.zIndex ?? nextZIndex()\n }\n )\n\n watch(\n () => props.modelValue,\n (val) => {\n if (val) {\n closed.value = false\n open()\n rendered.value = true // enables lazy rendering\n zIndex.value = props.zIndex ?? nextZIndex()\n // this.$el.addEventListener('scroll', this.updatePopper)\n nextTick(() => {\n emit('open')\n if (targetRef.value) {\n targetRef.value.parentElement!.scrollTop = 0\n targetRef.value.parentElement!.scrollLeft = 0\n targetRef.value.scrollTop = 0\n }\n })\n } else {\n // this.$el.removeEventListener('scroll', this.updatePopper\n if (visible.value) {\n close()\n }\n }\n }\n )\n\n watch(\n () => props.fullscreen,\n (val) => {\n if (!targetRef.value) return\n if (val) {\n lastPosition = targetRef.value.style.transform\n targetRef.value.style.transform = ''\n } else {\n targetRef.value.style.transform = lastPosition\n }\n }\n )\n\n onMounted(() => {\n if (props.modelValue) {\n visible.value = true\n rendered.value = true // enables lazy rendering\n open()\n }\n })\n\n return {\n afterEnter,\n afterLeave,\n beforeLeave,\n handleClose,\n onModalClick,\n close,\n doClose,\n onOpenAutoFocus,\n onCloseAutoFocus,\n onCloseRequested,\n onFocusoutPrevented,\n titleId,\n bodyId,\n closed,\n style,\n overlayDialogStyle,\n rendered,\n visible,\n zIndex,\n transitionConfig,\n _draggable,\n _alignCenter,\n _overflow,\n }\n}\n","import { computed, getCurrentInstance } from 'vue'\nimport { fromPairs } from 'lodash-unified'\nimport { debugWarn } from '@element-plus/utils'\n\nimport type { ComputedRef } from 'vue'\n\ninterface Params {\n excludeListeners?: boolean\n excludeKeys?: ComputedRef\n}\n\nconst DEFAULT_EXCLUDE_KEYS = ['class', 'style']\nconst LISTENER_PREFIX = /^on[A-Z]/\n\nexport const useAttrs = (\n params: Params = {}\n): ComputedRef> => {\n const { excludeListeners = false, excludeKeys } = params\n const allExcludeKeys = computed(() => {\n return (excludeKeys?.value || []).concat(DEFAULT_EXCLUDE_KEYS)\n })\n\n const instance = getCurrentInstance()\n if (!instance) {\n debugWarn(\n 'use-attrs',\n 'getCurrentInstance() returned null. useAttrs() must be called at the top of a setup function'\n )\n return computed(() => ({}))\n }\n\n return computed(() =>\n fromPairs(\n Object.entries(instance.proxy?.$attrs!).filter(\n ([key]) =>\n !allExcludeKeys.value.includes(key) &&\n !(excludeListeners && LISTENER_PREFIX.test(key))\n )\n )\n )\n}\n","'use strict';\n// eslint-disable-next-line es/no-object-getownpropertysymbols -- safe\nexports.f = Object.getOwnPropertySymbols;\n","'use strict';\nvar fails = require('../internals/fails');\n\n// Detect IE8's incomplete defineProperty implementation\nmodule.exports = !fails(function () {\n // eslint-disable-next-line es/no-object-defineproperty -- required for testing\n return Object.defineProperty({}, 1, { get: function () { return 7; } })[1] !== 7;\n});\n","export interface CacheOptions {\r\n // initial value of _value.\r\n _initialValue: Value;\r\n // Custom comparison function if shallow compare isn't enough. Returns true if nothing changed.\r\n _equal?: EqualCachePropFunction;\r\n // If true always updates _value and _previous, otherwise they update only when they changed.\r\n _alwaysUpdateValues?: boolean;\r\n}\r\n\r\nexport type CacheValues = [value: T, changed: boolean, previous?: T];\r\n\r\nexport type EqualCachePropFunction = (currentVal: Value, newVal: Value) => boolean;\r\n\r\nexport type CacheUpdater = (current: Value, previous?: Value) => Value;\r\n\r\nexport type UpdateCacheContextual = (newValue: Value, force?: boolean) => CacheValues;\r\n\r\nexport type UpdateCache = (force?: boolean) => CacheValues;\r\n\r\nexport type GetCurrentCache = (force?: boolean) => CacheValues;\r\n\r\nexport type Cache = [UpdateCache, GetCurrentCache];\r\n\r\nexport type CacheContextual = [UpdateCacheContextual, GetCurrentCache];\r\n\r\ntype CreateCache = {\r\n (options: CacheOptions): CacheContextual;\r\n (options: CacheOptions, update: CacheUpdater): Cache;\r\n (\r\n options: CacheOptions,\r\n update?: CacheUpdater\r\n ): CacheContextual | Cache;\r\n};\r\n\r\nexport const createCache: CreateCache = (\r\n options: CacheOptions,\r\n update?: CacheUpdater\r\n): CacheContextual | Cache => {\r\n const { _initialValue, _equal, _alwaysUpdateValues } = options;\r\n let _value: Value = _initialValue;\r\n let _previous: Value | undefined;\r\n\r\n const cacheUpdateContextual: UpdateCacheContextual = (newValue, force?) => {\r\n const curr = _value;\r\n\r\n const newVal = newValue;\r\n const changed = force || (_equal ? !_equal(curr, newVal) : curr !== newVal);\r\n\r\n if (changed || _alwaysUpdateValues) {\r\n _value = newVal;\r\n _previous = curr;\r\n }\r\n\r\n return [_value, changed, _previous];\r\n };\r\n const cacheUpdateIsolated: UpdateCache = (force?) =>\r\n cacheUpdateContextual(update!(_value, _previous), force);\r\n\r\n const getCurrentCache: GetCurrentCache = (force?: boolean) => [\r\n _value,\r\n !!force, // changed\r\n _previous,\r\n ];\r\n\r\n return [update ? cacheUpdateIsolated : cacheUpdateContextual, getCurrentCache] as\r\n | CacheContextual\r\n | Cache;\r\n};\r\n","export const isBrowser =\r\n // deno has the global `window` defined\r\n typeof window !== 'undefined' &&\r\n // make sure HTML element is available\r\n typeof HTMLElement !== 'undefined' &&\r\n // make sure document is defined\r\n !!window.document;\r\n","import { isBrowser } from '../compatibility/isBrowser';\r\n\r\nexport const wnd = (isBrowser ? window : {}) as typeof window;\r\nexport const mathMax = Math.max;\r\nexport const mathMin = Math.min;\r\nexport const mathRound = Math.round;\r\nexport const mathFloor = Math.floor;\r\nexport const mathCeil = Math.ceil;\r\nexport const mathAbs = Math.abs;\r\nexport const mathSign = Math.sign;\r\nexport const cAF = wnd.cancelAnimationFrame;\r\nexport const rAF = wnd.requestAnimationFrame;\r\nexport const setT = wnd.setTimeout;\r\nexport const clearT = wnd.clearTimeout;\r\n","import { wnd } from '../utils/alias';\r\n\r\nconst getApi = (name: string) =>\r\n (typeof wnd[name as keyof typeof wnd] !== 'undefined'\r\n ? wnd[name as keyof typeof wnd]\r\n : undefined) as T;\r\n\r\nexport const MutationObserverConstructor = getApi('MutationObserver');\r\nexport const IntersectionObserverConstructor =\r\n getApi('IntersectionObserver');\r\nexport const ResizeObserverConstructor = getApi('ResizeObserver');\r\nexport const scrollT = getApi AnimationTimeline>('ScrollTimeline');\r\n","/* eslint-disable @typescript-eslint/no-explicit-any */\r\nimport type { PlainObject } from '../../typings';\r\n\r\nexport const isUndefined = (obj: any): obj is undefined => obj === undefined;\r\n\r\nexport const isNull = (obj: any): obj is null => obj === null;\r\n\r\nexport const type = (obj: any): string =>\r\n isUndefined(obj) || isNull(obj)\r\n ? `${obj}`\r\n : Object.prototype.toString\r\n .call(obj)\r\n .replace(/^\\[object (.+)\\]$/, '$1')\r\n .toLowerCase();\r\n\r\nexport const isNumber = (obj: any): obj is number => typeof obj === 'number';\r\n\r\nexport const isString = (obj: any): obj is string => typeof obj === 'string';\r\n\r\nexport const isBoolean = (obj: any): obj is boolean => typeof obj === 'boolean';\r\n\r\nexport const isFunction = (obj: any): obj is (...args: any[]) => any => typeof obj === 'function';\r\n\r\nexport const isArray = (obj: any): obj is Array => Array.isArray(obj);\r\n\r\nexport const isObject = (obj: any): obj is object =>\r\n typeof obj === 'object' && !isArray(obj) && !isNull(obj);\r\n\r\n/**\r\n * Returns true if the given object is array like, false otherwise.\r\n * @param obj The Object\r\n */\r\nexport const isArrayLike = (obj: any): obj is ArrayLike => {\r\n const length = !!obj && obj.length;\r\n const lengthCorrectFormat = isNumber(length) && length > -1 && length % 1 == 0;\r\n\r\n return isArray(obj) || (!isFunction(obj) && lengthCorrectFormat)\r\n ? length > 0 && isObject(obj)\r\n ? length - 1 in obj\r\n : true\r\n : false;\r\n};\r\n\r\n/**\r\n * Returns true if the given object is a \"plain\" (e.g. { key: value }) object, false otherwise.\r\n * @param obj The Object.\r\n */\r\nexport const isPlainObject = (obj: any): obj is PlainObject =>\r\n !!obj && obj.constructor === Object;\r\n\r\n/**\r\n * Checks whether the given object is a HTMLElement.\r\n * @param obj The object which shall be checked.\r\n */\r\nexport const isHTMLElement = (obj: any): obj is HTMLElement => obj instanceof HTMLElement;\r\n\r\n/**\r\n * Checks whether the given object is a Element.\r\n * @param obj The object which shall be checked.\r\n */\r\nexport const isElement = (obj: any): obj is Element => obj instanceof Element;\r\n","/* eslint-disable @typescript-eslint/no-explicit-any */\r\nimport type { PlainObject } from '../../typings';\r\nimport { isArray, isArrayLike, isString } from './types';\r\n\r\ntype RunEachItem = ((...args: any) => any | any[]) | false | null | undefined;\r\n\r\nexport function each | ReadonlyArray>(\r\n array: T,\r\n callback: (\r\n value: T extends Array | ReadonlyArray ? V : never,\r\n index: number,\r\n source: T\r\n ) => boolean | unknown\r\n): T;\r\nexport function each>(\r\n arrayLikeObject: T,\r\n callback: (\r\n value: T extends ArrayLike ? V : never,\r\n index: number,\r\n source: T\r\n ) => boolean | unknown\r\n): T;\r\nexport function each(\r\n obj: T,\r\n callback: (value: any, key: string, source: T) => boolean | unknown\r\n): T;\r\nexport function each(\r\n source: Array | ArrayLike | ReadonlyArray | PlainObject,\r\n callback: (value: any, indexOrKey: any, source: any) => boolean | unknown\r\n): Array | ArrayLike | ReadonlyArray | Set | PlainObject {\r\n if (isArrayLike(source)) {\r\n for (let i = 0; i < source.length; i++) {\r\n if (callback(source[i], i, source) === false) {\r\n break;\r\n }\r\n }\r\n } else if (source) {\r\n // cant use support func keys here due to circular dep\r\n each(Object.keys(source), (key) => callback(source[key], key, source));\r\n }\r\n return source;\r\n}\r\n\r\n/**\r\n * Returns true when the passed item is in the passed array and false otherwise.\r\n * @param arr The array.\r\n * @param item The item.\r\n * @returns Whether the item is in the array.\r\n */\r\nexport const inArray = (arr: T[] | readonly T[], item: T): boolean =>\r\n arr.indexOf(item) >= 0;\r\n\r\n/**\r\n * Concats two arrays and returns an new array without modifying any of the passed arrays.\r\n * @param a Array A.\r\n * @param b Array B.\r\n * @returns A new array which has the entries of both arrays.\r\n */\r\nexport const concat = (a: T[] | ReadonlyArray, b: T[] | ReadonlyArray): T[] => a.concat(b);\r\n\r\n/**\r\n * Pushesh all given items into the given array and returns it.\r\n * @param array The array the items shall be pushed into.\r\n * @param items The items which shall be pushed into the array.\r\n */\r\nexport const push = (array: T[], items: T | ArrayLike, arrayIsSingleItem?: boolean): T[] => {\r\n if (!arrayIsSingleItem && !isString(items) && isArrayLike(items)) {\r\n Array.prototype.push.apply(array, items as T[]);\r\n } else {\r\n array.push(items as T);\r\n }\r\n return array;\r\n};\r\n\r\n/**\r\n * Creates a shallow-copied Array instance from an array-like or iterable object.\r\n * @param arr The object from which the array instance shall be created.\r\n */\r\nexport const from = (arr?: ArrayLike | Set) => Array.from(arr || []);\r\n\r\n/**\r\n * Creates an array if the passed value is not an array, or returns the value if it is.\r\n * If the passed value is an array like structure and not a string it will be converted into an array.\r\n * @param value The value.\r\n * @returns An array which represents the passed value(s).\r\n */\r\nexport const createOrKeepArray = (value: T | T[] | ArrayLike): T[] => {\r\n if (isArray(value)) {\r\n return value;\r\n }\r\n return !isString(value) && isArrayLike(value) ? from(value) : [value];\r\n};\r\n\r\n/**\r\n * Check whether the passed array is empty.\r\n * @param array The array which shall be checked.\r\n */\r\nexport const isEmptyArray = (array: any[] | null | undefined): boolean => !!array && !array.length;\r\n\r\n/**\r\n * Deduplicates all items of the array.\r\n * @param array The array to be deduplicated.\r\n * @returns The deduplicated array.\r\n */\r\nexport const deduplicateArray = (array: T): T => from(new Set(array)) as T;\r\n\r\n/**\r\n * Calls all functions in the passed array/set of functions.\r\n * @param arr The array filled with function which shall be called.\r\n * @param args The args with which each function is called.\r\n * @param keep True when the Set / array should not be cleared afterwards, false otherwise.\r\n */\r\nexport const runEachAndClear = (arr: RunEachItem[], args?: any[], keep?: boolean): void => {\r\n // eslint-disable-next-line prefer-spread\r\n const runFn = (fn: RunEachItem) => (fn ? fn.apply(undefined, args || []) : true); // return true when fn is falsy to not break the loop\r\n each(arr, runFn);\r\n if (!keep) {\r\n (arr as any[]).length = 0;\r\n }\r\n};\r\n","export const strPaddingTop = 'paddingTop';\r\nexport const strPaddingRight = 'paddingRight';\r\nexport const strPaddingLeft = 'paddingLeft';\r\nexport const strPaddingBottom = 'paddingBottom';\r\nexport const strMarginLeft = 'marginLeft';\r\nexport const strMarginRight = 'marginRight';\r\nexport const strMarginBottom = 'marginBottom';\r\nexport const strOverflowX = 'overflowX';\r\nexport const strOverflowY = 'overflowY';\r\nexport const strWidth = 'width';\r\nexport const strHeight = 'height';\r\nexport const strVisible = 'visible';\r\nexport const strHidden = 'hidden';\r\nexport const strScroll = 'scroll';\r\n\r\nexport const capitalizeFirstLetter = (str: string | number | false | null | undefined): string => {\r\n const finalStr = String(str || '');\r\n return finalStr ? finalStr[0].toUpperCase() + finalStr.slice(1) : '';\r\n};\r\n","import type { WH } from '../dom/dimensions';\r\nimport type { XY } from '../dom/offset';\r\nimport type { TRBL } from '../dom/style';\r\nimport type { PlainObject } from '../../typings';\r\nimport { each } from './array';\r\nimport { mathRound } from './alias';\r\nimport { strHeight, strWidth } from './strings';\r\n\r\n/**\r\n * Compares two objects and returns true if all values of the passed prop names are identical, false otherwise or if one of the two object is falsy.\r\n * @param a Object a.\r\n * @param b Object b.\r\n * @param props The props which shall be compared.\r\n */\r\nexport const equal = (\r\n a: T | undefined,\r\n b: T | undefined,\r\n props: Array | ReadonlyArray,\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n propMutation?: ((value: any) => any) | null | false\r\n): boolean => {\r\n if (a && b) {\r\n let result = true;\r\n each(props, (prop) => {\r\n const compareA = propMutation ? propMutation(a[prop]) : a[prop];\r\n const compareB = propMutation ? propMutation(b[prop]) : b[prop];\r\n if (compareA !== compareB) {\r\n result = false;\r\n }\r\n });\r\n return result;\r\n }\r\n return false;\r\n};\r\n\r\n/**\r\n * Compares object a with object b and returns true if both have the same property values, false otherwise.\r\n * Also returns false if one of the objects is undefined or null.\r\n * @param a Object a.\r\n * @param b Object b.\r\n */\r\nexport const equalWH = (a?: Partial>, b?: Partial>) =>\r\n equal>>(a, b, ['w', 'h']);\r\n\r\n/**\r\n * Compares object a with object b and returns true if both have the same property values, false otherwise.\r\n * Also returns false if one of the objects is undefined or null.\r\n * @param a Object a.\r\n * @param b Object b.\r\n */\r\nexport const equalXY = (a?: Partial>, b?: Partial>) =>\r\n equal>>(a, b, ['x', 'y']);\r\n\r\n/**\r\n * Compares object a with object b and returns true if both have the same property values, false otherwise.\r\n * Also returns false if one of the objects is undefined or null.\r\n * @param a Object a.\r\n * @param b Object b.\r\n */\r\nexport const equalTRBL = (a?: TRBL, b?: TRBL) => equal(a, b, ['t', 'r', 'b', 'l']);\r\n\r\n/**\r\n * Compares two DOM Rects for their equality of their width and height properties\r\n * Also returns false if one of the DOM Rects is undefined or null.\r\n * @param a DOM Rect a.\r\n * @param b DOM Rect b.\r\n * @param round Whether the values should be rounded.\r\n */\r\nexport const equalBCRWH = (a?: DOMRect, b?: DOMRect, round?: boolean) =>\r\n equal(a, b, [strWidth, strHeight], round && ((value) => mathRound(value)));\r\n","/* eslint-disable @typescript-eslint/no-explicit-any */\r\nimport { isNumber, isFunction } from './types';\r\nimport { from } from './array';\r\nimport { rAF, cAF, setT, clearT } from './alias';\r\n\r\ntype DebouncerFn = (task: () => void) => () => void;\r\n\r\nexport type DebounceTiming = { _debouncer: DebouncerFn } | number | false | null | undefined;\r\nexport type DebounceLeading = boolean | null | undefined;\r\n\r\nexport interface DebounceOptions any> {\r\n /**\r\n * The timing for debouncing. If false, null or undefined, no debounce is applied.\r\n */\r\n _debounceTiming?: DebounceTiming | (() => DebounceTiming);\r\n /**\r\n * The timing which determines when the debounced will be called even when the debounce timing did not call it yet.\r\n */\r\n _maxDebounceTiming?: DebounceTiming | (() => DebounceTiming);\r\n /**\r\n * Defines the calling on the leading edge of the timeout.\r\n */\r\n _leading?: DebounceLeading | (() => DebounceLeading);\r\n /**\r\n * Function which merges parameters for each canceled debounce.\r\n * If parameters can't be merged the function will return null, otherwise it returns the merged parameters.\r\n */\r\n _mergeParams?: (\r\n prev: Parameters,\r\n curr: Parameters\r\n ) => Parameters | false | null | undefined;\r\n}\r\n\r\nexport interface Debounced any> {\r\n (...args: Parameters): ReturnType;\r\n _flush(): void;\r\n}\r\n\r\nexport const bind = (\r\n fn: (...args: [...A, ...B]) => R,\r\n ...args: A\r\n): ((...args: B) => R) => fn.bind(0, ...args);\r\n\r\n/**\r\n * Creates a timeout and cleartimeout tuple. The timeout function always clears the previously created timeout before it runs.\r\n * @param timeout The timeout in ms. If no timeout (or 0) is passed requestAnimationFrame is used instead of setTimeout.\r\n * @returns A tuple with the timeout function as the first value and the clearTimeout function as the second value.\r\n */\r\nexport const selfClearTimeout = (timeout?: number | (() => number)) => {\r\n let id: number;\r\n const setTFn = timeout ? setT : rAF!;\r\n const clearTFn = timeout ? clearT : cAF!;\r\n return [\r\n (callback: () => any) => {\r\n clearTFn(id);\r\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\r\n // @ts-ignore\r\n id = setTFn(() => callback(), isFunction(timeout) ? timeout() : timeout);\r\n },\r\n () => clearTFn(id),\r\n ] as [timeout: (callback: () => any) => void, clear: () => void];\r\n};\r\n\r\nconst getDebouncer = (\r\n debounceTiming: DebounceTiming | (() => DebounceTiming)\r\n): DebouncerFn | false | null | undefined | void => {\r\n const debounceTimingResult = isFunction(debounceTiming) ? debounceTiming() : debounceTiming;\r\n if (isNumber(debounceTimingResult)) {\r\n const schedule = debounceTimingResult ? setT! : rAF!;\r\n const clear = debounceTimingResult ? clearT : cAF;\r\n return (task) => {\r\n const timeoutId = schedule!(\r\n () => task(),\r\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\r\n // @ts-ignore\r\n debounceTimingResult\r\n );\r\n return () => {\r\n clear!(timeoutId);\r\n };\r\n };\r\n }\r\n\r\n return debounceTimingResult && debounceTimingResult._debouncer;\r\n};\r\n\r\n/**\r\n * Debounces the given function either with a timeout or a animation frame.\r\n * @param functionToDebounce The function which shall be debounced.\r\n * @param options Options for debouncing.\r\n */\r\nexport const debounce = any>(\r\n functionToDebounce: FunctionToDebounce,\r\n options?: DebounceOptions\r\n): Debounced => {\r\n const {\r\n _debounceTiming: _timeout,\r\n _maxDebounceTiming: _maxDelay,\r\n _leading,\r\n _mergeParams,\r\n } = options || {};\r\n let cancelMaxTimeoutDebouncer: (() => void) | undefined;\r\n let cancelTimeoutDebounder: (() => void) | undefined;\r\n let prevArguments: Parameters | null | undefined;\r\n let leadingInvoked: boolean | undefined;\r\n\r\n const invokeFunctionToDebounce = function (args: Parameters) {\r\n if (cancelTimeoutDebounder) {\r\n cancelTimeoutDebounder();\r\n }\r\n if (cancelMaxTimeoutDebouncer) {\r\n cancelMaxTimeoutDebouncer();\r\n }\r\n\r\n leadingInvoked = cancelTimeoutDebounder = cancelMaxTimeoutDebouncer = prevArguments = undefined;\r\n // eslint-disable-next-line\r\n // @ts-ignore\r\n functionToDebounce.apply(this, args);\r\n };\r\n\r\n const mergeParms = (\r\n curr: Parameters\r\n ): Parameters | false | null | undefined =>\r\n _mergeParams && prevArguments ? _mergeParams(prevArguments, curr) : curr;\r\n\r\n const flush = () => {\r\n /* istanbul ignore next */\r\n if (cancelTimeoutDebounder && prevArguments) {\r\n invokeFunctionToDebounce(mergeParms(prevArguments) || prevArguments);\r\n }\r\n };\r\n\r\n const debouncedFn = function () {\r\n // eslint-disable-next-line prefer-rest-params\r\n const args: Parameters = from(arguments) as Parameters;\r\n const timeoutDebouncer = getDebouncer(_timeout);\r\n\r\n if (timeoutDebouncer) {\r\n const leading = typeof _leading === 'function' ? _leading() : _leading;\r\n const maxDelayDebouncer = getDebouncer(_maxDelay);\r\n const mergeParamsResult = mergeParms(args);\r\n const invokedArgs = mergeParamsResult || args;\r\n const boundInvoke = invokeFunctionToDebounce.bind(0, invokedArgs);\r\n\r\n if (cancelTimeoutDebounder) {\r\n cancelTimeoutDebounder();\r\n }\r\n\r\n if (leading && !leadingInvoked) {\r\n boundInvoke();\r\n leadingInvoked = true;\r\n cancelTimeoutDebounder = timeoutDebouncer(() => (leadingInvoked = undefined));\r\n } else {\r\n cancelTimeoutDebounder = timeoutDebouncer(boundInvoke);\r\n\r\n if (maxDelayDebouncer && !cancelMaxTimeoutDebouncer) {\r\n cancelMaxTimeoutDebouncer = maxDelayDebouncer(flush);\r\n }\r\n }\r\n\r\n prevArguments = invokedArgs;\r\n } else {\r\n invokeFunctionToDebounce(args);\r\n }\r\n };\r\n debouncedFn._flush = flush;\r\n\r\n return debouncedFn as Debounced;\r\n};\r\n","/* eslint-disable @typescript-eslint/no-explicit-any */\r\nimport type { PlainObject } from '../../typings';\r\nimport { isArray, isFunction, isPlainObject, isNull } from './types';\r\nimport { each } from './array';\r\n\r\n/**\r\n * Determines whether the passed object has a property with the passed name.\r\n * @param obj The object.\r\n * @param prop The name of the property.\r\n */\r\nexport const hasOwnProperty = (obj: any, prop: string | number | symbol): boolean =>\r\n Object.prototype.hasOwnProperty.call(obj, prop);\r\n\r\n/**\r\n * Returns the names of the enumerable string properties and methods of an object.\r\n * @param obj The object of which the properties shall be returned.\r\n */\r\nexport const keys = (obj: any): Array => (obj ? Object.keys(obj) : []);\r\n\r\ntype AssignDeep = {\r\n (target: T, object1: U): T & U;\r\n (target: T, object1: U, object2: V): T & U & V;\r\n (target: T, object1: U, object2: V, object3: W): T & U & V & W;\r\n (target: T, object1: U, object2: V, object3: W, object4: X): T & U & V & W & X;\r\n (\r\n target: T,\r\n object1: U,\r\n object2: V,\r\n object3: W,\r\n object4: X,\r\n object5: Y\r\n ): T & U & V & W & X & Y;\r\n (\r\n target: T,\r\n object1?: U,\r\n object2?: V,\r\n object3?: W,\r\n object4?: X,\r\n object5?: Y,\r\n object6?: Z\r\n ): T & U & V & W & X & Y & Z;\r\n};\r\n\r\n// https://github.com/jquery/jquery/blob/master/src/core.js#L116\r\nexport const assignDeep: AssignDeep = (\r\n target: T,\r\n object1?: U,\r\n object2?: V,\r\n object3?: W,\r\n object4?: X,\r\n object5?: Y,\r\n object6?: Z\r\n): T & U & V & W & X & Y & Z => {\r\n const sources: Array = [object1, object2, object3, object4, object5, object6];\r\n\r\n // Handle case when target is a string or something (possible in deep copy)\r\n if ((typeof target !== 'object' || isNull(target)) && !isFunction(target)) {\r\n target = {} as T;\r\n }\r\n\r\n each(sources, (source) => {\r\n // Extend the base object\r\n each(source, (_, key) => {\r\n const copy: any = source[key];\r\n\r\n // Prevent Object.prototype pollution\r\n // Prevent never-ending loop\r\n if (target === copy) {\r\n return true;\r\n }\r\n\r\n const copyIsArray = isArray(copy);\r\n\r\n // Recurse if we're merging plain objects or arrays\r\n if (copy && isPlainObject(copy)) {\r\n const src = target[key as keyof T];\r\n let clone: any = src;\r\n\r\n // Ensure proper type for the source value\r\n if (copyIsArray && !isArray(src)) {\r\n clone = [];\r\n } else if (!copyIsArray && !isPlainObject(src)) {\r\n clone = {};\r\n }\r\n\r\n // Never move original objects, clone them\r\n target[key as keyof T] = assignDeep(clone, copy) as any;\r\n } else {\r\n target[key as keyof T] = copyIsArray ? copy.slice() : copy;\r\n }\r\n });\r\n });\r\n\r\n // Return the modified object\r\n return target as any;\r\n};\r\n\r\nexport const removeUndefinedProperties = (target: T, deep?: boolean): T =>\r\n each(assignDeep({}, target), (value, key, copy) => {\r\n if (value === undefined) {\r\n delete copy[key];\r\n } else if (deep && value && isPlainObject(value)) {\r\n copy[key as keyof typeof copy] = removeUndefinedProperties(value, deep) as any;\r\n }\r\n });\r\n\r\n/**\r\n * Returns true if the given object is empty, false otherwise.\r\n * @param obj The Object.\r\n */\r\nexport const isEmptyObject = (obj: any): boolean => !keys(obj).length;\r\n","export const noop = () => {};\r\n","import { mathMax, mathMin } from './alias';\r\n\r\n/**\r\n * Caps the passed number between the `min` and `max` bounds.\r\n * @param min The min bound.\r\n * @param max The max bound.\r\n * @param number The number to be capped.\r\n * @returns The capped number between min and max.\r\n */\r\nexport const capNumber = (min: number, max: number, number: number) =>\r\n mathMax(min, mathMin(max, number));\r\n","import type { HTMLElementTarget } from './types';\r\nimport { bind, deduplicateArray, each, from, isArray } from '../utils';\r\n\r\nexport type AttributeElementTarget = HTMLElementTarget | Element;\r\n\r\nexport type DomTokens = string | string[] | false | null | undefined | void;\r\n\r\nexport const getDomTokensArray = (tokens: DomTokens) =>\r\n deduplicateArray((isArray(tokens) ? tokens : (tokens || '').split(' ')).filter((token) => token));\r\n\r\n/**\r\n * Gets a attribute with the given attribute of the given element.\r\n * @param elm The element of which the attribute shall be get.\r\n * @param attrName The attribute name which shall be get.\r\n * @returns The attribute value or `null` when the attribute is not set or `false` if the element is undefined.\r\n */\r\nexport const getAttr = (elm: AttributeElementTarget, attrName: string) =>\r\n elm && elm.getAttribute(attrName);\r\n\r\n/**\r\n * Returns whether the given attribute exists on the given element.\r\n * @param elm The element.\r\n * @param attrName The attribute.\r\n * @returns A Truthy value indicates a present attrubte.\r\n */\r\nexport const hasAttr = (elm: AttributeElementTarget, attrName: string) =>\r\n elm && elm.hasAttribute(attrName);\r\n\r\n/**\r\n * Sets the given attributes to the given element.\r\n * @param elm The element of which the attributes shall be removed.\r\n * @param attrName The attribute names separated by a space.\r\n */\r\nexport const setAttrs = (\r\n elm: AttributeElementTarget,\r\n attrNames: string | string[],\r\n value: string | number | false | null | undefined\r\n) => {\r\n each(getDomTokensArray(attrNames), (attrName) => {\r\n if (elm) {\r\n elm.setAttribute(attrName, String(value || ''));\r\n }\r\n });\r\n};\r\n\r\n/**\r\n * Removes the given attributes from the given element.\r\n * @param elm The element of which the attribute shall be removed.\r\n * @param attrName The attribute names separated by a space.\r\n */\r\nexport const removeAttrs = (elm: AttributeElementTarget, attrNames: string | string[]): void => {\r\n each(getDomTokensArray(attrNames), (attrName) => elm && elm.removeAttribute(attrName));\r\n};\r\n\r\nexport const domTokenListAttr = (elm: AttributeElementTarget, attrName: string) => {\r\n const initialArr = getDomTokensArray(getAttr(elm, attrName));\r\n const setElmAttr = bind(setAttrs, elm, attrName);\r\n const domTokenListOperation = (operationTokens: DomTokens, operation: 'add' | 'delete') => {\r\n const initialArrSet = new Set(initialArr);\r\n each(getDomTokensArray(operationTokens), (token) => {\r\n initialArrSet[operation](token);\r\n });\r\n return from(initialArrSet).join(' ');\r\n };\r\n\r\n return {\r\n _remove: (removeTokens: DomTokens) => setElmAttr(domTokenListOperation(removeTokens, 'delete')),\r\n _add: (addTokens: DomTokens) => setElmAttr(domTokenListOperation(addTokens, 'add')),\r\n _has: (hasTokens: DomTokens) => {\r\n const tokenSet = getDomTokensArray(hasTokens);\r\n return tokenSet.reduce(\r\n (boolean, token) => boolean && initialArr.includes(token),\r\n tokenSet.length > 0\r\n );\r\n },\r\n };\r\n};\r\n\r\n/**\r\n * Treats the given attribute like the \"class\" attribute and removes the given value from it.\r\n * @param elm The element.\r\n * @param attrName The attributeName to which the value shall be removed.\r\n * @param value The value which shall be removed.\r\n */\r\nexport const removeAttrClass = (\r\n elm: AttributeElementTarget,\r\n attrName: string,\r\n value: DomTokens\r\n): (() => void) => {\r\n domTokenListAttr(elm, attrName)._remove(value);\r\n return bind(addAttrClass, elm, attrName, value);\r\n};\r\n\r\n/**\r\n * Treats the given attribute like the \"class\" attribute and adds value to it.\r\n * @param elm The element.\r\n * @param attrName The attributeName to which the value shall be added.\r\n * @param value The value which shall be added.\r\n */\r\nexport const addAttrClass = (\r\n elm: AttributeElementTarget,\r\n attrName: string,\r\n value: DomTokens\r\n): (() => void) => {\r\n domTokenListAttr(elm, attrName)._add(value);\r\n return bind(removeAttrClass, elm, attrName, value);\r\n};\r\n\r\nexport const addRemoveAttrClass = (\r\n elm: AttributeElementTarget,\r\n attrName: string,\r\n value: DomTokens,\r\n add?: boolean\r\n) => (add ? addAttrClass : removeAttrClass)(elm, attrName, value);\r\n\r\n/**\r\n * Treats the given attribute like the \"class\" attribute and checks if the given value is in it.\r\n * @param elm The element.\r\n * @param attrName The attributeName from which the content shall be checked.\r\n * @param value The value.\r\n * @returns True if the given attribute has the value in it, false otherwise.\r\n */\r\nexport const hasAttrClass = (\r\n elm: AttributeElementTarget,\r\n attrName: string,\r\n value: DomTokens\r\n): boolean => domTokenListAttr(elm, attrName)._has(value);\r\n","import type { AttributeElementTarget, DomTokens } from './attribute';\r\nimport { each, from } from '../utils/array';\r\nimport { bind } from '../utils/function';\r\nimport { domTokenListAttr } from './attribute';\r\n\r\nconst createDomTokenListClass = (elm: AttributeElementTarget) => domTokenListAttr(elm, 'class');\r\n\r\n/**\r\n * Check whether the given element has the given class name(s).\r\n * @param elm The element.\r\n * @param className The class name(s).\r\n */\r\nexport const hasClass = (elm: AttributeElementTarget, className: DomTokens): boolean =>\r\n createDomTokenListClass(elm)._has(className);\r\n\r\n/**\r\n * Removes the given class name(s) from the given element.\r\n * @param elm The element.\r\n * @param className The class name(s) which shall be removed. (separated by spaces)\r\n */\r\nexport const removeClass = (elm: AttributeElementTarget, className: DomTokens): void => {\r\n createDomTokenListClass(elm)._remove(className);\r\n};\r\n\r\n/**\r\n * Adds the given class name(s) to the given element.\r\n * @param elm The element.\r\n * @param className The class name(s) which shall be added. (separated by spaces)\r\n * @returns A function which removes the added class name(s).\r\n */\r\nexport const addClass = (elm: AttributeElementTarget, className: DomTokens): (() => void) => {\r\n createDomTokenListClass(elm)._add(className);\r\n return bind(removeClass, elm, className);\r\n};\r\n\r\n/**\r\n * Takes two className strings, compares them and returns the difference as array.\r\n * @param classNameA ClassName A.\r\n * @param classNameB ClassName B.\r\n */\r\nexport const diffClass = (\r\n classNameA: string | false | null | undefined,\r\n classNameB: string | false | null | undefined\r\n) => {\r\n const set = new Set(classNameA ? classNameA.split(' ') : []);\r\n\r\n each(classNameB ? classNameB.split(' ') : [], (className) => {\r\n set[set.has(className) ? 'delete' : 'add'](className);\r\n });\r\n\r\n return from(set);\r\n};\r\n","import type { NodeElementTarget } from './types';\r\nimport { isElement } from '../utils/types';\r\nimport { push, from } from '../utils/array';\r\n\r\n/**\r\n * Find all elements with the passed selector, outgoing (and including) the passed element or the document if no element was provided.\r\n * @param selector The selector which has to be searched by.\r\n * @param elm The element from which the search shall be outgoing.\r\n */\r\nexport const find = (selector: string, elm?: NodeElementTarget): Element[] => {\r\n const rootElm = elm ? isElement(elm) && elm : document;\r\n return rootElm ? from(rootElm.querySelectorAll(selector)) : [];\r\n};\r\n\r\n/**\r\n * Find the first element with the passed selector, outgoing (and including) the passed element or the document if no element was provided.\r\n * @param selector The selector which has to be searched by.\r\n * @param elm The element from which the search shall be outgoing.\r\n */\r\nexport const findFirst = (selector: string, elm?: NodeElementTarget): NodeElementTarget => {\r\n const rootElm = elm ? isElement(elm) && elm : document;\r\n return rootElm && rootElm.querySelector(selector);\r\n};\r\n\r\n/**\r\n * Determines whether the passed element is matching with the passed selector.\r\n * @param elm The element which has to be compared with the passed selector.\r\n * @param selector The selector which has to be compared with the passed element. Additional selectors: ':visible' and ':hidden'.\r\n */\r\nexport const is = (elm: NodeElementTarget, selector: string): boolean =>\r\n isElement(elm) && elm.matches(selector);\r\n\r\nexport const isBodyElement = (elm: NodeElementTarget) => is(elm, 'body'); // don't do targetElement === ownerDocument.body in case initialization happens in memory\r\n\r\n/**\r\n * Returns the children (no text-nodes or comments) of the passed element which are matching the passed selector. An empty array is returned if the passed element is null.\r\n * @param elm The element of which the children shall be returned.\r\n * @param selector The selector which must match with the children elements.\r\n */\r\nexport const children = (elm: NodeElementTarget, selector?: string): ReadonlyArray => {\r\n const childs: Array = [];\r\n\r\n return isElement(elm)\r\n ? push(\r\n childs,\r\n from(elm.children).filter((child) => (selector ? is(child, selector) : child))\r\n )\r\n : childs;\r\n};\r\n\r\n/**\r\n * Returns the childNodes (incl. text-nodes or comments etc.) of the passed element. An empty array is returned if the passed element is null.\r\n * @param elm The element of which the childNodes shall be returned.\r\n */\r\nexport const contents = (elm: NodeElementTarget): ReadonlyArray =>\r\n elm ? from(elm.childNodes) : [];\r\n\r\n/**\r\n * Returns the parent element of the passed element, or null if the passed element is null.\r\n * @param elm The element of which the parent element shall be returned.\r\n */\r\nexport const parent = (elm: NodeElementTarget): NodeElementTarget => elm && elm.parentElement;\r\n\r\n/**\r\n * Returns the closest element to the passed element which matches the given selector.\r\n * @param elm The element.\r\n * @param selector The selector.\r\n * @returns The closest element to the passed element which matches the given selector.\r\n */\r\nexport const closest = (elm: NodeElementTarget, selector: string): NodeElementTarget =>\r\n isElement(elm) && elm.closest(selector);\r\n\r\n/**\r\n * Gets the focused element of the passed or default document.\r\n * @returns The focused element of the passed document.\r\n */\r\nexport const getFocusedElement = (doc?: Document) => (doc || document).activeElement;\r\n\r\n/**\r\n * Determines whether the given element lies between two selectors in the DOM.\r\n * @param elm The element.\r\n * @param highBoundarySelector The high boundary selector.\r\n * @param deepBoundarySelector The deep boundary selector.\r\n */\r\nexport const liesBetween = (\r\n elm: NodeElementTarget,\r\n highBoundarySelector: string,\r\n deepBoundarySelector: string\r\n): boolean => {\r\n const closestHighBoundaryElm = closest(elm, highBoundarySelector);\r\n const closestDeepBoundaryElm = elm && findFirst(deepBoundarySelector, closestHighBoundaryElm);\r\n const deepBoundaryIsValid =\r\n closest(closestDeepBoundaryElm, highBoundarySelector) === closestHighBoundaryElm;\r\n\r\n return closestHighBoundaryElm && closestDeepBoundaryElm\r\n ? closestHighBoundaryElm === elm ||\r\n closestDeepBoundaryElm === elm ||\r\n (deepBoundaryIsValid &&\r\n closest(closest(elm, deepBoundarySelector), highBoundarySelector) !==\r\n closestHighBoundaryElm)\r\n : false;\r\n};\r\n","import type { NodeElementTarget, NodeElementTargetCollection } from './types';\r\nimport { createOrKeepArray, each } from '../utils/array';\r\nimport { parent } from './traversal';\r\nimport { bind } from '../utils';\r\n\r\n/**\r\n * Removes the given Nodes from their parent.\r\n * @param nodes The Nodes which shall be removed.\r\n */\r\nexport const removeElements = (nodes: NodeElementTargetCollection): void => {\r\n each(createOrKeepArray(nodes), (node) => {\r\n const parentElm = parent(node);\r\n if (node && parentElm) {\r\n parentElm.removeChild(node);\r\n }\r\n });\r\n};\r\n\r\n/**\r\n * Appends the given children at the end of the given Node.\r\n * @param node The Node to which the children shall be appended.\r\n * @param children The Nodes which shall be appended.\r\n * @returns A function which removes the inserted nodes.\r\n */\r\nexport const appendChildren = (node: NodeElementTarget, children: NodeElementTargetCollection) =>\r\n bind(\r\n removeElements,\r\n node &&\r\n children &&\r\n each(createOrKeepArray(children), (child) => {\r\n if (child) {\r\n node.appendChild(child);\r\n }\r\n })\r\n );\r\n","// at the time of implementation TypeScript doesn't offer any TrustedTypes typescript definitions\r\n// https://github.com/microsoft/TypeScript/issues/30024\r\nlet trustedTypePolicy: unknown | undefined;\r\n\r\nexport const getTrustedTypePolicy = () => trustedTypePolicy;\r\nexport const setTrustedTypePolicy = (newTrustedTypePolicy: unknown | undefined) => {\r\n trustedTypePolicy = newTrustedTypePolicy;\r\n};\r\n","import { each } from '../utils/array';\r\nimport { setAttrs } from './attribute';\r\nimport { contents } from './traversal';\r\nimport { removeElements } from './manipulation';\r\nimport { getTrustedTypePolicy } from '../../trustedTypePolicy';\r\n\r\n/**\r\n * Creates a div DOM node.\r\n */\r\nexport const createDiv = (classNames?: string): HTMLDivElement => {\r\n const div = document.createElement('div');\r\n setAttrs(div, 'class', classNames);\r\n return div;\r\n};\r\n\r\n/**\r\n * Creates DOM nodes modeled after the passed html string and returns the root dom nodes as a array.\r\n * @param html The html string after which the DOM nodes shall be created.\r\n */\r\nexport const createDOM = (html: string): ReadonlyArray => {\r\n const createdDiv = createDiv();\r\n const trustedTypesPolicy = getTrustedTypePolicy();\r\n const trimmedHtml = html.trim();\r\n createdDiv.innerHTML = trustedTypesPolicy\r\n ? // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n (trustedTypesPolicy as any).createHTML(trimmedHtml)\r\n : trimmedHtml;\r\n\r\n return each(contents(createdDiv), (elm) => removeElements(elm));\r\n};\r\n","import type { PlainObject, StyleObject, StyleObjectKey, StyleObjectValue } from '../../typings';\r\nimport type { XY } from './offset';\r\nimport type { HTMLElementTarget } from './types';\r\nimport { wnd } from '../utils/alias';\r\nimport { each, from } from '../utils/array';\r\nimport { isString, isNumber, isObject, isNull, isBoolean } from '../utils/types';\r\n\r\nexport interface TRBL {\r\n t: number;\r\n r: number;\r\n b: number;\r\n l: number;\r\n}\r\n\r\nconst getCSSVal = (computedStyle: CSSStyleDeclaration, prop: StyleObjectKey): string =>\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n computedStyle.getPropertyValue(prop) || computedStyle[prop as any] || '';\r\n\r\nconst validFiniteNumber = (number: number) => {\r\n const notNaN = number || 0;\r\n return isFinite(notNaN) ? notNaN : 0;\r\n};\r\n\r\nconst parseToZeroOrNumber = (value?: string): number => validFiniteNumber(parseFloat(value || ''));\r\n\r\nexport const roundCssNumber = (value: number) => Math.round(value * 10000) / 10000;\r\n\r\nexport const ratioToCssPercent = (ratio: number) =>\r\n `${roundCssNumber(validFiniteNumber(ratio) * 100)}%`;\r\n\r\nexport const numberToCssPx = (number: number) => `${roundCssNumber(validFiniteNumber(number))}px`;\r\n\r\nexport function setStyles(\r\n elm: HTMLElementTarget,\r\n styles: StyleObject | false | null | undefined\r\n): void {\r\n // eslint-disable-next-line @typescript-eslint/no-unused-expressions\r\n elm &&\r\n styles &&\r\n each(styles, (rawValue: StyleObjectValue, name) => {\r\n try {\r\n const elmStyle = elm.style;\r\n const value =\r\n isNull(rawValue) || isBoolean(rawValue)\r\n ? ''\r\n : isNumber(rawValue)\r\n ? numberToCssPx(rawValue)\r\n : rawValue;\r\n\r\n if (name.indexOf('--') === 0) {\r\n elmStyle.setProperty(name, value);\r\n } else {\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n elmStyle[name as any] = value;\r\n }\r\n // eslint-disable-next-line no-empty\r\n } catch {}\r\n });\r\n}\r\n\r\nexport function getStyles(\r\n elm: HTMLElementTarget,\r\n styles: Array | ReadonlyArray,\r\n pseudoElm?: string | null | undefined\r\n): Partial>;\r\nexport function getStyles(\r\n elm: HTMLElementTarget,\r\n styles: StyleObjectKey,\r\n pseudoElm?: string | null | undefined\r\n): string;\r\nexport function getStyles(\r\n elm: HTMLElementTarget,\r\n styles: Array | ReadonlyArray | StyleObjectKey,\r\n pseudoElm?: string | null | undefined\r\n): Partial> | string {\r\n const getSingleStyle = isString(styles);\r\n let getStylesResult: string | PlainObject = getSingleStyle ? '' : {};\r\n\r\n if (elm) {\r\n const computedStyle = wnd.getComputedStyle(elm, pseudoElm) || elm.style;\r\n getStylesResult = getSingleStyle\r\n ? getCSSVal(computedStyle, styles)\r\n : from(styles).reduce((result, key) => {\r\n result[key] = getCSSVal(computedStyle, key);\r\n return result;\r\n }, getStylesResult as PlainObject);\r\n }\r\n return getStylesResult;\r\n}\r\n\r\n/**\r\n * Returns the top right bottom left values of the passed css property.\r\n * @param elm The element of which the values shall be returned.\r\n * @param propertyPrefix The css property prefix. (e.g. \"border\")\r\n * @param propertySuffix The css property suffix. (e.g. \"width\")\r\n */\r\nexport const topRightBottomLeft = (\r\n elm?: HTMLElementTarget,\r\n propertyPrefix?: string,\r\n propertySuffix?: string\r\n): TRBL => {\r\n const finalPrefix = propertyPrefix ? `${propertyPrefix}-` : '';\r\n const finalSuffix = propertySuffix ? `-${propertySuffix}` : '';\r\n const top = `${finalPrefix}top${finalSuffix}` as StyleObjectKey;\r\n const right = `${finalPrefix}right${finalSuffix}` as StyleObjectKey;\r\n const bottom = `${finalPrefix}bottom${finalSuffix}` as StyleObjectKey;\r\n const left = `${finalPrefix}left${finalSuffix}` as StyleObjectKey;\r\n const result = getStyles(elm, [top, right, bottom, left]);\r\n return {\r\n t: parseToZeroOrNumber(result[top]),\r\n r: parseToZeroOrNumber(result[right]),\r\n b: parseToZeroOrNumber(result[bottom]),\r\n l: parseToZeroOrNumber(result[left]),\r\n };\r\n};\r\n\r\nexport const getTrasformTranslateValue = (\r\n value: string | number | XY,\r\n isHorizontal?: boolean\r\n) =>\r\n `translate${\r\n isObject(value) ? `(${value.x},${value.y})` : `${isHorizontal ? 'X' : 'Y'}(${value})`\r\n }`;\r\n","import type { HTMLElementTarget } from './types';\r\nimport { getStyles } from './style';\r\nimport { mathRound, wnd } from '../utils/alias';\r\nimport { bind } from '../utils/function';\r\nimport { strHeight, strWidth } from '../utils/strings';\r\n\r\nexport interface WH {\r\n w: T;\r\n h: T;\r\n}\r\n\r\nconst elementHasDimensions = (elm: HTMLElement): boolean =>\r\n !!(elm.offsetWidth || elm.offsetHeight || elm.getClientRects().length);\r\nconst zeroObj: WH = {\r\n w: 0,\r\n h: 0,\r\n};\r\n\r\nconst getElmWidthHeightProperty = (\r\n property: E extends HTMLElement ? 'client' | 'offset' | 'scroll' : 'inner',\r\n elm: E | false | null | undefined\r\n): Readonly =>\r\n elm\r\n ? {\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n w: (elm as any)[`${property}Width`],\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n h: (elm as any)[`${property}Height`],\r\n }\r\n : zeroObj;\r\n\r\n/**\r\n * Returns the window inner- width and height.\r\n */\r\nexport const getWindowSize = (customWnd?: Window): Readonly =>\r\n getElmWidthHeightProperty('inner', customWnd || wnd);\r\n\r\n/**\r\n * Returns the scroll- width and height of the passed element. If the element is null the width and height values are 0.\r\n * @param elm The element of which the scroll- width and height shall be returned.\r\n */\r\nexport const getOffsetSize = bind(getElmWidthHeightProperty, 'offset') satisfies (\r\n elm: HTMLElementTarget\r\n) => Readonly;\r\n\r\n/**\r\n * Returns the client- width and height of the passed element. If the element is null the width and height values are 0.\r\n * @param elm The element of which the client- width and height shall be returned.\r\n */\r\nexport const getClientSize = bind(getElmWidthHeightProperty, 'client') satisfies (\r\n elm: HTMLElementTarget\r\n) => Readonly;\r\n\r\n/**\r\n * Returns the client- width and height of the passed element. If the element is null the width and height values are 0.\r\n * @param elm The element of which the client- width and height shall be returned.\r\n */\r\nexport const getScrollSize = bind(getElmWidthHeightProperty, 'scroll') satisfies (\r\n elm: HTMLElementTarget\r\n) => Readonly;\r\n\r\n/**\r\n * Returns the fractional- width and height of the passed element. If the element is null the width and height values are 0.\r\n * @param elm The element of which the fractional- width and height shall be returned.\r\n */\r\nexport const getFractionalSize = (elm: HTMLElementTarget): Readonly => {\r\n const cssWidth = parseFloat(getStyles(elm, strWidth)) || 0;\r\n const cssHeight = parseFloat(getStyles(elm, strHeight)) || 0;\r\n return {\r\n w: cssWidth - mathRound(cssWidth),\r\n h: cssHeight - mathRound(cssHeight),\r\n };\r\n};\r\n\r\n/**\r\n * Returns the BoundingClientRect of the passed element.\r\n * @param elm The element of which the BoundingClientRect shall be returned.\r\n */\r\nexport const getBoundingClientRect = (elm: HTMLElement): DOMRect => elm.getBoundingClientRect();\r\n\r\n/**\r\n * Determines whether the passed element has any dimensions.\r\n * @param elm The element.\r\n */\r\nexport const hasDimensions = (elm: HTMLElementTarget): boolean =>\r\n !!elm && elementHasDimensions(elm);\r\n\r\n/**\r\n * Determines whether the passed DOM Rect has any dimensions.\r\n */\r\nexport const domRectHasDimensions = (rect?: DOMRectReadOnly | false | null) =>\r\n !!(rect && (rect[strHeight] || rect[strWidth]));\r\n\r\n/**\r\n * Determines whether current DOM Rect has appeared according the the previous dom rect..\r\n * @param currContentRect The current DOM Rect.\r\n * @param prevContentRect The previous DOM Rect.\r\n * @returns Whether the dom rect appeared.\r\n */\r\nexport const domRectAppeared = (\r\n currContentRect: DOMRectReadOnly | false | null | undefined,\r\n prevContentRect: DOMRectReadOnly | false | null | undefined\r\n) => {\r\n const rectHasDimensions = domRectHasDimensions(currContentRect);\r\n const rectHadDimensions = domRectHasDimensions(prevContentRect);\r\n return !rectHadDimensions && rectHasDimensions;\r\n};\r\n","/* eslint-disable @typescript-eslint/no-explicit-any */\r\nimport type { DomTokens } from './attribute';\r\nimport { each, runEachAndClear } from '../utils/array';\r\nimport { bind } from '../utils/function';\r\nimport { keys } from '../utils';\r\nimport { getDomTokensArray } from './attribute';\r\n\r\nexport interface EventListenerOptions {\r\n _capture?: boolean;\r\n _passive?: boolean;\r\n _once?: boolean;\r\n}\r\n\r\nexport type EventListenerTarget = EventTarget | false | null | undefined;\r\n\r\nexport type EventListenerMap = {\r\n [eventNames: string]: ((event: any) => any) | false | null | undefined;\r\n};\r\n\r\n/**\r\n * Removes the passed event listener for the passed event names with the passed options.\r\n * @param target The element from which the listener shall be removed.\r\n * @param eventNames The eventsnames for which the listener shall be removed.\r\n * @param listener The listener which shall be removed.\r\n * @param capture The options of the removed listener.\r\n */\r\nexport const removeEventListener = (\r\n target: EventListenerTarget,\r\n eventNames: DomTokens,\r\n listener: (event: T) => any,\r\n capture?: boolean\r\n): void => {\r\n each(getDomTokensArray(eventNames), (eventName) => {\r\n if (target) {\r\n target.removeEventListener(eventName, listener as EventListener, capture);\r\n }\r\n });\r\n};\r\n\r\n/**\r\n * Adds the passed event listener for the passed event names with the passed options.\r\n * @param target The element to which the listener shall be added.\r\n * @param eventNames The eventsnames for which the listener shall be called.\r\n * @param listener The listener which is called on the eventnames.\r\n * @param options The options of the added listener.\r\n */\r\nexport const addEventListener = (\r\n target: EventListenerTarget,\r\n eventNames: DomTokens,\r\n listener: ((event: T) => any) | false | null | undefined,\r\n options?: EventListenerOptions\r\n): (() => void) => {\r\n const passive = (options && options._passive) ?? true;\r\n const capture = (options && options._capture) || false;\r\n const once = (options && options._once) || false;\r\n const nativeOptions: AddEventListenerOptions = {\r\n passive,\r\n capture,\r\n };\r\n\r\n return bind(\r\n runEachAndClear,\r\n getDomTokensArray(eventNames).map((eventName) => {\r\n const finalListener = (\r\n once\r\n ? (evt: T) => {\r\n removeEventListener(target, eventName, finalListener, capture);\r\n if (listener) {\r\n listener(evt);\r\n }\r\n }\r\n : listener\r\n ) as EventListener;\r\n\r\n if (target) {\r\n target.addEventListener(eventName, finalListener, nativeOptions);\r\n }\r\n\r\n return bind(removeEventListener, target, eventName, finalListener, capture);\r\n })\r\n );\r\n};\r\n\r\n/**\r\n * Adds the passed event listeners for the passed event names with the passed options.\r\n * @param target The element to which the listener shall be added.\r\n * @param eventListenerMap A map which descirbes the event names and event listeners to be added.\r\n * @param options The options of the added listeners.\r\n */\r\nexport const addEventListeners = (\r\n target: EventListenerTarget,\r\n eventListenerMap: EventListenerMap,\r\n options?: EventListenerOptions\r\n): (() => void) =>\r\n bind(\r\n runEachAndClear,\r\n keys(eventListenerMap).map((eventNames) =>\r\n addEventListener(target, eventNames, eventListenerMap[eventNames], options)\r\n )\r\n );\r\n\r\n/**\r\n * Shorthand for the stopPropagation event Method.\r\n * @param evt The event of which the stopPropagation method shall be called.\r\n */\r\nexport const stopPropagation = (evt: Event): void => evt.stopPropagation();\r\n\r\n/**\r\n * Shorthand for the preventDefault event Method.\r\n * @param evt The event of which the preventDefault method shall be called.\r\n */\r\nexport const preventDefault = (evt: Event): void => evt.preventDefault();\r\n\r\n/**\r\n * Shorthand for the stopPropagation and preventDefault event Method.\r\n * @param evt The event of which the stopPropagation and preventDefault methods shall be called.\r\n */\r\nexport const stopAndPrevent = (evt: Event): void =>\r\n (stopPropagation(evt) as undefined) || (preventDefault(evt) as undefined);\r\n","import type { XY } from './offset';\r\nimport type { WH } from './dimensions';\r\nimport { capNumber, isNumber, mathAbs, mathSign } from '../utils';\r\n\r\nexport interface ScrollCoordinates {\r\n /** The start (origin) scroll coordinates for each axis. */\r\n _start: XY;\r\n /** The end scroll coordinates for each axis. */\r\n _end: XY;\r\n}\r\n\r\n/**\r\n * Scroll the passed element to the passed position.\r\n * @param elm The element to be scrolled.\r\n * @param position The scroll position.\r\n */\r\nexport const scrollElementTo = (\r\n elm: HTMLElement,\r\n position: Partial> | number | false | null | undefined\r\n): void => {\r\n const { x, y } = isNumber(position) ? { x: position, y: position } : position || {};\r\n // eslint-disable-next-line @typescript-eslint/no-unused-expressions\r\n isNumber(x) && (elm.scrollLeft = x);\r\n // eslint-disable-next-line @typescript-eslint/no-unused-expressions\r\n isNumber(y) && (elm.scrollTop = y);\r\n};\r\n\r\n/**\r\n * Scroll the passed element to the passed position.\r\n * @param elm The element to be scrolled.\r\n * @param position The scroll position.\r\n */\r\nexport const getElementScroll = (elm: HTMLElement): Readonly => ({\r\n x: elm.scrollLeft,\r\n y: elm.scrollTop,\r\n});\r\n\r\n/**\r\n * Scroll Coordinates which are 0.\r\n */\r\nexport const getZeroScrollCoordinates = (): ScrollCoordinates => ({\r\n _start: { x: 0, y: 0 },\r\n _end: { x: 0, y: 0 },\r\n});\r\n\r\n/**\r\n * Sanatizes raw scroll coordinates.\r\n * The passed `overflowAmount` is used as the \"max\" value for each axis if the sign of the raw max value is not `0`.\r\n * Makes sure that each axis has `0` either in the start or end coordinates.\r\n * @param rawScrollCoordinates The raw scroll coordinates.\r\n * @param overflowAmount The overflow amount.\r\n * @returns\r\n */\r\nexport const sanitizeScrollCoordinates = (\r\n rawScrollCoordinates: ScrollCoordinates,\r\n overflowAmount: WH\r\n) => {\r\n const { _start, _end } = rawScrollCoordinates;\r\n const { w, h } = overflowAmount;\r\n const sanitizeAxis = (start: number, end: number, amount: number) => {\r\n let newStart = mathSign(start) * amount;\r\n let newEnd = mathSign(end) * amount;\r\n\r\n if (newStart === newEnd) {\r\n const startAbs = mathAbs(start);\r\n const endAbs = mathAbs(end);\r\n\r\n newEnd = startAbs > endAbs ? 0 : newEnd;\r\n newStart = startAbs < endAbs ? 0 : newStart;\r\n }\r\n\r\n // in doubt set start to 0\r\n newStart = newStart === newEnd ? 0 : newStart;\r\n\r\n return [newStart + 0, newEnd + 0] as const; // \"+ 0\" prevents \"-0\" to be in the result\r\n };\r\n\r\n const [startX, endX] = sanitizeAxis(_start.x, _end.x, w);\r\n const [startY, endY] = sanitizeAxis(_start.y, _end.y, h);\r\n\r\n return {\r\n _start: {\r\n x: startX,\r\n y: startY,\r\n },\r\n _end: {\r\n x: endX,\r\n y: endY,\r\n },\r\n };\r\n};\r\n\r\n/**\r\n * Returns whether the passed scroll coordinates represent the browsers default scroll direction.\r\n * For the default scroll direction the following must be true:\r\n * 1. Start value is `0`.\r\n * 2. End value <= Start value.\r\n * @param scrollCoordinates The scroll coordinates.\r\n */\r\nexport const isDefaultDirectionScrollCoordinates = ({\r\n _start,\r\n _end,\r\n}: ScrollCoordinates): XY => {\r\n const getAxis = (start: number, end: number) => start === 0 && start <= end;\r\n\r\n return {\r\n x: getAxis(_start.x, _end.x),\r\n y: getAxis(_start.y, _end.y),\r\n };\r\n};\r\n\r\n/**\r\n * Gets the current scroll percent between 0..1 for each axis.\r\n * @param scrollCoordinates The scroll coordinates.\r\n * @param currentScroll The current scroll position of the element.\r\n */\r\nexport const getScrollCoordinatesPercent = (\r\n { _start, _end }: ScrollCoordinates,\r\n currentScroll: XY\r\n) => {\r\n const getAxis = (start: number, end: number, current: number) =>\r\n capNumber(0, 1, (start - current) / (start - end) || 0);\r\n\r\n return {\r\n x: getAxis(_start.x, _end.x, currentScroll.x),\r\n y: getAxis(_start.y, _end.y, currentScroll.y),\r\n };\r\n};\r\n\r\n/**\r\n * Gets the scroll position of the given percent.\r\n * @param scrollCoordinates The scroll coordinates.\r\n * @param percent The percentage of the scroll.\r\n */\r\nexport const getScrollCoordinatesPosition = (\r\n { _start, _end }: ScrollCoordinates,\r\n percent: XY\r\n) => {\r\n const getAxis = (start: number, end: number, p: number) => start + (end - start) * p;\r\n\r\n return {\r\n x: getAxis(_start.x, _end.x, percent.x),\r\n y: getAxis(_start.y, _end.y, percent.y),\r\n };\r\n};\r\n","import type { NodeElementTarget } from './types';\r\n// import { getAttr, removeAttrs, setAttrs } from './attribute';\r\n\r\nexport const focusElement = (element: NodeElementTarget /*, forceTabIndex?: boolean*/) => {\r\n if (element && (element as HTMLElement).focus) {\r\n // const tabIndexStr = 'tabindex';\r\n // const originalTabIndex = getAttr(element as HTMLElement, tabIndexStr);\r\n // if (forceTabIndex) {\r\n // setAttrs(element as HTMLElement, tabIndexStr, '-1');\r\n // }\r\n\r\n (element as HTMLElement).focus({\r\n preventScroll: true,\r\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\r\n // @ts-ignore\r\n focusVisible: false,\r\n });\r\n\r\n // if (forceTabIndex) {\r\n // if (originalTabIndex) {\r\n // setAttrs(element as HTMLElement, tabIndexStr, originalTabIndex);\r\n // } else {\r\n // removeAttrs(element as HTMLElement, tabIndexStr);\r\n // }\r\n // }\r\n }\r\n};\r\n","/* eslint-disable @typescript-eslint/no-explicit-any */\r\nimport { isBoolean, isFunction, isString } from './utils/types';\r\nimport { keys } from './utils/object';\r\nimport { each, push, from, isEmptyArray, runEachAndClear, createOrKeepArray } from './utils/array';\r\nimport { bind } from './utils/function';\r\n\r\nexport type EventListener, N extends keyof EventArgs> = (\r\n ...args: EventArgs[N]\r\n) => void;\r\n\r\nexport type EventListeners> = {\r\n [K in keyof EventArgs]?: EventListener | EventListener[] | null;\r\n};\r\n\r\nexport type RemoveEvent> = {\r\n (name?: N, listener?: EventListener): void;\r\n (name?: N, listener?: EventListener[]): void;\r\n (\r\n name?: N,\r\n listener?: EventListener | EventListener[]\r\n ): void;\r\n};\r\n\r\nexport type AddEvent> = {\r\n (eventListeners: EventListeners, pure?: boolean): () => void;\r\n (name: N, listener: EventListener): () => void;\r\n (name: N, listener: EventListener[]): () => void;\r\n (\r\n nameOrEventListeners: N | EventListeners,\r\n listener?: EventListener | EventListener[] | boolean\r\n ): () => void;\r\n};\r\n\r\nexport type TriggerEvent> = {\r\n (name: N, args: EventArgs[N]): void;\r\n};\r\n\r\nexport type EventListenerHub> = [\r\n AddEvent,\r\n RemoveEvent,\r\n TriggerEvent,\r\n];\r\n\r\nconst manageListener = , N extends keyof EventArgs>(\r\n callback: (listener?: EventListener) => void,\r\n listener?: EventListener | EventListener[]\r\n) => {\r\n each(createOrKeepArray(listener), callback);\r\n};\r\n\r\nexport const createEventListenerHub = >(\r\n initialEventListeners?: EventListeners\r\n): EventListenerHub => {\r\n const events = new Map>>();\r\n\r\n const removeEvent: RemoveEvent = (name, listener) => {\r\n if (name) {\r\n const eventSet = events.get(name);\r\n manageListener((currListener) => {\r\n if (eventSet) {\r\n eventSet[currListener ? 'delete' : 'clear'](currListener! as any);\r\n }\r\n }, listener);\r\n } else {\r\n events.forEach((eventSet) => {\r\n eventSet.clear();\r\n });\r\n events.clear();\r\n }\r\n };\r\n\r\n const addEvent: AddEvent = (\r\n nameOrEventListeners: keyof EventArgs | EventListeners,\r\n listenerOrPure?:\r\n | EventListener\r\n | EventListener[]\r\n | boolean\r\n ) => {\r\n if (isString(nameOrEventListeners)) {\r\n const eventSet = events.get(nameOrEventListeners) || new Set();\r\n events.set(nameOrEventListeners, eventSet);\r\n\r\n manageListener(\r\n (currListener) => {\r\n if (isFunction(currListener)) {\r\n eventSet.add(currListener);\r\n }\r\n },\r\n listenerOrPure as Exclude\r\n );\r\n\r\n return bind(\r\n removeEvent,\r\n nameOrEventListeners,\r\n listenerOrPure as Exclude\r\n );\r\n }\r\n if (isBoolean(listenerOrPure) && listenerOrPure) {\r\n removeEvent();\r\n }\r\n\r\n const eventListenerKeys = keys(nameOrEventListeners) as (keyof EventListeners)[];\r\n const offFns: (() => void)[] = [];\r\n each(eventListenerKeys, (key) => {\r\n const eventListener = (nameOrEventListeners as EventListeners)[key];\r\n if (eventListener) {\r\n push(offFns, addEvent(key, eventListener));\r\n }\r\n });\r\n\r\n return bind(runEachAndClear, offFns);\r\n };\r\n\r\n const triggerEvent: TriggerEvent = (name, args) => {\r\n each(from(events.get(name)), (event) => {\r\n if (args && !isEmptyArray(args)) {\r\n (event as (...eventArgs: EventArgs[keyof EventArgs]) => void).apply(0, args);\r\n } else {\r\n (event as () => void)();\r\n }\r\n });\r\n };\r\n\r\n addEvent(initialEventListeners || {});\r\n\r\n return [addEvent, removeEvent, triggerEvent];\r\n};\r\n","/* eslint-disable @typescript-eslint/no-explicit-any */\r\nimport type { OverlayScrollbars, OverlayScrollbarsStatic } from '../overlayscrollbars';\r\nimport type { EventListener, EventListenerArgs, EventListeners } from '../eventListeners';\r\nimport { each, keys } from '../support';\r\n\r\nexport type PluginModuleInstance = Record;\r\n\r\nexport type InstancePluginEvent = {\r\n /**\r\n * Adds event listeners to the instance.\r\n * @param eventListeners An object which contains the added listeners.\r\n * @returns Returns a function which removes the added listeners.\r\n */\r\n (eventListeners: EventListeners): () => void;\r\n /**\r\n * Adds a single event listener to the instance.\r\n * @param name The name of the event.\r\n * @param listener The listener which is invoked on that event.\r\n * @returns Returns a function which removes the added listeners.\r\n */\r\n (name: N, listener: EventListener): () => void;\r\n /**\r\n * Adds multiple event listeners to the instance.\r\n * @param name The name of the event.\r\n * @param listener The listeners which are invoked on that event.\r\n * @returns Returns a function which removes the added listeners.\r\n */\r\n (name: N, listener: EventListener[]): () => void;\r\n};\r\n\r\n/**\r\n * Describes a OverlayScrollbars plugin module.\r\n * Plugin modules must be side-effect free and deterministic. (same input produces same output)\r\n */\r\nexport type PluginModule<\r\n S extends PluginModuleInstance | void = PluginModuleInstance | void,\r\n I extends PluginModuleInstance | void = PluginModuleInstance | void,\r\n> = (S extends PluginModuleInstance\r\n ? {\r\n /**\r\n * Creates a plugin which is bound to the static object.\r\n * The function will be called once with the static object as soon as the plugin is registered.\r\n * The plugin can add new methods or fields to the passed static object.\r\n * @param osStatic The static object the plugin is bound to.\r\n * @returns The plugins instance object or a falsy value if the plugin doesn't need any instance object.\r\n */\r\n static: (osStatic: OverlayScrollbarsStatic) => S | void;\r\n }\r\n : object) &\r\n (I extends PluginModuleInstance\r\n ? {\r\n /**\r\n * Creates a A plugin which is bound to an instance.\r\n * The function will be called each time a new instance is created.\r\n * The plugin can add new methods or fields to the passed instance object.\r\n * @param osInstance The instance object the plugin is bound to.\r\n * @param event A function which adds events to the instance which can't be removed from outside the plugin. (instance events added with the `on` function can be removed with the optional `pure` parameter)\r\n * @param osStatic The static object the plugin is bound to.\r\n * @returns The plugins instance object or a falsy value if the plugin doesn't need any instance object.\r\n */\r\n instance: (\r\n osInstance: OverlayScrollbars,\r\n event: InstancePluginEvent,\r\n osStatic: OverlayScrollbarsStatic\r\n ) => I | void;\r\n }\r\n : object);\r\n\r\n/**\r\n * Describes a OverlayScrollbar plugin.\r\n */\r\nexport type Plugin<\r\n Name extends string = string,\r\n S extends PluginModuleInstance | void = PluginModuleInstance | void,\r\n I extends PluginModuleInstance | void = PluginModuleInstance | void,\r\n> = {\r\n /** The field is the plugins name. Plugin names must be globally unique, please choose wisely. */\r\n [pluginName in Name]: PluginModule;\r\n};\r\n\r\n/**\r\n * Describes a OverlayScrollbar plugin which has only a static module.\r\n */\r\nexport type StaticPlugin<\r\n Name extends string = string,\r\n T extends PluginModuleInstance = PluginModuleInstance,\r\n> = Plugin;\r\n\r\n/**\r\n * Describes a OverlayScrollbar plugin which has only a instance module.\r\n */\r\nexport type InstancePlugin<\r\n Name extends string = string,\r\n T extends PluginModuleInstance = PluginModuleInstance,\r\n> = Plugin;\r\n\r\n/**\r\n * Infers the type of the static modules instance of the passed plugin.\r\n */\r\nexport type InferStaticPluginModuleInstance =\r\n T extends StaticPlugin\r\n ? T[Name]['static'] extends (...args: any[]) => any\r\n ? ReturnType\r\n : void\r\n : void;\r\n\r\n/**\r\n * Infers the type of the instance modules instance of the passed plugin.\r\n */\r\nexport type InferInstancePluginModuleInstance =\r\n T extends InstancePlugin\r\n ? T[Name]['instance'] extends (...args: any[]) => any\r\n ? ReturnType\r\n : void\r\n : void;\r\n\r\n/** All registered plugin modules. */\r\nexport const pluginModules: Record = {};\r\n\r\n/** All static plugin module instances. */\r\nexport const staticPluginModuleInstances: Record = {};\r\n\r\n/**\r\n * Adds plugins.\r\n * @param addedPlugin The plugin(s) to add.\r\n * @returns The added plugin modules of the registered plugins.\r\n */\r\nexport const addPlugins = (addedPlugin: Plugin[]) => {\r\n each(addedPlugin, (plugin) =>\r\n each(plugin, (_, key) => {\r\n pluginModules[key] = plugin[key];\r\n })\r\n );\r\n};\r\n\r\nexport const registerPluginModuleInstances = (\r\n plugin: Plugin,\r\n staticObj: OverlayScrollbarsStatic,\r\n instanceInfo?: [\r\n instanceObj: OverlayScrollbars,\r\n event: InstancePluginEvent,\r\n instancePluginMap?: Record,\r\n ]\r\n): Array =>\r\n keys(plugin).map((name) => {\r\n const { static: osStatic, instance: osInstance } = (\r\n plugin as Plugin\r\n )[name];\r\n const [instanceObj, event, instancePluginMap] = instanceInfo || [];\r\n const ctor = instanceInfo ? osInstance : osStatic;\r\n if (ctor) {\r\n const instance = instanceInfo\r\n ? (\r\n ctor as Extract<\r\n typeof ctor,\r\n (\r\n osInstance: OverlayScrollbars,\r\n event: InstancePluginEvent,\r\n osStatic: OverlayScrollbarsStatic\r\n ) => PluginModuleInstance | void\r\n >\r\n )(instanceObj!, event!, staticObj)\r\n : (\r\n ctor as Extract<\r\n typeof ctor,\r\n (osStatic: OverlayScrollbarsStatic) => PluginModuleInstance | void\r\n >\r\n )(staticObj);\r\n return ((instancePluginMap || staticPluginModuleInstances)[name] = instance);\r\n }\r\n });\r\n\r\nexport const getStaticPluginModuleInstance = (\r\n pluginModuleName: T extends StaticPlugin ? N : never\r\n): InferStaticPluginModuleInstance | undefined =>\r\n staticPluginModuleInstances[pluginModuleName] as InferStaticPluginModuleInstance | undefined;\r\n","import type {\r\n Options,\r\n PartialOptions,\r\n OverflowBehavior,\r\n ScrollbarsVisibilityBehavior,\r\n ScrollbarsAutoHideBehavior,\r\n ScrollbarsClickScrollBehavior,\r\n} from '../../options';\r\nimport type { OptionsTemplate, OptionsTemplateValue } from './validation';\r\nimport type { StaticPlugin } from '../plugins';\r\nimport { validateOptions, optionsTemplateTypes as oTypes } from './validation';\r\n\r\nexport const optionsValidationPluginModuleName = '__osOptionsValidationPlugin';\r\n\r\nexport const OptionsValidationPlugin = /* @__PURE__ */ (() => ({\r\n [optionsValidationPluginModuleName]: {\r\n static: () => {\r\n const numberAllowedValues: OptionsTemplateValue = oTypes.number;\r\n const booleanAllowedValues: OptionsTemplateValue = oTypes.boolean;\r\n const arrayNullValues: OptionsTemplateValue | null> = [\r\n oTypes.array,\r\n oTypes.null,\r\n ];\r\n const overflowAllowedValues: OptionsTemplateValue =\r\n 'hidden scroll visible visible-hidden';\r\n const scrollbarsVisibilityAllowedValues: OptionsTemplateValue =\r\n 'visible hidden auto';\r\n const scrollbarsAutoHideAllowedValues: OptionsTemplateValue =\r\n 'never scroll leavemove';\r\n const scrollbarsClickScrollAllowedValues: OptionsTemplateValue =\r\n [booleanAllowedValues, oTypes.string];\r\n\r\n const optionsTemplate: OptionsTemplate = {\r\n paddingAbsolute: booleanAllowedValues, // true || false\r\n showNativeOverlaidScrollbars: booleanAllowedValues, // true || false\r\n update: {\r\n elementEvents: arrayNullValues, // array of tuples || null\r\n attributes: arrayNullValues,\r\n debounce: [oTypes.number, oTypes.array, oTypes.object, oTypes.null], // number || number array || object || null\r\n ignoreMutation: [oTypes.function, oTypes.null], // function || null\r\n },\r\n overflow: {\r\n x: overflowAllowedValues, // visible-hidden || visible-scroll || hidden || scroll\r\n y: overflowAllowedValues, // visible-hidden || visible-scroll || hidden || scroll\r\n },\r\n scrollbars: {\r\n theme: [oTypes.string, oTypes.null], // string || null\r\n visibility: scrollbarsVisibilityAllowedValues, // visible || hidden || auto\r\n autoHide: scrollbarsAutoHideAllowedValues, // never || scroll || leave || move ||\r\n autoHideDelay: numberAllowedValues, // number\r\n autoHideSuspend: booleanAllowedValues, // true || false\r\n dragScroll: booleanAllowedValues, // true || false\r\n clickScroll: scrollbarsClickScrollAllowedValues, // true || false || instant\r\n pointers: [oTypes.array, oTypes.null], // string array\r\n },\r\n /*\r\n textarea: {\r\n dynWidth: booleanAllowedValues, // true || false\r\n dynHeight: booleanAllowedValues, // true || false\r\n inheritedAttrs: stringArrayNullAllowedValues, // string || array || nul\r\n },\r\n */\r\n };\r\n return (options: PartialOptions, doWriteErrors?: boolean): PartialOptions => {\r\n const [validated, foreign] = validateOptions(optionsTemplate, options, doWriteErrors);\r\n return { ...foreign, ...validated };\r\n };\r\n },\r\n },\r\n}))() satisfies StaticPlugin;\r\n","import { strOverflowX, strOverflowY } from './support';\r\n\r\nconst dataAttributePrefix = `data-overlayscrollbars`;\r\n\r\n// environment\r\nexport const classNameEnvironment = 'os-environment';\r\nexport const classNameEnvironmentScrollbarHidden = `${classNameEnvironment}-scrollbar-hidden`;\r\n\r\n// initialize\r\nexport const dataAttributeInitialize = `${dataAttributePrefix}-initialize`;\r\n\r\n// shared\r\nexport const dataValueNoClipping = 'noClipping';\r\n\r\n// body\r\nexport const dataAttributeHtmlBody = `${dataAttributePrefix}-body`;\r\n\r\n// host\r\nexport const dataAttributeHost = dataAttributePrefix;\r\nexport const dataValueHostIsHost = 'host';\r\n\r\n// viewport\r\nexport const dataAttributeViewport = `${dataAttributePrefix}-viewport`;\r\nexport const dataValueViewportOverflowXPrefix = strOverflowX;\r\nexport const dataValueViewportOverflowYPrefix = strOverflowY;\r\nexport const dataValueViewportArrange = 'arrange';\r\nexport const dataValueViewportMeasuring = 'measuring';\r\nexport const dataValueViewportScrolling = 'scrolling';\r\nexport const dataValueViewportScrollbarHidden = 'scrollbarHidden';\r\nexport const dataValueViewportNoContent = 'noContent';\r\n\r\n// padding\r\nexport const dataAttributePadding = `${dataAttributePrefix}-padding`;\r\n\r\n// content\r\nexport const dataAttributeContent = `${dataAttributePrefix}-content`;\r\n\r\n// size observer\r\nexport const classNameSizeObserver = 'os-size-observer';\r\nexport const classNameSizeObserverAppear = `${classNameSizeObserver}-appear`;\r\nexport const classNameSizeObserverListener = `${classNameSizeObserver}-listener`;\r\nexport const classNameSizeObserverListenerScroll = `${classNameSizeObserverListener}-scroll`;\r\nexport const classNameSizeObserverListenerItem = `${classNameSizeObserverListener}-item`;\r\nexport const classNameSizeObserverListenerItemFinal = `${classNameSizeObserverListenerItem}-final`;\r\n\r\n// trinsic observer\r\nexport const classNameTrinsicObserver = 'os-trinsic-observer';\r\n\r\n// scrollbars\r\nexport const classNameScrollbarThemeNone = 'os-theme-none';\r\nexport const classNameScrollbar = 'os-scrollbar';\r\nexport const classNameScrollbarRtl = `${classNameScrollbar}-rtl`;\r\nexport const classNameScrollbarHorizontal = `${classNameScrollbar}-horizontal`;\r\nexport const classNameScrollbarVertical = `${classNameScrollbar}-vertical`;\r\nexport const classNameScrollbarTrack = `${classNameScrollbar}-track`;\r\nexport const classNameScrollbarHandle = `${classNameScrollbar}-handle`;\r\nexport const classNameScrollbarVisible = `${classNameScrollbar}-visible`;\r\nexport const classNameScrollbarCornerless = `${classNameScrollbar}-cornerless`;\r\nexport const classNameScrollbarTransitionless = `${classNameScrollbar}-transitionless`;\r\nexport const classNameScrollbarInteraction = `${classNameScrollbar}-interaction`;\r\nexport const classNameScrollbarUnusable = `${classNameScrollbar}-unusable`;\r\nexport const classNameScrollbarAutoHide = `${classNameScrollbar}-auto-hide`;\r\nexport const classNameScrollbarAutoHideHidden = `${classNameScrollbarAutoHide}-hidden`;\r\nexport const classNameScrollbarWheel = `${classNameScrollbar}-wheel`;\r\nexport const classNameScrollbarTrackInteractive = `${classNameScrollbarTrack}-interactive`;\r\nexport const classNameScrollbarHandleInteractive = `${classNameScrollbarHandle}-interactive`;\r\n","/* eslint-disable @typescript-eslint/no-explicit-any */\r\nimport type { StaticPlugin } from '../plugins';\r\nimport {\r\n createDOM,\r\n appendChildren,\r\n getOffsetSize,\r\n addEventListener,\r\n addClass,\r\n equalWH,\r\n cAF,\r\n rAF,\r\n stopPropagation,\r\n bind,\r\n scrollElementTo,\r\n strWidth,\r\n strHeight,\r\n setStyles,\r\n} from '../../support';\r\nimport {\r\n classNameSizeObserverListenerScroll,\r\n classNameSizeObserverListenerItem,\r\n classNameSizeObserverListenerItemFinal,\r\n} from '../../classnames';\r\n\r\nexport const sizeObserverPluginName = '__osSizeObserverPlugin';\r\n\r\nexport const SizeObserverPlugin = /* @__PURE__ */ (() => ({\r\n [sizeObserverPluginName]: {\r\n static:\r\n () =>\r\n (\r\n listenerElement: HTMLElement,\r\n onSizeChangedCallback: (appear: boolean) => any,\r\n observeAppearChange: boolean | null | undefined\r\n ): [appearCallback: () => void, offFns: (() => any)[]] => {\r\n const scrollAmount = 3333333;\r\n const scrollEventName = 'scroll';\r\n const observerElementChildren = createDOM(\r\n `
`\r\n );\r\n const observerElementChildrenRoot = observerElementChildren[0] as HTMLElement;\r\n const shrinkElement = observerElementChildrenRoot.lastChild as HTMLElement;\r\n const expandElement = observerElementChildrenRoot.firstChild as HTMLElement;\r\n const expandElementChild = expandElement?.firstChild as HTMLElement;\r\n\r\n let cacheSize = getOffsetSize(observerElementChildrenRoot);\r\n let currSize = cacheSize;\r\n let isDirty = false;\r\n let rAFId: number;\r\n\r\n const reset = () => {\r\n scrollElementTo(expandElement, scrollAmount);\r\n scrollElementTo(shrinkElement, scrollAmount);\r\n };\r\n const onResized = (appear?: unknown) => {\r\n rAFId = 0;\r\n if (isDirty) {\r\n cacheSize = currSize;\r\n onSizeChangedCallback(appear === true);\r\n }\r\n };\r\n const onScroll = (scrollEvent?: Event | false) => {\r\n currSize = getOffsetSize(observerElementChildrenRoot);\r\n isDirty = !scrollEvent || !equalWH(currSize, cacheSize);\r\n\r\n if (scrollEvent) {\r\n stopPropagation(scrollEvent);\r\n\r\n if (isDirty && !rAFId) {\r\n cAF!(rAFId);\r\n rAFId = rAF!(onResized);\r\n }\r\n } else {\r\n onResized(scrollEvent === false);\r\n }\r\n\r\n reset();\r\n };\r\n const destroyFns = [\r\n appendChildren(listenerElement, observerElementChildren),\r\n addEventListener(expandElement, scrollEventName, onScroll),\r\n addEventListener(shrinkElement, scrollEventName, onScroll),\r\n ];\r\n\r\n addClass(listenerElement, classNameSizeObserverListenerScroll);\r\n\r\n // lets assume that the divs will never be that large and a constant value is enough\r\n setStyles(expandElementChild, {\r\n [strWidth]: scrollAmount,\r\n [strHeight]: scrollAmount,\r\n });\r\n\r\n rAF!(reset);\r\n\r\n return [observeAppearChange ? bind(onScroll, false) : reset, destroyFns];\r\n },\r\n },\r\n}))() satisfies StaticPlugin;\r\n","import type { Env } from '../../environment';\r\nimport type { Options, OptionsCheckFn, OverflowBehavior } from '../../options';\r\nimport type { OverflowStyle } from '../../typings';\r\nimport {\r\n getStyles,\r\n strHidden,\r\n strOverflowX,\r\n strOverflowY,\r\n strScroll,\r\n strVisible,\r\n XY,\r\n} from '../../support';\r\n\r\nexport const getShowNativeOverlaidScrollbars = (checkOption: OptionsCheckFn, env: Env) => {\r\n const { _nativeScrollbarsOverlaid } = env;\r\n const [showNativeOverlaidScrollbarsOption, showNativeOverlaidScrollbarsChanged] = checkOption(\r\n 'showNativeOverlaidScrollbars'\r\n );\r\n\r\n return [\r\n showNativeOverlaidScrollbarsOption &&\r\n _nativeScrollbarsOverlaid.x &&\r\n _nativeScrollbarsOverlaid.y,\r\n showNativeOverlaidScrollbarsChanged,\r\n ] as const;\r\n};\r\n\r\nexport const overflowIsVisible = (overflow: string) => overflow.indexOf(strVisible) === 0;\r\n\r\nexport const overflowBehaviorToOverflowStyle = (\r\n overflowBehavior: OverflowBehavior\r\n): OverflowStyle => overflowBehavior.replace(`${strVisible}-`, '') as OverflowStyle;\r\n\r\nexport const overflowCssValueToOverflowStyle = (\r\n cssValue: string | undefined,\r\n hasOverflow?: boolean\r\n): OverflowStyle => {\r\n if (cssValue === 'auto') {\r\n return hasOverflow ? strScroll : strHidden;\r\n }\r\n\r\n const finalCssValue = cssValue || strHidden;\r\n return [strHidden, strScroll, strVisible].includes(finalCssValue)\r\n ? (finalCssValue as OverflowStyle)\r\n : strHidden;\r\n};\r\n\r\nexport const getElementOverflowStyle = (\r\n element: HTMLElement,\r\n hasOverflow: Partial>\r\n): XY => {\r\n const { overflowX, overflowY } = getStyles(element, [strOverflowX, strOverflowY]);\r\n\r\n return {\r\n x: overflowCssValueToOverflowStyle(overflowX, hasOverflow.x),\r\n y: overflowCssValueToOverflowStyle(overflowY, hasOverflow.y),\r\n };\r\n};\r\n","import type { ObserversSetupState } from '../../setups';\r\nimport type { Options, OptionsCheckFn } from '../../options';\r\nimport type { StructureSetupElementsObj } from '../../setups/structureSetup/structureSetup.elements';\r\nimport type { Env } from '../../environment';\r\nimport type { WH, XY } from '../../support';\r\nimport type { OverflowStyle, StyleObject, StyleObjectKey } from '../../typings';\r\nimport type { StructureSetupState } from '../../setups/structureSetup';\r\nimport type { StaticPlugin } from '../plugins';\r\nimport {\r\n getShowNativeOverlaidScrollbars,\r\n getElementOverflowStyle,\r\n} from '../../setups/structureSetup/structureSetup.utils';\r\nimport { dataValueViewportArrange, dataAttributeViewport } from '../../classnames';\r\nimport {\r\n keys,\r\n noop,\r\n each,\r\n assignDeep,\r\n strMarginBottom,\r\n strMarginLeft,\r\n strMarginRight,\r\n strPaddingBottom,\r\n strPaddingLeft,\r\n strPaddingRight,\r\n strPaddingTop,\r\n getStyles,\r\n setStyles,\r\n removeAttrClass,\r\n strWidth,\r\n strScroll,\r\n} from '../../support';\r\n\r\nexport const scrollbarsHidingPluginName = '__osScrollbarsHidingPlugin';\r\n\r\nexport const ScrollbarsHidingPlugin = /* @__PURE__ */ (() => ({\r\n [scrollbarsHidingPluginName]: {\r\n static: () => ({\r\n _viewportArrangement: (\r\n structureSetupElements: StructureSetupElementsObj,\r\n structureSetupState: StructureSetupState,\r\n observersSetupState: ObserversSetupState,\r\n env: Env,\r\n checkOptions: OptionsCheckFn\r\n ) => {\r\n const { _viewportIsTarget, _viewport } = structureSetupElements;\r\n const { _nativeScrollbarsHiding, _nativeScrollbarsOverlaid, _nativeScrollbarsSize } = env;\r\n const doViewportArrange =\r\n !_viewportIsTarget &&\r\n !_nativeScrollbarsHiding &&\r\n (_nativeScrollbarsOverlaid.x || _nativeScrollbarsOverlaid.y);\r\n const [showNativeOverlaidScrollbars] = getShowNativeOverlaidScrollbars(checkOptions, env);\r\n\r\n /**\r\n * Gets the hide offset matching the passed overflow state.\r\n * @param viewportOverflowState The overflow state of the viewport\r\n */\r\n const _getViewportOverflowHideOffset = (viewportOverflowStyle: XY) => {\r\n const arrangeHideOffset =\r\n _nativeScrollbarsHiding || showNativeOverlaidScrollbars ? 0 : 42;\r\n\r\n const getHideOffsetPerAxis = (\r\n isOverlaid: boolean,\r\n overflowScroll: boolean,\r\n nativeScrollbarSize: number\r\n ) => {\r\n const nonScrollbarStylingHideOffset = isOverlaid\r\n ? arrangeHideOffset\r\n : nativeScrollbarSize;\r\n const scrollbarsHideOffset =\r\n overflowScroll && !_nativeScrollbarsHiding ? nonScrollbarStylingHideOffset : 0;\r\n const scrollbarsHideOffsetArrange = isOverlaid && !!arrangeHideOffset;\r\n\r\n return [scrollbarsHideOffset, scrollbarsHideOffsetArrange] as const;\r\n };\r\n\r\n const [xScrollbarsHideOffset, xScrollbarsHideOffsetArrange] = getHideOffsetPerAxis(\r\n _nativeScrollbarsOverlaid.x,\r\n viewportOverflowStyle.x === strScroll,\r\n _nativeScrollbarsSize.x\r\n );\r\n const [yScrollbarsHideOffset, yScrollbarsHideOffsetArrange] = getHideOffsetPerAxis(\r\n _nativeScrollbarsOverlaid.y,\r\n viewportOverflowStyle.y === strScroll,\r\n _nativeScrollbarsSize.y\r\n );\r\n\r\n return {\r\n _scrollbarsHideOffset: {\r\n x: xScrollbarsHideOffset,\r\n y: yScrollbarsHideOffset,\r\n },\r\n _scrollbarsHideOffsetArrange: {\r\n x: xScrollbarsHideOffsetArrange,\r\n y: yScrollbarsHideOffsetArrange,\r\n },\r\n };\r\n };\r\n\r\n /**\r\n * Hides the native scrollbars according to the passed parameters.\r\n * @param viewportOverflowStyle The viewport overflow style.\r\n * @param directionIsRTL Whether the direction is RTL or not.\r\n * @param viewportArrange Whether special styles related to the viewport arrange strategy shall be applied.\r\n * @param viewportStyleObj The viewport style object to which the needed styles shall be applied.\r\n */\r\n const _hideNativeScrollbars = (\r\n viewportOverflowStyle: XY\r\n ): StyleObject | undefined => {\r\n if (!_viewportIsTarget) {\r\n const { _directionIsRTL } = observersSetupState;\r\n const viewportStyleObj: StyleObject = assignDeep(\r\n {},\r\n {\r\n [strMarginRight]: 0,\r\n [strMarginBottom]: 0,\r\n [strMarginLeft]: 0,\r\n }\r\n );\r\n const { _scrollbarsHideOffset, _scrollbarsHideOffsetArrange } =\r\n _getViewportOverflowHideOffset(viewportOverflowStyle);\r\n const { x: arrangeX, y: arrangeY } = _scrollbarsHideOffsetArrange;\r\n const { x: hideOffsetX, y: hideOffsetY } = _scrollbarsHideOffset;\r\n const { _viewportPaddingStyle } = structureSetupState;\r\n const horizontalMarginKey: keyof StyleObject = _directionIsRTL\r\n ? strMarginLeft\r\n : strMarginRight;\r\n const viewportHorizontalPaddingKey: keyof StyleObject = _directionIsRTL\r\n ? strPaddingLeft\r\n : strPaddingRight;\r\n const horizontalMarginValue = _viewportPaddingStyle[horizontalMarginKey] as number;\r\n const verticalMarginValue = _viewportPaddingStyle[strMarginBottom] as number;\r\n const horizontalPaddingValue = _viewportPaddingStyle[\r\n viewportHorizontalPaddingKey\r\n ] as number;\r\n const verticalPaddingValue = _viewportPaddingStyle[strPaddingBottom] as number;\r\n\r\n // horizontal\r\n viewportStyleObj[strWidth] = `calc(100% + ${\r\n hideOffsetY + horizontalMarginValue * -1\r\n }px)`;\r\n viewportStyleObj[horizontalMarginKey] = -hideOffsetY + horizontalMarginValue;\r\n\r\n // vertical\r\n viewportStyleObj[strMarginBottom] = -hideOffsetX + verticalMarginValue;\r\n\r\n // viewport arrange additional styles\r\n if (doViewportArrange) {\r\n viewportStyleObj[viewportHorizontalPaddingKey] =\r\n horizontalPaddingValue + (arrangeY ? hideOffsetY : 0);\r\n viewportStyleObj[strPaddingBottom] =\r\n verticalPaddingValue + (arrangeX ? hideOffsetX : 0);\r\n }\r\n\r\n return viewportStyleObj;\r\n }\r\n };\r\n\r\n /**\r\n * Sets the styles of the viewport arrange element.\r\n * @param viewportOverflowStyle The viewport overflow style according to which the scrollbars shall be hidden.\r\n * @param viewportScrollSize The content scroll size.\r\n * @param directionIsRTL Whether the direction is RTL or not.\r\n * @returns A boolean which indicates whether the viewport arrange element was adjusted.\r\n */\r\n const _arrangeViewport = (\r\n viewportOverflowStyle: XY,\r\n viewportScrollSize: WH,\r\n sizeFraction: WH\r\n ) => {\r\n if (doViewportArrange) {\r\n const { _viewportPaddingStyle } = structureSetupState;\r\n const { _scrollbarsHideOffset, _scrollbarsHideOffsetArrange } =\r\n _getViewportOverflowHideOffset(viewportOverflowStyle);\r\n const { x: arrangeX, y: arrangeY } = _scrollbarsHideOffsetArrange;\r\n const { x: hideOffsetX, y: hideOffsetY } = _scrollbarsHideOffset;\r\n const { _directionIsRTL } = observersSetupState;\r\n const viewportArrangeHorizontalPaddingKey: keyof StyleObject = _directionIsRTL\r\n ? strPaddingRight\r\n : strPaddingLeft;\r\n const viewportArrangeHorizontalPaddingValue = _viewportPaddingStyle[\r\n viewportArrangeHorizontalPaddingKey\r\n ] as number;\r\n const viewportArrangeVerticalPaddingValue = _viewportPaddingStyle.paddingTop as number;\r\n const fractionalContentWidth = viewportScrollSize.w + sizeFraction.w;\r\n const fractionalContenHeight = viewportScrollSize.h + sizeFraction.h;\r\n const arrangeSize = {\r\n w:\r\n hideOffsetY && arrangeY\r\n ? `${\r\n hideOffsetY + fractionalContentWidth - viewportArrangeHorizontalPaddingValue\r\n }px`\r\n : '',\r\n h:\r\n hideOffsetX && arrangeX\r\n ? `${\r\n hideOffsetX + fractionalContenHeight - viewportArrangeVerticalPaddingValue\r\n }px`\r\n : '',\r\n };\r\n\r\n setStyles(_viewport, {\r\n '--os-vaw': arrangeSize.w,\r\n '--os-vah': arrangeSize.h,\r\n });\r\n }\r\n\r\n return doViewportArrange;\r\n };\r\n\r\n /**\r\n * Removes all styles applied because of the viewport arrange strategy.\r\n */\r\n const _undoViewportArrange = () => {\r\n if (doViewportArrange) {\r\n const { _hasOverflow, _viewportPaddingStyle: viewportPaddingStyle } =\r\n structureSetupState;\r\n const viewportOverflowStyle = getElementOverflowStyle(_viewport, _hasOverflow);\r\n const { _scrollbarsHideOffsetArrange } =\r\n _getViewportOverflowHideOffset(viewportOverflowStyle);\r\n const { x: arrangeX, y: arrangeY } = _scrollbarsHideOffsetArrange;\r\n const finalPaddingStyle: StyleObject = {};\r\n const assignProps = (props: string[]) =>\r\n each(props, (prop) => {\r\n finalPaddingStyle[prop as StyleObjectKey] =\r\n viewportPaddingStyle[prop as StyleObjectKey];\r\n });\r\n\r\n if (arrangeX) {\r\n assignProps([strMarginBottom, strPaddingTop, strPaddingBottom]);\r\n }\r\n\r\n if (arrangeY) {\r\n assignProps([strMarginLeft, strMarginRight, strPaddingLeft, strPaddingRight]);\r\n }\r\n\r\n const prevStyle = getStyles(_viewport, keys(finalPaddingStyle) as StyleObjectKey[]);\r\n const addArrange = removeAttrClass(\r\n _viewport,\r\n dataAttributeViewport,\r\n dataValueViewportArrange\r\n );\r\n\r\n setStyles(_viewport, finalPaddingStyle);\r\n\r\n return () => {\r\n setStyles(\r\n _viewport,\r\n assignDeep({}, prevStyle, _hideNativeScrollbars(viewportOverflowStyle))\r\n );\r\n addArrange();\r\n };\r\n }\r\n return noop;\r\n };\r\n\r\n return {\r\n _arrangeViewport,\r\n _undoViewportArrange,\r\n _hideNativeScrollbars,\r\n };\r\n },\r\n }),\r\n },\r\n}))() satisfies StaticPlugin;\r\n","import type { StaticPlugin } from '../plugins';\r\nimport { animateNumber, noop, selfClearTimeout } from '../../support';\r\n\r\nexport const clickScrollPluginModuleName = '__osClickScrollPlugin';\r\n\r\nexport const ClickScrollPlugin = /* @__PURE__ */ (() => ({\r\n [clickScrollPluginModuleName]: {\r\n static:\r\n () =>\r\n (\r\n moveHandleRelative: (deltaMovement: number) => void,\r\n targetOffset: number,\r\n handleLength: number,\r\n onClickScrollCompleted: (stopped: boolean) => void\r\n ) => {\r\n // click scroll animation has 2 main parts:\r\n // 1. the \"click\" which scrolls 100% of the viewport in a certain amount of time\r\n // 2. the \"press\" which scrolls to the point where the cursor is located, the \"press\" always waits for the \"click\" to finish\r\n // The \"click\" should not be canceled by a \"pointerup\" event because very fast clicks or taps would cancel it too fast\r\n // The \"click\" should only be canceled by a subsequent \"pointerdown\" event because otherwise 2 animations would run\r\n // The \"press\" should be canceld by the next \"pointerup\" event\r\n\r\n let stopped = false;\r\n let stopPressAnimation = noop;\r\n const linearScrollMs = 133;\r\n const easedScrollMs = 222;\r\n const [setPressAnimationTimeout, clearPressAnimationTimeout] =\r\n selfClearTimeout(linearScrollMs);\r\n const targetOffsetSign = Math.sign(targetOffset);\r\n const handleLengthWithTargetSign = handleLength * targetOffsetSign;\r\n const handleLengthWithTargetSignHalf = handleLengthWithTargetSign / 2;\r\n const easing = (x: number) => 1 - (1 - x) * (1 - x); // easeOutQuad;\r\n const easedEndPressAnimation = (from: number, to: number) =>\r\n animateNumber(from, to, easedScrollMs, moveHandleRelative, easing);\r\n const linearPressAnimation = (linearFrom: number, msFactor: number) =>\r\n animateNumber(\r\n linearFrom,\r\n targetOffset - handleLengthWithTargetSign,\r\n linearScrollMs * msFactor,\r\n (progress, _, completed) => {\r\n moveHandleRelative(progress);\r\n\r\n if (completed) {\r\n stopPressAnimation = easedEndPressAnimation(progress, targetOffset);\r\n }\r\n }\r\n );\r\n const stopClickAnimation = animateNumber(\r\n 0,\r\n handleLengthWithTargetSign,\r\n easedScrollMs,\r\n (clickAnimationProgress, _, clickAnimationCompleted) => {\r\n moveHandleRelative(clickAnimationProgress);\r\n\r\n if (clickAnimationCompleted) {\r\n onClickScrollCompleted(stopped);\r\n\r\n if (!stopped) {\r\n const remainingScrollDistance = targetOffset - clickAnimationProgress;\r\n const continueWithPress =\r\n Math.sign(remainingScrollDistance - handleLengthWithTargetSignHalf) ===\r\n targetOffsetSign;\r\n\r\n if (continueWithPress) {\r\n setPressAnimationTimeout(() => {\r\n const remainingLinearScrollDistance =\r\n remainingScrollDistance - handleLengthWithTargetSign;\r\n const linearBridge =\r\n Math.sign(remainingLinearScrollDistance) === targetOffsetSign;\r\n\r\n stopPressAnimation = linearBridge\r\n ? linearPressAnimation(\r\n clickAnimationProgress,\r\n Math.abs(remainingLinearScrollDistance) / handleLength\r\n )\r\n : easedEndPressAnimation(clickAnimationProgress, targetOffset);\r\n });\r\n }\r\n }\r\n }\r\n },\r\n easing\r\n );\r\n\r\n return (stopClick?: boolean) => {\r\n stopped = true;\r\n\r\n if (stopClick) {\r\n stopClickAnimation();\r\n }\r\n\r\n clearPressAnimationTimeout();\r\n stopPressAnimation();\r\n };\r\n },\r\n },\r\n}))() satisfies StaticPlugin;\r\n","/* eslint-disable @typescript-eslint/no-explicit-any */\r\nimport type { DeepPartial, DeepReadonly } from './typings';\r\nimport {\r\n assignDeep,\r\n each,\r\n isObject,\r\n keys,\r\n isArray,\r\n hasOwnProperty,\r\n isFunction,\r\n isEmptyObject,\r\n concat,\r\n} from './support';\r\n\r\nexport type OptionsField = string;\r\n\r\nexport type OptionsPrimitiveValue =\r\n | boolean\r\n | number\r\n | string\r\n | Array\r\n | ReadonlyArray\r\n | [any]\r\n | [any, ...any[]]\r\n | ((this: any, ...args: any[]) => any)\r\n | null;\r\n\r\nexport type OptionsObject = {\r\n [field: OptionsField]: OptionsPrimitiveValue | OptionsObject;\r\n};\r\n\r\ntype OptionsObjectFieldNameTuples = T extends OptionsPrimitiveValue\r\n ? []\r\n : {\r\n [K in Extract]: [K, ...OptionsObjectFieldNameTuples];\r\n }[Extract];\r\n\r\ntype JoinOptionsObjectFieldTuples<\r\n T extends OptionsField[],\r\n IncompletePath extends boolean = false,\r\n> = T extends [infer F]\r\n ? F\r\n : T extends [infer F, ...infer R]\r\n ? F extends OptionsField\r\n ?\r\n | (IncompletePath extends true ? F : never)\r\n | `${F}.${JoinOptionsObjectFieldTuples>}`\r\n : never\r\n : OptionsField;\r\n\r\ntype SplitJoinedOptionsObjectFieldTuples = string extends S\r\n ? OptionsField[]\r\n : S extends ''\r\n ? []\r\n : S extends `${infer T}.${infer U}`\r\n ? [T, ...SplitJoinedOptionsObjectFieldTuples]\r\n : [S];\r\n\r\ntype OptionsObjectFieldTuplesType = T extends [infer F]\r\n ? F extends keyof O\r\n ? O[F]\r\n : never\r\n : T extends [infer F, ...infer R]\r\n ? F extends keyof O\r\n ? O[F] extends OptionsPrimitiveValue\r\n ? O[F]\r\n : OptionsObjectFieldTuplesType>\r\n : never\r\n : never;\r\n\r\ntype OptionsObjectFieldPath = JoinOptionsObjectFieldTuples<\r\n OptionsObjectFieldNameTuples,\r\n true\r\n>;\r\n\r\ntype OptionsObjectFieldPathType<\r\n O extends OptionsObject,\r\n P extends string,\r\n> = OptionsObjectFieldTuplesType>;\r\n\r\nconst opsStringify = (value: any) =>\r\n JSON.stringify(value, (_, val) => {\r\n if (isFunction(val)) {\r\n throw 0;\r\n }\r\n return val;\r\n });\r\n\r\nconst getPropByPath = (obj: any, path: string): T =>\r\n obj\r\n ? `${path}`\r\n .split('.')\r\n .reduce((o, prop) => (o && hasOwnProperty(o, prop) ? o[prop] : undefined), obj)\r\n : (undefined as T);\r\n\r\n/**\r\n * The overflow behavior of an axis.\r\n */\r\nexport type OverflowBehavior =\r\n /** No scrolling is possible and the content is clipped. */\r\n | 'hidden'\r\n /** No scrolling is possible and the content isn't clipped. */\r\n | 'visible'\r\n /** Scrolling is possible if there is an overflow. */\r\n | 'scroll'\r\n /**\r\n * If the other axis has no overflow the behavior is similar to `visible`.\r\n * If the other axis has overflow the behavior is similar to `hidden`.\r\n */\r\n | 'visible-hidden'\r\n /**\r\n * If the other axis has no overflow the behavior is similar to `visible`.\r\n * If the other axis has overflow the behavior is similar to `scroll`.\r\n */\r\n | 'visible-scroll';\r\n\r\n/**\r\n * The scrollbars visibility behavior.\r\n */\r\nexport type ScrollbarsVisibilityBehavior =\r\n /** The scrollbars are always visible. */\r\n | 'visible'\r\n /** The scrollbars are always hidden. */\r\n | 'hidden'\r\n /** The scrollbars are only visibile if there is overflow. */\r\n | 'auto';\r\n\r\n/**\r\n * The scrollbars auto hide behavior\r\n */\r\nexport type ScrollbarsAutoHideBehavior =\r\n /** The scrollbars are never hidden automatically. */\r\n | 'never'\r\n /** The scrollbars are hidden unless the user scrolls. */\r\n | 'scroll'\r\n /** The scrollbars are hidden unless the pointer moves in the host element or the user scrolls. */\r\n | 'move'\r\n /** The scrollbars are hidden if the pointer leaves the host element or unless the user scrolls. */\r\n | 'leave';\r\n\r\n/**\r\n * The scrollbar click scroll behavior.\r\n */\r\nexport type ScrollbarsClickScrollBehavior = boolean | 'instant';\r\n\r\n/**\r\n * A debounce value:\r\n * If a tuple is provided you can customize the `timeout` and the `maxWait` in milliseconds. The third value `leading` indicates whether the debounce is also executed on the leading edge\r\n * Only a number customizes the `timeout` in milliseconds.\r\n * If the `timeout` is `0`, a debounce still exists. (its executed via `requestAnimationFrame`).\r\n */\r\nexport type OptionsDebounceValue =\r\n | [\r\n timeout?: number | false | null | undefined,\r\n maxWait?: number | false | null | undefined,\r\n leading?: boolean | null | undefined,\r\n ]\r\n | number\r\n | false\r\n | null;\r\n\r\n/**\r\n * @deprecated Use the debounce object instead.\r\n */\r\nexport type OptionsDebounceLegacy = OptionsDebounceValue;\r\n\r\n/**\r\n * The options of a OverlayScrollbars instance.\r\n */\r\nexport type Options = {\r\n /** Whether the padding shall be absolute. */\r\n paddingAbsolute: boolean;\r\n /** Whether to show the native scrollbars. Has only an effect it the native scrollbars are overlaid. */\r\n showNativeOverlaidScrollbars: boolean;\r\n /** Customizes the automatic update behavior. */\r\n update: {\r\n /**\r\n * The given Event(s) from the elements with the given selector(s) will trigger an update.\r\n * Useful for everything the MutationObserver and ResizeObserver can't detect\r\n * e.g.: and Images `load` event or the `transitionend` / `animationend` events.\r\n */\r\n elementEvents: Array<[elementSelector: string, eventNames: string]> | null;\r\n /**\r\n * Options to debounce updates to fine-tune performance.\r\n * It is possible to debounce updates caused by mutations, resizes, events and environmental changes.\r\n */\r\n debounce:\r\n | {\r\n /** Debounce updates which were triggered by a MutationObserver. */\r\n mutation: OptionsDebounceValue;\r\n /** Debounce updates which were triggered by a ResizeObserver. */\r\n resize: OptionsDebounceValue;\r\n /** Debounce updates which were triggered by a Event. */\r\n event: OptionsDebounceValue;\r\n /** Debounce updates which were triggered by environmental changes. (e.g. zooming & window resize) */\r\n env: OptionsDebounceValue;\r\n }\r\n | OptionsDebounceLegacy;\r\n /**\r\n * HTML attributes which will trigger an update if they're changed.\r\n * Basic attributes like `id`, `class`, `style` etc. are always observed and doesn't have to be added explicitly.\r\n */\r\n attributes: string[] | null;\r\n /**\r\n * A function which makes it possible to ignore a content mutation or null if nothing shall be ignored.\r\n * @param mutation The MutationRecord from the MutationObserver.\r\n * @returns A Truthy value if the mutation shall be ignored, a falsy value otherwise.\r\n */\r\n ignoreMutation: ((mutation: MutationRecord) => any) | null;\r\n };\r\n /** Customizes the overflow behavior per axis. */\r\n overflow: {\r\n /** The overflow behavior of the horizontal (x) axis. */\r\n x: OverflowBehavior;\r\n /** The overflow behavior of the vertical (y) axis. */\r\n y: OverflowBehavior;\r\n };\r\n /** Customizes appearance of the scrollbars. */\r\n scrollbars: {\r\n /**\r\n * The scrollbars theme.\r\n * The theme value will be added as `class` to all `scrollbar` elements of the instance.\r\n */\r\n theme: string | null;\r\n /** The scrollbars visibility behavior. */\r\n visibility: ScrollbarsVisibilityBehavior;\r\n /** The scrollbars auto hide behavior. */\r\n autoHide: ScrollbarsAutoHideBehavior;\r\n /** The scrollbars auto hide delay in milliseconds. */\r\n autoHideDelay: number;\r\n /** Whether the scrollbars auto hide behavior is suspended until a scroll happened. */\r\n autoHideSuspend: boolean;\r\n /** Whether it is possible to drag the handle of a scrollbar to scroll the viewport. */\r\n dragScroll: boolean;\r\n /** Whether it is possible to click the track of a scrollbar to scroll the viewport. */\r\n clickScroll: ScrollbarsClickScrollBehavior;\r\n /**\r\n * An array of pointer types which shall be supported.\r\n * Common pointer types are: `mouse`, `pen` and `touch`.\r\n * https://developer.mozilla.org/en-US/docs/Web/API/PointerEvent/pointerType\r\n */\r\n pointers: string[] | null;\r\n };\r\n};\r\n\r\nexport type ReadonlyOptions = DeepReadonly;\r\n\r\nexport type PartialOptions = DeepPartial;\r\n\r\nexport type OptionsCheckFn =

>(\r\n path: P\r\n) => [value: OptionsObjectFieldPathType, changed: boolean];\r\n\r\nexport const defaultOptionsUpdateDebounceMutation = [0, 33] satisfies OptionsDebounceValue;\r\nexport const defaultOptionsUpdateDebounceEvent = [33, 99] satisfies OptionsDebounceValue;\r\nexport const defaultOptionsUpdateDebounceEnv = [222, 666, true] satisfies OptionsDebounceValue;\r\nexport const defaultOptions: ReadonlyOptions = {\r\n paddingAbsolute: false,\r\n showNativeOverlaidScrollbars: false,\r\n update: {\r\n elementEvents: [['img', 'load']],\r\n debounce: {\r\n mutation: defaultOptionsUpdateDebounceMutation,\r\n resize: null,\r\n event: defaultOptionsUpdateDebounceEvent,\r\n env: defaultOptionsUpdateDebounceEnv,\r\n },\r\n attributes: null,\r\n ignoreMutation: null,\r\n },\r\n overflow: {\r\n x: 'scroll',\r\n y: 'scroll',\r\n },\r\n scrollbars: {\r\n theme: 'os-theme-dark',\r\n visibility: 'auto',\r\n autoHide: 'never',\r\n autoHideDelay: 1300,\r\n autoHideSuspend: false,\r\n dragScroll: true,\r\n clickScroll: false,\r\n pointers: ['mouse', 'touch', 'pen'],\r\n },\r\n} satisfies OptionsObject & Options;\r\n\r\nexport const getOptionsDiff = (currOptions: T, newOptions: DeepPartial): DeepPartial => {\r\n const diff: DeepPartial = {};\r\n const optionsKeys = concat(keys(newOptions), keys(currOptions)) as Array<\r\n keyof T & keyof DeepPartial\r\n >;\r\n\r\n each(optionsKeys, (optionKey) => {\r\n const currOptionValue = currOptions[optionKey];\r\n const newOptionValue = newOptions[optionKey];\r\n\r\n if (isObject(currOptionValue) && isObject(newOptionValue)) {\r\n assignDeep((diff[optionKey] = {} as any), getOptionsDiff(currOptionValue, newOptionValue));\r\n // delete empty nested objects\r\n if (isEmptyObject(diff[optionKey])) {\r\n delete diff[optionKey];\r\n }\r\n } else if (hasOwnProperty(newOptions, optionKey) && newOptionValue !== currOptionValue) {\r\n let isDiff = true;\r\n\r\n if (isArray(currOptionValue) || isArray(newOptionValue)) {\r\n try {\r\n if (opsStringify(currOptionValue) === opsStringify(newOptionValue)) {\r\n isDiff = false;\r\n }\r\n // eslint-disable-next-line no-empty\r\n } catch {}\r\n }\r\n\r\n if (isDiff) {\r\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\r\n // @ts-ignore\r\n diff[optionKey] = newOptionValue;\r\n }\r\n }\r\n });\r\n\r\n return diff;\r\n};\r\n\r\nexport const createOptionCheck =\r\n (\r\n options: T,\r\n changedOptions: DeepPartial,\r\n force?: boolean\r\n ): OptionsCheckFn =>\r\n (path) => [\r\n getPropByPath(options, path),\r\n force || getPropByPath(changedOptions, path) !== undefined,\r\n ];\r\n","let nonce: string | undefined;\r\n\r\nexport const getNonce = () => nonce;\r\nexport const setNonce = (newNonce: string | undefined) => {\r\n nonce = newNonce;\r\n};\r\n","import type { XY, EventListener } from './support';\r\nimport type { Options, PartialOptions } from './options';\r\nimport type { Initialization, PartialInitialization } from './initialization';\r\nimport type { StyleObjectKey } from './typings';\r\nimport { defaultOptions } from './options';\r\nimport { classNameEnvironment, classNameEnvironmentScrollbarHidden } from './classnames';\r\nimport {\r\n createDOM,\r\n addClass,\r\n appendChildren,\r\n getFractionalSize,\r\n getClientSize,\r\n getOffsetSize,\r\n removeAttrs,\r\n removeElements,\r\n assignDeep,\r\n createCache,\r\n equalXY,\r\n createEventListenerHub,\r\n scrollT,\r\n bind,\r\n wnd,\r\n getStyles,\r\n isBodyElement,\r\n isFunction,\r\n addEventListener,\r\n} from './support';\r\nimport { getNonce } from './nonce';\r\n\r\ntype EnvironmentEventArgs = {\r\n r: [scrollbarSizeChanged?: boolean];\r\n};\r\n\r\nexport interface Env {\r\n readonly _nativeScrollbarsSize: XY;\r\n readonly _nativeScrollbarsOverlaid: XY;\r\n readonly _nativeScrollbarsHiding: boolean;\r\n readonly _scrollTimeline: boolean;\r\n readonly _staticDefaultInitialization: Initialization;\r\n readonly _staticDefaultOptions: Options;\r\n _addResizeListener(listener: EventListener): () => void;\r\n _getDefaultInitialization(): Initialization;\r\n _setDefaultInitialization(newInitialization: PartialInitialization): Initialization;\r\n _getDefaultOptions(): Options;\r\n _setDefaultOptions(newDefaultOptions: PartialOptions): Options;\r\n}\r\n\r\nlet environmentInstance: Env;\r\n\r\nconst createEnvironment = (): Env => {\r\n const getNativeScrollbarSize = (\r\n measureElm: HTMLElement,\r\n measureElmChild: HTMLElement,\r\n clear?: boolean\r\n ): XY => {\r\n // fix weird safari issue where getComputedStyle returns all empty styles by appending twice\r\n appendChildren(document.body, measureElm);\r\n appendChildren(document.body, measureElm);\r\n\r\n const cSize = getClientSize(measureElm);\r\n const oSize = getOffsetSize(measureElm);\r\n const fSize = getFractionalSize(measureElmChild);\r\n\r\n if (clear) {\r\n removeElements(measureElm);\r\n }\r\n\r\n return {\r\n x: oSize.h - cSize.h + fSize.h,\r\n y: oSize.w - cSize.w + fSize.w,\r\n };\r\n };\r\n\r\n const getNativeScrollbarsHiding = (testElm: HTMLElement): boolean => {\r\n let result = false;\r\n const revertClass = addClass(testElm, classNameEnvironmentScrollbarHidden);\r\n try {\r\n result =\r\n getStyles(testElm, 'scrollbar-width' as StyleObjectKey) === 'none' ||\r\n getStyles(testElm, 'display', '::-webkit-scrollbar') === 'none';\r\n // eslint-disable-next-line no-empty\r\n } catch {}\r\n revertClass();\r\n return result;\r\n };\r\n\r\n // changes to this styles need to be reflected in the \"hide native scrollbars\" section of the structure styles\r\n const envStyle = `.${classNameEnvironment}{scroll-behavior:auto!important;position:fixed;opacity:0;visibility:hidden;overflow:scroll;height:200px;width:200px;z-index:-1}.${classNameEnvironment} div{width:200%;height:200%;margin:10px 0}.${classNameEnvironmentScrollbarHidden}{scrollbar-width:none!important}.${classNameEnvironmentScrollbarHidden}::-webkit-scrollbar,.${classNameEnvironmentScrollbarHidden}::-webkit-scrollbar-corner{appearance:none!important;display:none!important;width:0!important;height:0!important}`;\r\n const envDOM = createDOM(\r\n `

`\r\n );\r\n const envElm = envDOM[0] as HTMLElement;\r\n const envChildElm = envElm.firstChild as HTMLElement;\r\n const styleElm = envElm.lastChild as HTMLStyleElement;\r\n const nonce = getNonce();\r\n\r\n if (nonce) {\r\n styleElm.nonce = nonce;\r\n }\r\n\r\n const [addEvent, , triggerEvent] = createEventListenerHub();\r\n const [updateNativeScrollbarSizeCache, getNativeScrollbarSizeCache] = createCache(\r\n {\r\n _initialValue: getNativeScrollbarSize(envElm, envChildElm),\r\n _equal: equalXY,\r\n },\r\n bind(getNativeScrollbarSize, envElm, envChildElm, true)\r\n );\r\n const [nativeScrollbarsSize] = getNativeScrollbarSizeCache();\r\n const nativeScrollbarsHiding = getNativeScrollbarsHiding(envElm);\r\n const nativeScrollbarsOverlaid = {\r\n x: nativeScrollbarsSize.x === 0,\r\n y: nativeScrollbarsSize.y === 0,\r\n };\r\n const staticDefaultInitialization: Initialization = {\r\n elements: {\r\n host: null,\r\n padding: !nativeScrollbarsHiding,\r\n viewport: (target) => nativeScrollbarsHiding && isBodyElement(target) && target,\r\n content: false,\r\n },\r\n scrollbars: {\r\n slot: true,\r\n },\r\n cancel: {\r\n nativeScrollbarsOverlaid: false,\r\n body: null,\r\n },\r\n };\r\n const staticDefaultOptions = assignDeep({}, defaultOptions);\r\n const getDefaultOptions = bind(\r\n assignDeep as typeof assignDeep,\r\n {} as Options,\r\n staticDefaultOptions\r\n );\r\n const getDefaultInitialization = bind(\r\n assignDeep as typeof assignDeep,\r\n {} as Initialization,\r\n staticDefaultInitialization\r\n );\r\n\r\n const env: Env = {\r\n _nativeScrollbarsSize: nativeScrollbarsSize,\r\n _nativeScrollbarsOverlaid: nativeScrollbarsOverlaid,\r\n _nativeScrollbarsHiding: nativeScrollbarsHiding,\r\n _scrollTimeline: !!scrollT,\r\n _addResizeListener: bind(addEvent, 'r'),\r\n _getDefaultInitialization: getDefaultInitialization,\r\n _setDefaultInitialization: (newInitializationStrategy) =>\r\n assignDeep(staticDefaultInitialization, newInitializationStrategy) &&\r\n getDefaultInitialization(),\r\n _getDefaultOptions: getDefaultOptions,\r\n _setDefaultOptions: (newDefaultOptions) =>\r\n assignDeep(staticDefaultOptions, newDefaultOptions) && getDefaultOptions(),\r\n _staticDefaultInitialization: assignDeep({}, staticDefaultInitialization),\r\n _staticDefaultOptions: assignDeep({}, staticDefaultOptions),\r\n };\r\n\r\n removeAttrs(envElm, 'style');\r\n removeElements(envElm);\r\n\r\n // needed in case content has css viewport units\r\n addEventListener(wnd, 'resize', () => {\r\n triggerEvent('r', []);\r\n });\r\n\r\n if (\r\n isFunction(wnd.matchMedia) &&\r\n !nativeScrollbarsHiding &&\r\n (!nativeScrollbarsOverlaid.x || !nativeScrollbarsOverlaid.y)\r\n ) {\r\n const addZoomListener = (onZoom: () => void) => {\r\n const media = wnd.matchMedia(`(resolution: ${wnd.devicePixelRatio}dppx)`);\r\n addEventListener(\r\n media,\r\n 'change',\r\n () => {\r\n onZoom();\r\n addZoomListener(onZoom);\r\n },\r\n {\r\n _once: true,\r\n }\r\n );\r\n };\r\n addZoomListener(() => {\r\n const [updatedNativeScrollbarSize, nativeScrollbarSizeChanged] =\r\n updateNativeScrollbarSizeCache();\r\n\r\n assignDeep(env._nativeScrollbarsSize, updatedNativeScrollbarSize); // keep the object and just re-assign!\r\n triggerEvent('r', [nativeScrollbarSizeChanged]);\r\n });\r\n }\r\n\r\n return env;\r\n};\r\n\r\nexport const getEnvironment = (): Env => {\r\n if (!environmentInstance) {\r\n environmentInstance = createEnvironment();\r\n }\r\n return environmentInstance;\r\n};\r\n","/* eslint-disable @typescript-eslint/no-explicit-any */\r\nimport {\r\n each,\r\n noop,\r\n MutationObserverConstructor,\r\n addEventListener,\r\n is,\r\n find,\r\n push,\r\n runEachAndClear,\r\n bind,\r\n isEmptyArray,\r\n deduplicateArray,\r\n inArray,\r\n concat,\r\n getAttr,\r\n isString,\r\n} from '../support';\r\n\r\ntype DOMContentObserverCallback = (contentChangedThroughEvent: boolean) => any;\r\n\r\ntype DOMTargetObserverCallback = (targetChangedAttrs: string[], targetStyleChanged: boolean) => any;\r\n\r\ninterface DOMObserverOptionsBase {\r\n _attributes?: string[];\r\n /**\r\n * A function which can ignore a changed attribute if it returns true.\r\n * for DOMTargetObserver this applies to the changes to the observed target\r\n * for DOMContentObserver this applies to changes to nested targets -> nested targets are elements which match the \"_nestedTargetSelector\" selector\r\n */\r\n _ignoreTargetChange?: DOMObserverIgnoreTargetChange;\r\n}\r\n\r\ninterface DOMContentObserverOptions extends DOMObserverOptionsBase {\r\n _eventContentChange?: DOMObserverEventContentChange; // [selector, eventname(s) | function returning eventname(s)] -> eventnames divided by whitespaces\r\n _nestedTargetSelector?: string;\r\n _ignoreContentChange?: DOMObserverIgnoreContentChange; // function which will prevent marking certain dom changes as content change if it returns true\r\n}\r\n\r\ninterface DOMTargetObserverOptions extends DOMObserverOptionsBase {\r\n /**\r\n * Marks certain attributes as style changing, should be a subset of the _attributes prop.\r\n * Used to set the \"targetStyleChanged\" param in the DOMTargetObserverCallback.\r\n */\r\n _styleChangingAttributes?: string[] | readonly string[];\r\n}\r\n\r\ntype ContentChangeArrayItem = [selector?: string, eventNames?: string] | null | undefined;\r\n\r\nexport type DOMObserverEventContentChange =\r\n | Array\r\n | false\r\n | null\r\n | undefined;\r\n\r\nexport type DOMObserverIgnoreContentChange = (\r\n mutation: MutationRecord,\r\n isNestedTarget: boolean,\r\n domObserverTarget: HTMLElement,\r\n domObserverOptions?: DOMContentObserverOptions\r\n) => boolean;\r\n\r\nexport type DOMObserverIgnoreTargetChange = (\r\n target: Node,\r\n attributeName: string,\r\n oldAttributeValue: string | null,\r\n newAttributeValue: string | null\r\n) => boolean;\r\n\r\nexport type DOMObserverCallback = ContentObserver extends true\r\n ? DOMContentObserverCallback\r\n : DOMTargetObserverCallback;\r\n\r\nexport type DOMObserverOptions = ContentObserver extends true\r\n ? DOMContentObserverOptions\r\n : DOMTargetObserverOptions;\r\n\r\nexport type DOMObserver = [\r\n construct: () => () => void,\r\n update: () => void | false | Parameters>,\r\n];\r\n\r\ntype EventContentChangeUpdateElement = (\r\n getElements?: (selector: string) => Node[],\r\n removed?: boolean\r\n) => void;\r\ntype EventContentChange = [destroy: () => void, updateElements: EventContentChangeUpdateElement];\r\n\r\n/**\r\n * Creates a set of helper functions to observe events of elements inside the target element.\r\n * @param target The target element of which the children elements shall be observed. (not only direct children but also nested ones)\r\n * @param eventContentChange The event content change array. (array of tuples: selector and eventname(s))\r\n * @param callback Callback which is called if one of the elements emits the corresponding event.\r\n * @returns A object which contains a set of helper functions to destroy and update the observation of elements.\r\n */\r\nconst createEventContentChange = (\r\n target: HTMLElement,\r\n callback: (...args: any) => any,\r\n eventContentChange?: DOMObserverEventContentChange\r\n): EventContentChange => {\r\n let destroyed = false;\r\n const map = eventContentChange ? new WeakMap any)[]>() : false; // weak map to prevent memory leak for detached elements\r\n const destroy = () => {\r\n destroyed = true;\r\n };\r\n const updateElements: EventContentChangeUpdateElement = (getElements) => {\r\n if (map && eventContentChange) {\r\n const eventElmList = eventContentChange.map((item) => {\r\n const [selector, eventNames] = item || [];\r\n const elements = eventNames && selector ? (getElements || find)(selector, target) : [];\r\n return [elements, eventNames] as const;\r\n });\r\n\r\n each(eventElmList, (item) =>\r\n each(item[0], (elm) => {\r\n const eventNames = item[1];\r\n const entries = map.get(elm) || [];\r\n const isTargetChild = target.contains(elm);\r\n\r\n if (isTargetChild && eventNames) {\r\n const removeListener = addEventListener(elm, eventNames, (event: Event) => {\r\n if (destroyed) {\r\n removeListener();\r\n map.delete(elm);\r\n } else {\r\n callback(event);\r\n }\r\n });\r\n map.set(elm, push(entries, removeListener));\r\n } else {\r\n runEachAndClear(entries);\r\n map.delete(elm);\r\n }\r\n })\r\n );\r\n }\r\n };\r\n\r\n updateElements();\r\n\r\n return [destroy, updateElements];\r\n};\r\n\r\n/**\r\n * Creates a DOM observer which observes DOM changes to either the target element or its children.\r\n * @param target The element which shall be observed.\r\n * @param isContentObserver Whether this observer is just observing the target or just the targets children. (not only direct children but also nested ones)\r\n * @param callback The callback which gets called if a change was detected.\r\n * @param options The options for DOM change detection.\r\n * @returns A object which represents the instance of the DOM observer.\r\n */\r\nexport const createDOMObserver = (\r\n target: HTMLElement,\r\n isContentObserver: ContentObserver,\r\n callback: DOMObserverCallback,\r\n options?: DOMObserverOptions\r\n): DOMObserver => {\r\n let isConnected = false;\r\n const {\r\n _attributes,\r\n _styleChangingAttributes,\r\n _eventContentChange,\r\n _nestedTargetSelector,\r\n _ignoreTargetChange,\r\n _ignoreContentChange,\r\n } = (options as DOMContentObserverOptions & DOMTargetObserverOptions) || {};\r\n const [destroyEventContentChange, updateEventContentChangeElements] = createEventContentChange(\r\n target,\r\n () => isConnected && (callback as DOMContentObserverCallback)(true),\r\n _eventContentChange\r\n );\r\n\r\n // MutationObserver\r\n const finalAttributes = _attributes || [];\r\n const finalStyleChangingAttributes = _styleChangingAttributes || [];\r\n const observedAttributes = concat(finalAttributes, finalStyleChangingAttributes);\r\n const observerCallback = (\r\n fromRecords: boolean,\r\n mutations: MutationRecord[]\r\n ): void | Parameters> => {\r\n if (!isEmptyArray(mutations)) {\r\n const ignoreTargetChange = _ignoreTargetChange || noop;\r\n const ignoreContentChange = _ignoreContentChange || noop;\r\n const totalChangedNodes: Node[] = [];\r\n const targetChangedAttrs: string[] = [];\r\n let targetStyleChanged: boolean | '' | null | undefined = false;\r\n let contentChanged: boolean | '' | null | undefined = false;\r\n let childListChanged: boolean | '' | null | undefined = false;\r\n\r\n each(mutations, (mutation) => {\r\n const {\r\n attributeName,\r\n target: mutationTarget,\r\n type,\r\n oldValue,\r\n addedNodes,\r\n removedNodes,\r\n } = mutation;\r\n const isAttributesType = type === 'attributes';\r\n const isChildListType = type === 'childList';\r\n const targetIsMutationTarget = target === mutationTarget;\r\n const isAttrChange = isAttributesType && attributeName;\r\n const newValue =\r\n isAttrChange && getAttr(mutationTarget as HTMLElement, attributeName || '');\r\n // narrow down attributeValue type to `string` or `null` but don't overwrite `` with `null`\r\n const attributeValue = isString(newValue) ? newValue : null;\r\n const attributeChanged = isAttrChange && oldValue !== attributeValue;\r\n const styleChangingAttrChanged =\r\n inArray(finalStyleChangingAttributes, attributeName) && attributeChanged;\r\n\r\n // if is content observer and something changed in children\r\n if (isContentObserver && (isChildListType || !targetIsMutationTarget)) {\r\n const contentAttrChanged = isAttributesType && attributeChanged;\r\n const isNestedTarget =\r\n contentAttrChanged &&\r\n _nestedTargetSelector &&\r\n is(mutationTarget, _nestedTargetSelector);\r\n const baseAssertion = isNestedTarget\r\n ? !ignoreTargetChange(mutationTarget, attributeName, oldValue, attributeValue)\r\n : !isAttributesType || contentAttrChanged;\r\n const contentFinalChanged =\r\n baseAssertion && !ignoreContentChange(mutation, !!isNestedTarget, target, options);\r\n\r\n each(addedNodes, (node) => push(totalChangedNodes, node));\r\n each(removedNodes, (node) => push(totalChangedNodes, node));\r\n\r\n contentChanged = contentChanged || contentFinalChanged;\r\n childListChanged = childListChanged || isChildListType;\r\n }\r\n // if is target observer and target attr changed\r\n if (\r\n !isContentObserver &&\r\n targetIsMutationTarget &&\r\n attributeChanged &&\r\n !ignoreTargetChange(mutationTarget, attributeName!, oldValue, attributeValue)\r\n ) {\r\n push(targetChangedAttrs, attributeName);\r\n targetStyleChanged = targetStyleChanged || styleChangingAttrChanged;\r\n }\r\n });\r\n\r\n // adds / removes the new elements from the event content change\r\n updateEventContentChangeElements((selector: string) =>\r\n deduplicateArray(totalChangedNodes).reduce((arr, node) => {\r\n push(arr, find(selector, node));\r\n return is(node, selector) ? push(arr, node) : arr;\r\n }, [])\r\n );\r\n\r\n if (isContentObserver) {\r\n if (!fromRecords && contentChanged) {\r\n (callback as DOMContentObserverCallback)(false);\r\n }\r\n return [false] satisfies Parameters> as Parameters<\r\n DOMObserverCallback\r\n >;\r\n }\r\n\r\n if (!isEmptyArray(targetChangedAttrs) || targetStyleChanged) {\r\n const args = [\r\n deduplicateArray(targetChangedAttrs),\r\n targetStyleChanged,\r\n ] satisfies Parameters & Parameters>;\r\n\r\n if (!fromRecords) {\r\n (callback as DOMTargetObserverCallback).apply(0, args);\r\n }\r\n\r\n return args as Parameters>;\r\n }\r\n }\r\n };\r\n const mutationObserver: MutationObserver = new MutationObserverConstructor!(\r\n bind(observerCallback, false)\r\n );\r\n\r\n return [\r\n () => {\r\n mutationObserver.observe(target, {\r\n attributes: true,\r\n attributeOldValue: true,\r\n attributeFilter: observedAttributes,\r\n subtree: isContentObserver,\r\n childList: isContentObserver,\r\n characterData: isContentObserver,\r\n });\r\n isConnected = true;\r\n\r\n return () => {\r\n if (isConnected) {\r\n destroyEventContentChange();\r\n mutationObserver.disconnect();\r\n isConnected = false;\r\n }\r\n };\r\n },\r\n () => {\r\n if (isConnected) {\r\n return observerCallback(true, mutationObserver.takeRecords());\r\n }\r\n },\r\n ];\r\n};\r\n","import type { SizeObserverPlugin } from '../plugins';\r\nimport {\r\n createCache,\r\n createDOM,\r\n runEachAndClear,\r\n addEventListener,\r\n addClass,\r\n push,\r\n ResizeObserverConstructor,\r\n appendChildren,\r\n domRectHasDimensions,\r\n bind,\r\n noop,\r\n domRectAppeared,\r\n concat,\r\n debounce,\r\n isBoolean,\r\n isArray,\r\n isEmptyArray,\r\n} from '../support';\r\nimport {\r\n classNameSizeObserver,\r\n classNameSizeObserverAppear,\r\n classNameSizeObserverListener,\r\n} from '../classnames';\r\nimport { getStaticPluginModuleInstance, sizeObserverPluginName } from '../plugins';\r\n\r\nexport interface SizeObserverOptions {\r\n /** Whether appearing should be observed. */\r\n _appear?: boolean;\r\n}\r\n\r\nexport interface SizeObserverCallbackParams {\r\n _sizeChanged: boolean;\r\n _appear?: boolean;\r\n}\r\n\r\nexport type SizeObserver = () => () => void;\r\n\r\nlet resizeObserverBoxSupport: boolean | null = null;\r\n\r\n/**\r\n * Creates a size observer which observes any size, padding, border, margin and box-sizing changes of the target element. Depending on the options also direction and appear can be observed.\r\n * @param target The target element which shall be observed.\r\n * @param onSizeChangedCallback The callback which gets called after a size change was detected.\r\n * @param options The options for size detection, whether to observe also direction and appear.\r\n * @returns A object which represents the instance of the size observer.\r\n */\r\nexport const createSizeObserver = (\r\n target: HTMLElement,\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n onSizeChangedCallback: (params: SizeObserverCallbackParams) => any,\r\n options?: SizeObserverOptions\r\n): SizeObserver => {\r\n const { _appear: observeAppearChange } = options || {};\r\n const sizeObserverPlugin =\r\n getStaticPluginModuleInstance(sizeObserverPluginName);\r\n const [updateResizeObserverContentRectCache] = createCache({\r\n _initialValue: false,\r\n _alwaysUpdateValues: true,\r\n });\r\n\r\n return () => {\r\n const destroyFns: (() => void)[] = [];\r\n const polyfillElements = createDOM(\r\n `
`\r\n );\r\n const polyfillRootElement = polyfillElements[0] as HTMLElement;\r\n const polyfillTargetElement = polyfillRootElement.firstChild as HTMLElement;\r\n\r\n const onSizeChangedCallbackProxy = (sizeChangedContext?: ResizeObserverEntry[] | boolean) => {\r\n const isResizeObserverCall = isArray(sizeChangedContext) && !isEmptyArray(sizeChangedContext);\r\n\r\n let skip = false;\r\n let appear = false;\r\n\r\n // if triggered from RO.\r\n if (isResizeObserverCall) {\r\n const resizeObserverEntry = sizeChangedContext[0];\r\n const [currContentRect, , prevContentRect] = updateResizeObserverContentRectCache(\r\n resizeObserverEntry.contentRect\r\n );\r\n const hasDimensions = domRectHasDimensions(currContentRect);\r\n appear = domRectAppeared(currContentRect, prevContentRect);\r\n skip = !appear && !hasDimensions; // skip if display is none or when window resize\r\n }\r\n // else if it triggered with appear from polyfill\r\n else {\r\n appear = sizeChangedContext === true;\r\n }\r\n\r\n if (!skip) {\r\n onSizeChangedCallback({\r\n _sizeChanged: true,\r\n _appear: appear,\r\n });\r\n }\r\n };\r\n\r\n if (ResizeObserverConstructor) {\r\n if (!isBoolean(resizeObserverBoxSupport)) {\r\n const detectSupportResizeObserver = new ResizeObserverConstructor(noop);\r\n detectSupportResizeObserver.observe(target, {\r\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\r\n // @ts-ignore -> void === undefined\r\n get box() {\r\n resizeObserverBoxSupport = true;\r\n },\r\n });\r\n resizeObserverBoxSupport = resizeObserverBoxSupport || false;\r\n detectSupportResizeObserver.disconnect();\r\n }\r\n\r\n /*\r\n const { port1, port2 } = new MessageChannel();\r\n const tasks: Set<() => void> = new Set();\r\n const debounceTiming: DebounceTiming = {\r\n _debouncer: (task) => {\r\n tasks.add(task);\r\n port2.postMessage(0);\r\n return () => {\r\n tasks.delete(task);\r\n };\r\n },\r\n };\r\n port1.onmessage = () => {\r\n tasks.forEach((task) => task());\r\n };\r\n */\r\n const debouncedOnSizeChangedCallbackProxy = debounce(onSizeChangedCallbackProxy, {\r\n _debounceTiming: 0,\r\n _maxDebounceTiming: 0,\r\n });\r\n const resizeObserverCallback = (entries: ResizeObserverEntry[]) =>\r\n debouncedOnSizeChangedCallbackProxy(entries);\r\n const contentBoxResizeObserver = new ResizeObserverConstructor(resizeObserverCallback);\r\n contentBoxResizeObserver.observe(resizeObserverBoxSupport ? target : polyfillTargetElement);\r\n\r\n push(destroyFns, [\r\n () => {\r\n contentBoxResizeObserver.disconnect();\r\n /*\r\n port1.close();\r\n port2.close();\r\n tasks.clear();\r\n */\r\n },\r\n !resizeObserverBoxSupport && appendChildren(target, polyfillRootElement),\r\n ]);\r\n\r\n if (resizeObserverBoxSupport) {\r\n const borderBoxResizeObserver = new ResizeObserverConstructor(resizeObserverCallback);\r\n borderBoxResizeObserver.observe(target, {\r\n box: 'border-box',\r\n });\r\n push(destroyFns, () => borderBoxResizeObserver.disconnect());\r\n }\r\n } else if (sizeObserverPlugin) {\r\n const [pluginAppearCallback, pluginDestroyFns] = sizeObserverPlugin(\r\n polyfillTargetElement,\r\n onSizeChangedCallbackProxy,\r\n observeAppearChange\r\n );\r\n push(\r\n destroyFns,\r\n concat(\r\n [\r\n addClass(polyfillRootElement, classNameSizeObserverAppear),\r\n addEventListener(polyfillRootElement, 'animationstart', pluginAppearCallback),\r\n appendChildren(target, polyfillRootElement),\r\n ],\r\n pluginDestroyFns\r\n )\r\n );\r\n } else {\r\n return noop;\r\n }\r\n\r\n return bind(runEachAndClear, destroyFns);\r\n };\r\n};\r\n","import type { WH, CacheValues } from '../support';\r\nimport { createSizeObserver } from './sizeObserver';\r\nimport { classNameTrinsicObserver } from '../classnames';\r\nimport {\r\n createDiv,\r\n getOffsetSize,\r\n runEachAndClear,\r\n createCache,\r\n push,\r\n IntersectionObserverConstructor,\r\n appendChildren,\r\n bind,\r\n} from '../support';\r\n\r\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\r\nexport type TrinsicObserverCallback = (heightIntrinsic: CacheValues) => any;\r\nexport type TrinsicObserver = [\r\n construct: () => () => void,\r\n update: () => void | false | null | undefined | Parameters,\r\n];\r\n\r\n/**\r\n * Creates a trinsic observer which observes changes to intrinsic or extrinsic sizing for the height of the target element.\r\n * @param target The element which shall be observed.\r\n * @param onTrinsicChangedCallback The callback which gets called after a change was detected.\r\n * @returns A object which represents the instance of the trinsic observer.\r\n */\r\nexport const createTrinsicObserver = (\r\n target: HTMLElement,\r\n onTrinsicChangedCallback: TrinsicObserverCallback\r\n): TrinsicObserver => {\r\n let intersectionObserverInstance: undefined | IntersectionObserver;\r\n const isHeightIntrinsic = (ioEntryOrSize: IntersectionObserverEntry | WH): boolean =>\r\n (ioEntryOrSize as WH).h === 0 ||\r\n (ioEntryOrSize as IntersectionObserverEntry).isIntersecting ||\r\n (ioEntryOrSize as IntersectionObserverEntry).intersectionRatio > 0;\r\n const trinsicObserver = createDiv(classNameTrinsicObserver);\r\n const [updateHeightIntrinsicCache] = createCache({\r\n _initialValue: false,\r\n });\r\n const triggerOnTrinsicChangedCallback = (\r\n updateValue: IntersectionObserverEntry | WH | undefined,\r\n fromRecords?: boolean\r\n ): void | Parameters => {\r\n if (updateValue) {\r\n const heightIntrinsic = updateHeightIntrinsicCache(isHeightIntrinsic(updateValue));\r\n const [, heightIntrinsicChanged] = heightIntrinsic;\r\n return (\r\n heightIntrinsicChanged &&\r\n !fromRecords &&\r\n onTrinsicChangedCallback(heightIntrinsic) && [heightIntrinsic]\r\n );\r\n }\r\n };\r\n const intersectionObserverCallback = (\r\n fromRecords: boolean,\r\n entries: IntersectionObserverEntry[]\r\n ) => triggerOnTrinsicChangedCallback(entries.pop(), fromRecords);\r\n\r\n return [\r\n () => {\r\n const destroyFns: (() => void)[] = [];\r\n\r\n if (IntersectionObserverConstructor) {\r\n intersectionObserverInstance = new IntersectionObserverConstructor(\r\n bind(intersectionObserverCallback, false),\r\n { root: target }\r\n );\r\n intersectionObserverInstance.observe(trinsicObserver);\r\n push(destroyFns, () => {\r\n intersectionObserverInstance!.disconnect();\r\n });\r\n } else {\r\n const onSizeChanged = () => {\r\n const newSize = getOffsetSize(trinsicObserver);\r\n triggerOnTrinsicChangedCallback(newSize);\r\n };\r\n push(destroyFns, createSizeObserver(trinsicObserver, onSizeChanged)());\r\n onSizeChanged();\r\n }\r\n\r\n return bind(runEachAndClear, push(destroyFns, appendChildren(target, trinsicObserver)));\r\n },\r\n () =>\r\n intersectionObserverInstance &&\r\n intersectionObserverCallback(true, intersectionObserverInstance.takeRecords()),\r\n ];\r\n};\r\n","import type { Options, OptionsCheckFn, OptionsDebounceValue } from '../../options';\r\nimport type { ScrollbarsHidingPlugin } from '../../plugins';\r\nimport type { SizeObserverCallbackParams } from '../../observers';\r\nimport type { StructureSetupElementsObj } from '../structureSetup/structureSetup.elements';\r\nimport type { Setup, SetupUpdateInfo, StructureSetupState } from '../../setups';\r\nimport type { CacheValues, DebounceLeading, DebounceTiming, WH } from '../../support';\r\nimport type { PlainObject } from '../../typings';\r\nimport { defaultOptionsUpdateDebounceEnv, defaultOptionsUpdateDebounceEvent } from '../../options';\r\nimport { getStaticPluginModuleInstance, scrollbarsHidingPluginName } from '../../plugins';\r\nimport {\r\n classNameScrollbar,\r\n dataAttributeHost,\r\n dataAttributeViewport,\r\n dataValueViewportMeasuring,\r\n dataValueViewportArrange,\r\n dataValueNoClipping,\r\n} from '../../classnames';\r\nimport { getEnvironment } from '../../environment';\r\nimport { createDOMObserver, createSizeObserver, createTrinsicObserver } from '../../observers';\r\nimport {\r\n ResizeObserverConstructor,\r\n assignDeep,\r\n closest,\r\n createCache,\r\n debounce,\r\n equalWH,\r\n getFractionalSize,\r\n isArray,\r\n isFunction,\r\n isNumber,\r\n isPlainObject,\r\n keys,\r\n liesBetween,\r\n getScrollSize,\r\n getElementScroll,\r\n scrollElementTo,\r\n domRectAppeared,\r\n concat,\r\n getStyles,\r\n hasAttrClass,\r\n} from '../../support';\r\n\r\nexport interface ObserversSetupState {\r\n _heightIntrinsic: boolean;\r\n _directionIsRTL: boolean;\r\n}\r\n\r\nexport interface ObserversSetupUpdateInfo extends SetupUpdateInfo {\r\n _takeRecords?: boolean;\r\n}\r\n\r\nexport type ObserversSetupUpdateHints = {\r\n _sizeChanged?: boolean;\r\n _directionChanged?: boolean;\r\n _heightIntrinsicChanged?: boolean;\r\n _hostMutation?: boolean;\r\n _contentMutation?: boolean;\r\n _appear?: boolean;\r\n _scrollbarSizeChanged?: boolean;\r\n};\r\n\r\nexport type ObserversSetup = Setup<\r\n ObserversSetupUpdateInfo,\r\n ObserversSetupState,\r\n ObserversSetupUpdateHints\r\n>;\r\n\r\nexport const createObserversSetup = (\r\n structureSetupElements: StructureSetupElementsObj,\r\n structureSetupState: StructureSetupState,\r\n getCurrentOption: OptionsCheckFn,\r\n onObserversUpdated: (updateHints: ObserversSetupUpdateHints) => void\r\n): ObserversSetup => {\r\n // latest debounce options\r\n let debounceMutation: OptionsDebounceValue | undefined;\r\n let debounceResize: OptionsDebounceValue | undefined;\r\n let debounceEvent: OptionsDebounceValue | undefined;\r\n let debounceEnv: OptionsDebounceValue | undefined;\r\n\r\n let updateContentMutationObserver: (() => void) | undefined;\r\n let destroyContentMutationObserver: (() => void) | undefined;\r\n let prevContentRect: DOMRectReadOnly | undefined;\r\n let prevDirectionIsRTL: boolean | undefined;\r\n const hostSelector = `[${dataAttributeHost}]`;\r\n\r\n // TODO: observer textarea attrs if textarea\r\n\r\n const viewportSelector = `[${dataAttributeViewport}]`;\r\n const baseStyleChangingAttrs = ['id', 'class', 'style', 'open', 'wrap', 'cols', 'rows'];\r\n const {\r\n _target,\r\n _host,\r\n _viewport,\r\n _scrollOffsetElement,\r\n _content,\r\n _viewportIsTarget,\r\n _isBody,\r\n _viewportHasClass,\r\n _viewportAddRemoveClass,\r\n _removeScrollObscuringStyles,\r\n } = structureSetupElements;\r\n const getDirectionIsRTL = (elm: HTMLElement): boolean => getStyles(elm, 'direction') === 'rtl';\r\n const createDebouncedObservesUpdate = () => {\r\n let currDebounceTiming: DebounceTiming;\r\n let currMaxDebounceTiming: DebounceTiming;\r\n let currDebounceLeading: DebounceLeading;\r\n const debouncedFn = debounce(onObserversUpdated, {\r\n _debounceTiming: () => currDebounceTiming,\r\n _maxDebounceTiming: () => currMaxDebounceTiming,\r\n _leading: () => currDebounceLeading,\r\n _mergeParams(prev, curr) {\r\n const [prevObj] = prev;\r\n const [currObj] = curr;\r\n return [\r\n concat(keys(prevObj), keys(currObj)).reduce((obj, key) => {\r\n obj[key] = prevObj[key as keyof typeof prevObj] || currObj[key as keyof typeof currObj];\r\n return obj;\r\n }, {} as PlainObject),\r\n ] as [Partial];\r\n },\r\n });\r\n const fn = (\r\n updateHints: ObserversSetupUpdateHints,\r\n debounceOption: OptionsDebounceValue | false | undefined\r\n ) => {\r\n if (isArray(debounceOption)) {\r\n const [timing, maxTiming, leading] = debounceOption;\r\n currDebounceTiming = timing;\r\n currMaxDebounceTiming = maxTiming;\r\n currDebounceLeading = leading;\r\n } else if (isNumber(debounceOption)) {\r\n currDebounceTiming = debounceOption;\r\n currMaxDebounceTiming = false;\r\n currDebounceLeading = false;\r\n } else {\r\n currDebounceTiming = false;\r\n currMaxDebounceTiming = false;\r\n currDebounceLeading = false;\r\n }\r\n\r\n debouncedFn(updateHints);\r\n };\r\n fn._flush = debouncedFn._flush;\r\n\r\n return fn;\r\n };\r\n\r\n const state: ObserversSetupState = {\r\n _heightIntrinsic: false,\r\n _directionIsRTL: getDirectionIsRTL(_target),\r\n };\r\n const env = getEnvironment();\r\n const scrollbarsHidingPlugin = getStaticPluginModuleInstance(\r\n scrollbarsHidingPluginName\r\n );\r\n const [updateContentSizeCache] = createCache>(\r\n {\r\n _equal: equalWH,\r\n _initialValue: { w: 0, h: 0 },\r\n },\r\n () => {\r\n const undoViewportArrange =\r\n scrollbarsHidingPlugin &&\r\n scrollbarsHidingPlugin._viewportArrangement(\r\n structureSetupElements,\r\n structureSetupState,\r\n state,\r\n env,\r\n getCurrentOption\r\n )._undoViewportArrange;\r\n\r\n const viewportIsTargetBody = _isBody && _viewportIsTarget;\r\n const noClipping =\r\n !viewportIsTargetBody && hasAttrClass(_host, dataAttributeHost, dataValueNoClipping);\r\n const isArranged = !_viewportIsTarget && _viewportHasClass(dataValueViewportArrange);\r\n const scrollOffset = isArranged && getElementScroll(_scrollOffsetElement);\r\n const revertScrollObscuringStyles = scrollOffset && _removeScrollObscuringStyles();\r\n\r\n const revertMeasuring = _viewportAddRemoveClass(dataValueViewportMeasuring, noClipping);\r\n const redoViewportArrange = isArranged && undoViewportArrange && undoViewportArrange();\r\n const viewportScroll = getScrollSize(_viewport);\r\n const fractional = getFractionalSize(_viewport);\r\n\r\n if (redoViewportArrange) {\r\n redoViewportArrange();\r\n }\r\n\r\n scrollElementTo(_scrollOffsetElement, scrollOffset);\r\n if (revertScrollObscuringStyles) {\r\n revertScrollObscuringStyles();\r\n }\r\n if (noClipping) {\r\n revertMeasuring();\r\n }\r\n\r\n return {\r\n w: viewportScroll.w + fractional.w,\r\n h: viewportScroll.h + fractional.h,\r\n };\r\n }\r\n );\r\n const onObserversUpdatedDebounced = createDebouncedObservesUpdate();\r\n const setDirection = (updateHints: ObserversSetupUpdateHints) => {\r\n const newDirectionIsRTL = getDirectionIsRTL(_target);\r\n assignDeep(updateHints, { _directionChanged: prevDirectionIsRTL !== newDirectionIsRTL });\r\n assignDeep(state, { _directionIsRTL: newDirectionIsRTL });\r\n prevDirectionIsRTL = newDirectionIsRTL;\r\n };\r\n const onTrinsicChanged = (\r\n heightIntrinsicCache: CacheValues,\r\n fromRecords?: true\r\n ): ObserversSetupUpdateHints => {\r\n const [heightIntrinsic, heightIntrinsicChanged] = heightIntrinsicCache;\r\n const updateHints: ObserversSetupUpdateHints = {\r\n _heightIntrinsicChanged: heightIntrinsicChanged,\r\n };\r\n\r\n assignDeep(state, { _heightIntrinsic: heightIntrinsic });\r\n\r\n if (!fromRecords) {\r\n onObserversUpdated(updateHints);\r\n }\r\n\r\n return updateHints;\r\n };\r\n const onSizeChanged = ({ _sizeChanged, _appear }: SizeObserverCallbackParams) => {\r\n // only don't debounce appear since it shouldn't happen that frequently\r\n const updateFn = _appear ? onObserversUpdated : onObserversUpdatedDebounced;\r\n const updateHints: ObserversSetupUpdateHints = {\r\n _sizeChanged: _sizeChanged || _appear,\r\n _appear,\r\n };\r\n\r\n setDirection(updateHints);\r\n updateFn(updateHints, debounceResize);\r\n };\r\n const onContentMutation = (\r\n contentChangedThroughEvent: boolean,\r\n fromRecords?: true\r\n ): ObserversSetupUpdateHints => {\r\n const [, _contentMutation] = updateContentSizeCache();\r\n const updateHints: ObserversSetupUpdateHints = {\r\n _contentMutation,\r\n };\r\n\r\n setDirection(updateHints);\r\n\r\n if (_contentMutation && !fromRecords) {\r\n onObserversUpdatedDebounced(\r\n updateHints,\r\n contentChangedThroughEvent ? debounceEvent : debounceMutation\r\n );\r\n }\r\n\r\n return updateHints;\r\n };\r\n const onHostMutation = (\r\n targetChangedAttrs: string[],\r\n targetStyleChanged: boolean,\r\n fromRecords?: true\r\n ): ObserversSetupUpdateHints => {\r\n const updateHints: ObserversSetupUpdateHints = {\r\n _hostMutation: targetStyleChanged,\r\n };\r\n\r\n setDirection(updateHints);\r\n\r\n if (targetStyleChanged && !fromRecords) {\r\n onObserversUpdatedDebounced(updateHints, debounceMutation);\r\n }\r\n /*\r\n else if (!_viewportIsTarget) {\r\n updateViewportAttrsFromHost(targetChangedAttrs);\r\n }\r\n */\r\n\r\n return updateHints;\r\n };\r\n const [constructTrinsicObserver, updateTrinsicObserver] = _content\r\n ? createTrinsicObserver(_host, onTrinsicChanged)\r\n : [];\r\n const constructSizeObserver =\r\n !_viewportIsTarget &&\r\n createSizeObserver(_host, onSizeChanged, {\r\n _appear: true,\r\n });\r\n const [constructHostMutationObserver, updateHostMutationObserver] = createDOMObserver(\r\n _host,\r\n false,\r\n onHostMutation,\r\n {\r\n _styleChangingAttributes: baseStyleChangingAttrs,\r\n _attributes: baseStyleChangingAttrs,\r\n }\r\n );\r\n const viewportIsTargetResizeObserver =\r\n _viewportIsTarget &&\r\n ResizeObserverConstructor &&\r\n new ResizeObserverConstructor((entries) => {\r\n const currContentRect = entries[entries.length - 1].contentRect;\r\n onSizeChanged({\r\n _sizeChanged: true,\r\n _appear: domRectAppeared(currContentRect, prevContentRect),\r\n });\r\n prevContentRect = currContentRect;\r\n });\r\n\r\n return [\r\n () => {\r\n // order is matter!\r\n // updateViewportAttrsFromHost();\r\n if (viewportIsTargetResizeObserver) {\r\n viewportIsTargetResizeObserver.observe(_host);\r\n }\r\n const destroySizeObserver = constructSizeObserver && constructSizeObserver();\r\n const destroyTrinsicObserver = constructTrinsicObserver && constructTrinsicObserver();\r\n const destroyHostMutationObserver = constructHostMutationObserver();\r\n const removeResizeListener = env._addResizeListener((_scrollbarSizeChanged) => {\r\n const [, _contentMutation] = updateContentSizeCache();\r\n onObserversUpdatedDebounced(\r\n { _scrollbarSizeChanged, _contentMutation, _sizeChanged: _isBody },\r\n debounceEnv\r\n );\r\n });\r\n\r\n return () => {\r\n if (viewportIsTargetResizeObserver) {\r\n viewportIsTargetResizeObserver.disconnect();\r\n }\r\n if (destroySizeObserver) {\r\n destroySizeObserver();\r\n }\r\n if (destroyTrinsicObserver) {\r\n destroyTrinsicObserver();\r\n }\r\n if (destroyContentMutationObserver) {\r\n destroyContentMutationObserver();\r\n }\r\n destroyHostMutationObserver();\r\n removeResizeListener();\r\n };\r\n },\r\n ({ _checkOption, _takeRecords, _force }) => {\r\n const updateHints: ObserversSetupUpdateHints = {};\r\n\r\n const [ignoreMutation] = _checkOption('update.ignoreMutation');\r\n const [attributes, attributesChanged] = _checkOption('update.attributes');\r\n const [elementEvents, elementEventsChanged] = _checkOption('update.elementEvents');\r\n const [debounceValue, debounceChanged] = _checkOption('update.debounce');\r\n const contentMutationObserverChanged = elementEventsChanged || attributesChanged;\r\n const takeRecords = _takeRecords || _force;\r\n const ignoreMutationFromOptions = (mutation: MutationRecord) =>\r\n isFunction(ignoreMutation) && ignoreMutation(mutation);\r\n\r\n if (contentMutationObserverChanged) {\r\n if (updateContentMutationObserver) {\r\n updateContentMutationObserver();\r\n }\r\n if (destroyContentMutationObserver) {\r\n destroyContentMutationObserver();\r\n }\r\n\r\n const [construct, update] = createDOMObserver(\r\n _content || _viewport,\r\n true,\r\n onContentMutation,\r\n {\r\n _attributes: concat(baseStyleChangingAttrs, attributes || []),\r\n _eventContentChange: elementEvents,\r\n _nestedTargetSelector: hostSelector,\r\n _ignoreContentChange: (mutation, isNestedTarget) => {\r\n const { target: mutationTarget, attributeName } = mutation;\r\n const ignore =\r\n !isNestedTarget && attributeName && !_viewportIsTarget\r\n ? liesBetween(mutationTarget, hostSelector, viewportSelector)\r\n : false;\r\n return (\r\n ignore ||\r\n !!closest(mutationTarget, `.${classNameScrollbar}`) || // ignore explicitely all scrollbar elements\r\n !!ignoreMutationFromOptions(mutation)\r\n );\r\n },\r\n }\r\n );\r\n\r\n destroyContentMutationObserver = construct();\r\n updateContentMutationObserver = update;\r\n }\r\n\r\n if (debounceChanged) {\r\n onObserversUpdatedDebounced._flush();\r\n // parse and distribute the debounce option\r\n if (isArray(debounceValue) || isNumber(debounceValue)) {\r\n // deprecated behavior: Value applies to mutation. resize and event are undefined\r\n debounceMutation = debounceValue;\r\n debounceResize = false;\r\n debounceEvent = defaultOptionsUpdateDebounceEvent;\r\n debounceEnv = defaultOptionsUpdateDebounceEnv;\r\n } else if (isPlainObject(debounceValue)) {\r\n debounceMutation = debounceValue.mutation;\r\n debounceResize = debounceValue.resize;\r\n debounceEvent = debounceValue.event;\r\n debounceEnv = debounceValue.env;\r\n } else {\r\n debounceMutation = false;\r\n debounceResize = false;\r\n debounceEvent = false;\r\n debounceEnv = false;\r\n }\r\n }\r\n\r\n if (takeRecords) {\r\n const hostUpdateResult = updateHostMutationObserver();\r\n const trinsicUpdateResult = updateTrinsicObserver && updateTrinsicObserver();\r\n const contentUpdateResult =\r\n updateContentMutationObserver && updateContentMutationObserver();\r\n\r\n if (hostUpdateResult) {\r\n assignDeep(\r\n updateHints,\r\n onHostMutation(hostUpdateResult[0], hostUpdateResult[1], takeRecords)\r\n );\r\n }\r\n\r\n if (trinsicUpdateResult) {\r\n assignDeep(updateHints, onTrinsicChanged(trinsicUpdateResult[0], takeRecords));\r\n }\r\n\r\n if (contentUpdateResult) {\r\n assignDeep(updateHints, onContentMutation(contentUpdateResult[0], takeRecords));\r\n }\r\n }\r\n\r\n setDirection(updateHints);\r\n\r\n return updateHints;\r\n },\r\n state,\r\n ];\r\n};\r\n","/* eslint-disable @typescript-eslint/no-explicit-any */\r\nimport type { DeepPartial } from './typings';\r\nimport { isFunction, isHTMLElement, isNull, isUndefined } from './support';\r\nimport { getEnvironment } from './environment';\r\n\r\ntype FallbackStaticInitializtationElement =\r\n Extract, (...args: Args) => any> extends (\r\n ...args: infer P\r\n ) => any\r\n ? (...args: P) => HTMLElement\r\n : never;\r\ntype FallbackDynamicInitializtationElement =\r\n Extract, (...args: Args) => any> extends (\r\n ...args: infer P\r\n ) => any\r\n ? (...args: P) => HTMLElement\r\n : never;\r\n\r\nexport type StaticInitialization = HTMLElement | false | null;\r\nexport type DynamicInitialization = HTMLElement | boolean | null;\r\n\r\n/**\r\n * Static elements are elements which MUST be present in the final DOM.\r\n * If an `HTMLElement` is passed the passed element will be taken as the repsective element.\r\n * With `false`, `null` or `undefined` an appropriate element is generated automatically.\r\n */\r\nexport type StaticInitializationElement =\r\n /** A function which returns the the StaticInitialization value. */\r\n | ((...args: Args) => StaticInitialization)\r\n /** The StaticInitialization value. */\r\n | StaticInitialization;\r\n\r\n/**\r\n * Dynamic elements are elements which CAN be present in the final DOM.\r\n * If an `HTMLElement`is passed the passed element will be taken as the repsective element.\r\n * With `true` an appropriate element is generated automatically.\r\n * With `false`, `null` or `undefined` the element won't be in the DOM.\r\n */\r\nexport type DynamicInitializationElement =\r\n /** A function which returns the the DynamicInitialization value. */\r\n | ((...args: Args) => DynamicInitialization)\r\n /** The DynamicInitialization value. */\r\n | DynamicInitialization;\r\n\r\n/**\r\n * Describes how a OverlayScrollbar instance should initialize.\r\n */\r\nexport type Initialization = {\r\n /**\r\n * Customizes which elements are generated and used.\r\n * If a function is passed to any of the fields, it receives the `target` element as its argument.\r\n * Any passed function should be a \"pure\" function. (same input produces same output)\r\n */\r\n elements: {\r\n /**\r\n * Assign a custom element as the host element.\r\n * Only relevant if the target element is a Textarea.\r\n */\r\n host: StaticInitializationElement<[target: InitializationTargetElement]>;\r\n /** Assign a custom element as the viewport element. */\r\n viewport: StaticInitializationElement<[target: InitializationTargetElement]>;\r\n /** Assign a custom element as the padding element or force the element not to be generated. */\r\n padding: DynamicInitializationElement<[target: InitializationTargetElement]>;\r\n /** Assign a custom element as the content element or force the element not to be generated. */\r\n content: DynamicInitializationElement<[target: InitializationTargetElement]>;\r\n };\r\n /**\r\n * Customizes elements related to the scrollbars.\r\n * If a function is passed, it receives the `target`, `host` and `viewport` element as arguments.\r\n */\r\n scrollbars: {\r\n slot: DynamicInitializationElement<\r\n [target: InitializationTargetElement, host: HTMLElement, viewport: HTMLElement]\r\n >;\r\n };\r\n /**\r\n * Customizes the cancelation behavior.\r\n */\r\n cancel: {\r\n /** Whether the initialization shall be canceled if the native scrollbars are overlaid. */\r\n nativeScrollbarsOverlaid: boolean;\r\n /**\r\n * Whether the initialization shall be canceled if its applied to a body element.\r\n * With `true` an initialization is always canceled, with `false` its never canceled.\r\n * With `null` the initialization will only be canceled when the initialization would affect the browsers functionality. (window.scrollTo, mobile browser behavior etc.)\r\n */\r\n body: boolean | null;\r\n };\r\n};\r\n\r\nexport type PartialInitialization = DeepPartial;\r\n\r\n/** The initialization target element. */\r\nexport type InitializationTargetElement = HTMLElement; // | HTMLTextAreaElement;\r\n\r\n/**\r\n * The initialization target object.\r\n * OverlayScrollbars({ target: myElement }) is equivalent to OverlayScrollbars(myElement).\r\n */\r\nexport type InitializationTargetObject = PartialInitialization & {\r\n target: InitializationTargetElement;\r\n};\r\n\r\n/** The initialization target. */\r\nexport type InitializationTarget = InitializationTargetElement | InitializationTargetObject;\r\n\r\nexport const resolveInitialization = (\r\n args: any,\r\n value: any\r\n): T => (isFunction(value) ? value.apply(0, args) : value);\r\n\r\nexport const staticInitializationElement = (\r\n args: Args,\r\n fallbackStaticInitializationElement: FallbackStaticInitializtationElement,\r\n defaultStaticInitializationElement: StaticInitializationElement,\r\n staticInitializationElementValue?: StaticInitializationElement\r\n): HTMLElement => {\r\n const staticInitialization = isUndefined(staticInitializationElementValue)\r\n ? defaultStaticInitializationElement\r\n : staticInitializationElementValue;\r\n const resolvedInitialization = resolveInitialization(\r\n args,\r\n staticInitialization\r\n );\r\n return resolvedInitialization || fallbackStaticInitializationElement.apply(0, args);\r\n};\r\n\r\nexport const dynamicInitializationElement = (\r\n args: Args,\r\n fallbackDynamicInitializationElement: FallbackDynamicInitializtationElement,\r\n defaultDynamicInitializationElement: DynamicInitializationElement,\r\n dynamicInitializationElementValue?: DynamicInitializationElement\r\n): HTMLElement | false => {\r\n const dynamicInitialization = isUndefined(dynamicInitializationElementValue)\r\n ? defaultDynamicInitializationElement\r\n : dynamicInitializationElementValue;\r\n const resolvedInitialization = resolveInitialization(\r\n args,\r\n dynamicInitialization\r\n );\r\n return (\r\n !!resolvedInitialization &&\r\n (isHTMLElement(resolvedInitialization)\r\n ? resolvedInitialization\r\n : fallbackDynamicInitializationElement.apply(0, args))\r\n );\r\n};\r\n\r\nexport const cancelInitialization = (\r\n isBody: boolean,\r\n cancelInitializationValue?: DeepPartial | false | null | undefined\r\n): boolean => {\r\n const { nativeScrollbarsOverlaid, body } = cancelInitializationValue || {};\r\n const { _nativeScrollbarsOverlaid, _nativeScrollbarsHiding, _getDefaultInitialization } =\r\n getEnvironment();\r\n const { nativeScrollbarsOverlaid: defaultNativeScrollbarsOverlaid, body: defaultbody } =\r\n _getDefaultInitialization().cancel;\r\n\r\n const resolvedNativeScrollbarsOverlaid =\r\n nativeScrollbarsOverlaid ?? defaultNativeScrollbarsOverlaid;\r\n const resolvedDocumentScrollingElement = isUndefined(body) ? defaultbody : body;\r\n\r\n const finalNativeScrollbarsOverlaid =\r\n (_nativeScrollbarsOverlaid.x || _nativeScrollbarsOverlaid.y) &&\r\n resolvedNativeScrollbarsOverlaid;\r\n const finalDocumentScrollingElement =\r\n isBody &&\r\n (isNull(resolvedDocumentScrollingElement)\r\n ? !_nativeScrollbarsHiding\r\n : resolvedDocumentScrollingElement);\r\n\r\n return !!finalNativeScrollbarsOverlaid || !!finalDocumentScrollingElement;\r\n};\r\n","import type { XY } from '../../support';\r\nimport type {\r\n InitializationTarget,\r\n InitializationTargetElement,\r\n InitializationTargetObject,\r\n} from '../../initialization';\r\nimport type { StructureSetupElementsObj } from '../structureSetup/structureSetup.elements';\r\nimport type { ScrollbarsSetupEvents } from './scrollbarsSetup.events';\r\nimport type { StyleObject } from '../../typings';\r\nimport type { StructureSetupState } from '../structureSetup';\r\nimport { dynamicInitializationElement as generalDynamicInitializationElement } from '../../initialization';\r\nimport { getEnvironment } from '../../environment';\r\nimport {\r\n classNameScrollbar,\r\n classNameScrollbarHorizontal,\r\n classNameScrollbarVertical,\r\n classNameScrollbarTrack,\r\n classNameScrollbarHandle,\r\n} from '../../classnames';\r\nimport {\r\n addClass,\r\n appendChildren,\r\n createDiv,\r\n each,\r\n getTrasformTranslateValue,\r\n isBoolean,\r\n parent,\r\n push,\r\n removeClass,\r\n removeElements,\r\n runEachAndClear,\r\n scrollT,\r\n bind,\r\n getElementScroll,\r\n numberToCssPx,\r\n setStyles,\r\n capNumber,\r\n getScrollCoordinatesPercent,\r\n isDefaultDirectionScrollCoordinates,\r\n roundCssNumber,\r\n} from '../../support';\r\n\r\nexport interface ScrollbarStructure {\r\n _scrollbar: HTMLElement;\r\n _track: HTMLElement;\r\n _handle: HTMLElement;\r\n}\r\n\r\nexport interface ScrollbarsSetupElement {\r\n _scrollbarStructures: ScrollbarStructure[];\r\n _clone: () => ScrollbarStructure;\r\n _style: (\r\n elmStyle: (\r\n scrollbarStructure: ScrollbarStructure\r\n ) => [HTMLElement | false | null | undefined, StyleObject]\r\n ) => void;\r\n}\r\n\r\nexport interface ScrollbarsSetupElementsObj {\r\n _scrollbarsAddRemoveClass: (\r\n classNames: string | false | null | undefined,\r\n add?: boolean,\r\n isHorizontal?: boolean\r\n ) => void;\r\n _refreshScrollbarsHandleLength: () => void;\r\n _refreshScrollbarsHandleOffset: () => void;\r\n _refreshScrollbarsScrollbarOffset: () => void;\r\n _refreshScrollbarsScrollCoordinates: () => void;\r\n _horizontal: ScrollbarsSetupElement;\r\n _vertical: ScrollbarsSetupElement;\r\n}\r\n\r\nexport type ScrollbarsSetupElements = [\r\n elements: ScrollbarsSetupElementsObj,\r\n appendElements: () => () => void,\r\n];\r\n\r\ntype ScrollbarStyleFn = (\r\n scrollbarStructure: ScrollbarStructure\r\n) => [HTMLElement | false | null | undefined, StyleObject | false | null | undefined];\r\n\r\nexport const createScrollbarsSetupElements = (\r\n target: InitializationTarget,\r\n structureSetupElements: StructureSetupElementsObj,\r\n structureSetupState: StructureSetupState,\r\n scrollbarsSetupEvents: ScrollbarsSetupEvents\r\n): ScrollbarsSetupElements => {\r\n const cssCustomPropViewportPercent = '--os-viewport-percent';\r\n const cssCustomPropScrollPercent = '--os-scroll-percent';\r\n const cssCustomPropScrollDirection = '--os-scroll-direction';\r\n const { _getDefaultInitialization } = getEnvironment();\r\n const { scrollbars: defaultInitScrollbars } = _getDefaultInitialization();\r\n const { slot: defaultInitScrollbarsSlot } = defaultInitScrollbars;\r\n const {\r\n _target,\r\n _host,\r\n _viewport,\r\n _targetIsElm,\r\n _scrollOffsetElement,\r\n _isBody,\r\n _viewportIsTarget,\r\n } = structureSetupElements;\r\n const { scrollbars: scrollbarsInit } = (_targetIsElm ? {} : target) as InitializationTargetObject;\r\n const { slot: initScrollbarsSlot } = scrollbarsInit || {};\r\n const destroyFns: (() => void)[] = [];\r\n const horizontalScrollbars: ScrollbarStructure[] = [];\r\n const verticalScrollbars: ScrollbarStructure[] = [];\r\n const evaluatedScrollbarSlot = generalDynamicInitializationElement<\r\n [InitializationTargetElement, HTMLElement, HTMLElement]\r\n >(\r\n [_target, _host, _viewport],\r\n () => (_viewportIsTarget && _isBody ? _target : _host),\r\n defaultInitScrollbarsSlot,\r\n initScrollbarsSlot\r\n );\r\n\r\n const initScrollTimeline = (axis: keyof XY) => {\r\n if (scrollT) {\r\n let currAnimation: Animation | null = null;\r\n let currAnimationTransform: string[] = [];\r\n const timeline = new scrollT({\r\n source: _scrollOffsetElement,\r\n axis,\r\n });\r\n const cancelAnimation = () => {\r\n if (currAnimation) {\r\n currAnimation.cancel();\r\n }\r\n currAnimation = null;\r\n };\r\n const _setScrollPercentAnimation = (structure: ScrollbarStructure) => {\r\n const { _scrollCoordinates } = structureSetupState;\r\n const defaultDirectionScroll =\r\n isDefaultDirectionScrollCoordinates(_scrollCoordinates)[axis];\r\n const isHorizontal = axis === 'x';\r\n const transformArray = [\r\n getTrasformTranslateValue(0, isHorizontal),\r\n getTrasformTranslateValue(`calc(-100% + 100cq${isHorizontal ? 'w' : 'h'})`, isHorizontal),\r\n ];\r\n const transform = defaultDirectionScroll ? transformArray : transformArray.reverse();\r\n\r\n // if the animation keyframes are identical, do nothing and keep current animation\r\n if (\r\n currAnimationTransform[0] === transform[0] &&\r\n currAnimationTransform[1] === transform[1]\r\n ) {\r\n return cancelAnimation;\r\n }\r\n\r\n currAnimationTransform = transform;\r\n\r\n cancelAnimation();\r\n currAnimation = structure._handle.animate(\r\n {\r\n // dummy keyframe which fixes bug where the scrollbar handle is reverted to origin position when it should be at its max position\r\n clear: ['left'],\r\n // transform is a temporary fix for: https://github.com/KingSora/OverlayScrollbars/issues/705\r\n // can be reverted to just animate \"cssCustomPropScrollPercent\" when browsers implement an optimization possibility\r\n transform,\r\n // [cssCustomPropScrollPercent]: [0, 1],\r\n },\r\n {\r\n timeline,\r\n }\r\n );\r\n\r\n return cancelAnimation;\r\n };\r\n\r\n return {\r\n _setScrollPercentAnimation,\r\n };\r\n }\r\n };\r\n const scrollTimeline = {\r\n x: initScrollTimeline('x'),\r\n y: initScrollTimeline('y'),\r\n };\r\n const getViewportPercent = () => {\r\n const { _overflowAmount, _overflowEdge } = structureSetupState;\r\n const getAxisValue = (axisViewportSize: number, axisOverflowAmount: number) =>\r\n capNumber(0, 1, axisViewportSize / (axisViewportSize + axisOverflowAmount) || 0);\r\n\r\n return {\r\n x: getAxisValue(_overflowEdge.x, _overflowAmount.x),\r\n y: getAxisValue(_overflowEdge.y, _overflowAmount.y),\r\n };\r\n };\r\n const scrollbarStructureAddRemoveClass = (\r\n scrollbarStructures: ScrollbarStructure[],\r\n classNames: string | false | null | undefined,\r\n add?: boolean\r\n ) => {\r\n const action = add ? addClass : removeClass;\r\n each(scrollbarStructures, (scrollbarStructure) => {\r\n action(scrollbarStructure._scrollbar, classNames);\r\n });\r\n };\r\n const scrollbarStyle = (\r\n scrollbarStructures: ScrollbarStructure[],\r\n elmStyle: ScrollbarStyleFn\r\n ) => {\r\n each(scrollbarStructures, (scrollbarStructure) => {\r\n const [elm, styles] = elmStyle(scrollbarStructure);\r\n setStyles(elm, styles);\r\n });\r\n };\r\n const scrollbarsAddRemoveClass = (\r\n className: string | false | null | undefined,\r\n add?: boolean,\r\n onlyHorizontal?: boolean\r\n ) => {\r\n const singleAxis = isBoolean(onlyHorizontal);\r\n const runHorizontal = singleAxis ? onlyHorizontal : true;\r\n const runVertical = singleAxis ? !onlyHorizontal : true;\r\n if (runHorizontal) {\r\n scrollbarStructureAddRemoveClass(horizontalScrollbars, className, add);\r\n }\r\n if (runVertical) {\r\n scrollbarStructureAddRemoveClass(verticalScrollbars, className, add);\r\n }\r\n };\r\n const refreshScrollbarsHandleLength = () => {\r\n const viewportPercent = getViewportPercent();\r\n const createScrollbarStyleFn =\r\n (axisViewportPercent: number): ScrollbarStyleFn =>\r\n (structure: ScrollbarStructure) => [\r\n structure._scrollbar,\r\n {\r\n [cssCustomPropViewportPercent]: roundCssNumber(axisViewportPercent) + '',\r\n },\r\n ];\r\n\r\n scrollbarStyle(horizontalScrollbars, createScrollbarStyleFn(viewportPercent.x));\r\n scrollbarStyle(verticalScrollbars, createScrollbarStyleFn(viewportPercent.y));\r\n };\r\n const refreshScrollbarsHandleOffset = () => {\r\n if (!scrollT) {\r\n const { _scrollCoordinates } = structureSetupState;\r\n const scrollPercent = getScrollCoordinatesPercent(\r\n _scrollCoordinates,\r\n getElementScroll(_scrollOffsetElement)\r\n );\r\n const createScrollbarStyleFn =\r\n (axisScrollPercent: number): ScrollbarStyleFn =>\r\n (structure: ScrollbarStructure) => [\r\n structure._scrollbar,\r\n {\r\n [cssCustomPropScrollPercent]: roundCssNumber(axisScrollPercent) + '',\r\n },\r\n ];\r\n\r\n scrollbarStyle(horizontalScrollbars, createScrollbarStyleFn(scrollPercent.x));\r\n scrollbarStyle(verticalScrollbars, createScrollbarStyleFn(scrollPercent.y));\r\n }\r\n };\r\n const refreshScrollbarsScrollCoordinates = () => {\r\n const { _scrollCoordinates } = structureSetupState;\r\n const defaultDirectionScroll = isDefaultDirectionScrollCoordinates(_scrollCoordinates);\r\n const createScrollbarStyleFn =\r\n (axisIsDefaultDirectionScrollCoordinates: boolean): ScrollbarStyleFn =>\r\n (structure: ScrollbarStructure) => [\r\n structure._scrollbar,\r\n {\r\n [cssCustomPropScrollDirection]: axisIsDefaultDirectionScrollCoordinates ? '0' : '1',\r\n },\r\n ];\r\n\r\n scrollbarStyle(horizontalScrollbars, createScrollbarStyleFn(defaultDirectionScroll.x));\r\n scrollbarStyle(verticalScrollbars, createScrollbarStyleFn(defaultDirectionScroll.y));\r\n\r\n // temporary fix for: https://github.com/KingSora/OverlayScrollbars/issues/705\r\n if (scrollT) {\r\n horizontalScrollbars.forEach(scrollTimeline.x!._setScrollPercentAnimation);\r\n verticalScrollbars.forEach(scrollTimeline.y!._setScrollPercentAnimation);\r\n }\r\n };\r\n const refreshScrollbarsScrollbarOffset = () => {\r\n if (_viewportIsTarget && !_isBody) {\r\n const { _overflowAmount, _scrollCoordinates } = structureSetupState;\r\n const isDefaultDirectionScroll = isDefaultDirectionScrollCoordinates(_scrollCoordinates);\r\n const scrollPercent = getScrollCoordinatesPercent(\r\n _scrollCoordinates,\r\n getElementScroll(_scrollOffsetElement)\r\n );\r\n const styleScrollbarPosition: ScrollbarStyleFn = (structure: ScrollbarStructure) => {\r\n const { _scrollbar } = structure;\r\n const elm = parent(_scrollbar) === _viewport && _scrollbar;\r\n const getTranslateValue = (\r\n axisScrollPercent: number,\r\n axisOverflowAmount: number,\r\n axisIsDefaultCoordinates: boolean\r\n ) => {\r\n const px = axisOverflowAmount * axisScrollPercent;\r\n return numberToCssPx(axisIsDefaultCoordinates ? px : -px);\r\n };\r\n\r\n return [\r\n elm,\r\n elm && {\r\n transform: getTrasformTranslateValue({\r\n x: getTranslateValue(scrollPercent.x, _overflowAmount.x, isDefaultDirectionScroll.x),\r\n y: getTranslateValue(scrollPercent.y, _overflowAmount.y, isDefaultDirectionScroll.y),\r\n }),\r\n },\r\n ];\r\n };\r\n\r\n scrollbarStyle(horizontalScrollbars, styleScrollbarPosition);\r\n scrollbarStyle(verticalScrollbars, styleScrollbarPosition);\r\n }\r\n };\r\n const generateScrollbarDOM = (isHorizontal?: boolean): ScrollbarStructure => {\r\n const xyKey = isHorizontal ? 'x' : 'y';\r\n const scrollbarClassName = isHorizontal\r\n ? classNameScrollbarHorizontal\r\n : classNameScrollbarVertical;\r\n const scrollbar = createDiv(`${classNameScrollbar} ${scrollbarClassName}`);\r\n const track = createDiv(classNameScrollbarTrack);\r\n const handle = createDiv(classNameScrollbarHandle);\r\n const result = {\r\n _scrollbar: scrollbar,\r\n _track: track,\r\n _handle: handle,\r\n };\r\n const timeline = scrollTimeline[xyKey];\r\n\r\n push(isHorizontal ? horizontalScrollbars : verticalScrollbars, result);\r\n push(destroyFns, [\r\n appendChildren(scrollbar, track),\r\n appendChildren(track, handle),\r\n bind(removeElements, scrollbar),\r\n timeline && timeline._setScrollPercentAnimation(result),\r\n scrollbarsSetupEvents(result, scrollbarsAddRemoveClass, isHorizontal),\r\n ]);\r\n\r\n return result;\r\n };\r\n const generateHorizontalScrollbarStructure = bind(generateScrollbarDOM, true);\r\n const generateVerticalScrollbarStructure = bind(generateScrollbarDOM, false);\r\n const appendElements = () => {\r\n appendChildren(evaluatedScrollbarSlot, horizontalScrollbars[0]._scrollbar);\r\n appendChildren(evaluatedScrollbarSlot, verticalScrollbars[0]._scrollbar);\r\n\r\n return bind(runEachAndClear, destroyFns);\r\n };\r\n\r\n generateHorizontalScrollbarStructure();\r\n generateVerticalScrollbarStructure();\r\n\r\n return [\r\n {\r\n _refreshScrollbarsHandleLength: refreshScrollbarsHandleLength,\r\n _refreshScrollbarsHandleOffset: refreshScrollbarsHandleOffset,\r\n _refreshScrollbarsScrollCoordinates: refreshScrollbarsScrollCoordinates,\r\n _refreshScrollbarsScrollbarOffset: refreshScrollbarsScrollbarOffset,\r\n _scrollbarsAddRemoveClass: scrollbarsAddRemoveClass,\r\n _horizontal: {\r\n _scrollbarStructures: horizontalScrollbars,\r\n _clone: generateHorizontalScrollbarStructure,\r\n _style: bind(scrollbarStyle, horizontalScrollbars),\r\n },\r\n _vertical: {\r\n _scrollbarStructures: verticalScrollbars,\r\n _clone: generateVerticalScrollbarStructure,\r\n _style: bind(scrollbarStyle, verticalScrollbars),\r\n },\r\n },\r\n appendElements,\r\n ];\r\n};\r\n","import type { XY } from '../../support';\r\nimport type { ClickScrollPlugin } from '../../plugins';\r\nimport type { ReadonlyOptions } from '../../options';\r\nimport type { StructureSetupState } from '../../setups';\r\nimport type { ScrollbarsSetupElementsObj, ScrollbarStructure } from './scrollbarsSetup.elements';\r\nimport type { StructureSetupElementsObj } from '../structureSetup/structureSetup.elements';\r\nimport {\r\n classNameScrollbarHandle,\r\n classNameScrollbarInteraction,\r\n classNameScrollbarWheel,\r\n dataAttributeHost,\r\n dataAttributeViewport,\r\n} from '../../classnames';\r\nimport { clickScrollPluginModuleName, getStaticPluginModuleInstance } from '../../plugins';\r\nimport {\r\n getBoundingClientRect,\r\n getOffsetSize,\r\n addEventListener,\r\n preventDefault,\r\n runEachAndClear,\r\n selfClearTimeout,\r\n parent,\r\n closest,\r\n push,\r\n bind,\r\n mathRound,\r\n strWidth,\r\n strHeight,\r\n getElementScroll,\r\n scrollElementTo,\r\n getFocusedElement,\r\n setT,\r\n hasAttr,\r\n stopAndPrevent,\r\n isFunction,\r\n mathAbs,\r\n focusElement,\r\n} from '../../support';\r\n\r\nexport type ScrollbarsSetupEvents = (\r\n scrollbarStructure: ScrollbarStructure,\r\n scrollbarsAddRemoveClass: ScrollbarsSetupElementsObj['_scrollbarsAddRemoveClass'],\r\n isHorizontal?: boolean\r\n) => () => void;\r\n\r\nexport const createScrollbarsSetupEvents = (\r\n options: ReadonlyOptions,\r\n structureSetupElements: StructureSetupElementsObj,\r\n structureSetupState: StructureSetupState,\r\n scrollbarHandlePointerInteraction: (event: PointerEvent) => void\r\n): ScrollbarsSetupEvents => {\r\n return (scrollbarStructure, scrollbarsAddRemoveClass, isHorizontal) => {\r\n const {\r\n _host,\r\n _viewport,\r\n _viewportIsTarget,\r\n _scrollOffsetElement,\r\n _documentElm,\r\n _removeScrollObscuringStyles,\r\n } = structureSetupElements;\r\n const { _scrollbar, _track, _handle } = scrollbarStructure;\r\n const [wheelTimeout, clearWheelTimeout] = selfClearTimeout(333);\r\n const [scrollSnapScrollTransitionTimeout, clearScrollSnapScrollTransitionTimeout] =\r\n selfClearTimeout(444);\r\n const scrollOffsetElementScrollBy = (coordinates: XY) => {\r\n if (isFunction(_scrollOffsetElement.scrollBy)) {\r\n _scrollOffsetElement.scrollBy({\r\n behavior: 'smooth',\r\n left: coordinates.x,\r\n top: coordinates.y,\r\n });\r\n }\r\n };\r\n\r\n const createInteractiveScrollEvents = () => {\r\n const releasePointerCaptureEvents = 'pointerup pointercancel lostpointercapture';\r\n const clientXYKey = `client${isHorizontal ? 'X' : 'Y'}` as 'clientX' | 'clientY';\r\n const widthHeightKey = isHorizontal ? strWidth : strHeight;\r\n const leftTopKey = isHorizontal ? 'left' : 'top';\r\n const whKey = isHorizontal ? 'w' : 'h';\r\n const xyKey = isHorizontal ? 'x' : 'y';\r\n\r\n const createRelativeHandleMove =\r\n (mouseDownScroll: number, invertedScale: number) => (deltaMovement: number) => {\r\n const { _overflowAmount } = structureSetupState;\r\n const handleTrackDiff = getOffsetSize(_track)[whKey] - getOffsetSize(_handle)[whKey];\r\n const scrollDeltaPercent = (invertedScale * deltaMovement) / handleTrackDiff;\r\n const scrollDelta = scrollDeltaPercent * _overflowAmount[xyKey];\r\n\r\n scrollElementTo(_scrollOffsetElement, {\r\n [xyKey]: mouseDownScroll + scrollDelta,\r\n });\r\n };\r\n const pointerdownCleanupFns: Array<() => void> = [];\r\n\r\n return addEventListener(_track, 'pointerdown', (pointerDownEvent: PointerEvent) => {\r\n const isDragScroll =\r\n closest(pointerDownEvent.target as Node, `.${classNameScrollbarHandle}`) === _handle;\r\n const pointerCaptureElement = isDragScroll ? _handle : _track;\r\n\r\n const scrollbarOptions = options.scrollbars;\r\n const dragClickScrollOption = scrollbarOptions[isDragScroll ? 'dragScroll' : 'clickScroll'];\r\n const { button, isPrimary, pointerType } = pointerDownEvent;\r\n const { pointers } = scrollbarOptions;\r\n\r\n const continuePointerDown =\r\n button === 0 &&\r\n isPrimary &&\r\n dragClickScrollOption &&\r\n (pointers || []).includes(pointerType);\r\n\r\n if (continuePointerDown) {\r\n runEachAndClear(pointerdownCleanupFns);\r\n clearScrollSnapScrollTransitionTimeout();\r\n\r\n const instantClickScroll =\r\n !isDragScroll && (pointerDownEvent.shiftKey || dragClickScrollOption === 'instant');\r\n const getHandleRect = bind(getBoundingClientRect, _handle);\r\n const getTrackRect = bind(getBoundingClientRect, _track);\r\n const getHandleOffset = (handleRect?: DOMRect, trackRect?: DOMRect) =>\r\n (handleRect || getHandleRect())[leftTopKey] - (trackRect || getTrackRect())[leftTopKey];\r\n const axisScale =\r\n mathRound(getBoundingClientRect(_scrollOffsetElement)[widthHeightKey]) /\r\n getOffsetSize(_scrollOffsetElement)[whKey] || 1;\r\n const moveHandleRelative = createRelativeHandleMove(\r\n getElementScroll(_scrollOffsetElement)[xyKey],\r\n 1 / axisScale\r\n );\r\n const pointerDownOffset = pointerDownEvent[clientXYKey];\r\n const handleRect = getHandleRect();\r\n const trackRect = getTrackRect();\r\n const handleLength = handleRect[widthHeightKey];\r\n const handleCenter = getHandleOffset(handleRect, trackRect) + handleLength / 2;\r\n const relativeTrackPointerOffset = pointerDownOffset - trackRect[leftTopKey];\r\n const startOffset = isDragScroll ? 0 : relativeTrackPointerOffset - handleCenter;\r\n const releasePointerCapture = (pointerUpEvent: PointerEvent) => {\r\n runEachAndClear(pointerupCleanupFns);\r\n pointerCaptureElement.releasePointerCapture(pointerUpEvent.pointerId);\r\n };\r\n const nonAnimatedScroll = isDragScroll || instantClickScroll;\r\n const revertScrollObscuringStyles = _removeScrollObscuringStyles();\r\n\r\n const pointerupCleanupFns = [\r\n addEventListener(_documentElm, releasePointerCaptureEvents, releasePointerCapture),\r\n addEventListener(_documentElm, 'selectstart', (event: Event) => preventDefault(event), {\r\n _passive: false,\r\n }),\r\n addEventListener(_track, releasePointerCaptureEvents, releasePointerCapture),\r\n nonAnimatedScroll &&\r\n addEventListener(_track, 'pointermove', (pointerMoveEvent: PointerEvent) =>\r\n moveHandleRelative(\r\n startOffset + (pointerMoveEvent[clientXYKey] - pointerDownOffset)\r\n )\r\n ),\r\n nonAnimatedScroll &&\r\n (() => {\r\n const withoutSnapScrollOffset = getElementScroll(_scrollOffsetElement);\r\n revertScrollObscuringStyles();\r\n const withSnapScrollOffset = getElementScroll(_scrollOffsetElement);\r\n const snapScrollDiff = {\r\n x: withSnapScrollOffset.x - withoutSnapScrollOffset.x,\r\n y: withSnapScrollOffset.y - withoutSnapScrollOffset.y,\r\n };\r\n\r\n if (mathAbs(snapScrollDiff.x) > 3 || mathAbs(snapScrollDiff.y) > 3) {\r\n _removeScrollObscuringStyles();\r\n scrollElementTo(_scrollOffsetElement, withoutSnapScrollOffset);\r\n scrollOffsetElementScrollBy(snapScrollDiff);\r\n scrollSnapScrollTransitionTimeout(revertScrollObscuringStyles);\r\n }\r\n }),\r\n ];\r\n\r\n pointerCaptureElement.setPointerCapture(pointerDownEvent.pointerId);\r\n\r\n if (instantClickScroll) {\r\n moveHandleRelative(startOffset);\r\n } else if (!isDragScroll) {\r\n const animateClickScroll = getStaticPluginModuleInstance(\r\n clickScrollPluginModuleName\r\n );\r\n if (animateClickScroll) {\r\n const stopClickScrollAnimation = animateClickScroll(\r\n moveHandleRelative,\r\n startOffset,\r\n handleLength,\r\n (stopped) => {\r\n // if the scroll animation doesn't continue with a press\r\n if (stopped) {\r\n revertScrollObscuringStyles();\r\n } else {\r\n push(pointerupCleanupFns, revertScrollObscuringStyles);\r\n }\r\n }\r\n );\r\n\r\n push(pointerupCleanupFns, stopClickScrollAnimation);\r\n push(pointerdownCleanupFns, bind(stopClickScrollAnimation, true));\r\n }\r\n }\r\n }\r\n });\r\n };\r\n\r\n let wheelScrollBy = true;\r\n\r\n return bind(runEachAndClear, [\r\n addEventListener(_handle, 'pointermove pointerleave', scrollbarHandlePointerInteraction),\r\n addEventListener(_scrollbar, 'pointerenter', () => {\r\n scrollbarsAddRemoveClass(classNameScrollbarInteraction, true);\r\n }),\r\n addEventListener(_scrollbar, 'pointerleave pointercancel', () => {\r\n scrollbarsAddRemoveClass(classNameScrollbarInteraction, false);\r\n }),\r\n // focus viewport when clicking on a scrollbar (mouse only)\r\n !_viewportIsTarget &&\r\n addEventListener(_scrollbar, 'mousedown', () => {\r\n const focusedElement = getFocusedElement();\r\n // dont steal focus from buttons or other interactive elements\r\n if (\r\n hasAttr(focusedElement, dataAttributeViewport) ||\r\n hasAttr(focusedElement, dataAttributeHost) ||\r\n focusedElement === document.body\r\n ) {\r\n setT(bind(focusElement, _viewport), 25);\r\n }\r\n }),\r\n // propagate wheel events to viewport when mouse is over scrollbar\r\n addEventListener(\r\n _scrollbar,\r\n 'wheel',\r\n (wheelEvent: WheelEvent) => {\r\n const { deltaX, deltaY, deltaMode } = wheelEvent;\r\n\r\n // the first wheel event is swallowed, simulate scroll to compensate for it\r\n if (wheelScrollBy && deltaMode === 0 && parent(_scrollbar) === _host) {\r\n scrollOffsetElementScrollBy({\r\n x: deltaX,\r\n y: deltaY,\r\n });\r\n }\r\n\r\n wheelScrollBy = false;\r\n scrollbarsAddRemoveClass(classNameScrollbarWheel, true);\r\n wheelTimeout(() => {\r\n wheelScrollBy = true;\r\n scrollbarsAddRemoveClass(classNameScrollbarWheel);\r\n });\r\n\r\n preventDefault(wheelEvent);\r\n },\r\n { _passive: false, _capture: true }\r\n ),\r\n // solve problem of interaction causing `click` events (https://github.com/KingSora/OverlayScrollbars/issues/251)\r\n // 1. on `scrollbar` pointer down register a `document` click event which gets prevented and propagation is stopped\r\n // 2. on `document` pointerup / pointercancel remove that click event after a timeout (in case the click is never triggered)\r\n addEventListener(\r\n _scrollbar,\r\n 'pointerdown',\r\n () => {\r\n const removeClickEvent = addEventListener(\r\n _documentElm,\r\n 'click',\r\n (clickEvent: Event) => {\r\n removePointerEvents();\r\n stopAndPrevent(clickEvent);\r\n },\r\n {\r\n _once: true,\r\n _capture: true,\r\n _passive: false,\r\n }\r\n );\r\n const removePointerEvents = addEventListener(\r\n _documentElm,\r\n 'pointerup pointercancel',\r\n () => {\r\n removePointerEvents();\r\n setTimeout(removeClickEvent, 150);\r\n },\r\n {\r\n _capture: true,\r\n _passive: true,\r\n }\r\n );\r\n },\r\n { _capture: true, _passive: true }\r\n ),\r\n createInteractiveScrollEvents(),\r\n clearWheelTimeout,\r\n clearScrollSnapScrollTransitionTimeout,\r\n ]);\r\n };\r\n};\r\n","import type { OverflowBehavior, ReadonlyOptions } from '../../options';\r\nimport type { ScrollbarsSetupElementsObj } from './scrollbarsSetup.elements';\r\nimport type {\r\n ObserversSetupState,\r\n ObserversSetupUpdateHints,\r\n Setup,\r\n SetupUpdateInfo,\r\n StructureSetupState,\r\n StructureSetupUpdateHints,\r\n} from '../../setups';\r\nimport type { InitializationTarget } from '../../initialization';\r\nimport type { OverflowStyle } from '../../typings';\r\nimport type { StructureSetupElementsObj } from '../structureSetup/structureSetup.elements';\r\nimport {\r\n classNameScrollbarThemeNone,\r\n classNameScrollbarVisible,\r\n classNameScrollbarUnusable,\r\n classNameScrollbarCornerless,\r\n classNameScrollbarAutoHideHidden,\r\n classNameScrollbarHandleInteractive,\r\n classNameScrollbarTrackInteractive,\r\n classNameScrollbarRtl,\r\n classNameScrollbarAutoHide,\r\n} from '../../classnames';\r\nimport { getEnvironment } from '../../environment';\r\nimport {\r\n bind,\r\n noop,\r\n addEventListener,\r\n push,\r\n runEachAndClear,\r\n selfClearTimeout,\r\n strScroll,\r\n strVisible,\r\n} from '../../support';\r\nimport { createScrollbarsSetupElements } from './scrollbarsSetup.elements';\r\nimport { createScrollbarsSetupEvents } from './scrollbarsSetup.events';\r\nimport {\r\n getStaticPluginModuleInstance,\r\n ScrollbarsHidingPlugin,\r\n scrollbarsHidingPluginName,\r\n} from '../../plugins';\r\n\r\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\r\nexport interface ScrollbarsSetupState {}\r\n\r\nexport interface ScrollbarsSetupUpdateInfo extends SetupUpdateInfo {\r\n _observersUpdateHints?: ObserversSetupUpdateHints;\r\n _structureUpdateHints?: StructureSetupUpdateHints;\r\n}\r\n\r\nexport type ScrollbarsSetup = [\r\n ...Setup,\r\n /** The elements created by the scrollbars setup. */\r\n ScrollbarsSetupElementsObj,\r\n];\r\n\r\nexport const createScrollbarsSetup = (\r\n target: InitializationTarget,\r\n options: ReadonlyOptions,\r\n observersSetupState: ObserversSetupState,\r\n structureSetupState: StructureSetupState,\r\n structureSetupElements: StructureSetupElementsObj,\r\n onScroll: (event: Event) => void\r\n): ScrollbarsSetup => {\r\n let mouseInHost: boolean | undefined;\r\n let autoHideIsMove: boolean | undefined;\r\n let autoHideIsLeave: boolean | undefined;\r\n let autoHideIsNever: boolean | undefined;\r\n let prevTheme: string | null | undefined;\r\n let instanceAutoHideSuspendScrollDestroyFn = noop;\r\n let instanceAutoHideDelay = 0;\r\n const hoverablePointerTypes = ['mouse', 'pen'];\r\n\r\n // needed to not fire unnecessary operations for pointer events on ios safari which will cause side effects: https://github.com/KingSora/OverlayScrollbars/issues/560\r\n const isHoverablePointerType = (event: PointerEvent) =>\r\n hoverablePointerTypes.includes(event.pointerType);\r\n\r\n const [requestScrollAnimationFrame, cancelScrollAnimationFrame] = selfClearTimeout();\r\n const [autoHideInstantInteractionTimeout, clearAutoHideInstantInteractionTimeout] =\r\n selfClearTimeout(100);\r\n const [autoHideSuspendTimeout, clearAutoHideSuspendTimeout] = selfClearTimeout(100);\r\n const [auotHideTimeout, clearAutoHideTimeout] = selfClearTimeout(() => instanceAutoHideDelay);\r\n const [elements, appendElements] = createScrollbarsSetupElements(\r\n target,\r\n structureSetupElements,\r\n structureSetupState,\r\n createScrollbarsSetupEvents(\r\n options,\r\n structureSetupElements,\r\n structureSetupState,\r\n (event) => isHoverablePointerType(event) && manageScrollbarsAutoHideInstantInteraction()\r\n )\r\n );\r\n const { _host, _scrollEventElement, _isBody } = structureSetupElements;\r\n const {\r\n _scrollbarsAddRemoveClass,\r\n _refreshScrollbarsHandleLength,\r\n _refreshScrollbarsHandleOffset,\r\n _refreshScrollbarsScrollCoordinates,\r\n _refreshScrollbarsScrollbarOffset,\r\n } = elements;\r\n const manageScrollbarsAutoHide = (removeAutoHide: boolean, delayless?: boolean) => {\r\n clearAutoHideTimeout();\r\n if (removeAutoHide) {\r\n _scrollbarsAddRemoveClass(classNameScrollbarAutoHideHidden);\r\n } else {\r\n const hide = bind(_scrollbarsAddRemoveClass, classNameScrollbarAutoHideHidden, true);\r\n if (instanceAutoHideDelay > 0 && !delayless) {\r\n auotHideTimeout(hide);\r\n } else {\r\n hide();\r\n }\r\n }\r\n };\r\n const manageScrollbarsAutoHideInstantInteraction = () => {\r\n if (autoHideIsLeave ? !mouseInHost : !autoHideIsNever) {\r\n manageScrollbarsAutoHide(true);\r\n autoHideInstantInteractionTimeout(() => {\r\n manageScrollbarsAutoHide(false);\r\n });\r\n }\r\n };\r\n const manageAutoHideSuspension = (add: boolean) => {\r\n _scrollbarsAddRemoveClass(classNameScrollbarAutoHide, add, true);\r\n _scrollbarsAddRemoveClass(classNameScrollbarAutoHide, add, false);\r\n };\r\n const onHostMouseEnter = (event: PointerEvent) => {\r\n if (isHoverablePointerType(event)) {\r\n mouseInHost = autoHideIsLeave;\r\n if (autoHideIsLeave) {\r\n manageScrollbarsAutoHide(true);\r\n }\r\n }\r\n };\r\n const destroyFns: (() => void)[] = [\r\n clearAutoHideTimeout,\r\n clearAutoHideInstantInteractionTimeout,\r\n clearAutoHideSuspendTimeout,\r\n cancelScrollAnimationFrame,\r\n () => instanceAutoHideSuspendScrollDestroyFn(),\r\n\r\n addEventListener(_host, 'pointerover', onHostMouseEnter, { _once: true }),\r\n addEventListener(_host, 'pointerenter', onHostMouseEnter),\r\n addEventListener(_host, 'pointerleave', (event: PointerEvent) => {\r\n if (isHoverablePointerType(event)) {\r\n mouseInHost = false;\r\n if (autoHideIsLeave) {\r\n manageScrollbarsAutoHide(false);\r\n }\r\n }\r\n }),\r\n addEventListener(_host, 'pointermove', (event: PointerEvent) => {\r\n if (isHoverablePointerType(event) && autoHideIsMove) {\r\n manageScrollbarsAutoHideInstantInteraction();\r\n }\r\n }),\r\n addEventListener(_scrollEventElement, 'scroll', (event) => {\r\n requestScrollAnimationFrame(() => {\r\n _refreshScrollbarsHandleOffset();\r\n manageScrollbarsAutoHideInstantInteraction();\r\n });\r\n\r\n onScroll(event);\r\n\r\n _refreshScrollbarsScrollbarOffset();\r\n }),\r\n ];\r\n const scrollbarsHidingPlugin = getStaticPluginModuleInstance(\r\n scrollbarsHidingPluginName\r\n );\r\n\r\n return [\r\n () => bind(runEachAndClear, push(destroyFns, appendElements())),\r\n ({ _checkOption, _force, _observersUpdateHints, _structureUpdateHints }) => {\r\n const {\r\n _overflowEdgeChanged,\r\n _overflowAmountChanged,\r\n _overflowStyleChanged,\r\n _scrollCoordinatesChanged,\r\n } = _structureUpdateHints || {};\r\n const { _directionChanged, _appear } = _observersUpdateHints || {};\r\n const { _directionIsRTL } = observersSetupState;\r\n const { _nativeScrollbarsOverlaid, _nativeScrollbarsHiding } = getEnvironment();\r\n const { _overflowStyle, _hasOverflow } = structureSetupState;\r\n const [showNativeOverlaidScrollbarsOption, showNativeOverlaidScrollbarsChanged] =\r\n _checkOption('showNativeOverlaidScrollbars');\r\n const [theme, themeChanged] = _checkOption('scrollbars.theme');\r\n const [visibility, visibilityChanged] = _checkOption('scrollbars.visibility');\r\n const [autoHide, autoHideChanged] = _checkOption('scrollbars.autoHide');\r\n const [autoHideSuspend, autoHideSuspendChanged] = _checkOption('scrollbars.autoHideSuspend');\r\n const [autoHideDelay] = _checkOption('scrollbars.autoHideDelay');\r\n const [dragScroll, dragScrollChanged] = _checkOption('scrollbars.dragScroll');\r\n const [clickScroll, clickScrollChanged] = _checkOption('scrollbars.clickScroll');\r\n const [overflow, overflowChanged] = _checkOption('overflow');\r\n const trulyAppeared = _appear && !_force;\r\n const hasOverflow = _hasOverflow.x || _hasOverflow.y;\r\n const updateScrollbars =\r\n _overflowEdgeChanged ||\r\n _overflowAmountChanged ||\r\n _scrollCoordinatesChanged ||\r\n _directionChanged ||\r\n _force;\r\n const updateVisibility = _overflowStyleChanged || visibilityChanged || overflowChanged;\r\n const showNativeOverlaidScrollbars =\r\n showNativeOverlaidScrollbarsOption &&\r\n _nativeScrollbarsOverlaid.x &&\r\n _nativeScrollbarsOverlaid.y;\r\n const cantHideScrollbars = !_nativeScrollbarsHiding && !scrollbarsHidingPlugin;\r\n const showNativeScrollbars = showNativeOverlaidScrollbars || cantHideScrollbars;\r\n\r\n const setScrollbarVisibility = (\r\n overflowBehavior: OverflowBehavior,\r\n overflowStyle: OverflowStyle,\r\n isHorizontal: boolean\r\n ) => {\r\n const isVisible =\r\n overflowBehavior.includes(strScroll) &&\r\n (visibility === strVisible || (visibility === 'auto' && overflowStyle === strScroll));\r\n\r\n _scrollbarsAddRemoveClass(classNameScrollbarVisible, isVisible, isHorizontal);\r\n\r\n return isVisible;\r\n };\r\n\r\n instanceAutoHideDelay = autoHideDelay;\r\n\r\n if (trulyAppeared) {\r\n if (autoHideSuspend && hasOverflow) {\r\n manageAutoHideSuspension(false);\r\n instanceAutoHideSuspendScrollDestroyFn();\r\n autoHideSuspendTimeout(() => {\r\n instanceAutoHideSuspendScrollDestroyFn = addEventListener(\r\n _scrollEventElement,\r\n 'scroll',\r\n bind(manageAutoHideSuspension, true),\r\n {\r\n _once: true,\r\n }\r\n );\r\n });\r\n } else {\r\n manageAutoHideSuspension(true);\r\n }\r\n }\r\n\r\n if (showNativeOverlaidScrollbarsChanged || cantHideScrollbars) {\r\n _scrollbarsAddRemoveClass(classNameScrollbarThemeNone, showNativeScrollbars);\r\n }\r\n\r\n if (themeChanged) {\r\n _scrollbarsAddRemoveClass(prevTheme);\r\n _scrollbarsAddRemoveClass(theme, true);\r\n\r\n prevTheme = theme;\r\n }\r\n\r\n if (autoHideSuspendChanged && !autoHideSuspend) {\r\n manageAutoHideSuspension(true);\r\n }\r\n\r\n if (autoHideChanged) {\r\n autoHideIsMove = autoHide === 'move';\r\n autoHideIsLeave = autoHide === 'leave';\r\n autoHideIsNever = autoHide === 'never';\r\n manageScrollbarsAutoHide(autoHideIsNever, true);\r\n }\r\n\r\n if (dragScrollChanged) {\r\n _scrollbarsAddRemoveClass(classNameScrollbarHandleInteractive, dragScroll);\r\n }\r\n\r\n if (clickScrollChanged) {\r\n _scrollbarsAddRemoveClass(classNameScrollbarTrackInteractive, !!clickScroll);\r\n }\r\n\r\n // always update scrollbar visibility before scrollbar size\r\n // the scrollbar size is influenced whether both or just one scrollbar is visible (because of the corner element)\r\n if (updateVisibility) {\r\n const xVisible = setScrollbarVisibility(overflow.x, _overflowStyle.x, true);\r\n const yVisible = setScrollbarVisibility(overflow.y, _overflowStyle.y, false);\r\n const hasCorner = xVisible && yVisible;\r\n\r\n _scrollbarsAddRemoveClass(classNameScrollbarCornerless, !hasCorner);\r\n }\r\n\r\n // always update scrollbar sizes after the visibility\r\n if (updateScrollbars) {\r\n _refreshScrollbarsHandleOffset();\r\n _refreshScrollbarsHandleLength();\r\n _refreshScrollbarsScrollbarOffset();\r\n if (_scrollCoordinatesChanged) {\r\n _refreshScrollbarsScrollCoordinates();\r\n }\r\n\r\n _scrollbarsAddRemoveClass(classNameScrollbarUnusable, !_hasOverflow.x, true);\r\n _scrollbarsAddRemoveClass(classNameScrollbarUnusable, !_hasOverflow.y, false);\r\n _scrollbarsAddRemoveClass(classNameScrollbarRtl, _directionIsRTL && !_isBody);\r\n }\r\n },\r\n {},\r\n elements,\r\n ];\r\n};\r\n","import type {\r\n InitializationTarget,\r\n InitializationTargetElement,\r\n InitializationTargetObject,\r\n} from '../../initialization';\r\nimport {\r\n isHTMLElement,\r\n appendChildren,\r\n createDiv,\r\n contents,\r\n parent,\r\n removeElements,\r\n push,\r\n runEachAndClear,\r\n removeAttrs,\r\n hasAttrClass,\r\n addEventListener,\r\n bind,\r\n inArray,\r\n addAttrClass,\r\n addRemoveAttrClass,\r\n setAttrs,\r\n getAttr,\r\n isBodyElement,\r\n getFocusedElement,\r\n wnd,\r\n focusElement,\r\n stopAndPrevent,\r\n getOffsetSize,\r\n getScrollSize,\r\n getStyles,\r\n strOverflowX,\r\n strOverflowY,\r\n} from '../../support';\r\nimport {\r\n dataAttributeHost,\r\n dataAttributeInitialize,\r\n dataAttributeViewport,\r\n dataValueViewportScrollbarHidden,\r\n dataAttributePadding,\r\n dataAttributeContent,\r\n dataAttributeHtmlBody,\r\n dataValueHostIsHost,\r\n dataValueViewportScrolling,\r\n} from '../../classnames';\r\nimport { getEnvironment } from '../../environment';\r\nimport {\r\n staticInitializationElement as generalStaticInitializationElement,\r\n dynamicInitializationElement as generalDynamicInitializationElement,\r\n} from '../../initialization';\r\nimport { overflowIsVisible } from './structureSetup.utils';\r\n\r\nexport type StructureSetupElements = [\r\n elements: StructureSetupElementsObj,\r\n appendElements: () => () => void,\r\n canceled: () => void,\r\n];\r\n\r\nexport interface StructureSetupElementsObj {\r\n _target: InitializationTargetElement;\r\n _host: HTMLElement;\r\n _viewport: HTMLElement;\r\n _padding: HTMLElement | false;\r\n _content: HTMLElement | false;\r\n _scrollOffsetElement: HTMLElement;\r\n _scrollEventElement: HTMLElement | Document;\r\n _originalScrollOffsetElement: HTMLElement;\r\n // ctx ----\r\n _isBody: boolean;\r\n _documentElm: Document;\r\n _targetIsElm: boolean;\r\n _viewportIsTarget: boolean;\r\n _windowElm: () => Window;\r\n _viewportHasClass: (viewportAttributeClassName: string) => boolean;\r\n _viewportAddRemoveClass: (viewportAttributeClassName: string, add?: boolean) => () => void;\r\n _removeScrollObscuringStyles: () => () => void;\r\n}\r\n\r\nexport const createStructureSetupElements = (\r\n target: InitializationTarget\r\n): StructureSetupElements => {\r\n const env = getEnvironment();\r\n const { _getDefaultInitialization, _nativeScrollbarsHiding } = env;\r\n const { elements: defaultInitElements } = _getDefaultInitialization();\r\n const {\r\n padding: defaultPaddingInitialization,\r\n viewport: defaultViewportInitialization,\r\n content: defaultContentInitialization,\r\n } = defaultInitElements;\r\n const targetIsElm = isHTMLElement(target);\r\n const targetStructureInitialization = (targetIsElm ? {} : target) as InitializationTargetObject;\r\n const { elements: initElements } = targetStructureInitialization;\r\n const {\r\n padding: paddingInitialization,\r\n viewport: viewportInitialization,\r\n content: contentInitialization,\r\n } = initElements || {};\r\n\r\n const targetElement = targetIsElm ? target : targetStructureInitialization.target;\r\n const isBody = isBodyElement(targetElement);\r\n const ownerDocument = targetElement.ownerDocument;\r\n const docElement = ownerDocument.documentElement;\r\n const getDocumentWindow = () => ownerDocument.defaultView || wnd;\r\n const staticInitializationElement = bind(generalStaticInitializationElement, [targetElement]);\r\n const dynamicInitializationElement = bind(generalDynamicInitializationElement, [targetElement]);\r\n const createNewDiv = bind(createDiv, '');\r\n const generateViewportElement = bind(\r\n staticInitializationElement,\r\n createNewDiv,\r\n defaultViewportInitialization\r\n );\r\n const generateContentElement = bind(\r\n dynamicInitializationElement,\r\n createNewDiv,\r\n defaultContentInitialization\r\n );\r\n const elementHasOverflow = (elm: HTMLElement) => {\r\n const offsetSize = getOffsetSize(elm);\r\n const scrollSize = getScrollSize(elm);\r\n const overflowX = getStyles(elm, strOverflowX);\r\n const overflowY = getStyles(elm, strOverflowY);\r\n\r\n return (\r\n (scrollSize.w - offsetSize.w > 0 && !overflowIsVisible(overflowX)) ||\r\n (scrollSize.h - offsetSize.h > 0 && !overflowIsVisible(overflowY))\r\n );\r\n };\r\n const possibleViewportElement = generateViewportElement(viewportInitialization);\r\n const viewportIsTarget = possibleViewportElement === targetElement;\r\n const viewportIsTargetBody = viewportIsTarget && isBody;\r\n const possibleContentElement = !viewportIsTarget && generateContentElement(contentInitialization);\r\n // edge case if passed viewportElement is contentElement:\r\n // viewport element has higher priority and content element will not be generated\r\n // will act the same way as initialization: `{ elements: { viewport, content: false } }`\r\n const viewportIsContent = !viewportIsTarget && possibleViewportElement === possibleContentElement;\r\n const viewportElement = viewportIsTargetBody ? docElement : possibleViewportElement;\r\n const hostElement = viewportIsTargetBody ? viewportElement : targetElement;\r\n const paddingElement =\r\n !viewportIsTarget &&\r\n dynamicInitializationElement(createNewDiv, defaultPaddingInitialization, paddingInitialization);\r\n const contentElement = !viewportIsContent && possibleContentElement;\r\n const generatedElements = [contentElement, viewportElement, paddingElement, hostElement].map(\r\n (elm) => isHTMLElement(elm) && !parent(elm) && elm\r\n );\r\n const elementIsGenerated = (elm: HTMLElement | false) => elm && inArray(generatedElements, elm);\r\n const originalNonBodyScrollOffsetElement =\r\n !elementIsGenerated(viewportElement) && elementHasOverflow(viewportElement)\r\n ? viewportElement\r\n : targetElement;\r\n const scrollOffsetElement = viewportIsTargetBody ? docElement : viewportElement;\r\n const scrollEventElement = viewportIsTargetBody ? ownerDocument : viewportElement;\r\n\r\n const evaluatedTargetObj: StructureSetupElementsObj = {\r\n _target: targetElement,\r\n _host: hostElement,\r\n _viewport: viewportElement,\r\n _padding: paddingElement,\r\n _content: contentElement,\r\n _scrollOffsetElement: scrollOffsetElement,\r\n _scrollEventElement: scrollEventElement,\r\n _originalScrollOffsetElement: isBody ? docElement : originalNonBodyScrollOffsetElement,\r\n _documentElm: ownerDocument,\r\n _isBody: isBody,\r\n _targetIsElm: targetIsElm,\r\n _viewportIsTarget: viewportIsTarget,\r\n _windowElm: getDocumentWindow,\r\n _viewportHasClass: (viewportAttributeClassName: string) =>\r\n hasAttrClass(viewportElement, dataAttributeViewport, viewportAttributeClassName),\r\n _viewportAddRemoveClass: (viewportAttributeClassName: string, add?: boolean) =>\r\n addRemoveAttrClass(viewportElement, dataAttributeViewport, viewportAttributeClassName, add),\r\n _removeScrollObscuringStyles: () =>\r\n addRemoveAttrClass(\r\n scrollOffsetElement,\r\n dataAttributeViewport,\r\n dataValueViewportScrolling,\r\n true\r\n ),\r\n };\r\n const { _target, _host, _padding, _viewport, _content } = evaluatedTargetObj;\r\n const destroyFns: (() => void)[] = [\r\n () => {\r\n // always remove dataAttributeHost & dataAttributeInitialize from host and from element if target is body\r\n removeAttrs(_host, [dataAttributeHost, dataAttributeInitialize]);\r\n removeAttrs(_target, dataAttributeInitialize);\r\n if (isBody) {\r\n removeAttrs(docElement, [dataAttributeInitialize, dataAttributeHost]);\r\n }\r\n },\r\n ];\r\n let targetContents = contents(\r\n [_content, _viewport, _padding, _host, _target].find((elm) => elm && !elementIsGenerated(elm))\r\n );\r\n const contentSlot = viewportIsTargetBody ? _target : _content || _viewport;\r\n const destroy = bind(runEachAndClear, destroyFns);\r\n const appendElements = () => {\r\n const docWnd = getDocumentWindow();\r\n const initActiveElm = getFocusedElement();\r\n const unwrap = (elm: HTMLElement | false | null | undefined) => {\r\n appendChildren(parent(elm), contents(elm));\r\n removeElements(elm);\r\n };\r\n // wrapping / unwrapping will cause the focused element to blur, this should prevent those events to surface\r\n const prepareWrapUnwrapFocus = (activeElement: Element | false | null | undefined) =>\r\n addEventListener(activeElement, 'focusin focusout focus blur', stopAndPrevent, {\r\n _capture: true,\r\n _passive: false,\r\n });\r\n const tabIndexStr = 'tabindex';\r\n const originalViewportTabIndex = getAttr(_viewport, tabIndexStr);\r\n const undoInitWrapUndwrapFocus = prepareWrapUnwrapFocus(initActiveElm);\r\n setAttrs(_host, dataAttributeHost, viewportIsTarget ? '' : dataValueHostIsHost);\r\n setAttrs(_padding, dataAttributePadding, '');\r\n setAttrs(_viewport, dataAttributeViewport, '');\r\n setAttrs(_content, dataAttributeContent, '');\r\n\r\n if (!viewportIsTarget) {\r\n setAttrs(_viewport, tabIndexStr, originalViewportTabIndex || '-1');\r\n if (isBody) {\r\n setAttrs(docElement, dataAttributeHtmlBody, '');\r\n }\r\n }\r\n\r\n appendChildren(contentSlot, targetContents);\r\n appendChildren(_host, _padding);\r\n appendChildren(_padding || _host, !viewportIsTarget && _viewport);\r\n appendChildren(_viewport, _content);\r\n\r\n push(destroyFns, [\r\n undoInitWrapUndwrapFocus,\r\n () => {\r\n const destroyActiveElm = getFocusedElement();\r\n const viewportIsGenerated = elementIsGenerated(_viewport);\r\n // if the focused element is viewport and viewport will be destroyed shift the focus to target\r\n // otherwise keep the focused element\r\n const destroyFocusElement =\r\n viewportIsGenerated && destroyActiveElm === _viewport ? _target : destroyActiveElm;\r\n const undoDestroyWrapUndwrapFocus = prepareWrapUnwrapFocus(destroyFocusElement);\r\n removeAttrs(_padding, dataAttributePadding);\r\n removeAttrs(_content, dataAttributeContent);\r\n removeAttrs(_viewport, dataAttributeViewport);\r\n if (isBody) {\r\n removeAttrs(docElement, dataAttributeHtmlBody);\r\n }\r\n if (originalViewportTabIndex) {\r\n setAttrs(_viewport, tabIndexStr, originalViewportTabIndex);\r\n } else {\r\n removeAttrs(_viewport, tabIndexStr);\r\n }\r\n\r\n if (elementIsGenerated(_content)) {\r\n unwrap(_content);\r\n }\r\n if (viewportIsGenerated) {\r\n unwrap(_viewport);\r\n }\r\n if (elementIsGenerated(_padding)) {\r\n unwrap(_padding);\r\n }\r\n\r\n focusElement(destroyFocusElement);\r\n undoDestroyWrapUndwrapFocus();\r\n },\r\n ]);\r\n\r\n if (_nativeScrollbarsHiding && !viewportIsTarget) {\r\n addAttrClass(_viewport, dataAttributeViewport, dataValueViewportScrollbarHidden);\r\n push(destroyFns, bind(removeAttrs, _viewport, dataAttributeViewport));\r\n }\r\n\r\n // keep the original focused element focused except when\r\n // the target is body and viewport is not target, then shift the focus to the viewport element\r\n focusElement(\r\n !viewportIsTarget && isBody && initActiveElm === _target && docWnd.top === docWnd\r\n ? _viewport\r\n : initActiveElm\r\n );\r\n undoInitWrapUndwrapFocus();\r\n\r\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\r\n // @ts-ignore\r\n targetContents = 0;\r\n\r\n return destroy;\r\n };\r\n\r\n return [evaluatedTargetObj, appendElements, destroy];\r\n};\r\n","import type { CreateStructureUpdateSegment } from '../structureSetup';\r\nimport { setStyles, strHeight } from '../../../support';\r\n\r\n/**\r\n * Lifecycle with the responsibility to adjust the trinsic behavior of the content element.\r\n * @param structureUpdateHub\r\n * @returns\r\n */\r\nexport const createTrinsicUpdateSegment: CreateStructureUpdateSegment =\r\n ({ _content }) =>\r\n ({ _observersUpdateHints, _observersState, _force }) => {\r\n const { _heightIntrinsicChanged } = _observersUpdateHints || {};\r\n const { _heightIntrinsic } = _observersState;\r\n const heightIntrinsicChanged = _content && (_heightIntrinsicChanged || _force);\r\n\r\n if (heightIntrinsicChanged) {\r\n setStyles(_content, {\r\n [strHeight]: _heightIntrinsic && '100%',\r\n });\r\n }\r\n };\r\n","import type { StyleObject } from '../../../typings';\r\nimport type { CreateStructureUpdateSegment } from '../structureSetup';\r\nimport {\r\n createCache,\r\n topRightBottomLeft,\r\n equalTRBL,\r\n assignDeep,\r\n bind,\r\n strMarginBottom,\r\n strMarginLeft,\r\n strMarginRight,\r\n strPaddingBottom,\r\n strPaddingLeft,\r\n strPaddingRight,\r\n strPaddingTop,\r\n strWidth,\r\n setStyles,\r\n} from '../../../support';\r\nimport { getEnvironment } from '../../../environment';\r\n\r\n/**\r\n * Lifecycle with the responsibility to adjust the padding styling of the padding and viewport element.\r\n * @param structureUpdateHub\r\n * @returns\r\n */\r\nexport const createPaddingUpdateSegment: CreateStructureUpdateSegment = (\r\n { _host, _padding, _viewport, _viewportIsTarget },\r\n state\r\n) => {\r\n const [updatePaddingCache, currentPaddingCache] = createCache(\r\n {\r\n _equal: equalTRBL,\r\n _initialValue: topRightBottomLeft(),\r\n },\r\n bind(topRightBottomLeft, _host, 'padding', '')\r\n );\r\n\r\n return ({ _checkOption, _observersUpdateHints, _observersState, _force }) => {\r\n let [padding, paddingChanged] = currentPaddingCache(_force);\r\n const { _nativeScrollbarsHiding } = getEnvironment();\r\n const { _sizeChanged, _contentMutation, _directionChanged } = _observersUpdateHints || {};\r\n const { _directionIsRTL } = _observersState;\r\n const [paddingAbsolute, paddingAbsoluteChanged] = _checkOption('paddingAbsolute');\r\n const contentMutation = _force || _contentMutation;\r\n\r\n if (_sizeChanged || paddingChanged || contentMutation) {\r\n [padding, paddingChanged] = updatePaddingCache(_force);\r\n }\r\n\r\n const paddingStyleChanged =\r\n !_viewportIsTarget && (paddingAbsoluteChanged || _directionChanged || paddingChanged);\r\n\r\n if (paddingStyleChanged) {\r\n // if there is no padding element and no scrollbar styling, paddingAbsolute isn't supported\r\n const paddingRelative = !paddingAbsolute || (!_padding && !_nativeScrollbarsHiding);\r\n const paddingHorizontal = padding.r + padding.l;\r\n const paddingVertical = padding.t + padding.b;\r\n\r\n const paddingStyle: StyleObject = {\r\n [strMarginRight]: paddingRelative && !_directionIsRTL ? -paddingHorizontal : 0,\r\n [strMarginBottom]: paddingRelative ? -paddingVertical : 0,\r\n [strMarginLeft]: paddingRelative && _directionIsRTL ? -paddingHorizontal : 0,\r\n top: paddingRelative ? -padding.t : 0,\r\n right: paddingRelative ? (_directionIsRTL ? -padding.r : 'auto') : 0,\r\n left: paddingRelative ? (_directionIsRTL ? 'auto' : -padding.l) : 0,\r\n [strWidth]: paddingRelative && `calc(100% + ${paddingHorizontal}px)`,\r\n };\r\n const viewportStyle: StyleObject = {\r\n [strPaddingTop]: paddingRelative ? padding.t : 0,\r\n [strPaddingRight]: paddingRelative ? padding.r : 0,\r\n [strPaddingBottom]: paddingRelative ? padding.b : 0,\r\n [strPaddingLeft]: paddingRelative ? padding.l : 0,\r\n };\r\n\r\n // if there is no padding element apply the style to the viewport element instead\r\n setStyles(_padding || _viewport, paddingStyle);\r\n setStyles(_viewport, viewportStyle);\r\n\r\n assignDeep(state, {\r\n _padding: padding,\r\n _paddingAbsolute: !paddingRelative,\r\n _viewportPaddingStyle: _padding\r\n ? viewportStyle\r\n : assignDeep({}, paddingStyle, viewportStyle),\r\n });\r\n }\r\n\r\n return {\r\n _paddingStyleChanged: paddingStyleChanged,\r\n };\r\n };\r\n};\r\n","import type { ScrollCoordinates, WH, XY } from '../../../support';\r\nimport type { ScrollbarsHidingPlugin } from '../../../plugins/scrollbarsHidingPlugin';\r\nimport type { OverflowStyle } from '../../../typings';\r\nimport type { CreateStructureUpdateSegment } from '../structureSetup';\r\nimport {\r\n createCache,\r\n getScrollSize,\r\n getFractionalSize,\r\n equalWH,\r\n getClientSize,\r\n equalXY,\r\n assignDeep,\r\n bind,\r\n wnd,\r\n mathMax,\r\n getWindowSize,\r\n addRemoveAttrClass,\r\n capitalizeFirstLetter,\r\n setStyles,\r\n strVisible,\r\n strHidden,\r\n keys,\r\n strScroll,\r\n scrollElementTo,\r\n getElementScroll,\r\n sanitizeScrollCoordinates,\r\n getStyles,\r\n equal,\r\n getZeroScrollCoordinates,\r\n hasDimensions,\r\n addEventListener,\r\n stopPropagation,\r\n rAF,\r\n hasAttrClass,\r\n} from '../../../support';\r\nimport { getEnvironment } from '../../../environment';\r\nimport {\r\n dataAttributeHost,\r\n dataValueNoClipping,\r\n dataValueViewportScrollbarHidden,\r\n dataAttributePadding,\r\n dataValueViewportOverflowXPrefix,\r\n dataValueViewportOverflowYPrefix,\r\n dataValueViewportNoContent,\r\n dataValueViewportMeasuring,\r\n} from '../../../classnames';\r\nimport { getStaticPluginModuleInstance, scrollbarsHidingPluginName } from '../../../plugins';\r\nimport {\r\n getShowNativeOverlaidScrollbars,\r\n getElementOverflowStyle,\r\n overflowBehaviorToOverflowStyle,\r\n overflowCssValueToOverflowStyle,\r\n overflowIsVisible,\r\n} from '../structureSetup.utils';\r\nimport { OverflowBehavior } from '../../../options';\r\n\r\ninterface FlowDirectionStyles {\r\n display?: string;\r\n direction?: string;\r\n flexDirection?: string;\r\n writingMode?: string;\r\n}\r\n\r\n/**\r\n * Lifecycle with the responsibility to set the correct overflow and scrollbar hiding styles of the viewport element.\r\n * @param structureUpdateHub\r\n * @returns\r\n */\r\nexport const createOverflowUpdateSegment: CreateStructureUpdateSegment = (\r\n structureSetupElements,\r\n structureSetupState\r\n) => {\r\n const env = getEnvironment();\r\n const {\r\n _host,\r\n _padding,\r\n _viewport,\r\n _viewportIsTarget,\r\n _scrollEventElement,\r\n _scrollOffsetElement,\r\n _isBody,\r\n _viewportAddRemoveClass,\r\n _windowElm,\r\n } = structureSetupElements;\r\n const { _nativeScrollbarsHiding } = env;\r\n const viewportIsTargetBody = _isBody && _viewportIsTarget;\r\n const max0 = bind(mathMax, 0);\r\n const flowDirectionCanBeNonDefaultMap: Record<\r\n keyof FlowDirectionStyles,\r\n (styleValue: string) => boolean\r\n > = {\r\n display: () => false,\r\n direction: (directionStyle) => directionStyle !== 'ltr',\r\n flexDirection: (flexDirectionStyle) => flexDirectionStyle.endsWith('-reverse'),\r\n writingMode: (writingModeStyle) => writingModeStyle !== 'horizontal-tb',\r\n };\r\n const flowDirectionStyleArr = keys(flowDirectionCanBeNonDefaultMap) as Array<\r\n keyof FlowDirectionStyles\r\n >;\r\n const whCacheOptions = {\r\n _equal: equalWH,\r\n _initialValue: { w: 0, h: 0 },\r\n };\r\n const partialXYOptions = {\r\n _equal: equalXY,\r\n _initialValue: {},\r\n };\r\n\r\n const setMeasuringMode = (active: boolean) => {\r\n // viewportIsTargetBody never needs measuring\r\n _viewportAddRemoveClass(dataValueViewportMeasuring, !viewportIsTargetBody && active);\r\n };\r\n\r\n const getMeasuredScrollCoordinates = (flowDirectionStyles: FlowDirectionStyles) => {\r\n const flowDirectionCanBeNonDefault = flowDirectionStyleArr.some((styleName) => {\r\n const styleValue = flowDirectionStyles[styleName];\r\n return styleValue && flowDirectionCanBeNonDefaultMap[styleName](styleValue);\r\n });\r\n\r\n // if the direction can not be non-default return default scroll coordinates (only the sign of the numbers matters)\r\n if (!flowDirectionCanBeNonDefault) {\r\n return {\r\n _start: { x: 0, y: 0 },\r\n _end: { x: 1, y: 1 },\r\n };\r\n }\r\n\r\n setMeasuringMode(true);\r\n\r\n const originalScrollOffset = getElementScroll(_scrollOffsetElement);\r\n const removeNoContent = _viewportAddRemoveClass(dataValueViewportNoContent, true);\r\n const removeScrollBlock = addEventListener(\r\n _scrollEventElement,\r\n strScroll,\r\n (event) => {\r\n const scrollEventScrollOffset = getElementScroll(_scrollOffsetElement);\r\n // if scroll offset didnt change\r\n if (\r\n event.isTrusted &&\r\n scrollEventScrollOffset.x === originalScrollOffset.x &&\r\n scrollEventScrollOffset.y === originalScrollOffset.y\r\n ) {\r\n stopPropagation(event);\r\n }\r\n },\r\n {\r\n _capture: true,\r\n _once: true,\r\n }\r\n );\r\n\r\n scrollElementTo(_scrollOffsetElement, {\r\n x: 0,\r\n y: 0,\r\n });\r\n removeNoContent();\r\n\r\n const _start = getElementScroll(_scrollOffsetElement);\r\n const scrollSize = getScrollSize(_scrollOffsetElement);\r\n scrollElementTo(_scrollOffsetElement, {\r\n x: scrollSize.w,\r\n y: scrollSize.h,\r\n });\r\n\r\n const tmp = getElementScroll(_scrollOffsetElement);\r\n scrollElementTo(_scrollOffsetElement, {\r\n // if tmp is very close start there porbably wasn't any scroll happening so scroll again in different direction\r\n x: tmp.x - _start.x < 1 && -scrollSize.w,\r\n y: tmp.y - _start.y < 1 && -scrollSize.h,\r\n });\r\n\r\n const _end = getElementScroll(_scrollOffsetElement);\r\n scrollElementTo(_scrollOffsetElement, originalScrollOffset);\r\n rAF(() => removeScrollBlock());\r\n\r\n return {\r\n _start,\r\n _end,\r\n };\r\n };\r\n const getOverflowAmount = (\r\n viewportScrollSize: WH,\r\n viewportClientSize: WH\r\n ): WH => {\r\n const tollerance = wnd.devicePixelRatio % 1 !== 0 ? 1 : 0;\r\n const amount = {\r\n w: max0(viewportScrollSize.w - viewportClientSize.w),\r\n h: max0(viewportScrollSize.h - viewportClientSize.h),\r\n };\r\n\r\n return {\r\n w: amount.w > tollerance ? amount.w : 0,\r\n h: amount.h > tollerance ? amount.h : 0,\r\n };\r\n };\r\n const getViewportOverflowStyle = (\r\n hasOverflow: Partial>,\r\n overflowBehavior: XY\r\n ): XY => {\r\n const getAxisOverflowStyle = (\r\n axisBehavior: OverflowBehavior,\r\n axisHasOverflow: boolean | undefined,\r\n perpendicularBehavior: OverflowBehavior,\r\n perpendicularOverflow: boolean | undefined\r\n ): OverflowStyle => {\r\n // convert behavior to style:\r\n // 'visible' -> 'hidden'\r\n // 'hidden' -> 'hidden'\r\n // 'scroll' -> 'scroll'\r\n // 'visible-hidden' -> 'hidden'\r\n // 'visible-scroll' -> 'scroll'\r\n const behaviorStyle =\r\n axisBehavior === strVisible ? strHidden : overflowBehaviorToOverflowStyle(axisBehavior);\r\n const axisOverflowVisible = overflowIsVisible(axisBehavior);\r\n const perpendicularOverflowVisible = overflowIsVisible(perpendicularBehavior);\r\n\r\n // if no axis has overflow set 'hidden'\r\n if (!axisHasOverflow && !perpendicularOverflow) {\r\n return strHidden;\r\n }\r\n\r\n // if both axis have a visible behavior ('visible', 'visible-hidden', 'visible-scroll') set 'visible'\r\n if (axisOverflowVisible && perpendicularOverflowVisible) {\r\n return strVisible;\r\n }\r\n\r\n // this this axis has a visible behavior\r\n if (axisOverflowVisible) {\r\n const nonPerpendicularOverflow = axisHasOverflow ? strVisible : strHidden;\r\n return axisHasOverflow && perpendicularOverflow\r\n ? behaviorStyle // if both axis have an overflow set ('hidden' or 'scroll')\r\n : nonPerpendicularOverflow; // if only this axis has an overflow set 'visible', if no axis has an overflow set 'hidden'\r\n }\r\n\r\n const nonOverflow =\r\n perpendicularOverflowVisible && perpendicularOverflow ? strVisible : strHidden;\r\n return axisHasOverflow\r\n ? behaviorStyle // if this axis has an overflow\r\n : nonOverflow; // if the perp. axis has a visible behavior and has an overflow set 'visible', otherwise set 'hidden'\r\n };\r\n\r\n return {\r\n x: getAxisOverflowStyle(overflowBehavior.x, hasOverflow.x, overflowBehavior.y, hasOverflow.y),\r\n y: getAxisOverflowStyle(overflowBehavior.y, hasOverflow.y, overflowBehavior.x, hasOverflow.x),\r\n };\r\n };\r\n const setViewportOverflowStyle = (viewportOverflowStyle: XY) => {\r\n // `createAllOverflowStyleClassNames` and `allOverflowStyleClassNames` could be one scope further up but would increase bundle size\r\n const createAllOverflowStyleClassNames = (isHorizontal?: boolean) =>\r\n [strVisible, strHidden, strScroll].map((style) =>\r\n createViewportOverflowStyleClassName(overflowCssValueToOverflowStyle(style), isHorizontal)\r\n );\r\n const allOverflowStyleClassNames = createAllOverflowStyleClassNames(true)\r\n .concat(createAllOverflowStyleClassNames())\r\n .join(' ');\r\n\r\n _viewportAddRemoveClass(allOverflowStyleClassNames);\r\n _viewportAddRemoveClass(\r\n (keys(viewportOverflowStyle) as Array)\r\n .map((axis) =>\r\n createViewportOverflowStyleClassName(viewportOverflowStyle[axis], axis === 'x')\r\n )\r\n .join(' '),\r\n true\r\n );\r\n };\r\n\r\n const [updateSizeFraction, getCurrentSizeFraction] = createCache>(\r\n whCacheOptions,\r\n bind(getFractionalSize, _viewport)\r\n );\r\n const [updateViewportScrollSizeCache, getCurrentViewportScrollSizeCache] = createCache<\r\n WH\r\n >(whCacheOptions, bind(getScrollSize, _viewport));\r\n const [updateOverflowAmountCache, getCurrentOverflowAmountCache] =\r\n createCache>(whCacheOptions);\r\n const [updateHasOverflowCache] = createCache>>(partialXYOptions);\r\n const [updateOverflowEdge, getCurrentOverflowEdgeCache] = createCache>(whCacheOptions);\r\n const [updateOverflowStyleCache] = createCache>>(partialXYOptions);\r\n const [updateFlowDirectionStyles] = createCache(\r\n {\r\n _equal: (currVal, newValu) => equal(currVal, newValu, flowDirectionStyleArr),\r\n _initialValue: {},\r\n },\r\n () => (hasDimensions(_viewport) ? getStyles(_viewport, flowDirectionStyleArr) : {})\r\n );\r\n const [updateMeasuredScrollCoordinates, getCurrentMeasuredScrollCoordinates] =\r\n createCache({\r\n _equal: (currVal, newVal) =>\r\n equalXY(currVal._start, newVal._start) && equalXY(currVal._end, newVal._end),\r\n _initialValue: getZeroScrollCoordinates(),\r\n });\r\n\r\n const scrollbarsHidingPlugin = getStaticPluginModuleInstance(\r\n scrollbarsHidingPluginName\r\n );\r\n\r\n const createViewportOverflowStyleClassName = (\r\n overflowStyle: OverflowStyle,\r\n isHorizontal?: boolean\r\n ) => {\r\n const prefix = isHorizontal\r\n ? dataValueViewportOverflowXPrefix\r\n : dataValueViewportOverflowYPrefix;\r\n return `${prefix}${capitalizeFirstLetter(overflowStyle)}`;\r\n };\r\n\r\n return (\r\n { _checkOption, _observersUpdateHints, _observersState, _force },\r\n { _paddingStyleChanged }\r\n ) => {\r\n const {\r\n _sizeChanged,\r\n _hostMutation,\r\n _contentMutation,\r\n _directionChanged,\r\n _appear,\r\n _scrollbarSizeChanged,\r\n } = _observersUpdateHints || {};\r\n const scrollbarsHidingPluginViewportArrangement =\r\n scrollbarsHidingPlugin &&\r\n scrollbarsHidingPlugin._viewportArrangement(\r\n structureSetupElements,\r\n structureSetupState,\r\n _observersState,\r\n env,\r\n _checkOption\r\n );\r\n\r\n const { _arrangeViewport, _undoViewportArrange, _hideNativeScrollbars } =\r\n scrollbarsHidingPluginViewportArrangement || {};\r\n\r\n const [showNativeOverlaidScrollbars, showNativeOverlaidScrollbarsChanged] =\r\n getShowNativeOverlaidScrollbars(_checkOption, env);\r\n const [overflow, overflowChanged] = _checkOption('overflow');\r\n const overflowXVisible = overflowIsVisible(overflow.x);\r\n const overflowYVisible = overflowIsVisible(overflow.y);\r\n\r\n const viewportChanged =\r\n _sizeChanged ||\r\n _paddingStyleChanged ||\r\n _contentMutation ||\r\n _directionChanged ||\r\n _scrollbarSizeChanged ||\r\n showNativeOverlaidScrollbarsChanged;\r\n\r\n let sizeFractionCache = getCurrentSizeFraction(_force);\r\n let viewportScrollSizeCache = getCurrentViewportScrollSizeCache(_force);\r\n let overflowAmuntCache = getCurrentOverflowAmountCache(_force);\r\n let overflowEdgeCache = getCurrentOverflowEdgeCache(_force);\r\n\r\n if (showNativeOverlaidScrollbarsChanged && _nativeScrollbarsHiding) {\r\n _viewportAddRemoveClass(dataValueViewportScrollbarHidden, !showNativeOverlaidScrollbars);\r\n }\r\n\r\n if (viewportChanged) {\r\n if (hasAttrClass(_host, dataAttributeHost, dataValueNoClipping)) {\r\n setMeasuringMode(true);\r\n }\r\n\r\n const redoViewportArrange = _undoViewportArrange && _undoViewportArrange();\r\n\r\n const [sizeFraction] = (sizeFractionCache = updateSizeFraction(_force));\r\n const [viewportScrollSize] = (viewportScrollSizeCache =\r\n updateViewportScrollSizeCache(_force));\r\n const viewportClientSize = getClientSize(_viewport);\r\n const windowInnerSize = viewportIsTargetBody && getWindowSize(_windowElm());\r\n const overflowAmountScrollSize = {\r\n w: max0(viewportScrollSize.w + sizeFraction.w),\r\n h: max0(viewportScrollSize.h + sizeFraction.h),\r\n };\r\n\r\n const overflowAmountClientSize = {\r\n w: max0(\r\n (windowInnerSize\r\n ? windowInnerSize.w\r\n : viewportClientSize.w + max0(viewportClientSize.w - viewportScrollSize.w)) +\r\n sizeFraction.w\r\n ),\r\n h: max0(\r\n (windowInnerSize\r\n ? windowInnerSize.h\r\n : viewportClientSize.h + max0(viewportClientSize.h - viewportScrollSize.h)) +\r\n sizeFraction.h\r\n ),\r\n };\r\n\r\n if (redoViewportArrange) {\r\n redoViewportArrange();\r\n }\r\n\r\n overflowEdgeCache = updateOverflowEdge(overflowAmountClientSize);\r\n overflowAmuntCache = updateOverflowAmountCache(\r\n getOverflowAmount(overflowAmountScrollSize, overflowAmountClientSize),\r\n _force\r\n );\r\n }\r\n\r\n const [overflowEdge, overflowEdgeChanged] = overflowEdgeCache;\r\n const [overflowAmount, overflowAmountChanged] = overflowAmuntCache;\r\n const [viewportScrollSize, viewportScrollSizeChanged] = viewportScrollSizeCache;\r\n const [sizeFraction, sizeFractionChanged] = sizeFractionCache;\r\n const [hasOverflow, hasOverflowChanged] = updateHasOverflowCache({\r\n x: overflowAmount.w > 0,\r\n y: overflowAmount.h > 0,\r\n });\r\n const removeClipping =\r\n (overflowXVisible && overflowYVisible && (hasOverflow.x || hasOverflow.y)) ||\r\n (overflowXVisible && hasOverflow.x && !hasOverflow.y) ||\r\n (overflowYVisible && hasOverflow.y && !hasOverflow.x);\r\n const adjustViewportStyle =\r\n _paddingStyleChanged ||\r\n _directionChanged ||\r\n _scrollbarSizeChanged ||\r\n sizeFractionChanged ||\r\n viewportScrollSizeChanged ||\r\n overflowEdgeChanged ||\r\n overflowAmountChanged ||\r\n overflowChanged ||\r\n showNativeOverlaidScrollbarsChanged ||\r\n viewportChanged ||\r\n (_hostMutation && viewportIsTargetBody);\r\n const [flowDirectionStyles, flowDirectionStylesChanged] = updateFlowDirectionStyles(_force);\r\n const adjustMeasuredScrollCoordinates =\r\n _directionChanged || _appear || flowDirectionStylesChanged || hasOverflowChanged || _force;\r\n const [scrollCoordinates, scrollCoordinatesChanged] = adjustMeasuredScrollCoordinates\r\n ? updateMeasuredScrollCoordinates(getMeasuredScrollCoordinates(flowDirectionStyles), _force)\r\n : getCurrentMeasuredScrollCoordinates();\r\n\r\n let viewportOverflowStyle = getViewportOverflowStyle(hasOverflow, overflow);\r\n\r\n setMeasuringMode(false);\r\n\r\n if (adjustViewportStyle) {\r\n setViewportOverflowStyle(viewportOverflowStyle);\r\n\r\n viewportOverflowStyle = getElementOverflowStyle(_viewport, hasOverflow);\r\n\r\n if (_hideNativeScrollbars && _arrangeViewport) {\r\n _arrangeViewport(viewportOverflowStyle, viewportScrollSize, sizeFraction);\r\n\r\n setStyles(_viewport, _hideNativeScrollbars(viewportOverflowStyle));\r\n }\r\n }\r\n\r\n const [overflowStyle, overflowStyleChanged] = updateOverflowStyleCache(viewportOverflowStyle);\r\n\r\n addRemoveAttrClass(_host, dataAttributeHost, dataValueNoClipping, removeClipping);\r\n addRemoveAttrClass(_padding, dataAttributePadding, dataValueNoClipping, removeClipping);\r\n\r\n assignDeep(structureSetupState, {\r\n _overflowStyle: overflowStyle,\r\n _overflowEdge: {\r\n x: overflowEdge.w,\r\n y: overflowEdge.h,\r\n },\r\n _overflowAmount: {\r\n x: overflowAmount.w,\r\n y: overflowAmount.h,\r\n },\r\n _hasOverflow: hasOverflow,\r\n _scrollCoordinates: sanitizeScrollCoordinates(scrollCoordinates, overflowAmount),\r\n });\r\n\r\n return {\r\n _overflowStyleChanged: overflowStyleChanged,\r\n _overflowEdgeChanged: overflowEdgeChanged,\r\n _overflowAmountChanged: overflowAmountChanged,\r\n _scrollCoordinatesChanged: scrollCoordinatesChanged || overflowAmountChanged,\r\n };\r\n };\r\n};\r\n","import type { TRBL, XY, ScrollCoordinates } from '../../support';\r\nimport type { StructureSetupElementsObj } from './structureSetup.elements';\r\nimport type {\r\n ObserversSetupState,\r\n ObserversSetupUpdateHints,\r\n Setup,\r\n SetupUpdateInfo,\r\n} from '../../setups';\r\nimport type { InitializationTarget } from '../../initialization';\r\nimport type { StyleObject, OverflowStyle } from '../../typings';\r\nimport {\r\n assignDeep,\r\n each,\r\n getElementScroll,\r\n getZeroScrollCoordinates,\r\n scrollElementTo,\r\n strHidden,\r\n strMarginBottom,\r\n strMarginLeft,\r\n strMarginRight,\r\n strPaddingBottom,\r\n strPaddingLeft,\r\n strPaddingRight,\r\n strPaddingTop,\r\n} from '../../support';\r\nimport { getEnvironment } from '../../environment';\r\nimport { createStructureSetupElements } from './structureSetup.elements';\r\nimport {\r\n createOverflowUpdateSegment,\r\n createPaddingUpdateSegment,\r\n createTrinsicUpdateSegment,\r\n} from './updateSegments';\r\n\r\nexport interface StructureSetupState {\r\n _padding: TRBL;\r\n _paddingAbsolute: boolean;\r\n _viewportPaddingStyle: StyleObject;\r\n _overflowEdge: XY;\r\n _overflowAmount: XY;\r\n _overflowStyle: XY;\r\n _hasOverflow: XY;\r\n _scrollCoordinates: ScrollCoordinates;\r\n}\r\n\r\nexport interface StructureSetupUpdateInfo extends SetupUpdateInfo {\r\n _observersState: ObserversSetupState;\r\n _observersUpdateHints?: ObserversSetupUpdateHints;\r\n}\r\n\r\nexport type StructureSetupUpdateHints = {\r\n _overflowEdgeChanged?: boolean;\r\n _overflowAmountChanged?: boolean;\r\n _overflowStyleChanged?: boolean;\r\n _paddingStyleChanged?: boolean;\r\n _scrollCoordinatesChanged?: boolean;\r\n};\r\n\r\nexport type StructureSetup = [\r\n ...Setup,\r\n /** The elements created by the structure setup. */\r\n StructureSetupElementsObj,\r\n /** Function to be called when the initialization was canceled. */\r\n () => void,\r\n];\r\n\r\nexport type StructureUpdateSegment = (\r\n updateInfo: StructureSetupUpdateInfo,\r\n updateHints: Readonly\r\n) => StructureSetupUpdateHints | void;\r\n\r\nexport type CreateStructureUpdateSegment = (\r\n structureSetupElements: StructureSetupElementsObj,\r\n state: StructureSetupState\r\n) => StructureUpdateSegment;\r\n\r\nexport const createStructureSetup = (target: InitializationTarget): StructureSetup => {\r\n const [elements, appendStructureElements, canceled] = createStructureSetupElements(target);\r\n const state: StructureSetupState = {\r\n _padding: {\r\n t: 0,\r\n r: 0,\r\n b: 0,\r\n l: 0,\r\n },\r\n _paddingAbsolute: false,\r\n _viewportPaddingStyle: {\r\n [strMarginRight]: 0,\r\n [strMarginBottom]: 0,\r\n [strMarginLeft]: 0,\r\n [strPaddingTop]: 0,\r\n [strPaddingRight]: 0,\r\n [strPaddingBottom]: 0,\r\n [strPaddingLeft]: 0,\r\n },\r\n _overflowEdge: { x: 0, y: 0 },\r\n _overflowAmount: { x: 0, y: 0 },\r\n _overflowStyle: {\r\n x: strHidden,\r\n y: strHidden,\r\n },\r\n _hasOverflow: {\r\n x: false,\r\n y: false,\r\n },\r\n _scrollCoordinates: getZeroScrollCoordinates(),\r\n };\r\n const { _target, _scrollOffsetElement, _viewportIsTarget, _removeScrollObscuringStyles } =\r\n elements;\r\n const { _nativeScrollbarsHiding, _nativeScrollbarsOverlaid } = getEnvironment();\r\n const doViewportArrange =\r\n !_nativeScrollbarsHiding && (_nativeScrollbarsOverlaid.x || _nativeScrollbarsOverlaid.y);\r\n\r\n const updateSegments: StructureUpdateSegment[] = [\r\n createTrinsicUpdateSegment(elements, state),\r\n createPaddingUpdateSegment(elements, state),\r\n createOverflowUpdateSegment(elements, state),\r\n ];\r\n\r\n return [\r\n appendStructureElements,\r\n (updateInfo) => {\r\n const updateHints: StructureSetupUpdateHints = {};\r\n const adjustScrollOffset = doViewportArrange;\r\n const scrollOffset = adjustScrollOffset && getElementScroll(_scrollOffsetElement);\r\n const revertScrollObscuringStyles = scrollOffset && _removeScrollObscuringStyles();\r\n\r\n each(updateSegments, (updateSegment) => {\r\n assignDeep(updateHints, updateSegment(updateInfo, updateHints) || {});\r\n });\r\n\r\n scrollElementTo(_scrollOffsetElement, scrollOffset);\r\n if (revertScrollObscuringStyles) {\r\n revertScrollObscuringStyles();\r\n }\r\n if (!_viewportIsTarget) {\r\n scrollElementTo(_target, 0);\r\n }\r\n\r\n return updateHints;\r\n },\r\n state,\r\n elements,\r\n canceled,\r\n ];\r\n};\r\n","import type { OptionsCheckFn, Options, PartialOptions, ReadonlyOptions } from '../options';\r\nimport type { DeepReadonly } from '../typings';\r\nimport type { InitializationTarget } from '../initialization';\r\nimport type { ObserversSetupState, ObserversSetupUpdateHints } from './observersSetup';\r\nimport type { StructureSetupState, StructureSetupUpdateHints } from './structureSetup';\r\nimport type { StructureSetupElementsObj } from './structureSetup/structureSetup.elements';\r\nimport type { ScrollbarsSetupElementsObj } from './scrollbarsSetup/scrollbarsSetup.elements';\r\nimport { createOptionCheck } from '../options';\r\nimport {\r\n assignDeep,\r\n bind,\r\n getElementScroll,\r\n isEmptyObject,\r\n keys,\r\n runEachAndClear,\r\n scrollElementTo,\r\n} from '../support';\r\nimport { createObserversSetup } from './observersSetup';\r\nimport { createScrollbarsSetup } from './scrollbarsSetup';\r\nimport { createStructureSetup } from './structureSetup';\r\n\r\nexport type SetupUpdateHints = Partial>;\r\n\r\nexport type SetupUpdateInfo = {\r\n _checkOption: OptionsCheckFn;\r\n _changedOptions: PartialOptions;\r\n _force: boolean;\r\n};\r\n\r\nexport type Setup<\r\n U extends SetupUpdateInfo,\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n S extends Readonly>,\r\n H extends SetupUpdateHints | void,\r\n> = [\r\n /** The create function which returns the `destroy` function. */\r\n _create: () => () => void,\r\n /** Function which updates the setup and returns the update result. */\r\n _update: (updateInfo: U) => H,\r\n /** Function which returns the current state. */\r\n _state: S,\r\n];\r\n\r\nexport interface SetupsUpdateInfo {\r\n /** The options that changed or `undefined` if none changed. */\r\n _changedOptions?: PartialOptions;\r\n /** Whether chache should be ignored. */\r\n _force?: boolean;\r\n /** Whether observers should take their records and thus update as well. */\r\n _takeRecords?: boolean;\r\n /** Whether one or more scrollbars has been cloned. */\r\n _cloneScrollbar?: boolean;\r\n}\r\n\r\nexport interface SetupsUpdateHints {\r\n readonly _observersUpdateHints: DeepReadonly;\r\n readonly _structureUpdateHints: DeepReadonly;\r\n}\r\n\r\nexport interface SetupsState {\r\n readonly _observersSetupState: DeepReadonly;\r\n readonly _structureSetupState: DeepReadonly;\r\n}\r\n\r\nexport interface SetupsElements {\r\n readonly _structureSetupElements: DeepReadonly;\r\n readonly _scrollbarsSetupElements: DeepReadonly;\r\n}\r\n\r\nexport type Setups = [\r\n construct: () => () => void,\r\n update: (updateInfo: SetupsUpdateInfo) => boolean,\r\n getState: () => SetupsState,\r\n elements: SetupsElements,\r\n canceled: () => void,\r\n];\r\n\r\nexport const createSetups = (\r\n target: InitializationTarget,\r\n options: ReadonlyOptions,\r\n isDestroyed: () => boolean,\r\n onUpdated: (updateInfo: SetupsUpdateInfo, updateHints: SetupsUpdateHints) => void,\r\n onScroll: (scrollEvent: Event) => void\r\n): Setups => {\r\n let cacheAndOptionsInitialized = false;\r\n const getCurrentOption = createOptionCheck(options, {});\r\n const [\r\n structureSetupCreate,\r\n structureSetupUpdate,\r\n structureSetupState,\r\n structureSetupElements,\r\n structureSetupCanceled,\r\n ] = createStructureSetup(target);\r\n const [observersSetupCreate, observersSetupUpdate, observersSetupState] = createObserversSetup(\r\n structureSetupElements,\r\n structureSetupState,\r\n getCurrentOption,\r\n (observersUpdateHints) => {\r\n update({}, observersUpdateHints);\r\n }\r\n );\r\n const [scrollbarsSetupCreate, scrollbarsSetupUpdate, , scrollbarsSetupElements] =\r\n createScrollbarsSetup(\r\n target,\r\n options,\r\n observersSetupState,\r\n structureSetupState,\r\n structureSetupElements,\r\n onScroll\r\n );\r\n\r\n const updateHintsAreTruthy = (hints: SetupUpdateHints) =>\r\n keys(hints).some((key) => !!hints[key as keyof typeof hints]);\r\n\r\n const update = (\r\n updateInfo: SetupsUpdateInfo,\r\n observerUpdateHints?: ObserversSetupUpdateHints\r\n ): boolean => {\r\n if (isDestroyed()) {\r\n return false;\r\n }\r\n\r\n const {\r\n _changedOptions: rawChangedOptions,\r\n _force: rawForce,\r\n _takeRecords,\r\n _cloneScrollbar,\r\n } = updateInfo;\r\n\r\n const _changedOptions = rawChangedOptions || {};\r\n const _force = !!rawForce || !cacheAndOptionsInitialized;\r\n const baseUpdateInfoObj: SetupUpdateInfo = {\r\n _checkOption: createOptionCheck(options, _changedOptions, _force),\r\n _changedOptions,\r\n _force,\r\n };\r\n\r\n if (_cloneScrollbar) {\r\n scrollbarsSetupUpdate(baseUpdateInfoObj);\r\n return false;\r\n }\r\n\r\n const observersHints =\r\n observerUpdateHints ||\r\n observersSetupUpdate(\r\n assignDeep({}, baseUpdateInfoObj, {\r\n _takeRecords,\r\n })\r\n );\r\n\r\n const structureHints = structureSetupUpdate(\r\n assignDeep({}, baseUpdateInfoObj, {\r\n _observersState: observersSetupState,\r\n _observersUpdateHints: observersHints,\r\n })\r\n );\r\n\r\n scrollbarsSetupUpdate(\r\n assignDeep({}, baseUpdateInfoObj, {\r\n _observersUpdateHints: observersHints,\r\n _structureUpdateHints: structureHints,\r\n })\r\n );\r\n\r\n const truthyObserversHints = updateHintsAreTruthy(observersHints);\r\n const truthyStructureHints = updateHintsAreTruthy(structureHints);\r\n const changed =\r\n truthyObserversHints || truthyStructureHints || !isEmptyObject(_changedOptions) || _force;\r\n\r\n cacheAndOptionsInitialized = true;\r\n\r\n if (changed) {\r\n onUpdated(updateInfo, {\r\n _observersUpdateHints: observersHints,\r\n _structureUpdateHints: structureHints,\r\n });\r\n }\r\n\r\n return changed;\r\n };\r\n\r\n return [\r\n () => {\r\n const { _originalScrollOffsetElement, _scrollOffsetElement, _removeScrollObscuringStyles } =\r\n structureSetupElements;\r\n const initialScroll = getElementScroll(_originalScrollOffsetElement);\r\n const destroyFns = [observersSetupCreate(), structureSetupCreate(), scrollbarsSetupCreate()];\r\n const revertScrollObscuringStyles = _removeScrollObscuringStyles();\r\n\r\n scrollElementTo(_scrollOffsetElement, initialScroll);\r\n revertScrollObscuringStyles();\r\n\r\n return bind(runEachAndClear, destroyFns);\r\n },\r\n update,\r\n () => ({\r\n _observersSetupState: observersSetupState,\r\n _structureSetupState: structureSetupState,\r\n }),\r\n {\r\n _structureSetupElements: structureSetupElements,\r\n _scrollbarsSetupElements: scrollbarsSetupElements,\r\n },\r\n structureSetupCanceled,\r\n ];\r\n};\r\n","import type { OverlayScrollbars } from './overlayscrollbars';\r\n\r\nconst targetInstanceMap: WeakMap = new WeakMap();\r\n\r\n/**\r\n * Adds the given OverlayScrollbars instance to the given element.\r\n * @param target The element which is the target of the OverlayScrollbars instance.\r\n * @param osInstance The OverlayScrollbars instance.\r\n */\r\nexport const addInstance = (target: Element, osInstance: OverlayScrollbars): void => {\r\n targetInstanceMap.set(target, osInstance);\r\n};\r\n\r\n/**\r\n * Removes a OverlayScrollbars instance from the given element.\r\n * @param target The element from which its OverlayScrollbars instance shall be removed.\r\n */\r\nexport const removeInstance = (target: Element): void => {\r\n targetInstanceMap.delete(target);\r\n};\r\n\r\n/**\r\n * Gets the OverlayScrollbars from the given element or undefined if it doesn't have one.\r\n * @param target The element of which its OverlayScrollbars instance shall be get.\r\n */\r\nexport const getInstance = (target: Element): OverlayScrollbars | undefined =>\r\n targetInstanceMap.get(target);\r\n","/* eslint-disable @typescript-eslint/no-explicit-any */\r\nimport type { XY, TRBL } from './support';\r\nimport type { Options, PartialOptions, ReadonlyOptions } from './options';\r\nimport type {\r\n InferInstancePluginModuleInstance,\r\n InferStaticPluginModuleInstance,\r\n InstancePlugin,\r\n OptionsValidationPlugin,\r\n Plugin,\r\n PluginModuleInstance,\r\n StaticPlugin,\r\n} from './plugins';\r\nimport type { Initialization, InitializationTarget, PartialInitialization } from './initialization';\r\nimport type { OverflowStyle } from './typings';\r\nimport type { EventListenerArgs, EventListener, EventListeners } from './eventListeners';\r\nimport type {\r\n ScrollbarsSetupElement,\r\n ScrollbarStructure,\r\n} from './setups/scrollbarsSetup/scrollbarsSetup.elements';\r\nimport {\r\n addPlugins,\r\n getStaticPluginModuleInstance,\r\n optionsValidationPluginModuleName,\r\n pluginModules,\r\n registerPluginModuleInstances,\r\n} from './plugins';\r\nimport { createSetups } from './setups';\r\nimport { addInstance, getInstance, removeInstance } from './instances';\r\nimport { cancelInitialization } from './initialization';\r\nimport { getEnvironment } from './environment';\r\nimport { getOptionsDiff } from './options';\r\nimport {\r\n assignDeep,\r\n isEmptyObject,\r\n isFunction,\r\n isHTMLElement,\r\n createEventListenerHub,\r\n isPlainObject,\r\n keys,\r\n isArray,\r\n push,\r\n runEachAndClear,\r\n bind,\r\n removeUndefinedProperties,\r\n} from './support';\r\nimport { setNonce } from './nonce';\r\nimport { setTrustedTypePolicy } from './trustedTypePolicy';\r\n\r\n// Notes:\r\n// Height intrinsic detection use \"content: true\" init strategy - or open ticket for custom height intrinsic observer\r\n\r\n/**\r\n * Describes the OverlayScrollbars environment.\r\n */\r\nexport interface Environment {\r\n /** The native scrollbars size of the browser / system. */\r\n scrollbarsSize: XY;\r\n /** Whether the native scrollbars are overlaid. */\r\n scrollbarsOverlaid: XY;\r\n /** Whether the browser supports native scrollbars hiding. */\r\n scrollbarsHiding: boolean;\r\n /** Whether the browser supports the ScrollTimeline API. */\r\n scrollTimeline: boolean;\r\n /** The default Initialization to use if nothing else is specified. */\r\n staticDefaultInitialization: Initialization;\r\n /** The default Options to use if nothing else is specified. */\r\n staticDefaultOptions: Options;\r\n\r\n /** Returns the current default Initialization. */\r\n getDefaultInitialization(): Initialization;\r\n /** Returns the current default Options. */\r\n getDefaultOptions(): Options;\r\n\r\n /**\r\n * Sets a new default Initialization.\r\n * If the new default Initialization is partially filled, its deeply merged with the current default Initialization.\r\n * @param newDefaultInitialization The new default Initialization.\r\n * @returns The current default Initialization.\r\n */\r\n setDefaultInitialization(newDefaultInitialization: PartialInitialization): Initialization;\r\n /**\r\n * Sets new default Options.\r\n * If the new default Options are partially filled, they're deeply merged with the current default Options.\r\n * @param newDefaultOptions The new default Options.\r\n * @returns The current default options.\r\n */\r\n setDefaultOptions(newDefaultOptions: PartialOptions): Options;\r\n}\r\n\r\n/**\r\n * The primary entry point to OverlayScrollbars.\r\n */\r\nexport interface OverlayScrollbarsStatic {\r\n /**\r\n * Returns the current OverlayScrollbars instance if the target already has an instance.\r\n * @param target The initialization target to from which the instance shall be returned.\r\n */\r\n (target: InitializationTarget): OverlayScrollbars | undefined;\r\n /**\r\n * Initializes a new OverlayScrollbars instance to the given target\r\n * or returns the current OverlayScrollbars instance if the target already has an instance.\r\n * @param target The target.\r\n * @param options The options. (Can be just an empty object)\r\n * @param eventListeners Optional event listeners.\r\n */\r\n (\r\n target: InitializationTarget,\r\n options: PartialOptions,\r\n eventListeners?: EventListeners\r\n ): OverlayScrollbars;\r\n\r\n /**\r\n * Checks whether the passed value is a valid and not destroyed overlayscrollbars instance.\r\n * @param osInstance The value which shall be checked.\r\n */\r\n valid(osInstance: any): osInstance is OverlayScrollbars;\r\n /**\r\n * Gets the environment.\r\n */\r\n env(): Environment;\r\n /**\r\n * Sets the nonce attribute for inline styles.\r\n */\r\n nonce(newNonce: string | undefined): void;\r\n /**\r\n * Sets the trusted type policy used for DOM operations.\r\n */\r\n trustedTypePolicy(newTrustedTypePolicy: unknown | undefined): void;\r\n /**\r\n * Adds a single plugin.\r\n * @param plugin The plugin to be added.\r\n * @returns The plugins static modules instance or `void` if no instance was found.\r\n */\r\n plugin

(\r\n plugin: P\r\n ): P extends StaticPlugin ? InferStaticPluginModuleInstance

: void;\r\n /**\r\n * Adds multiple plugins.\r\n * @param plugins The plugins to be added.\r\n * @returns The plugins static modules instances or `void` if no instance was found.\r\n */\r\n plugin

(\r\n plugins: P\r\n ): P extends [Plugin, ...Plugin[]]\r\n ? {\r\n [K in keyof P]: P[K] extends StaticPlugin ? InferStaticPluginModuleInstance : void;\r\n }\r\n : void;\r\n}\r\n\r\n/**\r\n * Describes a OverlayScrollbars instances state.\r\n */\r\nexport interface State {\r\n /** Describes the current padding in pixel. */\r\n padding: TRBL;\r\n /** Whether the current padding is absolute. */\r\n paddingAbsolute: boolean;\r\n /** The client width (x) & height (y) of the viewport in pixel. */\r\n overflowEdge: XY;\r\n /** The overflow amount in pixel. */\r\n overflowAmount: XY;\r\n /** The css overflow style of the viewport. */\r\n overflowStyle: XY;\r\n /** Whether the viewport has an overflow. */\r\n hasOverflow: XY;\r\n /** The scroll coordinates of the viewport. */\r\n scrollCoordinates: {\r\n /** The start (origin) scroll coordinates for each axis. */\r\n start: XY;\r\n /** The end scroll coordinates for each axis. */\r\n end: XY;\r\n };\r\n /** Whether the direction is considered rtl. */\r\n directionRTL: boolean;\r\n /** Whether the instance is considered destroyed. */\r\n destroyed: boolean;\r\n}\r\n\r\n/**\r\n * Describes the elements of a scrollbar.\r\n */\r\nexport interface ScrollbarElements {\r\n /**\r\n * The root element of the scrollbar.\r\n * The HTML structure looks like this:\r\n * \r\n * \r\n * \r\n * \r\n * \r\n */\r\n scrollbar: HTMLElement;\r\n /** The track element of the scrollbar. */\r\n track: HTMLElement;\r\n /** The handle element of the scrollbar. */\r\n handle: HTMLElement;\r\n}\r\n\r\n/**\r\n * Describes the elements of a scrollbar and provides the possibility to clone them.\r\n */\r\nexport interface CloneableScrollbarElements extends ScrollbarElements {\r\n /**\r\n * Clones the current scrollbar and returns the cloned elements.\r\n * The returned elements aren't added to the DOM.\r\n */\r\n clone(): ScrollbarElements;\r\n}\r\n\r\n/**\r\n * Describes the elements of a OverlayScrollbars instance.\r\n */\r\nexport interface Elements {\r\n /** The element the instance was applied to. */\r\n target: HTMLElement;\r\n /** The host element. Its the root of all other elements. */\r\n host: HTMLElement;\r\n /**\r\n * The element which is responsible to apply correct paddings.\r\n * Depending on the Initialization it can be the same as the viewport element.\r\n */\r\n padding: HTMLElement;\r\n /** The element which is responsible to do any scrolling. */\r\n viewport: HTMLElement;\r\n /**\r\n * The element which is responsible to hold the content.\r\n * Depending on the Initialization it can be the same as the viewport element.\r\n */\r\n content: HTMLElement;\r\n /**\r\n * The element through which you can get the current `scrollLeft` or `scrollTop` offset.\r\n * Depending on the target element it can be the same as the viewport element.\r\n */\r\n scrollOffsetElement: HTMLElement;\r\n /**\r\n * The element through which you can add `scroll` events.\r\n * Depending on the target element it can be the same as the viewport element.\r\n */\r\n scrollEventElement: HTMLElement | Document;\r\n /** The horizontal scrollbar elements. */\r\n scrollbarHorizontal: CloneableScrollbarElements;\r\n /** The vertical scrollbar elements. */\r\n scrollbarVertical: CloneableScrollbarElements;\r\n}\r\n\r\n/**\r\n * Describes a OverlayScrollbars instance.\r\n */\r\nexport interface OverlayScrollbars {\r\n /** Gets the current options of the instance. */\r\n options(): Options;\r\n /**\r\n * Sets the options of the instance.\r\n * If the new options are partially filled, they're deeply merged with either the current options or the current default options.\r\n * @param newOptions The new options which should be applied.\r\n * @param pure Whether the options should be reset before the new options are added.\r\n * @returns Returns the current options of the instance.\r\n */\r\n options(newOptions: PartialOptions, pure?: boolean): Options;\r\n\r\n /**\r\n * Adds event listeners to the instance.\r\n * @param eventListeners An object which contains the added listeners.\r\n * @param pure Whether all already added event listeners should be removed before the new listeners are added.\r\n * @returns Returns a function which removes the added listeners.\r\n */\r\n on(eventListeners: EventListeners, pure?: boolean): () => void;\r\n /**\r\n * Adds a single event listener to the instance.\r\n * @param name The name of the event.\r\n * @param listener The listener which is invoked on that event.\r\n * @returns Returns a function which removes the added listeners.\r\n */\r\n on(name: N, listener: EventListener): () => void;\r\n /**\r\n * Adds multiple event listeners to the instance.\r\n * @param name The name of the event.\r\n * @param listener The listeners which are invoked on that event.\r\n * @returns Returns a function which removes the added listeners.\r\n */\r\n on(name: N, listener: EventListener[]): () => void;\r\n\r\n /**\r\n * Removes a single event listener from the instance.\r\n * @param name The name of the event.\r\n * @param listener The listener which shall be removed.\r\n */\r\n off(name: N, listener: EventListener): void;\r\n /**\r\n * Removes multiple event listeners from the instance.\r\n * @param name The name of the event.\r\n * @param listener The listeners which shall be removed.\r\n */\r\n off(name: N, listener: EventListener[]): void;\r\n\r\n /**\r\n * Updates the instance.\r\n * @param force Whether the update should force the cache to be invalidated.\r\n * @returns A boolean which indicates whether the `update` event was triggered through this update.\r\n * The update event is only triggered if something changed because of this update.\r\n */\r\n update(force?: boolean): boolean;\r\n /** Returns the state of the instance. */\r\n state(): State;\r\n /** Returns the elements of the instance. */\r\n elements(): Elements;\r\n /** Destroys the instance and removes all added elements. */\r\n destroy(): void;\r\n /** Returns the instance of the passed plugin or `undefined` if no instance was found. */\r\n plugin

(osPlugin: P): InferInstancePluginModuleInstance

| undefined;\r\n}\r\n\r\nexport const OverlayScrollbars: OverlayScrollbarsStatic = (\r\n target: InitializationTarget,\r\n options?: PartialOptions,\r\n eventListeners?: EventListeners\r\n) => {\r\n const { _getDefaultOptions } = getEnvironment();\r\n const targetIsElement = isHTMLElement(target);\r\n const instanceTarget = targetIsElement ? target : target.target;\r\n const potentialInstance = getInstance(instanceTarget);\r\n if (options && !potentialInstance) {\r\n let destroyed = false;\r\n const destroyFns: (() => void)[] = [];\r\n const instancePluginModuleInstances: Record = {};\r\n const validateOptions = (newOptions: PartialOptions) => {\r\n const newOptionsWithoutUndefined = removeUndefinedProperties(newOptions, true);\r\n const pluginValidate = getStaticPluginModuleInstance(\r\n optionsValidationPluginModuleName\r\n );\r\n return pluginValidate\r\n ? pluginValidate(newOptionsWithoutUndefined, true)\r\n : newOptionsWithoutUndefined;\r\n };\r\n const currentOptions: ReadonlyOptions = assignDeep(\r\n {},\r\n _getDefaultOptions(),\r\n validateOptions(options)\r\n );\r\n const [addPluginEvent, removePluginEvents, triggerPluginEvent] =\r\n createEventListenerHub();\r\n const [addInstanceEvent, removeInstanceEvents, triggerInstanceEvent] =\r\n createEventListenerHub(eventListeners);\r\n const triggerEvent: typeof triggerPluginEvent = (name, args) => {\r\n triggerInstanceEvent(name, args);\r\n triggerPluginEvent(name, args);\r\n };\r\n const [setupsConstruct, setupsUpdate, setupsState, setupsElements, setupsCanceled] =\r\n createSetups(\r\n target,\r\n currentOptions,\r\n () => destroyed,\r\n ({ _changedOptions, _force }, { _observersUpdateHints, _structureUpdateHints }) => {\r\n const {\r\n _sizeChanged,\r\n _directionChanged,\r\n _heightIntrinsicChanged,\r\n _contentMutation,\r\n _hostMutation,\r\n _appear,\r\n } = _observersUpdateHints;\r\n\r\n const {\r\n _overflowEdgeChanged,\r\n _overflowAmountChanged,\r\n _overflowStyleChanged,\r\n _scrollCoordinatesChanged,\r\n } = _structureUpdateHints;\r\n\r\n triggerEvent('updated', [\r\n instance,\r\n {\r\n updateHints: {\r\n sizeChanged: !!_sizeChanged,\r\n directionChanged: !!_directionChanged,\r\n heightIntrinsicChanged: !!_heightIntrinsicChanged,\r\n overflowEdgeChanged: !!_overflowEdgeChanged,\r\n overflowAmountChanged: !!_overflowAmountChanged,\r\n overflowStyleChanged: !!_overflowStyleChanged,\r\n scrollCoordinatesChanged: !!_scrollCoordinatesChanged,\r\n contentMutation: !!_contentMutation,\r\n hostMutation: !!_hostMutation,\r\n appear: !!_appear,\r\n },\r\n changedOptions: _changedOptions || {},\r\n force: !!_force,\r\n },\r\n ]);\r\n },\r\n\r\n (scrollEvent) => triggerEvent('scroll', [instance, scrollEvent])\r\n );\r\n\r\n const destroy = (canceled: boolean) => {\r\n removeInstance(instanceTarget);\r\n runEachAndClear(destroyFns);\r\n\r\n destroyed = true;\r\n\r\n triggerEvent('destroyed', [instance, canceled]);\r\n removePluginEvents();\r\n removeInstanceEvents();\r\n };\r\n\r\n const instance: OverlayScrollbars = {\r\n options(newOptions?: PartialOptions, pure?: boolean) {\r\n if (newOptions) {\r\n const base = pure ? _getDefaultOptions() : {};\r\n const changedOptions = getOptionsDiff(\r\n currentOptions,\r\n assignDeep(base, validateOptions(newOptions))\r\n );\r\n if (!isEmptyObject(changedOptions)) {\r\n assignDeep(currentOptions, changedOptions);\r\n setupsUpdate({ _changedOptions: changedOptions });\r\n }\r\n }\r\n return assignDeep({}, currentOptions);\r\n },\r\n on: addInstanceEvent,\r\n off: (name, listener) => {\r\n if (name && listener) {\r\n removeInstanceEvents(name, listener);\r\n }\r\n },\r\n state() {\r\n const { _observersSetupState, _structureSetupState } = setupsState();\r\n const { _directionIsRTL } = _observersSetupState;\r\n const {\r\n _overflowEdge,\r\n _overflowAmount,\r\n _overflowStyle,\r\n _hasOverflow,\r\n _padding,\r\n _paddingAbsolute,\r\n _scrollCoordinates,\r\n } = _structureSetupState;\r\n return assignDeep(\r\n {},\r\n {\r\n overflowEdge: _overflowEdge,\r\n overflowAmount: _overflowAmount,\r\n overflowStyle: _overflowStyle,\r\n hasOverflow: _hasOverflow,\r\n scrollCoordinates: {\r\n start: _scrollCoordinates._start,\r\n end: _scrollCoordinates._end,\r\n },\r\n padding: _padding,\r\n paddingAbsolute: _paddingAbsolute,\r\n directionRTL: _directionIsRTL,\r\n destroyed,\r\n }\r\n );\r\n },\r\n elements() {\r\n const {\r\n _target,\r\n _host,\r\n _padding,\r\n _viewport,\r\n _content,\r\n _scrollOffsetElement,\r\n _scrollEventElement,\r\n } = setupsElements._structureSetupElements;\r\n const { _horizontal, _vertical } = setupsElements._scrollbarsSetupElements;\r\n const translateScrollbarStructure = (\r\n scrollbarStructure: ScrollbarStructure\r\n ): ScrollbarElements => {\r\n const { _handle, _track, _scrollbar } = scrollbarStructure;\r\n return {\r\n scrollbar: _scrollbar,\r\n track: _track,\r\n handle: _handle,\r\n };\r\n };\r\n const translateScrollbarsSetupElement = (\r\n scrollbarsSetupElement: ScrollbarsSetupElement\r\n ): CloneableScrollbarElements => {\r\n const { _scrollbarStructures, _clone } = scrollbarsSetupElement;\r\n const translatedStructure = translateScrollbarStructure(_scrollbarStructures[0]);\r\n\r\n return assignDeep({}, translatedStructure, {\r\n clone: () => {\r\n const result = translateScrollbarStructure(_clone());\r\n setupsUpdate({ _cloneScrollbar: true });\r\n return result;\r\n },\r\n });\r\n };\r\n return assignDeep(\r\n {},\r\n {\r\n target: _target,\r\n host: _host,\r\n padding: _padding || _viewport,\r\n viewport: _viewport,\r\n content: _content || _viewport,\r\n scrollOffsetElement: _scrollOffsetElement,\r\n scrollEventElement: _scrollEventElement,\r\n scrollbarHorizontal: translateScrollbarsSetupElement(_horizontal),\r\n scrollbarVertical: translateScrollbarsSetupElement(_vertical),\r\n }\r\n );\r\n },\r\n update: (_force?: boolean) => setupsUpdate({ _force, _takeRecords: true }),\r\n destroy: bind(destroy, false),\r\n plugin:

(plugin: P) =>\r\n instancePluginModuleInstances[keys(plugin)[0]] as\r\n | InferInstancePluginModuleInstance

\r\n | undefined,\r\n };\r\n\r\n push(destroyFns, [setupsCanceled]);\r\n\r\n // valid inside plugins\r\n addInstance(instanceTarget, instance);\r\n\r\n // init plugins\r\n registerPluginModuleInstances(pluginModules, OverlayScrollbars, [\r\n instance,\r\n addPluginEvent,\r\n instancePluginModuleInstances,\r\n ]);\r\n\r\n if (\r\n cancelInitialization(\r\n setupsElements._structureSetupElements._isBody,\r\n !targetIsElement && target.cancel\r\n )\r\n ) {\r\n destroy(true);\r\n return instance;\r\n }\r\n\r\n push(destroyFns, setupsConstruct());\r\n\r\n triggerEvent('initialized', [instance]);\r\n\r\n instance.update();\r\n\r\n return instance;\r\n }\r\n return potentialInstance!;\r\n};\r\n\r\nOverlayScrollbars.plugin = (plugins: Plugin | Plugin[]) => {\r\n const isArr = isArray(plugins);\r\n const pluginsToAdd: Plugin[] =\r\n isArr ? plugins : [plugins];\r\n const result = pluginsToAdd.map(\r\n (plugin) => registerPluginModuleInstances(plugin, OverlayScrollbars)[0]\r\n );\r\n addPlugins(pluginsToAdd);\r\n return isArr ? result : (result[0] as any);\r\n};\r\nOverlayScrollbars.valid = (osInstance: any): osInstance is OverlayScrollbars => {\r\n const hasElmsFn = osInstance && (osInstance as OverlayScrollbars).elements;\r\n const elements = isFunction(hasElmsFn) && hasElmsFn();\r\n return isPlainObject(elements) && !!getInstance(elements.target);\r\n};\r\nOverlayScrollbars.env = () => {\r\n const {\r\n _nativeScrollbarsSize,\r\n _nativeScrollbarsOverlaid,\r\n _nativeScrollbarsHiding,\r\n _scrollTimeline,\r\n _staticDefaultInitialization,\r\n _staticDefaultOptions,\r\n _getDefaultInitialization,\r\n _setDefaultInitialization,\r\n _getDefaultOptions,\r\n _setDefaultOptions,\r\n } = getEnvironment();\r\n return assignDeep(\r\n {},\r\n {\r\n scrollbarsSize: _nativeScrollbarsSize,\r\n scrollbarsOverlaid: _nativeScrollbarsOverlaid,\r\n scrollbarsHiding: _nativeScrollbarsHiding,\r\n scrollTimeline: _scrollTimeline,\r\n staticDefaultInitialization: _staticDefaultInitialization,\r\n staticDefaultOptions: _staticDefaultOptions,\r\n\r\n getDefaultInitialization: _getDefaultInitialization,\r\n setDefaultInitialization: _setDefaultInitialization,\r\n getDefaultOptions: _getDefaultOptions,\r\n setDefaultOptions: _setDefaultOptions,\r\n }\r\n );\r\n};\r\nOverlayScrollbars.nonce = setNonce;\r\nOverlayScrollbars.trustedTypePolicy = setTrustedTypePolicy;\r\n","'use strict';\nvar aCallable = require('../internals/a-callable');\nvar anObject = require('../internals/an-object');\nvar call = require('../internals/function-call');\nvar toIntegerOrInfinity = require('../internals/to-integer-or-infinity');\nvar getIteratorDirect = require('../internals/get-iterator-direct');\n\nvar INVALID_SIZE = 'Invalid size';\nvar $RangeError = RangeError;\nvar $TypeError = TypeError;\nvar max = Math.max;\n\nvar SetRecord = function (set, intSize) {\n this.set = set;\n this.size = max(intSize, 0);\n this.has = aCallable(set.has);\n this.keys = aCallable(set.keys);\n};\n\nSetRecord.prototype = {\n getIterator: function () {\n return getIteratorDirect(anObject(call(this.keys, this.set)));\n },\n includes: function (it) {\n return call(this.has, this.set, it);\n }\n};\n\n// `GetSetRecord` abstract operation\n// https://tc39.es/proposal-set-methods/#sec-getsetrecord\nmodule.exports = function (obj) {\n anObject(obj);\n var numSize = +obj.size;\n // NOTE: If size is undefined, then numSize will be NaN\n // eslint-disable-next-line no-self-compare -- NaN check\n if (numSize !== numSize) throw new $TypeError(INVALID_SIZE);\n var intSize = toIntegerOrInfinity(numSize);\n if (intSize < 0) throw new $RangeError(INVALID_SIZE);\n return new SetRecord(obj, intSize);\n};\n","import { buildProps } from '@element-plus/utils'\nimport { componentSizes } from '@element-plus/constants'\n\nimport type Tag from './tag.vue'\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\n\nexport const tagProps = buildProps({\n /**\n * @description type of Tag\n */\n type: {\n type: String,\n values: ['primary', 'success', 'info', 'warning', 'danger'],\n default: 'primary',\n },\n /**\n * @description whether Tag can be removed\n */\n closable: Boolean,\n /**\n * @description whether to disable animations\n */\n disableTransitions: Boolean,\n /**\n * @description whether Tag has a highlighted border\n */\n hit: Boolean,\n /**\n * @description background color of the Tag\n */\n color: String,\n /**\n * @description size of Tag\n */\n size: {\n type: String,\n values: componentSizes,\n },\n /**\n * @description theme of Tag\n */\n effect: {\n type: String,\n values: ['dark', 'light', 'plain'],\n default: 'light',\n },\n /**\n * @description whether Tag is rounded\n */\n round: Boolean,\n} as const)\nexport type TagProps = ExtractPropTypes\nexport type TagPropsPublic = __ExtractPublicPropTypes\n\nexport const tagEmits = {\n close: (evt: MouseEvent) => evt instanceof MouseEvent,\n click: (evt: MouseEvent) => evt instanceof MouseEvent,\n}\nexport type TagEmits = typeof tagEmits\n\nexport type TagInstance = InstanceType & unknown\n","'use strict';\nvar aSet = require('../internals/a-set');\nvar size = require('../internals/set-size');\nvar iterate = require('../internals/set-iterate');\nvar getSetRecord = require('../internals/get-set-record');\n\n// `Set.prototype.isSubsetOf` method\n// https://tc39.es/ecma262/#sec-set.prototype.issubsetof\nmodule.exports = function isSubsetOf(other) {\n var O = aSet(this);\n var otherRec = getSetRecord(other);\n if (size(O) > otherRec.size) return false;\n return iterate(O, function (e) {\n if (!otherRec.includes(e)) return false;\n }, true) !== false;\n};\n","import { computed, inject, unref } from 'vue'\nimport { buildProp } from '@element-plus/utils'\nimport { componentSizes } from '@element-plus/constants'\n\nimport type { InjectionKey, Ref } from 'vue'\nimport type { ComponentSize } from '@element-plus/constants'\n\nexport const useSizeProp = buildProp({\n type: String,\n values: componentSizes,\n required: false,\n} as const)\n\nexport const useSizeProps = {\n size: useSizeProp,\n}\n\nexport interface SizeContext {\n size: Ref\n}\n\nexport const SIZE_INJECTION_KEY: InjectionKey = Symbol('size')\n\nexport const useGlobalSize = () => {\n const injectedSize = inject(SIZE_INJECTION_KEY, {} as SizeContext)\n\n return computed(() => {\n return unref(injectedSize.size) || ''\n })\n}\n","'use strict';\nvar $ = require('../internals/export');\nvar isDisjointFrom = require('../internals/set-is-disjoint-from');\nvar setMethodAcceptSetLike = require('../internals/set-method-accept-set-like');\n\nvar INCORRECT = !setMethodAcceptSetLike('isDisjointFrom', function (result) {\n return !result;\n});\n\n// `Set.prototype.isDisjointFrom` method\n// https://tc39.es/ecma262/#sec-set.prototype.isdisjointfrom\n$({ target: 'Set', proto: true, real: true, forced: INCORRECT }, {\n isDisjointFrom: isDisjointFrom\n});\n","import { u as useHead } from './shared/vue.-sixQ7xP.mjs';\nimport 'vue';\nimport './shared/vue.ziyDaVMR.mjs';\nimport 'unhead';\nimport '@unhead/shared';\n\nfunction polyfillAsVueUseHead(head) {\n const polyfilled = head;\n polyfilled.headTags = head.resolveTags;\n polyfilled.addEntry = head.push;\n polyfilled.addHeadObjs = head.push;\n polyfilled.addReactiveEntry = (input, options) => {\n const api = useHead(input, options);\n if (api !== void 0)\n return api.dispose;\n return () => {\n };\n };\n polyfilled.removeHeadObjs = () => {\n };\n polyfilled.updateDOM = () => {\n head.hooks.callHook(\"entries:updated\", head);\n };\n polyfilled.unhead = head;\n return polyfilled;\n}\n\nexport { polyfillAsVueUseHead };\n","import { createHead as createHead$1, Vue2ProvideUnheadPlugin } from '@unhead/vue';\nexport { Vue2ProvideUnheadPlugin, VueHeadMixin, createHeadCore, injectHead, unheadVueComposablesImports, useHead, useHeadSafe, useSeoMeta, useServerHead, useServerHeadSafe, useServerSeoMeta } from '@unhead/vue';\nimport { polyfillAsVueUseHead } from '@unhead/vue/polyfill';\nimport { renderSSRHead } from '@unhead/ssr';\nexport { Head } from '@unhead/vue/components';\n\nfunction createHead(initHeadObject, options) {\n const unhead = createHead$1(options || {});\n const legacyHead = polyfillAsVueUseHead(unhead);\n if (initHeadObject)\n legacyHead.push(initHeadObject);\n return legacyHead;\n}\n\nconst HeadVuePlugin = Vue2ProvideUnheadPlugin;\nconst renderHeadToString = (head) => renderSSRHead(head.unhead);\n\nexport { HeadVuePlugin, createHead, renderHeadToString };\n","'use strict';\nvar isObject = require('../internals/is-object');\n\nmodule.exports = function (argument) {\n return isObject(argument) || argument === null;\n};\n","import root from './_root.js';\n\n/** Built-in value references. */\nvar Uint8Array = root.Uint8Array;\n\nexport default Uint8Array;\n","'use strict';\nvar isObject = require('../internals/is-object');\n\nvar $String = String;\nvar $TypeError = TypeError;\n\nmodule.exports = function (argument) {\n if (argument === undefined || isObject(argument)) return argument;\n throw new $TypeError($String(argument) + ' is not an object or undefined');\n};\n","'use strict';\nvar globalThis = require('../internals/global-this');\nvar isObject = require('../internals/is-object');\n\nvar document = globalThis.document;\n// typeof document.createElement is 'object' in old IE\nvar EXISTS = isObject(document) && isObject(document.createElement);\n\nmodule.exports = function (it) {\n return EXISTS ? document.createElement(it) : {};\n};\n","export const version = '2.12.0'\n","export const INSTALLED_KEY = Symbol('INSTALLED_KEY')\n","import { provideGlobalConfig } from '@element-plus/components/config-provider'\nimport { INSTALLED_KEY } from '@element-plus/constants'\nimport { version } from './version'\n\nimport type { App, Plugin } from 'vue'\nimport type { ConfigProviderContext } from '@element-plus/components/config-provider'\n\nexport const makeInstaller = (components: Plugin[] = []) => {\n const install = (app: App, options?: ConfigProviderContext) => {\n if (app[INSTALLED_KEY]) return\n\n app[INSTALLED_KEY] = true\n components.forEach((c) => app.use(c))\n\n if (options) provideGlobalConfig(options, app, true)\n }\n\n return {\n version,\n install,\n }\n}\n","import {\n buildProps,\n definePropType,\n isBoolean,\n isNumber,\n} from '@element-plus/utils'\nimport { CHANGE_EVENT } from '@element-plus/constants'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type { ZIndexProperty } from 'csstype'\nimport type Affix from './affix.vue'\n\nexport const affixProps = buildProps({\n /**\n * @description affix element zIndex value\n * */\n zIndex: {\n type: definePropType([Number, String]),\n default: 100,\n },\n /**\n * @description target container. (CSS selector)\n */\n target: {\n type: String,\n default: '',\n },\n /**\n * @description offset distance\n * */\n offset: {\n type: Number,\n default: 0,\n },\n /**\n * @description position of affix\n * */\n position: {\n type: String,\n values: ['top', 'bottom'],\n default: 'top',\n },\n} as const)\nexport type AffixProps = ExtractPropTypes\nexport type AffixPropsPublic = __ExtractPublicPropTypes\n\nexport const affixEmits = {\n scroll: ({ scrollTop, fixed }: { scrollTop: number; fixed: boolean }) =>\n isNumber(scrollTop) && isBoolean(fixed),\n [CHANGE_EVENT]: (fixed: boolean) => isBoolean(fixed),\n}\nexport type AffixEmits = typeof affixEmits\n\nexport type AffixInstance = InstanceType & unknown\n","\n\n\n","import { withInstall } from '@element-plus/utils'\nimport Affix from './src/affix.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElAffix: SFCWithInstall = withInstall(Affix)\nexport default ElAffix\n\nexport * from './src/affix'\n","import {\n NOOP,\n buildProps,\n definePropType,\n isNumber,\n isObject,\n isString,\n} from '@element-plus/utils'\nimport { useTooltipContentProps } from '@element-plus/components/tooltip'\nimport {\n CHANGE_EVENT,\n INPUT_EVENT,\n UPDATE_MODEL_EVENT,\n} from '@element-plus/constants'\nimport { inputProps } from '@element-plus/components/input'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type Autocomplete from './autocomplete.vue'\nimport type { Placement } from '@element-plus/components/popper'\nimport type { Awaitable } from '@element-plus/utils'\n\nexport type AutocompleteData = Record[]\nexport type AutocompleteFetchSuggestionsCallback = (\n data: AutocompleteData\n) => void\nexport type AutocompleteFetchSuggestions =\n | ((\n queryString: string,\n cb: AutocompleteFetchSuggestionsCallback\n ) => Awaitable | void)\n | AutocompleteData\n\nexport const autocompleteProps = buildProps({\n ...inputProps,\n /**\n * @description key name of the input suggestion object for display\n */\n valueKey: {\n type: String,\n default: 'value',\n },\n /**\n * @description binding value\n */\n modelValue: {\n type: [String, Number],\n default: '',\n },\n /**\n * @description debounce delay when typing, in milliseconds\n */\n debounce: {\n type: Number,\n default: 300,\n },\n /**\n * @description placement of the popup menu\n */\n placement: {\n type: definePropType(String),\n values: [\n 'top',\n 'top-start',\n 'top-end',\n 'bottom',\n 'bottom-start',\n 'bottom-end',\n ],\n default: 'bottom-start',\n },\n /**\n * @description a method to fetch input suggestions. When suggestions are ready, invoke `callback(data:[])` to return them to Autocomplete\n */\n fetchSuggestions: {\n type: definePropType([Function, Array]),\n default: NOOP,\n },\n /**\n * @description custom class name for autocomplete's dropdown\n */\n popperClass: useTooltipContentProps.popperClass,\n /**\n * @description custom style for autocomplete's dropdown\n */\n popperStyle: useTooltipContentProps.popperStyle,\n /**\n * @description whether show suggestions when input focus\n */\n triggerOnFocus: {\n type: Boolean,\n default: true,\n },\n /**\n * @description whether to emit a `select` event on enter when there is no autocomplete match\n */\n selectWhenUnmatched: Boolean,\n /**\n * @description whether to hide the loading icon in remote search\n */\n hideLoading: Boolean,\n /**\n * @description whether select dropdown is teleported to the body\n */\n teleported: useTooltipContentProps.teleported,\n /**\n * @description which select dropdown appends to\n */\n appendTo: useTooltipContentProps.appendTo,\n /**\n * @description whether to highlight first item in remote search suggestions by default\n */\n highlightFirstItem: Boolean,\n /**\n * @description whether the width of the dropdown is the same as the input\n */\n fitInputWidth: Boolean,\n /**\n * @description whether keyboard navigation loops from end to start\n */\n loopNavigation: {\n type: Boolean,\n default: true,\n },\n} as const)\nexport type AutocompleteProps = ExtractPropTypes\nexport type AutocompletePropsPublic = __ExtractPublicPropTypes<\n typeof autocompleteProps\n>\n\nexport const autocompleteEmits = {\n [UPDATE_MODEL_EVENT]: (value: string | number) =>\n isString(value) || isNumber(value),\n [INPUT_EVENT]: (value: string | number) => isString(value) || isNumber(value),\n [CHANGE_EVENT]: (value: string | number) =>\n isString(value) || isNumber(value),\n focus: (evt: FocusEvent) => evt instanceof FocusEvent,\n blur: (evt: FocusEvent) => evt instanceof FocusEvent,\n clear: () => true,\n select: (item: Record) => isObject(item),\n}\nexport type AutocompleteEmits = typeof autocompleteEmits\n\nexport type AutocompleteInstance = InstanceType & unknown\n","\n\n\n","import { withInstall } from '@element-plus/utils'\nimport Autocomplete from './src/autocomplete.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElAutocomplete: SFCWithInstall =\n withInstall(Autocomplete)\n\nexport default ElAutocomplete\n\nexport * from './src/autocomplete'\n","import {\n buildProps,\n definePropType,\n iconPropType,\n isNumber,\n} from '@element-plus/utils'\nimport { componentSizes } from '@element-plus/constants'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type { ObjectFitProperty } from 'csstype'\n\nexport const avatarProps = buildProps({\n /**\n * @description avatar size.\n */\n size: {\n type: [Number, String],\n values: componentSizes,\n default: '',\n validator: (val: unknown): val is number => isNumber(val),\n },\n /**\n * @description avatar shape.\n */\n shape: {\n type: String,\n values: ['circle', 'square'],\n default: 'circle',\n },\n /**\n * @description representation type to icon, more info on icon component.\n */\n icon: {\n type: iconPropType,\n },\n /**\n * @description the source of the image for an image avatar.\n */\n src: {\n type: String,\n default: '',\n },\n /**\n * @description native attribute `alt` of image avatar.\n */\n alt: String,\n /**\n * @description native attribute srcset of image avatar.\n */\n srcSet: String,\n /**\n * @description set how the image fit its container for an image avatar.\n */\n fit: {\n type: definePropType(String),\n default: 'cover',\n },\n} as const)\nexport type AvatarProps = ExtractPropTypes\nexport type AvatarPropsPublic = __ExtractPublicPropTypes\n\nexport const avatarEmits = {\n error: (evt: Event) => evt instanceof Event,\n}\nexport type AvatarEmits = typeof avatarEmits\n","\n\n\n","import { withInstall } from '@element-plus/utils'\nimport Avatar from './src/avatar.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElAvatar: SFCWithInstall = withInstall(Avatar)\nexport default ElAvatar\n\nexport * from './src/avatar'\nexport type { AvatarInstance } from './src/instance'\n","import type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\n\nexport const backtopProps = {\n /**\n * @description the button will not show until the scroll height reaches this value.\n */\n visibilityHeight: {\n type: Number,\n default: 200,\n },\n /**\n * @description the target to trigger scroll.\n */\n target: {\n type: String,\n default: '',\n },\n /**\n * @description right distance.\n */\n right: {\n type: Number,\n default: 40,\n },\n /**\n * @description bottom distance.\n */\n bottom: {\n type: Number,\n default: 40,\n },\n} as const\nexport type BacktopProps = ExtractPropTypes\nexport type BacktopPropsPublic = __ExtractPublicPropTypes\n\nexport const backtopEmits = {\n click: (evt: MouseEvent) => evt instanceof MouseEvent,\n}\nexport type BacktopEmits = typeof backtopEmits\n","import { onMounted, ref, shallowRef } from 'vue'\nimport { useEventListener, useThrottleFn } from '@vueuse/core'\nimport { throwError } from '@element-plus/utils'\n\nimport type { SetupContext } from 'vue'\nimport type { BacktopEmits, BacktopProps } from './backtop'\n\nexport const useBackTop = (\n props: BacktopProps,\n emit: SetupContext['emit'],\n componentName: string\n) => {\n const el = shallowRef()\n const container = shallowRef()\n const visible = ref(false)\n\n const handleScroll = () => {\n if (el.value) visible.value = el.value.scrollTop >= props.visibilityHeight\n }\n\n const handleClick = (event: MouseEvent) => {\n el.value?.scrollTo({ top: 0, behavior: 'smooth' })\n emit('click', event)\n }\n\n const handleScrollThrottled = useThrottleFn(handleScroll, 300, true)\n\n useEventListener(container, 'scroll', handleScrollThrottled)\n onMounted(() => {\n container.value = document\n el.value = document.documentElement\n\n if (props.target) {\n el.value = document.querySelector(props.target) ?? undefined\n if (!el.value) {\n throwError(componentName, `target does not exist: ${props.target}`)\n }\n container.value = el.value\n }\n // Give visible an initial value, fix #13066\n handleScroll()\n })\n\n return {\n visible,\n handleClick,\n }\n}\n","\n\n\n","import { withInstall } from '@element-plus/utils'\nimport Backtop from './src/backtop.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElBacktop: SFCWithInstall = withInstall(Backtop)\nexport default ElBacktop\n\nexport * from './src/backtop'\nexport type { BacktopInstance } from './src/instance'\n","import dayjs from 'dayjs'\nimport { isArray, isDate, isEmpty } from '@element-plus/utils'\n\nimport type { Dayjs } from 'dayjs'\nimport type { DateOrDates, DayOrDays } from './common/props'\n\nexport type TimeList = [number | undefined, number, undefined | number]\n\nexport const buildTimeList = (value: number, bound: number): TimeList => {\n return [\n value > 0 ? value - 1 : undefined,\n value,\n value < bound ? value + 1 : undefined,\n ]\n}\n\nexport const rangeArr = (n: number) =>\n Array.from(Array.from({ length: n }).keys())\n\nexport const extractDateFormat = (format: string) => {\n return format\n .replace(/\\W?m{1,2}|\\W?ZZ/g, '')\n .replace(/\\W?h{1,2}|\\W?s{1,3}|\\W?a/gi, '')\n .trim()\n}\n\nexport const extractTimeFormat = (format: string) => {\n return format\n .replace(/\\W?D{1,2}|\\W?Do|\\W?d{1,4}|\\W?M{1,4}|\\W?Y{2,4}/g, '')\n .trim()\n}\n\nexport const dateEquals = function (a: Date | unknown, b: Date | unknown) {\n const aIsDate = isDate(a)\n const bIsDate = isDate(b)\n if (aIsDate && bIsDate) {\n return a.getTime() === b.getTime()\n }\n if (!aIsDate && !bIsDate) {\n return a === b\n }\n return false\n}\n\nexport const valueEquals = function (\n a: Array | unknown,\n b: Array | unknown\n) {\n const aIsArray = isArray(a)\n const bIsArray = isArray(b)\n if (aIsArray && bIsArray) {\n if (a.length !== b.length) {\n return false\n }\n return a.every((item, index) => dateEquals(item, b[index]))\n }\n if (!aIsArray && !bIsArray) {\n return dateEquals(a, b)\n }\n return false\n}\n\nexport const parseDate = function (\n date: string | number | Date,\n format: string | undefined,\n lang: string\n) {\n const day =\n isEmpty(format) || format === 'x'\n ? dayjs(date).locale(lang)\n : dayjs(date, format).locale(lang)\n return day.isValid() ? day : undefined\n}\n\nexport const formatter = function (\n date: string | number | Date | Dayjs,\n format: string | undefined,\n lang: string\n) {\n if (isEmpty(format)) return date\n if (format === 'x') return +date\n return dayjs(date).locale(lang).format(format)\n}\n\nexport const makeList = (total: number, method?: () => number[]) => {\n const arr: boolean[] = []\n const disabledArr = method?.()\n for (let i = 0; i < total; i++) {\n arr.push(disabledArr?.includes(i) ?? false)\n }\n return arr\n}\n\nexport const dayOrDaysToDate = (dayOrDays: DayOrDays): DateOrDates => {\n return isArray(dayOrDays)\n ? (dayOrDays.map((d) => d.toDate()) as [Date, Date])\n : dayOrDays.toDate()\n}\n","import { buildProps, definePropType, isObject } from '@element-plus/utils'\nimport { rangeArr } from '@element-plus/components/time-picker'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type { Dayjs } from 'dayjs'\n\nexport type CalendarDateCellType = 'next' | 'prev' | 'current'\nexport type CalendarDateCell = {\n text: number\n type: CalendarDateCellType\n}\n\nexport const getPrevMonthLastDays = (date: Dayjs, count: number) => {\n const lastDay = date.subtract(1, 'month').endOf('month').date()\n return rangeArr(count).map((_, index) => lastDay - (count - index - 1))\n}\n\nexport const getMonthDays = (date: Dayjs) => {\n const days = date.daysInMonth()\n return rangeArr(days).map((_, index) => index + 1)\n}\n\nexport const toNestedArr = (days: CalendarDateCell[]) =>\n rangeArr(days.length / 7).map((index) => {\n const start = index * 7\n return days.slice(start, start + 7)\n })\n\nexport const dateTableProps = buildProps({\n selectedDay: {\n type: definePropType(Object),\n },\n range: {\n type: definePropType<[Dayjs, Dayjs]>(Array),\n },\n date: {\n type: definePropType(Object),\n required: true,\n },\n hideHeader: {\n type: Boolean,\n },\n} as const)\nexport type DateTableProps = ExtractPropTypes\nexport type DateTablePropsPublic = __ExtractPublicPropTypes<\n typeof dateTableProps\n>\n\nexport const dateTableEmits = {\n pick: (value: Dayjs) => isObject(value),\n}\nexport type DateTableEmits = typeof dateTableEmits\n","export const datePickTypes = [\n 'year',\n 'years',\n 'month',\n 'months',\n 'date',\n 'dates',\n 'week',\n 'datetime',\n 'datetimerange',\n 'daterange',\n 'monthrange',\n 'yearrange',\n] as const\n\nexport const WEEK_DAYS = [\n 'sun',\n 'mon',\n 'tue',\n 'wed',\n 'thu',\n 'fri',\n 'sat',\n] as const\n\nexport type DatePickType = (typeof datePickTypes)[number]\n","import { computed } from 'vue'\nimport dayjs from 'dayjs'\nimport localeData from 'dayjs/plugin/localeData.js'\nimport { useLocale } from '@element-plus/hooks'\nimport { rangeArr } from '@element-plus/components/time-picker'\nimport { WEEK_DAYS } from '@element-plus/constants'\nimport { getMonthDays, getPrevMonthLastDays, toNestedArr } from './date-table'\n\nimport type { SetupContext } from 'vue'\nimport type { Dayjs } from 'dayjs'\nimport type {\n CalendarDateCell,\n CalendarDateCellType,\n DateTableEmits,\n DateTableProps,\n} from './date-table'\n\nexport const useDateTable = (\n props: DateTableProps,\n emit: SetupContext['emit']\n) => {\n dayjs.extend(localeData)\n // https://day.js.org/docs/en/i18n/locale-data\n const firstDayOfWeek: number = dayjs.localeData().firstDayOfWeek()\n\n const { t, lang } = useLocale()\n const now = dayjs().locale(lang.value)\n\n const isInRange = computed(() => !!props.range && !!props.range.length)\n\n const rows = computed(() => {\n let days: CalendarDateCell[] = []\n if (isInRange.value) {\n const [start, end] = props.range!\n const currentMonthRange: CalendarDateCell[] = rangeArr(\n end.date() - start.date() + 1\n ).map((index) => ({\n text: start.date() + index,\n type: 'current',\n }))\n\n let remaining = currentMonthRange.length % 7\n remaining = remaining === 0 ? 0 : 7 - remaining\n const nextMonthRange: CalendarDateCell[] = rangeArr(remaining).map(\n (_, index) => ({\n text: index + 1,\n type: 'next',\n })\n )\n days = currentMonthRange.concat(nextMonthRange)\n } else {\n const firstDay = props.date.startOf('month').day()\n const prevMonthDays: CalendarDateCell[] = getPrevMonthLastDays(\n props.date,\n (firstDay - firstDayOfWeek + 7) % 7\n ).map((day) => ({\n text: day,\n type: 'prev',\n }))\n const currentMonthDays: CalendarDateCell[] = getMonthDays(props.date).map(\n (day) => ({\n text: day,\n type: 'current',\n })\n )\n days = [...prevMonthDays, ...currentMonthDays]\n const remaining = 7 - (days.length % 7 || 7)\n const nextMonthDays: CalendarDateCell[] = rangeArr(remaining).map(\n (_, index) => ({\n text: index + 1,\n type: 'next',\n })\n )\n days = days.concat(nextMonthDays)\n }\n return toNestedArr(days)\n })\n\n const weekDays = computed(() => {\n const start = firstDayOfWeek\n if (start === 0) {\n return WEEK_DAYS.map((_) => t(`el.datepicker.weeks.${_}`))\n } else {\n return WEEK_DAYS.slice(start)\n .concat(WEEK_DAYS.slice(0, start))\n .map((_) => t(`el.datepicker.weeks.${_}`))\n }\n })\n\n const getFormattedDate = (day: number, type: CalendarDateCellType): Dayjs => {\n switch (type) {\n case 'prev':\n return props.date.startOf('month').subtract(1, 'month').date(day)\n case 'next':\n return props.date.startOf('month').add(1, 'month').date(day)\n case 'current':\n return props.date.date(day)\n }\n }\n\n const handlePickDay = ({ text, type }: CalendarDateCell) => {\n const date = getFormattedDate(text, type)\n emit('pick', date)\n }\n\n const getSlotData = ({ text, type }: CalendarDateCell) => {\n const day = getFormattedDate(text, type)\n return {\n isSelected: day.isSame(props.selectedDay),\n type: `${type}-month`,\n day: day.format('YYYY-MM-DD'),\n date: day.toDate(),\n }\n }\n\n return {\n now,\n isInRange,\n rows,\n weekDays,\n getFormattedDate,\n handlePickDay,\n getSlotData,\n }\n}\n","\n\n\n","import { computed, ref } from 'vue'\nimport dayjs from 'dayjs'\nimport { useLocale } from '@element-plus/hooks'\nimport { debugWarn, isArray, isDate } from '@element-plus/utils'\nimport { INPUT_EVENT, UPDATE_MODEL_EVENT } from '@element-plus/constants'\n\nimport type { ComputedRef, SetupContext } from 'vue'\nimport type { Dayjs } from 'dayjs'\nimport type { CalendarDateType, CalendarEmits, CalendarProps } from './calendar'\n\nconst adjacentMonth = (start: Dayjs, end: Dayjs): [Dayjs, Dayjs][] => {\n const firstMonthLastDay = start.endOf('month')\n const lastMonthFirstDay = end.startOf('month')\n\n // Whether the last day of the first month and the first day of the last month is in the same week\n const isSameWeek = firstMonthLastDay.isSame(lastMonthFirstDay, 'week')\n const lastMonthStartDay = isSameWeek\n ? lastMonthFirstDay.add(1, 'week')\n : lastMonthFirstDay\n\n return [\n [start, firstMonthLastDay],\n [lastMonthStartDay.startOf('week'), end],\n ]\n}\n\nconst threeConsecutiveMonth = (start: Dayjs, end: Dayjs): [Dayjs, Dayjs][] => {\n const firstMonthLastDay = start.endOf('month')\n const secondMonthFirstDay = start.add(1, 'month').startOf('month')\n\n // Whether the last day of the first month and the second month is in the same week\n const secondMonthStartDay = firstMonthLastDay.isSame(\n secondMonthFirstDay,\n 'week'\n )\n ? secondMonthFirstDay.add(1, 'week')\n : secondMonthFirstDay\n\n const secondMonthLastDay = secondMonthStartDay.endOf('month')\n const lastMonthFirstDay = end.startOf('month')\n\n // Whether the last day of the second month and the last day of the last month is in the same week\n const lastMonthStartDay = secondMonthLastDay.isSame(lastMonthFirstDay, 'week')\n ? lastMonthFirstDay.add(1, 'week')\n : lastMonthFirstDay\n\n return [\n [start, firstMonthLastDay],\n [secondMonthStartDay.startOf('week'), secondMonthLastDay],\n [lastMonthStartDay.startOf('week'), end],\n ]\n}\n\nexport const useCalendar = (\n props: CalendarProps,\n emit: SetupContext['emit'],\n componentName: string\n) => {\n const { lang } = useLocale()\n\n const selectedDay = ref()\n const now = dayjs().locale(lang.value)\n\n const realSelectedDay = computed({\n get() {\n if (!props.modelValue) return selectedDay.value\n return date.value\n },\n set(val) {\n if (!val) return\n selectedDay.value = val\n const result = val.toDate()\n\n emit(INPUT_EVENT, result)\n emit(UPDATE_MODEL_EVENT, result)\n },\n })\n\n // if range is valid, we get a two-digit array\n const validatedRange = computed(() => {\n if (\n !props.range ||\n !isArray(props.range) ||\n props.range.length !== 2 ||\n props.range.some((item) => !isDate(item))\n )\n return []\n const rangeArrDayjs = props.range.map((_) => dayjs(_).locale(lang.value))\n const [startDayjs, endDayjs] = rangeArrDayjs\n if (startDayjs.isAfter(endDayjs)) {\n debugWarn(componentName, 'end time should be greater than start time')\n return []\n }\n if (startDayjs.isSame(endDayjs, 'month')) {\n // same month\n return calculateValidatedDateRange(startDayjs, endDayjs)\n } else {\n // two months\n if (startDayjs.add(1, 'month').month() !== endDayjs.month()) {\n debugWarn(\n componentName,\n 'start time and end time interval must not exceed two months'\n )\n return []\n }\n return calculateValidatedDateRange(startDayjs, endDayjs)\n }\n })\n\n const date: ComputedRef = computed(() => {\n if (!props.modelValue) {\n return (\n realSelectedDay.value ||\n (validatedRange.value.length ? validatedRange.value[0][0] : now)\n )\n } else {\n return dayjs(props.modelValue).locale(lang.value)\n }\n })\n const prevMonthDayjs = computed(() => date.value.subtract(1, 'month').date(1))\n const nextMonthDayjs = computed(() => date.value.add(1, 'month').date(1))\n const prevYearDayjs = computed(() => date.value.subtract(1, 'year').date(1))\n const nextYearDayjs = computed(() => date.value.add(1, 'year').date(1))\n\n // https://github.com/element-plus/element-plus/issues/3155\n // Calculate the validate date range according to the start and end dates\n const calculateValidatedDateRange = (\n startDayjs: Dayjs,\n endDayjs: Dayjs\n ): [Dayjs, Dayjs][] => {\n const firstDay = startDayjs.startOf('week')\n const lastDay = endDayjs.endOf('week')\n const firstMonth = firstDay.get('month')\n const lastMonth = lastDay.get('month')\n\n // Current mouth\n if (firstMonth === lastMonth) {\n return [[firstDay, lastDay]]\n }\n // Two adjacent months\n else if ((firstMonth + 1) % 12 === lastMonth) {\n return adjacentMonth(firstDay, lastDay)\n }\n // Three consecutive months (compatible: 2021-01-30 to 2021-02-28)\n else if (\n firstMonth + 2 === lastMonth ||\n (firstMonth + 1) % 11 === lastMonth\n ) {\n return threeConsecutiveMonth(firstDay, lastDay)\n }\n // Other cases\n else {\n debugWarn(\n componentName,\n 'start time and end time interval must not exceed two months'\n )\n return []\n }\n }\n\n const pickDay = (day: Dayjs) => {\n realSelectedDay.value = day\n }\n\n const selectDate = (type: CalendarDateType) => {\n const dateMap: Record = {\n 'prev-month': prevMonthDayjs.value,\n 'next-month': nextMonthDayjs.value,\n 'prev-year': prevYearDayjs.value,\n 'next-year': nextYearDayjs.value,\n today: now,\n }\n\n const day = dateMap[type]\n\n if (!day.isSame(date.value, 'day')) {\n pickDay(day)\n }\n }\n\n return {\n calculateValidatedDateRange,\n date,\n realSelectedDay,\n pickDay,\n selectDate,\n validatedRange,\n }\n}\n","import {\n buildProps,\n definePropType,\n isArray,\n isDate,\n} from '@element-plus/utils'\nimport { INPUT_EVENT, UPDATE_MODEL_EVENT } from '@element-plus/constants'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\n\nexport type CalendarDateType =\n | 'prev-month'\n | 'next-month'\n | 'prev-year'\n | 'next-year'\n | 'today'\n\nconst isValidRange = (range: unknown): range is [Date, Date] =>\n isArray(range) && range.length === 2 && range.every((item) => isDate(item))\n\nexport const calendarProps = buildProps({\n /**\n * @description binding value\n */\n modelValue: {\n type: Date,\n },\n /**\n * @description time range, including start time and end time.\n * Start time must be start day of week, end time must be end day of week, the time span cannot exceed two months.\n */\n range: {\n type: definePropType<[Date, Date]>(Array),\n validator: isValidRange,\n },\n} as const)\nexport type CalendarProps = ExtractPropTypes\nexport type CalendarPropsPublic = __ExtractPublicPropTypes\n\nexport const calendarEmits = {\n [UPDATE_MODEL_EVENT]: (value: Date) => isDate(value),\n [INPUT_EVENT]: (value: Date) => isDate(value),\n}\nexport type CalendarEmits = typeof calendarEmits\n","\n\n\n","import { withInstall } from '@element-plus/utils'\nimport Calendar from './src/calendar.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElCalendar: SFCWithInstall = withInstall(Calendar)\nexport default ElCalendar\n\nexport * from './src/calendar'\nexport type {\n CalendarDateTableInstance,\n DateTableInstance,\n CalendarInstance,\n} from './src/instance'\n","import { buildProps, isNumber } from '@element-plus/utils'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\n\nexport const carouselProps = buildProps({\n /**\n * @description index of the initially active slide (starting from 0)\n */\n initialIndex: {\n type: Number,\n default: 0,\n },\n /**\n * @description height of the carousel\n */\n height: {\n type: String,\n default: '',\n },\n /**\n * @description how indicators are triggered\n */\n trigger: {\n type: String,\n values: ['hover', 'click'],\n default: 'hover',\n },\n /**\n * @description whether automatically loop the slides\n */\n autoplay: {\n type: Boolean,\n default: true,\n },\n /**\n * @description interval of the auto loop, in milliseconds\n */\n interval: {\n type: Number,\n default: 3000,\n },\n /**\n * @description position of the indicators\n */\n indicatorPosition: {\n type: String,\n values: ['', 'none', 'outside'],\n default: '',\n },\n /**\n * @description when arrows are shown\n */\n arrow: {\n type: String,\n values: ['always', 'hover', 'never'],\n default: 'hover',\n },\n /**\n * @description type of the Carousel\n */\n type: {\n type: String,\n values: ['', 'card'],\n default: '',\n },\n /**\n * @description when type is card, scaled size of secondary cards\n */\n cardScale: {\n type: Number,\n default: 0.83,\n },\n /**\n * @description display the items in loop\n */\n loop: {\n type: Boolean,\n default: true,\n },\n /**\n * @description display direction\n */\n direction: {\n type: String,\n values: ['horizontal', 'vertical'],\n default: 'horizontal',\n },\n /**\n * @description pause autoplay when hover\n */\n pauseOnHover: {\n type: Boolean,\n default: true,\n },\n /**\n * @description infuse dynamism and smoothness into the carousel\n */\n motionBlur: Boolean,\n} as const)\n\nexport const carouselEmits = {\n /**\n * @description triggers when the active slide switches\n * @param current index of the new active slide\n * @param prev index of the old active slide\n */\n change: (current: number, prev: number) => [current, prev].every(isNumber),\n}\n\nexport type CarouselProps = ExtractPropTypes\nexport type CarouselPropsPublic = __ExtractPublicPropTypes\nexport type CarouselEmits = typeof carouselEmits\n","import type { InjectionKey, Ref, VNode } from 'vue'\nimport type { CarouselItemProps } from './carousel-item'\n\nexport type CarouselItemStates = {\n hover: boolean\n translate: number\n scale: number\n active: boolean\n ready: boolean\n inStage: boolean\n animating: boolean\n}\n\nexport type CarouselItemContext = {\n props: CarouselItemProps\n states: CarouselItemStates\n uid: number\n getVnode: () => VNode\n translateItem: (index: number, activeIndex: number, oldIndex?: number) => void\n}\n\nexport type CarouselContext = {\n root: Ref\n items: Ref\n isCardType: Ref\n isVertical: Ref\n loop: boolean\n cardScale: number\n addItem: (item: CarouselItemContext) => void\n removeItem: (item: CarouselItemContext) => void\n setActiveItem: (index: number) => void\n setContainerHeight: (height: number) => void\n}\n\nexport const carouselContextKey: InjectionKey =\n Symbol('carouselContextKey')\n\nexport const CAROUSEL_ITEM_NAME = 'ElCarouselItem'\n","import {\n computed,\n getCurrentInstance,\n isVNode,\n onBeforeUnmount,\n onMounted,\n provide,\n ref,\n shallowRef,\n unref,\n useSlots,\n watch,\n} from 'vue'\nimport { throttle } from 'lodash-unified'\nimport { useResizeObserver } from '@vueuse/core'\nimport { debugWarn, flattedChildren, isString } from '@element-plus/utils'\nimport { useOrderedChildren } from '@element-plus/hooks'\nimport { CHANGE_EVENT } from '@element-plus/constants'\nimport { CAROUSEL_ITEM_NAME, carouselContextKey } from './constants'\n\nimport type { SetupContext } from 'vue'\nimport type { CarouselItemContext } from './constants'\nimport type { CarouselEmits, CarouselProps } from './carousel'\n\nconst THROTTLE_TIME = 300\n\nexport const useCarousel = (\n props: CarouselProps,\n emit: SetupContext['emit'],\n componentName: string\n) => {\n const {\n children: items,\n addChild: addItem,\n removeChild: removeItem,\n ChildrenSorter: ItemsSorter,\n } = useOrderedChildren(\n getCurrentInstance()!,\n CAROUSEL_ITEM_NAME\n )\n\n const slots = useSlots()\n\n // refs\n const activeIndex = ref(-1)\n const timer = ref | null>(null)\n const hover = ref(false)\n const root = ref()\n const containerHeight = ref(0)\n const isItemsTwoLength = ref(true)\n\n // computed\n const arrowDisplay = computed(\n () => props.arrow !== 'never' && !unref(isVertical)\n )\n\n const hasLabel = computed(() => {\n return items.value.some((item) => item.props.label.toString().length > 0)\n })\n\n const isCardType = computed(() => props.type === 'card')\n const isVertical = computed(() => props.direction === 'vertical')\n\n const containerStyle = computed(() => {\n if (props.height !== 'auto') {\n return {\n height: props.height,\n }\n }\n return {\n height: `${containerHeight.value}px`,\n overflow: 'hidden',\n }\n })\n\n // methods\n const throttledArrowClick = throttle(\n (index: number) => {\n setActiveItem(index)\n },\n THROTTLE_TIME,\n { trailing: true }\n )\n\n const throttledIndicatorHover = throttle((index: number) => {\n handleIndicatorHover(index)\n }, THROTTLE_TIME)\n\n const isTwoLengthShow = (index: number) => {\n if (!isItemsTwoLength.value) return true\n return activeIndex.value <= 1 ? index <= 1 : index > 1\n }\n\n function pauseTimer() {\n if (timer.value) {\n clearInterval(timer.value)\n timer.value = null\n }\n }\n\n function startTimer() {\n if (props.interval <= 0 || !props.autoplay || timer.value) return\n timer.value = setInterval(() => playSlides(), props.interval)\n }\n\n const playSlides = () => {\n if (activeIndex.value < items.value.length - 1) {\n activeIndex.value = activeIndex.value + 1\n } else if (props.loop) {\n activeIndex.value = 0\n }\n }\n\n function setActiveItem(index: number | string) {\n if (isString(index)) {\n const filteredItems = items.value.filter(\n (item) => item.props.name === index\n )\n if (filteredItems.length > 0) {\n index = items.value.indexOf(filteredItems[0])\n }\n }\n index = Number(index)\n if (Number.isNaN(index) || index !== Math.floor(index)) {\n debugWarn(componentName, 'index must be integer.')\n return\n }\n const itemCount = items.value.length\n const oldIndex = activeIndex.value\n if (index < 0) {\n activeIndex.value = props.loop ? itemCount - 1 : 0\n } else if (index >= itemCount) {\n activeIndex.value = props.loop ? 0 : itemCount - 1\n } else {\n activeIndex.value = index\n }\n if (oldIndex === activeIndex.value) {\n resetItemPosition(oldIndex)\n }\n resetTimer()\n }\n\n function resetItemPosition(oldIndex?: number) {\n items.value.forEach((item, index) => {\n item.translateItem(index, activeIndex.value, oldIndex)\n })\n }\n\n function itemInStage(item: CarouselItemContext, index: number) {\n const _items = unref(items)\n const itemCount = _items.length\n if (itemCount === 0 || !item.states.inStage) return false\n const nextItemIndex = index + 1\n const prevItemIndex = index - 1\n const lastItemIndex = itemCount - 1\n const isLastItemActive = _items[lastItemIndex].states.active\n const isFirstItemActive = _items[0].states.active\n const isNextItemActive = _items[nextItemIndex]?.states?.active\n const isPrevItemActive = _items[prevItemIndex]?.states?.active\n\n if ((index === lastItemIndex && isFirstItemActive) || isNextItemActive) {\n return 'left'\n } else if ((index === 0 && isLastItemActive) || isPrevItemActive) {\n return 'right'\n }\n return false\n }\n\n function handleMouseEnter() {\n hover.value = true\n if (props.pauseOnHover) {\n pauseTimer()\n }\n }\n\n function handleMouseLeave() {\n hover.value = false\n startTimer()\n }\n\n function handleButtonEnter(arrow: 'left' | 'right') {\n if (unref(isVertical)) return\n items.value.forEach((item, index) => {\n if (arrow === itemInStage(item, index)) {\n item.states.hover = true\n }\n })\n }\n\n function handleButtonLeave() {\n if (unref(isVertical)) return\n items.value.forEach((item) => {\n item.states.hover = false\n })\n }\n\n function handleIndicatorClick(index: number) {\n activeIndex.value = index\n }\n\n function handleIndicatorHover(index: number) {\n if (props.trigger === 'hover' && index !== activeIndex.value) {\n activeIndex.value = index\n }\n }\n\n function prev() {\n setActiveItem(activeIndex.value - 1)\n }\n\n function next() {\n setActiveItem(activeIndex.value + 1)\n }\n\n function resetTimer() {\n pauseTimer()\n if (!props.pauseOnHover) startTimer()\n }\n\n function setContainerHeight(height: number) {\n if (props.height !== 'auto') return\n containerHeight.value = height\n }\n\n function PlaceholderItem() {\n // fix: https://github.com/element-plus/element-plus/issues/12139\n const defaultSlots = slots.default?.()\n if (!defaultSlots) return null\n\n const flatSlots = flattedChildren(defaultSlots)\n\n const normalizeSlots = flatSlots.filter((slot) => {\n return isVNode(slot) && (slot.type as any).name === CAROUSEL_ITEM_NAME\n })\n\n if (normalizeSlots?.length === 2 && props.loop && !isCardType.value) {\n isItemsTwoLength.value = true\n return normalizeSlots\n }\n isItemsTwoLength.value = false\n return null\n }\n\n // watch\n watch(\n () => activeIndex.value,\n (current, prev) => {\n resetItemPosition(prev)\n if (isItemsTwoLength.value) {\n current = current % 2\n prev = prev % 2\n }\n if (prev > -1) {\n emit(CHANGE_EVENT, current, prev)\n }\n }\n )\n\n const exposeActiveIndex = computed({\n get: () => {\n return isItemsTwoLength.value ? activeIndex.value % 2 : activeIndex.value\n },\n set: (value) => (activeIndex.value = value),\n })\n\n watch(\n () => props.autoplay,\n (autoplay) => {\n autoplay ? startTimer() : pauseTimer()\n }\n )\n watch(\n () => props.loop,\n () => {\n setActiveItem(activeIndex.value)\n }\n )\n\n watch(\n () => props.interval,\n () => {\n resetTimer()\n }\n )\n\n const resizeObserver = shallowRef>()\n // lifecycle\n onMounted(() => {\n watch(\n () => items.value,\n () => {\n if (items.value.length > 0) setActiveItem(props.initialIndex)\n },\n {\n immediate: true,\n }\n )\n\n resizeObserver.value = useResizeObserver(root.value, () => {\n resetItemPosition()\n })\n startTimer()\n })\n\n onBeforeUnmount(() => {\n pauseTimer()\n if (root.value && resizeObserver.value) resizeObserver.value.stop()\n })\n\n // provide\n provide(carouselContextKey, {\n root,\n isCardType,\n isVertical,\n items,\n loop: props.loop,\n cardScale: props.cardScale,\n addItem,\n removeItem,\n setActiveItem,\n setContainerHeight,\n })\n\n return {\n root,\n activeIndex,\n exposeActiveIndex,\n arrowDisplay,\n hasLabel,\n hover,\n isCardType,\n items,\n isVertical,\n containerStyle,\n isItemsTwoLength,\n handleButtonEnter,\n handleButtonLeave,\n handleIndicatorClick,\n handleMouseEnter,\n handleMouseLeave,\n setActiveItem,\n prev,\n next,\n PlaceholderItem,\n isTwoLengthShow,\n ItemsSorter,\n throttledArrowClick,\n throttledIndicatorHover,\n }\n}\n","\n\n\n","import { buildProps } from '@element-plus/utils'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\n\nexport const carouselItemProps = buildProps({\n /**\n * @description name of the item, can be used in `setActiveItem`\n */\n name: { type: String, default: '' },\n /**\n * @description text content for the corresponding indicator\n */\n label: {\n type: [String, Number],\n default: '',\n },\n} as const)\n\nexport type CarouselItemProps = ExtractPropTypes\nexport type CarouselItemPropsPublic = __ExtractPublicPropTypes<\n typeof carouselItemProps\n>\n","import {\n getCurrentInstance,\n inject,\n onBeforeUnmount,\n reactive,\n ref,\n unref,\n} from 'vue'\nimport { debugWarn, isUndefined } from '@element-plus/utils'\nimport { CAROUSEL_ITEM_NAME, carouselContextKey } from './constants'\n\nimport type { CarouselItemProps } from './carousel-item'\n\nexport const useCarouselItem = (props: CarouselItemProps) => {\n const carouselContext = inject(carouselContextKey)!\n // instance\n const instance = getCurrentInstance()!\n if (!carouselContext) {\n debugWarn(\n CAROUSEL_ITEM_NAME,\n 'usage: '\n )\n }\n\n if (!instance) {\n debugWarn(\n CAROUSEL_ITEM_NAME,\n 'compositional hook can only be invoked inside setups'\n )\n }\n\n const carouselItemRef = ref()\n const hover = ref(false)\n const translate = ref(0)\n const scale = ref(1)\n const active = ref(false)\n const ready = ref(false)\n const inStage = ref(false)\n const animating = ref(false)\n\n // computed\n const { isCardType, isVertical, cardScale } = carouselContext\n\n // methods\n\n function processIndex(index: number, activeIndex: number, length: number) {\n const lastItemIndex = length - 1\n const prevItemIndex = activeIndex - 1\n const nextItemIndex = activeIndex + 1\n const halfItemIndex = length / 2\n\n if (activeIndex === 0 && index === lastItemIndex) {\n return -1\n } else if (activeIndex === lastItemIndex && index === 0) {\n return length\n } else if (index < prevItemIndex && activeIndex - index >= halfItemIndex) {\n return length + 1\n } else if (index > nextItemIndex && index - activeIndex >= halfItemIndex) {\n return -2\n }\n return index\n }\n\n function calcCardTranslate(index: number, activeIndex: number) {\n const parentWidth = unref(isVertical)\n ? carouselContext.root.value?.offsetHeight || 0\n : carouselContext.root.value?.offsetWidth || 0\n\n if (inStage.value) {\n return (parentWidth * ((2 - cardScale) * (index - activeIndex) + 1)) / 4\n } else if (index < activeIndex) {\n return (-(1 + cardScale) * parentWidth) / 4\n } else {\n return ((3 + cardScale) * parentWidth) / 4\n }\n }\n\n function calcTranslate(\n index: number,\n activeIndex: number,\n isVertical: boolean\n ) {\n const rootEl = carouselContext.root.value\n if (!rootEl) return 0\n\n const distance =\n (isVertical ? rootEl.offsetHeight : rootEl.offsetWidth) || 0\n return distance * (index - activeIndex)\n }\n\n const translateItem = (\n index: number,\n activeIndex: number,\n oldIndex?: number\n ) => {\n const _isCardType = unref(isCardType)\n const carouselItemLength = carouselContext.items.value.length ?? Number.NaN\n\n const isActive = index === activeIndex\n if (!_isCardType && !isUndefined(oldIndex)) {\n animating.value = isActive || index === oldIndex\n }\n\n if (!isActive && carouselItemLength > 2 && carouselContext.loop) {\n index = processIndex(index, activeIndex, carouselItemLength)\n }\n\n const _isVertical = unref(isVertical)\n active.value = isActive\n\n if (_isCardType) {\n inStage.value = Math.round(Math.abs(index - activeIndex)) <= 1\n translate.value = calcCardTranslate(index, activeIndex)\n scale.value = unref(active) ? 1 : cardScale\n } else {\n translate.value = calcTranslate(index, activeIndex, _isVertical)\n }\n\n ready.value = true\n\n if (isActive && carouselItemRef.value) {\n carouselContext.setContainerHeight(carouselItemRef.value.offsetHeight)\n }\n }\n\n function handleItemClick() {\n if (carouselContext && unref(isCardType)) {\n const index = carouselContext.items.value.findIndex(\n ({ uid }) => uid === instance.uid\n )\n carouselContext.setActiveItem(index)\n }\n }\n\n const carouselItemContext = {\n props,\n states: reactive({\n hover,\n translate,\n scale,\n active,\n ready,\n inStage,\n animating,\n }),\n uid: instance.uid,\n getVnode: () => instance.vnode,\n translateItem,\n }\n\n carouselContext.addItem(carouselItemContext)\n\n onBeforeUnmount(() => {\n carouselContext.removeItem(carouselItemContext)\n })\n\n return {\n carouselItemRef,\n active,\n animating,\n hover,\n inStage,\n isVertical,\n translate,\n isCardType,\n scale,\n ready,\n handleItemClick,\n }\n}\n","\n\n\n","import { withInstall, withNoopInstall } from '@element-plus/utils'\nimport Carousel from './src/carousel.vue'\nimport CarouselItem from './src/carousel-item.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElCarousel: SFCWithInstall & {\n CarouselItem: typeof CarouselItem\n} = withInstall(Carousel, {\n CarouselItem,\n})\n\nexport default ElCarousel\n\nexport const ElCarouselItem: SFCWithInstall =\n withNoopInstall(CarouselItem)\n\nexport * from './src/carousel'\nexport * from './src/carousel-item'\nexport * from './src/constants'\n\nexport type { CarouselInstance, CarouselItemInstance } from './src/instance'\n","import baseFlatten from './_baseFlatten.js';\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0;\n\n/**\n * Recursively flattens `array`.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to flatten.\n * @returns {Array} Returns the new flattened array.\n * @example\n *\n * _.flattenDeep([1, [2, [3, [4]], 5]]);\n * // => [1, 2, 3, 4, 5]\n */\nfunction flattenDeep(array) {\n var length = array == null ? 0 : array.length;\n return length ? baseFlatten(array, INFINITY) : [];\n}\n\nexport default flattenDeep;\n","import type { InjectionKey, VNode } from 'vue'\nimport type { Nullable } from '@element-plus/utils'\nimport type { default as CascaderNode } from './node'\n\nexport type { CascaderNode, Nullable }\nexport type CascaderNodeValue = string | number | Record\nexport type CascaderNodePathValue = CascaderNodeValue[]\nexport type CascaderValue =\n | CascaderNodeValue\n | CascaderNodePathValue\n | (CascaderNodeValue | CascaderNodePathValue)[]\nexport type CascaderConfig = Required\nexport type ExpandTrigger = 'click' | 'hover'\nexport type isDisabled = (data: CascaderOption, node: CascaderNode) => boolean\nexport type isLeaf = (data: CascaderOption, node: CascaderNode) => boolean\nexport type Resolve = (dataList?: CascaderOption[]) => void\nexport type LazyLoad = (\n node: CascaderNode,\n resolve: Resolve,\n reject: () => void\n) => void\nexport interface RenderLabelProps {\n node: CascaderNode\n data: CascaderOption\n}\nexport type RenderLabel = (props: RenderLabelProps) => VNode | VNode[]\nexport interface CascaderOption extends Record {\n label?: string\n value?: CascaderNodeValue\n children?: CascaderOption[]\n disabled?: boolean\n leaf?: boolean\n}\n\nexport interface CascaderProps {\n expandTrigger?: ExpandTrigger\n multiple?: boolean\n checkStrictly?: boolean\n emitPath?: boolean\n lazy?: boolean\n lazyLoad?: LazyLoad\n value?: string\n label?: string\n children?: string\n disabled?: string | isDisabled\n leaf?: string | isLeaf\n hoverThreshold?: number\n checkOnClickNode?: boolean\n checkOnClickLeaf?: boolean\n showPrefix?: boolean\n}\n\nexport interface Tag {\n node?: CascaderNode\n key: number\n text: string\n hitState?: boolean\n closable: boolean\n}\n\nexport interface ElCascaderPanelContext {\n config: CascaderConfig\n expandingNode: CascaderNode | undefined\n checkedNodes: CascaderNode[]\n isHoverMenu: boolean\n initialLoaded: boolean\n renderLabelFn: RenderLabel\n lazyLoad: (\n node?: CascaderNode,\n cb?: (dataList: CascaderOption[]) => void\n ) => void\n expandNode: (node: CascaderNode, silent?: boolean) => void\n handleCheckChange: (\n node: CascaderNode,\n checked: boolean,\n emitClose?: boolean\n ) => void\n}\n\nexport const CASCADER_PANEL_INJECTION_KEY: InjectionKey =\n Symbol()\n","import { Comment, defineComponent, inject } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport { isArray } from '@element-plus/utils'\nimport { CASCADER_PANEL_INJECTION_KEY } from './types'\n\nimport type { PropType, VNode } from 'vue'\nimport type { CascaderNode } from './types'\n\nfunction isVNodeEmpty(vnodes?: VNode[] | VNode) {\n return !!(isArray(vnodes)\n ? vnodes.every(({ type }) => type === Comment)\n : vnodes?.type === Comment)\n}\n\nexport default defineComponent({\n name: 'NodeContent',\n props: {\n node: {\n type: Object as PropType,\n required: true,\n },\n },\n setup(props) {\n const ns = useNamespace('cascader-node')\n const { renderLabelFn } = inject(CASCADER_PANEL_INJECTION_KEY)!\n const { node } = props\n const { data, label: nodeLabel } = node\n\n const label = () => {\n const renderLabel = renderLabelFn?.({ node, data })\n return isVNodeEmpty(renderLabel) ? nodeLabel : (renderLabel ?? nodeLabel)\n }\n return () => {label()}\n },\n})\n","\n\n\n","\n\n\n","import { isArray, isEmpty, isFunction, isUndefined } from '@element-plus/utils'\n\nimport type {\n CascaderConfig,\n CascaderNodePathValue,\n CascaderNodeValue,\n CascaderOption,\n} from './types'\n\ntype ChildrenData = CascaderOption[] | undefined\n\nlet uid = 0\n\nconst calculatePathNodes = (node: Node) => {\n const nodes = [node]\n let { parent } = node\n\n while (parent) {\n nodes.unshift(parent)\n parent = parent.parent\n }\n\n return nodes\n}\n\nclass Node {\n readonly uid: number = uid++\n readonly level: number\n readonly value: CascaderNodeValue\n readonly label: string\n readonly pathNodes: Node[]\n readonly pathValues: CascaderNodePathValue\n readonly pathLabels: string[]\n\n childrenData: ChildrenData\n children: Node[]\n text: string\n loaded: boolean\n /**\n * Is it checked\n *\n * @default false\n */\n checked = false\n /**\n * Used to indicate the intermediate state of unchecked and fully checked child nodes\n *\n * @default false\n */\n indeterminate = false\n /**\n * Loading Status\n *\n * @default false\n */\n loading = false\n\n constructor(\n readonly data: CascaderOption,\n readonly config: CascaderConfig,\n readonly parent?: Node,\n readonly root = false\n ) {\n const { value: valueKey, label: labelKey, children: childrenKey } = config\n\n const childrenData = data[childrenKey] as ChildrenData\n const pathNodes = calculatePathNodes(this)\n\n this.level = root ? 0 : parent ? parent.level + 1 : 1\n this.value = data[valueKey] as CascaderNodeValue\n this.label = data[labelKey] as string\n this.pathNodes = pathNodes\n this.pathValues = pathNodes.map((node) => node.value)\n this.pathLabels = pathNodes.map((node) => node.label)\n this.childrenData = childrenData\n this.children = (childrenData || []).map(\n (child) => new Node(child, config, this)\n )\n this.loaded = !config.lazy || this.isLeaf || !isEmpty(childrenData)\n this.text = ''\n }\n\n get isDisabled(): boolean {\n const { data, parent, config } = this\n const { disabled, checkStrictly } = config\n const isDisabled = isFunction(disabled)\n ? disabled(data, this)\n : !!data[disabled]\n return isDisabled || (!checkStrictly && !!parent?.isDisabled)\n }\n\n get isLeaf(): boolean {\n const { data, config, childrenData, loaded } = this\n const { lazy, leaf } = config\n const isLeaf = isFunction(leaf) ? leaf(data, this) : data[leaf]\n\n return isUndefined(isLeaf)\n ? lazy && !loaded\n ? false\n : !(isArray(childrenData) && childrenData.length)\n : !!isLeaf\n }\n\n get valueByOption() {\n return this.config.emitPath ? this.pathValues : this.value\n }\n\n appendChild(childData: CascaderOption) {\n const { childrenData, children } = this\n const node = new Node(childData, this.config, this)\n\n if (isArray(childrenData)) {\n childrenData.push(childData)\n } else {\n this.childrenData = [childData]\n }\n\n children.push(node)\n\n return node\n }\n\n calcText(allLevels: boolean, separator: string) {\n const text = allLevels ? this.pathLabels.join(separator) : this.label\n this.text = text\n return text\n }\n\n broadcast(checked: boolean) {\n this.children.forEach((child) => {\n if (child) {\n // bottom up\n child.broadcast(checked)\n child.onParentCheck?.(checked)\n }\n })\n }\n\n emit() {\n const { parent } = this\n if (parent) {\n parent.onChildCheck?.()\n parent.emit()\n }\n }\n\n onParentCheck(checked: boolean) {\n if (!this.isDisabled) {\n this.setCheckState(checked)\n }\n }\n\n onChildCheck() {\n const { children } = this\n const validChildren = children.filter((child) => !child.isDisabled)\n const checked = validChildren.length\n ? validChildren.every((child) => child.checked)\n : false\n\n this.setCheckState(checked)\n }\n\n setCheckState(checked: boolean) {\n const totalNum = this.children.length\n const checkedNum = this.children.reduce((c, p) => {\n const num = p.checked ? 1 : p.indeterminate ? 0.5 : 0\n return c + num\n }, 0)\n\n this.checked =\n this.loaded &&\n this.children\n .filter((child) => !child.isDisabled)\n .every((child) => child.loaded && child.checked) &&\n checked\n this.indeterminate =\n this.loaded && checkedNum !== totalNum && checkedNum > 0\n }\n\n doCheck(checked: boolean) {\n if (this.checked === checked) return\n\n const { checkStrictly, multiple } = this.config\n\n if (checkStrictly || !multiple) {\n this.checked = checked\n } else {\n // bottom up to unify the calculation of the indeterminate state\n this.broadcast(checked)\n this.setCheckState(checked)\n this.emit()\n }\n }\n}\n\nexport default Node\n","import { isEqual } from 'lodash-unified'\nimport { isPropAbsent } from '@element-plus/utils'\nimport Node from './node'\n\nimport type { Nullable } from '@element-plus/utils'\nimport type {\n CascaderConfig,\n CascaderNodePathValue,\n CascaderNodeValue,\n CascaderOption,\n} from './types'\n\nconst flatNodes = (nodes: Node[], leafOnly: boolean) => {\n return nodes.reduce((res, node) => {\n if (node.isLeaf) {\n res.push(node)\n } else {\n !leafOnly && res.push(node)\n res = res.concat(flatNodes(node.children, leafOnly))\n }\n return res\n }, [] as Node[])\n}\n\nexport default class Store {\n readonly nodes: Node[]\n readonly allNodes: Node[]\n readonly leafNodes: Node[]\n\n constructor(\n data: CascaderOption[],\n readonly config: CascaderConfig\n ) {\n const nodes = (data || []).map(\n (nodeData) => new Node(nodeData, this.config)\n )\n this.nodes = nodes\n this.allNodes = flatNodes(nodes, false)\n this.leafNodes = flatNodes(nodes, true)\n }\n\n getNodes() {\n return this.nodes\n }\n\n getFlattedNodes(leafOnly: boolean) {\n return leafOnly ? this.leafNodes : this.allNodes\n }\n\n appendNode(nodeData: CascaderOption, parentNode?: Node) {\n const node = parentNode\n ? parentNode.appendChild(nodeData)\n : new Node(nodeData, this.config)\n\n if (!parentNode) this.nodes.push(node)\n\n this.appendAllNodesAndLeafNodes(node)\n }\n\n appendNodes(nodeDataList: CascaderOption[], parentNode: Node) {\n if (nodeDataList.length > 0) {\n nodeDataList.forEach((nodeData) => this.appendNode(nodeData, parentNode))\n } else {\n parentNode && parentNode.isLeaf && this.leafNodes.push(parentNode)\n }\n }\n\n appendAllNodesAndLeafNodes(node: Node) {\n this.allNodes.push(node)\n node.isLeaf && this.leafNodes.push(node)\n if (node.children) {\n node.children.forEach((subNode) => {\n this.appendAllNodesAndLeafNodes(subNode)\n })\n }\n }\n\n // when checkStrictly, leaf node first\n getNodeByValue(\n value: CascaderNodeValue | CascaderNodePathValue,\n leafOnly = false\n ): Nullable {\n if (isPropAbsent(value)) return null\n\n const node = this.getFlattedNodes(leafOnly).find(\n (node) => isEqual(node.value, value) || isEqual(node.pathValues, value)\n )\n\n return node || null\n }\n\n getSameNode(node: Node): Nullable {\n if (!node) return null\n\n const node_ = this.getFlattedNodes(false).find(\n ({ value, level }) => isEqual(node.value, value) && node.level === level\n )\n\n return node_ || null\n }\n}\n","import { computed } from 'vue'\nimport { NOOP, buildProps, definePropType } from '@element-plus/utils'\nimport { CHANGE_EVENT, UPDATE_MODEL_EVENT } from '@element-plus/constants'\n\nimport type { PropType } from 'vue'\nimport type {\n CascaderConfig,\n CascaderNodePathValue,\n CascaderOption,\n CascaderProps,\n CascaderValue,\n RenderLabel,\n} from './types'\n\nexport const CommonProps = buildProps({\n /**\n * @description specify which key of node object is used as the node's value\n */\n modelValue: {\n type: definePropType([Number, String, Array, Object]),\n },\n /**\n * @description data of the options, the key of `value` and `label` can be customize by `CascaderProps`.\n */\n options: {\n type: definePropType(Array),\n default: () => [] as CascaderOption[],\n },\n /**\n * @description configuration options, see the following `CascaderProps` table.\n */\n props: {\n type: definePropType(Object),\n default: () => ({}) as CascaderProps,\n },\n} as const)\n\nexport const DefaultProps: CascaderConfig = {\n /**\n * @description trigger mode of expanding options\n */\n expandTrigger: 'click',\n /**\n * @description whether multiple selection is enabled\n */\n multiple: false,\n /**\n * @description whether checked state of a node not affects its parent and child nodes\n */\n checkStrictly: false, // whether all nodes can be selected\n /**\n * @description when checked nodes change, whether to emit an array of node's path, if false, only emit the value of node.\n */\n emitPath: true, // wether to emit an array of all levels value in which node is located\n /**\n * @description whether to dynamic load child nodes, use with `lazyload` attribute\n */\n lazy: false,\n /**\n * @description method for loading child nodes data, only works when `lazy` is true\n */\n lazyLoad: NOOP,\n /**\n * @description specify which key of node object is used as the node's value\n */\n value: 'value',\n /**\n * @description specify which key of node object is used as the node's label\n */\n label: 'label',\n /**\n * @description specify which key of node object is used as the node's children\n */\n children: 'children',\n /**\n * @description specify which key of node object is used as the node's leaf\n */\n leaf: 'leaf',\n /**\n * @description specify which key of node object is used as the node's disabled\n */\n disabled: 'disabled',\n /**\n * @description hover threshold of expanding options\n */\n hoverThreshold: 500,\n /**\n * @description whether to check or uncheck node when clicking on the node\n */\n checkOnClickNode: false,\n /**\n * @description whether to check or uncheck node when clicking on leaf node (last children).\n */\n checkOnClickLeaf: true,\n /**\n * @description whether to show the radio or checkbox prefix\n */\n showPrefix: true,\n}\n\nexport const cascaderPanelProps = buildProps({\n ...CommonProps,\n border: {\n type: Boolean,\n default: true,\n },\n renderLabel: {\n type: Function as PropType,\n },\n})\n\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nconst emitChangeFn = (value: CascaderValue | undefined | null) => true\n\nexport const cascaderPanelEmits = {\n [UPDATE_MODEL_EVENT]: emitChangeFn,\n [CHANGE_EVENT]: emitChangeFn,\n close: () => true,\n 'expand-change': (value: CascaderNodePathValue) => value,\n}\n\nexport const useCascaderConfig = (props: { props: CascaderProps }) => {\n return computed(() => ({\n ...DefaultProps,\n ...props.props,\n }))\n}\n","import { isLeaf } from '@element-plus/utils'\n\nimport type { CascaderNode } from './types'\n\nexport const getMenuIndex = (el: HTMLElement) => {\n if (!el) return 0\n const pieces = el.id.split('-')\n return Number(pieces[pieces.length - 2])\n}\n\nexport const checkNode = (el: HTMLElement) => {\n if (!el) return\n\n const input = el.querySelector('input')\n if (input) {\n input.click()\n } else if (isLeaf(el)) {\n el.click()\n }\n}\n\nexport const sortByOriginalOrder = (\n oldNodes: CascaderNode[],\n newNodes: CascaderNode[]\n) => {\n const newNodesCopy = newNodes.slice(0)\n const newIds = newNodesCopy.map((node) => node.uid)\n const res = oldNodes.reduce((acc, item) => {\n const index = newIds.indexOf(item.uid)\n if (index > -1) {\n acc.push(item)\n newNodesCopy.splice(index, 1)\n newIds.splice(index, 1)\n }\n return acc\n }, [] as CascaderNode[])\n\n res.push(...newNodesCopy)\n\n return res\n}\n","\n\n\n","import { withInstall } from '@element-plus/utils'\nimport CascaderPanel from './src/index.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElCascaderPanel: SFCWithInstall =\n withInstall(CascaderPanel)\n\nexport default ElCascaderPanel\nexport * from './src/types'\nexport * from './src/config'\nexport * from './src/instance'\n","import { placements } from '@popperjs/core'\nimport { CommonProps } from '@element-plus/components/cascader-panel'\nimport {\n buildProps,\n definePropType,\n iconPropType,\n isBoolean,\n} from '@element-plus/utils'\nimport { useEmptyValuesProps, useSizeProp } from '@element-plus/hooks'\nimport { useTooltipContentProps } from '@element-plus/components/tooltip'\nimport { tagProps } from '@element-plus/components/tag'\nimport { CHANGE_EVENT, UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport { CircleClose } from '@element-plus/icons-vue'\n\nimport type {\n CascaderNode,\n CascaderValue,\n} from '@element-plus/components/cascader-panel'\nimport type { Placement, PopperEffect } from '@element-plus/components/popper'\n\nexport const cascaderProps = buildProps({\n ...CommonProps,\n /**\n * @description size of input\n */\n size: useSizeProp,\n /**\n * @description placeholder of input\n */\n placeholder: String,\n /**\n * @description whether Cascader is disabled\n */\n disabled: {\n type: Boolean,\n default: undefined,\n },\n /**\n * @description whether selected value can be cleared\n */\n clearable: Boolean,\n /**\n * @description custom clear icon component\n */\n clearIcon: {\n type: iconPropType,\n default: CircleClose,\n },\n /**\n * @description whether the options can be searched\n */\n filterable: Boolean,\n /**\n * @description customize search logic, the first parameter is `node`, the second is `keyword`, and need return a boolean value indicating whether it hits.\n */\n filterMethod: {\n type: definePropType<(node: CascaderNode, keyword: string) => boolean>(\n Function\n ),\n default: (node: CascaderNode, keyword: string) =>\n node.text.includes(keyword),\n },\n /**\n * @description option label separator\n */\n separator: {\n type: String,\n default: ' / ',\n },\n /**\n * @description whether to display all levels of the selected value in the input\n */\n showAllLevels: {\n type: Boolean,\n default: true,\n },\n /**\n * @description whether to collapse tags in multiple selection mode\n */\n collapseTags: Boolean,\n /**\n * @description The max tags number to be shown. To use this, collapse-tags must be true\n */\n maxCollapseTags: {\n type: Number,\n default: 1,\n },\n /**\n * @description whether show all selected tags when mouse hover text of collapse-tags. To use this, collapse-tags must be true\n */\n collapseTagsTooltip: Boolean,\n /**\n * @description The max height of collapse tags tooltip, in pixels. To use this, collapse-tags-tooltip must be true\n */\n maxCollapseTagsTooltipHeight: {\n type: [String, Number],\n },\n /**\n * @description debounce delay when typing filter keyword, in milliseconds\n */\n debounce: {\n type: Number,\n default: 300,\n },\n /**\n * @description hook function before filtering with the value to be filtered as its parameter. If `false` is returned or a `Promise` is returned and then is rejected, filtering will be aborted\n */\n beforeFilter: {\n type: definePropType<(value: string) => boolean | Promise>(Function),\n default: () => true,\n },\n /**\n * @description position of dropdown\n */\n placement: {\n type: definePropType(String),\n values: placements,\n default: 'bottom-start',\n },\n /**\n * @description list of possible positions for dropdown\n */\n fallbackPlacements: {\n type: definePropType(Array),\n default: ['bottom-start', 'bottom', 'top-start', 'top', 'right', 'left'],\n },\n /**\n * @description custom class name for Cascader's dropdown\n */\n popperClass: useTooltipContentProps.popperClass,\n /**\n * @description custom style for Cascader's dropdown\n */\n popperStyle: useTooltipContentProps.popperStyle,\n /**\n * @description whether cascader popup is teleported\n */\n teleported: useTooltipContentProps.teleported,\n /**\n * @description tooltip theme, built-in theme: `dark` / `light`\n */\n effect: {\n type: definePropType(String),\n default: 'light',\n },\n /**\n * @description tag type\n */\n\n tagType: { ...tagProps.type, default: 'info' },\n /**\n * @description tag effect\n */\n tagEffect: { ...tagProps.effect, default: 'light' },\n /**\n * @description whether to trigger form validation\n */\n validateEvent: {\n type: Boolean,\n default: true,\n },\n /**\n * @description when dropdown is inactive and `persistent` is `false`, dropdown will be destroyed\n */\n persistent: {\n type: Boolean,\n default: true,\n },\n /**\n * @description Use `parent` when you want things tidy (like \"Entire Collection\" instead of listing 100 items)\n * Use `child` when every single item matters (like important settings)\n */\n showCheckedStrategy: {\n type: String,\n values: ['parent', 'child'],\n default: 'child',\n },\n /**\n * @description whether to check or uncheck node when clicking on the node\n */\n checkOnClickNode: Boolean,\n /**\n * @description whether to show the radio or checkbox prefix\n */\n showPrefix: {\n type: Boolean,\n default: true,\n },\n ...useEmptyValuesProps,\n})\n\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nconst emitChangeFn = (value: CascaderValue | null | undefined) => true\n\nexport const cascaderEmits = {\n [UPDATE_MODEL_EVENT]: emitChangeFn,\n [CHANGE_EVENT]: emitChangeFn,\n focus: (evt: FocusEvent) => evt instanceof FocusEvent,\n blur: (evt: FocusEvent) => evt instanceof FocusEvent,\n clear: () => true,\n visibleChange: (val: boolean) => isBoolean(val),\n expandChange: (val: CascaderValue) => !!val,\n removeTag: (val: CascaderNode['valueByOption']) => !!val,\n}\n\n// Type name is taken(cascader-panel/src/node), needs discussion\n// export type CascaderProps = ExtractPropTypes\n\nexport type CascaderEmits = typeof cascaderEmits\n","\n\n\n","import { withInstall } from '@element-plus/utils'\nimport Cascader from './src/cascader.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElCascader: SFCWithInstall = withInstall(Cascader)\n\nexport default ElCascader\n\nexport * from './src/cascader'\nexport * from './src/instances'\n","import { buildProps, isBoolean } from '@element-plus/utils'\nimport { CHANGE_EVENT } from '@element-plus/constants'\n\nimport type CheckTag from './check-tag.vue'\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\n\nexport const checkTagProps = buildProps({\n /**\n * @description is checked\n */\n checked: Boolean,\n /**\n * @description whether the check-tag is disabled\n */\n disabled: Boolean,\n /**\n * @description type of Tag\n */\n type: {\n type: String,\n values: ['primary', 'success', 'info', 'warning', 'danger'],\n default: 'primary',\n },\n} as const)\nexport type CheckTagProps = ExtractPropTypes\nexport type CheckTagPropsPublic = __ExtractPublicPropTypes\n\nexport const checkTagEmits = {\n 'update:checked': (value: boolean) => isBoolean(value),\n [CHANGE_EVENT]: (value: boolean) => isBoolean(value),\n}\nexport type CheckTagEmits = typeof checkTagEmits\n\nexport type CheckTagInstance = InstanceType & unknown\n","\n\n\n","import { withInstall } from '@element-plus/utils'\nimport CheckTag from './src/check-tag.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElCheckTag: SFCWithInstall = withInstall(CheckTag)\nexport default ElCheckTag\n\nexport * from './src/check-tag'\n","import { buildProps, definePropType, mutable } from '@element-plus/utils'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type Col from './col.vue'\n\nexport type ColSizeObject = {\n span?: number\n offset?: number\n pull?: number\n push?: number\n}\nexport type ColSize = number | ColSizeObject\n\nexport const colProps = buildProps({\n /**\n * @description custom element tag\n */\n tag: {\n type: String,\n default: 'div',\n },\n /**\n * @description number of column the grid spans\n */\n span: {\n type: Number,\n default: 24,\n },\n /**\n * @description number of spacing on the left side of the grid\n */\n offset: {\n type: Number,\n default: 0,\n },\n /**\n * @description number of columns that grid moves to the left\n */\n pull: {\n type: Number,\n default: 0,\n },\n /**\n * @description number of columns that grid moves to the right\n */\n push: {\n type: Number,\n default: 0,\n },\n /**\n * @description `<768px` Responsive columns or column props object\n */\n xs: {\n type: definePropType([Number, Object]),\n default: () => mutable({} as const),\n },\n /**\n * @description `≥768px` Responsive columns or column props object\n */\n sm: {\n type: definePropType([Number, Object]),\n default: () => mutable({} as const),\n },\n /**\n * @description `≥992px` Responsive columns or column props object\n */\n md: {\n type: definePropType([Number, Object]),\n default: () => mutable({} as const),\n },\n /**\n * @description `≥1200px` Responsive columns or column props object\n */\n lg: {\n type: definePropType([Number, Object]),\n default: () => mutable({} as const),\n },\n /**\n * @description `≥1920px` Responsive columns or column props object\n */\n xl: {\n type: definePropType([Number, Object]),\n default: () => mutable({} as const),\n },\n} as const)\nexport type ColProps = ExtractPropTypes\nexport type ColPropsPublic = __ExtractPublicPropTypes\nexport type ColInstance = InstanceType & unknown\n","import type { ComputedRef, InjectionKey } from 'vue'\n\ninterface RowContext {\n gutter: ComputedRef\n}\n\nexport const rowContextKey: InjectionKey = Symbol('rowContextKey')\n","\n\n\n","import { withInstall } from '@element-plus/utils'\nimport Col from './src/col.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElCol: SFCWithInstall = withInstall(Col)\nexport default ElCol\n\nexport * from './src/col'\n","import {\n buildProps,\n definePropType,\n isArray,\n isNumber,\n isString,\n mutable,\n} from '@element-plus/utils'\nimport { CHANGE_EVENT, UPDATE_MODEL_EVENT } from '@element-plus/constants'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type { Arrayable, Awaitable } from '@element-plus/utils'\n\nexport type CollapseActiveName = string | number\nexport type CollapseModelValue = Arrayable\n\nexport type CollapseIconPositionType = 'left' | 'right'\n\nexport const emitChangeFn = (value: CollapseModelValue) =>\n isNumber(value) || isString(value) || isArray(value)\n\nexport const collapseProps = buildProps({\n /**\n * @description whether to activate accordion mode\n */\n accordion: Boolean,\n /**\n * @description currently active panel, the type is `string` in accordion mode, otherwise it is `array`\n */\n modelValue: {\n type: definePropType([Array, String, Number]),\n default: () => mutable([] as const),\n },\n /**\n * @description set expand icon position\n */\n expandIconPosition: {\n type: definePropType([String]),\n default: 'right',\n },\n /**\n * @description before-collapse hook before the collapse state changes. If `false` is returned or a `Promise` is returned and then is rejected, will stop collapsing\n */\n beforeCollapse: {\n type: definePropType<(name: CollapseActiveName) => Awaitable>(\n Function\n ),\n },\n} as const)\nexport type CollapseProps = ExtractPropTypes\nexport type CollapsePropsPublic = __ExtractPublicPropTypes\n\nexport const collapseEmits = {\n [UPDATE_MODEL_EVENT]: emitChangeFn,\n [CHANGE_EVENT]: emitChangeFn,\n}\nexport type CollapseEmits = typeof collapseEmits\n","import type { InjectionKey, Ref } from 'vue'\nimport type { CollapseActiveName } from './collapse'\n\nexport interface CollapseContext {\n activeNames: Ref\n handleItemClick: (name: CollapseActiveName) => void\n}\n\nexport const collapseContextKey: InjectionKey =\n Symbol('collapseContextKey')\n","import { computed, provide, ref, watch } from 'vue'\nimport {\n debugWarn,\n ensureArray,\n isBoolean,\n isPromise,\n throwError,\n} from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport { CHANGE_EVENT, UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport { collapseContextKey } from './constants'\n\nimport type { SetupContext } from 'vue'\nimport type {\n CollapseActiveName,\n CollapseEmits,\n CollapseProps,\n} from './collapse'\n\nconst SCOPE = 'ElCollapse'\nexport const useCollapse = (\n props: CollapseProps,\n emit: SetupContext['emit']\n) => {\n const activeNames = ref(ensureArray(props.modelValue))\n\n const setActiveNames = (_activeNames: CollapseActiveName[]) => {\n activeNames.value = _activeNames\n const value = props.accordion ? activeNames.value[0] : activeNames.value\n emit(UPDATE_MODEL_EVENT, value)\n emit(CHANGE_EVENT, value)\n }\n\n const handleChange = (name: CollapseActiveName) => {\n if (props.accordion) {\n setActiveNames([activeNames.value[0] === name ? '' : name])\n } else {\n const _activeNames = [...activeNames.value]\n const index = _activeNames.indexOf(name)\n\n if (index > -1) {\n _activeNames.splice(index, 1)\n } else {\n _activeNames.push(name)\n }\n setActiveNames(_activeNames)\n }\n }\n\n const handleItemClick = async (name: CollapseActiveName) => {\n const { beforeCollapse } = props\n if (!beforeCollapse) {\n handleChange(name)\n return\n }\n\n const shouldChange = beforeCollapse(name)\n const isPromiseOrBool = [\n isPromise(shouldChange),\n isBoolean(shouldChange),\n ].includes(true)\n if (!isPromiseOrBool) {\n throwError(\n SCOPE,\n 'beforeCollapse must return type `Promise` or `boolean`'\n )\n }\n\n if (isPromise(shouldChange)) {\n shouldChange\n .then((result) => {\n if (result !== false) {\n handleChange(name)\n }\n })\n .catch((e) => {\n debugWarn(SCOPE, `some error occurred: ${e}`)\n })\n } else if (shouldChange) {\n handleChange(name)\n }\n }\n\n watch(\n () => props.modelValue,\n () => (activeNames.value = ensureArray(props.modelValue)),\n { deep: true }\n )\n\n provide(collapseContextKey, {\n activeNames,\n handleItemClick,\n })\n return {\n activeNames,\n setActiveNames,\n }\n}\n\nexport const useCollapseDOM = (props: CollapseProps) => {\n const ns = useNamespace('collapse')\n\n const rootKls = computed(() => [\n ns.b(),\n ns.b(`icon-position-${props.expandIconPosition}`),\n ])\n\n return {\n rootKls,\n }\n}\n","\n\n\n","\n\n\n","import { withInstall } from '@element-plus/utils'\nimport CollapseTransition from './src/collapse-transition.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElCollapseTransition: SFCWithInstall =\n withInstall(CollapseTransition)\n\nexport default ElCollapseTransition\n","import { buildProps, definePropType, iconPropType } from '@element-plus/utils'\nimport { ArrowRight } from '@element-plus/icons-vue'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type { CollapseActiveName } from './collapse'\n\nexport const collapseItemProps = buildProps({\n /**\n * @description title of the panel\n */\n title: {\n type: String,\n default: '',\n },\n /**\n * @description unique identification of the panel\n */\n name: {\n type: definePropType([String, Number]),\n default: undefined,\n },\n /**\n * @description icon of the collapse item\n */\n icon: {\n type: iconPropType,\n default: ArrowRight,\n },\n /**\n * @description disable the collapse item\n */\n disabled: Boolean,\n} as const)\nexport type CollapseItemProps = ExtractPropTypes\nexport type CollapseItemPropsPublic = __ExtractPublicPropTypes<\n typeof collapseItemProps\n>\n","import { computed, inject, ref, unref } from 'vue'\nimport { useIdInjection, useNamespace } from '@element-plus/hooks'\nimport { collapseContextKey } from './constants'\n\nimport type { CollapseItemProps } from './collapse-item'\n\nexport const useCollapseItem = (props: CollapseItemProps) => {\n const collapse = inject(collapseContextKey)\n const { namespace } = useNamespace('collapse')\n\n const focusing = ref(false)\n const isClick = ref(false)\n const idInjection = useIdInjection()\n const id = computed(() => idInjection.current++)\n const name = computed(() => {\n return (\n props.name ?? `${namespace.value}-id-${idInjection.prefix}-${unref(id)}`\n )\n })\n\n const isActive = computed(() =>\n collapse?.activeNames.value.includes(unref(name))\n )\n\n const handleFocus = () => {\n setTimeout(() => {\n if (!isClick.value) {\n focusing.value = true\n } else {\n isClick.value = false\n }\n }, 50)\n }\n\n const handleHeaderClick = (e: MouseEvent) => {\n if (props.disabled) return\n const target = e.target as HTMLElement\n if (target?.closest('input, textarea, select')) return\n collapse?.handleItemClick(unref(name))\n focusing.value = false\n isClick.value = true\n }\n\n const handleEnterClick = (e: KeyboardEvent) => {\n const target = e.target as HTMLElement\n if (target?.closest('input, textarea, select')) return\n e.preventDefault()\n collapse?.handleItemClick(unref(name))\n }\n\n return {\n focusing,\n id,\n isActive,\n handleFocus,\n handleHeaderClick,\n handleEnterClick,\n }\n}\n\nexport const useCollapseItemDOM = (\n props: CollapseItemProps,\n { focusing, isActive, id }: Partial>\n) => {\n const ns = useNamespace('collapse')\n\n const rootKls = computed(() => [\n ns.b('item'),\n ns.is('active', unref(isActive)),\n ns.is('disabled', props.disabled),\n ])\n const headKls = computed(() => [\n ns.be('item', 'header'),\n ns.is('active', unref(isActive)),\n { focusing: unref(focusing) && !props.disabled },\n ])\n const arrowKls = computed(() => [\n ns.be('item', 'arrow'),\n ns.is('active', unref(isActive)),\n ])\n const itemTitleKls = computed(() => [ns.be('item', 'title')])\n const itemWrapperKls = computed(() => ns.be('item', 'wrap'))\n const itemContentKls = computed(() => ns.be('item', 'content'))\n const scopedContentId = computed(() => ns.b(`content-${unref(id)}`))\n const scopedHeadId = computed(() => ns.b(`head-${unref(id)}`))\n\n return {\n itemTitleKls,\n arrowKls,\n headKls,\n rootKls,\n itemWrapperKls,\n itemContentKls,\n scopedContentId,\n scopedHeadId,\n }\n}\n","\n\n\n","import { withInstall, withNoopInstall } from '@element-plus/utils'\nimport Collapse from './src/collapse.vue'\nimport CollapseItem from './src/collapse-item.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElCollapse: SFCWithInstall & {\n CollapseItem: typeof CollapseItem\n} = withInstall(Collapse, {\n CollapseItem,\n})\nexport default ElCollapse\nexport const ElCollapseItem: SFCWithInstall =\n withNoopInstall(CollapseItem)\n\nexport * from './src/collapse'\nexport * from './src/collapse-item'\nexport * from './src/constants'\nexport type { CollapseInstance, CollapseItemInstance } from './src/instance'\n","import { buildProps, definePropType } from '@element-plus/utils'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type Color from '../utils/color'\n\nexport const alphaSliderProps = buildProps({\n color: {\n type: definePropType(Object),\n required: true,\n },\n vertical: Boolean,\n disabled: Boolean,\n} as const)\nexport const hueSliderProps = alphaSliderProps\n\nexport type AlphaSliderProps = ExtractPropTypes\nexport type AlphaSliderPropsPublic = __ExtractPublicPropTypes<\n typeof alphaSliderProps\n>\nexport type HueSliderEmits = AlphaSliderProps\nexport type HueSliderProps = AlphaSliderPropsPublic\n","import { isClient } from '@element-plus/utils'\n\nlet isDragging = false\n\nexport interface DraggableOptions {\n drag?: (event: MouseEvent | TouchEvent) => void\n start?: (event: MouseEvent | TouchEvent) => void\n end?: (event: MouseEvent | TouchEvent) => void\n}\n\nexport function draggable(element: HTMLElement, options: DraggableOptions) {\n if (!isClient) return\n\n const moveFn = function (event: MouseEvent | TouchEvent) {\n options.drag?.(event)\n }\n\n const upFn = function (event: MouseEvent | TouchEvent) {\n document.removeEventListener('mousemove', moveFn)\n document.removeEventListener('mouseup', upFn)\n document.removeEventListener('touchmove', moveFn)\n document.removeEventListener('touchend', upFn)\n document.onselectstart = null\n document.ondragstart = null\n\n isDragging = false\n\n options.end?.(event)\n }\n\n const downFn = function (event: MouseEvent | TouchEvent) {\n if (isDragging) return\n document.onselectstart = () => false\n document.ondragstart = () => false\n document.addEventListener('mousemove', moveFn)\n document.addEventListener('mouseup', upFn)\n document.addEventListener('touchmove', moveFn)\n document.addEventListener('touchend', upFn)\n\n isDragging = true\n\n options.start?.(event)\n }\n\n element.addEventListener('mousedown', downFn)\n element.addEventListener('touchstart', downFn, { passive: false })\n}\n","import { isClient } from '../browser'\n\nexport const isInContainer = (\n el?: Element,\n container?: Element | Window\n): boolean => {\n if (!isClient || !el || !container) return false\n\n const elRect = el.getBoundingClientRect()\n\n let containerRect: Pick\n if (container instanceof Element) {\n containerRect = container.getBoundingClientRect()\n } else {\n containerRect = {\n top: 0,\n right: window.innerWidth,\n bottom: window.innerHeight,\n left: 0,\n }\n }\n return (\n elRect.top < containerRect.bottom &&\n elRect.bottom > containerRect.top &&\n elRect.right > containerRect.left &&\n elRect.left < containerRect.right\n )\n}\n\nexport const getOffsetTop = (el: HTMLElement) => {\n let offset = 0\n let parent = el\n\n while (parent) {\n offset += parent.offsetTop\n parent = parent.offsetParent as HTMLElement\n }\n\n return offset\n}\n\nexport const getOffsetTopDistance = (\n el: HTMLElement,\n containerEl: HTMLElement\n) => {\n return Math.abs(getOffsetTop(el) - getOffsetTop(containerEl))\n}\n\nexport const getClientXY = (event: MouseEvent | TouchEvent) => {\n let clientX: number\n let clientY: number\n if (event.type === 'touchend') {\n clientY = (event as TouchEvent).changedTouches[0].clientY\n clientX = (event as TouchEvent).changedTouches[0].clientX\n } else if (event.type.startsWith('touch')) {\n clientY = (event as TouchEvent).touches[0].clientY\n clientX = (event as TouchEvent).touches[0].clientX\n } else {\n clientY = (event as MouseEvent).clientY\n clientX = (event as MouseEvent).clientX\n }\n return {\n clientX,\n clientY,\n }\n}\n","import {\n computed,\n getCurrentInstance,\n onMounted,\n ref,\n shallowRef,\n watch,\n} from 'vue'\nimport { addUnit, getClientXY, getEventCode } from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport { EVENT_CODE } from '@element-plus/constants'\nimport { draggable } from '../utils/draggable'\n\nimport type { AlphaSliderProps } from '../props/slider'\n\ninterface UseSliderOptions {\n key: 'hue' | 'alpha'\n minValue: number\n maxValue: number\n}\n\nexport const useSlider = (\n props: AlphaSliderProps,\n { key, minValue, maxValue }: UseSliderOptions\n) => {\n const instance = getCurrentInstance()!\n\n const thumb = shallowRef()\n const bar = shallowRef()\n\n const currentValue = computed(() => props.color.get(key))\n\n function handleClick(event: MouseEvent | TouchEvent) {\n if (props.disabled) return\n const target = event.target\n\n if (target !== thumb.value) {\n handleDrag(event)\n }\n thumb.value?.focus()\n }\n\n function handleDrag(event: MouseEvent | TouchEvent) {\n if (!bar.value || !thumb.value || props.disabled) return\n\n const el = instance.vnode.el as HTMLElement\n const rect = el.getBoundingClientRect()\n const { clientX, clientY } = getClientXY(event)\n let value\n\n if (!props.vertical) {\n let left = clientX - rect.left\n left = Math.max(thumb.value.offsetWidth / 2, left)\n left = Math.min(left, rect.width - thumb.value.offsetWidth / 2)\n\n value = Math.round(\n ((left - thumb.value.offsetWidth / 2) /\n (rect.width - thumb.value.offsetWidth)) *\n maxValue\n )\n } else {\n let top = clientY - rect.top\n top = Math.max(thumb.value.offsetHeight / 2, top)\n top = Math.min(top, rect.height - thumb.value.offsetHeight / 2)\n\n value = Math.round(\n ((top - thumb.value.offsetHeight / 2) /\n (rect.height - thumb.value.offsetHeight)) *\n maxValue\n )\n }\n props.color.set(key, value)\n }\n\n function handleKeydown(event: KeyboardEvent) {\n if (props.disabled) return\n const { shiftKey } = event\n const code = getEventCode(event)\n const step = shiftKey ? 10 : 1\n // NOTE: The hue-slider is opposite in direction to the regular slider, so the hue slider has been reversed here.\n // But this is not the best way to handle it.\n const reverse = key === 'hue' ? -1 : 1\n let isPreventDefault = true\n\n switch (code) {\n case EVENT_CODE.left:\n case EVENT_CODE.down:\n incrementPosition(-step * reverse)\n break\n case EVENT_CODE.right:\n case EVENT_CODE.up:\n incrementPosition(step * reverse)\n break\n case EVENT_CODE.home:\n props.color.set(key, key === 'hue' ? maxValue : minValue)\n break\n case EVENT_CODE.end:\n props.color.set(key, key === 'hue' ? minValue : maxValue)\n break\n case EVENT_CODE.pageDown:\n incrementPosition(-4 * reverse)\n break\n case EVENT_CODE.pageUp:\n incrementPosition(4 * reverse)\n break\n default:\n isPreventDefault = false\n break\n }\n\n isPreventDefault && event.preventDefault()\n }\n\n function incrementPosition(step: number) {\n let next = currentValue.value + step\n next = next < minValue ? minValue : next > maxValue ? maxValue : next\n props.color.set(key, next)\n }\n\n return {\n thumb,\n bar,\n currentValue,\n handleDrag,\n handleClick,\n handleKeydown,\n }\n}\n\ninterface UseSliderDOMOptions\n extends Pick<\n ReturnType,\n 'bar' | 'thumb' | 'currentValue' | 'handleDrag'\n > {\n namespace: string\n maxValue: number\n getBackground?: () => string\n}\n\nexport const useSliderDOM = (\n props: AlphaSliderProps,\n {\n namespace,\n maxValue,\n bar,\n thumb,\n currentValue,\n handleDrag,\n getBackground,\n }: UseSliderDOMOptions\n) => {\n const instance = getCurrentInstance()!\n const ns = useNamespace(namespace)\n\n const thumbLeft = ref(0)\n const thumbTop = ref(0)\n const background = ref()\n\n function getThumbLeft() {\n if (!thumb.value) return 0\n\n if (props.vertical) return 0\n const el = instance.vnode.el\n const value = currentValue.value\n\n if (!el) return 0\n return Math.round(\n (value * (el.offsetWidth - thumb.value.offsetWidth / 2)) / maxValue\n )\n }\n\n function getThumbTop() {\n if (!thumb.value) return 0\n\n const el = instance.vnode.el\n if (!props.vertical) return 0\n const value = currentValue.value\n\n if (!el) return 0\n return Math.round(\n (value * (el.offsetHeight - thumb.value.offsetHeight / 2)) / maxValue\n )\n }\n\n function update() {\n thumbLeft.value = getThumbLeft()\n thumbTop.value = getThumbTop()\n background.value = getBackground?.()\n }\n\n onMounted(() => {\n if (!bar.value || !thumb.value) return\n\n const dragConfig = {\n drag: (event: MouseEvent | TouchEvent) => {\n handleDrag(event)\n },\n end: (event: MouseEvent | TouchEvent) => {\n handleDrag(event)\n },\n }\n\n draggable(bar.value, dragConfig)\n draggable(thumb.value, dragConfig)\n update()\n })\n\n watch(currentValue, () => update())\n\n watch(\n () => props.color.value,\n () => update()\n )\n\n const rootKls = computed(() => [\n ns.b(),\n ns.is('vertical', props.vertical),\n ns.is('disabled', props.disabled),\n ])\n const barKls = computed(() => ns.e('bar'))\n const thumbKls = computed(() => ns.e('thumb'))\n const barStyle = computed(() => ({ background: background.value }))\n const thumbStyle = computed(() => ({\n left: addUnit(thumbLeft.value),\n top: addUnit(thumbTop.value),\n }))\n\n return {\n rootKls,\n barKls,\n barStyle,\n thumbKls,\n thumbStyle,\n thumbLeft,\n thumbTop,\n update,\n }\n}\n","\n\n\n","\n\n\n","import { buildProps, definePropType } from '@element-plus/utils'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type Color from '../utils/color'\n\nexport const predefineProps = buildProps({\n colors: {\n type: definePropType(Array),\n required: true,\n },\n color: {\n type: definePropType(Object),\n required: true,\n },\n enableAlpha: {\n type: Boolean,\n required: true,\n },\n disabled: Boolean,\n} as const)\n\nexport type PredefineProps = ExtractPropTypes\nexport type PredefinePropsPublic = __ExtractPublicPropTypes<\n typeof predefineProps\n>\n","import { isNil } from 'lodash-unified'\nimport { buildProps, definePropType, isString } from '@element-plus/utils'\nimport { UPDATE_MODEL_EVENT } from '@element-plus/constants'\n\nimport type {\n ComputedRef,\n ExtractPropTypes,\n InjectionKey,\n __ExtractPublicPropTypes,\n} from 'vue'\nimport type ColorPickerPanel from './color-picker-panel.vue'\nimport type Color from './utils/color'\n\nexport const colorPickerPanelProps = buildProps({\n /**\n * @description binding value\n */\n modelValue: {\n type: definePropType(String),\n default: undefined,\n },\n /**\n * @description whether the color picker is bordered\n */\n border: {\n type: Boolean,\n default: true,\n },\n /**\n * @description whether to display the alpha slider\n */\n showAlpha: Boolean,\n /**\n * @description color format of v-model\n */\n colorFormat: String,\n /**\n * @description whether to disable the color picker\n */\n disabled: Boolean,\n /**\n * @description predefined color options\n */\n predefine: {\n type: definePropType(Array),\n },\n /**\n * @description whether to trigger form validation\n */\n validateEvent: {\n type: Boolean,\n default: true,\n },\n} as const)\nexport const colorPickerPanelEmits = {\n [UPDATE_MODEL_EVENT]: (val: string | null) => isString(val) || isNil(val),\n}\n\nexport type ColorPickerPanelProps = ExtractPropTypes<\n typeof colorPickerPanelProps\n>\nexport type ColorPickerPanelPropsPublic = __ExtractPublicPropTypes<\n typeof colorPickerPanelProps\n>\nexport type ColorPickerPanelEmits = typeof colorPickerPanelEmits\nexport type ColorPickerPanelInstance = InstanceType &\n unknown\n\nexport interface ColorPickerPanelContext {\n currentColor: ComputedRef\n}\n\nexport interface CommonColorContext {\n color: Color\n}\n\nexport const ROOT_COMMON_COLOR_INJECTION_KEY: InjectionKey =\n Symbol('colorCommonPickerKey')\nexport const colorPickerPanelContextKey: InjectionKey =\n Symbol('colorPickerPanelContextKey')\n","import { TinyColor } from '@ctrl/tinycolor'\nimport { hasOwn } from '@element-plus/utils'\n\nimport type { ColorFormats } from '@ctrl/tinycolor'\n\ninterface ColorOptions {\n enableAlpha: boolean\n format: string\n value?: string | null\n}\n\nexport default class Color {\n private _hue = 0\n private _saturation = 100\n private _value = 100\n private _alpha = 100\n private _tiny = new TinyColor()\n private _isValid = false\n public enableAlpha = false\n public format = ''\n public value = ''\n public selected?: boolean\n\n constructor(options: Partial = {}) {\n for (const option in options) {\n if (hasOwn(options, option)) {\n this[option] = options[option]\n }\n }\n if (options.value) {\n this.fromString(options.value)\n } else {\n this.doOnChange()\n }\n }\n\n set(prop: { [key: string]: any } | any, value?: number) {\n if (arguments.length === 1 && typeof prop === 'object') {\n for (const p in prop) {\n if (hasOwn(prop, p)) {\n this.set(p, prop[p])\n }\n }\n\n return\n }\n ;(this as any)[`_${prop}`] = value\n this._isValid = true\n this.doOnChange()\n }\n\n get(prop: string) {\n if (['hue', 'saturation', 'value', 'alpha'].includes(prop)) {\n return Math.round((this as any)[`_${prop}`])\n }\n return (this as any)[`_${prop}`]\n }\n\n toRgb() {\n return this._isValid ? this._tiny.toRgb() : { r: 255, g: 255, b: 255, a: 0 }\n }\n\n fromString(value: string) {\n const color = new TinyColor(value)\n this._isValid = color.isValid\n if (color.isValid) {\n const { h, s, v, a } = color.toHsv()\n this._hue = h\n this._saturation = s * 100\n this._value = v * 100\n this._alpha = a * 100\n } else {\n this._hue = 0\n this._saturation = 100\n this._value = 100\n this._alpha = 100\n }\n this.doOnChange()\n }\n\n clear() {\n this._isValid = false\n this.value = ''\n this._hue = 0\n this._saturation = 100\n this._value = 100\n this._alpha = 100\n }\n\n compare(color: this) {\n const compareColor = new TinyColor({\n h: color._hue,\n s: color._saturation / 100,\n v: color._value / 100,\n a: color._alpha / 100,\n })\n return this._tiny.equals(compareColor)\n }\n\n doOnChange() {\n const { _hue, _saturation, _value, _alpha, format, enableAlpha } = this\n let _format = format || (enableAlpha ? 'rgb' : 'hex')\n if (format === 'hex' && enableAlpha) {\n _format = 'hex8'\n }\n this._tiny = new TinyColor({\n h: _hue,\n s: _saturation / 100,\n v: _value / 100,\n a: _alpha / 100,\n })\n this.value = this._isValid\n ? this._tiny.toString(_format as ColorFormats)\n : ''\n }\n}\n","import { computed, inject, ref, watch, watchEffect } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport { PredefineProps } from '../props/predefine'\nimport { colorPickerPanelContextKey } from '../color-picker-panel'\nimport Color from '../utils/color'\n\nimport type { Ref } from 'vue'\n\nexport const usePredefine = (props: PredefineProps) => {\n const { currentColor } = inject(colorPickerPanelContextKey)!\n\n const rgbaColors = ref(parseColors(props.colors, props.color)) as Ref\n\n watch(\n () => currentColor.value,\n (val) => {\n const color = new Color({\n value: val,\n enableAlpha: props.enableAlpha,\n })\n\n rgbaColors.value.forEach((item) => {\n item.selected = color.compare(item)\n })\n }\n )\n\n watchEffect(() => {\n rgbaColors.value = parseColors(props.colors, props.color)\n })\n\n function handleSelect(index: number) {\n props.color.fromString(props.colors[index])\n }\n\n function parseColors(colors: string[], color: Color) {\n return colors.map((value) => {\n const c = new Color({\n value,\n enableAlpha: props.enableAlpha,\n })\n c.selected = c.compare(color)\n return c\n })\n }\n\n return {\n rgbaColors,\n handleSelect,\n }\n}\n\nexport const usePredefineDOM = (props: PredefineProps) => {\n const ns = useNamespace('color-predefine')\n\n const rootKls = computed(() => [ns.b(), ns.is('disabled', props.disabled)])\n\n const colorsKls = computed(() => ns.e('colors'))\n\n function colorSelectorKls(item: Color) {\n return [\n ns.e('color-selector'),\n ns.is('alpha', item.get('alpha') < 100),\n { selected: item.selected },\n ]\n }\n\n return {\n rootKls,\n colorsKls,\n colorSelectorKls,\n }\n}\n","\n\n\n","import { buildProps, definePropType } from '@element-plus/utils'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type Color from '../utils/color'\n\nexport const svPanelProps = buildProps({\n color: {\n type: definePropType(Object),\n required: true,\n },\n disabled: Boolean,\n} as const)\n\nexport type SvPanelProps = ExtractPropTypes\nexport type SvPanelPropsPublic = __ExtractPublicPropTypes\n","import { computed, getCurrentInstance, onMounted, ref, watch } from 'vue'\nimport { EVENT_CODE } from '@element-plus/constants'\nimport { useNamespace } from '@element-plus/hooks'\nimport { addUnit, getClientXY, getEventCode } from '@element-plus/utils'\nimport { draggable } from '../utils/draggable'\n\nimport type { SvPanelProps } from '../props/sv-panel'\n\nexport const useSvPanel = (props: SvPanelProps) => {\n const instance = getCurrentInstance()!\n\n const cursorRef = ref()\n const cursorTop = ref(0)\n const cursorLeft = ref(0)\n const background = ref('hsl(0, 100%, 50%)')\n\n const saturation = computed(() => props.color.get('saturation'))\n const brightness = computed(() => props.color.get('value'))\n const hue = computed(() => props.color.get('hue'))\n\n function handleClick(event: MouseEvent | TouchEvent) {\n if (props.disabled) return\n const target = event.target\n\n if (target !== cursorRef.value) {\n handleDrag(event)\n }\n cursorRef.value?.focus({ preventScroll: true })\n }\n\n function handleDrag(event: MouseEvent | TouchEvent) {\n if (props.disabled) return\n\n const el = instance.vnode.el!\n const rect = el.getBoundingClientRect()\n const { clientX, clientY } = getClientXY(event)\n\n let left = clientX - rect.left\n let top = clientY - rect.top\n left = Math.max(0, left)\n left = Math.min(left, rect.width)\n\n top = Math.max(0, top)\n top = Math.min(top, rect.height)\n\n cursorLeft.value = left\n cursorTop.value = top\n props.color.set({\n saturation: (left / rect.width) * 100,\n value: 100 - (top / rect.height) * 100,\n })\n }\n\n function handleKeydown(event: KeyboardEvent) {\n if (props.disabled) return\n const { shiftKey } = event\n const code = getEventCode(event)\n const step = shiftKey ? 10 : 1\n let isPreventDefault = true\n\n switch (code) {\n case EVENT_CODE.left:\n incrementSaturation(-step)\n break\n case EVENT_CODE.right:\n incrementSaturation(step)\n break\n case EVENT_CODE.up:\n incrementBrightness(step)\n break\n case EVENT_CODE.down:\n incrementBrightness(-step)\n break\n default:\n isPreventDefault = false\n break\n }\n\n isPreventDefault && event.preventDefault()\n }\n\n function incrementSaturation(step: number) {\n let next = saturation.value + step\n next = next < 0 ? 0 : next > 100 ? 100 : next\n props.color.set('saturation', next)\n }\n\n function incrementBrightness(step: number) {\n let next = brightness.value + step\n next = next < 0 ? 0 : next > 100 ? 100 : next\n props.color.set('value', next)\n }\n\n return {\n cursorRef,\n cursorTop,\n cursorLeft,\n background,\n saturation,\n brightness,\n hue,\n handleClick,\n handleDrag,\n handleKeydown,\n }\n}\n\nexport const useSvPanelDOM = (\n props: SvPanelProps,\n {\n cursorTop,\n cursorLeft,\n background,\n handleDrag,\n }: Pick<\n ReturnType,\n 'cursorTop' | 'cursorLeft' | 'background' | 'handleDrag'\n >\n) => {\n const instance = getCurrentInstance()!\n const ns = useNamespace('color-svpanel')\n\n function update() {\n const saturation = props.color.get('saturation')\n const brightness = props.color.get('value')\n\n const el = instance.vnode.el!\n const { clientWidth: width, clientHeight: height } = el\n\n cursorLeft.value = (saturation * width) / 100\n cursorTop.value = ((100 - brightness) * height) / 100\n\n background.value = `hsl(${props.color.get('hue')}, 100%, 50%)`\n }\n\n onMounted(() => {\n draggable(instance.vnode.el as HTMLElement, {\n drag: (event) => {\n handleDrag(event)\n },\n end: (event) => {\n handleDrag(event)\n },\n })\n\n update()\n })\n\n watch(\n [\n () => props.color.get('hue'),\n () => props.color.get('value'),\n () => props.color.value,\n ],\n () => update()\n )\n\n const rootKls = computed(() => ns.b())\n const cursorKls = computed(() => ns.e('cursor'))\n const rootStyle = computed(() => ({\n backgroundColor: background.value,\n }))\n const cursorStyle = computed(() => ({\n top: addUnit(cursorTop.value),\n left: addUnit(cursorLeft.value),\n }))\n\n return {\n rootKls,\n cursorKls,\n rootStyle,\n cursorStyle,\n update,\n }\n}\n","\n\n\n","import { reactive, watch } from 'vue'\nimport Color from '../utils/color'\nimport { UPDATE_MODEL_EVENT } from '@element-plus/constants'\n\ntype CommonColorProps = {\n modelValue?: string | null\n showAlpha: boolean\n colorFormat?: string\n}\ntype CommonColorEmits = (event: 'update:modelValue', ...args: any[]) => void\n\nexport const useCommonColor = <\n P extends CommonColorProps,\n E extends CommonColorEmits,\n>(\n props: P,\n emit: E\n) => {\n const color = reactive(\n new Color({\n enableAlpha: props.showAlpha,\n format: props.colorFormat || '',\n value: props.modelValue,\n })\n ) as Color\n\n watch(\n () => [props.colorFormat, props.showAlpha],\n () => {\n color.enableAlpha = props.showAlpha\n color.format = props.colorFormat || color.format\n color.doOnChange()\n emit(UPDATE_MODEL_EVENT, color.value)\n }\n )\n\n return {\n color,\n }\n}\n","\n\n\n","import { withInstall } from '@element-plus/utils'\nimport ColorPickerPanel from './src/color-picker-panel.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElColorPickerPanel: SFCWithInstall =\n withInstall(ColorPickerPanel)\nexport default ElColorPickerPanel\n\nexport * from './src/color-picker-panel'\n","import { isNil } from 'lodash-unified'\nimport { buildProps, definePropType, isString } from '@element-plus/utils'\nimport {\n useAriaProps,\n useEmptyValuesProps,\n useSizeProp,\n} from '@element-plus/hooks'\nimport { useTooltipContentProps } from '@element-plus/components/tooltip'\nimport { CHANGE_EVENT, UPDATE_MODEL_EVENT } from '@element-plus/constants'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type ColorPicker from './color-picker.vue'\n\nexport const colorPickerProps = buildProps({\n /**\n * @description when color-picker inactive and persistent is false, the color panel will be destroyed\n */\n persistent: {\n type: Boolean,\n default: true,\n },\n /**\n * @description binding value\n */\n modelValue: {\n type: definePropType(String),\n default: undefined,\n },\n /**\n * @description ColorPicker id\n */\n id: String,\n /**\n * @description whether to display the alpha slider\n */\n showAlpha: Boolean,\n /**\n * @description color format of v-model\n */\n colorFormat: String,\n /**\n * @description whether to disable the ColorPicker\n */\n disabled: {\n type: Boolean,\n default: undefined,\n },\n /**\n * @description size of ColorPicker\n */\n size: useSizeProp,\n /**\n * @description custom class name for ColorPicker's dropdown\n */\n popperClass: useTooltipContentProps.popperClass,\n /**\n * @description custom style for ColorPicker's dropdown\n */\n popperStyle: useTooltipContentProps.popperStyle,\n /**\n * @description ColorPicker tabindex\n */\n tabindex: {\n type: [String, Number],\n default: 0,\n },\n /**\n * @description whether color-picker popper is teleported to the body\n */\n teleported: useTooltipContentProps.teleported,\n /**\n * @description which color-picker panel appends to\n */\n appendTo: useTooltipContentProps.appendTo,\n /**\n * @description predefined color options\n */\n predefine: {\n type: definePropType(Array),\n },\n /**\n * @description whether to trigger form validation\n */\n validateEvent: {\n type: Boolean,\n default: true,\n },\n ...useEmptyValuesProps,\n ...useAriaProps(['ariaLabel']),\n} as const)\nexport const colorPickerEmits = {\n [UPDATE_MODEL_EVENT]: (val: string | null) => isString(val) || isNil(val),\n [CHANGE_EVENT]: (val: string | null) => isString(val) || isNil(val),\n activeChange: (val: string | null) => isString(val) || isNil(val),\n focus: (evt: FocusEvent) => evt instanceof FocusEvent,\n blur: (evt: FocusEvent) => evt instanceof FocusEvent,\n}\n\nexport type ColorPickerProps = ExtractPropTypes\nexport type ColorPickerPropsPublic = __ExtractPublicPropTypes<\n typeof colorPickerProps\n>\nexport type ColorPickerEmits = typeof colorPickerEmits\nexport type ColorPickerInstance = InstanceType & unknown\n","\n\n\n","import { withInstall } from '@element-plus/utils'\nimport ColorPicker from './src/color-picker.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElColorPicker: SFCWithInstall =\n withInstall(ColorPicker)\nexport default ElColorPicker\n\nexport * from './src/color-picker'\n","import { withInstall } from '@element-plus/utils'\nimport ConfigProvider from './src/config-provider'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElConfigProvider: SFCWithInstall =\n withInstall(ConfigProvider)\nexport default ElConfigProvider\n\nexport * from './src/config-provider'\nexport * from './src/config-provider-props'\nexport * from './src/constants'\nexport * from './src/hooks/use-global-config'\n","import { buildProps, definePropType } from '@element-plus/utils'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type {\n GetDisabledHours,\n GetDisabledMinutes,\n GetDisabledSeconds,\n} from '../common/props'\n\nexport const disabledTimeListsProps = buildProps({\n /**\n * @description To specify the array of hours that cannot be selected\n */\n disabledHours: {\n type: definePropType(Function),\n },\n /**\n * @description To specify the array of minutes that cannot be selected\n */\n disabledMinutes: {\n type: definePropType(Function),\n },\n /**\n * @description To specify the array of seconds that cannot be selected\n */\n disabledSeconds: {\n type: definePropType(Function),\n },\n} as const)\n\nexport type DisabledTimeListsProps = ExtractPropTypes<\n typeof disabledTimeListsProps\n>\nexport type DisabledTimeListsPropsPublic = __ExtractPublicPropTypes<\n typeof disabledTimeListsProps\n>\n\nexport const timePanelSharedProps = buildProps({\n visible: Boolean,\n actualVisible: {\n type: Boolean,\n default: undefined,\n },\n format: {\n type: String,\n default: '',\n },\n} as const)\n\nexport type TimePanelSharedProps = ExtractPropTypes\nexport type TimePanelSharedPropsPublic = __ExtractPublicPropTypes<\n typeof timePanelSharedProps\n>\n","import { buildProps, definePropType } from '@element-plus/utils'\nimport { disabledTimeListsProps } from '@element-plus/components/time-picker/src/props/shared'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type {\n ModelValueType,\n SingleOrRange,\n} from '@element-plus/components/time-picker'\nimport type { DatePickerType } from '../types'\n\nexport const datePickerPanelProps = buildProps({\n /**\n * @description optional, format of binding value. If not specified, the binding value will be a Date object\n */\n valueFormat: String,\n /**\n * @description optional, format of the date displayed in input's inner panel\n */\n dateFormat: String,\n /**\n * @description optional, format of the time displayed in input's inner panel\n */\n timeFormat: String,\n /**\n * @description whether picker is disabled\n */\n disabled: {\n type: Boolean,\n default: undefined,\n },\n /**\n * @description binding value, if it is an array, the length should be 2\n */\n modelValue: {\n type: definePropType([Date, Array, String, Number]),\n default: '',\n },\n /**\n * @description optional, default date of the calendar\n */\n defaultValue: {\n type: definePropType>([Date, Array]),\n },\n /**\n * @description optional, the time value to use when selecting date range\n */\n defaultTime: {\n type: definePropType>([Date, Array]),\n },\n /**\n * @description whether to pick a time range\n */\n isRange: Boolean,\n ...disabledTimeListsProps,\n /**\n * @description a function determining if a date is disabled with that date as its parameter. Should return a Boolean\n */\n disabledDate: {\n type: Function,\n },\n /**\n * @description set custom className\n */\n cellClassName: {\n type: Function,\n },\n /**\n * @description an object array to set shortcut options\n */\n shortcuts: {\n type: Array,\n default: () => [],\n },\n /**\n * @description whether to pick time using arrow buttons\n */\n arrowControl: Boolean,\n /**\n * @description unlink two date-panels in range-picker\n */\n unlinkPanels: Boolean,\n /**\n * @description whether to show the now button\n */\n showNow: {\n type: Boolean,\n default: true,\n },\n /**\n * @description whether to show the confirm button\n */\n showConfirm: Boolean,\n /**\n * @description whether to show footer\n */\n showFooter: Boolean,\n /**\n * @description whether to show the number of the calendar week\n */\n showWeekNumber: Boolean,\n /**\n * @description type of the picker\n */\n type: {\n type: definePropType(String),\n default: 'date',\n },\n /**\n * @description whether to show clear button in range mode\n */\n clearable: {\n type: Boolean,\n default: true,\n },\n /**\n * @description whether the date picker is bordered\n */\n border: {\n type: Boolean,\n default: true,\n },\n} as const)\n\nexport type DatePickerPanelProps = ExtractPropTypes\nexport type DatePickerPanelPropsPublic = __ExtractPublicPropTypes<\n typeof datePickerPanelProps\n>\n","import type { InjectionKey, SetupContext } from 'vue'\nimport type { UseNamespaceReturn } from '@element-plus/hooks'\n\ninterface DatePickerContext {\n slots: SetupContext['slots']\n pickerNs: UseNamespaceReturn\n}\n\nexport const ROOT_PICKER_INJECTION_KEY: InjectionKey =\n Symbol('rootPickerContextKey')\n\nexport const ROOT_PICKER_IS_DEFAULT_FORMAT_INJECTION_KEY = 'ElIsDefaultFormat'\n","import { buildProps, definePropType, isArray } from '@element-plus/utils'\nimport { datePickTypes } from '@element-plus/constants'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type { Dayjs } from 'dayjs'\nimport type { DatePickType } from '@element-plus/constants'\nimport type { DayOrDays } from '@element-plus/components/time-picker'\n\nconst selectionModes = [\n 'date',\n 'dates',\n 'year',\n 'years',\n 'month',\n 'months',\n 'week',\n 'range',\n]\n\nexport type RangeState = {\n endDate: null | Dayjs\n selecting: boolean\n}\n\nexport type DisabledDateType = (date: Date) => boolean\nexport type CellClassNameType = (date: Date) => string\n\nexport const datePickerSharedProps = buildProps({\n cellClassName: {\n type: definePropType(Function),\n },\n disabledDate: {\n type: definePropType(Function),\n },\n date: {\n type: definePropType(Object),\n required: true,\n },\n minDate: {\n type: definePropType(Object),\n },\n maxDate: {\n type: definePropType(Object),\n },\n parsedValue: {\n type: definePropType([Object, Array]),\n },\n rangeState: {\n type: definePropType(Object),\n default: () => ({\n endDate: null,\n selecting: false,\n }),\n },\n disabled: Boolean,\n} as const)\n\nexport const panelSharedProps = buildProps({\n type: {\n type: definePropType(String),\n required: true,\n values: datePickTypes,\n },\n dateFormat: String,\n timeFormat: String,\n showNow: {\n type: Boolean,\n default: true,\n },\n showConfirm: Boolean,\n showFooter: {\n type: Boolean,\n default: true,\n },\n showWeekNumber: Boolean,\n border: Boolean,\n disabled: Boolean,\n} as const)\n\nexport const panelRangeSharedProps = buildProps({\n unlinkPanels: Boolean,\n visible: {\n type: Boolean,\n default: true,\n },\n showConfirm: Boolean,\n showFooter: {\n type: Boolean,\n default: true,\n },\n border: Boolean,\n disabled: Boolean,\n parsedValue: {\n type: definePropType(Array),\n },\n} as const)\n\nexport const selectionModeWithDefault = (\n mode: (typeof selectionModes)[number]\n) => {\n return {\n type: String,\n values: selectionModes,\n default: mode,\n }\n}\n\nexport const rangePickerSharedEmits = {\n pick: (range: [Dayjs, Dayjs]) => isArray(range),\n}\n\nexport type RangePickerSharedEmits = typeof rangePickerSharedEmits\nexport type PanelRangeSharedProps = ExtractPropTypes<\n typeof panelRangeSharedProps\n>\nexport type PanelRangeSharedPropsPublic = __ExtractPublicPropTypes<\n typeof panelRangeSharedProps\n>\n","import { buildProps, definePropType } from '@element-plus/utils'\nimport { panelSharedProps } from './shared'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type { DayOrDays } from '@element-plus/components/time-picker'\n\nexport const panelDatePickProps = buildProps({\n ...panelSharedProps,\n parsedValue: {\n type: definePropType([Object, Array]),\n },\n visible: {\n type: Boolean,\n default: true,\n },\n format: {\n type: String,\n default: '',\n },\n} as const)\n\nexport type PanelDatePickProps = ExtractPropTypes\nexport type PanelDatePickPropsPublic = __ExtractPublicPropTypes<\n typeof panelDatePickProps\n>\n","import dayjs from 'dayjs'\nimport { isArray, isString } from '@element-plus/utils'\nimport { rangeArr } from '@element-plus/components/time-picker'\n\nimport type { ComputedRef } from 'vue'\nimport type { Dayjs } from 'dayjs'\nimport type { DateCell } from './types'\nimport type { DisabledDateType } from './props/shared'\n\ntype DayRange = [Dayjs | undefined, Dayjs | undefined]\n\nexport const isValidRange = (range: DayRange): boolean => {\n if (!isArray(range)) return false\n\n const [left, right] = range\n\n return (\n dayjs.isDayjs(left) &&\n dayjs.isDayjs(right) &&\n dayjs(left).isValid() &&\n dayjs(right).isValid() &&\n left.isSameOrBefore(right)\n )\n}\n\ntype GetDefaultValueParams = {\n lang: string\n step?: number\n unit: 'month' | 'year'\n unlinkPanels: boolean\n}\n\nexport type DefaultValue = [Date, Date] | Date | undefined\n\nexport const getDefaultValue = (\n defaultValue: DefaultValue,\n { lang, step = 1, unit, unlinkPanels }: GetDefaultValueParams\n) => {\n let start: Dayjs\n\n if (isArray(defaultValue)) {\n let [left, right] = defaultValue.map((d) => dayjs(d).locale(lang))\n if (!unlinkPanels) {\n right = left.add(step, unit)\n }\n return [left, right]\n } else if (defaultValue) {\n start = dayjs(defaultValue)\n } else {\n start = dayjs()\n }\n start = start.locale(lang)\n return [start, start.add(step, unit)]\n}\n\ntype Dimension = {\n row: number\n column: number\n}\n\ntype BuildPickerTableMetadata = {\n startDate?: Dayjs | null\n unit: 'month' | 'day'\n columnIndexOffset: number\n now: Dayjs\n nextEndDate: Dayjs | null\n relativeDateGetter: (index: number) => Dayjs\n setCellMetadata?: (\n cell: DateCell,\n dimension: { rowIndex: number; columnIndex: number }\n ) => void\n setRowMetadata?: (row: DateCell[]) => void\n}\n\nexport const buildPickerTable = (\n dimension: Dimension,\n rows: DateCell[][],\n {\n columnIndexOffset,\n startDate,\n nextEndDate,\n now,\n unit,\n relativeDateGetter,\n setCellMetadata,\n setRowMetadata,\n }: BuildPickerTableMetadata\n) => {\n for (let rowIndex = 0; rowIndex < dimension.row; rowIndex++) {\n const row = rows[rowIndex]\n for (let columnIndex = 0; columnIndex < dimension.column; columnIndex++) {\n let cell = row[columnIndex + columnIndexOffset]\n if (!cell) {\n cell = {\n row: rowIndex,\n column: columnIndex,\n type: 'normal',\n inRange: false,\n start: false,\n end: false,\n }\n }\n const index = rowIndex * dimension.column + columnIndex\n const nextStartDate = relativeDateGetter(index)\n cell.dayjs = nextStartDate\n cell.date = nextStartDate.toDate()\n cell.timestamp = nextStartDate.valueOf()\n cell.type = 'normal'\n\n cell.inRange =\n !!(\n startDate &&\n nextStartDate.isSameOrAfter(startDate, unit) &&\n nextEndDate &&\n nextStartDate.isSameOrBefore(nextEndDate, unit)\n ) ||\n !!(\n startDate &&\n nextStartDate.isSameOrBefore(startDate, unit) &&\n nextEndDate &&\n nextStartDate.isSameOrAfter(nextEndDate, unit)\n )\n\n if (startDate?.isSameOrAfter(nextEndDate)) {\n cell.start = !!nextEndDate && nextStartDate.isSame(nextEndDate, unit)\n cell.end = startDate && nextStartDate.isSame(startDate, unit)\n } else {\n cell.start = !!startDate && nextStartDate.isSame(startDate, unit)\n cell.end = !!nextEndDate && nextStartDate.isSame(nextEndDate, unit)\n }\n\n const isToday = nextStartDate.isSame(now, unit)\n\n if (isToday) {\n cell.type = 'today'\n }\n setCellMetadata?.(cell, { rowIndex, columnIndex })\n row[columnIndex + columnIndexOffset] = cell\n }\n setRowMetadata?.(row)\n }\n}\n\nexport const datesInMonth = (\n date: Dayjs,\n year: number,\n month: number,\n lang: string\n) => {\n const firstDay = dayjs()\n .locale(lang)\n .startOf('month')\n .month(month)\n .year(year)\n .hour(date.hour())\n .minute(date.minute())\n .second(date.second())\n\n const numOfDays = firstDay.daysInMonth()\n return rangeArr(numOfDays).map((n) => firstDay.add(n, 'day').toDate())\n}\n\nexport const getValidDateOfMonth = (\n date: Dayjs,\n year: number,\n month: number,\n lang: string,\n disabledDate?: DisabledDateType\n) => {\n const _value = dayjs()\n .year(year)\n .month(month)\n .startOf('month')\n .hour(date.hour())\n .minute(date.minute())\n .second(date.second())\n const _date = datesInMonth(date, year, month, lang).find((date) => {\n return !disabledDate?.(date)\n })\n if (_date) {\n return dayjs(_date).locale(lang)\n }\n return _value.locale(lang)\n}\n\nexport const getValidDateOfYear = (\n value: Dayjs,\n lang: string,\n disabledDate?: DisabledDateType\n) => {\n const year = value.year()\n if (!disabledDate?.(value.toDate())) {\n return value.locale(lang)\n }\n const month = value.month()\n if (!datesInMonth(value, year, month, lang).every(disabledDate)) {\n return getValidDateOfMonth(value, year, month, lang, disabledDate)\n }\n for (let i = 0; i < 12; i++) {\n if (!datesInMonth(value, year, i, lang).every(disabledDate)) {\n return getValidDateOfMonth(value, year, i, lang, disabledDate)\n }\n }\n return value\n}\n\nexport const correctlyParseUserInput = (\n value: string | Dayjs | Dayjs[],\n format: string,\n lang: string,\n defaultFormat: ComputedRef | undefined\n): Dayjs | Dayjs[] => {\n if (isArray(value)) {\n return value.map(\n (v) => correctlyParseUserInput(v, format, lang, defaultFormat) as Dayjs\n )\n }\n if (isString(value)) {\n const dayjsValue = defaultFormat?.value\n ? dayjs(value)\n : dayjs(value, format)\n if (!dayjsValue.isValid()) {\n // return directly if not valid\n return dayjsValue\n }\n }\n return dayjs(value, format).locale(lang)\n}\n","import { buildProps } from '@element-plus/utils'\nimport { datePickerSharedProps, selectionModeWithDefault } from './shared'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type { Dayjs } from 'dayjs'\n\nexport const basicDateTableProps = buildProps({\n ...datePickerSharedProps,\n showWeekNumber: Boolean,\n selectionMode: selectionModeWithDefault('date'),\n} as const)\n\nexport const basicDateTableEmits = ['changerange', 'pick', 'select']\n\nexport type BasicDateTableProps = ExtractPropTypes\nexport type BasicDateTablePropsPublic = __ExtractPublicPropTypes<\n typeof basicDateTableProps\n>\nexport type BasicDateTableEmits = typeof basicDateTableEmits\n\nexport type RangePickerEmits = { minDate: Dayjs; maxDate: null }\nexport type DatePickerEmits = Dayjs\nexport type DatesPickerEmits = Dayjs[]\nexport type MonthsPickerEmits = Dayjs[]\nexport type YearsPickerEmits = Dayjs[]\nexport type WeekPickerEmits = {\n year: number\n week: number\n value: string\n date: Dayjs\n}\n\nexport type DateTableEmits =\n | RangePickerEmits\n | DatePickerEmits\n | DatesPickerEmits\n | WeekPickerEmits\n","import { computed, nextTick, ref, unref, watch } from 'vue'\nimport dayjs from 'dayjs'\nimport { flatten } from 'lodash-unified'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport { castArray, isArray } from '@element-plus/utils'\nimport { buildPickerTable } from '../utils'\n\nimport type { SetupContext } from 'vue'\nimport type { Dayjs } from 'dayjs'\nimport type { DateCell } from '../types'\nimport type {\n BasicDateTableEmits,\n BasicDateTableProps,\n} from '../props/basic-date-table'\n\nconst isNormalDay = (type = '') => {\n return ['normal', 'today'].includes(type)\n}\n\nexport const useBasicDateTable = (\n props: BasicDateTableProps,\n emit: SetupContext['emit']\n) => {\n const { lang } = useLocale()\n const tbodyRef = ref()\n const currentCellRef = ref()\n // data\n const lastRow = ref()\n const lastColumn = ref()\n const tableRows = ref([[], [], [], [], [], []])\n\n let focusWithClick = false\n\n // todo better way to get Day.js locale object\n const firstDayOfWeek = (props.date as any).$locale().weekStart || 7\n const WEEKS_CONSTANT = props.date\n .locale('en')\n .localeData()\n .weekdaysShort()\n .map((_) => _.toLowerCase())\n\n const offsetDay = computed(() => {\n // Sunday 7(0), cal the left and right offset days, 3217654, such as Monday is -1, the is to adjust the position of the first two rows of dates\n return firstDayOfWeek > 3 ? 7 - firstDayOfWeek : -firstDayOfWeek\n })\n\n const startDate = computed(() => {\n const startDayOfMonth = props.date.startOf('month')\n return startDayOfMonth.subtract(startDayOfMonth.day() || 7, 'day')\n })\n\n const WEEKS = computed(() => {\n return WEEKS_CONSTANT.concat(WEEKS_CONSTANT).slice(\n firstDayOfWeek,\n firstDayOfWeek + 7\n )\n })\n\n const hasCurrent = computed(() => {\n return flatten(unref(rows)).some((row) => {\n return row.isCurrent\n })\n })\n\n const days = computed(() => {\n const startOfMonth = props.date.startOf('month')\n const startOfMonthDay = startOfMonth.day() || 7 // day of first day\n const dateCountOfMonth = startOfMonth.daysInMonth()\n\n const dateCountOfLastMonth = startOfMonth.subtract(1, 'month').daysInMonth()\n\n return {\n startOfMonthDay,\n dateCountOfMonth,\n dateCountOfLastMonth,\n }\n })\n\n const selectedDate = computed(() => {\n return props.selectionMode === 'dates' ? castArray(props.parsedValue!) : []\n })\n\n // Return value indicates should the counter be incremented\n type CellCoordinate = { columnIndex: number; rowIndex: number }\n type CellMeta = CellCoordinate & {\n count: number\n }\n const setDateText = (\n cell: DateCell,\n { count, rowIndex, columnIndex }: CellMeta\n ): boolean => {\n const { startOfMonthDay, dateCountOfMonth, dateCountOfLastMonth } =\n unref(days)\n const offset = unref(offsetDay)\n if (rowIndex >= 0 && rowIndex <= 1) {\n const numberOfDaysFromPreviousMonth =\n startOfMonthDay + offset < 0\n ? 7 + startOfMonthDay + offset\n : startOfMonthDay + offset\n\n if (columnIndex + rowIndex * 7 >= numberOfDaysFromPreviousMonth) {\n cell.text = count\n return true\n } else {\n cell.text =\n dateCountOfLastMonth -\n (numberOfDaysFromPreviousMonth - (columnIndex % 7)) +\n 1 +\n rowIndex * 7\n cell.type = 'prev-month'\n }\n } else {\n if (count <= dateCountOfMonth) {\n cell.text = count\n } else {\n cell.text = count - dateCountOfMonth\n cell.type = 'next-month'\n }\n return true\n }\n return false\n }\n\n const setCellMetadata = (\n cell: DateCell,\n { columnIndex, rowIndex }: CellCoordinate,\n count: number\n ) => {\n const { disabledDate, cellClassName } = props\n const _selectedDate = unref(selectedDate)\n const shouldIncrement = setDateText(cell, { count, rowIndex, columnIndex })\n\n const cellDate = cell.dayjs!.toDate()\n cell.selected = _selectedDate.find((d) => d.isSame(cell.dayjs, 'day'))\n cell.isSelected = !!cell.selected\n cell.isCurrent = isCurrent(cell)\n cell.disabled = disabledDate?.(cellDate)\n cell.customClass = cellClassName?.(cellDate)\n return shouldIncrement\n }\n\n const setRowMetadata = (row: DateCell[]) => {\n if (props.selectionMode === 'week') {\n const [start, end] = props.showWeekNumber ? [1, 7] : [0, 6]\n const isActive = isWeekActive(row[start + 1])\n row[start].inRange = isActive\n row[start].start = isActive\n row[end].inRange = isActive\n row[end].end = isActive\n }\n }\n\n const rows = computed(() => {\n const { minDate, maxDate, rangeState, showWeekNumber } = props\n\n const offset = unref(offsetDay)\n const rows_ = unref(tableRows)\n const dateUnit = 'day'\n let count = 1\n\n buildPickerTable({ row: 6, column: 7 }, rows_, {\n startDate: minDate,\n columnIndexOffset: showWeekNumber ? 1 : 0,\n nextEndDate:\n rangeState.endDate ||\n maxDate ||\n (rangeState.selecting && minDate) ||\n null,\n now: dayjs().locale(unref(lang)).startOf(dateUnit),\n unit: dateUnit,\n relativeDateGetter: (idx: number) =>\n unref(startDate).add(idx - offset, dateUnit),\n setCellMetadata: (...args) => {\n if (setCellMetadata(...args, count)) {\n count += 1\n }\n },\n\n setRowMetadata,\n })\n\n if (showWeekNumber) {\n for (let rowIndex = 0; rowIndex < 6; rowIndex++) {\n if (rows_[rowIndex][1].dayjs) {\n rows_[rowIndex][0] = {\n type: 'week',\n text: rows_[rowIndex][1].dayjs!.week(),\n }\n }\n }\n }\n\n return rows_\n })\n\n watch(\n () => props.date,\n async () => {\n if (unref(tbodyRef)?.contains(document.activeElement)) {\n await nextTick()\n await focus()\n // currentCellRef.value?.focus()\n }\n }\n )\n\n const focus = async () => unref(currentCellRef)?.focus()\n\n const isCurrent = (cell: DateCell): boolean => {\n return (\n props.selectionMode === 'date' &&\n isNormalDay(cell.type) &&\n cellMatchesDate(cell, props.parsedValue as Dayjs)\n )\n }\n\n const cellMatchesDate = (cell: DateCell, date: Dayjs) => {\n if (!date) return false\n return dayjs(date)\n .locale(unref(lang))\n .isSame(props.date.date(Number(cell.text)), 'day')\n }\n\n const getDateOfCell = (row: number, column: number) => {\n const offsetFromStart =\n row * 7 + (column - (props.showWeekNumber ? 1 : 0)) - unref(offsetDay)\n return unref(startDate).add(offsetFromStart, 'day')\n }\n\n const handleMouseMove = (event: MouseEvent) => {\n if (!props.rangeState.selecting) return\n\n let target = event.target as HTMLElement\n if (target.tagName === 'SPAN') {\n target = target.parentNode?.parentNode as HTMLElement\n }\n if (target.tagName === 'DIV') {\n target = target.parentNode as HTMLElement\n }\n if (target.tagName !== 'TD') return\n\n const row = (target.parentNode as HTMLTableRowElement).rowIndex - 1\n const column = (target as HTMLTableCellElement).cellIndex\n\n // can not select disabled date\n if (unref(rows)[row][column].disabled) return\n\n // only update rangeState when mouse moves to a new cell\n // this avoids frequent Date object creation and improves performance\n if (row !== unref(lastRow) || column !== unref(lastColumn)) {\n lastRow.value = row\n lastColumn.value = column\n emit('changerange', {\n selecting: true,\n endDate: getDateOfCell(row, column),\n })\n }\n }\n\n const isSelectedCell = (cell: DateCell) => {\n return (\n (!unref(hasCurrent) && cell?.text === 1 && isNormalDay(cell.type)) ||\n cell.isCurrent\n )\n }\n\n const handleFocus = (event: FocusEvent) => {\n if (focusWithClick || unref(hasCurrent) || props.selectionMode !== 'date')\n return\n handlePickDate(event, true)\n }\n\n const handleMouseDown = (event: MouseEvent) => {\n const target = (event.target as HTMLElement).closest('td')\n if (!target) return\n focusWithClick = true\n }\n\n const handleMouseUp = (event: MouseEvent) => {\n const target = (event.target as HTMLElement).closest('td')\n if (!target) return\n focusWithClick = false\n }\n\n const handleRangePick = (newDate: Dayjs) => {\n if (!props.rangeState.selecting || !props.minDate) {\n emit('pick', { minDate: newDate, maxDate: null })\n emit('select', true)\n } else {\n if (newDate >= props.minDate) {\n emit('pick', { minDate: props.minDate, maxDate: newDate })\n } else {\n emit('pick', { minDate: newDate, maxDate: props.minDate })\n }\n emit('select', false)\n }\n }\n\n const handleWeekPick = (newDate: Dayjs) => {\n const weekNumber = newDate.week()\n const value = `${newDate.year()}w${weekNumber}`\n emit('pick', {\n year: newDate.year(),\n week: weekNumber,\n value,\n date: newDate.startOf('week'),\n })\n }\n\n const handleDatesPick = (newDate: Dayjs, selected: boolean) => {\n const newValue = selected\n ? castArray(props.parsedValue).filter(\n (d) => d?.valueOf() !== newDate.valueOf()\n )\n : castArray(props.parsedValue).concat([newDate])\n emit('pick', newValue)\n }\n\n const handlePickDate = (\n event: FocusEvent | MouseEvent,\n isKeyboardMovement = false\n ) => {\n if (props.disabled) return\n const target = (event.target as HTMLElement).closest('td')\n\n if (!target) return\n\n const row = (target.parentNode as HTMLTableRowElement).rowIndex - 1\n const column = (target as HTMLTableCellElement).cellIndex\n const cell = unref(rows)[row][column]\n\n if (cell.disabled || cell.type === 'week') return\n\n const newDate = getDateOfCell(row, column)\n\n switch (props.selectionMode) {\n case 'range': {\n handleRangePick(newDate)\n break\n }\n case 'date': {\n emit('pick', newDate, isKeyboardMovement)\n break\n }\n case 'week': {\n handleWeekPick(newDate)\n break\n }\n case 'dates': {\n handleDatesPick(newDate, !!cell.selected)\n break\n }\n default: {\n break\n }\n }\n }\n\n const isWeekActive = (cell: DateCell) => {\n if (props.selectionMode !== 'week') return false\n let newDate = props.date.startOf('day')\n\n if (cell.type === 'prev-month') {\n newDate = newDate.subtract(1, 'month')\n }\n\n if (cell.type === 'next-month') {\n newDate = newDate.add(1, 'month')\n }\n\n newDate = newDate.date(Number.parseInt(cell.text as any, 10))\n\n if (props.parsedValue && !isArray(props.parsedValue)) {\n const dayOffset = ((props.parsedValue.day() - firstDayOfWeek + 7) % 7) - 1\n const weekDate = props.parsedValue.subtract(dayOffset, 'day')\n return weekDate.isSame(newDate, 'day')\n }\n return false\n }\n\n return {\n WEEKS,\n rows,\n tbodyRef,\n currentCellRef,\n\n // cellMatchesDate,\n // getDateOfCell,\n focus,\n isCurrent,\n isWeekActive,\n isSelectedCell,\n\n handlePickDate,\n handleMouseUp,\n handleMouseDown,\n handleMouseMove,\n handleFocus,\n }\n}\n\nexport const useBasicDateTableDOM = (\n props: BasicDateTableProps,\n {\n isCurrent,\n isWeekActive,\n }: Pick, 'isCurrent' | 'isWeekActive'>\n) => {\n const ns = useNamespace('date-table')\n const { t } = useLocale()\n\n const tableKls = computed(() => [\n ns.b(),\n ns.is('week-mode', props.selectionMode === 'week' && !props.disabled),\n ])\n\n const tableLabel = computed(() => t('el.datepicker.dateTablePrompt'))\n\n const getCellClasses = (cell: DateCell) => {\n const classes: string[] = []\n if (isNormalDay(cell.type) && !cell.disabled) {\n classes.push('available')\n if (cell.type === 'today') {\n classes.push('today')\n }\n } else {\n classes.push(cell.type!)\n }\n\n if (isCurrent(cell)) {\n classes.push('current')\n }\n\n if (\n cell.inRange &&\n (isNormalDay(cell.type) || props.selectionMode === 'week')\n ) {\n classes.push('in-range')\n\n if (cell.start) {\n classes.push('start-date')\n }\n\n if (cell.end) {\n classes.push('end-date')\n }\n }\n\n if (cell.disabled || props.disabled) {\n classes.push('disabled')\n }\n\n if (cell.selected) {\n classes.push('selected')\n }\n\n if (cell.customClass) {\n classes.push(cell.customClass)\n }\n\n return classes.join(' ')\n }\n\n const getRowKls = (cell: DateCell) => [\n ns.e('row'),\n { current: isWeekActive(cell) },\n ]\n\n return {\n tableKls,\n tableLabel,\n weekHeaderClass: ns.e('week-header'),\n\n getCellClasses,\n getRowKls,\n t,\n }\n}\n","import { buildProps, definePropType } from '@element-plus/utils'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type { DateCell } from '../types'\n\nexport const basicCellProps = buildProps({\n cell: {\n type: definePropType(Object),\n },\n} as const)\n\nexport type BasicCellProps = ExtractPropTypes\nexport type BasicCellPropsPublic = __ExtractPublicPropTypes<\n typeof basicCellProps\n>\n","import { defineComponent, inject, renderSlot } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport { ROOT_PICKER_INJECTION_KEY } from '../constants'\nimport { basicCellProps } from '../props/basic-cell'\n\nexport default defineComponent({\n name: 'ElDatePickerCell',\n props: basicCellProps,\n setup(props) {\n const ns = useNamespace('date-table-cell')\n const { slots } = inject(ROOT_PICKER_INJECTION_KEY)!\n return () => {\n const { cell } = props\n\n return renderSlot(slots, 'default', { ...cell }, () => [\n

\n {cell?.renderText ?? cell?.text}\n
,\n ])\n }\n },\n})\n","\n\n\n","import { buildProps } from '@element-plus/utils'\nimport { datePickerSharedProps, selectionModeWithDefault } from './shared'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\n\nexport const basicMonthTableProps = buildProps({\n ...datePickerSharedProps,\n selectionMode: selectionModeWithDefault('month'),\n})\n\nexport type BasicMonthTableProps = ExtractPropTypes\nexport type BasicMonthTablePropsPublic = __ExtractPublicPropTypes<\n typeof basicMonthTableProps\n>\n","\n\n\n","import { buildProps } from '@element-plus/utils'\nimport { datePickerSharedProps, selectionModeWithDefault } from './shared'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\n\nexport const basicYearTableProps = buildProps({\n ...datePickerSharedProps,\n selectionMode: selectionModeWithDefault('year'),\n} as const)\n\nexport type BasicYearTableProps = ExtractPropTypes\nexport type BasicYearTablePropsPublic = __ExtractPublicPropTypes<\n typeof basicYearTableProps\n>\n","\n\n\n","import type { InjectionKey } from 'vue'\nimport type { CommonPickerContext } from './composables/use-common-picker'\n\nexport const timeUnits = ['hours', 'minutes', 'seconds'] as const\n\nexport const PICKER_BASE_INJECTION_KEY = 'EP_PICKER_BASE'\n\nexport const PICKER_POPPER_OPTIONS_INJECTION_KEY = 'ElPopperOptions'\n\nexport const ROOT_COMMON_PICKER_INJECTION_KEY: InjectionKey =\n Symbol('commonPickerContextKey')\n\nexport const DEFAULT_FORMATS_TIME = 'HH:mm:ss'\n\nexport const DEFAULT_FORMATS_DATE = 'YYYY-MM-DD'\n\nexport const DEFAULT_FORMATS_DATEPICKER = {\n date: DEFAULT_FORMATS_DATE,\n dates: DEFAULT_FORMATS_DATE,\n week: 'gggg[w]ww',\n year: 'YYYY',\n years: 'YYYY',\n month: 'YYYY-MM',\n months: 'YYYY-MM',\n datetime: `${DEFAULT_FORMATS_DATE} ${DEFAULT_FORMATS_TIME}`,\n monthrange: 'YYYY-MM',\n yearrange: 'YYYY',\n daterange: DEFAULT_FORMATS_DATE,\n datetimerange: `${DEFAULT_FORMATS_DATE} ${DEFAULT_FORMATS_TIME}`,\n}\n\nexport type TimeUnit = (typeof timeUnits)[number]\n","import { buildProps, definePropType } from '@element-plus/utils'\nimport { timePanelSharedProps } from './shared'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type { Dayjs } from 'dayjs'\n\nexport const panelTimePickerProps = buildProps({\n ...timePanelSharedProps,\n datetimeRole: String,\n parsedValue: {\n type: definePropType(Object),\n },\n} as const)\n\nexport type PanelTimePickerProps = ExtractPropTypes\nexport type PanelTimePickerPropsPublic = __ExtractPublicPropTypes<\n typeof panelTimePickerProps\n>\n","import type { Dayjs } from 'dayjs'\nimport type {\n GetDisabledHours,\n GetDisabledMinutes,\n GetDisabledSeconds,\n} from '../common/props'\n\ntype UseTimePanelProps = {\n getAvailableHours: GetDisabledHours\n getAvailableMinutes: GetDisabledMinutes\n getAvailableSeconds: GetDisabledSeconds\n}\n\nexport const useTimePanel = ({\n getAvailableHours,\n getAvailableMinutes,\n getAvailableSeconds,\n}: UseTimePanelProps) => {\n const getAvailableTime = (\n date: Dayjs,\n role: string,\n first: boolean,\n compareDate?: Dayjs\n ) => {\n const availableTimeGetters = {\n hour: getAvailableHours,\n minute: getAvailableMinutes,\n second: getAvailableSeconds,\n } as const\n let result = date\n ;(['hour', 'minute', 'second'] as const).forEach((type) => {\n if (availableTimeGetters[type]) {\n let availableTimeSlots: number[]\n const method = availableTimeGetters[type]\n switch (type) {\n case 'minute': {\n availableTimeSlots = (method as typeof getAvailableMinutes)(\n result.hour(),\n role,\n compareDate\n )\n break\n }\n case 'second': {\n availableTimeSlots = (method as typeof getAvailableSeconds)(\n result.hour(),\n result.minute(),\n role,\n compareDate\n )\n break\n }\n default: {\n availableTimeSlots = (method as typeof getAvailableHours)(\n role,\n compareDate\n )\n break\n }\n }\n\n if (\n availableTimeSlots?.length &&\n !availableTimeSlots.includes(result[type]())\n ) {\n const pos = first ? 0 : availableTimeSlots.length - 1\n result = result[type](availableTimeSlots[pos]) as unknown as Dayjs\n }\n }\n })\n return result\n }\n\n const timePickerOptions: Record void> = {}\n\n const onSetOption = ([key, val]: [string, (...args: any[]) => void]) => {\n timePickerOptions[key] = val\n }\n\n return {\n timePickerOptions,\n\n getAvailableTime,\n onSetOption,\n }\n}\n","import { ref, watch } from 'vue'\nimport { makeList } from '../utils'\n\nimport type { Dayjs } from 'dayjs'\nimport type {\n GetDisabledHours,\n GetDisabledMinutes,\n GetDisabledSeconds,\n} from '../common/props'\n\nconst makeAvailableArr = (disabledList: boolean[]): number[] => {\n const trueOrNumber = (isDisabled: boolean, index: number) =>\n isDisabled || index\n\n const getNumber = (predicate: number | true): predicate is number =>\n predicate !== true\n\n return disabledList.map(trueOrNumber).filter(getNumber)\n}\n\nexport const getTimeLists = (\n disabledHours?: GetDisabledHours,\n disabledMinutes?: GetDisabledMinutes,\n disabledSeconds?: GetDisabledSeconds\n) => {\n const getHoursList = (role: string, compare?: Dayjs) => {\n return makeList(24, disabledHours && (() => disabledHours?.(role, compare)))\n }\n\n const getMinutesList = (hour: number, role: string, compare?: Dayjs) => {\n return makeList(\n 60,\n disabledMinutes && (() => disabledMinutes?.(hour, role, compare))\n )\n }\n\n const getSecondsList = (\n hour: number,\n minute: number,\n role: string,\n compare?: Dayjs\n ) => {\n return makeList(\n 60,\n disabledSeconds && (() => disabledSeconds?.(hour, minute, role, compare))\n )\n }\n\n return {\n getHoursList,\n getMinutesList,\n getSecondsList,\n }\n}\n\nexport const buildAvailableTimeSlotGetter = (\n disabledHours: GetDisabledHours,\n disabledMinutes: GetDisabledMinutes,\n disabledSeconds: GetDisabledSeconds\n) => {\n const { getHoursList, getMinutesList, getSecondsList } = getTimeLists(\n disabledHours,\n disabledMinutes,\n disabledSeconds\n )\n\n const getAvailableHours: GetDisabledHours = (role, compare?) => {\n return makeAvailableArr(getHoursList(role, compare))\n }\n\n const getAvailableMinutes: GetDisabledMinutes = (hour, role, compare?) => {\n return makeAvailableArr(getMinutesList(hour, role, compare))\n }\n\n const getAvailableSeconds: GetDisabledSeconds = (\n hour,\n minute,\n role,\n compare?\n ) => {\n return makeAvailableArr(getSecondsList(hour, minute, role, compare))\n }\n\n return {\n getAvailableHours,\n getAvailableMinutes,\n getAvailableSeconds,\n }\n}\n\nexport const useOldValue = (props: {\n parsedValue?: string | Dayjs | Dayjs[]\n visible: boolean\n}) => {\n const oldValue = ref(props.parsedValue)\n\n watch(\n () => props.visible,\n (val) => {\n if (!val) {\n oldValue.value = props.parsedValue\n }\n }\n )\n\n return oldValue\n}\n","import { buildProps, definePropType } from '@element-plus/utils'\nimport { disabledTimeListsProps } from '../props/shared'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type { Dayjs } from 'dayjs'\n\nexport const basicTimeSpinnerProps = buildProps({\n role: {\n type: String,\n required: true,\n },\n spinnerDate: {\n type: definePropType(Object),\n required: true,\n },\n showSeconds: {\n type: Boolean,\n default: true,\n },\n arrowControl: Boolean,\n amPmMode: {\n // 'a': am/pm; 'A': AM/PM\n type: definePropType<'a' | 'A' | ''>(String),\n default: '',\n },\n ...disabledTimeListsProps,\n} as const)\n\nexport type BasicTimeSpinnerProps = ExtractPropTypes<\n typeof basicTimeSpinnerProps\n>\nexport type BasicTimeSpinnerPropsPublic = __ExtractPublicPropTypes<\n typeof basicTimeSpinnerProps\n>\n","\n\n\n","\n\n\n","\n\n\n","import { buildProps } from '@element-plus/utils'\nimport { panelRangeSharedProps, panelSharedProps } from './shared'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\n\nexport const panelDateRangeProps = buildProps({\n ...panelSharedProps,\n ...panelRangeSharedProps,\n} as const)\n\nexport type PanelDateRangeProps = ExtractPropTypes\nexport type PanelDateRangePropsPublic = __ExtractPublicPropTypes<\n typeof panelDateRangeProps\n>\n","import { getCurrentInstance, useAttrs, useSlots } from 'vue'\nimport dayjs from 'dayjs'\nimport { isFunction } from '@element-plus/utils'\n\nimport type { SetupContext } from 'vue'\nimport type { useLocale } from '@element-plus/hooks'\nimport type { RangePickerSharedEmits } from '../props/shared'\n\n// FIXME: extract this to `date-picker.ts`\nexport type Shortcut = {\n text: string\n value: [Date, Date] | (() => [Date, Date])\n onClick?: (ctx: Omit, 'expose'>) => void\n}\n\nexport const useShortcut = (lang: ReturnType['lang']) => {\n const { emit } = getCurrentInstance()!\n const attrs = useAttrs()\n const slots = useSlots()\n\n const handleShortcutClick = (shortcut: Shortcut) => {\n const shortcutValues = isFunction(shortcut.value)\n ? shortcut.value()\n : shortcut.value\n\n if (shortcutValues) {\n emit('pick', [\n dayjs(shortcutValues[0]).locale(lang.value),\n dayjs(shortcutValues[1]).locale(lang.value),\n ])\n return\n }\n if (shortcut.onClick) {\n shortcut.onClick({\n attrs,\n slots,\n emit,\n })\n }\n }\n\n return handleShortcutClick\n}\n","import { getCurrentInstance, inject, ref, unref, watch } from 'vue'\nimport dayjs from 'dayjs'\nimport { isArray } from '@element-plus/utils'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport { isEqual } from 'lodash-unified'\nimport { getDefaultValue, isValidRange } from '../utils'\nimport { ROOT_PICKER_INJECTION_KEY } from '../constants'\nimport { useShortcut } from './use-shortcut'\n\nimport type { Ref } from 'vue'\nimport type { Dayjs } from 'dayjs'\nimport type { PanelRangeSharedProps, RangeState } from '../props/shared'\nimport type { DefaultValue } from '../utils'\n\ntype UseRangePickerProps = {\n sortDates: (minDate: Dayjs | undefined, maxDate: Dayjs | undefined) => void\n defaultValue: Ref\n defaultTime?: Ref\n leftDate: Ref\n rightDate: Ref\n step?: number\n unit: 'month' | 'year'\n}\n\nexport const useRangePicker = (\n props: PanelRangeSharedProps,\n {\n defaultValue,\n defaultTime,\n leftDate,\n rightDate,\n step,\n unit,\n\n sortDates,\n }: UseRangePickerProps\n) => {\n const { emit } = getCurrentInstance()!\n\n const { pickerNs } = inject(ROOT_PICKER_INJECTION_KEY)!\n const drpNs = useNamespace('date-range-picker')\n const { t, lang } = useLocale()\n const handleShortcutClick = useShortcut(lang)\n const minDate = ref()\n const maxDate = ref()\n const rangeState = ref({\n endDate: null,\n selecting: false,\n })\n\n const handleChangeRange = (val: RangeState) => {\n rangeState.value = val\n }\n\n const handleRangeConfirm = (visible = false) => {\n const _minDate = unref(minDate)\n const _maxDate = unref(maxDate)\n\n if (isValidRange([_minDate, _maxDate])) {\n emit('pick', [_minDate, _maxDate], visible)\n }\n }\n\n const onSelect = (selecting: boolean) => {\n rangeState.value.selecting = selecting\n if (!selecting) {\n rangeState.value.endDate = null\n }\n }\n\n const parseValue = (parsedValue: PanelRangeSharedProps['parsedValue']) => {\n if (isArray(parsedValue) && parsedValue.length === 2) {\n const [start, end] = parsedValue\n minDate.value = start\n leftDate.value = start\n maxDate.value = end\n sortDates(unref(minDate), unref(maxDate))\n } else {\n restoreDefault()\n }\n }\n\n const restoreDefault = () => {\n let [start, end] = getDefaultValue(unref(defaultValue), {\n lang: unref(lang),\n step,\n unit,\n unlinkPanels: props.unlinkPanels,\n })\n const getShift = (day: Dayjs) => {\n return day.diff(day.startOf('d'), 'ms')\n }\n const maybeTimes = unref(defaultTime)\n if (maybeTimes) {\n let leftShift = 0\n let rightShift = 0\n if (isArray(maybeTimes)) {\n const [timeStart, timeEnd] = maybeTimes.map(dayjs)\n leftShift = getShift(timeStart)\n rightShift = getShift(timeEnd)\n } else {\n const shift = getShift(dayjs(maybeTimes))\n leftShift = shift\n rightShift = shift\n }\n start = start.startOf('d').add(leftShift, 'ms')\n end = end.startOf('d').add(rightShift, 'ms')\n }\n\n minDate.value = undefined\n maxDate.value = undefined\n leftDate.value = start\n rightDate.value = end\n }\n\n watch(\n defaultValue,\n (val) => {\n if (val) {\n restoreDefault()\n }\n },\n { immediate: true }\n )\n\n watch(\n () => props.parsedValue,\n (parsedValue) => {\n if (\n !(parsedValue as [Dayjs, Dayjs])?.length ||\n !isEqual(parsedValue, [minDate.value, maxDate.value])\n ) {\n parseValue(parsedValue)\n }\n },\n {\n immediate: true,\n }\n )\n\n watch(\n () => props.visible,\n () => {\n if (props.visible) {\n parseValue(props.parsedValue)\n }\n },\n { immediate: true }\n )\n\n return {\n minDate,\n maxDate,\n rangeState,\n lang,\n ppNs: pickerNs,\n drpNs,\n\n handleChangeRange,\n handleRangeConfirm,\n handleShortcutClick,\n onSelect,\n parseValue,\n t,\n }\n}\n","import { computed, inject, nextTick, ref } from 'vue'\nimport { useLocale } from '@element-plus/hooks'\nimport { PICKER_BASE_INJECTION_KEY } from '@element-plus/components/time-picker'\nimport { getValidDateOfMonth, getValidDateOfYear } from '../utils'\n\nimport type { PanelDateRangeProps } from '../props/panel-date-range'\nimport type { Dayjs } from 'dayjs'\nimport type { ComputedRef, Ref } from 'vue'\n\ntype CurrentView = 'date' | 'year' | 'month'\ntype CurrentViewRef = { focus: () => void }\n\nexport type Emits = (\n event: 'pick' | 'set-picker-option' | 'calendar-change' | 'panel-change',\n ...args: any[]\n) => void\n\nexport const usePanelDateRange = (\n props: PanelDateRangeProps,\n emit: Emits,\n leftDate: Ref,\n rightDate: Ref\n) => {\n const leftCurrentView = ref('date')\n const leftCurrentViewRef = ref()\n const rightCurrentView = ref('date')\n const rightCurrentViewRef = ref()\n const pickerBase = inject(PICKER_BASE_INJECTION_KEY) as any\n const { disabledDate } = pickerBase.props\n const { t, lang } = useLocale()\n\n const leftYear = computed(() => {\n return leftDate.value.year()\n })\n const leftMonth = computed(() => {\n return leftDate.value.month()\n })\n\n const rightYear = computed(() => {\n return rightDate.value.year()\n })\n const rightMonth = computed(() => {\n return rightDate.value.month()\n })\n\n function computedYearLabel(\n currentView: Ref,\n yearValue: ComputedRef\n ) {\n const yearTranslation = t('el.datepicker.year')\n if (currentView.value === 'year') {\n const startYear = Math.floor(yearValue.value! / 10) * 10\n return yearTranslation\n ? `${startYear} ${yearTranslation} - ${\n startYear + 9\n } ${yearTranslation}`\n : `${startYear} - ${startYear + 9}`\n }\n return `${yearValue.value} ${yearTranslation}`\n }\n\n function focusPicker(currentViewRef?: CurrentViewRef) {\n currentViewRef?.focus()\n }\n\n async function showPicker(\n pickerType: 'left' | 'right',\n view: 'month' | 'year'\n ) {\n if (props.disabled) return\n const currentView =\n pickerType === 'left' ? leftCurrentView : rightCurrentView\n const currentViewRef =\n pickerType === 'left' ? leftCurrentViewRef : rightCurrentViewRef\n currentView.value = view\n await nextTick()\n focusPicker(currentViewRef.value)\n }\n\n async function handlePick(\n mode: 'month' | 'year',\n pickerType: 'left' | 'right',\n value: number\n ) {\n if (props.disabled) return\n const isLeftPicker = pickerType === 'left'\n const startDate = isLeftPicker ? leftDate : rightDate\n const endDate = isLeftPicker ? rightDate : leftDate\n const currentView = isLeftPicker ? leftCurrentView : rightCurrentView\n const currentViewRef = isLeftPicker\n ? leftCurrentViewRef\n : rightCurrentViewRef\n\n if (mode === 'year') {\n const data = startDate.value.year(value)\n startDate.value = getValidDateOfYear(data, lang.value, disabledDate)\n }\n\n if (mode === 'month') {\n startDate.value = getValidDateOfMonth(\n startDate.value,\n startDate.value.year(),\n value,\n lang.value,\n disabledDate\n )\n }\n\n if (!props.unlinkPanels) {\n endDate.value =\n pickerType === 'left'\n ? startDate.value.add(1, 'month')\n : startDate.value.subtract(1, 'month')\n }\n\n currentView.value = mode === 'year' ? 'month' : 'date'\n await nextTick()\n focusPicker(currentViewRef.value)\n handlePanelChange(mode)\n }\n\n function handlePanelChange(mode: 'month' | 'year') {\n emit(\n 'panel-change',\n [leftDate.value.toDate(), rightDate.value.toDate()],\n mode\n )\n }\n\n function adjustDateByView(\n currentView: CurrentView,\n date: Dayjs,\n forward: boolean\n ) {\n const action = forward ? 'add' : 'subtract'\n return currentView === 'year'\n ? date[action](10, 'year')\n : date[action](1, 'year')\n }\n\n return {\n leftCurrentView,\n rightCurrentView,\n leftCurrentViewRef,\n rightCurrentViewRef,\n leftYear,\n rightYear,\n leftMonth,\n rightMonth,\n leftYearLabel: computed(() => computedYearLabel(leftCurrentView, leftYear)),\n rightYearLabel: computed(() =>\n computedYearLabel(rightCurrentView, rightYear)\n ),\n showLeftPicker: (view: 'month' | 'year') => showPicker('left', view),\n showRightPicker: (view: 'month' | 'year') => showPicker('right', view),\n handleLeftYearPick: (year: number) => handlePick('year', 'left', year),\n handleRightYearPick: (year: number) => handlePick('year', 'right', year),\n handleLeftMonthPick: (month: number) => handlePick('month', 'left', month),\n handleRightMonthPick: (month: number) =>\n handlePick('month', 'right', month),\n handlePanelChange,\n adjustDateByView,\n }\n}\n","\n\n\n","import { buildProps } from '@element-plus/utils'\nimport { panelRangeSharedProps } from './shared'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\n\nexport const panelMonthRangeProps = buildProps({\n ...panelRangeSharedProps,\n} as const)\n\nexport const panelMonthRangeEmits = [\n 'pick',\n 'set-picker-option',\n 'calendar-change',\n]\n\nexport type PanelMonthRangeProps = ExtractPropTypes\nexport type PanelMonthRangePropsPublic = __ExtractPublicPropTypes<\n typeof panelMonthRangeProps\n>\n","import { computed } from 'vue'\nimport { useLocale } from '@element-plus/hooks'\n\nimport type { Ref, ToRef } from 'vue'\nimport type { Dayjs } from 'dayjs'\n\nexport const useMonthRangeHeader = ({\n unlinkPanels,\n leftDate,\n rightDate,\n}: {\n unlinkPanels: ToRef\n leftDate: Ref\n rightDate: Ref\n}) => {\n const { t } = useLocale()\n const leftPrevYear = () => {\n leftDate.value = leftDate.value.subtract(1, 'year')\n if (!unlinkPanels.value) {\n rightDate.value = rightDate.value.subtract(1, 'year')\n }\n }\n\n const rightNextYear = () => {\n if (!unlinkPanels.value) {\n leftDate.value = leftDate.value.add(1, 'year')\n }\n rightDate.value = rightDate.value.add(1, 'year')\n }\n\n const leftNextYear = () => {\n leftDate.value = leftDate.value.add(1, 'year')\n }\n\n const rightPrevYear = () => {\n rightDate.value = rightDate.value.subtract(1, 'year')\n }\n const leftLabel = computed(() => {\n return `${leftDate.value.year()} ${t('el.datepicker.year')}`\n })\n\n const rightLabel = computed(() => {\n return `${rightDate.value.year()} ${t('el.datepicker.year')}`\n })\n\n const leftYear = computed(() => {\n return leftDate.value.year()\n })\n\n const rightYear = computed(() => {\n return rightDate.value.year() === leftDate.value.year()\n ? leftDate.value.year() + 1\n : rightDate.value.year()\n })\n\n return {\n leftPrevYear,\n rightNextYear,\n leftNextYear,\n rightPrevYear,\n leftLabel,\n rightLabel,\n leftYear,\n rightYear,\n }\n}\n","\n\n\n","import { buildProps } from '@element-plus/utils'\nimport { panelRangeSharedProps } from './shared'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\n\nexport const panelYearRangeProps = buildProps({\n ...panelRangeSharedProps,\n} as const)\n\nexport const panelYearRangeEmits = [\n 'pick',\n 'set-picker-option',\n 'calendar-change',\n]\n\nexport type PanelYearRangeProps = ExtractPropTypes\nexport type PanelYearRangePropsPublic = __ExtractPublicPropTypes<\n typeof panelYearRangeProps\n>\n","import { computed } from 'vue'\n\nimport type { Ref, ToRef } from 'vue'\nimport type { Dayjs } from 'dayjs'\n\nexport const useYearRangeHeader = ({\n unlinkPanels,\n leftDate,\n rightDate,\n}: {\n unlinkPanels: ToRef\n leftDate: Ref\n rightDate: Ref\n}) => {\n const leftPrevYear = () => {\n leftDate.value = leftDate.value.subtract(10, 'year')\n if (!unlinkPanels.value) {\n rightDate.value = rightDate.value.subtract(10, 'year')\n }\n }\n\n const rightNextYear = () => {\n if (!unlinkPanels.value) {\n leftDate.value = leftDate.value.add(10, 'year')\n }\n rightDate.value = rightDate.value.add(10, 'year')\n }\n\n const leftNextYear = () => {\n leftDate.value = leftDate.value.add(10, 'year')\n }\n\n const rightPrevYear = () => {\n rightDate.value = rightDate.value.subtract(10, 'year')\n }\n\n const leftLabel = computed(() => {\n const leftStartDate = Math.floor(leftDate.value.year() / 10) * 10\n return `${leftStartDate}-${leftStartDate + 9}`\n })\n\n const rightLabel = computed(() => {\n const rightStartDate = Math.floor(rightDate.value.year() / 10) * 10\n return `${rightStartDate}-${rightStartDate + 9}`\n })\n\n const leftYear = computed(() => {\n const leftEndDate = Math.floor(leftDate.value.year() / 10) * 10 + 9\n return leftEndDate\n })\n\n const rightYear = computed(() => {\n const rightStartDate = Math.floor(rightDate.value.year() / 10) * 10\n return rightStartDate\n })\n\n return {\n leftPrevYear,\n rightNextYear,\n leftNextYear,\n rightPrevYear,\n leftLabel,\n rightLabel,\n leftYear,\n rightYear,\n }\n}\n","\n\n\n","import DatePickPanel from './date-picker-com/panel-date-pick.vue'\nimport DateRangePickPanel from './date-picker-com/panel-date-range.vue'\nimport MonthRangePickPanel from './date-picker-com/panel-month-range.vue'\nimport YearRangePickPanel from './date-picker-com/panel-year-range.vue'\n\nimport type { DatePickerType } from './types'\n\nexport const getPanel = function (type: DatePickerType) {\n switch (type) {\n case 'daterange':\n case 'datetimerange': {\n return DateRangePickPanel\n }\n case 'monthrange': {\n return MonthRangePickPanel\n }\n case 'yearrange': {\n return YearRangePickPanel\n }\n default: {\n return DatePickPanel\n }\n }\n}\n","import { computed, ref } from 'vue'\nimport { isEqual } from 'lodash-unified'\nimport { useLocale } from '@element-plus/hooks/use-locale'\nimport { isArray } from '@element-plus/utils'\nimport { UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport { dayOrDaysToDate, formatter, parseDate, valueEquals } from '../utils'\n\nimport type { Dayjs } from 'dayjs'\nimport type {\n DateModelType,\n DayOrDays,\n ModelValueType,\n PickerOptions,\n SingleOrRange,\n UserInput,\n} from '../common/props'\n\ninterface CommonPickerProps {\n modelValue: ModelValueType | null\n valueFormat?: string\n}\ntype CommonPickerEmits = (\n event: 'update:modelValue' | 'calendar-change' | 'panel-change',\n ...args: any[]\n) => void\n\nexport const useCommonPicker = <\n P extends CommonPickerProps,\n E extends CommonPickerEmits,\n>(\n props: P,\n emit: E\n) => {\n const { lang } = useLocale()\n const pickerVisible = ref(false)\n const pickerActualVisible = ref(false)\n const userInput = ref(null)\n\n const valueIsEmpty = computed(() => {\n const { modelValue } = props\n return (\n !modelValue || (isArray(modelValue) && !modelValue.filter(Boolean).length)\n )\n })\n\n const emitInput = (input: SingleOrRange | null) => {\n if (!valueEquals(props.modelValue, input)) {\n let formatted\n if (isArray(input)) {\n formatted = input.map((item) =>\n formatter(item, props.valueFormat, lang.value)\n )\n } else if (input) {\n formatted = formatter(input, props.valueFormat, lang.value)\n }\n const emitVal = input ? formatted : input\n emit(UPDATE_MODEL_EVENT, emitVal, lang.value)\n }\n }\n\n const parsedValue = computed(() => {\n let dayOrDays: DayOrDays\n if (valueIsEmpty.value) {\n if (pickerOptions.value.getDefaultValue) {\n dayOrDays = pickerOptions.value.getDefaultValue()\n }\n } else {\n if (isArray(props.modelValue)) {\n dayOrDays = props.modelValue.map((d) =>\n parseDate(d, props.valueFormat, lang.value)\n ) as [Dayjs, Dayjs]\n } else {\n dayOrDays = parseDate(\n props.modelValue ?? '',\n props.valueFormat,\n lang.value\n )!\n }\n }\n\n if (pickerOptions.value.getRangeAvailableTime) {\n const availableResult = pickerOptions.value.getRangeAvailableTime(\n dayOrDays!\n )\n if (!isEqual(availableResult, dayOrDays!)) {\n dayOrDays = availableResult\n\n // The result is corrected only when model-value exists\n if (!valueIsEmpty.value) {\n emitInput(dayOrDaysToDate(dayOrDays))\n }\n }\n }\n if (isArray(dayOrDays!) && dayOrDays.some((day) => !day)) {\n dayOrDays = [] as unknown as DayOrDays\n }\n return dayOrDays!\n })\n\n const pickerOptions = ref>({})\n\n const onSetPickerOption = (\n e: [T, PickerOptions[T]]\n ) => {\n pickerOptions.value[e[0]] = e[1]\n pickerOptions.value.panelReady = true\n }\n\n const onCalendarChange = (e: [Date, null | Date]) => {\n emit('calendar-change', e)\n }\n\n const onPanelChange = (\n value: [Dayjs, Dayjs],\n mode: 'month' | 'year',\n view: unknown\n ) => {\n emit('panel-change', value, mode, view)\n }\n\n const onPick = (date: any = '', visible = false) => {\n pickerVisible.value = visible\n let result\n if (isArray(date)) {\n result = date.map((_) => _.toDate())\n } else {\n // clear btn emit null\n result = date ? date.toDate() : date\n }\n userInput.value = null\n emitInput(result)\n }\n\n return {\n parsedValue,\n pickerActualVisible,\n pickerOptions,\n pickerVisible,\n userInput,\n valueIsEmpty,\n emitInput,\n onCalendarChange,\n onPanelChange,\n onPick,\n onSetPickerOption,\n }\n}\n\nexport type CommonPickerContext = ReturnType\n","import { defineComponent, inject, provide, reactive, toRefs } from 'vue'\nimport dayjs from 'dayjs'\nimport customParseFormat from 'dayjs/plugin/customParseFormat.js'\nimport advancedFormat from 'dayjs/plugin/advancedFormat.js'\nimport localeData from 'dayjs/plugin/localeData.js'\nimport weekOfYear from 'dayjs/plugin/weekOfYear.js'\nimport weekYear from 'dayjs/plugin/weekYear.js'\nimport dayOfYear from 'dayjs/plugin/dayOfYear.js'\nimport isSameOrAfter from 'dayjs/plugin/isSameOrAfter.js'\nimport isSameOrBefore from 'dayjs/plugin/isSameOrBefore.js'\nimport {\n PICKER_BASE_INJECTION_KEY,\n ROOT_COMMON_PICKER_INJECTION_KEY,\n} from '@element-plus/components/time-picker'\nimport { useNamespace } from '@element-plus/hooks'\nimport { isUndefined } from '@element-plus/utils'\nimport { UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport { datePickerPanelProps } from './props/date-picker-panel'\nimport { ROOT_PICKER_INJECTION_KEY } from './constants'\nimport { getPanel } from './panel-utils'\nimport { useCommonPicker } from '../../time-picker/src/composables/use-common-picker'\n\ndayjs.extend(localeData)\ndayjs.extend(advancedFormat)\ndayjs.extend(customParseFormat)\ndayjs.extend(weekOfYear)\ndayjs.extend(weekYear)\ndayjs.extend(dayOfYear)\ndayjs.extend(isSameOrAfter)\ndayjs.extend(isSameOrBefore)\n\nexport default defineComponent({\n name: 'ElDatePickerPanel',\n install: null,\n props: datePickerPanelProps,\n emits: [\n UPDATE_MODEL_EVENT,\n 'calendar-change',\n 'panel-change',\n 'visible-change',\n 'pick',\n ],\n setup(props, { slots, emit }) {\n const ns = useNamespace('picker-panel')\n const pickerInjection = inject(PICKER_BASE_INJECTION_KEY, undefined)\n if (isUndefined(pickerInjection)) {\n const _props = reactive({\n ...toRefs(props),\n })\n provide(PICKER_BASE_INJECTION_KEY, {\n props: _props,\n })\n }\n\n provide(ROOT_PICKER_INJECTION_KEY, {\n slots,\n pickerNs: ns,\n })\n const {\n parsedValue,\n onCalendarChange,\n onPanelChange,\n onSetPickerOption,\n onPick,\n } = inject(\n ROOT_COMMON_PICKER_INJECTION_KEY,\n () => useCommonPicker(props, emit),\n true\n )\n\n return () => {\n const Component = getPanel(props.type)\n return (\n \n {slots}\n \n )\n }\n },\n})\n","import { withInstall } from '@element-plus/utils'\nimport DatePickerPanel from './src/date-picker-panel'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElDatePickerPanel: SFCWithInstall =\n withInstall(DatePickerPanel)\n\nexport default ElDatePickerPanel\nexport * from './src/constants'\nexport * from './src/props/date-picker-panel'\nexport * from './src/types'\nexport type { DatePickerPanelInstance } from './src/instance'\n","import { placements } from '@popperjs/core'\nimport { buildProps, definePropType } from '@element-plus/utils'\nimport {\n useAriaProps,\n useEmptyValuesProps,\n useSizeProp,\n} from '@element-plus/hooks'\nimport { useTooltipContentProps } from '@element-plus/components/tooltip'\nimport { CircleClose } from '@element-plus/icons-vue'\nimport { disabledTimeListsProps } from '../props/shared'\n\nimport type { Component, ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type { Options } from '@popperjs/core'\nimport type { Dayjs } from 'dayjs'\nimport type { Placement } from '@element-plus/components/popper'\n\nexport type SingleOrRange = T | [T, T]\nexport type DateModelType = number | string | Date\nexport type ModelValueType = DateModelType | number[] | string[] | Date[]\nexport type DayOrDays = SingleOrRange\nexport type DateOrDates = SingleOrRange\nexport type UserInput = SingleOrRange\nexport type GetDisabledHours = (role: string, comparingDate?: Dayjs) => number[]\nexport type GetDisabledMinutes = (\n hour: number,\n role: string,\n comparingDate?: Dayjs\n) => number[]\nexport type GetDisabledSeconds = (\n hour: number,\n minute: number,\n role: string,\n comparingDate?: Dayjs\n) => number[]\n\nexport const timePickerDefaultProps = buildProps({\n /**\n * @description this prop decides if the date picker panel pops up when the input is focused\n */\n automaticDropdown: {\n type: Boolean,\n default: true,\n },\n /**\n * @description same as `id` in native input\n */\n id: {\n type: definePropType>([Array, String]),\n },\n /**\n * @description same as `name` in native input\n */\n name: {\n type: definePropType>([Array, String]),\n },\n /**\n * @description custom class name for TimePicker's dropdown\n */\n popperClass: useTooltipContentProps.popperClass,\n /**\n * @description custom style for TimePicker's dropdown\n */\n popperStyle: useTooltipContentProps.popperStyle,\n /**\n * @description format of the displayed value in the input box\n */\n format: String,\n /**\n * @description optional, format of binding value. If not specified, the binding value will be a Date object\n */\n valueFormat: String,\n /**\n * @description optional, format of the date displayed in input's inner panel\n */\n dateFormat: String,\n /**\n * @description optional, format of the time displayed in input's inner panel\n */\n timeFormat: String,\n /**\n * @description type of the picker\n */\n type: {\n type: String,\n default: '',\n },\n /**\n * @description whether to show clear button\n */\n clearable: {\n type: Boolean,\n default: true,\n },\n /**\n * @description Custom clear icon component\n */\n clearIcon: {\n type: definePropType([String, Object]),\n default: CircleClose,\n },\n /**\n * @description whether the input is editable\n */\n editable: {\n type: Boolean,\n default: true,\n },\n /**\n * @description Custom prefix icon component\n */\n prefixIcon: {\n type: definePropType([String, Object]),\n default: '',\n },\n /**\n * @description size of Input\n */\n size: useSizeProp,\n /**\n * @description whether TimePicker is read only\n */\n readonly: Boolean,\n /**\n * @description whether TimePicker is disabled\n */\n disabled: Boolean,\n /**\n * @description placeholder in non-range mode\n */\n placeholder: {\n type: String,\n default: '',\n },\n /**\n * @description [popper.js](https://popper.js.org/docs/v2/) parameters\n */\n popperOptions: {\n type: definePropType>(Object),\n default: () => ({}),\n },\n /**\n * @description binding value, if it is an array, the length should be 2\n */\n modelValue: {\n type: definePropType([Date, Array, String, Number]),\n default: '',\n },\n /**\n * @description range separator\n */\n rangeSeparator: {\n type: String,\n default: '-',\n },\n /**\n * @description placeholder for the start date in range mode\n */\n startPlaceholder: String,\n /**\n * @description placeholder for the end date in range mode\n */\n endPlaceholder: String,\n /**\n * @description optional, default date of the calendar\n */\n defaultValue: {\n type: definePropType>([Date, Array]),\n },\n /**\n * @description optional, the time value to use when selecting date range\n */\n defaultTime: {\n type: definePropType>([Date, Array]),\n },\n /**\n * @description whether to pick a time range\n */\n isRange: Boolean,\n ...disabledTimeListsProps,\n /**\n * @description a function determining if a date is disabled with that date as its parameter. Should return a Boolean\n */\n disabledDate: {\n type: Function,\n },\n /**\n * @description set custom className\n */\n cellClassName: {\n type: Function,\n },\n /**\n * @description an object array to set shortcut options\n */\n shortcuts: {\n type: Array,\n default: () => [],\n },\n /**\n * @description whether to pick time using arrow buttons\n */\n arrowControl: Boolean,\n /**\n * @description input tabindex\n */\n tabindex: {\n type: definePropType([String, Number]),\n default: 0,\n },\n /**\n * @description whether to trigger form validation\n */\n validateEvent: {\n type: Boolean,\n default: true,\n },\n /**\n * @description unlink two date-panels in range-picker\n */\n unlinkPanels: Boolean,\n /**\n * @description position of dropdown\n */\n placement: {\n type: definePropType(String),\n values: placements,\n default: 'bottom',\n },\n /**\n * @description list of possible positions for dropdown\n */\n fallbackPlacements: {\n type: definePropType(Array),\n default: ['bottom', 'top', 'right', 'left'],\n },\n ...useEmptyValuesProps,\n ...useAriaProps(['ariaLabel']),\n /**\n * @description whether to show the now button\n */\n showNow: {\n type: Boolean,\n default: true,\n },\n /**\n * @description whether to show footer\n */\n showConfirm: {\n type: Boolean,\n default: true,\n },\n /**\n * @description whether to show footer\n */\n showFooter: {\n type: Boolean,\n default: true,\n },\n /**\n * @description whether to show the number of the calendar week\n */\n showWeekNumber: Boolean,\n} as const)\n\nexport type TimePickerDefaultProps = ExtractPropTypes<\n typeof timePickerDefaultProps\n>\nexport type TimePickerDefaultPropsPublic = __ExtractPublicPropTypes<\n typeof timePickerDefaultProps\n>\n\nexport interface PickerOptions {\n isValidValue: (date: DayOrDays) => boolean\n handleKeydownInput: (event: KeyboardEvent) => void\n parseUserInput: (value: UserInput) => DayOrDays\n getRangeAvailableTime: (date: DayOrDays) => DayOrDays\n getDefaultValue: () => DayOrDays\n panelReady: boolean\n handleClear: () => void\n handleFocusPicker?: () => void\n}\n\nexport const timePickerRangeTriggerProps = buildProps({\n id: {\n type: definePropType(Array),\n },\n name: {\n type: definePropType(Array),\n },\n modelValue: {\n type: definePropType([Array, String]),\n },\n startPlaceholder: String,\n endPlaceholder: String,\n disabled: Boolean,\n} as const)\n\n/**\n * @deprecated Use `timePickerRangeTriggerProps` instead. This will be removed in future versions.\n */\nexport const timePickerRngeTriggerProps = timePickerRangeTriggerProps\n","import { timePickerDefaultProps } from '@element-plus/components/time-picker'\nimport { buildProps, definePropType } from '@element-plus/utils'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type { DatePickerType } from '@element-plus/components/date-picker-panel/src/types'\n\nexport const datePickerProps = buildProps({\n ...timePickerDefaultProps,\n /**\n * @description type of the picker\n */\n type: {\n type: definePropType(String),\n default: 'date',\n },\n} as const)\n\nexport type DatePickerProps = ExtractPropTypes\nexport type DatePickerPropsPublic = __ExtractPublicPropTypes<\n typeof datePickerProps\n>\n","\n\n\n","\n\n\n","import { computed, defineComponent, provide, reactive, ref, toRef } from 'vue'\nimport {\n CommonPicker,\n DEFAULT_FORMATS_DATE,\n DEFAULT_FORMATS_DATEPICKER,\n PICKER_POPPER_OPTIONS_INJECTION_KEY,\n} from '@element-plus/components/time-picker'\nimport { UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport {\n ElDatePickerPanel,\n ROOT_PICKER_IS_DEFAULT_FORMAT_INJECTION_KEY,\n} from '@element-plus/components/date-picker-panel'\nimport { datePickerProps } from './props'\n\nimport type {\n DateModelType,\n SingleOrRange,\n} from '@element-plus/components/time-picker'\nimport type { DatePickerExpose } from './instance'\n\nexport default defineComponent({\n name: 'ElDatePicker',\n install: null,\n props: datePickerProps,\n emits: [UPDATE_MODEL_EVENT],\n setup(props, { expose, emit, slots }) {\n const isDefaultFormat = computed(() => {\n return !props.format\n })\n provide(ROOT_PICKER_IS_DEFAULT_FORMAT_INJECTION_KEY, isDefaultFormat)\n provide(\n PICKER_POPPER_OPTIONS_INJECTION_KEY,\n reactive(toRef(props, 'popperOptions'))\n )\n\n const commonPicker = ref>()\n const refProps: DatePickerExpose = {\n focus: () => {\n commonPicker.value?.focus()\n },\n blur: () => {\n commonPicker.value?.blur()\n },\n handleOpen: () => {\n commonPicker.value?.handleOpen()\n },\n handleClose: () => {\n commonPicker.value?.handleClose()\n },\n }\n\n expose(refProps)\n\n const onModelValueUpdated = (val: SingleOrRange | null) => {\n emit(UPDATE_MODEL_EVENT, val)\n }\n\n return () => {\n // since props always have all defined keys on it, {format, ...props} will always overwrite format\n // pick props.format or provide default value here before spreading\n const format =\n props.format ??\n (DEFAULT_FORMATS_DATEPICKER[props.type] || DEFAULT_FORMATS_DATE)\n\n return (\n \n {{\n default: (scopedProps: /**FIXME: remove any type */ any) => (\n \n {slots}\n \n ),\n 'range-separator': slots['range-separator'],\n }}\n \n )\n }\n },\n})\n","import { withInstall } from '@element-plus/utils'\nimport DatePicker from './src/date-picker'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElDatePicker: SFCWithInstall =\n withInstall(DatePicker)\n\nexport default ElDatePicker\nexport * from './src/props'\nexport type { DatePickerInstance } from './src/instance'\n","import { buildProps, definePropType } from '@element-plus/utils'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type Divider from './divider.vue'\n\nexport type BorderStyle = CSSStyleDeclaration['borderStyle']\n\nexport const dividerProps = buildProps({\n /**\n * @description Set divider's direction\n */\n direction: {\n type: String,\n values: ['horizontal', 'vertical'],\n default: 'horizontal',\n },\n /**\n * @description Set the style of divider\n */\n contentPosition: {\n type: String,\n values: ['left', 'center', 'right'],\n default: 'center',\n },\n /**\n * @description the position of the customized content on the divider line\n */\n borderStyle: {\n type: definePropType(String),\n default: 'solid',\n },\n} as const)\nexport type DividerProps = ExtractPropTypes\nexport type DividerPropsPublic = __ExtractPublicPropTypes\n\nexport type DividerInstance = InstanceType & unknown\n","\n\n\n","import { withInstall } from '@element-plus/utils'\nimport Divider from './src/divider.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElDivider: SFCWithInstall = withInstall(Divider)\nexport default ElDivider\n\nexport * from './src/divider'\n","import { buildProps } from '@element-plus/utils'\nimport { dialogEmits, dialogProps } from '@element-plus/components/dialog'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\n\nexport const drawerProps = buildProps({\n ...dialogProps,\n direction: {\n type: String,\n default: 'rtl',\n values: ['ltr', 'rtl', 'ttb', 'btt'],\n },\n resizable: Boolean,\n size: {\n type: [String, Number],\n default: '30%',\n },\n withHeader: {\n type: Boolean,\n default: true,\n },\n modalFade: {\n type: Boolean,\n default: true,\n },\n headerAriaLevel: {\n type: String,\n default: '2',\n },\n} as const)\n\nexport type DrawerProps = ExtractPropTypes\nexport type DrawerPropsPublic = __ExtractPublicPropTypes\n\nexport const drawerEmits = {\n ...dialogEmits,\n 'resize-start': (evt: MouseEvent, size: number) =>\n evt instanceof MouseEvent && typeof size === 'number',\n resize: (evt: MouseEvent, size: number) =>\n evt instanceof MouseEvent && typeof size === 'number',\n 'resize-end': (evt: MouseEvent, size: number) =>\n evt instanceof MouseEvent && typeof size === 'number',\n}\n\nexport type DrawerEmits = typeof drawerEmits\n","import { computed, onBeforeUnmount, ref, watch } from 'vue'\nimport { addUnit } from '@element-plus/utils'\nimport { clamp, useEventListener, useWindowSize } from '@vueuse/core'\n\nimport type { Ref, SetupContext } from 'vue'\nimport type { DrawerEmits, DrawerProps } from '../drawer'\n\nexport function useResizable(\n props: DrawerProps,\n target: Ref,\n emit: SetupContext['emit']\n) {\n const { width, height } = useWindowSize()\n\n const isHorizontal = computed(() => ['ltr', 'rtl'].includes(props.direction))\n const sign = computed(() =>\n ['ltr', 'ttb'].includes(props.direction) ? 1 : -1\n )\n const windowSize = computed(() =>\n isHorizontal.value ? width.value : height.value\n )\n const getSize = computed(() => {\n return clamp(\n startSize.value + sign.value * offset.value,\n 4,\n windowSize.value\n )\n })\n\n const startSize = ref(0)\n const offset = ref(0)\n const isResizing = ref(false)\n const hasStartedDragging = ref(false)\n let startPos: number[] = []\n let cleanups: (() => void)[] = []\n\n const getActualSize = () => {\n const drawerEl = target.value?.closest('[aria-modal=\"true\"]') as HTMLElement\n if (drawerEl) {\n return isHorizontal.value ? drawerEl.offsetWidth : drawerEl.offsetHeight\n }\n return 100\n }\n\n watch(\n () => [props.size, props.resizable] as const,\n () => {\n hasStartedDragging.value = false\n startSize.value = 0\n offset.value = 0\n onMouseUp()\n }\n )\n\n const onMousedown = (e: MouseEvent) => {\n if (!props.resizable) return\n\n if (!hasStartedDragging.value) {\n startSize.value = getActualSize()\n hasStartedDragging.value = true\n }\n\n startPos = [e.pageX, e.pageY]\n isResizing.value = true\n emit('resize-start', e, startSize.value)\n cleanups.push(\n useEventListener(window, 'mouseup', onMouseUp),\n useEventListener(window, 'mousemove', onMouseMove)\n )\n }\n\n const onMouseMove = (e: MouseEvent) => {\n const { pageX, pageY } = e\n const offsetX = pageX - startPos[0]\n const offsetY = pageY - startPos[1]\n offset.value = isHorizontal.value ? offsetX : offsetY\n emit('resize', e, getSize.value)\n }\n\n const onMouseUp = (e?: MouseEvent) => {\n // premature interruption\n // avoid triggering meaningless execution due to watch size/resizable constraints.\n if (!isResizing.value) return\n\n startPos = []\n startSize.value = getSize.value\n offset.value = 0\n isResizing.value = false\n cleanups.forEach((cleanup) => cleanup?.())\n cleanups = []\n if (e) {\n emit('resize-end', e, startSize.value)\n }\n }\n\n const cleanup = useEventListener(target, 'mousedown', onMousedown)\n\n onBeforeUnmount(() => {\n cleanup()\n onMouseUp()\n })\n\n return {\n size: computed(() => {\n return hasStartedDragging.value\n ? `${getSize.value}px`\n : addUnit(props.size)\n }),\n isResizing,\n isHorizontal,\n }\n}\n","\n\n\n","import { withInstall } from '@element-plus/utils'\nimport Drawer from './src/drawer.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElDrawer: SFCWithInstall = withInstall(Drawer)\nexport default ElDrawer\n\nexport * from './src/drawer'\n","\n\n\n","import { buildProps } from '@element-plus/utils'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\n\nexport const emptyProps = buildProps({\n /**\n * @description image URL of empty\n */\n image: {\n type: String,\n default: '',\n },\n /**\n * @description image size (width) of empty\n */\n imageSize: Number,\n /**\n * @description description of empty\n */\n description: {\n type: String,\n default: '',\n },\n} as const)\n\nexport type EmptyProps = ExtractPropTypes\nexport type EmptyPropsPublic = __ExtractPublicPropTypes\n","\n\n\n","import { withInstall } from '@element-plus/utils'\nimport Empty from './src/empty.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElEmpty: SFCWithInstall = withInstall(Empty)\nexport default ElEmpty\n\nexport * from './src/empty'\nexport type { EmptyInstance } from './src/instance'\n","import {\n buildProps,\n definePropType,\n iconPropType,\n isArray,\n isNumber,\n isString,\n isUndefined,\n} from '@element-plus/utils'\nimport { useSizeProp } from '@element-plus/hooks'\nimport {\n CHANGE_EVENT,\n EVENT_CODE,\n INPUT_EVENT,\n UPDATE_MODEL_EVENT,\n} from '@element-plus/constants'\nimport { tagProps } from '@element-plus/components/tag/src/tag'\nimport { CircleClose } from '@element-plus/icons-vue'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\n\nexport const inputTagProps = buildProps({\n /**\n * @description binding value\n */\n modelValue: {\n type: definePropType(Array),\n },\n /**\n * @description max number tags that can be enter\n */\n max: Number,\n /**\n * @description tag type\n */\n tagType: { ...tagProps.type, default: 'info' },\n /**\n * @description tag effect\n */\n tagEffect: tagProps.effect,\n /**\n * @description the key to trigger input tag\n */\n trigger: {\n type: definePropType<'Enter' | 'Space'>(String),\n default: EVENT_CODE.enter,\n },\n /**\n * @description whether tags can be dragged\n */\n draggable: Boolean,\n /**\n * @description add a tag when a delimiter is matched\n */\n delimiter: {\n type: [String, RegExp],\n default: '',\n },\n /**\n * @description input box size\n */\n size: useSizeProp,\n /**\n * @description whether to show clear button\n */\n clearable: Boolean,\n /**\n * @description custom clear icon component\n */\n clearIcon: {\n type: iconPropType,\n default: CircleClose,\n },\n /**\n * @description whether to disable input-tag\n */\n disabled: {\n type: Boolean,\n default: undefined,\n },\n /**\n * @description whether to trigger form validation\n */\n validateEvent: {\n type: Boolean,\n default: true,\n },\n /**\n * @description native input readonly\n */\n readonly: Boolean,\n /**\n * @description native input autofocus\n */\n autofocus: Boolean,\n /**\n * @description same as `id` in native input\n */\n id: {\n type: String,\n default: undefined,\n },\n /**\n * @description same as `tabindex` in native input\n */\n tabindex: {\n type: [String, Number],\n default: 0,\n },\n /**\n * @description same as `maxlength` in native input\n */\n maxlength: {\n type: [String, Number],\n },\n /**\n * @description same as `minlength` in native input\n */\n minlength: {\n type: [String, Number],\n },\n /**\n * @description placeholder of input\n */\n placeholder: String,\n /**\n * @description native input autocomplete\n */\n autocomplete: {\n type: definePropType(String),\n default: 'off',\n },\n /**\n * @description whether to save the input value when the input loses focus\n */\n saveOnBlur: {\n type: Boolean,\n default: true,\n },\n /**\n * @description whether to collapse tags to a text\n */\n collapseTags: Boolean,\n /**\n * @description whether show all selected tags when mouse hover text of collapse-tags. To use this, `collapse-tags` must be true\n */\n collapseTagsTooltip: Boolean,\n /**\n * @description the max tags number to be shown. To use this, `collapse-tags` must be true\n */\n maxCollapseTags: {\n type: Number,\n default: 1,\n },\n /**\n * @description native `aria-label` attribute\n */\n ariaLabel: String,\n} as const)\nexport type InputTagProps = ExtractPropTypes\nexport type InputTagPropsPublic = __ExtractPublicPropTypes\n\nexport const inputTagEmits = {\n [UPDATE_MODEL_EVENT]: (value?: string[]) =>\n isArray(value) || isUndefined(value),\n [CHANGE_EVENT]: (value?: string[]) => isArray(value) || isUndefined(value),\n [INPUT_EVENT]: (value: string) => isString(value),\n 'add-tag': (value: string | string[]) => isString(value) || isArray(value),\n 'remove-tag': (value: string, index: number) =>\n isString(value) && isNumber(index),\n 'drag-tag': (oldIndex: number, newIndex: number, value: string) =>\n isNumber(oldIndex) && isNumber(newIndex) && isString(value),\n focus: (evt: FocusEvent) => evt instanceof FocusEvent,\n blur: (evt: FocusEvent) => evt instanceof FocusEvent,\n clear: () => true,\n}\nexport type InputTagEmits = typeof inputTagEmits\n","import { computed, ref, shallowRef, watch } from 'vue'\nimport {\n CHANGE_EVENT,\n EVENT_CODE,\n INPUT_EVENT,\n UPDATE_MODEL_EVENT,\n} from '@element-plus/constants'\nimport {\n debugWarn,\n ensureArray,\n getEventCode,\n isAndroid,\n isUndefined,\n} from '@element-plus/utils'\nimport { useComposition, useFocusController } from '@element-plus/hooks'\nimport { useFormDisabled, useFormSize } from '@element-plus/components/form'\n\nimport type { TooltipInstance } from '@element-plus/components/tooltip'\nimport type { EmitFn } from '@element-plus/utils'\nimport type { FormItemContext } from '@element-plus/components/form'\nimport type { InputTagEmits, InputTagProps } from '../input-tag'\n\ninterface UseInputTagOptions {\n props: InputTagProps\n emit: EmitFn\n formItem?: FormItemContext\n}\n\nexport function useInputTag({ props, emit, formItem }: UseInputTagOptions) {\n const disabled = useFormDisabled()\n const size = useFormSize()\n\n const inputRef = shallowRef()\n const inputValue = ref()\n const tagTooltipRef = ref()\n\n const tagSize = computed(() => {\n return ['small'].includes(size.value) ? 'small' : 'default'\n })\n const placeholder = computed(() => {\n return props.modelValue?.length ? undefined : props.placeholder\n })\n const closable = computed(() => !(props.readonly || disabled.value))\n const inputLimit = computed(() => {\n return isUndefined(props.max)\n ? false\n : (props.modelValue?.length ?? 0) >= props.max\n })\n const showTagList = computed(() => {\n return props.collapseTags\n ? props.modelValue?.slice(0, props.maxCollapseTags)\n : props.modelValue\n })\n const collapseTagList = computed(() => {\n return props.collapseTags\n ? props.modelValue?.slice(props.maxCollapseTags)\n : []\n })\n\n const addTagsEmit = (value: string | string[]) => {\n const list = [...(props.modelValue ?? []), ...ensureArray(value)]\n\n emit(UPDATE_MODEL_EVENT, list)\n emit(CHANGE_EVENT, list)\n emit('add-tag', value)\n inputValue.value = undefined\n }\n\n const getDelimitedTags = (input: string) => {\n const tags = input\n .split(props.delimiter)\n .filter((val) => val && val !== input)\n if (props.max) {\n const maxInsert = props.max - (props.modelValue?.length ?? 0)\n tags.splice(maxInsert)\n }\n return tags.length === 1 ? tags[0] : tags\n }\n\n const handleInput = (event: Event) => {\n if (inputLimit.value) {\n inputValue.value = undefined\n return\n }\n\n if (isComposing.value) return\n if (props.delimiter && inputValue.value) {\n const tags = getDelimitedTags(inputValue.value)\n if (tags.length) {\n addTagsEmit(tags)\n }\n }\n emit(INPUT_EVENT, (event.target as HTMLInputElement).value)\n }\n\n const handleKeydown = (event: KeyboardEvent) => {\n if (isComposing.value) return\n const code = getEventCode(event)\n\n switch (code) {\n case props.trigger:\n event.preventDefault()\n event.stopPropagation()\n handleAddTag()\n break\n case EVENT_CODE.numpadEnter:\n if (props.trigger === EVENT_CODE.enter) {\n event.preventDefault()\n event.stopPropagation()\n handleAddTag()\n }\n break\n case EVENT_CODE.backspace:\n if (!inputValue.value && props.modelValue?.length) {\n event.preventDefault()\n event.stopPropagation()\n handleRemoveTag(props.modelValue.length - 1)\n }\n break\n }\n }\n\n const handleKeyup = (event: KeyboardEvent) => {\n if (isComposing.value || !isAndroid()) return\n const code = getEventCode(event)\n\n switch (code) {\n case EVENT_CODE.space:\n if (props.trigger === EVENT_CODE.space) {\n event.preventDefault()\n event.stopPropagation()\n handleAddTag()\n }\n break\n }\n }\n\n const handleAddTag = () => {\n const value = inputValue.value?.trim()\n if (!value || inputLimit.value) return\n addTagsEmit(value)\n }\n\n const handleRemoveTag = (index: number) => {\n const value = (props.modelValue ?? []).slice()\n const [item] = value.splice(index, 1)\n\n emit(UPDATE_MODEL_EVENT, value)\n emit(CHANGE_EVENT, value)\n emit('remove-tag', item, index)\n }\n\n const handleClear = () => {\n inputValue.value = undefined\n emit(UPDATE_MODEL_EVENT, undefined)\n emit(CHANGE_EVENT, undefined)\n emit('clear')\n }\n\n const handleDragged = (\n draggingIndex: number,\n dropIndex: number,\n type: 'before' | 'after'\n ) => {\n const value = (props.modelValue ?? []).slice()\n const [draggedItem] = value.splice(draggingIndex, 1)\n const step =\n dropIndex > draggingIndex && type === 'before'\n ? -1\n : dropIndex < draggingIndex && type === 'after'\n ? 1\n : 0\n\n value.splice(dropIndex + step, 0, draggedItem)\n emit(UPDATE_MODEL_EVENT, value)\n emit(CHANGE_EVENT, value)\n emit('drag-tag', draggingIndex, dropIndex + step, draggedItem)\n }\n\n const focus = () => {\n inputRef.value?.focus()\n }\n\n const blur = () => {\n inputRef.value?.blur()\n }\n\n const { wrapperRef, isFocused } = useFocusController(inputRef, {\n disabled,\n beforeBlur(event) {\n return tagTooltipRef.value?.isFocusInsideContent(event)\n },\n afterBlur() {\n if (props.saveOnBlur) {\n handleAddTag()\n } else {\n inputValue.value = undefined\n }\n\n if (props.validateEvent) {\n formItem?.validate?.('blur').catch((err) => debugWarn(err))\n }\n },\n })\n\n const {\n isComposing,\n handleCompositionStart,\n handleCompositionUpdate,\n handleCompositionEnd,\n } = useComposition({ afterComposition: handleInput })\n\n watch(\n () => props.modelValue,\n () => {\n if (props.validateEvent) {\n formItem?.validate?.(CHANGE_EVENT).catch((err) => debugWarn(err))\n }\n }\n )\n\n return {\n inputRef,\n wrapperRef,\n tagTooltipRef,\n isFocused,\n isComposing,\n inputValue,\n size,\n tagSize,\n placeholder,\n closable,\n disabled,\n inputLimit,\n showTagList,\n collapseTagList,\n handleDragged,\n handleInput,\n handleKeydown,\n handleKeyup,\n handleAddTag,\n handleRemoveTag,\n handleClear,\n handleCompositionStart,\n handleCompositionUpdate,\n handleCompositionEnd,\n focus,\n blur,\n }\n}\n","import { ref } from 'vue'\n\nexport function useHovering() {\n const hovering = ref(false)\n\n const handleMouseEnter = () => {\n hovering.value = true\n }\n\n const handleMouseLeave = () => {\n hovering.value = false\n }\n\n return {\n hovering,\n handleMouseEnter,\n handleMouseLeave,\n }\n}\n","import { ref, shallowRef } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport { getStyle, isUndefined, setStyle } from '@element-plus/utils'\n\nimport type { ShallowRef } from 'vue'\n\ntype DropType = 'before' | 'after'\n\ninterface UseDragTagOptions {\n wrapperRef: ShallowRef\n handleDragged: (\n draggingIndex: number,\n dropIndex: number,\n type: DropType\n ) => void\n afterDragged?: () => void\n}\n\nexport function useDragTag({\n wrapperRef,\n handleDragged,\n afterDragged,\n}: UseDragTagOptions) {\n const ns = useNamespace('input-tag')\n const dropIndicatorRef = shallowRef()\n const showDropIndicator = ref(false)\n\n let draggingIndex: number | undefined\n let draggingTag: HTMLElement | null\n let dropIndex: number | undefined\n let dropType: DropType | undefined\n\n function getTagClassName(index: number) {\n return `.${ns.e('inner')} .${ns.namespace.value}-tag:nth-child(${\n index + 1\n })`\n }\n\n function handleDragStart(event: DragEvent, index: number) {\n draggingIndex = index\n draggingTag = wrapperRef.value!.querySelector(\n getTagClassName(index)\n )\n\n if (draggingTag) {\n draggingTag.style.opacity = '0.5'\n }\n event.dataTransfer!.effectAllowed = 'move'\n }\n\n function handleDragOver(event: DragEvent, index: number) {\n dropIndex = index\n event.preventDefault()\n event.dataTransfer!.dropEffect = 'move'\n\n if (isUndefined(draggingIndex) || draggingIndex === index) {\n showDropIndicator.value = false\n return\n }\n\n const dropPosition = wrapperRef\n .value!.querySelector(getTagClassName(index))!\n .getBoundingClientRect()\n const dropPrev = !(draggingIndex + 1 === index)\n const dropNext = !(draggingIndex - 1 === index)\n const distance = event.clientX - dropPosition.left\n const prevPercent = dropPrev ? (dropNext ? 0.5 : 1) : -1\n const nextPercent = dropNext ? (dropPrev ? 0.5 : 0) : 1\n\n if (distance <= dropPosition.width * prevPercent) {\n dropType = 'before'\n } else if (distance > dropPosition.width * nextPercent) {\n dropType = 'after'\n } else {\n dropType = undefined\n }\n\n const innerEl = wrapperRef.value!.querySelector(\n `.${ns.e('inner')}`\n )!\n const innerPosition = innerEl.getBoundingClientRect()\n const gap = Number.parseFloat(getStyle(innerEl, 'gap')) / 2\n\n const indicatorTop = dropPosition.top - innerPosition.top\n let indicatorLeft = -9999\n\n if (dropType === 'before') {\n indicatorLeft = Math.max(\n dropPosition.left - innerPosition.left - gap,\n Math.floor(-gap / 2)\n )\n } else if (dropType === 'after') {\n const left = dropPosition.right - innerPosition.left\n indicatorLeft =\n left + (innerPosition.width === left ? Math.floor(gap / 2) : gap)\n }\n\n setStyle(dropIndicatorRef.value!, {\n top: `${indicatorTop}px`,\n left: `${indicatorLeft}px`,\n })\n showDropIndicator.value = !!dropType\n }\n\n function handleDragEnd(event: DragEvent) {\n event.preventDefault()\n\n if (draggingTag) {\n draggingTag.style.opacity = ''\n }\n\n if (\n dropType &&\n !isUndefined(draggingIndex) &&\n !isUndefined(dropIndex) &&\n draggingIndex !== dropIndex\n ) {\n handleDragged(draggingIndex, dropIndex, dropType)\n }\n\n showDropIndicator.value = false\n draggingIndex = undefined\n draggingTag = null\n dropIndex = undefined\n dropType = undefined\n afterDragged?.()\n }\n\n return {\n dropIndicatorRef,\n showDropIndicator,\n handleDragStart,\n handleDragOver,\n handleDragEnd,\n }\n}\n","import { computed, reactive, ref, useAttrs, useSlots } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport { MINIMUM_INPUT_WIDTH } from '@element-plus/constants'\nimport { useResizeObserver } from '@vueuse/core'\n\nimport type { ComputedRef, Ref, StyleValue } from 'vue'\nimport type { ComponentSize } from '@element-plus/constants'\nimport type { InputTagProps } from '../input-tag'\n\ninterface UseInputTagDomOptions {\n props: InputTagProps\n isFocused: Ref\n hovering: Ref\n disabled: ComputedRef\n inputValue: Ref\n size: ComputedRef\n validateState: ComputedRef\n validateIcon: ComputedRef\n needStatusIcon: ComputedRef\n}\n\nexport function useInputTagDom({\n props,\n isFocused,\n hovering,\n disabled,\n inputValue,\n size,\n validateState,\n validateIcon,\n needStatusIcon,\n}: UseInputTagDomOptions) {\n const attrs = useAttrs()\n const slots = useSlots()\n const ns = useNamespace('input-tag')\n const nsInput = useNamespace('input')\n\n const collapseItemRef = ref()\n const innerRef = ref()\n\n const containerKls = computed(() => [\n ns.b(),\n ns.is('focused', isFocused.value),\n ns.is('hovering', hovering.value),\n ns.is('disabled', disabled.value),\n ns.m(size.value),\n ns.e('wrapper'),\n attrs.class,\n ])\n const containerStyle = computed(() => [attrs.style as StyleValue])\n const innerKls = computed(() => [\n ns.e('inner'),\n ns.is('draggable', props.draggable),\n ns.is('left-space', !props.modelValue?.length && !slots.prefix),\n ns.is('right-space', !props.modelValue?.length && !showSuffix.value),\n ])\n const showClear = computed(() => {\n return (\n props.clearable &&\n !disabled.value &&\n !props.readonly &&\n (props.modelValue?.length || inputValue.value) &&\n (isFocused.value || hovering.value)\n )\n })\n const showSuffix = computed(() => {\n return (\n slots.suffix ||\n showClear.value ||\n (validateState.value && validateIcon.value && needStatusIcon.value)\n )\n })\n\n const states = reactive({\n innerWidth: 0,\n collapseItemWidth: 0,\n })\n\n const getGapWidth = () => {\n if (!innerRef.value) return 0\n const style = window.getComputedStyle(innerRef.value)\n return Number.parseFloat(style.gap || '6px')\n }\n\n const resetInnerWidth = () => {\n states.innerWidth = Number.parseFloat(\n window.getComputedStyle(innerRef.value!).width\n )\n }\n\n const resetCollapseItemWidth = () => {\n states.collapseItemWidth =\n collapseItemRef.value!.getBoundingClientRect().width\n }\n\n const tagStyle = computed(() => {\n if (!props.collapseTags) return {}\n const gapWidth = getGapWidth()\n\n const inputSlotWidth = gapWidth + MINIMUM_INPUT_WIDTH\n\n const maxWidth =\n collapseItemRef.value && props.maxCollapseTags === 1\n ? states.innerWidth -\n states.collapseItemWidth -\n gapWidth -\n inputSlotWidth\n : states.innerWidth - inputSlotWidth\n\n return { maxWidth: `${Math.max(maxWidth, 0)}px` }\n })\n\n useResizeObserver(innerRef, resetInnerWidth)\n useResizeObserver(collapseItemRef, resetCollapseItemWidth)\n\n return {\n ns,\n nsInput,\n containerKls,\n containerStyle,\n innerKls,\n showClear,\n showSuffix,\n tagStyle,\n collapseItemRef,\n innerRef,\n }\n}\n","\n\n\n","import { withInstall } from '@element-plus/utils'\nimport InputTag from './src/input-tag.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElInputTag: SFCWithInstall = withInstall(InputTag)\nexport default ElInputTag\n\nexport * from './src/input-tag'\nexport type { InputTagInstance } from './src/instance'\n","import { buildProps, iconPropType } from '@element-plus/utils'\n\nimport type { ExtractPropTypes, PropType, __ExtractPublicPropTypes } from 'vue'\nimport type Link from './link.vue'\n\nexport const linkProps = buildProps({\n /**\n * @description type\n */\n type: {\n type: String,\n values: ['primary', 'success', 'warning', 'info', 'danger', 'default'],\n default: undefined,\n },\n /**\n * @description when underlines should appear\n */\n underline: {\n type: [Boolean, String],\n values: [true, false, 'always', 'never', 'hover'],\n default: undefined,\n },\n /**\n * @description whether the component is disabled\n */\n disabled: Boolean,\n /**\n * @description same as native hyperlink's `href`\n */\n href: { type: String, default: '' },\n /**\n * @description same as native hyperlink's `target`\n */\n target: {\n type: String as PropType<'_blank' | '_parent' | '_self' | '_top' | string>,\n default: '_self',\n },\n /**\n * @description icon component\n */\n icon: {\n type: iconPropType,\n },\n} as const)\nexport type LinkProps = ExtractPropTypes\nexport type LinkPropsPublic = __ExtractPublicPropTypes\n\nexport const linkEmits = {\n click: (evt: MouseEvent) => evt instanceof MouseEvent,\n}\nexport type LinkEmits = typeof linkEmits\n\nexport type LinkInstance = InstanceType & unknown\nexport interface LinkConfigContext {\n type?: string\n underline?: string | boolean\n}\n","\n\n\n","import { withInstall } from '@element-plus/utils'\nimport Link from './src/link.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElLink: SFCWithInstall = withInstall(Link)\nexport default ElLink\n\nexport * from './src/link'\n","// @ts-nocheck\nimport { getEventCode, triggerEvent } from '@element-plus/utils'\nimport { EVENT_CODE } from '@element-plus/constants'\n\nimport type MenuItem from './menu-item'\n\nclass SubMenu {\n public subMenuItems: NodeList\n public subIndex = 0\n constructor(\n public parent: MenuItem,\n public domNode: ParentNode\n ) {\n this.subIndex = 0\n this.init()\n }\n\n init(): void {\n this.subMenuItems = this.domNode.querySelectorAll('li')\n this.addListeners()\n }\n\n gotoSubIndex(idx: number): void {\n if (idx === this.subMenuItems.length) {\n idx = 0\n } else if (idx < 0) {\n idx = this.subMenuItems.length - 1\n }\n ;(this.subMenuItems[idx] as HTMLElement).focus()\n this.subIndex = idx\n }\n\n addListeners(): void {\n const parentNode = this.parent.domNode\n Array.prototype.forEach.call(this.subMenuItems, (el: Element) => {\n el.addEventListener('keydown', (event: KeyboardEvent) => {\n const code = getEventCode(event)\n let prevDef = false\n\n switch (code) {\n case EVENT_CODE.down: {\n this.gotoSubIndex(this.subIndex + 1)\n prevDef = true\n break\n }\n case EVENT_CODE.up: {\n this.gotoSubIndex(this.subIndex - 1)\n prevDef = true\n break\n }\n case EVENT_CODE.tab: {\n triggerEvent(parentNode as HTMLElement, 'mouseleave')\n break\n }\n case EVENT_CODE.enter:\n case EVENT_CODE.numpadEnter:\n case EVENT_CODE.space: {\n prevDef = true\n ;(event.currentTarget as HTMLElement).click()\n break\n }\n }\n if (prevDef) {\n event.preventDefault()\n event.stopPropagation()\n }\n return false\n })\n })\n }\n}\n\nexport default SubMenu\n","// @ts-nocheck\nimport { getEventCode, triggerEvent } from '@element-plus/utils'\nimport { EVENT_CODE } from '@element-plus/constants'\nimport SubMenu from './submenu'\n\nclass MenuItem {\n public submenu: SubMenu = null\n constructor(\n public domNode: HTMLElement,\n namespace: string\n ) {\n this.submenu = null\n this.init(namespace)\n }\n\n init(namespace: string): void {\n this.domNode.setAttribute('tabindex', '0')\n const menuChild = this.domNode.querySelector(`.${namespace}-menu`)\n if (menuChild) {\n this.submenu = new SubMenu(this, menuChild)\n }\n this.addListeners()\n }\n\n addListeners(): void {\n this.domNode.addEventListener('keydown', (event: KeyboardEvent) => {\n const code = getEventCode(event)\n let prevDef = false\n\n switch (code) {\n case EVENT_CODE.down: {\n triggerEvent(event.currentTarget as HTMLElement, 'mouseenter')\n this.submenu && this.submenu.gotoSubIndex(0)\n prevDef = true\n break\n }\n case EVENT_CODE.up: {\n triggerEvent(event.currentTarget as HTMLElement, 'mouseenter')\n this.submenu &&\n this.submenu.gotoSubIndex(this.submenu.subMenuItems.length - 1)\n prevDef = true\n break\n }\n case EVENT_CODE.tab: {\n triggerEvent(event.currentTarget as HTMLElement, 'mouseleave')\n break\n }\n case EVENT_CODE.enter:\n case EVENT_CODE.numpadEnter:\n case EVENT_CODE.space: {\n prevDef = true\n ;(event.currentTarget as HTMLElement).click()\n break\n }\n }\n if (prevDef) {\n event.preventDefault()\n }\n })\n }\n}\n\nexport default MenuItem\n","import MenuItem from './menu-item'\n\nimport type { RendererNode } from 'vue'\n\nclass Menu {\n constructor(\n public domNode: RendererNode,\n namespace: string\n ) {\n this.init(namespace)\n }\n init(namespace: string): void {\n const menuChildren = this.domNode.childNodes\n Array.from(menuChildren).forEach((child) => {\n if (child.nodeType === 1) {\n new MenuItem(child as HTMLElement, namespace)\n }\n })\n }\n}\n\nexport default Menu\n","\n\n\n","import { computed } from 'vue'\n\nimport type { ComponentInternalInstance, Ref } from 'vue'\n\nexport default function useMenu(\n instance: ComponentInternalInstance,\n currentIndex: Ref\n) {\n const indexPath = computed(() => {\n let parent = instance.parent!\n const path = [currentIndex.value]\n while (parent.type.name !== 'ElMenu') {\n if (parent.props.index) {\n path.unshift(parent.props.index as string)\n }\n parent = parent.parent!\n }\n return path\n })\n\n const parentMenu = computed(() => {\n let parent = instance.parent\n while (parent && !['ElMenu', 'ElSubMenu'].includes(parent.type.name!)) {\n parent = parent.parent\n }\n return parent!\n })\n\n return {\n parentMenu,\n indexPath,\n }\n}\n","import { computed } from 'vue'\nimport { TinyColor } from '@ctrl/tinycolor'\n\nimport type { MenuProps } from './menu'\n\nexport default function useMenuColor(props: MenuProps) {\n const menuBarColor = computed(() => {\n const color = props.backgroundColor\n return color ? new TinyColor(color).shade(20).toString() : ''\n })\n return menuBarColor\n}\n","import { computed } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport useMenuColor from './use-menu-color'\n\nimport type { MenuProps } from './menu'\n\nexport const useMenuCssVar = (props: MenuProps, level: number) => {\n const ns = useNamespace('menu')\n return computed(() =>\n ns.cssVarBlock({\n 'text-color': props.textColor || '',\n 'hover-text-color': props.textColor || '',\n 'bg-color': props.backgroundColor || '',\n 'hover-bg-color': useMenuColor(props).value || '',\n 'active-color': props.activeTextColor || '',\n level: `${level}`,\n })\n )\n}\n","export const MENU_INJECTION_KEY = 'rootMenu'\n\nexport const SUB_MENU_INJECTION_KEY = 'subMenu:'\n","import {\n Fragment,\n computed,\n defineComponent,\n getCurrentInstance,\n h,\n inject,\n nextTick,\n onBeforeUnmount,\n onMounted,\n provide,\n reactive,\n ref,\n vShow,\n watch,\n withDirectives,\n} from 'vue'\nimport { useTimeoutFn } from '@vueuse/core'\nimport ElCollapseTransition from '@element-plus/components/collapse-transition'\nimport ElTooltip from '@element-plus/components/tooltip'\nimport {\n buildProps,\n definePropType,\n focusElement,\n iconPropType,\n isString,\n isUndefined,\n throwError,\n} from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport { ArrowDown, ArrowRight } from '@element-plus/icons-vue'\nimport { ElIcon } from '@element-plus/components/icon'\nimport useMenu from './use-menu'\nimport { useMenuCssVar } from './use-menu-css-var'\nimport { MENU_INJECTION_KEY, SUB_MENU_INJECTION_KEY } from './tokens'\n\nimport type { Placement } from '@element-plus/components/popper'\nimport type { TooltipInstance } from '@element-plus/components/tooltip'\nimport type {\n CSSProperties,\n ExtractPropTypes,\n VNodeArrayChildren,\n __ExtractPublicPropTypes,\n} from 'vue'\nimport type { MenuProvider, SubMenuProvider } from './types'\n\nexport const subMenuProps = buildProps({\n /**\n * @description unique identification\n */\n index: {\n type: String,\n required: true,\n },\n /**\n * @description timeout before showing a sub-menu(inherit `show-timeout` of the menu by default.)\n */\n showTimeout: Number,\n /**\n * @description timeout before hiding a sub-menu(inherit `hide-timeout` of the menu by default.)\n */\n hideTimeout: Number,\n /**\n * @description custom class name for the popup menu\n */\n popperClass: String,\n /**\n * @description custom style for the popup menu\n */\n popperStyle: {\n type: definePropType([String, Object]),\n },\n /**\n * @description whether the sub-menu is disabled\n */\n disabled: Boolean,\n /**\n * @description whether popup menu is teleported to the body\n */\n teleported: {\n type: Boolean,\n default: undefined,\n },\n /**\n * @description offset of the popper (overrides the `popper` of menu)\n */\n popperOffset: Number,\n /**\n * @description Icon when menu are expanded and submenu are closed, `expand-close-icon` and `expand-open-icon` need to be passed together to take effect\n */\n expandCloseIcon: {\n type: iconPropType,\n },\n /**\n * @description Icon when menu are expanded and submenu are opened, `expand-open-icon` and `expand-close-icon` need to be passed together to take effect\n */\n expandOpenIcon: {\n type: iconPropType,\n },\n /**\n * @description Icon when menu are collapsed and submenu are closed, `collapse-close-icon` and `collapse-open-icon` need to be passed together to take effect\n */\n collapseCloseIcon: {\n type: iconPropType,\n },\n /**\n * @description Icon when menu are collapsed and submenu are opened, `collapse-open-icon` and `collapse-close-icon` need to be passed together to take effect\n */\n collapseOpenIcon: {\n type: iconPropType,\n },\n} as const)\nexport type SubMenuProps = ExtractPropTypes\nexport type SubMenuPropsPublic = __ExtractPublicPropTypes\n\nconst COMPONENT_NAME = 'ElSubMenu'\nexport default defineComponent({\n name: COMPONENT_NAME,\n props: subMenuProps,\n\n setup(props, { slots, expose }) {\n const instance = getCurrentInstance()!\n const { indexPath, parentMenu } = useMenu(\n instance,\n computed(() => props.index)\n )\n const nsMenu = useNamespace('menu')\n const nsSubMenu = useNamespace('sub-menu')\n\n // inject\n const rootMenu = inject(MENU_INJECTION_KEY)\n if (!rootMenu) throwError(COMPONENT_NAME, 'can not inject root menu')\n\n const subMenu = inject(\n `${SUB_MENU_INJECTION_KEY}${parentMenu.value!.uid}`\n )\n if (!subMenu) throwError(COMPONENT_NAME, 'can not inject sub menu')\n\n const items = ref({})\n const subMenus = ref({})\n\n let timeout: (() => void) | undefined\n const mouseInChild = ref(false)\n const verticalTitleRef = ref()\n const vPopper = ref()\n\n // computed\n const isFirstLevel = computed(() => subMenu.level === 0)\n const currentPlacement = computed(() =>\n mode.value === 'horizontal' && isFirstLevel.value\n ? 'bottom-start'\n : 'right-start'\n )\n const subMenuTitleIcon = computed(() => {\n const isExpandedMode =\n (mode.value === 'horizontal' && isFirstLevel.value) ||\n (mode.value === 'vertical' && !rootMenu.props.collapse)\n\n if (isExpandedMode) {\n if (props.expandCloseIcon && props.expandOpenIcon) {\n return opened.value ? props.expandOpenIcon : props.expandCloseIcon\n }\n return ArrowDown\n } else {\n if (props.collapseCloseIcon && props.collapseOpenIcon) {\n return opened.value ? props.collapseOpenIcon : props.collapseCloseIcon\n }\n return ArrowRight\n }\n })\n\n const appendToBody = computed(() => {\n const value = props.teleported\n return isUndefined(value) ? isFirstLevel.value : value\n })\n const menuTransitionName = computed(() =>\n rootMenu.props.collapse\n ? `${nsMenu.namespace.value}-zoom-in-left`\n : `${nsMenu.namespace.value}-zoom-in-top`\n )\n const fallbackPlacements = computed(() =>\n mode.value === 'horizontal' && isFirstLevel.value\n ? [\n 'bottom-start',\n 'bottom-end',\n 'top-start',\n 'top-end',\n 'right-start',\n 'left-start',\n ]\n : [\n 'right-start',\n 'right',\n 'right-end',\n 'left-start',\n 'bottom-start',\n 'bottom-end',\n 'top-start',\n 'top-end',\n ]\n )\n const opened = computed(() => rootMenu.openedMenus.includes(props.index))\n const active = computed(() =>\n [...Object.values(items.value), ...Object.values(subMenus.value)].some(\n ({ active }) => active\n )\n )\n\n const mode = computed(() => rootMenu.props.mode)\n const persistent = computed(() => rootMenu.props.persistent)\n const item = reactive({\n index: props.index,\n indexPath,\n active,\n })\n\n const ulStyle = useMenuCssVar(rootMenu.props, subMenu.level + 1)\n\n const subMenuPopperOffset = computed(\n () => props.popperOffset ?? rootMenu.props.popperOffset\n )\n\n const subMenuPopperClass = computed(\n () => props.popperClass ?? rootMenu.props.popperClass\n )\n\n const subMenuPopperStyle = computed(\n () => props.popperStyle ?? rootMenu.props.popperStyle\n )\n\n const subMenuShowTimeout = computed(\n () => props.showTimeout ?? rootMenu.props.showTimeout\n )\n\n const subMenuHideTimeout = computed(\n () => props.hideTimeout ?? rootMenu.props.hideTimeout\n )\n\n // methods\n const doDestroy = () =>\n vPopper.value?.popperRef?.popperInstanceRef?.destroy()\n\n const handleCollapseToggle = (value: boolean) => {\n if (!value) {\n doDestroy()\n }\n }\n\n const handleClick = () => {\n if (\n (rootMenu.props.menuTrigger === 'hover' &&\n rootMenu.props.mode === 'horizontal') ||\n (rootMenu.props.collapse && rootMenu.props.mode === 'vertical') ||\n props.disabled\n )\n return\n\n rootMenu.handleSubMenuClick({\n index: props.index,\n indexPath: indexPath.value,\n active: active.value,\n })\n }\n\n const handleMouseenter = (\n event: MouseEvent | FocusEvent,\n showTimeout = subMenuShowTimeout.value\n ) => {\n if (event.type === 'focus') return\n\n if (\n (rootMenu.props.menuTrigger === 'click' &&\n rootMenu.props.mode === 'horizontal') ||\n (!rootMenu.props.collapse && rootMenu.props.mode === 'vertical') ||\n props.disabled\n ) {\n subMenu.mouseInChild.value = true\n return\n }\n subMenu.mouseInChild.value = true\n\n timeout?.()\n ;({ stop: timeout } = useTimeoutFn(() => {\n rootMenu.openMenu(props.index, indexPath.value)\n }, showTimeout))\n\n if (appendToBody.value) {\n parentMenu.value.vnode.el?.dispatchEvent(new MouseEvent('mouseenter'))\n }\n\n if (event.type === 'mouseenter' && event.target) {\n nextTick(() => {\n focusElement(event.target as HTMLElement, { preventScroll: true })\n })\n }\n }\n\n const handleMouseleave = (deepDispatch = false) => {\n if (\n (rootMenu.props.menuTrigger === 'click' &&\n rootMenu.props.mode === 'horizontal') ||\n (!rootMenu.props.collapse && rootMenu.props.mode === 'vertical')\n ) {\n subMenu.mouseInChild.value = false\n return\n }\n timeout?.()\n subMenu.mouseInChild.value = false\n ;({ stop: timeout } = useTimeoutFn(\n () =>\n !mouseInChild.value &&\n rootMenu.closeMenu(props.index, indexPath.value),\n subMenuHideTimeout.value\n ))\n\n if (appendToBody.value && deepDispatch) {\n subMenu.handleMouseleave?.(true)\n }\n }\n\n watch(\n () => rootMenu.props.collapse,\n (value) => handleCollapseToggle(Boolean(value))\n )\n\n // provide\n {\n const addSubMenu: SubMenuProvider['addSubMenu'] = (item) => {\n subMenus.value[item.index] = item\n }\n const removeSubMenu: SubMenuProvider['removeSubMenu'] = (item) => {\n delete subMenus.value[item.index]\n }\n provide(`${SUB_MENU_INJECTION_KEY}${instance.uid}`, {\n addSubMenu,\n removeSubMenu,\n handleMouseleave,\n mouseInChild,\n level: subMenu.level + 1,\n })\n }\n\n // expose\n expose({\n opened,\n })\n\n // lifecycle\n onMounted(() => {\n rootMenu.addSubMenu(item)\n subMenu.addSubMenu(item)\n })\n\n onBeforeUnmount(() => {\n subMenu.removeSubMenu(item)\n rootMenu.removeSubMenu(item)\n })\n\n return () => {\n const titleTag: VNodeArrayChildren = [\n slots.title?.(),\n h(\n ElIcon,\n {\n class: nsSubMenu.e('icon-arrow'),\n style: {\n transform: opened.value\n ? (props.expandCloseIcon && props.expandOpenIcon) ||\n (props.collapseCloseIcon &&\n props.collapseOpenIcon &&\n rootMenu.props.collapse)\n ? 'none'\n : 'rotateZ(180deg)'\n : 'none',\n },\n },\n {\n default: () =>\n isString(subMenuTitleIcon.value)\n ? h(instance.appContext.components[subMenuTitleIcon.value])\n : h(subMenuTitleIcon.value),\n }\n ),\n ]\n\n // this render function is only used for bypass `Vue`'s compiler caused patching issue.\n const child = rootMenu.isMenuPopup\n ? h(\n ElTooltip,\n {\n ref: vPopper,\n visible: opened.value,\n effect: 'light',\n pure: true,\n offset: subMenuPopperOffset.value,\n showArrow: false,\n persistent: persistent.value,\n popperClass: subMenuPopperClass.value,\n popperStyle: subMenuPopperStyle.value,\n placement: currentPlacement.value,\n teleported: appendToBody.value,\n fallbackPlacements: fallbackPlacements.value,\n transition: menuTransitionName.value,\n gpuAcceleration: false,\n },\n {\n content: () =>\n h(\n 'div',\n {\n class: [\n nsMenu.m(mode.value),\n nsMenu.m('popup-container'),\n subMenuPopperClass.value,\n ],\n onMouseenter: (evt: MouseEvent) =>\n handleMouseenter(evt, 100),\n onMouseleave: () => handleMouseleave(true),\n onFocus: (evt: FocusEvent) => handleMouseenter(evt, 100),\n },\n [\n h(\n 'ul',\n {\n class: [\n nsMenu.b(),\n nsMenu.m('popup'),\n nsMenu.m(`popup-${currentPlacement.value}`),\n ],\n style: ulStyle.value,\n },\n [slots.default?.()]\n ),\n ]\n ),\n default: () =>\n h(\n 'div',\n {\n class: nsSubMenu.e('title'),\n onClick: handleClick,\n },\n titleTag\n ),\n }\n )\n : h(Fragment, {}, [\n h(\n 'div',\n {\n class: nsSubMenu.e('title'),\n ref: verticalTitleRef,\n onClick: handleClick,\n },\n titleTag\n ),\n h(\n ElCollapseTransition,\n {},\n {\n default: () =>\n withDirectives(\n h(\n 'ul',\n {\n role: 'menu',\n class: [nsMenu.b(), nsMenu.m('inline')],\n style: ulStyle.value,\n },\n [slots.default?.()]\n ),\n [[vShow, opened.value]]\n ),\n }\n ),\n ])\n\n return h(\n 'li',\n {\n class: [\n nsSubMenu.b(),\n nsSubMenu.is('active', active.value),\n nsSubMenu.is('opened', opened.value),\n nsSubMenu.is('disabled', props.disabled),\n ],\n role: 'menuitem',\n ariaHaspopup: true,\n ariaExpanded: opened.value,\n onMouseenter: handleMouseenter,\n onMouseleave: () => handleMouseleave(),\n onFocus: handleMouseenter,\n },\n [child]\n )\n }\n },\n})\n","import {\n computed,\n defineComponent,\n getCurrentInstance,\n h,\n nextTick,\n onMounted,\n provide,\n reactive,\n ref,\n watch,\n watchEffect,\n withDirectives,\n} from 'vue'\nimport { unrefElement, useResizeObserver } from '@vueuse/core'\nimport { isNil } from 'lodash-unified'\nimport ElIcon from '@element-plus/components/icon'\nimport { More } from '@element-plus/icons-vue'\nimport {\n buildProps,\n definePropType,\n flattedChildren,\n iconPropType,\n isArray,\n isObject,\n isString,\n isUndefined,\n mutable,\n} from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport { ClickOutside as vClickoutside } from '@element-plus/directives'\nimport Menubar from './utils/menu-bar'\nimport ElMenuCollapseTransition from './menu-collapse-transition.vue'\nimport ElSubMenu from './sub-menu'\nimport { useMenuCssVar } from './use-menu-css-var'\nimport { MENU_INJECTION_KEY, SUB_MENU_INJECTION_KEY } from './tokens'\n\nimport type { PopperEffect } from '@element-plus/components/popper'\nimport type { MenuItemClicked, MenuProvider, SubMenuProvider } from './types'\nimport type { NavigationFailure, Router } from 'vue-router'\nimport type {\n CSSProperties,\n Component,\n DirectiveArguments,\n ExtractPropTypes,\n VNode,\n VNodeArrayChildren,\n __ExtractPublicPropTypes,\n} from 'vue'\nimport type { UseResizeObserverReturn } from '@vueuse/core'\n\nexport const menuProps = buildProps({\n /**\n * @description menu display mode\n */\n mode: {\n type: String,\n values: ['horizontal', 'vertical'],\n default: 'vertical',\n },\n /**\n * @description index of active menu on page load\n */\n defaultActive: {\n type: String,\n default: '',\n },\n /**\n * @description array that contains indexes of currently active sub-menus\n */\n defaultOpeneds: {\n type: definePropType(Array),\n default: () => mutable([] as const),\n },\n /**\n * @description whether only one sub-menu can be active\n */\n uniqueOpened: Boolean,\n /**\n * @description whether `vue-router` mode is activated. If true, index will be used as 'path' to activate the route action. Use with `default-active` to set the active item on load.\n */\n router: Boolean,\n /**\n * @description how sub-menus are triggered, only works when `mode` is 'horizontal'\n */\n menuTrigger: {\n type: String,\n values: ['hover', 'click'],\n default: 'hover',\n },\n /**\n * @description whether the menu is collapsed (available only in vertical mode)\n */\n collapse: Boolean,\n /**\n * @description background color of Menu (hex format) (deprecated, use `--bg-color` instead)\n * @deprecated use `--bg-color` instead\n */\n backgroundColor: String,\n /**\n * @description text color of Menu (hex format) (deprecated, use `--text-color` instead)\n * @deprecated use `--text-color` instead\n */\n textColor: String,\n /**\n * @description text color of currently active menu item (hex format) (deprecated, use `--active-color` instead)\n * @deprecated use `--active-color` instead\n */\n activeTextColor: String,\n /**\n * @description optional, whether menu is collapsed when clicking outside\n */\n closeOnClickOutside: Boolean,\n /**\n * @description whether to enable the collapse transition\n */\n collapseTransition: {\n type: Boolean,\n default: true,\n },\n /**\n * @description whether the menu is ellipsis (available only in horizontal mode)\n */\n ellipsis: {\n type: Boolean,\n default: true,\n },\n /**\n * @description offset of the popper (effective for all submenus)\n */\n popperOffset: {\n type: Number,\n default: 6,\n },\n /**\n * @description custom ellipsis icon (available only in horizontal mode and ellipsis is true)\n */\n ellipsisIcon: {\n type: iconPropType,\n default: () => More,\n },\n /**\n * @description Tooltip theme, built-in theme: `dark` / `light` when menu is collapsed\n */\n popperEffect: {\n type: definePropType(String),\n default: 'dark',\n },\n /**\n * @description custom class name for all popup menus\n */\n popperClass: String,\n /**\n * @description custom style for all popup menus\n */\n popperStyle: {\n type: definePropType([String, Object]),\n },\n /**\n * @description control timeout for all menus before showing\n */\n showTimeout: {\n type: Number,\n default: 300,\n },\n /**\n * @description control timeout for all menus before hiding\n */\n hideTimeout: {\n type: Number,\n default: 300,\n },\n /**\n * @description when menu inactive and `persistent` is `false` , dropdown menu will be destroyed\n */\n persistent: {\n type: Boolean,\n default: true,\n },\n} as const)\nexport type MenuProps = ExtractPropTypes\nexport type MenuPropsPublic = __ExtractPublicPropTypes\n\nconst checkIndexPath = (indexPath: unknown): indexPath is string[] =>\n isArray(indexPath) && indexPath.every((path) => isString(path))\n\nexport const menuEmits = {\n close: (index: string, indexPath: string[]) =>\n isString(index) && checkIndexPath(indexPath),\n\n open: (index: string, indexPath: string[]) =>\n isString(index) && checkIndexPath(indexPath),\n\n select: (\n index: string,\n indexPath: string[],\n item: MenuItemClicked,\n routerResult?: Promise\n ) =>\n isString(index) &&\n checkIndexPath(indexPath) &&\n isObject(item) &&\n (isUndefined(routerResult) || routerResult instanceof Promise),\n}\nexport type MenuEmits = typeof menuEmits\n\nconst DEFAULT_MORE_ITEM_WIDTH = 64\n\nexport default defineComponent({\n name: 'ElMenu',\n\n props: menuProps,\n emits: menuEmits,\n\n setup(props, { emit, slots, expose }) {\n const instance = getCurrentInstance()!\n const router = instance.appContext.config.globalProperties.$router as Router\n const menu = ref()\n const subMenu = ref()\n const nsMenu = useNamespace('menu')\n const nsSubMenu = useNamespace('sub-menu')\n let moreItemWidth = DEFAULT_MORE_ITEM_WIDTH\n\n // data\n const sliceIndex = ref(-1)\n\n const openedMenus = ref(\n props.defaultOpeneds && !props.collapse\n ? props.defaultOpeneds.slice(0)\n : []\n )\n const activeIndex = ref(props.defaultActive)\n const items = ref({})\n const subMenus = ref({})\n\n // computed\n const isMenuPopup = computed(\n () =>\n props.mode === 'horizontal' ||\n (props.mode === 'vertical' && props.collapse)\n )\n\n // methods\n const initMenu = () => {\n const activeItem = activeIndex.value && items.value[activeIndex.value]\n if (!activeItem || props.mode === 'horizontal' || props.collapse) return\n\n const indexPath = activeItem.indexPath\n\n // 展开该菜单项的路径上所有子菜单\n // expand all subMenus of the menu item\n indexPath.forEach((index) => {\n const subMenu = subMenus.value[index]\n subMenu && openMenu(index, subMenu.indexPath)\n })\n }\n\n const openMenu: MenuProvider['openMenu'] = (index, indexPath) => {\n if (openedMenus.value.includes(index)) return\n // 将不在该菜单路径下的其余菜单收起\n // collapse all menu that are not under current menu item\n if (props.uniqueOpened) {\n openedMenus.value = openedMenus.value.filter((index: string) =>\n indexPath.includes(index)\n )\n }\n openedMenus.value.push(index)\n emit('open', index, indexPath)\n }\n\n const close = (index: string) => {\n const i = openedMenus.value.indexOf(index)\n if (i !== -1) {\n openedMenus.value.splice(i, 1)\n }\n }\n\n const closeMenu: MenuProvider['closeMenu'] = (index, indexPath) => {\n close(index)\n emit('close', index, indexPath)\n }\n\n const handleSubMenuClick: MenuProvider['handleSubMenuClick'] = ({\n index,\n indexPath,\n }) => {\n const isOpened = openedMenus.value.includes(index)\n\n isOpened ? closeMenu(index, indexPath) : openMenu(index, indexPath)\n }\n\n const handleMenuItemClick: MenuProvider['handleMenuItemClick'] = (\n menuItem\n ) => {\n if (props.mode === 'horizontal' || props.collapse) {\n openedMenus.value = []\n }\n const { index, indexPath } = menuItem\n if (isNil(index) || isNil(indexPath)) return\n\n if (props.router && router) {\n const route = menuItem.route || index\n const routerResult = router.push(route).then((res) => {\n if (!res) activeIndex.value = index\n return res\n })\n emit(\n 'select',\n index,\n indexPath,\n { index, indexPath, route },\n routerResult\n )\n } else {\n activeIndex.value = index\n emit('select', index, indexPath, { index, indexPath })\n }\n }\n\n const updateActiveIndex = (val: string) => {\n const itemsInData = items.value\n const item =\n itemsInData[val] ||\n (activeIndex.value && itemsInData[activeIndex.value]) ||\n itemsInData[props.defaultActive]\n\n activeIndex.value = item?.index ?? val\n }\n\n const calcMenuItemWidth = (menuItem: HTMLElement) => {\n const computedStyle = getComputedStyle(menuItem)\n const marginLeft = Number.parseInt(computedStyle.marginLeft, 10)\n const marginRight = Number.parseInt(computedStyle.marginRight, 10)\n return menuItem.offsetWidth + marginLeft + marginRight || 0\n }\n\n const calcSliceIndex = () => {\n if (!menu.value) return -1\n\n const items = Array.from(menu.value.childNodes).filter(\n (item) =>\n item.nodeName !== '#comment' &&\n (item.nodeName !== '#text' || item.nodeValue)\n ) as HTMLElement[]\n\n const computedMenuStyle = getComputedStyle(menu.value)\n const paddingLeft = Number.parseInt(computedMenuStyle.paddingLeft, 10)\n const paddingRight = Number.parseInt(computedMenuStyle.paddingRight, 10)\n const menuWidth = menu.value.clientWidth - paddingLeft - paddingRight\n\n let calcWidth = 0\n let sliceIndex = 0\n items.forEach((item, index) => {\n calcWidth += calcMenuItemWidth(item)\n if (calcWidth <= menuWidth - moreItemWidth) {\n sliceIndex = index + 1\n }\n })\n return sliceIndex === items.length ? -1 : sliceIndex\n }\n\n const getIndexPath = (index: string) => subMenus.value[index].indexPath\n\n // Common computer monitor FPS is 60Hz, which means 60 redraws per second. Calculation formula: 1000ms/60 ≈ 16.67ms, In order to avoid a certain chance of repeated triggering when `resize`, set wait to 16.67 * 2 = 33.34\n const debounce = (fn: () => void, wait = 33.34) => {\n let timer: ReturnType | null\n return () => {\n timer && clearTimeout(timer)\n timer = setTimeout(() => {\n fn()\n }, wait)\n }\n }\n\n let isFirstTimeRender = true\n const handleResize = () => {\n const el = unrefElement(subMenu)\n if (el) moreItemWidth = calcMenuItemWidth(el) || DEFAULT_MORE_ITEM_WIDTH\n if (sliceIndex.value === calcSliceIndex()) return\n const callback = () => {\n sliceIndex.value = -1\n nextTick(() => {\n sliceIndex.value = calcSliceIndex()\n })\n }\n // execute callback directly when first time resize to avoid shaking\n isFirstTimeRender ? callback() : debounce(callback)()\n isFirstTimeRender = false\n }\n\n watch(\n () => props.defaultActive,\n (currentActive) => {\n if (!items.value[currentActive]) {\n activeIndex.value = ''\n }\n updateActiveIndex(currentActive)\n }\n )\n\n watch(\n () => props.collapse,\n (value) => {\n if (value) openedMenus.value = []\n }\n )\n\n watch(items.value, initMenu)\n\n let resizeStopper: UseResizeObserverReturn['stop']\n watchEffect(() => {\n if (props.mode === 'horizontal' && props.ellipsis)\n resizeStopper = useResizeObserver(menu, handleResize).stop\n else resizeStopper?.()\n })\n\n const mouseInChild = ref(false)\n\n // provide\n {\n const addSubMenu: MenuProvider['addSubMenu'] = (item) => {\n subMenus.value[item.index] = item\n }\n\n const removeSubMenu: MenuProvider['removeSubMenu'] = (item) => {\n delete subMenus.value[item.index]\n }\n\n const addMenuItem: MenuProvider['addMenuItem'] = (item) => {\n items.value[item.index] = item\n }\n\n const removeMenuItem: MenuProvider['removeMenuItem'] = (item) => {\n delete items.value[item.index]\n }\n\n provide(\n MENU_INJECTION_KEY,\n reactive({\n props,\n openedMenus,\n items,\n subMenus,\n activeIndex,\n isMenuPopup,\n\n addMenuItem,\n removeMenuItem,\n addSubMenu,\n removeSubMenu,\n openMenu,\n closeMenu,\n handleMenuItemClick,\n handleSubMenuClick,\n })\n )\n\n provide(`${SUB_MENU_INJECTION_KEY}${instance.uid}`, {\n addSubMenu,\n removeSubMenu,\n mouseInChild,\n level: 0,\n })\n }\n\n // lifecycle\n onMounted(() => {\n if (props.mode === 'horizontal') {\n new Menubar(instance.vnode.el!, nsMenu.namespace.value)\n }\n })\n\n {\n const open = (index: string) => {\n const { indexPath } = subMenus.value[index]\n indexPath.forEach((i) => openMenu(i, indexPath))\n }\n\n expose({\n open,\n close,\n updateActiveIndex,\n handleResize,\n })\n }\n\n const ulStyle = useMenuCssVar(props, 0)\n\n return () => {\n let slot: VNodeArrayChildren = slots.default?.() ?? []\n const vShowMore: VNode[] = []\n\n if (props.mode === 'horizontal' && menu.value) {\n const originalSlot = (\n flattedChildren(slot) as VNodeArrayChildren\n ).filter((vnode) => {\n // Filter text and comment nodes (https://github.com/vuejs/core/blob/c875019d49b4c36a88d929ccadc31ad414747c7b/packages/shared/src/shapeFlags.ts#L5)\n return (vnode as VNode)?.shapeFlag !== 8\n })\n const slotDefault =\n sliceIndex.value === -1\n ? originalSlot\n : originalSlot.slice(0, sliceIndex.value)\n\n const slotMore =\n sliceIndex.value === -1 ? [] : originalSlot.slice(sliceIndex.value)\n\n if (slotMore?.length && props.ellipsis) {\n slot = slotDefault\n vShowMore.push(\n h(\n ElSubMenu,\n {\n ref: subMenu,\n index: 'sub-menu-more',\n class: nsSubMenu.e('hide-arrow'),\n popperOffset: props.popperOffset,\n },\n {\n title: () =>\n h(\n ElIcon,\n {\n class: nsSubMenu.e('icon-more'),\n },\n {\n default: () => h(props.ellipsisIcon as Component),\n }\n ),\n default: () => slotMore,\n }\n )\n )\n }\n }\n\n const directives: DirectiveArguments = props.closeOnClickOutside\n ? [\n [\n vClickoutside,\n () => {\n if (!openedMenus.value.length) return\n\n if (!mouseInChild.value) {\n openedMenus.value.forEach((openedMenu) =>\n emit('close', openedMenu, getIndexPath(openedMenu))\n )\n\n openedMenus.value = []\n }\n },\n ],\n ]\n : []\n\n const vMenu = withDirectives(\n h(\n 'ul',\n {\n key: String(props.collapse),\n role: 'menubar',\n ref: menu,\n style: ulStyle.value,\n class: {\n [nsMenu.b()]: true,\n [nsMenu.m(props.mode)]: true,\n [nsMenu.m('collapse')]: props.collapse,\n },\n },\n [...slot, ...vShowMore]\n ),\n directives\n )\n\n if (props.collapseTransition && props.mode === 'vertical') {\n return h(ElMenuCollapseTransition, () => vMenu)\n }\n\n return vMenu\n }\n },\n})\n","import {\n buildProps,\n definePropType,\n isArray,\n isString,\n} from '@element-plus/utils'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type { RouteLocationRaw } from 'vue-router'\nimport type { MenuItemRegistered } from './types'\n\nexport const menuItemProps = buildProps({\n /**\n * @description unique identification\n */\n index: {\n type: definePropType([String, null]),\n // will be required in the next major version\n // required: true,\n default: null,\n },\n /**\n * @description Vue Router object\n */\n route: {\n type: definePropType([String, Object]),\n },\n /**\n * @description whether disabled\n */\n disabled: Boolean,\n} as const)\nexport type MenuItemProps = ExtractPropTypes\nexport type MenuItemPropsPublic = __ExtractPublicPropTypes\n\nexport const menuItemEmits = {\n click: (item: MenuItemRegistered) =>\n isString(item.index) && isArray(item.indexPath),\n}\nexport type MenuItemEmits = typeof menuItemEmits\n","\n\n\n","import type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\n\nexport const menuItemGroupProps = {\n /**\n * @description group title\n */\n title: String,\n} as const\nexport type MenuItemGroupProps = ExtractPropTypes\nexport type MenuItemGroupPropsPublic = __ExtractPublicPropTypes<\n typeof menuItemGroupProps\n>\n","\n\n\n","import { withInstall, withNoopInstall } from '@element-plus/utils'\nimport Menu from './src/menu'\nimport MenuItem from './src/menu-item.vue'\nimport MenuItemGroup from './src/menu-item-group.vue'\nimport SubMenu from './src/sub-menu'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElMenu: SFCWithInstall & {\n MenuItem: typeof MenuItem\n MenuItemGroup: typeof MenuItemGroup\n SubMenu: typeof SubMenu\n} = withInstall(Menu, {\n MenuItem,\n MenuItemGroup,\n SubMenu,\n})\nexport default ElMenu\nexport const ElMenuItem: SFCWithInstall =\n withNoopInstall(MenuItem)\nexport const ElMenuItemGroup: SFCWithInstall =\n withNoopInstall(MenuItemGroup)\nexport const ElSubMenu: SFCWithInstall =\n withNoopInstall(SubMenu)\n\nexport * from './src/menu'\nexport * from './src/menu-item'\nexport * from './src/menu-item-group'\nexport * from './src/sub-menu'\nexport * from './src/types'\nexport * from './src/instance'\nexport * from './src/tokens'\n","import { buildProps, iconPropType } from '@element-plus/utils'\nimport { Back } from '@element-plus/icons-vue'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type PageHeader from './page-header.vue'\n\nexport const pageHeaderProps = buildProps({\n /**\n * @description icon component of page header\n */\n icon: {\n type: iconPropType,\n default: () => Back,\n },\n /**\n * @description main title of page header\n */\n title: String,\n /**\n * @description content of page header\n */\n content: {\n type: String,\n default: '',\n },\n} as const)\nexport type PageHeaderProps = ExtractPropTypes\nexport type PageHeaderPropsPublic = __ExtractPublicPropTypes<\n typeof pageHeaderProps\n>\n\nexport const pageHeaderEmits = {\n back: () => true,\n}\nexport type PageHeaderEmits = typeof pageHeaderEmits\n\nexport type PageHeaderInstance = InstanceType & unknown\n","\n\n\n","import { withInstall } from '@element-plus/utils'\nimport PageHeader from './src/page-header.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElPageHeader: SFCWithInstall =\n withInstall(PageHeader)\nexport default ElPageHeader\n\nexport * from './src/page-header'\n","import { buttonTypes } from '@element-plus/components/button'\nimport { QuestionFilled } from '@element-plus/icons-vue'\nimport { buildProps, iconPropType } from '@element-plus/utils'\nimport {\n useTooltipContentProps,\n useTooltipTriggerProps,\n} from '@element-plus/components/tooltip'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type Popconfirm from './popconfirm.vue'\n\nexport const popconfirmProps = buildProps({\n /**\n * @description Title\n */\n title: String,\n /**\n * @description Confirm button text\n */\n confirmButtonText: String,\n /**\n * @description Cancel button text\n */\n cancelButtonText: String,\n /**\n * @description Confirm button type\n */\n confirmButtonType: {\n type: String,\n values: buttonTypes,\n default: 'primary',\n },\n /**\n * @description Cancel button type\n */\n cancelButtonType: {\n type: String,\n values: buttonTypes,\n default: 'text',\n },\n /**\n * @description Icon Component\n */\n icon: {\n type: iconPropType,\n default: () => QuestionFilled,\n },\n /**\n * @description Icon color\n */\n iconColor: {\n type: String,\n default: '#f90',\n },\n /**\n * @description is hide Icon\n */\n hideIcon: Boolean,\n /**\n * @description delay of disappear, in millisecond\n */\n hideAfter: {\n type: Number,\n default: 200,\n },\n /**\n * @description Tooltip theme, built-in theme: `dark` / `light`\n */\n effect: {\n ...useTooltipContentProps.effect,\n default: 'light',\n },\n /**\n * @description whether popconfirm is teleported to the body\n */\n teleported: useTooltipContentProps.teleported,\n /**\n * @description when popconfirm inactive and `persistent` is `false` , popconfirm will be destroyed\n */\n persistent: useTooltipContentProps.persistent,\n /**\n * @description popconfirm width, min width 150px\n */\n width: {\n type: [String, Number],\n default: 150,\n },\n virtualTriggering: useTooltipTriggerProps.virtualTriggering,\n virtualRef: useTooltipTriggerProps.virtualRef,\n} as const)\n\nexport const popconfirmEmits = {\n /**\n * @description triggers when click confirm button\n */\n confirm: (e: MouseEvent) => e instanceof MouseEvent,\n /**\n * @description triggers when click cancel button\n */\n cancel: (e: MouseEvent) => e instanceof MouseEvent,\n}\n\nexport type PopconfirmEmits = typeof popconfirmEmits\n\nexport type PopconfirmProps = ExtractPropTypes\nexport type PopconfirmPropsPublic = __ExtractPublicPropTypes<\n typeof popconfirmProps\n>\n\nexport type PopconfirmInstance = InstanceType & unknown\n","\n\n\n","import { withInstall } from '@element-plus/utils'\nimport Popconfirm from './src/popconfirm.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElPopconfirm: SFCWithInstall =\n withInstall(Popconfirm)\nexport default ElPopconfirm\n\nexport * from './src/popconfirm'\n","import { buildProps, isBoolean } from '@element-plus/utils'\nimport {\n useTooltipContentProps,\n useTooltipTriggerProps,\n} from '@element-plus/components/tooltip'\nimport { dropdownProps } from '@element-plus/components/dropdown'\n\nimport type { ExtractPropTypes, PropType, __ExtractPublicPropTypes } from 'vue'\nimport type Popover from './popover.vue'\n\nexport const popoverProps = buildProps({\n /**\n * @description how the popover is triggered, not valid in controlled mode\n */\n trigger: useTooltipTriggerProps.trigger,\n /**\n * @description When you click the mouse to focus on the trigger element, you can define a set of keyboard codes to control the display of popover through the keyboard, not valid in controlled mode\n */\n triggerKeys: useTooltipTriggerProps.triggerKeys,\n /**\n * @description popover placement\n */\n placement: dropdownProps.placement,\n /**\n * @description whether Popover is disabled\n */\n disabled: useTooltipTriggerProps.disabled,\n /**\n * @description whether popover is visible\n */\n visible: useTooltipContentProps.visible,\n /**\n * @description popover transition animation\n */\n transition: useTooltipContentProps.transition,\n /**\n * @description parameters for [popper.js](https://popper.js.org/docs/v2/)\n */\n popperOptions: dropdownProps.popperOptions,\n /**\n * @description [tabindex](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/tabindex) of Popover\n */\n tabindex: dropdownProps.tabindex,\n /**\n * @description popover content, can be replaced with a default `slot`\n */\n content: useTooltipContentProps.content,\n /**\n * @description custom style for popover\n */\n popperStyle: useTooltipContentProps.popperStyle,\n /**\n * @description custom class name for popover\n */\n popperClass: useTooltipContentProps.popperClass,\n enterable: {\n ...useTooltipContentProps.enterable,\n default: true,\n },\n /**\n * @description Tooltip theme, built-in theme: `dark` / `light`\n */\n effect: {\n ...useTooltipContentProps.effect,\n default: 'light',\n },\n /**\n * @description whether popover dropdown is teleported to the body\n */\n teleported: useTooltipContentProps.teleported,\n /**\n * @description which select dropdown appends to\n */\n appendTo: useTooltipContentProps.appendTo,\n /**\n * @description popover title\n */\n title: String,\n /**\n * @description popover width\n */\n width: {\n type: [String, Number],\n default: 150,\n },\n /**\n * @description popover offset\n */\n offset: {\n type: Number,\n default: undefined,\n },\n /**\n * @description delay of appearance, in millisecond, not valid in controlled mode\n */\n showAfter: {\n type: Number,\n default: 0,\n },\n /**\n * @description delay of disappear, in millisecond, not valid in controlled mode\n */\n hideAfter: {\n type: Number,\n default: 200,\n },\n /**\n * @description timeout in milliseconds to hide tooltip, not valid in controlled mode\n */\n autoClose: {\n type: Number,\n default: 0,\n },\n /**\n * @description whether a tooltip arrow is displayed or not. For more info, please refer to [ElPopper](https://github.com/element-plus/element-plus/tree/dev/packages/components/popper)\n */\n showArrow: {\n type: Boolean,\n default: true,\n },\n /**\n * @description when popover inactive and `persistent` is `false` , popover will be destroyed\n */\n persistent: {\n type: Boolean,\n default: true,\n },\n 'onUpdate:visible': {\n type: Function as PropType<(visible: boolean) => void>,\n },\n} as const)\nexport type PopoverProps = ExtractPropTypes\nexport type PopoverPropsPublic = __ExtractPublicPropTypes\n\nexport const popoverEmits = {\n 'update:visible': (value: boolean) => isBoolean(value),\n 'before-enter': () => true,\n 'before-leave': () => true,\n 'after-enter': () => true,\n 'after-leave': () => true,\n}\nexport type PopoverEmits = typeof popoverEmits\n\nexport type PopoverInstance = InstanceType & unknown\n","\n\n\n","import type { DirectiveBinding, ObjectDirective } from 'vue'\nimport type { PopoverInstance } from './popover'\n\nconst attachEvents = (el: HTMLElement, binding: DirectiveBinding) => {\n const popperComponent: PopoverInstance = binding.arg || binding.value\n const popover = popperComponent?.popperRef\n if (popover) {\n popover.triggerRef = el\n }\n}\n\nexport default {\n mounted(el, binding) {\n attachEvents(el, binding)\n },\n updated(el, binding) {\n attachEvents(el, binding)\n },\n} as ObjectDirective\n\nexport const VPopover = 'popover'\n","import { withInstall, withInstallDirective } from '@element-plus/utils'\nimport Popover from './src/popover.vue'\nimport PopoverDirective, { VPopover } from './src/directive'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElPopoverDirective: SFCWithInstall =\n withInstallDirective(PopoverDirective, VPopover)\n\nexport const ElPopover: SFCWithInstall & {\n directive: typeof ElPopoverDirective\n} = withInstall(Popover, {\n directive: ElPopoverDirective,\n})\nexport default ElPopover\n\nexport * from './src/popover'\n","import { Star, StarFilled } from '@element-plus/icons-vue'\nimport { CHANGE_EVENT, UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport {\n buildProps,\n definePropType,\n iconPropType,\n isNumber,\n mutable,\n} from '@element-plus/utils'\nimport { useAriaProps, useSizeProp } from '@element-plus/hooks'\n\nimport type { Component, ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type Rate from './rate.vue'\n\nexport const rateProps = buildProps({\n /**\n * @description binding value\n */\n modelValue: {\n type: Number,\n default: 0,\n },\n /**\n * @description native `id` attribute\n */\n id: {\n type: String,\n default: undefined,\n },\n /**\n * @description threshold value between low and medium level. The value itself will be included in low level\n */\n lowThreshold: {\n type: Number,\n default: 2,\n },\n /**\n * @description threshold value between medium and high level. The value itself will be included in high level\n */\n highThreshold: {\n type: Number,\n default: 4,\n },\n /**\n * @description max rating score\n */\n max: {\n type: Number,\n default: 5,\n },\n /**\n * @description colors for icons. If array, it should have 3 elements, each of which corresponds with a score level, else if object, the key should be threshold value between two levels, and the value should be corresponding color\n */\n colors: {\n type: definePropType>([Array, Object]),\n default: () => mutable(['', '', ''] as const),\n },\n /**\n * @description color of unselected icons\n */\n voidColor: {\n type: String,\n default: '',\n },\n /**\n * @description color of unselected read-only icons\n */\n disabledVoidColor: {\n type: String,\n default: '',\n },\n /**\n * @description icon components. If array, it should have 3 elements, each of which corresponds with a score level, else if object, the key should be threshold value between two levels, and the value should be corresponding icon component\n */\n icons: {\n type: definePropType<\n Array | Record\n >([Array, Object]),\n default: () =>\n [StarFilled, StarFilled, StarFilled] as [Component, Component, Component],\n },\n /**\n * @description component of unselected icons\n */\n voidIcon: {\n type: iconPropType,\n default: () => Star as Component,\n },\n /**\n * @description component of unselected read-only icons\n */\n disabledVoidIcon: {\n type: iconPropType,\n default: () => StarFilled as Component,\n },\n /**\n * @description whether Rate is read-only\n */\n disabled: {\n type: Boolean,\n default: undefined,\n },\n /**\n * @description whether picking half start is allowed\n */\n allowHalf: Boolean,\n /**\n * @description whether to display texts\n */\n showText: Boolean,\n /**\n * @description whether to display current score. show-score and show-text cannot be true at the same time\n */\n showScore: Boolean,\n /**\n * @description color of texts\n */\n textColor: {\n type: String,\n default: '',\n },\n /**\n * @description text array\n */\n texts: {\n type: definePropType(Array),\n default: () =>\n mutable([\n 'Extremely bad',\n 'Disappointed',\n 'Fair',\n 'Satisfied',\n 'Surprise',\n ] as const),\n },\n /**\n * @description score template\n */\n scoreTemplate: {\n type: String,\n default: '{value}',\n },\n /**\n * @description size of Rate\n */\n size: useSizeProp,\n /**\n * @description whether value can be reset to `0`\n */\n clearable: Boolean,\n ...useAriaProps(['ariaLabel']),\n} as const)\n\nexport type RateProps = ExtractPropTypes\nexport type RatePropsPublic = __ExtractPublicPropTypes\n\nexport const rateEmits = {\n [CHANGE_EVENT]: (value: number) => isNumber(value),\n [UPDATE_MODEL_EVENT]: (value: number) => isNumber(value),\n}\nexport type RateEmits = typeof rateEmits\n\nexport type RateInstance = InstanceType & unknown\n","\n\n\n","import { withInstall } from '@element-plus/utils'\nimport Rate from './src/rate.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElRate: SFCWithInstall = withInstall(Rate)\nexport default ElRate\n\nexport * from './src/rate'\n","import { buildProps } from '@element-plus/utils'\nimport {\n CircleCheckFilled,\n CircleCloseFilled,\n InfoFilled,\n WarningFilled,\n} from '@element-plus/icons-vue'\n\nimport type { Component, ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type Result from './result.vue'\n\nexport const IconMap = {\n primary: 'icon-primary',\n success: 'icon-success',\n warning: 'icon-warning',\n error: 'icon-error',\n info: 'icon-info',\n} as const\n\nexport const IconComponentMap: Record<\n (typeof IconMap)[keyof typeof IconMap],\n Component\n> = {\n [IconMap.primary]: InfoFilled,\n [IconMap.success]: CircleCheckFilled,\n [IconMap.warning]: WarningFilled,\n [IconMap.error]: CircleCloseFilled,\n [IconMap.info]: InfoFilled,\n}\n\nexport const resultProps = buildProps({\n /**\n * @description title of result\n */\n title: {\n type: String,\n default: '',\n },\n /**\n * @description sub title of result\n */\n subTitle: {\n type: String,\n default: '',\n },\n /**\n * @description icon type of result\n */\n icon: {\n type: String,\n values: ['primary', 'success', 'warning', 'info', 'error'],\n default: 'info',\n },\n} as const)\n\nexport type ResultProps = ExtractPropTypes\nexport type ResultPropsPublic = __ExtractPublicPropTypes\n\nexport type ResultInstance = InstanceType & unknown\n","\n\n\n","import { withInstall } from '@element-plus/utils'\nimport Result from './src/result.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElResult: SFCWithInstall = withInstall(Result)\n\nexport default ElResult\n\nexport * from './src/result'\n","import { buildProps } from '@element-plus/utils'\n\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type Row from './row.vue'\n\nexport const RowJustify = [\n 'start',\n 'center',\n 'end',\n 'space-around',\n 'space-between',\n 'space-evenly',\n] as const\n\nexport const RowAlign = ['top', 'middle', 'bottom'] as const\n\nexport const rowProps = buildProps({\n /**\n * @description custom element tag\n */\n tag: {\n type: String,\n default: 'div',\n },\n /**\n * @description grid spacing\n */\n gutter: {\n type: Number,\n default: 0,\n },\n /**\n * @description horizontal alignment of flex layout\n */\n justify: {\n type: String,\n values: RowJustify,\n default: 'start',\n },\n /**\n * @description vertical alignment of flex layout\n */\n align: {\n type: String,\n values: RowAlign,\n },\n} as const)\n\nexport type RowProps = ExtractPropTypes\nexport type RowPropsPublic = __ExtractPublicPropTypes\nexport type RowInstance = InstanceType & unknown\n","\n\n\n","import { withInstall } from '@element-plus/utils'\nimport Row from './src/row.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElRow: SFCWithInstall = withInstall(Row)\nexport default ElRow\n\nexport * from './src/row'\nexport * from './src/constants'\n","\n\n\n","import type { OptionV2EmitFn, OptionV2Props } from './defaults'\n\nexport function useOption(\n props: OptionV2Props,\n { emit }: { emit: OptionV2EmitFn }\n) {\n return {\n hoverItem: () => {\n if (!props.disabled) {\n emit('hover', props.index)\n }\n },\n selectOptionClick: () => {\n if (!props.disabled) {\n emit('select', props.item, props.index)\n }\n },\n }\n}\n","import { placements } from '@popperjs/core'\nimport {\n useAriaProps,\n useEmptyValuesProps,\n useSizeProp,\n} from '@element-plus/hooks'\nimport {\n buildProps,\n definePropType,\n iconPropType,\n isBoolean,\n isNumber,\n} from '@element-plus/utils'\nimport { CHANGE_EVENT, UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport { useTooltipContentProps } from '@element-plus/components/tooltip'\nimport { ArrowDown, CircleClose } from '@element-plus/icons-vue'\nimport { tagProps } from '../../tag'\nimport { defaultProps } from './useProps'\n\nimport type SelectV2 from './select.vue'\nimport type { Option, OptionType } from './select.types'\nimport type { Props } from './useProps'\nimport type { EmitFn } from '@element-plus/utils/vue/typescript'\nimport type { ExtractPropTypes, __ExtractPublicPropTypes } from 'vue'\nimport type {\n Options,\n Placement,\n PopperEffect,\n} from '@element-plus/components/popper'\n\nexport const selectV2Props = buildProps({\n /**\n * @description whether creating new items is allowed. To use this, `filterable` must be true\n */\n allowCreate: Boolean,\n /**\n * @description autocomplete of select input\n */\n autocomplete: {\n type: definePropType<'none' | 'both' | 'list' | 'inline'>(String),\n default: 'none',\n },\n /**\n * @description for non-filterable Select, this prop decides if the option menu pops up when the input is focused\n */\n automaticDropdown: Boolean,\n /**\n * @description whether select can be cleared\n */\n clearable: Boolean,\n /**\n * @description custom clear icon\n */\n clearIcon: {\n type: iconPropType,\n default: CircleClose,\n },\n /**\n * @description tooltip theme, built-in theme: `dark` / `light`\n */\n effect: {\n type: definePropType(String),\n default: 'light',\n },\n /**\n * @description whether to collapse tags to a text when multiple selecting\n */\n collapseTags: Boolean,\n /**\n * @description whether show all selected tags when mouse hover text of collapse-tags. To use this, `collapse-tags` must be true\n */\n collapseTagsTooltip: Boolean,\n /**\n * @description The max tags number to be shown. To use this, `collapse-tags` must be true\n */\n maxCollapseTags: {\n type: Number,\n default: 1,\n },\n /**\n * @description\n */\n defaultFirstOption: Boolean,\n /**\n * @description is disabled\n */\n disabled: {\n type: Boolean,\n default: undefined,\n },\n /**\n * @description\n */\n estimatedOptionHeight: {\n type: Number,\n default: undefined,\n },\n /**\n * @description whether Select is filterable\n */\n filterable: Boolean,\n /**\n * @description custom filter method, the first parameter is the current input value. To use this, `filterable` must be true\n */\n filterMethod: {\n type: definePropType<(query: string) => void>(Function),\n },\n /**\n * @description The height of the dropdown panel, 34px for each item\n */\n height: {\n type: Number,\n default: 274, // same as select dropdown menu\n },\n /**\n * @description The height of the dropdown item\n */\n itemHeight: {\n type: Number,\n default: 34,\n },\n /**\n * @description native input id\n */\n id: String,\n /**\n * @description whether Select is loading data from server\n */\n loading: Boolean,\n /**\n * @description displayed text while loading data from server, default is 'Loading'\n */\n loadingText: String,\n /**\n * @description biding value\n */\n modelValue: {\n type: definePropType<\n any[] | string | number | boolean | Record | any\n >([Array, String, Number, Boolean, Object]),\n default: undefined,\n },\n /**\n * @description is multiple\n */\n multiple: Boolean,\n /**\n * @description maximum number of options user can select when multiple is true. No limit when set to 0\n */\n multipleLimit: {\n type: Number,\n default: 0,\n },\n /**\n * @description the name attribute of select input\n */\n name: String,\n /**\n * @description displayed text when there is no options, you can also use slot empty, the default is 'No Data'\n */\n noDataText: String,\n /**\n * @description displayed text when no data matches the filtering query, you can also use slot `empty`, default is 'No matching data'\n */\n noMatchText: String,\n /**\n * @description function that gets called when the input value changes. Its parameter is the current input value. To use this, `filterable` must be true\n */\n remoteMethod: {\n type: definePropType<(query: string) => void>(Function),\n },\n /**\n * @description whether reserve the keyword after select filtered option.\n */\n reserveKeyword: {\n type: Boolean,\n default: true,\n },\n /**\n * @description data of the options, the key of `value` and `label` can be customize by `props`\n */\n options: {\n type: definePropType(Array),\n required: true,\n },\n /**\n * @description placeholder, the default is 'Please select'\n */\n placeholder: {\n type: String,\n },\n /**\n * @description whether select dropdown is teleported, if `true` it will be teleported to where `append-to` sets\n */\n teleported: useTooltipContentProps.teleported,\n /**\n * @description when select dropdown is inactive and `persistent` is `false`, select dropdown will be destroyed\n */\n persistent: {\n type: Boolean,\n default: true,\n },\n /**\n * @description custom class name for Select's dropdown\n */\n popperClass: useTooltipContentProps.popperClass,\n /**\n * @description custom style for Select's dropdown\n */\n popperStyle: useTooltipContentProps.popperStyle,\n /**\n * @description [popper.js](https://popper.js.org/docs/v2/) parameters\n */\n popperOptions: {\n type: definePropType>(Object),\n default: () => ({}) as Partial,\n },\n /**\n * @description whether search data from server\n */\n remote: Boolean,\n /**\n * @description debounce delay during remote search, in milliseconds\n */\n debounce: {\n type: Number,\n default: 300,\n },\n /**\n * @description size of component\n */\n size: useSizeProp,\n /**\n * @description configuration options, see the following table\n */\n props: {\n type: definePropType(Object),\n default: () => defaultProps,\n },\n /**\n * @description unique identity key name for value, required when value is an object\n */\n valueKey: {\n type: String,\n default: 'value',\n },\n /**\n * @description Controls whether the scrollbar is always displayed\n */\n scrollbarAlwaysOn: Boolean,\n /**\n * @description whether to trigger form validation\n */\n validateEvent: {\n type: Boolean,\n default: true,\n },\n /**\n * @description offset of the dropdown\n */\n offset: {\n type: Number,\n default: 12,\n },\n /**\n * @description in remote search method show suffix icon\n */\n remoteShowSuffix: Boolean,\n /**\n * @description Determines whether the arrow is displayed\n */\n showArrow: {\n type: Boolean,\n default: true,\n },\n /**\n * @description position of dropdown\n */\n placement: {\n type: definePropType(String),\n values: placements,\n default: 'bottom-start',\n },\n /**\n * @description list of possible positions for dropdown\n */\n fallbackPlacements: {\n type: definePropType(Array),\n default: ['bottom-start', 'top-start', 'right', 'left'],\n },\n /**\n * @description tag type\n */\n tagType: { ...tagProps.type, default: 'info' },\n /**\n * @description tag effect\n */\n tagEffect: { ...tagProps.effect, default: 'light' },\n /**\n * @description tabindex for input\n */\n tabindex: {\n type: [String, Number],\n default: 0,\n },\n /**\n * @description which element the select dropdown appends to\n */\n appendTo: useTooltipContentProps.appendTo,\n /**\n * @description if it is `true`, the width of the dropdown panel is the same as the input box.\n * if it is `false`, the width is automatically calculated based on the value of `label`,\n * or it can be set to a number to make it a fixed width\n */\n fitInputWidth: {\n type: [Boolean, Number],\n default: true,\n validator(val) {\n return isBoolean(val) || isNumber(val)\n },\n },\n suffixIcon: {\n type: iconPropType,\n default: ArrowDown,\n },\n ...useEmptyValuesProps,\n ...useAriaProps(['ariaLabel']),\n} as const)\n\nexport const optionV2Props = buildProps({\n data: Array,\n disabled: Boolean,\n hovering: Boolean,\n item: {\n type: definePropType