| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498 | <template>  <div class="app-container">    <el-row :gutter="10">      <el-col :xs="24" :sm="12">        <el-card class="user-center">          <div slot="header" class="clearfix">            <span>关于我</span>          </div>          <div class="user-profile">            <div class="box-center">              <pan-thumb :image="avatar" :height="'100px'" :width="'100px'" :hoverable="false">                <el-link type="primary" class="change-avatar" @click="dialogVisible = true">更换头像</el-link>              </pan-thumb>            </div>            <div class="box-center">              <div class="user-name text-center">{{ user.username }}</div>              <div class="user-role text-center text-muted">                <span>{{ user.deptName ? user.deptName : '没有' }}</span> · <span>{{ user.roleName ? user.roleName : '没有' }}</span>              </div>            </div>          </div>          <div class="user-bio">            <!-- <div class="user-education user-bio-section">              <div class="user-bio-section-header"><el-icon class="el-icon-connection" /><span>第三方账号</span></div>              <div class="user-bio-section-body">                <div class="text-muted">                  <template v-for="(l, index) in logo">                    <div :key="index" class="logo-wrapper">                      <img v-if="l.bind" :src="resolveLogo(l.img)" :class="{ 'radius': l.radius }" alt="" title="1" @click="unbind(l.name)">                      <img v-else :src="resolveLogo(l.img)" :class="{ 'radius': l.radius }" alt="" title="2" class="unbind" @click="bind(l.name)">                    </div>                  </template>                </div>              </div>            </div> -->          </div>        </el-card>      </el-col>      <el-col :xs="24" :sm="12">        <el-card class="user-center">          <el-tabs v-model="activeName" @tab-click="handleClick">            <el-tab-pane label="个人信息" name="first">              <div class="user" style="width: 600px">                <el-form ref="form" :model="user" label-width="80px">                  <el-form-item label="用户名">                    <el-input v-model="user.username" />                  </el-form-item>                  <el-form-item label="头像">                    <el-upload                      class="avatar-uploader"                      action="https://jsonplaceholder.typicode.com/posts/"                      :show-file-list="false"                      :before-upload="beforeAvatarUpload"                    >                      <img v-if="user.avatar" :src="user.avatar" class="avatar" alt="">                      <i v-else class="el-icon-plus avatar-uploader-icon" />                    </el-upload>                  </el-form-item>                  <el-form-item label="手机号">                    <el-input v-model="user.phone" />                  </el-form-item>                  <!-- <el-form-item label="用户邮箱">                    <el-input v-model="user.email" :disabled="true" />                  </el-form-item> -->                  <el-form-item label="所属部门">                    <el-input v-model="user.deptName" :disabled="true" />                  </el-form-item>                  <el-form-item>                    <el-button type="primary">提交</el-button>                    <el-button>取消</el-button>                  </el-form-item>                </el-form>              </div>            </el-tab-pane>            <el-tab-pane label="修改密码" name="second">              <div style="width: 400px">                <el-form                  ref="passForm"                  :model="passForm"                  status-icon                  :rules="rules"                  label-width="100px"                  class="demo-ruleForm"                >                  <el-form-item label="原密码" prop="oldPass">                    <el-input v-model="passForm.oldPass" type="password" autocomplete="off" />                  </el-form-item>                  <el-form-item label="密码" prop="newPass">                    <el-input v-model="passForm.newPass" type="password" autocomplete="off" />                  </el-form-item>                  <el-form-item label="确认密码" prop="checkPass">                    <el-input v-model="passForm.checkPass" type="password" autocomplete="off" />                  </el-form-item>                  <el-form-item>                    <el-button type="primary" @click="updatePass('passForm')">修改</el-button>                    <el-button @click="resetForm('passForm')">重置</el-button>                  </el-form-item>                </el-form>              </div>            </el-tab-pane>            <!-- <el-tab-pane label="修改邮箱" name="third">              <div style="width: 500px">                <el-form ref="mailForm" :model="mailForm" label-width="100px" class="demo-ruleForm">                  <el-form-item                    prop="email"                    label="邮箱"                    :rules="[{ required: true, message: '请输入邮箱地址', trigger: 'blur' },                             { type: 'email', message: '请输入正确的邮箱地址', trigger: ['blur', 'change'] }]"                  >                    <el-input v-model="mailForm.email" style="width: 250px;" />                    <el-button :loading="codeLoading" :disabled="isDisabled" @click="sendCode">{{ buttonName }}                    </el-button>                  </el-form-item>                  <el-form-item                    label="验证码"                    prop="code"                    :rules="[{ required: true, message: '验证码不能为空'}]"                  >                    <el-input v-model="mailForm.code" type="age" autocomplete="off" />                  </el-form-item>                  <el-form-item                    label="密码"                    prop="pass"                    :rules="[{ required: true, message: '密码不能为空'}]"                  >                    <el-input v-model="mailForm.pass" type="age" autocomplete="off" />                  </el-form-item>                  <el-form-item>                    <el-button type="primary" @click="updateEmail('mailForm')">提交</el-button>                    <el-button @click="resetForm('mailForm')">重置</el-button>                  </el-form-item>                </el-form>              </div>            </el-tab-pane> -->          </el-tabs>        </el-card>      </el-col>    </el-row>  </div></template><script>import PanThumb from '@/components/PanThumb'import { getUserInfo, updatePass, resetEmail, updateEmail } from '@/api/user'export default {  name: 'Index',  components: { PanThumb },  data() {    const validatePass = (rule, value, callback) => {      if (value === '') {        callback(new Error('请输入密码'))      } else {        if (this.passForm.checkPass !== '') {          this.$refs.passForm.validateField('checkPass')        }        callback()      }    }    const validatePass2 = (rule, value, callback) => {      if (value === '') {        callback(new Error('请再次输入密码'))      } else if (value !== this.passForm.newPass) {        callback(new Error('两次输入密码不一致!'))      } else {        callback()      }    }    return {      user: {        avatar: '',        username: '',        phone: 0,        email: '',        deptName: '',        jobName: '',        createTime: ''      },      activeName: 'first',      passForm: {        oldPass: '',        newPass: '',        checkPass: ''      },      rules: {        oldPass: [{ required: true, message: '原密码不能为空', trigger: 'blur' }],        newPass: [{ validator: validatePass, trigger: 'blur' }],        checkPass: [{ validator: validatePass2, trigger: 'blur' }]      },      mailForm: {        email: '',        code: '',        pass: ''      },      buttonName: '发送验证码',      isDisabled: false,      codeLoading: false,      time: 60,      logo: [        { img: 'gitee.png', name: 'gitee', bind: false, radius: true },        { img: 'github.png', name: 'github', bind: false, radius: true },        { img: 'tencent_cloud.png', name: 'tencent_cloud', bind: false, radius: true },        { img: 'qq.png', name: 'qq', bind: false, radius: false },        { img: 'dingtalk.png', name: 'dingtalk', bind: false, radius: true },        { img: 'microsoft.png', name: 'microsoft', bind: false, radius: false }      ]    }  },  computed: {    avatar() {      return require(`@/assets/avatar/c7c4ee7be3eb4e73a19887dc713505145.jpg`)    }  },  created() {    this.findUserInfo()  },  methods: {    // parseTime,    // formatEmail(mail) {    //   return regEmail(mail)    // },    resolveLogo(logo) {      return require(`@/assets/logo/${logo}`)    },    // 加载用户个人信息    findUserInfo: function() {      getUserInfo().then((res) => {        this.user = res.data.data        // console.log(res)      })    },    // 修改密码    updatePass: function(formName) {      this.$refs[formName].validate((valid) => {        if (valid) {          const params = new URLSearchParams()          params.append('oldPass', this.passForm.oldPass)          params.append('newPass', this.passForm.newPass)          updatePass(params).then((res) => {            if (res.data.code === 200) {              this.$message({                type: 'success',                message: '操作成功'              })              this.activeName = 'second'              this.$refs['passForm'].resetFields()            } else {              this.$message({                type: 'error',                message: res.data.msg              })            }          })        } else {          return false        }      })    },    // 修改邮箱    updateEmail: function(formName) {      this.$refs[formName].validate((valid) => {        if (valid) {          const params = new URLSearchParams()          params.append('mail', this.mailForm.email)          params.append('code', this.mailForm.code)          params.append('pass', this.mailForm.pass)          updateEmail(params).then((res) => {            if (res.data.code === 200) {              this.$message({                type: 'success',                message: '操作成功'              })              this.activeName = 'third'              this.$refs['mailForm'].resetFields()            } else {              this.$message({                type: 'error',                message: res.data.msg              })            }          })        } else {          return false        }      })    },    // 发送邮箱验证码    sendCode() {      if (this.mailForm.email && this.mailForm.email !== '') {        this.codeLoading = true        this.buttonName = '验证码发送中'        const params = new URLSearchParams()        params.append('to', this.mailForm.email)        const _this = this        resetEmail(params).then(res => {          if (res.data.code === 200) {            this.$message({              showClose: true,              message: '发送成功,验证码有效期5分钟',              type: 'success'            })            this.codeLoading = false            this.isDisabled = true            this.buttonName = this.time-- + '秒后重新发送'            this.timer = window.setInterval(function() {              _this.buttonName = _this.time + '秒后重新发送'              --_this.time              if (_this.time < 0) {                _this.buttonName = '重新发送'                _this.time = 60                _this.isDisabled = false                window.clearInterval(_this.timer)              }            }, 1000)          }        }).catch(err => {          this.resetForm()          this.codeLoading = false          console.log(err.data.message)        })      }    },    // handleSuccess(response, file, fileList) {    //   this.$notify({    //     title: '头像修改成功',    //     type: 'success',    //     duration: 2500    //   })    //   store.dispatch('GetInfo').then(() => {    //   })    // },    // 监听上传失败    // handleError(e, file, fileList) {    //   const msg = JSON.parse(e.message)    //   this.$notify({    //     title: msg.message,    //     type: 'error',    //     duration: 2500    //   })    // },    refresh() {      this.ico = 'el-icon-loading'      this.$refs.log.init()      setTimeout(() => {        this.ico = 'el-icon-refresh'      }, 300)    },    submitForm(formName) {      this.$refs[formName].validate((valid) => {        if (valid) {          alert('submit!')        } else {          console.log('error submit!!')          return false        }      })    },    resetForm(formName) {      if (this.$refs[formName] !== undefined) {        this.$refs[formName].resetFields()      }    },    handleClick(tab, event) {      console.log(tab, event)    },    // handleAvatarSuccess(res, file) {    //   // this.imageUrl = URL.createObjectURL(file.raw)    //   const data = new FormData()    //   data.append('token', '')    //   data.append('file', file[0])    //   axiosInstance({    //     method: 'POST',    //     url: 'http://up.qiniu.com',    //     data: data    //   })    //     .then(function(res) {    //       // console.log('res',res)    //       const { base_url, path } = res.data    //       // 页面所用字段    //       self.previewAvatar = `${base_url}${path}?imageView2/1/w/154/h/154`    //       // 传给后台不完整    //       self.formData.avatar = `${path}`    //     })    //     .catch(function(err) {    //       console.log('err', err)    //     })    // },    beforeAvatarUpload(file) {      const isJPG = file.type === 'image/jpeg'      const isLt2M = file.size / 1024 / 1024 < 2      if (!isJPG) {        this.$message.error('上传头像图片只能是 JPG 格式!')      }      if (!isLt2M) {        this.$message.error('上传头像图片大小不能超过 2MB!')      }      return isJPG && isLt2M    }  }}</script><style lang="scss" scoped>  .user-center{    height: 440px;  }  .box-center {    margin: 0 auto;    display: table;  }  .text-muted {    color: #777;  }  .user-profile {    .user-name {      font-weight: bold;    }    .box-center {      padding-top: 10px;    }    .user-role {      padding-top: 10px;      font-weight: 400;      font-size: 14px;    }    .box-social {      padding-top: 30px;      .el-table {        border-top: 1px solid #dfe6ec;      }    }    .user-follow {      padding-top: 20px;    }  }  .user-bio {    margin-top: 20px;    color: #606266;    span {      padding-left: 4px;    }    .logo-wrapper {      display: inline-block;      margin: 10px 0;      img {        width: 1.4rem;        display: inline-block;        margin: 0 .6rem;        cursor: pointer;        &.unbind {          -webkit-filter: grayscale(100%);          -moz-filter: grayscale(100%);          -o-filter: grayscale(100%);          filter: grayscale(100%);        }        &.radius {          border-radius: 50%;        }      }    }    .user-bio-section {      font-size: 14px;      padding: 15px 0;      .user-bio-section-header {        border-bottom: 1px solid #dfe6ec;        padding-bottom: 10px;        margin-bottom: 10px;        font-weight: bold;      }    }  }</style>
 |