index.vue 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754
  1. <template>
  2. <div>
  3. <basic-container v-if="isShow">
  4. <avue-crud :option="option"
  5. :table-loading="loading"
  6. :data="data"
  7. :page.sync="page"
  8. :permission="permissionList"
  9. :before-open="beforeOpen"
  10. v-model="form"
  11. ref="crud"
  12. id="out-table"
  13. :header-cell-class-name="headerClassName"
  14. @row-update="rowUpdate"
  15. @row-save="rowSave"
  16. @row-del="rowDel"
  17. @search-change="searchChange"
  18. @search-reset="searchReset"
  19. @selection-change="selectionChange"
  20. @current-change="currentChange"
  21. @size-change="sizeChange"
  22. @refresh-change="refreshChange"
  23. @resetColumn="resetColumnTwo('crud', 'option', 'optionBack', 320)"
  24. @saveColumn="saveColumnTwo('crud', 'option', 'optionBack', 320)"
  25. @on-load="onLoad">
  26. <template slot="menuLeft">
  27. <el-button type="success"
  28. size="small"
  29. icon="el-icon-plus"
  30. plain
  31. @click="newbillFun">新建申请
  32. </el-button>
  33. <el-button type="danger"
  34. size="small"
  35. icon="el-icon-delete"
  36. plain
  37. @click="handleDelete">删 除
  38. </el-button>
  39. </template>
  40. <template slot="menu" slot-scope="{row}">
  41. <el-button type="text"
  42. size="small"
  43. @click="editFun(row)">编辑
  44. </el-button>
  45. <el-button type="text"
  46. size="small"
  47. @click="rowDel(row)">删除
  48. </el-button>
  49. </template>
  50. <template slot-scope="scope" slot="stlMode">
  51. <span>{{scope.row.stlMode?'月结':'票结'}}</span>
  52. </template>
  53. </avue-crud>
  54. </basic-container>
  55. <fininvoicesDetails ref="fininvoicesDetails" :editSave="editSave" v-if="!isShow" @goBack="goBack"></fininvoicesDetails>
  56. </div>
  57. </template>
  58. <script>
  59. import {
  60. fininvoicesList,
  61. fininvoicesDetail,
  62. fininvoicesRemove, fininvoicesSubmit
  63. } from "@/api/iosBasicData/fininvoices";
  64. import fininvoicesDetails from "@/views/iosBasicData/fininvoicesApplyfor/fininvoicesDetails.vue";
  65. import {mapGetters} from "vuex";
  66. export default {
  67. components:{ fininvoicesDetails},
  68. data() {
  69. return {
  70. // 详情页面和列表切换
  71. isShow:true,
  72. editSave:false, // 编辑还是保存
  73. form: {},
  74. query: {},
  75. loading: true,
  76. page: {
  77. pageSize: 10,
  78. currentPage: 1,
  79. total: 0
  80. },
  81. selectionList: [],
  82. option:{},
  83. optionBack: {
  84. height:'auto',
  85. calcHeight: 30,
  86. tip: false,
  87. searchShow: true,
  88. searchMenuSpan: 6,
  89. border: true,
  90. index: true,
  91. viewBtn: true,
  92. selection: true,
  93. dialogClickModal: false,
  94. menuWidth:100,
  95. column: [
  96. {
  97. label: "单据编号",
  98. prop: "billNo",
  99. search:true,
  100. rules: [{
  101. required: true,
  102. message: "请输入单据编号",
  103. trigger: "blur"
  104. }],
  105. overHidden:true,
  106. },
  107. {
  108. label: "客户中文名称",
  109. prop: "corpCnName",
  110. width:"120",
  111. overHidden:true,
  112. },
  113. {
  114. label: "开票单位中文名称",
  115. prop: "invCorpCnName",
  116. width:"160",
  117. overHidden:true,
  118. },
  119. {
  120. label: "合计本位币(CNY)",
  121. prop: "amountLoc",
  122. width: "120",
  123. overHidden:true,
  124. },
  125. {
  126. label: "单据日期",
  127. prop: "billDate",
  128. rules: [{
  129. required: true,
  130. message: "请输入单据日期",
  131. trigger: "blur"
  132. }],
  133. overHidden:true,
  134. },
  135. {
  136. label: "发票号码",
  137. prop: "invoiceNo",
  138. rules: [{
  139. required: true,
  140. message: "请输入发票号码",
  141. trigger: "blur"
  142. }],
  143. overHidden:true,
  144. },
  145. {
  146. label: "开票日期",
  147. prop: "invoiceDate",
  148. rules: [{
  149. required: true,
  150. message: "请输入开票日期",
  151. trigger: "blur"
  152. }],
  153. overHidden:true,
  154. },
  155. {
  156. label: "原发票号码",
  157. prop: "origInvoiceNo",
  158. width:"120",
  159. overHidden:true,
  160. },
  161. {
  162. label: "税务发票号码",
  163. prop: "taxInvoiceNo",
  164. width:"150",
  165. overHidden:true,
  166. },
  167. {
  168. label: "全电发票",
  169. prop: "invType",
  170. overHidden:true,
  171. },
  172. {
  173. label: "普通发票/专用发票",
  174. prop: "taxType",
  175. width:"160",
  176. overHidden:true,
  177. },
  178. {
  179. label: "税率 %",
  180. prop: "taxRate",
  181. rules: [{
  182. required: true,
  183. message: "请输入税率 %",
  184. trigger: "blur"
  185. }],
  186. overHidden:true,
  187. },
  188. {
  189. label: "结算方式",
  190. prop: "stlMode",
  191. overHidden:true,
  192. },
  193. {
  194. label: "发票币种",
  195. prop: "invCurCode",
  196. rules: [{
  197. required: true,
  198. message: "请输入发票币种",
  199. trigger: "blur"
  200. }],
  201. overHidden:true,
  202. },
  203. {
  204. label: "客户英文名称",
  205. prop: "corpEnName",
  206. width:"120",
  207. overHidden:true,
  208. },
  209. {
  210. label: "开票单位英文名称",
  211. prop: "invCorpEnName",
  212. width:"150",
  213. overHidden:true,
  214. },
  215. {
  216. label: "开票单位税号",
  217. prop: "invCorpTaxNo",
  218. width:"140",
  219. overHidden:true,
  220. },
  221. {
  222. label: "开票单位CNY开户银行",
  223. prop: "invCorpAccountBankCny",
  224. width:"160",
  225. overHidden:true,
  226. },
  227. {
  228. label: "开票单位CNY银行账号",
  229. prop: "invCorpAccountNoCny",
  230. width:"160",
  231. overHidden:true,
  232. },
  233. {
  234. label: "开票单位USD开户银行",
  235. prop: "invCorpAccountBankUsd",
  236. width:"160",
  237. overHidden:true,
  238. },
  239. {
  240. label: "开票单位USD银行账号",
  241. prop: "invCorpAccountNoUsd",
  242. width:"160",
  243. overHidden:true,
  244. },
  245. {
  246. label: "船名/航次",
  247. prop: "vesselVoyno",
  248. width:"100",
  249. overHidden:true,
  250. },
  251. {
  252. label: "开船日",
  253. prop: "etd",
  254. overHidden:true,
  255. },
  256. {
  257. label: "装货港",
  258. prop: "pol",
  259. overHidden:true,
  260. },
  261. {
  262. label: "卸货港",
  263. prop: "pod",
  264. overHidden:true,
  265. },
  266. {
  267. label: "目的地",
  268. prop: "destination",
  269. overHidden:true,
  270. },
  271. {
  272. label: "箱型/箱量",
  273. prop: "containers",
  274. width:"100",
  275. overHidden:true,
  276. },
  277. {
  278. label: "币种",
  279. prop: "curCode",
  280. overHidden:true,
  281. },
  282. {
  283. label: "原汇率",
  284. prop: "exrate",
  285. overHidden:true,
  286. },
  287. {
  288. label: "是否转换为人民币",
  289. prop: "isExchangeToCny",
  290. width:"140",
  291. dicData:[{
  292. label:'否',
  293. value:0
  294. },{
  295. label:'是',
  296. value:1
  297. }],
  298. overHidden:true,
  299. },
  300. {
  301. label: "业务类型",
  302. prop: "businessTypes",
  303. overHidden:true,
  304. },
  305. {
  306. label: "业务单据编号",
  307. prop: "businessNo",
  308. width:"120",
  309. overHidden:true,
  310. },
  311. {
  312. label: "对账单编号",
  313. prop: "checkNo",
  314. width:"120",
  315. overHidden:true,
  316. },
  317. {
  318. label: "MBL NO",
  319. prop: "mblno",
  320. overHidden:true,
  321. },
  322. {
  323. label: "HBL NO",
  324. prop: "hblno",
  325. overHidden:true,
  326. },
  327. {
  328. label: "订舱",
  329. prop: "bookingNo",
  330. overHidden:true,
  331. },
  332. {
  333. label: "中文船名",
  334. prop: "vesselCnName",
  335. overHidden:true,
  336. },
  337. {
  338. label: "英文船名",
  339. prop: "vesselEnName",
  340. overHidden:true,
  341. },
  342. {
  343. label: "航次",
  344. prop: "voyageNo",
  345. overHidden:true,
  346. },
  347. {
  348. label: "财务开始日期",
  349. prop: "accountDateFrom",
  350. width:"100",
  351. overHidden:true,
  352. },
  353. {
  354. label: "财务结束日期",
  355. prop: "accountDateTo",
  356. width:"100",
  357. overHidden:true,
  358. },
  359. {
  360. label: "申请人",
  361. prop: "applicantName",
  362. overHidden:true,
  363. },
  364. {
  365. label: "审核人",
  366. prop: "approverName",
  367. overHidden:true,
  368. },
  369. {
  370. label: "是否代理发票",
  371. prop: "isAgent",
  372. width:"120",
  373. dicData:[{
  374. label:'否',
  375. value:0
  376. },{
  377. label:'是',
  378. value:1
  379. }],
  380. overHidden:true,
  381. },
  382. {
  383. label: "是否DK",
  384. prop: "isDk",
  385. dicData:[{
  386. label:'否',
  387. value:0
  388. },{
  389. label:'是',
  390. value:1
  391. }],
  392. overHidden:true,
  393. },
  394. {
  395. label: "是否RP",
  396. prop: "isRp",
  397. dicData:[{
  398. label:'否',
  399. value:0
  400. },{
  401. label:'是',
  402. value:1
  403. }],
  404. overHidden:true,
  405. },
  406. {
  407. label: "RP名称",
  408. prop: "rpName",
  409. overHidden:true,
  410. },
  411. {
  412. label: "导出日期",
  413. prop: "exportDate",
  414. width: "100",
  415. overHidden:true,
  416. },
  417. {
  418. label: "导出人",
  419. prop: "exportName",
  420. overHidden:true,
  421. },
  422. {
  423. label: "是否导出船名航次",
  424. prop: "isExportVslvoy",
  425. width: "140",
  426. dicData:[{
  427. label:'否',
  428. value:0
  429. },{
  430. label:'是',
  431. value:1
  432. }],
  433. overHidden:true,
  434. },
  435. {
  436. label: "是否导出主单号",
  437. prop: "isExportMblno",
  438. width: "140",
  439. dicData:[{
  440. label:'否',
  441. value:0
  442. },{
  443. label:'是',
  444. value:1
  445. }],
  446. overHidden:true,
  447. },
  448. {
  449. label: "是否导出分单号",
  450. prop: "isExportHblno",
  451. width: "140",
  452. dicData:[{
  453. label:'否',
  454. value:0
  455. },{
  456. label:'是',
  457. value:1
  458. }],
  459. overHidden:true,
  460. },
  461. {
  462. label: "发票本位币(CNY)",
  463. prop: "amountCny",
  464. width: "140",
  465. overHidden:true,
  466. },
  467. {
  468. label: "发票USD",
  469. prop: "amountUsd",
  470. width: "100",
  471. overHidden:true,
  472. },
  473. {
  474. label: "税额(CNY)",
  475. prop: "amountTax",
  476. width: "100",
  477. overHidden:true,
  478. },
  479. {
  480. label: "全电发票备注",
  481. prop: "elecRemarks",
  482. width: "120",
  483. overHidden:true,
  484. },
  485. {
  486. label: "银行进账单出票人名称",
  487. prop: "bankReceiptCorpName",
  488. width: "160",
  489. overHidden:true,
  490. },
  491. {
  492. label: "银行进账单出票银行",
  493. prop: "bankReceiptBankName",
  494. width: "160",
  495. overHidden:true,
  496. },
  497. {
  498. label: "银行进账单出票银行账号",
  499. prop: "bankReceiptAccountNo",
  500. width: "160",
  501. overHidden:true,
  502. },
  503. {
  504. label: "银行进账单票据种类",
  505. prop: "bankReceiptBillType",
  506. width: "160",
  507. overHidden:true,
  508. },
  509. {
  510. label: "银行进账单票据张数",
  511. prop: "bankReceiptBillCount",
  512. width: "160",
  513. overHidden:true,
  514. },
  515. {
  516. label: "银行进账单是否已进账(收款)",
  517. prop: "bankReceiptIsIncome",
  518. width: "180",
  519. overHidden:true,
  520. },
  521. {
  522. label: "备注",
  523. prop: "remarks",
  524. rules: [{
  525. required: true,
  526. message: "请输入备注",
  527. trigger: "blur"
  528. }],
  529. overHidden:true,
  530. },
  531. ]
  532. },
  533. data: []
  534. };
  535. },
  536. watch:{
  537. },
  538. computed: {
  539. ...mapGetters(["permission"]),
  540. permissionList() {
  541. return {
  542. addBtn: this.vaildData(this.permission.fininvoices_add, false),
  543. viewBtn: this.vaildData(this.permission.fininvoices_view, false),
  544. delBtn: this.vaildData(this.permission.fininvoices_delete, false),
  545. editBtn: this.vaildData(this.permission.fininvoices_edit, false)
  546. };
  547. },
  548. ids() {
  549. let ids = [];
  550. this.selectionList.forEach(ele => {
  551. ids.push(ele.id);
  552. });
  553. return ids.join(",");
  554. }
  555. },
  556. async created() {
  557. this.option = await this.getColumnData(this.getColumnName(320), this.optionBack);
  558. },
  559. methods: {
  560. // 新建发票
  561. newbillFun(){
  562. this.isShow = false;
  563. this.editSave = false
  564. },
  565. // 编辑
  566. editFun(row) {
  567. this.isShow = false
  568. this.editSave = true
  569. this.$nextTick(()=>{
  570. this.$refs.fininvoicesDetails.fininvoicesDetailfun(row.id)
  571. })
  572. },
  573. // 详情的返回列表
  574. goBack() {
  575. // 初始化数据
  576. // this.detailData = this.$options.data().detailData;
  577. if (JSON.stringify(this.$route.query) != "{}") {
  578. this.$router.$avueRouter.closeTag();
  579. this.$router.push({
  580. path: "/iosBasicData/fininvoices/index"
  581. });
  582. }
  583. this.isShow = true;
  584. this.onLoad(this.page, this.search);
  585. },
  586. rowSave(row, done, loading) {
  587. fininvoicesSubmit(row).then(() => {
  588. this.onLoad(this.page);
  589. this.$message({
  590. type: "success",
  591. message: "操作成功!"
  592. });
  593. done();
  594. }, error => {
  595. loading();
  596. window.console.log(error);
  597. });
  598. },
  599. rowUpdate(row, index, done, loading) {
  600. fininvoicesSubmit(row).then(() => {
  601. this.onLoad(this.page);
  602. this.$message({
  603. type: "success",
  604. message: "操作成功!"
  605. });
  606. done();
  607. }, error => {
  608. loading();
  609. console.log(error);
  610. });
  611. },
  612. rowDel(row) {
  613. this.$confirm("确定将选择数据删除?", {
  614. confirmButtonText: "确定",
  615. cancelButtonText: "取消",
  616. type: "warning"
  617. })
  618. .then(() => {
  619. return fininvoicesRemove(row.id);
  620. })
  621. .then(() => {
  622. this.onLoad(this.page);
  623. this.$message({
  624. type: "success",
  625. message: "操作成功!"
  626. });
  627. });
  628. },
  629. handleDelete() {
  630. if (this.selectionList.length === 0) {
  631. this.$message.warning("请选择至少一条数据");
  632. return;
  633. }
  634. this.$confirm("确定将选择数据删除?", {
  635. confirmButtonText: "确定",
  636. cancelButtonText: "取消",
  637. type: "warning"
  638. })
  639. .then(() => {
  640. return fininvoicesRemove(this.ids);
  641. })
  642. .then(() => {
  643. this.onLoad(this.page);
  644. this.$message({
  645. type: "success",
  646. message: "操作成功!"
  647. });
  648. this.$refs.crud.toggleSelection();
  649. });
  650. },
  651. beforeOpen(done, type) {
  652. if (["edit", "view"].includes(type)) {
  653. fininvoicesDetail(this.form.id).then(res => {
  654. this.form = res.data.data;
  655. });
  656. }
  657. done();
  658. },
  659. searchReset() {
  660. this.query = {};
  661. this.onLoad(this.page);
  662. },
  663. searchChange(params, done) {
  664. this.query = params;
  665. this.page.currentPage = 1;
  666. this.onLoad(this.page, params);
  667. done();
  668. },
  669. selectionChange(list) {
  670. this.selectionList = list;
  671. },
  672. selectionClear() {
  673. this.selectionList = [];
  674. this.$refs.crud.toggleSelection();
  675. },
  676. currentChange(currentPage){
  677. this.page.currentPage = currentPage;
  678. },
  679. sizeChange(pageSize){
  680. this.page.pageSize = pageSize;
  681. },
  682. refreshChange() {
  683. this.onLoad(this.page, this.query);
  684. },
  685. onLoad(page, params = {}) {
  686. this.loading = true;
  687. fininvoicesList(page.currentPage, page.pageSize,
  688. {...Object.assign(params, this.query),type:"申请",billNoFormat:'FPSQ',businessTypeCode:'FPSQ'}).then(res => {
  689. const data = res.data.data;
  690. this.page.total = data.total;
  691. this.data = data.records;
  692. this.loading = false;
  693. this.selectionClear();
  694. });
  695. },
  696. //自定义列保存
  697. async saveColumnTwo(ref, option, optionBack, code) {
  698. /**
  699. * 已定义全局方法,直接使用,saveColumnData保存列数据方法,参数传值(表格名称,当前表格的option数据)
  700. * 已定义全局方法,直接使用,getColumnName方法用来获取枚举值,参数根据自己定义的code值获取中文名
  701. * 一定要执行异步操作,要等接口成功返回,才能执行下一行代码
  702. */
  703. const inSave = await this.saveColumnData(this.getColumnName(code), this[option]);
  704. if (inSave) {
  705. this.$message.success("保存成功");
  706. //关闭窗口
  707. this.$refs[ref].$refs.dialogColumn.columnBox = false;
  708. }
  709. },
  710. //自定义列重置
  711. async resetColumnTwo(ref, option, optionBack, code) {
  712. this[option] = this[optionBack];
  713. const inSave = await this.delColumnData(this.getColumnName(code), this[optionBack]);
  714. if (inSave) {
  715. this.$message.success("重置成功");
  716. this.$refs[ref].$refs.dialogColumn.columnBox = false;
  717. }
  718. },
  719. // 更改表格颜色
  720. headerClassName(tab) {
  721. //颜色间隔
  722. let back = ""
  723. if (tab.columnIndex >= 0 && tab.column.level === 1) {
  724. if (tab.columnIndex % 2 === 0) {
  725. back = "back-one"
  726. } else if (tab.columnIndex % 2 === 1) {
  727. back = "back-two"
  728. }
  729. }
  730. return back;
  731. },
  732. }
  733. };
  734. </script>
  735. <style scoped>
  736. ::v-deep#out-table .back-one {
  737. background: #ecf5ff !important;
  738. text-align: center;
  739. }
  740. ::v-deep#out-table .back-two {
  741. background: #ecf5ff !important;
  742. text-align: center;
  743. }
  744. </style>