Commit b5380156 authored by 罗超's avatar 罗超

1

parent f2de6bc5
...@@ -535,6 +535,9 @@ input:-webkit-autofill { ...@@ -535,6 +535,9 @@ input:-webkit-autofill {
.w780 { .w780 {
width: 780px!important; width: 780px!important;
} }
.w1000 {
width: 1000px!important;
}
.w50 { .w50 {
width: 50px !important; width: 50px !important;
......
<style> <style>
@import "../../assets/css/advert/advmanager"; @import "../../assets/css/advert/advmanager";
</style> </style>
<template> <template>
<div class="advmanager-box"> <div class="advmanager-box">
<div class="content" style="top: 50px">
<div class="content" style="top:50px;"> <!-- <ul>
<!-- <ul>
<li v-for='item in addatas' :key="item.id"> <li v-for='item in addatas' :key="item.id">
<div class="img-box"> <div class="img-box">
<img :src="item.advertisingPicUrlStr" /> <img :src="item.advertisingPicUrlStr" />
...@@ -18,139 +17,189 @@ ...@@ -18,139 +17,189 @@
</div> </div>
</li> </li>
</ul> --> </ul> -->
<vueWaterfallEasy v-if='addatas.length!=0' ref="waterfall" :imgsArr="addatas" @scrollReachBottom="handleCurrentChange" :maxCols='7' :imgWidth='208' :enablePullDownEvent='true'> <vueWaterfallEasy
<template slot-scope="props"> v-if="addatas.length != 0"
<span class="free"><i class="el-icon-share"></i> 0</span> ref="waterfall"
<div class="zezhao"> :imgsArr="addatas"
<a :href='`/#/advert?id=${props.value.id}`'><i class="el-icon-edit" title="修改"></i></a> @scrollReachBottom="handleCurrentChange"
<a :href='props.value.advertisingPicUrlStr' download="广告图.png"><i class="el-icon-download" title="下载"></i></a> :maxCols="7"
<i class="el-icon-delete" title="删除" @click="deleteItem(props.value)"></i> :imgWidth="208"
</div> :enablePullDownEvent="true"
</template> >
</vueWaterfallEasy> <template slot-scope="props">
<span class="free"><i class="el-icon-share"></i> 0</span>
<div class="zezhao">
<a :href="`/#/advert?id=${props.value.id}`"
><i class="el-icon-edit" title="修改"></i
></a>
<a :href="props.value.advertisingPicUrlStr" download="广告图.png"
><i class="el-icon-download" title="下载"></i
></a>
<i
class="el-icon-delete"
title="删除"
@click="deleteItem(props.value)"
></i>
</div>
</template>
</vueWaterfallEasy>
<div v-if='addatas.length==0' style='width:100%;margin-top:50px;text-align:center;color: #ccc;'> <div
<i class="iconfont icon-kong" style="font-size: 120px;"></i><br/> v-if="addatas.length == 0"
还没有广告哦,<a href='/#/advert' style="color:rgb(0, 129, 255)">立即制作</a> style="width: 100%; margin-top: 50px; text-align: center; color: #ccc"
</div> >
</div> <i class="iconfont icon-kong" style="font-size: 120px"></i><br />
还没有广告哦,<a href="/#/advert" style="color: rgb(0, 129, 255)"
>立即制作</a
>
</div>
</div> </div>
</div>
</template> </template>
<script> <script>
import vueWaterfallEasy from 'vue-waterfall-easy' import vueWaterfallEasy from "vue-waterfall-easy";
export default { export default {
data(){ data() {
return{ return {
lines:[], lines: [],
teams:[], teams: [],
modelTeams:[], modelTeams: [],
countrys:[], countrys: [],
addatas:[], addatas: [],
pageIndex:0, pageIndex: 0,
pageSize:15, pageSize: 15,
total:0, total: 0,
msg:{ msg: {
lineId:'0', lineId: "0",
teamId:'0', teamId: "0",
countryId:'0', countryId: "0",
type:'0' type: "0",
}, },
user:{}, user: {},
model:{}, model: {},
isAdd:false, isAdd: false,
uploadType:0, uploadType: 0,
} };
}, },
components: { components: {
vueWaterfallEasy vueWaterfallEasy,
},
mounted() {
this.user = JSON.parse(window.localStorage.userInfo);
this.getline();
this.getcountry();
this.getaddatas(0);
},
methods: {
deleteItem(x) {
this.apipost(
"Advertising_post_Remove",
{ ID: x.id },
(x) => {
if (x.data.resultCode == 1) {
this.$message.success("删除成功");
this.getaddatas(0);
} else {
this.$message.error(x.data.message);
}
},
(err) => {}
);
}, },
mounted(){
this.user=JSON.parse(window.localStorage.userInfo) handleCurrentChange(val) {
this.getline() this.pageIndex++;
this.getcountry() this.getaddatas(1);
this.getaddatas(0)
}, },
methods:{ getaddatas(type) {
deleteItem(x){ if (type == 0) {
this.apipost("Advertising_post_Remove", {'ID':x.id}, x => { this.pageIndex = 0;
if(x.data.resultCode==1){ }
this.$message.success('删除成功') let msg = {
this.getaddatas(0) pageIndex: this.pageIndex,
}else{ pageSize: this.pageSize,
this.$message.error(x.data.message) };
} this.apipost(
},err => {}) "Advertising_post_GetPageList",
}, msg,
(x) => {
handleCurrentChange(val) { x.data.data.pageData.forEach((x) => {
this.pageIndex++ x.src = `${x.advertisingPicUrlStr}?x-oss-process=image/resize,w_200`;
this.getaddatas(1) });
}, if (x.data.data.pageData.length == 0) {
getaddatas(type){ this.$refs.waterfall.waterfallOver();
if(type==0){ }
this.pageIndex=0 this.addatas = [];
} this.addatas = this.addatas.concat(x.data.data.pageData);
let msg={ this.total = x.data.data.pageCount;
pageIndex:this.pageIndex,
pageSize:this.pageSize
}
this.apipost("Advertising_post_GetPageList", msg, x => {
x.data.data.pageData.forEach(x=>{
x.src=`${x.advertisingPicUrlStr}?x-oss-process=image/resize,w_200`
})
if(x.data.data.pageData.length==0){
this.$refs.waterfall.waterfallOver()
}
this.addatas=[];
this.addatas=this.addatas.concat(x.data.data.pageData)
this.total=x.data.data.pageCount
},err => {})
},
getcountry(){
this.apipost("dict_post_Destination_GetCountry", {}, x => {
this.countrys=x.data.data
},err => {})
}, },
getteam(){ (err) => {}
let msg={ );
'RB_Branch_id':this.user.RB_Branch_id, },
'isTOOP':1, getcountry() {
'lineID':this.msg.lineId this.apipost(
} "dict_post_Destination_GetCountry",
this.apipost("team_post_GetList", msg, x => { {},
this.teams=x.data.data (x) => {
if(x.data.data.length>0) this.countrys = x.data.data;
this.msg.teamId=x.data.data[0].LtID
},err => {})
}, },
changeLine(){ (err) => {}
this.teams.splice(0,this.teams.length-1) );
if(this.msg.lineId!==0){ },
this.getteam() getteam() {
} let msg = {
RB_Branch_id: this.user.RB_Branch_id,
isTOOP: 1,
lineID: this.msg.lineId,
};
this.apipost(
"team_post_GetList",
msg,
(x) => {
this.teams = x.data.data;
if (x.data.data.length > 0) this.msg.teamId = x.data.data[0].LtID;
}, },
changeLineForm(){ (err) => {}
this.modelTeams.splice(0,this.modelTeams.length-1) );
if(this.model.LineID!==0&&this.model.LineID!=''){ },
let msg={ changeLine() {
'RB_Branch_id':this.user.RB_Branch_id, this.teams.splice(0, this.teams.length - 1);
'isTOOP':1, if (this.msg.lineId !== 0) {
'lineID':this.model.LineID this.getteam();
} }
this.apipost("team_post_GetList", msg, x => { },
this.modelTeams=x.data.data changeLineForm() {
if(x.data.data.length>0) this.modelTeams.splice(0, this.modelTeams.length - 1);
this.model.SeriesID=x.data.data[0].LtID if (this.model.LineID !== 0 && this.model.LineID != "") {
},err => {}) let msg = {
} RB_Branch_id: this.user.RB_Branch_id,
isTOOP: 1,
lineID: this.model.LineID,
};
this.apipost(
"team_post_GetList",
msg,
(x) => {
this.modelTeams = x.data.data;
if (x.data.data.length > 0)
this.model.SeriesID = x.data.data[0].LtID;
},
(err) => {}
);
}
},
getline() {
let msg = { pageIndex: 0, pageSize: 100 };
this.apipost(
"line_post_GetPageList",
msg,
(x) => {
this.lines = x.data.data.pageData;
}, },
getline(){ (err) => {}
let msg={'pageIndex':0,'pageSize':100} );
this.apipost("line_post_GetPageList", msg, x => { },
this.lines=x.data.data.pageData },
},err => {}) };
}
}
}
</script> </script>
\ No newline at end of file
<style> <style>
@import "../../assets/css/advert/advmanager"; @import "../../assets/css/advert/advmanager";
</style> </style>
<template> <template>
<div class="advmanager-box"> <div class="advmanager-box">
<div class="query-box"> <div class="query-box">
<ul> <ul>
<!-- <li> <!-- <li>
<span>{{$t('advmanager.v_line')}}</span> <span>{{$t('advmanager.v_line')}}</span>
<el-select v-model="msg.lineId" clearable class="w150" filterable @change="changeLine"> <el-select v-model="msg.lineId" clearable class="w150" filterable @change="changeLine">
<el-option :label="$t('advmanager.v_all')" value='0' ></el-option> <el-option :label="$t('advmanager.v_all')" value='0' ></el-option>
...@@ -27,49 +27,75 @@ ...@@ -27,49 +27,75 @@
</el-option> </el-option>
</el-select> </el-select>
</li> --> </li> -->
<li> <li>
<span>{{$t('advmanager.v_country')}}</span> <span>{{ $t("advmanager.v_country") }}</span>
<el-select v-model="msg.countryId" clearable class="w150" filterable> <el-select v-model="msg.countryId" clearable class="w150" filterable>
<el-option :label="$t('advmanager.v_all')" value='0'></el-option> <el-option :label="$t('advmanager.v_all')" value="0"></el-option>
<el-option v-for='item in countrys' <el-option
:key="item.ID" v-for="item in countrys"
:label="item.Name" :key="item.ID"
:value="item.ID"> :label="item.Name"
</el-option> :value="item.ID"
</el-select> >
</li> </el-option>
<li> </el-select>
<span>{{$t('advmanager.v_type')}}</span> </li>
<el-select v-model="msg.type" class="w150" clearable filterable> <li>
<el-option :label="$t('advmanager.v_all')" value='0'></el-option> <span>{{ $t("advmanager.v_type") }}</span>
<el-option :label="$t('advmanager.v_shoufei')" value='1'></el-option> <el-select v-model="msg.type" class="w150" clearable filterable>
<el-option :label="$t('advmanager.v_free')" value='2'></el-option> <el-option :label="$t('advmanager.v_all')" value="0"></el-option>
</el-select> <el-option
</li> :label="$t('advmanager.v_shoufei')"
<li> value="1"
<button class="normalBtn" type="button" @click="openaddbox">{{$t('pub.addBtn')}}</button> ></el-option>
<button class="hollowFixedBtn" type="button" @click="getaddatas(0)">{{$t('pub.searchBtn')}}</button> <el-option :label="$t('advmanager.v_free')" value="2"></el-option>
</li> </el-select>
</ul> </li>
</div> <li>
<div class="content" :class="{showAddBox:isAdd}" > <button class="normalBtn" type="button" @click="openaddbox">
<vueWaterfallEasy :imgsArr="addatas" @scrollReachBottom="handleCurrentChange" :maxCols='7' :imgWidth='208' :enablePullDownEvent='true'> {{ $t("pub.addBtn") }}
<template slot-scope="props"> </button>
<span class="money" v-if="props.value.IsFee==1">{{props.value.ChargeAmount.toFixed(2)}}</span> <button class="hollowFixedBtn" type="button" @click="getaddatas(0)">
<span class="free" v-else>{{$t('advmanager.v_free')}}</span> {{ $t("pub.searchBtn") }}
<div class="star-box"> </button>
<i class="iconfont icon-star star"></i>&nbsp; {{props.value.AdvertisingCount}} </li>
</div> </ul>
<div class="zezhao"> </div>
<i class="el-icon-edit" :title="$t('pub.updateMsg')" @click="update(props.value)"></i> <div class="content" :class="{ showAddBox: isAdd }">
<i class="el-icon-delete" :title="$t('system.table_delete')" @click="deleteItem(props.value)" ></i> <vueWaterfallEasy
</div> :imgsArr="addatas"
</template> @scrollReachBottom="handleCurrentChange"
</vueWaterfallEasy> :maxCols="7"
</div> :imgWidth="208"
<div class="add-box query-box" v-show="isAdd"> :enablePullDownEvent="true"
<ul> >
<!-- <li> <template slot-scope="props">
<span class="money" v-if="props.value.IsFee == 1"
>{{ props.value.ChargeAmount.toFixed(2) }}</span
>
<span class="free" v-else>{{ $t("advmanager.v_free") }}</span>
<div class="star-box">
<i class="iconfont icon-star star"></i>&nbsp;
{{ props.value.AdvertisingCount }}
</div>
<div class="zezhao">
<i
class="el-icon-edit"
:title="$t('pub.updateMsg')"
@click="update(props.value)"
></i>
<i
class="el-icon-delete"
:title="$t('system.table_delete')"
@click="deleteItem(props.value)"
></i>
</div>
</template>
</vueWaterfallEasy>
</div>
<div class="add-box query-box" v-show="isAdd">
<ul>
<!-- <li>
<span>{{$t('advmanager.v_line')}}:</span> <span>{{$t('advmanager.v_line')}}:</span>
<el-select v-model="model.LineID" clearable class="w150" @change="changeLineForm"> <el-select v-model="model.LineID" clearable class="w150" @change="changeLineForm">
<el-option v-for='item in lines' <el-option v-for='item in lines'
...@@ -89,358 +115,441 @@ ...@@ -89,358 +115,441 @@
</el-option> </el-option>
</el-select> </el-select>
</li> --> </li> -->
<li> <li>
<span>{{$t('advmanager.v_type')}}:</span> <span>{{ $t("advmanager.v_type") }}:</span>
<el-select v-model="model.IsFee" class="w150" clearable filterable> <el-select v-model="model.IsFee" class="w150" clearable filterable>
<el-option :label="$t('advmanager.v_shoufei')" value='1'></el-option> <el-option
<el-option :label="$t('advmanager.v_free')" value='2'></el-option> :label="$t('advmanager.v_shoufei')"
</el-select> value="1"
</li> ></el-option>
<li> <el-option :label="$t('advmanager.v_free')" value="2"></el-option>
<span>{{$t('advmanager.v_country')}}:</span> </el-select>
<el-select v-model="CountryID" multiple collapse-tags clearable class="w240" filterable> </li>
<el-option v-for='item in countrys' <li>
:key="item.ID" <span>{{ $t("advmanager.v_country") }}:</span>
:label="item.Name" <el-select
:value="item.ID"> v-model="CountryID"
</el-option> multiple
</el-select> collapse-tags
</li> clearable
<li v-show='model.IsFee=="1"'> class="w240"
<span>收费金额:</span> filterable
<el-input v-model="model.ChargeAmount" class="w150" clearable filterable></el-input> >
</li> <el-option
<li> v-for="item in countrys"
:key="item.ID"
</li> :label="item.Name"
</ul> :value="item.ID"
<div class="upload-box"> >
<input type="file" value="" ref="loadFile" @change="upload" style="display:none;"/> </el-option>
<label>底图:</label> </el-select>
<div class="upload-box-normal" v-if='model.PictureUrl==""' @click="openupload(0)" > </li>
<i class="iconfont icon-img_jiahao_big"></i> <li v-show="model.IsFee == '1'">
</div> <span>收费金额:</span>
<div class="upload-box-img" v-else> <el-input
<img :src='model.PictureUrl'> v-model="model.ChargeAmount"
<div class="zezhao"> class="w150"
<i class="el-icon-delete" title="删除" @click="deletePic(0)"></i> clearable
</div> filterable
</div> ></el-input>
<label>原图:</label> </li>
<div class="upload-box-normal" v-if='model.SamplePicturesUrl==""' @click="openupload(1)" > <li></li>
<i class="iconfont icon-img_jiahao_big"></i> </ul>
</div> <div class="upload-box">
<div class="upload-box-img" v-else> <input
<img :src='model.SamplePicturesUrl'> type="file"
<div class="zezhao"> value=""
<i class="el-icon-delete" title="删除" @click="deletePic(1)"></i> ref="loadFile"
</div> @change="upload"
</div> style="display: none"
</div> />
<div class="opera-btn-box"> <label>底图:</label>
<button class="normalBtn" type="button" @click="save">{{$t('pub.saveBtn')}}</button> <div
<button class="hollowFixedBtn" type="button" @click="close">{{$t('pub.cancelBtn')}}</button> class="upload-box-normal"
</div> v-if="model.PictureUrl == ''"
@click="openupload(0)"
>
<i class="iconfont icon-img_jiahao_big"></i>
</div> </div>
<!-- <el-pagination background @current-change="handleCurrentChange" :current-page.sync="pageIndex" layout="total,prev, pager, next, jumper" :page-size="pageSize" :total="total"> <div class="upload-box-img" v-else>
</el-pagination> --> <img :src="model.PictureUrl" />
<div class="zezhao">
<i class="el-icon-delete" title="删除" @click="deletePic(0)"></i>
</div>
</div>
<label>原图:</label>
<div
class="upload-box-normal"
v-if="model.SamplePicturesUrl == ''"
@click="openupload(1)"
>
<i class="iconfont icon-img_jiahao_big"></i>
</div>
<div class="upload-box-img" v-else>
<img :src="model.SamplePicturesUrl" />
<div class="zezhao">
<i class="el-icon-delete" title="删除" @click="deletePic(1)"></i>
</div>
</div>
</div>
<div class="opera-btn-box">
<button class="normalBtn" type="button" @click="save">
{{ $t("pub.saveBtn") }}
</button>
<button class="hollowFixedBtn" type="button" @click="close">
{{ $t("pub.cancelBtn") }}
</button>
</div>
</div> </div>
<!-- <el-pagination background @current-change="handleCurrentChange" :current-page.sync="pageIndex" layout="total,prev, pager, next, jumper" :page-size="pageSize" :total="total">
</el-pagination> -->
</div>
</template> </template>
<script> <script>
import vueWaterfallEasy from 'vue-waterfall-easy' import vueWaterfallEasy from "vue-waterfall-easy";
export default { export default {
data(){ data() {
return{ return {
lines:[], lines: [],
teams:[], teams: [],
modelTeams:[], modelTeams: [],
countrys:[], countrys: [],
addatas:[], addatas: [],
CountryID:[], CountryID: [],
pageIndex:0, pageIndex: 0,
pageSize:50, pageSize: 50,
total:0, total: 0,
msg:{ msg: {
lineId:'0', lineId: "0",
teamId:'0', teamId: "0",
countryId:'0', countryId: "0",
type:'0' type: "0",
}, },
user:{}, user: {},
model:{}, model: {},
isAdd:false, isAdd: false,
uploadType:0 uploadType: 0,
} };
},
mounted() {
this.user = JSON.parse(window.localStorage.userInfo);
this.getline();
this.getcountry();
this.getaddatas(0);
},
components: {
vueWaterfallEasy,
},
methods: {
deleteItem(x) {
this.apipost(
"Advertising_post_DelAdvertising",
{ BAID: x.ID },
(x) => {
if (x.data.resultCode == 1) {
this.$message.success("删除成功");
this.getaddatas(0);
} else {
this.$message.error(x.data.message);
}
},
(err) => {}
);
}, },
mounted(){ update(x) {
this.user=JSON.parse(window.localStorage.userInfo) this.CountryID = [];
this.getline() this.getmodelTeams(x.LineID);
this.getcountry() x.CountryIds.forEach((y) => {
this.getaddatas(0) this.CountryID.push(y.CountryID);
});
this.model = {
ID: x.ID,
LineID: x.LineID,
SeriesID: x.SeriesID,
CountryID: x.CountryID,
ScenicSpotID: x.ScenicSpotID,
PictureUrl: x.PictureUrl,
SamplePicturesUrl: x.SamplePicturesUrl,
Title: x.Title,
ChargeAmount: x.ChargeAmount,
IsFee: x.IsFee.toString(),
};
this.isAdd = true;
}, },
components: { close() {
vueWaterfallEasy this.isAdd = false;
}, },
methods:{ save() {
deleteItem(x){ if (this.model.LineID == "") {
this.apipost("Advertising_post_DelAdvertising", {'BAID':x.ID}, x => { this.$message.error("请选择线路");
if(x.data.resultCode==1){ } else if (this.model.SeriesID === "") {
this.$message.success('删除成功') this.$message.error("请选择系列");
this.getaddatas(0) } else if (this.CountryID.length == 0) {
}else{ this.$message.error("请选择国家");
this.$message.error(x.data.message) } else if (this.model.IsFee == "") {
} this.$message.error("请选择类型");
},err => {}) } else if (this.model.ChargeAmount == "" && this.model.IsFee == "1") {
}, this.$message.error("请填写金额");
update(x){ } else if (
this.CountryID=[]; Number.isNaN(this.model.ChargeAmount) &&
this.getmodelTeams(x.LineID); this.model.IsFee == "1"
x.CountryIds.forEach(y=>{ ) {
this.CountryID.push(y.CountryID); this.$message.error("填写金额非法");
}) } else if (this.model.PictureUrl == "") {
this.model={ this.$message.error("请选择广告图");
ID:x.ID, } else if (this.model.SamplePicturesUrl == "") {
LineID:x.LineID, this.$message.error("请选择原图");
SeriesID:x.SeriesID, } else {
CountryID:x.CountryID, this.model.CountryIDs = this.CountryID;
ScenicSpotID:x.ScenicSpotID, this.model.ChargeAmount =
PictureUrl:x.PictureUrl, this.model.IsFee == "1" ? this.model.ChargeAmount : "0";
SamplePicturesUrl:x.SamplePicturesUrl, this.uploadImage(0);
Title:x.Title, }
ChargeAmount:x.ChargeAmount, },
IsFee:x.IsFee.toString() base64ToBlob(code) {
} let parts = code.split(";base64,");
this.isAdd=true let contentType = parts[0].split(":")[1];
}, let raw = window.atob(parts[1]);
close(){ let rawLength = raw.length;
this.isAdd=false
},
save(){
if(this.model.LineID==''){
this.$message.error('请选择线路')
}else if(this.model.SeriesID===''){
this.$message.error('请选择系列')
}else if(this.CountryID.length==0){
this.$message.error('请选择国家')
}else if(this.model.IsFee==''){
this.$message.error('请选择类型')
}else if(this.model.ChargeAmount==''&&this.model.IsFee=='1'){
this.$message.error('请填写金额')
}else if(Number.isNaN(this.model.ChargeAmount)&&this.model.IsFee=='1'){
this.$message.error('填写金额非法')
}else if(this.model.PictureUrl==''){
this.$message.error('请选择广告图')
}else if(this.model.SamplePicturesUrl==''){
this.$message.error('请选择原图')
}else{
this.model.CountryIDs = this.CountryID;
this.model.ChargeAmount=this.model.IsFee=='1'?this.model.ChargeAmount:'0'
this.uploadImage(0)
}
},
base64ToBlob(code) {
let parts = code.split(';base64,');
let contentType = parts[0].split(':')[1];
let raw = window.atob(parts[1]);
let rawLength = raw.length;
let uInt8Array = new Uint8Array(rawLength); let uInt8Array = new Uint8Array(rawLength);
for (let i = 0; i < rawLength; ++i) { for (let i = 0; i < rawLength; ++i) {
uInt8Array[i] = raw.charCodeAt(i); uInt8Array[i] = raw.charCodeAt(i);
} }
return new Blob([uInt8Array], {type: contentType}); return new Blob([uInt8Array], { type: contentType });
}, },
uploadImage(cnt) { uploadImage(cnt) {
if(cnt==2){ if (cnt == 2) {
this.apipost("Advertising_post_SetAdvertising", this.model, x => { this.apipost(
if(x.data.resultCode==1){ "Advertising_post_SetAdvertising",
this.$message.success('保存成功'); this.model,
this.isAdd=false; (x) => {
this.CountryID = []; if (x.data.resultCode == 1) {
this.getaddatas(0); this.$message.success("保存成功");
}else{ this.isAdd = false;
this.$message.error(x.data.message) this.CountryID = [];
} this.getaddatas(0);
},err => {})
} else { } else {
let dataUrl=cnt==0?this.model.PictureUrl:this.model.SamplePicturesUrl this.$message.error(x.data.message);
if(dataUrl.indexOf('base64')==-1){
if(cnt==0){
this.model.PictureUrl=`/Adv${this.model.PictureUrl.split('/Adv')[1]}`
}else{
this.model.SamplePicturesUrl=`/Adv${this.model.SamplePicturesUrl.split('/Adv')[1]}`
}
this.uploadImage(cnt+1)
} else {
let file=this.base64ToBlob(dataUrl)
let newArr = []
newArr.push(file)
var path = `/Adv/template/${this.uuid(10,10)}.jpg`
let that=this
this.uploadBlob(path, newArr, x => {
if(cnt==0){
that.model.PictureUrl=path
that.uploadImage(1)
}else{
that.model.SamplePicturesUrl=path
that.uploadImage(2)
}
})
}
} }
}, },
uuid(len, radix) { (err) => {}
var chars = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz'.split(''); );
var uuid = [], i; } else {
radix = radix || chars.length; let dataUrl =
if (len) { cnt == 0 ? this.model.PictureUrl : this.model.SamplePicturesUrl;
// Compact form if (dataUrl.indexOf("base64") == -1) {
for (i = 0; i < len; i++) uuid[i] = chars[0 | Math.random()*radix]; if (cnt == 0) {
this.model.PictureUrl = `/Adv${
this.model.PictureUrl.split("/Adv")[1]
}`;
} else {
this.model.SamplePicturesUrl = `/Adv${
this.model.SamplePicturesUrl.split("/Adv")[1]
}`;
}
this.uploadImage(cnt + 1);
} else {
let file = this.base64ToBlob(dataUrl);
let newArr = [];
newArr.push(file);
var path = `/Adv/template/${this.uuid(10, 10)}.jpg`;
let that = this;
this.uploadBlob(path, newArr, (x) => {
if (cnt == 0) {
that.model.PictureUrl = path;
that.uploadImage(1);
} else { } else {
var r; that.model.SamplePicturesUrl = path;
uuid[8] = uuid[13] = uuid[18] = uuid[23] = '-'; that.uploadImage(2);
uuid[14] = '4';
for (i = 0; i < 36; i++) {
if (!uuid[i]) {
r = 0 | Math.random()*16;
uuid[i] = chars[(i == 19) ? (r & 0x3) | 0x8 : r];
}
}
} }
return uuid.join(''); });
}, }
deletePic(type){ }
if(type==0) },
this.model.PictureUrl='' uuid(len, radix) {
else var chars =
this.model.SamplePicturesUrl='' "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz".split(
}, ""
upload(){ );
if(this.$refs.loadFile.files.length>0 && this.$refs.loadFile.files[0].size>0){ var uuid = [],
let reader = new FileReader() i;
let that=this radix = radix || chars.length;
reader.readAsDataURL(this.$refs.loadFile.files[0]) if (len) {
reader.onload=function(e) { // Compact form
if(that.uploadType==0) for (i = 0; i < len; i++) uuid[i] = chars[0 | (Math.random() * radix)];
that.model.PictureUrl=e.target.result } else {
else var r;
that.model.SamplePicturesUrl=e.target.result uuid[8] = uuid[13] = uuid[18] = uuid[23] = "-";
} uuid[14] = "4";
this.$refs.loadFile.value = ""; for (i = 0; i < 36; i++) {
} if (!uuid[i]) {
}, r = 0 | (Math.random() * 16);
openupload(t){ uuid[i] = chars[i == 19 ? (r & 0x3) | 0x8 : r];
this.uploadType=t }
this.$refs.loadFile.click() }
}, }
getmodelTeams(t){ return uuid.join("");
let msg={ },
'RB_Branch_id':this.user.RB_Branch_id, deletePic(type) {
'isTOOP':1, if (type == 0) this.model.PictureUrl = "";
'lineID':t==0?this.lines[0].lineID:t else this.model.SamplePicturesUrl = "";
} },
this.apipost("team_post_GetList", msg, x => { upload() {
this.modelTeams=x.data.data if (
if(t==0) this.$refs.loadFile.files.length > 0 &&
// this.model.SeriesID=this.modelTeams[0].LtID 没这LtID 要报错 this.$refs.loadFile.files[0].size > 0
this.model.SeriesID = 0; ) {
},err => {}) let reader = new FileReader();
}, let that = this;
openaddbox(){ reader.readAsDataURL(this.$refs.loadFile.files[0]);
this.CountryID = []; reader.onload = function (e) {
this.getmodelTeams(0) if (that.uploadType == 0) that.model.PictureUrl = e.target.result;
this.model={ else that.model.SamplePicturesUrl = e.target.result;
ID:0, };
LineID:this.lines[0].lineID, this.$refs.loadFile.value = "";
SeriesID:0, }
CountryID:this.countrys[0].ID, },
ScenicSpotID:0, openupload(t) {
PictureUrl:'', this.uploadType = t;
SamplePicturesUrl:'', this.$refs.loadFile.click();
Title:'无', },
ChargeAmount:'1.00', getmodelTeams(t) {
IsFee:'2' let msg = {
} RB_Branch_id: this.user.RB_Branch_id,
this.isAdd=true isTOOP: 1,
}, lineID: t == 0 ? this.lines[0].lineID : t,
handleCurrentChange() { };
this.pageIndex++ this.apipost(
this.getaddatas(1) "team_post_GetList",
}, msg,
getaddatas(type){ (x) => {
if(type==0){ this.modelTeams = x.data.data;
this.pageIndex=0 if (t == 0)
} // this.model.SeriesID=this.modelTeams[0].LtID 没这LtID 要报错
let msg={ this.model.SeriesID = 0;
pageIndex:this.pageIndex,
pageSize:this.pageSize,
lineId:this.msg.lineId,
SeriesId:this.msg.teamId,
CountryId:this.msg.countryId,
AdvName:'',
IsFee:this.msg.type
}
this.apipost("Advertising_get_GetAdvertisingList", msg, x => {
x.data.data.pageData.forEach(x=>{
x.src=`${x.SamplePicturesUrl}?x-oss-process=image/resize,w_200`
x.id=x.ID
})
if(type==0){
this.addatas=x.data.data.pageData
}else{
this.addatas=this.addatas.concat(x.data.data.pageData)
}
this.total=x.data.data.count
},err => {})
}, },
getcountry(){ (err) => {}
this.apipost("dict_post_Destination_GetCountry", {}, x => { );
this.countrys=x.data.data },
},err => {}) openaddbox() {
this.CountryID = [];
this.getmodelTeams(0);
this.model = {
ID: 0,
LineID: this.lines[0].lineID,
SeriesID: 0,
CountryID: this.countrys[0].ID,
ScenicSpotID: 0,
PictureUrl: "",
SamplePicturesUrl: "",
Title: "无",
ChargeAmount: "1.00",
IsFee: "2",
};
this.isAdd = true;
},
handleCurrentChange() {
this.pageIndex++;
this.getaddatas(1);
},
getaddatas(type) {
if (type == 0) {
this.pageIndex = 0;
}
let msg = {
pageIndex: this.pageIndex,
pageSize: this.pageSize,
lineId: this.msg.lineId,
SeriesId: this.msg.teamId,
CountryId: this.msg.countryId,
AdvName: "",
IsFee: this.msg.type,
};
this.apipost(
"Advertising_get_GetAdvertisingList",
msg,
(x) => {
x.data.data.pageData.forEach((x) => {
x.src = `${x.SamplePicturesUrl}?x-oss-process=image/resize,w_200`;
x.id = x.ID;
});
if (type == 0) {
this.addatas = x.data.data.pageData;
} else {
this.addatas = this.addatas.concat(x.data.data.pageData);
}
this.total = x.data.data.count;
}, },
getteam(){ (err) => {}
let msg={ );
'RB_Branch_id':this.user.RB_Branch_id, },
'isTOOP':1, getcountry() {
'lineID':this.msg.lineId this.apipost(
} "dict_post_Destination_GetCountry",
this.apipost("team_post_GetList", msg, x => { {},
this.teams=x.data.data (x) => {
if(x.data.data.length>0) this.countrys = x.data.data;
this.msg.teamId=x.data.data[0].LtID
},err => {})
}, },
changeLine(){ (err) => {}
this.teams.splice(0,this.teams.length-1) );
if(this.msg.lineId!==0){ },
this.getteam() getteam() {
} let msg = {
RB_Branch_id: this.user.RB_Branch_id,
isTOOP: 1,
lineID: this.msg.lineId,
};
this.apipost(
"team_post_GetList",
msg,
(x) => {
this.teams = x.data.data;
if (x.data.data.length > 0) this.msg.teamId = x.data.data[0].LtID;
}, },
changeLineForm(){ (err) => {}
this.modelTeams.splice(0,this.modelTeams.length-1) );
if(this.model.LineID!==0&&this.model.LineID!=''){ },
let msg={ changeLine() {
'RB_Branch_id':this.user.RB_Branch_id, this.teams.splice(0, this.teams.length - 1);
'isTOOP':1, if (this.msg.lineId !== 0) {
'lineID':this.model.LineID this.getteam();
} }
this.apipost("team_post_GetList", msg, x => { },
this.modelTeams=x.data.data changeLineForm() {
if(x.data.data.length>0) this.modelTeams.splice(0, this.modelTeams.length - 1);
this.model.SeriesID=x.data.data[0].LtID if (this.model.LineID !== 0 && this.model.LineID != "") {
},err => {}) let msg = {
} RB_Branch_id: this.user.RB_Branch_id,
isTOOP: 1,
lineID: this.model.LineID,
};
this.apipost(
"team_post_GetList",
msg,
(x) => {
this.modelTeams = x.data.data;
if (x.data.data.length > 0)
this.model.SeriesID = x.data.data[0].LtID;
},
(err) => {}
);
}
},
getline() {
let msg = { pageIndex: 0, pageSize: 100 };
this.apipost(
"line_post_GetPageList",
msg,
(x) => {
this.lines = x.data.data.pageData;
}, },
getline(){ (err) => {}
let msg={'pageIndex':0,'pageSize':100} );
this.apipost("line_post_GetPageList", msg, x => { },
this.lines=x.data.data.pageData },
},err => {}) };
}
}
}
</script> </script>
...@@ -37,33 +37,35 @@ import pinyin from 'pinyin' ...@@ -37,33 +37,35 @@ import pinyin from 'pinyin'
// import JsPDF from 'jspdf' // import JsPDF from 'jspdf'
import lrz from 'lrz' import lrz from 'lrz'
import 'vue-easytable/libs/themes-base/index.css' import 'vue-easytable/libs/themes-base/index.css'
import {VTable,VPagination} from 'vue-easytable' import { VTable, VPagination } from 'vue-easytable'
import 'viewerjs/dist/viewer.css' import 'viewerjs/dist/viewer.css'
import Viewer from 'v-viewer' import Viewer from 'v-viewer'
Vue.component(VTable.name, VTable) Vue.component(VTable.name, VTable)
Vue.component(VPagination.name, VPagination) Vue.component(VPagination.name, VPagination)
Vue.config.productionTip = false Vue.config.productionTip = false
Vue.http = Vue.prototype.$http = axios Vue.http = Vue.prototype.$http = axios
Vue.cookie = Vue.prototype.$cookie=cookie Vue.cookie = Vue.prototype.$cookie = cookie
Vue.commonUtils = Vue.prototype.$commonUtils=commonUtils Vue.commonUtils = Vue.prototype.$commonUtils = commonUtils
Vue.tripUtils=Vue.prototype.$tripUtils=tripUtils Vue.tripUtils = Vue.prototype.$tripUtils = tripUtils
Vue.DMCUtils=Vue.prototype.$DMCUtils=DMCUtils Vue.DMCUtils = Vue.prototype.$DMCUtils = DMCUtils
Vue.languageUtils=Vue.prototype.$languageUtils=languageUtils Vue.languageUtils = Vue.prototype.$languageUtils = languageUtils
Vue.calendarUtils=Vue.prototype.$calendarUtils=calendarUtils Vue.calendarUtils = Vue.prototype.$calendarUtils = calendarUtils
Vue.lunarCalendar=Vue.prototype.$lunarCalendar=lunarCalendar Vue.lunarCalendar = Vue.prototype.$lunarCalendar = lunarCalendar
Vue.googleMap=Vue.prototype.$googleMap=googleMap Vue.googleMap = Vue.prototype.$googleMap = googleMap
Vue.AuthCode=Vue.prototype.$AuthCode=AuthCode Vue.AuthCode = Vue.prototype.$AuthCode = AuthCode
Vue.prototype.$echarts = echarts Vue.prototype.$echarts = echarts
Vue.chartsUtils=Vue.prototype.$chartsUtils=chartsUtils Vue.chartsUtils = Vue.prototype.$chartsUtils = chartsUtils
Vue.prototype.$VueBarcode = VueBarcode Vue.prototype.$VueBarcode = VueBarcode
// Vue.prototype.GLOBAL = global_ // Vue.prototype.GLOBAL = global_
// Vue.component('barcode', VueBarcode); // Vue.component('barcode', VueBarcode);
Vue.prototype.pinyin = pinyin Vue.prototype.pinyin = pinyin
// Vue.prototype.h2c=h2c // Vue.prototype.h2c=h2c
Vue.prototype.lrz=lrz Vue.prototype.lrz = lrz
/* eslint-disable no-new */ /* eslint-disable no-new */
// Vue.use(htmlToPdf) // Vue.use(htmlToPdf)
...@@ -74,7 +76,7 @@ Vue.use(vueQuillEditor) ...@@ -74,7 +76,7 @@ Vue.use(vueQuillEditor)
//Vue.use(VueAMap); //Vue.use(VueAMap);
Vue.use(VueBarcode); //声明条形码组件 Vue.use(VueBarcode); //声明条形码组件
Vue.use(store); Vue.use(store);
Vue.use(Viewer,{ Vue.use(Viewer, {
defaultOptions: { defaultOptions: {
zIndex: 9999 zIndex: 9999
} }
...@@ -87,28 +89,28 @@ Vue.use(Viewer,{ ...@@ -87,28 +89,28 @@ Vue.use(Viewer,{
// 时间扩展格式化 // 时间扩展格式化
Date.prototype.Format = function (fmt) { Date.prototype.Format = function (fmt) {
var o = { var o = {
"M+": this.getMonth() + 1, //月份 "M+": this.getMonth() + 1, //月份
"d+": this.getDate(), //日 "d+": this.getDate(), //日
"h+": this.getHours(), //小时 "h+": this.getHours(), //小时
"m+": this.getMinutes(), //分 "m+": this.getMinutes(), //分
"s+": this.getSeconds() //秒 "s+": this.getSeconds() //秒
}; };
if (/(y+)/.test(fmt)){ //根据y的长度来截取年 if (/(y+)/.test(fmt)) { //根据y的长度来截取年
fmt = fmt.replace(RegExp.$1, (this.getFullYear() + "").substr(4 - RegExp.$1.length)); fmt = fmt.replace(RegExp.$1, (this.getFullYear() + "").substr(4 - RegExp.$1.length));
} }
for (var k in o){ for (var k in o) {
if (new RegExp("(" + k + ")").test(fmt)) fmt = fmt.replace(RegExp.$1, (RegExp.$1.length == 1) ? (o[k]) : (("00" + o[k]).substr(("" + o[k]).length))); if (new RegExp("(" + k + ")").test(fmt)) fmt = fmt.replace(RegExp.$1, (RegExp.$1.length == 1) ? (o[k]) : (("00" + o[k]).substr(("" + o[k]).length)));
} }
return fmt; return fmt;
}; };
Vue.prototype.DateDiff = function (sDate1, sDate2) { Vue.prototype.DateDiff = function (sDate1, sDate2) {
var aDate, oDate1, oDate2, iDays var aDate, oDate1, oDate2, iDays
aDate = sDate1.split("-") aDate = sDate1.split("-")
oDate1 = new Date(aDate[1] + '-' + aDate[2] + '-' + aDate[0]) oDate1 = new Date(aDate[1] + '-' + aDate[2] + '-' + aDate[0])
aDate = sDate2.split("-") aDate = sDate2.split("-")
oDate2 = new Date(aDate[1] + '-' + aDate[2] + '-' + aDate[0]) oDate2 = new Date(aDate[1] + '-' + aDate[2] + '-' + aDate[0])
iDays = parseInt(Math.abs(oDate1 - oDate2) / 1000 / 60 / 60 /24) //把相差的毫秒数转换为天数 iDays = parseInt(Math.abs(oDate1 - oDate2) / 1000 / 60 / 60 / 24) //把相差的毫秒数转换为天数
return iDays return iDays
} }
// 数组对比 // 数组对比
...@@ -155,7 +157,7 @@ const i18n = new VueI18n({ ...@@ -155,7 +157,7 @@ const i18n = new VueI18n({
'zh-CN': require('./assets/common/lang/zh'), // 中文语言包 'zh-CN': require('./assets/common/lang/zh'), // 中文语言包
'en-US': require('./assets/common/lang/en'), // 英文语言包 'en-US': require('./assets/common/lang/en'), // 英文语言包
'zh-TW': require('./assets/common/lang/zh-tw'), // 台湾语言包 'zh-TW': require('./assets/common/lang/zh-tw'), // 台湾语言包
'Japanese' : require('./assets/common/lang/jp') // 日本语言包 'Japanese': require('./assets/common/lang/jp') // 日本语言包
} }
}) })
......
This source diff could not be displayed because it is too large. You can view the blob instead.
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