| | |
| | | NODE_ENV = 'development' |
| | | |
| | | # ä¼ä¸ç«¯-ä»åº· |
| | | #VUE_APP_API = 'http://192.168.0.134:10025/' |
| | | VUE_APP_API = 'http://192.168.0.134:10025/' |
| | | |
| | | # å¹³å°ç«¯-ä»åº· |
| | | # VUE_APP_API = 'http://192.168.0.134:10023/' |
| | | |
| | | # å¹³å°ç«¯-èå§ |
| | | VUE_APP_API = 'http://192.168.0.103:10023/' |
| | | # VUE_APP_API = 'http://192.168.0.103:10023/' |
| | | |
| | | # VUE_APP_API = 'http://localhost:10023/' |
| | | # VUE_APP_API = 'http://localhost:10023/' |
| | |
| | | trim: true |
| | | }) |
| | | } |
| | | |
| | | // è·åç´ä¿æ°æ®ä¿¡æ¯ |
| | | export function getDirectTaxes (id) { |
| | | return request.get(`/business/taxes/getDirectTaxes?id=${id}`) |
| | | } |
| | | |
| | | // æäº¤ç´æææ¥å¼ç¥¨ |
| | | export function directInvoicing(data) { |
| | | return request.post('/business/taxes/directInvoicing', data, { |
| | | trim: true |
| | | }) |
| | | } |
| | |
| | | // 头é¨é«åº¦ |
| | | $header-height: 60px; |
| | | // èå宽度 |
| | | $menu-width: 208px; |
| | | $menu-width: 250px; |
| | | // 页颿å°å®½åº¦ |
| | | $page-min-width: 1000px; |
| | | |
| | |
| | | $input-height: 32px; |
| | | .global-window { |
| | | top: 80px !important; |
| | | left: 218px !important; |
| | | left: 250px !important; |
| | | // 头鍿 é¢ |
| | | ::v-deep .el-drawer__header { |
| | | padding: 0 10px 0 0; |
¶Ô±ÈÐÂÎļþ |
| | |
| | | <template> |
| | | <GlobalWindow |
| | | :title="title" |
| | | width="100%" |
| | | :visible.sync="visible" |
| | | :confirm-working="isWorking" |
| | | @confirm="confirm" |
| | | > |
| | | <div class="info"> |
| | | <div class="info_list"> |
| | | <div class="info_list_item"> |
| | | <div class="info_list_item_label">å¼ç¥¨åç§°ï¼</div> |
| | | <div class="info_list_item_val">{{userInfo.company.name}}</div> |
| | | </div> |
| | | <div class="info_list_item"> |
| | | <div class="info_list_item_label">纳ç¨äººè¯å«å·ï¼</div> |
| | | <div class="info_list_item_val">{{userInfo.company.code}}</div> |
| | | </div> |
| | | <div class="info_list_item"> |
| | | <div class="info_list_item_label">弿·è¡ï¼</div> |
| | | <div class="info_list_item_val">{{userInfo.company.taxBank}}</div> |
| | | </div> |
| | | <div class="info_list_item"> |
| | | <div class="info_list_item_label">è´¦å·ï¼</div> |
| | | <div class="info_list_item_val"> |
| | | {{userInfo.company.taxAccount}} |
| | | </div> |
| | | </div> |
| | | <div class="info_list_item" style="width: 100%;"> |
| | | <div class="info_list_item_label">å°åãçµè¯ï¼</div> |
| | | <div class="info_list_item_val">{{userInfo.company.invoiceAddr}} {{userInfo.company.phone}}</div> |
| | | </div> |
| | | <div class="info_list_item" style="width: 100%;"> |
| | | <div class="info_list_item_label">å¼ç¥¨éé¢ï¼</div> |
| | | <div class="info_list_item_val" style="color:rgba(249, 86, 1, 0.996078431372549);">{{totalPrice}}</div> |
| | | </div> |
| | | <div class="list" style="width: 100%;" v-if="form.type === 0"> |
| | | <div class="list_label"> |
| | | æ¥æ¶æ¹å¼ï¼çµåå票 |
| | | </div> |
| | | <div class="list_val"> |
| | | <div class="list_val_label">æ¥æ¶å°åï¼</div> |
| | | <div class="list_val_info">{{form.addr}}</div> |
| | | </div> |
| | | </div> |
| | | <div class="list" style="width: 100%;" v-else> |
| | | <div class="list_label"> |
| | | æ¥æ¶æ¹å¼ï¼çº¸è´¨å票 |
| | | </div> |
| | | <div class="list_val"> |
| | | <div class="list_val_label">æ¥æ¶å°åï¼</div> |
| | | <div class="list_val_info">{{form.addr}}</div> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | <!-- å åä¿ --> |
| | | <el-table |
| | | :data="list1" |
| | | border |
| | | show-summary |
| | | :summary-method="getSummaries1" |
| | | style="width: 100%; margin-bottom: 20px;"> |
| | | <el-table-column |
| | | label="åºå·" |
| | | align="center" |
| | | width="80"> |
| | | <template slot-scope="scope"> |
| | | <span>{{scope.$index + 1}}</span> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column |
| | | align="center" |
| | | prop="solutionName" |
| | | label="ä¿é©æ¹æ¡"> |
| | | </el-table-column> |
| | | <el-table-column |
| | | align="center" |
| | | prop="applyCode" |
| | | label="ä¿åå·"> |
| | | </el-table-column> |
| | | <el-table-column |
| | | align="center" |
| | | label="éé¢"> |
| | | <template slot-scope="{row}"> |
| | | <span style="color:rgba(249, 86, 1, 0.996078431372549);">{{row.totalFee}}</span> |
| | | </template> |
| | | </el-table-column> |
| | | </el-table> |
| | | <!-- å²çº¢å --> |
| | | <el-table |
| | | :data="list2" |
| | | border |
| | | show-summary |
| | | :summary-method="getSummaries2" |
| | | style="width: 100%; margin-bottom: 20px;"> |
| | | <el-table-column |
| | | label="å²çº¢å" |
| | | align="center" |
| | | width="80"> |
| | | <template slot-scope="scope"> |
| | | <span>{{scope.$index + 1}}</span> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column |
| | | align="center" |
| | | prop="solutionsName" |
| | | label="ä¿é©æ¹æ¡"> |
| | | </el-table-column> |
| | | <el-table-column |
| | | align="center" |
| | | prop="downCode" |
| | | label="å票å·"> |
| | | </el-table-column> |
| | | <el-table-column |
| | | align="center" |
| | | prop="createTime" |
| | | label="ç³è¯·å¼ç¥¨æ¶é´"> |
| | | </el-table-column> |
| | | <el-table-column |
| | | align="center" |
| | | label="éé¢"> |
| | | <template slot-scope="{row}"> |
| | | <span style="color:rgba(249, 86, 1, 0.996078431372549);">{{row.totalFee}}</span> |
| | | </template> |
| | | </el-table-column> |
| | | </el-table> |
| | | </div> |
| | | <template v-slot:footer> |
| | | <el-button @click="close">è¿å</el-button> |
| | | </template> |
| | | </GlobalWindow> |
| | | </template> |
| | | |
| | | <script> |
| | | import BaseOpera from '@/components/base/BaseOpera' |
| | | import GlobalWindow from '@/components/common/GlobalWindow' |
| | | import { getDetail } from '@/api/business/taxes' |
| | | import { mapState } from 'vuex' |
| | | export default { |
| | | name: 'directInsuranceDetails', |
| | | extends: BaseOpera, |
| | | components: { GlobalWindow }, |
| | | data () { |
| | | return { |
| | | list1: [], |
| | | list2: [], |
| | | totalPrice: 0, |
| | | form: { |
| | | id: null, |
| | | type: '', |
| | | addr: '' |
| | | } |
| | | } |
| | | }, |
| | | created () { |
| | | this.config({ |
| | | api: '/business/taxes', |
| | | 'field.id': 'id' |
| | | }) |
| | | }, |
| | | computed: { |
| | | ...mapState(['userInfo']) |
| | | }, |
| | | methods: { |
| | | open (title, target) { |
| | | this.title = title |
| | | this.visible = true |
| | | this.list1 = [] |
| | | this.list2 = [] |
| | | this.$nextTick(() => { |
| | | for (const key in this.form) { |
| | | this.form[key] = target[key] |
| | | } |
| | | this.getData() |
| | | }) |
| | | }, |
| | | close () { |
| | | this.visible = false |
| | | }, |
| | | getData() { |
| | | getDetail(this.form.id) |
| | | .then(res => { |
| | | let price = 0 |
| | | this.list1 = res.applyList |
| | | this.list2 = res.delTaxList |
| | | if (this.list1 && this.list1.length > 0) { |
| | | this.list1.forEach(item => { |
| | | price += item.totalFee |
| | | }) |
| | | } |
| | | if (this.list2 && this.list2.length > 0) { |
| | | this.list2.forEach(row => { |
| | | price += row.totalFee |
| | | }) |
| | | } |
| | | this.totalPrice = price |
| | | }) |
| | | }, |
| | | getSummaries1 (param) { |
| | | const { columns, data } = param |
| | | const sums = [] |
| | | columns.forEach((column, index) => { |
| | | if (index === 0) { |
| | | sums[index] = 'å计' |
| | | } else if (index == 4) { |
| | | let price = 0 |
| | | data.forEach(item => { |
| | | price += item.totalFee |
| | | }) |
| | | sums[index] = price |
| | | } |
| | | }) |
| | | return sums; |
| | | }, |
| | | getSummaries2 (param) { |
| | | const { columns, data } = param |
| | | const sums = [] |
| | | columns.forEach((column, index) => { |
| | | if (index === 0) { |
| | | sums[index] = 'å计' |
| | | } else if (index == 5) { |
| | | let price = 0 |
| | | data.forEach(item => { |
| | | price += item.totalFee |
| | | }) |
| | | sums[index] = price |
| | | } |
| | | }) |
| | | return sums; |
| | | } |
| | | } |
| | | } |
| | | </script> |
| | | |
| | | <style lang="scss" scoped> |
| | | ::v-deep .el-table__footer-wrapper tbody td { |
| | | cursor: pointer; |
| | | text-align: center; |
| | | &:nth-child(5) { |
| | | color:rgba(249, 86, 1, 0.996078431372549); |
| | | } |
| | | } |
| | | .red { |
| | | color: red; |
| | | } |
| | | .info { |
| | | width: 100%; |
| | | .info_label { |
| | | width: 100%; |
| | | display: flex; |
| | | align-items: center; |
| | | justify-content: space-between; |
| | | margin-bottom: 20px; |
| | | span { |
| | | font-size: 14px; |
| | | font-weight: 500; |
| | | color: #000000; |
| | | } |
| | | } |
| | | .info_list { |
| | | width: 100%; |
| | | display: flex; |
| | | align-items: left; |
| | | flex-wrap: wrap; |
| | | .list::v-deep { |
| | | width: 100%; |
| | | display: flex; |
| | | align-items: center; |
| | | justify-content: space-between; |
| | | margin-bottom: 15px; |
| | | .el-radio__label { |
| | | color: black; |
| | | font-size: 14px; |
| | | } |
| | | .list_label { |
| | | color: black; |
| | | font-size: 14px; |
| | | margin-right: 20px; |
| | | } |
| | | .list_val { |
| | | flex: 1; |
| | | display: flex; |
| | | align-items: center; |
| | | .list_val_label { |
| | | font-size: 14px; |
| | | color: black; |
| | | flex-shrink: 0; |
| | | margin-right: 15px; |
| | | } |
| | | .list_val_info { |
| | | flex: 1; |
| | | font-size: 14px; |
| | | color: black; |
| | | } |
| | | } |
| | | } |
| | | .info_list_item { |
| | | width: 50%; |
| | | display: flex; |
| | | align-items: start; |
| | | font-size: 14px; |
| | | margin-bottom: 20px; |
| | | .info_list_item_label { |
| | | width: 150px; |
| | | flex-shrink: 0; |
| | | } |
| | | .info_list_item_val { |
| | | flex: 1; |
| | | display: flex; |
| | | align-items: center; |
| | | .image { |
| | | width: 100px; |
| | | height: 100px; |
| | | display: flex; |
| | | align-items: center; |
| | | justify-content: center; |
| | | overflow: hidden; |
| | | img { |
| | | width: 100%; |
| | | } |
| | | } |
| | | } |
| | | } |
| | | } |
| | | } |
| | | |
| | | .form { |
| | | width: 100%; |
| | | display: flex; |
| | | flex-direction: column; |
| | | .form_item { |
| | | width: 100%; |
| | | display: flex; |
| | | align-items: center; |
| | | margin-bottom: 20px; |
| | | &:last-child { |
| | | margin-bottom: 0 !important; |
| | | } |
| | | .form_item_label { |
| | | width: 100px; |
| | | flex-shrink: 0; |
| | | font-size: 14px; |
| | | color: black; |
| | | } |
| | | .form_item_val { |
| | | flex: 1; |
| | | min-height: 35px; |
| | | display: flex; |
| | | align-items: center; |
| | | input { |
| | | width: 100%; |
| | | height: 100%; |
| | | font-size: 14px; |
| | | color: black; |
| | | padding: 5px 10px; |
| | | outline: none; |
| | | box-sizing: border-box; |
| | | border: 1px solid #ececec; |
| | | } |
| | | } |
| | | } |
| | | } |
| | | </style> |
¶Ô±ÈÐÂÎļþ |
| | |
| | | <template> |
| | | <GlobalWindow |
| | | :title="title" |
| | | width="100%" |
| | | :visible.sync="visible" |
| | | :confirm-working="isWorking" |
| | | @confirm="confirm" |
| | | > |
| | | <div class="info"> |
| | | <div class="info_list"> |
| | | <div class="info_list_item"> |
| | | <div class="info_list_item_label">å¼ç¥¨åç§°ï¼</div> |
| | | <div class="info_list_item_val">{{userInfo.company.name}}</div> |
| | | </div> |
| | | <div class="info_list_item"> |
| | | <div class="info_list_item_label">纳ç¨äººè¯å«å·ï¼</div> |
| | | <div class="info_list_item_val">{{userInfo.company.code}}</div> |
| | | </div> |
| | | <div class="info_list_item"> |
| | | <div class="info_list_item_label">弿·è¡ï¼</div> |
| | | <div class="info_list_item_val">{{userInfo.company.taxBank}}</div> |
| | | </div> |
| | | <div class="info_list_item"> |
| | | <div class="info_list_item_label">è´¦å·ï¼</div> |
| | | <div class="info_list_item_val"> |
| | | {{userInfo.company.taxAccount}} |
| | | </div> |
| | | </div> |
| | | <div class="info_list_item" style="width: 100%;"> |
| | | <div class="info_list_item_label">å°åãçµè¯ï¼</div> |
| | | <div class="info_list_item_val">{{userInfo.company.invoiceAddr}} {{userInfo.company.phone}}</div> |
| | | </div> |
| | | <div class="info_list_item" style="width: 100%;"> |
| | | <div class="info_list_item_label">å¼ç¥¨éé¢ï¼</div> |
| | | <div class="info_list_item_val" style="color:rgba(249, 86, 1, 0.996078431372549);">{{totalPrice}}</div> |
| | | </div> |
| | | <div class="list" style="width: 100%;"> |
| | | <el-radio v-model="type" label="0">çµåå票</el-radio> |
| | | <div class="list_val"> |
| | | <div class="list_val_label">æ¥æ¶å°åï¼</div> |
| | | <el-input v-model="val" :disabled="type === '1'" placeholder="111222333@qq.com"></el-input> |
| | | </div> |
| | | </div> |
| | | <div class="list" style="width: 100%;"> |
| | | <el-radio v-model="type" label="1">纸质å票</el-radio> |
| | | <div class="list_val"> |
| | | <div class="list_val_label">æ¥æ¶å°åï¼</div> |
| | | <el-input v-model="val1" :disabled="type === '0'" placeholder="å®å¾½çåè¥å¸ç»æµææ¯å¼ååºè²è±è·¯ä»¥ä¸ãç³é¨è·¯ä»¥åè²è±è·¯1ï¼ 0551-63450845"></el-input> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | <!-- å åä¿ --> |
| | | <el-table |
| | | :data="list1" |
| | | border |
| | | show-summary |
| | | :summary-method="getSummaries1" |
| | | style="width: 100%; margin-bottom: 20px;"> |
| | | <el-table-column |
| | | label="åºå·" |
| | | align="center" |
| | | width="80"> |
| | | <template slot-scope="scope"> |
| | | <span>{{scope.$index + 1}}</span> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column |
| | | align="center" |
| | | prop="solutionsName" |
| | | label="ä¿é©æ¹æ¡"> |
| | | </el-table-column> |
| | | <el-table-column |
| | | align="center" |
| | | prop="insuranceCode" |
| | | label="ä¿åå·"> |
| | | </el-table-column> |
| | | <el-table-column |
| | | align="center" |
| | | label="éé¢"> |
| | | <template slot-scope="{row}"> |
| | | <span style="color:rgba(249, 86, 1, 0.996078431372549);">{{row.amount}}</span> |
| | | </template> |
| | | </el-table-column> |
| | | </el-table> |
| | | <!-- å²çº¢å --> |
| | | <el-table |
| | | :data="list2" |
| | | border |
| | | show-summary |
| | | :summary-method="getSummaries2" |
| | | @selection-change="handleSelectionChange" |
| | | style="width: 100%; margin-bottom: 20px;"> |
| | | <el-table-column type="selection" fixed="left" width="55"></el-table-column> |
| | | <el-table-column |
| | | label="å²çº¢å" |
| | | align="center" |
| | | width="80"> |
| | | <template slot-scope="scope"> |
| | | <span>{{scope.$index + 1}}</span> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column |
| | | align="center" |
| | | prop="solutionsName" |
| | | label="ä¿é©æ¹æ¡"> |
| | | </el-table-column> |
| | | <el-table-column |
| | | align="center" |
| | | prop="downCode" |
| | | label="å票å·"> |
| | | </el-table-column> |
| | | <el-table-column |
| | | align="center" |
| | | prop="createTime" |
| | | label="ç³è¯·å¼ç¥¨æ¶é´"> |
| | | </el-table-column> |
| | | <el-table-column |
| | | align="center" |
| | | label="éé¢"> |
| | | <template slot-scope="{row}"> |
| | | <span style="color:rgba(249, 86, 1, 0.996078431372549);">{{row.amount}}</span> |
| | | </template> |
| | | </el-table-column> |
| | | </el-table> |
| | | </div> |
| | | </GlobalWindow> |
| | | </template> |
| | | |
| | | <script> |
| | | import BaseOpera from '@/components/base/BaseOpera' |
| | | import GlobalWindow from '@/components/common/GlobalWindow' |
| | | import { getDirectTaxes, directInvoicing } from '@/api/business/taxes' |
| | | import { mapState } from 'vuex' |
| | | export default { |
| | | name: 'directInvoicingApplication', |
| | | extends: BaseOpera, |
| | | components: { GlobalWindow }, |
| | | data () { |
| | | return { |
| | | list1: [], |
| | | list2: [], |
| | | form: { |
| | | id: null |
| | | }, |
| | | setectData: [], |
| | | type: '0', |
| | | val: '', |
| | | val1: '', |
| | | rules: { |
| | | backInfo: [ |
| | | { required: true, message: '请è¾å
¥éå说æ' } |
| | | ] |
| | | } |
| | | } |
| | | }, |
| | | created () { |
| | | this.config({ |
| | | api: '/business/taxes', |
| | | 'field.id': 'id' |
| | | }) |
| | | }, |
| | | computed: { |
| | | ...mapState(['userInfo']), |
| | | totalPrice() { |
| | | let price = 0 |
| | | this.list1.forEach(item => { |
| | | price += item.amount |
| | | }) |
| | | this.setectData.forEach(item => { |
| | | this.list2.forEach(row => { |
| | | if (item.id === row.id) { |
| | | price += row.amount |
| | | } |
| | | }) |
| | | }) |
| | | return price |
| | | } |
| | | }, |
| | | watch: { |
| | | type: { |
| | | handler(news) { |
| | | this.val = '' |
| | | this.val1 = '' |
| | | } |
| | | } |
| | | }, |
| | | methods: { |
| | | open (title, target) { |
| | | this.title = title |
| | | this.visible = true |
| | | this.list1 = [] |
| | | this.list2 = [] |
| | | this.$nextTick(() => { |
| | | for (const key in this.form) { |
| | | this.form[key] = target[key] |
| | | } |
| | | this.getData() |
| | | }) |
| | | }, |
| | | confirm () { |
| | | if (!this.val && !this.val1) { |
| | | this.$message.warning('请è¾å
¥æ¥æ¶å°å') |
| | | return |
| | | } |
| | | if (this.setectData.length === 0) { |
| | | this.$message.warning('è³å°å¾éä¸é¡¹å²çº¢åæ°æ®') |
| | | return |
| | | } |
| | | this.isWorking = true |
| | | directInvoicing({ |
| | | address: this.val1 || this.val, |
| | | id: this.form.id, |
| | | invoicingDetailDTOList: this.setectData.map(item => item.id), |
| | | invoicingMoney: this.totalPrice, |
| | | type: this.type |
| | | }).then(res => { |
| | | this.visible = false |
| | | this.$tip.apiSuccess('æä½æå') |
| | | this.$emit('success') |
| | | }).catch(e => { |
| | | this.$tip.apiFailed(e) |
| | | }).finally(() => { |
| | | this.isWorking = false |
| | | }) |
| | | }, |
| | | handleSelectionChange(e) { |
| | | this.setectData = e |
| | | }, |
| | | getData() { |
| | | getDirectTaxes(this.form.id) |
| | | .then(res => { |
| | | res.forEach(item => { |
| | | if (item.type === 2) { |
| | | this.list2.push(item) |
| | | } else { |
| | | this.list1.push(item) |
| | | } |
| | | }) |
| | | }) |
| | | }, |
| | | getSummaries1 (param) { |
| | | const { columns, data } = param |
| | | const sums = [] |
| | | columns.forEach((column, index) => { |
| | | if (index === 0) { |
| | | sums[index] = 'å计' |
| | | } else if (index == 4) { |
| | | let price = 0 |
| | | data.forEach(item => { |
| | | price += item.amount |
| | | }) |
| | | sums[index] = price |
| | | } |
| | | }) |
| | | return sums; |
| | | }, |
| | | getSummaries2 (param) { |
| | | const { columns, data } = param |
| | | const sums = [] |
| | | columns.forEach((column, index) => { |
| | | if (index === 0) { |
| | | sums[index] = 'å计' |
| | | } else if (index == 5) { |
| | | let price = 0 |
| | | data.forEach(item => { |
| | | price += item.amount |
| | | }) |
| | | sums[index] = price |
| | | } |
| | | }) |
| | | return sums; |
| | | } |
| | | } |
| | | } |
| | | </script> |
| | | |
| | | <style lang="scss" scoped> |
| | | ::v-deep .el-table__footer-wrapper tbody td { |
| | | cursor: pointer; |
| | | text-align: center; |
| | | &:nth-child(5) { |
| | | color:rgba(249, 86, 1, 0.996078431372549); |
| | | } |
| | | } |
| | | .red { |
| | | color: red; |
| | | } |
| | | .info { |
| | | width: 100%; |
| | | .info_label { |
| | | width: 100%; |
| | | display: flex; |
| | | align-items: center; |
| | | justify-content: space-between; |
| | | margin-bottom: 20px; |
| | | span { |
| | | font-size: 14px; |
| | | font-weight: 500; |
| | | color: #000000; |
| | | } |
| | | } |
| | | .info_list { |
| | | width: 100%; |
| | | display: flex; |
| | | align-items: left; |
| | | flex-wrap: wrap; |
| | | .list::v-deep { |
| | | width: 100%; |
| | | display: flex; |
| | | align-items: center; |
| | | justify-content: space-between; |
| | | margin-bottom: 15px; |
| | | .el-radio__label { |
| | | color: black; |
| | | font-size: 14px; |
| | | } |
| | | .list_val { |
| | | flex: 1; |
| | | display: flex; |
| | | align-items: center; |
| | | .list_val_label { |
| | | font-size: 14px; |
| | | color: black; |
| | | flex-shrink: 0; |
| | | margin-right: 15px; |
| | | } |
| | | } |
| | | } |
| | | .info_list_item { |
| | | width: 50%; |
| | | display: flex; |
| | | align-items: start; |
| | | font-size: 14px; |
| | | margin-bottom: 20px; |
| | | .info_list_item_label { |
| | | width: 150px; |
| | | flex-shrink: 0; |
| | | } |
| | | .info_list_item_val { |
| | | flex: 1; |
| | | display: flex; |
| | | align-items: center; |
| | | .image { |
| | | width: 100px; |
| | | height: 100px; |
| | | display: flex; |
| | | align-items: center; |
| | | justify-content: center; |
| | | overflow: hidden; |
| | | img { |
| | | width: 100%; |
| | | } |
| | | } |
| | | } |
| | | } |
| | | } |
| | | } |
| | | |
| | | .form { |
| | | width: 100%; |
| | | display: flex; |
| | | flex-direction: column; |
| | | .form_item { |
| | | width: 100%; |
| | | display: flex; |
| | | align-items: center; |
| | | margin-bottom: 20px; |
| | | &:last-child { |
| | | margin-bottom: 0 !important; |
| | | } |
| | | .form_item_label { |
| | | width: 100px; |
| | | flex-shrink: 0; |
| | | font-size: 14px; |
| | | color: black; |
| | | } |
| | | .form_item_val { |
| | | flex: 1; |
| | | min-height: 35px; |
| | | display: flex; |
| | | align-items: center; |
| | | input { |
| | | width: 100%; |
| | | height: 100%; |
| | | font-size: 14px; |
| | | color: black; |
| | | padding: 5px 10px; |
| | | outline: none; |
| | | box-sizing: border-box; |
| | | border: 1px solid #ececec; |
| | | } |
| | | } |
| | | } |
| | | } |
| | | </style> |
| | |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column |
| | | prop="solutionName" |
| | | prop="createDate" |
| | | label="ç³è¯·å¼ç¥¨æ¶é´"> |
| | | </el-table-column> |
| | | <el-table-column |
| | | prop="bdCode" |
| | | label="å¼ç¥¨ç¶æ"> |
| | | <template slot-scope="{row}"> |
| | | <span v-if="row.status === 1">å·²å¼ç¥¨</span> |
| | | <span v-else-if="row.status === 2">平尿¤å</span> |
| | | <span v-else-if="row.status === 3">å·²å²çº¢</span> |
| | | <span v-else>å¾
å¤ç</span> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column |
| | | prop="applyChangeId" |
| | | prop="price" |
| | | label="å¼ç¥¨éé¢ï¼å
ï¼"> |
| | | </el-table-column> |
| | | <el-table-column |
| | | prop="duName" |
| | | label="æ¥æ¶æ¹å¼"> |
| | | <template slot-scope="{row}"> |
| | | <span v-if="row.type === 1">纸质å票</span> |
| | | <span v-else>çµåå票</span> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column |
| | | label="çµåå票"> |
| | | <template slot-scope="{row}"> |
| | | <el-image |
| | | style="width: 50px; height: 50px" |
| | | :src="row.imgurlFull" |
| | | :preview-src-list="[row.imgurlFull]"> |
| | | </el-image> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column |
| | | label="æä½"> |
| | | <template slot-scope="{row}"> |
| | | <el-button type="text">ç³è¯·è¯¦æ
</el-button> |
| | | <el-button type="text" @click="see(row)">ç³è¯·è¯¦æ
</el-button> |
| | | </template> |
| | | </el-table-column> |
| | | </el-table> |
| | | <template v-slot:footer> |
| | | <el-button @click="close">è¿å</el-button> |
| | | </template> |
| | | <directInsuranceDetails ref="directInsuranceDetails" /> |
| | | </GlobalWindow> |
| | | </template> |
| | | |
| | |
| | | import BaseOpera from '@/components/base/BaseOpera' |
| | | import GlobalWindow from '@/components/common/GlobalWindow' |
| | | import { list } from '@/api/business/taxes' |
| | | import directInsuranceDetails from '@/components/enterprise/directInsuranceDetails' |
| | | export default { |
| | | name: 'entrustmentHistory', |
| | | extends: BaseOpera, |
| | | components: { GlobalWindow }, |
| | | components: { GlobalWindow, directInsuranceDetails }, |
| | | data () { |
| | | return { |
| | | form: { |
| | |
| | | methods: { |
| | | open (title, target) { |
| | | this.title = title |
| | | this.list = [] |
| | | this.visible = true |
| | | // ç¼è¾ |
| | | this.$nextTick(() => { |
| | |
| | | this.getList() |
| | | }) |
| | | }, |
| | | see(row) { |
| | | let info = '' |
| | | if (row.status === 1) { |
| | | info = 'å·²å¼ç¥¨' |
| | | } else if (row.status === 2) { |
| | | info = '平尿¤å' |
| | | } else if (row.status === 3) { |
| | | info = 'å·²å²çº¢' |
| | | } else { |
| | | info = 'å¾
å¤ç' |
| | | } |
| | | this.$refs.directInsuranceDetails.open(`å¼ç¥¨è¯¦æ
ï¼${info}ï¼`, row) |
| | | }, |
| | | getList() { |
| | | list({ insuranceApplyId: this.form.id }) |
| | | .then(res => { |
| | | console.log(res) |
| | | this.list = res |
| | | }) |
| | | }, |
| | | close () { |
| | | this.visible = false |
| | | } |
| | | } |
| | | } |
| | | </script> |
| | | |
| | | <style> |
| | | .el-image-viewer__wrapper { |
| | | z-index: 3000 !important; |
| | | } |
| | | </style> |
| | |
| | | <template v-slot:table-wrap> |
| | | <ul style="margin-bottom: 30px;width: 100%;display: flex;align-items: center;justify-content: space-between;"> |
| | | <li style="font-size: 18px;font-weight: bold;">ç³è¯·å¼ç¥¨</li> |
| | | <li><el-button type="primary" @click="apply">æäº¤å¼ç¥¨</el-button></li> |
| | | </ul> |
| | | <el-table |
| | | v-loading="isWorking.search" |
| | | :data="tableData.list" |
| | | stripe |
| | | @selection-change="handleSelectionChange" |
| | | > |
| | | <el-table-column type="selection" fixed="left" width="55"></el-table-column> |
| | | <el-table-column label="åºå·" width="80px"> |
| | | <template slot-scope="scope"> |
| | | <span>{{scope.$index + 1}}</span> |
| | |
| | | <el-table-column label="æä½" min-width="180px"> |
| | | <template slot-scope="{row}"> |
| | | <el-button type="text" @click="$refs.entrustmentHistory.open('å¼ç¥¨åå²', row)">å¼ç¥¨åå²</el-button> |
| | | <el-button type="text" @click="$refs.directInvoicingApplication.open('å¼ç¥¨ç³è¯·', row)">ç³è¯·å¼ç¥¨</el-button> |
| | | </template> |
| | | </el-table-column> |
| | | </el-table> |
| | |
| | | </pagination> |
| | | </template> |
| | | <!-- ç³è¯· --> |
| | | <entrustedInvoicingApplication ref="entrustedInvoicingApplication" @success="handlePageChange" /> |
| | | <directInvoicingApplication ref="directInvoicingApplication" @success="handlePageChange" /> |
| | | <!-- å¼ç¥¨åå² --> |
| | | <entrustmentHistory ref="entrustmentHistory" @success="handlePageChange" /> |
| | | </TableLayout> |
| | |
| | | import BaseTable from '@/components/base/BaseTable' |
| | | import TableLayout from '@/layouts/TableLayout' |
| | | import Pagination from '@/components/common/Pagination' |
| | | import entrustedInvoicingApplication from '@/components/enterprise/entrustedInvoicingApplication' |
| | | import directInvoicingApplication from '@/components/enterprise/directInvoicingApplication' |
| | | import entrustmentHistory from '@/components/enterprise/entrustmentHistory' |
| | | export default { |
| | | name: 'directInvoicing', |
| | | extends: BaseTable, |
| | | components: { TableLayout, Pagination, entrustedInvoicingApplication, entrustmentHistory }, |
| | | components: { TableLayout, Pagination, directInvoicingApplication, entrustmentHistory }, |
| | | data () { |
| | | return { |
| | | searchForm: { |
| | |
| | | this.search() |
| | | }, |
| | | methods: { |
| | | apply() { |
| | | if (this.tableData.selectedRows.length === 0) { |
| | | this.$message.warning('è³å°éæ©ä¸é¡¹å
容') |
| | | return |
| | | } |
| | | for (let i = 0; i < this.tableData.selectedRows.length; i++) { |
| | | if (this.tableData.selectedRows[i].currentFee - this.tableData.selectedRows[i].taxesMoney === 0) { |
| | | this.$message.warning(`第${i + 1}项å¯å¼ç¥¨éé¢ä¸º0ï¼ä¸è½è¿è¡å¼ç¥¨ï¼`) |
| | | return |
| | | } |
| | | } |
| | | let obj = {} |
| | | obj.list = JSON.parse(JSON.stringify(this.tableData.selectedRows)) |
| | | obj.list.forEach(item => { |
| | | item.totalPrice = item.currentFee - item.taxesMoney |
| | | }) |
| | | console.log(obj.list) |
| | | this.$refs.entrustedInvoicingApplication.open('ç³è¯·å¼ç¥¨', obj) |
| | | } |
| | | |
| | | } |
| | | } |
| | | </script> |