staffEdit.vue 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618
  1. <!--
  2. * @Author: your name
  3. * @Date: 2022-02-10 14:49:20
  4. * @LastEditTime: 2022-02-16 14:10:05
  5. * @LastEditors: Please set LastEditors
  6. * @Description: 编辑职员
  7. * @FilePath: \Foshan4A4.0\src\views\staffManagement\compontents\staffEdit.vue
  8. -->
  9. <template>
  10. <div class="authorityPower">
  11. <!--编辑职员-->
  12. <div class="addApp-form">
  13. <div class="addApp-form-title flex">
  14. <div class="title">编辑职员</div>
  15. <div class="btn">
  16. <el-button @click="saveBtn('form')" type="primary">保存</el-button>
  17. </div>
  18. </div>
  19. <div class="addApp-form-content dialog-public-background">
  20. <el-form :inline="true" ref="form" :rules="rules" class="form" :model="form">
  21. <el-form-item prop="name" label="职员名称">
  22. <el-input placeholder="请输入职员名称" maxlength="32" v-model="form.name"></el-input>
  23. </el-form-item>
  24. <el-form-item prop="loginName" label="职员登录名">
  25. <el-input placeholder="请输入职员登录名" maxlength="32" v-model="form.loginName"></el-input>
  26. </el-form-item>
  27. <el-form-item style="margin-right: 16px" label="登录密码">
  28. <el-input placeholder="*******" disabled maxlength="32" v-model="form.loginPwd"></el-input>
  29. </el-form-item>
  30. <el-form-item>
  31. <el-button size="small" type="primary" @click="reSetPassWord">重置密码</el-button>
  32. </el-form-item>
  33. <el-form-item label="描述">
  34. <el-input style="width: 25.65vw" maxlength="200" placeholder="请输入描述" v-model="form.app"></el-input>
  35. </el-form-item>
  36. </el-form>
  37. </div>
  38. </div>
  39. <div class="power-content flex-wrap">
  40. <div class="r24 flex1 part">
  41. <Organization ref="Organization" :defaultProps="defaultProps" :mainData="mainData" :vice="true" :data="data" @getTreeData="getOrgan" @radioChange="radioChange" :checkedKeys="orgCheckedKeys" :radioCheck="radioNum" nodekey="OrganId" title="选择组织" />
  42. </div>
  43. <!--开启多对多-->
  44. <template v-if="OpenAuthData">
  45. <div class="flex1 part">
  46. <Rolelist @checkChange="accountChange" :checkBoxList="checkBoxList" :roleType="roleType" :active="true" class="hucRole" :number="4" title="账号列表" />
  47. </div>
  48. </template>
  49. <!--未开启多对多-->
  50. <template v-else>
  51. <!--有账号组 无角色-->
  52. <template v-if="OpenGroup && !openRole">
  53. <div class="r24 flex1 part">
  54. <Usergroup @getTreeData="getUserGroup" :checkedKeys="userGroupKeys" title="用户组树" />
  55. </div>
  56. <div class="r24 flex1 part">
  57. <Permissiontree ref="Permissiontree" :queryType="queryType" :queryId="treeId" :checkedKeys="checkedBoxs" :isMainJob="isMainJob" @nodeClick="nodeClick" @getTreeData="getTreeData" title="权限树" />
  58. </div>
  59. <div class="flex1 part">
  60. <Rulesofcompetency style="height: 512px" class="hucPower" :authList="authList" :authTo="authTo" @getData="getData" title="权限规则" />
  61. <Loginpolicy style="margin-top: 24px; height: calc(100% - 24px - 512px)" :imageSize="20" :checkedList="checkedList" @getCheckedList="getCheckedList" title="登录策略" />
  62. </div>
  63. </template>
  64. <!--有角色 无账号组-->
  65. <template v-if="openRole && !OpenGroup">
  66. <div class="r24 flex1 part">
  67. <Rolelist @checkChange="checkChange" @checkClick="checkClick" :roleType="roleType" :checkBoxList="roleCheckBoxs" :active="true" class="hucRole" :number="8" title="角色列表" />
  68. </div>
  69. <div class="flex1 part">
  70. <Permissionlist style="height: 376px" :imageSize="120" :RoleList="RoleList" :check="true" class="hucPower" title="权限列表" />
  71. <Loginpolicy style="margin-top: 24px; height: calc(100% - 24px - 376px)" :imageSize="120" :checkedList="checkedList" @getCheckedList="getCheckedList" title="登录策略" />
  72. </div>
  73. </template>
  74. <!--有角色 有账号组-->
  75. <template v-if="openRole && OpenGroup">
  76. <div class="r24 flex1 part">
  77. <Usergroup @getTreeData="getUserGroup" :checkedKeys="userGroupKeys" title="用户组树" />
  78. </div>
  79. <div class="r24 flex1 part">
  80. <Rolelist @checkChange="checkChange" @checkClick="checkClick" :GroupIds="GroupIds" :roleType="roleType" :checkBoxList="roleCheckBoxs" :active="true" class="hucRole" :number="8" title="角色列表" />
  81. </div>
  82. <div class="flex1 part">
  83. <Permissionlist style="height: 376px" :imageSize="120" :RoleList="RoleList" :check="true" class="hucPower" title="权限列表" />
  84. <Loginpolicy style="margin-top: 24px; height: calc(100% - 24px - 376px)" :imageSize="120" :checkedList="checkedList" @getCheckedList="getCheckedList" title="登录策略" />
  85. </div>
  86. </template>
  87. <!--无账号组 无角色-->
  88. <template v-if="!OpenGroup && !openRole">
  89. <div class="r24 flex1 part">
  90. <Permissiontree ref="Permissiontree" :queryType="queryType" :queryId="treeId" :checkedKeys="checkedBoxs" :isMainJob="isMainJob" @nodeClick="nodeClick" @getTreeData="getTreeData" title="权限树" />
  91. </div>
  92. <div class="flex1 part">
  93. <Rulesofcompetency style="height: 512px" class="hucPower" :authList="authList" :authTo="authTo" @getData="getData" title="权限规则" />
  94. <Loginpolicy style="margin-top: 24px; height: calc(100% - 24px - 512px)" :imageSize="20" :checkedList="checkedList" @getCheckedList="getCheckedList" title="登录策略" />
  95. </div>
  96. </template>
  97. </template>
  98. </div>
  99. </div>
  100. </template>
  101. <script>
  102. import Permissiontree from "@/components/permissiontree";
  103. import Rulesofcompetency from "@/components/rulesofcompetency";
  104. import Organization from "@/components/organization";
  105. import Permissionlist from "@/components/permissionlist";
  106. import Rolelist from "@/components/rolelist";
  107. import Loginpolicy from "@/components/loginpolicy";
  108. import Usergroup from "@/components/usergrouptree";
  109. import treeData from "../minixs/treeData";
  110. import { mapGetters } from "vuex";
  111. import { RoleAuths } from "@/api/apiAuthority";
  112. import {
  113. newstaffmod,
  114. postList,
  115. organgitpost,
  116. jbdetpop,
  117. Staffdetails,
  118. } from "@/api/postInterface";
  119. import { pwdProduce } from "@/utils/validate";
  120. export default {
  121. name: "AuthorityPower",
  122. mixins: [treeData],
  123. components: {
  124. Rulesofcompetency,
  125. Organization,
  126. Permissiontree,
  127. Permissionlist,
  128. Rolelist,
  129. Loginpolicy,
  130. Usergroup
  131. },
  132. data () {
  133. return {
  134. Status: null,
  135. AppId: null,
  136. form: {
  137. //应用表单
  138. name: "",
  139. loginName: "",
  140. loginPwd: "",
  141. app: "",
  142. },
  143. title: "角色",
  144. rules: {
  145. //表单验证
  146. name: [{ required: true, message: "请输入职员名称", trigger: "blur" }],
  147. loginName: [
  148. { required: true, message: "请输入职员登录名", trigger: "blur" },
  149. ],
  150. loginPwd: [
  151. { required: true, message: "请输入职员登录密码", trigger: "blur" },
  152. ],
  153. },
  154. defaultProps: {
  155. children: "children",
  156. label: "OrganName",
  157. },
  158. treeId: null, //根据组织获取权限树的组织ID
  159. checkedKeys: [], //上级组织选中
  160. RoleList: [],
  161. checkedBoxs: [],
  162. arrs: [],
  163. authArrs: [],//
  164. OfficerId: null,
  165. authId: [], //权限树默认选中ID
  166. authList: [],
  167. authTo: {},
  168. orgTypes: [],
  169. checkBoxList: [], //副岗默认选中
  170. checkedList: [], //登录策略默认选中的数据
  171. radioCheck: null, //主岗默认选中
  172. radioNum: null, //主岗已选中
  173. roleDatas: [], //接口详情返回的角色列表数据
  174. roleCheckBoxs: [], //角色列表默认选中数据
  175. groupCheckBoxs: [], //权限组列表默认选中数据
  176. orgCheckedKeys: [], //组织树默认选中
  177. loginCheckBoxs: [], //登录策略数据
  178. mainData: [], //主岗数据
  179. JobId: "", //选中主岗ID
  180. DepJobIds: [],//选中副岗ID集合
  181. lessData: [], //副岗数据
  182. lessCheckBoxs: [], //副岗选中数据联合主岗
  183. lessChecksData: [], //副岗选中数据
  184. queryType: null, //权限树类型
  185. openRole: null,
  186. OpenGroup: null,
  187. OpenAuthData: null,
  188. roleType: '',
  189. dataObj: {}, //上级权限指定树数据
  190. data: [], //上级权限
  191. roleList: [], //角色
  192. checkRoles: [], //选中的角色
  193. checkTrees: [], //上级权限选中树数据
  194. rulesObj: {}, //权限规则数据
  195. isMainJob: true, //是否主岗
  196. oldOrganId: "",
  197. onCheckedArr: [],//当前显示选中权限组
  198. alljobArr: [],//全部岗位
  199. GroupIds: [], //当前选中的用户组
  200. userGroupKeys: [] //当前回调选中的用户组
  201. };
  202. },
  203. computed: {
  204. ...mapGetters(["systemSet"]),
  205. },
  206. watch: {
  207. //监听上级组织数据
  208. dataList: {
  209. handler (val) {
  210. this.data = [val];
  211. },
  212. deep: true,
  213. },
  214. mainData: {
  215. handler (arr) {
  216. if (this.radioCheck) {
  217. let ids = null;
  218. arr.forEach((item, index) => {
  219. if (item.JobId == this.radioCheck) {
  220. ids = index;
  221. }
  222. })
  223. this.radioNum = ids;
  224. }
  225. },
  226. deep: true,
  227. }
  228. },
  229. created () {
  230. const { OrganId, Status, OfficerId } = this.$route.query;
  231. const { OpenRole, PwdLengthBegin, PwdLengthEnd, PwdStruc, OpenGroup, UserOfficerMulti } =
  232. typeof this.systemSet === "string"
  233. ? JSON.parse(this.systemSet)
  234. : this.systemSet; //1是请求角色 0是请求用户
  235. // this.form.loginPwd = pwdProduce(PwdLengthBegin, PwdLengthEnd, PwdStruc);
  236. this.Status = Status;
  237. this.OfficerId = OfficerId;
  238. this.openRole = OpenRole;
  239. this.OpenGroup = OpenGroup;
  240. this.OpenAuthData = UserOfficerMulti;
  241. if (OpenGroup || !OpenGroup && !OpenRole) {
  242. this.queryType = "all";
  243. }
  244. this.getOfficerDetails(OfficerId);
  245. },
  246. methods: {
  247. //职员详情查询
  248. async getOfficerDetails (id) {
  249. try {
  250. let params = {
  251. OfficerId: id,
  252. };
  253. const res = await Staffdetails(params);
  254. if (res.code === 0) {
  255. const obj = res.returnData;
  256. const {
  257. AuthList,
  258. DepJobList,
  259. JobId,
  260. OrganId,
  261. OfficerDesc,
  262. OfficerLoginName,
  263. OfficerName,
  264. RoleList,
  265. TacList,
  266. GroupList,
  267. UserList
  268. } = obj;
  269. this.form.name = OfficerName;
  270. this.form.loginName = OfficerLoginName;
  271. this.form.app = OfficerDesc;
  272. this.orgCheckedKeys = [OrganId];
  273. this.oldOrganId = OrganId;
  274. this.roleDatas = RoleList;
  275. this.radioCheck = JobId;
  276. this.JobId = JobId;
  277. this.lessChecksData = DepJobList;
  278. this.isMainJob = false;
  279. this.AppId = OrganId;
  280. this.getJobListByOrgan(OrganId);
  281. if (this.OpenAuthData) {
  282. this.roleType = 'account';
  283. }
  284. if (this.openRole && !this.OpenGroup && !this.OpenAuthData) {
  285. this.roleType = 'onlyRole';
  286. }
  287. if (AuthList && AuthList.length) {
  288. AuthList.forEach((item) => {
  289. this.authId.push(item.AuthId);
  290. });
  291. this.authList = _.cloneDeep(AuthList);
  292. this.authTo = AuthList[0];
  293. this.checkedBoxs = this.authId;
  294. }
  295. if (RoleList && RoleList.length) {
  296. this.roleCheckBoxs = RoleList;
  297. this.checkRoles = RoleList;
  298. if (this.openRole && this.OpenGroup && !this.OpenAuthData) {
  299. this.roleType = 'onlyRole';
  300. }
  301. }
  302. if (GroupList && GroupList.length) {
  303. const datas = [];
  304. GroupList.forEach(item => {
  305. datas.push(item.GroupId);
  306. })
  307. this.userGroupKeys = datas;
  308. this.GroupIds = datas;
  309. }
  310. if (UserList && UserList.length) {
  311. const datas = [];
  312. UserList.forEach(item => {
  313. datas.push(item.UserId);
  314. })
  315. this.checkBoxList = datas;
  316. }
  317. this.checkedList = TacList;
  318. this.loginCheckBoxs = TacList;
  319. } else {
  320. this.$message.error(res.message);
  321. }
  322. } catch (error) {
  323. console.log("出错了", error);
  324. }
  325. },
  326. //获取选中的树数据
  327. getTreeData (arr) {
  328. this.checkTrees = arr;
  329. },
  330. // 默认选中
  331. defaultChecked (arr, id) {
  332. const datas = []
  333. this.onCheckedArr = [];
  334. arr.forEach((item, index) => {
  335. this.checkRoles.forEach(p => {
  336. if (item[id] == p[id]) {
  337. datas.push(index)
  338. this.onCheckedArr.push(item);
  339. }
  340. })
  341. })
  342. if (this.openRole) {
  343. this.roleCheckBoxs = datas;
  344. } else if (this.OpenGroup) {
  345. this.groupCheckBoxs = datas;
  346. }
  347. },
  348. //获取组织选中的数据
  349. getOrgan (arr) {
  350. const { OrganId } = arr[0];
  351. this.AppId = OrganId;
  352. this.getJobListByOrgan(OrganId);
  353. },
  354. //获取指定数据
  355. decompose (data, id) {
  356. for (let i = 0; i < data.length; i++) {
  357. if (data[i].OrganId == id) {
  358. this.dataObj = data[i];
  359. } else if (data[i].children && data[i].children.length > 0) {
  360. this.decompose(data[i].children, id);
  361. }
  362. }
  363. },
  364. //权限树点击
  365. nodeClick (obj) {
  366. const arr = this.$store.getters.authArrs;
  367. arr.push(obj);
  368. this.$store.dispatch("auth/changeAuthArrs", arr);
  369. },
  370. //根据主岗查询角色
  371. radioChange (val) {
  372. const { JobId } = this.mainData[val];
  373. this.JobId = JobId;
  374. this.radioCheck = null;
  375. },
  376. //根据岗位获取角色
  377. async getRoleByJob (id, index) {
  378. try {
  379. let params = {
  380. JobId: id,
  381. };
  382. const res = await jbdetpop(params);
  383. if (res.code === 0) {
  384. const datas = res.returnData;
  385. const arrs = [];
  386. datas.forEach((item) => {
  387. item.name = item.RoleName;
  388. if (item.IsSelected == 1) {
  389. arrs.push(item);
  390. }
  391. });
  392. if (index == 1) {
  393. this.arrs = arrs;
  394. this.lessCheckBoxs.push(arrs);
  395. } else if (index == 2) {
  396. if (arrs.length) {
  397. this.lessCheckBoxs.push(arrs);
  398. const msgs = this.lessCheckBoxs.flat();
  399. const uninqMsgs = _.unionBy(msgs, "RoleId");
  400. this.arrs = uninqMsgs;
  401. }
  402. }
  403. } else {
  404. this.$message.error(res.message);
  405. }
  406. } catch (error) {
  407. console.log("出错了", error);
  408. }
  409. },
  410. //根据组织查询岗位列表-主岗
  411. async getJobListByOrgan (id) {
  412. try {
  413. let params = {
  414. OrganId: id,
  415. };
  416. const res = await organgitpost(params);
  417. if (res.code === 0) {
  418. const datas = res.returnData;
  419. datas.forEach((item) => {
  420. item.name = item.JobName;
  421. });
  422. this.mainData = datas;
  423. } else {
  424. this.$message.error(res.message);
  425. }
  426. } catch (error) {
  427. console.log("出错了", error);
  428. }
  429. },
  430. //角色点击回调
  431. checkClick (item) {
  432. this.roleAuths(item.RoleId);
  433. },
  434. //用户组选中回调
  435. getUserGroup (arr) {
  436. const datas = [];
  437. arr.forEach(item => {
  438. datas.push(item.GroupId);
  439. })
  440. this.GroupIds = datas;
  441. },
  442. //账号组点击回调
  443. checkGroup (item) {
  444. this.groupAuths(item.GroupId)
  445. },
  446. //根据角色查看权限列表
  447. async roleAuths (id) {
  448. try {
  449. let params = {
  450. RoleId: id
  451. };
  452. const res = await RoleAuths(params);
  453. if (res.code === 0) {
  454. this.RoleList = res.returnData;
  455. } else {
  456. this.$message.error(res.message);
  457. }
  458. } catch (error) {
  459. console.log("出错了", error);
  460. }
  461. },
  462. //账号列表选取
  463. accountChange (arr) {
  464. this.checkBoxList = arr;
  465. },
  466. //角色选取
  467. checkChange (arr) {
  468. this.checkRoles = arr;
  469. this.onCheckedArr = arr;
  470. },
  471. //获取权限规则
  472. getData (obj) {
  473. this.rulesObj = obj;
  474. },
  475. //获取登录策略回调
  476. getCheckedList (arr) {
  477. this.loginCheckBoxs = arr;
  478. },
  479. //保存
  480. saveBtn (formName) {
  481. this.$refs[formName].validate((valid) => {
  482. if (valid) {
  483. this.saveOrgan();
  484. } else {
  485. console.log("error submit!!");
  486. return false;
  487. }
  488. });
  489. },
  490. //组织新增保存
  491. async saveOrgan () {
  492. try {
  493. if (this.JobId) {
  494. if (!this.AppId) {
  495. this.$message.error("请选中一个组织后再新增");
  496. return false;
  497. }
  498. } else {
  499. this.AppId = this.oldOrganId
  500. }
  501. const datas = [];
  502. const checks = [];
  503. const GroupIds = [];
  504. if (this.checkTrees.length) {
  505. this.checkTrees.forEach((item) => {
  506. datas.push(item.AuthList);
  507. });
  508. }
  509. if (this.GroupIds.length) {
  510. this.GroupIds.forEach(item => {
  511. const obj = {
  512. GroupId: item
  513. }
  514. GroupIds.push(obj);
  515. });
  516. }
  517. if (this.checkRoles.length) {
  518. this.checkRoles.forEach(item => {
  519. item.IsSelected = 1;
  520. checks.push(item);
  521. });
  522. }
  523. const res = await newstaffmod({
  524. OfficerName: this.form.name,
  525. OfficerDesc: this.form.app,
  526. OfficerLoginName: this.form.loginName,
  527. OfficerPwd: this.form.loginPwd,
  528. RoleList: checks.length ? checks : [],
  529. AuthList: this.openRole ? [] : datas,
  530. TacList: this.loginCheckBoxs,
  531. DepJobList: this.lessChecksData,
  532. GroupList: GroupIds.length ? GroupIds : [],
  533. JobId: this.JobId,
  534. Status: Number(this.Status),
  535. OrganId: this.AppId,
  536. OfficerId: this.OfficerId,
  537. UserList: this.OpenAuthData ? this.checkBoxList : []
  538. });
  539. if (res.code === 0) {
  540. this.$message.success(res.message);
  541. this.$store.dispatch("tagsView/delView", this.$route);
  542. this.$router.push("/staff");
  543. } else {
  544. this.$message.error(res.message);
  545. }
  546. } catch (error) {
  547. console.log("出错了", error);
  548. }
  549. },
  550. reSetPassWord () {
  551. const { PwdLengthBegin, PwdLengthEnd, PwdStruc } =
  552. typeof this.systemSet === "string"
  553. ? JSON.parse(this.systemSet)
  554. : this.systemSet; //1是请求角色 0是请求用户
  555. this.form.loginPwd = pwdProduce(PwdLengthBegin, PwdLengthEnd, PwdStruc);
  556. },
  557. }
  558. }
  559. </script>
  560. <style lang="scss" scoped>
  561. .authorityPower {
  562. padding: 0 64px;
  563. padding-top: 32px;
  564. }
  565. .addApp-form {
  566. background: #ffffff;
  567. box-shadow: 0px 6px 7px 0px rgba(0, 0, 0, 0.06);
  568. border-radius: 16px;
  569. padding: 32px 32px 40px 32px;
  570. .title {
  571. font-size: 24px;
  572. font-family: Microsoft YaHei;
  573. font-weight: bold;
  574. color: #303133;
  575. .isqy {
  576. span {
  577. font-weight: 400;
  578. font-size: 14px;
  579. margin: 0 28px 0 42px;
  580. }
  581. }
  582. }
  583. .addApp-form-content {
  584. margin-top: 40px;
  585. ::v-deep .form {
  586. .el-form-item {
  587. margin-bottom: 0;
  588. margin-right: 40px;
  589. &:last-child {
  590. margin-right: 0;
  591. }
  592. }
  593. .el-input__inner {
  594. height: 32px;
  595. line-height: 32px;
  596. min-width: 184px;
  597. }
  598. .content {
  599. .el-form-item__content {
  600. flex: 1;
  601. }
  602. .el-form-item__label {
  603. margin-left: 27px;
  604. }
  605. }
  606. }
  607. }
  608. }
  609. .power-content {
  610. margin-top: 24px;
  611. min-height: 68vh;
  612. .part {
  613. height: 750px;
  614. }
  615. }
  616. </style>