<template> <c-page title="汇出汇款"> <div class="eContainer"> <!-- <c-bus-button :$pntvm="this"></c-bus-button> --> <c-function-btn :handleSubmit="handleSubmit" :handleCheck="handleCheck" :handleStash="handleStash"> <el-button size="small">备忘录</el-button> <el-button size="small">影像信息</el-button> <!-- <el-button size="small">保存模板</el-button> --> <!-- <el-button size="small">使用模板</el-button> --> <el-button size="small">制裁信息</el-button> <!-- <el-button size="small">拆分报文</el-button> --> <el-button size="small">智能提示</el-button> </c-function-btn> <el-form :model="model" :rules="rules" ref="modelForm" label-width="120px" size="small" :validate-on-rule-change="false"> <c-tabs :value="tabVal" ref="elment" type="card" @tab-click="mimeTabClick"> <el-tab-pane label="概要" name="opnp1"> <!--PD000020 --> <c-content> <m-opnp1 :model="model" :codes="codes" /> </c-content> </el-tab-pane> <el-tab-pane label="Additional Info" name="AdditionalInfo" v-if="this.model.cpdgrp.rec.swftyp != ''"> <m-AdditionalInfo :model="model" :codes="codes" /> </el-tab-pane> <el-tab-pane label="结算" name="setpan"> <!--PD000000 --> <m-setpan :model="model" :codes="codes" /> </el-tab-pane> <el-tab-pane label="分录" name="glepan"> <!--PD000001 --> <m-glepan :model="model" :codes="codes" ref="glepan" /> </el-tab-pane> <el-tab-pane label="提示信息" name="coninfp"> <!--PD000000 --> <m-coninfp :model="model" :codes="codes" /> </el-tab-pane> <el-tab-pane label="报文和面函" name="docpan"> <!--PD000529 --> <m-docpan :model="model" :codes="codes" /> </el-tab-pane> <el-tab-pane label="附件" name="doctre"> <!--PD000546 --> <m-doctre :model="model" :codes="codes" /> </el-tab-pane> <el-tab-pane label="融资" name="finp"> <!--PD000218 --> <m-finp :model="model" :codes="codes" /> </el-tab-pane> <el-tab-pane label="申报信息" name="sbxx"> <!--PD000009 --> <m-sbxx :model="model" :codes="codes" /> </el-tab-pane> <el-tab-pane label="境内汇款申请书-基础信息" name="dbe" v-if="model.bopmod.szflg === '2' && model.bopmod.basflg"> <m-dbe :model="model" :codes="codes"></m-dbe> </el-tab-pane> <el-tab-pane label="境外汇款申请书-基础信息" name="dbb" v-if="model.bopmod.szflg === '1' && model.bopmod.basflg"> <m-dbb :model="model" :codes="codes"></m-dbb> </el-tab-pane> <el-tab-pane label="2111跨境支出信息" name="outp" v-if="model.cnybop.outflg === '1'"> <m-outp :model="model" :codes="codes"></m-outp> </el-tab-pane> <el-tab-pane label="Payment 103 PYE USD" name="Payment103" v-if=" model.cpdgrp.rec.swftyp === '103' || model.cpdgrp.rec.swftyp === '202' "> <m-Payment :model="model" :codes="codes" /> </el-tab-pane> <!-- <el-tab-pane label="Payment 103 PYE USD" name="Payment103"> <m-Payment103 :model="model" :codes="codes" /> </el-tab-pane> --> <!-- <el-tab-pane label="Payment 202 PYE USD" name="Payment202"> <m-Payment202 :model="model" :codes="codes" /> </el-tab-pane> --> </c-tabs> </el-form> </div> <c-grid-ety-prompt-dialog ref="doxpDialog" :isPty="false" :promptData="promptData" @select-ety="selectMsg"> </c-grid-ety-prompt-dialog> <c-grid-ety-prompt-dialog ref="etyDialog" :promptData="promptData" v-on:select-ety="selectEty"> </c-grid-ety-prompt-dialog> </c-page> </template> <script> import Api from "~/service/Api"; import Utils from "~/utils/index"; import CodeTable from "~/config/CodeTable"; import Cptopn from "~/model/Cptopn"; import commonProcess from "~/mixin/commonProcess"; import commonFuncs from "~/mixin/commonFuncs"; import Pattern from "~/model/Cptopn/Pattern"; import Default from "~/model/Cptopn/Default"; import Check from "~/model/Cptopn/Check"; import Opnp1 from "./Opnp1"; import Finp from "./Finp"; import Dbe from "./Dbe.vue"; import Dbb from "./Dbb.vue"; import Outp from "./Outp.vue"; import AdditionalInfo from "./AdditionalInfo.vue"; import Payment from "./Payment103.vue"; import Basp from "./Basp" import Coninfp from "~/views/Public/Coninfp"; import Doctre from "~/views/Public/Doctre"; import Glepan from "~/views/Public/Glepan"; import Setpan from "~/views/Public/Setpan"; import Docpan from "~/views/Public/Docpan"; import Sbxx from "~/views/Public/Sbxx"; export default { name: "Cptopn", components: { "m-opnp1": Opnp1, "m-setpan": Setpan, "m-glepan": Glepan, "m-coninfp": Coninfp, "m-docpan": Docpan, "m-doctre": Doctre, "m-finp": Finp, "m-sbxx": Sbxx, "m-dbe": Dbe, "m-dbb": Dbb, "m-outp": Outp, "m-AdditionalInfo": AdditionalInfo, "m-Payment": Payment, "m-basp": Basp, // "m-Payment103": Payment103, // "m-Payment202": Payment202 }, provide() { return { root: this, }; }, mixins: [commonProcess, commonFuncs], // 里面包含了Default、Check等的公共处理 data() { return { tabVal: "opnp1", trnName: "cptopn", model: new Cptopn().data, checkRules: Check, defaultRules: Default, pattern: Pattern, rules: null, codes: { ...CodeTable }, }; }, methods: { mimeTabClick(tab) { this.tabClick(tab); const name = tab.name; let rulePath; if (name === "setpan") { rulePath = "pyenam"; } if (name === "glepan") { rulePath = "glepan"; } if (name === "coninfp") { rulePath = "coninfp"; } if (name === "docpan") { rulePath = "oit.inftxt"; } if (name === "doctre") { rulePath = "doctre"; } if (name === "sbxx") { rulePath = "trd.ownref,cnyp"; } if (!!rulePath) { this.executeRule(rulePath).then((res) => { if (res.respCode == SUCCESS) { this.updateModel(res.data); } }); } }, }, created: async function () { console.log("进入cptopn交易"); let rtnmsg = await this.init(this.$route.query); if (rtnmsg.respCode == SUCCESS) { Utils.copyValueFromVO(this.model, rtnmsg.data); if (this.isInDisplay) { this.restoreDisplay(); } } else { this.$notify.error({ title: "错误", message: "服务请求失败!" }); } }, watch: { "model.cpdgrp.cbs.nom1.amt": { handler(val, oldVal) { this.changeFormItemRequired("cpdgrp.rec.swftyp", val != "0.000"); }, immediate: true, }, }, }; </script> <style> .el-col .el-divider--horizontal { margin-top: 0; } .messageLabel .el-form-item__label { text-align: left; font-weight: bold; font-size: 12px; } </style>