|
@@ -1,5 +1,6 @@
|
|
|
<template>
|
|
|
- <div class="cost-all">
|
|
|
+ <div class="cost-all" v-loading="costloading" element-loading-text="拼命加载中" element-loading-spinner="el-icon-loading"
|
|
|
+ element-loading-background="rgba(0, 0, 0, 0.8)">
|
|
|
<div class="cost-box">
|
|
|
<div class="cost-haed">
|
|
|
<div class="ser-btn">
|
|
@@ -13,7 +14,7 @@
|
|
|
<div style="line-height: 40px;width: 90px;text-align: right;padding-right: 12px;">
|
|
|
分段类型:
|
|
|
</div>
|
|
|
- <el-select v-model="costTypevalue" placeholder="请选择">
|
|
|
+ <el-select v-model="costTypevalue" placeholder="请选择" @change="costTypeSelect">
|
|
|
<el-option v-for="item in costType" :key="item.value" :label="item.label" :value="item.value">
|
|
|
</el-option>
|
|
|
</el-select>
|
|
@@ -29,8 +30,9 @@
|
|
|
</div>
|
|
|
</div>
|
|
|
<div class="cost-input">
|
|
|
- <el-form :inline="true" :model="formInline" class="demo-form-inline">
|
|
|
- <el-form-item label="税率:">
|
|
|
+ <el-form :inline="true" class="demo-form-inline" :model='AGroupCostParameter' ref="inputs"
|
|
|
+ :rules="rules">
|
|
|
+ <el-form-item label="税率:" prop="tax">
|
|
|
<el-input v-model="AGroupCostParameter.tax" placeholder="税率"></el-input>
|
|
|
</el-form-item>
|
|
|
<el-form-item label="货币:">
|
|
@@ -40,43 +42,53 @@
|
|
|
</el-option>
|
|
|
</el-select>
|
|
|
</el-form-item>
|
|
|
- <el-form-item label="汇率:">
|
|
|
+ <el-form-item label="汇率:" prop="rate">
|
|
|
<el-input v-model="AGroupCostParameter.rate" placeholder="汇率"></el-input>
|
|
|
</el-form-item>
|
|
|
- <div v-if="costTypevalue == 'A'">
|
|
|
- <el-form-item label="TBR:">
|
|
|
- <el-input v-model="costTypeHotelNumbers.filter(item => item.type == 'Default')[0].tbr"
|
|
|
+ </el-form>
|
|
|
+ <div v-show="costTypevalue == 'A'">
|
|
|
+ <el-form :inline="true" class="demo-form-inline" :rules="HotelRules" ref="DHotel"
|
|
|
+ :model="costTypeHotelNumbers.filter(item => item.type == 'Default')[0]">
|
|
|
+ <el-form-item label="TBR:" prop="tbr">
|
|
|
+ <el-input
|
|
|
+ v-model.number="costTypeHotelNumbers.filter(item => item.type == 'Default')[0].tbr"
|
|
|
placeholder="TBR"><i slot="suffix"
|
|
|
style="font-style:normal;margin-right: 10px;">间</i></el-input>
|
|
|
</el-form-item>
|
|
|
- <el-form-item label="SGR:">
|
|
|
- <el-input v-model="costTypeHotelNumbers.filter(item => item.type == 'Default')[0].sgr"
|
|
|
+ <el-form-item label="SGR:" prop="sgr">
|
|
|
+ <el-input
|
|
|
+ v-model.number="costTypeHotelNumbers.filter(item => item.type == 'Default')[0].sgr"
|
|
|
placeholder="SGR"><i slot="suffix"
|
|
|
style="font-style:normal;margin-right: 10px;">间</i></el-input>
|
|
|
</el-form-item>
|
|
|
- <el-form-item label="JS/ES:">
|
|
|
- <el-input v-model="costTypeHotelNumbers.filter(item => item.type == 'Default')[0].jses"
|
|
|
+ <el-form-item label="JS/ES:" prop="jses">
|
|
|
+ <el-input
|
|
|
+ v-model.number="costTypeHotelNumbers.filter(item => item.type == 'Default')[0].jses"
|
|
|
placeholder="JS/ES"><i slot="suffix"
|
|
|
style="font-style:normal;margin-right: 10px;">间</i></el-input>
|
|
|
</el-form-item>
|
|
|
- <el-form-item label="SUITE:">
|
|
|
- <el-input v-model="costTypeHotelNumbers.filter(item => item.type == 'Default')[0].suite"
|
|
|
+ <el-form-item label="SUITE:" prop="suite">
|
|
|
+ <el-input
|
|
|
+ v-model.number="costTypeHotelNumbers.filter(item => item.type == 'Default')[0].suite"
|
|
|
placeholder="SUITE"><i slot="suffix"
|
|
|
style="font-style:normal;margin-right: 10px;">间</i></el-input>
|
|
|
</el-form-item>
|
|
|
- </div>
|
|
|
- <div v-else class="CostBShow">
|
|
|
- <el-row>
|
|
|
+ </el-form>
|
|
|
+ </div>
|
|
|
+ <div v-show="costTypevalue == 'B'" class="CostBShow">
|
|
|
+ <el-row>
|
|
|
+ <el-form ref="Asection" :inline="true" class="demo-form-inline" :rules="CostTimeRules"
|
|
|
+ :model="AGroupCostParameter">
|
|
|
<el-col :span="5">
|
|
|
- <div> <el-form-item label="第一段开始时间:"><el-date-picker
|
|
|
- v-model="AGroupCostParameter.costTypeStartTime" type="date"
|
|
|
+ <div> <el-form-item label="第一段开始时间:" prop="costTypeStartTime">
|
|
|
+ <el-date-picker v-model="AGroupCostParameter.costTypeStartTime" type="date"
|
|
|
placeholder="第一段开始时间" format="yyyy 年 MM 月 dd 日" value-format="yyyy-MM-dd">
|
|
|
</el-date-picker>
|
|
|
</el-form-item>
|
|
|
</div>
|
|
|
</el-col>
|
|
|
<el-col :span="4">
|
|
|
- <div> <el-form-item label="结束时间:"><el-date-picker
|
|
|
+ <div> <el-form-item label="结束时间:" prop="costTypeendTime"><el-date-picker
|
|
|
v-model="AGroupCostParameter.costTypeendTime" type="date" placeholder="结束时间"
|
|
|
format="yyyy 年 MM 月 dd 日" value-format="yyyy-MM-dd">
|
|
|
</el-date-picker>
|
|
@@ -85,54 +97,62 @@
|
|
|
</el-col>
|
|
|
<el-col :span="3">
|
|
|
<div>
|
|
|
- <el-form-item label="人数:"><el-input placeholder="人数"
|
|
|
- v-model="AGroupCostParameter.costTypenumber" clearable>
|
|
|
+ <el-form-item label="人数:" prop="costTypenumber"><el-input placeholder="人数"
|
|
|
+ v-model.number="AGroupCostParameter.costTypenumber" clearable>
|
|
|
</el-input>
|
|
|
</el-form-item>
|
|
|
</div>
|
|
|
</el-col>
|
|
|
+ </el-form>
|
|
|
+ <el-form ref="AHotel" :inline="true" class="demo-form-inline" :rules="HotelRules"
|
|
|
+ :model="costTypeHotelNumbers.filter(item => item.type == 'A')[0]">
|
|
|
<el-col :span="3">
|
|
|
- <div><el-form-item label="TBR:">
|
|
|
- <el-input v-model="costTypeHotelNumbers.filter(item => item.type == 'A')[0].tbr"
|
|
|
+ <div><el-form-item label="TBR:" prop="tbr">
|
|
|
+ <el-input
|
|
|
+ v-model.number="costTypeHotelNumbers.filter(item => item.type == 'A')[0].tbr"
|
|
|
placeholder="TBR"><i slot="suffix"
|
|
|
style="font-style:normal;margin-right: 10px;">间</i></el-input>
|
|
|
</el-form-item></div>
|
|
|
</el-col>
|
|
|
<el-col :span="3">
|
|
|
- <div> <el-form-item label="SGR:">
|
|
|
- <el-input v-model="costTypeHotelNumbers.filter(item => item.type == 'A')[0].sgr"
|
|
|
+ <div> <el-form-item label="SGR:" prop="sgr">
|
|
|
+ <el-input
|
|
|
+ v-model.number="costTypeHotelNumbers.filter(item => item.type == 'A')[0].sgr"
|
|
|
placeholder="SGR"><i slot="suffix"
|
|
|
style="font-style:normal;margin-right: 10px;">间</i></el-input>
|
|
|
</el-form-item></div>
|
|
|
</el-col>
|
|
|
<el-col :span="3">
|
|
|
- <div><el-form-item label="JS/ES:">
|
|
|
+ <div><el-form-item label="JS/ES:" prop="jses">
|
|
|
<el-input
|
|
|
- v-model="costTypeHotelNumbers.filter(item => item.type == 'A')[0].jses"
|
|
|
+ v-model.number="costTypeHotelNumbers.filter(item => item.type == 'A')[0].jses"
|
|
|
placeholder="JS/ES"><i slot="suffix"
|
|
|
style="font-style:normal;margin-right: 10px;">间</i></el-input>
|
|
|
</el-form-item></div>
|
|
|
</el-col>
|
|
|
<el-col :span="3">
|
|
|
- <div><el-form-item label="SUITE:">
|
|
|
+ <div><el-form-item label="SUITE:" prop="suite">
|
|
|
<el-input
|
|
|
- v-model="costTypeHotelNumbers.filter(item => item.type == 'A')[0].suite"
|
|
|
+ v-model.number="costTypeHotelNumbers.filter(item => item.type == 'A')[0].suite"
|
|
|
placeholder="SUITE"><i slot="suffix"
|
|
|
style="font-style:normal;margin-right: 10px;">间</i></el-input>
|
|
|
</el-form-item></div>
|
|
|
</el-col>
|
|
|
- </el-row>
|
|
|
- <el-row>
|
|
|
+ </el-form>
|
|
|
+ </el-row>
|
|
|
+ <el-row>
|
|
|
+ <el-form ref="Bsection" :inline="true" class="demo-form-inline" :rules="CostTimeRules"
|
|
|
+ :model="BGroupCostParameter">
|
|
|
<el-col :span="5">
|
|
|
- <div> <el-form-item label="第二段开始时间:"><el-date-picker
|
|
|
- v-model="BGroupCostParameter.costTypeStartTime" type="date"
|
|
|
+ <div> <el-form-item label="第二段开始时间:" prop="costTypeStartTime">
|
|
|
+ <el-date-picker v-model="BGroupCostParameter.costTypeStartTime" type="date"
|
|
|
placeholder="第二段开始时间" format="yyyy 年 MM 月 dd 日" value-format="yyyy-MM-dd">
|
|
|
</el-date-picker>
|
|
|
</el-form-item>
|
|
|
</div>
|
|
|
</el-col>
|
|
|
<el-col :span="4">
|
|
|
- <div> <el-form-item label="结束时间:"><el-date-picker
|
|
|
+ <div> <el-form-item label="结束时间:" prop="costTypeendTime"><el-date-picker
|
|
|
v-model="BGroupCostParameter.costTypeendTime" type="date" placeholder="结束时间"
|
|
|
format="yyyy 年 MM 月 dd 日" value-format="yyyy-MM-dd">
|
|
|
</el-date-picker>
|
|
@@ -141,45 +161,53 @@
|
|
|
</el-col>
|
|
|
<el-col :span="3">
|
|
|
<div>
|
|
|
- <el-form-item label="人数:"><el-input placeholder="人数"
|
|
|
- v-model="BGroupCostParameter.costTypenumber" clearable>
|
|
|
+ <el-form-item label="人数:" prop="costTypenumber"><el-input placeholder="人数"
|
|
|
+ v-model.number="BGroupCostParameter.costTypenumber" clearable>
|
|
|
</el-input>
|
|
|
</el-form-item>
|
|
|
</div>
|
|
|
</el-col>
|
|
|
+ </el-form>
|
|
|
+ <el-form ref="BHotel" :inline="true" class="demo-form-inline" :rules="HotelRules"
|
|
|
+ :model="costTypeHotelNumbers.filter(item => item.type == 'B')[0]">
|
|
|
<el-col :span="3">
|
|
|
- <div><el-form-item label="TBR:">
|
|
|
- <el-input v-model="costTypeHotelNumbers.filter(item => item.type == 'B')[0].tbr"
|
|
|
+ <div>
|
|
|
+ <el-form-item label="TBR:" prop="tbr">
|
|
|
+ <el-input
|
|
|
+ v-model.number="costTypeHotelNumbers.filter(item => item.type == 'B')[0].tbr"
|
|
|
placeholder="TBR"><i slot="suffix"
|
|
|
style="font-style:normal;margin-right: 10px;">间</i></el-input>
|
|
|
- </el-form-item></div>
|
|
|
+ </el-form-item>
|
|
|
+ </div>
|
|
|
</el-col>
|
|
|
<el-col :span="3">
|
|
|
- <div> <el-form-item label="SGR:">
|
|
|
- <el-input v-model="costTypeHotelNumbers.filter(item => item.type == 'B')[0].sgr"
|
|
|
+ <div> <el-form-item label="SGR:" prop="sgr">
|
|
|
+ <el-input
|
|
|
+ v-model.number="costTypeHotelNumbers.filter(item => item.type == 'B')[0].sgr"
|
|
|
placeholder="SGR"><i slot="suffix"
|
|
|
style="font-style:normal;margin-right: 10px;">间</i></el-input>
|
|
|
</el-form-item></div>
|
|
|
</el-col>
|
|
|
<el-col :span="3">
|
|
|
- <div><el-form-item label="JS/ES:">
|
|
|
+ <div><el-form-item label="JS/ES:" prop="jses">
|
|
|
<el-input
|
|
|
- v-model="costTypeHotelNumbers.filter(item => item.type == 'B')[0].jses"
|
|
|
+ v-model.number="costTypeHotelNumbers.filter(item => item.type == 'B')[0].jses"
|
|
|
placeholder="JS/ES"><i slot="suffix"
|
|
|
style="font-style:normal;margin-right: 10px;">间</i></el-input>
|
|
|
</el-form-item></div>
|
|
|
</el-col>
|
|
|
<el-col :span="3">
|
|
|
- <div><el-form-item label="SUITE:">
|
|
|
+ <div><el-form-item label="SUITE:" prop="suite">
|
|
|
<el-input
|
|
|
- v-model="costTypeHotelNumbers.filter(item => item.type == 'B')[0].suite"
|
|
|
+ v-model.number="costTypeHotelNumbers.filter(item => item.type == 'B')[0].suite"
|
|
|
placeholder="SUITE"><i slot="suffix"
|
|
|
style="font-style:normal;margin-right: 10px;">间</i></el-input>
|
|
|
</el-form-item></div>
|
|
|
</el-col>
|
|
|
- </el-row>
|
|
|
- </div>
|
|
|
- </el-form>
|
|
|
+ </el-form>
|
|
|
+ </el-row>
|
|
|
+
|
|
|
+ </div>
|
|
|
</div>
|
|
|
<div class="cost-info">
|
|
|
<div class="cost-info-li">
|
|
@@ -209,13 +237,15 @@
|
|
|
<div style="color: #606266;font-size: 15px;font-weight: 600;">请选择要显示的项:</div>
|
|
|
<el-checkbox-group class="form-ss" v-model="CheckBoxListSelect.filter(item => item.cbType == 'Top')[0].cbValues"
|
|
|
@change="TopChange">
|
|
|
- <el-checkbox v-for="(item, index) in checkOptions" :key="index" :title="item.tips"
|
|
|
- :label="item.label"></el-checkbox>
|
|
|
+ <el-checkbox v-for="( item, index ) in checkOptions " :key="index" :title="item.tips"
|
|
|
+ :label="item.label" @change="(val) => { topcheckboxChange(val, item.label) }"></el-checkbox>
|
|
|
</el-checkbox-group>
|
|
|
<el-table :summary-method="getSummaries" show-summary :data="tableData" :border="true" size="small"
|
|
|
- row-class-name="row" cell-class-name="column" :highlight-current-row="true" fit>
|
|
|
- <template v-for="(item, index) in tableLabel">
|
|
|
- <el-table-column :key="index" :prop="item.prop" :width="item.width" :label="item.label"
|
|
|
+ row-class-name="row" cell-class-name="column" :highlight-current-row="true" :fit="true"
|
|
|
+ :height="centerheight">
|
|
|
+ <template v-for="( item, index ) in tableLabel ">
|
|
|
+ <el-table-column :key="index" :prop="item.prop" :width="item.width == 150 ? columnWidth : item.width"
|
|
|
+ :label="item.label"
|
|
|
v-if="CheckBoxListSelect.filter(item => item.cbType == 'Top')[0].cbValues.includes(item.label)">
|
|
|
<!-- eslint-disable-next-line -->
|
|
|
<template slot="header" slot-scope="scope">
|
|
@@ -253,7 +283,7 @@
|
|
|
</template>
|
|
|
</el-table-column>
|
|
|
</template>
|
|
|
- <el-table-column label="操作">
|
|
|
+ <el-table-column label="操作" :width="200">
|
|
|
<!-- eslint-disable-next-line -->
|
|
|
<template slot-scope="scope">
|
|
|
<el-button size="mini" @click="handleDelete(scope.$index, scope.row, tableData)" type="danger"><i
|
|
@@ -267,16 +297,17 @@
|
|
|
<div class="sheet-li">
|
|
|
<div style="color: #606266;font-size: 15px;font-weight: 600;">请选择要显示的项:</div>
|
|
|
<el-checkbox-group v-model="CheckBoxListSelect.filter(item => item.cbType == 'Left')[0].cbValues">
|
|
|
- <el-checkbox v-for="(item, index) in sheetoneOptions" :key="index" :label="item"></el-checkbox>
|
|
|
+ <el-checkbox v-for="( item, index ) in sheetoneOptions " :key="index"
|
|
|
+ :label="item"></el-checkbox>
|
|
|
</el-checkbox-group>
|
|
|
<div style="display: flex;">
|
|
|
<div :style="{ 'width': costTypevalue == 'A' ? '100%' : '49%' }">
|
|
|
- <div v-for="(sheetitem, index) in sheetDatal" :key="index">
|
|
|
+ <div v-for="( sheetitem, index ) in sheetDatal " :key="index">
|
|
|
<div class="biaoge"
|
|
|
v-if="CheckBoxListSelect.filter(item => item.cbType == 'Left')[0].cbValues.includes(sheetitem.label)">
|
|
|
<el-table :data="[{ a: 1 }]" border style="width: 100%">
|
|
|
- <el-table-column v-for="(itemsheetone, index) in sheetitem.childList" :key="index"
|
|
|
- :prop="itemsheetone.prop" :label="itemsheetone.childLabel">
|
|
|
+ <el-table-column v-for="( itemsheetone, index ) in sheetitem.childList "
|
|
|
+ :key="index" :prop="itemsheetone.prop" :label="itemsheetone.childLabel">
|
|
|
<template slot-scope="scope">
|
|
|
<div v-if="itemsheetone.prop.indexOf(sheetitem.EnLabel) != -1">
|
|
|
<div v-if="itemsheetone.isBind">
|
|
@@ -311,13 +342,13 @@
|
|
|
</div>
|
|
|
<div style="width: 2%;" v-show="costTypevalue != 'A'"></div>
|
|
|
<div style="width: 49%;" v-show="costTypevalue != 'A'">
|
|
|
- <div v-for="(sheetitem, index) in sheetDatal" :key="index">
|
|
|
+ <div v-for="( sheetitem, index ) in sheetDatal " :key="index">
|
|
|
<div class="biaoge"
|
|
|
v-if="CheckBoxListSelect.filter(item => item.cbType == 'Left')[0].cbValues.includes(sheetitem.label)">
|
|
|
<el-table :data="[{ a: 1 }]" border style="width: 100%"
|
|
|
:class="{ 'hiddenElement': (sheetitem.EnLabel == 'visa' || sheetitem.EnLabel == 'bx') ? true : false }">
|
|
|
- <el-table-column v-for="(itemsheetone, index) in sheetitem.childList" :key="index"
|
|
|
- :prop="itemsheetone.prop" :label="itemsheetone.childLabel">
|
|
|
+ <el-table-column v-for="( itemsheetone, index ) in sheetitem.childList "
|
|
|
+ :key="index" :prop="itemsheetone.prop" :label="itemsheetone.childLabel">
|
|
|
<template slot-scope="scope">
|
|
|
<div v-if="itemsheetone.prop.indexOf(sheetitem.EnLabel) != -1">
|
|
|
<div v-if="itemsheetone.isBind">
|
|
@@ -358,19 +389,20 @@
|
|
|
<div class="cabin-li">
|
|
|
<div style="color: #606266;font-size: 15px;font-weight: 600;">请选择要显示的项:</div>
|
|
|
<el-checkbox-group v-model="CheckBoxListSelect.filter(item => item.cbType == 'Right')[0].cbValues">
|
|
|
- <el-checkbox v-for="(item, index) in cabinoneOptions" :key="index" :label="item"></el-checkbox>
|
|
|
+ <el-checkbox v-for="( item, index ) in cabinoneOptions " :key="index"
|
|
|
+ :label="item"></el-checkbox>
|
|
|
</el-checkbox-group>
|
|
|
<div style="display: flex;">
|
|
|
<div :style="{ 'width': costTypevalue == 'A' ? '100%' : '49%' }">
|
|
|
- <div v-for="(cabinitem, index) in cabinDatal" :key="index">
|
|
|
+ <div v-for="( cabinitem, index ) in cabinDatal " :key="index">
|
|
|
<div class="biaoge"
|
|
|
v-if="CheckBoxListSelect.filter(item => item.cbType == 'Right')[0].cbValues.includes(cabinitem.label)">
|
|
|
<div style=" color: rgb(96, 98, 102);font-size: 15px;font-weight: 600;">{{
|
|
|
cabinitem.label }}
|
|
|
</div>
|
|
|
<el-table :data="cabinitem.sheetInfo" border style="width: 100%">
|
|
|
- <el-table-column v-for="(itemcabinone, index) in cabinitem.childList" :key="index"
|
|
|
- :prop="itemcabinone.prop" :label="itemcabinone.childLabel">
|
|
|
+ <el-table-column v-for="( itemcabinone, index ) in cabinitem.childList "
|
|
|
+ :key="index" :prop="itemcabinone.prop" :label="itemcabinone.childLabel">
|
|
|
<template slot-scope="scope">
|
|
|
<div v-if="itemcabinone.prop === 'toll'">
|
|
|
<el-input :ref="'el-input-' + index"
|
|
@@ -410,15 +442,15 @@
|
|
|
</div>
|
|
|
<div style="width: 2%;" v-show="costTypevalue != 'A'"></div>
|
|
|
<div style="width: 49%;" v-show="costTypevalue != 'A'">
|
|
|
- <div v-for="(cabinitem, index) in BcabinDatal" :key="index">
|
|
|
+ <div v-for="( cabinitem, index ) in BcabinDatal " :key="index">
|
|
|
<div class="biaoge"
|
|
|
v-if="CheckBoxListSelect.filter(item => item.cbType == 'Right')[0].cbValues.includes(cabinitem.label)">
|
|
|
<div style=" color: rgb(96, 98, 102);font-size: 15px;font-weight: 600;">{{
|
|
|
cabinitem.label }}
|
|
|
</div>
|
|
|
<el-table :data="cabinitem.sheetInfo" border style="width: 100%">
|
|
|
- <el-table-column v-for="(itemcabinone, index) in cabinitem.childList" :key="index"
|
|
|
- :prop="itemcabinone.prop" :label="itemcabinone.childLabel">
|
|
|
+ <el-table-column v-for="( itemcabinone, index ) in cabinitem.childList "
|
|
|
+ :key="index" :prop="itemcabinone.prop" :label="itemcabinone.childLabel">
|
|
|
<template slot-scope="scope">
|
|
|
<div v-if="itemcabinone.prop === 'toll'">
|
|
|
<el-input :ref="'el-input-' + index"
|
|
@@ -473,7 +505,7 @@
|
|
|
<el-table ref="singleTable" border @current-change="SelChange"
|
|
|
:data="filterdialogSearchInput.slice((currentPage - 1) * pageSize, currentPage * pageSize)"
|
|
|
highlight-current-row style="width: 100%">
|
|
|
- <el-table-column v-for=" item, index in SeldialogColumn" :key="index" :prop="item.prop"
|
|
|
+ <el-table-column v-for=" item, index in SeldialogColumn " :key="index" :prop="item.prop"
|
|
|
:label="item.title">
|
|
|
<template slot-scope="scope">
|
|
|
<div>
|
|
@@ -508,6 +540,7 @@
|
|
|
export default {
|
|
|
data() {
|
|
|
return {
|
|
|
+ costloading: true,
|
|
|
outerVisible: false,
|
|
|
innerVisible: false,
|
|
|
//checkList: ['DAY', 'ITIN', 'VA', 'VF', 'VRD', 'T/G S', 'DATE'], //列表默认选中
|
|
@@ -557,7 +590,7 @@ export default {
|
|
|
{ label: 'VA', width: '85', prop: 'sale', describe: '车服务区域(Vehicle Area)' }, // ??????????????
|
|
|
{ label: 'VT', width: '200', prop: 'carType', describe: '车型(VEHICLE TYPE)' },
|
|
|
{ label: 'VF', width: '150', prop: 'carCost', describe: '车费用(VEHICLE FEES)' },
|
|
|
- { label: 'VN', total: '150', prop: 'carNumber', describe: '车数量(VEHICLE Number)' },
|
|
|
+ { label: 'VN', width: '150', prop: 'carNumber', describe: '车数量(VEHICLE Number)' },
|
|
|
{ label: 'VRD', width: '150', prop: 'carTiming', describe: '用车时间(VEHICLE RENTAL DURATION)' },
|
|
|
{ label: 'T/G S', width: '150', prop: 'tgs', describe: '导游工资(TOUR GUIDE SALARY)' },
|
|
|
{ label: 'T/G N', width: '150', prop: 'tgn', describe: '导游数量(TOUR GUIDE Number' },
|
|
@@ -1980,9 +2013,44 @@ export default {
|
|
|
sumTopPrice: [],
|
|
|
DJLables: ['VF', 'T/G S', 'T/G OF', 'T/G M', 'T/G A', 'T/G TF', 'T/G EF', 'C/F M', 'C/F OF', 'B', 'L', 'D', 'EF', 'B/R/F', 'TE', 'T/G T', 'DRV T', 'T/L F'],
|
|
|
GwLables: ['T/V', 'E/C T', 'I/F', '1/L'],
|
|
|
- OtherCostProperty: ['visaCB', 'hscb', 'cpcb', 'bxcb', 'hscb', 'djcb', 'gwcb', 'lyjcb'],
|
|
|
- OtherCostPropertyBJ: ['visa', 'hs', 'cp', 'bx', 'hs', 'dj', 'gw', 'lyj'],
|
|
|
+ OtherCostProperty: ['visaCB', 'hcpcb', 'cpcb', 'bxcb', 'hscb', 'djcb', 'gwcb', 'lyjcb'],
|
|
|
+ OtherCostPropertyBJ: ['visa', 'hcp', 'cp', 'bx', 'hs', 'dj', 'gw', 'lyj'],
|
|
|
peopleNumber: 1,
|
|
|
+ centerheight: 700,
|
|
|
+ defaultheight: 50,
|
|
|
+ rules: {
|
|
|
+ rate: [
|
|
|
+ { pattern: /^-?\d+\.?\d*$/, message: '请输入正确数据', trigger: 'blur', required: true, }
|
|
|
+ ],
|
|
|
+ tax: [
|
|
|
+ { pattern: /^-?\d+\.?\d*$/, message: '请输入正确数据', trigger: 'blur', required: true, }
|
|
|
+ ],
|
|
|
+ },
|
|
|
+ HotelRules: {
|
|
|
+ sgr: [
|
|
|
+ { type: 'number', min: 0, message: '请输入整数', trigger: 'blur', required: true, },
|
|
|
+ ],
|
|
|
+ tbr: [
|
|
|
+ { type: 'number', min: 0, message: '请输入整数', trigger: 'blur', required: true, },
|
|
|
+ ],
|
|
|
+ suite: [
|
|
|
+ { type: 'number', min: 0, message: '请输入整数', trigger: 'blur', required: true, },
|
|
|
+ ],
|
|
|
+ jses: [
|
|
|
+ { type: 'number', min: 0, message: '请输入整数', trigger: 'blur', required: true, },
|
|
|
+ ],
|
|
|
+ },
|
|
|
+ CostTimeRules: {
|
|
|
+ costTypeendTime: [
|
|
|
+ { message: '请输入结束时间', trigger: 'blur', required: true, },
|
|
|
+ ],
|
|
|
+ costTypenumber: [
|
|
|
+ { type: 'number', min: 0, message: '请输入整数', trigger: 'blur', required: true, },
|
|
|
+ ],
|
|
|
+ costTypeStartTime: [
|
|
|
+ { message: '请输入开始时间', trigger: 'blur', required: true, },
|
|
|
+ ],
|
|
|
+ }
|
|
|
};
|
|
|
},
|
|
|
watch: {
|
|
@@ -1992,6 +2060,19 @@ export default {
|
|
|
// // console.log(item2)
|
|
|
// // item1为新值,item2为旧值
|
|
|
// },
|
|
|
+ 'tableData.length': {
|
|
|
+ handler(newValue, oldValue) {
|
|
|
+ if (newValue !== oldValue) {
|
|
|
+ if (this.tableData.length > 3) {
|
|
|
+ this.centerheight = 700;
|
|
|
+ } else {
|
|
|
+ this.centerheight = this.defaultheight + (this.tableData.length * 220);
|
|
|
+ }
|
|
|
+ console.log('高度' + this.centerheight);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
},
|
|
|
methods: {
|
|
|
getSummaries(param) {
|
|
@@ -2037,7 +2118,7 @@ export default {
|
|
|
prices[index] = "总计:";
|
|
|
return;
|
|
|
}
|
|
|
- if (column.label == 'DATE' || column.label == 'ITIN' || column.label == 'VT' || column.label == 'VN' || column.label == 'ACCO N' || column.label == 'VA' || column.label == 'VRD') {
|
|
|
+ if (column.label == 'DATE' || column.label == 'ITIN' || column.label == 'VT' || column.label == 'VN' || column.label == 'ACCO N' || column.label == 'VA' || column.label == 'VRD' || column.label == 'T/G N' || column.label == 'T/G WH' || column.label == '操作') {
|
|
|
prices[index] = "——";
|
|
|
return;
|
|
|
}
|
|
@@ -2053,10 +2134,10 @@ export default {
|
|
|
|
|
|
}, 0);
|
|
|
|
|
|
- if (column.label == 'SGR' || column.label == 'JS/ES' || column.label == 'SUITE' || column.label == 'TBR' || column.label == 'B' || column.label == 'L' || column.label == 'D' || column.label == 'EF' || column.label == 'TE' || column.label == 'T/G T' || column.label == 'P/C') {
|
|
|
- prices[index] = '共' + sums[index] * that.peopleNumber + ' 人均' + sums[index] + " " + this.AGroupCostParameter.currency //sums[index] + '(' + this.AGroupCostParameter.currency + ')' + ' 人均(' + sums[index] + ')';
|
|
|
+ if (column.label == 'SGR' || column.label == 'JS/ES' || column.label == 'SUITE' || column.label == 'TBR' || column.label == 'B' || column.label == 'L' || column.label == 'D' || column.label == 'EF' || column.label == 'TE' || column.label == 'T/G T' || column.label == 'P/C' || column.label == ' DRV T') {
|
|
|
+ prices[index] = '共' + (sums[index] * that.peopleNumber).toFixed(2) + ' ' + this.AGroupCostParameter.currency + '\r\n人均' + (sums[index]).toFixed(2) + " " + this.AGroupCostParameter.currency //sums[index] + '(' + this.AGroupCostParameter.currency + ')' + ' 人均(' + sums[index] + ')';
|
|
|
} else {
|
|
|
- prices[index] = '共' + sums[index] + ' 人均' + (sums[index] / that.peopleNumber).toFixed(2) + " " + this.AGroupCostParameter.currency //sums[index] + '(' + this.AGroupCostParameter.currency + ')' + ' 人均(' + sums[index] + ')';
|
|
|
+ prices[index] = '共' + sums[index].toFixed(2) + ' ' + this.AGroupCostParameter.currency + '\r\n人均' + (sums[index] / that.peopleNumber).toFixed(2) + " " + this.AGroupCostParameter.currency //sums[index] + '(' + this.AGroupCostParameter.currency + ')' + ' 人均(' + sums[index] + ')';
|
|
|
sums[index] = parseFloat((sums[index] / that.peopleNumber).toFixed(2));
|
|
|
}
|
|
|
|
|
@@ -2077,10 +2158,10 @@ export default {
|
|
|
}
|
|
|
}, 0);
|
|
|
|
|
|
- if (column.label == 'SGR' || column.label == 'JS/ES' || column.label == 'SUITE' || column.label == 'TBR' || column.label == 'B' || column.label == 'L' || column.label == 'D' || column.label == 'EF' || column.label == 'TE' || column.label == 'T/G T' || column.label == 'P/C') {
|
|
|
- prices[index] = 'A段费用' + prices[index] + '\r\n B段费用 共' + sums1[index] * that.BGroupCostParameter.costTypenumber + ' 人均' + sums1[index] + " " + this.AGroupCostParameter.currency //sums[index] + '(' + this.AGroupCostParameter.currency + ')' + ' 人均(' + sums[index] + ')';
|
|
|
+ if (column.label == 'SGR' || column.label == 'JS/ES' || column.label == 'SUITE' || column.label == 'TBR' || column.label == 'B' || column.label == 'L' || column.label == 'D' || column.label == 'EF' || column.label == 'TE' || column.label == 'T/G T' || column.label == 'P/C' || column.label == ' DRV T') {
|
|
|
+ prices[index] = 'A段费用' + prices[index] + '\r\nB段费用共' + (sums1[index] * that.BGroupCostParameter.costTypenumber).toFixed(2) + " " + this.AGroupCostParameter.currency + '\r\n人均' + sums1[index] + " " + this.AGroupCostParameter.currency //sums[index] + '(' + this.AGroupCostParameter.currency + ')' + ' 人均(' + sums[index] + ')';
|
|
|
} else {
|
|
|
- prices[index] = 'A段费用' + prices[index] + '\r\n B段费用 共' + sums1[index] + ' 人均' + (sums1[index] / that.BGroupCostParameter.costTypenumber).toFixed(2) + " " + this.AGroupCostParameter.currency //sums[index] + '(' + this.AGroupCostParameter.currency + ')' + ' 人均(' + sums[index] + ')';
|
|
|
+ prices[index] = 'A段费用' + prices[index] + '\r\nB段费用共' + sums1[index].toFixed(2) + " " + this.AGroupCostParameter.currency + '\r\n人均' + (sums1[index] / that.BGroupCostParameter.costTypenumber).toFixed(2) + " " + this.AGroupCostParameter.currency //sums[index] + '(' + this.AGroupCostParameter.currency + ')' + ' 人均(' + sums[index] + ')';
|
|
|
sums1[index] = ((sums1[index] / that.BGroupCostParameter.costTypenumber).toFixed(2));
|
|
|
}
|
|
|
|
|
@@ -2225,6 +2306,7 @@ export default {
|
|
|
)
|
|
|
},
|
|
|
loadData(id) {
|
|
|
+ this.costloading = true;
|
|
|
this.tableData = [];
|
|
|
var that = this;
|
|
|
this.$axios.post('/api/Groups/GroupCostInit', {
|
|
@@ -2631,7 +2713,9 @@ export default {
|
|
|
}]
|
|
|
}
|
|
|
}
|
|
|
+ that.costloading = false;
|
|
|
}).catch(err => {
|
|
|
+ that.costloading = false;
|
|
|
this.$message({
|
|
|
message: '网络异常!',
|
|
|
type: 'error'
|
|
@@ -2640,73 +2724,81 @@ export default {
|
|
|
|
|
|
},
|
|
|
groupChange() {
|
|
|
+ this.clearFormVerify();
|
|
|
this.loadData(this.diid);
|
|
|
},
|
|
|
- save() {
|
|
|
+ async save() {
|
|
|
var that = this;
|
|
|
var Data = { diid: this.diid, userid: this.userId };
|
|
|
- Data.checkBoxs = this.CheckBoxListSelect.map(x => {
|
|
|
- return {
|
|
|
- diid: x.diid,
|
|
|
- cbType: x.cbType,
|
|
|
- cbValues: x.cbValues.join(',')
|
|
|
- };
|
|
|
- });
|
|
|
-
|
|
|
- Data.groupCosts = this.tableData;
|
|
|
- Data.costTypeHotelNumbers = this.costTypeHotelNumbers.map(x => {
|
|
|
- return {
|
|
|
- id: x.id,
|
|
|
- sgr: x.sgr,
|
|
|
- tbr: x.tbr,
|
|
|
- jses: x.jses,
|
|
|
- suite: x.suite,
|
|
|
- type: x.type,
|
|
|
- diid: that.diid
|
|
|
- };
|
|
|
- });
|
|
|
-
|
|
|
- this.AGroupCostParameter.diId = this.diid;
|
|
|
- this.BGroupCostParameter.diId = this.diid;
|
|
|
+ var isTrue = await this.formVerify();
|
|
|
+ if (isTrue) {
|
|
|
+ Data.checkBoxs = this.CheckBoxListSelect.map(x => {
|
|
|
+ return {
|
|
|
+ diid: x.diid,
|
|
|
+ cbType: x.cbType,
|
|
|
+ cbValues: x.cbValues.join(',')
|
|
|
+ };
|
|
|
+ });
|
|
|
|
|
|
- var Aparam = Object.assign({}, this.AGroupCostParameter);
|
|
|
- var Bparam = Object.assign({}, this.BGroupCostParameter);
|
|
|
- if (that.AGroupCostParameter.costTypeStartTime) {
|
|
|
- Aparam.costTypeStartTime = this.addOneDay(that.AGroupCostParameter.costTypeStartTime, 0);
|
|
|
- }
|
|
|
- if (that.AGroupCostParameter.costTypeendTime) {
|
|
|
- Aparam.costTypeendTime = this.addOneDay(that.AGroupCostParameter.costTypeendTime, 0);
|
|
|
- }
|
|
|
- if (that.BGroupCostParameter.costTypeStartTime) {
|
|
|
- Bparam.costTypeStartTime = this.addOneDay(that.BGroupCostParameter.costTypeStartTime, 0);
|
|
|
- }
|
|
|
- if (that.BGroupCostParameter.costTypeendTime) {
|
|
|
- Bparam.costTypeendTime = this.addOneDay(that.BGroupCostParameter.costTypeendTime, 0);
|
|
|
- }
|
|
|
- if (this.costTypevalue == "A") {
|
|
|
- Data.groupCostParameters = [Aparam];
|
|
|
- } else {
|
|
|
- Data.groupCostParameters = [Aparam, Bparam];
|
|
|
- }
|
|
|
+ Data.groupCosts = this.tableData;
|
|
|
+ Data.costTypeHotelNumbers = this.costTypeHotelNumbers.map(x => {
|
|
|
+ return {
|
|
|
+ id: x.id,
|
|
|
+ sgr: x.sgr,
|
|
|
+ tbr: x.tbr,
|
|
|
+ jses: x.jses,
|
|
|
+ suite: x.suite,
|
|
|
+ type: x.type,
|
|
|
+ diid: that.diid
|
|
|
+ };
|
|
|
+ });
|
|
|
|
|
|
- console.log(Data, "save-------Data");
|
|
|
+ this.AGroupCostParameter.diId = this.diid;
|
|
|
+ this.BGroupCostParameter.diId = this.diid;
|
|
|
|
|
|
- var that = this;
|
|
|
- this.$axios.post('/api/Groups/SaveGroupCost', Data, {
|
|
|
- headers: {
|
|
|
- 'Authorization': that.token,
|
|
|
+ var Aparam = Object.assign({}, this.AGroupCostParameter);
|
|
|
+ var Bparam = Object.assign({}, this.BGroupCostParameter);
|
|
|
+ if (that.AGroupCostParameter.costTypeStartTime) {
|
|
|
+ Aparam.costTypeStartTime = this.addOneDay(that.AGroupCostParameter.costTypeStartTime, 0);
|
|
|
}
|
|
|
- }).then(resp => {
|
|
|
- console.log(resp.data.data, '------------------------------------');
|
|
|
- if (resp.data.code == 200) {
|
|
|
- this.$message({
|
|
|
- message: '保存成功!',
|
|
|
- type: 'success'
|
|
|
- });
|
|
|
+ if (that.AGroupCostParameter.costTypeendTime) {
|
|
|
+ Aparam.costTypeendTime = this.addOneDay(that.AGroupCostParameter.costTypeendTime, 0);
|
|
|
+ }
|
|
|
+ if (that.BGroupCostParameter.costTypeStartTime) {
|
|
|
+ Bparam.costTypeStartTime = this.addOneDay(that.BGroupCostParameter.costTypeStartTime, 0);
|
|
|
+ }
|
|
|
+ if (that.BGroupCostParameter.costTypeendTime) {
|
|
|
+ Bparam.costTypeendTime = this.addOneDay(that.BGroupCostParameter.costTypeendTime, 0);
|
|
|
+ }
|
|
|
+ if (this.costTypevalue == "A") {
|
|
|
+ Data.groupCostParameters = [Aparam];
|
|
|
} else {
|
|
|
- this.$message.error('保存失败!' + resp.data.msg);
|
|
|
+ Data.groupCostParameters = [Aparam, Bparam];
|
|
|
}
|
|
|
- })
|
|
|
+
|
|
|
+ console.log(Data, "save-------Data");
|
|
|
+
|
|
|
+ var that = this;
|
|
|
+ this.$axios.post('/api/Groups/SaveGroupCost', Data, {
|
|
|
+ headers: {
|
|
|
+ 'Authorization': that.token,
|
|
|
+ }
|
|
|
+ }).then(resp => {
|
|
|
+ console.log(resp.data.data, '------------------------------------');
|
|
|
+ if (resp.data.code == 200) {
|
|
|
+ this.$message({
|
|
|
+ message: '保存成功!',
|
|
|
+ type: 'success'
|
|
|
+ });
|
|
|
+ } else {
|
|
|
+ this.$message.error('保存失败!' + resp.data.msg);
|
|
|
+ }
|
|
|
+ })
|
|
|
+
|
|
|
+ } else {
|
|
|
+ this.$message.error('请输入完整!');
|
|
|
+ }
|
|
|
+
|
|
|
},
|
|
|
TopChange() {
|
|
|
},
|
|
@@ -3344,6 +3436,131 @@ export default {
|
|
|
day = day < 10 ? '0' + day : day;
|
|
|
return `${year}-${month}-${day}`;
|
|
|
},
|
|
|
+ costTypeSelect(val) {
|
|
|
+ console.log('costTypeSelect--------------------------------------------------------', val);
|
|
|
+ },
|
|
|
+ async formVerify() {
|
|
|
+ return new Promise((resolve, reject) => {
|
|
|
+
|
|
|
+ var forFormList = [];
|
|
|
+ if (this.costTypevalue == 'A') {
|
|
|
+ forFormList = ['inputs', 'DHotel'];
|
|
|
+ } else {
|
|
|
+ forFormList = ['inputs', 'AHotel', 'Asection', 'BHotel', 'Bsection'];
|
|
|
+ }
|
|
|
+
|
|
|
+ var that = this;
|
|
|
+ for (var i = 0; i < forFormList.length; i++) {
|
|
|
+ that.$refs[forFormList[i]].validate((valid) => {
|
|
|
+ if (valid) {
|
|
|
+
|
|
|
+ } else {
|
|
|
+ resolve(valid);
|
|
|
+ }
|
|
|
+ });
|
|
|
+ }
|
|
|
+ resolve(true);
|
|
|
+ })
|
|
|
+ },
|
|
|
+ clearFormVerify() {
|
|
|
+ var forFormList = ['inputs', 'AHotel', 'Asection', 'BHotel', 'Bsection', 'DHotel'];
|
|
|
+ this.$nextTick(() => {
|
|
|
+ for (var i = 0; i < forFormList.length; i++) {
|
|
|
+ this.$refs[forFormList[i]].resetFields();
|
|
|
+ }
|
|
|
+ })
|
|
|
+ },
|
|
|
+ topcheckboxChange(val, label) {
|
|
|
+ console.log(val, label, 'topcheckboxChangeval');
|
|
|
+ var that = this;
|
|
|
+ if (!val) {
|
|
|
+ this.$confirm('此操作将清空整列数据, 是否继续?', '提示', {
|
|
|
+ confirmButtonText: '确定',
|
|
|
+ cancelButtonText: '取消',
|
|
|
+ type: 'warning'
|
|
|
+ }).then(() => {
|
|
|
+
|
|
|
+ console.log('确定清空数据');
|
|
|
+ var fliterList = this.sumTopPrice.filter(x => x.label == label);
|
|
|
+ if (fliterList.length != 0) {
|
|
|
+ fliterList[0].Aprice = 0;
|
|
|
+ fliterList[0].Bprice = 0;
|
|
|
+ }
|
|
|
+
|
|
|
+ fliterList = that.tableLabel.filter(x => x.label == label);
|
|
|
+ if (fliterList.length != 0) {
|
|
|
+ var obj = {
|
|
|
+ "diid": that.diid,
|
|
|
+ "day": "-",
|
|
|
+ "date": "",
|
|
|
+ "itin": "",
|
|
|
+ "carType": "",
|
|
|
+ "carCost": 0,
|
|
|
+ "carNumber": 0,
|
|
|
+ "carTiming": 0,
|
|
|
+ "tgs": 0,
|
|
|
+ "tgwh": 0,
|
|
|
+ "tgn": 0,
|
|
|
+ "tgof": 0,
|
|
|
+ "tgm": 0,
|
|
|
+ "tga": 0,
|
|
|
+ "tgtf": 0,
|
|
|
+ "tgef": 0,
|
|
|
+ "cfs": 0,
|
|
|
+ "cfm": 0,
|
|
|
+ "cfof": 0,
|
|
|
+ "b": 0,
|
|
|
+ "l": 0,
|
|
|
+ "d": 0,
|
|
|
+ "tbr": 0,
|
|
|
+ "sgr": 0,
|
|
|
+ "jS_ES": 0,
|
|
|
+ "suite": 0,
|
|
|
+ "accon": "",
|
|
|
+ "tv": 0,
|
|
|
+ "iL": 0,
|
|
|
+ "if": 0,
|
|
|
+ "ef": 0,
|
|
|
+ "b_R_F": 0,
|
|
|
+ "te": 0,
|
|
|
+ "tgTips": 0,
|
|
|
+ "drvTips": 0,
|
|
|
+ "pc": 0,
|
|
|
+ "tlf": 0,
|
|
|
+ "ect": 0,
|
|
|
+ "id": 1,
|
|
|
+ };
|
|
|
+ var prop = fliterList[0].prop;
|
|
|
+ var initval = obj[prop];
|
|
|
+
|
|
|
+ for (var i = 0; i < that.tableData.length; i++) {
|
|
|
+ that.tableData[i][prop] = initval;
|
|
|
+ }
|
|
|
+ console.log(that.tableData, 'that.tableData数据');
|
|
|
+ }
|
|
|
+
|
|
|
+ this.$message({
|
|
|
+ message: '已清除!',
|
|
|
+ type: 'success',
|
|
|
+ offset: 50
|
|
|
+ });
|
|
|
+
|
|
|
+ }).catch(() => {
|
|
|
+ this.$message({
|
|
|
+ type: 'info',
|
|
|
+ message: '已取消操作'
|
|
|
+ });
|
|
|
+
|
|
|
+ if (!that.CheckBoxListSelect.filter(item => item.cbType == 'Top')[0].cbValues.includes(label)) {
|
|
|
+ that.CheckBoxListSelect.filter(item => item.cbType == 'Top')[0].cbValues.push(label);
|
|
|
+ }
|
|
|
+
|
|
|
+ });
|
|
|
+ }
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
},
|
|
|
mounted() {
|
|
|
this.token = JSON.parse(localStorage.getItem('userinif')).token;
|
|
@@ -3361,6 +3578,13 @@ export default {
|
|
|
return x.city.indexOf(that.dialogSearchInput) != -1 || x.country.indexOf(that.dialogSearchInput) != -1;
|
|
|
})
|
|
|
},
|
|
|
+ columnWidth() {
|
|
|
+ if (this.CheckBoxListSelect.filter(item => item.cbType == 'Top')[0].cbValues.length < 9) {
|
|
|
+ return ''
|
|
|
+ } else {
|
|
|
+ return 150
|
|
|
+ }
|
|
|
+ }
|
|
|
}
|
|
|
}
|
|
|
</script>
|
|
@@ -3462,8 +3686,12 @@ export default {
|
|
|
margin-left: 0;
|
|
|
}
|
|
|
|
|
|
+.CostBShow .el-col-3 .el-form-item__content {
|
|
|
+ width: 60%;
|
|
|
+}
|
|
|
+
|
|
|
.CostBShow .el-form-item__content {
|
|
|
- width: 62%;
|
|
|
+ width: 60%;
|
|
|
}
|
|
|
|
|
|
.CostBShow .el-date-editor--date {
|
|
@@ -3477,5 +3705,10 @@ export default {
|
|
|
.hiddenElement {
|
|
|
visibility: hidden;
|
|
|
|
|
|
+}
|
|
|
+
|
|
|
+.cost-all .el-table__footer-wrapper .cell {
|
|
|
+ white-space: pre;
|
|
|
+
|
|
|
}
|
|
|
</style>
|