123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338 |
- <template>
- <view class="flowDetails">
- <!-- #ifdef H5 -->
- <!-- <view class="tab">
- <u-icon name="arrow-left" color="#fff" size="40" @click="goBack"></u-icon>
- <span>流量卡</span>
- <span></span>
- </view> -->
- <u-navbar back-text=" " :custom-back='goBack' title="流量卡" :border-bottom="false" :background="{backgroundColor: '#d52e4c'}" back-icon-color="#fff" title-color="#fff"></u-navbar>
- <!-- #endif -->
-
- <u-toast ref="uToast" />
- <view class="img">
- <image :src="showData.info.flow_images[1]" mode="widthFix"></image>
- </view>
- <view class="selectphone u-flex u-row-between" @click="openShow" v-if="showData.select_num_status==1">
- <text>选择号码</text>
- <view class="">
- <text class="selectText" v-if="current==null">点击选择号码,不选将随机选号</text>
- <text class="selectText1" v-else >{{boxList1[current]}}</text>
- <u-icon name="arrow-right"></u-icon>
- </view>
- </view>
- <view class="form">
- <view class="formInput">
- <u-form :model="form" label-width="220">
- <u-form-item label="姓名" v-if="!orderId">
- <u-input v-model="form.name" placeholder-style="font-size:26rpx;" :clearable="false"
- placeholder="请输入真实姓名" />
- </u-form-item>
- <view class="" v-if="!configAll.system_sms_open&&!orderId">
- <u-form-item label="手机号" >
- <u-input v-model="form.phone" placeholder-style="font-size:26rpx;" :clearable="false"
- placeholder="请输入手机号" />
- </u-form-item>
- </view>
-
- <u-form-item label="手机号" v-if="configAll.system_sms_open&&!orderId">
- <!-- -->
- <view class="sendSMS" v-if="configAll.system_sms_open">
- <view>
- <input type="number" maxlength="11" v-model="form.phone" placeholder-style="font-size:28rpx;" :clearable="false" placeholder="请输入手机号"/>
- </view>
- <view class="sms" >
-
- <u-verification-code :seconds="seconds" start-text="验证码" @end="end" @start="start" ref="uCode"
- @change="codeChange"></u-verification-code>
- <view class="tips" @tap="getCode" >{{tips}}</view>
- </view>
- </view>
- <!-- -->
-
-
- </u-form-item>
- <u-form-item label="验证码" v-if="configAll.system_sms_open&&!orderId">
- <input maxlength="4" v-model="form.sms_code" placeholder-style="font-size:28rpx;" :clearable="false" placeholder="请输入验证码"/>
- </u-form-item>
- <u-form-item label="身份证号" v-if="!orderId">
- <u-input v-model="form.id_no" placeholder-style="font-size:26rpx;" :clearable="false"
- placeholder="请输入身份证号" />
- </u-form-item>
- <u-form-item label="城市" v-if="!orderId">
- <view class="county" @tap="countyHide=!countyHide">
- {{countyName}}
- </view>
- <!-- 快手小程序 出现异常抖动更换 -->
- <!-- <u-select v-model="countyHide" :default-value='countyIndex' mode="mutil-column-auto" lchild-name="children" :list="selector" @confirm="confirm"></u-select> -->
- <w-picker :visible.sync="countyHide" mode="region" :value="countyIndex" default-type="value"
- :hide-area="false" @confirm="onConfirm($event,'region')" @cancel="onCancel" ref="region">
- </w-picker>
- </u-form-item>
- <u-form-item label="详细地址" v-if="!orderId">
- <u-input v-model="form.address" placeholder-style="font-size:26rpx;" :clearable="false"
- placeholder="请输入街道/镇+村/小区+门牌号 " />
- </u-form-item>
- </u-form>
- <view class="" v-if="showData.card_status==1||orderId">
- <view class="upload">
- <view class="flexJu">
- <image src="@/static/img/uUploadID11.png" mode="widthFix"></image>
- <image class="ding" src="../../static/img/uploadadd.png" mode=""></image>
- <u-upload ref="uUpload1" :multiple="false" width="600rpx" height="300rpx" max-count="1" @on-change="progress1"
- :action="action"></u-upload>
- </view>
- <view style="font-size: 32rpx;color: #333;margin-top: 20rpx;margin-top: 30rpx;">身份证正面照</view>
- <view style="color: rgba(187, 187, 187);font-size: 20rpx;margin-top: 10rpx;">
- 证件四角边缘空隙2厘米以上,手机横排,照片清晰不模糊,无水印,无反光,无PS</view>
- </view>
- <view class="upload">
- <view class="flexJu">
- <image src="../../static/img/uUploadID22.png" mode=""></image>
- <image class="ding" src="../../static/img/uploadadd.png" mode=""></image>
- <u-upload max-count="1" :multiple="false" ref="uUpload2" width="600rpx" height="300rpx" @on-change="progress2"
- :action="action"></u-upload>
- </view>
- <view style="font-size: 32rpx;color: #333;margin-top: 20rpx;margin-top: 30rpx;">身份证反面照</view>
- <view style="color: rgba(187, 187, 187);font-size: 20rpx;margin-top: 10rpx;">
- 证件四角边缘空隙2厘米以上,手机横排,照片清晰不模糊,无水印,无反光,无PS</view>
- </view>
- <view class="upload">
- <view class="flexJu">
- <image src="../../static/img/uUploadID33.png" mode=""></image>
- <image class="ding" src="../../static/img/uploadadd.png" mode=""></image>
- <u-upload max-count="1" :multiple="false" ref="uUpload3" width="600rpx" height="300rpx" @on-change="progress3"
- :action="action"></u-upload>
- </view>
- <view style="font-size: 32rpx;color: #333;margin-top: 20rpx;margin-top: 30rpx;">本人免冠正面照</view>
- <view style="color: rgba(187, 187, 187);font-size: 20rpx;margin-top: 10rpx;">
- 无需手持身份证,胸部以上,露出双肩,人像面部比例不低于1/3,无水印,无反光,无PS</view>
- </view>
- <!-- <view class="card">
- <view class="cardImg u-flex u-row-between">
- <image src="../../static/img/id1@2x.png" mode=""></image>
- <image src="../../static/img/id2@2x.png" mode=""></image>
- </view>
- <view class="cardTitle">
- 身份证正面照
- </view>
- <view class="intro">
- 证件四角边缘空隙2厘米以上,手机横拍,照片清晰
- 不模糊,无水印,无反光,无PS。
- </view>
- </view>
-
- <view class="card">
- <view class="cardImg u-flex u-row-between">
- <image src="../../static/img/id4@2x.png" mode=""></image>
- <image src="../../static/img/id2@2x.png" mode=""></image>
- </view>
- <view class="cardTitle">
- 身份证反面照
- </view>
- <view class="intro">
- 证件四角边缘空隙2厘米以上,手机横拍,照片清晰
- 不模糊,无水印,无反光,无PS。
- </view>
- </view>
- <view class="card">
- <view class="cardImg u-flex u-row-between">
- <image src="../../static/img/id3@2x.png" mode=""></image>
- <image src="../../static/img/id2@2x.png" mode=""></image>
- </view>
- <view class="cardTitle">
- 本人免冠正面照
- </view>
- <view class="intro">
- 无需手持身份证,胸部以上,露出双肩,人像面部比例
- 不低于1/3,无水印,无反光,无PS。
- </view>
- </view> -->
- </view>
- <view class="btn" @tap="apply()" v-if="!orderId">
- 立即领取
- </view>
- <view class="btn" @tap="submitOrder()" v-if="orderId">
- 立即提交
- </view>
- </view>
- </view>
- <!-- <view class="img">
- <image v-for="(item,index) in showData.info.flow_images" :key="index" v-if="index>1" :src="item"
- mode="widthFix"></image>
- </view> -->
- <view class="img">
- <image
- v-for="(item,index) in Object.keys(showData.info.flow_images).map((i,j)=>j?showData.info.flow_images[i].split(','):'').filter(i=>i).flat()"
- :key="index"
- :src="item"
- mode="widthFix"
- ></image>
- </view>
- <view class="popupBox">
- <view class="maskName" v-if="login_show"></view>
- <view class="newForm" v-if="login_show">
- <view class="alertContent">
- <view class="title">温馨提示</view>
- <view class="content">{{login_content}}</view>
- <view class="u-flex u-col-center u-row-center btn" style="border-top: 1px solid #ececec;">
- <text style="border-right: 1px solid #ececec;" @tap="login_cancel">取消</text>
- <text style="color: #D52E4C;" v-if="mixin_type=='TOUTIAO'" @tap="userLogin">确认</text>
- <button v-else
- style="box-shadow: none; background: transparent;box-sizing:border-box;width: 50%;border: 0px solid #f3f3f3;color: #D52E4C;"
- type="default" open-type="getPhoneNumber" @getphonenumber="decryptPhoneNumber">确认</button>
- </view>
- </view>
- </view>
- </view>
- <u-popup v-model="show" mode="bottom" border-radius="30" height="1000">
- <view class="popup">
- <view class="search u-flex u-row-between">
- <view class="inputBox u-flex u-row-between">
- <input type="text" confirm-type="done" maxlength="11" v-model="searchNumber">
- <view class="searchIcon" @click="query" >
- <image src="../../static/img/whitesearch.png" mode=""></image>
- </view>
- </view>
- <view class="check">
- <u-checkbox-group size='20'>
- <u-checkbox shape="circle" @change="search_lastChange" active-color="#E30029"
- v-model="searchChecked" style="white-space: nowrap;">尾号</u-checkbox>
- </u-checkbox-group>
- </view>
- </view>
- <view class="" v-if="empty" style="text-align: center;margin-top:100rpx">
- 没有找到该号码
- </view>
- <view class="numberList u-flex u-row-between">
- <view class="numberItem" :class="{'selectItem':index==current}" v-for="(item,index) in boxList"
- @tap="ListClick(index)" :key="index">
- <view v-html="item"></view>
- </view>
- </view>
-
- <view class="last u-flex u-row-center" @click="query">
- <image src="../../static/img/reset.png" mode=""></image>
- <text>换一批</text>
- </view>
- <view class="btn" @tap="submit">
- 确认选择
- </view>
- </view>
- </u-popup>
- </view>
- </template>
- <script>
- import wPicker from "@/components/w-picker/w-picker.vue"
- export default {
- data() {
- return {
- empty:false,
- searchNumber:'',
- orderId:'',
- tips:'',
- seconds: 60,//倒计时秒数
- // 上传地址
- action: '',
- current: null,
- // 列表参数
- listData: {
- city_id: "city_id", //地区id 'city_id'全部
- exclude_num: [], //排除 复选 值
- is_activity: 0, //是否是优惠号码
- keyword: ["1", "", "", "", "", "", "", "", "", "", ""], //搜索内容,模糊就是字符串,精准就是数组
- limit: 20,
- network: "",
- num_max: "", //数字较多,传数字
- page: 1, //
- price_max: "", //价格最高数字
- price_min: "", //价格最低数字
- rule_name: "", //规律名,AAAA什么的
- rule_position: "tail", //规律位置,middle中间,tail尾部
- search_last: 1, //0,1是否搜索尾部
- search_type: "precise", //fuzzy模糊,precise精准
- sort: "", //price_asc价格从低到高,price_desc价格从高到低
- is_offer: 0, //是否为特价号
- },
- page: 1,
- boxList: [],
- boxList1: [],
- searchChecked: false,
- show: false,
- id: '',
- countyName: '城市名称',
- countyHide: false,
- countyIndex: [1], //城市弹窗下标
- selector: [],
- showData: {
- info: {
- flow_images: []
- }
- }, //号码详情
- form: {
- sms_code:'', // 验证码
- address: '', //详细地址
- chanId: '',
- county: 1480, //城市ID,区县id
- id_no: '', //身份号码,
- mobile_id: '',
- name: '', //姓名
- pay_type: 5,
- phone: '', //手机号
- return_url: '',
- clickid: '',
- open_idcard_face_img:'',
- open_idcard_back_img:'',
- open_face_img:'',
- orderId:'',
- no:''
- },
- chanId:''
- }
- },
- onLoad(option) {
- if(option.chanId){
- uni.setStorageSync('chanId', option.chanId);
- this.chanId=option.chanId
- }else{
- uni.removeStorageSync('chanId');
- }
- // if(option.chanId){
- // this.form.chanId=option.chanId
- // }
- this.action = this.$httpUrl + '/api/common/upload'
-
- console.log(option)
- if (option.id) {
- this.showDetails(option.id)
- this.form.mobile_id = option.id
- }
- if (option.orderId) {
- this.orderId=option.orderId
- }
-
- },
-
- onShow() {
- this.area_tree()
- },
-
- components: {
- wPicker
- },
- methods: {
- goBack(){
- if(getCurrentPages().length==1){
- return
- }else{
- uni.redirectTo({
- url:'/pages/flow/flow?chanId='+this.chanId
- })
- }
-
- },
- openShow(){
-
- // this.show=true
- // this.searchNumber=''
- // this.phoneList()
- this.show=true
- if(this.current==null){
- this.searchNumber=''
- this.phoneList()
- }
- },
- // 获取短信
- getCode() {
- if(this.$refs.uCode.canGetCode) {
- if(this.form.phone==''){
- this.$refs.uToast.show({
- title: '请输入手机号',
- type: 'error ',
- })
- return;
- }
- if(!this.$check.checkMobile(this.form.phone)){
- this.$refs.uToast.show({
- title: '请输入正确手机号的格式',
- type: 'error ',
- })
- return;
- }
- // this.$u.toast('验证码已发送');
- // this.$refs.uCode.start();
- this.$http.send({mobile:this.form.phone,event:'order'})
- .then(res=>{
- if(res.data.code==1){
- this.$u.toast('验证码已发送');
- this.$refs.uCode.start();
-
- }else{
- this.$refs.uToast.show({
- title: res.data.msg,
- type: 'error ',
- })
- }
- })
- } else {
- this.$u.toast('倒计时结束后再发送');
- }
- },
- codeChange(text) {
- this.tips = text;
- },
- start() {
- this.$u.toast('倒计时开始');
- },
- end() {
- this.$u.toast('倒计时结束');
- },
- progress1(res, index, lists, name) {
- // console.log(JSON.parse(res.data))
- if (JSON.parse(res.data).code == 0) {
- this.$refs.uToast.show({
- title: JSON.parse(res.data).msg,
- type: 'error ',
- })
- this.$refs.uUpload1.clear()
- }
- },
- progress2(res, index, lists, name) {
- // console.log(JSON.parse(res.data))
- if (JSON.parse(res.data).code == 0) {
- this.$refs.uToast.show({
- title: JSON.parse(res.data).msg,
- type: 'error ',
- })
- this.$refs.uUpload2.clear()
- }
- },
- progress3(res, index, lists, name) {
- // console.log(JSON.parse(res.data))
- if (JSON.parse(res.data).code == 0) {
- this.$refs.uToast.show({
- title: JSON.parse(res.data).msg,
- type: 'error ',
- })
- this.$refs.uUpload3.clear()
- }
- },
- ListClick(index) {
- if (this.current != index) {
- this.current = index
- }
- },
- submit() {
- if(this.current==null){
- this.$refs.uToast.show({
- title: '请选择号码',
- type: 'error ',
- })
- return
- }else{
- this.show = false
- }
- },
- // 查询按钮
- query() {
- this.phoneList()
- },
- // 按照账号规则匹配
- numberTypeHits(type, no) {
- let arrStr = ''
- type.forEach((item, index) => {
- if (item) {
- arrStr += '<span class="active">' + no[index] + '</span>'
- } else {
- arrStr += no[index]
- }
- })
- return arrStr
- },
- // 搜索选中红色
- numberType(val,index) {
- let str = val+'';
- // console.log(str)
- let html, num;
- let first=str.substr(0, 3)
- let second=str.substr(3, 4)
- let third=str.substr(7, str.length)
- if (!this.searchNumber) {
-
- return '<span class="active2">' + first + '</span>' + second +
- '<span class="active2">' + third + '</span>'
- // return '<span class="active">' + str.substr(0, 3) + '</span>' + str.substr(3, 4) +
- // '<span class="active">' + str.substr(7, str.length) + '</span>'
-
- // if (this.searchNumber!= ["1", "", "", "", "", "", "", "", "", "", ""].toString()) {
- // let arrStr = ''
- // let strArr = str.split('');
- // let list = this.searchNumber
- // strArr.forEach((item, index) => {
- // if (item == list[index] && index != 0) {
- // arrStr += '<span class="active">' + item + '</span>'
- // } else {
- // arrStr += item
- // }
- // })
- // return arrStr
- // } else {
-
- // }
- } else {
- return str.replace(new RegExp(this.searchNumber, 'g'), '<span class="active">' + this.searchNumber + '</span>')
-
- }
- // if (this.searchNumber) {
-
- // return str.replace(new RegExp(num, 'g'), '<span class="active">' + num + '</span>')
- // } else {
- // return '<span class="active1">' + str.substr(0, 3) + '</span>' + str.substr(3, 4) +
- // '<span class="active1">' + str.substr(7, str.length) + '</span>'
- // }
- },
- // 初始化列表
- phoneList() {
- this.boxList = []
- this.boxList1 = []
- this.current=null
- this.$http.searchList({'product_sku':this.showData.product_sku}).then(res => {
- if (res.data.code == 1) {
- let boxList = res.data.data
- boxList.forEach((item,index) => {
- if(this.searchNumber&&!this.searchChecked){
- if((item+'').indexOf(this.searchNumber)!=-1){
- this.boxList1.push(JSON.parse(JSON.stringify(item)))
- let item1='<div>' + this.numberType(item,index) + '</div>'
- this.boxList.push(item1)
-
-
- }else{
- return
- }
-
- }if(this.searchNumber&&this.searchChecked){
- // console.log((boxList+'').substr((boxList+'').substr(7, (boxList+'').length),this.searchNumber)
- if((item+'').substr(-this.searchNumber.length)==this.searchNumber){
- this.boxList1.push(JSON.parse(JSON.stringify(item)))
- item='<div>' + this.numberType(item,index) + '</div>'
- this.boxList.push(item)
- }
-
- }
- else{
- this.boxList1.push(JSON.parse(JSON.stringify(item)))
- item='<div>' + this.numberType(item,index) + '</div>'
- this.boxList.push(item)
- }
-
-
-
- // this.$set(item, 'phoneHtml', '<div>' + this.numberType(item) + '</div>')
- // if (item.hits) {
- // this.$set(item, 'phoneHtml', '<div>' + this.numberTypeHits(item.hits, item
- // .no) + '</div>')
- // } else {
- // this.$set(item, 'phoneHtml', '<div>' + this.numberType(item.no) + '</div>')
- // }
- })
- this.$nextTick(()=>{
- if(this.boxList.length==0){
- this.empty=true
- }else{
- this.empty=false
- }
- })
- }
- })
- },
- // 是否是尾号
- search_lastChange(e) {
- this.listData.search_last = e.value ? 1 : 0
- this.phoneList()
- },
- onConfirm(res) {
- console.log(res)
- this.form.county = res.value[2]
- this.countyName = res.result
- this.countyIndex = res.value
- },
- onCancel() {
- },
- // 区域内容
- area_tree() {
- this.$http.area_tree().then(res => {
- if (res.data.code === 1) {
- this.selector = res.data.data
- console.log(this.selector)
- this.loca()
- }
- });
- },
- // 号码详情界面
- showDetails(id) {
- this.$http.show({
- id: id
- })
- .then(res => {
- if (res.data.code == 1) {
- this.showData = res.data.data
- }
- })
- },
- // 获取本地经纬度
- loca() {
- let this_ = this;
- if (this.mixin_type != 'TOUTIAO' && this.mixin_type != 'H5') {
- ks.getSetting({
- success(res) {
- if (!res.authSetting['scope.userLocation']) {
- //提前向用户发起授权请求
- uni.getLocation({
- type: 'wgs84',
- success: function(res) {
- console.log('当前位置的经度:' + res.longitude);
- console.log('当前位置的纬度:' + res.latitude);
- this_.loAcquire(res.longitude, res.latitude)
- }
- });
- }
- },
- });
- } else if (this_.mixin_type == 'H5') {
- this_.jsonp('https://apis.map.qq.com/ws/location/v1/ip', {
- key: "O7NBZ-PTTCG-OEPQF-I6MTS-YEKCJ-OCFVO",
- output: "jsonp"
- })
- .then(res => {
- console.log(res.result.ad_info);
- let adInfo = res.result.ad_info
- this_.cityId(adInfo.province, adInfo.city, adInfo.district)
- })
- } else {
- uni.getLocation({
- type: 'wgs84',
- highAccuracyExpireTime: 100,
- success: function(res) {
- console.log('当前位置的经度:' + res.longitude);
- console.log('当前位置的纬度:' + res.latitude);
- this_.loAcquire(res.longitude, res.latitude)
- }
- });
- }
- },
- // 根据经纬度查询城市
- loAcquire(longitude, latitude) {
- let this_ = this;
- this.myAmapFun.reverseGeocoder({
- location: {
- latitude: latitude,
- longitude: longitude
- },
- success: function(res) {
- console.log("解析地址成功");
- console.log(res);
- // 根据名称筛选id
- this_.cityId(res.result.address_component.province, res.result.address_component.city,
- res.result.address_component.district)
- },
- fail: function(res) {
- uni.showToast({
- title: '定位失败',
- duration: 2000,
- icon: "none"
- })
- console.log(res);
- },
- complete: function(res) {
- console.log(res);
- }
- })
- },
- // 根据名称筛选id
- cityId(province, city, district) {
- this.selector.forEach((val, i) => {
- if (val.label.slice(0, 2) == province.slice(0, 2) || val.label == province) {
- console.log(val.label)
- console.log(val.value)
- val.children.forEach((item, l) => {
- if (item.label.slice(0, 2) == city.slice(0, 2) || item.label == city) {
- console.log(item.label)
- console.log(item.value)
- item.children.forEach((con, y) => {
- if (con.label.slice(0, 2) == district.slice(0, 2) || con
- .label == district) {
- console.log(con.label)
- console.log(con.value)
- this.countyIndex = [i, l, y]
- this.countyName = val.label + item.label + con.label
- this.form.county = con.value
- }
- })
- }
- })
- }
- })
- },
- // 城市选择id锁定
- confirm(e) {
- console.log(e)
- this.form.county = e[2].value
- this.countyName = e[0].label + e[1].label + e[2].label
- },
- //重新提交订单
- submitOrder(){
- //图片处理
- let files1 = [];
- let files2 = [];
- let files3 = [];
- // 通过filter,筛选出上传进度为100的文件(因为某些上传失败的文件,进度值不为100,这个是可选的操作)
- files1 = this.$refs.uUpload1.lists.filter(val => {
- return val.progress == 100;
- })
- files2 = this.$refs.uUpload2.lists.filter(val => {
- return val.progress == 100;
- })
- files3 = this.$refs.uUpload3.lists.filter(val => {
- return val.progress == 100;
- })
- if(files1[0]==undefined){
- this.$refs.uToast.show({
- title: '请上传身份证正面照',
- type: 'error ',
- })
- return;
- }
- if(files2[0]==undefined){
- this.$refs.uToast.show({
- title: '请上传身份证背面照',
- type: 'error ',
- })
- return;
- }
- if(files3[0]==undefined){
- this.$refs.uToast.show({
- title: '请上传本人免冠正面照',
- type: 'error ',
- })
- return;
- }
- let form={}
- form.id=this.orderId
- form.idcard_face_img=files1[0].response.data.url
- form.idcard_back_img=files2[0].response.data.url
- form.face_img=files3[0].response.data.url
- this.$http.uploadIdentityFlow(form)
- .then(res => {
- console.log(121,res)
-
- if (res.data.code == 1) {
- this.$refs.uToast.show({
- title: res.data.msg,
- type: 'error ',
- })
- setTimeout(()=>{
- uni.navigateBack()
- },1000)
-
- } else {
- this.$refs.uToast.show({
- title: res.data.msg,
- type: 'error ',
- })
- }
- })
- },
- apply() {
- if(this.showData.card_status==1){
- //图片处理
- let files1 = [];
- let files2 = [];
- let files3 = [];
- // 通过filter,筛选出上传进度为100的文件(因为某些上传失败的文件,进度值不为100,这个是可选的操作)
- files1 = this.$refs.uUpload1.lists.filter(val => {
- return val.progress == 100;
- })
- files2 = this.$refs.uUpload2.lists.filter(val => {
- return val.progress == 100;
- })
- files3 = this.$refs.uUpload3.lists.filter(val => {
- return val.progress == 100;
- })
- if(files1[0]==undefined){
- this.$refs.uToast.show({
- title: '请上传身份证正面照',
- type: 'error ',
- })
- return;
- }
- if(files2[0]==undefined){
- this.$refs.uToast.show({
- title: '请上传身份证背面照',
- type: 'error ',
- })
- return;
- }
- if(files3[0]==undefined){
- this.$refs.uToast.show({
- title: '请上传本人免冠正面照',
- type: 'error ',
- })
- return;
- }
-
- this.form.open_idcard_face_img=files1[0].response.data.url
- this.form.open_idcard_back_img=files2[0].response.data.url
- this.form.open_face_img=files3[0].response.data.url
- }
- if(this.current!=null){
-
- this.form.no=this.boxList1[this.current]
- }
- if (this.form.name == '') {
- this.$refs.uToast.show({
- title: '请输入姓名',
- type: 'error ',
- })
- return;
- }
- if (!this.$check.checkName(this.form.name)) {
- this.$refs.uToast.show({
- title: '请输入正确的格式',
- type: 'error ',
- })
- return;
- }
- if (this.form.phone == '') {
- this.$refs.uToast.show({
- title: '请输入手机号',
- type: 'error ',
- })
- return;
- }
- if (!this.$check.checkMobile(this.form.phone)) {
- this.$refs.uToast.show({
- title: '请输入正确手机号的格式',
- type: 'error ',
- })
- return;
- }
- if(this.form.sms_code=='' && this.configAll.system_sms_open){
- this.$refs.uToast.show({
- title: '请输入验证码',
- type: 'error ',
- })
- return;
- }
- if (this.form.id_no == '') {
- this.$refs.uToast.show({
- title: '请输入身份证号',
- type: 'error',
- })
- return;
- }
- if (!this.$check.IdName(this.form.id_no)) {
- this.$refs.uToast.show({
- title: '请输入正确的身份证',
- type: 'error',
- })
- return;
- }
- if (this.form.address == '') {
- this.$refs.uToast.show({
- title: '请输入地址',
- type: 'error ',
- })
- return;
- }
- this.applyType = false
- //#ifdef MP-TOUTIAO
- this.form.pay_type = 4
- //#endif
- // 是否是H5支付
- if (this.mixin_type == 'H5') {
- this.form.pay_type = 2
- }
- //#ifdef H5
- const res = window.location.href;
- if (res.indexOf('?') === -1) return
- const URL = res.split('?')[1];
- let obj = {}; // 声明参数对象
- let arr = URL.split("&");
- for (let i = 0; i < arr.length; i++) {
- let arrNew = arr[i].split("=");
- obj[arrNew[0]] = arrNew[1];
- }
- this.form.return_url = 'https://mmlh.vip/build/#/'
- this.form.clickid = obj.clickid
-
- //#endif
- this.$http.apply(this.form)
- .then(res => {
- console.log(res)
- //#ifdef H5
- let this_ = this;
- _baq.track("form", {
- assets_id: this_.$assets_id,
- product_name: this_.showData.name,
- product_price: this_.showData.amount
- })
- //#endif
- if (res.data.code == 1) {
- if (res.data.data.without_pay == 0) {
- if (this.mixin_type == 'H5') {
- window.location.href = res.data.data.pay_url
- } else {
- this.pay(res.data.data)
- }
- } else {
- uni.navigateTo({
- url: '/pages/flowOrderDetails/flowOrderDetails?id=' + res.data.data.id,
- });
- }
- } else {
- this.$refs.uToast.show({
- title: res.data.msg,
- type: 'error ',
- })
- }
- })
- },
- //调用支付
- pay(val) {
- let this_ = this;
- uni.getProvider({
- service: 'oauth',
- success: function(res) {
- console.log(res.provider)
- console.log(this_.mixin_type + '来源')
- if (this_.mixin_type != 'TOUTIAO') {
- ks.pay({
- serviceId: '1',
- orderInfo: val.res,
- success(res) {
- console.log(res)
- // 支付成功
- this_.$refs.uToast.show({
- title: '支付成功',
- type: 'success ',
- })
- uni.navigateTo({
- url: '/pages/flowOrderDetails/flowOrderDetails?id=' +
- res.data.data.id,
- });
- },
- fail(e) {
- if (e.errMsg == 'pay:fail request payment cancel') {
- this_.$refs.uToast.show({
- title: '支付取消',
- type: 'error ',
- })
- } else {
- this_.$refs.uToast.show({
- title: '支付失败',
- type: 'error ',
- })
- }
- }
- })
- } else {
- uni.requestPayment({
- "provider": res.provider[0],
- "orderInfo": val.res,
- "service": 5,
- getOrderStatus: res => new Promise((resolve, reject) => {
- console.log(res)
- resolve(res)
- }),
- success(res) {
- console.log(res)
- // 支付成功
- if (res.code == 0) {
- this_.$refs.uToast.show({
- title: '支付成功',
- type: 'success ',
- })
- uni.navigateTo({
- url: '/pages/flowOrderDetails/flowOrderDetails?id=' +
- res.data.data.id,
- });
- } else if (res.code == 4) {
- this_.$refs.uToast.show({
- title: '支付取消',
- type: 'error ',
- })
- } else if (res.code == 1) {
- this_.$refs.uToast.show({
- title: '支付超时',
- type: 'error ',
- })
- } else if (res.code == 2) {
- this_.$refs.uToast.show({
- title: '支付失败',
- type: 'error ',
- })
- } else if (res.code == 3) {
- this_.$refs.uToast.show({
- title: '支付关闭 ',
- type: 'error ',
- })
- } else {
- }
- },
- fail(e) {
- console.log(e)
- }
- })
- }
- }
- });
- },
- }
- }
- </script>
- <style lang="scss">
-
- .tab{
- background-color: rgb(213, 46, 76);
- color: rgb(255, 255, 255);
- height: 44px;
- line-height: 44px;
- display: flex;
- justify-content: space-between;
- padding: 0 3px;
- font-size: 16px;
- font-weight: bold;
- }
- .sendSMS{
- position: relative;
- width: 100%;
- .sms{
- position: absolute;
- right: 0;
- top: 50%;
- transform: translateY(-50%);
- z-index: 11;
- }
- }
- .sms{
- /deep/ .tips{
- width: 168rpx;
- height: 49rpx;
- text-align: center;
- line-height: 49rpx;
- // border: 1rpx solid #D52E4C;
- border-radius: 20rpx;
- font-size: 26rpx;
- color: #fff;
- background-color: $uni-color-BGC;
- margin-top: 4rpx;
- }
- /deep/ input{
- flex: 1;
- }
- }
- .upload {
- position: relative;
- left: 50%;
- transform: translateX(-50%);
- padding: 30rpx;
- margin-bottom: 30rpx;
- border: 3rpx dashed #d52e4c;
- border-radius: 10rpx;
- image {
- width: 220rpx;
- height: 140rpx;
- border-radius: 10rpx;
- }
- //平均分配
- .flexJu{
- display: flex;
- justify-content: space-between;
- }
- .ding {
- position: absolute;
- width: 60rpx;
- height: 50rpx;
- right: 110rpx;
- top: 70rpx;
- }
- .u-upload {
- width: 220rpx;
- height: 140rpx;
- border-radius: 10rpx;
- background-color: #f1cfd5;
- }
- /deep/ .u-list-item {
- margin: 0;
- height: 140rpx !important;
- }
- /deep/ .u-add-wrap {
- opacity: 0;
- }
- }
- page {
- height: 100%;
- }
- .card {
- padding: 30rpx 40rpx 180rpx;
- width: 635rpx;
- background: rgba(255, 255, 255, 0.2);
- border: 2px dashed #D52E4C;
- border-radius: 20rpx;
- margin-bottom: 20rpx;
- overflow: hidden;
- .cardImg {
- image {
- width: 237rpx;
- height: 138rpx;
- }
- }
- .cardTitle {
- font-size: 32rpx;
- color: #333333;
- font-weight: bold;
- margin: 35rpx 0 20rpx;
- }
- .intro {
- font-size: 20rpx;
- line-height: 30rpx;
- color: #BBBBBB;
- }
- }
- .popup {
- position: fixed;
- bottom: 0;
- left: 0;
- right: 0;
- height: 1000rpx;
- position: relative;
- width: 100%;
- max-width: 400px;
- box-sizing: border-box;
- padding: 37rpx 60rpx 69rpx;
- .btn {
- position: absolute;
- bottom: 40rpx;
- width: 630rpx;
- height: 77rpx;
- line-height: 77rpx;
- background: #D52E4C;
- border-radius: 39rpx;
- margin: 20rpx auto;
- text-align: center;
- color: #fff;
- font-size: 32rpx;
- }
- .last {
- image {
- margin-right: 11rpx;
- width: 28rpx;
- height: 28rpx;
- }
- font-size: 24rpx;
- color: #2FA4FF;
- margin: 20rpx auto 20rpx;
- }
- .search {
- .inputBox {
- box-sizing: border-box;
- padding-left: 40rpx;
- width: 480rpx;
- height: 74rpx;
- background: #F1F1F1;
- border-radius: 37rpx;
- input {
- border: none;
- }
- .searchIcon {
- width: 140rpx;
- height: 74rpx;
- background: #D0352D;
- border-radius: 37rpx;
- line-height: 74rpx;
- text-align: center;
- image {
- width: 37rpx;
- height: 37rpx;
- vertical-align: middle;
- }
- }
- }
- }
- .numberList {
- flex-wrap: wrap;
- margin-top: 23rpx;
- max-height: 640rpx;
- overflow: auto;
- .numberItem {
- font-weight: bold;
- margin-bottom: 15rpx;
- line-height: 79rpx;
- text-align: center;
- width: 283rpx;
- height: 79rpx;
- background: #FFFFFF;
- border: 1px solid #E2E2E2;
- border-radius: 12rpx;
- /deep/ .active {
- color: $uni-color-BGC;
- }
- /deep/ .active1 {
- margin: 0 5px;
- }
- /deep/ .active2 {
- color: $uni-color-BGC;
- margin: 0 5px;
- }
- }
- .selectItem {
- color:#fff;
- // border: 2px solid #D52E4C;
- background-color: #D52E4C;
- /deep/ .active {
- color:#fff;
- }
- /deep/ .active2 {
- color:#fff;
- }
-
- // background: #FBEAED;
- }
- }
- }
- .selectphone {
- line-height: 102rpx;
- padding: 0 52rpx;
- margin: 26rpx auto 0;
- width: 701rpx;
- height: 102rpx;
- border: 2px solid #E6028D;
- border-radius: 24rpx;
- text {
- font-size: 25rpx;
- color: #333333;
- }
- .selectText {
- color: #BBBBBB;
- margin-right: 30rpx;
- }
- .selectText1 {
- color: #333;
- margin-right: 30rpx;
- }
- }
- .flowDetails {
- // height: 100%;
- overflow: hidden;
- .img {
- width: 100%;
- display: flex;
- flex-direction: column;
- image {
- width: 100%;
- }
- uni-image {
- display: block;
- }
- }
- .form {
- width: 703rpx;
- box-sizing: border-box;
- padding: 30rpx;
- position: relative;
- margin: 20rpx auto 30rpx;
- background-color: #fff;
- border: 4rpx solid #E6028D;
- border-radius: 30rpx;
- .btn {
- width: 569rpx;
- height: 77rpx;
- line-height: 77rpx;
- background: #D52E4C;
- border-radius: 39rpx;
- margin: 20rpx auto;
- text-align: center;
- color: #fff;
- font-size: 32rpx;
- }
- .orderTit {
- text {
- margin-left: 30rpx;
- color: dimgray;
- }
- }
- .formInput {
- .u-form-item {
- /deep/ .u-form-item--left__content__label {
- position: relative;
- padding-left: 30rpx;
- }
- /deep/.u-form-item--left__content__label::after {
- content: '*';
- position: absolute;
- left: 18rpx;
- top: 0;
- color: red;
- }
- }
- .remark {
- /deep/.u-form-item--left__content__label::after {
- display: none;
- }
- }
- }
- }
- }
- </style>
|