Commit a91d656f authored by 黄奎's avatar 黄奎

新增团队修改,是否拆分团队

parent 4147fe27
......@@ -685,7 +685,8 @@
<p class="travelnowrap">
<span>{{ $t("Airticket.Air_StartTime") }}</span>
<span class="go_date">{{ item.StartDate }}(<font style="color:red;font-weight:bold;">
{{item.StartDateWeekStr}}</font>)</span>
{{item.StartDateWeekStr}}</font>)
</span>
<template v-if="item.RelationPriceList && item.RelationPriceList.length > 0">
<el-tooltip class="item" effect="dark" :content="$t('objFill.xilietdate')">
<el-popover width="350" trigger="click" popper-class="TC_HotelPop">
......@@ -712,6 +713,32 @@
</el-popover>
</el-tooltip>
</template>
<!-- <template v-if="item.TeamPriceList && item.TeamPriceList.length > 0">
<el-tooltip class="item" effect="dark" content="合并列表">
<el-popover width="350" trigger="click" popper-class="TC_HotelPop">
<table width="100%" border="0" cellspacing="0" cellpadding="0">
<tr>
<td style="width: 100px">
{{ $t("Airticket.Air_StartTime") }}
</td>
<td style="width: 250px">{{ $t("visa.v_tuanhao") }}</td>
</tr>
<tr v-for="(rItem, rIndex) in item.TeamPriceList" :key="`d_`+index+`_t_`+rIndex">
<td>
{{ rItem.StartDate }}
</td>
<td>
({{ rItem.TCID }}){{ rItem.TCNUM }}[{{ rItem.TCState }}]
</td>
</tr>
</table>
<el-button slot="reference" circle size="mini" type="primary"
style="width: 20px; height: 20px; padding: 4px" style="">
{{ item.TeamPriceList.length }}
</el-button>
</el-popover>
</el-tooltip>
</template> -->
</p>
<p class="travelnowrap flex" v-if="item.OfferShouPeiFee > 0">
<span>{{ $t("objFill.handpartscharge") }}</span>
......@@ -1895,7 +1922,8 @@
<el-col :span="4">
<el-form-item :label="$t('objFill.tuanduilx')" prop="Remark">
<el-select class="multiple_input" v-model="changePriceMsg.NewB2BPrice">
<el-option v-for='item in teamList' v-if="item.ID!=2" :key="item.ID" :label="item.Name" :value="item.ID">
<el-option v-for='item in teamList' v-if="item.ID!=2" :key="item.ID" :label="item.Name"
:value="item.ID">
</el-option>
</el-select>
</el-form-item>
......
<style>
.commChooseTrip .webSliderDiv {
width: 370px;
line-height: 0;
height: 244px;
border: 1px solid #ccc;
position: relative;
}
.commChooseTrip .webSliderDiv .web_imgUrl {
width: 100%;
height: 100%;
}
.commChooseTrip .webSliderDiv .el-upload {
width: 100%;
height: 100%;
}
.commChooseTrip .webSliderDiv .addIconDiv {
position: absolute;
width: 100%;
height: 100%;
top: 0;
background-color: transparent;
display: flex;
align-items: center;
justify-content: center;
}
.commChooseTrip .webSliderDiv>div {
height: 100%;
}
.commChooseTrip .myWebDiv {
width: 175px !important;
overflow: hidden;
}
.commChooseTrip .webImg_radius {
width: 310px !important;
height: 310px !important;
border-radius: 50%;
overflow: hidden;
border: 0 !important;
}
.b2b_imgList {
width: 100%;
min-height: 233px;
background-color: #f1f1f1;
position: relative;
}
.commChooseTrip .sectionImg {
position: absolute;
width: 100%;
height: 100%;
background-position: center;
background-size: cover;
}
.commChooseTrip .title {
word-wrap: break-word;
word-break: normal;
color: #333;
}
.commChooseTrip .table-striped {
width: 100%;
border-spacing: 0;
border-collapse: collapse;
}
.table-striped tbody {
border-bottom: 1px solid #000;
}
.commChooseTrip .table-striped th,
.commChooseTrip .table-striped td {
padding: 8px;
text-align: center;
}
.commChooseTrip .table-striped>tr:nth-of-type(odd) {
background-color: #f9f9f9;
}
</style>
<template>
<div class="commChooseTrip">
<el-form>
<el-row>
<el-col :span="6">
<el-form-item :label="$t('system.table_ssLine')" label-width="115px;">
<el-select class="w150" v-model="queryMsg.LineId" filterable :placeholder="$t('pub.pleaseSel')"
@change="getLinePlaceList()">
<el-option :label="$t('pub.unlimitedSel')" :value="0"></el-option>
<el-option v-for="item in queryCommonData.LineList" :label="item.LineName" :value="item.LineID"
:key="item.LineID"></el-option>
</el-select>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item :label="$t('system.query_dest')" label-width="115px;">
<el-select class="w150" v-model="queryMsg.PlaceID" filterable :placeholder="$t('pub.pleaseSel')"
@change="getLineTeamList()">
<el-option :label="$t('pub.unlimitedSel')" :value="0"></el-option>
<el-option v-for="item in queryCommonData.PlaceList" :label="item.PlaceName" :value="item.PlaceID"
:key="item.LtID"></el-option>
</el-select>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item :label="$t('active.ad_xlmc')" label-width="115px;">
<el-select class="w150" v-model="queryMsg.LineteamId" filterable :placeholder="$t('pub.pleaseSel')">
<el-option :label="$t('pub.unlimitedSel')" :value="0"></el-option>
<el-option v-for="item in queryCommonData.LineTeamList" :label="item.LtName" :value="item.LtID"
:key="item.LtID"></el-option>
</el-select>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item :label="$t('visa.v_tuanhao')" label-width="115px;">
<el-input maxlength="50" v-model="queryMsg.TCNUM" class="w150" :placeholder="$t('pub.pleaseImport')">
</el-input>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item :label="$t('Operation.Op_TeamName')" label-width="115px;">
<el-input maxlength="50" v-model="queryMsg.Title" class="w150" :placeholder="$t('pub.pleaseImport')">
</el-input>
</el-form-item>
</el-col>
<el-col :span="10">
<el-form-item :label="$t('scen.sc_ftTime')" label-width="115px;">
<DateLimit :clearable="false" :StartGroupDate="queryMsg.StartGroupDate"
:EndGroupDate="queryMsg.EndGroupDate" @change="(date) => (queryMsg.StartGroupDate = date)"></DateLimit>
<el-date-picker class="w150" type="date" v-model="queryMsg.EndGroupDate"
:picker-options="pickerBeginDateAfter" value-format="yyyy-MM-dd" placeholder></el-date-picker>
</el-form-item>
</el-col>
<el-col :span="8">
<!--出团类型-->
<el-form-item :label="$t('objFill.v101.chutuanleix')" label-width="115px;">
<el-select class="w150" v-model="queryMsg.QTeamType">
<el-option v-for="item in teamList" :key="item.ID" :label="item.Name" :value="item.ID">
</el-option>
</el-select>
<input type="button" class="hollowFixedBtn" @click="resetPageIndex(), GetList()"
:value="$t('pub.searchBtn')" />
</el-form-item>
</el-col>
</el-row>
</el-form>
<table style="width: 100%" class="table-striped" v-loading="queryMsg.loading">
<tr>
<th width="50">
{{ $t("fnc.xuanze") }}
</th>
<th>
{{ $t("objFill.v101.chufari") }}
</th>
<th colspan="2">
{{ $t("visa.v_tuanhao") }}
</th>
<th>
{{ $t("ground.tianshu") }}
</th>
<th>
{{$t('Operation.Op_directPrice')}}
</th>
<th>
{{ $t("objFill.v101.tuanweizku") }}
</th>
</tr>
<tbody v-for="(item, index) in dataList" :key="index">
<tr>
<td rowspan="2">
<el-checkbox v-model="item.Checked" @change="changeTrip(item)"></el-checkbox>
</td>
<td>
{{ item.StartDate }}
</td>
<td colspan="2">{{ item.TCNUM }}({{ item.TCID }})</td>
<td>
{{ item.DayNum }}
</td>
<td>
{{ item.B2CPrice }}
</td>
<td>
{{
item.FSeat +
item.CSeat +
item.YSeat -
(item.SurplusFSeat + item.SurplusCSeat + item.SurplusYSeat)
}}
</td>
</tr>
<tr>
<td colspan="6" style="text-align: left">
<span class="title">
{{ item.Title }}
</span>
</td>
</tr>
</tbody>
<tfoot>
<tr>
<td colspan="7">
<div class="noData" v-show="queryMsg.noData">
{{ $t("system.content_noData") }}
</div>
<el-pagination background @current-change="handleCurrentChange" :current-page.sync="queryMsg.currentPage"
layout="total,prev, pager, next, jumper" :page-size="queryMsg.pageSize" :total="queryMsg.total">
</el-pagination>
</td>
</tr>
</tfoot>
</table>
</div>
</template>
<script>
import DateLimit from "../public/DateLimit.vue";
export default {
components: {
DateLimit,
},
props: ["IsMultiple"],
data() {
return {
queryMsg: {
AirTicketId: 0,
ApplyMaxNum: -1,
ApplyMinNum: -1,
CreateBy: 0,
DayNum: -1,
EndGroupDate: "",
FlightState: 0,
GroupState: [],
HotelId: 0,
HotelUseTime: "",
IsShowUnion: 0,
IsWarning: false,
LineId: 0,
LineIdList: [],
LineteamId: 0,
OnlyShowOverTeam: "false",
OutBranchId: -1,
OutBranchIds: [],
PlaceID: 0,
RateOn: "-1",
RateOnDay: "-1",
SaleBranchId: [],
SalePlat: [],
StartGroupDate: "",
TCID: 0,
TCNUM: "",
TCState: [3],
TeamMaxNum: -1,
TeamMinNum: -1,
TeamType: 0,
UnionCityId: 0,
WarningQuery: "-1",
pageIndex: 1,
pageSize: 10,
currentPage: 1,
total: 0,
noData: true,
loading: false,
QTeamType: 0,
},
queryCommonData: {
LineList: [],
PlaceList: [],
LineTeamList: [],
},
teamList: [], //团队类型列表
dataList: [], //列表数据
pickerBeginDateAfter: {
disabledDate: (time) => {
let startTime = new Date(this.queryMsg.StartGroupDate);
return startTime.getTime() >= time.getTime();
},
},
};
},
created() {
var myDate = new Date();
var nowDate =
myDate.getFullYear() +
"-" +
parseInt(myDate.getMonth() + 1) +
"-" +
myDate.getDate();
this.queryMsg.StartGroupDate = nowDate;
},
methods: {
//选中切换
changeTrip(item) {
//单选
if (!this.IsMultiple) {
this.dataList.forEach((x) => {
if (x.TCID == item.TCID) {
//item.Checked = !item.Checked;
} else {
x.Checked = false;
}
});
}
},
//获取线路列表
getLineList() {
this.apipost(
"line_post_GetList", {
LineDirection: 2,
},
(res) => {
if (res.data.resultCode == 1) {
this.queryCommonData.LineList = res.data.data;
this.queryCommonData.PlaceList = [];
this.queryCommonData.LineTeamList = [];
}
}
);
},
//获取目的地列表
getLinePlaceList() {
this.queryMsg.PlaceID = 0;
this.queryMsg.LineteamId = 0;
let msg = {
lineID: this.queryMsg.LineId,
};
this.apipost("team_post_GetLinePlace", msg, (res) => {
if (res.data.resultCode == 1) {
this.queryCommonData.PlaceList = res.data.data;
this.queryCommonData.LineTeamList = [];
}
});
},
//获取系列列表
getLineTeamList() {
this.queryMsg.LineteamId = 0;
let msg = {
lineID: this.queryMsg.LineId,
placeID: this.queryMsg.PlaceID,
isTOOP: 1,
};
this.apipost("team_post_GetList", msg, (res) => {
if (res.data.resultCode == 1) {
this.queryCommonData.LineTeamList = res.data.data;
}
});
},
//翻页
handleCurrentChange(val) {
this.queryMsg.pageIndex = val;
this.GetList();
},
//重新查询
resetPageIndex() {
this.queryMsg.pageIndex = 1;
this.queryMsg.currentPage = 1;
},
GetList() {
this.queryMsg.loading = true;
this.apipost(
"travel_get_GetTravelPrciePageList_V2",
this.queryMsg,
(res) => {
this.queryMsg.loading = false;
if (res.data.resultCode == 1) {
var tempArray = res.data.data.pageData;
this.queryMsg.total = res.data.data.count;
this.queryMsg.noData = !this.queryMsg.total > 0;
if (tempArray && tempArray.length > 0) {
tempArray.forEach((item) => {
item.Checked = false;
});
}
this.dataList = tempArray;
} else {
this.Error(res.data.message);
}
},
(err) => {}
);
},
//获取选中的行程
getChooseData() {
var tempArray = [];
this.dataList.forEach((item) => {
if (item.Checked) {
tempArray.push(item);
}
});
return tempArray;
},
//清空数据
clearData() {
// this.dataList=[];
// this.queryMsg.pageIndex=1;
// this.queryMsg.total=0;
},
//团队类型
getTeamList() {
this.apipost("travel_GetTeamTypeEnumList", {}, (res) => {
if (res.data.resultCode == 1) {
this.teamList = res.data.data;
}
});
},
},
mounted() {
this.getTeamList();
this.getLineList();
},
};
</script>
......@@ -122,7 +122,7 @@
@click="submitForm(2)">
{{$t('fnc.tijiao')}}</div>
<div v-if="modifyType==2" class="DTSaveBtn" :class="{'disClick':!isSubmit}" :loading="saveLoading"
@click="submitForm(3)" :title="$t('objFill.v101.myOrdersAllType.lingcwxmb')">{{$t('pub.saveBtn')}}
@click="submitForm(3)" >{{$t('pub.saveBtn')}}
</div>
<div style="display:none;" v-if="ConfigId>0" class="DTSaveBtn" :class="{'disClick':!isSubmit}" @click="goB2B()">
{{$t('sm.yulan')}}
......@@ -231,6 +231,7 @@
NotQueryCityList: [], //使用系统中的经纬度城市
FeaturePageType: 0, //1横版 2竖版
TeamType: 0,
IsSplitTeam:0,//当团修改是否拆分团队(1-拆分)
},
//行程
FeatureData: {
......@@ -565,7 +566,8 @@
}
basicData.IsUpdateHotel = this.PostConfig.IsUpdateHotel;
basicData.MapUrl = this.PostConfig.MapUrl
basicData.MapUrl = this.PostConfig.MapUrl;
basicData.IsSplitTeam=this.PostConfig.IsSplitTeam;
console.log("travel_post_SetTravelConfigInfo", basicData);
this.isSubmit = false;
this.apipost(
......
......@@ -18,6 +18,7 @@
.TP_rightDate {
margin-left: 50px;
padding-bottom: 10px;
}
.TPDateContent .currentInput {
......@@ -419,21 +420,39 @@
</div>
<div class="TP_rightDate">
<div class="TP_dateContent">
<span class="TP_toLeft" @click="priceLeftMove">
<i class="iconfont icon-previewleft"></i>
</span>
<div class="TP_childContent">
<span class="TP_tips" :class="{'ckedSpan':item.Checked}" @click="getDateInfo(item)"
v-for="(item,index) in showPriceList" :key="index">
{{item.StartDate}}
<span class="TP_cancel" @click.stop="delDateList(item)">
<i class="iconfont icon-quxiao"></i>
<el-row v-if="modifyTcid>0">
<el-col>
<el-tooltip class="item" effect="dark" content="勾选此项将会调整为独立团期" placement="top-start">
<el-checkbox v-model="PostConfig.IsSplitTeam" :true-label="CheckedVaule"
:false-label="UnCheckedLessPrice">
<font style="color:red;font-weight:bold;">拆分团队</font>
</el-checkbox>
</el-tooltip>
</el-col>
</el-row>
<el-row>
<el-col>
<span class="TP_toLeft" @click="priceLeftMove">
<i class="iconfont icon-previewleft"></i>
</span>
</span>
</div>
<span class="TP_Right" @click="priceRightMove">
<i class="iconfont icon-arrow-right"></i>
</span>
</el-col>
<el-col>
<div class="TP_childContent">
<span class="TP_tips" :class="{'ckedSpan':item.Checked}" @click="getDateInfo(item)"
v-for="(item,index) in showPriceList" :key="index">
{{item.StartDate}}
<span class="TP_cancel" @click.stop="delDateList(item)">
<i class="iconfont icon-quxiao"></i>
</span>
</span>
</div>
</el-col>
<el-col>
<span class="TP_Right" @click="priceRightMove">
<i class="iconfont icon-arrow-right"></i>
</span>
</el-col>
</el-row>
</div>
<div class="TP_DateList"></div>
</div>
......@@ -868,7 +887,7 @@
{{$t('system.query_flightNum')}}/{{$t('system.query_airCompanyName')}}/{{$t('Airticket.Air_segment')}}
</td>
<td class="_color_666">{{$t('adm.adm_time')}}/PNR</td>
<td class="_color_666">{{$t('visa.v_xcdays')}}</td>
<td class="_color_666">{{$t('op.TicketNum')}}/{{$t('hotel.table_UseAmount')}}</td>
<td class="_color_666">{{$t('op.BindTicket')}}</td>
......@@ -886,7 +905,7 @@
{{fitem.AlName}} / {{fitem.DepartureName}}-{{fitem.ArrivalCityName}}
</td>
<td>{{fitem.FlightDate}} {{fitem.Departure_time}}
<br/>
<br />
{{fitem.PNR}}
</td>
<td>{{fitem.DayNum}}</td>
......
......@@ -416,23 +416,41 @@
<span class="TPNotice">{{$t('sm.tipscompanyyuj')}}</span>
<span class="TPLine"></span>
</div>
<div class="TP_rightDate">
<div class="TP_rightDate">
<div class="TP_dateContent">
<span class="TP_toLeft" @click="priceLeftMove">
<i class="iconfont icon-previewleft"></i>
</span>
<div class="TP_childContent">
<span class="TP_tips" :class="{'ckedSpan':item.Checked}" @click="getDateInfo(item)"
v-for="(item,index) in showPriceList" :key="index">
{{item.StartDate}}
<span class="TP_cancel" @click.stop="delDateList(item)">
<i class="iconfont icon-quxiao"></i>
<el-row v-if="modifyTcid>0">
<el-col>
<el-tooltip class="item" effect="dark" content="勾选此项将会调整为独立团期" placement="top-start">
<el-checkbox v-model="PostConfig.IsSplitTeam" :true-label="CheckedVaule"
:false-label="UnCheckedLessPrice">
<font style="color:red;font-weight:bold;">拆分团队</font>
</el-checkbox>
</el-tooltip>
</el-col>
</el-row>
<el-row>
<el-col>
<span class="TP_toLeft" @click="priceLeftMove">
<i class="iconfont icon-previewleft"></i>
</span>
</span>
</div>
<span class="TP_Right" @click="priceRightMove">
<i class="iconfont icon-arrow-right"></i>
</span>
</el-col>
<el-col>
<div class="TP_childContent">
<span class="TP_tips" :class="{'ckedSpan':item.Checked}" @click="getDateInfo(item)"
v-for="(item,index) in showPriceList" :key="index">
{{item.StartDate}}
<span class="TP_cancel" @click.stop="delDateList(item)">
<i class="iconfont icon-quxiao"></i>
</span>
</span>
</div>
</el-col>
<el-col>
<span class="TP_Right" @click="priceRightMove">
<i class="iconfont icon-arrow-right"></i>
</span>
</el-col>
</el-row>
</div>
<div class="TP_DateList"></div>
</div>
......
......@@ -404,21 +404,39 @@
</div>
<div class="TP_rightDate">
<div class="TP_dateContent">
<span class="TP_toLeft" @click="priceLeftMove">
<i class="iconfont icon-previewleft"></i>
</span>
<div class="TP_childContent">
<span class="TP_tips" :class="{'ckedSpan':item.Checked}" @click="getDateInfo(item)"
v-for="(item,index) in showPriceList" :key="index">
{{item.StartDate}}
<span class="TP_cancel" @click.stop="delDateList(item)">
<i class="iconfont icon-quxiao"></i>
<el-row v-if="modifyTcid>0">
<el-col>
<el-tooltip class="item" effect="dark" content="勾选此项将会调整为独立团期" placement="top-start">
<el-checkbox v-model="PostConfig.IsSplitTeam" :true-label="CheckedVaule"
:false-label="UnCheckedLessPrice">
<font style="color:red;font-weight:bold;">拆分团队</font>
</el-checkbox>
</el-tooltip>
</el-col>
</el-row>
<el-row>
<el-col>
<span class="TP_toLeft" @click="priceLeftMove">
<i class="iconfont icon-previewleft"></i>
</span>
</span>
</div>
<span class="TP_Right" @click="priceRightMove">
<i class="iconfont icon-arrow-right"></i>
</span>
</el-col>
<el-col>
<div class="TP_childContent">
<span class="TP_tips" :class="{'ckedSpan':item.Checked}" @click="getDateInfo(item)"
v-for="(item,index) in showPriceList" :key="index">
{{item.StartDate}}
<span class="TP_cancel" @click.stop="delDateList(item)">
<i class="iconfont icon-quxiao"></i>
</span>
</span>
</div>
</el-col>
<el-col>
<span class="TP_Right" @click="priceRightMove">
<i class="iconfont icon-arrow-right"></i>
</span>
</el-col>
</el-row>
</div>
<div class="TP_DateList"></div>
</div>
......@@ -1187,7 +1205,7 @@
IsNeedAirportShuttle: 0, //是否需要接送服务
GuideNum: 0, //导游人数
IsNewArrival: 0, //是否新品
TeamId:0,//团队分组编号
TeamId: 0, //团队分组编号
};
}
this.returnPriceList.push(objItem);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment