index.vue 30 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073
  1. <template>
  2. <div>
  3. <div v-if="pageDisplay" class="app-container">
  4. <formComponent
  5. v-if="searchWhether"
  6. :formOption="formOption"
  7. :dataList="dataList"
  8. :inDex="inDex"
  9. ref="avatar"
  10. @submitForm="submitForm"
  11. @returnToForm="returnToForm"
  12. />
  13. <listComponent
  14. :tableData="tableData"
  15. @selectionbox="selectionbox"
  16. @see="viewMethod"
  17. @modify="modification"
  18. @deletion="deletion"
  19. @buttonList="buttonList"
  20. @showSearch="showSearch"
  21. @feedback="feedback"
  22. @getList="getList"
  23. :isItHidden="isItHidden"
  24. :customButton="customButton"
  25. :listStyle="listStyle"
  26. :queryList="queryList"
  27. :setRowList="setRowList"
  28. />
  29. <el-pagination
  30. style="float: right;margin-top: 10px"
  31. @size-change="handleSizeChange"
  32. @current-change="handleCurrentChange"
  33. :page-sizes="[10, 20, 30, 50]"
  34. :page-size="this.formDataList.pageSize"
  35. background
  36. layout="sizes, prev, pager, next"
  37. :total="total">
  38. </el-pagination>
  39. </div>
  40. <div v-else class="app-container">
  41. <formComponent
  42. v-if="searchWhether"
  43. :formOption="contentOption"
  44. :dataList="dataList"
  45. :inDex="inDex"
  46. ref="avatar"
  47. @submitForm="submitForm"
  48. @returnToForm="returnToForm"
  49. @submitAndSave="submitAndSave"
  50. @selectTrigger="selectTrigger"
  51. />
  52. <listComponent
  53. ref="listComponent"
  54. :tableData="contentList"
  55. @selectionbox="selectionbox"
  56. @see="viewMethod"
  57. @modify="modification"
  58. @deletion="deletion"
  59. @buttonList="buttonList"
  60. @showSearch="showSearch"
  61. @feedback="feedback"
  62. @getList="getList"
  63. @deletRows="deletRows"
  64. @totalAmount="totalAmount"
  65. :tatolLabel="tatolLabel"
  66. :isItHidden="isItHidden"
  67. :customButton="contentButton"
  68. :listStyle="contentStyle"
  69. :queryList="purchaseList"
  70. :setRowList="setRowList"
  71. :listData="listData"
  72. />
  73. </div>
  74. <el-dialog
  75. title="打印采购"
  76. :visible.sync="dialogVisible"
  77. :fullscreen="true"
  78. style="padding: 0;margin:0"
  79. width="70%">
  80. <div ref="print">
  81. <table class="table table-striped table-bordered" align="center" valign="center">
  82. <tr>
  83. <td style="font-size: 24px;font-weight:bold" class="column" colspan="6">采购表</td>
  84. </tr>
  85. <tr>
  86. <td class="column" style="width: 10%;">项目</td>
  87. <td class="column" style="width: 25%;">{{formList.projectName}}</td>
  88. <td class="column" style="width: 10%;">供应商</td>
  89. <td class="column" style="width: 25%;">{{ formList.corpName }}</td>
  90. <td class="column" style="width: 25%;" colspan="2">日期:{{formList.fBsdate}}</td>
  91. </tr>
  92. </table>
  93. <table class="table table-striped table-bordered" align="center" valign="center">
  94. <tr>
  95. <td class="column" style="width: 15%;border-top: none;">品名</td>
  96. <td class="column" style="width: 15%;border-top: none;">单价</td>
  97. <td class="column" style="width: 15%;border-top: none;">采购计划(斤)</td>
  98. <td class="column" style="width: 15%;border-top: none;">实际重量(斤)</td>
  99. <td class="column" style="width: 15%;border-top: none;">金额</td>
  100. <td class="column" style="width: 20%;border-top: none;">备注</td>
  101. </tr>
  102. <tr v-for="(item,index) in this.contentList" :key="index">
  103. <td class="column">{{item.feeName}}</td>
  104. <td class="column">{{item.fUnitprice}}</td>
  105. <td class="column">{{item.fPurchase}}</td>
  106. <td class="column">{{item.fQty}}</td>
  107. <td class="column">{{item.fAmount}}</td>
  108. <td class="column">{{item.remark}}</td>
  109. </tr>
  110. </table>
  111. <table class="table table-striped table-bordered" align="center" valign="center">
  112. <tr>
  113. <td colspan="6" style="border-top: none;" class="column"></td>
  114. </tr>
  115. <tr>
  116. <td class="column" style="width: 25%;">采购人签字</td>
  117. <td class="column" style="width: 25%;">厨房主管签字</td>
  118. <td class="column" style="width: 25%;">验收人签字</td>
  119. <td class="column" style="width: 25%;">主管签字</td>
  120. </tr>
  121. <tr>
  122. <td class="column" style="width: 25%;height: 37px;"></td>
  123. <td class="column" style="width: 25%;"></td>
  124. <td class="column" style="width: 25%;"></td>
  125. <td class="column" style="width: 25%;"></td>
  126. </tr>
  127. <tr>
  128. <td colspan="4" style="border-top: none;font-weight:bold;text-align: right;padding-right: 10%;font-size: 16px;" class="column">{{ formList.fsbuName }}</td>
  129. </tr>
  130. </table>
  131. </div>
  132. <span slot="footer" class="dialog-footer">
  133. <el-button @click="dialogVisible = false">取 消</el-button>
  134. <el-button type="primary" @click="Printing">打印</el-button>
  135. </span>
  136. </el-dialog>
  137. </div>
  138. </template>
  139. <script>
  140. import { select } from '@/api/system/set'
  141. import {
  142. listQuery,
  143. submit,
  144. viewSingle,
  145. deleteQuery,
  146. productName,
  147. queryItem,
  148. company,
  149. warehouse,
  150. listDelete,
  151. tableDeleteQuery,
  152. confirmDeletion
  153. } from '@/api/purchaseRequest/index'
  154. import Cookies from 'js-cookie'
  155. export default {
  156. name: 'index',
  157. data() {
  158. return {
  159. total:0,
  160. formDataList:{
  161. fBilltype: 'SQ',
  162. pageSize:10,
  163. pageNum:1,
  164. },
  165. formList:{},
  166. tatolLabel:['金额'],
  167. dialogVisible: false,
  168. listData: {
  169. fFeeid: [],
  170. fFeeunitid: [],
  171. fStltypeid: []
  172. },
  173. setTimeout:'',
  174. searchWhether: true,
  175. pageDisplay: true,
  176. dataList: {
  177. fGoodsid: [],
  178. fSbu: [],
  179. fWarehouseid: [],
  180. fCorpid: []
  181. },
  182. contentList: [],
  183. inDex: 4,
  184. tableData: [],
  185. tableList: [],
  186. isItHidden: true,
  187. listStyle: [
  188. {
  189. surface: '1',
  190. label: 'serialNumber',
  191. name: '序号',
  192. checked: 0,
  193. width: 100,
  194. onabort: ''
  195. }, {
  196. surface: '2',
  197. label: 'fBillno',
  198. name: '申请编号',
  199. checked: 0,
  200. width: 100,
  201. onabort: ''
  202. }, {
  203. surface: '3',
  204. label: 'projectName',
  205. name: '项目名称',
  206. checked: 0,
  207. width: 100,
  208. onabort: ''
  209. }, {
  210. surface: '4',
  211. label: 'corpName',
  212. name: '客户名称',
  213. checked: 0,
  214. width: 100,
  215. onabort: ''
  216. }, {
  217. surface: '5',
  218. label: 'fMoney',
  219. name: '金额',
  220. checked: 0,
  221. width: 100,
  222. onabort: ''
  223. }, {
  224. surface: '6',
  225. label: 'createTime',
  226. name: '申请日期',
  227. checked: 0,
  228. width: 100,
  229. onabort: ''
  230. },{
  231. surface: '7',
  232. label: 'createBy',
  233. name: '申请人',
  234. checked: 0,
  235. width: 100,
  236. onabort: ''
  237. }, {
  238. surface: '8',
  239. label: 'fReviewDate',
  240. name: '审核日期',
  241. checked: 0,
  242. width: 100,
  243. onabort: ''
  244. },{
  245. surface: '9',
  246. label: 'remark',
  247. name: '备注',
  248. checked: 0,
  249. width: 100,
  250. onabort: ''
  251. },{
  252. surface: '11',
  253. label: 'operation',
  254. name: '操作',
  255. checked: 0,
  256. width: 160,
  257. operation: '1',
  258. onabort: ''
  259. }
  260. ],
  261. contentStyle: [
  262. {
  263. surface: '1',
  264. label: 'serialNumber',
  265. name: '序号',
  266. checked: 0,
  267. width: 100,
  268. disabled: false,
  269. onabort: ''
  270. }, {
  271. surface: '2',
  272. label: 'fFeeid',
  273. name: '品名',
  274. checked: 0,
  275. width: 100,
  276. onabort: '',
  277. disabled: false,
  278. changeable: 1
  279. }, {
  280. surface: '3',
  281. label: 'fUnitprice',
  282. name: '单价',
  283. checked: 0,
  284. width: 100,
  285. disabled: false,
  286. onabort: 'this.value=this.value.replace(/[^\\-?\\d.]/g,"").replace(/^(\\-)*(\\d+)\\.(\\d\\d).*$/, "$1$2.$3")',
  287. changeable: 2
  288. }, {
  289. surface: '4',
  290. label: 'fPurchase',
  291. name: '采购重量',
  292. checked: 0,
  293. width: 100,
  294. onabort: '',
  295. disabled: false,
  296. changeable: 2
  297. }, {
  298. surface: '5',
  299. label: 'fQty',
  300. name: '实际重量',
  301. checked: 0,
  302. width: 100,
  303. onabort: 'this.value=this.value.replace(/[^\\-?\\d.]/g,"").replace(/^(\\-)*(\\d+)\\.(\\d\\d).*$/, "$1$2.$3")',
  304. disabled: false,
  305. changeable: 2
  306. }, {
  307. surface: '6',
  308. label: 'fFeeunitid',
  309. name: '计量单位',
  310. checked: 0,
  311. width: 100,
  312. onabort: '',
  313. disabled: false,
  314. changeable: 1
  315. }, {
  316. surface: '7',
  317. label: 'fAmount',
  318. name: '金额',
  319. checked: 0,
  320. width: 100,
  321. onabort: 'this.value=this.value.replace(/[^\\-?\\d.]/g,"").replace(/^(\\-)*(\\d+)\\.(\\d\\d).*$/, "$1$2.$3")',
  322. disabled: false,
  323. changeable: 2
  324. }, {
  325. surface: '8',
  326. label: 'fStltypeid',
  327. name: '付费方式',
  328. checked: 0,
  329. width: 100,
  330. onabort: '',
  331. disabled: false,
  332. changeable: 1
  333. }, {
  334. surface: '9',
  335. label: 'remark',
  336. name: '备注',
  337. checked: 0,
  338. width: 100,
  339. onabort: '',
  340. disabled: false,
  341. changeable: 2
  342. }, {
  343. surface: '10',
  344. label: 'createTime',
  345. name: '申请日期',
  346. checked: 0,
  347. disabled: false,
  348. width: 100,
  349. onabort: ''
  350. }, {
  351. surface: '11',
  352. label: 'createBy',
  353. name: '申请人',
  354. disabled: false,
  355. checked: 0,
  356. width: 100,
  357. onabort: ''
  358. }, {
  359. surface: '12',
  360. label: 'fReviewDate',
  361. name: '审核日期',
  362. checked: 0,
  363. disabled: false,
  364. width: 100,
  365. onabort: ''
  366. }, {
  367. surface: '13',
  368. label: 'operation',
  369. name: '操作',
  370. checked: 0,
  371. disabled: false,
  372. width: 160,
  373. operation: '2',
  374. onabort: ''
  375. }
  376. ],
  377. queryList: {
  378. tableName: '采购申请',
  379. columnList: []
  380. },
  381. purchaseList: {
  382. tableName: '采购申请详情',
  383. columnList: []
  384. },
  385. setRowList: [],
  386. customButton: [
  387. {
  388. type: 'primary',
  389. size: 'mini',
  390. icon: 'el-icon-edit',
  391. name: '新增',
  392. disabled: false
  393. },
  394. // {
  395. // type:'warning',
  396. // size:'mini',
  397. // icon:'el-icon-edit',
  398. // name:'立即修改',
  399. // disabled:false,
  400. // },
  401. {
  402. type: 'warning',
  403. size: 'mini',
  404. icon: 'el-icon-upload2',
  405. name: '导出',
  406. disabled: false
  407. }, {
  408. type: 'success',
  409. size: 'mini',
  410. icon: 'el-icon-c-scale-to-original',
  411. name: '复制新增',
  412. disabled: false
  413. }
  414. ],
  415. contentButton: [
  416. {
  417. type: 'danger',
  418. size: 'mini',
  419. icon: 'el-icon-arrow-left',
  420. name: '返回列表',
  421. disabled: false
  422. }, {
  423. type: 'primary',
  424. size: 'mini',
  425. icon: 'el-icon-plus',
  426. name: '录入',
  427. disabled: false
  428. }, {
  429. type: 'primary',
  430. size: 'mini',
  431. icon: 'el-icon-plus',
  432. name: '保存',
  433. plain: true,
  434. disabled: false
  435. }, {
  436. type: 'success',
  437. size: 'mini',
  438. icon: 'el-icon-edit',
  439. name: '修改',
  440. disabled: false
  441. }, {
  442. type: 'warning',
  443. size: 'mini',
  444. icon: 'el-icon-download',
  445. name: '导出',
  446. disabled: false
  447. },{
  448. type: 'info',
  449. size: 'mini',
  450. icon: 'el-icon-edit-outline',
  451. name: '打印',
  452. disabled: false
  453. },{
  454. type: 'primary',
  455. size: 'mini',
  456. icon: 'el-icon-edit-outline',
  457. name: '请核',
  458. disabled: false
  459. },{
  460. type: 'info',
  461. size: 'mini',
  462. icon: 'el-icon-edit-outline',
  463. name: '生成入库单',
  464. disabled: false
  465. },{
  466. type: 'info',
  467. size: 'mini',
  468. icon: 'el-icon-edit-outline',
  469. name: '生成销售单',
  470. disabled: false
  471. }
  472. ],
  473. formOption: [
  474. {
  475. span: 6,
  476. label: 'fBillno',
  477. name: '申请编号',
  478. inputType: 2,
  479. width: 200,
  480. labelSize: '80',
  481. rules: [{ required: false, message: ' ' }]
  482. }, {
  483. span: 6,
  484. label: 'fGoodsid',
  485. name: '项目名称',
  486. inputType: 1,
  487. width: 200,
  488. labelSize: '80',
  489. rules: [{ required: false, message: ' ' }]
  490. }, {
  491. span: 6,
  492. label: 'fCorpid',
  493. name: '供应商',
  494. inputType: 2,
  495. width: 200,
  496. labelSize: '80',
  497. rules: [{ required: false, message: ' ' }]
  498. }, {
  499. span: 6,
  500. label: 'createBy',
  501. name: '申请人',
  502. inputType: 2,
  503. width: 200,
  504. labelSize: '80',
  505. rules: [{ required: false, message: ' ' }]
  506. }, {
  507. span: 6,
  508. label: 'moneys',
  509. name: '金额',
  510. inputType: 5,
  511. width: 200,
  512. labelSize: '80',
  513. rules: [{ required: false, message: ' ' }]
  514. }, {
  515. span: 6,
  516. label: 'cLoadDate',
  517. name: '申请日期',
  518. inputType: 3,
  519. width: 200,
  520. labelSize: '80',
  521. rules: [{ required: false, message: ' ' }]
  522. }
  523. ],
  524. contentOption: [
  525. {
  526. index:'1',
  527. span: 6,
  528. label: 'fBillno',
  529. name: '系统编号',
  530. inputType: 2,
  531. width: 200,
  532. labelSize: '80',
  533. disabled: true,
  534. rules: [{ required: false, message: ' ' }]
  535. }, {
  536. index:'2',
  537. span: 6,
  538. label: 'fGoodsid',
  539. name: '项目名称',
  540. inputType: 1,
  541. width: 200,
  542. labelSize: '80',
  543. disabled: true,
  544. rules: [{ required: true, message: ' ' }]
  545. }, {
  546. index:'3',
  547. span: 6,
  548. label: 'personNaem',
  549. name: '项目主管',
  550. inputType: 2,
  551. width: 200,
  552. labelSize: '80',
  553. disabled: true,
  554. rules: [{ required: false, message: ' ' }]
  555. }, {
  556. index:'4',
  557. span: 6,
  558. label: 'corpsName',
  559. name: '客户',
  560. inputType: 2,
  561. width: 200,
  562. labelSize: '80',
  563. disabled: true,
  564. rules: [{ required: false, message: ' ' }]
  565. }, {
  566. index:'5',
  567. span: 6,
  568. label: 'fCorpid',
  569. name: '供应商',
  570. inputType: 1,
  571. width: 200,
  572. labelSize: '80',
  573. disabled: true,
  574. rules: [{ required: true, message: ' ' }]
  575. }, {
  576. index:'6',
  577. span: 6,
  578. label: 'fWarehouseid',
  579. name: '仓库',
  580. inputType: 1,
  581. width: 200,
  582. disabled: true,
  583. labelSize: '80',
  584. rules: [{ required: true, message: ' ' }]
  585. }, {
  586. index:'7',
  587. span: 6,
  588. label: 'fBsdate',
  589. name: '提货日期',
  590. inputType: 6,
  591. width: 200,
  592. disabled: true,
  593. labelSize: '80',
  594. rules: [{ required: true, message: ' ' }]
  595. }, {
  596. index:'8',
  597. span: 6,
  598. label: 'createBy',
  599. name: '申请人',
  600. inputType: 2,
  601. width: 200,
  602. disabled: true,
  603. labelSize: '80',
  604. rules: [{ required: false, message: ' ' }]
  605. },
  606. {
  607. index:'9',
  608. span: 6,
  609. label: 'fStudentsWeight',
  610. name: '学生人数',
  611. inputType: 2,
  612. onabort: 'this.value=this.value.replace(/[^0-9]/g,\'\')',
  613. width: 200,
  614. disabled: true,
  615. labelSize: '80',
  616. rules: [{ required: true, message: ' ' }]
  617. }, {
  618. index:'10',
  619. span: 6,
  620. label: 'fTeachersWeight',
  621. name: '教师人数',
  622. onabort: 'this.value=this.value.replace(/[^0-9]/g,\'\')',
  623. inputType: 2,
  624. width: 200,
  625. disabled: true,
  626. labelSize: '80',
  627. rules: [{ required: true, message: ' ' }]
  628. },
  629. {
  630. index:'11',
  631. span: 6,
  632. label: 'fSbu',
  633. name: '开票公司',
  634. inputType: 1,
  635. width: 200,
  636. disabled: true,
  637. labelSize: '80',
  638. rules: [{ required: true, message: ' ' }]
  639. }, {
  640. index:'12',
  641. span: 6,
  642. label: 'remark',
  643. name: '备注',
  644. inputType: 4,
  645. disabled: true,
  646. width: 200,
  647. labelSize: '80',
  648. rules: [{ required: false, message: ' ' }]
  649. }
  650. ]
  651. }
  652. },
  653. created() {
  654. let data = {
  655. tableName: this.queryList.tableName,
  656. userId: Cookies.get('userName')
  657. }
  658. this.getRow(data)
  659. this.query(this.formDataList)
  660. productName().then(res => {
  661. console.log(res)
  662. if (res.code === 200) {
  663. for (let item in res.rows) {
  664. this.listData.fFeeid.push({
  665. label: res.rows[item].fName,
  666. value: res.rows[item].fId
  667. })
  668. }
  669. console.log(this.listData)
  670. }
  671. })
  672. this.getDicts('data_unitfees').then(res => {
  673. console.log(res.data)
  674. for (let item in res.data) {
  675. this.listData.fFeeunitid.push({
  676. label: res.data[item].dictLabel,
  677. value: JSON.parse(res.data[item].dictValue)
  678. })
  679. }
  680. })
  681. this.getDicts('f_paymode').then(res => {
  682. console.log(res)
  683. for (let item in res.data) {
  684. this.listData.fStltypeid.push({
  685. label: res.data[item].dictLabel,
  686. value: JSON.parse(res.data[item].dictValue)
  687. })
  688. }
  689. })
  690. queryItem().then(res => {
  691. console.log(res)
  692. for (let item in res.data) {
  693. this.dataList.fGoodsid.push({
  694. label: res.data[item].projectName,
  695. value: res.data[item].fId,
  696. personNaem: res.data[item].personNaem,
  697. corpsName: res.data[item].corpsName,
  698. fCorpid: res.data[item].fCorpid
  699. })
  700. }
  701. })
  702. //查询仓库
  703. warehouse().then(res => {
  704. console.log(res)
  705. for (let item in res.rows) {
  706. this.dataList.fWarehouseid.push({
  707. label: res.rows[item].fName,
  708. value: res.rows[item].fId
  709. })
  710. }
  711. })
  712. this.fCompany(1)
  713. this.fCompany(2)
  714. },
  715. methods: {
  716. handleSizeChange(val) {
  717. // console.log(`每页 ${val} 条`);
  718. this.formDataList.pageSize = val
  719. this.query(this.formDataList)
  720. },
  721. handleCurrentChange(val) {
  722. // console.log(`当前页: ${val}`);
  723. this.formDataList.pageNum = val
  724. this.query(this.formDataList)
  725. },
  726. //计算金额
  727. totalAmount(scope) {
  728. console.log(scope)
  729. if (scope.row.fUnitprice && scope.row.fQty) {
  730. scope.row.fAmount = (scope.row.fUnitprice * scope.row.fQty).toFixed(2)
  731. }
  732. },
  733. //查询公司
  734. fCompany(name) {
  735. company(name).then(res => {
  736. console.log(res)
  737. if (name == 1) {
  738. this.dataList.fCorpid = []
  739. for (let item in res.data) {
  740. this.dataList.fCorpid.push({
  741. label: res.data[item].fName,
  742. value: res.data[item].fId
  743. })
  744. }
  745. } else if (name == 2) {
  746. this.dataList.fSbu = []
  747. for (let item in res.data) {
  748. this.dataList.fSbu.push({
  749. label: res.data[item].fName,
  750. value: res.data[item].fId
  751. })
  752. }
  753. }
  754. })
  755. },
  756. //查询主页列数据
  757. query(data) {
  758. listQuery(data).then(res => {
  759. this.tableData = res.rows
  760. this.total = res.total
  761. })
  762. },
  763. //查询列数据
  764. getRow(data,list) {
  765. select(data).then((res) => {
  766. console.log(res)
  767. if (data.tableName === '采购申请详情') {
  768. if (res.data.length != 0) {
  769. this.purchaseList.columnList = res.data.filter((e) => e.checked == 0)
  770. this.purchaseList.columnList = res.data
  771. this.setRowList = res.data
  772. this.purchaseList.columnList = this.purchaseList.columnList.filter((e) => e.checked == 0)
  773. // this.waitFor = true
  774. } else {
  775. // this.waitFor = true
  776. this.purchaseList.columnList = this.contentStyle
  777. this.setRowList = this.contentStyle
  778. }
  779. this.pageDisplay = false
  780. this.isItHidden = false
  781. this.inDex = this.contentOption.length
  782. } else {
  783. if (res.data.length != 0) {
  784. this.queryList.columnList = res.data.filter((e) => e.checked == 0)
  785. this.queryList.columnList = res.data
  786. this.setRowList = res.data
  787. this.queryList.columnList = this.queryList.columnList.filter((e) => e.checked == 0)
  788. // this.waitFor = true
  789. } else {
  790. // this.waitFor = true
  791. this.queryList.columnList = this.listStyle
  792. console.log(this.queryList.columnList.fFeeid)
  793. this.setRowList = this.listStyle
  794. }
  795. this.pageDisplay = true
  796. this.isItHidden = true
  797. this.inDex = 4
  798. }
  799. this.$refs.avatar.form = {}
  800. if (list){
  801. this.$refs.avatar.form = list.warehouseBills
  802. this.contentList = list.tWarehousebillsfees
  803. }
  804. })
  805. },
  806. returnToForm(row) {
  807. console.log(row, 111)
  808. },
  809. //查看
  810. viewMethod(scope) {
  811. console.log(scope)
  812. this.contentOption.forEach(item => item.disabled = true)
  813. this.contentStyle.forEach(item => item.disabled = true)
  814. viewSingle(scope.row.fId).then(res => {
  815. if (res.code === 200) {
  816. let data = {
  817. tableName: this.purchaseList.tableName,
  818. userId: Cookies.get('userName')
  819. }
  820. let list ={
  821. warehouseBills:res.data.warehouseBills,
  822. tWarehousebillsfees:res.data.tWarehousebillsfees
  823. }
  824. this.$refs.avatar.form = {}
  825. this.getRow(data,list)
  826. }
  827. })
  828. },
  829. //修改
  830. modification(scope) {
  831. console.log(scope)
  832. },
  833. //删除
  834. deletion(scope) {
  835. console.log(scope.row.fId)
  836. tableDeleteQuery(scope.row.fId).then(res => {
  837. console.log(res)
  838. this.$confirm(res.msg == 1 ? '主表数据为空' : (res.msg == 2 ? '主表有数据' : '未知状态') + '是否永久删除该条数据?', '提示', {
  839. confirmButtonText: '确定',
  840. cancelButtonText: '取消',
  841. type: 'warning'
  842. }).then(() => {
  843. confirmDeletion(scope.row.fId).then(data => {
  844. this.$message({
  845. type: 'success',
  846. message: '删除成功!'
  847. })
  848. this.query(this.formDataList)
  849. })
  850. }).catch(() => {
  851. this.$message({
  852. type: 'info',
  853. message: '已取消删除'
  854. })
  855. })
  856. })
  857. },
  858. //选择框
  859. selectionbox(selection) {
  860. console.log(selection)
  861. },
  862. //详情内容保存
  863. submitAndSave(item) {
  864. let formData = new window.FormData()
  865. formData.append('tWarehousebills', JSON.stringify(this.$refs.avatar.form))
  866. formData.append('tWarehousebillsfees', JSON.stringify(this.contentList))
  867. formData.append('fBilltype', 'SQ')
  868. submit(formData).then(res => {
  869. if (res.code == 200) {
  870. this.$message.success('保存成功')
  871. this.$refs.avatar.form = res.data.warehouseBills
  872. this.contentList = res.data.tWarehousebillsCntrs
  873. console.log(this.dataList, this.contentList)
  874. if (item == 1){
  875. this.dialogVisible = true
  876. }
  877. }
  878. })
  879. },
  880. //表单选中后触发
  881. selectTrigger(name, list, id) {
  882. console.log(list, id)
  883. if (name == 'fGoodsid') {
  884. for (let item in list) {
  885. if (list[item].value == id) {
  886. this.$refs.avatar.form.personNaem = list[item].personNaem
  887. this.$refs.avatar.form.corpsName = list[item].corpsName
  888. }
  889. }
  890. }
  891. },
  892. //确认打印
  893. Printing(){
  894. this.$print(this.$refs.print)
  895. },
  896. //所以按钮
  897. buttonList(row) {
  898. console.log(row)
  899. let data
  900. switch (row.name) {
  901. case '新增':
  902. this.contentList = []
  903. data = {
  904. tableName: this.purchaseList.tableName,
  905. userId: Cookies.get('userName')
  906. }
  907. this.$refs.avatar.form = {}
  908. this.getRow(data)
  909. this.contentOption.forEach(item => {
  910. if (item.label == 'personNaem' || item.label == 'corpsName' || item.label == 'createBy') {
  911. item.disabled = true
  912. } else {
  913. item.disabled = false
  914. }
  915. })
  916. this.$refs.avatar.form.createBy = Cookies.get('userName')
  917. break
  918. case '保存':
  919. this.$refs.avatar.submitForm('submit')
  920. break
  921. case '打印':
  922. if (!this.$refs.avatar.form.fId){
  923. this.$message.error('未保存,不允许打印');
  924. }else {
  925. this.formList = this.$refs.avatar.form
  926. this.submitAndSave(1)
  927. }
  928. break
  929. case '修改':
  930. this.contentOption.forEach(item => {
  931. if (item.label == 'personNaem' || item.label == 'corpsName' || item.label == 'createBy') {
  932. item.disabled = true
  933. } else {
  934. item.disabled = false
  935. }
  936. })
  937. this.contentStyle.forEach(item => item.disabled = false)
  938. break
  939. case '录入':
  940. this.contentList.push({
  941. fFeeid: '',
  942. fUnitprice: '',
  943. fPurchase: '',
  944. fQty: '',
  945. fFeeunitid: '',
  946. fAmount: '',
  947. fStltypeid: '',
  948. remark: '',
  949. createTime: '',
  950. createBy: Cookies.get('userName'),
  951. fReviewDate: '',
  952. operation: '',
  953. })
  954. break
  955. case '返回列表':
  956. console.log(this.$refs.avatar.form,this.contentList)
  957. if (!this.$refs.avatar.form.fId && this.contentList !== 0) {
  958. data = {
  959. tableName: this.queryList.tableName,
  960. userId: Cookies.get('userName')
  961. }
  962. this.getRow(data)
  963. this.query(this.formDataList)
  964. } else {
  965. this.$confirm('当前数据未保存是否保存?', '提示', {
  966. confirmButtonText: '保存',
  967. cancelButtonText: '取消',
  968. type: 'warning'
  969. }).then(() => {
  970. this.submitAndSave()
  971. }).catch(() => {
  972. data = {
  973. tableName: this.queryList.tableName,
  974. userId: Cookies.get('userName')
  975. }
  976. this.getRow(data)
  977. this.query(this.formDataList)
  978. })
  979. }
  980. break
  981. case '请核':
  982. default:
  983. this.$message.error('该按钮暂无功能')
  984. }
  985. },
  986. // 显示搜索条件、点击后会调用此方法
  987. showSearch() {
  988. console.log('到我了')
  989. this.searchWhether = !this.searchWhether
  990. },
  991. //搜索、重置、展开
  992. feedback(res) {
  993. console.log(res)
  994. if (res == '展开') {
  995. if (this.inDex == 4) {
  996. this.inDex = this.formOption.length
  997. } else {
  998. this.inDex = 4
  999. }
  1000. } else if (res == '搜索') {
  1001. this.$refs.avatar.submitForm()
  1002. } else if (res == '重置') {
  1003. this.$refs.avatar.form = {}
  1004. }
  1005. },
  1006. //表单验证通过执行搜索
  1007. submitForm() {
  1008. console.log('111')
  1009. let list = this.formDataList
  1010. console.log(this.$refs.avatar.form)
  1011. this.formDataList = this.$refs.avatar.form
  1012. this.formDataList.fBilltype = list.fBilltype
  1013. this.formDataList.pageSize = list.pageSize
  1014. this.formDataList.pageNum = list.pageNum
  1015. this.query(this.formDataList)
  1016. },
  1017. //点击刷新会调用此方法
  1018. getList() {
  1019. this.feedback('重置')
  1020. this.submitForm()
  1021. console.log('到我了2')
  1022. },
  1023. //详情表内容移出
  1024. deletRows(index, rows) {
  1025. console.log(index, rows)
  1026. if (rows[index].fId) {
  1027. deleteQuery(this.$refs.avatar.form.fId, this.$refs.avatar.form.fDateChanged).then(res => {
  1028. if (res.code === 200) {
  1029. listDelete(rows[index].fId).then(data => {
  1030. rows.splice(index, 1)
  1031. })
  1032. }
  1033. })
  1034. } else {
  1035. rows.splice(index, 1)
  1036. }
  1037. }
  1038. }
  1039. }
  1040. </script>
  1041. <style scoped>
  1042. .table {
  1043. border-collapse: collapse;
  1044. border-spacing: 0;
  1045. background-color: transparent;
  1046. display: table;
  1047. width: 100%;
  1048. max-width: 100%;
  1049. margin: 0 auto;
  1050. }
  1051. .table td {
  1052. text-align: center;
  1053. vertical-align: middle;
  1054. font-size: 14px;
  1055. color: #333333;
  1056. padding: 8px 12px;
  1057. }
  1058. .column {
  1059. border: 1px solid #000;
  1060. }
  1061. .app-container >>> .el-form-item{
  1062. margin-bottom: 0;
  1063. }
  1064. </style>