You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

839 lines
27 KiB

3 years ago
1 year ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
  1. <template>
  2. <div class="mod-config">
  3. <!-- <div>-->
  4. <!-- <span @click="favoriteFunction()">-->
  5. <!-- <icon-svg :name="favorite?'xiangqufill':'xiangqu'" class="sl-svg"></icon-svg>-->
  6. <!-- </span>-->
  7. <!-- </div>-->
  8. <el-form :inline="true" label-position="top" :model="searchData" @keyup.enter.native="getDataList()">
  9. <el-form-item :label="'BU'">
  10. <el-select v-model="searchData.buDesc" placeholder="请选择" clearable style="width: 130px">
  11. <el-option
  12. v-for = "i in userBuList"
  13. :key = "i.buNo"
  14. :label = "i.buDesc"
  15. :value = "i.buDesc">
  16. </el-option>
  17. </el-select>
  18. </el-form-item>
  19. <el-form-item :label="'制造商编码'">
  20. <el-input v-model="searchData.manufacturerID" style="width: 120px"></el-input>
  21. </el-form-item>
  22. <el-form-item :label="'制造商名称'">
  23. <el-input v-model="searchData.manufacturerName" style="width: 120px"></el-input>
  24. </el-form-item>
  25. <el-form-item :label="'在用'">
  26. <el-select filterable v-model="searchData.active" style="width: 130px">
  27. <el-option label="全部" value=""></el-option>
  28. <el-option label="是" value="Y"></el-option>
  29. <el-option label="否" value="N"></el-option>
  30. </el-select>
  31. </el-form-item>
  32. <el-form-item :label="' '">
  33. <el-button v-if="!authSearch" @click="getDataList()">查询</el-button>
  34. <el-button v-if="!authSave" type="primary" @click="addModal()">新增</el-button>
  35. <download-excel
  36. :fields="fields()"
  37. :data="exportData"
  38. type="xls"
  39. :name="exportName"
  40. :header="exportHeader"
  41. :footer="exportFooter"
  42. :fetch="createExportData"
  43. :before-generate="startDownload"
  44. :before-finish="finishDownload"
  45. worksheet="导出信息"
  46. class="el-button el-button--primary el-button--medium">
  47. {{ "导出" }}
  48. </download-excel>
  49. </el-form-item>
  50. </el-form>
  51. <el-table
  52. :height="height"
  53. :data="dataList"
  54. border
  55. style="width: 100%;">
  56. <el-table-column
  57. v-for="(item,index) in columnList" :key="index"
  58. :sortable="item.columnSortable"
  59. :prop="item.columnProp"
  60. :header-align="item.headerAlign"
  61. :show-overflow-tooltip="item.showOverflowTooltip"
  62. :align="item.align"
  63. :fixed="item.fixed==''?false:item.fixed"
  64. :min-width="item.columnWidth"
  65. :label="item.columnLabel">
  66. <template slot-scope="scope">
  67. <span v-if="!item.columnHidden"> {{ scope.row[item.columnProp] }}</span>
  68. <span v-if="item.columnImage"><img :src="scope.row[item.columnProp]" style="width: 100px; height: 80px"/></span>
  69. </template>
  70. </el-table-column>
  71. <el-table-column
  72. fixed="right"
  73. header-align="center"
  74. align="center"
  75. width="100"
  76. label="操作">
  77. <template slot-scope="scope">
  78. <a v-if="!authUpdate" type="text" size="small" @click="updateModal(scope.row)">修改</a>
  79. <a v-if="!authDelete" type="text" size="small" @click="deleteManufacturer(scope.row)">删除</a>
  80. </template>
  81. </el-table-column>
  82. </el-table>
  83. <el-pagination
  84. @size-change="sizeChangeHandle"
  85. @current-change="currentChangeHandle"
  86. :current-page="pageIndex"
  87. :page-sizes="[20, 50, 100, 200, 500]"
  88. :page-size="pageSize"
  89. :total="totalPage"
  90. layout="total, sizes, prev, pager, next, jumper">
  91. </el-pagination>
  92. <el-dialog title="制造商" :close-on-click-modal="false" v-drag :visible.sync="modalFlag" width="430px">
  93. <el-form :inline="true" label-position="top" :model="modalData" :rules="rules" style="margin-left: 7px;margin-top: -5px;">
  94. <el-form-item label="BU" prop="bu" :rules="rules.bu">
  95. <el-select v-model="modalData.bu" placeholder="请选择" :disabled="modalDisableFlag" style="width: 230px">
  96. <el-option
  97. v-for = "i in userBuList"
  98. :key = "i.buNo"
  99. :label = "i.sitename"
  100. :value = "i.buNo">
  101. <span style="float: left;width: 100px">{{ i.sitename }}</span>
  102. <span style="float: right; color: #8492a6;white-space:nowrap;overflow:hidden;text-overflow:ellipsis; font-size: 11px;width: 60px">{{ i.buDesc }}</span>
  103. </el-option>
  104. </el-select>
  105. </el-form-item>
  106. <el-form-item label="是否在用:" prop="active" :rules="rules.activeType">
  107. <el-select filterable v-model="modalData.active" style="width: 140px">
  108. <el-option label="是" value="Y"></el-option>
  109. <el-option label="否" value="N"></el-option>
  110. </el-select>
  111. </el-form-item>
  112. </el-form>
  113. <el-form :inline="true" label-position="top" :model="modalData" :rules="rules" style="margin-left: 7px;margin-top: -5px;">
  114. <el-form-item label="制造商编码:" prop="manufacturerID" :rules="rules.manufacturerIdType">
  115. <el-input v-model="modalData.manufacturerID" :disabled="modalDisableFlag" style="width: 140px"></el-input>
  116. </el-form-item>
  117. <el-form-item label="制造商名称:" prop="manufacturerName" :rules="rules.manufacturerNameType">
  118. <el-input v-model="modalData.manufacturerName" :disabled="modalDisableFlag" style="width: 230px"></el-input>
  119. </el-form-item>
  120. </el-form>
  121. <el-form :inline="true" label-position="top" :model="modalData" :rules="rules" style="margin-left: 7px;margin-top: 0px;">
  122. <el-form-item label="联系人">
  123. <el-input v-model="modalData.contact" style="width: 140px"></el-input>
  124. </el-form-item>
  125. <el-form-item label="地址">
  126. <el-input v-model="modalData.address" style="width: 230px"></el-input>
  127. </el-form-item>
  128. </el-form>
  129. <el-form :inline="true" label-position="top" style="margin-left: 7px;margin-top: 0px;">
  130. <el-form-item label="电话">
  131. <el-input v-model="modalData.phone" style="width: 140px"></el-input>
  132. </el-form-item>
  133. <el-form-item label="邮箱">
  134. <el-input v-model="modalData.email" style="width: 230px"></el-input>
  135. </el-form-item>
  136. </el-form>
  137. <el-form :inline="true" label-position="top" style="margin-left: 7px;margin-top: 0px;">
  138. <el-form-item label="备注">
  139. <el-input
  140. type="textarea"
  141. v-model="modalData.remark"
  142. :rows="3"
  143. resize='none'
  144. show-word-limit
  145. style="width: 388px;height: 60px">
  146. </el-input>
  147. </el-form-item>
  148. </el-form>
  149. <el-footer style="height:40px;margin-top: 50px;text-align:center">
  150. <el-button type="primary" @click="saveData()">保存</el-button>
  151. <el-button type="primary" @click="modalFlag = false">关闭</el-button>
  152. </el-footer>
  153. </el-dialog>
  154. </div>
  155. </template>
  156. <script>
  157. import {
  158. eamManufacturerSearch,
  159. eamManufacturerSave,
  160. eamManufacturerEdit,
  161. eamManufacturerDelete,
  162. getSiteAndBuByUserName
  163. } from "@/api/eam/eam.js"
  164. import {userFavoriteList, saveUserFavorite, removeUserFavorite} from '@/api/userFavorite.js'
  165. import {
  166. getTableDefaultListLanguage,
  167. getTableUserListLanguage,
  168. } from "@/api/table.js"
  169. export default {
  170. watch: {
  171. searchData: {
  172. deep: true,
  173. handler: function (newV, oldV) {
  174. this.searchData.manufacturerID = this.searchData.manufacturerID.toUpperCase()
  175. }
  176. },
  177. modalData: {
  178. deep: true,
  179. handler: function (newV, oldV) {
  180. this.modalData.manufacturerID = this.modalData.manufacturerID.toUpperCase()
  181. }
  182. }
  183. },
  184. data () {
  185. return {
  186. // 是否收藏
  187. favorite: false,
  188. // 导出 start
  189. exportData: [],
  190. exportName: "设备制造商" + this.dayjs().format('YYYYMMDDHHmmss'),
  191. exportHeader: ["设备制造商"],
  192. exportFooter: [],
  193. exportList: [],
  194. // 导出 end
  195. searchData: {
  196. site: '',
  197. userName: this.$store.state.user.name,
  198. manufacturerID: '',
  199. manufacturerName: '',
  200. buDesc: '',
  201. active: 'Y',
  202. page: 1,
  203. limit: 10,
  204. },
  205. height: 200,
  206. pageIndex: 1,
  207. pageSize: 20,
  208. totalPage: 0,
  209. dataList: [],
  210. dataListSelections: [],
  211. modalFlag: false,
  212. modalDisableFlag: false,
  213. modalData: {
  214. flag: '',
  215. bu: '',
  216. site: '',
  217. manufacturerID: '',
  218. manufacturerName: '',
  219. active: '',
  220. contact: '',
  221. phone: '',
  222. address: '',
  223. email: '',
  224. remark: '',
  225. updateBy: this.$store.state.user.name,
  226. createBy: this.$store.state.user.name,
  227. },
  228. departmentList: [],
  229. // 展示列集
  230. columnList: [
  231. {
  232. userId: this.$store.state.user.name,
  233. functionId: 101001005,
  234. serialNumber: '101001005Table1BuDesc',
  235. tableId: "101001005Table1",
  236. tableName: "设备制造商表",
  237. columnProp: 'buDesc',
  238. headerAlign: "center",
  239. align: "center",
  240. columnLabel: 'BU',
  241. columnHidden: false,
  242. columnImage: false,
  243. columnSortable: false,
  244. sortLv: 0,
  245. status: true,
  246. fixed: '',
  247. columnWidth: 100,
  248. },
  249. {
  250. userId: this.$store.state.user.name,
  251. functionId: 101001005,
  252. serialNumber: '101001005Table1ManufacturerID',
  253. tableId: "101001005Table1",
  254. tableName: "设备制造商表",
  255. columnProp: 'manufacturerID',
  256. headerAlign: "center",
  257. align: "center",
  258. columnLabel: '制造商编码',
  259. columnHidden: false,
  260. columnImage: false,
  261. columnSortable: false,
  262. sortLv: 0,
  263. status: true,
  264. fixed: '',
  265. columnWidth: 120,
  266. },
  267. {
  268. userId: this.$store.state.user.name,
  269. functionId: 101001005,
  270. serialNumber: '101001005Table1ManufacturerName',
  271. tableId: "101001005Table1",
  272. tableName: "设备制造商表",
  273. columnProp: 'manufacturerName',
  274. headerAlign: "center",
  275. align: "left",
  276. columnLabel: '制造商名称',
  277. columnHidden: false,
  278. columnImage: false,
  279. columnSortable: false,
  280. sortLv: 0,
  281. status: true,
  282. fixed: '',
  283. columnWidth: 200,
  284. },
  285. {
  286. userId: this.$store.state.user.name,
  287. functionId: 101001005,
  288. serialNumber: '101001005Table1Active',
  289. tableId: "101001005Table1",
  290. tableName: "设备制造商表",
  291. columnProp: 'active',
  292. headerAlign: "center",
  293. align: "center",
  294. columnLabel: '在用',
  295. columnHidden: false,
  296. columnImage: false,
  297. columnSortable: false,
  298. sortLv: 0,
  299. status: true,
  300. fixed: '',
  301. columnWidth: 100,
  302. },
  303. {
  304. userId: this.$store.state.user.name,
  305. functionId: 101001005,
  306. serialNumber: '101001005Table1Contact',
  307. tableId: "101001005Table1",
  308. tableName: "设备制造商表",
  309. columnProp: 'contact',
  310. headerAlign: "center",
  311. align: "center",
  312. columnLabel: '联系人',
  313. columnHidden: false,
  314. columnImage: false,
  315. columnSortable: false,
  316. sortLv: 0,
  317. status: true,
  318. fixed: '',
  319. columnWidth: 100,
  320. },
  321. {
  322. userId: this.$store.state.user.name,
  323. functionId: 101001005,
  324. serialNumber: '101001005Table1Phone',
  325. tableId: "101001005Table1",
  326. tableName: "设备制造商表",
  327. columnProp: 'phone',
  328. headerAlign: "center",
  329. align: "center",
  330. columnLabel: '电话',
  331. columnHidden: false,
  332. columnImage: false,
  333. columnSortable: false,
  334. sortLv: 0,
  335. status: true,
  336. fixed: '',
  337. columnWidth: 130,
  338. },
  339. {
  340. userId: this.$store.state.user.name,
  341. functionId: 101001005,
  342. serialNumber: '101001005Table1Address',
  343. tableId: "101001005Table1",
  344. tableName: "设备制造商表",
  345. columnProp: 'address',
  346. headerAlign: "center",
  347. align: "left",
  348. columnLabel: '地址',
  349. columnHidden: false,
  350. columnImage: false,
  351. columnSortable: false,
  352. sortLv: 0,
  353. status: true,
  354. fixed: '',
  355. columnWidth: 200,
  356. },
  357. {
  358. userId: this.$store.state.user.name,
  359. functionId: 101001005,
  360. serialNumber: '101001005Table1Email',
  361. tableId: "101001005Table1",
  362. tableName: "设备制造商表",
  363. columnProp: 'email',
  364. headerAlign: "center",
  365. align: "left",
  366. columnLabel: '邮箱',
  367. columnHidden: false,
  368. columnImage: false,
  369. columnSortable: false,
  370. sortLv: 0,
  371. status: true,
  372. fixed: '',
  373. columnWidth: 130,
  374. },
  375. {
  376. userId: this.$store.state.user.name,
  377. functionId: 101001005,
  378. serialNumber: '101001005Table1Remark',
  379. tableId: "101001005Table1",
  380. tableName: "设备制造商表",
  381. columnProp: 'remark',
  382. headerAlign: "center",
  383. align: "left",
  384. columnLabel: '备注',
  385. columnHidden: false,
  386. columnImage: false,
  387. columnSortable: false,
  388. sortLv: 0,
  389. status: true,
  390. fixed: '',
  391. columnWidth: 200,
  392. },
  393. {
  394. userId: this.$store.state.user.name,
  395. functionId: 101001005,
  396. serialNumber: '101001005Table1CreateDate',
  397. tableId: "101001005Table1",
  398. tableName: "设备制造商表",
  399. columnProp: 'createDate',
  400. headerAlign: "center",
  401. align: "center",
  402. columnLabel: '创建时间',
  403. columnHidden: false,
  404. columnImage: false,
  405. columnSortable: false,
  406. sortLv: 0,
  407. status: true,
  408. fixed: '',
  409. columnWidth: 170,
  410. },
  411. {
  412. userId: this.$store.state.user.name,
  413. functionId: 101001005,
  414. serialNumber: '101001005Table1CreateBy',
  415. tableId: "101001005Table1",
  416. tableName: "设备制造商表",
  417. columnProp: 'createBy',
  418. headerAlign: "center",
  419. align: "center",
  420. columnLabel: '创建人',
  421. columnHidden: false,
  422. columnImage: false,
  423. columnSortable: false,
  424. sortLv: 0,
  425. status: true,
  426. fixed: '',
  427. columnWidth: 100,
  428. },
  429. {
  430. userId: this.$store.state.user.name,
  431. functionId: 101001005,
  432. serialNumber: '101001005Table1UpdateDate',
  433. tableId: "101001005Table1",
  434. tableName: "设备制造商表",
  435. columnProp: 'updateDate',
  436. headerAlign: "center",
  437. align: "center",
  438. columnLabel: '更新时间',
  439. columnHidden: false,
  440. columnImage: false,
  441. columnSortable: false,
  442. sortLv: 0,
  443. status: true,
  444. fixed: '',
  445. columnWidth: 170,
  446. },
  447. {
  448. userId: this.$store.state.user.name,
  449. functionId: 101001005,
  450. serialNumber: '101001005Table1UpdateBy',
  451. tableId: "101001005Table1",
  452. tableName: "设备制造商表",
  453. columnProp: 'updateBy',
  454. headerAlign: "center",
  455. align: "center",
  456. columnLabel: '更新人',
  457. columnHidden: false,
  458. columnImage: false,
  459. columnSortable: false,
  460. sortLv: 0,
  461. status: true,
  462. fixed: '',
  463. columnWidth: 100,
  464. },
  465. ],
  466. levelList: [],
  467. rules: {
  468. manufacturerIdType:[
  469. {
  470. required: true,
  471. message: ' ',
  472. trigger: ['blur','change']
  473. }
  474. ],
  475. manufacturerNameType:[
  476. {
  477. required: true,
  478. message: ' ',
  479. trigger: ['blur','change']
  480. }
  481. ],
  482. activeType:[
  483. {
  484. required: true,
  485. message: ' ',
  486. trigger: ['blur','change']
  487. }
  488. ],
  489. bu:[
  490. {
  491. required: true,
  492. message: ' ',
  493. trigger: ['blur','change']
  494. }
  495. ]
  496. },
  497. userBuList: [],
  498. authSearch: false,
  499. authSave: false,
  500. authUpdate: false,
  501. authDelete: false,
  502. menuId: this.$route.meta.menuId,
  503. }
  504. },
  505. mounted () {
  506. this.$nextTick(() => {
  507. this.height = window.innerHeight - 210
  508. })
  509. },
  510. created () {
  511. // 按钮控制
  512. this.getButtonAuthData()
  513. // 获取用户的 site 和 bu
  514. this.getSiteAndBuByUserName()
  515. // 校验用户是否收藏
  516. this.favoriteIsOk()
  517. // 动态列
  518. this.getTableUserColumn(this.$route.meta.menuId+'table1',1)
  519. if (!this.authSearch) {
  520. // 获取数据列表
  521. this.getDataList()
  522. }
  523. },
  524. methods: {
  525. // 获取用户的bu
  526. getSiteAndBuByUserName () {
  527. let tempData = {
  528. username: this.$store.state.user.name,
  529. }
  530. getSiteAndBuByUserName(tempData).then(({data}) => {
  531. if (data.code === 0) {
  532. this.userBuList = data.rows
  533. }
  534. })
  535. },
  536. // 校验用户是否收藏
  537. favoriteIsOk () {
  538. let userFavorite = {
  539. userId: this.$store.state.user.id,
  540. languageCode: this.$i18n.locale
  541. }
  542. userFavoriteList(userFavorite).then(({data}) => {
  543. for (let i = 0; i < data.list.length; i++) {
  544. if(this.$route.meta.menuId === data.list[i].menuId){
  545. this.favorite = true
  546. }
  547. }
  548. })
  549. },
  550. // 收藏 OR 取消收藏
  551. favoriteFunction () {
  552. let userFavorite = {
  553. userId: this.$store.state.user.id,
  554. functionId: this.$route.meta.menuId,
  555. }
  556. if (this.favorite) {
  557. removeUserFavorite(userFavorite).then(({data}) => {
  558. this.$message.success(data.msg)
  559. this.favorite = false
  560. })
  561. } else {
  562. // 收藏
  563. saveUserFavorite(userFavorite).then(({data}) => {
  564. this.$message.success(data.msg)
  565. this.favorite = true
  566. })
  567. }
  568. },
  569. //导出excel
  570. async createExportData () {
  571. this.searchData.limit = -1
  572. this.searchData.page = 1
  573. await eamManufacturerSearch(this.searchData).then(({data}) => {
  574. this.exportList = data.page.list
  575. })
  576. return this.exportList
  577. },
  578. startDownload () {},
  579. finishDownload () {},
  580. fields () {
  581. let json = "{"
  582. this.columnList.forEach((item, index) => {
  583. if (index == this.columnList.length - 1) {
  584. json += "\"" + item.columnLabel + "\"" + ":" + "\"" + item.columnProp + "\""
  585. } else {
  586. json += "\"" + item.columnLabel + "\"" + ":" + "\"" + item.columnProp + "\"" + ","
  587. }
  588. })
  589. json += "}"
  590. let s = eval("(" + json + ")")
  591. return s
  592. },
  593. // 获取数据列表
  594. getDataList () {
  595. this.searchData.limit = this.pageSize
  596. this.searchData.page = this.pageIndex
  597. eamManufacturerSearch(this.searchData).then(({data}) => {
  598. if (data.code === 0) {
  599. this.dataList = data.page.list
  600. this.pageIndex = data.page.currPage
  601. this.pageSize = data.page.pageSize
  602. this.totalPage = data.page.totalCount
  603. }
  604. })
  605. },
  606. // 每页数
  607. sizeChangeHandle (val) {
  608. this.pageSize = val
  609. this.pageIndex = 1
  610. this.getDataList()
  611. },
  612. // 当前页
  613. currentChangeHandle (val) {
  614. this.pageIndex = val
  615. this.getDataList()
  616. },
  617. // 多选
  618. selectionChangeHandle (val) {
  619. this.dataListSelections = val
  620. },
  621. addModal () {
  622. this.modalData = {
  623. flag: '1',
  624. bu: this.userBuList[0].buNo,
  625. site: '',
  626. manufacturerID: '',
  627. manufacturerName: '',
  628. active: 'Y',
  629. contact: '',
  630. phone: '',
  631. address: '',
  632. email: '',
  633. remark: '',
  634. createBy: this.$store.state.user.name,
  635. updateBy: this.$store.state.user.name,
  636. }
  637. this.modalDisableFlag = false
  638. this.modalFlag = true
  639. },
  640. updateModal (row) {
  641. this.modalData = {
  642. flag: '2',
  643. bu: row.site + '_' + row.buNo,
  644. site: row.site,
  645. manufacturerID: row.manufacturerID,
  646. manufacturerName: row.manufacturerName,
  647. active: row.active,
  648. contact: row.contact,
  649. phone: row.phone,
  650. address: row.address,
  651. email: row.email,
  652. remark: row.remark,
  653. updateBy: this.$store.state.user.name,
  654. }
  655. this.modalDisableFlag = true
  656. this.modalFlag = true
  657. },
  658. // 删除
  659. deleteManufacturer (row) {
  660. this.$confirm(`是否删除这个制造商?`, '提示', {
  661. confirmButtonText: '确定',
  662. cancelButtonText: '取消',
  663. type: 'warning'
  664. }).then(() => {
  665. eamManufacturerDelete(row).then(({data}) => {
  666. if (data && data.code === '0') {
  667. this.getDataList()
  668. this.$message({
  669. message: '操作成功',
  670. type: 'success',
  671. duration: 1500,
  672. onClose: () => {}
  673. })
  674. } else {
  675. this.$alert(data.msg, '错误', {
  676. confirmButtonText: '确定'
  677. })
  678. }
  679. })
  680. }).catch(() => {
  681. })
  682. },
  683. saveData () {
  684. if (this.modalData.bu === '' || this.modalData.bu == null) {
  685. this.$message.warning('请选择BU!')
  686. return
  687. }
  688. if (this.modalData.manufacturerID === '' || this.modalData.manufacturerID == null) {
  689. this.$message.warning('请输入制造商编码!')
  690. return
  691. }
  692. if (this.modalData.manufacturerName === '' || this.modalData.manufacturerName == null) {
  693. this.$message.warning('请输入制造商名称!')
  694. return
  695. }
  696. if (this.modalData.active === '' || this.modalData.active == null) {
  697. this.$message.warning('选择是否在用!')
  698. return
  699. }
  700. if (this.modalData.flag === '1') {
  701. eamManufacturerSave(this.modalData).then(({data}) => {
  702. if (data && data.code === '0') {
  703. this.getDataList()
  704. this.modalFlag=false
  705. this.$message({
  706. message: '操作成功',
  707. type: 'success',
  708. duration: 1500,
  709. onClose: () => {}
  710. })
  711. } else {
  712. this.$alert(data.msg, '错误', {
  713. confirmButtonText: '确定'
  714. })
  715. }
  716. })
  717. } else {
  718. eamManufacturerEdit(this.modalData).then(({data}) => {
  719. if (data && data.code === '0') {
  720. this.getDataList()
  721. this.modalFlag=false
  722. this.$message({
  723. message: '操作成功',
  724. type: 'success',
  725. duration: 1500,
  726. onClose: () => {}
  727. })
  728. } else {
  729. this.$alert(data.msg, '错误', {
  730. confirmButtonText: '确定'
  731. })
  732. }
  733. })
  734. }
  735. },
  736. // 动态列开始 获取 用户保存的 格式列
  737. async getTableUserColumn (tableId, columnId) {
  738. let queryTableUser = {
  739. userId: this.$store.state.user.name,
  740. functionId: this.$route.meta.menuId,
  741. tableId: tableId,
  742. status: true,
  743. languageCode: this.$i18n.locale
  744. }
  745. await getTableUserListLanguage(queryTableUser).then(({data}) => {
  746. if (data.rows.length > 0) {
  747. //this.columnList1 = []
  748. switch (columnId) {
  749. case 1:
  750. this.columnList = data.rows
  751. break;
  752. // case 2:
  753. // this.detailColumnList = data.rows
  754. // break;
  755. // case 3:
  756. // this.columnList2 = data.rows
  757. // break;
  758. // case 4:
  759. // this.columnList3 = data.rows
  760. // break;
  761. }
  762. } else {
  763. this.getColumnList(tableId, columnId)
  764. }
  765. })
  766. },
  767. // 获取 tableDefault 列
  768. async getColumnList (tableId, columnId) {
  769. let queryTable = {
  770. functionId: this.$route.meta.menuId,
  771. tableId: tableId,
  772. languageCode: this.$i18n.locale
  773. }
  774. await getTableDefaultListLanguage(queryTable).then(({data}) => {
  775. if (!data.rows.length == 0) {
  776. switch (columnId) {
  777. case 1:
  778. this.columnList = data.rows
  779. break;
  780. // case 2:
  781. // this.detailColumnList = data.rows
  782. // break;
  783. // case 3:
  784. // this.columnList2 = data.rows
  785. // break;
  786. // case 4:
  787. // this.columnList3 = data.rows
  788. // break;
  789. }
  790. } else {
  791. // this.showDefault = true.
  792. }
  793. })
  794. },
  795. //获取按钮的权限数据
  796. getButtonAuthData () {
  797. let searchFlag = this.isAuth(this.menuId+":search")
  798. let saveFlag = this.isAuth(this.menuId+":save")
  799. let updateFlag = this.isAuth(this.menuId+":update")
  800. let deleteFlag = this.isAuth(this.menuId+":delete")
  801. //处理页面的权限数据
  802. this.authSearch = !searchFlag
  803. this.authSave = !saveFlag
  804. this.authUpdate = !updateFlag
  805. this.authDelete = !deleteFlag
  806. },
  807. }
  808. }
  809. </script>
  810. <style scoped>
  811. .el-table /deep/ .cell{
  812. height: auto;
  813. line-height: 1.5;
  814. }
  815. </style>