index.vue 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900
  1. <template>
  2. <div class="admin-user">
  3. <el-form :inline="true">
  4. <el-form-item v-if="$permission('/admin/user/check')">
  5. <el-input
  6. v-model="queryParams.name"
  7. size="small"
  8. placeholder="请输入"
  9. ></el-input>
  10. </el-form-item>
  11. <el-form-item class="tenant" v-if="userinfo.rList?(userinfo.rList.filter(item=>item.roleId==1))[0]:''">
  12. <el-select v-model="queryParams.tenant" @change="getList2" clearable placeholder="根据租户查询">
  13. <el-option
  14. v-for="item in tenantList"
  15. :key="item.id"
  16. :label="item.name"
  17. :value="item.id">
  18. </el-option>
  19. </el-select>
  20. </el-form-item>
  21. <!-- <el-form-item label="用户名">
  22. <el-input v-model="queryParams.name" size="small" placeholder="请输入用户名"></el-input>
  23. </el-form-item> -->
  24. <el-form-item>
  25. <el-button type="" size="small" @click="getList2" v-if="$permission('/admin/user/check')">查询</el-button>
  26. <el-button type="primary" size="small" @click="handleAdd()" v-if="$permission('/admin/user/add')">新增</el-button
  27. >
  28. </el-form-item>
  29. </el-form>
  30. <el-table
  31. v-loading="loading"
  32. :data="tableData"
  33. border
  34. header-row-class-name="custom-table-header"
  35. >
  36. <el-table-column
  37. type="index"
  38. label="#"
  39. width="55"
  40. align="center"
  41. >
  42. <template slot-scope="scope">
  43. <span>{{ (scope.$index + 1) + ((queryParams.current - 1) * queryParams.size) }}</span>
  44. </template>
  45. </el-table-column>
  46. <el-table-column
  47. prop="name"
  48. label="姓名"
  49. align="center"
  50. show-overflow-tooltip
  51. ></el-table-column>
  52. <el-table-column
  53. prop="username"
  54. label="账号"
  55. align="center"
  56. show-overflow-tooltip
  57. ></el-table-column>
  58. <el-table-column label="性别" align="center" show-overflow-tooltip>
  59. <template slot-scope="scope">
  60. <span>{{ genderObj[scope.row.gender] }}</span>
  61. </template>
  62. </el-table-column>
  63. <el-table-column
  64. prop="email"
  65. label="邮箱"
  66. align="center"
  67. show-overflow-tooltip
  68. ></el-table-column>
  69. <el-table-column
  70. prop="mobile"
  71. label="联系方式"
  72. align="center"
  73. show-overflow-tooltip
  74. ></el-table-column>
  75. <el-table-column
  76. prop="tenantName"
  77. label="所属租户"
  78. align="center"
  79. show-overflow-tooltip
  80. ></el-table-column>
  81. <el-table-column label="是否启用" align="center" show-overflow-tooltip>
  82. <template slot-scope="scope">
  83. <span v-if="scope.row.state == 0">否</span>
  84. <span v-if="scope.row.state == 1">是</span>
  85. </template>
  86. </el-table-column>
  87. <el-table-column
  88. prop="remark"
  89. label="备注"
  90. align="center"
  91. show-overflow-tooltip
  92. ></el-table-column>
  93. <el-table-column label="操作" align="center" width="150">
  94. <template slot-scope="scope">
  95. <el-dropdown split-button type="primary" size="small" >
  96. <p @click="handleEdit(scope.row)" v-if="$permission('/admin/user/modify')">编辑</p>
  97. <p v-else :disabled="true">编辑</p>
  98. <el-dropdown-menu slot="dropdown" class="text-align_center">
  99. <!-- <el-dropdown-item @click.native="handleDetails(scope.row)" divided v-if="$permission('/admin/user/detail')">人员详情</el-dropdown-item> -->
  100. <el-dropdown-item @click.native="handleReset(scope.row)" v-if="$permission('/admin/user/reset')">重置密码</el-dropdown-item>
  101. <el-dropdown-item class="color-red" @click.native="handleDelete(scope.row)" divided v-if="$permission('/admin/user/delete')">删除</el-dropdown-item>
  102. </el-dropdown-menu>
  103. </el-dropdown>
  104. </template>
  105. </el-table-column>
  106. </el-table>
  107. <div class="pagination">
  108. <el-pagination
  109. :current-page.sync="queryParams.current"
  110. :page-size="queryParams.size"
  111. :total="total"
  112. @current-change="handleCurrentChange"
  113. layout="total, prev, pager, next, jumper"
  114. background
  115. ></el-pagination>
  116. </div>
  117. <el-dialog
  118. :title="title"
  119. :visible.sync="visible"
  120. width="700px"
  121. :before-close="close"
  122. >
  123. <el-form
  124. v-if="visible"
  125. :model="ruleForm"
  126. :rules="rules"
  127. ref="ruleForm"
  128. label-width="100px"
  129. label-position="left"
  130. >
  131. <el-row :gutter="24">
  132. <el-col :span="12">
  133. <el-form-item label="姓名" prop="name">
  134. <el-input
  135. v-model="ruleForm.name"
  136. placeholder="请输入姓名"
  137. ></el-input>
  138. </el-form-item>
  139. </el-col>
  140. <el-col :span="12">
  141. <el-form-item label="性别" prop="gender">
  142. <el-select
  143. v-model="ruleForm.gender"
  144. class="width_100"
  145. placeholder="请选择"
  146. >
  147. <el-option
  148. v-for="(item, key) in genderObj" :key="key"
  149. :label="item"
  150. :value="parseInt(key)"
  151. ></el-option>
  152. </el-select>
  153. </el-form-item>
  154. </el-col>
  155. </el-row>
  156. <el-row :gutter="24">
  157. <el-col :span="12">
  158. <el-form-item label="邮箱" prop="email">
  159. <el-input
  160. v-model="ruleForm.email"
  161. placeholder="请输入邮箱"
  162. ></el-input>
  163. </el-form-item>
  164. </el-col>
  165. <el-col :span="12">
  166. <el-form-item label="联系方式" prop="mobile">
  167. <el-input
  168. v-model="ruleForm.mobile"
  169. placeholder="请输入联系方式"
  170. ></el-input>
  171. </el-form-item>
  172. </el-col>
  173. </el-row>
  174. <el-row :gutter="24">
  175. <el-col :span="12">
  176. <el-form-item label="QQ号" prop="qqNumber">
  177. <el-input
  178. type="text"
  179. v-model="ruleForm.qqNumber"
  180. placeholder="请输入QQ号"
  181. @input="change($event)"
  182. ></el-input>
  183. </el-form-item>
  184. </el-col>
  185. <el-col :span="12">
  186. <el-form-item label="微信号" prop="wechat">
  187. <el-input
  188. v-model="ruleForm.wechat"
  189. placeholder="请输入微信号"
  190. ></el-input>
  191. </el-form-item>
  192. </el-col>
  193. </el-row>
  194. <el-row :gutter="24">
  195. <el-col :span="12">
  196. <el-form-item label="钉钉号" prop="nail">
  197. <el-input
  198. v-model="ruleForm.nail"
  199. placeholder="请输入钉钉号"
  200. ></el-input>
  201. </el-form-item>
  202. </el-col>
  203. <el-col :span="12">
  204. <el-form-item label="所属租户" prop="tenant">
  205. <!-- <el-tooltip
  206. class="item"
  207. effect="dark"
  208. :disabled="!ruleForm.tenantName"
  209. :content="ruleForm.tenantName"
  210. placement="top-start"
  211. >
  212. <el-input
  213. v-model="ruleForm.tenantName"
  214. placeholder="请输入所属租户"
  215. :readonly="true"
  216. ></el-input>
  217. </el-tooltip> -->
  218. <el-select v-model="ruleForm.tenant" :disabled="(userinfo.rList?!(userinfo.rList.filter(item=>item.roleId==1))[0]:'')||disabled" placeholder="请选择">
  219. <el-option
  220. v-for="item in tenantList"
  221. :key="item.id"
  222. :label="item.name"
  223. :value="item.id">
  224. </el-option>
  225. </el-select>
  226. </el-form-item>
  227. </el-col>
  228. </el-row>
  229. <el-row :gutter="24">
  230. <el-col :span="24">
  231. <el-form-item label="职位[部门]" prop="nail">
  232. <template>
  233. <el-col :span="11" style="padding-left: 0">
  234. <el-form-item label-width="0" prop="position">
  235. <el-tooltip
  236. class="item"
  237. effect="dark"
  238. :disabled="!labelVal"
  239. :content="labelVal"
  240. placement="top-start"
  241. >
  242. <el-cascader
  243. ref="deptIdCascader"
  244. v-model="positionAndDepartment.department"
  245. :options="departmentList"
  246. :show-all-levels="false"
  247. :props="{
  248. checkStrictly: true,
  249. value: 'id',
  250. label: 'name',
  251. }"
  252. clearable
  253. @change="handleChange"
  254. placeholder="请选择部门"
  255. >
  256. </el-cascader>
  257. </el-tooltip>
  258. </el-form-item>
  259. </el-col>
  260. <el-col :span="11" style="padding-left: 0">
  261. <el-form-item
  262. label-width="0"
  263. label-height="82"
  264. label-line-height="82px"
  265. prop="position"
  266. >
  267. <el-select
  268. v-model="positionAndDepartment.position"
  269. filterable
  270. placeholder="请选择职位"
  271. >
  272. <el-option
  273. v-for="item in positionList"
  274. :key="item.name"
  275. :label="item.position"
  276. :value="item.id"
  277. ></el-option>
  278. </el-select>
  279. </el-form-item>
  280. </el-col>
  281. <el-col :span="2">
  282. <el-button
  283. type="primary"
  284. size="mini"
  285. @click="showInputLabel"
  286. circle
  287. icon="el-icon-plus"
  288. ></el-button>
  289. </el-col>
  290. <el-col :span="24" style="padding-left: 0; margin: 10px 0 0 0">
  291. <template>
  292. <div
  293. style="
  294. width: 100%;
  295. height: 75px;
  296. border: 1px solid #c0c0c0;
  297. border-radius: 4px;
  298. overflow: auto;
  299. "
  300. >
  301. <el-tag
  302. v-for="(tag, index) in ruleForm.positions"
  303. :key="index"
  304. closable
  305. :disable-transitions="false"
  306. @close="handleClose(index)"
  307. >
  308. <span
  309. >{{ tag.positionName }}<span v-if="tag.departmentName">[{{
  310. tag.departmentName
  311. }}]</span></span
  312. >
  313. </el-tag>
  314. </div>
  315. </template>
  316. </el-col>
  317. </template>
  318. </el-form-item>
  319. </el-col>
  320. </el-row>
  321. <el-row :gutter="24">
  322. <el-col :span="12">
  323. <el-form-item label="所属用户组" prop="group">
  324. <el-select
  325. v-model="ruleForm.group"
  326. multiple
  327. collapse-tags
  328. placeholder="请选择用户组"
  329. >
  330. <el-option
  331. v-for="item in groupList"
  332. :key="item.id"
  333. :label="item.name"
  334. :value="item.id"
  335. >
  336. </el-option>
  337. </el-select>
  338. </el-form-item>
  339. </el-col>
  340. <el-col :span="12">
  341. <el-form-item label="所属角色" prop="role" class="role">
  342. <el-select
  343. v-model="ruleForm.role"
  344. multiple
  345. collapse-tags
  346. placeholder="请选择所属角色"
  347. >
  348. <el-option
  349. v-for="item in roleList"
  350. :key="item.id"
  351. :label="item.name"
  352. :value="item.id"
  353. :disabled="item.disabled"
  354. >
  355. </el-option>
  356. </el-select>
  357. </el-form-item>
  358. </el-col>
  359. </el-row>
  360. <el-row :gutter="24">
  361. <el-col :span="12">
  362. <el-form-item label="账号" prop="username">
  363. <el-input
  364. v-model="ruleForm.username"
  365. placeholder="请输入账号"
  366. ></el-input>
  367. </el-form-item>
  368. </el-col>
  369. <el-col :span="12">
  370. <el-form-item v-if="pswdshow" label="密码" prop="password">
  371. <el-input
  372. v-model="ruleForm.password"
  373. placeholder="请输入密码"
  374. ></el-input>
  375. </el-form-item>
  376. </el-col>
  377. <el-col :span="12">
  378. <el-form-item label="是否启用" prop="state">
  379. <el-switch
  380. :active-value="1"
  381. :inactive-value="0"
  382. v-model="ruleForm.state"
  383. active-color="#13ce66"
  384. inactive-color="#ff4949"
  385. >
  386. </el-switch>
  387. <!-- <el-input v-model="ruleForm.state" placeholder="请输入状态" type="textarea"></el-input> -->
  388. </el-form-item>
  389. </el-col>
  390. </el-row>
  391. <el-form-item label="备注" prop="remark">
  392. <el-input
  393. v-model="ruleForm.remark"
  394. placeholder="请输入备注"
  395. type="textarea"
  396. maxlength="100"
  397. show-word-limit
  398. ></el-input>
  399. </el-form-item>
  400. </el-form>
  401. <div slot="footer" class="dialog-footer">
  402. <el-button @click="close">取 消</el-button>
  403. <el-button type="primary" @click="submit" :loading="btnLoading"
  404. >确 定</el-button
  405. >
  406. </div>
  407. </el-dialog>
  408. <el-dialog
  409. :title="title"
  410. :visible.sync="showvisible"
  411. width="700px"
  412. class="my-dialog-name"
  413. contentStyle="width:400px;"
  414. :before-close="close"
  415. v-if="ruleForm.apply != null"
  416. >
  417. <el-form
  418. label-position="left"
  419. class="demo-table-expand"
  420. label-width="80px"
  421. >
  422. <el-form-item label="账号 :" class="marginB">
  423. <span>{{ ruleForm.apply.username }}</span>
  424. </el-form-item>
  425. <el-form-item label="姓名 :" class="marginB">
  426. <span>{{ ruleForm.apply.remark }}</span>
  427. </el-form-item>
  428. <el-form-item label="性别 :" class="marginB">
  429. <span>{{ ruleForm.apply.gender === 1 ? "男" : "女" }}</span>
  430. </el-form-item>
  431. <el-form-item label="邮箱 :" class="marginB">
  432. <span>{{ ruleForm.apply.email }}</span>
  433. </el-form-item>
  434. <el-form-item label="联系方式 :" class="marginB">
  435. <span>{{ ruleForm.apply.mobile }}</span>
  436. </el-form-item>
  437. <el-form-item label="QQ号 :" class="marginB">
  438. <span>{{ ruleForm.apply.qqNumber }}</span>
  439. </el-form-item>
  440. <el-form-item label="微信号 :" class="marginB">
  441. <span>{{ ruleForm.apply.mobile }}</span>
  442. </el-form-item>
  443. <el-form-item label="钉钉号 :" class="marginB">
  444. <span>{{ ruleForm.apply.nail }}</span>
  445. </el-form-item>
  446. <el-form-item label="所属租户 :" class="marginB">
  447. <span>{{ ruleForm.apply.tenantName }}</span>
  448. </el-form-item>
  449. <el-form-item label="用户组 :" class="marginB">
  450. <span v-for="item in ruleForm.apply.groupList">{{ item.name }}</span>
  451. </el-form-item>
  452. <el-form-item label="所属角色 :" class="marginB">
  453. <span v-for="item in ruleForm.apply.roleList">{{ item.name }}</span>
  454. </el-form-item>
  455. <!-- <el-form-item label="账号 :" class="marginB">
  456. <span>{{ ruleForm.apply.nail }}</span>
  457. </el-form-item> -->
  458. <el-form-item label="是否启用 :" class="marginB">
  459. <span>{{ ruleForm.apply.state === 1 ? "已启用" : "未启用" }}</span>
  460. </el-form-item>
  461. <el-form-item label="备注 :" class="marginB">
  462. <span>{{ ruleForm.apply.remark }}</span>
  463. </el-form-item>
  464. </el-form>
  465. </el-dialog>
  466. </div>
  467. </template>
  468. <script>
  469. import Treeselect from "@riophae/vue-treeselect"
  470. import "@riophae/vue-treeselect/dist/vue-treeselect.css"
  471. export default {
  472. components: {
  473. Treeselect
  474. },
  475. data() {
  476. const isMobile = (rule, value, callback) => {
  477. if (value) {
  478. var reg = /(^((\+86)|(86))?(1[3-9])\d{9}$)|(^(0\d{2,3})-?(\d{7,8})$)/
  479. var re = new RegExp(reg)
  480. if (re.test(value)) {
  481. callback()
  482. } else {
  483. callback(new Error('输入的手机号码格式不正确,请重新输入'))
  484. }
  485. } else {
  486. callback()
  487. }
  488. };
  489. const isPassword = (rule, value, callback) => {
  490. if (value) {
  491. let reg = /^(?=.*\d)(?=.*[a-z])(?=.*[A-Z])(?=.*[`~!#$%^&*()_\-+=<>?:\"{}|,.\/;'\\[\]·!@¥……()——【】、:;‘’“”,。/《》? ]).{6,}$/
  492. let re = new RegExp(reg)
  493. if (re.test(value)) {
  494. callback()
  495. } else {
  496. callback(new Error('密码必须包含大小写字母、数字、特殊字符且长度至少为六位的组合'))
  497. }
  498. } else {
  499. callback(new Error('请输入密码'))
  500. }
  501. };
  502. return {
  503. disabled:false,
  504. pswdshow: false,
  505. showvisible: false,
  506. visible: false,
  507. loading: false,
  508. btnLoading: false,
  509. total: 0,
  510. tableData: [],
  511. tenantList:[],
  512. title: "",
  513. roleList: [
  514. {
  515. value: "选项1",
  516. label: "黄金糕",
  517. },
  518. {
  519. value: "选项2",
  520. label: "双皮奶",
  521. },
  522. {
  523. value: "选项3",
  524. label: "蚵仔煎",
  525. },
  526. {
  527. value: "选项4",
  528. label: "龙须面",
  529. },
  530. {
  531. value: "选项5",
  532. label: "北京烤鸭",
  533. },
  534. ],
  535. queryParams: {
  536. size: 10,
  537. current: 1,
  538. // username: '',
  539. departmentIds: [],
  540. positionIds:[],
  541. name: "",
  542. tenant:''
  543. },
  544. labelVal: "",
  545. departmentList: [],
  546. positionList: [],
  547. groupList: [],
  548. roleList: [],
  549. genderObj: {
  550. 0: "女",
  551. 1: "男",
  552. },
  553. positionAndDepartment: {},
  554. // departmentList: [],
  555. ruleForm: {},
  556. rules: {
  557. name: [{ required: true, message: "请输入姓名", trigger: "blur" }],
  558. username: [{ required: true, message: "请输入账号", trigger: "blur" }],
  559. password: [{ required: true, validator:isPassword, trigger: "blur" }],
  560. mobile: [
  561. { required: false, validator:isMobile, trigger: "blur" },
  562. // {
  563. // pattern:
  564. // /(^((\+86)|(86))?(1[3-9])\d{9}$)|(^(0\d{2,3})-?(\d{7,8})$)/,
  565. // message: "输入的手机号码格式不正确,请重新输入",
  566. // trigger: "blur",
  567. // },
  568. ],
  569. email: [
  570. { required: true, message: "请输入邮箱", trigger: "blur" },
  571. {
  572. pattern:
  573. /^([a-zA-Z0-9_\.\-])+\@(([a-zA-Z0-9_\.\-])+\.)+([a-zA-Z0-9]{2,4})+$/,
  574. message: "请输入正确的邮箱格式",
  575. trigger: "blur",
  576. },
  577. ],
  578. sex: [{ required: true, message: "请选择性别", trigger: "change" }],
  579. // position: [{ required: true, message: '请选择职位', trigger: 'change' },],
  580. // department: [{ required: true, message: '请选择部门', trigger: 'change' },],
  581. state: [{ required: true, message: "请选择", trigger: "change" }],
  582. tenant:[{ required: true, message: "请选择", trigger: "change" }],
  583. },
  584. };
  585. },
  586. watch: {
  587. "positionAndDepartment.department"() {
  588. if (this.$refs.deptIdCascader) {
  589. this.$refs.deptIdCascader.dropDownVisible = false;
  590. }
  591. },
  592. "ruleForm.email"(val) {
  593. // console.log(val)
  594. if (val.indexOf("@qq.com") != -1) {
  595. var index = val.indexOf("@qq.com");
  596. var str = val.substring(0, index);
  597. this.ruleForm.qqNumber = str;
  598. } else if (val.indexOf("@qq.com") == -1) {
  599. }
  600. },
  601. },
  602. computed: {
  603. userinfo() {
  604. return this.$store.state.admin.userinfo;
  605. },
  606. },
  607. mounted() {
  608. this.getList();
  609. this.getDepartment();
  610. this.getPositionList();
  611. this.getGroupList();
  612. this.getRoleList();
  613. this.getTenantList()
  614. },
  615. methods: {
  616. //根据条件查询
  617. getList2(){
  618. this.queryParams.current=1
  619. this.getList()
  620. },
  621. change(e) {
  622. this.$forceUpdate();
  623. },
  624. // getqqNumber(val){
  625. // if(val.indexOf('@qq.com')){
  626. // var index = val.indexOf('@qq.com')
  627. // var str = val.substring(0,index)
  628. // this.ruleForm.qqNumber=str
  629. // console.log(this.ruleForm.qqNumber,str)
  630. // }else{
  631. // this.ruleForm.qqNumber=''
  632. // }
  633. // },
  634. handleClose(index) {
  635. this.ruleForm.positions.splice(index, 1);
  636. },
  637. handleChange(val) {
  638. // console.log(val)
  639. let res = this.getVal(val, this.departmentList, []);
  640. this.labelVal = res.join("/");
  641. },
  642. getVal(data, options, arr) {
  643. options.forEach((e) => {
  644. if(data){
  645. data.forEach((i) => {
  646. if (i == e.id) {
  647. arr.push(e.name || e.position);
  648. return;
  649. } else {
  650. if (e.children) {
  651. this.getVal([i], e.children, arr);
  652. } else {
  653. return;
  654. }
  655. }
  656. });
  657. }
  658. });
  659. return arr;
  660. },
  661. normalizer(node) {
  662. if (node.children && !node.children.length) {
  663. delete node.children;
  664. }
  665. return {
  666. id: node.id,
  667. label: node.name,
  668. children: node.children,
  669. };
  670. },
  671. handleAdd() {
  672. this.disabled=false
  673. this.title = "新增人员";
  674. this.pswdshow = true;
  675. this.visible = true;
  676. this.ruleForm = {
  677. tenant:this.userinfo.tenantId,
  678. gender: 0,
  679. state: 1,
  680. positions: [],
  681. email:''
  682. };
  683. },
  684. handleEdit(row) {
  685. this.disabled=true
  686. this.title = "编辑人员";
  687. this.pswdshow = false;
  688. this.visible = true;
  689. // this.ruleForm = { ...row };
  690. this.ruleForm =JSON.parse(JSON.stringify(row));
  691. },
  692. handleDetails(row) {
  693. this.title = "人员详情";
  694. this.showvisible = true;
  695. this.ruleForm.apply = row;
  696. },
  697. close() {
  698. this.positionAndDepartment = {};
  699. this.pswdshow = false;
  700. this.visible = false;
  701. this.showvisible = false;
  702. },
  703. getDepartment() {
  704. this.$api.getAllDepartmentList().then((response) => {
  705. this.departmentList = response.data;
  706. });
  707. },
  708. getPositionList() {
  709. this.$api.getAllPositionList().then((response) => {
  710. this.positionList = response.data;
  711. });
  712. },
  713. getGroupList() {
  714. this.$api.getAllUserGroupList().then((response) => {
  715. this.groupList = response.data;
  716. });
  717. },
  718. getTenantList(){
  719. this.$api.getAllTenantList().then(response => {
  720. this.tenantList = response.data
  721. })
  722. },
  723. getRoleList() {
  724. this.$api.getAllRoleList().then((response) => {
  725. this.roleList = response.data;
  726. var a = this.userinfo.rList.findIndex((item) => {
  727. return item.roleId == 1;
  728. });
  729. if(a == -1){
  730. var b = this.roleList.findIndex(i=>{
  731. return i.id == 1
  732. })
  733. if(b !=-1){
  734. this.roleList[b].disabled=true
  735. }
  736. }else{
  737. this.roleList[0].disabled=false
  738. }
  739. });
  740. },
  741. showInputLabel() {
  742. // console.log(this.positionAndDepartment.hasOwnProperty('department'))
  743. if(this.positionAndDepartment.hasOwnProperty('department')==true){
  744. var departmentName = this.getVal(
  745. [
  746. this.positionAndDepartment.department[
  747. this.positionAndDepartment.department.length - 1
  748. ],
  749. ],
  750. this.departmentList,
  751. []
  752. );
  753. }else{
  754. this.positionAndDepartment.department=[''],
  755. departmentName=['']
  756. }
  757. var positionName = this.getVal(
  758. [this.positionAndDepartment.position],
  759. this.positionList,
  760. []
  761. );
  762. this.ruleForm.positions.push({
  763. position: this.positionAndDepartment.position,
  764. positionName: positionName[0],
  765. department:
  766. this.positionAndDepartment.department[
  767. this.positionAndDepartment.department.length - 1
  768. ],
  769. departmentName: departmentName[departmentName.length - 1],
  770. });
  771. this.positionAndDepartment = {};
  772. this.labelVal = "";
  773. },
  774. getList() {
  775. this.loading = true;
  776. this.$api
  777. .getPersonnelList(this.queryParams)
  778. .then((response) => {
  779. this.tableData = response.data;
  780. this.total = response.pageColumn.total;
  781. this.loading = false;
  782. })
  783. .catch((error) => {
  784. this.loading = false;
  785. });
  786. },
  787. handleCurrentChange(val) {
  788. this.queryParams.current = val;
  789. this.getList();
  790. },
  791. submit() {
  792. this.$refs.ruleForm.validate((valid) => {
  793. if (valid) {
  794. this.btnLoading = true;
  795. if (this.ruleForm.id) {
  796. this.$api
  797. .editPersonnel(this.ruleForm)
  798. .then((response) => {
  799. this.$message.success("编辑成功");
  800. this.btnLoading = false;
  801. this.getList();
  802. this.close();
  803. })
  804. .catch((error) => {
  805. this.btnLoading = false;
  806. });
  807. } else {
  808. // this.ruleForm.tenant = this.userinfo.tenantId;
  809. this.$api
  810. .addPersonnel(this.ruleForm)
  811. .then((response) => {
  812. if(response.code == 200){
  813. this.$message.success("新增成功");
  814. }else if(response.code == 0){
  815. this.$message.error("新增失败")
  816. }
  817. // console.log(1212)
  818. this.btnLoading = false;
  819. this.getList();
  820. this.close();
  821. })
  822. .catch((error) => {
  823. this.btnLoading = false;
  824. });
  825. }
  826. } else {
  827. // console.log("error submit!!");
  828. return false;
  829. }
  830. });
  831. },
  832. handleReset(row) {
  833. this.$confirm("确认将用户密码重置吗?", "提示", {
  834. confirmButtonText: "确定",
  835. cancelButtonText: "取消",
  836. type: "warning",
  837. }).then(() => {
  838. this.loading = true;
  839. this.$api
  840. .ResetPassword({ userId: row.id })
  841. .then((response) => {
  842. this.$message.success("重置成功");
  843. this.loading = false;
  844. this.getList();
  845. })
  846. .catch((error) => {
  847. this.loading = false;
  848. });
  849. });
  850. },
  851. handleDelete(row) {
  852. this.$confirm("确认删除本条数据吗?", "提示", {
  853. confirmButtonText: "确定",
  854. cancelButtonText: "取消",
  855. type: "warning",
  856. }).then(() => {
  857. this.loading = true;
  858. this.$api
  859. .deletePersonnel({ id: row.id })
  860. .then((response) => {
  861. this.$message.success("删除成功");
  862. this.loading = false;
  863. this.getList();
  864. })
  865. .catch((error) => {
  866. this.loading = false;
  867. });
  868. });
  869. },
  870. },
  871. };
  872. </script>
  873. <style>
  874. </style>
  875. <style lang="scss" scoped>
  876. .el-tag + .el-tag {
  877. margin-left: 10px;
  878. }
  879. .admin-user {
  880. }
  881. .marginB {
  882. margin-bottom: 0;
  883. }
  884. </style>