Prechádzať zdrojové kódy

配置文件+角色查看权限

zhaoke 2 rokov pred
rodič
commit
5d34e7f739
3 zmenil súbory, kde vykonal 344 pridanie a 60 odobranie
  1. 153 42
      public/demo.js
  2. 2 1
      src/theme/index.scss
  3. 189 17
      src/views/userManagement/role/auth.vue

+ 153 - 42
public/demo.js

@@ -19,16 +19,14 @@ const LOOP_INTERVAL = {
   baggageMessage: 15 * 1000, // 行李原始报文
 };
 
-const DATACONTENT_ID = {
+const DATACONTENT_ID = DATACONTENT_ID = {
   /***-----登录------***/
   loginId: 36, //登录-获取权限-id
 
-  /***-----权限管理------***/
-  authTreeId: 40, //权限管理-权限树
-  authTreeNewId: 92, //权限管理-权限树
-
-  /***-----应用管理------***/
-  appTableId: 39, //应用管理
+  /***-----高级查询------***/
+  baggageTypeId: 86, //高级查询-特殊行李类型下拉选项查询-id
+  advancedQueryId: 30, //高级查询-数据查询-id
+  advancedQueryNew: 93, //高级查询-数据查询-id
 
   /***-----账号管理------***/
   accountTableId: 78, //账号管理-首页-列表
@@ -47,56 +45,169 @@ const DATACONTENT_ID = {
   roleDetailsId: 62, //角色管理-根据id查详情
   roleAuthId: 42, //角色管理-根据id查权限
 
-  /***-----基础数据------***/
-  airlineTableId: 80, //基础数据-航司信息维护-表格-id
-  airportTreeId: 58, //基础数据-机场信息维护-公司列表-id
-  airportTableId: 79, //基础数据-机场信息维护-表格-id
-  terminalTableId: 1803432, //基础数据-机场信息维护-航站楼-表格-id
-  airpositTableId: 1803433, //基础数据-机场信息维护-航站楼位置-表格-id
-  deployNodeId: 54, //基础数据-节点信息维护-id
-  modelMainNodeId: 1803434, //基础数据-机型维护-id
-  shippingNodeId: 1803435, //基础数据-舱位-id
-  containerNodeId: 1803436, //基础数据-容器-id
-  bagTableId: 55, //基础数据-特殊行李维护-表格-id
-  equipmentNodeId: 1803437, //基础数据-设备维护-表格-id
-  forwarderNodeId: 1803438, //基础数据-货代-表格-id
+  /***-----权限管理------***/
+  authTreeId: 40, //权限管理-权限树
+  authTreeNewId: 92, //权限管理-权限树
 
   /***-----系统设置------***/
+  sysSourceId: 13, //系统设置-数据源-id
   sysProtoTabId: 1, //系统设置-协议管理-表格-id
   sysServiceTabId: 2, //系统设置-服务管理-表格-id
-  structureTabId: 5, //系统设置-数据结构管理-表格-id
-  sourceDataTabId: 6, //系统设置-源数据管理-表格-id
-  dataitemTabId: 9, //系统设置-数据项-表格-id
-  sysLogTable: 12, //系统设置-日志-表格
-  sysServiceWarningId: 18029, //查询预警报警场景列表
-  sysServiceWarnId: 18030, //预警报警场景(按照ID)
-  sysServiceStrategyId: 18033, //预警报警策略(按照ID)
-  sysSourceId: 13, //系统设置-数据源-id
+  sysServiceOutTabId: 7, //系统设置-服务管理-编辑-输出-表格-id
+  sysServiceJqTabId: 3, //系统设置-服务管理-编辑-部署机器-表格-id
+  sysQueryTabId: 4, //系统设置-查询模板-表格-id
   sysQueryEditId: 24, //系统设置-查询模板-编辑-根据id获取服务
   sysQueryChildTabId: 25, //系统设置-查询模板-列设置-表格-id
   sysQueryChildEditTabId: 26, //系统设置-查询模板-列设置-表格-编辑-id
-  sysServiceTopTable: 31, //系统设置-服务管理-服务拓扑-查看日志
-  messageQueryTabId: 1803442, //系统设置-消息查询-表格-id
+  sysDataTabId: 5, //系统设置-数据结构-表格-id
+  sysDataChildTabId: 9, //系统设置-数据结构-数据项-表格-id
+  sysLogTabId: 12, //系统设置-数据结构-数据项-表格-id
+  sysDataEditId: 57, //系统设置-数据结构-数据项-表格-编辑-id
+  sysServiceXyId: 15, //系统设置-服务管理-新增服务-新增数据来源-id
+  sysServiceEditId: 23, //系统设置-服务管理-编辑服务-根据id获取服务
+  sysServiceTopId: 32, //系统设置-服务管理-服务拓扑-根据id获取拓扑图
+  sysServiceTopTableId: 31, //系统设置-服务管理-服务拓扑-查看日志id
+  sysServiceNodeListId: 89,
+  sysServiceWarningId: 18029, //查询预警报警场景列表
+  sysServiceaddId: 8013, //新增预警报警场景
+  sysServiceWarnId: 18030, //预警报警场景(按照ID)
+  sysServiceStrategyId: 18033, //预警报警策略(按照ID)
+  sysServiceStrategyaddId: 8014, //新增预警报警策略
+  /***-----进港管理------***/
+  arrivalAirId: 67, //进港管理-机场选择
+  arrivalTableId: 38, //进港管理-表格
+
+  /***-----离港管理------***/
+  departureAirMainId: 65, //离港管理-机场选择
+  departureTableMainId: 66, //离港管理-表格
+  departureWarningId: 18040, //离港管理-报警策略
+
+  /***-----中转进港------***/
+  departureAirId: 72, // 中转进港-机场选择
+  departureAviJoinId: 71, // 中转进港-进港承运航司
+  departureAviLeaveId: 74, // 中转进港-离港承运航司
+  departureTableId: 69, // 中转进港-表格
+
+  /***-----中转离港------***/
+  departureAirLtId: 72, // 中转离港-机场选择
+  departureAviJoinLtId: 71, // 中转离港-进港承运航司
+  departureAviLeaveLtId: 74, // 中转离港-离港承运航司
+  departureTableLtId: 68, // 中转离港-表格
+
+  /***-----航班视图------***/
+  flightAirline: 1141, // 航班-航段
+  flightInfo: 1142, // 航班-基础信息
+  flightContainer: 41, // 航班-容器
+  flightBaggage: 1144, // 航班-行李列表
+  abnormalBaggageInfo: 1145,
+
+  /***-----行李视图------***/
+  baggageBasicInfo: 255, // 行李-基础信息
+  baggageAirline: 18009, // 行李-航段
+  baggageTrack: 18010, // 行李-追踪节点
+  baggageDetails: 44, // 行李-详情列表
+  baggageMessage: 3066, // 行李-原始报文
 
-  /***-----数据查询------***/
-  flightTabId: 1803439, //数据查询-航班-表格-id
-  waybillTabId: 1803441, //数据查询-运单-表格-id
-  goodsTabId: 1803440, //数据查询-货物-表格-id
+  /***-----容器视图------***/
+  containerHistory: 18026,
+  containerBaggage: 18027,
+
+  /***-----基础数据------***/
+  deployNodeId: 54, //基础数据-节点信息维护-获取二级节点(表格)-id
+  deployNodeteoId: 60, //基础数据-节点信息维护-二级页面-id
+  deployNodeThreeId: 64, //基础数据-节点信息维护-获取三级节点-id
+  airlineTableId: 80, //基础数据-航司信息维护-表格-id
+  airportTableId: 79, //基础数据-机场信息维护-表格-id
+  airportTreeId: 58, //基础数据-机场信息维护-公司列表-id
+  bagTableId: 55, //基础数据-特殊行李维护-表格-id
+
+  /***-----统计分析------***/
+  stOrderId: 18012,
+  stOrderChartId: 18013,
+  stCalId: 18014,
+  stFigntsId: 18015,
+  stSpeedId: 18016,
+  stBaggageId: 18017,
+  stMapId: 18018,
+  stCountryId: 18019,
+  stTerminalId: 18020,
+  stBrsId: 1803429,
+
+  // 数据统计
+  airlineOptions: 1806, // 航线下拉
+  twoCharacterOptions: 1803426, // 二字码下拉
+  termSeleid: 1156, //航站选择下拉
+  areaOptions: 1807, // 大区/基地分公司下拉
+  AirportId: 1808, // 航站下拉
+  TerminalId: 1809, // 航站楼下拉
+  byOther: 1810, // 大区/分公司以外航班统计(全部)
+  byArea: 1811, // 根据大区/分公司航班统计(全部)
+  withBaggageByOther: 1812, // 大区/分公司以外航班统计(有行李)
+  withBaggageByArea: 1814, // 根据大区/分公司航班统计(有行李)
+  baggageByOther: 1815, // 行李统计(全部)
+  baggageByArea: 1816, // 行李统计-分公司(全部)
+  notDelByOther: 1817, // 行李统计(不包含DEL)
+  notDelByArea: 1818, // 行李统计-分公司(不包含DEL)
+  baggagePassengerByOther: 1819, // 行李旅客统计
+  baggagePassengerByArea: 1820, // 行李旅客统计-分公司
+  specialBaggageByOther: 1821, // 特殊行李统计
+  specialBaggageByArea: 1822, // 特殊行李统计-分公司
+  abnormalBaggageByOther: 1823, // 异常行李统计
+  abnormalBaggageByArea: 1824, // 异常行李统计-分公司
+  complaintBaggageByOther: 1825, // 投诉行李统计
+  complaintBaggageByArea: 1826, // 投诉行李统计-分公司
+  compensationBaggageByOther: 1827, // 赔偿行李统计
+  compensationBaggageByArea: 1828, // 赔偿行李统计-分公司
+  compensationByOther: 1829, // 赔偿金额统计
+  compensationByArea: 1830, // 赔偿金额统计-分公司
+  baggageAverageByOther: 1831, // 平均行李统计
+  baggageAverageByArea: 1832, // 平均行李统计-分公司
+  specialBaggageClassificationByOther: 1193, // 特殊行李分类统计
+  specialBaggageClassificationByArea: 1194, // 特殊行李分类统计-分公司
+  flightClassificationByOther: 1195, // 航班分类统计
+  flightClassificationByArea: 1196, // 航班分类统计-分公司
+  compensationClassificationByOther: 1197, // 赔偿分类统计
+  compensationClassificationByArea: 1198, // 赔偿分类统计-分公司
+  passengerNormalClassificationByOther: 1199, // 旅客分类常客统计
+  passengerNormalClassificationByArea: 1200, // 旅客分类常客统计-分公司
+  passengerImportantClassificationByOther: 1201, // 旅客分类要客统计
+  passengerImportantClassificationByArea: 1202, // 旅客分类要客统计-分公司
+  abnormalBaggageClassificationByOther: 1205, // 异常行李分类统计
+  abnormalBaggageClassificationByArea: 1206, // 异常行李分类统计-分公司
+  nodeRange: 1801, // 节点查询范围
+  nodeAirline: 1802, // 节点航线下拉
+  nodeAirport: 1803, // 节点航站下拉
+  nodeAll: 1804, // 节点统计雷达图-全部
+  nodeIn: 1804, // 节点统计雷达图-进港
+  nodeOut: 1804, // 节点统计雷达图-离港
+  nodeExportAirline: 1805, // 节点统计导出-航线
+  nodeExportAirport: 1805, // 节点统计导出-航站
+  nodeAxisDesc: 90, // 节点统计指示器名称解释
 };
 
 const SERVICE_ID = {
-  sysQueryTabId: 5, //系统设置-查询模板-表格-增删改
-  /***-----权限项管理------***/
-  authScId: 13, //权限项管理-增删改
-  /***-----应用管理------***/
-  appScId: 12, //应用管理-增删改
   /***-----账号管理------***/
   accountScId: 17, //账号管理-增删改
   roleScId: 16, //账号管理-角色授权-增删改
+
+  /***-----账号组管理------***/
+  accountGroupScId: 8015, //账号管理-增删改
+
   /***-----角色管理------***/
   roleMsgId: 14, //角色管理-增删改
   roleMsgTreeId: 15, //角色管理-权限树-增删改
   roleMsgAuthId: 20, //角色管理-权限树规则-增删改
-  /***-----账号组管理------***/
-  accountGroupScId: 8015, //账号管理-增删改
-};
+
+  /***-----权限项管理------***/
+  authScId: 13, //权限项管理-增删改
+
+  /***-----离港管理------***/
+  departureScId: 8011, //发送报警预警日志信息
+
+  sysProtoTabId: 1, //系统设置-协议管理-表格-增删改
+  sysServiceAddId: 3, //系统设置-服务管理-新增服务-提交-id/服务管理-编辑服务-保存
+  sysServiceEditBoxId: 4, //系统设置-服务管理-编辑服务-部署机器-多选框
+  sysQueryTabId: 5, //系统设置-查询模板-表格-增删改
+  sysServiceAddXyId: 10, //系统设置-服务管理-新增服务-新增数据源-提交
+  sysDataTabId: 9, //系统设置-数据结构-数据项-表格-增删改
+};

+ 2 - 1
src/theme/index.scss

@@ -25,7 +25,8 @@
   }
 }
 .el-radio__input.is-checked .el-radio__inner,
-.el-checkbox__input.is-checked .el-checkbox__inner {
+.el-checkbox__input.is-checked .el-checkbox__inner,
+.el-checkbox__input.is-indeterminate .el-checkbox__inner {
   background: #ac014d;
   border-color: #ac014d;
 }

+ 189 - 17
src/views/userManagement/role/auth.vue

@@ -75,8 +75,7 @@
 </template>
 
 <script setup lang="ts">
-import { ref, reactive, onBeforeMount, watch } from "vue";
-import { EditRole } from "@/api/apiAuthority";
+import { ref, onBeforeMount, watch } from "vue";
 import { Query, GeneralDataReception } from "@/api/dataIntegration";
 import { translateDataToTreeAll } from "@/utils/validate";
 import { ElMessage, ElTree } from "element-plus";
@@ -98,31 +97,34 @@ const form = ref({
   edit_row_condition: "",
   edit_col_condition: "",
 });
+const maxReq = ref(20);
+const proAll = ref<any>([]);
+const proNum = ref(0);
 const checkObj = ref<any>(null);
 const data = ref<any>([]);
 const newData = ref<any>([]);
 const checkData = ref<any>([]);
-const checkKeys = ref<any>([]);
+const checkKeys = ref<any>([-1]);
+const boxData = ref<any>([]);
 const treeRef = ref<InstanceType<typeof ElTree>>();
 onBeforeMount(() => {
   roleDetails();
   getTree();
-  roleAuths();
 });
 
 watch(
   () => form,
   (newValue) => {
     newData.value.forEach((item) => {
+      if (item.children) {
+        delete item.children;
+      }
       if (item.auth_id == checkObj.value.auth_id) {
         item = Object.assign(item, newValue.value);
-        checkData.value.push(item);
-        const datas = _.unionBy(checkData.value, "auth_id");
-        checkData.value = datas;
       }
     });
     checkKeys.value = [checkObj.value.auth_id];
-    data.value = [tree.setTree(newData.value)];
+    toTree();
   },
   { deep: true }
 );
@@ -142,11 +144,64 @@ const roleDetails = async () => {
   } catch (error) {}
 };
 
+const toTree = () => {
+  data.value = [];
+  const chks = treeRef.value!.getCheckedNodes(false, true);
+  const arr = translateDataToTreeAll(newData.value, "up_auth_id", "auth_id");
+  const items = {
+    auth_id: -1,
+    auth_name: "所有权限",
+    auth_status: 0,
+    up_auth_id: -2,
+    auth_type: 0,
+    children: arr,
+    disabled: true,
+  };
+  data.value = [items];
+  if (chks && chks.length) {
+    checkBox(chks, newData.value);
+  }
+};
+
 //权限树
 const getTree = async () => {
-  const res = await tree.getTree();
-  newData.value = await tree.newData.value;
-  data.value = res.value;
+  try {
+    const { returnData, code } = await Query({
+      id: DATACONTENT_ID.authTreeNewId,
+      dataContent: [sessionStorage.getItem("User_Id")],
+    });
+    if (code == 0 && returnData.listValues) {
+      newData.value = _.cloneDeep(returnData.listValues);
+      toTree();
+      roleAuths();
+    } else {
+    }
+  } catch (error) {}
+  // const res = await tree.getTree();
+  // newData.value = await tree.newData.value;
+  // data.value = res.value;
+};
+
+const checkBox = (arr, all) => {
+  const checks: any = [];
+  const nots = _.cloneDeep(arr);
+  const caps = _.cloneDeep(all);
+  arr.forEach((item) => {
+    checks.push(item.auth_id);
+  });
+  const res = [...caps, ...nots].filter(
+    (item) =>
+      !(
+        caps.some((p) => item.auth_id == p.auth_id) &&
+        nots.some((c) => item.auth_id == c.auth_id)
+      )
+  );
+  treeRef.value!.setCheckedKeys(checks);
+  setTimeout(() => {
+    res.forEach((item) => {
+      treeRef.value!.setChecked(item.auth_id, false, false);
+    });
+  }, 0);
 };
 
 //权限详情
@@ -157,11 +212,8 @@ const roleAuths = async () => {
       dataContent: [role_id],
     });
     if (code == 0 && returnData.listValues) {
-      const datas: any = [];
-      returnData.listValues.forEach((item) => {
-        datas.push(item.auth_id);
-      });
-      treeRef.value!.setCheckedKeys(datas, false);
+      boxData.value.push(returnData.listValues);
+      checkBox(returnData.listValues, newData.value);
     } else {
       ElMessage.error(message);
     }
@@ -170,6 +222,9 @@ const roleAuths = async () => {
 
 const handleNodeClick = (data) => {
   checkObj.value = data;
+  checkData.value.push(_.cloneDeep(data));
+  const datas = _.unionBy(checkData.value, "auth_id");
+  checkData.value = datas;
   const checkNode = checkData.value.filter(
     (item) => item.auth_id == data.auth_id
   );
@@ -192,7 +247,124 @@ const clearFormData = () => {
 
 const currentChange = () => {
   const datas = treeRef.value!.getCheckedNodes(false, true);
-  console.log(datas);
+  datas.forEach((item, index) => {
+    if (item.auth_id == -1) {
+      datas.splice(index, 1);
+    }
+  });
+  boxData.value.push(datas);
+  const data1 = boxData.value[boxData.value.length - 1]; //最后一条数据
+  const data2 = boxData.value[boxData.value.length - 2]; //倒数第二条数据
+  if (data1.length > data2.length) {
+    checksBoxTs(data1, data2, "add");
+  } else {
+    checksBoxTs(data2, data1, "del");
+  }
+};
+
+const checksBoxTs = async (datas, arr, type) => {
+  const res = [...datas, ...arr].filter(
+    (item) =>
+      !(
+        datas.some((p) => item.auth_id == p.auth_id) &&
+        arr.some((c) => item.auth_id == c.auth_id)
+      )
+  );
+  const [msg1, msg2] = [<any>[], <any>[]];
+  if (res && res.length) {
+    for (let i = 0; i < res.length; i++) {
+      delete res[i].children;
+      let obj = <any>{
+        auth_id: res[i].auth_id || res[i].AuthId,
+        role_id: role_id,
+      };
+      let authObj = res[i].AuthList
+        ? Object.assign(_.cloneDeep(obj), res[i].AuthList)
+        : Object.assign(_.cloneDeep(obj), res[i]);
+      if (type == "add") {
+        obj.event = 1;
+        authObj.event = 1;
+        msg1.push(obj);
+        msg2.push(authObj);
+      } else {
+        obj.event = 3;
+        authObj.event = 3;
+        msg1.push(obj);
+        msg2.push(authObj);
+      }
+    }
+    GeneralDataReception({
+      serviceId: SERVICE_ID.roleMsgTreeId,
+      dataContent: JSON.stringify(msg1),
+    }).then((result) => {
+      if (result.code == 0) {
+        if (type == "add") {
+          ElMessage.success("操作权限成功");
+        } else {
+          ElMessage.success("操作权限成功");
+        }
+      } else {
+        if (type == "add") {
+          ElMessage.error("操作权限失败");
+        } else {
+          ElMessage.error("操作权限失败");
+        }
+      }
+    });
+    if (msg2.length > maxReq.value) {
+      foxFunc(msg2);
+    } else {
+      GeneralDataReception({
+        serviceId: SERVICE_ID.roleMsgAuthId,
+        dataContent: JSON.stringify(msg2),
+      }).then((result) => {
+        if (result.code == 0) {
+          if (type == "add") {
+            ElMessage.success("操作规则成功");
+          } else {
+            ElMessage.success("操作规则成功");
+          }
+        } else {
+          if (type == "add") {
+            ElMessage.error("操作规则失败");
+          } else {
+            ElMessage.error("操作规则失败");
+          }
+        }
+      });
+    }
+  } else {
+    // this.$message.error('未选中数据')
+  }
+};
+
+const foxFunc = async (arr?: Array<any>) => {
+  if (proAll.value.length == 0) {
+    proAll.value = _.cloneDeep(arr);
+  }
+  const limit = _.chunk(proAll.value, maxReq.value);
+  const reqUts = [];
+  limit.forEach((item, index) => {
+    const req = GeneralDataReception({
+      serviceId: SERVICE_ID.roleMsgAuthId,
+      dataContent: JSON.stringify(limit[index]),
+    });
+    reqUts.push(req);
+  });
+  const result = Promise.all(reqUts);
+  const resultLen = await result;
+  if (limit.length == resultLen.length) {
+    proAll.value = [];
+    proNum.value = 0;
+    ElMessage.success("操作规则成功");
+  } else {
+    proNum.value += 1;
+    if (proNum.value == 4) {
+      ElMessage.success("网络错误,请稍后重试");
+    } else {
+      foxFunc();
+    }
+  }
 };
 
 const defaultProps = {