You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
pifa/pages/member/index.vue

601 lines
14 KiB

6 months ago
<template>
<view class="member">
<u-navbar :title="title" :border-bottom="false" backIconColor="#fff" title-color="#fff" :background="background"></u-navbar>
<view class="member-hd" v-if="showTtype == 1 || showTtype == 2">
<view class="title">商业类型</view>
<view class="tab">
<view class="item" :class="tabIndex1 == 0?'item-on':''" @click="tabItem1(0)">企业商户</view>
<view class="item" :class="tabIndex1 == 1?'item-on':''" @click="tabItem1(1)">个体工商户</view>
</view>
</view>
<view class="member-bd" v-if="showTtype == 1 || showTtype == 2">
<view class="a">
<view class="item">
<view class="l">店铺名称</view>
<view class="r">
<input v-model="shop_name" type="text" placeholder="填写店铺名称或公司名称" />
</view>
</view>
<view class="item">
<view class="l">主营品类</view>
<input type="text" disabled style="text-align: right;" placeholder="可多选" />
</view>
<view class="items">
<view class="li" v-for="(a,i) in list" :key="i" :class="a.isClick?'li-on':''" @click="tabItem(i)">{{a.name}}</view>
</view>
</view>
<view class="a">
<view class="item">
<view class="l">联系人</view>
<view class="r">
<input v-model="real_name" type="text" placeholder="填写联系人" />
</view>
</view>
<view class="item">
<view class="l">联系人电话</view>
<view class="r">
<input v-model="mobile" type="number" placeholder="填写联系人电话" />
</view>
</view>
<view class="item">
<view class="l">服务城市</view>
<picker style="flex: 1;" mode="multiSelector" @change="multiChange" @columnchange="columnChange" value="{{multiIndex}}" :range="multiArray" range-key="name">
<view class="pbox" :style="{'color': cityInfo.province?'#303030':'gray' }">
{{cityInfo.province?cityInfo.province+cityInfo.city+cityInfo.area:'请选择服务城市'}}
</view>
</picker>
<image src="https://hys.royaum.com.cn/static/caigou/icon-arrow.png"></image>
</view>
</view>
</view>
<view class="member-bd" style="margin-top: 200rpx;" v-if="showTtype == 3 || showTtype == 4">
<view class="b">
<image src="https://hys.royaum.com.cn/static/caigou/success.png"></image>
<view class="title">{{info.apply_status == 10?'待审核':'当前已认证'}}</view>
</view>
</view>
<view class="member-fd" v-if="showTtype <= 3">
<view class="btn" v-if="showTtype == 1" @click="toSubmit()">立即提交合作意向</view>
<view class="btn" v-if="showTtype == 2" @click="toSubmit1()">编辑并提交</view>
<view class="btn" v-if="showTtype == 3" @click="toSubmit2()">立即修改</view>
</view>
</view>
</template>
<script>
import * as AddressApi from '@/api/address'
import * as newFunApi from '@/api/newFun'
import Config from '@/core/config'
import * as CaptchaApi from "@/api/captcha";
export default{
data() {
return {
title: "",
showTtype: 5,
tabIndex1: 0,
background: {
background: 'url(https://hys.royaum.com.cn/static/news1/bg@2x1.png) center top no-repeat',
backgroundSize: '100% auto',
},
list: [{
name: "大小家电",
isClick: false,
index: 0
},{
name: "家具家居",
isClick: false,
index: 1
},{
name: "家装建材",
isClick: false,
index: 2
},{
name: "3C数码",
isClick: false,
index: 3
},{
name: "日用百货",
isClick: false,
index: 4
},{
name: "生鲜超市",
isClick: false,
index: 5
},{
name: "母婴用品",
isClick: false,
index: 6
},{
name: "美妆护肤",
isClick: false,
index: 7
},{
name: "社区团购",
isClick: false,
index: 8
},{
name: "餐饮酒店",
isClick: false,
index: 9
},{
name: "文体户外",
isClick: false,
index: 10
},{
name: "物业房产",
isClick: false,
index: 11
},{
name: "菜鸟驿站",
isClick: false,
index: 12
},{
name: "其它",
isClick: false,
index: 13
}],
cityInfo: {
province: '',
city: '',
area: ''
},
multiIndex: [0, 0],
multiArray: [],
multiData: [],
province_id: "",
city_id: "",
info: {},
form: {
name: '',
phone: '',
region: [],
detail: ''
},
isClick: true
}
},
onLoad() {
this.getProvinceAll();
this.getInfo();
},
methods: {
toSubmit2() {
this.showTtype = 2
},
async getInfo() {
const that = this;
const { status, data, message } = await newFunApi.getApplyInfo({});
if(status == 200){
this.info = data.info;
if(!data.info){
this.showTtype = 1
this.title="申请服务商"
}else if(data.info && data.info.apply_status == 20){
this.showTtype = 4
this.title= "我的服务商"
}else if(data.info && data.info.apply_status == 10){
this.showTtype = 3
this.real_name = data.info.real_name
this.mobile = data.info.mobile
this.tabIndex1 = (data.info.shop_type == 10?1:0)
this.shop_name = data.info.shop_name
this.business = data.info.business
if(data.info && data.info.business){
let business = data.info.business.split(",");
business.map(a=>{
that.list.map(b=>{
if(a == b.name){
b.isClick = true
}
})
})
}
this.title="编辑服务商"
this.cityInfo.province = data.info.city.split("-")[0]
this.cityInfo.city = data.info.city.split("-")[1]
this.form.region = [{
label: this.cityInfo.province
}, {
label: this.cityInfo.city
}]
}
}
},
async toSubmit() {
if(!this.shop_name){
uni.showToast({
icon: "none",
title: "店铺名称不能为空!"
})
return ;
}
if(!this.business){
uni.showToast({
icon: "none",
title: "请选择主营类目!"
})
return ;
}
if(!this.real_name){
uni.showToast({
icon: "none",
title: "联系人不能为空!"
})
return ;
}
if(!/^1[3456789]\d{9}$/.test(this.mobile)){
uni.showToast({
icon: "none",
title: "联系人电话不能为空!"
})
return ;
}
if(!this.cityInfo.province){
uni.showToast({
icon: "none",
title: "服务城市不能为空!"
})
return ;
}
if(this.isClick == false){
return ;
}
this.isClick = false;
const that = this;
console.log({
real_name: this.real_name,
mobile: this.mobile,
shop_type: this.tabIndex1 == 0?10: 20,
shop_name: this.shop_name,
business: this.business,
city: this.cityInfo.province+"-"+this.cityInfo.city,
})
const { status, data, message } = await newFunApi.applyProviders({
real_name: this.real_name,
mobile: this.mobile,
shop_type: this.tabIndex1 == 0?10: 20,
shop_name: this.shop_name,
business: this.business,
city: this.cityInfo.province+"-"+this.cityInfo.city,
})
if(status == 200) {
uni.showToast({
title: "提交成功"
})
this.isClick = true;
setTimeout(()=>{
that.getInfo();
},1000)
}else{
uni.showToast({
icon: "none",
title: message
})
this.isClick = true;
}
},
async toSubmit1() {
if(!this.shop_name){
uni.showToast({
icon: "none",
title: "店铺名称不能为空!"
})
return ;
}
if(!this.business){
uni.showToast({
icon: "none",
title: "请选择主营类目!"
})
return ;
}
if(!this.real_name){
uni.showToast({
icon: "none",
title: "联系人不能为空!"
})
return ;
}
if(!/^1[3456789]\d{9}$/.test(this.mobile)){
uni.showToast({
icon: "none",
title: "联系人电话不能为空!"
})
return ;
}
if(!this.cityInfo.province){
uni.showToast({
icon: "none",
title: "服务城市不能为空!"
})
return ;
}
if(this.isClick == false){
return ;
}
this.isClick = false;
const that = this;
const { status, data, message } = await newFunApi.editApplyProviders({
real_name: this.real_name,
mobile: this.mobile,
shop_type: this.tabIndex1 == 0?10: 20,
shop_name: this.shop_name,
business: this.business,
city: this.cityInfo.province+"-"+this.cityInfo.city,
})
if(status == 200) {
uni.showToast({
title: "提交成功"
})
this.isClick = true;
setTimeout(()=>{
that.getInfo();
},1000)
}else{
uni.showToast({
icon: "none",
title: message
})
this.isClick = true;
}
},
async getProvinceAll() {
let {
status,
message,
data
} = await AddressApi.province();
if (status == 200) {
this.multiData = data.list;
var multiIndex = this.multiIndex;
this.multiArray = [
this.multiData,
this.multiData[0].children,
// this.multiData[0].children[0].children
]
}
},
// 获取多列的索引
multiChange: function(e) {
this.multiIndex = e.detail.value;
let a_name = this.multiArray[0][e.detail.value[0]].name;
let a_id = this.multiArray[0][e.detail.value[0]].id;
let b_name = this.multiArray[1][e.detail.value[1]].name;
let b_id = this.multiArray[1][e.detail.value[1]].id;
// let c_name = this.multiArray[2][e.detail.value[2]].name;
// let c_id = this.multiArray[2][e.detail.value[2]].id;
this.cityInfo.province = a_name;
this.cityInfo.city = b_name;
// this.cityInfo.area = c_name;
this.form.region = [{
value: a_id,
label: a_name
}, {
value: b_id,
label: b_name
},
// {
// value: c_id,
// label: c_name
// }
];
},
// 选择列
columnChange: function(e) {
var _this = this;
var columnIndex = e.detail.column;
var columnValue = e.detail.value;
_this.multiIndex[columnIndex] = columnValue;
this.multiArray = [
_this.multiData,
_this.multiData[_this.multiIndex[0]].children,
// _this.multiData[_this.multiIndex[0]].children[_this.multiIndex[1]].children
]
},
tabItem(i){
this.list[i].isClick = !this.list[i].isClick;
let arr = [];
this.list.map(a=>{
if(a.isClick){
arr.push(a.name)
}
})
this.business = arr.join(",")
},
tabItem1(i){
this.tabIndex1 = i
},
async getList() {
uni.showLoading({
title:"加载中"
})
const {status, data} = await newFunApi.inviteGetList({});
if(status == 200){
uni.hideLoading();
this.list = data.list.data;
this.total = data.list.total
}
},
}
}
</script>
<style lang="scss" scoped>
.member{
background: #f5f5f5 url(https://hys.royaum.com.cn/static/news1/bg@2x1.png) center top no-repeat;
background-size: 100% auto;
padding-bottom: 160rpx;
min-height: 100vh;
&-hd{
width: 702rpx;
height: 202rpx;
background: #FFFFFF;
border-radius: 10rpx;
margin: 0 auto;
padding: 20rpx 30rpx 0;
box-sizing: border-box;
margin-top: 200rpx;
.title{
font-weight: 400;
font-size: 34rpx;
color: #333333;
}
.tab{
display: flex;
justify-content: space-between;
margin-top: 20rpx;
.item{
width: 306rpx;
line-height: 80rpx;
background: #FFFFFF;
border-radius: 10rpx;
border: 1px solid #CCCCCC;
text-align: center;
font-size: 30rpx;
color: #666666;
&-on{
border-color: #F34A40;
color: #F34A40;
}
}
}
}
&-bd{
padding: 0 25rpx;
overflow: hidden;
.b{
padding: 120rpx 30rpx;
background-color: #fff;
background: #FFFFFF;
border-radius: 10rpx;
margin-top: 20rpx;
.title{
font-size: 36rpx;
color: #222222;
text-align: center;
margin-top: 30rpx;
}
image{
width: 189rpx;
height: 166rpx;
display: block;
margin: 0 auto;
margin-top: 80rpx;
}
}
.a{
padding: 0 30rpx;
background-color: #fff;
background: #FFFFFF;
border-radius: 10rpx;
margin-top: 20rpx;
.item{
padding: 25rpx 0;
display: flex;
align-items: center;
border-top: 1px solid #E9E9E9;
&:first-child{
border-top-color: #fff;
}
.l{
font-size: 28rpx;
color: #222222;
height: 50rpx;
line-height: 50rpx;
width: 200rpx;
}
input{
flex: 1;
font-size: 28rpx;
color: #222222;
height: 50rpx;
line-height: 50rpx;
}
.code{
font-weight: 400;
font-size: 28rpx;
color: #F34A40;
}
image{
width: 11rpx;
height: 20rpx;
margin: 0;
}
}
.items{
overflow: hidden;
width: 110%;
.li{
min-width: 152rpx;
line-height: 70rpx;
background: #fff;
border-radius: 10rpx;
text-align: center;
margin-bottom: 20rpx;
margin-right: 11rpx;
float: left;
font-size: 28rpx;
color: #333333;
border: 1px solid #E2E2E2;
&-on{
color: #F34A40;
border: 1px solid #F34A40;
}
}
}
.tips{
width: 662rpx;
min-height: 246rpx;
background: #FFF6F5;
border-radius: 10rpx;
padding: 20rpx;
box-sizing: border-box;
margin: 10rpx auto;
line-height: 50rpx;
}
.rule{
display: flex;
align-items: center;
font-size: 24rpx;
color: #333333;
padding: 20rpx 0;
image{
width: 30rpx;
height: 30rpx;
margin: 0;
margin-right: 10rpx;
}
text{
color: #F34A40;
}
}
}
}
&-fd{
height: 140rpx;
width: 100%;
position: fixed;
left: 0;
bottom: 0;
z-index: 22;
background-color: #FFFFFF;
display: flex;
justify-content: center;
align-items: center;
.btn{
width: 662rpx;
height: 90rpx;
line-height: 90rpx;
background: #F34A40;
border-radius: 90rpx;
text-align: center;
font-size: 32rpx;
color: #FFFFFF;
&-on{
background-color: #ccc;
}
}
}
}
</style>