user.vue 36 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287
  1. <template>
  2. <section
  3. v-loading.fullscreen="loading"
  4. class="content"
  5. element-loading-text="请稍后..."
  6. >
  7. <div class="part-box">
  8. <h2 class="part-box-title">用户管理</h2>
  9. <!-- 搜索 -->
  10. <el-form class="part-filter-form" inline :model="searchForm">
  11. <el-form-item v-if="isSuperAdmin" label="学校">
  12. <el-select
  13. v-model="searchForm.rootOrgId"
  14. placeholder="请选择"
  15. :disabled="!isSuperAdmin"
  16. filterable
  17. @change="rootOrgChanged4Search"
  18. >
  19. <el-option
  20. v-for="item in rootSchoolSelect"
  21. :key="item.id"
  22. :label="item.name"
  23. :value="item.id"
  24. />
  25. </el-select>
  26. </el-form-item>
  27. <el-form-item v-if="!onlySubjectTeacher" label="角色">
  28. <el-select v-model="searchForm.roleId" clearable placeholder="请选择">
  29. <el-option
  30. v-for="item in roleList4Search"
  31. :key="item.roleId"
  32. :label="item.roleName"
  33. :value="item.roleId"
  34. />
  35. </el-select>
  36. </el-form-item>
  37. <el-form-item label="课程">
  38. <el-select
  39. v-model="searchForm.courseId"
  40. class="input"
  41. :remote-method="getCourses4Search"
  42. :loading="courseLoading4Search"
  43. remote
  44. filterable
  45. clearable
  46. placeholder="请选择"
  47. >
  48. <el-option
  49. v-for="item in courseList4Search"
  50. :key="item.id"
  51. :label="item.name + ' - ' + item.code"
  52. :value="item.id"
  53. ></el-option>
  54. </el-select>
  55. </el-form-item>
  56. <el-form-item label="登录名">
  57. <el-input
  58. v-model="searchForm.loginName"
  59. placeholder="请输入登录名"
  60. maxlength="20"
  61. />
  62. </el-form-item>
  63. <el-form-item label="姓名">
  64. <el-input
  65. v-model="searchForm.name"
  66. placeholder="请输入姓名"
  67. maxlength="20"
  68. />
  69. </el-form-item>
  70. <el-form-item label="状态">
  71. <el-select v-model="searchForm.enable" class="input">
  72. <el-option label="未选择" value=""></el-option>
  73. <el-option label="已启用" value="true"></el-option>
  74. <el-option label="已禁用" value="false"></el-option>
  75. </el-select>
  76. </el-form-item>
  77. <el-form-item>
  78. <el-button type="danger" @click="handleSearchBtn"> 查询 </el-button>
  79. <el-button type="danger" plain @click="resetEcsFormSearch">
  80. 重置
  81. </el-button>
  82. </el-form-item>
  83. </el-form>
  84. <div class="part-box-action">
  85. <div>
  86. <el-button
  87. type="success"
  88. plain
  89. icon="icon icon-play"
  90. :disabled="noBatchSelected"
  91. @click="enableByIds"
  92. >启用
  93. </el-button>
  94. <el-button
  95. type="danger"
  96. plain
  97. icon="icon icon-delete"
  98. :disabled="noBatchSelected"
  99. @click="disableByIds"
  100. >禁用
  101. </el-button>
  102. </div>
  103. <div>
  104. <el-button
  105. type="primary"
  106. icon="icon icon-plus-white"
  107. @click="openAddingDialog"
  108. >新增
  109. </el-button>
  110. <el-button
  111. type="primary"
  112. plain
  113. icon="icon icon-import"
  114. @click="impUser"
  115. >导入
  116. </el-button>
  117. </div>
  118. </div>
  119. </div>
  120. <div class="part-box">
  121. <!-- 页面列表 -->
  122. <el-table
  123. ref="table"
  124. :data="tableData"
  125. resizable
  126. @selection-change="selectChange"
  127. >
  128. <el-table-column
  129. type="selection"
  130. width="50"
  131. align="center"
  132. ></el-table-column>
  133. <el-table-column prop="id" width="80" label="ID" />
  134. <el-table-column prop="name" width="120" label="姓名" />
  135. <el-table-column prop="loginName" width="100" label="登录名" />
  136. <el-table-column prop="rootOrgName" label="顶级机构" />
  137. <!-- <el-table-column prop="roleNamesStr" width="110" label="角色" /> -->
  138. <el-table-column width="120" label="角色">
  139. <span
  140. slot-scope="scope"
  141. v-html="scope.row.roleNamesStr.replace(/,/g, '<br />')"
  142. >
  143. </span>
  144. </el-table-column>
  145. <el-table-column width="100" label="审核权限">
  146. <span slot-scope="scope">{{
  147. scope.row.auditAuthority | auditAuthorityFilter
  148. }}</span>
  149. </el-table-column>
  150. <el-table-column width="120" label="关联课程">
  151. <span
  152. slot-scope="scope"
  153. v-html="
  154. scope.row.courseNamesStr &&
  155. scope.row.courseNamesStr.replace(/,/g, '<br />')
  156. "
  157. >
  158. </span>
  159. </el-table-column>
  160. <el-table-column
  161. sortable
  162. prop="updateTime"
  163. width="160"
  164. label="更新时间"
  165. />
  166. <el-table-column width="50" label="状态">
  167. <span slot-scope="scope">
  168. <span v-if="scope.row.enable">
  169. <el-tooltip
  170. class="item"
  171. effect="dark"
  172. content="启用"
  173. placement="left"
  174. >
  175. <i class="icon icon-right"></i>
  176. </el-tooltip>
  177. </span>
  178. <span v-else>
  179. <el-tooltip
  180. class="item"
  181. effect="dark"
  182. content="禁用"
  183. placement="left"
  184. >
  185. <i class="icon icon-error"></i>
  186. </el-tooltip>
  187. </span>
  188. </span>
  189. </el-table-column>
  190. <el-table-column width="170" label="操作">
  191. <div slot-scope="scope">
  192. <div v-if="showBtn(scope.row)">
  193. <el-button
  194. v-if="!scope.row.enable"
  195. size="mini"
  196. type="primary"
  197. plain
  198. @click="enableById(scope.row)"
  199. >
  200. 启用
  201. </el-button>
  202. <el-button
  203. v-if="scope.row.enable"
  204. size="mini"
  205. plain
  206. type="danger"
  207. @click="disableById(scope.row)"
  208. >
  209. 禁用
  210. </el-button>
  211. <el-dropdown>
  212. <el-button type="primary" plain size="mini">
  213. 更多<i class="el-icon-more el-icon--right"></i>
  214. </el-button>
  215. <el-dropdown-menu slot="dropdown" class="action-dropdown">
  216. <el-dropdown-item>
  217. <el-button
  218. v-if="showUserDataRuleSetting(scope.row)"
  219. size="mini"
  220. type="primary"
  221. plain
  222. @click="setPrivilege(scope.row)"
  223. >权限设置
  224. </el-button>
  225. </el-dropdown-item>
  226. <el-dropdown-item>
  227. <el-button
  228. size="mini"
  229. type="primary"
  230. plain
  231. @click="openUpdateDialog(scope.row)"
  232. >编辑
  233. </el-button>
  234. </el-dropdown-item>
  235. <el-dropdown-item>
  236. <el-button
  237. v-if="false"
  238. size="mini"
  239. type="danger"
  240. plain
  241. @click="deleteById(scope.row)"
  242. >删除
  243. </el-button>
  244. </el-dropdown-item>
  245. <el-dropdown-item>
  246. <el-button
  247. size="mini"
  248. type="danger"
  249. plain
  250. @click="resetPass(scope.row)"
  251. >
  252. 重置密码
  253. </el-button>
  254. </el-dropdown-item>
  255. </el-dropdown-menu>
  256. </el-dropdown>
  257. </div>
  258. </div>
  259. </el-table-column>
  260. </el-table>
  261. <div class="part-page">
  262. <el-pagination
  263. :current-page.sync="currentPage"
  264. :page-size.sync="pageSize"
  265. :page-sizes="[10, 20, 50, 100, 200, 300]"
  266. layout="total, sizes, prev, pager, next, jumper"
  267. :total="total"
  268. @current-change="handleCurrentChange"
  269. @size-change="handleSizeChange"
  270. />
  271. </div>
  272. </div>
  273. <!-- 添加用户信息弹出框 -->
  274. <el-dialog
  275. title="新增用户"
  276. width="620px"
  277. :visible.sync="addingDialog"
  278. :modal="false"
  279. :close-on-click-modal="false"
  280. :close-on-press-escape="false"
  281. append-to-body
  282. custom-class="side-dialog"
  283. >
  284. <el-form
  285. ref="addingForm"
  286. inline-message
  287. class="form-tight"
  288. :model="userForm"
  289. :rules="rules"
  290. label-width="80px"
  291. >
  292. <el-form-item label="姓名" prop="name">
  293. <el-input
  294. v-model="userForm.name"
  295. class="dialog-input-width"
  296. auto-complete="off"
  297. placeholder="请输入姓名"
  298. maxlength="20"
  299. />
  300. </el-form-item>
  301. <el-form-item label="登录名" prop="loginName">
  302. <el-input
  303. v-model="userForm.loginName"
  304. class="dialog-input-width"
  305. auto-complete="off"
  306. placeholder="请输入登录名"
  307. maxlength="20"
  308. />
  309. </el-form-item>
  310. <el-form-item label="密码" prop="password">
  311. <el-input
  312. v-model="userForm.password"
  313. class="dialog-input-width"
  314. auto-complete="off"
  315. placeholder="请输入密码"
  316. />
  317. </el-form-item>
  318. <el-form-item v-if="isSuperAdmin" label="学校" prop="rootOrgId">
  319. <el-select
  320. v-model="userForm.rootOrgId"
  321. class="dialog-input-width"
  322. placeholder="请选择"
  323. :disabled="!isSuperAdmin"
  324. filterable
  325. @change="rootOrgChanged4InsertOrUpdate"
  326. >
  327. <el-option
  328. v-for="item in rootSchoolSelect"
  329. :key="item.id"
  330. :label="item.name"
  331. :value="item.id"
  332. >
  333. </el-option>
  334. </el-select>
  335. </el-form-item>
  336. <el-form-item label="角色" prop="roleId">
  337. <el-select
  338. v-model="userForm.roleId"
  339. class="dialog-input-width"
  340. placeholder="请选择"
  341. >
  342. <el-option
  343. v-for="item in roleList4InsertOrUpdateWithoutSuperAdmin"
  344. :key="item.roleId"
  345. :label="item.roleName"
  346. :value="item.roleId"
  347. :disabled="roleDis(item.roleCode)"
  348. >
  349. </el-option>
  350. </el-select>
  351. </el-form-item>
  352. <el-form-item label="状态">
  353. <el-radio-group v-model="enableStr" class="pull_right_sm">
  354. <el-radio label="true">启用</el-radio>
  355. <el-radio label="false">禁用</el-radio>
  356. </el-radio-group>
  357. </el-form-item>
  358. </el-form>
  359. <div slot="footer">
  360. <el-button type="primary" @click="add">保存</el-button>
  361. <el-button type="danger" plain @click="addingDialog = false"
  362. >取消</el-button
  363. >
  364. </div>
  365. </el-dialog>
  366. <!-- 修改用户信息弹出框 -->
  367. <el-dialog
  368. title="编辑用户"
  369. width="620px"
  370. :visible.sync="updateDialog"
  371. :modal="false"
  372. :close-on-click-modal="false"
  373. :close-on-press-escape="false"
  374. append-to-body
  375. custom-class="side-dialog"
  376. >
  377. <el-form
  378. ref="updateForm"
  379. inline-message
  380. class="form-tight"
  381. :model="userForm"
  382. :rules="rules"
  383. label-position="right"
  384. label-width="80px"
  385. >
  386. <el-form-item label="ID">
  387. <el-input
  388. v-model="userForm.id"
  389. class="dialog-input-width"
  390. :disabled="true"
  391. />
  392. </el-form-item>
  393. <el-form-item label="姓名" prop="name">
  394. <el-input
  395. v-model="userForm.name"
  396. class="dialog-input-width"
  397. auto-complete="off"
  398. placeholder="请输入姓名"
  399. maxlength="20"
  400. />
  401. </el-form-item>
  402. <el-form-item label="登录名" prop="loginName">
  403. <el-input
  404. v-model="userForm.loginName"
  405. class="dialog-input-width"
  406. auto-complete="off"
  407. placeholder="请输入登录名"
  408. maxlength="20"
  409. />
  410. </el-form-item>
  411. <el-form-item v-if="isSuperAdmin" label="学校" prop="rootOrgId">
  412. <el-select
  413. v-model="userForm.rootOrgId"
  414. class="dialog-input-width"
  415. placeholder="请选择"
  416. :disabled="true"
  417. >
  418. <el-option
  419. v-for="item in rootSchoolSelect"
  420. :key="item.id"
  421. :label="item.name"
  422. :value="item.id"
  423. >
  424. </el-option>
  425. </el-select>
  426. </el-form-item>
  427. <el-form-item label="角色" prop="roleId">
  428. <el-select
  429. v-model="userForm.roleId"
  430. class="dialog-input-width"
  431. placeholder="请选择"
  432. :disabled="rowIsSuperAdmin"
  433. >
  434. <el-option
  435. v-for="item in roleList4InsertOrUpdate"
  436. :key="item.roleId"
  437. :label="item.roleName"
  438. :disabled="roleDis(item.roleCode)"
  439. :value="item.roleId"
  440. >
  441. </el-option>
  442. </el-select>
  443. </el-form-item>
  444. <el-form-item label="状态">
  445. <el-radio-group
  446. v-model="enableStr"
  447. class="pull_right_sm"
  448. :disabled="rowIsSuperAdmin"
  449. >
  450. <el-radio label="true">启用</el-radio>
  451. <el-radio label="false">禁用</el-radio>
  452. </el-radio-group>
  453. </el-form-item>
  454. </el-form>
  455. <div slot="footer">
  456. <el-button type="primary" @click="update">保存</el-button>
  457. <el-button type="danger" plain @click="updateDialog = false"
  458. >取消</el-button
  459. >
  460. </div>
  461. </el-dialog>
  462. <!-- 导入弹窗 -->
  463. <el-dialog
  464. title="导入用户"
  465. width="520px"
  466. :visible.sync="impDialog"
  467. :modal="false"
  468. :close-on-click-modal="false"
  469. :close-on-press-escape="false"
  470. append-to-body
  471. custom-class="side-dialog"
  472. >
  473. <el-form>
  474. <el-form-item style="margin-left: 20px">
  475. <el-upload
  476. ref="upload"
  477. class="form_left"
  478. accept="application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"
  479. :action="uploadAction"
  480. :headers="uploadHeaders"
  481. :data="uploadData"
  482. :on-success="uploadSuccess"
  483. :on-error="uploadError"
  484. :file-list="fileList"
  485. :auto-upload="false"
  486. :multiple="false"
  487. >
  488. <el-button
  489. slot="trigger"
  490. size="small"
  491. type="primary"
  492. icon="icon icon-search-white"
  493. >
  494. 选择文件
  495. </el-button>
  496. <el-button
  497. size="small"
  498. type="primary"
  499. icon="icon icon-save-white"
  500. @click="submitUpload"
  501. >
  502. 确认上传
  503. </el-button>
  504. <el-button
  505. size="small"
  506. type="primary"
  507. icon="icon icon-delete-white"
  508. @click="removeFile"
  509. >
  510. 清空文件
  511. </el-button>
  512. <el-button
  513. size="small"
  514. type="primary"
  515. icon="icon icon-export-white"
  516. @click="exportFile"
  517. >
  518. 下载模板
  519. </el-button>
  520. <div slot="tip" class="el-upload__tip">只能上传xlsx文件</div>
  521. </el-upload>
  522. </el-form-item>
  523. </el-form>
  524. </el-dialog>
  525. <!-- 导入错误信息列表 -->
  526. <el-dialog title="错误提示" :visible.sync="errDialog" append-to-body>
  527. <div
  528. v-for="errMessage in errMessages"
  529. :key="errMessage.lineNum"
  530. class="text-danger"
  531. >
  532. 第{{ errMessage.lineNum }}行:{{ errMessage.msg }}
  533. </div>
  534. <span slot="footer" class="dialog-footer">
  535. <el-button @click="errDialog = false">确定</el-button>
  536. </span>
  537. </el-dialog>
  538. </section>
  539. </template>
  540. <script>
  541. import { QUESTION_API } from "@/constants/constants.js";
  542. import { mapState } from "vuex";
  543. export default {
  544. name: "User",
  545. data() {
  546. var validateRootOrg = (rule, value, callback) => {
  547. if (0 != value && !value) {
  548. callback(new Error("请选择学校"));
  549. } else {
  550. callback();
  551. }
  552. };
  553. var validateRoles = (rule, value, callback) => {
  554. if (0 != value && !value) {
  555. callback(new Error("请选择角色"));
  556. } else {
  557. callback();
  558. }
  559. };
  560. return {
  561. impDialog: false,
  562. uploadAction: QUESTION_API + "/user/import",
  563. uploadHeaders: {},
  564. uploadData: {},
  565. errMessages: [],
  566. errDialog: false,
  567. fileLoading: false,
  568. fileList: [],
  569. courseList4Search: [],
  570. courseLoading4Search: false,
  571. rolePrivileges: {
  572. user_data_rule_setting: false,
  573. },
  574. loading: false,
  575. orgLoading4InsertOrUpdate: false,
  576. roleList4Search: [],
  577. roleList4InsertOrUpdate: [],
  578. rootOrgList: [],
  579. orgList4InsertOrUpdate: [],
  580. searchForm: {
  581. courseId: "",
  582. name: "",
  583. loginName: "",
  584. enable: "",
  585. rootOrgId: "",
  586. roleId: "",
  587. },
  588. userForm: {
  589. id: null,
  590. name: "",
  591. loginName: "",
  592. password: "",
  593. phoneNumber: "",
  594. enable: true,
  595. rootOrgId: null,
  596. orgId: null,
  597. roleId: null,
  598. },
  599. enableStr: "true",
  600. tempOrgList: [],
  601. userId: "",
  602. selectedUserIds: [],
  603. selectedUserToCopy: null,
  604. tableData: [],
  605. currentPage: 1,
  606. pageSize: 10,
  607. total: 10,
  608. addingDialog: false,
  609. updateDialog: false,
  610. rowIsSuperAdmin: false,
  611. rules: {
  612. name: [
  613. {
  614. required: true,
  615. max: 20,
  616. message: "请输入姓名,最多20字符",
  617. trigger: "blur",
  618. },
  619. ],
  620. loginName: [
  621. {
  622. required: true,
  623. max: 20,
  624. message: "请输入登录名,最多20字符",
  625. trigger: "blur",
  626. },
  627. ],
  628. password: [
  629. {
  630. validator: (rule, value, callback) => {
  631. if (
  632. value &&
  633. (/^([0-9]+|[a-z]+|[A-Z]+)$/.test(value) ||
  634. !/^[a-zA-Z0-9_]+$/.test(value))
  635. ) {
  636. callback(
  637. new Error("密码只能大写字母、小写字母、数字至少两种组成")
  638. );
  639. } else {
  640. callback();
  641. }
  642. },
  643. trigger: "change",
  644. },
  645. {
  646. required: true,
  647. min: 8,
  648. max: 16,
  649. message: "密码只能8-16个字符",
  650. trigger: "change",
  651. },
  652. ],
  653. phoneNumber: [
  654. // {
  655. // message: "请输入联系方式",
  656. // trigger: "blur"
  657. // }
  658. ],
  659. rootOrgId: [
  660. {
  661. validator: validateRootOrg,
  662. trigger: "blur",
  663. },
  664. ],
  665. orgId: [],
  666. roleId: [
  667. {
  668. required: true,
  669. validator: validateRoles,
  670. trigger: ["blur", "change"],
  671. },
  672. ],
  673. },
  674. };
  675. },
  676. computed: {
  677. ...mapState({
  678. user: (state) => state.user,
  679. }),
  680. userIds() {
  681. var userIds = "";
  682. for (let userId of this.selectedUserIds) {
  683. if (!userIds) {
  684. userIds += userId;
  685. } else {
  686. userIds += "," + userId;
  687. }
  688. }
  689. return userIds;
  690. },
  691. noBatchSelected() {
  692. return this.selectedUserIds.length === 0;
  693. },
  694. roleList4InsertOrUpdateWithoutSuperAdmin() {
  695. return this.roleList4InsertOrUpdate.filter(
  696. (item) => item.roleCode != "SUPER_ADMIN"
  697. );
  698. },
  699. isSubjectTeacher() {
  700. return this.user.roleList.some(
  701. (role) => role.roleCode == "SUBJECT_TEACHER"
  702. );
  703. },
  704. onlySubjectTeacher() {
  705. if (this.isAdmin) {
  706. return false;
  707. } else {
  708. return this.user.roleList.some(
  709. (role) => role.roleCode == "SUBJECT_TEACHER"
  710. );
  711. }
  712. },
  713. isSuperAdmin() {
  714. return this.user.roleList.some((role) => role.roleCode == "SUPER_ADMIN");
  715. },
  716. isAdmin() {
  717. return this.user.roleList.some(
  718. (role) => role.roleCode == "SUPER_ADMIN" || role.roleCode == "ADMIN"
  719. );
  720. },
  721. rootSchoolSelect() {
  722. let rootSchools = [];
  723. for (let i = 0; i < this.rootOrgList.length; i++) {
  724. let info = {
  725. name: this.rootOrgList[i].name + "(" + this.rootOrgList[i].id + ")",
  726. id: this.rootOrgList[i].id,
  727. };
  728. rootSchools.push(info);
  729. }
  730. return rootSchools;
  731. },
  732. },
  733. //初始化查询
  734. created() {
  735. this.initPrivileges();
  736. this.init();
  737. this.uploadHeaders = {
  738. key: this.user.key,
  739. token: this.user.token,
  740. };
  741. },
  742. methods: {
  743. roleDis(code) {
  744. if (this.onlySubjectTeacher && code != "ASSIGN_TEACHER") {
  745. return true;
  746. } else {
  747. return false;
  748. }
  749. },
  750. impUser() {
  751. this.impDialog = true;
  752. this.initUpload();
  753. },
  754. initUpload() {
  755. this.fileList = [];
  756. },
  757. uploadSuccess(response) {
  758. if (!response.hasError) {
  759. this.$notify({
  760. message: "上传成功",
  761. type: "success",
  762. });
  763. this.fileLoading = false;
  764. this.impDialog = false;
  765. this.searchForm();
  766. } else {
  767. this.fileLoading = false;
  768. this.impDialog = false;
  769. this.errMessages = response.failRecords;
  770. this.errDialog = true;
  771. }
  772. },
  773. uploadError(response) {
  774. var json = JSON.parse(response.message);
  775. if (response.status == 500) {
  776. this.$notify({
  777. message: json.desc,
  778. type: "error",
  779. });
  780. }
  781. this.fileLoading = false;
  782. },
  783. //确定上传
  784. submitUpload() {
  785. if (!this.checkUpload()) {
  786. return false;
  787. }
  788. this.$refs.upload.submit();
  789. this.fileLoading = true;
  790. },
  791. checkUpload() {
  792. var fileList = this.$refs.upload.uploadFiles;
  793. if (fileList.length == 0) {
  794. this.$notify({
  795. message: "上传文件不能为空",
  796. type: "error",
  797. });
  798. return false;
  799. }
  800. if (fileList.length > 1) {
  801. this.$notify({
  802. message: "每次只能上传一个文件",
  803. type: "error",
  804. });
  805. return false;
  806. }
  807. for (let file of fileList) {
  808. if (!file.name.endsWith(".xlsx")) {
  809. this.$notify({
  810. message: "上传文件必须为xlsx格式",
  811. type: "error",
  812. });
  813. this.initUpload();
  814. return false;
  815. }
  816. }
  817. return true;
  818. },
  819. //清空文件
  820. removeFile() {
  821. // this.fileList = [];
  822. this.$refs.upload.clearFiles();
  823. },
  824. //下载模板
  825. exportFile() {
  826. window.location.href =
  827. QUESTION_API +
  828. "/user/importTemplate?$key=" +
  829. this.user.key +
  830. "&$token=" +
  831. this.user.token;
  832. },
  833. getCourses4Search(query) {
  834. this.courseLoading4Search = true;
  835. this.$httpWithMsg
  836. .get(QUESTION_API + "/course/query?name=" + query)
  837. .then((response) => {
  838. this.courseList4Search = response.data;
  839. this.courseLoading4Search = false;
  840. });
  841. },
  842. resetEcsFormSearch() {
  843. this.searchForm = Object.assign(this.searchForm, {
  844. roleId: "",
  845. loginName: "",
  846. name: "",
  847. enable: "",
  848. });
  849. },
  850. handleSizeChange(val) {
  851. this.currentPage = 1;
  852. this.pageSize = val;
  853. this.search();
  854. },
  855. validateOrg(rule, value, callback) {
  856. if (0 != value && !value) {
  857. callback(new Error("请选择子机构"));
  858. } else {
  859. callback();
  860. }
  861. },
  862. rootOrgChanged4Search() {
  863. var url =
  864. QUESTION_API +
  865. "/rolePrivilege/getRoles?includeSuperAdmin=" +
  866. true +
  867. "&rootOrgId=" +
  868. this.searchForm.rootOrgId;
  869. this.$httpWithMsg.post(url).then((response) => {
  870. this.roleList4Search = response.data;
  871. });
  872. },
  873. rootOrgChanged4InsertOrUpdate() {
  874. this.orgList4InsertOrUpdate = [];
  875. var url =
  876. QUESTION_API +
  877. "/rolePrivilege/getRoles?rootOrgId=" +
  878. this.userForm.rootOrgId;
  879. this.$httpWithMsg.post(url).then((response) => {
  880. this.roleList4InsertOrUpdate = response.data;
  881. });
  882. },
  883. getOrgList4InsertOrUpdate(query) {
  884. this.orgLoading4InsertOrUpdate = true;
  885. var url =
  886. QUESTION_API +
  887. "/org/query?" +
  888. new URLSearchParams({
  889. name: query,
  890. rootOrgId: this.userForm.rootOrgId,
  891. });
  892. this.$httpWithMsg
  893. .get(url)
  894. .then((response) => {
  895. this.orgList4InsertOrUpdate = response.data;
  896. this.orgLoading4InsertOrUpdate = false;
  897. })
  898. .catch(() => {
  899. this.orgLoading4InsertOrUpdate = false;
  900. });
  901. },
  902. getTag(status) {
  903. if (status == true) {
  904. return "success";
  905. } else if (status == false) {
  906. return "danger";
  907. }
  908. return status;
  909. },
  910. getLevel(level) {
  911. if (level == "ZSB") {
  912. return "专升本";
  913. } else if (level == "GQZ") {
  914. return "高起专";
  915. }
  916. return level;
  917. },
  918. handleSearchBtn() {
  919. this.currentPage = 1;
  920. this.search();
  921. },
  922. search() {
  923. let searchLock = true;
  924. setTimeout(() => {
  925. if (searchLock) {
  926. this.loading = true;
  927. }
  928. }, 500);
  929. var param = new URLSearchParams(this.searchForm);
  930. var url =
  931. QUESTION_API +
  932. "/user/all/" +
  933. this.currentPage +
  934. "/" +
  935. this.pageSize +
  936. "?" +
  937. param;
  938. this.$httpWithMsg
  939. .get(url)
  940. .then((response) => {
  941. // console.log(response);
  942. this.tableData = response.data.content;
  943. this.total = response.data.totalElements;
  944. this.loading = false;
  945. })
  946. .finally(() => {
  947. searchLock = false;
  948. this.loading = false;
  949. });
  950. },
  951. handleCurrentChange(val) {
  952. this.currentPage = val;
  953. this.search();
  954. },
  955. selectChange(row) {
  956. this.selectedUserIds = [];
  957. row.forEach((element) => {
  958. this.selectedUserIds.push(element.id);
  959. });
  960. },
  961. //新增
  962. openAddingDialog() {
  963. if (this.$refs.addingForm) {
  964. this.$refs.addingForm.resetFields();
  965. }
  966. if (this.$refs.updateForm) {
  967. this.$refs.updateForm.resetFields();
  968. }
  969. this.addingDialog = true;
  970. this.userForm.name = "";
  971. this.userForm.loginName = "";
  972. this.userForm.password = "";
  973. this.userForm.phoneNumber = "";
  974. this.userForm.roleId = null;
  975. this.userForm.orgId = null;
  976. this.enableStr = "true";
  977. this.orgList4InsertOrUpdate = [];
  978. },
  979. //修改
  980. openUpdateDialog(row) {
  981. if (this.$refs.updateForm) {
  982. this.$refs.updateForm.resetFields();
  983. }
  984. if (this.$refs.addingForm) {
  985. this.$refs.addingForm.resetFields();
  986. }
  987. this.updateDialog = true;
  988. this.userForm.id = row.id;
  989. this.userForm.roleId = row.roleIds[0];
  990. this.userForm.name = row.name;
  991. this.userForm.loginName = row.loginName;
  992. this.enableStr = row.enable ? "true" : "false";
  993. this.userForm.phoneNumber = row.phoneNumber;
  994. this.userForm.password = null;
  995. this.userForm.rootOrgId = row.rootOrgId;
  996. this.rowIsSuperAdmin = false;
  997. for (let roleCode of row.roleCodes) {
  998. if (roleCode == "SUPER_ADMIN") {
  999. this.rowIsSuperAdmin = true;
  1000. break;
  1001. }
  1002. }
  1003. this.rootOrgChanged4InsertOrUpdate();
  1004. this.orgList4InsertOrUpdate = [{ id: row.orgId, name: row.orgName }];
  1005. this.userForm.orgId = row.orgId;
  1006. },
  1007. exportUser() {
  1008. var param = new URLSearchParams(this.searchForm);
  1009. window.open(QUESTION_API + "/user/export?" + param);
  1010. },
  1011. // 设置权限
  1012. setPrivilege(row) {
  1013. window.sessionStorage.setItem(
  1014. "userPageCache",
  1015. JSON.stringify({
  1016. searchFilter: this.userForm,
  1017. currentPage: this.currentPage,
  1018. pageSize: this.pageSize,
  1019. total: this.total,
  1020. })
  1021. );
  1022. this.$router.push(`./user/data_previllege/${row.rootOrgId}/${row.id}`);
  1023. },
  1024. //保存
  1025. add() {
  1026. var url = QUESTION_API + "/user";
  1027. this.$refs.addingForm.validate((valid) => {
  1028. if (valid) {
  1029. this.userForm.enable = this.enableStr == "true";
  1030. this.$httpWithMsg.post(url, this.userForm).then(() => {
  1031. this.$notify({
  1032. type: "success",
  1033. message: "添加成功",
  1034. });
  1035. this.search();
  1036. this.addingDialog = false;
  1037. });
  1038. } else {
  1039. return false;
  1040. }
  1041. });
  1042. },
  1043. //保存
  1044. update() {
  1045. var url = QUESTION_API + "/user";
  1046. this.$refs.updateForm.validate((valid) => {
  1047. if (valid) {
  1048. this.userForm.enable = this.enableStr == "true";
  1049. this.$httpWithMsg.put(url, this.userForm).then(() => {
  1050. this.$notify({
  1051. type: "success",
  1052. message: "添加成功",
  1053. });
  1054. this.search();
  1055. this.updateDialog = false;
  1056. });
  1057. } else {
  1058. return false;
  1059. }
  1060. });
  1061. },
  1062. //重置密码
  1063. resetPass(row) {
  1064. this.$confirm("是否重置密码?", "提示", {
  1065. confirmButtonText: "确定",
  1066. cancelButtonText: "取消",
  1067. type: "warning",
  1068. })
  1069. .then(() => {
  1070. var url = QUESTION_API + "/user/resetPass/" + row.id;
  1071. this.$httpWithMsg.put(url).then(() => {
  1072. this.$notify({
  1073. type: "success",
  1074. message: "重置成功!",
  1075. });
  1076. return this.search();
  1077. });
  1078. })
  1079. .catch((e) => console.log(e));
  1080. },
  1081. //删除单个数据
  1082. deleteById(row) {
  1083. this.$confirm("是否删除该用户?", "提示", {
  1084. confirmButtonText: "确定",
  1085. cancelButtonText: "取消",
  1086. type: "warning",
  1087. }).then(() => {
  1088. var url = QUESTION_API + "/user/" + row.id;
  1089. this.$httpWithMsg.delete(url).then(() => {
  1090. this.$notify({
  1091. type: "success",
  1092. message: "删除成功!",
  1093. });
  1094. return this.search();
  1095. });
  1096. });
  1097. },
  1098. //删除多条数据
  1099. deleteByIds() {
  1100. if (this.selectedUserIds.length === 0) {
  1101. this.$notify({
  1102. type: "warning",
  1103. message: "请选择要删除的用户",
  1104. });
  1105. } else {
  1106. this.$confirm("是否删除这些用户?", "提示", {
  1107. confirmButtonText: "确定",
  1108. cancelButtonText: "取消",
  1109. type: "error",
  1110. }).then(() => {
  1111. var url = QUESTION_API + "/user/" + this.userIds;
  1112. this.$httpWithMsg.delete(url).then(() => {
  1113. this.$notify({
  1114. type: "success",
  1115. message: "删除成功!",
  1116. });
  1117. this.search();
  1118. });
  1119. });
  1120. }
  1121. },
  1122. //启用
  1123. enableByIds() {
  1124. if (this.selectedUserIds.length === 0) {
  1125. this.$notify({
  1126. type: "warning",
  1127. message: "请选择要启用的用户",
  1128. });
  1129. } else {
  1130. this.$confirm("是否启用这些用户?", "提示", {
  1131. confirmButtonText: "确定",
  1132. cancelButtonText: "取消",
  1133. type: "warning",
  1134. }).then(() => {
  1135. var url = QUESTION_API + "/user/enable/" + this.userIds;
  1136. this.$httpWithMsg.put(url, {}).then(() => {
  1137. this.$notify({
  1138. type: "success",
  1139. message: "启用成功!",
  1140. });
  1141. return this.search();
  1142. });
  1143. });
  1144. }
  1145. },
  1146. enableById(row) {
  1147. this.$confirm("是否启用该用户?", "提示", {
  1148. confirmButtonText: "确定",
  1149. cancelButtonText: "取消",
  1150. type: "warning",
  1151. }).then(() => {
  1152. var url = QUESTION_API + "/user/enable/" + row.id;
  1153. this.$httpWithMsg.put(url, {}).then(() => {
  1154. this.$notify({
  1155. type: "success",
  1156. message: "启用成功!",
  1157. });
  1158. this.search();
  1159. });
  1160. });
  1161. },
  1162. //禁用
  1163. disableByIds() {
  1164. if (this.selectedUserIds.length === 0) {
  1165. this.$notify({
  1166. type: "warning",
  1167. message: "请选择要禁用的用户",
  1168. });
  1169. } else {
  1170. this.$confirm("是否禁用这些用户?", "提示", {
  1171. confirmButtonText: "确定",
  1172. cancelButtonText: "取消",
  1173. type: "error",
  1174. }).then(() => {
  1175. var url = QUESTION_API + "/user/disable/" + this.userIds;
  1176. this.$httpWithMsg.put(url, {}).then(() => {
  1177. this.$notify({
  1178. type: "success",
  1179. message: "禁用成功!",
  1180. });
  1181. this.search();
  1182. });
  1183. });
  1184. }
  1185. },
  1186. //禁用
  1187. disableById(row) {
  1188. this.$confirm("是否禁用该用户?", "提示", {
  1189. confirmButtonText: "确定",
  1190. cancelButtonText: "取消",
  1191. type: "error",
  1192. }).then(() => {
  1193. var url = QUESTION_API + "/user/disable/" + row.id;
  1194. this.$httpWithMsg.put(url, {}).then(() => {
  1195. this.$notify({
  1196. type: "success",
  1197. message: "禁用成功!",
  1198. });
  1199. this.search();
  1200. });
  1201. });
  1202. },
  1203. /*初始化*/
  1204. init() {
  1205. this.searchForm.rootOrgId = this.user.rootOrgId;
  1206. this.userForm.rootOrgId = this.user.rootOrgId;
  1207. var url1 = QUESTION_API + "/org/getRootOrgList";
  1208. var url2 =
  1209. QUESTION_API +
  1210. "/rolePrivilege/getRoles?includeSuperAdmin=true&rootOrgId=" +
  1211. this.user.rootOrgId;
  1212. Promise.all([
  1213. this.$httpWithMsg.get(url1),
  1214. this.$httpWithMsg.post(url2),
  1215. ]).then(([resp1, resp2]) => {
  1216. this.rootOrgList = resp1.data;
  1217. this.roleList4Search = resp2.data;
  1218. this.roleList4InsertOrUpdate = resp2.data;
  1219. const cacheInfo = window.sessionStorage.getItem("userPageCache");
  1220. if (cacheInfo) {
  1221. const { searchFilter, currentPage, pageSize, total } =
  1222. JSON.parse(cacheInfo);
  1223. this.userForm = searchFilter;
  1224. this.currentPage = currentPage;
  1225. this.pageSize = pageSize;
  1226. this.total = total;
  1227. window.sessionStorage.removeItem("userPageCache");
  1228. }
  1229. this.search();
  1230. });
  1231. },
  1232. initPrivileges() {
  1233. let params = new URLSearchParams();
  1234. params.append(
  1235. "privilegeCodes",
  1236. Object.keys(this.rolePrivileges).toString()
  1237. );
  1238. var url = QUESTION_API + "/rolePrivilege/checkPrivileges?" + params;
  1239. this.$httpWithMsg.post(url).then((response) => {
  1240. this.rolePrivileges = response.data;
  1241. });
  1242. this.getCourses4Search("");
  1243. },
  1244. showUserDataRuleSetting(row) {
  1245. let roleCodes = row.roleCodes;
  1246. for (let n = 0; n < roleCodes.length; n++) {
  1247. let roleCode = roleCodes[n];
  1248. if (roleCode == "SUPER_ADMIN" || roleCode == "ADMIN") {
  1249. return false;
  1250. }
  1251. }
  1252. return true;
  1253. },
  1254. showBtn(row) {
  1255. let roleCodes = row.roleCodes;
  1256. for (let n = 0; n < roleCodes.length; n++) {
  1257. let roleCode = roleCodes[n];
  1258. if (roleCode == "SUPER_ADMIN") {
  1259. return false;
  1260. }
  1261. }
  1262. return true;
  1263. },
  1264. },
  1265. };
  1266. </script>