{"remainingRequest":"D:\\源码\\vue-element-admin-master\\node_modules\\vue-loader\\lib\\index.js??vue-loader-options!D:\\源码\\vue-element-admin-master\\src\\views\\login\\index.vue?vue&type=script&lang=js&","dependencies":[{"path":"D:\\源码\\vue-element-admin-master\\src\\views\\login\\index.vue","mtime":1649647926000},{"path":"D:\\源码\\vue-element-admin-master\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"D:\\源码\\vue-element-admin-master\\node_modules\\babel-loader\\lib\\index.js","mtime":315532800000},{"path":"D:\\源码\\vue-element-admin-master\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"D:\\源码\\vue-element-admin-master\\node_modules\\vue-loader\\lib\\index.js","mtime":499162500000}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64:Ly8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KCmltcG9ydCB7IHZhbGlkVXNlcm5hbWUgfSBmcm9tICdAL3V0aWxzL3ZhbGlkYXRlJwppbXBvcnQgU29jaWFsU2lnbiBmcm9tICcuL2NvbXBvbmVudHMvU29jaWFsU2lnbmluJwoKZXhwb3J0IGRlZmF1bHQgewogIG5hbWU6ICdMb2dpbicsCiAgY29tcG9uZW50czogeyBTb2NpYWxTaWduIH0sCiAgZGF0YSgpIHsKICAgIGNvbnN0IHZhbGlkYXRlVXNlcm5hbWUgPSAocnVsZSwgdmFsdWUsIGNhbGxiYWNrKSA9PiB7CiAgICAgIGlmICghdmFsaWRVc2VybmFtZSh2YWx1ZSkpIHsKICAgICAgICBjYWxsYmFjayhuZXcgRXJyb3IoJ1BsZWFzZSBlbnRlciB0aGUgY29ycmVjdCB1c2VyIG5hbWUnKSkKICAgICAgfSBlbHNlIHsKICAgICAgICBjYWxsYmFjaygpCiAgICAgIH0KICAgIH0KICAgIGNvbnN0IHZhbGlkYXRlUGFzc3dvcmQgPSAocnVsZSwgdmFsdWUsIGNhbGxiYWNrKSA9PiB7CiAgICAgIGlmICh2YWx1ZS5sZW5ndGggPCA2KSB7CiAgICAgICAgY2FsbGJhY2sobmV3IEVycm9yKCdUaGUgcGFzc3dvcmQgY2FuIG5vdCBiZSBsZXNzIHRoYW4gNiBkaWdpdHMnKSkKICAgICAgfSBlbHNlIHsKICAgICAgICBjYWxsYmFjaygpCiAgICAgIH0KICAgIH0KICAgIHJldHVybiB7CiAgICAgIGxvZ2luRm9ybTogewogICAgICAgIHVzZXJuYW1lOiAnYWRtaW4nLAogICAgICAgIHBhc3N3b3JkOiAnMTExMTExJwogICAgICB9LAogICAgICBsb2dpblJ1bGVzOiB7CiAgICAgICAgdXNlcm5hbWU6IFt7IHJlcXVpcmVkOiB0cnVlLCB0cmlnZ2VyOiAnYmx1cicsIHZhbGlkYXRvcjogdmFsaWRhdGVVc2VybmFtZSB9XSwKICAgICAgICBwYXNzd29yZDogW3sgcmVxdWlyZWQ6IHRydWUsIHRyaWdnZXI6ICdibHVyJywgdmFsaWRhdG9yOiB2YWxpZGF0ZVBhc3N3b3JkIH1dCiAgICAgIH0sCiAgICAgIHBhc3N3b3JkVHlwZTogJ3Bhc3N3b3JkJywKICAgICAgY2Fwc1Rvb2x0aXA6IGZhbHNlLAogICAgICBsb2FkaW5nOiBmYWxzZSwKICAgICAgc2hvd0RpYWxvZzogZmFsc2UsCiAgICAgIHJlZGlyZWN0OiB1bmRlZmluZWQsCiAgICAgIG90aGVyUXVlcnk6IHt9CiAgICB9CiAgfSwKICB3YXRjaDogewogICAgJHJvdXRlOiB7CiAgICAgIGhhbmRsZXI6IGZ1bmN0aW9uKHJvdXRlKSB7CiAgICAgICAgY29uc3QgcXVlcnkgPSByb3V0ZS5xdWVyeQogICAgICAgIGlmIChxdWVyeSkgewogICAgICAgICAgdGhpcy5yZWRpcmVjdCA9IHF1ZXJ5LnJlZGlyZWN0CiAgICAgICAgICB0aGlzLm90aGVyUXVlcnkgPSB0aGlzLmdldE90aGVyUXVlcnkocXVlcnkpCiAgICAgICAgfQogICAgICB9LAogICAgICBpbW1lZGlhdGU6IHRydWUKICAgIH0KICB9LAogIGNyZWF0ZWQoKSB7CiAgICAvLyB3aW5kb3cuYWRkRXZlbnRMaXN0ZW5lcignc3RvcmFnZScsIHRoaXMuYWZ0ZXJRUlNjYW4pCiAgfSwKICBtb3VudGVkKCkgewogICAgaWYgKHRoaXMubG9naW5Gb3JtLnVzZXJuYW1lID09PSAnJykgewogICAgICB0aGlzLiRyZWZzLnVzZXJuYW1lLmZvY3VzKCkKICAgIH0gZWxzZSBpZiAodGhpcy5sb2dpbkZvcm0ucGFzc3dvcmQgPT09ICcnKSB7CiAgICAgIHRoaXMuJHJlZnMucGFzc3dvcmQuZm9jdXMoKQogICAgfQogIH0sCiAgZGVzdHJveWVkKCkgewogICAgLy8gd2luZG93LnJlbW92ZUV2ZW50TGlzdGVuZXIoJ3N0b3JhZ2UnLCB0aGlzLmFmdGVyUVJTY2FuKQogIH0sCiAgbWV0aG9kczogewogICAgY2hlY2tDYXBzbG9jayhlKSB7CiAgICAgIGNvbnN0IHsga2V5IH0gPSBlCiAgICAgIHRoaXMuY2Fwc1Rvb2x0aXAgPSBrZXkgJiYga2V5Lmxlbmd0aCA9PT0gMSAmJiAoa2V5ID49ICdBJyAmJiBrZXkgPD0gJ1onKQogICAgfSwKICAgIHNob3dQd2QoKSB7CiAgICAgIGlmICh0aGlzLnBhc3N3b3JkVHlwZSA9PT0gJ3Bhc3N3b3JkJykgewogICAgICAgIHRoaXMucGFzc3dvcmRUeXBlID0gJycKICAgICAgfSBlbHNlIHsKICAgICAgICB0aGlzLnBhc3N3b3JkVHlwZSA9ICdwYXNzd29yZCcKICAgICAgfQogICAgICB0aGlzLiRuZXh0VGljaygoKSA9PiB7CiAgICAgICAgdGhpcy4kcmVmcy5wYXNzd29yZC5mb2N1cygpCiAgICAgIH0pCiAgICB9LAogICAgaGFuZGxlTG9naW4oKSB7CiAgICAgIHRoaXMuJHJlZnMubG9naW5Gb3JtLnZhbGlkYXRlKHZhbGlkID0+IHsKICAgICAgICBpZiAodmFsaWQpIHsKICAgICAgICAgIHRoaXMubG9hZGluZyA9IHRydWUKICAgICAgICAgIHRoaXMuJHN0b3JlLmRpc3BhdGNoKCd1c2VyL2xvZ2luJywgdGhpcy5sb2dpbkZvcm0pCiAgICAgICAgICAgIC50aGVuKCgpID0+IHsKICAgICAgICAgICAgICB0aGlzLiRyb3V0ZXIucHVzaCh7IHBhdGg6IHRoaXMucmVkaXJlY3QgfHwgJy8nLCBxdWVyeTogdGhpcy5vdGhlclF1ZXJ5IH0pCiAgICAgICAgICAgICAgdGhpcy5sb2FkaW5nID0gZmFsc2UKICAgICAgICAgICAgfSkKICAgICAgICAgICAgLmNhdGNoKCgpID0+IHsKICAgICAgICAgICAgICB0aGlzLmxvYWRpbmcgPSBmYWxzZQogICAgICAgICAgICB9KQogICAgICAgIH0gZWxzZSB7CiAgICAgICAgICBjb25zb2xlLmxvZygnZXJyb3Igc3VibWl0ISEnKQogICAgICAgICAgcmV0dXJuIGZhbHNlCiAgICAgICAgfQogICAgICB9KQogICAgfSwKICAgIGdldE90aGVyUXVlcnkocXVlcnkpIHsKICAgICAgcmV0dXJuIE9iamVjdC5rZXlzKHF1ZXJ5KS5yZWR1Y2UoKGFjYywgY3VyKSA9PiB7CiAgICAgICAgaWYgKGN1ciAhPT0gJ3JlZGlyZWN0JykgewogICAgICAgICAgYWNjW2N1cl0gPSBxdWVyeVtjdXJdCiAgICAgICAgfQogICAgICAgIHJldHVybiBhY2MKICAgICAgfSwge30pCiAgICB9CiAgICAvLyBhZnRlclFSU2NhbigpIHsKICAgIC8vICAgaWYgKGUua2V5ID09PSAneC1hZG1pbi1vYXV0aC1jb2RlJykgewogICAgLy8gICAgIGNvbnN0IGNvZGUgPSBnZXRRdWVyeU9iamVjdChlLm5ld1ZhbHVlKQogICAgLy8gICAgIGNvbnN0IGNvZGVNYXAgPSB7CiAgICAvLyAgICAgICB3ZWNoYXQ6ICdjb2RlJywKICAgIC8vICAgICAgIHRlbmNlbnQ6ICdjb2RlJwogICAgLy8gICAgIH0KICAgIC8vICAgICBjb25zdCB0eXBlID0gY29kZU1hcFt0aGlzLmF1dGhfdHlwZV0KICAgIC8vICAgICBjb25zdCBjb2RlTmFtZSA9IGNvZGVbdHlwZV0KICAgIC8vICAgICBpZiAoY29kZU5hbWUpIHsKICAgIC8vICAgICAgIHRoaXMuJHN0b3JlLmRpc3BhdGNoKCdMb2dpbkJ5VGhpcmRwYXJ0eScsIGNvZGVOYW1lKS50aGVuKCgpID0+IHsKICAgIC8vICAgICAgICAgdGhpcy4kcm91dGVyLnB1c2goeyBwYXRoOiB0aGlzLnJlZGlyZWN0IHx8ICcvJyB9KQogICAgLy8gICAgICAgfSkKICAgIC8vICAgICB9IGVsc2UgewogICAgLy8gICAgICAgYWxlcnQoJ+esrOS4ieaWueeZu+W9leWksei0pScpCiAgICAvLyAgICAgfQogICAgLy8gICB9CiAgICAvLyB9CiAgfQp9Cg=="},{"version":3,"sources":["index.vue"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA4EA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"index.vue","sourceRoot":"src/views/login","sourcesContent":["<template>\n <div class=\"login-container\">\n <el-form ref=\"loginForm\" :model=\"loginForm\" :rules=\"loginRules\" class=\"login-form\" autocomplete=\"on\" label-position=\"left\">\n\n <div class=\"title-container\">\n <h3 class=\"title\">Login Form</h3>\n </div>\n\n <el-form-item prop=\"username\">\n <span class=\"svg-container\">\n <svg-icon icon-class=\"user\" />\n </span>\n <el-input\n ref=\"username\"\n v-model=\"loginForm.username\"\n placeholder=\"Username\"\n name=\"username\"\n type=\"text\"\n tabindex=\"1\"\n autocomplete=\"on\"\n />\n </el-form-item>\n\n <el-tooltip v-model=\"capsTooltip\" content=\"Caps lock is On\" placement=\"right\" manual>\n <el-form-item prop=\"password\">\n <span class=\"svg-container\">\n <svg-icon icon-class=\"password\" />\n </span>\n <el-input\n :key=\"passwordType\"\n ref=\"password\"\n v-model=\"loginForm.password\"\n :type=\"passwordType\"\n placeholder=\"Password\"\n name=\"password\"\n tabindex=\"2\"\n autocomplete=\"on\"\n @keyup.native=\"checkCapslock\"\n @blur=\"capsTooltip = false\"\n @keyup.enter.native=\"handleLogin\"\n />\n <span class=\"show-pwd\" @click=\"showPwd\">\n <svg-icon :icon-class=\"passwordType === 'password' ? 'eye' : 'eye-open'\" />\n </span>\n </el-form-item>\n </el-tooltip>\n\n <el-button :loading=\"loading\" type=\"primary\" style=\"width:100%;margin-bottom:30px;\" @click.native.prevent=\"handleLogin\">Login</el-button>\n\n <div style=\"position:relative\">\n <div class=\"tips\">\n <span>Username : admin</span>\n <span>Password : any</span>\n </div>\n <div class=\"tips\">\n <span style=\"margin-right:18px;\">Username : editor</span>\n <span>Password : any</span>\n </div>\n\n <el-button class=\"thirdparty-button\" type=\"primary\" @click=\"showDialog=true\">\n Or connect with\n </el-button>\n </div>\n </el-form>\n\n <el-dialog title=\"Or connect with\" :visible.sync=\"showDialog\">\n Can not be simulated on local, so please combine you own business simulation! ! !\n <br>\n <br>\n <br>\n <social-sign />\n </el-dialog>\n </div>\n</template>\n\n<script>\nimport { validUsername } from '@/utils/validate'\nimport SocialSign from './components/SocialSignin'\n\nexport default {\n name: 'Login',\n components: { SocialSign },\n data() {\n const validateUsername = (rule, value, callback) => {\n if (!validUsername(value)) {\n callback(new Error('Please enter the correct user name'))\n } else {\n callback()\n }\n }\n const validatePassword = (rule, value, callback) => {\n if (value.length < 6) {\n callback(new Error('The password can not be less than 6 digits'))\n } else {\n callback()\n }\n }\n return {\n loginForm: {\n username: 'admin',\n password: '111111'\n },\n loginRules: {\n username: [{ required: true, trigger: 'blur', validator: validateUsername }],\n password: [{ required: true, trigger: 'blur', validator: validatePassword }]\n },\n passwordType: 'password',\n capsTooltip: false,\n loading: false,\n showDialog: false,\n redirect: undefined,\n otherQuery: {}\n }\n },\n watch: {\n $route: {\n handler: function(route) {\n const query = route.query\n if (query) {\n this.redirect = query.redirect\n this.otherQuery = this.getOtherQuery(query)\n }\n },\n immediate: true\n }\n },\n created() {\n // window.addEventListener('storage', this.afterQRScan)\n },\n mounted() {\n if (this.loginForm.username === '') {\n this.$refs.username.focus()\n } else if (this.loginForm.password === '') {\n this.$refs.password.focus()\n }\n },\n destroyed() {\n // window.removeEventListener('storage', this.afterQRScan)\n },\n methods: {\n checkCapslock(e) {\n const { key } = e\n this.capsTooltip = key && key.length === 1 && (key >= 'A' && key <= 'Z')\n },\n showPwd() {\n if (this.passwordType === 'password') {\n this.passwordType = ''\n } else {\n this.passwordType = 'password'\n }\n this.$nextTick(() => {\n this.$refs.password.focus()\n })\n },\n handleLogin() {\n this.$refs.loginForm.validate(valid => {\n if (valid) {\n this.loading = true\n this.$store.dispatch('user/login', this.loginForm)\n .then(() => {\n this.$router.push({ path: this.redirect || '/', query: this.otherQuery })\n this.loading = false\n })\n .catch(() => {\n this.loading = false\n })\n } else {\n console.log('error submit!!')\n return false\n }\n })\n },\n getOtherQuery(query) {\n return Object.keys(query).reduce((acc, cur) => {\n if (cur !== 'redirect') {\n acc[cur] = query[cur]\n }\n return acc\n }, {})\n }\n // afterQRScan() {\n // if (e.key === 'x-admin-oauth-code') {\n // const code = getQueryObject(e.newValue)\n // const codeMap = {\n // wechat: 'code',\n // tencent: 'code'\n // }\n // const type = codeMap[this.auth_type]\n // const codeName = code[type]\n // if (codeName) {\n // this.$store.dispatch('LoginByThirdparty', codeName).then(() => {\n // this.$router.push({ path: this.redirect || '/' })\n // })\n // } else {\n // alert('第三方登录失败')\n // }\n // }\n // }\n }\n}\n</script>\n\n<style lang=\"scss\">\n/* 修复input 背景不协调 和光标变色 */\n/* Detail see https://github.com/PanJiaChen/vue-element-admin/pull/927 */\n\n$bg:#283443;\n$light_gray:#fff;\n$cursor: #fff;\n\n@supports (-webkit-mask: none) and (not (cater-color: $cursor)) {\n .login-container .el-input input {\n color: $cursor;\n }\n}\n\n/* reset element-ui css */\n.login-container {\n .el-input {\n display: inline-block;\n height: 47px;\n width: 85%;\n\n input {\n background: transparent;\n border: 0px;\n -webkit-appearance: none;\n border-radius: 0px;\n padding: 12px 5px 12px 15px;\n color: $light_gray;\n height: 47px;\n caret-color: $cursor;\n\n &:-webkit-autofill {\n box-shadow: 0 0 0px 1000px $bg inset !important;\n -webkit-text-fill-color: $cursor !important;\n }\n }\n }\n\n .el-form-item {\n border: 1px solid rgba(255, 255, 255, 0.1);\n background: rgba(0, 0, 0, 0.1);\n border-radius: 5px;\n color: #454545;\n }\n}\n</style>\n\n<style lang=\"scss\" scoped>\n$bg:#2d3a4b;\n$dark_gray:#889aa4;\n$light_gray:#eee;\n\n.login-container {\n min-height: 100%;\n width: 100%;\n background-color: $bg;\n overflow: hidden;\n\n .login-form {\n position: relative;\n width: 520px;\n max-width: 100%;\n padding: 160px 35px 0;\n margin: 0 auto;\n overflow: hidden;\n }\n\n .tips {\n font-size: 14px;\n color: #fff;\n margin-bottom: 10px;\n\n span {\n &:first-of-type {\n margin-right: 16px;\n }\n }\n }\n\n .svg-container {\n padding: 6px 5px 6px 15px;\n color: $dark_gray;\n vertical-align: middle;\n width: 30px;\n display: inline-block;\n }\n\n .title-container {\n position: relative;\n\n .title {\n font-size: 26px;\n color: $light_gray;\n margin: 0px auto 40px auto;\n text-align: center;\n font-weight: bold;\n }\n }\n\n .show-pwd {\n position: absolute;\n right: 10px;\n top: 7px;\n font-size: 16px;\n color: $dark_gray;\n cursor: pointer;\n user-select: none;\n }\n\n .thirdparty-button {\n position: absolute;\n right: 0;\n bottom: 6px;\n }\n\n @media only screen and (max-width: 470px) {\n .thirdparty-button {\n display: none;\n }\n }\n}\n</style>\n"]}]}
|