wxUserList.vue 9.62 KB
<template>
  <a-card :bordered="false">

    <!-- 查询区域 -->
    <div class="table-page-search-wrapper">
      <a-form layout="inline" @keyup.enter.native="searchQuery">
        <a-row :gutter="24">

          <a-col :md="6" :sm="8">
            <a-form-item label="微信昵称">
              <a-input placeholder="请输入微信昵称" v-model="queryParam.nickName"></a-input>
            </a-form-item>
          </a-col>
          <a-col :md="6" :sm="8">
            <span style="float: left;overflow: hidden;" class="table-page-search-submitButtons">
              <a-button type="primary" @click="searchQuery" icon="search">查询</a-button>
              <a-button type="primary" @click="searchReset" icon="reload" style="margin-left: 8px">重置</a-button>
            </span>
          </a-col>

        </a-row>
      </a-form>
    </div>

    <!-- 操作按钮区域 -->
    <div class="table-operator">
      <a-dropdown v-if="selectedRowKeys.length > 0">
        <a-menu slot="overlay">
          <a-menu-item key="1" @click="batchDel">
            <a-icon type="delete"/>
            删除
          </a-menu-item>
        </a-menu>
        <a-button style="margin-left: 8px"> 批量操作 <a-icon type="down" /></a-button>
      </a-dropdown>
    </div>

    <!-- table区域-begin -->
    <div>
      <div class="ant-alert ant-alert-info" style="margin-bottom: 16px;">
        <i class="anticon anticon-info-circle ant-alert-icon"></i> 已选择 <a style="font-weight: 600">{{ selectedRowKeys.length }}</a>项
        <a style="margin-left: 24px" @click="onClearSelected">清空</a>
      </div>

      <a-table
        ref="table"
        size="middle"
        bordered
        rowKey="id"
        :columns="columns"
        :dataSource="dataSource"
        :pagination="ipagination"
        :loading="loading"
        :rowSelection="{selectedRowKeys: selectedRowKeys, onChange: onSelectChange}"
        @change="handleTableChange">

        <template slot="headimgurlslot" slot-scope="text, record, index">
          <div class="anty-img-wrap">
            <a-avatar shape="square" :src="getAvatarView(record.avatarUrl)" icon="user"/>
          </div>
        </template>

        <span slot="action" slot-scope="text, record">

          <span v-if="record.forbiddenStatus=='1'">
          <a-popconfirm title="确定禁用该用户吗?" @confirm="() => handleForbiddenStatus(record.id)">
                  <a >禁用</a>
          </a-popconfirm>
               <a-divider type="vertical" />
           </span>

          <span v-if="record.forbiddenStatus=='2'">
          <a-popconfirm title="确定解禁该用户吗?" @confirm="() => handleForbiddenStatus(record.id)">
                  <a>解禁</a>
          </a-popconfirm>
               <a-divider type="vertical" />
          </span>

          <span v-if="record.sysUserId!=''">
          <a-popconfirm title="确定解除绑定吗?" @confirm="() => handleUnbundling(record.id)">
                  <a>解除绑定</a>
          </a-popconfirm>
             <a-divider type="vertical" />
            </span>
           <a-popconfirm title="确定删除吗?" @confirm="() => handleDelete(record.id)">
                  <a>删除</a>
           </a-popconfirm>

<!--          <a-dropdown>
            <a class="ant-dropdown-link">更多 <a-icon type="down"/></a>
            <a-menu slot="overlay">
              <a-menu-item>
                <a-popconfirm title="确定删除吗?" @confirm="() => handleDelete(record.id)">
                  <a>删除</a>
                </a-popconfirm>
              </a-menu-item>

              <a-menu-item v-if="record.sysUserId!=''">
                <a-popconfirm title="确定解除绑定吗?" @confirm="() => handleUnbundling(record.id)">
                  <a>解除绑定</a>
                </a-popconfirm>
              </a-menu-item>

              <a-menu-item v-if="record.forbiddenStatus=='1'">
                <a-popconfirm title="确定禁用该用户吗?" @confirm="() => handleForbiddenStatus(record.id)">
                  <a>禁用</a>
                </a-popconfirm>
              </a-menu-item>

               <a-menu-item v-if="record.forbiddenStatus=='2'">
                <a-popconfirm title="确定解禁该用户吗?" @confirm="() => handleForbiddenStatus(record.id)">
                  <a>解禁</a>
                </a-popconfirm>
              </a-menu-item>

            </a-menu>
          </a-dropdown>-->
        </span>

      </a-table>
    </div>
    <!-- table区域-end -->

  </a-card>
</template>

<script>
  import { JeecgListMixin } from '@/mixins/JeecgListMixin'
  import {putAction,getFileAccessHttpUrl} from '@/api/manage';
  import {unbundling,handleForbiddenStatus} from '@/api/api'
  export default {
    name: 'wxUserList',
    mixins: [JeecgListMixin],
    data() {
      var that=this
      return {
        description: '微信管理页面',
        // 表头
        columns: [
          {
            title: '#',
            dataIndex: '',
            key: 'rowIndex',
            width: 60,
            align: 'center',
            customRender: function (t, r, index) {
              return parseInt(index) + 1
            }
          }, {
            title: '微信昵称',
            align: 'center',
            dataIndex: 'nickName',
            customRender:function (text) {
              let name = that.decodeText(text)
              return name;
            }
          },{
            title: '性别',
            align:"center",
            dataIndex: 'sex',
            customRender:function (text) {
              if(text=='0'){
                return "男";
              }else if(text=="1"){
                return "女";
              } else {
                return text;
              }
            }
          },{
            title: '头像',
            align:"center",
            width: 120,
            dataIndex: 'avatarUrl',
            scopedSlots: {customRender: "headimgurlslot"}
          },{
            title: '绑定账号',
            align:"center",
            dataIndex: 'sysUserId_dictText',
          },

          {
            title: '状态',
            align:"center",
            dataIndex: 'forbiddenStatus',
            customRender:function (text) {
              if(text=='1'){
                return "正常";
              }else if(text=="2"){
                return "禁用";
              } else {
                return text;
              }
            }
          },
          {
            title: '创建时间',
            dataIndex: 'createTime',
            align:"center",
            sorter: true
          },
          {
            title: '操作',
            dataIndex: 'action',
            align: 'center',
            scopedSlots: { customRender: 'action' },
          }
        ],
        url: {
          list: '/system/wxUser/list',
          delete: '/system/wxUser/delete',
          deleteBatch: '/system/wxUser/deleteBatch',
        },
        keyStr: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",
      }
    },
    computed: {
    },
    methods: {
      handleUnbundling: function(id){
        var that = this;
        unbundling({id: id}).then((res) => {
          if (res.success) {
            that.$message.success(res.message);
          } else {
            that.$message.warning(res.message);
          }
        });
      },
      handleForbiddenStatus: function(id){
        var that = this;
        handleForbiddenStatus({id: id,}).then((res) => {
          if (res.success) {
            this.loadData();
            that.$message.success(res.message);
          } else {
            that.$message.warning(res.message);
          }
        });
      },
      getAvatarView: function (avatar) {
        return getFileAccessHttpUrl(avatar)
      },
      _utf8_decode: function(utftext) {
        var string = "";
        var i = 0;
        var c = 0;
        var c1 = 0;
        var c2 = 0;
        var c3 = 0;

        while (i < utftext.length) {

          c = utftext.charCodeAt(i);

          if (c < 128) {
            string += String.fromCharCode(c);
            i++;
          } else if ((c > 191) && (c < 224)) {
            c2 = utftext.charCodeAt(i + 1);
            string += String.fromCharCode(((c & 31) << 6) | (c2 & 63));
            i += 2;
          } else {
            c2 = utftext.charCodeAt(i + 1);
            c3 = utftext.charCodeAt(i + 2);
            string += String.fromCharCode(((c & 15) << 12) | ((c2 & 63) << 6) | (c3 & 63));
            i += 3;
          }

        }

        return string;
      },
      decode_in: function(input) {
        var that=this
        var output = "";
        var chr1, chr2, chr3;
        var enc1, enc2, enc3, enc4;
        var i = 0;

        input = input.replace(/[^A-Za-z0-9\+\/\=]/g, "");

        while (i < input.length) {

          enc1 = that.keyStr.indexOf(input.charAt(i++));
          enc2 = that.keyStr.indexOf(input.charAt(i++));
          enc3 = that.keyStr.indexOf(input.charAt(i++));
          enc4 = that.keyStr.indexOf(input.charAt(i++));

          chr1 = (enc1 << 2) | (enc2 >> 4);
          chr2 = ((enc2 & 15) << 4) | (enc3 >> 2);
          chr3 = ((enc3 & 3) << 6) | enc4;

          output = output + String.fromCharCode(chr1);

          if (enc3 != 64) {
            output = output + String.fromCharCode(chr2);
          }
          if (enc4 != 64) {
            output = output + String.fromCharCode(chr3);
          }

        }

        output = that._utf8_decode(output);

        return output;
      },
      decodeText: function (input){
        var str = input;
        try{
          return this.decode_in(input);
        }catch(e){
          return str;
        }
      },
    }
  }
</script>
<style scoped>
  @import '~@assets/less/common.less'
</style>