/* @import "./normalize.css";
@import "./bootstrap.css";
@import "./app.css"; */
html,body{height:100%;}
.table{border: 1px solid #dddee1;border-collapse: collapse;}
.table thead{background-color: #f8f8f9;border-bottom: 1px solid #e9eaec;}
.table thead th{text-align: left;padding: 8px 0 8px 5px;}
.table tbody tr td{text-align: left;padding: 5px 5px 5px 5px;}
.fontBlack{color:#333;cursor: pointer;}
.fontBlue{color:#1890ff;cursor: pointer;}
.fontPink{color:#eb2f96;cursor: pointer;}
.fontGreen{color:#19be6b;cursor: pointer;}
.fontRed{color:#f5222d;cursor: pointer;}
.fontOrange{color:#fa8c16;cursor: pointer;}
.buttons>span{margin-right:5px;}
.ivu-poptip-confirm .ivu-poptip-body .ivu-icon{left:16px;}
.ivu-form .ivu-form-item-label,.ivu-radio-wrapper,.ivu-input,.ivu-form-item-content,.ivu-poptip-popper,.ivu-select-item,.ivu-select-single .ivu-select-selection .ivu-select-placeholder,.ivu-select-single .ivu-select-selection .ivu-select-selected-value,.ivu-btn-small{font-size:12px !important;}
#main{height:100%;}
.ivu-card-body{height:100%;}
.layout{
    height:100%;
    display: flex;
    flex-direction: row;
}
.layout-header-bar{
    background: #fff;
    box-shadow: 0 1px 1px rgba(0,0,0,.1);
}
.layout-logo-left{
    width: 90%;
    height: 30px;
    background: #5b6270;
    border-radius: 3px;
    margin: 15px auto;
}
.menu-icon{
    transition: all .3s;
}
.rotate-icon{
    transform: rotate(-90deg);
}
.menu-item span{
    display: inline-block;
    /* overflow: hidden; */
    width: 60%;
    /* text-overflow: ellipsis; */
    white-space: nowrap;
    vertical-align: bottom;
    transition: width .2s ease .2s;
}
.menu-item i{
    transform: translateX(0px);
    transition: font-size .2s ease, transform .2s ease;
    vertical-align: middle;
    font-size: 16px;
}
.collapsed-menu span{
    width: 0px;
    display: none;
    transition: width .2s ease;
}
.collapsed-menu i{
    transform: translateX(5px);
    transition: font-size .2s ease .2s, transform .2s ease .2s;
    vertical-align: middle;
    font-size: 22px;
}
.collapsed-menu .ivu-menu-submenu{height: 50px;}
/* .collapsed-menu .ivu-menu-item{display: none} */
.collapsed-menu .ivu-menu-submenu-title-icon{display: none}
.logo-con {
  padding: 8px;
  text-align: center;
}
.logo-con img {
  height: 60px;
  width: auto;
}
.ivu-layout-header {
  width: 100%;
  position: absolute;
  top: 0;
  z-index: 2;
  padding: 0;
}
.navicon-con {
  margin: 0 6px;
  display: inline-block;
}
.ivu-menu-vertical .ivu-menu-item{
    padding:0;
}
.ivu-menu-vertical .ivu-menu-item a{
    display: block;
    padding:14px 24px;
}
.main-header {
    height: 60px;
    background: #fff;
    box-shadow: 0 2px 1px 1px hsla(0,0%,39%,.1);
    position: relative;
    z-index: 11;
}
.user-dropdown-menu-con {
    position: fixed;
    right: 0;
    top: 0;
    width: 150px;
}
.user-dropdown-innercon {
    height: 100%;
    padding-right: 14px;
}
.ivu-dropdown {
    display: inline-block;
}
.ivu-dropdown-rel {
    position: relative;
}
.user-dropdown-menu-con .main-user-name {
    display: inline-block;
    width: 80px;
    word-break: keep-all;
    white-space: nowrap;
    vertical-align: middle;
    overflow: hidden;
    text-overflow: ellipsis;
    text-align: right;
}

body {
    margin: 0 0px;
}
a {
    text-decoration: none;
    color: inherit;
}
a:hover {
    color: inherit;
}
a:visited {
    color: inherit;
}
a:link {
    color: inherit;
}
.ivu-select-item{
    padding:7px 5px;
}


.slide-verify[data-v-9d34ce3e] {
    position: relative;
}

/* 图片加载样式 */
.slider-verify-loading[data-v-9d34ce3e] {
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    background: rgba(255, 255, 255, 0.9);
    z-index: 999;
    animation: loading-data-v-9d34ce3e 1.5s infinite;
}
@keyframes loading-data-v-9d34ce3e {
0% {
        opacity: .7;
}
100% {
        opacity: 9;
}
}
.slide-verify-block[data-v-9d34ce3e] {
    position: absolute;
    left: 0;
    top: 0
}
.slide-verify-refresh-icon[data-v-9d34ce3e] {
    position: absolute;
    right: 0;
    top: 0;
    width: 34px;
    height: 34px;
    cursor: pointer;
    background: url(../img/icon_light.3d52436a.png) 0 -437px;
    background-size: 34px 471px
}
.slide-verify-slider[data-v-9d34ce3e] {
    position: relative;
    text-align: center;
    width: 100%;
    height: 40px;
    line-height: 40px;
    margin-top: 15px;
    background: #f7f9fa;
    color: #45494c;
    border: 1px solid #e4e7eb
}
.slide-verify-slider-mask[data-v-9d34ce3e] {
    position: absolute;
    left: 0;
    top: 0;
    height: 40px;
    border: 0 solid #1991FA;
    background: #D1E9FE
}
.slide-verify-slider-mask-item[data-v-9d34ce3e] {
    position: absolute;
    top: 0;
    left: 0;
    width: 40px;
    height: 40px;
    background: #fff;
    box-shadow: 0 0 3px rgba(0, 0, 0, 0.3);
    cursor: pointer;
    transition: background .2s linear
}
.slide-verify-slider-mask-item[data-v-9d34ce3e]:hover {
    background: #1991FA
}
.slide-verify-slider-mask-item:hover .slide-verify-slider-mask-item-icon[data-v-9d34ce3e] {
    background-position: 0 -13px
}
.slide-verify-slider-mask-item-icon[data-v-9d34ce3e] {
    position: absolute;
    top: 15px;
    left: 13px;
    width: 14px;
    height: 12px;
    background: url(../img/icon_light.3d52436a.png) 0 -26px;
    background-size: 34px 471px
}
.container-active .slide-verify-slider-mask-item[data-v-9d34ce3e] {
    height: 38px;
    top: -1px;
    border: 1px solid #1991FA;
}
.container-active .slide-verify-slider-mask[data-v-9d34ce3e] {
    height: 38px;
    border-width: 1px;
}
.container-success .slide-verify-slider-mask-item[data-v-9d34ce3e] {
    height: 38px;
    top: -1px;
    border: 1px solid #52CCBA;
    background-color: #52CCBA !important;
}
.container-success .slide-verify-slider-mask[data-v-9d34ce3e] {
    height: 38px;
    border: 1px solid #52CCBA;
    background-color: #D2F4EF;
}
.container-success .slide-verify-slider-mask-item-icon[data-v-9d34ce3e] {
    background-position: 0 0 !important;
}
.container-fail .slide-verify-slider-mask-item[data-v-9d34ce3e] {
    height: 38px;
    top: -1px;
    border: 1px solid #f57a7a;
    background-color: #f57a7a !important;
}
.container-fail .slide-verify-slider-mask[data-v-9d34ce3e] {
    height: 38px;
    border: 1px solid #f57a7a;
    background-color: #fce1e1;
}
.container-fail .slide-verify-slider-mask-item-icon[data-v-9d34ce3e] {
    top: 14px;
    background-position: 0 -82px !important;
}
.container-active .slide-verify-slider-text[data-v-9d34ce3e],
.container-success .slide-verify-slider-text[data-v-9d34ce3e],
.container-fail .slide-verify-slider-text[data-v-9d34ce3e] {
    display: none;
}


#publicSliderVerify {
    font-family: 'Avenir', Helvetica, Arial, sans-serif;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    color: #2c3e50;
}
.btn {
    margin-top: 20px;
    outline: 0;
    border: none;
    padding: 8px 15px;
    border-radius: 5px;
    color: #fff;
    background-color: #1890ff;
    cursor: pointer;
}
.btn:active {
    box-shadow: 1px 5px 0 rgba(0, 0, 0, 0.1) inset;
}
.login[data-v-a49090ce] {
    width: 100%;
    height: 100%;
    padding: 0;
    /* background-image: url(https://file.iviewui.com/iview-admin/login_bg.jpg); */
    background-image: url(https://download.snec.org.cn/SNEC/article/2025/03/13//login_bg-95115908.jpg);
    background-size: cover;
    background-position: center;
    position: relative;
}
.login-con[data-v-a49090ce] {
    position: absolute;
    right: 160px;
    top: 50%;
    transform: translateY(-60%);
    width: 300px;
}
.login-con .form-con[data-v-a49090ce] {
    padding: 10px 0 0;
}
.login-con .login-tip[data-v-a49090ce] {
    font-size: 10px;
    text-align: center;
    color: #c3c3c3;
}
@media (max-width: 767px){
.login-con[data-v-a49090ce]{
        top:50%;
        left:50%;
        transform: translate(-50%,-50%);
}
}

html,
body,
#main1,
#main1>div {
    height: 100%;
}


/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///./src/asset/css/global.css","webpack:///./src/component/layout/standard/main.css","webpack:///./src/component/layout/standard/src/component/layout/standard/main.vue","webpack:///./src/views/publicSliderVerify/components/src/views/publicSliderVerify/components/sliderVerify.vue","webpack:///./src/views/publicSliderVerify/src/views/publicSliderVerify/publicSliderVerify.vue","webpack:///./src/views/login/login.css","webpack:///./src/views/login/src/views/login/login.vue"],"names":[],"mappings":"AAAA;;uBAEuB;AACvB,UAAU,YAAY,CAAC;AACvB,OAAO,0BAA0B,0BAA0B,CAAC;AAC5D,aAAa,0BAA0B,iCAAiC,CAAC;AACzE,gBAAgB,iBAAiB,uBAAuB,CAAC;AACzD,mBAAmB,iBAAiB,yBAAyB,CAAC;AAC9D,WAAW,WAAW,gBAAgB,CAAC;AACvC,UAAU,cAAc,gBAAgB,CAAC;AACzC,UAAU,cAAc,gBAAgB,CAAC;AACzC,WAAW,cAAc,gBAAgB,CAAC;AAC1C,SAAS,cAAc,gBAAgB,CAAC;AACxC,YAAY,cAAc,gBAAgB,CAAC;AAC3C,cAAc,iBAAiB,CAAC;AAChC,+CAA+C,UAAU,CAAC;AAC1D,4QAA4Q,0BAA0B,C;AChBtS,MAAM,YAAY,CAAC;AACnB,eAAe,YAAY,CAAC;AAC5B;IACI,YAAY;IACZ,cAAc;IACd,oBAAoB;CACvB;AACD;IACI,iBAAiB;IACjB,qCAAqC;CACxC;AACD;IACI,WAAW;IACX,aAAa;IACb,oBAAoB;IACpB,mBAAmB;IACnB,kBAAkB;CACrB;AACD;IACI,oBAAoB;CACvB;AACD;IACI,0BAA0B;CAC7B;AACD;IACI,sBAAsB;IACtB,uBAAuB;IACvB,WAAW;IACX,8BAA8B;IAC9B,oBAAoB;IACpB,uBAAuB;IACvB,+BAA+B;CAClC;AACD;IACI,2BAA2B;IAC3B,mDAAmD;IACnD,uBAAuB;IACvB,gBAAgB;CACnB;AACD;IACI,WAAW;IACX,cAAc;IACd,2BAA2B;CAC9B;AACD;IACI,2BAA2B;IAC3B,2DAA2D;IAC3D,uBAAuB;IACvB,gBAAgB;CACnB;AACD,kCAAkC,aAAa,CAAC;AAChD,mDAAmD;AACnD,6CAA6C,aAAa,CAAC;AAC3D;EACE,aAAa;EACb,mBAAmB;CACpB;AACD;EACE,aAAa;EACb,YAAY;CACb;AACD;EACE,YAAY;EACZ,mBAAmB;EACnB,OAAO;EACP,WAAW;EACX,WAAW;CACZ;AACD;EACE,cAAc;EACd,sBAAsB;CACvB;AACD;IACI,UAAU;CACb;AACD;IACI,eAAe;IACf,kBAAkB;CACrB;AACD;IACI,aAAa;IACb,iBAAiB;IACjB,4CAA4C;IAC5C,mBAAmB;IACnB,YAAY;CACf;AACD;IACI,gBAAgB;IAChB,SAAS;IACT,OAAO;IACP,aAAa;CAChB;AACD;IACI,aAAa;IACb,oBAAoB;CACvB;AACD;IACI,sBAAsB;CACzB;AACD;IACI,mBAAmB;CACtB;AACD;IACI,sBAAsB;IACtB,YAAY;IACZ,qBAAqB;IACrB,oBAAoB;IACpB,uBAAuB;IACvB,iBAAiB;IACjB,wBAAwB;IACxB,kBAAkB;;;ACJtB;IACA;CACA;AAEA;IACA;IACA;CACA;AAEA;IACA;CACA;AAEA;IACA;CACA;AAEA;IACA;CACA;AACA;IACA;CACA;;;AC2WA;IACA;CACA;;AAEA;AACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;CACA;AAEA;AACA;QACA;CACA;AAEA;QACA;CACA;CACA;AAEA;IACA;IACA;IACA;CACA;AAEA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;CACA;AAEA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;CACA;AAEA;IACA;IACA;IACA;IACA;IACA;IACA;CACA;AAEA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;CACA;AAEA;IACA;CACA;AAEA;IACA;CACA;AAEA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;CACA;AAEA;IACA;IACA;IACA;CACA;AAEA;IACA;IACA;CACA;AAEA;IACA;IACA;IACA;IACA;CACA;AAEA;IACA;IACA;IACA;CACA;AAEA;IACA;CACA;AAEA;IACA;IACA;IACA;IACA;CACA;AAEA;IACA;IACA;IACA;CACA;AAEA;IACA;IACA;CACA;AAEA;;;IAGA;CACA;;;ACpgBA;IACA;IACA;IACA;IACA;CACA;AAEA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;CACA;AAEA;IACA;;AC1IA;IACI,YAAY;IACZ,aAAa;IACb,WAAW;IACX,+EAA+E;IAC/E,mGAAmG;IACnG,uBAAuB;IACvB,4BAA4B;IAC5B,mBAAmB;CACtB;AACD;IACI,mBAAmB;IACnB,aAAa;IACb,SAAS;IACT,4BAA4B;IAC5B,aAAa;CAChB;AACD;IACI,kBAAkB;CACrB;AACD;IACI,gBAAgB;IAChB,mBAAmB;IACnB,eAAe;CAClB;AACD;AACA;QACQ,QAAQ;QACR,SAAS;QACT,gCAAgC;CACvC;;;AC4BD;;;;IAIA;CACA","file":"css/login.ed26dcb4.css","sourcesContent":["/* @import \"./normalize.css\";\n@import \"./bootstrap.css\";\n@import \"./app.css\"; */\nhtml,body{height:100%;}\n.table{border: 1px solid #dddee1;border-collapse: collapse;}\n.table thead{background-color: #f8f8f9;border-bottom: 1px solid #e9eaec;}\n.table thead th{text-align: left;padding: 8px 0 8px 5px;}\n.table tbody tr td{text-align: left;padding: 5px 5px 5px 5px;}\n.fontBlack{color:#333;cursor: pointer;}\n.fontBlue{color:#1890ff;cursor: pointer;}\n.fontPink{color:#eb2f96;cursor: pointer;}\n.fontGreen{color:#19be6b;cursor: pointer;}\n.fontRed{color:#f5222d;cursor: pointer;}\n.fontOrange{color:#fa8c16;cursor: pointer;}\n.buttons>span{margin-right:5px;}\n.ivu-poptip-confirm .ivu-poptip-body .ivu-icon{left:16px;}\n.ivu-form .ivu-form-item-label,.ivu-radio-wrapper,.ivu-input,.ivu-form-item-content,.ivu-poptip-popper,.ivu-select-item,.ivu-select-single .ivu-select-selection .ivu-select-placeholder,.ivu-select-single .ivu-select-selection .ivu-select-selected-value,.ivu-btn-small{font-size:12px !important;}","#main{height:100%;}\n.ivu-card-body{height:100%;}\n.layout{\n    height:100%;\n    display: flex;\n    flex-direction: row;\n}\n.layout-header-bar{\n    background: #fff;\n    box-shadow: 0 1px 1px rgba(0,0,0,.1);\n}\n.layout-logo-left{\n    width: 90%;\n    height: 30px;\n    background: #5b6270;\n    border-radius: 3px;\n    margin: 15px auto;\n}\n.menu-icon{\n    transition: all .3s;\n}\n.rotate-icon{\n    transform: rotate(-90deg);\n}\n.menu-item span{\n    display: inline-block;\n    /* overflow: hidden; */\n    width: 60%;\n    /* text-overflow: ellipsis; */\n    white-space: nowrap;\n    vertical-align: bottom;\n    transition: width .2s ease .2s;\n}\n.menu-item i{\n    transform: translateX(0px);\n    transition: font-size .2s ease, transform .2s ease;\n    vertical-align: middle;\n    font-size: 16px;\n}\n.collapsed-menu span{\n    width: 0px;\n    display: none;\n    transition: width .2s ease;\n}\n.collapsed-menu i{\n    transform: translateX(5px);\n    transition: font-size .2s ease .2s, transform .2s ease .2s;\n    vertical-align: middle;\n    font-size: 22px;\n}\n.collapsed-menu .ivu-menu-submenu{height: 50px;}\n/* .collapsed-menu .ivu-menu-item{display: none} */\n.collapsed-menu .ivu-menu-submenu-title-icon{display: none}\n.logo-con {\n  padding: 8px;\n  text-align: center;\n}\n.logo-con img {\n  height: 60px;\n  width: auto;\n}\n.ivu-layout-header {\n  width: 100%;\n  position: absolute;\n  top: 0;\n  z-index: 2;\n  padding: 0;\n}\n.navicon-con {\n  margin: 0 6px;\n  display: inline-block;\n}\n.ivu-menu-vertical .ivu-menu-item{\n    padding:0;\n}\n.ivu-menu-vertical .ivu-menu-item a{\n    display: block;\n    padding:14px 24px;\n}\n.main-header {\n    height: 60px;\n    background: #fff;\n    box-shadow: 0 2px 1px 1px hsla(0,0%,39%,.1);\n    position: relative;\n    z-index: 11;\n}\n.user-dropdown-menu-con {\n    position: fixed;\n    right: 0;\n    top: 0;\n    width: 150px;\n}\n.user-dropdown-innercon {\n    height: 100%;\n    padding-right: 14px;\n}\n.ivu-dropdown {\n    display: inline-block;\n}\n.ivu-dropdown-rel {\n    position: relative;\n}\n.user-dropdown-menu-con .main-user-name {\n    display: inline-block;\n    width: 80px;\n    word-break: keep-all;\n    white-space: nowrap;\n    vertical-align: middle;\n    overflow: hidden;\n    text-overflow: ellipsis;\n    text-align: right;\n}","<template>\n    <div class=\"layout\">\n        <Sider ref=\"side1\" hide-trigger collapsible :collapsed-width=\"78\" v-model=\"isCollapsed\" style=\"overflow-y:auto;\">\n            <div class=\"logo-con\">\n                <img v-show=\"!isCollapsed\" :src=\"logo_SYSTEM\" key=\"max-logo\" />\n                <img v-show=\"isCollapsed\" :src=\"logo_SYSTEM_sm\" key=\"min-logo\" />\n            </div>\n            <Menu :active-name=\"activeName\" theme=\"dark\" width=\"auto\" :class=\"menuitemClasses\"\n                @on-select='changeHref'>\n                <MenuItem v-for=\"(item,index) in menuList\" v-if=\"item.Show\" :name=\"item.PurviewName\" :key=\"index\">\n                    <a :href=\"item.Href\">\n                        <Icon type=\"ios-home\"></Icon>\n                        <span>{{$t(item.PurviewName)}}</span>\n                    </a>\n                </MenuItem>\n            </Menu>\n        </Sider>\n        <div style=\"width:100%;height:100%;position:relative;\">\n            <Header\n                :style=\"{ background: currentBackColor, boxShadow: '0 2px 3px 2px rgba(0,0,0,.1)' }\">\n                <!-- <div style=\"position:relative;\"> -->\n                <div class=\"navicon-con\">\n                    <Button :style=\"{ transform: 'rotateZ(' + (this.isCollapsed ? '-90' : '0') + 'deg)' }\" type=\"text\"\n                        @click.native=\"collapsedSider\">\n                        <Icon type=\"navicon\" size=\"32\"></Icon>\n                    </Button>\n                </div>\n                <!-- <div>\n                  \n              </div> -->\n                <!-- 跳转其他系统 -->\n                <div style=\"display: inline-block;margin: 0 25px;\">\n                    <label>{{ $t(\"跳转其他系统\") }}</label>\n                    <Select v-model=\"currentSysHref\" style=\"width:180px\" @on-change='changeSysGroup'>\n                        <Option v-for=\"item in sysGroupList\" v-if=\"item.showChanel\" :value=\"item.value\" :key=\"item.value\">\n                            <template v-if=\"item.sysHref\">\n                                <a :href=\"item.sysHref\" target=\"_blank\">{{ item.label }}</a>\n                            </template>\n                            <template v-else>{{ item.label }}</template>\n                        </Option>\n                    </Select>\n                </div>\n                <!-- 巴西测试业务员，只能预览PV巴西 -->\n                <span class=\"language\">语言/Language:<a :style=\"{ color: $i18n.locale == 'en-US' ? 'black' : 'orange' }\"\n                        @click=\"changeLanguageHref('zh-CN')\">中文</a> &nbsp;&nbsp;<a\n                        :style=\"{ color: $i18n.locale == 'zh-CN' ? 'black' : 'orange' }\"\n                        @click=\"changeLanguageHref('en-US')\">ENGLISH</a></span>\n                <div class=\"user-dropdown-menu-con\" style=\"width:auto;\">\n                    <Row type=\"flex\" justify=\"end\" align=\"middle\" class=\"user-dropdown-innercon\">\n                        <template v-if=\"showSwitchSys\">\n                            <template v-if=\"this.$i18n.locale === 'zh-CN'\">\n                                <label style=\"font-size:12px;\">切换系统：</label>\n                                <Select v-model=\"system_model\" size=\"small\" style=\"width:95px;font-size:12px;\"\n                                    @on-change=\"changeSystem\">\n                                    <template v-for=\"(item, index) in WebSetList\" >\n                                        <Option :value=\"item.website\" :key=\"index\" v-if=\"!item.hide\">{{item.listNameCn }}</Option>\n                                    </template>\n                                </Select>\n                            </template>\n                            <template v-if=\"this.$i18n.locale === 'en-US'\">\n                                <label style=\"font-size:12px;\">Switch systems:</label>\n                                <Select v-model=\"system_model\" size=\"small\" style=\"width:95px;font-size:12px;width: 130px;\"\n                                    @on-change=\"changeSystem\">\n                                    <template v-for=\"(item, index) in WebSetList\" >\n                                        <Option :value=\"item.website\" :key=\"index\" v-if=\"!item.hide\">{{item.listNameEn }}</Option>\n                                    </template>\n                                </Select>\n                            </template>\n                        </template>\n                        <template v-else>\n                            <span style=\"display: block; margin-top: 1.2px;\">{{ $t('当前系统(PV巴西)') }}</span>\n                        </template>\n                        <Dropdown transfer trigger=\"click\" @on-click=\"handleClickUserDropdown\">\n                            <a href=\"javascript:void(0)\">\n                                <span class=\"main-user-name\" style=\"width:auto;margin-left:20px;\">{{ UserName }}</span>\n                                <Icon type=\"arrow-down-b\"></Icon>\n                            </a>\n                            <DropdownMenu slot=\"list\">\n                                <!-- <DropdownItem name=\"ownSpace\" divided>个人中心</DropdownItem> -->\n                                <template v-if=\"showSwitchSys\">\n                                    <DropdownItem name=\"cmsManage\" divided>CMS系统网站管理</DropdownItem>\n                                </template>\n                                <DropdownItem name=\"loginout\">{{ $t('退出登录') }}</DropdownItem>\n                            </DropdownMenu>\n                        </Dropdown>\n                        <Avatar\n                            src=\"https://ss1.bdstatic.com/70cFvXSh_Q1YnxGkpoWK1HF6hhy/it/u=3448484253,3685836170&fm=27&gp=0.jpg\"\n                            style=\"background: #619fe7;margin-left: 10px;\"></Avatar>\n                    </Row>\n                </div>\n                <!-- </div> -->\n            </Header>\n            <Content :style=\"{ height: '100%', padding: '64px 16px 16px', overflowY: 'auto' }\">\n                <Breadcrumb :style=\"{ margin: '16px 0' }\">\n                    <BreadcrumbItem>{{ $t(breadCrumbItem) }}</BreadcrumbItem>\n                </Breadcrumb>\n                <Card style=\"height: 90%;\">\n                    <div id=\"wrapper\" style=\"height: 100%;overflow-y:auto;\">\n                        <slot name=\"main\"></slot>\n                    </div>\n                </Card>\n            </Content>\n        </div>\n    </div>\n</template>\n<style lang=\"css\">\nbody {\n    margin: 0 0px;\n}\n\na {\n    text-decoration: none;\n    color: inherit;\n}\n\na:hover {\n    color: inherit;\n}\n\na:visited {\n    color: inherit;\n}\n\na:link {\n    color: inherit;\n}\n.ivu-select-item{\n    padding:7px 5px;\n}\n\n@import \"../../../asset/css/global.css\";\n@import \"./main.css\";\n</style>\n<script type=\"text/javascript\">\nimport Vue from 'vue';\n\nexport default {\n    data() {\n        return {\n            UserName: '',\n            isCollapsed: false,\n            activeName:'',\n            breadCrumbItem: '',\n            currentSysHref: '',\n            urlName: '',\n            sysGroupList: [\n                {\n                    value: 1,\n                    label: \"展会管理系统（新）\",\n                    showChanel: true,\n                    sysHref: this.RUN_ENV === 'development' ? 'http://47.56.246.214:3220/' : 'http://adminpanel.snec.org.cn/'\n                },\n                {\n                    value: 2,\n                    label: \"邮件系统（新）\",\n                    showChanel: true,\n                    sysHref: this.RUN_ENV === 'development' ? 'http://47.56.246.214:3213/' : 'http://emailpanel.snec.org.cn/'\n                },\n                {\n                    value: 3,\n                    label: \"用户角色权限管理系统（新）\",\n                    showChanel: true,\n                    sysHref: this.RUN_ENV === 'development' ? 'http://47.56.246.214:3205/' : 'http://rolepanel.snec.org.cn/'\n                },\n                {\n                    value: 4,\n                    label: \"工作管理平台\",\n                    showChanel: true,\n                    sysHref: 'http://workmanage.snec.org.cn/'\n                }\n            ],\n            systemList: [\n                {\n                    value: 0,\n                    label: 'PV2022',\n                    labelEn: 'PV(2022)',\n                    show: false,\n\n                },\n                {\n                    value: 3,\n                    label: 'PV虹桥',\n                    labelEn: 'PV(HONGQIAO)',\n                    show: true,\n                },\n                {\n                    value: 1,\n                    label: 'ES浦东',\n                    labelEn: 'ES(PUDONG)',\n                    show: true,\n                },\n                {\n                    value: 2,\n                    label: 'HFC浦东',\n                    labelEn: 'HFC(PUDONG)',\n                    show: true,\n                },\n                {\n                    value: 6,\n                    label: 'NEV',\n                    labelEn: 'NEV',\n                    show: false,\n                },\n                {\n                    value: 7,\n                    label: 'HFCDL大连',\n                    labelEn: 'HFCDL(Dalian)',\n                    show: true,\n                },\n                {\n                    value: 8,\n                    label: 'HEA',\n                    labelEn: 'HEA',\n                    show: true,\n                },\n                {\n                    value: 12,\n                    label: 'NEIAAP',\n                    labelEn: 'NEIAAP',\n                    show: true,\n                },{\n                    value: 13,\n                    label: 'APVIA',\n                    labelEn: 'APVIA',\n                    show: true,\n                },\n                {\n                    value: 9,\n                    label: 'FOLLOWME',\n                    labelEn: 'FOLLOWME',\n                    show: true,\n                },\n                {\n                    value: 10,\n                    label: 'GGet',\n                    labelEn: 'GGet',\n                    show: true,\n                },\n                {\n                    value: 11,\n                    label: 'PV巴西',\n                    labelEn: 'PV(BRAZIL)',\n                    show: true,\n                },{\n                    value: 14,\n                    label: '小程序',\n                    labelEn: 'Mini Program',\n                    show: true,\n                },\n                {\n                    value: 15,\n                    label: '小程序pv',\n                    labelEn: 'Mini Program pv',\n                    show: true,\n                },\n                {\n                    value: 4,\n                    label: 'ES8',\n                    labelEn: 'ES8',\n                    show: true,\n                },\n                {\n                    value: 5,\n                    label: 'HFC6',\n                    labelEn: 'HFC6',\n                    show: true,\n                },\n            ],\n            system_model: 'pv',\n            currentBackColor:'palevioletred',\n            showMenu1: false,\n            showMenuJP: false,\n            RoleCode: '',\n            showMenuIndex: false,\n            showMenuCtma: false,\n            showMenuArtLab: false,\n            showMenuArtList: false,\n            showMenuStaticList: false,\n            showMenuDlList: false,\n            showMenuFrdShip: false,\n            showMenuHmBanner: false,\n            showMenuCoExh: false,\n            showMenuBright: false,\n            showMenuJpPageArts: false,\n            showMenuJpArtList: false,\n            showTopBot: false,\n            showSwitchSys: true,\n            menuList:[],\n            WebSetList:[],\n        }\n    },\n    computed: {\n        rotateIcon() {\n            return [\n                'menu-icon',\n                this.isCollapsed ? 'rotate-icon' : ''\n            ];\n        },\n        menuitemClasses() {\n            return [\n                'menu-item',\n                this.isCollapsed ? 'collapsed-menu' : ''\n            ]\n        },\n    },\n    methods: {\n        // 切换语言\n        changeLanguageHref(str) {\n            this.changeLanguage(str);\n            location.reload();\n        },\n        changeSysGroup(value) {\n\n        },\n        // 切换系统\n        changeSystem(value) {\n            // 将system_model存到sessionstorage里\n            window.sessionStorage.setItem('system_model', value);\n            window.sessionStorage.setItem('logo_SYSTEM', '/images/snec_logo.svg');\n            window.sessionStorage.setItem('logo_SYSTEM_sm', '/images/snec_logo_sm.svg');\n\n             window.sessionStorage.setItem('websiteDB', value);\n             if(value=='indo'){\n                window.sessionStorage.setItem('SNEC_ENV','INDO');\n             }else{\n                window.sessionStorage.setItem('SNEC_ENV','');\n             }\n             \n            this.WebSetList.forEach(item=>{\n                if(item.website == value){\n                    // this.currentBackColor = value;\n                    \n                    window.sessionStorage.setItem('currentBackColor', item.listBackColor);\n                    window.location.reload();\n                }\n            })\n\n            // if (value == 0) {\n            //     window.sessionStorage.setItem('grpc', 'GrpcCMS');\n            //     window.sessionStorage.setItem('SNEC_ENV', 'SNEC');\n               \n            // } else if (value == 1) {\n            //     window.sessionStorage.setItem('grpc', 'GrpcCMS_IESH');\n            //     window.sessionStorage.setItem('SNEC_ENV', 'IESH');\n            //     window.sessionStorage.setItem('websiteDB', 'es');\n            // } else if (value == 2) {\n            //     window.sessionStorage.setItem('grpc', 'GrpcCMS_HFC');\n            //     window.sessionStorage.setItem('SNEC_ENV', 'HFC');\n            //     window.sessionStorage.setItem('websiteDB', 'hfc');\n            // } else if (value == 3) {\n            //     window.sessionStorage.setItem('grpc', 'GrpcCMS_PV16');\n            //     window.sessionStorage.setItem('SNEC_ENV', 'PV17');\n            //     window.sessionStorage.setItem('websiteDB', 'pv16');\n            // } else if (value == 4) {\n            //     window.sessionStorage.setItem('grpc', 'GrpcCMS_IESH8');\n            //     window.sessionStorage.setItem('SNEC_ENV', 'ES8');\n            //     window.sessionStorage.setItem('websiteDB', 'es8');\n            // } else if (value == 5) {\n            //     window.sessionStorage.setItem('grpc', 'GrpcCMS_HFC6');\n            //     window.sessionStorage.setItem('SNEC_ENV', 'HFC6');\n            //     window.sessionStorage.setItem('websiteDB', 'hfc6');\n            // } else if (value == 6) {\n            //     window.sessionStorage.setItem('grpc', 'GrpcCMS_NEV');\n            //     window.sessionStorage.setItem('SNEC_ENV', 'NEV');\n            //     window.sessionStorage.setItem('websiteDB', 'nev');\n            // } else if (value == 7) {\n            //     window.sessionStorage.setItem('grpc', 'GrpcCMS_HFCDL');\n            //     window.sessionStorage.setItem('SNEC_ENV', 'HFCDL');\n            //     window.sessionStorage.setItem('websiteDB', 'hfcdl');\n            // } else if (value == 8) {\n            //     window.sessionStorage.setItem('grpc', 'GrpcCMS_HEA');\n            //     window.sessionStorage.setItem('SNEC_ENV', 'HEA');\n            //     window.sessionStorage.setItem('websiteDB', 'hea');\n            // } else if (value == 9) {\n            //     window.sessionStorage.setItem('grpc', 'GrpcCMS_FOLLOWME');\n            //     window.sessionStorage.setItem('SNEC_ENV', 'FOLLOWME');\n            //     window.sessionStorage.setItem('websiteDB', 'followme');\n            // } else if (value == 10) {\n            //     window.sessionStorage.setItem('grpc', 'GrpcCMS_GGET');\n            //     window.sessionStorage.setItem('SNEC_ENV', 'GGET');\n            //     window.sessionStorage.setItem('websiteDB', 'gget');\n            // } else if (value == 11) {\n            //     window.sessionStorage.setItem('grpc', 'GrpcCMS_INDO');\n            //     window.sessionStorage.setItem('SNEC_ENV', 'INDO');    \n            //     window.sessionStorage.setItem('websiteDB', 'indo');            \n            // } else if (value == 12) {\n            //     window.sessionStorage.setItem('grpc', 'GrpcCMS_NEIAAP');\n            //     window.sessionStorage.setItem('SNEC_ENV', 'NEIAAP');    \n            //     window.sessionStorage.setItem('websiteDB', 'neiaap');            \n            // } else if (value == 13) {\n            //     window.sessionStorage.setItem('grpc', 'GrpcCMS_APVIA');\n            //     window.sessionStorage.setItem('SNEC_ENV', 'APVIA');  \n            //     window.sessionStorage.setItem('websiteDB', 'apvia');              \n            // } else if (value == 14) {\n            //     window.sessionStorage.setItem('grpc', 'GrpcCMS_SMALL_PROGRAM');\n            //     window.sessionStorage.setItem('SNEC_ENV', '小程序'); \n            //     window.sessionStorage.setItem('websiteDB', 'speshfc');   \n            // } else if (value == 15) {\n            //     window.sessionStorage.setItem('grpc', 'GrpcCMS_SMALL_PROGRAM');\n            //     window.sessionStorage.setItem('SNEC_ENV', '小程序pv'); \n            //     window.sessionStorage.setItem('websiteDB', 'sppv');   \n            // }\n            \n        },\n        collapsedSider() {\n            this.$refs.side1.toggleCollapse();\n        },\n        changeHref(name) {\n            console.log(name)\n            window.sessionStorage.setItem('activeName', name);//每次切换左侧菜单栏后将activeName的值存在sessionStorage里\n            window.sessionStorage.setItem('breadCrumbItem', event.target.innerText);\n        },\n        handleClickUserDropdown(name) {\n            if (name === 'ownSpace') {\n                // util.openNewPage(this, 'ownspace_index');\n                // this.$router.push({\n                //     name: 'ownspace_index'\n                // });\n            } else if (name === 'cmsManage') {\n                // 跳转到系统网站管理页面\n                window.location.href = '/CMSmanage';\n                window.sessionStorage.setItem('breadCrumbItem', event.target.innerText);\n            } else if (name === 'loginout') {\n                // 退出登录\n                window.location.href = '/login';\n            }\n        },\n\n    },\n    mounted() {\n        this.UserName = window.sessionStorage.getItem('UserName');\n        const active_name = window.sessionStorage.getItem('activeName') || '';\n        // console.log('active_name*******', active_name)\n        let bred_crumb_item = \"\";\n        if (this.RoleCode === 'JAPANESE') {\n            bred_crumb_item = window.sessionStorage.getItem('breadCrumbItem') || '日本語翻訳の内容欄';\n        } else {\n            bred_crumb_item = window.sessionStorage.getItem('breadCrumbItem') || '主菜单';\n        }\n\n        this.activeName = active_name;\n        this.breadCrumbItem = bred_crumb_item;\n\n    },\n    created() {\n        if (!window.sessionStorage.getItem('system_model')) {\n            window.sessionStorage.setItem('system_model', 'pv16');\n        }\n        Vue.set(this, 'system_model', window.sessionStorage.getItem('system_model') || 'pv16');\n        Vue.set(this, 'currentBackColor', window.sessionStorage.getItem('currentBackColor') || 'palevioletred');\n        \n        // console.log(3333,this.system_model);\n\n        // if (!window.sessionStorage.getItem('SNEC_ENV')) {\n        //     window.sessionStorage.setItem('SNEC_ENV', 'PV17');\n        // }\n\n        // 从sessionStorage里获取网站列表数据\n        let weblist = window.sessionStorage.getItem('WebSetList');\n        if(weblist){\n            this.WebSetList = JSON.parse(weblist);\n            console.log(222,this.WebSetList);\n        }\n        \n\n        var RoleCodeList = window.sessionStorage.getItem('RoleCodeList');\n        RoleCodeList = RoleCodeList.split(',');\n        // console.log('RoleCodeList',RoleCodeList);\n        RoleCodeList.forEach(item => {\n            if (item === 'A' || item === \"ITHG\") {\n                this.showMenu1 = true;\n            }\n            // 巴西测试业务员，只能预览PV巴西\n            if (item === 'YY') {\n                this.showSwitchSys = false;\n                window.sessionStorage.setItem('system_model', 'indo');\n                // window.sessionStorage.setItem('grpc', 'GrpcCMS_INDO');\n                window.sessionStorage.setItem('SNEC_ENV', 'INDO');\n                window.sessionStorage.setItem('logo_SYSTEM', '/images/snec_logo.svg');\n                window.sessionStorage.setItem('logo_SYSTEM_sm', '/images/snec_logo_sm.svg');\n                Vue.set(this, 'system_model', 'indo');\n                window.sessionStorage.setItem('currentBackColor', 'rgb(255, 211, 155)');\n            }\n            if (item === 'JAPANESE') {\n                this.RoleCode = item;\n            }\n        });\n        console.log('this.showSwitchSys', this.showSwitchSys)\n\n        var PurviewCodes = window.sessionStorage.getItem('PurviewCodes');\n        PurviewCodes = JSON.parse(PurviewCodes);\n        // let sysModel = this.system_model;\n        // console.log('sysModel', sysModel);\n        this.menuList = [];\n        PurviewCodes.forEach(item => {\n            if(item.SourceCode == this.system_model){\n                this.menuList.push(item);\n            }\n        });\n        console.log(this.menuList);\n        // 对新数组按Sort进行从大到小排序\n        this.menuList.sort(function (a, b) {\n            return a.Sort - b.Sort;\n        });\n\n\n        // if (sysModel === 0) {\n        //     this.menuList = [];\n        //     PurviewCodes.forEach(item => {\n        //         if(item.SourceCode == 'PV'){\n        //             this.menuList.push(item);\n        //         }\n        //     });\n        //     console.log(this.menuList);\n        //     // 对新数组按Sort进行从大到小排序\n        //     this.menuList.sort(function (a, b) {\n        //         return a.Sort - b.Sort;\n        //     });\n\n        // } else if (sysModel === 1) {\n        //     this.menuList = [];\n        //     PurviewCodes.forEach(item => {\n        //         if(item.SourceCode == 'ES浦东'){\n        //             this.menuList.push(item);\n        //         }\n        //     });\n        //     console.log(this.menuList);\n        //     // 对新数组按Sort进行从大到小排序\n        //     this.menuList.sort(function (a, b) {\n        //         return a.Sort - b.Sort;\n        //     });\n        // } else if (sysModel === 2) {\n        //     this.menuList = [];\n        //     PurviewCodes.forEach(item => {\n        //         if(item.SourceCode == 'HFC浦东'){\n        //             this.menuList.push(item);\n        //         }\n        //     });\n        //     console.log(this.menuList);\n        //     // 对新数组按Sort进行从大到小排序\n        //     this.menuList.sort(function (a, b) {\n        //         return a.Sort - b.Sort;\n        //     });\n        // } else if (sysModel === 3) {\n        //     this.menuList = [];\n        //     PurviewCodes.forEach(item => {\n        //         if(item.SourceCode == 'PV浦东'){\n        //             this.menuList.push(item);\n        //         }\n        //     });\n        //     console.log(this.menuList);\n        //     // 对新数组按Sort进行从大到小排序\n        //     this.menuList.sort(function (a, b) {\n        //         return a.Sort - b.Sort;\n        //     });\n        // } else if (sysModel === 4) {\n        //     this.menuList = [];\n        //     PurviewCodes.forEach(item => {\n        //         if(item.SourceCode == 'ES浦东2'){\n        //             this.menuList.push(item);\n        //         }\n        //     });\n        //     console.log(this.menuList);\n        //     // 对新数组按Sort进行从大到小排序\n        //     this.menuList.sort(function (a, b) {\n        //         return a.Sort - b.Sort;\n        //     });\n        // } else if (sysModel === 5) {\n        //     this.menuList = [];\n        //     PurviewCodes.forEach(item => {\n        //         if(item.SourceCode == 'HFC浦东2'){\n        //             this.menuList.push(item);\n        //         }\n        //     });\n        //     console.log(this.menuList);\n        //     // 对新数组按Sort进行从大到小排序\n        //     this.menuList.sort(function (a, b) {\n        //         return a.Sort - b.Sort;\n        //     });\n        // } else if (sysModel === 6) {\n        //     this.menuList = [];\n        //     PurviewCodes.forEach(item => {\n        //         if(item.SourceCode == 'NEV'){\n        //             this.menuList.push(item);\n        //         }\n        //     });\n        //     console.log(this.menuList);\n        //     // 对新数组按Sort进行从大到小排序\n        //     this.menuList.sort(function (a, b) {\n        //         return a.Sort - b.Sort;\n        //     });\n        // } else if (sysModel === 7) {\n        //     this.menuList = [];\n        //     PurviewCodes.forEach(item => {\n        //         if(item.SourceCode == 'HFCDL'){\n        //             this.menuList.push(item);\n        //         }\n        //     });\n        //     console.log(this.menuList);\n        //     // 对新数组按Sort进行从大到小排序\n        //     this.menuList.sort(function (a, b) {\n        //         return a.Sort - b.Sort;\n        //     });\n        // } else if (sysModel === 8) {\n        //     this.menuList = [];\n        //     PurviewCodes.forEach(item => {\n        //         if(item.SourceCode == 'HEA'){\n        //             this.menuList.push(item);\n        //         }\n        //     });\n        //     console.log(this.menuList);\n        //     // 对新数组按Sort进行从大到小排序\n        //     this.menuList.sort(function (a, b) {\n        //         return a.Sort - b.Sort;\n        //     });\n        // } else if (sysModel === 9) {\n        //     this.menuList = [];\n        //     PurviewCodes.forEach(item => {\n        //         if(item.SourceCode == 'FOLLOWME'){\n        //             this.menuList.push(item);\n        //         }\n        //     });\n        //     console.log(this.menuList);\n        //     // 对新数组按Sort进行从大到小排序\n        //     this.menuList.sort(function (a, b) {\n        //         return a.Sort - b.Sort;\n        //     });\n        // } else if (sysModel === 10) {\n        //     this.menuList = [];\n        //     PurviewCodes.forEach(item => {\n        //         if(item.SourceCode == 'GGET'){\n        //             this.menuList.push(item);\n        //         }\n        //     });\n        //     console.log(this.menuList);\n        //     // 对新数组按Sort进行从大到小排序\n        //     this.menuList.sort(function (a, b) {\n        //         return a.Sort - b.Sort;\n        //     });\n        // } else if (sysModel === 11) {\n        //     this.menuList = [];\n        //     PurviewCodes.forEach(item => {\n        //         if(item.SourceCode == 'PVS'){\n        //             this.menuList.push(item);\n        //         }\n        //     });\n        //     console.log(this.menuList);\n        //     // 对新数组按Sort进行从大到小排序\n        //     this.menuList.sort(function (a, b) {\n        //         return a.Sort - b.Sort;\n        //     });\n        // } else if (sysModel === 12) {\n        //     this.menuList = [];\n        //     PurviewCodes.forEach(item => {\n        //         if(item.SourceCode == 'NEIAAP'){\n        //             this.menuList.push(item);\n        //         }\n        //     });\n        //     console.log(this.menuList);\n        //     // 对新数组按Sort进行从大到小排序\n        //     this.menuList.sort(function (a, b) {\n        //         return a.Sort - b.Sort;\n        //     });\n        // } else if (sysModel === 13) {\n        //     this.menuList = [];\n        //     PurviewCodes.forEach(item => {\n        //         if(item.SourceCode == 'APVIA'){\n        //             this.menuList.push(item);\n        //         }\n        //     });\n        //     console.log(this.menuList);\n        //     // 对新数组按Sort进行从大到小排序\n        //     this.menuList.sort(function (a, b) {\n        //         return a.Sort - b.Sort;\n        //     });\n        // } else if (sysModel === 14) {\n        //     this.menuList = [];\n        //     PurviewCodes.forEach(item => {\n        //         if(item.SourceCode == '小程序'){\n        //             this.menuList.push(item);\n        //         }\n        //     });\n        //     console.log(this.menuList);\n        //     // 对新数组按Sort进行从大到小排序\n        //     this.menuList.sort(function (a, b) {\n        //         return a.Sort - b.Sort;\n        //     });\n        // }else if (sysModel === 15) {\n        //     this.menuList = [];\n        //     PurviewCodes.forEach(item => {\n        //         if(item.SourceCode == '小程序pv'){\n        //             this.menuList.push(item);\n        //         }\n        //     });\n        //     console.log(this.menuList);\n        //     // 对新数组按Sort进行从大到小排序\n        //     this.menuList.sort(function (a, b) {\n        //         return a.Sort - b.Sort;\n        //     });\n        // }\n    }\n}\n</script>\n  ","<template>\n    <div>\n        <div v-if='!currentImg'>\n            <template>{{ $t('图片加载中，请稍候...') }}</template>\n        </div>\n        <div class=\"slide-verify\" :style=\"{ width: w + 'px' }\" id=\"slideVerify\" onselectstart=\"return false;\">\n            <!-- 图片加载遮蔽罩 -->\n            <div :class=\"{ 'slider-verify-loading': loadBlock }\"></div>\n            <canvas :width=\"w\" :height=\"h\" ref=\"canvas\"></canvas>\n            <div v-if=\"show\" @click=\"refreshSlider\" class=\"slide-verify-refresh-icon\"></div>\n            <canvas :width=\"w\" :height=\"h\" ref=\"block\" class=\"slide-verify-block\"></canvas>\n            <!-- container -->\n            <div class=\"slide-verify-slider\"\n                :class=\"{ 'container-active': containerActive, 'container-success': containerSuccess, 'container-fail': containerFail }\">\n                <div class=\"slide-verify-slider-mask\" :style=\"{ width: sliderMaskWidth }\">\n                    <!-- slider -->\n                    <div @mousedown=\"sliderDown\" @touchstart=\"touchStartEvent\" @touchmove=\"touchMoveEvent\"\n                        @touchend=\"touchEndEvent\" class=\"slide-verify-slider-mask-item\" :style=\"{ left: sliderLeft }\">\n                        <div class=\"slide-verify-slider-mask-item-icon\"></div>\n                    </div>\n                </div>\n                <span class=\"slide-verify-slider-text\">{{ sliderText }}</span>\n            </div>\n        </div>\n    </div>\n</template>\n<script>\nimport Vue from 'vue';\nimport axios from 'axios';\nimport Cookies from 'js-cookie';\nconst trans = require('./sliderVerify.json')\n\naxios.defaults.headers.post['Content-Type'] =\n    'application/x-www-form-urlencoded';\nVue.prototype.$axios = axios;\n\nconst PI = Math.PI;\n\nfunction sum(x, y) {\n    return x + y\n}\n\nfunction square(x) {\n    return x * x\n}\nexport default {\n    name: 'SlideVerify',\n    props: {\n        // block length\n        l: {\n            type: Number,\n            default: 42,\n        },\n        // block radius\n        r: {\n            type: Number,\n            default: 10,\n        },\n        // canvas width\n        w: {\n            type: Number,\n            default: 310,\n        },\n        // canvas height\n        h: {\n            type: Number,\n            default: 155,\n        },\n        sliderText: {\n            type: String\n        },\n        accuracy: {\n            type: Number,\n            default: 5, // 若为 -1 则不进行机器判断\n        },\n        show: {\n            type: Boolean,\n            default: true,\n        },\n        imgs: {\n            type: Array,\n            default: () => [],\n        },\n    },\n    data() {\n        return {\n            containerActive: false, // container active class\n            containerSuccess: false, // container success class\n            containerFail: false, // container fail class\n            canvasCtx: null,\n            blockCtx: null,\n            block: null,\n            block_x: undefined, // container random position\n            block_y: undefined,\n            L: this.l + this.r * 2 + 3, // block real lenght\n            img: undefined,\n            originX: undefined,\n            originY: undefined,\n            isMouseDown: false,\n            trail: [],\n            sliderLeft: 0, // block right offset\n            sliderMaskWidth: 0, // mask width,\n            success: false, // Bug Fixes 修复了验证成功后还能滑动\n            loadBlock: true, // Features 图片加载提示，防止图片没加载完就开始验证\n            timestamp: null,\n            sliderImgs: [],\n            currentImg: '',\n        }\n    },\n\n    mounted() {\n        // 设置定时器监测接口请求图片完成时再开始初始化拖动画面\n        let that = this;\n        let intv = setInterval(function () {\n            // console.log(1)\n            if (that.currentImg) {\n                // console.log(2)\n                that.init();\n                clearInterval(intv);\n            }\n        }, 600);\n\n    },\n    methods: {\n        init() {\n            this.initDom()\n            this.initImg()\n            this.bindEvents()\n        },\n        initDom() {\n            this.block = this.$refs.block;\n            this.canvasCtx = this.$refs.canvas.getContext('2d')\n            this.blockCtx = this.block.getContext('2d')\n        },\n        initImg() {\n            const img = this.createImg(() => {\n                if (img) {\n                    // 图片加载完关闭遮蔽罩\n                    this.loadBlock = false;\n                    this.drawBlock()\n                    this.canvasCtx.drawImage(img, 0, 0, this.w, this.h)\n                    this.blockCtx.drawImage(img, 0, 0, this.w, this.h)\n                    let {\n                        block_x: x,\n                        block_y: y,\n                        r,\n                        L\n                    } = this\n                    let _y = y - r * 2 - 1\n                    let ImageData = this.blockCtx.getImageData(x, _y, L, L);\n                    this.block.width = L;\n                    this.blockCtx.putImageData(ImageData, 0, _y)\n                }\n\n            });\n            this.img = img;\n        },\n        drawBlock() {\n            this.block_x = this.getRandomNumberByRange(this.L + 10, this.w - (this.L + 10))\n            this.block_y = this.getRandomNumberByRange(10 + this.r * 2, this.h - (this.L + 10))\n            this.draw(this.canvasCtx, this.block_x, this.block_y, 'fill')\n            this.draw(this.blockCtx, this.block_x, this.block_y, 'clip')\n        },\n        draw(ctx, x, y, operation) {\n            let {\n                l,\n                r\n            } = this;\n            ctx.beginPath()\n            ctx.moveTo(x, y)\n            ctx.arc(x + l / 2, y - r + 2, r, 0.72 * PI, 2.26 * PI)\n            ctx.lineTo(x + l, y)\n            ctx.arc(x + l + r - 2, y + l / 2, r, 1.21 * PI, 2.78 * PI)\n            ctx.lineTo(x + l, y + l)\n            ctx.lineTo(x, y + l)\n            ctx.arc(x + r - 2, y + l / 2, r + 0.4, 2.76 * PI, 1.24 * PI, true)\n            ctx.lineTo(x, y)\n            ctx.lineWidth = 2\n            ctx.fillStyle = 'rgba(255, 255, 255, 0.7)'\n            ctx.strokeStyle = 'rgba(255, 255, 255, 0.7)'\n            ctx.stroke()\n            ctx[operation]()\n            // Bug Fixes 修复了火狐和ie显示问题\n            ctx.globalCompositeOperation = \"destination-over\"\n        },\n\n        createImg(onload) {\n\n            const img = document.createElement('img');\n            img.crossOrigin = \"Anonymous\";\n            img.onload = onload;\n            img.onerror = () => {\n                if (this.currentImg) {\n                    img.src = this.currentImg;\n                }\n            }\n\n            if (this.currentImg) {\n                img.src = this.currentImg;\n                return img;\n            }\n\n\n        },\n        // 随机生成img src\n        getRandomImg() {\n            // return require('../assets/img.jpg')\n            // console.log('aaa ',this.getRandomNumberByRange(0, len));\n            // const len = this.imgs.length;\n            // return len > 0 ?\n            //   this.imgs[this.getRandomNumberByRange(0, len)] :\n            //   'https://picsum.photos/300/150/?image=' + this.getRandomNumberByRange(0, 1084);\n            console.log('this.sliderImgs', this.sliderImgs);\n            if (this.sliderImgs.length > 0) {\n                return this.sliderImgs[0];\n            }\n        },\n\n        //判断图片是否存在\n        CheckImgExistsAsync() {\n            const len = this.imgs.length;\n            var imgurl = 'https://picsum.photos/300/150/?image=' + this.getRandomNumberByRange(0, 1084);\n            let that = this;\n            return new Promise(function (resolve, reject) {\n                try {\n                    var ImgObj = new Image(); //判断图片是否存在\n                    ImgObj.src = imgurl;\n                    ImgObj.onload = function (res) {\n                        // let str = '图片加载完成'\n                        resolve(imgurl);\n                    }\n                    ImgObj.onerror = function (err) {\n                        reject(err);\n                        resolve(that.imgs[that.getRandomNumberByRange(0, len)]);\n                    }\n                } catch (e) {\n                    console.log(e);\n                    resolve(that.imgs[that.getRandomNumberByRange(0, len)]);\n                }\n\n            })\n        },\n        CheckImgExists() {\n            // var ImgObj = new Image(); //判断图片是否存在  \n            // ImgObj.src = imgurl;\n            // console.log('ImgObj',ImgObj);  \n            // //存在图片 调出来引用\n            // if (ImgObj.fileSize > 0 || (ImgObj.width > 0 && ImgObj.height > 0)) {  \n            //     this.currentImg = imgurl;\n            //     console.log('this.currentImg22',this.currentImg);\n            // } else { \n            //     // 当前图片不存在，调用本地图片 每次随机调出一张图片放到新数组里 \n            //     this.currentImg = this.imgs[this.getRandomNumberByRange(0, len)];\n            // }   \n            const len = this.imgs.length;\n            let that = this;\n            // 当前图片不存在，调用本地图片 每次随机调出一张图片放到新数组里 \n            that.currentImg = that.imgs[that.getRandomNumberByRange(0, len)];\n            // that.CheckImgExistsAsync().then((res)=>{\n            //     // console.log('125',res)\n            //     that.currentImg = res;\n            // }).catch((err)=>{\n            //     // 当前图片不存在，调用本地图片 每次随机调出一张图片放到新数组里 \n            //     that.currentImg = that.imgs[that.getRandomNumberByRange(0, len)];\n            // });   \n\n        },\n\n        // 获取第三方库图片，如果不存在，则调用本地图片\n        getImgFromPics() {\n            // this.sliderImgs = [];//默认置空\n            const len = this.imgs.length;\n            let picsrc = 'https://picsum.photos/300/150/?image=' + this.getRandomNumberByRange(0, 1084);\n\n            // 这里需要请求图片地址，判断图片是否存在后再决定调不调第三方图库的图片出来显示\n            return axios({\n                method: \"get\",\n                headers: {\n                    // \"x-csrf-token\":Cookies.get('csrfToken')\n                },\n                url: picsrc,\n                data: {}\n            }).then(res => {\n                if (res.status == 200) {\n                    // console.log('res',res);\n                    // 图片存在，调出来引用\n                    // this.sliderImgs.push(picsrc);\n                    // console.log('this.sliderImgs',this.sliderImgs);\n                    this.currentImg = picsrc;\n                    console.log('this.currentImg11', this.currentImg);\n                } else {\n                    // 当前图片不存在，调用本地图片 每次随机调出一张图片放到新数组里\n                    // this.sliderImgs.push(this.imgs[this.getRandomNumberByRange(0, len)]);\n                    // console.log('this.sliderImgs',this.sliderImgs);\n                    // return this.imgs[this.getRandomNumberByRange(0, len)];\n                    this.currentImg = this.imgs[this.getRandomNumberByRange(0, len)];\n                }\n            }).catch(err => {\n                this.CatchErr(err);\n                // 当前图片不存在，调用本地图片 每次随机调出一张图片放到新数组里\n                // this.sliderImgs.push(this.imgs[this.getRandomNumberByRange(0, len)]);\n                // console.log('this.sliderImgs',this.sliderImgs);\n                // return this.imgs[this.getRandomNumberByRange(0, len)];\n                this.currentImg = this.imgs[this.getRandomNumberByRange(0, len)];\n            });\n        },\n\n        getRandomNumberByRange(start, end) {\n            // console.log('random ',Math.random() * (end - start) + start);\n            return Math.round(Math.random() * (end - start)) + start\n        },\n        refreshSlider() {\n            this.reset();\n            this.$emit('refresh');\n        },\n        sliderDown(event) {\n            if (this.success) return;\n            this.originX = event.clientX;\n            this.originY = event.clientY;\n            this.isMouseDown = true;\n            this.timestamp = + new Date();\n        },\n        touchStartEvent(e) {\n            if (this.success) return;\n            this.originX = e.changedTouches[0].pageX;\n            this.originY = e.changedTouches[0].pageY;\n            this.isMouseDown = true;\n            this.timestamp = + new Date();\n        },\n        bindEvents() {\n            document.addEventListener('mousemove', (e) => {\n                if (!this.isMouseDown) return false;\n                const moveX = e.clientX - this.originX;\n                const moveY = e.clientY - this.originY;\n                if (moveX < 0 || moveX + 38 >= this.w) return false;\n                this.sliderLeft = moveX + 'px';\n                let blockLeft = (this.w - 40 - 20) / (this.w - 40) * moveX;\n                this.block.style.left = blockLeft + 'px';\n\n                this.containerActive = true; // add active\n                this.sliderMaskWidth = moveX + 'px';\n                this.trail.push(moveY);\n            });\n            document.addEventListener('mouseup', (e) => {\n                if (!this.isMouseDown) return false\n                this.isMouseDown = false\n                if (e.clientX === this.originX) return false;\n                this.containerActive = false; // remove active\n                this.timestamp = + new Date() - this.timestamp;\n\n                const {\n                    spliced,\n                    TuringTest\n                } = this.verify();\n                if (spliced) {\n                    if (this.accuracy === -1) {\n                        this.containerSuccess = true;\n                        this.success = true;\n                        this.$emit('success', this.timestamp);\n                        return;\n                    }\n                    if (TuringTest) {\n                        // succ\n                        this.containerSuccess = true;\n                        this.success = true;\n                        this.$emit('success', this.timestamp)\n                    } else {\n                        this.containerFail = true;\n                        this.$emit('again')\n                    }\n                } else {\n                    this.containerFail = true;\n                    this.$emit('fail')\n                    setTimeout(() => {\n                        this.reset()\n                    }, 1000)\n                }\n            })\n        },\n        touchMoveEvent(e) {\n            if (!this.isMouseDown) return false;\n            const moveX = e.changedTouches[0].pageX - this.originX;\n            const moveY = e.changedTouches[0].pageY - this.originY;\n            if (moveX < 0 || moveX + 38 >= this.w) return false;\n            this.sliderLeft = moveX + 'px';\n            let blockLeft = (this.w - 40 - 20) / (this.w - 40) * moveX;\n            this.block.style.left = blockLeft + 'px';\n\n            this.containerActive = true;\n            this.sliderMaskWidth = moveX + 'px';\n            this.trail.push(moveY);\n        },\n        touchEndEvent(e) {\n            if (!this.isMouseDown) return false\n            this.isMouseDown = false\n            if (e.changedTouches[0].pageX === this.originX) return false;\n            this.containerActive = false;\n            this.timestamp = + new Date() - this.timestamp;\n\n            const {\n                spliced,\n                TuringTest\n            } = this.verify();\n            if (spliced) {\n                if (this.accuracy === -1) {\n                    this.containerSuccess = true;\n                    this.success = true;\n                    this.$emit('success', this.timestamp);\n                    return;\n                }\n                if (TuringTest) {\n                    // succ\n                    this.containerSuccess = true;\n                    this.success = true;\n                    this.$emit('success', this.timestamp)\n                } else {\n                    this.containerFail = true;\n                    this.$emit('again')\n                }\n            } else {\n                this.containerFail = true;\n                this.$emit('fail')\n                setTimeout(() => {\n                    this.reset()\n                }, 1000)\n            }\n        },\n        verify() {\n            const arr = this.trail // drag y move distance\n            const average = arr.reduce(sum) / arr.length // average\n            const deviations = arr.map(x => x - average) // deviation array\n            const stddev = Math.sqrt(deviations.map(square).reduce(sum) / arr.length) // standard deviation\n            const left = parseInt(this.block.style.left)\n            const accuracy = this.accuracy <= 1 ? 1 : this.accuracy > 10 ? 10 : this.accuracy;\n            return {\n                spliced: Math.abs(left - this.block_x) <= accuracy,\n                TuringTest: average !== stddev, // equal => not person operate\n            }\n        },\n\n        reset() {\n            // 每次重置时重新获取图片\n            this.currentImg = '';\n            // this.getImgFromPics();\n            //判断图片是否存在\n            this.CheckImgExists();\n\n            this.success = false;\n            this.containerActive = false;\n            this.containerSuccess = false;\n            this.containerFail = false;\n            this.sliderLeft = 0;\n            this.block.style.left = 0;\n            this.sliderMaskWidth = 0;\n            // canvas\n            let {\n                w,\n                h\n            } = this;\n            this.canvasCtx.clearRect(0, 0, w, h)\n            this.blockCtx.clearRect(0, 0, w, h)\n            this.block.width = w\n\n            // // generate img\n            // this.img.src = this.getRandomImg();\n            // console.log('this.img.src ',this.img.src);\n            // 设置定时器监测接口请求图片完成时再开始初始化拖动画面\n            let that = this;\n            let intv = setInterval(function () {\n                // console.log(1)\n                if (that.currentImg) {\n                    // console.log(2)\n                    that.img.src = that.currentImg;\n                    that.$emit('fulfilled')\n                    clearInterval(intv);\n                }\n            }, 600);\n\n        },\n    },\n    created() {\n        this.$i18n.mergeLocaleMessage(\"en\", trans.en);\n        this.$i18n.mergeLocaleMessage(\"zh\", trans.zh);\n        // // 获取第三方库图片，如果不存在，则调用本地图片\n        // this.getImgFromPics();\n        //判断图片是否存在\n        this.CheckImgExists();\n    }\n}\n</script>\n<style scoped>\n.slide-verify {\n    position: relative;\n}\n\n/* 图片加载样式 */\n.slider-verify-loading {\n    position: absolute;\n    top: 0;\n    right: 0;\n    left: 0;\n    bottom: 0;\n    background: rgba(255, 255, 255, 0.9);\n    z-index: 999;\n    animation: loading 1.5s infinite;\n}\n\n@keyframes loading {\n    0% {\n        opacity: .7;\n    }\n\n    100% {\n        opacity: 9;\n    }\n}\n\n.slide-verify-block {\n    position: absolute;\n    left: 0;\n    top: 0\n}\n\n.slide-verify-refresh-icon {\n    position: absolute;\n    right: 0;\n    top: 0;\n    width: 34px;\n    height: 34px;\n    cursor: pointer;\n    background: url(\"../assets/icon_light.png\") 0 -437px;\n    background-size: 34px 471px\n}\n\n.slide-verify-slider {\n    position: relative;\n    text-align: center;\n    width: 100%;\n    height: 40px;\n    line-height: 40px;\n    margin-top: 15px;\n    background: #f7f9fa;\n    color: #45494c;\n    border: 1px solid #e4e7eb\n}\n\n.slide-verify-slider-mask {\n    position: absolute;\n    left: 0;\n    top: 0;\n    height: 40px;\n    border: 0 solid #1991FA;\n    background: #D1E9FE\n}\n\n.slide-verify-slider-mask-item {\n    position: absolute;\n    top: 0;\n    left: 0;\n    width: 40px;\n    height: 40px;\n    background: #fff;\n    box-shadow: 0 0 3px rgba(0, 0, 0, 0.3);\n    cursor: pointer;\n    transition: background .2s linear\n}\n\n.slide-verify-slider-mask-item:hover {\n    background: #1991FA\n}\n\n.slide-verify-slider-mask-item:hover .slide-verify-slider-mask-item-icon {\n    background-position: 0 -13px\n}\n\n.slide-verify-slider-mask-item-icon {\n    position: absolute;\n    top: 15px;\n    left: 13px;\n    width: 14px;\n    height: 12px;\n    background: url(\"../assets/icon_light.png\") 0 -26px;\n    background-size: 34px 471px\n}\n\n.container-active .slide-verify-slider-mask-item {\n    height: 38px;\n    top: -1px;\n    border: 1px solid #1991FA;\n}\n\n.container-active .slide-verify-slider-mask {\n    height: 38px;\n    border-width: 1px;\n}\n\n.container-success .slide-verify-slider-mask-item {\n    height: 38px;\n    top: -1px;\n    border: 1px solid #52CCBA;\n    background-color: #52CCBA !important;\n}\n\n.container-success .slide-verify-slider-mask {\n    height: 38px;\n    border: 1px solid #52CCBA;\n    background-color: #D2F4EF;\n}\n\n.container-success .slide-verify-slider-mask-item-icon {\n    background-position: 0 0 !important;\n}\n\n.container-fail .slide-verify-slider-mask-item {\n    height: 38px;\n    top: -1px;\n    border: 1px solid #f57a7a;\n    background-color: #f57a7a !important;\n}\n\n.container-fail .slide-verify-slider-mask {\n    height: 38px;\n    border: 1px solid #f57a7a;\n    background-color: #fce1e1;\n}\n\n.container-fail .slide-verify-slider-mask-item-icon {\n    top: 14px;\n    background-position: 0 -82px !important;\n}\n\n.container-active .slide-verify-slider-text,\n.container-success .slide-verify-slider-text,\n.container-fail .slide-verify-slider-text {\n    display: none;\n}\n</style>\n","<!-- 拖动组件自定义封装  by:王燕南 -->\n<template>\n    <div id=\"publicSliderVerify\">\n        <SlideVerify class=\"slideVer\" ref=\"slideblock\" :w='265' :imgs=\"imgs\" :slider-text='sliderText' :accuracy=\"accuracy\"\n            @success=\"onSuccess\" @again=\"onAgain\" @fulfilled=\"onFulfilled\" @fail=\"onFail\" @refresh=\"onRefresh\">\n        </SlideVerify>\n    <!-- <div>{{msg}}</div>\n          <button class=\"btn\" @click=\"handleClick\">在父组件可以点我刷新哦</button> -->\n    </div>\n</template>\n\n<script>\nimport SlideVerify from './components/sliderVerify.vue';\nimport img0 from './assets/img.jpg';\nimport img1 from './assets/img1.jpg';\nimport img2 from './assets/img2.jpg';\nimport img3 from './assets/img3.jpg';\nimport img4 from './assets/img4.jpg';\nimport img5 from './assets/img5.jpg';\nimport img6 from './assets/img6.jpg';\nimport img7 from './assets/img7.jpg';\nimport img8 from './assets/img8.jpg';\nimport img9 from './assets/img9.jpg';\nconst trans = require('./publicSliderVerify.json')\nexport default {\n    name: 'PublicSliderVerify',\n    components: { SlideVerify },\n    props: ['sliderText'],\n    data() {\n        return {\n            msg: '',\n            text: this.$t('向右滑动->'),\n            imgs: [\n                img0,\n                img1,\n                img2,\n                img3,\n                img4,\n                img5,\n                img6,\n                img7,\n                img8,\n                img9,\n            ],\n            accuracy: 2, // 精确度小，可允许的误差范围小；为1时，则表示滑块要与凹槽完全重叠，才能验证成功。默认值为5\n            // sliderImgs:[],\n        }\n    },\n    computed: {\n        // sliderText: function() {\n        //     if (this.locale == \"zh-cn\") {\n        //         console.log(46)\n        //         return '向右滑动，完成拼图';\n        //     }else if (this.locale == \"en-us\"){\n        //         return 'Slide to the right to complete the puzzle';\n        //     }else if (this.locale == \"japanese\"){\n        //         return '右にスライドして、パズルを完成します';\n        //     }\n        // },\n    },\n    methods: {\n        onSuccess(times) {\n            console.log('验证通过');\n            // this.msg = `login success, 耗时${(times / 1000).toFixed(1)}s`;\n            let sliderOk = true;\n            // 通知父组件更新状态\n            this.$emit('resetSliderSuccess', sliderOk);\n        },\n        onFail() {\n            console.log('验证不通过');\n            // this.msg = ''\n            let sliderOk = false;\n            // 通知父组件更新状态\n            this.$emit('resetSliderSuccess', sliderOk);\n        },\n        onRefresh() {\n            console.log('点击了刷新小图标');\n            // this.msg = ''\n            let sliderOk = false;\n            // 通知父组件更新状态\n            this.$emit('resetSliderSuccess', sliderOk);\n        },\n        onFulfilled() {\n            // console.log('刷新成功啦！');\n            // let sliderOk = false;\n            // // 通知父组件更新状态\n            // this.$emit('resetSliderSuccess',sliderOk);\n        },\n        onAgain() {\n            console.log('检测到非人为操作的哦！');\n            this.msg = 'try again';\n            let sliderOk = false;\n            // 通知父组件更新状态\n            this.$emit('resetSliderSuccess', sliderOk);\n            // 刷新\n            this.handleClick();\n        },\n        handleClick() {\n            this.$refs.slideblock.reset();\n            this.msg = ''\n            let sliderOk = false;\n            // 通知父组件更新状态\n            this.$emit('resetSliderSuccess', sliderOk);\n        },\n    },\n    mounted() {\n        // const oScript = document.createElement('script');\n        // oScript.type = 'text/javascript';\n        // oScript.src = '/js/slide-verify.js';\n        // document.body.appendChild(oScript);\n    },\n    created() {\n        this.$i18n.mergeLocaleMessage(\"en\", trans.en);\n        this.$i18n.mergeLocaleMessage(\"zh\", trans.zh);\n    }\n}\n</script>\n\n<style>\n#publicSliderVerify {\n    font-family: 'Avenir', Helvetica, Arial, sans-serif;\n    -webkit-font-smoothing: antialiased;\n    -moz-osx-font-smoothing: grayscale;\n    color: #2c3e50;\n}\n\n.btn {\n    margin-top: 20px;\n    outline: 0;\n    border: none;\n    padding: 8px 15px;\n    border-radius: 5px;\n    color: #fff;\n    background-color: #1890ff;\n    cursor: pointer;\n}\n\n.btn:active {\n    box-shadow: 1px 5px 0 rgba(0, 0, 0, 0.1) inset;\n}</style>\n",".login[data-v-a49090ce] {\n    width: 100%;\n    height: 100%;\n    padding: 0;\n    /* background-image: url(https://file.iviewui.com/iview-admin/login_bg.jpg); */\n    background-image: url(https://download.snec.org.cn/SNEC/article/2025/03/13//login_bg-95115908.jpg);\n    background-size: cover;\n    background-position: center;\n    position: relative;\n}\n.login-con[data-v-a49090ce] {\n    position: absolute;\n    right: 160px;\n    top: 50%;\n    transform: translateY(-60%);\n    width: 300px;\n}\n.login-con .form-con[data-v-a49090ce] {\n    padding: 10px 0 0;\n}\n.login-con .login-tip[data-v-a49090ce] {\n    font-size: 10px;\n    text-align: center;\n    color: #c3c3c3;\n}\n@media (max-width: 767px){\n.login-con[data-v-a49090ce]{\n        top:50%;\n        left:50%;\n        transform: translate(-50%,-50%);\n}\n}","<template>\n    <NoLayout>\n        <div class=\"login\" @keydown.enter=\"checkVerificationCode\">\n            <div class=\"login-con\">\n                <Card :bordered=\"false\">\n                    <p slot=\"title\">\n                        <Icon type=\"log-in\"></Icon>\n                        {{ $t(\"欢迎登录网站后台管理系统\") }}\n                    </p>\n                    <div style=\"padding:0 0 0 20px;font-size: 12px;\">语言/Language:<a\n                            :style=\"{ color: $i18n.locale === 'en-US' ? 'black' : 'orange' }\"\n                            @click=\"changeLanguage('zh-CN')\">中文</a> &nbsp;&nbsp;<a\n                            :style=\"{ color: $i18n.locale === 'zh-CN' ? 'black' : 'orange' }\"\n                            @click=\"changeLanguage('en-US')\">ENGLISH</a></div>\n                    <div class=\"form-con\">\n                        <Form ref=\"loginForm\" :model=\"form\" :rules=\"rules\">\n                            <FormItem prop=\"userName\">\n                                <Input v-model=\"form.userName\" placeholder=\"$t('请输入用户名')\">\n                                <span slot=\"prepend\">\n                                    <Icon :size=\"16\" type=\"person\"></Icon>\n                                </span>\n                                </Input>\n                            </FormItem>\n                            <FormItem prop=\"password\">\n                                <Input type=\"password\" v-model=\"form.password\" placeholder=\"$t('请输入密码')\">\n                                <span slot=\"prepend\">\n                                    <Icon :size=\"14\" type=\"locked\"></Icon>\n                                </span>\n                                </Input>\n                            </FormItem>\n                            <FormItem prop=\"verification\">\n                                <template>\n                                    <PublicSliderVerify ref=\"publicSliderVerify\" :slider-text=\"$t('向右滑动，完成拼图')\"\n                                        @resetSliderSuccess='resetSliderSuccess'></PublicSliderVerify>\n                                </template>\n                                <!-- <span class=\"form_span\">验证码:</span>\n                            <Input v-model=\"form.verification\" placeholder=\"请输入验证码\" style=\"width:45%;\"></Input>\n                            <div style=\"margin-top:15px;margin-left:44px;\">\n                                <img :src='\"data:image/png;base64,\"+verificationImg'/>\n                                <a href=\"javascript:void(0)\" style=\"font-size: 14px;display: inline-block;margin-left: 10px;vertical-align: top;margin-top: 4px;\" @click=\"getVerification\">换一张</a>\n                            </div> -->\n                                <!-- <button style=\"border-radius: 4px;border: none;color: #fff;background: #f90;padding: 0 10px;font-size: 14px;margin-left: 5px;\">获取验证码</button> -->\n                            </FormItem>\n                            <FormItem>\n                                <Button @click=\"checkVerificationCode\" type=\"primary\" long>{{ $t('登录') }}</Button>\n                            </FormItem>\n                        </Form>\n                        <p class=\"login-tip\">{{ $t('输入用户名和密码') }}</p>\n                    </div>\n                </Card>\n            </div>\n        </div>\n    </NoLayout>\n</template>\n<style scoped src='./login.css'>\n/* @import \"login.css\"; */\n</style>\n<style>\nhtml,\nbody,\n#main1,\n#main1>div {\n    height: 100%;\n}\n</style>\n<script type=\"text/babel\">\nimport Vue from 'vue';\nimport axios from 'axios';\nimport Cookies from 'js-cookie';\n\nconst trans = require(\"./login.json\");\nimport PublicSliderVerify from '../publicSliderVerify/publicSliderVerify.vue';\n\naxios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded';\nVue.prototype.$axios = axios;\n\nexport default {\n    components: { PublicSliderVerify },\n    data() {\n        return {\n            form: {\n                userName: 'test',\n                password: 'ccVoqH',\n                verification: ''\n            },\n            rules: {\n                userName: [\n                    { required: true, message: this.$t('账号不能为空'), trigger: 'blur' }\n                ],\n                password: [\n                    { required: true, message: this.$t('密码不能为空'), trigger: 'blur' }\n                ]\n            },\n            verificationImg: '',\n            verificationAnswer: '',\n            sliderSuccess: false,\n            sliderImgs: [],\n        };\n    },\n    methods: {\n        resetSliderSuccess(sliderOk) {\n            this.sliderSuccess = sliderOk;\n            console.log('this.sliderSuccess', this.sliderSuccess);\n        },\n        //ES5原生去重办法\n        Es5duplicate(arr, type) {\n            var newArr = [];\n            var tArr = [];\n            if (arr.length == 0) {\n                return arr;\n            } else {\n                for (var i = 0; i < arr.length; i++) {\n                    if (!tArr[arr[i][type]]) {\n                        newArr.push(arr[i]);\n                        tArr[arr[i][type]] = true;\n                    }\n                }\n                return newArr;\n            }\n        },\n        // 获取验证码（图片格式）\n        getVerification() {\n            //获取安全密钥csrfToken\n            const csrftoken = Cookies.get('csrfToken');\n            axios({\n                method: \"get\",\n                url: this.VERIFICATION_CODE + \"api/captcha\",\n                headers: {\n                    \"x-csrf-token\": csrftoken\n                },\n                data: {}\n            }).then((res) => {\n                console.log('getVerification', res)\n                if (res.status === 200) {\n                    this.verificationImg = res.data.image;\n                    this.verificationAnswer = res.data.answer;\n                }\n\n            }).catch((err) => {\n                console.log(err)\n                this.CatchErr(err);\n            });\n        },\n        // 校验验证码\n        checkVerificationCode() {\n            //获取安全密钥csrfToken\n            // const csrftoken = Cookies.get('csrfToken');\n            // axios({\n            //     method: \"post\",\n            //     url: this.VERIFICATION_CODE+\"api/captcha/verify\",\n            //     headers:{\n            //         \"x-csrf-token\":csrftoken\n            //     },\n            //     data: {\n            //         Answer:this.form.verification,\n            //         Captcha:this.verificationAnswer,\n            //     }\n            // }).then((res) => {\n            //     console.log('checkVerificationCode',res)\n            //     if(res.data.code != 100){\n            //         this.$Message.warning(res.data.message);   \n            //         this.getVerification();\n            //         return;\n            //     }else if(res.data.code === 100){\n            //         // 验证表单\n            //         this.handleSubmit();\n            //     }\n\n            // }).catch((err)=>{\n            //     console.log(err)\n            //     this.CatchErr(err);\n            // });\n            if (this.sliderSuccess) {\n                this.handleSubmit();\n            } else {\n                this.$refs.publicSliderVerify.handleClick();\n            }\n        },\n        handleClick() {\n            // 父组件直接可以调用刷新方法\n            this.$refs.slideblock.reset();\n            this.getRandomImg();\n        },\n        // 随机生成img src 图库有图片用图库的，没有用本地的   -----暂时不用\n        getRandomImg() {\n            // return require('../assets/img.jpg')\n            const len = this.localImgs.length;\n            this.sliderImgs = [];\n\n            let picsrc = 'https://picsum.photos/300/150/?image=' + this.getRandomNumberByRange(0, 1084);\n            // 这里需要请求图片地址，判断图片是否存在后再决定调不调第三方图库的图片出来显示\n            axios({\n                method: \"get\",\n                headers: {\n                    // \"x-csrf-token\":Cookies.get('csrfToken')\n                },\n                url: picsrc,\n                data: {}\n            }).then(res => {\n                if (res.status == 200) {\n                    // console.log('res',res);\n                    // 图片存在，调出来引用\n                    this.sliderImgs.push(picsrc);\n                } else {\n                    // 当前图片不存在，调用本地图片\n                    this.sliderImgs.push(this.localImgs[this.getRandomNumberByRange(0, len)]);\n                }\n            }).catch(err => {\n                //this.CatchErr(err);\n                // 当前图片不存在，调用本地图片\n                this.sliderImgs.push(this.localImgs[this.getRandomNumberByRange(0, len)]);\n            });\n            // if(picsrc){\n            //   this.sliderImgs.push(picsrc);\n            // }else{\n            //   this.sliderImgs.push(this.localImgs[this.getRandomNumberByRange(0, len)]); \n            // }\n            console.log('this.sliderImgs', this.sliderImgs);\n        },\n        getRandomNumberByRange(start, end) {\n            return Math.round(Math.random() * (end - start)) + start\n        },\n        handleSubmit() {\n            //获取安全密钥csrftoken\n            const csrftoken = Cookies.get('csrfToken');\n            const _this = this\n            //提交post请求\n            this.$axios({\n                method: 'post',\n                headers: {\n                    // 'x-csrf-token':csrftoken\n                    'Content-Type': 'text/plain',\n                },\n                url: this.HOST_DEFAULT + 'GrpcRoleService.RoleServiceToGrpc/LoginToUser',\n                data: {\n                    UserName: this.form.userName,\n                    UserPassword: this.form.password\n                }\n            }).then((res) => {\n                console.log(res);\n                if (res.data.isLogin) {\n                    let csrf_token = res.headers['x-token-refresh'];\n                    // console.log(csrf_token);\n                    Cookies.set('csrf_token', csrf_token);\n                    Cookies.set('UserName', this.form.userName);\n                    window.sessionStorage.removeItem('activeName'); //每次登陆后清空sessionStorage里的activeName值\n                    window.sessionStorage.removeItem('breadCrumbItem');\n                    \n                    const arr = res.data.listdata;\n                    // 获取网站列表数据 将列表数据存到sessionStorage\n                    this.updateWebSetList(arr);\n                } else {\n                    alert(res.data.msg);\n                    this.$refs.publicSliderVerify.handleClick();\n                    // this.getVerification();\n                }\n            }).catch((err) => {\n                console.log(3333,err)\n                alert(this.$t('登录已过期，请重新登录！'));\n                this.$refs.publicSliderVerify.handleClick();\n                window.location.href = '/login';\n            });\n\n        },\n\n        // 获取网站列表数据\n        updateWebSetList(arr) {\n            const csrf_token = Cookies.get(\"csrf_token\");\n            const _this = this\n            //提交post请求  获取网站列表数据\n            axios({\n                method: \"post\",\n                headers: {\n                \"x-auth-token\": csrf_token,\n                \"Content-Type\": \"text/plain\",\n                },\n                url: this.HOST_DEFAULT + \"GrpcCMS_NEW.CMSToGrpcWebSet/getAllWebListInfoList\",\n                data: {},\n            })\n                .then((res) => {\n                console.log(res);\n                if (res.status == 200) {\n                    // 将网站列表存到sessionStorage\n                    window.sessionStorage.setItem('WebSetList', JSON.stringify(res.data.listdata));\n\n                    let PurviewCodes = [];\n                    let RoleCodeList = [];\n                    for (let i = 0; i < arr.length; i++) {\n                        RoleCodeList.push(arr[i].Role.RoleCode);\n                        PurviewCodes = PurviewCodes.concat(arr[i].purview_listdata);\n                        if (arr[i].Role.RoleCode === 'YY') _this.changeLanguage('en-US')\n                    }\n                    PurviewCodes = this.Es5duplicate(PurviewCodes, 'PurviewPK');\n                    // 将登陆的用户名存到sessionstorage里\n                    window.sessionStorage.setItem('UserName', this.form.userName);\n                    window.sessionStorage.setItem('PurviewCodes', JSON.stringify(PurviewCodes));\n                    window.sessionStorage.setItem('RoleCodeList', RoleCodeList.toString());\n\n                    console.log('PurviewCodes', PurviewCodes);\n                    let count = 0;\n                    RoleCodeList.forEach(item => {\n                        if (item === 'JAPANESE') {\n                            window.location.href = '/japanesePageArticles';\n                        } else {\n                            count++;\n                        }\n                    });\n                    if (count === RoleCodeList.length) {\n                        window.location.href = '/index';\n                        window.sessionStorage.setItem('refresh', 'true');\n                    }\n                }\n            })\n            .catch((err) => {\n                this.CatchErr(err);\n            });\n        },\n    },\n    mounted() {\n      document.title = this.$t('网站后台管理系统');\n      window.sessionStorage.removeItem('SNEC_ENV');\n     \n    },\n    created() {\n        // 获取验证码（图片格式）\n        //this.getVerification();\n        this.$i18n.mergeLocaleMessage(\"en\", trans.en);\n        this.$i18n.mergeLocaleMessage(\"zh\", trans.zh);\n        this.rules.userName[0].message = this.$t('账号不能为空');\n        this.rules.password[0].message = this.$t('密码不能为空');\n        console.log(this.HOST_DEFAULT);\n        console.log(\"V3-topbott 新框架 by wyn\")\n    }\n};\n</script>"],"sourceRoot":""}*/