08335 / hivui-platform-template
hivui平台项目模板
Newer
Older
hivui-platform-template / project / hivuiMain / views / personalCenter / index.vue
<template>
  <div class="app-container" style="height: 100%;overflow:auto;">
    <el-row v-if="user" style="height: 100%;">
      <el-col :span="6" :xs="24" style="padding: 10px;height: 100%;box-sizing: border-box">
        <user-card :user="userCardInfo" :avatar="avatar" ref="userCard" style="height: 100%;min-height: 772px;"/>
      </el-col>

      <el-col :span="18" :xs="24" style="padding: 10px;height: 100%;box-sizing: border-box">
        <el-card class="r-card" style="height: 100%;min-height: 772px;" :body-style="{padding:'0 20px',height: '100%'}">
          <el-tabs v-model="activeTab">
            <el-tab-pane :label="userLabel" :name="userLabel">
              <user-update ref="userUpdate" />
            </el-tab-pane>
            <el-tab-pane :label="bzLabel" :name="bzLabel">
              <bz-update ref="bzUpdate" />
            </el-tab-pane>
          </el-tabs>
        </el-card>
      </el-col>

    </el-row>
  </div>
</template>

<script>
import UserCard from './components/UserCard'
import UserUpdate from './components/UserUpdate'
import BzUpdate from './components/BzUpdate'
import { getToken } from '@main/utils/auth'
import { query,getBzList } from '@main/api/user.js'

export default {
  name: 'Profile',
  components: { UserCard,UserUpdate, BzUpdate },
  data() {
    return {
      user: {},
      activeTab: this.$t("hivuiMain_app_user", { default: '用户' }),
      userInfo:{},
      bzList:[],
      userLabel: this.$t("hivuiMain_app_user", { default: '用户' }),
      bzLabel: this.$t("hivuiMain_app_orgbz", { default: '岗编' })
    }
  },
  computed: {
    avatar(){
      let me=this;
      if(me.userInfo && me.userInfo.FUSERPHOTO){
        return me._getImageUrl(me.userInfo.FUSERPHOTO)
      }else{
        return false
      }
    },
    userCardInfo(){
      let me=this;
      console.log('userInfo', me.userInfo)
      return Object.assign(me.user, me.userInfo || {})
    },
    reviewUrl(){
      let me=this;
      return me.$HI.review.includes(window.HIVUI_SETTING.url) ? me.$HI.review : window.HIVUI_SETTING.url + me.$HI.review
    }
  },
  mounted() {
    let me=this;
    me.getUser();
    me.getUserInfo();
    me.getBzList();
  },
  methods: {
    getBzList(){
      let me=this;
      getBzList().then(res =>{
        me.bzList = res.dataPack;
        let curtBz = me.bzList.filter(res => res.fdefaultbz)[0]
        me.$refs.userCard.bzList = me.bzList
        me.$refs.bzUpdate.bzList = me.bzList
        if(curtBz && curtBz.fbzid){
          me.$refs.bzUpdate.curtBzId = curtBz.fbzid
        }
      })
    },
    getUser() {
      let me=this;
      me.user = top.Scp.User
    },
    getUserInfo(){
      let me=this;
      var param = {
        modelFilePath: "/platf/user-info/entity/SysUserInfoBizEntity.xml",
        pageSize: 10,
        pageNum: 1,
        __zcQuery: false,
        __returnCount: true,
        __bottomSummary: false,
      }
      let userId = top.Scp.User && top.Scp.User.fuserid
      if(userId){
        let queryCdions = {
          join: 'and',
          items:[
            {
              sign: 'eq',
              name: 'FUSERID',
              dataType: 'dbString',
              value: userId,
              enable: true
            }
          ]
        }
        let __body = JSON.stringify({queryCdions: queryCdions})
        param.__body = __body
        query(param).then((res)=>{
          let data = res.dataPack && res.dataPack.rows
          if(data && data.length){
            me.userInfo = data[0]
            let form = {
              FSEX: "",
              FBIRTHDAY: "",
              FMBPHONE: "",
              FEMAIL: "",
              FQQ: "",
              FWEIXIN: "",
              FUSERSFZ: "",
              FADDRESS: [],
              FUSERPHOTO: '',
              FUSERSFZPIC1: '',
              FUSERSFZPIC2: '',
            }
            form = Object.assign(form, data[0])
            me.$refs.userUpdate.form = form
            me.$refs.userUpdate.copyForm = {...form}
          }
        })
      }
    },
    _getImageUrl(path) {
      let me=this;
      let token = getToken();
      if (typeof path == "string") {
        path = path.replace(/\\/g, "/");
        if(path.includes(";") && path.split(";").length >= 2){
          path = path.split(";")[2];
        }
      }
      return `${me.reviewUrl}?relativePath=${path}&access_token=${token}`;
    },
  }
}
</script>