Elizabeth's proactive approach involves introducing urinal toilet attachment , an ingenious concept that optimizes space and functionality.

admin.vue 36KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230
  1. <template>
  2. <div class="main-contain">
  3. <div class="position">
  4. <bread-crumb :crumbs="crumbs"></bread-crumb>
  5. <div>
  6. <!-- <el-button
  7. type="primary"
  8. size="small"
  9. icon="el-icon-circle-plus-outline"
  10. style="float:left"
  11. @click="toGet">CA企业认证</el-button> -->
  12. <el-button
  13. type="primary"
  14. size="small"
  15. icon="el-icon-circle-plus-outline"
  16. style="float:left"
  17. @click="openForm(0)">新增</el-button>
  18. <el-button
  19. type="primary"
  20. size="small"
  21. @click="BatchDelete"
  22. >医药师登记</el-button>
  23. <el-button
  24. type="primary"
  25. size="small"
  26. icon="el-icon-circle-plus-outline"
  27. style="float:left"
  28. @click="toJiaBan">加班</el-button>
  29. <!-- <el-button
  30. type="primary"
  31. size="small"
  32. icon="el-icon-circle-plus-outline"
  33. style="float:left"
  34. @click="toTest">短信</el-button> -->
  35. <!-- <el-button
  36. type="primary"
  37. size="small"
  38. icon="el-icon-circle-plus-outline"
  39. style="float:left"
  40. @click="toTestOne">创建个人用户实名</el-button>
  41. <el-button
  42. type="primary"
  43. size="small"
  44. icon="el-icon-circle-plus-outline"
  45. style="float:left"
  46. @click="toTestFive">创建企业用户并实名</el-button>
  47. <el-button
  48. type="primary"
  49. size="small"
  50. icon="el-icon-circle-plus-outline"
  51. style="float:left"
  52. @click="toTestFour">添加企业成员</el-button>
  53. <el-button
  54. type="primary"
  55. size="small"
  56. icon="el-icon-circle-plus-outline"
  57. style="float:left"
  58. @click="toTestTwo">创建个人印章</el-button>
  59. <el-button
  60. type="primary"
  61. size="small"
  62. icon="el-icon-circle-plus-outline"
  63. style="float:left"
  64. @click="toTestThree">创建合同</el-button> -->
  65. <!-- <el-button
  66. type="primary"
  67. size="small"
  68. icon="el-icon-circle-plus-outline"
  69. style="float:left"
  70. @click="toTestSeven">添加合同签署人</el-button> -->
  71. <!-- <el-button
  72. type="primary"
  73. size="small"
  74. icon="el-icon-circle-plus-outline"
  75. style="float:left"
  76. @click="toTestTen"
  77. >
  78. 短信验证码
  79. </el-button> -->
  80. <!-- <el-button
  81. type="primary"
  82. size="small"
  83. icon="el-icon-circle-plus-outline"
  84. style="float:left"
  85. @click="toTestNight">后台签署</el-button>
  86. -->
  87. <!-- <el-button
  88. type="primary"
  89. size="small"
  90. icon="el-icon-circle-plus-outline"
  91. style="float:left"
  92. @click="toTestElement">创建企业用章</el-button> -->
  93. <!-- <el-button
  94. type="primary"
  95. size="small"
  96. icon="el-icon-circle-plus-outline"
  97. style="float:left"
  98. @click="toTestThrityMent">生成PDF</el-button> -->
  99. <!-- <el-button
  100. type="primary"
  101. size="small"
  102. icon="el-icon-circle-plus-outline"
  103. style="float:left"
  104. @click="toTestTwo">创建个人印章</el-button> -->
  105. <!-- <el-button
  106. type="primary"
  107. size="small"
  108. icon="el-icon-circle-plus-outline"
  109. style="float:left"
  110. @click="toTestThree">创建合同</el-button>
  111. <el-button
  112. type="primary"
  113. size="small"
  114. icon="el-icon-circle-plus-outline"
  115. style="float:left"
  116. @click="toTestSeven">添加合同签署人</el-button>
  117. <el-button
  118. type="primary"
  119. size="small"
  120. icon="el-icon-circle-plus-outline"
  121. style="float:left"
  122. @click="toTestTen"
  123. >
  124. 获取短信验证码
  125. </el-button>
  126. <el-button
  127. type="primary"
  128. size="small"
  129. icon="el-icon-circle-plus-outline"
  130. style="float:left"
  131. @click="toTestNight">后台签署</el-button>
  132. <el-button
  133. type="primary"
  134. size="small"
  135. icon="el-icon-circle-plus-outline"
  136. style="float:left"
  137. @click="toTestThrity">合同详情查询</el-button>
  138. <el-button
  139. type="primary"
  140. size="small"
  141. icon="el-icon-circle-plus-outline"
  142. style="float:left"
  143. @click="toWatch">合同在线预览</el-button>
  144. <el-button
  145. type="primary"
  146. size="small"
  147. icon="el-icon-circle-plus-outline"
  148. style="float:left"
  149. @click="toEnd">结束签署</el-button> -->
  150. <!-- <el-button
  151. type="primary"
  152. size="small"
  153. icon="el-icon-circle-plus-outline"
  154. style="float:left"
  155. @click="toSendInformaton">发送短信验证码</el-button> -->
  156. <!--<el-button
  157. type="primary"
  158. size="small"
  159. icon="el-icon-circle-plus-outline"
  160. style="float:left"
  161. @click="toSavePDFInformation">生成PDF</el-button>-->
  162. <!-- <el-button
  163. type="primary"
  164. size="small"
  165. icon="el-icon-circle-plus-outline"
  166. style="float:left"
  167. @click="toCheckPDFInformation">PDF验证</el-button> -->
  168. <!-- <el-button
  169. type="primary"
  170. size="small"
  171. icon="el-icon-circle-plus-outline"
  172. style="float:left"
  173. @click="toAutoDrug">自动生成</el-button> -->
  174. <el-button
  175. type="primary"
  176. size="small"
  177. icon="el-icon-circle-plus-outline"
  178. style="float:left"
  179. @click="toAutoDiagnose">自动脚本</el-button>
  180. </div>
  181. </div>
  182. <div class="app-container">
  183. <el-table
  184. :row-style="{ color: '#303133' }"
  185. :header-cell-style="{
  186. backgroundColor: 'rgb(245, 247, 250)',
  187. color: '#606266'
  188. }"
  189. style="width:100%;"
  190. ref="table"
  191. border
  192. :data="admins"
  193. v-loading="is_loading_admins"
  194. @selection-change="handleSelectionChange"
  195. >
  196. <el-table-column
  197. align="center"
  198. type="selection"
  199. width="55">
  200. </el-table-column>
  201. <el-table-column
  202. label="用户名"
  203. prop="user_name"
  204. min-width="160"
  205. align="center"
  206. ></el-table-column>
  207. <el-table-column v-if="this.$store.getters.xt_user.org_id != 10206" label="医保医师编码" prop="doctor_number" min-width="160" align="center">
  208. <template slot-scope="scope">
  209. <span v-if="scope.row.doctor_number== 0"></span>
  210. <span v-if="scope.row.doctor_number!= 0">{{scope.row.doctor_number}}</span>
  211. </template>
  212. </el-table-column>
  213. <el-table-column v-if="this.$store.getters.xt_user.org_id == 10206" label="员工ID" prop="doctor_number" min-width="160" align="center">
  214. <template slot-scope="scope">
  215. <span v-if="scope.row.doctor_number== 0"></span>
  216. <span v-if="scope.row.doctor_number!= 0">{{scope.row.doctor_number}}</span>
  217. </template>
  218. </el-table-column>
  219. <el-table-column
  220. label="最后登录IP"
  221. prop="ip"
  222. min-width="150"
  223. align="center"
  224. ></el-table-column>
  225. <el-table-column
  226. label="最后登录时间"
  227. prop="last_login_time"
  228. min-width="170"
  229. align="center"
  230. >
  231. <template slot-scope="scope">
  232. <span>{{
  233. scope.row.last_login_time == 0
  234. ? ""
  235. : _parseTime(scope.row.last_login_time, "{y}-{m}-{d} {h}:{i}")
  236. }}</span>
  237. </template>
  238. </el-table-column>
  239. <el-table-column
  240. label="角色"
  241. prop="role_name"
  242. min-width="160"
  243. align="center"
  244. ></el-table-column>
  245. <el-table-column label="状态" min-width="100" align="center">
  246. <template slot-scope="scope">
  247. <div
  248. v-if="scope.row.status == 1"
  249. style="color: #67C23A; font-size:20px;"
  250. >
  251. <li class="el-icon-success"></li>
  252. </div>
  253. <div v-else style="color: #F56C6C; font-size:20px;">
  254. <li class="el-icon-error"></li>
  255. </div>
  256. </template>
  257. </el-table-column>
  258. <el-table-column label="操作" width="240" align="center">
  259. <template slot-scope="scope">
  260. <!-- <span>
  261. <el-button type="primary" size="small" @click="toRenZhen(scope.row.user_id,scope.row.user_name)">
  262. <span>CA个人认证</span>
  263. </el-button>
  264. </span> -->
  265. <!-- <span>
  266. <el-button type="primary" size="small" @click="toQianShu(scope.row.user_id,scope.row.user_name)">
  267. <span>创建签署人用户</span>
  268. </el-button>
  269. </span>
  270. <span>
  271. <el-button type="primary" size="small" @click="toYinZhang(scope.row.user_id,scope.row.user_name)">
  272. <span>创建个人印章</span>
  273. </el-button>
  274. </span> -->
  275. <!--
  276. <span>
  277. <el-button type="primary" size="small" @click="toShouQuan(scope.row.user_id,scope.row.user_name)">
  278. <span>创建企业印章</span>
  279. </el-button>
  280. </span> -->
  281. <el-tooltip
  282. class="item"
  283. effect="dark"
  284. content="编辑"
  285. placement="top"
  286. >
  287. <el-button
  288. type="primary"
  289. icon="el-icon-edit-outline"
  290. size="small"
  291. @click="openForm(scope.row.user_id)"
  292. ></el-button>
  293. </el-tooltip>
  294. <!-- </router-link> -->
  295. <el-tooltip
  296. class="item"
  297. effect="dark"
  298. content="移除"
  299. placement="top"
  300. >
  301. <el-button
  302. type="danger"
  303. size="small"
  304. icon="el-icon-delete"
  305. v-if="
  306. scope.row.status == 1 &&
  307. org.creator != scope.row.user_id &&
  308. scope.row.user_id != local_user_id
  309. "
  310. @click="disableAdminAction(scope.row)"
  311. ></el-button>
  312. </el-tooltip>
  313. <el-tooltip
  314. class="item"
  315. effect="dark"
  316. content="恢复"
  317. placement="top"
  318. >
  319. <el-button
  320. size="small"
  321. type="info"
  322. icon="el-icon-refresh"
  323. v-if="
  324. scope.row.status == 0 &&
  325. org.creator != scope.row.user_id &&
  326. scope.row.user_id != local_user_id
  327. "
  328. @click="recoverAdminAction(scope.row)"
  329. ></el-button>
  330. </el-tooltip>
  331. <span v-if="scope.row.user_type == 2">
  332. <el-button type="primary" size="small" icon="el-icon-refresh-left" @click="toReturn(scope.row.user_id,scope.row.is_mark)">
  333. <span v-if="scope.row.is_mark ==0">登记</span>
  334. <span v-if="scope.row.is_mark ==1">撤销</span>
  335. </el-button>
  336. </span>
  337. </template>
  338. </el-table-column>
  339. </el-table>
  340. <el-row style="margin-top: 15px;" v-if="admin_total_count > 10">
  341. <el-col :span="24">
  342. <el-pagination
  343. :total="admin_total_count"
  344. :current-page.sync="current_page"
  345. @current-change="pageChange"
  346. :page-size="10"
  347. layout="total, prev, pager, next, jumper"
  348. ></el-pagination>
  349. </el-col>
  350. </el-row>
  351. <admin-info-form ref="admininfoform"></admin-info-form>
  352. </div>
  353. <el-dialog
  354. title="CA企业认证"
  355. :visible.sync="dialogVisible"
  356. width="50%">
  357. <span>
  358. <el-form>
  359. <el-row>
  360. <el-col>
  361. <el-form-item label="企业类型:">
  362. <el-select
  363. v-model="form.org_type"
  364. filterable
  365. clearable
  366. allow-create
  367. placeholder="选择"
  368. >
  369. <el-option
  370. v-for="item in businessList"
  371. :key="item.id"
  372. :label="item.name "
  373. :value="item.id"
  374. ></el-option>
  375. </el-select>
  376. </el-form-item>
  377. </el-col>
  378. <el-col>
  379. <el-form-item label="企业名称:">
  380. <el-input style="width:200px" v-model="form.enterprise_name" placeholder="请按营业执照上面的公司填写名称"></el-input>
  381. </el-form-item>
  382. </el-col>
  383. <el-col>
  384. <el-form-item label="统一社会信用代码:">
  385. <el-input style="width:200px" v-model="form.code" placeholder="请输入统一社会信息代码"></el-input>
  386. </el-form-item>
  387. </el-col>
  388. <el-col>
  389. <el-form-item label="组织机构代码:">
  390. <el-input style="width:200px" v-model="form.org_code" placeholder="请输入统一社会信息代码"></el-input>
  391. </el-form-item>
  392. </el-col>
  393. <el-col>
  394. <el-form-item label="法定代表人:">
  395. <el-input style="width:200px" v-model="form.legal_person_name" placeholder="请输入统一社会信息代码"></el-input>
  396. </el-form-item>
  397. </el-col>
  398. <el-col>
  399. <el-form-item label="法定代表人身份证:">
  400. <el-input style="width:200px" v-model="form.legal_id_card_num" placeholder="请输入统一社会信息代码"></el-input>
  401. </el-form-item>
  402. </el-col>
  403. <el-col>
  404. <el-form-item label="法人手机号码:">
  405. <el-input style="width:200px" v-model="form.legal_phone" placeholder="请输入法人手机号码"></el-input>
  406. </el-form-item>
  407. </el-col>
  408. </el-row>
  409. </el-form>
  410. </span>
  411. <span slot="footer" class="dialog-footer">
  412. <el-button @click="dialogVisible = false">取 消</el-button>
  413. <el-button type="primary" @click="saveEnterprise">立即认证</el-button>
  414. </span>
  415. </el-dialog>
  416. <el-dialog
  417. title="CA个人认证"
  418. :visible.sync="persionDialogVisible"
  419. width="50%">
  420. <span>
  421. <el-form>
  422. <el-row>
  423. <el-col>
  424. <el-form-item label="姓名:">
  425. <el-input style="width:200px" v-model="personForm.display_name" placeholder="请输入姓名"></el-input>
  426. </el-form-item>
  427. </el-col>
  428. <el-col>
  429. <el-form-item label="身份证号:">
  430. <el-input style="width:200px" v-model="personForm.id_card_num" placeholder="请输入身份证号"></el-input>
  431. </el-form-item>
  432. </el-col>
  433. <el-col>
  434. <el-form-item label="手机号:">
  435. <el-input style="width:200px" v-model="personForm.phone" placeholder="请输入手机号"></el-input>
  436. </el-form-item>
  437. </el-col>
  438. <el-col>
  439. <el-form-item label="验证码:">
  440. <el-input style="width:100px" v-model="form.code" placeholder="请输入验证码"></el-input>
  441. <el-button type="primary" size="small" @click="getCode">获取验证码</el-button>
  442. </el-form-item>
  443. </el-col>
  444. </el-row>
  445. </el-form>
  446. </span>
  447. <span slot="footer" class="dialog-footer">
  448. <el-button @click="persionDialogVisible = false">取 消</el-button>
  449. <el-button type="primary" @click="savePersonEnterprise">立即认证</el-button>
  450. </span>
  451. </el-dialog>
  452. </div>
  453. </template>
  454. <script>
  455. import { adminMainView, getAdmins, setAdminStatus,toSign,toTestOne,toTestTwo,toTestThree,toTestFour,toTestFive,toTestSeven,toTestEight,toTestNight,toTestTen,toTestElement,toTestThrityMent,saveEnterprise,getEnterPriseById,getMobileCode,savePersionEnterPrise,getPerseEnterPriseById,CreatePersionSeal,CreateNewEnterPrise,toTestThrity,toEndEnterPrise,getEnterPriseDetail
  456. ,CreateQianshuUserName,CreateSKDSendInformation,toSavePDFInformation,toCheckPDFInformation,getdruginfoInformation,toAutoDrug,toAutoDiagnose} from "@/api/role/admin";
  457. import { getRoles } from "@/api/role/role";
  458. import { UploadPrintOrder } from "@/api/role/admin"
  459. import { parseTime } from "@/utils";
  460. import BreadCrumb from "@/xt_pages/components/bread-crumb";
  461. import AdminInfoForm from "./components/AdminInfoForm";
  462. import axios from 'axios'
  463. export default {
  464. name: "adminManage",
  465. data() {
  466. return {
  467. crumbs: [
  468. { path: false, name: "管理中心" },
  469. { path: false, name: "员工管理" }
  470. ],
  471. is_loading_admins: true,
  472. admins: [], // [{user_id, user_name, role_name, title_name, ip, last_login_time, status}]
  473. admin_total_count: 0,
  474. current_page: 1,
  475. roles: [],
  476. is_exist_role: false,
  477. org: null,
  478. isSubSuperAdmin: false,
  479. local_user_id: 0,
  480. selectDrug:[],
  481. dialogVisible:false,
  482. persionDialogVisible:false,
  483. businessList:[
  484. {id:1,name:"企业"},
  485. {id:2,name:"个体工商户"},
  486. {id:3,name:"政府机构"}
  487. ],
  488. form:{
  489. id:0,
  490. org_type:"",
  491. enterprise_name:"",
  492. code:"",
  493. org_code:"",
  494. legal_person_name:"",
  495. legal_id_card_num:"",
  496. legal_phone:"",
  497. },
  498. personForm:{
  499. id:0,
  500. display_name:"",
  501. phone:"",
  502. id_card_num:"",
  503. admin_user_id:"",
  504. code:"",
  505. }
  506. };
  507. },
  508. components: {
  509. BreadCrumb,
  510. AdminInfoForm
  511. },
  512. created: function() {
  513. this.local_user_id = this.$store.getters.xt_user.user.id;
  514. let page = 1;
  515. this.getRoles(page);
  516. adminMainView()
  517. .then(rs => {
  518. this.is_loading_admins = false;
  519. var resp = rs.data;
  520. if (resp.state === 1) {
  521. var adminData = resp.data.admins
  522. console.log("数据",adminData)
  523. this.admins.push(...adminData);
  524. this.admin_total_count = resp.data.total_count;
  525. this.is_exist_role = resp.data.is_exist_role;
  526. this.current_page = 1;
  527. this.org = resp.data.org;
  528. this.isSubSuperAdmin = resp.data.isSubSuperAdmin;
  529. //能进入当前页面的角色只有超级管理员和子管理员,如果当前角色是子管理员,需要把超级管理员和其他子管理员的信息去除,子管理员不能编辑超级管理员和其他子管理员信息,
  530. if (this.isSubSuperAdmin) {
  531. //去除管理员信息
  532. for (let i = 0; i < this.admins.length; i++) {
  533. if (this.admins[i].user_id == this.org.creator) {
  534. this.admins.splice(i, 1);
  535. i--;
  536. }
  537. }
  538. //去除其他子管理员信息
  539. for (let i = 0; i < this.admins.length; i++) {
  540. if (
  541. this.admins[i].user_id != this.local_user_id &&
  542. this.admins[i].is_sub_super_admin
  543. ) {
  544. //将自己排除在外
  545. console.log(this.admins[i]);
  546. this.admins.splice(i, 1);
  547. i--;
  548. }
  549. }
  550. }
  551. } else {
  552. this.$message.error(resp.msg);
  553. }
  554. })
  555. .catch(err => {
  556. this.is_loading_admins = false;
  557. this.$message.error(err);
  558. });
  559. },
  560. computed: {
  561. should_update_admins() {
  562. return this.$store.getters.xt_role_temps.did_admins_changed;
  563. }
  564. },
  565. methods: {
  566. getRoles(page) {
  567. getRoles(page)
  568. .then(rs => {
  569. this.loading_roles = false;
  570. const resp = rs.data;
  571. if (resp.state === 1) {
  572. this.roles.push(...resp.data.roles);
  573. } else {
  574. this.$message.error(resp.msg);
  575. }
  576. })
  577. .catch(err => {
  578. this.loading_roles = false;
  579. this.$message.error(err);
  580. });
  581. },
  582. openForm(adminId) {
  583. this.$refs["admininfoform"].open(adminId, this.roles);
  584. },
  585. _parseTime(time, format) {
  586. return parseTime(time, format);
  587. },
  588. requestAdminsWithPage: function(page) {
  589. this.admins.splice(0, this.admins.length);
  590. this.is_loading_admins = true;
  591. getAdmins(page)
  592. .then(rs => {
  593. this.is_loading_admins = false;
  594. const resp = rs.data;
  595. console.log(resp);
  596. if (resp.state === 1) {
  597. var admindata = resp.data.admins
  598. this.admins.push(...admindata);
  599. this.admin_total_count = resp.data.total_count;
  600. } else {
  601. this.$message.error(resp.msg);
  602. }
  603. })
  604. .catch(err => {
  605. this.is_loading_admins = false;
  606. this.$message.error(err);
  607. });
  608. },
  609. addAdminAction: function() {
  610. this.$router.push({ path: "/role/admin/create" });
  611. },
  612. disableAdminAction: function(row) {
  613. this.$msgbox({
  614. title: "提示",
  615. message: "是否确定要移除该用户",
  616. showCancelButton: true,
  617. confirmButtonText: "确定",
  618. cancelButtonText: "取消",
  619. type: "warning",
  620. beforeClose: (action, instance, done) => {
  621. if (action === "confirm") {
  622. instance.confirmButtonLoading = true;
  623. instance.confirmButtonText = "删除中...";
  624. setAdminStatus(row.user_id, false)
  625. .then(rs => {
  626. done();
  627. instance.confirmButtonLoading = false;
  628. const resp = rs.data;
  629. if (resp.state === 1) {
  630. row.status = 0;
  631. } else {
  632. this.$message.error(resp.msg);
  633. }
  634. })
  635. .catch(err => {
  636. done();
  637. instance.confirmButtonLoading = false;
  638. this.$message.error(err);
  639. });
  640. } else {
  641. done();
  642. }
  643. }
  644. });
  645. },
  646. recoverAdminAction: function(row) {
  647. const loading = this.$loading({
  648. lock: true,
  649. text: "正在恢复管理员...",
  650. spinner: "el-icon-loading",
  651. background: "rgba(0, 0, 0, 0.7)"
  652. });
  653. setAdminStatus(row.user_id, true)
  654. .then(rs => {
  655. loading.close();
  656. const resp = rs.data;
  657. if (resp.state === 1) {
  658. row.status = 1;
  659. } else {
  660. this.$message.error(resp.msg);
  661. }
  662. })
  663. .catch(err => {
  664. loading.close();
  665. this.$message.error(err);
  666. });
  667. },
  668. pageChange: function(nextPage) {
  669. this.requestAdminsWithPage(nextPage);
  670. },
  671. // toLogin(){
  672. // var that = this
  673. // axios.get('http://127.0.0.1:9532/sz/api/doctor/get').then(function(response) {
  674. // if (response.data.state == 0) {
  675. // that.$message.error(response.data.msg)
  676. // return false
  677. // } else {
  678. // that.$message({ message: '登记成功', type: 'success' })
  679. // }
  680. // }).catch(function(error) {
  681. // })
  682. // },
  683. BatchDelete() {
  684. if (this.selectDrug.length == 0) {
  685. this.$message.error("请选择要登记的信息");
  686. return false;
  687. }
  688. this.$confirm(
  689. "确认要登记所选记录吗? <br>",
  690. "备案提示",
  691. {
  692. dangerouslyUseHTMLString: true,
  693. confirmButtonText: "确定",
  694. cancelButtonText: "取消",
  695. type: "warning"
  696. }
  697. ).then(() => {
  698. var ids = [];
  699. var idMap = {};
  700. console.log("3333333",this.selectDrug)
  701. for (const index in this.selectDrug) {
  702. ids.push(this.selectDrug[index].user_id);
  703. idMap[this.selectDrug[index].user_id] = this.selectDrug[index].user_id;
  704. }
  705. var idss = ids.join(',')
  706. let params = {
  707. ids:idss,
  708. admin_user_id:this.$store.getters.xt_user.user.id
  709. }
  710. console.log("prams222",params)
  711. var that = this
  712. axios.get('http://127.0.0.1:9532/sz/api/doctor/get',{ params: params }).then(function(response) {
  713. if (response.data.state == 0) {
  714. that.$message.error(response.data.data.msg)
  715. return false
  716. } else {
  717. that.$message.error(response.data.data.msg)
  718. if(response.data.data.msg == ""){
  719. that.$message.success("登记成功!")
  720. that.adminMainView()
  721. }
  722. if(response.data.data.msg!=""){
  723. that.$message.error(response.data.data.msg)
  724. that.adminMainView()
  725. }
  726. }
  727. }).catch(function(error) {
  728. })
  729. });
  730. },
  731. toReturn(id,is_mark){
  732. var that = this
  733. let params = {
  734. 'id':id,
  735. "is_mark":is_mark,
  736. "admin_user_id":this.$store.getters.xt_user.user.id
  737. }
  738. axios.get('http://127.0.0.1:9532/sz/api/medical/get',{params:params}).then(function(response) {
  739. if (response.data.state == 0) {
  740. that.$message.error(response.data.data.msg)
  741. return false
  742. } else {
  743. if(response.data.data.msg == ""){
  744. that.$message.success("登记成功!")
  745. that.adminMainView()
  746. }
  747. if(response.data.data.msg!=""){
  748. that.$message.error(response.data.data.msg)
  749. that.adminMainView()
  750. }
  751. }
  752. }).catch(function(error) {
  753. })
  754. },
  755. handleSelectionChange(val) {
  756. this.selectDrug = val;
  757. },
  758. toTest(){
  759. toSign().then(response=>{
  760. if(response.data.state ==1){
  761. var sign = response.data.data.sign
  762. console.log("sign",sign)
  763. }
  764. })
  765. },
  766. toTestOne(){
  767. toTestOne().then(response=>{
  768. if(response.data.state==1){
  769. var sign = response.data.data.sign
  770. console.log("sign",sign)
  771. }
  772. })
  773. },
  774. toTestTwo(){
  775. toTestTwo().then(response=>{
  776. if(response.data.state ==1){
  777. var sign = response.data.data.sign
  778. console.log("sign",sign)
  779. }
  780. })
  781. },
  782. toTestThree(){
  783. toTestThree().then(response=>{
  784. if(response.data.state ==1){
  785. var sign = response.data.data.sign
  786. console.log("sign",sign)
  787. }
  788. })
  789. },
  790. toTestFour(){
  791. toTestFour().then(response=>{
  792. if(response.data.state==1){
  793. var sign = response.data.data.sign
  794. console.log("sign",sign)
  795. }
  796. })
  797. },
  798. toTestFive(){
  799. toTestFive().then(response=>{
  800. if(response.data.state==1){
  801. var sign = response.data.data.sign
  802. console.log("sign",sign)
  803. }
  804. })
  805. },
  806. toTestSeven(){
  807. toTestSeven().then(response=>{
  808. if(response.data.state ==1){
  809. var sign = response.data.data.sign
  810. console.log("sign",sign)
  811. }
  812. })
  813. },
  814. toTestEight(){
  815. toTestEight().then(response=>{
  816. if(response.data.state== 1){
  817. var sign = response.data.data.sign
  818. console.log("sign",sign)
  819. this.$message.success("保存")
  820. }
  821. })
  822. },
  823. toTestNight(){
  824. toTestNight().then(response=>{
  825. if(response.data.state == 1){
  826. var sign = response.data.data.sign
  827. console.log("sign",sign)
  828. this.$message.success("保存")
  829. var maprequest = response.data.data.maprequest
  830. console.log("maprequest",maprequest)
  831. }
  832. })
  833. },
  834. toTestTen(){
  835. toTestTen().then(response=>{
  836. if(response.data.state == 1){
  837. var sign = response.data.data.sign
  838. console.log("sign",sign)
  839. this.$message.success("保存")
  840. }
  841. })
  842. },
  843. toTestElement(){
  844. toTestElement().then(response=>{
  845. if(response.data.state == 1){
  846. var sign = response.data.data.sign
  847. console.log("sign",sign)
  848. this.$message.success("保存")
  849. }
  850. })
  851. },
  852. toTestThrityMent(){
  853. toTestThrityMent().then(response=>{
  854. var sign = response.data.data.sign
  855. console.log("sign",sign)
  856. this.$message.success("保存")
  857. })
  858. },
  859. saveEnterprise(){
  860. var params = {
  861. id:this.form.id,
  862. org_type:parseInt(this.form.org_type),
  863. enterprise_name:this.form.enterprise_name,
  864. code:this.form.code,
  865. org_code:this.form.org_code,
  866. legal_person_name:this.form.legal_person_name,
  867. legal_id_card_num:this.form.legal_id_card_num,
  868. legal_phone:this.form.legal_phone,
  869. }
  870. console.log("paramswowo",params)
  871. saveEnterprise(params).then(response=>{
  872. if(response.data.state==1){
  873. var enterPrise = response.data.data.enterPrise
  874. this.dialogVisible = false
  875. this.$message.success("保存成功!")
  876. }
  877. })
  878. },
  879. toGet(){
  880. getEnterPriseById().then(response=>{
  881. if(response.data.state == 1){
  882. this.dialogVisible = true
  883. var enterPrise = response.data.data.enterPrise
  884. this.form.id = enterPrise.id
  885. this.form.org_type = enterPrise.org_type?enterPrise.org_type:""
  886. this.form.enterprise_name = enterPrise.enterprise_name
  887. this.form.code = enterPrise.code
  888. this.form.org_code = enterPrise.org_code
  889. this.form.legal_person_name = enterPrise.legal_person_name
  890. this.form.legal_id_card_num = enterPrise.legal_id_card_num
  891. this.form.legal_phone = enterPrise.legal_phone
  892. }
  893. })
  894. },
  895. toRenZhen(admin_user_id,user_name){
  896. getPerseEnterPriseById(admin_user_id).then(response=>{
  897. if(response.data.state== 1){
  898. var lastPerson = response.data.data.lastPerson
  899. this.personForm.id = lastPerson.id
  900. this.personForm.display_name = user_name
  901. this.personForm.phone = lastPerson.phone
  902. this.personForm.id_card_num = lastPerson.id_card_num
  903. this.personForm.admin_user_id =lastPerson.admin_user_id
  904. this.persionDialogVisible = true
  905. }
  906. })
  907. },
  908. getCode(){
  909. var params = {
  910. phone:this.personForm.phone,
  911. }
  912. console.log("paramsowowo",params)
  913. getMobileCode(params).then(response=>{
  914. if(response.data.state == 1){
  915. var sign = response.data.data.sign
  916. console.log("sign",sign)
  917. this.$message.success("发送成功!")
  918. }
  919. })
  920. },
  921. savePersonEnterprise(){
  922. var params = {
  923. id:this.personForm.id,
  924. display_name:this.personForm.display_name,
  925. phone:this.personForm.phone,
  926. id_card_num:this.personForm.id_card_num,
  927. admin_user_id:this.personForm.admin_user_id,
  928. code:this.personForm.code,
  929. }
  930. console.log("param2o2o2o2",params)
  931. savePersionEnterPrise(params).then(response=>{
  932. if(response.data.state == 1){
  933. var personEnterPrse = response.data.data.personEnterPrse
  934. this.$message.success("认证成功")
  935. this.persionDialogVisible = false
  936. }
  937. })
  938. },
  939. toYinZhang(admin_user_id){
  940. CreatePersionSeal(admin_user_id).then(response=>{
  941. if(response.data.state == 1){
  942. var personSeal = response.data.data.personSeal
  943. this.$message.success("创建成功")
  944. }
  945. })
  946. },
  947. toShouQuan(admin_user_id){
  948. CreateNewEnterPrise(admin_user_id).then(response=>{
  949. if(response.data.state == 1){
  950. var newEnterPrise = response.data.data.newEnterPrise
  951. this.$message.success("保存成功!")
  952. }
  953. })
  954. },
  955. toTestThrity(){
  956. toTestThrity().then(response=>{
  957. if(response.data.state == 1){
  958. var sign = response.data.data.sign
  959. console.log("signwoowow",sign)
  960. }
  961. })
  962. },
  963. toEnd(){
  964. toEndEnterPrise().then(response=>{
  965. if(response.data.state == 1){
  966. var sign = response.data.data.sign
  967. this.$message.success("保存成功")
  968. }
  969. })
  970. },
  971. toWatch(){
  972. getEnterPriseDetail().then(response=>{
  973. if(response.data.state == 1){
  974. var sign = response.data.data.sign
  975. this.$message.success("保存成功")
  976. }
  977. })
  978. },
  979. toQianShu(admin_user_id){
  980. CreateQianshuUserName(admin_user_id).then(response=>{
  981. if(response.data.state==1){
  982. var sign = response.data.data.sign
  983. var userId = response.data.data.userId
  984. this.$message.success("签署成功!")
  985. }
  986. })
  987. },
  988. toSendInformaton(){
  989. CreateSKDSendInformation().then(response=>{
  990. if(response.data.state==1){
  991. var information = response.data.data.information
  992. var orderId = response.data.data.orderId
  993. }
  994. })
  995. },
  996. toSavePDFInformation(){
  997. toSavePDFInformation().then(response=>{
  998. if(response.data.state == 1){
  999. var information = response.data.data.information
  1000. var orderId = response.data.data.orderId
  1001. // var base64Img = 'data:image/png;base64'+","+orderId
  1002. // console.log("base64Img",base64Img)
  1003. // var imgFile = this.base64ImgtoFile(base64Img)
  1004. // this.downloadBlob(imgFile, 'test.png')
  1005. // console.log("imgFilewoowow",imgFile)
  1006. const blob = this.base64ToBlob(orderId, 'application/pdf');
  1007. this.openPdf(blob);
  1008. }
  1009. })
  1010. },
  1011. openPdf(blob) {
  1012. const objectUrl = URL.createObjectURL(blob);
  1013. const a = document.createElement('a');
  1014. a.href = objectUrl;
  1015. a.target = '_blank';
  1016. a.click();
  1017. URL.revokeObjectURL(objectUrl);
  1018. },
  1019. base64ToBlob(base64Data, contentType) {
  1020. contentType = contentType || '';
  1021. const sliceSize = 1024;
  1022. const byteCharacters = window.atob(base64Data);
  1023. const bytesLength = byteCharacters.length;
  1024. const slicesCount = Math.ceil(bytesLength / sliceSize);
  1025. const byteArrays = new Array(slicesCount);
  1026. for (let sliceIndex = 0; sliceIndex < slicesCount; ++sliceIndex) {
  1027. const begin = sliceIndex * sliceSize;
  1028. const end = Math.min(begin + sliceSize, bytesLength);
  1029. const bytes = new Array(end - begin);
  1030. for (let offset = begin, i = 0; offset < end; ++i, ++offset) {
  1031. bytes[i] = byteCharacters[offset].charCodeAt(0);
  1032. }
  1033. byteArrays[sliceIndex] = new Uint8Array(bytes);
  1034. }
  1035. return new Blob(byteArrays, {
  1036. type: contentType
  1037. });
  1038. },
  1039. downloadBlob(blob, filename) {
  1040. const url = URL.createObjectURL(blob);
  1041. const a = document.createElement('a');
  1042. a.href = url;
  1043. a.download = filename;
  1044. a.click();
  1045. URL.revokeObjectURL(url);
  1046. },
  1047. toCheckPDFInformation(){
  1048. toCheckPDFInformation().then(response=>{
  1049. if(response.data.data == 1){
  1050. var information = response.data.data.information
  1051. }
  1052. })
  1053. },
  1054. base64ImgtoFile(dataurl, filename = 'file') {
  1055. let arr = dataurl.split(',')
  1056. let mime = arr[0].match(/:(.*?);/)[1]
  1057. let suffix = mime.split('/')[1]
  1058. let bstr = atob(arr[1])
  1059. let n = bstr.length
  1060. let u8arr = new Uint8Array(n)
  1061. while (n--) {
  1062. u8arr[n] = bstr.charCodeAt(n)
  1063. }
  1064. return new File([u8arr], `${filename}.${suffix}`, {
  1065. type: mime
  1066. })
  1067. },
  1068. // toDrugInfo(){
  1069. // getdruginfoInformation().then(response=>{
  1070. // if(response.data.state==1){
  1071. // }
  1072. // })
  1073. // }
  1074. toJiaBan(){
  1075. UploadPrintOrder().then(response=>{
  1076. if(response.data.state ==1){
  1077. }
  1078. })
  1079. },
  1080. toAutoDrug(){
  1081. toAutoDrug().then(Response=>{
  1082. })
  1083. },
  1084. toAutoDiagnose(){
  1085. toAutoDiagnose().then(response=>{
  1086. })
  1087. }
  1088. },
  1089. watch: {
  1090. should_update_admins(should_change) {
  1091. if (should_change) {
  1092. this.requestAdminsWithPage(this.current_page);
  1093. }
  1094. }
  1095. }
  1096. };
  1097. </script>
  1098. <style rel="stylesheet/scss" lang="scss" scoped>
  1099. .el-button + .el-button {
  1100. margin-left: 0 !important;
  1101. }
  1102. </style>
  1103. <style>
  1104. .el-table td,
  1105. .el-table th.is-leaf,
  1106. .el-table--border,
  1107. .el-table--group {
  1108. border-color: #d0d3da;
  1109. }
  1110. .el-table--border::after,
  1111. .el-table--group::after,
  1112. .el-table::before {
  1113. background-color: #d0d3da;
  1114. }
  1115. </style>