staffAdd.vue 18 KB

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