diff --git a/EN/MODULE.md b/EN/MODULE.md
index 29284d9d..d15986ec 100644
--- a/EN/MODULE.md
+++ b/EN/MODULE.md
@@ -2,8 +2,8 @@
##### TCode Help Module
-
+
##### Customized TCode Module
-
\ No newline at end of file
+
\ No newline at end of file
diff --git a/EN/README.md b/EN/README.md
index f8f627fe..987cfdc4 100644
--- a/EN/README.md
+++ b/EN/README.md
@@ -10,17 +10,17 @@
>
> Preview: https://ssh.kkbpro.com/ (For domestic servers) or https://ssh.kkbapps.com/ (For foreign servers)
>
-> Update Time: 2024-08-14
+> Update Time: 2024-09-16
>

-
-
-
-
-
+
+
+
+
+
简体中文 | English
@@ -68,13 +68,13 @@ Visit the following website:
- 🌐 For domestic servers: https://ssh.kkbpro.com/
- 🌍 For foreign servers: https://ssh.kkbapps.com/
-
+
-
+
-
+
-
+
[**More Module Previews**](./MODULE.md)
@@ -107,7 +107,14 @@ Visit the following website:
### 👨💻 Update Records
-##### zyyzyykk/kkterminal:3.2.2: latest
+##### zyyzyykk/kkterminal:3.2.6: latest
+
+- Fix bugs related to special character operations in files
+- Optimize file upload and download
+- File Attribute Module: Folder addition includes attributes, file size attributes, and real-time refresh
+- Optimize display logic and standardize coding
+
+##### zyyzyykk/kkterminal:3.2.2:
- TCode supports Get/Set to Session/Local Level variables
- Text editor adds intelligent prompts for TCode native object `kkTerminal`
@@ -119,11 +126,6 @@ Visit the following website:
- Support folder download
- Refactoring some logic and optimizing display
-##### zyyzyykk/kkterminal:3.1.7 :
-
-- Adapt to default fonts and optimize TCode status display
-- Support local PC deployment, automatically open browser window
-
##### [History Update Records](./UPDATE.md)
### 🧬 Architecture
diff --git a/EN/UPDATE.md b/EN/UPDATE.md
index e93cf05c..364c4aca 100644
--- a/EN/UPDATE.md
+++ b/EN/UPDATE.md
@@ -1,5 +1,10 @@
### 👨💻 History Update Records
+##### zyyzyykk/kkterminal:3.1.7 :
+
+- Adapt to default fonts and optimize TCode status display
+- Support local PC deployment, automatically open browser window
+
##### zyyzyykk/kkterminal:3.1.5 :
- Fix bug where files cannot be uploaded through the input box
diff --git a/MODULE.md b/MODULE.md
index 29c811ab..bb711685 100644
--- a/MODULE.md
+++ b/MODULE.md
@@ -2,8 +2,8 @@
##### TCode 帮助模块
-
+
##### 自定义TCode 模块
-
\ No newline at end of file
+
\ No newline at end of file
diff --git a/README.md b/README.md
index 5142cb18..47792837 100644
--- a/README.md
+++ b/README.md
@@ -12,17 +12,17 @@
>
> 预览:https://ssh.kkbpro.com/ (国内服务器访问) 或 https://ssh.kkbapps.com/ (国外服务器访问)
>
-> 更新时间:2024-08-14
+> 更新时间:2024-09-16
>

-
-
-
-
-
+
+
+
+
+
简体中文 | English
@@ -70,13 +70,13 @@ docker run -d --name kkterminal -p 3000:3000 -e TITLE="kkbpro" zyyzyykk/kktermin
- 🌐 国内服务器访问:https://ssh.kkbpro.com/
- 🌍 国外服务器访问:https://ssh.kkbapps.com/
-
+
-
+
-
+
-
+
[**更多模块预览**](./MODULE.md)
@@ -109,9 +109,16 @@ docker run -d --name kkterminal -p 3000:3000 -e TITLE="kkbpro" zyyzyykk/kktermin
### 👨💻 更新记录
-##### zyyzyykk/kkterminal:3.2.2:latest
+##### zyyzyykk/kkterminal:3.2.6:latest
-- TCode支持 会话级/本地级 变量的存取
+- 修复文件特殊字符操作问题的bug
+- 优化文件上传与下载
+- 文件属性模块:文件夹新增包含属性、文件大小属性实时刷新
+- 优化显示逻辑,规范编码
+
+##### zyyzyykk/kkterminal:3.2.2:
+
+- TCode支持会话级/本地级变量的存取
- 文本编辑器新增TCode原生对象 `kkTerminal` 的智能提示
- 文件管理模块快捷键适配MacOS
@@ -121,11 +128,6 @@ docker run -d --name kkterminal -p 3000:3000 -e TITLE="kkbpro" zyyzyykk/kktermin
- 支持文件夹下载
- 重构部分逻辑,优化显示
-##### zyyzyykk/kkterminal:3.1.7:
-
-- 适配默认字体、优化TCode状态显示
-- 支持本地PC端部署,自动打开浏览器窗口
-
##### [历史更新记录](./UPDATE.md)
### 🧬 架构
diff --git a/UPDATE.md b/UPDATE.md
index a557423b..8b0887ea 100644
--- a/UPDATE.md
+++ b/UPDATE.md
@@ -1,5 +1,10 @@
### 👨💻 历史更新记录
+##### zyyzyykk/kkterminal:3.1.7:
+
+- 适配默认字体、优化TCode状态显示
+- 支持本地PC端部署,自动打开浏览器窗口
+
##### zyyzyykk/kkterminal:3.1.5:
- 修复无法通过input框上传文件的bug
diff --git a/backend/terminal/src/main/resources/application.properties b/backend/terminal/src/main/resources/application.properties
index 64e56279..97b9318e 100644
--- a/backend/terminal/src/main/resources/application.properties
+++ b/backend/terminal/src/main/resources/application.properties
@@ -16,4 +16,4 @@ spring.servlet.multipart.max-file-size=20MB
spring.servlet.multipart.max-request-size=100MB
# PC端启用窗口
-kk.pc.window=false
\ No newline at end of file
+kk.pc.window=true
\ No newline at end of file
diff --git a/backend/terminal/src/main/resources/static/css/app.642389ee.css b/backend/terminal/src/main/resources/static/css/app.f0fce407.css
similarity index 50%
rename from backend/terminal/src/main/resources/static/css/app.642389ee.css
rename to backend/terminal/src/main/resources/static/css/app.f0fce407.css
index 79271768..efd0170c 100644
--- a/backend/terminal/src/main/resources/static/css/app.642389ee.css
+++ b/backend/terminal/src/main/resources/static/css/app.f0fce407.css
@@ -1 +1 @@
-.no-data[data-v-7a3a533e]{text-align:center;display:flex;align-items:center;justify-content:center}.msg[data-v-7a3a533e]{margin-top:10px;color:#909399;font-size:14px}.item-class[data-v-1f07a939]{display:flex;align-items:center;padding:5px 10px;border-bottom:1px solid #ececec;cursor:pointer;width:100%}.item-class[data-v-1f07a939]:hover,.item-selected[data-v-1f07a939]{background-color:#f3f3f3}.kk-flex[data-v-1f07a939]{display:flex;align-items:center;margin-top:10px}.no-select[data-v-1f07a939]{-webkit-user-select:none;-moz-user-select:none;user-select:none}.kk-border[data-v-1f07a939]{height:30.1vh;overflow-y:scroll;width:100%;border-bottom:1px solid #ececec}.ellipsis[data-v-1f07a939]{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.item-class[data-v-663bb10e]{display:flex;align-items:center}.errInfo[data-v-663bb10e]{font-size:12px;color:#ea5050;margin-top:8px}.no-select[data-v-663bb10e]{-webkit-user-select:none;-moz-user-select:none;user-select:none}.ellipsis[data-v-663bb10e]{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nowrap[data-v-663bb10e]{white-space:nowrap}.old-option[data-v-663bb10e]{color:#67c23a}.new-option[data-v-663bb10e]{color:#f56c6c}.item-class[data-v-d18bce82]{display:flex;align-items:center}.no-select[data-v-d18bce82]{-webkit-user-select:none;-moz-user-select:none;user-select:none}.kk-code-editor[data-v-73ef2e97]{height:100%;width:100%;border:1px solid #ececec}.kk-flex[data-v-480795cf]{display:flex;align-items:center}.ellipsis[data-v-480795cf]{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.kk-flex[data-v-101691e8]{display:flex;align-items:center;margin-top:10px}.no-select[data-v-101691e8]{-webkit-user-select:none;-moz-user-select:none;user-select:none}.errInfo[data-v-101691e8]{font-size:12px;color:#ea5050;margin-top:8px}.kk-flex[data-v-1ef7ac5d]{display:flex;align-items:center;margin-top:15px}.kk-border[data-v-1ef7ac5d]{padding-bottom:10px;border-bottom:1px solid #ececec}.no-select[data-v-1ef7ac5d]{-webkit-user-select:none;-moz-user-select:none;user-select:none}.ellipsis[data-v-1ef7ac5d]{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nowrap[data-v-1ef7ac5d]{white-space:nowrap}.title[data-v-7d7f3746]{background-color:#efefef;padding:4px 10px;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:15px}.list-class[data-v-7d7f3746]{height:30vh;overflow-y:scroll;width:100%}.item-class[data-v-7d7f3746]{display:flex;align-items:center;padding:5px 10px;border-bottom:1px solid #efefef;cursor:pointer;width:100%}.item-class[data-v-7d7f3746]:hover{background-color:#f3f3f3}.hover-class[data-v-7d7f3746]:hover{color:#409eff}.item-selected[data-v-7d7f3746]{background-color:#efefef!important;border-bottom:1px solid #d8d8d8}.no-select[data-v-7d7f3746]{-webkit-user-select:none;-moz-user-select:none;user-select:none}.ellipsis[data-v-7d7f3746]{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.kk-menu[data-v-7d7f3746]{position:absolute;z-index:3466;text-align:center;border-radius:8px;border-top:8px solid #fff;border-bottom:8px solid #fff;box-shadow:0 6px 12px 0 rgba(0,0,0,.15),0 3px 6px -2px rgba(0,0,0,.2),0 8px 16px 4px rgba(0,0,0,.12)}.kk-menu-item[data-v-7d7f3746]{height:30px;font-size:13px;line-height:30px;width:110px;color:#383838;background-color:#fff;cursor:pointer}.kk-menu-item[data-v-7d7f3746]:hover{background-color:#efefef}.disabled[data-v-7d7f3746]{background-color:#f5f7fa}.disabled-function[data-v-7d7f3746],.disabled[data-v-7d7f3746]{color:#a8abb2;pointer-events:none}.kk-flex[data-v-c9882564]{display:flex;align-items:center;margin-top:15px}.kk-border[data-v-c9882564]{margin-top:3px;margin-bottom:3px;padding-bottom:5px;border-bottom:1px solid #ececec}.no-select[data-v-c9882564]{-webkit-user-select:none;-moz-user-select:none;user-select:none}.nowrap[data-v-c9882564]{white-space:nowrap}.kk-flex[data-v-26579f9f]{display:flex;align-items:center}.kk-border[data-v-26579f9f]{padding-bottom:10px;border-bottom:1px solid #ddd}.tocde-item[data-v-26579f9f]:hover{background-color:#efefef}.no-select[data-v-26579f9f]{-webkit-user-select:none;-moz-user-select:none;user-select:none}.ellipsis[data-v-26579f9f]{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nowrap[data-v-26579f9f]{white-space:nowrap}.golbal[data-v-1ebaa6c4]{position:relative;width:100%;display:flex;flex-direction:column;overflow:hidden}.bar[data-v-1ebaa6c4]{display:flex;align-items:center;background-color:#f5f5f5;color:#000;width:100%;height:25px;border-top:1px solid #d7d7d7;border-bottom:1px solid #d7d7d7;border-left:1px solid #d7d7d7;border-right:1px solid #d7d7d7}.terminal-class[data-v-1ebaa6c4]{width:100%}.setting[data-v-1ebaa6c4]{position:absolute;left:0;top:25px;z-index:100;cursor:pointer;border:2px solid #f2f2f2}.setting-menu[data-v-1ebaa6c4]{display:flex;align-items:center;justify-content:center;background-color:#f2f2f2;text-align:center;width:80px;height:25px;line-height:25px;font-size:13px;color:#383838}.setting-menu[data-v-1ebaa6c4]:hover{background-color:#91c9f7}.no-select[data-v-1ebaa6c4]{-webkit-user-select:none;-moz-user-select:none;user-select:none}img{-webkit-user-drag:none;-khtml-user-drag:none;-moz-user-drag:none;-o-user-drag:none}.kk-dialog-class{pointer-events:none;z-index:3456}.el-dialog{pointer-events:auto}:root{--link:#007fff;--pink:#f69;--text2:#61666d;--icon:#9499a0}body{margin:0;font-size:14px;color:#636d7e}*,body{padding:0}*{box-sizing:border-box;border:0;outline:0;vertical-align:middle}.a-link{text-decoration:none;color:var(--link);cursor:pointer}.el-form-item{align-items:center}.container-body{margin:0 auto;padding-top:5px}.el-button{.iconfont:before{margin-right:5px}}
\ No newline at end of file
+.no-data[data-v-7a3a533e]{text-align:center;display:flex;align-items:center;justify-content:center}.msg[data-v-7a3a533e]{margin-top:10px;color:#909399;font-size:14px}.item-class[data-v-1f07a939]{display:flex;align-items:center;padding:5px 10px;border-bottom:1px solid #ececec;cursor:pointer;width:100%}.item-class[data-v-1f07a939]:hover,.item-selected[data-v-1f07a939]{background-color:#f3f3f3}.kk-flex[data-v-1f07a939]{display:flex;align-items:center;margin-top:10px}.no-select[data-v-1f07a939]{-webkit-user-select:none;-moz-user-select:none;user-select:none}.kk-border[data-v-1f07a939]{height:30.1vh;overflow-y:scroll;width:100%;border-bottom:1px solid #ececec}.ellipsis[data-v-1f07a939]{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.item-class[data-v-bf2f54ee]{display:flex;align-items:center}.errInfo[data-v-bf2f54ee]{font-size:12px;color:#ea5050;margin-top:8px}.no-select[data-v-bf2f54ee]{-webkit-user-select:none;-moz-user-select:none;user-select:none}.ellipsis[data-v-bf2f54ee]{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nowrap[data-v-bf2f54ee]{white-space:nowrap}.old-option[data-v-bf2f54ee]{color:#67c23a}.new-option[data-v-bf2f54ee]{color:#f56c6c}.item-class[data-v-d18bce82]{display:flex;align-items:center}.no-select[data-v-d18bce82]{-webkit-user-select:none;-moz-user-select:none;user-select:none}.kk-code-editor[data-v-980ea70c]{height:100%;width:100%;border:1px solid #ececec}.kk-flex[data-v-d5692da0]{display:flex;align-items:center}.ellipsis[data-v-d5692da0]{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.kk-flex[data-v-cb2a471c]{display:flex;align-items:center;margin-top:10px}.no-select[data-v-cb2a471c]{-webkit-user-select:none;-moz-user-select:none;user-select:none}.errInfo[data-v-cb2a471c]{font-size:12px;color:#ea5050;margin-top:8px}.kk-flex[data-v-2c6df403]{display:flex;align-items:center;margin-top:15px}.kk-border[data-v-2c6df403]{padding-bottom:10px;border-bottom:1px solid #ececec}.no-select[data-v-2c6df403]{-webkit-user-select:none;-moz-user-select:none;user-select:none}.ellipsis[data-v-2c6df403]{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nowrap[data-v-2c6df403]{white-space:nowrap}.title[data-v-32fde74a]{background-color:#efefef;padding:4px 10px;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:15px}.list-class[data-v-32fde74a]{height:30vh;overflow-y:scroll;width:100%}.item-class[data-v-32fde74a]{display:flex;align-items:center;padding:5px 10px;border-bottom:1px solid #efefef;cursor:pointer;width:100%}.item-class[data-v-32fde74a]:hover{background-color:#f3f3f3}.hover-class[data-v-32fde74a]:hover{color:#409eff}.item-selected[data-v-32fde74a]{background-color:#efefef!important;border-bottom:1px solid #d8d8d8}.no-select[data-v-32fde74a]{-webkit-user-select:none;-moz-user-select:none;user-select:none}.ellipsis[data-v-32fde74a]{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.kk-menu[data-v-32fde74a]{position:absolute;z-index:3466;text-align:center;border-radius:8px;border-top:8px solid #fff;border-bottom:8px solid #fff;box-shadow:0 6px 12px 0 rgba(0,0,0,.15),0 3px 6px -2px rgba(0,0,0,.2),0 8px 16px 4px rgba(0,0,0,.12)}.kk-menu-item[data-v-32fde74a]{height:30px;font-size:13px;line-height:30px;width:110px;color:#383838;background-color:#fff;cursor:pointer}.kk-menu-item[data-v-32fde74a]:hover{background-color:#efefef}.disabled[data-v-32fde74a]{background-color:#f5f7fa}.disabled-function[data-v-32fde74a],.disabled[data-v-32fde74a]{color:#a8abb2;pointer-events:none}.kk-flex[data-v-c9882564]{display:flex;align-items:center;margin-top:15px}.kk-border[data-v-c9882564]{margin-top:3px;margin-bottom:3px;padding-bottom:5px;border-bottom:1px solid #ececec}.no-select[data-v-c9882564]{-webkit-user-select:none;-moz-user-select:none;user-select:none}.nowrap[data-v-c9882564]{white-space:nowrap}.kk-flex[data-v-bfe11042]{display:flex;align-items:center}.kk-border[data-v-bfe11042]{padding-bottom:10px;border-bottom:1px solid #ddd}.tocde-item[data-v-bfe11042]:hover{background-color:#efefef}.no-select[data-v-bfe11042]{-webkit-user-select:none;-moz-user-select:none;user-select:none}.ellipsis[data-v-bfe11042]{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nowrap[data-v-bfe11042]{white-space:nowrap}.golbal[data-v-1d051994]{position:relative;width:100%;display:flex;flex-direction:column;overflow:hidden}.bar[data-v-1d051994]{display:flex;align-items:center;background-color:#f5f5f5;color:#000;width:100%;height:25px;border-top:1px solid #d7d7d7;border-bottom:1px solid #d7d7d7;border-left:1px solid #d7d7d7;border-right:1px solid #d7d7d7}.terminal-class[data-v-1d051994]{width:100%}.setting[data-v-1d051994]{position:absolute;left:0;top:25px;z-index:100;cursor:pointer;border:2px solid #f2f2f2}.setting-menu[data-v-1d051994]{display:flex;align-items:center;justify-content:center;background-color:#f2f2f2;text-align:center;width:80px;height:25px;line-height:25px;font-size:13px;color:#383838}.setting-menu[data-v-1d051994]:hover{background-color:#91c9f7}.no-select[data-v-1d051994]{-webkit-user-select:none;-moz-user-select:none;user-select:none}img{-webkit-user-drag:none;-khtml-user-drag:none;-moz-user-drag:none;-o-user-drag:none}.kk-dialog-class{pointer-events:none;z-index:3456}.el-dialog{pointer-events:auto}:root{--link:#007fff;--pink:#f69;--text2:#61666d;--icon:#9499a0}body{margin:0;font-size:14px;color:#636d7e}*,body{padding:0}*{box-sizing:border-box;border:0;outline:0;vertical-align:middle}.a-link{text-decoration:none;color:var(--link);cursor:pointer}.el-form-item{align-items:center}.container-body{margin:0 auto;padding-top:5px}.el-button{.iconfont:before{margin-right:5px}}
\ No newline at end of file
diff --git a/backend/terminal/src/main/resources/static/index.html b/backend/terminal/src/main/resources/static/index.html
index 7176898d..862f84a7 100644
--- a/backend/terminal/src/main/resources/static/index.html
+++ b/backend/terminal/src/main/resources/static/index.html
@@ -1 +1 @@
-kk Terminal
\ No newline at end of file
+kk Terminal
\ No newline at end of file
diff --git a/backend/terminal/src/main/resources/static/js/app.094f4502.js b/backend/terminal/src/main/resources/static/js/app.094f4502.js
deleted file mode 100644
index 700190e8..00000000
--- a/backend/terminal/src/main/resources/static/js/app.094f4502.js
+++ /dev/null
@@ -1,2 +0,0 @@
-(function(){var e={3247:function(e,l,t){"use strict";var a=t(7387),o=t.n(a),i=t(8082),s=t.n(i);const n="P5P1SIqVe6kaOxMX";function r(e){var l=s().enc.Utf8.parse(n),t=s().enc.Utf8.parse(e),a=s().AES.encrypt(t,l,{mode:s().mode.ECB,padding:s().pad.Pkcs7});return a.toString()}function u(e){var l=s().enc.Utf8.parse(n),t=s().AES.decrypt(e,l,{mode:s().mode.ECB,padding:s().pad.Pkcs7});return s().enc.Utf8.stringify(t).toString()}var d=t(9242),c=t(3396);function p(e,l,t,a,o,i){const s=(0,c.up)("FrameWork");return(0,c.wg)(),(0,c.j4)(s)}var v="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAMgAAADICAYAAACtWK6eAAAAAXNSR0IArs4c6QAAB/dJREFUeF7tnbGv5VMQx2f/yNUoNAqFQqFQSKxCoVAoFAqNQrEbghCCEIQQhCBBCBtCEIIQgrD22rPZt8l7d+/Ombn3fGc+t74z58znO5/87ktu7jtlvCAAgRMJnIINBCBwMgEEYTsgsIUAgrAeEEAQdgACPgI8QXzcqGpCAEGaBM2YPgII4uNGVRMCCNIkaMb0EUAQHzeqmhBAkCZBM6aPAIL4uFHVhACCNAmaMX0EEMTHjaomBBCkSdCM6SOAID5uVDUhgCBNgmZMHwEE8XGjqgkBBGkSNGP6CCCIjxtVTQggSJOgGdNHAEF83KhqQgBBmgTNmD4CCOLjRlUTAgjSJGjG9BHYCHLBV0oVBOoTQJD6GTPhBAEEmYBHaX0CCFI/YyacIIAgE/AorU8AQepnzIQTBBBkAh6l9QkgSP2MmXCCAIJMwKO0PgEEqZ8xE04QQJAJeJTWJ4Ag9TNmwgkCCDIBj9L6BBCkfsZMOEEAQSbgUVqfAILUz5gJJwggyAQ8SusTQJD6GTPhBAEEmYBHaX0CCFI/YyacIIAgE/AorU8AQepnzIQTBBBkAh6l9QkgSP2MmXCCAIJMwKO0PgEEqZ8xE04QQJAJeJTWJ4Ag9TNmwgkCCDIBj9L6BBCkfsZMOEEAQSbgUVqfAILUz5gJJwioC3LOzE5PzE8pBLYSUBbkETO70czOIglbnkVAVZCHzeymI1CQJGtDmvdVFOQhM7v5mNyQpPkyZ4yvJsiDZnbLFhBIkrEljXsqCfKAmd26Q1ZIsgMk3rIbARVB7jez23Yb6f93Icl1wOKtJxNQEOQ+M7vdESKSOKBRcjWB1QW518zumAgNSSbgUWq2siD3mNmdASEhSQDEri1WFeTui4GcCQwFSQJhdmq1qiCbDJCk0yYuOuvKgiDJokvT6VqrC4IknbZxwVkVBEGSBReny5VUBEGSLhu52JxKgiDJYsvT4TpqgiBJh61caEZFQZBkoQWqfhVVQZCk+mYuMp+yIEiyyBJVvoa6IEhSeTsXmK2CIEiywCJVvUIVQZCk6oYeeK5KgiDJgZep4vHVBEGSilt6wJkqCoIkB1yoakdXFQRJqm3qgeapLAiSHGipKh1bXRAkqbStB5ilgyBIcoDFqnJkF0GQpMrG7nmOToIgyZ6Xq8Jx3QRBkgpbu8cZOgqCJHtcMPWjugqCJOqbu6f7dxYESfa0ZMrHdBcESZS3dw93R5BLkPmZ0z0sm+IRCHIlNSRR3ODkOyPI1YCRJHnh1NojyJXEPjSzG8zso6AQT49/BRfUjjaHIIAgl6h/MOT4OCgE5AgCeeg2CGL2/pDjk6AwkCMI5Aptugvy3pDj06AwkCMI5CptOgvy7pDjs6AwkCMI5EptugryzpDj86AwkCMI5GptOgry9pDji6AwkCMI5Iptugny1pDjfFAYyBEEctU2nQR5c8jxZVAYyBEEcuU2XQR5Y8jxVVAYyBEEcvU2HQR5fcjxdVAYyBEEUqFNdUFeG3J8ExQGcgSBVGlTWZBXhxzfBoWBHEEgldpUFeSVIcd3QWEgRxBItTYVBXl5yPF9UBjIEQRSsU01QV4acvwQFAZyBIFUbVNJkBeHHD8GhYEcQSCV21QR5IUhx09BYSBHEEj1NhUEeX7I8XNQGMgRBLJCG3VBnhty/BIUBnIEgazSRlmQZ4ccvwaFgRxBICu1URXkmSHHb0FhIEcQyGptFAV5esjxe1AYyBEEsmIbNUGeGnL8ERQGcgSBrNpGSZAnhxx/BoWBHEEgK7dREeSJIcdfQWEgRxDI6m0UBHl8yPF3UBjIEQSyQ5vVBXlsyPFPUBgKcmwy6fa66+LAZ1YcemVBHh1y/BsETkGOzagdBdnIsZFkudeqgpwbckQBU5GjqyA8QRybvvml9Y0osy8lORBkNu3g+lWfIJfHnJVETY6ugvARa0JsrySKcnQVhI9YE4JsSq9XElU5EGRyUaLLV/+IdXTeXSVRlqOrIHzECjL7WpKoy4EgQYsS1UbpCXKtP9wryIEgUZsd1EdRkOP+JqkiB4IELXZUG1VBjkpSSQ4EidrsoD7KglyW5GwQi1Xa8FWTVZIY3/u5sNB9uArfxVpqB9SfIEvBDLoMT5AgkBFtECSCYmyPXb72vU2i4z4RKEjHt3lj94huEMgnwBMknzEnCBNAEOHwuHo+AQTJZ8wJwgQQRDg8rp5PAEHyGXOCMAEEEQ6Pq+cTQJB8xpwgTABBhMPj6vkEECSfMScIE0AQ4fC4ej4BBMlnzAnCBBBEODyunk8AQfIZc4IwAQQRDo+r5xNAkHzGnCBMAEGEw+Pq+QQQJJ8xJwgTQBDh8Lh6PgEEyWfMCcIEEEQ4PK6eTwBB8hlzgjABBBEOj6vnE0CQfMacIEwAQYTD4+r5BBAknzEnCBNAEOHwuHo+AQTJZ8wJwgQQRDg8rp5PAEHyGXOCMAEEEQ6Pq+cTQJB8xpwgTABBhMPj6vkEECSfMScIE9gIwgsCEDiBAIKwGhDYQgBBWA8IIAg7AAEfAZ4gPm5UNSGAIE2CZkwfAQTxcaOqCQEEaRI0Y/oIIIiPG1VNCCBIk6AZ00cAQXzcqGpCAEGaBM2YPgII4uNGVRMCCNIkaMb0EUAQHzeqmhBAkCZBM6aPAIL4uFHVhACCNAmaMX0EEMTHjaomBBCkSdCM6SOAID5uVDUhgCBNgmZMHwEE8XGjqgkBBGkSNGP6CCCIjxtVTQj8B1C6ZEICxVr9AAAAAElFTkSuQmCC";const m=e=>((0,c.dD)("data-v-1ebaa6c4"),e=e(),(0,c.Cn)(),e),g={class:"golbal"},f={class:"setting"},y=m((()=>(0,c._)("div",null,"连接设置",-1))),w=[y],k=m((()=>(0,c._)("div",null,"偏好设置",-1))),h=[k],_=m((()=>(0,c._)("div",null,"文件管理",-1))),x=[_],C=m((()=>(0,c._)("div",null,"重启",-1))),S=[C],b={class:"bar"},I=m((()=>(0,c._)("img",{src:v,alt:"终端",style:{height:"16px",margin:"0 7px",cursor:"pointer"}},null,-1))),D=[I],E=m((()=>(0,c._)("div",{style:{"user-select":"none","font-size":"14px"}},[(0,c._)("span",null,"kk Terminal")],-1))),T=m((()=>(0,c._)("div",{style:{flex:"1"}},null,-1))),W={key:0,style:{display:"flex","align-items":"center"}},V=m((()=>(0,c._)("div",{style:{"font-size":"12px",color:"#313131","user-select":"none"}}," TCode ",-1))),F=m((()=>(0,c._)("div",{style:{"margin-left":"7px"}},null,-1))),A={style:{cursor:"pointer","margin-left":"5px"}},B=m((()=>(0,c._)("div",{style:{"font-size":"12px",color:"#313131"}},[(0,c._)("div",{style:{"user-select":"none","font-size":"14px","font-weight":"bold"}},"什么是 TCode (终端代码) ?"),(0,c._)("div",{style:{"user-select":"none","margin-top":"5px"}},"TCode(终端代码)是用于访问和执行特定操作流程的快捷方式"),(0,c._)("div",{style:{"user-select":"none","margin-top":"5px"}},[(0,c.Uk)(" 输入 "),(0,c._)("span",{style:{"background-color":"#f3f4f4","user-select":"text"}},"/H"),(0,c.Uk)(" 并按下回车,查看帮助信息 ")]),(0,c._)("div",{style:{"user-select":"none","margin-top":"5px"}},[(0,c.Uk)(" 输入 "),(0,c._)("span",{style:{"background-color":"#f3f4f4","user-select":"text"}},"/A"),(0,c.Uk)(" 并按下回车,自定义TCode ")])],-1))),z=m((()=>(0,c._)("div",{style:{"margin-left":"20px"}},null,-1))),H={ref:"terminal",class:"terminal-class"};function O(e,l,t,a,o,i){const s=(0,c.up)("el-input"),n=(0,c.up)("QuestionFilled"),r=(0,c.up)("el-icon"),u=(0,c.up)("el-popover"),p=(0,c.up)("ConnectSetting"),v=(0,c.up)("StyleSetting"),m=(0,c.up)("FileBlock"),y=(0,c.up)("UserTcode"),k=(0,c.up)("HelpTcode");return(0,c.wg)(),(0,c.iD)(c.HY,null,[(0,c._)("div",g,[(0,c.wy)((0,c._)("div",f,[(0,c._)("div",{class:"setting-menu no-select",onClick:l[0]||(l[0]=e=>a.doSettings(1))},w),(0,c._)("div",{class:"setting-menu no-select",onClick:l[1]||(l[1]=e=>a.doSettings(2))},h),(0,c._)("div",{class:"setting-menu no-select",onClick:l[2]||(l[2]=e=>a.doSettings(4))},x),(0,c._)("div",{class:"setting-menu no-select",onClick:l[3]||(l[3]=e=>a.doSettings(3))},S)],512),[[d.F8,a.isShowSetting]]),(0,c._)("div",b,[(0,c._)("div",{style:{"user-select":"none"},onClick:l[4]||(l[4]=(...e)=>a.showSettings&&a.showSettings(...e))},D),E,T,a.env.tCode?((0,c.wg)(),(0,c.iD)("div",W,[V,F,(0,c._)("div",null,[(0,c.Wm)(s,{modelValue:a.tcode,"onUpdate:modelValue":l[5]||(l[5]=e=>a.tcode=e),id:"kkterminalTcode",ref:"tCodeInputRef",style:{width:"100px",height:"20px",fontSize:"12px"},onKeydown:(0,d.D2)(a.handleTcode,["enter"]),maxlength:"6"},null,8,["modelValue","onKeydown"])]),(0,c._)("div",A,[(0,c.Wm)(u,{placement:"bottom-end",width:220,trigger:"hover"},{reference:(0,c.w5)((()=>[(0,c.Wm)(r,{style:{color:"#606266"}},{default:(0,c.w5)((()=>[(0,c.Wm)(n)])),_:1})])),default:(0,c.w5)((()=>[B])),_:1})]),z])):(0,c.kq)("",!0)]),(0,c._)("div",H,null,512)]),(0,c.Wm)(p,{ref:"connectSettingRef",env:a.env,sshOptions:a.options,onSaveOp:a.saveOp,onCallback:a.saveEnv},null,8,["env","sshOptions","onSaveOp","onCallback"]),(0,c.Wm)(v,{ref:"styleSettingRef",env:a.env,onCallback:a.saveEnv,os:a.osInfo.clientOS},null,8,["env","onCallback","os"]),(0,c.Wm)(m,{ref:"fileBlockRef",sshKey:a.sshKey,os:a.osInfo.clientOS},null,8,["sshKey","os"]),(0,c.Wm)(y,{ref:"userTcodeRef",onImportTCodes:a.importTCodes,onExportTcodes:a.exportTcodes},null,8,["onImportTCodes","onExportTcodes"]),(0,c.Wm)(k,{ref:"helpTcodeRef",userTCodes:a.tcodes,onHandleSaveTCode:a.handleSaveTCode},null,8,["userTCodes","onHandleSaveTCode"])],64)}t(7658),t(6229),t(7330),t(2062);var U=t(7071),R=t(4870),N=t(5595),j=t(6537),M=t(7114);const Q={server_ip:"",server_port:22,server_user:"root",server_password:"",option:"",bg:"#0c0c0c",fg:"#cccccc",fontFamily:"Courier New",fontSize:16,cursorStyle:"block",cursorBlink:!0,tCode:!0};let P=window.location.protocol,K="";K="https:"==P?"wss://":"ws://";const L=K+window.location.host+"/socket/ssh/",J=P+"//"+window.location.host+"/api";function G(e){let l="";for(let t=0;t((0,c.dD)("data-v-663bb10e"),e=e(),(0,c.Cn)(),e),Y=Z((()=>(0,c._)("div",{style:{"margin-top":"-25px"}},null,-1))),X={class:"item-class",style:{"margin-bottom":"15px"}},$=Z((()=>(0,c._)("div",{class:"no-select nowrap"},"配 置:",-1))),ee=Z((()=>(0,c._)("div",{style:{flex:"1"}},null,-1))),le={class:"item-class",style:{"margin-bottom":"15px"}},te=Z((()=>(0,c._)("div",{class:"no-select"},"主机ip:",-1))),ae={class:"item-class",style:{"margin-bottom":"15px"}},oe=Z((()=>(0,c._)("div",{class:"no-select"},"端口号:",-1))),ie={class:"item-class",style:{"margin-bottom":"15px"}},se=Z((()=>(0,c._)("div",{class:"no-select"},"用户名:",-1))),ne={class:"item-class",style:{"margin-bottom":"5px"}},re=Z((()=>(0,c._)("div",{class:"no-select"},"密 码:",-1))),ue={class:"errInfo no-select"},de=Z((()=>(0,c._)("div",{style:{"margin-bottom":"5px"}},null,-1))),ce={style:{display:"flex","border-top":"1px solid #f1f2f4"}},pe=Z((()=>(0,c._)("div",{style:{flex:"1"}},null,-1)));function ve(e,l,t,a,o,i){const s=(0,c.up)("Switch"),n=(0,c.up)("el-icon"),r=(0,c.up)("el-button"),u=(0,c.up)("Finished"),d=(0,c.up)("Edit"),p=(0,c.up)("HomeFilled"),v=(0,c.up)("el-input"),m=(0,c.up)("DocumentCopy"),g=(0,c.up)("Paperclip"),f=(0,c.up)("User"),y=(0,c.up)("Lock"),w=(0,c.up)("View"),k=(0,c.up)("Hide"),h=(0,c.up)("el-dialog"),_=(0,c.up)("OptionBlock");return(0,c.wg)(),(0,c.iD)(c.HY,null,[(0,c.Wm)(h,{modelValue:a.DialogVisilble,"onUpdate:modelValue":l[11]||(l[11]=e=>a.DialogVisilble=e),"destory-on-close":!0,"before-close":a.closeDialog,width:360,title:"连接设置",modal:!1,"close-on-click-modal":!1,"modal-class":"kk-dialog-class","align-center":"",draggable:""},{default:(0,c.w5)((()=>[Y,(0,c._)("div",null,[(0,c._)("div",X,[$,(0,c._)("div",{class:(0,q.C_)(["ellipsis",a.setInfo.option&&a.setInfo.option.length>0?"old-option":"new-option"]),style:{"user-select":"none"}},(0,q.zw)(a.setInfo.option&&a.setInfo.option.length>0?a.setInfo.option:"新建配置"),3),ee,(0,c._)("div",null,[(0,c.Wm)(r,{size:"small",type:"primary",onClick:l[0]||(l[0]=e=>a.showOption(0)),style:{"margin-left":"10px"}},{default:(0,c.w5)((()=>[(0,c.Wm)(n,{class:"el-icon--left"},{default:(0,c.w5)((()=>[(0,c.Wm)(s)])),_:1}),(0,c.Uk)("切换")])),_:1})]),(0,c._)("div",null,[0==a.isForbidInput?((0,c.wg)(),(0,c.j4)(r,{key:0,size:"small",type:"primary",onClick:l[1]||(l[1]=e=>a.showOption(1)),style:{"margin-left":"10px"}},{default:(0,c.w5)((()=>[(0,c.Wm)(n,{class:"el-icon--left"},{default:(0,c.w5)((()=>[(0,c.Wm)(u)])),_:1}),(0,c.Uk)("保存")])),_:1})):(0,c.kq)("",!0)]),(0,c._)("div",null,[1==a.isForbidInput?((0,c.wg)(),(0,c.j4)(r,{key:0,size:"small",type:"primary",onClick:a.newOp,style:{"margin-left":"10px"}},{default:(0,c.w5)((()=>[(0,c.Wm)(n,{class:"el-icon--left"},{default:(0,c.w5)((()=>[(0,c.Wm)(d)])),_:1}),(0,c.Uk)("新建")])),_:1},8,["onClick"])):(0,c.kq)("",!0)])]),(0,c._)("div",le,[te,(0,c._)("div",null,[(0,c.Wm)(v,{disabled:a.isForbidInput,modelValue:a.setInfo.server_ip,"onUpdate:modelValue":l[2]||(l[2]=e=>a.setInfo.server_ip=e),class:"w-50 m-2",placeholder:"输入主机ip"},{prefix:(0,c.w5)((()=>[(0,c.Wm)(n,null,{default:(0,c.w5)((()=>[(0,c.Wm)(p)])),_:1})])),_:1},8,["disabled","modelValue"])]),(0,c._)("div",{style:{cursor:"pointer","margin-left":"10px"},onClick:l[3]||(l[3]=e=>a.doCopy(a.setInfo.server_ip))},[(0,c.Wm)(n,{size:"15"},{default:(0,c.w5)((()=>[(0,c.Wm)(m)])),_:1})])]),(0,c._)("div",ae,[oe,(0,c._)("div",null,[(0,c.Wm)(v,{disabled:a.isForbidInput,modelValue:a.setInfo.server_port,"onUpdate:modelValue":l[4]||(l[4]=e=>a.setInfo.server_port=e),class:"w-50 m-2",placeholder:"输入端口号"},{prefix:(0,c.w5)((()=>[(0,c.Wm)(n,null,{default:(0,c.w5)((()=>[(0,c.Wm)(g)])),_:1})])),_:1},8,["disabled","modelValue"])]),(0,c._)("div",{style:{cursor:"pointer","margin-left":"10px"},onClick:l[5]||(l[5]=e=>a.doCopy(a.setInfo.server_port))},[(0,c.Wm)(n,{size:"15"},{default:(0,c.w5)((()=>[(0,c.Wm)(m)])),_:1})])]),(0,c._)("div",ie,[se,(0,c._)("div",null,[(0,c.Wm)(v,{disabled:a.isForbidInput,modelValue:a.setInfo.server_user,"onUpdate:modelValue":l[6]||(l[6]=e=>a.setInfo.server_user=e),class:"w-50 m-2",placeholder:"输入用户名"},{prefix:(0,c.w5)((()=>[(0,c.Wm)(n,{class:"el-input__icon"},{default:(0,c.w5)((()=>[(0,c.Wm)(f)])),_:1})])),_:1},8,["disabled","modelValue"])]),(0,c._)("div",{style:{cursor:"pointer","margin-left":"10px"},onClick:l[7]||(l[7]=e=>a.doCopy(a.setInfo.server_user))},[(0,c.Wm)(n,{size:"15"},{default:(0,c.w5)((()=>[(0,c.Wm)(m)])),_:1})])]),(0,c._)("div",ne,[re,(0,c._)("div",null,[(0,c.Wm)(v,{disabled:a.isForbidInput,modelValue:a.setInfo.server_password,"onUpdate:modelValue":l[8]||(l[8]=e=>a.setInfo.server_password=e),type:a.isShowPassword?"text":"password",class:"w-50 m-2",placeholder:"输入密码"},{prefix:(0,c.w5)((()=>[(0,c.Wm)(n,{class:"el-input__icon"},{default:(0,c.w5)((()=>[(0,c.Wm)(y)])),_:1})])),_:1},8,["disabled","modelValue","type"])]),1==a.isShowPassword?((0,c.wg)(),(0,c.iD)("div",{key:0,style:{cursor:"pointer","margin-left":"10px"},onClick:l[9]||(l[9]=e=>a.isShowPassword=!1)},[(0,c.Wm)(n,{size:"15"},{default:(0,c.w5)((()=>[(0,c.Wm)(w)])),_:1})])):((0,c.wg)(),(0,c.iD)("div",{key:1,style:{cursor:"pointer","margin-left":"10px"},onClick:l[10]||(l[10]=e=>a.isShowPassword=!0)},[(0,c.Wm)(n,{size:"15"},{default:(0,c.w5)((()=>[(0,c.Wm)(k)])),_:1})]))])]),(0,c._)("div",ue,(0,q.zw)(a.err_msg),1),de,(0,c._)("div",ce,[pe,(0,c.Wm)(r,{size:"small",type:"primary",onClick:a.confirm,style:{"margin-bottom":"-15px","margin-top":"10px"}},{default:(0,c.w5)((()=>[(0,c.Uk)(" 确定 ")])),_:1},8,["onClick"])])])),_:1},8,["modelValue","before-close"]),(0,c.Wm)(_,{ref:"optionBlockRef",onCallback:a.doOption,opType:a.optionBlockType,sshOptions:t.sshOptions},null,8,["onCallback","opType","sshOptions"])],64)}const me=e=>((0,c.dD)("data-v-1f07a939"),e=e(),(0,c.Cn)(),e),ge=me((()=>(0,c._)("div",{style:{"margin-top":"-27px"}},null,-1))),fe={class:"no-select"},ye={key:0,class:"kk-border"},we=["onClick"],ke={class:"ellipsis",style:{margin:"0 10px"}},he={key:1,class:"kk-border"},_e={class:"kk-flex"},xe=me((()=>(0,c._)("div",null,"配置名:",-1))),Ce={style:{flex:"1"}},Se={style:{"margin-left":"10px"}},be=me((()=>(0,c._)("div",{style:{"margin-top":"-15px"}},null,-1)));function Ie(e,l,t,a,o,i){const s=(0,c.up)("FileIcons"),n=(0,c.up)("NoData"),r=(0,c.up)("el-input"),u=(0,c.up)("el-button"),d=(0,c.up)("el-dialog");return(0,c.wg)(),(0,c.j4)(d,{modelValue:a.DialogVisilble,"onUpdate:modelValue":l[1]||(l[1]=e=>a.DialogVisilble=e),"before-close":a.closeDialog,"destroy-on-close":"",width:420,modal:!1,title:"全部配置","modal-class":"kk-dialog-class",draggable:""},{default:(0,c.w5)((()=>[ge,(0,c._)("div",fe,[Object.keys(t.sshOptions).length>0?((0,c.wg)(),(0,c.iD)("div",ye,[((0,c.wg)(!0),(0,c.iD)(c.HY,null,(0,c.Ko)(t.sshOptions,((e,l)=>((0,c.wg)(),(0,c.iD)("div",{key:l},[(0,c._)("div",{class:(0,q.C_)(["item-class",a.aimOption==l?"item-selected":""]),onClick:e=>a.aimOption=l},[(0,c.Wm)(s,{name:"kk.txt",width:"20",height:"20",isFolder:!1}),(0,c._)("div",ke,(0,q.zw)(l),1)],10,we)])))),128))])):((0,c.wg)(),(0,c.iD)("div",he,[(0,c.Wm)(n,{msg:a.noDataMsg},null,8,["msg"])])),(0,c._)("div",_e,[xe,(0,c._)("div",Ce,[(0,c.Wm)(r,{size:"small",modelValue:a.aimOption,"onUpdate:modelValue":l[0]||(l[0]=e=>a.aimOption=e),disabled:0==t.opType,class:"w-50 m-2",placeholder:""},null,8,["modelValue","disabled"])]),(0,c._)("div",Se,[(0,c.Wm)(u,{size:"small",type:"primary",onClick:a.confirm},{default:(0,c.w5)((()=>[(0,c.Uk)((0,q.zw)(t.opType?"保存":"选择"),1)])),_:1},8,["onClick"])])])]),be])),_:1},8,["modelValue","before-close"])}var De=t.p+"img/no_data.ec5c928e.png";const Ee=e=>((0,c.dD)("data-v-7a3a533e"),e=e(),(0,c.Cn)(),e),Te=Ee((()=>(0,c._)("div",null,[(0,c._)("img",{src:De,alt:"暂无数据",style:{width:"120px"}})],-1))),We={class:"msg"};function Ve(e,l,t,a,o,i){return(0,c.wg)(),(0,c.iD)("div",{class:"no-data",style:(0,q.j5)(a.viewStyle)},[(0,c._)("div",null,[(0,c.WI)(e.$slots,"myslot",{},void 0,!0),Te,(0,c._)("div",We,(0,q.zw)(t.msg),1)])],4)}var Fe={name:"NoData",components:{},props:{msg:{type:String,required:!1,default:"暂无数据"},width:{type:String,required:!1},height:{type:String,required:!1}},setup(e){const l=(0,c.Fl)((()=>({width:e.width?e.width+"px":"100%",height:e.height?e.height+"px":"30vh"})));return{viewStyle:l}}},Ae=t(89);const Be=(0,Ae.Z)(Fe,[["render",Ve],["__scopeId","data-v-7a3a533e"]]);var ze=Be,He=t(3223),Oe=t.n(He),Ue={name:"OptionBlock",components:{FileIcons:Oe(),NoData:ze},props:["opType","sshOptions"],setup(e,l){const t=(0,R.iH)(!1),a=(0,R.iH)(""),o=(0,R.iH)("暂无配置"),i=(0,R.iH)(""),s=()=>{""!=i.value&&""!=i.value.trim()&&(l.emit("callback",i.value.trim()),t.value=!1)},n=e=>{i.value="",e()};return{DialogVisilble:t,err_msg:a,noDataMsg:o,aimOption:i,confirm:s,closeDialog:n}}};const Re=(0,Ae.Z)(Ue,[["render",Ie],["__scopeId","data-v-1f07a939"]]);var Ne=Re,je=t(2748),Me={name:"ConnectSetting",components:{OptionBlock:Ne,HomeFilled:je.Ozs,Paperclip:je.pkz,User:je.n5m,Lock:je.HEZ,DocumentCopy:je.IBc,View:je.G7x,Hide:je.caK,Edit:je.I8b,Finished:je.qWi,Switch:je.rsf},props:["env","sshOptions"],setup(e,l){const t=(0,R.iH)(!1),a=(0,R.iH)(""),o=(0,R.iH)({server_ip:e.env.server_ip,server_port:e.env.server_port,server_user:e.env.server_user,server_password:e.env.server_password,option:e.env.option}),i=()=>{a.value="";const e=/^(?:(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.){3}(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)$/;return e.test(o.value.server_ip)?isNaN(o.value.server_port)||o.value.server_port<0||o.value.server_port>65535?(a.value="端口号无效",!1):o.value.server_user&&""!=o.value.server_user?!(!o.value.server_password||""==o.value.server_password)||(a.value="密码不能为空",!1):(a.value="用户名不能为空",!1):(a.value="主机ip地址无效",!1)},s=(0,R.iH)(),n=(0,R.iH)(0),r=e=>{1==e&&0==i()||(n.value=e,s.value.DialogVisilble=!0,s.value.aimOption="")},u=(0,R.iH)(!1);""!=o.value.option&&(u.value=!0);const d=t=>{0==n.value?(o.value={...o.value,...e.sshOptions[t]},u.value=!0):1==n.value&&(o.value.option=t,l.emit("saveOp",t,o.value),u.value=!0)},c=()=>{u.value=!1,o.value.option=""},p=()=>{0!=i()&&(l.emit("callback",o.value),t.value=!1)},{toClipboard:v}=(0,U.Z)(),m=async e=>{e+="",e&&e.length>0?(await v(e),(0,N.z8)({message:"复制成功",type:"success",grouping:!0,repeatNum:Number.MIN_SAFE_INTEGER})):(0,N.z8)({message:"内容为空",type:"warning",grouping:!0,repeatNum:Number.MIN_SAFE_INTEGER})},g=(0,R.iH)(!1),f=l=>{s.value.DialogVisilble=!1,setTimeout((()=>{a.value="",g.value=!1,o.value={server_ip:e.env.server_ip,server_port:e.env.server_port,server_user:e.env.server_user,server_password:e.env.server_password,option:e.env.option},""!=o.value.option?u.value=!0:u.value=!1}),200),l()};return{setInfo:o,DialogVisilble:t,err_msg:a,confirm:p,optionBlockRef:s,showOption:r,optionBlockType:n,doOption:d,isForbidInput:u,newOp:c,closeDialog:f,doCopy:m,isShowPassword:g}}};const Qe=(0,Ae.Z)(Me,[["render",ve],["__scopeId","data-v-663bb10e"]]);var Pe=Qe;const Ke=e=>((0,c.dD)("data-v-d18bce82"),e=e(),(0,c.Cn)(),e),Le=Ke((()=>(0,c._)("div",{style:{"margin-top":"-27px"}},null,-1))),Je={class:"no-select"},Ge={class:"item-class",style:{"margin-bottom":"15px"}},qe=Ke((()=>(0,c._)("div",{style:{"margin-right":"10px"}},"颜色:",-1))),Ze={class:"item-class"},Ye=Ke((()=>(0,c._)("div",null,"背景色",-1))),Xe={style:{margin:"0 20px"}},$e=Ke((()=>(0,c._)("div",{style:{width:"20px"}},null,-1))),el={class:"item-class"},ll=Ke((()=>(0,c._)("div",null,"前景色",-1))),tl={style:{margin:"0 20px"}},al={class:"item-class",style:{"margin-bottom":"15px"}},ol=Ke((()=>(0,c._)("div",{style:{"margin-right":"10px"}},"文本:",-1))),il={class:"item-class"},sl=Ke((()=>(0,c._)("div",null,"字体",-1))),nl={class:"a-link"},rl={class:"item-class"},ul=Ke((()=>(0,c._)("div",null,"字号",-1))),dl={class:"a-link"},cl={class:"item-class",style:{"margin-bottom":"5px"}},pl=Ke((()=>(0,c._)("div",{style:{"margin-right":"10px"}},"光标:",-1))),vl={class:"item-class"},ml=Ke((()=>(0,c._)("div",null,"样式",-1))),gl={class:"a-link"},fl={class:"item-class"},yl=Ke((()=>(0,c._)("div",null,"闪烁",-1))),wl={style:{margin:"0 20px"}},kl={class:"item-class",style:{"margin-bottom":"5px"}},hl=Ke((()=>(0,c._)("div",{style:{"margin-right":"10px"}},"功能:",-1))),_l={class:"item-class"},xl=Ke((()=>(0,c._)("div",null,"TCode",-1))),Cl={style:{margin:"0 20px"}},Sl=Ke((()=>(0,c._)("div",{style:{"margin-bottom":"5px"}},null,-1))),bl={style:{display:"flex","border-top":"1px solid #f1f2f4"}},Il=Ke((()=>(0,c._)("div",{style:{flex:"1"}},null,-1)));function Dl(e,l,t,a,o,i){const s=(0,c.up)("el-color-picker"),n=(0,c.up)("arrow-down"),r=(0,c.up)("el-icon"),u=(0,c.up)("el-dropdown-item"),d=(0,c.up)("el-dropdown-menu"),p=(0,c.up)("el-dropdown"),v=(0,c.up)("el-switch"),m=(0,c.up)("el-button"),g=(0,c.up)("el-dialog");return(0,c.wg)(),(0,c.j4)(g,{modelValue:a.DialogVisilble,"onUpdate:modelValue":l[4]||(l[4]=e=>a.DialogVisilble=e),"destroy-on-close":"",width:420,title:"偏好设置",modal:!1,"modal-class":"kk-dialog-class",draggable:""},{default:(0,c.w5)((()=>[Le,(0,c._)("div",Je,[(0,c._)("div",Ge,[qe,(0,c._)("div",Ze,[Ye,(0,c._)("div",Xe,[(0,c.Wm)(s,{modelValue:a.setInfo.bg,"onUpdate:modelValue":l[0]||(l[0]=e=>a.setInfo.bg=e)},null,8,["modelValue"])])]),$e,(0,c._)("div",el,[ll,(0,c._)("div",tl,[(0,c.Wm)(s,{modelValue:a.setInfo.fg,"onUpdate:modelValue":l[1]||(l[1]=e=>a.setInfo.fg=e)},null,8,["modelValue"])])])]),(0,c._)("div",al,[ol,(0,c._)("div",il,[sl,(0,c.Wm)(p,{style:{margin:"0 20px"}},{dropdown:(0,c.w5)((()=>[(0,c.Wm)(d,null,{default:(0,c.w5)((()=>[((0,c.wg)(!0),(0,c.iD)(c.HY,null,(0,c.Ko)(a.fontFamilyList,((e,l)=>((0,c.wg)(),(0,c.j4)(u,{key:l,onClick:l=>a.setInfo.fontFamily=e},{default:(0,c.w5)((()=>[(0,c.Uk)((0,q.zw)(e),1)])),_:2},1032,["onClick"])))),128))])),_:1})])),default:(0,c.w5)((()=>[(0,c._)("span",nl,[(0,c.Uk)((0,q.zw)(a.setInfo.fontFamily),1),(0,c.Wm)(r,{class:"el-icon--right"},{default:(0,c.w5)((()=>[(0,c.Wm)(n)])),_:1})])])),_:1})]),(0,c._)("div",rl,[ul,(0,c.Wm)(p,{style:{margin:"0 20px"}},{dropdown:(0,c.w5)((()=>[(0,c.Wm)(d,null,{default:(0,c.w5)((()=>[((0,c.wg)(!0),(0,c.iD)(c.HY,null,(0,c.Ko)(a.fontSizeList,((e,l)=>((0,c.wg)(),(0,c.j4)(u,{key:l,onClick:l=>a.setInfo.fontSize=e},{default:(0,c.w5)((()=>[(0,c.Uk)((0,q.zw)(e),1)])),_:2},1032,["onClick"])))),128))])),_:1})])),default:(0,c.w5)((()=>[(0,c._)("span",dl,[(0,c.Uk)((0,q.zw)(a.setInfo.fontSize),1),(0,c.Wm)(r,{class:"el-icon--right"},{default:(0,c.w5)((()=>[(0,c.Wm)(n)])),_:1})])])),_:1})])]),(0,c._)("div",cl,[pl,(0,c._)("div",vl,[ml,(0,c.Wm)(p,{style:{margin:"0 20px"}},{dropdown:(0,c.w5)((()=>[(0,c.Wm)(d,null,{default:(0,c.w5)((()=>[((0,c.wg)(!0),(0,c.iD)(c.HY,null,(0,c.Ko)(a.cursorStyleList,((e,l)=>((0,c.wg)(),(0,c.j4)(u,{key:l,onClick:l=>a.setInfo.cursorStyle=e},{default:(0,c.w5)((()=>[(0,c.Uk)((0,q.zw)(e),1)])),_:2},1032,["onClick"])))),128))])),_:1})])),default:(0,c.w5)((()=>[(0,c._)("span",gl,[(0,c.Uk)((0,q.zw)(a.setInfo.cursorStyle),1),(0,c.Wm)(r,{class:"el-icon--right"},{default:(0,c.w5)((()=>[(0,c.Wm)(n)])),_:1})])])),_:1})]),(0,c._)("div",fl,[yl,(0,c._)("div",wl,[(0,c.Wm)(v,{modelValue:a.setInfo.cursorBlink,"onUpdate:modelValue":l[2]||(l[2]=e=>a.setInfo.cursorBlink=e)},null,8,["modelValue"])])])]),(0,c._)("div",kl,[hl,(0,c._)("div",_l,[xl,(0,c._)("div",Cl,[(0,c.Wm)(v,{modelValue:a.setInfo.tCode,"onUpdate:modelValue":l[3]||(l[3]=e=>a.setInfo.tCode=e)},null,8,["modelValue"])])])])]),Sl,(0,c._)("div",bl,[Il,(0,c.Wm)(m,{size:"small",type:"primary",onClick:a.confirm,style:{"margin-bottom":"-15px","margin-top":"10px"}},{default:(0,c.w5)((()=>[(0,c.Uk)(" 确定 ")])),_:1},8,["onClick"])])])),_:1},8,["modelValue"])}var El={name:"StyleSetting",components:{ArrowDown:je.K5e},props:["env","os"],setup(e,l){const t=(0,R.iH)(!1),a=(0,c.Fl)((()=>"Windows"==e.os?["Courier New","Consolas","Monospace","Lucida Console"]:"Mac"==e.os||"iOS"==e.os?["Courier New","Menlo","Monaco","Courier"]:["Courier New","Consolas","Monospace","Lucida Console"])),o=[12,14,16,18,20],i=["block","underline","bar"],s=(0,R.iH)({bg:e.env.bg,fg:e.env.fg,fontFamily:e.env.fontFamily,fontSize:e.env.fontSize,cursorStyle:e.env.cursorStyle,cursorBlink:e.env.cursorBlink,tCode:e.env.tCode}),n=()=>{l.emit("callback",s.value),t.value=!1};return{fontFamilyList:a,fontSizeList:o,cursorStyleList:i,setInfo:s,DialogVisilble:t,confirm:n}}};const Tl=(0,Ae.Z)(El,[["render",Dl],["__scopeId","data-v-d18bce82"]]);var Wl=Tl;const Vl=e=>((0,c.dD)("data-v-7d7f3746"),e=e(),(0,c.Cn)(),e),Fl=Vl((()=>(0,c._)("div",{style:{"margin-top":"-27px"}},null,-1))),Al={class:"title",style:{display:"flex","align-items":"center"}},Bl={class:"ellipsis",style:{flex:"1"}},zl={key:0},Hl={style:{display:"flex","align-items":"center"}},Ol={key:1,class:"disabled-function",style:{"margin-left":"10px","font-size":"18px",cursor:"pointer"}},Ul={key:3,class:"disabled-function",style:{"margin-left":"10px","font-size":"18px",cursor:"pointer"}},Rl={key:5,class:"disabled-function",style:{"margin-left":"10px","font-size":"18px",cursor:"pointer"}},Nl={key:0},jl=["onClick","onDblclick","onContextmenu"],Ml={key:0,style:{margin:"0 10px"}},Ql={key:1,class:"ellipsis",style:{margin:"0 10px"}},Pl=["onClick","onDblclick","onContextmenu"],Kl={key:0,style:{margin:"0 10px"}},Ll={key:1,class:"ellipsis",style:{margin:"0 10px"}},Jl={key:1},Gl=Vl((()=>(0,c._)("div",{style:{"margin-top":"-12px"}},null,-1))),ql=Vl((()=>(0,c._)("div",{class:"no-select",style:{"font-size":"13px","margin-top":"4px"}},"确定删除此文件/文件夹吗?",-1)));function Zl(e,l,t,a,o,i){const s=(0,c.up)("el-input"),n=(0,c.up)("Refresh"),r=(0,c.up)("el-icon"),u=(0,c.up)("Fold"),p=(0,c.up)("Download"),v=(0,c.up)("Upload"),m=(0,c.up)("el-upload"),g=(0,c.up)("FileIcons"),f=(0,c.up)("NoData"),y=(0,c.up)("el-dialog"),w=(0,c.up)("TxtPreview"),k=(0,c.up)("MkFile"),h=(0,c.up)("FileAttr"),_=(0,c.up)("el-button"),x=(0,c.up)("a-popconfirm"),C=(0,c.Q2)("loading");return(0,c.wg)(),(0,c.iD)(c.HY,null,[(0,c.Wm)(y,{modelValue:a.DialogVisilble,"onUpdate:modelValue":l[14]||(l[14]=e=>a.DialogVisilble=e),"before-close":a.closeDialog,title:"文件管理",width:"50%",modal:!1,"modal-class":"kk-dialog-class",draggable:"",style:{position:"relative"}},{default:(0,c.w5)((()=>[Fl,(0,c._)("div",null,[(0,c._)("div",Al,[(0,c._)("div",Bl,[1==a.isShowDirInput?((0,c.wg)(),(0,c.iD)("div",zl,[(0,c.Wm)(s,{id:"aimDirInput",modelValue:a.dir,"onUpdate:modelValue":l[0]||(l[0]=e=>a.dir=e),placeholder:"输入目录路径",size:"small",onBlur:a.dirInputCallback},null,8,["modelValue","onBlur"])])):((0,c.wg)(),(0,c.iD)("div",{key:1,class:"no-select ellipsis",onDblclick:l[1]||(l[1]=(...e)=>a.doShowDirInput&&a.doShowDirInput(...e))},(0,q.zw)(a.dir),33))]),(0,c._)("div",Hl,[(0,c._)("div",{class:"hover-class",onClick:l[2]||(l[2]=(...e)=>a.doRefresh&&a.doRefresh(...e)),style:{"margin-left":"10px","font-size":"18px",cursor:"pointer"}},[(0,c.Wm)(r,null,{default:(0,c.w5)((()=>[(0,c.Wm)(n)])),_:1})]),a.dir&&"/"!=a.dir?((0,c.wg)(),(0,c.iD)("div",{key:0,class:"hover-class",onClick:l[3]||(l[3]=(...e)=>a.doReturn&&a.doReturn(...e)),style:{"margin-left":"10px","font-size":"18px",cursor:"pointer"}},[(0,c.Wm)(r,null,{default:(0,c.w5)((()=>[(0,c.Wm)(u)])),_:1})])):((0,c.wg)(),(0,c.iD)("div",Ol,[(0,c.Wm)(r,null,{default:(0,c.w5)((()=>[(0,c.Wm)(u)])),_:1})])),1==a.selectedFiles.length?((0,c.wg)(),(0,c.iD)("div",{key:2,class:"hover-class",onClick:l[4]||(l[4]=(...e)=>a.doDownload&&a.doDownload(...e)),style:{"margin-left":"10px","font-size":"18px",cursor:"pointer"}},[(0,c.Wm)(r,null,{default:(0,c.w5)((()=>[(0,c.Wm)(p)])),_:1})])):((0,c.wg)(),(0,c.iD)("div",Ul,[(0,c.Wm)(r,null,{default:(0,c.w5)((()=>[(0,c.Wm)(p)])),_:1})])),0==a.dirStatus?((0,c.wg)(),(0,c.iD)("div",{key:4,class:"hover-class",onClick:l[5]||(l[5]=(...e)=>a.doUpload&&a.doUpload(...e)),style:{"margin-left":"10px","font-size":"18px",cursor:"pointer"}},[(0,c.Wm)(m,{"show-file-list":!1,"with-credentials":!0,"http-request":a.doUpload,multiple:!0},{default:(0,c.w5)((()=>[(0,c.Wm)(r,null,{default:(0,c.w5)((()=>[(0,c.Wm)(v)])),_:1})])),_:1},8,["http-request"])])):((0,c.wg)(),(0,c.iD)("div",Rl,[(0,c.Wm)(r,null,{default:(0,c.w5)((()=>[(0,c.Wm)(v)])),_:1})]))])]),(0,c.wy)(((0,c.wg)(),(0,c.iD)("div",{id:"fileArea",ref:"fileAreaRef","element-loading-text":"Loading...",class:"list-class no-select",onContextmenu:l[9]||(l[9]=(...e)=>a.handleContextMenu&&a.handleContextMenu(...e)),onScroll:l[10]||(l[10]=(...e)=>a.handleScroll&&a.handleScroll(...e)),onDragover:l[11]||(l[11]=(...e)=>a.preventDefault&&a.preventDefault(...e)),onDrop:l[12]||(l[12]=(...e)=>a.handleFileDrag&&a.handleFileDrag(...e)),tabindex:"0",onKeydown:l[13]||(l[13]=(...e)=>a.handleShortcutKeys&&a.handleShortcutKeys(...e))},[0!=a.files.length?((0,c.wg)(),(0,c.iD)("div",Nl,[((0,c.wg)(!0),(0,c.iD)(c.HY,null,(0,c.Ko)(a.files,(e=>((0,c.wg)(),(0,c.iD)("div",{key:e.id},[1==e.isDirectory?((0,c.wg)(),(0,c.iD)("div",{key:0,class:(0,q.C_)([-1!=a.isSelected(e.id)?"item-selected":"","item-class"]),onClick:l=>a.addSelectFile(l,e),onDblclick:l=>a.changeDir(a.dir+e.name+"/"),onContextmenu:l=>a.addSelectFile(l,e,!1)},[(0,c.Wm)(g,{style:(0,q.j5)({opacity:-1!=a.isClipboard(e.id)&&a.isCtrlx?.5:1}),name:e.name,width:"20",height:"20",isFolder:e.isDirectory},null,8,["style","name","isFolder"]),1==a.isShowRenameInput&&a.renameFile&&e.id==a.renameFile.id?((0,c.wg)(),(0,c.iD)("div",Ml,[(0,c.Wm)(s,{id:"rename",modelValue:a.renameFile.name,"onUpdate:modelValue":l[6]||(l[6]=e=>a.renameFile.name=e),placeholder:"",size:"small",onBlur:l=>a.handleRename(e)},null,8,["modelValue","onBlur"])])):((0,c.wg)(),(0,c.iD)("div",Ql,(0,q.zw)(e.name),1))],42,jl)):((0,c.wg)(),(0,c.iD)("div",{key:1,class:(0,q.C_)([-1!=a.isSelected(e.id)?"item-selected":"","item-class"]),onClick:l=>a.addSelectFile(l,e),onDblclick:l=>a.preViewFile(e.name),onContextmenu:l=>a.addSelectFile(l,e,!1)},[(0,c.Wm)(g,{style:(0,q.j5)({opacity:-1!=a.isClipboard(e.id)&&a.isCtrlx?.5:1}),name:e.name,width:"20",height:"20",isFolder:e.isDirectory},null,8,["style","name","isFolder"]),1==a.isShowRenameInput&&a.renameFile&&e.id==a.renameFile.id?((0,c.wg)(),(0,c.iD)("div",Kl,[(0,c.Wm)(s,{id:"rename",modelValue:a.renameFile.name,"onUpdate:modelValue":l[7]||(l[7]=e=>a.renameFile.name=e),placeholder:"",size:"small",onBlur:l=>a.handleRename(e)},null,8,["modelValue","onBlur"])])):((0,c.wg)(),(0,c.iD)("div",Ll,(0,q.zw)(e.name),1))],42,Pl))])))),128))])):((0,c.wg)(),(0,c.iD)("div",Jl,[0==a.loading?((0,c.wg)(),(0,c.j4)(f,{key:0,onContextmenu:l[8]||(l[8]=e=>a.selectedFiles=[]),msg:a.noDataMsg},null,8,["msg"])):(0,c.kq)("",!0)]))],32)),[[C,a.loading]])]),Gl])),_:1},8,["modelValue","before-close"]),(0,c.Wm)(w,{ref:"txtPreviewRef",onDoSave:a.doSave},null,8,["onDoSave"]),(0,c.Wm)(k,{ref:"mkFileRef",onCallback:a.handleMkFile},null,8,["onCallback"]),(0,c.Wm)(h,{ref:"fileAttrRef",onCallback:a.doRename},null,8,["onCallback"]),(0,c.wy)((0,c._)("div",{ref:"menuBlockRef",onContextmenu:l[23]||(l[23]=(...e)=>a.preventDefault&&a.preventDefault(...e)),class:"kk-menu no-select"},[(0,c._)("div",{style:{"border-bottom":"1px solid #ddd"},class:"kk-menu-item",onClick:l[15]||(l[15]=e=>a.handleMenuSelect(1)),key:"1"},"刷新"),(0,c._)("div",{class:(0,q.C_)(["kk-menu-item",1!=a.selectedFiles.length?"disabled":""]),onClick:l[16]||(l[16]=e=>a.handleMenuSelect(2)),key:"2"},"打开",2),(0,c._)("div",{style:{"border-bottom":"1px solid #ddd"},class:(0,q.C_)(["kk-menu-item",a.selectedFiles.length>1?"disabled":""]),onClick:l[17]||(l[17]=e=>a.handleMenuSelect(3)),key:"3"},"复制路径",2),(0,c._)("div",{class:(0,q.C_)(["kk-menu-item",1!=a.selectedFiles.length?"disabled":""]),onClick:l[18]||(l[18]=e=>a.handleMenuSelect(4)),key:"4"},"下载",2),(0,c._)("div",{class:(0,q.C_)(["kk-menu-item",1==a.dirStatus?"disabled":""]),onClick:l[19]||(l[19]=e=>a.handleMenuSelect(5)),key:"5"},"新建",2),(0,c._)("div",{class:(0,q.C_)(["kk-menu-item",1!=a.selectedFiles.length?"disabled":""]),onClick:l[20]||(l[20]=e=>a.handleMenuSelect(6)),key:"6"},"重命名",2),(0,c.Wm)(x,{open:a.isShowMenu&&a.isShowPop,overlayStyle:{zIndex:3466,marginLeft:"10px"},placement:"rightBottom","ok-text":"确定","cancel-text":"取消"},{title:(0,c.w5)((()=>[ql])),okButton:(0,c.w5)((()=>[(0,c.Wm)(_,{id:"sureDelFileBtn",size:"small",type:"primary",onClick:a.handlePopConfirm},{default:(0,c.w5)((()=>[(0,c.Uk)("确定")])),_:1},8,["onClick"])])),cancelButton:(0,c.w5)((()=>[(0,c.Wm)(_,{size:"small",text:""},{default:(0,c.w5)((()=>[(0,c.Uk)("取消")])),_:1})])),default:(0,c.w5)((()=>[(0,c._)("div",{class:(0,q.C_)(["kk-menu-item",0==a.selectedFiles.length?"disabled":""]),key:"7"},[(0,c._)("div",{onClick:l[21]||(l[21]=e=>a.handleMenuSelect(7))},"删除")],2)])),_:1},8,["open"]),(0,c._)("div",{style:{"border-top":"1px solid #ddd"},class:(0,q.C_)(["kk-menu-item",1!=a.selectedFiles.length?"disabled":""]),onClick:l[22]||(l[22]=e=>a.handleMenuSelect(8)),key:"8"},"属性",2)],544),[[d.F8,a.isShowMenu]])],64)}const Yl=e=>((0,c.dD)("data-v-480795cf"),e=e(),(0,c.Cn)(),e),Xl={class:"kk-flex"},$l={class:"ellipsis",style:{margin:"0 5px","font-size":"larger"}},et=Yl((()=>(0,c._)("div",{style:{"margin-top":"-28px"}},null,-1))),lt={"element-loading-text":"Loading...",style:{padding:"0px 5px",width:"100%",height:"60vh"}},tt=Yl((()=>(0,c._)("div",{style:{"margin-top":"-13px"}},null,-1)));function at(e,l,t,a,o,i){const s=(0,c.up)("FileIcons"),n=(0,c.up)("AceEditor"),r=(0,c.up)("el-dialog"),u=(0,c.Q2)("loading");return(0,c.wg)(),(0,c.j4)(r,{modelValue:a.DialogVisilble,"onUpdate:modelValue":l[0]||(l[0]=e=>a.DialogVisilble=e),width:"80%",modal:!1,"modal-class":"kk-dialog-class","before-close":a.closeDialog,"align-center":"",draggable:""},{title:(0,c.w5)((()=>[(0,c._)("div",Xl,[(0,c.Wm)(s,{name:a.fileName,width:"25",height:"25",isFolder:!1},null,8,["name"]),(0,c._)("div",$l,(0,q.zw)(a.modifyTag+a.fileName),1)])])),default:(0,c.w5)((()=>[et,(0,c.wy)(((0,c.wg)(),(0,c.iD)("div",lt,[(0,c.Wm)(n,{ref:"codeEditorRef",onHandleChange:a.handleChange,onHandleSave:a.handleSave},null,8,["onHandleChange","onHandleSave"])])),[[u,a.loading]]),tt])),_:1},8,["modelValue","before-close"])}const ot={ref:"aceEditorRef",class:"kk-code-editor"};function it(e,l,t,a,o,i){return(0,c.wg)(),(0,c.iD)("div",ot,null,512)}var st=t(17),nt=t.n(st);t(7050),t(4783),t(2428),t(516),t(6684),t(350),t(8930),t(9986),t(3669),t(629),t(5045),t(1564),t(6668),t(1838),t(9375),t(2606),t(1948),t(4070),t(1853),t(6347),t(4840),t(498),t(9394),t(4733),t(7366),t(5293),t(6529),t(6895),t(8918),t(1910),t(5955),t(2376),t(8633),t(1710),t(1067),t(2841),t(1122),t(366),t(5824),t(7682),t(7535);const rt={c:"c_cpp",h:"c_cpp",cpp:"c_cpp",hpp:"c_cpp",cs:"csharp",css:"css",gitignore:"gitignore",go:"golang",html:"html",htm:"html",java:"java",js:"javascript",jsx:"javascript",json:"json",jsp:"jsp",md:"markdown",markdown:"markdown",properties:"properties",py:"python",sh:"sh",bash:"sh",sql:"sql",ts:"typescript",tsx:"typescript",vue:"javascript",xml:"xml",xsd:"xml",xsl:"xml",xslt:"xml",yaml:"yaml",yml:"yaml"},ut=e=>{let l="txt";if(e&&e.length>0){let t=e.lastIndexOf(".");-1!=t&&(l=e.substring(t+1))}return l};function dt(e){return rt[ut(e)]||"text"}var ct=t(18);const pt="tcode-local-vars",vt={"/A":{desc:"自定义TCode",execFlow(e){setTimeout((()=>{e.proxy.userTcodeRef.initText()}),1),e.proxy.userTcodeRef.DialogVisilble=!0}},"/O":{desc:"新建窗口",execFlow(){let e=window.location.href;window.open(e,"_blank")}},"/C":{desc:"关闭窗口",execFlow(){window.close()}},"/E":{desc:"退出登录",execFlow(e){e.proxy.socket&&e.proxy.socket.close(3131)}},"/R":{desc:"刷新页面",execFlow(){window.location.reload()}},"/H":{desc:"帮助",execFlow(e){e.proxy.helpTcodeRef.DialogVisilble=!0}}},mt={SC:{desc:"连接设置",execFlow(e){e.proxy.isShowSetting=!1,e.proxy.connectSettingRef.DialogVisilble=!0}},SP:{desc:"偏好设置",execFlow(e){e.proxy.isShowSetting=!1,e.proxy.styleSettingRef.DialogVisilble=!0}},SF:{desc:"文件管理",execFlow(e){e.proxy.isShowSetting=!1,e.proxy.fileBlockRef.DialogVisilble=!0,e.proxy.fileBlockRef.getInitDir()}},SS:{desc:"重启",execFlow(e){e.proxy.isShowSetting=!1,e.proxy.now_connect_status=e.proxy.connect_status["Connecting"],e.proxy.sshKey="",e.proxy.socket&&e.proxy.socket.close(3333),e.proxy.closeFileBlock(),e.proxy.doSSHConnect(),e.proxy.resetTerminal()}}},gt={active:!1,display:!0,outArray:[],cnt:0,variables:{session(e,l){if(void 0==l)return sessionStorage.getItem(e)?JSON.parse(sessionStorage.getItem(e)):null;sessionStorage.setItem(e,JSON.stringify(l))},local(e,l){let t={};if(localStorage.getItem(pt)&&(t=JSON.parse(u(localStorage.getItem(pt)))),void 0==l)return t[e];t[e]=l,localStorage.setItem(pt,r(JSON.stringify(t)))},clean(){if(0==arguments.length)return void localStorage.removeItem(pt);let e={};localStorage.getItem(pt)&&(e=JSON.parse(u(localStorage.getItem(pt))));for(let l=0;l0&&"\n"!=e[e.length-1]&&"\r"!=e[e.length-1]&&(e+="\n"),this.cnt=this.outArray.length,this.writeOnly(e,!0),await new Promise((e=>setTimeout(e,l>0?l:0)))},write(e,l=200){return this.writeAndWait(e,l)},read(){return ft(this.outArray.slice(this.cnt))},readAll(){return ft(this.outArray.slice(0))},hide(){this.display=!1},show(){this.display=!0}},ft=e=>{let l=[],t=yt(e);for(let a=0;a{let l=[];for(let t=0;t(0,ct.Z)(e).replace(/[\x00-\x1F\x7F]/g,""),kt={"Load Error":"Error","Execute Error":"Interrupted","Not Active":"Inactive","Execute Success":"Success"},ht={getCompletions:function(e,l,t,a,o){const i=[{name:"kkTerminal",value:"kkTerminal",meta:"kkTerminal",description:"kkTerminal API",score:1e3},{name:"variables",value:"variables",meta:"kkTerminal",description:"access variables",score:1e3},{name:"session",value:"session()",meta:"kkTerminal",description:"get or set session variables",score:1e3},{name:"local",value:"local()",meta:"kkTerminal",description:"get or set local variables",score:1e3},{name:"clean",value:"clean()",meta:"kkTerminal",description:"remove local variables",score:1e3},{name:"write",value:"write()",meta:"kkTerminal",description:"write to terminal",score:1e3},{name:"read",value:"read()",meta:"kkTerminal",description:"read lastest from terminal",score:1e3},{name:"readAll",value:"readAll()",meta:"kkTerminal",description:"read all from terminal",score:1e3},{name:"hide",value:"hide()",meta:"kkTerminal",description:"hide TCode display",score:1e3},{name:"show",value:"show()",meta:"kkTerminal",description:"show TCode display",score:1e3}];o(null,i.map((e=>({caption:e.caption||e.name,value:e.value,meta:e.meta,description:e.description||""}))))}};var _t={name:"AceEditor",setup(e,l){const t=(0,R.iH)(),a=(0,R.iH)(null),o=e=>{a.value&&a.value.setValue(e),a.value&&a.value.selection.clearSelection()},i=()=>a.value?a.value.getValue():"",s=()=>{a.value&&a.value.getSession().getUndoManager().reset()},n=e=>{a.value&&a.value.getSession().setMode(`ace/mode/${dt(e)}`)},r=e=>{if(a.value){a.value.setReadOnly(e);const l=e?"#f0f0f0":"";t.value.style.backgroundColor=l}},u=e=>{if(e.ctrlKey||e.metaKey)switch(String.fromCharCode(e.which).toLowerCase()){case"s":e.preventDefault(),l.emit("handleSave",a.value.getValue());break}};return(0,c.bv)((()=>{a.value=nt().edit(t.value,{autoScrollEditorIntoView:!1,copyWithEmptySelection:!1,showPrintMargin:!1,highlightActiveLine:!0,enableBasicAutocompletion:!0,enableSnippets:!0,enableLiveAutocompletion:!0,theme:"ace/theme/chrome",mode:"ace/mode/text"}),a.value.completers.push(ht),a.value.session.setOption("useWorker",!1),a.value.on("change",(()=>{l.emit("handleChange")})),a.value.find("needle",{backwards:!1,wrap:!1,caseSensitive:!1,wholeWord:!1,regExp:!1}),a.value.findNext(),a.value.findPrevious(),t.value.addEventListener("keydown",u)})),(0,c.Ah)((()=>{t.value&&t.value.removeEventListener("keydown",u)})),{aceEditorRef:t,aceEditor:a,setValue:o,reset:s,setLanguage:n,getValue:i,setReadOnly:r}}};const xt=(0,Ae.Z)(_t,[["render",it],["__scopeId","data-v-73ef2e97"]]);var Ct=xt,St={name:"TxtPreview",components:{AceEditor:Ct,FileIcons:Oe()},setup(e,l){const t=(0,R.iH)(!1),a=(0,R.iH)(!1),i=(0,R.iH)(""),s=(0,R.iH)(""),n=(0,R.iH)(""),r=(0,R.iH)(),u=async()=>{p(),a.value=!0;let e=n.value;await o().ajax({url:e,method:"GET",dataType:"text",dataFilter(e){return e},success(l){e==n.value&&(r.value.setValue(l),r.value.reset(),r.value.setLanguage(s.value),i.value="",a.value=!1)},error(){e==n.value&&((0,N.z8)({message:"文件加载失败",type:"error",grouping:!0}),p(),t.value=!1)}})},d=()=>{i.value="*"},c=e=>{"*"==i.value&&(l.emit("doSave",s.value,n.value,e),i.value="")},p=()=>{r.value&&(r.value.setValue(""),r.value.reset()),i.value=""},v=e=>{setTimeout((()=>{p()}),200),e()};return{DialogVisilble:t,initText:u,loading:a,fileName:s,fileUrl:n,codeEditorRef:r,modifyTag:i,handleChange:d,handleSave:c,closeDialog:v,resetEditor:p}}};const bt=(0,Ae.Z)(St,[["render",at],["__scopeId","data-v-480795cf"]]);var It=bt;const Dt=e=>((0,c.dD)("data-v-101691e8"),e=e(),(0,c.Cn)(),e),Et=Dt((()=>(0,c._)("div",{style:{"margin-top":"-32px"}},null,-1))),Tt={class:"no-select"},Wt={class:"errInfo no-select"},Vt={class:"kk-flex"},Ft=Dt((()=>(0,c._)("div",{style:{width:"10px"}},null,-1))),At={style:{flex:"1"}},Bt={style:{"margin-left":"10px"}},zt=Dt((()=>(0,c._)("div",{style:{"margin-top":"-10px"}},null,-1)));function Ht(e,l,t,a,o,i){const s=(0,c.up)("el-radio"),n=(0,c.up)("el-radio-group"),r=(0,c.up)("FileIcons"),u=(0,c.up)("el-input"),d=(0,c.up)("el-button"),p=(0,c.up)("el-dialog");return(0,c.wg)(),(0,c.j4)(p,{modelValue:a.DialogVisilble,"onUpdate:modelValue":l[2]||(l[2]=e=>a.DialogVisilble=e),"before-close":a.closeDialog,width:300,modal:!1,title:"新建","modal-class":"kk-dialog-class",draggable:""},{default:(0,c.w5)((()=>[Et,(0,c._)("div",Tt,[(0,c.Wm)(n,{modelValue:a.isDirectory,"onUpdate:modelValue":l[0]||(l[0]=e=>a.isDirectory=e),class:"ml-4"},{default:(0,c.w5)((()=>[(0,c.Wm)(s,{label:!1,size:"large"},{default:(0,c.w5)((()=>[(0,c.Uk)("文件")])),_:1}),(0,c.Wm)(s,{label:!0,size:"large"},{default:(0,c.w5)((()=>[(0,c.Uk)("文件夹")])),_:1})])),_:1},8,["modelValue"]),(0,c._)("div",Wt,(0,q.zw)(a.err_msg),1),(0,c._)("div",Vt,[(0,c._)("div",null,[1==a.isDirectory?((0,c.wg)(),(0,c.j4)(r,{key:0,width:"24",height:"24",name:"kk.txt",isFolder:!0})):((0,c.wg)(),(0,c.j4)(r,{key:1,width:"24",height:"24",name:"kk.txt",isFolder:!1}))]),Ft,(0,c._)("div",At,[(0,c.Wm)(u,{size:"small",modelValue:a.name,"onUpdate:modelValue":l[1]||(l[1]=e=>a.name=e),class:"w-50 m-2",placeholder:""},null,8,["modelValue"])]),(0,c._)("div",Bt,[(0,c.Wm)(d,{size:"small",type:"primary",onClick:a.confirm},{default:(0,c.w5)((()=>[(0,c.Uk)("确定")])),_:1},8,["onClick"])])])]),zt])),_:1},8,["modelValue","before-close"])}var Ot={name:"MkFile",components:{FileIcons:Oe()},setup(e,l){const t=(0,R.iH)(!1),a=(0,R.iH)(""),o=(0,R.iH)(!1),i=(0,R.iH)(""),s=(0,R.iH)(""),n=()=>{a.value="",i.value&&i.value.trim().length>0?-1==i.value.indexOf("/")?(l.emit("callback",o.value,i.value,s.value),u()):a.value="文件名不能含有 /":a.value="文件名不能为空"},r=e=>{setTimeout((()=>{u()}),200),e()},u=()=>{a.value="",o.value=!1,i.value="",s.value="",t.value=!1};return{DialogVisilble:t,err_msg:a,isDirectory:o,name:i,nowDir:s,confirm:n,closeDialog:r,reset:u}}};const Ut=(0,Ae.Z)(Ot,[["render",Ht],["__scopeId","data-v-101691e8"]]);var Rt=Ut;const Nt=e=>((0,c.dD)("data-v-1ef7ac5d"),e=e(),(0,c.Cn)(),e),jt=Nt((()=>(0,c._)("div",{style:{"margin-top":"-15px"}},null,-1))),Mt={class:"kk-flex nowrap"},Qt={class:"ellipsis",style:{margin:"0 5px","font-size":"small"}},Pt=Nt((()=>(0,c._)("div",{style:{"font-size":"small"}},"属性",-1))),Kt=Nt((()=>(0,c._)("div",{style:{"margin-top":"-32px"}},null,-1))),Lt={class:"kk-flex"},Jt={style:{"margin-right":"10px"}},Gt=Nt((()=>(0,c._)("div",{class:"kk-border"},null,-1))),qt={class:"kk-flex nowrap"},Zt=Nt((()=>(0,c._)("div",{class:"no-select",style:{"text-align":"left",width:"100px"}},"位置:",-1))),Yt={class:"ellipsis"},Xt={class:"kk-flex"},$t=Nt((()=>(0,c._)("div",{class:"no-select",style:{"text-align":"left",width:"100px"}},"大小:",-1))),ea=Nt((()=>(0,c._)("div",{class:"kk-border"},null,-1))),la={class:"kk-flex"},ta=Nt((()=>(0,c._)("div",{class:"no-select",style:{"text-align":"left",width:"100px"}},"修改时间:",-1))),aa={class:"kk-flex"},oa=Nt((()=>(0,c._)("div",{class:"no-select",style:{"text-align":"left",width:"100px"}},"访问时间:",-1))),ia=Nt((()=>(0,c._)("div",{class:"kk-border"},null,-1))),sa={class:"kk-flex"},na=Nt((()=>(0,c._)("div",{class:"no-select",style:{"text-align":"left",width:"100px"}},"权限:",-1))),ra=Nt((()=>(0,c._)("div",{style:{flex:"1"}},null,-1))),ua=Nt((()=>(0,c._)("div",{style:{"margin-top":"-15px"}},null,-1)));function da(e,l,t,a,o,i){const s=(0,c.up)("FileIcons"),n=(0,c.up)("el-input"),r=(0,c.up)("DocumentCopy"),u=(0,c.up)("el-icon"),d=(0,c.up)("el-button"),p=(0,c.up)("el-dialog");return(0,c.wg)(),(0,c.j4)(p,{modelValue:a.DialogVisilble,"onUpdate:modelValue":l[2]||(l[2]=e=>a.DialogVisilble=e),"before-close":a.closeDialog,width:400,modal:!1,"modal-class":"kk-dialog-class","align-center":"",draggable:""},{title:(0,c.w5)((()=>[jt,(0,c._)("div",Mt,[(0,c.Wm)(s,{name:a.fileInfo.name,width:"16",height:"16",isFolder:a.fileInfo.isDirectory},null,8,["name","isFolder"]),(0,c._)("div",Qt,(0,q.zw)(a.fileInfo.name),1),Pt])])),default:(0,c.w5)((()=>[Kt,(0,c._)("div",null,[(0,c._)("div",Lt,[(0,c._)("div",Jt,[(0,c.Wm)(s,{name:a.fileInfo.name,width:"32",height:"32",isFolder:a.fileInfo.isDirectory},null,8,["name","isFolder"])]),(0,c._)("div",null,[(0,c.Wm)(n,{modelValue:a.rename,"onUpdate:modelValue":l[0]||(l[0]=e=>a.rename=e),placeholder:""},null,8,["modelValue"])])]),Gt,(0,c._)("div",qt,[Zt,(0,c._)("div",Yt,(0,q.zw)(a.fileDir+a.fileInfo.name),1),(0,c._)("div",{style:{cursor:"pointer","margin-left":"5px"},onClick:l[1]||(l[1]=e=>a.doCopy(a.fileDir+a.fileInfo.name))},[(0,c.Wm)(u,{size:"15"},{default:(0,c.w5)((()=>[(0,c.Wm)(r)])),_:1})])]),(0,c._)("div",Xt,[$t,(0,c._)("div",null,(0,q.zw)(a.calcSize(a.fileInfo.attributes.size))+" ("+(0,q.zw)(a.fileInfo.attributes.size+" 字节")+") ",1)]),ea,(0,c._)("div",la,[ta,(0,c._)("div",null,(0,q.zw)(a.formatDate(a.fileInfo.attributes.mtime)),1)]),(0,c._)("div",aa,[oa,(0,c._)("div",null,(0,q.zw)(a.formatDate(a.fileInfo.attributes.atime)),1)]),ia,(0,c._)("div",sa,[na,(0,c._)("div",null,(0,q.zw)(a.calcPriority(a.fileInfo.attributes.mode.type,a.fileInfo.attributes.permissions)),1),ra,(0,c._)("div",null,[(0,c.Wm)(d,{size:"small",type:"primary",onClick:a.confirm},{default:(0,c.w5)((()=>[(0,c.Uk)("确定")])),_:1},8,["onClick"])])])]),ua])),_:1},8,["modelValue","before-close"])}const ca=e=>{if(!e)return"";let l=new Date(1e3*e),t=l.getFullYear(),a=l.getMonth()+1,o=l.getDate(),i=l.getHours(),s=l.getMinutes(),n=l.getSeconds();return a<10&&(a="0"+a),o<10&&(o="0"+o),i<10&&(i="0"+i),s<10&&(s="0"+s),n<10&&(n="0"+n),t+"年"+a+"月"+o+"日,"+i+":"+s+":"+n},pa=(e,l)=>ma(e)+fa(l),va={BLOCK_SPECIAL:"b",CHAR_SPECIAL:"c",FIFO_SPECIAL:"p",SOCKET_SPECIAL:"s",REGULAR:"-",DIRECTORY:"d",SYMLINK:"l",UNKNOWN:"?"},ma=e=>va[e],ga={USR_R:256,USR_W:128,USR_X:64,GRP_R:32,GRP_W:16,GRP_X:8,OTH_R:4,OTH_W:2,OTH_X:1,SUID:2048,SGID:1024,STICKY:512},fa=e=>{let l="---------",t=0;for(let a=0;a{if(null==e||void 0==e)return"";let l="";l=e<1024?e.toFixed(2)+" B":e<1048576?(e/1024).toFixed(2)+" KB":e<1073741824?(e/1048576).toFixed(2)+" MB":(e/1073741824).toFixed(2)+" GB";let t=l+"",a=t.indexOf("."),o=t.substring(a+1,a+3);return"00"==o?t.substring(0,a)+t.substring(a+3):l};var ka={name:"FileAttr",components:{FileIcons:Oe(),DocumentCopy:je.IBc},setup(e,l){const{toClipboard:t}=(0,U.Z)(),a=(0,R.iH)(!1),o=(0,R.iH)({}),i=(0,R.iH)(""),s=(0,R.iH)(""),n=()=>{if(o.value.name==s.value)return void(a.value=!1);if(!(s.value&&s.value.trim().length>0))return void(0,N.z8)({message:"文件名不能为空",type:"warning",grouping:!0});if(-1!=s.value.indexOf("/"))return void(0,N.z8)({message:"文件名不能含有 /",type:"warning",grouping:!0});let e=i.value+o.value.name,t=i.value+s.value;l.emit("callback",e,t),a.value=!1},r=e=>{e()},u=()=>{o.value={},s.value="",i.value="",a.value=!1},d=async e=>{e+="",e&&e.length>0?(await t(e),(0,N.z8)({message:"复制成功",type:"success",grouping:!0,repeatNum:Number.MIN_SAFE_INTEGER})):(0,N.z8)({message:"内容为空",type:"warning",grouping:!0,repeatNum:Number.MIN_SAFE_INTEGER})};return{DialogVisilble:a,fileInfo:o,confirm:n,closeDialog:r,reset:u,fileDir:i,rename:s,formatDate:ca,calcPriority:pa,calcSize:wa,doCopy:d}}};const ha=(0,Ae.Z)(ka,[["render",da],["__scopeId","data-v-1ef7ac5d"]]);var _a=ha,xa={name:"FileBlock",components:{NoData:ze,FileIcons:Oe(),TxtPreview:It,MkFile:Rt,FileAttr:_a,Refresh:je.hYj,Fold:je.qFw,Download:je.UWx,Upload:je.gqx},props:["sshKey","os"],setup(e){const l=(0,R.iH)(!0),{toClipboard:t}=(0,U.Z)(),a=(0,R.iH)([]),i=(0,R.iH)([]);let s=-1;const n=(l,t,o=!0)=>{l.preventDefault();const n=r(t.id);if(o)if(l.shiftKey)if(0==i.value.length||-1==s||s>=a.value.length){i.value=[];for(let e=0;e<=t.index;e++)i.value.push({...a.value[e]});s=-1}else{i.value=[];const e=Math.min(t.index,s),l=Math.max(t.index,s);for(let t=e;t<=l;t++)i.value.push({...a.value[t]})}else"Windows"==e.os&&l.ctrlKey||("Mac"==e.os||"iOS"==e.os)&&l.metaKey?(s=t.index,-1!=n?i.value.splice(n,1):i.value.push(t)):(s=t.index,i.value=[],i.value.push(t));else-1==n&&(s=t.index,i.value=[],i.value.push(t))},r=e=>{for(let l=0;l{for(let l=0;l{""!=d.value&&"/"==d.value[0]||(d.value="/"+d.value),"/"!=d.value[d.value.length-1]&&(d.value=d.value+"/"),d.value=d.value.replace(/\/{2,}/g,"/")},v=(0,R.iH)(!1),m=()=>{""==d.value&&o().ajax({url:J+"/pwd",type:"get",data:{sshKey:e.sshKey},success(e){d.value=e.data.path,p(),i.value=[],a.value=[],y()}})},g=(0,R.iH)("暂无文件"),f=(0,R.iH)(0),y=()=>{let t=d.value;o().ajax({url:J+"/ls",type:"get",data:{sshKey:e.sshKey,path:t},beforeSend:function(){l.value=!0,a.value=[]},success(e){t==d.value&&(i.value=[],"success"==e.status?(a.value=e.data.files,g.value="暂无文件",f.value=0):(a.value=[],g.value=e.info,f.value=1))},complete:function(){t==d.value&&(l.value=!1)}})},w=(l,t)=>J+"/download/remote/file/"+l+"?time="+(new Date).getTime()+"&sshKey="+e.sshKey+"&path="+(t||d.value),k=(l,t)=>J+"/download/remote/folder/"+l+"?time="+(new Date).getTime()+"&sshKey="+e.sshKey+"&path="+(t||d.value),h=e=>{let l={key:"",path:null},t=e.indexOf("&sshKey="),a=e.indexOf("&path=");return-1!=t&&-1!=a&&(l.key=e.substring(t+8,a)),-1!=a&&(l.path=e.substring(a+6)),l},_=e=>{if(1==v.value)return;let l=document.createElement("a");l.href=w(e),document.body.appendChild(l),l.click(),document.body.removeChild(l)},x=e=>{if(1==v.value)return;let l=document.createElement("a");l.href=k(e),document.body.appendChild(l),l.click(),document.body.removeChild(l)},C=e=>{1!=v.value&&(d.value=e,i.value=[],y())},S=()=>{v.value=!1,p(),i.value=[],y()},b=()=>{v.value=!1,y()},I=()=>{if(1==v.value)return;if("/"==d.value)return;"/"==d.value[d.value.length-1]&&(d.value=d.value.substring(0,d.value.length-1));let e=d.value.lastIndexOf("/");-1!=e&&(d.value=d.value.substring(0,e+1)),i.value=[],b()},D=()=>{1!=v.value&&(1==i.value.length&&i.value[0].name&&i.value[0].isDirectory&&x(i.value[0].name),1==i.value.length&&i.value[0].name&&!i.value[0].isDirectory&&_(i.value[0].name))},E=529408,T=async(l,t={})=>{try{if(1==v.value)return;let a=l.file;if(!a)return;const i=a.name,s=a.size,n=0==parseInt(Math.ceil(s/E))?1:parseInt(Math.ceil(s/E)),r=a.uid;let u=1;const c=t.pathVal?t.pathVal:d.value;s>20971520&&(0,N.z8)({message:t.startUpLoad?t.startUpLoad:"开始上传",type:"success",grouping:!0});for(let l=u;l<=n;l++){let u=(l-1)*E,p=u+E>=s?s:u+E,v=a.slice(u,p),m=new FormData;m.append("file",v),m.append("fileName",i),m.append("chunks",n),m.append("chunk",l),m.append("totalSize",s),m.append("id",r),m.append("sshKey",e.sshKey),m.append("path",c),await o().ajax({url:J+"/upload",type:"post",data:m,contentType:!1,processData:!1,success(e){202==e.code?((0,N.z8)({message:t.alert?t.alert:e.info,type:e.status,grouping:!0}),c==d.value&&setTimeout((()=>{y()}),Math.min(1e3,500+10*n))):(502==e.code||503==e.code||504==e.code||602==e.code)&&((0,N.z8)({message:e.info,type:e.status,grouping:!0}),l=n+1)}})}}catch(a){(0,N.z8)({message:"文件上传失败",type:"error",grouping:!0})}},W=()=>{v.value=!0,setTimeout((()=>{document.querySelector("#aimDirInput").focus()}),1)},V=(0,R.iH)(!1),F=e=>{i.value=[],L.value={},A.value.DialogVisilble=!1,te.value.DialogVisilble=!1,te.value.reset(),G.value.DialogVisilble=!1,e()},A=(0,R.iH)(),B=e=>{A.value.fileName=e,A.value.fileUrl=w(e),A.value.loading=!0,A.value.initText(),A.value.DialogVisilble=!0},z=(l,t,a)=>{let o=h(t);if(o.key!=e.sshKey)return;const i=new Blob([a],{type:"text/plain"}),s=new File([i],l);s.uid=Math.random().toString(36).substring(2),T({file:s},{pathVal:o.path,startUpLoad:"修改保存中",alert:"文件后台保存中"})},H=(0,R.iH)(),O=e=>{e.preventDefault()},j=l=>{l.preventDefault();const t=l.dataTransfer.items;if(t&&t.length>0)for(let a=0;a{e.uid=Math.random().toString(36).substring(2),T({file:e},{pathVal:d.value})}));else if(!l.isFile&&l.isDirectory){const t=d.value+l.name;o().ajax({url:J+"/mkdir",type:"post",data:{sshKey:e.sshKey,path:t},success(e){"success"==e.status?(y(),M(l,t+"/")):(0,N.z8)({message:e.info,type:e.status,grouping:!0})}})}}},M=(l,t)=>{const a=l.createReader();a.readEntries((l=>{for(let a=0;a{e.uid=Math.random().toString(36).substring(2),T({file:e},{pathVal:t})}));else if(!i.isFile&&i.isDirectory){const l=t+i.name;o().ajax({url:J+"/mkdir",type:"post",data:{sshKey:e.sshKey,path:l},success(e){"success"==e.status?M(i,l+"/"):(0,N.z8)({message:e.info,type:e.status,grouping:!0})}})}}}))},Q=(0,R.iH)(!1),P=(0,R.iH)(!1),K=(0,R.iH)(!1),L=(0,R.iH)({}),G=(0,R.iH)(),q=async e=>{switch(e){case 1:b();break;case 2:1==i.value.length&&1==i.value[0].isDirectory?C(d.value+i.value[0].name+"/"):1==i.value.length&&0==i.value[0].isDirectory&&B(i.value[0].name);break;case 3:if(d.value&&d.value.length>0){const e=d.value+(1==i.value.length?i.value[0].name:"");await t(e),(0,N.z8)({message:"复制成功",type:"success",grouping:!0,repeatNum:Number.MIN_SAFE_INTEGER})}else(0,N.z8)({message:"内容为空",type:"warning",grouping:!0,repeatNum:Number.MIN_SAFE_INTEGER});break;case 4:1==i.value.length&&D();break;case 5:te.value.DialogVisilble=!0,te.value.nowDir=d.value;break;case 6:1==i.value.length&&(L.value={...i.value[0]},K.value=!0,setTimeout((()=>{document.querySelector("#rename").focus()}),1));break;case 7:P.value=!0;break;case 8:1==i.value.length&&(G.value.fileInfo={...i.value[0]},G.value.fileDir=d.value,G.value.rename=i.value[0].name,G.value.DialogVisilble=!0);break;default:break}7!=e&&(Q.value=!1,P.value=!1)},Z=()=>{Q.value=!1,P.value=!1},Y=(0,R.iH)(),X=e=>{"fileArea"==e.target.id&&(i.value=[]),Y.value.style.top=e.clientY-135+"px",Y.value.style.left=e.clientX+1+"px",Q.value=!0,P.value=!1,e.preventDefault()},$=e=>{if(K.value=!1,e.name==L.value.name)return void(L.value={});if(!(L.value.name&&L.value.name.trim().length>0))return(0,N.z8)({message:"文件名不能为空",type:"warning",grouping:!0}),void(L.value={});if(-1!=L.value.name.indexOf("/"))return(0,N.z8)({message:"文件名不能含有 /",type:"warning",grouping:!0}),void(L.value={});let l=d.value+e.name,t=d.value+L.value.name;L.value={},ee(l,t)},ee=(l,t)=>{o().ajax({url:J+"/rename",type:"post",data:{sshKey:e.sshKey,oldPath:l,newPath:t},success(e){(0,N.z8)({message:e.info,type:e.status,grouping:!0}),y()}})},le=()=>{Q.value=!1,P.value=!1,0!=i.value.length&&o().ajax({url:J+"/rm-rf",type:"post",data:{sshKey:e.sshKey,path:d.value,items:i.value.map((e=>e.name)).join(" ")},success(e){(0,N.z8)({message:e.info,type:e.status,grouping:!0}),y()}})},te=(0,R.iH)(),ae=(l,t,a)=>{o().ajax({url:J+(l?"/mkdir":"/touch"),type:"post",data:{sshKey:e.sshKey,path:a+t},success(e){(0,N.z8)({message:e.info,type:e.status,grouping:!0}),y()}})};(0,c.YP)(d,(()=>{te.value&&te.value.reset()}));const oe=(0,R.iH)({path:"/",files:[]}),ie=(0,R.iH)(!1),se=l=>{const t=document.querySelector("#rename");if((!t||!t.contains(l.target))&&(l.preventDefault(),"Windows"==e.os&&l.ctrlKey||("Mac"==e.os||"iOS"==e.os)&&l.metaKey))switch(String.fromCharCode(l.which).toLowerCase()){case"a":i.value=[];for(let e=0;e0&&(oe.value.path=d.value,oe.value.files=i.value.slice(0),ie.value=!1);break;case"v":if(0==oe.value.files.length)return;ne(ie.value?"mv":"cp"),ie.value&&(ie.value=!1,oe.value={path:"/",files:[]});break;case"x":oe.value.path=d.value,oe.value.files=i.value.slice(0),ie.value=!0;break}},ne=l=>{oe.value.path!=d.value&&o().ajax({url:J+"/"+l,type:"post",data:{sshKey:e.sshKey,src:oe.value.path,dst:d.value,items:oe.value.files.map((e=>e.name)).join(" ")},success(e){"success"==e.status?y():((0,N.z8)({message:e.info,type:e.status,grouping:!0}),oe.value={path:"/",files:[]})}})};return(0,c.bv)((()=>{document.addEventListener("mousedown",(e=>{if(H.value&&H.value.contains(e.target)&&(H.value.tabindex="0",H.value.focus()),Y.value&&Y.value.contains(e.target))return;const l=document.querySelector("#sureDelFileBtn");l&&l.contains(e.target)||(Q.value=!1,P.value=!1)}))})),(0,c.Ah)((()=>{H.value&&(H.value.removeEventListener("dragover",O),H.value.removeEventListener("drop",j),H.value.removeEventListener("scroll",Z),H.value.removeEventListener("keydown",se))})),{DialogVisilble:V,closeDialog:F,isShowDirInput:v,dir:d,files:a,getInitDir:m,getDirList:y,downloadRemoteFile:_,downloadDir:x,changeDir:C,dirInputCallback:S,noDataMsg:g,doRefresh:b,doReturn:I,doDownload:D,doUpload:T,selectedFiles:i,loading:l,txtPreviewRef:A,preViewFile:B,doSave:z,fileAreaRef:H,handleMenuSelect:q,isShowMenu:Q,preventDefault:O,handleFileDrag:j,handleScroll:Z,handleContextMenu:X,isShowRenameInput:K,handleRename:$,renameFile:L,menuBlockRef:Y,doShowDirInput:W,isShowPop:P,handlePopConfirm:le,mkFileRef:te,handleMkFile:ae,doRename:ee,fileAttrRef:G,folderUpload:M,dirStatus:f,handleShortcutKeys:se,fileClipboard:oe,addSelectFile:n,isSelected:r,isClipboard:u,isCtrlx:ie,fileCopyMove:ne}}};const Ca=(0,Ae.Z)(xa,[["render",Zl],["__scopeId","data-v-7d7f3746"]]);var Sa=Ca;const ba=e=>((0,c.dD)("data-v-c9882564"),e=e(),(0,c.Cn)(),e),Ia=ba((()=>(0,c._)("div",{style:{"margin-top":"-32px"}},null,-1))),Da={class:"kk-flex"},Ea=ba((()=>(0,c._)("div",{class:"no-select nowrap"},"TCode:",-1))),Ta=ba((()=>(0,c._)("div",{class:"no-select nowrap",style:{"background-color":"#f3f4f4","margin-right":"8px"}},"U",-1))),Wa=ba((()=>(0,c._)("div",{style:{flex:"1"}},null,-1))),Va={class:"kk-flex"},Fa=ba((()=>(0,c._)("div",{class:"no-select nowrap",style:{"margin-right":"2px"}},"描 述:",-1))),Aa=ba((()=>(0,c._)("div",{style:{flex:"1"}},null,-1))),Ba=ba((()=>(0,c._)("div",{class:"kk-border"},null,-1))),za={class:"kk-flex",style:{margin:"7px 0"}},Ha=ba((()=>(0,c._)("div",{class:"no-select nowrap"},"Workflow",-1))),Oa=ba((()=>(0,c._)("div",{style:{flex:"1"}},null,-1))),Ua={"element-loading-text":"Loading...",style:{padding:"0px 5px",width:"100%",height:"30vh"}},Ra={style:{display:"flex"}},Na=ba((()=>(0,c._)("div",{style:{flex:"1"}},null,-1)));function ja(e,l,t,a,o,i){const s=(0,c.up)("CollectionTag"),n=(0,c.up)("el-icon"),r=(0,c.up)("el-input"),u=(0,c.up)("Upload"),d=(0,c.up)("el-button"),p=(0,c.up)("el-upload"),v=(0,c.up)("EditPen"),m=(0,c.up)("Download"),g=(0,c.up)("Refresh"),f=(0,c.up)("el-tooltip"),y=(0,c.up)("DocumentDelete"),w=(0,c.up)("Finished"),k=(0,c.up)("AceEditor"),h=(0,c.up)("el-dialog"),_=(0,c.Q2)("loading");return(0,c.wg)(),(0,c.j4)(h,{modelValue:a.DialogVisilble,"onUpdate:modelValue":l[5]||(l[5]=e=>a.DialogVisilble=e),"before-close":a.closeDialog,"destroy-on-close":"",width:550,title:"自定义TCode",modal:!1,"modal-class":"kk-dialog-class","align-center":"",draggable:""},{default:(0,c.w5)((()=>[Ia,(0,c._)("div",null,[(0,c._)("div",Da,[Ea,Ta,(0,c.Wm)(r,{size:"small",style:{width:"130px"},modelValue:a.userTcodeInfo.name,"onUpdate:modelValue":l[0]||(l[0]=e=>a.userTcodeInfo.name=e),class:"w-50 m-2",placeholder:"输入TCode",maxlength:"5",minlength:"1"},{prefix:(0,c.w5)((()=>[(0,c.Wm)(n,null,{default:(0,c.w5)((()=>[(0,c.Wm)(s)])),_:1})])),_:1},8,["modelValue"]),Wa,(0,c._)("div",null,[(0,c.Wm)(p,{"show-file-list":!1,"with-credentials":!1,"http-request":a.importTcodes,multiple:!1},{default:(0,c.w5)((()=>[(0,c.Wm)(d,{size:"small",type:"primary"},{default:(0,c.w5)((()=>[(0,c.Wm)(n,{class:"el-icon--left"},{default:(0,c.w5)((()=>[(0,c.Wm)(u)])),_:1}),(0,c.Uk)(" 导入 ")])),_:1})])),_:1},8,["http-request"])])]),(0,c._)("div",Va,[Fa,(0,c.Wm)(r,{size:"small",style:{width:"148px"},modelValue:a.userTcodeInfo.desc,"onUpdate:modelValue":l[1]||(l[1]=e=>a.userTcodeInfo.desc=e),class:"w-50 m-2",placeholder:"输入TCode描述"},{prefix:(0,c.w5)((()=>[(0,c.Wm)(n,null,{default:(0,c.w5)((()=>[(0,c.Wm)(v)])),_:1})])),_:1},8,["modelValue"]),Aa,(0,c._)("div",null,[(0,c.Wm)(d,{size:"small",type:"primary",onClick:a.exportTcodes},{default:(0,c.w5)((()=>[(0,c.Wm)(n,{class:"el-icon--left"},{default:(0,c.w5)((()=>[(0,c.Wm)(m)])),_:1}),(0,c.Uk)(" 导出 ")])),_:1},8,["onClick"])])]),Ba,(0,c._)("div",za,[Ha,Oa,(0,c._)("div",{onClick:l[2]||(l[2]=e=>a.workflowTab(1)),style:{"font-size":"18px",cursor:"pointer","margin-left":"15px"}},[(0,c.Wm)(f,{content:"默认模板",placement:"top"},{default:(0,c.w5)((()=>[(0,c.Wm)(n,null,{default:(0,c.w5)((()=>[(0,c.Wm)(g)])),_:1})])),_:1})]),(0,c._)("div",{onClick:l[3]||(l[3]=e=>a.workflowTab(2)),style:{"font-size":"18px",cursor:"pointer","margin-left":"15px"}},[(0,c.Wm)(f,{content:"清空",placement:"top"},{default:(0,c.w5)((()=>[(0,c.Wm)(n,null,{default:(0,c.w5)((()=>[(0,c.Wm)(y)])),_:1})])),_:1})]),(0,c._)("div",{onClick:l[4]||(l[4]=e=>a.workflowTab(3)),style:{"font-size":"18px",cursor:"pointer","margin-left":"15px"}},[(0,c.Wm)(f,{content:"保存",placement:"top"},{default:(0,c.w5)((()=>[(0,c.Wm)(n,null,{default:(0,c.w5)((()=>[(0,c.Wm)(w)])),_:1})])),_:1})])]),(0,c.wy)(((0,c.wg)(),(0,c.iD)("div",Ua,[(0,c.Wm)(k,{ref:"userTcodeEditorRef",onHandleSave:a.handleSave},null,8,["onHandleSave"])])),[[_,a.loading]])]),(0,c._)("div",Ra,[Na,(0,c.Wm)(d,{size:"small",type:"primary",onClick:a.confirm,style:{"margin-bottom":"-15px","margin-top":"10px"}},{default:(0,c.w5)((()=>[(0,c.Uk)(" 确定 ")])),_:1},8,["onClick"])])])),_:1},8,["modelValue","before-close"])}var Ma={name:"UserTcode",components:{AceEditor:Ct,CollectionTag:je.O$2,EditPen:je.qHu,Upload:je.gqx,Download:je.UWx,Refresh:je.hYj,Finished:je.qWi,DocumentDelete:je.jY0},setup(e,l){const t=(0,R.iH)(!1),a=(0,R.iH)(!1),o="await kkTerminal.write('cd /root/terminal');\nawait kkTerminal.write('lsof -i :3000', 500);\nlet resultArr = kkTerminal.read();\nif(resultArr.length >= 3) {\n let pid = resultArr[2].replace(/\\s+/g, ' ').split(' ')[1];\n\tif(pid) await kkTerminal.write('kill -9 ' + pid);\n}\nlet jar = 'kkTerminal.jar';\nawait kkTerminal.write('java -jar ./' + jar + ' > ./out.log &');\nalert('TCode Workflow Over!');",i=(0,R.iH)(),s=(0,R.iH)({name:"",desc:""}),n=e=>{localStorage.setItem("tcode-draft",e),(0,N.z8)({message:"保存成功",type:"success",grouping:!0,repeatNum:Number.MIN_SAFE_INTEGER})},r=e=>{i.value.setValue(e),i.value.reset()},u=()=>{i.value.setLanguage("kk.js"),localStorage.getItem("tcode-draft")&&(i.value.setValue(localStorage.getItem("tcode-draft")),i.value.reset())},d=e=>{const l=/^[A-Za-z0-9]+$/;return l.test(e)},c=e=>{let t=e.file;const o=new FileReader;o.onload=()=>{try{const e=JSON.parse(o.result);let t={},a=0,i=0;for(const l in e)l&&l.length>=2&&l.length<=6&&("U"==l[0]||"u"==l[0])&&d(l)?(t[l.toUpperCase()]={desc:e[l].desc||"",workflow:e[l].workflow||"",status:"Not Active"},a++):((0,N.z8)({message:"TCode-"+l+":名称非法",type:"error",grouping:!0}),i++);0==i?(l.emit("importTCodes",t),(0,N.z8)({message:"导入成功",type:"success",grouping:!0}),f()):0==a?(0,N.z8)({message:"导入失败:无合法TCode",type:"error",grouping:!0}):(l.emit("importTCodes",t),(0,N.z8)({message:"导入成功:"+a+"个,导入失败:"+i+"个",type:"warning",grouping:!0}))}catch(e){(0,N.z8)({message:"导入失败:json格式错误",type:"error",grouping:!0})}finally{a.value=!1}},o.onerror=()=>{(0,N.z8)({message:"导入失败:文件读取失败",type:"error",grouping:!0}),a.value=!1},a.value=!0,o.readAsText(t)},p=()=>{l.emit("exportTcodes"),(0,N.z8)({message:"导出成功",type:"success",grouping:!0})},v=e=>{switch(e){case 1:localStorage.removeItem("tcode-draft"),r(o);break;case 2:localStorage.removeItem("tcode-draft"),r("");break;case 3:n(i.value.getValue());break}},m=()=>{if(!(s.value.name&&s.value.name.length>=1&&s.value.name.length<=5))return void(0,N.z8)({message:"TCode不能为空",type:"error",grouping:!0,repeatNum:Number.MIN_SAFE_INTEGER});if(!d(s.value.name))return void(0,N.z8)({message:"TCode只能由字母和数字组成",type:"error",grouping:!0,repeatNum:Number.MIN_SAFE_INTEGER});let e={};e["U"+s.value.name.toUpperCase()]={desc:s.value.desc,workflow:i.value.getValue(),status:"Not Active"},l.emit("importTCodes",e),(0,N.z8)({message:"添加成功",type:"success",grouping:!0}),localStorage.removeItem("tcode-draft"),f()},g=e=>{f(),e()},f=()=>{setTimeout((()=>{a.value=!1,s.value.name="",s.value.desc="",i.value.setValue(""),i.value.reset()}),200),t.value=!1};return{DialogVisilble:t,confirm:m,closeDialog:g,reset:f,userTcodeEditorRef:i,handleSave:n,initText:u,loading:a,userTcodeInfo:s,importTcodes:c,exportTcodes:p,setValue:r,workflowTab:v}}};const Qa=(0,Ae.Z)(Ma,[["render",ja],["__scopeId","data-v-c9882564"]]);var Pa=Qa;const Ka=e=>((0,c.dD)("data-v-26579f9f"),e=e(),(0,c.Cn)(),e),La=Ka((()=>(0,c._)("div",{style:{"margin-top":"-27px"}},null,-1))),Ja={class:"no-select"},Ga={style:{height:"210px","overflow-y":"auto",padding:"10px 0"}},qa=Ka((()=>(0,c._)("div",null,[(0,c.Uk)("以 "),(0,c._)("span",{style:{"background-color":"#f3f4f4"}},"/"),(0,c.Uk)(" 开头,用于快速执行通用功能")],-1))),Za=Ka((()=>(0,c._)("div",{class:"kk-border"},null,-1))),Ya={class:"kk-flex tocde-item",style:{padding:"12px 10px"}},Xa={style:{"background-color":"#f3f4f4"}},$a={style:{"margin-left":"25px"}},eo={style:{height:"210px","overflow-y":"auto",padding:"10px 0"}},lo=Ka((()=>(0,c._)("div",null,[(0,c.Uk)("以 "),(0,c._)("span",{style:{"background-color":"#f3f4f4"}},"S"),(0,c.Uk)(" 开头,用于快速访问系统模块")],-1))),to=Ka((()=>(0,c._)("div",{class:"kk-border"},null,-1))),ao={class:"kk-flex tocde-item",style:{padding:"12px 10px"}},oo={style:{"background-color":"#f3f4f4"}},io={style:{"margin-left":"25px"}},so={style:{height:"210px","overflow-y":"auto",padding:"10px 0"}},no={class:"kk-flex",style:{"margin-bottom":"12px","margin-top":"-10px"}},ro={style:{"margin-top":"3px"}},uo={style:{cursor:"pointer","margin-left":"10px"}},co=Ka((()=>(0,c._)("div",{style:{flex:"1"}},null,-1))),po=Ka((()=>(0,c._)("div",{style:{"margin-left":"10px"}},null,-1))),vo={style:{width:"100%",height:"166px"}},mo=Ka((()=>(0,c._)("div",null,[(0,c.Uk)("以 "),(0,c._)("span",{style:{"background-color":"#f3f4f4"}},"U"),(0,c.Uk)(" 开头,自定义实现类似Shell脚本的自动化Workflow")],-1))),go=Ka((()=>(0,c._)("div",{class:"kk-border"},null,-1))),fo={class:"kk-flex tocde-item",style:{padding:"12px 10px"}},yo={class:"kk-flex",style:{width:"60px"}},wo={style:{"background-color":"#f3f4f4"}},ko=Ka((()=>(0,c._)("div",{style:{flex:"1"}},null,-1))),ho={class:"ellipsis",style:{"margin-left":"10px"}},_o=Ka((()=>(0,c._)("div",{style:{flex:"1"}},null,-1))),xo={style:{cursor:"pointer","margin-left":"10px"}},Co=["onClick"],So=Ka((()=>(0,c._)("div",null,[(0,c.Uk)("以 "),(0,c._)("span",{style:{"background-color":"#f3f4f4"}},"U"),(0,c.Uk)(" 开头,自定义实现类似Shell脚本的自动化Workflow")],-1))),bo=Ka((()=>(0,c._)("div",{class:"kk-border"},null,-1))),Io=Ka((()=>(0,c._)("div",{style:{"margin-top":"20px"}},null,-1)));function Do(e,l,t,a,o,i){const s=(0,c.up)("el-tab-pane"),n=(0,c.up)("ArrowLeft"),r=(0,c.up)("el-icon"),u=(0,c.up)("TcodeStatus"),d=(0,c.up)("el-tooltip"),p=(0,c.up)("Edit"),v=(0,c.up)("View"),m=(0,c.up)("Finished"),g=(0,c.up)("AceEditor"),f=(0,c.up)("ArrowRight"),y=(0,c.up)("NoData"),w=(0,c.up)("el-tabs"),k=(0,c.up)("el-dialog");return(0,c.wg)(),(0,c.j4)(k,{modelValue:a.DialogVisilble,"onUpdate:modelValue":l[4]||(l[4]=e=>a.DialogVisilble=e),"destroy-on-close":"",width:480,title:"帮助",modal:!1,"modal-class":"kk-dialog-class","before-close":a.closeDialog,draggable:""},{default:(0,c.w5)((()=>[La,(0,c._)("div",Ja,[(0,c.Wm)(w,{type:"border-card"},{default:(0,c.w5)((()=>[(0,c.Wm)(s,{label:"功能TCode"},{default:(0,c.w5)((()=>[(0,c._)("div",Ga,[qa,Za,((0,c.wg)(!0),(0,c.iD)(c.HY,null,(0,c.Ko)(a.FuncTcode,((e,l)=>((0,c.wg)(),(0,c.iD)("div",{key:l},[(0,c._)("div",Ya,[(0,c._)("div",Xa,(0,q.zw)(l),1),(0,c._)("div",$a,(0,q.zw)(e.desc),1)])])))),128))])])),_:1}),(0,c.Wm)(s,{label:"系统TCode"},{default:(0,c.w5)((()=>[(0,c._)("div",eo,[lo,to,((0,c.wg)(!0),(0,c.iD)(c.HY,null,(0,c.Ko)(a.SysTcode,((e,l)=>((0,c.wg)(),(0,c.iD)("div",{key:l},[(0,c._)("div",ao,[(0,c._)("div",oo,(0,q.zw)(l),1),(0,c._)("div",io,(0,q.zw)(e.desc),1)])])))),128))])])),_:1}),(0,c.Wm)(s,{label:"用户TCode"},{default:(0,c.w5)((()=>[(0,c._)("div",so,[a.userTCodes&&Object.keys(a.userTCodes).length>0?((0,c.wg)(),(0,c.iD)(c.HY,{key:0},[a.nowTCode&&a.nowTCode.length>=2&&a.nowTCode.length<=6?((0,c.wg)(),(0,c.iD)(c.HY,{key:0},[(0,c._)("div",no,[(0,c._)("div",{onClick:l[0]||(l[0]=(...e)=>a.toOverview&&a.toOverview(...e)),style:{"margin-right":"10px",cursor:"pointer","font-size":"16px"}},[(0,c.Wm)(r,null,{default:(0,c.w5)((()=>[(0,c.Wm)(n)])),_:1})]),(0,c._)("div",ro,(0,q.zw)(a.modifyTag+a.nowTCode),1),(0,c._)("div",uo,[(0,c.Wm)(d,{content:a.TCodeStatusEnum[a.userTCodes[a.nowTCode].status],placement:"top"},{default:(0,c.w5)((()=>[(0,c.Wm)(u,{style:{fontSize:"18px"},status:a.userTCodes[a.nowTCode].status},null,8,["status"])])),_:1},8,["content"])]),co,0==a.mode?((0,c.wg)(),(0,c.iD)("div",{key:0,onClick:l[1]||(l[1]=(...e)=>a.doModifyTCode&&a.doModifyTCode(...e)),style:{"margin-top":"-3px","font-size":"18px",cursor:"pointer","margin-left":"15px"}},[(0,c.Wm)(d,{content:"编辑",placement:"top"},{default:(0,c.w5)((()=>[(0,c.Wm)(r,null,{default:(0,c.w5)((()=>[(0,c.Wm)(p)])),_:1})])),_:1})])):(0,c.kq)("",!0),1==a.mode?((0,c.wg)(),(0,c.iD)("div",{key:1,onClick:l[2]||(l[2]=(...e)=>a.doOnlyRead&&a.doOnlyRead(...e)),style:{"margin-top":"-3px","font-size":"18px",cursor:"pointer","margin-left":"15px"}},[(0,c.Wm)(d,{content:"只读",placement:"top"},{default:(0,c.w5)((()=>[(0,c.Wm)(r,null,{default:(0,c.w5)((()=>[(0,c.Wm)(v)])),_:1})])),_:1})])):(0,c.kq)("",!0),1==a.mode?((0,c.wg)(),(0,c.iD)("div",{key:2,onClick:l[3]||(l[3]=(...e)=>a.doSaveTCode&&a.doSaveTCode(...e)),style:{"margin-top":"-3px","font-size":"18px",cursor:"pointer","margin-left":"15px"}},[(0,c.Wm)(d,{content:"保存修改",placement:"top"},{default:(0,c.w5)((()=>[(0,c.Wm)(r,null,{default:(0,c.w5)((()=>[(0,c.Wm)(m)])),_:1})])),_:1})])):(0,c.kq)("",!0),po]),(0,c._)("div",vo,[(0,c.Wm)(g,{ref:"userTcodeEditorRef",onHandleChange:a.handleChange,onHandleSave:a.doSaveTCode},null,8,["onHandleChange","onHandleSave"])])],64)):((0,c.wg)(),(0,c.iD)(c.HY,{key:1},[mo,go,((0,c.wg)(!0),(0,c.iD)(c.HY,null,(0,c.Ko)(a.userTCodes,((e,l)=>((0,c.wg)(),(0,c.iD)("div",{key:l},[(0,c._)("div",fo,[(0,c._)("div",yo,[(0,c._)("div",wo,(0,q.zw)(l),1),ko]),(0,c._)("div",ho,(0,q.zw)(e.desc),1),_o,(0,c._)("div",xo,[(0,c.Wm)(d,{content:a.TCodeStatusEnum[e.status],placement:"top"},{default:(0,c.w5)((()=>[(0,c.Wm)(u,{style:{fontSize:"18px"},status:e.status},null,8,["status"])])),_:2},1032,["content"])]),(0,c._)("div",{onClick:e=>a.toWorkflow(l),style:{"margin-left":"15px",cursor:"pointer","font-size":"16px"}},[(0,c.Wm)(r,null,{default:(0,c.w5)((()=>[(0,c.Wm)(f)])),_:1})],8,Co)])])))),128))],64))],64)):((0,c.wg)(),(0,c.iD)(c.HY,{key:1},[So,bo,(0,c.Wm)(y,{height:"210px"},{myslot:(0,c.w5)((()=>[Io])),_:1})],64))])])),_:1})])),_:1})])])),_:1},8,["modelValue","before-close"])}function Eo(e,l,t,a,o,i){const s=(0,c.up)("CircleCloseFilled"),n=(0,c.up)("el-icon"),r=(0,c.up)("WarningFilled"),u=(0,c.up)("SuccessFilled"),d=(0,c.up)("InfoFilled");return-2==a.statusType?((0,c.wg)(),(0,c.iD)("div",{key:0,style:(0,q.j5)(a.statusStyle)},[(0,c.Wm)(n,null,{default:(0,c.w5)((()=>[(0,c.Wm)(s)])),_:1})],4)):-1==a.statusType?((0,c.wg)(),(0,c.iD)("div",{key:1,style:(0,q.j5)(a.statusStyle)},[(0,c.Wm)(n,null,{default:(0,c.w5)((()=>[(0,c.Wm)(r)])),_:1})],4)):1==a.statusType?((0,c.wg)(),(0,c.iD)("div",{key:2,style:(0,q.j5)(a.statusStyle)},[(0,c.Wm)(n,null,{default:(0,c.w5)((()=>[(0,c.Wm)(u)])),_:1})],4)):((0,c.wg)(),(0,c.iD)("div",{key:3,style:(0,q.j5)(a.statusStyle)},[(0,c.Wm)(n,null,{default:(0,c.w5)((()=>[(0,c.Wm)(d)])),_:1})],4))}var To={name:"TcodeStatus",components:{SuccessFilled:je.c5o,WarningFilled:je.Rrw,CircleCloseFilled:je.Tw$,InfoFilled:je.cEj},props:{status:{type:String,default:"success"},style:{type:Object,default:()=>{}}},setup(e){const l={"Load Error":-2,"Execute Error":-1,"Not Active":0,"Execute Success":1},t=["#f56c6c","#e6a23c","#909399","#67c23a"],a=(0,c.Fl)((()=>l[e.status]||0)),o=(0,c.Fl)((()=>({fontSize:"16px",...e.style,color:t[(l[e.status]||0)+2]})));return{statusStyle:o,statusType:a}}};const Wo=(0,Ae.Z)(To,[["render",Eo]]);var Vo=Wo,Fo={name:"HelpTcode",components:{NoData:ze,TcodeStatus:Vo,AceEditor:Ct,ArrowRight:je.olP,ArrowLeft:je.XdH,Edit:je.I8b,View:je.G7x,Finished:je.qWi},setup(e,l){const t=(0,R.iH)(!1),a=(0,R.iH)(""),o=(0,R.iH)({}),i=(0,R.iH)(""),s=(0,R.iH)(!1),n=e=>{i.value=e,s.value=!1,setTimeout((()=>{c(!0)}),1)},r=()=>{s.value=!1,i.value="",a.value=""},d=(0,R.iH)(),c=e=>{d.value.setLanguage("kk.js"),d.value.setValue(JSON.parse(u(localStorage.getItem("tcodes")))[i.value].workflow||""),d.value.reset(),d.value.setReadOnly(e),a.value=""},p=()=>{s.value=!0,c(!1)},v=()=>{s.value=!1,c(!0)},m=()=>{"*"==a.value&&(l.emit("handleSaveTCode",i.value,d.value.getValue()),v(),(0,N.z8)({message:"修改成功",type:"success",grouping:!0}),a.value="")},g=()=>{a.value="*"},f=e=>{setTimeout((()=>{r()}),300),e()};return{DialogVisilble:t,FuncTcode:vt,SysTcode:mt,nowTCode:i,toWorkflow:n,toOverview:r,userTCodes:o,userTcodeEditorRef:d,initTcodeEditor:c,TCodeStatusEnum:kt,mode:s,doModifyTCode:p,doOnlyRead:v,doSaveTCode:m,handleChange:g,modifyTag:a,closeDialog:f}}};const Ao=(0,Ae.Z)(Fo,[["render",Do],["__scopeId","data-v-26579f9f"]]);var Bo=Ao,zo={name:"FrameWork",components:{ConnectSetting:Pe,StyleSetting:Wl,FileBlock:Sa,UserTcode:Pa,HelpTcode:Bo,QuestionFilled:je.Ruj},setup(){const e=(0,c.FN)(),{toClipboard:l}=(0,U.Z)(),t=new M.FitAddon,a=(0,R.iH)({}),i=(0,R.iH)({}),s=()=>{localStorage.getItem("options")?i.value=JSON.parse(u(localStorage.getItem("options"))):i.value={}};s();const n=(0,R.iH)({}),d=()=>{n.value={},localStorage.getItem("tcodes")&&(n.value=JSON.parse(u(localStorage.getItem("tcodes")))),setTimeout((()=>{te.value.userTCodes={...n.value}}),1)};d();const p=(0,R.iH)(null),v=()=>{if(localStorage.getItem("env")){p.value=JSON.parse(u(localStorage.getItem("env")));let e=i.value[p.value["option"]];e?p.value={...p.value,...e}:p.value.option=""}else p.value=Q};v();const m=(e,l)=>{i.value={...i.value,[e]:l},localStorage.setItem("options",r(JSON.stringify(i.value))),s()},g=(0,R.iH)({Fail:"Fail to connect remote server !\r\n",Success:"Connecting success !\r\n",Connecting:"Connecting to remote server ...\r\n",Disconnected:"Disconnect to remote server.\r\n"}),f=(0,R.iH)(g.value["Connecting"]),y=(0,R.iH)();let w=null;const k=(0,R.iH)(!0),h=()=>{w=new j.Terminal({rendererType:"canvas",convertEol:!0,scrollback:0,disableStdin:!1,cursorStyle:p.value.cursorStyle,cursorBlink:p.value.cursorBlink,theme:{foreground:p.value.fg,background:p.value.bg,cursor:"help"},lineHeight:1.2,fontFamily:p.value.fontFamily,fontSize:p.value.fontSize}),w.loadAddon(t)},_=()=>{if(y.value.style.height=window.innerHeight-25+"px",t.fit(),C.value&&C.value.readyState==WebSocket.OPEN&&w){let e=t.proposeDimensions().rows,l=t.proposeDimensions().cols;C.value.send(r(JSON.stringify({type:1,content:"",rows:e,cols:l}))),w.resize(l,e)}},x=(0,R.iH)(""),C=(0,R.iH)(null),S=()=>{C.value=new WebSocket(L+G(r(JSON.stringify(p.value)))),C.value.onopen=()=>{_()},C.value.onmessage=e=>{let l=JSON.parse(e.data);if(-1==l.code&&(w.clear(),f.value=g.value["Fail"],w.write(f.value),H(1)),0==l.code&&(w.clear(),f.value=g.value["Success"],x.value=u(l.info),setTimeout((()=>{_()}),1)),1==l.code){let e=u(l.info);gt.active&>.outArray.push(e),gt.active&&!gt.display||w.write(e),w.options.scrollback+=w._core.buffer.lines.length}},C.value.onclose=e=>{f.value==g.value["Success"]&&3333!=e.code&&(x.value="",K(),f.value=g.value["Disconnected"],w.write("\r\n"+f.value)),X()}},b=(0,R.iH)(!1),I=()=>{b.value=!b.value},D=(0,R.iH)(),E=(0,R.iH)(),T=(0,R.iH)(),W=e=>{p.value={...p.value,...e},localStorage.setItem("env",r(JSON.stringify(p.value))),H(3)},V=(e,l=!1)=>{C.value&&(k.value&&(_(),k.value=!1),gt.active===l&&C.value.send(r(JSON.stringify({type:0,content:e,rows:0,cols:0}))))},F=e=>{e.preventDefault(),V(e.target.value),e.target.value=""},A=async function(e){e.preventDefault();let l=await navigator.clipboard.readText();V(l)},B=()=>{b.value=!1},z=()=>{w&&y.value&&(y.value.removeEventListener("contextmenu",A),y.value.removeEventListener("compositionend",F),y.value.removeEventListener("click",B)),y.value.innerHTML="",k.value=!0,v(),h(),w.open(y.value),_(),y.value.addEventListener("compositionend",F),w.onKey((e=>{V(e.key)})),w.onSelectionChange((async()=>{if(w.hasSelection()){let e=w.getSelection(),t=e.trim();t&&""!=t&&await l(e)}})),y.value.addEventListener("contextmenu",A),y.value.addEventListener("click",B),w.write(f.value)},H=e=>{1==e?(b.value=!1,D.value.DialogVisilble=!0):2==e?(b.value=!1,E.value.DialogVisilble=!0):3==e?(b.value=!1,f.value=g.value["Connecting"],x.value="",C.value&&C.value.close(3333),K(),S(),z()):4==e&&(b.value=!1,T.value.DialogVisilble=!0,T.value.getInitDir())};let O=null;const P=()=>{null==O&&(O=setInterval((()=>{C.value&&C.value.readyState==WebSocket.OPEN&&C.value.send(r(JSON.stringify({type:2,content:"",rows:0,cols:0}))),"Linux"!=a.value.serverOS&&o().ajax({url:J+"/beat",type:"post",data:{windowId:a.value.windowId},success(){}})}),25e3))},K=()=>{T.value.txtPreviewRef.DialogVisilble=!1,T.value.txtPreviewRef.resetEditor(),T.value.mkFileRef.DialogVisilble=!1,T.value.fileAttrRef.DialogVisilble=!1,T.value.DialogVisilble=!1,T.value.dir="",T.value.selectedFiles=[],T.value.renameFile=null,T.value.fileClipboard={path:"/",files:[]},T.value.isCtrlx=!1},q=(e,l)=>{n.value[e].status=l,localStorage.setItem("tcodes",r(JSON.stringify(n.value))),setTimeout((()=>{te.value.userTCodes={...n.value}}),1)},Z=(0,R.iH)(""),Y=async()=>{if(!Z.value||Z.value.length<2)return;let l=Z.value.toUpperCase();if(Z.value="","/"==l[0]&&vt[l])vt[l].execFlow(e);else if("S"==l[0]&&mt[l])mt[l].execFlow(e);else if("U"==l[0]&&n.value[l])if(gt.writeOnly||(gt.writeOnly=V),0==gt.active){if(X(),gt.active=!0,!n.value[l].execFlow||!(n.value[l].execFlow instanceof Function)){let e=n.value[l].workflow.toString();try{n.value[l].execFlow=new Function("kkTerminal",`return (async function() { ${e} })()`)}catch(t){return q(l,"Load Error"),(0,N.z8)({message:"TCode-"+l+" Load Error: "+t,type:"error",grouping:!0}),void X()}}try{await n.value[l].execFlow(gt),(0,N.z8)({message:"TCode-"+l+" Workflow Over",type:"success",grouping:!0}),q(l,"Execute Success")}catch(t){(0,N.z8)({message:"TCode-"+l+" Execute Error: "+t,type:"warning",grouping:!0}),q(l,"Execute Error")}finally{X()}}else(0,N.z8)({message:"Another TCode is executing",type:"warning",grouping:!0})},X=()=>{gt.active=!1,gt.display=!0,gt.outArray=[],gt.cnt=0},$=(0,R.iH)(),ee=e=>{let l={};l={...n.value,...e},localStorage.setItem("tcodes",r(JSON.stringify(l))),d()},le=()=>{let e={};localStorage.getItem("tcodes")&&(e=JSON.parse(u(localStorage.getItem("tcodes"))));const l=new Blob([JSON.stringify(e,null,4)],{type:"text/plain"}),t=URL.createObjectURL(l),a=document.createElement("a");a.href=t,a.download="TCode.json",document.body.appendChild(a),a.click(),document.body.removeChild(a),URL.revokeObjectURL(t)},te=(0,R.iH)(),ae=(e,l)=>{let t={};t[e]={desc:n.value[e].desc||"",workflow:l||"",status:"Not Active"},ee(t)};return(0,c.bv)((()=>{z(),o().ajax({url:J+"/init",type:"get",success(e){a.value={...e.data},S(),window.addEventListener("resize",(()=>{T.value&&(T.value.isShowMenu=!1,T.value.isShowPop=!1),_()})),P()}})})),(0,c.Ah)((()=>{w&&y.value&&(y.value.removeEventListener("contextmenu",A),y.value.removeEventListener("compositionend",F),y.value.removeEventListener("click",B)),O&&clearInterval(O)})),{env:p,options:i,now_connect_status:f,connect_status:g,terminal:y,doSSHConnect:S,socket:C,showSettings:I,isShowSetting:b,doSettings:H,connectSettingRef:D,styleSettingRef:E,fileBlockRef:T,saveEnv:W,sshKey:x,doHeartBeat:P,saveOp:m,tcode:Z,handleTcode:Y,closeFileBlock:K,resetTerminal:z,tcodes:n,userTcodeRef:$,sendMessage:V,importTCodes:ee,exportTcodes:le,helpTcodeRef:te,handleSaveTCode:ae,osInfo:a}}};const Ho=(0,Ae.Z)(zo,[["render",O],["__scopeId","data-v-1ebaa6c4"]]);var Oo=Ho,Uo={name:"App",components:{FrameWork:Oo}};const Ro=(0,Ae.Z)(Uo,[["render",p]]);var No=Ro,jo=(t(4415),t(391)),Mo=t(5974),Qo=t(1015),Po=t(3370),Ko=t(3096),Lo=t(5868),Jo=t(881),Go=t(9695),qo=t(4133),Zo=t(6199),Yo=t(7224),Xo=t(4775),$o=t(3838),ei=t(7919),li=(t(1849),t(3189));o().ajaxSetup({processData:!0,xhrFields:{withCredentials:!0},dataFilter(e){e=JSON.parse(e);let l=e.data;return l&&(e.data=JSON.parse(u(e.data))),JSON.stringify(e)}});const ti=(0,d.ri)(No);ti.use(jo.ElButton).use(Mo.d0).use(Qo.gn).use(Po.EZ).use(Ko.LW).use(Lo.$).use(Jo.Ub).use(Jo.p8).use(Go.b9).use(qo.Q0),ti.use(Zo.YK).use(Zo.o2).use(Zo.Df).use(Yo.OX).use(Xo.kN).use($o.KD).use($o.rh).use(ei.$t),ti.use(li.Z),ti.mount("#app"),ti.config.warnHandler=()=>{}},2480:function(){}},l={};function t(a){var o=l[a];if(void 0!==o)return o.exports;var i=l[a]={id:a,loaded:!1,exports:{}};return e[a].call(i.exports,i,i.exports,t),i.loaded=!0,i.exports}t.m=e,function(){t.amdD=function(){throw new Error("define cannot be used indirect")}}(),function(){var e=[];t.O=function(l,a,o,i){if(!a){var s=1/0;for(d=0;d=i)&&Object.keys(t.O).every((function(e){return t.O[e](a[r])}))?a.splice(r--,1):(n=!1,i0&&e[d-1][2]>i;d--)e[d]=e[d-1];e[d]=[a,o,i]}}(),function(){t.n=function(e){var l=e&&e.__esModule?function(){return e["default"]}:function(){return e};return t.d(l,{a:l}),l}}(),function(){t.d=function(e,l){for(var a in l)t.o(l,a)&&!t.o(e,a)&&Object.defineProperty(e,a,{enumerable:!0,get:l[a]})}}(),function(){t.g=function(){if("object"===typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"===typeof window)return window}}()}(),function(){t.o=function(e,l){return Object.prototype.hasOwnProperty.call(e,l)}}(),function(){t.r=function(e){"undefined"!==typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})}}(),function(){t.nmd=function(e){return e.paths=[],e.children||(e.children=[]),e}}(),function(){t.p="/"}(),function(){var e={143:0};t.O.j=function(l){return 0===e[l]};var l=function(l,a){var o,i,s=a[0],n=a[1],r=a[2],u=0;if(s.some((function(l){return 0!==e[l]}))){for(o in n)t.o(n,o)&&(t.m[o]=n[o]);if(r)var d=r(t)}for(l&&l(a);u>2;o=(n&3)<<4|r>>4;u=(r&15)<<2|i>>6;a=i&63;if(isNaN(r)){u=a=64}else if(isNaN(i)){a=64}t=t+this._keyStr.charAt(s)+this._keyStr.charAt(o)+this._keyStr.charAt(u)+this._keyStr.charAt(a)}return t},decode:function(e){var t=\"\";var n,r,i;var s,o,u,a;var f=0;e=e.replace(/[^A-Za-z0-9+/=]/g,\"\");while(f>4;r=(o&15)<<4|u>>2;i=(u&3)<<6|a;t=t+String.fromCharCode(n);if(u!=64){t=t+String.fromCharCode(r)}if(a!=64){t=t+String.fromCharCode(i)}}t=Base64._utf8_decode(t);return t},_utf8_encode:function(e){e=e.replace(/rn/g,\"n\");var t=\"\";for(var n=0;n127&&r<2048){t+=String.fromCharCode(r>>6|192);t+=String.fromCharCode(r&63|128)}else{t+=String.fromCharCode(r>>12|224);t+=String.fromCharCode(r>>6&63|128);t+=String.fromCharCode(r&63|128)}}return t},_utf8_decode:function(e){var t=\"\";var n=0;var r=0;var c2=0;while(n191&&r<224){c2=e.charCodeAt(n+1);t+=String.fromCharCode((r&31)<<6|c2&63);n+=2}else{c2=e.charCodeAt(n+1);var c3=e.charCodeAt(n+2);t+=String.fromCharCode((r&15)<<12|(c2&63)<<6|c3&63);n+=3}}return t}}\r\n","\n \n\n\n\n\n","\r\n \r\n \r\n
\r\n \r\n \r\n \r\n \r\n
\r\n
\r\n
\r\n

\r\n
\r\n
kk Terminal
\r\n
\r\n
\r\n
TCode
\r\n
\r\n
\r\n \r\n \r\n
\r\n
\r\n
\r\n \r\n \r\n \r\n \r\n
什么是 TCode (终端代码) ?
\r\n
TCode(终端代码)是用于访问和执行特定操作流程的快捷方式
\r\n
\r\n 输入 \r\n /H\r\n 并按下回车,查看帮助信息\r\n
\r\n
\r\n 输入 \r\n /A\r\n 并按下回车,自定义TCode\r\n
\r\n
\r\n \r\n
\r\n
\r\n
\r\n
\r\n \r\n
\r\n
\r\n\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n\r\n\r\n\r\n\r\n\r\n\r\n","export const default_env = {\r\n // 连接相关\r\n server_ip: '',\r\n server_port: 22,\r\n server_user: 'root',\r\n server_password:'',\r\n option:'',\r\n // 样式相关\r\n bg:'#0c0c0c',\r\n fg:'#cccccc',\r\n fontFamily: 'Courier New',\r\n fontSize: 16,\r\n cursorStyle: 'block',\r\n cursorBlink: true,\r\n tCode: true,\r\n};","// 上线环境\r\nlet http_protocol = window.location.protocol;\r\nlet ws_protocol = '';\r\nif(http_protocol == 'https:') ws_protocol = 'wss://';\r\nelse ws_protocol = 'ws://';\r\nexport const ws_base_url = ws_protocol + window.location.host + '/socket/ssh/';\r\nexport const http_base_url = http_protocol + '//' + window.location.host + '/api';\r\n\r\n// 本地开发环境\r\n// export const ws_base_url = 'ws://localhost:3000/socket/ssh/';\r\n// export const http_base_url = 'http://localhost:3000/api';\r\n\r\n// 在线环境\r\n// export const ws_base_url = 'wss://ssh.kkbpro.com/socket/ssh/';\r\n// export const http_base_url = 'https://ssh.kkbpro.com/api';","// 将 '/' 转为 '@'\r\nexport function changeStr(str) {\r\n let result = '';\r\n for (let i = 0; i < str.length; i++) {\r\n if(str[i] != '/') result += str[i];\r\n else result += '@';\r\n }\r\n \r\n return result;\r\n}","\r\n \r\n \r\n \r\n
\r\n
配 置:
\r\n
0) ? 'new-option': 'old-option'\" >{{ !(setInfo.option && setInfo.option.length > 0) ? '新建配置' : setInfo.option }}
\r\n
\r\n
切换
\r\n
保存
\r\n
新建
\r\n
\r\n
\r\n
主机ip:
\r\n
\r\n \r\n \r\n \r\n \r\n \r\n
\r\n
\r\n
\r\n
\r\n
端口号:
\r\n
\r\n
\r\n \r\n \r\n \r\n \r\n
\r\n
\r\n
\r\n
\r\n
用户名:
\r\n
\r\n \r\n \r\n \r\n \r\n \r\n
\r\n
\r\n
\r\n
\r\n
密 码:
\r\n
\r\n \r\n \r\n \r\n \r\n \r\n
\r\n
\r\n
\r\n
\r\n
\r\n {{ err_msg }}
\r\n \r\n \r\n
\r\n
\r\n 确定\r\n \r\n
\r\n \r\n\r\n \r\n \r\n\r\n\r\n\r\n\r\n","\r\n \r\n \r\n \r\n
0\" class=\"kk-border\">\r\n
\r\n
\r\n
\r\n \r\n
\r\n
\r\n
配置名:
\r\n
\r\n \r\n \r\n
\r\n
\r\n \r\n {{ opType ? '保存' : '选择'}}\r\n \r\n
\r\n
\r\n
\r\n \r\n \r\n\r\n\r\n\r\n\r\n","\r\n \r\n
\r\n
\r\n
\r\n

\r\n
\r\n
{{ msg }}
\r\n
\r\n
\r\n\r\n\r\n\r\n\r\n","import { render } from \"./NoData.vue?vue&type=template&id=7a3a533e&scoped=true\"\nimport script from \"./NoData.vue?vue&type=script&lang=js\"\nexport * from \"./NoData.vue?vue&type=script&lang=js\"\n\nimport \"./NoData.vue?vue&type=style&index=0&id=7a3a533e&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-7a3a533e\"]])\n\nexport default __exports__","import { render } from \"./OptionBlock.vue?vue&type=template&id=1f07a939&scoped=true\"\nimport script from \"./OptionBlock.vue?vue&type=script&lang=js\"\nexport * from \"./OptionBlock.vue?vue&type=script&lang=js\"\n\nimport \"./OptionBlock.vue?vue&type=style&index=0&id=1f07a939&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-1f07a939\"]])\n\nexport default __exports__","import { render } from \"./ConnectSetting.vue?vue&type=template&id=663bb10e&scoped=true\"\nimport script from \"./ConnectSetting.vue?vue&type=script&lang=js\"\nexport * from \"./ConnectSetting.vue?vue&type=script&lang=js\"\n\nimport \"./ConnectSetting.vue?vue&type=style&index=0&id=663bb10e&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-663bb10e\"]])\n\nexport default __exports__","\r\n \r\n \r\n \r\n
\r\n
颜色:
\r\n
\r\n
背景色
\r\n
\r\n \r\n
\r\n
\r\n
\r\n
\r\n
前景色
\r\n
\r\n \r\n
\r\n
\r\n
\r\n
\r\n
文本:
\r\n
\r\n
字体
\r\n
\r\n {{ setInfo.fontFamily }}\r\n \r\n \r\n \r\n {{ font }}\r\n \r\n \r\n \r\n \r\n
\r\n
\r\n
字号
\r\n
\r\n {{ setInfo.fontSize }}\r\n \r\n \r\n \r\n {{ size }}\r\n \r\n \r\n \r\n \r\n
\r\n
\r\n
\r\n
光标:
\r\n
\r\n
样式
\r\n
\r\n {{ setInfo.cursorStyle }}\r\n \r\n \r\n \r\n {{ style }}\r\n \r\n \r\n \r\n \r\n
\r\n
\r\n
闪烁
\r\n
\r\n \r\n
\r\n
\r\n
\r\n
\r\n
功能:
\r\n
\r\n
TCode
\r\n
\r\n \r\n
\r\n
\r\n
\r\n
\r\n \r\n \r\n
\r\n
\r\n 确定\r\n \r\n
\r\n \r\n\r\n\r\n\r\n\r\n","import { render } from \"./StyleSetting.vue?vue&type=template&id=d18bce82&scoped=true\"\nimport script from \"./StyleSetting.vue?vue&type=script&lang=js\"\nexport * from \"./StyleSetting.vue?vue&type=script&lang=js\"\n\nimport \"./StyleSetting.vue?vue&type=style&index=0&id=d18bce82&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-d18bce82\"]])\n\nexport default __exports__","\r\n \r\n \r\n \r\n
\r\n
\r\n
\r\n \r\n
\r\n
{{ dir }}
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n \r\n \r\n \r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n \r\n
\r\n
\r\n \r\n
\r\n
{{ item.name }}
\r\n
\r\n \r\n
\r\n \r\n
\r\n
\r\n \r\n
\r\n
{{ item.name }}
\r\n
\r\n \r\n
\r\n
\r\n
\r\n \r\n
\r\n
\r\n
\r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n\r\n\r\n\r\n\r\n\r\n","\r\n \r\n \r\n \r\n
\r\n
{{ modifyTag + fileName }}
\r\n
\r\n \r\n \r\n \r\n \r\n \r\n\r\n\r\n\r\n\r\n","\r\n \r\n\r\n\r\n\r\n\r\n","const langs = {\r\n \"c\": \"c_cpp\",\r\n \"h\": \"c_cpp\",\r\n \"cpp\": \"c_cpp\",\r\n \"hpp\": \"c_cpp\",\r\n \"cs\": \"csharp\",\r\n \"css\": \"css\",\r\n \"gitignore\": \"gitignore\",\r\n \"go\": \"golang\",\r\n \"html\": \"html\",\r\n \"htm\": \"html\",\r\n \"java\": \"java\",\r\n \"js\": \"javascript\",\r\n \"jsx\": \"javascript\",\r\n \"json\": \"json\",\r\n \"jsp\": \"jsp\",\r\n \"md\": \"markdown\",\r\n \"markdown\": \"markdown\",\r\n \"properties\": \"properties\",\r\n \"py\": \"python\",\r\n \"sh\": \"sh\",\r\n \"bash\": \"sh\",\r\n \"sql\": \"sql\",\r\n \"ts\": \"typescript\",\r\n \"tsx\": \"typescript\",\r\n \"vue\": \"javascript\",\r\n \"xml\": \"xml\",\r\n \"xsd\": \"xml\",\r\n \"xsl\": \"xml\",\r\n \"xslt\": \"xml\",\r\n \"yaml\": \"yaml\",\r\n \"yml\": \"yaml\"\r\n}\r\n\r\n// 获取文件名后缀\r\nconst getSuffix = (name) => {\r\n let suffix = 'txt';\r\n if(name && name.length > 0) {\r\n let index = name.lastIndexOf('.');\r\n if(index != -1) suffix = name.substring(index + 1);\r\n }\r\n return suffix;\r\n}\r\n\r\nexport default function langToMode(name) {\r\n return langs[getSuffix(name)] || \"text\";\r\n}","import { encrypt, decrypt } from './Encrypt';\r\nconst storageKey = 'tcode-local-vars';\r\n\r\n// 功能TCode, 以 / 开头\r\nexport const FuncTcode = {\r\n '/A': {\r\n desc: '自定义TCode',\r\n execFlow(context) {\r\n setTimeout(() => {\r\n context.proxy.userTcodeRef.initText();\r\n },1);\r\n context.proxy.userTcodeRef.DialogVisilble = true;\r\n }\r\n },\r\n '/O': {\r\n desc: '新建窗口',\r\n execFlow() {\r\n let _url = window.location.href;\r\n window.open(_url, '_blank');\r\n }\r\n },\r\n '/C': {\r\n desc: '关闭窗口',\r\n execFlow() {\r\n window.close();\r\n }\r\n },\r\n '/E': {\r\n desc: '退出登录',\r\n execFlow(context) {\r\n if(context.proxy.socket) context.proxy.socket.close(3131);\r\n }\r\n },\r\n '/R': {\r\n desc: '刷新页面',\r\n execFlow() {\r\n window.location.reload();\r\n }\r\n },\r\n '/H': {\r\n desc: '帮助',\r\n execFlow(context) {\r\n context.proxy.helpTcodeRef.DialogVisilble = true;\r\n }\r\n },\r\n}\r\n\r\n// 系统TCode, 以 S 开头\r\nexport const SysTcode = {\r\n 'SC': {\r\n desc: '连接设置',\r\n execFlow(context) {\r\n context.proxy.isShowSetting = false;\r\n context.proxy.connectSettingRef.DialogVisilble = true;\r\n }\r\n },\r\n 'SP': {\r\n desc: '偏好设置',\r\n execFlow(context) {\r\n context.proxy.isShowSetting = false;\r\n context.proxy.styleSettingRef.DialogVisilble = true;\r\n }\r\n },\r\n 'SF': {\r\n desc: '文件管理',\r\n execFlow(context) {\r\n context.proxy.isShowSetting = false;\r\n context.proxy.fileBlockRef.DialogVisilble = true;\r\n context.proxy.fileBlockRef.getInitDir();\r\n }\r\n },\r\n 'SS': {\r\n desc: '重启',\r\n execFlow(context) {\r\n context.proxy.isShowSetting = false;\r\n context.proxy.now_connect_status = context.proxy.connect_status['Connecting'];\r\n context.proxy.sshKey = '';\r\n if(context.proxy.socket) context.proxy.socket.close(3333); // 主动释放资源,必需\r\n // 进行重启\r\n context.proxy.closeFileBlock();\r\n context.proxy.doSSHConnect();\r\n context.proxy.resetTerminal();\r\n }\r\n }\r\n}\r\n\r\n// 用户TCode, 以 U 开头\r\nexport const UserTcodeExecutor = {\r\n active: false,\r\n display: true,\r\n outArray: [],\r\n cnt: 0,\r\n // 变量\r\n variables: {\r\n session(key,value) {\r\n if(value != undefined) sessionStorage.setItem(key,JSON.stringify(value));\r\n else {\r\n if(sessionStorage.getItem(key)) return JSON.parse(sessionStorage.getItem(key));\r\n else return null;\r\n }\r\n },\r\n local(key,value) {\r\n let tcodeLocalVars = {};\r\n if(localStorage.getItem(storageKey)) {\r\n tcodeLocalVars = JSON.parse(decrypt(localStorage.getItem(storageKey)));\r\n }\r\n if(value != undefined) {\r\n tcodeLocalVars[key] = value;\r\n localStorage.setItem(storageKey,encrypt(JSON.stringify(tcodeLocalVars)));\r\n }\r\n else return tcodeLocalVars[key];\r\n },\r\n clean() {\r\n if(arguments.length == 0) {\r\n localStorage.removeItem(storageKey);\r\n return;\r\n }\r\n let tcodeLocalVars = {};\r\n if(localStorage.getItem(storageKey)) {\r\n tcodeLocalVars = JSON.parse(decrypt(localStorage.getItem(storageKey)));\r\n }\r\n for (let i = 0; i < arguments.length; i++) {\r\n delete tcodeLocalVars[arguments[i]];\r\n }\r\n localStorage.setItem(storageKey,encrypt(JSON.stringify(tcodeLocalVars)));\r\n }\r\n },\r\n // 仅向terminal写入,不等待\r\n writeOnly: null,\r\n // 向terminal写入并等待\r\n async writeAndWait(content, time = 200) {\r\n if(content && content.length > 0 && content[content.length - 1] != '\\n' && content[content.length - 1] != '\\r') content += '\\n';\r\n this.cnt = this.outArray.length;\r\n this.writeOnly(content,true);\r\n await new Promise(resolve => setTimeout(resolve, time > 0 ? time : 0));\r\n },\r\n // writeAndWait简写\r\n write(content, time = 200) {\r\n return this.writeAndWait(content, time);\r\n },\r\n // 读取输出\r\n read() {\r\n return filter(this.outArray.slice(this.cnt));\r\n },\r\n // 读取全部输出\r\n readAll() {\r\n return filter(this.outArray.slice(0));\r\n },\r\n // 隐藏\r\n hide() {\r\n this.display = false;\r\n },\r\n // 显示\r\n show() {\r\n this.display = true;\r\n },\r\n}\r\n\r\n// 处理过滤输出\r\nconst filter = (arr) => {\r\n let ret = [];\r\n let tmp = filterRN(arr);\r\n for(let i = 0; i < tmp.length; i++) {\r\n let str = filterANSI(tmp[i]);\r\n if(str && str != '') ret.push(str);\r\n }\r\n return ret;\r\n};\r\n\r\n// 以 \\r\\n 分割\r\nconst filterRN = (arr) => {\r\n let ret = [];\r\n for(let i = 0; i < arr.length; i++) {\r\n let tmp = arr[i].split(\"\\r\\n\");\r\n for(let j = 0; j < tmp.length; j++) {\r\n if (tmp[j] && tmp[j] != '') ret.push(tmp[j]);\r\n }\r\n }\r\n return ret;\r\n};\r\n// 过滤 ANSI 等终端字符\r\nimport stripAnsi from 'strip-ansi';\r\nconst filterANSI = (str) => {\r\n // eslint-disable-next-line\r\n return stripAnsi(str).replace(/[\\x00-\\x1F\\x7F]/g, '');\r\n};\r\n\r\n// 用户TCode状态枚举\r\n// Error-加载失败: Load Error\r\n// Interrupted-执行失败: Execute Error\r\n// Inactive-未被使用: Not Active\r\n// Success-执行成功: Execute Success\r\nexport const TCodeStatusEnum = {\r\n 'Load Error': 'Error',\r\n 'Execute Error':'Interrupted',\r\n 'Not Active': 'Inactive',\r\n 'Execute Success': 'Success',\r\n}\r\n\r\n\r\n// 编辑器添加kkTerminal智能提示\r\nexport const userTcodeExecutorCompleter = {\r\n getCompletions: function(editor, session, pos, prefix, callback) {\r\n const userTcodeExecutorCompletions = [\r\n {\r\n name: \"kkTerminal\",\r\n value: \"kkTerminal\",\r\n meta: \"kkTerminal\",\r\n description: \"kkTerminal API\",\r\n score: 1000,\r\n },\r\n {\r\n name: \"variables\",\r\n value: \"variables\",\r\n meta: \"kkTerminal\",\r\n description: \"access variables\",\r\n score: 1000,\r\n },\r\n {\r\n name: \"session\",\r\n value: \"session()\",\r\n meta: \"kkTerminal\",\r\n description: \"get or set session variables\",\r\n score: 1000,\r\n },\r\n {\r\n name: \"local\",\r\n value: \"local()\",\r\n meta: \"kkTerminal\",\r\n description: \"get or set local variables\",\r\n score: 1000,\r\n },\r\n {\r\n name: \"clean\",\r\n value: \"clean()\",\r\n meta: \"kkTerminal\",\r\n description: \"remove local variables\",\r\n score: 1000,\r\n },\r\n {\r\n name: \"write\",\r\n value: \"write()\",\r\n meta: \"kkTerminal\",\r\n description: \"write to terminal\",\r\n score: 1000,\r\n },\r\n {\r\n name: \"read\",\r\n value: \"read()\",\r\n meta: \"kkTerminal\",\r\n description: \"read lastest from terminal\",\r\n score: 1000,\r\n },\r\n {\r\n name: \"readAll\",\r\n value: \"readAll()\",\r\n meta: \"kkTerminal\",\r\n description: \"read all from terminal\",\r\n score: 1000,\r\n },\r\n {\r\n name: \"hide\",\r\n value: \"hide()\",\r\n meta: \"kkTerminal\",\r\n description: \"hide TCode display\",\r\n score: 1000,\r\n },\r\n {\r\n name: \"show\",\r\n value: \"show()\",\r\n meta: \"kkTerminal\",\r\n description: \"show TCode display\",\r\n score: 1000,\r\n }\r\n ];\r\n\r\n callback(null, userTcodeExecutorCompletions.map((completion) => {\r\n return {\r\n caption: completion.caption || completion.name,\r\n value: completion.value,\r\n meta: completion.meta,\r\n description: completion.description || ''\r\n };\r\n }));\r\n }\r\n};","import { render } from \"./AceEditor.vue?vue&type=template&id=73ef2e97&scoped=true\"\nimport script from \"./AceEditor.vue?vue&type=script&lang=js\"\nexport * from \"./AceEditor.vue?vue&type=script&lang=js\"\n\nimport \"./AceEditor.vue?vue&type=style&index=0&id=73ef2e97&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-73ef2e97\"]])\n\nexport default __exports__","import { render } from \"./TxtPreview.vue?vue&type=template&id=480795cf&scoped=true\"\nimport script from \"./TxtPreview.vue?vue&type=script&lang=js\"\nexport * from \"./TxtPreview.vue?vue&type=script&lang=js\"\n\nimport \"./TxtPreview.vue?vue&type=style&index=0&id=480795cf&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-480795cf\"]])\n\nexport default __exports__","\r\n \r\n \r\n \r\n
\r\n 文件\r\n 文件夹\r\n \r\n
{{ err_msg }}
\r\n
\r\n
\r\n \r\n \r\n
\r\n
\r\n
\r\n \r\n \r\n
\r\n
\r\n 确定\r\n
\r\n
\r\n
\r\n \r\n \r\n\r\n\r\n\r\n\r\n","import { render } from \"./MkFile.vue?vue&type=template&id=101691e8&scoped=true\"\nimport script from \"./MkFile.vue?vue&type=script&lang=js\"\nexport * from \"./MkFile.vue?vue&type=script&lang=js\"\n\nimport \"./MkFile.vue?vue&type=style&index=0&id=101691e8&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-101691e8\"]])\n\nexport default __exports__","\r\n \r\n \r\n \r\n \r\n
\r\n
{{ fileInfo.name }}
\r\n
属性
\r\n
\r\n \r\n \r\n \r\n
\r\n
\r\n
\r\n
位置:
\r\n
\r\n {{ fileDir + fileInfo.name }}\r\n
\r\n
\r\n
\r\n
\r\n
大小:
\r\n
\r\n {{ calcSize(fileInfo.attributes.size) }} ({{ fileInfo.attributes.size + ' 字节' }})\r\n
\r\n
\r\n
\r\n
\r\n
修改时间:
\r\n
\r\n {{ formatDate(fileInfo.attributes.mtime) }}\r\n
\r\n
\r\n
\r\n
访问时间:
\r\n
\r\n {{ formatDate(fileInfo.attributes.atime) }}\r\n
\r\n
\r\n
\r\n
\r\n
权限:
\r\n
\r\n {{ calcPriority(fileInfo.attributes.mode.type,fileInfo.attributes.permissions) }}\r\n
\r\n
\r\n
\r\n 确定\r\n
\r\n
\r\n
\r\n \r\n \r\n\r\n\r\n\r\n\r\n","// 将时间戳转为 2024年1月22日,20:40:38 格式\r\nexport const formatDate = (time) => {\r\n if(!time) return \"\";\r\n let date = new Date(time*1000);\r\n let year = date.getFullYear();\r\n let month = date.getMonth() + 1;\r\n let day = date.getDate();\r\n let hour = date.getHours();\r\n let min = date.getMinutes();\r\n let seconds = date.getSeconds();\r\n\r\n if(month < 10) month = \"0\" + month;\r\n if(day < 10) day = \"0\" + day;\r\n if(hour < 10) hour = \"0\" + hour;\r\n if(min < 10) min = \"0\" + min;\r\n if(seconds < 10) seconds = \"0\" + seconds;\r\n\r\n return year + \"年\" + month + \"月\" + day + \"日,\" + hour + \":\" + min + \":\" + seconds;\r\n}","export const calcPriority = (type,attrs) => {\r\n return getType(type) + getAttrs(attrs);\r\n}\r\n\r\nconst fileTypeSymbols = {\r\n 'BLOCK_SPECIAL': 'b',\r\n 'CHAR_SPECIAL': 'c',\r\n 'FIFO_SPECIAL': 'p',\r\n 'SOCKET_SPECIAL': 's',\r\n 'REGULAR': '-',\r\n 'DIRECTORY': 'd',\r\n 'SYMLINK': 'l',\r\n 'UNKNOWN': '?'\r\n};\r\n\r\nconst getType = (type) => {\r\n return fileTypeSymbols[type];\r\n}\r\n\r\nconst permissionMap = {\r\n 'USR_R': 256,\r\n 'USR_W': 128,\r\n 'USR_X': 64,\r\n 'GRP_R': 32,\r\n 'GRP_W': 16,\r\n 'GRP_X': 8,\r\n 'OTH_R': 4,\r\n 'OTH_W': 2,\r\n 'OTH_X': 1,\r\n 'SUID': 2048,\r\n 'SGID': 1024,\r\n 'STICKY': 512\r\n};\r\n\r\nconst getAttrs = (attrs) => {\r\n let symbol = '---------';\r\n // 将权限数组转换为对应的权限值总和\r\n let permissionValue = 0;\r\n for(let i=0;i {\r\n if(sizeRaw == null || sizeRaw == undefined) return \"\";\r\n let size = \"\";\r\n if (sizeRaw < 1024) { // B\r\n size = sizeRaw.toFixed(2) + \" B\"\r\n } else if (sizeRaw < 1024 * 1024) { // KB\r\n size = (sizeRaw / 1024).toFixed(2) + \" KB\"\r\n } else if (sizeRaw < 1024 * 1024 * 1024) { // MB\r\n size = (sizeRaw / (1024 * 1024)).toFixed(2) + \" MB\"\r\n } else { // GB\r\n size = (sizeRaw / (1024 * 1024 * 1024)).toFixed(2) + \" GB\"\r\n }\r\n let sizeStr = size + \"\"; // 转成字符串\r\n let index = sizeStr.indexOf(\".\"); // 获取小数点处的索引\r\n let dou = sizeStr.substring(index + 1, index + 3) // 获取小数点后两位的值\r\n if (dou == \"00\") { // 判断后两位是否为00,如果是则删除00 \r\n return sizeStr.substring(0, index) + sizeStr.substring(index + 3)\r\n }\r\n return size;\r\n}","import { render } from \"./FileAttr.vue?vue&type=template&id=1ef7ac5d&scoped=true\"\nimport script from \"./FileAttr.vue?vue&type=script&lang=js\"\nexport * from \"./FileAttr.vue?vue&type=script&lang=js\"\n\nimport \"./FileAttr.vue?vue&type=style&index=0&id=1ef7ac5d&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-1ef7ac5d\"]])\n\nexport default __exports__","import { render } from \"./FileBlock.vue?vue&type=template&id=7d7f3746&scoped=true\"\nimport script from \"./FileBlock.vue?vue&type=script&lang=js\"\nexport * from \"./FileBlock.vue?vue&type=script&lang=js\"\n\nimport \"./FileBlock.vue?vue&type=style&index=0&id=7d7f3746&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-7d7f3746\"]])\n\nexport default __exports__","\r\n \r\n \r\n \r\n
\r\n
TCode:
\r\n
U
\r\n
\r\n \r\n \r\n \r\n \r\n
\r\n
\r\n \r\n \r\n 导入\r\n \r\n \r\n
\r\n
\r\n
\r\n
描 述:
\r\n
\r\n \r\n \r\n \r\n \r\n
\r\n
\r\n \r\n 导出\r\n \r\n
\r\n
\r\n
\r\n
\r\n
Workflow
\r\n
\r\n
\r\n \r\n \r\n \r\n
\r\n
\r\n \r\n \r\n \r\n
\r\n
\r\n \r\n \r\n \r\n
\r\n
\r\n
\r\n
\r\n \r\n
\r\n
\r\n 确定\r\n \r\n
\r\n \r\n\r\n\r\n\r\n\r\n","import { render } from \"./UserTcode.vue?vue&type=template&id=c9882564&scoped=true\"\nimport script from \"./UserTcode.vue?vue&type=script&lang=js\"\nexport * from \"./UserTcode.vue?vue&type=script&lang=js\"\n\nimport \"./UserTcode.vue?vue&type=style&index=0&id=c9882564&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-c9882564\"]])\n\nexport default __exports__","\r\n \r\n \r\n \r\n
\r\n \r\n \r\n
以 / 开头,用于快速执行通用功能
\r\n
\r\n
\r\n
\r\n
{{ key }}
\r\n
{{ item.desc }}
\r\n
\r\n
\r\n
\r\n \r\n \r\n \r\n
以 S 开头,用于快速访问系统模块
\r\n
\r\n
\r\n
\r\n
{{ key }}
\r\n
{{ item.desc }}
\r\n
\r\n
\r\n
\r\n \r\n \r\n \r\n
0\" >\r\n = 2 && nowTCode.length <= 6\" >\r\n \r\n
\r\n
{{ modifyTag + nowTCode }}
\r\n
\r\n \r\n \r\n \r\n
\r\n
\r\n
\r\n \r\n \r\n \r\n
\r\n
\r\n \r\n \r\n \r\n
\r\n
\r\n \r\n \r\n \r\n
\r\n
\r\n
\r\n \r\n \r\n \r\n 以 U 开头,自定义实现类似Shell脚本的自动化Workflow
\r\n \r\n \r\n
\r\n
\r\n
{{ item.desc }}
\r\n
\r\n
\r\n \r\n \r\n \r\n
\r\n
\r\n
\r\n
\r\n \r\n \r\n
\r\n 以 U 开头,自定义实现类似Shell脚本的自动化Workflow
\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n
\r\n \r\n \r\n
\r\n \r\n\r\n\r\n\r\n\r\n","\r\n
\r\n
\r\n
\r\n
\r\n\r\n\r\n\r\n\r\n","import { render } from \"./TcodeStatus.vue?vue&type=template&id=779311f7\"\nimport script from \"./TcodeStatus.vue?vue&type=script&lang=js\"\nexport * from \"./TcodeStatus.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 { render } from \"./HelpTcode.vue?vue&type=template&id=26579f9f&scoped=true\"\nimport script from \"./HelpTcode.vue?vue&type=script&lang=js\"\nexport * from \"./HelpTcode.vue?vue&type=script&lang=js\"\n\nimport \"./HelpTcode.vue?vue&type=style&index=0&id=26579f9f&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-26579f9f\"]])\n\nexport default __exports__","import { render } from \"./FrameWork.vue?vue&type=template&id=1ebaa6c4&scoped=true\"\nimport script from \"./FrameWork.vue?vue&type=script&lang=js\"\nexport * from \"./FrameWork.vue?vue&type=script&lang=js\"\n\nimport \"./FrameWork.vue?vue&type=style&index=0&id=1ebaa6c4&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-1ebaa6c4\"]])\n\nexport default __exports__","import { render } from \"./App.vue?vue&type=template&id=47d20700\"\nimport script from \"./App.vue?vue&type=script&lang=js\"\nexport * from \"./App.vue?vue&type=script&lang=js\"\n\nimport \"./App.vue?vue&type=style&index=0&id=47d20700&lang=css\"\n\nimport exportComponent from \"../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render]])\n\nexport default __exports__","// jQuery配置Ajax全局响应拦截,进行数据解密\nimport $ from 'jquery';\nimport { decrypt } from './Utils/Encrypt';\n\n$.ajaxSetup({\n processData: true,\n // 携带cookie\n xhrFields:{\n withCredentials: true,\n },\n dataFilter(resp) {\n resp = JSON.parse(resp);\n let data = resp.data;\n if(data) resp.data = JSON.parse(decrypt(resp.data));\n return JSON.stringify(resp);\n },\n});\n\nimport { createApp } from 'vue';\nimport App from './App.vue';\n\nconst app = createApp(App);\n\n// 按需引入element-plus\nimport 'element-plus/dist/index.css';\nimport { ElButton, ElDialog, ElIcon, ElInput, ElUpload, ElColorPicker,ElDropdown, ElDropdownMenu, ElDropdownItem, ElSwitch, ElLoading, ElRadioGroup, ElRadio, ElPopover, ElTabs, ElTabPane, ElResult, ElTooltip } from 'element-plus';\napp.use(ElButton).use(ElDialog).use(ElIcon).use(ElInput).use(ElUpload).use(ElColorPicker).use(ElTabs).use(ElTabPane).use(ElResult).use(ElTooltip);\napp.use(ElDropdown).use(ElDropdownMenu).use(ElDropdownItem).use(ElSwitch).use(ElLoading).use(ElRadioGroup).use(ElRadio).use(ElPopover);\n\n// 按需引入ant-design\nimport 'ant-design-vue/dist/reset.css';\nimport { Popconfirm } from 'ant-design-vue';\napp.use(Popconfirm);\n\napp.mount('#app');\n\n// 引入全局样式\nimport './assets/base.css';\n\n//用于去掉eazyplayer警告,开发时禁用,打包开启\napp.config.warnHandler = () => {}","// 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\tid: moduleId,\n\t\tloaded: false,\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// Flag the module as loaded\n\tmodule.loaded = true;\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","__webpack_require__.amdD = function () {\n\tthrow new Error('define cannot be used indirect');\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__.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); }","// 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__.nmd = function(module) {\n\tmodule.paths = [];\n\tif (!module.children) module.children = [];\n\treturn module;\n};","__webpack_require__.p = \"/\";","// 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\t143: 0\n};\n\n// no chunk on demand loading\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[\"webpackChunkterminal\"] = self[\"webpackChunkterminal\"] || [];\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, [998], function() { return __webpack_require__(3247); })\n__webpack_exports__ = __webpack_require__.O(__webpack_exports__);\n"],"names":["SECRET_KEY","encrypt","word","key","CryptoJS","Utf8","parse","srcs","encrypted","mode","ECB","padding","Pkcs7","toString","decrypt","stringify","_createBlock","_component_FrameWork","class","_createElementVNode","_hoisted_3","_hoisted_5","_hoisted_7","_hoisted_9","src","_imports_0","alt","style","_hoisted_12","ref","_hoisted_1","_hoisted_2","onClick","_cache","$event","$setup","doSettings","isShowSetting","_hoisted_11","args","showSettings","_hoisted_14","_hoisted_15","env","tCode","_createElementBlock","_hoisted_16","_hoisted_17","_hoisted_18","_createVNode","_component_el_input","tcode","id","width","height","fontSize","onKeydown","_withKeys","handleTcode","maxlength","_hoisted_19","_component_el_popover","placement","trigger","reference","_withCtx","_component_el_icon","color","_component_QuestionFilled","_hoisted_20","_hoisted_21","_hoisted_22","_component_ConnectSetting","sshOptions","options","onSaveOp","saveOp","onCallback","saveEnv","_component_StyleSetting","os","osInfo","clientOS","_component_FileBlock","sshKey","_component_UserTcode","onImportTCodes","importTCodes","onExportTcodes","exportTcodes","_component_HelpTcode","userTCodes","tcodes","onHandleSaveTCode","handleSaveTCode","default_env","server_ip","server_port","server_user","server_password","option","bg","fg","fontFamily","cursorStyle","cursorBlink","http_protocol","window","location","protocol","ws_protocol","ws_base_url","host","http_base_url","changeStr","str","result","i","length","_component_el_dialog","DialogVisilble","closeDialog","title","modal","draggable","_normalizeClass","setInfo","_hoisted_4","_component_el_button","size","type","showOption","_component_Switch","isForbidInput","_component_Finished","newOp","_component_Edit","_hoisted_6","disabled","placeholder","prefix","_component_HomeFilled","doCopy","_component_DocumentCopy","_hoisted_8","_component_Paperclip","_hoisted_10","_component_User","isShowPassword","_component_Lock","_component_View","_component_Hide","_hoisted_13","_toDisplayString","err_msg","confirm","_component_OptionBlock","doOption","opType","optionBlockType","$props","Object","keys","_Fragment","_renderList","value","aimOption","_component_FileIcons","name","isFolder","_component_NoData","msg","noDataMsg","_normalizeStyle","viewStyle","_renderSlot","_ctx","$slots","undefined","components","props","String","required","default","setup","computed","__exports__","FileIcons","NoData","context","trim","emit","done","OptionBlock","HomeFilled","Paperclip","User","Lock","DocumentCopy","View","Hide","Edit","Finished","Switch","verifyParams","ipRegex","test","isNaN","optionBlockRef","toClipboard","useClipboard","async","content","ElMessage","message","grouping","repeatNum","Number","MIN_SAFE_INTEGER","setTimeout","_component_el_color_picker","_component_el_dropdown","dropdown","_component_el_dropdown_menu","fontFamilyList","font","index","_component_el_dropdown_item","_component_arrow_down","fontSizeList","_hoisted_23","cursorStyleList","_hoisted_24","_hoisted_25","_hoisted_26","_hoisted_27","_component_el_switch","_hoisted_28","_hoisted_29","_hoisted_30","_hoisted_31","_hoisted_32","_hoisted_33","_hoisted_34","_hoisted_35","ArrowDown","isShowDirInput","dir","onBlur","dirInputCallback","onDblclick","doShowDirInput","doRefresh","_component_Refresh","doReturn","_component_Fold","selectedFiles","doDownload","_component_Download","dirStatus","doUpload","_component_el_upload","multiple","_component_Upload","onContextmenu","handleContextMenu","onScroll","handleScroll","onDragover","preventDefault","onDrop","handleFileDrag","tabindex","handleShortcutKeys","files","item","isDirectory","isSelected","addSelectFile","changeDir","opacity","isClipboard","isCtrlx","isShowRenameInput","renameFile","handleRename","preViewFile","loading","_component_TxtPreview","onDoSave","doSave","_component_MkFile","handleMkFile","_component_FileAttr","doRename","handleMenuSelect","_component_a_popconfirm","open","isShowMenu","isShowPop","overlayStyle","zIndex","marginLeft","okButton","handlePopConfirm","cancelButton","text","fileName","modifyTag","_component_AceEditor","onHandleChange","handleChange","onHandleSave","handleSave","langs","getSuffix","suffix","lastIndexOf","substring","langToMode","storageKey","FuncTcode","desc","execFlow","proxy","userTcodeRef","initText","_url","href","close","socket","reload","helpTcodeRef","SysTcode","connectSettingRef","styleSettingRef","fileBlockRef","getInitDir","now_connect_status","connect_status","closeFileBlock","doSSHConnect","resetTerminal","UserTcodeExecutor","active","display","outArray","cnt","variables","session","sessionStorage","getItem","JSON","setItem","local","tcodeLocalVars","localStorage","clean","arguments","removeItem","writeOnly","writeAndWait","time","this","Promise","resolve","write","read","filter","slice","readAll","hide","show","arr","ret","tmp","filterRN","filterANSI","push","split","j","stripAnsi","replace","TCodeStatusEnum","userTcodeExecutorCompleter","getCompletions","editor","pos","callback","userTcodeExecutorCompletions","meta","description","score","map","completion","caption","aceEditorRef","aceEditor","setValue","selection","clearSelection","getValue","reset","getSession","getUndoManager","setLanguage","setMode","setReadOnly","isReadOnly","backgroundColor","CtrlS","event","ctrlKey","metaKey","fromCharCode","which","toLowerCase","onMounted","ace","autoScrollEditorIntoView","copyWithEmptySelection","showPrintMargin","highlightActiveLine","enableBasicAutocompletion","enableSnippets","enableLiveAutocompletion","theme","completers","setOption","on","find","backwards","wrap","caseSensitive","wholeWord","regExp","findNext","findPrevious","addEventListener","onUnmounted","removeEventListener","AceEditor","fileUrl","codeEditorRef","resetEditor","url","$","method","dataType","dataFilter","resp","success","error","_component_el_radio_group","_component_el_radio","label","nowDir","indexOf","fileInfo","rename","fileDir","calcSize","attributes","formatDate","mtime","atime","calcPriority","permissions","date","Date","year","getFullYear","month","getMonth","day","getDate","hour","getHours","min","getMinutes","seconds","getSeconds","attrs","getType","getAttrs","fileTypeSymbols","permissionMap","symbol","permissionValue","setPermissionSymbol","attr","char","specialPermission","specialChar","noPermissionChar","sizeRaw","toFixed","sizeStr","dou","oldPath","newPath","TxtPreview","MkFile","FileAttr","Refresh","Fold","Download","Upload","lastSelectedIndex","click","shiftKey","start","Math","end","max","splice","fileClipboard","confirmDirCorrect","data","path","getDirList","now_dir","beforeSend","status","info","complete","getRemoteFileUrl","getTime","getRemoteFolderUrl","parseUrl","urlParams","indexKey","indexPath","downloadRemoteFile","a","document","createElement","body","appendChild","removeChild","downloadDir","new_dir","chunkSize","fileData","file","fileSize","chunks","parseInt","ceil","fileId","uid","chunkIndex","pathVal","startUpLoad","chunk","chunkFile","formData","FormData","append","contentType","processData","code","alert","querySelector","focus","txtPreviewRef","mkFileRef","fileAttrRef","blob","Blob","File","random","fileAreaRef","items","dataTransfer","webkitGetAsEntry","isFile","nowPath","folderUpload","directoryEntry","basePath","reader","createReader","readEntries","entries","menuBlockRef","target","top","clientY","left","clientX","e","join","watch","renameDom","contains","fileCopyMove","dst","sureDelFileBtn","userTcodeInfo","minlength","_component_CollectionTag","importTcodes","_component_EditPen","workflowTab","_component_el_tooltip","_component_DocumentDelete","CollectionTag","EditPen","DocumentDelete","workflowTemplate","userTcodeEditorRef","isAlphaNumeric","regex","fileReader","FileReader","onload","scnt","fcnt","toUpperCase","workflow","onerror","readAsText","_component_el_tabs","_component_el_tab_pane","nowTCode","toOverview","_component_ArrowLeft","_component_TcodeStatus","doModifyTCode","doOnlyRead","doSaveTCode","toWorkflow","_component_ArrowRight","myslot","statusType","statusStyle","_component_CircleCloseFilled","_component_WarningFilled","_component_SuccessFilled","_component_InfoFilled","SuccessFilled","WarningFilled","CircleCloseFilled","InfoFilled","statusTypeMap","statusColor","TcodeStatus","ArrowRight","ArrowLeft","initTcodeEditor","ConnectSetting","StyleSetting","FileBlock","UserTcode","HelpTcode","QuestionFilled","instance","getCurrentInstance","fitAddon","FitAddon","loadOps","loadTCodes","loadEnv","nowOpInfo","terminal","term","isFirst","initTerminal","Terminal","rendererType","convertEol","scrollback","disableStdin","foreground","background","cursor","lineHeight","loadAddon","termFit","innerHeight","fit","readyState","WebSocket","OPEN","new_rows","proposeDimensions","rows","new_cols","cols","send","resize","onopen","onmessage","clear","output","_core","buffer","lines","onclose","userTcodeExecutorReset","new_env","sendMessage","putChinese","doPaste","pasteText","navigator","clipboard","readText","doClick","innerHTML","onKey","onSelectionChange","hasSelection","copyText","getSelection","copyTextTrim","timer","doHeartBeat","setInterval","serverOS","windowId","setTcodeStatus","transTcode","state","Function","textflow","tCodeData","URL","createObjectURL","download","revokeObjectURL","clearInterval","FrameWork","render","xhrFields","withCredentials","app","createApp","App","use","ElButton","ElDialog","ElIcon","ElInput","ElUpload","ElColorPicker","ElTabs","ElTabPane","ElResult","ElTooltip","ElDropdown","ElDropdownMenu","ElDropdownItem","ElSwitch","ElLoading","ElRadioGroup","ElRadio","ElPopover","Popconfirm","mount","config","warnHandler","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","exports","module","loaded","__webpack_modules__","call","m","amdD","Error","deferred","O","chunkIds","fn","priority","notFulfilled","Infinity","fulfilled","every","r","n","getter","__esModule","d","definition","o","defineProperty","enumerable","get","g","globalThis","obj","prop","prototype","hasOwnProperty","Symbol","toStringTag","nmd","paths","children","p","installedChunks","chunkId","webpackJsonpCallback","parentChunkLoadingFunction","moreModules","runtime","some","chunkLoadingGlobal","self","forEach","bind","__webpack_exports__"],"sourceRoot":""}
\ No newline at end of file
diff --git a/backend/terminal/src/main/resources/static/js/app.39142009.js b/backend/terminal/src/main/resources/static/js/app.39142009.js
new file mode 100644
index 00000000..e12cee8f
--- /dev/null
+++ b/backend/terminal/src/main/resources/static/js/app.39142009.js
@@ -0,0 +1,2 @@
+(function(){var e={7883:function(e,l,t){"use strict";var a=t(7387),o=t.n(a),i=t(8082),s=t.n(i);const n="P5P1SIqVe6kaOxMX",r=e=>{var l=s().enc.Utf8.parse(n),t=s().enc.Utf8.parse(e),a=s().AES.encrypt(t,l,{mode:s().mode.ECB,padding:s().pad.Pkcs7});return a.toString()},u=e=>{var l=s().enc.Utf8.parse(n),t=s().AES.decrypt(e,l,{mode:s().mode.ECB,padding:s().pad.Pkcs7});return s().enc.Utf8.stringify(t).toString()};var d=t(9242),c=t(3396);function p(e,l,t,a,o,i){const s=(0,c.up)("FrameWork");return(0,c.wg)(),(0,c.j4)(s)}var v="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAMgAAADICAYAAACtWK6eAAAAAXNSR0IArs4c6QAAB/dJREFUeF7tnbGv5VMQx2f/yNUoNAqFQqFQSKxCoVAoFAqNQrEbghCCEIQQhCBBCBtCEIIQgrD22rPZt8l7d+/Ombn3fGc+t74z58znO5/87ktu7jtlvCAAgRMJnIINBCBwMgEEYTsgsIUAgrAeEEAQdgACPgI8QXzcqGpCAEGaBM2YPgII4uNGVRMCCNIkaMb0EUAQHzeqmhBAkCZBM6aPAIL4uFHVhACCNAmaMX0EEMTHjaomBBCkSdCM6SOAID5uVDUhgCBNgmZMHwEE8XGjqgkBBGkSNGP6CCCIjxtVTQggSJOgGdNHAEF83KhqQgBBmgTNmD4CCOLjRlUTAgjSJGjG9BHYCHLBV0oVBOoTQJD6GTPhBAEEmYBHaX0CCFI/YyacIIAgE/AorU8AQepnzIQTBBBkAh6l9QkgSP2MmXCCAIJMwKO0PgEEqZ8xE04QQJAJeJTWJ4Ag9TNmwgkCCDIBj9L6BBCkfsZMOEEAQSbgUVqfAILUz5gJJwggyAQ8SusTQJD6GTPhBAEEmYBHaX0CCFI/YyacIIAgE/AorU8AQepnzIQTBBBkAh6l9QkgSP2MmXCCAIJMwKO0PgEEqZ8xE04QQJAJeJTWJ4Ag9TNmwgkCCDIBj9L6BBCkfsZMOEEAQSbgUVqfAILUz5gJJwioC3LOzE5PzE8pBLYSUBbkETO70czOIglbnkVAVZCHzeymI1CQJGtDmvdVFOQhM7v5mNyQpPkyZ4yvJsiDZnbLFhBIkrEljXsqCfKAmd26Q1ZIsgMk3rIbARVB7jez23Yb6f93Icl1wOKtJxNQEOQ+M7vdESKSOKBRcjWB1QW518zumAgNSSbgUWq2siD3mNmdASEhSQDEri1WFeTui4GcCQwFSQJhdmq1qiCbDJCk0yYuOuvKgiDJokvT6VqrC4IknbZxwVkVBEGSBReny5VUBEGSLhu52JxKgiDJYsvT4TpqgiBJh61caEZFQZBkoQWqfhVVQZCk+mYuMp+yIEiyyBJVvoa6IEhSeTsXmK2CIEiywCJVvUIVQZCk6oYeeK5KgiDJgZep4vHVBEGSilt6wJkqCoIkB1yoakdXFQRJqm3qgeapLAiSHGipKh1bXRAkqbStB5ilgyBIcoDFqnJkF0GQpMrG7nmOToIgyZ6Xq8Jx3QRBkgpbu8cZOgqCJHtcMPWjugqCJOqbu6f7dxYESfa0ZMrHdBcESZS3dw93R5BLkPmZ0z0sm+IRCHIlNSRR3ODkOyPI1YCRJHnh1NojyJXEPjSzG8zso6AQT49/BRfUjjaHIIAgl6h/MOT4OCgE5AgCeeg2CGL2/pDjk6AwkCMI5Aptugvy3pDj06AwkCMI5CptOgvy7pDjs6AwkCMI5EptugryzpDj86AwkCMI5GptOgry9pDji6AwkCMI5Iptugny1pDjfFAYyBEEctU2nQR5c8jxZVAYyBEEcuU2XQR5Y8jxVVAYyBEEcvU2HQR5fcjxdVAYyBEEUqFNdUFeG3J8ExQGcgSBVGlTWZBXhxzfBoWBHEEgldpUFeSVIcd3QWEgRxBItTYVBXl5yPF9UBjIEQRSsU01QV4acvwQFAZyBIFUbVNJkBeHHD8GhYEcQSCV21QR5IUhx09BYSBHEEj1NhUEeX7I8XNQGMgRBLJCG3VBnhty/BIUBnIEgazSRlmQZ4ccvwaFgRxBICu1URXkmSHHb0FhIEcQyGptFAV5esjxe1AYyBEEsmIbNUGeGnL8ERQGcgSBrNpGSZAnhxx/BoWBHEEgK7dREeSJIcdfQWEgRxDI6m0UBHl8yPF3UBjIEQSyQ5vVBXlsyPFPUBgKcmwy6fa66+LAZ1YcemVBHh1y/BsETkGOzagdBdnIsZFkudeqgpwbckQBU5GjqyA8QRybvvml9Y0osy8lORBkNu3g+lWfIJfHnJVETY6ugvARa0JsrySKcnQVhI9YE4JsSq9XElU5EGRyUaLLV/+IdXTeXSVRlqOrIHzECjL7WpKoy4EgQYsS1UbpCXKtP9wryIEgUZsd1EdRkOP+JqkiB4IELXZUG1VBjkpSSQ4EidrsoD7KglyW5GwQi1Xa8FWTVZIY3/u5sNB9uArfxVpqB9SfIEvBDLoMT5AgkBFtECSCYmyPXb72vU2i4z4RKEjHt3lj94huEMgnwBMknzEnCBNAEOHwuHo+AQTJZ8wJwgQQRDg8rp5PAEHyGXOCMAEEEQ6Pq+cTQJB8xpwgTABBhMPj6vkEECSfMScIE0AQ4fC4ej4BBMlnzAnCBBBEODyunk8AQfIZc4IwAQQRDo+r5xNAkHzGnCBMAEGEw+Pq+QQQJJ8xJwgTQBDh8Lh6PgEEyWfMCcIEEEQ4PK6eTwBB8hlzgjABBBEOj6vnE0CQfMacIEwAQYTD4+r5BBAknzEnCBNAEOHwuHo+AQTJZ8wJwgQQRDg8rp5PAEHyGXOCMAEEEQ6Pq+cTQJB8xpwgTABBhMPj6vkEECSfMScIE9gIwgsCEDiBAIKwGhDYQgBBWA8IIAg7AAEfAZ4gPm5UNSGAIE2CZkwfAQTxcaOqCQEEaRI0Y/oIIIiPG1VNCCBIk6AZ00cAQXzcqGpCAEGaBM2YPgII4uNGVRMCCNIkaMb0EUAQHzeqmhBAkCZBM6aPAIL4uFHVhACCNAmaMX0EEMTHjaomBBCkSdCM6SOAID5uVDUhgCBNgmZMHwEE8XGjqgkBBGkSNGP6CCCIjxtVTQj8B1C6ZEICxVr9AAAAAElFTkSuQmCC";const m=e=>((0,c.dD)("data-v-1d051994"),e=e(),(0,c.Cn)(),e),g={class:"golbal"},f={class:"setting"},y=m((()=>(0,c._)("div",null,"连接设置",-1))),w=[y],h=m((()=>(0,c._)("div",null,"偏好设置",-1))),k=[h],_=m((()=>(0,c._)("div",null,"文件管理",-1))),x=[_],C=m((()=>(0,c._)("div",null,"重启",-1))),S=[C],b={class:"bar"},I=m((()=>(0,c._)("img",{src:v,alt:"终端",style:{height:"16px",margin:"0 7px",cursor:"pointer"}},null,-1))),D=[I],E=m((()=>(0,c._)("div",{style:{"user-select":"none","font-size":"14px"}},[(0,c._)("span",null,"kk Terminal")],-1))),T=m((()=>(0,c._)("div",{style:{flex:"1"}},null,-1))),W={key:0,style:{display:"flex","align-items":"center"}},F=m((()=>(0,c._)("div",{style:{"font-size":"12px",color:"#313131","user-select":"none"}}," TCode ",-1))),V=m((()=>(0,c._)("div",{style:{"margin-left":"7px"}},null,-1))),A={style:{cursor:"pointer","margin-left":"5px"}},z=m((()=>(0,c._)("div",{style:{"font-size":"12px",color:"#313131"}},[(0,c._)("div",{style:{"user-select":"none","font-size":"14px","font-weight":"bold"}},"什么是 TCode (终端代码) ?"),(0,c._)("div",{style:{"user-select":"none","margin-top":"5px"}},"TCode(终端代码)是用于访问和执行特定操作流程的快捷方式"),(0,c._)("div",{style:{"user-select":"none","margin-top":"5px"}},[(0,c.Uk)(" 输入 "),(0,c._)("span",{style:{"background-color":"#f3f4f4","user-select":"text"}},"/H"),(0,c.Uk)(" 并按下回车,查看帮助信息 ")]),(0,c._)("div",{style:{"user-select":"none","margin-top":"5px"}},[(0,c.Uk)(" 输入 "),(0,c._)("span",{style:{"background-color":"#f3f4f4","user-select":"text"}},"/A"),(0,c.Uk)(" 并按下回车,自定义TCode ")])],-1))),B=m((()=>(0,c._)("div",{style:{"margin-left":"20px"}},null,-1))),H={ref:"terminal",class:"terminal-class"};function U(e,l,t,a,o,i){const s=(0,c.up)("el-input"),n=(0,c.up)("QuestionFilled"),r=(0,c.up)("el-icon"),u=(0,c.up)("el-popover"),p=(0,c.up)("ConnectSetting"),v=(0,c.up)("StyleSetting"),m=(0,c.up)("FileBlock"),y=(0,c.up)("UserTcode"),h=(0,c.up)("HelpTcode");return(0,c.wg)(),(0,c.iD)(c.HY,null,[(0,c._)("div",g,[(0,c.wy)((0,c._)("div",f,[(0,c._)("div",{class:"setting-menu no-select",onClick:l[0]||(l[0]=e=>a.doSettings(1))},w),(0,c._)("div",{class:"setting-menu no-select",onClick:l[1]||(l[1]=e=>a.doSettings(2))},k),(0,c._)("div",{class:"setting-menu no-select",onClick:l[2]||(l[2]=e=>a.doSettings(4))},x),(0,c._)("div",{class:"setting-menu no-select",onClick:l[3]||(l[3]=e=>a.doSettings(3))},S)],512),[[d.F8,a.isShowSetting]]),(0,c._)("div",b,[(0,c._)("div",{style:{"user-select":"none"},onClick:l[4]||(l[4]=(...e)=>a.showSettings&&a.showSettings(...e))},D),E,T,a.env.tCode?((0,c.wg)(),(0,c.iD)("div",W,[F,V,(0,c._)("div",null,[(0,c.Wm)(s,{modelValue:a.tcode,"onUpdate:modelValue":l[5]||(l[5]=e=>a.tcode=e),id:"kkterminalTcode",ref:"tCodeInputRef",style:{width:"100px",height:"20px",fontSize:"12px"},onKeydown:(0,d.D2)(a.handleTcode,["enter"]),maxlength:"6"},null,8,["modelValue","onKeydown"])]),(0,c._)("div",A,[(0,c.Wm)(u,{placement:"bottom-end",width:220,trigger:"hover"},{reference:(0,c.w5)((()=>[(0,c.Wm)(r,{style:{color:"#606266"}},{default:(0,c.w5)((()=>[(0,c.Wm)(n)])),_:1})])),default:(0,c.w5)((()=>[z])),_:1})]),B])):(0,c.kq)("",!0)]),(0,c._)("div",H,null,512)]),(0,c.Wm)(p,{ref:"connectSettingRef",env:a.env,sshOptions:a.options,onSaveOp:a.saveOp,onCallback:a.saveEnv},null,8,["env","sshOptions","onSaveOp","onCallback"]),(0,c.Wm)(v,{ref:"styleSettingRef",env:a.env,onCallback:a.saveEnv,os:a.osInfo.clientOS},null,8,["env","onCallback","os"]),(0,c.Wm)(m,{ref:"fileBlockRef",sshKey:a.sshKey,os:a.osInfo.clientOS},null,8,["sshKey","os"]),(0,c.Wm)(y,{ref:"userTcodeRef",onImportTCodes:a.importTCodes,onExportTcodes:a.exportTcodes},null,8,["onImportTCodes","onExportTcodes"]),(0,c.Wm)(h,{ref:"helpTcodeRef",userTCodes:a.tcodes,onHandleSaveTCode:a.handleSaveTCode},null,8,["userTCodes","onHandleSaveTCode"])],64)}t(7658),t(6229),t(7330),t(2062);var O=t(7071),R=t(4870),N=t(5595),M=t(6537),j=t(7114);const Q={server_ip:"",server_port:22,server_user:"root",server_password:"",option:"",bg:"#0c0c0c",fg:"#cccccc",fontFamily:"Courier New",fontSize:16,cursorStyle:"block",cursorBlink:!0,tCode:!0};let K=window.location.protocol,P="";P="https:"==K?"wss://":"ws://";const L=P+window.location.host+"/socket/ssh/",J=K+"//"+window.location.host+"/api",G=e=>{let l="";for(let t=0;t?@[\]^`]/g,Z=e=>e.replace(q,(function(e){return"\\"+e})),Y=e=>Z(e);var X=t(7139);const $=e=>((0,c.dD)("data-v-bf2f54ee"),e=e(),(0,c.Cn)(),e),ee=$((()=>(0,c._)("div",{style:{"margin-top":"-25px"}},null,-1))),le={class:"item-class",style:{"margin-bottom":"15px"}},te=$((()=>(0,c._)("div",{class:"no-select nowrap"},"配 置:",-1))),ae=$((()=>(0,c._)("div",{style:{flex:"1"}},null,-1))),oe={class:"item-class",style:{"margin-bottom":"15px"}},ie=$((()=>(0,c._)("div",{class:"no-select"},"主机ip:",-1))),se={class:"item-class",style:{"margin-bottom":"15px"}},ne=$((()=>(0,c._)("div",{class:"no-select"},"端口号:",-1))),re={class:"item-class",style:{"margin-bottom":"15px"}},ue=$((()=>(0,c._)("div",{class:"no-select"},"用户名:",-1))),de={class:"item-class",style:{"margin-bottom":"5px"}},ce=$((()=>(0,c._)("div",{class:"no-select"},"密 码:",-1))),pe={class:"errInfo no-select"},ve=$((()=>(0,c._)("div",{style:{"margin-bottom":"5px"}},null,-1))),me={style:{display:"flex","border-top":"1px solid #f1f2f4"}},ge=$((()=>(0,c._)("div",{style:{flex:"1"}},null,-1)));function fe(e,l,t,a,o,i){const s=(0,c.up)("Switch"),n=(0,c.up)("el-icon"),r=(0,c.up)("el-button"),u=(0,c.up)("Finished"),d=(0,c.up)("Edit"),p=(0,c.up)("HomeFilled"),v=(0,c.up)("el-input"),m=(0,c.up)("DocumentCopy"),g=(0,c.up)("Paperclip"),f=(0,c.up)("User"),y=(0,c.up)("Lock"),w=(0,c.up)("View"),h=(0,c.up)("Hide"),k=(0,c.up)("el-dialog"),_=(0,c.up)("OptionBlock");return(0,c.wg)(),(0,c.iD)(c.HY,null,[(0,c.Wm)(k,{modelValue:a.DialogVisilble,"onUpdate:modelValue":l[11]||(l[11]=e=>a.DialogVisilble=e),"destory-on-close":!0,"before-close":a.closeDialog,width:360,title:"连接设置",modal:!1,"close-on-click-modal":!1,"modal-class":"kk-dialog-class","align-center":"",draggable:""},{default:(0,c.w5)((()=>[ee,(0,c._)("div",null,[(0,c._)("div",le,[te,(0,c._)("div",{class:(0,X.C_)(["ellipsis",a.setInfo.option&&a.setInfo.option.length>0?"old-option":"new-option"]),style:{"user-select":"none"}},(0,X.zw)(a.setInfo.option&&a.setInfo.option.length>0?a.setInfo.option:"新建配置"),3),ae,(0,c._)("div",null,[(0,c.Wm)(r,{size:"small",type:"primary",onClick:l[0]||(l[0]=e=>a.showOption(0)),style:{"margin-left":"10px"}},{default:(0,c.w5)((()=>[(0,c.Wm)(n,{class:"el-icon--left"},{default:(0,c.w5)((()=>[(0,c.Wm)(s)])),_:1}),(0,c.Uk)("切换")])),_:1})]),(0,c._)("div",null,[0==a.isForbidInput?((0,c.wg)(),(0,c.j4)(r,{key:0,size:"small",type:"primary",onClick:l[1]||(l[1]=e=>a.showOption(1)),style:{"margin-left":"10px"}},{default:(0,c.w5)((()=>[(0,c.Wm)(n,{class:"el-icon--left"},{default:(0,c.w5)((()=>[(0,c.Wm)(u)])),_:1}),(0,c.Uk)("保存")])),_:1})):(0,c.kq)("",!0)]),(0,c._)("div",null,[1==a.isForbidInput?((0,c.wg)(),(0,c.j4)(r,{key:0,size:"small",type:"primary",onClick:a.newOp,style:{"margin-left":"10px"}},{default:(0,c.w5)((()=>[(0,c.Wm)(n,{class:"el-icon--left"},{default:(0,c.w5)((()=>[(0,c.Wm)(d)])),_:1}),(0,c.Uk)("新建")])),_:1},8,["onClick"])):(0,c.kq)("",!0)])]),(0,c._)("div",oe,[ie,(0,c._)("div",null,[(0,c.Wm)(v,{disabled:a.isForbidInput,modelValue:a.setInfo.server_ip,"onUpdate:modelValue":l[2]||(l[2]=e=>a.setInfo.server_ip=e),class:"w-50 m-2",placeholder:"输入主机ip"},{prefix:(0,c.w5)((()=>[(0,c.Wm)(n,null,{default:(0,c.w5)((()=>[(0,c.Wm)(p)])),_:1})])),_:1},8,["disabled","modelValue"])]),(0,c._)("div",{style:{cursor:"pointer","margin-left":"10px"},onClick:l[3]||(l[3]=e=>a.doCopy(a.setInfo.server_ip))},[(0,c.Wm)(n,{size:"15"},{default:(0,c.w5)((()=>[(0,c.Wm)(m)])),_:1})])]),(0,c._)("div",se,[ne,(0,c._)("div",null,[(0,c.Wm)(v,{disabled:a.isForbidInput,modelValue:a.setInfo.server_port,"onUpdate:modelValue":l[4]||(l[4]=e=>a.setInfo.server_port=e),class:"w-50 m-2",placeholder:"输入端口号"},{prefix:(0,c.w5)((()=>[(0,c.Wm)(n,null,{default:(0,c.w5)((()=>[(0,c.Wm)(g)])),_:1})])),_:1},8,["disabled","modelValue"])]),(0,c._)("div",{style:{cursor:"pointer","margin-left":"10px"},onClick:l[5]||(l[5]=e=>a.doCopy(a.setInfo.server_port))},[(0,c.Wm)(n,{size:"15"},{default:(0,c.w5)((()=>[(0,c.Wm)(m)])),_:1})])]),(0,c._)("div",re,[ue,(0,c._)("div",null,[(0,c.Wm)(v,{disabled:a.isForbidInput,modelValue:a.setInfo.server_user,"onUpdate:modelValue":l[6]||(l[6]=e=>a.setInfo.server_user=e),class:"w-50 m-2",placeholder:"输入用户名"},{prefix:(0,c.w5)((()=>[(0,c.Wm)(n,{class:"el-input__icon"},{default:(0,c.w5)((()=>[(0,c.Wm)(f)])),_:1})])),_:1},8,["disabled","modelValue"])]),(0,c._)("div",{style:{cursor:"pointer","margin-left":"10px"},onClick:l[7]||(l[7]=e=>a.doCopy(a.setInfo.server_user))},[(0,c.Wm)(n,{size:"15"},{default:(0,c.w5)((()=>[(0,c.Wm)(m)])),_:1})])]),(0,c._)("div",de,[ce,(0,c._)("div",null,[(0,c.Wm)(v,{disabled:a.isForbidInput,modelValue:a.setInfo.server_password,"onUpdate:modelValue":l[8]||(l[8]=e=>a.setInfo.server_password=e),type:a.isShowPassword?"text":"password",class:"w-50 m-2",placeholder:"输入密码"},{prefix:(0,c.w5)((()=>[(0,c.Wm)(n,{class:"el-input__icon"},{default:(0,c.w5)((()=>[(0,c.Wm)(y)])),_:1})])),_:1},8,["disabled","modelValue","type"])]),1==a.isShowPassword?((0,c.wg)(),(0,c.iD)("div",{key:0,style:{cursor:"pointer","margin-left":"10px"},onClick:l[9]||(l[9]=e=>a.isShowPassword=!1)},[(0,c.Wm)(n,{size:"15"},{default:(0,c.w5)((()=>[(0,c.Wm)(w)])),_:1})])):((0,c.wg)(),(0,c.iD)("div",{key:1,style:{cursor:"pointer","margin-left":"10px"},onClick:l[10]||(l[10]=e=>a.isShowPassword=!0)},[(0,c.Wm)(n,{size:"15"},{default:(0,c.w5)((()=>[(0,c.Wm)(h)])),_:1})]))])]),(0,c._)("div",pe,(0,X.zw)(a.err_msg),1),ve,(0,c._)("div",me,[ge,(0,c.Wm)(r,{size:"small",type:"primary",onClick:a.confirm,style:{"margin-bottom":"-15px","margin-top":"10px"}},{default:(0,c.w5)((()=>[(0,c.Uk)(" 确定 ")])),_:1},8,["onClick"])])])),_:1},8,["modelValue","before-close"]),(0,c.Wm)(_,{ref:"optionBlockRef",onCallback:a.doOption,opType:a.optionBlockType,sshOptions:t.sshOptions},null,8,["onCallback","opType","sshOptions"])],64)}const ye=e=>((0,c.dD)("data-v-1f07a939"),e=e(),(0,c.Cn)(),e),we=ye((()=>(0,c._)("div",{style:{"margin-top":"-27px"}},null,-1))),he={class:"no-select"},ke={key:0,class:"kk-border"},_e=["onClick"],xe={class:"ellipsis",style:{margin:"0 10px"}},Ce={key:1,class:"kk-border"},Se={class:"kk-flex"},be=ye((()=>(0,c._)("div",null,"配置名:",-1))),Ie={style:{flex:"1"}},De={style:{"margin-left":"10px"}},Ee=ye((()=>(0,c._)("div",{style:{"margin-top":"-15px"}},null,-1)));function Te(e,l,t,a,o,i){const s=(0,c.up)("FileIcons"),n=(0,c.up)("NoData"),r=(0,c.up)("el-input"),u=(0,c.up)("el-button"),d=(0,c.up)("el-dialog");return(0,c.wg)(),(0,c.j4)(d,{modelValue:a.DialogVisilble,"onUpdate:modelValue":l[1]||(l[1]=e=>a.DialogVisilble=e),"before-close":a.closeDialog,"destroy-on-close":"",width:420,modal:!1,title:"全部配置","modal-class":"kk-dialog-class",draggable:""},{default:(0,c.w5)((()=>[we,(0,c._)("div",he,[Object.keys(t.sshOptions).length>0?((0,c.wg)(),(0,c.iD)("div",ke,[((0,c.wg)(!0),(0,c.iD)(c.HY,null,(0,c.Ko)(t.sshOptions,((e,l)=>((0,c.wg)(),(0,c.iD)("div",{key:l},[(0,c._)("div",{class:(0,X.C_)(["item-class",a.aimOption==l?"item-selected":""]),onClick:e=>a.aimOption=l},[(0,c.Wm)(s,{name:"kk.txt",width:"20",height:"20",isFolder:!1}),(0,c._)("div",xe,(0,X.zw)(l),1)],10,_e)])))),128))])):((0,c.wg)(),(0,c.iD)("div",Ce,[(0,c.Wm)(n,{msg:a.noDataMsg},null,8,["msg"])])),(0,c._)("div",Se,[be,(0,c._)("div",Ie,[(0,c.Wm)(r,{size:"small",modelValue:a.aimOption,"onUpdate:modelValue":l[0]||(l[0]=e=>a.aimOption=e),disabled:0==t.opType,class:"w-50 m-2",placeholder:""},null,8,["modelValue","disabled"])]),(0,c._)("div",De,[(0,c.Wm)(u,{size:"small",type:"primary",onClick:a.confirm},{default:(0,c.w5)((()=>[(0,c.Uk)((0,X.zw)(t.opType?"保存":"选择"),1)])),_:1},8,["onClick"])])])]),Ee])),_:1},8,["modelValue","before-close"])}var We=t.p+"img/no_data.ec5c928e.png";const Fe=e=>((0,c.dD)("data-v-7a3a533e"),e=e(),(0,c.Cn)(),e),Ve=Fe((()=>(0,c._)("div",null,[(0,c._)("img",{src:We,alt:"暂无数据",style:{width:"120px"}})],-1))),Ae={class:"msg"};function ze(e,l,t,a,o,i){return(0,c.wg)(),(0,c.iD)("div",{class:"no-data",style:(0,X.j5)(a.viewStyle)},[(0,c._)("div",null,[(0,c.WI)(e.$slots,"myslot",{},void 0,!0),Ve,(0,c._)("div",Ae,(0,X.zw)(t.msg),1)])],4)}var Be={name:"NoData",components:{},props:{msg:{type:String,required:!1,default:"暂无数据"},width:{type:String,required:!1},height:{type:String,required:!1}},setup(e){const l=(0,c.Fl)((()=>({width:e.width?e.width+"px":"100%",height:e.height?e.height+"px":"30vh"})));return{viewStyle:l}}},He=t(89);const Ue=(0,He.Z)(Be,[["render",ze],["__scopeId","data-v-7a3a533e"]]);var Oe=Ue,Re=t(3223),Ne=t.n(Re),Me={name:"OptionBlock",components:{FileIcons:Ne(),NoData:Oe},props:["opType","sshOptions"],setup(e,l){const t=(0,R.iH)(!1),a=(0,R.iH)(""),o=(0,R.iH)("暂无配置"),i=(0,R.iH)(""),s=()=>{""!=i.value&&""!=i.value.trim()&&(l.emit("callback",i.value.trim()),t.value=!1)},n=e=>{i.value="",e()};return{DialogVisilble:t,err_msg:a,noDataMsg:o,aimOption:i,confirm:s,closeDialog:n}}};const je=(0,He.Z)(Me,[["render",Te],["__scopeId","data-v-1f07a939"]]);var Qe=je,Ke=t(2748),Pe={name:"ConnectSetting",components:{OptionBlock:Qe,HomeFilled:Ke.Ozs,Paperclip:Ke.pkz,User:Ke.n5m,Lock:Ke.HEZ,DocumentCopy:Ke.IBc,View:Ke.G7x,Hide:Ke.caK,Edit:Ke.I8b,Finished:Ke.qWi,Switch:Ke.rsf},props:["env","sshOptions"],setup(e,l){const t=(0,R.iH)(!1),a=(0,R.iH)(""),o=(0,R.iH)({server_ip:e.env.server_ip,server_port:e.env.server_port,server_user:e.env.server_user,server_password:e.env.server_password,option:e.env.option}),i=()=>{a.value="";const e=/^(?:(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.){3}(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)$/;return e.test(o.value.server_ip)?isNaN(o.value.server_port)||o.value.server_port<0||o.value.server_port>65535?(a.value="端口号无效",!1):o.value.server_user&&""!=o.value.server_user?!(!o.value.server_password||""==o.value.server_password)||(a.value="密码不能为空",!1):(a.value="用户名不能为空",!1):(a.value="主机ip地址无效",!1)},s=(0,R.iH)(),n=(0,R.iH)(0),r=e=>{1==e&&0==i()||(n.value=e,s.value.DialogVisilble=!0,s.value.aimOption="")},u=(0,R.iH)(!1);""!=o.value.option&&(u.value=!0);const d=t=>{0==n.value?(o.value={...o.value,...e.sshOptions[t]},u.value=!0):1==n.value&&(o.value.option=t,l.emit("saveOp",t,o.value),u.value=!0)},c=()=>{u.value=!1,o.value.option=""},p=()=>{0!=i()&&(l.emit("callback",o.value),t.value=!1)},{toClipboard:v}=(0,O.Z)(),m=async e=>{e+="",e&&e.length>0?(await v(e),(0,N.z8)({message:"复制成功",type:"success",grouping:!0,repeatNum:Number.MIN_SAFE_INTEGER})):(0,N.z8)({message:"内容为空",type:"warning",grouping:!0,repeatNum:Number.MIN_SAFE_INTEGER})},g=(0,R.iH)(!1),f=l=>{s.value.DialogVisilble=!1,setTimeout((()=>{a.value="",g.value=!1,o.value={server_ip:e.env.server_ip,server_port:e.env.server_port,server_user:e.env.server_user,server_password:e.env.server_password,option:e.env.option},""!=o.value.option?u.value=!0:u.value=!1}),200),l()};return{setInfo:o,DialogVisilble:t,err_msg:a,confirm:p,optionBlockRef:s,showOption:r,optionBlockType:n,doOption:d,isForbidInput:u,newOp:c,closeDialog:f,doCopy:m,isShowPassword:g}}};const Le=(0,He.Z)(Pe,[["render",fe],["__scopeId","data-v-bf2f54ee"]]);var Je=Le;const Ge=e=>((0,c.dD)("data-v-d18bce82"),e=e(),(0,c.Cn)(),e),qe=Ge((()=>(0,c._)("div",{style:{"margin-top":"-27px"}},null,-1))),Ze={class:"no-select"},Ye={class:"item-class",style:{"margin-bottom":"15px"}},Xe=Ge((()=>(0,c._)("div",{style:{"margin-right":"10px"}},"颜色:",-1))),$e={class:"item-class"},el=Ge((()=>(0,c._)("div",null,"背景色",-1))),ll={style:{margin:"0 20px"}},tl=Ge((()=>(0,c._)("div",{style:{width:"20px"}},null,-1))),al={class:"item-class"},ol=Ge((()=>(0,c._)("div",null,"前景色",-1))),il={style:{margin:"0 20px"}},sl={class:"item-class",style:{"margin-bottom":"15px"}},nl=Ge((()=>(0,c._)("div",{style:{"margin-right":"10px"}},"文本:",-1))),rl={class:"item-class"},ul=Ge((()=>(0,c._)("div",null,"字体",-1))),dl={class:"a-link"},cl={class:"item-class"},pl=Ge((()=>(0,c._)("div",null,"字号",-1))),vl={class:"a-link"},ml={class:"item-class",style:{"margin-bottom":"5px"}},gl=Ge((()=>(0,c._)("div",{style:{"margin-right":"10px"}},"光标:",-1))),fl={class:"item-class"},yl=Ge((()=>(0,c._)("div",null,"样式",-1))),wl={class:"a-link"},hl={class:"item-class"},kl=Ge((()=>(0,c._)("div",null,"闪烁",-1))),_l={style:{margin:"0 20px"}},xl={class:"item-class",style:{"margin-bottom":"5px"}},Cl=Ge((()=>(0,c._)("div",{style:{"margin-right":"10px"}},"功能:",-1))),Sl={class:"item-class"},bl=Ge((()=>(0,c._)("div",null,"TCode",-1))),Il={style:{margin:"0 20px"}},Dl=Ge((()=>(0,c._)("div",{style:{"margin-bottom":"5px"}},null,-1))),El={style:{display:"flex","border-top":"1px solid #f1f2f4"}},Tl=Ge((()=>(0,c._)("div",{style:{flex:"1"}},null,-1)));function Wl(e,l,t,a,o,i){const s=(0,c.up)("el-color-picker"),n=(0,c.up)("arrow-down"),r=(0,c.up)("el-icon"),u=(0,c.up)("el-dropdown-item"),d=(0,c.up)("el-dropdown-menu"),p=(0,c.up)("el-dropdown"),v=(0,c.up)("el-switch"),m=(0,c.up)("el-button"),g=(0,c.up)("el-dialog");return(0,c.wg)(),(0,c.j4)(g,{modelValue:a.DialogVisilble,"onUpdate:modelValue":l[4]||(l[4]=e=>a.DialogVisilble=e),"destroy-on-close":"",width:420,title:"偏好设置",modal:!1,"modal-class":"kk-dialog-class",draggable:""},{default:(0,c.w5)((()=>[qe,(0,c._)("div",Ze,[(0,c._)("div",Ye,[Xe,(0,c._)("div",$e,[el,(0,c._)("div",ll,[(0,c.Wm)(s,{modelValue:a.setInfo.bg,"onUpdate:modelValue":l[0]||(l[0]=e=>a.setInfo.bg=e)},null,8,["modelValue"])])]),tl,(0,c._)("div",al,[ol,(0,c._)("div",il,[(0,c.Wm)(s,{modelValue:a.setInfo.fg,"onUpdate:modelValue":l[1]||(l[1]=e=>a.setInfo.fg=e)},null,8,["modelValue"])])])]),(0,c._)("div",sl,[nl,(0,c._)("div",rl,[ul,(0,c.Wm)(p,{style:{margin:"0 20px"}},{dropdown:(0,c.w5)((()=>[(0,c.Wm)(d,null,{default:(0,c.w5)((()=>[((0,c.wg)(!0),(0,c.iD)(c.HY,null,(0,c.Ko)(a.fontFamilyList,((e,l)=>((0,c.wg)(),(0,c.j4)(u,{key:l,onClick:l=>a.setInfo.fontFamily=e},{default:(0,c.w5)((()=>[(0,c.Uk)((0,X.zw)(e),1)])),_:2},1032,["onClick"])))),128))])),_:1})])),default:(0,c.w5)((()=>[(0,c._)("span",dl,[(0,c.Uk)((0,X.zw)(a.setInfo.fontFamily),1),(0,c.Wm)(r,{class:"el-icon--right"},{default:(0,c.w5)((()=>[(0,c.Wm)(n)])),_:1})])])),_:1})]),(0,c._)("div",cl,[pl,(0,c.Wm)(p,{style:{margin:"0 20px"}},{dropdown:(0,c.w5)((()=>[(0,c.Wm)(d,null,{default:(0,c.w5)((()=>[((0,c.wg)(!0),(0,c.iD)(c.HY,null,(0,c.Ko)(a.fontSizeList,((e,l)=>((0,c.wg)(),(0,c.j4)(u,{key:l,onClick:l=>a.setInfo.fontSize=e},{default:(0,c.w5)((()=>[(0,c.Uk)((0,X.zw)(e),1)])),_:2},1032,["onClick"])))),128))])),_:1})])),default:(0,c.w5)((()=>[(0,c._)("span",vl,[(0,c.Uk)((0,X.zw)(a.setInfo.fontSize),1),(0,c.Wm)(r,{class:"el-icon--right"},{default:(0,c.w5)((()=>[(0,c.Wm)(n)])),_:1})])])),_:1})])]),(0,c._)("div",ml,[gl,(0,c._)("div",fl,[yl,(0,c.Wm)(p,{style:{margin:"0 20px"}},{dropdown:(0,c.w5)((()=>[(0,c.Wm)(d,null,{default:(0,c.w5)((()=>[((0,c.wg)(!0),(0,c.iD)(c.HY,null,(0,c.Ko)(a.cursorStyleList,((e,l)=>((0,c.wg)(),(0,c.j4)(u,{key:l,onClick:l=>a.setInfo.cursorStyle=e},{default:(0,c.w5)((()=>[(0,c.Uk)((0,X.zw)(e),1)])),_:2},1032,["onClick"])))),128))])),_:1})])),default:(0,c.w5)((()=>[(0,c._)("span",wl,[(0,c.Uk)((0,X.zw)(a.setInfo.cursorStyle),1),(0,c.Wm)(r,{class:"el-icon--right"},{default:(0,c.w5)((()=>[(0,c.Wm)(n)])),_:1})])])),_:1})]),(0,c._)("div",hl,[kl,(0,c._)("div",_l,[(0,c.Wm)(v,{modelValue:a.setInfo.cursorBlink,"onUpdate:modelValue":l[2]||(l[2]=e=>a.setInfo.cursorBlink=e)},null,8,["modelValue"])])])]),(0,c._)("div",xl,[Cl,(0,c._)("div",Sl,[bl,(0,c._)("div",Il,[(0,c.Wm)(v,{modelValue:a.setInfo.tCode,"onUpdate:modelValue":l[3]||(l[3]=e=>a.setInfo.tCode=e)},null,8,["modelValue"])])])])]),Dl,(0,c._)("div",El,[Tl,(0,c.Wm)(m,{size:"small",type:"primary",onClick:a.confirm,style:{"margin-bottom":"-15px","margin-top":"10px"}},{default:(0,c.w5)((()=>[(0,c.Uk)(" 确定 ")])),_:1},8,["onClick"])])])),_:1},8,["modelValue"])}var Fl={name:"StyleSetting",components:{ArrowDown:Ke.K5e},props:["env","os"],setup(e,l){const t=(0,R.iH)(!1),a=(0,c.Fl)((()=>"Windows"==e.os?["Courier New","Consolas","Monospace","Lucida Console"]:"Mac"==e.os||"iOS"==e.os?["Courier New","Menlo","Monaco","Courier"]:["Courier New","Consolas","Monospace","Lucida Console"])),o=[12,14,16,18,20],i=["block","underline","bar"],s=(0,R.iH)({bg:e.env.bg,fg:e.env.fg,fontFamily:e.env.fontFamily,fontSize:e.env.fontSize,cursorStyle:e.env.cursorStyle,cursorBlink:e.env.cursorBlink,tCode:e.env.tCode}),n=()=>{l.emit("callback",s.value),t.value=!1};return{fontFamilyList:a,fontSizeList:o,cursorStyleList:i,setInfo:s,DialogVisilble:t,confirm:n}}};const Vl=(0,He.Z)(Fl,[["render",Wl],["__scopeId","data-v-d18bce82"]]);var Al=Vl;const zl=e=>((0,c.dD)("data-v-32fde74a"),e=e(),(0,c.Cn)(),e),Bl=zl((()=>(0,c._)("div",{style:{"margin-top":"-27px"}},null,-1))),Hl={class:"title",style:{display:"flex","align-items":"center"}},Ul={class:"ellipsis",style:{flex:"1"}},Ol={key:0},Rl={style:{display:"flex","align-items":"center"}},Nl={key:1,class:"disabled-function",style:{"margin-left":"10px","font-size":"18px",cursor:"pointer"}},Ml={key:3,class:"disabled-function",style:{"margin-left":"10px","font-size":"18px",cursor:"pointer"}},jl={key:5,class:"disabled-function",style:{"margin-left":"10px","font-size":"18px",cursor:"pointer"}},Ql={key:0},Kl=["onClick","onDblclick","onContextmenu"],Pl={key:0,style:{margin:"0 10px"}},Ll={key:1,class:"ellipsis",style:{margin:"0 10px"}},Jl=["onClick","onDblclick","onContextmenu"],Gl={key:0,style:{margin:"0 10px"}},ql={key:1,class:"ellipsis",style:{margin:"0 10px"}},Zl={key:1},Yl=zl((()=>(0,c._)("div",{style:{"margin-top":"-12px"}},null,-1))),Xl=zl((()=>(0,c._)("div",{class:"no-select",style:{"font-size":"13px","margin-top":"4px"}},"确定删除此文件/文件夹吗?",-1)));function $l(e,l,t,a,o,i){const s=(0,c.up)("el-input"),n=(0,c.up)("Refresh"),r=(0,c.up)("el-icon"),u=(0,c.up)("Fold"),p=(0,c.up)("Download"),v=(0,c.up)("Upload"),m=(0,c.up)("el-upload"),g=(0,c.up)("FileIcons"),f=(0,c.up)("NoData"),y=(0,c.up)("el-dialog"),w=(0,c.up)("TxtPreview"),h=(0,c.up)("MkFile"),k=(0,c.up)("FileAttr"),_=(0,c.up)("el-button"),x=(0,c.up)("a-popconfirm"),C=(0,c.Q2)("loading");return(0,c.wg)(),(0,c.iD)(c.HY,null,[(0,c.Wm)(y,{modelValue:a.DialogVisilble,"onUpdate:modelValue":l[26]||(l[26]=e=>a.DialogVisilble=e),"before-close":a.closeDialog,title:"文件管理",width:"50%",modal:!1,"modal-class":"kk-dialog-class",draggable:"",style:{position:"relative"}},{default:(0,c.w5)((()=>[Bl,(0,c._)("div",null,[(0,c._)("div",Hl,[(0,c._)("div",Ul,[1==a.isShowDirInput?((0,c.wg)(),(0,c.iD)("div",Ol,[(0,c.Wm)(s,{id:"aimDirInput",modelValue:a.dir,"onUpdate:modelValue":l[0]||(l[0]=e=>a.dir=e),placeholder:"输入目录路径",size:"small",onKeydown:l[1]||(l[1]=(0,d.D2)((e=>{a.isShowDirInput=!1}),["enter"])),onBlur:l[2]||(l[2]=e=>{a.isShowDirInput=!1}),onMousedown:l[3]||(l[3]=(0,d.iM)((()=>{}),["stop"])),onDblclick:l[4]||(l[4]=(0,d.iM)((()=>{}),["stop"])),onChange:a.dirInputCallback},null,8,["modelValue","onChange"])])):((0,c.wg)(),(0,c.iD)("div",{key:1,class:"no-select ellipsis",onDblclick:l[5]||(l[5]=(...e)=>a.doShowDirInput&&a.doShowDirInput(...e))},(0,X.zw)(a.dir),33))]),(0,c._)("div",Rl,[(0,c._)("div",{class:"hover-class",onClick:l[6]||(l[6]=(...e)=>a.doRefresh&&a.doRefresh(...e)),style:{"margin-left":"10px","font-size":"18px",cursor:"pointer"}},[(0,c.Wm)(r,null,{default:(0,c.w5)((()=>[(0,c.Wm)(n)])),_:1})]),a.dir&&"/"!=a.dir?((0,c.wg)(),(0,c.iD)("div",{key:0,class:"hover-class",onClick:l[7]||(l[7]=(...e)=>a.doReturn&&a.doReturn(...e)),style:{"margin-left":"10px","font-size":"18px",cursor:"pointer"}},[(0,c.Wm)(r,null,{default:(0,c.w5)((()=>[(0,c.Wm)(u)])),_:1})])):((0,c.wg)(),(0,c.iD)("div",Nl,[(0,c.Wm)(r,null,{default:(0,c.w5)((()=>[(0,c.Wm)(u)])),_:1})])),1==a.selectedFiles.length?((0,c.wg)(),(0,c.iD)("div",{key:2,class:"hover-class",onClick:l[8]||(l[8]=(...e)=>a.doDownload&&a.doDownload(...e)),style:{"margin-left":"10px","font-size":"18px",cursor:"pointer"}},[(0,c.Wm)(r,null,{default:(0,c.w5)((()=>[(0,c.Wm)(p)])),_:1})])):((0,c.wg)(),(0,c.iD)("div",Ml,[(0,c.Wm)(r,null,{default:(0,c.w5)((()=>[(0,c.Wm)(p)])),_:1})])),0==a.dirStatus?((0,c.wg)(),(0,c.iD)("div",{key:4,class:"hover-class",onClick:l[9]||(l[9]=(...e)=>a.doUpload&&a.doUpload(...e)),style:{"margin-left":"10px","font-size":"18px",cursor:"pointer"}},[(0,c.Wm)(m,{"show-file-list":!1,"with-credentials":!0,"http-request":a.doUpload,multiple:!0},{default:(0,c.w5)((()=>[(0,c.Wm)(r,null,{default:(0,c.w5)((()=>[(0,c.Wm)(v)])),_:1})])),_:1},8,["http-request"])])):((0,c.wg)(),(0,c.iD)("div",jl,[(0,c.Wm)(r,null,{default:(0,c.w5)((()=>[(0,c.Wm)(v)])),_:1})]))])]),(0,c.wy)(((0,c.wg)(),(0,c.iD)("div",{id:"fileArea",ref:"fileAreaRef","element-loading-text":"Loading...",class:"list-class no-select",onContextmenu:l[21]||(l[21]=(...e)=>a.handleContextMenu&&a.handleContextMenu(...e)),onScroll:l[22]||(l[22]=(...e)=>a.handleScroll&&a.handleScroll(...e)),onDragover:l[23]||(l[23]=(...e)=>a.preventDefault&&a.preventDefault(...e)),onDrop:l[24]||(l[24]=(...e)=>a.handleFileDrag&&a.handleFileDrag(...e)),tabindex:"0",onKeydown:l[25]||(l[25]=(...e)=>a.handleShortcutKeys&&a.handleShortcutKeys(...e))},[0!=a.files.length?((0,c.wg)(),(0,c.iD)("div",Ql,[((0,c.wg)(!0),(0,c.iD)(c.HY,null,(0,c.Ko)(a.files,(e=>((0,c.wg)(),(0,c.iD)("div",{key:e.id},[1==e.isDirectory?((0,c.wg)(),(0,c.iD)("div",{key:0,class:(0,X.C_)([-1!=a.isSelected(e.id)?"item-selected":"","item-class"]),onClick:l=>a.addSelectFile(l,e),onDblclick:l=>a.changeDir(a.dir+e.name+"/"),onContextmenu:l=>a.addSelectFile(l,e,!1)},[(0,c.Wm)(g,{style:(0,X.j5)({opacity:-1!=a.isClipboard(e.id)&&a.isCtrlx?.5:1}),name:e.name,width:"20",height:"20",isFolder:e.isDirectory},null,8,["style","name","isFolder"]),1==a.isShowRenameInput&&a.renameFile&&e.id==a.renameFile.id?((0,c.wg)(),(0,c.iD)("div",Pl,[(0,c.Wm)(s,{id:"rename",modelValue:a.renameFile.name,"onUpdate:modelValue":l[10]||(l[10]=e=>a.renameFile.name=e),placeholder:"",size:"small",onKeydown:l[11]||(l[11]=(0,d.D2)((e=>{a.isShowRenameInput=!1}),["enter"])),onBlur:l[12]||(l[12]=e=>{a.isShowRenameInput=!1}),onMousedown:l[13]||(l[13]=(0,d.iM)((()=>{}),["stop"])),onDblclick:l[14]||(l[14]=(0,d.iM)((()=>{}),["stop"])),onChange:l=>a.handleRename(e)},null,8,["modelValue","onChange"])])):((0,c.wg)(),(0,c.iD)("div",Ll,(0,X.zw)(e.name),1))],42,Kl)):((0,c.wg)(),(0,c.iD)("div",{key:1,class:(0,X.C_)([-1!=a.isSelected(e.id)?"item-selected":"","item-class"]),onClick:l=>a.addSelectFile(l,e),onDblclick:l=>a.preViewFile(e.name),onContextmenu:l=>a.addSelectFile(l,e,!1)},[(0,c.Wm)(g,{style:(0,X.j5)({opacity:-1!=a.isClipboard(e.id)&&a.isCtrlx?.5:1}),name:e.name,width:"20",height:"20",isFolder:e.isDirectory},null,8,["style","name","isFolder"]),1==a.isShowRenameInput&&a.renameFile&&e.id==a.renameFile.id?((0,c.wg)(),(0,c.iD)("div",Gl,[(0,c.Wm)(s,{id:"rename",modelValue:a.renameFile.name,"onUpdate:modelValue":l[15]||(l[15]=e=>a.renameFile.name=e),placeholder:"",size:"small",onKeydown:l[16]||(l[16]=(0,d.D2)((e=>{a.isShowRenameInput=!1}),["enter"])),onBlur:l[17]||(l[17]=e=>{a.isShowRenameInput=!1}),onMousedown:l[18]||(l[18]=(0,d.iM)((()=>{}),["stop"])),onDblclick:l[19]||(l[19]=(0,d.iM)((()=>{}),["stop"])),onChange:l=>a.handleRename(e)},null,8,["modelValue","onChange"])])):((0,c.wg)(),(0,c.iD)("div",ql,(0,X.zw)(e.name),1))],42,Jl))])))),128))])):((0,c.wg)(),(0,c.iD)("div",Zl,[0==a.loading?((0,c.wg)(),(0,c.j4)(f,{key:0,onContextmenu:l[20]||(l[20]=e=>a.selectedFiles=[]),msg:a.noDataMsg},null,8,["msg"])):(0,c.kq)("",!0)]))],32)),[[C,a.loading]])]),Yl])),_:1},8,["modelValue","before-close"]),(0,c.Wm)(w,{ref:"txtPreviewRef",onDoSave:a.doSave},null,8,["onDoSave"]),(0,c.Wm)(h,{ref:"mkFileRef",onCallback:a.handleMkFile},null,8,["onCallback"]),(0,c.Wm)(k,{ref:"fileAttrRef",onCallback:a.doRename},null,8,["onCallback"]),(0,c.wy)((0,c._)("div",{ref:"menuBlockRef",onContextmenu:l[35]||(l[35]=(...e)=>a.preventDefault&&a.preventDefault(...e)),class:"kk-menu no-select"},[(0,c._)("div",{style:{"border-bottom":"1px solid #ddd"},class:"kk-menu-item",onClick:l[27]||(l[27]=e=>a.handleMenuSelect(1)),key:"1"},"刷新"),(0,c._)("div",{class:(0,X.C_)(["kk-menu-item",1!=a.selectedFiles.length?"disabled":""]),onClick:l[28]||(l[28]=e=>a.handleMenuSelect(2)),key:"2"},"打开",2),(0,c._)("div",{style:{"border-bottom":"1px solid #ddd"},class:(0,X.C_)(["kk-menu-item",a.selectedFiles.length>1?"disabled":""]),onClick:l[29]||(l[29]=e=>a.handleMenuSelect(3)),key:"3"},"复制路径",2),(0,c._)("div",{class:(0,X.C_)(["kk-menu-item",1!=a.selectedFiles.length?"disabled":""]),onClick:l[30]||(l[30]=e=>a.handleMenuSelect(4)),key:"4"},"下载",2),(0,c._)("div",{class:(0,X.C_)(["kk-menu-item",1==a.dirStatus?"disabled":""]),onClick:l[31]||(l[31]=e=>a.handleMenuSelect(5)),key:"5"},"新建",2),(0,c._)("div",{class:(0,X.C_)(["kk-menu-item",1!=a.selectedFiles.length?"disabled":""]),onClick:l[32]||(l[32]=e=>a.handleMenuSelect(6)),key:"6"},"重命名",2),(0,c.Wm)(x,{open:a.isShowMenu&&a.isShowPop,overlayStyle:{zIndex:3466,marginLeft:"10px"},placement:"rightBottom","ok-text":"确定","cancel-text":"取消"},{title:(0,c.w5)((()=>[Xl])),okButton:(0,c.w5)((()=>[(0,c.Wm)(_,{id:"sureDelFileBtn",size:"small",type:"primary",onClick:a.handlePopConfirm},{default:(0,c.w5)((()=>[(0,c.Uk)("确定")])),_:1},8,["onClick"])])),cancelButton:(0,c.w5)((()=>[(0,c.Wm)(_,{size:"small",text:""},{default:(0,c.w5)((()=>[(0,c.Uk)("取消")])),_:1})])),default:(0,c.w5)((()=>[(0,c._)("div",{class:(0,X.C_)(["kk-menu-item",0==a.selectedFiles.length?"disabled":""]),key:"7"},[(0,c._)("div",{onClick:l[33]||(l[33]=e=>a.handleMenuSelect(7))},"删除")],2)])),_:1},8,["open"]),(0,c._)("div",{style:{"border-top":"1px solid #ddd"},class:(0,X.C_)(["kk-menu-item",1!=a.selectedFiles.length?"disabled":""]),onClick:l[34]||(l[34]=e=>a.handleMenuSelect(8)),key:"8"},"属性",2)],544),[[d.F8,a.isShowMenu]])],64)}const et=e=>((0,c.dD)("data-v-d5692da0"),e=e(),(0,c.Cn)(),e),lt={class:"kk-flex"},tt={class:"ellipsis",style:{margin:"0 5px","font-size":"larger"}},at=et((()=>(0,c._)("div",{style:{"margin-top":"-28px"}},null,-1))),ot={"element-loading-text":"Loading...",style:{padding:"0px 5px",width:"100%",height:"60vh"}},it=et((()=>(0,c._)("div",{style:{"margin-top":"-13px"}},null,-1)));function st(e,l,t,a,o,i){const s=(0,c.up)("FileIcons"),n=(0,c.up)("AceEditor"),r=(0,c.up)("el-dialog"),u=(0,c.Q2)("loading");return(0,c.wg)(),(0,c.j4)(r,{modelValue:a.DialogVisilble,"onUpdate:modelValue":l[0]||(l[0]=e=>a.DialogVisilble=e),width:"80%",modal:!1,"modal-class":"kk-dialog-class","before-close":a.closeDialog,"align-center":"",draggable:""},{title:(0,c.w5)((()=>[(0,c._)("div",lt,[(0,c.Wm)(s,{name:a.fileName,width:"25",height:"25",isFolder:!1},null,8,["name"]),(0,c._)("div",tt,(0,X.zw)(a.modifyTag+a.fileName),1)])])),default:(0,c.w5)((()=>[at,(0,c.wy)(((0,c.wg)(),(0,c.iD)("div",ot,[(0,c.Wm)(n,{ref:"codeEditorRef",onHandleChange:a.handleChange,onHandleSave:a.handleSave},null,8,["onHandleChange","onHandleSave"])])),[[u,a.loading]]),it])),_:1},8,["modelValue","before-close"])}const nt={ref:"aceEditorRef",class:"kk-code-editor"};function rt(e,l,t,a,o,i){return(0,c.wg)(),(0,c.iD)("div",nt,null,512)}var ut=t(17),dt=t.n(ut);t(7050),t(4783),t(2428),t(516),t(6684),t(350),t(8930),t(9986),t(3669),t(629),t(5045),t(1564),t(6668),t(1838),t(9375),t(2606),t(1948),t(4070),t(1853),t(6347),t(4840),t(498),t(9394),t(4733),t(7366),t(5293),t(6529),t(6895),t(8918),t(1910),t(5955),t(2376),t(8633),t(1710),t(1067),t(2841),t(1122),t(366),t(5824),t(7682),t(7535);const ct={c:"c_cpp",h:"c_cpp",cpp:"c_cpp",hpp:"c_cpp",cs:"csharp",css:"css",gitignore:"gitignore",go:"golang",html:"html",htm:"html",java:"java",js:"javascript",jsx:"javascript",json:"json",jsp:"jsp",md:"markdown",markdown:"markdown",properties:"properties",py:"python",sh:"sh",bash:"sh",sql:"sql",ts:"typescript",tsx:"typescript",vue:"javascript",xml:"xml",xsd:"xml",xsl:"xml",xslt:"xml",yaml:"yaml",yml:"yaml"},pt=e=>{let l="txt";if(e&&e.length>0){let t=e.lastIndexOf(".");-1!=t&&(l=e.substring(t+1))}return l},vt=e=>ct[pt(e)]||"text";var mt=vt,gt=t(18);const ft="tcode-local-vars",yt="tcode-session-vars-",wt={"/A":{desc:"自定义TCode",execFlow(e){setTimeout((()=>{e.proxy.userTcodeRef.initText()}),1),e.proxy.userTcodeRef.DialogVisilble=!0}},"/O":{desc:"新建窗口",execFlow(){let e=window.location.href;window.open(e,"_blank")}},"/C":{desc:"关闭窗口",execFlow(){window.close()}},"/E":{desc:"退出登录",execFlow(e){e.proxy.socket&&e.proxy.socket.close(3131)}},"/R":{desc:"刷新页面",execFlow(){window.location.reload()}},"/H":{desc:"帮助",execFlow(e){e.proxy.helpTcodeRef.DialogVisilble=!0}}},ht={SC:{desc:"连接设置",execFlow(e){e.proxy.isShowSetting=!1,e.proxy.connectSettingRef.DialogVisilble=!0}},SP:{desc:"偏好设置",execFlow(e){e.proxy.isShowSetting=!1,e.proxy.styleSettingRef.DialogVisilble=!0}},SF:{desc:"文件管理",execFlow(e){e.proxy.isShowSetting=!1,e.proxy.fileBlockRef.DialogVisilble=!0,e.proxy.fileBlockRef.getInitDir()}},SS:{desc:"重启",execFlow(e){e.proxy.isShowSetting=!1,e.proxy.now_connect_status=e.proxy.connect_status["Connecting"],e.proxy.sshKey="",e.proxy.socket&&e.proxy.socket.close(3333),e.proxy.closeFileBlock(),e.proxy.doSSHConnect(),e.proxy.resetTerminal()}}},kt={active:!1,display:!0,outArray:[],cnt:0,variables:{session(e,l){if(void 0==l)return sessionStorage.getItem(yt+e)?JSON.parse(sessionStorage.getItem(yt+e)):null;sessionStorage.setItem(yt+e,JSON.stringify(l))},local(e,l){let t={};if(localStorage.getItem(ft)&&(t=JSON.parse(u(localStorage.getItem(ft)))),void 0==l)return t[e];t[e]=l,localStorage.setItem(ft,r(JSON.stringify(t)))},clean(){if(0==arguments.length)return void localStorage.removeItem(ft);let e={};localStorage.getItem(ft)&&(e=JSON.parse(u(localStorage.getItem(ft))));for(let l=0;l0&&"\n"!=e[e.length-1]&&"\r"!=e[e.length-1]&&(e+="\n"),this.cnt=this.outArray.length,this.writeOnly(e,!0),await new Promise((e=>setTimeout(e,l>0?l:0)))},write(e,l=200){return this.writeAndWait(e,l)},read(){return _t(this.outArray.slice(this.cnt))},readAll(){return _t(this.outArray.slice(0))},hide(){this.display=!1},show(){this.display=!0}},_t=e=>{let l=[],t=xt(e);for(let a=0;a{let l=[];for(let t=0;t(0,gt.Z)(e).replace(/[\x00-\x1F\x7F]/g,""),St={"Load Error":"Error","Execute Error":"Interrupted","Not Active":"Inactive","Execute Success":"Success"},bt={getCompletions:function(e,l,t,a,o){const i=[{name:"kkTerminal",value:"kkTerminal",meta:"kkTerminal",description:"kkTerminal API",score:1e3},{name:"variables",value:"variables",meta:"kkTerminal",description:"access variables",score:1e3},{name:"session",value:"session()",meta:"kkTerminal",description:"get or set session variables",score:1e3},{name:"local",value:"local()",meta:"kkTerminal",description:"get or set local variables",score:1e3},{name:"clean",value:"clean()",meta:"kkTerminal",description:"remove local variables",score:1e3},{name:"write",value:"write()",meta:"kkTerminal",description:"write to terminal",score:1e3},{name:"read",value:"read()",meta:"kkTerminal",description:"read lastest from terminal",score:1e3},{name:"readAll",value:"readAll()",meta:"kkTerminal",description:"read all from terminal",score:1e3},{name:"hide",value:"hide()",meta:"kkTerminal",description:"hide TCode display",score:1e3},{name:"show",value:"show()",meta:"kkTerminal",description:"show TCode display",score:1e3}];o(null,i.map((e=>({caption:e.caption||e.name,value:e.value,meta:e.meta,description:e.description||""}))))}};var It={name:"AceEditor",setup(e,l){const t=(0,R.iH)(),a=(0,R.iH)(null),o=e=>{a.value&&a.value.setValue(e),a.value&&a.value.selection.clearSelection()},i=()=>a.value?a.value.getValue():"",s=()=>{a.value&&a.value.getSession().getUndoManager().reset()},n=e=>{a.value&&a.value.getSession().setMode(`ace/mode/${mt(e)}`)},r=e=>{if(a.value){a.value.setReadOnly(e);const l=e?"#f0f0f0":"";t.value.style.backgroundColor=l}},u=e=>{if(e.ctrlKey||e.metaKey)switch(String.fromCharCode(e.which).toLowerCase()){case"s":e.preventDefault(),l.emit("handleSave",a.value.getValue());break}};return(0,c.bv)((()=>{a.value=dt().edit(t.value,{autoScrollEditorIntoView:!1,copyWithEmptySelection:!1,showPrintMargin:!1,highlightActiveLine:!0,enableBasicAutocompletion:!0,enableSnippets:!0,enableLiveAutocompletion:!0,theme:"ace/theme/chrome",mode:"ace/mode/text"}),a.value.completers.push(bt),a.value.session.setOption("useWorker",!1),a.value.on("change",(()=>{l.emit("handleChange")})),a.value.find("needle",{backwards:!1,wrap:!1,caseSensitive:!1,wholeWord:!1,regExp:!1}),a.value.findNext(),a.value.findPrevious(),t.value.addEventListener("keydown",u)})),(0,c.Ah)((()=>{t.value&&t.value.removeEventListener("keydown",u)})),{aceEditorRef:t,aceEditor:a,setValue:o,reset:s,setLanguage:n,getValue:i,setReadOnly:r}}};const Dt=(0,He.Z)(It,[["render",rt],["__scopeId","data-v-980ea70c"]]);var Et=Dt,Tt={name:"TxtPreview",components:{AceEditor:Et,FileIcons:Ne()},setup(e,l){const t=(0,R.iH)(!1),a=(0,R.iH)(!1),i=(0,R.iH)(""),s=(0,R.iH)(""),n=(0,R.iH)(""),r=(0,R.iH)(),u=async()=>{p(),a.value=!0;let e=n.value;await o().ajax({url:e,method:"GET",dataType:"text",dataFilter(e){return e},success(l){e==n.value&&(r.value.setValue(l),r.value.reset(),r.value.setLanguage(s.value),i.value="",a.value=!1)},error(){e==n.value&&((0,N.z8)({message:"文件加载失败",type:"error",grouping:!0}),p(),t.value=!1)}})},d=()=>{i.value="*"},c=e=>{"*"==i.value&&(l.emit("doSave",s.value,n.value,e),i.value="")},p=()=>{r.value&&(r.value.setValue(""),r.value.reset()),i.value=""},v=e=>{setTimeout((()=>{p()}),200),e()};return{DialogVisilble:t,initText:u,loading:a,fileName:s,fileUrl:n,codeEditorRef:r,modifyTag:i,handleChange:d,handleSave:c,closeDialog:v,resetEditor:p}}};const Wt=(0,He.Z)(Tt,[["render",st],["__scopeId","data-v-d5692da0"]]);var Ft=Wt;const Vt=e=>((0,c.dD)("data-v-cb2a471c"),e=e(),(0,c.Cn)(),e),At=Vt((()=>(0,c._)("div",{style:{"margin-top":"-32px"}},null,-1))),zt={class:"no-select"},Bt={class:"errInfo no-select"},Ht={class:"kk-flex"},Ut=Vt((()=>(0,c._)("div",{style:{width:"10px"}},null,-1))),Ot={style:{flex:"1"}},Rt={style:{"margin-left":"10px"}},Nt=Vt((()=>(0,c._)("div",{style:{"margin-top":"-10px"}},null,-1)));function Mt(e,l,t,a,o,i){const s=(0,c.up)("el-radio"),n=(0,c.up)("el-radio-group"),r=(0,c.up)("FileIcons"),u=(0,c.up)("el-input"),d=(0,c.up)("el-button"),p=(0,c.up)("el-dialog");return(0,c.wg)(),(0,c.j4)(p,{modelValue:a.DialogVisilble,"onUpdate:modelValue":l[2]||(l[2]=e=>a.DialogVisilble=e),"before-close":a.closeDialog,width:300,modal:!1,title:"新建","modal-class":"kk-dialog-class",draggable:""},{default:(0,c.w5)((()=>[At,(0,c._)("div",zt,[(0,c.Wm)(n,{modelValue:a.isDirectory,"onUpdate:modelValue":l[0]||(l[0]=e=>a.isDirectory=e),class:"ml-4"},{default:(0,c.w5)((()=>[(0,c.Wm)(s,{label:!1,size:"large"},{default:(0,c.w5)((()=>[(0,c.Uk)("文件")])),_:1}),(0,c.Wm)(s,{label:!0,size:"large"},{default:(0,c.w5)((()=>[(0,c.Uk)("文件夹")])),_:1})])),_:1},8,["modelValue"]),(0,c._)("div",Bt,(0,X.zw)(a.err_msg),1),(0,c._)("div",Ht,[(0,c._)("div",null,[1==a.isDirectory?((0,c.wg)(),(0,c.j4)(r,{key:0,width:"24",height:"24",name:"kk.txt",isFolder:!0})):((0,c.wg)(),(0,c.j4)(r,{key:1,width:"24",height:"24",name:"kk.txt",isFolder:!1}))]),Ut,(0,c._)("div",Ot,[(0,c.Wm)(u,{size:"small",modelValue:a.name,"onUpdate:modelValue":l[1]||(l[1]=e=>a.name=e),class:"w-50 m-2",placeholder:""},null,8,["modelValue"])]),(0,c._)("div",Rt,[(0,c.Wm)(d,{size:"small",type:"primary",onClick:a.confirm},{default:(0,c.w5)((()=>[(0,c.Uk)("确定")])),_:1},8,["onClick"])])])]),Nt])),_:1},8,["modelValue","before-close"])}var jt={name:"MkFile",components:{FileIcons:Ne()},setup(e,l){const t=(0,R.iH)(!1),a=(0,R.iH)(""),o=(0,R.iH)(!1),i=(0,R.iH)(""),s=(0,R.iH)(""),n=()=>{a.value="",i.value&&i.value.trim().length>0?-1==i.value.indexOf("/")?(l.emit("callback",o.value,i.value,s.value),u()):a.value="文件名不能含有 /":a.value="文件名不能为空"},r=e=>{setTimeout((()=>{u()}),200),e()},u=()=>{a.value="",o.value=!1,i.value="",s.value="",t.value=!1};return{DialogVisilble:t,err_msg:a,isDirectory:o,name:i,nowDir:s,confirm:n,closeDialog:r,reset:u}}};const Qt=(0,He.Z)(jt,[["render",Mt],["__scopeId","data-v-cb2a471c"]]);var Kt=Qt;const Pt=e=>((0,c.dD)("data-v-2c6df403"),e=e(),(0,c.Cn)(),e),Lt=Pt((()=>(0,c._)("div",{style:{"margin-top":"-15px"}},null,-1))),Jt={class:"kk-flex nowrap"},Gt={class:"ellipsis",style:{margin:"0 5px","font-size":"small"}},qt=Pt((()=>(0,c._)("div",{style:{"font-size":"small"}},"属性",-1))),Zt=Pt((()=>(0,c._)("div",{style:{"margin-top":"-32px"}},null,-1))),Yt={"element-loading-text":"Loading..."},Xt={class:"kk-flex"},$t={style:{"margin-right":"10px"}},ea=Pt((()=>(0,c._)("div",{class:"kk-border"},null,-1))),la={class:"kk-flex nowrap"},ta=Pt((()=>(0,c._)("div",{class:"no-select",style:{"text-align":"left",width:"100px"}},"位置:",-1))),aa={class:"ellipsis"},oa={key:0,class:"kk-flex"},ia=Pt((()=>(0,c._)("div",{class:"no-select",style:{"text-align":"left",width:"100px"}},"包含:",-1))),sa={key:0,style:{"margin-left":"10px"}},na={key:1,class:"kk-flex"},ra=Pt((()=>(0,c._)("div",{class:"no-select",style:{"text-align":"left",width:"100px"}},"大小:",-1))),ua={key:0,style:{"margin-left":"10px"}},da=Pt((()=>(0,c._)("div",{class:"kk-border"},null,-1))),ca={class:"kk-flex"},pa=Pt((()=>(0,c._)("div",{class:"no-select",style:{"text-align":"left",width:"100px"}},"修改时间:",-1))),va={class:"kk-flex"},ma=Pt((()=>(0,c._)("div",{class:"no-select",style:{"text-align":"left",width:"100px"}},"访问时间:",-1))),ga=Pt((()=>(0,c._)("div",{class:"kk-border"},null,-1))),fa={class:"kk-flex"},ya=Pt((()=>(0,c._)("div",{class:"no-select",style:{"text-align":"left",width:"100px"}},"权限:",-1))),wa=Pt((()=>(0,c._)("div",{style:{flex:"1"}},null,-1))),ha=Pt((()=>(0,c._)("div",{style:{"margin-top":"-15px"}},null,-1)));function ka(e,l,t,a,o,i){const s=(0,c.up)("FileIcons"),n=(0,c.up)("el-input"),r=(0,c.up)("DocumentCopy"),u=(0,c.up)("el-icon"),d=(0,c.up)("el-tag"),p=(0,c.up)("el-button"),v=(0,c.up)("el-dialog"),m=(0,c.Q2)("loading");return(0,c.wg)(),(0,c.j4)(v,{modelValue:a.DialogVisilble,"onUpdate:modelValue":l[2]||(l[2]=e=>a.DialogVisilble=e),"before-close":a.closeDialog,width:400,modal:!1,"modal-class":"kk-dialog-class","align-center":"",draggable:""},{title:(0,c.w5)((()=>[Lt,(0,c._)("div",Jt,[(0,c.Wm)(s,{name:a.fileInfo.name,width:"16",height:"16",isFolder:a.fileInfo.isDirectory},null,8,["name","isFolder"]),(0,c._)("div",Gt,(0,X.zw)(a.fileInfo.name),1),qt])])),default:(0,c.w5)((()=>[Zt,(0,c.wy)(((0,c.wg)(),(0,c.iD)("div",Yt,[(0,c._)("div",Xt,[(0,c._)("div",$t,[(0,c.Wm)(s,{name:a.fileInfo.name,width:"32",height:"32",isFolder:a.fileInfo.isDirectory},null,8,["name","isFolder"])]),(0,c._)("div",null,[(0,c.Wm)(n,{modelValue:a.rename,"onUpdate:modelValue":l[0]||(l[0]=e=>a.rename=e),placeholder:""},null,8,["modelValue"])])]),ea,(0,c._)("div",la,[ta,(0,c._)("div",aa,(0,X.zw)(a.fileDir+a.fileInfo.name),1),(0,c._)("div",{style:{cursor:"pointer","margin-left":"5px"},onClick:l[1]||(l[1]=e=>a.doCopy(a.fileDir+a.fileInfo.name))},[(0,c.Wm)(u,{size:"15"},{default:(0,c.w5)((()=>[(0,c.Wm)(r)])),_:1})])]),a.fileInfo.isDirectory?((0,c.wg)(),(0,c.iD)("div",oa,[ia,(0,c._)("div",null,(0,X.zw)(a.includeInfo),1),a.unreliable?((0,c.wg)(),(0,c.iD)("div",sa,[(0,c.Wm)(d,{size:"small",type:"danger"},{default:(0,c.w5)((()=>[(0,c.Uk)("unsure")])),_:1})])):(0,c.kq)("",!0)])):((0,c.wg)(),(0,c.iD)("div",na,[ra,(0,c._)("div",null,(0,X.zw)(a.calcSize(a.fileInfo.attributes.size))+" ("+(0,X.zw)(a.fileInfo.attributes.size+" 字节")+") ",1),a.unreliable?((0,c.wg)(),(0,c.iD)("div",ua,[(0,c.Wm)(d,{size:"small",type:"danger"},{default:(0,c.w5)((()=>[(0,c.Uk)("unsure")])),_:1})])):(0,c.kq)("",!0)])),da,(0,c._)("div",ca,[pa,(0,c._)("div",null,(0,X.zw)(a.formatDate(a.fileInfo.attributes.mtime)),1)]),(0,c._)("div",va,[ma,(0,c._)("div",null,(0,X.zw)(a.formatDate(a.fileInfo.attributes.atime)),1)]),ga,(0,c._)("div",fa,[ya,(0,c._)("div",null,(0,X.zw)(a.calcPriority(a.fileInfo.attributes.mode.type,a.fileInfo.attributes.permissions)),1),wa,(0,c._)("div",null,[(0,c.Wm)(p,{size:"small",type:"primary",onClick:a.confirm},{default:(0,c.w5)((()=>[(0,c.Uk)("确定")])),_:1},8,["onClick"])])])])),[[m,a.loading]]),ha])),_:1},8,["modelValue","before-close"])}const _a=e=>{if(!e)return"";let l=new Date(1e3*e),t=l.getFullYear(),a=l.getMonth()+1,o=l.getDate(),i=l.getHours(),s=l.getMinutes(),n=l.getSeconds();return a<10&&(a="0"+a),o<10&&(o="0"+o),i<10&&(i="0"+i),s<10&&(s="0"+s),n<10&&(n="0"+n),t+"年"+a+"月"+o+"日,"+i+":"+s+":"+n},xa=(e,l)=>Sa(e)+Ia(l),Ca={BLOCK_SPECIAL:"b",CHAR_SPECIAL:"c",FIFO_SPECIAL:"p",SOCKET_SPECIAL:"s",REGULAR:"-",DIRECTORY:"d",SYMLINK:"l",UNKNOWN:"?"},Sa=e=>Ca[e],ba={USR_R:256,USR_W:128,USR_X:64,GRP_R:32,GRP_W:16,GRP_X:8,OTH_R:4,OTH_W:2,OTH_X:1,SUID:2048,SGID:1024,STICKY:512},Ia=e=>{let l="---------",t=0;for(let a=0;a(e=o?e.substring(0,l)+(t?i:s)+e.substring(l+1):e.substring(0,l)+(t?a:e[l])+e.substring(l+1),e),Ea=e=>{if(null==e||void 0==e)return"";let l="";l=e<1024?e.toFixed(2)+" B":e<1048576?(e/1024).toFixed(2)+" KB":e<1073741824?(e/1048576).toFixed(2)+" MB":(e/1073741824).toFixed(2)+" GB";let t=l+"",a=t.indexOf("."),o=t.substring(a+1,a+3);return"00"==o?t.substring(0,a)+t.substring(a+3):l};var Ta={name:"FileAttr",components:{FileIcons:Ne(),DocumentCopy:Ke.IBc},setup(e,l){const{toClipboard:t}=(0,O.Z)(),a=(0,R.iH)(!1),i=(0,R.iH)({}),s=(0,R.iH)(""),n=(0,R.iH)(""),r=(0,R.iH)(!0),u=(0,R.iH)(!1),d=(0,R.iH)("0 个文件,0 个文件夹"),c=e=>{o().ajax({url:J+"/du",type:"get",data:{time:(new Date).getTime(),sshKey:e,path:Z(s.value),item:Y(i.value.name)},beforeSend:function(){r.value=!0},success(e){"success"==e.status?i.value.attributes.size=parseInt(e.data,10):u.value=!0},complete:function(){r.value=!1}})},p=e=>{o().ajax({url:J+"/find",type:"get",data:{time:(new Date).getTime(),sshKey:e,path:Z(s.value),item:Y(i.value.name)},beforeSend:function(){r.value=!0},success(e){"success"==e.status?d.value=e.data[0]+" 个文件,"+Math.max(0,parseInt(e.data[1],10)-1)+" 个文件夹":u.value=!0},complete:function(){r.value=!1}})},v=()=>{if(i.value.name==n.value)return void(a.value=!1);if(!(n.value&&n.value.trim().length>0))return void(0,N.z8)({message:"文件名不能为空",type:"warning",grouping:!0});if(-1!=n.value.indexOf("/"))return void(0,N.z8)({message:"文件名不能含有 /",type:"warning",grouping:!0});let e=s.value+i.value.name,t=s.value+n.value;l.emit("callback",e,t),a.value=!1},m=e=>{e()},g=()=>{i.value={},n.value="",s.value="",r.value=!1,u.value=!1,d.value="0 个文件,0 个文件夹",a.value=!1},f=async e=>{e+="",e&&e.length>0?(await t(e),(0,N.z8)({message:"复制成功",type:"success",grouping:!0,repeatNum:Number.MIN_SAFE_INTEGER})):(0,N.z8)({message:"内容为空",type:"warning",grouping:!0,repeatNum:Number.MIN_SAFE_INTEGER})};return{DialogVisilble:a,fileInfo:i,confirm:v,closeDialog:m,reset:g,fileDir:s,rename:n,formatDate:_a,calcPriority:xa,calcSize:Ea,doCopy:f,loading:r,unreliable:u,includeInfo:d,getFileSize:c,getFolderInclude:p}}};const Wa=(0,He.Z)(Ta,[["render",ka],["__scopeId","data-v-2c6df403"]]);var Fa=Wa,Va={name:"FileBlock",components:{NoData:Oe,FileIcons:Ne(),TxtPreview:Ft,MkFile:Kt,FileAttr:Fa,Refresh:Ke.hYj,Fold:Ke.qFw,Download:Ke.UWx,Upload:Ke.gqx},props:["sshKey","os"],setup(e){const l=(0,R.iH)(!0),{toClipboard:t}=(0,O.Z)(),a=(0,R.iH)([]),i=(0,R.iH)([]);let s=-1;const n=(l,t,o=!0)=>{l.preventDefault();const n=r(t.id);if(o)if(l.shiftKey)if(0==i.value.length||-1==s||s>=a.value.length){i.value=[];for(let e=0;e<=t.index;e++)i.value.push({...a.value[e]});s=-1}else{i.value=[];const e=Math.min(t.index,s),l=Math.max(t.index,s);for(let t=e;t<=l;t++)i.value.push({...a.value[t]})}else"Windows"==e.os&&l.ctrlKey||("Mac"==e.os||"iOS"==e.os)&&l.metaKey?(s=t.index,-1!=n?i.value.splice(n,1):i.value.push(t)):(s=t.index,i.value=[],i.value.push(t));else-1==n&&(s=t.index,i.value=[],i.value.push(t))},r=e=>{for(let l=0;l{for(let l=0;l{""!=d.value&&"/"==d.value[0]||(d.value="/"+d.value),"/"!=d.value[d.value.length-1]&&(d.value=d.value+"/"),d.value=d.value.replace(/\/{2,}/g,"/")},v=(0,R.iH)(!1),m=()=>{""==d.value&&o().ajax({url:J+"/home",type:"get",data:{time:(new Date).getTime(),sshKey:e.sshKey},success(e){"success"==e.status?(g.value="暂无文件",f.value=0,d.value=e.data.path,p(),i.value=[],a.value=[],y()):(g.value=e.info,f.value=1)}})},g=(0,R.iH)("暂无文件"),f=(0,R.iH)(0),y=()=>{let t=d.value;o().ajax({url:J+"/ls",type:"get",data:{time:(new Date).getTime(),sshKey:e.sshKey,path:t},beforeSend:function(){l.value=!0,a.value=[]},success(e){t==d.value&&(i.value=[],"success"==e.status?(a.value=e.data.files,g.value="暂无文件",f.value=0):(a.value=[],g.value=e.info,f.value=1))},complete:function(){t==d.value&&(l.value=!1)}})},w=(l,t)=>J+"/download/remote/file?time="+(new Date).getTime()+"&fileName="+encodeURIComponent(l)+"&sshKey="+e.sshKey+"&path="+encodeURIComponent(t||d.value),h=(l,t)=>J+"/download/remote/folder?time="+(new Date).getTime()+"&folderName="+encodeURIComponent(Y(l))+"&sshKey="+e.sshKey+"&path="+encodeURIComponent(Z(t||d.value)),k=e=>{let l={key:"",path:null},t=e.indexOf("&sshKey="),a=e.indexOf("&path=");return-1!=t&&-1!=a&&(l.key=e.substring(t+8,a)),-1!=a&&(l.path=decodeURIComponent(e.substring(a+6))),l},_=e=>{if(1==v.value)return;let l=document.createElement("a");l.href=w(e),document.body.appendChild(l),l.click(),document.body.removeChild(l)},x=e=>{if(1==v.value)return;let l=document.createElement("a");l.href=h(e),document.body.appendChild(l),l.click(),document.body.removeChild(l)},C=e=>{1!=v.value&&(d.value=e,i.value=[],y())},S=()=>{v.value=!1,p(),i.value=[],y()},b=()=>{v.value=!1,y()},I=()=>{if(1==v.value)return;if("/"==d.value)return;"/"==d.value[d.value.length-1]&&(d.value=d.value.substring(0,d.value.length-1));let e=d.value.lastIndexOf("/");-1!=e&&(d.value=d.value.substring(0,e+1)),i.value=[],b()},D=()=>{1!=v.value&&(1==i.value.length&&i.value[0].name&&i.value[0].isDirectory&&x(i.value[0].name),1==i.value.length&&i.value[0].name&&!i.value[0].isDirectory&&_(i.value[0].name))},E=529408,T=async(l,t={})=>{try{if(1==v.value)return;let a=l.file;if(!a)return;const i=a.name,s=a.size,n=0==parseInt(Math.ceil(s/E))?1:parseInt(Math.ceil(s/E)),r=a.uid;let u=1;const c=t.pathVal?t.pathVal:d.value;s>20971520&&(0,N.z8)({message:t.startUpLoad?t.startUpLoad:"开始上传",type:"success",grouping:!0});for(let l=u;l<=n;l++){let u=(l-1)*E,p=u+E>=s?s:u+E,v=a.slice(u,p),m=new FormData;m.append("file",v),m.append("fileName",i),m.append("chunks",n),m.append("chunk",l),m.append("totalSize",s),m.append("id",r),m.append("sshKey",e.sshKey),m.append("path",c),await o().ajax({url:J+"/upload",type:"post",data:m,contentType:!1,processData:!1,success(e){202==e.code?((0,N.z8)({message:t.alert?t.alert:e.info,type:e.status,grouping:!0}),c==d.value&&setTimeout((()=>{y()}),Math.min(1e3,500+10*n))):(502==e.code||503==e.code||504==e.code||602==e.code)&&((0,N.z8)({message:e.info,type:e.status,grouping:!0}),l=n+1)}})}}catch(a){(0,N.z8)({message:"文件上传失败",type:"error",grouping:!0})}},W=()=>{v.value=!0,setTimeout((()=>{document.querySelector("#aimDirInput").focus()}),1)},F=(0,R.iH)(!1),V=e=>{i.value=[],L.value={},A.value.DialogVisilble=!1,oe.value.DialogVisilble=!1,oe.value.reset(),G.value.DialogVisilble=!1,e()},A=(0,R.iH)(),z=e=>{A.value.fileName=e,A.value.fileUrl=w(e),A.value.loading=!0,A.value.initText(),A.value.DialogVisilble=!0},B=(l,t,a)=>{let o=k(t);if(o.key!=e.sshKey)return;const i=new Blob([a],{type:"text/plain"}),s=new File([i],l);s.uid=Math.random().toString(36).substring(2),T({file:s},{pathVal:o.path,startUpLoad:"修改保存中",alert:"文件后台保存中"})},H=(0,R.iH)(),U=e=>{e.preventDefault()},M=l=>{l.preventDefault();const t=l.dataTransfer.items;if(t&&t.length>0)for(let a=0;a{e.uid=Math.random().toString(36).substring(2),T({file:e},{pathVal:d.value})}));else if(!l.isFile&&l.isDirectory){const t=d.value+l.name;o().ajax({url:J+"/mkdir",type:"post",data:{sshKey:e.sshKey,path:Z(d.value),item:Y(l.name)},success(e){"success"==e.status?(y(),j(l,t+"/")):(0,N.z8)({message:e.info,type:e.status,grouping:!0})}})}}},j=(l,t)=>{const a=l.createReader();a.readEntries((l=>{for(let a=0;a{e.uid=Math.random().toString(36).substring(2),T({file:e},{pathVal:t})}));else if(!i.isFile&&i.isDirectory){const l=t+i.name;o().ajax({url:J+"/mkdir",type:"post",data:{sshKey:e.sshKey,path:Z(t),item:Y(i.name)},success(e){"success"==e.status?j(i,l+"/"):(0,N.z8)({message:e.info,type:e.status,grouping:!0})}})}}}))},Q=(0,R.iH)(!1),K=(0,R.iH)(!1),P=(0,R.iH)(!1),L=(0,R.iH)({}),G=(0,R.iH)(),q=async l=>{switch(l){case 1:b();break;case 2:1==i.value.length&&1==i.value[0].isDirectory?C(d.value+i.value[0].name+"/"):1==i.value.length&&0==i.value[0].isDirectory&&z(i.value[0].name);break;case 3:if(d.value&&d.value.length>0){const e=d.value+(1==i.value.length?i.value[0].name:"");await t(e),(0,N.z8)({message:"复制成功",type:"success",grouping:!0,repeatNum:Number.MIN_SAFE_INTEGER})}else(0,N.z8)({message:"内容为空",type:"warning",grouping:!0,repeatNum:Number.MIN_SAFE_INTEGER});break;case 4:1==i.value.length&&D();break;case 5:oe.value.DialogVisilble=!0,oe.value.nowDir=d.value;break;case 6:1==i.value.length&&(L.value={...i.value[0]},P.value=!0,setTimeout((()=>{document.querySelector("#rename").focus()}),1));break;case 7:K.value=!0;break;case 8:1==i.value.length&&(G.value.reset(),G.value.fileInfo={...i.value[0]},G.value.fileDir=d.value,G.value.rename=i.value[0].name,G.value.DialogVisilble=!0,i.value[0].isDirectory?G.value.getFolderInclude(e.sshKey):G.value.getFileSize(e.sshKey));break;default:break}7!=l&&(Q.value=!1,K.value=!1)},X=()=>{Q.value=!1,K.value=!1},$=(0,R.iH)(),ee=e=>{"fileArea"==e.target.id&&(i.value=[]),$.value.style.top=e.clientY-135+"px",$.value.style.left=e.clientX+1+"px",Q.value=!0,K.value=!1,e.preventDefault()},le=e=>{if(P.value=!1,e.name==L.value.name)return void(L.value={});if(!(L.value.name&&L.value.name.trim().length>0))return(0,N.z8)({message:"文件名不能为空",type:"warning",grouping:!0}),void(L.value={});if(-1!=L.value.name.indexOf("/"))return(0,N.z8)({message:"文件名不能含有 /",type:"warning",grouping:!0}),void(L.value={});let l=d.value+e.name,t=d.value+L.value.name;L.value={},te(l,t)},te=(l,t)=>{o().ajax({url:J+"/rename",type:"post",data:{sshKey:e.sshKey,oldPath:l,newPath:t},success(e){(0,N.z8)({message:e.info,type:e.status,grouping:!0}),y()}})},ae=()=>{Q.value=!1,K.value=!1,0!=i.value.length&&o().ajax({url:J+"/rm-rf",type:"post",data:{sshKey:e.sshKey,path:Z(d.value),items:i.value.map((e=>Y(e.name))).join(" ")},success(e){(0,N.z8)({message:e.info,type:e.status,grouping:!0}),y()}})},oe=(0,R.iH)(),ie=(l,t,a)=>{o().ajax({url:J+(l?"/mkdir":"/touch"),type:"post",data:{sshKey:e.sshKey,path:Z(a),item:Y(t)},success(e){(0,N.z8)({message:e.info,type:e.status,grouping:!0}),y()}})};(0,c.YP)(d,(()=>{oe.value&&oe.value.reset()}));const se=(0,R.iH)({path:"/",files:[]}),ne=(0,R.iH)(!1),re=l=>{const t=document.querySelector("#rename");if((!t||!t.contains(l.target))&&(l.preventDefault(),"Windows"==e.os&&l.ctrlKey||("Mac"==e.os||"iOS"==e.os)&&l.metaKey))switch(String.fromCharCode(l.which).toLowerCase()){case"a":i.value=[];for(let e=0;e0&&(se.value.path=d.value,se.value.files=i.value.slice(0),ne.value=!1);break;case"v":if(0==se.value.files.length)return;ue(ne.value?"mv":"cp"),ne.value&&(ne.value=!1,se.value={path:"/",files:[]});break;case"x":se.value.path=d.value,se.value.files=i.value.slice(0),ne.value=!0;break}},ue=l=>{se.value.path!=d.value&&o().ajax({url:J+"/"+l,type:"post",data:{sshKey:e.sshKey,src:Z(se.value.path),dst:Z(d.value),items:se.value.files.map((e=>Y(e.name))).join(" ")},success(e){"success"==e.status?y():((0,N.z8)({message:e.info,type:e.status,grouping:!0}),se.value={path:"/",files:[]})}})};return(0,c.bv)((()=>{document.addEventListener("mousedown",(e=>{if(H.value&&H.value.contains(e.target)&&(H.value.tabindex="0",H.value.focus()),$.value&&$.value.contains(e.target))return;const l=document.querySelector("#sureDelFileBtn");l&&l.contains(e.target)||(Q.value=!1,K.value=!1)}))})),(0,c.Ah)((()=>{H.value&&(H.value.removeEventListener("dragover",U),H.value.removeEventListener("drop",M),H.value.removeEventListener("scroll",X),H.value.removeEventListener("keydown",re))})),{DialogVisilble:F,closeDialog:V,isShowDirInput:v,dir:d,files:a,getInitDir:m,getDirList:y,downloadRemoteFile:_,downloadDir:x,changeDir:C,dirInputCallback:S,noDataMsg:g,doRefresh:b,doReturn:I,doDownload:D,doUpload:T,selectedFiles:i,loading:l,txtPreviewRef:A,preViewFile:z,doSave:B,fileAreaRef:H,handleMenuSelect:q,isShowMenu:Q,preventDefault:U,handleFileDrag:M,handleScroll:X,handleContextMenu:ee,isShowRenameInput:P,handleRename:le,renameFile:L,menuBlockRef:$,doShowDirInput:W,isShowPop:K,handlePopConfirm:ae,mkFileRef:oe,handleMkFile:ie,doRename:te,fileAttrRef:G,folderUpload:j,dirStatus:f,handleShortcutKeys:re,fileClipboard:se,addSelectFile:n,isSelected:r,isClipboard:u,isCtrlx:ne,fileCopyMove:ue}}};const Aa=(0,He.Z)(Va,[["render",$l],["__scopeId","data-v-32fde74a"]]);var za=Aa;const Ba=e=>((0,c.dD)("data-v-c9882564"),e=e(),(0,c.Cn)(),e),Ha=Ba((()=>(0,c._)("div",{style:{"margin-top":"-32px"}},null,-1))),Ua={class:"kk-flex"},Oa=Ba((()=>(0,c._)("div",{class:"no-select nowrap"},"TCode:",-1))),Ra=Ba((()=>(0,c._)("div",{class:"no-select nowrap",style:{"background-color":"#f3f4f4","margin-right":"8px"}},"U",-1))),Na=Ba((()=>(0,c._)("div",{style:{flex:"1"}},null,-1))),Ma={class:"kk-flex"},ja=Ba((()=>(0,c._)("div",{class:"no-select nowrap",style:{"margin-right":"2px"}},"描 述:",-1))),Qa=Ba((()=>(0,c._)("div",{style:{flex:"1"}},null,-1))),Ka=Ba((()=>(0,c._)("div",{class:"kk-border"},null,-1))),Pa={class:"kk-flex",style:{margin:"7px 0"}},La=Ba((()=>(0,c._)("div",{class:"no-select nowrap"},"Workflow",-1))),Ja=Ba((()=>(0,c._)("div",{style:{flex:"1"}},null,-1))),Ga={"element-loading-text":"Loading...",style:{padding:"0px 5px",width:"100%",height:"30vh"}},qa={style:{display:"flex"}},Za=Ba((()=>(0,c._)("div",{style:{flex:"1"}},null,-1)));function Ya(e,l,t,a,o,i){const s=(0,c.up)("CollectionTag"),n=(0,c.up)("el-icon"),r=(0,c.up)("el-input"),u=(0,c.up)("Upload"),d=(0,c.up)("el-button"),p=(0,c.up)("el-upload"),v=(0,c.up)("EditPen"),m=(0,c.up)("Download"),g=(0,c.up)("Refresh"),f=(0,c.up)("el-tooltip"),y=(0,c.up)("DocumentDelete"),w=(0,c.up)("Finished"),h=(0,c.up)("AceEditor"),k=(0,c.up)("el-dialog"),_=(0,c.Q2)("loading");return(0,c.wg)(),(0,c.j4)(k,{modelValue:a.DialogVisilble,"onUpdate:modelValue":l[5]||(l[5]=e=>a.DialogVisilble=e),"before-close":a.closeDialog,"destroy-on-close":"",width:550,title:"自定义TCode",modal:!1,"modal-class":"kk-dialog-class","align-center":"",draggable:""},{default:(0,c.w5)((()=>[Ha,(0,c._)("div",null,[(0,c._)("div",Ua,[Oa,Ra,(0,c.Wm)(r,{size:"small",style:{width:"130px"},modelValue:a.userTcodeInfo.name,"onUpdate:modelValue":l[0]||(l[0]=e=>a.userTcodeInfo.name=e),class:"w-50 m-2",placeholder:"输入TCode",maxlength:"5",minlength:"1"},{prefix:(0,c.w5)((()=>[(0,c.Wm)(n,null,{default:(0,c.w5)((()=>[(0,c.Wm)(s)])),_:1})])),_:1},8,["modelValue"]),Na,(0,c._)("div",null,[(0,c.Wm)(p,{"show-file-list":!1,"with-credentials":!1,"http-request":a.importTcodes,multiple:!1},{default:(0,c.w5)((()=>[(0,c.Wm)(d,{size:"small",type:"primary"},{default:(0,c.w5)((()=>[(0,c.Wm)(n,{class:"el-icon--left"},{default:(0,c.w5)((()=>[(0,c.Wm)(u)])),_:1}),(0,c.Uk)(" 导入 ")])),_:1})])),_:1},8,["http-request"])])]),(0,c._)("div",Ma,[ja,(0,c.Wm)(r,{size:"small",style:{width:"148px"},modelValue:a.userTcodeInfo.desc,"onUpdate:modelValue":l[1]||(l[1]=e=>a.userTcodeInfo.desc=e),class:"w-50 m-2",placeholder:"输入TCode描述"},{prefix:(0,c.w5)((()=>[(0,c.Wm)(n,null,{default:(0,c.w5)((()=>[(0,c.Wm)(v)])),_:1})])),_:1},8,["modelValue"]),Qa,(0,c._)("div",null,[(0,c.Wm)(d,{size:"small",type:"primary",onClick:a.exportTcodes},{default:(0,c.w5)((()=>[(0,c.Wm)(n,{class:"el-icon--left"},{default:(0,c.w5)((()=>[(0,c.Wm)(m)])),_:1}),(0,c.Uk)(" 导出 ")])),_:1},8,["onClick"])])]),Ka,(0,c._)("div",Pa,[La,Ja,(0,c._)("div",{onClick:l[2]||(l[2]=e=>a.workflowTab(1)),style:{"font-size":"18px",cursor:"pointer","margin-left":"15px"}},[(0,c.Wm)(f,{content:"默认模板",placement:"top"},{default:(0,c.w5)((()=>[(0,c.Wm)(n,null,{default:(0,c.w5)((()=>[(0,c.Wm)(g)])),_:1})])),_:1})]),(0,c._)("div",{onClick:l[3]||(l[3]=e=>a.workflowTab(2)),style:{"font-size":"18px",cursor:"pointer","margin-left":"15px"}},[(0,c.Wm)(f,{content:"清空",placement:"top"},{default:(0,c.w5)((()=>[(0,c.Wm)(n,null,{default:(0,c.w5)((()=>[(0,c.Wm)(y)])),_:1})])),_:1})]),(0,c._)("div",{onClick:l[4]||(l[4]=e=>a.workflowTab(3)),style:{"font-size":"18px",cursor:"pointer","margin-left":"15px"}},[(0,c.Wm)(f,{content:"保存",placement:"top"},{default:(0,c.w5)((()=>[(0,c.Wm)(n,null,{default:(0,c.w5)((()=>[(0,c.Wm)(w)])),_:1})])),_:1})])]),(0,c.wy)(((0,c.wg)(),(0,c.iD)("div",Ga,[(0,c.Wm)(h,{ref:"userTcodeEditorRef",onHandleSave:a.handleSave},null,8,["onHandleSave"])])),[[_,a.loading]])]),(0,c._)("div",qa,[Za,(0,c.Wm)(d,{size:"small",type:"primary",onClick:a.confirm,style:{"margin-bottom":"-15px","margin-top":"10px"}},{default:(0,c.w5)((()=>[(0,c.Uk)(" 确定 ")])),_:1},8,["onClick"])])])),_:1},8,["modelValue","before-close"])}var Xa={name:"UserTcode",components:{AceEditor:Et,CollectionTag:Ke.O$2,EditPen:Ke.qHu,Upload:Ke.gqx,Download:Ke.UWx,Refresh:Ke.hYj,Finished:Ke.qWi,DocumentDelete:Ke.jY0},setup(e,l){const t=(0,R.iH)(!1),a=(0,R.iH)(!1),o="await kkTerminal.write('cd /root/terminal');\nawait kkTerminal.write('lsof -i :3000', 500);\nlet resultArr = kkTerminal.read();\nif(resultArr.length >= 3) {\n let pid = resultArr[2].replace(/\\s+/g, ' ').split(' ')[1];\n\tif(pid) await kkTerminal.write('kill -9 ' + pid);\n}\nlet jar = 'kkTerminal.jar';\nawait kkTerminal.write('java -jar ./' + jar + ' > ./out.log &');\nalert('TCode Workflow Over!');",i=(0,R.iH)(),s=(0,R.iH)({name:"",desc:""}),n=e=>{localStorage.setItem("tcode-draft",e),(0,N.z8)({message:"保存成功",type:"success",grouping:!0,repeatNum:Number.MIN_SAFE_INTEGER})},r=e=>{i.value.setValue(e),i.value.reset()},u=()=>{i.value.setLanguage("kk.js"),localStorage.getItem("tcode-draft")&&(i.value.setValue(localStorage.getItem("tcode-draft")),i.value.reset())},d=e=>{const l=/^[A-Za-z0-9]+$/;return l.test(e)},c=e=>{let t=e.file;const o=new FileReader;o.onload=()=>{try{const e=JSON.parse(o.result);let t={},a=0,i=0;for(const l in e)l&&l.length>=2&&l.length<=6&&("U"==l[0]||"u"==l[0])&&d(l)?(t[l.toUpperCase()]={desc:e[l].desc||"",workflow:e[l].workflow||"",status:"Not Active"},a++):((0,N.z8)({message:"TCode-"+l+":名称非法",type:"error",grouping:!0}),i++);0==i?(l.emit("importTCodes",t),(0,N.z8)({message:"导入成功",type:"success",grouping:!0}),f()):0==a?(0,N.z8)({message:"导入失败:无合法TCode",type:"error",grouping:!0}):(l.emit("importTCodes",t),(0,N.z8)({message:"导入成功:"+a+"个,导入失败:"+i+"个",type:"warning",grouping:!0}))}catch(e){(0,N.z8)({message:"导入失败:json格式错误",type:"error",grouping:!0})}finally{a.value=!1}},o.onerror=()=>{(0,N.z8)({message:"导入失败:文件读取失败",type:"error",grouping:!0}),a.value=!1},a.value=!0,o.readAsText(t)},p=()=>{l.emit("exportTcodes"),(0,N.z8)({message:"导出成功",type:"success",grouping:!0})},v=e=>{switch(e){case 1:localStorage.removeItem("tcode-draft"),r(o);break;case 2:localStorage.removeItem("tcode-draft"),r("");break;case 3:n(i.value.getValue());break}},m=()=>{if(!(s.value.name&&s.value.name.length>=1&&s.value.name.length<=5))return void(0,N.z8)({message:"TCode不能为空",type:"error",grouping:!0,repeatNum:Number.MIN_SAFE_INTEGER});if(!d(s.value.name))return void(0,N.z8)({message:"TCode只能由字母和数字组成",type:"error",grouping:!0,repeatNum:Number.MIN_SAFE_INTEGER});let e={};e["U"+s.value.name.toUpperCase()]={desc:s.value.desc,workflow:i.value.getValue(),status:"Not Active"},l.emit("importTCodes",e),(0,N.z8)({message:"添加成功",type:"success",grouping:!0}),localStorage.removeItem("tcode-draft"),f()},g=e=>{f(),e()},f=()=>{setTimeout((()=>{a.value=!1,s.value.name="",s.value.desc="",i.value.setValue(""),i.value.reset()}),200),t.value=!1};return{DialogVisilble:t,confirm:m,closeDialog:g,reset:f,userTcodeEditorRef:i,handleSave:n,initText:u,loading:a,userTcodeInfo:s,importTcodes:c,exportTcodes:p,setValue:r,workflowTab:v}}};const $a=(0,He.Z)(Xa,[["render",Ya],["__scopeId","data-v-c9882564"]]);var eo=$a;const lo=e=>((0,c.dD)("data-v-bfe11042"),e=e(),(0,c.Cn)(),e),to=lo((()=>(0,c._)("div",{style:{"margin-top":"-27px"}},null,-1))),ao={class:"no-select"},oo={style:{height:"210px","overflow-y":"auto",padding:"10px 0"}},io=lo((()=>(0,c._)("div",null,[(0,c.Uk)("以 "),(0,c._)("span",{style:{"background-color":"#f3f4f4"}},"/"),(0,c.Uk)(" 开头,用于快速执行通用功能")],-1))),so=lo((()=>(0,c._)("div",{class:"kk-border"},null,-1))),no={class:"kk-flex tocde-item",style:{padding:"12px 10px"}},ro={style:{"background-color":"#f3f4f4"}},uo={style:{"margin-left":"25px"}},co={style:{height:"210px","overflow-y":"auto",padding:"10px 0"}},po=lo((()=>(0,c._)("div",null,[(0,c.Uk)("以 "),(0,c._)("span",{style:{"background-color":"#f3f4f4"}},"S"),(0,c.Uk)(" 开头,用于快速访问系统模块")],-1))),vo=lo((()=>(0,c._)("div",{class:"kk-border"},null,-1))),mo={class:"kk-flex tocde-item",style:{padding:"12px 10px"}},go={style:{"background-color":"#f3f4f4"}},fo={style:{"margin-left":"25px"}},yo={style:{height:"210px","overflow-y":"auto",padding:"10px 0"}},wo={class:"kk-flex",style:{"margin-bottom":"12px","margin-top":"-10px"}},ho={style:{"margin-top":"3px"}},ko={style:{cursor:"pointer","margin-left":"10px"}},_o=lo((()=>(0,c._)("div",{style:{flex:"1"}},null,-1))),xo=lo((()=>(0,c._)("div",{style:{"margin-left":"10px"}},null,-1))),Co={style:{width:"100%",height:"166px"}},So=lo((()=>(0,c._)("div",null,[(0,c.Uk)("以 "),(0,c._)("span",{style:{"background-color":"#f3f4f4"}},"U"),(0,c.Uk)(" 开头,自定义实现类似Shell脚本的自动化Workflow")],-1))),bo=lo((()=>(0,c._)("div",{class:"kk-border"},null,-1))),Io={class:"kk-flex tocde-item",style:{padding:"12px 10px"}},Do={class:"kk-flex",style:{width:"60px"}},Eo={style:{"background-color":"#f3f4f4"}},To=lo((()=>(0,c._)("div",{style:{flex:"1"}},null,-1))),Wo={class:"ellipsis",style:{"margin-left":"10px"}},Fo=lo((()=>(0,c._)("div",{style:{flex:"1"}},null,-1))),Vo={style:{cursor:"pointer","margin-left":"10px"}},Ao=["onClick"],zo=lo((()=>(0,c._)("div",null,[(0,c.Uk)("以 "),(0,c._)("span",{style:{"background-color":"#f3f4f4"}},"U"),(0,c.Uk)(" 开头,自定义实现类似Shell脚本的自动化Workflow")],-1))),Bo=lo((()=>(0,c._)("div",{class:"kk-border"},null,-1))),Ho=lo((()=>(0,c._)("div",{style:{"margin-top":"20px"}},null,-1)));function Uo(e,l,t,a,o,i){const s=(0,c.up)("el-tab-pane"),n=(0,c.up)("ArrowLeft"),r=(0,c.up)("el-icon"),u=(0,c.up)("TcodeStatus"),d=(0,c.up)("el-tooltip"),p=(0,c.up)("Edit"),v=(0,c.up)("View"),m=(0,c.up)("Finished"),g=(0,c.up)("AceEditor"),f=(0,c.up)("ArrowRight"),y=(0,c.up)("NoData"),w=(0,c.up)("el-tabs"),h=(0,c.up)("el-dialog");return(0,c.wg)(),(0,c.j4)(h,{modelValue:a.DialogVisilble,"onUpdate:modelValue":l[4]||(l[4]=e=>a.DialogVisilble=e),"destroy-on-close":"",width:480,title:"帮助",modal:!1,"modal-class":"kk-dialog-class","before-close":a.closeDialog,draggable:""},{default:(0,c.w5)((()=>[to,(0,c._)("div",ao,[(0,c.Wm)(w,{type:"border-card"},{default:(0,c.w5)((()=>[(0,c.Wm)(s,{label:"功能TCode"},{default:(0,c.w5)((()=>[(0,c._)("div",oo,[io,so,((0,c.wg)(!0),(0,c.iD)(c.HY,null,(0,c.Ko)(a.FuncTcode,((e,l)=>((0,c.wg)(),(0,c.iD)("div",{key:l},[(0,c._)("div",no,[(0,c._)("div",ro,(0,X.zw)(l),1),(0,c._)("div",uo,(0,X.zw)(e.desc),1)])])))),128))])])),_:1}),(0,c.Wm)(s,{label:"系统TCode"},{default:(0,c.w5)((()=>[(0,c._)("div",co,[po,vo,((0,c.wg)(!0),(0,c.iD)(c.HY,null,(0,c.Ko)(a.SysTcode,((e,l)=>((0,c.wg)(),(0,c.iD)("div",{key:l},[(0,c._)("div",mo,[(0,c._)("div",go,(0,X.zw)(l),1),(0,c._)("div",fo,(0,X.zw)(e.desc),1)])])))),128))])])),_:1}),(0,c.Wm)(s,{label:"用户TCode"},{default:(0,c.w5)((()=>[(0,c._)("div",yo,[a.userTCodes&&Object.keys(a.userTCodes).length>0?((0,c.wg)(),(0,c.iD)(c.HY,{key:0},[a.nowTCode&&a.nowTCode.length>=2&&a.nowTCode.length<=6?((0,c.wg)(),(0,c.iD)(c.HY,{key:0},[(0,c._)("div",wo,[(0,c._)("div",{onClick:l[0]||(l[0]=(...e)=>a.toOverview&&a.toOverview(...e)),style:{"margin-right":"10px",cursor:"pointer","font-size":"16px"}},[(0,c.Wm)(r,null,{default:(0,c.w5)((()=>[(0,c.Wm)(n)])),_:1})]),(0,c._)("div",ho,(0,X.zw)(a.modifyTag+a.nowTCode),1),(0,c._)("div",ko,[(0,c.Wm)(d,{content:a.TCodeStatusEnum[a.userTCodes[a.nowTCode].status],placement:"top"},{default:(0,c.w5)((()=>[(0,c.Wm)(u,{style:{fontSize:"18px"},status:a.userTCodes[a.nowTCode].status},null,8,["status"])])),_:1},8,["content"])]),_o,0==a.mode?((0,c.wg)(),(0,c.iD)("div",{key:0,onClick:l[1]||(l[1]=(...e)=>a.doModifyTCode&&a.doModifyTCode(...e)),style:{"margin-top":"-3px","font-size":"18px",cursor:"pointer","margin-left":"15px"}},[(0,c.Wm)(d,{content:"编辑",placement:"top"},{default:(0,c.w5)((()=>[(0,c.Wm)(r,null,{default:(0,c.w5)((()=>[(0,c.Wm)(p)])),_:1})])),_:1})])):(0,c.kq)("",!0),1==a.mode?((0,c.wg)(),(0,c.iD)("div",{key:1,onClick:l[2]||(l[2]=(...e)=>a.doOnlyRead&&a.doOnlyRead(...e)),style:{"margin-top":"-3px","font-size":"18px",cursor:"pointer","margin-left":"15px"}},[(0,c.Wm)(d,{content:"只读",placement:"top"},{default:(0,c.w5)((()=>[(0,c.Wm)(r,null,{default:(0,c.w5)((()=>[(0,c.Wm)(v)])),_:1})])),_:1})])):(0,c.kq)("",!0),1==a.mode?((0,c.wg)(),(0,c.iD)("div",{key:2,onClick:l[3]||(l[3]=(...e)=>a.doSaveTCode&&a.doSaveTCode(...e)),style:{"margin-top":"-3px","font-size":"18px",cursor:"pointer","margin-left":"15px"}},[(0,c.Wm)(d,{content:"保存修改",placement:"top"},{default:(0,c.w5)((()=>[(0,c.Wm)(r,null,{default:(0,c.w5)((()=>[(0,c.Wm)(m)])),_:1})])),_:1})])):(0,c.kq)("",!0),xo]),(0,c._)("div",Co,[(0,c.Wm)(g,{ref:"userTcodeEditorRef",onHandleChange:a.handleChange,onHandleSave:a.doSaveTCode},null,8,["onHandleChange","onHandleSave"])])],64)):((0,c.wg)(),(0,c.iD)(c.HY,{key:1},[So,bo,((0,c.wg)(!0),(0,c.iD)(c.HY,null,(0,c.Ko)(a.userTCodes,((e,l)=>((0,c.wg)(),(0,c.iD)("div",{key:l},[(0,c._)("div",Io,[(0,c._)("div",Do,[(0,c._)("div",Eo,(0,X.zw)(l),1),To]),(0,c._)("div",Wo,(0,X.zw)(e.desc),1),Fo,(0,c._)("div",Vo,[(0,c.Wm)(d,{content:a.TCodeStatusEnum[e.status],placement:"top"},{default:(0,c.w5)((()=>[(0,c.Wm)(u,{style:{fontSize:"18px"},status:e.status},null,8,["status"])])),_:2},1032,["content"])]),(0,c._)("div",{onClick:e=>a.toWorkflow(l),style:{"margin-left":"15px",cursor:"pointer","font-size":"16px"}},[(0,c.Wm)(r,null,{default:(0,c.w5)((()=>[(0,c.Wm)(f)])),_:1})],8,Ao)])])))),128))],64))],64)):((0,c.wg)(),(0,c.iD)(c.HY,{key:1},[zo,Bo,(0,c.Wm)(y,{height:"210px"},{myslot:(0,c.w5)((()=>[Ho])),_:1})],64))])])),_:1})])),_:1})])])),_:1},8,["modelValue","before-close"])}function Oo(e,l,t,a,o,i){const s=(0,c.up)("CircleCloseFilled"),n=(0,c.up)("el-icon"),r=(0,c.up)("WarningFilled"),u=(0,c.up)("SuccessFilled"),d=(0,c.up)("InfoFilled");return-2==a.statusType?((0,c.wg)(),(0,c.iD)("div",{key:0,style:(0,X.j5)(a.statusStyle)},[(0,c.Wm)(n,null,{default:(0,c.w5)((()=>[(0,c.Wm)(s)])),_:1})],4)):-1==a.statusType?((0,c.wg)(),(0,c.iD)("div",{key:1,style:(0,X.j5)(a.statusStyle)},[(0,c.Wm)(n,null,{default:(0,c.w5)((()=>[(0,c.Wm)(r)])),_:1})],4)):1==a.statusType?((0,c.wg)(),(0,c.iD)("div",{key:2,style:(0,X.j5)(a.statusStyle)},[(0,c.Wm)(n,null,{default:(0,c.w5)((()=>[(0,c.Wm)(u)])),_:1})],4)):((0,c.wg)(),(0,c.iD)("div",{key:3,style:(0,X.j5)(a.statusStyle)},[(0,c.Wm)(n,null,{default:(0,c.w5)((()=>[(0,c.Wm)(d)])),_:1})],4))}var Ro={name:"TcodeStatus",components:{SuccessFilled:Ke.c5o,WarningFilled:Ke.Rrw,CircleCloseFilled:Ke.Tw$,InfoFilled:Ke.cEj},props:{status:{type:String,default:"success"},style:{type:Object,default:()=>{}}},setup(e){const l={"Load Error":-2,"Execute Error":-1,"Not Active":0,"Execute Success":1},t=["#f56c6c","#e6a23c","#909399","#67c23a"],a=(0,c.Fl)((()=>l[e.status]||0)),o=(0,c.Fl)((()=>({fontSize:"16px",...e.style,color:t[(l[e.status]||0)+2]})));return{statusStyle:o,statusType:a}}};const No=(0,He.Z)(Ro,[["render",Oo]]);var Mo=No,jo={name:"HelpTcode",components:{NoData:Oe,TcodeStatus:Mo,AceEditor:Et,ArrowRight:Ke.olP,ArrowLeft:Ke.XdH,Edit:Ke.I8b,View:Ke.G7x,Finished:Ke.qWi},setup(e,l){const t=(0,R.iH)(!1),a=(0,R.iH)(""),o=(0,R.iH)({}),i=(0,R.iH)(""),s=(0,R.iH)(!1),n=e=>{i.value=e,s.value=!1,setTimeout((()=>{c(!0)}),1)},r=()=>{s.value=!1,i.value="",a.value=""},d=(0,R.iH)(),c=e=>{d.value.setLanguage("kk.js"),d.value.setValue(JSON.parse(u(localStorage.getItem("tcodes")))[i.value].workflow||""),d.value.reset(),d.value.setReadOnly(e),a.value=""},p=()=>{s.value=!0,c(!1)},v=()=>{s.value=!1,c(!0)},m=()=>{"*"==a.value&&(l.emit("handleSaveTCode",i.value,d.value.getValue()),v(),(0,N.z8)({message:"修改成功",type:"success",grouping:!0}),a.value="")},g=()=>{a.value="*"},f=e=>{setTimeout((()=>{r()}),300),e()};return{DialogVisilble:t,FuncTcode:wt,SysTcode:ht,nowTCode:i,toWorkflow:n,toOverview:r,userTCodes:o,userTcodeEditorRef:d,initTcodeEditor:c,TCodeStatusEnum:St,mode:s,doModifyTCode:p,doOnlyRead:v,doSaveTCode:m,handleChange:g,modifyTag:a,closeDialog:f}}};const Qo=(0,He.Z)(jo,[["render",Uo],["__scopeId","data-v-bfe11042"]]);var Ko=Qo,Po={name:"FrameWork",components:{ConnectSetting:Je,StyleSetting:Al,FileBlock:za,UserTcode:eo,HelpTcode:Ko,QuestionFilled:Ke.Ruj},setup(){const e=(0,c.FN)(),{toClipboard:l}=(0,O.Z)(),t=new j.FitAddon,a=(0,R.iH)({}),i=(0,R.iH)({}),s=()=>{localStorage.getItem("options")?i.value=JSON.parse(u(localStorage.getItem("options"))):i.value={}};s();const n=(0,R.iH)({}),d=()=>{n.value={},localStorage.getItem("tcodes")&&(n.value=JSON.parse(u(localStorage.getItem("tcodes")))),setTimeout((()=>{te.value.userTCodes={...n.value}}),1)};d();const p=(0,R.iH)(null),v=()=>{if(localStorage.getItem("env")){p.value=JSON.parse(u(localStorage.getItem("env")));let e=i.value[p.value["option"]];e?p.value={...p.value,...e}:p.value.option=""}else p.value=Q};v();const m=(e,l)=>{i.value={...i.value,[e]:l},localStorage.setItem("options",r(JSON.stringify(i.value))),s()},g=(0,R.iH)({Fail:"Fail to connect remote server !\r\n",Success:"Connecting success !\r\n",Connecting:"Connecting to remote server ...\r\n",Disconnected:"Disconnect to remote server.\r\n"}),f=(0,R.iH)(g.value["Connecting"]),y=(0,R.iH)();let w=null;const h=(0,R.iH)(!0),k=()=>{w=new M.Terminal({rendererType:"canvas",convertEol:!0,scrollback:0,disableStdin:!1,cursorStyle:p.value.cursorStyle,cursorBlink:p.value.cursorBlink,theme:{foreground:p.value.fg,background:p.value.bg,cursor:"help"},lineHeight:1.2,fontFamily:p.value.fontFamily,fontSize:p.value.fontSize}),w.loadAddon(t)},_=()=>{if(y.value.style.height=window.innerHeight-25+"px",t.fit(),C.value&&C.value.readyState==WebSocket.OPEN&&w){let e=t.proposeDimensions().rows,l=t.proposeDimensions().cols;C.value.send(r(JSON.stringify({type:1,content:"",rows:e,cols:l}))),w.resize(l,e)}},x=(0,R.iH)(""),C=(0,R.iH)(null),S=()=>{C.value=new WebSocket(L+G(r(JSON.stringify(p.value)))),C.value.onopen=()=>{_()},C.value.onmessage=e=>{let l=JSON.parse(e.data);if(-1==l.code&&(w.clear(),f.value=g.value["Fail"],w.write(f.value),H(1)),0==l.code&&(w.clear(),f.value=g.value["Success"],x.value=u(l.info),setTimeout((()=>{_()}),1)),1==l.code){let e=u(l.info);kt.active&&kt.outArray.push(e),kt.active&&!kt.display||w.write(e),w.options.scrollback+=w._core.buffer.lines.length}},C.value.onclose=e=>{f.value==g.value["Success"]&&3333!=e.code&&(x.value="",P(),f.value=g.value["Disconnected"],w.write("\r\n"+f.value)),X()}},b=(0,R.iH)(!1),I=()=>{b.value=!b.value},D=(0,R.iH)(),E=(0,R.iH)(),T=(0,R.iH)(),W=e=>{p.value={...p.value,...e},localStorage.setItem("env",r(JSON.stringify(p.value))),H(3)},F=(e,l=!1)=>{C.value&&(h.value&&(_(),h.value=!1),kt.active===l&&C.value.send(r(JSON.stringify({type:0,content:e,rows:0,cols:0}))))},V=e=>{e.preventDefault(),F(e.target.value),e.target.value=""},A=async function(e){e.preventDefault();let l=await navigator.clipboard.readText();F(l)},z=()=>{b.value=!1},B=()=>{w&&y.value&&(y.value.removeEventListener("contextmenu",A),y.value.removeEventListener("compositionend",V),y.value.removeEventListener("click",z)),y.value.innerHTML="",h.value=!0,v(),k(),w.open(y.value),_(),y.value.addEventListener("compositionend",V),w.onKey((e=>{F(e.key)})),w.onSelectionChange((async()=>{if(w.hasSelection()){let e=w.getSelection(),t=e.trim();t&&""!=t&&await l(e)}})),y.value.addEventListener("contextmenu",A),y.value.addEventListener("click",z),w.write(f.value)},H=e=>{1==e?(b.value=!1,D.value.DialogVisilble=!0):2==e?(b.value=!1,E.value.DialogVisilble=!0):3==e?(b.value=!1,f.value=g.value["Connecting"],x.value="",C.value&&C.value.close(3333),P(),S(),B()):4==e&&(b.value=!1,T.value.DialogVisilble=!0,T.value.getInitDir())};let U=null;const K=()=>{null==U&&(U=setInterval((()=>{C.value&&C.value.readyState==WebSocket.OPEN&&C.value.send(r(JSON.stringify({type:2,content:"",rows:0,cols:0}))),"Linux"!=a.value.serverOS&&o().ajax({url:J+"/beat",type:"post",data:{windowId:a.value.windowId},success(){}})}),25e3))},P=()=>{T.value.txtPreviewRef.DialogVisilble=!1,T.value.txtPreviewRef.resetEditor(),T.value.mkFileRef.DialogVisilble=!1,T.value.fileAttrRef.DialogVisilble=!1,T.value.DialogVisilble=!1,T.value.dir="",T.value.selectedFiles=[],T.value.renameFile=null,T.value.fileClipboard={path:"/",files:[]},T.value.isCtrlx=!1},q=(e,l)=>{n.value[e].status=l,localStorage.setItem("tcodes",r(JSON.stringify(n.value))),setTimeout((()=>{te.value.userTCodes={...n.value}}),1)},Z=(0,R.iH)(""),Y=async()=>{if(!Z.value||Z.value.length<2)return;let l=Z.value.toUpperCase();if(Z.value="","/"==l[0]&&wt[l])wt[l].execFlow(e);else if("S"==l[0]&&ht[l])ht[l].execFlow(e);else if("U"==l[0]&&n.value[l])if(kt.writeOnly||(kt.writeOnly=F),0==kt.active){if(X(),kt.active=!0,!n.value[l].execFlow||!(n.value[l].execFlow instanceof Function)){let e=n.value[l].workflow.toString();try{n.value[l].execFlow=new Function("kkTerminal",`return (async function() { ${e} })()`)}catch(t){return q(l,"Load Error"),(0,N.z8)({message:"TCode-"+l+" Load Error: "+t,type:"error",grouping:!0}),void X()}}try{await n.value[l].execFlow(kt),(0,N.z8)({message:"TCode-"+l+" Workflow Over",type:"success",grouping:!0}),q(l,"Execute Success")}catch(t){(0,N.z8)({message:"TCode-"+l+" Execute Error: "+t,type:"warning",grouping:!0}),q(l,"Execute Error")}finally{X()}}else(0,N.z8)({message:"Another TCode is executing",type:"warning",grouping:!0});else(0,N.z8)({message:"TCode-"+l+" 不存在",type:"warning",grouping:!0})},X=()=>{kt.active=!1,kt.display=!0,kt.outArray=[],kt.cnt=0},$=(0,R.iH)(),ee=e=>{let l={};l={...n.value,...e},localStorage.setItem("tcodes",r(JSON.stringify(l))),d()},le=()=>{let e={};localStorage.getItem("tcodes")&&(e=JSON.parse(u(localStorage.getItem("tcodes"))));const l=new Blob([JSON.stringify(e,null,4)],{type:"text/plain"}),t=URL.createObjectURL(l),a=document.createElement("a");a.href=t,a.download="TCode.json",document.body.appendChild(a),a.click(),document.body.removeChild(a),URL.revokeObjectURL(t)},te=(0,R.iH)(),ae=(e,l)=>{let t={};t[e]={desc:n.value[e].desc||"",workflow:l||"",status:"Not Active"},ee(t)};return(0,c.bv)((()=>{B(),o().ajax({url:J+"/init",type:"get",data:{time:(new Date).getTime()},success(e){a.value={...e.data},S(),window.addEventListener("resize",(()=>{T.value&&(T.value.isShowMenu=!1,T.value.isShowPop=!1),_()})),K()}})})),(0,c.Ah)((()=>{w&&y.value&&(y.value.removeEventListener("contextmenu",A),y.value.removeEventListener("compositionend",V),y.value.removeEventListener("click",z)),U&&clearInterval(U)})),{env:p,options:i,now_connect_status:f,connect_status:g,terminal:y,doSSHConnect:S,socket:C,showSettings:I,isShowSetting:b,doSettings:H,connectSettingRef:D,styleSettingRef:E,fileBlockRef:T,saveEnv:W,sshKey:x,doHeartBeat:K,saveOp:m,tcode:Z,handleTcode:Y,closeFileBlock:P,resetTerminal:B,tcodes:n,userTcodeRef:$,sendMessage:F,importTCodes:ee,exportTcodes:le,helpTcodeRef:te,handleSaveTCode:ae,osInfo:a}}};const Lo=(0,He.Z)(Po,[["render",U],["__scopeId","data-v-1d051994"]]);var Jo=Lo,Go={name:"App",components:{FrameWork:Jo}};const qo=(0,He.Z)(Go,[["render",p]]);var Zo=qo,Yo=(t(4415),t(391)),Xo=t(5974),$o=t(1015),ei=t(3370),li=t(3096),ti=t(5868),ai=t(881),oi=t(9695),ii=t(4133),si=t(6199),ni=t(7224),ri=t(4775),ui=t(3838),di=t(7919),ci=t(1902),pi=(t(1849),t(3189));o().ajaxSetup({processData:!0,xhrFields:{withCredentials:!0},dataFilter(e){e=JSON.parse(e);let l=e.data;return l&&(e.data=JSON.parse(u(e.data))),JSON.stringify(e)}});const vi=(0,d.ri)(Zo);vi.use(Yo.ElButton).use(Xo.d0).use($o.gn).use(ei.EZ).use(li.LW).use(ti.$).use(ai.Ub).use(ai.p8).use(oi.b9).use(ii.Q0),vi.use(si.YK).use(si.o2).use(si.Df).use(ni.OX).use(ri.kN).use(ui.KD).use(ui.rh).use(di.$t).use(ci.Ks),vi.use(pi.Z),vi.mount("#app"),vi.config.warnHandler=()=>{}},2480:function(){}},l={};function t(a){var o=l[a];if(void 0!==o)return o.exports;var i=l[a]={id:a,loaded:!1,exports:{}};return e[a].call(i.exports,i,i.exports,t),i.loaded=!0,i.exports}t.m=e,function(){t.amdD=function(){throw new Error("define cannot be used indirect")}}(),function(){var e=[];t.O=function(l,a,o,i){if(!a){var s=1/0;for(d=0;d=i)&&Object.keys(t.O).every((function(e){return t.O[e](a[r])}))?a.splice(r--,1):(n=!1,i0&&e[d-1][2]>i;d--)e[d]=e[d-1];e[d]=[a,o,i]}}(),function(){t.n=function(e){var l=e&&e.__esModule?function(){return e["default"]}:function(){return e};return t.d(l,{a:l}),l}}(),function(){t.d=function(e,l){for(var a in l)t.o(l,a)&&!t.o(e,a)&&Object.defineProperty(e,a,{enumerable:!0,get:l[a]})}}(),function(){t.g=function(){if("object"===typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"===typeof window)return window}}()}(),function(){t.o=function(e,l){return Object.prototype.hasOwnProperty.call(e,l)}}(),function(){t.r=function(e){"undefined"!==typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})}}(),function(){t.nmd=function(e){return e.paths=[],e.children||(e.children=[]),e}}(),function(){t.p="/"}(),function(){var e={143:0};t.O.j=function(l){return 0===e[l]};var l=function(l,a){var o,i,s=a[0],n=a[1],r=a[2],u=0;if(s.some((function(l){return 0!==e[l]}))){for(o in n)t.o(n,o)&&(t.m[o]=n[o]);if(r)var d=r(t)}for(l&&l(a);u {\r\n var key = CryptoJS.enc.Utf8.parse(SECRET_KEY);\r\n var srcs = CryptoJS.enc.Utf8.parse(word);\r\n var encrypted = CryptoJS.AES.encrypt(srcs, key, {mode:CryptoJS.mode.ECB,padding: CryptoJS.pad.Pkcs7});\r\n return encrypted.toString();\r\n};\r\n\r\n/**\r\n * AES解密\r\n */\r\nexport const decrypt = (word) => {\r\n var key = CryptoJS.enc.Utf8.parse(SECRET_KEY);\r\n var decrypt = CryptoJS.AES.decrypt(word, key, {mode:CryptoJS.mode.ECB,padding: CryptoJS.pad.Pkcs7});\r\n return CryptoJS.enc.Utf8.stringify(decrypt).toString();\r\n};\r\n\r\n// BASE64编码与解码\r\nexport const Base64={_keyStr:\"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=\",encode:function(e){var t=\"\";var n,r,i,s,o,u,a;var f=0;e=Base64._utf8_encode(e);while(f>2;o=(n&3)<<4|r>>4;u=(r&15)<<2|i>>6;a=i&63;if(isNaN(r)){u=a=64}else if(isNaN(i)){a=64}t=t+this._keyStr.charAt(s)+this._keyStr.charAt(o)+this._keyStr.charAt(u)+this._keyStr.charAt(a)}return t},decode:function(e){var t=\"\";var n,r,i;var s,o,u,a;var f=0;e=e.replace(/[^A-Za-z0-9+/=]/g,\"\");while(f>4;r=(o&15)<<4|u>>2;i=(u&3)<<6|a;t=t+String.fromCharCode(n);if(u!=64){t=t+String.fromCharCode(r)}if(a!=64){t=t+String.fromCharCode(i)}}t=Base64._utf8_decode(t);return t},_utf8_encode:function(e){e=e.replace(/rn/g,\"n\");var t=\"\";for(var n=0;n127&&r<2048){t+=String.fromCharCode(r>>6|192);t+=String.fromCharCode(r&63|128)}else{t+=String.fromCharCode(r>>12|224);t+=String.fromCharCode(r>>6&63|128);t+=String.fromCharCode(r&63|128)}}return t},_utf8_decode:function(e){var t=\"\";var n=0;var r=0;var c2=0;while(n191&&r<224){c2=e.charCodeAt(n+1);t+=String.fromCharCode((r&31)<<6|c2&63);n+=2}else{c2=e.charCodeAt(n+1);var c3=e.charCodeAt(n+2);t+=String.fromCharCode((r&15)<<12|(c2&63)<<6|c3&63);n+=3}}return t}};\r\n","\n \n\n\n\n\n","\r\n \r\n \r\n
\r\n \r\n \r\n \r\n \r\n
\r\n
\r\n
\r\n

\r\n
\r\n
kk Terminal
\r\n
\r\n
\r\n
TCode
\r\n
\r\n
\r\n \r\n \r\n
\r\n
\r\n
\r\n \r\n \r\n \r\n \r\n
什么是 TCode (终端代码) ?
\r\n
TCode(终端代码)是用于访问和执行特定操作流程的快捷方式
\r\n
\r\n 输入 \r\n /H\r\n 并按下回车,查看帮助信息\r\n
\r\n
\r\n 输入 \r\n /A\r\n 并按下回车,自定义TCode\r\n
\r\n
\r\n \r\n
\r\n
\r\n
\r\n
\r\n \r\n
\r\n
\r\n\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n\r\n\r\n\r\n\r\n\r\n\r\n","export const default_env = {\r\n // 连接相关\r\n server_ip: '',\r\n server_port: 22,\r\n server_user: 'root',\r\n server_password:'',\r\n option:'',\r\n // 样式相关\r\n bg:'#0c0c0c',\r\n fg:'#cccccc',\r\n fontFamily: 'Courier New',\r\n fontSize: 16,\r\n cursorStyle: 'block',\r\n cursorBlink: true,\r\n tCode: true,\r\n};","// 上线环境\r\nlet http_protocol = window.location.protocol;\r\nlet ws_protocol = '';\r\nif(http_protocol == 'https:') ws_protocol = 'wss://';\r\nelse ws_protocol = 'ws://';\r\nexport const ws_base_url = ws_protocol + window.location.host + '/socket/ssh/';\r\nexport const http_base_url = http_protocol + '//' + window.location.host + '/api';\r\n\r\n// 本地开发环境\r\n// export const ws_base_url = 'ws://localhost:3000/socket/ssh/';\r\n// export const http_base_url = 'http://localhost:3000/api';\r\n\r\n// 在线环境\r\n// export const ws_base_url = 'wss://ssh.kkbpro.com/socket/ssh/';\r\n// export const http_base_url = 'https://ssh.kkbpro.com/api';","// 将 '/' 转为 '@'\r\nexport const changeStr = (str) => {\r\n let result = '';\r\n for (let i = 0; i < str.length; i++) {\r\n if(str[i] != '/') result += str[i];\r\n else result += '@';\r\n }\r\n \r\n return result;\r\n};\r\n\r\n// 转义字符串(路径)\r\nconst pathChars = /[ !\"#$&'()*,:;<=>?@[\\]^`]/g;\r\nexport const escapePath = (str) => {\r\n return str.replace(pathChars, function(match) {\r\n return '\\\\' + match;\r\n });\r\n};\r\n\r\n// 转义字符串(文件项)\r\nexport const escapeItem = (str) => {\r\n return escapePath(str);\r\n};","\r\n \r\n \r\n \r\n
\r\n
配 置:
\r\n
0) ? 'new-option': 'old-option'\" >{{ !(setInfo.option && setInfo.option.length > 0) ? '新建配置' : setInfo.option }}
\r\n
\r\n
切换
\r\n
保存
\r\n
新建
\r\n
\r\n
\r\n
主机ip:
\r\n
\r\n \r\n \r\n \r\n \r\n \r\n
\r\n
\r\n
\r\n
\r\n
端口号:
\r\n
\r\n
\r\n \r\n \r\n \r\n \r\n
\r\n
\r\n
\r\n
\r\n
用户名:
\r\n
\r\n \r\n \r\n \r\n \r\n \r\n
\r\n
\r\n
\r\n
\r\n
密 码:
\r\n
\r\n \r\n \r\n \r\n \r\n \r\n
\r\n
\r\n
\r\n
\r\n
\r\n {{ err_msg }}
\r\n \r\n \r\n
\r\n
\r\n 确定\r\n \r\n
\r\n \r\n\r\n \r\n \r\n\r\n\r\n\r\n\r\n","\r\n \r\n \r\n \r\n
0\" class=\"kk-border\">\r\n
\r\n
\r\n
\r\n \r\n
\r\n
\r\n
配置名:
\r\n
\r\n \r\n \r\n
\r\n
\r\n \r\n {{ opType ? '保存' : '选择'}}\r\n \r\n
\r\n
\r\n
\r\n \r\n \r\n\r\n\r\n\r\n\r\n","\r\n \r\n
\r\n
\r\n
\r\n

\r\n
\r\n
{{ msg }}
\r\n
\r\n
\r\n\r\n\r\n\r\n\r\n","import { render } from \"./NoData.vue?vue&type=template&id=7a3a533e&scoped=true\"\nimport script from \"./NoData.vue?vue&type=script&lang=js\"\nexport * from \"./NoData.vue?vue&type=script&lang=js\"\n\nimport \"./NoData.vue?vue&type=style&index=0&id=7a3a533e&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-7a3a533e\"]])\n\nexport default __exports__","import { render } from \"./OptionBlock.vue?vue&type=template&id=1f07a939&scoped=true\"\nimport script from \"./OptionBlock.vue?vue&type=script&lang=js\"\nexport * from \"./OptionBlock.vue?vue&type=script&lang=js\"\n\nimport \"./OptionBlock.vue?vue&type=style&index=0&id=1f07a939&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-1f07a939\"]])\n\nexport default __exports__","import { render } from \"./ConnectSetting.vue?vue&type=template&id=bf2f54ee&scoped=true\"\nimport script from \"./ConnectSetting.vue?vue&type=script&lang=js\"\nexport * from \"./ConnectSetting.vue?vue&type=script&lang=js\"\n\nimport \"./ConnectSetting.vue?vue&type=style&index=0&id=bf2f54ee&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-bf2f54ee\"]])\n\nexport default __exports__","\r\n \r\n \r\n \r\n
\r\n
颜色:
\r\n
\r\n
背景色
\r\n
\r\n \r\n
\r\n
\r\n
\r\n
\r\n
前景色
\r\n
\r\n \r\n
\r\n
\r\n
\r\n
\r\n
文本:
\r\n
\r\n
字体
\r\n
\r\n {{ setInfo.fontFamily }}\r\n \r\n \r\n \r\n {{ font }}\r\n \r\n \r\n \r\n \r\n
\r\n
\r\n
字号
\r\n
\r\n {{ setInfo.fontSize }}\r\n \r\n \r\n \r\n {{ size }}\r\n \r\n \r\n \r\n \r\n
\r\n
\r\n
\r\n
光标:
\r\n
\r\n
样式
\r\n
\r\n {{ setInfo.cursorStyle }}\r\n \r\n \r\n \r\n {{ style }}\r\n \r\n \r\n \r\n \r\n
\r\n
\r\n
闪烁
\r\n
\r\n \r\n
\r\n
\r\n
\r\n
\r\n
功能:
\r\n
\r\n
TCode
\r\n
\r\n \r\n
\r\n
\r\n
\r\n
\r\n \r\n \r\n
\r\n
\r\n 确定\r\n \r\n
\r\n \r\n\r\n\r\n\r\n\r\n","import { render } from \"./StyleSetting.vue?vue&type=template&id=d18bce82&scoped=true\"\nimport script from \"./StyleSetting.vue?vue&type=script&lang=js\"\nexport * from \"./StyleSetting.vue?vue&type=script&lang=js\"\n\nimport \"./StyleSetting.vue?vue&type=style&index=0&id=d18bce82&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-d18bce82\"]])\n\nexport default __exports__","\r\n \r\n \r\n \r\n
\r\n
\r\n
\r\n \r\n
\r\n
{{ dir }}
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n \r\n \r\n \r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n \r\n
\r\n
\r\n \r\n
\r\n
{{ item.name }}
\r\n
\r\n \r\n
\r\n \r\n
\r\n
\r\n \r\n
\r\n
{{ item.name }}
\r\n
\r\n \r\n
\r\n
\r\n
\r\n \r\n
\r\n
\r\n
\r\n \r\n \r\n\r\n \r\n \r\n \r\n\r\n \r\n\r\n\r\n\r\n\r\n\r\n","\r\n \r\n \r\n \r\n
\r\n
{{ modifyTag + fileName }}
\r\n
\r\n \r\n \r\n \r\n \r\n \r\n\r\n\r\n\r\n\r\n","\r\n \r\n\r\n\r\n\r\n\r\n","const langs = {\r\n \"c\": \"c_cpp\",\r\n \"h\": \"c_cpp\",\r\n \"cpp\": \"c_cpp\",\r\n \"hpp\": \"c_cpp\",\r\n \"cs\": \"csharp\",\r\n \"css\": \"css\",\r\n \"gitignore\": \"gitignore\",\r\n \"go\": \"golang\",\r\n \"html\": \"html\",\r\n \"htm\": \"html\",\r\n \"java\": \"java\",\r\n \"js\": \"javascript\",\r\n \"jsx\": \"javascript\",\r\n \"json\": \"json\",\r\n \"jsp\": \"jsp\",\r\n \"md\": \"markdown\",\r\n \"markdown\": \"markdown\",\r\n \"properties\": \"properties\",\r\n \"py\": \"python\",\r\n \"sh\": \"sh\",\r\n \"bash\": \"sh\",\r\n \"sql\": \"sql\",\r\n \"ts\": \"typescript\",\r\n \"tsx\": \"typescript\",\r\n \"vue\": \"javascript\",\r\n \"xml\": \"xml\",\r\n \"xsd\": \"xml\",\r\n \"xsl\": \"xml\",\r\n \"xslt\": \"xml\",\r\n \"yaml\": \"yaml\",\r\n \"yml\": \"yaml\",\r\n};\r\n\r\n// 获取文件名后缀\r\nconst getSuffix = (name) => {\r\n let suffix = 'txt';\r\n if(name && name.length > 0) {\r\n let index = name.lastIndexOf('.');\r\n if(index != -1) suffix = name.substring(index + 1);\r\n }\r\n return suffix;\r\n};\r\n\r\n// 文件名 => 语言\r\nconst langToMode = (name) => {\r\n return langs[getSuffix(name)] || \"text\";\r\n};\r\n\r\nexport default langToMode;","import { encrypt, decrypt } from './Encrypt';\r\nconst storageLocalKey = 'tcode-local-vars';\r\nconst storageSessionPrefix = 'tcode-session-vars-';\r\n\r\n// 功能TCode, 以 / 开头\r\nexport const FuncTcode = {\r\n '/A': {\r\n desc: '自定义TCode',\r\n execFlow(context) {\r\n setTimeout(() => {\r\n context.proxy.userTcodeRef.initText();\r\n },1);\r\n context.proxy.userTcodeRef.DialogVisilble = true;\r\n }\r\n },\r\n '/O': {\r\n desc: '新建窗口',\r\n execFlow() {\r\n let _url = window.location.href;\r\n window.open(_url, '_blank');\r\n }\r\n },\r\n '/C': {\r\n desc: '关闭窗口',\r\n execFlow() {\r\n window.close();\r\n }\r\n },\r\n '/E': {\r\n desc: '退出登录',\r\n execFlow(context) {\r\n if(context.proxy.socket) context.proxy.socket.close(3131);\r\n }\r\n },\r\n '/R': {\r\n desc: '刷新页面',\r\n execFlow() {\r\n window.location.reload();\r\n }\r\n },\r\n '/H': {\r\n desc: '帮助',\r\n execFlow(context) {\r\n context.proxy.helpTcodeRef.DialogVisilble = true;\r\n }\r\n },\r\n};\r\n\r\n// 系统TCode, 以 S 开头\r\nexport const SysTcode = {\r\n 'SC': {\r\n desc: '连接设置',\r\n execFlow(context) {\r\n context.proxy.isShowSetting = false;\r\n context.proxy.connectSettingRef.DialogVisilble = true;\r\n }\r\n },\r\n 'SP': {\r\n desc: '偏好设置',\r\n execFlow(context) {\r\n context.proxy.isShowSetting = false;\r\n context.proxy.styleSettingRef.DialogVisilble = true;\r\n }\r\n },\r\n 'SF': {\r\n desc: '文件管理',\r\n execFlow(context) {\r\n context.proxy.isShowSetting = false;\r\n context.proxy.fileBlockRef.DialogVisilble = true;\r\n context.proxy.fileBlockRef.getInitDir();\r\n }\r\n },\r\n 'SS': {\r\n desc: '重启',\r\n execFlow(context) {\r\n context.proxy.isShowSetting = false;\r\n context.proxy.now_connect_status = context.proxy.connect_status['Connecting'];\r\n context.proxy.sshKey = '';\r\n if(context.proxy.socket) context.proxy.socket.close(3333); // 主动释放资源,必需\r\n // 进行重启\r\n context.proxy.closeFileBlock();\r\n context.proxy.doSSHConnect();\r\n context.proxy.resetTerminal();\r\n }\r\n }\r\n};\r\n\r\n// 用户TCode, 以 U 开头\r\nexport const UserTcodeExecutor = {\r\n active: false,\r\n display: true,\r\n outArray: [],\r\n cnt: 0,\r\n // 变量\r\n variables: {\r\n session(key,value) {\r\n if(value != undefined) sessionStorage.setItem(storageSessionPrefix + key,JSON.stringify(value));\r\n else {\r\n if(sessionStorage.getItem(storageSessionPrefix + key)) return JSON.parse(sessionStorage.getItem(storageSessionPrefix + key));\r\n else return null;\r\n }\r\n },\r\n local(key,value) {\r\n let tcodeLocalVars = {};\r\n if(localStorage.getItem(storageLocalKey)) {\r\n tcodeLocalVars = JSON.parse(decrypt(localStorage.getItem(storageLocalKey)));\r\n }\r\n if(value != undefined) {\r\n tcodeLocalVars[key] = value;\r\n localStorage.setItem(storageLocalKey,encrypt(JSON.stringify(tcodeLocalVars)));\r\n }\r\n else return tcodeLocalVars[key];\r\n },\r\n clean() {\r\n if(arguments.length == 0) {\r\n localStorage.removeItem(storageLocalKey);\r\n return;\r\n }\r\n let tcodeLocalVars = {};\r\n if(localStorage.getItem(storageLocalKey)) {\r\n tcodeLocalVars = JSON.parse(decrypt(localStorage.getItem(storageLocalKey)));\r\n }\r\n for (let i = 0; i < arguments.length; i++) {\r\n delete tcodeLocalVars[arguments[i]];\r\n }\r\n localStorage.setItem(storageLocalKey,encrypt(JSON.stringify(tcodeLocalVars)));\r\n }\r\n },\r\n // 仅向terminal写入,不等待\r\n writeOnly: null,\r\n // 向terminal写入并等待\r\n async writeAndWait(content, time = 200) {\r\n if(content && content.length > 0 && content[content.length - 1] != '\\n' && content[content.length - 1] != '\\r') content += '\\n';\r\n this.cnt = this.outArray.length;\r\n this.writeOnly(content,true);\r\n await new Promise(resolve => setTimeout(resolve, time > 0 ? time : 0));\r\n },\r\n // writeAndWait简写\r\n write(content, time = 200) {\r\n return this.writeAndWait(content, time);\r\n },\r\n // 读取输出\r\n read() {\r\n return filter(this.outArray.slice(this.cnt));\r\n },\r\n // 读取全部输出\r\n readAll() {\r\n return filter(this.outArray.slice(0));\r\n },\r\n // 隐藏\r\n hide() {\r\n this.display = false;\r\n },\r\n // 显示\r\n show() {\r\n this.display = true;\r\n },\r\n};\r\n\r\n// 处理过滤输出\r\nconst filter = (arr) => {\r\n let ret = [];\r\n let tmp = filterRN(arr);\r\n for(let i = 0; i < tmp.length; i++) {\r\n let str = filterANSI(tmp[i]);\r\n if(str && str != '') ret.push(str);\r\n }\r\n return ret;\r\n};\r\n\r\n// 以 \\r\\n 分割\r\nconst filterRN = (arr) => {\r\n let ret = [];\r\n for(let i = 0; i < arr.length; i++) {\r\n let tmp = arr[i].split(\"\\r\\n\");\r\n for(let j = 0; j < tmp.length; j++) {\r\n if (tmp[j] && tmp[j] != '') ret.push(tmp[j]);\r\n }\r\n }\r\n return ret;\r\n};\r\n// 过滤 ANSI 等终端字符\r\nimport stripAnsi from 'strip-ansi';\r\nconst filterANSI = (str) => {\r\n // eslint-disable-next-line\r\n return stripAnsi(str).replace(/[\\x00-\\x1F\\x7F]/g, '');\r\n};\r\n\r\n// 用户TCode状态枚举\r\n// Error-加载失败: Load Error\r\n// Interrupted-执行失败: Execute Error\r\n// Inactive-未被使用: Not Active\r\n// Success-执行成功: Execute Success\r\nexport const TCodeStatusEnum = {\r\n 'Load Error': 'Error',\r\n 'Execute Error':'Interrupted',\r\n 'Not Active': 'Inactive',\r\n 'Execute Success': 'Success',\r\n};\r\n\r\n\r\n// 编辑器添加kkTerminal智能提示\r\nexport const userTcodeExecutorCompleter = {\r\n getCompletions: function(editor, session, pos, prefix, callback) {\r\n const userTcodeExecutorCompletions = [\r\n {\r\n name: \"kkTerminal\",\r\n value: \"kkTerminal\",\r\n meta: \"kkTerminal\",\r\n description: \"kkTerminal API\",\r\n score: 1000,\r\n },\r\n {\r\n name: \"variables\",\r\n value: \"variables\",\r\n meta: \"kkTerminal\",\r\n description: \"access variables\",\r\n score: 1000,\r\n },\r\n {\r\n name: \"session\",\r\n value: \"session()\",\r\n meta: \"kkTerminal\",\r\n description: \"get or set session variables\",\r\n score: 1000,\r\n },\r\n {\r\n name: \"local\",\r\n value: \"local()\",\r\n meta: \"kkTerminal\",\r\n description: \"get or set local variables\",\r\n score: 1000,\r\n },\r\n {\r\n name: \"clean\",\r\n value: \"clean()\",\r\n meta: \"kkTerminal\",\r\n description: \"remove local variables\",\r\n score: 1000,\r\n },\r\n {\r\n name: \"write\",\r\n value: \"write()\",\r\n meta: \"kkTerminal\",\r\n description: \"write to terminal\",\r\n score: 1000,\r\n },\r\n {\r\n name: \"read\",\r\n value: \"read()\",\r\n meta: \"kkTerminal\",\r\n description: \"read lastest from terminal\",\r\n score: 1000,\r\n },\r\n {\r\n name: \"readAll\",\r\n value: \"readAll()\",\r\n meta: \"kkTerminal\",\r\n description: \"read all from terminal\",\r\n score: 1000,\r\n },\r\n {\r\n name: \"hide\",\r\n value: \"hide()\",\r\n meta: \"kkTerminal\",\r\n description: \"hide TCode display\",\r\n score: 1000,\r\n },\r\n {\r\n name: \"show\",\r\n value: \"show()\",\r\n meta: \"kkTerminal\",\r\n description: \"show TCode display\",\r\n score: 1000,\r\n }\r\n ];\r\n\r\n callback(null, userTcodeExecutorCompletions.map((completion) => {\r\n return {\r\n caption: completion.caption || completion.name,\r\n value: completion.value,\r\n meta: completion.meta,\r\n description: completion.description || ''\r\n };\r\n }));\r\n }\r\n};","import { render } from \"./AceEditor.vue?vue&type=template&id=980ea70c&scoped=true\"\nimport script from \"./AceEditor.vue?vue&type=script&lang=js\"\nexport * from \"./AceEditor.vue?vue&type=script&lang=js\"\n\nimport \"./AceEditor.vue?vue&type=style&index=0&id=980ea70c&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-980ea70c\"]])\n\nexport default __exports__","import { render } from \"./TxtPreview.vue?vue&type=template&id=d5692da0&scoped=true\"\nimport script from \"./TxtPreview.vue?vue&type=script&lang=js\"\nexport * from \"./TxtPreview.vue?vue&type=script&lang=js\"\n\nimport \"./TxtPreview.vue?vue&type=style&index=0&id=d5692da0&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-d5692da0\"]])\n\nexport default __exports__","\r\n \r\n \r\n \r\n
\r\n 文件\r\n 文件夹\r\n \r\n
{{ err_msg }}
\r\n
\r\n
\r\n \r\n \r\n
\r\n
\r\n
\r\n \r\n \r\n
\r\n
\r\n 确定\r\n
\r\n
\r\n
\r\n \r\n \r\n\r\n\r\n\r\n\r\n","import { render } from \"./MkFile.vue?vue&type=template&id=cb2a471c&scoped=true\"\nimport script from \"./MkFile.vue?vue&type=script&lang=js\"\nexport * from \"./MkFile.vue?vue&type=script&lang=js\"\n\nimport \"./MkFile.vue?vue&type=style&index=0&id=cb2a471c&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-cb2a471c\"]])\n\nexport default __exports__","\r\n \r\n \r\n \r\n \r\n
\r\n
{{ fileInfo.name }}
\r\n
属性
\r\n
\r\n \r\n \r\n \r\n
\r\n
\r\n
\r\n
位置:
\r\n
\r\n {{ fileDir + fileInfo.name }}\r\n
\r\n
\r\n
\r\n
\r\n
包含:
\r\n
\r\n {{ includeInfo }}\r\n
\r\n
\r\n unsure\r\n
\r\n
\r\n
\r\n
大小:
\r\n
\r\n {{ calcSize(fileInfo.attributes.size) }} ({{ fileInfo.attributes.size + ' 字节' }})\r\n
\r\n
\r\n unsure\r\n
\r\n
\r\n
\r\n
\r\n
修改时间:
\r\n
\r\n {{ formatDate(fileInfo.attributes.mtime) }}\r\n
\r\n
\r\n
\r\n
访问时间:
\r\n
\r\n {{ formatDate(fileInfo.attributes.atime) }}\r\n
\r\n
\r\n
\r\n
\r\n
权限:
\r\n
\r\n {{ calcPriority(fileInfo.attributes.mode.type,fileInfo.attributes.permissions) }}\r\n
\r\n
\r\n
\r\n 确定\r\n
\r\n
\r\n
\r\n \r\n \r\n\r\n\r\n\r\n\r\n","// 将时间戳转为 2024年1月22日,20:40:38 格式\r\nexport const formatDate = (time) => {\r\n if(!time) return \"\";\r\n let date = new Date(time*1000);\r\n let year = date.getFullYear();\r\n let month = date.getMonth() + 1;\r\n let day = date.getDate();\r\n let hour = date.getHours();\r\n let min = date.getMinutes();\r\n let seconds = date.getSeconds();\r\n\r\n if(month < 10) month = \"0\" + month;\r\n if(day < 10) day = \"0\" + day;\r\n if(hour < 10) hour = \"0\" + hour;\r\n if(min < 10) min = \"0\" + min;\r\n if(seconds < 10) seconds = \"0\" + seconds;\r\n\r\n return year + \"年\" + month + \"月\" + day + \"日,\" + hour + \":\" + min + \":\" + seconds;\r\n};","export const calcPriority = (type,attrs) => {\r\n return getType(type) + getAttrs(attrs);\r\n};\r\n\r\nconst fileTypeSymbols = {\r\n 'BLOCK_SPECIAL': 'b',\r\n 'CHAR_SPECIAL': 'c',\r\n 'FIFO_SPECIAL': 'p',\r\n 'SOCKET_SPECIAL': 's',\r\n 'REGULAR': '-',\r\n 'DIRECTORY': 'd',\r\n 'SYMLINK': 'l',\r\n 'UNKNOWN': '?'\r\n};\r\n\r\nconst getType = (type) => {\r\n return fileTypeSymbols[type];\r\n};\r\n\r\nconst permissionMap = {\r\n 'USR_R': 256,\r\n 'USR_W': 128,\r\n 'USR_X': 64,\r\n 'GRP_R': 32,\r\n 'GRP_W': 16,\r\n 'GRP_X': 8,\r\n 'OTH_R': 4,\r\n 'OTH_W': 2,\r\n 'OTH_X': 1,\r\n 'SUID': 2048,\r\n 'SGID': 1024,\r\n 'STICKY': 512\r\n};\r\n\r\nconst getAttrs = (attrs) => {\r\n let symbol = '---------';\r\n // 将权限数组转换为对应的权限值总和\r\n let permissionValue = 0;\r\n for(let i=0;i {\r\n if (specialPermission) symbol = symbol.substring(0, index) + (attr ? specialChar : noPermissionChar) + symbol.substring(index + 1);\r\n else symbol = symbol.substring(0, index) + (attr ? char : symbol[index]) + symbol.substring(index + 1);\r\n return symbol;\r\n};","export const calcSize = (sizeRaw) => {\r\n if(sizeRaw == null || sizeRaw == undefined) return \"\";\r\n let size = \"\";\r\n if (sizeRaw < 1024) { // B\r\n size = sizeRaw.toFixed(2) + \" B\"\r\n } else if (sizeRaw < 1024 * 1024) { // KB\r\n size = (sizeRaw / 1024).toFixed(2) + \" KB\"\r\n } else if (sizeRaw < 1024 * 1024 * 1024) { // MB\r\n size = (sizeRaw / (1024 * 1024)).toFixed(2) + \" MB\"\r\n } else { // GB\r\n size = (sizeRaw / (1024 * 1024 * 1024)).toFixed(2) + \" GB\"\r\n }\r\n let sizeStr = size + \"\"; // 转成字符串\r\n let index = sizeStr.indexOf(\".\"); // 获取小数点处的索引\r\n let dou = sizeStr.substring(index + 1, index + 3) // 获取小数点后两位的值\r\n if (dou == \"00\") { // 判断后两位是否为00,如果是则删除00 \r\n return sizeStr.substring(0, index) + sizeStr.substring(index + 3)\r\n }\r\n return size;\r\n};","import { render } from \"./FileAttr.vue?vue&type=template&id=2c6df403&scoped=true\"\nimport script from \"./FileAttr.vue?vue&type=script&lang=js\"\nexport * from \"./FileAttr.vue?vue&type=script&lang=js\"\n\nimport \"./FileAttr.vue?vue&type=style&index=0&id=2c6df403&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-2c6df403\"]])\n\nexport default __exports__","import { render } from \"./FileBlock.vue?vue&type=template&id=32fde74a&scoped=true\"\nimport script from \"./FileBlock.vue?vue&type=script&lang=js\"\nexport * from \"./FileBlock.vue?vue&type=script&lang=js\"\n\nimport \"./FileBlock.vue?vue&type=style&index=0&id=32fde74a&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-32fde74a\"]])\n\nexport default __exports__","\r\n \r\n \r\n \r\n
\r\n
TCode:
\r\n
U
\r\n
\r\n \r\n \r\n \r\n \r\n
\r\n
\r\n \r\n \r\n 导入\r\n \r\n \r\n
\r\n
\r\n
\r\n
描 述:
\r\n
\r\n \r\n \r\n \r\n \r\n
\r\n
\r\n \r\n 导出\r\n \r\n
\r\n
\r\n
\r\n
\r\n
Workflow
\r\n
\r\n
\r\n \r\n \r\n \r\n
\r\n
\r\n \r\n \r\n \r\n
\r\n
\r\n \r\n \r\n \r\n
\r\n
\r\n
\r\n
\r\n \r\n
\r\n
\r\n 确定\r\n \r\n
\r\n \r\n\r\n\r\n\r\n\r\n","import { render } from \"./UserTcode.vue?vue&type=template&id=c9882564&scoped=true\"\nimport script from \"./UserTcode.vue?vue&type=script&lang=js\"\nexport * from \"./UserTcode.vue?vue&type=script&lang=js\"\n\nimport \"./UserTcode.vue?vue&type=style&index=0&id=c9882564&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-c9882564\"]])\n\nexport default __exports__","\r\n \r\n \r\n \r\n
\r\n \r\n \r\n
以 / 开头,用于快速执行通用功能
\r\n
\r\n
\r\n
\r\n
{{ key }}
\r\n
{{ item.desc }}
\r\n
\r\n
\r\n
\r\n \r\n \r\n \r\n
以 S 开头,用于快速访问系统模块
\r\n
\r\n
\r\n
\r\n
{{ key }}
\r\n
{{ item.desc }}
\r\n
\r\n
\r\n
\r\n \r\n \r\n \r\n
0\" >\r\n = 2 && nowTCode.length <= 6\" >\r\n \r\n
\r\n
{{ modifyTag + nowTCode }}
\r\n
\r\n \r\n \r\n \r\n
\r\n
\r\n
\r\n \r\n \r\n \r\n
\r\n
\r\n \r\n \r\n \r\n
\r\n
\r\n \r\n \r\n \r\n
\r\n
\r\n
\r\n \r\n \r\n \r\n 以 U 开头,自定义实现类似Shell脚本的自动化Workflow
\r\n \r\n \r\n
\r\n
\r\n
{{ item.desc }}
\r\n
\r\n
\r\n \r\n \r\n \r\n
\r\n
\r\n
\r\n
\r\n \r\n \r\n
\r\n 以 U 开头,自定义实现类似Shell脚本的自动化Workflow
\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n
\r\n \r\n \r\n
\r\n \r\n\r\n\r\n\r\n\r\n","\r\n
\r\n
\r\n
\r\n
\r\n\r\n\r\n\r\n\r\n","import { render } from \"./TcodeStatus.vue?vue&type=template&id=779311f7\"\nimport script from \"./TcodeStatus.vue?vue&type=script&lang=js\"\nexport * from \"./TcodeStatus.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 { render } from \"./HelpTcode.vue?vue&type=template&id=bfe11042&scoped=true\"\nimport script from \"./HelpTcode.vue?vue&type=script&lang=js\"\nexport * from \"./HelpTcode.vue?vue&type=script&lang=js\"\n\nimport \"./HelpTcode.vue?vue&type=style&index=0&id=bfe11042&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-bfe11042\"]])\n\nexport default __exports__","import { render } from \"./FrameWork.vue?vue&type=template&id=1d051994&scoped=true\"\nimport script from \"./FrameWork.vue?vue&type=script&lang=js\"\nexport * from \"./FrameWork.vue?vue&type=script&lang=js\"\n\nimport \"./FrameWork.vue?vue&type=style&index=0&id=1d051994&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-1d051994\"]])\n\nexport default __exports__","import { render } from \"./App.vue?vue&type=template&id=47d20700\"\nimport script from \"./App.vue?vue&type=script&lang=js\"\nexport * from \"./App.vue?vue&type=script&lang=js\"\n\nimport \"./App.vue?vue&type=style&index=0&id=47d20700&lang=css\"\n\nimport exportComponent from \"../node_modules/vue-loader/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render]])\n\nexport default __exports__","// jQuery配置Ajax全局响应拦截,进行数据解密\r\nimport $ from 'jquery';\r\nimport { decrypt } from '@/utils/Encrypt';\r\n\r\n$.ajaxSetup({\r\n processData: true,\r\n // 携带cookie\r\n xhrFields:{\r\n withCredentials: true,\r\n },\r\n dataFilter(resp) {\r\n resp = JSON.parse(resp);\r\n let data = resp.data;\r\n if(data) resp.data = JSON.parse(decrypt(resp.data));\r\n return JSON.stringify(resp);\r\n },\r\n});\r\n\r\nimport { createApp } from 'vue';\r\nimport App from './App.vue';\r\n\r\nconst app = createApp(App);\r\n\r\n// 按需引入element-plus\r\nimport 'element-plus/dist/index.css';\r\nimport { ElButton, ElDialog, ElIcon, ElInput, ElUpload, ElColorPicker,ElDropdown, ElDropdownMenu, ElDropdownItem, ElSwitch, ElLoading, ElRadioGroup, ElRadio, ElPopover, ElTabs, ElTabPane, ElResult, ElTooltip, ElTag } from 'element-plus';\r\napp.use(ElButton).use(ElDialog).use(ElIcon).use(ElInput).use(ElUpload).use(ElColorPicker).use(ElTabs).use(ElTabPane).use(ElResult).use(ElTooltip);\r\napp.use(ElDropdown).use(ElDropdownMenu).use(ElDropdownItem).use(ElSwitch).use(ElLoading).use(ElRadioGroup).use(ElRadio).use(ElPopover).use(ElTag);\r\n\r\n// 按需引入ant-design\r\nimport 'ant-design-vue/dist/reset.css';\r\nimport { Popconfirm } from 'ant-design-vue';\r\napp.use(Popconfirm);\r\n\r\napp.mount('#app');\r\n\r\n// 引入全局样式\r\nimport './assets/base.css';\r\n\r\n//用于去掉eazyplayer警告,开发时禁用,打包开启\r\napp.config.warnHandler = () => {};","// 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\tid: moduleId,\n\t\tloaded: false,\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// Flag the module as loaded\n\tmodule.loaded = true;\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","__webpack_require__.amdD = function () {\n\tthrow new Error('define cannot be used indirect');\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__.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); }","// 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__.nmd = function(module) {\n\tmodule.paths = [];\n\tif (!module.children) module.children = [];\n\treturn module;\n};","__webpack_require__.p = \"/\";","// 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\t143: 0\n};\n\n// no chunk on demand loading\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[\"webpackChunkterminal\"] = self[\"webpackChunkterminal\"] || [];\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, [998], function() { return __webpack_require__(7883); })\n__webpack_exports__ = __webpack_require__.O(__webpack_exports__);\n"],"names":["SECRET_KEY","encrypt","word","key","CryptoJS","Utf8","parse","srcs","encrypted","mode","ECB","padding","Pkcs7","toString","decrypt","stringify","_createBlock","_component_FrameWork","class","_createElementVNode","_hoisted_3","_hoisted_5","_hoisted_7","_hoisted_9","src","_imports_0","alt","style","_hoisted_12","ref","_hoisted_1","_hoisted_2","onClick","_cache","$event","$setup","doSettings","isShowSetting","_hoisted_11","args","showSettings","_hoisted_14","_hoisted_15","env","tCode","_createElementBlock","_hoisted_16","_hoisted_17","_hoisted_18","_createVNode","_component_el_input","tcode","id","width","height","fontSize","onKeydown","_withKeys","handleTcode","maxlength","_hoisted_19","_component_el_popover","placement","trigger","reference","_withCtx","_component_el_icon","color","_component_QuestionFilled","_hoisted_20","_hoisted_21","_hoisted_22","_component_ConnectSetting","sshOptions","options","onSaveOp","saveOp","onCallback","saveEnv","_component_StyleSetting","os","osInfo","clientOS","_component_FileBlock","sshKey","_component_UserTcode","onImportTCodes","importTCodes","onExportTcodes","exportTcodes","_component_HelpTcode","userTCodes","tcodes","onHandleSaveTCode","handleSaveTCode","default_env","server_ip","server_port","server_user","server_password","option","bg","fg","fontFamily","cursorStyle","cursorBlink","http_protocol","window","location","protocol","ws_protocol","ws_base_url","host","http_base_url","changeStr","str","result","i","length","pathChars","escapePath","replace","match","escapeItem","_component_el_dialog","DialogVisilble","closeDialog","title","modal","draggable","_normalizeClass","setInfo","_hoisted_4","_component_el_button","size","type","showOption","_component_Switch","isForbidInput","_component_Finished","newOp","_component_Edit","_hoisted_6","disabled","placeholder","prefix","_component_HomeFilled","doCopy","_component_DocumentCopy","_hoisted_8","_component_Paperclip","_hoisted_10","_component_User","isShowPassword","_component_Lock","_component_View","_component_Hide","_hoisted_13","_toDisplayString","err_msg","confirm","_component_OptionBlock","doOption","opType","optionBlockType","$props","Object","keys","_Fragment","_renderList","value","aimOption","_component_FileIcons","name","isFolder","_component_NoData","msg","noDataMsg","_normalizeStyle","viewStyle","_renderSlot","_ctx","$slots","undefined","components","props","String","required","default","setup","computed","__exports__","FileIcons","NoData","context","trim","emit","done","OptionBlock","HomeFilled","Paperclip","User","Lock","DocumentCopy","View","Hide","Edit","Finished","Switch","verifyParams","ipRegex","test","isNaN","optionBlockRef","toClipboard","useClipboard","async","content","ElMessage","message","grouping","repeatNum","Number","MIN_SAFE_INTEGER","setTimeout","_component_el_color_picker","_component_el_dropdown","dropdown","_component_el_dropdown_menu","fontFamilyList","font","index","_component_el_dropdown_item","_component_arrow_down","fontSizeList","_hoisted_23","cursorStyleList","_hoisted_24","_hoisted_25","_hoisted_26","_hoisted_27","_component_el_switch","_hoisted_28","_hoisted_29","_hoisted_30","_hoisted_31","_hoisted_32","_hoisted_33","_hoisted_34","_hoisted_35","ArrowDown","isShowDirInput","dir","onBlur","onMousedown","_withModifiers","onDblclick","onChange","dirInputCallback","doShowDirInput","doRefresh","_component_Refresh","doReturn","_component_Fold","selectedFiles","doDownload","_component_Download","dirStatus","doUpload","_component_el_upload","multiple","_component_Upload","onContextmenu","handleContextMenu","onScroll","handleScroll","onDragover","preventDefault","onDrop","handleFileDrag","tabindex","handleShortcutKeys","files","item","isDirectory","isSelected","addSelectFile","changeDir","opacity","isClipboard","isCtrlx","isShowRenameInput","renameFile","handleRename","preViewFile","loading","_component_TxtPreview","onDoSave","doSave","_component_MkFile","handleMkFile","_component_FileAttr","doRename","handleMenuSelect","_component_a_popconfirm","open","isShowMenu","isShowPop","overlayStyle","zIndex","marginLeft","okButton","handlePopConfirm","cancelButton","text","fileName","modifyTag","_component_AceEditor","onHandleChange","handleChange","onHandleSave","handleSave","langs","getSuffix","suffix","lastIndexOf","substring","langToMode","storageLocalKey","storageSessionPrefix","FuncTcode","desc","execFlow","proxy","userTcodeRef","initText","_url","href","close","socket","reload","helpTcodeRef","SysTcode","connectSettingRef","styleSettingRef","fileBlockRef","getInitDir","now_connect_status","connect_status","closeFileBlock","doSSHConnect","resetTerminal","UserTcodeExecutor","active","display","outArray","cnt","variables","session","sessionStorage","getItem","JSON","setItem","local","tcodeLocalVars","localStorage","clean","arguments","removeItem","writeOnly","writeAndWait","time","this","Promise","resolve","write","read","filter","slice","readAll","hide","show","arr","ret","tmp","filterRN","filterANSI","push","split","j","stripAnsi","TCodeStatusEnum","userTcodeExecutorCompleter","getCompletions","editor","pos","callback","userTcodeExecutorCompletions","meta","description","score","map","completion","caption","aceEditorRef","aceEditor","setValue","selection","clearSelection","getValue","reset","getSession","getUndoManager","setLanguage","setMode","setReadOnly","isReadOnly","backgroundColor","CtrlS","event","ctrlKey","metaKey","fromCharCode","which","toLowerCase","onMounted","ace","autoScrollEditorIntoView","copyWithEmptySelection","showPrintMargin","highlightActiveLine","enableBasicAutocompletion","enableSnippets","enableLiveAutocompletion","theme","completers","setOption","on","find","backwards","wrap","caseSensitive","wholeWord","regExp","findNext","findPrevious","addEventListener","onUnmounted","removeEventListener","AceEditor","fileUrl","codeEditorRef","resetEditor","url","$","method","dataType","dataFilter","resp","success","error","_component_el_radio_group","_component_el_radio","label","nowDir","indexOf","fileInfo","rename","fileDir","includeInfo","unreliable","_component_el_tag","calcSize","attributes","formatDate","mtime","atime","calcPriority","permissions","date","Date","year","getFullYear","month","getMonth","day","getDate","hour","getHours","min","getMinutes","seconds","getSeconds","attrs","getType","getAttrs","fileTypeSymbols","permissionMap","symbol","permissionValue","setPermissionSymbol","attr","char","specialPermission","specialChar","noPermissionChar","sizeRaw","toFixed","sizeStr","dou","getFileSize","data","getTime","path","beforeSend","status","parseInt","complete","getFolderInclude","Math","max","oldPath","newPath","TxtPreview","MkFile","FileAttr","Refresh","Fold","Download","Upload","lastSelectedIndex","click","shiftKey","start","end","splice","fileClipboard","confirmDirCorrect","getDirList","info","now_dir","getRemoteFileUrl","encodeURIComponent","getRemoteFolderUrl","parseUrl","urlParams","indexKey","indexPath","decodeURIComponent","downloadRemoteFile","a","document","createElement","body","appendChild","removeChild","downloadDir","new_dir","chunkSize","fileData","file","fileSize","chunks","ceil","fileId","uid","chunkIndex","pathVal","startUpLoad","chunk","chunkFile","formData","FormData","append","contentType","processData","code","alert","querySelector","focus","txtPreviewRef","mkFileRef","fileAttrRef","blob","Blob","File","random","fileAreaRef","items","dataTransfer","webkitGetAsEntry","isFile","nowPath","folderUpload","directoryEntry","basePath","reader","createReader","readEntries","entries","menuBlockRef","target","top","clientY","left","clientX","e","join","watch","renameDom","contains","fileCopyMove","dst","sureDelFileBtn","userTcodeInfo","minlength","_component_CollectionTag","importTcodes","_component_EditPen","workflowTab","_component_el_tooltip","_component_DocumentDelete","CollectionTag","EditPen","DocumentDelete","workflowTemplate","userTcodeEditorRef","isAlphaNumeric","regex","fileReader","FileReader","onload","scnt","fcnt","toUpperCase","workflow","onerror","readAsText","_component_el_tabs","_component_el_tab_pane","nowTCode","toOverview","_component_ArrowLeft","_component_TcodeStatus","doModifyTCode","doOnlyRead","doSaveTCode","toWorkflow","_component_ArrowRight","myslot","statusType","statusStyle","_component_CircleCloseFilled","_component_WarningFilled","_component_SuccessFilled","_component_InfoFilled","SuccessFilled","WarningFilled","CircleCloseFilled","InfoFilled","statusTypeMap","statusColor","TcodeStatus","ArrowRight","ArrowLeft","initTcodeEditor","ConnectSetting","StyleSetting","FileBlock","UserTcode","HelpTcode","QuestionFilled","instance","getCurrentInstance","fitAddon","FitAddon","loadOps","loadTCodes","loadEnv","nowOpInfo","terminal","term","isFirst","initTerminal","Terminal","rendererType","convertEol","scrollback","disableStdin","foreground","background","cursor","lineHeight","loadAddon","termFit","innerHeight","fit","readyState","WebSocket","OPEN","new_rows","proposeDimensions","rows","new_cols","cols","send","resize","onopen","onmessage","clear","output","_core","buffer","lines","onclose","userTcodeExecutorReset","new_env","sendMessage","putChinese","doPaste","pasteText","navigator","clipboard","readText","doClick","innerHTML","onKey","onSelectionChange","hasSelection","copyText","getSelection","copyTextTrim","timer","doHeartBeat","setInterval","serverOS","windowId","setTcodeStatus","transTcode","state","Function","textflow","tCodeData","URL","createObjectURL","download","revokeObjectURL","clearInterval","FrameWork","render","xhrFields","withCredentials","app","createApp","App","use","ElButton","ElDialog","ElIcon","ElInput","ElUpload","ElColorPicker","ElTabs","ElTabPane","ElResult","ElTooltip","ElDropdown","ElDropdownMenu","ElDropdownItem","ElSwitch","ElLoading","ElRadioGroup","ElRadio","ElPopover","ElTag","Popconfirm","mount","config","warnHandler","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","exports","module","loaded","__webpack_modules__","call","m","amdD","Error","deferred","O","chunkIds","fn","priority","notFulfilled","Infinity","fulfilled","every","r","n","getter","__esModule","d","definition","o","defineProperty","enumerable","get","g","globalThis","obj","prop","prototype","hasOwnProperty","Symbol","toStringTag","nmd","paths","children","p","installedChunks","chunkId","webpackJsonpCallback","parentChunkLoadingFunction","moreModules","runtime","some","chunkLoadingGlobal","self","forEach","bind","__webpack_exports__"],"sourceRoot":""}
\ No newline at end of file
diff --git a/backend/terminal/src/main/resources/static/js/chunk-vendors.915e7665.js b/backend/terminal/src/main/resources/static/js/chunk-vendors.7bcaa66b.js
similarity index 96%
rename from backend/terminal/src/main/resources/static/js/chunk-vendors.915e7665.js
rename to backend/terminal/src/main/resources/static/js/chunk-vendors.7bcaa66b.js
index 265bf55a..f896c6be 100644
--- a/backend/terminal/src/main/resources/static/js/chunk-vendors.915e7665.js
+++ b/backend/terminal/src/main/resources/static/js/chunk-vendors.7bcaa66b.js
@@ -70,5 +70,5 @@ return function(t){var n=e,r=n.lib,i=r.WordArray,o=r.Hasher,s=n.algo,a=i.create(
* Date: 2023-08-28T13:37Z
*/
function(t,n){"use strict";"object"===typeof e.exports?e.exports=t.document?n(t,!0):function(e){if(!e.document)throw new Error("jQuery requires a window with a document");return n(e)}:n(t)}("undefined"!==typeof window?window:this,(function(n,o){"use strict";var s=[],a=Object.getPrototypeOf,l=s.slice,c=s.flat?function(e){return s.flat.call(e)}:function(e){return s.concat.apply([],e)},u=s.push,d=s.indexOf,h={},p=h.toString,f=h.hasOwnProperty,g=f.toString,m=g.call(Object),v={},b=function(e){return"function"===typeof e&&"number"!==typeof e.nodeType&&"function"!==typeof e.item},y=function(e){return null!=e&&e===e.window},w=n.document,x={type:!0,src:!0,nonce:!0,noModule:!0};function A(e,t,n){n=n||w;var r,i,o=n.createElement("script");if(o.text=e,t)for(r in x)i=t[r]||t.getAttribute&&t.getAttribute(r),i&&o.setAttribute(r,i);n.head.appendChild(o).parentNode.removeChild(o)}function k(e){return null==e?e+"":"object"===typeof e||"function"===typeof e?h[p.call(e)]||"object":typeof e}var C="3.7.1",S=/HTML$/i,_=function(e,t){return new _.fn.init(e,t)};function E(e){var t=!!e&&"length"in e&&e.length,n=k(e);return!b(e)&&!y(e)&&("array"===n||0===t||"number"===typeof t&&t>0&&t-1 in e)}function R(e,t){return e.nodeName&&e.nodeName.toLowerCase()===t.toLowerCase()}_.fn=_.prototype={jquery:C,constructor:_,length:0,toArray:function(){return l.call(this)},get:function(e){return null==e?l.call(this):e<0?this[e+this.length]:this[e]},pushStack:function(e){var t=_.merge(this.constructor(),e);return t.prevObject=this,t},each:function(e){return _.each(this,e)},map:function(e){return this.pushStack(_.map(this,(function(t,n){return e.call(t,n,t)})))},slice:function(){return this.pushStack(l.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},even:function(){return this.pushStack(_.grep(this,(function(e,t){return(t+1)%2})))},odd:function(){return this.pushStack(_.grep(this,(function(e,t){return t%2})))},eq:function(e){var t=this.length,n=+e+(e<0?t:0);return this.pushStack(n>=0&&n+~]|"+L+")"+L+"*"),U=new RegExp(L+"|>"),z=new RegExp(D),$=new RegExp("^"+E+"$"),W={ID:new RegExp("^#("+E+")"),CLASS:new RegExp("^\\.("+E+")"),TAG:new RegExp("^("+E+"|[*])"),ATTR:new RegExp("^"+B),PSEUDO:new RegExp("^"+D),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+L+"*(even|odd|(([+-]|)(\\d*)n|)"+L+"*(?:([+-]|)"+L+"*(\\d+)|))"+L+"*\\)|)","i"),bool:new RegExp("^(?:"+S+")$","i"),needsContext:new RegExp("^"+L+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+L+"*((?:-\\d)?\\d*)"+L+"*\\)|)(?=[^-]|$)","i")},q=/^(?:input|select|textarea|button)$/i,V=/^h\d$/i,Y=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,G=/[+~]/,K=new RegExp("\\\\[\\da-fA-F]{1,6}"+L+"?|\\\\([^\\r\\n\\f])","g"),Q=function(e,t){var n="0x"+e.slice(1)-65536;return t||(n<0?String.fromCharCode(n+65536):String.fromCharCode(n>>10|55296,1023&n|56320))},Z=function(){ce()},X=pe((function(e){return!0===e.disabled&&R(e,"fieldset")}),{dir:"parentNode",next:"legend"});function J(){try{return a.activeElement}catch(e){}}try{g.apply(s=l.call(F.childNodes),F.childNodes),s[F.childNodes.length].nodeType}catch(Ae){g={apply:function(e,t){P.apply(e,l.call(t))},call:function(e){P.apply(e,l.call(arguments,1))}}}function ee(e,t,n,r){var i,o,s,l,c,d,p,f=t&&t.ownerDocument,b=t?t.nodeType:9;if(n=n||[],"string"!==typeof e||!e||1!==b&&9!==b&&11!==b)return n;if(!r&&(ce(t),t=t||a,u)){if(11!==b&&(c=Y.exec(e)))if(i=c[1]){if(9===b){if(!(s=t.getElementById(i)))return n;if(s.id===i)return g.call(n,s),n}else if(f&&(s=f.getElementById(i))&&ee.contains(t,s)&&s.id===i)return g.call(n,s),n}else{if(c[2])return g.apply(n,t.getElementsByTagName(e)),n;if((i=c[3])&&t.getElementsByClassName)return g.apply(n,t.getElementsByClassName(i)),n}if(!k[e+" "]&&(!h||!h.test(e))){if(p=e,f=t,1===b&&(U.test(e)||j.test(e))){f=G.test(e)&&le(t.parentNode)||t,f==t&&v.scope||((l=t.getAttribute("id"))?l=_.escapeSelector(l):t.setAttribute("id",l=m)),d=de(e),o=d.length;while(o--)d[o]=(l?"#"+l:":scope")+" "+he(d[o]);p=d.join(",")}try{return g.apply(n,f.querySelectorAll(p)),n}catch(y){k(e,!0)}finally{l===m&&t.removeAttribute("id")}}}return xe(e.replace(O,"$1"),t,n,r)}function te(){var e=[];function n(r,i){return e.push(r+" ")>t.cacheLength&&delete n[e.shift()],n[r+" "]=i}return n}function ne(e){return e[m]=!0,e}function re(e){var t=a.createElement("fieldset");try{return!!e(t)}catch(Ae){return!1}finally{t.parentNode&&t.parentNode.removeChild(t),t=null}}function ie(e){return function(t){return R(t,"input")&&t.type===e}}function oe(e){return function(t){return(R(t,"input")||R(t,"button"))&&t.type===e}}function se(e){return function(t){return"form"in t?t.parentNode&&!1===t.disabled?"label"in t?"label"in t.parentNode?t.parentNode.disabled===e:t.disabled===e:t.isDisabled===e||t.isDisabled!==!e&&X(t)===e:t.disabled===e:"label"in t&&t.disabled===e}}function ae(e){return ne((function(t){return t=+t,ne((function(n,r){var i,o=e([],n.length,t),s=o.length;while(s--)n[i=o[s]]&&(n[i]=!(r[i]=n[i]))}))}))}function le(e){return e&&"undefined"!==typeof e.getElementsByTagName&&e}function ce(e){var n,r=e?e.ownerDocument||e:F;return r!=a&&9===r.nodeType&&r.documentElement?(a=r,c=a.documentElement,u=!_.isXMLDoc(a),p=c.matches||c.webkitMatchesSelector||c.msMatchesSelector,c.msMatchesSelector&&F!=a&&(n=a.defaultView)&&n.top!==n&&n.addEventListener("unload",Z),v.getById=re((function(e){return c.appendChild(e).id=_.expando,!a.getElementsByName||!a.getElementsByName(_.expando).length})),v.disconnectedMatch=re((function(e){return p.call(e,"*")})),v.scope=re((function(){return a.querySelectorAll(":scope")})),v.cssHas=re((function(){try{return a.querySelector(":has(*,:jqfake)"),!1}catch(Ae){return!0}})),v.getById?(t.filter.ID=function(e){var t=e.replace(K,Q);return function(e){return e.getAttribute("id")===t}},t.find.ID=function(e,t){if("undefined"!==typeof t.getElementById&&u){var n=t.getElementById(e);return n?[n]:[]}}):(t.filter.ID=function(e){var t=e.replace(K,Q);return function(e){var n="undefined"!==typeof e.getAttributeNode&&e.getAttributeNode("id");return n&&n.value===t}},t.find.ID=function(e,t){if("undefined"!==typeof t.getElementById&&u){var n,r,i,o=t.getElementById(e);if(o){if(n=o.getAttributeNode("id"),n&&n.value===e)return[o];i=t.getElementsByName(e),r=0;while(o=i[r++])if(n=o.getAttributeNode("id"),n&&n.value===e)return[o]}return[]}}),t.find.TAG=function(e,t){return"undefined"!==typeof t.getElementsByTagName?t.getElementsByTagName(e):t.querySelectorAll(e)},t.find.CLASS=function(e,t){if("undefined"!==typeof t.getElementsByClassName&&u)return t.getElementsByClassName(e)},h=[],re((function(e){var t;c.appendChild(e).innerHTML="",e.querySelectorAll("[selected]").length||h.push("\\["+L+"*(?:value|"+S+")"),e.querySelectorAll("[id~="+m+"-]").length||h.push("~="),e.querySelectorAll("a#"+m+"+*").length||h.push(".#.+[+~]"),e.querySelectorAll(":checked").length||h.push(":checked"),t=a.createElement("input"),t.setAttribute("type","hidden"),e.appendChild(t).setAttribute("name","D"),c.appendChild(e).disabled=!0,2!==e.querySelectorAll(":disabled").length&&h.push(":enabled",":disabled"),t=a.createElement("input"),t.setAttribute("name",""),e.appendChild(t),e.querySelectorAll("[name='']").length||h.push("\\["+L+"*name"+L+"*="+L+"*(?:''|\"\")")})),v.cssHas||h.push(":has"),h=h.length&&new RegExp(h.join("|")),C=function(e,t){if(e===t)return o=!0,0;var n=!e.compareDocumentPosition-!t.compareDocumentPosition;return n||(n=(e.ownerDocument||e)==(t.ownerDocument||t)?e.compareDocumentPosition(t):1,1&n||!v.sortDetached&&t.compareDocumentPosition(e)===n?e===a||e.ownerDocument==F&&ee.contains(F,e)?-1:t===a||t.ownerDocument==F&&ee.contains(F,t)?1:i?d.call(i,e)-d.call(i,t):0:4&n?-1:1)},a):a}for(e in ee.matches=function(e,t){return ee(e,null,null,t)},ee.matchesSelector=function(e,t){if(ce(e),u&&!k[t+" "]&&(!h||!h.test(t)))try{var n=p.call(e,t);if(n||v.disconnectedMatch||e.document&&11!==e.document.nodeType)return n}catch(Ae){k(t,!0)}return ee(t,a,null,[e]).length>0},ee.contains=function(e,t){return(e.ownerDocument||e)!=a&&ce(e),_.contains(e,t)},ee.attr=function(e,n){(e.ownerDocument||e)!=a&&ce(e);var r=t.attrHandle[n.toLowerCase()],i=r&&f.call(t.attrHandle,n.toLowerCase())?r(e,n,!u):void 0;return void 0!==i?i:e.getAttribute(n)},ee.error=function(e){throw new Error("Syntax error, unrecognized expression: "+e)},_.uniqueSort=function(e){var t,n=[],r=0,s=0;if(o=!v.sortStable,i=!v.sortStable&&l.call(e,0),M.call(e,C),o){while(t=e[s++])t===e[s]&&(r=n.push(s));while(r--)I.call(e,n[r],1)}return i=null,e},_.fn.uniqueSort=function(){return this.pushStack(_.uniqueSort(l.apply(this)))},t=_.expr={cacheLength:50,createPseudo:ne,match:W,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(e){return e[1]=e[1].replace(K,Q),e[3]=(e[3]||e[4]||e[5]||"").replace(K,Q),"~="===e[2]&&(e[3]=" "+e[3]+" "),e.slice(0,4)},CHILD:function(e){return e[1]=e[1].toLowerCase(),"nth"===e[1].slice(0,3)?(e[3]||ee.error(e[0]),e[4]=+(e[4]?e[5]+(e[6]||1):2*("even"===e[3]||"odd"===e[3])),e[5]=+(e[7]+e[8]||"odd"===e[3])):e[3]&&ee.error(e[0]),e},PSEUDO:function(e){var t,n=!e[6]&&e[2];return W.CHILD.test(e[0])?null:(e[3]?e[2]=e[4]||e[5]||"":n&&z.test(n)&&(t=de(n,!0))&&(t=n.indexOf(")",n.length-t)-n.length)&&(e[0]=e[0].slice(0,t),e[2]=n.slice(0,t)),e.slice(0,3))}},filter:{TAG:function(e){var t=e.replace(K,Q).toLowerCase();return"*"===e?function(){return!0}:function(e){return R(e,t)}},CLASS:function(e){var t=w[e+" "];return t||(t=new RegExp("(^|"+L+")"+e+"("+L+"|$)"))&&w(e,(function(e){return t.test("string"===typeof e.className&&e.className||"undefined"!==typeof e.getAttribute&&e.getAttribute("class")||"")}))},ATTR:function(e,t,n){return function(r){var i=ee.attr(r,e);return null==i?"!="===t:!t||(i+="","="===t?i===n:"!="===t?i!==n:"^="===t?n&&0===i.indexOf(n):"*="===t?n&&i.indexOf(n)>-1:"$="===t?n&&i.slice(-n.length)===n:"~="===t?(" "+i.replace(H," ")+" ").indexOf(n)>-1:"|="===t&&(i===n||i.slice(0,n.length+1)===n+"-"))}},CHILD:function(e,t,n,r,i){var o="nth"!==e.slice(0,3),s="last"!==e.slice(-4),a="of-type"===t;return 1===r&&0===i?function(e){return!!e.parentNode}:function(t,n,l){var c,u,d,h,p,f=o!==s?"nextSibling":"previousSibling",g=t.parentNode,v=a&&t.nodeName.toLowerCase(),y=!l&&!a,w=!1;if(g){if(o){while(f){d=t;while(d=d[f])if(a?R(d,v):1===d.nodeType)return!1;p=f="only"===e&&!p&&"nextSibling"}return!0}if(p=[s?g.firstChild:g.lastChild],s&&y){u=g[m]||(g[m]={}),c=u[e]||[],h=c[0]===b&&c[1],w=h&&c[2],d=h&&g.childNodes[h];while(d=++h&&d&&d[f]||(w=h=0)||p.pop())if(1===d.nodeType&&++w&&d===t){u[e]=[b,h,w];break}}else if(y&&(u=t[m]||(t[m]={}),c=u[e]||[],h=c[0]===b&&c[1],w=h),!1===w)while(d=++h&&d&&d[f]||(w=h=0)||p.pop())if((a?R(d,v):1===d.nodeType)&&++w&&(y&&(u=d[m]||(d[m]={}),u[e]=[b,w]),d===t))break;return w-=i,w===r||w%r===0&&w/r>=0}}},PSEUDO:function(e,n){var r,i=t.pseudos[e]||t.setFilters[e.toLowerCase()]||ee.error("unsupported pseudo: "+e);return i[m]?i(n):i.length>1?(r=[e,e,"",n],t.setFilters.hasOwnProperty(e.toLowerCase())?ne((function(e,t){var r,o=i(e,n),s=o.length;while(s--)r=d.call(e,o[s]),e[r]=!(t[r]=o[s])})):function(e){return i(e,0,r)}):i}},pseudos:{not:ne((function(e){var t=[],n=[],r=we(e.replace(O,"$1"));return r[m]?ne((function(e,t,n,i){var o,s=r(e,null,i,[]),a=e.length;while(a--)(o=s[a])&&(e[a]=!(t[a]=o))})):function(e,i,o){return t[0]=e,r(t,null,o,n),t[0]=null,!n.pop()}})),has:ne((function(e){return function(t){return ee(e,t).length>0}})),contains:ne((function(e){return e=e.replace(K,Q),function(t){return(t.textContent||_.text(t)).indexOf(e)>-1}})),lang:ne((function(e){return $.test(e||"")||ee.error("unsupported lang: "+e),e=e.replace(K,Q).toLowerCase(),function(t){var n;do{if(n=u?t.lang:t.getAttribute("xml:lang")||t.getAttribute("lang"))return n=n.toLowerCase(),n===e||0===n.indexOf(e+"-")}while((t=t.parentNode)&&1===t.nodeType);return!1}})),target:function(e){var t=n.location&&n.location.hash;return t&&t.slice(1)===e.id},root:function(e){return e===c},focus:function(e){return e===J()&&a.hasFocus()&&!!(e.type||e.href||~e.tabIndex)},enabled:se(!1),disabled:se(!0),checked:function(e){return R(e,"input")&&!!e.checked||R(e,"option")&&!!e.selected},selected:function(e){return e.parentNode&&e.parentNode.selectedIndex,!0===e.selected},empty:function(e){for(e=e.firstChild;e;e=e.nextSibling)if(e.nodeType<6)return!1;return!0},parent:function(e){return!t.pseudos.empty(e)},header:function(e){return V.test(e.nodeName)},input:function(e){return q.test(e.nodeName)},button:function(e){return R(e,"input")&&"button"===e.type||R(e,"button")},text:function(e){var t;return R(e,"input")&&"text"===e.type&&(null==(t=e.getAttribute("type"))||"text"===t.toLowerCase())},first:ae((function(){return[0]})),last:ae((function(e,t){return[t-1]})),eq:ae((function(e,t,n){return[n<0?n+t:n]})),even:ae((function(e,t){for(var n=0;nt?t:n;--r>=0;)e.push(r);return e})),gt:ae((function(e,t,n){for(var r=n<0?n+t:n;++r1?function(t,n,r){var i=e.length;while(i--)if(!e[i](t,n,r))return!1;return!0}:e[0]}function ge(e,t,n){for(var r=0,i=t.length;r-1&&(o[c]=!(s[c]=h))}}else p=me(p===s?p.splice(v,p.length):p),i?i(null,s,p,l):g.apply(s,p)}))}function be(e){for(var n,i,o,s=e.length,a=t.relative[e[0].type],l=a||t.relative[" "],c=a?1:0,u=pe((function(e){return e===n}),l,!0),h=pe((function(e){return d.call(n,e)>-1}),l,!0),p=[function(e,t,i){var o=!a&&(i||t!=r)||((n=t).nodeType?u(e,t,i):h(e,t,i));return n=null,o}];c1&&fe(p),c>1&&he(e.slice(0,c-1).concat({value:" "===e[c-2].type?"*":""})).replace(O,"$1"),i,c0,o=e.length>0,s=function(s,l,c,d,h){var p,f,m,v=0,y="0",w=s&&[],x=[],A=r,k=s||o&&t.find.TAG("*",h),C=b+=null==A?1:Math.random()||.1,S=k.length;for(h&&(r=l==a||l||h);y!==S&&null!=(p=k[y]);y++){if(o&&p){f=0,l||p.ownerDocument==a||(ce(p),c=!u);while(m=e[f++])if(m(p,l||a,c)){g.call(d,p);break}h&&(b=C)}i&&((p=!m&&p)&&v--,s&&w.push(p))}if(v+=y,i&&y!==v){f=0;while(m=n[f++])m(w,x,l,c);if(s){if(v>0)while(y--)w[y]||x[y]||(x[y]=T.call(d));x=me(x)}g.apply(d,x),h&&!s&&x.length>0&&v+n.length>1&&_.uniqueSort(d)}return h&&(b=C,r=A),w};return i?ne(s):s}function we(e,t){var n,r=[],i=[],o=A[e+" "];if(!o){t||(t=de(e)),n=t.length;while(n--)o=be(t[n]),o[m]?r.push(o):i.push(o);o=A(e,ye(i,r)),o.selector=e}return o}function xe(e,n,r,i){var o,s,a,l,c,d="function"===typeof e&&e,h=!i&&de(e=d.selector||e);if(r=r||[],1===h.length){if(s=h[0]=h[0].slice(0),s.length>2&&"ID"===(a=s[0]).type&&9===n.nodeType&&u&&t.relative[s[1].type]){if(n=(t.find.ID(a.matches[0].replace(K,Q),n)||[])[0],!n)return r;d&&(n=n.parentNode),e=e.slice(s.shift().value.length)}o=W.needsContext.test(e)?0:s.length;while(o--){if(a=s[o],t.relative[l=a.type])break;if((c=t.find[l])&&(i=c(a.matches[0].replace(K,Q),G.test(s[0].type)&&le(n.parentNode)||n))){if(s.splice(o,1),e=i.length&&he(s),!e)return g.apply(r,i),r;break}}}return(d||we(e,h))(i,n,!u,r,!n||G.test(e)&&le(n.parentNode)||n),r}ue.prototype=t.filters=t.pseudos,t.setFilters=new ue,v.sortStable=m.split("").sort(C).join("")===m,ce(),v.sortDetached=re((function(e){return 1&e.compareDocumentPosition(a.createElement("fieldset"))})),_.find=ee,_.expr[":"]=_.expr.pseudos,_.unique=_.uniqueSort,ee.compile=we,ee.select=xe,ee.setDocument=ce,ee.tokenize=de,ee.escape=_.escapeSelector,ee.getText=_.text,ee.isXML=_.isXMLDoc,ee.selectors=_.expr,ee.support=_.support,ee.uniqueSort=_.uniqueSort})();var H=function(e,t,n){var r=[],i=void 0!==n;while((e=e[t])&&9!==e.nodeType)if(1===e.nodeType){if(i&&_(e).is(n))break;r.push(e)}return r},N=function(e,t){for(var n=[];e;e=e.nextSibling)1===e.nodeType&&e!==t&&n.push(e);return n},j=_.expr.match.needsContext,U=/^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i;function z(e,t,n){return b(t)?_.grep(e,(function(e,r){return!!t.call(e,r,e)!==n})):t.nodeType?_.grep(e,(function(e){return e===t!==n})):"string"!==typeof t?_.grep(e,(function(e){return d.call(t,e)>-1!==n})):_.filter(t,e,n)}_.filter=function(e,t,n){var r=t[0];return n&&(e=":not("+e+")"),1===t.length&&1===r.nodeType?_.find.matchesSelector(r,e)?[r]:[]:_.find.matches(e,_.grep(t,(function(e){return 1===e.nodeType})))},_.fn.extend({find:function(e){var t,n,r=this.length,i=this;if("string"!==typeof e)return this.pushStack(_(e).filter((function(){for(t=0;t1?_.uniqueSort(n):n},filter:function(e){return this.pushStack(z(this,e||[],!1))},not:function(e){return this.pushStack(z(this,e||[],!0))},is:function(e){return!!z(this,"string"===typeof e&&j.test(e)?_(e):e||[],!1).length}});var $,W=/^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]+))$/,q=_.fn.init=function(e,t,n){var r,i;if(!e)return this;if(n=n||$,"string"===typeof e){if(r="<"===e[0]&&">"===e[e.length-1]&&e.length>=3?[null,e,null]:W.exec(e),!r||!r[1]&&t)return!t||t.jquery?(t||n).find(e):this.constructor(t).find(e);if(r[1]){if(t=t instanceof _?t[0]:t,_.merge(this,_.parseHTML(r[1],t&&t.nodeType?t.ownerDocument||t:w,!0)),U.test(r[1])&&_.isPlainObject(t))for(r in t)b(this[r])?this[r](t[r]):this.attr(r,t[r]);return this}return i=w.getElementById(r[2]),i&&(this[0]=i,this.length=1),this}return e.nodeType?(this[0]=e,this.length=1,this):b(e)?void 0!==n.ready?n.ready(e):e(_):_.makeArray(e,this)};q.prototype=_.fn,$=_(w);var V=/^(?:parents|prev(?:Until|All))/,Y={children:!0,contents:!0,next:!0,prev:!0};function G(e,t){while((e=e[t])&&1!==e.nodeType);return e}_.fn.extend({has:function(e){var t=_(e,this),n=t.length;return this.filter((function(){for(var e=0;e-1:1===n.nodeType&&_.find.matchesSelector(n,e))){o.push(n);break}return this.pushStack(o.length>1?_.uniqueSort(o):o)},index:function(e){return e?"string"===typeof e?d.call(_(e),this[0]):d.call(this,e.jquery?e[0]:e):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(e,t){return this.pushStack(_.uniqueSort(_.merge(this.get(),_(e,t))))},addBack:function(e){return this.add(null==e?this.prevObject:this.prevObject.filter(e))}}),_.each({parent:function(e){var t=e.parentNode;return t&&11!==t.nodeType?t:null},parents:function(e){return H(e,"parentNode")},parentsUntil:function(e,t,n){return H(e,"parentNode",n)},next:function(e){return G(e,"nextSibling")},prev:function(e){return G(e,"previousSibling")},nextAll:function(e){return H(e,"nextSibling")},prevAll:function(e){return H(e,"previousSibling")},nextUntil:function(e,t,n){return H(e,"nextSibling",n)},prevUntil:function(e,t,n){return H(e,"previousSibling",n)},siblings:function(e){return N((e.parentNode||{}).firstChild,e)},children:function(e){return N(e.firstChild)},contents:function(e){return null!=e.contentDocument&&a(e.contentDocument)?e.contentDocument:(R(e,"template")&&(e=e.content||e),_.merge([],e.childNodes))}},(function(e,t){_.fn[e]=function(n,r){var i=_.map(this,t,n);return"Until"!==e.slice(-5)&&(r=n),r&&"string"===typeof r&&(i=_.filter(r,i)),this.length>1&&(Y[e]||_.uniqueSort(i),V.test(e)&&i.reverse()),this.pushStack(i)}}));var K=/[^\x20\t\r\n\f]+/g;function Q(e){var t={};return _.each(e.match(K)||[],(function(e,n){t[n]=!0})),t}function Z(e){return e}function X(e){throw e}function J(e,t,n,r){var i;try{e&&b(i=e.promise)?i.call(e).done(t).fail(n):e&&b(i=e.then)?i.call(e,t,n):t.apply(void 0,[e].slice(r))}catch(e){n.apply(void 0,[e])}}_.Callbacks=function(e){e="string"===typeof e?Q(e):_.extend({},e);var t,n,r,i,o=[],s=[],a=-1,l=function(){for(i=i||e.once,r=t=!0;s.length;a=-1){n=s.shift();while(++a-1)o.splice(n,1),n<=a&&a--})),this},has:function(e){return e?_.inArray(e,o)>-1:o.length>0},empty:function(){return o&&(o=[]),this},disable:function(){return i=s=[],o=n="",this},disabled:function(){return!o},lock:function(){return i=s=[],n||t||(o=n=""),this},locked:function(){return!!i},fireWith:function(e,n){return i||(n=n||[],n=[e,n.slice?n.slice():n],s.push(n),t||l()),this},fire:function(){return c.fireWith(this,arguments),this},fired:function(){return!!r}};return c},_.extend({Deferred:function(e){var t=[["notify","progress",_.Callbacks("memory"),_.Callbacks("memory"),2],["resolve","done",_.Callbacks("once memory"),_.Callbacks("once memory"),0,"resolved"],["reject","fail",_.Callbacks("once memory"),_.Callbacks("once memory"),1,"rejected"]],r="pending",i={state:function(){return r},always:function(){return o.done(arguments).fail(arguments),this},catch:function(e){return i.then(null,e)},pipe:function(){var e=arguments;return _.Deferred((function(n){_.each(t,(function(t,r){var i=b(e[r[4]])&&e[r[4]];o[r[1]]((function(){var e=i&&i.apply(this,arguments);e&&b(e.promise)?e.promise().progress(n.notify).done(n.resolve).fail(n.reject):n[r[0]+"With"](this,i?[e]:arguments)}))})),e=null})).promise()},then:function(e,r,i){var o=0;function s(e,t,r,i){return function(){var a=this,l=arguments,c=function(){var n,c;if(!(e=o&&(r!==X&&(a=void 0,l=[n]),t.rejectWith(a,l))}};e?u():(_.Deferred.getErrorHook?u.error=_.Deferred.getErrorHook():_.Deferred.getStackHook&&(u.error=_.Deferred.getStackHook()),n.setTimeout(u))}}return _.Deferred((function(n){t[0][3].add(s(0,n,b(i)?i:Z,n.notifyWith)),t[1][3].add(s(0,n,b(e)?e:Z)),t[2][3].add(s(0,n,b(r)?r:X))})).promise()},promise:function(e){return null!=e?_.extend(e,i):i}},o={};return _.each(t,(function(e,n){var s=n[2],a=n[5];i[n[1]]=s.add,a&&s.add((function(){r=a}),t[3-e][2].disable,t[3-e][3].disable,t[0][2].lock,t[0][3].lock),s.add(n[3].fire),o[n[0]]=function(){return o[n[0]+"With"](this===o?void 0:this,arguments),this},o[n[0]+"With"]=s.fireWith})),i.promise(o),e&&e.call(o,o),o},when:function(e){var t=arguments.length,n=t,r=Array(n),i=l.call(arguments),o=_.Deferred(),s=function(e){return function(n){r[e]=this,i[e]=arguments.length>1?l.call(arguments):n,--t||o.resolveWith(r,i)}};if(t<=1&&(J(e,o.done(s(n)).resolve,o.reject,!t),"pending"===o.state()||b(i[n]&&i[n].then)))return o.then();while(n--)J(i[n],s(n),o.reject);return o.promise()}});var ee=/^(Eval|Internal|Range|Reference|Syntax|Type|URI)Error$/;_.Deferred.exceptionHook=function(e,t){n.console&&n.console.warn&&e&&ee.test(e.name)&&n.console.warn("jQuery.Deferred exception: "+e.message,e.stack,t)},_.readyException=function(e){n.setTimeout((function(){throw e}))};var te=_.Deferred();function ne(){w.removeEventListener("DOMContentLoaded",ne),n.removeEventListener("load",ne),_.ready()}_.fn.ready=function(e){return te.then(e).catch((function(e){_.readyException(e)})),this},_.extend({isReady:!1,readyWait:1,ready:function(e){(!0===e?--_.readyWait:_.isReady)||(_.isReady=!0,!0!==e&&--_.readyWait>0||te.resolveWith(w,[_]))}}),_.ready.then=te.then,"complete"===w.readyState||"loading"!==w.readyState&&!w.documentElement.doScroll?n.setTimeout(_.ready):(w.addEventListener("DOMContentLoaded",ne),n.addEventListener("load",ne));var re=function(e,t,n,r,i,o,s){var a=0,l=e.length,c=null==n;if("object"===k(n))for(a in i=!0,n)re(e,t,a,n[a],!0,o,s);else if(void 0!==r&&(i=!0,b(r)||(s=!0),c&&(s?(t.call(e,r),t=null):(c=t,t=function(e,t,n){return c.call(_(e),n)})),t))for(;a1,null,!0)},removeData:function(e){return this.each((function(){de.remove(this,e)}))}}),_.extend({queue:function(e,t,n){var r;if(e)return t=(t||"fx")+"queue",r=ue.get(e,t),n&&(!r||Array.isArray(n)?r=ue.access(e,t,_.makeArray(n)):r.push(n)),r||[]},dequeue:function(e,t){t=t||"fx";var n=_.queue(e,t),r=n.length,i=n.shift(),o=_._queueHooks(e,t),s=function(){_.dequeue(e,t)};"inprogress"===i&&(i=n.shift(),r--),i&&("fx"===t&&n.unshift("inprogress"),delete o.stop,i.call(e,s,o)),!r&&o&&o.empty.fire()},_queueHooks:function(e,t){var n=t+"queueHooks";return ue.get(e,n)||ue.access(e,n,{empty:_.Callbacks("once memory").add((function(){ue.remove(e,[t+"queue",n])}))})}}),_.fn.extend({queue:function(e,t){var n=2;return"string"!==typeof e&&(t=e,e="fx",n--),arguments.length\x20\t\r\n\f]*)/i,Te=/^$|^module$|\/(?:java|ecma)script/i;(function(){var e=w.createDocumentFragment(),t=e.appendChild(w.createElement("div")),n=w.createElement("input");n.setAttribute("type","radio"),n.setAttribute("checked","checked"),n.setAttribute("name","t"),t.appendChild(n),v.checkClone=t.cloneNode(!0).cloneNode(!0).lastChild.checked,t.innerHTML="",v.noCloneChecked=!!t.cloneNode(!0).lastChild.defaultValue,t.innerHTML="",v.option=!!t.lastChild})();var Me={thead:[1,""],col:[2,""],tr:[2,""],td:[3,""],_default:[0,"",""]};function Ie(e,t){var n;return n="undefined"!==typeof e.getElementsByTagName?e.getElementsByTagName(t||"*"):"undefined"!==typeof e.querySelectorAll?e.querySelectorAll(t||"*"):[],void 0===t||t&&R(e,t)?_.merge([e],n):n}function Le(e,t){for(var n=0,r=e.length;n",""]);var Oe=/<|?\w+;/;function Be(e,t,n,r,i){for(var o,s,a,l,c,u,d=t.createDocumentFragment(),h=[],p=0,f=e.length;p-1)i&&i.push(o);else if(c=we(o),s=Ie(d.appendChild(o),"script"),c&&Le(s),n){u=0;while(o=s[u++])Te.test(o.type||"")&&n.push(o)}return d}var De=/^([^.]*)(?:\.(.+)|)/;function Fe(){return!0}function Pe(){return!1}function He(e,t,n,r,i,o){var s,a;if("object"===typeof t){for(a in"string"!==typeof n&&(r=r||n,n=void 0),t)He(e,a,n,r,t[a],o);return e}if(null==r&&null==i?(i=n,r=n=void 0):null==i&&("string"===typeof n?(i=r,r=void 0):(i=r,r=n,n=void 0)),!1===i)i=Pe;else if(!i)return e;return 1===o&&(s=i,i=function(e){return _().off(e),s.apply(this,arguments)},i.guid=s.guid||(s.guid=_.guid++)),e.each((function(){_.event.add(this,t,i,r,n)}))}function Ne(e,t,n){n?(ue.set(e,t,!1),_.event.add(e,t,{namespace:!1,handler:function(e){var n,r=ue.get(this,t);if(1&e.isTrigger&&this[t]){if(r)(_.event.special[t]||{}).delegateType&&e.stopPropagation();else if(r=l.call(arguments),ue.set(this,t,r),this[t](),n=ue.get(this,t),ue.set(this,t,!1),r!==n)return e.stopImmediatePropagation(),e.preventDefault(),n}else r&&(ue.set(this,t,_.event.trigger(r[0],r.slice(1),this)),e.stopPropagation(),e.isImmediatePropagationStopped=Fe)}})):void 0===ue.get(e,t)&&_.event.add(e,t,Fe)}_.event={global:{},add:function(e,t,n,r,i){var o,s,a,l,c,u,d,h,p,f,g,m=ue.get(e);if(le(e)){n.handler&&(o=n,n=o.handler,i=o.selector),i&&_.find.matchesSelector(ye,i),n.guid||(n.guid=_.guid++),(l=m.events)||(l=m.events=Object.create(null)),(s=m.handle)||(s=m.handle=function(t){return"undefined"!==typeof _&&_.event.triggered!==t.type?_.event.dispatch.apply(e,arguments):void 0}),t=(t||"").match(K)||[""],c=t.length;while(c--)a=De.exec(t[c])||[],p=g=a[1],f=(a[2]||"").split(".").sort(),p&&(d=_.event.special[p]||{},p=(i?d.delegateType:d.bindType)||p,d=_.event.special[p]||{},u=_.extend({type:p,origType:g,data:r,handler:n,guid:n.guid,selector:i,needsContext:i&&_.expr.match.needsContext.test(i),namespace:f.join(".")},o),(h=l[p])||(h=l[p]=[],h.delegateCount=0,d.setup&&!1!==d.setup.call(e,r,f,s)||e.addEventListener&&e.addEventListener(p,s)),d.add&&(d.add.call(e,u),u.handler.guid||(u.handler.guid=n.guid)),i?h.splice(h.delegateCount++,0,u):h.push(u),_.event.global[p]=!0)}},remove:function(e,t,n,r,i){var o,s,a,l,c,u,d,h,p,f,g,m=ue.hasData(e)&&ue.get(e);if(m&&(l=m.events)){t=(t||"").match(K)||[""],c=t.length;while(c--)if(a=De.exec(t[c])||[],p=g=a[1],f=(a[2]||"").split(".").sort(),p){d=_.event.special[p]||{},p=(r?d.delegateType:d.bindType)||p,h=l[p]||[],a=a[2]&&new RegExp("(^|\\.)"+f.join("\\.(?:.*\\.|)")+"(\\.|$)"),s=o=h.length;while(o--)u=h[o],!i&&g!==u.origType||n&&n.guid!==u.guid||a&&!a.test(u.namespace)||r&&r!==u.selector&&("**"!==r||!u.selector)||(h.splice(o,1),u.selector&&h.delegateCount--,d.remove&&d.remove.call(e,u));s&&!h.length&&(d.teardown&&!1!==d.teardown.call(e,f,m.handle)||_.removeEvent(e,p,m.handle),delete l[p])}else for(p in l)_.event.remove(e,p+t[c],n,r,!0);_.isEmptyObject(l)&&ue.remove(e,"handle events")}},dispatch:function(e){var t,n,r,i,o,s,a=new Array(arguments.length),l=_.event.fix(e),c=(ue.get(this,"events")||Object.create(null))[l.type]||[],u=_.event.special[l.type]||{};for(a[0]=l,t=1;t=1))for(;c!==this;c=c.parentNode||this)if(1===c.nodeType&&("click"!==e.type||!0!==c.disabled)){for(o=[],s={},n=0;n-1:_.find(i,this,null,[c]).length),s[i]&&o.push(r);o.length&&a.push({elem:c,handlers:o})}return c=this,l\s*$/g;function $e(e,t){return R(e,"table")&&R(11!==t.nodeType?t:t.firstChild,"tr")&&_(e).children("tbody")[0]||e}function We(e){return e.type=(null!==e.getAttribute("type"))+"/"+e.type,e}function qe(e){return"true/"===(e.type||"").slice(0,5)?e.type=e.type.slice(5):e.removeAttribute("type"),e}function Ve(e,t){var n,r,i,o,s,a,l;if(1===t.nodeType){if(ue.hasData(e)&&(o=ue.get(e),l=o.events,l))for(i in ue.remove(t,"handle events"),l)for(n=0,r=l[i].length;n1&&"string"===typeof f&&!v.checkClone&&Ue.test(f))return e.each((function(i){var o=e.eq(i);g&&(t[0]=f.call(this,i,o.html())),Ge(o,t,n,r)}));if(h&&(i=Be(t,e[0].ownerDocument,!1,e,r),o=i.firstChild,1===i.childNodes.length&&(i=o),o||r)){for(s=_.map(Ie(i,"script"),We),a=s.length;d0&&Le(s,!l&&Ie(e,"script")),a},cleanData:function(e){for(var t,n,r,i=_.event.special,o=0;void 0!==(n=e[o]);o++)if(le(n)){if(t=n[ue.expando]){if(t.events)for(r in t.events)i[r]?_.event.remove(n,r):_.removeEvent(n,r,t.handle);n[ue.expando]=void 0}n[de.expando]&&(n[de.expando]=void 0)}}}),_.fn.extend({detach:function(e){return Ke(this,e,!0)},remove:function(e){return Ke(this,e)},text:function(e){return re(this,(function(e){return void 0===e?_.text(this):this.empty().each((function(){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||(this.textContent=e)}))}),null,e,arguments.length)},append:function(){return Ge(this,arguments,(function(e){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var t=$e(this,e);t.appendChild(e)}}))},prepend:function(){return Ge(this,arguments,(function(e){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var t=$e(this,e);t.insertBefore(e,t.firstChild)}}))},before:function(){return Ge(this,arguments,(function(e){this.parentNode&&this.parentNode.insertBefore(e,this)}))},after:function(){return Ge(this,arguments,(function(e){this.parentNode&&this.parentNode.insertBefore(e,this.nextSibling)}))},empty:function(){for(var e,t=0;null!=(e=this[t]);t++)1===e.nodeType&&(_.cleanData(Ie(e,!1)),e.textContent="");return this},clone:function(e,t){return e=null!=e&&e,t=null==t?e:t,this.map((function(){return _.clone(this,e,t)}))},html:function(e){return re(this,(function(e){var t=this[0]||{},n=0,r=this.length;if(void 0===e&&1===t.nodeType)return t.innerHTML;if("string"===typeof e&&!je.test(e)&&!Me[(Re.exec(e)||["",""])[1].toLowerCase()]){e=_.htmlPrefilter(e);try{for(;n=0&&(l+=Math.max(0,Math.ceil(e["offset"+t[0].toUpperCase()+t.slice(1)]-o-l-a-.5))||0),l+c}function pt(e,t,n){var r=Xe(e),i=!v.boxSizingReliable()||n,o=i&&"border-box"===_.css(e,"boxSizing",!1,r),s=o,a=tt(e,t,r),l="offset"+t[0].toUpperCase()+t.slice(1);if(Qe.test(a)){if(!n)return a;a="auto"}return(!v.boxSizingReliable()&&o||!v.reliableTrDimensions()&&R(e,"tr")||"auto"===a||!parseFloat(a)&&"inline"===_.css(e,"display",!1,r))&&e.getClientRects().length&&(o="border-box"===_.css(e,"boxSizing",!1,r),s=l in e,s&&(a=e[l])),a=parseFloat(a)||0,a+ht(e,t,n||(o?"border":"content"),s,r,a)+"px"}function ft(e,t,n,r,i){return new ft.prototype.init(e,t,n,r,i)}_.extend({cssHooks:{opacity:{get:function(e,t){if(t){var n=tt(e,"opacity");return""===n?"1":n}}}},cssNumber:{animationIterationCount:!0,aspectRatio:!0,borderImageSlice:!0,columnCount:!0,flexGrow:!0,flexShrink:!0,fontWeight:!0,gridArea:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnStart:!0,gridRow:!0,gridRowEnd:!0,gridRowStart:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,scale:!0,widows:!0,zIndex:!0,zoom:!0,fillOpacity:!0,floodOpacity:!0,stopOpacity:!0,strokeMiterlimit:!0,strokeOpacity:!0},cssProps:{},style:function(e,t,n,r){if(e&&3!==e.nodeType&&8!==e.nodeType&&e.style){var i,o,s,a=ae(t),l=Ze.test(t),c=e.style;if(l||(t=at(a)),s=_.cssHooks[t]||_.cssHooks[a],void 0===n)return s&&"get"in s&&void 0!==(i=s.get(e,!1,r))?i:c[t];o=typeof n,"string"===o&&(i=ve.exec(n))&&i[1]&&(n=ke(e,t,i),o="number"),null!=n&&n===n&&("number"!==o||l||(n+=i&&i[3]||(_.cssNumber[a]?"":"px")),v.clearCloneStyle||""!==n||0!==t.indexOf("background")||(c[t]="inherit"),s&&"set"in s&&void 0===(n=s.set(e,n,r))||(l?c.setProperty(t,n):c[t]=n))}},css:function(e,t,n,r){var i,o,s,a=ae(t),l=Ze.test(t);return l||(t=at(a)),s=_.cssHooks[t]||_.cssHooks[a],s&&"get"in s&&(i=s.get(e,!0,n)),void 0===i&&(i=tt(e,t,r)),"normal"===i&&t in ut&&(i=ut[t]),""===n||n?(o=parseFloat(i),!0===n||isFinite(o)?o||0:i):i}}),_.each(["height","width"],(function(e,t){_.cssHooks[t]={get:function(e,n,r){if(n)return!lt.test(_.css(e,"display"))||e.getClientRects().length&&e.getBoundingClientRect().width?pt(e,t,r):Je(e,ct,(function(){return pt(e,t,r)}))},set:function(e,n,r){var i,o=Xe(e),s=!v.scrollboxSize()&&"absolute"===o.position,a=s||r,l=a&&"border-box"===_.css(e,"boxSizing",!1,o),c=r?ht(e,t,r,l,o):0;return l&&s&&(c-=Math.ceil(e["offset"+t[0].toUpperCase()+t.slice(1)]-parseFloat(o[t])-ht(e,t,"border",!1,o)-.5)),c&&(i=ve.exec(n))&&"px"!==(i[3]||"px")&&(e.style[t]=n,n=_.css(e,t)),dt(e,n,c)}}})),_.cssHooks.marginLeft=nt(v.reliableMarginLeft,(function(e,t){if(t)return(parseFloat(tt(e,"marginLeft"))||e.getBoundingClientRect().left-Je(e,{marginLeft:0},(function(){return e.getBoundingClientRect().left})))+"px"})),_.each({margin:"",padding:"",border:"Width"},(function(e,t){_.cssHooks[e+t]={expand:function(n){for(var r=0,i={},o="string"===typeof n?n.split(" "):[n];r<4;r++)i[e+be[r]+t]=o[r]||o[r-2]||o[0];return i}},"margin"!==e&&(_.cssHooks[e+t].set=dt)})),_.fn.extend({css:function(e,t){return re(this,(function(e,t,n){var r,i,o={},s=0;if(Array.isArray(t)){for(r=Xe(e),i=t.length;s1)}}),_.Tween=ft,ft.prototype={constructor:ft,init:function(e,t,n,r,i,o){this.elem=e,this.prop=n,this.easing=i||_.easing._default,this.options=t,this.start=this.now=this.cur(),this.end=r,this.unit=o||(_.cssNumber[n]?"":"px")},cur:function(){var e=ft.propHooks[this.prop];return e&&e.get?e.get(this):ft.propHooks._default.get(this)},run:function(e){var t,n=ft.propHooks[this.prop];return this.options.duration?this.pos=t=_.easing[this.easing](e,this.options.duration*e,0,1,this.options.duration):this.pos=t=e,this.now=(this.end-this.start)*t+this.start,this.options.step&&this.options.step.call(this.elem,this.now,this),n&&n.set?n.set(this):ft.propHooks._default.set(this),this}},ft.prototype.init.prototype=ft.prototype,ft.propHooks={_default:{get:function(e){var t;return 1!==e.elem.nodeType||null!=e.elem[e.prop]&&null==e.elem.style[e.prop]?e.elem[e.prop]:(t=_.css(e.elem,e.prop,""),t&&"auto"!==t?t:0)},set:function(e){_.fx.step[e.prop]?_.fx.step[e.prop](e):1!==e.elem.nodeType||!_.cssHooks[e.prop]&&null==e.elem.style[at(e.prop)]?e.elem[e.prop]=e.now:_.style(e.elem,e.prop,e.now+e.unit)}}},ft.propHooks.scrollTop=ft.propHooks.scrollLeft={set:function(e){e.elem.nodeType&&e.elem.parentNode&&(e.elem[e.prop]=e.now)}},_.easing={linear:function(e){return e},swing:function(e){return.5-Math.cos(e*Math.PI)/2},_default:"swing"},_.fx=ft.prototype.init,_.fx.step={};var gt,mt,vt=/^(?:toggle|show|hide)$/,bt=/queueHooks$/;function yt(){mt&&(!1===w.hidden&&n.requestAnimationFrame?n.requestAnimationFrame(yt):n.setTimeout(yt,_.fx.interval),_.fx.tick())}function wt(){return n.setTimeout((function(){gt=void 0})),gt=Date.now()}function xt(e,t){var n,r=0,i={height:e};for(t=t?1:0;r<4;r+=2-t)n=be[r],i["margin"+n]=i["padding"+n]=e;return t&&(i.opacity=i.width=e),i}function At(e,t,n){for(var r,i=(St.tweeners[t]||[]).concat(St.tweeners["*"]),o=0,s=i.length;o1)},removeAttr:function(e){return this.each((function(){_.removeAttr(this,e)}))}}),_.extend({attr:function(e,t,n){var r,i,o=e.nodeType;if(3!==o&&8!==o&&2!==o)return"undefined"===typeof e.getAttribute?_.prop(e,t,n):(1===o&&_.isXMLDoc(e)||(i=_.attrHooks[t.toLowerCase()]||(_.expr.match.bool.test(t)?_t:void 0)),void 0!==n?null===n?void _.removeAttr(e,t):i&&"set"in i&&void 0!==(r=i.set(e,n,t))?r:(e.setAttribute(t,n+""),n):i&&"get"in i&&null!==(r=i.get(e,t))?r:(r=_.find.attr(e,t),null==r?void 0:r))},attrHooks:{type:{set:function(e,t){if(!v.radioValue&&"radio"===t&&R(e,"input")){var n=e.value;return e.setAttribute("type",t),n&&(e.value=n),t}}}},removeAttr:function(e,t){var n,r=0,i=t&&t.match(K);if(i&&1===e.nodeType)while(n=i[r++])e.removeAttribute(n)}}),_t={set:function(e,t,n){return!1===t?_.removeAttr(e,n):e.setAttribute(n,n),n}},_.each(_.expr.match.bool.source.match(/\w+/g),(function(e,t){var n=Et[t]||_.find.attr;Et[t]=function(e,t,r){var i,o,s=t.toLowerCase();return r||(o=Et[s],Et[s]=i,i=null!=n(e,t,r)?s:null,Et[s]=o),i}}));var Rt=/^(?:input|select|textarea|button)$/i,Tt=/^(?:a|area)$/i;function Mt(e){var t=e.match(K)||[];return t.join(" ")}function It(e){return e.getAttribute&&e.getAttribute("class")||""}function Lt(e){return Array.isArray(e)?e:"string"===typeof e&&e.match(K)||[]}_.fn.extend({prop:function(e,t){return re(this,_.prop,e,t,arguments.length>1)},removeProp:function(e){return this.each((function(){delete this[_.propFix[e]||e]}))}}),_.extend({prop:function(e,t,n){var r,i,o=e.nodeType;if(3!==o&&8!==o&&2!==o)return 1===o&&_.isXMLDoc(e)||(t=_.propFix[t]||t,i=_.propHooks[t]),void 0!==n?i&&"set"in i&&void 0!==(r=i.set(e,n,t))?r:e[t]=n:i&&"get"in i&&null!==(r=i.get(e,t))?r:e[t]},propHooks:{tabIndex:{get:function(e){var t=_.find.attr(e,"tabindex");return t?parseInt(t,10):Rt.test(e.nodeName)||Tt.test(e.nodeName)&&e.href?0:-1}}},propFix:{for:"htmlFor",class:"className"}}),v.optSelected||(_.propHooks.selected={get:function(e){var t=e.parentNode;return t&&t.parentNode&&t.parentNode.selectedIndex,null},set:function(e){var t=e.parentNode;t&&(t.selectedIndex,t.parentNode&&t.parentNode.selectedIndex)}}),_.each(["tabIndex","readOnly","maxLength","cellSpacing","cellPadding","rowSpan","colSpan","useMap","frameBorder","contentEditable"],(function(){_.propFix[this.toLowerCase()]=this})),_.fn.extend({addClass:function(e){var t,n,r,i,o,s;return b(e)?this.each((function(t){_(this).addClass(e.call(this,t,It(this)))})):(t=Lt(e),t.length?this.each((function(){if(r=It(this),n=1===this.nodeType&&" "+Mt(r)+" ",n){for(o=0;o-1)n=n.replace(" "+i+" "," ")}s=Mt(n),r!==s&&this.setAttribute("class",s)}})):this):this.attr("class","")},toggleClass:function(e,t){var n,r,i,o,s=typeof e,a="string"===s||Array.isArray(e);return b(e)?this.each((function(n){_(this).toggleClass(e.call(this,n,It(this),t),t)})):"boolean"===typeof t&&a?t?this.addClass(e):this.removeClass(e):(n=Lt(e),this.each((function(){if(a)for(o=_(this),i=0;i-1)return!0;return!1}});var Ot=/\r/g;_.fn.extend({val:function(e){var t,n,r,i=this[0];return arguments.length?(r=b(e),this.each((function(n){var i;1===this.nodeType&&(i=r?e.call(this,n,_(this).val()):e,null==i?i="":"number"===typeof i?i+="":Array.isArray(i)&&(i=_.map(i,(function(e){return null==e?"":e+""}))),t=_.valHooks[this.type]||_.valHooks[this.nodeName.toLowerCase()],t&&"set"in t&&void 0!==t.set(this,i,"value")||(this.value=i))}))):i?(t=_.valHooks[i.type]||_.valHooks[i.nodeName.toLowerCase()],t&&"get"in t&&void 0!==(n=t.get(i,"value"))?n:(n=i.value,"string"===typeof n?n.replace(Ot,""):null==n?"":n)):void 0}}),_.extend({valHooks:{option:{get:function(e){var t=_.find.attr(e,"value");return null!=t?t:Mt(_.text(e))}},select:{get:function(e){var t,n,r,i=e.options,o=e.selectedIndex,s="select-one"===e.type,a=s?null:[],l=s?o+1:i.length;for(r=o<0?l:s?o:0;r-1)&&(n=!0);return n||(e.selectedIndex=-1),o}}}}),_.each(["radio","checkbox"],(function(){_.valHooks[this]={set:function(e,t){if(Array.isArray(t))return e.checked=_.inArray(_(e).val(),t)>-1}},v.checkOn||(_.valHooks[this].get=function(e){return null===e.getAttribute("value")?"on":e.value})}));var Bt=n.location,Dt={guid:Date.now()},Ft=/\?/;_.parseXML=function(e){var t,r;if(!e||"string"!==typeof e)return null;try{t=(new n.DOMParser).parseFromString(e,"text/xml")}catch(i){}return r=t&&t.getElementsByTagName("parsererror")[0],t&&!r||_.error("Invalid XML: "+(r?_.map(r.childNodes,(function(e){return e.textContent})).join("\n"):e)),t};var Pt=/^(?:focusinfocus|focusoutblur)$/,Ht=function(e){e.stopPropagation()};_.extend(_.event,{trigger:function(e,t,r,i){var o,s,a,l,c,u,d,h,p=[r||w],g=f.call(e,"type")?e.type:e,m=f.call(e,"namespace")?e.namespace.split("."):[];if(s=h=a=r=r||w,3!==r.nodeType&&8!==r.nodeType&&!Pt.test(g+_.event.triggered)&&(g.indexOf(".")>-1&&(m=g.split("."),g=m.shift(),m.sort()),c=g.indexOf(":")<0&&"on"+g,e=e[_.expando]?e:new _.Event(g,"object"===typeof e&&e),e.isTrigger=i?2:3,e.namespace=m.join("."),e.rnamespace=e.namespace?new RegExp("(^|\\.)"+m.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,e.result=void 0,e.target||(e.target=r),t=null==t?[e]:_.makeArray(t,[e]),d=_.event.special[g]||{},i||!d.trigger||!1!==d.trigger.apply(r,t))){if(!i&&!d.noBubble&&!y(r)){for(l=d.delegateType||g,Pt.test(l+g)||(s=s.parentNode);s;s=s.parentNode)p.push(s),a=s;a===(r.ownerDocument||w)&&p.push(a.defaultView||a.parentWindow||n)}o=0;while((s=p[o++])&&!e.isPropagationStopped())h=s,e.type=o>1?l:d.bindType||g,u=(ue.get(s,"events")||Object.create(null))[e.type]&&ue.get(s,"handle"),u&&u.apply(s,t),u=c&&s[c],u&&u.apply&&le(s)&&(e.result=u.apply(s,t),!1===e.result&&e.preventDefault());return e.type=g,i||e.isDefaultPrevented()||d._default&&!1!==d._default.apply(p.pop(),t)||!le(r)||c&&b(r[g])&&!y(r)&&(a=r[c],a&&(r[c]=null),_.event.triggered=g,e.isPropagationStopped()&&h.addEventListener(g,Ht),r[g](),e.isPropagationStopped()&&h.removeEventListener(g,Ht),_.event.triggered=void 0,a&&(r[c]=a)),e.result}},simulate:function(e,t,n){var r=_.extend(new _.Event,n,{type:e,isSimulated:!0});_.event.trigger(r,null,t)}}),_.fn.extend({trigger:function(e,t){return this.each((function(){_.event.trigger(e,t,this)}))},triggerHandler:function(e,t){var n=this[0];if(n)return _.event.trigger(e,t,n,!0)}});var Nt=/\[\]$/,jt=/\r?\n/g,Ut=/^(?:submit|button|image|reset|file)$/i,zt=/^(?:input|select|textarea|keygen)/i;function $t(e,t,n,r){var i;if(Array.isArray(t))_.each(t,(function(t,i){n||Nt.test(e)?r(e,i):$t(e+"["+("object"===typeof i&&null!=i?t:"")+"]",i,n,r)}));else if(n||"object"!==k(t))r(e,t);else for(i in t)$t(e+"["+i+"]",t[i],n,r)}_.param=function(e,t){var n,r=[],i=function(e,t){var n=b(t)?t():t;r[r.length]=encodeURIComponent(e)+"="+encodeURIComponent(null==n?"":n)};if(null==e)return"";if(Array.isArray(e)||e.jquery&&!_.isPlainObject(e))_.each(e,(function(){i(this.name,this.value)}));else for(n in e)$t(n,e[n],t,i);return r.join("&")},_.fn.extend({serialize:function(){return _.param(this.serializeArray())},serializeArray:function(){return this.map((function(){var e=_.prop(this,"elements");return e?_.makeArray(e):this})).filter((function(){var e=this.type;return this.name&&!_(this).is(":disabled")&&zt.test(this.nodeName)&&!Ut.test(e)&&(this.checked||!Ee.test(e))})).map((function(e,t){var n=_(this).val();return null==n?null:Array.isArray(n)?_.map(n,(function(e){return{name:t.name,value:e.replace(jt,"\r\n")}})):{name:t.name,value:n.replace(jt,"\r\n")}})).get()}});var Wt=/%20/g,qt=/#.*$/,Vt=/([?&])_=[^&]*/,Yt=/^(.*?):[ \t]*([^\r\n]*)$/gm,Gt=/^(?:about|app|app-storage|.+-extension|file|res|widget):$/,Kt=/^(?:GET|HEAD)$/,Qt=/^\/\//,Zt={},Xt={},Jt="*/".concat("*"),en=w.createElement("a");function tn(e){return function(t,n){"string"!==typeof t&&(n=t,t="*");var r,i=0,o=t.toLowerCase().match(K)||[];if(b(n))while(r=o[i++])"+"===r[0]?(r=r.slice(1)||"*",(e[r]=e[r]||[]).unshift(n)):(e[r]=e[r]||[]).push(n)}}function nn(e,t,n,r){var i={},o=e===Xt;function s(a){var l;return i[a]=!0,_.each(e[a]||[],(function(e,a){var c=a(t,n,r);return"string"!==typeof c||o||i[c]?o?!(l=c):void 0:(t.dataTypes.unshift(c),s(c),!1)})),l}return s(t.dataTypes[0])||!i["*"]&&s("*")}function rn(e,t){var n,r,i=_.ajaxSettings.flatOptions||{};for(n in t)void 0!==t[n]&&((i[n]?e:r||(r={}))[n]=t[n]);return r&&_.extend(!0,e,r),e}function on(e,t,n){var r,i,o,s,a=e.contents,l=e.dataTypes;while("*"===l[0])l.shift(),void 0===r&&(r=e.mimeType||t.getResponseHeader("Content-Type"));if(r)for(i in a)if(a[i]&&a[i].test(r)){l.unshift(i);break}if(l[0]in n)o=l[0];else{for(i in n){if(!l[0]||e.converters[i+" "+l[0]]){o=i;break}s||(s=i)}o=o||s}if(o)return o!==l[0]&&l.unshift(o),n[o]}function sn(e,t,n,r){var i,o,s,a,l,c={},u=e.dataTypes.slice();if(u[1])for(s in e.converters)c[s.toLowerCase()]=e.converters[s];o=u.shift();while(o)if(e.responseFields[o]&&(n[e.responseFields[o]]=t),!l&&r&&e.dataFilter&&(t=e.dataFilter(t,e.dataType)),l=o,o=u.shift(),o)if("*"===o)o=l;else if("*"!==l&&l!==o){if(s=c[l+" "+o]||c["* "+o],!s)for(i in c)if(a=i.split(" "),a[1]===o&&(s=c[l+" "+a[0]]||c["* "+a[0]],s)){!0===s?s=c[i]:!0!==c[i]&&(o=a[0],u.unshift(a[1]));break}if(!0!==s)if(s&&e.throws)t=s(t);else try{t=s(t)}catch(d){return{state:"parsererror",error:s?d:"No conversion from "+l+" to "+o}}}return{state:"success",data:t}}en.href=Bt.href,_.extend({active:0,lastModified:{},etag:{},ajaxSettings:{url:Bt.href,type:"GET",isLocal:Gt.test(Bt.protocol),global:!0,processData:!0,async:!0,contentType:"application/x-www-form-urlencoded; charset=UTF-8",accepts:{"*":Jt,text:"text/plain",html:"text/html",xml:"application/xml, text/xml",json:"application/json, text/javascript"},contents:{xml:/\bxml\b/,html:/\bhtml/,json:/\bjson\b/},responseFields:{xml:"responseXML",text:"responseText",json:"responseJSON"},converters:{"* text":String,"text html":!0,"text json":JSON.parse,"text xml":_.parseXML},flatOptions:{url:!0,context:!0}},ajaxSetup:function(e,t){return t?rn(rn(e,_.ajaxSettings),t):rn(_.ajaxSettings,e)},ajaxPrefilter:tn(Zt),ajaxTransport:tn(Xt),ajax:function(e,t){"object"===typeof e&&(t=e,e=void 0),t=t||{};var r,i,o,s,a,l,c,u,d,h,p=_.ajaxSetup({},t),f=p.context||p,g=p.context&&(f.nodeType||f.jquery)?_(f):_.event,m=_.Deferred(),v=_.Callbacks("once memory"),b=p.statusCode||{},y={},x={},A="canceled",k={readyState:0,getResponseHeader:function(e){var t;if(c){if(!s){s={};while(t=Yt.exec(o))s[t[1].toLowerCase()+" "]=(s[t[1].toLowerCase()+" "]||[]).concat(t[2])}t=s[e.toLowerCase()+" "]}return null==t?null:t.join(", ")},getAllResponseHeaders:function(){return c?o:null},setRequestHeader:function(e,t){return null==c&&(e=x[e.toLowerCase()]=x[e.toLowerCase()]||e,y[e]=t),this},overrideMimeType:function(e){return null==c&&(p.mimeType=e),this},statusCode:function(e){var t;if(e)if(c)k.always(e[k.status]);else for(t in e)b[t]=[b[t],e[t]];return this},abort:function(e){var t=e||A;return r&&r.abort(t),C(0,t),this}};if(m.promise(k),p.url=((e||p.url||Bt.href)+"").replace(Qt,Bt.protocol+"//"),p.type=t.method||t.type||p.method||p.type,p.dataTypes=(p.dataType||"*").toLowerCase().match(K)||[""],null==p.crossDomain){l=w.createElement("a");try{l.href=p.url,l.href=l.href,p.crossDomain=en.protocol+"//"+en.host!==l.protocol+"//"+l.host}catch(S){p.crossDomain=!0}}if(p.data&&p.processData&&"string"!==typeof p.data&&(p.data=_.param(p.data,p.traditional)),nn(Zt,p,t,k),c)return k;for(d in u=_.event&&p.global,u&&0===_.active++&&_.event.trigger("ajaxStart"),p.type=p.type.toUpperCase(),p.hasContent=!Kt.test(p.type),i=p.url.replace(qt,""),p.hasContent?p.data&&p.processData&&0===(p.contentType||"").indexOf("application/x-www-form-urlencoded")&&(p.data=p.data.replace(Wt,"+")):(h=p.url.slice(i.length),p.data&&(p.processData||"string"===typeof p.data)&&(i+=(Ft.test(i)?"&":"?")+p.data,delete p.data),!1===p.cache&&(i=i.replace(Vt,"$1"),h=(Ft.test(i)?"&":"?")+"_="+Dt.guid+++h),p.url=i+h),p.ifModified&&(_.lastModified[i]&&k.setRequestHeader("If-Modified-Since",_.lastModified[i]),_.etag[i]&&k.setRequestHeader("If-None-Match",_.etag[i])),(p.data&&p.hasContent&&!1!==p.contentType||t.contentType)&&k.setRequestHeader("Content-Type",p.contentType),k.setRequestHeader("Accept",p.dataTypes[0]&&p.accepts[p.dataTypes[0]]?p.accepts[p.dataTypes[0]]+("*"!==p.dataTypes[0]?", "+Jt+"; q=0.01":""):p.accepts["*"]),p.headers)k.setRequestHeader(d,p.headers[d]);if(p.beforeSend&&(!1===p.beforeSend.call(f,k,p)||c))return k.abort();if(A="abort",v.add(p.complete),k.done(p.success),k.fail(p.error),r=nn(Xt,p,t,k),r){if(k.readyState=1,u&&g.trigger("ajaxSend",[k,p]),c)return k;p.async&&p.timeout>0&&(a=n.setTimeout((function(){k.abort("timeout")}),p.timeout));try{c=!1,r.send(y,C)}catch(S){if(c)throw S;C(-1,S)}}else C(-1,"No Transport");function C(e,t,s,l){var d,h,y,w,x,A=t;c||(c=!0,a&&n.clearTimeout(a),r=void 0,o=l||"",k.readyState=e>0?4:0,d=e>=200&&e<300||304===e,s&&(w=on(p,k,s)),!d&&_.inArray("script",p.dataTypes)>-1&&_.inArray("json",p.dataTypes)<0&&(p.converters["text script"]=function(){}),w=sn(p,w,k,d),d?(p.ifModified&&(x=k.getResponseHeader("Last-Modified"),x&&(_.lastModified[i]=x),x=k.getResponseHeader("etag"),x&&(_.etag[i]=x)),204===e||"HEAD"===p.type?A="nocontent":304===e?A="notmodified":(A=w.state,h=w.data,y=w.error,d=!y)):(y=A,!e&&A||(A="error",e<0&&(e=0))),k.status=e,k.statusText=(t||A)+"",d?m.resolveWith(f,[h,A,k]):m.rejectWith(f,[k,A,y]),k.statusCode(b),b=void 0,u&&g.trigger(d?"ajaxSuccess":"ajaxError",[k,p,d?h:y]),v.fireWith(f,[k,A]),u&&(g.trigger("ajaxComplete",[k,p]),--_.active||_.event.trigger("ajaxStop")))}return k},getJSON:function(e,t,n){return _.get(e,t,n,"json")},getScript:function(e,t){return _.get(e,void 0,t,"script")}}),_.each(["get","post"],(function(e,t){_[t]=function(e,n,r,i){return b(n)&&(i=i||r,r=n,n=void 0),_.ajax(_.extend({url:e,type:t,dataType:i,data:n,success:r},_.isPlainObject(e)&&e))}})),_.ajaxPrefilter((function(e){var t;for(t in e.headers)"content-type"===t.toLowerCase()&&(e.contentType=e.headers[t]||"")})),_._evalUrl=function(e,t,n){return _.ajax({url:e,type:"GET",dataType:"script",cache:!0,async:!1,global:!1,converters:{"text script":function(){}},dataFilter:function(e){_.globalEval(e,t,n)}})},_.fn.extend({wrapAll:function(e){var t;return this[0]&&(b(e)&&(e=e.call(this[0])),t=_(e,this[0].ownerDocument).eq(0).clone(!0),this[0].parentNode&&t.insertBefore(this[0]),t.map((function(){var e=this;while(e.firstElementChild)e=e.firstElementChild;return e})).append(this)),this},wrapInner:function(e){return b(e)?this.each((function(t){_(this).wrapInner(e.call(this,t))})):this.each((function(){var t=_(this),n=t.contents();n.length?n.wrapAll(e):t.append(e)}))},wrap:function(e){var t=b(e);return this.each((function(n){_(this).wrapAll(t?e.call(this,n):e)}))},unwrap:function(e){return this.parent(e).not("body").each((function(){_(this).replaceWith(this.childNodes)})),this}}),_.expr.pseudos.hidden=function(e){return!_.expr.pseudos.visible(e)},_.expr.pseudos.visible=function(e){return!!(e.offsetWidth||e.offsetHeight||e.getClientRects().length)},_.ajaxSettings.xhr=function(){try{return new n.XMLHttpRequest}catch(e){}};var an={0:200,1223:204},ln=_.ajaxSettings.xhr();v.cors=!!ln&&"withCredentials"in ln,v.ajax=ln=!!ln,_.ajaxTransport((function(e){var t,r;if(v.cors||ln&&!e.crossDomain)return{send:function(i,o){var s,a=e.xhr();if(a.open(e.type,e.url,e.async,e.username,e.password),e.xhrFields)for(s in e.xhrFields)a[s]=e.xhrFields[s];for(s in e.mimeType&&a.overrideMimeType&&a.overrideMimeType(e.mimeType),e.crossDomain||i["X-Requested-With"]||(i["X-Requested-With"]="XMLHttpRequest"),i)a.setRequestHeader(s,i[s]);t=function(e){return function(){t&&(t=r=a.onload=a.onerror=a.onabort=a.ontimeout=a.onreadystatechange=null,"abort"===e?a.abort():"error"===e?"number"!==typeof a.status?o(0,"error"):o(a.status,a.statusText):o(an[a.status]||a.status,a.statusText,"text"!==(a.responseType||"text")||"string"!==typeof a.responseText?{binary:a.response}:{text:a.responseText},a.getAllResponseHeaders()))}},a.onload=t(),r=a.onerror=a.ontimeout=t("error"),void 0!==a.onabort?a.onabort=r:a.onreadystatechange=function(){4===a.readyState&&n.setTimeout((function(){t&&r()}))},t=t("abort");try{a.send(e.hasContent&&e.data||null)}catch(l){if(t)throw l}},abort:function(){t&&t()}}})),_.ajaxPrefilter((function(e){e.crossDomain&&(e.contents.script=!1)})),_.ajaxSetup({accepts:{script:"text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"},contents:{script:/\b(?:java|ecma)script\b/},converters:{"text script":function(e){return _.globalEval(e),e}}}),_.ajaxPrefilter("script",(function(e){void 0===e.cache&&(e.cache=!1),e.crossDomain&&(e.type="GET")})),_.ajaxTransport("script",(function(e){var t,n;if(e.crossDomain||e.scriptAttrs)return{send:function(r,i){t=_("\\n\\t\\nsnippet html5printshiv\\n\\t\\n# Attributes\\nsnippet attr\\n\\t${1:attribute}=\\\"${2:property}\\\"\\nsnippet attr+\\n\\t${1:attribute}=\\\"${2:property}\\\" attr+${3}\\nsnippet .\\n\\tclass=\\\"${1}\\\"${2}\\nsnippet #\\n\\tid=\\\"${1}\\\"${2}\\nsnippet alt\\n\\talt=\\\"${1}\\\"${2}\\nsnippet charset\\n\\tcharset=\\\"${1:utf-8}\\\"${2}\\nsnippet data\\n\\tdata-${1}=\\\"${2:$1}\\\"${3}\\nsnippet for\\n\\tfor=\\\"${1}\\\"${2}\\nsnippet height\\n\\theight=\\\"${1}\\\"${2}\\nsnippet href\\n\\thref=\\\"${1:#}\\\"${2}\\nsnippet lang\\n\\tlang=\\\"${1:en}\\\"${2}\\nsnippet media\\n\\tmedia=\\\"${1}\\\"${2}\\nsnippet name\\n\\tname=\\\"${1}\\\"${2}\\nsnippet rel\\n\\trel=\\\"${1}\\\"${2}\\nsnippet scope\\n\\tscope=\\\"${1:row}\\\"${2}\\nsnippet src\\n\\tsrc=\\\"${1}\\\"${2}\\nsnippet title=\\n\\ttitle=\\\"${1}\\\"${2}\\nsnippet type\\n\\ttype=\\\"${1}\\\"${2}\\nsnippet value\\n\\tvalue=\\\"${1}\\\"${2}\\nsnippet width\\n\\twidth=\\\"${1}\\\"${2}\\n# Elements\\nsnippet a\\n\\t${2:$1}\\nsnippet a.\\n\\t${3:$1}\\nsnippet a#\\n\\t${3:$1}\\nsnippet a:ext\\n\\t${2:$1}\\nsnippet a:mail\\n\\t${3:email me}\\nsnippet abbr\\n\\t${2}\\nsnippet address\\n\\t\\n\\t\\t${1}\\n\\t\\nsnippet area\\n\\t\\nsnippet area+\\n\\t\\n\\tarea+${5}\\nsnippet area:c\\n\\t\\nsnippet area:d\\n\\t\\nsnippet area:p\\n\\t\\nsnippet area:r\\n\\t\\nsnippet article\\n\\t\\n\\t\\t${1}\\n\\t\\nsnippet article.\\n\\t\\n\\t\\t${2}\\n\\t\\nsnippet article#\\n\\t\\n\\t\\t${2}\\n\\t\\nsnippet aside\\n\\t\\nsnippet aside.\\n\\t\\nsnippet aside#\\n\\t\\nsnippet audio\\n\\t\\nsnippet b\\n\\t${1}\\nsnippet base\\n\\t\\nsnippet bdi\\n\\t${1}\\nsnippet bdo\\n\\t${2}\\nsnippet bdo:l\\n\\t${1}\\nsnippet bdo:r\\n\\t${1}\\nsnippet blockquote\\n\\t\\n\\t\\t${1}\\n\\t
\\nsnippet body\\n\\t\\n\\t\\t${1}\\n\\t\\nsnippet br\\n\\t
${1}\\nsnippet button\\n\\t\\nsnippet button.\\n\\t\\nsnippet button#\\n\\t\\nsnippet button:s\\n\\t\\nsnippet button:r\\n\\t\\nsnippet canvas\\n\\t\\nsnippet caption\\n\\t${1}\\nsnippet cite\\n\\t${1}\\nsnippet code\\n\\t${1}
\\nsnippet col\\n\\t${1}\\nsnippet col+\\n\\t\\n\\tcol+${1}\\nsnippet colgroup\\n\\t\\n\\t\\t${1}\\n\\t\\nsnippet colgroup+\\n\\t\\n\\t\\t\\n\\t\\tcol+${1}\\n\\t\\nsnippet command\\n\\t\\nsnippet command:c\\n\\t\\nsnippet command:r\\n\\t\\nsnippet datagrid\\n\\t\\n\\t\\t${1}\\n\\t\\nsnippet datalist\\n\\t\\nsnippet datatemplate\\n\\t\\n\\t\\t${1}\\n\\t\\nsnippet dd\\n\\t${1}\\nsnippet dd.\\n\\t${2}\\nsnippet dd#\\n\\t${2}\\nsnippet del\\n\\t${1}\\nsnippet details\\n\\t${1} \\nsnippet dfn\\n\\t${1}\\nsnippet dialog\\n\\t\\nsnippet div\\n\\t\\n\\t\\t${1}\\n\\t
\\nsnippet div.\\n\\t\\n\\t\\t${2}\\n\\t
\\nsnippet div#\\n\\t\\n\\t\\t${2}\\n\\t
\\nsnippet dl\\n\\t\\n\\t\\t${1}\\n\\t
\\nsnippet dl.\\n\\t\\n\\t\\t${2}\\n\\t
\\nsnippet dl#\\n\\t\\n\\t\\t${2}\\n\\t
\\nsnippet dl+\\n\\t\\n\\t\\t- ${1}
\\n\\t\\t- ${2}
\\n\\t\\tdt+${3}\\n\\t
\\nsnippet dt\\n\\t${1}\\nsnippet dt.\\n\\t${2}\\nsnippet dt#\\n\\t${2}\\nsnippet dt+\\n\\t${1}\\n\\t${2}\\n\\tdt+${3}\\nsnippet em\\n\\t${1}\\nsnippet embed\\n\\t\\nsnippet fieldset\\n\\t\\nsnippet fieldset.\\n\\t\\nsnippet fieldset#\\n\\t\\nsnippet fieldset+\\n\\t\\n\\tfieldset+${3}\\nsnippet figcaption\\n\\t${1}\\nsnippet figure\\n\\t${1}\\nsnippet footer\\n\\t\\nsnippet footer.\\n\\t\\nsnippet footer#\\n\\t\\nsnippet form\\n\\t\\nsnippet form.\\n\\t\\nsnippet form#\\n\\t\\nsnippet h1\\n\\t${1}
\\nsnippet h1.\\n\\t${2}
\\nsnippet h1#\\n\\t${2}
\\nsnippet h2\\n\\t${1}
\\nsnippet h2.\\n\\t${2}
\\nsnippet h2#\\n\\t${2}
\\nsnippet h3\\n\\t${1}
\\nsnippet h3.\\n\\t${2}
\\nsnippet h3#\\n\\t${2}
\\nsnippet h4\\n\\t${1}
\\nsnippet h4.\\n\\t${2}
\\nsnippet h4#\\n\\t${2}
\\nsnippet h5\\n\\t${1}
\\nsnippet h5.\\n\\t${2}
\\nsnippet h5#\\n\\t${2}
\\nsnippet h6\\n\\t${1}
\\nsnippet h6.\\n\\t${2}
\\nsnippet h6#\\n\\t${2}
\\nsnippet head\\n\\t\\n\\t\\t\\n\\n\\t\\t${1:`substitute(Filename('', 'Page Title'), '^.', '\\\\u&', '')`}\\n\\t\\t${2}\\n\\t\\nsnippet header\\n\\t\\nsnippet header.\\n\\t\\nsnippet header#\\n\\t\\nsnippet hgroup\\n\\t\\n\\t\\t${1}\\n\\t\\nsnippet hgroup.\\n\\t\\n\\t\\t${2}\\n\\t\\nsnippet hr\\n\\t
${1}\\nsnippet html\\n\\t\\n\\t${1}\\n\\t\\nsnippet xhtml\\n\\t\\n\\t${1}\\n\\t\\nsnippet html5\\n\\t\\n\\t\\n\\t\\t\\n\\t\\t\\t\\n\\t\\t\\t${1:`substitute(Filename('', 'Page Title'), '^.', '\\\\u&', '')`}\\n\\t\\t\\t${2:meta}\\n\\t\\t\\n\\t\\t\\n\\t\\t\\t${3:body}\\n\\t\\t\\n\\t\\nsnippet xhtml5\\n\\t\\n\\t\\n\\t\\t\\n\\t\\t\\t\\n\\t\\t\\t${1:`substitute(Filename('', 'Page Title'), '^.', '\\\\u&', '')`}\\n\\t\\t\\t${2:meta}\\n\\t\\t\\n\\t\\t\\n\\t\\t\\t${3:body}\\n\\t\\t\\n\\t\\nsnippet i\\n\\t${1}\\nsnippet iframe\\n\\t${2}\\nsnippet iframe.\\n\\t${3}\\nsnippet iframe#\\n\\t${3}\\nsnippet img\\n\\t
${3}\\nsnippet img.\\n\\t
${4}\\nsnippet img#\\n\\t
${4}\\nsnippet input\\n\\t${5}\\nsnippet input.\\n\\t${6}\\nsnippet input:text\\n\\t${4}\\nsnippet input:submit\\n\\t${4}\\nsnippet input:hidden\\n\\t${4}\\nsnippet input:button\\n\\t${4}\\nsnippet input:image\\n\\t${5}\\nsnippet input:checkbox\\n\\t${3}\\nsnippet input:radio\\n\\t${3}\\nsnippet input:color\\n\\t${4}\\nsnippet input:date\\n\\t${4}\\nsnippet input:datetime\\n\\t${4}\\nsnippet input:datetime-local\\n\\t${4}\\nsnippet input:email\\n\\t${4}\\nsnippet input:file\\n\\t${4}\\nsnippet input:month\\n\\t${4}\\nsnippet input:number\\n\\t${4}\\nsnippet input:password\\n\\t${4}\\nsnippet input:range\\n\\t${4}\\nsnippet input:reset\\n\\t${4}\\nsnippet input:search\\n\\t${4}\\nsnippet input:time\\n\\t${4}\\nsnippet input:url\\n\\t${4}\\nsnippet input:week\\n\\t${4}\\nsnippet ins\\n\\t${1}\\nsnippet kbd\\n\\t${1}\\nsnippet keygen\\n\\t${1}\\nsnippet label\\n\\t\\nsnippet label:i\\n\\t\\n\\t${7}\\nsnippet label:s\\n\\t\\n\\t\\nsnippet legend\\n\\t\\nsnippet legend+\\n\\t\\nsnippet li\\n\\t${1}\\nsnippet li.\\n\\t${2}\\nsnippet li+\\n\\t${1}\\n\\tli+${2}\\nsnippet lia\\n\\t${1}\\nsnippet lia+\\n\\t${1}\\n\\tlia+${3}\\nsnippet link\\n\\t${5}\\nsnippet link:atom\\n\\t${2}\\nsnippet link:css\\n\\t${4}\\nsnippet link:favicon\\n\\t${2}\\nsnippet link:rss\\n\\t${2}\\nsnippet link:touch\\n\\t${2}\\nsnippet map\\n\\t\\nsnippet map.\\n\\t\\nsnippet map#\\n\\t\\nsnippet map+\\n\\t${7}\\nsnippet mark\\n\\t${1}\\nsnippet menu\\n\\t\\nsnippet menu:c\\n\\t\\nsnippet menu:t\\n\\t\\nsnippet meta\\n\\t${3}\\nsnippet meta:compat\\n\\t${3}\\nsnippet meta:refresh\\n\\t${3}\\nsnippet meta:utf\\n\\t${3}\\nsnippet meter\\n\\t${1}\\nsnippet nav\\n\\t\\nsnippet nav.\\n\\t\\nsnippet nav#\\n\\t\\nsnippet noscript\\n\\t\\nsnippet object\\n\\t${4}\\n# Embed QT Movie\\nsnippet movie\\n\\t${6}\\nsnippet ol\\n\\t\\n\\t\\t${1}\\n\\t
\\nsnippet ol.\\n\\t\\n\\t\\t${2}\\n\\t
\\nsnippet ol#\\n\\t\\n\\t\\t${2}\\n\\t
\\nsnippet ol+\\n\\t\\n\\t\\t- ${1}
\\n\\t\\tli+${2}\\n\\t
\\nsnippet opt\\n\\t\\nsnippet opt+\\n\\t\\n\\topt+${3}\\nsnippet optt\\n\\t\\nsnippet optgroup\\n\\t\\nsnippet output\\n\\t\\nsnippet p\\n\\t${1}
\\nsnippet param\\n\\t${3}\\nsnippet pre\\n\\t\\n\\t\\t${1}\\n\\t
\\nsnippet progress\\n\\t\\nsnippet q\\n\\t${1}
\\nsnippet rp\\n\\t\\nsnippet rt\\n\\t\\nsnippet ruby\\n\\t\\n\\t\\t\\n\\t\\nsnippet s\\n\\t${1}\\nsnippet samp\\n\\t\\n\\t\\t${1}\\n\\t\\nsnippet script\\n\\t\\nsnippet scriptsrc\\n\\t\\nsnippet newscript\\n\\t\\nsnippet newscriptsrc\\n\\t\\nsnippet section\\n\\t\\nsnippet section.\\n\\t\\nsnippet section#\\n\\t\\nsnippet select\\n\\t\\nsnippet select.\\n\\t\\nsnippet select+\\n\\t\\nsnippet small\\n\\t${1}\\nsnippet source\\n\\t\\nsnippet span\\n\\t${1}\\nsnippet strong\\n\\t${1}\\nsnippet style\\n\\t\\nsnippet sub\\n\\t${1}\\nsnippet summary\\n\\t\\n\\t\\t${1}\\n\\t\\nsnippet sup\\n\\t${1}\\nsnippet table\\n\\t\\nsnippet table.\\n\\t\\nsnippet table#\\n\\t\\nsnippet tbody\\n\\t\\n\\t\\t${1}\\n\\t\\nsnippet td\\n\\t${1} | \\nsnippet td.\\n\\t${2} | \\nsnippet td#\\n\\t${2} | \\nsnippet td+\\n\\t${1} | \\n\\ttd+${2}\\nsnippet textarea\\n\\t${6}\\nsnippet tfoot\\n\\t\\n\\t\\t${1}\\n\\t\\nsnippet th\\n\\t${1} | \\nsnippet th.\\n\\t${2} | \\nsnippet th#\\n\\t${2} | \\nsnippet th+\\n\\t${1} | \\n\\tth+${2}\\nsnippet thead\\n\\t\\n\\t\\t${1}\\n\\t\\nsnippet time\\n\\t\\nsnippet title\\n\\t${1:`substitute(Filename('', 'Page Title'), '^.', '\\\\u&', '')`}\\nsnippet tr\\n\\t\\n\\t\\t${1}\\n\\t
\\nsnippet tr+\\n\\t\\n\\t\\t${1} | \\n\\t\\ttd+${2}\\n\\t
\\nsnippet track\\n\\t${6}\\nsnippet ul\\n\\t\\nsnippet ul.\\n\\t\\nsnippet ul#\\n\\t\\nsnippet ul+\\n\\t\\n\\t\\t- ${1}
\\n\\t\\tli+${2}\\n\\t
\\nsnippet var\\n\\t${1}\\nsnippet video\\n\\t${8}\\nsnippet wbr\\n\\t${1}\\n\";\n\n});\n\nace.define(\"ace/snippets/html\",[\"require\",\"exports\",\"module\",\"ace/snippets/html.snippets\"], function(require, exports, module){\"use strict\";\nexports.snippetText = require(\"./html.snippets\");\nexports.scope = \"html\";\n\n}); (function() {\n ace.require([\"ace/snippets/html\"], function(m) {\n if (typeof module == \"object\" && typeof exports == \"object\" && module) {\n module.exports = m;\n }\n });\n })();\n ","ace.define(\"ace/snippets/java.snippets\",[\"require\",\"exports\",\"module\"], function(require, exports, module){module.exports = \"## Access Modifiers\\nsnippet po\\n\\tprotected\\nsnippet pu\\n\\tpublic\\nsnippet pr\\n\\tprivate\\n##\\n## Annotations\\nsnippet before\\n\\t@Before\\n\\tstatic void ${1:intercept}(${2:args}) { ${3} }\\nsnippet mm\\n\\t@ManyToMany\\n\\t${1}\\nsnippet mo\\n\\t@ManyToOne\\n\\t${1}\\nsnippet om\\n\\t@OneToMany${1:(cascade=CascadeType.ALL)}\\n\\t${2}\\nsnippet oo\\n\\t@OneToOne\\n\\t${1}\\n##\\n## Basic Java packages and import\\nsnippet im\\n\\timport\\nsnippet j.b\\n\\tjava.beans.\\nsnippet j.i\\n\\tjava.io.\\nsnippet j.m\\n\\tjava.math.\\nsnippet j.n\\n\\tjava.net.\\nsnippet j.u\\n\\tjava.util.\\n##\\n## Class\\nsnippet cl\\n\\tclass ${1:`Filename(\\\"\\\", \\\"untitled\\\")`} ${2}\\nsnippet in\\n\\tinterface ${1:`Filename(\\\"\\\", \\\"untitled\\\")`} ${2:extends Parent}${3}\\nsnippet tc\\n\\tpublic class ${1:`Filename()`} extends ${2:TestCase}\\n##\\n## Class Enhancements\\nsnippet ext\\n\\textends \\nsnippet imp\\n\\timplements\\n##\\n## Comments\\nsnippet /*\\n\\t/*\\n\\t * ${1}\\n\\t */\\n##\\n## Constants\\nsnippet co\\n\\tstatic public final ${1:String} ${2:var} = ${3};${4}\\nsnippet cos\\n\\tstatic public final String ${1:var} = \\\"${2}\\\";${3}\\n##\\n## Control Statements\\nsnippet case\\n\\tcase ${1}:\\n\\t\\t${2}\\nsnippet def\\n\\tdefault:\\n\\t\\t${2}\\nsnippet el\\n\\telse\\nsnippet elif\\n\\telse if (${1}) ${2}\\nsnippet if\\n\\tif (${1}) ${2}\\nsnippet sw\\n\\tswitch (${1}) {\\n\\t\\t${2}\\n\\t}\\n##\\n## Create a Method\\nsnippet m\\n\\t${1:void} ${2:method}(${3}) ${4:throws }${5}\\n##\\n## Create a Variable\\nsnippet v\\n\\t${1:String} ${2:var}${3: = null}${4};${5}\\n##\\n## Enhancements to Methods, variables, classes, etc.\\nsnippet ab\\n\\tabstract\\nsnippet fi\\n\\tfinal\\nsnippet st\\n\\tstatic\\nsnippet sy\\n\\tsynchronized\\n##\\n## Error Methods\\nsnippet err\\n\\tSystem.err.print(\\\"${1:Message}\\\");\\nsnippet errf\\n\\tSystem.err.printf(\\\"${1:Message}\\\", ${2:exception});\\nsnippet errln\\n\\tSystem.err.println(\\\"${1:Message}\\\");\\n##\\n## Exception Handling\\nsnippet as\\n\\tassert ${1:test} : \\\"${2:Failure message}\\\";${3}\\nsnippet ca\\n\\tcatch(${1:Exception} ${2:e}) ${3}\\nsnippet thr\\n\\tthrow\\nsnippet ths\\n\\tthrows\\nsnippet try\\n\\ttry {\\n\\t\\t${3}\\n\\t} catch(${1:Exception} ${2:e}) {\\n\\t}\\nsnippet tryf\\n\\ttry {\\n\\t\\t${3}\\n\\t} catch(${1:Exception} ${2:e}) {\\n\\t} finally {\\n\\t}\\n##\\n## Find Methods\\nsnippet findall\\n\\tList<${1:listName}> ${2:items} = ${1}.findAll();${3}\\nsnippet findbyid\\n\\t${1:var} ${2:item} = ${1}.findById(${3});${4}\\n##\\n## Javadocs\\nsnippet /**\\n\\t/**\\n\\t * ${1}\\n\\t */\\nsnippet @au\\n\\t@author `system(\\\"grep \\\\`id -un\\\\` /etc/passwd | cut -d \\\\\\\":\\\\\\\" -f5 | cut -d \\\\\\\",\\\\\\\" -f1\\\")`\\nsnippet @br\\n\\t@brief ${1:Description}\\nsnippet @fi\\n\\t@file ${1:`Filename()`}.java\\nsnippet @pa\\n\\t@param ${1:param}\\nsnippet @re\\n\\t@return ${1:param}\\n##\\n## Logger Methods\\nsnippet debug\\n\\tLogger.debug(${1:param});${2}\\nsnippet error\\n\\tLogger.error(${1:param});${2}\\nsnippet info\\n\\tLogger.info(${1:param});${2}\\nsnippet warn\\n\\tLogger.warn(${1:param});${2}\\n##\\n## Loops\\nsnippet enfor\\n\\tfor (${1} : ${2}) ${3}\\nsnippet for\\n\\tfor (${1}; ${2}; ${3}) ${4}\\nsnippet wh\\n\\twhile (${1}) ${2}\\n##\\n## Main method\\nsnippet main\\n\\tpublic static void main (String[] args) {\\n\\t\\t${1:/* code */}\\n\\t}\\n##\\n## Print Methods\\nsnippet print\\n\\tSystem.out.print(\\\"${1:Message}\\\");\\nsnippet printf\\n\\tSystem.out.printf(\\\"${1:Message}\\\", ${2:args});\\nsnippet println\\n\\tSystem.out.println(${1});\\n##\\n## Render Methods\\nsnippet ren\\n\\trender(${1:param});${2}\\nsnippet rena\\n\\trenderArgs.put(\\\"${1}\\\", ${2});${3}\\nsnippet renb\\n\\trenderBinary(${1:param});${2}\\nsnippet renj\\n\\trenderJSON(${1:param});${2}\\nsnippet renx\\n\\trenderXml(${1:param});${2}\\n##\\n## Setter and Getter Methods\\nsnippet set\\n\\t${1:public} void set${3:}(${2:String} ${4:}){\\n\\t\\tthis.$4 = $4;\\n\\t}\\nsnippet get\\n\\t${1:public} ${2:String} get${3:}(){\\n\\t\\treturn this.${4:};\\n\\t}\\n##\\n## Terminate Methods or Loops\\nsnippet re\\n\\treturn\\nsnippet br\\n\\tbreak;\\n##\\n## Test Methods\\nsnippet t\\n\\tpublic void test${1:Name}() throws Exception {\\n\\t\\t${2}\\n\\t}\\nsnippet test\\n\\t@Test\\n\\tpublic void test${1:Name}() throws Exception {\\n\\t\\t${2}\\n\\t}\\n##\\n## Utils\\nsnippet Sc\\n\\tScanner\\n##\\n## Miscellaneous\\nsnippet action\\n\\tpublic static void ${1:index}(${2:args}) { ${3} }\\nsnippet rnf\\n\\tnotFound(${1:param});${2}\\nsnippet rnfin\\n\\tnotFoundIfNull(${1:param});${2}\\nsnippet rr\\n\\tredirect(${1:param});${2}\\nsnippet ru\\n\\tunauthorized(${1:param});${2}\\nsnippet unless\\n\\t(unless=${1:param});${2}\\n\";\n\n});\n\nace.define(\"ace/snippets/java\",[\"require\",\"exports\",\"module\",\"ace/snippets/java.snippets\"], function(require, exports, module){\"use strict\";\nexports.snippetText = require(\"./java.snippets\");\nexports.scope = \"java\";\n\n}); (function() {\n ace.require([\"ace/snippets/java\"], function(m) {\n if (typeof module == \"object\" && typeof exports == \"object\" && module) {\n module.exports = m;\n }\n });\n })();\n ","ace.define(\"ace/snippets/javascript.snippets\",[\"require\",\"exports\",\"module\"], function(require, exports, module){module.exports = \"# Prototype\\nsnippet proto\\n\\t${1:class_name}.prototype.${2:method_name} = function(${3:first_argument}) {\\n\\t\\t${4:// body...}\\n\\t};\\n# Function\\nsnippet fun\\n\\tfunction ${1?:function_name}(${2:argument}) {\\n\\t\\t${3:// body...}\\n\\t}\\n# Anonymous Function\\nregex /((=)\\\\s*|(:)\\\\s*|(\\\\()|\\\\b)/f/(\\\\))?/\\nsnippet f\\n\\tfunction${M1?: ${1:functionName}}($2) {\\n\\t\\t${0:$TM_SELECTED_TEXT}\\n\\t}${M2?;}${M3?,}${M4?)}\\n# Immediate function\\ntrigger \\\\(?f\\\\(\\nendTrigger \\\\)?\\nsnippet f(\\n\\t(function(${1}) {\\n\\t\\t${0:${TM_SELECTED_TEXT:/* code */}}\\n\\t}(${1}));\\n# if\\nsnippet if\\n\\tif (${1:true}) {\\n\\t\\t${0}\\n\\t}\\n# if ... else\\nsnippet ife\\n\\tif (${1:true}) {\\n\\t\\t${2}\\n\\t} else {\\n\\t\\t${0}\\n\\t}\\n# tertiary conditional\\nsnippet ter\\n\\t${1:/* condition */} ? ${2:a} : ${3:b}\\n# switch\\nsnippet switch\\n\\tswitch (${1:expression}) {\\n\\t\\tcase '${3:case}':\\n\\t\\t\\t${4:// code}\\n\\t\\t\\tbreak;\\n\\t\\t${5}\\n\\t\\tdefault:\\n\\t\\t\\t${2:// code}\\n\\t}\\n# case\\nsnippet case\\n\\tcase '${1:case}':\\n\\t\\t${2:// code}\\n\\t\\tbreak;\\n\\t${3}\\n\\n# while (...) {...}\\nsnippet wh\\n\\twhile (${1:/* condition */}) {\\n\\t\\t${0:/* code */}\\n\\t}\\n# try\\nsnippet try\\n\\ttry {\\n\\t\\t${0:/* code */}\\n\\t} catch (e) {}\\n# do...while\\nsnippet do\\n\\tdo {\\n\\t\\t${2:/* code */}\\n\\t} while (${1:/* condition */});\\n# Object Method\\nsnippet :f\\nregex /([,{[])|^\\\\s*/:f/\\n\\t${1:method_name}: function(${2:attribute}) {\\n\\t\\t${0}\\n\\t}${3:,}\\n# setTimeout function\\nsnippet setTimeout\\nregex /\\\\b/st|timeout|setTimeo?u?t?/\\n\\tsetTimeout(function() {${3:$TM_SELECTED_TEXT}}, ${1:10});\\n# Get Elements\\nsnippet gett\\n\\tgetElementsBy${1:TagName}('${2}')${3}\\n# Get Element\\nsnippet get\\n\\tgetElementBy${1:Id}('${2}')${3}\\n# console.log (Firebug)\\nsnippet cl\\n\\tconsole.log(${1});\\n# return\\nsnippet ret\\n\\treturn ${1:result}\\n# for (property in object ) { ... }\\nsnippet fori\\n\\tfor (var ${1:prop} in ${2:Things}) {\\n\\t\\t${0:$2[$1]}\\n\\t}\\n# hasOwnProperty\\nsnippet has\\n\\thasOwnProperty(${1})\\n# docstring\\nsnippet /**\\n\\t/**\\n\\t * ${1:description}\\n\\t *\\n\\t */\\nsnippet @par\\nregex /^\\\\s*\\\\*\\\\s*/@(para?m?)?/\\n\\t@param {${1:type}} ${2:name} ${3:description}\\nsnippet @ret\\n\\t@return {${1:type}} ${2:description}\\n# JSON.parse\\nsnippet jsonp\\n\\tJSON.parse(${1:jstr});\\n# JSON.stringify\\nsnippet jsons\\n\\tJSON.stringify(${1:object});\\n# self-defining function\\nsnippet sdf\\n\\tvar ${1:function_name} = function(${2:argument}) {\\n\\t\\t${3:// initial code ...}\\n\\n\\t\\t$1 = function($2) {\\n\\t\\t\\t${4:// main code}\\n\\t\\t};\\n\\t}\\n# singleton\\nsnippet sing\\n\\tfunction ${1:Singleton} (${2:argument}) {\\n\\t\\t// the cached instance\\n\\t\\tvar instance;\\n\\n\\t\\t// rewrite the constructor\\n\\t\\t$1 = function $1($2) {\\n\\t\\t\\treturn instance;\\n\\t\\t};\\n\\t\\t\\n\\t\\t// carry over the prototype properties\\n\\t\\t$1.prototype = this;\\n\\n\\t\\t// the instance\\n\\t\\tinstance = new $1();\\n\\n\\t\\t// reset the constructor pointer\\n\\t\\tinstance.constructor = $1;\\n\\n\\t\\t${3:// code ...}\\n\\n\\t\\treturn instance;\\n\\t}\\n# class\\nsnippet class\\nregex /^\\\\s*/clas{0,2}/\\n\\tvar ${1:class} = function(${20}) {\\n\\t\\t$40$0\\n\\t};\\n\\t\\n\\t(function() {\\n\\t\\t${60:this.prop = \\\"\\\"}\\n\\t}).call(${1:class}.prototype);\\n\\t\\n\\texports.${1:class} = ${1:class};\\n# \\nsnippet for-\\n\\tfor (var ${1:i} = ${2:Things}.length; ${1:i}--; ) {\\n\\t\\t${0:${2:Things}[${1:i}];}\\n\\t}\\n# for (...) {...}\\nsnippet for\\n\\tfor (var ${1:i} = 0; $1 < ${2:Things}.length; $1++) {\\n\\t\\t${3:$2[$1]}$0\\n\\t}\\n# for (...) {...} (Improved Native For-Loop)\\nsnippet forr\\n\\tfor (var ${1:i} = ${2:Things}.length - 1; $1 >= 0; $1--) {\\n\\t\\t${3:$2[$1]}$0\\n\\t}\\n\\n\\n#modules\\nsnippet def\\n\\tdefine(function(require, exports, module) {\\n\\t\\\"use strict\\\";\\n\\tvar ${1/.*\\\\///} = require(\\\"${1}\\\");\\n\\t\\n\\t$TM_SELECTED_TEXT\\n\\t});\\nsnippet req\\nguard ^\\\\s*\\n\\tvar ${1/.*\\\\///} = require(\\\"${1}\\\");\\n\\t$0\\nsnippet requ\\nguard ^\\\\s*\\n\\tvar ${1/.*\\\\/(.)/\\\\u$1/} = require(\\\"${1}\\\").${1/.*\\\\/(.)/\\\\u$1/};\\n\\t$0\\n\";\n\n});\n\nace.define(\"ace/snippets/javascript\",[\"require\",\"exports\",\"module\",\"ace/snippets/javascript.snippets\"], function(require, exports, module){\"use strict\";\nexports.snippetText = require(\"./javascript.snippets\");\nexports.scope = \"javascript\";\n\n}); (function() {\n ace.require([\"ace/snippets/javascript\"], function(m) {\n if (typeof module == \"object\" && typeof exports == \"object\" && module) {\n module.exports = m;\n }\n });\n })();\n ","\n; (function() {\n ace.require([\"ace/snippets/json\"], function(m) {\n if (typeof module == \"object\" && typeof exports == \"object\" && module) {\n module.exports = m;\n }\n });\n })();\n ","ace.define(\"ace/snippets/jsp.snippets\",[\"require\",\"exports\",\"module\"], function(require, exports, module){module.exports = \"snippet @page\\n\\t<%@page contentType=\\\"text/html\\\" pageEncoding=\\\"UTF-8\\\"%>\\nsnippet jstl\\n\\t<%@ taglib uri=\\\"http://java.sun.com/jsp/jstl/core\\\" prefix=\\\"c\\\" %>\\n\\t<%@ taglib uri=\\\"http://java.sun.com/jsp/jstl/functions\\\" prefix=\\\"fn\\\" %>\\nsnippet jstl:c\\n\\t<%@ taglib uri=\\\"http://java.sun.com/jsp/jstl/core\\\" prefix=\\\"c\\\" %>\\nsnippet jstl:fn\\n\\t<%@ taglib uri=\\\"http://java.sun.com/jsp/jstl/functions\\\" prefix=\\\"fn\\\" %>\\nsnippet cpath\\n\\t${pageContext.request.contextPath}\\nsnippet cout\\n\\t\\nsnippet cset\\n\\t\\nsnippet cremove\\n\\t\\nsnippet ccatch\\n\\t\\nsnippet cif\\n\\t\\n\\t\\t${2}\\n\\t\\nsnippet cchoose\\n\\t\\n\\t\\t${1}\\n\\t\\nsnippet cwhen\\n\\t\\n\\t\\t${2}\\n\\t\\nsnippet cother\\n\\t\\n\\t\\t${1}\\n\\t\\nsnippet cfore\\n\\t\\n\\t\\t${4:}\\n\\t\\nsnippet cfort\\n\\t${2:item1,item2,item3}\\n\\t\\n\\t\\t${5:}\\n\\t\\nsnippet cparam\\n\\t\\nsnippet cparam+\\n\\t\\n\\tcparam+${3}\\nsnippet cimport\\n\\t\\nsnippet cimport+\\n\\t\\n\\t\\t\\n\\t\\tcparam+${4}\\n\\t\\nsnippet curl\\n\\t\\n\\t${3}\\nsnippet curl+\\n\\t\\n\\t\\t\\n\\t\\tcparam+${6}\\n\\t\\n\\t${3}\\nsnippet credirect\\n\\t\\nsnippet contains\\n\\t${fn:contains(${1:string}, ${2:substr})}\\nsnippet contains:i\\n\\t${fn:containsIgnoreCase(${1:string}, ${2:substr})}\\nsnippet endswith\\n\\t${fn:endsWith(${1:string}, ${2:suffix})}\\nsnippet escape\\n\\t${fn:escapeXml(${1:string})}\\nsnippet indexof\\n\\t${fn:indexOf(${1:string}, ${2:substr})}\\nsnippet join\\n\\t${fn:join(${1:collection}, ${2:delims})}\\nsnippet length\\n\\t${fn:length(${1:collection_or_string})}\\nsnippet replace\\n\\t${fn:replace(${1:string}, ${2:substr}, ${3:replace})}\\nsnippet split\\n\\t${fn:split(${1:string}, ${2:delims})}\\nsnippet startswith\\n\\t${fn:startsWith(${1:string}, ${2:prefix})}\\nsnippet substr\\n\\t${fn:substring(${1:string}, ${2:begin}, ${3:end})}\\nsnippet substr:a\\n\\t${fn:substringAfter(${1:string}, ${2:substr})}\\nsnippet substr:b\\n\\t${fn:substringBefore(${1:string}, ${2:substr})}\\nsnippet lc\\n\\t${fn:toLowerCase(${1:string})}\\nsnippet uc\\n\\t${fn:toUpperCase(${1:string})}\\nsnippet trim\\n\\t${fn:trim(${1:string})}\\n\";\n\n});\n\nace.define(\"ace/snippets/jsp\",[\"require\",\"exports\",\"module\",\"ace/snippets/jsp.snippets\"], function(require, exports, module){\"use strict\";\nexports.snippetText = require(\"./jsp.snippets\");\nexports.scope = \"jsp\";\n\n}); (function() {\n ace.require([\"ace/snippets/jsp\"], function(m) {\n if (typeof module == \"object\" && typeof exports == \"object\" && module) {\n module.exports = m;\n }\n });\n })();\n ","ace.define(\"ace/snippets/markdown.snippets\",[\"require\",\"exports\",\"module\"], function(require, exports, module){module.exports = \"# Markdown\\n\\n# Includes octopress (http://octopress.org/) snippets\\n\\nsnippet [\\n\\t[${1:text}](http://${2:address} \\\"${3:title}\\\")\\nsnippet [*\\n\\t[${1:link}](${2:`@*`} \\\"${3:title}\\\")${4}\\n\\nsnippet [:\\n\\t[${1:id}]: http://${2:url} \\\"${3:title}\\\"\\nsnippet [:*\\n\\t[${1:id}]: ${2:`@*`} \\\"${3:title}\\\"\\n\\nsnippet \\nsnippet ${4}\\n\\nsnippet ![:\\n\\t![${1:id}]: ${2:url} \\\"${3:title}\\\"\\nsnippet ![:*\\n\\t![${1:id}]: ${2:`@*`} \\\"${3:title}\\\"\\n\\nsnippet ===\\nregex /^/=+/=*//\\n\\t${PREV_LINE/./=/g}\\n\\t\\n\\t${0}\\nsnippet ---\\nregex /^/-+/-*//\\n\\t${PREV_LINE/./-/g}\\n\\t\\n\\t${0}\\nsnippet blockquote\\n\\t{% blockquote %}\\n\\t${1:quote}\\n\\t{% endblockquote %}\\n\\nsnippet blockquote-author\\n\\t{% blockquote ${1:author}, ${2:title} %}\\n\\t${3:quote}\\n\\t{% endblockquote %}\\n\\nsnippet blockquote-link\\n\\t{% blockquote ${1:author} ${2:URL} ${3:link_text} %}\\n\\t${4:quote}\\n\\t{% endblockquote %}\\n\\nsnippet bt-codeblock-short\\n\\t```\\n\\t${1:code_snippet}\\n\\t```\\n\\nsnippet bt-codeblock-full\\n\\t``` ${1:language} ${2:title} ${3:URL} ${4:link_text}\\n\\t${5:code_snippet}\\n\\t```\\n\\nsnippet codeblock-short\\n\\t{% codeblock %}\\n\\t${1:code_snippet}\\n\\t{% endcodeblock %}\\n\\nsnippet codeblock-full\\n\\t{% codeblock ${1:title} lang:${2:language} ${3:URL} ${4:link_text} %}\\n\\t${5:code_snippet}\\n\\t{% endcodeblock %}\\n\\nsnippet gist-full\\n\\t{% gist ${1:gist_id} ${2:filename} %}\\n\\nsnippet gist-short\\n\\t{% gist ${1:gist_id} %}\\n\\nsnippet img\\n\\t{% img ${1:class} ${2:URL} ${3:width} ${4:height} ${5:title_text} ${6:alt_text} %}\\n\\nsnippet youtube\\n\\t{% youtube ${1:video_id} %}\\n\\n# The quote should appear only once in the text. It is inherently part of it.\\n# See http://octopress.org/docs/plugins/pullquote/ for more info.\\n\\nsnippet pullquote\\n\\t{% pullquote %}\\n\\t${1:text} {\\\" ${2:quote} \\\"} ${3:text}\\n\\t{% endpullquote %}\\n\";\n\n});\n\nace.define(\"ace/snippets/markdown\",[\"require\",\"exports\",\"module\",\"ace/snippets/markdown.snippets\"], function(require, exports, module){\"use strict\";\nexports.snippetText = require(\"./markdown.snippets\");\nexports.scope = \"markdown\";\n\n}); (function() {\n ace.require([\"ace/snippets/markdown\"], function(m) {\n if (typeof module == \"object\" && typeof exports == \"object\" && module) {\n module.exports = m;\n }\n });\n })();\n ","\n; (function() {\n ace.require([\"ace/snippets/properties\"], function(m) {\n if (typeof module == \"object\" && typeof exports == \"object\" && module) {\n module.exports = m;\n }\n });\n })();\n ","ace.define(\"ace/snippets/python.snippets\",[\"require\",\"exports\",\"module\"], function(require, exports, module){module.exports = \"snippet #!\\n\\t#!/usr/bin/env python\\nsnippet imp\\n\\timport ${1:module}\\nsnippet from\\n\\tfrom ${1:package} import ${2:module}\\n# Module Docstring\\nsnippet docs\\n\\t'''\\n\\tFile: ${1:FILENAME:file_name}\\n\\tAuthor: ${2:author}\\n\\tDescription: ${3}\\n\\t'''\\nsnippet wh\\n\\twhile ${1:condition}:\\n\\t\\t${2:# TODO: write code...}\\n# dowh - does the same as do...while in other languages\\nsnippet dowh\\n\\twhile True:\\n\\t\\t${1:# TODO: write code...}\\n\\t\\tif ${2:condition}:\\n\\t\\t\\tbreak\\nsnippet with\\n\\twith ${1:expr} as ${2:var}:\\n\\t\\t${3:# TODO: write code...}\\n# New Class\\nsnippet cl\\n\\tclass ${1:ClassName}(${2:object}):\\n\\t\\t\\\"\\\"\\\"${3:docstring for $1}\\\"\\\"\\\"\\n\\t\\tdef __init__(self, ${4:arg}):\\n\\t\\t\\t${5:super($1, self).__init__()}\\n\\t\\t\\tself.$4 = $4\\n\\t\\t\\t${6}\\n# New Function\\nsnippet def\\n\\tdef ${1:fname}(${2:`indent('.') ? 'self' : ''`}):\\n\\t\\t\\\"\\\"\\\"${3:docstring for $1}\\\"\\\"\\\"\\n\\t\\t${4:# TODO: write code...}\\nsnippet deff\\n\\tdef ${1:fname}(${2:`indent('.') ? 'self' : ''`}):\\n\\t\\t${3:# TODO: write code...}\\n# New Method\\nsnippet defs\\n\\tdef ${1:mname}(self, ${2:arg}):\\n\\t\\t${3:# TODO: write code...}\\n# New Property\\nsnippet property\\n\\tdef ${1:foo}():\\n\\t\\tdoc = \\\"${2:The $1 property.}\\\"\\n\\t\\tdef fget(self):\\n\\t\\t\\t${3:return self._$1}\\n\\t\\tdef fset(self, value):\\n\\t\\t\\t${4:self._$1 = value}\\n# Ifs\\nsnippet if\\n\\tif ${1:condition}:\\n\\t\\t${2:# TODO: write code...}\\nsnippet el\\n\\telse:\\n\\t\\t${1:# TODO: write code...}\\nsnippet ei\\n\\telif ${1:condition}:\\n\\t\\t${2:# TODO: write code...}\\n# For\\nsnippet for\\n\\tfor ${1:item} in ${2:items}:\\n\\t\\t${3:# TODO: write code...}\\n# Encodes\\nsnippet cutf8\\n\\t# -*- coding: utf-8 -*-\\nsnippet clatin1\\n\\t# -*- coding: latin-1 -*-\\nsnippet cascii\\n\\t# -*- coding: ascii -*-\\n# Lambda\\nsnippet ld\\n\\t${1:var} = lambda ${2:vars} : ${3:action}\\nsnippet .\\n\\tself.\\nsnippet try Try/Except\\n\\ttry:\\n\\t\\t${1:# TODO: write code...}\\n\\texcept ${2:Exception}, ${3:e}:\\n\\t\\t${4:raise $3}\\nsnippet try Try/Except/Else\\n\\ttry:\\n\\t\\t${1:# TODO: write code...}\\n\\texcept ${2:Exception}, ${3:e}:\\n\\t\\t${4:raise $3}\\n\\telse:\\n\\t\\t${5:# TODO: write code...}\\nsnippet try Try/Except/Finally\\n\\ttry:\\n\\t\\t${1:# TODO: write code...}\\n\\texcept ${2:Exception}, ${3:e}:\\n\\t\\t${4:raise $3}\\n\\tfinally:\\n\\t\\t${5:# TODO: write code...}\\nsnippet try Try/Except/Else/Finally\\n\\ttry:\\n\\t\\t${1:# TODO: write code...}\\n\\texcept ${2:Exception}, ${3:e}:\\n\\t\\t${4:raise $3}\\n\\telse:\\n\\t\\t${5:# TODO: write code...}\\n\\tfinally:\\n\\t\\t${6:# TODO: write code...}\\n# if __name__ == '__main__':\\nsnippet ifmain\\n\\tif __name__ == '__main__':\\n\\t\\t${1:main()}\\n# __magic__\\nsnippet _\\n\\t__${1:init}__${2}\\n# python debugger (pdb)\\nsnippet pdb\\n\\timport pdb; pdb.set_trace()\\n# ipython debugger (ipdb)\\nsnippet ipdb\\n\\timport ipdb; ipdb.set_trace()\\n# ipython debugger (pdbbb)\\nsnippet pdbbb\\n\\timport pdbpp; pdbpp.set_trace()\\nsnippet pprint\\n\\timport pprint; pprint.pprint(${1})${2}\\nsnippet \\\"\\n\\t\\\"\\\"\\\"\\n\\t${1:doc}\\n\\t\\\"\\\"\\\"\\n# test function/method\\nsnippet test\\n\\tdef test_${1:description}(${2:self}):\\n\\t\\t${3:# TODO: write code...}\\n# test case\\nsnippet testcase\\n\\tclass ${1:ExampleCase}(unittest.TestCase):\\n\\t\\t\\n\\t\\tdef test_${2:description}(self):\\n\\t\\t\\t${3:# TODO: write code...}\\nsnippet fut\\n\\tfrom __future__ import ${1}\\n#getopt\\nsnippet getopt\\n\\ttry:\\n\\t\\t# Short option syntax: \\\"hv:\\\"\\n\\t\\t# Long option syntax: \\\"help\\\" or \\\"verbose=\\\"\\n\\t\\topts, args = getopt.getopt(sys.argv[1:], \\\"${1:short_options}\\\", [${2:long_options}])\\n\\t\\n\\texcept getopt.GetoptError, err:\\n\\t\\t# Print debug info\\n\\t\\tprint str(err)\\n\\t\\t${3:error_action}\\n\\n\\tfor option, argument in opts:\\n\\t\\tif option in (\\\"-h\\\", \\\"--help\\\"):\\n\\t\\t\\t${4}\\n\\t\\telif option in (\\\"-v\\\", \\\"--verbose\\\"):\\n\\t\\t\\tverbose = argument\\n\";\n\n});\n\nace.define(\"ace/snippets/python\",[\"require\",\"exports\",\"module\",\"ace/snippets/python.snippets\"], function(require, exports, module){\"use strict\";\nexports.snippetText = require(\"./python.snippets\");\nexports.scope = \"python\";\n\n}); (function() {\n ace.require([\"ace/snippets/python\"], function(m) {\n if (typeof module == \"object\" && typeof exports == \"object\" && module) {\n module.exports = m;\n }\n });\n })();\n ","ace.define(\"ace/snippets/sh.snippets\",[\"require\",\"exports\",\"module\"], function(require, exports, module){module.exports = \"# Shebang. Executing bash via /usr/bin/env makes scripts more portable.\\nsnippet #!\\n\\t#!/usr/bin/env bash\\n\\t\\nsnippet if\\n\\tif [[ ${1:condition} ]]; then\\n\\t\\t${2:#statements}\\n\\tfi\\nsnippet elif\\n\\telif [[ ${1:condition} ]]; then\\n\\t\\t${2:#statements}\\nsnippet for\\n\\tfor (( ${2:i} = 0; $2 < ${1:count}; $2++ )); do\\n\\t\\t${3:#statements}\\n\\tdone\\nsnippet fori\\n\\tfor ${1:needle} in ${2:haystack} ; do\\n\\t\\t${3:#statements}\\n\\tdone\\nsnippet wh\\n\\twhile [[ ${1:condition} ]]; do\\n\\t\\t${2:#statements}\\n\\tdone\\nsnippet until\\n\\tuntil [[ ${1:condition} ]]; do\\n\\t\\t${2:#statements}\\n\\tdone\\nsnippet case\\n\\tcase ${1:word} in\\n\\t\\t${2:pattern})\\n\\t\\t\\t${3};;\\n\\tesac\\nsnippet go \\n\\twhile getopts '${1:o}' ${2:opts} \\n\\tdo \\n\\t\\tcase $$2 in\\n\\t\\t${3:o0})\\n\\t\\t\\t${4:#staments};;\\n\\t\\tesac\\n\\tdone\\n# Set SCRIPT_DIR variable to directory script is located.\\nsnippet sdir\\n\\tSCRIPT_DIR=\\\"$( cd \\\"$( dirname \\\"${BASH_SOURCE[0]}\\\" )\\\" && pwd )\\\"\\n# getopt\\nsnippet getopt\\n\\t__ScriptVersion=\\\"${1:version}\\\"\\n\\n\\t#=== FUNCTION ================================================================\\n\\t# NAME: usage\\n\\t# DESCRIPTION: Display usage information.\\n\\t#===============================================================================\\n\\tfunction usage ()\\n\\t{\\n\\t\\t\\tcat <<- EOT\\n\\n\\t Usage : $${0:0} [options] [--] \\n\\n\\t Options: \\n\\t -h|help Display this message\\n\\t -v|version Display script version\\n\\n\\tEOT\\n\\t} # ---------- end of function usage ----------\\n\\n\\t#-----------------------------------------------------------------------\\n\\t# Handle command line arguments\\n\\t#-----------------------------------------------------------------------\\n\\n\\twhile getopts \\\":hv\\\" opt\\n\\tdo\\n\\t case $opt in\\n\\n\\t\\th|help ) usage; exit 0 ;;\\n\\n\\t\\tv|version ) echo \\\"$${0:0} -- Version $__ScriptVersion\\\"; exit 0 ;;\\n\\n\\t\\t\\\\? ) echo -e \\\"\\\\n Option does not exist : $OPTARG\\\\n\\\"\\n\\t\\t\\t usage; exit 1 ;;\\n\\n\\t esac # --- end of case ---\\n\\tdone\\n\\tshift $(($OPTIND-1))\\n\\n\";\n\n});\n\nace.define(\"ace/snippets/sh\",[\"require\",\"exports\",\"module\",\"ace/snippets/sh.snippets\"], function(require, exports, module){\"use strict\";\nexports.snippetText = require(\"./sh.snippets\");\nexports.scope = \"sh\";\n\n}); (function() {\n ace.require([\"ace/snippets/sh\"], function(m) {\n if (typeof module == \"object\" && typeof exports == \"object\" && module) {\n module.exports = m;\n }\n });\n })();\n ","ace.define(\"ace/snippets/sql.snippets\",[\"require\",\"exports\",\"module\"], function(require, exports, module){module.exports = \"snippet tbl\\n\\tcreate table ${1:table} (\\n\\t\\t${2:columns}\\n\\t);\\nsnippet col\\n\\t${1:name}\\t${2:type}\\t${3:default ''}\\t${4:not null}\\nsnippet ccol\\n\\t${1:name}\\tvarchar2(${2:size})\\t${3:default ''}\\t${4:not null}\\nsnippet ncol\\n\\t${1:name}\\tnumber\\t${3:default 0}\\t${4:not null}\\nsnippet dcol\\n\\t${1:name}\\tdate\\t${3:default sysdate}\\t${4:not null}\\nsnippet ind\\n\\tcreate index ${3:$1_$2} on ${1:table}(${2:column});\\nsnippet uind\\n\\tcreate unique index ${1:name} on ${2:table}(${3:column});\\nsnippet tblcom\\n\\tcomment on table ${1:table} is '${2:comment}';\\nsnippet colcom\\n\\tcomment on column ${1:table}.${2:column} is '${3:comment}';\\nsnippet addcol\\n\\talter table ${1:table} add (${2:column} ${3:type});\\nsnippet seq\\n\\tcreate sequence ${1:name} start with ${2:1} increment by ${3:1} minvalue ${4:1};\\nsnippet s*\\n\\tselect * from ${1:table}\\n\";\n\n});\n\nace.define(\"ace/snippets/sql\",[\"require\",\"exports\",\"module\",\"ace/snippets/sql.snippets\"], function(require, exports, module){\"use strict\";\nexports.snippetText = require(\"./sql.snippets\");\nexports.scope = \"sql\";\n\n}); (function() {\n ace.require([\"ace/snippets/sql\"], function(m) {\n if (typeof module == \"object\" && typeof exports == \"object\" && module) {\n module.exports = m;\n }\n });\n })();\n ","\n; (function() {\n ace.require([\"ace/snippets/text\"], function(m) {\n if (typeof module == \"object\" && typeof exports == \"object\" && module) {\n module.exports = m;\n }\n });\n })();\n ","\n; (function() {\n ace.require([\"ace/snippets/typescript\"], function(m) {\n if (typeof module == \"object\" && typeof exports == \"object\" && module) {\n module.exports = m;\n }\n });\n })();\n ","\n; (function() {\n ace.require([\"ace/snippets/xml\"], function(m) {\n if (typeof module == \"object\" && typeof exports == \"object\" && module) {\n module.exports = m;\n }\n });\n })();\n ","\n; (function() {\n ace.require([\"ace/snippets/yaml\"], function(m) {\n if (typeof module == \"object\" && typeof exports == \"object\" && module) {\n module.exports = m;\n }\n });\n })();\n ","ace.define(\"ace/theme/chrome-css\",[\"require\",\"exports\",\"module\"], function(require, exports, module){module.exports = \".ace-chrome .ace_gutter {\\n background: #ebebeb;\\n color: #333;\\n overflow : hidden;\\n}\\n\\n.ace-chrome .ace_print-margin {\\n width: 1px;\\n background: #e8e8e8;\\n}\\n\\n.ace-chrome {\\n background-color: #FFFFFF;\\n color: black;\\n}\\n\\n.ace-chrome .ace_cursor {\\n color: black;\\n}\\n\\n.ace-chrome .ace_invisible {\\n color: rgb(191, 191, 191);\\n}\\n\\n.ace-chrome .ace_constant.ace_buildin {\\n color: rgb(88, 72, 246);\\n}\\n\\n.ace-chrome .ace_constant.ace_language {\\n color: rgb(88, 92, 246);\\n}\\n\\n.ace-chrome .ace_constant.ace_library {\\n color: rgb(6, 150, 14);\\n}\\n\\n.ace-chrome .ace_invalid {\\n background-color: rgb(153, 0, 0);\\n color: white;\\n}\\n\\n.ace-chrome .ace_fold {\\n}\\n\\n.ace-chrome .ace_support.ace_function {\\n color: rgb(60, 76, 114);\\n}\\n\\n.ace-chrome .ace_support.ace_constant {\\n color: rgb(6, 150, 14);\\n}\\n\\n.ace-chrome .ace_support.ace_type,\\n.ace-chrome .ace_support.ace_class\\n.ace-chrome .ace_support.ace_other {\\n color: rgb(109, 121, 222);\\n}\\n\\n.ace-chrome .ace_variable.ace_parameter {\\n font-style:italic;\\n color:#FD971F;\\n}\\n.ace-chrome .ace_keyword.ace_operator {\\n color: rgb(104, 118, 135);\\n}\\n\\n.ace-chrome .ace_comment {\\n color: #236e24;\\n}\\n\\n.ace-chrome .ace_comment.ace_doc {\\n color: #236e24;\\n}\\n\\n.ace-chrome .ace_comment.ace_doc.ace_tag {\\n color: #236e24;\\n}\\n\\n.ace-chrome .ace_constant.ace_numeric {\\n color: rgb(0, 0, 205);\\n}\\n\\n.ace-chrome .ace_variable {\\n color: rgb(49, 132, 149);\\n}\\n\\n.ace-chrome .ace_xml-pe {\\n color: rgb(104, 104, 91);\\n}\\n\\n.ace-chrome .ace_entity.ace_name.ace_function {\\n color: #0000A2;\\n}\\n\\n\\n.ace-chrome .ace_heading {\\n color: rgb(12, 7, 255);\\n}\\n\\n.ace-chrome .ace_list {\\n color:rgb(185, 6, 144);\\n}\\n\\n.ace-chrome .ace_marker-layer .ace_selection {\\n background: rgb(181, 213, 255);\\n}\\n\\n.ace-chrome .ace_marker-layer .ace_step {\\n background: rgb(252, 255, 0);\\n}\\n\\n.ace-chrome .ace_marker-layer .ace_stack {\\n background: rgb(164, 229, 101);\\n}\\n\\n.ace-chrome .ace_marker-layer .ace_bracket {\\n margin: -1px 0 0 -1px;\\n border: 1px solid rgb(192, 192, 192);\\n}\\n\\n.ace-chrome .ace_marker-layer .ace_active-line {\\n background: rgba(0, 0, 0, 0.07);\\n}\\n\\n.ace-chrome .ace_gutter-active-line {\\n background-color : #dcdcdc;\\n}\\n\\n.ace-chrome .ace_marker-layer .ace_selected-word {\\n background: rgb(250, 250, 255);\\n border: 1px solid rgb(200, 200, 250);\\n}\\n\\n.ace-chrome .ace_storage,\\n.ace-chrome .ace_keyword,\\n.ace-chrome .ace_meta.ace_tag {\\n color: rgb(147, 15, 128);\\n}\\n\\n.ace-chrome .ace_string.ace_regex {\\n color: rgb(255, 0, 0)\\n}\\n\\n.ace-chrome .ace_string {\\n color: #1A1AA6;\\n}\\n\\n.ace-chrome .ace_entity.ace_other.ace_attribute-name {\\n color: #994409;\\n}\\n\\n.ace-chrome .ace_indent-guide {\\n background: url(\\\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAACCAYAAACZgbYnAAAAE0lEQVQImWP4////f4bLly//BwAmVgd1/w11/gAAAABJRU5ErkJggg==\\\") right repeat-y;\\n}\\n \\n.ace-chrome .ace_indent-guide-active {\\n background: url(\\\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAACCAYAAACZgbYnAAAACXBIWXMAAAsTAAALEwEAmpwYAAAAIGNIUk0AAHolAACAgwAA+f8AAIDpAAB1MAAA6mAAADqYAAAXb5JfxUYAAAAZSURBVHjaYvj///9/hivKyv8BAAAA//8DACLqBhbvk+/eAAAAAElFTkSuQmCC\\\") right repeat-y;\\n}\\n\";\n\n});\n\nace.define(\"ace/theme/chrome\",[\"require\",\"exports\",\"module\",\"ace/theme/chrome-css\",\"ace/lib/dom\"], function(require, exports, module){exports.isDark = false;\nexports.cssClass = \"ace-chrome\";\nexports.cssText = require(\"./chrome-css\");\nvar dom = require(\"../lib/dom\");\ndom.importCssString(exports.cssText, exports.cssClass, false);\n\n}); (function() {\n ace.require([\"ace/theme/chrome\"], function(m) {\n if (typeof module == \"object\" && typeof exports == \"object\" && module) {\n module.exports = m;\n }\n });\n })();\n ","export default 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}","import _typeof from \"./typeof.js\";\nexport default function _toPrimitive(input, hint) {\n if (_typeof(input) !== \"object\" || input === null) return input;\n var prim = input[Symbol.toPrimitive];\n if (prim !== undefined) {\n var res = prim.call(input, hint || \"default\");\n if (_typeof(res) !== \"object\") return res;\n throw new TypeError(\"@@toPrimitive must return a primitive value.\");\n }\n return (hint === \"string\" ? String : Number)(input);\n}","import _typeof from \"./typeof.js\";\nimport toPrimitive from \"./toPrimitive.js\";\nexport default function _toPropertyKey(arg) {\n var key = toPrimitive(arg, \"string\");\n return _typeof(key) === \"symbol\" ? key : String(key);\n}","import toPropertyKey from \"./toPropertyKey.js\";\nexport default function _defineProperty(obj, key, value) {\n key = toPropertyKey(key);\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n return obj;\n}","import defineProperty from \"./defineProperty.js\";\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}\nexport default function _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}","export default function _extends() {\n _extends = Object.assign ? Object.assign.bind() : function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n return target;\n };\n return _extends.apply(this, arguments);\n}","// https://stackoverflow.com/questions/46176165/ways-to-get-string-literal-type-of-array-values-without-enum-overhead\nexport const tuple = function () {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n return args;\n};\nexport const tupleNum = function () {\n for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n args[_key2] = arguments[_key2];\n }\n return args;\n};\nexport const withInstall = comp => {\n const c = comp;\n c.install = function (app) {\n app.component(c.displayName || c.name, comp);\n };\n return comp;\n};\nexport function eventType() {\n return {\n type: [Function, Array]\n };\n}\nexport function objectType(defaultVal) {\n return {\n type: Object,\n default: defaultVal\n };\n}\nexport function booleanType(defaultVal) {\n return {\n type: Boolean,\n default: defaultVal\n };\n}\nexport function functionType(defaultVal) {\n return {\n type: Function,\n default: defaultVal\n };\n}\nexport function anyType(defaultVal, required) {\n const type = {\n validator: () => true,\n default: defaultVal\n };\n return required ? type : type;\n}\nexport function vNodeType() {\n return {\n validator: () => true\n };\n}\nexport function arrayType(defaultVal) {\n return {\n type: Array,\n default: defaultVal\n };\n}\nexport function stringType(defaultVal) {\n return {\n type: String,\n default: defaultVal\n };\n}\nexport function someType(types, defaultVal) {\n return types ? {\n type: types,\n default: defaultVal\n } : anyType(defaultVal);\n}","/*!\n * isobject \n *\n * Copyright (c) 2014-2017, Jon Schlinkert.\n * Released under the MIT License.\n */\n\nfunction isObject(val) {\n return val != null && typeof val === 'object' && Array.isArray(val) === false;\n}\n\n/*!\n * is-plain-object \n *\n * Copyright (c) 2014-2017, Jon Schlinkert.\n * Released under the MIT License.\n */\n\nfunction isObjectObject(o) {\n return isObject(o) === true\n && Object.prototype.toString.call(o) === '[object Object]';\n}\n\nfunction isPlainObject(o) {\n var ctor,prot;\n\n if (isObjectObject(o) === false) return false;\n\n // If has modified constructor\n ctor = o.constructor;\n if (typeof ctor !== 'function') return false;\n\n // If has modified prototype\n prot = ctor.prototype;\n if (isObjectObject(prot) === false) return false;\n\n // If constructor does not have an Object-specific method\n if (prot.hasOwnProperty('isPrototypeOf') === false) {\n return false;\n }\n\n // Most likely a plain Object\n return true;\n}\n\nexport default isPlainObject;\n","import _isPlainObject from 'is-plain-object'\nimport {\n VueTypeDef,\n VueTypeValidableDef,\n VueProp,\n InferType,\n PropOptions,\n} from './types'\n\nconst ObjProto = Object.prototype\nconst toString = ObjProto.toString\nexport const hasOwn = ObjProto.hasOwnProperty\n\nconst FN_MATCH_REGEXP = /^\\s*function (\\w+)/\n\n// https://github.com/vuejs/vue/blob/dev/src/core/util/props.js#L177\nexport function getType(\n fn: VueProp | (() => any) | (new (...args: any[]) => any),\n): string {\n const type = (fn as VueProp)?.type ?? fn\n if (type) {\n const match = type.toString().match(FN_MATCH_REGEXP)\n return match ? match[1] : ''\n }\n return ''\n}\n\nexport function getNativeType(value: any): string {\n if (value === null || value === undefined) return ''\n const match = value.constructor.toString().match(FN_MATCH_REGEXP)\n return match ? match[1] : ''\n}\n\ntype PlainObject = { [key: string]: any }\nexport const isPlainObject = _isPlainObject as (obj: any) => obj is PlainObject\n\n/**\n * No-op function\n */\n// eslint-disable-next-line @typescript-eslint/no-empty-function\nexport function noop() {}\n\n/**\n * A function that returns its first argument\n *\n * @param arg - Any argument\n */\nexport const identity = (arg: any) => arg\n\nlet warn: (msg: string) => string | void = identity\n\nif (process.env.NODE_ENV !== 'production') {\n const hasConsole = typeof console !== 'undefined'\n warn = hasConsole\n ? function warn(msg) {\n // eslint-disable-next-line no-console\n console.warn(`[VueTypes warn]: ${msg}`)\n }\n : identity\n}\n\nexport { warn }\n\n/**\n * Checks for a own property in an object\n *\n * @param {object} obj - Object\n * @param {string} prop - Property to check\n */\nexport const has = (obj: T, prop: U) =>\n hasOwn.call(obj, prop)\n\n/**\n * Determines whether the passed value is an integer. Uses `Number.isInteger` if available\n *\n * @see https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Number/isInteger\n * @param {*} value - The value to be tested for being an integer.\n * @returns {boolean}\n */\nexport const isInteger =\n Number.isInteger ||\n function isInteger(value: unknown): value is number {\n return (\n typeof value === 'number' &&\n isFinite(value) &&\n Math.floor(value) === value\n )\n }\n\n/**\n * Determines whether the passed value is an Array.\n *\n * @param {*} value - The value to be tested for being an array.\n * @returns {boolean}\n */\nexport const isArray =\n Array.isArray ||\n function isArray(value): value is any[] {\n return toString.call(value) === '[object Array]'\n }\n\n/**\n * Checks if a value is a function\n *\n * @param {any} value - Value to check\n * @returns {boolean}\n */\n// eslint-disable-next-line @typescript-eslint/ban-types\nexport const isFunction = (value: unknown): value is Function =>\n toString.call(value) === '[object Function]'\n\n/**\n * Checks if the passed-in value is a VueTypes type\n * @param value - The value to check\n */\nexport const isVueTypeDef = (\n value: any,\n): value is VueTypeDef | VueTypeValidableDef =>\n isPlainObject(value) && has(value, '_vueTypes_name')\n\n/**\n * Checks if the passed-in value is a Vue prop definition object or a VueTypes type\n * @param value - The value to check\n */\nexport const isComplexType = (value: any): value is VueProp =>\n isPlainObject(value) &&\n (has(value, 'type') ||\n ['_vueTypes_name', 'validator', 'default', 'required'].some((k) =>\n has(value, k),\n ))\n\nexport interface WrappedFn {\n (...args: any[]): any\n __original: (...args: any[]) => any\n}\n\n/**\n * Binds a function to a context and saves a reference to the original.\n *\n * @param fn - Target function\n * @param ctx - New function context\n */\nexport function bindTo(fn: (...args: any[]) => any, ctx: any): WrappedFn {\n return Object.defineProperty(fn.bind(ctx), '__original', {\n value: fn,\n })\n}\n\n/**\n * Returns the original function bounded with `bindTo`. If the passed-in function\n * has not be bound, the function itself will be returned instead.\n *\n * @param fn - Function to unwrap\n */\n// eslint-disable-next-line @typescript-eslint/ban-types\nexport function unwrap(fn: T) {\n return (fn as WrappedFn).__original ?? fn\n}\n\n/**\n * Validates a given value against a prop type object.\n *\n * If `silent` is `false` (default) will return a boolean. If it is set to `true`\n * it will return `true` on success or a string error message on failure\n *\n * @param {Object|*} type - Type to use for validation. Either a type object or a constructor\n * @param {*} value - Value to check\n * @param {boolean} silent - Silence warnings\n */\nexport function validateType(\n type: T,\n value: U,\n silent = false,\n): string | boolean {\n let typeToCheck: { [key: string]: any }\n let valid = true\n let expectedType = ''\n if (!isPlainObject(type)) {\n typeToCheck = { type }\n } else {\n typeToCheck = type\n }\n const namePrefix = isVueTypeDef(typeToCheck)\n ? typeToCheck._vueTypes_name + ' - '\n : ''\n\n if (isComplexType(typeToCheck) && typeToCheck.type !== null) {\n if (typeToCheck.type === undefined || typeToCheck.type === true) {\n return valid\n }\n if (!typeToCheck.required && value === undefined) {\n return valid\n }\n if (isArray(typeToCheck.type)) {\n valid = typeToCheck.type.some(\n (type: any) => validateType(type, value, true) === true,\n )\n expectedType = typeToCheck.type\n .map((type: any) => getType(type))\n .join(' or ')\n } else {\n expectedType = getType(typeToCheck)\n\n if (expectedType === 'Array') {\n valid = isArray(value)\n } else if (expectedType === 'Object') {\n valid = isPlainObject(value)\n } else if (\n expectedType === 'String' ||\n expectedType === 'Number' ||\n expectedType === 'Boolean' ||\n expectedType === 'Function'\n ) {\n valid = getNativeType(value) === expectedType\n } else {\n valid = value instanceof typeToCheck.type\n }\n }\n }\n\n if (!valid) {\n const msg = `${namePrefix}value \"${value}\" should be of type \"${expectedType}\"`\n if (silent === false) {\n warn(msg)\n return false\n }\n return msg\n }\n\n if (has(typeToCheck, 'validator') && isFunction(typeToCheck.validator)) {\n const oldWarn = warn\n const warnLog = []\n warn = (msg) => {\n warnLog.push(msg)\n }\n\n valid = typeToCheck.validator(value)\n warn = oldWarn\n\n if (!valid) {\n const msg = (warnLog.length > 1 ? '* ' : '') + warnLog.join('\\n* ')\n warnLog.length = 0\n if (silent === false) {\n warn(msg)\n return valid\n }\n return msg\n }\n }\n return valid\n}\n\n/**\n * Adds `isRequired` and `def` modifiers to an object\n *\n * @param {string} name - Type internal name\n * @param {object} obj - Object to enhance\n */\nexport function toType(name: string, obj: PropOptions) {\n const type: VueTypeDef = Object.defineProperties(obj, {\n _vueTypes_name: {\n value: name,\n writable: true,\n },\n isRequired: {\n get() {\n this.required = true\n return this\n },\n },\n def: {\n value(def?: any) {\n if (def === undefined && !this.default) {\n return this\n }\n if (!isFunction(def) && validateType(this, def, true) !== true) {\n warn(`${this._vueTypes_name} - invalid default value: \"${def}\"`)\n return this\n }\n if (isArray(def)) {\n this.default = () => [...def]\n } else if (isPlainObject(def)) {\n this.default = () => Object.assign({}, def)\n } else {\n this.default = def\n }\n return this\n },\n },\n })\n\n const { validator } = type\n if (isFunction(validator)) {\n type.validator = bindTo(validator, type)\n }\n\n return type\n}\n\n/**\n * Like `toType` but also adds the `validate()` method to the type object\n *\n * @param {string} name - Type internal name\n * @param {object} obj - Object to enhance\n */\nexport function toValidableType(name: string, obj: PropOptions) {\n const type = toType(name, obj)\n return Object.defineProperty(type, 'validate', {\n value(fn: (value: T) => boolean) {\n if (isFunction(this.validator)) {\n warn(\n `${\n this._vueTypes_name\n } - calling .validate() will overwrite the current custom validator function. Validator info:\\n${JSON.stringify(\n this,\n )}`,\n )\n }\n this.validator = bindTo(fn, this)\n return this\n },\n }) as VueTypeValidableDef\n}\n\n/**\n * Clones an object preserving all of it's own keys.\n *\n * @param obj - Object to clone\n */\n// eslint-disable-next-line @typescript-eslint/ban-types\nexport function clone(obj: T): T {\n const descriptors = {} as { [P in keyof T]: any }\n Object.getOwnPropertyNames(obj).forEach((key) => {\n descriptors[key as keyof T] = Object.getOwnPropertyDescriptor(obj, key)\n })\n return Object.defineProperties({}, descriptors)\n}\n\n/**\n * Return a new VueTypes type using another type as base.\n *\n * Properties in the `props` object will overwrite those defined in the source one\n * expect for the `validator` function. In that case both functions will be executed in series.\n *\n * @param name - Name of the new type\n * @param source - Source type\n * @param props - Custom type properties\n */\nexport function fromType>(name: string, source: T): T\nexport function fromType<\n T extends VueTypeDef,\n V extends PropOptions>\n>(name: string, source: T, props: V): Omit & V\nexport function fromType<\n T extends VueTypeDef,\n V extends PropOptions>\n>(name: string, source: T, props?: V) {\n // 1. create an exact copy of the source type\n const copy = clone(source)\n\n // 2. give it a new name\n copy._vueTypes_name = name\n\n if (!isPlainObject(props)) {\n return copy\n }\n const { validator, ...rest } = props\n\n // 3. compose the validator function\n // with the one on the source (if present)\n // and ensure it is bound to the copy\n if (isFunction(validator)) {\n let { validator: prevValidator } = copy\n\n if (prevValidator) {\n prevValidator = unwrap(prevValidator)\n }\n\n copy.validator = bindTo(\n prevValidator\n ? function (this: T, value: any) {\n return (\n prevValidator.call(this, value) && validator.call(this, value)\n )\n }\n : validator,\n copy,\n )\n }\n // 4. overwrite the rest, if present\n return Object.assign(copy, rest as V)\n}\n\nexport function indent(string: string) {\n return string.replace(/^(?!\\s*$)/gm, ' ')\n}\n","import { toType, toValidableType, isInteger } from '../utils'\nimport { PropType } from '../types'\n\nexport const any = () => toValidableType('any', {})\n\nexport const func = any>() =>\n toValidableType('function', {\n type: Function as PropType,\n })\n\nexport const bool = () =>\n toValidableType('boolean', {\n type: Boolean,\n })\n\nexport const string = () =>\n toValidableType('string', {\n type: String,\n })\n\nexport const number = () =>\n toValidableType('number', {\n type: Number,\n })\n\nexport const array = () =>\n toValidableType('array', {\n type: Array,\n })\n\nexport const object = () =>\n toValidableType('object', {\n type: Object,\n })\n\nexport const integer = () =>\n toType('integer', {\n type: Number,\n validator(value) {\n return isInteger(value)\n },\n })\n\nexport const symbol = () =>\n toType('symbol', {\n validator(value) {\n return typeof value === 'symbol'\n },\n })\n","import { toType, warn } from '../utils'\nimport { ValidatorFunction, VueTypeDef } from '../types'\n\nexport default function custom(\n validatorFn: ValidatorFunction,\n warnMsg = 'custom validation failed',\n) {\n if (typeof validatorFn !== 'function') {\n throw new TypeError(\n '[VueTypes error]: You must provide a function as argument',\n )\n }\n\n return toType(validatorFn.name || '<>', {\n validator(this: VueTypeDef, value: T) {\n const valid = validatorFn(value)\n if (!valid) warn(`${this._vueTypes_name} - ${warnMsg}`)\n return valid\n },\n })\n}\n","import { Prop } from '../types'\nimport { toType, warn, isArray } from '../utils'\n\nexport default function oneOf(arr: T) {\n if (!isArray(arr)) {\n throw new TypeError(\n '[VueTypes error]: You must provide an array as argument.',\n )\n }\n const msg = `oneOf - value should be one of \"${arr.join('\", \"')}\".`\n const allowedTypes = arr.reduce((ret, v) => {\n if (v !== null && v !== undefined) {\n const constr = (v as any).constructor\n ret.indexOf(constr) === -1 && ret.push(constr)\n }\n return ret\n }, [] as Prop[])\n\n return toType('oneOf', {\n type: allowedTypes.length > 0 ? allowedTypes : undefined,\n validator(value) {\n const valid = arr.indexOf(value) !== -1\n if (!valid) warn(msg)\n return valid\n },\n })\n}\n","import { Prop, VueProp, InferType, PropType } from '../types'\nimport {\n isArray,\n isComplexType,\n isVueTypeDef,\n isFunction,\n toType,\n validateType,\n warn,\n indent,\n} from '../utils'\n\nexport default function oneOfType<\n U extends VueProp | Prop,\n V = InferType\n>(arr: U[]) {\n if (!isArray(arr)) {\n throw new TypeError(\n '[VueTypes error]: You must provide an array as argument',\n )\n }\n\n let hasCustomValidators = false\n\n let nativeChecks: Prop[] = []\n\n for (let i = 0; i < arr.length; i += 1) {\n const type = arr[i]\n if (isComplexType(type)) {\n if (isVueTypeDef(type) && type._vueTypes_name === 'oneOf') {\n nativeChecks = nativeChecks.concat(type.type as PropType)\n continue\n }\n if (isFunction(type.validator)) {\n hasCustomValidators = true\n }\n if (type.type !== true && type.type) {\n nativeChecks = nativeChecks.concat(type.type)\n continue\n }\n }\n nativeChecks.push(type as Prop)\n }\n\n // filter duplicates\n nativeChecks = nativeChecks.filter((t, i) => nativeChecks.indexOf(t) === i)\n\n if (!hasCustomValidators) {\n // we got just native objects (ie: Array, Object)\n // delegate to Vue native prop check\n return toType('oneOfType', {\n type: nativeChecks,\n })\n }\n\n return toType('oneOfType', {\n type: nativeChecks,\n validator(value) {\n const err: string[] = []\n const valid = arr.some((type) => {\n const t =\n isVueTypeDef(type) && type._vueTypes_name === 'oneOf'\n ? type.type || null\n : type\n const res = validateType(t, value, true)\n if (typeof res === 'string') {\n err.push(res)\n }\n return res === true\n })\n if (!valid) {\n warn(\n `oneOfType - provided value does not match any of the ${\n err.length\n } passed-in validators:\\n${indent(err.join('\\n'))}`,\n )\n }\n\n return valid\n },\n })\n}\n","import { Prop, VueProp, InferType } from '../types'\nimport { toType, validateType, warn, indent } from '../utils'\n\nexport default function arrayOf | Prop>(type: T) {\n return toType[]>('arrayOf', {\n type: Array,\n validator(values: any[]) {\n let vResult: string | boolean\n const valid = values.every((value) => {\n vResult = validateType(type, value, true)\n return vResult === true\n })\n if (!valid) {\n warn(`arrayOf - value validation error:\\n${indent(vResult as string)}`)\n }\n return valid\n },\n })\n}\n","import { toType } from '../utils'\nimport { Constructor } from '../types'\n\nexport default function instanceOf(\n instanceConstructor: C,\n) {\n return toType>('instanceOf', {\n type: instanceConstructor,\n })\n}\n","import { Prop, VueProp, InferType } from '../types'\nimport { toType, validateType, warn, indent } from '../utils'\n\nexport default function objectOf | Prop>(type: T) {\n return toType<{ [key: string]: InferType }>('objectOf', {\n type: Object,\n validator(obj) {\n let vResult: string | boolean\n const valid = Object.keys(obj).every((key) => {\n vResult = validateType(type, obj[key], true)\n return vResult === true\n })\n\n if (!valid) {\n warn(`objectOf - value validation error:\\n${indent(vResult as string)}`)\n }\n return valid\n },\n })\n}\n","import { Prop, VueProp, VueTypeShape, VueTypeLooseShape } from '../types'\nimport { toType, validateType, warn, isPlainObject, indent } from '../utils'\n\n// eslint-disable-next-line @typescript-eslint/ban-types\nexport default function shape(\n obj: { [K in keyof T]: Prop | VueProp },\n): VueTypeShape {\n const keys = Object.keys(obj)\n const requiredKeys = keys.filter((key) => !!(obj as any)[key]?.required)\n\n const type = toType('shape', {\n type: Object,\n validator(this: VueTypeShape | VueTypeLooseShape, value) {\n if (!isPlainObject(value)) {\n return false\n }\n const valueKeys = Object.keys(value)\n\n // check for required keys (if any)\n if (\n requiredKeys.length > 0 &&\n requiredKeys.some((req) => valueKeys.indexOf(req) === -1)\n ) {\n const missing = requiredKeys.filter(\n (req) => valueKeys.indexOf(req) === -1,\n )\n if (missing.length === 1) {\n warn(`shape - required property \"${missing[0]}\" is not defined.`)\n } else {\n warn(\n `shape - required properties \"${missing.join(\n '\", \"',\n )}\" are not defined.`,\n )\n }\n\n return false\n }\n\n return valueKeys.every((key) => {\n if (keys.indexOf(key) === -1) {\n if ((this as VueTypeLooseShape)._vueTypes_isLoose === true)\n return true\n warn(\n `shape - shape definition does not include a \"${key}\" property. Allowed keys: \"${keys.join(\n '\", \"',\n )}\".`,\n )\n return false\n }\n const type = (obj as any)[key]\n const valid = validateType(type, value[key], true)\n if (typeof valid === 'string') {\n warn(`shape - \"${key}\" property validation error:\\n ${indent(valid)}`)\n }\n return valid === true\n })\n },\n }) as VueTypeShape\n\n Object.defineProperty(type, '_vueTypes_isLoose', {\n writable: true,\n value: false,\n })\n\n Object.defineProperty(type, 'loose', {\n get() {\n this._vueTypes_isLoose = true\n return this\n },\n })\n\n return type\n}\n","import {\n toType,\n toValidableType,\n validateType,\n isArray,\n isVueTypeDef,\n has,\n fromType,\n} from './utils'\n\nimport {\n VueTypesDefaults,\n ExtendProps,\n VueTypeDef,\n VueTypeValidableDef,\n VueTypeShape,\n VueTypeLooseShape,\n} from './types'\nimport { typeDefaults } from './sensibles'\nimport { PropOptions } from './types'\n\nimport {\n any,\n func,\n bool,\n string,\n number,\n array,\n integer,\n symbol,\n object,\n} from './validators/native'\nimport custom from './validators/custom'\nimport oneOf from './validators/oneof'\nimport oneOfType from './validators/oneoftype'\nimport arrayOf from './validators/arrayof'\nimport instanceOf from './validators/instanceof'\nimport objectOf from './validators/objectof'\nimport shape from './validators/shape'\n\nclass BaseVueTypes {\n static defaults: Partial = {}\n\n static sensibleDefaults: Partial | boolean\n\n static get any() {\n return any()\n }\n static get func() {\n return func().def(this.defaults.func)\n }\n static get bool() {\n return bool().def(this.defaults.bool)\n }\n static get string() {\n return string().def(this.defaults.string)\n }\n static get number() {\n return number().def(this.defaults.number)\n }\n static get array() {\n return array().def(this.defaults.array)\n }\n static get object() {\n return object().def(this.defaults.object)\n }\n static get integer() {\n return integer().def(this.defaults.integer)\n }\n static get symbol() {\n return symbol()\n }\n\n static readonly custom = custom\n static readonly oneOf = oneOf\n static readonly instanceOf = instanceOf\n static readonly oneOfType = oneOfType\n static readonly arrayOf = arrayOf\n static readonly objectOf = objectOf\n static readonly shape = shape\n\n static extend(props: ExtendProps | ExtendProps[]): T {\n if (isArray(props)) {\n props.forEach((p) => this.extend(p))\n return this as any\n }\n\n const { name, validate = false, getter = false, ...opts } = props\n\n if (has(this, name as any)) {\n throw new TypeError(`[VueTypes error]: Type \"${name}\" already defined`)\n }\n\n const { type } = opts\n if (isVueTypeDef(type)) {\n // we are using as base type a vue-type object\n\n // detach the original type\n // we are going to inherit the parent data.\n delete opts.type\n\n if (getter) {\n return Object.defineProperty(this, name, {\n get: () => fromType(name, type, opts as Omit),\n })\n }\n return Object.defineProperty(this, name, {\n value(...args: unknown[]) {\n const t = fromType(name, type, opts as Omit)\n if (t.validator) {\n t.validator = t.validator.bind(t, ...args)\n }\n return t\n },\n })\n }\n\n let descriptor: PropertyDescriptor\n if (getter) {\n descriptor = {\n get() {\n const typeOptions = Object.assign({}, opts as PropOptions)\n if (validate) {\n return toValidableType(name, typeOptions)\n }\n return toType(name, typeOptions)\n },\n enumerable: true,\n }\n } else {\n descriptor = {\n value(...args: T[]) {\n const typeOptions = Object.assign({}, opts as PropOptions)\n let ret: VueTypeDef\n if (validate) {\n ret = toValidableType(name, typeOptions)\n } else {\n ret = toType(name, typeOptions)\n }\n\n if (typeOptions.validator) {\n ret.validator = typeOptions.validator.bind(ret, ...args)\n }\n return ret\n },\n enumerable: true,\n }\n }\n\n return Object.defineProperty(this, name, descriptor)\n }\n\n static utils = {\n validate(value: T, type: U) {\n return validateType(type, value, true) === true\n },\n toType(\n name: string,\n obj: PropOptions,\n validable = false,\n ): VueTypeDef | VueTypeValidableDef {\n return validable ? toValidableType(name, obj) : toType(name, obj)\n },\n }\n}\n\nfunction createTypes(defs: Partial = typeDefaults()) {\n return class extends BaseVueTypes {\n static defaults: Partial = { ...defs }\n\n static get sensibleDefaults() {\n return { ...this.defaults }\n }\n\n static set sensibleDefaults(v: boolean | Partial) {\n if (v === false) {\n this.defaults = {}\n return\n }\n if (v === true) {\n this.defaults = { ...defs }\n return\n }\n this.defaults = { ...v }\n }\n }\n}\n\nexport default class VueTypes extends createTypes() {}\n\nexport {\n any,\n func,\n bool,\n string,\n number,\n array,\n integer,\n symbol,\n object,\n custom,\n oneOf,\n oneOfType,\n arrayOf,\n instanceOf,\n objectOf,\n shape,\n createTypes,\n toType,\n toValidableType,\n validateType,\n fromType,\n}\n\nexport type VueTypesInterface = ReturnType\nexport { VueTypeDef, VueTypeValidableDef, VueTypeShape, VueTypeLooseShape }\n","import { VueTypesDefaults } from './types'\n\nexport const typeDefaults = (): VueTypesDefaults => ({\n func: () => undefined,\n bool: true,\n string: '',\n number: 0,\n array: () => [],\n object: () => ({}),\n integer: 0,\n})\n","import { createTypes } from 'vue-types';\nconst PropTypes = createTypes({\n func: undefined,\n bool: undefined,\n string: undefined,\n number: undefined,\n array: undefined,\n object: undefined,\n integer: undefined\n});\nPropTypes.extend([{\n name: 'looseBool',\n getter: true,\n type: Boolean,\n default: undefined\n}, {\n name: 'style',\n getter: true,\n type: [String, Object],\n default: undefined\n}, {\n name: 'VueNode',\n getter: true,\n type: null\n}]);\nexport function withUndefined(type) {\n type.default = undefined;\n return type;\n}\nexport default PropTypes;","import PropTypes from '../_util/vue-types';\nfunction returnEmptyString() {\n return '';\n}\nfunction returnDocument(element) {\n if (element) {\n return element.ownerDocument;\n }\n return window.document;\n}\nexport function noop() {}\nexport const triggerProps = () => ({\n action: PropTypes.oneOfType([PropTypes.string, PropTypes.arrayOf(PropTypes.string)]).def([]),\n showAction: PropTypes.any.def([]),\n hideAction: PropTypes.any.def([]),\n getPopupClassNameFromAlign: PropTypes.any.def(returnEmptyString),\n onPopupVisibleChange: Function,\n afterPopupVisibleChange: PropTypes.func.def(noop),\n popup: PropTypes.any,\n popupStyle: {\n type: Object,\n default: undefined\n },\n prefixCls: PropTypes.string.def('rc-trigger-popup'),\n popupClassName: PropTypes.string.def(''),\n popupPlacement: String,\n builtinPlacements: PropTypes.object,\n popupTransitionName: String,\n popupAnimation: PropTypes.any,\n mouseEnterDelay: PropTypes.number.def(0),\n mouseLeaveDelay: PropTypes.number.def(0.1),\n zIndex: Number,\n focusDelay: PropTypes.number.def(0),\n blurDelay: PropTypes.number.def(0.15),\n getPopupContainer: Function,\n getDocument: PropTypes.func.def(returnDocument),\n forceRender: {\n type: Boolean,\n default: undefined\n },\n destroyPopupOnHide: {\n type: Boolean,\n default: false\n },\n mask: {\n type: Boolean,\n default: false\n },\n maskClosable: {\n type: Boolean,\n default: true\n },\n // onPopupAlign: PropTypes.func.def(noop),\n popupAlign: PropTypes.object.def(() => ({})),\n popupVisible: {\n type: Boolean,\n default: undefined\n },\n defaultPopupVisible: {\n type: Boolean,\n default: false\n },\n maskTransitionName: String,\n maskAnimation: String,\n stretch: String,\n alignPoint: {\n type: Boolean,\n default: undefined\n },\n autoDestroy: {\n type: Boolean,\n default: false\n },\n mobile: Object,\n getTriggerDOMNode: Function\n});","export default function contains(root, n) {\n if (!root) {\n return false;\n }\n // Use native if support\n if (root.contains) {\n return root.contains(n);\n }\n return false;\n}","let raf = callback => setTimeout(callback, 16);\nlet caf = num => clearTimeout(num);\nif (typeof window !== 'undefined' && 'requestAnimationFrame' in window) {\n raf = callback => window.requestAnimationFrame(callback);\n caf = handle => window.cancelAnimationFrame(handle);\n}\nlet rafUUID = 0;\nconst rafIds = new Map();\nfunction cleanup(id) {\n rafIds.delete(id);\n}\nexport default function wrapperRaf(callback) {\n let times = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1;\n rafUUID += 1;\n const id = rafUUID;\n function callRef(leftTimes) {\n if (leftTimes === 0) {\n // Clean up\n cleanup(id);\n // Trigger\n callback();\n } else {\n // Next raf\n const realId = raf(() => {\n callRef(leftTimes - 1);\n });\n // Bind real raf id\n rafIds.set(id, realId);\n }\n }\n callRef(times);\n return id;\n}\nwrapperRaf.cancel = id => {\n const realId = rafIds.get(id);\n cleanup(realId);\n return caf(realId);\n};","export const isFunction = val => typeof val === 'function';\nexport const controlDefaultValue = Symbol('controlDefaultValue');\nexport const isArray = Array.isArray;\nexport const isString = val => typeof val === 'string';\nexport const isSymbol = val => typeof val === 'symbol';\nexport const isObject = val => val !== null && typeof val === 'object';\nconst onRE = /^on[^a-z]/;\nconst isOn = key => onRE.test(key);\nconst cacheStringFunction = fn => {\n const cache = Object.create(null);\n return str => {\n const hit = cache[str];\n return hit || (cache[str] = fn(str));\n };\n};\nconst camelizeRE = /-(\\w)/g;\nconst camelize = cacheStringFunction(str => {\n return str.replace(camelizeRE, (_, c) => c ? c.toUpperCase() : '');\n});\nconst hyphenateRE = /\\B([A-Z])/g;\nconst hyphenate = cacheStringFunction(str => {\n return str.replace(hyphenateRE, '-$1').toLowerCase();\n});\nconst capitalize = cacheStringFunction(str => {\n return str.charAt(0).toUpperCase() + str.slice(1);\n});\nconst hasOwnProperty = Object.prototype.hasOwnProperty;\nconst hasOwn = (val, key) => hasOwnProperty.call(val, key);\n// change from vue sourcecode\nfunction resolvePropValue(options, props, key, value) {\n const opt = options[key];\n if (opt != null) {\n const hasDefault = hasOwn(opt, 'default');\n // default values\n if (hasDefault && value === undefined) {\n const defaultValue = opt.default;\n value = opt.type !== Function && isFunction(defaultValue) ? defaultValue() : defaultValue;\n }\n // boolean casting\n if (opt.type === Boolean) {\n if (!hasOwn(props, key) && !hasDefault) {\n value = false;\n } else if (value === '') {\n value = true;\n }\n }\n }\n return value;\n}\nexport function getDataAndAriaProps(props) {\n return Object.keys(props).reduce((memo, key) => {\n if (key.startsWith('data-') || key.startsWith('aria-')) {\n memo[key] = props[key];\n }\n return memo;\n }, {});\n}\nexport function toPx(val) {\n if (typeof val === 'number') return `${val}px`;\n return val;\n}\nexport function renderHelper(v) {\n let props = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n let defaultV = arguments.length > 2 ? arguments[2] : undefined;\n if (typeof v === 'function') {\n return v(props);\n }\n return v !== null && v !== void 0 ? v : defaultV;\n}\nexport function wrapPromiseFn(openFn) {\n let closeFn;\n const closePromise = new Promise(resolve => {\n closeFn = openFn(() => {\n resolve(true);\n });\n });\n const result = () => {\n closeFn === null || closeFn === void 0 ? void 0 : closeFn();\n };\n result.then = (filled, rejected) => closePromise.then(filled, rejected);\n result.promise = closePromise;\n return result;\n}\nexport { isOn, cacheStringFunction, camelize, hyphenate, capitalize, resolvePropValue };","const isValid = value => {\n return value !== undefined && value !== null && value !== '';\n};\nexport default isValid;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport classNames from '../classNames';\nimport { isVNode, Fragment, Comment, Text } from 'vue';\nimport { camelize, hyphenate, isOn, resolvePropValue } from '../util';\nimport isValid from '../isValid';\nimport initDefaultProps from './initDefaultProps';\n// function getType(fn) {\n// const match = fn && fn.toString().match(/^\\s*function (\\w+)/);\n// return match ? match[1] : '';\n// }\nconst splitAttrs = attrs => {\n const allAttrs = Object.keys(attrs);\n const eventAttrs = {};\n const onEvents = {};\n const extraAttrs = {};\n for (let i = 0, l = allAttrs.length; i < l; i++) {\n const key = allAttrs[i];\n if (isOn(key)) {\n eventAttrs[key[2].toLowerCase() + key.slice(3)] = attrs[key];\n onEvents[key] = attrs[key];\n } else {\n extraAttrs[key] = attrs[key];\n }\n }\n return {\n onEvents,\n events: eventAttrs,\n extraAttrs\n };\n};\nconst parseStyleText = function () {\n let cssText = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';\n let camel = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;\n const res = {};\n const listDelimiter = /;(?![^(]*\\))/g;\n const propertyDelimiter = /:(.+)/;\n if (typeof cssText === 'object') return cssText;\n cssText.split(listDelimiter).forEach(function (item) {\n if (item) {\n const tmp = item.split(propertyDelimiter);\n if (tmp.length > 1) {\n const k = camel ? camelize(tmp[0].trim()) : tmp[0].trim();\n res[k] = tmp[1].trim();\n }\n }\n });\n return res;\n};\nconst hasProp = (instance, prop) => {\n return instance[prop] !== undefined;\n};\nexport const skipFlattenKey = Symbol('skipFlatten');\nconst flattenChildren = function () {\n let children = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];\n let filterEmpty = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;\n const temp = Array.isArray(children) ? children : [children];\n const res = [];\n temp.forEach(child => {\n if (Array.isArray(child)) {\n res.push(...flattenChildren(child, filterEmpty));\n } else if (child && child.type === Fragment) {\n if (child.key === skipFlattenKey) {\n res.push(child);\n } else {\n res.push(...flattenChildren(child.children, filterEmpty));\n }\n } else if (child && isVNode(child)) {\n if (filterEmpty && !isEmptyElement(child)) {\n res.push(child);\n } else if (!filterEmpty) {\n res.push(child);\n }\n } else if (isValid(child)) {\n res.push(child);\n }\n });\n return res;\n};\nconst getSlot = function (self) {\n let name = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'default';\n let options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n if (isVNode(self)) {\n if (self.type === Fragment) {\n return name === 'default' ? flattenChildren(self.children) : [];\n } else if (self.children && self.children[name]) {\n return flattenChildren(self.children[name](options));\n } else {\n return [];\n }\n } else {\n const res = self.$slots[name] && self.$slots[name](options);\n return flattenChildren(res);\n }\n};\nconst findDOMNode = instance => {\n var _a;\n let node = ((_a = instance === null || instance === void 0 ? void 0 : instance.vnode) === null || _a === void 0 ? void 0 : _a.el) || instance && (instance.$el || instance);\n while (node && !node.tagName) {\n node = node.nextSibling;\n }\n return node;\n};\nconst getOptionProps = instance => {\n const res = {};\n if (instance.$ && instance.$.vnode) {\n const props = instance.$.vnode.props || {};\n Object.keys(instance.$props).forEach(k => {\n const v = instance.$props[k];\n const hyphenateKey = hyphenate(k);\n if (v !== undefined || hyphenateKey in props) {\n res[k] = v; // 直接取 $props[k]\n }\n });\n } else if (isVNode(instance) && typeof instance.type === 'object') {\n const originProps = instance.props || {};\n const props = {};\n Object.keys(originProps).forEach(key => {\n props[camelize(key)] = originProps[key];\n });\n const options = instance.type.props || {};\n Object.keys(options).forEach(k => {\n const v = resolvePropValue(options, props, k, props[k]);\n if (v !== undefined || k in props) {\n res[k] = v;\n }\n });\n }\n return res;\n};\nconst getComponent = function (instance) {\n let prop = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'default';\n let options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : instance;\n let execute = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : true;\n let com = undefined;\n if (instance.$) {\n const temp = instance[prop];\n if (temp !== undefined) {\n return typeof temp === 'function' && execute ? temp(options) : temp;\n } else {\n com = instance.$slots[prop];\n com = execute && com ? com(options) : com;\n }\n } else if (isVNode(instance)) {\n const temp = instance.props && instance.props[prop];\n if (temp !== undefined && instance.props !== null) {\n return typeof temp === 'function' && execute ? temp(options) : temp;\n } else if (instance.type === Fragment) {\n com = instance.children;\n } else if (instance.children && instance.children[prop]) {\n com = instance.children[prop];\n com = execute && com ? com(options) : com;\n }\n }\n if (Array.isArray(com)) {\n com = flattenChildren(com);\n com = com.length === 1 ? com[0] : com;\n com = com.length === 0 ? undefined : com;\n }\n return com;\n};\nconst getKey = ele => {\n const key = ele.key;\n return key;\n};\nexport function getEvents() {\n let ele = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n let on = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;\n let props = {};\n if (ele.$) {\n props = _extends(_extends({}, props), ele.$attrs);\n } else {\n props = _extends(_extends({}, props), ele.props);\n }\n return splitAttrs(props)[on ? 'onEvents' : 'events'];\n}\nexport function getClass(ele) {\n const props = (isVNode(ele) ? ele.props : ele.$attrs) || {};\n const tempCls = props.class || {};\n let cls = {};\n if (typeof tempCls === 'string') {\n tempCls.split(' ').forEach(c => {\n cls[c.trim()] = true;\n });\n } else if (Array.isArray(tempCls)) {\n classNames(tempCls).split(' ').forEach(c => {\n cls[c.trim()] = true;\n });\n } else {\n cls = _extends(_extends({}, cls), tempCls);\n }\n return cls;\n}\nexport function getStyle(ele, camel) {\n const props = (isVNode(ele) ? ele.props : ele.$attrs) || {};\n let style = props.style || {};\n if (typeof style === 'string') {\n style = parseStyleText(style, camel);\n } else if (camel && style) {\n // 驼峰化\n const res = {};\n Object.keys(style).forEach(k => res[camelize(k)] = style[k]);\n return res;\n }\n return style;\n}\nexport function getComponentName(opts) {\n return opts && (opts.Ctor.options.name || opts.tag);\n}\nexport function isFragment(c) {\n return c.length === 1 && c[0].type === Fragment;\n}\nexport function isEmptyContent(c) {\n return c === undefined || c === null || c === '' || Array.isArray(c) && c.length === 0;\n}\nexport function isEmptyElement(c) {\n return c && (c.type === Comment || c.type === Fragment && c.children.length === 0 || c.type === Text && c.children.trim() === '');\n}\nexport function isEmptySlot(c) {\n return !c || c().every(isEmptyElement);\n}\nexport function isStringElement(c) {\n return c && c.type === Text;\n}\nexport function filterEmpty() {\n let children = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];\n const res = [];\n children.forEach(child => {\n if (Array.isArray(child)) {\n res.push(...child);\n } else if ((child === null || child === void 0 ? void 0 : child.type) === Fragment) {\n res.push(...filterEmpty(child.children));\n } else {\n res.push(child);\n }\n });\n return res.filter(c => !isEmptyElement(c));\n}\nexport function filterEmptyWithUndefined(children) {\n if (children) {\n const coms = filterEmpty(children);\n return coms.length ? coms : undefined;\n } else {\n return children;\n }\n}\nfunction isValidElement(element) {\n if (Array.isArray(element) && element.length === 1) {\n element = element[0];\n }\n return element && element.__v_isVNode && typeof element.type !== 'symbol'; // remove text node\n}\nfunction getPropsSlot(slots, props) {\n let prop = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'default';\n var _a, _b;\n return (_a = props[prop]) !== null && _a !== void 0 ? _a : (_b = slots[prop]) === null || _b === void 0 ? void 0 : _b.call(slots);\n}\nexport const getTextFromElement = ele => {\n if (isValidElement(ele) && isStringElement(ele[0])) {\n return ele[0].children;\n }\n return ele;\n};\nexport { splitAttrs, hasProp, getOptionProps, getComponent, getKey, parseStyleText, initDefaultProps, isValidElement, camelize, getSlot, findDOMNode, flattenChildren, getPropsSlot };\nexport default hasProp;","// Test via a getter in the options object to see if the passive property is accessed\nlet supportsPassive = false;\ntry {\n const opts = Object.defineProperty({}, 'passive', {\n get() {\n supportsPassive = true;\n }\n });\n window.addEventListener('testPassive', null, opts);\n window.removeEventListener('testPassive', null, opts);\n} catch (e) {}\nexport default supportsPassive;","import supportsPassive from '../../_util/supportsPassive';\nexport default function addEventListenerWrap(target, eventType, cb, option) {\n if (target && target.addEventListener) {\n let opt = option;\n if (opt === undefined && supportsPassive && (eventType === 'touchstart' || eventType === 'touchmove' || eventType === 'wheel')) {\n opt = {\n passive: false\n };\n }\n target.addEventListener(eventType, cb, opt);\n }\n return {\n remove: () => {\n if (target && target.removeEventListener) {\n target.removeEventListener(eventType, cb);\n }\n }\n };\n}","import _extends from \"@babel/runtime/helpers/esm/extends\";\nexport const innerProps = {\n visible: Boolean,\n prefixCls: String,\n zIndex: Number,\n destroyPopupOnHide: Boolean,\n forceRender: Boolean,\n // Legacy Motion\n animation: [String, Object],\n transitionName: String,\n // Measure\n stretch: {\n type: String\n },\n // Align\n align: {\n type: Object\n },\n point: {\n type: Object\n },\n getRootDomNode: {\n type: Function\n },\n getClassNameFromAlign: {\n type: Function\n },\n onAlign: {\n type: Function\n },\n onMouseenter: {\n type: Function\n },\n onMouseleave: {\n type: Function\n },\n onMousedown: {\n type: Function\n },\n onTouchstart: {\n type: Function\n }\n};\nexport const mobileProps = _extends(_extends({}, innerProps), {\n mobile: {\n type: Object\n }\n});\nexport const popupProps = _extends(_extends({}, innerProps), {\n mask: Boolean,\n mobile: {\n type: Object\n },\n maskAnimation: String,\n maskTransitionName: String\n});","export function getMotion(_ref) {\n let {\n prefixCls,\n animation,\n transitionName\n } = _ref;\n if (animation) {\n return {\n name: `${prefixCls}-${animation}`\n };\n }\n if (transitionName) {\n return {\n name: transitionName\n };\n }\n return {};\n}","import _objectSpread from \"@babel/runtime/helpers/esm/objectSpread2\";\nimport { withDirectives as _withDirectives, createVNode as _createVNode, resolveDirective as _resolveDirective } from \"vue\";\nimport { Transition } from 'vue';\nimport { getMotion } from '../utils/motionUtil';\nexport default function Mask(props) {\n const {\n prefixCls,\n visible,\n zIndex,\n mask,\n maskAnimation,\n maskTransitionName\n } = props;\n if (!mask) {\n return null;\n }\n let motion = {};\n if (maskTransitionName || maskAnimation) {\n motion = getMotion({\n prefixCls,\n transitionName: maskTransitionName,\n animation: maskAnimation\n });\n }\n return _createVNode(Transition, _objectSpread({\n \"appear\": true\n }, motion), {\n default: () => [_withDirectives(_createVNode(\"div\", {\n \"style\": {\n zIndex\n },\n \"class\": `${prefixCls}-mask`\n }, null), [[_resolveDirective(\"if\"), visible]])]\n });\n}\nMask.displayName = 'Mask';","import { isArray, isString, isObject } from './util';\nfunction classNames() {\n const classes = [];\n for (let i = 0; i < arguments.length; i++) {\n const value = i < 0 || arguments.length <= i ? undefined : arguments[i];\n if (!value) continue;\n if (isString(value)) {\n classes.push(value);\n } else if (isArray(value)) {\n for (let i = 0; i < value.length; i++) {\n const inner = classNames(value[i]);\n if (inner) {\n classes.push(inner);\n }\n }\n } else if (isObject(value)) {\n for (const name in value) {\n if (value[name]) {\n classes.push(name);\n }\n }\n }\n }\n return classes.join(' ');\n}\nexport default classNames;","import _objectSpread from \"@babel/runtime/helpers/esm/objectSpread2\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport { createVNode as _createVNode } from \"vue\";\nimport { defineComponent, ref, Transition } from 'vue';\nimport { flattenChildren } from '../../_util/props-util';\nimport classNames from '../../_util/classNames';\nimport { mobileProps } from './interface';\nexport default defineComponent({\n compatConfig: {\n MODE: 3\n },\n name: 'MobilePopupInner',\n inheritAttrs: false,\n props: mobileProps,\n emits: ['mouseenter', 'mouseleave', 'mousedown', 'touchstart', 'align'],\n setup(props, _ref) {\n let {\n expose,\n slots\n } = _ref;\n const elementRef = ref();\n expose({\n forceAlign: () => {},\n getElement: () => elementRef.value\n });\n return () => {\n var _a;\n const {\n zIndex,\n visible,\n prefixCls,\n mobile: {\n popupClassName,\n popupStyle,\n popupMotion = {},\n popupRender\n } = {}\n } = props;\n // ======================== Render ========================\n const mergedStyle = _extends({\n zIndex\n }, popupStyle);\n let childNode = flattenChildren((_a = slots.default) === null || _a === void 0 ? void 0 : _a.call(slots));\n // Wrapper when multiple children\n if (childNode.length > 1) {\n const _childNode = function () {\n return childNode;\n }();\n childNode = _createVNode(\"div\", {\n \"class\": `${prefixCls}-content`\n }, [childNode]);\n }\n // Mobile support additional render\n if (popupRender) {\n childNode = popupRender(childNode);\n }\n const mergedClassName = classNames(prefixCls, popupClassName);\n return _createVNode(Transition, _objectSpread({\n \"ref\": elementRef\n }, popupMotion), {\n default: () => [visible ? _createVNode(\"div\", {\n \"class\": mergedClassName,\n \"style\": mergedStyle\n }, [childNode]) : null]\n });\n };\n }\n});","var __awaiter = this && this.__awaiter || function (thisArg, _arguments, P, generator) {\n function adopt(value) {\n return value instanceof P ? value : new P(function (resolve) {\n resolve(value);\n });\n }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) {\n try {\n step(generator.next(value));\n } catch (e) {\n reject(e);\n }\n }\n function rejected(value) {\n try {\n step(generator[\"throw\"](value));\n } catch (e) {\n reject(e);\n }\n }\n function step(result) {\n result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);\n }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nimport { onBeforeUnmount, shallowRef, watch, onMounted } from 'vue';\nimport raf from '../../_util/raf';\nconst StatusQueue = ['measure', 'align', null, 'motion'];\nexport default ((visible, doMeasure) => {\n const status = shallowRef(null);\n const rafRef = shallowRef();\n const destroyRef = shallowRef(false);\n function setStatus(nextStatus) {\n if (!destroyRef.value) {\n status.value = nextStatus;\n }\n }\n function cancelRaf() {\n raf.cancel(rafRef.value);\n }\n function goNextStatus(callback) {\n cancelRaf();\n rafRef.value = raf(() => {\n // Only align should be manually trigger\n let newStatus = status.value;\n switch (status.value) {\n case 'align':\n newStatus = 'motion';\n break;\n case 'motion':\n newStatus = 'stable';\n break;\n default:\n }\n setStatus(newStatus);\n callback === null || callback === void 0 ? void 0 : callback();\n });\n }\n watch(visible, () => {\n setStatus('measure');\n }, {\n immediate: true,\n flush: 'post'\n });\n onMounted(() => {\n // Go next status\n watch(status, () => {\n switch (status.value) {\n case 'measure':\n doMeasure();\n break;\n default:\n }\n if (status.value) {\n rafRef.value = raf(() => __awaiter(void 0, void 0, void 0, function* () {\n const index = StatusQueue.indexOf(status.value);\n const nextStatus = StatusQueue[index + 1];\n if (nextStatus && index !== -1) {\n setStatus(nextStatus);\n }\n }));\n }\n }, {\n immediate: true,\n flush: 'post'\n });\n });\n onBeforeUnmount(() => {\n destroyRef.value = true;\n cancelRaf();\n });\n return [status, goNextStatus];\n});","let vendorPrefix;\n\nconst jsCssMap = {\n Webkit: '-webkit-',\n Moz: '-moz-',\n // IE did it wrong again ...\n ms: '-ms-',\n O: '-o-',\n};\n\nfunction getVendorPrefix() {\n if (vendorPrefix !== undefined) {\n return vendorPrefix;\n }\n vendorPrefix = '';\n const style = document.createElement('p').style;\n const testProp = 'Transform';\n for (const key in jsCssMap) {\n if (key + testProp in style) {\n vendorPrefix = key;\n }\n }\n return vendorPrefix;\n}\n\nfunction getTransitionName() {\n return getVendorPrefix()\n ? `${getVendorPrefix()}TransitionProperty`\n : 'transitionProperty';\n}\n\nexport function getTransformName() {\n return getVendorPrefix() ? `${getVendorPrefix()}Transform` : 'transform';\n}\n\nexport function setTransitionProperty(node, value) {\n const name = getTransitionName();\n if (name) {\n node.style[name] = value;\n if (name !== 'transitionProperty') {\n node.style.transitionProperty = value;\n }\n }\n}\n\nfunction setTransform(node, value) {\n const name = getTransformName();\n if (name) {\n node.style[name] = value;\n if (name !== 'transform') {\n node.style.transform = value;\n }\n }\n}\n\nexport function getTransitionProperty(node) {\n return node.style.transitionProperty || node.style[getTransitionName()];\n}\n\nexport function getTransformXY(node) {\n const style = window.getComputedStyle(node, null);\n const transform =\n style.getPropertyValue('transform') ||\n style.getPropertyValue(getTransformName());\n if (transform && transform !== 'none') {\n const matrix = transform.replace(/[^0-9\\-.,]/g, '').split(',');\n return {\n x: parseFloat(matrix[12] || matrix[4], 0),\n y: parseFloat(matrix[13] || matrix[5], 0),\n };\n }\n return {\n x: 0,\n y: 0,\n };\n}\n\nconst matrix2d = /matrix\\((.*)\\)/;\nconst matrix3d = /matrix3d\\((.*)\\)/;\n\nexport function setTransformXY(node, xy) {\n const style = window.getComputedStyle(node, null);\n const transform =\n style.getPropertyValue('transform') ||\n style.getPropertyValue(getTransformName());\n if (transform && transform !== 'none') {\n let arr;\n let match2d = transform.match(matrix2d);\n if (match2d) {\n match2d = match2d[1];\n arr = match2d.split(',').map(item => {\n return parseFloat(item, 10);\n });\n arr[4] = xy.x;\n arr[5] = xy.y;\n setTransform(node, `matrix(${arr.join(',')})`);\n } else {\n const match3d = transform.match(matrix3d)[1];\n arr = match3d.split(',').map(item => {\n return parseFloat(item, 10);\n });\n arr[12] = xy.x;\n arr[13] = xy.y;\n setTransform(node, `matrix3d(${arr.join(',')})`);\n }\n } else {\n setTransform(\n node,\n `translateX(${xy.x}px) translateY(${xy.y}px) translateZ(0)`,\n );\n }\n}\n","import { computed, shallowRef } from 'vue';\nexport default (stretch => {\n const targetSize = shallowRef({\n width: 0,\n height: 0\n });\n function measureStretch(element) {\n targetSize.value = {\n width: element.offsetWidth,\n height: element.offsetHeight\n };\n }\n // Merge stretch style\n const style = computed(() => {\n const sizeStyle = {};\n if (stretch.value) {\n const {\n width,\n height\n } = targetSize.value;\n // Stretch with target\n if (stretch.value.indexOf('height') !== -1 && height) {\n sizeStyle.height = `${height}px`;\n } else if (stretch.value.indexOf('minHeight') !== -1 && height) {\n sizeStyle.minHeight = `${height}px`;\n }\n if (stretch.value.indexOf('width') !== -1 && width) {\n sizeStyle.width = `${width}px`;\n } else if (stretch.value.indexOf('minWidth') !== -1 && width) {\n sizeStyle.minWidth = `${width}px`;\n }\n }\n return sizeStyle;\n });\n return [style, measureStretch];\n});","import {\n setTransitionProperty,\n getTransitionProperty,\n getTransformXY,\n setTransformXY,\n getTransformName,\n} from './propertyUtils';\n\nconst RE_NUM = /[\\-+]?(?:\\d*\\.|)\\d+(?:[eE][\\-+]?\\d+|)/.source;\n\nlet getComputedStyleX;\n\n// https://stackoverflow.com/a/3485654/3040605\nfunction forceRelayout(elem) {\n const originalStyle = elem.style.display;\n elem.style.display = 'none';\n elem.offsetHeight; // eslint-disable-line\n elem.style.display = originalStyle;\n}\n\nfunction css(el, name, v) {\n let value = v;\n if (typeof name === 'object') {\n for (const i in name) {\n if (name.hasOwnProperty(i)) {\n css(el, i, name[i]);\n }\n }\n return undefined;\n }\n if (typeof value !== 'undefined') {\n if (typeof value === 'number') {\n value = `${value}px`;\n }\n el.style[name] = value;\n return undefined;\n }\n return getComputedStyleX(el, name);\n}\n\nfunction getClientPosition(elem) {\n let box;\n let x;\n let y;\n const doc = elem.ownerDocument;\n const body = doc.body;\n const docElem = doc && doc.documentElement;\n // 根据 GBS 最新数据,A-Grade Browsers 都已支持 getBoundingClientRect 方法,不用再考虑传统的实现方式\n box = elem.getBoundingClientRect();\n\n // 注:jQuery 还考虑减去 docElem.clientLeft/clientTop\n // 但测试发现,这样反而会导致当 html 和 body 有边距/边框样式时,获取的值不正确\n // 此外,ie6 会忽略 html 的 margin 值,幸运地是没有谁会去设置 html 的 margin\n\n x = Math.floor(box.left);\n y = Math.floor(box.top);\n\n // In IE, most of the time, 2 extra pixels are added to the top and left\n // due to the implicit 2-pixel inset border. In IE6/7 quirks mode and\n // IE6 standards mode, this border can be overridden by setting the\n // document element's border to zero -- thus, we cannot rely on the\n // offset always being 2 pixels.\n\n // In quirks mode, the offset can be determined by querying the body's\n // clientLeft/clientTop, but in standards mode, it is found by querying\n // the document element's clientLeft/clientTop. Since we already called\n // getClientBoundingRect we have already forced a reflow, so it is not\n // too expensive just to query them all.\n\n // ie 下应该减去窗口的边框吧,毕竟默认 absolute 都是相对窗口定位的\n // 窗口边框标准是设 documentElement ,quirks 时设置 body\n // 最好禁止在 body 和 html 上边框 ,但 ie < 9 html 默认有 2px ,减去\n // 但是非 ie 不可能设置窗口边框,body html 也不是窗口 ,ie 可以通过 html,body 设置\n // 标准 ie 下 docElem.clientTop 就是 border-top\n // ie7 html 即窗口边框改变不了。永远为 2\n // 但标准 firefox/chrome/ie9 下 docElem.clientTop 是窗口边框,即使设了 border-top 也为 0\n\n x -= docElem.clientLeft || body.clientLeft || 0;\n y -= docElem.clientTop || body.clientTop || 0;\n\n return {\n left: x,\n top: y,\n };\n}\n\nfunction getScroll(w, top) {\n let ret = w[`page${top ? 'Y' : 'X'}Offset`];\n const method = `scroll${top ? 'Top' : 'Left'}`;\n if (typeof ret !== 'number') {\n const d = w.document;\n // ie6,7,8 standard mode\n ret = d.documentElement[method];\n if (typeof ret !== 'number') {\n // quirks mode\n ret = d.body[method];\n }\n }\n return ret;\n}\n\nfunction getScrollLeft(w) {\n return getScroll(w);\n}\n\nfunction getScrollTop(w) {\n return getScroll(w, true);\n}\n\nfunction getOffset(el) {\n const pos = getClientPosition(el);\n const doc = el.ownerDocument;\n const w = doc.defaultView || doc.parentWindow;\n pos.left += getScrollLeft(w);\n pos.top += getScrollTop(w);\n return pos;\n}\n\n/**\n * A crude way of determining if an object is a window\n * @member util\n */\nfunction isWindow(obj) {\n // must use == for ie8\n /* eslint eqeqeq:0 */\n return obj !== null && obj !== undefined && obj == obj.window;\n}\n\nfunction getDocument(node) {\n if (isWindow(node)) {\n return node.document;\n }\n if (node.nodeType === 9) {\n return node;\n }\n return node.ownerDocument;\n}\n\nfunction _getComputedStyle(elem, name, cs) {\n let computedStyle = cs;\n let val = '';\n const d = getDocument(elem);\n computedStyle = computedStyle || d.defaultView.getComputedStyle(elem, null);\n\n // https://github.com/kissyteam/kissy/issues/61\n if (computedStyle) {\n val = computedStyle.getPropertyValue(name) || computedStyle[name];\n }\n\n return val;\n}\n\nconst _RE_NUM_NO_PX = new RegExp(`^(${RE_NUM})(?!px)[a-z%]+$`, 'i');\nconst RE_POS = /^(top|right|bottom|left)$/;\nconst CURRENT_STYLE = 'currentStyle';\nconst RUNTIME_STYLE = 'runtimeStyle';\nconst LEFT = 'left';\nconst PX = 'px';\n\nfunction _getComputedStyleIE(elem, name) {\n // currentStyle maybe null\n // http://msdn.microsoft.com/en-us/library/ms535231.aspx\n let ret = elem[CURRENT_STYLE] && elem[CURRENT_STYLE][name];\n\n // 当 width/height 设置为百分比时,通过 pixelLeft 方式转换的 width/height 值\n // 一开始就处理了! CUSTOM_STYLE.height,CUSTOM_STYLE.width ,cssHook 解决@2011-08-19\n // 在 ie 下不对,需要直接用 offset 方式\n // borderWidth 等值也有问题,但考虑到 borderWidth 设为百分比的概率很小,这里就不考虑了\n\n // From the awesome hack by Dean Edwards\n // http://erik.eae.net/archives/2007/07/27/18.54.15/#comment-102291\n // If we're not dealing with a regular pixel number\n // but a number that has a weird ending, we need to convert it to pixels\n // exclude left right for relativity\n if (_RE_NUM_NO_PX.test(ret) && !RE_POS.test(name)) {\n // Remember the original values\n const style = elem.style;\n const left = style[LEFT];\n const rsLeft = elem[RUNTIME_STYLE][LEFT];\n\n // prevent flashing of content\n elem[RUNTIME_STYLE][LEFT] = elem[CURRENT_STYLE][LEFT];\n\n // Put in the new values to get a computed value out\n style[LEFT] = name === 'fontSize' ? '1em' : ret || 0;\n ret = style.pixelLeft + PX;\n\n // Revert the changed values\n style[LEFT] = left;\n\n elem[RUNTIME_STYLE][LEFT] = rsLeft;\n }\n return ret === '' ? 'auto' : ret;\n}\n\nif (typeof window !== 'undefined') {\n getComputedStyleX = window.getComputedStyle\n ? _getComputedStyle\n : _getComputedStyleIE;\n}\n\nfunction getOffsetDirection(dir, option) {\n if (dir === 'left') {\n return option.useCssRight ? 'right' : dir;\n }\n return option.useCssBottom ? 'bottom' : dir;\n}\n\nfunction oppositeOffsetDirection(dir) {\n if (dir === 'left') {\n return 'right';\n } else if (dir === 'right') {\n return 'left';\n } else if (dir === 'top') {\n return 'bottom';\n } else if (dir === 'bottom') {\n return 'top';\n }\n}\n\n// 设置 elem 相对 elem.ownerDocument 的坐标\nfunction setLeftTop(elem, offset, option) {\n // set position first, in-case top/left are set even on static elem\n if (css(elem, 'position') === 'static') {\n elem.style.position = 'relative';\n }\n let presetH = -999;\n let presetV = -999;\n const horizontalProperty = getOffsetDirection('left', option);\n const verticalProperty = getOffsetDirection('top', option);\n const oppositeHorizontalProperty = oppositeOffsetDirection(\n horizontalProperty,\n );\n const oppositeVerticalProperty = oppositeOffsetDirection(verticalProperty);\n\n if (horizontalProperty !== 'left') {\n presetH = 999;\n }\n\n if (verticalProperty !== 'top') {\n presetV = 999;\n }\n let originalTransition = '';\n const originalOffset = getOffset(elem);\n if ('left' in offset || 'top' in offset) {\n originalTransition = getTransitionProperty(elem) || '';\n setTransitionProperty(elem, 'none');\n }\n if ('left' in offset) {\n elem.style[oppositeHorizontalProperty] = '';\n elem.style[horizontalProperty] = `${presetH}px`;\n }\n if ('top' in offset) {\n elem.style[oppositeVerticalProperty] = '';\n elem.style[verticalProperty] = `${presetV}px`;\n }\n // force relayout\n forceRelayout(elem);\n const old = getOffset(elem);\n const originalStyle = {};\n for (const key in offset) {\n if (offset.hasOwnProperty(key)) {\n const dir = getOffsetDirection(key, option);\n const preset = key === 'left' ? presetH : presetV;\n const off = originalOffset[key] - old[key];\n if (dir === key) {\n originalStyle[dir] = preset + off;\n } else {\n originalStyle[dir] = preset - off;\n }\n }\n }\n css(elem, originalStyle);\n // force relayout\n forceRelayout(elem);\n if ('left' in offset || 'top' in offset) {\n setTransitionProperty(elem, originalTransition);\n }\n const ret = {};\n for (const key in offset) {\n if (offset.hasOwnProperty(key)) {\n const dir = getOffsetDirection(key, option);\n const off = offset[key] - originalOffset[key];\n if (key === dir) {\n ret[dir] = originalStyle[dir] + off;\n } else {\n ret[dir] = originalStyle[dir] - off;\n }\n }\n }\n css(elem, ret);\n}\n\nfunction setTransform(elem, offset) {\n const originalOffset = getOffset(elem);\n const originalXY = getTransformXY(elem);\n const resultXY = { x: originalXY.x, y: originalXY.y };\n if ('left' in offset) {\n resultXY.x = originalXY.x + offset.left - originalOffset.left;\n }\n if ('top' in offset) {\n resultXY.y = originalXY.y + offset.top - originalOffset.top;\n }\n setTransformXY(elem, resultXY);\n}\n\nfunction setOffset(elem, offset, option) {\n if (option.ignoreShake) {\n const oriOffset = getOffset(elem);\n\n const oLeft = oriOffset.left.toFixed(0);\n const oTop = oriOffset.top.toFixed(0);\n const tLeft = offset.left.toFixed(0);\n const tTop = offset.top.toFixed(0);\n\n if (oLeft === tLeft && oTop === tTop) {\n return;\n }\n }\n\n if (option.useCssRight || option.useCssBottom) {\n setLeftTop(elem, offset, option);\n } else if (\n option.useCssTransform &&\n getTransformName() in document.body.style\n ) {\n setTransform(elem, offset, option);\n } else {\n setLeftTop(elem, offset, option);\n }\n}\n\nfunction each(arr, fn) {\n for (let i = 0; i < arr.length; i++) {\n fn(arr[i]);\n }\n}\n\nfunction isBorderBoxFn(elem) {\n return getComputedStyleX(elem, 'boxSizing') === 'border-box';\n}\n\nconst BOX_MODELS = ['margin', 'border', 'padding'];\nconst CONTENT_INDEX = -1;\nconst PADDING_INDEX = 2;\nconst BORDER_INDEX = 1;\nconst MARGIN_INDEX = 0;\n\nfunction swap(elem, options, callback) {\n const old = {};\n const style = elem.style;\n let name;\n\n // Remember the old values, and insert the new ones\n for (name in options) {\n if (options.hasOwnProperty(name)) {\n old[name] = style[name];\n style[name] = options[name];\n }\n }\n\n callback.call(elem);\n\n // Revert the old values\n for (name in options) {\n if (options.hasOwnProperty(name)) {\n style[name] = old[name];\n }\n }\n}\n\nfunction getPBMWidth(elem, props, which) {\n let value = 0;\n let prop;\n let j;\n let i;\n for (j = 0; j < props.length; j++) {\n prop = props[j];\n if (prop) {\n for (i = 0; i < which.length; i++) {\n let cssProp;\n if (prop === 'border') {\n cssProp = `${prop}${which[i]}Width`;\n } else {\n cssProp = prop + which[i];\n }\n value += parseFloat(getComputedStyleX(elem, cssProp)) || 0;\n }\n }\n }\n return value;\n}\n\nconst domUtils = {\n getParent(element) {\n let parent = element;\n do {\n if (parent.nodeType === 11 && parent.host) {\n parent = parent.host;\n } else {\n parent = parent.parentNode;\n }\n } while (parent && parent.nodeType !== 1 && parent.nodeType !== 9);\n return parent;\n },\n};\n\neach(['Width', 'Height'], name => {\n domUtils[`doc${name}`] = refWin => {\n const d = refWin.document;\n return Math.max(\n // firefox chrome documentElement.scrollHeight< body.scrollHeight\n // ie standard mode : documentElement.scrollHeight> body.scrollHeight\n d.documentElement[`scroll${name}`],\n // quirks : documentElement.scrollHeight 最大等于可视窗口多一点?\n d.body[`scroll${name}`],\n domUtils[`viewport${name}`](d),\n );\n };\n\n domUtils[`viewport${name}`] = win => {\n // pc browser includes scrollbar in window.innerWidth\n const prop = `client${name}`;\n const doc = win.document;\n const body = doc.body;\n const documentElement = doc.documentElement;\n const documentElementProp = documentElement[prop];\n // 标准模式取 documentElement\n // backcompat 取 body\n return (\n (doc.compatMode === 'CSS1Compat' && documentElementProp) ||\n (body && body[prop]) ||\n documentElementProp\n );\n };\n});\n\n/*\n 得到元素的大小信息\n @param elem\n @param name\n @param {String} [extra] 'padding' : (css width) + padding\n 'border' : (css width) + padding + border\n 'margin' : (css width) + padding + border + margin\n */\nfunction getWH(elem, name, ex) {\n let extra = ex;\n if (isWindow(elem)) {\n return name === 'width'\n ? domUtils.viewportWidth(elem)\n : domUtils.viewportHeight(elem);\n } else if (elem.nodeType === 9) {\n return name === 'width'\n ? domUtils.docWidth(elem)\n : domUtils.docHeight(elem);\n }\n const which = name === 'width' ? ['Left', 'Right'] : ['Top', 'Bottom'];\n let borderBoxValue =\n name === 'width'\n ? Math.floor(elem.getBoundingClientRect().width)\n : Math.floor(elem.getBoundingClientRect().height);\n const isBorderBox = isBorderBoxFn(elem);\n let cssBoxValue = 0;\n if (\n borderBoxValue === null ||\n borderBoxValue === undefined ||\n borderBoxValue <= 0\n ) {\n borderBoxValue = undefined;\n // Fall back to computed then un computed css if necessary\n cssBoxValue = getComputedStyleX(elem, name);\n if (\n cssBoxValue === null ||\n cssBoxValue === undefined ||\n Number(cssBoxValue) < 0\n ) {\n cssBoxValue = elem.style[name] || 0;\n }\n // Normalize '', auto, and prepare for extra\n cssBoxValue = Math.floor(parseFloat(cssBoxValue)) || 0;\n }\n if (extra === undefined) {\n extra = isBorderBox ? BORDER_INDEX : CONTENT_INDEX;\n }\n const borderBoxValueOrIsBorderBox =\n borderBoxValue !== undefined || isBorderBox;\n const val = borderBoxValue || cssBoxValue;\n if (extra === CONTENT_INDEX) {\n if (borderBoxValueOrIsBorderBox) {\n return val - getPBMWidth(elem, ['border', 'padding'], which);\n }\n return cssBoxValue;\n } else if (borderBoxValueOrIsBorderBox) {\n if (extra === BORDER_INDEX) {\n return val;\n }\n return (\n val +\n (extra === PADDING_INDEX\n ? -getPBMWidth(elem, ['border'], which)\n : getPBMWidth(elem, ['margin'], which))\n );\n }\n return cssBoxValue + getPBMWidth(elem, BOX_MODELS.slice(extra), which);\n}\n\nconst cssShow = {\n position: 'absolute',\n visibility: 'hidden',\n display: 'block',\n};\n\n// fix #119 : https://github.com/kissyteam/kissy/issues/119\nfunction getWHIgnoreDisplay(...args) {\n let val;\n const elem = args[0];\n // in case elem is window\n // elem.offsetWidth === undefined\n if (elem.offsetWidth !== 0) {\n val = getWH.apply(undefined, args);\n } else {\n swap(elem, cssShow, () => {\n val = getWH.apply(undefined, args);\n });\n }\n return val;\n}\n\neach(['width', 'height'], name => {\n const first = name.charAt(0).toUpperCase() + name.slice(1);\n domUtils[`outer${first}`] = (el, includeMargin) => {\n return (\n el &&\n getWHIgnoreDisplay(el, name, includeMargin ? MARGIN_INDEX : BORDER_INDEX)\n );\n };\n const which = name === 'width' ? ['Left', 'Right'] : ['Top', 'Bottom'];\n\n domUtils[name] = (elem, v) => {\n let val = v;\n if (val !== undefined) {\n if (elem) {\n const isBorderBox = isBorderBoxFn(elem);\n if (isBorderBox) {\n val += getPBMWidth(elem, ['padding', 'border'], which);\n }\n return css(elem, name, val);\n }\n return undefined;\n }\n return elem && getWHIgnoreDisplay(elem, name, CONTENT_INDEX);\n };\n});\n\nfunction mix(to, from) {\n for (const i in from) {\n if (from.hasOwnProperty(i)) {\n to[i] = from[i];\n }\n }\n return to;\n}\n\nconst utils = {\n getWindow(node) {\n if (node && node.document && node.setTimeout) {\n return node;\n }\n const doc = node.ownerDocument || node;\n return doc.defaultView || doc.parentWindow;\n },\n getDocument,\n offset(el, value, option) {\n if (typeof value !== 'undefined') {\n setOffset(el, value, option || {});\n } else {\n return getOffset(el);\n }\n },\n isWindow,\n each,\n css,\n clone(obj) {\n let i;\n const ret = {};\n for (i in obj) {\n if (obj.hasOwnProperty(i)) {\n ret[i] = obj[i];\n }\n }\n const overflow = obj.overflow;\n if (overflow) {\n for (i in obj) {\n if (obj.hasOwnProperty(i)) {\n ret.overflow[i] = obj.overflow[i];\n }\n }\n }\n return ret;\n },\n mix,\n getWindowScrollLeft(w) {\n return getScrollLeft(w);\n },\n getWindowScrollTop(w) {\n return getScrollTop(w);\n },\n merge(...args) {\n const ret = {};\n for (let i = 0; i < args.length; i++) {\n utils.mix(ret, args[i]);\n }\n return ret;\n },\n viewportWidth: 0,\n viewportHeight: 0,\n};\n\nmix(utils, domUtils);\n\nexport default utils;\n","import utils from './utils';\n\n/**\n * 得到会导致元素显示不全的祖先元素\n */\nconst { getParent } = utils;\n\nfunction getOffsetParent(element) {\n if (utils.isWindow(element) || element.nodeType === 9) {\n return null;\n }\n // ie 这个也不是完全可行\n /*\n \n
\n 元素 6 高 100px 宽 50px
\n
\n
\n */\n // element.offsetParent does the right thing in ie7 and below. Return parent with layout!\n // In other browsers it only includes elements with position absolute, relative or\n // fixed, not elements with overflow set to auto or scroll.\n // if (UA.ie && ieMode < 8) {\n // return element.offsetParent;\n // }\n // 统一的 offsetParent 方法\n const doc = utils.getDocument(element);\n const body = doc.body;\n let parent;\n let positionStyle = utils.css(element, 'position');\n const skipStatic = positionStyle === 'fixed' || positionStyle === 'absolute';\n\n if (!skipStatic) {\n return element.nodeName.toLowerCase() === 'html'\n ? null\n : getParent(element);\n }\n\n for (\n parent = getParent(element);\n parent && parent !== body && parent.nodeType !== 9;\n parent = getParent(parent)\n ) {\n positionStyle = utils.css(parent, 'position');\n if (positionStyle !== 'static') {\n return parent;\n }\n }\n return null;\n}\n\nexport default getOffsetParent;\n","import utils from './utils';\n\nconst { getParent } = utils;\n\nexport default function isAncestorFixed(element) {\n if (utils.isWindow(element) || element.nodeType === 9) {\n return false;\n }\n\n const doc = utils.getDocument(element);\n const body = doc.body;\n let parent = null;\n for (\n parent = getParent(element);\n // 修复元素位于 document.documentElement 下导致崩溃问题\n parent && parent !== body && parent !== doc;\n parent = getParent(parent)\n ) {\n const positionStyle = utils.css(parent, 'position');\n if (positionStyle === 'fixed') {\n return true;\n }\n }\n return false;\n}\n","import utils from './utils';\nimport getOffsetParent from './getOffsetParent';\nimport isAncestorFixed from './isAncestorFixed';\n\n/**\n * 获得元素的显示部分的区域\n */\nfunction getVisibleRectForElement(element, alwaysByViewport) {\n const visibleRect = {\n left: 0,\n right: Infinity,\n top: 0,\n bottom: Infinity,\n };\n let el = getOffsetParent(element);\n const doc = utils.getDocument(element);\n const win = doc.defaultView || doc.parentWindow;\n const body = doc.body;\n const documentElement = doc.documentElement;\n\n // Determine the size of the visible rect by climbing the dom accounting for\n // all scrollable containers.\n while (el) {\n // clientWidth is zero for inline block elements in ie.\n if (\n (navigator.userAgent.indexOf('MSIE') === -1 || el.clientWidth !== 0) &&\n // body may have overflow set on it, yet we still get the entire\n // viewport. In some browsers, el.offsetParent may be\n // document.documentElement, so check for that too.\n (el !== body &&\n el !== documentElement &&\n utils.css(el, 'overflow') !== 'visible')\n ) {\n const pos = utils.offset(el);\n // add border\n pos.left += el.clientLeft;\n pos.top += el.clientTop;\n visibleRect.top = Math.max(visibleRect.top, pos.top);\n visibleRect.right = Math.min(\n visibleRect.right,\n // consider area without scrollBar\n pos.left + el.clientWidth,\n );\n visibleRect.bottom = Math.min(\n visibleRect.bottom,\n pos.top + el.clientHeight,\n );\n visibleRect.left = Math.max(visibleRect.left, pos.left);\n } else if (el === body || el === documentElement) {\n break;\n }\n el = getOffsetParent(el);\n }\n\n // Set element position to fixed\n // make sure absolute element itself don't affect it's visible area\n // https://github.com/ant-design/ant-design/issues/7601\n let originalPosition = null;\n if (!utils.isWindow(element) && element.nodeType !== 9) {\n originalPosition = element.style.position;\n const position = utils.css(element, 'position');\n if (position === 'absolute') {\n element.style.position = 'fixed';\n }\n }\n\n const scrollX = utils.getWindowScrollLeft(win);\n const scrollY = utils.getWindowScrollTop(win);\n const viewportWidth = utils.viewportWidth(win);\n const viewportHeight = utils.viewportHeight(win);\n let documentWidth = documentElement.scrollWidth;\n let documentHeight = documentElement.scrollHeight;\n\n // scrollXXX on html is sync with body which means overflow: hidden on body gets wrong scrollXXX.\n // We should cut this ourself.\n const bodyStyle = window.getComputedStyle(body);\n if (bodyStyle.overflowX === 'hidden') {\n documentWidth = win.innerWidth;\n }\n if (bodyStyle.overflowY === 'hidden') {\n documentHeight = win.innerHeight;\n }\n\n // Reset element position after calculate the visible area\n if (element.style) {\n element.style.position = originalPosition;\n }\n\n if (alwaysByViewport || isAncestorFixed(element)) {\n // Clip by viewport's size.\n visibleRect.left = Math.max(visibleRect.left, scrollX);\n visibleRect.top = Math.max(visibleRect.top, scrollY);\n visibleRect.right = Math.min(visibleRect.right, scrollX + viewportWidth);\n visibleRect.bottom = Math.min(visibleRect.bottom, scrollY + viewportHeight);\n } else {\n // Clip by document's size.\n const maxVisibleWidth = Math.max(documentWidth, scrollX + viewportWidth);\n visibleRect.right = Math.min(visibleRect.right, maxVisibleWidth);\n\n const maxVisibleHeight = Math.max(documentHeight, scrollY + viewportHeight);\n visibleRect.bottom = Math.min(visibleRect.bottom, maxVisibleHeight);\n }\n\n return visibleRect.top >= 0 &&\n visibleRect.left >= 0 &&\n visibleRect.bottom > visibleRect.top &&\n visibleRect.right > visibleRect.left\n ? visibleRect\n : null;\n}\n\nexport default getVisibleRectForElement;\n","import utils from './utils';\n\nfunction adjustForViewport(elFuturePos, elRegion, visibleRect, overflow) {\n const pos = utils.clone(elFuturePos);\n const size = {\n width: elRegion.width,\n height: elRegion.height,\n };\n\n if (overflow.adjustX && pos.left < visibleRect.left) {\n pos.left = visibleRect.left;\n }\n\n // Left edge inside and right edge outside viewport, try to resize it.\n if (\n overflow.resizeWidth &&\n pos.left >= visibleRect.left &&\n pos.left + size.width > visibleRect.right\n ) {\n size.width -= pos.left + size.width - visibleRect.right;\n }\n\n // Right edge outside viewport, try to move it.\n if (overflow.adjustX && pos.left + size.width > visibleRect.right) {\n // 保证左边界和可视区域左边界对齐\n pos.left = Math.max(visibleRect.right - size.width, visibleRect.left);\n }\n\n // Top edge outside viewport, try to move it.\n if (overflow.adjustY && pos.top < visibleRect.top) {\n pos.top = visibleRect.top;\n }\n\n // Top edge inside and bottom edge outside viewport, try to resize it.\n if (\n overflow.resizeHeight &&\n pos.top >= visibleRect.top &&\n pos.top + size.height > visibleRect.bottom\n ) {\n size.height -= pos.top + size.height - visibleRect.bottom;\n }\n\n // Bottom edge outside viewport, try to move it.\n if (overflow.adjustY && pos.top + size.height > visibleRect.bottom) {\n // 保证上边界和可视区域上边界对齐\n pos.top = Math.max(visibleRect.bottom - size.height, visibleRect.top);\n }\n\n return utils.mix(pos, size);\n}\n\nexport default adjustForViewport;\n","import utils from './utils';\n\nfunction getRegion(node) {\n let offset;\n let w;\n let h;\n if (!utils.isWindow(node) && node.nodeType !== 9) {\n offset = utils.offset(node);\n w = utils.outerWidth(node);\n h = utils.outerHeight(node);\n } else {\n const win = utils.getWindow(node);\n offset = {\n left: utils.getWindowScrollLeft(win),\n top: utils.getWindowScrollTop(win),\n };\n w = utils.viewportWidth(win);\n h = utils.viewportHeight(win);\n }\n offset.width = w;\n offset.height = h;\n return offset;\n}\n\nexport default getRegion;\n","/**\n * 获取 node 上的 align 对齐点 相对于页面的坐标\n */\n\nfunction getAlignOffset(region, align) {\n const V = align.charAt(0);\n const H = align.charAt(1);\n const w = region.width;\n const h = region.height;\n\n let x = region.left;\n let y = region.top;\n\n if (V === 'c') {\n y += h / 2;\n } else if (V === 'b') {\n y += h;\n }\n\n if (H === 'c') {\n x += w / 2;\n } else if (H === 'r') {\n x += w;\n }\n\n return {\n left: x,\n top: y,\n };\n}\n\nexport default getAlignOffset;\n","import getAlignOffset from './getAlignOffset';\n\nfunction getElFuturePos(elRegion, refNodeRegion, points, offset, targetOffset) {\n const p1 = getAlignOffset(refNodeRegion, points[1]);\n const p2 = getAlignOffset(elRegion, points[0]);\n const diff = [p2.left - p1.left, p2.top - p1.top];\n\n return {\n left: Math.round(elRegion.left - diff[0] + offset[0] - targetOffset[0]),\n top: Math.round(elRegion.top - diff[1] + offset[1] - targetOffset[1]),\n };\n}\n\nexport default getElFuturePos;\n","/**\n * align dom node flexibly\n * @author yiminghe@gmail.com\n */\n\nimport utils from '../utils';\nimport getVisibleRectForElement from '../getVisibleRectForElement';\nimport adjustForViewport from '../adjustForViewport';\nimport getRegion from '../getRegion';\nimport getElFuturePos from '../getElFuturePos';\n\n// http://yiminghe.iteye.com/blog/1124720\n\nfunction isFailX(elFuturePos, elRegion, visibleRect) {\n return (\n elFuturePos.left < visibleRect.left ||\n elFuturePos.left + elRegion.width > visibleRect.right\n );\n}\n\nfunction isFailY(elFuturePos, elRegion, visibleRect) {\n return (\n elFuturePos.top < visibleRect.top ||\n elFuturePos.top + elRegion.height > visibleRect.bottom\n );\n}\n\nfunction isCompleteFailX(elFuturePos, elRegion, visibleRect) {\n return (\n elFuturePos.left > visibleRect.right ||\n elFuturePos.left + elRegion.width < visibleRect.left\n );\n}\n\nfunction isCompleteFailY(elFuturePos, elRegion, visibleRect) {\n return (\n elFuturePos.top > visibleRect.bottom ||\n elFuturePos.top + elRegion.height < visibleRect.top\n );\n}\n\nfunction flip(points, reg, map) {\n const ret = [];\n utils.each(points, p => {\n ret.push(\n p.replace(reg, m => {\n return map[m];\n }),\n );\n });\n return ret;\n}\n\nfunction flipOffset(offset, index) {\n offset[index] = -offset[index];\n return offset;\n}\n\nfunction convertOffset(str, offsetLen) {\n let n;\n if (/%$/.test(str)) {\n n = (parseInt(str.substring(0, str.length - 1), 10) / 100) * offsetLen;\n } else {\n n = parseInt(str, 10);\n }\n return n || 0;\n}\n\nfunction normalizeOffset(offset, el) {\n offset[0] = convertOffset(offset[0], el.width);\n offset[1] = convertOffset(offset[1], el.height);\n}\n\n/**\n * @param el\n * @param tgtRegion 参照节点所占的区域: { left, top, width, height }\n * @param align\n */\nfunction doAlign(el, tgtRegion, align, isTgtRegionVisible) {\n let points = align.points;\n let offset = align.offset || [0, 0];\n let targetOffset = align.targetOffset || [0, 0];\n let overflow = align.overflow;\n const source = align.source || el;\n offset = [].concat(offset);\n targetOffset = [].concat(targetOffset);\n overflow = overflow || {};\n const newOverflowCfg = {};\n let fail = 0;\n const alwaysByViewport = !!(overflow && overflow.alwaysByViewport);\n // 当前节点可以被放置的显示区域\n const visibleRect = getVisibleRectForElement(source, alwaysByViewport);\n // 当前节点所占的区域, left/top/width/height\n const elRegion = getRegion(source);\n // 将 offset 转换成数值,支持百分比\n normalizeOffset(offset, elRegion);\n normalizeOffset(targetOffset, tgtRegion);\n // 当前节点将要被放置的位置\n let elFuturePos = getElFuturePos(\n elRegion,\n tgtRegion,\n points,\n offset,\n targetOffset,\n );\n // 当前节点将要所处的区域\n let newElRegion = utils.merge(elRegion, elFuturePos);\n\n // 如果可视区域不能完全放置当前节点时允许调整\n if (\n visibleRect &&\n (overflow.adjustX || overflow.adjustY) &&\n isTgtRegionVisible\n ) {\n if (overflow.adjustX) {\n // 如果横向不能放下\n if (isFailX(elFuturePos, elRegion, visibleRect)) {\n // 对齐位置反下\n const newPoints = flip(points, /[lr]/gi, {\n l: 'r',\n r: 'l',\n });\n // 偏移量也反下\n const newOffset = flipOffset(offset, 0);\n const newTargetOffset = flipOffset(targetOffset, 0);\n const newElFuturePos = getElFuturePos(\n elRegion,\n tgtRegion,\n newPoints,\n newOffset,\n newTargetOffset,\n );\n\n if (!isCompleteFailX(newElFuturePos, elRegion, visibleRect)) {\n fail = 1;\n points = newPoints;\n offset = newOffset;\n targetOffset = newTargetOffset;\n }\n }\n }\n\n if (overflow.adjustY) {\n // 如果纵向不能放下\n if (isFailY(elFuturePos, elRegion, visibleRect)) {\n // 对齐位置反下\n const newPoints = flip(points, /[tb]/gi, {\n t: 'b',\n b: 't',\n });\n // 偏移量也反下\n const newOffset = flipOffset(offset, 1);\n const newTargetOffset = flipOffset(targetOffset, 1);\n const newElFuturePos = getElFuturePos(\n elRegion,\n tgtRegion,\n newPoints,\n newOffset,\n newTargetOffset,\n );\n\n if (!isCompleteFailY(newElFuturePos, elRegion, visibleRect)) {\n fail = 1;\n points = newPoints;\n offset = newOffset;\n targetOffset = newTargetOffset;\n }\n }\n }\n\n // 如果失败,重新计算当前节点将要被放置的位置\n if (fail) {\n elFuturePos = getElFuturePos(\n elRegion,\n tgtRegion,\n points,\n offset,\n targetOffset,\n );\n utils.mix(newElRegion, elFuturePos);\n }\n const isStillFailX = isFailX(elFuturePos, elRegion, visibleRect);\n const isStillFailY = isFailY(elFuturePos, elRegion, visibleRect);\n // 检查反下后的位置是否可以放下了,如果仍然放不下:\n // 1. 复原修改过的定位参数\n if (isStillFailX || isStillFailY) {\n let newPoints = points;\n\n // 重置对应部分的翻转逻辑\n if (isStillFailX) {\n newPoints = flip(points, /[lr]/gi, {\n l: 'r',\n r: 'l',\n });\n }\n if (isStillFailY) {\n newPoints = flip(points, /[tb]/gi, {\n t: 'b',\n b: 't',\n });\n }\n\n points = newPoints;\n\n offset = align.offset || [0, 0];\n targetOffset = align.targetOffset || [0, 0];\n }\n // 2. 只有指定了可以调整当前方向才调整\n newOverflowCfg.adjustX = overflow.adjustX && isStillFailX;\n newOverflowCfg.adjustY = overflow.adjustY && isStillFailY;\n\n // 确实要调整,甚至可能会调整高度宽度\n if (newOverflowCfg.adjustX || newOverflowCfg.adjustY) {\n newElRegion = adjustForViewport(\n elFuturePos,\n elRegion,\n visibleRect,\n newOverflowCfg,\n );\n }\n }\n\n // need judge to in case set fixed with in css on height auto element\n if (newElRegion.width !== elRegion.width) {\n utils.css(\n source,\n 'width',\n utils.width(source) + newElRegion.width - elRegion.width,\n );\n }\n\n if (newElRegion.height !== elRegion.height) {\n utils.css(\n source,\n 'height',\n utils.height(source) + newElRegion.height - elRegion.height,\n );\n }\n\n // https://github.com/kissyteam/kissy/issues/190\n // 相对于屏幕位置没变,而 left/top 变了\n // 例如
\n utils.offset(\n source,\n {\n left: newElRegion.left,\n top: newElRegion.top,\n },\n {\n useCssRight: align.useCssRight,\n useCssBottom: align.useCssBottom,\n useCssTransform: align.useCssTransform,\n ignoreShake: align.ignoreShake,\n },\n );\n\n return {\n points,\n offset,\n targetOffset,\n overflow: newOverflowCfg,\n };\n}\n\nexport default doAlign;\n/**\n * 2012-04-26 yiminghe@gmail.com\n * - 优化智能对齐算法\n * - 慎用 resizeXX\n *\n * 2011-07-13 yiminghe@gmail.com note:\n * - 增加智能对齐,以及大小调整选项\n **/\n","import doAlign from './align';\nimport getOffsetParent from '../getOffsetParent';\nimport getVisibleRectForElement from '../getVisibleRectForElement';\nimport getRegion from '../getRegion';\n\nfunction isOutOfVisibleRect(target, alwaysByViewport) {\n const visibleRect = getVisibleRectForElement(target, alwaysByViewport);\n const targetRegion = getRegion(target);\n\n return (\n !visibleRect ||\n targetRegion.left + targetRegion.width <= visibleRect.left ||\n targetRegion.top + targetRegion.height <= visibleRect.top ||\n targetRegion.left >= visibleRect.right ||\n targetRegion.top >= visibleRect.bottom\n );\n}\n\nfunction alignElement(el, refNode, align) {\n const target = align.target || refNode;\n const refNodeRegion = getRegion(target);\n\n const isTargetNotOutOfVisible = !isOutOfVisibleRect(\n target,\n align.overflow && align.overflow.alwaysByViewport,\n );\n\n return doAlign(el, refNodeRegion, align, isTargetNotOutOfVisible);\n}\n\nalignElement.__getOffsetParent = getOffsetParent;\n\nalignElement.__getVisibleRectForElement = getVisibleRectForElement;\n\nexport default alignElement;\n","import utils from '../utils';\nimport doAlign from './align';\n\n/**\n * `tgtPoint`: { pageX, pageY } or { clientX, clientY }.\n * If client position provided, will internal convert to page position.\n */\n\nfunction alignPoint(el, tgtPoint, align) {\n let pageX;\n let pageY;\n\n const doc = utils.getDocument(el);\n const win = doc.defaultView || doc.parentWindow;\n\n const scrollX = utils.getWindowScrollLeft(win);\n const scrollY = utils.getWindowScrollTop(win);\n const viewportWidth = utils.viewportWidth(win);\n const viewportHeight = utils.viewportHeight(win);\n\n if ('pageX' in tgtPoint) {\n pageX = tgtPoint.pageX;\n } else {\n pageX = scrollX + tgtPoint.clientX;\n }\n\n if ('pageY' in tgtPoint) {\n pageY = tgtPoint.pageY;\n } else {\n pageY = scrollY + tgtPoint.clientY;\n }\n\n const tgtRegion = {\n left: pageX,\n top: pageY,\n width: 0,\n height: 0,\n };\n\n const pointInView =\n pageX >= 0 &&\n pageX <= scrollX + viewportWidth &&\n (pageY >= 0 && pageY <= scrollY + viewportHeight);\n\n // Provide default target point\n const points = [align.points[0], 'cc'];\n\n return doAlign(el, tgtRegion, { ...align, points }, pointInView);\n}\n\nexport default alignPoint;\n","import vcWarning, { resetWarned } from '../vc-util/warning';\nexport { resetWarned };\nexport function noop() {}\n// eslint-disable-next-line import/no-mutable-exports\nlet warning = noop;\nif (process.env.NODE_ENV !== 'production') {\n warning = (valid, component, message) => {\n vcWarning(valid, `[ant-design-vue: ${component}] ${message}`);\n // StrictMode will inject console which will not throw warning in React 17.\n if (process.env.NODE_ENV === 'test') {\n resetWarned();\n }\n };\n}\nexport default warning;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport { filterEmpty } from './props-util';\nimport { cloneVNode, isVNode, Comment, Fragment, render as VueRender } from 'vue';\nimport warning from './warning';\nexport function cloneElement(vnode) {\n let nodeProps = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n let override = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true;\n let mergeRef = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;\n let ele = vnode;\n if (Array.isArray(vnode)) {\n ele = filterEmpty(vnode)[0];\n }\n if (!ele) {\n return null;\n }\n const node = cloneVNode(ele, nodeProps, mergeRef);\n // cloneVNode内部是合并属性,这里改成覆盖属性\n node.props = override ? _extends(_extends({}, node.props), nodeProps) : node.props;\n warning(typeof node.props.class !== 'object', 'class must be string');\n return node;\n}\nexport function cloneVNodes(vnodes) {\n let nodeProps = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n let override = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true;\n return vnodes.map(vnode => cloneElement(vnode, nodeProps, override));\n}\nexport function deepCloneElement(vnode) {\n let nodeProps = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n let override = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true;\n let mergeRef = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;\n if (Array.isArray(vnode)) {\n return vnode.map(item => deepCloneElement(item, nodeProps, override, mergeRef));\n } else {\n // 需要判断是否为vnode方可进行clone操作\n if (!isVNode(vnode)) {\n return vnode;\n }\n const cloned = cloneElement(vnode, nodeProps, override, mergeRef);\n if (Array.isArray(cloned.children)) {\n cloned.children = deepCloneElement(cloned.children);\n }\n return cloned;\n }\n}\nexport function triggerVNodeUpdate(vm, attrs, dom) {\n VueRender(cloneVNode(vm, _extends({}, attrs)), dom);\n}\nconst ensureValidVNode = slot => {\n return (slot || []).some(child => {\n if (!isVNode(child)) return true;\n if (child.type === Comment) return false;\n if (child.type === Fragment && !ensureValidVNode(child.children)) return false;\n return true;\n }) ? slot : null;\n};\nexport function customRenderSlot(slots, name, props, fallback) {\n var _a;\n const slot = (_a = slots[name]) === null || _a === void 0 ? void 0 : _a.call(slots, props);\n if (ensureValidVNode(slot)) {\n return slot;\n }\n return fallback === null || fallback === void 0 ? void 0 : fallback();\n}","export default (element => {\n if (!element) {\n return false;\n }\n if (element.offsetParent) {\n return true;\n }\n if (element.getBBox) {\n const box = element.getBBox();\n if (box.width || box.height) {\n return true;\n }\n }\n if (element.getBoundingClientRect) {\n const box = element.getBoundingClientRect();\n if (box.width || box.height) {\n return true;\n }\n }\n return false;\n});","/**\r\n * A collection of shims that provide minimal functionality of the ES6 collections.\r\n *\r\n * These implementations are not meant to be used outside of the ResizeObserver\r\n * modules as they cover only a limited range of use cases.\r\n */\r\n/* eslint-disable require-jsdoc, valid-jsdoc */\r\nvar MapShim = (function () {\r\n if (typeof Map !== 'undefined') {\r\n return Map;\r\n }\r\n /**\r\n * Returns index in provided array that matches the specified key.\r\n *\r\n * @param {Array} arr\r\n * @param {*} key\r\n * @returns {number}\r\n */\r\n function getIndex(arr, key) {\r\n var result = -1;\r\n arr.some(function (entry, index) {\r\n if (entry[0] === key) {\r\n result = index;\r\n return true;\r\n }\r\n return false;\r\n });\r\n return result;\r\n }\r\n return /** @class */ (function () {\r\n function class_1() {\r\n this.__entries__ = [];\r\n }\r\n Object.defineProperty(class_1.prototype, \"size\", {\r\n /**\r\n * @returns {boolean}\r\n */\r\n get: function () {\r\n return this.__entries__.length;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * @param {*} key\r\n * @returns {*}\r\n */\r\n class_1.prototype.get = function (key) {\r\n var index = getIndex(this.__entries__, key);\r\n var entry = this.__entries__[index];\r\n return entry && entry[1];\r\n };\r\n /**\r\n * @param {*} key\r\n * @param {*} value\r\n * @returns {void}\r\n */\r\n class_1.prototype.set = function (key, value) {\r\n var index = getIndex(this.__entries__, key);\r\n if (~index) {\r\n this.__entries__[index][1] = value;\r\n }\r\n else {\r\n this.__entries__.push([key, value]);\r\n }\r\n };\r\n /**\r\n * @param {*} key\r\n * @returns {void}\r\n */\r\n class_1.prototype.delete = function (key) {\r\n var entries = this.__entries__;\r\n var index = getIndex(entries, key);\r\n if (~index) {\r\n entries.splice(index, 1);\r\n }\r\n };\r\n /**\r\n * @param {*} key\r\n * @returns {void}\r\n */\r\n class_1.prototype.has = function (key) {\r\n return !!~getIndex(this.__entries__, key);\r\n };\r\n /**\r\n * @returns {void}\r\n */\r\n class_1.prototype.clear = function () {\r\n this.__entries__.splice(0);\r\n };\r\n /**\r\n * @param {Function} callback\r\n * @param {*} [ctx=null]\r\n * @returns {void}\r\n */\r\n class_1.prototype.forEach = function (callback, ctx) {\r\n if (ctx === void 0) { ctx = null; }\r\n for (var _i = 0, _a = this.__entries__; _i < _a.length; _i++) {\r\n var entry = _a[_i];\r\n callback.call(ctx, entry[1], entry[0]);\r\n }\r\n };\r\n return class_1;\r\n }());\r\n})();\n\n/**\r\n * Detects whether window and document objects are available in current environment.\r\n */\r\nvar isBrowser = typeof window !== 'undefined' && typeof document !== 'undefined' && window.document === document;\n\n// Returns global object of a current environment.\r\nvar global$1 = (function () {\r\n if (typeof global !== 'undefined' && global.Math === Math) {\r\n return global;\r\n }\r\n if (typeof self !== 'undefined' && self.Math === Math) {\r\n return self;\r\n }\r\n if (typeof window !== 'undefined' && window.Math === Math) {\r\n return window;\r\n }\r\n // eslint-disable-next-line no-new-func\r\n return Function('return this')();\r\n})();\n\n/**\r\n * A shim for the requestAnimationFrame which falls back to the setTimeout if\r\n * first one is not supported.\r\n *\r\n * @returns {number} Requests' identifier.\r\n */\r\nvar requestAnimationFrame$1 = (function () {\r\n if (typeof requestAnimationFrame === 'function') {\r\n // It's required to use a bounded function because IE sometimes throws\r\n // an \"Invalid calling object\" error if rAF is invoked without the global\r\n // object on the left hand side.\r\n return requestAnimationFrame.bind(global$1);\r\n }\r\n return function (callback) { return setTimeout(function () { return callback(Date.now()); }, 1000 / 60); };\r\n})();\n\n// Defines minimum timeout before adding a trailing call.\r\nvar trailingTimeout = 2;\r\n/**\r\n * Creates a wrapper function which ensures that provided callback will be\r\n * invoked only once during the specified delay period.\r\n *\r\n * @param {Function} callback - Function to be invoked after the delay period.\r\n * @param {number} delay - Delay after which to invoke callback.\r\n * @returns {Function}\r\n */\r\nfunction throttle (callback, delay) {\r\n var leadingCall = false, trailingCall = false, lastCallTime = 0;\r\n /**\r\n * Invokes the original callback function and schedules new invocation if\r\n * the \"proxy\" was called during current request.\r\n *\r\n * @returns {void}\r\n */\r\n function resolvePending() {\r\n if (leadingCall) {\r\n leadingCall = false;\r\n callback();\r\n }\r\n if (trailingCall) {\r\n proxy();\r\n }\r\n }\r\n /**\r\n * Callback invoked after the specified delay. It will further postpone\r\n * invocation of the original function delegating it to the\r\n * requestAnimationFrame.\r\n *\r\n * @returns {void}\r\n */\r\n function timeoutCallback() {\r\n requestAnimationFrame$1(resolvePending);\r\n }\r\n /**\r\n * Schedules invocation of the original function.\r\n *\r\n * @returns {void}\r\n */\r\n function proxy() {\r\n var timeStamp = Date.now();\r\n if (leadingCall) {\r\n // Reject immediately following calls.\r\n if (timeStamp - lastCallTime < trailingTimeout) {\r\n return;\r\n }\r\n // Schedule new call to be in invoked when the pending one is resolved.\r\n // This is important for \"transitions\" which never actually start\r\n // immediately so there is a chance that we might miss one if change\r\n // happens amids the pending invocation.\r\n trailingCall = true;\r\n }\r\n else {\r\n leadingCall = true;\r\n trailingCall = false;\r\n setTimeout(timeoutCallback, delay);\r\n }\r\n lastCallTime = timeStamp;\r\n }\r\n return proxy;\r\n}\n\n// Minimum delay before invoking the update of observers.\r\nvar REFRESH_DELAY = 20;\r\n// A list of substrings of CSS properties used to find transition events that\r\n// might affect dimensions of observed elements.\r\nvar transitionKeys = ['top', 'right', 'bottom', 'left', 'width', 'height', 'size', 'weight'];\r\n// Check if MutationObserver is available.\r\nvar mutationObserverSupported = typeof MutationObserver !== 'undefined';\r\n/**\r\n * Singleton controller class which handles updates of ResizeObserver instances.\r\n */\r\nvar ResizeObserverController = /** @class */ (function () {\r\n /**\r\n * Creates a new instance of ResizeObserverController.\r\n *\r\n * @private\r\n */\r\n function ResizeObserverController() {\r\n /**\r\n * Indicates whether DOM listeners have been added.\r\n *\r\n * @private {boolean}\r\n */\r\n this.connected_ = false;\r\n /**\r\n * Tells that controller has subscribed for Mutation Events.\r\n *\r\n * @private {boolean}\r\n */\r\n this.mutationEventsAdded_ = false;\r\n /**\r\n * Keeps reference to the instance of MutationObserver.\r\n *\r\n * @private {MutationObserver}\r\n */\r\n this.mutationsObserver_ = null;\r\n /**\r\n * A list of connected observers.\r\n *\r\n * @private {Array}\r\n */\r\n this.observers_ = [];\r\n this.onTransitionEnd_ = this.onTransitionEnd_.bind(this);\r\n this.refresh = throttle(this.refresh.bind(this), REFRESH_DELAY);\r\n }\r\n /**\r\n * Adds observer to observers list.\r\n *\r\n * @param {ResizeObserverSPI} observer - Observer to be added.\r\n * @returns {void}\r\n */\r\n ResizeObserverController.prototype.addObserver = function (observer) {\r\n if (!~this.observers_.indexOf(observer)) {\r\n this.observers_.push(observer);\r\n }\r\n // Add listeners if they haven't been added yet.\r\n if (!this.connected_) {\r\n this.connect_();\r\n }\r\n };\r\n /**\r\n * Removes observer from observers list.\r\n *\r\n * @param {ResizeObserverSPI} observer - Observer to be removed.\r\n * @returns {void}\r\n */\r\n ResizeObserverController.prototype.removeObserver = function (observer) {\r\n var observers = this.observers_;\r\n var index = observers.indexOf(observer);\r\n // Remove observer if it's present in registry.\r\n if (~index) {\r\n observers.splice(index, 1);\r\n }\r\n // Remove listeners if controller has no connected observers.\r\n if (!observers.length && this.connected_) {\r\n this.disconnect_();\r\n }\r\n };\r\n /**\r\n * Invokes the update of observers. It will continue running updates insofar\r\n * it detects changes.\r\n *\r\n * @returns {void}\r\n */\r\n ResizeObserverController.prototype.refresh = function () {\r\n var changesDetected = this.updateObservers_();\r\n // Continue running updates if changes have been detected as there might\r\n // be future ones caused by CSS transitions.\r\n if (changesDetected) {\r\n this.refresh();\r\n }\r\n };\r\n /**\r\n * Updates every observer from observers list and notifies them of queued\r\n * entries.\r\n *\r\n * @private\r\n * @returns {boolean} Returns \"true\" if any observer has detected changes in\r\n * dimensions of it's elements.\r\n */\r\n ResizeObserverController.prototype.updateObservers_ = function () {\r\n // Collect observers that have active observations.\r\n var activeObservers = this.observers_.filter(function (observer) {\r\n return observer.gatherActive(), observer.hasActive();\r\n });\r\n // Deliver notifications in a separate cycle in order to avoid any\r\n // collisions between observers, e.g. when multiple instances of\r\n // ResizeObserver are tracking the same element and the callback of one\r\n // of them changes content dimensions of the observed target. Sometimes\r\n // this may result in notifications being blocked for the rest of observers.\r\n activeObservers.forEach(function (observer) { return observer.broadcastActive(); });\r\n return activeObservers.length > 0;\r\n };\r\n /**\r\n * Initializes DOM listeners.\r\n *\r\n * @private\r\n * @returns {void}\r\n */\r\n ResizeObserverController.prototype.connect_ = function () {\r\n // Do nothing if running in a non-browser environment or if listeners\r\n // have been already added.\r\n if (!isBrowser || this.connected_) {\r\n return;\r\n }\r\n // Subscription to the \"Transitionend\" event is used as a workaround for\r\n // delayed transitions. This way it's possible to capture at least the\r\n // final state of an element.\r\n document.addEventListener('transitionend', this.onTransitionEnd_);\r\n window.addEventListener('resize', this.refresh);\r\n if (mutationObserverSupported) {\r\n this.mutationsObserver_ = new MutationObserver(this.refresh);\r\n this.mutationsObserver_.observe(document, {\r\n attributes: true,\r\n childList: true,\r\n characterData: true,\r\n subtree: true\r\n });\r\n }\r\n else {\r\n document.addEventListener('DOMSubtreeModified', this.refresh);\r\n this.mutationEventsAdded_ = true;\r\n }\r\n this.connected_ = true;\r\n };\r\n /**\r\n * Removes DOM listeners.\r\n *\r\n * @private\r\n * @returns {void}\r\n */\r\n ResizeObserverController.prototype.disconnect_ = function () {\r\n // Do nothing if running in a non-browser environment or if listeners\r\n // have been already removed.\r\n if (!isBrowser || !this.connected_) {\r\n return;\r\n }\r\n document.removeEventListener('transitionend', this.onTransitionEnd_);\r\n window.removeEventListener('resize', this.refresh);\r\n if (this.mutationsObserver_) {\r\n this.mutationsObserver_.disconnect();\r\n }\r\n if (this.mutationEventsAdded_) {\r\n document.removeEventListener('DOMSubtreeModified', this.refresh);\r\n }\r\n this.mutationsObserver_ = null;\r\n this.mutationEventsAdded_ = false;\r\n this.connected_ = false;\r\n };\r\n /**\r\n * \"Transitionend\" event handler.\r\n *\r\n * @private\r\n * @param {TransitionEvent} event\r\n * @returns {void}\r\n */\r\n ResizeObserverController.prototype.onTransitionEnd_ = function (_a) {\r\n var _b = _a.propertyName, propertyName = _b === void 0 ? '' : _b;\r\n // Detect whether transition may affect dimensions of an element.\r\n var isReflowProperty = transitionKeys.some(function (key) {\r\n return !!~propertyName.indexOf(key);\r\n });\r\n if (isReflowProperty) {\r\n this.refresh();\r\n }\r\n };\r\n /**\r\n * Returns instance of the ResizeObserverController.\r\n *\r\n * @returns {ResizeObserverController}\r\n */\r\n ResizeObserverController.getInstance = function () {\r\n if (!this.instance_) {\r\n this.instance_ = new ResizeObserverController();\r\n }\r\n return this.instance_;\r\n };\r\n /**\r\n * Holds reference to the controller's instance.\r\n *\r\n * @private {ResizeObserverController}\r\n */\r\n ResizeObserverController.instance_ = null;\r\n return ResizeObserverController;\r\n}());\n\n/**\r\n * Defines non-writable/enumerable properties of the provided target object.\r\n *\r\n * @param {Object} target - Object for which to define properties.\r\n * @param {Object} props - Properties to be defined.\r\n * @returns {Object} Target object.\r\n */\r\nvar defineConfigurable = (function (target, props) {\r\n for (var _i = 0, _a = Object.keys(props); _i < _a.length; _i++) {\r\n var key = _a[_i];\r\n Object.defineProperty(target, key, {\r\n value: props[key],\r\n enumerable: false,\r\n writable: false,\r\n configurable: true\r\n });\r\n }\r\n return target;\r\n});\n\n/**\r\n * Returns the global object associated with provided element.\r\n *\r\n * @param {Object} target\r\n * @returns {Object}\r\n */\r\nvar getWindowOf = (function (target) {\r\n // Assume that the element is an instance of Node, which means that it\r\n // has the \"ownerDocument\" property from which we can retrieve a\r\n // corresponding global object.\r\n var ownerGlobal = target && target.ownerDocument && target.ownerDocument.defaultView;\r\n // Return the local global object if it's not possible extract one from\r\n // provided element.\r\n return ownerGlobal || global$1;\r\n});\n\n// Placeholder of an empty content rectangle.\r\nvar emptyRect = createRectInit(0, 0, 0, 0);\r\n/**\r\n * Converts provided string to a number.\r\n *\r\n * @param {number|string} value\r\n * @returns {number}\r\n */\r\nfunction toFloat(value) {\r\n return parseFloat(value) || 0;\r\n}\r\n/**\r\n * Extracts borders size from provided styles.\r\n *\r\n * @param {CSSStyleDeclaration} styles\r\n * @param {...string} positions - Borders positions (top, right, ...)\r\n * @returns {number}\r\n */\r\nfunction getBordersSize(styles) {\r\n var positions = [];\r\n for (var _i = 1; _i < arguments.length; _i++) {\r\n positions[_i - 1] = arguments[_i];\r\n }\r\n return positions.reduce(function (size, position) {\r\n var value = styles['border-' + position + '-width'];\r\n return size + toFloat(value);\r\n }, 0);\r\n}\r\n/**\r\n * Extracts paddings sizes from provided styles.\r\n *\r\n * @param {CSSStyleDeclaration} styles\r\n * @returns {Object} Paddings box.\r\n */\r\nfunction getPaddings(styles) {\r\n var positions = ['top', 'right', 'bottom', 'left'];\r\n var paddings = {};\r\n for (var _i = 0, positions_1 = positions; _i < positions_1.length; _i++) {\r\n var position = positions_1[_i];\r\n var value = styles['padding-' + position];\r\n paddings[position] = toFloat(value);\r\n }\r\n return paddings;\r\n}\r\n/**\r\n * Calculates content rectangle of provided SVG element.\r\n *\r\n * @param {SVGGraphicsElement} target - Element content rectangle of which needs\r\n * to be calculated.\r\n * @returns {DOMRectInit}\r\n */\r\nfunction getSVGContentRect(target) {\r\n var bbox = target.getBBox();\r\n return createRectInit(0, 0, bbox.width, bbox.height);\r\n}\r\n/**\r\n * Calculates content rectangle of provided HTMLElement.\r\n *\r\n * @param {HTMLElement} target - Element for which to calculate the content rectangle.\r\n * @returns {DOMRectInit}\r\n */\r\nfunction getHTMLElementContentRect(target) {\r\n // Client width & height properties can't be\r\n // used exclusively as they provide rounded values.\r\n var clientWidth = target.clientWidth, clientHeight = target.clientHeight;\r\n // By this condition we can catch all non-replaced inline, hidden and\r\n // detached elements. Though elements with width & height properties less\r\n // than 0.5 will be discarded as well.\r\n //\r\n // Without it we would need to implement separate methods for each of\r\n // those cases and it's not possible to perform a precise and performance\r\n // effective test for hidden elements. E.g. even jQuery's ':visible' filter\r\n // gives wrong results for elements with width & height less than 0.5.\r\n if (!clientWidth && !clientHeight) {\r\n return emptyRect;\r\n }\r\n var styles = getWindowOf(target).getComputedStyle(target);\r\n var paddings = getPaddings(styles);\r\n var horizPad = paddings.left + paddings.right;\r\n var vertPad = paddings.top + paddings.bottom;\r\n // Computed styles of width & height are being used because they are the\r\n // only dimensions available to JS that contain non-rounded values. It could\r\n // be possible to utilize the getBoundingClientRect if only it's data wasn't\r\n // affected by CSS transformations let alone paddings, borders and scroll bars.\r\n var width = toFloat(styles.width), height = toFloat(styles.height);\r\n // Width & height include paddings and borders when the 'border-box' box\r\n // model is applied (except for IE).\r\n if (styles.boxSizing === 'border-box') {\r\n // Following conditions are required to handle Internet Explorer which\r\n // doesn't include paddings and borders to computed CSS dimensions.\r\n //\r\n // We can say that if CSS dimensions + paddings are equal to the \"client\"\r\n // properties then it's either IE, and thus we don't need to subtract\r\n // anything, or an element merely doesn't have paddings/borders styles.\r\n if (Math.round(width + horizPad) !== clientWidth) {\r\n width -= getBordersSize(styles, 'left', 'right') + horizPad;\r\n }\r\n if (Math.round(height + vertPad) !== clientHeight) {\r\n height -= getBordersSize(styles, 'top', 'bottom') + vertPad;\r\n }\r\n }\r\n // Following steps can't be applied to the document's root element as its\r\n // client[Width/Height] properties represent viewport area of the window.\r\n // Besides, it's as well not necessary as the itself neither has\r\n // rendered scroll bars nor it can be clipped.\r\n if (!isDocumentElement(target)) {\r\n // In some browsers (only in Firefox, actually) CSS width & height\r\n // include scroll bars size which can be removed at this step as scroll\r\n // bars are the only difference between rounded dimensions + paddings\r\n // and \"client\" properties, though that is not always true in Chrome.\r\n var vertScrollbar = Math.round(width + horizPad) - clientWidth;\r\n var horizScrollbar = Math.round(height + vertPad) - clientHeight;\r\n // Chrome has a rather weird rounding of \"client\" properties.\r\n // E.g. for an element with content width of 314.2px it sometimes gives\r\n // the client width of 315px and for the width of 314.7px it may give\r\n // 314px. And it doesn't happen all the time. So just ignore this delta\r\n // as a non-relevant.\r\n if (Math.abs(vertScrollbar) !== 1) {\r\n width -= vertScrollbar;\r\n }\r\n if (Math.abs(horizScrollbar) !== 1) {\r\n height -= horizScrollbar;\r\n }\r\n }\r\n return createRectInit(paddings.left, paddings.top, width, height);\r\n}\r\n/**\r\n * Checks whether provided element is an instance of the SVGGraphicsElement.\r\n *\r\n * @param {Element} target - Element to be checked.\r\n * @returns {boolean}\r\n */\r\nvar isSVGGraphicsElement = (function () {\r\n // Some browsers, namely IE and Edge, don't have the SVGGraphicsElement\r\n // interface.\r\n if (typeof SVGGraphicsElement !== 'undefined') {\r\n return function (target) { return target instanceof getWindowOf(target).SVGGraphicsElement; };\r\n }\r\n // If it's so, then check that element is at least an instance of the\r\n // SVGElement and that it has the \"getBBox\" method.\r\n // eslint-disable-next-line no-extra-parens\r\n return function (target) { return (target instanceof getWindowOf(target).SVGElement &&\r\n typeof target.getBBox === 'function'); };\r\n})();\r\n/**\r\n * Checks whether provided element is a document element ().\r\n *\r\n * @param {Element} target - Element to be checked.\r\n * @returns {boolean}\r\n */\r\nfunction isDocumentElement(target) {\r\n return target === getWindowOf(target).document.documentElement;\r\n}\r\n/**\r\n * Calculates an appropriate content rectangle for provided html or svg element.\r\n *\r\n * @param {Element} target - Element content rectangle of which needs to be calculated.\r\n * @returns {DOMRectInit}\r\n */\r\nfunction getContentRect(target) {\r\n if (!isBrowser) {\r\n return emptyRect;\r\n }\r\n if (isSVGGraphicsElement(target)) {\r\n return getSVGContentRect(target);\r\n }\r\n return getHTMLElementContentRect(target);\r\n}\r\n/**\r\n * Creates rectangle with an interface of the DOMRectReadOnly.\r\n * Spec: https://drafts.fxtf.org/geometry/#domrectreadonly\r\n *\r\n * @param {DOMRectInit} rectInit - Object with rectangle's x/y coordinates and dimensions.\r\n * @returns {DOMRectReadOnly}\r\n */\r\nfunction createReadOnlyRect(_a) {\r\n var x = _a.x, y = _a.y, width = _a.width, height = _a.height;\r\n // If DOMRectReadOnly is available use it as a prototype for the rectangle.\r\n var Constr = typeof DOMRectReadOnly !== 'undefined' ? DOMRectReadOnly : Object;\r\n var rect = Object.create(Constr.prototype);\r\n // Rectangle's properties are not writable and non-enumerable.\r\n defineConfigurable(rect, {\r\n x: x, y: y, width: width, height: height,\r\n top: y,\r\n right: x + width,\r\n bottom: height + y,\r\n left: x\r\n });\r\n return rect;\r\n}\r\n/**\r\n * Creates DOMRectInit object based on the provided dimensions and the x/y coordinates.\r\n * Spec: https://drafts.fxtf.org/geometry/#dictdef-domrectinit\r\n *\r\n * @param {number} x - X coordinate.\r\n * @param {number} y - Y coordinate.\r\n * @param {number} width - Rectangle's width.\r\n * @param {number} height - Rectangle's height.\r\n * @returns {DOMRectInit}\r\n */\r\nfunction createRectInit(x, y, width, height) {\r\n return { x: x, y: y, width: width, height: height };\r\n}\n\n/**\r\n * Class that is responsible for computations of the content rectangle of\r\n * provided DOM element and for keeping track of it's changes.\r\n */\r\nvar ResizeObservation = /** @class */ (function () {\r\n /**\r\n * Creates an instance of ResizeObservation.\r\n *\r\n * @param {Element} target - Element to be observed.\r\n */\r\n function ResizeObservation(target) {\r\n /**\r\n * Broadcasted width of content rectangle.\r\n *\r\n * @type {number}\r\n */\r\n this.broadcastWidth = 0;\r\n /**\r\n * Broadcasted height of content rectangle.\r\n *\r\n * @type {number}\r\n */\r\n this.broadcastHeight = 0;\r\n /**\r\n * Reference to the last observed content rectangle.\r\n *\r\n * @private {DOMRectInit}\r\n */\r\n this.contentRect_ = createRectInit(0, 0, 0, 0);\r\n this.target = target;\r\n }\r\n /**\r\n * Updates content rectangle and tells whether it's width or height properties\r\n * have changed since the last broadcast.\r\n *\r\n * @returns {boolean}\r\n */\r\n ResizeObservation.prototype.isActive = function () {\r\n var rect = getContentRect(this.target);\r\n this.contentRect_ = rect;\r\n return (rect.width !== this.broadcastWidth ||\r\n rect.height !== this.broadcastHeight);\r\n };\r\n /**\r\n * Updates 'broadcastWidth' and 'broadcastHeight' properties with a data\r\n * from the corresponding properties of the last observed content rectangle.\r\n *\r\n * @returns {DOMRectInit} Last observed content rectangle.\r\n */\r\n ResizeObservation.prototype.broadcastRect = function () {\r\n var rect = this.contentRect_;\r\n this.broadcastWidth = rect.width;\r\n this.broadcastHeight = rect.height;\r\n return rect;\r\n };\r\n return ResizeObservation;\r\n}());\n\nvar ResizeObserverEntry = /** @class */ (function () {\r\n /**\r\n * Creates an instance of ResizeObserverEntry.\r\n *\r\n * @param {Element} target - Element that is being observed.\r\n * @param {DOMRectInit} rectInit - Data of the element's content rectangle.\r\n */\r\n function ResizeObserverEntry(target, rectInit) {\r\n var contentRect = createReadOnlyRect(rectInit);\r\n // According to the specification following properties are not writable\r\n // and are also not enumerable in the native implementation.\r\n //\r\n // Property accessors are not being used as they'd require to define a\r\n // private WeakMap storage which may cause memory leaks in browsers that\r\n // don't support this type of collections.\r\n defineConfigurable(this, { target: target, contentRect: contentRect });\r\n }\r\n return ResizeObserverEntry;\r\n}());\n\nvar ResizeObserverSPI = /** @class */ (function () {\r\n /**\r\n * Creates a new instance of ResizeObserver.\r\n *\r\n * @param {ResizeObserverCallback} callback - Callback function that is invoked\r\n * when one of the observed elements changes it's content dimensions.\r\n * @param {ResizeObserverController} controller - Controller instance which\r\n * is responsible for the updates of observer.\r\n * @param {ResizeObserver} callbackCtx - Reference to the public\r\n * ResizeObserver instance which will be passed to callback function.\r\n */\r\n function ResizeObserverSPI(callback, controller, callbackCtx) {\r\n /**\r\n * Collection of resize observations that have detected changes in dimensions\r\n * of elements.\r\n *\r\n * @private {Array}\r\n */\r\n this.activeObservations_ = [];\r\n /**\r\n * Registry of the ResizeObservation instances.\r\n *\r\n * @private {Map}\r\n */\r\n this.observations_ = new MapShim();\r\n if (typeof callback !== 'function') {\r\n throw new TypeError('The callback provided as parameter 1 is not a function.');\r\n }\r\n this.callback_ = callback;\r\n this.controller_ = controller;\r\n this.callbackCtx_ = callbackCtx;\r\n }\r\n /**\r\n * Starts observing provided element.\r\n *\r\n * @param {Element} target - Element to be observed.\r\n * @returns {void}\r\n */\r\n ResizeObserverSPI.prototype.observe = function (target) {\r\n if (!arguments.length) {\r\n throw new TypeError('1 argument required, but only 0 present.');\r\n }\r\n // Do nothing if current environment doesn't have the Element interface.\r\n if (typeof Element === 'undefined' || !(Element instanceof Object)) {\r\n return;\r\n }\r\n if (!(target instanceof getWindowOf(target).Element)) {\r\n throw new TypeError('parameter 1 is not of type \"Element\".');\r\n }\r\n var observations = this.observations_;\r\n // Do nothing if element is already being observed.\r\n if (observations.has(target)) {\r\n return;\r\n }\r\n observations.set(target, new ResizeObservation(target));\r\n this.controller_.addObserver(this);\r\n // Force the update of observations.\r\n this.controller_.refresh();\r\n };\r\n /**\r\n * Stops observing provided element.\r\n *\r\n * @param {Element} target - Element to stop observing.\r\n * @returns {void}\r\n */\r\n ResizeObserverSPI.prototype.unobserve = function (target) {\r\n if (!arguments.length) {\r\n throw new TypeError('1 argument required, but only 0 present.');\r\n }\r\n // Do nothing if current environment doesn't have the Element interface.\r\n if (typeof Element === 'undefined' || !(Element instanceof Object)) {\r\n return;\r\n }\r\n if (!(target instanceof getWindowOf(target).Element)) {\r\n throw new TypeError('parameter 1 is not of type \"Element\".');\r\n }\r\n var observations = this.observations_;\r\n // Do nothing if element is not being observed.\r\n if (!observations.has(target)) {\r\n return;\r\n }\r\n observations.delete(target);\r\n if (!observations.size) {\r\n this.controller_.removeObserver(this);\r\n }\r\n };\r\n /**\r\n * Stops observing all elements.\r\n *\r\n * @returns {void}\r\n */\r\n ResizeObserverSPI.prototype.disconnect = function () {\r\n this.clearActive();\r\n this.observations_.clear();\r\n this.controller_.removeObserver(this);\r\n };\r\n /**\r\n * Collects observation instances the associated element of which has changed\r\n * it's content rectangle.\r\n *\r\n * @returns {void}\r\n */\r\n ResizeObserverSPI.prototype.gatherActive = function () {\r\n var _this = this;\r\n this.clearActive();\r\n this.observations_.forEach(function (observation) {\r\n if (observation.isActive()) {\r\n _this.activeObservations_.push(observation);\r\n }\r\n });\r\n };\r\n /**\r\n * Invokes initial callback function with a list of ResizeObserverEntry\r\n * instances collected from active resize observations.\r\n *\r\n * @returns {void}\r\n */\r\n ResizeObserverSPI.prototype.broadcastActive = function () {\r\n // Do nothing if observer doesn't have active observations.\r\n if (!this.hasActive()) {\r\n return;\r\n }\r\n var ctx = this.callbackCtx_;\r\n // Create ResizeObserverEntry instance for every active observation.\r\n var entries = this.activeObservations_.map(function (observation) {\r\n return new ResizeObserverEntry(observation.target, observation.broadcastRect());\r\n });\r\n this.callback_.call(ctx, entries, ctx);\r\n this.clearActive();\r\n };\r\n /**\r\n * Clears the collection of active observations.\r\n *\r\n * @returns {void}\r\n */\r\n ResizeObserverSPI.prototype.clearActive = function () {\r\n this.activeObservations_.splice(0);\r\n };\r\n /**\r\n * Tells whether observer has active observations.\r\n *\r\n * @returns {boolean}\r\n */\r\n ResizeObserverSPI.prototype.hasActive = function () {\r\n return this.activeObservations_.length > 0;\r\n };\r\n return ResizeObserverSPI;\r\n}());\n\n// Registry of internal observers. If WeakMap is not available use current shim\r\n// for the Map collection as it has all required methods and because WeakMap\r\n// can't be fully polyfilled anyway.\r\nvar observers = typeof WeakMap !== 'undefined' ? new WeakMap() : new MapShim();\r\n/**\r\n * ResizeObserver API. Encapsulates the ResizeObserver SPI implementation\r\n * exposing only those methods and properties that are defined in the spec.\r\n */\r\nvar ResizeObserver = /** @class */ (function () {\r\n /**\r\n * Creates a new instance of ResizeObserver.\r\n *\r\n * @param {ResizeObserverCallback} callback - Callback that is invoked when\r\n * dimensions of the observed elements change.\r\n */\r\n function ResizeObserver(callback) {\r\n if (!(this instanceof ResizeObserver)) {\r\n throw new TypeError('Cannot call a class as a function.');\r\n }\r\n if (!arguments.length) {\r\n throw new TypeError('1 argument required, but only 0 present.');\r\n }\r\n var controller = ResizeObserverController.getInstance();\r\n var observer = new ResizeObserverSPI(callback, controller, this);\r\n observers.set(this, observer);\r\n }\r\n return ResizeObserver;\r\n}());\r\n// Expose public methods of ResizeObserver.\r\n[\r\n 'observe',\r\n 'unobserve',\r\n 'disconnect'\r\n].forEach(function (method) {\r\n ResizeObserver.prototype[method] = function () {\r\n var _a;\r\n return (_a = observers.get(this))[method].apply(_a, arguments);\r\n };\r\n});\n\nvar index = (function () {\r\n // Export existing implementation if available.\r\n if (typeof global$1.ResizeObserver !== 'undefined') {\r\n return global$1.ResizeObserver;\r\n }\r\n return ResizeObserver;\r\n})();\n\nexport default index;\n","import contains from '../vc-util/Dom/contains';\nimport ResizeObserver from 'resize-observer-polyfill';\nexport function isSamePoint(prev, next) {\n if (prev === next) return true;\n if (!prev || !next) return false;\n if ('pageX' in next && 'pageY' in next) {\n return prev.pageX === next.pageX && prev.pageY === next.pageY;\n }\n if ('clientX' in next && 'clientY' in next) {\n return prev.clientX === next.clientX && prev.clientY === next.clientY;\n }\n return false;\n}\nexport function restoreFocus(activeElement, container) {\n // Focus back if is in the container\n if (activeElement !== document.activeElement && contains(container, activeElement) && typeof activeElement.focus === 'function') {\n activeElement.focus();\n }\n}\nexport function monitorResize(element, callback) {\n let prevWidth = null;\n let prevHeight = null;\n function onResize(_ref) {\n let [{\n target\n }] = _ref;\n if (!document.documentElement.contains(target)) return;\n const {\n width,\n height\n } = target.getBoundingClientRect();\n const fixedWidth = Math.floor(width);\n const fixedHeight = Math.floor(height);\n if (prevWidth !== fixedWidth || prevHeight !== fixedHeight) {\n // https://webkit.org/blog/9997/resizeobserver-in-webkit/\n Promise.resolve().then(() => {\n callback({\n width: fixedWidth,\n height: fixedHeight\n });\n });\n }\n prevWidth = fixedWidth;\n prevHeight = fixedHeight;\n }\n const resizeObserver = new ResizeObserver(onResize);\n if (element) {\n resizeObserver.observe(element);\n }\n return () => {\n resizeObserver.disconnect();\n };\n}","export default ((callback, buffer) => {\n let called = false;\n let timeout = null;\n function cancelTrigger() {\n clearTimeout(timeout);\n }\n function trigger(force) {\n if (!called || force === true) {\n if (callback() === false) {\n // Not delay since callback cancelled self\n return;\n }\n called = true;\n cancelTrigger();\n timeout = setTimeout(() => {\n called = false;\n }, buffer.value);\n } else {\n cancelTrigger();\n timeout = setTimeout(() => {\n called = false;\n trigger();\n }, buffer.value);\n }\n }\n return [trigger, () => {\n called = false;\n cancelTrigger();\n }];\n});","import { nextTick, defineComponent, ref, computed, onMounted, onUpdated, watch, onUnmounted } from 'vue';\nimport { alignElement, alignPoint } from 'dom-align';\nimport addEventListener from '../vc-util/Dom/addEventListener';\nimport { cloneElement } from '../_util/vnode';\nimport isVisible from '../vc-util/Dom/isVisible';\nimport { isSamePoint, restoreFocus, monitorResize } from './util';\nimport useBuffer from './hooks/useBuffer';\nimport isEqual from 'lodash-es/isEqual';\nexport const alignProps = {\n align: Object,\n target: [Object, Function],\n onAlign: Function,\n monitorBufferTime: Number,\n monitorWindowResize: Boolean,\n disabled: Boolean\n};\nfunction getElement(func) {\n if (typeof func !== 'function') return null;\n return func();\n}\nfunction getPoint(point) {\n if (typeof point !== 'object' || !point) return null;\n return point;\n}\nexport default defineComponent({\n compatConfig: {\n MODE: 3\n },\n name: 'Align',\n props: alignProps,\n emits: ['align'],\n setup(props, _ref) {\n let {\n expose,\n slots\n } = _ref;\n const cacheRef = ref({});\n const nodeRef = ref();\n const [forceAlign, cancelForceAlign] = useBuffer(() => {\n const {\n disabled: latestDisabled,\n target: latestTarget,\n align: latestAlign,\n onAlign: latestOnAlign\n } = props;\n if (!latestDisabled && latestTarget && nodeRef.value) {\n const source = nodeRef.value;\n let result;\n const element = getElement(latestTarget);\n const point = getPoint(latestTarget);\n cacheRef.value.element = element;\n cacheRef.value.point = point;\n cacheRef.value.align = latestAlign;\n // IE lose focus after element realign\n // We should record activeElement and restore later\n const {\n activeElement\n } = document;\n // We only align when element is visible\n if (element && isVisible(element)) {\n result = alignElement(source, element, latestAlign);\n } else if (point) {\n result = alignPoint(source, point, latestAlign);\n }\n restoreFocus(activeElement, source);\n if (latestOnAlign && result) {\n latestOnAlign(source, result);\n }\n return true;\n }\n return false;\n }, computed(() => props.monitorBufferTime));\n // ===================== Effect =====================\n // Listen for target updated\n const resizeMonitor = ref({\n cancel: () => {}\n });\n // Listen for source updated\n const sourceResizeMonitor = ref({\n cancel: () => {}\n });\n const goAlign = () => {\n const target = props.target;\n const element = getElement(target);\n const point = getPoint(target);\n if (nodeRef.value !== sourceResizeMonitor.value.element) {\n sourceResizeMonitor.value.cancel();\n sourceResizeMonitor.value.element = nodeRef.value;\n sourceResizeMonitor.value.cancel = monitorResize(nodeRef.value, forceAlign);\n }\n if (cacheRef.value.element !== element || !isSamePoint(cacheRef.value.point, point) || !isEqual(cacheRef.value.align, props.align)) {\n forceAlign();\n // Add resize observer\n if (resizeMonitor.value.element !== element) {\n resizeMonitor.value.cancel();\n resizeMonitor.value.element = element;\n resizeMonitor.value.cancel = monitorResize(element, forceAlign);\n }\n }\n };\n onMounted(() => {\n nextTick(() => {\n goAlign();\n });\n });\n onUpdated(() => {\n nextTick(() => {\n goAlign();\n });\n });\n // Listen for disabled change\n watch(() => props.disabled, disabled => {\n if (!disabled) {\n forceAlign();\n } else {\n cancelForceAlign();\n }\n }, {\n immediate: true,\n flush: 'post'\n });\n // Listen for window resize\n const winResizeRef = ref(null);\n watch(() => props.monitorWindowResize, monitorWindowResize => {\n if (monitorWindowResize) {\n if (!winResizeRef.value) {\n winResizeRef.value = addEventListener(window, 'resize', forceAlign);\n }\n } else if (winResizeRef.value) {\n winResizeRef.value.remove();\n winResizeRef.value = null;\n }\n }, {\n flush: 'post'\n });\n onUnmounted(() => {\n resizeMonitor.value.cancel();\n sourceResizeMonitor.value.cancel();\n if (winResizeRef.value) winResizeRef.value.remove();\n cancelForceAlign();\n });\n expose({\n forceAlign: () => forceAlign(true)\n });\n return () => {\n const child = slots === null || slots === void 0 ? void 0 : slots.default();\n if (child) {\n return cloneElement(child[0], {\n ref: nodeRef\n }, true, true);\n }\n return null;\n };\n }\n});","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport { nextTick, Transition, TransitionGroup } from 'vue';\nimport { tuple } from './type';\nconst SelectPlacements = tuple('bottomLeft', 'bottomRight', 'topLeft', 'topRight');\nconst getTransitionDirection = placement => {\n if (placement !== undefined && (placement === 'topLeft' || placement === 'topRight')) {\n return `slide-down`;\n }\n return `slide-up`;\n};\nexport const getTransitionProps = function (transitionName) {\n let opt = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n const transitionProps = transitionName ? _extends({\n name: transitionName,\n appear: true,\n // type: 'animation',\n // appearFromClass: `${transitionName}-appear ${transitionName}-appear-prepare`,\n // appearActiveClass: `antdv-base-transtion`,\n // appearToClass: `${transitionName}-appear ${transitionName}-appear-active`,\n enterFromClass: `${transitionName}-enter ${transitionName}-enter-prepare ${transitionName}-enter-start`,\n enterActiveClass: `${transitionName}-enter ${transitionName}-enter-prepare`,\n enterToClass: `${transitionName}-enter ${transitionName}-enter-active`,\n leaveFromClass: ` ${transitionName}-leave`,\n leaveActiveClass: `${transitionName}-leave ${transitionName}-leave-active`,\n leaveToClass: `${transitionName}-leave ${transitionName}-leave-active`\n }, opt) : _extends({\n css: false\n }, opt);\n return transitionProps;\n};\nexport const getTransitionGroupProps = function (transitionName) {\n let opt = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n const transitionProps = transitionName ? _extends({\n name: transitionName,\n appear: true,\n // appearFromClass: `${transitionName}-appear ${transitionName}-appear-prepare`,\n appearActiveClass: `${transitionName}`,\n appearToClass: `${transitionName}-appear ${transitionName}-appear-active`,\n enterFromClass: `${transitionName}-appear ${transitionName}-enter ${transitionName}-appear-prepare ${transitionName}-enter-prepare`,\n enterActiveClass: `${transitionName}`,\n enterToClass: `${transitionName}-enter ${transitionName}-appear ${transitionName}-appear-active ${transitionName}-enter-active`,\n leaveActiveClass: `${transitionName} ${transitionName}-leave`,\n leaveToClass: `${transitionName}-leave-active`\n }, opt) : _extends({\n css: false\n }, opt);\n return transitionProps;\n};\n// ================== Collapse Motion ==================\nconst getCollapsedHeight = () => ({\n height: 0,\n opacity: 0\n});\nconst getRealHeight = node => ({\n height: `${node.scrollHeight}px`,\n opacity: 1\n});\nconst getCurrentHeight = node => ({\n height: `${node.offsetHeight}px`\n});\nconst collapseMotion = function () {\n let name = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'ant-motion-collapse';\n let style = arguments.length > 1 ? arguments[1] : undefined;\n let className = arguments.length > 2 ? arguments[2] : undefined;\n return {\n name,\n appear: true,\n css: true,\n onBeforeEnter: node => {\n className.value = name;\n style.value = getCollapsedHeight(node);\n },\n onEnter: node => {\n nextTick(() => {\n style.value = getRealHeight(node);\n });\n },\n onAfterEnter: () => {\n className.value = '';\n style.value = {};\n },\n onBeforeLeave: node => {\n className.value = name;\n style.value = getCurrentHeight(node);\n },\n onLeave: node => {\n setTimeout(() => {\n style.value = getCollapsedHeight(node);\n });\n },\n onAfterLeave: () => {\n className.value = '';\n style.value = {};\n }\n };\n};\nconst getTransitionName = (rootPrefixCls, motion, transitionName) => {\n if (transitionName !== undefined) {\n return transitionName;\n }\n return `${rootPrefixCls}-${motion}`;\n};\nexport { Transition, TransitionGroup, collapseMotion, getTransitionName, getTransitionDirection };\nexport default Transition;","import _objectSpread from \"@babel/runtime/helpers/esm/objectSpread2\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport { withDirectives as _withDirectives, resolveDirective as _resolveDirective, vShow as _vShow, createVNode as _createVNode } from \"vue\";\nimport useVisibleStatus from './useVisibleStatus';\nimport useStretchStyle from './useStretchStyle';\nimport { computed, defineComponent, shallowRef, toRef, Transition, watch, withModifiers } from 'vue';\nimport Align from '../../vc-align/Align';\nimport { getMotion } from '../utils/motionUtil';\nimport { flattenChildren } from '../../_util/props-util';\nimport classNames from '../../_util/classNames';\nimport { innerProps } from './interface';\nimport { getTransitionProps } from '../../_util/transition';\nimport supportsPassive from '../../_util/supportsPassive';\nexport default defineComponent({\n compatConfig: {\n MODE: 3\n },\n name: 'PopupInner',\n inheritAttrs: false,\n props: innerProps,\n emits: ['mouseenter', 'mouseleave', 'mousedown', 'touchstart', 'align'],\n setup(props, _ref) {\n let {\n expose,\n attrs,\n slots\n } = _ref;\n const alignRef = shallowRef();\n const elementRef = shallowRef();\n const alignedClassName = shallowRef();\n // ======================= Measure ========================\n const [stretchStyle, measureStretchStyle] = useStretchStyle(toRef(props, 'stretch'));\n const doMeasure = () => {\n if (props.stretch) {\n measureStretchStyle(props.getRootDomNode());\n }\n };\n const visible = shallowRef(false);\n let timeoutId;\n watch(() => props.visible, val => {\n clearTimeout(timeoutId);\n if (val) {\n timeoutId = setTimeout(() => {\n visible.value = props.visible;\n });\n } else {\n visible.value = false;\n }\n }, {\n immediate: true\n });\n // ======================== Status ========================\n const [status, goNextStatus] = useVisibleStatus(visible, doMeasure);\n // ======================== Aligns ========================\n const prepareResolveRef = shallowRef();\n // `target` on `rc-align` can accept as a function to get the bind element or a point.\n // ref: https://www.npmjs.com/package/rc-align\n const getAlignTarget = () => {\n if (props.point) {\n return props.point;\n }\n return props.getRootDomNode;\n };\n const forceAlign = () => {\n var _a;\n (_a = alignRef.value) === null || _a === void 0 ? void 0 : _a.forceAlign();\n };\n const onInternalAlign = (popupDomNode, matchAlign) => {\n var _a;\n const nextAlignedClassName = props.getClassNameFromAlign(matchAlign);\n const preAlignedClassName = alignedClassName.value;\n if (alignedClassName.value !== nextAlignedClassName) {\n alignedClassName.value = nextAlignedClassName;\n }\n if (status.value === 'align') {\n // Repeat until not more align needed\n if (preAlignedClassName !== nextAlignedClassName) {\n Promise.resolve().then(() => {\n forceAlign();\n });\n } else {\n goNextStatus(() => {\n var _a;\n (_a = prepareResolveRef.value) === null || _a === void 0 ? void 0 : _a.call(prepareResolveRef);\n });\n }\n (_a = props.onAlign) === null || _a === void 0 ? void 0 : _a.call(props, popupDomNode, matchAlign);\n }\n };\n // ======================== Motion ========================\n const motion = computed(() => {\n const m = typeof props.animation === 'object' ? props.animation : getMotion(props);\n ['onAfterEnter', 'onAfterLeave'].forEach(eventName => {\n const originFn = m[eventName];\n m[eventName] = node => {\n goNextStatus();\n // 结束后,强制 stable\n status.value = 'stable';\n originFn === null || originFn === void 0 ? void 0 : originFn(node);\n };\n });\n return m;\n });\n const onShowPrepare = () => {\n return new Promise(resolve => {\n prepareResolveRef.value = resolve;\n });\n };\n watch([motion, status], () => {\n if (!motion.value && status.value === 'motion') {\n goNextStatus();\n }\n }, {\n immediate: true\n });\n expose({\n forceAlign,\n getElement: () => {\n return elementRef.value.$el || elementRef.value;\n }\n });\n const alignDisabled = computed(() => {\n var _a;\n if (((_a = props.align) === null || _a === void 0 ? void 0 : _a.points) && (status.value === 'align' || status.value === 'stable')) {\n return false;\n }\n return true;\n });\n return () => {\n var _a;\n const {\n zIndex,\n align,\n prefixCls,\n destroyPopupOnHide,\n onMouseenter,\n onMouseleave,\n onTouchstart = () => {},\n onMousedown\n } = props;\n const statusValue = status.value;\n // ======================== Render ========================\n const mergedStyle = [_extends(_extends({}, stretchStyle.value), {\n zIndex,\n opacity: statusValue === 'motion' || statusValue === 'stable' || !visible.value ? null : 0,\n // pointerEvents: statusValue === 'stable' ? null : 'none',\n pointerEvents: !visible.value && statusValue !== 'stable' ? 'none' : null\n }), attrs.style];\n let childNode = flattenChildren((_a = slots.default) === null || _a === void 0 ? void 0 : _a.call(slots, {\n visible: props.visible\n }));\n // Wrapper when multiple children\n if (childNode.length > 1) {\n const _childNode = function () {\n return childNode;\n }();\n childNode = _createVNode(\"div\", {\n \"class\": `${prefixCls}-content`\n }, [childNode]);\n }\n const mergedClassName = classNames(prefixCls, attrs.class, alignedClassName.value);\n const hasAnimate = visible.value || !props.visible;\n const transitionProps = hasAnimate ? getTransitionProps(motion.value.name, motion.value) : {};\n return _createVNode(Transition, _objectSpread(_objectSpread({\n \"ref\": elementRef\n }, transitionProps), {}, {\n \"onBeforeEnter\": onShowPrepare\n }), {\n default: () => {\n return !destroyPopupOnHide || props.visible ? _withDirectives(_createVNode(Align, {\n \"target\": getAlignTarget(),\n \"key\": \"popup\",\n \"ref\": alignRef,\n \"monitorWindowResize\": true,\n \"disabled\": alignDisabled.value,\n \"align\": align,\n \"onAlign\": onInternalAlign\n }, {\n default: () => _createVNode(\"div\", {\n \"class\": mergedClassName,\n \"onMouseenter\": onMouseenter,\n \"onMouseleave\": onMouseleave,\n \"onMousedown\": withModifiers(onMousedown, ['capture']),\n [supportsPassive ? 'onTouchstartPassive' : 'onTouchstart']: withModifiers(onTouchstart, ['capture']),\n \"style\": mergedStyle\n }, [childNode])\n }), [[_vShow, visible.value]]) : null;\n }\n });\n };\n }\n});","import _objectSpread from \"@babel/runtime/helpers/esm/objectSpread2\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport { createVNode as _createVNode, resolveDirective as _resolveDirective } from \"vue\";\nimport { defineComponent, shallowRef, watch } from 'vue';\nimport { popupProps } from './interface';\nimport Mask from './Mask';\nimport MobilePopupInner from './MobilePopupInner';\nimport PopupInner from './PopupInner';\nexport default defineComponent({\n compatConfig: {\n MODE: 3\n },\n name: 'Popup',\n inheritAttrs: false,\n props: popupProps,\n setup(props, _ref) {\n let {\n attrs,\n slots,\n expose\n } = _ref;\n const innerVisible = shallowRef(false);\n const inMobile = shallowRef(false);\n const popupRef = shallowRef();\n const rootRef = shallowRef();\n watch([() => props.visible, () => props.mobile], () => {\n innerVisible.value = props.visible;\n if (props.visible && props.mobile) {\n inMobile.value = true;\n }\n }, {\n immediate: true,\n flush: 'post'\n });\n expose({\n forceAlign: () => {\n var _a;\n (_a = popupRef.value) === null || _a === void 0 ? void 0 : _a.forceAlign();\n },\n getElement: () => {\n var _a;\n return (_a = popupRef.value) === null || _a === void 0 ? void 0 : _a.getElement();\n }\n });\n return () => {\n const cloneProps = _extends(_extends(_extends({}, props), attrs), {\n visible: innerVisible.value\n });\n const popupNode = inMobile.value ? _createVNode(MobilePopupInner, _objectSpread(_objectSpread({}, cloneProps), {}, {\n \"mobile\": props.mobile,\n \"ref\": popupRef\n }), {\n default: slots.default\n }) : _createVNode(PopupInner, _objectSpread(_objectSpread({}, cloneProps), {}, {\n \"ref\": popupRef\n }), {\n default: slots.default\n });\n return _createVNode(\"div\", {\n \"ref\": rootRef\n }, [_createVNode(Mask, cloneProps, null), popupNode]);\n };\n }\n});","import _extends from \"@babel/runtime/helpers/esm/extends\";\nfunction isPointsEq(a1, a2, isAlignPoint) {\n if (isAlignPoint) {\n return a1[0] === a2[0];\n }\n return a1[0] === a2[0] && a1[1] === a2[1];\n}\nexport function getAlignFromPlacement(builtinPlacements, placementStr, align) {\n const baseAlign = builtinPlacements[placementStr] || {};\n return _extends(_extends({}, baseAlign), align);\n}\nexport function getAlignPopupClassName(builtinPlacements, prefixCls, align, isAlignPoint) {\n const {\n points\n } = align;\n const placements = Object.keys(builtinPlacements);\n for (let i = 0; i < placements.length; i += 1) {\n const placement = placements[i];\n if (isPointsEq(builtinPlacements[placement].points, points, isAlignPoint)) {\n return `${prefixCls}-placement-${placement}`;\n }\n }\n return '';\n}","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport { nextTick } from 'vue';\nimport { getOptionProps } from './props-util';\nexport default {\n methods: {\n setState() {\n let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n let callback = arguments.length > 1 ? arguments[1] : undefined;\n let newState = typeof state === 'function' ? state(this.$data, this.$props) : state;\n if (this.getDerivedStateFromProps) {\n const s = this.getDerivedStateFromProps(getOptionProps(this), _extends(_extends({}, this.$data), newState));\n if (s === null) {\n return;\n } else {\n newState = _extends(_extends({}, newState), s || {});\n }\n }\n _extends(this.$data, newState);\n if (this._.isMounted) {\n this.$forceUpdate();\n }\n nextTick(() => {\n callback && callback();\n });\n },\n __emit() {\n // 直接调用事件,底层组件不需要vueTool记录events\n // eslint-disable-next-line prefer-rest-params\n const args = [].slice.call(arguments, 0);\n let eventName = args[0];\n eventName = `on${eventName[0].toUpperCase()}${eventName.substring(1)}`;\n const event = this.$props[eventName] || this.$attrs[eventName];\n if (args.length && event) {\n if (Array.isArray(event)) {\n for (let i = 0, l = event.length; i < l; i++) {\n event[i](...args.slice(1));\n }\n } else {\n event(...args.slice(1));\n }\n }\n }\n }\n};","import { computed, inject, provide } from 'vue';\nconst PortalContextKey = Symbol('PortalContextKey');\nexport const useProvidePortal = function (instance) {\n let config = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {\n inTriggerContext: true\n };\n provide(PortalContextKey, {\n inTriggerContext: config.inTriggerContext,\n shouldRender: computed(() => {\n const {\n sPopupVisible,\n popupRef,\n forceRender,\n autoDestroy\n } = instance || {};\n // if (popPortal) return true;\n let shouldRender = false;\n if (sPopupVisible || popupRef || forceRender) {\n shouldRender = true;\n }\n if (!sPopupVisible && autoDestroy) {\n shouldRender = false;\n }\n return shouldRender;\n })\n });\n};\nexport const useInjectPortal = () => {\n useProvidePortal({}, {\n inTriggerContext: false\n });\n const portalContext = inject(PortalContextKey, {\n shouldRender: computed(() => false),\n inTriggerContext: false\n });\n return {\n shouldRender: computed(() => portalContext.shouldRender.value || portalContext.inTriggerContext === false)\n };\n};","import { createVNode as _createVNode, resolveDirective as _resolveDirective } from \"vue\";\nimport PropTypes from './vue-types';\nimport { defineComponent, nextTick, onBeforeMount, onMounted, onUpdated, Teleport, watch } from 'vue';\nimport { useInjectPortal } from '../vc-trigger/context';\nexport default defineComponent({\n compatConfig: {\n MODE: 3\n },\n name: 'Portal',\n inheritAttrs: false,\n props: {\n getContainer: PropTypes.func.isRequired,\n didUpdate: Function\n },\n setup(props, _ref) {\n let {\n slots\n } = _ref;\n let isSSR = true;\n // getContainer 不会改变,不用响应式\n let container;\n const {\n shouldRender\n } = useInjectPortal();\n function setContainer() {\n if (shouldRender.value) {\n container = props.getContainer();\n }\n }\n onBeforeMount(() => {\n isSSR = false;\n // drawer\n setContainer();\n });\n onMounted(() => {\n if (container) return;\n // https://github.com/vueComponent/ant-design-vue/issues/6937\n setContainer();\n });\n const stopWatch = watch(shouldRender, () => {\n if (shouldRender.value && !container) {\n container = props.getContainer();\n }\n if (container) {\n stopWatch();\n }\n });\n onUpdated(() => {\n nextTick(() => {\n var _a;\n if (shouldRender.value) {\n (_a = props.didUpdate) === null || _a === void 0 ? void 0 : _a.call(props, props);\n }\n });\n });\n // onBeforeUnmount(() => {\n // if (container && container.parentNode) {\n // container.parentNode.removeChild(container);\n // }\n // });\n return () => {\n var _a;\n if (!shouldRender.value) return null;\n if (isSSR) {\n return (_a = slots.default) === null || _a === void 0 ? void 0 : _a.call(slots);\n }\n return container ? _createVNode(Teleport, {\n \"to\": container\n }, slots) : null;\n };\n }\n});","function canUseDom() {\n return !!(typeof window !== 'undefined' && window.document && window.document.createElement);\n}\nexport default canUseDom;","import canUseDom from '../../_util/canUseDom';\nimport contains from './contains';\nconst APPEND_ORDER = 'data-vc-order';\nconst MARK_KEY = `vc-util-key`;\nconst containerCache = new Map();\nfunction getMark() {\n let {\n mark\n } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n if (mark) {\n return mark.startsWith('data-') ? mark : `data-${mark}`;\n }\n return MARK_KEY;\n}\nfunction getContainer(option) {\n if (option.attachTo) {\n return option.attachTo;\n }\n const head = document.querySelector('head');\n return head || document.body;\n}\nfunction getOrder(prepend) {\n if (prepend === 'queue') {\n return 'prependQueue';\n }\n return prepend ? 'prepend' : 'append';\n}\n/**\n * Find style which inject by rc-util\n */\nfunction findStyles(container) {\n return Array.from((containerCache.get(container) || container).children).filter(node => node.tagName === 'STYLE');\n}\nexport function injectCSS(css) {\n let option = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n if (!canUseDom()) {\n return null;\n }\n const {\n csp,\n prepend\n } = option;\n const styleNode = document.createElement('style');\n styleNode.setAttribute(APPEND_ORDER, getOrder(prepend));\n if (csp === null || csp === void 0 ? void 0 : csp.nonce) {\n styleNode.nonce = csp === null || csp === void 0 ? void 0 : csp.nonce;\n }\n styleNode.innerHTML = css;\n const container = getContainer(option);\n const {\n firstChild\n } = container;\n if (prepend) {\n // If is queue `prepend`, it will prepend first style and then append rest style\n if (prepend === 'queue') {\n const existStyle = findStyles(container).filter(node => ['prepend', 'prependQueue'].includes(node.getAttribute(APPEND_ORDER)));\n if (existStyle.length) {\n container.insertBefore(styleNode, existStyle[existStyle.length - 1].nextSibling);\n return styleNode;\n }\n }\n // Use `insertBefore` as `prepend`\n container.insertBefore(styleNode, firstChild);\n } else {\n container.appendChild(styleNode);\n }\n return styleNode;\n}\nfunction findExistNode(key) {\n let option = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n const container = getContainer(option);\n return findStyles(container).find(node => node.getAttribute(getMark(option)) === key);\n}\nexport function removeCSS(key) {\n let option = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n const existNode = findExistNode(key, option);\n if (existNode) {\n const container = getContainer(option);\n container.removeChild(existNode);\n }\n}\n/**\n * qiankun will inject `appendChild` to insert into other\n */\nfunction syncRealContainer(container, option) {\n const cachedRealContainer = containerCache.get(container);\n // Find real container when not cached or cached container removed\n if (!cachedRealContainer || !contains(document, cachedRealContainer)) {\n const placeholderStyle = injectCSS('', option);\n const {\n parentNode\n } = placeholderStyle;\n containerCache.set(container, parentNode);\n container.removeChild(placeholderStyle);\n }\n}\n/**\n * manually clear container cache to avoid global cache in unit testes\n */\nexport function clearContainerCache() {\n containerCache.clear();\n}\nexport function updateCSS(css, key) {\n let option = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n var _a, _b, _c;\n const container = getContainer(option);\n // Sync real parent\n syncRealContainer(container, option);\n const existNode = findExistNode(key, option);\n if (existNode) {\n if (((_a = option.csp) === null || _a === void 0 ? void 0 : _a.nonce) && existNode.nonce !== ((_b = option.csp) === null || _b === void 0 ? void 0 : _b.nonce)) {\n existNode.nonce = (_c = option.csp) === null || _c === void 0 ? void 0 : _c.nonce;\n }\n if (existNode.innerHTML !== css) {\n existNode.innerHTML = css;\n }\n return existNode;\n }\n const newNode = injectCSS(css, option);\n newNode.setAttribute(getMark(option), key);\n return newNode;\n}","/* eslint-disable no-param-reassign */\nlet cached;\nexport default function getScrollBarSize(fresh) {\n if (typeof document === 'undefined') {\n return 0;\n }\n if (fresh || cached === undefined) {\n const inner = document.createElement('div');\n inner.style.width = '100%';\n inner.style.height = '200px';\n const outer = document.createElement('div');\n const outerStyle = outer.style;\n outerStyle.position = 'absolute';\n outerStyle.top = '0';\n outerStyle.left = '0';\n outerStyle.pointerEvents = 'none';\n outerStyle.visibility = 'hidden';\n outerStyle.width = '200px';\n outerStyle.height = '150px';\n outerStyle.overflow = 'hidden';\n outer.appendChild(inner);\n document.body.appendChild(outer);\n const widthContained = inner.offsetWidth;\n outer.style.overflow = 'scroll';\n let widthScroll = inner.offsetWidth;\n if (widthContained === widthScroll) {\n widthScroll = outer.clientWidth;\n }\n document.body.removeChild(outer);\n cached = widthContained - widthScroll;\n }\n return cached;\n}\nfunction ensureSize(str) {\n const match = str.match(/^(.*)px$/);\n const value = Number(match === null || match === void 0 ? void 0 : match[1]);\n return Number.isNaN(value) ? getScrollBarSize() : value;\n}\nexport function getTargetScrollBarSize(target) {\n if (typeof document === 'undefined' || !target || !(target instanceof Element)) {\n return {\n width: 0,\n height: 0\n };\n }\n const {\n width,\n height\n } = getComputedStyle(target, '::-webkit-scrollbar');\n return {\n width: ensureSize(width),\n height: ensureSize(height)\n };\n}","import { computed, watchEffect } from 'vue';\nimport { updateCSS, removeCSS } from '../../vc-util/Dom/dynamicCSS';\nimport getScrollBarSize from '../../_util/getScrollBarSize';\nimport canUseDom from '../../_util/canUseDom';\nconst UNIQUE_ID = `vc-util-locker-${Date.now()}`;\nlet uuid = 0;\n/**../vc-util/Dom/dynam\n * Test usage export. Do not use in your production\n */\nexport function isBodyOverflowing() {\n return document.body.scrollHeight > (window.innerHeight || document.documentElement.clientHeight) && window.innerWidth > document.body.offsetWidth;\n}\nexport default function useScrollLocker(lock) {\n const mergedLock = computed(() => !!lock && !!lock.value);\n uuid += 1;\n const id = `${UNIQUE_ID}_${uuid}`;\n watchEffect(onClear => {\n if (!canUseDom()) {\n return;\n }\n if (mergedLock.value) {\n const scrollbarSize = getScrollBarSize();\n const isOverflow = isBodyOverflowing();\n updateCSS(`\nhtml body {\n overflow-y: hidden;\n ${isOverflow ? `width: calc(100% - ${scrollbarSize}px);` : ''}\n}`, id);\n } else {\n removeCSS(id);\n }\n onClear(() => {\n removeCSS(id);\n });\n }, {\n flush: 'post'\n });\n}","import { createVNode as _createVNode, resolveDirective as _resolveDirective } from \"vue\";\nimport PropTypes from './vue-types';\nimport Portal from './Portal';\nimport { defineComponent, shallowRef, watch, onMounted, onBeforeUnmount, onUpdated, nextTick, computed } from 'vue';\nimport canUseDom from './canUseDom';\nimport raf from './raf';\nimport { booleanType } from './type';\nimport useScrollLocker from './hooks/useScrollLocker';\nlet openCount = 0;\nconst supportDom = canUseDom();\n/** @private Test usage only */\nexport function getOpenCount() {\n return process.env.NODE_ENV === 'test' ? openCount : 0;\n}\nconst getParent = getContainer => {\n if (!supportDom) {\n return null;\n }\n if (getContainer) {\n if (typeof getContainer === 'string') {\n return document.querySelectorAll(getContainer)[0];\n }\n if (typeof getContainer === 'function') {\n return getContainer();\n }\n if (typeof getContainer === 'object' && getContainer instanceof window.HTMLElement) {\n return getContainer;\n }\n }\n return document.body;\n};\nexport default defineComponent({\n compatConfig: {\n MODE: 3\n },\n name: 'PortalWrapper',\n inheritAttrs: false,\n props: {\n wrapperClassName: String,\n forceRender: {\n type: Boolean,\n default: undefined\n },\n getContainer: PropTypes.any,\n visible: {\n type: Boolean,\n default: undefined\n },\n autoLock: booleanType(),\n didUpdate: Function\n },\n setup(props, _ref) {\n let {\n slots\n } = _ref;\n const container = shallowRef();\n const componentRef = shallowRef();\n const rafId = shallowRef();\n const triggerUpdate = shallowRef(1);\n const defaultContainer = canUseDom() && document.createElement('div');\n const removeCurrentContainer = () => {\n var _a, _b;\n // Portal will remove from `parentNode`.\n // Let's handle this again to avoid refactor issue.\n if (container.value === defaultContainer) {\n (_b = (_a = container.value) === null || _a === void 0 ? void 0 : _a.parentNode) === null || _b === void 0 ? void 0 : _b.removeChild(container.value);\n }\n container.value = null;\n };\n let parent = null;\n const attachToParent = function () {\n let force = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;\n if (force || container.value && !container.value.parentNode) {\n parent = getParent(props.getContainer);\n if (parent) {\n parent.appendChild(container.value);\n return true;\n }\n return false;\n }\n return true;\n };\n const getContainer = () => {\n if (!supportDom) {\n return null;\n }\n if (!container.value) {\n container.value = defaultContainer;\n attachToParent(true);\n }\n setWrapperClassName();\n return container.value;\n };\n const setWrapperClassName = () => {\n const {\n wrapperClassName\n } = props;\n if (container.value && wrapperClassName && wrapperClassName !== container.value.className) {\n container.value.className = wrapperClassName;\n }\n };\n onUpdated(() => {\n setWrapperClassName();\n attachToParent();\n });\n useScrollLocker(computed(() => {\n return props.autoLock && props.visible && canUseDom() && (container.value === document.body || container.value === defaultContainer);\n }));\n onMounted(() => {\n let init = false;\n watch([() => props.visible, () => props.getContainer], (_ref2, _ref3) => {\n let [visible, getContainer] = _ref2;\n let [prevVisible, prevGetContainer] = _ref3;\n // Update count\n if (supportDom) {\n parent = getParent(props.getContainer);\n if (parent === document.body) {\n if (visible && !prevVisible) {\n openCount += 1;\n } else if (init) {\n openCount -= 1;\n }\n }\n }\n if (init) {\n // Clean up container if needed\n const getContainerIsFunc = typeof getContainer === 'function' && typeof prevGetContainer === 'function';\n if (getContainerIsFunc ? getContainer.toString() !== prevGetContainer.toString() : getContainer !== prevGetContainer) {\n removeCurrentContainer();\n }\n }\n init = true;\n }, {\n immediate: true,\n flush: 'post'\n });\n nextTick(() => {\n if (!attachToParent()) {\n rafId.value = raf(() => {\n triggerUpdate.value += 1;\n });\n }\n });\n });\n onBeforeUnmount(() => {\n const {\n visible\n } = props;\n if (supportDom && parent === document.body) {\n // 离开时不会 render, 导到离开时数值不变,改用 func 。。\n openCount = visible && openCount ? openCount - 1 : openCount;\n }\n removeCurrentContainer();\n raf.cancel(rafId.value);\n });\n return () => {\n const {\n forceRender,\n visible\n } = props;\n let portal = null;\n const childProps = {\n getOpenCount: () => openCount,\n getContainer\n };\n if (triggerUpdate.value && (forceRender || visible || componentRef.value)) {\n portal = _createVNode(Portal, {\n \"getContainer\": getContainer,\n \"ref\": componentRef,\n \"didUpdate\": props.didUpdate\n }, {\n default: () => {\n var _a;\n return (_a = slots.default) === null || _a === void 0 ? void 0 : _a.call(slots, childProps);\n }\n });\n }\n return portal;\n };\n }\n});","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport { Fragment as _Fragment, createVNode as _createVNode, resolveDirective as _resolveDirective } from \"vue\";\nimport { computed, defineComponent, inject, provide, shallowRef } from 'vue';\nimport { triggerProps, noop } from './interface';\nimport contains from '../vc-util/Dom/contains';\nimport raf from '../_util/raf';\nimport { hasProp, getComponent, getEvents, filterEmpty, getSlot, findDOMNode } from '../_util/props-util';\nimport addEventListener from '../vc-util/Dom/addEventListener';\nimport Popup from './Popup';\nimport { getAlignFromPlacement, getAlignPopupClassName } from './utils/alignUtil';\nimport BaseMixin from '../_util/BaseMixin';\nimport Portal from '../_util/PortalWrapper';\nimport classNames from '../_util/classNames';\nimport { cloneElement } from '../_util/vnode';\nimport supportsPassive from '../_util/supportsPassive';\nimport { useProvidePortal } from './context';\nconst ALL_HANDLERS = ['onClick', 'onMousedown', 'onTouchstart', 'onMouseenter', 'onMouseleave', 'onFocus', 'onBlur', 'onContextmenu'];\nexport default defineComponent({\n compatConfig: {\n MODE: 3\n },\n name: 'Trigger',\n mixins: [BaseMixin],\n inheritAttrs: false,\n props: triggerProps(),\n setup(props) {\n const align = computed(() => {\n const {\n popupPlacement,\n popupAlign,\n builtinPlacements\n } = props;\n if (popupPlacement && builtinPlacements) {\n return getAlignFromPlacement(builtinPlacements, popupPlacement, popupAlign);\n }\n return popupAlign;\n });\n const popupRef = shallowRef(null);\n const setPopupRef = val => {\n popupRef.value = val;\n };\n return {\n vcTriggerContext: inject('vcTriggerContext', {}),\n popupRef,\n setPopupRef,\n triggerRef: shallowRef(null),\n align,\n focusTime: null,\n clickOutsideHandler: null,\n contextmenuOutsideHandler1: null,\n contextmenuOutsideHandler2: null,\n touchOutsideHandler: null,\n attachId: null,\n delayTimer: null,\n hasPopupMouseDown: false,\n preClickTime: null,\n preTouchTime: null,\n mouseDownTimeout: null,\n childOriginEvents: {}\n };\n },\n data() {\n const props = this.$props;\n let popupVisible;\n if (this.popupVisible !== undefined) {\n popupVisible = !!props.popupVisible;\n } else {\n popupVisible = !!props.defaultPopupVisible;\n }\n ALL_HANDLERS.forEach(h => {\n this[`fire${h}`] = e => {\n this.fireEvents(h, e);\n };\n });\n return {\n prevPopupVisible: popupVisible,\n sPopupVisible: popupVisible,\n point: null\n };\n },\n watch: {\n popupVisible(val) {\n if (val !== undefined) {\n this.prevPopupVisible = this.sPopupVisible;\n this.sPopupVisible = val;\n }\n }\n },\n created() {\n provide('vcTriggerContext', {\n onPopupMouseDown: this.onPopupMouseDown,\n onPopupMouseenter: this.onPopupMouseenter,\n onPopupMouseleave: this.onPopupMouseleave\n });\n useProvidePortal(this);\n },\n deactivated() {\n this.setPopupVisible(false);\n },\n mounted() {\n this.$nextTick(() => {\n this.updatedCal();\n });\n },\n updated() {\n this.$nextTick(() => {\n this.updatedCal();\n });\n },\n beforeUnmount() {\n this.clearDelayTimer();\n this.clearOutsideHandler();\n clearTimeout(this.mouseDownTimeout);\n raf.cancel(this.attachId);\n },\n methods: {\n updatedCal() {\n const props = this.$props;\n const state = this.$data;\n // We must listen to `mousedown` or `touchstart`, edge case:\n // https://github.com/ant-design/ant-design/issues/5804\n // https://github.com/react-component/calendar/issues/250\n // https://github.com/react-component/trigger/issues/50\n if (state.sPopupVisible) {\n let currentDocument;\n if (!this.clickOutsideHandler && (this.isClickToHide() || this.isContextmenuToShow())) {\n currentDocument = props.getDocument(this.getRootDomNode());\n this.clickOutsideHandler = addEventListener(currentDocument, 'mousedown', this.onDocumentClick);\n }\n // always hide on mobile\n if (!this.touchOutsideHandler) {\n currentDocument = currentDocument || props.getDocument(this.getRootDomNode());\n this.touchOutsideHandler = addEventListener(currentDocument, 'touchstart', this.onDocumentClick, supportsPassive ? {\n passive: false\n } : false);\n }\n // close popup when trigger type contains 'onContextmenu' and document is scrolling.\n if (!this.contextmenuOutsideHandler1 && this.isContextmenuToShow()) {\n currentDocument = currentDocument || props.getDocument(this.getRootDomNode());\n this.contextmenuOutsideHandler1 = addEventListener(currentDocument, 'scroll', this.onContextmenuClose);\n }\n // close popup when trigger type contains 'onContextmenu' and window is blur.\n if (!this.contextmenuOutsideHandler2 && this.isContextmenuToShow()) {\n this.contextmenuOutsideHandler2 = addEventListener(window, 'blur', this.onContextmenuClose);\n }\n } else {\n this.clearOutsideHandler();\n }\n },\n onMouseenter(e) {\n const {\n mouseEnterDelay\n } = this.$props;\n this.fireEvents('onMouseenter', e);\n this.delaySetPopupVisible(true, mouseEnterDelay, mouseEnterDelay ? null : e);\n },\n onMouseMove(e) {\n this.fireEvents('onMousemove', e);\n this.setPoint(e);\n },\n onMouseleave(e) {\n this.fireEvents('onMouseleave', e);\n this.delaySetPopupVisible(false, this.$props.mouseLeaveDelay);\n },\n onPopupMouseenter() {\n const {\n vcTriggerContext = {}\n } = this;\n if (vcTriggerContext.onPopupMouseenter) {\n vcTriggerContext.onPopupMouseenter();\n }\n this.clearDelayTimer();\n },\n onPopupMouseleave(e) {\n var _a;\n if (e && e.relatedTarget && !e.relatedTarget.setTimeout && contains((_a = this.popupRef) === null || _a === void 0 ? void 0 : _a.getElement(), e.relatedTarget)) {\n return;\n }\n if (this.isMouseLeaveToHide()) {\n this.delaySetPopupVisible(false, this.$props.mouseLeaveDelay);\n }\n const {\n vcTriggerContext = {}\n } = this;\n if (vcTriggerContext.onPopupMouseleave) {\n vcTriggerContext.onPopupMouseleave(e);\n }\n },\n onFocus(e) {\n this.fireEvents('onFocus', e);\n // incase focusin and focusout\n this.clearDelayTimer();\n if (this.isFocusToShow()) {\n this.focusTime = Date.now();\n this.delaySetPopupVisible(true, this.$props.focusDelay);\n }\n },\n onMousedown(e) {\n this.fireEvents('onMousedown', e);\n this.preClickTime = Date.now();\n },\n onTouchstart(e) {\n this.fireEvents('onTouchstart', e);\n this.preTouchTime = Date.now();\n },\n onBlur(e) {\n if (!contains(e.target, e.relatedTarget || document.activeElement)) {\n this.fireEvents('onBlur', e);\n this.clearDelayTimer();\n if (this.isBlurToHide()) {\n this.delaySetPopupVisible(false, this.$props.blurDelay);\n }\n }\n },\n onContextmenu(e) {\n e.preventDefault();\n this.fireEvents('onContextmenu', e);\n this.setPopupVisible(true, e);\n },\n onContextmenuClose() {\n if (this.isContextmenuToShow()) {\n this.close();\n }\n },\n onClick(event) {\n this.fireEvents('onClick', event);\n // focus will trigger click\n if (this.focusTime) {\n let preTime;\n if (this.preClickTime && this.preTouchTime) {\n preTime = Math.min(this.preClickTime, this.preTouchTime);\n } else if (this.preClickTime) {\n preTime = this.preClickTime;\n } else if (this.preTouchTime) {\n preTime = this.preTouchTime;\n }\n if (Math.abs(preTime - this.focusTime) < 20) {\n return;\n }\n this.focusTime = 0;\n }\n this.preClickTime = 0;\n this.preTouchTime = 0;\n // Only prevent default when all the action is click.\n // https://github.com/ant-design/ant-design/issues/17043\n // https://github.com/ant-design/ant-design/issues/17291\n if (this.isClickToShow() && (this.isClickToHide() || this.isBlurToHide()) && event && event.preventDefault) {\n event.preventDefault();\n }\n if (event && event.domEvent) {\n event.domEvent.preventDefault();\n }\n const nextVisible = !this.$data.sPopupVisible;\n if (this.isClickToHide() && !nextVisible || nextVisible && this.isClickToShow()) {\n this.setPopupVisible(!this.$data.sPopupVisible, event);\n }\n },\n onPopupMouseDown() {\n const {\n vcTriggerContext = {}\n } = this;\n this.hasPopupMouseDown = true;\n clearTimeout(this.mouseDownTimeout);\n this.mouseDownTimeout = setTimeout(() => {\n this.hasPopupMouseDown = false;\n }, 0);\n if (vcTriggerContext.onPopupMouseDown) {\n vcTriggerContext.onPopupMouseDown(...arguments);\n }\n },\n onDocumentClick(event) {\n if (this.$props.mask && !this.$props.maskClosable) {\n return;\n }\n const target = event.target;\n const root = this.getRootDomNode();\n const popupNode = this.getPopupDomNode();\n if (\n // mousedown on the target should also close popup when action is contextMenu.\n // https://github.com/ant-design/ant-design/issues/29853\n (!contains(root, target) || this.isContextMenuOnly()) && !contains(popupNode, target) && !this.hasPopupMouseDown) {\n // https://github.com/vuejs/core/issues/4462\n // vue 动画bug导致 https://github.com/vueComponent/ant-design-vue/issues/5259,\n // 改成延时解决\n this.delaySetPopupVisible(false, 0.1);\n }\n },\n getPopupDomNode() {\n var _a;\n // for test\n return ((_a = this.popupRef) === null || _a === void 0 ? void 0 : _a.getElement()) || null;\n },\n getRootDomNode() {\n var _a, _b, _c, _d;\n const {\n getTriggerDOMNode\n } = this.$props;\n if (getTriggerDOMNode) {\n const domNode = ((_b = (_a = this.triggerRef) === null || _a === void 0 ? void 0 : _a.$el) === null || _b === void 0 ? void 0 : _b.nodeName) === '#comment' ? null : findDOMNode(this.triggerRef);\n return findDOMNode(getTriggerDOMNode(domNode));\n }\n try {\n const domNode = ((_d = (_c = this.triggerRef) === null || _c === void 0 ? void 0 : _c.$el) === null || _d === void 0 ? void 0 : _d.nodeName) === '#comment' ? null : findDOMNode(this.triggerRef);\n if (domNode) {\n return domNode;\n }\n } catch (err) {\n // Do nothing\n }\n return findDOMNode(this);\n },\n handleGetPopupClassFromAlign(align) {\n const className = [];\n const props = this.$props;\n const {\n popupPlacement,\n builtinPlacements,\n prefixCls,\n alignPoint,\n getPopupClassNameFromAlign\n } = props;\n if (popupPlacement && builtinPlacements) {\n className.push(getAlignPopupClassName(builtinPlacements, prefixCls, align, alignPoint));\n }\n if (getPopupClassNameFromAlign) {\n className.push(getPopupClassNameFromAlign(align));\n }\n return className.join(' ');\n },\n getPopupAlign() {\n const props = this.$props;\n const {\n popupPlacement,\n popupAlign,\n builtinPlacements\n } = props;\n if (popupPlacement && builtinPlacements) {\n return getAlignFromPlacement(builtinPlacements, popupPlacement, popupAlign);\n }\n return popupAlign;\n },\n getComponent() {\n const mouseProps = {};\n if (this.isMouseEnterToShow()) {\n mouseProps.onMouseenter = this.onPopupMouseenter;\n }\n if (this.isMouseLeaveToHide()) {\n mouseProps.onMouseleave = this.onPopupMouseleave;\n }\n mouseProps.onMousedown = this.onPopupMouseDown;\n mouseProps[supportsPassive ? 'onTouchstartPassive' : 'onTouchstart'] = this.onPopupMouseDown;\n const {\n handleGetPopupClassFromAlign,\n getRootDomNode,\n $attrs\n } = this;\n const {\n prefixCls,\n destroyPopupOnHide,\n popupClassName,\n popupAnimation,\n popupTransitionName,\n popupStyle,\n mask,\n maskAnimation,\n maskTransitionName,\n zIndex,\n stretch,\n alignPoint,\n mobile,\n forceRender\n } = this.$props;\n const {\n sPopupVisible,\n point\n } = this.$data;\n const popupProps = _extends(_extends({\n prefixCls,\n destroyPopupOnHide,\n visible: sPopupVisible,\n point: alignPoint ? point : null,\n align: this.align,\n animation: popupAnimation,\n getClassNameFromAlign: handleGetPopupClassFromAlign,\n stretch,\n getRootDomNode,\n mask,\n zIndex,\n transitionName: popupTransitionName,\n maskAnimation,\n maskTransitionName,\n class: popupClassName,\n style: popupStyle,\n onAlign: $attrs.onPopupAlign || noop\n }, mouseProps), {\n ref: this.setPopupRef,\n mobile,\n forceRender\n });\n return _createVNode(Popup, popupProps, {\n default: this.$slots.popup || (() => getComponent(this, 'popup'))\n });\n },\n attachParent(popupContainer) {\n raf.cancel(this.attachId);\n const {\n getPopupContainer,\n getDocument\n } = this.$props;\n const domNode = this.getRootDomNode();\n let mountNode;\n if (!getPopupContainer) {\n mountNode = getDocument(this.getRootDomNode()).body;\n } else if (domNode || getPopupContainer.length === 0) {\n // Compatible for legacy getPopupContainer with domNode argument.\n // If no need `domNode` argument, will call directly.\n // https://codesandbox.io/s/eloquent-mclean-ss93m?file=/src/App.js\n mountNode = getPopupContainer(domNode);\n }\n if (mountNode) {\n mountNode.appendChild(popupContainer);\n } else {\n // Retry after frame render in case parent not ready\n this.attachId = raf(() => {\n this.attachParent(popupContainer);\n });\n }\n },\n getContainer() {\n const {\n $props: props\n } = this;\n const {\n getDocument\n } = props;\n const popupContainer = getDocument(this.getRootDomNode()).createElement('div');\n // Make sure default popup container will never cause scrollbar appearing\n // https://github.com/react-component/trigger/issues/41\n popupContainer.style.position = 'absolute';\n popupContainer.style.top = '0';\n popupContainer.style.left = '0';\n popupContainer.style.width = '100%';\n this.attachParent(popupContainer);\n return popupContainer;\n },\n setPopupVisible(sPopupVisible, event) {\n const {\n alignPoint,\n sPopupVisible: prevPopupVisible,\n onPopupVisibleChange\n } = this;\n this.clearDelayTimer();\n if (prevPopupVisible !== sPopupVisible) {\n if (!hasProp(this, 'popupVisible')) {\n this.setState({\n sPopupVisible,\n prevPopupVisible\n });\n }\n onPopupVisibleChange && onPopupVisibleChange(sPopupVisible);\n }\n // Always record the point position since mouseEnterDelay will delay the show\n if (alignPoint && event && sPopupVisible) {\n this.setPoint(event);\n }\n },\n setPoint(point) {\n const {\n alignPoint\n } = this.$props;\n if (!alignPoint || !point) return;\n this.setState({\n point: {\n pageX: point.pageX,\n pageY: point.pageY\n }\n });\n },\n handlePortalUpdate() {\n if (this.prevPopupVisible !== this.sPopupVisible) {\n this.afterPopupVisibleChange(this.sPopupVisible);\n }\n },\n delaySetPopupVisible(visible, delayS, event) {\n const delay = delayS * 1000;\n this.clearDelayTimer();\n if (delay) {\n const point = event ? {\n pageX: event.pageX,\n pageY: event.pageY\n } : null;\n this.delayTimer = setTimeout(() => {\n this.setPopupVisible(visible, point);\n this.clearDelayTimer();\n }, delay);\n } else {\n this.setPopupVisible(visible, event);\n }\n },\n clearDelayTimer() {\n if (this.delayTimer) {\n clearTimeout(this.delayTimer);\n this.delayTimer = null;\n }\n },\n clearOutsideHandler() {\n if (this.clickOutsideHandler) {\n this.clickOutsideHandler.remove();\n this.clickOutsideHandler = null;\n }\n if (this.contextmenuOutsideHandler1) {\n this.contextmenuOutsideHandler1.remove();\n this.contextmenuOutsideHandler1 = null;\n }\n if (this.contextmenuOutsideHandler2) {\n this.contextmenuOutsideHandler2.remove();\n this.contextmenuOutsideHandler2 = null;\n }\n if (this.touchOutsideHandler) {\n this.touchOutsideHandler.remove();\n this.touchOutsideHandler = null;\n }\n },\n createTwoChains(event) {\n let fn = () => {};\n const events = getEvents(this);\n if (this.childOriginEvents[event] && events[event]) {\n return this[`fire${event}`];\n }\n fn = this.childOriginEvents[event] || events[event] || fn;\n return fn;\n },\n isClickToShow() {\n const {\n action,\n showAction\n } = this.$props;\n return action.indexOf('click') !== -1 || showAction.indexOf('click') !== -1;\n },\n isContextMenuOnly() {\n const {\n action\n } = this.$props;\n return action === 'contextmenu' || action.length === 1 && action[0] === 'contextmenu';\n },\n isContextmenuToShow() {\n const {\n action,\n showAction\n } = this.$props;\n return action.indexOf('contextmenu') !== -1 || showAction.indexOf('contextmenu') !== -1;\n },\n isClickToHide() {\n const {\n action,\n hideAction\n } = this.$props;\n return action.indexOf('click') !== -1 || hideAction.indexOf('click') !== -1;\n },\n isMouseEnterToShow() {\n const {\n action,\n showAction\n } = this.$props;\n return action.indexOf('hover') !== -1 || showAction.indexOf('mouseenter') !== -1;\n },\n isMouseLeaveToHide() {\n const {\n action,\n hideAction\n } = this.$props;\n return action.indexOf('hover') !== -1 || hideAction.indexOf('mouseleave') !== -1;\n },\n isFocusToShow() {\n const {\n action,\n showAction\n } = this.$props;\n return action.indexOf('focus') !== -1 || showAction.indexOf('focus') !== -1;\n },\n isBlurToHide() {\n const {\n action,\n hideAction\n } = this.$props;\n return action.indexOf('focus') !== -1 || hideAction.indexOf('blur') !== -1;\n },\n forcePopupAlign() {\n var _a;\n if (this.$data.sPopupVisible) {\n (_a = this.popupRef) === null || _a === void 0 ? void 0 : _a.forceAlign();\n }\n },\n fireEvents(type, e) {\n if (this.childOriginEvents[type]) {\n this.childOriginEvents[type](e);\n }\n const event = this.$props[type] || this.$attrs[type];\n if (event) {\n event(e);\n }\n },\n close() {\n this.setPopupVisible(false);\n }\n },\n render() {\n const {\n $attrs\n } = this;\n const children = filterEmpty(getSlot(this));\n const {\n alignPoint,\n getPopupContainer\n } = this.$props;\n const child = children[0];\n this.childOriginEvents = getEvents(child);\n const newChildProps = {\n key: 'trigger'\n };\n if (this.isContextmenuToShow()) {\n newChildProps.onContextmenu = this.onContextmenu;\n } else {\n newChildProps.onContextmenu = this.createTwoChains('onContextmenu');\n }\n if (this.isClickToHide() || this.isClickToShow()) {\n newChildProps.onClick = this.onClick;\n newChildProps.onMousedown = this.onMousedown;\n newChildProps[supportsPassive ? 'onTouchstartPassive' : 'onTouchstart'] = this.onTouchstart;\n } else {\n newChildProps.onClick = this.createTwoChains('onClick');\n newChildProps.onMousedown = this.createTwoChains('onMousedown');\n newChildProps[supportsPassive ? 'onTouchstartPassive' : 'onTouchstart'] = this.createTwoChains('onTouchstart');\n }\n if (this.isMouseEnterToShow()) {\n newChildProps.onMouseenter = this.onMouseenter;\n if (alignPoint) {\n newChildProps.onMousemove = this.onMouseMove;\n }\n } else {\n newChildProps.onMouseenter = this.createTwoChains('onMouseenter');\n }\n if (this.isMouseLeaveToHide()) {\n newChildProps.onMouseleave = this.onMouseleave;\n } else {\n newChildProps.onMouseleave = this.createTwoChains('onMouseleave');\n }\n if (this.isFocusToShow() || this.isBlurToHide()) {\n newChildProps.onFocus = this.onFocus;\n newChildProps.onBlur = this.onBlur;\n } else {\n newChildProps.onFocus = this.createTwoChains('onFocus');\n newChildProps.onBlur = e => {\n if (e && (!e.relatedTarget || !contains(e.target, e.relatedTarget))) {\n this.createTwoChains('onBlur')(e);\n }\n };\n }\n const childrenClassName = classNames(child && child.props && child.props.class, $attrs.class);\n if (childrenClassName) {\n newChildProps.class = childrenClassName;\n }\n const trigger = cloneElement(child, _extends(_extends({}, newChildProps), {\n ref: 'triggerRef'\n }), true, true);\n const portal = _createVNode(Portal, {\n \"key\": \"portal\",\n \"getContainer\": getPopupContainer && (() => getPopupContainer(this.getRootDomNode())),\n \"didUpdate\": this.handlePortalUpdate,\n \"visible\": this.$data.sPopupVisible\n }, {\n default: this.getComponent\n });\n return _createVNode(_Fragment, null, [trigger, portal]);\n }\n});","// based on rc-trigger 5.2.10\nimport Trigger from './Trigger';\nimport { triggerProps } from './interface';\nexport { triggerProps };\nexport default Trigger;","const autoAdjustOverflow = {\n adjustX: 1,\n adjustY: 1\n};\nconst targetOffset = [0, 0];\nexport const placements = {\n left: {\n points: ['cr', 'cl'],\n overflow: autoAdjustOverflow,\n offset: [-4, 0],\n targetOffset\n },\n right: {\n points: ['cl', 'cr'],\n overflow: autoAdjustOverflow,\n offset: [4, 0],\n targetOffset\n },\n top: {\n points: ['bc', 'tc'],\n overflow: autoAdjustOverflow,\n offset: [0, -4],\n targetOffset\n },\n bottom: {\n points: ['tc', 'bc'],\n overflow: autoAdjustOverflow,\n offset: [0, 4],\n targetOffset\n },\n topLeft: {\n points: ['bl', 'tl'],\n overflow: autoAdjustOverflow,\n offset: [0, -4],\n targetOffset\n },\n leftTop: {\n points: ['tr', 'tl'],\n overflow: autoAdjustOverflow,\n offset: [-4, 0],\n targetOffset\n },\n topRight: {\n points: ['br', 'tr'],\n overflow: autoAdjustOverflow,\n offset: [0, -4],\n targetOffset\n },\n rightTop: {\n points: ['tl', 'tr'],\n overflow: autoAdjustOverflow,\n offset: [4, 0],\n targetOffset\n },\n bottomRight: {\n points: ['tr', 'br'],\n overflow: autoAdjustOverflow,\n offset: [0, 4],\n targetOffset\n },\n rightBottom: {\n points: ['bl', 'br'],\n overflow: autoAdjustOverflow,\n offset: [4, 0],\n targetOffset\n },\n bottomLeft: {\n points: ['tl', 'bl'],\n overflow: autoAdjustOverflow,\n offset: [0, 4],\n targetOffset\n },\n leftBottom: {\n points: ['br', 'bl'],\n overflow: autoAdjustOverflow,\n offset: [-4, 0],\n targetOffset\n }\n};\nexport default placements;","import { createVNode as _createVNode } from \"vue\";\nimport { defineComponent } from 'vue';\nimport PropTypes from '../../_util/vue-types';\nconst tooltipContentProps = {\n prefixCls: String,\n id: String,\n overlayInnerStyle: PropTypes.any\n};\nexport default defineComponent({\n compatConfig: {\n MODE: 3\n },\n name: 'TooltipContent',\n props: tooltipContentProps,\n setup(props, _ref) {\n let {\n slots\n } = _ref;\n return () => {\n var _a;\n return _createVNode(\"div\", {\n \"class\": `${props.prefixCls}-inner`,\n \"id\": props.id,\n \"role\": \"tooltip\",\n \"style\": props.overlayInnerStyle\n }, [(_a = slots.overlay) === null || _a === void 0 ? void 0 : _a.call(slots)]);\n };\n }\n});","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport { resolveDirective as _resolveDirective, createVNode as _createVNode } from \"vue\";\nvar __rest = this && this.__rest || function (s, e) {\n var t = {};\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];\n }\n return t;\n};\nimport PropTypes from '../../_util/vue-types';\nimport Trigger from '../../vc-trigger';\nimport { placements } from './placements';\nimport Content from './Content';\nimport { getPropsSlot } from '../../_util/props-util';\nimport { defineComponent, shallowRef, watchEffect } from 'vue';\nfunction noop() {}\nexport default defineComponent({\n compatConfig: {\n MODE: 3\n },\n name: 'Tooltip',\n inheritAttrs: false,\n props: {\n trigger: PropTypes.any.def(['hover']),\n defaultVisible: {\n type: Boolean,\n default: undefined\n },\n visible: {\n type: Boolean,\n default: undefined\n },\n placement: PropTypes.string.def('right'),\n transitionName: String,\n animation: PropTypes.any,\n afterVisibleChange: PropTypes.func.def(() => {}),\n overlayStyle: {\n type: Object,\n default: undefined\n },\n overlayClassName: String,\n prefixCls: PropTypes.string.def('rc-tooltip'),\n mouseEnterDelay: PropTypes.number.def(0.1),\n mouseLeaveDelay: PropTypes.number.def(0.1),\n getPopupContainer: Function,\n destroyTooltipOnHide: {\n type: Boolean,\n default: false\n },\n align: PropTypes.object.def(() => ({})),\n arrowContent: PropTypes.any.def(null),\n tipId: String,\n builtinPlacements: PropTypes.object,\n overlayInnerStyle: {\n type: Object,\n default: undefined\n },\n popupVisible: {\n type: Boolean,\n default: undefined\n },\n onVisibleChange: Function,\n onPopupAlign: Function\n },\n setup(props, _ref) {\n let {\n slots,\n attrs,\n expose\n } = _ref;\n const triggerDOM = shallowRef();\n const getPopupElement = () => {\n const {\n prefixCls,\n tipId,\n overlayInnerStyle\n } = props;\n return [_createVNode(\"div\", {\n \"class\": `${prefixCls}-arrow`,\n \"key\": \"arrow\"\n }, [getPropsSlot(slots, props, 'arrowContent')]), _createVNode(Content, {\n \"key\": \"content\",\n \"prefixCls\": prefixCls,\n \"id\": tipId,\n \"overlayInnerStyle\": overlayInnerStyle\n }, {\n overlay: slots.overlay\n })];\n };\n const getPopupDomNode = () => {\n return triggerDOM.value.getPopupDomNode();\n };\n expose({\n getPopupDomNode,\n triggerDOM,\n forcePopupAlign: () => {\n var _a;\n return (_a = triggerDOM.value) === null || _a === void 0 ? void 0 : _a.forcePopupAlign();\n }\n });\n const destroyTooltip = shallowRef(false);\n const autoDestroy = shallowRef(false);\n watchEffect(() => {\n const {\n destroyTooltipOnHide\n } = props;\n if (typeof destroyTooltipOnHide === 'boolean') {\n destroyTooltip.value = destroyTooltipOnHide;\n } else if (destroyTooltipOnHide && typeof destroyTooltipOnHide === 'object') {\n const {\n keepParent\n } = destroyTooltipOnHide;\n destroyTooltip.value = keepParent === true;\n autoDestroy.value = keepParent === false;\n }\n });\n return () => {\n const {\n overlayClassName,\n trigger,\n mouseEnterDelay,\n mouseLeaveDelay,\n overlayStyle,\n prefixCls,\n afterVisibleChange,\n transitionName,\n animation,\n placement,\n align,\n destroyTooltipOnHide,\n defaultVisible\n } = props,\n restProps = __rest(props, [\"overlayClassName\", \"trigger\", \"mouseEnterDelay\", \"mouseLeaveDelay\", \"overlayStyle\", \"prefixCls\", \"afterVisibleChange\", \"transitionName\", \"animation\", \"placement\", \"align\", \"destroyTooltipOnHide\", \"defaultVisible\"]);\n const extraProps = _extends({}, restProps);\n if (props.visible !== undefined) {\n extraProps.popupVisible = props.visible;\n }\n const triggerProps = _extends(_extends(_extends({\n popupClassName: overlayClassName,\n prefixCls,\n action: trigger,\n builtinPlacements: placements,\n popupPlacement: placement,\n popupAlign: align,\n afterPopupVisibleChange: afterVisibleChange,\n popupTransitionName: transitionName,\n popupAnimation: animation,\n defaultPopupVisible: defaultVisible,\n destroyPopupOnHide: destroyTooltip.value,\n autoDestroy: autoDestroy.value,\n mouseLeaveDelay,\n popupStyle: overlayStyle,\n mouseEnterDelay\n }, extraProps), attrs), {\n onPopupVisibleChange: props.onVisibleChange || noop,\n onPopupAlign: props.onPopupAlign || noop,\n ref: triggerDOM,\n popup: getPopupElement()\n });\n return _createVNode(Trigger, triggerProps, {\n default: slots.default\n });\n };\n }\n});","// base rc-tooltip 5.1.1\nimport Tooltip from './src/Tooltip';\nexport default Tooltip;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nconst initDefaultProps = (types, defaultProps) => {\n const propTypes = _extends({}, types);\n Object.keys(defaultProps).forEach(k => {\n const prop = propTypes[k];\n if (prop) {\n if (prop.type || prop.default) {\n prop.default = defaultProps[k];\n } else if (prop.def) {\n prop.def(defaultProps[k]);\n } else {\n propTypes[k] = {\n type: prop,\n default: defaultProps[k]\n };\n }\n } else {\n throw new Error(`not have ${k} prop`);\n }\n });\n return propTypes;\n};\nexport default initDefaultProps;","import { objectType } from '../_util/type';\nexport default (() => ({\n trigger: [String, Array],\n open: {\n type: Boolean,\n default: undefined\n },\n /** @deprecated Please use `open` instead. */\n visible: {\n type: Boolean,\n default: undefined\n },\n placement: String,\n color: String,\n transitionName: String,\n overlayStyle: objectType(),\n overlayInnerStyle: objectType(),\n overlayClassName: String,\n openClassName: String,\n prefixCls: String,\n mouseEnterDelay: Number,\n mouseLeaveDelay: Number,\n getPopupContainer: Function,\n arrowPointAtCenter: {\n type: Boolean,\n default: undefined\n },\n autoAdjustOverflow: {\n type: [Boolean, Object],\n default: undefined\n },\n destroyTooltipOnHide: {\n type: Boolean,\n default: undefined\n },\n align: objectType(),\n builtinPlacements: objectType(),\n children: Array,\n /** @deprecated Please use `onOpenChange` instead. */\n onVisibleChange: Function,\n /** @deprecated Please use `onUpdate:open` instead. */\n 'onUpdate:visible': Function,\n onOpenChange: Function,\n 'onUpdate:open': Function\n}));","import { computed, inject, provide } from 'vue';\nimport { objectType } from '../_util/type';\nexport const defaultIconPrefixCls = 'anticon';\nexport const GlobalFormContextKey = Symbol('GlobalFormContextKey');\nexport const useProvideGlobalForm = state => {\n provide(GlobalFormContextKey, state);\n};\nexport const useInjectGlobalForm = () => {\n return inject(GlobalFormContextKey, {\n validateMessages: computed(() => undefined)\n });\n};\nexport const GlobalConfigContextKey = Symbol('GlobalConfigContextKey');\nexport const configProviderProps = () => ({\n iconPrefixCls: String,\n getTargetContainer: {\n type: Function\n },\n getPopupContainer: {\n type: Function\n },\n prefixCls: String,\n getPrefixCls: {\n type: Function\n },\n renderEmpty: {\n type: Function\n },\n transformCellText: {\n type: Function\n },\n csp: objectType(),\n input: objectType(),\n autoInsertSpaceInButton: {\n type: Boolean,\n default: undefined\n },\n locale: objectType(),\n pageHeader: objectType(),\n componentSize: {\n type: String\n },\n componentDisabled: {\n type: Boolean,\n default: undefined\n },\n direction: {\n type: String,\n default: 'ltr'\n },\n space: objectType(),\n virtual: {\n type: Boolean,\n default: undefined\n },\n dropdownMatchSelectWidth: {\n type: [Number, Boolean],\n default: true\n },\n form: objectType(),\n pagination: objectType(),\n theme: objectType(),\n select: objectType(),\n wave: objectType()\n});\nexport const configProviderKey = Symbol('configProvider');\nexport const defaultConfigProvider = {\n getPrefixCls: (suffixCls, customizePrefixCls) => {\n if (customizePrefixCls) return customizePrefixCls;\n return suffixCls ? `ant-${suffixCls}` : 'ant';\n },\n iconPrefixCls: computed(() => defaultIconPrefixCls),\n getPopupContainer: computed(() => () => document.body),\n direction: computed(() => 'ltr')\n};\nexport const useConfigContextInject = () => {\n return inject(configProviderKey, defaultConfigProvider);\n};\nexport const useConfigContextProvider = props => {\n return provide(configProviderKey, props);\n};","import { computed, inject, ref, provide } from 'vue';\nconst DisabledContextKey = Symbol('DisabledContextKey');\nexport const useInjectDisabled = () => {\n return inject(DisabledContextKey, ref(undefined));\n};\nexport const useProviderDisabled = disabled => {\n const parentDisabled = useInjectDisabled();\n provide(DisabledContextKey, computed(() => {\n var _a;\n return (_a = disabled.value) !== null && _a !== void 0 ? _a : parentDisabled.value;\n }));\n return disabled;\n};","export default {\n // Options.jsx\n items_per_page: '/ page',\n jump_to: 'Go to',\n jump_to_confirm: 'confirm',\n page: '',\n // Pagination.jsx\n prev_page: 'Previous Page',\n next_page: 'Next Page',\n prev_5: 'Previous 5 Pages',\n next_5: 'Next 5 Pages',\n prev_3: 'Previous 3 Pages',\n next_3: 'Next 3 Pages'\n};","const locale = {\n locale: 'en_US',\n today: 'Today',\n now: 'Now',\n backToToday: 'Back to today',\n ok: 'Ok',\n clear: 'Clear',\n month: 'Month',\n year: 'Year',\n timeSelect: 'select time',\n dateSelect: 'select date',\n weekSelect: 'Choose a week',\n monthSelect: 'Choose a month',\n yearSelect: 'Choose a year',\n decadeSelect: 'Choose a decade',\n yearFormat: 'YYYY',\n dateFormat: 'M/D/YYYY',\n dayFormat: 'D',\n dateTimeFormat: 'M/D/YYYY HH:mm:ss',\n monthBeforeYear: true,\n previousMonth: 'Previous month (PageUp)',\n nextMonth: 'Next month (PageDown)',\n previousYear: 'Last year (Control + left)',\n nextYear: 'Next year (Control + right)',\n previousDecade: 'Last decade',\n nextDecade: 'Next decade',\n previousCentury: 'Last century',\n nextCentury: 'Next century'\n};\nexport default locale;","const locale = {\n placeholder: 'Select time',\n rangePlaceholder: ['Start time', 'End time']\n};\nexport default locale;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport CalendarLocale from '../../vc-picker/locale/en_US';\nimport TimePickerLocale from '../../time-picker/locale/en_US';\n// Merge into a locale object\nconst locale = {\n lang: _extends({\n placeholder: 'Select date',\n yearPlaceholder: 'Select year',\n quarterPlaceholder: 'Select quarter',\n monthPlaceholder: 'Select month',\n weekPlaceholder: 'Select week',\n rangePlaceholder: ['Start date', 'End date'],\n rangeYearPlaceholder: ['Start year', 'End year'],\n rangeQuarterPlaceholder: ['Start quarter', 'End quarter'],\n rangeMonthPlaceholder: ['Start month', 'End month'],\n rangeWeekPlaceholder: ['Start week', 'End week']\n }, CalendarLocale),\n timePickerLocale: _extends({}, TimePickerLocale)\n};\n// All settings at:\n// https://github.com/ant-design/ant-design/blob/master/components/date-picker/locale/example.json\nexport default locale;","import enUS from '../../date-picker/locale/en_US';\nexport default enUS;","/* eslint-disable no-template-curly-in-string */\nimport Pagination from '../vc-pagination/locale/en_US';\nimport Calendar from '../calendar/locale/en_US';\nimport DatePicker from '../date-picker/locale/en_US';\nimport TimePicker from '../time-picker/locale/en_US';\nconst typeTemplate = '${label} is not a valid ${type}';\nconst localeValues = {\n locale: 'en',\n Pagination,\n DatePicker,\n TimePicker,\n Calendar,\n global: {\n placeholder: 'Please select'\n },\n Table: {\n filterTitle: 'Filter menu',\n filterConfirm: 'OK',\n filterReset: 'Reset',\n filterEmptyText: 'No filters',\n filterCheckall: 'Select all items',\n filterSearchPlaceholder: 'Search in filters',\n emptyText: 'No data',\n selectAll: 'Select current page',\n selectInvert: 'Invert current page',\n selectNone: 'Clear all data',\n selectionAll: 'Select all data',\n sortTitle: 'Sort',\n expand: 'Expand row',\n collapse: 'Collapse row',\n triggerDesc: 'Click to sort descending',\n triggerAsc: 'Click to sort ascending',\n cancelSort: 'Click to cancel sorting'\n },\n Tour: {\n Next: 'Next',\n Previous: 'Previous',\n Finish: 'Finish'\n },\n Modal: {\n okText: 'OK',\n cancelText: 'Cancel',\n justOkText: 'OK'\n },\n Popconfirm: {\n okText: 'OK',\n cancelText: 'Cancel'\n },\n Transfer: {\n titles: ['', ''],\n searchPlaceholder: 'Search here',\n itemUnit: 'item',\n itemsUnit: 'items',\n remove: 'Remove',\n selectCurrent: 'Select current page',\n removeCurrent: 'Remove current page',\n selectAll: 'Select all data',\n removeAll: 'Remove all data',\n selectInvert: 'Invert current page'\n },\n Upload: {\n uploading: 'Uploading...',\n removeFile: 'Remove file',\n uploadError: 'Upload error',\n previewFile: 'Preview file',\n downloadFile: 'Download file'\n },\n Empty: {\n description: 'No data'\n },\n Icon: {\n icon: 'icon'\n },\n Text: {\n edit: 'Edit',\n copy: 'Copy',\n copied: 'Copied',\n expand: 'Expand'\n },\n PageHeader: {\n back: 'Back'\n },\n Form: {\n optional: '(optional)',\n defaultValidateMessages: {\n default: 'Field validation error for ${label}',\n required: 'Please enter ${label}',\n enum: '${label} must be one of [${enum}]',\n whitespace: '${label} cannot be a blank character',\n date: {\n format: '${label} date format is invalid',\n parse: '${label} cannot be converted to a date',\n invalid: '${label} is an invalid date'\n },\n types: {\n string: typeTemplate,\n method: typeTemplate,\n array: typeTemplate,\n object: typeTemplate,\n number: typeTemplate,\n date: typeTemplate,\n boolean: typeTemplate,\n integer: typeTemplate,\n float: typeTemplate,\n regexp: typeTemplate,\n email: typeTemplate,\n url: typeTemplate,\n hex: typeTemplate\n },\n string: {\n len: '${label} must be ${len} characters',\n min: '${label} must be at least ${min} characters',\n max: '${label} must be up to ${max} characters',\n range: '${label} must be between ${min}-${max} characters'\n },\n number: {\n len: '${label} must be equal to ${len}',\n min: '${label} must be minimum ${min}',\n max: '${label} must be maximum ${max}',\n range: '${label} must be between ${min}-${max}'\n },\n array: {\n len: 'Must be ${len} ${label}',\n min: 'At least ${min} ${label}',\n max: 'At most ${max} ${label}',\n range: 'The amount of ${label} must be between ${min}-${max}'\n },\n pattern: {\n mismatch: '${label} does not match the pattern ${pattern}'\n }\n }\n },\n Image: {\n preview: 'Preview'\n },\n QRCode: {\n expired: 'QR code expired',\n refresh: 'Refresh',\n scanned: 'Scanned'\n }\n};\nexport default localeValues;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport { unref, inject, defineComponent, computed } from 'vue';\nimport defaultLocaleData from './en_US';\nexport default defineComponent({\n compatConfig: {\n MODE: 3\n },\n name: 'LocaleReceiver',\n props: {\n componentName: String,\n defaultLocale: {\n type: [Object, Function]\n },\n children: {\n type: Function\n }\n },\n setup(props, _ref) {\n let {\n slots\n } = _ref;\n const localeData = inject('localeData', {});\n const locale = computed(() => {\n const {\n componentName = 'global',\n defaultLocale\n } = props;\n const locale = defaultLocale || defaultLocaleData[componentName || 'global'];\n const {\n antLocale\n } = localeData;\n const localeFromContext = componentName && antLocale ? antLocale[componentName] : {};\n return _extends(_extends({}, typeof locale === 'function' ? locale() : locale), localeFromContext || {});\n });\n const localeCode = computed(() => {\n const {\n antLocale\n } = localeData;\n const localeCode = antLocale && antLocale.locale;\n // Had use LocaleProvide but didn't set locale\n if (antLocale && antLocale.exist && !localeCode) {\n return defaultLocaleData.locale;\n }\n return localeCode;\n });\n return () => {\n const children = props.children || slots.default;\n const {\n antLocale\n } = localeData;\n return children === null || children === void 0 ? void 0 : children(locale.value, localeCode.value, antLocale);\n };\n }\n});\nexport function useLocaleReceiver(componentName, defaultLocale, propsLocale) {\n const localeData = inject('localeData', {});\n const componentLocale = computed(() => {\n const {\n antLocale\n } = localeData;\n const locale = unref(defaultLocale) || defaultLocaleData[componentName || 'global'];\n const localeFromContext = componentName && antLocale ? antLocale[componentName] : {};\n return _extends(_extends(_extends({}, typeof locale === 'function' ? locale() : locale), localeFromContext || {}), unref(propsLocale) || {});\n });\n return [componentLocale];\n}","import LocaleReceiver from '../locale/LocaleReceiver';\nexport * from '../locale/LocaleReceiver';\nexport default LocaleReceiver;","export function sameDerivativeOption(left, right) {\n if (left.length !== right.length) {\n return false;\n }\n for (let i = 0; i < left.length; i++) {\n if (left[i] !== right[i]) {\n return false;\n }\n }\n return true;\n}\nexport default class ThemeCache {\n constructor() {\n this.cache = new Map();\n this.keys = [];\n this.cacheCallTimes = 0;\n }\n size() {\n return this.keys.length;\n }\n internalGet(derivativeOption) {\n let updateCallTimes = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;\n let cache = {\n map: this.cache\n };\n derivativeOption.forEach(derivative => {\n var _a;\n if (!cache) {\n cache = undefined;\n } else {\n cache = (_a = cache === null || cache === void 0 ? void 0 : cache.map) === null || _a === void 0 ? void 0 : _a.get(derivative);\n }\n });\n if ((cache === null || cache === void 0 ? void 0 : cache.value) && updateCallTimes) {\n cache.value[1] = this.cacheCallTimes++;\n }\n return cache === null || cache === void 0 ? void 0 : cache.value;\n }\n get(derivativeOption) {\n var _a;\n return (_a = this.internalGet(derivativeOption, true)) === null || _a === void 0 ? void 0 : _a[0];\n }\n has(derivativeOption) {\n return !!this.internalGet(derivativeOption);\n }\n set(derivativeOption, value) {\n // New cache\n if (!this.has(derivativeOption)) {\n if (this.size() + 1 > ThemeCache.MAX_CACHE_SIZE + ThemeCache.MAX_CACHE_OFFSET) {\n const [targetKey] = this.keys.reduce((result, key) => {\n const [, callTimes] = result;\n if (this.internalGet(key)[1] < callTimes) {\n return [key, this.internalGet(key)[1]];\n }\n return result;\n }, [this.keys[0], this.cacheCallTimes]);\n this.delete(targetKey);\n }\n this.keys.push(derivativeOption);\n }\n let cache = this.cache;\n derivativeOption.forEach((derivative, index) => {\n if (index === derivativeOption.length - 1) {\n cache.set(derivative, {\n value: [value, this.cacheCallTimes++]\n });\n } else {\n const cacheValue = cache.get(derivative);\n if (!cacheValue) {\n cache.set(derivative, {\n map: new Map()\n });\n } else if (!cacheValue.map) {\n cacheValue.map = new Map();\n }\n cache = cache.get(derivative).map;\n }\n });\n }\n deleteByPath(currentCache, derivatives) {\n var _a;\n const cache = currentCache.get(derivatives[0]);\n if (derivatives.length === 1) {\n if (!cache.map) {\n currentCache.delete(derivatives[0]);\n } else {\n currentCache.set(derivatives[0], {\n map: cache.map\n });\n }\n return (_a = cache.value) === null || _a === void 0 ? void 0 : _a[0];\n }\n const result = this.deleteByPath(cache.map, derivatives.slice(1));\n if ((!cache.map || cache.map.size === 0) && !cache.value) {\n currentCache.delete(derivatives[0]);\n }\n return result;\n }\n delete(derivativeOption) {\n // If cache exists\n if (this.has(derivativeOption)) {\n this.keys = this.keys.filter(item => !sameDerivativeOption(item, derivativeOption));\n return this.deleteByPath(this.cache, derivativeOption);\n }\n return undefined;\n }\n}\nThemeCache.MAX_CACHE_SIZE = 20;\nThemeCache.MAX_CACHE_OFFSET = 5;","import warning from '../../warning';\nlet uuid = 0;\n/**\n * Theme with algorithms to derive tokens from design tokens.\n * Use `createTheme` first which will help to manage the theme instance cache.\n */\nexport default class Theme {\n constructor(derivatives) {\n this.derivatives = Array.isArray(derivatives) ? derivatives : [derivatives];\n this.id = uuid;\n if (derivatives.length === 0) {\n warning(derivatives.length > 0, '[Ant Design Vue CSS-in-JS] Theme should have at least one derivative function.');\n }\n uuid += 1;\n }\n getDerivativeToken(token) {\n return this.derivatives.reduce((result, derivative) => derivative(token, result), undefined);\n }\n}","import ThemeCache from './ThemeCache';\nimport Theme from './Theme';\nconst cacheThemes = new ThemeCache();\n/**\n * Same as new Theme, but will always return same one if `derivative` not changed.\n */\nexport default function createTheme(derivatives) {\n const derivativeArr = Array.isArray(derivatives) ? derivatives : [derivatives];\n // Create new theme if not exist\n if (!cacheThemes.has(derivativeArr)) {\n cacheThemes.set(derivativeArr, new Theme(derivativeArr));\n }\n // Get theme from cache and return\n return cacheThemes.get(derivativeArr);\n}","/* eslint-disable */\n// Inspired by https://github.com/garycourt/murmurhash-js\n// Ported from https://github.com/aappleby/smhasher/blob/61a0530f28277f2e850bfc39600ce61d02b518de/src/MurmurHash2.cpp#L37-L86\nfunction murmur2(str) {\n // 'm' and 'r' are mixing constants generated offline.\n // They're not really 'magic', they just happen to work well.\n // const m = 0x5bd1e995;\n // const r = 24;\n // Initialize the hash\n var h = 0; // Mix 4 bytes at a time into the hash\n\n var k,\n i = 0,\n len = str.length;\n\n for (; len >= 4; ++i, len -= 4) {\n k = str.charCodeAt(i) & 0xff | (str.charCodeAt(++i) & 0xff) << 8 | (str.charCodeAt(++i) & 0xff) << 16 | (str.charCodeAt(++i) & 0xff) << 24;\n k =\n /* Math.imul(k, m): */\n (k & 0xffff) * 0x5bd1e995 + ((k >>> 16) * 0xe995 << 16);\n k ^=\n /* k >>> r: */\n k >>> 24;\n h =\n /* Math.imul(k, m): */\n (k & 0xffff) * 0x5bd1e995 + ((k >>> 16) * 0xe995 << 16) ^\n /* Math.imul(h, m): */\n (h & 0xffff) * 0x5bd1e995 + ((h >>> 16) * 0xe995 << 16);\n } // Handle the last few bytes of the input array\n\n\n switch (len) {\n case 3:\n h ^= (str.charCodeAt(i + 2) & 0xff) << 16;\n\n case 2:\n h ^= (str.charCodeAt(i + 1) & 0xff) << 8;\n\n case 1:\n h ^= str.charCodeAt(i) & 0xff;\n h =\n /* Math.imul(h, m): */\n (h & 0xffff) * 0x5bd1e995 + ((h >>> 16) * 0xe995 << 16);\n } // Do a few final mixes of the hash to ensure the last few\n // bytes are well-incorporated.\n\n\n h ^= h >>> 13;\n h =\n /* Math.imul(h, m): */\n (h & 0xffff) * 0x5bd1e995 + ((h >>> 16) * 0xe995 << 16);\n return ((h ^ h >>> 15) >>> 0).toString(36);\n}\n\nexport { murmur2 as default };\n","const SPLIT = '%';\nclass Entity {\n constructor(instanceId) {\n /** @private Internal cache map. Do not access this directly */\n this.cache = new Map();\n this.instanceId = instanceId;\n }\n get(keys) {\n return this.cache.get(Array.isArray(keys) ? keys.join(SPLIT) : keys) || null;\n }\n update(keys, valueFn) {\n const path = Array.isArray(keys) ? keys.join(SPLIT) : keys;\n const prevValue = this.cache.get(path);\n const nextValue = valueFn(prevValue);\n if (nextValue === null) {\n this.cache.delete(path);\n } else {\n this.cache.set(path, nextValue);\n }\n }\n}\nexport default Entity;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport { provide, defineComponent, unref, inject, watch, shallowRef, getCurrentInstance } from 'vue';\nimport CacheEntity from './Cache';\nimport { arrayType, booleanType, objectType, someType, stringType, withInstall } from '../type';\nexport const ATTR_TOKEN = 'data-token-hash';\nexport const ATTR_MARK = 'data-css-hash';\nexport const ATTR_CACHE_PATH = 'data-cache-path';\n// Mark css-in-js instance in style element\nexport const CSS_IN_JS_INSTANCE = '__cssinjs_instance__';\nexport function createCache() {\n const cssinjsInstanceId = Math.random().toString(12).slice(2);\n // Tricky SSR: Move all inline style to the head.\n // PS: We do not recommend tricky mode.\n if (typeof document !== 'undefined' && document.head && document.body) {\n const styles = document.body.querySelectorAll(`style[${ATTR_MARK}]`) || [];\n const {\n firstChild\n } = document.head;\n Array.from(styles).forEach(style => {\n style[CSS_IN_JS_INSTANCE] = style[CSS_IN_JS_INSTANCE] || cssinjsInstanceId;\n // Not force move if no head\n // Not force move if no head\n if (style[CSS_IN_JS_INSTANCE] === cssinjsInstanceId) {\n document.head.insertBefore(style, firstChild);\n }\n });\n // Deduplicate of moved styles\n const styleHash = {};\n Array.from(document.querySelectorAll(`style[${ATTR_MARK}]`)).forEach(style => {\n var _a;\n const hash = style.getAttribute(ATTR_MARK);\n if (styleHash[hash]) {\n if (style[CSS_IN_JS_INSTANCE] === cssinjsInstanceId) {\n (_a = style.parentNode) === null || _a === void 0 ? void 0 : _a.removeChild(style);\n }\n } else {\n styleHash[hash] = true;\n }\n });\n }\n return new CacheEntity(cssinjsInstanceId);\n}\nconst StyleContextKey = Symbol('StyleContextKey');\n// fix: https://github.com/vueComponent/ant-design-vue/issues/7023\nconst getCache = () => {\n var _a, _b, _c;\n const instance = getCurrentInstance();\n let cache;\n if (instance && instance.appContext) {\n const globalCache = (_c = (_b = (_a = instance.appContext) === null || _a === void 0 ? void 0 : _a.config) === null || _b === void 0 ? void 0 : _b.globalProperties) === null || _c === void 0 ? void 0 : _c.__ANTDV_CSSINJS_CACHE__;\n if (globalCache) {\n cache = globalCache;\n } else {\n cache = createCache();\n if (instance.appContext.config.globalProperties) {\n instance.appContext.config.globalProperties.__ANTDV_CSSINJS_CACHE__ = cache;\n }\n }\n } else {\n cache = createCache();\n }\n return cache;\n};\nconst defaultStyleContext = {\n cache: createCache(),\n defaultCache: true,\n hashPriority: 'low'\n};\n// fix: https://github.com/vueComponent/ant-design-vue/issues/6912\nexport const useStyleInject = () => {\n const cache = getCache();\n return inject(StyleContextKey, shallowRef(_extends(_extends({}, defaultStyleContext), {\n cache\n })));\n};\nexport const useStyleProvider = props => {\n const parentContext = useStyleInject();\n const context = shallowRef(_extends(_extends({}, defaultStyleContext), {\n cache: createCache()\n }));\n watch([() => unref(props), parentContext], () => {\n const mergedContext = _extends({}, parentContext.value);\n const propsValue = unref(props);\n Object.keys(propsValue).forEach(key => {\n const value = propsValue[key];\n if (propsValue[key] !== undefined) {\n mergedContext[key] = value;\n }\n });\n const {\n cache\n } = propsValue;\n mergedContext.cache = mergedContext.cache || createCache();\n mergedContext.defaultCache = !cache && parentContext.value.defaultCache;\n context.value = mergedContext;\n }, {\n immediate: true\n });\n provide(StyleContextKey, context);\n return context;\n};\nexport const styleProviderProps = () => ({\n autoClear: booleanType(),\n /** @private Test only. Not work in production. */\n mock: stringType(),\n /**\n * Only set when you need ssr to extract style on you own.\n * If not provided, it will auto create on the end of Provider in server side.\n */\n cache: objectType(),\n /** Tell children that this context is default generated context */\n defaultCache: booleanType(),\n /** Use `:where` selector to reduce hashId css selector priority */\n hashPriority: stringType(),\n /** Tell cssinjs where to inject style in */\n container: someType(),\n /** Component wil render inline `` for fallback in SSR. Not recommend. */\n ssrInline: booleanType(),\n /** Transform css before inject in document. Please note that `transformers` do not support dynamic update */\n transformers: arrayType(),\n /**\n * Linters to lint css before inject in document.\n * Styles will be linted after transforming.\n * Please note that `linters` do not support dynamic update.\n */\n linters: arrayType()\n});\nexport const StyleProvider = withInstall(defineComponent({\n name: 'AStyleProvider',\n inheritAttrs: false,\n props: styleProviderProps(),\n setup(props, _ref) {\n let {\n slots\n } = _ref;\n useStyleProvider(props);\n return () => {\n var _a;\n return (_a = slots.default) === null || _a === void 0 ? void 0 : _a.call(slots);\n };\n }\n}));\nexport default {\n useStyleInject,\n useStyleProvider,\n StyleProvider\n};","function useProdHMR() {\n return false;\n}\nlet webpackHMR = false;\nfunction useDevHMR() {\n return webpackHMR;\n}\nexport default process.env.NODE_ENV === 'production' ? useProdHMR : useDevHMR;\n// Webpack `module.hot.accept` do not support any deps update trigger\n// We have to hack handler to force mark as HRM\nif (process.env.NODE_ENV !== 'production' && typeof module !== 'undefined' && module && module.hot && typeof window !== 'undefined') {\n const win = window;\n if (typeof win.webpackHotUpdate === 'function') {\n const originWebpackHotUpdate = win.webpackHotUpdate;\n win.webpackHotUpdate = function () {\n webpackHMR = true;\n setTimeout(() => {\n webpackHMR = false;\n }, 0);\n return originWebpackHotUpdate(...arguments);\n };\n }\n}","import { useStyleInject } from '../StyleContext';\nimport useHMR from './useHMR';\nimport { onBeforeUnmount, watch, watchEffect, shallowRef } from 'vue';\nexport default function useClientCache(prefix, keyPath, cacheFn, onCacheRemove) {\n const styleContext = useStyleInject();\n const fullPathStr = shallowRef('');\n const res = shallowRef();\n watchEffect(() => {\n fullPathStr.value = [prefix, ...keyPath.value].join('%');\n });\n const HMRUpdate = useHMR();\n const clearCache = pathStr => {\n styleContext.value.cache.update(pathStr, prevCache => {\n const [times = 0, cache] = prevCache || [];\n const nextCount = times - 1;\n if (nextCount === 0) {\n onCacheRemove === null || onCacheRemove === void 0 ? void 0 : onCacheRemove(cache, false);\n return null;\n }\n return [times - 1, cache];\n });\n };\n watch(fullPathStr, (newStr, oldStr) => {\n if (oldStr) clearCache(oldStr);\n // Create cache\n styleContext.value.cache.update(newStr, prevCache => {\n const [times = 0, cache] = prevCache || [];\n // HMR should always ignore cache since developer may change it\n let tmpCache = cache;\n if (process.env.NODE_ENV !== 'production' && cache && HMRUpdate) {\n onCacheRemove === null || onCacheRemove === void 0 ? void 0 : onCacheRemove(tmpCache, HMRUpdate);\n tmpCache = null;\n }\n const mergedCache = tmpCache || cacheFn();\n return [times + 1, mergedCache];\n });\n res.value = styleContext.value.cache.get(fullPathStr.value)[1];\n }, {\n immediate: true\n });\n onBeforeUnmount(() => {\n clearCache(fullPathStr.value);\n });\n return res;\n}","import hash from '@emotion/hash';\nimport { removeCSS, updateCSS } from '../../vc-util/Dom/dynamicCSS';\nimport canUseDom from '../canUseDom';\nimport { Theme } from './theme';\n// Create a cache here to avoid always loop generate\nconst flattenTokenCache = new WeakMap();\nexport function flattenToken(token) {\n let str = flattenTokenCache.get(token) || '';\n if (!str) {\n Object.keys(token).forEach(key => {\n const value = token[key];\n str += key;\n if (value instanceof Theme) {\n str += value.id;\n } else if (value && typeof value === 'object') {\n str += flattenToken(value);\n } else {\n str += value;\n }\n });\n // Put in cache\n flattenTokenCache.set(token, str);\n }\n return str;\n}\n/**\n * Convert derivative token to key string\n */\nexport function token2key(token, salt) {\n return hash(`${salt}_${flattenToken(token)}`);\n}\nconst randomSelectorKey = `random-${Date.now()}-${Math.random()}`.replace(/\\./g, '');\n// Magic `content` for detect selector support\nconst checkContent = '_bAmBoO_';\nfunction supportSelector(styleStr, handleElement, supportCheck) {\n var _a, _b;\n if (canUseDom()) {\n updateCSS(styleStr, randomSelectorKey);\n const ele = document.createElement('div');\n ele.style.position = 'fixed';\n ele.style.left = '0';\n ele.style.top = '0';\n handleElement === null || handleElement === void 0 ? void 0 : handleElement(ele);\n document.body.appendChild(ele);\n if (process.env.NODE_ENV !== 'production') {\n ele.innerHTML = 'Test';\n ele.style.zIndex = '9999999';\n }\n const support = supportCheck ? supportCheck(ele) : (_a = getComputedStyle(ele).content) === null || _a === void 0 ? void 0 : _a.includes(checkContent);\n (_b = ele.parentNode) === null || _b === void 0 ? void 0 : _b.removeChild(ele);\n removeCSS(randomSelectorKey);\n return support;\n }\n return false;\n}\nlet canLayer = undefined;\nexport function supportLayer() {\n if (canLayer === undefined) {\n canLayer = supportSelector(`@layer ${randomSelectorKey} { .${randomSelectorKey} { content: \"${checkContent}\"!important; } }`, ele => {\n ele.className = randomSelectorKey;\n });\n }\n return canLayer;\n}\nlet canWhere = undefined;\nexport function supportWhere() {\n if (canWhere === undefined) {\n canWhere = supportSelector(`:where(.${randomSelectorKey}) { content: \"${checkContent}\"!important; }`, ele => {\n ele.className = randomSelectorKey;\n });\n }\n return canWhere;\n}\nlet canLogic = undefined;\nexport function supportLogicProps() {\n if (canLogic === undefined) {\n canLogic = supportSelector(`.${randomSelectorKey} { inset-block: 93px !important; }`, ele => {\n ele.className = randomSelectorKey;\n }, ele => getComputedStyle(ele).bottom === '93px');\n }\n return canLogic;\n}","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport hash from '@emotion/hash';\nimport { ATTR_TOKEN, CSS_IN_JS_INSTANCE, useStyleInject } from '../StyleContext';\nimport useGlobalCache from './useGlobalCache';\nimport { flattenToken, token2key } from '../util';\nimport { ref, computed } from 'vue';\nconst EMPTY_OVERRIDE = {};\nconst isProduction = process.env.NODE_ENV === 'production';\n// nuxt generate when NODE_ENV is prerender\nconst isPrerender = process.env.NODE_ENV === 'prerender';\n// Generate different prefix to make user selector break in production env.\n// This helps developer not to do style override directly on the hash id.\nconst hashPrefix = !isProduction && !isPrerender ? 'css-dev-only-do-not-override' : 'css';\nconst tokenKeys = new Map();\nfunction recordCleanToken(tokenKey) {\n tokenKeys.set(tokenKey, (tokenKeys.get(tokenKey) || 0) + 1);\n}\nfunction removeStyleTags(key, instanceId) {\n if (typeof document !== 'undefined') {\n const styles = document.querySelectorAll(`style[${ATTR_TOKEN}=\"${key}\"]`);\n styles.forEach(style => {\n var _a;\n if (style[CSS_IN_JS_INSTANCE] === instanceId) {\n (_a = style.parentNode) === null || _a === void 0 ? void 0 : _a.removeChild(style);\n }\n });\n }\n}\nconst TOKEN_THRESHOLD = 0;\n// Remove will check current keys first\nfunction cleanTokenStyle(tokenKey, instanceId) {\n tokenKeys.set(tokenKey, (tokenKeys.get(tokenKey) || 0) - 1);\n const tokenKeyList = Array.from(tokenKeys.keys());\n const cleanableKeyList = tokenKeyList.filter(key => {\n const count = tokenKeys.get(key) || 0;\n return count <= 0;\n });\n // Should keep tokens under threshold for not to insert style too often\n if (tokenKeyList.length - cleanableKeyList.length > TOKEN_THRESHOLD) {\n cleanableKeyList.forEach(key => {\n removeStyleTags(key, instanceId);\n tokenKeys.delete(key);\n });\n }\n}\nexport const getComputedToken = (originToken, overrideToken, theme, format) => {\n const derivativeToken = theme.getDerivativeToken(originToken);\n // Merge with override\n let mergedDerivativeToken = _extends(_extends({}, derivativeToken), overrideToken);\n // Format if needed\n if (format) {\n mergedDerivativeToken = format(mergedDerivativeToken);\n }\n return mergedDerivativeToken;\n};\n/**\n * Cache theme derivative token as global shared one\n * @param theme Theme entity\n * @param tokens List of tokens, used for cache. Please do not dynamic generate object directly\n * @param option Additional config\n * @returns Call Theme.getDerivativeToken(tokenObject) to get token\n */\nexport default function useCacheToken(theme, tokens) {\n let option = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : ref({});\n const style = useStyleInject();\n // Basic - We do basic cache here\n const mergedToken = computed(() => _extends({}, ...tokens.value));\n const tokenStr = computed(() => flattenToken(mergedToken.value));\n const overrideTokenStr = computed(() => flattenToken(option.value.override || EMPTY_OVERRIDE));\n const cachedToken = useGlobalCache('token', computed(() => [option.value.salt || '', theme.value.id, tokenStr.value, overrideTokenStr.value]), () => {\n const {\n salt = '',\n override = EMPTY_OVERRIDE,\n formatToken,\n getComputedToken: compute\n } = option.value;\n const mergedDerivativeToken = compute ? compute(mergedToken.value, override, theme.value) : getComputedToken(mergedToken.value, override, theme.value, formatToken);\n // Optimize for `useStyleRegister` performance\n const tokenKey = token2key(mergedDerivativeToken, salt);\n mergedDerivativeToken._tokenKey = tokenKey;\n recordCleanToken(tokenKey);\n const hashId = `${hashPrefix}-${hash(tokenKey)}`;\n mergedDerivativeToken._hashId = hashId; // Not used\n return [mergedDerivativeToken, hashId];\n }, cache => {\n var _a;\n // Remove token will remove all related style\n cleanTokenStyle(cache[0]._tokenKey, (_a = style.value) === null || _a === void 0 ? void 0 : _a.cache.instanceId);\n });\n return cachedToken;\n}","export default '4.1.2';","/* eslint import/no-unresolved: 0 */\n// @ts-ignore\nimport version from './version';\nexport default version;","import { inputToRGB, rgbToHex, rgbToHsv } from '@ctrl/tinycolor';\n\nvar hueStep = 2; // 色相阶梯\n\nvar saturationStep = 0.16; // 饱和度阶梯,浅色部分\n\nvar saturationStep2 = 0.05; // 饱和度阶梯,深色部分\n\nvar brightnessStep1 = 0.05; // 亮度阶梯,浅色部分\n\nvar brightnessStep2 = 0.15; // 亮度阶梯,深色部分\n\nvar lightColorCount = 5; // 浅色数量,主色上\n\nvar darkColorCount = 4; // 深色数量,主色下\n// 暗色主题颜色映射关系表\n\nvar darkColorMap = [{\n index: 7,\n opacity: 0.15\n}, {\n index: 6,\n opacity: 0.25\n}, {\n index: 5,\n opacity: 0.3\n}, {\n index: 5,\n opacity: 0.45\n}, {\n index: 5,\n opacity: 0.65\n}, {\n index: 5,\n opacity: 0.85\n}, {\n index: 4,\n opacity: 0.9\n}, {\n index: 3,\n opacity: 0.95\n}, {\n index: 2,\n opacity: 0.97\n}, {\n index: 1,\n opacity: 0.98\n}]; // Wrapper function ported from TinyColor.prototype.toHsv\n// Keep it here because of `hsv.h * 360`\n\nfunction toHsv(_ref) {\n var r = _ref.r,\n g = _ref.g,\n b = _ref.b;\n var hsv = rgbToHsv(r, g, b);\n return {\n h: hsv.h * 360,\n s: hsv.s,\n v: hsv.v\n };\n} // Wrapper function ported from TinyColor.prototype.toHexString\n// Keep it here because of the prefix `#`\n\n\nfunction toHex(_ref2) {\n var r = _ref2.r,\n g = _ref2.g,\n b = _ref2.b;\n return \"#\".concat(rgbToHex(r, g, b, false));\n} // Wrapper function ported from TinyColor.prototype.mix, not treeshakable.\n// Amount in range [0, 1]\n// Assume color1 & color2 has no alpha, since the following src code did so.\n\n\nfunction mix(rgb1, rgb2, amount) {\n var p = amount / 100;\n var rgb = {\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 };\n return rgb;\n}\n\nfunction getHue(hsv, i, light) {\n var hue; // 根据色相不同,色相转向不同\n\n if (Math.round(hsv.h) >= 60 && Math.round(hsv.h) <= 240) {\n hue = light ? Math.round(hsv.h) - hueStep * i : Math.round(hsv.h) + hueStep * i;\n } else {\n hue = light ? Math.round(hsv.h) + hueStep * i : Math.round(hsv.h) - hueStep * i;\n }\n\n if (hue < 0) {\n hue += 360;\n } else if (hue >= 360) {\n hue -= 360;\n }\n\n return hue;\n}\n\nfunction getSaturation(hsv, i, light) {\n // grey color don't change saturation\n if (hsv.h === 0 && hsv.s === 0) {\n return hsv.s;\n }\n\n var saturation;\n\n if (light) {\n saturation = hsv.s - saturationStep * i;\n } else if (i === darkColorCount) {\n saturation = hsv.s + saturationStep;\n } else {\n saturation = hsv.s + saturationStep2 * i;\n } // 边界值修正\n\n\n if (saturation > 1) {\n saturation = 1;\n } // 第一格的 s 限制在 0.06-0.1 之间\n\n\n if (light && i === lightColorCount && saturation > 0.1) {\n saturation = 0.1;\n }\n\n if (saturation < 0.06) {\n saturation = 0.06;\n }\n\n return Number(saturation.toFixed(2));\n}\n\nfunction getValue(hsv, i, light) {\n var value;\n\n if (light) {\n value = hsv.v + brightnessStep1 * i;\n } else {\n value = hsv.v - brightnessStep2 * i;\n }\n\n if (value > 1) {\n value = 1;\n }\n\n return Number(value.toFixed(2));\n}\n\nfunction generate(color) {\n var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n var patterns = [];\n var pColor = inputToRGB(color);\n\n for (var i = lightColorCount; i > 0; i -= 1) {\n var hsv = toHsv(pColor);\n var colorString = toHex(inputToRGB({\n h: getHue(hsv, i, true),\n s: getSaturation(hsv, i, true),\n v: getValue(hsv, i, true)\n }));\n patterns.push(colorString);\n }\n\n patterns.push(toHex(pColor));\n\n for (var _i = 1; _i <= darkColorCount; _i += 1) {\n var _hsv = toHsv(pColor);\n\n var _colorString = toHex(inputToRGB({\n h: getHue(_hsv, _i),\n s: getSaturation(_hsv, _i),\n v: getValue(_hsv, _i)\n }));\n\n patterns.push(_colorString);\n } // dark theme patterns\n\n\n if (opts.theme === 'dark') {\n return darkColorMap.map(function (_ref3) {\n var index = _ref3.index,\n opacity = _ref3.opacity;\n var darkColorString = toHex(mix(inputToRGB(opts.backgroundColor || '#141414'), inputToRGB(patterns[index]), opacity * 100));\n return darkColorString;\n });\n }\n\n return patterns;\n}\n\nvar presetPrimaryColors = {\n red: '#F5222D',\n volcano: '#FA541C',\n orange: '#FA8C16',\n gold: '#FAAD14',\n yellow: '#FADB14',\n lime: '#A0D911',\n green: '#52C41A',\n cyan: '#13C2C2',\n blue: '#1890FF',\n geekblue: '#2F54EB',\n purple: '#722ED1',\n magenta: '#EB2F96',\n grey: '#666666'\n};\nvar presetPalettes = {};\nvar presetDarkPalettes = {};\nObject.keys(presetPrimaryColors).forEach(function (key) {\n presetPalettes[key] = generate(presetPrimaryColors[key]);\n presetPalettes[key].primary = presetPalettes[key][5]; // dark presetPalettes\n\n presetDarkPalettes[key] = generate(presetPrimaryColors[key], {\n theme: 'dark',\n backgroundColor: '#141414'\n });\n presetDarkPalettes[key].primary = presetDarkPalettes[key][5];\n});\nvar red = presetPalettes.red;\nvar volcano = presetPalettes.volcano;\nvar gold = presetPalettes.gold;\nvar orange = presetPalettes.orange;\nvar yellow = presetPalettes.yellow;\nvar lime = presetPalettes.lime;\nvar green = presetPalettes.green;\nvar cyan = presetPalettes.cyan;\nvar blue = presetPalettes.blue;\nvar geekblue = presetPalettes.geekblue;\nvar purple = presetPalettes.purple;\nvar magenta = presetPalettes.magenta;\nvar grey = presetPalettes.grey;\n\nexport { blue, cyan, geekblue, generate, gold, green, grey, lime, magenta, orange, presetDarkPalettes, presetPalettes, presetPrimaryColors, purple, red, volcano, yellow };\n","const genControlHeight = token => {\n const {\n controlHeight\n } = token;\n return {\n controlHeightSM: controlHeight * 0.75,\n controlHeightXS: controlHeight * 0.5,\n controlHeightLG: controlHeight * 1.25\n };\n};\nexport default genControlHeight;","export default function genSizeMapToken(token) {\n const {\n sizeUnit,\n sizeStep\n } = token;\n return {\n sizeXXL: sizeUnit * (sizeStep + 8),\n sizeXL: sizeUnit * (sizeStep + 4),\n sizeLG: sizeUnit * (sizeStep + 2),\n sizeMD: sizeUnit * (sizeStep + 1),\n sizeMS: sizeUnit * sizeStep,\n size: sizeUnit * sizeStep,\n sizeSM: sizeUnit * (sizeStep - 1),\n sizeXS: sizeUnit * (sizeStep - 2),\n sizeXXS: sizeUnit * (sizeStep - 3) // 4\n };\n}","import _extends from \"@babel/runtime/helpers/esm/extends\";\nexport const defaultPresetColors = {\n blue: '#1677ff',\n purple: '#722ED1',\n cyan: '#13C2C2',\n green: '#52C41A',\n magenta: '#EB2F96',\n pink: '#eb2f96',\n red: '#F5222D',\n orange: '#FA8C16',\n yellow: '#FADB14',\n volcano: '#FA541C',\n geekblue: '#2F54EB',\n gold: '#FAAD14',\n lime: '#A0D911'\n};\nconst seedToken = _extends(_extends({}, defaultPresetColors), {\n // Color\n colorPrimary: '#1677ff',\n colorSuccess: '#52c41a',\n colorWarning: '#faad14',\n colorError: '#ff4d4f',\n colorInfo: '#1677ff',\n colorTextBase: '',\n colorBgBase: '',\n // Font\n fontFamily: `-apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial,\n'Noto Sans', sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol',\n'Noto Color Emoji'`,\n fontSize: 14,\n // Line\n lineWidth: 1,\n lineType: 'solid',\n // Motion\n motionUnit: 0.1,\n motionBase: 0,\n motionEaseOutCirc: 'cubic-bezier(0.08, 0.82, 0.17, 1)',\n motionEaseInOutCirc: 'cubic-bezier(0.78, 0.14, 0.15, 0.86)',\n motionEaseOut: 'cubic-bezier(0.215, 0.61, 0.355, 1)',\n motionEaseInOut: 'cubic-bezier(0.645, 0.045, 0.355, 1)',\n motionEaseOutBack: 'cubic-bezier(0.12, 0.4, 0.29, 1.46)',\n motionEaseInBack: 'cubic-bezier(0.71, -0.46, 0.88, 0.6)',\n motionEaseInQuint: 'cubic-bezier(0.755, 0.05, 0.855, 0.06)',\n motionEaseOutQuint: 'cubic-bezier(0.23, 1, 0.32, 1)',\n // Radius\n borderRadius: 6,\n // Size\n sizeUnit: 4,\n sizeStep: 4,\n sizePopupArrow: 16,\n // Control Base\n controlHeight: 32,\n // zIndex\n zIndexBase: 0,\n zIndexPopupBase: 1000,\n // Image\n opacityImage: 1,\n // Wireframe\n wireframe: false\n});\nexport default seedToken;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport { TinyColor } from '@ctrl/tinycolor';\nexport default function genColorMapToken(seed, _ref) {\n let {\n generateColorPalettes,\n generateNeutralColorPalettes\n } = _ref;\n const {\n colorSuccess: colorSuccessBase,\n colorWarning: colorWarningBase,\n colorError: colorErrorBase,\n colorInfo: colorInfoBase,\n colorPrimary: colorPrimaryBase,\n colorBgBase,\n colorTextBase\n } = seed;\n const primaryColors = generateColorPalettes(colorPrimaryBase);\n const successColors = generateColorPalettes(colorSuccessBase);\n const warningColors = generateColorPalettes(colorWarningBase);\n const errorColors = generateColorPalettes(colorErrorBase);\n const infoColors = generateColorPalettes(colorInfoBase);\n const neutralColors = generateNeutralColorPalettes(colorBgBase, colorTextBase);\n return _extends(_extends({}, neutralColors), {\n colorPrimaryBg: primaryColors[1],\n colorPrimaryBgHover: primaryColors[2],\n colorPrimaryBorder: primaryColors[3],\n colorPrimaryBorderHover: primaryColors[4],\n colorPrimaryHover: primaryColors[5],\n colorPrimary: primaryColors[6],\n colorPrimaryActive: primaryColors[7],\n colorPrimaryTextHover: primaryColors[8],\n colorPrimaryText: primaryColors[9],\n colorPrimaryTextActive: primaryColors[10],\n colorSuccessBg: successColors[1],\n colorSuccessBgHover: successColors[2],\n colorSuccessBorder: successColors[3],\n colorSuccessBorderHover: successColors[4],\n colorSuccessHover: successColors[4],\n colorSuccess: successColors[6],\n colorSuccessActive: successColors[7],\n colorSuccessTextHover: successColors[8],\n colorSuccessText: successColors[9],\n colorSuccessTextActive: successColors[10],\n colorErrorBg: errorColors[1],\n colorErrorBgHover: errorColors[2],\n colorErrorBorder: errorColors[3],\n colorErrorBorderHover: errorColors[4],\n colorErrorHover: errorColors[5],\n colorError: errorColors[6],\n colorErrorActive: errorColors[7],\n colorErrorTextHover: errorColors[8],\n colorErrorText: errorColors[9],\n colorErrorTextActive: errorColors[10],\n colorWarningBg: warningColors[1],\n colorWarningBgHover: warningColors[2],\n colorWarningBorder: warningColors[3],\n colorWarningBorderHover: warningColors[4],\n colorWarningHover: warningColors[4],\n colorWarning: warningColors[6],\n colorWarningActive: warningColors[7],\n colorWarningTextHover: warningColors[8],\n colorWarningText: warningColors[9],\n colorWarningTextActive: warningColors[10],\n colorInfoBg: infoColors[1],\n colorInfoBgHover: infoColors[2],\n colorInfoBorder: infoColors[3],\n colorInfoBorderHover: infoColors[4],\n colorInfoHover: infoColors[4],\n colorInfo: infoColors[6],\n colorInfoActive: infoColors[7],\n colorInfoTextHover: infoColors[8],\n colorInfoText: infoColors[9],\n colorInfoTextActive: infoColors[10],\n colorBgMask: new TinyColor('#000').setAlpha(0.45).toRgbString(),\n colorWhite: '#fff'\n });\n}","const genRadius = radiusBase => {\n let radiusLG = radiusBase;\n let radiusSM = radiusBase;\n let radiusXS = radiusBase;\n let radiusOuter = radiusBase;\n // radiusLG\n if (radiusBase < 6 && radiusBase >= 5) {\n radiusLG = radiusBase + 1;\n } else if (radiusBase < 16 && radiusBase >= 6) {\n radiusLG = radiusBase + 2;\n } else if (radiusBase >= 16) {\n radiusLG = 16;\n }\n // radiusSM\n if (radiusBase < 7 && radiusBase >= 5) {\n radiusSM = 4;\n } else if (radiusBase < 8 && radiusBase >= 7) {\n radiusSM = 5;\n } else if (radiusBase < 14 && radiusBase >= 8) {\n radiusSM = 6;\n } else if (radiusBase < 16 && radiusBase >= 14) {\n radiusSM = 7;\n } else if (radiusBase >= 16) {\n radiusSM = 8;\n }\n // radiusXS\n if (radiusBase < 6 && radiusBase >= 2) {\n radiusXS = 1;\n } else if (radiusBase >= 6) {\n radiusXS = 2;\n }\n // radiusOuter\n if (radiusBase > 4 && radiusBase < 8) {\n radiusOuter = 4;\n } else if (radiusBase >= 8) {\n radiusOuter = 6;\n }\n return {\n borderRadius: radiusBase > 16 ? 16 : radiusBase,\n borderRadiusXS: radiusXS,\n borderRadiusSM: radiusSM,\n borderRadiusLG: radiusLG,\n borderRadiusOuter: radiusOuter\n };\n};\nexport default genRadius;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport genRadius from './genRadius';\nexport default function genCommonMapToken(token) {\n const {\n motionUnit,\n motionBase,\n borderRadius,\n lineWidth\n } = token;\n return _extends({\n // motion\n motionDurationFast: `${(motionBase + motionUnit).toFixed(1)}s`,\n motionDurationMid: `${(motionBase + motionUnit * 2).toFixed(1)}s`,\n motionDurationSlow: `${(motionBase + motionUnit * 3).toFixed(1)}s`,\n // line\n lineWidthBold: lineWidth + 1\n }, genRadius(borderRadius));\n}","import { TinyColor } from '@ctrl/tinycolor';\nexport const getAlphaColor = (baseColor, alpha) => new TinyColor(baseColor).setAlpha(alpha).toRgbString();\nexport const getSolidColor = (baseColor, brightness) => {\n const instance = new TinyColor(baseColor);\n return instance.darken(brightness).toHexString();\n};","import { generate } from '@ant-design/colors';\nimport { getAlphaColor, getSolidColor } from './colorAlgorithm';\nexport const generateColorPalettes = baseColor => {\n const colors = generate(baseColor);\n return {\n 1: colors[0],\n 2: colors[1],\n 3: colors[2],\n 4: colors[3],\n 5: colors[4],\n 6: colors[5],\n 7: colors[6],\n 8: colors[4],\n 9: colors[5],\n 10: colors[6]\n // 8: colors[7],\n // 9: colors[8],\n // 10: colors[9],\n };\n};\nexport const generateNeutralColorPalettes = (bgBaseColor, textBaseColor) => {\n const colorBgBase = bgBaseColor || '#fff';\n const colorTextBase = textBaseColor || '#000';\n return {\n colorBgBase,\n colorTextBase,\n colorText: getAlphaColor(colorTextBase, 0.88),\n colorTextSecondary: getAlphaColor(colorTextBase, 0.65),\n colorTextTertiary: getAlphaColor(colorTextBase, 0.45),\n colorTextQuaternary: getAlphaColor(colorTextBase, 0.25),\n colorFill: getAlphaColor(colorTextBase, 0.15),\n colorFillSecondary: getAlphaColor(colorTextBase, 0.06),\n colorFillTertiary: getAlphaColor(colorTextBase, 0.04),\n colorFillQuaternary: getAlphaColor(colorTextBase, 0.02),\n colorBgLayout: getSolidColor(colorBgBase, 4),\n colorBgContainer: getSolidColor(colorBgBase, 0),\n colorBgElevated: getSolidColor(colorBgBase, 0),\n colorBgSpotlight: getAlphaColor(colorTextBase, 0.85),\n colorBorder: getSolidColor(colorBgBase, 15),\n colorBorderSecondary: getSolidColor(colorBgBase, 6)\n };\n};","// https://zhuanlan.zhihu.com/p/32746810\nexport default function getFontSizes(base) {\n const fontSizes = new Array(10).fill(null).map((_, index) => {\n const i = index - 1;\n const baseSize = base * Math.pow(2.71828, i / 5);\n const intSize = index > 1 ? Math.floor(baseSize) : Math.ceil(baseSize);\n // Convert to even\n return Math.floor(intSize / 2) * 2;\n });\n fontSizes[1] = base;\n return fontSizes.map(size => {\n const height = size + 8;\n return {\n size,\n lineHeight: height / size\n };\n });\n}","import genFontSizes from './genFontSizes';\nconst genFontMapToken = fontSize => {\n const fontSizePairs = genFontSizes(fontSize);\n const fontSizes = fontSizePairs.map(pair => pair.size);\n const lineHeights = fontSizePairs.map(pair => pair.lineHeight);\n return {\n fontSizeSM: fontSizes[0],\n fontSize: fontSizes[1],\n fontSizeLG: fontSizes[2],\n fontSizeXL: fontSizes[3],\n fontSizeHeading1: fontSizes[6],\n fontSizeHeading2: fontSizes[5],\n fontSizeHeading3: fontSizes[4],\n fontSizeHeading4: fontSizes[3],\n fontSizeHeading5: fontSizes[2],\n lineHeight: lineHeights[1],\n lineHeightLG: lineHeights[2],\n lineHeightSM: lineHeights[0],\n lineHeightHeading1: lineHeights[6],\n lineHeightHeading2: lineHeights[5],\n lineHeightHeading3: lineHeights[4],\n lineHeightHeading4: lineHeights[3],\n lineHeightHeading5: lineHeights[2]\n };\n};\nexport default genFontMapToken;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport { generate } from '@ant-design/colors';\nimport genControlHeight from '../shared/genControlHeight';\nimport genSizeMapToken from '../shared/genSizeMapToken';\nimport { defaultPresetColors } from '../seed';\nimport genColorMapToken from '../shared/genColorMapToken';\nimport genCommonMapToken from '../shared/genCommonMapToken';\nimport { generateColorPalettes, generateNeutralColorPalettes } from './colors';\nimport genFontMapToken from '../shared/genFontMapToken';\nexport default function derivative(token) {\n const colorPalettes = Object.keys(defaultPresetColors).map(colorKey => {\n const colors = generate(token[colorKey]);\n return new Array(10).fill(1).reduce((prev, _, i) => {\n prev[`${colorKey}-${i + 1}`] = colors[i];\n return prev;\n }, {});\n }).reduce((prev, cur) => {\n prev = _extends(_extends({}, prev), cur);\n return prev;\n }, {});\n return _extends(_extends(_extends(_extends(_extends(_extends(_extends({}, token), colorPalettes), genColorMapToken(token, {\n generateColorPalettes,\n generateNeutralColorPalettes\n })), genFontMapToken(token.fontSize)), genSizeMapToken(token)), genControlHeight(token)), genCommonMapToken(token));\n}","import { TinyColor } from '@ctrl/tinycolor';\nfunction isStableColor(color) {\n return color >= 0 && color <= 255;\n}\nfunction getAlphaColor(frontColor, backgroundColor) {\n const {\n r: fR,\n g: fG,\n b: fB,\n a: originAlpha\n } = new TinyColor(frontColor).toRgb();\n if (originAlpha < 1) {\n return frontColor;\n }\n const {\n r: bR,\n g: bG,\n b: bB\n } = new TinyColor(backgroundColor).toRgb();\n for (let fA = 0.01; fA <= 1; fA += 0.01) {\n const r = Math.round((fR - bR * (1 - fA)) / fA);\n const g = Math.round((fG - bG * (1 - fA)) / fA);\n const b = Math.round((fB - bB * (1 - fA)) / fA);\n if (isStableColor(r) && isStableColor(g) && isStableColor(b)) {\n return new TinyColor({\n r,\n g,\n b,\n a: Math.round(fA * 100) / 100\n }).toRgbString();\n }\n }\n // fallback\n /* istanbul ignore next */\n return new TinyColor({\n r: fR,\n g: fG,\n b: fB,\n a: 1\n }).toRgbString();\n}\nexport default getAlphaColor;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nvar __rest = this && this.__rest || function (s, e) {\n var t = {};\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];\n }\n return t;\n};\nimport { TinyColor } from '@ctrl/tinycolor';\nimport getAlphaColor from './getAlphaColor';\nimport seedToken from '../themes/seed';\n/**\n * Seed (designer) > Derivative (designer) > Alias (developer).\n *\n * Merge seed & derivative & override token and generate alias token for developer.\n */\nexport default function formatToken(derivativeToken) {\n const {\n override\n } = derivativeToken,\n restToken = __rest(derivativeToken, [\"override\"]);\n const overrideTokens = _extends({}, override);\n Object.keys(seedToken).forEach(token => {\n delete overrideTokens[token];\n });\n const mergedToken = _extends(_extends({}, restToken), overrideTokens);\n const screenXS = 480;\n const screenSM = 576;\n const screenMD = 768;\n const screenLG = 992;\n const screenXL = 1200;\n const screenXXL = 1600;\n const screenXXXL = 2000;\n // Generate alias token\n const aliasToken = _extends(_extends(_extends({}, mergedToken), {\n colorLink: mergedToken.colorInfoText,\n colorLinkHover: mergedToken.colorInfoHover,\n colorLinkActive: mergedToken.colorInfoActive,\n // ============== Background ============== //\n colorFillContent: mergedToken.colorFillSecondary,\n colorFillContentHover: mergedToken.colorFill,\n colorFillAlter: mergedToken.colorFillQuaternary,\n colorBgContainerDisabled: mergedToken.colorFillTertiary,\n // ============== Split ============== //\n colorBorderBg: mergedToken.colorBgContainer,\n colorSplit: getAlphaColor(mergedToken.colorBorderSecondary, mergedToken.colorBgContainer),\n // ============== Text ============== //\n colorTextPlaceholder: mergedToken.colorTextQuaternary,\n colorTextDisabled: mergedToken.colorTextQuaternary,\n colorTextHeading: mergedToken.colorText,\n colorTextLabel: mergedToken.colorTextSecondary,\n colorTextDescription: mergedToken.colorTextTertiary,\n colorTextLightSolid: mergedToken.colorWhite,\n colorHighlight: mergedToken.colorError,\n colorBgTextHover: mergedToken.colorFillSecondary,\n colorBgTextActive: mergedToken.colorFill,\n colorIcon: mergedToken.colorTextTertiary,\n colorIconHover: mergedToken.colorText,\n colorErrorOutline: getAlphaColor(mergedToken.colorErrorBg, mergedToken.colorBgContainer),\n colorWarningOutline: getAlphaColor(mergedToken.colorWarningBg, mergedToken.colorBgContainer),\n // Font\n fontSizeIcon: mergedToken.fontSizeSM,\n // Control\n lineWidth: mergedToken.lineWidth,\n controlOutlineWidth: mergedToken.lineWidth * 2,\n // Checkbox size and expand icon size\n controlInteractiveSize: mergedToken.controlHeight / 2,\n controlItemBgHover: mergedToken.colorFillTertiary,\n controlItemBgActive: mergedToken.colorPrimaryBg,\n controlItemBgActiveHover: mergedToken.colorPrimaryBgHover,\n controlItemBgActiveDisabled: mergedToken.colorFill,\n controlTmpOutline: mergedToken.colorFillQuaternary,\n controlOutline: getAlphaColor(mergedToken.colorPrimaryBg, mergedToken.colorBgContainer),\n lineType: mergedToken.lineType,\n borderRadius: mergedToken.borderRadius,\n borderRadiusXS: mergedToken.borderRadiusXS,\n borderRadiusSM: mergedToken.borderRadiusSM,\n borderRadiusLG: mergedToken.borderRadiusLG,\n fontWeightStrong: 600,\n opacityLoading: 0.65,\n linkDecoration: 'none',\n linkHoverDecoration: 'none',\n linkFocusDecoration: 'none',\n controlPaddingHorizontal: 12,\n controlPaddingHorizontalSM: 8,\n paddingXXS: mergedToken.sizeXXS,\n paddingXS: mergedToken.sizeXS,\n paddingSM: mergedToken.sizeSM,\n padding: mergedToken.size,\n paddingMD: mergedToken.sizeMD,\n paddingLG: mergedToken.sizeLG,\n paddingXL: mergedToken.sizeXL,\n paddingContentHorizontalLG: mergedToken.sizeLG,\n paddingContentVerticalLG: mergedToken.sizeMS,\n paddingContentHorizontal: mergedToken.sizeMS,\n paddingContentVertical: mergedToken.sizeSM,\n paddingContentHorizontalSM: mergedToken.size,\n paddingContentVerticalSM: mergedToken.sizeXS,\n marginXXS: mergedToken.sizeXXS,\n marginXS: mergedToken.sizeXS,\n marginSM: mergedToken.sizeSM,\n margin: mergedToken.size,\n marginMD: mergedToken.sizeMD,\n marginLG: mergedToken.sizeLG,\n marginXL: mergedToken.sizeXL,\n marginXXL: mergedToken.sizeXXL,\n boxShadow: `\n 0 1px 2px 0 rgba(0, 0, 0, 0.03),\n 0 1px 6px -1px rgba(0, 0, 0, 0.02),\n 0 2px 4px 0 rgba(0, 0, 0, 0.02)\n `,\n boxShadowSecondary: `\n 0 6px 16px 0 rgba(0, 0, 0, 0.08),\n 0 3px 6px -4px rgba(0, 0, 0, 0.12),\n 0 9px 28px 8px rgba(0, 0, 0, 0.05)\n `,\n boxShadowTertiary: `\n 0 1px 2px 0 rgba(0, 0, 0, 0.03),\n 0 1px 6px -1px rgba(0, 0, 0, 0.02),\n 0 2px 4px 0 rgba(0, 0, 0, 0.02)\n `,\n screenXS,\n screenXSMin: screenXS,\n screenXSMax: screenSM - 1,\n screenSM,\n screenSMMin: screenSM,\n screenSMMax: screenMD - 1,\n screenMD,\n screenMDMin: screenMD,\n screenMDMax: screenLG - 1,\n screenLG,\n screenLGMin: screenLG,\n screenLGMax: screenXL - 1,\n screenXL,\n screenXLMin: screenXL,\n screenXLMax: screenXXL - 1,\n screenXXL,\n screenXXLMin: screenXXL,\n screenXXLMax: screenXXXL - 1,\n screenXXXL,\n screenXXXLMin: screenXXXL,\n // FIXME: component box-shadow, should be removed\n boxShadowPopoverArrow: '3px 3px 7px rgba(0, 0, 0, 0.1)',\n boxShadowCard: `\n 0 1px 2px -2px ${new TinyColor('rgba(0, 0, 0, 0.16)').toRgbString()},\n 0 3px 6px 0 ${new TinyColor('rgba(0, 0, 0, 0.12)').toRgbString()},\n 0 5px 12px 4px ${new TinyColor('rgba(0, 0, 0, 0.09)').toRgbString()}\n `,\n boxShadowDrawerRight: `\n -6px 0 16px 0 rgba(0, 0, 0, 0.08),\n -3px 0 6px -4px rgba(0, 0, 0, 0.12),\n -9px 0 28px 8px rgba(0, 0, 0, 0.05)\n `,\n boxShadowDrawerLeft: `\n 6px 0 16px 0 rgba(0, 0, 0, 0.08),\n 3px 0 6px -4px rgba(0, 0, 0, 0.12),\n 9px 0 28px 8px rgba(0, 0, 0, 0.05)\n `,\n boxShadowDrawerUp: `\n 0 6px 16px 0 rgba(0, 0, 0, 0.08),\n 0 3px 6px -4px rgba(0, 0, 0, 0.12),\n 0 9px 28px 8px rgba(0, 0, 0, 0.05)\n `,\n boxShadowDrawerDown: `\n 0 -6px 16px 0 rgba(0, 0, 0, 0.08),\n 0 -3px 6px -4px rgba(0, 0, 0, 0.12),\n 0 -9px 28px 8px rgba(0, 0, 0, 0.05)\n `,\n boxShadowTabsOverflowLeft: 'inset 10px 0 8px -8px rgba(0, 0, 0, 0.08)',\n boxShadowTabsOverflowRight: 'inset -10px 0 8px -8px rgba(0, 0, 0, 0.08)',\n boxShadowTabsOverflowTop: 'inset 0 10px 8px -8px rgba(0, 0, 0, 0.08)',\n boxShadowTabsOverflowBottom: 'inset 0 -10px 8px -8px rgba(0, 0, 0, 0.08)'\n }), overrideTokens);\n return aliasToken;\n}","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport { createTheme, useCacheToken, useStyleRegister } from '../_util/cssinjs';\nimport version from '../version';\nimport { PresetColors } from './interface';\nimport defaultDerivative from './themes/default';\nimport defaultSeedToken from './themes/seed';\nimport formatToken from './util/alias';\nimport genComponentStyleHook from './util/genComponentStyleHook';\nimport statisticToken, { merge as mergeToken, statistic } from './util/statistic';\nimport { objectType } from '../_util/type';\nimport { triggerRef, unref, defineComponent, provide, computed, inject, watch, shallowRef } from 'vue';\nconst defaultTheme = createTheme(defaultDerivative);\nexport {\n// colors\nPresetColors,\n// Statistic\nstatistic, statisticToken, mergeToken,\n// hooks\nuseStyleRegister, genComponentStyleHook };\n// ================================ Context =================================\n// To ensure snapshot stable. We disable hashed in test env.\nexport const defaultConfig = {\n token: defaultSeedToken,\n hashed: true\n};\n//defaultConfig\nconst DesignTokenContextKey = Symbol('DesignTokenContext');\nexport const globalDesignTokenApi = shallowRef();\nexport const useDesignTokenProvider = value => {\n provide(DesignTokenContextKey, value);\n watch(value, () => {\n globalDesignTokenApi.value = unref(value);\n triggerRef(globalDesignTokenApi);\n }, {\n immediate: true,\n deep: true\n });\n};\nexport const useDesignTokenInject = () => {\n return inject(DesignTokenContextKey, computed(() => globalDesignTokenApi.value || defaultConfig));\n};\nexport const DesignTokenProvider = defineComponent({\n props: {\n value: objectType()\n },\n setup(props, _ref) {\n let {\n slots\n } = _ref;\n useDesignTokenProvider(computed(() => props.value));\n return () => {\n var _a;\n return (_a = slots.default) === null || _a === void 0 ? void 0 : _a.call(slots);\n };\n }\n});\n// ================================== Hook ==================================\nexport function useToken() {\n const designTokenContext = inject(DesignTokenContextKey, computed(() => globalDesignTokenApi.value || defaultConfig));\n const salt = computed(() => `${version}-${designTokenContext.value.hashed || ''}`);\n const mergedTheme = computed(() => designTokenContext.value.theme || defaultTheme);\n const cacheToken = useCacheToken(mergedTheme, computed(() => [defaultSeedToken, designTokenContext.value.token]), computed(() => ({\n salt: salt.value,\n override: _extends({\n override: designTokenContext.value.token\n }, designTokenContext.value.components),\n formatToken\n })));\n return [mergedTheme, computed(() => cacheToken.value[0]), computed(() => designTokenContext.value.hashed ? cacheToken.value[1] : '')];\n}","import { createVNode as _createVNode } from \"vue\";\nimport { useToken } from '../theme/internal';\nimport { TinyColor } from '@ctrl/tinycolor';\nimport { defineComponent, computed } from 'vue';\nconst Empty = defineComponent({\n compatConfig: {\n MODE: 3\n },\n setup() {\n const [, token] = useToken();\n const themeStyle = computed(() => {\n const bgColor = new TinyColor(token.value.colorBgBase);\n // Dark Theme need more dark of this\n if (bgColor.toHsl().l < 0.5) {\n return {\n opacity: 0.65\n };\n }\n return {};\n });\n return () => _createVNode(\"svg\", {\n \"style\": themeStyle.value,\n \"width\": \"184\",\n \"height\": \"152\",\n \"viewBox\": \"0 0 184 152\",\n \"xmlns\": \"http://www.w3.org/2000/svg\"\n }, [_createVNode(\"g\", {\n \"fill\": \"none\",\n \"fill-rule\": \"evenodd\"\n }, [_createVNode(\"g\", {\n \"transform\": \"translate(24 31.67)\"\n }, [_createVNode(\"ellipse\", {\n \"fill-opacity\": \".8\",\n \"fill\": \"#F5F5F7\",\n \"cx\": \"67.797\",\n \"cy\": \"106.89\",\n \"rx\": \"67.797\",\n \"ry\": \"12.668\"\n }, null), _createVNode(\"path\", {\n \"d\": \"M122.034 69.674L98.109 40.229c-1.148-1.386-2.826-2.225-4.593-2.225h-51.44c-1.766 0-3.444.839-4.592 2.225L13.56 69.674v15.383h108.475V69.674z\",\n \"fill\": \"#AEB8C2\"\n }, null), _createVNode(\"path\", {\n \"d\": \"M101.537 86.214L80.63 61.102c-1.001-1.207-2.507-1.867-4.048-1.867H31.724c-1.54 0-3.047.66-4.048 1.867L6.769 86.214v13.792h94.768V86.214z\",\n \"fill\": \"url(#linearGradient-1)\",\n \"transform\": \"translate(13.56)\"\n }, null), _createVNode(\"path\", {\n \"d\": \"M33.83 0h67.933a4 4 0 0 1 4 4v93.344a4 4 0 0 1-4 4H33.83a4 4 0 0 1-4-4V4a4 4 0 0 1 4-4z\",\n \"fill\": \"#F5F5F7\"\n }, null), _createVNode(\"path\", {\n \"d\": \"M42.678 9.953h50.237a2 2 0 0 1 2 2V36.91a2 2 0 0 1-2 2H42.678a2 2 0 0 1-2-2V11.953a2 2 0 0 1 2-2zM42.94 49.767h49.713a2.262 2.262 0 1 1 0 4.524H42.94a2.262 2.262 0 0 1 0-4.524zM42.94 61.53h49.713a2.262 2.262 0 1 1 0 4.525H42.94a2.262 2.262 0 0 1 0-4.525zM121.813 105.032c-.775 3.071-3.497 5.36-6.735 5.36H20.515c-3.238 0-5.96-2.29-6.734-5.36a7.309 7.309 0 0 1-.222-1.79V69.675h26.318c2.907 0 5.25 2.448 5.25 5.42v.04c0 2.971 2.37 5.37 5.277 5.37h34.785c2.907 0 5.277-2.421 5.277-5.393V75.1c0-2.972 2.343-5.426 5.25-5.426h26.318v33.569c0 .617-.077 1.216-.221 1.789z\",\n \"fill\": \"#DCE0E6\"\n }, null)]), _createVNode(\"path\", {\n \"d\": \"M149.121 33.292l-6.83 2.65a1 1 0 0 1-1.317-1.23l1.937-6.207c-2.589-2.944-4.109-6.534-4.109-10.408C138.802 8.102 148.92 0 161.402 0 173.881 0 184 8.102 184 18.097c0 9.995-10.118 18.097-22.599 18.097-4.528 0-8.744-1.066-12.28-2.902z\",\n \"fill\": \"#DCE0E6\"\n }, null), _createVNode(\"g\", {\n \"transform\": \"translate(149.65 15.383)\",\n \"fill\": \"#FFF\"\n }, [_createVNode(\"ellipse\", {\n \"cx\": \"20.654\",\n \"cy\": \"3.167\",\n \"rx\": \"2.849\",\n \"ry\": \"2.815\"\n }, null), _createVNode(\"path\", {\n \"d\": \"M5.698 5.63H0L2.898.704zM9.259.704h4.985V5.63H9.259z\"\n }, null)])])]);\n }\n});\nEmpty.PRESENTED_IMAGE_DEFAULT = true;\nexport default Empty;","import { createVNode as _createVNode } from \"vue\";\nimport { TinyColor } from '@ctrl/tinycolor';\nimport { computed, defineComponent } from 'vue';\nimport { useToken } from '../theme/internal';\nconst Simple = defineComponent({\n compatConfig: {\n MODE: 3\n },\n setup() {\n const [, token] = useToken();\n const color = computed(() => {\n const {\n colorFill,\n colorFillTertiary,\n colorFillQuaternary,\n colorBgContainer\n } = token.value;\n return {\n borderColor: new TinyColor(colorFill).onBackground(colorBgContainer).toHexString(),\n shadowColor: new TinyColor(colorFillTertiary).onBackground(colorBgContainer).toHexString(),\n contentColor: new TinyColor(colorFillQuaternary).onBackground(colorBgContainer).toHexString()\n };\n });\n return () => _createVNode(\"svg\", {\n \"width\": \"64\",\n \"height\": \"41\",\n \"viewBox\": \"0 0 64 41\",\n \"xmlns\": \"http://www.w3.org/2000/svg\"\n }, [_createVNode(\"g\", {\n \"transform\": \"translate(0 1)\",\n \"fill\": \"none\",\n \"fill-rule\": \"evenodd\"\n }, [_createVNode(\"ellipse\", {\n \"fill\": color.value.shadowColor,\n \"cx\": \"32\",\n \"cy\": \"33\",\n \"rx\": \"32\",\n \"ry\": \"7\"\n }, null), _createVNode(\"g\", {\n \"fill-rule\": \"nonzero\",\n \"stroke\": color.value.borderColor\n }, [_createVNode(\"path\", {\n \"d\": \"M55 12.76L44.854 1.258C44.367.474 43.656 0 42.907 0H21.093c-.749 0-1.46.474-1.947 1.257L9 12.761V22h46v-9.24z\"\n }, null), _createVNode(\"path\", {\n \"d\": \"M41.613 15.931c0-1.605.994-2.93 2.227-2.931H55v18.137C55 33.26 53.68 35 52.05 35h-40.1C10.32 35 9 33.259 9 31.137V13h11.16c1.233 0 2.227 1.323 2.227 2.928v.022c0 1.605 1.005 2.901 2.237 2.901h14.752c1.232 0 2.237-1.308 2.237-2.913v-.007z\",\n \"fill\": color.value.contentColor\n }, null)])])]);\n }\n});\nSimple.PRESENTED_IMAGE_SIMPLE = true;\nexport default Simple;","var unitlessKeys = {\n animationIterationCount: 1,\n aspectRatio: 1,\n borderImageOutset: 1,\n borderImageSlice: 1,\n borderImageWidth: 1,\n boxFlex: 1,\n boxFlexGroup: 1,\n boxOrdinalGroup: 1,\n columnCount: 1,\n columns: 1,\n flex: 1,\n flexGrow: 1,\n flexPositive: 1,\n flexShrink: 1,\n flexNegative: 1,\n flexOrder: 1,\n gridRow: 1,\n gridRowEnd: 1,\n gridRowSpan: 1,\n gridRowStart: 1,\n gridColumn: 1,\n gridColumnEnd: 1,\n gridColumnSpan: 1,\n gridColumnStart: 1,\n msGridRow: 1,\n msGridRowSpan: 1,\n msGridColumn: 1,\n msGridColumnSpan: 1,\n fontWeight: 1,\n lineHeight: 1,\n opacity: 1,\n order: 1,\n orphans: 1,\n tabSize: 1,\n widows: 1,\n zIndex: 1,\n zoom: 1,\n WebkitLineClamp: 1,\n // SVG-related properties\n fillOpacity: 1,\n floodOpacity: 1,\n stopOpacity: 1,\n strokeDasharray: 1,\n strokeDashoffset: 1,\n strokeMiterlimit: 1,\n strokeOpacity: 1,\n strokeWidth: 1\n};\n\nexport { unitlessKeys as default };\n","export var MS = '-ms-'\nexport var MOZ = '-moz-'\nexport var WEBKIT = '-webkit-'\n\nexport var COMMENT = 'comm'\nexport var RULESET = 'rule'\nexport var DECLARATION = 'decl'\n\nexport var PAGE = '@page'\nexport var MEDIA = '@media'\nexport var IMPORT = '@import'\nexport var CHARSET = '@charset'\nexport var VIEWPORT = '@viewport'\nexport var SUPPORTS = '@supports'\nexport var DOCUMENT = '@document'\nexport var NAMESPACE = '@namespace'\nexport var KEYFRAMES = '@keyframes'\nexport var FONT_FACE = '@font-face'\nexport var COUNTER_STYLE = '@counter-style'\nexport var FONT_FEATURE_VALUES = '@font-feature-values'\nexport var LAYER = '@layer'\n","/**\n * @param {number}\n * @return {number}\n */\nexport var abs = Math.abs\n\n/**\n * @param {number}\n * @return {string}\n */\nexport var from = String.fromCharCode\n\n/**\n * @param {object}\n * @return {object}\n */\nexport var assign = Object.assign\n\n/**\n * @param {string} value\n * @param {number} length\n * @return {number}\n */\nexport function hash (value, length) {\n\treturn charat(value, 0) ^ 45 ? (((((((length << 2) ^ charat(value, 0)) << 2) ^ charat(value, 1)) << 2) ^ charat(value, 2)) << 2) ^ charat(value, 3) : 0\n}\n\n/**\n * @param {string} value\n * @return {string}\n */\nexport function trim (value) {\n\treturn value.trim()\n}\n\n/**\n * @param {string} value\n * @param {RegExp} pattern\n * @return {string?}\n */\nexport function match (value, pattern) {\n\treturn (value = pattern.exec(value)) ? value[0] : value\n}\n\n/**\n * @param {string} value\n * @param {(string|RegExp)} pattern\n * @param {string} replacement\n * @return {string}\n */\nexport function replace (value, pattern, replacement) {\n\treturn value.replace(pattern, replacement)\n}\n\n/**\n * @param {string} value\n * @param {string} search\n * @param {number} position\n * @return {number}\n */\nexport function indexof (value, search, position) {\n\treturn value.indexOf(search, position)\n}\n\n/**\n * @param {string} value\n * @param {number} index\n * @return {number}\n */\nexport function charat (value, index) {\n\treturn value.charCodeAt(index) | 0\n}\n\n/**\n * @param {string} value\n * @param {number} begin\n * @param {number} end\n * @return {string}\n */\nexport function substr (value, begin, end) {\n\treturn value.slice(begin, end)\n}\n\n/**\n * @param {string} value\n * @return {number}\n */\nexport function strlen (value) {\n\treturn value.length\n}\n\n/**\n * @param {any[]} value\n * @return {number}\n */\nexport function sizeof (value) {\n\treturn value.length\n}\n\n/**\n * @param {any} value\n * @param {any[]} array\n * @return {any}\n */\nexport function append (value, array) {\n\treturn array.push(value), value\n}\n\n/**\n * @param {string[]} array\n * @param {function} callback\n * @return {string}\n */\nexport function combine (array, callback) {\n\treturn array.map(callback).join('')\n}\n\n/**\n * @param {string[]} array\n * @param {RegExp} pattern\n * @return {string[]}\n */\nexport function filter (array, pattern) {\n\treturn array.filter(function (value) { return !match(value, pattern) })\n}\n","import {IMPORT, LAYER, COMMENT, RULESET, DECLARATION, KEYFRAMES} from './Enum.js'\nimport {strlen} from './Utility.js'\n\n/**\n * @param {object[]} children\n * @param {function} callback\n * @return {string}\n */\nexport function serialize (children, callback) {\n\tvar output = ''\n\n\tfor (var i = 0; i < children.length; i++)\n\t\toutput += callback(children[i], i, children, callback) || ''\n\n\treturn output\n}\n\n/**\n * @param {object} element\n * @param {number} index\n * @param {object[]} children\n * @param {function} callback\n * @return {string}\n */\nexport function stringify (element, index, children, callback) {\n\tswitch (element.type) {\n\t\tcase LAYER: if (element.children.length) break\n\t\tcase IMPORT: case DECLARATION: return element.return = element.return || element.value\n\t\tcase COMMENT: return ''\n\t\tcase KEYFRAMES: return element.return = element.value + '{' + serialize(element.children, callback) + '}'\n\t\tcase RULESET: if (!strlen(element.value = element.props.join(','))) return ''\n\t}\n\n\treturn strlen(children = serialize(element.children, callback)) ? element.return = element.value + '{' + children + '}' : ''\n}\n","import {from, trim, charat, strlen, substr, append, assign} from './Utility.js'\n\nexport var line = 1\nexport var column = 1\nexport var length = 0\nexport var position = 0\nexport var character = 0\nexport var characters = ''\n\n/**\n * @param {string} value\n * @param {object | null} root\n * @param {object | null} parent\n * @param {string} type\n * @param {string[] | string} props\n * @param {object[] | string} children\n * @param {object[]} siblings\n * @param {number} length\n */\nexport function node (value, root, parent, type, props, children, length, siblings) {\n\treturn {value: value, root: root, parent: parent, type: type, props: props, children: children, line: line, column: column, length: length, return: '', siblings: siblings}\n}\n\n/**\n * @param {object} root\n * @param {object} props\n * @return {object}\n */\nexport function copy (root, props) {\n\treturn assign(node('', null, null, '', null, null, 0, root.siblings), root, {length: -root.length}, props)\n}\n\n/**\n * @param {object} root\n */\nexport function lift (root) {\n\twhile (root.root)\n\t\troot = copy(root.root, {children: [root]})\n\n\tappend(root, root.siblings)\n}\n\n/**\n * @return {number}\n */\nexport function char () {\n\treturn character\n}\n\n/**\n * @return {number}\n */\nexport function prev () {\n\tcharacter = position > 0 ? charat(characters, --position) : 0\n\n\tif (column--, character === 10)\n\t\tcolumn = 1, line--\n\n\treturn character\n}\n\n/**\n * @return {number}\n */\nexport function next () {\n\tcharacter = position < length ? charat(characters, position++) : 0\n\n\tif (column++, character === 10)\n\t\tcolumn = 1, line++\n\n\treturn character\n}\n\n/**\n * @return {number}\n */\nexport function peek () {\n\treturn charat(characters, position)\n}\n\n/**\n * @return {number}\n */\nexport function caret () {\n\treturn position\n}\n\n/**\n * @param {number} begin\n * @param {number} end\n * @return {string}\n */\nexport function slice (begin, end) {\n\treturn substr(characters, begin, end)\n}\n\n/**\n * @param {number} type\n * @return {number}\n */\nexport function token (type) {\n\tswitch (type) {\n\t\t// \\0 \\t \\n \\r \\s whitespace token\n\t\tcase 0: case 9: case 10: case 13: case 32:\n\t\t\treturn 5\n\t\t// ! + , / > @ ~ isolate token\n\t\tcase 33: case 43: case 44: case 47: case 62: case 64: case 126:\n\t\t// ; { } breakpoint token\n\t\tcase 59: case 123: case 125:\n\t\t\treturn 4\n\t\t// : accompanied token\n\t\tcase 58:\n\t\t\treturn 3\n\t\t// \" ' ( [ opening delimit token\n\t\tcase 34: case 39: case 40: case 91:\n\t\t\treturn 2\n\t\t// ) ] closing delimit token\n\t\tcase 41: case 93:\n\t\t\treturn 1\n\t}\n\n\treturn 0\n}\n\n/**\n * @param {string} value\n * @return {any[]}\n */\nexport function alloc (value) {\n\treturn line = column = 1, length = strlen(characters = value), position = 0, []\n}\n\n/**\n * @param {any} value\n * @return {any}\n */\nexport function dealloc (value) {\n\treturn characters = '', value\n}\n\n/**\n * @param {number} type\n * @return {string}\n */\nexport function delimit (type) {\n\treturn trim(slice(position - 1, delimiter(type === 91 ? type + 2 : type === 40 ? type + 1 : type)))\n}\n\n/**\n * @param {string} value\n * @return {string[]}\n */\nexport function tokenize (value) {\n\treturn dealloc(tokenizer(alloc(value)))\n}\n\n/**\n * @param {number} type\n * @return {string}\n */\nexport function whitespace (type) {\n\twhile (character = peek())\n\t\tif (character < 33)\n\t\t\tnext()\n\t\telse\n\t\t\tbreak\n\n\treturn token(type) > 2 || token(character) > 3 ? '' : ' '\n}\n\n/**\n * @param {string[]} children\n * @return {string[]}\n */\nexport function tokenizer (children) {\n\twhile (next())\n\t\tswitch (token(character)) {\n\t\t\tcase 0: append(identifier(position - 1), children)\n\t\t\t\tbreak\n\t\t\tcase 2: append(delimit(character), children)\n\t\t\t\tbreak\n\t\t\tdefault: append(from(character), children)\n\t\t}\n\n\treturn children\n}\n\n/**\n * @param {number} index\n * @param {number} count\n * @return {string}\n */\nexport function escaping (index, count) {\n\twhile (--count && next())\n\t\t// not 0-9 A-F a-f\n\t\tif (character < 48 || character > 102 || (character > 57 && character < 65) || (character > 70 && character < 97))\n\t\t\tbreak\n\n\treturn slice(index, caret() + (count < 6 && peek() == 32 && next() == 32))\n}\n\n/**\n * @param {number} type\n * @return {number}\n */\nexport function delimiter (type) {\n\twhile (next())\n\t\tswitch (character) {\n\t\t\t// ] ) \" '\n\t\t\tcase type:\n\t\t\t\treturn position\n\t\t\t// \" '\n\t\t\tcase 34: case 39:\n\t\t\t\tif (type !== 34 && type !== 39)\n\t\t\t\t\tdelimiter(character)\n\t\t\t\tbreak\n\t\t\t// (\n\t\t\tcase 40:\n\t\t\t\tif (type === 41)\n\t\t\t\t\tdelimiter(type)\n\t\t\t\tbreak\n\t\t\t// \\\n\t\t\tcase 92:\n\t\t\t\tnext()\n\t\t\t\tbreak\n\t\t}\n\n\treturn position\n}\n\n/**\n * @param {number} type\n * @param {number} index\n * @return {number}\n */\nexport function commenter (type, index) {\n\twhile (next())\n\t\t// //\n\t\tif (type + character === 47 + 10)\n\t\t\tbreak\n\t\t// /*\n\t\telse if (type + character === 42 + 42 && peek() === 47)\n\t\t\tbreak\n\n\treturn '/*' + slice(index, position - 1) + '*' + from(type === 47 ? type : next())\n}\n\n/**\n * @param {number} index\n * @return {string}\n */\nexport function identifier (index) {\n\twhile (!token(peek()))\n\t\tnext()\n\n\treturn slice(index, position)\n}\n","import {COMMENT, RULESET, DECLARATION} from './Enum.js'\nimport {abs, charat, trim, from, sizeof, strlen, substr, append, replace, indexof} from './Utility.js'\nimport {node, char, prev, next, peek, caret, alloc, dealloc, delimit, whitespace, escaping, identifier, commenter} from './Tokenizer.js'\n\n/**\n * @param {string} value\n * @return {object[]}\n */\nexport function compile (value) {\n\treturn dealloc(parse('', null, null, null, [''], value = alloc(value), 0, [0], value))\n}\n\n/**\n * @param {string} value\n * @param {object} root\n * @param {object?} parent\n * @param {string[]} rule\n * @param {string[]} rules\n * @param {string[]} rulesets\n * @param {number[]} pseudo\n * @param {number[]} points\n * @param {string[]} declarations\n * @return {object}\n */\nexport function parse (value, root, parent, rule, rules, rulesets, pseudo, points, declarations) {\n\tvar index = 0\n\tvar offset = 0\n\tvar length = pseudo\n\tvar atrule = 0\n\tvar property = 0\n\tvar previous = 0\n\tvar variable = 1\n\tvar scanning = 1\n\tvar ampersand = 1\n\tvar character = 0\n\tvar type = ''\n\tvar props = rules\n\tvar children = rulesets\n\tvar reference = rule\n\tvar characters = type\n\n\twhile (scanning)\n\t\tswitch (previous = character, character = next()) {\n\t\t\t// (\n\t\t\tcase 40:\n\t\t\t\tif (previous != 108 && charat(characters, length - 1) == 58) {\n\t\t\t\t\tif (indexof(characters += replace(delimit(character), '&', '&\\f'), '&\\f', abs(index ? points[index - 1] : 0)) != -1)\n\t\t\t\t\t\tampersand = -1\n\t\t\t\t\tbreak\n\t\t\t\t}\n\t\t\t// \" ' [\n\t\t\tcase 34: case 39: case 91:\n\t\t\t\tcharacters += delimit(character)\n\t\t\t\tbreak\n\t\t\t// \\t \\n \\r \\s\n\t\t\tcase 9: case 10: case 13: case 32:\n\t\t\t\tcharacters += whitespace(previous)\n\t\t\t\tbreak\n\t\t\t// \\\n\t\t\tcase 92:\n\t\t\t\tcharacters += escaping(caret() - 1, 7)\n\t\t\t\tcontinue\n\t\t\t// /\n\t\t\tcase 47:\n\t\t\t\tswitch (peek()) {\n\t\t\t\t\tcase 42: case 47:\n\t\t\t\t\t\tappend(comment(commenter(next(), caret()), root, parent, declarations), declarations)\n\t\t\t\t\t\tbreak\n\t\t\t\t\tdefault:\n\t\t\t\t\t\tcharacters += '/'\n\t\t\t\t}\n\t\t\t\tbreak\n\t\t\t// {\n\t\t\tcase 123 * variable:\n\t\t\t\tpoints[index++] = strlen(characters) * ampersand\n\t\t\t// } ; \\0\n\t\t\tcase 125 * variable: case 59: case 0:\n\t\t\t\tswitch (character) {\n\t\t\t\t\t// \\0 }\n\t\t\t\t\tcase 0: case 125: scanning = 0\n\t\t\t\t\t// ;\n\t\t\t\t\tcase 59 + offset: if (ampersand == -1) characters = replace(characters, /\\f/g, '')\n\t\t\t\t\t\tif (property > 0 && (strlen(characters) - length))\n\t\t\t\t\t\t\tappend(property > 32 ? declaration(characters + ';', rule, parent, length - 1, declarations) : declaration(replace(characters, ' ', '') + ';', rule, parent, length - 2, declarations), declarations)\n\t\t\t\t\t\tbreak\n\t\t\t\t\t// @ ;\n\t\t\t\t\tcase 59: characters += ';'\n\t\t\t\t\t// { rule/at-rule\n\t\t\t\t\tdefault:\n\t\t\t\t\t\tappend(reference = ruleset(characters, root, parent, index, offset, rules, points, type, props = [], children = [], length, rulesets), rulesets)\n\n\t\t\t\t\t\tif (character === 123)\n\t\t\t\t\t\t\tif (offset === 0)\n\t\t\t\t\t\t\t\tparse(characters, root, reference, reference, props, rulesets, length, points, children)\n\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\tswitch (atrule === 99 && charat(characters, 3) === 110 ? 100 : atrule) {\n\t\t\t\t\t\t\t\t\t// d l m s\n\t\t\t\t\t\t\t\t\tcase 100: case 108: case 109: case 115:\n\t\t\t\t\t\t\t\t\t\tparse(value, reference, reference, rule && append(ruleset(value, reference, reference, 0, 0, rules, points, type, rules, props = [], length, children), children), rules, children, length, points, rule ? props : children)\n\t\t\t\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\t\t\t\tparse(characters, reference, reference, reference, [''], children, 0, points, children)\n\t\t\t\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tindex = offset = property = 0, variable = ampersand = 1, type = characters = '', length = pseudo\n\t\t\t\tbreak\n\t\t\t// :\n\t\t\tcase 58:\n\t\t\t\tlength = 1 + strlen(characters), property = previous\n\t\t\tdefault:\n\t\t\t\tif (variable < 1)\n\t\t\t\t\tif (character == 123)\n\t\t\t\t\t\t--variable\n\t\t\t\t\telse if (character == 125 && variable++ == 0 && prev() == 125)\n\t\t\t\t\t\tcontinue\n\n\t\t\t\tswitch (characters += from(character), character * variable) {\n\t\t\t\t\t// &\n\t\t\t\t\tcase 38:\n\t\t\t\t\t\tampersand = offset > 0 ? 1 : (characters += '\\f', -1)\n\t\t\t\t\t\tbreak\n\t\t\t\t\t// ,\n\t\t\t\t\tcase 44:\n\t\t\t\t\t\tpoints[index++] = (strlen(characters) - 1) * ampersand, ampersand = 1\n\t\t\t\t\t\tbreak\n\t\t\t\t\t// @\n\t\t\t\t\tcase 64:\n\t\t\t\t\t\t// -\n\t\t\t\t\t\tif (peek() === 45)\n\t\t\t\t\t\t\tcharacters += delimit(next())\n\n\t\t\t\t\t\tatrule = peek(), offset = length = strlen(type = characters += identifier(caret())), character++\n\t\t\t\t\t\tbreak\n\t\t\t\t\t// -\n\t\t\t\t\tcase 45:\n\t\t\t\t\t\tif (previous === 45 && strlen(characters) == 2)\n\t\t\t\t\t\t\tvariable = 0\n\t\t\t\t}\n\t\t}\n\n\treturn rulesets\n}\n\n/**\n * @param {string} value\n * @param {object} root\n * @param {object?} parent\n * @param {number} index\n * @param {number} offset\n * @param {string[]} rules\n * @param {number[]} points\n * @param {string} type\n * @param {string[]} props\n * @param {string[]} children\n * @param {number} length\n * @param {object[]} siblings\n * @return {object}\n */\nexport function ruleset (value, root, parent, index, offset, rules, points, type, props, children, length, siblings) {\n\tvar post = offset - 1\n\tvar rule = offset === 0 ? rules : ['']\n\tvar size = sizeof(rule)\n\n\tfor (var i = 0, j = 0, k = 0; i < index; ++i)\n\t\tfor (var x = 0, y = substr(value, post + 1, post = abs(j = points[i])), z = value; x < size; ++x)\n\t\t\tif (z = trim(j > 0 ? rule[x] + ' ' + y : replace(y, /&\\f/g, rule[x])))\n\t\t\t\tprops[k++] = z\n\n\treturn node(value, root, parent, offset === 0 ? RULESET : type, props, children, length, siblings)\n}\n\n/**\n * @param {number} value\n * @param {object} root\n * @param {object?} parent\n * @param {object[]} siblings\n * @return {object}\n */\nexport function comment (value, root, parent, siblings) {\n\treturn node(value, root, parent, COMMENT, from(char()), substr(value, 2, -2), 0, siblings)\n}\n\n/**\n * @param {string} value\n * @param {object} root\n * @param {object?} parent\n * @param {number} length\n * @param {object[]} siblings\n * @return {object}\n */\nexport function declaration (value, root, parent, length, siblings) {\n\treturn node(value, root, parent, DECLARATION, substr(value, 0, length), substr(value, length + 1, -1), length, siblings)\n}\n","import canUseDom from '../../../../_util/canUseDom';\nimport { ATTR_MARK } from '../../StyleContext';\nexport const ATTR_CACHE_MAP = 'data-ant-cssinjs-cache-path';\n/**\n * This marks style from the css file.\n * Which means not exist in `` tag.\n */\nexport const CSS_FILE_STYLE = '_FILE_STYLE__';\nexport function serialize(cachePathMap) {\n return Object.keys(cachePathMap).map(path => {\n const hash = cachePathMap[path];\n return `${path}:${hash}`;\n }).join(';');\n}\nlet cachePathMap;\nlet fromCSSFile = true;\n/**\n * @private Test usage only. Can save remove if no need.\n */\nexport function reset(mockCache) {\n let fromFile = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;\n cachePathMap = mockCache;\n fromCSSFile = fromFile;\n}\nexport function prepare() {\n var _a;\n if (!cachePathMap) {\n cachePathMap = {};\n if (canUseDom()) {\n const div = document.createElement('div');\n div.className = ATTR_CACHE_MAP;\n div.style.position = 'fixed';\n div.style.visibility = 'hidden';\n div.style.top = '-9999px';\n document.body.appendChild(div);\n let content = getComputedStyle(div).content || '';\n content = content.replace(/^\"/, '').replace(/\"$/, '');\n // Fill data\n content.split(';').forEach(item => {\n const [path, hash] = item.split(':');\n cachePathMap[path] = hash;\n });\n // Remove inline record style\n const inlineMapStyle = document.querySelector(`style[${ATTR_CACHE_MAP}]`);\n if (inlineMapStyle) {\n fromCSSFile = false;\n (_a = inlineMapStyle.parentNode) === null || _a === void 0 ? void 0 : _a.removeChild(inlineMapStyle);\n }\n document.body.removeChild(div);\n }\n }\n}\nexport function existPath(path) {\n prepare();\n return !!cachePathMap[path];\n}\nexport function getStyleAndHash(path) {\n const hash = cachePathMap[path];\n let styleStr = null;\n if (hash && canUseDom()) {\n if (fromCSSFile) {\n styleStr = CSS_FILE_STYLE;\n } else {\n const style = document.querySelector(`style[${ATTR_MARK}=\"${cachePathMap[path]}\"]`);\n if (style) {\n styleStr = style.innerHTML;\n } else {\n // Clean up since not exist anymore\n delete cachePathMap[path];\n }\n }\n }\n return [styleStr, hash];\n}","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport hash from '@emotion/hash';\n// @ts-ignore\nimport unitless from '@emotion/unitless';\nimport { compile, serialize, stringify } from 'stylis';\nimport { contentQuotesLinter, hashedAnimationLinter } from '../../linters';\nimport { useStyleInject, ATTR_CACHE_PATH, ATTR_MARK, ATTR_TOKEN, CSS_IN_JS_INSTANCE } from '../../StyleContext';\nimport { supportLayer } from '../../util';\nimport useGlobalCache from '../useGlobalCache';\nimport { removeCSS, updateCSS } from '../../../../vc-util/Dom/dynamicCSS';\nimport { computed } from 'vue';\nimport canUseDom from '../../../../_util/canUseDom';\nimport { ATTR_CACHE_MAP, existPath, getStyleAndHash, serialize as serializeCacheMap } from './cacheMapUtil';\nconst isClientSide = canUseDom();\nconst SKIP_CHECK = '_skip_check_';\nconst MULTI_VALUE = '_multi_value_';\n// ============================================================================\n// == Parser ==\n// ============================================================================\n// Preprocessor style content to browser support one\nexport function normalizeStyle(styleStr) {\n const serialized = serialize(compile(styleStr), stringify);\n return serialized.replace(/\\{%%%\\:[^;];}/g, ';');\n}\nfunction isCompoundCSSProperty(value) {\n return typeof value === 'object' && value && (SKIP_CHECK in value || MULTI_VALUE in value);\n}\n// 注入 hash 值\nfunction injectSelectorHash(key, hashId, hashPriority) {\n if (!hashId) {\n return key;\n }\n const hashClassName = `.${hashId}`;\n const hashSelector = hashPriority === 'low' ? `:where(${hashClassName})` : hashClassName;\n // 注入 hashId\n const keys = key.split(',').map(k => {\n var _a;\n const fullPath = k.trim().split(/\\s+/);\n // 如果 Selector 第一个是 HTML Element,那我们就插到它的后面。反之,就插到最前面。\n let firstPath = fullPath[0] || '';\n const htmlElement = ((_a = firstPath.match(/^\\w+/)) === null || _a === void 0 ? void 0 : _a[0]) || '';\n firstPath = `${htmlElement}${hashSelector}${firstPath.slice(htmlElement.length)}`;\n return [firstPath, ...fullPath.slice(1)].join(' ');\n });\n return keys.join(',');\n}\n// Global effect style will mount once and not removed\n// The effect will not save in SSR cache (e.g. keyframes)\nconst globalEffectStyleKeys = new Set();\n/**\n * @private Test only. Clear the global effect style keys.\n */\nexport const _cf = process.env.NODE_ENV !== 'production' ? () => globalEffectStyleKeys.clear() : undefined;\n// Parse CSSObject to style content\nexport const parseStyle = function (interpolation) {\n let config = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n let {\n root,\n injectHash,\n parentSelectors\n } = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {\n root: true,\n parentSelectors: []\n };\n const {\n hashId,\n layer,\n path,\n hashPriority,\n transformers = [],\n linters = []\n } = config;\n let styleStr = '';\n let effectStyle = {};\n function parseKeyframes(keyframes) {\n const animationName = keyframes.getName(hashId);\n if (!effectStyle[animationName]) {\n const [parsedStr] = parseStyle(keyframes.style, config, {\n root: false,\n parentSelectors\n });\n effectStyle[animationName] = `@keyframes ${keyframes.getName(hashId)}${parsedStr}`;\n }\n }\n function flattenList(list) {\n let fullList = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];\n list.forEach(item => {\n if (Array.isArray(item)) {\n flattenList(item, fullList);\n } else if (item) {\n fullList.push(item);\n }\n });\n return fullList;\n }\n const flattenStyleList = flattenList(Array.isArray(interpolation) ? interpolation : [interpolation]);\n flattenStyleList.forEach(originStyle => {\n // Only root level can use raw string\n const style = typeof originStyle === 'string' && !root ? {} : originStyle;\n if (typeof style === 'string') {\n styleStr += `${style}\\n`;\n } else if (style._keyframe) {\n // Keyframe\n parseKeyframes(style);\n } else {\n const mergedStyle = transformers.reduce((prev, trans) => {\n var _a;\n return ((_a = trans === null || trans === void 0 ? void 0 : trans.visit) === null || _a === void 0 ? void 0 : _a.call(trans, prev)) || prev;\n }, style);\n // Normal CSSObject\n Object.keys(mergedStyle).forEach(key => {\n var _a;\n const value = mergedStyle[key];\n if (typeof value === 'object' && value && (key !== 'animationName' || !value._keyframe) && !isCompoundCSSProperty(value)) {\n let subInjectHash = false;\n // 当成嵌套对象来处理\n let mergedKey = key.trim();\n // Whether treat child as root. In most case it is false.\n let nextRoot = false;\n // 拆分多个选择器\n if ((root || injectHash) && hashId) {\n if (mergedKey.startsWith('@')) {\n // 略过媒体查询,交给子节点继续插入 hashId\n subInjectHash = true;\n } else {\n // 注入 hashId\n mergedKey = injectSelectorHash(key, hashId, hashPriority);\n }\n } else if (root && !hashId && (mergedKey === '&' || mergedKey === '')) {\n // In case of `{ '&': { a: { color: 'red' } } }` or `{ '': { a: { color: 'red' } } }` without hashId,\n // we will get `&{a:{color:red;}}` or `{a:{color:red;}}` string for stylis to compile.\n // But it does not conform to stylis syntax,\n // and finally we will get `{color:red;}` as css, which is wrong.\n // So we need to remove key in root, and treat child `{ a: { color: 'red' } }` as root.\n mergedKey = '';\n nextRoot = true;\n }\n const [parsedStr, childEffectStyle] = parseStyle(value, config, {\n root: nextRoot,\n injectHash: subInjectHash,\n parentSelectors: [...parentSelectors, mergedKey]\n });\n effectStyle = _extends(_extends({}, effectStyle), childEffectStyle);\n styleStr += `${mergedKey}${parsedStr}`;\n } else {\n function appendStyle(cssKey, cssValue) {\n if (process.env.NODE_ENV !== 'production' && (typeof value !== 'object' || !(value === null || value === void 0 ? void 0 : value[SKIP_CHECK]))) {\n [contentQuotesLinter, hashedAnimationLinter, ...linters].forEach(linter => linter(cssKey, cssValue, {\n path,\n hashId,\n parentSelectors\n }));\n }\n // 如果是样式则直接插入\n const styleName = cssKey.replace(/[A-Z]/g, match => `-${match.toLowerCase()}`);\n // Auto suffix with px\n let formatValue = cssValue;\n if (!unitless[cssKey] && typeof formatValue === 'number' && formatValue !== 0) {\n formatValue = `${formatValue}px`;\n }\n // handle animationName & Keyframe value\n if (cssKey === 'animationName' && (cssValue === null || cssValue === void 0 ? void 0 : cssValue._keyframe)) {\n parseKeyframes(cssValue);\n formatValue = cssValue.getName(hashId);\n }\n styleStr += `${styleName}:${formatValue};`;\n }\n const actualValue = (_a = value === null || value === void 0 ? void 0 : value.value) !== null && _a !== void 0 ? _a : value;\n if (typeof value === 'object' && (value === null || value === void 0 ? void 0 : value[MULTI_VALUE]) && Array.isArray(actualValue)) {\n actualValue.forEach(item => {\n appendStyle(key, item);\n });\n } else {\n appendStyle(key, actualValue);\n }\n }\n });\n }\n });\n if (!root) {\n styleStr = `{${styleStr}}`;\n } else if (layer && supportLayer()) {\n const layerCells = layer.split(',');\n const layerName = layerCells[layerCells.length - 1].trim();\n styleStr = `@layer ${layerName} {${styleStr}}`;\n // Order of layer if needed\n if (layerCells.length > 1) {\n // zombieJ: stylis do not support layer order, so we need to handle it manually.\n styleStr = `@layer ${layer}{%%%:%}${styleStr}`;\n }\n }\n return [styleStr, effectStyle];\n};\n// ============================================================================\n// == Register ==\n// ============================================================================\nfunction uniqueHash(path, styleStr) {\n return hash(`${path.join('%')}${styleStr}`);\n}\n// function Empty() {\n// return null;\n// }\n/**\n * Register a style to the global style sheet.\n */\nexport default function useStyleRegister(info, styleFn) {\n const styleContext = useStyleInject();\n const tokenKey = computed(() => info.value.token._tokenKey);\n const fullPath = computed(() => [tokenKey.value, ...info.value.path]);\n // Check if need insert style\n let isMergedClientSide = isClientSide;\n if (process.env.NODE_ENV !== 'production' && styleContext.value.mock !== undefined) {\n isMergedClientSide = styleContext.value.mock === 'client';\n }\n // const [cacheStyle[0], cacheStyle[1], cacheStyle[2]]\n useGlobalCache('style', fullPath,\n // Create cache if needed\n () => {\n const {\n path,\n hashId,\n layer,\n nonce,\n clientOnly,\n order = 0\n } = info.value;\n const cachePath = fullPath.value.join('|');\n // Get style from SSR inline style directly\n if (existPath(cachePath)) {\n const [inlineCacheStyleStr, styleHash] = getStyleAndHash(cachePath);\n if (inlineCacheStyleStr) {\n return [inlineCacheStyleStr, tokenKey.value, styleHash, {}, clientOnly, order];\n }\n }\n const styleObj = styleFn();\n const {\n hashPriority,\n container,\n transformers,\n linters,\n cache\n } = styleContext.value;\n const [parsedStyle, effectStyle] = parseStyle(styleObj, {\n hashId,\n hashPriority,\n layer,\n path: path.join('-'),\n transformers,\n linters\n });\n const styleStr = normalizeStyle(parsedStyle);\n const styleId = uniqueHash(fullPath.value, styleStr);\n if (isMergedClientSide) {\n const mergedCSSConfig = {\n mark: ATTR_MARK,\n prepend: 'queue',\n attachTo: container,\n priority: order\n };\n const nonceStr = typeof nonce === 'function' ? nonce() : nonce;\n if (nonceStr) {\n mergedCSSConfig.csp = {\n nonce: nonceStr\n };\n }\n const style = updateCSS(styleStr, styleId, mergedCSSConfig);\n style[CSS_IN_JS_INSTANCE] = cache.instanceId;\n // Used for `useCacheToken` to remove on batch when token removed\n style.setAttribute(ATTR_TOKEN, tokenKey.value);\n // Dev usage to find which cache path made this easily\n if (process.env.NODE_ENV !== 'production') {\n style.setAttribute(ATTR_CACHE_PATH, fullPath.value.join('|'));\n }\n // Inject client side effect style\n Object.keys(effectStyle).forEach(effectKey => {\n if (!globalEffectStyleKeys.has(effectKey)) {\n globalEffectStyleKeys.add(effectKey);\n // Inject\n updateCSS(normalizeStyle(effectStyle[effectKey]), `_effect-${effectKey}`, {\n mark: ATTR_MARK,\n prepend: 'queue',\n attachTo: container\n });\n }\n });\n }\n return [styleStr, tokenKey.value, styleId, effectStyle, clientOnly, order];\n },\n // Remove cache if no need\n (_ref, fromHMR) => {\n let [,, styleId] = _ref;\n if ((fromHMR || styleContext.value.autoClear) && isClientSide) {\n removeCSS(styleId, {\n mark: ATTR_MARK\n });\n }\n });\n return node => {\n return node;\n // let styleNode: VueNode;\n // if (!styleContext.ssrInline || isMergedClientSide || !styleContext.defaultCache) {\n // styleNode = ;\n // } else {\n // styleNode = (\n // \n // );\n // }\n // return (\n // <>\n // {styleNode}\n // {node}\n // >\n // );\n };\n}\n// ============================================================================\n// == SSR ==\n// ============================================================================\nexport function extractStyle(cache) {\n let plain = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;\n const matchPrefix = `style%`;\n // prefix with `style` is used for `useStyleRegister` to cache style context\n const styleKeys = Array.from(cache.cache.keys()).filter(key => key.startsWith(matchPrefix));\n // Common effect styles like animation\n const effectStyles = {};\n // Mapping of cachePath to style hash\n const cachePathMap = {};\n let styleText = '';\n function toStyleStr(style, tokenKey, styleId) {\n let customizeAttrs = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {};\n const attrs = _extends(_extends({}, customizeAttrs), {\n [ATTR_TOKEN]: tokenKey,\n [ATTR_MARK]: styleId\n });\n const attrStr = Object.keys(attrs).map(attr => {\n const val = attrs[attr];\n return val ? `${attr}=\"${val}\"` : null;\n }).filter(v => v).join(' ');\n return plain ? style : ``;\n }\n const orderStyles = styleKeys.map(key => {\n const cachePath = key.slice(matchPrefix.length).replace(/%/g, '|');\n const [styleStr, tokenKey, styleId, effectStyle, clientOnly, order] = cache.cache.get(key)[1];\n // Skip client only style\n if (clientOnly) {\n return null;\n }\n // ====================== Style ======================\n // Used for vc-util\n const sharedAttrs = {\n 'data-vc-order': 'prependQueue',\n 'data-vc-priority': `${order}`\n };\n let keyStyleText = toStyleStr(styleStr, tokenKey, styleId, sharedAttrs);\n // Save cache path with hash mapping\n cachePathMap[cachePath] = styleId;\n // =============== Create effect style ===============\n if (effectStyle) {\n Object.keys(effectStyle).forEach(effectKey => {\n // Effect style can be reused\n if (!effectStyles[effectKey]) {\n effectStyles[effectKey] = true;\n keyStyleText += toStyleStr(normalizeStyle(effectStyle[effectKey]), tokenKey, `_effect-${effectKey}`, sharedAttrs);\n }\n });\n }\n const ret = [order, keyStyleText];\n return ret;\n }).filter(o => o);\n orderStyles.sort((o1, o2) => o1[0] - o2[0]).forEach(_ref2 => {\n let [, style] = _ref2;\n styleText += style;\n });\n // ==================== Fill Cache Path ====================\n styleText += toStyleStr(`.${ATTR_CACHE_MAP}{content:\"${serializeCacheMap(cachePathMap)}\";}`, undefined, undefined, {\n [ATTR_CACHE_MAP]: ATTR_CACHE_MAP\n });\n return styleText;\n}","import _extends from \"@babel/runtime/helpers/esm/extends\";\nexport { operationUnit } from './operationUnit';\nexport { roundedArrow } from './roundedArrow';\nexport { genPresetColor } from './presetColor';\nexport const textEllipsis = {\n overflow: 'hidden',\n whiteSpace: 'nowrap',\n textOverflow: 'ellipsis'\n};\nexport const resetComponent = token => ({\n boxSizing: 'border-box',\n margin: 0,\n padding: 0,\n color: token.colorText,\n fontSize: token.fontSize,\n // font-variant: @font-variant-base;\n lineHeight: token.lineHeight,\n listStyle: 'none',\n // font-feature-settings: @font-feature-settings-base;\n fontFamily: token.fontFamily\n});\nexport const resetIcon = () => ({\n display: 'inline-flex',\n alignItems: 'center',\n color: 'inherit',\n fontStyle: 'normal',\n lineHeight: 0,\n textAlign: 'center',\n textTransform: 'none',\n // for SVG icon, see https://blog.prototypr.io/align-svg-icons-to-text-and-say-goodbye-to-font-icons-d44b3d7b26b4\n verticalAlign: '-0.125em',\n textRendering: 'optimizeLegibility',\n '-webkit-font-smoothing': 'antialiased',\n '-moz-osx-font-smoothing': 'grayscale',\n '> *': {\n lineHeight: 1\n },\n svg: {\n display: 'inline-block'\n }\n});\nexport const clearFix = () => ({\n // https://github.com/ant-design/ant-design/issues/21301#issuecomment-583955229\n '&::before': {\n display: 'table',\n content: '\"\"'\n },\n '&::after': {\n // https://github.com/ant-design/ant-design/issues/21864\n display: 'table',\n clear: 'both',\n content: '\"\"'\n }\n});\nexport const genLinkStyle = token => ({\n a: {\n color: token.colorLink,\n textDecoration: token.linkDecoration,\n backgroundColor: 'transparent',\n outline: 'none',\n cursor: 'pointer',\n transition: `color ${token.motionDurationSlow}`,\n '-webkit-text-decoration-skip': 'objects',\n '&:hover': {\n color: token.colorLinkHover\n },\n '&:active': {\n color: token.colorLinkActive\n },\n [`&:active,\n &:hover`]: {\n textDecoration: token.linkHoverDecoration,\n outline: 0\n },\n // https://github.com/ant-design/ant-design/issues/22503\n '&:focus': {\n textDecoration: token.linkFocusDecoration,\n outline: 0\n },\n '&[disabled]': {\n color: token.colorTextDisabled,\n cursor: 'not-allowed'\n }\n }\n});\nexport const genCommonStyle = (token, componentPrefixCls) => {\n const {\n fontFamily,\n fontSize\n } = token;\n const rootPrefixSelector = `[class^=\"${componentPrefixCls}\"], [class*=\" ${componentPrefixCls}\"]`;\n return {\n [rootPrefixSelector]: {\n fontFamily,\n fontSize,\n boxSizing: 'border-box',\n '&::before, &::after': {\n boxSizing: 'border-box'\n },\n [rootPrefixSelector]: {\n boxSizing: 'border-box',\n '&::before, &::after': {\n boxSizing: 'border-box'\n }\n }\n }\n };\n};\nexport const genFocusOutline = token => ({\n outline: `${token.lineWidthBold}px solid ${token.colorPrimaryBorder}`,\n outlineOffset: 1,\n transition: 'outline-offset 0s, outline 0s'\n});\nexport const genFocusStyle = token => ({\n '&:focus-visible': _extends({}, genFocusOutline(token))\n});","import _extends from \"@babel/runtime/helpers/esm/extends\";\nconst enableStatistic = process.env.NODE_ENV !== 'production' || typeof CSSINJS_STATISTIC !== 'undefined';\nlet recording = true;\n/**\n * This function will do as `Object.assign` in production. But will use Object.defineProperty:get to\n * pass all value access in development. To support statistic field usage with alias token.\n */\nexport function merge() {\n for (var _len = arguments.length, objs = new Array(_len), _key = 0; _key < _len; _key++) {\n objs[_key] = arguments[_key];\n }\n /* istanbul ignore next */\n if (!enableStatistic) {\n return _extends({}, ...objs);\n }\n recording = false;\n const ret = {};\n objs.forEach(obj => {\n const keys = Object.keys(obj);\n keys.forEach(key => {\n Object.defineProperty(ret, key, {\n configurable: true,\n enumerable: true,\n get: () => obj[key]\n });\n });\n });\n recording = true;\n return ret;\n}\n/** @private Internal Usage. Not use in your production. */\nexport const statistic = {};\n/** @private Internal Usage. Not use in your production. */\n// eslint-disable-next-line camelcase\nexport const _statistic_build_ = {};\n/* istanbul ignore next */\nfunction noop() {}\n/** Statistic token usage case. Should use `merge` function if you do not want spread record. */\nexport default function statisticToken(token) {\n let tokenKeys;\n let proxy = token;\n let flush = noop;\n if (enableStatistic) {\n tokenKeys = new Set();\n proxy = new Proxy(token, {\n get(obj, prop) {\n if (recording) {\n tokenKeys.add(prop);\n }\n return obj[prop];\n }\n });\n flush = (componentName, componentToken) => {\n statistic[componentName] = {\n global: Array.from(tokenKeys),\n component: componentToken\n };\n };\n }\n return {\n token: proxy,\n keys: tokenKeys,\n flush\n };\n}","import _extends from \"@babel/runtime/helpers/esm/extends\";\n/* eslint-disable no-redeclare */\nimport { useStyleRegister } from '../../_util/cssinjs';\nimport { genCommonStyle, genLinkStyle } from '../../style';\nimport { mergeToken, statisticToken, useToken } from '../internal';\nimport { computed } from 'vue';\nimport { useConfigContextInject } from '../../config-provider/context';\nexport default function genComponentStyleHook(component, styleFn, getDefaultToken) {\n return _prefixCls => {\n const prefixCls = computed(() => _prefixCls === null || _prefixCls === void 0 ? void 0 : _prefixCls.value);\n const [theme, token, hashId] = useToken();\n const {\n getPrefixCls,\n iconPrefixCls\n } = useConfigContextInject();\n const rootPrefixCls = computed(() => getPrefixCls());\n const sharedInfo = computed(() => {\n return {\n theme: theme.value,\n token: token.value,\n hashId: hashId.value,\n path: ['Shared', rootPrefixCls.value]\n };\n });\n // Generate style for all a tags in antd component.\n useStyleRegister(sharedInfo, () => [{\n // Link\n '&': genLinkStyle(token.value)\n }]);\n const componentInfo = computed(() => {\n return {\n theme: theme.value,\n token: token.value,\n hashId: hashId.value,\n path: [component, prefixCls.value, iconPrefixCls.value]\n };\n });\n return [useStyleRegister(componentInfo, () => {\n const {\n token: proxyToken,\n flush\n } = statisticToken(token.value);\n const defaultComponentToken = typeof getDefaultToken === 'function' ? getDefaultToken(proxyToken) : getDefaultToken;\n const mergedComponentToken = _extends(_extends({}, defaultComponentToken), token.value[component]);\n const componentCls = `.${prefixCls.value}`;\n const mergedToken = mergeToken(proxyToken, {\n componentCls,\n prefixCls: prefixCls.value,\n iconCls: `.${iconPrefixCls.value}`,\n antCls: `.${rootPrefixCls.value}`\n }, mergedComponentToken);\n const styleInterpolation = styleFn(mergedToken, {\n hashId: hashId.value,\n prefixCls: prefixCls.value,\n rootPrefixCls: rootPrefixCls.value,\n iconPrefixCls: iconPrefixCls.value,\n overrideComponentToken: token.value[component]\n });\n flush(component, mergedComponentToken);\n return [genCommonStyle(token.value, prefixCls.value), styleInterpolation];\n }), hashId];\n };\n}","import { genComponentStyleHook, mergeToken } from '../../theme/internal';\n// ============================== Shared ==============================\nconst genSharedEmptyStyle = token => {\n const {\n componentCls,\n margin,\n marginXS,\n marginXL,\n fontSize,\n lineHeight\n } = token;\n return {\n [componentCls]: {\n marginInline: marginXS,\n fontSize,\n lineHeight,\n textAlign: 'center',\n // 原来 &-image 没有父子结构,现在为了外层承担我们的hashId,改成父子结果\n [`${componentCls}-image`]: {\n height: token.emptyImgHeight,\n marginBottom: marginXS,\n opacity: token.opacityImage,\n img: {\n height: '100%'\n },\n svg: {\n height: '100%',\n margin: 'auto'\n }\n },\n // 原来 &-footer 没有父子结构,现在为了外层承担我们的hashId,改成父子结果\n [`${componentCls}-footer`]: {\n marginTop: margin\n },\n '&-normal': {\n marginBlock: marginXL,\n color: token.colorTextDisabled,\n [`${componentCls}-image`]: {\n height: token.emptyImgHeightMD\n }\n },\n '&-small': {\n marginBlock: marginXS,\n color: token.colorTextDisabled,\n [`${componentCls}-image`]: {\n height: token.emptyImgHeightSM\n }\n }\n }\n };\n};\n// ============================== Export ==============================\nexport default genComponentStyleHook('Empty', token => {\n const {\n componentCls,\n controlHeightLG\n } = token;\n const emptyToken = mergeToken(token, {\n emptyImgCls: `${componentCls}-img`,\n emptyImgHeight: controlHeightLG * 2.5,\n emptyImgHeightMD: controlHeightLG,\n emptyImgHeightSM: controlHeightLG * 0.875\n });\n return [genSharedEmptyStyle(emptyToken)];\n});","import _objectSpread from \"@babel/runtime/helpers/esm/objectSpread2\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport { createVNode as _createVNode } from \"vue\";\nvar __rest = this && this.__rest || function (s, e) {\n var t = {};\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];\n }\n return t;\n};\nimport { defineComponent } from 'vue';\nimport classNames from '../_util/classNames';\nimport LocaleReceiver from '../locale-provider/LocaleReceiver';\nimport DefaultEmptyImg from './empty';\nimport SimpleEmptyImg from './simple';\nimport { filterEmpty } from '../_util/props-util';\nimport { anyType, objectType, withInstall } from '../_util/type';\nimport useConfigInject from '../config-provider/hooks/useConfigInject';\nimport useStyle from './style';\nconst defaultEmptyImg = _createVNode(DefaultEmptyImg, null, null);\nconst simpleEmptyImg = _createVNode(SimpleEmptyImg, null, null);\nexport const emptyProps = () => ({\n prefixCls: String,\n imageStyle: objectType(),\n image: anyType(),\n description: anyType()\n});\nconst Empty = defineComponent({\n name: 'AEmpty',\n compatConfig: {\n MODE: 3\n },\n inheritAttrs: false,\n props: emptyProps(),\n setup(props, _ref) {\n let {\n slots = {},\n attrs\n } = _ref;\n const {\n direction,\n prefixCls: prefixClsRef\n } = useConfigInject('empty', props);\n const [wrapSSR, hashId] = useStyle(prefixClsRef);\n return () => {\n var _a, _b;\n const prefixCls = prefixClsRef.value;\n const _c = _extends(_extends({}, props), attrs),\n {\n image = ((_a = slots.image) === null || _a === void 0 ? void 0 : _a.call(slots)) || defaultEmptyImg,\n description = ((_b = slots.description) === null || _b === void 0 ? void 0 : _b.call(slots)) || undefined,\n imageStyle,\n class: className = ''\n } = _c,\n restProps = __rest(_c, [\"image\", \"description\", \"imageStyle\", \"class\"]);\n return wrapSSR(_createVNode(LocaleReceiver, {\n \"componentName\": \"Empty\",\n \"children\": locale => {\n const des = typeof description !== 'undefined' ? description : locale.description;\n const alt = typeof des === 'string' ? des : 'empty';\n let imageNode = null;\n if (typeof image === 'string') {\n imageNode = _createVNode(\"img\", {\n \"alt\": alt,\n \"src\": image\n }, null);\n } else {\n imageNode = image;\n }\n return _createVNode(\"div\", _objectSpread({\n \"class\": classNames(prefixCls, className, hashId.value, {\n [`${prefixCls}-normal`]: image === simpleEmptyImg,\n [`${prefixCls}-rtl`]: direction.value === 'rtl'\n })\n }, restProps), [_createVNode(\"div\", {\n \"class\": `${prefixCls}-image`,\n \"style\": imageStyle\n }, [imageNode]), des && _createVNode(\"p\", {\n \"class\": `${prefixCls}-description`\n }, [des]), slots.default && _createVNode(\"div\", {\n \"class\": `${prefixCls}-footer`\n }, [filterEmpty(slots.default())])]);\n }\n }, null));\n };\n }\n});\nEmpty.PRESENTED_IMAGE_DEFAULT = defaultEmptyImg;\nEmpty.PRESENTED_IMAGE_SIMPLE = simpleEmptyImg;\nexport default withInstall(Empty);","import { createVNode as _createVNode } from \"vue\";\nimport Empty from '../empty';\nimport useConfigInject from './hooks/useConfigInject';\nexport const DefaultRenderEmpty = props => {\n const {\n prefixCls\n } = useConfigInject('empty', props);\n const renderHtml = componentName => {\n switch (componentName) {\n case 'Table':\n case 'List':\n return _createVNode(Empty, {\n \"image\": Empty.PRESENTED_IMAGE_SIMPLE\n }, null);\n case 'Select':\n case 'TreeSelect':\n case 'Cascader':\n case 'Transfer':\n case 'Mentions':\n return _createVNode(Empty, {\n \"image\": Empty.PRESENTED_IMAGE_SIMPLE,\n \"class\": `${prefixCls.value}-small`\n }, null);\n default:\n return _createVNode(Empty, null, null);\n }\n };\n return renderHtml(props.componentName);\n};\nfunction renderEmpty(componentName) {\n return _createVNode(DefaultRenderEmpty, {\n \"componentName\": componentName\n }, null);\n}\nexport default renderEmpty;","import { computed, inject, ref, provide } from 'vue';\nconst SizeContextKey = Symbol('SizeContextKey');\nexport const useInjectSize = () => {\n return inject(SizeContextKey, ref(undefined));\n};\nexport const useProviderSize = size => {\n const parentSize = useInjectSize();\n provide(SizeContextKey, computed(() => size.value || parentSize.value));\n return size;\n};","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport { computed, h, inject } from 'vue';\nimport { defaultConfigProvider, configProviderKey } from '../context';\nimport { useInjectDisabled } from '../DisabledContext';\nimport { DefaultRenderEmpty } from '../renderEmpty';\nimport { useInjectSize } from '../SizeContext';\nexport default ((name, props) => {\n const sizeContext = useInjectSize();\n const disabledContext = useInjectDisabled();\n const configProvider = inject(configProviderKey, _extends(_extends({}, defaultConfigProvider), {\n renderEmpty: name => h(DefaultRenderEmpty, {\n componentName: name\n })\n }));\n const prefixCls = computed(() => configProvider.getPrefixCls(name, props.prefixCls));\n const direction = computed(() => {\n var _a, _b;\n return (_a = props.direction) !== null && _a !== void 0 ? _a : (_b = configProvider.direction) === null || _b === void 0 ? void 0 : _b.value;\n });\n const iconPrefixCls = computed(() => {\n var _a;\n return (_a = props.iconPrefixCls) !== null && _a !== void 0 ? _a : configProvider.iconPrefixCls.value;\n });\n const rootPrefixCls = computed(() => configProvider.getPrefixCls());\n const autoInsertSpaceInButton = computed(() => {\n var _a;\n return (_a = configProvider.autoInsertSpaceInButton) === null || _a === void 0 ? void 0 : _a.value;\n });\n const renderEmpty = configProvider.renderEmpty;\n const space = configProvider.space;\n const pageHeader = configProvider.pageHeader;\n const form = configProvider.form;\n const getTargetContainer = computed(() => {\n var _a, _b;\n return (_a = props.getTargetContainer) !== null && _a !== void 0 ? _a : (_b = configProvider.getTargetContainer) === null || _b === void 0 ? void 0 : _b.value;\n });\n const getPopupContainer = computed(() => {\n var _a, _b, _c;\n return (_b = (_a = props.getContainer) !== null && _a !== void 0 ? _a : props.getPopupContainer) !== null && _b !== void 0 ? _b : (_c = configProvider.getPopupContainer) === null || _c === void 0 ? void 0 : _c.value;\n });\n const dropdownMatchSelectWidth = computed(() => {\n var _a, _b;\n return (_a = props.dropdownMatchSelectWidth) !== null && _a !== void 0 ? _a : (_b = configProvider.dropdownMatchSelectWidth) === null || _b === void 0 ? void 0 : _b.value;\n });\n const virtual = computed(() => {\n var _a;\n return (props.virtual === undefined ? ((_a = configProvider.virtual) === null || _a === void 0 ? void 0 : _a.value) !== false : props.virtual !== false) && dropdownMatchSelectWidth.value !== false;\n });\n const size = computed(() => props.size || sizeContext.value);\n const autocomplete = computed(() => {\n var _a, _b, _c;\n return (_a = props.autocomplete) !== null && _a !== void 0 ? _a : (_c = (_b = configProvider.input) === null || _b === void 0 ? void 0 : _b.value) === null || _c === void 0 ? void 0 : _c.autocomplete;\n });\n const disabled = computed(() => {\n var _a;\n return (_a = props.disabled) !== null && _a !== void 0 ? _a : disabledContext.value;\n });\n const csp = computed(() => {\n var _a;\n return (_a = props.csp) !== null && _a !== void 0 ? _a : configProvider.csp;\n });\n const wave = computed(() => {\n var _a, _b;\n return (_a = props.wave) !== null && _a !== void 0 ? _a : (_b = configProvider.wave) === null || _b === void 0 ? void 0 : _b.value;\n });\n return {\n configProvider,\n prefixCls,\n direction,\n size,\n getTargetContainer,\n getPopupContainer,\n space,\n pageHeader,\n form,\n autoInsertSpaceInButton,\n renderEmpty,\n virtual,\n dropdownMatchSelectWidth,\n rootPrefixCls,\n getPrefixCls: configProvider.getPrefixCls,\n autocomplete,\n csp,\n iconPrefixCls,\n disabled,\n select: configProvider.select,\n wave\n };\n});","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport { placements } from '../vc-tooltip/src/placements';\nconst autoAdjustOverflowEnabled = {\n adjustX: 1,\n adjustY: 1\n};\nconst autoAdjustOverflowDisabled = {\n adjustX: 0,\n adjustY: 0\n};\nconst targetOffset = [0, 0];\nexport function getOverflowOptions(autoAdjustOverflow) {\n if (typeof autoAdjustOverflow === 'boolean') {\n return autoAdjustOverflow ? autoAdjustOverflowEnabled : autoAdjustOverflowDisabled;\n }\n return _extends(_extends({}, autoAdjustOverflowDisabled), autoAdjustOverflow);\n}\nexport default function getPlacements(config) {\n const {\n arrowWidth = 4,\n horizontalArrowShift = 16,\n verticalArrowShift = 8,\n autoAdjustOverflow,\n arrowPointAtCenter\n } = config;\n const placementMap = {\n left: {\n points: ['cr', 'cl'],\n offset: [-4, 0]\n },\n right: {\n points: ['cl', 'cr'],\n offset: [4, 0]\n },\n top: {\n points: ['bc', 'tc'],\n offset: [0, -4]\n },\n bottom: {\n points: ['tc', 'bc'],\n offset: [0, 4]\n },\n topLeft: {\n points: ['bl', 'tc'],\n offset: [-(horizontalArrowShift + arrowWidth), -4]\n },\n leftTop: {\n points: ['tr', 'cl'],\n offset: [-4, -(verticalArrowShift + arrowWidth)]\n },\n topRight: {\n points: ['br', 'tc'],\n offset: [horizontalArrowShift + arrowWidth, -4]\n },\n rightTop: {\n points: ['tl', 'cr'],\n offset: [4, -(verticalArrowShift + arrowWidth)]\n },\n bottomRight: {\n points: ['tr', 'bc'],\n offset: [horizontalArrowShift + arrowWidth, 4]\n },\n rightBottom: {\n points: ['bl', 'cr'],\n offset: [4, verticalArrowShift + arrowWidth]\n },\n bottomLeft: {\n points: ['tl', 'bc'],\n offset: [-(horizontalArrowShift + arrowWidth), 4]\n },\n leftBottom: {\n points: ['br', 'cl'],\n offset: [-4, verticalArrowShift + arrowWidth]\n }\n };\n Object.keys(placementMap).forEach(key => {\n placementMap[key] = arrowPointAtCenter ? _extends(_extends({}, placementMap[key]), {\n overflow: getOverflowOptions(autoAdjustOverflow),\n targetOffset\n }) : _extends(_extends({}, placements[key]), {\n overflow: getOverflowOptions(autoAdjustOverflow)\n });\n placementMap[key].ignoreShake = true;\n });\n return placementMap;\n}","function firstNotUndefined() {\n let arr = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];\n for (let i = 0, len = arr.length; i < len; i++) {\n if (arr[i] !== undefined) {\n return arr[i];\n }\n }\n return undefined;\n}\nexport default firstNotUndefined;","export const PresetColors = ['blue', 'purple', 'cyan', 'green', 'magenta', 'pink', 'red', 'orange', 'yellow', 'volcano', 'geekblue', 'lime', 'gold'];","import { PresetColors } from '../theme/interface';\nconst inverseColors = PresetColors.map(color => `${color}-inverse`);\nexport const PresetStatusColorTypes = ['success', 'processing', 'error', 'default', 'warning'];\n/**\n * determine if the color keyword belongs to the `Ant Design` {@link PresetColors}.\n * @param color color to be judged\n * @param includeInverse whether to include reversed colors\n */\nexport function isPresetColor(color) {\n let includeInverse = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;\n if (includeInverse) {\n return [...inverseColors, ...PresetColors].includes(color);\n }\n return PresetColors.includes(color);\n}\nexport function isPresetStatusColor(color) {\n return PresetStatusColorTypes.includes(color);\n}","import classNames from '../_util/classNames';\nimport { isPresetColor } from '../_util/colors';\nexport function parseColor(prefixCls, color) {\n const isInternalColor = isPresetColor(color);\n const className = classNames({\n [`${prefixCls}-${color}`]: color && isInternalColor\n });\n const overlayStyle = {};\n const arrowStyle = {};\n if (color && !isInternalColor) {\n overlayStyle.background = color;\n // @ts-ignore\n arrowStyle['--antd-arrow-background-color'] = color;\n }\n return {\n className,\n overlayStyle,\n arrowStyle\n };\n}","class Keyframe {\n constructor(name, style) {\n this._keyframe = true;\n this.name = name;\n this.style = style;\n }\n getName() {\n let hashId = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';\n return hashId ? `${hashId}-${this.name}` : this.name;\n }\n}\nexport default Keyframe;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nconst initMotionCommon = duration => ({\n animationDuration: duration,\n animationFillMode: 'both'\n});\n// FIXME: origin less code seems same as initMotionCommon. Maybe we can safe remove\nconst initMotionCommonLeave = duration => ({\n animationDuration: duration,\n animationFillMode: 'both'\n});\nexport const initMotion = function (motionCls, inKeyframes, outKeyframes, duration) {\n let sameLevel = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : false;\n const sameLevelPrefix = sameLevel ? '&' : '';\n return {\n [`\n ${sameLevelPrefix}${motionCls}-enter,\n ${sameLevelPrefix}${motionCls}-appear\n `]: _extends(_extends({}, initMotionCommon(duration)), {\n animationPlayState: 'paused'\n }),\n [`${sameLevelPrefix}${motionCls}-leave`]: _extends(_extends({}, initMotionCommonLeave(duration)), {\n animationPlayState: 'paused'\n }),\n [`\n ${sameLevelPrefix}${motionCls}-enter${motionCls}-enter-active,\n ${sameLevelPrefix}${motionCls}-appear${motionCls}-appear-active\n `]: {\n animationName: inKeyframes,\n animationPlayState: 'running'\n },\n [`${sameLevelPrefix}${motionCls}-leave${motionCls}-leave-active`]: {\n animationName: outKeyframes,\n animationPlayState: 'running',\n pointerEvents: 'none'\n }\n };\n};","import { Keyframes } from '../../_util/cssinjs';\nimport { initMotion } from './motion';\nexport const zoomIn = new Keyframes('antZoomIn', {\n '0%': {\n transform: 'scale(0.2)',\n opacity: 0\n },\n '100%': {\n transform: 'scale(1)',\n opacity: 1\n }\n});\nexport const zoomOut = new Keyframes('antZoomOut', {\n '0%': {\n transform: 'scale(1)'\n },\n '100%': {\n transform: 'scale(0.2)',\n opacity: 0\n }\n});\nexport const zoomBigIn = new Keyframes('antZoomBigIn', {\n '0%': {\n transform: 'scale(0.8)',\n opacity: 0\n },\n '100%': {\n transform: 'scale(1)',\n opacity: 1\n }\n});\nexport const zoomBigOut = new Keyframes('antZoomBigOut', {\n '0%': {\n transform: 'scale(1)'\n },\n '100%': {\n transform: 'scale(0.8)',\n opacity: 0\n }\n});\nexport const zoomUpIn = new Keyframes('antZoomUpIn', {\n '0%': {\n transform: 'scale(0.8)',\n transformOrigin: '50% 0%',\n opacity: 0\n },\n '100%': {\n transform: 'scale(1)',\n transformOrigin: '50% 0%'\n }\n});\nexport const zoomUpOut = new Keyframes('antZoomUpOut', {\n '0%': {\n transform: 'scale(1)',\n transformOrigin: '50% 0%'\n },\n '100%': {\n transform: 'scale(0.8)',\n transformOrigin: '50% 0%',\n opacity: 0\n }\n});\nexport const zoomLeftIn = new Keyframes('antZoomLeftIn', {\n '0%': {\n transform: 'scale(0.8)',\n transformOrigin: '0% 50%',\n opacity: 0\n },\n '100%': {\n transform: 'scale(1)',\n transformOrigin: '0% 50%'\n }\n});\nexport const zoomLeftOut = new Keyframes('antZoomLeftOut', {\n '0%': {\n transform: 'scale(1)',\n transformOrigin: '0% 50%'\n },\n '100%': {\n transform: 'scale(0.8)',\n transformOrigin: '0% 50%',\n opacity: 0\n }\n});\nexport const zoomRightIn = new Keyframes('antZoomRightIn', {\n '0%': {\n transform: 'scale(0.8)',\n transformOrigin: '100% 50%',\n opacity: 0\n },\n '100%': {\n transform: 'scale(1)',\n transformOrigin: '100% 50%'\n }\n});\nexport const zoomRightOut = new Keyframes('antZoomRightOut', {\n '0%': {\n transform: 'scale(1)',\n transformOrigin: '100% 50%'\n },\n '100%': {\n transform: 'scale(0.8)',\n transformOrigin: '100% 50%',\n opacity: 0\n }\n});\nexport const zoomDownIn = new Keyframes('antZoomDownIn', {\n '0%': {\n transform: 'scale(0.8)',\n transformOrigin: '50% 100%',\n opacity: 0\n },\n '100%': {\n transform: 'scale(1)',\n transformOrigin: '50% 100%'\n }\n});\nexport const zoomDownOut = new Keyframes('antZoomDownOut', {\n '0%': {\n transform: 'scale(1)',\n transformOrigin: '50% 100%'\n },\n '100%': {\n transform: 'scale(0.8)',\n transformOrigin: '50% 100%',\n opacity: 0\n }\n});\nconst zoomMotion = {\n zoom: {\n inKeyframes: zoomIn,\n outKeyframes: zoomOut\n },\n 'zoom-big': {\n inKeyframes: zoomBigIn,\n outKeyframes: zoomBigOut\n },\n 'zoom-big-fast': {\n inKeyframes: zoomBigIn,\n outKeyframes: zoomBigOut\n },\n 'zoom-left': {\n inKeyframes: zoomLeftIn,\n outKeyframes: zoomLeftOut\n },\n 'zoom-right': {\n inKeyframes: zoomRightIn,\n outKeyframes: zoomRightOut\n },\n 'zoom-up': {\n inKeyframes: zoomUpIn,\n outKeyframes: zoomUpOut\n },\n 'zoom-down': {\n inKeyframes: zoomDownIn,\n outKeyframes: zoomDownOut\n }\n};\nexport const initZoomMotion = (token, motionName) => {\n const {\n antCls\n } = token;\n const motionCls = `${antCls}-${motionName}`;\n const {\n inKeyframes,\n outKeyframes\n } = zoomMotion[motionName];\n return [initMotion(motionCls, inKeyframes, outKeyframes, motionName === 'zoom-big-fast' ? token.motionDurationFast : token.motionDurationMid), {\n [`\n ${motionCls}-enter,\n ${motionCls}-appear\n `]: {\n transform: 'scale(0)',\n opacity: 0,\n animationTimingFunction: token.motionEaseOutCirc,\n '&-prepare': {\n transform: 'none'\n }\n },\n [`${motionCls}-leave`]: {\n animationTimingFunction: token.motionEaseInOutCirc\n }\n }];\n};","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport { PresetColors } from '../theme/interface';\nexport function genPresetColor(token, genCss) {\n return PresetColors.reduce((prev, colorKey) => {\n const lightColor = token[`${colorKey}-1`];\n const lightBorderColor = token[`${colorKey}-3`];\n const darkColor = token[`${colorKey}-6`];\n const textColor = token[`${colorKey}-7`];\n return _extends(_extends({}, prev), genCss(colorKey, {\n lightColor,\n lightBorderColor,\n darkColor,\n textColor\n }));\n }, {});\n}","export const roundedArrow = (width, innerRadius, outerRadius, bgColor, boxShadow) => {\n const unitWidth = width / 2;\n const ax = 0;\n const ay = unitWidth;\n const bx = outerRadius * 1 / Math.sqrt(2);\n const by = unitWidth - outerRadius * (1 - 1 / Math.sqrt(2));\n const cx = unitWidth - innerRadius * (1 / Math.sqrt(2));\n const cy = outerRadius * (Math.sqrt(2) - 1) + innerRadius * (1 / Math.sqrt(2));\n const dx = 2 * unitWidth - cx;\n const dy = cy;\n const ex = 2 * unitWidth - bx;\n const ey = by;\n const fx = 2 * unitWidth - ax;\n const fy = ay;\n const shadowWidth = unitWidth * Math.sqrt(2) + outerRadius * (Math.sqrt(2) - 2);\n const polygonOffset = outerRadius * (Math.sqrt(2) - 1);\n return {\n pointerEvents: 'none',\n width,\n height: width,\n overflow: 'hidden',\n '&::after': {\n content: '\"\"',\n position: 'absolute',\n width: shadowWidth,\n height: shadowWidth,\n bottom: 0,\n insetInline: 0,\n margin: 'auto',\n borderRadius: {\n _skip_check_: true,\n value: `0 0 ${innerRadius}px 0`\n },\n transform: 'translateY(50%) rotate(-135deg)',\n boxShadow,\n zIndex: 0,\n background: 'transparent'\n },\n '&::before': {\n position: 'absolute',\n bottom: 0,\n insetInlineStart: 0,\n width,\n height: width / 2,\n background: bgColor,\n clipPath: {\n _multi_value_: true,\n value: [`polygon(${polygonOffset}px 100%, 50% ${polygonOffset}px, ${2 * unitWidth - polygonOffset}px 100%, ${polygonOffset}px 100%)`, `path('M ${ax} ${ay} A ${outerRadius} ${outerRadius} 0 0 0 ${bx} ${by} L ${cx} ${cy} A ${innerRadius} ${innerRadius} 0 0 1 ${dx} ${dy} L ${ex} ${ey} A ${outerRadius} ${outerRadius} 0 0 0 ${fx} ${fy} Z')`]\n },\n content: '\"\"'\n }\n };\n};","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport { roundedArrow } from './roundedArrow';\nfunction connectArrowCls(classList) {\n let showArrowCls = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';\n return classList.map(cls => `${showArrowCls}${cls}`).join(',');\n}\nexport const MAX_VERTICAL_CONTENT_RADIUS = 8;\nexport function getArrowOffset(options) {\n const maxVerticalContentRadius = MAX_VERTICAL_CONTENT_RADIUS;\n const {\n sizePopupArrow,\n contentRadius,\n borderRadiusOuter,\n limitVerticalRadius\n } = options;\n const arrowInnerOffset = sizePopupArrow / 2 - Math.ceil(borderRadiusOuter * (Math.sqrt(2) - 1));\n const dropdownArrowOffset = (contentRadius > 12 ? contentRadius + 2 : 12) - arrowInnerOffset;\n const dropdownArrowOffsetVertical = limitVerticalRadius ? maxVerticalContentRadius - arrowInnerOffset : dropdownArrowOffset;\n return {\n dropdownArrowOffset,\n dropdownArrowOffsetVertical\n };\n}\nexport default function getArrowStyle(token, options) {\n const {\n componentCls,\n sizePopupArrow,\n marginXXS,\n borderRadiusXS,\n borderRadiusOuter,\n boxShadowPopoverArrow\n } = token;\n const {\n colorBg,\n showArrowCls,\n contentRadius = token.borderRadiusLG,\n limitVerticalRadius\n } = options;\n const {\n dropdownArrowOffsetVertical,\n dropdownArrowOffset\n } = getArrowOffset({\n sizePopupArrow,\n contentRadius,\n borderRadiusOuter,\n limitVerticalRadius\n });\n const dropdownArrowDistance = sizePopupArrow / 2 + marginXXS;\n return {\n [componentCls]: {\n // ============================ Basic ============================\n [`${componentCls}-arrow`]: [_extends(_extends({\n position: 'absolute',\n zIndex: 1,\n display: 'block'\n }, roundedArrow(sizePopupArrow, borderRadiusXS, borderRadiusOuter, colorBg, boxShadowPopoverArrow)), {\n '&:before': {\n background: colorBg\n }\n })],\n // ========================== Placement ==========================\n // Here handle the arrow position and rotate stuff\n // >>>>> Top\n [[`&-placement-top ${componentCls}-arrow`, `&-placement-topLeft ${componentCls}-arrow`, `&-placement-topRight ${componentCls}-arrow`].join(',')]: {\n bottom: 0,\n transform: 'translateY(100%) rotate(180deg)'\n },\n [`&-placement-top ${componentCls}-arrow`]: {\n left: {\n _skip_check_: true,\n value: '50%'\n },\n transform: 'translateX(-50%) translateY(100%) rotate(180deg)'\n },\n [`&-placement-topLeft ${componentCls}-arrow`]: {\n left: {\n _skip_check_: true,\n value: dropdownArrowOffset\n }\n },\n [`&-placement-topRight ${componentCls}-arrow`]: {\n right: {\n _skip_check_: true,\n value: dropdownArrowOffset\n }\n },\n // >>>>> Bottom\n [[`&-placement-bottom ${componentCls}-arrow`, `&-placement-bottomLeft ${componentCls}-arrow`, `&-placement-bottomRight ${componentCls}-arrow`].join(',')]: {\n top: 0,\n transform: `translateY(-100%)`\n },\n [`&-placement-bottom ${componentCls}-arrow`]: {\n left: {\n _skip_check_: true,\n value: '50%'\n },\n transform: `translateX(-50%) translateY(-100%)`\n },\n [`&-placement-bottomLeft ${componentCls}-arrow`]: {\n left: {\n _skip_check_: true,\n value: dropdownArrowOffset\n }\n },\n [`&-placement-bottomRight ${componentCls}-arrow`]: {\n right: {\n _skip_check_: true,\n value: dropdownArrowOffset\n }\n },\n // >>>>> Left\n [[`&-placement-left ${componentCls}-arrow`, `&-placement-leftTop ${componentCls}-arrow`, `&-placement-leftBottom ${componentCls}-arrow`].join(',')]: {\n right: {\n _skip_check_: true,\n value: 0\n },\n transform: 'translateX(100%) rotate(90deg)'\n },\n [`&-placement-left ${componentCls}-arrow`]: {\n top: {\n _skip_check_: true,\n value: '50%'\n },\n transform: 'translateY(-50%) translateX(100%) rotate(90deg)'\n },\n [`&-placement-leftTop ${componentCls}-arrow`]: {\n top: dropdownArrowOffsetVertical\n },\n [`&-placement-leftBottom ${componentCls}-arrow`]: {\n bottom: dropdownArrowOffsetVertical\n },\n // >>>>> Right\n [[`&-placement-right ${componentCls}-arrow`, `&-placement-rightTop ${componentCls}-arrow`, `&-placement-rightBottom ${componentCls}-arrow`].join(',')]: {\n left: {\n _skip_check_: true,\n value: 0\n },\n transform: 'translateX(-100%) rotate(-90deg)'\n },\n [`&-placement-right ${componentCls}-arrow`]: {\n top: {\n _skip_check_: true,\n value: '50%'\n },\n transform: 'translateY(-50%) translateX(-100%) rotate(-90deg)'\n },\n [`&-placement-rightTop ${componentCls}-arrow`]: {\n top: dropdownArrowOffsetVertical\n },\n [`&-placement-rightBottom ${componentCls}-arrow`]: {\n bottom: dropdownArrowOffsetVertical\n },\n // =========================== Offset ============================\n // Offset the popover to account for the dropdown arrow\n // >>>>> Top\n [connectArrowCls([`&-placement-topLeft`, `&-placement-top`, `&-placement-topRight`], showArrowCls)]: {\n paddingBottom: dropdownArrowDistance\n },\n // >>>>> Bottom\n [connectArrowCls([`&-placement-bottomLeft`, `&-placement-bottom`, `&-placement-bottomRight`], showArrowCls)]: {\n paddingTop: dropdownArrowDistance\n },\n // >>>>> Left\n [connectArrowCls([`&-placement-leftTop`, `&-placement-left`, `&-placement-leftBottom`], showArrowCls)]: {\n paddingRight: {\n _skip_check_: true,\n value: dropdownArrowDistance\n }\n },\n // >>>>> Right\n [connectArrowCls([`&-placement-rightTop`, `&-placement-right`, `&-placement-rightBottom`], showArrowCls)]: {\n paddingLeft: {\n _skip_check_: true,\n value: dropdownArrowDistance\n }\n }\n }\n };\n}","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport { initZoomMotion } from '../../style/motion';\nimport { genComponentStyleHook, mergeToken } from '../../theme/internal';\nimport { genPresetColor, resetComponent } from '../../style';\nimport getArrowStyle, { MAX_VERTICAL_CONTENT_RADIUS } from '../../style/placementArrow';\nimport 'vue';\nconst genTooltipStyle = token => {\n const {\n componentCls,\n // ant-tooltip\n tooltipMaxWidth,\n tooltipColor,\n tooltipBg,\n tooltipBorderRadius,\n zIndexPopup,\n controlHeight,\n boxShadowSecondary,\n paddingSM,\n paddingXS,\n tooltipRadiusOuter\n } = token;\n return [{\n [componentCls]: _extends(_extends(_extends(_extends({}, resetComponent(token)), {\n position: 'absolute',\n zIndex: zIndexPopup,\n display: 'block',\n '&': [{\n width: 'max-content'\n }, {\n width: 'intrinsic'\n }],\n maxWidth: tooltipMaxWidth,\n visibility: 'visible',\n '&-hidden': {\n display: 'none'\n },\n '--antd-arrow-background-color': tooltipBg,\n // Wrapper for the tooltip content\n [`${componentCls}-inner`]: {\n minWidth: controlHeight,\n minHeight: controlHeight,\n padding: `${paddingSM / 2}px ${paddingXS}px`,\n color: tooltipColor,\n textAlign: 'start',\n textDecoration: 'none',\n wordWrap: 'break-word',\n backgroundColor: tooltipBg,\n borderRadius: tooltipBorderRadius,\n boxShadow: boxShadowSecondary\n },\n // Limit left and right placement radius\n [[`&-placement-left`, `&-placement-leftTop`, `&-placement-leftBottom`, `&-placement-right`, `&-placement-rightTop`, `&-placement-rightBottom`].join(',')]: {\n [`${componentCls}-inner`]: {\n borderRadius: Math.min(tooltipBorderRadius, MAX_VERTICAL_CONTENT_RADIUS)\n }\n },\n [`${componentCls}-content`]: {\n position: 'relative'\n }\n }), genPresetColor(token, (colorKey, _ref) => {\n let {\n darkColor\n } = _ref;\n return {\n [`&${componentCls}-${colorKey}`]: {\n [`${componentCls}-inner`]: {\n backgroundColor: darkColor\n },\n [`${componentCls}-arrow`]: {\n '--antd-arrow-background-color': darkColor\n }\n }\n };\n })), {\n // RTL\n '&-rtl': {\n direction: 'rtl'\n }\n })\n },\n // Arrow Style\n getArrowStyle(mergeToken(token, {\n borderRadiusOuter: tooltipRadiusOuter\n }), {\n colorBg: 'var(--antd-arrow-background-color)',\n showArrowCls: '',\n contentRadius: tooltipBorderRadius,\n limitVerticalRadius: true\n }),\n // Pure Render\n {\n [`${componentCls}-pure`]: {\n position: 'relative',\n maxWidth: 'none'\n }\n }];\n};\n// ============================== Export ==============================\nexport default ((prefixCls, injectStyle) => {\n const useOriginHook = genComponentStyleHook('Tooltip', token => {\n // Popover use Tooltip as internal component. We do not need to handle this.\n if ((injectStyle === null || injectStyle === void 0 ? void 0 : injectStyle.value) === false) {\n return [];\n }\n const {\n borderRadius,\n colorTextLightSolid,\n colorBgDefault,\n borderRadiusOuter\n } = token;\n const TooltipToken = mergeToken(token, {\n // default variables\n tooltipMaxWidth: 250,\n tooltipColor: colorTextLightSolid,\n tooltipBorderRadius: borderRadius,\n tooltipBg: colorBgDefault,\n tooltipRadiusOuter: borderRadiusOuter > 4 ? 4 : borderRadiusOuter\n });\n return [genTooltipStyle(TooltipToken), initZoomMotion(token, 'zoom-big-fast')];\n }, _ref2 => {\n let {\n zIndexPopupBase,\n colorBgSpotlight\n } = _ref2;\n return {\n zIndexPopup: zIndexPopupBase + 70,\n colorBgDefault: colorBgSpotlight\n };\n });\n return useOriginHook(prefixCls);\n});","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport { resolveDirective as _resolveDirective, createVNode as _createVNode } from \"vue\";\nimport { computed, watch, defineComponent, ref } from 'vue';\nimport VcTooltip from '../vc-tooltip';\nimport classNames from '../_util/classNames';\nimport PropTypes from '../_util/vue-types';\nimport warning from '../_util/warning';\nimport { getStyle, filterEmpty, isValidElement, initDefaultProps, isFragment } from '../_util/props-util';\nimport { cloneElement } from '../_util/vnode';\nimport abstractTooltipProps from './abstractTooltipProps';\nimport useConfigInject from '../config-provider/hooks/useConfigInject';\nimport getPlacements from '../_util/placements';\nimport firstNotUndefined from '../_util/firstNotUndefined';\nimport raf from '../_util/raf';\nimport { parseColor } from './util';\nimport useStyle from './style';\nimport { getTransitionName } from '../_util/transition';\nconst splitObject = (obj, keys) => {\n const picked = {};\n const omitted = _extends({}, obj);\n keys.forEach(key => {\n if (obj && key in obj) {\n picked[key] = obj[key];\n delete omitted[key];\n }\n });\n return {\n picked,\n omitted\n };\n};\nexport const tooltipProps = () => _extends(_extends({}, abstractTooltipProps()), {\n title: PropTypes.any\n});\nexport const tooltipDefaultProps = () => ({\n trigger: 'hover',\n align: {},\n placement: 'top',\n mouseEnterDelay: 0.1,\n mouseLeaveDelay: 0.1,\n arrowPointAtCenter: false,\n autoAdjustOverflow: true\n});\nexport default defineComponent({\n compatConfig: {\n MODE: 3\n },\n name: 'ATooltip',\n inheritAttrs: false,\n props: initDefaultProps(tooltipProps(), {\n trigger: 'hover',\n align: {},\n placement: 'top',\n mouseEnterDelay: 0.1,\n mouseLeaveDelay: 0.1,\n arrowPointAtCenter: false,\n autoAdjustOverflow: true\n }),\n slots: Object,\n // emits: ['update:visible', 'visibleChange'],\n setup(props, _ref) {\n let {\n slots,\n emit,\n attrs,\n expose\n } = _ref;\n if (process.env.NODE_ENV !== 'production') {\n [['visible', 'open'], ['onVisibleChange', 'onOpenChange']].forEach(_ref2 => {\n let [deprecatedName, newName] = _ref2;\n warning(props[deprecatedName] === undefined, 'Tooltip', `\\`${deprecatedName}\\` is deprecated, please use \\`${newName}\\` instead.`);\n });\n }\n const {\n prefixCls,\n getPopupContainer,\n direction,\n rootPrefixCls\n } = useConfigInject('tooltip', props);\n const mergedOpen = computed(() => {\n var _a;\n return (_a = props.open) !== null && _a !== void 0 ? _a : props.visible;\n });\n const innerOpen = ref(firstNotUndefined([props.open, props.visible]));\n const tooltip = ref();\n let rafId;\n watch(mergedOpen, val => {\n raf.cancel(rafId);\n rafId = raf(() => {\n innerOpen.value = !!val;\n });\n });\n const isNoTitle = () => {\n var _a;\n const title = (_a = props.title) !== null && _a !== void 0 ? _a : slots.title;\n return !title && title !== 0;\n };\n const handleVisibleChange = val => {\n const noTitle = isNoTitle();\n if (mergedOpen.value === undefined) {\n innerOpen.value = noTitle ? false : val;\n }\n if (!noTitle) {\n emit('update:visible', val);\n emit('visibleChange', val);\n emit('update:open', val);\n emit('openChange', val);\n }\n };\n const getPopupDomNode = () => {\n return tooltip.value.getPopupDomNode();\n };\n expose({\n getPopupDomNode,\n open: innerOpen,\n forcePopupAlign: () => {\n var _a;\n return (_a = tooltip.value) === null || _a === void 0 ? void 0 : _a.forcePopupAlign();\n }\n });\n const tooltipPlacements = computed(() => {\n const {\n builtinPlacements,\n arrowPointAtCenter,\n autoAdjustOverflow\n } = props;\n return builtinPlacements || getPlacements({\n arrowPointAtCenter,\n autoAdjustOverflow\n });\n });\n const isTrueProps = val => {\n return val || val === '';\n };\n const getDisabledCompatibleChildren = ele => {\n const elementType = ele.type;\n if (typeof elementType === 'object' && ele.props) {\n if ((elementType.__ANT_BUTTON === true || elementType === 'button') && isTrueProps(ele.props.disabled) || elementType.__ANT_SWITCH === true && (isTrueProps(ele.props.disabled) || isTrueProps(ele.props.loading)) || elementType.__ANT_RADIO === true && isTrueProps(ele.props.disabled)) {\n // Pick some layout related style properties up to span\n // Prevent layout bugs like https://github.com/ant-design/ant-design/issues/5254\n const {\n picked,\n omitted\n } = splitObject(getStyle(ele), ['position', 'left', 'right', 'top', 'bottom', 'float', 'display', 'zIndex']);\n const spanStyle = _extends(_extends({\n display: 'inline-block'\n }, picked), {\n cursor: 'not-allowed',\n lineHeight: 1,\n width: ele.props && ele.props.block ? '100%' : undefined\n });\n const buttonStyle = _extends(_extends({}, omitted), {\n pointerEvents: 'none'\n });\n const child = cloneElement(ele, {\n style: buttonStyle\n }, true);\n return _createVNode(\"span\", {\n \"style\": spanStyle,\n \"class\": `${prefixCls.value}-disabled-compatible-wrapper`\n }, [child]);\n }\n }\n return ele;\n };\n const getOverlay = () => {\n var _a, _b;\n return (_a = props.title) !== null && _a !== void 0 ? _a : (_b = slots.title) === null || _b === void 0 ? void 0 : _b.call(slots);\n };\n const onPopupAlign = (domNode, align) => {\n const placements = tooltipPlacements.value;\n // 当前返回的位置\n const placement = Object.keys(placements).find(key => {\n var _a, _b;\n return placements[key].points[0] === ((_a = align.points) === null || _a === void 0 ? void 0 : _a[0]) && placements[key].points[1] === ((_b = align.points) === null || _b === void 0 ? void 0 : _b[1]);\n });\n if (placement) {\n // 根据当前坐标设置动画点\n const rect = domNode.getBoundingClientRect();\n const transformOrigin = {\n top: '50%',\n left: '50%'\n };\n if (placement.indexOf('top') >= 0 || placement.indexOf('Bottom') >= 0) {\n transformOrigin.top = `${rect.height - align.offset[1]}px`;\n } else if (placement.indexOf('Top') >= 0 || placement.indexOf('bottom') >= 0) {\n transformOrigin.top = `${-align.offset[1]}px`;\n }\n if (placement.indexOf('left') >= 0 || placement.indexOf('Right') >= 0) {\n transformOrigin.left = `${rect.width - align.offset[0]}px`;\n } else if (placement.indexOf('right') >= 0 || placement.indexOf('Left') >= 0) {\n transformOrigin.left = `${-align.offset[0]}px`;\n }\n domNode.style.transformOrigin = `${transformOrigin.left} ${transformOrigin.top}`;\n }\n };\n const colorInfo = computed(() => parseColor(prefixCls.value, props.color));\n const injectFromPopover = computed(() => attrs['data-popover-inject']);\n const [wrapSSR, hashId] = useStyle(prefixCls, computed(() => !injectFromPopover.value));\n return () => {\n var _a, _b;\n const {\n openClassName,\n overlayClassName,\n overlayStyle,\n overlayInnerStyle\n } = props;\n let children = (_b = filterEmpty((_a = slots.default) === null || _a === void 0 ? void 0 : _a.call(slots))) !== null && _b !== void 0 ? _b : null;\n children = children.length === 1 ? children[0] : children;\n let tempVisible = innerOpen.value;\n // Hide tooltip when there is no title\n if (mergedOpen.value === undefined && isNoTitle()) {\n tempVisible = false;\n }\n if (!children) {\n return null;\n }\n const child = getDisabledCompatibleChildren(isValidElement(children) && !isFragment(children) ? children : _createVNode(\"span\", null, [children]));\n const childCls = classNames({\n [openClassName || `${prefixCls.value}-open`]: true,\n [child.props && child.props.class]: child.props && child.props.class\n });\n const customOverlayClassName = classNames(overlayClassName, {\n [`${prefixCls.value}-rtl`]: direction.value === 'rtl'\n }, colorInfo.value.className, hashId.value);\n const formattedOverlayInnerStyle = _extends(_extends({}, colorInfo.value.overlayStyle), overlayInnerStyle);\n const arrowContentStyle = colorInfo.value.arrowStyle;\n const vcTooltipProps = _extends(_extends(_extends({}, attrs), props), {\n prefixCls: prefixCls.value,\n getPopupContainer: getPopupContainer === null || getPopupContainer === void 0 ? void 0 : getPopupContainer.value,\n builtinPlacements: tooltipPlacements.value,\n visible: tempVisible,\n ref: tooltip,\n overlayClassName: customOverlayClassName,\n overlayStyle: _extends(_extends({}, arrowContentStyle), overlayStyle),\n overlayInnerStyle: formattedOverlayInnerStyle,\n onVisibleChange: handleVisibleChange,\n onPopupAlign,\n transitionName: getTransitionName(rootPrefixCls.value, 'zoom-big-fast', props.transitionName)\n });\n return wrapSSR(_createVNode(VcTooltip, vcTooltipProps, {\n default: () => [innerOpen.value ? cloneElement(child, {\n class: childCls\n }) : child],\n arrowContent: () => _createVNode(\"span\", {\n \"class\": `${prefixCls.value}-arrow-content`\n }, null),\n overlay: getOverlay\n }));\n };\n }\n});","import { withInstall } from '../_util/type';\nimport ToolTip, { tooltipProps } from './Tooltip';\nexport { tooltipProps };\nexport default withInstall(ToolTip);","import _extends from \"@babel/runtime/helpers/esm/extends\";\nfunction omit(obj, fields) {\n // eslint-disable-next-line prefer-object-spread\n const shallowCopy = _extends({}, obj);\n for (let i = 0; i < fields.length; i += 1) {\n const key = fields[i];\n delete shallowCopy[key];\n }\n return shallowCopy;\n}\nexport default omit;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport { initZoomMotion } from '../../style/motion';\nimport { genComponentStyleHook, mergeToken, PresetColors } from '../../theme/internal';\nimport { resetComponent } from '../../style';\nimport getArrowStyle from '../../style/placementArrow';\nconst genBaseStyle = token => {\n const {\n componentCls,\n popoverBg,\n popoverColor,\n width,\n fontWeightStrong,\n popoverPadding,\n boxShadowSecondary,\n colorTextHeading,\n borderRadiusLG: borderRadius,\n zIndexPopup,\n marginXS,\n colorBgElevated\n } = token;\n return [{\n [componentCls]: _extends(_extends({}, resetComponent(token)), {\n position: 'absolute',\n top: 0,\n // use `left` to fix https://github.com/ant-design/ant-design/issues/39195\n left: {\n _skip_check_: true,\n value: 0\n },\n zIndex: zIndexPopup,\n fontWeight: 'normal',\n whiteSpace: 'normal',\n textAlign: 'start',\n cursor: 'auto',\n userSelect: 'text',\n '--antd-arrow-background-color': colorBgElevated,\n '&-rtl': {\n direction: 'rtl'\n },\n '&-hidden': {\n display: 'none'\n },\n [`${componentCls}-content`]: {\n position: 'relative'\n },\n [`${componentCls}-inner`]: {\n backgroundColor: popoverBg,\n backgroundClip: 'padding-box',\n borderRadius,\n boxShadow: boxShadowSecondary,\n padding: popoverPadding\n },\n [`${componentCls}-title`]: {\n minWidth: width,\n marginBottom: marginXS,\n color: colorTextHeading,\n fontWeight: fontWeightStrong\n },\n [`${componentCls}-inner-content`]: {\n color: popoverColor\n }\n })\n },\n // Arrow Style\n getArrowStyle(token, {\n colorBg: 'var(--antd-arrow-background-color)'\n }),\n // Pure Render\n {\n [`${componentCls}-pure`]: {\n position: 'relative',\n maxWidth: 'none',\n [`${componentCls}-content`]: {\n display: 'inline-block'\n }\n }\n }];\n};\nconst genColorStyle = token => {\n const {\n componentCls\n } = token;\n return {\n [componentCls]: PresetColors.map(colorKey => {\n const lightColor = token[`${colorKey}-6`];\n return {\n [`&${componentCls}-${colorKey}`]: {\n '--antd-arrow-background-color': lightColor,\n [`${componentCls}-inner`]: {\n backgroundColor: lightColor\n },\n [`${componentCls}-arrow`]: {\n background: 'transparent'\n }\n }\n };\n })\n };\n};\nconst genWireframeStyle = token => {\n const {\n componentCls,\n lineWidth,\n lineType,\n colorSplit,\n paddingSM,\n controlHeight,\n fontSize,\n lineHeight,\n padding\n } = token;\n const titlePaddingBlockDist = controlHeight - Math.round(fontSize * lineHeight);\n const popoverTitlePaddingBlockTop = titlePaddingBlockDist / 2;\n const popoverTitlePaddingBlockBottom = titlePaddingBlockDist / 2 - lineWidth;\n const popoverPaddingHorizontal = padding;\n return {\n [componentCls]: {\n [`${componentCls}-inner`]: {\n padding: 0\n },\n [`${componentCls}-title`]: {\n margin: 0,\n padding: `${popoverTitlePaddingBlockTop}px ${popoverPaddingHorizontal}px ${popoverTitlePaddingBlockBottom}px`,\n borderBottom: `${lineWidth}px ${lineType} ${colorSplit}`\n },\n [`${componentCls}-inner-content`]: {\n padding: `${paddingSM}px ${popoverPaddingHorizontal}px`\n }\n }\n };\n};\nexport default genComponentStyleHook('Popover', token => {\n const {\n colorBgElevated,\n colorText,\n wireframe\n } = token;\n const popoverToken = mergeToken(token, {\n popoverBg: colorBgElevated,\n popoverColor: colorText,\n popoverPadding: 12 // Fixed Value\n });\n return [genBaseStyle(popoverToken), genColorStyle(popoverToken), wireframe && genWireframeStyle(popoverToken), initZoomMotion(popoverToken, 'zoom-big')];\n}, _ref => {\n let {\n zIndexPopupBase\n } = _ref;\n return {\n zIndexPopup: zIndexPopupBase + 30,\n width: 177\n };\n});","import _objectSpread from \"@babel/runtime/helpers/esm/objectSpread2\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport { resolveDirective as _resolveDirective, createVNode as _createVNode, Fragment as _Fragment } from \"vue\";\nimport { computed, defineComponent, ref } from 'vue';\nimport Tooltip from '../tooltip';\nimport abstractTooltipProps from '../tooltip/abstractTooltipProps';\nimport { filterEmpty, initDefaultProps } from '../_util/props-util';\nimport { anyType, withInstall } from '../_util/type';\nimport useConfigInject from '../config-provider/hooks/useConfigInject';\nimport omit from '../_util/omit';\nimport { getTransitionName } from '../_util/transition';\nimport { tooltipDefaultProps } from '../tooltip/Tooltip';\nimport useStyle from './style';\nimport classNames from '../_util/classNames';\nimport warning from '../_util/warning';\nexport const popoverProps = () => _extends(_extends({}, abstractTooltipProps()), {\n content: anyType(),\n title: anyType()\n});\nconst Popover = defineComponent({\n compatConfig: {\n MODE: 3\n },\n name: 'APopover',\n inheritAttrs: false,\n props: initDefaultProps(popoverProps(), _extends(_extends({}, tooltipDefaultProps()), {\n trigger: 'hover',\n placement: 'top',\n mouseEnterDelay: 0.1,\n mouseLeaveDelay: 0.1\n })),\n setup(props, _ref) {\n let {\n expose,\n slots,\n attrs\n } = _ref;\n const tooltipRef = ref();\n warning(props.visible === undefined, 'popover', `\\`visible\\` will be removed in next major version, please use \\`open\\` instead.`);\n expose({\n getPopupDomNode: () => {\n var _a, _b;\n return (_b = (_a = tooltipRef.value) === null || _a === void 0 ? void 0 : _a.getPopupDomNode) === null || _b === void 0 ? void 0 : _b.call(_a);\n }\n });\n const {\n prefixCls,\n configProvider\n } = useConfigInject('popover', props);\n const [wrapSSR, hashId] = useStyle(prefixCls);\n const rootPrefixCls = computed(() => configProvider.getPrefixCls());\n const getOverlay = () => {\n var _a, _b;\n const {\n title = filterEmpty((_a = slots.title) === null || _a === void 0 ? void 0 : _a.call(slots)),\n content = filterEmpty((_b = slots.content) === null || _b === void 0 ? void 0 : _b.call(slots))\n } = props;\n const hasTitle = !!(Array.isArray(title) ? title.length : title);\n const hasContent = !!(Array.isArray(content) ? content.length : title);\n if (!hasTitle && !hasContent) return null;\n return _createVNode(_Fragment, null, [hasTitle && _createVNode(\"div\", {\n \"class\": `${prefixCls.value}-title`\n }, [title]), _createVNode(\"div\", {\n \"class\": `${prefixCls.value}-inner-content`\n }, [content])]);\n };\n return () => {\n const overlayCls = classNames(props.overlayClassName, hashId.value);\n return wrapSSR(_createVNode(Tooltip, _objectSpread(_objectSpread(_objectSpread({}, omit(props, ['title', 'content'])), attrs), {}, {\n \"prefixCls\": prefixCls.value,\n \"ref\": tooltipRef,\n \"overlayClassName\": overlayCls,\n \"transitionName\": getTransitionName(rootPrefixCls.value, 'zoom-big', props.transitionName),\n \"data-popover-inject\": true\n }), {\n title: getOverlay,\n default: slots.default\n }));\n };\n }\n});\nexport default withInstall(Popover);","import PropTypes from '../_util/vue-types';\nimport { eventType } from '../_util/type';\nexport function convertLegacyProps(type) {\n if (type === 'danger') {\n return {\n danger: true\n };\n }\n return {\n type\n };\n}\nexport const buttonProps = () => ({\n prefixCls: String,\n type: String,\n htmlType: {\n type: String,\n default: 'button'\n },\n shape: {\n type: String\n },\n size: {\n type: String\n },\n loading: {\n type: [Boolean, Object],\n default: () => false\n },\n disabled: {\n type: Boolean,\n default: undefined\n },\n ghost: {\n type: Boolean,\n default: undefined\n },\n block: {\n type: Boolean,\n default: undefined\n },\n danger: {\n type: Boolean,\n default: undefined\n },\n icon: PropTypes.any,\n href: String,\n target: String,\n title: String,\n onClick: eventType(),\n onMousedown: eventType()\n});\nexport default buttonProps;","// This icon file is generated automatically.\nvar ExclamationCircleFilled = { \"icon\": { \"tag\": \"svg\", \"attrs\": { \"viewBox\": \"64 64 896 896\", \"focusable\": \"false\" }, \"children\": [{ \"tag\": \"path\", \"attrs\": { \"d\": \"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm-32 232c0-4.4 3.6-8 8-8h48c4.4 0 8 3.6 8 8v272c0 4.4-3.6 8-8 8h-48c-4.4 0-8-3.6-8-8V296zm32 440a48.01 48.01 0 010-96 48.01 48.01 0 010 96z\" } }] }, \"name\": \"exclamation-circle\", \"theme\": \"filled\" };\nexport default ExclamationCircleFilled;\n","import { inject, provide, ref } from 'vue';\nvar contextKey = Symbol('iconContext');\nexport var useProvideIconContext = function useProvideIconContext(props) {\n provide(contextKey, props);\n return props;\n};\nexport var useInjectIconContext = function useInjectIconContext() {\n return inject(contextKey, {\n prefixCls: ref('anticon'),\n rootClassName: ref(''),\n csp: ref()\n });\n};","export function canUseDom() {\n return !!(typeof window !== 'undefined' && window.document && window.document.createElement);\n}\n\nfunction contains(root, n) {\n if (!root) {\n return false;\n } // Use native if support\n\n\n if (root.contains) {\n return root.contains(n);\n }\n\n return false;\n}\n\nvar APPEND_ORDER = 'data-vc-order';\nvar MARK_KEY = \"vc-icon-key\";\nvar containerCache = new Map();\n\nfunction getMark() {\n var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},\n mark = _ref.mark;\n\n if (mark) {\n return mark.startsWith('data-') ? mark : \"data-\".concat(mark);\n }\n\n return MARK_KEY;\n}\n\nfunction getContainer(option) {\n if (option.attachTo) {\n return option.attachTo;\n }\n\n var head = document.querySelector('head');\n return head || document.body;\n}\n\nfunction getOrder(prepend) {\n if (prepend === 'queue') {\n return 'prependQueue';\n }\n\n return prepend ? 'prepend' : 'append';\n}\n/**\n * Find style which inject by rc-util\n */\n\n\nfunction findStyles(container) {\n return Array.from((containerCache.get(container) || container).children).filter(function (node) {\n return node.tagName === 'STYLE';\n });\n}\n\nexport function injectCSS(css) {\n var option = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n if (!canUseDom()) {\n return null;\n }\n\n var csp = option.csp,\n prepend = option.prepend;\n var styleNode = document.createElement('style');\n styleNode.setAttribute(APPEND_ORDER, getOrder(prepend));\n\n if (csp && csp.nonce) {\n styleNode.nonce = csp.nonce;\n }\n\n styleNode.innerHTML = css;\n var container = getContainer(option);\n var firstChild = container.firstChild;\n\n if (prepend) {\n // If is queue `prepend`, it will prepend first style and then append rest style\n if (prepend === 'queue') {\n var existStyle = findStyles(container).filter(function (node) {\n return ['prepend', 'prependQueue'].includes(node.getAttribute(APPEND_ORDER));\n });\n\n if (existStyle.length) {\n container.insertBefore(styleNode, existStyle[existStyle.length - 1].nextSibling);\n return styleNode;\n }\n } // Use `insertBefore` as `prepend`\n\n\n container.insertBefore(styleNode, firstChild);\n } else {\n container.appendChild(styleNode);\n }\n\n return styleNode;\n}\n\nfunction findExistNode(key) {\n var option = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n var container = getContainer(option);\n return findStyles(container).find(function (node) {\n return node.getAttribute(getMark(option)) === key;\n });\n}\n\nexport function removeCSS(key) {\n var option = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n var existNode = findExistNode(key, option);\n\n if (existNode) {\n var container = getContainer(option);\n container.removeChild(existNode);\n }\n}\n/**\n * qiankun will inject `appendChild` to insert into other\n */\n\nfunction syncRealContainer(container, option) {\n var cachedRealContainer = containerCache.get(container); // Find real container when not cached or cached container removed\n\n if (!cachedRealContainer || !contains(document, cachedRealContainer)) {\n var placeholderStyle = injectCSS('', option);\n var parentNode = placeholderStyle.parentNode;\n containerCache.set(container, parentNode);\n container.removeChild(placeholderStyle);\n }\n}\n/**\n * manually clear container cache to avoid global cache in unit testes\n */\n\n\nexport function clearContainerCache() {\n containerCache.clear();\n}\nexport function updateCSS(css, key) {\n var option = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n var container = getContainer(option); // Sync real parent\n\n syncRealContainer(container, option);\n var existNode = findExistNode(key, option);\n\n if (existNode) {\n if (option.csp && option.csp.nonce && existNode.nonce !== option.csp.nonce) {\n existNode.nonce = option.csp.nonce;\n }\n\n if (existNode.innerHTML !== css) {\n existNode.innerHTML = css;\n }\n\n return existNode;\n }\n\n var newNode = injectCSS(css, option);\n newNode.setAttribute(getMark(option), key);\n return newNode;\n}","function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? Object(arguments[i]) : {}; var ownKeys = Object.keys(source); if (typeof Object.getOwnPropertySymbols === 'function') { ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function (sym) { return Object.getOwnPropertyDescriptor(source, sym).enumerable; })); } ownKeys.forEach(function (key) { _defineProperty(target, key, source[key]); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { nextTick, h, getCurrentInstance } from 'vue';\nimport { generate as generateColor } from '@ant-design/colors';\nimport { useInjectIconContext } from './components/Context';\nimport { updateCSS, canUseDom } from './dynamicCSS';\nexport function warn(valid, message) {\n // Support uglify\n if (process.env.NODE_ENV !== 'production' && !valid && console !== undefined) {\n console.error(\"Warning: \".concat(message));\n }\n}\nexport function warning(valid, message) {\n warn(valid, \"[@ant-design/icons-vue] \".concat(message));\n}\n\nfunction camelCase(input) {\n return input.replace(/-(.)/g, function (_match, g) {\n return g.toUpperCase();\n });\n} // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\n\n\nexport function isIconDefinition(target) {\n return typeof target === 'object' && typeof target.name === 'string' && typeof target.theme === 'string' && (typeof target.icon === 'object' || typeof target.icon === 'function');\n}\nexport function normalizeAttrs() {\n var attrs = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n return Object.keys(attrs).reduce(function (acc, key) {\n var val = attrs[key];\n\n switch (key) {\n case 'class':\n acc.className = val;\n delete acc[\"class\"];\n break;\n\n default:\n delete acc[key];\n acc[camelCase(key)] = val;\n }\n\n return acc;\n }, {});\n}\nexport function generate(node, key, rootProps) {\n if (!rootProps) {\n return h(node.tag, _objectSpread({\n key: key\n }, node.attrs), (node.children || []).map(function (child, index) {\n return generate(child, \"\".concat(key, \"-\").concat(node.tag, \"-\").concat(index));\n }));\n }\n\n return h(node.tag, _objectSpread({\n key: key\n }, rootProps, node.attrs), (node.children || []).map(function (child, index) {\n return generate(child, \"\".concat(key, \"-\").concat(node.tag, \"-\").concat(index));\n }));\n}\nexport function getSecondaryColor(primaryColor) {\n // choose the second color\n return generateColor(primaryColor)[0];\n}\nexport function normalizeTwoToneColors(twoToneColor) {\n if (!twoToneColor) {\n return [];\n }\n\n return Array.isArray(twoToneColor) ? twoToneColor : [twoToneColor];\n} // These props make sure that the SVG behaviours like general text.\n// Reference: https://blog.prototypr.io/align-svg-icons-to-text-and-say-goodbye-to-font-icons-d44b3d7b26b4\n\nexport var svgBaseProps = {\n width: '1em',\n height: '1em',\n fill: 'currentColor',\n 'aria-hidden': 'true',\n focusable: 'false'\n};\nexport var iconStyles = \"\\n.anticon {\\n display: inline-block;\\n color: inherit;\\n font-style: normal;\\n line-height: 0;\\n text-align: center;\\n text-transform: none;\\n vertical-align: -0.125em;\\n text-rendering: optimizeLegibility;\\n -webkit-font-smoothing: antialiased;\\n -moz-osx-font-smoothing: grayscale;\\n}\\n\\n.anticon > * {\\n line-height: 1;\\n}\\n\\n.anticon svg {\\n display: inline-block;\\n}\\n\\n.anticon::before {\\n display: none;\\n}\\n\\n.anticon .anticon-icon {\\n display: block;\\n}\\n\\n.anticon[tabindex] {\\n cursor: pointer;\\n}\\n\\n.anticon-spin::before,\\n.anticon-spin {\\n display: inline-block;\\n -webkit-animation: loadingCircle 1s infinite linear;\\n animation: loadingCircle 1s infinite linear;\\n}\\n\\n@-webkit-keyframes loadingCircle {\\n 100% {\\n -webkit-transform: rotate(360deg);\\n transform: rotate(360deg);\\n }\\n}\\n\\n@keyframes loadingCircle {\\n 100% {\\n -webkit-transform: rotate(360deg);\\n transform: rotate(360deg);\\n }\\n}\\n\";\n\nfunction getRoot(ele) {\n return ele && ele.getRootNode && ele.getRootNode();\n}\n/**\n * Check if is in shadowRoot\n */\n\n\nfunction inShadow(ele) {\n if (!canUseDom()) {\n return false;\n }\n\n return getRoot(ele) instanceof ShadowRoot;\n}\n/**\n * Return shadowRoot if possible\n */\n\n\nfunction getShadowRoot(ele) {\n return inShadow(ele) ? getRoot(ele) : null;\n}\n\nexport var useInsertStyles = function useInsertStyles() {\n var _useInjectIconContext = useInjectIconContext(),\n prefixCls = _useInjectIconContext.prefixCls,\n csp = _useInjectIconContext.csp;\n\n var instance = getCurrentInstance();\n var mergedStyleStr = iconStyles;\n\n if (prefixCls) {\n mergedStyleStr = mergedStyleStr.replace(/anticon/g, prefixCls.value);\n }\n\n nextTick(function () {\n if (!canUseDom()) {\n return;\n }\n\n var ele = instance.vnode.el;\n var shadowRoot = getShadowRoot(ele);\n updateCSS(mergedStyleStr, '@ant-design-vue-icons', {\n prepend: true,\n csp: csp.value,\n attachTo: shadowRoot\n });\n });\n};","var _excluded = [\"icon\", \"primaryColor\", \"secondaryColor\"];\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? Object(arguments[i]) : {}; var ownKeys = Object.keys(source); if (typeof Object.getOwnPropertySymbols === 'function') { ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function (sym) { return Object.getOwnPropertyDescriptor(source, sym).enumerable; })); } ownKeys.forEach(function (key) { _defineProperty(target, key, source[key]); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { generate, getSecondaryColor, isIconDefinition, warning } from '../utils';\nimport { reactive } from 'vue';\nvar twoToneColorPalette = reactive({\n primaryColor: '#333',\n secondaryColor: '#E6E6E6',\n calculated: false\n});\n\nfunction setTwoToneColors(_ref) {\n var primaryColor = _ref.primaryColor,\n secondaryColor = _ref.secondaryColor;\n twoToneColorPalette.primaryColor = primaryColor;\n twoToneColorPalette.secondaryColor = secondaryColor || getSecondaryColor(primaryColor);\n twoToneColorPalette.calculated = !!secondaryColor;\n}\n\nfunction getTwoToneColors() {\n return _objectSpread({}, twoToneColorPalette);\n}\n\nvar IconBase = function IconBase(props, context) {\n var _props$context$attrs = _objectSpread({}, props, context.attrs),\n icon = _props$context$attrs.icon,\n primaryColor = _props$context$attrs.primaryColor,\n secondaryColor = _props$context$attrs.secondaryColor,\n restProps = _objectWithoutProperties(_props$context$attrs, _excluded);\n\n var colors = twoToneColorPalette;\n\n if (primaryColor) {\n colors = {\n primaryColor: primaryColor,\n secondaryColor: secondaryColor || getSecondaryColor(primaryColor)\n };\n }\n\n warning(isIconDefinition(icon), \"icon should be icon definiton, but got \".concat(icon));\n\n if (!isIconDefinition(icon)) {\n return null;\n }\n\n var target = icon;\n\n if (target && typeof target.icon === 'function') {\n target = _objectSpread({}, target, {\n icon: target.icon(colors.primaryColor, colors.secondaryColor)\n });\n }\n\n return generate(target.icon, \"svg-\".concat(target.name), _objectSpread({}, restProps, {\n 'data-icon': target.name,\n width: '1em',\n height: '1em',\n fill: 'currentColor',\n 'aria-hidden': 'true'\n })); // },\n};\n\nIconBase.props = {\n icon: Object,\n primaryColor: String,\n secondaryColor: String,\n focusable: String\n};\nIconBase.inheritAttrs = false;\nIconBase.displayName = 'IconBase';\nIconBase.getTwoToneColors = getTwoToneColors;\nIconBase.setTwoToneColors = setTwoToneColors;\nexport default IconBase;","function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\n\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\n\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\n\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }\n\nfunction _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== \"undefined\" && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i[\"return\"] != null) _i[\"return\"](); } finally { if (_d) throw _e; } } return _arr; }\n\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\n\nimport VueIcon from './IconBase';\nimport { normalizeTwoToneColors } from '../utils';\nexport function setTwoToneColor(twoToneColor) {\n var _normalizeTwoToneColo = normalizeTwoToneColors(twoToneColor),\n _normalizeTwoToneColo2 = _slicedToArray(_normalizeTwoToneColo, 2),\n primaryColor = _normalizeTwoToneColo2[0],\n secondaryColor = _normalizeTwoToneColo2[1];\n\n return VueIcon.setTwoToneColors({\n primaryColor: primaryColor,\n secondaryColor: secondaryColor\n });\n}\nexport function getTwoToneColor() {\n var colors = VueIcon.getTwoToneColors();\n\n if (!colors.calculated) {\n return colors.primaryColor;\n }\n\n return [colors.primaryColor, colors.secondaryColor];\n}","import { defineComponent } from 'vue';\nimport { useInsertStyles } from '../utils';\nexport var InsertStyles = defineComponent({\n name: 'InsertStyles',\n setup: function setup() {\n useInsertStyles();\n return function () {\n return null;\n };\n }\n});","var _excluded = [\"class\", \"icon\", \"spin\", \"rotate\", \"tabindex\", \"twoToneColor\", \"onClick\"];\nimport { createVNode as _createVNode } from \"vue\";\n\nfunction _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\n\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\n\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\n\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }\n\nfunction _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== \"undefined\" && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i[\"return\"] != null) _i[\"return\"](); } finally { if (_d) throw _e; } } return _arr; }\n\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? Object(arguments[i]) : {}; var ownKeys = Object.keys(source); if (typeof Object.getOwnPropertySymbols === 'function') { ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function (sym) { return Object.getOwnPropertyDescriptor(source, sym).enumerable; })); } ownKeys.forEach(function (key) { _defineProperty(target, key, source[key]); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nimport VueIcon from './IconBase';\nimport { getTwoToneColor, setTwoToneColor } from './twoTonePrimaryColor';\nimport { normalizeTwoToneColors } from '../utils';\nimport { blue } from '@ant-design/colors';\nimport { useInjectIconContext } from './Context';\nimport { InsertStyles } from './InsertStyle'; // Initial setting\n\nsetTwoToneColor(blue.primary);\n\nvar Icon = function Icon(props, context) {\n var _classObj;\n\n var _props$context$attrs = _objectSpread({}, props, context.attrs),\n cls = _props$context$attrs[\"class\"],\n icon = _props$context$attrs.icon,\n spin = _props$context$attrs.spin,\n rotate = _props$context$attrs.rotate,\n tabindex = _props$context$attrs.tabindex,\n twoToneColor = _props$context$attrs.twoToneColor,\n onClick = _props$context$attrs.onClick,\n restProps = _objectWithoutProperties(_props$context$attrs, _excluded);\n\n var _useInjectIconContext = useInjectIconContext(),\n prefixCls = _useInjectIconContext.prefixCls,\n rootClassName = _useInjectIconContext.rootClassName;\n\n var classObj = (_classObj = {}, _defineProperty(_classObj, rootClassName.value, !!rootClassName.value), _defineProperty(_classObj, prefixCls.value, true), _defineProperty(_classObj, \"\".concat(prefixCls.value, \"-\").concat(icon.name), Boolean(icon.name)), _defineProperty(_classObj, \"\".concat(prefixCls.value, \"-spin\"), !!spin || icon.name === 'loading'), _classObj);\n var iconTabIndex = tabindex;\n\n if (iconTabIndex === undefined && onClick) {\n iconTabIndex = -1;\n }\n\n var svgStyle = rotate ? {\n msTransform: \"rotate(\".concat(rotate, \"deg)\"),\n transform: \"rotate(\".concat(rotate, \"deg)\")\n } : undefined;\n\n var _normalizeTwoToneColo = normalizeTwoToneColors(twoToneColor),\n _normalizeTwoToneColo2 = _slicedToArray(_normalizeTwoToneColo, 2),\n primaryColor = _normalizeTwoToneColo2[0],\n secondaryColor = _normalizeTwoToneColo2[1];\n\n return _createVNode(\"span\", _objectSpread({\n \"role\": \"img\",\n \"aria-label\": icon.name\n }, restProps, {\n \"onClick\": onClick,\n \"class\": [classObj, cls],\n \"tabindex\": iconTabIndex\n }), [_createVNode(VueIcon, {\n \"icon\": icon,\n \"primaryColor\": primaryColor,\n \"secondaryColor\": secondaryColor,\n \"style\": svgStyle\n }, null), _createVNode(InsertStyles, null, null)]);\n};\n\nIcon.props = {\n spin: Boolean,\n rotate: Number,\n icon: Object,\n twoToneColor: [String, Array]\n};\nIcon.displayName = 'AntdIcon';\nIcon.inheritAttrs = false;\nIcon.getTwoToneColor = getTwoToneColor;\nIcon.setTwoToneColor = setTwoToneColor;\nexport default Icon;","import { createVNode as _createVNode } from \"vue\";\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? Object(arguments[i]) : {}; var ownKeys = Object.keys(source); if (typeof Object.getOwnPropertySymbols === 'function') { ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function (sym) { return Object.getOwnPropertyDescriptor(source, sym).enumerable; })); } ownKeys.forEach(function (key) { _defineProperty(target, key, source[key]); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n// GENERATE BY ./scripts/generate.ts\n// DON NOT EDIT IT MANUALLY\nimport ExclamationCircleFilledSvg from \"@ant-design/icons-svg/es/asn/ExclamationCircleFilled\";\nimport AntdIcon from '../components/AntdIcon';\n\nvar ExclamationCircleFilled = function ExclamationCircleFilled(props, context) {\n var p = _objectSpread({}, props, context.attrs);\n\n return _createVNode(AntdIcon, _objectSpread({}, p, {\n \"icon\": ExclamationCircleFilledSvg\n }), null);\n};\n\nExclamationCircleFilled.displayName = 'ExclamationCircleFilled';\nExclamationCircleFilled.inheritAttrs = false;\nexport default ExclamationCircleFilled;","import { genComponentStyleHook } from '../../theme/internal';\nconst genWaveStyle = token => {\n const {\n componentCls,\n colorPrimary\n } = token;\n return {\n [componentCls]: {\n position: 'absolute',\n background: 'transparent',\n pointerEvents: 'none',\n boxSizing: 'border-box',\n color: `var(--wave-color, ${colorPrimary})`,\n boxShadow: `0 0 0 0 currentcolor`,\n opacity: 0.2,\n // =================== Motion ===================\n '&.wave-motion-appear': {\n transition: [`box-shadow 0.4s ${token.motionEaseOutCirc}`, `opacity 2s ${token.motionEaseOutCirc}`].join(','),\n '&-active': {\n boxShadow: `0 0 0 6px currentcolor`,\n opacity: 0\n }\n }\n }\n };\n};\nexport default genComponentStyleHook('Wave', token => [genWaveStyle(token)]);","import { ref } from 'vue';\nexport default function useState(defaultStateValue) {\n const initValue = typeof defaultStateValue === 'function' ? defaultStateValue() : defaultStateValue;\n const innerValue = ref(initValue);\n function triggerChange(newValue) {\n innerValue.value = newValue;\n }\n return [innerValue, triggerChange];\n}","export function isNotGrey(color) {\n // eslint-disable-next-line no-useless-escape\n const match = (color || '').match(/rgba?\\((\\d*), (\\d*), (\\d*)(, [\\d.]*)?\\)/);\n if (match && match[1] && match[2] && match[3]) {\n return !(match[1] === match[2] && match[2] === match[3]);\n }\n return true;\n}\nexport function isValidWaveColor(color) {\n return color && color !== '#fff' && color !== '#ffffff' && color !== 'rgb(255, 255, 255)' && color !== 'rgba(255, 255, 255, 1)' && isNotGrey(color) && !/rgba\\((?:\\d*, ){3}0\\)/.test(color) &&\n // any transparent rgba color\n color !== 'transparent';\n}\nexport function getTargetWaveColor(node) {\n const {\n borderTopColor,\n borderColor,\n backgroundColor\n } = getComputedStyle(node);\n if (isValidWaveColor(borderTopColor)) {\n return borderTopColor;\n }\n if (isValidWaveColor(borderColor)) {\n return borderColor;\n }\n if (isValidWaveColor(backgroundColor)) {\n return backgroundColor;\n }\n return null;\n}","import { createVNode as _createVNode } from \"vue\";\nimport { onBeforeUnmount, onMounted, Transition, render, defineComponent, shallowRef } from 'vue';\nimport useState from '../hooks/useState';\nimport { objectType } from '../type';\nimport { getTargetWaveColor } from './util';\nimport wrapperRaf from '../raf';\nfunction validateNum(value) {\n return Number.isNaN(value) ? 0 : value;\n}\nconst WaveEffect = defineComponent({\n props: {\n target: objectType(),\n className: String\n },\n setup(props) {\n const divRef = shallowRef(null);\n const [color, setWaveColor] = useState(null);\n const [borderRadius, setBorderRadius] = useState([]);\n const [left, setLeft] = useState(0);\n const [top, setTop] = useState(0);\n const [width, setWidth] = useState(0);\n const [height, setHeight] = useState(0);\n const [enabled, setEnabled] = useState(false);\n function syncPos() {\n const {\n target\n } = props;\n const nodeStyle = getComputedStyle(target);\n // Get wave color from target\n setWaveColor(getTargetWaveColor(target));\n const isStatic = nodeStyle.position === 'static';\n // Rect\n const {\n borderLeftWidth,\n borderTopWidth\n } = nodeStyle;\n setLeft(isStatic ? target.offsetLeft : validateNum(-parseFloat(borderLeftWidth)));\n setTop(isStatic ? target.offsetTop : validateNum(-parseFloat(borderTopWidth)));\n setWidth(target.offsetWidth);\n setHeight(target.offsetHeight);\n // Get border radius\n const {\n borderTopLeftRadius,\n borderTopRightRadius,\n borderBottomLeftRadius,\n borderBottomRightRadius\n } = nodeStyle;\n setBorderRadius([borderTopLeftRadius, borderTopRightRadius, borderBottomRightRadius, borderBottomLeftRadius].map(radius => validateNum(parseFloat(radius))));\n }\n // Add resize observer to follow size\n let resizeObserver;\n let rafId;\n let timeoutId;\n const clear = () => {\n clearTimeout(timeoutId);\n wrapperRaf.cancel(rafId);\n resizeObserver === null || resizeObserver === void 0 ? void 0 : resizeObserver.disconnect();\n };\n const removeDom = () => {\n var _a;\n const holder = (_a = divRef.value) === null || _a === void 0 ? void 0 : _a.parentElement;\n if (holder) {\n render(null, holder);\n if (holder.parentElement) {\n holder.parentElement.removeChild(holder);\n }\n }\n };\n onMounted(() => {\n clear();\n timeoutId = setTimeout(() => {\n removeDom();\n }, 5000);\n const {\n target\n } = props;\n if (target) {\n // We need delay to check position here\n // since UI may change after click\n rafId = wrapperRaf(() => {\n syncPos();\n setEnabled(true);\n });\n if (typeof ResizeObserver !== 'undefined') {\n resizeObserver = new ResizeObserver(syncPos);\n resizeObserver.observe(target);\n }\n }\n });\n onBeforeUnmount(() => {\n clear();\n });\n const onTransitionend = e => {\n if (e.propertyName === 'opacity') {\n removeDom();\n }\n };\n return () => {\n if (!enabled.value) {\n return null;\n }\n const waveStyle = {\n left: `${left.value}px`,\n top: `${top.value}px`,\n width: `${width.value}px`,\n height: `${height.value}px`,\n borderRadius: borderRadius.value.map(radius => `${radius}px`).join(' ')\n };\n if (color) {\n waveStyle['--wave-color'] = color.value;\n }\n return _createVNode(Transition, {\n \"appear\": true,\n \"name\": \"wave-motion\",\n \"appearFromClass\": \"wave-motion-appear\",\n \"appearActiveClass\": \"wave-motion-appear\",\n \"appearToClass\": \"wave-motion-appear wave-motion-appear-active\"\n }, {\n default: () => [_createVNode(\"div\", {\n \"ref\": divRef,\n \"class\": props.className,\n \"style\": waveStyle,\n \"onTransitionend\": onTransitionend\n }, null)]\n });\n };\n }\n});\nfunction showWaveEffect(node, className) {\n // Create holder\n const holder = document.createElement('div');\n holder.style.position = 'absolute';\n holder.style.left = `0px`;\n holder.style.top = `0px`;\n node === null || node === void 0 ? void 0 : node.insertBefore(holder, node === null || node === void 0 ? void 0 : node.firstChild);\n render(_createVNode(WaveEffect, {\n \"target\": node,\n \"className\": className\n }, null), holder);\n}\nexport default showWaveEffect;","import { findDOMNode } from '../props-util';\nimport showWaveEffect from './WaveEffect';\nexport default function useWave(instance, className, wave) {\n function showWave() {\n var _a;\n const node = findDOMNode(instance);\n if (((_a = wave === null || wave === void 0 ? void 0 : wave.value) === null || _a === void 0 ? void 0 : _a.disabled) || !node) {\n return;\n }\n showWaveEffect(node, className.value);\n }\n return showWave;\n}","import { computed, defineComponent, getCurrentInstance, nextTick, onBeforeUnmount, onMounted, watch } from 'vue';\nimport useConfigInject from '../../config-provider/hooks/useConfigInject';\nimport isVisible from '../../vc-util/Dom/isVisible';\nimport classNames from '../classNames';\nimport { findDOMNode } from '../props-util';\nimport useStyle from './style';\nimport useWave from './useWave';\nexport default defineComponent({\n compatConfig: {\n MODE: 3\n },\n name: 'Wave',\n props: {\n disabled: Boolean\n },\n setup(props, _ref) {\n let {\n slots\n } = _ref;\n const instance = getCurrentInstance();\n const {\n prefixCls,\n wave\n } = useConfigInject('wave', props);\n // ============================== Style ===============================\n const [, hashId] = useStyle(prefixCls);\n // =============================== Wave ===============================\n const showWave = useWave(instance, computed(() => classNames(prefixCls.value, hashId.value)), wave);\n let onClick;\n const clear = () => {\n const node = findDOMNode(instance);\n node.removeEventListener('click', onClick, true);\n };\n onMounted(() => {\n watch(() => props.disabled, () => {\n clear();\n nextTick(() => {\n const node = findDOMNode(instance);\n node === null || node === void 0 ? void 0 : node.removeEventListener('click', onClick, true);\n if (!node || node.nodeType !== 1 || props.disabled) {\n return;\n }\n // Click handler\n onClick = e => {\n // Fix radio button click twice\n if (e.target.tagName === 'INPUT' || !isVisible(e.target) ||\n // No need wave\n !node.getAttribute || node.getAttribute('disabled') || node.disabled || node.className.includes('disabled') || node.className.includes('-leave')) {\n return;\n }\n showWave();\n };\n // Bind events\n node.addEventListener('click', onClick, true);\n });\n }, {\n immediate: true,\n flush: 'post'\n });\n });\n onBeforeUnmount(() => {\n clear();\n });\n return () => {\n var _a;\n // ============================== Render ==============================\n const children = (_a = slots.default) === null || _a === void 0 ? void 0 : _a.call(slots)[0];\n return children;\n };\n }\n});","/* eslint-disable no-console */\nlet warned = {};\nexport function warning(valid, message) {\n // Support uglify\n if (process.env.NODE_ENV !== 'production' && !valid && console !== undefined) {\n console.error(`Warning: ${message}`);\n }\n}\nexport function note(valid, message) {\n // Support uglify\n if (process.env.NODE_ENV !== 'production' && !valid && console !== undefined) {\n console.warn(`Note: ${message}`);\n }\n}\nexport function resetWarned() {\n warned = {};\n}\nexport function call(method, valid, message) {\n if (!valid && !warned[message]) {\n method(false, message);\n warned[message] = true;\n }\n}\nexport function warningOnce(valid, message) {\n call(warning, valid, message);\n}\nexport function noteOnce(valid, message) {\n call(note, valid, message);\n}\nexport default warningOnce;\n/* eslint-enable */","import devWarning, { resetWarned } from './warning';\nexport { resetWarned };\nexport default ((valid, component, message) => {\n devWarning(valid, `[ant-design-vue: ${component}] ${message}`);\n});","// This icon file is generated automatically.\nvar LoadingOutlined = { \"icon\": { \"tag\": \"svg\", \"attrs\": { \"viewBox\": \"0 0 1024 1024\", \"focusable\": \"false\" }, \"children\": [{ \"tag\": \"path\", \"attrs\": { \"d\": \"M988 548c-19.9 0-36-16.1-36-36 0-59.4-11.6-117-34.6-171.3a440.45 440.45 0 00-94.3-139.9 437.71 437.71 0 00-139.9-94.3C629 83.6 571.4 72 512 72c-19.9 0-36-16.1-36-36s16.1-36 36-36c69.1 0 136.2 13.5 199.3 40.3C772.3 66 827 103 874 150c47 47 83.9 101.8 109.7 162.7 26.7 63.1 40.2 130.2 40.2 199.3.1 19.9-16 36-35.9 36z\" } }] }, \"name\": \"loading\", \"theme\": \"outlined\" };\nexport default LoadingOutlined;\n","import { createVNode as _createVNode } from \"vue\";\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? Object(arguments[i]) : {}; var ownKeys = Object.keys(source); if (typeof Object.getOwnPropertySymbols === 'function') { ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function (sym) { return Object.getOwnPropertyDescriptor(source, sym).enumerable; })); } ownKeys.forEach(function (key) { _defineProperty(target, key, source[key]); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n// GENERATE BY ./scripts/generate.ts\n// DON NOT EDIT IT MANUALLY\nimport LoadingOutlinedSvg from \"@ant-design/icons-svg/es/asn/LoadingOutlined\";\nimport AntdIcon from '../components/AntdIcon';\n\nvar LoadingOutlined = function LoadingOutlined(props, context) {\n var p = _objectSpread({}, props, context.attrs);\n\n return _createVNode(AntdIcon, _objectSpread({}, p, {\n \"icon\": LoadingOutlinedSvg\n }), null);\n};\n\nLoadingOutlined.displayName = 'LoadingOutlined';\nLoadingOutlined.inheritAttrs = false;\nexport default LoadingOutlined;","import { createVNode as _createVNode } from \"vue\";\nimport { defineComponent, nextTick } from 'vue';\nimport LoadingOutlined from \"@ant-design/icons-vue/es/icons/LoadingOutlined\";\nimport Transition from '../_util/transition';\nconst getCollapsedWidth = node => {\n if (node) {\n node.style.width = '0px';\n node.style.opacity = '0';\n node.style.transform = 'scale(0)';\n }\n};\nconst getRealWidth = node => {\n nextTick(() => {\n if (node) {\n node.style.width = `${node.scrollWidth}px`;\n node.style.opacity = '1';\n node.style.transform = 'scale(1)';\n }\n });\n};\nconst resetStyle = node => {\n if (node && node.style) {\n node.style.width = null;\n node.style.opacity = null;\n node.style.transform = null;\n }\n};\nexport default defineComponent({\n compatConfig: {\n MODE: 3\n },\n name: 'LoadingIcon',\n props: {\n prefixCls: String,\n loading: [Boolean, Object],\n existIcon: Boolean\n },\n setup(props) {\n return () => {\n const {\n existIcon,\n prefixCls,\n loading\n } = props;\n if (existIcon) {\n return _createVNode(\"span\", {\n \"class\": `${prefixCls}-loading-icon`\n }, [_createVNode(LoadingOutlined, null, null)]);\n }\n const visible = !!loading;\n return _createVNode(Transition, {\n \"name\": `${prefixCls}-loading-icon-motion`,\n \"onBeforeEnter\": getCollapsedWidth,\n \"onEnter\": getRealWidth,\n \"onAfterEnter\": resetStyle,\n \"onBeforeLeave\": getRealWidth,\n \"onLeave\": node => {\n setTimeout(() => {\n getCollapsedWidth(node);\n });\n },\n \"onAfterLeave\": resetStyle\n }, {\n default: () => [visible ? _createVNode(\"span\", {\n \"class\": `${prefixCls}-loading-icon`\n }, [_createVNode(LoadingOutlined, null, null)]) : null]\n });\n };\n }\n});","const genButtonBorderStyle = (buttonTypeCls, borderColor) => ({\n // Border\n [`> span, > ${buttonTypeCls}`]: {\n '&:not(:last-child)': {\n [`&, & > ${buttonTypeCls}`]: {\n '&:not(:disabled)': {\n borderInlineEndColor: borderColor\n }\n }\n },\n '&:not(:first-child)': {\n [`&, & > ${buttonTypeCls}`]: {\n '&:not(:disabled)': {\n borderInlineStartColor: borderColor\n }\n }\n }\n }\n});\nconst genGroupStyle = token => {\n const {\n componentCls,\n fontSize,\n lineWidth,\n colorPrimaryHover,\n colorErrorHover\n } = token;\n return {\n [`${componentCls}-group`]: [{\n position: 'relative',\n display: 'inline-flex',\n // Border\n [`> span, > ${componentCls}`]: {\n '&:not(:last-child)': {\n [`&, & > ${componentCls}`]: {\n borderStartEndRadius: 0,\n borderEndEndRadius: 0\n }\n },\n '&:not(:first-child)': {\n marginInlineStart: -lineWidth,\n [`&, & > ${componentCls}`]: {\n borderStartStartRadius: 0,\n borderEndStartRadius: 0\n }\n }\n },\n [componentCls]: {\n position: 'relative',\n zIndex: 1,\n [`&:hover,\n &:focus,\n &:active`]: {\n zIndex: 2\n },\n '&[disabled]': {\n zIndex: 0\n }\n },\n [`${componentCls}-icon-only`]: {\n fontSize\n }\n },\n // Border Color\n genButtonBorderStyle(`${componentCls}-primary`, colorPrimaryHover), genButtonBorderStyle(`${componentCls}-danger`, colorErrorHover)]\n };\n};\nexport default genGroupStyle;","import _extends from \"@babel/runtime/helpers/esm/extends\";\n// handle border collapse\nfunction compactItemBorder(token, parentCls, options) {\n const {\n focusElCls,\n focus,\n borderElCls\n } = options;\n const childCombinator = borderElCls ? '> *' : '';\n const hoverEffects = ['hover', focus ? 'focus' : null, 'active'].filter(Boolean).map(n => `&:${n} ${childCombinator}`).join(',');\n return {\n [`&-item:not(${parentCls}-last-item)`]: {\n marginInlineEnd: -token.lineWidth\n },\n '&-item': _extends(_extends({\n [hoverEffects]: {\n zIndex: 2\n }\n }, focusElCls ? {\n [`&${focusElCls}`]: {\n zIndex: 2\n }\n } : {}), {\n [`&[disabled] ${childCombinator}`]: {\n zIndex: 0\n }\n })\n };\n}\n// handle border-radius\nfunction compactItemBorderRadius(prefixCls, parentCls, options) {\n const {\n borderElCls\n } = options;\n const childCombinator = borderElCls ? `> ${borderElCls}` : '';\n return {\n [`&-item:not(${parentCls}-first-item):not(${parentCls}-last-item) ${childCombinator}`]: {\n borderRadius: 0\n },\n [`&-item:not(${parentCls}-last-item)${parentCls}-first-item`]: {\n [`& ${childCombinator}, &${prefixCls}-sm ${childCombinator}, &${prefixCls}-lg ${childCombinator}`]: {\n borderStartEndRadius: 0,\n borderEndEndRadius: 0\n }\n },\n [`&-item:not(${parentCls}-first-item)${parentCls}-last-item`]: {\n [`& ${childCombinator}, &${prefixCls}-sm ${childCombinator}, &${prefixCls}-lg ${childCombinator}`]: {\n borderStartStartRadius: 0,\n borderEndStartRadius: 0\n }\n }\n };\n}\nexport function genCompactItemStyle(token) {\n let options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {\n focus: true\n };\n const {\n componentCls\n } = token;\n const compactCls = `${componentCls}-compact`;\n return {\n [compactCls]: _extends(_extends({}, compactItemBorder(token, compactCls, options)), compactItemBorderRadius(componentCls, compactCls, options))\n };\n}","import _extends from \"@babel/runtime/helpers/esm/extends\";\nfunction compactItemVerticalBorder(token, parentCls) {\n return {\n // border collapse\n [`&-item:not(${parentCls}-last-item)`]: {\n marginBottom: -token.lineWidth\n },\n '&-item': {\n '&:hover,&:focus,&:active': {\n zIndex: 2\n },\n '&[disabled]': {\n zIndex: 0\n }\n }\n };\n}\nfunction compactItemBorderVerticalRadius(prefixCls, parentCls) {\n return {\n [`&-item:not(${parentCls}-first-item):not(${parentCls}-last-item)`]: {\n borderRadius: 0\n },\n [`&-item${parentCls}-first-item:not(${parentCls}-last-item)`]: {\n [`&, &${prefixCls}-sm, &${prefixCls}-lg`]: {\n borderEndEndRadius: 0,\n borderEndStartRadius: 0\n }\n },\n [`&-item${parentCls}-last-item:not(${parentCls}-first-item)`]: {\n [`&, &${prefixCls}-sm, &${prefixCls}-lg`]: {\n borderStartStartRadius: 0,\n borderStartEndRadius: 0\n }\n }\n };\n}\nexport function genCompactItemVerticalStyle(token) {\n const compactCls = `${token.componentCls}-compact-vertical`;\n return {\n [compactCls]: _extends(_extends({}, compactItemVerticalBorder(token, compactCls)), compactItemBorderVerticalRadius(token.componentCls, compactCls))\n };\n}","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport { genComponentStyleHook, mergeToken } from '../../theme/internal';\nimport genGroupStyle from './group';\nimport { genFocusStyle } from '../../style';\nimport { genCompactItemStyle } from '../../style/compact-item';\nimport { genCompactItemVerticalStyle } from '../../style/compact-item-vertical';\n// ============================== Shared ==============================\nconst genSharedButtonStyle = token => {\n const {\n componentCls,\n iconCls\n } = token;\n return {\n [componentCls]: {\n outline: 'none',\n position: 'relative',\n display: 'inline-block',\n fontWeight: 400,\n whiteSpace: 'nowrap',\n textAlign: 'center',\n backgroundImage: 'none',\n backgroundColor: 'transparent',\n border: `${token.lineWidth}px ${token.lineType} transparent`,\n cursor: 'pointer',\n transition: `all ${token.motionDurationMid} ${token.motionEaseInOut}`,\n userSelect: 'none',\n touchAction: 'manipulation',\n lineHeight: token.lineHeight,\n color: token.colorText,\n '> span': {\n display: 'inline-block'\n },\n // Leave a space between icon and text.\n [`> ${iconCls} + span, > span + ${iconCls}`]: {\n marginInlineStart: token.marginXS\n },\n '> a': {\n color: 'currentColor'\n },\n '&:not(:disabled)': _extends({}, genFocusStyle(token)),\n // make `btn-icon-only` not too narrow\n [`&-icon-only${componentCls}-compact-item`]: {\n flex: 'none'\n },\n // Special styles for Primary Button\n [`&-compact-item${componentCls}-primary`]: {\n [`&:not([disabled]) + ${componentCls}-compact-item${componentCls}-primary:not([disabled])`]: {\n position: 'relative',\n '&:before': {\n position: 'absolute',\n top: -token.lineWidth,\n insetInlineStart: -token.lineWidth,\n display: 'inline-block',\n width: token.lineWidth,\n height: `calc(100% + ${token.lineWidth * 2}px)`,\n backgroundColor: token.colorPrimaryHover,\n content: '\"\"'\n }\n }\n },\n // Special styles for Primary Button\n '&-compact-vertical-item': {\n [`&${componentCls}-primary`]: {\n [`&:not([disabled]) + ${componentCls}-compact-vertical-item${componentCls}-primary:not([disabled])`]: {\n position: 'relative',\n '&:before': {\n position: 'absolute',\n top: -token.lineWidth,\n insetInlineStart: -token.lineWidth,\n display: 'inline-block',\n width: `calc(100% + ${token.lineWidth * 2}px)`,\n height: token.lineWidth,\n backgroundColor: token.colorPrimaryHover,\n content: '\"\"'\n }\n }\n }\n }\n }\n };\n};\nconst genHoverActiveButtonStyle = (hoverStyle, activeStyle) => ({\n '&:not(:disabled)': {\n '&:hover': hoverStyle,\n '&:active': activeStyle\n }\n});\n// ============================== Shape ===============================\nconst genCircleButtonStyle = token => ({\n minWidth: token.controlHeight,\n paddingInlineStart: 0,\n paddingInlineEnd: 0,\n borderRadius: '50%'\n});\nconst genRoundButtonStyle = token => ({\n borderRadius: token.controlHeight,\n paddingInlineStart: token.controlHeight / 2,\n paddingInlineEnd: token.controlHeight / 2\n});\n// =============================== Type ===============================\nconst genDisabledStyle = token => ({\n cursor: 'not-allowed',\n borderColor: token.colorBorder,\n color: token.colorTextDisabled,\n backgroundColor: token.colorBgContainerDisabled,\n boxShadow: 'none'\n});\nconst genGhostButtonStyle = (btnCls, textColor, borderColor, textColorDisabled, borderColorDisabled, hoverStyle, activeStyle) => ({\n [`&${btnCls}-background-ghost`]: _extends(_extends({\n color: textColor || undefined,\n backgroundColor: 'transparent',\n borderColor: borderColor || undefined,\n boxShadow: 'none'\n }, genHoverActiveButtonStyle(_extends({\n backgroundColor: 'transparent'\n }, hoverStyle), _extends({\n backgroundColor: 'transparent'\n }, activeStyle))), {\n '&:disabled': {\n cursor: 'not-allowed',\n color: textColorDisabled || undefined,\n borderColor: borderColorDisabled || undefined\n }\n })\n});\nconst genSolidDisabledButtonStyle = token => ({\n '&:disabled': _extends({}, genDisabledStyle(token))\n});\nconst genSolidButtonStyle = token => _extends({}, genSolidDisabledButtonStyle(token));\nconst genPureDisabledButtonStyle = token => ({\n '&:disabled': {\n cursor: 'not-allowed',\n color: token.colorTextDisabled\n }\n});\n// Type: Default\nconst genDefaultButtonStyle = token => _extends(_extends(_extends(_extends(_extends({}, genSolidButtonStyle(token)), {\n backgroundColor: token.colorBgContainer,\n borderColor: token.colorBorder,\n boxShadow: `0 ${token.controlOutlineWidth}px 0 ${token.controlTmpOutline}`\n}), genHoverActiveButtonStyle({\n color: token.colorPrimaryHover,\n borderColor: token.colorPrimaryHover\n}, {\n color: token.colorPrimaryActive,\n borderColor: token.colorPrimaryActive\n})), genGhostButtonStyle(token.componentCls, token.colorBgContainer, token.colorBgContainer, token.colorTextDisabled, token.colorBorder)), {\n [`&${token.componentCls}-dangerous`]: _extends(_extends(_extends({\n color: token.colorError,\n borderColor: token.colorError\n }, genHoverActiveButtonStyle({\n color: token.colorErrorHover,\n borderColor: token.colorErrorBorderHover\n }, {\n color: token.colorErrorActive,\n borderColor: token.colorErrorActive\n })), genGhostButtonStyle(token.componentCls, token.colorError, token.colorError, token.colorTextDisabled, token.colorBorder)), genSolidDisabledButtonStyle(token))\n});\n// Type: Primary\nconst genPrimaryButtonStyle = token => _extends(_extends(_extends(_extends(_extends({}, genSolidButtonStyle(token)), {\n color: token.colorTextLightSolid,\n backgroundColor: token.colorPrimary,\n boxShadow: `0 ${token.controlOutlineWidth}px 0 ${token.controlOutline}`\n}), genHoverActiveButtonStyle({\n color: token.colorTextLightSolid,\n backgroundColor: token.colorPrimaryHover\n}, {\n color: token.colorTextLightSolid,\n backgroundColor: token.colorPrimaryActive\n})), genGhostButtonStyle(token.componentCls, token.colorPrimary, token.colorPrimary, token.colorTextDisabled, token.colorBorder, {\n color: token.colorPrimaryHover,\n borderColor: token.colorPrimaryHover\n}, {\n color: token.colorPrimaryActive,\n borderColor: token.colorPrimaryActive\n})), {\n [`&${token.componentCls}-dangerous`]: _extends(_extends(_extends({\n backgroundColor: token.colorError,\n boxShadow: `0 ${token.controlOutlineWidth}px 0 ${token.colorErrorOutline}`\n }, genHoverActiveButtonStyle({\n backgroundColor: token.colorErrorHover\n }, {\n backgroundColor: token.colorErrorActive\n })), genGhostButtonStyle(token.componentCls, token.colorError, token.colorError, token.colorTextDisabled, token.colorBorder, {\n color: token.colorErrorHover,\n borderColor: token.colorErrorHover\n }, {\n color: token.colorErrorActive,\n borderColor: token.colorErrorActive\n })), genSolidDisabledButtonStyle(token))\n});\n// Type: Dashed\nconst genDashedButtonStyle = token => _extends(_extends({}, genDefaultButtonStyle(token)), {\n borderStyle: 'dashed'\n});\n// Type: Link\nconst genLinkButtonStyle = token => _extends(_extends(_extends({\n color: token.colorLink\n}, genHoverActiveButtonStyle({\n color: token.colorLinkHover\n}, {\n color: token.colorLinkActive\n})), genPureDisabledButtonStyle(token)), {\n [`&${token.componentCls}-dangerous`]: _extends(_extends({\n color: token.colorError\n }, genHoverActiveButtonStyle({\n color: token.colorErrorHover\n }, {\n color: token.colorErrorActive\n })), genPureDisabledButtonStyle(token))\n});\n// Type: Text\nconst genTextButtonStyle = token => _extends(_extends(_extends({}, genHoverActiveButtonStyle({\n color: token.colorText,\n backgroundColor: token.colorBgTextHover\n}, {\n color: token.colorText,\n backgroundColor: token.colorBgTextActive\n})), genPureDisabledButtonStyle(token)), {\n [`&${token.componentCls}-dangerous`]: _extends(_extends({\n color: token.colorError\n }, genPureDisabledButtonStyle(token)), genHoverActiveButtonStyle({\n color: token.colorErrorHover,\n backgroundColor: token.colorErrorBg\n }, {\n color: token.colorErrorHover,\n backgroundColor: token.colorErrorBg\n }))\n});\n// Href and Disabled\nconst genDisabledButtonStyle = token => _extends(_extends({}, genDisabledStyle(token)), {\n [`&${token.componentCls}:hover`]: _extends({}, genDisabledStyle(token))\n});\nconst genTypeButtonStyle = token => {\n const {\n componentCls\n } = token;\n return {\n [`${componentCls}-default`]: genDefaultButtonStyle(token),\n [`${componentCls}-primary`]: genPrimaryButtonStyle(token),\n [`${componentCls}-dashed`]: genDashedButtonStyle(token),\n [`${componentCls}-link`]: genLinkButtonStyle(token),\n [`${componentCls}-text`]: genTextButtonStyle(token),\n [`${componentCls}-disabled`]: genDisabledButtonStyle(token)\n };\n};\n// =============================== Size ===============================\nconst genSizeButtonStyle = function (token) {\n let sizePrefixCls = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';\n const {\n componentCls,\n iconCls,\n controlHeight,\n fontSize,\n lineHeight,\n lineWidth,\n borderRadius,\n buttonPaddingHorizontal\n } = token;\n const paddingVertical = Math.max(0, (controlHeight - fontSize * lineHeight) / 2 - lineWidth);\n const paddingHorizontal = buttonPaddingHorizontal - lineWidth;\n const iconOnlyCls = `${componentCls}-icon-only`;\n return [\n // Size\n {\n [`${componentCls}${sizePrefixCls}`]: {\n fontSize,\n height: controlHeight,\n padding: `${paddingVertical}px ${paddingHorizontal}px`,\n borderRadius,\n [`&${iconOnlyCls}`]: {\n width: controlHeight,\n paddingInlineStart: 0,\n paddingInlineEnd: 0,\n [`&${componentCls}-round`]: {\n width: 'auto'\n },\n '> span': {\n transform: 'scale(1.143)' // 14px -> 16px\n }\n },\n // Loading\n [`&${componentCls}-loading`]: {\n opacity: token.opacityLoading,\n cursor: 'default'\n },\n [`${componentCls}-loading-icon`]: {\n transition: `width ${token.motionDurationSlow} ${token.motionEaseInOut}, opacity ${token.motionDurationSlow} ${token.motionEaseInOut}`\n },\n [`&:not(${iconOnlyCls}) ${componentCls}-loading-icon > ${iconCls}`]: {\n marginInlineEnd: token.marginXS\n }\n }\n },\n // Shape - patch prefixCls again to override solid border radius style\n {\n [`${componentCls}${componentCls}-circle${sizePrefixCls}`]: genCircleButtonStyle(token)\n }, {\n [`${componentCls}${componentCls}-round${sizePrefixCls}`]: genRoundButtonStyle(token)\n }];\n};\nconst genSizeBaseButtonStyle = token => genSizeButtonStyle(token);\nconst genSizeSmallButtonStyle = token => {\n const smallToken = mergeToken(token, {\n controlHeight: token.controlHeightSM,\n padding: token.paddingXS,\n buttonPaddingHorizontal: 8,\n borderRadius: token.borderRadiusSM\n });\n return genSizeButtonStyle(smallToken, `${token.componentCls}-sm`);\n};\nconst genSizeLargeButtonStyle = token => {\n const largeToken = mergeToken(token, {\n controlHeight: token.controlHeightLG,\n fontSize: token.fontSizeLG,\n borderRadius: token.borderRadiusLG\n });\n return genSizeButtonStyle(largeToken, `${token.componentCls}-lg`);\n};\nconst genBlockButtonStyle = token => {\n const {\n componentCls\n } = token;\n return {\n [componentCls]: {\n [`&${componentCls}-block`]: {\n width: '100%'\n }\n }\n };\n};\n// ============================== Export ==============================\nexport default genComponentStyleHook('Button', token => {\n const {\n controlTmpOutline,\n paddingContentHorizontal\n } = token;\n const buttonToken = mergeToken(token, {\n colorOutlineDefault: controlTmpOutline,\n buttonPaddingHorizontal: paddingContentHorizontal\n });\n return [\n // Shared\n genSharedButtonStyle(buttonToken),\n // Size\n genSizeSmallButtonStyle(buttonToken), genSizeBaseButtonStyle(buttonToken), genSizeLargeButtonStyle(buttonToken),\n // Block\n genBlockButtonStyle(buttonToken),\n // Group (type, ghost, danger, disabled, loading)\n genTypeButtonStyle(buttonToken),\n // Button Group\n genGroupStyle(buttonToken),\n // Space Compact\n genCompactItemStyle(token, {\n focus: false\n }), genCompactItemVerticalStyle(token)];\n});","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport { inject, provide, reactive, watchEffect } from 'vue';\nfunction createContext(defaultValue) {\n const contextKey = Symbol('contextKey');\n const useProvide = (props, newProps) => {\n const mergedProps = reactive({});\n provide(contextKey, mergedProps);\n watchEffect(() => {\n _extends(mergedProps, props, newProps || {});\n });\n return mergedProps;\n };\n const useInject = () => {\n return inject(contextKey, defaultValue) || {};\n };\n return {\n useProvide,\n useInject\n };\n}\nexport default createContext;","import { createVNode as _createVNode } from \"vue\";\nimport { computed, defineComponent, reactive } from 'vue';\nimport { flattenChildren } from '../_util/props-util';\nimport useConfigInject from '../config-provider/hooks/useConfigInject';\nimport { useToken } from '../theme/internal';\nimport devWarning from '../vc-util/devWarning';\nimport createContext from '../_util/createContext';\nexport const buttonGroupProps = () => ({\n prefixCls: String,\n size: {\n type: String\n }\n});\nexport const GroupSizeContext = createContext();\nexport default defineComponent({\n compatConfig: {\n MODE: 3\n },\n name: 'AButtonGroup',\n props: buttonGroupProps(),\n setup(props, _ref) {\n let {\n slots\n } = _ref;\n const {\n prefixCls,\n direction\n } = useConfigInject('btn-group', props);\n const [,, hashId] = useToken();\n GroupSizeContext.useProvide(reactive({\n size: computed(() => props.size)\n }));\n const classes = computed(() => {\n const {\n size\n } = props;\n let sizeCls = '';\n switch (size) {\n case 'large':\n sizeCls = 'lg';\n break;\n case 'small':\n sizeCls = 'sm';\n break;\n case 'middle':\n case undefined:\n break;\n default:\n // eslint-disable-next-line no-console\n devWarning(!size, 'Button.Group', 'Invalid prop `size`.');\n }\n return {\n [`${prefixCls.value}`]: true,\n [`${prefixCls.value}-${sizeCls}`]: sizeCls,\n [`${prefixCls.value}-rtl`]: direction.value === 'rtl',\n [hashId.value]: true\n };\n });\n return () => {\n var _a;\n return _createVNode(\"div\", {\n \"class\": classes.value\n }, [flattenChildren((_a = slots.default) === null || _a === void 0 ? void 0 : _a.call(slots))]);\n };\n }\n});","const genSpaceCompactStyle = token => {\n const {\n componentCls\n } = token;\n return {\n [componentCls]: {\n display: 'inline-flex',\n '&-block': {\n display: 'flex',\n width: '100%'\n },\n '&-vertical': {\n flexDirection: 'column'\n }\n }\n };\n};\n// ============================== Export ==============================\nexport default genSpaceCompactStyle;","import { genComponentStyleHook } from '../../theme/internal';\nimport genSpaceCompactStyle from './compact';\nconst genSpaceStyle = token => {\n const {\n componentCls\n } = token;\n return {\n [componentCls]: {\n display: 'inline-flex',\n '&-rtl': {\n direction: 'rtl'\n },\n '&-vertical': {\n flexDirection: 'column'\n },\n '&-align': {\n flexDirection: 'column',\n '&-center': {\n alignItems: 'center'\n },\n '&-start': {\n alignItems: 'flex-start'\n },\n '&-end': {\n alignItems: 'flex-end'\n },\n '&-baseline': {\n alignItems: 'baseline'\n }\n },\n [`${componentCls}-space-item`]: {\n '&:empty': {\n display: 'none'\n }\n }\n }\n };\n};\n// ============================== Export ==============================\nexport default genComponentStyleHook('Space', token => [genSpaceStyle(token), genSpaceCompactStyle(token)]);","import baseKeys from './_baseKeys.js';\nimport getTag from './_getTag.js';\nimport isArguments from './isArguments.js';\nimport isArray from './isArray.js';\nimport isArrayLike from './isArrayLike.js';\nimport isBuffer from './isBuffer.js';\nimport isPrototype from './_isPrototype.js';\nimport isTypedArray from './isTypedArray.js';\n\n/** `Object#toString` result references. */\nvar mapTag = '[object Map]',\n setTag = '[object Set]';\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 * Checks if `value` is an empty object, collection, map, or set.\n *\n * Objects are considered empty if they have no own enumerable string keyed\n * properties.\n *\n * Array-like values such as `arguments` objects, arrays, buffers, strings, or\n * jQuery-like collections are considered empty if they have a `length` of `0`.\n * Similarly, maps and sets are considered empty if they have a `size` of `0`.\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 empty, else `false`.\n * @example\n *\n * _.isEmpty(null);\n * // => true\n *\n * _.isEmpty(true);\n * // => true\n *\n * _.isEmpty(1);\n * // => true\n *\n * _.isEmpty([1, 2, 3]);\n * // => false\n *\n * _.isEmpty({ 'a': 1 });\n * // => false\n */\nfunction isEmpty(value) {\n if (value == null) {\n return true;\n }\n if (isArrayLike(value) &&\n (isArray(value) || typeof value == 'string' || typeof value.splice == 'function' ||\n isBuffer(value) || isTypedArray(value) || isArguments(value))) {\n return !value.length;\n }\n var tag = getTag(value);\n if (tag == mapTag || tag == setTag) {\n return !value.size;\n }\n if (isPrototype(value)) {\n return !baseKeys(value).length;\n }\n for (var key in value) {\n if (hasOwnProperty.call(value, key)) {\n return false;\n }\n }\n return true;\n}\n\nexport default isEmpty;\n","import _objectSpread from \"@babel/runtime/helpers/esm/objectSpread2\";\nimport { createVNode as _createVNode } from \"vue\";\nimport classNames from '../_util/classNames';\nimport createContext from '../_util/createContext';\nimport useConfigInject from '../config-provider/hooks/useConfigInject';\nimport useStyle from './style';\nimport { computed, defineComponent } from 'vue';\nimport PropTypes from '../_util/vue-types';\nimport { booleanType, tuple } from '../_util/type';\nimport { isEmpty } from 'lodash-es';\nimport { flattenChildren } from '../_util/props-util';\nexport const spaceCompactItemProps = () => ({\n compactSize: String,\n compactDirection: PropTypes.oneOf(tuple('horizontal', 'vertical')).def('horizontal'),\n isFirstItem: booleanType(),\n isLastItem: booleanType()\n});\nexport const SpaceCompactItemContext = createContext(null);\nexport const useCompactItemContext = (prefixCls, direction) => {\n const compactItemContext = SpaceCompactItemContext.useInject();\n const compactItemClassnames = computed(() => {\n if (!compactItemContext || isEmpty(compactItemContext)) return '';\n const {\n compactDirection,\n isFirstItem,\n isLastItem\n } = compactItemContext;\n const separator = compactDirection === 'vertical' ? '-vertical-' : '-';\n return classNames({\n [`${prefixCls.value}-compact${separator}item`]: true,\n [`${prefixCls.value}-compact${separator}first-item`]: isFirstItem,\n [`${prefixCls.value}-compact${separator}last-item`]: isLastItem,\n [`${prefixCls.value}-compact${separator}item-rtl`]: direction.value === 'rtl'\n });\n });\n return {\n compactSize: computed(() => compactItemContext === null || compactItemContext === void 0 ? void 0 : compactItemContext.compactSize),\n compactDirection: computed(() => compactItemContext === null || compactItemContext === void 0 ? void 0 : compactItemContext.compactDirection),\n compactItemClassnames\n };\n};\nexport const NoCompactStyle = defineComponent({\n name: 'NoCompactStyle',\n setup(_, _ref) {\n let {\n slots\n } = _ref;\n SpaceCompactItemContext.useProvide(null);\n return () => {\n var _a;\n return (_a = slots.default) === null || _a === void 0 ? void 0 : _a.call(slots);\n };\n }\n});\nexport const spaceCompactProps = () => ({\n prefixCls: String,\n size: {\n type: String\n },\n direction: PropTypes.oneOf(tuple('horizontal', 'vertical')).def('horizontal'),\n align: PropTypes.oneOf(tuple('start', 'end', 'center', 'baseline')),\n block: {\n type: Boolean,\n default: undefined\n }\n});\nconst CompactItem = defineComponent({\n name: 'CompactItem',\n props: spaceCompactItemProps(),\n setup(props, _ref2) {\n let {\n slots\n } = _ref2;\n SpaceCompactItemContext.useProvide(props);\n return () => {\n var _a;\n return (_a = slots.default) === null || _a === void 0 ? void 0 : _a.call(slots);\n };\n }\n});\nconst Compact = defineComponent({\n name: 'ASpaceCompact',\n inheritAttrs: false,\n props: spaceCompactProps(),\n setup(props, _ref3) {\n let {\n attrs,\n slots\n } = _ref3;\n const {\n prefixCls,\n direction: directionConfig\n } = useConfigInject('space-compact', props);\n const compactItemContext = SpaceCompactItemContext.useInject();\n const [wrapSSR, hashId] = useStyle(prefixCls);\n const clx = computed(() => {\n return classNames(prefixCls.value, hashId.value, {\n [`${prefixCls.value}-rtl`]: directionConfig.value === 'rtl',\n [`${prefixCls.value}-block`]: props.block,\n [`${prefixCls.value}-vertical`]: props.direction === 'vertical'\n });\n });\n return () => {\n var _a;\n const childNodes = flattenChildren(((_a = slots.default) === null || _a === void 0 ? void 0 : _a.call(slots)) || []);\n // =========================== Render ===========================\n if (childNodes.length === 0) {\n return null;\n }\n return wrapSSR(_createVNode(\"div\", _objectSpread(_objectSpread({}, attrs), {}, {\n \"class\": [clx.value, attrs.class]\n }), [childNodes.map((child, i) => {\n var _a;\n const key = child && child.key || `${prefixCls.value}-item-${i}`;\n const noCompactItemContext = !compactItemContext || isEmpty(compactItemContext);\n return _createVNode(CompactItem, {\n \"key\": key,\n \"compactSize\": (_a = props.size) !== null && _a !== void 0 ? _a : 'middle',\n \"compactDirection\": props.direction,\n \"isFirstItem\": i === 0 && (noCompactItemContext || (compactItemContext === null || compactItemContext === void 0 ? void 0 : compactItemContext.isFirstItem)),\n \"isLastItem\": i === childNodes.length - 1 && (noCompactItemContext || (compactItemContext === null || compactItemContext === void 0 ? void 0 : compactItemContext.isLastItem))\n }, {\n default: () => [child]\n });\n })]));\n };\n }\n});\nexport default Compact;","import _objectSpread from \"@babel/runtime/helpers/esm/objectSpread2\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport { createVNode as _createVNode } from \"vue\";\nimport { computed, defineComponent, onBeforeUnmount, onMounted, onUpdated, shallowRef, Text, watch, watchEffect } from 'vue';\nimport Wave from '../_util/wave';\nimport buttonProps from './buttonTypes';\nimport { flattenChildren, initDefaultProps } from '../_util/props-util';\nimport useConfigInject from '../config-provider/hooks/useConfigInject';\nimport { useInjectDisabled } from '../config-provider/DisabledContext';\nimport devWarning from '../vc-util/devWarning';\nimport LoadingIcon from './LoadingIcon';\nimport useStyle from './style';\nimport { GroupSizeContext } from './button-group';\nimport { useCompactItemContext } from '../space/Compact';\nconst rxTwoCNChar = /^[\\u4e00-\\u9fa5]{2}$/;\nconst isTwoCNChar = rxTwoCNChar.test.bind(rxTwoCNChar);\nfunction isUnBorderedButtonType(type) {\n return type === 'text' || type === 'link';\n}\nexport { buttonProps };\nexport default defineComponent({\n compatConfig: {\n MODE: 3\n },\n name: 'AButton',\n inheritAttrs: false,\n __ANT_BUTTON: true,\n props: initDefaultProps(buttonProps(), {\n type: 'default'\n }),\n slots: Object,\n // emits: ['click', 'mousedown'],\n setup(props, _ref) {\n let {\n slots,\n attrs,\n emit,\n expose\n } = _ref;\n const {\n prefixCls,\n autoInsertSpaceInButton,\n direction,\n size\n } = useConfigInject('btn', props);\n const [wrapSSR, hashId] = useStyle(prefixCls);\n const groupSizeContext = GroupSizeContext.useInject();\n const disabledContext = useInjectDisabled();\n const mergedDisabled = computed(() => {\n var _a;\n return (_a = props.disabled) !== null && _a !== void 0 ? _a : disabledContext.value;\n });\n const buttonNodeRef = shallowRef(null);\n const delayTimeoutRef = shallowRef(undefined);\n let isNeedInserted = false;\n const innerLoading = shallowRef(false);\n const hasTwoCNChar = shallowRef(false);\n const autoInsertSpace = computed(() => autoInsertSpaceInButton.value !== false);\n const {\n compactSize,\n compactItemClassnames\n } = useCompactItemContext(prefixCls, direction);\n // =============== Update Loading ===============\n const loadingOrDelay = computed(() => typeof props.loading === 'object' && props.loading.delay ? props.loading.delay || true : !!props.loading);\n watch(loadingOrDelay, val => {\n clearTimeout(delayTimeoutRef.value);\n if (typeof loadingOrDelay.value === 'number') {\n delayTimeoutRef.value = setTimeout(() => {\n innerLoading.value = val;\n }, loadingOrDelay.value);\n } else {\n innerLoading.value = val;\n }\n }, {\n immediate: true\n });\n const classes = computed(() => {\n const {\n type,\n shape = 'default',\n ghost,\n block,\n danger\n } = props;\n const pre = prefixCls.value;\n const sizeClassNameMap = {\n large: 'lg',\n small: 'sm',\n middle: undefined\n };\n const sizeFullname = compactSize.value || (groupSizeContext === null || groupSizeContext === void 0 ? void 0 : groupSizeContext.size) || size.value;\n const sizeCls = sizeFullname ? sizeClassNameMap[sizeFullname] || '' : '';\n return [compactItemClassnames.value, {\n [hashId.value]: true,\n [`${pre}`]: true,\n [`${pre}-${shape}`]: shape !== 'default' && shape,\n [`${pre}-${type}`]: type,\n [`${pre}-${sizeCls}`]: sizeCls,\n [`${pre}-loading`]: innerLoading.value,\n [`${pre}-background-ghost`]: ghost && !isUnBorderedButtonType(type),\n [`${pre}-two-chinese-chars`]: hasTwoCNChar.value && autoInsertSpace.value,\n [`${pre}-block`]: block,\n [`${pre}-dangerous`]: !!danger,\n [`${pre}-rtl`]: direction.value === 'rtl'\n }];\n });\n const fixTwoCNChar = () => {\n // Fix for HOC usage like \n const node = buttonNodeRef.value;\n if (!node || autoInsertSpaceInButton.value === false) {\n return;\n }\n const buttonText = node.textContent;\n if (isNeedInserted && isTwoCNChar(buttonText)) {\n if (!hasTwoCNChar.value) {\n hasTwoCNChar.value = true;\n }\n } else if (hasTwoCNChar.value) {\n hasTwoCNChar.value = false;\n }\n };\n const handleClick = event => {\n // https://github.com/ant-design/ant-design/issues/30207\n if (innerLoading.value || mergedDisabled.value) {\n event.preventDefault();\n return;\n }\n emit('click', event);\n };\n const handleMousedown = event => {\n emit('mousedown', event);\n };\n const insertSpace = (child, needInserted) => {\n const SPACE = needInserted ? ' ' : '';\n if (child.type === Text) {\n let text = child.children.trim();\n if (isTwoCNChar(text)) {\n text = text.split('').join(SPACE);\n }\n return _createVNode(\"span\", null, [text]);\n }\n return child;\n };\n watchEffect(() => {\n devWarning(!(props.ghost && isUnBorderedButtonType(props.type)), 'Button', \"`link` or `text` button can't be a `ghost` button.\");\n });\n onMounted(fixTwoCNChar);\n onUpdated(fixTwoCNChar);\n onBeforeUnmount(() => {\n delayTimeoutRef.value && clearTimeout(delayTimeoutRef.value);\n });\n const focus = () => {\n var _a;\n (_a = buttonNodeRef.value) === null || _a === void 0 ? void 0 : _a.focus();\n };\n const blur = () => {\n var _a;\n (_a = buttonNodeRef.value) === null || _a === void 0 ? void 0 : _a.blur();\n };\n expose({\n focus,\n blur\n });\n return () => {\n var _a, _b;\n const {\n icon = (_a = slots.icon) === null || _a === void 0 ? void 0 : _a.call(slots)\n } = props;\n const children = flattenChildren((_b = slots.default) === null || _b === void 0 ? void 0 : _b.call(slots));\n isNeedInserted = children.length === 1 && !icon && !isUnBorderedButtonType(props.type);\n const {\n type,\n htmlType,\n href,\n title,\n target\n } = props;\n const iconType = innerLoading.value ? 'loading' : icon;\n const buttonProps = _extends(_extends({}, attrs), {\n title,\n disabled: mergedDisabled.value,\n class: [classes.value, attrs.class, {\n [`${prefixCls.value}-icon-only`]: children.length === 0 && !!iconType\n }],\n onClick: handleClick,\n onMousedown: handleMousedown\n });\n // https://github.com/vueComponent/ant-design-vue/issues/4930\n if (!mergedDisabled.value) {\n delete buttonProps.disabled;\n }\n const iconNode = icon && !innerLoading.value ? icon : _createVNode(LoadingIcon, {\n \"existIcon\": !!icon,\n \"prefixCls\": prefixCls.value,\n \"loading\": !!innerLoading.value\n }, null);\n const kids = children.map(child => insertSpace(child, isNeedInserted && autoInsertSpace.value));\n if (href !== undefined) {\n return wrapSSR(_createVNode(\"a\", _objectSpread(_objectSpread({}, buttonProps), {}, {\n \"href\": href,\n \"target\": target,\n \"ref\": buttonNodeRef\n }), [iconNode, kids]));\n }\n let buttonNode = _createVNode(\"button\", _objectSpread(_objectSpread({}, buttonProps), {}, {\n \"ref\": buttonNodeRef,\n \"type\": htmlType\n }), [iconNode, kids]);\n if (!isUnBorderedButtonType(type)) {\n const _buttonNode = function () {\n return buttonNode;\n }();\n buttonNode = _createVNode(Wave, {\n \"ref\": \"wave\",\n \"disabled\": !!innerLoading.value\n }, {\n default: () => [_buttonNode]\n });\n }\n return wrapSSR(buttonNode);\n };\n }\n});","import Button from './button';\nimport ButtonGroup from './button-group';\nButton.Group = ButtonGroup;\n/* istanbul ignore next */\nButton.install = function (app) {\n app.component(Button.name, Button);\n app.component(ButtonGroup.name, ButtonGroup);\n return app;\n};\nexport { ButtonGroup };\nexport default Button;","import { toRaw, watchEffect, unref, watch, ref } from 'vue';\nexport default function useMergedState(defaultStateValue, option) {\n const {\n defaultValue,\n value = ref()\n } = option || {};\n let initValue = typeof defaultStateValue === 'function' ? defaultStateValue() : defaultStateValue;\n if (value.value !== undefined) {\n initValue = unref(value);\n }\n if (defaultValue !== undefined) {\n initValue = typeof defaultValue === 'function' ? defaultValue() : defaultValue;\n }\n const innerValue = ref(initValue);\n const mergedValue = ref(initValue);\n watchEffect(() => {\n let val = value.value !== undefined ? value.value : innerValue.value;\n if (option.postState) {\n val = option.postState(val);\n }\n mergedValue.value = val;\n });\n function triggerChange(newValue) {\n const preVal = mergedValue.value;\n innerValue.value = newValue;\n if (toRaw(mergedValue.value) !== newValue && option.onChange) {\n option.onChange(newValue, preVal);\n }\n }\n // Effect of reset value to `undefined`\n watch(value, () => {\n innerValue.value = value.value;\n });\n return [mergedValue, triggerChange];\n}","/**\n * @ignore\n * some key-codes definition and utils from closure-library\n * @author yiminghe@gmail.com\n */\nconst KeyCode = {\n /**\n * MAC_ENTER\n */\n MAC_ENTER: 3,\n /**\n * BACKSPACE\n */\n BACKSPACE: 8,\n /**\n * TAB\n */\n TAB: 9,\n /**\n * NUMLOCK on FF/Safari Mac\n */\n NUM_CENTER: 12,\n /**\n * ENTER\n */\n ENTER: 13,\n /**\n * SHIFT\n */\n SHIFT: 16,\n /**\n * CTRL\n */\n CTRL: 17,\n /**\n * ALT\n */\n ALT: 18,\n /**\n * PAUSE\n */\n PAUSE: 19,\n /**\n * CAPS_LOCK\n */\n CAPS_LOCK: 20,\n /**\n * ESC\n */\n ESC: 27,\n /**\n * SPACE\n */\n SPACE: 32,\n /**\n * PAGE_UP\n */\n PAGE_UP: 33,\n /**\n * PAGE_DOWN\n */\n PAGE_DOWN: 34,\n /**\n * END\n */\n END: 35,\n /**\n * HOME\n */\n HOME: 36,\n /**\n * LEFT\n */\n LEFT: 37,\n /**\n * UP\n */\n UP: 38,\n /**\n * RIGHT\n */\n RIGHT: 39,\n /**\n * DOWN\n */\n DOWN: 40,\n /**\n * PRINT_SCREEN\n */\n PRINT_SCREEN: 44,\n /**\n * INSERT\n */\n INSERT: 45,\n /**\n * DELETE\n */\n DELETE: 46,\n /**\n * ZERO\n */\n ZERO: 48,\n /**\n * ONE\n */\n ONE: 49,\n /**\n * TWO\n */\n TWO: 50,\n /**\n * THREE\n */\n THREE: 51,\n /**\n * FOUR\n */\n FOUR: 52,\n /**\n * FIVE\n */\n FIVE: 53,\n /**\n * SIX\n */\n SIX: 54,\n /**\n * SEVEN\n */\n SEVEN: 55,\n /**\n * EIGHT\n */\n EIGHT: 56,\n /**\n * NINE\n */\n NINE: 57,\n /**\n * QUESTION_MARK\n */\n QUESTION_MARK: 63,\n /**\n * A\n */\n A: 65,\n /**\n * B\n */\n B: 66,\n /**\n * C\n */\n C: 67,\n /**\n * D\n */\n D: 68,\n /**\n * E\n */\n E: 69,\n /**\n * F\n */\n F: 70,\n /**\n * G\n */\n G: 71,\n /**\n * H\n */\n H: 72,\n /**\n * I\n */\n I: 73,\n /**\n * J\n */\n J: 74,\n /**\n * K\n */\n K: 75,\n /**\n * L\n */\n L: 76,\n /**\n * M\n */\n M: 77,\n /**\n * N\n */\n N: 78,\n /**\n * O\n */\n O: 79,\n /**\n * P\n */\n P: 80,\n /**\n * Q\n */\n Q: 81,\n /**\n * R\n */\n R: 82,\n /**\n * S\n */\n S: 83,\n /**\n * T\n */\n T: 84,\n /**\n * U\n */\n U: 85,\n /**\n * V\n */\n V: 86,\n /**\n * W\n */\n W: 87,\n /**\n * X\n */\n X: 88,\n /**\n * Y\n */\n Y: 89,\n /**\n * Z\n */\n Z: 90,\n /**\n * META\n */\n META: 91,\n /**\n * WIN_KEY_RIGHT\n */\n WIN_KEY_RIGHT: 92,\n /**\n * CONTEXT_MENU\n */\n CONTEXT_MENU: 93,\n /**\n * NUM_ZERO\n */\n NUM_ZERO: 96,\n /**\n * NUM_ONE\n */\n NUM_ONE: 97,\n /**\n * NUM_TWO\n */\n NUM_TWO: 98,\n /**\n * NUM_THREE\n */\n NUM_THREE: 99,\n /**\n * NUM_FOUR\n */\n NUM_FOUR: 100,\n /**\n * NUM_FIVE\n */\n NUM_FIVE: 101,\n /**\n * NUM_SIX\n */\n NUM_SIX: 102,\n /**\n * NUM_SEVEN\n */\n NUM_SEVEN: 103,\n /**\n * NUM_EIGHT\n */\n NUM_EIGHT: 104,\n /**\n * NUM_NINE\n */\n NUM_NINE: 105,\n /**\n * NUM_MULTIPLY\n */\n NUM_MULTIPLY: 106,\n /**\n * NUM_PLUS\n */\n NUM_PLUS: 107,\n /**\n * NUM_MINUS\n */\n NUM_MINUS: 109,\n /**\n * NUM_PERIOD\n */\n NUM_PERIOD: 110,\n /**\n * NUM_DIVISION\n */\n NUM_DIVISION: 111,\n /**\n * F1\n */\n F1: 112,\n /**\n * F2\n */\n F2: 113,\n /**\n * F3\n */\n F3: 114,\n /**\n * F4\n */\n F4: 115,\n /**\n * F5\n */\n F5: 116,\n /**\n * F6\n */\n F6: 117,\n /**\n * F7\n */\n F7: 118,\n /**\n * F8\n */\n F8: 119,\n /**\n * F9\n */\n F9: 120,\n /**\n * F10\n */\n F10: 121,\n /**\n * F11\n */\n F11: 122,\n /**\n * F12\n */\n F12: 123,\n /**\n * NUMLOCK\n */\n NUMLOCK: 144,\n /**\n * SEMICOLON\n */\n SEMICOLON: 186,\n /**\n * DASH\n */\n DASH: 189,\n /**\n * EQUALS\n */\n EQUALS: 187,\n /**\n * COMMA\n */\n COMMA: 188,\n /**\n * PERIOD\n */\n PERIOD: 190,\n /**\n * SLASH\n */\n SLASH: 191,\n /**\n * APOSTROPHE\n */\n APOSTROPHE: 192,\n /**\n * SINGLE_QUOTE\n */\n SINGLE_QUOTE: 222,\n /**\n * OPEN_SQUARE_BRACKET\n */\n OPEN_SQUARE_BRACKET: 219,\n /**\n * BACKSLASH\n */\n BACKSLASH: 220,\n /**\n * CLOSE_SQUARE_BRACKET\n */\n CLOSE_SQUARE_BRACKET: 221,\n /**\n * WIN_KEY\n */\n WIN_KEY: 224,\n /**\n * MAC_FF_META\n */\n MAC_FF_META: 224,\n /**\n * WIN_IME\n */\n WIN_IME: 229,\n // ======================== Function ========================\n /**\n * whether text and modified key is entered at the same time.\n */\n isTextModifyingKeyEvent: function isTextModifyingKeyEvent(e) {\n const {\n keyCode\n } = e;\n if (e.altKey && !e.ctrlKey || e.metaKey ||\n // Function keys don't generate text\n keyCode >= KeyCode.F1 && keyCode <= KeyCode.F12) {\n return false;\n }\n // The following keys are quite harmless, even in combination with\n // CTRL, ALT or SHIFT.\n switch (keyCode) {\n case KeyCode.ALT:\n case KeyCode.CAPS_LOCK:\n case KeyCode.CONTEXT_MENU:\n case KeyCode.CTRL:\n case KeyCode.DOWN:\n case KeyCode.END:\n case KeyCode.ESC:\n case KeyCode.HOME:\n case KeyCode.INSERT:\n case KeyCode.LEFT:\n case KeyCode.MAC_FF_META:\n case KeyCode.META:\n case KeyCode.NUMLOCK:\n case KeyCode.NUM_CENTER:\n case KeyCode.PAGE_DOWN:\n case KeyCode.PAGE_UP:\n case KeyCode.PAUSE:\n case KeyCode.PRINT_SCREEN:\n case KeyCode.RIGHT:\n case KeyCode.SHIFT:\n case KeyCode.UP:\n case KeyCode.WIN_KEY:\n case KeyCode.WIN_KEY_RIGHT:\n return false;\n default:\n return true;\n }\n },\n /**\n * whether character is entered.\n */\n isCharacterKey: function isCharacterKey(keyCode) {\n if (keyCode >= KeyCode.ZERO && keyCode <= KeyCode.NINE) {\n return true;\n }\n if (keyCode >= KeyCode.NUM_ZERO && keyCode <= KeyCode.NUM_MULTIPLY) {\n return true;\n }\n if (keyCode >= KeyCode.A && keyCode <= KeyCode.Z) {\n return true;\n }\n // Safari sends zero key code for non-latin characters.\n if (window.navigator.userAgent.indexOf('WebKit') !== -1 && keyCode === 0) {\n return true;\n }\n switch (keyCode) {\n case KeyCode.SPACE:\n case KeyCode.QUESTION_MARK:\n case KeyCode.NUM_PLUS:\n case KeyCode.NUM_MINUS:\n case KeyCode.NUM_PERIOD:\n case KeyCode.NUM_DIVISION:\n case KeyCode.SEMICOLON:\n case KeyCode.DASH:\n case KeyCode.EQUALS:\n case KeyCode.COMMA:\n case KeyCode.PERIOD:\n case KeyCode.SLASH:\n case KeyCode.APOSTROPHE:\n case KeyCode.SINGLE_QUOTE:\n case KeyCode.OPEN_SQUARE_BRACKET:\n case KeyCode.BACKSLASH:\n case KeyCode.CLOSE_SQUARE_BRACKET:\n return true;\n default:\n return false;\n }\n }\n};\nexport default KeyCode;","import { onBeforeUnmount, shallowRef } from 'vue';\nconst useDestroyed = () => {\n const destroyed = shallowRef(false);\n onBeforeUnmount(() => {\n destroyed.value = true;\n });\n return destroyed;\n};\nexport default useDestroyed;","import _objectSpread from \"@babel/runtime/helpers/esm/objectSpread2\";\nimport { createVNode as _createVNode, resolveDirective as _resolveDirective } from \"vue\";\nimport { shallowRef, onMounted, defineComponent, onBeforeUnmount } from 'vue';\nimport Button from '../button';\nimport { convertLegacyProps } from '../button/buttonTypes';\nimport useDestroyed from './hooks/useDestroyed';\nimport { objectType } from './type';\nimport { findDOMNode } from './props-util';\nconst actionButtonProps = {\n type: {\n type: String\n },\n actionFn: Function,\n close: Function,\n autofocus: Boolean,\n prefixCls: String,\n buttonProps: objectType(),\n emitEvent: Boolean,\n quitOnNullishReturnValue: Boolean\n};\nfunction isThenable(thing) {\n return !!(thing && thing.then);\n}\nexport default defineComponent({\n compatConfig: {\n MODE: 3\n },\n name: 'ActionButton',\n props: actionButtonProps,\n setup(props, _ref) {\n let {\n slots\n } = _ref;\n const clickedRef = shallowRef(false);\n const buttonRef = shallowRef();\n const loading = shallowRef(false);\n let timeoutId;\n const isDestroyed = useDestroyed();\n onMounted(() => {\n if (props.autofocus) {\n timeoutId = setTimeout(() => {\n var _a, _b;\n return (_b = (_a = findDOMNode(buttonRef.value)) === null || _a === void 0 ? void 0 : _a.focus) === null || _b === void 0 ? void 0 : _b.call(_a);\n });\n }\n });\n onBeforeUnmount(() => {\n clearTimeout(timeoutId);\n });\n const onInternalClose = function () {\n var _a;\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n (_a = props.close) === null || _a === void 0 ? void 0 : _a.call(props, ...args);\n };\n const handlePromiseOnOk = returnValueOfOnOk => {\n if (!isThenable(returnValueOfOnOk)) {\n return;\n }\n loading.value = true;\n returnValueOfOnOk.then(function () {\n if (!isDestroyed.value) {\n loading.value = false;\n }\n onInternalClose(...arguments);\n clickedRef.value = false;\n }, e => {\n // See: https://github.com/ant-design/ant-design/issues/6183\n if (!isDestroyed.value) {\n loading.value = false;\n }\n clickedRef.value = false;\n return Promise.reject(e);\n });\n };\n const onClick = e => {\n const {\n actionFn\n } = props;\n if (clickedRef.value) {\n return;\n }\n clickedRef.value = true;\n if (!actionFn) {\n onInternalClose();\n return;\n }\n let returnValueOfOnOk;\n if (props.emitEvent) {\n returnValueOfOnOk = actionFn(e);\n if (props.quitOnNullishReturnValue && !isThenable(returnValueOfOnOk)) {\n clickedRef.value = false;\n onInternalClose(e);\n return;\n }\n } else if (actionFn.length) {\n returnValueOfOnOk = actionFn(props.close);\n // https://github.com/ant-design/ant-design/issues/23358\n clickedRef.value = false;\n } else {\n returnValueOfOnOk = actionFn();\n if (!returnValueOfOnOk) {\n onInternalClose();\n return;\n }\n }\n handlePromiseOnOk(returnValueOfOnOk);\n };\n return () => {\n const {\n type,\n prefixCls,\n buttonProps\n } = props;\n return _createVNode(Button, _objectSpread(_objectSpread(_objectSpread({}, convertLegacyProps(type)), {}, {\n \"onClick\": onClick,\n \"loading\": loading.value,\n \"prefixCls\": prefixCls\n }, buttonProps), {}, {\n \"ref\": buttonRef\n }), slots);\n };\n }\n});","import { genComponentStyleHook } from '../../theme/internal';\n// =============================== Base ===============================\nconst genBaseStyle = token => {\n const {\n componentCls,\n iconCls,\n zIndexPopup,\n colorText,\n colorWarning,\n marginXS,\n fontSize,\n fontWeightStrong,\n lineHeight\n } = token;\n return {\n [componentCls]: {\n zIndex: zIndexPopup,\n [`${componentCls}-inner-content`]: {\n color: colorText\n },\n [`${componentCls}-message`]: {\n position: 'relative',\n marginBottom: marginXS,\n color: colorText,\n fontSize,\n display: 'flex',\n flexWrap: 'nowrap',\n alignItems: 'start',\n [`> ${componentCls}-message-icon ${iconCls}`]: {\n color: colorWarning,\n fontSize,\n flex: 'none',\n lineHeight: 1,\n paddingTop: (Math.round(fontSize * lineHeight) - fontSize) / 2\n },\n '&-title': {\n flex: 'auto',\n marginInlineStart: marginXS\n },\n '&-title-only': {\n fontWeight: fontWeightStrong\n }\n },\n [`${componentCls}-description`]: {\n position: 'relative',\n marginInlineStart: fontSize + marginXS,\n marginBottom: marginXS,\n color: colorText,\n fontSize\n },\n [`${componentCls}-buttons`]: {\n textAlign: 'end',\n button: {\n marginInlineStart: marginXS\n }\n }\n }\n };\n};\n// ============================== Export ==============================\nexport default genComponentStyleHook('Popconfirm', token => genBaseStyle(token), token => {\n const {\n zIndexPopupBase\n } = token;\n return {\n zIndexPopup: zIndexPopupBase + 60\n };\n});","import _objectSpread from \"@babel/runtime/helpers/esm/objectSpread2\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport { resolveDirective as _resolveDirective, createVNode as _createVNode } from \"vue\";\nvar __rest = this && this.__rest || function (s, e) {\n var t = {};\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];\n }\n return t;\n};\nimport { computed, ref, toRef, defineComponent } from 'vue';\nimport Popover from '../popover';\nimport abstractTooltipProps from '../tooltip/abstractTooltipProps';\nimport { initDefaultProps } from '../_util/props-util';\nimport { convertLegacyProps } from '../button/buttonTypes';\nimport ExclamationCircleFilled from \"@ant-design/icons-vue/es/icons/ExclamationCircleFilled\";\nimport Button from '../button';\nimport { useLocaleReceiver } from '../locale-provider/LocaleReceiver';\nimport defaultLocale from '../locale/en_US';\nimport { anyType, objectType, stringType, withInstall } from '../_util/type';\nimport useMergedState from '../_util/hooks/useMergedState';\nimport KeyCode from '../_util/KeyCode';\nimport useConfigInject from '../config-provider/hooks/useConfigInject';\nimport classNames from '../_util/classNames';\nimport { getTransitionName } from '../_util/transition';\nimport { cloneVNodes } from '../_util/vnode';\nimport omit from '../_util/omit';\nimport { tooltipDefaultProps } from '../tooltip/Tooltip';\nimport ActionButton from '../_util/ActionButton';\nimport usePopconfirmStyle from './style';\nimport warning from '../_util/warning';\nexport const popconfirmProps = () => _extends(_extends({}, abstractTooltipProps()), {\n prefixCls: String,\n content: anyType(),\n title: anyType(),\n description: anyType(),\n okType: stringType('primary'),\n disabled: {\n type: Boolean,\n default: false\n },\n okText: anyType(),\n cancelText: anyType(),\n icon: anyType(),\n okButtonProps: objectType(),\n cancelButtonProps: objectType(),\n showCancel: {\n type: Boolean,\n default: true\n },\n onConfirm: Function,\n onCancel: Function\n});\nconst Popconfirm = defineComponent({\n compatConfig: {\n MODE: 3\n },\n name: 'APopconfirm',\n inheritAttrs: false,\n props: initDefaultProps(popconfirmProps(), _extends(_extends({}, tooltipDefaultProps()), {\n trigger: 'click',\n placement: 'top',\n mouseEnterDelay: 0.1,\n mouseLeaveDelay: 0.1,\n arrowPointAtCenter: false,\n autoAdjustOverflow: true,\n okType: 'primary',\n disabled: false\n })),\n slots: Object,\n // emits: ['update:open', 'visibleChange'],\n setup(props, _ref) {\n let {\n slots,\n emit,\n expose,\n attrs\n } = _ref;\n const rootRef = ref();\n warning(props.visible === undefined, 'Popconfirm', `\\`visible\\` will be removed in next major version, please use \\`open\\` instead.`);\n expose({\n getPopupDomNode: () => {\n var _a, _b;\n return (_b = (_a = rootRef.value) === null || _a === void 0 ? void 0 : _a.getPopupDomNode) === null || _b === void 0 ? void 0 : _b.call(_a);\n }\n });\n const [open, setOpen] = useMergedState(false, {\n value: toRef(props, 'open')\n });\n const settingOpen = (value, e) => {\n if (props.open === undefined) {\n setOpen(value);\n }\n emit('update:open', value);\n emit('openChange', value, e);\n };\n const close = e => {\n settingOpen(false, e);\n };\n const onConfirm = e => {\n var _a;\n return (_a = props.onConfirm) === null || _a === void 0 ? void 0 : _a.call(props, e);\n };\n const onCancel = e => {\n var _a;\n settingOpen(false, e);\n (_a = props.onCancel) === null || _a === void 0 ? void 0 : _a.call(props, e);\n };\n const onKeyDown = e => {\n if (e.keyCode === KeyCode.ESC && open) {\n settingOpen(false, e);\n }\n };\n const onOpenChange = value => {\n const {\n disabled\n } = props;\n if (disabled) {\n return;\n }\n settingOpen(value);\n };\n const {\n prefixCls: prefixClsConfirm,\n getPrefixCls\n } = useConfigInject('popconfirm', props);\n const rootPrefixCls = computed(() => getPrefixCls());\n const btnPrefixCls = computed(() => getPrefixCls('btn'));\n const [wrapSSR] = usePopconfirmStyle(prefixClsConfirm);\n const [popconfirmLocale] = useLocaleReceiver('Popconfirm', defaultLocale.Popconfirm);\n const renderOverlay = () => {\n var _a, _b, _c, _d, _e;\n const {\n okButtonProps,\n cancelButtonProps,\n title = (_a = slots.title) === null || _a === void 0 ? void 0 : _a.call(slots),\n description = (_b = slots.description) === null || _b === void 0 ? void 0 : _b.call(slots),\n cancelText = (_c = slots.cancel) === null || _c === void 0 ? void 0 : _c.call(slots),\n okText = (_d = slots.okText) === null || _d === void 0 ? void 0 : _d.call(slots),\n okType,\n icon = ((_e = slots.icon) === null || _e === void 0 ? void 0 : _e.call(slots)) || _createVNode(ExclamationCircleFilled, null, null),\n showCancel = true\n } = props;\n const {\n cancelButton,\n okButton\n } = slots;\n const cancelProps = _extends({\n onClick: onCancel,\n size: 'small'\n }, cancelButtonProps);\n const okProps = _extends(_extends(_extends({\n onClick: onConfirm\n }, convertLegacyProps(okType)), {\n size: 'small'\n }), okButtonProps);\n return _createVNode(\"div\", {\n \"class\": `${prefixClsConfirm.value}-inner-content`\n }, [_createVNode(\"div\", {\n \"class\": `${prefixClsConfirm.value}-message`\n }, [icon && _createVNode(\"span\", {\n \"class\": `${prefixClsConfirm.value}-message-icon`\n }, [icon]), _createVNode(\"div\", {\n \"class\": [`${prefixClsConfirm.value}-message-title`, {\n [`${prefixClsConfirm.value}-message-title-only`]: !!description\n }]\n }, [title])]), description && _createVNode(\"div\", {\n \"class\": `${prefixClsConfirm.value}-description`\n }, [description]), _createVNode(\"div\", {\n \"class\": `${prefixClsConfirm.value}-buttons`\n }, [showCancel ? cancelButton ? cancelButton(cancelProps) : _createVNode(Button, cancelProps, {\n default: () => [cancelText || popconfirmLocale.value.cancelText]\n }) : null, okButton ? okButton(okProps) : _createVNode(ActionButton, {\n \"buttonProps\": _extends(_extends({\n size: 'small'\n }, convertLegacyProps(okType)), okButtonProps),\n \"actionFn\": onConfirm,\n \"close\": close,\n \"prefixCls\": btnPrefixCls.value,\n \"quitOnNullishReturnValue\": true,\n \"emitEvent\": true\n }, {\n default: () => [okText || popconfirmLocale.value.okText]\n })])]);\n };\n return () => {\n var _a;\n const {\n placement,\n overlayClassName,\n trigger = 'click'\n } = props,\n restProps = __rest(props, [\"placement\", \"overlayClassName\", \"trigger\"]);\n const otherProps = omit(restProps, ['title', 'content', 'cancelText', 'okText', 'onUpdate:open', 'onConfirm', 'onCancel', 'prefixCls']);\n const overlayClassNames = classNames(prefixClsConfirm.value, overlayClassName);\n return wrapSSR(_createVNode(Popover, _objectSpread(_objectSpread(_objectSpread({}, otherProps), attrs), {}, {\n \"trigger\": trigger,\n \"placement\": placement,\n \"onOpenChange\": onOpenChange,\n \"open\": open.value,\n \"overlayClassName\": overlayClassNames,\n \"transitionName\": getTransitionName(rootPrefixCls.value, 'zoom-big', props.transitionName),\n \"ref\": rootRef,\n \"data-popover-inject\": true\n }), {\n default: () => [cloneVNodes(((_a = slots.default) === null || _a === void 0 ? void 0 : _a.call(slots)) || [], {\n onKeydown: e => {\n onKeyDown(e);\n }\n }, false)],\n content: renderOverlay\n }));\n };\n }\n});\nexport default withInstall(Popconfirm);","/*!\n * clipboard.js v2.0.11\n * https://clipboardjs.com/\n *\n * Licensed MIT © Zeno Rocha\n */\n(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"ClipboardJS\"] = factory();\n\telse\n\t\troot[\"ClipboardJS\"] = factory();\n})(this, function() {\nreturn /******/ (function() { // webpackBootstrap\n/******/ \tvar __webpack_modules__ = ({\n\n/***/ 686:\n/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n\n// EXPORTS\n__webpack_require__.d(__webpack_exports__, {\n \"default\": function() { return /* binding */ clipboard; }\n});\n\n// EXTERNAL MODULE: ./node_modules/tiny-emitter/index.js\nvar tiny_emitter = __webpack_require__(279);\nvar tiny_emitter_default = /*#__PURE__*/__webpack_require__.n(tiny_emitter);\n// EXTERNAL MODULE: ./node_modules/good-listener/src/listen.js\nvar listen = __webpack_require__(370);\nvar listen_default = /*#__PURE__*/__webpack_require__.n(listen);\n// EXTERNAL MODULE: ./node_modules/select/src/select.js\nvar src_select = __webpack_require__(817);\nvar select_default = /*#__PURE__*/__webpack_require__.n(src_select);\n;// CONCATENATED MODULE: ./src/common/command.js\n/**\n * Executes a given operation type.\n * @param {String} type\n * @return {Boolean}\n */\nfunction command(type) {\n try {\n return document.execCommand(type);\n } catch (err) {\n return false;\n }\n}\n;// CONCATENATED MODULE: ./src/actions/cut.js\n\n\n/**\n * Cut action wrapper.\n * @param {String|HTMLElement} target\n * @return {String}\n */\n\nvar ClipboardActionCut = function ClipboardActionCut(target) {\n var selectedText = select_default()(target);\n command('cut');\n return selectedText;\n};\n\n/* harmony default export */ var actions_cut = (ClipboardActionCut);\n;// CONCATENATED MODULE: ./src/common/create-fake-element.js\n/**\n * Creates a fake textarea element with a value.\n * @param {String} value\n * @return {HTMLElement}\n */\nfunction createFakeElement(value) {\n var isRTL = document.documentElement.getAttribute('dir') === 'rtl';\n var fakeElement = document.createElement('textarea'); // Prevent zooming on iOS\n\n fakeElement.style.fontSize = '12pt'; // Reset box model\n\n fakeElement.style.border = '0';\n fakeElement.style.padding = '0';\n fakeElement.style.margin = '0'; // Move element out of screen horizontally\n\n fakeElement.style.position = 'absolute';\n fakeElement.style[isRTL ? 'right' : 'left'] = '-9999px'; // Move element to the same position vertically\n\n var yPosition = window.pageYOffset || document.documentElement.scrollTop;\n fakeElement.style.top = \"\".concat(yPosition, \"px\");\n fakeElement.setAttribute('readonly', '');\n fakeElement.value = value;\n return fakeElement;\n}\n;// CONCATENATED MODULE: ./src/actions/copy.js\n\n\n\n/**\n * Create fake copy action wrapper using a fake element.\n * @param {String} target\n * @param {Object} options\n * @return {String}\n */\n\nvar fakeCopyAction = function fakeCopyAction(value, options) {\n var fakeElement = createFakeElement(value);\n options.container.appendChild(fakeElement);\n var selectedText = select_default()(fakeElement);\n command('copy');\n fakeElement.remove();\n return selectedText;\n};\n/**\n * Copy action wrapper.\n * @param {String|HTMLElement} target\n * @param {Object} options\n * @return {String}\n */\n\n\nvar ClipboardActionCopy = function ClipboardActionCopy(target) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {\n container: document.body\n };\n var selectedText = '';\n\n if (typeof target === 'string') {\n selectedText = fakeCopyAction(target, options);\n } else if (target instanceof HTMLInputElement && !['text', 'search', 'url', 'tel', 'password'].includes(target === null || target === void 0 ? void 0 : target.type)) {\n // If input type doesn't support `setSelectionRange`. Simulate it. https://developer.mozilla.org/en-US/docs/Web/API/HTMLInputElement/setSelectionRange\n selectedText = fakeCopyAction(target.value, options);\n } else {\n selectedText = select_default()(target);\n command('copy');\n }\n\n return selectedText;\n};\n\n/* harmony default export */ var actions_copy = (ClipboardActionCopy);\n;// CONCATENATED MODULE: ./src/actions/default.js\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\n\n\n/**\n * Inner function which performs selection from either `text` or `target`\n * properties and then executes copy or cut operations.\n * @param {Object} options\n */\n\nvar ClipboardActionDefault = function ClipboardActionDefault() {\n var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n // Defines base properties passed from constructor.\n var _options$action = options.action,\n action = _options$action === void 0 ? 'copy' : _options$action,\n container = options.container,\n target = options.target,\n text = options.text; // Sets the `action` to be performed which can be either 'copy' or 'cut'.\n\n if (action !== 'copy' && action !== 'cut') {\n throw new Error('Invalid \"action\" value, use either \"copy\" or \"cut\"');\n } // Sets the `target` property using an element that will be have its content copied.\n\n\n if (target !== undefined) {\n if (target && _typeof(target) === 'object' && target.nodeType === 1) {\n if (action === 'copy' && target.hasAttribute('disabled')) {\n throw new Error('Invalid \"target\" attribute. Please use \"readonly\" instead of \"disabled\" attribute');\n }\n\n if (action === 'cut' && (target.hasAttribute('readonly') || target.hasAttribute('disabled'))) {\n throw new Error('Invalid \"target\" attribute. You can\\'t cut text from elements with \"readonly\" or \"disabled\" attributes');\n }\n } else {\n throw new Error('Invalid \"target\" value, use a valid Element');\n }\n } // Define selection strategy based on `text` property.\n\n\n if (text) {\n return actions_copy(text, {\n container: container\n });\n } // Defines which selection strategy based on `target` property.\n\n\n if (target) {\n return action === 'cut' ? actions_cut(target) : actions_copy(target, {\n container: container\n });\n }\n};\n\n/* harmony default export */ var actions_default = (ClipboardActionDefault);\n;// CONCATENATED MODULE: ./src/clipboard.js\nfunction clipboard_typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { clipboard_typeof = function _typeof(obj) { return typeof obj; }; } else { clipboard_typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return clipboard_typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\nfunction _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (clipboard_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _isNativeReflectConstruct() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\n\n\n\n\n\n/**\n * Helper function to retrieve attribute value.\n * @param {String} suffix\n * @param {Element} element\n */\n\nfunction getAttributeValue(suffix, element) {\n var attribute = \"data-clipboard-\".concat(suffix);\n\n if (!element.hasAttribute(attribute)) {\n return;\n }\n\n return element.getAttribute(attribute);\n}\n/**\n * Base class which takes one or more elements, adds event listeners to them,\n * and instantiates a new `ClipboardAction` on each click.\n */\n\n\nvar Clipboard = /*#__PURE__*/function (_Emitter) {\n _inherits(Clipboard, _Emitter);\n\n var _super = _createSuper(Clipboard);\n\n /**\n * @param {String|HTMLElement|HTMLCollection|NodeList} trigger\n * @param {Object} options\n */\n function Clipboard(trigger, options) {\n var _this;\n\n _classCallCheck(this, Clipboard);\n\n _this = _super.call(this);\n\n _this.resolveOptions(options);\n\n _this.listenClick(trigger);\n\n return _this;\n }\n /**\n * Defines if attributes would be resolved using internal setter functions\n * or custom functions that were passed in the constructor.\n * @param {Object} options\n */\n\n\n _createClass(Clipboard, [{\n key: \"resolveOptions\",\n value: function resolveOptions() {\n var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n this.action = typeof options.action === 'function' ? options.action : this.defaultAction;\n this.target = typeof options.target === 'function' ? options.target : this.defaultTarget;\n this.text = typeof options.text === 'function' ? options.text : this.defaultText;\n this.container = clipboard_typeof(options.container) === 'object' ? options.container : document.body;\n }\n /**\n * Adds a click event listener to the passed trigger.\n * @param {String|HTMLElement|HTMLCollection|NodeList} trigger\n */\n\n }, {\n key: \"listenClick\",\n value: function listenClick(trigger) {\n var _this2 = this;\n\n this.listener = listen_default()(trigger, 'click', function (e) {\n return _this2.onClick(e);\n });\n }\n /**\n * Defines a new `ClipboardAction` on each click event.\n * @param {Event} e\n */\n\n }, {\n key: \"onClick\",\n value: function onClick(e) {\n var trigger = e.delegateTarget || e.currentTarget;\n var action = this.action(trigger) || 'copy';\n var text = actions_default({\n action: action,\n container: this.container,\n target: this.target(trigger),\n text: this.text(trigger)\n }); // Fires an event based on the copy operation result.\n\n this.emit(text ? 'success' : 'error', {\n action: action,\n text: text,\n trigger: trigger,\n clearSelection: function clearSelection() {\n if (trigger) {\n trigger.focus();\n }\n\n window.getSelection().removeAllRanges();\n }\n });\n }\n /**\n * Default `action` lookup function.\n * @param {Element} trigger\n */\n\n }, {\n key: \"defaultAction\",\n value: function defaultAction(trigger) {\n return getAttributeValue('action', trigger);\n }\n /**\n * Default `target` lookup function.\n * @param {Element} trigger\n */\n\n }, {\n key: \"defaultTarget\",\n value: function defaultTarget(trigger) {\n var selector = getAttributeValue('target', trigger);\n\n if (selector) {\n return document.querySelector(selector);\n }\n }\n /**\n * Allow fire programmatically a copy action\n * @param {String|HTMLElement} target\n * @param {Object} options\n * @returns Text copied.\n */\n\n }, {\n key: \"defaultText\",\n\n /**\n * Default `text` lookup function.\n * @param {Element} trigger\n */\n value: function defaultText(trigger) {\n return getAttributeValue('text', trigger);\n }\n /**\n * Destroy lifecycle.\n */\n\n }, {\n key: \"destroy\",\n value: function destroy() {\n this.listener.destroy();\n }\n }], [{\n key: \"copy\",\n value: function copy(target) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {\n container: document.body\n };\n return actions_copy(target, options);\n }\n /**\n * Allow fire programmatically a cut action\n * @param {String|HTMLElement} target\n * @returns Text cutted.\n */\n\n }, {\n key: \"cut\",\n value: function cut(target) {\n return actions_cut(target);\n }\n /**\n * Returns the support of the given action, or all actions if no action is\n * given.\n * @param {String} [action]\n */\n\n }, {\n key: \"isSupported\",\n value: function isSupported() {\n var action = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : ['copy', 'cut'];\n var actions = typeof action === 'string' ? [action] : action;\n var support = !!document.queryCommandSupported;\n actions.forEach(function (action) {\n support = support && !!document.queryCommandSupported(action);\n });\n return support;\n }\n }]);\n\n return Clipboard;\n}((tiny_emitter_default()));\n\n/* harmony default export */ var clipboard = (Clipboard);\n\n/***/ }),\n\n/***/ 828:\n/***/ (function(module) {\n\nvar DOCUMENT_NODE_TYPE = 9;\n\n/**\n * A polyfill for Element.matches()\n */\nif (typeof Element !== 'undefined' && !Element.prototype.matches) {\n var proto = Element.prototype;\n\n proto.matches = proto.matchesSelector ||\n proto.mozMatchesSelector ||\n proto.msMatchesSelector ||\n proto.oMatchesSelector ||\n proto.webkitMatchesSelector;\n}\n\n/**\n * Finds the closest parent that matches a selector.\n *\n * @param {Element} element\n * @param {String} selector\n * @return {Function}\n */\nfunction closest (element, selector) {\n while (element && element.nodeType !== DOCUMENT_NODE_TYPE) {\n if (typeof element.matches === 'function' &&\n element.matches(selector)) {\n return element;\n }\n element = element.parentNode;\n }\n}\n\nmodule.exports = closest;\n\n\n/***/ }),\n\n/***/ 438:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\nvar closest = __webpack_require__(828);\n\n/**\n * Delegates event to a selector.\n *\n * @param {Element} element\n * @param {String} selector\n * @param {String} type\n * @param {Function} callback\n * @param {Boolean} useCapture\n * @return {Object}\n */\nfunction _delegate(element, selector, type, callback, useCapture) {\n var listenerFn = listener.apply(this, arguments);\n\n element.addEventListener(type, listenerFn, useCapture);\n\n return {\n destroy: function() {\n element.removeEventListener(type, listenerFn, useCapture);\n }\n }\n}\n\n/**\n * Delegates event to a selector.\n *\n * @param {Element|String|Array} [elements]\n * @param {String} selector\n * @param {String} type\n * @param {Function} callback\n * @param {Boolean} useCapture\n * @return {Object}\n */\nfunction delegate(elements, selector, type, callback, useCapture) {\n // Handle the regular Element usage\n if (typeof elements.addEventListener === 'function') {\n return _delegate.apply(null, arguments);\n }\n\n // Handle Element-less usage, it defaults to global delegation\n if (typeof type === 'function') {\n // Use `document` as the first parameter, then apply arguments\n // This is a short way to .unshift `arguments` without running into deoptimizations\n return _delegate.bind(null, document).apply(null, arguments);\n }\n\n // Handle Selector-based usage\n if (typeof elements === 'string') {\n elements = document.querySelectorAll(elements);\n }\n\n // Handle Array-like based usage\n return Array.prototype.map.call(elements, function (element) {\n return _delegate(element, selector, type, callback, useCapture);\n });\n}\n\n/**\n * Finds closest match and invokes callback.\n *\n * @param {Element} element\n * @param {String} selector\n * @param {String} type\n * @param {Function} callback\n * @return {Function}\n */\nfunction listener(element, selector, type, callback) {\n return function(e) {\n e.delegateTarget = closest(e.target, selector);\n\n if (e.delegateTarget) {\n callback.call(element, e);\n }\n }\n}\n\nmodule.exports = delegate;\n\n\n/***/ }),\n\n/***/ 879:\n/***/ (function(__unused_webpack_module, exports) {\n\n/**\n * Check if argument is a HTML element.\n *\n * @param {Object} value\n * @return {Boolean}\n */\nexports.node = function(value) {\n return value !== undefined\n && value instanceof HTMLElement\n && value.nodeType === 1;\n};\n\n/**\n * Check if argument is a list of HTML elements.\n *\n * @param {Object} value\n * @return {Boolean}\n */\nexports.nodeList = function(value) {\n var type = Object.prototype.toString.call(value);\n\n return value !== undefined\n && (type === '[object NodeList]' || type === '[object HTMLCollection]')\n && ('length' in value)\n && (value.length === 0 || exports.node(value[0]));\n};\n\n/**\n * Check if argument is a string.\n *\n * @param {Object} value\n * @return {Boolean}\n */\nexports.string = function(value) {\n return typeof value === 'string'\n || value instanceof String;\n};\n\n/**\n * Check if argument is a function.\n *\n * @param {Object} value\n * @return {Boolean}\n */\nexports.fn = function(value) {\n var type = Object.prototype.toString.call(value);\n\n return type === '[object Function]';\n};\n\n\n/***/ }),\n\n/***/ 370:\n/***/ (function(module, __unused_webpack_exports, __webpack_require__) {\n\nvar is = __webpack_require__(879);\nvar delegate = __webpack_require__(438);\n\n/**\n * Validates all params and calls the right\n * listener function based on its target type.\n *\n * @param {String|HTMLElement|HTMLCollection|NodeList} target\n * @param {String} type\n * @param {Function} callback\n * @return {Object}\n */\nfunction listen(target, type, callback) {\n if (!target && !type && !callback) {\n throw new Error('Missing required arguments');\n }\n\n if (!is.string(type)) {\n throw new TypeError('Second argument must be a String');\n }\n\n if (!is.fn(callback)) {\n throw new TypeError('Third argument must be a Function');\n }\n\n if (is.node(target)) {\n return listenNode(target, type, callback);\n }\n else if (is.nodeList(target)) {\n return listenNodeList(target, type, callback);\n }\n else if (is.string(target)) {\n return listenSelector(target, type, callback);\n }\n else {\n throw new TypeError('First argument must be a String, HTMLElement, HTMLCollection, or NodeList');\n }\n}\n\n/**\n * Adds an event listener to a HTML element\n * and returns a remove listener function.\n *\n * @param {HTMLElement} node\n * @param {String} type\n * @param {Function} callback\n * @return {Object}\n */\nfunction listenNode(node, type, callback) {\n node.addEventListener(type, callback);\n\n return {\n destroy: function() {\n node.removeEventListener(type, callback);\n }\n }\n}\n\n/**\n * Add an event listener to a list of HTML elements\n * and returns a remove listener function.\n *\n * @param {NodeList|HTMLCollection} nodeList\n * @param {String} type\n * @param {Function} callback\n * @return {Object}\n */\nfunction listenNodeList(nodeList, type, callback) {\n Array.prototype.forEach.call(nodeList, function(node) {\n node.addEventListener(type, callback);\n });\n\n return {\n destroy: function() {\n Array.prototype.forEach.call(nodeList, function(node) {\n node.removeEventListener(type, callback);\n });\n }\n }\n}\n\n/**\n * Add an event listener to a selector\n * and returns a remove listener function.\n *\n * @param {String} selector\n * @param {String} type\n * @param {Function} callback\n * @return {Object}\n */\nfunction listenSelector(selector, type, callback) {\n return delegate(document.body, selector, type, callback);\n}\n\nmodule.exports = listen;\n\n\n/***/ }),\n\n/***/ 817:\n/***/ (function(module) {\n\nfunction select(element) {\n var selectedText;\n\n if (element.nodeName === 'SELECT') {\n element.focus();\n\n selectedText = element.value;\n }\n else if (element.nodeName === 'INPUT' || element.nodeName === 'TEXTAREA') {\n var isReadOnly = element.hasAttribute('readonly');\n\n if (!isReadOnly) {\n element.setAttribute('readonly', '');\n }\n\n element.select();\n element.setSelectionRange(0, element.value.length);\n\n if (!isReadOnly) {\n element.removeAttribute('readonly');\n }\n\n selectedText = element.value;\n }\n else {\n if (element.hasAttribute('contenteditable')) {\n element.focus();\n }\n\n var selection = window.getSelection();\n var range = document.createRange();\n\n range.selectNodeContents(element);\n selection.removeAllRanges();\n selection.addRange(range);\n\n selectedText = selection.toString();\n }\n\n return selectedText;\n}\n\nmodule.exports = select;\n\n\n/***/ }),\n\n/***/ 279:\n/***/ (function(module) {\n\nfunction E () {\n // Keep this empty so it's easier to inherit from\n // (via https://github.com/lipsmack from https://github.com/scottcorgan/tiny-emitter/issues/3)\n}\n\nE.prototype = {\n on: function (name, callback, ctx) {\n var e = this.e || (this.e = {});\n\n (e[name] || (e[name] = [])).push({\n fn: callback,\n ctx: ctx\n });\n\n return this;\n },\n\n once: function (name, callback, ctx) {\n var self = this;\n function listener () {\n self.off(name, listener);\n callback.apply(ctx, arguments);\n };\n\n listener._ = callback\n return this.on(name, listener, ctx);\n },\n\n emit: function (name) {\n var data = [].slice.call(arguments, 1);\n var evtArr = ((this.e || (this.e = {}))[name] || []).slice();\n var i = 0;\n var len = evtArr.length;\n\n for (i; i < len; i++) {\n evtArr[i].fn.apply(evtArr[i].ctx, data);\n }\n\n return this;\n },\n\n off: function (name, callback) {\n var e = this.e || (this.e = {});\n var evts = e[name];\n var liveEvents = [];\n\n if (evts && callback) {\n for (var i = 0, len = evts.length; i < len; i++) {\n if (evts[i].fn !== callback && evts[i].fn._ !== callback)\n liveEvents.push(evts[i]);\n }\n }\n\n // Remove event from queue to prevent memory leak\n // Suggested by https://github.com/lazd\n // Ref: https://github.com/scottcorgan/tiny-emitter/commit/c6ebfaa9bc973b33d110a84a307742b7cf94c953#commitcomment-5024910\n\n (liveEvents.length)\n ? e[name] = liveEvents\n : delete e[name];\n\n return this;\n }\n};\n\nmodule.exports = E;\nmodule.exports.TinyEmitter = E;\n\n\n/***/ })\n\n/******/ \t});\n/************************************************************************/\n/******/ \t// The module cache\n/******/ \tvar __webpack_module_cache__ = {};\n/******/ \t\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(__webpack_module_cache__[moduleId]) {\n/******/ \t\t\treturn __webpack_module_cache__[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = __webpack_module_cache__[moduleId] = {\n/******/ \t\t\t// no module.id needed\n/******/ \t\t\t// no module.loaded needed\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/ \t\n/******/ \t\t// Execute the module function\n/******/ \t\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n/******/ \t\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/ \t\n/************************************************************************/\n/******/ \t/* webpack/runtime/compat get default export */\n/******/ \t!function() {\n/******/ \t\t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t\t__webpack_require__.n = function(module) {\n/******/ \t\t\tvar getter = module && module.__esModule ?\n/******/ \t\t\t\tfunction() { return module['default']; } :\n/******/ \t\t\t\tfunction() { return module; };\n/******/ \t\t\t__webpack_require__.d(getter, { a: getter });\n/******/ \t\t\treturn getter;\n/******/ \t\t};\n/******/ \t}();\n/******/ \t\n/******/ \t/* webpack/runtime/define property getters */\n/******/ \t!function() {\n/******/ \t\t// define getter functions for harmony exports\n/******/ \t\t__webpack_require__.d = function(exports, definition) {\n/******/ \t\t\tfor(var key in definition) {\n/******/ \t\t\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n/******/ \t\t\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n/******/ \t\t\t\t}\n/******/ \t\t\t}\n/******/ \t\t};\n/******/ \t}();\n/******/ \t\n/******/ \t/* webpack/runtime/hasOwnProperty shorthand */\n/******/ \t!function() {\n/******/ \t\t__webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); }\n/******/ \t}();\n/******/ \t\n/************************************************************************/\n/******/ \t// module exports must be returned from runtime so entry inlining is disabled\n/******/ \t// startup\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(686);\n/******/ })()\n.default;\n});",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./enc-base64\"), require(\"./md5\"), require(\"./evpkdf\"), require(\"./cipher-core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./enc-base64\", \"./md5\", \"./evpkdf\", \"./cipher-core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function () {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var BlockCipher = C_lib.BlockCipher;\n\t var C_algo = C.algo;\n\n\t // Lookup tables\n\t var SBOX = [];\n\t var INV_SBOX = [];\n\t var SUB_MIX_0 = [];\n\t var SUB_MIX_1 = [];\n\t var SUB_MIX_2 = [];\n\t var SUB_MIX_3 = [];\n\t var INV_SUB_MIX_0 = [];\n\t var INV_SUB_MIX_1 = [];\n\t var INV_SUB_MIX_2 = [];\n\t var INV_SUB_MIX_3 = [];\n\n\t // Compute lookup tables\n\t (function () {\n\t // Compute double table\n\t var d = [];\n\t for (var i = 0; i < 256; i++) {\n\t if (i < 128) {\n\t d[i] = i << 1;\n\t } else {\n\t d[i] = (i << 1) ^ 0x11b;\n\t }\n\t }\n\n\t // Walk GF(2^8)\n\t var x = 0;\n\t var xi = 0;\n\t for (var i = 0; i < 256; i++) {\n\t // Compute sbox\n\t var sx = xi ^ (xi << 1) ^ (xi << 2) ^ (xi << 3) ^ (xi << 4);\n\t sx = (sx >>> 8) ^ (sx & 0xff) ^ 0x63;\n\t SBOX[x] = sx;\n\t INV_SBOX[sx] = x;\n\n\t // Compute multiplication\n\t var x2 = d[x];\n\t var x4 = d[x2];\n\t var x8 = d[x4];\n\n\t // Compute sub bytes, mix columns tables\n\t var t = (d[sx] * 0x101) ^ (sx * 0x1010100);\n\t SUB_MIX_0[x] = (t << 24) | (t >>> 8);\n\t SUB_MIX_1[x] = (t << 16) | (t >>> 16);\n\t SUB_MIX_2[x] = (t << 8) | (t >>> 24);\n\t SUB_MIX_3[x] = t;\n\n\t // Compute inv sub bytes, inv mix columns tables\n\t var t = (x8 * 0x1010101) ^ (x4 * 0x10001) ^ (x2 * 0x101) ^ (x * 0x1010100);\n\t INV_SUB_MIX_0[sx] = (t << 24) | (t >>> 8);\n\t INV_SUB_MIX_1[sx] = (t << 16) | (t >>> 16);\n\t INV_SUB_MIX_2[sx] = (t << 8) | (t >>> 24);\n\t INV_SUB_MIX_3[sx] = t;\n\n\t // Compute next counter\n\t if (!x) {\n\t x = xi = 1;\n\t } else {\n\t x = x2 ^ d[d[d[x8 ^ x2]]];\n\t xi ^= d[d[xi]];\n\t }\n\t }\n\t }());\n\n\t // Precomputed Rcon lookup\n\t var RCON = [0x00, 0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80, 0x1b, 0x36];\n\n\t /**\n\t * AES block cipher algorithm.\n\t */\n\t var AES = C_algo.AES = BlockCipher.extend({\n\t _doReset: function () {\n\t var t;\n\n\t // Skip reset of nRounds has been set before and key did not change\n\t if (this._nRounds && this._keyPriorReset === this._key) {\n\t return;\n\t }\n\n\t // Shortcuts\n\t var key = this._keyPriorReset = this._key;\n\t var keyWords = key.words;\n\t var keySize = key.sigBytes / 4;\n\n\t // Compute number of rounds\n\t var nRounds = this._nRounds = keySize + 6;\n\n\t // Compute number of key schedule rows\n\t var ksRows = (nRounds + 1) * 4;\n\n\t // Compute key schedule\n\t var keySchedule = this._keySchedule = [];\n\t for (var ksRow = 0; ksRow < ksRows; ksRow++) {\n\t if (ksRow < keySize) {\n\t keySchedule[ksRow] = keyWords[ksRow];\n\t } else {\n\t t = keySchedule[ksRow - 1];\n\n\t if (!(ksRow % keySize)) {\n\t // Rot word\n\t t = (t << 8) | (t >>> 24);\n\n\t // Sub word\n\t t = (SBOX[t >>> 24] << 24) | (SBOX[(t >>> 16) & 0xff] << 16) | (SBOX[(t >>> 8) & 0xff] << 8) | SBOX[t & 0xff];\n\n\t // Mix Rcon\n\t t ^= RCON[(ksRow / keySize) | 0] << 24;\n\t } else if (keySize > 6 && ksRow % keySize == 4) {\n\t // Sub word\n\t t = (SBOX[t >>> 24] << 24) | (SBOX[(t >>> 16) & 0xff] << 16) | (SBOX[(t >>> 8) & 0xff] << 8) | SBOX[t & 0xff];\n\t }\n\n\t keySchedule[ksRow] = keySchedule[ksRow - keySize] ^ t;\n\t }\n\t }\n\n\t // Compute inv key schedule\n\t var invKeySchedule = this._invKeySchedule = [];\n\t for (var invKsRow = 0; invKsRow < ksRows; invKsRow++) {\n\t var ksRow = ksRows - invKsRow;\n\n\t if (invKsRow % 4) {\n\t var t = keySchedule[ksRow];\n\t } else {\n\t var t = keySchedule[ksRow - 4];\n\t }\n\n\t if (invKsRow < 4 || ksRow <= 4) {\n\t invKeySchedule[invKsRow] = t;\n\t } else {\n\t invKeySchedule[invKsRow] = INV_SUB_MIX_0[SBOX[t >>> 24]] ^ INV_SUB_MIX_1[SBOX[(t >>> 16) & 0xff]] ^\n\t INV_SUB_MIX_2[SBOX[(t >>> 8) & 0xff]] ^ INV_SUB_MIX_3[SBOX[t & 0xff]];\n\t }\n\t }\n\t },\n\n\t encryptBlock: function (M, offset) {\n\t this._doCryptBlock(M, offset, this._keySchedule, SUB_MIX_0, SUB_MIX_1, SUB_MIX_2, SUB_MIX_3, SBOX);\n\t },\n\n\t decryptBlock: function (M, offset) {\n\t // Swap 2nd and 4th rows\n\t var t = M[offset + 1];\n\t M[offset + 1] = M[offset + 3];\n\t M[offset + 3] = t;\n\n\t this._doCryptBlock(M, offset, this._invKeySchedule, INV_SUB_MIX_0, INV_SUB_MIX_1, INV_SUB_MIX_2, INV_SUB_MIX_3, INV_SBOX);\n\n\t // Inv swap 2nd and 4th rows\n\t var t = M[offset + 1];\n\t M[offset + 1] = M[offset + 3];\n\t M[offset + 3] = t;\n\t },\n\n\t _doCryptBlock: function (M, offset, keySchedule, SUB_MIX_0, SUB_MIX_1, SUB_MIX_2, SUB_MIX_3, SBOX) {\n\t // Shortcut\n\t var nRounds = this._nRounds;\n\n\t // Get input, add round key\n\t var s0 = M[offset] ^ keySchedule[0];\n\t var s1 = M[offset + 1] ^ keySchedule[1];\n\t var s2 = M[offset + 2] ^ keySchedule[2];\n\t var s3 = M[offset + 3] ^ keySchedule[3];\n\n\t // Key schedule row counter\n\t var ksRow = 4;\n\n\t // Rounds\n\t for (var round = 1; round < nRounds; round++) {\n\t // Shift rows, sub bytes, mix columns, add round key\n\t var t0 = SUB_MIX_0[s0 >>> 24] ^ SUB_MIX_1[(s1 >>> 16) & 0xff] ^ SUB_MIX_2[(s2 >>> 8) & 0xff] ^ SUB_MIX_3[s3 & 0xff] ^ keySchedule[ksRow++];\n\t var t1 = SUB_MIX_0[s1 >>> 24] ^ SUB_MIX_1[(s2 >>> 16) & 0xff] ^ SUB_MIX_2[(s3 >>> 8) & 0xff] ^ SUB_MIX_3[s0 & 0xff] ^ keySchedule[ksRow++];\n\t var t2 = SUB_MIX_0[s2 >>> 24] ^ SUB_MIX_1[(s3 >>> 16) & 0xff] ^ SUB_MIX_2[(s0 >>> 8) & 0xff] ^ SUB_MIX_3[s1 & 0xff] ^ keySchedule[ksRow++];\n\t var t3 = SUB_MIX_0[s3 >>> 24] ^ SUB_MIX_1[(s0 >>> 16) & 0xff] ^ SUB_MIX_2[(s1 >>> 8) & 0xff] ^ SUB_MIX_3[s2 & 0xff] ^ keySchedule[ksRow++];\n\n\t // Update state\n\t s0 = t0;\n\t s1 = t1;\n\t s2 = t2;\n\t s3 = t3;\n\t }\n\n\t // Shift rows, sub bytes, add round key\n\t var t0 = ((SBOX[s0 >>> 24] << 24) | (SBOX[(s1 >>> 16) & 0xff] << 16) | (SBOX[(s2 >>> 8) & 0xff] << 8) | SBOX[s3 & 0xff]) ^ keySchedule[ksRow++];\n\t var t1 = ((SBOX[s1 >>> 24] << 24) | (SBOX[(s2 >>> 16) & 0xff] << 16) | (SBOX[(s3 >>> 8) & 0xff] << 8) | SBOX[s0 & 0xff]) ^ keySchedule[ksRow++];\n\t var t2 = ((SBOX[s2 >>> 24] << 24) | (SBOX[(s3 >>> 16) & 0xff] << 16) | (SBOX[(s0 >>> 8) & 0xff] << 8) | SBOX[s1 & 0xff]) ^ keySchedule[ksRow++];\n\t var t3 = ((SBOX[s3 >>> 24] << 24) | (SBOX[(s0 >>> 16) & 0xff] << 16) | (SBOX[(s1 >>> 8) & 0xff] << 8) | SBOX[s2 & 0xff]) ^ keySchedule[ksRow++];\n\n\t // Set output\n\t M[offset] = t0;\n\t M[offset + 1] = t1;\n\t M[offset + 2] = t2;\n\t M[offset + 3] = t3;\n\t },\n\n\t keySize: 256/32\n\t });\n\n\t /**\n\t * Shortcut functions to the cipher's object interface.\n\t *\n\t * @example\n\t *\n\t * var ciphertext = CryptoJS.AES.encrypt(message, key, cfg);\n\t * var plaintext = CryptoJS.AES.decrypt(ciphertext, key, cfg);\n\t */\n\t C.AES = BlockCipher._createHelper(AES);\n\t}());\n\n\n\treturn CryptoJS.AES;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./enc-base64\"), require(\"./md5\"), require(\"./evpkdf\"), require(\"./cipher-core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./enc-base64\", \"./md5\", \"./evpkdf\", \"./cipher-core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function () {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var BlockCipher = C_lib.BlockCipher;\n\t var C_algo = C.algo;\n\n\t const N = 16;\n\n\t //Origin pbox and sbox, derived from PI\n\t const ORIG_P = [\n\t 0x243F6A88, 0x85A308D3, 0x13198A2E, 0x03707344,\n\t 0xA4093822, 0x299F31D0, 0x082EFA98, 0xEC4E6C89,\n\t 0x452821E6, 0x38D01377, 0xBE5466CF, 0x34E90C6C,\n\t 0xC0AC29B7, 0xC97C50DD, 0x3F84D5B5, 0xB5470917,\n\t 0x9216D5D9, 0x8979FB1B\n\t ];\n\n\t const ORIG_S = [\n\t [ 0xD1310BA6, 0x98DFB5AC, 0x2FFD72DB, 0xD01ADFB7,\n\t 0xB8E1AFED, 0x6A267E96, 0xBA7C9045, 0xF12C7F99,\n\t 0x24A19947, 0xB3916CF7, 0x0801F2E2, 0x858EFC16,\n\t 0x636920D8, 0x71574E69, 0xA458FEA3, 0xF4933D7E,\n\t 0x0D95748F, 0x728EB658, 0x718BCD58, 0x82154AEE,\n\t 0x7B54A41D, 0xC25A59B5, 0x9C30D539, 0x2AF26013,\n\t 0xC5D1B023, 0x286085F0, 0xCA417918, 0xB8DB38EF,\n\t 0x8E79DCB0, 0x603A180E, 0x6C9E0E8B, 0xB01E8A3E,\n\t 0xD71577C1, 0xBD314B27, 0x78AF2FDA, 0x55605C60,\n\t 0xE65525F3, 0xAA55AB94, 0x57489862, 0x63E81440,\n\t 0x55CA396A, 0x2AAB10B6, 0xB4CC5C34, 0x1141E8CE,\n\t 0xA15486AF, 0x7C72E993, 0xB3EE1411, 0x636FBC2A,\n\t 0x2BA9C55D, 0x741831F6, 0xCE5C3E16, 0x9B87931E,\n\t 0xAFD6BA33, 0x6C24CF5C, 0x7A325381, 0x28958677,\n\t 0x3B8F4898, 0x6B4BB9AF, 0xC4BFE81B, 0x66282193,\n\t 0x61D809CC, 0xFB21A991, 0x487CAC60, 0x5DEC8032,\n\t 0xEF845D5D, 0xE98575B1, 0xDC262302, 0xEB651B88,\n\t 0x23893E81, 0xD396ACC5, 0x0F6D6FF3, 0x83F44239,\n\t 0x2E0B4482, 0xA4842004, 0x69C8F04A, 0x9E1F9B5E,\n\t 0x21C66842, 0xF6E96C9A, 0x670C9C61, 0xABD388F0,\n\t 0x6A51A0D2, 0xD8542F68, 0x960FA728, 0xAB5133A3,\n\t 0x6EEF0B6C, 0x137A3BE4, 0xBA3BF050, 0x7EFB2A98,\n\t 0xA1F1651D, 0x39AF0176, 0x66CA593E, 0x82430E88,\n\t 0x8CEE8619, 0x456F9FB4, 0x7D84A5C3, 0x3B8B5EBE,\n\t 0xE06F75D8, 0x85C12073, 0x401A449F, 0x56C16AA6,\n\t 0x4ED3AA62, 0x363F7706, 0x1BFEDF72, 0x429B023D,\n\t 0x37D0D724, 0xD00A1248, 0xDB0FEAD3, 0x49F1C09B,\n\t 0x075372C9, 0x80991B7B, 0x25D479D8, 0xF6E8DEF7,\n\t 0xE3FE501A, 0xB6794C3B, 0x976CE0BD, 0x04C006BA,\n\t 0xC1A94FB6, 0x409F60C4, 0x5E5C9EC2, 0x196A2463,\n\t 0x68FB6FAF, 0x3E6C53B5, 0x1339B2EB, 0x3B52EC6F,\n\t 0x6DFC511F, 0x9B30952C, 0xCC814544, 0xAF5EBD09,\n\t 0xBEE3D004, 0xDE334AFD, 0x660F2807, 0x192E4BB3,\n\t 0xC0CBA857, 0x45C8740F, 0xD20B5F39, 0xB9D3FBDB,\n\t 0x5579C0BD, 0x1A60320A, 0xD6A100C6, 0x402C7279,\n\t 0x679F25FE, 0xFB1FA3CC, 0x8EA5E9F8, 0xDB3222F8,\n\t 0x3C7516DF, 0xFD616B15, 0x2F501EC8, 0xAD0552AB,\n\t 0x323DB5FA, 0xFD238760, 0x53317B48, 0x3E00DF82,\n\t 0x9E5C57BB, 0xCA6F8CA0, 0x1A87562E, 0xDF1769DB,\n\t 0xD542A8F6, 0x287EFFC3, 0xAC6732C6, 0x8C4F5573,\n\t 0x695B27B0, 0xBBCA58C8, 0xE1FFA35D, 0xB8F011A0,\n\t 0x10FA3D98, 0xFD2183B8, 0x4AFCB56C, 0x2DD1D35B,\n\t 0x9A53E479, 0xB6F84565, 0xD28E49BC, 0x4BFB9790,\n\t 0xE1DDF2DA, 0xA4CB7E33, 0x62FB1341, 0xCEE4C6E8,\n\t 0xEF20CADA, 0x36774C01, 0xD07E9EFE, 0x2BF11FB4,\n\t 0x95DBDA4D, 0xAE909198, 0xEAAD8E71, 0x6B93D5A0,\n\t 0xD08ED1D0, 0xAFC725E0, 0x8E3C5B2F, 0x8E7594B7,\n\t 0x8FF6E2FB, 0xF2122B64, 0x8888B812, 0x900DF01C,\n\t 0x4FAD5EA0, 0x688FC31C, 0xD1CFF191, 0xB3A8C1AD,\n\t 0x2F2F2218, 0xBE0E1777, 0xEA752DFE, 0x8B021FA1,\n\t 0xE5A0CC0F, 0xB56F74E8, 0x18ACF3D6, 0xCE89E299,\n\t 0xB4A84FE0, 0xFD13E0B7, 0x7CC43B81, 0xD2ADA8D9,\n\t 0x165FA266, 0x80957705, 0x93CC7314, 0x211A1477,\n\t 0xE6AD2065, 0x77B5FA86, 0xC75442F5, 0xFB9D35CF,\n\t 0xEBCDAF0C, 0x7B3E89A0, 0xD6411BD3, 0xAE1E7E49,\n\t 0x00250E2D, 0x2071B35E, 0x226800BB, 0x57B8E0AF,\n\t 0x2464369B, 0xF009B91E, 0x5563911D, 0x59DFA6AA,\n\t 0x78C14389, 0xD95A537F, 0x207D5BA2, 0x02E5B9C5,\n\t 0x83260376, 0x6295CFA9, 0x11C81968, 0x4E734A41,\n\t 0xB3472DCA, 0x7B14A94A, 0x1B510052, 0x9A532915,\n\t 0xD60F573F, 0xBC9BC6E4, 0x2B60A476, 0x81E67400,\n\t 0x08BA6FB5, 0x571BE91F, 0xF296EC6B, 0x2A0DD915,\n\t 0xB6636521, 0xE7B9F9B6, 0xFF34052E, 0xC5855664,\n\t 0x53B02D5D, 0xA99F8FA1, 0x08BA4799, 0x6E85076A ],\n\t [ 0x4B7A70E9, 0xB5B32944, 0xDB75092E, 0xC4192623,\n\t 0xAD6EA6B0, 0x49A7DF7D, 0x9CEE60B8, 0x8FEDB266,\n\t 0xECAA8C71, 0x699A17FF, 0x5664526C, 0xC2B19EE1,\n\t 0x193602A5, 0x75094C29, 0xA0591340, 0xE4183A3E,\n\t 0x3F54989A, 0x5B429D65, 0x6B8FE4D6, 0x99F73FD6,\n\t 0xA1D29C07, 0xEFE830F5, 0x4D2D38E6, 0xF0255DC1,\n\t 0x4CDD2086, 0x8470EB26, 0x6382E9C6, 0x021ECC5E,\n\t 0x09686B3F, 0x3EBAEFC9, 0x3C971814, 0x6B6A70A1,\n\t 0x687F3584, 0x52A0E286, 0xB79C5305, 0xAA500737,\n\t 0x3E07841C, 0x7FDEAE5C, 0x8E7D44EC, 0x5716F2B8,\n\t 0xB03ADA37, 0xF0500C0D, 0xF01C1F04, 0x0200B3FF,\n\t 0xAE0CF51A, 0x3CB574B2, 0x25837A58, 0xDC0921BD,\n\t 0xD19113F9, 0x7CA92FF6, 0x94324773, 0x22F54701,\n\t 0x3AE5E581, 0x37C2DADC, 0xC8B57634, 0x9AF3DDA7,\n\t 0xA9446146, 0x0FD0030E, 0xECC8C73E, 0xA4751E41,\n\t 0xE238CD99, 0x3BEA0E2F, 0x3280BBA1, 0x183EB331,\n\t 0x4E548B38, 0x4F6DB908, 0x6F420D03, 0xF60A04BF,\n\t 0x2CB81290, 0x24977C79, 0x5679B072, 0xBCAF89AF,\n\t 0xDE9A771F, 0xD9930810, 0xB38BAE12, 0xDCCF3F2E,\n\t 0x5512721F, 0x2E6B7124, 0x501ADDE6, 0x9F84CD87,\n\t 0x7A584718, 0x7408DA17, 0xBC9F9ABC, 0xE94B7D8C,\n\t 0xEC7AEC3A, 0xDB851DFA, 0x63094366, 0xC464C3D2,\n\t 0xEF1C1847, 0x3215D908, 0xDD433B37, 0x24C2BA16,\n\t 0x12A14D43, 0x2A65C451, 0x50940002, 0x133AE4DD,\n\t 0x71DFF89E, 0x10314E55, 0x81AC77D6, 0x5F11199B,\n\t 0x043556F1, 0xD7A3C76B, 0x3C11183B, 0x5924A509,\n\t 0xF28FE6ED, 0x97F1FBFA, 0x9EBABF2C, 0x1E153C6E,\n\t 0x86E34570, 0xEAE96FB1, 0x860E5E0A, 0x5A3E2AB3,\n\t 0x771FE71C, 0x4E3D06FA, 0x2965DCB9, 0x99E71D0F,\n\t 0x803E89D6, 0x5266C825, 0x2E4CC978, 0x9C10B36A,\n\t 0xC6150EBA, 0x94E2EA78, 0xA5FC3C53, 0x1E0A2DF4,\n\t 0xF2F74EA7, 0x361D2B3D, 0x1939260F, 0x19C27960,\n\t 0x5223A708, 0xF71312B6, 0xEBADFE6E, 0xEAC31F66,\n\t 0xE3BC4595, 0xA67BC883, 0xB17F37D1, 0x018CFF28,\n\t 0xC332DDEF, 0xBE6C5AA5, 0x65582185, 0x68AB9802,\n\t 0xEECEA50F, 0xDB2F953B, 0x2AEF7DAD, 0x5B6E2F84,\n\t 0x1521B628, 0x29076170, 0xECDD4775, 0x619F1510,\n\t 0x13CCA830, 0xEB61BD96, 0x0334FE1E, 0xAA0363CF,\n\t 0xB5735C90, 0x4C70A239, 0xD59E9E0B, 0xCBAADE14,\n\t 0xEECC86BC, 0x60622CA7, 0x9CAB5CAB, 0xB2F3846E,\n\t 0x648B1EAF, 0x19BDF0CA, 0xA02369B9, 0x655ABB50,\n\t 0x40685A32, 0x3C2AB4B3, 0x319EE9D5, 0xC021B8F7,\n\t 0x9B540B19, 0x875FA099, 0x95F7997E, 0x623D7DA8,\n\t 0xF837889A, 0x97E32D77, 0x11ED935F, 0x16681281,\n\t 0x0E358829, 0xC7E61FD6, 0x96DEDFA1, 0x7858BA99,\n\t 0x57F584A5, 0x1B227263, 0x9B83C3FF, 0x1AC24696,\n\t 0xCDB30AEB, 0x532E3054, 0x8FD948E4, 0x6DBC3128,\n\t 0x58EBF2EF, 0x34C6FFEA, 0xFE28ED61, 0xEE7C3C73,\n\t 0x5D4A14D9, 0xE864B7E3, 0x42105D14, 0x203E13E0,\n\t 0x45EEE2B6, 0xA3AAABEA, 0xDB6C4F15, 0xFACB4FD0,\n\t 0xC742F442, 0xEF6ABBB5, 0x654F3B1D, 0x41CD2105,\n\t 0xD81E799E, 0x86854DC7, 0xE44B476A, 0x3D816250,\n\t 0xCF62A1F2, 0x5B8D2646, 0xFC8883A0, 0xC1C7B6A3,\n\t 0x7F1524C3, 0x69CB7492, 0x47848A0B, 0x5692B285,\n\t 0x095BBF00, 0xAD19489D, 0x1462B174, 0x23820E00,\n\t 0x58428D2A, 0x0C55F5EA, 0x1DADF43E, 0x233F7061,\n\t 0x3372F092, 0x8D937E41, 0xD65FECF1, 0x6C223BDB,\n\t 0x7CDE3759, 0xCBEE7460, 0x4085F2A7, 0xCE77326E,\n\t 0xA6078084, 0x19F8509E, 0xE8EFD855, 0x61D99735,\n\t 0xA969A7AA, 0xC50C06C2, 0x5A04ABFC, 0x800BCADC,\n\t 0x9E447A2E, 0xC3453484, 0xFDD56705, 0x0E1E9EC9,\n\t 0xDB73DBD3, 0x105588CD, 0x675FDA79, 0xE3674340,\n\t 0xC5C43465, 0x713E38D8, 0x3D28F89E, 0xF16DFF20,\n\t 0x153E21E7, 0x8FB03D4A, 0xE6E39F2B, 0xDB83ADF7 ],\n\t [ 0xE93D5A68, 0x948140F7, 0xF64C261C, 0x94692934,\n\t 0x411520F7, 0x7602D4F7, 0xBCF46B2E, 0xD4A20068,\n\t 0xD4082471, 0x3320F46A, 0x43B7D4B7, 0x500061AF,\n\t 0x1E39F62E, 0x97244546, 0x14214F74, 0xBF8B8840,\n\t 0x4D95FC1D, 0x96B591AF, 0x70F4DDD3, 0x66A02F45,\n\t 0xBFBC09EC, 0x03BD9785, 0x7FAC6DD0, 0x31CB8504,\n\t 0x96EB27B3, 0x55FD3941, 0xDA2547E6, 0xABCA0A9A,\n\t 0x28507825, 0x530429F4, 0x0A2C86DA, 0xE9B66DFB,\n\t 0x68DC1462, 0xD7486900, 0x680EC0A4, 0x27A18DEE,\n\t 0x4F3FFEA2, 0xE887AD8C, 0xB58CE006, 0x7AF4D6B6,\n\t 0xAACE1E7C, 0xD3375FEC, 0xCE78A399, 0x406B2A42,\n\t 0x20FE9E35, 0xD9F385B9, 0xEE39D7AB, 0x3B124E8B,\n\t 0x1DC9FAF7, 0x4B6D1856, 0x26A36631, 0xEAE397B2,\n\t 0x3A6EFA74, 0xDD5B4332, 0x6841E7F7, 0xCA7820FB,\n\t 0xFB0AF54E, 0xD8FEB397, 0x454056AC, 0xBA489527,\n\t 0x55533A3A, 0x20838D87, 0xFE6BA9B7, 0xD096954B,\n\t 0x55A867BC, 0xA1159A58, 0xCCA92963, 0x99E1DB33,\n\t 0xA62A4A56, 0x3F3125F9, 0x5EF47E1C, 0x9029317C,\n\t 0xFDF8E802, 0x04272F70, 0x80BB155C, 0x05282CE3,\n\t 0x95C11548, 0xE4C66D22, 0x48C1133F, 0xC70F86DC,\n\t 0x07F9C9EE, 0x41041F0F, 0x404779A4, 0x5D886E17,\n\t 0x325F51EB, 0xD59BC0D1, 0xF2BCC18F, 0x41113564,\n\t 0x257B7834, 0x602A9C60, 0xDFF8E8A3, 0x1F636C1B,\n\t 0x0E12B4C2, 0x02E1329E, 0xAF664FD1, 0xCAD18115,\n\t 0x6B2395E0, 0x333E92E1, 0x3B240B62, 0xEEBEB922,\n\t 0x85B2A20E, 0xE6BA0D99, 0xDE720C8C, 0x2DA2F728,\n\t 0xD0127845, 0x95B794FD, 0x647D0862, 0xE7CCF5F0,\n\t 0x5449A36F, 0x877D48FA, 0xC39DFD27, 0xF33E8D1E,\n\t 0x0A476341, 0x992EFF74, 0x3A6F6EAB, 0xF4F8FD37,\n\t 0xA812DC60, 0xA1EBDDF8, 0x991BE14C, 0xDB6E6B0D,\n\t 0xC67B5510, 0x6D672C37, 0x2765D43B, 0xDCD0E804,\n\t 0xF1290DC7, 0xCC00FFA3, 0xB5390F92, 0x690FED0B,\n\t 0x667B9FFB, 0xCEDB7D9C, 0xA091CF0B, 0xD9155EA3,\n\t 0xBB132F88, 0x515BAD24, 0x7B9479BF, 0x763BD6EB,\n\t 0x37392EB3, 0xCC115979, 0x8026E297, 0xF42E312D,\n\t 0x6842ADA7, 0xC66A2B3B, 0x12754CCC, 0x782EF11C,\n\t 0x6A124237, 0xB79251E7, 0x06A1BBE6, 0x4BFB6350,\n\t 0x1A6B1018, 0x11CAEDFA, 0x3D25BDD8, 0xE2E1C3C9,\n\t 0x44421659, 0x0A121386, 0xD90CEC6E, 0xD5ABEA2A,\n\t 0x64AF674E, 0xDA86A85F, 0xBEBFE988, 0x64E4C3FE,\n\t 0x9DBC8057, 0xF0F7C086, 0x60787BF8, 0x6003604D,\n\t 0xD1FD8346, 0xF6381FB0, 0x7745AE04, 0xD736FCCC,\n\t 0x83426B33, 0xF01EAB71, 0xB0804187, 0x3C005E5F,\n\t 0x77A057BE, 0xBDE8AE24, 0x55464299, 0xBF582E61,\n\t 0x4E58F48F, 0xF2DDFDA2, 0xF474EF38, 0x8789BDC2,\n\t 0x5366F9C3, 0xC8B38E74, 0xB475F255, 0x46FCD9B9,\n\t 0x7AEB2661, 0x8B1DDF84, 0x846A0E79, 0x915F95E2,\n\t 0x466E598E, 0x20B45770, 0x8CD55591, 0xC902DE4C,\n\t 0xB90BACE1, 0xBB8205D0, 0x11A86248, 0x7574A99E,\n\t 0xB77F19B6, 0xE0A9DC09, 0x662D09A1, 0xC4324633,\n\t 0xE85A1F02, 0x09F0BE8C, 0x4A99A025, 0x1D6EFE10,\n\t 0x1AB93D1D, 0x0BA5A4DF, 0xA186F20F, 0x2868F169,\n\t 0xDCB7DA83, 0x573906FE, 0xA1E2CE9B, 0x4FCD7F52,\n\t 0x50115E01, 0xA70683FA, 0xA002B5C4, 0x0DE6D027,\n\t 0x9AF88C27, 0x773F8641, 0xC3604C06, 0x61A806B5,\n\t 0xF0177A28, 0xC0F586E0, 0x006058AA, 0x30DC7D62,\n\t 0x11E69ED7, 0x2338EA63, 0x53C2DD94, 0xC2C21634,\n\t 0xBBCBEE56, 0x90BCB6DE, 0xEBFC7DA1, 0xCE591D76,\n\t 0x6F05E409, 0x4B7C0188, 0x39720A3D, 0x7C927C24,\n\t 0x86E3725F, 0x724D9DB9, 0x1AC15BB4, 0xD39EB8FC,\n\t 0xED545578, 0x08FCA5B5, 0xD83D7CD3, 0x4DAD0FC4,\n\t 0x1E50EF5E, 0xB161E6F8, 0xA28514D9, 0x6C51133C,\n\t 0x6FD5C7E7, 0x56E14EC4, 0x362ABFCE, 0xDDC6C837,\n\t 0xD79A3234, 0x92638212, 0x670EFA8E, 0x406000E0 ],\n\t [ 0x3A39CE37, 0xD3FAF5CF, 0xABC27737, 0x5AC52D1B,\n\t 0x5CB0679E, 0x4FA33742, 0xD3822740, 0x99BC9BBE,\n\t 0xD5118E9D, 0xBF0F7315, 0xD62D1C7E, 0xC700C47B,\n\t 0xB78C1B6B, 0x21A19045, 0xB26EB1BE, 0x6A366EB4,\n\t 0x5748AB2F, 0xBC946E79, 0xC6A376D2, 0x6549C2C8,\n\t 0x530FF8EE, 0x468DDE7D, 0xD5730A1D, 0x4CD04DC6,\n\t 0x2939BBDB, 0xA9BA4650, 0xAC9526E8, 0xBE5EE304,\n\t 0xA1FAD5F0, 0x6A2D519A, 0x63EF8CE2, 0x9A86EE22,\n\t 0xC089C2B8, 0x43242EF6, 0xA51E03AA, 0x9CF2D0A4,\n\t 0x83C061BA, 0x9BE96A4D, 0x8FE51550, 0xBA645BD6,\n\t 0x2826A2F9, 0xA73A3AE1, 0x4BA99586, 0xEF5562E9,\n\t 0xC72FEFD3, 0xF752F7DA, 0x3F046F69, 0x77FA0A59,\n\t 0x80E4A915, 0x87B08601, 0x9B09E6AD, 0x3B3EE593,\n\t 0xE990FD5A, 0x9E34D797, 0x2CF0B7D9, 0x022B8B51,\n\t 0x96D5AC3A, 0x017DA67D, 0xD1CF3ED6, 0x7C7D2D28,\n\t 0x1F9F25CF, 0xADF2B89B, 0x5AD6B472, 0x5A88F54C,\n\t 0xE029AC71, 0xE019A5E6, 0x47B0ACFD, 0xED93FA9B,\n\t 0xE8D3C48D, 0x283B57CC, 0xF8D56629, 0x79132E28,\n\t 0x785F0191, 0xED756055, 0xF7960E44, 0xE3D35E8C,\n\t 0x15056DD4, 0x88F46DBA, 0x03A16125, 0x0564F0BD,\n\t 0xC3EB9E15, 0x3C9057A2, 0x97271AEC, 0xA93A072A,\n\t 0x1B3F6D9B, 0x1E6321F5, 0xF59C66FB, 0x26DCF319,\n\t 0x7533D928, 0xB155FDF5, 0x03563482, 0x8ABA3CBB,\n\t 0x28517711, 0xC20AD9F8, 0xABCC5167, 0xCCAD925F,\n\t 0x4DE81751, 0x3830DC8E, 0x379D5862, 0x9320F991,\n\t 0xEA7A90C2, 0xFB3E7BCE, 0x5121CE64, 0x774FBE32,\n\t 0xA8B6E37E, 0xC3293D46, 0x48DE5369, 0x6413E680,\n\t 0xA2AE0810, 0xDD6DB224, 0x69852DFD, 0x09072166,\n\t 0xB39A460A, 0x6445C0DD, 0x586CDECF, 0x1C20C8AE,\n\t 0x5BBEF7DD, 0x1B588D40, 0xCCD2017F, 0x6BB4E3BB,\n\t 0xDDA26A7E, 0x3A59FF45, 0x3E350A44, 0xBCB4CDD5,\n\t 0x72EACEA8, 0xFA6484BB, 0x8D6612AE, 0xBF3C6F47,\n\t 0xD29BE463, 0x542F5D9E, 0xAEC2771B, 0xF64E6370,\n\t 0x740E0D8D, 0xE75B1357, 0xF8721671, 0xAF537D5D,\n\t 0x4040CB08, 0x4EB4E2CC, 0x34D2466A, 0x0115AF84,\n\t 0xE1B00428, 0x95983A1D, 0x06B89FB4, 0xCE6EA048,\n\t 0x6F3F3B82, 0x3520AB82, 0x011A1D4B, 0x277227F8,\n\t 0x611560B1, 0xE7933FDC, 0xBB3A792B, 0x344525BD,\n\t 0xA08839E1, 0x51CE794B, 0x2F32C9B7, 0xA01FBAC9,\n\t 0xE01CC87E, 0xBCC7D1F6, 0xCF0111C3, 0xA1E8AAC7,\n\t 0x1A908749, 0xD44FBD9A, 0xD0DADECB, 0xD50ADA38,\n\t 0x0339C32A, 0xC6913667, 0x8DF9317C, 0xE0B12B4F,\n\t 0xF79E59B7, 0x43F5BB3A, 0xF2D519FF, 0x27D9459C,\n\t 0xBF97222C, 0x15E6FC2A, 0x0F91FC71, 0x9B941525,\n\t 0xFAE59361, 0xCEB69CEB, 0xC2A86459, 0x12BAA8D1,\n\t 0xB6C1075E, 0xE3056A0C, 0x10D25065, 0xCB03A442,\n\t 0xE0EC6E0E, 0x1698DB3B, 0x4C98A0BE, 0x3278E964,\n\t 0x9F1F9532, 0xE0D392DF, 0xD3A0342B, 0x8971F21E,\n\t 0x1B0A7441, 0x4BA3348C, 0xC5BE7120, 0xC37632D8,\n\t 0xDF359F8D, 0x9B992F2E, 0xE60B6F47, 0x0FE3F11D,\n\t 0xE54CDA54, 0x1EDAD891, 0xCE6279CF, 0xCD3E7E6F,\n\t 0x1618B166, 0xFD2C1D05, 0x848FD2C5, 0xF6FB2299,\n\t 0xF523F357, 0xA6327623, 0x93A83531, 0x56CCCD02,\n\t 0xACF08162, 0x5A75EBB5, 0x6E163697, 0x88D273CC,\n\t 0xDE966292, 0x81B949D0, 0x4C50901B, 0x71C65614,\n\t 0xE6C6C7BD, 0x327A140A, 0x45E1D006, 0xC3F27B9A,\n\t 0xC9AA53FD, 0x62A80F00, 0xBB25BFE2, 0x35BDD2F6,\n\t 0x71126905, 0xB2040222, 0xB6CBCF7C, 0xCD769C2B,\n\t 0x53113EC0, 0x1640E3D3, 0x38ABBD60, 0x2547ADF0,\n\t 0xBA38209C, 0xF746CE76, 0x77AFA1C5, 0x20756060,\n\t 0x85CBFE4E, 0x8AE88DD8, 0x7AAAF9B0, 0x4CF9AA7E,\n\t 0x1948C25C, 0x02FB8A8C, 0x01C36AE4, 0xD6EBE1F9,\n\t 0x90D4F869, 0xA65CDEA0, 0x3F09252D, 0xC208E69F,\n\t 0xB74E6132, 0xCE77E25B, 0x578FDFE3, 0x3AC372E6 ]\n\t ];\n\n\t var BLOWFISH_CTX = {\n\t pbox: [],\n\t sbox: []\n\t }\n\n\t function F(ctx, x){\n\t let a = (x >> 24) & 0xFF;\n\t let b = (x >> 16) & 0xFF;\n\t let c = (x >> 8) & 0xFF;\n\t let d = x & 0xFF;\n\n\t let y = ctx.sbox[0][a] + ctx.sbox[1][b];\n\t y = y ^ ctx.sbox[2][c];\n\t y = y + ctx.sbox[3][d];\n\n\t return y;\n\t }\n\n\t function BlowFish_Encrypt(ctx, left, right){\n\t let Xl = left;\n\t let Xr = right;\n\t let temp;\n\n\t for(let i = 0; i < N; ++i){\n\t Xl = Xl ^ ctx.pbox[i];\n\t Xr = F(ctx, Xl) ^ Xr;\n\n\t temp = Xl;\n\t Xl = Xr;\n\t Xr = temp;\n\t }\n\n\t temp = Xl;\n\t Xl = Xr;\n\t Xr = temp;\n\n\t Xr = Xr ^ ctx.pbox[N];\n\t Xl = Xl ^ ctx.pbox[N + 1];\n\n\t return {left: Xl, right: Xr};\n\t }\n\n\t function BlowFish_Decrypt(ctx, left, right){\n\t let Xl = left;\n\t let Xr = right;\n\t let temp;\n\n\t for(let i = N + 1; i > 1; --i){\n\t Xl = Xl ^ ctx.pbox[i];\n\t Xr = F(ctx, Xl) ^ Xr;\n\n\t temp = Xl;\n\t Xl = Xr;\n\t Xr = temp;\n\t }\n\n\t temp = Xl;\n\t Xl = Xr;\n\t Xr = temp;\n\n\t Xr = Xr ^ ctx.pbox[1];\n\t Xl = Xl ^ ctx.pbox[0];\n\n\t return {left: Xl, right: Xr};\n\t }\n\n\t /**\n\t * Initialization ctx's pbox and sbox.\n\t *\n\t * @param {Object} ctx The object has pbox and sbox.\n\t * @param {Array} key An array of 32-bit words.\n\t * @param {int} keysize The length of the key.\n\t *\n\t * @example\n\t *\n\t * BlowFishInit(BLOWFISH_CTX, key, 128/32);\n\t */\n\t function BlowFishInit(ctx, key, keysize)\n\t {\n\t for(let Row = 0; Row < 4; Row++)\n\t {\n\t ctx.sbox[Row] = [];\n\t for(let Col = 0; Col < 256; Col++)\n\t {\n\t ctx.sbox[Row][Col] = ORIG_S[Row][Col];\n\t }\n\t }\n\n\t let keyIndex = 0;\n\t for(let index = 0; index < N + 2; index++)\n\t {\n\t ctx.pbox[index] = ORIG_P[index] ^ key[keyIndex];\n\t keyIndex++;\n\t if(keyIndex >= keysize)\n\t {\n\t keyIndex = 0;\n\t }\n\t }\n\n\t let Data1 = 0;\n\t let Data2 = 0;\n\t let res = 0;\n\t for(let i = 0; i < N + 2; i += 2)\n\t {\n\t res = BlowFish_Encrypt(ctx, Data1, Data2);\n\t Data1 = res.left;\n\t Data2 = res.right;\n\t ctx.pbox[i] = Data1;\n\t ctx.pbox[i + 1] = Data2;\n\t }\n\n\t for(let i = 0; i < 4; i++)\n\t {\n\t for(let j = 0; j < 256; j += 2)\n\t {\n\t res = BlowFish_Encrypt(ctx, Data1, Data2);\n\t Data1 = res.left;\n\t Data2 = res.right;\n\t ctx.sbox[i][j] = Data1;\n\t ctx.sbox[i][j + 1] = Data2;\n\t }\n\t }\n\n\t return true;\n\t }\n\n\t /**\n\t * Blowfish block cipher algorithm.\n\t */\n\t var Blowfish = C_algo.Blowfish = BlockCipher.extend({\n\t _doReset: function () {\n\t // Skip reset of nRounds has been set before and key did not change\n\t if (this._keyPriorReset === this._key) {\n\t return;\n\t }\n\n\t // Shortcuts\n\t var key = this._keyPriorReset = this._key;\n\t var keyWords = key.words;\n\t var keySize = key.sigBytes / 4;\n\n\t //Initialization pbox and sbox\n\t BlowFishInit(BLOWFISH_CTX, keyWords, keySize);\n\t },\n\n\t encryptBlock: function (M, offset) {\n\t var res = BlowFish_Encrypt(BLOWFISH_CTX, M[offset], M[offset + 1]);\n\t M[offset] = res.left;\n\t M[offset + 1] = res.right;\n\t },\n\n\t decryptBlock: function (M, offset) {\n\t var res = BlowFish_Decrypt(BLOWFISH_CTX, M[offset], M[offset + 1]);\n\t M[offset] = res.left;\n\t M[offset + 1] = res.right;\n\t },\n\n\t blockSize: 64/32,\n\n\t keySize: 128/32,\n\n\t ivSize: 64/32\n\t });\n\n\t /**\n\t * Shortcut functions to the cipher's object interface.\n\t *\n\t * @example\n\t *\n\t * var ciphertext = CryptoJS.Blowfish.encrypt(message, key, cfg);\n\t * var plaintext = CryptoJS.Blowfish.decrypt(ciphertext, key, cfg);\n\t */\n\t C.Blowfish = BlockCipher._createHelper(Blowfish);\n\t}());\n\n\n\treturn CryptoJS.Blowfish;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./evpkdf\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./evpkdf\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t/**\n\t * Cipher core components.\n\t */\n\tCryptoJS.lib.Cipher || (function (undefined) {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var Base = C_lib.Base;\n\t var WordArray = C_lib.WordArray;\n\t var BufferedBlockAlgorithm = C_lib.BufferedBlockAlgorithm;\n\t var C_enc = C.enc;\n\t var Utf8 = C_enc.Utf8;\n\t var Base64 = C_enc.Base64;\n\t var C_algo = C.algo;\n\t var EvpKDF = C_algo.EvpKDF;\n\n\t /**\n\t * Abstract base cipher template.\n\t *\n\t * @property {number} keySize This cipher's key size. Default: 4 (128 bits)\n\t * @property {number} ivSize This cipher's IV size. Default: 4 (128 bits)\n\t * @property {number} _ENC_XFORM_MODE A constant representing encryption mode.\n\t * @property {number} _DEC_XFORM_MODE A constant representing decryption mode.\n\t */\n\t var Cipher = C_lib.Cipher = BufferedBlockAlgorithm.extend({\n\t /**\n\t * Configuration options.\n\t *\n\t * @property {WordArray} iv The IV to use for this operation.\n\t */\n\t cfg: Base.extend(),\n\n\t /**\n\t * Creates this cipher in encryption mode.\n\t *\n\t * @param {WordArray} key The key.\n\t * @param {Object} cfg (Optional) The configuration options to use for this operation.\n\t *\n\t * @return {Cipher} A cipher instance.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var cipher = CryptoJS.algo.AES.createEncryptor(keyWordArray, { iv: ivWordArray });\n\t */\n\t createEncryptor: function (key, cfg) {\n\t return this.create(this._ENC_XFORM_MODE, key, cfg);\n\t },\n\n\t /**\n\t * Creates this cipher in decryption mode.\n\t *\n\t * @param {WordArray} key The key.\n\t * @param {Object} cfg (Optional) The configuration options to use for this operation.\n\t *\n\t * @return {Cipher} A cipher instance.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var cipher = CryptoJS.algo.AES.createDecryptor(keyWordArray, { iv: ivWordArray });\n\t */\n\t createDecryptor: function (key, cfg) {\n\t return this.create(this._DEC_XFORM_MODE, key, cfg);\n\t },\n\n\t /**\n\t * Initializes a newly created cipher.\n\t *\n\t * @param {number} xformMode Either the encryption or decryption transormation mode constant.\n\t * @param {WordArray} key The key.\n\t * @param {Object} cfg (Optional) The configuration options to use for this operation.\n\t *\n\t * @example\n\t *\n\t * var cipher = CryptoJS.algo.AES.create(CryptoJS.algo.AES._ENC_XFORM_MODE, keyWordArray, { iv: ivWordArray });\n\t */\n\t init: function (xformMode, key, cfg) {\n\t // Apply config defaults\n\t this.cfg = this.cfg.extend(cfg);\n\n\t // Store transform mode and key\n\t this._xformMode = xformMode;\n\t this._key = key;\n\n\t // Set initial values\n\t this.reset();\n\t },\n\n\t /**\n\t * Resets this cipher to its initial state.\n\t *\n\t * @example\n\t *\n\t * cipher.reset();\n\t */\n\t reset: function () {\n\t // Reset data buffer\n\t BufferedBlockAlgorithm.reset.call(this);\n\n\t // Perform concrete-cipher logic\n\t this._doReset();\n\t },\n\n\t /**\n\t * Adds data to be encrypted or decrypted.\n\t *\n\t * @param {WordArray|string} dataUpdate The data to encrypt or decrypt.\n\t *\n\t * @return {WordArray} The data after processing.\n\t *\n\t * @example\n\t *\n\t * var encrypted = cipher.process('data');\n\t * var encrypted = cipher.process(wordArray);\n\t */\n\t process: function (dataUpdate) {\n\t // Append\n\t this._append(dataUpdate);\n\n\t // Process available blocks\n\t return this._process();\n\t },\n\n\t /**\n\t * Finalizes the encryption or decryption process.\n\t * Note that the finalize operation is effectively a destructive, read-once operation.\n\t *\n\t * @param {WordArray|string} dataUpdate The final data to encrypt or decrypt.\n\t *\n\t * @return {WordArray} The data after final processing.\n\t *\n\t * @example\n\t *\n\t * var encrypted = cipher.finalize();\n\t * var encrypted = cipher.finalize('data');\n\t * var encrypted = cipher.finalize(wordArray);\n\t */\n\t finalize: function (dataUpdate) {\n\t // Final data update\n\t if (dataUpdate) {\n\t this._append(dataUpdate);\n\t }\n\n\t // Perform concrete-cipher logic\n\t var finalProcessedData = this._doFinalize();\n\n\t return finalProcessedData;\n\t },\n\n\t keySize: 128/32,\n\n\t ivSize: 128/32,\n\n\t _ENC_XFORM_MODE: 1,\n\n\t _DEC_XFORM_MODE: 2,\n\n\t /**\n\t * Creates shortcut functions to a cipher's object interface.\n\t *\n\t * @param {Cipher} cipher The cipher to create a helper for.\n\t *\n\t * @return {Object} An object with encrypt and decrypt shortcut functions.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var AES = CryptoJS.lib.Cipher._createHelper(CryptoJS.algo.AES);\n\t */\n\t _createHelper: (function () {\n\t function selectCipherStrategy(key) {\n\t if (typeof key == 'string') {\n\t return PasswordBasedCipher;\n\t } else {\n\t return SerializableCipher;\n\t }\n\t }\n\n\t return function (cipher) {\n\t return {\n\t encrypt: function (message, key, cfg) {\n\t return selectCipherStrategy(key).encrypt(cipher, message, key, cfg);\n\t },\n\n\t decrypt: function (ciphertext, key, cfg) {\n\t return selectCipherStrategy(key).decrypt(cipher, ciphertext, key, cfg);\n\t }\n\t };\n\t };\n\t }())\n\t });\n\n\t /**\n\t * Abstract base stream cipher template.\n\t *\n\t * @property {number} blockSize The number of 32-bit words this cipher operates on. Default: 1 (32 bits)\n\t */\n\t var StreamCipher = C_lib.StreamCipher = Cipher.extend({\n\t _doFinalize: function () {\n\t // Process partial blocks\n\t var finalProcessedBlocks = this._process(!!'flush');\n\n\t return finalProcessedBlocks;\n\t },\n\n\t blockSize: 1\n\t });\n\n\t /**\n\t * Mode namespace.\n\t */\n\t var C_mode = C.mode = {};\n\n\t /**\n\t * Abstract base block cipher mode template.\n\t */\n\t var BlockCipherMode = C_lib.BlockCipherMode = Base.extend({\n\t /**\n\t * Creates this mode for encryption.\n\t *\n\t * @param {Cipher} cipher A block cipher instance.\n\t * @param {Array} iv The IV words.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var mode = CryptoJS.mode.CBC.createEncryptor(cipher, iv.words);\n\t */\n\t createEncryptor: function (cipher, iv) {\n\t return this.Encryptor.create(cipher, iv);\n\t },\n\n\t /**\n\t * Creates this mode for decryption.\n\t *\n\t * @param {Cipher} cipher A block cipher instance.\n\t * @param {Array} iv The IV words.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var mode = CryptoJS.mode.CBC.createDecryptor(cipher, iv.words);\n\t */\n\t createDecryptor: function (cipher, iv) {\n\t return this.Decryptor.create(cipher, iv);\n\t },\n\n\t /**\n\t * Initializes a newly created mode.\n\t *\n\t * @param {Cipher} cipher A block cipher instance.\n\t * @param {Array} iv The IV words.\n\t *\n\t * @example\n\t *\n\t * var mode = CryptoJS.mode.CBC.Encryptor.create(cipher, iv.words);\n\t */\n\t init: function (cipher, iv) {\n\t this._cipher = cipher;\n\t this._iv = iv;\n\t }\n\t });\n\n\t /**\n\t * Cipher Block Chaining mode.\n\t */\n\t var CBC = C_mode.CBC = (function () {\n\t /**\n\t * Abstract base CBC mode.\n\t */\n\t var CBC = BlockCipherMode.extend();\n\n\t /**\n\t * CBC encryptor.\n\t */\n\t CBC.Encryptor = CBC.extend({\n\t /**\n\t * Processes the data block at offset.\n\t *\n\t * @param {Array} words The data words to operate on.\n\t * @param {number} offset The offset where the block starts.\n\t *\n\t * @example\n\t *\n\t * mode.processBlock(data.words, offset);\n\t */\n\t processBlock: function (words, offset) {\n\t // Shortcuts\n\t var cipher = this._cipher;\n\t var blockSize = cipher.blockSize;\n\n\t // XOR and encrypt\n\t xorBlock.call(this, words, offset, blockSize);\n\t cipher.encryptBlock(words, offset);\n\n\t // Remember this block to use with next block\n\t this._prevBlock = words.slice(offset, offset + blockSize);\n\t }\n\t });\n\n\t /**\n\t * CBC decryptor.\n\t */\n\t CBC.Decryptor = CBC.extend({\n\t /**\n\t * Processes the data block at offset.\n\t *\n\t * @param {Array} words The data words to operate on.\n\t * @param {number} offset The offset where the block starts.\n\t *\n\t * @example\n\t *\n\t * mode.processBlock(data.words, offset);\n\t */\n\t processBlock: function (words, offset) {\n\t // Shortcuts\n\t var cipher = this._cipher;\n\t var blockSize = cipher.blockSize;\n\n\t // Remember this block to use with next block\n\t var thisBlock = words.slice(offset, offset + blockSize);\n\n\t // Decrypt and XOR\n\t cipher.decryptBlock(words, offset);\n\t xorBlock.call(this, words, offset, blockSize);\n\n\t // This block becomes the previous block\n\t this._prevBlock = thisBlock;\n\t }\n\t });\n\n\t function xorBlock(words, offset, blockSize) {\n\t var block;\n\n\t // Shortcut\n\t var iv = this._iv;\n\n\t // Choose mixing block\n\t if (iv) {\n\t block = iv;\n\n\t // Remove IV for subsequent blocks\n\t this._iv = undefined;\n\t } else {\n\t block = this._prevBlock;\n\t }\n\n\t // XOR blocks\n\t for (var i = 0; i < blockSize; i++) {\n\t words[offset + i] ^= block[i];\n\t }\n\t }\n\n\t return CBC;\n\t }());\n\n\t /**\n\t * Padding namespace.\n\t */\n\t var C_pad = C.pad = {};\n\n\t /**\n\t * PKCS #5/7 padding strategy.\n\t */\n\t var Pkcs7 = C_pad.Pkcs7 = {\n\t /**\n\t * Pads data using the algorithm defined in PKCS #5/7.\n\t *\n\t * @param {WordArray} data The data to pad.\n\t * @param {number} blockSize The multiple that the data should be padded to.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * CryptoJS.pad.Pkcs7.pad(wordArray, 4);\n\t */\n\t pad: function (data, blockSize) {\n\t // Shortcut\n\t var blockSizeBytes = blockSize * 4;\n\n\t // Count padding bytes\n\t var nPaddingBytes = blockSizeBytes - data.sigBytes % blockSizeBytes;\n\n\t // Create padding word\n\t var paddingWord = (nPaddingBytes << 24) | (nPaddingBytes << 16) | (nPaddingBytes << 8) | nPaddingBytes;\n\n\t // Create padding\n\t var paddingWords = [];\n\t for (var i = 0; i < nPaddingBytes; i += 4) {\n\t paddingWords.push(paddingWord);\n\t }\n\t var padding = WordArray.create(paddingWords, nPaddingBytes);\n\n\t // Add padding\n\t data.concat(padding);\n\t },\n\n\t /**\n\t * Unpads data that had been padded using the algorithm defined in PKCS #5/7.\n\t *\n\t * @param {WordArray} data The data to unpad.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * CryptoJS.pad.Pkcs7.unpad(wordArray);\n\t */\n\t unpad: function (data) {\n\t // Get number of padding bytes from last byte\n\t var nPaddingBytes = data.words[(data.sigBytes - 1) >>> 2] & 0xff;\n\n\t // Remove padding\n\t data.sigBytes -= nPaddingBytes;\n\t }\n\t };\n\n\t /**\n\t * Abstract base block cipher template.\n\t *\n\t * @property {number} blockSize The number of 32-bit words this cipher operates on. Default: 4 (128 bits)\n\t */\n\t var BlockCipher = C_lib.BlockCipher = Cipher.extend({\n\t /**\n\t * Configuration options.\n\t *\n\t * @property {Mode} mode The block mode to use. Default: CBC\n\t * @property {Padding} padding The padding strategy to use. Default: Pkcs7\n\t */\n\t cfg: Cipher.cfg.extend({\n\t mode: CBC,\n\t padding: Pkcs7\n\t }),\n\n\t reset: function () {\n\t var modeCreator;\n\n\t // Reset cipher\n\t Cipher.reset.call(this);\n\n\t // Shortcuts\n\t var cfg = this.cfg;\n\t var iv = cfg.iv;\n\t var mode = cfg.mode;\n\n\t // Reset block mode\n\t if (this._xformMode == this._ENC_XFORM_MODE) {\n\t modeCreator = mode.createEncryptor;\n\t } else /* if (this._xformMode == this._DEC_XFORM_MODE) */ {\n\t modeCreator = mode.createDecryptor;\n\t // Keep at least one block in the buffer for unpadding\n\t this._minBufferSize = 1;\n\t }\n\n\t if (this._mode && this._mode.__creator == modeCreator) {\n\t this._mode.init(this, iv && iv.words);\n\t } else {\n\t this._mode = modeCreator.call(mode, this, iv && iv.words);\n\t this._mode.__creator = modeCreator;\n\t }\n\t },\n\n\t _doProcessBlock: function (words, offset) {\n\t this._mode.processBlock(words, offset);\n\t },\n\n\t _doFinalize: function () {\n\t var finalProcessedBlocks;\n\n\t // Shortcut\n\t var padding = this.cfg.padding;\n\n\t // Finalize\n\t if (this._xformMode == this._ENC_XFORM_MODE) {\n\t // Pad data\n\t padding.pad(this._data, this.blockSize);\n\n\t // Process final blocks\n\t finalProcessedBlocks = this._process(!!'flush');\n\t } else /* if (this._xformMode == this._DEC_XFORM_MODE) */ {\n\t // Process final blocks\n\t finalProcessedBlocks = this._process(!!'flush');\n\n\t // Unpad data\n\t padding.unpad(finalProcessedBlocks);\n\t }\n\n\t return finalProcessedBlocks;\n\t },\n\n\t blockSize: 128/32\n\t });\n\n\t /**\n\t * A collection of cipher parameters.\n\t *\n\t * @property {WordArray} ciphertext The raw ciphertext.\n\t * @property {WordArray} key The key to this ciphertext.\n\t * @property {WordArray} iv The IV used in the ciphering operation.\n\t * @property {WordArray} salt The salt used with a key derivation function.\n\t * @property {Cipher} algorithm The cipher algorithm.\n\t * @property {Mode} mode The block mode used in the ciphering operation.\n\t * @property {Padding} padding The padding scheme used in the ciphering operation.\n\t * @property {number} blockSize The block size of the cipher.\n\t * @property {Format} formatter The default formatting strategy to convert this cipher params object to a string.\n\t */\n\t var CipherParams = C_lib.CipherParams = Base.extend({\n\t /**\n\t * Initializes a newly created cipher params object.\n\t *\n\t * @param {Object} cipherParams An object with any of the possible cipher parameters.\n\t *\n\t * @example\n\t *\n\t * var cipherParams = CryptoJS.lib.CipherParams.create({\n\t * ciphertext: ciphertextWordArray,\n\t * key: keyWordArray,\n\t * iv: ivWordArray,\n\t * salt: saltWordArray,\n\t * algorithm: CryptoJS.algo.AES,\n\t * mode: CryptoJS.mode.CBC,\n\t * padding: CryptoJS.pad.PKCS7,\n\t * blockSize: 4,\n\t * formatter: CryptoJS.format.OpenSSL\n\t * });\n\t */\n\t init: function (cipherParams) {\n\t this.mixIn(cipherParams);\n\t },\n\n\t /**\n\t * Converts this cipher params object to a string.\n\t *\n\t * @param {Format} formatter (Optional) The formatting strategy to use.\n\t *\n\t * @return {string} The stringified cipher params.\n\t *\n\t * @throws Error If neither the formatter nor the default formatter is set.\n\t *\n\t * @example\n\t *\n\t * var string = cipherParams + '';\n\t * var string = cipherParams.toString();\n\t * var string = cipherParams.toString(CryptoJS.format.OpenSSL);\n\t */\n\t toString: function (formatter) {\n\t return (formatter || this.formatter).stringify(this);\n\t }\n\t });\n\n\t /**\n\t * Format namespace.\n\t */\n\t var C_format = C.format = {};\n\n\t /**\n\t * OpenSSL formatting strategy.\n\t */\n\t var OpenSSLFormatter = C_format.OpenSSL = {\n\t /**\n\t * Converts a cipher params object to an OpenSSL-compatible string.\n\t *\n\t * @param {CipherParams} cipherParams The cipher params object.\n\t *\n\t * @return {string} The OpenSSL-compatible string.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var openSSLString = CryptoJS.format.OpenSSL.stringify(cipherParams);\n\t */\n\t stringify: function (cipherParams) {\n\t var wordArray;\n\n\t // Shortcuts\n\t var ciphertext = cipherParams.ciphertext;\n\t var salt = cipherParams.salt;\n\n\t // Format\n\t if (salt) {\n\t wordArray = WordArray.create([0x53616c74, 0x65645f5f]).concat(salt).concat(ciphertext);\n\t } else {\n\t wordArray = ciphertext;\n\t }\n\n\t return wordArray.toString(Base64);\n\t },\n\n\t /**\n\t * Converts an OpenSSL-compatible string to a cipher params object.\n\t *\n\t * @param {string} openSSLStr The OpenSSL-compatible string.\n\t *\n\t * @return {CipherParams} The cipher params object.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var cipherParams = CryptoJS.format.OpenSSL.parse(openSSLString);\n\t */\n\t parse: function (openSSLStr) {\n\t var salt;\n\n\t // Parse base64\n\t var ciphertext = Base64.parse(openSSLStr);\n\n\t // Shortcut\n\t var ciphertextWords = ciphertext.words;\n\n\t // Test for salt\n\t if (ciphertextWords[0] == 0x53616c74 && ciphertextWords[1] == 0x65645f5f) {\n\t // Extract salt\n\t salt = WordArray.create(ciphertextWords.slice(2, 4));\n\n\t // Remove salt from ciphertext\n\t ciphertextWords.splice(0, 4);\n\t ciphertext.sigBytes -= 16;\n\t }\n\n\t return CipherParams.create({ ciphertext: ciphertext, salt: salt });\n\t }\n\t };\n\n\t /**\n\t * A cipher wrapper that returns ciphertext as a serializable cipher params object.\n\t */\n\t var SerializableCipher = C_lib.SerializableCipher = Base.extend({\n\t /**\n\t * Configuration options.\n\t *\n\t * @property {Formatter} format The formatting strategy to convert cipher param objects to and from a string. Default: OpenSSL\n\t */\n\t cfg: Base.extend({\n\t format: OpenSSLFormatter\n\t }),\n\n\t /**\n\t * Encrypts a message.\n\t *\n\t * @param {Cipher} cipher The cipher algorithm to use.\n\t * @param {WordArray|string} message The message to encrypt.\n\t * @param {WordArray} key The key.\n\t * @param {Object} cfg (Optional) The configuration options to use for this operation.\n\t *\n\t * @return {CipherParams} A cipher params object.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var ciphertextParams = CryptoJS.lib.SerializableCipher.encrypt(CryptoJS.algo.AES, message, key);\n\t * var ciphertextParams = CryptoJS.lib.SerializableCipher.encrypt(CryptoJS.algo.AES, message, key, { iv: iv });\n\t * var ciphertextParams = CryptoJS.lib.SerializableCipher.encrypt(CryptoJS.algo.AES, message, key, { iv: iv, format: CryptoJS.format.OpenSSL });\n\t */\n\t encrypt: function (cipher, message, key, cfg) {\n\t // Apply config defaults\n\t cfg = this.cfg.extend(cfg);\n\n\t // Encrypt\n\t var encryptor = cipher.createEncryptor(key, cfg);\n\t var ciphertext = encryptor.finalize(message);\n\n\t // Shortcut\n\t var cipherCfg = encryptor.cfg;\n\n\t // Create and return serializable cipher params\n\t return CipherParams.create({\n\t ciphertext: ciphertext,\n\t key: key,\n\t iv: cipherCfg.iv,\n\t algorithm: cipher,\n\t mode: cipherCfg.mode,\n\t padding: cipherCfg.padding,\n\t blockSize: cipher.blockSize,\n\t formatter: cfg.format\n\t });\n\t },\n\n\t /**\n\t * Decrypts serialized ciphertext.\n\t *\n\t * @param {Cipher} cipher The cipher algorithm to use.\n\t * @param {CipherParams|string} ciphertext The ciphertext to decrypt.\n\t * @param {WordArray} key The key.\n\t * @param {Object} cfg (Optional) The configuration options to use for this operation.\n\t *\n\t * @return {WordArray} The plaintext.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var plaintext = CryptoJS.lib.SerializableCipher.decrypt(CryptoJS.algo.AES, formattedCiphertext, key, { iv: iv, format: CryptoJS.format.OpenSSL });\n\t * var plaintext = CryptoJS.lib.SerializableCipher.decrypt(CryptoJS.algo.AES, ciphertextParams, key, { iv: iv, format: CryptoJS.format.OpenSSL });\n\t */\n\t decrypt: function (cipher, ciphertext, key, cfg) {\n\t // Apply config defaults\n\t cfg = this.cfg.extend(cfg);\n\n\t // Convert string to CipherParams\n\t ciphertext = this._parse(ciphertext, cfg.format);\n\n\t // Decrypt\n\t var plaintext = cipher.createDecryptor(key, cfg).finalize(ciphertext.ciphertext);\n\n\t return plaintext;\n\t },\n\n\t /**\n\t * Converts serialized ciphertext to CipherParams,\n\t * else assumed CipherParams already and returns ciphertext unchanged.\n\t *\n\t * @param {CipherParams|string} ciphertext The ciphertext.\n\t * @param {Formatter} format The formatting strategy to use to parse serialized ciphertext.\n\t *\n\t * @return {CipherParams} The unserialized ciphertext.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var ciphertextParams = CryptoJS.lib.SerializableCipher._parse(ciphertextStringOrParams, format);\n\t */\n\t _parse: function (ciphertext, format) {\n\t if (typeof ciphertext == 'string') {\n\t return format.parse(ciphertext, this);\n\t } else {\n\t return ciphertext;\n\t }\n\t }\n\t });\n\n\t /**\n\t * Key derivation function namespace.\n\t */\n\t var C_kdf = C.kdf = {};\n\n\t /**\n\t * OpenSSL key derivation function.\n\t */\n\t var OpenSSLKdf = C_kdf.OpenSSL = {\n\t /**\n\t * Derives a key and IV from a password.\n\t *\n\t * @param {string} password The password to derive from.\n\t * @param {number} keySize The size in words of the key to generate.\n\t * @param {number} ivSize The size in words of the IV to generate.\n\t * @param {WordArray|string} salt (Optional) A 64-bit salt to use. If omitted, a salt will be generated randomly.\n\t *\n\t * @return {CipherParams} A cipher params object with the key, IV, and salt.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var derivedParams = CryptoJS.kdf.OpenSSL.execute('Password', 256/32, 128/32);\n\t * var derivedParams = CryptoJS.kdf.OpenSSL.execute('Password', 256/32, 128/32, 'saltsalt');\n\t */\n\t execute: function (password, keySize, ivSize, salt, hasher) {\n\t // Generate random salt\n\t if (!salt) {\n\t salt = WordArray.random(64/8);\n\t }\n\n\t // Derive key and IV\n\t if (!hasher) {\n\t var key = EvpKDF.create({ keySize: keySize + ivSize }).compute(password, salt);\n\t } else {\n\t var key = EvpKDF.create({ keySize: keySize + ivSize, hasher: hasher }).compute(password, salt);\n\t }\n\n\n\t // Separate key and IV\n\t var iv = WordArray.create(key.words.slice(keySize), ivSize * 4);\n\t key.sigBytes = keySize * 4;\n\n\t // Return params\n\t return CipherParams.create({ key: key, iv: iv, salt: salt });\n\t }\n\t };\n\n\t /**\n\t * A serializable cipher wrapper that derives the key from a password,\n\t * and returns ciphertext as a serializable cipher params object.\n\t */\n\t var PasswordBasedCipher = C_lib.PasswordBasedCipher = SerializableCipher.extend({\n\t /**\n\t * Configuration options.\n\t *\n\t * @property {KDF} kdf The key derivation function to use to generate a key and IV from a password. Default: OpenSSL\n\t */\n\t cfg: SerializableCipher.cfg.extend({\n\t kdf: OpenSSLKdf\n\t }),\n\n\t /**\n\t * Encrypts a message using a password.\n\t *\n\t * @param {Cipher} cipher The cipher algorithm to use.\n\t * @param {WordArray|string} message The message to encrypt.\n\t * @param {string} password The password.\n\t * @param {Object} cfg (Optional) The configuration options to use for this operation.\n\t *\n\t * @return {CipherParams} A cipher params object.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var ciphertextParams = CryptoJS.lib.PasswordBasedCipher.encrypt(CryptoJS.algo.AES, message, 'password');\n\t * var ciphertextParams = CryptoJS.lib.PasswordBasedCipher.encrypt(CryptoJS.algo.AES, message, 'password', { format: CryptoJS.format.OpenSSL });\n\t */\n\t encrypt: function (cipher, message, password, cfg) {\n\t // Apply config defaults\n\t cfg = this.cfg.extend(cfg);\n\n\t // Derive key and other params\n\t var derivedParams = cfg.kdf.execute(password, cipher.keySize, cipher.ivSize, cfg.salt, cfg.hasher);\n\n\t // Add IV to config\n\t cfg.iv = derivedParams.iv;\n\n\t // Encrypt\n\t var ciphertext = SerializableCipher.encrypt.call(this, cipher, message, derivedParams.key, cfg);\n\n\t // Mix in derived params\n\t ciphertext.mixIn(derivedParams);\n\n\t return ciphertext;\n\t },\n\n\t /**\n\t * Decrypts serialized ciphertext using a password.\n\t *\n\t * @param {Cipher} cipher The cipher algorithm to use.\n\t * @param {CipherParams|string} ciphertext The ciphertext to decrypt.\n\t * @param {string} password The password.\n\t * @param {Object} cfg (Optional) The configuration options to use for this operation.\n\t *\n\t * @return {WordArray} The plaintext.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var plaintext = CryptoJS.lib.PasswordBasedCipher.decrypt(CryptoJS.algo.AES, formattedCiphertext, 'password', { format: CryptoJS.format.OpenSSL });\n\t * var plaintext = CryptoJS.lib.PasswordBasedCipher.decrypt(CryptoJS.algo.AES, ciphertextParams, 'password', { format: CryptoJS.format.OpenSSL });\n\t */\n\t decrypt: function (cipher, ciphertext, password, cfg) {\n\t // Apply config defaults\n\t cfg = this.cfg.extend(cfg);\n\n\t // Convert string to CipherParams\n\t ciphertext = this._parse(ciphertext, cfg.format);\n\n\t // Derive key and other params\n\t var derivedParams = cfg.kdf.execute(password, cipher.keySize, cipher.ivSize, ciphertext.salt, cfg.hasher);\n\n\t // Add IV to config\n\t cfg.iv = derivedParams.iv;\n\n\t // Decrypt\n\t var plaintext = SerializableCipher.decrypt.call(this, cipher, ciphertext, derivedParams.key, cfg);\n\n\t return plaintext;\n\t }\n\t });\n\t}());\n\n\n}));",";(function (root, factory) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory();\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\troot.CryptoJS = factory();\n\t}\n}(this, function () {\n\n\t/*globals window, global, require*/\n\n\t/**\n\t * CryptoJS core components.\n\t */\n\tvar CryptoJS = CryptoJS || (function (Math, undefined) {\n\n\t var crypto;\n\n\t // Native crypto from window (Browser)\n\t if (typeof window !== 'undefined' && window.crypto) {\n\t crypto = window.crypto;\n\t }\n\n\t // Native crypto in web worker (Browser)\n\t if (typeof self !== 'undefined' && self.crypto) {\n\t crypto = self.crypto;\n\t }\n\n\t // Native crypto from worker\n\t if (typeof globalThis !== 'undefined' && globalThis.crypto) {\n\t crypto = globalThis.crypto;\n\t }\n\n\t // Native (experimental IE 11) crypto from window (Browser)\n\t if (!crypto && typeof window !== 'undefined' && window.msCrypto) {\n\t crypto = window.msCrypto;\n\t }\n\n\t // Native crypto from global (NodeJS)\n\t if (!crypto && typeof global !== 'undefined' && global.crypto) {\n\t crypto = global.crypto;\n\t }\n\n\t // Native crypto import via require (NodeJS)\n\t if (!crypto && typeof require === 'function') {\n\t try {\n\t crypto = require('crypto');\n\t } catch (err) {}\n\t }\n\n\t /*\n\t * Cryptographically secure pseudorandom number generator\n\t *\n\t * As Math.random() is cryptographically not safe to use\n\t */\n\t var cryptoSecureRandomInt = function () {\n\t if (crypto) {\n\t // Use getRandomValues method (Browser)\n\t if (typeof crypto.getRandomValues === 'function') {\n\t try {\n\t return crypto.getRandomValues(new Uint32Array(1))[0];\n\t } catch (err) {}\n\t }\n\n\t // Use randomBytes method (NodeJS)\n\t if (typeof crypto.randomBytes === 'function') {\n\t try {\n\t return crypto.randomBytes(4).readInt32LE();\n\t } catch (err) {}\n\t }\n\t }\n\n\t throw new Error('Native crypto module could not be used to get secure random number.');\n\t };\n\n\t /*\n\t * Local polyfill of Object.create\n\n\t */\n\t var create = Object.create || (function () {\n\t function F() {}\n\n\t return function (obj) {\n\t var subtype;\n\n\t F.prototype = obj;\n\n\t subtype = new F();\n\n\t F.prototype = null;\n\n\t return subtype;\n\t };\n\t }());\n\n\t /**\n\t * CryptoJS namespace.\n\t */\n\t var C = {};\n\n\t /**\n\t * Library namespace.\n\t */\n\t var C_lib = C.lib = {};\n\n\t /**\n\t * Base object for prototypal inheritance.\n\t */\n\t var Base = C_lib.Base = (function () {\n\n\n\t return {\n\t /**\n\t * Creates a new object that inherits from this object.\n\t *\n\t * @param {Object} overrides Properties to copy into the new object.\n\t *\n\t * @return {Object} The new object.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var MyType = CryptoJS.lib.Base.extend({\n\t * field: 'value',\n\t *\n\t * method: function () {\n\t * }\n\t * });\n\t */\n\t extend: function (overrides) {\n\t // Spawn\n\t var subtype = create(this);\n\n\t // Augment\n\t if (overrides) {\n\t subtype.mixIn(overrides);\n\t }\n\n\t // Create default initializer\n\t if (!subtype.hasOwnProperty('init') || this.init === subtype.init) {\n\t subtype.init = function () {\n\t subtype.$super.init.apply(this, arguments);\n\t };\n\t }\n\n\t // Initializer's prototype is the subtype object\n\t subtype.init.prototype = subtype;\n\n\t // Reference supertype\n\t subtype.$super = this;\n\n\t return subtype;\n\t },\n\n\t /**\n\t * Extends this object and runs the init method.\n\t * Arguments to create() will be passed to init().\n\t *\n\t * @return {Object} The new object.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var instance = MyType.create();\n\t */\n\t create: function () {\n\t var instance = this.extend();\n\t instance.init.apply(instance, arguments);\n\n\t return instance;\n\t },\n\n\t /**\n\t * Initializes a newly created object.\n\t * Override this method to add some logic when your objects are created.\n\t *\n\t * @example\n\t *\n\t * var MyType = CryptoJS.lib.Base.extend({\n\t * init: function () {\n\t * // ...\n\t * }\n\t * });\n\t */\n\t init: function () {\n\t },\n\n\t /**\n\t * Copies properties into this object.\n\t *\n\t * @param {Object} properties The properties to mix in.\n\t *\n\t * @example\n\t *\n\t * MyType.mixIn({\n\t * field: 'value'\n\t * });\n\t */\n\t mixIn: function (properties) {\n\t for (var propertyName in properties) {\n\t if (properties.hasOwnProperty(propertyName)) {\n\t this[propertyName] = properties[propertyName];\n\t }\n\t }\n\n\t // IE won't copy toString using the loop above\n\t if (properties.hasOwnProperty('toString')) {\n\t this.toString = properties.toString;\n\t }\n\t },\n\n\t /**\n\t * Creates a copy of this object.\n\t *\n\t * @return {Object} The clone.\n\t *\n\t * @example\n\t *\n\t * var clone = instance.clone();\n\t */\n\t clone: function () {\n\t return this.init.prototype.extend(this);\n\t }\n\t };\n\t }());\n\n\t /**\n\t * An array of 32-bit words.\n\t *\n\t * @property {Array} words The array of 32-bit words.\n\t * @property {number} sigBytes The number of significant bytes in this word array.\n\t */\n\t var WordArray = C_lib.WordArray = Base.extend({\n\t /**\n\t * Initializes a newly created word array.\n\t *\n\t * @param {Array} words (Optional) An array of 32-bit words.\n\t * @param {number} sigBytes (Optional) The number of significant bytes in the words.\n\t *\n\t * @example\n\t *\n\t * var wordArray = CryptoJS.lib.WordArray.create();\n\t * var wordArray = CryptoJS.lib.WordArray.create([0x00010203, 0x04050607]);\n\t * var wordArray = CryptoJS.lib.WordArray.create([0x00010203, 0x04050607], 6);\n\t */\n\t init: function (words, sigBytes) {\n\t words = this.words = words || [];\n\n\t if (sigBytes != undefined) {\n\t this.sigBytes = sigBytes;\n\t } else {\n\t this.sigBytes = words.length * 4;\n\t }\n\t },\n\n\t /**\n\t * Converts this word array to a string.\n\t *\n\t * @param {Encoder} encoder (Optional) The encoding strategy to use. Default: CryptoJS.enc.Hex\n\t *\n\t * @return {string} The stringified word array.\n\t *\n\t * @example\n\t *\n\t * var string = wordArray + '';\n\t * var string = wordArray.toString();\n\t * var string = wordArray.toString(CryptoJS.enc.Utf8);\n\t */\n\t toString: function (encoder) {\n\t return (encoder || Hex).stringify(this);\n\t },\n\n\t /**\n\t * Concatenates a word array to this word array.\n\t *\n\t * @param {WordArray} wordArray The word array to append.\n\t *\n\t * @return {WordArray} This word array.\n\t *\n\t * @example\n\t *\n\t * wordArray1.concat(wordArray2);\n\t */\n\t concat: function (wordArray) {\n\t // Shortcuts\n\t var thisWords = this.words;\n\t var thatWords = wordArray.words;\n\t var thisSigBytes = this.sigBytes;\n\t var thatSigBytes = wordArray.sigBytes;\n\n\t // Clamp excess bits\n\t this.clamp();\n\n\t // Concat\n\t if (thisSigBytes % 4) {\n\t // Copy one byte at a time\n\t for (var i = 0; i < thatSigBytes; i++) {\n\t var thatByte = (thatWords[i >>> 2] >>> (24 - (i % 4) * 8)) & 0xff;\n\t thisWords[(thisSigBytes + i) >>> 2] |= thatByte << (24 - ((thisSigBytes + i) % 4) * 8);\n\t }\n\t } else {\n\t // Copy one word at a time\n\t for (var j = 0; j < thatSigBytes; j += 4) {\n\t thisWords[(thisSigBytes + j) >>> 2] = thatWords[j >>> 2];\n\t }\n\t }\n\t this.sigBytes += thatSigBytes;\n\n\t // Chainable\n\t return this;\n\t },\n\n\t /**\n\t * Removes insignificant bits.\n\t *\n\t * @example\n\t *\n\t * wordArray.clamp();\n\t */\n\t clamp: function () {\n\t // Shortcuts\n\t var words = this.words;\n\t var sigBytes = this.sigBytes;\n\n\t // Clamp\n\t words[sigBytes >>> 2] &= 0xffffffff << (32 - (sigBytes % 4) * 8);\n\t words.length = Math.ceil(sigBytes / 4);\n\t },\n\n\t /**\n\t * Creates a copy of this word array.\n\t *\n\t * @return {WordArray} The clone.\n\t *\n\t * @example\n\t *\n\t * var clone = wordArray.clone();\n\t */\n\t clone: function () {\n\t var clone = Base.clone.call(this);\n\t clone.words = this.words.slice(0);\n\n\t return clone;\n\t },\n\n\t /**\n\t * Creates a word array filled with random bytes.\n\t *\n\t * @param {number} nBytes The number of random bytes to generate.\n\t *\n\t * @return {WordArray} The random word array.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var wordArray = CryptoJS.lib.WordArray.random(16);\n\t */\n\t random: function (nBytes) {\n\t var words = [];\n\n\t for (var i = 0; i < nBytes; i += 4) {\n\t words.push(cryptoSecureRandomInt());\n\t }\n\n\t return new WordArray.init(words, nBytes);\n\t }\n\t });\n\n\t /**\n\t * Encoder namespace.\n\t */\n\t var C_enc = C.enc = {};\n\n\t /**\n\t * Hex encoding strategy.\n\t */\n\t var Hex = C_enc.Hex = {\n\t /**\n\t * Converts a word array to a hex string.\n\t *\n\t * @param {WordArray} wordArray The word array.\n\t *\n\t * @return {string} The hex string.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hexString = CryptoJS.enc.Hex.stringify(wordArray);\n\t */\n\t stringify: function (wordArray) {\n\t // Shortcuts\n\t var words = wordArray.words;\n\t var sigBytes = wordArray.sigBytes;\n\n\t // Convert\n\t var hexChars = [];\n\t for (var i = 0; i < sigBytes; i++) {\n\t var bite = (words[i >>> 2] >>> (24 - (i % 4) * 8)) & 0xff;\n\t hexChars.push((bite >>> 4).toString(16));\n\t hexChars.push((bite & 0x0f).toString(16));\n\t }\n\n\t return hexChars.join('');\n\t },\n\n\t /**\n\t * Converts a hex string to a word array.\n\t *\n\t * @param {string} hexStr The hex string.\n\t *\n\t * @return {WordArray} The word array.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var wordArray = CryptoJS.enc.Hex.parse(hexString);\n\t */\n\t parse: function (hexStr) {\n\t // Shortcut\n\t var hexStrLength = hexStr.length;\n\n\t // Convert\n\t var words = [];\n\t for (var i = 0; i < hexStrLength; i += 2) {\n\t words[i >>> 3] |= parseInt(hexStr.substr(i, 2), 16) << (24 - (i % 8) * 4);\n\t }\n\n\t return new WordArray.init(words, hexStrLength / 2);\n\t }\n\t };\n\n\t /**\n\t * Latin1 encoding strategy.\n\t */\n\t var Latin1 = C_enc.Latin1 = {\n\t /**\n\t * Converts a word array to a Latin1 string.\n\t *\n\t * @param {WordArray} wordArray The word array.\n\t *\n\t * @return {string} The Latin1 string.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var latin1String = CryptoJS.enc.Latin1.stringify(wordArray);\n\t */\n\t stringify: function (wordArray) {\n\t // Shortcuts\n\t var words = wordArray.words;\n\t var sigBytes = wordArray.sigBytes;\n\n\t // Convert\n\t var latin1Chars = [];\n\t for (var i = 0; i < sigBytes; i++) {\n\t var bite = (words[i >>> 2] >>> (24 - (i % 4) * 8)) & 0xff;\n\t latin1Chars.push(String.fromCharCode(bite));\n\t }\n\n\t return latin1Chars.join('');\n\t },\n\n\t /**\n\t * Converts a Latin1 string to a word array.\n\t *\n\t * @param {string} latin1Str The Latin1 string.\n\t *\n\t * @return {WordArray} The word array.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var wordArray = CryptoJS.enc.Latin1.parse(latin1String);\n\t */\n\t parse: function (latin1Str) {\n\t // Shortcut\n\t var latin1StrLength = latin1Str.length;\n\n\t // Convert\n\t var words = [];\n\t for (var i = 0; i < latin1StrLength; i++) {\n\t words[i >>> 2] |= (latin1Str.charCodeAt(i) & 0xff) << (24 - (i % 4) * 8);\n\t }\n\n\t return new WordArray.init(words, latin1StrLength);\n\t }\n\t };\n\n\t /**\n\t * UTF-8 encoding strategy.\n\t */\n\t var Utf8 = C_enc.Utf8 = {\n\t /**\n\t * Converts a word array to a UTF-8 string.\n\t *\n\t * @param {WordArray} wordArray The word array.\n\t *\n\t * @return {string} The UTF-8 string.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var utf8String = CryptoJS.enc.Utf8.stringify(wordArray);\n\t */\n\t stringify: function (wordArray) {\n\t try {\n\t return decodeURIComponent(escape(Latin1.stringify(wordArray)));\n\t } catch (e) {\n\t throw new Error('Malformed UTF-8 data');\n\t }\n\t },\n\n\t /**\n\t * Converts a UTF-8 string to a word array.\n\t *\n\t * @param {string} utf8Str The UTF-8 string.\n\t *\n\t * @return {WordArray} The word array.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var wordArray = CryptoJS.enc.Utf8.parse(utf8String);\n\t */\n\t parse: function (utf8Str) {\n\t return Latin1.parse(unescape(encodeURIComponent(utf8Str)));\n\t }\n\t };\n\n\t /**\n\t * Abstract buffered block algorithm template.\n\t *\n\t * The property blockSize must be implemented in a concrete subtype.\n\t *\n\t * @property {number} _minBufferSize The number of blocks that should be kept unprocessed in the buffer. Default: 0\n\t */\n\t var BufferedBlockAlgorithm = C_lib.BufferedBlockAlgorithm = Base.extend({\n\t /**\n\t * Resets this block algorithm's data buffer to its initial state.\n\t *\n\t * @example\n\t *\n\t * bufferedBlockAlgorithm.reset();\n\t */\n\t reset: function () {\n\t // Initial values\n\t this._data = new WordArray.init();\n\t this._nDataBytes = 0;\n\t },\n\n\t /**\n\t * Adds new data to this block algorithm's buffer.\n\t *\n\t * @param {WordArray|string} data The data to append. Strings are converted to a WordArray using UTF-8.\n\t *\n\t * @example\n\t *\n\t * bufferedBlockAlgorithm._append('data');\n\t * bufferedBlockAlgorithm._append(wordArray);\n\t */\n\t _append: function (data) {\n\t // Convert string to WordArray, else assume WordArray already\n\t if (typeof data == 'string') {\n\t data = Utf8.parse(data);\n\t }\n\n\t // Append\n\t this._data.concat(data);\n\t this._nDataBytes += data.sigBytes;\n\t },\n\n\t /**\n\t * Processes available data blocks.\n\t *\n\t * This method invokes _doProcessBlock(offset), which must be implemented by a concrete subtype.\n\t *\n\t * @param {boolean} doFlush Whether all blocks and partial blocks should be processed.\n\t *\n\t * @return {WordArray} The processed data.\n\t *\n\t * @example\n\t *\n\t * var processedData = bufferedBlockAlgorithm._process();\n\t * var processedData = bufferedBlockAlgorithm._process(!!'flush');\n\t */\n\t _process: function (doFlush) {\n\t var processedWords;\n\n\t // Shortcuts\n\t var data = this._data;\n\t var dataWords = data.words;\n\t var dataSigBytes = data.sigBytes;\n\t var blockSize = this.blockSize;\n\t var blockSizeBytes = blockSize * 4;\n\n\t // Count blocks ready\n\t var nBlocksReady = dataSigBytes / blockSizeBytes;\n\t if (doFlush) {\n\t // Round up to include partial blocks\n\t nBlocksReady = Math.ceil(nBlocksReady);\n\t } else {\n\t // Round down to include only full blocks,\n\t // less the number of blocks that must remain in the buffer\n\t nBlocksReady = Math.max((nBlocksReady | 0) - this._minBufferSize, 0);\n\t }\n\n\t // Count words ready\n\t var nWordsReady = nBlocksReady * blockSize;\n\n\t // Count bytes ready\n\t var nBytesReady = Math.min(nWordsReady * 4, dataSigBytes);\n\n\t // Process blocks\n\t if (nWordsReady) {\n\t for (var offset = 0; offset < nWordsReady; offset += blockSize) {\n\t // Perform concrete-algorithm logic\n\t this._doProcessBlock(dataWords, offset);\n\t }\n\n\t // Remove processed words\n\t processedWords = dataWords.splice(0, nWordsReady);\n\t data.sigBytes -= nBytesReady;\n\t }\n\n\t // Return processed words\n\t return new WordArray.init(processedWords, nBytesReady);\n\t },\n\n\t /**\n\t * Creates a copy of this object.\n\t *\n\t * @return {Object} The clone.\n\t *\n\t * @example\n\t *\n\t * var clone = bufferedBlockAlgorithm.clone();\n\t */\n\t clone: function () {\n\t var clone = Base.clone.call(this);\n\t clone._data = this._data.clone();\n\n\t return clone;\n\t },\n\n\t _minBufferSize: 0\n\t });\n\n\t /**\n\t * Abstract hasher template.\n\t *\n\t * @property {number} blockSize The number of 32-bit words this hasher operates on. Default: 16 (512 bits)\n\t */\n\t var Hasher = C_lib.Hasher = BufferedBlockAlgorithm.extend({\n\t /**\n\t * Configuration options.\n\t */\n\t cfg: Base.extend(),\n\n\t /**\n\t * Initializes a newly created hasher.\n\t *\n\t * @param {Object} cfg (Optional) The configuration options to use for this hash computation.\n\t *\n\t * @example\n\t *\n\t * var hasher = CryptoJS.algo.SHA256.create();\n\t */\n\t init: function (cfg) {\n\t // Apply config defaults\n\t this.cfg = this.cfg.extend(cfg);\n\n\t // Set initial values\n\t this.reset();\n\t },\n\n\t /**\n\t * Resets this hasher to its initial state.\n\t *\n\t * @example\n\t *\n\t * hasher.reset();\n\t */\n\t reset: function () {\n\t // Reset data buffer\n\t BufferedBlockAlgorithm.reset.call(this);\n\n\t // Perform concrete-hasher logic\n\t this._doReset();\n\t },\n\n\t /**\n\t * Updates this hasher with a message.\n\t *\n\t * @param {WordArray|string} messageUpdate The message to append.\n\t *\n\t * @return {Hasher} This hasher.\n\t *\n\t * @example\n\t *\n\t * hasher.update('message');\n\t * hasher.update(wordArray);\n\t */\n\t update: function (messageUpdate) {\n\t // Append\n\t this._append(messageUpdate);\n\n\t // Update the hash\n\t this._process();\n\n\t // Chainable\n\t return this;\n\t },\n\n\t /**\n\t * Finalizes the hash computation.\n\t * Note that the finalize operation is effectively a destructive, read-once operation.\n\t *\n\t * @param {WordArray|string} messageUpdate (Optional) A final message update.\n\t *\n\t * @return {WordArray} The hash.\n\t *\n\t * @example\n\t *\n\t * var hash = hasher.finalize();\n\t * var hash = hasher.finalize('message');\n\t * var hash = hasher.finalize(wordArray);\n\t */\n\t finalize: function (messageUpdate) {\n\t // Final message update\n\t if (messageUpdate) {\n\t this._append(messageUpdate);\n\t }\n\n\t // Perform concrete-hasher logic\n\t var hash = this._doFinalize();\n\n\t return hash;\n\t },\n\n\t blockSize: 512/32,\n\n\t /**\n\t * Creates a shortcut function to a hasher's object interface.\n\t *\n\t * @param {Hasher} hasher The hasher to create a helper for.\n\t *\n\t * @return {Function} The shortcut function.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var SHA256 = CryptoJS.lib.Hasher._createHelper(CryptoJS.algo.SHA256);\n\t */\n\t _createHelper: function (hasher) {\n\t return function (message, cfg) {\n\t return new hasher.init(cfg).finalize(message);\n\t };\n\t },\n\n\t /**\n\t * Creates a shortcut function to the HMAC's object interface.\n\t *\n\t * @param {Hasher} hasher The hasher to use in this HMAC helper.\n\t *\n\t * @return {Function} The shortcut function.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var HmacSHA256 = CryptoJS.lib.Hasher._createHmacHelper(CryptoJS.algo.SHA256);\n\t */\n\t _createHmacHelper: function (hasher) {\n\t return function (message, key) {\n\t return new C_algo.HMAC.init(hasher, key).finalize(message);\n\t };\n\t }\n\t });\n\n\t /**\n\t * Algorithm namespace.\n\t */\n\t var C_algo = C.algo = {};\n\n\t return C;\n\t}(Math));\n\n\n\treturn CryptoJS;\n\n}));",";(function (root, factory) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function () {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var WordArray = C_lib.WordArray;\n\t var C_enc = C.enc;\n\n\t /**\n\t * Base64 encoding strategy.\n\t */\n\t var Base64 = C_enc.Base64 = {\n\t /**\n\t * Converts a word array to a Base64 string.\n\t *\n\t * @param {WordArray} wordArray The word array.\n\t *\n\t * @return {string} The Base64 string.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var base64String = CryptoJS.enc.Base64.stringify(wordArray);\n\t */\n\t stringify: function (wordArray) {\n\t // Shortcuts\n\t var words = wordArray.words;\n\t var sigBytes = wordArray.sigBytes;\n\t var map = this._map;\n\n\t // Clamp excess bits\n\t wordArray.clamp();\n\n\t // Convert\n\t var base64Chars = [];\n\t for (var i = 0; i < sigBytes; i += 3) {\n\t var byte1 = (words[i >>> 2] >>> (24 - (i % 4) * 8)) & 0xff;\n\t var byte2 = (words[(i + 1) >>> 2] >>> (24 - ((i + 1) % 4) * 8)) & 0xff;\n\t var byte3 = (words[(i + 2) >>> 2] >>> (24 - ((i + 2) % 4) * 8)) & 0xff;\n\n\t var triplet = (byte1 << 16) | (byte2 << 8) | byte3;\n\n\t for (var j = 0; (j < 4) && (i + j * 0.75 < sigBytes); j++) {\n\t base64Chars.push(map.charAt((triplet >>> (6 * (3 - j))) & 0x3f));\n\t }\n\t }\n\n\t // Add padding\n\t var paddingChar = map.charAt(64);\n\t if (paddingChar) {\n\t while (base64Chars.length % 4) {\n\t base64Chars.push(paddingChar);\n\t }\n\t }\n\n\t return base64Chars.join('');\n\t },\n\n\t /**\n\t * Converts a Base64 string to a word array.\n\t *\n\t * @param {string} base64Str The Base64 string.\n\t *\n\t * @return {WordArray} The word array.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var wordArray = CryptoJS.enc.Base64.parse(base64String);\n\t */\n\t parse: function (base64Str) {\n\t // Shortcuts\n\t var base64StrLength = base64Str.length;\n\t var map = this._map;\n\t var reverseMap = this._reverseMap;\n\n\t if (!reverseMap) {\n\t reverseMap = this._reverseMap = [];\n\t for (var j = 0; j < map.length; j++) {\n\t reverseMap[map.charCodeAt(j)] = j;\n\t }\n\t }\n\n\t // Ignore padding\n\t var paddingChar = map.charAt(64);\n\t if (paddingChar) {\n\t var paddingIndex = base64Str.indexOf(paddingChar);\n\t if (paddingIndex !== -1) {\n\t base64StrLength = paddingIndex;\n\t }\n\t }\n\n\t // Convert\n\t return parseLoop(base64Str, base64StrLength, reverseMap);\n\n\t },\n\n\t _map: 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/='\n\t };\n\n\t function parseLoop(base64Str, base64StrLength, reverseMap) {\n\t var words = [];\n\t var nBytes = 0;\n\t for (var i = 0; i < base64StrLength; i++) {\n\t if (i % 4) {\n\t var bits1 = reverseMap[base64Str.charCodeAt(i - 1)] << ((i % 4) * 2);\n\t var bits2 = reverseMap[base64Str.charCodeAt(i)] >>> (6 - (i % 4) * 2);\n\t var bitsCombined = bits1 | bits2;\n\t words[nBytes >>> 2] |= bitsCombined << (24 - (nBytes % 4) * 8);\n\t nBytes++;\n\t }\n\t }\n\t return WordArray.create(words, nBytes);\n\t }\n\t}());\n\n\n\treturn CryptoJS.enc.Base64;\n\n}));",";(function (root, factory) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function () {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var WordArray = C_lib.WordArray;\n\t var C_enc = C.enc;\n\n\t /**\n\t * Base64url encoding strategy.\n\t */\n\t var Base64url = C_enc.Base64url = {\n\t /**\n\t * Converts a word array to a Base64url string.\n\t *\n\t * @param {WordArray} wordArray The word array.\n\t *\n\t * @param {boolean} urlSafe Whether to use url safe\n\t *\n\t * @return {string} The Base64url string.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var base64String = CryptoJS.enc.Base64url.stringify(wordArray);\n\t */\n\t stringify: function (wordArray, urlSafe) {\n\t if (urlSafe === undefined) {\n\t urlSafe = true\n\t }\n\t // Shortcuts\n\t var words = wordArray.words;\n\t var sigBytes = wordArray.sigBytes;\n\t var map = urlSafe ? this._safe_map : this._map;\n\n\t // Clamp excess bits\n\t wordArray.clamp();\n\n\t // Convert\n\t var base64Chars = [];\n\t for (var i = 0; i < sigBytes; i += 3) {\n\t var byte1 = (words[i >>> 2] >>> (24 - (i % 4) * 8)) & 0xff;\n\t var byte2 = (words[(i + 1) >>> 2] >>> (24 - ((i + 1) % 4) * 8)) & 0xff;\n\t var byte3 = (words[(i + 2) >>> 2] >>> (24 - ((i + 2) % 4) * 8)) & 0xff;\n\n\t var triplet = (byte1 << 16) | (byte2 << 8) | byte3;\n\n\t for (var j = 0; (j < 4) && (i + j * 0.75 < sigBytes); j++) {\n\t base64Chars.push(map.charAt((triplet >>> (6 * (3 - j))) & 0x3f));\n\t }\n\t }\n\n\t // Add padding\n\t var paddingChar = map.charAt(64);\n\t if (paddingChar) {\n\t while (base64Chars.length % 4) {\n\t base64Chars.push(paddingChar);\n\t }\n\t }\n\n\t return base64Chars.join('');\n\t },\n\n\t /**\n\t * Converts a Base64url string to a word array.\n\t *\n\t * @param {string} base64Str The Base64url string.\n\t *\n\t * @param {boolean} urlSafe Whether to use url safe\n\t *\n\t * @return {WordArray} The word array.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var wordArray = CryptoJS.enc.Base64url.parse(base64String);\n\t */\n\t parse: function (base64Str, urlSafe) {\n\t if (urlSafe === undefined) {\n\t urlSafe = true\n\t }\n\n\t // Shortcuts\n\t var base64StrLength = base64Str.length;\n\t var map = urlSafe ? this._safe_map : this._map;\n\t var reverseMap = this._reverseMap;\n\n\t if (!reverseMap) {\n\t reverseMap = this._reverseMap = [];\n\t for (var j = 0; j < map.length; j++) {\n\t reverseMap[map.charCodeAt(j)] = j;\n\t }\n\t }\n\n\t // Ignore padding\n\t var paddingChar = map.charAt(64);\n\t if (paddingChar) {\n\t var paddingIndex = base64Str.indexOf(paddingChar);\n\t if (paddingIndex !== -1) {\n\t base64StrLength = paddingIndex;\n\t }\n\t }\n\n\t // Convert\n\t return parseLoop(base64Str, base64StrLength, reverseMap);\n\n\t },\n\n\t _map: 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=',\n\t _safe_map: 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_',\n\t };\n\n\t function parseLoop(base64Str, base64StrLength, reverseMap) {\n\t var words = [];\n\t var nBytes = 0;\n\t for (var i = 0; i < base64StrLength; i++) {\n\t if (i % 4) {\n\t var bits1 = reverseMap[base64Str.charCodeAt(i - 1)] << ((i % 4) * 2);\n\t var bits2 = reverseMap[base64Str.charCodeAt(i)] >>> (6 - (i % 4) * 2);\n\t var bitsCombined = bits1 | bits2;\n\t words[nBytes >>> 2] |= bitsCombined << (24 - (nBytes % 4) * 8);\n\t nBytes++;\n\t }\n\t }\n\t return WordArray.create(words, nBytes);\n\t }\n\t}());\n\n\n\treturn CryptoJS.enc.Base64url;\n\n}));",";(function (root, factory) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function () {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var WordArray = C_lib.WordArray;\n\t var C_enc = C.enc;\n\n\t /**\n\t * UTF-16 BE encoding strategy.\n\t */\n\t var Utf16BE = C_enc.Utf16 = C_enc.Utf16BE = {\n\t /**\n\t * Converts a word array to a UTF-16 BE string.\n\t *\n\t * @param {WordArray} wordArray The word array.\n\t *\n\t * @return {string} The UTF-16 BE string.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var utf16String = CryptoJS.enc.Utf16.stringify(wordArray);\n\t */\n\t stringify: function (wordArray) {\n\t // Shortcuts\n\t var words = wordArray.words;\n\t var sigBytes = wordArray.sigBytes;\n\n\t // Convert\n\t var utf16Chars = [];\n\t for (var i = 0; i < sigBytes; i += 2) {\n\t var codePoint = (words[i >>> 2] >>> (16 - (i % 4) * 8)) & 0xffff;\n\t utf16Chars.push(String.fromCharCode(codePoint));\n\t }\n\n\t return utf16Chars.join('');\n\t },\n\n\t /**\n\t * Converts a UTF-16 BE string to a word array.\n\t *\n\t * @param {string} utf16Str The UTF-16 BE string.\n\t *\n\t * @return {WordArray} The word array.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var wordArray = CryptoJS.enc.Utf16.parse(utf16String);\n\t */\n\t parse: function (utf16Str) {\n\t // Shortcut\n\t var utf16StrLength = utf16Str.length;\n\n\t // Convert\n\t var words = [];\n\t for (var i = 0; i < utf16StrLength; i++) {\n\t words[i >>> 1] |= utf16Str.charCodeAt(i) << (16 - (i % 2) * 16);\n\t }\n\n\t return WordArray.create(words, utf16StrLength * 2);\n\t }\n\t };\n\n\t /**\n\t * UTF-16 LE encoding strategy.\n\t */\n\t C_enc.Utf16LE = {\n\t /**\n\t * Converts a word array to a UTF-16 LE string.\n\t *\n\t * @param {WordArray} wordArray The word array.\n\t *\n\t * @return {string} The UTF-16 LE string.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var utf16Str = CryptoJS.enc.Utf16LE.stringify(wordArray);\n\t */\n\t stringify: function (wordArray) {\n\t // Shortcuts\n\t var words = wordArray.words;\n\t var sigBytes = wordArray.sigBytes;\n\n\t // Convert\n\t var utf16Chars = [];\n\t for (var i = 0; i < sigBytes; i += 2) {\n\t var codePoint = swapEndian((words[i >>> 2] >>> (16 - (i % 4) * 8)) & 0xffff);\n\t utf16Chars.push(String.fromCharCode(codePoint));\n\t }\n\n\t return utf16Chars.join('');\n\t },\n\n\t /**\n\t * Converts a UTF-16 LE string to a word array.\n\t *\n\t * @param {string} utf16Str The UTF-16 LE string.\n\t *\n\t * @return {WordArray} The word array.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var wordArray = CryptoJS.enc.Utf16LE.parse(utf16Str);\n\t */\n\t parse: function (utf16Str) {\n\t // Shortcut\n\t var utf16StrLength = utf16Str.length;\n\n\t // Convert\n\t var words = [];\n\t for (var i = 0; i < utf16StrLength; i++) {\n\t words[i >>> 1] |= swapEndian(utf16Str.charCodeAt(i) << (16 - (i % 2) * 16));\n\t }\n\n\t return WordArray.create(words, utf16StrLength * 2);\n\t }\n\t };\n\n\t function swapEndian(word) {\n\t return ((word << 8) & 0xff00ff00) | ((word >>> 8) & 0x00ff00ff);\n\t }\n\t}());\n\n\n\treturn CryptoJS.enc.Utf16;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./sha1\"), require(\"./hmac\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./sha1\", \"./hmac\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function () {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var Base = C_lib.Base;\n\t var WordArray = C_lib.WordArray;\n\t var C_algo = C.algo;\n\t var MD5 = C_algo.MD5;\n\n\t /**\n\t * This key derivation function is meant to conform with EVP_BytesToKey.\n\t * www.openssl.org/docs/crypto/EVP_BytesToKey.html\n\t */\n\t var EvpKDF = C_algo.EvpKDF = Base.extend({\n\t /**\n\t * Configuration options.\n\t *\n\t * @property {number} keySize The key size in words to generate. Default: 4 (128 bits)\n\t * @property {Hasher} hasher The hash algorithm to use. Default: MD5\n\t * @property {number} iterations The number of iterations to perform. Default: 1\n\t */\n\t cfg: Base.extend({\n\t keySize: 128/32,\n\t hasher: MD5,\n\t iterations: 1\n\t }),\n\n\t /**\n\t * Initializes a newly created key derivation function.\n\t *\n\t * @param {Object} cfg (Optional) The configuration options to use for the derivation.\n\t *\n\t * @example\n\t *\n\t * var kdf = CryptoJS.algo.EvpKDF.create();\n\t * var kdf = CryptoJS.algo.EvpKDF.create({ keySize: 8 });\n\t * var kdf = CryptoJS.algo.EvpKDF.create({ keySize: 8, iterations: 1000 });\n\t */\n\t init: function (cfg) {\n\t this.cfg = this.cfg.extend(cfg);\n\t },\n\n\t /**\n\t * Derives a key from a password.\n\t *\n\t * @param {WordArray|string} password The password.\n\t * @param {WordArray|string} salt A salt.\n\t *\n\t * @return {WordArray} The derived key.\n\t *\n\t * @example\n\t *\n\t * var key = kdf.compute(password, salt);\n\t */\n\t compute: function (password, salt) {\n\t var block;\n\n\t // Shortcut\n\t var cfg = this.cfg;\n\n\t // Init hasher\n\t var hasher = cfg.hasher.create();\n\n\t // Initial values\n\t var derivedKey = WordArray.create();\n\n\t // Shortcuts\n\t var derivedKeyWords = derivedKey.words;\n\t var keySize = cfg.keySize;\n\t var iterations = cfg.iterations;\n\n\t // Generate key\n\t while (derivedKeyWords.length < keySize) {\n\t if (block) {\n\t hasher.update(block);\n\t }\n\t block = hasher.update(password).finalize(salt);\n\t hasher.reset();\n\n\t // Iterations\n\t for (var i = 1; i < iterations; i++) {\n\t block = hasher.finalize(block);\n\t hasher.reset();\n\t }\n\n\t derivedKey.concat(block);\n\t }\n\t derivedKey.sigBytes = keySize * 4;\n\n\t return derivedKey;\n\t }\n\t });\n\n\t /**\n\t * Derives a key from a password.\n\t *\n\t * @param {WordArray|string} password The password.\n\t * @param {WordArray|string} salt A salt.\n\t * @param {Object} cfg (Optional) The configuration options to use for this computation.\n\t *\n\t * @return {WordArray} The derived key.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var key = CryptoJS.EvpKDF(password, salt);\n\t * var key = CryptoJS.EvpKDF(password, salt, { keySize: 8 });\n\t * var key = CryptoJS.EvpKDF(password, salt, { keySize: 8, iterations: 1000 });\n\t */\n\t C.EvpKDF = function (password, salt, cfg) {\n\t return EvpKDF.create(cfg).compute(password, salt);\n\t };\n\t}());\n\n\n\treturn CryptoJS.EvpKDF;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./cipher-core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./cipher-core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function (undefined) {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var CipherParams = C_lib.CipherParams;\n\t var C_enc = C.enc;\n\t var Hex = C_enc.Hex;\n\t var C_format = C.format;\n\n\t var HexFormatter = C_format.Hex = {\n\t /**\n\t * Converts the ciphertext of a cipher params object to a hexadecimally encoded string.\n\t *\n\t * @param {CipherParams} cipherParams The cipher params object.\n\t *\n\t * @return {string} The hexadecimally encoded string.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hexString = CryptoJS.format.Hex.stringify(cipherParams);\n\t */\n\t stringify: function (cipherParams) {\n\t return cipherParams.ciphertext.toString(Hex);\n\t },\n\n\t /**\n\t * Converts a hexadecimally encoded ciphertext string to a cipher params object.\n\t *\n\t * @param {string} input The hexadecimally encoded string.\n\t *\n\t * @return {CipherParams} The cipher params object.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var cipherParams = CryptoJS.format.Hex.parse(hexString);\n\t */\n\t parse: function (input) {\n\t var ciphertext = Hex.parse(input);\n\t return CipherParams.create({ ciphertext: ciphertext });\n\t }\n\t };\n\t}());\n\n\n\treturn CryptoJS.format.Hex;\n\n}));",";(function (root, factory) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function () {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var Base = C_lib.Base;\n\t var C_enc = C.enc;\n\t var Utf8 = C_enc.Utf8;\n\t var C_algo = C.algo;\n\n\t /**\n\t * HMAC algorithm.\n\t */\n\t var HMAC = C_algo.HMAC = Base.extend({\n\t /**\n\t * Initializes a newly created HMAC.\n\t *\n\t * @param {Hasher} hasher The hash algorithm to use.\n\t * @param {WordArray|string} key The secret key.\n\t *\n\t * @example\n\t *\n\t * var hmacHasher = CryptoJS.algo.HMAC.create(CryptoJS.algo.SHA256, key);\n\t */\n\t init: function (hasher, key) {\n\t // Init hasher\n\t hasher = this._hasher = new hasher.init();\n\n\t // Convert string to WordArray, else assume WordArray already\n\t if (typeof key == 'string') {\n\t key = Utf8.parse(key);\n\t }\n\n\t // Shortcuts\n\t var hasherBlockSize = hasher.blockSize;\n\t var hasherBlockSizeBytes = hasherBlockSize * 4;\n\n\t // Allow arbitrary length keys\n\t if (key.sigBytes > hasherBlockSizeBytes) {\n\t key = hasher.finalize(key);\n\t }\n\n\t // Clamp excess bits\n\t key.clamp();\n\n\t // Clone key for inner and outer pads\n\t var oKey = this._oKey = key.clone();\n\t var iKey = this._iKey = key.clone();\n\n\t // Shortcuts\n\t var oKeyWords = oKey.words;\n\t var iKeyWords = iKey.words;\n\n\t // XOR keys with pad constants\n\t for (var i = 0; i < hasherBlockSize; i++) {\n\t oKeyWords[i] ^= 0x5c5c5c5c;\n\t iKeyWords[i] ^= 0x36363636;\n\t }\n\t oKey.sigBytes = iKey.sigBytes = hasherBlockSizeBytes;\n\n\t // Set initial values\n\t this.reset();\n\t },\n\n\t /**\n\t * Resets this HMAC to its initial state.\n\t *\n\t * @example\n\t *\n\t * hmacHasher.reset();\n\t */\n\t reset: function () {\n\t // Shortcut\n\t var hasher = this._hasher;\n\n\t // Reset\n\t hasher.reset();\n\t hasher.update(this._iKey);\n\t },\n\n\t /**\n\t * Updates this HMAC with a message.\n\t *\n\t * @param {WordArray|string} messageUpdate The message to append.\n\t *\n\t * @return {HMAC} This HMAC instance.\n\t *\n\t * @example\n\t *\n\t * hmacHasher.update('message');\n\t * hmacHasher.update(wordArray);\n\t */\n\t update: function (messageUpdate) {\n\t this._hasher.update(messageUpdate);\n\n\t // Chainable\n\t return this;\n\t },\n\n\t /**\n\t * Finalizes the HMAC computation.\n\t * Note that the finalize operation is effectively a destructive, read-once operation.\n\t *\n\t * @param {WordArray|string} messageUpdate (Optional) A final message update.\n\t *\n\t * @return {WordArray} The HMAC.\n\t *\n\t * @example\n\t *\n\t * var hmac = hmacHasher.finalize();\n\t * var hmac = hmacHasher.finalize('message');\n\t * var hmac = hmacHasher.finalize(wordArray);\n\t */\n\t finalize: function (messageUpdate) {\n\t // Shortcut\n\t var hasher = this._hasher;\n\n\t // Compute HMAC\n\t var innerHash = hasher.finalize(messageUpdate);\n\t hasher.reset();\n\t var hmac = hasher.finalize(this._oKey.clone().concat(innerHash));\n\n\t return hmac;\n\t }\n\t });\n\t}());\n\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./x64-core\"), require(\"./lib-typedarrays\"), require(\"./enc-utf16\"), require(\"./enc-base64\"), require(\"./enc-base64url\"), require(\"./md5\"), require(\"./sha1\"), require(\"./sha256\"), require(\"./sha224\"), require(\"./sha512\"), require(\"./sha384\"), require(\"./sha3\"), require(\"./ripemd160\"), require(\"./hmac\"), require(\"./pbkdf2\"), require(\"./evpkdf\"), require(\"./cipher-core\"), require(\"./mode-cfb\"), require(\"./mode-ctr\"), require(\"./mode-ctr-gladman\"), require(\"./mode-ofb\"), require(\"./mode-ecb\"), require(\"./pad-ansix923\"), require(\"./pad-iso10126\"), require(\"./pad-iso97971\"), require(\"./pad-zeropadding\"), require(\"./pad-nopadding\"), require(\"./format-hex\"), require(\"./aes\"), require(\"./tripledes\"), require(\"./rc4\"), require(\"./rabbit\"), require(\"./rabbit-legacy\"), require(\"./blowfish\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./x64-core\", \"./lib-typedarrays\", \"./enc-utf16\", \"./enc-base64\", \"./enc-base64url\", \"./md5\", \"./sha1\", \"./sha256\", \"./sha224\", \"./sha512\", \"./sha384\", \"./sha3\", \"./ripemd160\", \"./hmac\", \"./pbkdf2\", \"./evpkdf\", \"./cipher-core\", \"./mode-cfb\", \"./mode-ctr\", \"./mode-ctr-gladman\", \"./mode-ofb\", \"./mode-ecb\", \"./pad-ansix923\", \"./pad-iso10126\", \"./pad-iso97971\", \"./pad-zeropadding\", \"./pad-nopadding\", \"./format-hex\", \"./aes\", \"./tripledes\", \"./rc4\", \"./rabbit\", \"./rabbit-legacy\", \"./blowfish\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\troot.CryptoJS = factory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\treturn CryptoJS;\n\n}));",";(function (root, factory) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function () {\n\t // Check if typed arrays are supported\n\t if (typeof ArrayBuffer != 'function') {\n\t return;\n\t }\n\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var WordArray = C_lib.WordArray;\n\n\t // Reference original init\n\t var superInit = WordArray.init;\n\n\t // Augment WordArray.init to handle typed arrays\n\t var subInit = WordArray.init = function (typedArray) {\n\t // Convert buffers to uint8\n\t if (typedArray instanceof ArrayBuffer) {\n\t typedArray = new Uint8Array(typedArray);\n\t }\n\n\t // Convert other array views to uint8\n\t if (\n\t typedArray instanceof Int8Array ||\n\t (typeof Uint8ClampedArray !== \"undefined\" && typedArray instanceof Uint8ClampedArray) ||\n\t typedArray instanceof Int16Array ||\n\t typedArray instanceof Uint16Array ||\n\t typedArray instanceof Int32Array ||\n\t typedArray instanceof Uint32Array ||\n\t typedArray instanceof Float32Array ||\n\t typedArray instanceof Float64Array\n\t ) {\n\t typedArray = new Uint8Array(typedArray.buffer, typedArray.byteOffset, typedArray.byteLength);\n\t }\n\n\t // Handle Uint8Array\n\t if (typedArray instanceof Uint8Array) {\n\t // Shortcut\n\t var typedArrayByteLength = typedArray.byteLength;\n\n\t // Extract bytes\n\t var words = [];\n\t for (var i = 0; i < typedArrayByteLength; i++) {\n\t words[i >>> 2] |= typedArray[i] << (24 - (i % 4) * 8);\n\t }\n\n\t // Initialize this word array\n\t superInit.call(this, words, typedArrayByteLength);\n\t } else {\n\t // Else call normal init\n\t superInit.apply(this, arguments);\n\t }\n\t };\n\n\t subInit.prototype = WordArray;\n\t}());\n\n\n\treturn CryptoJS.lib.WordArray;\n\n}));",";(function (root, factory) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function (Math) {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var WordArray = C_lib.WordArray;\n\t var Hasher = C_lib.Hasher;\n\t var C_algo = C.algo;\n\n\t // Constants table\n\t var T = [];\n\n\t // Compute constants\n\t (function () {\n\t for (var i = 0; i < 64; i++) {\n\t T[i] = (Math.abs(Math.sin(i + 1)) * 0x100000000) | 0;\n\t }\n\t }());\n\n\t /**\n\t * MD5 hash algorithm.\n\t */\n\t var MD5 = C_algo.MD5 = Hasher.extend({\n\t _doReset: function () {\n\t this._hash = new WordArray.init([\n\t 0x67452301, 0xefcdab89,\n\t 0x98badcfe, 0x10325476\n\t ]);\n\t },\n\n\t _doProcessBlock: function (M, offset) {\n\t // Swap endian\n\t for (var i = 0; i < 16; i++) {\n\t // Shortcuts\n\t var offset_i = offset + i;\n\t var M_offset_i = M[offset_i];\n\n\t M[offset_i] = (\n\t (((M_offset_i << 8) | (M_offset_i >>> 24)) & 0x00ff00ff) |\n\t (((M_offset_i << 24) | (M_offset_i >>> 8)) & 0xff00ff00)\n\t );\n\t }\n\n\t // Shortcuts\n\t var H = this._hash.words;\n\n\t var M_offset_0 = M[offset + 0];\n\t var M_offset_1 = M[offset + 1];\n\t var M_offset_2 = M[offset + 2];\n\t var M_offset_3 = M[offset + 3];\n\t var M_offset_4 = M[offset + 4];\n\t var M_offset_5 = M[offset + 5];\n\t var M_offset_6 = M[offset + 6];\n\t var M_offset_7 = M[offset + 7];\n\t var M_offset_8 = M[offset + 8];\n\t var M_offset_9 = M[offset + 9];\n\t var M_offset_10 = M[offset + 10];\n\t var M_offset_11 = M[offset + 11];\n\t var M_offset_12 = M[offset + 12];\n\t var M_offset_13 = M[offset + 13];\n\t var M_offset_14 = M[offset + 14];\n\t var M_offset_15 = M[offset + 15];\n\n\t // Working variables\n\t var a = H[0];\n\t var b = H[1];\n\t var c = H[2];\n\t var d = H[3];\n\n\t // Computation\n\t a = FF(a, b, c, d, M_offset_0, 7, T[0]);\n\t d = FF(d, a, b, c, M_offset_1, 12, T[1]);\n\t c = FF(c, d, a, b, M_offset_2, 17, T[2]);\n\t b = FF(b, c, d, a, M_offset_3, 22, T[3]);\n\t a = FF(a, b, c, d, M_offset_4, 7, T[4]);\n\t d = FF(d, a, b, c, M_offset_5, 12, T[5]);\n\t c = FF(c, d, a, b, M_offset_6, 17, T[6]);\n\t b = FF(b, c, d, a, M_offset_7, 22, T[7]);\n\t a = FF(a, b, c, d, M_offset_8, 7, T[8]);\n\t d = FF(d, a, b, c, M_offset_9, 12, T[9]);\n\t c = FF(c, d, a, b, M_offset_10, 17, T[10]);\n\t b = FF(b, c, d, a, M_offset_11, 22, T[11]);\n\t a = FF(a, b, c, d, M_offset_12, 7, T[12]);\n\t d = FF(d, a, b, c, M_offset_13, 12, T[13]);\n\t c = FF(c, d, a, b, M_offset_14, 17, T[14]);\n\t b = FF(b, c, d, a, M_offset_15, 22, T[15]);\n\n\t a = GG(a, b, c, d, M_offset_1, 5, T[16]);\n\t d = GG(d, a, b, c, M_offset_6, 9, T[17]);\n\t c = GG(c, d, a, b, M_offset_11, 14, T[18]);\n\t b = GG(b, c, d, a, M_offset_0, 20, T[19]);\n\t a = GG(a, b, c, d, M_offset_5, 5, T[20]);\n\t d = GG(d, a, b, c, M_offset_10, 9, T[21]);\n\t c = GG(c, d, a, b, M_offset_15, 14, T[22]);\n\t b = GG(b, c, d, a, M_offset_4, 20, T[23]);\n\t a = GG(a, b, c, d, M_offset_9, 5, T[24]);\n\t d = GG(d, a, b, c, M_offset_14, 9, T[25]);\n\t c = GG(c, d, a, b, M_offset_3, 14, T[26]);\n\t b = GG(b, c, d, a, M_offset_8, 20, T[27]);\n\t a = GG(a, b, c, d, M_offset_13, 5, T[28]);\n\t d = GG(d, a, b, c, M_offset_2, 9, T[29]);\n\t c = GG(c, d, a, b, M_offset_7, 14, T[30]);\n\t b = GG(b, c, d, a, M_offset_12, 20, T[31]);\n\n\t a = HH(a, b, c, d, M_offset_5, 4, T[32]);\n\t d = HH(d, a, b, c, M_offset_8, 11, T[33]);\n\t c = HH(c, d, a, b, M_offset_11, 16, T[34]);\n\t b = HH(b, c, d, a, M_offset_14, 23, T[35]);\n\t a = HH(a, b, c, d, M_offset_1, 4, T[36]);\n\t d = HH(d, a, b, c, M_offset_4, 11, T[37]);\n\t c = HH(c, d, a, b, M_offset_7, 16, T[38]);\n\t b = HH(b, c, d, a, M_offset_10, 23, T[39]);\n\t a = HH(a, b, c, d, M_offset_13, 4, T[40]);\n\t d = HH(d, a, b, c, M_offset_0, 11, T[41]);\n\t c = HH(c, d, a, b, M_offset_3, 16, T[42]);\n\t b = HH(b, c, d, a, M_offset_6, 23, T[43]);\n\t a = HH(a, b, c, d, M_offset_9, 4, T[44]);\n\t d = HH(d, a, b, c, M_offset_12, 11, T[45]);\n\t c = HH(c, d, a, b, M_offset_15, 16, T[46]);\n\t b = HH(b, c, d, a, M_offset_2, 23, T[47]);\n\n\t a = II(a, b, c, d, M_offset_0, 6, T[48]);\n\t d = II(d, a, b, c, M_offset_7, 10, T[49]);\n\t c = II(c, d, a, b, M_offset_14, 15, T[50]);\n\t b = II(b, c, d, a, M_offset_5, 21, T[51]);\n\t a = II(a, b, c, d, M_offset_12, 6, T[52]);\n\t d = II(d, a, b, c, M_offset_3, 10, T[53]);\n\t c = II(c, d, a, b, M_offset_10, 15, T[54]);\n\t b = II(b, c, d, a, M_offset_1, 21, T[55]);\n\t a = II(a, b, c, d, M_offset_8, 6, T[56]);\n\t d = II(d, a, b, c, M_offset_15, 10, T[57]);\n\t c = II(c, d, a, b, M_offset_6, 15, T[58]);\n\t b = II(b, c, d, a, M_offset_13, 21, T[59]);\n\t a = II(a, b, c, d, M_offset_4, 6, T[60]);\n\t d = II(d, a, b, c, M_offset_11, 10, T[61]);\n\t c = II(c, d, a, b, M_offset_2, 15, T[62]);\n\t b = II(b, c, d, a, M_offset_9, 21, T[63]);\n\n\t // Intermediate hash value\n\t H[0] = (H[0] + a) | 0;\n\t H[1] = (H[1] + b) | 0;\n\t H[2] = (H[2] + c) | 0;\n\t H[3] = (H[3] + d) | 0;\n\t },\n\n\t _doFinalize: function () {\n\t // Shortcuts\n\t var data = this._data;\n\t var dataWords = data.words;\n\n\t var nBitsTotal = this._nDataBytes * 8;\n\t var nBitsLeft = data.sigBytes * 8;\n\n\t // Add padding\n\t dataWords[nBitsLeft >>> 5] |= 0x80 << (24 - nBitsLeft % 32);\n\n\t var nBitsTotalH = Math.floor(nBitsTotal / 0x100000000);\n\t var nBitsTotalL = nBitsTotal;\n\t dataWords[(((nBitsLeft + 64) >>> 9) << 4) + 15] = (\n\t (((nBitsTotalH << 8) | (nBitsTotalH >>> 24)) & 0x00ff00ff) |\n\t (((nBitsTotalH << 24) | (nBitsTotalH >>> 8)) & 0xff00ff00)\n\t );\n\t dataWords[(((nBitsLeft + 64) >>> 9) << 4) + 14] = (\n\t (((nBitsTotalL << 8) | (nBitsTotalL >>> 24)) & 0x00ff00ff) |\n\t (((nBitsTotalL << 24) | (nBitsTotalL >>> 8)) & 0xff00ff00)\n\t );\n\n\t data.sigBytes = (dataWords.length + 1) * 4;\n\n\t // Hash final blocks\n\t this._process();\n\n\t // Shortcuts\n\t var hash = this._hash;\n\t var H = hash.words;\n\n\t // Swap endian\n\t for (var i = 0; i < 4; i++) {\n\t // Shortcut\n\t var H_i = H[i];\n\n\t H[i] = (((H_i << 8) | (H_i >>> 24)) & 0x00ff00ff) |\n\t (((H_i << 24) | (H_i >>> 8)) & 0xff00ff00);\n\t }\n\n\t // Return final computed hash\n\t return hash;\n\t },\n\n\t clone: function () {\n\t var clone = Hasher.clone.call(this);\n\t clone._hash = this._hash.clone();\n\n\t return clone;\n\t }\n\t });\n\n\t function FF(a, b, c, d, x, s, t) {\n\t var n = a + ((b & c) | (~b & d)) + x + t;\n\t return ((n << s) | (n >>> (32 - s))) + b;\n\t }\n\n\t function GG(a, b, c, d, x, s, t) {\n\t var n = a + ((b & d) | (c & ~d)) + x + t;\n\t return ((n << s) | (n >>> (32 - s))) + b;\n\t }\n\n\t function HH(a, b, c, d, x, s, t) {\n\t var n = a + (b ^ c ^ d) + x + t;\n\t return ((n << s) | (n >>> (32 - s))) + b;\n\t }\n\n\t function II(a, b, c, d, x, s, t) {\n\t var n = a + (c ^ (b | ~d)) + x + t;\n\t return ((n << s) | (n >>> (32 - s))) + b;\n\t }\n\n\t /**\n\t * Shortcut function to the hasher's object interface.\n\t *\n\t * @param {WordArray|string} message The message to hash.\n\t *\n\t * @return {WordArray} The hash.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hash = CryptoJS.MD5('message');\n\t * var hash = CryptoJS.MD5(wordArray);\n\t */\n\t C.MD5 = Hasher._createHelper(MD5);\n\n\t /**\n\t * Shortcut function to the HMAC's object interface.\n\t *\n\t * @param {WordArray|string} message The message to hash.\n\t * @param {WordArray|string} key The secret key.\n\t *\n\t * @return {WordArray} The HMAC.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hmac = CryptoJS.HmacMD5(message, key);\n\t */\n\t C.HmacMD5 = Hasher._createHmacHelper(MD5);\n\t}(Math));\n\n\n\treturn CryptoJS.MD5;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./cipher-core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./cipher-core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t/**\n\t * Cipher Feedback block mode.\n\t */\n\tCryptoJS.mode.CFB = (function () {\n\t var CFB = CryptoJS.lib.BlockCipherMode.extend();\n\n\t CFB.Encryptor = CFB.extend({\n\t processBlock: function (words, offset) {\n\t // Shortcuts\n\t var cipher = this._cipher;\n\t var blockSize = cipher.blockSize;\n\n\t generateKeystreamAndEncrypt.call(this, words, offset, blockSize, cipher);\n\n\t // Remember this block to use with next block\n\t this._prevBlock = words.slice(offset, offset + blockSize);\n\t }\n\t });\n\n\t CFB.Decryptor = CFB.extend({\n\t processBlock: function (words, offset) {\n\t // Shortcuts\n\t var cipher = this._cipher;\n\t var blockSize = cipher.blockSize;\n\n\t // Remember this block to use with next block\n\t var thisBlock = words.slice(offset, offset + blockSize);\n\n\t generateKeystreamAndEncrypt.call(this, words, offset, blockSize, cipher);\n\n\t // This block becomes the previous block\n\t this._prevBlock = thisBlock;\n\t }\n\t });\n\n\t function generateKeystreamAndEncrypt(words, offset, blockSize, cipher) {\n\t var keystream;\n\n\t // Shortcut\n\t var iv = this._iv;\n\n\t // Generate keystream\n\t if (iv) {\n\t keystream = iv.slice(0);\n\n\t // Remove IV for subsequent blocks\n\t this._iv = undefined;\n\t } else {\n\t keystream = this._prevBlock;\n\t }\n\t cipher.encryptBlock(keystream, 0);\n\n\t // Encrypt\n\t for (var i = 0; i < blockSize; i++) {\n\t words[offset + i] ^= keystream[i];\n\t }\n\t }\n\n\t return CFB;\n\t}());\n\n\n\treturn CryptoJS.mode.CFB;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./cipher-core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./cipher-core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t/** @preserve\n\t * Counter block mode compatible with Dr Brian Gladman fileenc.c\n\t * derived from CryptoJS.mode.CTR\n\t * Jan Hruby jhruby.web@gmail.com\n\t */\n\tCryptoJS.mode.CTRGladman = (function () {\n\t var CTRGladman = CryptoJS.lib.BlockCipherMode.extend();\n\n\t\tfunction incWord(word)\n\t\t{\n\t\t\tif (((word >> 24) & 0xff) === 0xff) { //overflow\n\t\t\tvar b1 = (word >> 16)&0xff;\n\t\t\tvar b2 = (word >> 8)&0xff;\n\t\t\tvar b3 = word & 0xff;\n\n\t\t\tif (b1 === 0xff) // overflow b1\n\t\t\t{\n\t\t\tb1 = 0;\n\t\t\tif (b2 === 0xff)\n\t\t\t{\n\t\t\t\tb2 = 0;\n\t\t\t\tif (b3 === 0xff)\n\t\t\t\t{\n\t\t\t\t\tb3 = 0;\n\t\t\t\t}\n\t\t\t\telse\n\t\t\t\t{\n\t\t\t\t\t++b3;\n\t\t\t\t}\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t\t++b2;\n\t\t\t}\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t++b1;\n\t\t\t}\n\n\t\t\tword = 0;\n\t\t\tword += (b1 << 16);\n\t\t\tword += (b2 << 8);\n\t\t\tword += b3;\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\tword += (0x01 << 24);\n\t\t\t}\n\t\t\treturn word;\n\t\t}\n\n\t\tfunction incCounter(counter)\n\t\t{\n\t\t\tif ((counter[0] = incWord(counter[0])) === 0)\n\t\t\t{\n\t\t\t\t// encr_data in fileenc.c from Dr Brian Gladman's counts only with DWORD j < 8\n\t\t\t\tcounter[1] = incWord(counter[1]);\n\t\t\t}\n\t\t\treturn counter;\n\t\t}\n\n\t var Encryptor = CTRGladman.Encryptor = CTRGladman.extend({\n\t processBlock: function (words, offset) {\n\t // Shortcuts\n\t var cipher = this._cipher\n\t var blockSize = cipher.blockSize;\n\t var iv = this._iv;\n\t var counter = this._counter;\n\n\t // Generate keystream\n\t if (iv) {\n\t counter = this._counter = iv.slice(0);\n\n\t // Remove IV for subsequent blocks\n\t this._iv = undefined;\n\t }\n\n\t\t\t\tincCounter(counter);\n\n\t\t\t\tvar keystream = counter.slice(0);\n\t cipher.encryptBlock(keystream, 0);\n\n\t // Encrypt\n\t for (var i = 0; i < blockSize; i++) {\n\t words[offset + i] ^= keystream[i];\n\t }\n\t }\n\t });\n\n\t CTRGladman.Decryptor = Encryptor;\n\n\t return CTRGladman;\n\t}());\n\n\n\n\n\treturn CryptoJS.mode.CTRGladman;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./cipher-core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./cipher-core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t/**\n\t * Counter block mode.\n\t */\n\tCryptoJS.mode.CTR = (function () {\n\t var CTR = CryptoJS.lib.BlockCipherMode.extend();\n\n\t var Encryptor = CTR.Encryptor = CTR.extend({\n\t processBlock: function (words, offset) {\n\t // Shortcuts\n\t var cipher = this._cipher\n\t var blockSize = cipher.blockSize;\n\t var iv = this._iv;\n\t var counter = this._counter;\n\n\t // Generate keystream\n\t if (iv) {\n\t counter = this._counter = iv.slice(0);\n\n\t // Remove IV for subsequent blocks\n\t this._iv = undefined;\n\t }\n\t var keystream = counter.slice(0);\n\t cipher.encryptBlock(keystream, 0);\n\n\t // Increment counter\n\t counter[blockSize - 1] = (counter[blockSize - 1] + 1) | 0\n\n\t // Encrypt\n\t for (var i = 0; i < blockSize; i++) {\n\t words[offset + i] ^= keystream[i];\n\t }\n\t }\n\t });\n\n\t CTR.Decryptor = Encryptor;\n\n\t return CTR;\n\t}());\n\n\n\treturn CryptoJS.mode.CTR;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./cipher-core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./cipher-core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t/**\n\t * Electronic Codebook block mode.\n\t */\n\tCryptoJS.mode.ECB = (function () {\n\t var ECB = CryptoJS.lib.BlockCipherMode.extend();\n\n\t ECB.Encryptor = ECB.extend({\n\t processBlock: function (words, offset) {\n\t this._cipher.encryptBlock(words, offset);\n\t }\n\t });\n\n\t ECB.Decryptor = ECB.extend({\n\t processBlock: function (words, offset) {\n\t this._cipher.decryptBlock(words, offset);\n\t }\n\t });\n\n\t return ECB;\n\t}());\n\n\n\treturn CryptoJS.mode.ECB;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./cipher-core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./cipher-core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t/**\n\t * Output Feedback block mode.\n\t */\n\tCryptoJS.mode.OFB = (function () {\n\t var OFB = CryptoJS.lib.BlockCipherMode.extend();\n\n\t var Encryptor = OFB.Encryptor = OFB.extend({\n\t processBlock: function (words, offset) {\n\t // Shortcuts\n\t var cipher = this._cipher\n\t var blockSize = cipher.blockSize;\n\t var iv = this._iv;\n\t var keystream = this._keystream;\n\n\t // Generate keystream\n\t if (iv) {\n\t keystream = this._keystream = iv.slice(0);\n\n\t // Remove IV for subsequent blocks\n\t this._iv = undefined;\n\t }\n\t cipher.encryptBlock(keystream, 0);\n\n\t // Encrypt\n\t for (var i = 0; i < blockSize; i++) {\n\t words[offset + i] ^= keystream[i];\n\t }\n\t }\n\t });\n\n\t OFB.Decryptor = Encryptor;\n\n\t return OFB;\n\t}());\n\n\n\treturn CryptoJS.mode.OFB;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./cipher-core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./cipher-core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t/**\n\t * ANSI X.923 padding strategy.\n\t */\n\tCryptoJS.pad.AnsiX923 = {\n\t pad: function (data, blockSize) {\n\t // Shortcuts\n\t var dataSigBytes = data.sigBytes;\n\t var blockSizeBytes = blockSize * 4;\n\n\t // Count padding bytes\n\t var nPaddingBytes = blockSizeBytes - dataSigBytes % blockSizeBytes;\n\n\t // Compute last byte position\n\t var lastBytePos = dataSigBytes + nPaddingBytes - 1;\n\n\t // Pad\n\t data.clamp();\n\t data.words[lastBytePos >>> 2] |= nPaddingBytes << (24 - (lastBytePos % 4) * 8);\n\t data.sigBytes += nPaddingBytes;\n\t },\n\n\t unpad: function (data) {\n\t // Get number of padding bytes from last byte\n\t var nPaddingBytes = data.words[(data.sigBytes - 1) >>> 2] & 0xff;\n\n\t // Remove padding\n\t data.sigBytes -= nPaddingBytes;\n\t }\n\t};\n\n\n\treturn CryptoJS.pad.Ansix923;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./cipher-core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./cipher-core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t/**\n\t * ISO 10126 padding strategy.\n\t */\n\tCryptoJS.pad.Iso10126 = {\n\t pad: function (data, blockSize) {\n\t // Shortcut\n\t var blockSizeBytes = blockSize * 4;\n\n\t // Count padding bytes\n\t var nPaddingBytes = blockSizeBytes - data.sigBytes % blockSizeBytes;\n\n\t // Pad\n\t data.concat(CryptoJS.lib.WordArray.random(nPaddingBytes - 1)).\n\t concat(CryptoJS.lib.WordArray.create([nPaddingBytes << 24], 1));\n\t },\n\n\t unpad: function (data) {\n\t // Get number of padding bytes from last byte\n\t var nPaddingBytes = data.words[(data.sigBytes - 1) >>> 2] & 0xff;\n\n\t // Remove padding\n\t data.sigBytes -= nPaddingBytes;\n\t }\n\t};\n\n\n\treturn CryptoJS.pad.Iso10126;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./cipher-core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./cipher-core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t/**\n\t * ISO/IEC 9797-1 Padding Method 2.\n\t */\n\tCryptoJS.pad.Iso97971 = {\n\t pad: function (data, blockSize) {\n\t // Add 0x80 byte\n\t data.concat(CryptoJS.lib.WordArray.create([0x80000000], 1));\n\n\t // Zero pad the rest\n\t CryptoJS.pad.ZeroPadding.pad(data, blockSize);\n\t },\n\n\t unpad: function (data) {\n\t // Remove zero padding\n\t CryptoJS.pad.ZeroPadding.unpad(data);\n\n\t // Remove one more byte -- the 0x80 byte\n\t data.sigBytes--;\n\t }\n\t};\n\n\n\treturn CryptoJS.pad.Iso97971;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./cipher-core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./cipher-core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t/**\n\t * A noop padding strategy.\n\t */\n\tCryptoJS.pad.NoPadding = {\n\t pad: function () {\n\t },\n\n\t unpad: function () {\n\t }\n\t};\n\n\n\treturn CryptoJS.pad.NoPadding;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./cipher-core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./cipher-core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t/**\n\t * Zero padding strategy.\n\t */\n\tCryptoJS.pad.ZeroPadding = {\n\t pad: function (data, blockSize) {\n\t // Shortcut\n\t var blockSizeBytes = blockSize * 4;\n\n\t // Pad\n\t data.clamp();\n\t data.sigBytes += blockSizeBytes - ((data.sigBytes % blockSizeBytes) || blockSizeBytes);\n\t },\n\n\t unpad: function (data) {\n\t // Shortcut\n\t var dataWords = data.words;\n\n\t // Unpad\n\t var i = data.sigBytes - 1;\n\t for (var i = data.sigBytes - 1; i >= 0; i--) {\n\t if (((dataWords[i >>> 2] >>> (24 - (i % 4) * 8)) & 0xff)) {\n\t data.sigBytes = i + 1;\n\t break;\n\t }\n\t }\n\t }\n\t};\n\n\n\treturn CryptoJS.pad.ZeroPadding;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./sha256\"), require(\"./hmac\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./sha256\", \"./hmac\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function () {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var Base = C_lib.Base;\n\t var WordArray = C_lib.WordArray;\n\t var C_algo = C.algo;\n\t var SHA256 = C_algo.SHA256;\n\t var HMAC = C_algo.HMAC;\n\n\t /**\n\t * Password-Based Key Derivation Function 2 algorithm.\n\t */\n\t var PBKDF2 = C_algo.PBKDF2 = Base.extend({\n\t /**\n\t * Configuration options.\n\t *\n\t * @property {number} keySize The key size in words to generate. Default: 4 (128 bits)\n\t * @property {Hasher} hasher The hasher to use. Default: SHA256\n\t * @property {number} iterations The number of iterations to perform. Default: 250000\n\t */\n\t cfg: Base.extend({\n\t keySize: 128/32,\n\t hasher: SHA256,\n\t iterations: 250000\n\t }),\n\n\t /**\n\t * Initializes a newly created key derivation function.\n\t *\n\t * @param {Object} cfg (Optional) The configuration options to use for the derivation.\n\t *\n\t * @example\n\t *\n\t * var kdf = CryptoJS.algo.PBKDF2.create();\n\t * var kdf = CryptoJS.algo.PBKDF2.create({ keySize: 8 });\n\t * var kdf = CryptoJS.algo.PBKDF2.create({ keySize: 8, iterations: 1000 });\n\t */\n\t init: function (cfg) {\n\t this.cfg = this.cfg.extend(cfg);\n\t },\n\n\t /**\n\t * Computes the Password-Based Key Derivation Function 2.\n\t *\n\t * @param {WordArray|string} password The password.\n\t * @param {WordArray|string} salt A salt.\n\t *\n\t * @return {WordArray} The derived key.\n\t *\n\t * @example\n\t *\n\t * var key = kdf.compute(password, salt);\n\t */\n\t compute: function (password, salt) {\n\t // Shortcut\n\t var cfg = this.cfg;\n\n\t // Init HMAC\n\t var hmac = HMAC.create(cfg.hasher, password);\n\n\t // Initial values\n\t var derivedKey = WordArray.create();\n\t var blockIndex = WordArray.create([0x00000001]);\n\n\t // Shortcuts\n\t var derivedKeyWords = derivedKey.words;\n\t var blockIndexWords = blockIndex.words;\n\t var keySize = cfg.keySize;\n\t var iterations = cfg.iterations;\n\n\t // Generate key\n\t while (derivedKeyWords.length < keySize) {\n\t var block = hmac.update(salt).finalize(blockIndex);\n\t hmac.reset();\n\n\t // Shortcuts\n\t var blockWords = block.words;\n\t var blockWordsLength = blockWords.length;\n\n\t // Iterations\n\t var intermediate = block;\n\t for (var i = 1; i < iterations; i++) {\n\t intermediate = hmac.finalize(intermediate);\n\t hmac.reset();\n\n\t // Shortcut\n\t var intermediateWords = intermediate.words;\n\n\t // XOR intermediate with block\n\t for (var j = 0; j < blockWordsLength; j++) {\n\t blockWords[j] ^= intermediateWords[j];\n\t }\n\t }\n\n\t derivedKey.concat(block);\n\t blockIndexWords[0]++;\n\t }\n\t derivedKey.sigBytes = keySize * 4;\n\n\t return derivedKey;\n\t }\n\t });\n\n\t /**\n\t * Computes the Password-Based Key Derivation Function 2.\n\t *\n\t * @param {WordArray|string} password The password.\n\t * @param {WordArray|string} salt A salt.\n\t * @param {Object} cfg (Optional) The configuration options to use for this computation.\n\t *\n\t * @return {WordArray} The derived key.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var key = CryptoJS.PBKDF2(password, salt);\n\t * var key = CryptoJS.PBKDF2(password, salt, { keySize: 8 });\n\t * var key = CryptoJS.PBKDF2(password, salt, { keySize: 8, iterations: 1000 });\n\t */\n\t C.PBKDF2 = function (password, salt, cfg) {\n\t return PBKDF2.create(cfg).compute(password, salt);\n\t };\n\t}());\n\n\n\treturn CryptoJS.PBKDF2;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./enc-base64\"), require(\"./md5\"), require(\"./evpkdf\"), require(\"./cipher-core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./enc-base64\", \"./md5\", \"./evpkdf\", \"./cipher-core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function () {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var StreamCipher = C_lib.StreamCipher;\n\t var C_algo = C.algo;\n\n\t // Reusable objects\n\t var S = [];\n\t var C_ = [];\n\t var G = [];\n\n\t /**\n\t * Rabbit stream cipher algorithm.\n\t *\n\t * This is a legacy version that neglected to convert the key to little-endian.\n\t * This error doesn't affect the cipher's security,\n\t * but it does affect its compatibility with other implementations.\n\t */\n\t var RabbitLegacy = C_algo.RabbitLegacy = StreamCipher.extend({\n\t _doReset: function () {\n\t // Shortcuts\n\t var K = this._key.words;\n\t var iv = this.cfg.iv;\n\n\t // Generate initial state values\n\t var X = this._X = [\n\t K[0], (K[3] << 16) | (K[2] >>> 16),\n\t K[1], (K[0] << 16) | (K[3] >>> 16),\n\t K[2], (K[1] << 16) | (K[0] >>> 16),\n\t K[3], (K[2] << 16) | (K[1] >>> 16)\n\t ];\n\n\t // Generate initial counter values\n\t var C = this._C = [\n\t (K[2] << 16) | (K[2] >>> 16), (K[0] & 0xffff0000) | (K[1] & 0x0000ffff),\n\t (K[3] << 16) | (K[3] >>> 16), (K[1] & 0xffff0000) | (K[2] & 0x0000ffff),\n\t (K[0] << 16) | (K[0] >>> 16), (K[2] & 0xffff0000) | (K[3] & 0x0000ffff),\n\t (K[1] << 16) | (K[1] >>> 16), (K[3] & 0xffff0000) | (K[0] & 0x0000ffff)\n\t ];\n\n\t // Carry bit\n\t this._b = 0;\n\n\t // Iterate the system four times\n\t for (var i = 0; i < 4; i++) {\n\t nextState.call(this);\n\t }\n\n\t // Modify the counters\n\t for (var i = 0; i < 8; i++) {\n\t C[i] ^= X[(i + 4) & 7];\n\t }\n\n\t // IV setup\n\t if (iv) {\n\t // Shortcuts\n\t var IV = iv.words;\n\t var IV_0 = IV[0];\n\t var IV_1 = IV[1];\n\n\t // Generate four subvectors\n\t var i0 = (((IV_0 << 8) | (IV_0 >>> 24)) & 0x00ff00ff) | (((IV_0 << 24) | (IV_0 >>> 8)) & 0xff00ff00);\n\t var i2 = (((IV_1 << 8) | (IV_1 >>> 24)) & 0x00ff00ff) | (((IV_1 << 24) | (IV_1 >>> 8)) & 0xff00ff00);\n\t var i1 = (i0 >>> 16) | (i2 & 0xffff0000);\n\t var i3 = (i2 << 16) | (i0 & 0x0000ffff);\n\n\t // Modify counter values\n\t C[0] ^= i0;\n\t C[1] ^= i1;\n\t C[2] ^= i2;\n\t C[3] ^= i3;\n\t C[4] ^= i0;\n\t C[5] ^= i1;\n\t C[6] ^= i2;\n\t C[7] ^= i3;\n\n\t // Iterate the system four times\n\t for (var i = 0; i < 4; i++) {\n\t nextState.call(this);\n\t }\n\t }\n\t },\n\n\t _doProcessBlock: function (M, offset) {\n\t // Shortcut\n\t var X = this._X;\n\n\t // Iterate the system\n\t nextState.call(this);\n\n\t // Generate four keystream words\n\t S[0] = X[0] ^ (X[5] >>> 16) ^ (X[3] << 16);\n\t S[1] = X[2] ^ (X[7] >>> 16) ^ (X[5] << 16);\n\t S[2] = X[4] ^ (X[1] >>> 16) ^ (X[7] << 16);\n\t S[3] = X[6] ^ (X[3] >>> 16) ^ (X[1] << 16);\n\n\t for (var i = 0; i < 4; i++) {\n\t // Swap endian\n\t S[i] = (((S[i] << 8) | (S[i] >>> 24)) & 0x00ff00ff) |\n\t (((S[i] << 24) | (S[i] >>> 8)) & 0xff00ff00);\n\n\t // Encrypt\n\t M[offset + i] ^= S[i];\n\t }\n\t },\n\n\t blockSize: 128/32,\n\n\t ivSize: 64/32\n\t });\n\n\t function nextState() {\n\t // Shortcuts\n\t var X = this._X;\n\t var C = this._C;\n\n\t // Save old counter values\n\t for (var i = 0; i < 8; i++) {\n\t C_[i] = C[i];\n\t }\n\n\t // Calculate new counter values\n\t C[0] = (C[0] + 0x4d34d34d + this._b) | 0;\n\t C[1] = (C[1] + 0xd34d34d3 + ((C[0] >>> 0) < (C_[0] >>> 0) ? 1 : 0)) | 0;\n\t C[2] = (C[2] + 0x34d34d34 + ((C[1] >>> 0) < (C_[1] >>> 0) ? 1 : 0)) | 0;\n\t C[3] = (C[3] + 0x4d34d34d + ((C[2] >>> 0) < (C_[2] >>> 0) ? 1 : 0)) | 0;\n\t C[4] = (C[4] + 0xd34d34d3 + ((C[3] >>> 0) < (C_[3] >>> 0) ? 1 : 0)) | 0;\n\t C[5] = (C[5] + 0x34d34d34 + ((C[4] >>> 0) < (C_[4] >>> 0) ? 1 : 0)) | 0;\n\t C[6] = (C[6] + 0x4d34d34d + ((C[5] >>> 0) < (C_[5] >>> 0) ? 1 : 0)) | 0;\n\t C[7] = (C[7] + 0xd34d34d3 + ((C[6] >>> 0) < (C_[6] >>> 0) ? 1 : 0)) | 0;\n\t this._b = (C[7] >>> 0) < (C_[7] >>> 0) ? 1 : 0;\n\n\t // Calculate the g-values\n\t for (var i = 0; i < 8; i++) {\n\t var gx = X[i] + C[i];\n\n\t // Construct high and low argument for squaring\n\t var ga = gx & 0xffff;\n\t var gb = gx >>> 16;\n\n\t // Calculate high and low result of squaring\n\t var gh = ((((ga * ga) >>> 17) + ga * gb) >>> 15) + gb * gb;\n\t var gl = (((gx & 0xffff0000) * gx) | 0) + (((gx & 0x0000ffff) * gx) | 0);\n\n\t // High XOR low\n\t G[i] = gh ^ gl;\n\t }\n\n\t // Calculate new state values\n\t X[0] = (G[0] + ((G[7] << 16) | (G[7] >>> 16)) + ((G[6] << 16) | (G[6] >>> 16))) | 0;\n\t X[1] = (G[1] + ((G[0] << 8) | (G[0] >>> 24)) + G[7]) | 0;\n\t X[2] = (G[2] + ((G[1] << 16) | (G[1] >>> 16)) + ((G[0] << 16) | (G[0] >>> 16))) | 0;\n\t X[3] = (G[3] + ((G[2] << 8) | (G[2] >>> 24)) + G[1]) | 0;\n\t X[4] = (G[4] + ((G[3] << 16) | (G[3] >>> 16)) + ((G[2] << 16) | (G[2] >>> 16))) | 0;\n\t X[5] = (G[5] + ((G[4] << 8) | (G[4] >>> 24)) + G[3]) | 0;\n\t X[6] = (G[6] + ((G[5] << 16) | (G[5] >>> 16)) + ((G[4] << 16) | (G[4] >>> 16))) | 0;\n\t X[7] = (G[7] + ((G[6] << 8) | (G[6] >>> 24)) + G[5]) | 0;\n\t }\n\n\t /**\n\t * Shortcut functions to the cipher's object interface.\n\t *\n\t * @example\n\t *\n\t * var ciphertext = CryptoJS.RabbitLegacy.encrypt(message, key, cfg);\n\t * var plaintext = CryptoJS.RabbitLegacy.decrypt(ciphertext, key, cfg);\n\t */\n\t C.RabbitLegacy = StreamCipher._createHelper(RabbitLegacy);\n\t}());\n\n\n\treturn CryptoJS.RabbitLegacy;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./enc-base64\"), require(\"./md5\"), require(\"./evpkdf\"), require(\"./cipher-core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./enc-base64\", \"./md5\", \"./evpkdf\", \"./cipher-core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function () {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var StreamCipher = C_lib.StreamCipher;\n\t var C_algo = C.algo;\n\n\t // Reusable objects\n\t var S = [];\n\t var C_ = [];\n\t var G = [];\n\n\t /**\n\t * Rabbit stream cipher algorithm\n\t */\n\t var Rabbit = C_algo.Rabbit = StreamCipher.extend({\n\t _doReset: function () {\n\t // Shortcuts\n\t var K = this._key.words;\n\t var iv = this.cfg.iv;\n\n\t // Swap endian\n\t for (var i = 0; i < 4; i++) {\n\t K[i] = (((K[i] << 8) | (K[i] >>> 24)) & 0x00ff00ff) |\n\t (((K[i] << 24) | (K[i] >>> 8)) & 0xff00ff00);\n\t }\n\n\t // Generate initial state values\n\t var X = this._X = [\n\t K[0], (K[3] << 16) | (K[2] >>> 16),\n\t K[1], (K[0] << 16) | (K[3] >>> 16),\n\t K[2], (K[1] << 16) | (K[0] >>> 16),\n\t K[3], (K[2] << 16) | (K[1] >>> 16)\n\t ];\n\n\t // Generate initial counter values\n\t var C = this._C = [\n\t (K[2] << 16) | (K[2] >>> 16), (K[0] & 0xffff0000) | (K[1] & 0x0000ffff),\n\t (K[3] << 16) | (K[3] >>> 16), (K[1] & 0xffff0000) | (K[2] & 0x0000ffff),\n\t (K[0] << 16) | (K[0] >>> 16), (K[2] & 0xffff0000) | (K[3] & 0x0000ffff),\n\t (K[1] << 16) | (K[1] >>> 16), (K[3] & 0xffff0000) | (K[0] & 0x0000ffff)\n\t ];\n\n\t // Carry bit\n\t this._b = 0;\n\n\t // Iterate the system four times\n\t for (var i = 0; i < 4; i++) {\n\t nextState.call(this);\n\t }\n\n\t // Modify the counters\n\t for (var i = 0; i < 8; i++) {\n\t C[i] ^= X[(i + 4) & 7];\n\t }\n\n\t // IV setup\n\t if (iv) {\n\t // Shortcuts\n\t var IV = iv.words;\n\t var IV_0 = IV[0];\n\t var IV_1 = IV[1];\n\n\t // Generate four subvectors\n\t var i0 = (((IV_0 << 8) | (IV_0 >>> 24)) & 0x00ff00ff) | (((IV_0 << 24) | (IV_0 >>> 8)) & 0xff00ff00);\n\t var i2 = (((IV_1 << 8) | (IV_1 >>> 24)) & 0x00ff00ff) | (((IV_1 << 24) | (IV_1 >>> 8)) & 0xff00ff00);\n\t var i1 = (i0 >>> 16) | (i2 & 0xffff0000);\n\t var i3 = (i2 << 16) | (i0 & 0x0000ffff);\n\n\t // Modify counter values\n\t C[0] ^= i0;\n\t C[1] ^= i1;\n\t C[2] ^= i2;\n\t C[3] ^= i3;\n\t C[4] ^= i0;\n\t C[5] ^= i1;\n\t C[6] ^= i2;\n\t C[7] ^= i3;\n\n\t // Iterate the system four times\n\t for (var i = 0; i < 4; i++) {\n\t nextState.call(this);\n\t }\n\t }\n\t },\n\n\t _doProcessBlock: function (M, offset) {\n\t // Shortcut\n\t var X = this._X;\n\n\t // Iterate the system\n\t nextState.call(this);\n\n\t // Generate four keystream words\n\t S[0] = X[0] ^ (X[5] >>> 16) ^ (X[3] << 16);\n\t S[1] = X[2] ^ (X[7] >>> 16) ^ (X[5] << 16);\n\t S[2] = X[4] ^ (X[1] >>> 16) ^ (X[7] << 16);\n\t S[3] = X[6] ^ (X[3] >>> 16) ^ (X[1] << 16);\n\n\t for (var i = 0; i < 4; i++) {\n\t // Swap endian\n\t S[i] = (((S[i] << 8) | (S[i] >>> 24)) & 0x00ff00ff) |\n\t (((S[i] << 24) | (S[i] >>> 8)) & 0xff00ff00);\n\n\t // Encrypt\n\t M[offset + i] ^= S[i];\n\t }\n\t },\n\n\t blockSize: 128/32,\n\n\t ivSize: 64/32\n\t });\n\n\t function nextState() {\n\t // Shortcuts\n\t var X = this._X;\n\t var C = this._C;\n\n\t // Save old counter values\n\t for (var i = 0; i < 8; i++) {\n\t C_[i] = C[i];\n\t }\n\n\t // Calculate new counter values\n\t C[0] = (C[0] + 0x4d34d34d + this._b) | 0;\n\t C[1] = (C[1] + 0xd34d34d3 + ((C[0] >>> 0) < (C_[0] >>> 0) ? 1 : 0)) | 0;\n\t C[2] = (C[2] + 0x34d34d34 + ((C[1] >>> 0) < (C_[1] >>> 0) ? 1 : 0)) | 0;\n\t C[3] = (C[3] + 0x4d34d34d + ((C[2] >>> 0) < (C_[2] >>> 0) ? 1 : 0)) | 0;\n\t C[4] = (C[4] + 0xd34d34d3 + ((C[3] >>> 0) < (C_[3] >>> 0) ? 1 : 0)) | 0;\n\t C[5] = (C[5] + 0x34d34d34 + ((C[4] >>> 0) < (C_[4] >>> 0) ? 1 : 0)) | 0;\n\t C[6] = (C[6] + 0x4d34d34d + ((C[5] >>> 0) < (C_[5] >>> 0) ? 1 : 0)) | 0;\n\t C[7] = (C[7] + 0xd34d34d3 + ((C[6] >>> 0) < (C_[6] >>> 0) ? 1 : 0)) | 0;\n\t this._b = (C[7] >>> 0) < (C_[7] >>> 0) ? 1 : 0;\n\n\t // Calculate the g-values\n\t for (var i = 0; i < 8; i++) {\n\t var gx = X[i] + C[i];\n\n\t // Construct high and low argument for squaring\n\t var ga = gx & 0xffff;\n\t var gb = gx >>> 16;\n\n\t // Calculate high and low result of squaring\n\t var gh = ((((ga * ga) >>> 17) + ga * gb) >>> 15) + gb * gb;\n\t var gl = (((gx & 0xffff0000) * gx) | 0) + (((gx & 0x0000ffff) * gx) | 0);\n\n\t // High XOR low\n\t G[i] = gh ^ gl;\n\t }\n\n\t // Calculate new state values\n\t X[0] = (G[0] + ((G[7] << 16) | (G[7] >>> 16)) + ((G[6] << 16) | (G[6] >>> 16))) | 0;\n\t X[1] = (G[1] + ((G[0] << 8) | (G[0] >>> 24)) + G[7]) | 0;\n\t X[2] = (G[2] + ((G[1] << 16) | (G[1] >>> 16)) + ((G[0] << 16) | (G[0] >>> 16))) | 0;\n\t X[3] = (G[3] + ((G[2] << 8) | (G[2] >>> 24)) + G[1]) | 0;\n\t X[4] = (G[4] + ((G[3] << 16) | (G[3] >>> 16)) + ((G[2] << 16) | (G[2] >>> 16))) | 0;\n\t X[5] = (G[5] + ((G[4] << 8) | (G[4] >>> 24)) + G[3]) | 0;\n\t X[6] = (G[6] + ((G[5] << 16) | (G[5] >>> 16)) + ((G[4] << 16) | (G[4] >>> 16))) | 0;\n\t X[7] = (G[7] + ((G[6] << 8) | (G[6] >>> 24)) + G[5]) | 0;\n\t }\n\n\t /**\n\t * Shortcut functions to the cipher's object interface.\n\t *\n\t * @example\n\t *\n\t * var ciphertext = CryptoJS.Rabbit.encrypt(message, key, cfg);\n\t * var plaintext = CryptoJS.Rabbit.decrypt(ciphertext, key, cfg);\n\t */\n\t C.Rabbit = StreamCipher._createHelper(Rabbit);\n\t}());\n\n\n\treturn CryptoJS.Rabbit;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./enc-base64\"), require(\"./md5\"), require(\"./evpkdf\"), require(\"./cipher-core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./enc-base64\", \"./md5\", \"./evpkdf\", \"./cipher-core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function () {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var StreamCipher = C_lib.StreamCipher;\n\t var C_algo = C.algo;\n\n\t /**\n\t * RC4 stream cipher algorithm.\n\t */\n\t var RC4 = C_algo.RC4 = StreamCipher.extend({\n\t _doReset: function () {\n\t // Shortcuts\n\t var key = this._key;\n\t var keyWords = key.words;\n\t var keySigBytes = key.sigBytes;\n\n\t // Init sbox\n\t var S = this._S = [];\n\t for (var i = 0; i < 256; i++) {\n\t S[i] = i;\n\t }\n\n\t // Key setup\n\t for (var i = 0, j = 0; i < 256; i++) {\n\t var keyByteIndex = i % keySigBytes;\n\t var keyByte = (keyWords[keyByteIndex >>> 2] >>> (24 - (keyByteIndex % 4) * 8)) & 0xff;\n\n\t j = (j + S[i] + keyByte) % 256;\n\n\t // Swap\n\t var t = S[i];\n\t S[i] = S[j];\n\t S[j] = t;\n\t }\n\n\t // Counters\n\t this._i = this._j = 0;\n\t },\n\n\t _doProcessBlock: function (M, offset) {\n\t M[offset] ^= generateKeystreamWord.call(this);\n\t },\n\n\t keySize: 256/32,\n\n\t ivSize: 0\n\t });\n\n\t function generateKeystreamWord() {\n\t // Shortcuts\n\t var S = this._S;\n\t var i = this._i;\n\t var j = this._j;\n\n\t // Generate keystream word\n\t var keystreamWord = 0;\n\t for (var n = 0; n < 4; n++) {\n\t i = (i + 1) % 256;\n\t j = (j + S[i]) % 256;\n\n\t // Swap\n\t var t = S[i];\n\t S[i] = S[j];\n\t S[j] = t;\n\n\t keystreamWord |= S[(S[i] + S[j]) % 256] << (24 - n * 8);\n\t }\n\n\t // Update counters\n\t this._i = i;\n\t this._j = j;\n\n\t return keystreamWord;\n\t }\n\n\t /**\n\t * Shortcut functions to the cipher's object interface.\n\t *\n\t * @example\n\t *\n\t * var ciphertext = CryptoJS.RC4.encrypt(message, key, cfg);\n\t * var plaintext = CryptoJS.RC4.decrypt(ciphertext, key, cfg);\n\t */\n\t C.RC4 = StreamCipher._createHelper(RC4);\n\n\t /**\n\t * Modified RC4 stream cipher algorithm.\n\t */\n\t var RC4Drop = C_algo.RC4Drop = RC4.extend({\n\t /**\n\t * Configuration options.\n\t *\n\t * @property {number} drop The number of keystream words to drop. Default 192\n\t */\n\t cfg: RC4.cfg.extend({\n\t drop: 192\n\t }),\n\n\t _doReset: function () {\n\t RC4._doReset.call(this);\n\n\t // Drop\n\t for (var i = this.cfg.drop; i > 0; i--) {\n\t generateKeystreamWord.call(this);\n\t }\n\t }\n\t });\n\n\t /**\n\t * Shortcut functions to the cipher's object interface.\n\t *\n\t * @example\n\t *\n\t * var ciphertext = CryptoJS.RC4Drop.encrypt(message, key, cfg);\n\t * var plaintext = CryptoJS.RC4Drop.decrypt(ciphertext, key, cfg);\n\t */\n\t C.RC4Drop = StreamCipher._createHelper(RC4Drop);\n\t}());\n\n\n\treturn CryptoJS.RC4;\n\n}));",";(function (root, factory) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t/** @preserve\n\t(c) 2012 by Cédric Mesnil. All rights reserved.\n\n\tRedistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:\n\n\t - Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.\n\t - Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.\n\n\tTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n\t*/\n\n\t(function (Math) {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var WordArray = C_lib.WordArray;\n\t var Hasher = C_lib.Hasher;\n\t var C_algo = C.algo;\n\n\t // Constants table\n\t var _zl = WordArray.create([\n\t 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15,\n\t 7, 4, 13, 1, 10, 6, 15, 3, 12, 0, 9, 5, 2, 14, 11, 8,\n\t 3, 10, 14, 4, 9, 15, 8, 1, 2, 7, 0, 6, 13, 11, 5, 12,\n\t 1, 9, 11, 10, 0, 8, 12, 4, 13, 3, 7, 15, 14, 5, 6, 2,\n\t 4, 0, 5, 9, 7, 12, 2, 10, 14, 1, 3, 8, 11, 6, 15, 13]);\n\t var _zr = WordArray.create([\n\t 5, 14, 7, 0, 9, 2, 11, 4, 13, 6, 15, 8, 1, 10, 3, 12,\n\t 6, 11, 3, 7, 0, 13, 5, 10, 14, 15, 8, 12, 4, 9, 1, 2,\n\t 15, 5, 1, 3, 7, 14, 6, 9, 11, 8, 12, 2, 10, 0, 4, 13,\n\t 8, 6, 4, 1, 3, 11, 15, 0, 5, 12, 2, 13, 9, 7, 10, 14,\n\t 12, 15, 10, 4, 1, 5, 8, 7, 6, 2, 13, 14, 0, 3, 9, 11]);\n\t var _sl = WordArray.create([\n\t 11, 14, 15, 12, 5, 8, 7, 9, 11, 13, 14, 15, 6, 7, 9, 8,\n\t 7, 6, 8, 13, 11, 9, 7, 15, 7, 12, 15, 9, 11, 7, 13, 12,\n\t 11, 13, 6, 7, 14, 9, 13, 15, 14, 8, 13, 6, 5, 12, 7, 5,\n\t 11, 12, 14, 15, 14, 15, 9, 8, 9, 14, 5, 6, 8, 6, 5, 12,\n\t 9, 15, 5, 11, 6, 8, 13, 12, 5, 12, 13, 14, 11, 8, 5, 6 ]);\n\t var _sr = WordArray.create([\n\t 8, 9, 9, 11, 13, 15, 15, 5, 7, 7, 8, 11, 14, 14, 12, 6,\n\t 9, 13, 15, 7, 12, 8, 9, 11, 7, 7, 12, 7, 6, 15, 13, 11,\n\t 9, 7, 15, 11, 8, 6, 6, 14, 12, 13, 5, 14, 13, 13, 7, 5,\n\t 15, 5, 8, 11, 14, 14, 6, 14, 6, 9, 12, 9, 12, 5, 15, 8,\n\t 8, 5, 12, 9, 12, 5, 14, 6, 8, 13, 6, 5, 15, 13, 11, 11 ]);\n\n\t var _hl = WordArray.create([ 0x00000000, 0x5A827999, 0x6ED9EBA1, 0x8F1BBCDC, 0xA953FD4E]);\n\t var _hr = WordArray.create([ 0x50A28BE6, 0x5C4DD124, 0x6D703EF3, 0x7A6D76E9, 0x00000000]);\n\n\t /**\n\t * RIPEMD160 hash algorithm.\n\t */\n\t var RIPEMD160 = C_algo.RIPEMD160 = Hasher.extend({\n\t _doReset: function () {\n\t this._hash = WordArray.create([0x67452301, 0xEFCDAB89, 0x98BADCFE, 0x10325476, 0xC3D2E1F0]);\n\t },\n\n\t _doProcessBlock: function (M, offset) {\n\n\t // Swap endian\n\t for (var i = 0; i < 16; i++) {\n\t // Shortcuts\n\t var offset_i = offset + i;\n\t var M_offset_i = M[offset_i];\n\n\t // Swap\n\t M[offset_i] = (\n\t (((M_offset_i << 8) | (M_offset_i >>> 24)) & 0x00ff00ff) |\n\t (((M_offset_i << 24) | (M_offset_i >>> 8)) & 0xff00ff00)\n\t );\n\t }\n\t // Shortcut\n\t var H = this._hash.words;\n\t var hl = _hl.words;\n\t var hr = _hr.words;\n\t var zl = _zl.words;\n\t var zr = _zr.words;\n\t var sl = _sl.words;\n\t var sr = _sr.words;\n\n\t // Working variables\n\t var al, bl, cl, dl, el;\n\t var ar, br, cr, dr, er;\n\n\t ar = al = H[0];\n\t br = bl = H[1];\n\t cr = cl = H[2];\n\t dr = dl = H[3];\n\t er = el = H[4];\n\t // Computation\n\t var t;\n\t for (var i = 0; i < 80; i += 1) {\n\t t = (al + M[offset+zl[i]])|0;\n\t if (i<16){\n\t\t t += f1(bl,cl,dl) + hl[0];\n\t } else if (i<32) {\n\t\t t += f2(bl,cl,dl) + hl[1];\n\t } else if (i<48) {\n\t\t t += f3(bl,cl,dl) + hl[2];\n\t } else if (i<64) {\n\t\t t += f4(bl,cl,dl) + hl[3];\n\t } else {// if (i<80) {\n\t\t t += f5(bl,cl,dl) + hl[4];\n\t }\n\t t = t|0;\n\t t = rotl(t,sl[i]);\n\t t = (t+el)|0;\n\t al = el;\n\t el = dl;\n\t dl = rotl(cl, 10);\n\t cl = bl;\n\t bl = t;\n\n\t t = (ar + M[offset+zr[i]])|0;\n\t if (i<16){\n\t\t t += f5(br,cr,dr) + hr[0];\n\t } else if (i<32) {\n\t\t t += f4(br,cr,dr) + hr[1];\n\t } else if (i<48) {\n\t\t t += f3(br,cr,dr) + hr[2];\n\t } else if (i<64) {\n\t\t t += f2(br,cr,dr) + hr[3];\n\t } else {// if (i<80) {\n\t\t t += f1(br,cr,dr) + hr[4];\n\t }\n\t t = t|0;\n\t t = rotl(t,sr[i]) ;\n\t t = (t+er)|0;\n\t ar = er;\n\t er = dr;\n\t dr = rotl(cr, 10);\n\t cr = br;\n\t br = t;\n\t }\n\t // Intermediate hash value\n\t t = (H[1] + cl + dr)|0;\n\t H[1] = (H[2] + dl + er)|0;\n\t H[2] = (H[3] + el + ar)|0;\n\t H[3] = (H[4] + al + br)|0;\n\t H[4] = (H[0] + bl + cr)|0;\n\t H[0] = t;\n\t },\n\n\t _doFinalize: function () {\n\t // Shortcuts\n\t var data = this._data;\n\t var dataWords = data.words;\n\n\t var nBitsTotal = this._nDataBytes * 8;\n\t var nBitsLeft = data.sigBytes * 8;\n\n\t // Add padding\n\t dataWords[nBitsLeft >>> 5] |= 0x80 << (24 - nBitsLeft % 32);\n\t dataWords[(((nBitsLeft + 64) >>> 9) << 4) + 14] = (\n\t (((nBitsTotal << 8) | (nBitsTotal >>> 24)) & 0x00ff00ff) |\n\t (((nBitsTotal << 24) | (nBitsTotal >>> 8)) & 0xff00ff00)\n\t );\n\t data.sigBytes = (dataWords.length + 1) * 4;\n\n\t // Hash final blocks\n\t this._process();\n\n\t // Shortcuts\n\t var hash = this._hash;\n\t var H = hash.words;\n\n\t // Swap endian\n\t for (var i = 0; i < 5; i++) {\n\t // Shortcut\n\t var H_i = H[i];\n\n\t // Swap\n\t H[i] = (((H_i << 8) | (H_i >>> 24)) & 0x00ff00ff) |\n\t (((H_i << 24) | (H_i >>> 8)) & 0xff00ff00);\n\t }\n\n\t // Return final computed hash\n\t return hash;\n\t },\n\n\t clone: function () {\n\t var clone = Hasher.clone.call(this);\n\t clone._hash = this._hash.clone();\n\n\t return clone;\n\t }\n\t });\n\n\n\t function f1(x, y, z) {\n\t return ((x) ^ (y) ^ (z));\n\n\t }\n\n\t function f2(x, y, z) {\n\t return (((x)&(y)) | ((~x)&(z)));\n\t }\n\n\t function f3(x, y, z) {\n\t return (((x) | (~(y))) ^ (z));\n\t }\n\n\t function f4(x, y, z) {\n\t return (((x) & (z)) | ((y)&(~(z))));\n\t }\n\n\t function f5(x, y, z) {\n\t return ((x) ^ ((y) |(~(z))));\n\n\t }\n\n\t function rotl(x,n) {\n\t return (x<>>(32-n));\n\t }\n\n\n\t /**\n\t * Shortcut function to the hasher's object interface.\n\t *\n\t * @param {WordArray|string} message The message to hash.\n\t *\n\t * @return {WordArray} The hash.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hash = CryptoJS.RIPEMD160('message');\n\t * var hash = CryptoJS.RIPEMD160(wordArray);\n\t */\n\t C.RIPEMD160 = Hasher._createHelper(RIPEMD160);\n\n\t /**\n\t * Shortcut function to the HMAC's object interface.\n\t *\n\t * @param {WordArray|string} message The message to hash.\n\t * @param {WordArray|string} key The secret key.\n\t *\n\t * @return {WordArray} The HMAC.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hmac = CryptoJS.HmacRIPEMD160(message, key);\n\t */\n\t C.HmacRIPEMD160 = Hasher._createHmacHelper(RIPEMD160);\n\t}(Math));\n\n\n\treturn CryptoJS.RIPEMD160;\n\n}));",";(function (root, factory) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function () {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var WordArray = C_lib.WordArray;\n\t var Hasher = C_lib.Hasher;\n\t var C_algo = C.algo;\n\n\t // Reusable object\n\t var W = [];\n\n\t /**\n\t * SHA-1 hash algorithm.\n\t */\n\t var SHA1 = C_algo.SHA1 = Hasher.extend({\n\t _doReset: function () {\n\t this._hash = new WordArray.init([\n\t 0x67452301, 0xefcdab89,\n\t 0x98badcfe, 0x10325476,\n\t 0xc3d2e1f0\n\t ]);\n\t },\n\n\t _doProcessBlock: function (M, offset) {\n\t // Shortcut\n\t var H = this._hash.words;\n\n\t // Working variables\n\t var a = H[0];\n\t var b = H[1];\n\t var c = H[2];\n\t var d = H[3];\n\t var e = H[4];\n\n\t // Computation\n\t for (var i = 0; i < 80; i++) {\n\t if (i < 16) {\n\t W[i] = M[offset + i] | 0;\n\t } else {\n\t var n = W[i - 3] ^ W[i - 8] ^ W[i - 14] ^ W[i - 16];\n\t W[i] = (n << 1) | (n >>> 31);\n\t }\n\n\t var t = ((a << 5) | (a >>> 27)) + e + W[i];\n\t if (i < 20) {\n\t t += ((b & c) | (~b & d)) + 0x5a827999;\n\t } else if (i < 40) {\n\t t += (b ^ c ^ d) + 0x6ed9eba1;\n\t } else if (i < 60) {\n\t t += ((b & c) | (b & d) | (c & d)) - 0x70e44324;\n\t } else /* if (i < 80) */ {\n\t t += (b ^ c ^ d) - 0x359d3e2a;\n\t }\n\n\t e = d;\n\t d = c;\n\t c = (b << 30) | (b >>> 2);\n\t b = a;\n\t a = t;\n\t }\n\n\t // Intermediate hash value\n\t H[0] = (H[0] + a) | 0;\n\t H[1] = (H[1] + b) | 0;\n\t H[2] = (H[2] + c) | 0;\n\t H[3] = (H[3] + d) | 0;\n\t H[4] = (H[4] + e) | 0;\n\t },\n\n\t _doFinalize: function () {\n\t // Shortcuts\n\t var data = this._data;\n\t var dataWords = data.words;\n\n\t var nBitsTotal = this._nDataBytes * 8;\n\t var nBitsLeft = data.sigBytes * 8;\n\n\t // Add padding\n\t dataWords[nBitsLeft >>> 5] |= 0x80 << (24 - nBitsLeft % 32);\n\t dataWords[(((nBitsLeft + 64) >>> 9) << 4) + 14] = Math.floor(nBitsTotal / 0x100000000);\n\t dataWords[(((nBitsLeft + 64) >>> 9) << 4) + 15] = nBitsTotal;\n\t data.sigBytes = dataWords.length * 4;\n\n\t // Hash final blocks\n\t this._process();\n\n\t // Return final computed hash\n\t return this._hash;\n\t },\n\n\t clone: function () {\n\t var clone = Hasher.clone.call(this);\n\t clone._hash = this._hash.clone();\n\n\t return clone;\n\t }\n\t });\n\n\t /**\n\t * Shortcut function to the hasher's object interface.\n\t *\n\t * @param {WordArray|string} message The message to hash.\n\t *\n\t * @return {WordArray} The hash.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hash = CryptoJS.SHA1('message');\n\t * var hash = CryptoJS.SHA1(wordArray);\n\t */\n\t C.SHA1 = Hasher._createHelper(SHA1);\n\n\t /**\n\t * Shortcut function to the HMAC's object interface.\n\t *\n\t * @param {WordArray|string} message The message to hash.\n\t * @param {WordArray|string} key The secret key.\n\t *\n\t * @return {WordArray} The HMAC.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hmac = CryptoJS.HmacSHA1(message, key);\n\t */\n\t C.HmacSHA1 = Hasher._createHmacHelper(SHA1);\n\t}());\n\n\n\treturn CryptoJS.SHA1;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./sha256\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./sha256\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function () {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var WordArray = C_lib.WordArray;\n\t var C_algo = C.algo;\n\t var SHA256 = C_algo.SHA256;\n\n\t /**\n\t * SHA-224 hash algorithm.\n\t */\n\t var SHA224 = C_algo.SHA224 = SHA256.extend({\n\t _doReset: function () {\n\t this._hash = new WordArray.init([\n\t 0xc1059ed8, 0x367cd507, 0x3070dd17, 0xf70e5939,\n\t 0xffc00b31, 0x68581511, 0x64f98fa7, 0xbefa4fa4\n\t ]);\n\t },\n\n\t _doFinalize: function () {\n\t var hash = SHA256._doFinalize.call(this);\n\n\t hash.sigBytes -= 4;\n\n\t return hash;\n\t }\n\t });\n\n\t /**\n\t * Shortcut function to the hasher's object interface.\n\t *\n\t * @param {WordArray|string} message The message to hash.\n\t *\n\t * @return {WordArray} The hash.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hash = CryptoJS.SHA224('message');\n\t * var hash = CryptoJS.SHA224(wordArray);\n\t */\n\t C.SHA224 = SHA256._createHelper(SHA224);\n\n\t /**\n\t * Shortcut function to the HMAC's object interface.\n\t *\n\t * @param {WordArray|string} message The message to hash.\n\t * @param {WordArray|string} key The secret key.\n\t *\n\t * @return {WordArray} The HMAC.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hmac = CryptoJS.HmacSHA224(message, key);\n\t */\n\t C.HmacSHA224 = SHA256._createHmacHelper(SHA224);\n\t}());\n\n\n\treturn CryptoJS.SHA224;\n\n}));",";(function (root, factory) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function (Math) {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var WordArray = C_lib.WordArray;\n\t var Hasher = C_lib.Hasher;\n\t var C_algo = C.algo;\n\n\t // Initialization and round constants tables\n\t var H = [];\n\t var K = [];\n\n\t // Compute constants\n\t (function () {\n\t function isPrime(n) {\n\t var sqrtN = Math.sqrt(n);\n\t for (var factor = 2; factor <= sqrtN; factor++) {\n\t if (!(n % factor)) {\n\t return false;\n\t }\n\t }\n\n\t return true;\n\t }\n\n\t function getFractionalBits(n) {\n\t return ((n - (n | 0)) * 0x100000000) | 0;\n\t }\n\n\t var n = 2;\n\t var nPrime = 0;\n\t while (nPrime < 64) {\n\t if (isPrime(n)) {\n\t if (nPrime < 8) {\n\t H[nPrime] = getFractionalBits(Math.pow(n, 1 / 2));\n\t }\n\t K[nPrime] = getFractionalBits(Math.pow(n, 1 / 3));\n\n\t nPrime++;\n\t }\n\n\t n++;\n\t }\n\t }());\n\n\t // Reusable object\n\t var W = [];\n\n\t /**\n\t * SHA-256 hash algorithm.\n\t */\n\t var SHA256 = C_algo.SHA256 = Hasher.extend({\n\t _doReset: function () {\n\t this._hash = new WordArray.init(H.slice(0));\n\t },\n\n\t _doProcessBlock: function (M, offset) {\n\t // Shortcut\n\t var H = this._hash.words;\n\n\t // Working variables\n\t var a = H[0];\n\t var b = H[1];\n\t var c = H[2];\n\t var d = H[3];\n\t var e = H[4];\n\t var f = H[5];\n\t var g = H[6];\n\t var h = H[7];\n\n\t // Computation\n\t for (var i = 0; i < 64; i++) {\n\t if (i < 16) {\n\t W[i] = M[offset + i] | 0;\n\t } else {\n\t var gamma0x = W[i - 15];\n\t var gamma0 = ((gamma0x << 25) | (gamma0x >>> 7)) ^\n\t ((gamma0x << 14) | (gamma0x >>> 18)) ^\n\t (gamma0x >>> 3);\n\n\t var gamma1x = W[i - 2];\n\t var gamma1 = ((gamma1x << 15) | (gamma1x >>> 17)) ^\n\t ((gamma1x << 13) | (gamma1x >>> 19)) ^\n\t (gamma1x >>> 10);\n\n\t W[i] = gamma0 + W[i - 7] + gamma1 + W[i - 16];\n\t }\n\n\t var ch = (e & f) ^ (~e & g);\n\t var maj = (a & b) ^ (a & c) ^ (b & c);\n\n\t var sigma0 = ((a << 30) | (a >>> 2)) ^ ((a << 19) | (a >>> 13)) ^ ((a << 10) | (a >>> 22));\n\t var sigma1 = ((e << 26) | (e >>> 6)) ^ ((e << 21) | (e >>> 11)) ^ ((e << 7) | (e >>> 25));\n\n\t var t1 = h + sigma1 + ch + K[i] + W[i];\n\t var t2 = sigma0 + maj;\n\n\t h = g;\n\t g = f;\n\t f = e;\n\t e = (d + t1) | 0;\n\t d = c;\n\t c = b;\n\t b = a;\n\t a = (t1 + t2) | 0;\n\t }\n\n\t // Intermediate hash value\n\t H[0] = (H[0] + a) | 0;\n\t H[1] = (H[1] + b) | 0;\n\t H[2] = (H[2] + c) | 0;\n\t H[3] = (H[3] + d) | 0;\n\t H[4] = (H[4] + e) | 0;\n\t H[5] = (H[5] + f) | 0;\n\t H[6] = (H[6] + g) | 0;\n\t H[7] = (H[7] + h) | 0;\n\t },\n\n\t _doFinalize: function () {\n\t // Shortcuts\n\t var data = this._data;\n\t var dataWords = data.words;\n\n\t var nBitsTotal = this._nDataBytes * 8;\n\t var nBitsLeft = data.sigBytes * 8;\n\n\t // Add padding\n\t dataWords[nBitsLeft >>> 5] |= 0x80 << (24 - nBitsLeft % 32);\n\t dataWords[(((nBitsLeft + 64) >>> 9) << 4) + 14] = Math.floor(nBitsTotal / 0x100000000);\n\t dataWords[(((nBitsLeft + 64) >>> 9) << 4) + 15] = nBitsTotal;\n\t data.sigBytes = dataWords.length * 4;\n\n\t // Hash final blocks\n\t this._process();\n\n\t // Return final computed hash\n\t return this._hash;\n\t },\n\n\t clone: function () {\n\t var clone = Hasher.clone.call(this);\n\t clone._hash = this._hash.clone();\n\n\t return clone;\n\t }\n\t });\n\n\t /**\n\t * Shortcut function to the hasher's object interface.\n\t *\n\t * @param {WordArray|string} message The message to hash.\n\t *\n\t * @return {WordArray} The hash.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hash = CryptoJS.SHA256('message');\n\t * var hash = CryptoJS.SHA256(wordArray);\n\t */\n\t C.SHA256 = Hasher._createHelper(SHA256);\n\n\t /**\n\t * Shortcut function to the HMAC's object interface.\n\t *\n\t * @param {WordArray|string} message The message to hash.\n\t * @param {WordArray|string} key The secret key.\n\t *\n\t * @return {WordArray} The HMAC.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hmac = CryptoJS.HmacSHA256(message, key);\n\t */\n\t C.HmacSHA256 = Hasher._createHmacHelper(SHA256);\n\t}(Math));\n\n\n\treturn CryptoJS.SHA256;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./x64-core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./x64-core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function (Math) {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var WordArray = C_lib.WordArray;\n\t var Hasher = C_lib.Hasher;\n\t var C_x64 = C.x64;\n\t var X64Word = C_x64.Word;\n\t var C_algo = C.algo;\n\n\t // Constants tables\n\t var RHO_OFFSETS = [];\n\t var PI_INDEXES = [];\n\t var ROUND_CONSTANTS = [];\n\n\t // Compute Constants\n\t (function () {\n\t // Compute rho offset constants\n\t var x = 1, y = 0;\n\t for (var t = 0; t < 24; t++) {\n\t RHO_OFFSETS[x + 5 * y] = ((t + 1) * (t + 2) / 2) % 64;\n\n\t var newX = y % 5;\n\t var newY = (2 * x + 3 * y) % 5;\n\t x = newX;\n\t y = newY;\n\t }\n\n\t // Compute pi index constants\n\t for (var x = 0; x < 5; x++) {\n\t for (var y = 0; y < 5; y++) {\n\t PI_INDEXES[x + 5 * y] = y + ((2 * x + 3 * y) % 5) * 5;\n\t }\n\t }\n\n\t // Compute round constants\n\t var LFSR = 0x01;\n\t for (var i = 0; i < 24; i++) {\n\t var roundConstantMsw = 0;\n\t var roundConstantLsw = 0;\n\n\t for (var j = 0; j < 7; j++) {\n\t if (LFSR & 0x01) {\n\t var bitPosition = (1 << j) - 1;\n\t if (bitPosition < 32) {\n\t roundConstantLsw ^= 1 << bitPosition;\n\t } else /* if (bitPosition >= 32) */ {\n\t roundConstantMsw ^= 1 << (bitPosition - 32);\n\t }\n\t }\n\n\t // Compute next LFSR\n\t if (LFSR & 0x80) {\n\t // Primitive polynomial over GF(2): x^8 + x^6 + x^5 + x^4 + 1\n\t LFSR = (LFSR << 1) ^ 0x71;\n\t } else {\n\t LFSR <<= 1;\n\t }\n\t }\n\n\t ROUND_CONSTANTS[i] = X64Word.create(roundConstantMsw, roundConstantLsw);\n\t }\n\t }());\n\n\t // Reusable objects for temporary values\n\t var T = [];\n\t (function () {\n\t for (var i = 0; i < 25; i++) {\n\t T[i] = X64Word.create();\n\t }\n\t }());\n\n\t /**\n\t * SHA-3 hash algorithm.\n\t */\n\t var SHA3 = C_algo.SHA3 = Hasher.extend({\n\t /**\n\t * Configuration options.\n\t *\n\t * @property {number} outputLength\n\t * The desired number of bits in the output hash.\n\t * Only values permitted are: 224, 256, 384, 512.\n\t * Default: 512\n\t */\n\t cfg: Hasher.cfg.extend({\n\t outputLength: 512\n\t }),\n\n\t _doReset: function () {\n\t var state = this._state = []\n\t for (var i = 0; i < 25; i++) {\n\t state[i] = new X64Word.init();\n\t }\n\n\t this.blockSize = (1600 - 2 * this.cfg.outputLength) / 32;\n\t },\n\n\t _doProcessBlock: function (M, offset) {\n\t // Shortcuts\n\t var state = this._state;\n\t var nBlockSizeLanes = this.blockSize / 2;\n\n\t // Absorb\n\t for (var i = 0; i < nBlockSizeLanes; i++) {\n\t // Shortcuts\n\t var M2i = M[offset + 2 * i];\n\t var M2i1 = M[offset + 2 * i + 1];\n\n\t // Swap endian\n\t M2i = (\n\t (((M2i << 8) | (M2i >>> 24)) & 0x00ff00ff) |\n\t (((M2i << 24) | (M2i >>> 8)) & 0xff00ff00)\n\t );\n\t M2i1 = (\n\t (((M2i1 << 8) | (M2i1 >>> 24)) & 0x00ff00ff) |\n\t (((M2i1 << 24) | (M2i1 >>> 8)) & 0xff00ff00)\n\t );\n\n\t // Absorb message into state\n\t var lane = state[i];\n\t lane.high ^= M2i1;\n\t lane.low ^= M2i;\n\t }\n\n\t // Rounds\n\t for (var round = 0; round < 24; round++) {\n\t // Theta\n\t for (var x = 0; x < 5; x++) {\n\t // Mix column lanes\n\t var tMsw = 0, tLsw = 0;\n\t for (var y = 0; y < 5; y++) {\n\t var lane = state[x + 5 * y];\n\t tMsw ^= lane.high;\n\t tLsw ^= lane.low;\n\t }\n\n\t // Temporary values\n\t var Tx = T[x];\n\t Tx.high = tMsw;\n\t Tx.low = tLsw;\n\t }\n\t for (var x = 0; x < 5; x++) {\n\t // Shortcuts\n\t var Tx4 = T[(x + 4) % 5];\n\t var Tx1 = T[(x + 1) % 5];\n\t var Tx1Msw = Tx1.high;\n\t var Tx1Lsw = Tx1.low;\n\n\t // Mix surrounding columns\n\t var tMsw = Tx4.high ^ ((Tx1Msw << 1) | (Tx1Lsw >>> 31));\n\t var tLsw = Tx4.low ^ ((Tx1Lsw << 1) | (Tx1Msw >>> 31));\n\t for (var y = 0; y < 5; y++) {\n\t var lane = state[x + 5 * y];\n\t lane.high ^= tMsw;\n\t lane.low ^= tLsw;\n\t }\n\t }\n\n\t // Rho Pi\n\t for (var laneIndex = 1; laneIndex < 25; laneIndex++) {\n\t var tMsw;\n\t var tLsw;\n\n\t // Shortcuts\n\t var lane = state[laneIndex];\n\t var laneMsw = lane.high;\n\t var laneLsw = lane.low;\n\t var rhoOffset = RHO_OFFSETS[laneIndex];\n\n\t // Rotate lanes\n\t if (rhoOffset < 32) {\n\t tMsw = (laneMsw << rhoOffset) | (laneLsw >>> (32 - rhoOffset));\n\t tLsw = (laneLsw << rhoOffset) | (laneMsw >>> (32 - rhoOffset));\n\t } else /* if (rhoOffset >= 32) */ {\n\t tMsw = (laneLsw << (rhoOffset - 32)) | (laneMsw >>> (64 - rhoOffset));\n\t tLsw = (laneMsw << (rhoOffset - 32)) | (laneLsw >>> (64 - rhoOffset));\n\t }\n\n\t // Transpose lanes\n\t var TPiLane = T[PI_INDEXES[laneIndex]];\n\t TPiLane.high = tMsw;\n\t TPiLane.low = tLsw;\n\t }\n\n\t // Rho pi at x = y = 0\n\t var T0 = T[0];\n\t var state0 = state[0];\n\t T0.high = state0.high;\n\t T0.low = state0.low;\n\n\t // Chi\n\t for (var x = 0; x < 5; x++) {\n\t for (var y = 0; y < 5; y++) {\n\t // Shortcuts\n\t var laneIndex = x + 5 * y;\n\t var lane = state[laneIndex];\n\t var TLane = T[laneIndex];\n\t var Tx1Lane = T[((x + 1) % 5) + 5 * y];\n\t var Tx2Lane = T[((x + 2) % 5) + 5 * y];\n\n\t // Mix rows\n\t lane.high = TLane.high ^ (~Tx1Lane.high & Tx2Lane.high);\n\t lane.low = TLane.low ^ (~Tx1Lane.low & Tx2Lane.low);\n\t }\n\t }\n\n\t // Iota\n\t var lane = state[0];\n\t var roundConstant = ROUND_CONSTANTS[round];\n\t lane.high ^= roundConstant.high;\n\t lane.low ^= roundConstant.low;\n\t }\n\t },\n\n\t _doFinalize: function () {\n\t // Shortcuts\n\t var data = this._data;\n\t var dataWords = data.words;\n\t var nBitsTotal = this._nDataBytes * 8;\n\t var nBitsLeft = data.sigBytes * 8;\n\t var blockSizeBits = this.blockSize * 32;\n\n\t // Add padding\n\t dataWords[nBitsLeft >>> 5] |= 0x1 << (24 - nBitsLeft % 32);\n\t dataWords[((Math.ceil((nBitsLeft + 1) / blockSizeBits) * blockSizeBits) >>> 5) - 1] |= 0x80;\n\t data.sigBytes = dataWords.length * 4;\n\n\t // Hash final blocks\n\t this._process();\n\n\t // Shortcuts\n\t var state = this._state;\n\t var outputLengthBytes = this.cfg.outputLength / 8;\n\t var outputLengthLanes = outputLengthBytes / 8;\n\n\t // Squeeze\n\t var hashWords = [];\n\t for (var i = 0; i < outputLengthLanes; i++) {\n\t // Shortcuts\n\t var lane = state[i];\n\t var laneMsw = lane.high;\n\t var laneLsw = lane.low;\n\n\t // Swap endian\n\t laneMsw = (\n\t (((laneMsw << 8) | (laneMsw >>> 24)) & 0x00ff00ff) |\n\t (((laneMsw << 24) | (laneMsw >>> 8)) & 0xff00ff00)\n\t );\n\t laneLsw = (\n\t (((laneLsw << 8) | (laneLsw >>> 24)) & 0x00ff00ff) |\n\t (((laneLsw << 24) | (laneLsw >>> 8)) & 0xff00ff00)\n\t );\n\n\t // Squeeze state to retrieve hash\n\t hashWords.push(laneLsw);\n\t hashWords.push(laneMsw);\n\t }\n\n\t // Return final computed hash\n\t return new WordArray.init(hashWords, outputLengthBytes);\n\t },\n\n\t clone: function () {\n\t var clone = Hasher.clone.call(this);\n\n\t var state = clone._state = this._state.slice(0);\n\t for (var i = 0; i < 25; i++) {\n\t state[i] = state[i].clone();\n\t }\n\n\t return clone;\n\t }\n\t });\n\n\t /**\n\t * Shortcut function to the hasher's object interface.\n\t *\n\t * @param {WordArray|string} message The message to hash.\n\t *\n\t * @return {WordArray} The hash.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hash = CryptoJS.SHA3('message');\n\t * var hash = CryptoJS.SHA3(wordArray);\n\t */\n\t C.SHA3 = Hasher._createHelper(SHA3);\n\n\t /**\n\t * Shortcut function to the HMAC's object interface.\n\t *\n\t * @param {WordArray|string} message The message to hash.\n\t * @param {WordArray|string} key The secret key.\n\t *\n\t * @return {WordArray} The HMAC.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hmac = CryptoJS.HmacSHA3(message, key);\n\t */\n\t C.HmacSHA3 = Hasher._createHmacHelper(SHA3);\n\t}(Math));\n\n\n\treturn CryptoJS.SHA3;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./x64-core\"), require(\"./sha512\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./x64-core\", \"./sha512\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function () {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_x64 = C.x64;\n\t var X64Word = C_x64.Word;\n\t var X64WordArray = C_x64.WordArray;\n\t var C_algo = C.algo;\n\t var SHA512 = C_algo.SHA512;\n\n\t /**\n\t * SHA-384 hash algorithm.\n\t */\n\t var SHA384 = C_algo.SHA384 = SHA512.extend({\n\t _doReset: function () {\n\t this._hash = new X64WordArray.init([\n\t new X64Word.init(0xcbbb9d5d, 0xc1059ed8), new X64Word.init(0x629a292a, 0x367cd507),\n\t new X64Word.init(0x9159015a, 0x3070dd17), new X64Word.init(0x152fecd8, 0xf70e5939),\n\t new X64Word.init(0x67332667, 0xffc00b31), new X64Word.init(0x8eb44a87, 0x68581511),\n\t new X64Word.init(0xdb0c2e0d, 0x64f98fa7), new X64Word.init(0x47b5481d, 0xbefa4fa4)\n\t ]);\n\t },\n\n\t _doFinalize: function () {\n\t var hash = SHA512._doFinalize.call(this);\n\n\t hash.sigBytes -= 16;\n\n\t return hash;\n\t }\n\t });\n\n\t /**\n\t * Shortcut function to the hasher's object interface.\n\t *\n\t * @param {WordArray|string} message The message to hash.\n\t *\n\t * @return {WordArray} The hash.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hash = CryptoJS.SHA384('message');\n\t * var hash = CryptoJS.SHA384(wordArray);\n\t */\n\t C.SHA384 = SHA512._createHelper(SHA384);\n\n\t /**\n\t * Shortcut function to the HMAC's object interface.\n\t *\n\t * @param {WordArray|string} message The message to hash.\n\t * @param {WordArray|string} key The secret key.\n\t *\n\t * @return {WordArray} The HMAC.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hmac = CryptoJS.HmacSHA384(message, key);\n\t */\n\t C.HmacSHA384 = SHA512._createHmacHelper(SHA384);\n\t}());\n\n\n\treturn CryptoJS.SHA384;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./x64-core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./x64-core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function () {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var Hasher = C_lib.Hasher;\n\t var C_x64 = C.x64;\n\t var X64Word = C_x64.Word;\n\t var X64WordArray = C_x64.WordArray;\n\t var C_algo = C.algo;\n\n\t function X64Word_create() {\n\t return X64Word.create.apply(X64Word, arguments);\n\t }\n\n\t // Constants\n\t var K = [\n\t X64Word_create(0x428a2f98, 0xd728ae22), X64Word_create(0x71374491, 0x23ef65cd),\n\t X64Word_create(0xb5c0fbcf, 0xec4d3b2f), X64Word_create(0xe9b5dba5, 0x8189dbbc),\n\t X64Word_create(0x3956c25b, 0xf348b538), X64Word_create(0x59f111f1, 0xb605d019),\n\t X64Word_create(0x923f82a4, 0xaf194f9b), X64Word_create(0xab1c5ed5, 0xda6d8118),\n\t X64Word_create(0xd807aa98, 0xa3030242), X64Word_create(0x12835b01, 0x45706fbe),\n\t X64Word_create(0x243185be, 0x4ee4b28c), X64Word_create(0x550c7dc3, 0xd5ffb4e2),\n\t X64Word_create(0x72be5d74, 0xf27b896f), X64Word_create(0x80deb1fe, 0x3b1696b1),\n\t X64Word_create(0x9bdc06a7, 0x25c71235), X64Word_create(0xc19bf174, 0xcf692694),\n\t X64Word_create(0xe49b69c1, 0x9ef14ad2), X64Word_create(0xefbe4786, 0x384f25e3),\n\t X64Word_create(0x0fc19dc6, 0x8b8cd5b5), X64Word_create(0x240ca1cc, 0x77ac9c65),\n\t X64Word_create(0x2de92c6f, 0x592b0275), X64Word_create(0x4a7484aa, 0x6ea6e483),\n\t X64Word_create(0x5cb0a9dc, 0xbd41fbd4), X64Word_create(0x76f988da, 0x831153b5),\n\t X64Word_create(0x983e5152, 0xee66dfab), X64Word_create(0xa831c66d, 0x2db43210),\n\t X64Word_create(0xb00327c8, 0x98fb213f), X64Word_create(0xbf597fc7, 0xbeef0ee4),\n\t X64Word_create(0xc6e00bf3, 0x3da88fc2), X64Word_create(0xd5a79147, 0x930aa725),\n\t X64Word_create(0x06ca6351, 0xe003826f), X64Word_create(0x14292967, 0x0a0e6e70),\n\t X64Word_create(0x27b70a85, 0x46d22ffc), X64Word_create(0x2e1b2138, 0x5c26c926),\n\t X64Word_create(0x4d2c6dfc, 0x5ac42aed), X64Word_create(0x53380d13, 0x9d95b3df),\n\t X64Word_create(0x650a7354, 0x8baf63de), X64Word_create(0x766a0abb, 0x3c77b2a8),\n\t X64Word_create(0x81c2c92e, 0x47edaee6), X64Word_create(0x92722c85, 0x1482353b),\n\t X64Word_create(0xa2bfe8a1, 0x4cf10364), X64Word_create(0xa81a664b, 0xbc423001),\n\t X64Word_create(0xc24b8b70, 0xd0f89791), X64Word_create(0xc76c51a3, 0x0654be30),\n\t X64Word_create(0xd192e819, 0xd6ef5218), X64Word_create(0xd6990624, 0x5565a910),\n\t X64Word_create(0xf40e3585, 0x5771202a), X64Word_create(0x106aa070, 0x32bbd1b8),\n\t X64Word_create(0x19a4c116, 0xb8d2d0c8), X64Word_create(0x1e376c08, 0x5141ab53),\n\t X64Word_create(0x2748774c, 0xdf8eeb99), X64Word_create(0x34b0bcb5, 0xe19b48a8),\n\t X64Word_create(0x391c0cb3, 0xc5c95a63), X64Word_create(0x4ed8aa4a, 0xe3418acb),\n\t X64Word_create(0x5b9cca4f, 0x7763e373), X64Word_create(0x682e6ff3, 0xd6b2b8a3),\n\t X64Word_create(0x748f82ee, 0x5defb2fc), X64Word_create(0x78a5636f, 0x43172f60),\n\t X64Word_create(0x84c87814, 0xa1f0ab72), X64Word_create(0x8cc70208, 0x1a6439ec),\n\t X64Word_create(0x90befffa, 0x23631e28), X64Word_create(0xa4506ceb, 0xde82bde9),\n\t X64Word_create(0xbef9a3f7, 0xb2c67915), X64Word_create(0xc67178f2, 0xe372532b),\n\t X64Word_create(0xca273ece, 0xea26619c), X64Word_create(0xd186b8c7, 0x21c0c207),\n\t X64Word_create(0xeada7dd6, 0xcde0eb1e), X64Word_create(0xf57d4f7f, 0xee6ed178),\n\t X64Word_create(0x06f067aa, 0x72176fba), X64Word_create(0x0a637dc5, 0xa2c898a6),\n\t X64Word_create(0x113f9804, 0xbef90dae), X64Word_create(0x1b710b35, 0x131c471b),\n\t X64Word_create(0x28db77f5, 0x23047d84), X64Word_create(0x32caab7b, 0x40c72493),\n\t X64Word_create(0x3c9ebe0a, 0x15c9bebc), X64Word_create(0x431d67c4, 0x9c100d4c),\n\t X64Word_create(0x4cc5d4be, 0xcb3e42b6), X64Word_create(0x597f299c, 0xfc657e2a),\n\t X64Word_create(0x5fcb6fab, 0x3ad6faec), X64Word_create(0x6c44198c, 0x4a475817)\n\t ];\n\n\t // Reusable objects\n\t var W = [];\n\t (function () {\n\t for (var i = 0; i < 80; i++) {\n\t W[i] = X64Word_create();\n\t }\n\t }());\n\n\t /**\n\t * SHA-512 hash algorithm.\n\t */\n\t var SHA512 = C_algo.SHA512 = Hasher.extend({\n\t _doReset: function () {\n\t this._hash = new X64WordArray.init([\n\t new X64Word.init(0x6a09e667, 0xf3bcc908), new X64Word.init(0xbb67ae85, 0x84caa73b),\n\t new X64Word.init(0x3c6ef372, 0xfe94f82b), new X64Word.init(0xa54ff53a, 0x5f1d36f1),\n\t new X64Word.init(0x510e527f, 0xade682d1), new X64Word.init(0x9b05688c, 0x2b3e6c1f),\n\t new X64Word.init(0x1f83d9ab, 0xfb41bd6b), new X64Word.init(0x5be0cd19, 0x137e2179)\n\t ]);\n\t },\n\n\t _doProcessBlock: function (M, offset) {\n\t // Shortcuts\n\t var H = this._hash.words;\n\n\t var H0 = H[0];\n\t var H1 = H[1];\n\t var H2 = H[2];\n\t var H3 = H[3];\n\t var H4 = H[4];\n\t var H5 = H[5];\n\t var H6 = H[6];\n\t var H7 = H[7];\n\n\t var H0h = H0.high;\n\t var H0l = H0.low;\n\t var H1h = H1.high;\n\t var H1l = H1.low;\n\t var H2h = H2.high;\n\t var H2l = H2.low;\n\t var H3h = H3.high;\n\t var H3l = H3.low;\n\t var H4h = H4.high;\n\t var H4l = H4.low;\n\t var H5h = H5.high;\n\t var H5l = H5.low;\n\t var H6h = H6.high;\n\t var H6l = H6.low;\n\t var H7h = H7.high;\n\t var H7l = H7.low;\n\n\t // Working variables\n\t var ah = H0h;\n\t var al = H0l;\n\t var bh = H1h;\n\t var bl = H1l;\n\t var ch = H2h;\n\t var cl = H2l;\n\t var dh = H3h;\n\t var dl = H3l;\n\t var eh = H4h;\n\t var el = H4l;\n\t var fh = H5h;\n\t var fl = H5l;\n\t var gh = H6h;\n\t var gl = H6l;\n\t var hh = H7h;\n\t var hl = H7l;\n\n\t // Rounds\n\t for (var i = 0; i < 80; i++) {\n\t var Wil;\n\t var Wih;\n\n\t // Shortcut\n\t var Wi = W[i];\n\n\t // Extend message\n\t if (i < 16) {\n\t Wih = Wi.high = M[offset + i * 2] | 0;\n\t Wil = Wi.low = M[offset + i * 2 + 1] | 0;\n\t } else {\n\t // Gamma0\n\t var gamma0x = W[i - 15];\n\t var gamma0xh = gamma0x.high;\n\t var gamma0xl = gamma0x.low;\n\t var gamma0h = ((gamma0xh >>> 1) | (gamma0xl << 31)) ^ ((gamma0xh >>> 8) | (gamma0xl << 24)) ^ (gamma0xh >>> 7);\n\t var gamma0l = ((gamma0xl >>> 1) | (gamma0xh << 31)) ^ ((gamma0xl >>> 8) | (gamma0xh << 24)) ^ ((gamma0xl >>> 7) | (gamma0xh << 25));\n\n\t // Gamma1\n\t var gamma1x = W[i - 2];\n\t var gamma1xh = gamma1x.high;\n\t var gamma1xl = gamma1x.low;\n\t var gamma1h = ((gamma1xh >>> 19) | (gamma1xl << 13)) ^ ((gamma1xh << 3) | (gamma1xl >>> 29)) ^ (gamma1xh >>> 6);\n\t var gamma1l = ((gamma1xl >>> 19) | (gamma1xh << 13)) ^ ((gamma1xl << 3) | (gamma1xh >>> 29)) ^ ((gamma1xl >>> 6) | (gamma1xh << 26));\n\n\t // W[i] = gamma0 + W[i - 7] + gamma1 + W[i - 16]\n\t var Wi7 = W[i - 7];\n\t var Wi7h = Wi7.high;\n\t var Wi7l = Wi7.low;\n\n\t var Wi16 = W[i - 16];\n\t var Wi16h = Wi16.high;\n\t var Wi16l = Wi16.low;\n\n\t Wil = gamma0l + Wi7l;\n\t Wih = gamma0h + Wi7h + ((Wil >>> 0) < (gamma0l >>> 0) ? 1 : 0);\n\t Wil = Wil + gamma1l;\n\t Wih = Wih + gamma1h + ((Wil >>> 0) < (gamma1l >>> 0) ? 1 : 0);\n\t Wil = Wil + Wi16l;\n\t Wih = Wih + Wi16h + ((Wil >>> 0) < (Wi16l >>> 0) ? 1 : 0);\n\n\t Wi.high = Wih;\n\t Wi.low = Wil;\n\t }\n\n\t var chh = (eh & fh) ^ (~eh & gh);\n\t var chl = (el & fl) ^ (~el & gl);\n\t var majh = (ah & bh) ^ (ah & ch) ^ (bh & ch);\n\t var majl = (al & bl) ^ (al & cl) ^ (bl & cl);\n\n\t var sigma0h = ((ah >>> 28) | (al << 4)) ^ ((ah << 30) | (al >>> 2)) ^ ((ah << 25) | (al >>> 7));\n\t var sigma0l = ((al >>> 28) | (ah << 4)) ^ ((al << 30) | (ah >>> 2)) ^ ((al << 25) | (ah >>> 7));\n\t var sigma1h = ((eh >>> 14) | (el << 18)) ^ ((eh >>> 18) | (el << 14)) ^ ((eh << 23) | (el >>> 9));\n\t var sigma1l = ((el >>> 14) | (eh << 18)) ^ ((el >>> 18) | (eh << 14)) ^ ((el << 23) | (eh >>> 9));\n\n\t // t1 = h + sigma1 + ch + K[i] + W[i]\n\t var Ki = K[i];\n\t var Kih = Ki.high;\n\t var Kil = Ki.low;\n\n\t var t1l = hl + sigma1l;\n\t var t1h = hh + sigma1h + ((t1l >>> 0) < (hl >>> 0) ? 1 : 0);\n\t var t1l = t1l + chl;\n\t var t1h = t1h + chh + ((t1l >>> 0) < (chl >>> 0) ? 1 : 0);\n\t var t1l = t1l + Kil;\n\t var t1h = t1h + Kih + ((t1l >>> 0) < (Kil >>> 0) ? 1 : 0);\n\t var t1l = t1l + Wil;\n\t var t1h = t1h + Wih + ((t1l >>> 0) < (Wil >>> 0) ? 1 : 0);\n\n\t // t2 = sigma0 + maj\n\t var t2l = sigma0l + majl;\n\t var t2h = sigma0h + majh + ((t2l >>> 0) < (sigma0l >>> 0) ? 1 : 0);\n\n\t // Update working variables\n\t hh = gh;\n\t hl = gl;\n\t gh = fh;\n\t gl = fl;\n\t fh = eh;\n\t fl = el;\n\t el = (dl + t1l) | 0;\n\t eh = (dh + t1h + ((el >>> 0) < (dl >>> 0) ? 1 : 0)) | 0;\n\t dh = ch;\n\t dl = cl;\n\t ch = bh;\n\t cl = bl;\n\t bh = ah;\n\t bl = al;\n\t al = (t1l + t2l) | 0;\n\t ah = (t1h + t2h + ((al >>> 0) < (t1l >>> 0) ? 1 : 0)) | 0;\n\t }\n\n\t // Intermediate hash value\n\t H0l = H0.low = (H0l + al);\n\t H0.high = (H0h + ah + ((H0l >>> 0) < (al >>> 0) ? 1 : 0));\n\t H1l = H1.low = (H1l + bl);\n\t H1.high = (H1h + bh + ((H1l >>> 0) < (bl >>> 0) ? 1 : 0));\n\t H2l = H2.low = (H2l + cl);\n\t H2.high = (H2h + ch + ((H2l >>> 0) < (cl >>> 0) ? 1 : 0));\n\t H3l = H3.low = (H3l + dl);\n\t H3.high = (H3h + dh + ((H3l >>> 0) < (dl >>> 0) ? 1 : 0));\n\t H4l = H4.low = (H4l + el);\n\t H4.high = (H4h + eh + ((H4l >>> 0) < (el >>> 0) ? 1 : 0));\n\t H5l = H5.low = (H5l + fl);\n\t H5.high = (H5h + fh + ((H5l >>> 0) < (fl >>> 0) ? 1 : 0));\n\t H6l = H6.low = (H6l + gl);\n\t H6.high = (H6h + gh + ((H6l >>> 0) < (gl >>> 0) ? 1 : 0));\n\t H7l = H7.low = (H7l + hl);\n\t H7.high = (H7h + hh + ((H7l >>> 0) < (hl >>> 0) ? 1 : 0));\n\t },\n\n\t _doFinalize: function () {\n\t // Shortcuts\n\t var data = this._data;\n\t var dataWords = data.words;\n\n\t var nBitsTotal = this._nDataBytes * 8;\n\t var nBitsLeft = data.sigBytes * 8;\n\n\t // Add padding\n\t dataWords[nBitsLeft >>> 5] |= 0x80 << (24 - nBitsLeft % 32);\n\t dataWords[(((nBitsLeft + 128) >>> 10) << 5) + 30] = Math.floor(nBitsTotal / 0x100000000);\n\t dataWords[(((nBitsLeft + 128) >>> 10) << 5) + 31] = nBitsTotal;\n\t data.sigBytes = dataWords.length * 4;\n\n\t // Hash final blocks\n\t this._process();\n\n\t // Convert hash to 32-bit word array before returning\n\t var hash = this._hash.toX32();\n\n\t // Return final computed hash\n\t return hash;\n\t },\n\n\t clone: function () {\n\t var clone = Hasher.clone.call(this);\n\t clone._hash = this._hash.clone();\n\n\t return clone;\n\t },\n\n\t blockSize: 1024/32\n\t });\n\n\t /**\n\t * Shortcut function to the hasher's object interface.\n\t *\n\t * @param {WordArray|string} message The message to hash.\n\t *\n\t * @return {WordArray} The hash.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hash = CryptoJS.SHA512('message');\n\t * var hash = CryptoJS.SHA512(wordArray);\n\t */\n\t C.SHA512 = Hasher._createHelper(SHA512);\n\n\t /**\n\t * Shortcut function to the HMAC's object interface.\n\t *\n\t * @param {WordArray|string} message The message to hash.\n\t * @param {WordArray|string} key The secret key.\n\t *\n\t * @return {WordArray} The HMAC.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hmac = CryptoJS.HmacSHA512(message, key);\n\t */\n\t C.HmacSHA512 = Hasher._createHmacHelper(SHA512);\n\t}());\n\n\n\treturn CryptoJS.SHA512;\n\n}));",";(function (root, factory, undef) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"), require(\"./enc-base64\"), require(\"./md5\"), require(\"./evpkdf\"), require(\"./cipher-core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\", \"./enc-base64\", \"./md5\", \"./evpkdf\", \"./cipher-core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function () {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var WordArray = C_lib.WordArray;\n\t var BlockCipher = C_lib.BlockCipher;\n\t var C_algo = C.algo;\n\n\t // Permuted Choice 1 constants\n\t var PC1 = [\n\t 57, 49, 41, 33, 25, 17, 9, 1,\n\t 58, 50, 42, 34, 26, 18, 10, 2,\n\t 59, 51, 43, 35, 27, 19, 11, 3,\n\t 60, 52, 44, 36, 63, 55, 47, 39,\n\t 31, 23, 15, 7, 62, 54, 46, 38,\n\t 30, 22, 14, 6, 61, 53, 45, 37,\n\t 29, 21, 13, 5, 28, 20, 12, 4\n\t ];\n\n\t // Permuted Choice 2 constants\n\t var PC2 = [\n\t 14, 17, 11, 24, 1, 5,\n\t 3, 28, 15, 6, 21, 10,\n\t 23, 19, 12, 4, 26, 8,\n\t 16, 7, 27, 20, 13, 2,\n\t 41, 52, 31, 37, 47, 55,\n\t 30, 40, 51, 45, 33, 48,\n\t 44, 49, 39, 56, 34, 53,\n\t 46, 42, 50, 36, 29, 32\n\t ];\n\n\t // Cumulative bit shift constants\n\t var BIT_SHIFTS = [1, 2, 4, 6, 8, 10, 12, 14, 15, 17, 19, 21, 23, 25, 27, 28];\n\n\t // SBOXes and round permutation constants\n\t var SBOX_P = [\n\t {\n\t 0x0: 0x808200,\n\t 0x10000000: 0x8000,\n\t 0x20000000: 0x808002,\n\t 0x30000000: 0x2,\n\t 0x40000000: 0x200,\n\t 0x50000000: 0x808202,\n\t 0x60000000: 0x800202,\n\t 0x70000000: 0x800000,\n\t 0x80000000: 0x202,\n\t 0x90000000: 0x800200,\n\t 0xa0000000: 0x8200,\n\t 0xb0000000: 0x808000,\n\t 0xc0000000: 0x8002,\n\t 0xd0000000: 0x800002,\n\t 0xe0000000: 0x0,\n\t 0xf0000000: 0x8202,\n\t 0x8000000: 0x0,\n\t 0x18000000: 0x808202,\n\t 0x28000000: 0x8202,\n\t 0x38000000: 0x8000,\n\t 0x48000000: 0x808200,\n\t 0x58000000: 0x200,\n\t 0x68000000: 0x808002,\n\t 0x78000000: 0x2,\n\t 0x88000000: 0x800200,\n\t 0x98000000: 0x8200,\n\t 0xa8000000: 0x808000,\n\t 0xb8000000: 0x800202,\n\t 0xc8000000: 0x800002,\n\t 0xd8000000: 0x8002,\n\t 0xe8000000: 0x202,\n\t 0xf8000000: 0x800000,\n\t 0x1: 0x8000,\n\t 0x10000001: 0x2,\n\t 0x20000001: 0x808200,\n\t 0x30000001: 0x800000,\n\t 0x40000001: 0x808002,\n\t 0x50000001: 0x8200,\n\t 0x60000001: 0x200,\n\t 0x70000001: 0x800202,\n\t 0x80000001: 0x808202,\n\t 0x90000001: 0x808000,\n\t 0xa0000001: 0x800002,\n\t 0xb0000001: 0x8202,\n\t 0xc0000001: 0x202,\n\t 0xd0000001: 0x800200,\n\t 0xe0000001: 0x8002,\n\t 0xf0000001: 0x0,\n\t 0x8000001: 0x808202,\n\t 0x18000001: 0x808000,\n\t 0x28000001: 0x800000,\n\t 0x38000001: 0x200,\n\t 0x48000001: 0x8000,\n\t 0x58000001: 0x800002,\n\t 0x68000001: 0x2,\n\t 0x78000001: 0x8202,\n\t 0x88000001: 0x8002,\n\t 0x98000001: 0x800202,\n\t 0xa8000001: 0x202,\n\t 0xb8000001: 0x808200,\n\t 0xc8000001: 0x800200,\n\t 0xd8000001: 0x0,\n\t 0xe8000001: 0x8200,\n\t 0xf8000001: 0x808002\n\t },\n\t {\n\t 0x0: 0x40084010,\n\t 0x1000000: 0x4000,\n\t 0x2000000: 0x80000,\n\t 0x3000000: 0x40080010,\n\t 0x4000000: 0x40000010,\n\t 0x5000000: 0x40084000,\n\t 0x6000000: 0x40004000,\n\t 0x7000000: 0x10,\n\t 0x8000000: 0x84000,\n\t 0x9000000: 0x40004010,\n\t 0xa000000: 0x40000000,\n\t 0xb000000: 0x84010,\n\t 0xc000000: 0x80010,\n\t 0xd000000: 0x0,\n\t 0xe000000: 0x4010,\n\t 0xf000000: 0x40080000,\n\t 0x800000: 0x40004000,\n\t 0x1800000: 0x84010,\n\t 0x2800000: 0x10,\n\t 0x3800000: 0x40004010,\n\t 0x4800000: 0x40084010,\n\t 0x5800000: 0x40000000,\n\t 0x6800000: 0x80000,\n\t 0x7800000: 0x40080010,\n\t 0x8800000: 0x80010,\n\t 0x9800000: 0x0,\n\t 0xa800000: 0x4000,\n\t 0xb800000: 0x40080000,\n\t 0xc800000: 0x40000010,\n\t 0xd800000: 0x84000,\n\t 0xe800000: 0x40084000,\n\t 0xf800000: 0x4010,\n\t 0x10000000: 0x0,\n\t 0x11000000: 0x40080010,\n\t 0x12000000: 0x40004010,\n\t 0x13000000: 0x40084000,\n\t 0x14000000: 0x40080000,\n\t 0x15000000: 0x10,\n\t 0x16000000: 0x84010,\n\t 0x17000000: 0x4000,\n\t 0x18000000: 0x4010,\n\t 0x19000000: 0x80000,\n\t 0x1a000000: 0x80010,\n\t 0x1b000000: 0x40000010,\n\t 0x1c000000: 0x84000,\n\t 0x1d000000: 0x40004000,\n\t 0x1e000000: 0x40000000,\n\t 0x1f000000: 0x40084010,\n\t 0x10800000: 0x84010,\n\t 0x11800000: 0x80000,\n\t 0x12800000: 0x40080000,\n\t 0x13800000: 0x4000,\n\t 0x14800000: 0x40004000,\n\t 0x15800000: 0x40084010,\n\t 0x16800000: 0x10,\n\t 0x17800000: 0x40000000,\n\t 0x18800000: 0x40084000,\n\t 0x19800000: 0x40000010,\n\t 0x1a800000: 0x40004010,\n\t 0x1b800000: 0x80010,\n\t 0x1c800000: 0x0,\n\t 0x1d800000: 0x4010,\n\t 0x1e800000: 0x40080010,\n\t 0x1f800000: 0x84000\n\t },\n\t {\n\t 0x0: 0x104,\n\t 0x100000: 0x0,\n\t 0x200000: 0x4000100,\n\t 0x300000: 0x10104,\n\t 0x400000: 0x10004,\n\t 0x500000: 0x4000004,\n\t 0x600000: 0x4010104,\n\t 0x700000: 0x4010000,\n\t 0x800000: 0x4000000,\n\t 0x900000: 0x4010100,\n\t 0xa00000: 0x10100,\n\t 0xb00000: 0x4010004,\n\t 0xc00000: 0x4000104,\n\t 0xd00000: 0x10000,\n\t 0xe00000: 0x4,\n\t 0xf00000: 0x100,\n\t 0x80000: 0x4010100,\n\t 0x180000: 0x4010004,\n\t 0x280000: 0x0,\n\t 0x380000: 0x4000100,\n\t 0x480000: 0x4000004,\n\t 0x580000: 0x10000,\n\t 0x680000: 0x10004,\n\t 0x780000: 0x104,\n\t 0x880000: 0x4,\n\t 0x980000: 0x100,\n\t 0xa80000: 0x4010000,\n\t 0xb80000: 0x10104,\n\t 0xc80000: 0x10100,\n\t 0xd80000: 0x4000104,\n\t 0xe80000: 0x4010104,\n\t 0xf80000: 0x4000000,\n\t 0x1000000: 0x4010100,\n\t 0x1100000: 0x10004,\n\t 0x1200000: 0x10000,\n\t 0x1300000: 0x4000100,\n\t 0x1400000: 0x100,\n\t 0x1500000: 0x4010104,\n\t 0x1600000: 0x4000004,\n\t 0x1700000: 0x0,\n\t 0x1800000: 0x4000104,\n\t 0x1900000: 0x4000000,\n\t 0x1a00000: 0x4,\n\t 0x1b00000: 0x10100,\n\t 0x1c00000: 0x4010000,\n\t 0x1d00000: 0x104,\n\t 0x1e00000: 0x10104,\n\t 0x1f00000: 0x4010004,\n\t 0x1080000: 0x4000000,\n\t 0x1180000: 0x104,\n\t 0x1280000: 0x4010100,\n\t 0x1380000: 0x0,\n\t 0x1480000: 0x10004,\n\t 0x1580000: 0x4000100,\n\t 0x1680000: 0x100,\n\t 0x1780000: 0x4010004,\n\t 0x1880000: 0x10000,\n\t 0x1980000: 0x4010104,\n\t 0x1a80000: 0x10104,\n\t 0x1b80000: 0x4000004,\n\t 0x1c80000: 0x4000104,\n\t 0x1d80000: 0x4010000,\n\t 0x1e80000: 0x4,\n\t 0x1f80000: 0x10100\n\t },\n\t {\n\t 0x0: 0x80401000,\n\t 0x10000: 0x80001040,\n\t 0x20000: 0x401040,\n\t 0x30000: 0x80400000,\n\t 0x40000: 0x0,\n\t 0x50000: 0x401000,\n\t 0x60000: 0x80000040,\n\t 0x70000: 0x400040,\n\t 0x80000: 0x80000000,\n\t 0x90000: 0x400000,\n\t 0xa0000: 0x40,\n\t 0xb0000: 0x80001000,\n\t 0xc0000: 0x80400040,\n\t 0xd0000: 0x1040,\n\t 0xe0000: 0x1000,\n\t 0xf0000: 0x80401040,\n\t 0x8000: 0x80001040,\n\t 0x18000: 0x40,\n\t 0x28000: 0x80400040,\n\t 0x38000: 0x80001000,\n\t 0x48000: 0x401000,\n\t 0x58000: 0x80401040,\n\t 0x68000: 0x0,\n\t 0x78000: 0x80400000,\n\t 0x88000: 0x1000,\n\t 0x98000: 0x80401000,\n\t 0xa8000: 0x400000,\n\t 0xb8000: 0x1040,\n\t 0xc8000: 0x80000000,\n\t 0xd8000: 0x400040,\n\t 0xe8000: 0x401040,\n\t 0xf8000: 0x80000040,\n\t 0x100000: 0x400040,\n\t 0x110000: 0x401000,\n\t 0x120000: 0x80000040,\n\t 0x130000: 0x0,\n\t 0x140000: 0x1040,\n\t 0x150000: 0x80400040,\n\t 0x160000: 0x80401000,\n\t 0x170000: 0x80001040,\n\t 0x180000: 0x80401040,\n\t 0x190000: 0x80000000,\n\t 0x1a0000: 0x80400000,\n\t 0x1b0000: 0x401040,\n\t 0x1c0000: 0x80001000,\n\t 0x1d0000: 0x400000,\n\t 0x1e0000: 0x40,\n\t 0x1f0000: 0x1000,\n\t 0x108000: 0x80400000,\n\t 0x118000: 0x80401040,\n\t 0x128000: 0x0,\n\t 0x138000: 0x401000,\n\t 0x148000: 0x400040,\n\t 0x158000: 0x80000000,\n\t 0x168000: 0x80001040,\n\t 0x178000: 0x40,\n\t 0x188000: 0x80000040,\n\t 0x198000: 0x1000,\n\t 0x1a8000: 0x80001000,\n\t 0x1b8000: 0x80400040,\n\t 0x1c8000: 0x1040,\n\t 0x1d8000: 0x80401000,\n\t 0x1e8000: 0x400000,\n\t 0x1f8000: 0x401040\n\t },\n\t {\n\t 0x0: 0x80,\n\t 0x1000: 0x1040000,\n\t 0x2000: 0x40000,\n\t 0x3000: 0x20000000,\n\t 0x4000: 0x20040080,\n\t 0x5000: 0x1000080,\n\t 0x6000: 0x21000080,\n\t 0x7000: 0x40080,\n\t 0x8000: 0x1000000,\n\t 0x9000: 0x20040000,\n\t 0xa000: 0x20000080,\n\t 0xb000: 0x21040080,\n\t 0xc000: 0x21040000,\n\t 0xd000: 0x0,\n\t 0xe000: 0x1040080,\n\t 0xf000: 0x21000000,\n\t 0x800: 0x1040080,\n\t 0x1800: 0x21000080,\n\t 0x2800: 0x80,\n\t 0x3800: 0x1040000,\n\t 0x4800: 0x40000,\n\t 0x5800: 0x20040080,\n\t 0x6800: 0x21040000,\n\t 0x7800: 0x20000000,\n\t 0x8800: 0x20040000,\n\t 0x9800: 0x0,\n\t 0xa800: 0x21040080,\n\t 0xb800: 0x1000080,\n\t 0xc800: 0x20000080,\n\t 0xd800: 0x21000000,\n\t 0xe800: 0x1000000,\n\t 0xf800: 0x40080,\n\t 0x10000: 0x40000,\n\t 0x11000: 0x80,\n\t 0x12000: 0x20000000,\n\t 0x13000: 0x21000080,\n\t 0x14000: 0x1000080,\n\t 0x15000: 0x21040000,\n\t 0x16000: 0x20040080,\n\t 0x17000: 0x1000000,\n\t 0x18000: 0x21040080,\n\t 0x19000: 0x21000000,\n\t 0x1a000: 0x1040000,\n\t 0x1b000: 0x20040000,\n\t 0x1c000: 0x40080,\n\t 0x1d000: 0x20000080,\n\t 0x1e000: 0x0,\n\t 0x1f000: 0x1040080,\n\t 0x10800: 0x21000080,\n\t 0x11800: 0x1000000,\n\t 0x12800: 0x1040000,\n\t 0x13800: 0x20040080,\n\t 0x14800: 0x20000000,\n\t 0x15800: 0x1040080,\n\t 0x16800: 0x80,\n\t 0x17800: 0x21040000,\n\t 0x18800: 0x40080,\n\t 0x19800: 0x21040080,\n\t 0x1a800: 0x0,\n\t 0x1b800: 0x21000000,\n\t 0x1c800: 0x1000080,\n\t 0x1d800: 0x40000,\n\t 0x1e800: 0x20040000,\n\t 0x1f800: 0x20000080\n\t },\n\t {\n\t 0x0: 0x10000008,\n\t 0x100: 0x2000,\n\t 0x200: 0x10200000,\n\t 0x300: 0x10202008,\n\t 0x400: 0x10002000,\n\t 0x500: 0x200000,\n\t 0x600: 0x200008,\n\t 0x700: 0x10000000,\n\t 0x800: 0x0,\n\t 0x900: 0x10002008,\n\t 0xa00: 0x202000,\n\t 0xb00: 0x8,\n\t 0xc00: 0x10200008,\n\t 0xd00: 0x202008,\n\t 0xe00: 0x2008,\n\t 0xf00: 0x10202000,\n\t 0x80: 0x10200000,\n\t 0x180: 0x10202008,\n\t 0x280: 0x8,\n\t 0x380: 0x200000,\n\t 0x480: 0x202008,\n\t 0x580: 0x10000008,\n\t 0x680: 0x10002000,\n\t 0x780: 0x2008,\n\t 0x880: 0x200008,\n\t 0x980: 0x2000,\n\t 0xa80: 0x10002008,\n\t 0xb80: 0x10200008,\n\t 0xc80: 0x0,\n\t 0xd80: 0x10202000,\n\t 0xe80: 0x202000,\n\t 0xf80: 0x10000000,\n\t 0x1000: 0x10002000,\n\t 0x1100: 0x10200008,\n\t 0x1200: 0x10202008,\n\t 0x1300: 0x2008,\n\t 0x1400: 0x200000,\n\t 0x1500: 0x10000000,\n\t 0x1600: 0x10000008,\n\t 0x1700: 0x202000,\n\t 0x1800: 0x202008,\n\t 0x1900: 0x0,\n\t 0x1a00: 0x8,\n\t 0x1b00: 0x10200000,\n\t 0x1c00: 0x2000,\n\t 0x1d00: 0x10002008,\n\t 0x1e00: 0x10202000,\n\t 0x1f00: 0x200008,\n\t 0x1080: 0x8,\n\t 0x1180: 0x202000,\n\t 0x1280: 0x200000,\n\t 0x1380: 0x10000008,\n\t 0x1480: 0x10002000,\n\t 0x1580: 0x2008,\n\t 0x1680: 0x10202008,\n\t 0x1780: 0x10200000,\n\t 0x1880: 0x10202000,\n\t 0x1980: 0x10200008,\n\t 0x1a80: 0x2000,\n\t 0x1b80: 0x202008,\n\t 0x1c80: 0x200008,\n\t 0x1d80: 0x0,\n\t 0x1e80: 0x10000000,\n\t 0x1f80: 0x10002008\n\t },\n\t {\n\t 0x0: 0x100000,\n\t 0x10: 0x2000401,\n\t 0x20: 0x400,\n\t 0x30: 0x100401,\n\t 0x40: 0x2100401,\n\t 0x50: 0x0,\n\t 0x60: 0x1,\n\t 0x70: 0x2100001,\n\t 0x80: 0x2000400,\n\t 0x90: 0x100001,\n\t 0xa0: 0x2000001,\n\t 0xb0: 0x2100400,\n\t 0xc0: 0x2100000,\n\t 0xd0: 0x401,\n\t 0xe0: 0x100400,\n\t 0xf0: 0x2000000,\n\t 0x8: 0x2100001,\n\t 0x18: 0x0,\n\t 0x28: 0x2000401,\n\t 0x38: 0x2100400,\n\t 0x48: 0x100000,\n\t 0x58: 0x2000001,\n\t 0x68: 0x2000000,\n\t 0x78: 0x401,\n\t 0x88: 0x100401,\n\t 0x98: 0x2000400,\n\t 0xa8: 0x2100000,\n\t 0xb8: 0x100001,\n\t 0xc8: 0x400,\n\t 0xd8: 0x2100401,\n\t 0xe8: 0x1,\n\t 0xf8: 0x100400,\n\t 0x100: 0x2000000,\n\t 0x110: 0x100000,\n\t 0x120: 0x2000401,\n\t 0x130: 0x2100001,\n\t 0x140: 0x100001,\n\t 0x150: 0x2000400,\n\t 0x160: 0x2100400,\n\t 0x170: 0x100401,\n\t 0x180: 0x401,\n\t 0x190: 0x2100401,\n\t 0x1a0: 0x100400,\n\t 0x1b0: 0x1,\n\t 0x1c0: 0x0,\n\t 0x1d0: 0x2100000,\n\t 0x1e0: 0x2000001,\n\t 0x1f0: 0x400,\n\t 0x108: 0x100400,\n\t 0x118: 0x2000401,\n\t 0x128: 0x2100001,\n\t 0x138: 0x1,\n\t 0x148: 0x2000000,\n\t 0x158: 0x100000,\n\t 0x168: 0x401,\n\t 0x178: 0x2100400,\n\t 0x188: 0x2000001,\n\t 0x198: 0x2100000,\n\t 0x1a8: 0x0,\n\t 0x1b8: 0x2100401,\n\t 0x1c8: 0x100401,\n\t 0x1d8: 0x400,\n\t 0x1e8: 0x2000400,\n\t 0x1f8: 0x100001\n\t },\n\t {\n\t 0x0: 0x8000820,\n\t 0x1: 0x20000,\n\t 0x2: 0x8000000,\n\t 0x3: 0x20,\n\t 0x4: 0x20020,\n\t 0x5: 0x8020820,\n\t 0x6: 0x8020800,\n\t 0x7: 0x800,\n\t 0x8: 0x8020000,\n\t 0x9: 0x8000800,\n\t 0xa: 0x20800,\n\t 0xb: 0x8020020,\n\t 0xc: 0x820,\n\t 0xd: 0x0,\n\t 0xe: 0x8000020,\n\t 0xf: 0x20820,\n\t 0x80000000: 0x800,\n\t 0x80000001: 0x8020820,\n\t 0x80000002: 0x8000820,\n\t 0x80000003: 0x8000000,\n\t 0x80000004: 0x8020000,\n\t 0x80000005: 0x20800,\n\t 0x80000006: 0x20820,\n\t 0x80000007: 0x20,\n\t 0x80000008: 0x8000020,\n\t 0x80000009: 0x820,\n\t 0x8000000a: 0x20020,\n\t 0x8000000b: 0x8020800,\n\t 0x8000000c: 0x0,\n\t 0x8000000d: 0x8020020,\n\t 0x8000000e: 0x8000800,\n\t 0x8000000f: 0x20000,\n\t 0x10: 0x20820,\n\t 0x11: 0x8020800,\n\t 0x12: 0x20,\n\t 0x13: 0x800,\n\t 0x14: 0x8000800,\n\t 0x15: 0x8000020,\n\t 0x16: 0x8020020,\n\t 0x17: 0x20000,\n\t 0x18: 0x0,\n\t 0x19: 0x20020,\n\t 0x1a: 0x8020000,\n\t 0x1b: 0x8000820,\n\t 0x1c: 0x8020820,\n\t 0x1d: 0x20800,\n\t 0x1e: 0x820,\n\t 0x1f: 0x8000000,\n\t 0x80000010: 0x20000,\n\t 0x80000011: 0x800,\n\t 0x80000012: 0x8020020,\n\t 0x80000013: 0x20820,\n\t 0x80000014: 0x20,\n\t 0x80000015: 0x8020000,\n\t 0x80000016: 0x8000000,\n\t 0x80000017: 0x8000820,\n\t 0x80000018: 0x8020820,\n\t 0x80000019: 0x8000020,\n\t 0x8000001a: 0x8000800,\n\t 0x8000001b: 0x0,\n\t 0x8000001c: 0x20800,\n\t 0x8000001d: 0x820,\n\t 0x8000001e: 0x20020,\n\t 0x8000001f: 0x8020800\n\t }\n\t ];\n\n\t // Masks that select the SBOX input\n\t var SBOX_MASK = [\n\t 0xf8000001, 0x1f800000, 0x01f80000, 0x001f8000,\n\t 0x0001f800, 0x00001f80, 0x000001f8, 0x8000001f\n\t ];\n\n\t /**\n\t * DES block cipher algorithm.\n\t */\n\t var DES = C_algo.DES = BlockCipher.extend({\n\t _doReset: function () {\n\t // Shortcuts\n\t var key = this._key;\n\t var keyWords = key.words;\n\n\t // Select 56 bits according to PC1\n\t var keyBits = [];\n\t for (var i = 0; i < 56; i++) {\n\t var keyBitPos = PC1[i] - 1;\n\t keyBits[i] = (keyWords[keyBitPos >>> 5] >>> (31 - keyBitPos % 32)) & 1;\n\t }\n\n\t // Assemble 16 subkeys\n\t var subKeys = this._subKeys = [];\n\t for (var nSubKey = 0; nSubKey < 16; nSubKey++) {\n\t // Create subkey\n\t var subKey = subKeys[nSubKey] = [];\n\n\t // Shortcut\n\t var bitShift = BIT_SHIFTS[nSubKey];\n\n\t // Select 48 bits according to PC2\n\t for (var i = 0; i < 24; i++) {\n\t // Select from the left 28 key bits\n\t subKey[(i / 6) | 0] |= keyBits[((PC2[i] - 1) + bitShift) % 28] << (31 - i % 6);\n\n\t // Select from the right 28 key bits\n\t subKey[4 + ((i / 6) | 0)] |= keyBits[28 + (((PC2[i + 24] - 1) + bitShift) % 28)] << (31 - i % 6);\n\t }\n\n\t // Since each subkey is applied to an expanded 32-bit input,\n\t // the subkey can be broken into 8 values scaled to 32-bits,\n\t // which allows the key to be used without expansion\n\t subKey[0] = (subKey[0] << 1) | (subKey[0] >>> 31);\n\t for (var i = 1; i < 7; i++) {\n\t subKey[i] = subKey[i] >>> ((i - 1) * 4 + 3);\n\t }\n\t subKey[7] = (subKey[7] << 5) | (subKey[7] >>> 27);\n\t }\n\n\t // Compute inverse subkeys\n\t var invSubKeys = this._invSubKeys = [];\n\t for (var i = 0; i < 16; i++) {\n\t invSubKeys[i] = subKeys[15 - i];\n\t }\n\t },\n\n\t encryptBlock: function (M, offset) {\n\t this._doCryptBlock(M, offset, this._subKeys);\n\t },\n\n\t decryptBlock: function (M, offset) {\n\t this._doCryptBlock(M, offset, this._invSubKeys);\n\t },\n\n\t _doCryptBlock: function (M, offset, subKeys) {\n\t // Get input\n\t this._lBlock = M[offset];\n\t this._rBlock = M[offset + 1];\n\n\t // Initial permutation\n\t exchangeLR.call(this, 4, 0x0f0f0f0f);\n\t exchangeLR.call(this, 16, 0x0000ffff);\n\t exchangeRL.call(this, 2, 0x33333333);\n\t exchangeRL.call(this, 8, 0x00ff00ff);\n\t exchangeLR.call(this, 1, 0x55555555);\n\n\t // Rounds\n\t for (var round = 0; round < 16; round++) {\n\t // Shortcuts\n\t var subKey = subKeys[round];\n\t var lBlock = this._lBlock;\n\t var rBlock = this._rBlock;\n\n\t // Feistel function\n\t var f = 0;\n\t for (var i = 0; i < 8; i++) {\n\t f |= SBOX_P[i][((rBlock ^ subKey[i]) & SBOX_MASK[i]) >>> 0];\n\t }\n\t this._lBlock = rBlock;\n\t this._rBlock = lBlock ^ f;\n\t }\n\n\t // Undo swap from last round\n\t var t = this._lBlock;\n\t this._lBlock = this._rBlock;\n\t this._rBlock = t;\n\n\t // Final permutation\n\t exchangeLR.call(this, 1, 0x55555555);\n\t exchangeRL.call(this, 8, 0x00ff00ff);\n\t exchangeRL.call(this, 2, 0x33333333);\n\t exchangeLR.call(this, 16, 0x0000ffff);\n\t exchangeLR.call(this, 4, 0x0f0f0f0f);\n\n\t // Set output\n\t M[offset] = this._lBlock;\n\t M[offset + 1] = this._rBlock;\n\t },\n\n\t keySize: 64/32,\n\n\t ivSize: 64/32,\n\n\t blockSize: 64/32\n\t });\n\n\t // Swap bits across the left and right words\n\t function exchangeLR(offset, mask) {\n\t var t = ((this._lBlock >>> offset) ^ this._rBlock) & mask;\n\t this._rBlock ^= t;\n\t this._lBlock ^= t << offset;\n\t }\n\n\t function exchangeRL(offset, mask) {\n\t var t = ((this._rBlock >>> offset) ^ this._lBlock) & mask;\n\t this._lBlock ^= t;\n\t this._rBlock ^= t << offset;\n\t }\n\n\t /**\n\t * Shortcut functions to the cipher's object interface.\n\t *\n\t * @example\n\t *\n\t * var ciphertext = CryptoJS.DES.encrypt(message, key, cfg);\n\t * var plaintext = CryptoJS.DES.decrypt(ciphertext, key, cfg);\n\t */\n\t C.DES = BlockCipher._createHelper(DES);\n\n\t /**\n\t * Triple-DES block cipher algorithm.\n\t */\n\t var TripleDES = C_algo.TripleDES = BlockCipher.extend({\n\t _doReset: function () {\n\t // Shortcuts\n\t var key = this._key;\n\t var keyWords = key.words;\n\t // Make sure the key length is valid (64, 128 or >= 192 bit)\n\t if (keyWords.length !== 2 && keyWords.length !== 4 && keyWords.length < 6) {\n\t throw new Error('Invalid key length - 3DES requires the key length to be 64, 128, 192 or >192.');\n\t }\n\n\t // Extend the key according to the keying options defined in 3DES standard\n\t var key1 = keyWords.slice(0, 2);\n\t var key2 = keyWords.length < 4 ? keyWords.slice(0, 2) : keyWords.slice(2, 4);\n\t var key3 = keyWords.length < 6 ? keyWords.slice(0, 2) : keyWords.slice(4, 6);\n\n\t // Create DES instances\n\t this._des1 = DES.createEncryptor(WordArray.create(key1));\n\t this._des2 = DES.createEncryptor(WordArray.create(key2));\n\t this._des3 = DES.createEncryptor(WordArray.create(key3));\n\t },\n\n\t encryptBlock: function (M, offset) {\n\t this._des1.encryptBlock(M, offset);\n\t this._des2.decryptBlock(M, offset);\n\t this._des3.encryptBlock(M, offset);\n\t },\n\n\t decryptBlock: function (M, offset) {\n\t this._des3.decryptBlock(M, offset);\n\t this._des2.encryptBlock(M, offset);\n\t this._des1.decryptBlock(M, offset);\n\t },\n\n\t keySize: 192/32,\n\n\t ivSize: 64/32,\n\n\t blockSize: 64/32\n\t });\n\n\t /**\n\t * Shortcut functions to the cipher's object interface.\n\t *\n\t * @example\n\t *\n\t * var ciphertext = CryptoJS.TripleDES.encrypt(message, key, cfg);\n\t * var plaintext = CryptoJS.TripleDES.decrypt(ciphertext, key, cfg);\n\t */\n\t C.TripleDES = BlockCipher._createHelper(TripleDES);\n\t}());\n\n\n\treturn CryptoJS.TripleDES;\n\n}));",";(function (root, factory) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function (undefined) {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var Base = C_lib.Base;\n\t var X32WordArray = C_lib.WordArray;\n\n\t /**\n\t * x64 namespace.\n\t */\n\t var C_x64 = C.x64 = {};\n\n\t /**\n\t * A 64-bit word.\n\t */\n\t var X64Word = C_x64.Word = Base.extend({\n\t /**\n\t * Initializes a newly created 64-bit word.\n\t *\n\t * @param {number} high The high 32 bits.\n\t * @param {number} low The low 32 bits.\n\t *\n\t * @example\n\t *\n\t * var x64Word = CryptoJS.x64.Word.create(0x00010203, 0x04050607);\n\t */\n\t init: function (high, low) {\n\t this.high = high;\n\t this.low = low;\n\t }\n\n\t /**\n\t * Bitwise NOTs this word.\n\t *\n\t * @return {X64Word} A new x64-Word object after negating.\n\t *\n\t * @example\n\t *\n\t * var negated = x64Word.not();\n\t */\n\t // not: function () {\n\t // var high = ~this.high;\n\t // var low = ~this.low;\n\n\t // return X64Word.create(high, low);\n\t // },\n\n\t /**\n\t * Bitwise ANDs this word with the passed word.\n\t *\n\t * @param {X64Word} word The x64-Word to AND with this word.\n\t *\n\t * @return {X64Word} A new x64-Word object after ANDing.\n\t *\n\t * @example\n\t *\n\t * var anded = x64Word.and(anotherX64Word);\n\t */\n\t // and: function (word) {\n\t // var high = this.high & word.high;\n\t // var low = this.low & word.low;\n\n\t // return X64Word.create(high, low);\n\t // },\n\n\t /**\n\t * Bitwise ORs this word with the passed word.\n\t *\n\t * @param {X64Word} word The x64-Word to OR with this word.\n\t *\n\t * @return {X64Word} A new x64-Word object after ORing.\n\t *\n\t * @example\n\t *\n\t * var ored = x64Word.or(anotherX64Word);\n\t */\n\t // or: function (word) {\n\t // var high = this.high | word.high;\n\t // var low = this.low | word.low;\n\n\t // return X64Word.create(high, low);\n\t // },\n\n\t /**\n\t * Bitwise XORs this word with the passed word.\n\t *\n\t * @param {X64Word} word The x64-Word to XOR with this word.\n\t *\n\t * @return {X64Word} A new x64-Word object after XORing.\n\t *\n\t * @example\n\t *\n\t * var xored = x64Word.xor(anotherX64Word);\n\t */\n\t // xor: function (word) {\n\t // var high = this.high ^ word.high;\n\t // var low = this.low ^ word.low;\n\n\t // return X64Word.create(high, low);\n\t // },\n\n\t /**\n\t * Shifts this word n bits to the left.\n\t *\n\t * @param {number} n The number of bits to shift.\n\t *\n\t * @return {X64Word} A new x64-Word object after shifting.\n\t *\n\t * @example\n\t *\n\t * var shifted = x64Word.shiftL(25);\n\t */\n\t // shiftL: function (n) {\n\t // if (n < 32) {\n\t // var high = (this.high << n) | (this.low >>> (32 - n));\n\t // var low = this.low << n;\n\t // } else {\n\t // var high = this.low << (n - 32);\n\t // var low = 0;\n\t // }\n\n\t // return X64Word.create(high, low);\n\t // },\n\n\t /**\n\t * Shifts this word n bits to the right.\n\t *\n\t * @param {number} n The number of bits to shift.\n\t *\n\t * @return {X64Word} A new x64-Word object after shifting.\n\t *\n\t * @example\n\t *\n\t * var shifted = x64Word.shiftR(7);\n\t */\n\t // shiftR: function (n) {\n\t // if (n < 32) {\n\t // var low = (this.low >>> n) | (this.high << (32 - n));\n\t // var high = this.high >>> n;\n\t // } else {\n\t // var low = this.high >>> (n - 32);\n\t // var high = 0;\n\t // }\n\n\t // return X64Word.create(high, low);\n\t // },\n\n\t /**\n\t * Rotates this word n bits to the left.\n\t *\n\t * @param {number} n The number of bits to rotate.\n\t *\n\t * @return {X64Word} A new x64-Word object after rotating.\n\t *\n\t * @example\n\t *\n\t * var rotated = x64Word.rotL(25);\n\t */\n\t // rotL: function (n) {\n\t // return this.shiftL(n).or(this.shiftR(64 - n));\n\t // },\n\n\t /**\n\t * Rotates this word n bits to the right.\n\t *\n\t * @param {number} n The number of bits to rotate.\n\t *\n\t * @return {X64Word} A new x64-Word object after rotating.\n\t *\n\t * @example\n\t *\n\t * var rotated = x64Word.rotR(7);\n\t */\n\t // rotR: function (n) {\n\t // return this.shiftR(n).or(this.shiftL(64 - n));\n\t // },\n\n\t /**\n\t * Adds this word with the passed word.\n\t *\n\t * @param {X64Word} word The x64-Word to add with this word.\n\t *\n\t * @return {X64Word} A new x64-Word object after adding.\n\t *\n\t * @example\n\t *\n\t * var added = x64Word.add(anotherX64Word);\n\t */\n\t // add: function (word) {\n\t // var low = (this.low + word.low) | 0;\n\t // var carry = (low >>> 0) < (this.low >>> 0) ? 1 : 0;\n\t // var high = (this.high + word.high + carry) | 0;\n\n\t // return X64Word.create(high, low);\n\t // }\n\t });\n\n\t /**\n\t * An array of 64-bit words.\n\t *\n\t * @property {Array} words The array of CryptoJS.x64.Word objects.\n\t * @property {number} sigBytes The number of significant bytes in this word array.\n\t */\n\t var X64WordArray = C_x64.WordArray = Base.extend({\n\t /**\n\t * Initializes a newly created word array.\n\t *\n\t * @param {Array} words (Optional) An array of CryptoJS.x64.Word objects.\n\t * @param {number} sigBytes (Optional) The number of significant bytes in the words.\n\t *\n\t * @example\n\t *\n\t * var wordArray = CryptoJS.x64.WordArray.create();\n\t *\n\t * var wordArray = CryptoJS.x64.WordArray.create([\n\t * CryptoJS.x64.Word.create(0x00010203, 0x04050607),\n\t * CryptoJS.x64.Word.create(0x18191a1b, 0x1c1d1e1f)\n\t * ]);\n\t *\n\t * var wordArray = CryptoJS.x64.WordArray.create([\n\t * CryptoJS.x64.Word.create(0x00010203, 0x04050607),\n\t * CryptoJS.x64.Word.create(0x18191a1b, 0x1c1d1e1f)\n\t * ], 10);\n\t */\n\t init: function (words, sigBytes) {\n\t words = this.words = words || [];\n\n\t if (sigBytes != undefined) {\n\t this.sigBytes = sigBytes;\n\t } else {\n\t this.sigBytes = words.length * 8;\n\t }\n\t },\n\n\t /**\n\t * Converts this 64-bit word array to a 32-bit word array.\n\t *\n\t * @return {CryptoJS.lib.WordArray} This word array's data as a 32-bit word array.\n\t *\n\t * @example\n\t *\n\t * var x32WordArray = x64WordArray.toX32();\n\t */\n\t toX32: function () {\n\t // Shortcuts\n\t var x64Words = this.words;\n\t var x64WordsLength = x64Words.length;\n\n\t // Convert\n\t var x32Words = [];\n\t for (var i = 0; i < x64WordsLength; i++) {\n\t var x64Word = x64Words[i];\n\t x32Words.push(x64Word.high);\n\t x32Words.push(x64Word.low);\n\t }\n\n\t return X32WordArray.create(x32Words, this.sigBytes);\n\t },\n\n\t /**\n\t * Creates a copy of this word array.\n\t *\n\t * @return {X64WordArray} The clone.\n\t *\n\t * @example\n\t *\n\t * var clone = x64WordArray.clone();\n\t */\n\t clone: function () {\n\t var clone = Base.clone.call(this);\n\n\t // Clone \"words\" array\n\t var words = clone.words = this.words.slice(0);\n\n\t // Clone each X64Word object\n\t var wordsLength = words.length;\n\t for (var i = 0; i < wordsLength; i++) {\n\t words[i] = words[i].clone();\n\t }\n\n\t return clone;\n\t }\n\t });\n\t}());\n\n\n\treturn CryptoJS;\n\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","var map = {\n\t\"./7z.png\": 2839,\n\t\"./ahk.png\": 3108,\n\t\"./ai.png\": 3544,\n\t\"./apk.png\": 4935,\n\t\"./asm.png\": 9424,\n\t\"./asp.png\": 1476,\n\t\"./aspx.png\": 6119,\n\t\"./avi.png\": 286,\n\t\"./bashrc.png\": 5052,\n\t\"./bat.png\": 3504,\n\t\"./bmp.png\": 2670,\n\t\"./bz2.png\": 2284,\n\t\"./c.png\": 8416,\n\t\"./cc.png\": 9470,\n\t\"./cfg.png\": 7406,\n\t\"./cjs.png\": 9215,\n\t\"./cmd.png\": 7137,\n\t\"./conf.png\": 159,\n\t\"./cpp.png\": 7688,\n\t\"./crt.png\": 692,\n\t\"./cs.png\": 5716,\n\t\"./css.png\": 5988,\n\t\"./csv.png\": 2963,\n\t\"./cxx.png\": 9947,\n\t\"./db.png\": 3050,\n\t\"./dds.png\": 4142,\n\t\"./dll.png\": 1507,\n\t\"./doc.png\": 9171,\n\t\"./docx.png\": 7294,\n\t\"./dtd.png\": 101,\n\t\"./emf.png\": 1315,\n\t\"./eml.png\": 6803,\n\t\"./epub.png\": 353,\n\t\"./exe.png\": 7115,\n\t\"./folder.png\": 8874,\n\t\"./gif.png\": 8344,\n\t\"./gitignore.png\": 1002,\n\t\"./go.png\": 631,\n\t\"./gz.png\": 4677,\n\t\"./h.png\": 9271,\n\t\"./heic.png\": 181,\n\t\"./heif.png\": 1322,\n\t\"./hpp.png\": 6501,\n\t\"./htm.png\": 5844,\n\t\"./html.png\": 2789,\n\t\"./ico.png\": 336,\n\t\"./ics.png\": 2629,\n\t\"./ini.png\": 3302,\n\t\"./ipynb.png\": 7001,\n\t\"./iso.png\": 8648,\n\t\"./jar.png\": 9699,\n\t\"./java.png\": 7179,\n\t\"./jpeg.png\": 6996,\n\t\"./jpg.png\": 6380,\n\t\"./js.png\": 130,\n\t\"./json.png\": 4020,\n\t\"./jsp.png\": 423,\n\t\"./jsx.png\": 8182,\n\t\"./kk.png\": 9232,\n\t\"./less.png\": 2531,\n\t\"./lib.png\": 4412,\n\t\"./lic.png\": 4466,\n\t\"./log.png\": 7941,\n\t\"./lst.png\": 9911,\n\t\"./m4a.png\": 8889,\n\t\"./map.png\": 3808,\n\t\"./markdown.png\": 2153,\n\t\"./md.png\": 1503,\n\t\"./mobi.png\": 6663,\n\t\"./mp3.png\": 567,\n\t\"./mp4.png\": 7633,\n\t\"./msi.png\": 7282,\n\t\"./obj.png\": 6772,\n\t\"./odp.png\": 642,\n\t\"./ods.png\": 363,\n\t\"./odt.png\": 9252,\n\t\"./otf.png\": 359,\n\t\"./ova.png\": 7907,\n\t\"./ovpn.png\": 3432,\n\t\"./pdf.png\": 475,\n\t\"./pem.png\": 1490,\n\t\"./php.png\": 7621,\n\t\"./png.png\": 9469,\n\t\"./pot.png\": 8792,\n\t\"./ppa.png\": 8139,\n\t\"./pps.png\": 485,\n\t\"./ppt.png\": 5661,\n\t\"./pptx.png\": 174,\n\t\"./properties.png\": 3747,\n\t\"./ps1.png\": 7945,\n\t\"./psd.png\": 4281,\n\t\"./pwz.png\": 2490,\n\t\"./py.png\": 6085,\n\t\"./pyc.png\": 9369,\n\t\"./rar.png\": 7909,\n\t\"./ras.png\": 4689,\n\t\"./raw.png\": 5002,\n\t\"./rb.png\": 3101,\n\t\"./rtf.png\": 6727,\n\t\"./sass.png\": 7148,\n\t\"./scss.png\": 9538,\n\t\"./sh.png\": 6699,\n\t\"./sql.png\": 9891,\n\t\"./svg.png\": 8470,\n\t\"./tar.png\": 290,\n\t\"./tga.png\": 9631,\n\t\"./tif.png\": 2774,\n\t\"./tiff.png\": 4723,\n\t\"./ts.png\": 8140,\n\t\"./tsx.png\": 8530,\n\t\"./ttf.png\": 5006,\n\t\"./txt.png\": 5516,\n\t\"./vb.png\": 8638,\n\t\"./vbs.png\": 3431,\n\t\"./vcf.png\": 8852,\n\t\"./vdx.png\": 438,\n\t\"./vhdx.png\": 4454,\n\t\"./vmdk.png\": 197,\n\t\"./vmx.png\": 4740,\n\t\"./vsd.png\": 9937,\n\t\"./vue.png\": 6460,\n\t\"./webp.png\": 7526,\n\t\"./wiz.png\": 3428,\n\t\"./wmf.png\": 6829,\n\t\"./wmv.png\": 8083,\n\t\"./wsdl.png\": 2877,\n\t\"./xhtml.png\": 8112,\n\t\"./xls.png\": 5376,\n\t\"./xlsx.png\": 1997,\n\t\"./xml.png\": 7040,\n\t\"./xsl.png\": 575,\n\t\"./xz.png\": 8019,\n\t\"./yaml.png\": 8152,\n\t\"./yml.png\": 8372,\n\t\"./zip.png\": 2635\n};\n\n\nfunction webpackContext(req) {\n\tvar id = webpackContextResolve(req);\n\treturn __webpack_require__(id);\n}\nfunction webpackContextResolve(req) {\n\tif(!__webpack_require__.o(map, req)) {\n\t\tvar e = new Error(\"Cannot find module '\" + req + \"'\");\n\t\te.code = 'MODULE_NOT_FOUND';\n\t\tthrow e;\n\t}\n\treturn map[req];\n}\nwebpackContext.keys = function webpackContextKeys() {\n\treturn Object.keys(map);\n};\nwebpackContext.resolve = webpackContextResolve;\nmodule.exports = webpackContext;\nwebpackContext.id = 5675;","// 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](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\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__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); }","// 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 = \"\";","/* eslint-disable no-var */\n// This file is imported into lib/wc client bundles.\n\nif (typeof window !== 'undefined') {\n var currentScript = window.document.currentScript\n if (process.env.NEED_CURRENTSCRIPT_POLYFILL) {\n var getCurrentScript = require('@soda/get-current-script')\n currentScript = getCurrentScript()\n\n // for backward compatibility, because previously we directly included the polyfill\n if (!('currentScript' in document)) {\n Object.defineProperty(document, 'currentScript', { get: getCurrentScript })\n }\n }\n\n var src = currentScript && currentScript.src.match(/(.+\\/)[^/]+\\.js(\\?.*)?$/)\n if (src) {\n __webpack_public_path__ = src[1] // eslint-disable-line\n }\n}\n\n// Indicate to webpack that this file can be concatenated\nexport default null\n","var __WEBPACK_NAMESPACE_OBJECT__ = require(\"vue\");","\r\n
\r\n\r\n\r\n\r\n\r\n","import { render } from \"./file-icons.vue?vue&type=template&id=ced9306c\"\nimport script from \"./file-icons.vue?vue&type=script&lang=js\"\nexport * from \"./file-icons.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__","// 引入封装好的组件\r\nimport FileIcons from './file-icons.vue';\r\n\r\nexport default FileIcons;","import './setPublicPath'\nimport mod from '~entry'\nexport default mod\nexport * from '~entry'\n","/*!\n * jQuery JavaScript Library v3.7.1\n * https://jquery.com/\n *\n * Copyright OpenJS Foundation and other contributors\n * Released under the MIT license\n * https://jquery.org/license\n *\n * Date: 2023-08-28T13:37Z\n */\n( function( global, factory ) {\n\n\t\"use strict\";\n\n\tif ( typeof module === \"object\" && typeof module.exports === \"object\" ) {\n\n\t\t// For CommonJS and CommonJS-like environments where a proper `window`\n\t\t// is present, execute the factory and get jQuery.\n\t\t// For environments that do not have a `window` with a `document`\n\t\t// (such as Node.js), expose a factory as module.exports.\n\t\t// This accentuates the need for the creation of a real `window`.\n\t\t// e.g. var jQuery = require(\"jquery\")(window);\n\t\t// See ticket trac-14549 for more info.\n\t\tmodule.exports = global.document ?\n\t\t\tfactory( global, true ) :\n\t\t\tfunction( w ) {\n\t\t\t\tif ( !w.document ) {\n\t\t\t\t\tthrow new Error( \"jQuery requires a window with a document\" );\n\t\t\t\t}\n\t\t\t\treturn factory( w );\n\t\t\t};\n\t} else {\n\t\tfactory( global );\n\t}\n\n// Pass this if window is not defined yet\n} )( typeof window !== \"undefined\" ? window : this, function( window, noGlobal ) {\n\n// Edge <= 12 - 13+, Firefox <=18 - 45+, IE 10 - 11, Safari 5.1 - 9+, iOS 6 - 9.1\n// throw exceptions when non-strict code (e.g., ASP.NET 4.5) accesses strict mode\n// arguments.callee.caller (trac-13335). But as of jQuery 3.0 (2016), strict mode should be common\n// enough that all such attempts are guarded in a try block.\n\"use strict\";\n\nvar arr = [];\n\nvar getProto = Object.getPrototypeOf;\n\nvar slice = arr.slice;\n\nvar flat = arr.flat ? function( array ) {\n\treturn arr.flat.call( array );\n} : function( array ) {\n\treturn arr.concat.apply( [], array );\n};\n\n\nvar push = arr.push;\n\nvar indexOf = arr.indexOf;\n\nvar class2type = {};\n\nvar toString = class2type.toString;\n\nvar hasOwn = class2type.hasOwnProperty;\n\nvar fnToString = hasOwn.toString;\n\nvar ObjectFunctionString = fnToString.call( Object );\n\nvar support = {};\n\nvar isFunction = function isFunction( obj ) {\n\n\t\t// Support: Chrome <=57, Firefox <=52\n\t\t// In some browsers, typeof returns \"function\" for HTML