Commit 9c0cad44 authored by 黄奎's avatar 黄奎

页面优化

parent 17df71e3
<style>
.companyManagement .avatar-uploader .el-upload {border: 1px dashed #d9d9d9;cursor: pointer;position: relative;overflow: hidden;width: 100px;height: 100px;border-radius: 50%}
.companyManagement .avatar-uploader .el-upload:hover {border-color: #409EFF;}
.companyManagement .avatar-uploader-icon {font-size: 28px;color:white;width: 100px;height: 100px;line-height: 80px;text-align: center;position: absolute;left: 0;top: 0;background:rgba(0,0,0,0.5);}
.companyManagement .avatar-uploader .el-upload {
border: 1px dashed #d9d9d9;
cursor: pointer;
position: relative;
overflow: hidden;
width: 100px;
height: 100px;
border-radius: 50%
}
.companyManagement .avatar-uploader .el-upload:hover {
border-color: #409EFF;
}
.companyManagement .avatar-uploader-icon {
font-size: 28px;
color: white;
width: 100px;
height: 100px;
line-height: 80px;
text-align: center;
position: absolute;
left: 0;
top: 0;
background: rgba(0, 0, 0, 0.5);
}
/* 上传样式 */
.companyManagement .avatar-uploader .el-upload {border: 1px dashed #d9d9d9;cursor: pointer;position: relative;overflow: hidden;width: 100px;height: 100px;border-radius: 50%}
.companyManagement .avatar-uploader .el-upload:hover {border-color: #409EFF;}
.companyManagement .avatar-uploader-icon {font-size: 28px;color:white;width: 100px;height: 100px;line-height: 80px;text-align: center;position: absolute;left: 0;top: 0;background:rgba(0,0,0,0.5);}
.companyManagement .avatar {width: 100px;height: 100px;display: block;position: absolute;left: 0;top: 0}
.companyManagement .avatar-uploader .el-upload {
border: 1px dashed #d9d9d9;
cursor: pointer;
position: relative;
overflow: hidden;
width: 100px;
height: 100px;
border-radius: 50%
}
.companyManagement .avatar-uploader .el-upload:hover {
border-color: #409EFF;
}
.companyManagement .avatar-uploader-icon {
font-size: 28px;
color: white;
width: 100px;
height: 100px;
line-height: 80px;
text-align: center;
position: absolute;
left: 0;
top: 0;
background: rgba(0, 0, 0, 0.5);
}
.companyManagement .avatar {
width: 100px;
height: 100px;
display: block;
position: absolute;
left: 0;
top: 0
}
</style>
<template>
<div class="flexOne companyManagement">
<div class="query-box">
<ul>
<!--<li>
<span><em>{{$t('admin.admin_group')}}</em><el-select filterable clearable v-model='msg.RB_Group_Id' placeholder='请选择'>
<el-option v-for='item in groupList'
:key="item.Id"
:label="item.GroupName"
:value="item.Id">
</el-option>
</el-select>
</span>
</li>-->
<li>
<span><em>{{$t('admin.admin_company')}}</em><el-input @keyup.enter.native="getList" v-model="msg.BName" :placeholder="$t('pub.pleaseImport')"></el-input></span>
<span><em>{{$t('admin.admin_company')}}</em>
<el-input @keyup.enter.native="getList" v-model="msg.BName" :placeholder="$t('pub.pleaseImport')">
</el-input>
</span>
</li>
<li>
<span><em>{{$t('admin.admin_domain')}}</em><el-input @keyup.enter.native="getList" v-model="msg.Domain" :placeholder="$t('pub.pleaseImport')"></el-input></span>
<span><em>{{$t('admin.admin_domain')}}</em>
<el-input @keyup.enter.native="getList" v-model="msg.Domain" :placeholder="$t('pub.pleaseImport')">
</el-input>
</span>
</li>
<li>
<span><em>{{$t('admin.admin_status')}}</em><el-select v-model="msg.Status" :placeholder="$t('pub.unlimitedSel')">
<span><em>{{$t('admin.admin_status')}}</em>
<el-select v-model="msg.Status" :placeholder="$t('pub.unlimitedSel')">
<el-option :label="$t('pub.unlimitedSel')" value=''></el-option>
<el-option :label="$t('pub.openSel')" value='0'></el-option>
<el-option :label="$t('pub.closeSel')" value='1'></el-option>
......@@ -37,18 +90,17 @@
</span>
</li>
<li>
<input type="button" class="hollowFixedBtn" :value="$t('pub.searchBtn')" @click="resetPageIndex(),getList()" /> &nbsp;
<input type="button" class="normalBtn" :value="$t('pub.addBtn')" @click="outerVisible = true,dialogTitle='新增公司'" />
<input type="button" class="hollowFixedBtn" :value="$t('pub.searchBtn')"
@click="resetPageIndex(),getList()" /> &nbsp;
<input type="button" class="normalBtn" :value="$t('pub.addBtn')"
@click="outerVisible = true,dialogTitle='新增公司'" />
</li>
</ul>
</div>
<table class="singeRowTable" border="0" cellspacing="0" cellpadding="0">
<tr>
<!-- <th width="400">{{$t('admin.admin_group')}}</th>-->
<th width="300">{{$t('admin.admin_company')}}</th>
<!-- <th>{{$t('admin.admin_domain')}}</th> -->
<!-- <th>{{$t('admin.admin_leader')}}</th> -->
<th>{{$t('hotel.suplier_contact')}}</th>
<th>{{$t('restaurant.res_ContactNumber')}}</th>
<th>{{$t('admin.admin_status')}}</th>
......@@ -58,10 +110,7 @@
<th width="200">{{$t('admin.admin_operate')}}</th>
</tr>
<tr v-for="(item,index) in DataList" v-loading='loading'>
<!--<td>{{item.GroupName}}</td>-->
<td>{{item.BName}}</td>
<!-- <td>{{item.Domain}}</td> -->
<!-- <td>{{item.BranchManagerName}}</td> -->
<td>{{item.ContactPersion}}</td>
<td>{{item.MobilePhone}}</td>
<td>{{item.Status==0? $t('pub.openSel'): $t('pub.closeSel')}}</td>
......@@ -71,88 +120,63 @@
<td>
<el-row>
<el-tooltip class="item" effect="dark" content="修改" placement="top-start">
<el-button @click="outerVisible = true,dialogTitle='修改公司信息',updateData(item.Id)" type="primary" icon="el-icon-edit" circle></el-button>
<el-button @click="outerVisible = true,dialogTitle='修改公司信息',updateData(item.Id)" type="primary"
icon="el-icon-edit" circle></el-button>
</el-tooltip>
</el-row>
</td>
</tr>
</table>
<el-pagination background @current-change="handleCurrentChange" :current-page.sync="currentPage" layout="total,prev, pager, next, jumper" :page-size=msg.pageSize :total=total>
<el-pagination background @current-change="handleCurrentChange" :current-page.sync="currentPage"
layout="total,prev, pager, next, jumper" :page-size=msg.pageSize :total=total>
</el-pagination>
<el-dialog custom-class='w500' :title="dialogTitle" :visible.sync="outerVisible" center :before-close="closeChangeMachie">
<el-form :model="addMsg" :rules="rules" ref="addMsg" label-width="120px" >
<!--<el-form-item class='w400' :label="$t('admin.admin_group')" prop="RB_Group_Id">
<el-select class='w300' filterable clearable v-model='addMsg.RB_Group_Id'>
<el-option v-for='item in layerGroupList' :key="item.Id" :label="item.GroupName" :value="item.Id">
</el-option>
</el-select>
</el-form-item>-->
<el-dialog custom-class='w500' :title="dialogTitle" :visible.sync="outerVisible" center
:before-close="closeChangeMachie">
<el-form :model="addMsg" :rules="rules" ref="addMsg" label-width="120px">
<el-form-item class='w400' :label="$t('admin.admin_company')" prop="BName">
<el-input type="text" v-model="addMsg.BName" :placeholder="$t('pub.pleaseImport')"></el-input>
</el-form-item>
<el-form-item class='w400' label="确认件抬头" prop="CompanyTitle">
<el-input type="text" v-model="addMsg.CompanyTitle" placeholder="请输入确认件抬头"></el-input>
</el-form-item>
<!-- <el-form-item class='w400' :label="$t('admin.admin_domain')" prop="Domain">
<el-input type="text" v-model="addMsg.Domain" :placeholder="$t('pub.pleaseImport')"></el-input>
</el-form-item> -->
<el-form-item :label="$t('system.table_pvrg')" prop="Province">
<el-select class='w280' :placeholder="$t('pub.pleaseSel')" filterable v-model="addMsg.Province" @change="getCityList(addMsg.Province,1)">
<el-select class='w280' :placeholder="$t('pub.pleaseSel')" filterable v-model="addMsg.Province"
@change="getCityList(addMsg.Province,1)">
<el-option :label="$t('pub.unlimitedSel')" :value='commonDefaultSelect'></el-option>
<el-option v-for='item in ProvinceList'
:key="item.ID"
:label="item.Name"
:value="item.ID">
<el-option v-for='item in ProvinceList' :key="item.ID" :label="item.Name" :value="item.ID">
</el-option>
</el-select>
</el-form-item>
<el-form-item label="城市" prop="City">
<el-select class='w280' :placeholder="$t('pub.pleaseSel')" filterable v-model="addMsg.City">
<el-option :label="$t('pub.unlimitedSel')" :value='commonDefaultSelect'></el-option>
<el-option v-for='item in CityList'
:key="item.ID"
:label="item.Name"
:value="item.ID">
<el-option v-for='item in CityList' :key="item.ID" :label="item.Name" :value="item.ID">
</el-option>
</el-select>
</el-form-item>
<el-form-item class='w400' :label="$t('admin.admin_address')" prop="Address">
<el-input type="text" v-model="addMsg.Address" :placeholder="$t('pub.pleaseImport')"></el-input>
</el-form-item>
<el-form-item class='w400' :label="$t('pub.telphone')" prop="Tel">
<el-input type="text" v-model="addMsg.Tel" :placeholder="$t('pub.pleaseImport')"></el-input>
</el-form-item>
<el-form-item class='w400' label='联系人姓名' prop="ContactPersion">
<el-input type="text" v-model="addMsg.ContactPersion" :placeholder="$t('pub.pleaseImport')"></el-input>
</el-form-item>
<el-form-item class='w400' label='联系人手机' prop="MobilePhone">
<el-input type="text" v-model="addMsg.MobilePhone" :placeholder="$t('pub.pleaseImport')"></el-input>
</el-form-item>
<el-form-item class='w400' label='接机人姓名' prop="AirportServicePerson">
<el-input type="text" v-model="addMsg.AirportServicePerson" :placeholder="$t('pub.pleaseImport')"></el-input>
</el-form-item>
<el-form-item class='w400' label='接机人手机' prop="AirportServicePhone">
<el-input type="text" v-model="addMsg.AirportServicePhone" :placeholder="$t('pub.pleaseImport')"></el-input>
</el-form-item>
<el-form-item class='w400' label='出团通知名' prop="NoticesName">
<el-input type="text" v-model="addMsg.NoticesName" :placeholder="$t('pub.pleaseImport')"></el-input>
</el-form-item>
<!--
<el-form-item class='w400' label='集合时间' prop="GatheringTime">
<el-input type="text" v-model="addMsg.GatheringTime" :placeholder="$t('pub.pleaseImport')"></el-input>
</el-form-item>
<el-form-item class='w400' label='集合地点' prop="GatheringAddress">
<el-input type="text" v-model="addMsg.GatheringAddress" :placeholder="$t('pub.pleaseImport')"></el-input>
</el-form-item> -->
<el-form-item class='w400' :label='$t("admin.admin_status")' prop="Status" >
<el-form-item class='w400' :label='$t("admin.admin_status")' prop="Status">
<el-switch v-model="addMsg.Status" active-value="0" inactive-value="1"></el-switch>
</el-form-item>
<el-form-item class='w400' :label='$t("admin.admin_isshow")' prop="is_show">
......@@ -169,18 +193,15 @@
</el-form-item>
<el-form-item class='w400' :label='$t("admin.admin_leader")' prop="BranchManager">
<el-select filterable clearable v-model='addMsg.BranchManager' :placeholder="$t('pub.pleaseSel')">
<el-option :label="$t('admin.unlimitedSel')" value='0'></el-option>
<el-option v-for='item in employeeList' :key="item.EmployeeId" :label="item.EmName" :value="item.EmployeeId">
<el-option label="请选择" :value='0'></el-option>
<el-option v-for='item in employeeList' :key="item.EmployeeId" :label="item.EmName"
:value="item.EmployeeId">
</el-option>
</el-select>
</el-form-item>
<el-form-item label='公司确认章'>
<el-upload
class="avatar-uploader"
:http-request="UploadImage"
:show-file-list="false"
:on-success="handleAvatarSuccess"
:before-upload="beforeAvatarUpload">
<el-upload class="avatar-uploader" :http-request="UploadImage" :show-file-list="false"
:on-success="handleAvatarSuccess" :before-upload="beforeAvatarUpload">
<img v-if="imageUrl" :src="imageUrl" class="avatar">
<i class="el-icon-upload2 avatar-uploader-icon"></i>
<span v-if="imageUrl" class="repUp">{{$t('system.up_againUp')}}</span>
......@@ -188,12 +209,8 @@
</el-upload>
</el-form-item>
<el-form-item label='行程Logo'>
<el-upload
class="avatar-uploader"
:http-request="UploadImage_Logo"
:show-file-list="false"
:on-success="handleAvatarSuccessLogo"
:before-upload="beforeAvatarUpload">
<el-upload class="avatar-uploader" :http-request="UploadImage_Logo" :show-file-list="false"
:on-success="handleAvatarSuccessLogo" :before-upload="beforeAvatarUpload">
<img v-if="imageUrlLogo" :src="imageUrlLogo" class="avatar">
<i class="el-icon-upload2 avatar-uploader-icon"></i>
<span v-if="imageUrlLogo" class="repUp">{{$t('system.up_againUp')}}</span>
......@@ -205,7 +222,8 @@
</el-form-item>
</el-form>
<div slot="footer" class="dialog-footer">
<button class="hollowFixedBtn" @click="outerVisible = false,resetForm('addMsg')">{{$t('pub.cancelBtn')}}</button>
<button class="hollowFixedBtn"
@click="outerVisible = false,resetForm('addMsg')">{{$t('pub.cancelBtn')}}</button>
&nbsp;
<button class="normalBtn" type="primary" @click="submitForm('addMsg')">{{$t('pub.saveBtn')}}</button>
</div>
......@@ -216,13 +234,13 @@
<script>
export default {
data() {
let reg= /^([1-9][0-9]{0,1}|100)$/
let validateBeginTier=(rule, value, callback)=>{
if(this.addMsg.IsParentCompany=='1'&&value!='1'){
let reg = /^([1-9][0-9]{0,1}|100)$/
let validateBeginTier = (rule, value, callback) => {
if (this.addMsg.IsParentCompany == '1' && value != '1') {
return callback(new Error('总公司初始层级只能为1'));
}else if(this.addMsg.IsParentCompany=='2'&&!reg.test(value)){
} else if (this.addMsg.IsParentCompany == '2' && !reg.test(value)) {
return callback(new Error('层级只能为1~100数字'));
}else{
} else {
callback();
}
}
......@@ -234,12 +252,12 @@
value: '1',
label: this.$t('pub.closeSel')
}],
ProvinceList:[],
CityList:[],
commonDefaultSelect:0,
imageUrl:'',
imageUrlLogo:'',
loading:true,
ProvinceList: [],
CityList: [],
commonDefaultSelect: 0,
imageUrl: '',
imageUrlLogo: '',
loading: true,
chosenIndex: -1,
res: {},
total: 0,
......@@ -267,36 +285,56 @@
IsLeave: 0,
},
rules: { //表单验证
GroupName:[
{ required: true, message: '请选择集团', trigger: 'change' }
],
BName:[
{ required: true, message: '请输入公司名称', trigger: 'blur' }
],
Address:[
{ required: true, message: '请输入地址', trigger: 'blur' }
],
Tel:[
{ required: true, message: '请输入座机', trigger: 'blur' }
],
ContactPersion:[
{ required: true, message: '请输入联系人姓名', trigger: 'blur' }
],
MobilePhone:[
{ required: true, message: '请输入联系人电话', trigger: 'blur' }
],
NoticesName:[
{ required: true, message: '请输入出团通知书名称', trigger: 'blur' }
],
Remarks:[
{ required: false, message: '', trigger: 'blur' }
],
BeginTier:[
{ required: true, validator: validateBeginTier, trigger: 'blur' }
],
CompanyTitle: [
{ required: true, message: '请输入确认件抬头', trigger: 'blur' }
]
GroupName: [{
required: true,
message: '请选择集团',
trigger: 'change'
}],
BName: [{
required: true,
message: '请输入公司名称',
trigger: 'blur'
}],
Address: [{
required: true,
message: '请输入地址',
trigger: 'blur'
}],
Tel: [{
required: true,
message: '请输入座机',
trigger: 'blur'
}],
ContactPersion: [{
required: true,
message: '请输入联系人姓名',
trigger: 'blur'
}],
MobilePhone: [{
required: true,
message: '请输入联系人电话',
trigger: 'blur'
}],
NoticesName: [{
required: true,
message: '请输入出团通知书名称',
trigger: 'blur'
}],
Remarks: [{
required: false,
message: '',
trigger: 'blur'
}],
BeginTier: [{
required: true,
validator: validateBeginTier,
trigger: 'blur'
}],
CompanyTitle: [{
required: true,
message: '请输入确认件抬头',
trigger: 'blur'
}]
},
addMsg: {
......@@ -314,16 +352,16 @@
AirportServicePerson: '',
AirportServicePhone: '',
is_show: '0',
B2BShow:'0',
B2BShow: '0',
BranchManager: '',
IsParentCompany:'1',
BeginTier:'',
Province:'',
City:'',
ConfirmationSignet:'',
GatheringTime:'',
GatheringAddress:'',
TravelLogo:'',
IsParentCompany: '1',
BeginTier: '',
Province: '',
City: '',
ConfirmationSignet: '',
GatheringTime: '',
GatheringAddress: '',
TravelLogo: '',
CompanyTitle: '',
},
updateMsg: {
......@@ -332,11 +370,11 @@
}
},
mounted() {
let userInfo=this.getLocalStorage(); //获取用户登录信息
if(this.$route.query.id!=undefined){ //如果用户从集团页面跳到 公司页面, 那查询公司使用的是 选中集团id. 如果直接进入公司页面, 默认使用该用户登录信息中的 集团id
this.addMsg.RB_Group_Id=this.msg.RB_Group_Id = this.$route.query.id;
}else{
this.addMsg.RB_Group_Id=this.msg.RB_Group_Id = userInfo.RB_Group_id
let userInfo = this.getLocalStorage(); //获取用户登录信息
if (this.$route.query.id != undefined) { //如果用户从集团页面跳到 公司页面, 那查询公司使用的是 选中集团id. 如果直接进入公司页面, 默认使用该用户登录信息中的 集团id
this.addMsg.RB_Group_Id = this.msg.RB_Group_Id = this.$route.query.id;
} else {
this.addMsg.RB_Group_Id = this.msg.RB_Group_Id = userInfo.RB_Group_id
}
this.getProvince();
this.getList();
......@@ -352,7 +390,7 @@
var path = "/Upload/Temporary/";
this.UploadSelfFileT(path, newArr, x => {
this.imageUrl = this.domainManager().ViittoFileUrl + x.data.FilePath;
this.addMsg.ConfirmationSignet=x.data.FilePath;
this.addMsg.ConfirmationSignet = x.data.FilePath;
});
},
//上传图片
......@@ -363,20 +401,20 @@
var path = "/Upload/Temporary/";
this.UploadSelfFileT(path, newArr, x => {
this.imageUrlLogo = this.domainManager().ViittoFileUrl + x.data.FilePath;
this.addMsg.TravelLogo=x.data.FilePath;
this.addMsg.TravelLogo = x.data.FilePath;
});
},
handleAvatarSuccess(res, file) { //上传
if(res.resultCode==1){
if (res.resultCode == 1) {
var img_path = res.data.FullFilePath
this.addMsg.ConfirmationSignet=res.data.FilePath
this.addMsg.ConfirmationSignet = res.data.FilePath
this.imageUrl = img_path
}
},
handleAvatarSuccessLogo(res, file) { //上传
if(res.resultCode==1){
if (res.resultCode == 1) {
var img_path = res.data.FullFilePath
this.addMsg.TravelLogo=res.data.FilePath
this.addMsg.TravelLogo = res.data.FilePath
this.imageUrlLogo = img_path
}
},
......@@ -394,7 +432,7 @@
getList() { //获取数据
this.loading = true
this.apipost('admin_get_BranchGetPageList', this.msg, res => {
if(res.data.resultCode == 1) {
if (res.data.resultCode == 1) {
this.DataList = res.data.data.pageData;
this.total = res.data.data.count;
this.loading = false
......@@ -415,7 +453,7 @@
this.employeeList = res.data.data;
}, err => {})
},
submitForm(addMsg) {//提交创建、修改表单
submitForm(addMsg) { //提交创建、修改表单
this.$refs[addMsg].validate((valid) => {
if (valid) {
this.addData()
......@@ -426,9 +464,9 @@
},
addData() { //新增数据
this.apipost('admin_post_BranchSet', this.addMsg, res => {
if(res.data.resultCode == 1) {
if (res.data.resultCode == 1) {
this.$message.success(res.data.message);
this.outerVisible=false;
this.outerVisible = false;
this.getList()
this.resetForm('addMsg');
} else {
......@@ -438,18 +476,20 @@
this.getList();
},
updateData(id) {
this.apipost('admin_get_BranchGet',{branchId:id},res=>{
if(res.data.resultCode == 1) {
this.apipost('admin_get_BranchGet', {
branchId: id
}, res => {
if (res.data.resultCode == 1) {
this.addMsg = res.data.data;
this.getCityList(this.addMsg.Province,2);
this.addMsg.Status=this.addMsg.Status.toString();
this.addMsg.is_show=this.addMsg.is_show.toString();
this.addMsg.B2BShow=this.addMsg.B2BShow.toString();
this.addMsg.IsParentCompany=this.addMsg.IsParentCompany.toString();
this.getCityList(this.addMsg.Province, 2);
this.addMsg.Status = this.addMsg.Status.toString();
this.addMsg.is_show = this.addMsg.is_show.toString();
this.addMsg.B2BShow = this.addMsg.B2BShow.toString();
this.addMsg.IsParentCompany = this.addMsg.IsParentCompany.toString();
this.imageUrl = this.addMsg.ConfirmationSignet;
this.imageUrlLogo=this.addMsg.TravelLogo;
}else{}
},err=>{})
this.imageUrlLogo = this.addMsg.TravelLogo;
} else {}
}, err => {})
},
handleCurrentChange(val) {
this.msg.pageIndex = val;
......@@ -459,21 +499,23 @@
this.msg.pageIndex = 1;
this.currentPage = 1
},
closeChangeMachie(done){//弹出框关闭初始化弹框内表单
closeChangeMachie(done) { //弹出框关闭初始化弹框内表单
done();
this.resetForm('addMsg');
},
resetForm(formName) {//弹出框取消 初始化谈框内表单
resetForm(formName) { //弹出框取消 初始化谈框内表单
this.$refs[formName].resetFields();
this.addMsg.Id='-1'
this.addMsg.ConfirmationSignet='';
this.addMsg.TravelLogo='';
this.addMsg.Id = '-1'
this.addMsg.ConfirmationSignet = '';
this.addMsg.TravelLogo = '';
this.imageUrl = '';
this.imageUrlLogo='';
this.imageUrlLogo = '';
},
//获取城市列表
getProvince() {
let msg = { Id: 2 };
let msg = {
Id: 2
};
this.apipost(
"dict_post_Destination_GetChildList",
msg,
......@@ -484,12 +526,14 @@
);
},
//根据省份选择获取城市
getCityList(Id,type) {
getCityList(Id, type) {
this.CityList = [];
if(type==1){
if (type == 1) {
this.addMsg.City = "";
}
let msg = { Id: Id };
let msg = {
Id: Id
};
this.apipost(
"dict_post_Destination_GetChildList",
msg,
......@@ -501,4 +545,5 @@
},
},
}
</script>
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