externalQualityControl.vue 30 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701
  1. <template>
  2. <div>
  3. <div class="externalControl">
  4. <el-row type="flex">
  5. <el-col class="button">
  6. <div class="title">外部质量控制活动计划库/子表</div>
  7. <div v-if="readonly" />
  8. <div>
  9. <el-button type="primary" size="mini" icon="ibps-icon-add" @click="openDialog"> 添加</el-button>
  10. <el-button type="danger" size="mini" icon="ibps-icon-remove" @click="handleDelete"> 删除</el-button>
  11. <el-button type="success" size="mini" icon="ibps-icon-sign-in" @click="handleImport"> 导入数据</el-button>
  12. <el-button type="warning" size="mini" icon="ibps-icon-sign-out" @click="handleDownload"> 导出模版</el-button>
  13. </div>
  14. </el-col>
  15. </el-row>
  16. <el-row type="flex">
  17. <el-col>
  18. <el-table ref="external" :data="externalDataFilter" @selection-change="handleSelectionChange">
  19. <el-table-column type="selection" width="55" />
  20. <el-table-column label="验证类型" prop="biDuiLeiXing" />
  21. <el-table-column label="活动名称" prop="huoDongMingCheng" />
  22. <el-table-column label="序号" prop="xuHao" />
  23. <el-table-column label="能力验证提供者" prop="zuZhiDanWei">
  24. <template slot-scope="scope">
  25. <ibps-link-data
  26. v-model="scope.row.zuZhiDanWei"
  27. size="mini"
  28. readonly
  29. template-key="nlyztgzzly"
  30. :multiple="false"
  31. :temp-search="true"
  32. value-key="ming_cheng_"
  33. label-key="ming_cheng_"
  34. />
  35. </template>
  36. </el-table-column>
  37. <el-table-column label="室间质评组织方或室间比对方" prop="shiYanShiJianBiDu">
  38. <template slot-scope="scope">
  39. <ibps-link-data
  40. v-model="scope.row.shiYanShiJianBiDu"
  41. size="mini"
  42. template-key="sjzpzzfhsjbdfzly"
  43. readonly
  44. :temp-search="true"
  45. value-key="ming_cheng_"
  46. label-key="ming_cheng_"
  47. />
  48. </template>
  49. </el-table-column>
  50. <el-table-column label="项目名称" prop="xiangMuMingCheng" />
  51. <el-table-column label="组合名称" prop="zuTao" />
  52. <el-table-column label="领域代码" prop="lingYuDaiMa" />
  53. <el-table-column label="检验系统" prop="jianYanXiTong">
  54. <template slot-scope="scope">
  55. <ibps-custom-dialog
  56. v-model="scope.row.jianYanXiTong"
  57. size="mini"
  58. template-key="swckqjxzsbdhk"
  59. multiple
  60. disabled
  61. type="dialog"
  62. class="custom-dialog"
  63. placeholder="请选择"
  64. icon="el-icon-search"
  65. style="width:100%"
  66. />
  67. </template>
  68. </el-table-column>
  69. <el-table-column label="领域" prop="lingYu">
  70. <template slot-scope="scope">
  71. <ibps-link-data
  72. v-model="scope.row.lingYu"
  73. size="mini"
  74. template-key="lyzly"
  75. :multiple="false"
  76. readonly
  77. :temp-search="true"
  78. value-key="ming_cheng_"
  79. label-key="ming_cheng_"
  80. :dynamic-params="dynamicParams"
  81. />
  82. </template>
  83. </el-table-column>
  84. <el-table-column label="参加人员" prop="canJiaRenYuan">
  85. <template slot-scope="scope">
  86. <ibps-user-selector
  87. v-model="scope.row.canJiaRenYuan"
  88. type="user"
  89. readonly-text="text"
  90. disabled
  91. multiple
  92. size="mini"
  93. :filter="filter"
  94. filtrate
  95. />
  96. </template>
  97. </el-table-column>
  98. <el-table-column label="计划时间" prop="jiHuaShiJian" />
  99. <el-table-column label="备注" prop="beiZhu" />
  100. <el-table-column label="操作栏目" fixed="right">
  101. <template slot-scope="scope">
  102. <el-button type="text" icon="ibps-icon-edit" size="mini" @click="handleEdit(scope.row,scope.$index)">编辑</el-button>
  103. </template>
  104. </el-table-column>
  105. </el-table>
  106. <el-pagination
  107. layout="total,sizes,prev, pager, next,jumper"
  108. :current-page="requestPage.pageNo"
  109. :page-size="requestPage.limit"
  110. :page-sizes="[10,15,20,30,50,100]"
  111. :total="externalData.length"
  112. @size-change="handleSizeChange"
  113. @current-change="handleCurrentChange"
  114. />
  115. </el-col>
  116. </el-row>
  117. </div>
  118. <el-dialog
  119. ref="dialogFef"
  120. :title="isEdit?'编辑':'添加'"
  121. :visible.sync="dialogVisible"
  122. append-to-body
  123. width="80%"
  124. top="0vh"
  125. @close="closeDialog"
  126. >
  127. <el-form ref="formRef" :model="form" :rules="rules" label-width="110px" label-position="right">
  128. <el-form-item label="验证类型" prop="biDuiLeiXing">
  129. <el-radio-group v-model="form.biDuiLeiXing">
  130. <el-radio label="能力验证(PT)">能力验证(PT)</el-radio>
  131. <el-radio label="室间质评(EQA)">室间质评(EQA)</el-radio>
  132. <el-radio label="室间比对">室间比对</el-radio>
  133. </el-radio-group>
  134. </el-form-item>
  135. <el-row>
  136. <el-col :span="12">
  137. <el-form-item label="活动名称" prop="huoDongMingCheng">
  138. <el-input v-model="form.huoDongMingCheng" size="mini" placeholder="请输入活动名称" />
  139. </el-form-item>
  140. </el-col>
  141. <el-col :span="12">
  142. <el-form-item label="序号" prop="xuHao">
  143. <el-input v-model="form.xuHao" size="mini" placeholder="请输入序号" type="number" />
  144. </el-form-item>
  145. </el-col>
  146. </el-row>
  147. <el-tag v-if="false" type="warning" style="width: 100%;height: 30px;line-height: 30px;">室间质评组织方和室间比对方数据需点击“配置”按钮,选中室间质评组织方或室间比对方配置对应类型</el-tag>
  148. <el-form-item v-if="form.biDuiLeiXing=='能力验证(PT)'" label="能力验证提供者" prop="zuZhiDanWei">
  149. <ibps-link-data
  150. v-model="form.zuZhiDanWei"
  151. style="height: 28px;line-height: 28px;font-size: 14px;"
  152. size="mini"
  153. template-key="nlyztgzzly"
  154. :multiple="false"
  155. :temp-search="true"
  156. value-key="ming_cheng_"
  157. label-key="ming_cheng_"
  158. />
  159. </el-form-item>
  160. <el-form-item v-if="form.biDuiLeiXing=='室间质评(EQA)'||form.biDuiLeiXing=='室间比对'" label="室间质评组织方或室间比对方" prop="shiYanShiJianBiDu">
  161. <ibps-link-data
  162. v-model="form.shiYanShiJianBiDu"
  163. style="height: 28px;line-height: 28px;font-size: 14px;"
  164. size="mini"
  165. template-key="sjzpzzfhsjbdfzly"
  166. :multiple="false"
  167. :temp-search="true"
  168. value-key="ming_cheng_"
  169. label-key="ming_cheng_"
  170. />
  171. </el-form-item>
  172. <el-tag type="warning" style="width: 100%;height: 30px;line-height: 30px;">提交后系统将以项目名称字段的值为准,若是系统额外的项目,只需填写《检验项目》即可</el-tag>
  173. <el-row>
  174. <el-col :span="8">
  175. <el-form-item label="检验项目" prop="jianYanXiangMu">
  176. <ibps-custom-dialog
  177. v-model="form.jianYanXiangMu"
  178. size="mini"
  179. template-key="nlfwdhk"
  180. :disabled="false"
  181. type="dialog"
  182. class="custom-dialog"
  183. placeholder="请选择"
  184. icon="el-icon-search"
  185. style="width:100%"
  186. @change-link-data="jianYanXiangMuChange"
  187. />
  188. </el-form-item>
  189. </el-col>
  190. <el-col :span="8">
  191. <el-form-item label="项目名称" prop="xiangMuMingCheng">
  192. <el-input v-model="form.xiangMuMingCheng" size="mini" placeholder="请先选择检验项目" />
  193. </el-form-item>
  194. </el-col>
  195. <el-col :span="8">
  196. <el-form-item label="组合名称" prop="zuTao">
  197. <el-input v-model="form.zuTao" size="mini" placeholder="请输入" />
  198. </el-form-item>
  199. </el-col>
  200. </el-row>
  201. <el-row>
  202. <el-col :span="8">
  203. <el-form-item label="领域代码" prop="lingYuDaiMa">
  204. <el-input v-model="form.lingYuDaiMa" size="mini" placeholder="请先选择检验项目" />
  205. </el-form-item>
  206. </el-col>
  207. <el-col :span="8">
  208. <el-form-item label="领域" prop="lingYu">
  209. <ibps-link-data
  210. v-model="form.lingYu"
  211. style="height: 28px;line-height: 28px;font-size: 14px;"
  212. size="mini"
  213. template-key="lyzly"
  214. :multiple="false"
  215. :temp-search="true"
  216. value-key="ming_cheng_"
  217. label-key="ming_cheng_"
  218. :dynamic-params="dynamicParams"
  219. />
  220. </el-form-item>
  221. </el-col>
  222. <el-col :span="8">
  223. <el-form-item label="计划时间" prop="jiHuaShiJian">
  224. <el-input v-model="form.jiHuaShiJian" size="mini" placeholder="请输入" />
  225. </el-form-item>
  226. </el-col>
  227. </el-row>
  228. <el-row>
  229. <el-col :span="8">
  230. <el-form-item label="检验系统" prop="jianYanXiTong">
  231. <ibps-custom-dialog
  232. v-model="form.jianYanXiTong"
  233. size="mini"
  234. template-key="swckqjxzsbdhk"
  235. multiple
  236. :disabled="false"
  237. type="dialog"
  238. class="custom-dialog"
  239. placeholder="请选择"
  240. icon="el-icon-search"
  241. style="width:100%"
  242. />
  243. </el-form-item>
  244. </el-col>
  245. <el-col :span="8">
  246. <el-form-item label="参加人员" prop="canJiaRenYuan">
  247. <ibps-user-selector
  248. v-model="form.canJiaRenYuan"
  249. type="user"
  250. readonly-text="text"
  251. :disabled="false"
  252. multiple
  253. size="mini"
  254. style="width:100%"
  255. :filter="filter"
  256. filtrate
  257. />
  258. </el-form-item>
  259. </el-col>
  260. </el-row>
  261. <el-form-item label="备注" prop="beiZhu">
  262. <el-input v-model="form.beiZhu" size="mini" placeholder="请输入" />
  263. </el-form-item>
  264. </el-form>
  265. <div slot="footer" class="dialog-footer">
  266. <el-button type="primary" icon="ibps-icon-ok" @click="submitForm">确 定</el-button>
  267. <el-button type="danger" icon="ibps-icon-cancel" @click="closeDialog">取 消</el-button>
  268. </div>
  269. </el-dialog>
  270. <import-table
  271. :visible="importTableDialogVisible"
  272. title="导入"
  273. @close="(visible) => (importTableDialogVisible = visible)"
  274. @action-event="handleImportTableActionEvent"
  275. />
  276. </div>
  277. </template>
  278. <script>
  279. import { cloneDeep } from 'lodash'
  280. import importTable from '@/business/platform/form/formrender/dynamic-form/components/import-table'
  281. import ibpsUserSelector from '@/business/platform/org/selector'
  282. import IbpsLinkData from '@/business/platform/data/templaterender/link-data'
  283. import IbpsImport from '@/plugins/import'
  284. import IbpsExport from '@/plugins/export'
  285. import ActionUtils from '@/utils/action'
  286. import { downloadFile } from '@/business/platform/file/utils'
  287. export default {
  288. components: {
  289. IbpsCustomDialog: () => import('@/business/platform/data/templaterender/custom-dialog'),
  290. importTable,
  291. ibpsUserSelector,
  292. IbpsLinkData
  293. },
  294. props: {
  295. formData: {
  296. type: Object,
  297. default: () => {}
  298. },
  299. readonly: {
  300. type: Boolean,
  301. default: false
  302. },
  303. params: {
  304. type: Object,
  305. default: () => {}
  306. }
  307. },
  308. data () {
  309. return {
  310. isEdit: false,
  311. externalData: [],
  312. disabled: false,
  313. nodeId: '',
  314. show: true,
  315. requestPage: {
  316. limit: 10,
  317. pageNo: 1
  318. },
  319. form: {
  320. biDuiLeiXing: '',
  321. huoDongMingCheng: '',
  322. xuHao: '',
  323. zuZhiDanWei: '',
  324. shiYanShiJianBiDu: '',
  325. xiangMuMingCheng: '',
  326. zuTao: '',
  327. lingYuDaiMa: '',
  328. lingYu: '',
  329. jiHuaShiJian: '',
  330. jianYanXiTong: '',
  331. canJiaRenYuan: '',
  332. beiZhu: '',
  333. jianYanXiangMu: ''
  334. },
  335. rules: {
  336. biDuiLeiXing: [
  337. { required: true, message: '请选择验证类型', trigger: 'change' }
  338. ],
  339. huoDongMingCheng: [
  340. { required: true, message: '请输入活动名称', trigger: 'blur' }
  341. ],
  342. // xuHao: [
  343. // { required: true, message: '请输入序号', trigger: 'blur' }
  344. // ],
  345. zuZhiDanWei: [
  346. { required: true, message: '请选择', trigger: 'change' }
  347. ],
  348. shiYanShiJianBiDu: [
  349. { required: true, message: '请选择', trigger: 'change' }
  350. ],
  351. xiangMuMingCheng: [
  352. { required: true, message: '请输入', trigger: 'blur' }
  353. ],
  354. lingYu: [
  355. { required: true, message: '请选择领域', trigger: 'change' }
  356. ],
  357. canJiaRenYuan: [
  358. { required: true, message: '请选择参加人员', trigger: 'change' }
  359. ],
  360. jiHuaShiJian: [
  361. { required: true, message: '请输入计划时间', trigger: 'blur' }
  362. ]
  363. },
  364. dialogVisible: false,
  365. importTableDialogVisible: false,
  366. multipleSelection: [],
  367. filter: [{
  368. descVal: '1',
  369. includeSub: true,
  370. old: 'position',
  371. partyId: this.$store.getters.userInfo.employee.positions,
  372. partyName: '',
  373. scriptContent: '',
  374. type: 'user',
  375. userType: 'position'
  376. }],
  377. dynamicParams: {
  378. di_dian_san_: this.$store.getters.level.second || this.$store.getters.level.first
  379. },
  380. rowIndex: 0,
  381. paramsData: {},
  382. isFirst: true
  383. }
  384. },
  385. computed: {
  386. externalDataFilter () {
  387. return this.externalData.slice((this.requestPage.pageNo - 1) * (this.requestPage.limit), (this.requestPage.pageNo - 1) * (this.requestPage.limit) + this.requestPage.limit)
  388. }
  389. },
  390. watch: {
  391. 'form.biDuiLeiXing': {
  392. handler (value, old) {
  393. if (value === '能力验证(PT)') {
  394. this.form.shiYanShiJianBiDu = ''
  395. } else if (value === '室间质评(EQA)') {
  396. this.form.zuZhiDanWei = ''
  397. } else if (value === '室间比对') {
  398. this.form.zuZhiDanWei = ''
  399. }
  400. }
  401. },
  402. 'formData.sjzphdjhylxqb': {
  403. handler (value, old) {
  404. if (value && value.length) {
  405. this.externalData = JSON.parse(JSON.stringify(value))
  406. this.isFirst = false
  407. }
  408. }
  409. }
  410. },
  411. methods: {
  412. jianYanXiangMuChange (key, data) {
  413. this.form.xiangMuMingCheng = data.jian_yan_xiang_mu
  414. this.form.lingYuDaiMa = data.xu_hao_
  415. this.form.lingYu = data.zhuan_ye_
  416. },
  417. handleSelectionChange (val) {
  418. this.multipleSelection = val
  419. },
  420. handleDelete () {
  421. this.$confirm('确定删除当前选中数据', '提示', {
  422. confirmButtonText: '确定',
  423. cancelButtonText: '取消',
  424. type: 'warning'
  425. }).then(() => {
  426. if (this.multipleSelection.length > 0) {
  427. this.externalData = this.externalData.filter(row => !this.multipleSelection.includes(row))
  428. this.$emit('change-data', 'sjzphdjhylxqb', this.externalData)
  429. } else {
  430. this.$message.warning('请选择数据')
  431. }
  432. })
  433. },
  434. closeDialog () {
  435. this.dialogVisible = false
  436. },
  437. openDialog () {
  438. this.dialogVisible = true
  439. this.isEdit = false
  440. this.form = {
  441. biDuiLeiXing: '能力验证(PT)',
  442. huoDongMingCheng: '',
  443. xuHao: '',
  444. zuZhiDanWei: '',
  445. shiYanShiJianBiDu: '',
  446. xiangMuMingCheng: '',
  447. zuTao: '',
  448. lingYuDaiMa: '',
  449. lingYu: '',
  450. jiHuaShiJian: '',
  451. jianYanXiTong: '',
  452. canJiaRenYuan: '',
  453. beiZhu: '',
  454. jianYanXiangMu: ''
  455. }
  456. },
  457. handleEdit (row, index) {
  458. this.isEdit = true
  459. this.dialogVisible = true
  460. this.rowIndex = index
  461. this.form = cloneDeep(row)
  462. console.log(cloneDeep(this.form))
  463. },
  464. submitForm () {
  465. this.$refs.formRef.validate((valid) => {
  466. if (valid) {
  467. const {
  468. biDuiLeiXing, huoDongMingCheng, xuHao, zuZhiDanWei, shiYanShiJianBiDu, xiangMuMingCheng, zuTao, lingYuDaiMa, lingYu, jiHuaShiJian, jianYanXiTong, canJiaRenYuan, beiZhu, jianYanXiangMu } = this.form
  469. if (this.isEdit) {
  470. // this.externalData[this.rowIndex] = this.form
  471. // this.$set(this.externalData, this.rowIndex, this.form)
  472. this.externalData.splice(this.rowIndex, 1, this.form)
  473. } else {
  474. this.externalData.push({
  475. biDuiLeiXing,
  476. huoDongMingCheng,
  477. xuHao,
  478. zuZhiDanWei,
  479. shiYanShiJianBiDu,
  480. xiangMuMingCheng,
  481. zuTao,
  482. lingYuDaiMa,
  483. lingYu,
  484. jiHuaShiJian,
  485. jianYanXiTong,
  486. canJiaRenYuan,
  487. beiZhu,
  488. jianYanXiangMu
  489. })
  490. }
  491. this.$message.success(`表单提交成功!`)
  492. this.dialogVisible = false
  493. this.$emit('change-data', 'sjzphdjhylxqb', this.externalData)
  494. } else {
  495. this.$message.error('表单验证失败,请检查输入!')
  496. return false
  497. }
  498. })
  499. },
  500. handleImport () {
  501. this.importTableDialogVisible = true
  502. },
  503. getShebList () {
  504. const sbsql = `select id_, yuan_she_bei_bian from t_sbdj where yuan_she_bei_bian is not null and yuan_she_bei_bian != ''`
  505. return new Promise((resolve, reject) => {
  506. this.$common.request('sql', sbsql).then(res => {
  507. const arr = res.variables.data
  508. resolve(arr)
  509. }).catch(error => {
  510. reject(error)
  511. })
  512. })
  513. },
  514. getSb (deviceList, deviceCode) {
  515. if (!deviceCode) {
  516. return ''
  517. }
  518. const codeList = deviceCode.split(',')
  519. const idList = []
  520. codeList.forEach(n => {
  521. const device = deviceList.find(item => item.yuan_she_bei_bian === n.trim())
  522. idList.push(device?.id_)
  523. })
  524. return idList.join(',')
  525. },
  526. handleDownload () {
  527. IbpsExport.excel({
  528. columns: this.getDataValue(),
  529. data: [],
  530. nameKey: 'name',
  531. title: '外部质量控制活动计划'
  532. }).then(() => {
  533. ActionUtils.success('导出成功')
  534. })
  535. // downloadFile({ id: 'xxx', fileName: '室间质评活动计划一览表', ext: 'xlsx' })
  536. },
  537. getDataValue (data) {
  538. const columns = [
  539. {
  540. field_name: 'biDuiLeiXing',
  541. label: '验证类型',
  542. name: 'biDuiLeiXing'
  543. },
  544. {
  545. field_name: 'huoDongMingCheng',
  546. label: '活动名称',
  547. name: 'huoDongMingCheng'
  548. },
  549. {
  550. field_name: 'zuZhiDanWei',
  551. label: '能力验证提供者',
  552. name: 'zuZhiDanWei'
  553. },
  554. {
  555. field_name: 'shiYanShiJianBiDu',
  556. label: '室间质评组织方或室间比对方',
  557. name: 'shiYanShiJianBiDu'
  558. },
  559. {
  560. field_name: 'jianYanXiTong',
  561. label: '检验系统(填原设备编号)',
  562. name: 'jianYanXiTong'
  563. },
  564. {
  565. field_name: 'lingYu',
  566. label: '领域',
  567. name: 'lingYu'
  568. },
  569. {
  570. field_name: 'lingYuDaiMa',
  571. label: '领域代码',
  572. name: 'lingYuDaiMa'
  573. },
  574. {
  575. field_name: 'canJiaRenYuan',
  576. label: '参加人员',
  577. name: 'canJiaRenYuan'
  578. },
  579. {
  580. field_name: 'xuHao',
  581. label: '序号',
  582. name: 'xuHao'
  583. },
  584. {
  585. field_name: 'xiangMuMingCheng',
  586. label: '项目名称',
  587. name: 'xiangMuMingCheng'
  588. },
  589. {
  590. field_name: 'zuTao',
  591. label: '组合名称',
  592. name: 'zuTao'
  593. },
  594. {
  595. field_name: 'jiHuaShiJian',
  596. label: '计划时间',
  597. name: 'jiHuaShiJian'
  598. },
  599. {
  600. field_name: 'beiZhu',
  601. label: '备注',
  602. name: 'beiZhu'
  603. }
  604. ]
  605. return columns
  606. },
  607. getKeys (data) {
  608. return Array.isArray(data) ? data.reduce((acc, item) => ({ ...acc, [item.label]: item.name }), {}) : {}
  609. },
  610. async handleImportTableActionEvent (file, options) {
  611. const deviceList = await this.getShebList() // 获取所有设备
  612. const nowDate = await this.$common.getDateNow(10)
  613. const defaultPlanDate = await this.$common.getFormatDate('string', 10, await this.$common.getDate('month', 1, nowDate))
  614. IbpsImport.xlsx(file, options).then(({ header, results }) => {
  615. const list = []
  616. const keys = this.getKeys(this.getDataValue())
  617. const { userList } = this.$store.getters || {}
  618. results.forEach(item => {
  619. const obj = {}
  620. Object.keys(item).forEach(key => {
  621. if (keys[key]) {
  622. obj[keys[key]] = item[key]
  623. }
  624. })
  625. list.push(obj)
  626. })
  627. list.forEach(async item => {
  628. item.jiHuaShiJian = item.jiHuaShiJian || defaultPlanDate
  629. item.canJiaRenYuan = await this.getUserId(userList, item.canJiaRenYuan)
  630. item.jianYanXiTong = await this.getSb(deviceList, item.jianYanXiTong)
  631. })
  632. setTimeout(() => {
  633. this.$nextTick(() => {
  634. this.externalData = this.externalData.concat(list)
  635. this.$refs.external && this.$refs.external.$forceUpdate()
  636. console.log(JSON.parse(JSON.stringify(this.externalData)), 'console.log(this.externalData)')
  637. this.$emit('change-data', 'sjzphdjhylxqb', this.externalData)
  638. })
  639. })
  640. this.importTableDialogVisible = false
  641. })
  642. },
  643. getUserId (userList, userName) {
  644. if (!userName) {
  645. return ''
  646. }
  647. const nameList = userName.split(',')
  648. const idList = []
  649. nameList.forEach(n => {
  650. const user = userList.find(item => item.userName === n.trim())
  651. idList.push(user?.userId)
  652. })
  653. return idList.join(',')
  654. },
  655. // 当前页码改变
  656. handleCurrentChange (val) {
  657. this.requestPage.pageNo = val
  658. },
  659. // 页码选择器改变
  660. handleSizeChange (val) {
  661. this.requestPage.limit = val
  662. this.requestPage.pageNo = 1
  663. }
  664. }
  665. }
  666. </script>
  667. <style lang="scss" scoped>
  668. .externalControl{
  669. margin-bottom: 20px;
  670. .button{
  671. display: flex;
  672. justify-content: space-between;
  673. padding: 0px 0px 0px 15px;
  674. background: #f0ffff;
  675. .title {
  676. color: #999;
  677. font-size: 12px;
  678. font-weight: bold;
  679. margin-bottom: 0;
  680. }
  681. .el-button {
  682. margin: 0;
  683. }
  684. }
  685. }
  686. ::v-deep .el-dialog__body {
  687. height: 70vh;
  688. }
  689. ::v-deep .el-input__inner {
  690. height: 28px;
  691. line-height: 28px;
  692. }
  693. .dialog-footer {
  694. text-align: center;
  695. }
  696. .el-form {
  697. padding: 15px;
  698. }
  699. </style>