detailsPage.vue 37 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268
  1. <template>
  2. <div class="borderless" v-loading="pageLoading">
  3. <div class="customer-head">
  4. <div class="customer-back">
  5. <el-button
  6. type="danger"
  7. style="border: none;background: none;color: red"
  8. icon="el-icon-arrow-left"
  9. @click="backToList"
  10. >返回列表
  11. </el-button>
  12. </div>
  13. <div class="add-customer-btn" v-if="showBut" size="small">
  14. <el-button
  15. type="primary"
  16. size="small"
  17. v-if="detailData.status == 1"
  18. class="el-button--small-yh "
  19. @click.stop="openEdit"
  20. >编辑
  21. </el-button>
  22. <el-dropdown style="margin-right: 8px;margin-left: 8px;">
  23. <el-button type="primary" size="small">
  24. 审核处理<i class="el-icon-arrow-down el-icon--right"></i>
  25. </el-button>
  26. <el-dropdown-menu slot="dropdown">
  27. <el-dropdown-item
  28. :disabled="form.status > 0"
  29. @click.native="pleaseCheck"
  30. >请核数据</el-dropdown-item
  31. >
  32. <el-dropdown-item disabled>审核进度</el-dropdown-item>
  33. <el-dropdown-item disabled>撤销请核</el-dropdown-item>
  34. </el-dropdown-menu>
  35. </el-dropdown>
  36. <el-dropdown style="margin-right: 8px;">
  37. <el-button type="warning" size="small">
  38. 账单处理<i class="el-icon-arrow-down el-icon--right"></i>
  39. </el-button>
  40. <el-dropdown-menu slot="dropdown">
  41. <el-dropdown-item @click.native="generateBill" :disabled="!form.id"
  42. >申请货款</el-dropdown-item
  43. >
  44. <el-dropdown-item @click.native="viewBill" :disabled="!form.id"
  45. >查看货款</el-dropdown-item
  46. >
  47. </el-dropdown-menu>
  48. </el-dropdown>
  49. <el-dropdown style="margin-right: 8px;">
  50. <el-button type="success" size="small">
  51. 业务处理<i class="el-icon-arrow-down el-icon--right"></i>
  52. </el-button>
  53. <el-dropdown-menu slot="dropdown">
  54. <el-dropdown-item :disabled="!form.id" @click.native="copyDoc"
  55. >复制单据</el-dropdown-item
  56. >
  57. </el-dropdown-menu>
  58. </el-dropdown>
  59. <el-button
  60. type="primary"
  61. :disabled="disabled"
  62. @click="editCustomer"
  63. :loading="subLoading"
  64. v-if="detailData.status != 1"
  65. size="small"
  66. >保存数据
  67. </el-button>
  68. </div>
  69. </div>
  70. <div class="customer-main">
  71. <containerTitle title="基础信息"></containerTitle>
  72. <basic-container>
  73. <avue-form
  74. ref="form"
  75. class="trading-form"
  76. v-model="form"
  77. :option="option"
  78. >
  79. <template slot="corpId">
  80. <crop-select
  81. v-model="form.corpId"
  82. corpType="GYS"
  83. :disabled="detailData.status == 1"
  84. ></crop-select>
  85. </template>
  86. <template slot="exchangeRate">
  87. <el-input
  88. size="mini"
  89. v-model="form.exchangeRate"
  90. oninput="value=value.replace(/[^0-9.]/g,'').replace(/^(\-)*(\d+)\.(\d\d).*$/,'$1$2.$3')"
  91. @change="rateChange"
  92. placeholder="请输入 汇率"
  93. :disabled="detailData.status == 1"
  94. ><template slot="append">%</template></el-input
  95. >
  96. </template>
  97. <template slot="orderNo">
  98. <el-input
  99. size="mini"
  100. v-model="form.orderNo"
  101. oninput="this.value=this.value.toUpperCase()"
  102. placeholder="请输入 "
  103. :disabled="detailData.status == 1"
  104. />
  105. </template>
  106. </avue-form>
  107. </basic-container>
  108. <div>
  109. <containerTitle title="商品信息"></containerTitle>
  110. <basic-container>
  111. <avue-crud
  112. ref="crud"
  113. :data="data"
  114. :option="tableOption"
  115. @row-del="rowDel"
  116. @selection-change="goodsSelectionChange"
  117. @saveColumn="saveColumn"
  118. @resetColumn="resetColumn"
  119. :summary-method="summaryMethod"
  120. :cell-style="cellStyle"
  121. >
  122. <template slot="price" slot-scope="{ row }">
  123. <el-input
  124. v-if="row.$cellEdit"
  125. v-model="row.price"
  126. size="small"
  127. oninput="value=value.replace(/[^0-9.]/g,'').replace(/^(\-)*(\d+)\.(\d\d).*$/,'$1$2.$3')"
  128. @change="priceChange(row)"
  129. ></el-input>
  130. <span v-else>{{ row.price }}</span>
  131. </template>
  132. <template slot="orderQuantity" slot-scope="{ row }">
  133. <el-input
  134. v-if="row.$cellEdit"
  135. v-model="row.orderQuantity"
  136. size="small"
  137. oninput='this.value=this.value.replace(/[^(\d)]/g,"")'
  138. @change="quantityChange(row)"
  139. ></el-input>
  140. <span v-else>{{ row.orderQuantity | IntegerFormat }}</span>
  141. </template>
  142. <template slot="cname" slot-scope="{ row, index }">
  143. <el-button
  144. size="small"
  145. type="text"
  146. @click="rePick(row, index)"
  147. :disabled="disabled || detailData.status == 1"
  148. class="picker"
  149. style="padding:4px 10px;float:left"
  150. >选择</el-button
  151. >
  152. <span>{{ row.cname }}</span>
  153. </template>
  154. <template slot="itemType" slot-scope="{ row }">
  155. <el-select
  156. v-if="row.$cellEdit"
  157. v-model="row.itemType"
  158. filterable
  159. allow-create
  160. default-first-option
  161. placeholder="请输入"
  162. @focus="itemTypeFocus(row)"
  163. size="small"
  164. >
  165. <el-option
  166. v-for="(item, index) in itemtypeList"
  167. :key="index"
  168. :label="item.value"
  169. :value="item.value"
  170. >
  171. </el-option>
  172. </el-select>
  173. <span v-else>{{ row.itemType }}</span>
  174. </template>
  175. <template slot="menuLeft">
  176. <el-button
  177. type="primary"
  178. icon="el-icon-plus"
  179. size="small"
  180. @click.stop="newDetails"
  181. :disabled="detailData.status == 1"
  182. >录入明细</el-button
  183. >
  184. <el-button
  185. type="info"
  186. icon="el-icon-printer"
  187. size="small"
  188. @click.stop="openReport()"
  189. >报 表</el-button
  190. >
  191. <el-button
  192. type="warning"
  193. icon="el-icon-plus"
  194. size="small"
  195. :disabled="detailData.status == 1 || orderItemIds.length == 0"
  196. @click="getInvoice"
  197. >生成收货单
  198. </el-button>
  199. </template>
  200. <template slot="menu" slot-scope="{ row, index }">
  201. <el-button
  202. size="small"
  203. icon="el-icon-edit"
  204. type="text"
  205. @click="rowCell(row, index)"
  206. :disabled="disabled || detailData.status == 1"
  207. >{{ row.$cellEdit ? "保存" : "修改" }}</el-button
  208. >
  209. <el-button
  210. size="small"
  211. icon="el-icon-edit"
  212. type="text"
  213. @click="rowDel(row, index)"
  214. :disabled="detailData.status == 1"
  215. >删 除</el-button
  216. >
  217. </template>
  218. </avue-crud>
  219. </basic-container>
  220. </div>
  221. <fee-info
  222. ref="feeInfo"
  223. :orderFeesList="orderFeesList"
  224. :disabled="detailData.status == 1"
  225. feeUrl="/trade-purchase/purchase-order/removeByFees"
  226. optionType="CK"
  227. itemType="采购"
  228. @beforeFinance="beforeFinance"
  229. :corpId="form.corpId"
  230. />
  231. <upload-file
  232. ref="uploadFile"
  233. title="合同附件"
  234. :orderFilesList="orderFilesList"
  235. :disabled="detailData.status == 1"
  236. delUrl="/trade-purchase/purchase-order/removeByFiles"
  237. />
  238. <div>
  239. <containerTitle title="银行信息"></containerTitle>
  240. <basic-container>
  241. <avue-form
  242. class="trading-form"
  243. ref="form"
  244. v-model="form"
  245. :option="bankOption"
  246. />
  247. </basic-container>
  248. </div>
  249. </div>
  250. <el-dialog
  251. title="账单"
  252. append-to-body
  253. class="el-dialogDeep"
  254. :visible.sync="financialAccountDialog"
  255. width="60%"
  256. :close-on-click-modal="false"
  257. :destroy-on-close="true"
  258. :close-on-press-escape="false"
  259. v-dialog-drag
  260. >
  261. <financial-account
  262. billType="申请"
  263. :billData="billData"
  264. itemType="采购"
  265. @choceFun="choceFun"
  266. >
  267. </financial-account>
  268. </el-dialog>
  269. <el-dialog
  270. title="申请记录"
  271. append-to-body
  272. class="el-dialogDeep"
  273. :visible.sync="applicationDialog"
  274. width="60%"
  275. :close-on-click-modal="false"
  276. :destroy-on-close="true"
  277. :close-on-press-escape="false"
  278. v-dialog-drag
  279. >
  280. <bill-application :billId="form.id" @choceApplication="choceApplication">
  281. </bill-application>
  282. </el-dialog>
  283. <el-dialog
  284. title="导入商品"
  285. append-to-body
  286. class="el-dialogDeep"
  287. :visible.sync="dialogVisible"
  288. width="80%"
  289. :close-on-click-modal="false"
  290. :destroy-on-close="true"
  291. :close-on-press-escape="false"
  292. @close="closeGoods"
  293. top="5vh"
  294. v-dialog-drag
  295. >
  296. <span>
  297. <el-row>
  298. <el-col :span="4">
  299. <div>
  300. <el-scrollbar>
  301. <basic-container>
  302. <avue-tree
  303. :option="treeOption"
  304. @node-click="nodeClick"
  305. :style="treeStyle"
  306. />
  307. </basic-container>
  308. </el-scrollbar>
  309. </div>
  310. </el-col>
  311. <el-col :span="20">
  312. <avue-crud
  313. :option="goodsOption"
  314. :table-loading="loading"
  315. :data="goodsList"
  316. ref="goodsCrud"
  317. @refresh-change="refreshChange"
  318. @selection-change="selectionChange"
  319. @row-click="rowClick"
  320. :page.sync="page"
  321. @on-load="onLoad"
  322. @saveColumn="saveGoodsColumn"
  323. @resetColumn="resetGoodsColumn"
  324. :cell-style="cellStyle"
  325. ></avue-crud>
  326. </el-col>
  327. </el-row>
  328. </span>
  329. <span slot="footer" class="dialog-footer">
  330. <el-button @click="dialogVisible = false">取 消</el-button>
  331. <el-button
  332. type="primary"
  333. @click="importGoods"
  334. :disabled="selectionList.length == 0"
  335. >导入</el-button
  336. >
  337. </span>
  338. </el-dialog>
  339. <report-dialog
  340. :switchDialog="switchDialog"
  341. :reportId="form.id"
  342. reportName="客户询价"
  343. @onClose="onClose()"
  344. ></report-dialog>
  345. </div>
  346. </template>
  347. <script>
  348. import tableOption from "./config/customerContact.json";
  349. import goodsOption from "./config/commodity.json";
  350. import feeInfo from "@/components/fee-info/main";
  351. import uploadFile from "@/components/upload-file/main";
  352. import {
  353. detail,
  354. submit,
  355. delItem,
  356. getDeptLazyTree,
  357. getGoods,
  358. getSpecification,
  359. pleaseCheck
  360. } from "@/api/exportTrade/purchaseContract";
  361. import _ from "lodash";
  362. import reportDialog from "@/components/report-dialog/main";
  363. import { contrastObj, contrastList } from "@/util/contrastData";
  364. import {
  365. isvalidatemobile,
  366. validatename,
  367. micrometerFormat,
  368. IntegerFormat
  369. } from "@/util/validate";
  370. import financialAccount from "@/components/finance/financialAccount";
  371. import billApplication from "@/components/bill/billApplication";
  372. export default {
  373. name: "detailsPageEdit",
  374. data() {
  375. return {
  376. billData: {}, //账单需要数据
  377. financialAccountDialog: false,
  378. applicationDialog: false,
  379. treeStyle: "height:" + (window.innerHeight - 315) + "px",
  380. switchDialog: false,
  381. form: {
  382. orderStatus: "录入"
  383. },
  384. disabled: false,
  385. dialogVisible: false,
  386. tableOption: tableOption,
  387. option: {
  388. menuBtn: false,
  389. labelWidth: 100,
  390. disabled: false,
  391. column: [
  392. {
  393. label: "供应商",
  394. prop: "corpId",
  395. rules: [
  396. {
  397. required: true,
  398. message: "",
  399. trigger: "blur"
  400. }
  401. ],
  402. span: 16,
  403. slot: true
  404. },
  405. {
  406. label: "系统号",
  407. prop: "sysNo",
  408. span: 8,
  409. disabled: true
  410. },
  411. {
  412. label: "联系人",
  413. prop: "corpAttn",
  414. span: 8
  415. },
  416. {
  417. label: "电话",
  418. prop: "corpTel",
  419. span: 8
  420. },
  421. {
  422. label: "订单状态",
  423. prop: "orderStatus",
  424. span: 8,
  425. type: "select",
  426. dicUrl: "/api/blade-system/dict-biz/dictionary?code=order_status",
  427. props: {
  428. label: "dictValue",
  429. value: "dictValue"
  430. }
  431. },
  432. {
  433. label: "采购日期",
  434. prop: "businesDate",
  435. span: 8,
  436. type: "date",
  437. format: "yyyy-MM-dd",
  438. valueFormat: "yyyy-MM-dd 00:00:00",
  439. rules: [
  440. {
  441. required: true,
  442. message: "",
  443. trigger: "blur"
  444. }
  445. ]
  446. },
  447. {
  448. label: "预交日期",
  449. prop: "plannedDeliveryDate",
  450. span: 8,
  451. type: "date",
  452. format: "yyyy-MM-dd",
  453. valueFormat: "yyyy-MM-dd 00:00:00"
  454. },
  455. {
  456. label: "实交日期",
  457. prop: "requiredDeliveryDate",
  458. span: 8,
  459. type: "date",
  460. format: "yyyy-MM-dd",
  461. valueFormat: "yyyy-MM-dd 00:00:00"
  462. },
  463. {
  464. label: "是否开票",
  465. prop: "ifInvoice",
  466. span: 8,
  467. type: "select",
  468. dicUrl: "/api/blade-system/dict-biz/dictionary?code=ifInvoice",
  469. props: {
  470. label: "dictValue",
  471. value: "dictValue"
  472. }
  473. },
  474. {
  475. label: "付款方式",
  476. prop: "paymentType",
  477. span: 8,
  478. type: "select",
  479. dicUrl: "/api/blade-system/dict-biz/dictionary?code=payment_term",
  480. props: {
  481. label: "dictValue",
  482. value: "dictValue"
  483. }
  484. },
  485. {
  486. label: "付款说明",
  487. prop: "paymentTypeDescription",
  488. span: 8
  489. },
  490. {
  491. label: "采购订单号",
  492. prop: "orderNo",
  493. span: 8
  494. },
  495. {
  496. label: "币别",
  497. prop: "currency",
  498. span: 8,
  499. type: "select",
  500. dicUrl: "/api/blade-system/dict-biz/dictionary?code=currency",
  501. props: {
  502. label: "dictValue",
  503. value: "dictValue"
  504. },
  505. change: ({ value }) => {
  506. if (value == "CNY") {
  507. this.form.exchangeRate = 1;
  508. }
  509. if (value == "USD") {
  510. this.form.exchangeRate = 6.3843;
  511. }
  512. }
  513. },
  514. {
  515. label: "汇率",
  516. prop: "exchangeRate",
  517. span: 8,
  518. slot: true,
  519. row: true,
  520. disabled: true
  521. },
  522. {
  523. label: "备注",
  524. prop: "orderRemark",
  525. type: "textarea",
  526. minRows: 2,
  527. span: 24
  528. }
  529. ]
  530. },
  531. treeOption: {
  532. nodeKey: "id",
  533. lazy: true,
  534. treeLoad: function(node, resolve) {
  535. const parentId = node.level === 0 ? 0 : node.data.id;
  536. getDeptLazyTree(parentId).then(res => {
  537. resolve(
  538. res.data.data.map(item => {
  539. return {
  540. ...item,
  541. leaf: !item.hasChildren
  542. };
  543. })
  544. );
  545. });
  546. },
  547. addBtn: false,
  548. menu: false,
  549. size: "small",
  550. props: {
  551. label: "title",
  552. value: "value",
  553. children: "children"
  554. }
  555. },
  556. bankOption: {
  557. menuBtn: false,
  558. labelWidth: 100,
  559. column: [
  560. {
  561. label: "银行",
  562. prop: "banks",
  563. span: 8
  564. },
  565. {
  566. label: "银行信息",
  567. prop: "banksAccountName",
  568. span: 16,
  569. type: "textarea",
  570. minRows: 2
  571. }
  572. ]
  573. },
  574. insuranceOption: {
  575. menuBtn: false,
  576. labelWidth: 100,
  577. column: [
  578. {
  579. label: "保险描述",
  580. prop: "insuranceRemarks",
  581. span: 24,
  582. type: "textarea",
  583. minRows: 2
  584. }
  585. ]
  586. },
  587. markOption: {
  588. menuBtn: false,
  589. labelWidth: 100,
  590. column: [
  591. {
  592. label: "唛头描述",
  593. prop: "marks",
  594. span: 24,
  595. type: "textarea",
  596. minRows: 2
  597. }
  598. ]
  599. },
  600. page: {
  601. pageSize: 10,
  602. currentPage: 1,
  603. total: 0
  604. },
  605. loading: false,
  606. goodsOption: {},
  607. data: [],
  608. goodsList: [],
  609. selectionList: [],
  610. treeDeptId: null,
  611. orderFeesList: [],
  612. orderFilesList: [],
  613. orderItemIds: [],
  614. itemtypeList: [],
  615. goodsSelections: [],
  616. reData: null,
  617. oldform: {
  618. orderStatus: "录入"
  619. },
  620. olddata: [],
  621. oldorderFeesList: [],
  622. oldorderFilesList: [],
  623. subLoading: false,
  624. pageLoading: false,
  625. showBut: true
  626. };
  627. },
  628. props: {
  629. detailData: {
  630. type: Object
  631. }
  632. },
  633. components: {
  634. reportDialog,
  635. feeInfo,
  636. uploadFile,
  637. financialAccount,
  638. billApplication
  639. },
  640. async created() {
  641. if (this.detailData.id) {
  642. this.getDetail(this.detailData.id);
  643. }
  644. this.tableOption = await this.getColumnData(
  645. this.getColumnName(3),
  646. tableOption
  647. );
  648. this.goodsOption = await this.getColumnData(
  649. this.getColumnName(27),
  650. goodsOption
  651. );
  652. if (this.detailData.status == 1) {
  653. this.option.disabled = true;
  654. this.bankOption.disabled = true;
  655. this.insuranceOption.disabled = true;
  656. this.markOption.disabled = true;
  657. }
  658. this.getWorkDicts("product_properties").then(res => {
  659. this.findObject(this.tableOption.column, "itemProp").dicData =
  660. res.data.data;
  661. });
  662. this.getWorkDicts("unit").then(res => {
  663. this.findObject(this.tableOption.column, "unit").dicData = res.data.data;
  664. });
  665. },
  666. filters: {
  667. IntegerFormat(num) {
  668. return IntegerFormat(num);
  669. }
  670. },
  671. methods: {
  672. cellStyle() {
  673. return "padding:0;height:40px;";
  674. },
  675. copyDoc() {
  676. this.$emit("copyOrder", this.form.id);
  677. },
  678. rePick(row, index) {
  679. this.reData = {
  680. ...row,
  681. index: index
  682. };
  683. this.newDetails();
  684. },
  685. rowCell(row, index) {
  686. if (row.$cellEdit == true) {
  687. this.$set(row, "$cellEdit", false);
  688. } else {
  689. this.$set(row, "$cellEdit", true);
  690. }
  691. },
  692. itemTypeFocus(row) {
  693. this.itemtypeList = [];
  694. getSpecification({ goodId: row.itemId }).then(res => {
  695. const data = res.data.data;
  696. this.itemtypeList = data.map(item => ({ value: item }));
  697. });
  698. },
  699. priceChange(row) {
  700. console.log(row);
  701. if (!row.price) {
  702. row.price = 0;
  703. } else {
  704. row.amount = _.multiply(row.price, row.orderQuantity).toFixed(2);
  705. }
  706. },
  707. quantityChange(row) {
  708. if (Number(row.orderQuantity) < Number(row.actualQuantity)) {
  709. row.orderQuantity = row.actualQuantity;
  710. this.$message.error("修改的数量不能低于已收数量");
  711. }
  712. if (!row.orderQuantity) {
  713. row.orderQuantity = 0;
  714. } else {
  715. row.amount = _.multiply(row.price, row.orderQuantity).toFixed(2);
  716. }
  717. },
  718. rowSave(row) {
  719. console.log(row);
  720. this.$set(row, "$cellEdit", false);
  721. },
  722. rowDel(row, index) {
  723. this.$confirm("确定删除数据?", {
  724. confirmButtonText: "确定",
  725. cancelButtonText: "取消",
  726. type: "warning"
  727. }).then(() => {
  728. if (row.id) {
  729. delItem(row.id).then(res => {
  730. this.$message({
  731. type: "success",
  732. message: "删除成功!"
  733. });
  734. this.data.splice(index, 1);
  735. });
  736. } else {
  737. this.$message({
  738. type: "success",
  739. message: "删除成功!"
  740. });
  741. this.data.splice(index, 1);
  742. }
  743. });
  744. },
  745. importGoods() {
  746. if (this.reData) {
  747. console.log(this.reData);
  748. if (this.selectionList.length != 1) {
  749. return this.$message.error("重新选择的时候只能选择一条数据");
  750. } else {
  751. this.selectionList.forEach(e => {
  752. this.data.forEach((item, index) => {
  753. if (index == this.reData.index) {
  754. item.itemId = e.id;
  755. item.code = e.code;
  756. item.cname = e.cname;
  757. item.priceCategory = e.goodsTypeName;
  758. item.itemUrl = e.url;
  759. item.itemProp = this.reData.itemProp;
  760. item.itemDescription = e.cnameDescription;
  761. item.itemType = this.reData.itemType;
  762. item.tradeTerms = this.reData.tradeTerms;
  763. item.price = this.reData.price;
  764. item.orderQuantity = this.reData.orderQuantity;
  765. item.insurance = this.reData.insurance;
  766. item.freight = this.reData.freight;
  767. item.discount = this.reData.discount;
  768. item.amount = this.reData.amount;
  769. item.taxRate = this.reData.taxRate;
  770. item.unit = e.unit;
  771. item.remarks = this.reData.remarks;
  772. item.$cellEdit = true;
  773. }
  774. });
  775. });
  776. }
  777. } else {
  778. this.selectionList.forEach(e => {
  779. this.data.push({
  780. itemId: e.id,
  781. code: e.code,
  782. cname: e.cname,
  783. priceCategory: e.goodsTypeName,
  784. itemUrl: e.url,
  785. itemProp: null,
  786. itemDescription: e.cnameDescription,
  787. itemType: null,
  788. tradeTerms: null,
  789. price: 0,
  790. orderQuantity: 0,
  791. insurance: 0,
  792. freight: 0,
  793. discount: null,
  794. amount: 0,
  795. taxRate: 0,
  796. unit: e.unit,
  797. remarks: null,
  798. $cellEdit: true
  799. });
  800. });
  801. }
  802. this.dialogVisible = false;
  803. },
  804. closeGoods() {
  805. this.selectionList = [];
  806. this.treeDeptId = "";
  807. this.reData = null;
  808. },
  809. goodsSelectionChange(list) {
  810. this.goodsSelections = list;
  811. this.orderItemIds = [];
  812. list.map(e => {
  813. this.orderItemIds.push(e.id);
  814. });
  815. },
  816. selectionChange(list) {
  817. this.selectionList = list;
  818. },
  819. rowClick(row) {
  820. this.$refs.goodsCrud.toggleSelection([this.goodsList[row.$index]]);
  821. },
  822. nodeClick(data) {
  823. this.treeDeptId = data.id;
  824. this.page.currentPage = 1;
  825. this.onLoad(this.page);
  826. },
  827. //费用查询
  828. onLoad(page, params = {}) {
  829. this.loading = true;
  830. getGoods(page.currentPage, page.pageSize, this.treeDeptId).then(res => {
  831. const data = res.data.data;
  832. this.page.total = data.total;
  833. this.goodsList = data.records;
  834. this.loading = false;
  835. if (this.page.total) {
  836. this.goodsOption.height = window.innerHeight - 350;
  837. }
  838. });
  839. },
  840. //商品明细导入
  841. newDetails() {
  842. this.dialogVisible = !this.dialogVisible;
  843. },
  844. getDetail(id) {
  845. this.showBut = false;
  846. this.pageLoading = true;
  847. detail(id)
  848. .then(res => {
  849. if (this.detailData.status == "copy") {
  850. delete res.data.data.id;
  851. delete res.data.data.sysNo;
  852. delete res.data.data.orderNo;
  853. delete res.data.data.orgOrderNo;
  854. delete res.data.data.createTime;
  855. delete res.data.data.createUser;
  856. delete res.data.data.createUserName;
  857. delete res.data.data.updateTime;
  858. delete res.data.data.updateUser;
  859. delete res.data.data.updateUserName;
  860. delete res.data.data.morderNo;
  861. delete res.data.data.status;
  862. delete res.data.data.ifEnquiry;
  863. delete res.data.data.ifShipping;
  864. res.data.data.orderStatus = "录入";
  865. if (res.data.data.itemsVOList) {
  866. res.data.data.itemsVOList.forEach(e => {
  867. delete e.id;
  868. delete e.pid;
  869. delete e.createTime;
  870. delete e.createUser;
  871. delete e.updateTime;
  872. delete e.updateUser;
  873. delete e.orgOrderNo;
  874. delete e.srcId;
  875. delete e.status;
  876. delete e.isDeleted;
  877. });
  878. }
  879. if (res.data.data.orderFeesList) {
  880. res.data.data.orderFeesList.forEach(e => {
  881. delete e.id;
  882. delete e.pid;
  883. delete e.createTime;
  884. delete e.createUser;
  885. delete e.updateTime;
  886. delete e.updateUser;
  887. delete e.status;
  888. delete e.isDeleted;
  889. });
  890. }
  891. if (res.data.data.orderFilesList) {
  892. res.data.data.orderFilesList.forEach(e => {
  893. delete e.id;
  894. delete e.pid;
  895. delete e.createTime;
  896. delete e.createUser;
  897. delete e.updateTime;
  898. delete e.updateUser;
  899. delete e.status;
  900. delete e.isDeleted;
  901. });
  902. }
  903. }
  904. this.form = res.data.data;
  905. this.data = res.data.data.itemsVOList
  906. ? res.data.data.itemsVOList
  907. : [];
  908. this.orderFeesList = res.data.data.orderFeesList
  909. ? res.data.data.orderFeesList
  910. : [];
  911. this.orderFilesList = res.data.data.orderFilesList
  912. ? res.data.data.orderFilesList
  913. : [];
  914. this.oldform = res.data.data;
  915. this.olddata = this.deepClone(
  916. res.data.data.itemsVOList ? res.data.data.itemsVOList : []
  917. );
  918. this.oldorderFeesList = this.deepClone(
  919. res.data.data.orderFeesList ? res.data.data.orderFeesList : []
  920. );
  921. this.oldorderFilesList = this.deepClone(
  922. res.data.data.orderFilesList ? res.data.data.orderFilesList : []
  923. );
  924. })
  925. .finally(() => {
  926. this.showBut = true;
  927. this.pageLoading = false;
  928. });
  929. },
  930. //修改提交触发
  931. editCustomer(status) {
  932. this.$refs["form"].validate((valid, done) => {
  933. done();
  934. if (valid) {
  935. const orderFeesList = this.$refs.feeInfo.submitData();
  936. for (let i = 0; i < orderFeesList.length; i++) {
  937. if (orderFeesList[i].corpId == null) {
  938. return this.$message.error(`请输入第${i + 1}行的结算中心`);
  939. }
  940. if (orderFeesList[i].price == 0) {
  941. return this.$message.error(`请正确输入第${i + 1}行的价格`);
  942. }
  943. if (orderFeesList[i].quantity == 0) {
  944. return this.$message.error(`请正确输入第${i + 1}行的数量`);
  945. }
  946. }
  947. const orderFilesList = this.$refs.uploadFile.submitData();
  948. this.subLoading = true;
  949. submit({
  950. ...this.form,
  951. itemsVOList: this.data,
  952. orderFeesList: orderFeesList,
  953. orderFilesList: orderFilesList,
  954. tradeType: "CK",
  955. billType: "CG"
  956. })
  957. .then(res => {
  958. this.$message.success("保存成功");
  959. this.getDetail(res.data.data);
  960. if (status == "goBack") {
  961. if (this.form.id) {
  962. this.unLock({
  963. moduleName: "xs",
  964. tableName: "business_order",
  965. billId: this.form.id,
  966. billNo: this.form.orgOrderNo
  967. });
  968. }
  969. this.$emit("goBack");
  970. this.leaveDetailsKey(this.$route.name);
  971. }
  972. })
  973. .finally(() => {
  974. this.subLoading = false;
  975. });
  976. } else {
  977. return false;
  978. }
  979. });
  980. },
  981. generateBill() {
  982. this.financialAccountDialog = true;
  983. this.billData = {
  984. srcOrderno: this.form.orgOrderNo,
  985. itemType: "销售",
  986. corpsName: this.form.corpName,
  987. corpId: this.form.corpId,
  988. srcParentId: this.form.id,
  989. currency: "CNY",
  990. exchangeRate: "1",
  991. taxRate: "0",
  992. accDate: this.form.businesDate,
  993. srcType: 1,
  994. tradeType: "CK",
  995. optionType: "CK"
  996. };
  997. },
  998. choceFun() {
  999. this.financialAccountDialog = false;
  1000. },
  1001. viewBill() {
  1002. this.applicationDialog = true;
  1003. },
  1004. //关闭记录
  1005. choceApplication() {
  1006. this.applicationDialog = false;
  1007. },
  1008. // 请核
  1009. pleaseCheck() {
  1010. this.$confirm("您确定提交此次申请吗?", {
  1011. confirmButtonText: "确定",
  1012. cancelButtonText: "取消",
  1013. type: "warning"
  1014. }).then(() => {
  1015. const data = {
  1016. id: this.form.id,
  1017. checkType: "cgqh",
  1018. url: "/exportTrade/purchaseContract/index",
  1019. pageStatus: "this.$store.getters.domPurStatus",
  1020. pageLabel: "采购(E)",
  1021. checkFlag: 2
  1022. };
  1023. pleaseCheck(data).then(res => {
  1024. this.$message.success("请核成功");
  1025. this.getDetail(this.form.id);
  1026. });
  1027. });
  1028. },
  1029. //返回列表
  1030. backToList() {
  1031. let orderFeesList = this.$refs.feeInfo.submitData();
  1032. let orderFilesList = this.$refs.uploadFile.submitData();
  1033. if (
  1034. contrastObj(this.form, this.oldform) ||
  1035. contrastList(this.data, this.olddata) ||
  1036. contrastList(orderFeesList, this.oldorderFeesList) ||
  1037. contrastList(orderFilesList, this.oldorderFilesList)
  1038. ) {
  1039. this.$confirm("数据发生变化未有提交记录, 是否提交?", "提示", {
  1040. confirmButtonText: "确定",
  1041. cancelButtonText: "取消",
  1042. type: "warning"
  1043. })
  1044. .then(() => {
  1045. this.editCustomer("goBack");
  1046. })
  1047. .catch(() => {
  1048. if (this.form.id) {
  1049. this.unLock({
  1050. moduleName: "cg",
  1051. tableName: "business_order",
  1052. billId: this.form.id,
  1053. billNo: this.form.orgOrderNo
  1054. });
  1055. }
  1056. this.$emit("goBack");
  1057. this.leaveDetailsKey(this.$route.name);
  1058. });
  1059. } else {
  1060. if (this.form.id) {
  1061. this.unLock({
  1062. moduleName: "cg",
  1063. tableName: "business_order",
  1064. billId: this.form.id,
  1065. billNo: this.form.orgOrderNo
  1066. });
  1067. }
  1068. this.$emit("goBack");
  1069. this.leaveDetailsKey(this.$route.name);
  1070. }
  1071. },
  1072. openReport() {
  1073. this.switchDialog = !this.switchDialog;
  1074. },
  1075. onClose(val) {
  1076. this.switchDialog = val;
  1077. },
  1078. summaryMethod({ columns, data }) {
  1079. const sums = [];
  1080. if (columns.length > 0) {
  1081. columns.forEach((item, index) => {
  1082. sums[0] = "合计";
  1083. if (item.property == "orderQuantity" || item.property == "amount") {
  1084. let qtySum = 0;
  1085. let amountSum = 0;
  1086. data.forEach(e => {
  1087. qtySum = _.add(qtySum, Number(e.orderQuantity));
  1088. amountSum = _.add(amountSum, Number(e.amount));
  1089. });
  1090. //数量总计
  1091. if (item.property == "orderQuantity") {
  1092. sums[index] = qtySum ? qtySum.toFixed(2) : "0.00";
  1093. }
  1094. //金额总计
  1095. if (item.property == "amount") {
  1096. sums[index] = micrometerFormat(amountSum);
  1097. }
  1098. }
  1099. });
  1100. }
  1101. return sums;
  1102. },
  1103. getInvoice() {
  1104. if (!this.form.id) {
  1105. return this.$message.error("数据未提交,请提交数据");
  1106. }
  1107. for (let i = 0; i < this.goodsSelections.length; i++) {
  1108. if (!this.goodsSelections[i].id) {
  1109. return this.$message.error("明细表未提交数据,请提交数据");
  1110. }
  1111. }
  1112. if (this.$store.getters.outtaskStatus) {
  1113. this.$alert("出口发货单存在,请保存发货单再进行操作", "温馨提示", {
  1114. confirmButtonText: "确定",
  1115. type: "warning",
  1116. callback: action => {
  1117. console.log(action);
  1118. }
  1119. });
  1120. } else {
  1121. this.inInvoice();
  1122. }
  1123. },
  1124. inInvoice() {
  1125. const data = this.deepClone(this.form);
  1126. data.orderItemsList = this.deepClone(this.goodsSelections);
  1127. data.orderItemsList.forEach(e => {
  1128. e.actualQuantity = e.orderQuantity;
  1129. e.contractAmount = e.amount;
  1130. e.srcId = e.id;
  1131. e.packageRemarks = e.itemProp;
  1132. e.productDesc = e.itemDescription;
  1133. e.specificationAndModel = e.itemType;
  1134. delete e.id;
  1135. delete e.version;
  1136. delete e.status;
  1137. delete e.createUser;
  1138. delete e.createTime;
  1139. delete e.updateUser;
  1140. delete e.updateTime;
  1141. delete e.isDeleted;
  1142. });
  1143. delete data.id;
  1144. delete data.version;
  1145. delete data.status;
  1146. delete data.createUser;
  1147. delete data.createTime;
  1148. delete data.updateUser;
  1149. delete data.updateTime;
  1150. delete data.isDeleted;
  1151. delete data.orderStatus;
  1152. data.deliveryStatus = "录入";
  1153. data.srcOrderNo = data.sysNo;
  1154. delete data.sysNo;
  1155. data.corpName = data.corpsName;
  1156. delete data.corpsName;
  1157. this.$refs.crud.toggleSelection();
  1158. this.$router.$avueRouter.closeTag("/exportTrade/receipt/index");
  1159. this.$router.push({
  1160. path: "/exportTrade/receipt/index",
  1161. query: {
  1162. pageType: "Generate",
  1163. data: JSON.stringify(data)
  1164. }
  1165. });
  1166. },
  1167. //费用明细回调
  1168. beforeFinance(feesData, callback) {
  1169. this.advantageProjectData = feesData;
  1170. let params = {};
  1171. //暂时默认通过 之后优化
  1172. params.valid = true;
  1173. params.parentId = this.form.id;
  1174. params.srcOrderno = this.form.orderNo;
  1175. callback(params);
  1176. },
  1177. openEdit() {
  1178. const data = {
  1179. moduleName: "cg",
  1180. tableName: "business_order",
  1181. billId: this.form.id,
  1182. no: localStorage.getItem("browserID"),
  1183. billNo: this.form.orgOrderNo
  1184. };
  1185. this.inDetailsKey(this.$route.name, {
  1186. moduleName: "cg",
  1187. tableName: "business_order",
  1188. billId: this.form.id,
  1189. billNo: this.form.orgOrderNo
  1190. });
  1191. this.saveLoading = true;
  1192. this.checkLock(data).then(res => {
  1193. if (res.data.code == 200) {
  1194. this.onLock(data);
  1195. this.detailData.status = 2;
  1196. this.option = this.$options.data().option;
  1197. }
  1198. });
  1199. },
  1200. async saveColumn() {
  1201. const inSave = await this.saveColumnData(
  1202. this.getColumnName(3),
  1203. this.tableOption
  1204. );
  1205. if (inSave) {
  1206. this.$message.success("保存成功");
  1207. //关闭窗口
  1208. this.$refs.crud.$refs.dialogColumn.columnBox = false;
  1209. }
  1210. },
  1211. async resetColumn() {
  1212. this.tableOption = tableOption;
  1213. const inSave = await this.delColumnData(
  1214. this.getColumnName(3),
  1215. tableOption
  1216. );
  1217. if (inSave) {
  1218. this.$message.success("重置成功");
  1219. //关闭窗口
  1220. setTimeout(() => {
  1221. this.$refs.crud.$refs.dialogColumn.columnBox = false;
  1222. }, 1000);
  1223. }
  1224. },
  1225. async saveGoodsColumn() {
  1226. const inSave = await this.saveColumnData(
  1227. this.getColumnName(27),
  1228. this.goodsOption
  1229. );
  1230. if (inSave) {
  1231. this.$message.success("保存成功");
  1232. //关闭窗口
  1233. this.$refs.goodsCrud.$refs.dialogColumn.columnBox = false;
  1234. }
  1235. },
  1236. async resetGoodsColumn() {
  1237. this.goodsOption = goodsOption;
  1238. const inSave = await this.delColumnData(
  1239. this.getColumnName(30),
  1240. goodsOption
  1241. );
  1242. if (inSave) {
  1243. this.$message.success("重置成功");
  1244. //关闭窗口
  1245. setTimeout(() => {
  1246. this.$refs.goodsCrud.$refs.dialogColumn.columnBox = false;
  1247. }, 1000);
  1248. }
  1249. }
  1250. }
  1251. };
  1252. </script>
  1253. <style lang="scss" scoped>
  1254. .trading-form ::v-deep .el-form-item {
  1255. margin-bottom: 8px !important;
  1256. }
  1257. ::v-deep .el-form-item__error {
  1258. display: none !important;
  1259. }
  1260. ::v-deep .select-component {
  1261. display: flex !important;
  1262. }
  1263. </style>