{"remainingRequest":"/data/jenkins/workspace/badp-bcxin-web-5.x-staff/node_modules/vue-loader/lib/index.js??vue-loader-options!/data/jenkins/workspace/badp-bcxin-web-5.x-staff/src/views/Role/index.vue?vue&type=template&id=3f2777d6","dependencies":[{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-staff/src/views/Role/index.vue","mtime":1725944942464},{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-staff/node_modules/cache-loader/dist/cjs.js","mtime":499162500000},{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-staff/node_modules/cache-loader/dist/cjs.js","mtime":499162500000},{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-staff/node_modules/babel-loader/lib/index.js","mtime":456789000000},{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-staff/node_modules/vue-loader/lib/loaders/templateLoader.js","mtime":499162500000},{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-staff/node_modules/cache-loader/dist/cjs.js","mtime":499162500000},{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-staff/node_modules/vue-loader/lib/index.js","mtime":499162500000}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64:
<div class="ContainerBox tableAlign">
  <!-- 按钮区域 -->
  <section class="buttonBox">
    <el-row type="flex">
      <div style="color: red">
        <div>注意</div>
        <div style="margin-top: 12px">事项</div>
      </div>

      <div style="color: gray; margin-left: 12px">
        <div>
          1.
          用户获得对应角色之后，就可以获得该角色的对应功能权限，重新登录系统后即可查看对应功能；
        </div>
        <div style="margin-top: 12px">
          2. 在【功能授权】菜单中给用户已配置的功能权限不受角色授权影响。
        </div>
      </div>
      <!-- <el-col :span='4'>
                                  <el-input v-model="search" placeholder="请输入部门名称" clearable/>
                                </el-col> -->
    </el-row>
  </section>

  <!-- 内容区域 -->
  <section
    class="contentBox"
    style="display: flex; justify-content: space-between; margin-top: 16px"
  >
    <div class="left" style="width: 250px">
      <div style="display: flex; justify-content: space-between">
        <el-input
          v-model="inputRoleVb"
          placeholder="搜索角色名称"
          prefix-icon="el-icon-search"
        >
          <el-button
            slot="append"
            @click="search"
            icon="el-icon-search"
          ></el-button>
        </el-input>

        <el-button
          @click="sortRole"
          icon="el-icon-d-caret"
          style="margin-left: 6px"
        ></el-button>
      </div>

      <div
        class=""
        style="
          display: flex;
          justify-content: space-between;
          margin-top: 12px;
        "
      >
        <el-button style="width: 115px" @click="editDept({}, 0)">
          新增角色</el-button
        >

        <el-dropdown>
          <el-button style="width: 115px; margin-left: 6px">
            批量操作</el-button
          >

          <el-dropdown-menu slot="dropdown">
            <!-- <el-dropdown-item>
              <div @click="batchImportVbAction(true)">导入角色</div>
            </el-dropdown-item> -->

            <el-dropdown-item>
              <div @click="batchDeleteVb = true">批量删除</div>
            </el-dropdown-item>
          </el-dropdown-menu>
        </el-dropdown>
      </div>
      <div
        class=""
        style="margin-top: 12px; max-height: 500px; overflow: auto"
      >
        <div
          class="item-f"
          v-for="item in leftList"
          :class="{ actived: item.id === activeRole.id }"
          :key="item.id"
        >
          <div
            style="cursor: pointer; flex: 1"
            @click="
              () => {
                params.pageIndex = 1;
                tableData = [];
                getRoleUserList(item);
              }
            "
          >
            {{ item.roleName }}
          </div>

          <el-dropdown>
            <el-button type="text" size="small"> 操作 </el-button>
            <el-dropdown-menu slot="dropdown">
              <el-dropdown-item>
                <div @click="editDept(item, 3)">查看角色详情</div>
              </el-dropdown-item>
              <el-dropdown-item >
                <div @click="setPt([{userName: item.roleName,roleId:item.id}])">
                  配置功能权限
                </div>
                </el-dropdown-item>
              <!-- <el-dropdown-item>配置数据权限</el-dropdown-item> -->
              <el-dropdown-item>
                <div @click="editDept(item, 2)">编辑角色</div>
              </el-dropdown-item>
              <el-dropdown-item>
                <div @click="editDept(item, 1)">复制角色</div>
              </el-dropdown-item>
              <el-dropdown-item>
                <div @click="delDept(item)">删除角色</div>
              </el-dropdown-item>
            </el-dropdown-menu>
          </el-dropdown>
        </div>
      </div>
    </div>

    <div style="flex: 1; margin-left: 16px">
      <div style="font-size: 16px; margin-bottom: 29px">
        {{ activeRole.roleName }}角色成员列表
      </div>

      <div style="margin: 16px 0">
        <el-button type="primary" @click="getDepartmentList">
          添加成员</el-button
        >
        <el-button @click="batchImportVbAction(false)">
          批量导入成员</el-button
        >

        <el-button @click="batchRemoveMeber"> 批量移除成员</el-button>
      </div>
      <!-- 选中表格内容展示区域 -->
      <section class="TableSelectBox" v-if="multipleSelection.length">
        <span
          ><i class="el-icon-warning-outline el-icon-flag"></i>已选中：<span
            v-for="(item, index) in multipleSelection"
            :key="index"
            >{{ item.userName
            }}<b v-if="index != multipleSelection.length - 1">,</b></span
          ></span
        >
      </section>

      <el-table
        :data="tableData"
        ref="districtTable"
        max-height="500"
        row-key="id"
        @selection-change="handleSelectionChange"
        @select-all="handleSelectionAllChange"
      >
        <el-table-column type="selection" width="55"> </el-table-column>

        <el-table-column
          v-for="(item, index) in tableColumn"
          :key="index"
          :prop="item.prop"
          :label="item.label"
          :width="item.width"
          :align="item.align"
        >
          <template slot-scope="scope">
            <div v-if="item.label == '应用权限'">
              <el-tooltip
                class="item"
                :content="scope.row[item.prop]"
                placement="top-start"
              >
                <div class="two-elp">
                  {{ scope.row[item.prop] }}
                </div>
              </el-tooltip>
            </div>

            <span v-else>{{ scope.row[item.prop] }}</span>
          </template>
        </el-table-column>
      </el-table>

      <pages
        :total="params.total"
        :currentPage.sync="params.pageIndex"
        :pageSize="params.pageSize"
        @handleCurrentChangeSub="handleCurrentChange"
        @handleSizeChangeSub="handleSizeChange"
      ></pages>
    </div>
  </section>

  <!-- 添加 -->

  <!-- 详情 -->
  <Detail
    @callBack="search"
    :showdialog.sync="showdialogImport"
    :type="type"
    :data="rowOne"
  ></Detail>
  <!-- 批量删除角色 -->
  <el-dialog
    v-dialogDrag
    title="批量删除角色"
    :visible="batchDeleteVb"
    center
    style="width: 70%; margin: auto"
    @close="batchDeleteVb = false"
    :close-on-click-modal="false"
  >
    <div style="margin: 0 0 16px 0">
      选择需要
      <span style="color: red">删除</span
      >的角色，删除前请确认该属于该角色的成员

      <span style="color: red">已全部移除。</span>
    </div>
    <el-table
      :data="leftList"
      ref="roleMainList"
      max-height="400"
      row-key="id"
      @selection-change="roleMainListhandleSelectionChange"
      @select-all="roleMainListhandleSelectionAllChange"
    >
      <el-table-column type="selection" width="55"> </el-table-column>
      <el-table-column prop="roleName" label="角色名称" width="150">
      </el-table-column>
      <el-table-column prop="remark" label="角色说明"> </el-table-column>
      <el-table-column prop="createTime" label="创建时间"> </el-table-column>
    </el-table>
    <div slot="footer" class="dialog-footer">
      <el-button type="danger" @click="delDept()">确定删除</el-button>
      <el-button @click="batchDeleteVb = false">取 消</el-button>
    </div>
  </el-dialog>

  <!-- 批量导入角色 批量导入成员  -->
  <el-dialog
    v-dialogDrag
    :title="roleOrMeberFlag ? '批量导入角色' : '批量导入成员'"
    :visible="batchImportVb"
    center
    style="width: 60%; margin: auto"
    @close="batchImportVb = false"
    :close-on-click-modal="false"
  >
    <div style="margin: 36px; text-align: center">
      <div>
        请点击下载模板按钮下载批量导入文件，编辑完善后上传完成导入
      </div>

      <div style="margin: 18px; display: flex; justify-content: center">
        <el-button type="primary" @click="downloadTemp"> 下载模板</el-button>

        <el-upload
          :limit="1"
          accept=".xls"
          :before-upload="beforeUpload"
          :http-request="uploadImg"
          @on-remove="uploadloading = false"
          :show-file-list="true"
          ref="upload"
        >
          <el-button :loading="uploadloading" style="margin-left: 18px">
            {{ uploadloading ? "上传中" : "上传模板" }}
          </el-button>
        </el-upload>
      </div>

      <div style="margin-top: 26px; color: gray">
        注意：文档文件大小需控制在5M以下,一次上传一个文件
      </div>
    </div>
  </el-dialog>
  <!-- 选择需要添加的成员  -->
  <el-dialog
    v-dialogDrag
    title="选择需要添加的成员"
    :visible="chooseVb"
    center
    style="width: 100%; margin: auto"
    @close="chooseVb = false"
    :close-on-click-modal="false"
  >
    <div
      style="
        display: flex;
        justify-content: space-between;
        max-height: 400px;
        min-height: 400px;
        overflow: auto;
      "
    >
      <div style="flex: 1">
        <el-input
          v-model="inputchooseVb"
          placeholder="搜索"
          prefix-icon="el-icon-search"
        >
        </el-input>
        <div style="margin: 16px 0">选择需要添加的成员</div>
        <el-tree
          :props="{
            label: 'name',
            children: 'children',
          }"
          :expand-on-click-node="false"
          :data="dpTreeData"
          :default-expanded-keys="dpTreeData[0]?.id ? [dpTreeData[0].id] : []"
          :filter-node-method="filterNode"
          ref="tree"
          node-key="id"
        >
          <div
            class="custom-tree-node"
            style="
              display: flex;
              width: 100%;
              justify-content: space-between;
              align-items: center;
              margin: 6px 0;
            "
            slot-scope="{ node, data }"
          >
            <div
              style="
                margin: 0 2px;
                display: flex;
                justify-content: space-between;
                align-items: center;
              "
            >
              <img
                src="./af.png"
                style="
                  width: 20px;
                  height: 20px;
                  border-radius: 5%;
                  margin-right: 6px;
                "
              />
              {{ node.label }}
            </div>

            <el-button type="text" size="mini" @click="getMeberList(node)">
              查看人员
            </el-button>
          </div>
        </el-tree>
      </div>

      <div
        style="
          border-left: 1px solid rgba(211, 211, 211, 0.452);
          margin: 0 16px;
        "
      ></div>

      <div style="flex: 1; overflow: auto" v-loading="loadingcheckedData">
        <div
          style="
            display: flex;
            justify-content: space-between;
            align-items: center;
          "
        >
          <span>已选择人员</span>
          <el-button type="text" @click="deleteAllTag">清除</el-button>
        </div>
        <!-- <div v-for="(xj, key) in chooseData" :key="key"> -->
        <!-- <div style="margin: 6px 0; font-weight: bold">{{ xj.name }}</div>  -->
        <el-tag
          style="margin: 4px"
          v-for="(tag, tagIndex) in chooseData"
          :key="tag.id"
          @close="deleteTag(tagIndex)"
          closable
          type="info"
        >
          {{ tag.name }}
        </el-tag>
        <!-- </div> -->
      </div>
    </div>
    <div slot="footer" class="dialog-footer">
      <el-button type="primary" @click="sureAdd()">确定添加</el-button>
      <el-button @click="chooseVb = false">取 消</el-button>
    </div>
  </el-dialog>

  <UserDeptDialog
    :showdialogUser.sync="showdialogUser"
    @filterChooseData="filterChooseData"
    ref="UserpopChildren"
  ></UserDeptDialog>
  <UserAuthDialog ref="userauthdialog"></UserAuthDialog>

</div>
"},null]}