index.vue 41 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435
  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. :hasPermi="hasPermi"
  24. :isItHidden="isItHidden"
  25. :customButton="customButton"
  26. :listStyle="listStyle"
  27. :queryList="queryList"
  28. :setRowList="setRowList"
  29. />
  30. <el-pagination
  31. style="float: right;margin-top: 10px"
  32. @size-change="handleSizeChange"
  33. @current-change="handleCurrentChange"
  34. :page-sizes="[10, 20, 30, 50]"
  35. :page-size="this.formDataList.pageSize"
  36. background
  37. layout="sizes, prev, pager, next"
  38. :total="total">
  39. </el-pagination>
  40. </div>
  41. <div v-else class="app-container">
  42. <formComponent
  43. v-if="searchWhether"
  44. :formOption="contentOption"
  45. :dataList="dataList"
  46. :inDex="inDex"
  47. ref="avatar"
  48. @writeOff="writeOff"
  49. @submitForm="submitForm"
  50. @returnToForm="returnToForm"
  51. @submitAndSave="submitAndSave"
  52. @selectTrigger="selectTrigger"
  53. />
  54. <listComponent
  55. ref="listComponent"
  56. :tableData="contentList"
  57. @selectionbox="selectionbox"
  58. @see="viewMethod"
  59. @modify="modification"
  60. @deletion="deletion"
  61. @buttonList="buttonList"
  62. @showSearch="showSearch"
  63. @feedback="feedback"
  64. @getList="getList"
  65. @deletRows="deletRows"
  66. @totalAmount="totalAmount"
  67. @change="change"
  68. :hasPermi="hasPermi"
  69. :tatolLabel="tatolLabel"
  70. :isItHidden="isItHidden"
  71. :customButton="contentButton"
  72. :listStyle="contentStyle"
  73. :queryList="purchaseList"
  74. :setRowList="setRowList"
  75. :listData="listData"
  76. />
  77. </div>
  78. <add-or-update
  79. v-if="addOrUpdateVisible"
  80. ref="addOrUpdate"
  81. @refreshDataList="getDataList"
  82. ></add-or-update>
  83. <approval-comments
  84. v-if="addOrUpdateVisib"
  85. ref="ApprovalComments"
  86. @refreshDataList="returnData"
  87. ></approval-comments>
  88. <el-dialog
  89. title="打印采购"
  90. :visible.sync="dialogVisible"
  91. :fullscreen="true"
  92. style="padding: 0;margin:0"
  93. width="70%">
  94. <div ref="print">
  95. <table class="table table-striped table-bordered" align="center" valign="center">
  96. <tr>
  97. <td style="font-size: 24px;font-weight:bold" class="column" colspan="6">采购表</td>
  98. </tr>
  99. <tr>
  100. <td class="column" style="width: 10%;">项目</td>
  101. <td class="column" style="width: 25%;">{{formList.projectName}}</td>
  102. <td class="column" style="width: 10%;">供应商</td>
  103. <td class="column" style="width: 25%;">{{ formList.corpName }}</td>
  104. <td class="column" style="width: 25%;" colspan="2">日期:{{formList.fBsdate}}</td>
  105. </tr>
  106. </table>
  107. <table class="table table-striped table-bordered" align="center" valign="center">
  108. <tr>
  109. <td class="column" style="width: 15%;border-top: none;">品名</td>
  110. <td class="column" style="width: 15%;border-top: none;">单价</td>
  111. <td class="column" style="width: 15%;border-top: none;">采购计划</td>
  112. <td class="column" style="width: 15%;border-top: none;">实际重量</td>
  113. <td class="column" style="width: 15%;border-top: none;">金额</td>
  114. <td class="column" style="width: 20%;border-top: none;">备注</td>
  115. </tr>
  116. <tr v-for="(item,index) in contentList" :key="index">
  117. <td class="column">{{item.feeName}}</td>
  118. <td class="column">{{item.fUnitprice}}</td>
  119. <td class="column">{{item.fPurchase}}({{item.fFeeunitName}})</td>
  120. <td class="column">{{item.fQty}}({{item.fFeeunitName}})</td>
  121. <td class="column">{{item.fAmount}}</td>
  122. <td class="column">{{item.remark}}</td>
  123. </tr>
  124. </table>
  125. <table class="table table-striped table-bordered" align="center" valign="center">
  126. <tr>
  127. <td colspan="6" style="border-top: none;" class="column"></td>
  128. </tr>
  129. <tr>
  130. <td class="column" style="width: 25%;">采购人签字</td>
  131. <td class="column" style="width: 25%;">厨房主管签字</td>
  132. <td class="column" style="width: 25%;">验收人签字</td>
  133. <td class="column" style="width: 25%;">主管签字</td>
  134. </tr>
  135. <tr>
  136. <td class="column" style="width: 25%;height: 37px;"></td>
  137. <td class="column" style="width: 25%;"></td>
  138. <td class="column" style="width: 25%;"></td>
  139. <td class="column" style="width: 25%;"></td>
  140. </tr>
  141. <tr>
  142. <td colspan="4" style="border-top: none;font-weight:bold;text-align: right;padding-right: 10%;font-size: 16px;" class="column">{{ formList.fsbuName }}</td>
  143. </tr>
  144. </table>
  145. </div>
  146. <span slot="footer" class="dialog-footer">
  147. <el-button @click="dialogVisible = false">取 消</el-button>
  148. <el-button type="primary" @click="Printing">打印</el-button>
  149. </span>
  150. </el-dialog>
  151. </div>
  152. </template>
  153. <script>
  154. import { select } from '@/api/system/set'
  155. import {
  156. listQuery,
  157. submit,
  158. viewSingle,
  159. deleteQuery,
  160. productName,
  161. queryItem,
  162. company,
  163. warehouse,
  164. listDelete,
  165. tableDeleteQuery,
  166. confirmDeletion,
  167. pleaseCheck,
  168. copyNew,
  169. revoke,
  170. withdrawBy
  171. } from '@/api/purchaseRequest/index'
  172. import Cookies from 'js-cookie'
  173. export default {
  174. name: 'index',
  175. data() {
  176. return {
  177. addOrUpdateVisible: false,
  178. addOrUpdateVisib: false,
  179. total:0,
  180. selection:[],
  181. formDataList:{
  182. fBilltype: 'SQ',
  183. pageSize:10,
  184. pageNum:1,
  185. },
  186. formList:{},
  187. tatolLabel:['金额'],
  188. dialogVisible: false,
  189. listData: {
  190. fFeeid: [],
  191. fFeeunitid: [],
  192. fStltypeid: []
  193. },
  194. hasPermi:{
  195. lookup:['anpin:stockControl:query'],
  196. disappear:['anpin:stockControl:remove']
  197. },
  198. setTimeout:'',
  199. searchWhether: true,
  200. pageDisplay: true,
  201. dataList: {
  202. fGoodsid: [],
  203. fSbu: [],
  204. fWarehouseid: [],
  205. fCorpid: []
  206. },
  207. contentList: [],
  208. inDex: 4,
  209. tableData: [],
  210. tableList: [],
  211. isItHidden: true,
  212. listStyle: [
  213. {
  214. surface: '1',
  215. label: 'serialNumber',
  216. name: '序号',
  217. checked: 0,
  218. width: 100,
  219. onabort: ''
  220. }, {
  221. surface: '2',
  222. label: 'fBillno',
  223. name: '申请编号',
  224. checked: 0,
  225. width: 100,
  226. onabort: ''
  227. }, {
  228. surface: '3',
  229. label: 'projectName',
  230. name: '项目名称',
  231. checked: 0,
  232. width: 100,
  233. onabort: ''
  234. }, {
  235. surface: '4',
  236. label: 'corpName',
  237. name: '客户名称',
  238. checked: 0,
  239. width: 100,
  240. onabort: ''
  241. }, {
  242. surface: '5',
  243. label: 'fMoney',
  244. name: '金额',
  245. checked: 0,
  246. width: 100,
  247. onabort: ''
  248. }, {
  249. surface: '6',
  250. label: 'createTime',
  251. name: '申请日期',
  252. checked: 0,
  253. width: 100,
  254. onabort: ''
  255. },{
  256. surface: '7',
  257. label: 'createBy',
  258. name: '申请人',
  259. checked: 0,
  260. width: 100,
  261. onabort: ''
  262. }, {
  263. surface: '8',
  264. label: 'fReviewDate',
  265. name: '审核日期',
  266. checked: 0,
  267. width: 100,
  268. onabort: ''
  269. },{
  270. surface: '9',
  271. label: 'remark',
  272. name: '备注',
  273. checked: 0,
  274. width: 100,
  275. onabort: ''
  276. },{
  277. surface: '10',
  278. label: 'fBillstatusName',
  279. name: '状态',
  280. checked: 0,
  281. width: 100,
  282. onabort: ''
  283. },{
  284. surface: '11',
  285. label: 'operation',
  286. name: '操作',
  287. checked: 0,
  288. width: 160,
  289. fixed:'right',
  290. operation: '1',
  291. onabort: ''
  292. }
  293. ],
  294. contentStyle: [
  295. {
  296. surface: '1',
  297. label: 'serialNumber',
  298. name: '序号',
  299. checked: 0,
  300. width: 100,
  301. disabled: false,
  302. onabort: ''
  303. }, {
  304. surface: '2',
  305. label: 'fFeeid',
  306. name: '品名',
  307. checked: 0,
  308. width: 100,
  309. onabort: '',
  310. disabled: false,
  311. changeable: 1
  312. }, {
  313. surface: '3',
  314. label: 'fCurrencyName',
  315. name: '规格',
  316. checked: 0,
  317. width: 100,
  318. onabort: '',
  319. disabled: false,
  320. changeable: 1
  321. },{
  322. surface: '4',
  323. label: 'fUnitprice',
  324. name: '单价',
  325. checked: 0,
  326. width: 100,
  327. disabled: false,
  328. onabort: 'this.value=this.value.replace(/[^\\-?\\d.]/g,"").replace(/^(\\-)*(\\d+)\\.(\\d\\d).*$/, "$1$2.$3")',
  329. changeable: 2
  330. }, {
  331. surface: '5',
  332. label: 'fPurchase',
  333. name: '采购数量',
  334. checked: 0,
  335. width: 100,
  336. onabort: '',
  337. disabled: false,
  338. changeable: 2
  339. }, {
  340. surface: '6',
  341. label: 'fQty',
  342. name: '实际数量',
  343. checked: 0,
  344. width: 100,
  345. onabort: 'this.value=this.value.replace(/[^\\-?\\d.]/g,"").replace(/^(\\-)*(\\d+)\\.(\\d\\d).*$/, "$1$2.$3")',
  346. disabled: false,
  347. changeable: 2
  348. }, {
  349. surface: '7',
  350. label: 'fFeeunitid',
  351. name: '计量单位',
  352. checked: 0,
  353. width: 100,
  354. onabort: '',
  355. disabled: false,
  356. changeable: 1
  357. }, {
  358. surface: '8',
  359. label: 'fAmount',
  360. name: '金额',
  361. checked: 0,
  362. width: 100,
  363. onabort: 'this.value=this.value.replace(/[^\\-?\\d.]/g,"").replace(/^(\\-)*(\\d+)\\.(\\d\\d).*$/, "$1$2.$3")',
  364. disabled: false,
  365. changeable: 2
  366. }, {
  367. surface: '9',
  368. label: 'fStltypeid',
  369. name: '付费方式',
  370. checked: 0,
  371. width: 100,
  372. onabort: '',
  373. disabled: false,
  374. changeable: 1
  375. }, {
  376. surface: '10',
  377. label: 'remark',
  378. name: '备注',
  379. checked: 0,
  380. width: 100,
  381. onabort: '',
  382. disabled: false,
  383. changeable: 2
  384. }, {
  385. surface: '11',
  386. label: 'createTime',
  387. name: '申请日期',
  388. checked: 0,
  389. disabled: false,
  390. width: 100,
  391. onabort: ''
  392. }, {
  393. surface: '12',
  394. label: 'createBy',
  395. name: '申请人',
  396. disabled: false,
  397. checked: 0,
  398. width: 100,
  399. onabort: ''
  400. }, {
  401. surface: '13',
  402. label: 'fReviewDate',
  403. name: '审核日期',
  404. checked: 0,
  405. disabled: false,
  406. width: 100,
  407. onabort: ''
  408. }, {
  409. surface: '14',
  410. label: 'operation',
  411. name: '操作',
  412. checked: 0,
  413. disabled: false,
  414. width: 160,
  415. fixed:'right',
  416. operation: '2',
  417. onabort: ''
  418. }
  419. ],
  420. queryList: {
  421. tableName: '采购申请',
  422. columnList: []
  423. },
  424. purchaseList: {
  425. tableName: '采购申请详情',
  426. columnList: []
  427. },
  428. setRowList: [],
  429. customButton: [
  430. {
  431. type: 'primary',
  432. size: 'mini',
  433. icon: 'el-icon-edit',
  434. name: '新增',
  435. disabled: false,
  436. hasPermi:['anpin:stockControl:anPingApply']
  437. },
  438. // {
  439. // type:'warning',
  440. // size:'mini',
  441. // icon:'el-icon-edit',
  442. // name:'立即修改',
  443. // disabled:false,
  444. // },
  445. {
  446. type: 'warning',
  447. size: 'mini',
  448. icon: 'el-icon-upload2',
  449. name: '导出',
  450. disabled: false,
  451. hasPermi:['anpin:stockControl:export']
  452. }, {
  453. type: 'success',
  454. size: 'mini',
  455. icon: 'el-icon-c-scale-to-original',
  456. name: '复制新增',
  457. disabled: false,
  458. hasPermi:['anpin:stockControl:generateReceipts']
  459. }
  460. ],
  461. contentButton: [
  462. {
  463. type: 'danger',
  464. size: 'mini',
  465. icon: 'el-icon-arrow-left',
  466. name: '返回列表',
  467. disabled: false
  468. }, {
  469. type: 'primary',
  470. size: 'mini',
  471. icon: 'el-icon-plus',
  472. name: '录入',
  473. disabled: false
  474. }, {
  475. type: 'primary',
  476. size: 'mini',
  477. icon: 'el-icon-plus',
  478. name: '保存',
  479. plain: true,
  480. disabled: false
  481. }, {
  482. type: 'success',
  483. size: 'mini',
  484. icon: 'el-icon-edit',
  485. name: '修改',
  486. disabled: false
  487. }, {
  488. type: 'warning',
  489. size: 'mini',
  490. icon: 'el-icon-download',
  491. name: '导出',
  492. disabled: false
  493. },{
  494. type: 'info',
  495. size: 'mini',
  496. icon: 'el-icon-edit-outline',
  497. name: '打印',
  498. disabled: false
  499. },{
  500. type: 'primary',
  501. size: 'mini',
  502. icon: 'el-icon-edit-outline',
  503. name: '请核',
  504. disabled: false
  505. },{
  506. type: 'primary',
  507. size: 'mini',
  508. icon: 'el-icon-edit-outline',
  509. name: '查看审批',
  510. disabled: false
  511. },{
  512. type: 'info',
  513. size: 'mini',
  514. icon: 'el-icon-edit-outline',
  515. name: '生成入库单',
  516. disabled: false
  517. },{
  518. type: 'info',
  519. size: 'mini',
  520. icon: 'el-icon-edit-outline',
  521. name: '生成销售单',
  522. disabled: false
  523. },{
  524. type: 'info',
  525. size: 'mini',
  526. icon: 'el-icon-edit-outline',
  527. name: '生成出库单',
  528. disabled: false
  529. }
  530. ],
  531. formOption: [
  532. {
  533. span: 6,
  534. label: 'fBillno',
  535. name: '申请编号',
  536. inputType: 2,
  537. width: 200,
  538. labelSize: '80',
  539. rules: [{ required: false, message: ' ' }]
  540. }, {
  541. span: 6,
  542. label: 'fGoodsid',
  543. name: '项目名称',
  544. inputType: 1,
  545. width: 200,
  546. labelSize: '80',
  547. rules: [{ required: false, message: ' ' }]
  548. }, {
  549. span: 6,
  550. label: 'fCorpid',
  551. name: '供应商',
  552. inputType: 2,
  553. width: 200,
  554. labelSize: '80',
  555. rules: [{ required: false, message: ' ' }]
  556. }, {
  557. span: 6,
  558. label: 'createBy',
  559. name: '申请人',
  560. inputType: 2,
  561. width: 200,
  562. labelSize: '80',
  563. rules: [{ required: false, message: ' ' }]
  564. }, {
  565. span: 6,
  566. label: 'moneys',
  567. name: '金额',
  568. inputType: 5,
  569. width: 200,
  570. labelSize: '80',
  571. rules: [{ required: false, message: ' ' }]
  572. }, {
  573. span: 6,
  574. label: 'cLoadDate',
  575. name: '申请日期',
  576. inputType: 3,
  577. width: 300,
  578. labelSize: '80',
  579. rules: [{ required: false, message: ' ' }]
  580. }
  581. ],
  582. contentOption: [
  583. {
  584. index:'1',
  585. span: 6,
  586. label: 'fBillno',
  587. name: '系统编号',
  588. inputType: 2,
  589. width: 200,
  590. labelSize: '80',
  591. disabled: true,
  592. rules: [{ required: false, message: ' ' }]
  593. }, {
  594. index:'2',
  595. span: 6,
  596. label: 'fGoodsid',
  597. name: '项目名称',
  598. inputType: 1,
  599. width: 200,
  600. labelSize: '80',
  601. disabled: true,
  602. rules: [{ required: true, message: ' ' }]
  603. }, {
  604. index:'3',
  605. span: 6,
  606. label: 'personNaem',
  607. name: '项目主管',
  608. inputType: 2,
  609. width: 200,
  610. labelSize: '80',
  611. disabled: true,
  612. rules: [{ required: false, message: ' ' }]
  613. }, {
  614. index:'4',
  615. span: 6,
  616. label: 'corpsName',
  617. name: '客户',
  618. inputType: 2,
  619. width: 200,
  620. labelSize: '80',
  621. disabled: true,
  622. rules: [{ required: false, message: ' ' }]
  623. }, {
  624. index:'5',
  625. span: 6,
  626. label: 'fCorpid',
  627. name: '供应商',
  628. inputType: 1,
  629. width: 200,
  630. labelSize: '80',
  631. disabled: true,
  632. rules: [{ required: true, message: ' ' }]
  633. }, {
  634. index:'6',
  635. span: 6,
  636. label: 'fWarehouseid',
  637. name: '仓库',
  638. inputType: 1,
  639. width: 200,
  640. disabled: true,
  641. labelSize: '80',
  642. rules: [{ required: true, message: ' ' }]
  643. }, {
  644. index:'7',
  645. span: 6,
  646. label: 'fBsdate',
  647. name: '提货日期',
  648. inputType: 6,
  649. width: 200,
  650. disabled: true,
  651. labelSize: '80',
  652. rules: [{ required: true, message: ' ' }]
  653. }, {
  654. index:'8',
  655. span: 6,
  656. label: 'createBy',
  657. name: '申请人',
  658. inputType: 2,
  659. width: 200,
  660. disabled: true,
  661. labelSize: '80',
  662. rules: [{ required: false, message: ' ' }]
  663. },
  664. {
  665. index:'9',
  666. span: 6,
  667. label: 'fStudentsWeight',
  668. name: '学生人数',
  669. inputType: 2,
  670. onabort: 'this.value=this.value.replace(/[^0-9]/g,\'\')',
  671. width: 200,
  672. disabled: true,
  673. labelSize: '80',
  674. rules: [{ required: true, message: ' ' }]
  675. }, {
  676. index:'10',
  677. span: 6,
  678. label: 'fTeachersWeight',
  679. name: '教师人数',
  680. onabort: 'this.value=this.value.replace(/[^0-9]/g,\'\')',
  681. inputType: 2,
  682. width: 200,
  683. disabled: true,
  684. labelSize: '80',
  685. rules: [{ required: true, message: ' ' }]
  686. },
  687. {
  688. index:'11',
  689. span: 6,
  690. label: 'fSbu',
  691. name: '开票公司',
  692. inputType: 1,
  693. width: 200,
  694. disabled: true,
  695. labelSize: '80',
  696. rules: [{ required: true, message: ' ' }]
  697. }, {
  698. index:'12',
  699. span: 6,
  700. label: 'remark',
  701. name: '备注',
  702. inputType: 4,
  703. disabled: true,
  704. width: 200,
  705. labelSize: '80',
  706. rules: [{ required: false, message: ' ' }]
  707. }
  708. ]
  709. }
  710. },
  711. activated(){
  712. this.homePage()
  713. },
  714. created() {
  715. let data = {
  716. tableName: this.queryList.tableName,
  717. userId: Cookies.get('userName')
  718. }
  719. this.getRow(data)
  720. this.query(this.formDataList)
  721. productName().then(res => {
  722. console.log(res)
  723. if (res.code === 200) {
  724. for (let item in res.rows) {
  725. this.listData.fFeeid.push({
  726. label: res.rows[item].fName,
  727. value: res.rows[item].fId,
  728. fFeeunitid: res.rows[item].fFeeunitid,
  729. fCurrency: res.rows[item].fCurrency
  730. })
  731. }
  732. }
  733. })
  734. this.getDicts('data_unitfees').then(res => {
  735. console.log(res.data)
  736. for (let item in res.data) {
  737. this.listData.fFeeunitid.push({
  738. label: res.data[item].dictLabel,
  739. value: JSON.parse(res.data[item].dictValue)
  740. })
  741. }
  742. })
  743. this.getDicts('f_paymode').then(res => {
  744. console.log(res)
  745. for (let item in res.data) {
  746. this.listData.fStltypeid.push({
  747. label: res.data[item].dictLabel,
  748. value: JSON.parse(res.data[item].dictValue)
  749. })
  750. }
  751. })
  752. queryItem().then(res => {
  753. console.log(res)
  754. for (let item in res.data) {
  755. this.dataList.fGoodsid.push({
  756. label: res.data[item].projectName,
  757. value: res.data[item].fId,
  758. personNaem: res.data[item].personNaem,
  759. corpsName: res.data[item].corpsName,
  760. fCorpid: res.data[item].fCorpid
  761. })
  762. }
  763. })
  764. //查询仓库
  765. warehouse().then(res => {
  766. console.log(res)
  767. for (let item in res.rows) {
  768. this.dataList.fWarehouseid.push({
  769. label: res.rows[item].fName,
  770. value: res.rows[item].fId
  771. })
  772. }
  773. })
  774. this.fCompany(1)
  775. this.fCompany(2)
  776. },
  777. methods: {
  778. change(scope){
  779. console.log(this.contentList)
  780. for(let item in this.contentList){
  781. for(let li in this.listData.fFeeid){
  782. if(this.contentList[item].fFeeid == this.listData.fFeeid[li].value){
  783. console.log("111")
  784. this.$set(this.contentList[item],'fFeeunitid',this.listData.fFeeid[li].fFeeunitid)
  785. this.$set(this.contentList[item],'fCurrencyName',this.listData.fFeeid[li].fCurrency)
  786. }
  787. }
  788. }
  789. },
  790. homePage(){
  791. let date = this.$route.query
  792. console.log(date)
  793. if (this.$route.query.list){
  794. this.contentButton = this.$options.data().contentButton
  795. this.contentButton.push(JSON.parse(this.$route.query.list))
  796. console.log(this.contentButton)
  797. let scope = {
  798. row:{
  799. fId:JSON.parse(this.$route.query.data).billId
  800. }
  801. }
  802. this.viewMethod(scope)
  803. }
  804. },
  805. // 查看审批流
  806. getDataList() {
  807. this.addOrUpdateVisible = false;
  808. },
  809. returnData() {
  810. this.addOrUpdateVisib = false;
  811. this.open = false;
  812. this.cancelTwo();
  813. },
  814. addOrUpdateHandle() {
  815. this.addOrUpdateVisible = true;
  816. this.$nextTick(() => {
  817. this.$refs.addOrUpdate.init(this.$refs.avatar.form.fId,520);
  818. });
  819. },
  820. addOrUpdateHand() {
  821. this.addOrUpdateVisib = true;
  822. this.$nextTick(() => {
  823. this.$refs.ApprovalComments.init(this.$refs.avatar.form.fId,520);
  824. });
  825. },
  826. //首页审批跳转关闭返回首页
  827. cancelTwo() {
  828. let view = {
  829. fullPath: '/purchaseRequest',
  830. hash: '',
  831. matched: Array(2),
  832. meta: Object,
  833. name: 'PurchaseRequest',
  834. params: Object,
  835. path: '/purchaseRequest',
  836. query: Object,
  837. title: '采购申请'
  838. }
  839. this.$router.push({ path: '/index' })
  840. this.$store
  841. .dispatch('tagsView/delView', view)
  842. .then(({ visitedViews }) => {
  843. if (this.isActive(view)) {
  844. this.toLastView(visitedViews, view)
  845. }
  846. })
  847. Global.$emit('removeCache', 'closeSelectedTag', view)
  848. },
  849. //分页
  850. handleSizeChange(val) {
  851. // console.log(`每页 ${val} 条`);
  852. this.formDataList.pageSize = val
  853. this.query(this.formDataList)
  854. },
  855. handleCurrentChange(val) {
  856. // console.log(`当前页: ${val}`);
  857. this.formDataList.pageNum = val
  858. this.query(this.formDataList)
  859. },
  860. //计算金额
  861. totalAmount(scope) {
  862. console.log(scope)
  863. if (scope.row.fUnitprice && scope.row.fQty) {
  864. scope.row.fAmount = (scope.row.fUnitprice * scope.row.fQty).toFixed(2)
  865. }
  866. },
  867. //查询公司
  868. fCompany(name) {
  869. company(name).then(res => {
  870. console.log(res)
  871. if (name == 1) {
  872. this.dataList.fCorpid = []
  873. for (let item in res.data) {
  874. this.dataList.fCorpid.push({
  875. label: res.data[item].fName,
  876. value: res.data[item].fId
  877. })
  878. }
  879. } else if (name == 2) {
  880. this.dataList.fSbu = []
  881. for (let item in res.data) {
  882. this.dataList.fSbu.push({
  883. label: res.data[item].fName,
  884. value: res.data[item].fId
  885. })
  886. }
  887. }
  888. })
  889. },
  890. //查询主页列数据
  891. query(data) {
  892. listQuery(data).then(res => {
  893. this.tableData = res.rows
  894. this.total = res.total
  895. })
  896. },
  897. //查询列数据
  898. getRow(data,list) {
  899. select(data).then((res) => {
  900. console.log(res)
  901. if (data.tableName === '采购申请详情') {
  902. if (res.data.length != 0) {
  903. this.purchaseList.columnList = res.data.filter((e) => e.checked == 0)
  904. this.purchaseList.columnList = res.data
  905. this.setRowList = res.data
  906. this.purchaseList.columnList = this.purchaseList.columnList.filter((e) => e.checked == 0)
  907. // this.waitFor = true
  908. } else {
  909. // this.waitFor = true
  910. this.purchaseList.columnList = this.contentStyle
  911. this.setRowList = this.contentStyle
  912. }
  913. this.pageDisplay = false
  914. this.isItHidden = false
  915. this.inDex = this.contentOption.length
  916. } else {
  917. if (res.data.length != 0) {
  918. this.queryList.columnList = res.data.filter((e) => e.checked == 0)
  919. this.queryList.columnList = res.data
  920. this.setRowList = res.data
  921. this.queryList.columnList = this.queryList.columnList.filter((e) => e.checked == 0)
  922. // this.waitFor = true
  923. } else {
  924. // this.waitFor = true
  925. this.queryList.columnList = this.listStyle
  926. console.log(this.queryList.columnList.fFeeid)
  927. this.setRowList = this.listStyle
  928. }
  929. this.pageDisplay = true
  930. this.isItHidden = true
  931. this.inDex = 4
  932. }
  933. this.$refs.avatar.form = {}
  934. if (list){
  935. this.$refs.avatar.form = list.warehouseBills
  936. this.contentList = list.tWarehousebillsfees
  937. this.contentButton = this.$options.data().contentButton
  938. if (this.$refs.avatar.form.fBillstatus === 6){
  939. this.contentButton.push({
  940. type: 'danger',
  941. size: 'mini',
  942. icon: 'el-icon-edit-outline',
  943. name: '撤销采购',
  944. disabled: false
  945. })
  946. }else if(this.$refs.avatar.form.fBillstatus === 4){
  947. this.contentButton.push({
  948. type: 'danger',
  949. size: 'mini',
  950. icon: 'el-icon-edit-outline',
  951. name: '撤销审批',
  952. disabled: false
  953. })
  954. }
  955. this.contentButton.forEach(item =>{
  956. if (item.name == '返回列表' || item.name == '修改' || item.name == '打印'){
  957. item.disabled = false
  958. }else {
  959. item.disabled = true
  960. }
  961. })
  962. }
  963. })
  964. },
  965. returnToForm(row) {
  966. console.log(row, 111)
  967. },
  968. //查看
  969. viewMethod(scope) {
  970. console.log(scope)
  971. this.contentOption.forEach(item => item.disabled = true)
  972. this.contentStyle.forEach(item => item.disabled = true)
  973. this.contentButton.forEach(item =>{
  974. if (item.name == '返回列表' || item.name == '修改'){
  975. item.disabled = false
  976. }else {
  977. item.disabled = true
  978. }
  979. })
  980. viewSingle(scope.row.fId).then(res => {
  981. if (res.code === 200) {
  982. let data = {
  983. tableName: this.purchaseList.tableName,
  984. userId: Cookies.get('userName')
  985. }
  986. let list ={
  987. warehouseBills:res.data.warehouseBills,
  988. tWarehousebillsfees:res.data.tWarehousebillsfees
  989. }
  990. this.$refs.avatar.form = {}
  991. this.getRow(data,list)
  992. }
  993. })
  994. },
  995. //修改
  996. modification(scope) {
  997. console.log(scope)
  998. },
  999. //删除
  1000. deletion(scope) {
  1001. console.log(scope.row.fId)
  1002. tableDeleteQuery(scope.row.fId).then(res => {
  1003. console.log(res)
  1004. this.$confirm(res.msg == 1 ? '主表数据为空' : (res.msg == 2 ? '主表有数据' : '未知状态') + '是否永久删除该条数据?', '提示', {
  1005. confirmButtonText: '确定',
  1006. cancelButtonText: '取消',
  1007. type: 'warning'
  1008. }).then(() => {
  1009. confirmDeletion(scope.row.fId).then(data => {
  1010. this.$message({
  1011. type: 'success',
  1012. message: '删除成功!'
  1013. })
  1014. this.query(this.formDataList)
  1015. })
  1016. }).catch(() => {
  1017. this.$message({
  1018. type: 'info',
  1019. message: '已取消删除'
  1020. })
  1021. })
  1022. })
  1023. },
  1024. //选择框
  1025. selectionbox(selection) {
  1026. if (selection.length > 1){
  1027. this.customButton.forEach(item =>{
  1028. if (item.name === '复制新增'){
  1029. item.disabled = true
  1030. }else {
  1031. item.disabled = false
  1032. }
  1033. })
  1034. }else {
  1035. this.customButton.forEach(item => item.disabled = false)
  1036. this.selection = selection
  1037. }
  1038. },
  1039. //详情内容保存
  1040. submitAndSave(item) {
  1041. let formData = new window.FormData()
  1042. this.$refs.avatar.form.fMoney = 0
  1043. this.contentList.forEach(item => this.$refs.avatar.form.fMoney += Number(item.fAmount))
  1044. formData.append('tWarehousebills', JSON.stringify(this.$refs.avatar.form))
  1045. formData.append('tWarehousebillsfees', JSON.stringify(this.contentList))
  1046. formData.append('fBilltype', 'SQ')
  1047. submit(formData).then(res => {
  1048. if (res.code == 200) {
  1049. this.$message.success('保存成功')
  1050. this.$refs.avatar.form = res.data.warehouseBills
  1051. this.contentList = res.data.tWarehousebillsCntrs
  1052. console.log(this.dataList, this.contentList)
  1053. if (item == 1){
  1054. this.dialogVisible = true
  1055. }else if (item === 2){
  1056. let data = {
  1057. tableName: this.queryList.tableName,
  1058. userId: Cookies.get('userName')
  1059. }
  1060. this.getRow(data)
  1061. this.query(this.formDataList)
  1062. }
  1063. }
  1064. })
  1065. },
  1066. //表单选中后触发
  1067. selectTrigger(name, list, id) {
  1068. console.log(list, id)
  1069. if (name == 'fGoodsid') {
  1070. for (let item in list) {
  1071. if (list[item].value == id) {
  1072. this.$refs.avatar.form.personNaem = list[item].personNaem
  1073. this.$refs.avatar.form.corpsName = list[item].corpsName
  1074. }
  1075. }
  1076. }
  1077. },
  1078. //确认打印
  1079. Printing(){
  1080. this.$print(this.$refs.print)
  1081. },
  1082. //所以按钮
  1083. buttonList(row) {
  1084. console.log(row)
  1085. let data
  1086. switch (row.name) {
  1087. case '新增':
  1088. this.contentList = []
  1089. data = {
  1090. tableName: this.purchaseList.tableName,
  1091. userId: Cookies.get('userName')
  1092. }
  1093. this.$refs.avatar.form = {}
  1094. this.getRow(data)
  1095. this.contentOption.forEach(item => {
  1096. if (item.label == 'personNaem' || item.label == 'corpsName' || item.label == 'createBy' || item.label == 'fBillno') {
  1097. item.disabled = true
  1098. } else {
  1099. item.disabled = false
  1100. }
  1101. })
  1102. this.contentButton.forEach(item => item.disabled = false)
  1103. this.contentStyle.forEach(item => item.disabled = false)
  1104. this.$refs.avatar.form.createBy = Cookies.get('userName')
  1105. break
  1106. case '保存':
  1107. this.$refs.avatar.submitForm('submit')
  1108. break
  1109. case '打印':
  1110. console.log(this.listData.fFeeid,this.contentList)
  1111. for (let item in this.contentList){
  1112. for (let li in this.listData.fFeeid){
  1113. if (this.contentList[item].fFeeid == this.listData.fFeeid[li].value){
  1114. this.contentList[item].feeName = this.listData.fFeeid[li].label
  1115. }
  1116. }
  1117. for(let i in this.listData.fFeeunitid){
  1118. if (this.contentList[item].fFeeunitid == this.listData.fFeeunitid[i].value){
  1119. this.contentList[item].fFeeunitName = this.listData.fFeeunitid[i].label
  1120. }
  1121. }
  1122. }
  1123. if (!this.$refs.avatar.form.fId){
  1124. this.$message.error('未保存,不允许打印');
  1125. }else if (this.$refs.avatar.form.fBillstatus >= 4){
  1126. this.formList = this.$refs.avatar.form
  1127. this.dialogVisible = true
  1128. }else {
  1129. this.formList = this.$refs.avatar.form
  1130. console.log(this.$refs.avatar.form.fBillstatus)
  1131. this.submitAndSave(1)
  1132. }
  1133. break
  1134. case '修改':
  1135. this.contentButton.forEach(item =>{
  1136. if (this.$refs.avatar.form.fBillstatus >= 4){
  1137. if (item.name === '返回列表' || item.name == '打印' || item.name === '修改' || item.name === '生成入库单' || item.name === '生成销售单'||item.name === '生成出库单' || item.name === '查看审批' || item.name === '审批' || item.name === '撤销采购' || item.name === '撤销审批'){
  1138. item.disabled = false
  1139. }else {
  1140. item.disabled = true
  1141. }
  1142. }else {
  1143. item.disabled = false
  1144. this.contentStyle.forEach(item => item.disabled = false)
  1145. this.contentOption.forEach(item => {
  1146. if (item.label == 'personNaem' || item.label == 'corpsName' || item.label == 'createBy' || item.label == 'fBillno') {
  1147. item.disabled = true
  1148. } else {
  1149. item.disabled = false
  1150. }
  1151. })
  1152. }
  1153. })
  1154. break
  1155. case '录入':
  1156. this.contentList.push({
  1157. fFeeid: '',
  1158. fUnitprice: '',
  1159. fPurchase: '',
  1160. fQty: '',
  1161. fFeeunitid: '',
  1162. fAmount: '',
  1163. fStltypeid: '',
  1164. remark: '',
  1165. createTime: '',
  1166. createBy: Cookies.get('userName'),
  1167. fReviewDate: '',
  1168. operation: '',
  1169. })
  1170. break
  1171. case '查看审批':
  1172. this.addOrUpdateHandle()
  1173. break
  1174. case '审批':
  1175. this.addOrUpdateHand()
  1176. break
  1177. case '返回列表':
  1178. console.log(this.$route.query.data)
  1179. if (!this.$refs.avatar.form.fId && this.contentList !== 0 || this.$refs.avatar.form.fBillstatus > 3 && !this.$route.query.data) {
  1180. data = {
  1181. tableName: this.queryList.tableName,
  1182. userId: Cookies.get('userName')
  1183. }
  1184. this.getRow(data)
  1185. this.query(this.formDataList)
  1186. } else if(this.$route.query.data){
  1187. this.cancelTwo();
  1188. this.$router.push({path:'/index'})
  1189. }else {
  1190. this.$confirm('当前数据未保存是否保存?', '提示', {
  1191. confirmButtonText: '保存',
  1192. cancelButtonText: '取消',
  1193. type: 'warning'
  1194. }).then(() => {
  1195. this.submitAndSave(2)
  1196. }).catch(() => {
  1197. data = {
  1198. tableName: this.queryList.tableName,
  1199. userId: Cookies.get('userName')
  1200. }
  1201. this.getRow(data)
  1202. this.query(this.formDataList)
  1203. })
  1204. }
  1205. break
  1206. case '请核':
  1207. if (this.$refs.avatar.form.fBillstatus < 4){
  1208. this.$refs.avatar.submitForm('check')
  1209. }else {
  1210. this.$message.error('请先保存');
  1211. }
  1212. break
  1213. case '生成入库单':
  1214. let listData = {
  1215. fId:this.$refs.avatar.form.fId,
  1216. fBilltype:'RK'
  1217. }
  1218. copyNew(listData).then(res=>{
  1219. this.$message({
  1220. message: '生成成功',
  1221. type: 'success',
  1222. showClose:true
  1223. });
  1224. })
  1225. break
  1226. case '生成销售单':
  1227. let liste = {
  1228. fId:this.$refs.avatar.form.fId,
  1229. fBilltype:'XS'
  1230. }
  1231. copyNew(liste).then(res=>{
  1232. this.$message({
  1233. message: '生成成功',
  1234. type: 'success',
  1235. showClose:true
  1236. });
  1237. })
  1238. break
  1239. case '生成出库单':
  1240. let listd = {
  1241. fId:this.$refs.avatar.form.fId,
  1242. fBilltype:'CK'
  1243. }
  1244. copyNew(listd).then(res=>{
  1245. this.$message({
  1246. message: '生成成功',
  1247. type: 'success',
  1248. showClose:true
  1249. });
  1250. })
  1251. break
  1252. case '复制新增':
  1253. if (this.selection.length > 0){
  1254. let datae = {
  1255. fId:this.selection[0].fId,
  1256. fBilltype:'SQ'
  1257. }
  1258. copyNew(datae).then(res=>{
  1259. this.$message({
  1260. message: '复制新增成功',
  1261. type: 'success',
  1262. showClose:true
  1263. });
  1264. this.query(this.formDataList)
  1265. })
  1266. }else {
  1267. this.$message.warning('未选择列表,请选择后再点击');
  1268. }
  1269. break
  1270. case '撤销审批':
  1271. let date = new Date()
  1272. let y = date.getFullYear()
  1273. let m = (date.getMonth() + 1 < 10 ? '0' + (date.getMonth() + 1) : date.getMonth() + 1)
  1274. let d = (date.getDate() < 10 ? '0' + (date.getDate()) : date.getDate())
  1275. data = {
  1276. actId:520,
  1277. id:this.$refs.avatar.form.fId,
  1278. billId:this.$refs.avatar.form.fId,
  1279. auditItem:y + '-' + m + '-' + d
  1280. }
  1281. console.log(data)
  1282. revoke(data).then(res=>{
  1283. if (res.code === 200){
  1284. this.$message({
  1285. showClose: true,
  1286. message: '撤销成功',
  1287. type: 'success'
  1288. })
  1289. data = {
  1290. tableName: this.queryList.tableName,
  1291. userId: Cookies.get('userName')
  1292. }
  1293. this.getRow(data)
  1294. this.query(this.formDataList)
  1295. }
  1296. })
  1297. break
  1298. case '撤销采购':
  1299. withdrawBy(this.$refs.avatar.form.fId).then(res=>{
  1300. if (res.code === 200){
  1301. this.$message({
  1302. showClose: true,
  1303. message: '撤销成功',
  1304. type: 'success'
  1305. })
  1306. data = {
  1307. tableName: this.queryList.tableName,
  1308. userId: Cookies.get('userName')
  1309. }
  1310. this.getRow(data)
  1311. this.query(this.formDataList)
  1312. }
  1313. })
  1314. break
  1315. default:
  1316. this.$message.error('该按钮暂无功能')
  1317. }
  1318. },
  1319. //请核
  1320. writeOff(){
  1321. let formData = new window.FormData()
  1322. formData.append('tWarehousebills', JSON.stringify(this.$refs.avatar.form))
  1323. formData.append('tWarehousebillsfees', JSON.stringify(this.contentList))
  1324. formData.append('fBilltype', 'SQ')
  1325. pleaseCheck(formData).then(res => {
  1326. if (res.code == 200) {
  1327. this.$message.success('请核成功')
  1328. this.contentOption.forEach(item => item.disabled = true)
  1329. this.contentStyle.forEach(item => item.disabled = true)
  1330. this.contentButton.forEach(item =>{
  1331. if (item.name == '返回列表' || item.name == '修改'){
  1332. item.disabled = false
  1333. }else {
  1334. item.disabled = true
  1335. }
  1336. })
  1337. // this.$refs.avatar.form = res.data.warehouseBills
  1338. // this.contentList = res.data.tWarehousebillsCntrs
  1339. let data = {
  1340. tableName: this.queryList.tableName,
  1341. userId: Cookies.get('userName')
  1342. }
  1343. this.getRow(data)
  1344. this.query(this.formDataList)
  1345. }
  1346. })
  1347. },
  1348. // 显示搜索条件、点击后会调用此方法
  1349. showSearch() {
  1350. console.log('到我了')
  1351. this.searchWhether = !this.searchWhether
  1352. },
  1353. //搜索、重置、展开
  1354. feedback(res) {
  1355. console.log(res)
  1356. if (res == '展开') {
  1357. if (this.inDex == 4) {
  1358. this.inDex = this.formOption.length
  1359. } else {
  1360. this.inDex = 4
  1361. }
  1362. } else if (res == '搜索') {
  1363. this.$refs.avatar.submitForm()
  1364. } else if (res == '重置') {
  1365. this.$refs.avatar.form = {}
  1366. this.$refs.avatar.submitForm()
  1367. }
  1368. },
  1369. //表单验证通过执行搜索
  1370. submitForm() {
  1371. let list = this.formDataList
  1372. console.log(this.$refs.avatar.form)
  1373. this.formDataList = this.$refs.avatar.form
  1374. this.formDataList.fBilltype = list.fBilltype
  1375. this.formDataList.pageSize = list.pageSize
  1376. this.formDataList.pageNum = list.pageNum
  1377. this.query(this.formDataList)
  1378. },
  1379. //点击刷新会调用此方法
  1380. getList() {
  1381. this.feedback('重置')
  1382. this.submitForm()
  1383. console.log('到我了2')
  1384. },
  1385. //详情表内容移出
  1386. deletRows(index, rows) {
  1387. console.log(index, rows)
  1388. if (rows[index].fId) {
  1389. deleteQuery(this.$refs.avatar.form.fId, this.$refs.avatar.form.fDateChanged).then(res => {
  1390. if (res.code === 200) {
  1391. listDelete(rows[index].fId).then(data => {
  1392. rows.splice(index, 1)
  1393. })
  1394. }
  1395. })
  1396. } else {
  1397. rows.splice(index, 1)
  1398. }
  1399. }
  1400. }
  1401. }
  1402. </script>
  1403. <style scoped>
  1404. .table {
  1405. border-collapse: collapse;
  1406. border-spacing: 0;
  1407. background-color: transparent;
  1408. display: table;
  1409. width: 100%;
  1410. max-width: 100%;
  1411. margin: 0 auto;
  1412. }
  1413. .table td {
  1414. text-align: center;
  1415. vertical-align: middle;
  1416. font-size: 14px;
  1417. color: #333333;
  1418. padding: 8px 12px;
  1419. }
  1420. .column {
  1421. border: 1px solid #000;
  1422. }
  1423. .app-container >>> .el-form-item{
  1424. margin-bottom: 0;
  1425. }
  1426. </style>