billDetail.vue 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542
  1. <template>
  2. <div class="app-container">
  3. <el-card class="box-card" style="margin: 0.6%">
  4. <div class="text item">
  5. <el-form ref="bill" label-width="auto" :inline="true">
  6. <el-form-item label="创建人:" style="float: right">{{
  7. form.createUser
  8. }}</el-form-item>
  9. <el-form-item label="创建时间:" style="float: right">{{
  10. parseTime(new Date(form.createTime))
  11. }}</el-form-item>
  12. <el-form-item label="编号:" style="float: right">{{
  13. form.zbiNumber
  14. }}</el-form-item>
  15. </el-form>
  16. </div>
  17. </el-card>
  18. <el-card class="box-card" style="margin: 0.6%">
  19. <div slot="header" class="clearfix">
  20. <span style="color: #666ee8; font-weight: bold">基本信息</span>
  21. </div>
  22. <div class="text item" style="margin-bottom: 20px">
  23. <el-form
  24. ref="form"
  25. :model="form"
  26. label-width="auto"
  27. label-position="top"
  28. :inline="true"
  29. :disabled="true"
  30. >
  31. <el-form-item label="账款类型" prop="wplIsInput" style="width: 300px">
  32. <el-radio-group v-model="type" prop="type">
  33. <el-radio-button label="00" v-if="type == '00'"
  34. >应付账款</el-radio-button
  35. >
  36. <el-radio-button label="01" v-if="type == '01'"
  37. >应收账款</el-radio-button
  38. >
  39. </el-radio-group>
  40. </el-form-item>
  41. <el-form-item label="账款名称" prop="zbiName">
  42. <el-input
  43. v-model="form.zbiName"
  44. maxlength="20"
  45. style="width: 300px"
  46. />
  47. </el-form-item>
  48. <el-form-item label="应付方" prop="zbiPayerId">
  49. <el-input
  50. v-model="form.payerName"
  51. maxlength="20"
  52. style="width: 300px"
  53. />
  54. </el-form-item>
  55. <el-form-item label="应收方" prop="zbiPayeeId">
  56. <el-input
  57. v-model="form.payeeName"
  58. maxlength="20"
  59. style="width: 300px"
  60. />
  61. </el-form-item>
  62. <el-form-item label="贸易日期" prop="zbiDate">
  63. <el-date-picker
  64. style="width: 300px"
  65. v-model="form.zbiDate"
  66. value-format="yyyy-MM-dd"
  67. type="date"
  68. >
  69. </el-date-picker>
  70. </el-form-item>
  71. <el-form-item
  72. :label="
  73. type == '00'
  74. ? '预计付款日期'
  75. : type == '01'
  76. ? '预计收款日期'
  77. : '预计收/付款日期'
  78. "
  79. prop="zbiPayDate"
  80. >
  81. <el-date-picker
  82. style="width: 300px"
  83. v-model="form.zbiPayDate"
  84. value-format="yyyy-MM-dd"
  85. type="date"
  86. >
  87. </el-date-picker>
  88. </el-form-item>
  89. <el-form-item label="账款金额" prop="zbiAmount">
  90. <el-input
  91. v-model="form.zbiAmount"
  92. maxlength="20"
  93. style="width: 300px"
  94. >
  95. <template slot="append">元</template>
  96. </el-input>
  97. </el-form-item>
  98. <el-form-item label="账款金额大写">
  99. <el-input
  100. :disabled="true"
  101. :value="smallToBig(form.zbiAmount)"
  102. style="width: 300px"
  103. >
  104. </el-input>
  105. </el-form-item>
  106. <el-form-item label="贸易合同编号" prop="zbiContractNo">
  107. <el-input
  108. v-model="form.zbiContractNo"
  109. maxlength="20"
  110. style="width: 300px"
  111. />
  112. </el-form-item>
  113. <el-form-item label="贸易商品/服务">
  114. <el-input
  115. v-model="form.zbiService"
  116. maxlength="20"
  117. style="width: 300px"
  118. />
  119. </el-form-item>
  120. <el-form-item label="配送企业">
  121. <el-input
  122. v-model="form.zbiDistributor"
  123. maxlength="20"
  124. style="width: 300px"
  125. />
  126. </el-form-item>
  127. <el-form-item label="配送订单号">
  128. <el-input
  129. v-model="form.zbiOrderNo"
  130. maxlength="20"
  131. style="width: 300px"
  132. />
  133. </el-form-item>
  134. <el-form-item label="备注">
  135. <el-input
  136. v-model="form.zbiRemark"
  137. :autosize="{ minRows: 2, maxRows: 4 }"
  138. maxlength="100"
  139. type="textarea"
  140. style="width: 615px"
  141. />
  142. </el-form-item>
  143. </el-form>
  144. </div>
  145. </el-card>
  146. <el-card class="box-card" style="margin: 0.6%">
  147. <div slot="header" class="clearfix">
  148. <span style="color: #666ee8; font-weight: bold">发票列表</span>
  149. </div>
  150. <div class="text item" style="margin-bottom: 20px">
  151. <el-form ref="invoice" label-width="auto" :inline="true">
  152. <el-form-item label="合计:">{{
  153. handleInput(allAmount())
  154. }}</el-form-item>
  155. <el-form-item label="大写:">{{
  156. smallToBig(allAmount())
  157. }}</el-form-item>
  158. </el-form>
  159. <el-table
  160. :data="fileList"
  161. row-key="ziiId"
  162. default-expand-all
  163. :row-class-name="tableRowClassName"
  164. border
  165. >
  166. <el-table-column type="index" width="50" align="center" />
  167. <el-table-column
  168. label="发票代码"
  169. align="center"
  170. prop="ziiNo"
  171. maxlength="10"
  172. />
  173. <el-table-column
  174. label="发票号码"
  175. align="center"
  176. prop="ziiNumber"
  177. maxlength="10"
  178. />
  179. <el-table-column label="开票日期" align="center" prop="ziiDate" />
  180. <el-table-column
  181. label="购方识别号"
  182. align="center"
  183. prop="ziiPurchaserNo"
  184. />
  185. <el-table-column
  186. label="销方识别号"
  187. align="center"
  188. prop="ziiSellerNo"
  189. />
  190. <el-table-column
  191. label="合计金额"
  192. align="center"
  193. prop="ziiTotalAmount"
  194. />
  195. <el-table-column label="价税合计" align="center" prop="ziiAmount" />
  196. <el-table-column
  197. label="校验结果"
  198. align="center"
  199. prop="ziiCheckStt"
  200. :formatter="checkSttFormat"
  201. />
  202. <el-table-column
  203. label="附件"
  204. align="center"
  205. class-name="small-padding fixed-width"
  206. fixed="right"
  207. width="200"
  208. >
  209. <template slot-scope="scope">
  210. <el-button
  211. size="mini"
  212. type="text"
  213. @click="invoicePictureCardPreview(scope.row)"
  214. >详情</el-button
  215. >
  216. </template>
  217. </el-table-column>
  218. </el-table>
  219. </div>
  220. </el-card>
  221. <el-card class="box-card" style="margin: 0.6%">
  222. <div slot="header" class="clearfix">
  223. <span style="color: #666ee8; font-weight: bold">合同附件</span>
  224. </div>
  225. <div class="text item" style="margin-bottom: 20px">
  226. <el-upload
  227. :disabled="true"
  228. :file-list="contractList"
  229. :auto-upload="false"
  230. action=""
  231. ref="contractUpload"
  232. list-type="picture-card"
  233. :on-preview="invoicePictureCardPreview"
  234. >
  235. </el-upload>
  236. </div>
  237. </el-card>
  238. <el-card class="box-card" style="margin: 0.6%">
  239. <div slot="header" class="clearfix">
  240. <span style="color: #666ee8; font-weight: bold">物流附件</span>
  241. </div>
  242. <div class="text item" style="margin-bottom: 20px">
  243. <el-upload
  244. :disabled="true"
  245. :file-list="logisticsList"
  246. :auto-upload="false"
  247. action=""
  248. ref="logisticsUpload"
  249. list-type="picture-card"
  250. :on-preview="invoicePictureCardPreview"
  251. >
  252. </el-upload>
  253. </div>
  254. </el-card>
  255. <el-card class="box-card" style="margin: 0.6%">
  256. <div slot="header" class="clearfix">
  257. <span style="color: #666ee8; font-weight: bold">其他附件</span>
  258. </div>
  259. <div class="text item" style="margin-bottom: 20px">
  260. <el-upload
  261. :disabled="true"
  262. :file-list="otherList"
  263. :auto-upload="false"
  264. action=""
  265. ref="otherUpload"
  266. list-type="picture-card"
  267. :on-preview="invoicePictureCardPreview"
  268. >
  269. </el-upload>
  270. </div>
  271. </el-card>
  272. <!-- 查看图片 -->
  273. <el-dialog :visible.sync="invoiceVisible">
  274. <img width="100%" :src="invoiceImageUrl" alt="" />
  275. </el-dialog>
  276. <div style="text-align: center">
  277. <el-button type="primary" @click="submit()">取消</el-button>
  278. </div>
  279. </div>
  280. </template>
  281. <script>
  282. import {
  283. getBill,
  284. getInvoice,
  285. getFile,
  286. commitBill,
  287. } from "@/api/service/bill/bill";
  288. import { getOwnCompany, companyRelList } from "@/api/common/company";
  289. import { amtformat } from "@/utils/amtCommon";
  290. import { getToken } from "@/utils/auth";
  291. export default {
  292. name: "billDetail",
  293. components: {},
  294. props: {
  295. // 正常的业务数据,对应echarts饼图配置中series[0].data
  296. zbiId: {
  297. type: String,
  298. required: true,
  299. default: () => "",
  300. },
  301. },
  302. data() {
  303. return {
  304. // 查询参数
  305. queryParams: {},
  306. // 表单参数
  307. form: {},
  308. //进度
  309. active: 0,
  310. //类型
  311. type: "00",
  312. //合同附件
  313. contractList: [],
  314. //物流附件
  315. logisticsList: [],
  316. //其他附件
  317. otherList: [],
  318. //发票列表
  319. fileList: [],
  320. //合计金额
  321. totalPrice: 0,
  322. //验证结果
  323. checkSttOptions: [],
  324. //图片路径
  325. invoiceImageUrl: null,
  326. //图片显示
  327. invoiceVisible: false,
  328. //等待框
  329. fullscreenLoading: false,
  330. //链属企业
  331. companyRelList: [],
  332. //链属企业
  333. company: {},
  334. };
  335. },
  336. created() {
  337. //进度
  338. this.active = 0;
  339. const zbiId = this.zbiId;
  340. // const zbiId = this.$route.params && this.$route.params.zbiId;
  341. this.fullscreenLoading = true;
  342. getOwnCompany().then((response) => {
  343. this.company = response.data;
  344. });
  345. this.getCompanyRel();
  346. this.getDetail(zbiId);
  347. getInvoice(zbiId).then((response) => {
  348. response.data.forEach((element) => {
  349. element.url = element.url + "/" + getToken();
  350. });
  351. this.fileList = response.data;
  352. this.invoice = this.fileList[0] ? this.fileList[0] : {};
  353. this.ids = [];
  354. });
  355. getFile("0", zbiId).then((response) => {
  356. response.data.forEach((element) => {
  357. element.url = element.url + "/" + getToken();
  358. });
  359. this.contractList = response.data;
  360. });
  361. //查询物流
  362. getFile("1", zbiId).then((response) => {
  363. response.data.forEach((element) => {
  364. element.url = element.url + "/" + getToken();
  365. });
  366. this.logisticsList = response.data;
  367. });
  368. //查询其他附件
  369. getFile("2", zbiId).then((response) => {
  370. response.data.forEach((element) => {
  371. element.url = element.url + "/" + getToken();
  372. });
  373. this.otherList = response.data;
  374. });
  375. this.getDicts("zc_invoice_checkStt").then((response) => {
  376. this.checkSttOptions = response.data;
  377. });
  378. },
  379. activated() {},
  380. methods: {
  381. //查询往来账款详情
  382. getDetail(zbiId) {
  383. const loading = this.$loading({
  384. lock: true,
  385. text: 'Loading',
  386. spinner: 'el-icon-loading',
  387. background: 'rgba(0, 0, 0, 0.7)'
  388. });
  389. getBill(zbiId).then((response) => {
  390. this.form = response.data;
  391. if (this.form.zbiPayerId == this.company.scyId) {
  392. this.type = "00";
  393. } else {
  394. this.type = "01";
  395. }
  396. loading.close();
  397. })
  398. .catch(() => {
  399. loading.close();
  400. });
  401. },
  402. //查询链属企业
  403. getCompanyRel(val) {
  404. this.queryParams.companyName = val;
  405. companyRelList(this.queryParams).then((response) => {
  406. this.companyRelList = response.data;
  407. });
  408. },
  409. //表格置灰
  410. tableRowClassName({ row, rowIndex }) {
  411. if (row.ziiCheckStt != "1") {
  412. return "warning-row";
  413. }
  414. return "";
  415. },
  416. //查看图片
  417. invoicePictureCardPreview(file) {
  418. this.invoiceImageUrl = file.url;
  419. this.invoiceVisible = true;
  420. },
  421. //发票合计
  422. allAmount() {
  423. var strarr = [0.0];
  424. for (let i in this.fileList) {
  425. if (this.fileList[i]["ziiCheckStt"] == "1") {
  426. strarr.push(this.fileList[i]["ziiAmount"]);
  427. }
  428. }
  429. return (Math.floor(eval(strarr.join("+")) * 100) / 100).toFixed(2); //结果
  430. // return this.handleInput(eval(strarr.join("+"))); //结果
  431. },
  432. // 结束
  433. submit() {
  434. this.$store.dispatch("tagsView/delView", this.$route);
  435. this.$router.go(-1);
  436. },
  437. //校验结果字典
  438. checkSttFormat(row, column) {
  439. return this.selectDictLabel(this.checkSttOptions, row.ziiCheckStt);
  440. },
  441. /* 金额展示 */
  442. handleInput(str) {
  443. return amtformat(str, 2, ".", ",");
  444. },
  445. /* // 将数字金额转换为大写金额 */
  446. smallToBig(money) {
  447. // 将数字金额转换为大写金额
  448. var cnNums = new Array(
  449. "零",
  450. "壹",
  451. "贰",
  452. "叁",
  453. "肆",
  454. "伍",
  455. "陆",
  456. "柒",
  457. "捌",
  458. "玖"
  459. ); //汉字的数字
  460. var cnIntRadice = new Array("", "拾", "佰", "仟"); //基本单位
  461. var cnIntUnits = new Array("", "万", "亿", "兆"); //对应整数部分扩展单位
  462. var cnDecUnits = new Array("角", "分", "毫", "厘"); //对应小数部分单位
  463. var cnInteger = "整"; //整数金额时后面跟的字符
  464. var cnIntLast = "元"; //整数完以后的单位
  465. //最大处理的数字
  466. var maxNum = 999999999999999.9999;
  467. var integerNum; //金额整数部分
  468. var decimalNum; //金额小数部分
  469. //输出的中文金额字符串
  470. var chineseStr = "";
  471. var parts; //分离金额后用的数组,预定义
  472. if (money == "" || money == null || money == undefined) {
  473. return "零元零角零分";
  474. }
  475. money = parseFloat(money);
  476. if (money >= maxNum) {
  477. //超出最大处理数字
  478. return "超出最大处理数字";
  479. }
  480. if (money == 0) {
  481. chineseStr = cnNums[0] + cnIntLast + cnInteger;
  482. return chineseStr;
  483. }
  484. //四舍五入保留两位小数,转换为字符串
  485. money = Math.round(money * 100).toString();
  486. integerNum = money.substr(0, money.length - 2);
  487. decimalNum = money.substr(money.length - 2);
  488. //获取整型部分转换
  489. if (parseInt(integerNum, 10) > 0) {
  490. var zeroCount = 0;
  491. var IntLen = integerNum.length;
  492. for (var i = 0; i < IntLen; i++) {
  493. var n = integerNum.substr(i, 1);
  494. var p = IntLen - i - 1;
  495. var q = p / 4;
  496. var m = p % 4;
  497. if (n == "0") {
  498. zeroCount++;
  499. } else {
  500. if (zeroCount > 0) {
  501. chineseStr += cnNums[0];
  502. }
  503. //归零
  504. zeroCount = 0;
  505. chineseStr += cnNums[parseInt(n)] + cnIntRadice[m];
  506. }
  507. if (m == 0 && zeroCount < 4) {
  508. chineseStr += cnIntUnits[q];
  509. }
  510. }
  511. chineseStr += cnIntLast;
  512. }
  513. //小数部分
  514. if (decimalNum != "") {
  515. var decLen = decimalNum.length;
  516. for (var i = 0; i < decLen; i++) {
  517. var n = decimalNum.substr(i, 1);
  518. if (n != "0") {
  519. chineseStr += cnNums[Number(n)] + cnDecUnits[i];
  520. }
  521. }
  522. }
  523. if (chineseStr == "") {
  524. chineseStr += cnNums[0] + cnIntLast + cnInteger;
  525. } else if (decimalNum == "" || /^0*$/.test(decimalNum)) {
  526. chineseStr += cnInteger;
  527. }
  528. return chineseStr;
  529. },
  530. },
  531. };
  532. </script>
  533. <style>
  534. .el-table .warning-row {
  535. background: rgb(223, 223, 223);
  536. }
  537. </style>