Newer
Older
operation_web / src / components / ConfigManager / project.vue
@田松 田松 on 11 Jan 2021 27 KB +++配置管理-项目管理
<template>
  <div class="page-data">
    <!--搜素框-->
    <div class="page-filter">
      <page-filter
        :query.sync="projectFilterInfo.query"
        :filter-list="projectFilterInfo.list"
        @handleClick="handleClick"
      />
    </div>
    <div class="page-content">
      <!--表格-->
      <div class="h-100">
        <page-table
          tabIndex
          pagination
          :api-url="projectTableInfo.url"
          :refresh="projectTableInfo.refresh"
          :data.sync="projectTableInfo.data"
          :query="projectFilterInfo.query"
          :page-query="projectTableInfo.pageQuery"
          :list-type-info="listTypeInfo"
          :init-curpage="projectTableInfo.initCurpage"
          :field-list="projectTableInfo.fieldList"
          :handle="projectTableInfo.handle"
          @handleClick="handleClick"
        >
          <template v-slot:col-status="scope">
            <el-button type="text" size="small" :class="[scope.row.status === 1 ? '' : 'red']">
              {{ scope.row.status === 1 ? "管理中" : "未管理" }}
            </el-button>
          </template>
        </page-table>
      </div>
    </div>
    <!--弹窗-->
    <el-dialog
      :width="dialogInfo.width"
      append-to-body
      :title="dialogInfo.title[dialogInfo.type]"
      :visible.sync="dialogInfo.visible"
      :before-close="handleClose"
    >
      <!--项目关联站点-->
      <template v-if="dialogInfo.type === 'relate'">
        <div class="page-filter">
          <el-form :inline="true" :model="siteQuery" ref="siteQuery" size="medium">
            <el-form-item label="">
              <el-input v-model="siteQuery.searchStr" placeholder="请输入站点编号/名称"></el-input>
            </el-form-item>
            <el-form-item>
              <el-button type="primary" icon="el-icon-search" size="medium" @click="handleClick('siteSearch')">查询</el-button>
            </el-form-item>
          </el-form>
        </div>
        <div class="page-content">
          <el-row :gutter="20" class="h-100">
            <el-col :span="10" class="h-100">
              <page-table
                tabIndex
                checkBox
                pagination
                type="unRelate"
                :api-url="siteTableInfo.url"
                :refresh="siteTableInfo.refresh"
                :data.sync="UnRelateSiteTableInfo.data"
                :query="UnRelateSiteTableInfo.query"
                :init-curpage="siteTableInfo.initCurpage"
                :field-list="siteTableInfo.fieldList"
                @handleClick="handleClick"
                @handleEvent="handleEvent"
              />
            </el-col>
            <el-col :span="4" class="h-100">
              <div class="btn-group">
                <el-button
                  type="primary"
                  size="small"
                  icon="el-icon-d-arrow-right"
                  :disabled="isCanInsertSite"
                  @click="handleClick('insert')"
                  >添加</el-button
                >
                <el-button
                  type="primary"
                  size="small"
                  icon="el-icon-d-arrow-left"
                  :disabled="isCanRemoveSite"
                  @click="handleClick('remove')"
                  >移除</el-button
                >
              </div>
            </el-col>
            <el-col :span="10" class="h-100">
              <page-table
                tabIndex
                checkBox
                pagination
                type="isRelate"
                :api-url="siteTableInfo.url"
                :refresh="siteTableInfo.refresh"
                :data.sync="RelatedSiteTableInfo.data"
                :query="RelatedSiteTableInfo.query"
                :init-curpage="siteTableInfo.initCurpage"
                :field-list="siteTableInfo.fieldList"
                @handleClick="handleClick"
                @handleEvent="handleEvent"
              />
            </el-col>
          </el-row>
        </div>
      </template>
      <!--修改项目-->
      <template v-if="dialogInfo.type === 'update'">
        <div class="page-form">
          <page-form
            :ref-obj.sync="projectFormInfo.ref"
            :data="projectFormInfo.data"
            :field-list="projectFormInfo.fieldList"
            :rules="projectFormInfo.rules"
            :list-type-info="listTypeInfo"
            :need-clear-nodes="projectFormInfo.needClearNodes"
            :cascader-options="projectFormInfo.cascaderOptions"
            @handleClick="handleClick"
          />
        </div>
      </template>
      <!--分配权限-->
      <template v-if="dialogInfo.type === 'permission'">
        <div class="page-filter">
          <page-filter
            :query.sync="permissionFilterInfo.query"
            :filter-list="permissionFilterInfo.list"
            @handleClick="handleClick"
          />
        </div>
        <div class="page-content">
          <page-table
            tabIndex
            checkBox
            pagination
            :api-url="permissionTableInfo.url"
            :refresh="permissionTableInfo.refresh"
            :data.sync="permissionTableInfo.data"
            :query="permissionFilterInfo.query"
            :init-curpage="permissionTableInfo.initCurpage"
            :field-list="permissionTableInfo.fieldList"
            :handle="permissionTableInfo.handle"
            @handleClick="handleClick"
            @handleEvent="handleEvent"
          />
        </div>
      </template>
      <div class="dialot-footer" slot="footer">
        <template v-if="dialogInfo.type !== 'relate'">
          <el-button type="primary" size="medium" @click="handleClick('submit')">保存</el-button>
        </template>
        <el-button size="medium" @click="handleClick('close')">取消</el-button>
      </div>
    </el-dialog>
    <el-dialog
      class="userDialog"
      append-to-body
      width="500px"
      :title="userDialogInfo.title[userDialogInfo.type]"
      :visible.sync="userDialogInfo.visible"
      :before-close="handleUserClose"
    >
      <!--添加用户-->
      <template v-if="userDialogInfo.type === 'addUser'">
        <div class="page-form">
          <page-form
            :ref-obj.sync="userFormInfo.ref"
            size="medium"
            :data="userFormInfo.data"
            :field-list="userFormInfo.fieldList"
            :rules="userFormInfo.rules"
            :list-type-info="listTypeInfo"
            @handleClick="handleClick"
          />
        </div>
      </template>
      <!--添加用户组-->
      <template v-else>
        <div class="page-form">
          <page-form
            :ref-obj.sync="groupFormInfo.ref"
            :data="groupFormInfo.data"
            :field-list="groupFormInfo.fieldList"
            :rules="groupFormInfo.rules"
            @handleClick="handleClick"
          />
        </div>
      </template>
      <div slot="footer">
        <el-button size="small" type="primary" @click="handleClick('save')">提交</el-button>
        <el-button size="small" @click="handleClick('closeUserDialog')">取消</el-button>
      </div>
    </el-dialog>
  </div>
</template>

<script>
import { mapGetters } from "vuex";
export default {
  data() {
    // 验证电话
    let checkPhone = (rule, value, callback) => {
      let check = this.$validate({ label: "电话", value, rules: ["moblie"] });
      if (!check.result) {
        callback(new Error(check.message));
      } else {
        callback();
      }
    };
    return {
      //项目搜索相关
      projectFilterInfo: {
        query: {
          searchStr: "",
          startDate: "",
          endDate: ""
        },
        list: [
          {type: "input", label: "项目名称/编号", value: "searchStr", hideLabel: true },
          {type: "date", label: "开始时间", value: "startDate", dateType: "date", datePickerOptions: "pickerOptionsStart", hideLabel: true},
          {type: "date", label: "结束时间", value: "endDate", dateType: "date", datePickerOptions: "pickerOptionsEnd", hideLabel: true},
          {type: "button", label: "查询", btType: "primary", icon: "", event: "searchProject", show: true}
        ]
      },
      //项目表格相关
      projectTableInfo: {
        url: this.nozzle.sysPlatformList, //接口地址
        refresh: 1,
        initCurpage: 1,
        data: [],
        fieldList: [
          { label: "项目编号", value: "platformCode", width: 100 },
          { label: "项目名称", value: "name", minWidth: 150, tooltip: true },
          { label: "项目添加时间", value: "createTime", minWidth: 150, tooltip: true },
          { label: "操作人", value: "operator", width: 120 },
          { label: "状态", value: "status", width: 100, type: "slot" },
          { label: "项目类型", value: "sysGroup", minWidth: 100, tooltip: true, list: "xmlxList" }
        ],
        handle: {
          fixed: "right",
          label: "操作",
          width: "240",
          btList: [
            { label: "分配权限", size: "small", type: "text", event: "permission", show: true, has: 'm11-1-1' },
            { label: "项目关联站点", size: "small", type: "text", event: "relate", show: true, has: 'm11-1-2' },
            { label: "修改", size: "small", type: "text", event: "update", show: true, has: 'm11-1-3' }
          ]
        }
      },
      //分配权限表格相关
      permissionTableInfo: {
        url: this.nozzle.userGroupList, //接口地址
        refresh: 1,
        initCurpage: 1,
        data: [],
        fieldList: [
          { label: "分组名称", value: "groupName", minWidth: 150, tooltip: true },
          { label: "分组描述", value: "description", minWidth: 150, tooltip: true }
        ],
        handle: {
          fixed: "right",
          label: "操作",
          width: "120",
          btList: [
            { label: "添加用户", size: "small", type: "text", event: "addUser", show: true }
          ]
        }
      },
      //分配权限过滤相关
      permissionFilterInfo: {
        query: {
          searchStr: ""
        },
        list: [
          { type: "input", label: "分组名称", value: "searchStr", hideLabel: true },
          { type: "button", label: "查询", btType: "primary", icon: "el-icon-search", event: "searchPermission", show: true },
          { type: "button", label: "添加用户组", btType: "primary", icon: "el-icon-plus", event: "addGroup", show: true }
        ]
      },
      //分配权限选中表格数据
      permissionSelectData: [],
      //需要进行绑定操作的项目ID
      needHandleProjectId: "",
      //弹窗相关
      dialogInfo: {
        title: {
          update: "编辑"
        },
        type: "",
        visible: false,
        width: "80%"
      },
      //列表相关
      listTypeInfo: {
        xmlxList: [{ key: "合同项目", value: "0" }, { key: "临时项目", value: "1" }],
        groupList: [],
        deptTree: [],
        roleTree: [],
        userType: [{ key: "普通用户", value: 0 }, { key: "超级管理员", value: 1 }],
        statusList: [{ key: "未管理", value: 0 }, { key: "管理中", value: 1 }]
      },
      //用户弹窗相关
      userDialogInfo: {
        title: {
          addUser: "添加用户",
          addGroup: "添加用户组"
        },
        type: "",
        visible: false
      },
      //用户表单相关
      userFormInfo: {
        ref: null,
        data: {
          id: undefined,
          login: "",
          realName: "",
          pwd: "",
          userType: "",
          orgId: undefined,
          groupId: undefined,
          groupName: "",
          roleId: undefined,
          mobile: ""
        },
        fieldList: [
          { label: "用户名", value: "login", type: "input", required: true },
          { label: "姓名", value: "realName", type: "input", required: true },
          { label: "密码", value: "pwd", type: "password", required: true },
          { label: "电话", value: "mobile", type: "input", validator: checkPhone },
          { label: "用户类型", value: "userType", type: "select", list: "userType", required: true },
          { label: "所属部门", value: "orgId", type: "treeselect", list: "deptTree", required: true },
          { label: "所属分组", value: "groupName", type: "input", disabled: true },
          { label: "所属角色", value: "roleId", type: "treeselect", list: "roleTree", required: true }
        ],
        rules: {},
        treeOptions: []
      },
      //用户组表单相关
      groupFormInfo: {
        ref: null,
        data: {
          id: undefined,
          groupName: "",
          description: ""
        },
        fieldList: [
          { label: "用户组名称", value: "groupName", type: "input", required: true },
          { label: "用户组描述", value: "description", type: "textarea", limit: true }
        ],
        rules: {}
      },
      //站点表格相关
      siteTableInfo: {
        url: this.nozzle.sysStationBaseList, //接口地址
        refresh: 1,
        initCurpage: 1,
        fieldList: [
          { label: "站点编号", value: "stCode", minWidth: 150, tooltip: true },
          { label: "站点名称", value: "stName", minWidth: 150, tooltip: true }
        ]
      },
      //已关联站点表格相关
      RelatedSiteTableInfo: {
        data: [],
        query: {
          sign: ""
        },
        selectList: []
      },
      //未关联站点表格相关
      UnRelateSiteTableInfo: {
        data: [],
        query: {
          sign: "unbound"
        },
        selectList: []
      },
      //站点过滤相关
      siteQuery: {
        searchStr: "",
        platformCode: ""
      },
      //项目表单相关
      projectFormInfo: {
        ref: null,
        data: {
          id: undefined,
          name: "",
          sysGroup: "",
          operator: "",
          area: "",
          platformCode: "",
          status: undefined
        },
        fieldList: [
          { label: "项目名称", value: "name", type: "input", required: true },
          { label: "项目类型", value: "sysGroup", type: "select", list: "xmlxList", required: true },
          { label: "项目编号", value: "platformCode", type: "input", disabled: true },
          { label: "项目状态", value: "status", type: "select", list: "statusList", required: true },
          { label: "操作人", value: "operator", type: "input", disabled: true },
          { label: "所属区域", value: "area", type: "cascader", required: true }
        ],
        rules: {},
        cascaderOptions: [], //区域级联数据源
        needClearNodes: false //是否清除级联上次数据高亮
      }
    };
  },
  watch: {
    "dialogInfo.visible"(val) {
      if (!val) {
        this.permissionTableInfo.data = [];
        this.RelatedSiteTableInfo.data = [];
        this.UnRelateSiteTableInfo.data = [];
        this.siteQuery = {
          searchStr: ""
        };
        if (this.projectFormInfo.ref) {
          this.projectFormInfo.ref.resetFields();
        }
        const type = this.dialogInfo.type;
        this.projectFormInfo.needClearNodes = true;
        this.resetForm(type);
      }
    },
    "dialogInfo.type"(val) {
      if (val === "update") {
        this.dialogInfo.width = "500px";
        return;
      }
      this.dialogInfo.width = "80%";
    },
    "userDialogInfo.visible"(val) {
      if (!val) {
        if (this.groupFormInfo.ref) {
          this.groupFormInfo.ref.resetFields();
        }
        if (this.userFormInfo.ref) {
          this.userFormInfo.ref.resetFields();
        }
        const type = this.userDialogInfo.type;
        this.resetForm(type);
      }
    },
    "siteQuery.searchStr"(val) {
      Object.assign(this.RelatedSiteTableInfo.query, this.siteQuery);
      Object.assign(this.UnRelateSiteTableInfo.query, this.siteQuery);
    }
  },
  computed: {
    //移除按钮是否可点击
    isCanRemoveSite() {
      return this.RelatedSiteTableInfo.selectList.length ? false : true;
    },
    //添加按钮是否可点击
    isCanInsertSite() {
      return this.UnRelateSiteTableInfo.selectList.length ? false : true;
    },
    ...mapGetters(["allDept", "allRole", "allCity"])
  },
  mounted() {
    this.initRules();
    this.projectTableInfo.refresh = Math.random();
  },
  methods: {
    // 初始化验证
    initRules() {
      const userFormInfo = this.userFormInfo;
      const groupFormInfo = this.groupFormInfo;
      const projectFormInfo = this.projectFormInfo;
      userFormInfo.rules = this.$initRules(userFormInfo.fieldList);
      groupFormInfo.rules = this.$initRules(groupFormInfo.fieldList);
      projectFormInfo.rules = this.$initRules(projectFormInfo.fieldList);
    },
    //点击事件
    handleClick(event, data) {
      switch (event) {
        //项目搜索
        case "searchProject":
          this.projectTableInfo.initCurpage = Math.random();
          this.projectTableInfo.refresh = Math.random();
          break;
        //项目关联站点按钮
        case "relate":
          this.dialogInfo.type = event;
          this.siteQuery.platformCode = data.platformCode;
          this.dialogInfo.visible = true;
          setTimeout(() => {
            Object.assign(this.RelatedSiteTableInfo.query, this.siteQuery);
            Object.assign(this.UnRelateSiteTableInfo.query, this.siteQuery);
            this.siteTableInfo.refresh = Math.random();
          }, 0);
          break;
        //分配权限按钮
        case "permission":
          this.dialogInfo.visible = true;
          this.dialogInfo.type = event;
          this.listTypeInfo.deptTree = this.allDept;
          this.listTypeInfo.roleTree = this.allRole;
          this.needHandleProjectId = data.platformCode;
          setTimeout(() => {
            this.permissionTableInfo.refresh = Math.random();
          }, 0);
          break;
        //站点搜索
        case "siteSearch":
          this.siteTableInfo.initCurpage = Math.random();
          this.siteTableInfo.refresh = Math.random();
          break;
        //分配权限搜索
        case "searchPermission":
          this.permissionTableInfo.initCurpage = Math.random();
          this.permissionTableInfo.refresh = Math.random();
          break;
        //添加用户按钮
        case "addUser":
          this.userDialogInfo.type = event;
          this.userFormInfo.data["groupName"] = data.groupName;
          this.userFormInfo.data["groupId"] = data.id;
          this.userDialogInfo.visible = true;
          break;
        //添加用户组按钮
        case "addGroup":
          this.userDialogInfo.type = event;
          this.userDialogInfo.visible = true;
          break;
        //提交数据
        case "submit":
          let submitType = this.dialogInfo.type;
          let submitApi, submitParams;
          if (submitType === "permission") {
            if (this.permissionSelectData.length) {
              if (this.permissionSelectData.length > 1) {
                this.$message({
                  message: "仅能绑定一个用户组到项目",
                  type: "warning",
                  showClose: true
                });
                return;
              } else {
                const groupIds = this.permissionSelectData.map(item => item.id);
                submitApi = this.nozzle.addGroupToProject;
                submitParams = {
                  data: {
                    groupIds: groupIds,
                    platfromCode: this.needHandleProjectId
                  }
                };
                this.handleAjax(submitApi, submitParams);
              }
            } else {
              this.$message({
                message: "请选择需要绑定的用户组",
                type: "warning",
                showClose: true
              });
              return;
            }
          } else if (submitType === "update") {
            //更新项目
            this.projectFormInfo.ref.validate(valid => {
              if (valid) {
                submitApi = this.nozzle.sysPlatformUpdate;
                submitParams = {
                  data: this.projectFormInfo.data
                };
                this.handleAjax(submitApi, submitParams);
              }
            });
          } else {
            return;
          }
          break;
        //添加站点到项目
        case "insert":
          if (this.UnRelateSiteTableInfo.selectList.length) {
            const siteIdArr = this.UnRelateSiteTableInfo.selectList.map( item => item.id);
            const insertData = {
              platCode: this.RelatedSiteTableInfo.query.platformCode,
              siteList: siteIdArr
            };
            this.$http.post(this.nozzle.sysStationBaseUpdate, { data: insertData }).then(res => {
              if (res.data.code === 1) {
                this.siteQuery.searchStr = "";
                this.siteTableInfo.refresh = Math.random();
                this.siteTableInfo.initCurpage = Math.random();
              }
              this.$message({
                message: res.data.msg,
                type: res.data.code === 1 ? "success" : "error",
                showClose: true
              });
            });
          } else {
            this.$message({
              message: "请选择需要绑定的站点",
              type: "warning",
              showClose: true
            });
          }
          break;
        //从项目中移除站点
        case "remove":
          if (this.RelatedSiteTableInfo.selectList.length) {
            const siteIdArr = this.RelatedSiteTableInfo.selectList.map(item => item.id);
            const removeData = {
              platCode: this.RelatedSiteTableInfo.query.platformCode,
              siteList: siteIdArr
            };
            this.$http.post(this.nozzle.sysStationBaseRemove, { data: removeData }).then(res => {
              if (res.data.code === 1) {
                this.siteQuery.searchStr = "";
                this.siteTableInfo.refresh = Math.random();
                this.siteTableInfo.initCurpage = Math.random();
              }
              this.$message({
                message: res.data.msg,
                type: res.data.code === 1 ? "success" : "error",
                showClose: true
              });
            });
          } else {
            this.$message({
              message: "请选择需要移除的站点",
              type: "warning",
              showClose: true
            });
          }
          break;
        //编辑项目按钮
        case "update":
          this.dialogInfo.type = event;
          this.dialogInfo.visible = true;
          this.projectFormInfo.needClearNodes = false;
          this.projectFormInfo.cascaderOptions = this.removeEmptyChild(this.allCity);
          for (let key in data) {
            if (key in this.projectFormInfo.data) {
              this.projectFormInfo.data[key] = data[key];
              this.projectFormInfo.data["operator"] = this.$fn.getLocalStore("USERNO");
            }
          }
          break;
        //关闭
        case "close":
          this.dialogInfo.visible = false;
          break;
        case "closeUserDialog":
          this.userDialogInfo.visible = false;
          break;
        //保存用户组/用户
        case "save":
          const type = this.userDialogInfo.type;
          const formName = type === "addUser" ? this.userFormInfo : this.groupFormInfo;
          let params, api;
          formName.ref.validate(valid => {
            if (valid) {
              if (type === "addUser") {
                //添加用户绑定到用户组
                api = this.nozzle.addUserToGroup;
                params = this.userFormInfo.data;
              }
              if (type === "addGroup") {
                //添加保存用户组
                api = this.nozzle.userGroupAdd;
                params = { data: this.groupFormInfo.data };
              }
              this.$http.post(api, params).then(res => {
                if (res.data.code === 1 || res.data.code === 200) {
                  this.userDialogInfo.visible = false;
                  this.permissionTableInfo.refresh = Math.random();
                }
                this.$message({
                  message: res.data.msg,
                  type: res.data.code === 1 ? "success" : "error",
                  showClose: true
                });
              })
              .catch(e => {
                console.log(e);
              });
            }
          });
          break;
      }
    },
    //关闭弹窗
    handleClose() {
      this.dialogInfo.visible = false;
    },
    handleUserClose() {
      this.userDialogInfo.visible = false;
    },
    //表格checkbox选择事件
    handleEvent(event, data) {
      switch (event) {
        case "all":
          this.permissionSelectData = data;
          break;
        case "isRelate":
          this.RelatedSiteTableInfo.selectList = data;
          break;
        case "unRelate":
          this.UnRelateSiteTableInfo.selectList = data;
          break;
      }
    },
    //重置表单
    resetForm(type) {
      switch (type) {
        case "addUser":
          this.userFormInfo.data = {
            id: undefined,
            login: "",
            realName: "",
            pwd: "",
            userType: "",
            orgId: undefined,
            groupId: undefined,
            groupName: "",
            roleId: undefined,
            mobile: ""
          };
          break;
        case "addGroup":
          this.groupFormInfo.data = {
            id: undefined,
            groupName: "",
            description: ""
          };
          break;
        case "update":
          this.projectFormInfo.data = {
            id: undefined,
            name: "",
            sysGroup: "",
            operator: "",
            area: "",
            platformCode: "",
            status: undefined
          };
          break;
      }
    },
    //请求接口处理结果
    handleAjax(url, params) {
      this.$http
        .post(url, params)
        .then(res => {
          if (res.data.code === 1 || res.data.code === 200) {
            this.dialogInfo.visible = false;
            this.projectTableInfo.refresh = Math.random();
          }
          this.$message({
            message: res.data.msg,
            type: res.data.code === 1 ? "success" : "error",
            showClose: true
          });
        })
        .catch(e => {
          console.log(e);
        });
    },
    //将空的children置为undefined,避免在没有下一级数据的情况下显示暂无数据
    removeEmptyChild(arr) {
      arr.forEach(item => {
        if (!item.children || item.children.length < 1) {
          item.children = undefined;
        } else {
          this.removeEmptyChild(item.children);
        }
      });
      return arr;
    }
  }
};
</script>

<style lang="scss" scoped>
.page-data {
  @include fd();
}
.page-filter {
  text-align: left;
}
.page-content {
  flex: 1;
  overflow: hidden;
  .page-table {
    height: 100%;
  }
  .red {
    color: red;
  }
}
.btn-group {
  height: 100%;
  @include fdaj(center, center);
  /deep/ .el-button + .el-button {
    margin-left: 0;
    margin-top: 10px;
  }
}
/deep/ .el-dialog {
  @include fd();
  @include wh(80%, 60%);
  max-height: 60%;
  margin-top: 10vh !important;
  .el-dialog__body {
    @include fd();
    flex: 1;
    padding: 20px;
    overflow-y: auto;
  }
  .el-pagination__sizes,
  .el-pagination__total,
  .el-pagination__jump {
    display: none;
  }
}
.userDialog {
  /deep/ .el-form-item {
    .el-form-item__label {
      width: 120px;
      padding-right: 15px;
    }
  }
}
</style>